/* File: assets/css/pages/home.css */
/* Home: alternating sections white→soft→dark→white. BMW-square 4px. */

.home-page{display:block}

/* ─── Section wrappers ──────────────────────────────────── */
.section--white{background:var(--dag-sec-white);color:var(--dag-text)}
.section--soft{background:var(--dag-sec-soft);color:var(--dag-text)}
.section--dark{background:var(--dag-sec-dark);color:var(--dag-sec-dark-fg)}
.section--dark h1,.section--dark h2,.section--dark h3,.section--dark h4{color:var(--dag-sec-dark-fg)}
.section--dark a{color:var(--dag-sec-dark-fg)}

/* ─── Section head ──────────────────────────────────────── */
.section-head{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:var(--dag-gap);
  flex-wrap:wrap;
  margin-bottom:var(--dag-gap-lg);
  padding-top:var(--dag-section);
}
.section-head__eyebrow{
  font-size:12px;
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--dag-primary);
  flex:0 0 100%;
  margin-bottom:6px;
}
.section-head__title{
  font-family:var(--dag-font-display);
  font-weight:400;
  font-size:clamp(28px, 2rem + 1.4vw, 48px);
  letter-spacing:.02em;
  text-transform:uppercase;
  margin:0;
  line-height:1;
}
.section-head__link{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:13px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--dag-primary);
  text-decoration:none;
}
.section-head__link:hover{color:var(--dag-primary-active);text-decoration:underline}

.section-head--center{text-align:center;justify-content:center}
.section-head--center .section-head__eyebrow{text-align:center}
.section-head--inverse .section-head__eyebrow{color:var(--dag-accent)}
.section-head--inverse .section-head__title{color:var(--dag-sec-dark-fg)}

/* ═══════════ HERO ═══════════ */
.home-hero{padding-block:clamp(48px, 6vw, 96px)}

.home-hero__grid{
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);
  gap:clamp(24px, 4vw, 64px);
  align-items:center;
}

.home-hero__eyebrow{
  font-size:12px;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--dag-primary);
  margin-bottom:16px;
  padding-left:26px;
  position:relative;
}
.home-hero__eyebrow::before{
  content:"";
  position:absolute;
  left:0; top:50%;
  transform:translateY(-50%);
  width:18px;
  height:2px;
  background:var(--dag-primary);
}

.home-hero__title{
  font-family:var(--dag-font-display);
  font-weight:400;
  font-size:clamp(36px, 2.5rem + 2.6vw, 72px);
  line-height:.95;
  letter-spacing:.01em;
  text-transform:uppercase;
  color:var(--dag-secondary);
  margin:0 0 18px;
}
.home-hero__title-accent{
  display:block;
  color:var(--dag-primary);
}

.home-hero__lead{
  font-size:clamp(15px, .95rem + .25vw, 18px);
  color:var(--dag-text-2);
  max-width:48ch;
  margin:0 0 28px;
}

.home-hero__cta{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:32px;
}

.home-hero__stats{
  list-style:none;
  padding:24px 0 0;
  margin:0;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:8px;
  border-top:1px solid var(--dag-border);
}
.home-hero__stats li{display:flex;flex-direction:column;gap:4px}
.home-hero__stat-n{
  font-family:var(--dag-font-display);
  font-size:clamp(24px, 1.4rem + .6vw, 32px);
  letter-spacing:.02em;
  color:var(--dag-primary);
  line-height:1;
}
.home-hero__stat-k{
  font-size:11px;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--dag-muted);
}

.home-hero__media{
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
  border-radius:var(--dag-radius-sm);
  background:var(--dag-surface-3);
  box-shadow:var(--dag-shadow-md);
}
.home-hero__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.home-hero__media-ph{
  width:100%;height:100%;
  background:linear-gradient(135deg, var(--dag-surface-3), var(--dag-surface-2));
}

.home-hero__badge{
  position:absolute;
  right:16px;
  bottom:16px;
  background:var(--dag-secondary);
  color:var(--dag-sec-dark-fg);
  padding:10px 14px;
  border-radius:var(--dag-radius-sm);
  display:flex;
  flex-direction:column;
  line-height:1;
  box-shadow:var(--dag-shadow-md);
  border-left:3px solid var(--dag-accent);
}
.home-hero__badge-k{
  font-size:10px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--dag-accent);
  margin-bottom:4px;
}
.home-hero__badge-v{
  font-family:var(--dag-font-display);
  font-size:24px;
  letter-spacing:.04em;
}

@media (max-width: 900px){
  .home-hero__grid{grid-template-columns:1fr}
  .home-hero__media{order:-1; aspect-ratio:16/10}
}
@media (max-width: 520px){
  .home-hero__stats{grid-template-columns:1fr 1fr}
  .home-hero__stats li:nth-child(3){grid-column:1 / -1}
  .home-hero__cta .dag-btn{flex:1 1 auto}
}

/* ═══════════ FEATURED (carousel section) ═══════════ */
.home-featured{padding-bottom:clamp(48px, 5vw, 80px)}

.carousel{position:relative}
.carousel__viewport{overflow:hidden}
.carousel__track{
  display:flex;
  gap:18px;
  transition:transform .45s var(--ease-out);
  will-change:transform;
  touch-action:pan-y;
}
.carousel__slide{
  flex:0 0 calc((100% - 36px) / 3);
  min-width:0;
}

.carousel__arrow{
  position:absolute;
  top:calc(50% - 20px);
  transform:translateY(-50%);
  width:44px;
  height:44px;
  border-radius:var(--dag-radius-sm);
  border:1px solid var(--dag-border-strong);
  background:var(--dag-surface);
  color:var(--dag-secondary);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  box-shadow:var(--dag-shadow-sm);
  z-index:2;
  transition:background var(--anim-fast), color var(--anim-fast), border-color var(--anim-fast);
}
.carousel__arrow:hover{
  background:var(--dag-primary);
  color:var(--dag-primary-contrast);
  border-color:var(--dag-primary);
}
.carousel__arrow:disabled{opacity:.35;cursor:not-allowed}
.carousel__arrow--prev{left:-22px}
.carousel__arrow--next{right:-22px}

.carousel__dots{
  display:flex;
  justify-content:center;
  gap:8px;
  margin-top:20px;
}
.carousel__dot{
  width:20px; height:3px;
  border:0;
  background:var(--dag-border-strong);
  padding:0;
  cursor:pointer;
  transition:background var(--anim-fast), width var(--anim-fast);
}
.carousel__dot.is-active{background:var(--dag-primary); width:32px}

@media (max-width: 980px){.carousel__slide{flex:0 0 calc((100% - 18px) / 2)}}
@media (max-width: 640px){
  .carousel__slide{flex:0 0 100%}
  .carousel__arrow--prev{left:4px}
  .carousel__arrow--next{right:4px}
}

/* ═══════════ INV CARD ═══════════ */
.inv-card{margin:0;height:100%}

.inv-card__link{
  display:flex;
  flex-direction:column;
  height:100%;
  border:1px solid var(--dag-border);
  background:var(--dag-surface);
  text-decoration:none;
  color:inherit;
  transition:transform var(--dag-transition), box-shadow var(--dag-transition), border-color var(--dag-transition);
}

.inv-card__link:hover{
  transform:translateY(-3px);
  border-color:var(--dag-primary);
  box-shadow:var(--dag-shadow-md);
}

.inv-card__media{
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
  background:var(--dag-surface-3);
  flex:0 0 auto;
}
.inv-card__img{
  width:100%; height:100%;
  object-fit:cover;
  display:block;
  transition:transform .5s var(--ease-out);
}
.inv-card__link:hover .inv-card__img{transform:scale(1.04)}

.inv-card__badges{
  position:absolute;
  left:12px; top:12px;
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  z-index:2;
}

.inv-badge{
  display:inline-flex;
  align-items:center;
  padding:4px 10px;
  border-radius:0;
  font-size:11px;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  background:var(--dag-secondary);
  color:var(--dag-sec-dark-fg);
}
.inv-badge--sold{background:var(--dag-danger)}
.inv-badge--deal{background:var(--dag-primary);color:var(--dag-primary-contrast)}
.inv-badge--type{background:rgba(255,255,255,.92);color:var(--dag-secondary);border:1px solid var(--dag-border)}

.inv-card__body{
  padding:16px 18px 18px;
  display:flex;
  flex-direction:column;
  flex:1 1 auto;
}

.inv-card__eyebrow{
  font-size:11px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--dag-primary);
  margin-bottom:6px;
}

.inv-card__title{
  font-family:var(--dag-font-display);
  font-size:clamp(18px, 1.05rem + .3vw, 22px);
  font-weight:400;
  letter-spacing:.02em;
  text-transform:uppercase;
  color:var(--dag-secondary);
  margin:0 0 14px;
  line-height:1.1;
}

.inv-card__specs{
  list-style:none;
  padding:0;
  margin:0 0 16px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:8px;
  border-top:1px solid var(--dag-border);
  border-bottom:1px solid var(--dag-border);
  padding:10px 0;
}
.inv-card__specs li{display:flex;flex-direction:column;gap:2px;min-width:0}
.inv-card__spec-k{
  font-size:10px;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--dag-muted);
}
.inv-card__spec-v{
  font-weight:600;
  font-size:13px;
  color:var(--dag-text);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.inv-card__foot{
  margin-top:auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}

.inv-card__price{display:flex;flex-direction:column;line-height:1}
.inv-price--now{
  font-family:var(--dag-font-display);
  font-size:26px;
  letter-spacing:.02em;
  color:var(--dag-primary);
}
.inv-price--old{font-size:13px;color:var(--dag-muted);margin-top:2px}
.inv-price--sold{font-family:var(--dag-font-display);font-size:22px;color:var(--dag-danger)}
.inv-price--na{font-size:14px;color:var(--dag-muted)}

.inv-card__cta{
  display:inline-flex;
  align-items:center;
  gap:4px;
  font-size:12px;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--dag-primary);
  transition:transform var(--anim-fast) ease;
}
.inv-card__link:hover .inv-card__cta{transform:translateX(3px)}

/* ═══════════ WHY US (dark section) ═══════════ */
.home-why{padding-block:clamp(56px, 6vw, 96px)}

.home-why__grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:24px;
  margin-top:12px;
}
@media (max-width: 820px){.home-why__grid{grid-template-columns:1fr}}

.home-why__card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
  padding:28px 24px;
  border-left:3px solid var(--dag-accent);
}
.home-why__card h3{
  font-family:var(--dag-font-display);
  font-weight:400;
  letter-spacing:.04em;
  text-transform:uppercase;
  font-size:20px;
  margin:14px 0 10px;
  color:var(--dag-sec-dark-fg);
}
.home-why__card p{
  color:rgba(255,255,255,.72);
  margin:0;
  font-size:14.5px;
}
.home-why__ico{
  width:48px; height:48px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--dag-primary);
  color:var(--dag-primary-contrast);
}

.home-why__cta{
  display:flex;
  justify-content:center;
  gap:12px;
  flex-wrap:wrap;
  margin-top:40px;
}
.dag-btn--on-dark{
  border-color:rgba(255,255,255,.4);
  color:var(--dag-sec-dark-fg);
}
.dag-btn--on-dark:hover{
  background:var(--dag-sec-dark-fg);
  color:var(--dag-secondary);
  border-color:var(--dag-sec-dark-fg);
}

/* ═══════════ CONTACT STRIP ═══════════ */
.home-contact-strip{padding-block:clamp(40px, 5vw, 80px)}
.home-contact-strip__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  flex-wrap:wrap;
}
.home-contact-strip__title{
  font-family:var(--dag-font-display);
  font-weight:400;
  letter-spacing:.02em;
  text-transform:uppercase;
  font-size:clamp(24px, 1.5rem + 1vw, 36px);
  margin:0 0 4px;
  color:var(--dag-secondary);
}
.home-contact-strip__lead{
  color:var(--dag-muted);
  margin:0;
  font-size:15px;
}
.home-contact-strip__cta{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
