/* ============================================================================
   THE PAINTED VIEW INTERIORS  —  bespoke design system
   Coastal-luxury editorial. Warm ivory paper, deep ocean ink, powder-blue signal.
   Type: Fraunces (display) · Newsreader (reading) · Jost (micro-labels)
   Built for readability first (audience skews 50+): large type, high contrast.
   ========================================================================== */

/* ---------- tokens ---------- */
:root{
  /* palette — her coastal palette, refined: warm white, charcoal, powder blue */
  --paper:      #FAF9F6;   /* warm white */
  --paper-alt:  #EEF1F4;   /* whisper powder-blue grey for alt sections */
  --paper-deep: #E3E8ED;   /* deeper tint / fills */
  --ink:        #20262B;   /* charcoal (softer than black) */
  --ink-soft:   #383F45;   /* strong body text */
  --muted:      #626A70;   /* secondary text (AA on warm white) */
  --powder:     #8EB6DC;   /* signature powder blue (her accent) */
  --powder-soft:#CFDEEB;   /* washed powder for tints */
  --blue:       #2F6E97;   /* mid coastal blue — links / accents */
  --blue-deep:  #1C4E6E;   /* deep coastal */
  --blue-ink:   #14384F;   /* deepest — footer / overlay */
  --gold:       #B08A50;   /* restrained brass whisper */
  --line:       rgba(32,38,43,.14);
  --line-soft:  rgba(32,38,43,.08);

  /* type — architectural sans, with a serif reserved for accents */
  --f-display: "Hanken Grotesk", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
  --f-body:    "Hanken Grotesk", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
  --f-ui:      "Hanken Grotesk", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
  --f-serif:   "Newsreader", Georgia, "Times New Roman", serif;

  --stone:      #EDE7DB;   /* soft greige for quiet panels */

  /* rhythm — generous, gallery-like spacing */
  --wrap: 1440px;
  --wrap-narrow: 800px;
  --gut: clamp(1.4rem, 4.5vw, 5.5rem);
  --section-y: clamp(6rem, 12vw, 13.5rem);

  /* motion */
  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
  --dur: .9s;
}

/* ---------- reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion:reduce){ html{ scroll-behavior:auto; } }
body{
  margin:0;
  background:var(--paper);
  color:var(--ink-soft);
  font-family:var(--f-body);
  font-size:clamp(1.06rem, .6rem + .62vw, 1.22rem); /* ~17→19.5px sans, generous for 50+ */
  line-height:1.66;
  font-weight:400;
  letter-spacing:.0;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; cursor:pointer; }
h1,h2,h3,h4{ margin:0; font-weight:400; }
p{ margin:0 0 1.15em; }
::selection{ background:var(--powder); color:var(--blue-ink); }

/* ---------- type scale ---------- */
.display,h1.h,h2.h,h3.h{
  font-family:var(--f-display);
  font-weight:400;
  line-height:1.06;
  letter-spacing:-.02em;
  color:var(--ink);
  text-wrap:balance;
}
.d-hero{ font-size:clamp(2.7rem, 1rem + 6.2vw, 6.8rem); line-height:1.0; font-weight:350; letter-spacing:-.03em; }
.d-1{    font-size:clamp(2.1rem, 1rem + 3.6vw, 4.2rem); font-weight:370; letter-spacing:-.025em; }
.d-2{    font-size:clamp(1.7rem, 1rem + 2.4vw, 2.9rem); font-weight:400; letter-spacing:-.02em; }
.d-3{    font-size:clamp(1.3rem, 1rem + 1.2vw, 1.9rem); line-height:1.18; font-weight:450; letter-spacing:-.015em; }

/* serif accent — used sparingly for pull-quotes & emphasis */
.serif{ font-family:var(--f-serif); font-weight:400; }
em,.italic{ font-style:italic; }

/* eyebrow / kicker — finely-tracked caps */
.eyebrow{
  font-family:var(--f-ui);
  font-weight:600;
  font-size:.7rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--blue);
  display:inline-flex; align-items:center; gap:1em;
}
.eyebrow::before{
  content:""; width:2.8em; height:1px; background:currentColor; opacity:.55;
}
.eyebrow.center{ justify-content:center; }
.eyebrow.plain::before{ display:none; }

.lead{
  font-size:clamp(1.2rem, .9rem + .9vw, 1.5rem);
  line-height:1.6; color:var(--ink-soft);
  font-weight:380; letter-spacing:.005em;
}
.serif-italic{ font-style:italic; }

/* ---------- layout primitives ---------- */
.wrap{ width:100%; max-width:var(--wrap); margin-inline:auto; padding-inline:var(--gut); }
.narrow{ max-width:var(--wrap-narrow); margin-inline:auto; }
.section{ padding-block:var(--section-y); }
.section.tight{ padding-block:clamp(3rem,6vw,6rem); }
.bg-alt{ background:var(--paper-alt); }
.bg-deep{ background:var(--blue-deep); color:var(--paper); }
.bg-ink{ background:var(--ink); color:var(--paper); }
.center{ text-align:center; }
.rule{ height:1px; background:var(--line); border:0; margin:0; }

/* ---------- buttons ---------- */
.btn{
  --bg:var(--ink); --fg:var(--paper);
  font-family:var(--f-ui); font-weight:500;
  font-size:.82rem; letter-spacing:.2em; text-transform:uppercase;
  display:inline-flex; align-items:center; gap:.9em;
  padding:1.15em 2.1em; min-height:56px;
  background:var(--bg); color:var(--fg);
  border:1px solid var(--bg); border-radius:0;
  position:relative; overflow:hidden; isolation:isolate;
  transition:color .5s var(--ease), border-color .5s var(--ease);
}
.btn .btn-t{ position:relative; z-index:2; }
.btn::after{
  content:""; position:absolute; inset:0; z-index:1;
  background:var(--fg); transform:scaleY(0); transform-origin:bottom;
  transition:transform .5s var(--ease);
}
.btn:hover{ color:var(--bg); }
.btn:hover::after{ transform:scaleY(1); }
.btn .arw{ transition:transform .5s var(--ease); }
.btn:hover .arw{ transform:translateX(.35em); }
.btn.ghost{ --bg:transparent; --fg:var(--ink); color:var(--ink); border-color:var(--ink); }
.btn.ghost::after{ background:var(--ink); }
.btn.ghost:hover{ color:var(--paper); }
.btn.on-dark{ --bg:var(--paper); --fg:var(--blue-deep); }
.btn.ghost.on-dark{ --bg:transparent; --fg:var(--paper); color:var(--paper); border-color:rgba(251,249,244,.5); }
.btn.ghost.on-dark::after{ background:var(--paper); }
.btn.ghost.on-dark:hover{ color:var(--blue-deep); }

/* text link with drawn underline */
.tlink{
  font-family:var(--f-ui); font-weight:500; font-size:.82rem;
  letter-spacing:.18em; text-transform:uppercase; color:var(--ink);
  display:inline-flex; align-items:center; gap:.7em; position:relative;
}
.tlink::after{
  content:""; position:absolute; left:0; bottom:-.4em; height:1px; width:100%;
  background:currentColor; transform:scaleX(0); transform-origin:left;
  transition:transform .5s var(--ease);
}
.tlink:hover::after{ transform:scaleX(1); }
.tlink .arw{ transition:transform .45s var(--ease); }
.tlink:hover .arw{ transform:translateX(.3em); }

/* ============================================================================
   HEADER  —  minimal top bar + full-screen overlay menu
   ========================================================================== */
.site-head{
  position:fixed; inset:0 0 auto 0; z-index:60;
  display:flex; align-items:center; justify-content:space-between;
  gap:2rem; padding:1.5rem var(--gut);
  transition:transform .55s var(--ease), background .5s var(--ease), padding .5s var(--ease), box-shadow .5s var(--ease);
  color:var(--paper); mix-blend-mode:normal;
}
.site-head.solid{
  background:rgba(250,249,246,.9); -webkit-backdrop-filter:blur(10px); backdrop-filter:blur(10px);
  color:var(--ink); box-shadow:0 1px 0 var(--line-soft);
  padding-block:1rem;
}
.site-head.hide{ transform:translateY(-108%); }
.brand{ display:flex; align-items:center; line-height:0; }
.brand-logo{ width:auto; height:clamp(30px,3.2vw,42px); display:block; transition:filter .4s var(--ease); }
.site-head:not(.solid) .brand-logo{ filter:brightness(0) invert(1); }   /* white over hero image */
.site-head.solid .brand-logo{ filter:none; }                            /* natural blue on light */
body.menu-open .brand-logo{ filter:brightness(0) invert(1)!important; } /* white over dark overlay */

/* visible desktop nav */
.nav-inline{ display:none; }
@media(min-width:900px){ .nav-inline{ display:flex; align-items:center; gap:clamp(1.5rem,2.4vw,2.6rem); } }
.nav-inline a{ font-family:var(--f-ui); font-weight:600; font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; position:relative; padding:.5em 0; color:inherit; }
.nav-inline a::after{ content:""; position:absolute; left:0; right:0; bottom:0; height:1.5px; background:currentColor; transform:scaleX(0); transform-origin:left; transition:transform .45s var(--ease); }
.nav-inline a:hover::after, .nav-inline a[aria-current]::after{ transform:scaleX(1); }

.head-right{ display:flex; align-items:center; gap:clamp(1.2rem,2.4vw,2.2rem); }
.head-cta{ font-family:var(--f-ui); font-weight:600; font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; position:relative; padding:.3em 0; }
.head-cta::after{ content:""; position:absolute; left:0; right:0; bottom:0; height:1px; background:currentColor; transform:scaleX(0); transform-origin:left; transition:transform .45s var(--ease); }
.head-cta:hover::after{ transform:scaleX(1); }
@media(max-width:899px){ .head-cta{ display:none; } }

.menu-btn{ display:inline-flex; align-items:center; gap:.7em; background:none; border:0; color:inherit; padding:.4em 0; }
@media(min-width:900px){ .menu-btn{ display:none; } }  /* desktop shows inline nav instead */
.menu-btn .mb-label{ font-weight:600; font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; }
.menu-btn .mb-mark{ position:relative; width:26px; height:10px; display:inline-block; }
.menu-btn .mb-mark i{ position:absolute; left:0; right:0; height:1.5px; background:currentColor; transition:transform .4s var(--ease), width .4s var(--ease); }
.menu-btn .mb-mark i:nth-child(1){ top:2px; } .menu-btn .mb-mark i:nth-child(2){ bottom:2px; width:66%; }
.menu-btn:hover .mb-mark i:nth-child(2){ width:100%; }
.menu-btn[aria-expanded="true"] .mb-mark i:nth-child(1){ top:4px; width:100%; transform:rotate(45deg); }
.menu-btn[aria-expanded="true"] .mb-mark i:nth-child(2){ bottom:4px; width:100%; transform:rotate(-45deg); }
/* keep the bar (brand + close) above the overlay when open */
body.menu-open .site-head{ z-index:90; color:var(--paper); background:transparent!important; -webkit-backdrop-filter:none; backdrop-filter:none; box-shadow:none!important; transform:none!important; }
body.menu-open .site-head.hide{ transform:none!important; }

/* full-screen overlay */
.menu-overlay{
  position:fixed; inset:0; z-index:80; background:var(--blue-ink); color:var(--paper);
  clip-path:inset(0 0 100% 0); transition:clip-path .7s var(--ease); visibility:hidden;
}
.menu-overlay.open{ clip-path:inset(0 0 0 0); visibility:visible; }
.mo-grid{ height:100%; display:grid; grid-template-columns:1fr; }
@media(min-width:900px){ .mo-grid{ grid-template-columns:1.15fr .85fr; } }
.mo-main{ display:flex; flex-direction:column; justify-content:center; padding:clamp(5rem,10vw,7rem) var(--gut) clamp(2.5rem,5vw,4rem); gap:clamp(1.5rem,3vw,2.5rem); }
.mo-kicker{ color:var(--powder); }
.mo-nav{ display:flex; flex-direction:column; gap:.1em; }
.mo-nav a{ font-family:var(--f-display); font-weight:400; font-size:clamp(2.4rem,7vw,5rem); line-height:1.16; letter-spacing:-.02em; color:var(--paper); width:max-content; max-width:100%; position:relative; opacity:.92; transition:opacity .4s, transform .5s var(--ease), color .4s; }
.mo-nav a span{ position:relative; }
.mo-nav a::before{ content:""; position:absolute; left:-.7em; top:50%; width:.32em; height:.32em; border-radius:50%; background:var(--powder); transform:translateY(-50%) scale(0); transition:transform .4s var(--ease); }
.mo-nav a:hover{ opacity:1; transform:translateX(.7em); color:#fff; }
.mo-nav a:hover::before{ transform:translateY(-50%) scale(1); }
.mo-nav a[aria-current]{ color:var(--powder); }
.mo-foot{ display:flex; flex-wrap:wrap; gap:1.4rem 2.2rem; align-items:center; margin-top:1rem; font-weight:500; font-size:.82rem; letter-spacing:.12em; text-transform:uppercase; color:rgba(250,249,246,.72); }
.mo-foot a:hover{ color:#fff; }
.mo-social{ display:flex; gap:1.4rem; }
.mo-media{ position:relative; overflow:hidden; display:none; }
@media(min-width:900px){ .mo-media{ display:block; } }
.mo-media img{ width:100%; height:100%; object-fit:cover; transform:scale(1.05); transition:transform 8s var(--ease-out); }
.menu-overlay.open .mo-media img{ transform:scale(1); }
.mo-media::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(20,56,79,.1),rgba(20,56,79,.5)); }
.mo-cap{ position:absolute; left:1.6rem; bottom:1.4rem; z-index:2; font-weight:500; font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.85); }
/* staggered link entrance */
.menu-overlay .mo-nav a, .menu-overlay .mo-kicker, .menu-overlay .mo-foot{ opacity:0; transform:translateY(18px); }
.menu-overlay.open .mo-kicker{ transition:opacity .6s .18s, transform .6s .18s var(--ease); opacity:1; transform:none; }
.menu-overlay.open .mo-nav a{ transition:opacity .6s var(--ease), transform .6s var(--ease), color .4s; opacity:.92; transform:none; }
.menu-overlay.open .mo-nav a:nth-child(1){ transition-delay:.24s; } .menu-overlay.open .mo-nav a:nth-child(2){ transition-delay:.31s; }
.menu-overlay.open .mo-nav a:nth-child(3){ transition-delay:.38s; } .menu-overlay.open .mo-nav a:nth-child(4){ transition-delay:.45s; }
.menu-overlay.open .mo-nav a:nth-child(5){ transition-delay:.52s; }
.menu-overlay.open .mo-foot{ transition:opacity .6s .55s, transform .6s .55s var(--ease); opacity:1; transform:none; }
body.menu-open{ overflow:hidden; }

/* ============================================================================
   HERO
   ========================================================================== */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end; color:var(--paper); overflow:hidden; }
.hero-media{ position:absolute; inset:0; z-index:0; }
.hero-media img{ width:100%; height:100%; object-fit:cover; transform:scale(1.12); }
.hero.loaded .hero-media img{ animation:kenburns 18s var(--ease-out) forwards; }
@keyframes kenburns{ to{ transform:scale(1.0); } }
.hero-media::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(11,46,69,.42) 0%, rgba(11,46,69,.10) 30%, rgba(11,30,45,.30) 60%, rgba(9,26,40,.86) 100%),
    linear-gradient(75deg, rgba(9,26,40,.55) 0%, rgba(9,26,40,.20) 42%, rgba(9,26,40,0) 68%);
}
.hero-inner{ position:relative; z-index:2; width:100%; max-width:var(--wrap); margin-inline:auto; padding:0 var(--gut) clamp(3.2rem,7vw,6rem); }
.hero-eyebrow{ color:var(--powder-soft); margin-bottom:1.5rem; }
.hero h1{ color:#fff; max-width:16ch; margin-bottom:1.6rem; text-shadow:0 2px 40px rgba(6,24,38,.35); }
.hero-sub{ max-width:44ch; color:rgba(255,255,255,.92); font-size:clamp(1.1rem,.9rem+.6vw,1.4rem); line-height:1.62; margin-bottom:2.3rem; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:1rem 1.4rem; align-items:center; }
.scroll-cue{ position:absolute; left:var(--gut); bottom:1.6rem; z-index:2; display:flex; align-items:center; gap:.8em; font-family:var(--f-ui); letter-spacing:.24em; text-transform:uppercase; font-size:.66rem; color:rgba(255,255,255,.82); }
.scroll-cue .line{ width:52px; height:1px; background:rgba(255,255,255,.6); position:relative; overflow:hidden; }
.scroll-cue .line::after{ content:""; position:absolute; inset:0; background:#fff; transform:translateX(-100%); animation:cue 2.6s var(--ease) infinite; }
@keyframes cue{ 0%{transform:translateX(-100%);} 55%{transform:translateX(0);} 100%{transform:translateX(100%);} }
.hero-side{ position:absolute; right:calc(var(--gut) - .2rem); bottom:clamp(3.2rem,7vw,6rem); z-index:2; writing-mode:vertical-rl; font-family:var(--f-ui); letter-spacing:.32em; text-transform:uppercase; font-size:.68rem; color:rgba(255,255,255,.72); }

/* ============================================================================
   FULL-BLEED IMAGE MOMENT
   ========================================================================== */
.fullbleed{ position:relative; height:84svh; min-height:560px; overflow:hidden; display:flex; align-items:flex-end; }
.fb-media{ position:absolute; inset:0; }
.fb-media img{ width:100%; height:100%; object-fit:cover; }
.fb-media::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(9,26,40,.18) 0%, rgba(9,26,40,0) 38%, rgba(9,26,40,.66) 100%); }
.fb-cap{ position:relative; z-index:2; padding-bottom:clamp(2.6rem,5vw,4.8rem); color:var(--paper); }
.fb-line{ font-family:var(--f-display); font-weight:330; color:#fff; font-size:clamp(1.7rem,1rem+2.4vw,3.3rem); line-height:1.18; max-width:19ch; margin-top:1.1rem; letter-spacing:-.01em; }

/* ============================================================================
   MARQUEE (editorial moving band)
   ========================================================================== */
.marquee{ overflow:hidden; border-block:1px solid var(--line); padding-block:1.25rem; background:var(--paper); }
.marquee.on-deep{ background:transparent; border-color:rgba(251,249,244,.18); }
.marquee-track{ display:flex; gap:2.5rem; width:max-content; animation:marq 42s linear infinite; will-change:transform; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
.marquee-track span{ font-family:var(--f-display); font-size:clamp(1.4rem,3vw,2.4rem); color:var(--ink); font-weight:360; display:inline-flex; align-items:center; gap:2.5rem; }
.on-deep .marquee-track span{ color:var(--paper); }
.marquee-track span::after{ content:"❋"; font-size:.7em; color:var(--powder); }
@keyframes marq{ to{ transform:translateX(-50%); } }

/* ============================================================================
   INTRO / STATEMENT
   ========================================================================== */
.statement{ display:grid; grid-template-columns:1fr; gap:clamp(1.5rem,4vw,3rem); }
.statement .lead-xl{
  font-family:var(--f-serif); font-weight:400; letter-spacing:-.005em;
  font-size:clamp(1.7rem,1rem+2.4vw,3rem); line-height:1.28; color:var(--ink); text-wrap:balance;
}
.statement .lead-xl em{ font-style:italic; color:var(--blue); }

/* stat row — airy, no boxes, hairline dividers */
.stats{ display:grid; grid-template-columns:repeat(3,1fr); border-top:1px solid var(--line); }
.stat{ padding:clamp(2rem,4vw,3.4rem) clamp(1rem,2vw,2rem); text-align:center; position:relative; }
.stat + .stat::before{ content:""; position:absolute; left:0; top:22%; bottom:22%; width:1px; background:var(--line); }
.stat .n{ font-family:var(--f-display); font-size:clamp(2.6rem,1rem+3.4vw,4.2rem); line-height:1; color:var(--blue-deep); font-weight:330; letter-spacing:-.01em; }
.stat .l{ font-family:var(--f-ui); letter-spacing:.24em; text-transform:uppercase; font-size:.68rem; color:var(--muted); margin-top:1.1em; }

/* ============================================================================
   SECTION HEADINGS
   ========================================================================== */
.sec-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:2rem; flex-wrap:wrap; margin-bottom:clamp(2.2rem,4vw,3.6rem); }
.sec-head .sh-l{ max-width:40ch; }
.sec-head .eyebrow{ margin-bottom:1.1rem; }
.sec-head.center{ flex-direction:column; align-items:center; text-align:center; }
.sec-head.center .sh-l{ max-width:52ch; }

/* ============================================================================
   PORTFOLIO — editorial index + featured
   ========================================================================== */
.folio-feature{ display:grid; grid-template-columns:1fr; gap:clamp(1.4rem,3vw,2.4rem); align-items:center; }
@media(min-width:900px){ .folio-feature{ grid-template-columns:1.35fr .9fr; gap:clamp(2rem,4vw,4.5rem); } .folio-feature.flip{ grid-template-columns:.9fr 1.35fr; } .folio-feature.flip .ff-media{ order:2; } }
.ff-media{ position:relative; overflow:hidden; }
.ff-media .frame{ overflow:hidden; }
.ff-media img{ width:100%; aspect-ratio:4/3; object-fit:cover; transition:transform 1.2s var(--ease-out); }
.folio-feature:hover .ff-media img{ transform:scale(1.045); }
.ff-index{ position:absolute; top:1rem; left:1rem; font-family:var(--f-ui); font-size:.72rem; letter-spacing:.24em; color:#fff; background:rgba(11,46,69,.55); backdrop-filter:blur(3px); padding:.5em .9em; }
.ff-body .eyebrow{ margin-bottom:1.1rem; }
.ff-body h3{ margin-bottom:1rem; }
.ff-meta{ font-family:var(--f-ui); font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin-bottom:1.6rem; display:flex; gap:1.2em; flex-wrap:wrap; }

/* project index (magazine contents) */
.folio-index{ border-top:1px solid var(--line); }
.folio-row{
  display:grid; grid-template-columns:1fr auto auto; align-items:center; gap:clamp(1rem,3vw,2.5rem);
  padding:clamp(1.3rem,2.6vw,2.1rem) 0; border-bottom:1px solid var(--line);
  position:relative; transition:padding-inline .5s var(--ease);
}
.folio-row .fr-title{ font-family:var(--f-display); font-weight:400; font-size:clamp(1.5rem,1rem+2vw,2.6rem); color:var(--ink); line-height:1.06; letter-spacing:-.02em; transition:color .4s var(--ease), transform .5s var(--ease); }
.folio-row .fr-tag{ font-family:var(--f-ui); font-weight:500; font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); }
.folio-row .fr-arw{ transition:transform .5s var(--ease), opacity .4s; opacity:.3; }
.folio-row:hover{ padding-inline:clamp(.4rem,1.5vw,1.4rem); }
.folio-row:hover .fr-title{ color:var(--blue); }
.folio-row:hover .fr-arw{ opacity:1; transform:translateX(.4em); }
/* floating preview on hover (desktop) */
.folio-row .fr-preview{
  position:absolute; right:16%; top:50%; width:min(28vw,340px); aspect-ratio:4/3; z-index:5;
  transform:translate(0,-46%) scale(.94); opacity:0; pointer-events:none; overflow:hidden;
  box-shadow:0 40px 80px -40px rgba(11,46,69,.6); transition:opacity .45s var(--ease), transform .55s var(--ease);
}
.folio-row .fr-preview img{ width:100%; height:100%; object-fit:cover; }
@media(hover:hover) and (min-width:1000px){ .folio-row:hover .fr-preview{ opacity:1; transform:translate(0,-50%) scale(1); } }
@media(max-width:640px){ .folio-row{ grid-template-columns:1fr auto; } .folio-row .fr-tag{ display:none; } }

/* portfolio landing grid (all projects) — clean editorial pairs + full features */
.folio-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(2.2rem,4vw,4rem) clamp(1.4rem,2.4vw,2.6rem); }
.folio-card{ grid-column:span 2; display:block; }
@media(min-width:760px){ .folio-card.half{ grid-column:span 1; } .folio-card.full{ grid-column:span 2; } }
.folio-card .frame{ overflow:hidden; position:relative; }
.folio-card img{ width:100%; aspect-ratio:4/3; object-fit:cover; transition:transform 1.1s var(--ease-out); }
@media(min-width:760px){ .folio-card.full img{ aspect-ratio:16/7.5; } }
.folio-card:hover img{ transform:scale(1.05); }
.folio-card .fc-cap{ display:flex; justify-content:space-between; align-items:baseline; gap:1rem; padding-top:1.05rem; }
.folio-card .fc-cap h3{ font-family:var(--f-display); font-weight:450; font-size:clamp(1.25rem,1rem+.9vw,1.65rem); color:var(--ink); letter-spacing:-.02em; }
.folio-card .fc-cap .n{ font-size:1.2rem; color:var(--blue); transition:transform .5s var(--ease); }
.folio-card:hover .fc-cap .n{ transform:translateX(.4em); }
.folio-card .frame::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 55%,rgba(11,46,69,.28)); opacity:0; transition:opacity .5s; }
.folio-card:hover .frame::after{ opacity:1; }

/* ============================================================================
   PROJECT DETAIL — galleries
   ========================================================================== */
.proj-hero{ position:relative; height:78svh; min-height:520px; overflow:hidden; color:#fff; display:flex; align-items:flex-end; }
.proj-hero img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.proj-hero::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(11,46,69,.35),rgba(11,30,45,.05) 40%,rgba(11,30,45,.7)); }
.proj-hero .ph-inner{ position:relative; z-index:2; width:100%; max-width:var(--wrap); margin-inline:auto; padding:0 var(--gut) clamp(2.4rem,5vw,4rem); }
.proj-hero .eyebrow{ color:var(--powder-soft); margin-bottom:1rem; }
.proj-hero h1{ color:#fff; }
.proj-intro{ display:grid; gap:1.4rem; grid-template-columns:1fr; }
@media(min-width:860px){ .proj-intro{ grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,5rem); align-items:end; } }
.proj-meta{ display:flex; flex-direction:column; gap:.9rem; }
.proj-meta .row{ display:flex; justify-content:space-between; gap:1rem; padding-bottom:.9rem; border-bottom:1px solid var(--line); font-family:var(--f-ui); font-size:.8rem; letter-spacing:.1em; text-transform:uppercase; }
.proj-meta .row .k{ color:var(--muted); } .proj-meta .row .v{ color:var(--ink); }

.gallery{ display:grid; grid-template-columns:repeat(12,1fr); gap:clamp(.9rem,1.6vw,1.6rem); }
.gallery figure{ margin:0; grid-column:span 12; overflow:hidden; }
.gallery img{ width:100%; height:auto; object-fit:cover; }
@media(min-width:760px){
  .gallery figure.half{ grid-column:span 6; }
  .gallery figure.full{ grid-column:span 12; }
  .gallery figure.wide{ grid-column:span 8; }
  .gallery figure.narrow{ grid-column:span 4; }
}
.gallery figure .frame{ overflow:hidden; }
.gallery figure img{ transition:transform 1.4s var(--ease-out); }
.gallery figure:hover img{ transform:scale(1.035); }

/* prev / next projects */
.pager{ display:grid; grid-template-columns:1fr 1fr; border-top:1px solid var(--line); }
.pager a{ padding:clamp(2rem,4vw,3.4rem) var(--gut); position:relative; overflow:hidden; }
.pager a.next{ text-align:right; border-left:1px solid var(--line); }
.pager .p-k{ font-family:var(--f-ui); letter-spacing:.2em; text-transform:uppercase; font-size:.72rem; color:var(--muted); display:block; margin-bottom:.7rem; }
.pager .p-t{ font-family:var(--f-display); font-size:clamp(1.4rem,1rem+1.6vw,2.2rem); color:var(--ink); transition:color .4s; }
.pager a:hover .p-t{ color:var(--blue); }

/* ============================================================================
   ABOUT / TEAM
   ========================================================================== */
.about-grid{ display:grid; grid-template-columns:1fr; gap:clamp(2rem,5vw,4rem); align-items:start; }
@media(min-width:960px){ .about-grid{ grid-template-columns:.85fr 1.15fr; gap:clamp(2.5rem,6vw,6rem); } }
.about-media{ position:relative; }
.about-media img{ width:100%; aspect-ratio:4/5; object-fit:cover; }
.about-media .tag{ position:absolute; bottom:-1px; left:-1px; background:var(--blue-deep); color:var(--paper); padding:1.1rem 1.5rem; font-family:var(--f-ui); font-size:.74rem; letter-spacing:.2em; text-transform:uppercase; }
.about-body p{ font-size:clamp(1.05rem,.95rem+.45vw,1.24rem); }
.about-body p:first-of-type{ font-family:var(--f-serif); font-weight:400; font-size:clamp(1.35rem,1rem+1.3vw,1.9rem); line-height:1.4; color:var(--ink); }

.team-grid{ display:grid; grid-template-columns:1fr; gap:clamp(2rem,4vw,3rem); }
@media(min-width:720px){ .team-grid{ grid-template-columns:repeat(3,1fr); } }
.team-card .frame{ overflow:hidden; margin-bottom:1.4rem; }
.team-card img{ width:100%; aspect-ratio:4/5; object-fit:cover; filter:saturate(.96); transition:transform 1.2s var(--ease-out); }
.team-card:hover img{ transform:scale(1.04); }
.team-card h3{ font-family:var(--f-display); font-size:clamp(1.4rem,1rem+1vw,1.8rem); color:var(--ink); }
.team-card .role{ font-family:var(--f-ui); font-size:.76rem; letter-spacing:.2em; text-transform:uppercase; color:var(--blue); margin:.55rem 0 1.1rem; }
.team-card .bio{ font-size:1.02rem; line-height:1.66; color:var(--ink-soft); }

/* services — editorial list, oversized names, hairline rules */
.services-list{ border-top:1px solid var(--line); }
.service-row{ display:grid; grid-template-columns:1fr auto; align-items:center; gap:clamp(1.2rem,4vw,3rem);
  padding:clamp(1.5rem,3.2vw,2.6rem) 0; border-bottom:1px solid var(--line); transition:padding-inline .5s var(--ease); }
.service-row .s-t{ font-family:var(--f-display); font-weight:400; font-size:clamp(1.7rem,1rem+2.6vw,3.2rem); line-height:1.04; color:var(--ink); letter-spacing:-.025em; transition:color .4s var(--ease); }
.service-row .s-x{ color:var(--powder); font-size:1.4rem; opacity:0; transform:translateX(-.4em); transition:opacity .4s,transform .5s var(--ease); }
.service-row:hover{ padding-inline:clamp(.4rem,1.6vw,1.5rem); }
.service-row:hover .s-t{ color:var(--blue); }
.service-row:hover .s-x{ opacity:1; transform:none; }

/* ============================================================================
   TESTIMONIALS
   ========================================================================== */
/* testimonials — quiet, borderless, generous */
.quotes{ display:grid; grid-template-columns:1fr; gap:clamp(2.6rem,5vw,4rem); }
@media(min-width:860px){ .quotes{ grid-template-columns:repeat(3,1fr); gap:clamp(2rem,4vw,4.5rem); } }
.quote-card{ position:relative; padding-top:2.2rem; border-top:1px solid var(--line); }
.quote-card .mark{ position:absolute; top:.7rem; left:0; font-family:var(--f-display); font-size:2.4rem; line-height:1; color:var(--powder); }
.quote-card blockquote{ margin:0 0 1.8rem; font-family:var(--f-serif); font-style:italic; font-size:clamp(1.18rem,1rem+.55vw,1.42rem); line-height:1.5; color:var(--ink); font-weight:400; }
.quote-card .by{ font-family:var(--f-ui); font-size:.72rem; font-weight:600; letter-spacing:.2em; text-transform:uppercase; color:var(--blue); }
/* a single oversized pull-quote variant */
.quote-hero{ max-width:24ch; margin:0 auto; text-align:center; }
.quote-hero blockquote{ font-family:var(--f-serif); font-weight:400; font-style:normal; font-size:clamp(1.8rem,1rem+2.4vw,3rem); line-height:1.28; color:var(--ink); margin:0 0 1.6rem; letter-spacing:-.005em; }
.quote-hero .by{ font-family:var(--f-ui); font-size:.74rem; letter-spacing:.22em; text-transform:uppercase; color:var(--blue); }

/* ============================================================================
   BLOG / JOURNAL
   ========================================================================== */
.post-feature{ display:grid; grid-template-columns:1fr; gap:clamp(1.5rem,3vw,2.5rem); align-items:center; }
@media(min-width:900px){ .post-feature{ grid-template-columns:1.1fr .9fr; gap:clamp(2rem,5vw,4.5rem); } }
.post-feature .frame{ overflow:hidden; }
.post-feature img{ width:100%; aspect-ratio:16/10; object-fit:cover; transition:transform 1.2s var(--ease-out); }
.post-feature:hover img{ transform:scale(1.04); }
.post-meta{ font-family:var(--f-ui); font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); display:flex; gap:1em; align-items:center; margin-bottom:1.2rem; }
.post-meta .dot{ width:4px; height:4px; border-radius:50%; background:var(--powder); }

.post-list{ display:grid; grid-template-columns:1fr; gap:clamp(2rem,4vw,3rem); }
@media(min-width:720px){ .post-list{ grid-template-columns:repeat(3,1fr); } }
.post-card .frame{ overflow:hidden; margin-bottom:1.3rem; }
.post-card img{ width:100%; aspect-ratio:4/3; object-fit:cover; transition:transform 1.1s var(--ease-out); }
.post-card:hover img{ transform:scale(1.05); }
.post-card h3{ font-family:var(--f-display); font-size:clamp(1.25rem,1rem+.8vw,1.55rem); line-height:1.16; color:var(--ink); margin-bottom:.7rem; transition:color .4s; }
.post-card:hover h3{ color:var(--blue); }
.post-card .excerpt{ font-size:1.02rem; line-height:1.6; color:var(--muted); }

/* article */
.article-hero{ padding-top:clamp(7rem,12vw,10rem); }
.article-hero .a-meta{ font-family:var(--f-ui); font-size:.76rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); display:flex; gap:1em; align-items:center; justify-content:center; margin-bottom:1.6rem; }
.article-hero h1{ text-align:center; max-width:20ch; margin-inline:auto; }
.article-cover{ margin-block:clamp(2.5rem,5vw,4rem); overflow:hidden; }
.article-cover img{ width:100%; aspect-ratio:16/9; object-fit:cover; }
.prose{ max-width:40rem; margin-inline:auto; }
.prose p{ font-size:clamp(1.1rem,1rem+.45vw,1.28rem); line-height:1.76; color:var(--ink-soft); }
.prose p.dropcap:first-letter{ font-family:var(--f-serif); font-size:3.4em; line-height:.8; float:left; padding:.08em .14em .02em 0; color:var(--blue-deep); font-weight:400; }
.prose p.stand{ font-family:var(--f-serif); font-weight:400; font-style:italic; font-size:clamp(1.4rem,1rem+1.2vw,1.95rem); line-height:1.36; color:var(--blue-deep); text-align:center; margin-block:1.8em; }

/* ============================================================================
   CONTACT
   ========================================================================== */
.contact-grid{ display:grid; grid-template-columns:1fr; gap:clamp(2rem,5vw,4rem); }
@media(min-width:900px){ .contact-grid{ grid-template-columns:1fr 1fr; gap:clamp(2.5rem,6vw,6rem); } }
.contact-lines{ display:flex; flex-direction:column; gap:2rem; margin-top:2.5rem; }
.contact-lines .cl{ }
.contact-lines .cl .k{ font-family:var(--f-ui); font-size:.72rem; letter-spacing:.24em; text-transform:uppercase; color:var(--muted); margin-bottom:.6rem; }
.contact-lines .cl a,.contact-lines .cl .v{ font-family:var(--f-display); font-size:clamp(1.3rem,1rem+1.1vw,1.9rem); color:var(--ink); position:relative; display:inline-block; }
.contact-lines .cl a::after{ content:""; position:absolute; left:0; bottom:.05em; height:1px; width:100%; background:var(--blue); transform:scaleX(0); transform-origin:left; transition:transform .5s var(--ease); }
.contact-lines .cl a:hover::after{ transform:scaleX(1); }
.contact-form{ display:grid; gap:1.3rem; }
.field{ display:flex; flex-direction:column; gap:.55rem; }
.field label{ font-family:var(--f-ui); font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); }
.field input,.field textarea,.field select{
  font-family:var(--f-body); font-size:1.08rem; color:var(--ink);
  background:transparent; border:0; border-bottom:1px solid var(--line);
  padding:.85rem .2rem; border-radius:0; transition:border-color .4s;
}
.field input:focus,.field textarea:focus,.field select:focus{ outline:none; border-color:var(--blue); }
.field textarea{ resize:vertical; min-height:120px; }
.form-note{ font-size:.9rem; color:var(--muted); font-family:var(--f-ui); letter-spacing:.02em; }

/* split CTA band */
.cta-band{ position:relative; overflow:hidden; }
.cta-band .inner{ display:grid; grid-template-columns:1fr; gap:2rem; align-items:center; text-align:center; }
.cta-band h2{ color:#fff; max-width:20ch; margin-inline:auto; }
.cta-band p{ color:rgba(255,255,255,.85); max-width:52ch; margin:1.2rem auto 2rem; }
.cta-band .eyebrow{ color:var(--powder); justify-content:center; }

/* ============================================================================
   FOOTER
   ========================================================================== */
.site-foot{ background:var(--blue-ink); color:rgba(251,249,244,.82); padding-top:clamp(3.5rem,7vw,6rem); }
.foot-top{ display:grid; grid-template-columns:1fr; gap:clamp(2rem,4vw,3rem); padding-bottom:clamp(2.5rem,5vw,4rem); border-bottom:1px solid rgba(251,249,244,.14); }
@media(min-width:820px){ .foot-top{ grid-template-columns:1.4fr 1fr 1fr; } }
.foot-brand .b-main{ font-family:var(--f-display); font-size:1.9rem; color:#fff; }
.foot-logo{ width:auto; height:clamp(40px,5vw,58px); display:block; filter:brightness(0) invert(1); opacity:.95; }
.foot-brand p{ max-width:34ch; margin-top:1.4rem; color:rgba(251,249,244,.72); font-size:1.02rem; }
.foot-col h4{ font-family:var(--f-ui); font-size:.72rem; letter-spacing:.24em; text-transform:uppercase; color:var(--powder); margin-bottom:1.3rem; }
.foot-col a,.foot-col .v{ display:block; margin-bottom:.9rem; color:rgba(251,249,244,.82); font-size:1.02rem; transition:color .35s; }
.foot-col a:hover{ color:#fff; }
.foot-bottom{ display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; padding-block:1.8rem; font-family:var(--f-ui); font-size:.74rem; letter-spacing:.1em; color:rgba(251,249,244,.6); }
.foot-bottom a:hover{ color:#fff; }

/* ============================================================================
   REVEAL ANIMATIONS
   ========================================================================== */
/* reveals — FAIL-SAFE: everything is visible by default. JS adds .pre to hide an
   element just before it enters, then removes it to animate. If JS ever fails,
   nothing is hidden and no image can go missing. */
[data-reveal]{ transition:opacity 1.1s var(--ease-out), transform 1.1s var(--ease-out); }
[data-reveal].pre{ opacity:0; transform:translateY(26px); }
[data-reveal-d="1"]{ transition-delay:.08s; } [data-reveal-d="2"]{ transition-delay:.16s; }
[data-reveal-d="3"]{ transition-delay:.24s; } [data-reveal-d="4"]{ transition-delay:.32s; }
[data-reveal-d="5"]{ transition-delay:.40s; }
[data-clip]{ transition:clip-path 1.3s var(--ease-out); }
[data-clip].pre{ clip-path:inset(0 0 94% 0); }
[data-clip] img{ transition:transform 1.5s var(--ease-out); }
[data-clip].pre img{ transform:scale(1.08); }

@media (prefers-reduced-motion:reduce){
  [data-reveal],[data-clip],.reveal-line > *{ opacity:1 !important; transform:none !important; clip-path:none !important; transition:none !important; }
  .hero.loaded .hero-media img{ animation:none; transform:scale(1.02); }
  .marquee-track{ animation:none; }
  .scroll-cue .line::after{ animation:none; }
}

/* ---------- responsive nav ---------- */
@media(max-width:880px){
  .nav{ display:none; }
  .burger{ display:block; }
  .brand .b-main{ font-size:1.15rem; }
}

/* page-load curtain */
.curtain{ position:fixed; inset:0; z-index:120; background:var(--blue-deep); transform-origin:top; pointer-events:none; }
.curtain.up{ transform:scaleY(0); transition:transform .9s var(--ease); }
.curtain .cw{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; color:var(--paper); font-family:var(--f-display); font-size:1.6rem; letter-spacing:.02em; opacity:1; transition:opacity .5s ease; }
.curtain.up .cw{ opacity:0; }

/* focus visibility for keyboard users */
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{ outline:2px solid var(--blue); outline-offset:3px; }

/* skip link */
.skip{ position:absolute; left:-999px; top:0; z-index:200; background:var(--ink); color:#fff; padding:1rem 1.4rem; font-family:var(--f-ui); letter-spacing:.1em; }
.skip:focus{ left:1rem; top:1rem; }

/* breadcrumbs */
.crumbs{ font-family:var(--f-ui); font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); display:flex; gap:.6em; align-items:center; flex-wrap:wrap; }
.crumbs a{ color:var(--muted); transition:color .3s; } .crumbs a:hover{ color:var(--blue); }
.crumbs .bc-sep{ opacity:.5; } .crumbs [aria-current]{ color:var(--ink); }

/* FAQ */
.faq-item{ border-bottom:1px solid var(--line); }
.faq-item summary{ list-style:none; cursor:pointer; padding:1.4rem 0; font-family:var(--f-display); font-size:clamp(1.15rem,1rem+.6vw,1.5rem); color:var(--ink); display:flex; justify-content:space-between; align-items:center; gap:1rem; }
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{ content:"+"; font-family:var(--f-ui); font-weight:400; color:var(--blue); transition:transform .4s var(--ease); font-size:1.5rem; line-height:1; }
.faq-item[open] summary::after{ transform:rotate(45deg); }
.faq-a{ padding:0 0 1.5rem; color:var(--ink-soft); max-width:70ch; }
.faq-a p{ margin:0; }
