/* =========================================================
   SGK Styles — Shreya Gupta Kedia
   Design system
   ========================================================= */
:root{
  --ink:#191717;
  --ink-soft:#4a4544;
  --muted:#8a8280;
  --line:#e7e1dd;
  --paper:#ffffff;
  --cream:#f7f4f1;
  --cream-2:#f0ebe6;
  --accent:#b07a86;       /* rose */
  --accent-deep:#8f5b67;
  --gold:#b0894f;
  --shadow:0 18px 50px -28px rgba(40,30,30,.5);
  --serif:'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --sans:'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --wrap:1240px;
  --gut:clamp(20px,5vw,64px);
}
*{box-sizing:border-box}
html{
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;text-size-adjust:100%;
  -webkit-tap-highlight-color:transparent;
}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--paper);
  font-weight:300;line-height:1.65;-webkit-font-smoothing:antialiased;
  font-size:16.5px;overflow-x:hidden;overflow-wrap:break-word;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-weight:400;line-height:1.15;margin:0}
p{margin:0 0 1.1em}
.wrap{max-width:var(--wrap);margin:0 auto;padding-inline:max(var(--gut),env(safe-area-inset-left),env(safe-area-inset-right))}
.eyebrow{
  font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--accent-deep);font-weight:500;margin:0 0 1.1rem;
}
.serif{font-family:var(--serif)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;cursor:pointer;
  font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;font-weight:500;
  padding:1.05em 2.1em;border:1px solid var(--ink);background:var(--ink);color:#fff;
  border-radius:0;transition:.35s ease;
}
.btn:hover{background:transparent;color:var(--ink)}
.btn--ghost{background:transparent;color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:#fff}
.btn--light{border-color:#fff;background:transparent;color:#fff}
.btn--light:hover{background:#fff;color:var(--ink)}
.link-arrow{
  font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;font-weight:500;
  color:var(--ink);border-bottom:1px solid var(--accent);padding-bottom:.35em;
  display:inline-block;transition:.3s;
}
.link-arrow:hover{color:var(--accent-deep);gap:.8em}
.link-arrow span{transition:.3s;display:inline-block}
.link-arrow:hover span{transform:translateX(5px)}
.link-arrow--light{color:#fff;border-bottom-color:rgba(255,255,255,.55)}
.link-arrow--light:hover{color:#fff;border-bottom-color:#fff}

/* ---------- header ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px max(var(--gut),env(safe-area-inset-right)) 18px max(var(--gut),env(safe-area-inset-left));
  transition:background .4s,box-shadow .4s,padding .4s;
}
.site-header.solid{background:rgba(255,255,255,.96);box-shadow:0 1px 0 var(--line);backdrop-filter:saturate(1.2) blur(8px)}
.brand{display:flex;flex-direction:column;line-height:1;z-index:70}
.brand b{font-weight:500;letter-spacing:.28em;font-size:.96rem;text-transform:uppercase}
.brand small{font-weight:300;letter-spacing:.42em;font-size:.56rem;text-transform:uppercase;color:var(--muted);margin-top:5px}
.site-header.on-hero:not(.solid) .brand b{color:#fff}
.site-header.on-hero:not(.solid) .brand small{color:rgba(255,255,255,.8)}
.nav{display:flex;align-items:center;gap:34px}
.nav a{
  font-size:.73rem;letter-spacing:.16em;text-transform:uppercase;font-weight:400;
  color:var(--ink-soft);position:relative;padding:4px 0;transition:color .3s;
}
.nav a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--accent);transition:width .3s}
.nav a:hover,.nav a.active{color:var(--ink)}
.nav a:hover::after,.nav a.active::after{width:100%}
.site-header.on-hero:not(.solid) .nav a{color:rgba(255,255,255,.9)}
.site-header.on-hero:not(.solid) .nav a:hover{color:#fff}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;z-index:70;padding:6px}
.nav-toggle span{width:26px;height:2px;background:var(--ink);transition:.3s}
.site-header.on-hero:not(.solid) .nav-toggle span{background:#fff}

/* ---------- hero ---------- */
.hero{position:relative;min-height:100vh;min-height:100svh;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden}
.hero__bg{position:absolute;inset:0}
.hero__bg img{width:100%;height:100%;object-fit:cover}
.hero__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.4),rgba(0,0,0,.28) 40%,rgba(0,0,0,.5))}
.hero__inner{position:relative;z-index:2;max-width:880px;padding:0 24px}
.hero h1{font-family:var(--serif);font-weight:400;font-size:clamp(3.2rem,11vw,8rem);line-height:.95;letter-spacing:.01em}
.hero h1 em{font-style:italic}
.hero .kicker{display:block;font-family:var(--sans);font-size:.74rem;line-height:1.4;letter-spacing:.4em;text-transform:uppercase;margin-bottom:1.6rem;font-weight:400}
.hero .sub{font-size:clamp(1rem,2.2vw,1.25rem);font-weight:300;max-width:620px;margin:1.6rem auto 2.4rem;font-style:italic;font-family:var(--serif)}
.scroll-cue{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:2;font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.8);display:flex;flex-direction:column;align-items:center;gap:8px}
.scroll-cue::after{content:"";width:1px;height:42px;background:rgba(255,255,255,.6);animation:cue 1.8s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleY(.4);opacity:.4;transform-origin:top}50%{transform:scaleY(1);opacity:1;transform-origin:top}}

/* ---------- sections ---------- */
section{position:relative}
.pad{padding:clamp(70px,11vw,150px) 0}
.pad-sm{padding:clamp(48px,7vw,90px) 0}
.bg-cream{background:var(--cream)}
.bg-ink{background:var(--ink);color:#fff}
.center{text-align:center}
.section-head{max-width:720px}
.section-head.center{margin:0 auto}
.section-head h2{font-family:var(--serif);font-size:clamp(2.1rem,5vw,3.6rem);font-weight:400;letter-spacing:.01em;margin-bottom:.4em}
.section-head p{color:var(--ink-soft);font-size:1.02rem}
.bg-ink .section-head p{color:rgba(255,255,255,.75)}

/* split feature */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,6vw,80px);align-items:center}
.split.rev .split__media{order:2}
.split__media{position:relative}
.split__media img{width:100%;aspect-ratio:4/5;object-fit:cover;box-shadow:var(--shadow)}
.split__media .stack{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.split__media .stack img{aspect-ratio:3/4}
.split__body h2{font-family:var(--serif);font-size:clamp(1.9rem,4vw,3rem);margin-bottom:.5em}
.split__body p{color:var(--ink-soft)}
.split__body .btn,.split__body .link-arrow{margin-top:1.2rem}

/* tag row / stat */
.marquee{border-block:1px solid var(--line);padding:26px 0;overflow:hidden;white-space:nowrap}
.marquee__track{display:inline-flex;gap:54px;animation:slide 28s linear infinite;font-family:var(--serif);font-size:1.5rem;font-style:italic;color:var(--ink-soft)}
.marquee__track span{opacity:.85}
.marquee__track i{color:var(--accent);font-style:normal}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- featured mosaic (Work) ---------- */
.feat{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:240px 240px;gap:14px}
.feat__tile{position:relative;overflow:hidden;cursor:zoom-in;background:var(--cream)}
.feat__tile img{width:100%;height:100%;object-fit:cover;transition:.7s}
.feat__tile:hover img{transform:scale(1.05)}
.feat__tile--0{grid-row:span 2;grid-column:span 2}
.feat__tile--1{object-position:center 30%}
@media(max-width:760px){
  .feat{grid-template-columns:repeat(2,1fr);grid-template-rows:auto;gap:10px}
  .feat__tile{height:210px}
  .feat__tile--0{grid-column:span 2;grid-row:auto;height:300px}
}

/* ---------- gallery / masonry ---------- */
.masonry{columns:3;column-gap:16px}
.masonry img{width:100%;margin-bottom:16px;cursor:zoom-in;transition:.5s;break-inside:avoid;background:var(--cream)}
.masonry img:hover{filter:brightness(.94);transform:translateY(-2px)}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.grid-3 .tile{position:relative;overflow:hidden;cursor:zoom-in}
.grid-3 .tile img{aspect-ratio:3/4;object-fit:cover;width:100%;transition:.6s}
.grid-3 .tile:hover img{transform:scale(1.05)}
.gallery-filter{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:40px}
.gallery-filter button{font-family:var(--sans);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;background:none;border:1px solid var(--line);padding:.7em 1.4em;cursor:pointer;color:var(--ink-soft);transition:.3s}
.gallery-filter button.active,.gallery-filter button:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.gallery-filter button i{font-style:normal;opacity:.55;font-size:.85em;margin-left:.3em}

/* Work hero tweaks */
.work-hero{height:58vh;height:58svh;min-height:380px}

/* process steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,4vw,46px);counter-reset:s}
.step{position:relative;padding-top:30px;border-top:1px solid var(--line)}
.step::before{counter-increment:s;content:"0" counter(s);position:absolute;top:-2px;left:0;font-family:var(--serif);font-size:1.1rem;color:var(--accent)}
.step h4{font-size:1.05rem;font-weight:500;letter-spacing:.02em;margin:.2em 0 .5em}
.step p{color:var(--ink-soft);font-size:.95rem;margin:0}

/* number list (6 step) */
.numlist{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;background:var(--line);border:1px solid var(--line)}
.numlist .cell{background:var(--paper);padding:clamp(26px,3vw,40px)}
.numlist .cell .n{font-family:var(--serif);font-size:2.4rem;color:var(--accent);line-height:1;display:block;margin-bottom:.3em}
.numlist .cell p{margin:0;color:var(--ink-soft);font-size:.97rem}

/* ---------- blog ---------- */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(26px,3vw,40px)}
.post-card{display:flex;flex-direction:column}
.post-card__img{overflow:hidden;aspect-ratio:3/4;background:var(--cream)}
.post-card__img img{width:100%;height:100%;object-fit:cover;transition:.6s}
.post-card:hover .post-card__img img{transform:scale(1.04)}
.post-card .date{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin:1.3rem 0 .6rem}
.post-card h3{font-family:var(--serif);font-size:1.45rem;font-weight:500;line-height:1.2}
.post-card:hover h3{color:var(--accent-deep)}
.post-card__excerpt{color:var(--ink-soft);font-size:.92rem;line-height:1.55;margin:.7rem 0 0}

/* ---------- Journal (Projects & Blogs) — editorial layout ---------- */
.journal-intro{padding:clamp(120px,15vw,180px) 0 clamp(24px,4vw,44px);text-align:center;background:linear-gradient(180deg,var(--cream) 0%,var(--paper) 100%)}
.journal-intro .eyebrow{margin-bottom:1rem}
.journal-intro h1{font-family:var(--serif);font-weight:400;font-size:clamp(2.8rem,7vw,5.2rem);line-height:1.02}
.journal-intro p{max-width:580px;margin:1.2rem auto 0;color:var(--ink-soft)}

/* shared meta + category tag */
.j-meta{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin:1.2rem 0 .55rem;display:flex;align-items:center;gap:.55em;flex-wrap:wrap}
.j-meta span{color:var(--accent)}
.j-tag{position:absolute;top:14px;left:14px;z-index:2;font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;color:var(--ink);background:rgba(255,255,255,.92);padding:.5em .9em;backdrop-filter:blur(4px)}
.j-tag--solid{background:var(--accent);color:#fff}

/* featured cover story */
.cover{display:grid;grid-template-columns:1.12fr .88fr;gap:clamp(26px,5vw,64px);align-items:center}
.cover__media{position:relative;overflow:hidden;aspect-ratio:4/3;background:var(--cream)}
.cover__media img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.cover:hover .cover__media img{transform:scale(1.045)}
.cover__body .eyebrow{margin-bottom:.85rem}
.cover__body h2{font-family:var(--serif);font-weight:400;font-size:clamp(1.9rem,3.6vw,3.05rem);line-height:1.1;transition:color .3s}
.cover:hover .cover__body h2{color:var(--accent-deep)}
.cover__ex{color:var(--ink-soft);font-size:1.04rem;margin:1rem 0 0;max-width:46ch}
.cover__body .btn{margin-top:1.7rem}

/* archive header bar */
.journal-bar{display:flex;align-items:flex-end;justify-content:space-between;gap:22px;flex-wrap:wrap;margin-bottom:clamp(26px,4vw,44px)}
.journal-bar h2{font-size:clamp(1.7rem,3.2vw,2.4rem);font-weight:400}
.j-filter{margin-bottom:0;justify-content:flex-end}

/* archive grid */
.journal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(26px,3vw,42px)}
.j-card{display:flex;flex-direction:column}
.j-card__media{position:relative;overflow:hidden;aspect-ratio:4/5;background:var(--cream)}
.j-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .65s ease}
.j-card:hover .j-card__media img{transform:scale(1.05)}
.j-card h3{font-family:var(--serif);font-size:1.42rem;font-weight:500;line-height:1.2;transition:color .3s}
.j-card:hover h3{color:var(--accent-deep)}
.j-ex{color:var(--ink-soft);font-size:.92rem;line-height:1.55;margin:.7rem 0 0}
.j-more{margin-top:1rem;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;font-weight:500;color:var(--accent-deep);display:inline-flex;align-items:center;gap:.5em}
.j-more span{transition:transform .3s}
.j-card:hover .j-more span{transform:translateX(5px)}

/* cross-page interlinks */
.xlink-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.xlink{position:relative;overflow:hidden;min-height:320px;display:flex;align-items:flex-end;color:#fff}
.xlink img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.xlink:hover img{transform:scale(1.06)}
.xlink::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.12),rgba(0,0,0,.74))}
.xlink__in{position:relative;z-index:2;padding:30px}
.xlink__in h4{font-family:var(--serif);font-size:1.6rem;font-weight:500;margin-bottom:.35em}
.xlink__in p{font-size:.92rem;color:rgba(255,255,255,.82);margin:0 0 1rem;max-width:30ch}
.xlink__go{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;font-weight:500;display:inline-flex;align-items:center;gap:.5em}
.xlink__go span{transition:transform .3s}
.xlink:hover .xlink__go span{transform:translateX(5px)}

@media(max-width:900px){
  .cover{grid-template-columns:1fr;gap:22px}
  .cover__media{aspect-ratio:16/10}
  .journal-grid{grid-template-columns:1fr 1fr}
  .xlink-grid{grid-template-columns:1fr}
  .xlink{min-height:240px}
}
@media(max-width:560px){
  .journal-grid{grid-template-columns:1fr}
  .journal-bar{flex-direction:column;align-items:flex-start}
  .j-filter{justify-content:flex-start}
}

/* ---------- About page ---------- */
.about-hero{padding-top:clamp(130px,16vw,200px)}
.about-hero .split__media{position:relative}
.about-hero .media-cap{position:absolute;left:0;bottom:0;background:rgba(25,23,23,.78);color:#fff;font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;padding:.7em 1.1em;backdrop-filter:blur(4px)}
.about-name{font-family:var(--serif);font-weight:400;font-size:clamp(2.5rem,5.6vw,3.9rem);line-height:1.02;margin-bottom:.18em}
.about-sub{font-family:var(--serif);font-style:italic;color:var(--accent-deep);font-size:clamp(1.1rem,2vw,1.32rem);margin-bottom:1.5rem}

/* credentials stat band */
.stat-band{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border-block:1px solid var(--line)}
.stat-band .stat{background:var(--paper);padding:clamp(30px,4.5vw,52px) 24px;text-align:center}
.stat-band .stat .num{display:block;font-family:var(--serif);font-weight:500;font-size:clamp(2.3rem,5vw,3.4rem);color:var(--accent-deep);line-height:1}
.stat-band .stat .lbl{display:block;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:.95rem;line-height:1.5}
@media(max-width:640px){.stat-band{grid-template-columns:1fr}}

/* philosophy pull-quote */
.pullquote{max-width:920px;margin:0 auto;text-align:center;position:relative}
.pullquote::before{content:"\201C";font-family:var(--serif);font-size:clamp(4rem,9vw,7rem);color:var(--accent);opacity:.32;line-height:.7;display:block;margin-bottom:.1em}
.pullquote p{font-family:var(--serif);font-style:italic;font-size:clamp(1.5rem,3.4vw,2.5rem);line-height:1.36;color:var(--ink);margin:0}
.pullquote cite{display:block;font-style:normal;font-family:var(--sans);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-top:1.7rem}

/* article */
.article-hero{height:62vh;height:62svh;min-height:420px;position:relative;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.article-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.article-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.15),rgba(0,0,0,.62))}
.article-hero .wrap{position:relative;z-index:2;padding-bottom:48px}
.article-hero .date{font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;opacity:.85;margin-bottom:1rem}
.article-hero h1{font-family:var(--serif);font-weight:400;font-size:clamp(2.2rem,5vw,4rem);max-width:16ch}
.article{max-width:760px;margin:0 auto;padding:clamp(50px,8vw,90px) var(--gut)}
.article p{font-size:1.12rem;color:#2c2826;line-height:1.85;margin:0 0 1.4em}
.article h2,.article h3{font-family:var(--serif);font-weight:500;margin:1.8em 0 .6em;font-size:1.7rem}
.article figure{margin:2.4em 0}
.article figure img{width:100%}
.article .byline{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);border-top:1px solid var(--line);padding-top:1.4rem;margin-top:2.4rem}

/* ---------- wedding styling page ---------- */
.ws-hero{height:66vh;height:66svh;min-height:460px}
.ws-hero .wrap{padding-bottom:56px}
.ws-hero h1{max-width:16ch}
.ws-hero .ws-sub{color:rgba(255,255,255,.9);font-size:clamp(1rem,1.6vw,1.12rem);font-weight:300;margin-top:1rem;max-width:46ch}

/* function cards */
.func-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.func{background:var(--paper);border:1px solid var(--line);padding:32px 28px;transition:transform .35s,box-shadow .35s;position:relative;overflow:hidden}
.func::before{content:"";position:absolute;top:0;left:0;width:100%;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:.4s}
.func:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.func:hover::before{transform:scaleX(1)}
.func h4{font-family:var(--serif);font-size:1.45rem;font-weight:500;margin-bottom:.4em}
.func p{color:var(--ink-soft);font-size:.95rem;margin:0;line-height:1.55}

/* process timeline */
.timeline{position:relative;max-width:700px;margin:0 auto;padding-left:6px}
.timeline::before{content:"";position:absolute;left:23px;top:10px;bottom:10px;width:1px;background:var(--line)}
.tl-item{position:relative;padding:0 0 44px 76px}
.tl-item:last-child{padding-bottom:0}
.tl-num{position:absolute;left:0;top:-4px;width:48px;height:48px;border-radius:50%;border:1px solid var(--accent);color:var(--accent-deep);background:var(--paper);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:1.3rem;z-index:1}
.tl-item h4{font-size:1.12rem;font-weight:500;letter-spacing:.01em;margin-bottom:.45em}
.tl-item p{color:var(--ink-soft);margin:0;max-width:52ch}

/* what's included checklist */
.checklist{list-style:none;padding:0;margin:1.4rem 0 0;display:grid;grid-template-columns:1fr 1fr;gap:14px 28px}
.checklist li{position:relative;padding-left:30px;color:var(--ink-soft);font-size:.98rem;line-height:1.45}
.checklist li::before{content:"";position:absolute;left:2px;top:3px;width:15px;height:8px;border-left:2px solid var(--accent);border-bottom:2px solid var(--accent);transform:rotate(-45deg)}
@media(max-width:560px){.checklist{grid-template-columns:1fr;gap:12px}}

/* FAQ accordion */
.faq{max-width:760px;margin:0 auto;border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;background:none;border:0;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:24px;padding:26px 6px;font-family:var(--sans);font-size:clamp(1rem,1.6vw,1.1rem);font-weight:400;color:var(--ink);text-align:left;transition:color .25s}
.faq-q:hover{color:var(--accent-deep)}
.faq-q span{flex:none;width:24px;height:24px;position:relative}
.faq-q span::before,.faq-q span::after{content:"";position:absolute;background:var(--accent);transition:transform .3s}
.faq-q span::before{top:11px;left:3px;right:3px;height:2px}
.faq-q span::after{left:11px;top:3px;bottom:3px;width:2px}
.faq-item.open .faq-q span::after{transform:scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .45s ease}
.faq-a p{color:var(--ink-soft);padding:0 6px 26px;margin:0;max-width:66ch;line-height:1.7}
.faq-item.open .faq-a{max-height:360px}
@media(max-width:760px){
  .func-grid{grid-template-columns:1fr 1fr}
  .tl-item{padding-left:66px}
}
@media(max-width:480px){.func-grid{grid-template-columns:1fr}}

/* ---------- contact / forms ---------- */
.field{margin-bottom:22px}
.field label{display:block;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:.6rem}
.field input,.field textarea,.field select{
  width:100%;font-family:var(--sans);font-size:1rem;font-weight:300;color:var(--ink);
  background:var(--paper);border:1px solid var(--line);padding:.95em 1.1em;border-radius:0;transition:.25s;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--accent)}
.field textarea{min-height:150px;resize:vertical}
.form-note{font-size:.82rem;color:var(--muted);margin-top:6px}
.form-status{display:none;padding:1em 1.2em;font-size:.92rem;margin-top:14px}
.form-status.ok{display:block;background:#eef6ee;color:#2f6b34;border:1px solid #cfe6cf}
.form-status.err{display:block;background:#fbecec;color:#9b3434;border:1px solid #f0cfcf}
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(36px,6vw,80px)}
.contact-info a{display:block;font-family:var(--serif);font-size:1.5rem;color:var(--ink);margin:.2em 0 1rem;transition:.3s}
.contact-info a:hover{color:var(--accent)}
.contact-info .lbl{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-family:var(--sans)}

/* newsletter strip */
.news{display:flex;gap:14px;max-width:520px;flex-wrap:wrap}
.news input{flex:1;min-width:220px;border:1px solid rgba(255,255,255,.4);background:transparent;color:#fff;padding:1em 1.1em;font-family:var(--sans);font-weight:300}
.news input::placeholder{color:rgba(255,255,255,.6)}
.bg-ink .news input:focus{outline:none;border-color:#fff}

/* ---------- footer ---------- */
.site-footer{background:var(--ink);color:rgba(255,255,255,.72);padding:clamp(60px,8vw,100px) 0 36px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.3fr;gap:40px}
.footer-grid h5{font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:#fff;margin:0 0 1.3rem;font-weight:500}
.footer-grid a{display:block;color:rgba(255,255,255,.66);font-size:.92rem;margin-bottom:.7rem;transition:.25s}
.footer-grid a:hover{color:#fff}
.footer-brand b{font-family:var(--serif);font-size:1.7rem;color:#fff;letter-spacing:.04em;font-weight:500}
.footer-brand p{margin-top:1rem;font-size:.92rem;max-width:30ch;color:rgba(255,255,255,.6)}
.socials{display:flex;gap:14px;margin-top:1.4rem}
.socials a{width:38px;height:38px;border:1px solid rgba(255,255,255,.25);display:flex;align-items:center;justify-content:center;border-radius:50%;color:#fff}
.socials a:hover{background:#fff;color:var(--ink)}
.socials svg{width:16px;height:16px;fill:currentColor}
.footer-bottom{border-top:1px solid rgba(255,255,255,.13);margin-top:clamp(40px,6vw,70px);padding-top:28px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-size:.78rem;color:rgba(255,255,255,.5)}
.footer-bottom a{color:rgba(255,255,255,.5)}
.footer-bottom a:hover{color:#fff}

/* ---------- page header (interior) ---------- */
.page-hero{padding:clamp(130px,16vw,190px) 0 clamp(40px,6vw,70px);text-align:center;background:var(--cream)}
.page-hero .eyebrow{margin-bottom:1rem}
.page-hero h1{font-family:var(--serif);font-weight:400;font-size:clamp(2.6rem,7vw,5rem)}
.page-hero p{max-width:600px;margin:1.2rem auto 0;color:var(--ink-soft)}

/* ---------- lightbox ---------- */
.lb{position:fixed;inset:0;background:rgba(16,12,12,.94);z-index:200;display:none;align-items:center;justify-content:center;cursor:zoom-out}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:90vh;max-height:90dvh;object-fit:contain;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lb__close,.lb__nav{position:absolute;background:none;border:0;color:#fff;cursor:pointer;font-size:2rem;opacity:.8;transition:.2s}
.lb__close{top:24px;right:30px}
.lb__nav{top:50%;transform:translateY(-50%);font-size:3rem;padding:20px}
.lb__nav.prev{left:10px}.lb__nav.next{right:10px}
.lb__close:hover,.lb__nav:hover{opacity:1}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s ease,transform .9s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media(max-width:1000px){
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:820px){
  .masonry{columns:2}
}
@media(max-width:820px){
  .nav{
    position:fixed;inset:0;z-index:65;background:var(--ink);flex-direction:column;justify-content:center;
    gap:30px;padding:88px max(var(--gut),env(safe-area-inset-right)) calc(40px + env(safe-area-inset-bottom));
    overflow-y:auto;-webkit-overflow-scrolling:touch;
    transform:translateX(100%);visibility:hidden;
    transition:transform .4s ease, visibility 0s linear .4s;
  }
  .nav.open{transform:none;visibility:visible;transition:transform .4s ease, visibility 0s}
  .nav a{color:#fff!important;font-size:1.05rem;letter-spacing:.2em}
  .nav-toggle{display:flex}
  .nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg);background:#fff}
  .nav-toggle.open span:nth-child(2){opacity:0}
  .nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);background:#fff}
  .split{grid-template-columns:1fr;gap:34px}
  .split.rev .split__media{order:0}
  .steps{grid-template-columns:1fr}
  .numlist{grid-template-columns:1fr}
  .posts{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .masonry{columns:2;column-gap:10px}
  .masonry img{margin-bottom:10px}
  .posts{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr 1fr}
  body{font-size:16px}
}

/* ---------- small phones (≤380px) ---------- */
@media(max-width:380px){
  .brand b{font-size:.82rem;letter-spacing:.16em}
  .brand small{letter-spacing:.3em;font-size:.52rem}
  .btn{padding:.95em 1.5em;letter-spacing:.14em}
  .hero__inner{padding:0 16px}
  .gallery-filter button{padding:.6em 1em;letter-spacing:.12em}
  .grid-3{grid-template-columns:1fr}
  .footer-bottom{justify-content:center;text-align:center}
}

/* ---------- short / landscape viewports ---------- */
@media(max-height:560px) and (orientation:landscape){
  .hero{min-height:auto;padding:108px 0 72px}
  .work-hero,.ws-hero,.article-hero{height:auto;min-height:0;padding-top:112px;padding-bottom:54px}
  .scroll-cue{display:none}
}

/* ---------- keyboard focus (a11y, all platforms) ---------- */
:focus-visible{outline:2px solid var(--accent-deep);outline-offset:3px}
.btn:focus-visible,.nav a:focus-visible,.gallery-filter button:focus-visible{outline-offset:4px}

/* ---------- touch devices: no sticky hover states ---------- */
@media(hover:none){
  .feat__tile:hover img,.grid-3 .tile:hover img,.masonry img:hover,
  .post-card:hover .post-card__img img,.j-card:hover .j-card__media img,
  .cover:hover .cover__media img,.xlink:hover img,.split__media img:hover{transform:none}
  .func:hover{transform:none;box-shadow:none}
  .masonry img:hover{filter:none}
}

/* ---------- videos ---------- */
.video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:clamp(20px,2.4vw,32px)}
.video-card{background:#fff;border:1px solid var(--line);border-radius:4px;overflow:hidden;transition:border-color .3s,box-shadow .3s}
.video-card:hover{border-color:var(--accent);box-shadow:0 14px 34px -22px rgba(25,23,23,.4)}
.bg-cream .video-card{background:var(--paper)}
.video-embed{position:relative;width:100%;padding-bottom:56.25%;background:var(--ink)}
.video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-meta{padding:1rem 1.15rem 1.25rem}
.video-meta .v-year{font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-deep);margin:0 0 .35rem}
.video-meta .v-title{font-size:1.3rem;line-height:1.2;margin:0 0 .4rem}
.video-meta .v-cast{font-size:.86rem;color:var(--ink-soft);line-height:1.5;margin:0}
.video-meta .v-role{display:inline-block;margin-top:.7rem;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);border:1px solid var(--line);padding:.28em .7em;border-radius:2px}
.actors-list{display:flex;flex-wrap:wrap;gap:.5rem 1rem}
.actor-tag{font-family:var(--serif);font-size:clamp(1.05rem,2vw,1.3rem);font-style:italic;color:var(--ink-soft);transition:color .25s}
.actor-tag::after{content:" ·";color:var(--accent)}
.actor-tag:last-child::after{content:""}
.actor-tag:hover{color:var(--ink)}
@media(max-width:560px){.video-grid{grid-template-columns:1fr}}

/* ---------- reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{
    animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important;
  }
  .reveal{opacity:1!important;transform:none!important}
  .marquee__track,.scroll-cue::after{animation:none!important}
}
