/* ============================================================
   ONZE — layout.css  (header, nav, hero, footer, grids)
   ============================================================ */

/* ---- announcement strip ---- */
.topbar{
  background:var(--graphite);
  color:var(--milk);
  font-size:.74rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  text-align:center;
  padding:.55rem 1rem;
}
.topbar strong{color:#e7c7cd;font-weight:600}

/* ---- header ---- */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(244,241,234,.86);
  backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  gap:1.5rem;min-height:74px;
}
.brand{
  font-family:var(--serif);
  font-size:1.7rem;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  display:flex;align-items:baseline;gap:.45rem;
}
.brand .dot{color:var(--accent)}
.brand small{
  font-family:var(--sans);font-size:.56rem;letter-spacing:.34em;
  color:var(--muted);text-transform:uppercase;font-weight:600;
}

.nav-links{display:flex;align-items:center;gap:2rem;list-style:none}
.nav-links a{
  font-size:.82rem;letter-spacing:.13em;text-transform:uppercase;font-weight:500;
  color:var(--graphite-2);position:relative;padding:.3rem 0;
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:-2px;height:1px;width:0;
  background:var(--accent);transition:width .35s ease;
}
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{width:100%}
.nav-links a[aria-current="page"]{color:var(--graphite)}

.nav-actions{display:flex;align-items:center;gap:1.1rem}
.cart-btn{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;
}
.cart-btn .count{
  background:var(--accent);color:var(--milk);
  min-width:20px;height:20px;border-radius:999px;
  display:grid;place-items:center;font-size:.66rem;padding:0 5px;
}
.menu-toggle{display:none;background:none;border:0;cursor:pointer;width:30px;height:22px;position:relative}
.menu-toggle span{position:absolute;left:0;right:0;height:1.6px;background:var(--graphite);transition:.3s}
.menu-toggle span:nth-child(1){top:0}
.menu-toggle span:nth-child(2){top:50%;transform:translateY(-50%)}
.menu-toggle span:nth-child(3){bottom:0}
body.menu-open .menu-toggle span:nth-child(1){top:50%;transform:translateY(-50%) rotate(45deg)}
body.menu-open .menu-toggle span:nth-child(2){opacity:0}
body.menu-open .menu-toggle span:nth-child(3){bottom:50%;transform:translateY(50%) rotate(-45deg)}

/* ---- hero ---- */
.hero{position:relative;border-bottom:1px solid var(--line)}
.hero-grid{
  display:grid;grid-template-columns:1.05fr 1fr;align-items:stretch;
  min-height:min(86vh,760px);
}
.hero-copy{
  display:flex;flex-direction:column;justify-content:center;gap:1.6rem;
  padding:clamp(2.5rem,6vw,5rem) clamp(1.4rem,5vw,4.5rem) clamp(2.5rem,6vw,5rem) 0;
}
.hero-copy h1{margin-block:.2rem}
.hero-copy h1 .em{font-style:italic;color:var(--accent)}
.hero-lede{max-width:46ch;font-size:1.06rem;color:var(--graphite-2)}
.hero-cta{display:flex;flex-wrap:wrap;gap:1rem;margin-top:.4rem}
.hero-media{position:relative;overflow:hidden;background:var(--milk-2)}
.hero-media img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero-media::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(27,27,26,.06),transparent 40%)}
.hero-badge{
  position:absolute;left:0;bottom:0;z-index:2;
  background:var(--graphite);color:var(--milk);
  padding:1rem 1.4rem;display:flex;flex-direction:column;gap:.15rem;
}
.hero-badge .num{font-family:var(--serif);font-size:1.7rem;line-height:1}
.hero-badge .lbl{font-size:.64rem;letter-spacing:.24em;text-transform:uppercase;color:#cfc9bd}

/* countdown */
.countdown{display:flex;gap:1.2rem;align-items:flex-end}
.countdown .unit{display:flex;flex-direction:column;align-items:flex-start}
.countdown .v{font-family:var(--serif);font-size:clamp(1.8rem,3vw,2.6rem);line-height:1;font-variant-numeric:tabular-nums}
.countdown .u{font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-top:.35rem}
.countdown .sep{font-family:var(--serif);font-size:1.6rem;color:var(--line);align-self:center}

/* ---- generic section head ---- */
.section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:clamp(2rem,4vw,3rem)}
.section-head .lead{max-width:52ch}
.section-head h2{margin-top:.4rem}

/* ---- product grid ---- */
.grid{display:grid;gap:clamp(1.4rem,2.4vw,2.4rem)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}
.grid--2{grid-template-columns:repeat(2,1fr)}

/* ---- usp band ---- */
.usp{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-block:1px solid var(--line)}
.usp .item{padding:2.2rem clamp(1rem,2vw,1.8rem);border-left:1px solid var(--line)}
.usp .item:first-child{border-left:0}
.usp h3{font-size:1.15rem;margin-bottom:.4rem}
.usp p{font-size:.9rem}
.usp .ico{width:30px;height:30px;color:var(--accent);margin-bottom:1rem}

/* ---- categories ---- */
.cats{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,2vw,2rem)}
.cat{
  position:relative;display:flex;align-items:flex-end;
  min-height:300px;padding:1.6rem;overflow:hidden;
  border:1px solid var(--line);background:var(--milk-2);color:var(--milk);
}
.cat img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .9s cubic-bezier(.2,.7,.2,1)}
.cat::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(20,20,19,.78),rgba(20,20,19,.05))}
.cat:hover img{transform:scale(1.06)}
.cat .label{position:relative;z-index:2}
.cat .label h3{color:var(--milk);font-size:1.5rem}
.cat .label span{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:#e7c7cd}

/* ---- split feature ---- */
.split{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:clamp(2rem,5vw,5rem)}
.split-media{aspect-ratio:4/5;overflow:hidden;background:var(--milk-2)}
.split-media img{width:100%;height:100%;object-fit:cover}
.split-copy{display:flex;flex-direction:column;gap:1.2rem}

/* ---- testimonials ---- */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.4rem,2.5vw,2.4rem)}
.quote{border-top:1px solid var(--graphite);padding-top:1.6rem}
.quote blockquote{font-family:var(--serif);font-size:1.35rem;line-height:1.4;font-style:italic;color:var(--graphite)}
.quote cite{display:block;margin-top:1.2rem;font-style:normal;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.stars{color:var(--accent);letter-spacing:.18em;margin-bottom:.8rem;font-size:.9rem}

/* ---- footer ---- */
.site-footer{background:var(--graphite);color:#cbc6ba;padding-top:clamp(3rem,6vw,5rem)}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:clamp(1.6rem,3vw,3rem);padding-bottom:3rem}
.site-footer .brand{color:var(--milk)}
.site-footer h4{font-family:var(--sans);font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;color:var(--milk);margin-bottom:1.1rem;font-weight:600}
.site-footer ul{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.site-footer a:hover{color:var(--milk)}
.site-footer p{color:#a9a499;font-size:.9rem}
.footer-bottom{border-top:1px solid var(--line-dark);padding-block:1.5rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.78rem;color:#8a857a}
.footer-bottom a{text-decoration:underline;text-underline-offset:3px}
.pay-row{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap;margin-top:1rem}
.pay-row span{border:1px solid var(--line-dark);border-radius:3px;padding:.25rem .55rem;font-size:.64rem;letter-spacing:.12em;color:#bdb8ad}

/* ============ responsive ============ */
@media (max-width:1024px){
  .grid--4{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .usp{grid-template-columns:repeat(2,1fr)}
  .usp .item:nth-child(3){border-left:0}
  .usp .item:nth-child(odd){border-left:0}
  .usp .item:nth-child(3),.usp .item:nth-child(4){border-top:1px solid var(--line)}
}
@media (max-width:880px){
  .hero-grid{grid-template-columns:1fr;min-height:0}
  .hero-copy{padding:clamp(2.2rem,7vw,3.2rem) 0;order:2}
  .hero-media{order:1;aspect-ratio:4/3}
  .split{grid-template-columns:1fr}
  .split-media{aspect-ratio:16/10;order:-1}
  .quotes{grid-template-columns:1fr}
  .cats{grid-template-columns:1fr 1fr}
}
@media (max-width:768px){
  .menu-toggle{display:block}
  .nav-links{
    position:fixed;inset:0 0 0 auto;width:min(82vw,360px);
    flex-direction:column;align-items:flex-start;justify-content:center;gap:1.6rem;
    background:var(--milk);padding:2.5rem;
    transform:translateX(100%);transition:transform .4s cubic-bezier(.2,.7,.2,1);
    box-shadow:var(--shadow-lift);z-index:55;
  }
  body.menu-open .nav-links{transform:none}
  .nav-links a{font-size:1.1rem}
  .nav-overlay{position:fixed;inset:0;background:rgba(20,20,19,.4);opacity:0;visibility:hidden;transition:.3s;z-index:50}
  body.menu-open .nav-overlay{opacity:1;visibility:visible}
  .grid--3,.grid--4{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr}
}
@media (max-width:520px){
  .grid--3,.grid--4,.grid--2{grid-template-columns:1fr 1fr}
  .cats{grid-template-columns:1fr}
  .usp{grid-template-columns:1fr}
  .usp .item{border-left:0 !important;border-top:1px solid var(--line)}
  .usp .item:first-child{border-top:0}
  .countdown{gap:.7rem}
  .brand small{display:none}
}
@media (max-width:380px){
  .grid--3,.grid--4{grid-template-columns:1fr}
}
