/* Case study — ported 1:1 from content/mockups/intervyou-case-study-approved.html */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body.case-study-page{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:18px;
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}

/* ==== TOPBAR ==== */
.topbar{
  position:sticky; top:0;
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:18px 32px;
  background:rgba(244,237,224,.88);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--ink-10);
  z-index:100;
}
.topbar .back{
  font-family:var(--font-body);
  font-size:14px;
  font-weight:500;
  display:flex; align-items:center; gap:10px;
  color:var(--ink-90);
}
.topbar .back::before{
  content:'';
  width:18px; height:1px;
  background:var(--orange);
}
.topbar .marker{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-60);
  display:flex; align-items:center; gap:10px;
}
.topbar .marker::before{
  content:'';
  width:6px; height:6px; border-radius:50%;
  background:var(--orange);
}

/* ==== HERO ==== */
.hero{
  min-height:100vh;
  max-width:var(--w-wide);
  margin:0 auto;
  padding:64px var(--pad-x) 48px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  position:relative;
}
.hero-top{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-60);
}
.hero-top .left{display:flex;align-items:center;gap:14px;}
.hero-top .left::before{
  content:'';
  width:24px; height:1px;
  background:var(--orange);
}
.hero-top .right{text-align:right;line-height:1.8;}

.hero-center{
  margin-top:auto; margin-bottom:auto;
  padding:80px 0 64px;
}
.hero-eyebrow{
  font-family:var(--font-mono);
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--orange);
  margin-bottom:32px;
  display:flex; align-items:center; gap:14px;
}
.hero-eyebrow::after{
  content:'';
  flex:0 0 64px; height:1px;
  background:var(--orange);
}
.hero-title{
  font-family:var(--font-display);
  font-weight:400;
  font-size:clamp(56px,8.8vw,128px);
  line-height:.95;
  letter-spacing:-.025em;
  color:var(--ink);
  max-width:16ch;
}
.hero-title em,
.hero-title .hero-accent{
  font-style:italic;
  font-weight:400;
  color:var(--orange);
}

/* Per-letter hover — JS adds .is-lettered + .hero-char spans inside .hero-word */
.hero-title.is-lettered .hero-word{
  display:inline-block;
  white-space:nowrap;
}
.hero-title.is-lettered .hero-char{
  display:inline-block;
  transition:transform .32s cubic-bezier(.23,1,.32,1), color .32s ease;
  transform-origin:50% 100%;
  will-change:transform;
}
.hero-title.is-lettered .hero-char--space{ width:.28em; }
.hero-title.is-lettered .hero-accent .hero-char{ color:var(--orange); }
.hero-title.is-lettered:hover .hero-char{
  transform:translateY(-0.1em);
  transition-delay:calc(var(--i) * 0.018s);
}
.hero-title.is-lettered .hero-char:hover{
  transform:translateY(-0.22em) scale(1.08);
  color:var(--orange);
  transition-delay:0s;
}
.hero-title.is-lettered .hero-accent .hero-char:hover{
  color:var(--orange-deep);
  transform:translateY(-0.26em) scale(1.1);
}
.hero-lede{
  font-family:var(--font-body);
  font-size:clamp(18px,1.6vw,22px);
  line-height:1.5;
  color:var(--ink-70);
  max-width:48ch;
  margin-top:48px;
  font-weight:400;
}

.hero-meta{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:32px;
  padding-top:32px;
  border-top:1px solid var(--ink-20);
}
.hero-meta .item .label{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--ink-60);
  margin-bottom:8px;
}
.hero-meta .item .value{
  font-family:var(--font-display);
  font-size:20px;
  font-weight:400;
  letter-spacing:-.01em;
  color:var(--ink);
  line-height:1.25;
}

/* ==== PROCESS STRIP ==== */
.process{
  max-width:var(--w-figure);
  margin:24px auto 96px;
  padding:0 var(--pad-x);
}
.process-row{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:0;
  border-top:1px solid var(--ink-20);
  border-bottom:1px solid var(--ink-20);
}
.process-tick{
  padding:32px 16px;
  border-right:1px solid var(--ink-10);
  display:flex;
  flex-direction:column;
  gap:14px;
  position:relative;
}
.process-tick:last-child{border-right:0;}
.process-tick::before{
  content:'';
  position:absolute;
  top:-1px; left:0;
  width:36px; height:3px;
  background:var(--orange);
}
.process-tick .num{
  font-family:var(--font-mono);
  font-size:11px;
  color:var(--orange);
  letter-spacing:.16em;
}
.process-tick .label{
  font-family:var(--font-mono);
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--ink-90);
  font-weight:500;
}

/* ==== SECTION HEAD ==== */
.section-eyebrow{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--orange);
  margin-bottom:24px;
  display:flex; align-items:center; gap:14px;
}
.section-eyebrow::before{
  content:'';
  width:24px; height:1px;
  background:var(--orange);
}
.section-title{
  font-family:var(--font-display);
  font-weight:400;
  font-size:clamp(40px,5.5vw,72px);
  line-height:1;
  letter-spacing:-.02em;
  color:var(--ink);
}
.section-title em{font-style:italic;color:var(--orange);}

/* ==== TENSION ==== */
.tension{
  max-width:var(--w-figure);
  margin:0 auto 128px;
  padding:0 var(--pad-x);
}
.tension-head{margin-bottom:64px;}
.tension-grid{
  display:grid;
  grid-template-columns:1fr 380px;
  gap:96px;
  align-items:start;
}
.tension-body{max-width:var(--w-body);}
.tension-body p{
  font-size:19px;
  line-height:1.7;
  color:var(--ink-90);
  margin-bottom:24px;
}
.tension-body p:first-child::first-letter{
  font-family:var(--font-display);
  font-weight:500;
  font-size:90px;
  float:left;
  line-height:.82;
  margin:8px 14px 0 -4px;
  color:var(--orange);
}
.tension-body .design-q{
  font-family:var(--font-display);
  font-style:italic;
  font-size:30px;
  line-height:1.2;
  color:var(--ink);
  border-left:3px solid var(--orange);
  padding:8px 0 8px 28px;
  margin:32px 0 0;
  max-width:30ch;
  font-weight:400;
}

.tension-stat{
  position:sticky;
  top:120px;
}
.tension-stat .figure{
  font-family:var(--font-display);
  font-size:clamp(120px,16vw,220px);
  line-height:.82;
  font-weight:500;
  letter-spacing:-.045em;
  color:var(--ink);
}
.tension-stat .figure .unit{
  font-family:var(--font-display);
  font-size:.32em;
  vertical-align:top;
  margin-left:8px;
  color:var(--ink-40);
  letter-spacing:0;
}
.tension-stat .caption{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--ink-60);
  max-width:28ch;
  line-height:1.6;
  margin-top:24px;
  padding-top:20px;
  border-top:1px solid var(--ink-20);
}

/* ==== FRAMING ==== */
.framing{
  max-width:var(--w-figure);
  margin:0 auto 128px;
  padding:0 var(--pad-x);
}
.framing-head{margin-bottom:72px;}
.framing-head .section-title{max-width:18ch;}
.framing-head .intro{
  font-size:19px;
  line-height:1.65;
  color:var(--ink-70);
  max-width:60ch;
  margin-top:32px;
}
.framing-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.framing-card{
  padding:40px 36px 44px;
  background:var(--paper-soft);
  border:1px solid var(--ink-10);
  border-radius:14px;
  display:flex;
  flex-direction:column;
  gap:24px;
  min-height:340px;
  transition:transform .35s cubic-bezier(.23,1,.32,1), box-shadow .35s ease, border-color .35s ease;
}
.framing-card:hover{
  transform:translateY(-6px);
  box-shadow:0 18px 36px rgba(22,19,16,.08);
  border-color:var(--ink-20);
}
.framing-card .num{
  font-family:var(--font-mono);
  font-size:12px;
  color:var(--orange);
  letter-spacing:.18em;
  font-weight:500;
}
.framing-card .principle{
  font-family:var(--font-display);
  font-size:32px;
  line-height:1.1;
  font-weight:500;
  letter-spacing:-.015em;
  color:var(--ink);
}
.framing-card .principle em{font-style:italic;color:var(--orange);}
.framing-card .body{
  font-size:15px;
  line-height:1.6;
  color:var(--ink-70);
  margin-top:auto;
}

/* ==== CHAPTER BREAK (dark) ==== */
.chapter{
  background:var(--ink);
  color:var(--paper);
  padding:160px 0;
  margin:0 0 128px;
  position:relative;
  overflow:hidden;
}
.chapter::before{
  content:'';
  position:absolute;
  top:0; left:50%;
  transform:translateX(-50%);
  width:90%;
  max-width:var(--w-wide);
  height:1px;
  background:linear-gradient(90deg,transparent,var(--paper-20) 30%,var(--paper-20) 70%,transparent);
}
.chapter-inner{
  max-width:var(--w-wide);
  margin:0 auto;
  padding:0 var(--pad-x);
}
.chapter .section-eyebrow{color:var(--orange);}
.chapter .section-eyebrow::before{background:var(--orange);}
.chapter-title{
  font-family:var(--font-display);
  font-weight:400;
  font-size:clamp(60px,8.6vw,128px);
  line-height:.94;
  letter-spacing:-.025em;
  max-width:18ch;
  color:var(--paper);
}
.chapter-title em{font-style:italic;color:var(--orange);}

.chapter-moments{
  margin-top:120px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:32px;
}
.chapter-moment{
  border-top:1px solid var(--paper-20);
  padding-top:24px;
  display:flex;
  flex-direction:column;
  gap:18px;
}
.chapter-moment .num{
  font-family:var(--font-mono);
  font-size:13px;
  color:var(--orange);
  letter-spacing:.18em;
}
.chapter-moment .name{
  font-family:var(--font-display);
  font-size:26px;
  font-weight:400;
  line-height:1.15;
  letter-spacing:-.01em;
  color:var(--paper);
  max-width:22ch;
}

/* ==== MOMENT ==== */
.moment{
  max-width:var(--w-wide);
  margin:0 auto 160px;
  padding:0 var(--pad-x);
}
.moment-marker{
  display:grid;
  grid-template-columns:300px 1fr;
  gap:56px;
  align-items:start;
  margin-bottom:80px;
}
.moment-num{
  font-family:var(--font-display);
  font-weight:500;
  font-size:clamp(140px,18vw,260px);
  line-height:.78;
  letter-spacing:-.04em;
  color:var(--orange);
}
.moment-title-block{padding-top:36px;}
.moment-eyebrow{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-60);
  margin-bottom:24px;
}
.moment-title{
  font-family:var(--font-display);
  font-weight:400;
  font-size:clamp(40px,5vw,68px);
  line-height:.98;
  letter-spacing:-.02em;
  color:var(--ink);
  max-width:18ch;
}
.moment-title em{font-style:italic;color:var(--orange);}

.moment-body-grid{
  display:grid;
  grid-template-columns:220px 1fr;
  gap:80px;
  align-items:start;
}
.moment-sidebar{
  position:sticky;
  top:120px;
  display:flex;
  flex-direction:column;
  gap:28px;
}
.moment-sidebar .item{
  border-top:1px solid var(--ink-20);
  padding-top:14px;
}
.moment-sidebar .item .label{
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--orange);
  font-weight:500;
}
.moment-sidebar .item .text{
  font-size:14px;
  line-height:1.55;
  margin-top:8px;
  color:var(--ink-90);
}

.moment-running{max-width:var(--w-body);}
.moment-running p{
  font-size:18px;
  line-height:1.72;
  color:var(--ink-90);
  margin-bottom:24px;
}
.moment-running ol{
  margin:32px 0;
  padding:0;
  list-style:none;
  counter-reset:list;
  display:flex;
  flex-direction:column;
  gap:20px;
}
.moment-running ol li{
  counter-increment:list;
  padding-left:48px;
  position:relative;
  font-size:17px;
  line-height:1.6;
  color:var(--ink-90);
}
.moment-running ol li::before{
  content:counter(list,decimal-leading-zero);
  position:absolute;
  left:0; top:2px;
  font-family:var(--font-mono);
  font-size:13px;
  color:var(--orange);
  letter-spacing:.08em;
  font-weight:500;
}
.moment-running ol li strong{
  font-weight:600;
  color:var(--ink);
}

/* ==== FIGURE PLACEHOLDERS ==== */
.fig{
  margin:64px auto 0;
  max-width:var(--w-figure);
}
.fig-frame{
  background:linear-gradient(135deg,var(--paper-soft) 0%,var(--paper-deep) 100%);
  border:1px solid var(--ink-10);
  border-radius:18px;
  padding:48px;
  aspect-ratio:16/9;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:20px;
  position:relative;
}
.fig-frame::before{
  content:'';
  position:absolute;
  top:16px; left:16px;
  width:8px; height:8px;
  border-top:1px solid var(--ink-40);
  border-left:1px solid var(--ink-40);
}
.fig-frame::after{
  content:'';
  position:absolute;
  bottom:16px; right:16px;
  width:8px; height:8px;
  border-bottom:1px solid var(--ink-40);
  border-right:1px solid var(--ink-40);
}
.fig-frame--has-image{
  padding:0;
  aspect-ratio:auto;
  display:block;
  background:var(--paper-soft);
}
.fig-frame--has-image::before,
.fig-frame--has-image::after{ display:none; }
.fig-frame--has-image img{
  display:block;
  width:100%;
  height:auto;
  border-radius:18px;
}
.fig-grid .fig-frame--has-image img{ border-radius:14px; }

.fig-ribbon{
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-40);
  background:var(--paper);
  padding:6px 14px;
  border-radius:99px;
  border:1px solid var(--ink-10);
}
.fig-desc{
  font-family:var(--font-display);
  font-style:italic;
  font-size:22px;
  line-height:1.3;
  color:var(--ink-60);
  text-align:center;
  max-width:36ch;
  font-weight:400;
}
.fig-caption{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--ink-60);
  margin-top:20px;
  padding:0 16px;
  display:flex; gap:14px; align-items:center;
}
.fig-caption .tag{color:var(--orange);}

/* ==== FIGURE STACK (iOS shuffle gallery) ==== */
.fig:has(.fig-frame--stack){
  display:flex;
  flex-direction:column;
  align-items:center;
}
.fig-frame--stack{
  --stack-max-h:min(62.4vh,754px);
  padding:16px;
  align-items:stretch;
  justify-content:flex-end;
  gap:0;
  aspect-ratio:auto;
  width:fit-content;
  max-width:100%;
  margin-inline:auto;
}
.fig-stack-body{
  flex:1;
  min-height:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  width:100%;
}
.fig-frame--stack .stack{
  position:relative;
  flex:none;
  width:min(100%,calc(var(--stack-max-h) * 6 / 5));
  height:var(--stack-max-h);
  aspect-ratio:6/5;
  touch-action:pan-y;
  user-select:none;
  -webkit-user-select:none;
}
.fig-frame--stack .stack-card{
  position:absolute;
  inset:0;
  border:1px solid var(--ink-10);
  border-radius:14px;
  overflow:hidden;
  background:#fff;
  box-shadow:0 18px 40px -24px rgba(24,21,18,.35);
  will-change:transform;
  transition:transform .55s cubic-bezier(.23,1,.32,1), opacity .45s;
  cursor:grab;
}
.fig-frame--stack .stack-card.dragging{
  transition:none;
  cursor:grabbing;
}
.fig-frame--stack .stack-card img{
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:center center;
  display:block;
  pointer-events:none;
  -webkit-user-drag:none;
  background:#fff;
}
.fig-frame--stack .stack-card[data-pos="1"]{
  transform:translateX(5.5%) rotate(2.4deg) scale(.95);
}
.fig-frame--stack .stack-card[data-pos="2"]{
  transform:translateX(-4.5%) rotate(-2deg) scale(.9);
  opacity:.85;
}
.fig-frame--stack .stack-card-placeholder{
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,var(--paper-soft) 0%,var(--paper-deep) 100%);
}
.fig-frame--stack .stack-card-placeholder-label{
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-40);
  background:var(--paper);
  padding:6px 14px;
  border-radius:99px;
  border:1px solid var(--ink-10);
}
.fig-frame--stack .stack-foot{
  margin-top:12px;
  flex-shrink:0;
  width:min(100%,calc(var(--stack-max-h) * 6 / 5));
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:.13em;
  text-transform:uppercase;
  color:var(--ink-60);
}
.fig-frame--stack .stack-dots{
  display:flex;
  gap:6px;
}
.fig-frame--stack .stack-dots i{
  width:6px;
  height:6px;
  border-radius:50%;
  background:var(--ink-10);
  transition:background .3s;
}
.fig-frame--stack .stack-dots i.on{
  background:var(--orange);
}

/* Portrait stack — mobile mockups under web gallery */
.fig-frame--stack-portrait{
  --stack-max-h:min(56vh,680px);
}
.fig-frame--stack-portrait .stack{
  width:min(100%,calc(var(--stack-max-h) * 9 / 16));
  aspect-ratio:9/16;
}
.fig-frame--stack-portrait .stack-foot{
  width:min(100%,calc(var(--stack-max-h) * 9 / 16));
}
.fig-frame--stack-portrait .stack-card{
  background:transparent;
  border:none;
  border-radius:0;
  box-shadow:none;
  overflow:visible;
}
.fig-frame--stack-portrait .stack-card img{
  background:transparent;
  filter:drop-shadow(0 20px 36px rgba(24,21,18,.22));
}

.fig-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  max-width:var(--w-figure);
  margin:24px auto 0;
}
.fig-grid .fig{margin:0;}
.fig-grid .fig-frame:not(.fig-frame--has-image){aspect-ratio:4/3;padding:36px;}
.fig-grid .fig-desc{font-size:16px;}

/* ==== PULL QUOTE ==== */
.pullquote{
  background:var(--ink);
  color:var(--paper);
  padding:160px var(--pad-x);
  margin:0 0 0;
  text-align:left;
  position:relative;
  overflow:hidden;
}
.pullquote.alt{background:var(--paper-deep);color:var(--ink);}
.pullquote-inner{
  max-width:var(--w-wide);
  margin:0 auto;
  display:grid;
  grid-template-columns:140px 1fr;
  gap:64px;
  align-items:start;
}
.pullquote-tag{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--orange);
  padding-top:24px;
  display:flex;
  flex-direction:column;
  gap:18px;
}
.pullquote-tag::before{
  content:'';
  width:36px; height:2px;
  background:var(--orange);
}
.pullquote blockquote{
  font-family:var(--font-display);
  font-style:italic;
  font-weight:400;
  font-size:clamp(40px,5.4vw,88px);
  line-height:1.04;
  letter-spacing:-.018em;
  color:inherit;
  max-width:24ch;
}
.pullquote blockquote .accent{
  color:var(--orange);
  font-style:italic;
}
.pullquote.alt blockquote{color:var(--ink);}

/* ==== OUTCOMES (bento) ==== */
.outcomes{
  max-width:var(--w-figure);
  margin:160px auto 128px;
  padding:0 var(--pad-x);
}
.outcomes-head{margin-bottom:64px;}
.outcomes-head .section-title{max-width:14ch;}
.outcomes-head .lede{
  font-size:18px;
  line-height:1.65;
  color:var(--ink-70);
  max-width:56ch;
  margin-top:24px;
}
.outcomes-grid{
  display:grid;
  grid-template-columns:1.6fr 1fr 1fr;
  grid-template-rows:auto auto;
  gap:16px;
}
.outcome{
  background:var(--paper-soft);
  border:1px solid var(--ink-10);
  border-radius:16px;
  padding:36px 32px 32px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:24px;
  min-height:220px;
}
.outcome.feature{
  grid-row:span 2;
  background:var(--ink);
  color:var(--paper);
  border-color:var(--ink);
}
.outcome.feature .value{color:var(--orange);}
.outcome.feature .descriptor{color:var(--paper-70);}
.outcome.feature .label{color:var(--orange);}
.outcome .label{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-60);
}
.outcome .value{
  font-family:var(--font-display);
  font-weight:500;
  font-size:96px;
  line-height:.88;
  letter-spacing:-.04em;
  color:var(--ink);
}
.outcome.feature .value{font-size:clamp(140px,16vw,200px);}
.outcome .value .unit{
  font-size:.4em;
  vertical-align:top;
  margin-left:4px;
  color:inherit;
  opacity:.5;
  letter-spacing:0;
}
.outcome .descriptor{
  font-size:15px;
  line-height:1.5;
  color:var(--ink-70);
}
.outcome .value .small{
  font-size:.55em;
  letter-spacing:-.02em;
}
.outcomes-footer-quote{
  font-family:var(--font-display);
  font-style:italic;
  font-size:24px;
  line-height:1.4;
  color:var(--ink-90);
  max-width:52ch;
  margin:64px auto 0;
  text-align:center;
}

/* ==== REFLECTION (intimate) ==== */
.reflection{
  max-width:var(--w-narrow);
  margin:0 auto 128px;
  padding:0 var(--pad-x);
}
.reflection-eyebrow{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--orange);
  margin-bottom:24px;
  display:flex; align-items:center; gap:14px;
}
.reflection-eyebrow::before{
  content:'';
  width:24px; height:1px;
  background:var(--orange);
}
.reflection h2{
  font-family:var(--font-display);
  font-weight:400;
  font-size:48px;
  line-height:1.05;
  letter-spacing:-.02em;
  color:var(--ink);
  max-width:20ch;
}
.reflection h2 em{font-style:italic;color:var(--orange);}
.reflection h3{
  font-family:var(--font-display);
  font-weight:500;
  font-size:22px;
  line-height:1.25;
  margin-top:56px;
  color:var(--ink);
}
.reflection p{
  font-size:17px;
  line-height:1.75;
  color:var(--ink-90);
  margin-top:16px;
}

/* ==== CLOSING (dark) ==== */
.closing{
  background:var(--ink);
  color:var(--paper);
  padding:160px var(--pad-x) 140px;
  text-align:center;
  position:relative;
}
.closing-inner{
  max-width:980px;
  margin:0 auto;
}
.closing .eyebrow{
  font-family:var(--font-mono);
  font-size:12px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--orange);
  margin-bottom:40px;
  display:inline-flex; align-items:center; gap:14px;
}
.closing .eyebrow::before,.closing .eyebrow::after{
  content:'';
  width:24px; height:1px;
  background:var(--orange);
}
.closing .heading{
  font-family:var(--font-display);
  font-weight:400;
  font-size:clamp(48px,6vw,96px);
  line-height:1.02;
  letter-spacing:-.02em;
  max-width:22ch;
  margin:0 auto;
  color:var(--paper);
}
.closing .heading em{font-style:italic;color:var(--orange);}
.closing .sub{
  font-size:18px;
  line-height:1.65;
  color:var(--paper-70);
  max-width:48ch;
  margin:32px auto 0;
}
.closing .cta-row{
  margin-top:72px;
  display:flex; justify-content:center; gap:1.1rem;
  flex-wrap:wrap;
}

/* Closing CTAs — same .btn system as Home (square default, pill on hover) */
.closing .btn{
  display:inline-flex; align-items:center; gap:.7rem;
  font-family:var(--font-mono); font-size:.72rem; font-weight:500;
  letter-spacing:.15em; text-transform:uppercase;
  padding:1rem 1.7rem; border:1px solid var(--paper-20); border-radius:2px;
  transition:background .25s, color .25s, border-color .25s, border-radius .25s, padding .25s, gap .25s;
  background:transparent; color:var(--paper);
}
.closing .btn:hover{
  background:var(--paper);
  color:var(--ink);
  border-color:var(--paper);
  border-radius:6.375rem;
  padding:1rem 1.7625rem 1.069375rem;
}
.closing .btn.solid{
  background:var(--paper);
  color:var(--ink);
  border-color:var(--paper);
}
.closing .btn.solid:hover{
  background:var(--orange);
  color:var(--paper);
  border-color:var(--paper);
  border-radius:8.25rem;
  padding:1.0625rem 1.7625rem;
  gap:.699375rem;
}
.closing .btn .a{ transition:transform .25s; }
.closing .btn:hover .a{ transform:translateX(3px); }

@media (prefers-reduced-motion:reduce){
  .hero-title,
  .hero-title em,
  .hero-title.is-lettered .hero-char,
  .framing-card,
  .closing .btn,
  .closing .btn .a{ transition:none; }
  .hero-title.is-lettered .hero-char,
  .hero-title.is-lettered:hover .hero-char,
  .hero-title.is-lettered .hero-char:hover{ transform:none; }
  .framing-card:hover{ transform:none; }
}

/* ==== FOOTER ==== */
.footer{
  background:var(--paper);
  padding:48px var(--pad-x) 56px;
  border-top:1px solid var(--ink-10);
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--ink-60);
  max-width:var(--w-wide);
  margin:0 auto;
}

/* ==== RESPONSIVE ==== */
@media (max-width:980px){
  body.case-study-page{--pad-x:24px;}
  .hero-meta{grid-template-columns:repeat(2,1fr);gap:24px;}
  .tension-grid{grid-template-columns:1fr;gap:48px;}
  .tension-stat{position:static;}
  .framing-grid{grid-template-columns:1fr;}
  .chapter-moments{grid-template-columns:1fr;}
  .moment-marker{grid-template-columns:1fr;gap:24px;}
  .moment-num{font-size:120px;}
  .moment-body-grid{grid-template-columns:1fr;gap:32px;}
  .moment-sidebar{position:static;flex-direction:column;}
  .pullquote-inner{grid-template-columns:1fr;gap:32px;}
  .outcomes-grid{grid-template-columns:1fr;}
  .outcome.feature{grid-row:auto;}
  .fig-grid{grid-template-columns:1fr;}
  .fig-frame--stack{--stack-max-h:min(54.6vh,624px);}
  .process-row{grid-template-columns:repeat(2,1fr);}
  .process-tick{border-right:0;border-bottom:1px solid var(--ink-10);}
  .process-tick:nth-child(odd){border-right:1px solid var(--ink-10);}
  .process-tick:nth-last-child(-n+2){border-bottom:0;}
}

/* ===== HERO WITH EMBEDDED SCREEN (Figma screenshot, node 255:2486) ===== */
.hero.hero--with-screen{
  min-height:auto;
  max-width:var(--w-wide);
  margin:0 auto;
  padding:40px var(--pad-x) 72px;
  display:flex;
  flex-direction:column;
  gap:32px;
  justify-content:flex-start;
}
.hero--with-screen .hero-content{
  text-align:center;
  max-width:920px;
  margin:32px auto 0;
  display:flex;
  flex-direction:column;
  align-items:center;
}
.hero--with-screen .hero-eyebrow{display:inline-flex;align-items:center;gap:14px;}
.hero--with-screen .hero-eyebrow::before,
.hero--with-screen .hero-eyebrow::after{content:'';width:32px;height:1px;background:var(--orange);}
.hero--with-screen .hero-eyebrow::after{flex:none;}
.hero--with-screen .hero-title{font-size:clamp(48px,6.6vw,96px);line-height:1;max-width:22ch;margin:0 auto;}
.hero--with-screen .hero-lede{font-size:clamp(17px,1.4vw,20px);line-height:1.6;max-width:62ch;margin-top:32px;}
.hero-screen{max-width:var(--w-figure);margin:8px auto 0;width:100%;}
.hero-screen-frame{
  background:linear-gradient(135deg,var(--paper-soft) 0%,var(--paper-deep) 100%);
  border:1px solid var(--ink-10);border-radius:20px;padding:24px;position:relative;
}
.hero-screen-frame::before{content:'';position:absolute;top:14px;left:14px;width:10px;height:10px;border-top:1px solid var(--ink-40);border-left:1px solid var(--ink-40);}
.hero-screen-frame::after{content:'';position:absolute;bottom:14px;right:14px;width:10px;height:10px;border-bottom:1px solid var(--ink-40);border-right:1px solid var(--ink-40);}

.tm-screen{
  width:100%;
  margin:0 auto;
  border-radius:14px;
  overflow:hidden;
  background:#fefefe;
  box-shadow:0 18px 48px -16px rgba(22,19,16,.18),0 1px 0 var(--ink-10);
  opacity:0;
  transform:translateY(8px);
  clip-path:inset(0 100% 0 0);
  line-height:0;
}
.tm-screen-img{
  display:block;
  width:100%;
  height:auto;
  margin:0;
  border:0;
}
.is-playing .tm-screen{
  animation:tm-fade-up .5s cubic-bezier(.2,.7,.2,1) forwards,tm-draw-h .9s cubic-bezier(.65,0,.35,1) forwards;
  animation-delay:.05s,.85s;
}

.hero--with-screen .hero-meta{
  display:grid;grid-template-columns:repeat(4,1fr);gap:32px;padding-top:32px;
  border-top:1px solid var(--ink-20);margin-top:24px;
}
.hero--with-screen .hero-meta .item .label{
  font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-60);margin-bottom:8px;
}
.hero--with-screen .hero-meta .item .value{
  font-family:var(--font-display);font-size:20px;font-weight:400;letter-spacing:-.01em;color:var(--ink);line-height:1.25;
}

@keyframes tm-fade-up{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}
@keyframes tm-fade-down{from{opacity:0;transform:translateY(-4px);}to{opacity:1;transform:translateY(0);}}
@keyframes tm-fade-in{from{opacity:0;}to{opacity:1;}}
@keyframes tm-fade-right{from{opacity:0;transform:translateX(-4px);}to{opacity:1;transform:translateX(0);}}
@keyframes tm-pop-in{from{opacity:0;transform:scale(.86);}to{opacity:1;transform:scale(1);}}
@keyframes tm-draw-h{from{clip-path:inset(0 100% 0 0);}to{clip-path:inset(0 0 0 0);}}

@media (prefers-reduced-motion:reduce){
  .tm-screen{
    animation:none !important;
    opacity:1 !important;
    transform:none !important;
    clip-path:none !important;
  }
}


/* ===== HOW I WORKED BLOCK ===== */
.howi{
  max-width:var(--w-figure);
  margin:0 auto 96px;
  padding:0 var(--pad-x);
}
.howi-head{margin-bottom:40px;}
.howi-body{
  max-width:var(--w-body);
  font-size:18px;
  line-height:1.7;
  color:var(--ink-90);
}
.howi-body p{margin-bottom:20px;}
.howi-body strong{font-weight:600;color:var(--ink);}
