/* ═══════════════════════════════════════════════════════════════
   URU ADVERTISING — DESIGN SYSTEM v3
   Dark luxury · Poppins · Cyan–Magenta gradient accent
   ═══════════════════════════════════════════════════════════════ */

/* ── RESET ──────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:"Poppins","Helvetica Neue",sans-serif;background:#05050d;color:#e6e6f0;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img,video{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none}
ul,ol{list-style:none}

/* ── TOKENS ─────────────────────────────────────────────────── */
:root{
  --bg:#05050d; --bg2:#080812; --bg3:#0c0c1a;
  --surf:rgba(255,255,255,.035); --surf2:rgba(255,255,255,.06);
  --bdr:rgba(255,255,255,.08); --bdr2:rgba(255,255,255,.16);
  --txt:#e6e6f0; --muted:rgba(230,230,240,.52); --dim:rgba(230,230,240,.35);
  --cyan:#04c8ff; --mag:#c400ff;
  --grad:linear-gradient(105deg,#04c8ff 0%,#c400ff 100%);
  --grad-r:linear-gradient(105deg,#c400ff 0%,#04c8ff 100%);
  --grad-sub:linear-gradient(105deg,rgba(4,200,255,.12) 0%,rgba(196,0,255,.12) 100%);
  --r:12px; --r2:20px; --r3:28px; --r4:36px;
  --ease:cubic-bezier(.25,.46,.45,.94);
  --spring:cubic-bezier(.34,1.26,.64,1);
  --sh1:0 4px 24px rgba(0,0,0,.4);
  --sh2:0 16px 56px rgba(0,0,0,.55);
  --sh3:0 32px 90px rgba(0,0,0,.7);
}

/* ── LAYOUT ─────────────────────────────────────────────────── */
.container{width:min(1140px,100% - 3rem);margin-inline:auto}
.wrap{width:min(1180px,92vw);margin-inline:auto}
section{padding-block:6rem}

/* ── GRAD TEXT ──────────────────────────────────────────────── */
.grad-text{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;background-size:100%;-webkit-box-decoration-break:clone;box-decoration-break:clone}

/* ── BUTTONS ────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.72rem 1.8rem;border-radius:999px;font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;transition:transform .18s var(--ease),box-shadow .18s var(--ease),opacity .18s var(--ease),background .18s var(--ease);white-space:nowrap;cursor:pointer}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 4px 28px rgba(4,200,255,.22)}
.btn-primary:hover{box-shadow:0 8px 40px rgba(4,200,255,.38);opacity:.95}
.btn-outline{background:transparent;color:var(--txt);border:1px solid var(--bdr2)}
.btn-outline:hover{background:var(--surf2);border-color:rgba(255,255,255,.32)}
.btn-ghost{background:var(--surf);color:var(--txt);border:1px solid var(--bdr)}
.btn-ghost:hover{background:var(--surf2);border-color:var(--bdr2)}

/* ── TYPE UTILS ─────────────────────────────────────────────── */
.kicker{font-size:.65rem;font-weight:700;letter-spacing:.26em;text-transform:uppercase;color:var(--cyan);display:block}
.section-title{font-size:clamp(1.3rem,3vw,2rem);font-weight:800;letter-spacing:.05em;text-transform:uppercase;line-height:1.1}
.section-kicker{font-size:.65rem;font-weight:700;letter-spacing:.26em;text-transform:uppercase;color:var(--cyan);display:block;margin-bottom:.6rem}
.section-subtitle{font-size:.94rem;color:var(--muted);max-width:52ch;line-height:1.8;margin-top:.7rem}
.section-subtitle.centered{text-align:center;margin-inline:auto}
.centered{text-align:center}
.centered .section-subtitle{margin-inline:auto}
.no-uppercase{text-transform:none!important;letter-spacing:.02em!important}

/* ── REVEAL ─────────────────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal-visible{opacity:1;transform:none}
.reveal-in{opacity:0;transform:translateY(16px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal-in.is-in{opacity:1;transform:none}

/* ═══════════════════════════════════════════════════════════════
   HEADER
   ═══════════════════════════════════════════════════════════════ */
.site-header{position:fixed;inset-inline:0;top:0;z-index:100;height:66px;display:flex;align-items:center;padding-inline:0;background:rgba(5,5,13,.75);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--bdr);transition:background .3s var(--ease),box-shadow .3s var(--ease)}
.site-header.scrolled{background:rgba(5,5,13,.97);box-shadow:var(--sh2)}
.site-header .container{width:min(1140px,100% - 3rem);max-width:none;margin-inline:auto;padding-inline:0}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;width:100%}
.logo-area{flex-shrink:0}
.main-nav{flex:1;justify-content:center}
.header-inner>.btn{flex-shrink:0}
.header-inner>.hamburger{margin-left:auto}
.logo-area a{display:flex;align-items:center}
.uru-logo{width:110px;height:auto}
.main-nav{display:flex;align-items:center;gap:1.8rem}
.main-nav a{font-size:.72rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(230,230,240,.6);position:relative;transition:color .18s}
.main-nav a::after{content:'';position:absolute;left:0;bottom:-3px;width:0;height:1px;background:var(--grad);transition:width .22s var(--ease)}
.main-nav a:hover,.main-nav a.active{color:var(--txt)}
.main-nav a:hover::after,.main-nav a.active::after{width:100%}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;padding:9px;background:var(--surf);border:1px solid var(--bdr);border-radius:10px;transition:border-color .18s,background .18s}
.hamburger:hover{border-color:var(--bdr2);background:var(--surf2)}
.hamburger span{display:block;width:20px;height:1.5px;background:var(--txt);border-radius:2px;transform-origin:center;transition:transform .25s var(--ease),opacity .25s var(--ease)}
.hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* Mobile nav */
.mobile-nav{position:fixed;inset:66px 0 0;background:rgba(5,5,13,.98);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);z-index:99;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.8rem;opacity:0;pointer-events:none;transform:translateY(-8px);transition:opacity .28s var(--ease),transform .28s var(--ease)}
.mobile-nav.open{opacity:1;pointer-events:auto;transform:none}
.mobile-nav a{font-size:1.35rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:rgba(230,230,240,.55);transition:color .18s}
.mobile-nav a:hover{color:var(--txt)}
.mobile-nav .btn{margin-top:.5rem;font-size:.8rem}

@media(max-width:900px){.main-nav,.header-inner>.btn{display:none}.hamburger{display:flex}}

/* ═══════════════════════════════════════════════════════════════
   HERO
   ═══════════════════════════════════════════════════════════════ */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;padding-top:66px;overflow:hidden;background:var(--bg)}
.hero-blob{position:absolute;border-radius:50%;pointer-events:none;filter:blur(100px)}
.hero-blob--1{width:50vw;height:50vw;background:radial-gradient(circle,rgba(4,200,255,.08),transparent 70%);top:-5%;right:-5%;animation:blob 16s ease-in-out infinite}
.hero-blob--2{width:42vw;height:42vw;background:radial-gradient(circle,rgba(196,0,255,.07),transparent 70%);bottom:-10%;left:10%;animation:blob 16s ease-in-out infinite;animation-delay:-8s}

@keyframes blob{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(2%,3%) scale(1.03)}66%{transform:translate(-2%,-2%) scale(.97)}}
/* kept for bg depth */
.hero-gradient{position:absolute;inset:0;background:radial-gradient(circle at 15% 20%,rgba(255,255,255,.14),transparent 55%),radial-gradient(circle at 20% 100%,#00d6ff,transparent 55%),radial-gradient(circle at 85% 80%,#ff00c8,transparent 60%);opacity:.65;mix-blend-mode:screen;pointer-events:none}
.hero-inner{position:relative;z-index:1;padding-block:5rem}
.hero-copy{max-width:100%}
.hero-eyebrow{font-size:.68rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan);display:flex;align-items:center;flex-wrap:wrap;gap:.4rem .6rem;margin-bottom:1.25rem;row-gap:.4rem}
.eyebrow-item{white-space:nowrap}
@media(max-width:600px){
  .hero-eyebrow{flex-wrap:wrap;align-items:center;gap:.3rem .5rem}
  .eyebrow-green{display:inline-flex !important;opacity:1 !important;visibility:visible !important}
}
.hero-title{font-size:clamp(3rem,9vw,6.5rem);font-weight:800;line-height:1;letter-spacing:-.025em;margin-bottom:1.4rem;color:#fff}
.hero-subtitle{font-size:clamp(.9rem,1.4vw,1.05rem);color:var(--muted);line-height:1.8;max-width:72ch;margin-bottom:2.5rem}
.hero-actions{display:flex;align-items:center;flex-wrap:wrap;gap:1rem}
.scroll-cue{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--dim);font-size:.6rem;letter-spacing:.26em;text-transform:uppercase;animation:cue 2.4s ease-in-out infinite}
.scroll-cue::after{content:'';width:1px;height:40px;background:linear-gradient(to bottom,rgba(255,255,255,.28),transparent)}
@keyframes cue{0%,100%{opacity:.35;transform:translateX(-50%) translateY(0)}50%{opacity:.75;transform:translateX(-50%) translateY(5px)}}
@media(max-width:600px){.hero-title{font-size:clamp(2.6rem,11vw,3.4rem)}.hero-actions{flex-direction:column;align-items:flex-start}}

/* ═══════════════════════════════════════════════════════════════
   LOGO TICKER
   ═══════════════════════════════════════════════════════════════ */
.companies{background:var(--bg2);padding-block:3.5rem;overflow:hidden}
.companies-label{text-align:center;font-size:.62rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:rgba(230,230,240,.25);margin-bottom:1.75rem}
.logo-slider-wrapper{position:relative;overflow:hidden}
.logo-slider-wrapper::before,.logo-slider-wrapper::after{content:'';position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none}
.logo-slider-wrapper::before{left:0;background:linear-gradient(to right,var(--bg2),transparent)}
.logo-slider-wrapper::after{right:0;background:linear-gradient(to left,var(--bg2),transparent)}
.logo-slider{display:flex;align-items:center;gap:4rem;width:max-content;animation:ticker 26s linear infinite}
.logo-slider:hover{animation-play-state:paused}
.logo-item{display:flex;align-items:center;justify-content:center;flex-shrink:0;padding:0 .5rem}
.logo-item img{height:68px;width:auto;max-width:180px;object-fit:contain;opacity:.5;transition:opacity .25s;filter:none;mix-blend-mode:normal}
.logo-item:hover img{opacity:.9}
.logo-item img.logo-baroka{height:72px;max-width:190px}
.logo-item img.logo-midrange{height:78px;max-width:200px}
.logo-item img.logo-baskbay{height:72px;max-width:190px}
.logo-item img.logo-joburg{height:72px;max-width:190px}
@keyframes ticker{to{transform:translateX(-50%)}}

/* ═══════════════════════════════════════════════════════════════
   SERVICES
   ═══════════════════════════════════════════════════════════════ */
.services{background:var(--bg)}
.services-header{text-align:center;margin-bottom:3.5rem}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--bdr);border:1px solid var(--bdr);border-radius:var(--r3);overflow:hidden}
.service-card{background:var(--bg2);padding:2rem 1.75rem;position:relative;overflow:hidden;transition:background .25s}
.service-card::before{content:'';position:absolute;inset:0;background:var(--grad-sub);opacity:0;transition:opacity .3s}
.service-card:hover{background:var(--bg3)}
.service-card:hover::before{opacity:1}
.service-num{display:block;font-size:.58rem;font-weight:700;letter-spacing:.26em;text-transform:uppercase;color:var(--cyan);margin-bottom:1rem;opacity:.75}
.service-card h3{font-size:.9rem;font-weight:700;letter-spacing:.02em;margin-bottom:.55rem;color:#fff}
.service-card p{font-size:.84rem;color:var(--muted);line-height:1.75;max-width:none}
@media(max-width:900px){.services-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.services-grid{grid-template-columns:1fr}}

/* ═══════════════════════════════════════════════════════════════
   PORTFOLIO GRID (homepage)
   ═══════════════════════════════════════════════════════════════ */
.portfolio-grid-section{background:var(--bg2)}
.portfolio-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;margin-top:2.75rem}
.portfolio-card{background:var(--bg3);border:1px solid var(--bdr);border-radius:var(--r2);padding:.5rem .5rem 1rem;cursor:pointer;transition:transform .25s var(--ease),box-shadow .25s,border-color .25s}
.portfolio-card:hover{transform:translateY(-6px);box-shadow:var(--sh3);border-color:var(--bdr2)}
.portfolio-card-image-wrapper{border-radius:var(--r);overflow:hidden;aspect-ratio:1/1;background:#000}
.portfolio-card-image{width:100%;height:100%;object-fit:cover;object-position:center;transform:scale(1.06);transition:transform .45s var(--ease);display:block}
.portfolio-card:hover .portfolio-card-image{transform:scale(1.12)}
.portfolio-card-meta{padding:.8rem .35rem 0}
.portfolio-card-tag{font-size:.6rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--cyan);display:block;margin-bottom:.28rem}
.portfolio-card-title{font-size:.9rem;font-weight:700;color:#fff;margin-bottom:.28rem}
.portfolio-card-desc{font-size:.8rem;color:var(--muted);line-height:1.55}
.portfolio-hover-hint{margin-top:.65rem;font-size:.62rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--cyan);opacity:0;transform:translateY(4px);transition:opacity .2s,transform .2s}
.portfolio-card:hover .portfolio-hover-hint{opacity:1;transform:none}
@media(max-width:960px){.portfolio-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.portfolio-grid{grid-template-columns:1fr}}

/* ═══════════════════════════════════════════════════════════════
   PORTFOLIO MODAL
   ═══════════════════════════════════════════════════════════════ */
.portfolio-modal{position:fixed;inset:0;z-index:9999;display:none}
.portfolio-modal.is-open{display:block}
.portfolio-modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}
.portfolio-modal-sheet{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(840px,calc(100% - 2rem));max-height:90vh;overflow-y:auto;-webkit-overflow-scrolling:touch;border-radius:var(--r3);background:rgba(8,8,18,.96);border:1px solid rgba(255,255,255,.12);box-shadow:var(--sh3);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);animation:modalIn .3s var(--spring)}
@keyframes modalIn{from{opacity:0;transform:translate(-50%,-47%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}
.portfolio-modal-close{position:absolute;right:1rem;top:1rem;width:38px;height:38px;border-radius:50%;border:1px solid var(--bdr2);background:var(--surf);color:#fff;font-size:1.25rem;display:grid;place-items:center;transition:background .18s}
.portfolio-modal-close:hover{background:var(--surf2)}
.portfolio-modal-content{display:grid;grid-template-columns:1fr 1.15fr;min-height:340px;max-height:none;overflow:visible}
.portfolio-modal-media{padding:0;border-right:1px solid var(--bdr);display:flex;align-items:stretch;overflow:hidden;border-radius:var(--r3) 0 0 var(--r3)}

#portfolioModalImage{width:100%;height:100%;min-height:320px;max-height:76vh;border-radius:0;object-fit:cover;object-position:center top;display:block;transform:scale(1.08);transition:transform .4s var(--ease)}
.portfolio-modal-textwrap{padding:2rem 2rem 2rem 1.75rem}
.portfolio-modal-kicker{font-size:.62rem;font-weight:700;letter-spacing:.26em;text-transform:uppercase;color:var(--cyan);margin-bottom:.7rem}
.portfolio-modal-title{font-size:1.5rem;font-weight:800;color:#fff;letter-spacing:-.01em;margin-bottom:.45rem}
.portfolio-modal-subtitle{font-size:.88rem;color:var(--muted);line-height:1.65;margin-bottom:1.2rem}
.portfolio-modal-section{margin-top:1.2rem}
.portfolio-modal-section h4{font-size:.6rem;font-weight:700;letter-spacing:.26em;text-transform:uppercase;color:rgba(230,230,240,.38);margin-bottom:.55rem}
.portfolio-modal-section ul{padding:0;display:flex;flex-direction:column;gap:.42rem}
.portfolio-modal-section ul li{font-size:.86rem;color:rgba(230,230,240,.86);line-height:1.5;display:flex;gap:.55rem;align-items:flex-start}
.portfolio-modal-section ul li::before{content:'•';color:var(--cyan);font-size:.7rem;flex-shrink:0;margin-top:.15rem}
@media(max-width:660px){.portfolio-modal-content{grid-template-columns:1fr}.portfolio-modal-media{border-right:0;border-bottom:1px solid var(--bdr);border-radius:var(--r3) var(--r3) 0 0;min-height:240px}}

/* ═══════════════════════════════════════════════════════════════
   FOFO FEATURE
   ═══════════════════════════════════════════════════════════════ */
/* ── fofo feature / case study highlight ───────────────────── */
.fofoFeature{background:#000;padding:6rem 0;position:relative;overflow:hidden}
.fofoFeature::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 80% 50%,rgba(196,0,255,.055),transparent 65%);pointer-events:none}
.fofoFeature__wrap{display:grid;grid-template-columns:1fr 1.1fr;gap:5rem;align-items:center}
.fofoFeature__left{display:flex;justify-content:center;align-items:center}
.fofoFeature__logo{width:min(320px,72%);display:block;mix-blend-mode:screen}
.fofoFeature__eyebrow{font-size:.65rem;font-weight:700;letter-spacing:.26em;text-transform:uppercase;color:var(--cyan);margin-bottom:1rem}
.fofoFeature__title{font-size:clamp(1.5rem,3.5vw,2.3rem);font-weight:800;letter-spacing:-.015em;line-height:1.05;margin-bottom:1.4rem;color:#fff}
.fofoFeature__text{font-size:.92rem;color:rgba(230,230,240,.62);line-height:1.82;margin-bottom:1rem;max-width:54ch}
.fofoFeature__cta{margin-top:.7rem}
@media(max-width:860px){.fofoFeature__wrap{grid-template-columns:1fr;gap:2.5rem;text-align:center}.fofoFeature__text{max-width:none}}

/* ═══════════════════════════════════════════════════════════════
   TESTIMONIALS
   ═══════════════════════════════════════════════════════════════ */
.tBookSection{background:var(--bg2);padding-block:6rem}
.tBook{display:flex;align-items:center;justify-content:center;gap:1.2rem;margin-top:2.5rem}
.tBook__nav{width:44px;height:44px;border-radius:12px;border:1px solid var(--bdr2);background:var(--surf);color:#fff;font-size:24px;display:grid;place-items:center;flex-shrink:0;transition:background .18s,border-color .18s}
.tBook__nav:hover{background:var(--surf2);border-color:rgba(255,255,255,.28)}
.tBook__stage{width:min(960px,92vw);height:210px;perspective:1400px}
.tBook__stack{width:100%;height:100%;position:relative;transform-style:preserve-3d}
.tBook__page{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;transform-origin:left center;backface-visibility:hidden;transform:rotateY(180deg);opacity:0;pointer-events:none;transition:transform 600ms cubic-bezier(.2,.8,.2,1),opacity 200ms ease}
.tBook__page.is-active{transform:rotateY(0deg);opacity:1;pointer-events:auto}
.tBook__page.is-prev{transform:rotateY(-180deg);opacity:0}
.gCard{width:100%;max-width:900px;background:rgba(255,255,255,.93);border-radius:var(--r2);padding:1.4rem 1.6rem;box-shadow:0 20px 60px rgba(0,0,0,.4);color:#0b0f19}
.gHead{display:flex;gap:.9rem;align-items:flex-start}
.gAvatar{width:42px;height:42px;border-radius:50%;background:rgba(5,5,13,.14);display:grid;place-items:center;font-weight:800;font-size:.95rem;flex-shrink:0;overflow:hidden}
.gAvatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}
.gName{font-weight:800;font-size:.9rem}
.gSub{font-size:.72rem;opacity:.58;margin-top:2px}
.gRow{display:flex;gap:.7rem;align-items:center;margin-top:5px;flex-wrap:wrap}
.gStars{color:#f4b012;letter-spacing:2px;font-size:.82rem}
.gTime{font-size:.7rem;opacity:.52}
.gBadge{font-size:.62rem;font-weight:700;padding:2px 7px;border-radius:5px;background:rgba(5,5,13,.1)}
.gText{margin-top:.8rem;font-size:.9rem;line-height:1.62;color:rgba(11,15,25,.8)}
.tBook__hint{text-align:center;margin-top:1rem;font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);opacity:.55}
@media(max-width:600px){.tBook__nav{display:none}.tBook__stage{height:280px}.gCard{padding:1.1rem}}

/* ═══════════════════════════════════════════════════════════════
   FAQ / ABOUT
   ═══════════════════════════════════════════════════════════════ */
.about-faq-section{background:var(--bg);padding:6rem 0 5rem}
.about-faq-title{font-size:clamp(1.8rem,4vw,3rem);font-weight:800;letter-spacing:.02em;text-transform:uppercase;line-height:1.05;margin-bottom:.7rem}
.about-faq-subtitle{font-size:.92rem;color:var(--muted);max-width:58ch;line-height:1.8;margin-bottom:2.5rem}
.faq-list{border-top:1px solid var(--bdr)}
.faq-item{border-bottom:1px solid var(--bdr)}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.3rem 0;background:transparent;color:var(--txt);text-align:left;font-size:clamp(.88rem,1.5vw,1rem);font-weight:600;letter-spacing:.01em;transition:color .18s}
.faq-q:hover{color:var(--cyan)}
.faq-icon{width:26px;height:26px;border-radius:50%;border:1px solid var(--bdr2);background:var(--surf);font-size:1rem;font-weight:300;display:grid;place-items:center;flex-shrink:0;transition:background .2s,border-color .2s,transform .25s var(--ease)}
.faq-q[aria-expanded="true"] .faq-icon{background:rgba(4,200,255,.1);border-color:rgba(4,200,255,.35);transform:rotate(45deg)}
.faq-a{padding-bottom:1.2rem}
.faq-a p{font-size:.9rem;color:var(--muted);line-height:1.82;max-width:70ch}

/* ═══════════════════════════════════════════════════════════════
   CONTACT
   ═══════════════════════════════════════════════════════════════ */
.contact{background:var(--bg2)}
.contact-inner{display:grid;grid-template-columns:1.25fr .9fr;gap:4rem;align-items:flex-start}
.contact-form-wrapper .section-title{margin-bottom:1.75rem}
.contact-form{display:flex;flex-direction:column;gap:1rem}
.contact-form label{display:flex;flex-direction:column;font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(230,230,240,.5);gap:.38rem}
.contact-form input,.contact-form textarea{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);padding:.78rem 1rem;color:var(--txt);font-family:inherit;font-size:.9rem;transition:border-color .18s,box-shadow .18s,background .18s}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:rgba(4,200,255,.4);box-shadow:0 0 0 3px rgba(4,200,255,.07);background:rgba(255,255,255,.04)}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:rgba(230,230,240,.2)}
.form-note{font-size:.74rem;color:rgba(230,230,240,.38);margin-top:.35rem;line-height:1.6}
.form-note.success{color:#4ade80}
.form-note.error{color:#f87171}
.contact-side{display:flex;flex-direction:column;gap:2rem;padding-top:.4rem}
.contact-hours h3{font-size:.62rem;font-weight:700;letter-spacing:.26em;text-transform:uppercase;color:var(--cyan);margin-bottom:.45rem}
.contact-hours p{font-size:1.05rem;font-weight:600}
.contact-tagline{font-size:1.85rem;font-weight:800;line-height:1.05;letter-spacing:-.01em}
.contact-map{margin-top:1.4rem;border-radius:var(--r2);overflow:hidden;border:1px solid var(--bdr)}
.contact-map iframe{width:100%;height:192px;border:0;display:block}
@media(max-width:860px){.contact-inner{grid-template-columns:1fr;gap:2.5rem}}

/* ═══════════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════════ */
.site-footer{background:var(--bg);border-top:1px solid var(--bdr);padding-block:1.6rem}
.footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1.4rem}
.footer-social{display:flex;align-items:center;gap:.8rem}
.footer-icon{width:30px;height:30px;object-fit:contain;opacity:.45;transition:opacity .18s,transform .18s}
.footer-social a:hover .footer-icon{opacity:.88;transform:translateY(-2px)}
.footer-info p{font-size:.72rem;color:rgba(230,230,240,.3);text-align:right;line-height:1.7}
@media(max-width:600px){.footer-inner{flex-direction:column;align-items:flex-start}.footer-info p{text-align:left}}

/* ═══════════════════════════════════════════════════════════════
   PRICING PAGE
   ═══════════════════════════════════════════════════════════════ */
.pricing-page-body{padding-top:66px}
.pricing-hero{padding:5rem 0 2rem;text-align:center;background:var(--bg)}
.pricing-hero-kicker{margin-bottom:1rem}
.pricing-hero-title{font-size:clamp(2.2rem,6vw,4.8rem);font-weight:800;letter-spacing:-.025em;line-height:.96;color:#fff;margin-bottom:1rem}
.pricing-hero-sub{font-size:.98rem;color:var(--muted);max-width:44ch;margin-inline:auto;line-height:1.75}
.pricing-section{background:var(--bg);padding:2rem 0 5.5rem}
.pricing-grid.v2{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:3rem}
.price-card{background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--r3);padding:1.9rem 1.7rem 2.2rem;display:flex;flex-direction:column;gap:1.2rem;position:relative;transition:transform .22s var(--ease),box-shadow .22s,border-color .22s}
.price-card:hover{transform:translateY(-6px);box-shadow:var(--sh3);border-color:rgba(4,200,255,.22)}
.price-card.featured{border-color:rgba(255,255,255,.15);background:var(--bg3);transform:translateY(-8px);box-shadow:0 24px 70px rgba(0,0,0,.52)}
.price-card.featured:hover{transform:translateY(-14px);border-color:rgba(4,200,255,.38)}
.plan-badges{display:flex;gap:.5rem}
.badge{display:inline-flex;align-items:center;padding:4px 11px;border-radius:999px;font-size:.64rem;font-weight:700;letter-spacing:.08em;background:rgba(4,200,255,.1);border:1px solid rgba(4,200,255,.24);color:var(--cyan)}
.badge.ghost{background:var(--surf);border-color:var(--bdr);color:var(--muted)}
.price-title{font-size:1.45rem;font-weight:800;letter-spacing:-.01em;color:#fff}
.price-tagline{font-size:.84rem;color:var(--muted);margin-top:.2rem;line-height:1.5}
.price-list{padding:0;display:flex;flex-direction:column;gap:.52rem}
.price-list li{display:flex;align-items:flex-start;gap:.55rem;font-size:.86rem;color:rgba(230,230,240,.84);line-height:1.45}
.price-list li::before{content:'–';color:var(--cyan);font-size:.76rem;flex-shrink:0;margin-top:.1rem}
.price-outcome{font-size:.83rem;color:var(--muted);line-height:1.6;padding-top:.7rem;border-top:1px solid var(--bdr)}
.price-outcome strong{color:rgba(230,230,240,.88)}
.price-amount{font-size:2.5rem;font-weight:800;letter-spacing:-.025em;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}
.price-onceoff{font-size:.65rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--dim);margin-top:-.7rem}
.price-select{margin-top:auto}
@media(max-width:860px){.pricing-grid.v2{grid-template-columns:1fr;max-width:460px;margin-inline:auto}.price-card.featured{transform:none}}

/* ═══════════════════════════════════════════════════════════════
   ONBOARDING
   ═══════════════════════════════════════════════════════════════ */
.onboarding-page{padding-top:66px}
.onboarding-section{padding:4rem 0 6rem;background:var(--bg)}
.onboarding-container{max-width:800px}
.onboarding-title{font-size:clamp(1.75rem,4vw,2.8rem);font-weight:800;letter-spacing:-.01em;line-height:1.05;margin-bottom:.55rem;color:#fff}
.onboarding-intro{font-size:.94rem;color:var(--muted);max-width:58ch;line-height:1.8;margin-bottom:2rem}
.onboarding-form{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r3);padding:1.9rem}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.95rem 1.2rem;margin-bottom:.95rem}
.form-row{display:flex;flex-direction:column;gap:.45rem}
.form-row label{font-size:.68rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:rgba(230,230,240,.46)}
.form-row input,.form-row select,.form-row textarea{width:100%;padding:.76rem 1rem;border-radius:var(--r);border:1px solid var(--bdr);background:rgba(255,255,255,.03);color:var(--txt);font-family:inherit;font-size:.9rem;transition:border-color .18s,box-shadow .18s}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{outline:none;border-color:rgba(4,200,255,.4);box-shadow:0 0 0 3px rgba(4,200,255,.06)}
.form-row input::placeholder,.form-row textarea::placeholder{color:rgba(230,230,240,.2)}
.form-row select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='rgba(230,230,240,.35)' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.4rem}
.form-row select option{background:#0c0c1a;color:#fff}
.onboarding-submit{margin-top:1.2rem;min-width:200px}
.form-note.small{font-size:.68rem;opacity:.55}
@media(max-width:600px){.form-grid{grid-template-columns:1fr}.onboarding-form{padding:1.4rem}}

/* ═══════════════════════════════════════════════════════════════
   PORTFOLIO OVERVIEW (portfolio.html)
   ═══════════════════════════════════════════════════════════════ */
.portfolio-page-body{padding-top:66px}
/* ── portfolio / case studies page ──────────────────────────── */
.cs-page-section{background:var(--bg);min-height:100vh;padding:5rem 0 8rem}
.cs-page-title{font-size:clamp(2.8rem,7vw,6rem);font-weight:800;letter-spacing:-.035em;line-height:.94;color:#fff;margin-top:.5rem;margin-bottom:1.2rem}
.cs-page-intro{font-size:.97rem;color:var(--muted);max-width:50ch;line-height:1.8;margin-bottom:3rem}
.cs-page-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.cs-page-card{display:flex;flex-direction:column;border-radius:var(--r2);overflow:hidden;text-decoration:none;color:inherit;background:var(--bg3);border:1px solid var(--bdr);transition:transform .28s var(--ease),box-shadow .28s,border-color .28s}
.cs-page-card:hover{transform:translateY(-6px);box-shadow:var(--sh3);border-color:var(--bdr2)}
.cs-page-img{aspect-ratio:3/4;overflow:hidden;flex-shrink:0;background:#000}
.cs-page-img img{width:100%;height:100%;object-fit:cover;object-position:center;transform:scale(1.06);transition:transform .55s var(--ease);display:block}
.cs-page-card:hover .cs-page-img img{transform:scale(1.11)}
.cs-page-meta{padding:1.2rem 1.3rem 1.6rem}
.cs-page-tag{font-size:.58rem;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--cyan);display:block;margin-bottom:.5rem}
.cs-page-name{font-size:1.1rem;font-weight:800;color:#fff;margin-bottom:.45rem;letter-spacing:-.015em}
.cs-page-desc{font-size:.84rem;color:var(--muted);line-height:1.7}
@media(max-width:860px){.cs-page-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.cs-page-grid{grid-template-columns:1fr}}

/* ═══════════════════════════════════════════════════════════════
   CASE STUDY SHELL
   ═══════════════════════════════════════════════════════════════ */
.case-page-body{background:#000;color:#fff;padding-top:66px}
.case-wrap{width:min(1180px,92vw);margin-inline:auto}
.case-hero{padding:5rem 0 3.5rem}
.case-kicker{margin-bottom:1rem}
.case-title{font-size:clamp(2.4rem,6.5vw,5.8rem);font-weight:800;letter-spacing:-.035em;line-height:.94;color:#fff;margin-bottom:1.25rem}
.case-intro{font-size:1rem;color:rgba(255,255,255,.6);max-width:56ch;line-height:1.82;margin-bottom:2.4rem}
.case-meta-strip{display:flex;border:1px solid rgba(255,255,255,.1);border-radius:var(--r2);overflow:hidden;max-width:680px;background:rgba(255,255,255,.025)}
.case-meta-item{flex:1;padding:.95rem 1.2rem;border-right:1px solid rgba(255,255,255,.1)}
.case-meta-item:last-child{border-right:0}
.case-meta-label{font-size:.6rem;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--cyan);display:block;margin-bottom:3px}
.case-meta-value{font-size:.88rem;font-weight:700;color:#fff}
/* Three pillars */
.case-trio{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08);border-radius:var(--r3);overflow:hidden;margin:3.5rem 0}
.case-trio-panel{background:#000;padding:2rem 1.75rem;position:relative}
.case-trio-panel::before{content:'';position:absolute;top:0;left:0;width:100%;height:2px;background:var(--grad);opacity:0;transition:opacity .25s}
.case-trio-panel:hover::before{opacity:1}
.case-trio-num{font-size:.58rem;font-weight:700;letter-spacing:.26em;text-transform:uppercase;color:var(--cyan);display:block;margin-bottom:.7rem}
.case-trio-panel h3{font-size:.8rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#fff;margin-bottom:.7rem}
.case-trio-panel p{font-size:.88rem;color:rgba(255,255,255,.58);line-height:1.8;max-width:none}
@media(max-width:700px){.case-trio{grid-template-columns:1fr}.case-meta-strip{flex-direction:column}.case-meta-item{border-right:0;border-bottom:1px solid rgba(255,255,255,.1)}.case-meta-item:last-child{border-bottom:0}}
/* Media grid */
.case-media-section{padding:2rem 0 5rem}
.case-media-grid{display:grid;grid-template-columns:1.35fr .88fr;gap:1.2rem;align-items:start}
.case-img-card{border-radius:var(--r2);overflow:hidden;border:1px solid rgba(255,255,255,.09);background:rgba(255,255,255,.03)}
.case-img-card img{width:100%;height:auto;display:block}
.case-img-stack{display:flex;flex-direction:column;gap:1.2rem}
@media(max-width:860px){.case-media-grid{grid-template-columns:1fr}}
/* Content blocks */
.case-content{padding:0 0 6rem}
.case-block{border:1px solid rgba(255,255,255,.08);border-radius:var(--r2);padding:1.65rem;background:rgba(255,255,255,.02);transition:border-color .22s}
.case-block:hover{border-color:rgba(255,255,255,.15)}
.case-block-label{font-size:.6rem;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--cyan);display:block;margin-bottom:.55rem}
.case-block h2{font-size:.95rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:#fff;margin-bottom:.55rem}
.case-block p{font-size:.88rem;color:rgba(255,255,255,.58);line-height:1.8;max-width:none}
.case-3col{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.case-2col{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
@media(max-width:720px){.case-3col,.case-2col{grid-template-columns:1fr}}
.case-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin:2.5rem 0}
.case-gallery img{width:100%;border-radius:var(--r2);border:1px solid rgba(255,255,255,.08);display:block}
@media(max-width:700px){.case-gallery{grid-template-columns:1fr}}
/* More projects */
.case-more{padding:5rem 0 7rem;border-top:1px solid rgba(255,255,255,.08)}
.case-more-title{font-size:clamp(1.4rem,3vw,2.4rem);font-weight:800;letter-spacing:-.01em;margin-bottom:1.65rem}
.more-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.more-card{display:block;border-radius:var(--r2);overflow:hidden;text-decoration:none;color:#fff;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);transition:transform .22s var(--ease),box-shadow .22s}
.more-card:hover{transform:translateY(-4px);box-shadow:var(--sh2)}
.more-thumb{aspect-ratio:16/9;overflow:hidden}
.more-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.more-card:hover .more-thumb img{transform:scale(1.05)}
.more-copy{padding:.95rem 1.05rem}
.more-type{font-size:.6rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--cyan);display:block;margin-bottom:.28rem}
.more-name{font-size:.95rem;font-weight:800}
.more-desc{font-size:.8rem;color:rgba(255,255,255,.52);margin-top:.22rem}
@media(max-width:700px){.more-grid{grid-template-columns:1fr}}

/* ═══════════════════════════════════════════════════════════════
   ABOUT DECK
   ═══════════════════════════════════════════════════════════════ */
.aboutBookSection{background:var(--bg);padding:5rem 0}
.aboutBook{display:flex;align-items:center;justify-content:center;gap:1.2rem}
.aboutBook__nav{width:44px;height:44px;border-radius:12px;border:1px solid var(--bdr2);background:var(--surf);color:#fff;font-size:24px;display:grid;place-items:center;flex-shrink:0;transition:background .18s,border-color .18s}
.aboutBook__nav:hover{background:var(--surf2)}
.aboutBook__stage{width:min(520px,92vw);height:520px;perspective:1400px}
.aboutBook__stack{position:relative;width:100%;height:100%;transform-style:preserve-3d}
.aboutBook__page{position:absolute;inset:0;transform-origin:left center;backface-visibility:hidden;transform:rotateY(180deg);opacity:0;pointer-events:none;transition:transform 650ms cubic-bezier(.2,.8,.2,1),opacity 200ms ease}
.aboutBook__page.is-active{transform:rotateY(0deg);opacity:1;pointer-events:auto}
.aboutBook__page.is-prev{transform:rotateY(-180deg);opacity:0}
.aboutCard{width:100%;height:100%;border-radius:28px;padding:34px 28px;box-shadow:0 30px 70px rgba(0,0,0,.45);text-align:center;display:grid;align-content:start;gap:18px}
.aboutCard__title{letter-spacing:.14em;font-weight:900;margin:0 0 18px;font-size:clamp(16px,2vw,22px)}
.aboutCard__p{opacity:.92;line-height:1.55;margin:0 0 18px;font-size:clamp(13px,1.1vw,15px)}
.aboutCard__micro{font-weight:900;margin:8px 0 0;font-size:clamp(14px,1.2vw,17px)}
.aboutCard--1{background:linear-gradient(135deg,rgba(59,130,246,.92),rgba(147,51,234,.92));color:#fff}
.aboutCard--2{background:linear-gradient(135deg,rgba(59,130,246,.88),rgba(99,102,241,.92));color:#fff}
.aboutCard--3{background:linear-gradient(135deg,rgba(99,102,241,.88),rgba(147,51,234,.92));color:#fff}
.aboutCard--4{background:linear-gradient(135deg,rgba(59,130,246,.92),rgba(99,102,241,.92),rgba(147,51,234,.92));color:#fff}
.aboutBook__hint{text-align:center;opacity:.45;margin-top:14px;font-size:.68rem;letter-spacing:.18em;text-transform:uppercase}
@media(max-width:600px){.aboutBook__nav{display:none}.aboutBook__stage{width:min(400px,92vw);height:500px}}

/* ═══════════════════════════════════════════════════════════════
   FOFO WELLNESS CASE (legacy template)
   ═══════════════════════════════════════════════════════════════ */
.fofo-wellness-case{background:#000;color:#fff}
.fw-wrap{width:min(1240px,92vw);margin:0 auto}
.fw-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:44px;align-items:start}
.fw-hero{padding:120px 0 50px}
.fw-section{padding:40px 0}
.fw-last{padding-bottom:100px}
.fofo-wellness-case h1,.fofo-wellness-case h2{margin:0 0 12px}
.fw-title{font-size:22px;font-weight:800}
.fofo-wellness-case h2{font-size:16px;font-weight:800}
.fofo-wellness-case p{margin:0 0 12px;line-height:1.7;opacity:.86;max-width:none}
.fw-meta{max-width:340px;padding:0;margin-top:14px}
.fw-meta-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.fw-meta-row:last-child{border-bottom:none}
.fofo-wellness-case dt{font-size:12px;opacity:.72}
.fofo-wellness-case dd{margin:0;font-size:12px;font-weight:700}
.fw-card{border-radius:22px;overflow:hidden;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);display:flex;align-items:center;justify-content:center}
.fw-card img{width:100%;height:100%;object-fit:cover;display:block}
.fw-grid-2x2{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.fw-grid-2x2 .fw-card{aspect-ratio:1/1;background:transparent}
.fw-swatches{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:18px}
.fw-swatch{height:200px;border-radius:28px;background:var(--sw);border:1px solid rgba(255,255,255,.1)}
.fw-swatch-label{text-align:center;margin-top:10px;font-size:12px;opacity:.65}
@media(max-width:960px){.fw-grid{grid-template-columns:1fr;gap:18px}.fw-swatches{grid-template-columns:repeat(2,1fr)}}

/* ═══════════════════════════════════════════════════════════════
   PREMIUM CASE STUDY — editorial upgrade layer
   ═══════════════════════════════════════════════════════════════ */

/* ── upgraded hero ─────────────────────────────────────────── */
.cs-hero{padding:5.5rem 0 0;position:relative}
.cs-breadcrumb{font-size:.6rem;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:rgba(255,255,255,.32);margin-bottom:1.8rem;display:flex;align-items:center;gap:.5rem}
.cs-breadcrumb a{color:rgba(255,255,255,.32);transition:color .18s}.cs-breadcrumb a:hover{color:var(--cyan)}
.cs-breadcrumb span{color:rgba(255,255,255,.18)}
.cs-overline{font-size:.62rem;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:var(--cyan);display:flex;align-items:center;gap:.8rem;margin-bottom:1.2rem}
.cs-overline::before{content:'';display:block;width:32px;height:1px;background:var(--cyan);flex-shrink:0}
.cs-display-title{font-size:clamp(3.5rem,10vw,8rem);font-weight:800;line-height:.92;letter-spacing:-.04em;color:#fff;margin-bottom:1.6rem}
.cs-display-title em{font-style:normal;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.cs-lead{font-size:clamp(.95rem,1.5vw,1.1rem);color:rgba(255,255,255,.55);max-width:52ch;line-height:1.85;margin-bottom:3rem}

/* ── wide metadata bar ─────────────────────────────────────── */
.cs-meta-bar{display:grid;grid-template-columns:repeat(5,1fr);border:1px solid rgba(255,255,255,.1);border-radius:var(--r2);overflow:hidden;background:rgba(255,255,255,.02);margin-bottom:4rem}
.cs-meta-cell{padding:1.1rem 1.4rem;border-right:1px solid rgba(255,255,255,.08);position:relative}
.cs-meta-cell:last-child{border-right:0}
.cs-meta-cell::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--grad);transition:width .4s var(--ease)}
.cs-meta-cell:hover::after{width:100%}
.cs-meta-key{font-size:.56rem;font-weight:700;letter-spacing:.26em;text-transform:uppercase;color:var(--cyan);display:block;margin-bottom:.35rem}
.cs-meta-val{font-size:.86rem;font-weight:700;color:#fff;line-height:1.3}
@media(max-width:860px){.cs-meta-bar{grid-template-columns:repeat(3,1fr)}.cs-meta-cell:nth-child(3){border-right:0}.cs-meta-cell:nth-child(4),.cs-meta-cell:nth-child(5){border-top:1px solid rgba(255,255,255,.08)}}
@media(max-width:540px){.cs-meta-bar{grid-template-columns:1fr 1fr}.cs-meta-cell{border-right:1px solid rgba(255,255,255,.08)}.cs-meta-cell:nth-child(2n){border-right:0}.cs-meta-cell:nth-child(n+3){border-top:1px solid rgba(255,255,255,.08)}}

/* ── SVG showcase / hero visual ────────────────────────────── */
.cs-svg-block{width:100%;border-radius:var(--r3);overflow:hidden;border:1px solid rgba(255,255,255,.08);background:#080810;margin-bottom:5rem;position:relative}
.cs-svg-block img,.cs-svg-block object{width:100%;height:auto;display:block}
.cs-svg-block::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 20% 80%,rgba(4,200,255,.06),transparent 60%),radial-gradient(circle at 80% 20%,rgba(196,0,255,.05),transparent 60%);pointer-events:none;z-index:1}

/* ── oversized full-width visual ───────────────────────────── */
.cs-full-visual{width:100%;margin:4rem 0;border-radius:var(--r3);overflow:hidden;border:1px solid rgba(255,255,255,.08)}
.cs-full-visual img{width:100%;height:auto;display:block}

/* ── chapter dividers ──────────────────────────────────────── */
.cs-chapter{display:flex;align-items:center;gap:1.2rem;margin:5rem 0 2.5rem}
.cs-chapter-num{font-size:.58rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--cyan);white-space:nowrap}
.cs-chapter-label{font-size:clamp(1.1rem,2.4vw,1.7rem);font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:#fff}
.cs-chapter::after{content:'';flex:1;height:1px;background:rgba(255,255,255,.08)}

/* ── zoom-hover images ─────────────────────────────────────── */
.cs-zoom{display:block;overflow:hidden;border-radius:var(--r2);border:1px solid rgba(255,255,255,.08);cursor:zoom-in;position:relative}
.cs-zoom img{width:100%;height:auto;display:block;transition:transform .55s var(--ease)}
.cs-zoom:hover img{transform:scale(1.04)}
/* logo-on-black images: dissolve black bg with screen blend */
.cs-split img[src*="logoclean"]{mix-blend-mode:screen}
/* images with white canvas edges: clip via overflow+scale */
.cs-full-visual{overflow:hidden}
.cs-full-visual img{transform:scale(1.05);transform-origin:center}
.case-gallery a{display:block;overflow:hidden;border-radius:var(--r2)}
.case-gallery img{width:100%;border-radius:0;border:none;display:block;transform:scale(1.05);transform-origin:center}
.cs-zoom:hover img{transform:scale(1.04)}
.cs-zoom::after{content:'⤢';position:absolute;bottom:.7rem;right:.85rem;font-size:.75rem;color:rgba(255,255,255,.4);opacity:0;transition:opacity .2s;pointer-events:none}
.cs-zoom:hover::after{opacity:1}

/* upgrade existing image cards to zoom */
.case-img-card{cursor:zoom-in}
.case-img-card img{transition:transform .55s var(--ease)}
.case-img-card:hover img{transform:scale(1.04)}
.case-gallery a{display:block;border-radius:var(--r2);overflow:hidden;border:1px solid rgba(255,255,255,.08);cursor:zoom-in}
.case-gallery a img{width:100%;display:block;transition:transform .55s var(--ease)}
.case-gallery a:hover img{transform:scale(1.04)}

/* ── split editorial row ───────────────────────────────────── */
.cs-split{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin:4rem 0;align-items:start}
.cs-split--60-40{grid-template-columns:1.4fr 1fr}
.cs-split--40-60{grid-template-columns:1fr 1.4fr}
@media(max-width:800px){.cs-split,.cs-split--60-40,.cs-split--40-60{grid-template-columns:1fr}}
.cs-split-text{display:flex;flex-direction:column;justify-content:center;padding:.5rem 0}
.cs-split-text .cs-chapter-label{font-size:1.2rem;margin-bottom:.9rem}
.cs-split-text p{font-size:.92rem;color:rgba(255,255,255,.58);line-height:1.85;margin-bottom:.9rem}
.cs-split-text p:last-child{margin-bottom:0}

/* ── tall masonry image pair ───────────────────────────────── */
.cs-pair{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin:2.5rem 0;align-items:start}
.cs-pair .cs-zoom:first-child{margin-top:2.5rem}
@media(max-width:640px){.cs-pair{grid-template-columns:1fr}.cs-pair .cs-zoom:first-child{margin-top:0}}

/* ── stat strip ────────────────────────────────────────────── */
.cs-stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.07);border-radius:var(--r2);overflow:hidden;margin:4rem 0}
.cs-stat-cell{background:#000;padding:2rem 1.75rem;text-align:center}
.cs-stat-num{font-size:clamp(2.2rem,5vw,3.8rem);font-weight:800;letter-spacing:-.04em;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:.4rem}
.cs-stat-label{font-size:.62rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.4)}
@media(max-width:600px){.cs-stat-row{grid-template-columns:1fr}}

/* ── lightbox ──────────────────────────────────────────────── */
.cs-lb{position:fixed;inset:0;z-index:9000;background:rgba(0,0,0,.95);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .28s var(--ease);padding:1.5rem}
.cs-lb.open{opacity:1;pointer-events:auto}
.cs-lb-img{max-width:min(1000px,96vw);max-height:90svh;object-fit:contain;border-radius:var(--r2);box-shadow:var(--sh3);transform:scale(.94);transition:transform .32s var(--ease)}
.cs-lb.open .cs-lb-img{transform:scale(1)}
.cs-lb-close{position:absolute;top:1.2rem;right:1.4rem;width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:50%;color:#fff;font-size:1.1rem;cursor:pointer;transition:background .18s}
.cs-lb-close:hover{background:rgba(255,255,255,.16)}
.cs-lb-caption{position:absolute;bottom:1.6rem;left:50%;transform:translateX(-50%);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.4);white-space:nowrap}

/* ── CTA block ─────────────────────────────────────────────── */
.cs-cta{padding:7rem 0;position:relative;overflow:hidden;border-top:1px solid rgba(255,255,255,.07)}
.cs-cta::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 50%,rgba(4,200,255,.06),transparent 70%);pointer-events:none}
.cs-cta-inner{text-align:center;position:relative;z-index:1}
.cs-cta-label{font-size:.62rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--cyan);margin-bottom:1.2rem;display:block}
.cs-cta-heading{font-size:clamp(2rem,6vw,5rem);font-weight:800;letter-spacing:-.04em;line-height:.95;color:#fff;margin-bottom:1.4rem}
.cs-cta-heading em{font-style:normal;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.cs-cta-sub{font-size:.95rem;color:rgba(255,255,255,.44);max-width:44ch;margin:0 auto 2.5rem;line-height:1.8}
.cs-cta-actions{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap}

/* ── "more projects" premium ───────────────────────────────── */
.cs-more-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:2rem}
.cs-more-header h2{font-size:clamp(1.4rem,3vw,2.2rem);font-weight:800;letter-spacing:-.02em}
.cs-more-header a{font-size:.65rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--cyan);transition:opacity .18s}.cs-more-header a:hover{opacity:.7}

/* ═══════════════════════════════════════════════════════════════
   ACCESSIBILITY
   ═══════════════════════════════════════════════════════════════ */
:focus-visible{outline:2px solid var(--cyan);outline-offset:3px;border-radius:4px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
