/* ============================================================================
   TKOBE — itsthierry.com. Cinematic video-studio rebuild.
   North star: A24 / high-end production house. Monochrome + one ember accent.
   Footage is the colour. Sharp 4px radius. One motion curve. Transform/opacity only.
   ========================================================================== */

/* ---- self-hosted faces (no CDN link) -------------------------------------- */
@font-face{ font-family:"Hanken"; src:url("assets/fonts/hanken.woff2") format("woff2");
  font-weight:400 600; font-style:normal; font-display:swap; }
@font-face{ font-family:"GeistMono"; src:url("assets/fonts/geistmono.woff2") format("woff2");
  font-weight:400 500; font-style:normal; font-display:swap; }

*,*::before,*::after{ margin:0; padding:0; box-sizing:border-box; }

:root{
  --bg:#0A0A0B; --panel:#141416; --panel-2:#1B1B1E;
  --hairline:rgba(237,231,219,.08); --hairline-2:rgba(237,231,219,.14);
  --text:#ECE6DA; --text-dim:#9B958A; --text-faint:#6B655C;
  --ember:#E08A2B; --ember-hi:#F2A23E;
  --r:4px;
  --ease:cubic-bezier(.22,1,.36,1);
  --maxw:1240px;
  --pad:clamp(22px,5.2vw,64px);
  --sect:clamp(80px,12vw,164px);
  --serif: ; /* none */
  --font:"Hanken",-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif;
  --mono:"GeistMono",ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
}

html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; background:var(--bg); }
body{
  background:var(--bg); color:var(--text); font-family:var(--font);
  font-weight:400; font-size:17px; line-height:1.55;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img,video{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
::selection{ background:rgba(224,138,43,.26); color:#fff; }

/* ---- layout + shared type -------------------------------------------------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 var(--pad); }
.wrap.narrow{ max-width:880px; }

h1,h2,h3{ font-weight:450; letter-spacing:-.02em; line-height:.98; }
.eyebrow{
  display:inline-block; font-family:var(--mono); font-weight:500;
  font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--text-dim);
}
.lead{ color:var(--text-dim); font-size:clamp(1.06rem,1.5vw,1.3rem); line-height:1.55; max-width:46ch; }
.lead b{ color:var(--text); font-weight:500; }

/* ---- buttons (flat ember — no gradient, no glow) -------------------------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  font-family:var(--font); font-weight:500; font-size:.98rem; letter-spacing:.005em;
  padding:15px 26px; border-radius:var(--r); cursor:pointer;
  background:#F2AB3A; color:#0A0A0B; border:1px solid transparent;
  transition:background .24s var(--ease), transform .24s var(--ease);
}
.btn:hover{ background:#F8B84E; transform:translateY(-1px); }
.btn:active{ transform:translateY(0); }
.btn-lg{ padding:18px 34px; font-size:1.04rem; }
.btn-block{ width:100%; }
.tlink{
  display:inline-flex; align-items:center; gap:.5em; color:var(--text-dim);
  font-size:.96rem; padding-bottom:3px; border-bottom:1px solid var(--hairline-2);
  transition:color .24s var(--ease), border-color .24s var(--ease);
}
.tlink:hover{ color:var(--text); border-color:var(--text-dim); }
.tlink .ar{ transition:transform .24s var(--ease); }
.tlink:hover .ar{ transform:translateX(3px); }

/* ---- film grain (static) + section top-light ------------------------------ */
.grain{
  position:fixed; inset:0; z-index:80; pointer-events:none; opacity:.04; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:180px 180px;
}
.section{ position:relative; padding:var(--sect) 0; }
.section::before{
  content:""; position:absolute; left:0; right:0; top:0; height:300px; z-index:0; pointer-events:none;
  background:linear-gradient(180deg, rgba(237,231,219,.035), transparent 72%);
}
.section.warm::before{
  background:linear-gradient(180deg, rgba(224,138,43,.05), rgba(237,231,219,.018) 42%, transparent 74%);
}
.section > .wrap{ position:relative; z-index:1; }
.section-head{ max-width:var(--maxw); margin:0 auto clamp(40px,5.5vw,72px); }
.section-head .eyebrow{ margin-bottom:18px; }
.section-head h2{ font-size:clamp(2.1rem,5.2vw,3.9rem); max-width:18ch; }
.section-head .lead{ margin-top:20px; }

/* ---- nav masthead --------------------------------------------------------- */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:50; display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--pad); border-bottom:1px solid transparent;
  transition:background .3s var(--ease), backdrop-filter .3s var(--ease), border-color .3s var(--ease), padding .3s var(--ease);
}
.nav.scrolled{ background:rgba(10,10,11,.72); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  border-bottom-color:var(--hairline); padding-top:13px; padding-bottom:13px; }
.wordmark{ display:inline-flex; align-items:baseline; gap:.6em; color:rgba(236,230,218,.85); }
.wordmark b{ font-weight:500; letter-spacing:.26em; font-size:.86rem; }
.wordmark span{ font-family:var(--mono); font-weight:500; font-size:.58rem; letter-spacing:.2em;
  text-transform:uppercase; color:var(--text-faint); }
.nav-links{ display:flex; align-items:center; gap:clamp(18px,2.4vw,36px); }
.nav-links > a:not(.btn){ color:var(--text-dim); font-size:.9rem; font-weight:400; letter-spacing:.01em;
  transition:color .22s var(--ease); }
.nav-links > a:not(.btn):hover{ color:var(--text); }
.btn-sm{ padding:10px 18px; font-size:.86rem; }

/* ---- hero ----------------------------------------------------------------- */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end; overflow:hidden; }
.hero-video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; }
.hero-scrim{ position:absolute; inset:0; z-index:1; background:
  linear-gradient(90deg, rgba(10,10,11,.93) 0%, rgba(10,10,11,.6) 36%, rgba(10,10,11,.08) 70%, transparent 100%),
  linear-gradient(0deg, rgba(10,10,11,.9) 0%, rgba(10,10,11,.1) 40%, transparent 64%); }
.hero-inner{ position:relative; z-index:2; width:100%; max-width:var(--maxw); margin:0 auto;
  padding:0 var(--pad) clamp(58px,10vh,116px); }
.hero .eyebrow{ margin-bottom:26px; color:var(--text); opacity:.92; }
.hero h1{ font-size:clamp(2.7rem,7.8vw,6.6rem); font-weight:450; letter-spacing:-.025em; line-height:.98;
  max-width:16ch; }
.hero h1 .dim{ color:var(--text-dim); }
.hero-sub{ margin-top:24px; max-width:34ch; font-size:clamp(1.08rem,1.7vw,1.4rem); line-height:1.5; color:#d8d2c6; }
.hero-sub b{ color:var(--text); font-weight:500; }
.hero-cta{ display:flex; flex-wrap:wrap; align-items:center; gap:22px; margin-top:38px; }

/* ---- trust ribbon (quiet mono) -------------------------------------------- */
.trust{ display:flex; flex-wrap:wrap; align-items:center; gap:10px 20px; padding:18px var(--pad);
  font-family:var(--mono); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--text-dim); }
.trust i{ color:var(--text-faint); font-style:normal; }

/* ---- guarantee / "see it before you pay" moment --------------------------- */
.guarantee{ text-align:left; }
.guarantee .tag{ display:inline-block; font-family:var(--mono); font-size:.72rem; letter-spacing:.22em;
  text-transform:uppercase; color:var(--text-dim); margin-bottom:30px; }
.guarantee h2{ font-size:clamp(2.6rem,7vw,5.4rem); font-weight:450; letter-spacing:-.025em; line-height:1.0;
  max-width:18ch; }
.guarantee h2 .u{ position:relative; white-space:nowrap; }
.guarantee h2 .u::after{ content:""; position:absolute; left:0; right:0; bottom:.06em; height:2px;
  background:var(--ember); opacity:.9; }
.guarantee .lead{ margin-top:32px; font-size:clamp(1.14rem,1.9vw,1.5rem); color:var(--text-dim); max-width:40ch; }

/* ---- work showcase (the centrepiece) -------------------------------------- */
.work .stage{ position:relative; margin-top:clamp(20px,3vw,40px); overflow-x:clip; }
.track{ position:relative; height:clamp(280px,52vw,640px); will-change:transform; }
.plate{
  position:absolute; top:50%; left:50%; width:min(70vw,920px); aspect-ratio:16/9;
  transform:translate(-50%,-50%); transform-origin:center;
  transition:transform .5s var(--ease), opacity .5s var(--ease), filter .5s var(--ease);
  will-change:transform,opacity,filter;
}
.plate .screen{ position:relative; width:100%; height:100%; border-radius:var(--r); overflow:hidden;
  background:#000; box-shadow:0 40px 90px -40px rgba(0,0,0,.9); }
.plate video, .plate .poster{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.plate .poster{ background-size:cover; background-position:center; }
.plate .plate-meta{ position:absolute; left:2px; bottom:-30px; font-family:var(--mono); font-size:.72rem;
  letter-spacing:.14em; text-transform:uppercase; color:var(--text-dim); opacity:0; transition:opacity .5s var(--ease); }
.plate .scrim{ position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(0deg, rgba(8,8,10,.5), transparent 46%); }
.plate .toggle{ position:absolute; inset:0; z-index:3; background:transparent; border:0; cursor:pointer; }
.plate .cap{ position:absolute; z-index:2; left:14px; bottom:12px; font-family:var(--mono); font-size:.66rem;
  letter-spacing:.1em; text-transform:uppercase; color:#efeadf; background:rgba(8,8,10,.42);
  -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px); border:1px solid var(--hairline);
  padding:6px 11px; border-radius:var(--r); }
/* sound toggle — only on the active card; ember when on */
.plate .sound{ position:absolute; z-index:4; right:14px; bottom:14px; display:none; align-items:center; gap:8px;
  font-family:var(--mono); font-size:.62rem; letter-spacing:.14em; text-transform:uppercase; color:#efeadf;
  background:rgba(8,8,10,.5); -webkit-backdrop-filter:blur(10px); backdrop-filter:blur(10px);
  border:1px solid var(--hairline-2); padding:8px 13px; border-radius:var(--r); cursor:pointer;
  transition:border-color .22s var(--ease), background .22s var(--ease), color .22s var(--ease); }
.plate.is-active .sound{ display:inline-flex; }
.plate .sound:hover{ border-color:var(--text-dim); color:#fff; }
.plate .sound svg{ width:15px; height:15px; display:block; color:currentColor; }
.plate .sound .wave{ opacity:0; transition:opacity .22s var(--ease); }
.plate .sound .slash{ opacity:1; transition:opacity .22s var(--ease); }
.plate .sound.on{ border-color:var(--ember); color:var(--ember); background:rgba(224,138,43,.12); }
.plate .sound.on .wave{ opacity:1; }
.plate .sound.on .slash{ opacity:0; }
/* depth states (set by JS via data-rel) */
.plate.is-active{ z-index:5; }
.plate.is-active .screen{ box-shadow:0 60px 120px -42px rgba(0,0,0,.95);
  -webkit-box-reflect:below 4px linear-gradient(transparent 58%, rgba(0,0,0,.22)); }
.plate.is-active .plate-meta{ opacity:1; }
.plate.is-active::before{ content:""; position:absolute; inset:-12% -8%; z-index:-1;
  background:radial-gradient(60% 60% at 50% 52%, rgba(224,138,43,.22), transparent 70%); filter:blur(14px); }
.stage-nav{ display:flex; align-items:center; justify-content:center; gap:22px; margin-top:62px; }
.stage-nav .count{ font-family:var(--mono); font-size:.72rem; letter-spacing:.14em; color:var(--text-faint); margin-right:6px; }
.stage-nav .count b{ color:var(--text); font-weight:500; }
.arrow{ width:46px; height:46px; border-radius:50%; border:1px solid var(--hairline-2); background:transparent;
  color:var(--text-dim); font-size:1rem; cursor:pointer; display:grid; place-items:center;
  transition:color .22s var(--ease), border-color .22s var(--ease), transform .22s var(--ease); }
.arrow:hover{ color:var(--text); border-color:var(--text-dim); }
.arrow:active{ transform:scale(.94); }
.dots{ display:flex; align-items:center; gap:11px; }
.dot{ width:7px; height:7px; border-radius:50%; background:var(--text-faint); border:0; cursor:pointer; padding:0;
  transition:background .22s var(--ease), transform .22s var(--ease); }
.dot.on{ background:var(--ember); transform:scale(1.25); }

/* ---- industries (typographic columns, no boxes) --------------------------- */
.ind{ list-style:none; display:grid; grid-template-columns:1fr; }
.ind li{ display:flex; align-items:baseline; gap:1em; padding:clamp(15px,2vw,22px) 0;
  border-bottom:1px solid var(--hairline); font-size:clamp(1.08rem,1.9vw,1.42rem); font-weight:450; color:var(--text); }
.ind li .ix{ font-family:var(--mono); font-size:.74rem; letter-spacing:.1em; color:var(--text-faint); }
.ind li:hover{ color:var(--text); }

/* ---- what you get (numerals, no cards) ------------------------------------ */
.gets{ display:grid; grid-template-columns:1fr; }
.get{ display:grid; grid-template-columns:auto 1fr; gap:clamp(18px,4vw,60px); align-items:baseline;
  padding:clamp(24px,3.6vw,40px) 0; border-top:1px solid var(--hairline); }
.gets .get:last-child{ border-bottom:1px solid var(--hairline); }
.get .n{ font-weight:450; font-size:clamp(2.2rem,6vw,4.4rem); line-height:.9; letter-spacing:-.03em;
  color:var(--text-faint); }
.get h3{ font-size:clamp(1.16rem,2vw,1.55rem); font-weight:500; letter-spacing:-.015em; }
.get p{ color:var(--text-dim); margin-top:8px; max-width:48ch; font-size:1rem; }

/* ---- pricing -------------------------------------------------------------- */
.pricing .price{ display:flex; align-items:flex-start; font-weight:500; letter-spacing:-.045em; line-height:.86;
  font-size:clamp(5rem,22vw,15rem); margin:6px 0 8px; }
.price .cur{ color:var(--ember); font-size:.4em; margin-top:.14em; margin-right:.02em; font-weight:450; }
.price .flat{ align-self:flex-end; margin-bottom:.9em; margin-left:.4em; font-family:var(--mono); font-weight:500;
  font-size:.1em; letter-spacing:.14em; text-transform:uppercase; color:var(--text-dim); }
.pricing .lead{ margin-top:8px; max-width:42ch; }
.pricing .btn{ margin-top:40px; }

/* ---- faq (refined accordion) ---------------------------------------------- */
.faq-list{ border-top:1px solid var(--hairline); }
.faq-item{ border-bottom:1px solid var(--hairline); }
.faq-q{ width:100%; text-align:left; background:transparent; border:0; cursor:pointer; color:var(--text);
  font-family:var(--font); font-weight:450; font-size:clamp(1.1rem,1.9vw,1.4rem); letter-spacing:-.015em;
  padding:clamp(22px,2.6vw,30px) 44px clamp(22px,2.6vw,30px) 0; position:relative; }
.faq-ico{ position:absolute; right:6px; top:50%; width:15px; height:15px; transform:translateY(-50%); }
.faq-ico::before,.faq-ico::after{ content:""; position:absolute; background:var(--text-dim); transition:transform .3s var(--ease), background .3s var(--ease); }
.faq-ico::before{ left:0; right:0; top:50%; height:1.5px; transform:translateY(-50%); }   /* horizontal */
.faq-ico::after{ top:0; bottom:0; left:50%; width:1.5px; transform:translateX(-50%); }     /* vertical */
.faq-item.open .faq-ico::after{ transform:translateX(-50%) scaleY(0); }
.faq-item.open .faq-q{ color:var(--text); }
.faq-item.open .faq-ico::before{ background:var(--ember); }
.faq-a{ display:grid; grid-template-rows:0fr; transition:grid-template-rows .34s var(--ease); }
.faq-item.open .faq-a{ grid-template-rows:1fr; }
.faq-a > div{ overflow:hidden; }
.faq-a p{ color:var(--text-dim); max-width:64ch; line-height:1.6; padding:0 44px 28px 0; }

/* ---- start / creative-brief panel ----------------------------------------- */
.brief{ background:rgba(20,20,22,.9); -webkit-backdrop-filter:blur(18px); backdrop-filter:blur(18px);
  border:1px solid var(--hairline); border-radius:var(--r); padding:clamp(26px,4vw,52px);
  box-shadow:0 50px 110px -50px rgba(0,0,0,.85), inset 0 1px 0 rgba(237,231,219,.04); }
.brief-grid{ display:grid; gap:18px; }
.field{ display:grid; gap:8px; }
.field label{ font-family:var(--mono); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--text-dim); }
.field input,.field textarea{ width:100%; background:var(--panel-2); border:1px solid var(--hairline-2);
  color:var(--text); border-radius:var(--r); padding:14px 16px; font:inherit; font-size:1rem;
  transition:border-color .2s var(--ease), background .2s var(--ease), box-shadow .2s var(--ease); }
.field input::placeholder,.field textarea::placeholder{ color:var(--text-faint); }
.field input:focus,.field textarea:focus{ outline:none; border-color:var(--ember);
  background:#202023; box-shadow:0 0 0 2px rgba(224,138,43,.32); }
.field textarea{ resize:vertical; min-height:104px; }
.brief .btn{ margin-top:4px; }
.brief-note{ display:flex; align-items:center; gap:9px; margin-top:14px; color:var(--text-dim); font-size:.9rem; }
.brief-note .dot{ width:7px; height:7px; border-radius:50%; background:var(--ember); flex:none; }

/* ---- footer --------------------------------------------------------------- */
.footer{ border-top:1px solid var(--hairline); padding:clamp(48px,7vw,84px) 0; }
.footer-in{ display:flex; flex-wrap:wrap; gap:24px; align-items:flex-end; justify-content:space-between; }
.footer-meta{ display:flex; flex-direction:column; gap:7px; font-size:.92rem; color:var(--text-dim); }
.footer-meta a:hover{ color:var(--text); }
.footer-meta .row{ display:flex; flex-wrap:wrap; gap:6px 20px; }
.footer .copy{ font-family:var(--mono); font-size:.7rem; letter-spacing:.1em; color:var(--text-faint); text-transform:uppercase; }

/* ---- reveal (headers + primary cards only) -------------------------------- */
.reveal{ opacity:0; transform:translateY(20px); transition:opacity .5s var(--ease), transform .55s var(--ease); }
.reveal.in{ opacity:1; transform:none; }

/* ---- responsive ----------------------------------------------------------- */
@media (min-width:760px){
  .ind{ grid-template-columns:1fr 1fr; column-gap:clamp(44px,6vw,104px); }
  .pricing .wrap{ display:grid; grid-template-columns:1.05fr .95fr; align-items:end; gap:clamp(30px,5vw,72px); }
  .pricing .btn{ justify-self:start; }
  .start .wrap{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(34px,5vw,80px); align-items:start; }
  .start .section-head{ margin-bottom:0; position:sticky; top:120px; }
}
@media (min-width:1100px){
  .guarantee .wrap{ display:grid; grid-template-columns:1.15fr .85fr; align-items:center; gap:64px; }
}
@media (max-width:759px){
  body{ font-size:16px; }
  .nav-links > a:not(.btn){ display:none; }
  .nav{ padding-top:13px; padding-bottom:13px; }
  /* hero: lay content from BELOW the fixed nav (was bottom-aligned + overlapping it) */
  .hero{ align-items:flex-start; }
  .hero-inner{ padding-top:88px; padding-bottom:clamp(40px,7vh,72px); }
  .plate{ width:90vw; }
  .plate .sound{ right:10px; bottom:10px; padding:7px; gap:0; }   /* icon-only, smaller */
  .plate .sound span{ display:none; }
  .stage-nav{ margin-top:44px; }
  .footer-in{ flex-direction:column; align-items:flex-start; }
}

/* ---- reduced motion ------------------------------------------------------- */
@media (prefers-reduced-motion:reduce){
  html{ scroll-behavior:auto; }
  .reveal{ opacity:1 !important; transform:none !important; }
  .grain{ display:none; }
  .hero-video{ display:none; }
  .hero{ background:#0A0A0B; }
  .plate,.plate .plate-meta,.faq-a,.arrow,.dot{ transition:none !important; }
  .vtile video{ display:none; }
}

/* ============================================================================
   TKOBE2 — smooth-content components (process, work tags, verticals, deal-pin,
   deliverables, form aside, provider picker, honesty footer)
   ========================================================================== */

/* ember underline accent on any headline */
h2 .u{ position:relative; white-space:nowrap; }
h2 .u::after{ content:""; position:absolute; left:0; right:0; bottom:.06em; height:2px; background:var(--ember); opacity:.9; }

/* ---- hero: reply note, trust, deal-pin ------------------------------------ */
.reply-note{ margin-top:16px; color:var(--text-dim); font-size:.92rem; }
.hero .hero-trust{ display:block; margin-top:22px; color:var(--text-dim); opacity:.9; }
.hero-pin{ margin-top:26px; max-width:42ch; text-shadow:0 1px 2px rgba(0,0,0,.6), 0 0 16px rgba(0,0,0,.55); }
.hero-pin-label{ display:block; font-family:var(--mono); font-size:.6rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ember); margin-bottom:7px; }
.hero-pin-text{ font-size:.98rem; line-height:1.5; color:var(--text); }
.hero-pin-text b{ font-weight:500; }

/* ---- process (4-step) ----------------------------------------------------- */
.steps{ display:grid; grid-template-columns:1fr; margin-top:clamp(22px,3vw,40px); }
.step{ display:grid; grid-template-columns:auto 1fr; gap:20px; align-items:baseline; padding:clamp(22px,3vw,30px) 0; border-top:1px solid var(--hairline); }
.steps .step:last-child{ border-bottom:1px solid var(--hairline); }
.step .n{ font-weight:450; font-size:clamp(1.9rem,4.4vw,2.8rem); line-height:.9; letter-spacing:-.03em; color:var(--text); }
.step h3{ font-size:clamp(1.12rem,1.8vw,1.4rem); font-weight:500; letter-spacing:-.015em; }
.step p{ color:var(--text-dim); margin-top:8px; font-size:.98rem; max-width:46ch; }

/* ---- work tags + studio plate captions ------------------------------------ */
.work-tag{ position:absolute; z-index:3; left:14px; top:14px; font-family:var(--mono); font-size:.6rem; letter-spacing:.14em;
  text-transform:uppercase; padding:5px 10px; border-radius:var(--r); background:rgba(8,8,10,.5);
  -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px); border:1px solid var(--hairline-2); color:var(--text-dim); }
.work-tag.tag-client{ color:var(--text); border-color:rgba(224,138,43,.5); }

/* ---- vertical companion tiles --------------------------------------------- */
.verticals{ margin-top:clamp(42px,6vw,76px); }
.verticals-label{ font-family:var(--mono); font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--text-dim); text-align:center; margin-bottom:20px; }
.vrow{ display:flex; flex-wrap:wrap; gap:clamp(16px,3vw,30px); justify-content:center; }
.vtile{ width:clamp(150px,42vw,210px); }
.vscreen{ position:relative; aspect-ratio:9/16; border-radius:var(--r); overflow:hidden; background:#000; box-shadow:0 30px 70px -42px rgba(0,0,0,.9); }
.vscreen video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.vscreen .work-tag{ left:10px; top:10px; }
.vtoggle{ position:absolute; inset:0; z-index:4; background:transparent; border:0; cursor:pointer; }
.vtoggle::after{ content:""; position:absolute; left:50%; top:50%; width:48px; height:48px; transform:translate(-50%,-50%);
  border-radius:50%; border:1px solid var(--hairline-2); background:rgba(8,8,10,.42); -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px);
  transition:opacity .24s var(--ease); }
.vtile.playing .vtoggle::after{ opacity:0; }
.vtile figcaption{ font-family:var(--mono); font-size:.64rem; letter-spacing:.1em; text-transform:uppercase; color:var(--text-dim); text-align:center; margin-top:12px; }
.proof-note{ text-align:center; max-width:58ch; margin:clamp(38px,5vw,56px) auto 0; color:var(--text-dim); font-size:1rem; line-height:1.6; }

/* ---- industries foot ------------------------------------------------------ */
.ind-foot{ margin-top:clamp(24px,3vw,36px); color:var(--text-dim); font-size:1.05rem; max-width:48ch; }

/* ---- deliverables checklist ----------------------------------------------- */
.deliver{ list-style:none; display:grid; grid-template-columns:1fr; }
.deliver li{ display:flex; align-items:baseline; gap:14px; padding:clamp(14px,2vw,19px) 0; border-bottom:1px solid var(--hairline);
  font-size:clamp(1.02rem,1.7vw,1.25rem); color:var(--text); }
.deliver li:first-child{ border-top:1px solid var(--hairline); }
.deliver .dtick{ flex:none; width:15px; height:1px; background:var(--text-faint); transform:translateY(-.4em); }

/* ---- start: form + aside grid, provider picker, status -------------------- */
.start .wrap{ display:block; }
.start .section-head{ position:static; margin-bottom:clamp(40px,5.5vw,68px); }
.start-grid{ display:grid; grid-template-columns:1fr; gap:clamp(24px,4vw,40px); }
.field .opt{ color:var(--text-faint); text-transform:none; letter-spacing:0; }
.hp{ position:absolute !important; left:-9999px; width:1px; height:1px; opacity:0; pointer-events:none; }
.form-status{ margin-top:12px; font-size:.92rem; line-height:1.5; }
.form-status.ok{ color:var(--ember); }
.form-status.err{ color:#e0875a; }
.form-status.err a{ color:var(--ember); text-decoration:underline; }
.email-alt{ margin-top:24px; }
.email-alt-label{ color:var(--text-dim); font-size:.92rem; }
.email-alt-label .email-addr{ color:var(--text); }
.email-alt-row{ display:flex; flex-wrap:wrap; gap:10px; margin-top:12px; }
.email-alt-row a{ font-family:var(--mono); font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; color:var(--text-dim);
  border:1px solid var(--hairline-2); padding:8px 14px; border-radius:var(--r); transition:color .2s var(--ease), border-color .2s var(--ease); }
.email-alt-row a:hover{ color:var(--text); border-color:var(--text-dim); }
.start-aside{ background:rgba(20,20,22,.72); -webkit-backdrop-filter:blur(14px); backdrop-filter:blur(14px);
  border:1px solid var(--hairline); border-radius:var(--r); padding:clamp(24px,3vw,34px); align-self:start; }
.aside-price{ display:flex; align-items:flex-start; font-weight:500; font-size:clamp(3rem,7vw,4.4rem); letter-spacing:-.04em; line-height:.9; }
.aside-price .cur{ color:var(--ember); font-size:.4em; margin-top:.14em; }
.aside-price .flat{ align-self:flex-end; margin-bottom:.7em; margin-left:.3em; font-family:var(--mono); font-size:.16em; letter-spacing:.14em; text-transform:uppercase; color:var(--text-dim); }
.aside-list{ list-style:none; margin-top:18px; display:grid; gap:11px; }
.aside-list li{ position:relative; padding-left:18px; color:var(--text-dim); font-size:.96rem; line-height:1.4; }
.aside-list li::before{ content:""; position:absolute; left:0; top:.58em; width:8px; height:1px; background:var(--ember); }
.aside-foot{ margin-top:20px; font-family:var(--mono); font-size:.64rem; letter-spacing:.1em; text-transform:uppercase; color:var(--text-faint); }

/* ---- footer honesty ------------------------------------------------------- */
.footer-in{ display:flex; flex-direction:column; align-items:flex-start; gap:22px; }
.footer-honest{ color:var(--text-dim); max-width:62ch; line-height:1.6; font-size:.92rem; }
.footer-meta .row a{ color:var(--text-dim); }
.footer-meta .row a:hover{ color:var(--text); }

/* ---- TKOBE2 responsive ---------------------------------------------------- */
@media (min-width:760px){
  .steps{ grid-template-columns:repeat(4,1fr); gap:clamp(22px,3vw,40px); }
  .step{ display:block; padding:24px 0 0; border-top:1px solid var(--hairline); }
  .steps .step:last-child{ border-bottom:0; }
  .step .n{ display:block; margin-bottom:14px; color:var(--text-faint); }
  .step h3{ margin-bottom:8px; }
  .deliver{ grid-template-columns:1fr 1fr; column-gap:clamp(40px,6vw,90px); }
  .deliver li:nth-child(2){ border-top:1px solid var(--hairline); }
}
@media (min-width:880px){
  .start-grid{ grid-template-columns:1.55fr .85fr; align-items:start; }
}
@media (max-width:759px){
  .vtile{ width:46vw; }
  .hero-pin{ max-width:none; margin-top:18px; }
  .hero-pin-label{ font-size:.56rem; margin-bottom:5px; }
  .hero-pin-text{ font-size:.9rem; }
  /* work caption: one tidy centred line (was wrapping to 2 lines unevenly) */
  .plate .plate-meta{ left:0; right:0; text-align:center; font-size:.58rem; letter-spacing:.1em; white-space:nowrap; }
}

/* ============================================================================
   TKOBE2 feedback pass — pillarbox verticals in the slider; symmetric
   industries grid; paired form fields; overlay tags removed (no .work-tag in DOM)
   ========================================================================== */

/* vertical (9:16) cards inside the 16:9 slider: sharp video centred over a
   blurred fill of its own poster — clean, no stark black bars */
.plate .vbg{ position:absolute; inset:0; z-index:0; background-size:cover; background-position:center;
  filter:blur(26px) brightness(.42); transform:scale(1.2); }
.plate.vert .screen video{ object-fit:contain; z-index:1; }
.plate .scrim{ z-index:2; }

/* industries: clean, symmetric 3-column grid (9 = 3×3), no index numbers */
.ind{ grid-template-columns:1fr; gap:0; }
.ind li{ display:block; padding:clamp(15px,2vw,20px) 0; border-bottom:1px solid var(--hairline);
  font-size:clamp(1.05rem,1.8vw,1.3rem); font-weight:450; color:var(--text); }
@media (min-width:680px){ .ind{ grid-template-columns:1fr 1fr 1fr; column-gap:clamp(30px,4vw,64px); } }

/* form: pair the two short fields so the panel reads tighter */
.field-pair{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media (max-width:540px){ .field-pair{ grid-template-columns:1fr; } }
