/* ============================================================
   KEN SHEW — brand designer portfolio
   Editorial · light-serif · liquid-glass nav · scrolling work
   ============================================================ */

/* ---------- Season Mix : display / headlines ---------- */
@font-face{font-family:'Season Mix';src:url('fonts/SeasonMix-Light.woff2') format('woff2');font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:'Season Mix';src:url('fonts/SeasonMix-Regular.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Season Mix';src:url('fonts/SeasonMix-RegularItalic.woff2') format('woff2');font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:'Season Mix';src:url('fonts/SeasonMix-Medium.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
/* ---------- Season Sans : body / UI ---------- */
@font-face{font-family:'Season Sans';src:url('fonts/SeasonSans-Light.woff2') format('woff2');font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:'Season Sans';src:url('fonts/SeasonSans-Regular.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Season Sans';src:url('fonts/SeasonSans-Medium.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Season Sans';src:url('fonts/SeasonSans-SemiBold.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap}

:root{
  /* ---- palette (CODEX) ---- */
  --ink:#12231f;            /* deep green-black — primary text */
  --ink-soft:#26352f;
  --muted:#66726c;
  --faint:#8a948d;
  --paper:#f4f1ea;
  --paper-soft:#faf8f3;     /* shell surface */
  --paper-deep:#ece7dd;
  --cool:#e7e3d6;           /* warm stone band — same temperature world as the paper */
  --cool-deep:#a9a78f;      /* decorative warm-sage (strokes/dots only) */
  --eyebrow-ink:#5b6a60;    /* eyebrow / label TEXT on paper — warm green-gray, AA on paper & cream */
  --eyebrow-cool:#5a6052;   /* eyebrow / label TEXT on the stone band — AA */
  --moss:#13413c;           /* deep pine band (ALD green) */
  --moss-deep:#0c2a26;
  --white:#fffdf8;
  --mat:#efe8da;            /* barely-there warm frame — subtle float, not a grey border */
  --line:#d8d2c7;           /* hairline */
  --line-dark:rgba(18,35,31,.16);

  /* one restrained accent — olive forest (Cornerstore/ALD green), warm side of the family */
  --accent:#2f5321;
  --accent-soft:#a3c493;    /* light olive-sage, on dark pine */

  /* ---- type ---- */
  --serif:'Season Mix',Georgia,'Times New Roman',serif;
  --sans:'Season Sans',-apple-system,system-ui,sans-serif;
  --fs-hero:clamp(3.4rem,1.6rem + 7.6vw,9.1rem);
  --fs-h2:clamp(2.2rem,1.3rem + 3.6vw,4.6rem);
  --fs-h3:clamp(1.6rem,1.1rem + 1.7vw,2.55rem);
  --fs-lead:clamp(1.2rem,1.04rem + .66vw,1.55rem);
  --fs-body:clamp(1rem,.96rem + .18vw,1.125rem);
  --fs-small:clamp(.85rem,.82rem + .1vw,.9375rem);
  --fs-eyebrow:clamp(.6875rem,.66rem + .1vw,.7813rem);
  --fs-index:clamp(.75rem,.72rem + .1vw,.8125rem);

  /* ---- motion (the "expensive" set) ---- */
  --ease-out-soft:cubic-bezier(.22,1,.36,1);
  --ease-out-deep:cubic-bezier(.16,1,.3,1);
  --ease-in-out:cubic-bezier(.65,0,.35,1);
  --ease-quick:cubic-bezier(.4,0,.2,1);

  /* ---- layout ---- */
  --pad:clamp(22px,5vw,72px);
  --shell-w:1460px;
  --nav-h:62px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:100px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}
body{
  font-family:var(--sans);background:var(--mat);color:var(--ink);
  font-size:var(--fs-body);line-height:1.6;letter-spacing:-.005em;
  overflow-x:clip; /* clip (not hidden) so it never becomes a scroll container and breaks sticky cards in Safari */
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--moss);color:var(--white)}

/* Lenis smooth-scroll (only active when the .lenis class is present, so native
   scroll-behavior below still applies as a fallback when Lenis is off) */
html.lenis,html.lenis body{height:auto}
html.lenis{scroll-behavior:auto!important} /* Lenis owns scrolling; don't double-smooth */
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
.lenis.lenis-stopped{overflow:clip}

/* ---- type helpers ---- */
.display{font-family:var(--serif);font-weight:300;line-height:.96;letter-spacing:-.02em;text-wrap:balance}
.eyebrow{font-family:var(--sans);font-weight:500;font-size:var(--fs-eyebrow);letter-spacing:.16em;text-transform:uppercase;color:var(--eyebrow-ink)}
.lead{font-family:var(--serif);font-weight:300;font-size:var(--fs-lead);line-height:1.32;letter-spacing:-.01em;color:var(--ink-soft);max-width:38ch}
em,i{font-style:normal}

/* ============================================================
   FILM GRAIN  (warm multiply — the single biggest "expensive" tell)
   ============================================================ */
.grain{
  position:fixed;inset:0;z-index:100;pointer-events:none;opacity:.045;
  mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:160px 160px;
}
@media (prefers-reduced-motion:no-preference){
  .grain{animation:grain-shift 6s steps(6) infinite}
}
@keyframes grain-shift{
  0%,100%{transform:translate(0,0)}20%{transform:translate(-4%,3%)}40%{transform:translate(3%,-2%)}
  60%{transform:translate(-2%,4%)}80%{transform:translate(4%,-3%)}
}

/* ============================================================
   SHELL — content card on the warm mat
   ============================================================ */
.shell{
  max-width:min(var(--shell-w),calc(100% - 44px));
  margin:26px auto;
  background:var(--paper-soft);
  box-shadow:0 30px 80px -34px rgba(13,40,34,.3),0 3px 14px -8px rgba(13,40,34,.14);
}
.lg-svg{position:absolute}

/* ============================================================
   LIQUID GLASS NAV
   ============================================================ */
.nav{
  position:fixed;top:16px;left:50%;transform:translateX(-50%);
  width:min(var(--shell-w),calc(100% - 44px));
  z-index:1000;border-radius:20px;isolation:isolate;overflow:hidden;
  border:1px solid var(--nav-border);
  box-shadow:
    inset 0 1px 1px rgba(255,255,255,.35),
    0 6px 24px rgba(20,24,20,.10),
    0 18px 50px -18px rgba(20,24,20,.22);
  transition:transform .45s var(--ease-out-soft),opacity .4s var(--ease-quick),
             box-shadow .4s var(--ease-quick),border-color .4s var(--ease-quick),background .4s var(--ease-quick);
}
.nav.hide{transform:translateX(-50%) translateY(-150%)}

/* context tokens — flipped by IntersectionObserver as sections pass under */
.nav[data-context="light"]{--nav-tint:rgba(250,248,243,.38);--nav-border:rgba(255,255,255,.62);--nav-fg:#1c2a25;--nav-fg-soft:#52605a}
.nav[data-context="dark"]{--nav-tint:rgba(8,22,17,.42);--nav-border:rgba(255,253,248,.3);--nav-fg:#f5f8f5;--nav-fg-soft:rgba(245,248,245,.85)}
/* dark glass floats over varied (sometimes light) imagery — guarantee legible text regardless of backdrop */
.nav[data-context="dark"] .nav__content{text-shadow:0 1px 3px rgba(0,0,0,.45)}

.nav__refract,.nav__tint,.nav__specular{position:absolute;inset:0;border-radius:inherit;pointer-events:none}
.nav__tint{
  background:var(--nav-tint);
  /* hard-coded blur values: Safari rejects CSS vars inside backdrop-filter */
  -webkit-backdrop-filter:blur(18px) saturate(150%);
          backdrop-filter:blur(18px) saturate(150%);
}
/* brightness lift only over light sections — over dark imagery it washes the glass out */
.nav[data-context="light"] .nav__tint{
  -webkit-backdrop-filter:blur(18px) saturate(150%) brightness(1.04);
          backdrop-filter:blur(18px) saturate(150%) brightness(1.04);
}
.nav__specular{
  background:linear-gradient(180deg,rgba(255,255,255,.4) 0%,rgba(255,255,255,.06) 16%,rgba(255,255,255,0) 36%,rgba(255,255,255,0) 74%,rgba(255,255,255,.1) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.7),
    inset 0 -1px 0 rgba(255,255,255,.16),
    inset 1px 0 0 rgba(255,255,255,.18),
    inset -1px 0 0 rgba(255,255,255,.18),
    inset 0 0 16px rgba(255,255,255,.08);
  mix-blend-mode:screen;
}
/* hover sheen — sweeps a diagonal highlight (transform/opacity only) */
.nav__specular::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(105deg,transparent 36%,rgba(255,255,255,.32) 50%,transparent 64%);
  transform:translateX(-120%);opacity:0;
  transition:transform .9s var(--ease-out-soft),opacity .3s var(--ease-quick);
}
.nav:hover .nav__specular::before{transform:translateX(120%);opacity:1}

/* Chromium-only true refraction; Safari/FF keep the blur glass above */
@supports ((backdrop-filter:url(#lg-refraction)) or (-webkit-backdrop-filter:url(#lg-refraction))){
  .nav__refract{
    -webkit-backdrop-filter:url(#lg-refraction) blur(3px) saturate(150%);
            backdrop-filter:url(#lg-refraction) blur(3px) saturate(150%);
  }
  .nav__tint{
    -webkit-backdrop-filter:blur(8px) saturate(150%);
            backdrop-filter:blur(8px) saturate(150%);
  }
  .nav[data-context="light"] .nav__tint{
    -webkit-backdrop-filter:blur(8px) saturate(150%) brightness(1.04);
            backdrop-filter:blur(8px) saturate(150%) brightness(1.04);
  }
}
@supports not ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))){
  .nav[data-context="light"] .nav__tint{background:rgba(250,248,243,.95)}
  .nav[data-context="dark"] .nav__tint{background:rgba(13,40,34,.9)}
}

.nav__content{
  position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:18px;
  height:var(--nav-h);padding:0 14px 0 22px;color:var(--nav-fg);
}
.brand{font-family:var(--serif);font-weight:400;font-size:21px;letter-spacing:-.01em;white-space:nowrap;display:inline-flex;align-items:baseline;color:var(--nav-fg)}
.nav .brand{font-family:var(--sans);font-weight:700;text-transform:none;letter-spacing:-.02em;font-size:20px}
.brand sup{font-size:.44em;font-weight:500;top:-.7em;margin-left:.06em;color:var(--accent)}
/* signature monogram logo in nav — inherits adaptive --nav-fg via currentColor */
.nav .brand--logo{padding:0;line-height:0;align-items:center}
.brand-mark{height:42px;width:auto;display:block;color:var(--nav-fg);transition:color .4s var(--ease-quick)}
.nav-links{display:flex;gap:4px;align-items:center}
.nav-links a{position:relative;font-size:14.5px;font-weight:500;color:var(--nav-fg-soft);padding:8px 14px;border-radius:999px;transition:color .25s var(--ease-quick)}
.nav-links a::after{content:"";position:absolute;left:14px;right:14px;bottom:6px;height:1px;background:currentColor;transform:scaleX(0);transform-origin:right;transition:transform .34s var(--ease-quick)}
.nav-links a:hover{color:var(--nav-fg)}
.nav-links a:hover::after{transform:scaleX(1);transform-origin:left}
.nav-cta{display:flex;align-items:center;gap:12px}
.nav-avail{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--nav-fg-soft);white-space:nowrap}
.dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 0 rgba(47,83,33,.5);animation:pulse 2.6s infinite}
.nav[data-context="dark"] .dot{background:var(--accent-soft);box-shadow:0 0 0 0 rgba(163,196,147,.5)}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(47,83,33,.4)}70%{box-shadow:0 0 0 7px rgba(47,83,33,0)}100%{box-shadow:0 0 0 0 rgba(47,83,33,0)}}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;gap:.55em;font-family:var(--sans);
  font-weight:600;font-size:14.5px;letter-spacing:-.005em;white-space:nowrap;
  padding:12px 20px;border-radius:999px;border:1px solid transparent;cursor:pointer;
  transition:transform .34s var(--ease-out-soft),background .3s var(--ease-quick),color .3s var(--ease-quick),box-shadow .3s var(--ease-quick),border-color .3s var(--ease-quick);
}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0) scale(.98)}
.btn .ar{width:1em;height:1em;flex:none;transition:transform .34s var(--ease-out-soft)}
.btn:hover .ar{transform:translate(3px,-3px)}
.btn--primary{background:var(--ink);color:var(--paper-soft)}
.btn--primary:hover{background:var(--moss);box-shadow:0 14px 30px -14px rgba(13,48,40,.6)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn--ghost:hover{background:var(--ink);color:var(--paper-soft);border-color:var(--ink)}
.btn--accent{background:var(--white);color:var(--moss)}
.btn--accent:hover{background:var(--accent-soft);color:var(--moss-deep);box-shadow:0 14px 34px -14px rgba(163,196,147,.5)}
/* glass button on work cards */
.btn--glass{
  background:rgba(18,24,20,.34);color:#fff;border:1px solid rgba(255,255,255,.3);
  -webkit-backdrop-filter:blur(14px) saturate(130%);backdrop-filter:blur(14px) saturate(130%);
}
.btn--glass:hover{background:rgba(18,24,20,.5);border-color:rgba(255,255,255,.5)}


/* ---- keyboard focus (visible on light AND dark surfaces) ---- */
:where(a,button):focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}
/* white rings only on surfaces that are actually dark — the CTA is cream now */
.services :focus-visible,.wc-body a:focus-visible,
.nav[data-context="dark"] .nav__content a:focus-visible{outline-color:#fff}

/* ---- mobile menu toggle (hamburger) ---- */
.nav-toggle{display:none;width:42px;height:42px;flex-direction:column;align-items:center;justify-content:center;background:transparent;border:0;cursor:pointer;color:var(--nav-fg);border-radius:10px;padding:0}
.nav-toggle span{display:block;width:18px;height:1.5px;background:currentColor;border-radius:2px;transition:transform .3s var(--ease-quick),opacity .2s var(--ease-quick)}
.nav-toggle span+span{margin-top:4px}
.nav.is-open .nav-toggle span:nth-child(1){transform:translateY(5.5px) rotate(45deg)}
.nav.is-open .nav-toggle span:nth-child(2){opacity:0}
.nav.is-open .nav-toggle span:nth-child(3){transform:translateY(-5.5px) rotate(-45deg)}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  padding:calc(var(--nav-h) + 86px) var(--pad) clamp(40px,6vh,72px);
  background:linear-gradient(180deg,rgba(231,227,214,.62),rgba(250,248,243,0) 54%);
}
.hero-grid{display:block}
.hero-title{font-size:var(--fs-hero);line-height:.93;letter-spacing:-.035em;margin:.12em 0 0}
/* grid-stacked twin words so role changes CROSSFADE — the line is never empty mid-swap */
.role-rotator{display:grid;color:var(--accent);white-space:nowrap}
.role-word{grid-area:1/1;justify-self:start;will-change:transform,opacity}
.hero .lead{margin-top:30px}
.hero-actions{display:flex;gap:12px;margin-top:34px;flex-wrap:wrap}
.hero-meta{display:flex;flex-wrap:wrap;gap:14px 40px;margin-top:40px;padding-top:26px;border-top:1px solid var(--line)}
.hero-meta div{display:flex;flex-direction:column;gap:5px}
.hero-meta .k{font-size:var(--fs-small);color:var(--eyebrow-ink);letter-spacing:.02em}
.hero-meta .v{font-size:15px;font-weight:500;color:var(--ink)}
.hero-meta .hero-social{display:flex;flex-direction:row;align-items:center;gap:18px;margin-left:auto;align-self:center}
.hero-social a{display:inline-flex;color:var(--ink);transition:color .25s var(--ease-quick),transform .3s var(--ease-out-soft)}
.hero-social a:hover{color:var(--accent);transform:translateY(-3px)}
.hero-social svg{width:21px;height:21px;display:block}

/* ---- marquee ---- */
.proof{margin-top:clamp(34px,6vh,60px);padding-top:32px;border-top:1px solid var(--line)}
.proof-lead{font-size:var(--fs-small);letter-spacing:.16em;text-transform:uppercase;color:var(--eyebrow-ink);text-align:center;margin-bottom:22px}
.marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent);mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent)}
.marquee-track{display:flex;gap:60px;width:max-content;animation:scroll 40s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track span{font-family:var(--serif);font-weight:300;font-size:clamp(22px,2.6vw,34px);color:var(--ink);opacity:.5;white-space:nowrap;letter-spacing:-.01em}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ============================================================
   SECTION HEADINGS
   ============================================================ */
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px 40px;flex-wrap:wrap;margin-bottom:clamp(34px,5vh,56px)}
.sec-head>div{flex:1 1 auto;min-width:0}
.sec-head h2{font-size:var(--fs-h2);line-height:.98;letter-spacing:-.025em}
.sec-head .eyebrow{margin-bottom:18px;display:block}
.sec-note{flex:0 1 36ch;max-width:36ch;font-size:var(--fs-body);color:var(--muted);line-height:1.5}

/* ============================================================
   SELECTED WORK — stacking carousel cards
   ============================================================ */
.work{padding:clamp(64px,9vh,116px) var(--pad) clamp(36px,5vh,56px)}
.stack{position:relative}
.work-card{
  position:sticky;top:100px;
  height:min(78vh,640px);border-radius:4px;overflow:hidden;margin-bottom:24px;
  background:linear-gradient(165deg,#1a4a44 0%,#0f322d 46%,#061511 100%);
  box-shadow:0 40px 80px -36px rgba(8,20,16,.7);
  will-change:transform,filter;transform-origin:center top;
}
/* the carousel fills the card */
.wc-media{position:absolute;inset:0}
/* scrims keep overlaid text legible over ANY slide (light or dark) */
.wc-scrim{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(180deg,rgba(8,16,12,.48) 0%,rgba(8,16,12,0) 24%),
    linear-gradient(0deg,rgba(6,14,10,.9) 0%,rgba(6,14,10,.66) 20%,rgba(6,14,10,.28) 44%,rgba(6,14,10,0) 64%);
}
.wc-body{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;justify-content:space-between;padding:clamp(22px,3vw,44px);pointer-events:none}
.wc-body a{pointer-events:auto}
.wc-top{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}
.wc-top .idx{display:inline-flex;align-items:baseline;gap:.4em;flex:none;white-space:nowrap;font-family:var(--sans);font-size:var(--fs-index);letter-spacing:.04em;color:rgba(255,253,248,.62);font-variant-numeric:tabular-nums}
.wc-top .idx em{color:#fff;font-style:normal}
.wc-top .idx-sep{opacity:.5;margin:0 .1em}
.wc-top .idx .reg{font-size:.62em;vertical-align:super;line-height:0;margin-left:.05em;opacity:.9}
.wc-cat{font-size:11.5px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:#fff;border:1px solid rgba(255,255,255,.4);padding:7px 14px;border-radius:999px;background:rgba(255,255,255,.12);-webkit-backdrop-filter:blur(16px) saturate(165%);backdrop-filter:blur(16px) saturate(165%);box-shadow:inset 0 1px 0 rgba(255,255,255,.5),inset 0 -1px 0 rgba(255,255,255,.12),0 6px 18px -8px rgba(0,0,0,.45)}
.wc-bottom{color:#fff;max-width:800px}
.wc-bottom h3{font-size:var(--fs-h3);color:#fff;font-weight:400;text-transform:uppercase;letter-spacing:-.005em}
.wc-bottom h3 .reg{font-size:.5em;vertical-align:super;line-height:0;margin-left:.04em;font-weight:400}
.wc-bottom p{margin-top:14px;font-size:clamp(15px,1.25vw,18px);color:rgba(255,255,255,.88);max-width:54ch;line-height:1.5}
.wc-foot{display:flex;align-items:center;gap:16px;margin-top:24px;flex-wrap:wrap}
.wc-tags{display:flex;gap:8px;flex-wrap:wrap}
.wc-tags span{font-size:12px;color:#fff;border:1px solid rgba(255,255,255,.32);padding:6px 13px;border-radius:999px;background:rgba(255,255,255,.1);-webkit-backdrop-filter:blur(14px) saturate(150%);backdrop-filter:blur(14px) saturate(150%);box-shadow:inset 0 1px 0 rgba(255,255,255,.42),0 4px 12px -6px rgba(0,0,0,.4)}

/* ---- carousel (built into .wc-media by app.js) ---- */
/* .wc-media is absolute+inset:0 so it fills the card; the combined selector
   keeps that winning over the generic .carousel rule and anchors the arrows */
.wc-media.carousel{position:absolute;inset:0}
.carousel{position:relative}
.carousel__track{
  display:flex;height:100%;margin:0;padding:0;list-style:none;
  overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;scroll-behavior:smooth;
  -webkit-overflow-scrolling:touch;scrollbar-width:none;overscroll-behavior-x:contain;
}
.carousel__track::-webkit-scrollbar{display:none}
.carousel__track:focus-visible{outline:2px solid #fff;outline-offset:-4px}
.carousel__slide{flex:0 0 100%;scroll-snap-align:center;scroll-snap-stop:always;height:100%}
.carousel__slide img{width:100%;height:100%;object-fit:cover;display:block}
/* bare arrow glyphs — no circle; drop-shadow keeps them legible over any image */
.carousel__btn{
  position:absolute;top:50%;transform:translateY(-50%);z-index:5;
  width:44px;height:44px;display:grid;place-items:center;padding:0;border:0;background:none;cursor:pointer;color:#fff;
  opacity:.82;filter:drop-shadow(0 2px 6px rgba(0,0,0,.55));
  transition:opacity .2s var(--ease-quick),transform .25s var(--ease-out-soft);
}
.carousel__btn--prev{left:8px}
.carousel__btn--next{right:8px}
.carousel__btn svg{width:28px;height:28px}
.carousel:hover .carousel__btn,.carousel:focus-within .carousel__btn{opacity:1}
.carousel__btn:hover{transform:translateY(-50%) scale(1.14)}
.carousel__btn:focus-visible{outline:2px solid #fff;outline-offset:3px;border-radius:8px}
.carousel__btn:active{transform:translateY(-50%) scale(.94)}
.carousel__btn[aria-disabled="true"]{opacity:.3}
@media (hover:none){.carousel__btn{opacity:1}}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* ---- secondary work grid ---- */
.work-more{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:clamp(28px,4vh,46px)}
.wm-card{position:relative;border-radius:4px;overflow:hidden;aspect-ratio:5/4;background:var(--moss);cursor:pointer}
.wm-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease-out-soft)}
.wm-card:hover img{transform:scale(1.04)}
.wm-tint{position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,rgba(8,16,12,0) 42%,rgba(8,16,12,.76))}
.wm-body{position:absolute;inset:0;z-index:3;display:flex;flex-direction:column;justify-content:flex-end;padding:20px;color:#fff}
.wm-card h4,.wm-card h2{font-size:21px;color:#fff;font-weight:400;text-transform:uppercase;letter-spacing:.01em}
.wm-card h4 .reg,.wm-card h2 .reg,.pn-t .reg{font-size:.5em;vertical-align:super;line-height:0;margin-left:.04em}
.wm-cat{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.8);margin-bottom:7px}
.wm-arrow{position:absolute;top:15px;right:15px;z-index:3;width:36px;height:36px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.3);color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:transform .3s var(--ease-out-soft),background .3s var(--ease-quick)}
.wm-arrow .ar{width:15px;height:15px}
.wm-card:hover .wm-arrow{transform:translate(3px,-3px);background:rgba(255,255,255,.26)}
/* self-labeled artwork card (Hughes Street): no scrim/overlay, dark arrow for contrast on light art */
.wm-card--art{background:#d5d9ce}
.wm-card--art .wm-arrow{background:rgba(18,35,31,.06);border-color:rgba(18,35,31,.22);color:var(--ink)}
.wm-card--art:hover .wm-arrow{background:rgba(18,35,31,.14)}

/* ============================================================
   APPROACH
   ============================================================ */
.approach{padding:clamp(76px,11vh,138px) var(--pad);background:var(--cool)}
.approach .eyebrow{color:var(--eyebrow-cool)}
.steps{border-top:1px solid var(--line-dark)}
.step{display:grid;grid-template-columns:88px 1fr auto;gap:clamp(16px,3vw,48px);align-items:baseline;padding:30px 0;border-bottom:1px solid var(--line-dark);transition:transform .35s var(--ease-out-deep)}
.steps .step:hover{transform:translateX(5px)} /* beats .rv.in{transform:none} so the hover indent animates */
.step .s-num{font-family:var(--serif);font-weight:300;font-size:clamp(26px,3vw,40px);color:var(--accent)}
.step h3{font-size:clamp(22px,2.6vw,32px);letter-spacing:-.02em}
.step p{margin-top:10px;color:rgba(18,35,31,.66);max-width:52ch;font-size:var(--fs-body);line-height:1.55}
.step .s-tag{font-size:var(--fs-small);color:rgba(18,35,31,.5);white-space:nowrap;text-align:right}
.approach-note{margin-top:30px;font-size:var(--fs-body);color:rgba(18,35,31,.66)}
.approach-note em{font-family:var(--sans);font-weight:600;color:var(--ink)}

/* ============================================================
   SERVICES — dark moss band with glass cards
   ============================================================ */
.services{
  position:relative;isolation:isolate;padding:clamp(92px,12vh,150px) var(--pad);
  /* thin (~1.5cm) edge fades so the moss band meets the stone above / paper below without a hard line */
  background:
    linear-gradient(180deg,var(--cool) 0,rgba(231,227,214,0) 58px),
    linear-gradient(0deg,var(--paper-soft) 0,rgba(250,248,243,0) 58px),
    radial-gradient(135% 105% at 50% -12%,#13413c 0%,#0d2b27 46%,#051512 100%);
  color:#d3e2da;
}
.services::after{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;background:radial-gradient(60% 42% at 78% 6%,rgba(163,196,147,.13),transparent 70%)}
.services .eyebrow{color:var(--accent-soft)}
.services .sec-head h2{color:#eef6f1}
.services .sec-note{color:#9db8ac}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:clamp(34px,5vh,48px)}
.glass-card{
  background:rgba(180,205,160,.07);border:1px solid rgba(180,205,160,.16);border-radius:4px;
  -webkit-backdrop-filter:blur(20px) saturate(122%);backdrop-filter:blur(20px) saturate(122%);
  box-shadow:inset 0 1px 0 rgba(235,245,225,.18),0 24px 50px -28px rgba(0,0,0,.6);
}
.svc-card{padding:30px 28px 26px;display:flex;flex-direction:column;min-height:340px;color:#d3e2da;transition:transform .4s var(--ease-out-soft),box-shadow .4s var(--ease-quick),background .4s var(--ease-quick),border-color .4s var(--ease-quick)}
/* hover: subtle jade glow reflecting off the liquid glass — same family as the accent */
.svc-card:hover{transform:translateY(-5px);background:rgba(163,196,147,.11);border-color:rgba(170,200,150,.38);box-shadow:inset 0 1px 0 rgba(240,248,235,.3),0 0 0 1px rgba(165,200,145,.24),0 0 48px -8px rgba(110,150,85,.42),0 34px 60px -26px rgba(0,0,0,.7)}
.svc-card .svc-i{font-family:var(--serif);font-weight:300;font-size:22px;color:var(--accent-soft);margin-bottom:18px}
.svc-card h2,.svc-card h3{font-size:24px;color:#f2f8f4;letter-spacing:-.02em}
.svc-card .svc-d{margin-top:10px;color:#a8c2b5;font-size:15.5px;line-height:1.5}
.svc-card ul{list-style:none;margin-top:18px;display:flex;flex-direction:column;gap:9px}
.svc-card li{font-size:14.5px;color:#c6d8cd;display:flex;gap:10px;align-items:baseline}
.svc-card li::before{content:"";width:5px;height:5px;border-radius:50%;background:#7fa863;flex:none;transform:translateY(-2px)}
.svc-card .svc-foot{margin-top:auto;padding-top:18px;font-size:13.5px;color:#9db8ac;border-top:1px solid rgba(180,205,160,.16)}
/* filled jade banner so it stands out from the glass cards — one accent family, one temperature */
.svc-banner{margin-top:16px;padding:28px 32px;display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;color:#fff;
  background:linear-gradient(120deg,#335a24,#22411a);border:1px solid rgba(255,255,255,.16);border-radius:4px;
  -webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:inset 0 1px 0 rgba(255,255,255,.24),0 26px 54px -26px rgba(25,45,15,.6)}
.svc-banner p{font-size:clamp(20px,2.3vw,30px);letter-spacing:-.02em;max-width:32ch;line-height:1.12;color:#fff}
.services .svc-banner .btn--accent{background:#fff;color:#22411a}
.services .svc-banner .btn--accent:hover{background:#e4ecd9;color:#1a3212;box-shadow:0 14px 34px -14px rgba(20,40,12,.5)}

/* ============================================================
   ABOUT
   ============================================================ */
.about{padding:clamp(72px,10vh,130px) var(--pad)}
.about-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(28px,5vw,72px);align-items:center}
.about-visual{position:relative;aspect-ratio:5/6;overflow:hidden;background:var(--moss);border-radius:4px}
.about-visual--circle{aspect-ratio:1;border-radius:50%;max-width:440px;box-shadow:0 24px 50px -28px rgba(13,40,34,.5)}
.about-visual img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.about-body .big{font-size:clamp(26px,3.2vw,42px);line-height:1.08;letter-spacing:-.025em}
.about-body p:not(.big){margin-top:22px;color:var(--ink-soft);font-size:clamp(16px,1.3vw,17.5px);line-height:1.6;max-width:54ch}
.about-sign{margin-top:28px;display:flex;flex-direction:column;gap:4px}
.about-sign .nm{font-size:24px}
.about-sign .role{color:var(--eyebrow-ink);font-size:14px}

/* ============================================================
   CLOSING CTA (cream field of self-animating icons)
   ============================================================ */
.cta{position:relative;overflow:hidden;padding:clamp(120px,19vh,220px) var(--pad);text-align:center;background:#f1eee0;color:var(--ink)}
.cta-inner{position:relative;z-index:2}
.cta .eyebrow{margin-bottom:24px;display:block}
.cta h2{font-size:clamp(40px,8vw,108px);line-height:.96;color:var(--ink)}
.cta h2 em{color:var(--accent)}
.cta-sub{margin:26px auto 0;max-width:46ch;color:var(--ink-soft);font-size:clamp(16px,1.5vw,18px)}
.cta-actions{display:flex;gap:13px;justify-content:center;margin-top:38px;flex-wrap:wrap}

/* drifting icon field (Grain & Mortar-style scatter) */
.cta-field{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.fi{position:absolute;display:block;aspect-ratio:1;will-change:transform;filter:drop-shadow(0 8px 18px rgba(20,30,18,.1));animation:fi-float var(--dur,7s) var(--ease-in-out) infinite;animation-delay:var(--dl,0s)}
.fi svg{display:block;width:100%;height:100%}
@keyframes fi-float{0%,100%{transform:translateY(0) rotate(var(--r,0deg))}50%{transform:translateY(-13px) rotate(calc(var(--r,0deg) + 2.5deg))}}
.fi-1{top:9%;left:4%;width:64px;--dur:7.5s;--dl:0s;--r:-5deg}
.fi-2{top:6%;left:22%;width:52px;--dur:8.4s;--dl:.6s;--r:4deg}
.fi-4{top:6%;left:66%;width:58px;--dur:9s;--dl:.3s;--r:3deg}
.fi-5{top:10%;left:90%;width:56px;--dur:7.8s;--dl:1.4s;--r:-4deg}
.fi-6{top:33%;left:3%;width:72px;--dur:8.8s;--dl:.9s;--r:5deg}
.fi-7{top:56%;left:6%;width:54px;--dur:7.2s;--dl:.2s;--r:-3deg}
.fi-8{top:50%;left:89%;width:50px;--dur:8s;--dl:1.7s;--r:4deg}
.fi-9{top:80%;left:5%;width:46px;--dur:6.6s;--dl:1.2s;--r:0deg}
.fi-10{top:85%;left:24%;width:64px;--dur:9.2s;--dl:.5s;--r:-4deg}
.fi-11{top:88%;left:46%;width:50px;--dur:7.6s;--dl:1s;--r:3deg}
.fi-12{top:70%;left:93%;width:54px;--dur:8.6s;--dl:.4s;--r:-5deg}
.fi-14{top:30%;left:93%;width:52px;--dur:8.2s;--dl:.8s;--r:-3deg}

/* icon inner motion — ONE quiet language: a slow line-draw (craft) and a slow breathe.
   Everything louder (spin / blink / roll / flip…) is intentionally retired. */
.fi svg [class*="a-"]{transform-box:fill-box;transform-origin:center}
.a-draw{stroke-dasharray:150;animation:fa-draw 6s var(--ease-in-out) infinite}
@keyframes fa-draw{0%{stroke-dashoffset:150}30%{stroke-dashoffset:0}72%{stroke-dashoffset:0}100%{stroke-dashoffset:150}}
.a-breathe{animation:fa-breathe 4.5s var(--ease-in-out) infinite}
@keyframes fa-breathe{0%,100%{transform:scale(1)}50%{transform:scale(1.07)}}
.a-spin,.a-twinkle,.a-blink,.a-slide,.a-flip,.a-rock{animation:none}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{padding:46px var(--pad) 38px;background:var(--paper-soft);border-top:1px solid var(--line)}
.footer-grid{display:flex;justify-content:space-between;gap:28px;flex-wrap:wrap;align-items:flex-start}
.footer .brand--logo{line-height:0}
.footer-mark{height:48px;width:auto;display:block}
.footer-blurb{margin-top:14px;color:var(--muted);max-width:32ch;font-size:15px}
/* Contra "Hire me" keeps its recognizable orange; a soft shadow seats it on the footer */
.footer-contra{margin-top:18px;transform:scale(.8);transform-origin:left center;filter:drop-shadow(0 6px 14px rgba(13,40,34,.22))}
.footer-social{display:flex;align-items:center;gap:18px;margin-top:20px}
.footer-social a{display:inline-flex;color:var(--ink);transition:color .25s var(--ease-quick),transform .3s var(--ease-out-soft)}
.footer-social a:hover{color:var(--accent);transform:translateY(-3px)}
.footer-social svg{width:21px;height:21px;display:block}
.footer-cols{display:flex;gap:clamp(36px,7vw,90px);flex-wrap:wrap}
.footer-col .footer-h{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--eyebrow-ink);margin-bottom:14px;font-weight:600}
.footer-col a{display:block;font-size:15px;color:var(--ink-soft);padding:5px 0;transition:color .25s var(--ease-quick)}
.footer-col a:hover{color:var(--accent)}
.footer-base{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:44px;padding-top:22px;border-top:1px solid var(--line);font-size:13.5px;color:var(--eyebrow-ink)}

/* ============================================================
   REVEAL ON SCROLL
   ============================================================ */
.rv{opacity:0;transform:translateY(14px);transition:opacity .55s var(--ease-out-deep),transform .6s var(--ease-out-deep);will-change:transform,opacity}
.rv.in{opacity:1;transform:none}
.rv-d1{transition-delay:.06s}.rv-d2{transition-delay:.12s}.rv-d3{transition-delay:.18s}

/* retina hairlines */
@media (min-resolution:2dppx){
  .steps,.step,.hero-meta,.proof,.footer,.footer-base{border-width:.5px}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1000px){
  .hero-meta .hero-social{margin-left:0;flex-basis:100%}
  /* a long role ("marketing strategist") can't fit one line here — allow wrap; reserve 2 lines so rotation doesn't bounce the page */
  .role-rotator{white-space:normal;min-height:1.86em}
  .about-grid{grid-template-columns:1fr}
  .about-visual{aspect-ratio:16/11;max-width:460px}
  .about-visual--circle{aspect-ratio:1;max-width:300px}
  .svc-grid{grid-template-columns:1fr}
  .work-more{grid-template-columns:1fr 1fr}
  .nav-avail{display:none}
  .nav-toggle{display:flex}
  .nav{overflow:visible} /* let the dropdown escape the pill (hover sheen is hover-only, so safe on touch) */
  /* the dropdown needs near-opaque glass — the .38 nav tint is too transparent to read a menu over content */
  .nav[data-context="light"] .nav-links{background:rgba(250,248,243,.92)}
  .nav[data-context="dark"] .nav-links{background:rgba(13,40,34,.92)}
  .nav-links{
    position:absolute;top:calc(100% + 10px);right:8px;left:8px;flex-direction:column;align-items:stretch;gap:2px;
    padding:8px;border-radius:16px;
    -webkit-backdrop-filter:blur(20px) saturate(150%);backdrop-filter:blur(20px) saturate(150%);
    border:1px solid var(--nav-border);box-shadow:0 20px 44px -16px rgba(20,24,20,.45);
    opacity:0;transform:translateY(-8px) scale(.985);transform-origin:top;pointer-events:none;
    transition:opacity .26s var(--ease-quick),transform .26s var(--ease-out-soft);
  }
  .nav.is-open .nav-links{opacity:1;transform:none;pointer-events:auto}
  .nav-links a{font-size:16px;padding:12px 14px;border-radius:10px;color:var(--nav-fg)}
  .nav-links a::after{display:none}
  .nav-links a:hover{background:rgba(127,140,134,.16)}
  .step{grid-template-columns:56px 1fr}
  .step .s-tag{display:none}
}
@media (max-width:600px){
  .shell{max-width:100%;margin:0}
  .nav{top:10px;width:calc(100% - 20px);border-radius:16px}
  .work-more{grid-template-columns:1fr}
  /* phones: same rectangular frame as the grid cards (full cover visible, no tall crop) — still sticky-stacking */
  .work-card{height:auto;aspect-ratio:5/4;top:84px}
  .wc-cat{display:none} /* the category pill wraps awkwardly at this width; the index line already names the project */
  .wc-bottom h3{display:none} /* covers carry the project name at this size — the big title doubles it and hides the art */
  .wc-bottom p{display:none}
  .nav__content{padding:0 10px 0 16px}
  .brand{font-size:19px}
  /* keep only corner icons so none overlap the centered text */
  .fi-4,.fi-6,.fi-7,.fi-8,.fi-11,.fi-12,.fi-14{display:none}
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .rv{opacity:1;transform:none}
  .marquee-track{animation:none}
  .carousel__track{scroll-behavior:auto}
  html{scroll-behavior:auto}
}

/* ============================================================
   SUBPAGES — /work, /work/<project>, /services
   ============================================================ */
/* nav logo via mask so subpages don't carry the inline paths; adapts via currentColor */
.brand-mask-img{display:block;width:63px;height:42px;background:currentColor;color:var(--nav-fg);
  -webkit-mask:url(/assets/img/ken-monogram-ink.svg) no-repeat center / contain;
          mask:url(/assets/img/ken-monogram-ink.svg) no-repeat center / contain;
  transition:color .4s var(--ease-quick)}
.nav-links a[aria-current="page"]{color:var(--nav-fg)}
.nav-links a[aria-current="page"]::after{transform:scaleX(1)}

/* ---- page hero (shared) ---- */
.page-hero{padding:calc(var(--nav-h) + 92px) var(--pad) clamp(34px,6vh,60px);
  background:linear-gradient(180deg,rgba(231,227,214,.62),rgba(250,248,243,0) 60%)}
.page-hero .eyebrow{display:block;margin-bottom:18px}
.page-hero h1{font-size:clamp(2.7rem,1.5rem + 5.2vw,6rem);line-height:.95;letter-spacing:-.03em}
.page-hero h1 .reg{font-size:.45em;vertical-align:super;line-height:0;margin-left:.04em}
.page-hero .page-sub{margin-top:20px;color:var(--muted);max-width:54ch;font-size:var(--fs-body);line-height:1.55}
.page-hero .page-actions{display:flex;gap:12px;margin-top:26px;flex-wrap:wrap}

/* ---- work index grid ---- */
.windex{padding:clamp(10px,2vh,24px) var(--pad) clamp(70px,10vh,120px)}
.windex-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}

/* ---- case study ---- */
.cs{padding:clamp(20px,3.5vh,40px) var(--pad) clamp(64px,9vh,110px)}
.cs-wrap{max-width:1060px;margin:0 auto}
.cs-cover{border-radius:4px;overflow:hidden;background:var(--paper-deep);margin-bottom:clamp(30px,5.5vh,58px)}
.cs-cover img{width:100%;height:auto;display:block}
.cs-body h2,.cs-body h3{font-family:var(--serif);font-weight:300;letter-spacing:-.02em;line-height:1.06;color:var(--ink);
  max-width:26ch;margin:clamp(34px,5.5vh,58px) 0 14px}
.cs-body h2{font-size:clamp(1.7rem,1.2rem + 1.9vw,2.7rem)}
.cs-body h3{font-size:clamp(1.35rem,1.1rem + 1.1vw,1.9rem)}
.cs-body p{max-width:70ch;color:var(--ink-soft);margin:14px 0;font-size:clamp(16px,1.25vw,17.5px);line-height:1.65}
.cs-body ul,.cs-body ol{max-width:66ch;margin:14px 0 14px 1.25em;color:var(--ink-soft);font-size:clamp(16px,1.25vw,17.5px);line-height:1.6;display:flex;flex-direction:column;gap:8px}
.cs-body blockquote{border-left:2px solid var(--accent);padding-left:22px;margin:clamp(26px,4vh,40px) 0;
  font-family:var(--serif);font-weight:300;font-size:clamp(1.25rem,1.05rem + .9vw,1.7rem);line-height:1.3;color:var(--ink);max-width:46ch}
.cs-body hr{border:0;border-top:1px solid var(--line);margin:clamp(30px,5vh,52px) 0}
.cs-fig{margin:clamp(22px,4vh,42px) 0;border-radius:4px;overflow:hidden;background:var(--paper-deep)}
.cs-fig img,.cs-fig video{width:100%;height:auto;display:block}
.cs-cap{font-size:13px;color:var(--muted);margin-top:10px}
.cs-visit{margin:clamp(22px,4vh,38px) 0}
/* prev / next */
.cs-pn{display:grid;grid-template-columns:1fr 1fr;gap:16px;max-width:1060px;margin:clamp(40px,7vh,72px) auto 0;
  border-top:1px solid var(--line);padding-top:26px}
.pn-card{display:flex;flex-direction:column;gap:8px;padding:22px 20px;border:1px solid var(--line);border-radius:4px;
  transition:transform .35s var(--ease-out-soft),background .3s var(--ease-quick),border-color .3s var(--ease-quick)}
.pn-card:hover{transform:translateY(-3px);background:var(--paper);border-color:var(--line-dark)}
.pn-card.pn-next{text-align:right;align-items:flex-end}
.pn-k{font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--eyebrow-ink)}
.pn-t{font-family:var(--serif);font-weight:400;font-size:clamp(18px,1.8vw,24px);letter-spacing:-.01em;color:var(--ink)}

/* ---- services page ---- */
.services--page{background:
  linear-gradient(180deg,var(--paper-soft) 0,rgba(250,248,243,0) 58px),
  linear-gradient(0deg,var(--paper-soft) 0,rgba(250,248,243,0) 58px),
  radial-gradient(135% 105% at 50% -12%,#13413c 0%,#0d2b27 46%,#051512 100%)}
.svc-price{display:flex;align-items:baseline;gap:10px;margin-top:auto;padding-top:20px;border-top:1px solid rgba(180,205,160,.16)}
.svc-price em{font-family:var(--serif);font-weight:300;font-size:clamp(24px,2.2vw,32px);color:#f2f8f4;letter-spacing:-.02em}
.svc-price span{font-size:13px;color:#9db8ac}
/* reviews */
.reviews{padding:clamp(70px,10vh,120px) var(--pad);background:var(--paper-soft)}
.reviews-list{max-width:820px;margin:0 auto}
.review{padding:clamp(26px,4.5vh,44px) 0;border-bottom:1px solid var(--line)}
.review:last-child{border-bottom:0}
.review p{font-family:var(--serif);font-weight:300;font-size:clamp(1.2rem,1rem + 1.1vw,1.75rem);line-height:1.34;letter-spacing:-.01em;color:var(--ink)}
.review .review-by{margin-top:14px;font-family:var(--sans);font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--eyebrow-ink)}

@media (max-width:1000px){
  .windex-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:600px){
  .windex-grid{grid-template-columns:1fr}
  .cs-pn{grid-template-columns:1fr}
  .pn-card.pn-next{text-align:left;align-items:flex-start}
}

/* ---- work-grid video covers (mp4 loops of the original gifs) ---- */
.wm-card video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease-out-soft)}
.wm-card:hover video{transform:scale(1.04)}

/* ---- services accordion rows (Contra-style: row → expands with details) ---- */
.svc-rows{display:flex;flex-direction:column;gap:12px;margin-top:clamp(34px,5vh,48px)}
.svc-row{overflow:hidden}
.svc-row-head{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:clamp(14px,2.6vw,34px);
  width:100%;padding:22px clamp(18px,2.6vw,30px);background:none;border:0;cursor:pointer;text-align:left;color:#d3e2da;
  transition:background .3s var(--ease-quick)}
.svc-row-head:hover{background:rgba(163,196,147,.07)}
.svc-row-i{font-family:var(--serif);font-weight:300;font-size:15px;color:var(--accent-soft)}
.svc-row-t{font-size:clamp(19px,2vw,26px);color:#f2f8f4;letter-spacing:-.02em}
.svc-row-meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.svc-row-meta em{font-family:var(--serif);font-weight:300;font-size:clamp(19px,1.9vw,25px);color:#f2f8f4;letter-spacing:-.02em}
.svc-row-meta span{font-size:12.5px;color:#9db8ac;white-space:nowrap}
.svc-row-toggle{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:500;color:#c6d8cd;white-space:nowrap;
  border:1px solid rgba(180,205,160,.3);border-radius:999px;padding:9px 15px;transition:background .3s var(--ease-quick),border-color .3s var(--ease-quick)}
.svc-row-head:hover .svc-row-toggle{background:rgba(163,196,147,.12);border-color:rgba(170,200,150,.45)}
.svc-row-toggle .chev{width:13px;height:13px;transition:transform .4s var(--ease-out-soft)}
.svc-row.open .svc-row-toggle .chev{transform:rotate(180deg)}
/* smooth expand via the 0fr→1fr grid trick */
.svc-row-panel{display:grid;grid-template-rows:0fr;transition:grid-template-rows .5s var(--ease-out-soft)}
.svc-row.open .svc-row-panel{grid-template-rows:1fr}
.svc-row-body{overflow:hidden;min-height:0;padding:0 clamp(18px,2.6vw,30px)}
.svc-row.open .svc-row-body{padding-bottom:28px}
.svc-row-body p{max-width:64ch;color:#c6d8cd;font-size:15.5px;line-height:1.6;margin:12px 0}
.svc-row-body h3{font-family:var(--serif);font-weight:300;font-size:19px;color:#eef6f1;letter-spacing:-.01em;margin:20px 0 4px}
.svc-row-body ul{list-style:none;max-width:64ch;margin:12px 0;display:flex;flex-direction:column;gap:8px}
.svc-row-body li{font-size:14.5px;color:#c6d8cd;display:flex;gap:10px;align-items:baseline}
.svc-row-body li::before{content:"";width:5px;height:5px;border-radius:50%;background:#7fa863;flex:none;transform:translateY(-2px)}
.svc-delivs{margin-top:8px}
.svc-deliv{padding:14px 0;border-top:1px solid rgba(180,205,160,.14)}
.svc-deliv h4{font-family:var(--sans);font-weight:600;font-size:14px;color:#eef6f1;letter-spacing:.01em}
.svc-deliv p{margin:5px 0 0;font-size:14px;color:#a8c2b5}
.svc-row-cta{margin-top:20px}
@media (max-width:760px){
  .svc-row-head{grid-template-columns:auto 1fr;grid-template-rows:auto auto;row-gap:10px}
  .svc-row-meta{grid-column:2;justify-self:start;align-items:flex-start;flex-direction:row;align-items:baseline;gap:10px}
  .svc-row-toggle{grid-column:1 / -1;justify-self:start}
}

/* ---- reviews: center-mode scroller (Contra-style — active quote centered, neighbors faded) ---- */
.rev-carousel{position:relative}
.rev-track{display:flex;gap:clamp(44px,7vw,100px);list-style:none;margin:0;
  overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;overscroll-behavior-x:contain;
  padding:8px max(calc((100% - 800px)/2),9%) 16px;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 16%,#000 84%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 16%,#000 84%,transparent)}
.rev-track::-webkit-scrollbar{display:none}
.rev-track:focus-visible{outline:2px solid var(--accent);outline-offset:4px;border-radius:4px}
.rev-slide{flex:0 0 min(800px,82%);scroll-snap-align:center;scroll-snap-stop:always;
  opacity:.18;transition:opacity .5s var(--ease-quick)}
.rev-slide.is-center{opacity:1}
.rev-q{font-family:var(--serif);font-weight:300;font-size:clamp(1.2rem,1rem + 1.1vw,1.75rem);line-height:1.34;letter-spacing:-.01em;color:var(--ink)}
.rev-by{margin-top:20px;font-family:var(--sans);font-size:12.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);line-height:1.8}
.rev-by span{font-weight:500;color:var(--eyebrow-ink)}
.rev-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:3;
  width:44px;height:44px;display:grid;place-items:center;padding:0;border:0;background:none;cursor:pointer;
  color:var(--ink);opacity:.55;transition:opacity .2s var(--ease-quick),transform .25s var(--ease-out-soft)}
.rev-btn svg{width:26px;height:26px}
.rev-btn--prev{left:clamp(2px,2vw,28px)}
.rev-btn--next{right:clamp(2px,2vw,28px)}
.rev-carousel:hover .rev-btn,.rev-carousel:focus-within .rev-btn{opacity:.9}
.rev-btn:hover{transform:translateY(-50%) scale(1.12)}
.rev-btn:active{transform:translateY(-50%) scale(.94)}
.rev-btn[aria-disabled="true"]{opacity:.18;cursor:default}
@media (hover:none){.rev-btn{opacity:.9}}
@media (max-width:600px){
  .rev-slide{flex-basis:88%}
  .rev-track{padding-inline:max(calc((100% - 800px)/2),7%)}
}

/* ---- footer chrome logo — port of the Figma Make 3D chrome spin ----
   Stacked mask layers (dark "edge" gradients behind a bright chrome face)
   rotating on Y in a perspective box; 7s linear, continuous, no pauses. */
.chrome-spin{display:block;width:178px;height:120px;perspective:380px}
.chrome-rotor{display:block;position:relative;width:100%;height:100%;transform-style:preserve-3d;animation:chrome-spin 7s linear infinite}
@keyframes chrome-spin{from{transform:rotateY(0deg)}to{transform:rotateY(360deg)}}
.cl{position:absolute;inset:0;
  -webkit-mask:url(/assets/img/ken-monogram-ink.svg) no-repeat center / contain;
          mask:url(/assets/img/ken-monogram-ink.svg) no-repeat center / contain}
.cl--edge{background:linear-gradient(180deg,#2a2a2a 0%,#606060 17%,#909090 33%,#555 50%,#404040 67%,#707070 83%,#2a2a2a 100%)}
.cl--front{background:linear-gradient(180deg,#3a3a3a 0%,#8c8c8c 8%,#d8d8d8 17%,#fff 25%,#b8b8b8 33%,#fff 42%,#e0e0e0 50%,#9a9a9a 58%,#555 67%,#aaa 75%,#e8e8e8 83%,#707070 92%,#3a3a3a 100%)}
.cl--sheen{background:linear-gradient(135deg,rgba(255,255,255,0) 35%,rgba(255,255,255,.35) 50%,rgba(255,255,255,0) 65%);transform:translateZ(.5px)}
.cl--e1{transform:translateZ(-1px)}.cl--e2{transform:translateZ(-2px)}.cl--e3{transform:translateZ(-3px)}
.cl--e4{transform:translateZ(-4px)}.cl--e5{transform:translateZ(-5px)}.cl--e6{transform:translateZ(-6px)}
.cl--e7{transform:translateZ(-7px)}.cl--e8{transform:translateZ(-8px)}.cl--e9{transform:translateZ(-9px)}.cl--e10{transform:translateZ(-10px)}

/* ---- Landdding "Site of the Day" badge (Twin Coves) ---- */
.sotd{position:absolute;right:clamp(22px,3vw,44px);bottom:clamp(22px,3vw,44px);z-index:3;pointer-events:auto;
  transition:transform .3s var(--ease-out-soft)}
.sotd:hover{transform:translateY(-3px)}
.sotd img{display:block;height:48px;width:auto;border-radius:13px;box-shadow:0 14px 34px -12px rgba(0,0,0,.5)}
.cs-cover{position:relative}
.cs-cover .sotd{right:20px;bottom:20px}
@media (max-width:600px){
  /* phones: bottom-right collides with the tag row — tuck it top-right where the category pill was */
  .work-card .sotd{top:16px;right:16px;bottom:auto}
  .sotd img{height:40px}
}
/* square award badge variant (IDA) */
.sotd--sq img{height:74px;border-radius:8px}
@media (max-width:600px){.sotd--sq img{height:56px}}
