/* ============================================================
   STORICO CERAMICA — Editorial Architectural Luxury
   ============================================================ */

:root{
  /* palette — pulled from the wood-plank tiles */
  --bone:        #ece2d2;   /* warm paper */
  --bone-2:      #e3d6c2;
  --paper:       #f4ecdf;
  --ink:         #15100b;   /* espresso near-black */
  --ink-2:       #1f1810;
  --walnut:      #5a3d27;
  --honey:       #c79a52;   /* the single sharp accent */
  --honey-deep:  #a9772f;
  --ash:         #8e857a;
  --line:        rgba(21,16,11,.14);
  --line-light:  rgba(236,226,210,.16);

  --fg:          var(--ink);
  --bg:          var(--bone);

  --serif: "Fraunces", Georgia, serif;
  --sans:  "Hanken Grotesk", system-ui, sans-serif;
  --mono:  "JetBrains Mono", ui-monospace, monospace;

  --pad: clamp(20px, 5vw, 84px);
  --maxw: 1480px;
  --ease: cubic-bezier(.16,1,.3,1);
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; }
html.lenis,html.lenis body{ height:auto; }
.lenis.lenis-smooth{ scroll-behavior:auto !important; }
.lenis.lenis-stopped{ overflow:hidden; }

body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--fg);
  font-weight:400;
  line-height:1.55;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
em{ font-style:italic; }
.mono{ font-family:var(--mono); font-weight:500; letter-spacing:.04em; }

/* ---------- grain + progress ---------- */
.grain{
  position:fixed; inset:0; z-index:9000; pointer-events:none; opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}
.scroll-progress{
  position:fixed; top:0; left:0; height:2px; width:0%; z-index:9500;
  background:linear-gradient(90deg,var(--honey),var(--honey-deep));
}

/* ---------- loader ---------- */
.loader{
  position:fixed; inset:0; z-index:10000; background:var(--ink);
  display:grid; place-items:center; transition:opacity .7s var(--ease), visibility .7s;
}
.loader.done{ opacity:0; visibility:hidden; }
.loader__inner{ text-align:center; color:var(--bone); width:min(280px,70vw); }
.loader__mark{ font-family:var(--serif); font-size:64px; font-weight:300; color:var(--honey); line-height:1; }
.loader__bar{ height:2px; background:rgba(236,226,210,.16); margin:22px 0 12px; overflow:hidden; }
.loader__bar span{ display:block; height:100%; width:0%; background:var(--honey); transition:width .3s linear; }
.loader__txt{ font-size:10px; letter-spacing:.3em; opacity:.55; }

/* ---------- nav ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:1000;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--pad);
  transition:background .5s var(--ease), padding .5s var(--ease), box-shadow .5s var(--ease);
}
.nav.solid{
  background:rgba(236,226,210,.86);
  backdrop-filter:blur(14px) saturate(1.2);
  -webkit-backdrop-filter:blur(14px) saturate(1.2);
  padding:12px var(--pad);
  box-shadow:0 1px 0 var(--line);
}
.nav__brand{ display:flex; align-items:center; gap:12px; }
.nav__mark{
  font-family:var(--serif); font-weight:400; font-size:24px; color:var(--honey);
  width:38px; height:38px; display:grid; place-items:center;
  border:1px solid currentColor; border-radius:50%; line-height:1;
}
.nav__name{ font-family:var(--serif); font-size:19px; font-weight:500; letter-spacing:.01em; }
.nav__name em{ font-weight:300; opacity:.65; font-style:italic; }
.nav__usa{ font-family:var(--mono); font-weight:600; font-style:normal; font-size:.62em;
  letter-spacing:.06em; color:var(--honey); vertical-align:top; position:relative; top:.18em; margin-left:.12em; }
.nav.on-dark .nav__name,.nav.on-dark .nav__links a{ color:var(--bone); }
.nav__links{ display:flex; gap:34px; }
.nav__links a{ font-size:13.5px; font-weight:500; letter-spacing:.02em; position:relative; opacity:.78; transition:opacity .3s; }
.nav__links a::after{ content:""; position:absolute; left:0; bottom:-5px; height:1px; width:0; background:var(--honey); transition:width .35s var(--ease); }
.nav__links a:hover{ opacity:1; } .nav__links a:hover::after{ width:100%; }
.nav__cta{
  font-size:13px; font-weight:600; letter-spacing:.02em; padding:11px 20px;
  border:1px solid var(--ink); border-radius:40px; transition:.35s var(--ease);
}
.nav__cta:hover{ background:var(--ink); color:var(--bone); }
.nav.on-dark .nav__cta{ border-color:var(--bone); color:var(--bone); }
.nav.on-dark .nav__cta:hover{ background:var(--honey); border-color:var(--honey); color:var(--ink); }
.nav__burger{ display:none; background:none; border:0; cursor:pointer; width:34px; height:24px; position:relative; }
.nav__burger span{ position:absolute; left:0; height:2px; width:100%; background:currentColor; transition:.4s var(--ease); }
.nav__burger span:nth-child(1){ top:4px; } .nav__burger span:nth-child(2){ bottom:4px; }
.nav.on-dark .nav__burger{ color:var(--bone); }
body.menu-open .nav__burger span:nth-child(1){ top:11px; transform:rotate(45deg); }
body.menu-open .nav__burger span:nth-child(2){ bottom:11px; transform:rotate(-45deg); }

/* ---------- buttons ---------- */
.btn{ display:inline-flex; align-items:center; gap:9px; font-weight:600; font-size:14px; letter-spacing:.01em;
  padding:15px 26px; border-radius:44px; transition:.4s var(--ease); cursor:pointer; border:1px solid transparent; }
.btn--solid{ background:var(--honey); color:var(--ink); }
.btn--solid:hover{ background:var(--bone); transform:translateY(-2px); box-shadow:0 14px 34px -12px rgba(0,0,0,.5); }
.btn--ghost{ border-color:currentColor; }
.btn--ghost:hover{ background:rgba(236,226,210,.1); transform:translateY(-2px); }
.btn--full{ width:100%; justify-content:center; padding:17px; }

/* ---------- shared headings ---------- */
.kicker{ display:inline-block; font-size:11px; letter-spacing:.28em; color:var(--honey-deep); margin-bottom:22px; }
.nav.on-dark + *, section{ }
h2{ font-family:var(--serif); font-weight:340; line-height:1.02; letter-spacing:-.015em;
  font-size:clamp(2rem,5.4vw,4.6rem); }
h2 em{ color:var(--honey-deep); }

/* reveal helpers (JS toggles .in) */
.reveal,.reveal-up{ opacity:0; }
.reveal{ transform:translateY(8px); transition:opacity .9s var(--ease),transform .9s var(--ease); }
.reveal-up{ transform:translateY(28px); transition:opacity 1s var(--ease),transform 1s var(--ease); }
.reveal.in,.reveal-up.in{ opacity:1; transform:none; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; min-height:100svh; display:flex; flex-direction:column; justify-content:center;
  padding:0 var(--pad); color:var(--bone); overflow:hidden; background:var(--ink); }
.hero__wall{ position:absolute; inset:-14% -2% -2% -2%; z-index:0; display:grid;
  grid-template-columns:repeat(3,1fr); gap:10px; transform:scale(1.05); will-change:transform; }
.hero__wall .col{ display:flex; flex-direction:column; gap:10px; }
.hero__wall .plank{ border-radius:3px; background-size:cover; background-position:center; flex:1;
  min-height:120px; filter:saturate(.96) brightness(.82); }
.hero__veil{ position:absolute; inset:0; z-index:1;
  background:
    radial-gradient(120% 90% at 22% 40%, rgba(21,16,11,.30) 0%, rgba(21,16,11,.74) 55%, rgba(21,16,11,.94) 100%),
    linear-gradient(180deg, rgba(21,16,11,.55) 0%, rgba(21,16,11,.15) 40%, rgba(21,16,11,.85) 100%); }
.hero__content{ position:relative; z-index:2; max-width:1000px; }
.hero__eyebrow{ font-size:11px; letter-spacing:.3em; color:var(--honey); margin-bottom:26px; }
.hero__title{ font-family:var(--serif); font-weight:300; letter-spacing:-.02em;
  font-size:clamp(2.9rem,9.4vw,8.4rem); line-height:.98; }
.hero__title em{ font-style:italic; color:var(--honey); }
.hero__title .line{ display:block; overflow:hidden; }
.hero__title .line>span{ display:block; transform:translateY(110%); }
.hero__sub{ max-width:560px; margin:30px 0 36px; font-size:clamp(1rem,1.5vw,1.2rem);
  color:rgba(236,226,210,.82); font-weight:300; line-height:1.6; }
.hero__actions{ display:flex; gap:16px; flex-wrap:wrap; }
.hero__scroll{ position:absolute; left:var(--pad); bottom:30px; z-index:2; font-size:10px;
  letter-spacing:.3em; color:rgba(236,226,210,.6); display:flex; align-items:center; gap:10px; }
.hero__scroll span{ width:40px; height:1px; background:rgba(236,226,210,.4); position:relative; overflow:hidden; }
.hero__scroll span::after{ content:""; position:absolute; inset:0; background:var(--honey); transform:translateX(-100%); animation:scrollline 2.2s var(--ease) infinite; }
@keyframes scrollline{ 0%{transform:translateX(-100%)} 60%,100%{transform:translateX(100%)} }
.hero__meta{ position:absolute; right:var(--pad); bottom:30px; z-index:2; display:flex; gap:22px;
  font-size:10px; letter-spacing:.18em; color:rgba(236,226,210,.55); }
.hero__meta span{ position:relative; }
.hero__meta span+span::before{ content:"·"; position:absolute; left:-13px; }

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{ background:var(--ink); overflow:hidden; padding:14px 0; border-top:1px solid var(--line-light); }
.marquee__track{ display:flex; gap:60px; white-space:nowrap; width:max-content; will-change:transform; }
.marquee__track .m-item{ font-family:var(--serif); font-style:italic; font-size:clamp(1.3rem,3vw,2.1rem);
  color:rgba(236,226,210,.5); display:flex; align-items:center; gap:60px; }
.marquee__track .m-item::after{ content:"✦"; color:var(--honey); font-size:.6em; font-style:normal; }

/* ============================================================
   LEGACY
   ============================================================ */
.legacy{ padding:clamp(80px,12vw,170px) var(--pad); max-width:var(--maxw); margin:0 auto; }
.legacy__grid{ display:grid; grid-template-columns:1.1fr 1fr; gap:clamp(30px,6vw,90px); align-items:start; }
.legacy__lead h2{ margin-top:6px; }
.legacy__body{ padding-top:8px; }
.legacy__body p{ font-size:clamp(1rem,1.35vw,1.2rem); color:#3a2f24; max-width:46ch; }
.legacy__body p+p{ margin-top:22px; }
.legacy__body strong{ font-weight:600; color:var(--ink); }
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; margin-top:clamp(60px,9vw,120px);
  background:var(--line); border:1px solid var(--line); }
.stat{ background:var(--bone); padding:34px 28px; }
.stat__num{ font-size:clamp(2.6rem,5vw,4rem); font-weight:600; color:var(--ink); line-height:1; letter-spacing:-.02em; }
.stat__suf{ font-family:var(--serif); font-style:italic; font-size:1.4rem; color:var(--honey-deep); margin-left:4px; }
.stat p{ font-size:13.5px; color:#5a4d3e; margin-top:14px; max-width:20ch; line-height:1.4; }

/* ============================================================
   STATEMENT (pinned, word reveal)
   ============================================================ */
.statement{ position:relative; background:var(--ink); color:var(--bone); overflow:hidden; }
.statement__bg{ position:absolute; inset:0; opacity:.16; background-size:cover; background-position:center;
  filter:saturate(.4) brightness(.7); will-change:transform; }
.statement__inner{ position:relative; z-index:1; min-height:100svh; display:grid; place-items:center;
  padding:0 var(--pad); max-width:1400px; margin:0 auto; }
.statement__text{ font-family:var(--serif); font-weight:300; letter-spacing:-.01em;
  font-size:clamp(1.7rem,4.6vw,4.1rem); line-height:1.18; text-align:center; }
.statement__text .w{ display:inline-block; opacity:.16; transition:opacity .5s var(--ease); }
.statement__text .w.lit{ opacity:1; }

/* ============================================================
   COLLECTION — horizontal scroll
   ============================================================ */
.collection{ background:var(--paper); padding:clamp(70px,10vw,130px) 0 0; overflow:hidden; }
.collection__head{ padding:0 var(--pad); max-width:var(--maxw); margin:0 auto 50px; }
.collection__head h2{ margin:4px 0 16px; }
.collection__head p{ max-width:52ch; color:#4a3d2e; font-size:1.05rem; }
.collection__viewport{ overflow:hidden; }
.collection__track{ display:flex; gap:28px; padding:20px var(--pad) 70px; width:max-content; will-change:transform; }
.dcard{ width:clamp(280px,42vw,520px); flex:0 0 auto; }
.dcard__frame{ position:relative; border-radius:6px; overflow:hidden; background:var(--ink);
  box-shadow:0 30px 60px -30px rgba(0,0,0,.5); }
.dcard__hero{ aspect-ratio:3/2.05; background-size:cover; background-position:center; transition:transform 1.1s var(--ease); }
.dcard:hover .dcard__hero{ transform:scale(1.05); }
.dcard__tag{ position:absolute; top:16px; left:16px; z-index:2; background:rgba(21,16,11,.6);
  backdrop-filter:blur(6px); color:var(--bone); font-size:10px; letter-spacing:.15em; padding:6px 11px; border-radius:20px; }
.dcard__strip{ position:absolute; left:0; right:0; bottom:0; z-index:2; display:flex; gap:5px; padding:12px;
  background:linear-gradient(180deg,transparent,rgba(21,16,11,.55)); }
.dcard__sw{ flex:1; height:34px; border-radius:3px; background-size:cover; background-position:center;
  cursor:pointer; outline:1.5px solid transparent; transition:.3s var(--ease); }
.dcard__sw:hover{ transform:translateY(-5px); outline-color:var(--honey); }
.dcard__meta{ display:flex; justify-content:space-between; align-items:baseline; padding:18px 4px 0; }
.dcard__name{ font-family:var(--serif); font-size:1.5rem; font-weight:400; }
.dcard__name em{ display:block; font-size:.8rem; font-style:normal; font-family:var(--mono);
  letter-spacing:.12em; color:var(--honey-deep); margin-top:6px; }
.dcard__code{ font-family:var(--mono); font-size:12px; color:#7a6a55; letter-spacing:.06em; }

/* ============================================================
   CATALOGUE GRID
   ============================================================ */
.catalogue{ padding:clamp(80px,11vw,150px) var(--pad); max-width:var(--maxw); margin:0 auto; }
.catalogue__head{ display:flex; justify-content:space-between; align-items:flex-end; gap:40px; flex-wrap:wrap; }
.catalogue__head h2{ margin-top:4px; }
.catalogue__note{ max-width:34ch; color:#4a3d2e; font-size:.98rem; }
.catalogue__note span{ font-family:var(--mono); color:var(--honey-deep); }
.filters{ display:flex; flex-wrap:wrap; gap:10px; align-items:center; margin:42px 0 34px; }
.filter{ font-family:var(--sans); font-size:13px; font-weight:500; padding:9px 17px; border-radius:30px;
  border:1px solid var(--line); background:transparent; color:#4a3d2e; cursor:pointer; transition:.3s var(--ease); }
.filter:hover{ border-color:var(--ink); color:var(--ink); }
.filter.is-active{ background:var(--ink); border-color:var(--ink); color:var(--bone); }
.filters__sep{ width:1px; height:22px; background:var(--line); margin:0 6px; }
.grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.cell{ position:relative; border-radius:4px; overflow:hidden; aspect-ratio:3/1; cursor:pointer;
  background:#d8cab4; opacity:0; transform:translateY(20px) scale(.98); transition:opacity .6s var(--ease),transform .6s var(--ease); }
.cell.in{ opacity:1; transform:none; }
.cell img{ width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease); }
.cell:hover img{ transform:scale(1.08); }
.cell__info{ position:absolute; inset:0; display:flex; align-items:flex-end; justify-content:space-between;
  padding:10px 12px; opacity:0; transition:opacity .35s var(--ease);
  background:linear-gradient(0deg,rgba(21,16,11,.62),transparent 60%); }
.cell:hover .cell__info{ opacity:1; }
.cell__code{ font-family:var(--mono); font-size:11px; color:var(--bone); letter-spacing:.06em; }
.cell__hex{ font-family:var(--mono); font-size:10px; color:rgba(236,226,210,.75); }
.cell.hidden{ display:none; }
.cat-empty{ grid-column:1/-1; text-align:center; padding:50px; color:#7a6a55; font-style:italic; font-family:var(--serif); }

/* ============================================================
   SPACES / APPLICATIONS
   ============================================================ */
.spaces{ background:var(--ink); color:var(--bone); padding:clamp(80px,12vw,160px) var(--pad); }
.spaces__head{ max-width:var(--maxw); margin:0 auto 60px; }
.spaces__head h2{ max-width:18ch; }
.spaces__list{ max-width:var(--maxw); margin:0 auto; border-top:1px solid var(--line-light); }
.srow{ display:grid; grid-template-columns:80px 1fr auto; gap:30px; align-items:center;
  padding:30px 0; border-bottom:1px solid var(--line-light); position:relative; cursor:default; }
.srow__num{ font-family:var(--mono); font-size:13px; color:var(--honey); }
.srow__name{ font-family:var(--serif); font-size:clamp(1.6rem,4vw,2.9rem); font-weight:340; transition:.4s var(--ease); }
.srow__desc{ font-size:14px; color:rgba(236,226,210,.6); max-width:34ch; text-align:right; }
.srow__thumb{ position:fixed; width:230px; height:150px; border-radius:6px; background-size:cover; background-position:center;
  pointer-events:none; opacity:0; z-index:50; transform:translate(-50%,-50%) scale(.85); transition:opacity .35s var(--ease),transform .5s var(--ease);
  box-shadow:0 30px 60px -20px rgba(0,0,0,.6); }
.srow:hover .srow__name{ color:var(--honey); transform:translateX(14px); }

/* ============================================================
   FORMATS
   ============================================================ */
.formats{ background:var(--bone-2); padding:clamp(80px,11vw,150px) var(--pad); }
.formats__inner{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,90px); align-items:center; }
.formats__copy h2{ margin:4px 0 22px; }
.formats__copy p{ max-width:42ch; color:#4a3d2e; font-size:1.08rem; }
.formats__sizes{ list-style:none; margin-top:34px; border-top:1px solid var(--line); }
.formats__sizes li{ display:flex; justify-content:space-between; align-items:center; padding:16px 0;
  border-bottom:1px solid var(--line); font-size:15px; }
.formats__sizes li span:last-child{ color:#7a6a55; font-size:12px; }
.formats__visual{ aspect-ratio:4/5; border-radius:8px; overflow:hidden; position:relative; background:var(--ink);
  box-shadow:0 40px 80px -40px rgba(0,0,0,.5); display:grid; grid-template-columns:1fr 1fr; grid-template-rows:repeat(3,1fr); gap:6px; padding:6px; }
.formats__visual .fv{ background-size:cover; background-position:center; border-radius:3px; will-change:transform; }
.formats__visual .fv:nth-child(1){ grid-column:1/3; }

/* ============================================================
   EXPORT
   ============================================================ */
.export{ padding:clamp(80px,11vw,150px) var(--pad); max-width:var(--maxw); margin:0 auto; }
.export__head{ margin-bottom:60px; }
.export__head h2{ margin-top:4px; }
.export__cols{ display:grid; grid-template-columns:1.2fr 1fr; gap:clamp(40px,7vw,100px); align-items:start; }
.export__why{ display:grid; gap:1px; background:var(--line); border:1px solid var(--line); }
.wrow{ background:var(--bone); padding:26px 28px; display:flex; gap:22px; align-items:flex-start; }
.wrow__n{ font-family:var(--mono); font-size:12px; color:var(--honey-deep); padding-top:5px; }
.wrow__t{ font-family:var(--serif); font-size:1.35rem; font-weight:400; margin-bottom:6px; }
.wrow__d{ font-size:14px; color:#5a4d3e; max-width:40ch; }
.export__map h3{ font-size:11px; letter-spacing:.2em; color:var(--honey-deep); font-weight:500; margin-bottom:20px; }
.countries{ display:flex; flex-wrap:wrap; gap:8px; margin-bottom:40px; }
.countries span{ font-size:12.5px; padding:6px 13px; border:1px solid var(--line); border-radius:30px; color:#4a3d2e; transition:.3s var(--ease); }
.countries span.usa{ background:var(--honey); border-color:var(--honey); color:var(--ink); font-weight:600; }
.countries span:hover{ border-color:var(--ink); }
.export__route{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; font-size:11px; color:#4a3d2e; }
.route-line{ flex:1; min-width:30px; height:1px; background:var(--line); position:relative; }
.route-line i{ position:absolute; left:0; top:-2px; width:5px; height:5px; border-radius:50%; background:var(--honey); }
.spec-sheet{ margin-top:46px; border:1px solid var(--line); border-radius:8px; padding:26px 28px; background:linear-gradient(180deg,rgba(255,255,255,.18),transparent); }
.spec-sheet h4{ font-size:10px; letter-spacing:.2em; color:var(--honey-deep); margin-bottom:16px; font-weight:500; }
.spec-sheet dl{ display:grid; gap:0; }
.spec-sheet dl>div{ display:flex; justify-content:space-between; align-items:baseline; gap:16px; padding:11px 0; border-top:1px solid var(--line); }
.spec-sheet dl>div:first-child{ border-top:0; }
.spec-sheet dt{ font-size:13px; color:#7a6a55; }
.spec-sheet dd{ font-family:var(--serif); font-size:1.02rem; color:var(--ink); text-align:right; }

/* ============================================================
   CONTACT
   ============================================================ */
.contact{ position:relative; background:var(--ink); color:var(--bone); padding:clamp(80px,12vw,160px) var(--pad); overflow:hidden; }
.contact__bg{ position:absolute; inset:0; opacity:.1; background-size:cover; background-position:center; filter:saturate(.3); }
.contact__inner{ position:relative; z-index:1; max-width:var(--maxw); margin:0 auto;
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,7vw,110px); align-items:start; }
.contact__lead h2{ font-size:clamp(2.2rem,5.5vw,4.4rem); margin:6px 0 24px; }
.contact__lead>p{ color:rgba(236,226,210,.75); max-width:44ch; font-weight:300; font-size:1.08rem; }
.contact__cards{ display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:44px; }
.ccard{ border:1px solid var(--line-light); border-radius:8px; padding:22px; display:flex; flex-direction:column; gap:7px; }
.ccard span.mono{ font-size:10px; letter-spacing:.2em; color:var(--honey); }
.ccard strong{ font-family:var(--serif); font-size:1.3rem; font-weight:400; }
.ccard a,.ccard span:not(.mono){ font-size:13.5px; color:rgba(236,226,210,.72); transition:color .3s; }
.ccard a:hover{ color:var(--honey); }
.placeholder{ color:var(--honey); font-style:italic; font-size:.8em; opacity:.7; }
.placeholder-link{ color:rgba(236,226,210,.5)!important; }

.contact__form{ display:grid; gap:16px; }
.field{ display:flex; flex-direction:column; gap:7px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field label{ font-family:var(--mono); font-size:10.5px; letter-spacing:.14em; color:rgba(236,226,210,.55); text-transform:uppercase; }
.field input,.field select,.field textarea{
  background:transparent; border:0; border-bottom:1px solid var(--line-light); color:var(--bone);
  font-family:var(--sans); font-size:15px; padding:10px 2px; transition:border-color .3s; resize:none; }
.field select{ color:rgba(236,226,210,.9); }
.field select option{ background:var(--ink); }
.field input:focus,.field select:focus,.field textarea:focus{ outline:0; border-color:var(--honey); }
.field input::placeholder,.field textarea::placeholder{ color:rgba(236,226,210,.3); }
.form-note{ font-size:14px; color:var(--honey); font-family:var(--serif); font-style:italic; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--ink-2); color:var(--bone); padding:clamp(60px,8vw,90px) var(--pad) 30px; border-top:1px solid var(--line-light); }
.footer__top{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:1.3fr 2fr; gap:50px; padding-bottom:60px; border-bottom:1px solid var(--line-light); }
.footer__brand{ display:flex; gap:18px; align-items:flex-start; }
.footer__tag{ font-family:var(--serif); font-size:1.2rem; font-weight:300; line-height:1.4; color:rgba(236,226,210,.8); }
.footer__cols{ display:grid; grid-template-columns:repeat(3,1fr); gap:30px; }
.footer__cols>div{ display:flex; flex-direction:column; gap:13px; }
.footer__cols span.mono{ font-size:10px; letter-spacing:.2em; color:var(--honey); margin-bottom:4px; }
.footer__cols a{ font-size:14px; color:rgba(236,226,210,.7); transition:color .3s; }
.footer__cols a:hover{ color:var(--honey); }
.footer__base{ max-width:var(--maxw); margin:30px auto 0; display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.footer__base span{ font-size:10px; letter-spacing:.14em; color:rgba(236,226,210,.4); }

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lightbox{ position:fixed; inset:0; z-index:9999; background:rgba(15,11,7,.94); backdrop-filter:blur(8px);
  display:flex; align-items:center; justify-content:center; gap:20px; opacity:0; visibility:hidden; transition:opacity .4s var(--ease),visibility .4s; }
.lightbox.open{ opacity:1; visibility:visible; }
.lightbox__fig{ max-width:min(1100px,86vw); text-align:center; }
.lightbox__fig img{ width:100%; border-radius:6px; box-shadow:0 40px 100px -30px rgba(0,0,0,.8); }
.lightbox__fig figcaption{ color:var(--bone); margin-top:18px; font-size:12px; letter-spacing:.1em; }
.lightbox__fig figcaption b{ color:var(--honey); }
.lightbox__close{ position:absolute; top:22px; right:30px; background:none; border:0; color:var(--bone); font-size:38px; cursor:pointer; line-height:1; opacity:.7; transition:opacity .3s; }
.lightbox__close:hover{ opacity:1; }
.lightbox__nav{ background:rgba(236,226,210,.08); border:1px solid var(--line-light); color:var(--bone); width:54px; height:54px; border-radius:50%; font-size:26px; cursor:pointer; flex:0 0 auto; transition:.3s var(--ease); }
.lightbox__nav:hover{ background:var(--honey); color:var(--ink); border-color:var(--honey); }

/* ============================================================
   MOBILE NAV PANEL
   ============================================================ */
.mobile-menu{ position:fixed; inset:0; z-index:999; background:var(--ink); display:flex; flex-direction:column;
  justify-content:center; gap:8px; padding:var(--pad); transform:translateY(-100%); transition:transform .6s var(--ease); }
body.menu-open .mobile-menu{ transform:translateY(0); }
.mobile-menu a{ font-family:var(--serif); font-size:2.4rem; font-weight:300; color:var(--bone); transition:color .3s; }
.mobile-menu a:hover{ color:var(--honey); }
.mobile-menu .mm-cta{ margin-top:30px; font-family:var(--sans); font-size:1rem; color:var(--honey); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .legacy__grid,.formats__inner,.export__cols,.contact__inner{ grid-template-columns:1fr; }
  .stats{ grid-template-columns:repeat(2,1fr); }
  .grid{ grid-template-columns:repeat(3,1fr); }
  .footer__top{ grid-template-columns:1fr; gap:36px; }
}
@media (max-width:768px){
  .nav__links,.nav__cta{ display:none; }
  .nav__burger{ display:block; }
  .hero__meta{ display:none; }
  .hero__wall{ grid-template-columns:repeat(2,1fr); }
  .grid{ grid-template-columns:repeat(2,1fr); gap:10px; }
  .catalogue__head{ align-items:flex-start; }
  .srow{ grid-template-columns:44px 1fr; gap:16px; }
  .srow__desc{ display:none; }
  .srow:hover .srow__name{ transform:none; }
  .contact__cards{ grid-template-columns:1fr; }
  .footer__cols{ grid-template-columns:1fr 1fr; }
  .footer__base{ justify-content:flex-start; }
  .dcard{ width:78vw; }
  .lightbox__nav{ width:42px; height:42px; }
}
@media (max-width:480px){
  .stats{ grid-template-columns:1fr; }
  .field-row{ grid-template-columns:1fr; }
}

/* reduced motion */
@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.01ms!important; animation-iteration-count:1!important; transition-duration:.01ms!important; }
  .reveal,.reveal-up,.cell{ opacity:1!important; transform:none!important; }
  .hero__title .line>span{ transform:none!important; }
}

/* ============================================================
   REDESIGN v2 — COLLECTIONS + EXPLORE + ENHANCED LIGHTBOX
   ============================================================ */

/* ---------- Collections grid ---------- */
.collections{ padding:clamp(70px,10vw,140px) var(--pad); max-width:var(--maxw); margin:0 auto; }
.collections__head{ max-width:760px; margin-bottom:54px; }
.collections__head h2{ margin:4px 0 16px; }
.collections__head p{ color:#4a3d2e; font-size:1.05rem; max-width:56ch; }
.collections__grid{ display:grid; grid-template-columns:repeat(12,1fr); gap:16px; }
.ccol{ position:relative; border-radius:8px; overflow:hidden; cursor:pointer; min-height:260px;
  grid-column:span 4; display:flex; flex-direction:column; justify-content:flex-end;
  background:var(--ink); isolation:isolate; }
/* feature the first two */
.ccol:nth-child(1){ grid-column:span 8; min-height:380px; }
.ccol:nth-child(2){ grid-column:span 4; min-height:380px; }
.ccol__img{ position:absolute; inset:0; z-index:-2; background-size:cover; background-position:center;
  transition:transform 1s var(--ease); filter:saturate(.97); }
.ccol:hover .ccol__img{ transform:scale(1.07); }
.ccol__veil{ position:absolute; inset:0; z-index:-1;
  background:linear-gradient(0deg,rgba(15,11,7,.92) 0%,rgba(15,11,7,.45) 45%,rgba(15,11,7,.1) 100%); }
.ccol__body{ padding:22px 24px; color:var(--bone); }
.ccol__bar{ width:34px; height:3px; border-radius:2px; margin-bottom:14px; background:var(--honey); }
.ccol__name{ font-family:var(--serif); font-weight:400; font-size:clamp(1.4rem,2.4vw,2.1rem); line-height:1.05; }
.ccol__tag{ font-size:13px; color:rgba(236,226,210,.7); margin-top:6px; }
.ccol__chips{ display:flex; flex-wrap:wrap; gap:7px; margin-top:16px; }
.ccol__chips span{ font-family:var(--mono); font-size:10.5px; letter-spacing:.04em; padding:5px 10px;
  border:1px solid rgba(236,226,210,.25); border-radius:20px; color:rgba(236,226,210,.85); }
.ccol__go{ position:absolute; top:18px; right:18px; z-index:1; width:38px; height:38px; border-radius:50%;
  border:1px solid rgba(236,226,210,.4); color:var(--bone); display:grid; place-items:center; font-size:16px;
  transition:.35s var(--ease); }
.ccol:hover .ccol__go{ background:var(--honey); border-color:var(--honey); color:var(--ink); transform:rotate(-45deg); }

/* ---------- Explore ---------- */
.explore{ padding:clamp(70px,9vw,120px) var(--pad) clamp(60px,8vw,110px); max-width:var(--maxw); margin:0 auto; }
.explore__head{ display:flex; justify-content:space-between; align-items:flex-end; gap:40px; flex-wrap:wrap; }
.explore__head h2{ margin-top:4px; }
.explore__note{ max-width:40ch; color:#4a3d2e; font-size:.96rem; }
.explore__note span{ font-family:var(--mono); color:var(--honey-deep); font-size:.86rem; }
.explore__bar{ display:flex; align-items:center; gap:18px; margin:40px 0 14px; flex-wrap:wrap;
  position:sticky; top:64px; z-index:40; padding:10px 0;
  background:linear-gradient(180deg,var(--bone) 70%,rgba(236,226,210,0)); }
.search{ position:relative; flex:0 0 320px; max-width:100%; }
.search svg{ position:absolute; left:16px; top:50%; transform:translateY(-50%); width:17px; height:17px;
  fill:none; stroke:#7a6a55; stroke-width:2; stroke-linecap:round; }
.search input{ width:100%; padding:13px 16px 13px 42px; border-radius:40px; border:1px solid var(--line);
  background:#fff; font-family:var(--sans); font-size:14px; color:var(--ink); transition:border-color .3s,box-shadow .3s; }
.search input:focus{ outline:0; border-color:var(--honey); box-shadow:0 0 0 4px rgba(199,154,82,.13); }
.filters{ display:flex; flex-wrap:wrap; gap:9px; align-items:center; flex:1; }
.filters--sub{ margin:4px 0 30px; }
.filters--sub .filter{ font-size:12px; padding:7px 13px; }
.chip{ font-family:var(--sans); font-size:12.5px; font-weight:500; padding:8px 15px; border-radius:30px;
  border:1px solid var(--line); background:transparent; color:#4a3d2e; cursor:pointer; transition:.28s var(--ease);
  white-space:nowrap; display:inline-flex; align-items:center; gap:7px; }
.chip:hover{ border-color:var(--ink); color:var(--ink); }
.chip.is-active{ background:var(--ink); border-color:var(--ink); color:var(--bone); }
.chip .n{ font-family:var(--mono); font-size:10px; opacity:.6; }
.chip.is-active .n{ opacity:.8; }

/* design-card grid */
.grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(min(100%,250px),1fr)); gap:16px; margin-top:6px; }
.card{ position:relative; border-radius:7px; overflow:hidden; cursor:pointer; background:#ddcfb8;
  aspect-ratio:4/3.1; opacity:0; transform:translateY(16px); transition:opacity .5s var(--ease),transform .5s var(--ease); }
.card.in{ opacity:1; transform:none; }
.card img{ width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease); }
.card:hover img{ transform:scale(1.07); }
.card__grad{ position:absolute; inset:0; display:flex; flex-direction:column; justify-content:flex-end;
  padding:14px 15px; color:var(--bone); background:linear-gradient(0deg,rgba(15,11,7,.82) 0%,rgba(15,11,7,.18) 48%,transparent 75%);
  opacity:.96; }
.card__col{ font-family:var(--mono); font-size:9.5px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--honey); margin-bottom:4px; }
.card__name{ font-family:var(--serif); font-size:1.12rem; font-weight:400; line-height:1.1; }
.card__size{ font-family:var(--mono); font-size:10.5px; color:rgba(236,226,210,.8); margin-top:5px; }
.card__plus{ position:absolute; top:11px; right:11px; width:28px; height:28px; border-radius:50%;
  background:rgba(15,11,7,.45); backdrop-filter:blur(4px); color:var(--bone); display:grid; place-items:center;
  font-size:16px; opacity:0; transform:scale(.7); transition:.3s var(--ease); }
.card:hover .card__plus{ opacity:1; transform:scale(1); }
.card.hidden{ display:none; }
.grid__more{ display:flex; justify-content:center; margin-top:40px; }
.grid__more.gone{ display:none; }
.cat-empty{ text-align:center; padding:60px 20px; color:#7a6a55; font-family:var(--serif); font-style:italic; font-size:1.2rem; }

/* ---------- Enhanced lightbox ---------- */
.lightbox__stage{ display:flex; gap:0; width:min(1180px,92vw); max-height:88vh; background:var(--ink-2);
  border-radius:10px; overflow:hidden; box-shadow:0 40px 120px -30px rgba(0,0,0,.8); }
.lightbox__imgs{ flex:1.55; min-width:0; background:#0d0a07; display:flex; flex-direction:column; gap:2px; overflow:hidden; }
.lightbox__imgs img{ width:100%; height:100%; object-fit:cover; flex:1; min-height:0; }
.lightbox__imgs img.solo{ object-fit:contain; background:#0d0a07; }
.lightbox__panel{ flex:0 0 320px; padding:34px 32px; color:var(--bone); overflow-y:auto; }
.lbp__col{ font-family:var(--mono); font-size:10px; letter-spacing:.2em; color:var(--honey); text-transform:uppercase; }
.lbp__name{ font-family:var(--serif); font-weight:400; font-size:2rem; line-height:1.05; margin:10px 0 22px; }
.lbp__spec{ display:flex; justify-content:space-between; gap:14px; padding:12px 0; border-top:1px solid var(--line-light); font-size:13.5px; }
.lbp__spec dt{ color:rgba(236,226,210,.55); }
.lbp__spec dd{ text-align:right; font-family:var(--mono); font-size:12.5px; color:var(--bone); }
.lbp__spec dd em{ font-family:var(--sans); font-style:normal; color:rgba(236,226,210,.5); display:block; font-size:10.5px; margin-top:2px; }
.lbp__count{ font-family:var(--mono); font-size:11px; color:rgba(236,226,210,.45); margin-top:22px; }
.lbp__cta{ margin-top:20px; }

@media (max-width:860px){
  .lightbox__stage{ flex-direction:column; max-height:90vh; width:94vw; }
  .lightbox__imgs{ flex:none; height:46vh; flex-direction:row; }
  .lightbox__panel{ flex:none; padding:22px 22px 28px; }
  .lbp__name{ font-size:1.6rem; }
}
@media (max-width:1024px){
  .collections__grid{ grid-template-columns:repeat(6,1fr); }
  .ccol,.ccol:nth-child(1),.ccol:nth-child(2){ grid-column:span 3; min-height:300px; }
}
@media (max-width:680px){
  .collections__grid{ grid-template-columns:1fr 1fr; gap:12px; }
  .ccol,.ccol:nth-child(1),.ccol:nth-child(2){ grid-column:span 1; min-height:230px; }
  .grid{ grid-template-columns:1fr 1fr; gap:10px; }
  .explore__bar{ top:58px; }
  .search{ flex-basis:100%; }
}

/* ============================================================
   MOBILE POLISH — smooth, fast, app-like
   ============================================================ */
@media (hover:none){
  *{ -webkit-tap-highlight-color: transparent; }
  .card:hover img,.ccol:hover .ccol__img,.cell:hover img{ transform:none; } /* no hover zoom on touch */
}
/* bigger burger hit area without changing the visual */
.nav__burger::before{ content:""; position:absolute; inset:-13px; }

@media (max-width:680px){
  /* filter bar: not sticky, chips become one swipeable row */
  .explore__bar{ position:static; gap:14px; padding:0; margin:28px 0 12px; }
  #colFilters, #lookFilters{
    flex-wrap:nowrap; overflow-x:auto; overflow-y:hidden;
    scroll-snap-type:x proximity; -webkit-overflow-scrolling:touch;
    scrollbar-width:none; -ms-overflow-style:none;
    padding:2px 4px 8px; margin-left:-4px; margin-right:-4px;
    -webkit-mask-image:linear-gradient(90deg,#000 92%,transparent);
            mask-image:linear-gradient(90deg,#000 92%,transparent);
  }
  #colFilters::-webkit-scrollbar, #lookFilters::-webkit-scrollbar{ display:none; }
  .filters--sub{ margin:2px 0 26px; }
  .chip{ scroll-snap-align:start; flex:0 0 auto; padding:9px 16px; }
  .explore__head{ gap:14px; }
  /* tighten section vertical rhythm a touch on small screens */
  .collections,.explore,.spaces,.formats,.export,.legacy{ padding-left:18px; padding-right:18px; }
  /* active-press feedback */
  .btn:active,.chip:active,.ccol:active,.card:active{ transform:scale(.98); }
}

/* ============================================================
   EXCELLENCE PAGE (sub-page)
   ============================================================ */
.page-sub{ background:var(--bone); }
.nav--sub.solid{ background:rgba(236,226,210,.9); }
.nav__links a.is-current{ opacity:1; }
.nav__links a.is-current::after{ width:100%; }

/* sub-hero */
.subhero{ position:relative; min-height:74svh; display:flex; flex-direction:column; justify-content:center;
  padding:120px var(--pad) 80px; color:var(--bone); background:var(--ink); overflow:hidden; }
.subhero__bg{ position:absolute; inset:-12% -2% -2% -2%; z-index:0; background-size:cover; background-position:center;
  background-image:url("assets/collections/grandeslab/grandeslab_p009.webp"); filter:saturate(.9) brightness(.6); will-change:transform; }
.subhero__veil{ position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg,rgba(21,16,11,.7),rgba(21,16,11,.55) 45%,rgba(21,16,11,.92)); }
.subhero__inner{ position:relative; z-index:2; max-width:880px; }
.subhero__eyebrow{ font-size:11px; letter-spacing:.3em; color:var(--honey); margin-bottom:22px; }
.subhero__title{ font-family:var(--serif); font-weight:300; line-height:.96; letter-spacing:-.02em;
  font-size:clamp(2.8rem,8vw,6.6rem); }
.subhero__title em{ font-style:italic; color:var(--honey); }
.subhero__title .line{ display:block; overflow:hidden; }
.subhero__title .line>span{ display:block; transform:translateY(110%); }
.subhero__sub{ max-width:560px; margin:26px 0 30px; font-size:clamp(1rem,1.5vw,1.18rem); font-weight:300;
  color:rgba(236,226,210,.82); line-height:1.6; }
.subhero__crumb{ position:absolute; right:var(--pad); bottom:26px; z-index:2; font-size:11px; letter-spacing:.16em; }
.subhero__crumb a{ color:rgba(236,226,210,.6); transition:color .3s; } .subhero__crumb a:hover{ color:var(--honey); }

/* pillars */
.pillars{ padding:clamp(70px,10vw,140px) var(--pad); max-width:var(--maxw); margin:0 auto; }
.pillars__head{ max-width:720px; margin-bottom:54px; }
.pillars__head h2{ margin-top:6px; }
.pillars__list{ display:flex; flex-direction:column; gap:clamp(40px,7vw,96px); }
.pillar{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,5vw,72px); align-items:center; }
.pillar--alt .pillar__media{ order:2; }
.pillar__media{ border-radius:8px; overflow:hidden; aspect-ratio:4/3; background:var(--ink);
  box-shadow:0 30px 70px -36px rgba(0,0,0,.55); }
.pillar__img{ width:100%; height:100%; background-size:cover; background-position:center;
  transition:transform 1.1s var(--ease); }
.pillar:hover .pillar__img{ transform:scale(1.05); }
.pillar__n{ font-size:13px; color:var(--honey-deep); letter-spacing:.1em; }
.pillar__t{ font-family:var(--serif); font-weight:400; font-size:clamp(1.9rem,4vw,3rem); line-height:1.02; margin:10px 0 16px; }
.pillar__d{ font-size:clamp(1rem,1.3vw,1.12rem); color:#4a3d2e; max-width:46ch; line-height:1.6; }
.pillar__more{ overflow:hidden; }
.pillar__more p{ margin-top:16px; padding-top:16px; border-top:1px solid var(--line);
  font-size:.98rem; color:#5a4d3e; max-width:48ch; line-height:1.6; animation:fadeIn .5s var(--ease); }
@keyframes fadeIn{ from{ opacity:0; transform:translateY(-4px); } to{ opacity:1; transform:none; } }
.pillar__btn{ display:inline-flex; align-items:center; gap:12px; margin-top:24px; cursor:pointer;
  background:transparent; border:1px solid var(--ink); color:var(--ink); border-radius:40px;
  padding:11px 14px 11px 22px; font-family:var(--sans); font-size:13.5px; font-weight:600; transition:.35s var(--ease); }
.pillar__btn .arr{ width:26px; height:26px; border-radius:50%; background:var(--ink); color:var(--bone);
  display:grid; place-items:center; font-size:13px; transition:.35s var(--ease); }
.pillar__btn:hover{ background:var(--ink); color:var(--bone); }
.pillar__btn:hover .arr{ background:var(--honey); color:var(--ink); }
.pillar__btn.is-open .arr{ transform:rotate(135deg); }

/* founder */
.founder{ background:var(--ink); color:var(--bone); padding:clamp(70px,10vw,140px) var(--pad); }
.founder__inner{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:0.85fr 1.15fr;
  gap:clamp(36px,6vw,90px); align-items:center; }
.founder__media{ aspect-ratio:4/5; border-radius:8px; background-size:cover; background-position:center;
  box-shadow:0 36px 80px -40px rgba(0,0,0,.7); }
.founder__quote{ font-family:var(--serif); font-weight:300; font-style:italic; letter-spacing:-.01em;
  font-size:clamp(1.5rem,3vw,2.5rem); line-height:1.28; margin:6px 0 26px; }
.founder__by{ display:flex; flex-direction:column; gap:3px; margin-bottom:24px; }
.founder__by strong{ font-family:var(--serif); font-size:1.25rem; font-weight:500; }
.founder__by span{ font-size:13px; color:rgba(236,226,210,.55); }
.founder__note{ font-size:1.02rem; color:rgba(236,226,210,.78); max-width:48ch; line-height:1.6; }
.founder__note strong{ color:var(--honey); }

/* numbers */
.numbers{ background:var(--bone-2); padding:clamp(54px,7vw,90px) var(--pad); }
.numbers__grid{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); gap:1px;
  background:var(--line); border:1px solid var(--line); }
.nstat{ background:var(--bone-2); padding:30px 26px; }
.nstat__n{ font-size:clamp(2.4rem,4.6vw,3.6rem); font-weight:600; color:var(--ink); line-height:1; letter-spacing:-.02em; }
.nstat__s{ font-family:var(--serif); font-style:italic; font-size:1.3rem; color:var(--honey-deep); margin-left:4px; }
.nstat p{ font-size:13px; color:#5a4d3e; margin-top:12px; max-width:20ch; line-height:1.4; }

/* cta band */
.ctaband{ background:var(--ink); color:var(--bone); padding:clamp(70px,10vw,130px) var(--pad); text-align:center; }
.ctaband__inner{ max-width:760px; margin:0 auto; }
.ctaband h2{ margin-bottom:18px; }
.ctaband p{ color:rgba(236,226,210,.75); font-size:1.08rem; font-weight:300; margin-bottom:32px; }
.ctaband__actions{ display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }

@media (max-width:860px){
  .founder__inner{ grid-template-columns:1fr; }
  .founder__media{ aspect-ratio:16/10; max-height:340px; }
}
@media (max-width:760px){
  .pillar{ grid-template-columns:1fr; gap:18px; }
  .pillar--alt .pillar__media{ order:0; }
  .pillar__media{ aspect-ratio:16/10; }
  .numbers__grid{ grid-template-columns:1fr 1fr; }
  .subhero__crumb{ position:static; margin-top:30px; }
}

/* ============================================================
   DETAIL PAGES (Infrastructure / Plant / QC / Make-in-India)
   ============================================================ */
.dhero{ position:relative; min-height:62svh; display:flex; align-items:flex-end; padding:130px var(--pad) 60px;
  color:var(--bone); background:var(--ink); overflow:hidden; }
.dhero__bg{ position:absolute; inset:-10% -2% -2% -2%; z-index:0; background-size:cover; background-position:center;
  filter:saturate(.92) brightness(.5); will-change:transform; }
.dhero__veil{ position:absolute; inset:0; z-index:1; background:linear-gradient(180deg,rgba(21,16,11,.5),rgba(21,16,11,.5) 40%,rgba(21,16,11,.94)); }
.dhero__inner{ position:relative; z-index:2; max-width:920px; }
.dhero__eyebrow{ font-size:11px; letter-spacing:.3em; color:var(--honey); margin-bottom:18px; }
.dhero__title{ font-family:var(--serif); font-weight:300; line-height:.98; letter-spacing:-.02em; font-size:clamp(2.6rem,7vw,5.4rem); }
.dhero__tag{ font-family:var(--serif); font-style:italic; font-size:clamp(1.2rem,2.4vw,1.9rem); color:var(--honey); margin-top:14px; max-width:30ch; }
.dhero__intro{ max-width:620px; margin-top:20px; font-size:clamp(1rem,1.4vw,1.14rem); font-weight:300; color:rgba(236,226,210,.82); line-height:1.6; }
.dhero__crumb{ position:absolute; right:var(--pad); top:96px; z-index:2; font-size:11px; letter-spacing:.16em; }
.dhero__crumb a{ color:rgba(236,226,210,.6); transition:color .3s; } .dhero__crumb a:hover{ color:var(--honey); }

.dsec{ padding:clamp(60px,8vw,110px) var(--pad); max-width:var(--maxw); margin:0 auto; }
.dsec--tight{ padding-top:clamp(40px,5vw,64px); padding-bottom:0; }
.dsec__head{ max-width:760px; margin-bottom:46px; }
.dsec__head h2{ margin-top:6px; font-size:clamp(1.8rem,4.4vw,3.4rem); }
.dsec__note{ margin-top:14px; color:#4a3d2e; max-width:54ch; }

/* process / feature rows (reused for plant steps + make-in-india features) */
.proc{ display:flex; flex-direction:column; gap:clamp(36px,6vw,84px); }
.proc__row{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(26px,5vw,68px); align-items:center; }
.proc__row--alt .proc__media{ order:2; }
.proc__media{ border-radius:8px; overflow:hidden; aspect-ratio:4/3; background:var(--ink); box-shadow:0 30px 64px -34px rgba(0,0,0,.5); }
.proc__img{ width:100%; height:100%; background-size:cover; background-position:center; transition:transform 1.1s var(--ease); }
.proc__row:hover .proc__img{ transform:scale(1.05); }
.proc__n{ font-family:var(--mono); font-size:14px; color:var(--honey-deep); letter-spacing:.1em; }
.proc__t{ font-family:var(--serif); font-weight:400; font-size:clamp(1.7rem,3.6vw,2.7rem); line-height:1.04; margin:8px 0 14px; }
.proc__d{ font-size:clamp(.98rem,1.25vw,1.1rem); color:#4a3d2e; max-width:48ch; line-height:1.62; }

/* tech grid */
.techgrid{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
.techcard{ border:1px solid var(--line); border-radius:10px; padding:30px 30px 32px; background:linear-gradient(180deg,rgba(255,255,255,.25),transparent); }
.techcard__logo{ width:100%; height:54px; background-size:contain; background-repeat:no-repeat; background-position:left center; margin-bottom:18px; filter:saturate(.2) brightness(.4); opacity:.85; }
.techcard h3{ font-family:var(--serif); font-weight:400; font-size:1.45rem; margin-bottom:10px; }
.techcard p{ font-size:.98rem; color:#4a3d2e; line-height:1.6; }

/* QC checklist */
.checks{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.check{ display:flex; align-items:center; gap:16px; padding:22px 24px; border:1px solid var(--line); border-radius:10px; background:linear-gradient(180deg,rgba(255,255,255,.25),transparent); }
.check__n{ font-size:14px; color:var(--honey-deep); }
.check__t{ font-family:var(--serif); font-size:1.2rem; }

/* values chips */
.values{ display:flex; flex-wrap:wrap; gap:12px; max-width:var(--maxw); }
.value{ font-family:var(--mono); font-size:13px; letter-spacing:.06em; padding:11px 20px; border:1px solid var(--line); border-radius:40px; color:var(--ink); }

/* gallery grid + lightbox */
.ggrid{ display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
.gcell{ border:0; padding:0; cursor:pointer; border-radius:6px; overflow:hidden; aspect-ratio:4/3; background:#d8cab4; }
.gcell img{ width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease); }
.gcell:hover img{ transform:scale(1.07); }
.glb{ position:fixed; inset:0; z-index:9999; background:rgba(15,11,7,.94); backdrop-filter:blur(8px);
  display:flex; align-items:center; justify-content:center; gap:18px; opacity:0; visibility:hidden; transition:opacity .35s var(--ease),visibility .35s; }
.glb.open{ opacity:1; visibility:visible; }
.glb img{ max-width:min(1100px,88vw); max-height:84vh; border-radius:6px; box-shadow:0 40px 100px -30px rgba(0,0,0,.8); }
.glb__close{ position:absolute; top:22px; right:30px; background:none; border:0; color:var(--bone); font-size:38px; cursor:pointer; line-height:1; opacity:.75; }
.glb__close:hover{ opacity:1; }
.glb__nav{ background:rgba(236,226,210,.08); border:1px solid var(--line-light); color:var(--bone); width:54px; height:54px; border-radius:50%; font-size:26px; cursor:pointer; flex:0 0 auto; transition:.3s var(--ease); }
.glb__nav:hover{ background:var(--honey); color:var(--ink); border-color:var(--honey); }

@media (max-width:860px){
  .techgrid{ grid-template-columns:1fr; }
  .checks{ grid-template-columns:1fr 1fr; }
  .ggrid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:760px){
  .proc__row{ grid-template-columns:1fr; gap:18px; }
  .proc__row--alt .proc__media{ order:0; }
  .proc__media{ aspect-ratio:16/10; }
  .dhero__crumb{ position:static; margin-bottom:14px; order:-1; }
  .glb__nav{ width:42px; height:42px; }
}
@media (max-width:480px){ .checks{ grid-template-columns:1fr; } }
