/* ─── Design Tokens ─── */
:root{
  --header-h:90px;
  --hero-h-mobile:calc(100vh - var(--header-h));
  --hero-h-desktop:calc(100vh - var(--header-h));
  --hero-h-max:calc(100vh - var(--header-h));
  --hero-bg:#f7f9fc;
  --hero-surface:#ffffff;
  --hero-border:#e2e8f0;
  --hero-text:#0f172a;
  --hero-muted:#64748b;
}

/* ── Global ── */
body,html{ overflow-x:hidden; }
.object-fit-cover{ object-fit:cover; }
.home-main{
  flex:1;
  display:flex;
  flex-direction:column;
  width:100%;
  min-width:0;
}
.hero,
.hero *{
  box-sizing:border-box;
}

/* ── Hero Layout ── */
.hero{
  background:linear-gradient(180deg,#f8fafc 0%,#eef2f8 100%);
  padding:clamp(28px,5vw,64px) 20px 40px;
  flex:1;
  display:flex;
  align-items:center;
}

.hero-inner{
  max-width:1200px;
  width:100%;
  margin:0 auto;
  display:grid;
  grid-template-columns:minmax(280px,1fr) minmax(280px,1.1fr);
  gap:32px;
  align-items:center;
  min-width:0;
}

.hero-content{
  display:flex;
  flex-direction:column;
  gap:18px;
  min-width:0;
}

.hero-tag{
  font-size:11px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:#94a3b8;
}

.hero-title{
  margin:0;
  font-size:clamp(1.8rem,2.8vw,2.6rem);
  font-weight:700;
  color:var(--hero-text);
  letter-spacing:-0.02em;
}

.hero-subtitle{
  margin:0;
  color:var(--hero-muted);
  font-size:1rem;
}

/* ── Hero Buttons ── */
.overlay-grid{
  display:grid;
  gap:12px;
  grid-template-columns:repeat(2,minmax(150px,1fr));
  width:100%;
  min-width:0;
}

.hero-actions{
  margin-top:6px;
}

.hero-btn{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:12px 14px;
  border-radius:10px;
  border:1px solid var(--hero-border);
  background:var(--hero-surface);
  color:var(--hero-text);
  font-size:.98rem;
  font-weight:600;
  text-decoration:none;
  transition:transform .18s ease, border-color .18s ease, background .18s ease;
}

.hero-btn i{
  color:var(--btn-accent);
  font-size:1rem;
}

.hero-btn:hover{
  transform:translateY(-2px);
  border-color:rgba(15,23,42,0.2);
  background:#f8fafc;
}

.hero-btn:active{
  transform:translateY(0);
}

.hero-btn--primary{ --btn-accent:#3b82f6; }
.hero-btn--green{ --btn-accent:#22c55e; }
.hero-btn--amber{ --btn-accent:#f59e0b; }
.hero-btn--cyan{ --btn-accent:#06b6d4; }
.hero-btn--rose{ --btn-accent:#f43f5e; }
.hero-btn--slate{ --btn-accent:#64748b; }

/* ── Slider ── */
.hero-media{
  display:flex;
  justify-content:center;
  min-width:0;
}

#heroSlider{
  width:100%;
  max-width:100%;
  height:clamp(320px,50vw,520px);
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--hero-border);
  background:#fff;
  min-width:0;
}

#heroSlider .swiper-slide{
  height:100%;
}

#heroSlider img{
  filter:saturate(1.02);
  max-width:100%;
}

#heroSlider .swiper-wrapper{
  width:100%;
}

#heroSlider .swiper-button-prev,
#heroSlider .swiper-button-next{
  color:#fff;
  width:38px;
  height:38px;
  border-radius:999px;
  background:rgba(15,23,42,0.4);
  opacity:.7;
  transition:opacity .2s ease, transform .2s ease;
}

#heroSlider .swiper-button-prev:after,
#heroSlider .swiper-button-next:after{
  font-size:16px;
}

#heroSlider .swiper-button-prev:hover,
#heroSlider .swiper-button-next:hover{
  opacity:1;
  transform:translateY(-1px);
}

#heroSlider .swiper-pagination-bullet{
  background:#fff;
  opacity:.55;
}

#heroSlider .swiper-pagination-bullet-active{
  opacity:1;
}

/* ── Responsive ── */
@media (max-width: 992px){
  .hero-inner{
    grid-template-columns:1fr;
    gap:24px;
  }
  .hero-media{
    order:-1;
  }
  .overlay-grid{
    grid-template-columns:repeat(2,minmax(150px,1fr));
  }
}

@media (max-width: 768px){
  .hero-content{
    text-align:center;
    align-items:center;
  }
  .hero-actions{
    max-width:520px;
    margin:0 auto;
  }
}

@media (max-width: 576px){
  .hero{
    padding:24px 16px 32px;
  }
  .hero-title{
    font-size:1.6rem;
  }
  .hero-subtitle{
    font-size:.95rem;
  }
  .overlay-grid{
    grid-template-columns:repeat(2,1fr);
    gap:10px;
  }
  .hero-btn{
    font-size:.9rem;
    padding:10px 12px;
  }
  #heroSlider{
    height:auto;
    aspect-ratio:16 / 10;
    max-height:360px;
    border-radius:14px;
  }
  #heroSlider .swiper-button-prev,
  #heroSlider .swiper-button-next{
    display:none;
  }
}

@media (max-width: 420px){
  .overlay-grid{
    grid-template-columns:1fr;
  }
  .hero-btn{
    justify-content:flex-start;
    padding:12px 14px;
  }
}
