/* ============================================================
   QRIOUSMEDIA — V.3 (PHASE 6 EDGE PUSH)
   Modern studio · paper-neutral · sans-led precision
   Locked: Geist + Geist Mono · #E63970 + #2747FF
   Signature: full-viewport scroll-reveal manifesto
   Work: pinned horizontal scroll with drag
   ============================================================ */

/* RESET ----------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
/* Phase X.5: lock both html AND body against horizontal overflow at the root.
   overflow-x:clip is preferred (newer, more aggressive than hidden)
   with hidden as a fallback for older engines. Then we still fix the
   actual overflowing elements below — the body lock is belt-and-suspenders, not the cure. */
html{
  scroll-behavior:smooth;-webkit-text-size-adjust:100%;
  max-width:100%;
  overflow-x:hidden;
  overflow-x:clip;
}
body{
  min-height:100vh;line-height:1.55;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  max-width:100%;
}
img,picture,svg,video{display:block;max-width:100%;height:auto}
button,input,textarea,select{font:inherit;color:inherit}
button{background:none;border:0;cursor:pointer}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}

/* TOKENS ---------------------------------------------------- */
:root{
  /* paper palette */
  --bg:           #F2EFEA;
  --bg-alt:       #ECE7DD;
  --bg-deep:      #1A1A1C;
  --paper-line:   #2A2A2E14;
  --ink:          #0E0E10;
  --ink-soft:     #2A2A2E;
  --ink-mute:     #6A6A6E;
  --rule:         #1A1A1C;

  /* accents */
  --pink:         #E63970;
  --pink-deep:    #C7235A;
  --cobalt:       #2747FF;
  --cobalt-soft:  #6B7DFF;

  /* type — Phase 6: sans-first studio system, italic removed as default */
  --display: 'Geist', 'Inter', system-ui, sans-serif;
  --body:    'Geist', 'Inter', system-ui, sans-serif;
  --mono:    'Geist Mono', 'JetBrains Mono', ui-monospace, monospace;

  /* scale */
  --step--1: clamp(.78rem, .76rem + .12vw, .9rem);
  --step-0:  clamp(1rem, .96rem + .2vw, 1.125rem);
  --step-1:  clamp(1.18rem, 1.1rem + .4vw, 1.45rem);
  --step-2:  clamp(1.5rem, 1.3rem + .8vw, 2rem);
  --step-3:  clamp(2rem, 1.6rem + 1.6vw, 3rem);
  --step-4:  clamp(2.8rem, 2.1rem + 3.2vw, 5rem);
  --step-5:  clamp(3.6rem, 2.4rem + 5.4vw, 7.5rem);
  --step-6:  clamp(4.5rem, 2.4rem + 9vw, 11rem);

  /* layout */
  --gutter: clamp(1.25rem, 4vw, 3rem);
  --max:    1480px;
  --rad:    14px;
  --t-fast: 240ms cubic-bezier(.2,.7,.3,1);
  --t-mid:  520ms cubic-bezier(.2,.7,.3,1);
}

/* BASE ------------------------------------------------------ */
body{
  font-family:var(--body);
  background:var(--bg);
  color:var(--ink);
  font-size:var(--step-0);
  font-weight:400;
  letter-spacing:-0.005em;
  overflow-x:hidden;
  overflow-x:clip;
}

/* Ambient grain + gradient drift (Experience Feature 1) */
body::before{
  content:"";
  position:fixed;inset:-10%;z-index:0;pointer-events:none;
  background:
    radial-gradient(60% 40% at 18% 22%, rgba(230,57,112,.18), transparent 60%),
    radial-gradient(50% 36% at 82% 78%, rgba(39,71,255,.14), transparent 60%),
    radial-gradient(40% 30% at 58% 18%, rgba(230,57,112,.10), transparent 70%);
  filter:blur(40px);
  animation:drift 24s ease-in-out infinite alternate;
}
body::after{
  content:"";
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.06 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity:.55;mix-blend-mode:multiply;
}
@keyframes drift{
  0%   {transform:translate(0,0) rotate(0deg);}
  50%  {transform:translate(2%,-2%) rotate(.4deg);}
  100% {transform:translate(-1%,2%) rotate(-.3deg);}
}
@media (prefers-reduced-motion: reduce){
  body::before{animation:none}
}

main, header, footer, section{position:relative;z-index:1}

::selection{background:var(--pink);color:#fff}

/* TYPOGRAPHY — Phase X (clipping fix): line-heights ≥1.05, descenders preserved
   Phase X.5: overflow-wrap allows long single words (e.g. "Webbutveckling")
   to break gracefully on narrow viewports instead of overflowing. */
h1,h2,h3,h4{
  font-family:var(--display);
  font-weight:600;
  font-style:normal;
  letter-spacing:-0.045em;
  line-height:1.06;
  color:var(--ink);
  text-wrap:balance;
  overflow-wrap:break-word;
  word-break:normal;
  max-width:100%;
}
h1{font-size:var(--step-6);font-weight:700;letter-spacing:-0.055em;line-height:1.05}
h2{font-size:var(--step-5);line-height:1.06;letter-spacing:-0.05em}
h3{font-size:var(--step-3);line-height:1.08;letter-spacing:-0.035em;font-weight:600}
h4{font-size:var(--step-2);line-height:1.1;letter-spacing:-0.03em;font-weight:600}
p{max-width:62ch;line-height:1.58}
.lede{font-size:var(--step-1);line-height:1.4;color:var(--ink-soft);max-width:54ch;letter-spacing:-0.018em;font-weight:400}

.eyebrow{
  font-family:var(--mono);
  font-size:.74rem;
  font-weight:500;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-mute);
  display:inline-flex;align-items:center;gap:.6rem;
}
.eyebrow::before{
  content:"";width:1.6rem;height:1px;background:var(--ink-mute);
}

/* Phase 6: .upright is now a no-op (no italic to break out of), kept for backward compat */
.upright{font-style:normal !important;font-weight:inherit}
.accent-pink{color:var(--pink)}
.accent-cobalt{color:var(--cobalt)}

/* container */
.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--gutter)}
.wrap-narrow{max-width:920px;margin:0 auto;padding:0 var(--gutter)}

/* HEADER / NAV --------------------------------------------- */
.site-header{
  position:sticky;top:0;z-index:50;
  padding:1.2rem 0;
  /* background + backdrop-filter moved to ::before — if these sit on the element
     itself they create a containing block for position:fixed children (the mobile
     nav overlay), causing it to cover only the header area instead of the full
     viewport. The pseudo-element carries the glass effect without that side-effect. */
  transition:border-color var(--t-fast);
  border-bottom:1px solid transparent;
}
.site-header::before{
  content:"";
  position:absolute;inset:0;z-index:-1;
  pointer-events:none;
  background:color-mix(in srgb, var(--bg) 78%, transparent);
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
}
.site-header.scrolled{border-bottom-color:var(--paper-line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:2rem}
.brand{
  font-family:var(--display);
  font-weight:600;
  font-size:1.32rem;letter-spacing:-.04em;
  display:inline-flex;align-items:baseline;gap:.35rem;
}
.brand .dot{
  width:.55rem;height:.55rem;border-radius:50%;
  background:var(--pink);display:inline-block;
  transform:translateY(-.3rem);
}
.nav-links{display:flex;gap:2.2rem;align-items:center}
.nav-links a{
  font-size:.94rem;letter-spacing:-.005em;
  position:relative;padding:.4rem 0;
  transition:color var(--t-fast);
}
.nav-links a:hover{color:var(--pink)}
.nav-links a[aria-current="page"]{color:var(--pink)}
.nav-links a[aria-current="page"]::after{
  content:"";position:absolute;left:0;right:0;bottom:-4px;height:1px;background:var(--pink);
}
.nav-cta{
  font-family:var(--mono);font-size:.78rem;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink);border-bottom:1px solid var(--ink);
  padding-bottom:2px;transition:color var(--t-fast),border-color var(--t-fast);
}
.nav-cta:hover{color:var(--pink);border-color:var(--pink)}

.menu-toggle{display:none;width:2.6rem;height:2.6rem;border:1px solid var(--ink);border-radius:50%;align-items:center;justify-content:center}
.menu-toggle span,.menu-toggle span::before,.menu-toggle span::after{
  content:"";display:block;width:1.1rem;height:1.5px;background:var(--ink);position:relative;transition:transform var(--t-fast);
}
.menu-toggle span::before{position:absolute;top:-5px;left:0}
.menu-toggle span::after{position:absolute;top:5px;left:0}
.menu-toggle[aria-expanded="true"] span{background:transparent}
.menu-toggle[aria-expanded="true"] span::before{top:0;transform:rotate(45deg)}
.menu-toggle[aria-expanded="true"] span::after{top:0;transform:rotate(-45deg)}

/* HERO ------------------------------------------------------ */
.hero{
  padding:clamp(3rem,8vh,7rem) 0 0;
  position:relative;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.4fr .9fr;
  gap:clamp(1.5rem,3vw,3.5rem);
  align-items:end;
}
.hero-meta{
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:.6rem 1.4rem;
  font-family:var(--mono);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-mute);margin-bottom:2rem;
  border-top:1px solid var(--rule);padding-top:1rem;
}
.hero-meta span:nth-child(2){color:var(--ink)}
.hero h1{
  font-size:clamp(3rem, 2rem + 7.6vw, 9.6rem);
  line-height:1.05;letter-spacing:-.055em;font-weight:700;
  padding-bottom:.05em; /* descender safety */
}
/* .line wraps each visual line — overflow:hidden is needed for word-reveal slide-up.
   padding-bottom keeps descenders (g, y, p, j) visible inside the line-box. */
.hero h1 .line{
  display:block;overflow:hidden;
  padding-bottom:.18em;margin-bottom:-.08em;
}
.hero h1 .pink{color:var(--pink)}
/* Word-by-word reveal — Phase 6 motion layer */
.hero h1 .word{
  display:inline-block;will-change:transform,opacity;
  transform:translateY(110%);opacity:0;
  transition: transform 1s cubic-bezier(.2,.7,.2,1), opacity 1s ease;
}
.hero h1.in .word{transform:translateY(0);opacity:1}
.hero h1.in .word:nth-child(1){transition-delay:.05s}
.hero h1.in .word:nth-child(2){transition-delay:.12s}
.hero h1.in .word:nth-child(3){transition-delay:.19s}
.hero h1.in .word:nth-child(4){transition-delay:.26s}
.hero h1.in .word:nth-child(5){transition-delay:.33s}
.hero h1.in .word:nth-child(6){transition-delay:.40s}
.hero h1.in .word:nth-child(7){transition-delay:.47s}
.hero h1.in .word:nth-child(8){transition-delay:.54s}
@media (prefers-reduced-motion: reduce){
  .hero h1 .word{transform:none;opacity:1;transition:none}
}
.hero-img{
  position:relative;
  aspect-ratio: 3 / 4.2;
  overflow:hidden;
  border-radius:6px;
  background:linear-gradient(135deg,#1a1a1c 0%,#3b2030 50%,#0e0e10 100%);
  box-shadow: 0 30px 80px -30px rgba(20,15,30,.45);
  transform:translateY(-1.2rem);
}
.hero-img::after{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(80% 60% at 30% 30%, rgba(230,57,112,.45), transparent 60%),
    radial-gradient(60% 40% at 80% 70%, rgba(39,71,255,.35), transparent 60%);
  mix-blend-mode:screen;
}
.hero-img::before{
  content:"";position:absolute;inset:0;
  background-image:
    repeating-linear-gradient(0deg, rgba(255,255,255,.04) 0 1px, transparent 1px 4px);
  z-index:1;
}
.hero-img img{
  position:absolute;inset:-8%;width:116%;height:116%;object-fit:cover;mix-blend-mode:luminosity;opacity:.9;
  transition: transform .1s linear; /* parallax via JS — Phase 6 motion */
  will-change: transform;
}
.hero-tag{
  position:absolute;left:1rem;bottom:1rem;color:#fff;
  font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;
  z-index:2;
}
.hero-foot{
  display:grid;grid-template-columns: 1fr auto;gap:2rem;align-items:end;
  margin-top:2.4rem;padding-top:1.6rem;border-top:1px solid var(--rule);
}
.hero-lede{font-size:var(--step-1);line-height:1.32;letter-spacing:-.012em;color:var(--ink-soft);max-width:42ch}
.hero-cta{display:flex;flex-direction:column;align-items:flex-end;gap:.8rem}

/* CTA / BUTTON SYSTEM -------------------------------------- */
.btn{
  display:inline-flex;align-items:center;gap:.7rem;
  font-family:var(--mono);font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;
  padding:1rem 1.6rem;border-radius:999px;border:1px solid var(--ink);
  color:var(--ink);background:transparent;
  transition:background var(--t-fast),color var(--t-fast),border-color var(--t-fast),transform var(--t-fast);
  position:relative;will-change:transform;
}
.btn .arrow{transition:transform var(--t-fast)}
.btn:hover,.btn:focus-visible{background:var(--ink);color:var(--bg);outline:none}
.btn:focus-visible{box-shadow:0 0 0 3px rgba(230,57,112,.35)}
.btn:hover .arrow,.btn:focus-visible .arrow{transform:translateX(4px)}
.btn-pink{background:var(--pink);color:#fff;border-color:var(--pink)}
.btn-pink:hover,.btn-pink:focus-visible{background:var(--ink);border-color:var(--ink);color:#fff;outline:none}
.btn-pink:focus-visible{box-shadow:0 0 0 3px rgba(230,57,112,.45)}
.btn-ghost{border-color:var(--ink-mute);color:var(--ink-soft)}
.btn-ghost:hover,.btn-ghost:focus-visible{border-color:var(--ink);color:var(--ink);background:transparent;outline:none}

/* Magnetic CTA — Experience Feature 2 */
.magnetic{position:relative;display:inline-block}
.magnetic .btn{transition:transform 220ms cubic-bezier(.2,.7,.3,1), background var(--t-fast), color var(--t-fast)}
.magnetic::before{
  content:"";position:absolute;inset:-30px;border-radius:50%;
  background:radial-gradient(closest-side, rgba(230,57,112,.35), transparent 70%);
  opacity:0;transition:opacity var(--t-fast);pointer-events:none;
}
.magnetic.active::before{opacity:1}
@media (prefers-reduced-motion: reduce){
  .magnetic .btn{transition:background var(--t-fast),color var(--t-fast)}
  .magnetic::before{display:none}
}

.text-link{
  display:inline-flex;align-items:center;gap:.5rem;
  border-bottom:1px solid currentColor;padding-bottom:2px;
  font-weight:500;font-size:.96rem;letter-spacing:-.005em;
  transition:color var(--t-fast),border-color var(--t-fast),gap var(--t-fast);
}
.text-link:hover{color:var(--pink);gap:.85rem}

/* MARQUEE — Experience Feature 3 ------------------------------ */
.marquee{
  margin-top:clamp(2rem,6vh,4rem);
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  overflow:hidden;
  background:var(--bg);
  position:relative;
  z-index:2;
}
.marquee-track{
  display:flex;gap:3rem;
  padding:1.4rem 0;
  width:max-content;
  animation:marquee 38s linear infinite;
}
.marquee-track span{
  font-family:var(--display);font-weight:600;
  font-size:clamp(1.6rem,2.4vw,2.6rem);
  letter-spacing:-.04em;line-height:1;
  white-space:nowrap;color:var(--ink);
  display:inline-flex;align-items:center;gap:3rem;
}
.marquee-track span::after{
  content:"✦";color:var(--pink);font-style:normal;font-size:.7em;display:inline-block;transform:translateY(-.1em);
}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes marquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
@media (prefers-reduced-motion: reduce){
  .marquee-track{animation:none;flex-wrap:wrap;width:auto;justify-content:center}
}

/* SECTIONS GENERIC ----------------------------------------- */
section{padding:clamp(4rem, 10vh, 8rem) 0}
.section-head{
  display:grid;grid-template-columns: 1fr 1.6fr;gap:2rem;
  align-items:end;margin-bottom:clamp(2.5rem,6vh,5rem);
}
.section-head .eyebrow{align-self:start}
.section-head h2{margin-top:1rem}

/* SERVICES -------------------------------------------------- */
.services{
  display:grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap:0;
  border-top:1px solid var(--rule);
}
.service-card{
  border-right:1px solid var(--rule);
  padding:2.4rem 2rem 2.4rem;
  position:relative;
  display:flex;flex-direction:column;
  transition:background var(--t-fast);
  min-height:520px;
}
.service-card:last-child{border-right:0}
.service-card:hover{background:var(--bg-alt)}
.service-card .num{
  font-family:var(--mono);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute);
}
.service-card h3{
  margin-top:1.5rem;font-size:var(--step-3);
}
.service-card p{margin-top:1rem;color:var(--ink-soft);font-size:.98rem;line-height:1.55}
.service-card .visual{
  margin-top:auto;
  height:200px;border-radius:6px;
  position:relative;overflow:hidden;
  background:#0E0E10;
  margin-left:0;
}
.service-card .visual img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:transform .9s cubic-bezier(.2,.7,.3,1), filter .6s ease;
  filter:contrast(1.05) saturate(.92) brightness(.92);
}
.service-card .visual::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(160deg, rgba(230,57,112,.18), transparent 55%),
    linear-gradient(20deg, rgba(39,71,255,.16), transparent 60%);
  mix-blend-mode:screen;
}
.service-card:hover .visual img{transform:scale(1.04);filter:contrast(1.08) saturate(1) brightness(1)}
.service-card .more{
  margin-top:1.4rem;font-family:var(--mono);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:.6rem;color:var(--ink);
}
.service-card .more::after{content:"→";transition:transform var(--t-fast)}
.service-card:hover .more::after{transform:translateX(4px);color:var(--pink)}

/* PHILOSOPHY / PULL-QUOTE ---------------------------------- */
.philosophy{
  border-top:1px solid var(--rule);
}
.pullquote{
  font-family:var(--display);font-weight:500;
  font-size:clamp(1.7rem, 1.2rem + 2.6vw, 3.4rem);
  line-height:1.04;letter-spacing:-.04em;
  max-width:24ch;text-wrap:balance;color:var(--ink);
}
.pullquote .mark{color:var(--pink);font-weight:700;font-size:1em;display:inline-block;line-height:1;margin-right:.05em}
.philosophy-grid{
  display:grid;grid-template-columns: 1.5fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center;
}
.philosophy-grid .body p + p{margin-top:1.1rem}
.philosophy-grid .body p{color:var(--ink-soft);font-size:1.05rem;line-height:1.65}
.philosophy-attrib{
  font-family:var(--mono);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute);margin-top:1.6rem;
}

/* APPROACH -------------------------------------------------- */
.approach{border-top:1px solid var(--rule)}
.steps{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid var(--rule);
}
.step{
  border-right:1px solid var(--rule);
  padding:2rem 1.4rem;
  display:flex;flex-direction:column;gap:1rem;min-height:280px;
}
.step:last-child{border-right:0}
.step .label{
  font-family:var(--mono);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--pink);
}
.step h4{font-size:1.55rem;line-height:1.05;color:var(--ink)}
.step p{font-size:.94rem;color:var(--ink-soft);line-height:1.55;max-width:none}
.step .glyph{
  width:3rem;height:3rem;border:1px solid var(--rule);border-radius:50%;
  display:grid;place-items:center;
  font-family:var(--mono);font-weight:500;font-size:.9rem;letter-spacing:.04em;color:var(--ink);text-transform:uppercase;
  margin-top:auto;
}

/* WORK / NAMED PIECES (homepage strip) --------------------- */
.work{border-top:1px solid var(--rule);background:var(--bg-alt)}
.work-grid{
  display:grid;grid-template-columns:repeat(12,1fr);gap:1rem;margin-top:2rem;
}
.work-item{position:relative;overflow:hidden;border-radius:6px;background:var(--ink);min-height:240px}
.work-item.large{grid-column: span 7;min-height:380px}
.work-item.med{grid-column: span 5;min-height:380px}
.work-item.thin{grid-column:span 4;min-height:240px}
.work-item.wide{grid-column:span 8;min-height:240px}
.work-item .gradient{
  position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(230,57,112,.55), rgba(39,71,255,.5));
  mix-blend-mode:multiply;
}
.work-item:nth-child(1){background:linear-gradient(135deg,#1A1A1C,#3B1F33)}
.work-item:nth-child(2){background:linear-gradient(135deg,#1f1d35,#2747FF)}
.work-item:nth-child(3){background:linear-gradient(135deg,#2a1a20,#E63970)}
.work-item:nth-child(4){background:linear-gradient(135deg,#0E0E10,#5B5B62)}
.work-meta{
  position:absolute;left:1.2rem;bottom:1.2rem;color:#fff;z-index:1;
}
.work-meta .tag{font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;opacity:.75}
.work-meta h4{color:#fff;margin-top:.4rem;font-size:1.6rem;line-height:1.05}

/* CLOSE / FINAL CTA ---------------------------------------- */
.close{
  border-top:1px solid var(--rule);
  background:var(--bg-deep);color:var(--bg);
  padding:clamp(5rem,12vh,9rem) 0;
}
.close h2{color:var(--bg);font-size:clamp(2.2rem, 1.6rem + 4vw, 6rem);max-width:16ch;line-height:1.05;padding-bottom:.04em}
.close .lede{color:rgba(242,239,234,.7);margin-top:1.6rem}
.close-grid{display:grid;grid-template-columns: 1.6fr 1fr;gap:3rem;align-items:end}
.close .cta-stack{display:flex;flex-direction:column;gap:1rem;align-items:flex-start}
/* Phase X.2 contrast fix: dark section needs explicit light text in default + focus states */
.close .btn{border-color:var(--bg);color:var(--bg);background:transparent}
.close .btn:hover,
.close .btn:focus-visible{background:var(--bg);color:var(--ink);outline:none}
.close .btn:focus-visible{box-shadow:0 0 0 3px rgba(230,57,112,.45)}
.close .btn .arrow{color:inherit}
.close .btn-pink{background:var(--pink);border-color:var(--pink);color:#fff}
.close .btn-pink:hover,
.close .btn-pink:focus-visible{background:#fff;border-color:#fff;color:var(--ink);outline:none}
.close .meta-row{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;
  margin-top:3.5rem;padding-top:2rem;border-top:1px solid rgba(242,239,234,.18);
}
.close .meta-row .key{font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(242,239,234,.55)}
.close .meta-row .val{font-family:var(--display);font-weight:600;font-size:1.5rem;line-height:1.1;margin-top:.4rem;color:var(--bg);letter-spacing:-.04em}

/* FOOTER ---------------------------------------------------- */
.site-footer{
  background:var(--bg-deep);color:rgba(242,239,234,.78);
  padding:clamp(3rem,7vh,5rem) 0 2rem;
  border-top:1px solid rgba(242,239,234,.08);
}
.footer-grid{
  display:grid;grid-template-columns: 1.4fr repeat(3,1fr);gap:2rem;
}
.footer-grid h5{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
  font-weight:500;margin-bottom:1rem;color:rgba(242,239,234,.55);
}
.footer-grid a{display:block;padding:.3rem 0;font-size:.94rem;color:var(--bg);transition:color var(--t-fast)}
.footer-grid a:hover{color:var(--pink)}
.foot-mark{
  font-family:var(--display);font-weight:600;font-size:1.95rem;line-height:1;letter-spacing:-.045em;color:var(--bg);
}
.foot-mark .dot{display:inline-block;width:.5rem;height:.5rem;border-radius:50%;background:var(--pink);transform:translateY(-.5rem);margin-left:.2rem}
.foot-tag{margin-top:1rem;font-size:.94rem;color:rgba(242,239,234,.65);max-width:30ch;line-height:1.5}
.foot-bar{
  margin-top:3rem;padding-top:1.4rem;border-top:1px solid rgba(242,239,234,.12);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem;
  font-family:var(--mono);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(242,239,234,.5);
}
.foot-bar a{color:rgba(242,239,234,.7)}
.foot-bar a:hover{color:var(--pink)}

/* SERVICE-PAGE LAYOUT -------------------------------------- */
.page-hero{
  padding:clamp(3rem,7vh,6rem) 0 0;
}
.crumbs{
  font-family:var(--mono);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute);
  margin-bottom:2rem;display:flex;gap:.6rem .8rem;flex-wrap:wrap;
  max-width:100%;
}
.crumbs a{color:var(--ink-mute);transition:color var(--t-fast)}
.crumbs a:hover{color:var(--pink)}
.crumbs .sep{color:var(--ink-mute)}
.page-hero-grid{
  display:grid;grid-template-columns: 1.5fr 1fr;gap:clamp(2rem,4vw,4rem);align-items:end;
  padding-bottom:clamp(2rem,5vh,4rem);border-bottom:1px solid var(--rule);
}
.page-hero h1{
  font-size:clamp(2.4rem, 1.6rem + 4.6vw, 6.2rem);line-height:1.06;letter-spacing:-.04em;font-weight:700;
  padding-bottom:.08em; /* descender safety */
}
.page-hero h1 .line{
  display:block;line-height:1.06;padding-bottom:.18em;margin-bottom:-.06em;
  overflow:hidden;
}
/* Word-by-word reveal on subpage hero — Phase X.2 motion */
.page-hero h1 .word{
  display:inline-block;will-change:transform,opacity;
  transform:translateY(110%);opacity:0;
  transition:transform .9s cubic-bezier(.18,.7,.2,1), opacity .9s ease;
}
.page-hero h1.in .word{transform:translateY(0);opacity:1}
.page-hero h1.in .word:nth-child(1){transition-delay:.04s}
.page-hero h1.in .word:nth-child(2){transition-delay:.10s}
.page-hero h1.in .word:nth-child(3){transition-delay:.16s}
.page-hero h1.in .word:nth-child(4){transition-delay:.22s}
.page-hero h1.in .word:nth-child(5){transition-delay:.28s}
.page-hero h1.in .word:nth-child(6){transition-delay:.34s}
.page-hero h1.in .word:nth-child(7){transition-delay:.40s}
@media (prefers-reduced-motion: reduce){
  .page-hero h1 .word{transform:none;opacity:1;transition:none}
}

/* Subpage capability marquee — service-specific keyword strip ============ */
.subpage-marquee{
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  overflow:hidden;background:var(--bg-alt);
  position:relative;
}
.subpage-marquee .marquee-track{
  display:flex;gap:2.4rem;padding:1.1rem 0;width:max-content;
  animation:marquee 42s linear infinite;
}
.subpage-marquee .marquee-track span{
  font-family:var(--display);font-weight:600;
  font-size:clamp(1.2rem,.9rem + 1.4vw,2rem);
  letter-spacing:-.035em;line-height:1;
  white-space:nowrap;color:var(--ink);
  display:inline-flex;align-items:center;gap:2.4rem;
}
.subpage-marquee .marquee-track span::after{
  content:"·";color:var(--pink);font-style:normal;display:inline-block;font-size:1.4em;line-height:0;transform:translateY(-.05em);
}
.subpage-marquee:hover .marquee-track{animation-play-state:paused}
@media (prefers-reduced-motion: reduce){
  .subpage-marquee .marquee-track{animation:none;flex-wrap:wrap;width:auto;justify-content:center}
}

/* Sticky-H2 layout pattern — Phase X.2: H2 pins while body scrolls past */
@media (min-width: 980px){
  .body-grid.sticky-h2 h2{
    position:sticky;top:96px;align-self:start;
    transition:color .3s ease;
  }
  .body-grid.sticky-h2 h2::after{
    content:"";display:block;width:2.4rem;height:2px;background:var(--pink);
    margin-top:1.2rem;transform:scaleX(0);transform-origin:left;
    transition:transform .6s cubic-bezier(.2,.7,.3,1) .2s;
  }
  .body-grid.sticky-h2.in h2::after{transform:scaleX(1)}
}
.page-hero .lede{margin-top:1.6rem}
.page-hero-side{
  font-family:var(--mono);font-size:.84rem;line-height:1.6;color:var(--ink-soft);
  background:transparent;border:1px solid var(--rule);border-radius:6px;padding:1.4rem;
}
.page-hero-side dt{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute);margin-top:1rem}
.page-hero-side dt:first-child{margin-top:0}
.page-hero-side dd{font-size:.96rem;color:var(--ink);margin-top:.3rem}

/* article-style body */
.body-block{padding:clamp(3rem,7vh,5rem) 0;border-bottom:1px solid var(--rule)}
.body-grid{display:grid;grid-template-columns: 1fr 2fr;gap:clamp(2rem,4vw,4rem)}
.body-grid h2{font-size:clamp(1.85rem,1.3rem + 2.4vw,3.2rem);line-height:1.08;padding-bottom:.04em}
.body-grid p{font-size:1.05rem;line-height:1.7;color:var(--ink-soft)}
.body-grid p + p{margin-top:1.1rem}
.body-grid p a{color:var(--ink);border-bottom:1px solid var(--pink);transition:color var(--t-fast)}
.body-grid p a:hover{color:var(--pink)}
.body-grid .copy strong{color:var(--ink);font-weight:600}

/* deliverables / list */
.deliverables{
  margin-top:1.6rem;
  display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--rule);
  border:1px solid var(--rule);border-radius:6px;overflow:hidden;
}
.deliverables li{
  background:var(--bg);padding:1.1rem 1.2rem;
  display:flex;flex-direction:column;gap:.4rem;
}
.deliverables .key{font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute)}
.deliverables .val{font-size:1rem;line-height:1.4;color:var(--ink)}

/* SEO support paragraph block */
.seo-support{
  background:var(--bg-alt);border:1px solid var(--rule);border-radius:8px;
  padding:clamp(1.6rem,3vw,2.4rem);margin-top:2rem;
}
.seo-support p{font-size:1.02rem;line-height:1.7;color:var(--ink-soft);max-width:none}
.seo-support p + p{margin-top:1rem}

/* FAQ ------------------------------------------------------- */
.faq{padding:clamp(3rem,8vh,6rem) 0;border-bottom:1px solid var(--rule)}
.faq-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:clamp(2rem,4vw,4rem)}
.faq-list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--rule)}
.faq-item{border-bottom:1px solid var(--rule)}
.faq-item summary{
  list-style:none;cursor:pointer;
  display:flex;align-items:flex-start;justify-content:space-between;gap:1.6rem;
  padding:1.4rem 0;
  font-family:var(--display);font-weight:600;
  font-size:clamp(1.2rem,.9rem + 1vw, 1.65rem);line-height:1.18;letter-spacing:-.035em;
  color:var(--ink);transition:color var(--t-fast);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary .toggle{
  flex:0 0 auto;width:2.2rem;height:2.2rem;border:1px solid var(--ink);border-radius:50%;
  display:grid;place-items:center;font-family:var(--mono);font-size:1.1rem;
  transition:transform var(--t-fast),background var(--t-fast),color var(--t-fast);
}
.faq-item summary:hover{color:var(--pink)}
.faq-item summary:hover .toggle{background:var(--pink);border-color:var(--pink);color:#fff}
.faq-item[open] summary .toggle{transform:rotate(45deg);background:var(--ink);border-color:var(--ink);color:#fff}
.faq-item[open] summary{color:var(--ink)}
.faq-answer{
  padding:0 0 1.6rem;color:var(--ink-soft);font-size:1.02rem;line-height:1.65;max-width:62ch;
}
.faq-answer p + p{margin-top:.8rem}

/* internal-links block ------------------------------------- */
.related{padding:clamp(3rem,7vh,5rem) 0}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem}
.related-card{
  border:1px solid var(--rule);border-radius:6px;padding:1.4rem 1.4rem 1.6rem;
  display:flex;flex-direction:column;gap:.6rem;
  background:var(--bg);transition:background var(--t-fast),transform var(--t-fast);
}
.related-card:hover{background:var(--bg-alt);transform:translateY(-2px)}
.related-card .key{font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--pink)}
.related-card h4{font-size:1.4rem;line-height:1.05;font-weight:300}
.related-card .arr{font-family:var(--mono);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;margin-top:auto;display:inline-flex;gap:.5rem;align-items:center;color:var(--ink)}
.related-card .arr::after{content:"→";transition:transform var(--t-fast)}
.related-card:hover .arr::after{transform:translateX(3px);color:var(--pink)}

/* CONTACT FORM (final CTA on service pages) ---------------- */
.contact-form{
  background:var(--bg-deep);color:var(--bg);
  padding:clamp(4rem,10vh,7rem) 0;
}
.contact-form h2{color:var(--bg);font-size:clamp(2rem,1.4rem + 3vw, 4rem);max-width:18ch}
.contact-form .lede{color:rgba(242,239,234,.7);margin-top:1.2rem}
.cf-grid{display:grid;grid-template-columns: 1fr 1fr;gap:clamp(2rem,4vw,4rem);align-items:start}
.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.2rem}
.field label{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(242,239,234,.6);
}
.field input,.field textarea{
  background:transparent;color:var(--bg);
  border:0;border-bottom:1px solid rgba(242,239,234,.3);
  padding:.7rem 0;font-size:1.02rem;
  transition:border-color var(--t-fast);
}
.field input:focus,.field textarea:focus{outline:none;border-bottom-color:var(--pink)}
.field textarea{min-height:6rem;resize:vertical}
.consent{display:flex;gap:.7rem;align-items:flex-start;margin:1.2rem 0;font-size:.86rem;color:rgba(242,239,234,.7)}
.consent input{accent-color:var(--pink);margin-top:.25rem}

/* ANIMATIONS / REVEAL -------------------------------------- */
.reveal{
  opacity:0;transform:translateY(20px);
  transition:opacity .8s ease, transform .8s cubic-bezier(.2,.7,.3,1);
}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none}
}

/* RESPONSIVE ----------------------------------------------- */
@media (max-width: 980px){
  .hero-grid{grid-template-columns:1fr;gap:2rem}
  .hero-img{order:2;aspect-ratio:4/3;transform:none;max-width:520px}
  .hero-foot{grid-template-columns:1fr;align-items:start}
  .hero-cta{align-items:flex-start}
  .section-head{grid-template-columns:1fr;gap:1rem}
  .services{grid-template-columns:1fr}
  .service-card{border-right:0;border-bottom:1px solid var(--rule);min-height:auto}
  .service-card:last-child{border-bottom:0}
  .philosophy-grid{grid-template-columns:1fr;gap:2rem}
  .steps{grid-template-columns:1fr 1fr}
  .step{border-right:0;border-bottom:1px solid var(--rule);min-height:auto}
  .step:nth-child(2n){border-right:0}
  .step:nth-child(odd){border-right:1px solid var(--rule)}
  .work-grid{grid-template-columns:1fr}
  .work-item.large,.work-item.med,.work-item.thin,.work-item.wide{grid-column:1/-1;min-height:260px}
  .close-grid{grid-template-columns:1fr;gap:2rem}
  .close .meta-row{grid-template-columns:1fr;gap:1.2rem}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .page-hero-grid{grid-template-columns:1fr;gap:2rem}
  .body-grid{grid-template-columns:1fr;gap:1.2rem}
  .deliverables{grid-template-columns:1fr}
  .faq-grid{grid-template-columns:1fr}
  .related-grid{grid-template-columns:1fr}
  .cf-grid{grid-template-columns:1fr}
  /* MOBILE NAV — Phase X.4: full-overlay stacking lift.
     Hidden state already hardened in X.3 (transform + opacity + visibility + pointer-events).
     Phase X.4 lifts the menu's stacking context so it ALWAYS overlays page content,
     regardless of which sibling sections create their own stacking contexts. */
  .nav-links{
    position:fixed;
    inset:0;
    background:var(--bg); /* fully opaque cream — no transparency that could leak hero through */
    flex-direction:column;align-items:flex-start;gap:1.6rem;
    padding:5.5rem var(--gutter) 2.4rem;
    margin:0;
    border-bottom:1px solid var(--rule);
    overflow-y:auto;
    /* Closed state — Phase X.5: slide from right (translateX) per spec */
    transform:translateX(100%);
    opacity:0;
    visibility:hidden;
    pointer-events:none;
    transition:
      transform var(--t-mid) cubic-bezier(.2,.7,.3,1),
      opacity var(--t-mid) ease,
      visibility 0s linear var(--t-mid);
    z-index:9999;
  }
  .nav-links.open{
    transform:translateX(0);
    opacity:1;
    visibility:visible;
    pointer-events:auto;
    transition:
      transform var(--t-mid) cubic-bezier(.2,.7,.3,1),
      opacity var(--t-mid) ease,
      visibility 0s linear 0s;
  }
  .nav-links a{font-family:var(--display);font-weight:600;font-size:2rem;letter-spacing:-.04em}
  .nav-cta{font-family:var(--mono);font-size:.86rem}
  /* Toggle stays above the open menu so the X is always tappable. */
  .menu-toggle{display:inline-flex;position:relative;z-index:10000}
  /* Header creates the top stacking root; menu (z:9999) and toggle (z:10000) sit inside it. */
  .site-header{z-index:10001}
}

/* Body scroll lock when mobile menu is open — prevents background scroll bleed-through.
   JS adds .nav-open to body when the menu opens, removes it on close. */
body.nav-open{
  overflow:hidden;
  /* iOS Safari needs both for reliable scroll lock */
  position:relative;
}
@media (max-width: 540px){
  .hero h1{font-size:clamp(2.6rem,2rem + 8vw,4.4rem)}
  .pullquote{font-size:clamp(1.8rem,1.4rem + 3.2vw,2.6rem);max-width:none}
  .footer-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .step{border-right:0;border-bottom:1px solid var(--rule)}
  .step:nth-child(odd){border-right:0}
  .step:last-child{border-bottom:0}
  .marquee-track span{font-size:1.2rem;gap:1.6rem}
}

/* QRiousMedia footer credit on QM site is removed (own site) */

/* ============================================================
   PHASE 6 — EDGE PUSH ADDITIONS
   Signature manifesto · pinned horizontal work · timeline
   ============================================================ */

/* MANIFESTO — full-viewport signature section ============== */
.manifesto{
  padding:0;
  min-height:100vh;
  display:grid;place-items:center;
  position:relative;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  overflow:hidden;
  background:
    radial-gradient(80% 60% at 50% 50%, rgba(230,57,112,.08), transparent 60%),
    var(--bg);
}
.manifesto::before{
  content:"";position:absolute;left:50%;top:0;bottom:0;width:1px;
  background:linear-gradient(180deg, transparent, var(--pink) 30%, var(--pink) 70%, transparent);
  opacity:.35;
  transform-origin:top;
}
.manifesto-meta{
  position:absolute;top:2rem;left:0;right:0;
  display:flex;justify-content:space-between;align-items:center;
  padding:0 var(--gutter);
  font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-mute);
}
.manifesto-meta .dot{width:.42rem;height:.42rem;background:var(--pink);border-radius:50%;display:inline-block;margin:0 .5rem;animation:pulse 2.4s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.4;transform:scale(.85)}50%{opacity:1;transform:scale(1.15)}}
.manifesto-statement{
  text-align:center;
  font-family:var(--display);
  font-weight:700;
  font-size:clamp(2.4rem, 1rem + 9.4vw, 11.5rem);
  line-height:1.05;letter-spacing:-.065em;color:var(--ink);
  text-wrap:balance;
  padding:0 var(--gutter);
  max-width:18ch;
}
.manifesto-statement .line{
  display:block;overflow:hidden;
  padding-bottom:.18em;margin-bottom:-.06em;
}
.manifesto-statement .word{
  display:inline-block;will-change:transform,opacity;
  transform:translateY(110%);opacity:0;
  transition:transform .9s cubic-bezier(.18,.7,.2,1), opacity .9s ease;
}
.manifesto-statement.in .word{transform:translateY(0);opacity:1}
/* Stagger up to 14 words — even-numbered get pink offset (decorative) */
.manifesto-statement.in .word:nth-child(1){transition-delay:0s}
.manifesto-statement.in .word:nth-child(2){transition-delay:.06s}
.manifesto-statement.in .word:nth-child(3){transition-delay:.12s}
.manifesto-statement.in .word:nth-child(4){transition-delay:.18s}
.manifesto-statement.in .word:nth-child(5){transition-delay:.30s}
.manifesto-statement.in .word:nth-child(6){transition-delay:.36s}
.manifesto-statement.in .word:nth-child(7){transition-delay:.42s}
.manifesto-statement.in .word:nth-child(8){transition-delay:.48s}
.manifesto-statement .accent-mark{color:var(--pink)}
.manifesto-foot{
  position:absolute;bottom:2rem;left:0;right:0;
  display:flex;justify-content:space-between;align-items:center;
  padding:0 var(--gutter);
  font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-mute);
}
@media (prefers-reduced-motion: reduce){
  .manifesto-statement .word{transform:none;opacity:1;transition:none}
  .manifesto-meta .dot{animation:none}
}
@media (max-width: 720px){
  .manifesto{min-height:80vh;padding:6rem 0}
  .manifesto-statement{font-size:clamp(2.2rem,1.6rem + 6vw,4.8rem);max-width:none}
  .manifesto-meta,.manifesto-foot{position:static;padding:0 var(--gutter);margin:1.4rem 0}
  .manifesto-foot{order:3}
}

/* PINNED HORIZONTAL WORK ================================== */
.work-pin{
  /* Container is tall — inner sticky pin pans horizontally as user scrolls */
  position:relative;
  border-top:1px solid var(--rule);
  background:var(--bg-alt);
  /* tall outer = scroll runway; calculated by JS */
}
.work-pin-inner{
  position:sticky;top:0;
  height:100vh;
  overflow:hidden;
  display:flex;flex-direction:column;
}
.work-pin-head{
  padding:clamp(2.5rem,4vh,4rem) var(--gutter) 1.4rem;
  display:flex;justify-content:space-between;align-items:end;gap:1rem 2rem;
  flex-wrap:wrap;
  max-width:100%;
}
.work-pin-head .meta{flex-wrap:wrap;gap:.6rem 1.2rem}
.work-pin-head .meta .progress{max-width:100%}
.work-pin-head .lead{
  font-family:var(--display);font-weight:600;
  font-size:clamp(1.85rem,1.3rem + 2.2vw,3rem);
  line-height:1.06;letter-spacing:-.045em;max-width:16ch;
  padding-bottom:.04em;
}
.work-pin-head .meta{
  font-family:var(--mono);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute);
  display:flex;gap:1.2rem;align-items:center;
}
.work-pin-head .meta .progress{
  width:120px;height:1px;background:var(--rule);position:relative;display:inline-block;
}
.work-pin-head .meta .progress span{
  position:absolute;left:0;top:-1px;height:3px;background:var(--pink);width:0;transition:width .15s linear;
}
.work-pin-head .meta .hint{display:inline-flex;align-items:center;gap:.4rem}
.work-pin-head .meta .hint::before{content:"";width:.5rem;height:.5rem;background:var(--pink);border-radius:50%;animation:pulse 2.4s ease-in-out infinite}

.work-track-wrap{
  flex:1;overflow:hidden;cursor:grab;user-select:none;
  position:relative;
}
.work-track-wrap.dragging{cursor:grabbing}
.work-track{
  display:flex;height:100%;align-items:stretch;
  padding:0 var(--gutter);gap:1.5rem;
  will-change:transform;
  transform:translate3d(0,0,0);
}
.case{
  flex:0 0 auto;width:clamp(260px, 38vw, 540px);
  position:relative;border-radius:8px;overflow:hidden;
  background:#1A1A1C;color:#fff;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:2rem 1.8rem;
  transition:transform var(--t-fast);
}
.case::before{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.4) 0%, rgba(0,0,0,.15) 35%, rgba(0,0,0,.85) 100%);
  z-index:1;
}
.case::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(80% 60% at 30% 30%, rgba(230,57,112,.18), transparent 60%),
    radial-gradient(60% 50% at 80% 70%, rgba(39,71,255,.22), transparent 65%);
  mix-blend-mode:multiply;
}
/* Real-image cover for each case card — sits behind the gradient overlay */
.case .case-img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  z-index:0;
  filter:contrast(1.05) saturate(.85) brightness(.7);
  transition:transform .9s cubic-bezier(.2,.7,.3,1), filter .6s ease;
}
.case:hover .case-img{transform:scale(1.05);filter:contrast(1.1) saturate(.95) brightness(.78)}
.case > *{position:relative;z-index:2}
.case .tag{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-bottom:.6rem;
}
.case h4{
  color:#fff;font-size:clamp(1.4rem,1rem + 1.1vw,2rem);line-height:1.08;letter-spacing:-.035em;font-weight:600;
  padding-bottom:.04em;
}
.case .row{
  margin-top:1.4rem;display:flex;justify-content:space-between;align-items:end;gap:1rem;
}
.case .city{font-family:var(--mono);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.case .arr{
  width:2.4rem;height:2.4rem;border:1px solid rgba(255,255,255,.4);border-radius:50%;
  display:grid;place-items:center;color:#fff;
  transition:background var(--t-fast),border-color var(--t-fast),transform var(--t-fast);
}
.case:hover .arr{background:var(--pink);border-color:var(--pink);transform:translateX(4px)}
/* Per-card gradients (real "work" energy, hand-tuned) */
.case.c1{background:linear-gradient(135deg,#1A1A1C 0%,#3B1F33 100%)}
.case.c2{background:linear-gradient(135deg,#0E0E10 0%,#2747FF 100%)}
.case.c3{background:linear-gradient(135deg,#2A1820 0%,#E63970 100%)}
.case.c4{background:linear-gradient(135deg,#0E0E10 0%,#5B5B62 100%)}
.case.c5{background:linear-gradient(135deg,#1A1A1C 0%,#1F4B33 100%)}
.case.c6{background:linear-gradient(135deg,#1A1A1C 0%,#553A1F 100%)}
.case.c7{
  background:var(--bg);color:var(--ink);
  border:1px solid var(--rule);
  display:flex;flex-direction:column;justify-content:space-between;
}
.case.c7::before,.case.c7::after{display:none}
.case.c7 .tag{color:var(--pink)}
.case.c7 h4{color:var(--ink)}
.case.c7 .city{color:var(--ink-mute)}
.case.c7 .arr{border-color:var(--ink);color:var(--ink)}
.case.c7:hover .arr{background:var(--ink);border-color:var(--ink);color:var(--bg)}

/* Cover-image hover reveal — additional motion layer */
.case .cover{
  position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:0;transform:scale(1.06);transition:opacity .5s ease, transform .8s ease;z-index:0;
}
.case:hover .cover{opacity:.6;transform:scale(1)}

@media (max-width: 760px){
  /* Collapse pinned scroll to native horizontal swipe on small screens */
  .work-pin{height:auto !important}
  .work-pin-inner{position:static;height:auto}
  .work-track-wrap{overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
  .work-track{transform:none !important;padding:0 var(--gutter) 1.5rem}
  .case{scroll-snap-align:start;height:380px;width:78vw}
}

/* TIMELINE — "SÅ HÄNDER DET" =============================== */
.flow{
  border-top:1px solid var(--rule);
  background:var(--bg);
  padding-top:clamp(4rem,9vh,7rem);
}
.flow-head{
  display:grid;grid-template-columns:1fr 1.6fr;gap:2rem;align-items:end;
  margin-bottom:clamp(2.4rem,5vh,4rem);
}
.flow-head h2{font-size:clamp(2rem,1.5rem + 2.4vw,3.8rem);font-weight:700;letter-spacing:-.045em;line-height:1.06;padding-bottom:.04em}
.flow-head p{color:var(--ink-soft);font-size:1.05rem;line-height:1.5}

.flow-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;border-top:1px solid var(--rule);
  position:relative;
}
.flow-grid::before{
  content:"";position:absolute;left:0;right:0;top:0;height:3px;
  background:var(--pink);width:0;
  animation:flow-line 1.6s ease forwards;animation-play-state:paused;
}
.flow-grid.in::before{animation-play-state:running}
@keyframes flow-line{from{width:0}to{width:100%}}
.flow-step{
  border-right:1px solid var(--rule);
  padding:2rem 1.4rem 2.4rem;
  display:flex;flex-direction:column;gap:.8rem;
  position:relative;
  transition:background var(--t-fast);
}
.flow-step:last-child{border-right:0}
.flow-step:hover{background:var(--bg-alt)}
.flow-step:nth-child(2){padding-top:3rem}
.flow-step:nth-child(3){padding-top:2.4rem}
.flow-step:nth-child(4){padding-top:3.6rem}
.flow-step .when{
  font-family:var(--mono);font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--pink);font-weight:500;
}
.flow-step h4{
  font-family:var(--display);font-weight:600;font-size:1.5rem;line-height:1.05;letter-spacing:-.035em;color:var(--ink);
}
.flow-step p{font-size:.96rem;line-height:1.55;color:var(--ink-soft);max-width:none}
.flow-step .num{
  position:absolute;top:1rem;right:1.2rem;
  font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;color:var(--ink-mute);
}

/* WHAT YOU GET — clarity block ----------------------------- */
.outcome{
  border-top:1px solid var(--rule);
  background:var(--bg-alt);
  padding:clamp(4rem,8vh,6rem) 0;
}
.outcome-grid{
  display:grid;grid-template-columns:1fr 2fr;gap:clamp(2rem,4vw,4rem);align-items:start;
}
.outcome h2{font-size:clamp(1.85rem,1.3rem + 2vw,3rem);letter-spacing:-.04em;line-height:1.08;padding-bottom:.04em}
.outcome-list{
  display:grid;grid-template-columns:1fr 1fr;gap:1.5rem 2rem;
}
.outcome-item{
  border-top:1px solid var(--rule);padding-top:1.2rem;
  display:flex;flex-direction:column;gap:.4rem;
}
.outcome-item .key{font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--pink)}
.outcome-item h5{font-size:1.05rem;font-weight:600;letter-spacing:-.025em;color:var(--ink);font-family:var(--display)}
.outcome-item p{font-size:.92rem;line-height:1.5;color:var(--ink-soft)}

@media (max-width: 980px){
  .flow-head{grid-template-columns:1fr;gap:1rem}
  .flow-grid{grid-template-columns:1fr 1fr}
  .flow-step{border-right:0;border-bottom:1px solid var(--rule);padding:2rem 1.2rem !important}
  .flow-step:nth-child(odd){border-right:1px solid var(--rule)}
  .flow-step:nth-last-child(-n+2){border-bottom:0}
  .outcome-grid{grid-template-columns:1fr}
  .outcome-list{grid-template-columns:1fr}
}
@media (max-width: 540px){
  .flow-grid{grid-template-columns:1fr}
  .flow-step{border-right:0 !important;border-bottom:1px solid var(--rule)}
  .flow-step:last-child{border-bottom:0}
}

