/* ============================================================
   LUMORA — style.css (reads ONLY var(--token) from tokens.css)
   Warm cinematic studio. Reconstructed from cinery.webflow.io DNA:
   full-bleed dark stage hero, looping word-marquee, rounded dark cards,
   pill CTAs (amber-filled, invert on hover), giant footer wordmark.
   Adds a readable long-form layer (.prose) for journal + case studies.
   ============================================================ */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);font-size:var(--fs-body);line-height:1.6;
  color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}

/* —— layout —— */
.section{background:var(--bg);color:var(--ink);position:relative}
.wrap{max-width:var(--container);margin-inline:auto;padding:var(--section-y) var(--gutter)}
.wrap-tight{max-width:46rem;margin-inline:auto;padding-inline:var(--gutter)}

/* —— typography —— */
.display,h1{font-family:var(--font-display);font-size:var(--fs-display);font-weight:var(--w-bold);
  letter-spacing:var(--tracking-tight);line-height:var(--lh-display)}
.h2,h2{font-family:var(--font-display);font-size:var(--fs-h2);font-weight:var(--w-semi);
  letter-spacing:var(--tracking-tight);line-height:var(--lh-h2)}
.h3,h3{font-family:var(--font-display);font-size:var(--fs-h3);font-weight:var(--w-med);letter-spacing:var(--tracking-tight)}
.lead{font-size:var(--fs-lead);color:var(--body);line-height:1.55;max-width:54ch}
.muted{color:var(--body)}
.reg{font-weight:var(--w-reg)}
.accent{color:var(--accent)}

/* eyebrow / label — glyph in amber */
.eyebrow{display:inline-flex;align-items:center;gap:.55em;font-family:var(--font-display);
  font-size:var(--fs-eyebrow);font-weight:var(--w-med);letter-spacing:var(--tracking-eyebrow);
  text-transform:var(--eyebrow-transform);color:var(--body)}
.eyebrow::before{content:var(--eyebrow-glyph);color:var(--accent);font-size:.85em}
.eyebrow--num::before{content:none}
.eyebrow-num{color:var(--body);font-family:var(--font-display);font-weight:var(--w-med)}

/* —— buttons — pill, amber-filled, invert to outline on hover —— */
.btn{display:inline-flex;align-items:center;gap:.55em;font-family:var(--font-display);font-weight:var(--w-med);
  font-size:.95rem;padding:.95em 1.7em;border-radius:var(--radius-pill);cursor:pointer;
  border:var(--bw) solid var(--accent);
  transition:background var(--dur) var(--ease),color var(--dur) var(--ease),border-color var(--dur) var(--ease)}
.btn-primary{background:var(--accent);color:var(--accent-ink)}
.btn-primary:hover{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--border)}
.btn-ghost:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.btn-arrow::after{content:"\2192";transition:transform var(--dur) var(--ease)}
.btn-arrow:hover::after{transform:translateX(4px)}

/* —— nav —— */
.nav{position:sticky;top:0;z-index:60;background:color-mix(in srgb,var(--bg) 80%,transparent);
  backdrop-filter:blur(12px);border-bottom:var(--bw) solid transparent;transition:border-color var(--dur) var(--ease)}
.nav.is-stuck{border-color:var(--border)}
.nav-row{max-width:var(--container);margin-inline:auto;padding:1rem var(--gutter);
  display:flex;align-items:center;justify-content:space-between;gap:1rem}
.nav-logo{font-family:var(--font-display);font-weight:var(--w-bold);font-size:1.35rem;letter-spacing:-.02em;
  display:inline-flex;align-items:baseline;gap:.05rem}
.nav-logo .sup{font-size:.55em;font-weight:var(--w-med);vertical-align:super;color:var(--accent)}
.nav-links{display:flex;align-items:center;gap:1.7rem}
.nav-links a{font-family:var(--font-display);font-weight:var(--w-med);font-size:.95rem;color:var(--body);
  transition:color var(--dur) var(--ease)}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--ink)}
.nav-cta{display:flex;align-items:center;gap:.6rem}
.nav-burger{display:none;background:none;border:var(--bw) solid var(--border);border-radius:var(--radius-pill);
  width:44px;height:44px;font-size:1.2rem;cursor:pointer;color:var(--ink)}

/* —— hero — full-bleed dark stage —— */
.hero .wrap{padding-top:clamp(3rem,7vw,5rem);padding-bottom:clamp(2.5rem,5vw,3.5rem)}
.hero-eyebrows{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:clamp(2rem,5vw,3.5rem)}
.hero-h1{margin:0 0 1.4rem;max-width:18ch}
.hero-h1 em{font-style:normal;color:var(--accent)}
.hero-lead{max-width:60ch}
.hero-actions{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:2rem}
/* hero-meta — compact inline stat row (Lumora layout shift vs Noctura) */
.hero-meta{display:flex;flex-wrap:wrap;gap:clamp(1.5rem,5vw,3.5rem);margin-top:clamp(2rem,5vw,3rem);
  padding-top:clamp(1.5rem,4vw,2rem);border-top:var(--bw) solid var(--border)}
.hero-meta .n{font-family:var(--font-display);font-size:clamp(1.6rem,3vw,2.2rem);font-weight:var(--w-bold);
  letter-spacing:-.02em;line-height:1;color:var(--ink)}
.hero-meta .l{color:var(--body);font-size:.9rem;margin-top:.4rem;max-width:22ch}
.hero-media{margin-top:clamp(2.5rem,6vw,4rem);border-radius:var(--radius-huge);overflow:hidden;
  aspect-ratio:16/8;background:var(--surface-alt)}
.hero-media img{width:100%;height:100%;object-fit:cover}

/* —— word marquee (signature service-word strip) —— */
.marquee-strip{border-top:var(--bw) solid var(--border);border-bottom:var(--bw) solid var(--border);
  background:var(--bg);padding-block:clamp(1.4rem,3vw,2rem)}
.marquee{overflow:hidden;
  -webkit-mask:linear-gradient(90deg,transparent,#000 var(--marquee-fade),#000 calc(100% - var(--marquee-fade)),transparent);
  mask:linear-gradient(90deg,transparent,#000 var(--marquee-fade),#000 calc(100% - var(--marquee-fade)),transparent)}
.marquee-track{display:flex;width:max-content;gap:0;align-items:center;animation:marquee var(--marquee-speed) linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-item{font-family:var(--font-display);font-weight:var(--w-med);
  font-size:clamp(1.6rem,3.4vw,2.6rem);letter-spacing:-.01em;color:var(--ink);white-space:nowrap;
  display:inline-flex;align-items:center}
.marquee-item::after{content:"\2736";margin-inline:clamp(1rem,3vw,2.2rem);color:var(--accent);opacity:.85;font-size:.7em}
@keyframes marquee{to{transform:translateX(-50%)}}

/* —— logos row —— */
.logos .wrap{padding-block:clamp(3rem,6vw,4.5rem)}
.logos-head{text-align:center;margin-bottom:2rem;color:var(--body);font-family:var(--font-display);font-weight:var(--w-med)}
.logos-row{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:clamp(1.5rem,5vw,4rem)}
.logos-row span{font-family:var(--font-display);font-weight:var(--w-med);font-size:1.4rem;letter-spacing:-.01em;
  color:var(--ink);opacity:.45;transition:opacity var(--dur) var(--ease)}
.logos-row span:hover{opacity:.9}

/* —— head row (eyebrow + heading + side) —— */
.head{display:flex;justify-content:space-between;align-items:flex-end;gap:1.5rem;flex-wrap:wrap;margin-bottom:clamp(2rem,4vw,3rem)}
.head .h2{max-width:20ch}
.head .lead{margin-top:1rem}

/* —— about split —— */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center}
.split.rev .split-media{order:2}
.split-media{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3;background:var(--surface-alt)}
.split-media img{width:100%;height:100%;object-fit:cover;transition:transform var(--dur) var(--ease)}
.split-media:hover img{transform:var(--hover-img)}
.split .lead{margin:1.2rem 0 1.6rem}

/* —— stats band (count-up) —— */
.stat-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:clamp(1.5rem,4vw,3rem)}
.stat-item .n{font-family:var(--font-display);font-size:clamp(2.4rem,5vw,3.4rem);font-weight:var(--w-bold);
  letter-spacing:-.02em;line-height:1;color:var(--accent)}
.stat-item .l{color:var(--body);font-size:.95rem;margin-top:.5rem;max-width:20ch}

/* —— work grid (rounded dark cards) —— */
.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1.2rem,2.5vw,1.75rem)}
.work-card{display:block;background:var(--card);border:var(--bw) solid var(--border);border-radius:var(--radius-lg);
  overflow:hidden;transition:transform var(--dur) var(--ease)}
.work-card:hover{transform:var(--hover-card)}
.work-media{aspect-ratio:16/11;overflow:hidden;background:var(--surface-alt)}
.work-media img{width:100%;height:100%;object-fit:cover;transition:transform var(--dur) var(--ease)}
.work-card:hover .work-media img{transform:var(--hover-img)}
.work-body{padding:clamp(1.3rem,2.5vw,1.8rem);display:flex;justify-content:space-between;align-items:baseline;gap:1rem}
.work-body .name{font-family:var(--font-display);font-weight:var(--w-med);font-size:1.2rem}
.work-body .cat{color:var(--body);font-size:.9rem;white-space:nowrap}

/* —— services cards —— */
.srv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:clamp(1.2rem,2.5vw,1.75rem)}
.srv-card{background:var(--card);border:var(--bw) solid var(--border);border-radius:var(--radius-lg);
  padding:clamp(1.6rem,3vw,2.4rem);transition:transform var(--dur) var(--ease)}
.srv-card:hover{transform:var(--hover-card)}
.srv-card .num{font-family:var(--font-display);color:var(--accent);font-weight:var(--w-med);font-size:.95rem}
.srv-card h3{margin:1.4rem 0 .35rem}
.srv-card .tag{color:var(--body);font-size:.9rem;margin-bottom:1rem}
.srv-card p{color:var(--body)}

/* —— services rows (alt list layout — used on home for Lumora) —— */
.srv-rows{border-top:var(--bw) solid var(--border)}
.srv-row{display:grid;grid-template-columns:auto 1fr 1.4fr;gap:clamp(1rem,3vw,2.5rem);align-items:center;
  padding:clamp(1.6rem,3vw,2.2rem) 0;border-bottom:var(--bw) solid var(--border);
  transition:padding-left var(--dur) var(--ease)}
.srv-row:hover{padding-left:.8rem}
.srv-row .num{font-family:var(--font-display);color:var(--accent);font-weight:var(--w-med)}
.srv-row h3{margin:0}
.srv-row p{color:var(--body);margin:0}

/* —— process steps —— */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:clamp(1.2rem,2.5vw,1.75rem)}
.step{background:var(--card);border:var(--bw) solid var(--border);border-radius:var(--radius-lg);
  padding:clamp(1.6rem,3vw,2.2rem);transition:transform var(--dur) var(--ease)}
.step:hover{transform:var(--hover-card)}
.step-n{display:inline-grid;place-items:center;width:42px;height:42px;border-radius:var(--radius-pill);
  background:var(--accent);color:var(--accent-ink);font-family:var(--font-display);font-weight:var(--w-bold);margin-bottom:1.2rem}
.step h3{font-size:1.2rem;margin-bottom:.5rem}
.step p{color:var(--body)}

/* —— testimonials —— */
.quotes{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:clamp(1.2rem,2.5vw,1.75rem)}
.quote{background:var(--card);border:var(--bw) solid var(--border);border-radius:var(--radius-lg);
  padding:clamp(1.6rem,3vw,2.2rem);display:flex;flex-direction:column;gap:1.4rem}
.quote .stars{color:var(--accent);letter-spacing:.15em;font-size:.9rem}
.quote p{line-height:1.55;font-size:1.05rem}
.quote .who{display:flex;align-items:center;gap:.8rem;margin-top:auto}
.quote .who img{width:48px;height:48px;border-radius:50%;object-fit:cover}
.quote .who .nm{font-family:var(--font-display);font-weight:var(--w-med);font-size:.95rem;display:block}
.quote .who .rl{font-size:.85rem;color:var(--body)}

/* —— pricing —— */
.price-wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(1.5rem,4vw,3rem);align-items:start}
.price-card{background:var(--card);border:var(--bw) solid var(--border);border-radius:var(--radius-huge);
  padding:clamp(2rem,4vw,3rem)}
.price-card.is-feature{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}
.price-card.is-feature .muted,.price-card.is-feature .price-old,.price-card.is-feature .price-meta{color:color-mix(in srgb,var(--accent-ink) 65%,var(--accent))}
.price-old{text-decoration:line-through;color:var(--body);font-size:1.2rem;margin-right:.5rem}
.price-now{font-family:var(--font-display);font-size:clamp(2.6rem,6vw,3.6rem);font-weight:var(--w-bold);letter-spacing:-.02em;line-height:1}
.price-now .per{font-size:1.1rem;font-weight:var(--w-med);color:inherit;opacity:.7}
.price-meta{color:var(--body);font-size:.9rem;margin-top:.6rem}
.price-feature-list{list-style:none;display:grid;gap:.85rem;margin:1.8rem 0}
.price-feature-list li{display:flex;gap:.7rem;align-items:flex-start}
.price-feature-list li::before{content:"\2713";font-weight:var(--w-bold)}
.price-card.is-feature .btn-primary{background:var(--accent-ink);color:var(--accent);border-color:var(--accent-ink)}
.price-card.is-feature .btn-primary:hover{background:transparent;color:var(--accent-ink);border-color:var(--accent-ink)}
.price-aside{display:grid;gap:1.2rem}
.price-aside .panel{background:var(--card);border:var(--bw) solid var(--border);border-radius:var(--radius-lg);padding:1.6rem}
.price-aside .panel .big{font-family:var(--font-display);font-size:1.6rem;font-weight:var(--w-bold);line-height:1;color:var(--accent)}

/* —— comparison table —— */
.cmp{width:100%;border-collapse:collapse;font-size:.98rem}
.cmp th,.cmp td{text-align:left;padding:1rem 1.2rem;border-bottom:var(--bw) solid var(--border)}
.cmp thead th{font-family:var(--font-display);font-weight:var(--w-med);color:var(--body);font-size:.85rem;
  text-transform:uppercase;letter-spacing:.08em}
.cmp td.yes{color:var(--ink);font-weight:var(--w-med)}
.cmp td.yes::before{content:"\2713 ";color:var(--accent)}
.cmp td.no{color:var(--body)}
.cmp-wrap{border:var(--bw) solid var(--border);border-radius:var(--radius-lg);overflow:hidden}

/* —— faq —— */
.faq-list{border-top:var(--bw) solid var(--border)}
.faq-item{border-bottom:var(--bw) solid var(--border)}
.faq-item summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1.5rem;
  padding:clamp(1.4rem,3vw,1.9rem) 0;font-family:var(--font-display);font-weight:var(--w-med);font-size:1.15rem}
.faq-item summary::-webkit-details-marker{display:none}
.faq-q-num{color:var(--accent);font-weight:var(--w-med);margin-right:.9rem}
.faq-item summary .sign{margin-left:auto;font-size:1.4rem;color:var(--accent);transition:transform var(--dur) var(--ease);flex:none}
.faq-item[open] summary .sign{transform:rotate(45deg)}
.faq-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows var(--dur) var(--ease)}
.faq-item[open] .faq-body{grid-template-rows:1fr}
.faq-body>div{overflow:hidden;min-height:0}
.faq-body p{color:var(--body);padding-bottom:clamp(1.3rem,3vw,1.8rem);max-width:70ch}

/* —— blog grid (featured-first) —— */
.posts{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:clamp(1.2rem,2.5vw,1.75rem)}
.post{display:block;background:var(--card);border:var(--bw) solid var(--border);border-radius:var(--radius-lg);overflow:hidden;
  transition:transform var(--dur) var(--ease)}
.post:hover{transform:var(--hover-card)}
.post-media{aspect-ratio:16/10;overflow:hidden;background:var(--surface-alt)}
.post-media img{width:100%;height:100%;object-fit:cover;transition:transform var(--dur) var(--ease)}
.post:hover .post-media img{transform:var(--hover-img)}
.post-body{padding:clamp(1.4rem,2.5vw,1.8rem)}
.post-meta{display:flex;gap:.6rem;align-items:center;color:var(--body);font-size:.85rem;margin-bottom:.8rem}
.post-meta .tagchip{color:var(--accent)}
.post-body h3{margin-bottom:.6rem}
.post-body .more{color:var(--accent);font-family:var(--font-display);font-weight:var(--w-med);font-size:.9rem;margin-top:1rem;display:inline-block}
/* featured post spans two columns on wide screens */
.posts .post.feat{grid-column:1 / -1;display:grid;grid-template-columns:1.15fr 1fr}
.posts .post.feat .post-media{aspect-ratio:auto;height:100%;min-height:280px}
.posts .post.feat .post-body{align-self:center;padding:clamp(1.8rem,4vw,3rem)}

/* —— team —— */
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:clamp(1.2rem,2.5vw,1.75rem)}
.member{background:var(--card);border:var(--bw) solid var(--border);border-radius:var(--radius-lg);overflow:hidden;
  transition:transform var(--dur) var(--ease)}
.member:hover{transform:var(--hover-card)}
.member-media{aspect-ratio:3/4;overflow:hidden;background:var(--surface-alt)}
.member-media img{width:100%;height:100%;object-fit:cover;transition:transform var(--dur) var(--ease)}
.member:hover .member-media img{transform:var(--hover-img)}
.member-body{padding:1.3rem 1.4rem 1.6rem}
.member-body .nm{font-family:var(--font-display);font-weight:var(--w-med);font-size:1.1rem;display:block}
.member-body .rl{color:var(--accent);font-size:.9rem;margin-top:.25rem}

/* —— case studies (zig-zag listing) —— */
.case{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center;
  padding-block:clamp(2.5rem,5vw,4rem);border-top:var(--bw) solid var(--border)}
.case:nth-child(even) .case-media{order:2}
.case-media{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3;background:var(--surface-alt)}
.case-media img{width:100%;height:100%;object-fit:cover;transition:transform var(--dur) var(--ease)}
.case-media:hover img{transform:var(--hover-img)}
.case-stats{display:flex;flex-wrap:wrap;gap:2rem;margin-top:1.6rem}
.case-stats .n{font-family:var(--font-display);font-size:1.8rem;font-weight:var(--w-bold);line-height:1;color:var(--accent)}
.case-stats .l{color:var(--body);font-size:.85rem;margin-top:.3rem}
.case .links{margin-top:1.6rem}

/* —— newsletter —— */
.news{background:var(--card);border:var(--bw) solid var(--border);border-radius:var(--radius-huge);
  padding:clamp(2rem,5vw,3.5rem);text-align:center}
.news form{display:flex;gap:.7rem;max-width:30rem;margin:1.6rem auto 0;flex-wrap:wrap;justify-content:center}
.news input{flex:1 1 220px;font-family:var(--font-body);font-size:1rem;color:var(--ink);background:var(--bg);
  border:var(--bw) solid var(--border);border-radius:var(--radius-pill);padding:.9em 1.4em}
.news input:focus{outline:none;border-color:var(--accent)}

/* —— cta —— */
.cta{text-align:center}
.cta .display{margin:0 auto .6rem;max-width:14ch}
.cta-actions{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;margin-top:1.8rem}

/* —— contact —— */
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:start}
.info-list{display:flex;flex-direction:column;gap:1.5rem}
.info-item .k{font-family:var(--font-display);font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;
  color:var(--accent);margin-bottom:.4rem}
.info-item .v{font-size:1.1rem;font-weight:var(--w-med)}
.form{display:grid;gap:1rem}
.field{display:grid;gap:.45rem}
.field label{font-family:var(--font-display);font-size:.85rem;font-weight:var(--w-med);color:var(--body)}
.field input,.field textarea,.field select{font-family:var(--font-body);font-size:1rem;color:var(--ink);background:var(--card);
  border:var(--bw) solid var(--border);border-radius:var(--radius-md);padding:.9em 1.1em;width:100%;
  transition:border-color var(--dur) var(--ease)}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--accent)}
.field textarea{min-height:150px;resize:vertical}
.field-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form .btn{justify-self:start;margin-top:.4rem}

/* —— page hero (subpages) —— */
.page-hero .wrap{padding-top:clamp(3rem,7vw,4.5rem);padding-bottom:clamp(1.5rem,4vw,2.5rem)}
.page-hero .eyebrow{margin-bottom:1.2rem}
.page-hero .display{max-width:18ch}
.page-hero .lead{margin-top:1.4rem}
.crumb{display:flex;gap:.5rem;align-items:center;color:var(--body);font-size:.85rem;margin-bottom:1.4rem}
.crumb a:hover{color:var(--ink)}

/* ============================================================
   READABLE LONG-FORM — .prose (journal articles + case studies)
   ============================================================ */
.article-hero .wrap{padding-bottom:clamp(1.5rem,4vw,2.5rem)}
.article-hero .display{max-width:24ch;margin-top:1rem}
.article-meta{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;color:var(--body);font-size:.9rem;margin-top:1.6rem}
.article-meta .by{display:flex;align-items:center;gap:.6rem}
.article-meta .by img{width:36px;height:36px;border-radius:50%;object-fit:cover}
.article-meta .dot::before{content:"\00B7";margin-inline:.4rem;color:var(--accent)}
.article-cover{border-radius:var(--radius-huge);overflow:hidden;aspect-ratio:16/8;background:var(--surface-alt);
  max-width:var(--container);margin:0 auto}
.article-cover img{width:100%;height:100%;object-fit:cover}
.prose{max-width:46rem;margin-inline:auto}
.prose>*+*{margin-top:1.3rem}
.prose p{color:var(--body);font-size:1.075rem;line-height:1.75}
.prose h2{font-size:clamp(24px,3.4vw,34px);margin-top:2.6rem}
.prose h3{font-size:clamp(20px,2.4vw,26px);margin-top:2rem}
.prose ul,.prose ol{color:var(--body);padding-left:1.3rem;display:grid;gap:.6rem}
.prose li{line-height:1.7}
.prose li::marker{color:var(--accent)}
.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.prose strong{color:var(--ink);font-weight:var(--w-semi)}
.prose blockquote{border-left:3px solid var(--accent);padding:.3rem 0 .3rem 1.4rem;margin-block:2rem;
  font-family:var(--font-display);font-size:clamp(20px,2.6vw,28px);line-height:1.35;color:var(--ink);font-weight:var(--w-med)}
.prose figure{margin-block:2.2rem}
.prose figure img{border-radius:var(--radius-lg);width:100%}
.prose figcaption{color:var(--body);font-size:.85rem;margin-top:.7rem;text-align:center}
.prose hr{border:0;border-top:var(--bw) solid var(--border);margin-block:2.6rem}
.kicker{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;
  color:var(--accent);font-weight:var(--w-med)}
/* fact box (case studies) */
.factbox{background:var(--card);border:var(--bw) solid var(--border);border-radius:var(--radius-lg);
  padding:clamp(1.6rem,3vw,2.2rem);display:grid;gap:1.2rem;max-width:46rem;margin:2.4rem auto}
.factbox dl{display:grid;grid-template-columns:auto 1fr;gap:.6rem 1.4rem}
.factbox dt{font-family:var(--font-display);font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);align-self:center}
.factbox dd{color:var(--ink);font-weight:var(--w-med)}
/* related row */
.related{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:clamp(1.2rem,2.5vw,1.75rem)}

/* —— footer — giant wordmark —— */
.footer .wrap{padding-bottom:2.5rem}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2rem;padding-bottom:3rem;
  border-bottom:var(--bw) solid var(--border)}
.footer-brand .nav-logo{font-size:1.7rem;margin-bottom:1rem}
.footer-brand .muted{max-width:38ch}
.footer-col h4{font-family:var(--font-display);font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;
  color:var(--body);margin-bottom:1.1rem;font-weight:var(--w-med)}
.footer-col a{display:block;color:var(--body);padding:.35rem 0;transition:color var(--dur) var(--ease)}
.footer-col a:hover{color:var(--ink)}
.wordmark{font-family:var(--font-display);font-weight:var(--w-bold);font-size:var(--fs-wordmark);
  line-height:.82;letter-spacing:-.03em;text-align:center;color:var(--ink);margin-top:clamp(2rem,5vw,3.5rem);
  white-space:nowrap;overflow:hidden}
.wordmark .sup{color:var(--accent);font-size:.4em;vertical-align:super}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  padding-top:1.8rem;color:var(--body);font-size:.88rem}
.footer-bottom a:hover{color:var(--ink)}

/* ============================================================
   ANIMATIONS — baseline R2 (fade from LEFT, 0.15s delay) + extracted.
   start-state ONLY with JS active (.js) → no JS = text visible.
   ============================================================ */
.js [data-reveal]{opacity:0;transition:opacity var(--dur) var(--ease),transform var(--dur) var(--ease);transition-delay:var(--base-delay)}
.js [data-reveal="left"],.js [data-reveal=""]{transform:translateX(var(--base-x))}
.js [data-reveal="right"]{transform:translateX(calc(-1 * var(--base-x)))}
.js [data-reveal="up"]{transform:translateY(var(--reveal-shift))}
.js [data-reveal="down"]{transform:translateY(calc(-1 * var(--reveal-shift)))}
.js [data-reveal="fade"]{transform:none}
.js [data-reveal="scale"]{transform:scale(.94)}
.js [data-reveal].is-in{opacity:1;transform:none}
.js [data-delay="1"]{transition-delay:calc(var(--base-delay) + 1*var(--stagger))}
.js [data-delay="2"]{transition-delay:calc(var(--base-delay) + 2*var(--stagger))}
.js [data-delay="3"]{transition-delay:calc(var(--base-delay) + 3*var(--stagger))}
.js [data-delay="4"]{transition-delay:calc(var(--base-delay) + 4*var(--stagger))}
.js [data-delay="5"]{transition-delay:calc(var(--base-delay) + 5*var(--stagger))}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important;transition-delay:0!important}
  [data-reveal]{opacity:1!important;transform:none!important}
  .marquee-track{animation:none!important}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:960px){
  .split,.price-wrap,.contact-grid,.case{grid-template-columns:1fr}
  .split.rev .split-media{order:0}
  .case:nth-child(even) .case-media{order:0}
  .work-grid{grid-template-columns:1fr}
  .posts .post.feat{grid-template-columns:1fr}
  .posts .post.feat .post-media{min-height:220px}
  .srv-row{grid-template-columns:auto 1fr;gap:1rem}
  .srv-row p{grid-column:2}
  .footer-top{grid-template-columns:1fr 1fr}
  .nav-links{display:none}
  .nav-burger{display:block}
  .nav.is-open .nav-links{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;
    background:var(--bg);border-bottom:var(--bw) solid var(--border);padding:1.2rem var(--gutter);gap:1.1rem}
}
@media (max-width:560px){
  .footer-top{grid-template-columns:1fr}
  .field-2{grid-template-columns:1fr}
  .hero-media{aspect-ratio:4/3}
  .nav-cta .btn-ghost{display:none}
}
