/* ============================================================
   INDIC DECOR — augen-dark studio
   Design tokens + base + components. Vanilla, no framework.
   ============================================================ */

/* ---- Fonts (Geist) ---- */
@import url('https://fonts.googleapis.com/css2?family=Geist:wght@300;400;500&family=Marcellus&display=swap');

/* ---- Tokens ---- */
:root{
  /* color */
  --ground:#0f1012;
  --surface:#17181b;
  --surface-alt:#141518;
  --surface-high:#1c1d20;
  --ink:#f2f2f4;
  --ink-soft:#8a8a8e;
  --accent:#cc4c28;        /* terracotta — single accent */
  --accent-hi:#e0653f;     /* hover */
  --gold:#c4993b;          /* trade/spec stamps ONLY */
  --line:rgba(242,242,244,.14);
  --line-soft:rgba(242,242,244,.08);
  --wa:#25D366;

  /* type */
  --font:'Geist',system-ui,-apple-system,'Segoe UI',sans-serif;
  --font-display:'Marcellus','Cormorant Garamond',Georgia,'Times New Roman',serif;
  --fs-hero:clamp(2.75rem,9vw,8rem);
  --fs-h1:clamp(2.25rem,5vw,4rem);
  --fs-h2:clamp(1.75rem,3.2vw,2.5rem);
  --fs-h3:1.5rem;
  --fs-lg:1.125rem;
  --fs-md:1rem;
  --fs-sm:.875rem;
  --fs-xs:.75rem;

  /* space (4pt) */
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-6:24px;
  --s-8:32px; --s-12:48px; --s-16:64px; --s-24:96px; --s-32:128px;

  --radius:1.625rem;       /* 26px panels */
  --radius-pill:9999px;
  --container:1440px;
  --gutter:24px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---- Reset ---- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  font-family:var(--font);
  font-weight:400;
  font-size:var(--fs-md);
  line-height:1.6;
  letter-spacing:-.02em;
  color:var(--ink);
  background:var(--ground);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  min-height:100vh;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
ul{list-style:none}
::selection{background:var(--accent);color:#fff}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px}

/* ---- Layout helpers ---- */
.container{max-width:var(--container);margin-inline:auto;padding-inline:clamp(20px,5vw,64px)}
.eyebrow{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.18em;color:var(--ink-soft);font-weight:500}
.eyebrow--accent{color:var(--accent-hi)}
.muted{color:var(--ink-soft)}
.display{font-weight:300;line-height:.98;letter-spacing:-.035em}
section{padding-block:var(--s-24)}

/* ---- Display face: Marcellus (lapidary serif) on headings; Geist stays on body/UI ---- */
.hero__title,.hero__title em,.display,.statement,.manifesto p,.footer__brand,
.section-head h1,.section-head h2,.drench h2,.quote blockquote,.founder blockquote,
.disciplines .d-name,.pd-hero__cap h1,.hero__sub,.err__code,
.principles h3,.timeline h3,.nextsteps h3,.tcard h3,.pd-story h3,.work-group__head h3{
  font-family:var(--font-display);
  font-weight:400;
  letter-spacing:0;
}
.hero__sub{font-style:italic;color:var(--ink-soft)}

/* ---- Buttons / pills ---- */
.btn{display:inline-flex;align-items:center;gap:var(--s-2);padding:14px 28px;border-radius:var(--radius-pill);
  font-size:var(--fs-sm);letter-spacing:.02em;transition:background .2s var(--ease),color .2s var(--ease),transform .2s var(--ease)}
.btn--primary{background:var(--accent);color:#fff}
.btn--primary:hover{background:var(--accent-hi)}
.btn--ghost{border:1px solid var(--line);color:var(--ink)}
.btn--ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
.btn .ar{transition:transform .2s var(--ease)}
.btn:hover .ar{transform:translateX(4px)}

/* ============================================================
   NAV — floating glass pill
   ============================================================ */
.nav{position:fixed;top:16px;left:50%;transform:translateX(-50%);
  width:calc(100% - 32px);max-width:var(--container);z-index:50;
  display:flex;align-items:center;gap:var(--s-3);
  padding:10px 12px 10px 24px;border-radius:var(--radius-pill);
  border:1px solid var(--line-soft);background:var(--surface);
  transition:transform .3s var(--ease)}
.nav.is-hidden{transform:translateX(-50%) translateY(-150%)}
.nav__logo{display:inline-flex;align-items:center;gap:9px;white-space:nowrap;flex-shrink:0;text-decoration:none}
.nav__logo-mark{height:34px;width:auto;display:block}
.nav__logo-word{height:19px;width:auto;display:block}
@media(max-width:880px){.nav__logo-mark{height:30px}.nav__logo-word{height:16px}}
@media(min-width:881px) and (max-width:1199px){.nav__logo-word{display:none}.nav__links{gap:var(--s-6)}}
.nav__links{display:flex;gap:var(--s-8);align-items:center}
.nav__links a{font-size:var(--fs-sm);text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);transition:color .2s}
.nav__links a:hover,.nav__links a[aria-current]{color:var(--ink)}

/* ---- Products mega-menu ---- */
.nav__drop{position:static;display:flex;align-items:center}
.nav__mega{position:absolute;left:50%;top:100%;transform:translateX(-50%);padding-top:26px;display:none;z-index:60}
.nav__drop:hover .nav__mega,.nav__drop:focus-within .nav__mega{display:block}
.nav__mega-in{display:grid;grid-template-columns:repeat(3,1fr);gap:4px 44px;width:min(660px,calc(100vw - 48px));
  background:var(--surface-high);border:1px solid var(--line-soft);border-radius:var(--radius);padding:30px 36px}
.nav__links .nav__mega-in a{display:block;font-size:var(--fs-sm);color:var(--ink-soft);padding:5px 0;
  text-transform:none;letter-spacing:0}
.nav__links .nav__mega-in a:hover{color:var(--ink)}
.nav__links .nav__mega-in a.mh{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.16em;color:var(--accent-hi);margin-bottom:4px}
.nav__links .nav__mega-in a.mt{margin-top:16px}
@media(max-width:880px){.nav__mega{display:none!important}}
.nav__cta{margin-left:auto;flex-shrink:0}
.nav__burger{display:none}
@media (min-width:881px){
  .nav__links{position:absolute;left:50%;transform:translateX(-50%)}
}
@media (max-width:880px){
  .nav__links{display:none}
  .nav__cta{padding:10px 18px;font-size:var(--fs-xs)}
  .nav__burger{display:inline-flex;padding:8px;flex-shrink:0}
  .nav.is-open .nav__links{display:flex;position:absolute;top:calc(100% + 8px);left:0;right:0;
    flex-direction:column;gap:var(--s-4);padding:24px;border-radius:var(--radius);
    background:var(--surface-high);border:1px solid var(--line-soft)}
}

/* ============================================================
   HERO — full-bleed studio
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img{width:100%;height:100%;object-fit:cover}
.hero__media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(to top,var(--ground) 4%,rgba(15,16,18,.35) 45%,rgba(15,16,18,.65) 100%)}
.hero__inner{position:relative;z-index:1;width:100%;padding-bottom:var(--s-16)}
.hero__title{font-size:var(--fs-hero);font-weight:300;line-height:.95;letter-spacing:-.04em;max-width:14ch}
.hero__title em{font-style:normal;color:var(--accent)}
.hero__sub{font-size:var(--fs-lg);color:var(--ink-soft);max-width:44ch;margin-top:var(--s-6);line-height:1.6;letter-spacing:-.01em}
.hero__meta{display:flex;flex-wrap:wrap;gap:var(--s-8);margin-top:var(--s-8);padding-top:var(--s-6);border-top:1px solid var(--line)}
.hero__meta dt{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.18em;color:var(--ink-soft)}
.hero__meta dd{font-size:var(--fs-md);margin-top:4px}
.hero__cta{display:flex;gap:var(--s-3);margin-top:var(--s-8);flex-wrap:wrap}

/* ---- credibility / proof bar ---- */
.proofbar{padding-block:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.proofbar .grid{display:grid;grid-template-columns:repeat(4,1fr)}
.proofbar .item{padding:var(--s-8) var(--s-6) var(--s-8) 0}
.proofbar .item + .item{border-left:1px solid var(--line-soft);padding-left:var(--s-6)}
.proofbar .t{font-size:var(--fs-lg);font-weight:400;letter-spacing:-.01em}
.proofbar .d{font-size:var(--fs-sm);color:var(--ink-soft);margin-top:6px}
@media(max-width:760px){
  .proofbar .grid{grid-template-columns:repeat(2,1fr)}
  .proofbar .item:nth-child(3){border-left:0;padding-left:0}
}
@media(max-width:420px){.proofbar .grid{grid-template-columns:1fr}.proofbar .item{border-left:0!important;padding-left:0!important}}

/* ============================================================
   WORK GRID
   ============================================================ */
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--s-6);
  margin-bottom:var(--s-12);flex-wrap:wrap}
.section-head h2{font-size:var(--fs-h1);font-weight:300;letter-spacing:-.03em;line-height:1}
.viewtoggle{display:flex;gap:var(--s-4);font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.14em}
.viewtoggle button{color:var(--ink-soft)}
.viewtoggle button[aria-pressed="true"]{color:var(--ink)}

/* inner-page header clears the fixed nav */
.page-top{padding-top:140px}
@media(max-width:560px){
  .work-list th:nth-child(3),.work-list td:nth-child(3){display:none}
}

.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-6) var(--gutter)}
@media(max-width:980px){.work-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.work-grid{grid-template-columns:1fr}}
.work-card{display:block}
.work-card__frame{position:relative;aspect-ratio:4/5;border-radius:var(--radius);overflow:hidden;
  background:var(--surface);border:1px solid var(--line-soft)}
.work-card__frame img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.work-card:hover .work-card__frame img{transform:scale(1.03)}
.work-card__row{display:flex;justify-content:space-between;align-items:baseline;margin-top:var(--s-4);gap:var(--s-4)}
.work-card__title{font-size:var(--fs-lg);font-weight:400}
.work-card__meta{font-size:var(--fs-sm);color:var(--ink-soft)}
.work-card__ar{color:var(--ink-soft);transition:color .2s,transform .2s}
.work-card:hover .work-card__ar{color:var(--accent);transform:translateX(4px)}

/* filter bar */
.filters{display:flex;flex-wrap:wrap;gap:10px;margin:var(--s-8) 0 var(--s-12)}
.filters button{padding:8px 18px;border-radius:var(--radius-pill);border:1px solid var(--line);
  color:var(--ink-soft);font-size:var(--fs-sm);letter-spacing:.01em;transition:color .2s,border-color .2s,background .2s}
.filters button:hover{color:var(--ink);border-color:var(--ink)}
.filters button[aria-pressed="true"]{background:var(--accent);border-color:var(--accent);color:#fff}

/* grouped archive */
.work-group{margin-bottom:var(--s-16)}
.work-group__head{display:flex;align-items:baseline;gap:12px;margin-bottom:var(--s-8);padding-bottom:var(--s-3);border-bottom:1px solid var(--line-soft)}
.work-group__head h3{font-size:var(--fs-h3);font-weight:400;letter-spacing:-.02em}
.work-group__head .c{font-size:var(--fs-sm);color:var(--ink-soft)}
.work-card__code{color:var(--ink-soft);letter-spacing:.04em}

/* LIST view */
.work-list{width:100%;border-collapse:collapse}
.work-list th,.work-list td{text-align:left;padding:18px 8px;border-bottom:1px solid var(--line-soft)}
.work-list th{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.16em;color:var(--ink-soft);font-weight:500}
.work-list td{font-size:var(--fs-md)}
.work-list tbody tr{transition:color .2s}
.work-list tbody tr:hover td:first-child{color:var(--accent)}
.work-list td:last-child,.work-list th:last-child{text-align:right;color:var(--ink-soft)}
[hidden]{display:none!important}

/* ---- disciplines oversized type-list ---- */
.disciplines{position:relative}
.disciplines .list{margin-top:var(--s-8)}
.disciplines .row{display:flex;align-items:baseline;justify-content:space-between;gap:var(--s-6);
  padding:var(--s-6) 0;border-top:1px solid var(--line-soft);
  font-size:clamp(1.75rem,4.5vw,3.25rem);font-weight:300;letter-spacing:-.03em;line-height:1;
  color:var(--ink);transition:color .2s var(--ease)}
.disciplines .row:last-child{border-bottom:1px solid var(--line-soft)}
.disciplines .d-name{display:inline-block;transition:transform .25s var(--ease)}
.disciplines a.row:hover{color:var(--accent)}
.disciplines a.row:hover .d-name{transform:translateX(14px)}
.disciplines .d-meta{display:flex;align-items:baseline;gap:var(--s-6);flex-shrink:0}
.disciplines .d-desc{font-size:var(--fs-sm);color:var(--ink-soft);letter-spacing:-.01em}
.disciplines a.row:hover .d-desc{color:var(--ink)}
.disciplines .ar{font-size:var(--fs-h3);color:var(--ink-soft);opacity:0;transform:translateX(-8px);transition:opacity .2s,transform .2s}
.disciplines a.row:hover .ar{opacity:1;transform:none;color:var(--accent)}
.disc-preview{position:absolute;right:6%;width:280px;aspect-ratio:4/5;border-radius:var(--radius);overflow:hidden;
  pointer-events:none;opacity:0;transform:translateY(16px) scale(.98);transition:opacity .3s var(--ease),transform .3s var(--ease);
  z-index:5;border:1px solid var(--line-soft)}
.disc-preview.show{opacity:1;transform:none}
.disc-preview img{width:100%;height:100%;object-fit:cover}
@media (max-width:900px){
  .disc-preview{display:none}
  .disciplines .d-desc{display:none}
}
@media (prefers-reduced-motion:reduce){.disciplines a.row:hover .d-name{transform:none}.disciplines .ar{opacity:1;transform:none}.disc-preview{display:none}}

/* ============================================================
   MANIFESTO
   ============================================================ */
.manifesto{background:var(--surface-alt)}
.band-alt{background:var(--surface-alt);padding-block:var(--s-24)}
.manifesto p{font-size:var(--fs-hero);font-weight:300;line-height:1.02;letter-spacing:-.04em;max-width:18ch}
.manifesto .lead{font-size:var(--fs-lg);color:var(--ink-soft);max-width:52ch;margin-top:var(--s-8);line-height:1.6;letter-spacing:-.01em}

/* drench */
.drench{background:var(--accent);color:#fff;text-align:center}
.drench h2{font-size:var(--fs-h1);font-weight:300;letter-spacing:-.03em;max-width:18ch;margin-inline:auto}
.drench .btn--primary{background:#fff;color:var(--accent)}
.drench .btn--primary:hover{background:#0f1012;color:#fff}

/* ---- gallery moment (full-bleed single object) ---- */
.gallery-moment{position:relative;padding:0;margin-block:var(--s-24)}
.gallery-moment > img{width:100%;display:block;aspect-ratio:21/9;object-fit:cover;min-height:520px}
.gallery-moment__cap{position:absolute;inset:auto 0 0 0;padding-bottom:var(--s-16)}
.gallery-moment__cap h2{font-family:var(--font-display);font-weight:400;letter-spacing:0;
  font-size:clamp(2rem,5vw,4rem);line-height:1.05;max-width:18ch}
.gallery-moment__cap p{color:var(--ink-soft);margin-top:16px;max-width:46ch;font-size:var(--fs-lg)}
@media(max-width:640px){.gallery-moment > img{aspect-ratio:3/4;min-height:0}}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{border-top:1px solid var(--line);padding-block:var(--s-16) var(--s-8)}
.footer__top{display:flex;justify-content:space-between;gap:var(--s-12);flex-wrap:wrap}
.footer__brand{display:flex;align-items:center;gap:14px;line-height:1}
.footer__brand .footer__logo-mark{height:clamp(54px,7vw,74px);width:auto;display:block}
.footer__brand .footer__logo-word{height:clamp(28px,3.8vw,40px);width:auto;display:block}
/* Brand moment — homepage signature */
.brand-moment{padding-block:var(--s-24);text-align:center;border-top:1px solid var(--line)}
.brand-moment__mark{height:clamp(72px,11vw,130px);width:auto;display:inline-block}
.brand-moment__word{height:clamp(34px,5.5vw,58px);width:auto;display:block;margin:20px auto 0}
.brand-moment__tag{font-family:var(--font-display);font-size:clamp(1.2rem,2.6vw,1.9rem);color:var(--ink);margin-top:30px;letter-spacing:.01em}
.brand-moment__tag em{font-style:normal;color:var(--accent)}
.brand-moment__loc{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.3em;color:var(--ink-soft);margin-top:16px}
.footer__cols{display:flex;gap:var(--s-16);flex-wrap:wrap}
.footer__col h2{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.16em;color:var(--ink-soft);margin-bottom:var(--s-4);font-weight:500}
.footer__col a{display:block;font-size:var(--fs-md);color:var(--ink-soft);padding:4px 0;transition:color .2s}
.footer__col a:hover{color:var(--ink)}
/* ---- footer newsletter ---- */
.footer__news{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-8);align-items:center;
  margin-top:var(--s-12);padding:var(--s-8);background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius)}
.footer__news-copy h2{font-family:var(--font-display);font-weight:400;font-size:var(--fs-h3);letter-spacing:0}
.footer__news-copy p{font-size:var(--fs-sm);color:var(--ink-soft);margin-top:8px;max-width:40ch}
.footer__news-row{display:flex;gap:10px}
.footer__news-row input[type=email]{flex:1;background:transparent;color:var(--ink);font-family:inherit;font-size:var(--fs-md);
  border:0;border-bottom:1px solid var(--line);padding:12px 0;min-width:0}
.footer__news-row input[type=email]:focus{outline:none;border-bottom-color:var(--accent)}
.footer__news-row .btn{flex-shrink:0}
.footer__news .form-status{margin-top:12px}
@media(max-width:760px){.footer__news{grid-template-columns:1fr;gap:var(--s-6)}}

.footer__bottom{display:flex;justify-content:space-between;align-items:center;gap:var(--s-4);flex-wrap:wrap;
  margin-top:var(--s-16);padding-top:var(--s-6);border-top:1px solid var(--line-soft);
  font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.12em;color:var(--ink-soft)}
.footer__legal{display:flex;gap:var(--s-6);flex-wrap:wrap}
.footer__legal a{color:var(--ink-soft);transition:color .2s}
.footer__legal a:hover{color:var(--accent)}
@media(max-width:760px){.footer__bottom{justify-content:flex-start}.footer__legal{order:3;width:100%}}

/* ============================================================
   ABOUT — statement, principles, timeline, split
   ============================================================ */
.statement{font-size:clamp(1.75rem,4vw,3.25rem);font-weight:300;line-height:1.12;letter-spacing:-.03em;max-width:20ch}
.statement em{font-style:normal;color:var(--accent)}

.split{display:grid;grid-template-columns:1.1fr .9fr;gap:var(--s-16);align-items:center}
.split--media img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:var(--radius);border:1px solid var(--line-soft)}
@media(max-width:880px){.split{grid-template-columns:1fr;gap:var(--s-8)}}

.principles{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gutter);border-top:1px solid var(--line)}
.principles .item{padding-top:var(--s-6)}
.principles .num{font-size:var(--fs-xs);letter-spacing:.16em;color:var(--accent)}
.principles h3{font-size:var(--fs-h3);font-weight:400;margin:12px 0 8px;letter-spacing:-.02em}
.principles p{font-size:var(--fs-sm);color:var(--ink-soft)}
@media(max-width:880px){.principles{grid-template-columns:repeat(2,1fr);gap:var(--s-12) var(--gutter)}}
@media(max-width:480px){.principles{grid-template-columns:1fr}}

.timeline{border-top:1px solid var(--line)}
.timeline .step{display:grid;grid-template-columns:80px 1fr;gap:var(--s-6);padding:var(--s-8) 0;border-bottom:1px solid var(--line-soft);align-items:start}
.timeline .step .n{font-size:var(--fs-lg);color:var(--ink-soft)}
.timeline .step h3{font-size:var(--fs-h3);font-weight:400;letter-spacing:-.02em;margin-bottom:6px}
.timeline .step p{color:var(--ink-soft);max-width:60ch}
@media(max-width:560px){.timeline .step{grid-template-columns:48px 1fr;gap:var(--s-4)}}

.stamp{display:inline-flex;align-items:center;gap:8px;font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.14em;
  color:var(--gold);border:1px solid color-mix(in srgb,var(--gold) 40%,transparent);border-radius:var(--radius-pill);padding:8px 16px}

/* ============================================================
   PROJECT DETAIL
   ============================================================ */
.pd-hero{position:relative;height:88svh;min-height:560px;border-radius:0;overflow:hidden;display:flex;align-items:flex-end;background:#0c0d0f}
.pd-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;object-position:center 38%}
.pd-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,var(--ground),rgba(15,16,18,.1) 60%)}
.pd-hero__cap{position:relative;z-index:1;padding-bottom:var(--s-12)}
.pd-hero__cap h1{font-size:var(--fs-h1);font-weight:300;letter-spacing:-.03em}
.pd-grid{display:grid;grid-template-columns:1.4fr .6fr;gap:var(--s-16)}
@media(max-width:880px){.pd-grid{grid-template-columns:1fr;gap:var(--s-8)}}
.pd-spec dt{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.14em;color:var(--ink-soft);padding-top:var(--s-4)}
.pd-spec dd{font-size:var(--fs-md);padding:4px 0 var(--s-4);border-bottom:1px solid var(--line-soft)}
.pd-aside{position:sticky;top:104px;align-self:start}
@media(max-width:880px){.pd-aside{position:static}}
.pd-story .beat{margin-top:var(--s-16)}
.quote{border-top:1px solid var(--line);border-bottom:1px solid var(--line);text-align:center}
.quote blockquote{max-width:28ch;margin:0 auto;font-size:clamp(1.5rem,3.4vw,2.4rem);font-weight:300;line-height:1.3;letter-spacing:-.025em;color:var(--ink)}
.quote blockquote em{font-style:normal;color:var(--accent)}
.quote .by{margin-top:var(--s-8);font-size:var(--fs-xs);color:var(--ink-soft);text-transform:uppercase;letter-spacing:.14em}
.pd-gallery{display:grid;grid-template-columns:1fr 1fr;gap:var(--gutter)}
.pd-gallery img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:var(--radius);border:1px solid var(--line-soft)}
.pd-gallery .wide{grid-column:1/-1;aspect-ratio:16/9}

/* ============================================================
   FORMS
   ============================================================ */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-6) var(--gutter)}
.form-grid .full{grid-column:1/-1}
@media(max-width:640px){.form-grid{grid-template-columns:1fr}}
.field label{display:block;font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.14em;color:var(--ink-soft);margin-bottom:8px}
.field input,.field select,.field textarea{width:100%;background:transparent;color:var(--ink);font-family:inherit;font-size:var(--fs-md);
  border:0;border-bottom:1px solid var(--line);padding:10px 0;transition:border-color .2s}
.field textarea{min-height:120px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-bottom-color:var(--accent)}
.field select{appearance:none;background-color:var(--ground);cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238a8a8e' stroke-width='1.5'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 4px center;padding-right:24px}
.field select option{background:#17181b;color:var(--ink)}
.contact-side{display:flex;flex-direction:column;gap:var(--gutter)}
.contact-side > img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--radius);border:1px solid var(--line-soft)}
.reassure{margin-top:18px;font-size:var(--fs-sm);color:var(--ink-soft);line-height:1.6}
.form-status{margin-top:18px;font-size:var(--fs-sm);padding:12px 16px;border-radius:var(--radius);border:1px solid var(--line-soft);line-height:1.5}
.form-status.ok{color:#bfe6c8;border-color:rgba(37,211,102,.45);background:rgba(37,211,102,.06)}
.form-status.err{color:#ffd9d4;border-color:rgba(255,106,93,.45);background:rgba(255,106,93,.06)}
.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}
.nextsteps{border-top:1px solid var(--line)}
.nextsteps .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-12)}
.nextsteps .n{font-size:var(--fs-sm);letter-spacing:.16em;color:var(--accent)}
.nextsteps h3{font-size:var(--fs-h3);font-weight:400;letter-spacing:-.02em;margin:12px 0 8px}
.nextsteps p{color:var(--ink-soft);font-size:var(--fs-sm)}
@media(max-width:760px){.nextsteps .grid{grid-template-columns:1fr;gap:var(--s-8)}}
.contact-panel{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);padding:var(--s-8)}
.contact-panel h2{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.14em;color:var(--ink-soft);margin:var(--s-6) 0 6px;font-weight:500}
.contact-panel a.wa-btn{display:inline-flex;align-items:center;gap:10px;background:var(--wa);color:#fff;border-radius:var(--radius-pill);padding:12px 22px;font-size:var(--fs-sm);margin-top:8px}

/* visualizer panel */
.viz{display:grid;grid-template-columns:.8fr 1.2fr;gap:0;border:1px solid var(--line-soft);border-radius:var(--radius);overflow:hidden;background:var(--surface)}
.viz__controls{padding:var(--s-8)}
.viz__stage{background:var(--surface-alt);position:relative;min-height:420px}
.viz__stage img{width:100%;height:100%;object-fit:cover}
.viz__thumbs{display:flex;gap:10px;margin:14px 0 24px}
.viz__thumbs img{width:56px;height:56px;object-fit:cover;border-radius:12px;border:1px solid var(--line-soft)}
.viz__thumbs img:first-child{border-color:var(--accent)}
.viz__drop{border:1px dashed var(--line);border-radius:var(--radius);padding:var(--s-8);text-align:center;color:var(--ink-soft);font-size:var(--fs-sm)}
@media(max-width:780px){.viz{grid-template-columns:1fr}.viz__controls{border-right:0;border-bottom:1px solid var(--line-soft)}}

/* trade cards + downloads */
.tcards{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gutter)}
.tcard{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);padding:var(--s-6)}
.tcard h3{font-weight:400;font-size:var(--fs-lg);margin:14px 0 6px;letter-spacing:-.01em}
.tcard p{font-size:var(--fs-sm);color:var(--ink-soft)}
@media(max-width:880px){.tcards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.tcards{grid-template-columns:1fr}}
.downloads a{display:flex;justify-content:space-between;align-items:center;gap:var(--s-4);padding:18px 0;border-bottom:1px solid var(--line-soft);color:var(--ink);transition:color .2s}
.downloads a:hover{color:var(--accent)}
.downloads a span:last-child{color:var(--ink-soft);font-size:var(--fs-sm)}

/* 404 */
.err{min-height:100svh;display:grid;place-items:center;text-align:center}
.err__code{font-size:clamp(5rem,22vw,16rem);font-weight:300;line-height:1;letter-spacing:-.05em}

/* sample results gallery */
.samples{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gutter)}
.samples figure{margin:0}
.samples img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--radius);border:1px solid var(--line-soft)}
.samples figcaption{font-size:var(--fs-sm);color:var(--ink-soft);margin-top:12px}
@media(max-width:760px){.samples{grid-template-columns:1fr}}

/* journal index */
.article-row{display:grid;grid-template-columns:220px 1fr auto;gap:var(--s-8);align-items:baseline;
  padding:var(--s-8) 0;border-top:1px solid var(--line-soft);transition:color .2s}
.article-row:last-child{border-bottom:1px solid var(--line-soft)}
.article-row .meta{font-size:var(--fs-sm);color:var(--ink-soft)}
.article-row h3{font-family:var(--font-display);font-weight:400;font-size:var(--fs-h3);letter-spacing:0;line-height:1.15}
.article-row p{color:var(--ink-soft);font-size:var(--fs-sm);margin-top:8px;max-width:60ch}
.article-row .ar{color:var(--ink-soft);transition:color .2s,transform .2s}
.article-row:hover h3{color:var(--accent)}
.article-row:hover .ar{color:var(--accent);transform:translateX(4px)}
@media(max-width:760px){.article-row{grid-template-columns:1fr;gap:6px}.article-row .ar{display:none}}

/* article page */
.article-lead{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:var(--radius);border:1px solid var(--line-soft);margin:var(--s-12) 0}
.article-meta{font-size:var(--fs-sm);color:var(--ink-soft);margin-top:14px;display:flex;gap:16px;flex-wrap:wrap}

/* reading column for legal/long-form */
.prose{max-width:720px}
.prose h2{font-size:var(--fs-h2);font-weight:400;letter-spacing:-.02em;margin:var(--s-12) 0 var(--s-4)}
.prose p{color:var(--ink-soft);margin-bottom:var(--s-4);line-height:1.7}

/* ---- founder note ---- */
.founder blockquote{max-width:24ch;font-size:clamp(1.6rem,3.4vw,2.5rem);font-weight:300;line-height:1.25;letter-spacing:-.025em;color:var(--ink)}
.founder blockquote em{font-style:normal;color:var(--accent)}
.founder .sig{margin-top:var(--s-8);font-size:var(--fs-md);color:var(--ink-soft);line-height:1.5}
.founder .sig strong{display:block;color:var(--ink);font-weight:400;font-size:var(--fs-lg)}

/* ---- materials palette ---- */
.materials .grid{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--gutter)}
.materials .sw img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:var(--radius);border:1px solid var(--line-soft);transition:transform .4s var(--ease)}
.materials .sw:hover img{transform:scale(1.03)}
.materials .sw .n{font-size:var(--fs-sm);margin-top:12px}
.materials .sw .d{font-size:var(--fs-xs);color:var(--ink-soft);margin-top:2px}
@media(max-width:900px){.materials .grid{grid-template-columns:repeat(3,1fr);gap:var(--s-8) var(--gutter)}}
@media(max-width:420px){.materials .grid{grid-template-columns:repeat(2,1fr)}}

/* ============================================================
   CATEGORY GRID — image tiles (real stone behind each category)
   ============================================================ */
.catgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gutter)}
.catgrid__tile{position:relative;display:block;aspect-ratio:4/5;border-radius:var(--radius);
  overflow:hidden;border:1px solid var(--line-soft)}
.catgrid__tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:transform .6s var(--ease),filter .4s var(--ease);filter:brightness(.7)}
.catgrid__tile:hover img{transform:scale(1.06);filter:brightness(.82)}
.catgrid__tile::after{content:"";position:absolute;inset:0;
  background:linear-gradient(to top,rgba(15,16,18,.9),rgba(15,16,18,.08) 62%)}
.catgrid__cap{position:absolute;left:0;right:0;bottom:0;z-index:1;padding:var(--s-6)}
.catgrid__name{font-family:var(--font-display);font-size:var(--fs-h3);letter-spacing:0;display:flex;
  align-items:center;justify-content:space-between;gap:8px}
.catgrid__name .ar{color:var(--ink-soft);transition:color .2s,transform .2s}
.catgrid__tile:hover .catgrid__name .ar{color:var(--accent-hi);transform:translateX(4px)}
.catgrid__desc{font-size:var(--fs-sm);color:var(--ink-soft);margin-top:4px}
@media(max-width:980px){.catgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:440px){.catgrid{grid-template-columns:1fr}}

/* honest media label — for conceptual visualisations */
.media-tag{position:absolute;top:12px;left:12px;z-index:2;font-size:10px;text-transform:uppercase;
  letter-spacing:.14em;color:var(--ink-soft);background:rgba(15,16,18,.6);
  border:1px solid var(--line-soft);padding:5px 10px;border-radius:var(--radius-pill)}

/* ============================================================
   CATALOGUES — collection cover cards
   ============================================================ */
.catalogues{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-12) var(--gutter)}
.catcard{display:flex;flex-direction:column}
.catcard__frame{position:relative;aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line-soft);background:var(--surface)}
.catcard__frame img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.catcard:hover .catcard__frame img{transform:scale(1.04)}
.catcard h3{font-family:var(--font-display);font-weight:400;font-size:var(--fs-h3);letter-spacing:0;margin:18px 0 6px}
.catcard p{font-size:var(--fs-sm);color:var(--ink-soft);margin-bottom:16px;flex:1;line-height:1.6}
.catcard__actions{display:flex;gap:10px;flex-wrap:wrap}
.catcard__actions .btn{padding:11px 20px;font-size:var(--fs-xs)}
@media(max-width:880px){.catalogues{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.catalogues{grid-template-columns:1fr}}

/* ============================================================
   BLOG / JOURNAL — image-led cards
   ============================================================ */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-12) var(--gutter)}
.blog-card{display:block}
.blog-card__frame{aspect-ratio:16/10;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line-soft);background:var(--surface)}
.blog-card__frame img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.blog-card:hover .blog-card__frame img{transform:scale(1.04)}
.blog-card .meta{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.14em;color:var(--ink-soft);margin-top:16px}
.blog-card h3{font-family:var(--font-display);font-weight:400;font-size:var(--fs-h3);letter-spacing:0;line-height:1.18;margin-top:8px}
.blog-card:hover h3{color:var(--accent)}
.blog-card p{font-size:var(--fs-sm);color:var(--ink-soft);margin-top:8px;max-width:42ch}
@media(max-width:880px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.blog-grid{grid-template-columns:1fr}}

/* WhatsApp float */
.wa{position:fixed;right:20px;bottom:20px;z-index:60;width:56px;height:56px;border-radius:var(--radius-pill);
  background:var(--wa);display:grid;place-items:center;transition:transform .2s var(--ease)}
.wa:hover{transform:translateY(-3px)}
.wa svg{width:28px;height:28px;fill:#fff}

/* ---- reveal (motion-gated; hidden only when JS is active) ---- */
.js .reveal{opacity:0;transform:translateY(24px)}
.js .reveal.in{opacity:1;transform:none;transition:opacity .6s var(--ease),transform .6s var(--ease)}
@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important}
  .reveal{opacity:1!important;transform:none!important;transition:none!important}
  .work-card__frame img{transition:none!important}
}
