/* Drona VR — Production Styles
 * v1.0  •  May 2026
 * Brand-locked CSS extracted from approved templates
 */

:root{
  --red:#E10726; --red-bright:#FF1F3D; --red-glow:rgba(225,7,38,0.5); --red-deep:#B5051E;
  --black:#000; --black-2:#06060A; --black-3:#0C0C12; --black-4:#13131A;
  --line:rgba(255,255,255,0.08); --line-2:rgba(255,255,255,0.14);
  --white:#FFF; --white-90:rgba(255,255,255,0.92); --white-70:rgba(255,255,255,0.72);
  --white-50:rgba(255,255,255,0.5); --white-30:rgba(255,255,255,0.32);
  --green:#2E7D5C; --amber:#F2A100;
  --content-max:1340px; --gutter:28px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:'IBM Plex Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',Arial,sans-serif;color:var(--white-90);background:var(--black);line-height:1.55;font-size:17px;overflow-x:hidden;cursor:none}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
::selection{background:var(--red);color:#fff}

/* Global scanline overlay */
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:5;opacity:.06;background:repeating-linear-gradient(180deg,transparent 0,transparent 2px,#fff 2px,#fff 3px);mix-blend-mode:overlay}

/* Custom red cursor */
.cursor-dot,.cursor-ring{position:fixed;pointer-events:none;z-index:9999;border-radius:50%;transform:translate(-50%,-50%);transition:transform .15s ease-out,width .2s,height .2s,opacity .2s;mix-blend-mode:difference}
.cursor-dot{width:8px;height:8px;background:var(--red-bright)}
.cursor-ring{width:36px;height:36px;border:1px solid rgba(255,255,255,.5)}
body.has-touch{cursor:auto}
body.has-touch .cursor-dot,body.has-touch .cursor-ring{display:none}
a,button,.module-card,.industry-card,.kf-card,.compliance-tile,.shot,.post-card,.toc a,.region-card,.feat-card,.way-card,.tl-step,.faq,.promise-item,.compliance-tile,.industry-pill,.lang-pill,.priority-card,.contact-card,.shot-card,.outcome-card,.truth-card,.pillar,.buyer-quote,.case-shot,.takeaway,.related-card,.hw-card,.arch-card,.flow-step,.usecase,.status-bar,.obj,.spec-row-detail,.geo-select{cursor:none!important}

/* Topbar */
.topbar{background:var(--black);color:var(--white-50);font-size:12px;padding:10px 0;border-bottom:1px solid var(--line);position:relative;z-index:100;letter-spacing:.02em}
.topbar-inner{max-width:var(--content-max);margin:0 auto;padding:0 var(--gutter);display:flex;justify-content:space-between;align-items:center;gap:16px}
.topbar a{color:var(--white-70);text-decoration:none}
.topbar a:hover{color:var(--white-90)}
.topbar-right{display:flex;gap:18px;align-items:center}
.geo-select{background:transparent;color:var(--white-70);border:1px solid var(--line-2);padding:5px 14px 5px 12px;border-radius:2px;font-size:12px;font-family:inherit;text-transform:uppercase;letter-spacing:.05em;cursor:pointer}
.topbar-pulse{display:inline-flex;align-items:center;gap:8px}
.topbar-pulse::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--red);box-shadow:0 0 0 0 var(--red-glow);animation:pulse 2.4s infinite}

@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(225,7,38,.7)}70%{box-shadow:0 0 0 10px rgba(225,7,38,0)}100%{box-shadow:0 0 0 0 rgba(225,7,38,0)}}

/* Header */
.header{position:sticky;top:0;z-index:50;background:rgba(0,0,0,.78);backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid var(--line)}
.header-inner{max-width:var(--content-max);margin:0 auto;padding:16px var(--gutter);display:flex;align-items:center;justify-content:space-between;gap:32px}
.logo-img{height:40px;width:auto;filter:drop-shadow(0 0 14px rgba(225,7,38,.45));transition:filter .25s,transform .25s}
.logo-img:hover{filter:drop-shadow(0 0 22px rgba(225,7,38,.8));transform:scale(1.03)}
.nav{display:flex;gap:32px}
.nav a{color:var(--white-90);font-weight:500;font-size:14px;padding:10px 0;letter-spacing:.01em;transition:color .2s;position:relative}
.nav a:hover,.nav a.active{color:var(--red)}
.nav a::after{content:'';position:absolute;left:0;right:0;bottom:4px;height:1px;background:var(--red);transform:scaleX(0);transform-origin:right;transition:transform .3s cubic-bezier(.65,0,.35,1)}
.nav a:hover::after,.nav a.active::after{transform:scaleX(1);transform-origin:left}
.header-cta{display:flex;gap:12px;align-items:center}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 24px;font-weight:600;font-size:14px;border-radius:3px;letter-spacing:.02em;transition:all .25s cubic-bezier(.65,0,.35,1);border:1px solid transparent;cursor:pointer;font-family:inherit;text-transform:uppercase;position:relative;overflow:hidden;text-decoration:none}
.btn-primary{background:var(--red);color:#fff}
.btn-primary::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent);transition:left .6s}
.btn-primary:hover::before{left:100%}
.btn-primary:hover{background:var(--red-deep);box-shadow:0 8px 32px var(--red-glow),0 0 0 1px var(--red);transform:translateY(-1px)}
.btn-outline{background:transparent;color:#fff;border-color:var(--line-2)}
.btn-outline:hover{border-color:var(--red);color:var(--red);box-shadow:0 0 24px rgba(225,7,38,.3)}
.btn-large{padding:18px 34px;font-size:15px}
.btn-small{padding:9px 16px;font-size:12px}

/* Breadcrumb */
.breadcrumb{padding:18px var(--gutter);font-size:13px;color:var(--white-50);border-bottom:1px solid var(--line);background:var(--black-2)}
.breadcrumb-inner{max-width:var(--content-max);margin:0 auto;display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.breadcrumb a{color:var(--white-70);transition:color .15s}
.breadcrumb a:hover{color:var(--red)}
.breadcrumb .sep{color:var(--white-30)}
.breadcrumb .current{color:#fff}

/* Section framework */
section.frame{padding:120px var(--gutter);border-top:1px solid var(--line);position:relative;overflow:hidden}
section.frame.alt{background:linear-gradient(180deg,var(--black) 0%,var(--black-3) 50%,var(--black) 100%)}
section.frame.compact{padding:80px var(--gutter)}
.frame-inner{max-width:var(--content-max);margin:0 auto;position:relative}

/* Reveal animations */
.reveal{opacity:0;transform:translateY(40px);transition:all 1s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-stagger>*{opacity:0;transform:translateY(40px);transition:all 1s cubic-bezier(.16,1,.3,1)}
.reveal-stagger.in>*:nth-child(1){opacity:1;transform:translateY(0);transition-delay:0s}
.reveal-stagger.in>*:nth-child(2){opacity:1;transform:translateY(0);transition-delay:.08s}
.reveal-stagger.in>*:nth-child(3){opacity:1;transform:translateY(0);transition-delay:.16s}
.reveal-stagger.in>*:nth-child(4){opacity:1;transform:translateY(0);transition-delay:.24s}
.reveal-stagger.in>*:nth-child(5){opacity:1;transform:translateY(0);transition-delay:.32s}
.reveal-stagger.in>*:nth-child(6){opacity:1;transform:translateY(0);transition-delay:.40s}
.reveal-stagger.in>*:nth-child(n+7){opacity:1;transform:translateY(0);transition-delay:.48s}

/* Section eyebrow + headings */
.section-eyebrow{display:inline-flex;align-items:center;gap:10px;color:var(--red);font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;margin-bottom:24px}
.section-eyebrow::before{content:'';width:28px;height:1px;background:var(--red);box-shadow:0 0 8px var(--red)}
.section-h2{font-size:clamp(34px,4.6vw,56px);font-weight:700;line-height:1.05;letter-spacing:-.025em;color:#fff;margin-bottom:24px;max-width:1000px}
.section-h2 .accent{color:var(--red);background:linear-gradient(180deg,#ff2a4a 0%,var(--red) 80%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.section-lede{font-size:19px;color:var(--white-70);max-width:760px;margin-bottom:56px;line-height:1.55}

/* Hero base (used by templates) */
.hero{position:relative;padding:80px var(--gutter);overflow:hidden;border-bottom:1px solid var(--line)}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 50% at 75% 30%,rgba(225,7,38,.18) 0%,transparent 60%),radial-gradient(ellipse 60% 50% at 10% 80%,rgba(225,7,38,.06) 0%,transparent 60%);pointer-events:none}
.hero::after{content:'';position:absolute;inset:0;background-image:linear-gradient(to right,rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(to bottom,rgba(255,255,255,.04) 1px,transparent 1px);background-size:80px 80px;mask-image:radial-gradient(ellipse 80% 50% at 50% 50%,black 30%,transparent 80%);-webkit-mask-image:radial-gradient(ellipse 80% 50% at 50% 50%,black 30%,transparent 80%);opacity:.5;pointer-events:none}
.hero-inner{position:relative;z-index:2;max-width:var(--content-max);margin:0 auto;display:grid;grid-template-columns:1.1fr 1fr;gap:56px;align-items:center}
.hero-tag{display:inline-flex;align-items:center;gap:12px;padding:7px 16px 7px 12px;border:1px solid var(--line-2);border-radius:100px;background:rgba(255,255,255,.04);backdrop-filter:blur(8px);font-size:12px;font-weight:500;color:var(--white-70);letter-spacing:.06em;text-transform:uppercase;margin-bottom:32px}
.hero-tag::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--red);box-shadow:0 0 12px var(--red);animation:pulse 2.4s infinite}
.hero h1{font-size:clamp(40px,6vw,80px);font-weight:700;line-height:1;letter-spacing:-.03em;color:#fff;margin-bottom:28px}
.hero h1 .accent{color:var(--red);background:linear-gradient(180deg,#ff2a4a 0%,var(--red) 80%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-style:italic;font-weight:600}
.hero p.lede{font-size:20px;color:var(--white-70);line-height:1.5;margin-bottom:36px;max-width:600px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:40px}
.hero-stats{display:flex;gap:32px;flex-wrap:wrap;padding-top:28px;border-top:1px solid var(--line);max-width:680px}
.hero-stat{display:flex;flex-direction:column;gap:4px}
.hero-stat .num{font-family:'IBM Plex Mono',monospace;font-size:26px;font-weight:500;color:#fff;letter-spacing:-.02em;line-height:1}
.hero-stat .label{font-size:11px;color:var(--white-50);text-transform:uppercase;letter-spacing:.10em}
.hero-visual{position:relative;aspect-ratio:4/3;border-radius:12px;overflow:hidden;border:1px solid var(--line);box-shadow:0 30px 80px rgba(0,0,0,.6),0 0 60px rgba(225,7,38,.18)}
.hero-visual img{width:100%;height:100%;object-fit:cover;filter:contrast(1.05) saturate(1.05)}
.hero-visual::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(225,7,38,.18) 0%,transparent 40%,transparent 60%,rgba(0,0,0,.5) 100%);z-index:2;pointer-events:none}
.hero-visual-tag{position:absolute;left:24px;bottom:24px;z-index:3;display:flex;align-items:center;gap:10px;padding:10px 16px;background:rgba(0,0,0,.7);backdrop-filter:blur(12px);border:1px solid var(--line-2);border-radius:100px;font-size:12px;font-weight:500;color:var(--white-90);letter-spacing:.04em}
.hero-visual-tag::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 10px var(--red);animation:pulse 2.4s infinite}

/* Truth/Problem cards (used on industry, feature, solution pages) */
.truth-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:32px}
.truth-card{background:linear-gradient(180deg,var(--black-3) 0%,var(--black-2) 100%);border:1px solid var(--line);border-radius:8px;padding:36px 32px;transition:all .35s}
.truth-card:hover{border-color:var(--line-2);transform:translateY(-3px)}
.truth-num{font-family:'IBM Plex Mono',monospace;color:var(--red);font-size:13px;font-weight:500;letter-spacing:.08em;margin-bottom:18px}
.truth-card h3{font-size:22px;font-weight:600;color:#fff;line-height:1.25;margin-bottom:12px;letter-spacing:-.01em}
.truth-card p{color:var(--white-70);font-size:15px;line-height:1.6}

/* Pillar cards (homepage) */
.pillar-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.pillar{position:relative;background:linear-gradient(180deg,var(--black-3) 0%,var(--black-2) 100%);border:1px solid var(--line);border-radius:8px;padding:44px 36px 36px;transition:all .35s cubic-bezier(.65,0,.35,1);overflow:hidden;transform-style:preserve-3d}
.pillar::before{content:'';position:absolute;top:0;left:0;width:100%;height:1px;background:linear-gradient(90deg,transparent,var(--red),transparent);opacity:0;transition:opacity .35s}
.pillar:hover{border-color:var(--line-2);transform:translateY(-4px)}
.pillar:hover::before{opacity:1}
.pillar-num{font-family:'IBM Plex Mono',monospace;color:var(--red);font-size:13px;font-weight:500;letter-spacing:.08em;margin-bottom:24px}
.pillar h3{font-size:26px;font-weight:600;margin-bottom:14px;line-height:1.2;color:#fff;letter-spacing:-.015em}
.pillar p{color:var(--white-70);font-size:16px;line-height:1.6}

/* Killer feature triad (homepage) */
.kf-section{padding:120px var(--gutter);background:linear-gradient(180deg,var(--black) 0%,var(--black-3) 50%,var(--black) 100%);border-top:1px solid var(--line);position:relative;overflow:hidden}
.kf-section::before{content:'';position:absolute;width:600px;height:600px;left:-200px;top:50%;transform:translateY(-50%);background:radial-gradient(circle,rgba(225,7,38,.10) 0%,transparent 60%);filter:blur(60px);pointer-events:none}
.kf-section::after{content:'';position:absolute;width:500px;height:500px;right:-150px;bottom:-100px;background:radial-gradient(circle,rgba(225,7,38,.08) 0%,transparent 60%);filter:blur(60px);pointer-events:none}
.kf-inner{max-width:var(--content-max);margin:0 auto;position:relative;z-index:1}
.kf-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
.kf-card{position:relative;background:linear-gradient(180deg,rgba(255,255,255,.04) 0%,rgba(255,255,255,.01) 100%);border:1px solid var(--line);border-radius:12px;padding:40px 32px;overflow:hidden;transition:all .35s cubic-bezier(.65,0,.35,1);min-height:380px;display:flex;flex-direction:column;backdrop-filter:blur(8px)}
.kf-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--red),transparent);opacity:0;transition:opacity .3s}
.kf-card:hover{border-color:var(--red);transform:translateY(-4px);box-shadow:0 20px 50px rgba(225,7,38,.18)}
.kf-card:hover::before{opacity:1}
.kf-icon{width:64px;height:64px;border-radius:14px;background:linear-gradient(135deg,rgba(225,7,38,.20) 0%,rgba(225,7,38,.04) 100%);border:1px solid rgba(225,7,38,.4);display:flex;align-items:center;justify-content:center;margin-bottom:24px;color:var(--red);position:relative;z-index:1}
.kf-icon svg{width:32px;height:32px;stroke:var(--red);stroke-width:1.6;fill:none;stroke-linecap:round;stroke-linejoin:round}
.kf-tag{display:inline-block;font-family:'IBM Plex Mono',monospace;color:var(--red);font-size:12px;letter-spacing:.08em;margin-bottom:12px;font-weight:500;text-transform:uppercase}
.kf-card h3{font-size:26px;font-weight:600;line-height:1.2;color:#fff;letter-spacing:-.015em;margin-bottom:16px;position:relative;z-index:1}
.kf-card p{font-size:16px;color:var(--white-70);line-height:1.6;margin-bottom:auto;position:relative;z-index:1}
.kf-buyer{margin-top:24px;padding-top:20px;border-top:1px solid var(--line);font-size:12px;color:var(--white-50);letter-spacing:.04em;text-transform:uppercase;font-weight:500}
.kf-buyer strong{color:var(--red);font-weight:600}

/* Compliance band */
.compliance{background:var(--black-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:80px var(--gutter)}
.compliance-inner{max-width:var(--content-max);margin:0 auto;display:grid;grid-template-columns:1fr 2fr;gap:64px;align-items:center}
.compliance-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.compliance-tile{background:var(--black-3);border:1px solid var(--line);border-radius:6px;padding:22px;transition:all .25s;display:flex;align-items:center;gap:16px}
.compliance-tile:hover{border-color:var(--red);transform:translateY(-2px);box-shadow:0 8px 24px rgba(225,7,38,.15)}
.compliance-icon{width:42px;height:42px;border-radius:8px;background:rgba(225,7,38,.12);border:1px solid rgba(225,7,38,.3);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--red);font-family:'IBM Plex Mono',monospace;font-weight:600;font-size:11px;letter-spacing:.05em}
.compliance-info h5{font-size:15px;font-weight:600;color:#fff;margin-bottom:2px;letter-spacing:-.01em}
.compliance-info p{font-size:12px;color:var(--white-50);line-height:1.4}

/* Module cards */
.modules-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:32px}
.module-card{border:1px solid var(--line);border-radius:8px;overflow:hidden;background:var(--black-3);transition:all .35s cubic-bezier(.65,0,.35,1);display:flex;flex-direction:column;text-decoration:none}
.module-card:hover{border-color:var(--red);transform:translateY(-4px);box-shadow:0 16px 40px rgba(225,7,38,.2)}
.module-card .thumb{aspect-ratio:4/3;overflow:hidden;border-bottom:1px solid var(--line);position:relative;background:linear-gradient(135deg,#18181F 0%,#06060A 100%)}
.module-card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .8s}
.module-card:hover .thumb img{transform:scale(1.06)}
.module-card .thumb::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(225,7,38,.10) 0%,transparent 50%);z-index:1;pointer-events:none}
.module-card-body{padding:20px 22px 22px}
.module-card h4{font-size:17px;font-weight:600;margin-bottom:6px;color:#fff;letter-spacing:-.01em}
.module-card .cat{color:var(--white-50);font-size:12px;letter-spacing:.04em;text-transform:uppercase}

/* Industry tile / strip */
.industry-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.industry-tile{background:var(--black-3);border:1px solid var(--line);border-radius:6px;padding:28px 26px;transition:all .25s cubic-bezier(.65,0,.35,1);position:relative;overflow:hidden;text-decoration:none}
.industry-tile::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at top right,rgba(225,7,38,.20),transparent 60%);opacity:0;transition:opacity .3s}
.industry-tile:hover{border-color:var(--red);transform:translateY(-3px);box-shadow:0 12px 32px rgba(225,7,38,.18)}
.industry-tile:hover::before{opacity:1}
.industry-tile>*{position:relative;z-index:1}
.industry-tile .icon{font-family:'IBM Plex Mono',monospace;color:var(--red);font-size:13px;font-weight:500;margin-bottom:16px;letter-spacing:.05em}
.industry-tile h4{font-size:17px;font-weight:600;margin-bottom:6px;color:#fff;letter-spacing:-.01em}
.industry-tile p{color:var(--white-50);font-size:12px;line-height:1.5}

/* Outcome cards */
.outcomes-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.outcome-card{position:relative;background:radial-gradient(ellipse at top right,rgba(225,7,38,.10) 0%,transparent 50%),var(--black-3);border:1px solid var(--line);border-radius:8px;padding:44px 40px;overflow:hidden;transition:transform .35s cubic-bezier(.65,0,.35,1),border-color .25s,box-shadow .35s}
.outcome-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--red);box-shadow:0 0 16px var(--red)}
.outcome-card:hover{transform:translateY(-3px);border-color:var(--line-2);box-shadow:0 24px 60px rgba(225,7,38,.15)}
.outcome-tag{display:inline-block;padding:5px 14px;background:rgba(225,7,38,.12);color:var(--red);font-size:11px;font-weight:600;letter-spacing:.10em;text-transform:uppercase;border-radius:100px;border:1px solid rgba(225,7,38,.3);margin-bottom:24px}
.outcome-quote{font-size:24px;font-weight:500;line-height:1.4;color:#fff;letter-spacing:-.01em;margin-bottom:28px}
.outcome-meta{color:var(--white-50);font-size:13px;padding-top:20px;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between}
.outcome-meta a{color:var(--red);transition:color .2s}
.outcome-meta a:hover{color:var(--red-bright);text-shadow:0 0 12px var(--red)}

/* Outcomes strip (4-cell) */
.outcomes-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:32px;border:1px solid var(--line);border-radius:8px;overflow:hidden}
.outcome-cell{padding:32px 28px;border-right:1px solid var(--line);background:var(--black-3);transition:background .25s}
.outcome-cell:last-child{border-right:none}
.outcome-cell:hover{background:rgba(225,7,38,.05)}
.outcome-cell .o-num{font-family:'IBM Plex Mono',monospace;font-size:42px;font-weight:500;color:var(--red);letter-spacing:-.03em;line-height:1;margin-bottom:8px}
.outcome-cell .o-label{font-size:13px;color:var(--white-70);line-height:1.4}

/* CTA band */
.cta-band{position:relative;padding:120px var(--gutter);text-align:center;overflow:hidden;background:var(--black);border-top:1px solid var(--line)}
.cta-band::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 50%,rgba(225,7,38,.30) 0%,transparent 65%);animation:glowpulse 6s ease-in-out infinite}
@keyframes glowpulse{0%,100%{opacity:.85}50%{opacity:1.15}}
.cta-band::after{content:'';position:absolute;inset:0;background-image:linear-gradient(to right,rgba(255,255,255,.06) 1px,transparent 1px),linear-gradient(to bottom,rgba(255,255,255,.06) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse 60% 70% at 50% 50%,black 0%,transparent 80%);-webkit-mask-image:radial-gradient(ellipse 60% 70% at 50% 50%,black 0%,transparent 80%);opacity:.6;pointer-events:none;animation:gridshift 20s linear infinite}
@keyframes gridshift{0%{transform:translateY(0)}100%{transform:translateY(60px)}}
.cta-band-inner{position:relative;z-index:2;max-width:920px;margin:0 auto}
.cta-band h2{font-size:clamp(34px,4.5vw,56px);font-weight:700;margin-bottom:20px;line-height:1.05;letter-spacing:-.025em;color:#fff}
.cta-band h2 .accent{color:var(--red);background:linear-gradient(180deg,#ff2a4a 0%,var(--red) 80%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.cta-band p{font-size:18px;color:var(--white-70);margin-bottom:36px}
.cta-band-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* Marquee */
.marquee{background:var(--black-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:32px 0;overflow:hidden;position:relative;z-index:4}
.marquee-eyebrow{text-align:center;color:var(--white-50);font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;margin-bottom:22px}
.marquee-track{display:flex;align-items:center;gap:64px;animation:marquee 40s linear infinite;white-space:nowrap;padding:0 var(--gutter)}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.logo-tile{height:28px;padding:0 18px;color:var(--white-30);font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;display:flex;align-items:center;transition:color .25s;flex-shrink:0}
.logo-tile:hover{color:var(--white-70)}

/* Buyer quotes */
.buyer-quotes{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:36px}
.buyer-quote{background:linear-gradient(180deg,var(--black-3) 0%,var(--black-2) 100%);border:1px solid var(--line);border-radius:8px;padding:30px 28px;transition:all .25s;position:relative}
.buyer-quote::before{content:'\201C';position:absolute;top:-10px;left:24px;font-family:Georgia,serif;color:var(--red);font-size:64px;line-height:1;font-weight:700}
.buyer-quote:hover{border-color:var(--line-2)}
.buyer-quote p{color:var(--white-90);font-size:18px;line-height:1.5;margin-bottom:16px;font-style:italic;padding-top:8px}
.buyer-quote .role{color:var(--red);font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase}

/* Footer */
.footer{background:var(--black);padding:80px var(--gutter) 32px;border-top:1px solid var(--line);color:var(--white-70);font-size:14px}
.footer-inner{max-width:var(--content-max);margin:0 auto}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr;gap:56px;margin-bottom:64px}
.footer-brand .logo-img{height:32px;margin-bottom:20px;filter:drop-shadow(0 0 12px rgba(255,255,255,.15))}
.footer-brand p{color:var(--white-50);line-height:1.5;max-width:280px}
.footer-col h5{color:#fff;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;margin-bottom:18px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col a{color:var(--white-70);transition:color .15s}
.footer-col a:hover{color:var(--red)}
.footer-bottom{border-top:1px solid var(--line);padding-top:28px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;font-size:13px;color:var(--white-50)}
.footer-bottom .legal{display:flex;gap:24px}
.footer-bottom a:hover{color:var(--red)}

/* Footer offices block */
.footer-offices{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;padding:40px 0;margin-bottom:32px;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.footer-office{padding:0}
.footer-office .office-flag{font-family:'IBM Plex Mono',monospace;color:var(--red);font-size:10px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;margin-bottom:10px}
.footer-office h5{color:#fff;font-size:15px;font-weight:600;text-transform:none;letter-spacing:-.01em;margin-bottom:10px}
.footer-office p{color:var(--white-50);font-size:13px;line-height:1.55;margin-bottom:10px}
.footer-office .office-map{color:var(--red);font-size:12px;font-weight:500;letter-spacing:.04em;display:inline-block;transition:color .2s}
.footer-office .office-map:hover{color:var(--red-bright);text-shadow:0 0 12px var(--red-glow)}
@media(max-width:1024px){.footer-offices{grid-template-columns:1fr;gap:24px}}

/* Cookie consent banner */
.cookie-banner{position:fixed;bottom:24px;left:24px;right:24px;max-width:680px;margin:0 auto;background:rgba(0,0,0,0.95);backdrop-filter:blur(20px);border:1px solid var(--red);border-radius:10px;padding:24px 28px;z-index:1000;box-shadow:0 30px 80px rgba(0,0,0,.6),0 0 60px rgba(225,7,38,.18);display:none}
.cookie-banner.show{display:block;animation:slideUp .4s ease-out}
@keyframes slideUp{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}
.cookie-banner p{color:var(--white-90);font-size:14px;line-height:1.55;margin-bottom:16px}
.cookie-banner a{color:var(--red);text-decoration:underline}
.cookie-banner .actions{display:flex;gap:10px;flex-wrap:wrap}
.cookie-banner .btn{padding:10px 20px;font-size:13px}

/* Responsive */
@media(max-width:1024px){
  body{cursor:auto}
  .cursor-dot,.cursor-ring{display:none}
  .nav{display:none}
  .hero-inner,.compliance-inner{grid-template-columns:1fr;gap:32px}
  .truth-grid,.outcomes-grid,.buyer-quotes,.kf-grid{grid-template-columns:1fr}
  .pillar-grid{grid-template-columns:1fr;gap:24px}
  .modules-grid,.industry-grid{grid-template-columns:repeat(2,1fr)}
  .compliance-grid{grid-template-columns:1fr}
  .outcomes-strip{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
}
@media(max-width:600px){
  .hero{padding:56px var(--gutter)}
  .hero-cta{flex-direction:column;align-items:stretch;width:100%}
  .btn{width:100%;justify-content:center}
  .modules-grid,.industry-grid{grid-template-columns:1fr}
  .outcomes-strip,.footer-grid{grid-template-columns:1fr}
  .hero-stats{gap:16px}
}

/* ============================================================
   HOMEPAGE — additional sections per v4 mockup
   ============================================================ */

/* See it in action — action grid */
.action-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-top: 32px;
}
@media (max-width: 900px) { .action-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .action-grid { grid-template-columns: 1fr; } }
.action-card {
  position: relative;
  display: block;
  border-radius: 14px;
  overflow: hidden;
  background: var(--surface);
  border: 1px solid var(--line);
  text-decoration: none;
  color: inherit;
  transition: transform .25s ease, border-color .25s ease;
}
.action-card:hover { transform: translateY(-3px); border-color: rgba(225,7,38,0.4); }
.action-card img {
  width: 100%;
  height: 240px;
  object-fit: cover;
  display: block;
}
.action-card .action-tag {
  position: absolute;
  top: 14px;
  left: 14px;
  padding: 5px 10px;
  border-radius: 999px;
  background: rgba(14,14,16,0.85);
  color: var(--red);
  font-family: "IBM Plex Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.action-card h4 {
  padding: 18px 20px;
  margin: 0;
  font-size: 16px;
  font-weight: 600;
  color: var(--ink);
  background: var(--surface);
}

/* Deployed in real plants — parallax band */
.parallax-band {
  padding: 80px 0;
  background: linear-gradient(180deg, var(--bg-warm, #161618) 0%, var(--bg) 100%);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.parallax-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 32px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 50px;
  align-items: center;
}
@media (max-width: 900px) { .parallax-inner { grid-template-columns: 1fr; } }
.parallax-text h2 { margin-top: 8px; }
.parallax-photos {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}
.parallax-photo {
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 18px 50px rgba(0,0,0,0.4);
}
.parallax-photo:first-child {
  grid-column: 1 / -1;
}
.parallax-photo img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  aspect-ratio: 4 / 3;
}

/* Module library — tile grid */
.module-tile-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
@media (max-width: 1000px) { .module-tile-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 700px) { .module-tile-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 460px) { .module-tile-grid { grid-template-columns: 1fr; } }
.module-tile {
  display: block;
  padding: 24px 22px;
  border-radius: 12px;
  background: var(--surface);
  border: 1px solid var(--line);
  text-decoration: none;
  color: inherit;
  transition: transform .25s ease, border-color .25s ease;
}
.module-tile:hover { transform: translateY(-2px); border-color: rgba(225,7,38,0.4); }
.module-tile-tag {
  font-family: "IBM Plex Mono", monospace;
  font-size: 11px;
  color: var(--red);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 10px;
}
.module-tile h4 {
  font-size: 16px;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 6px;
}
.module-tile p {
  font-size: 12px;
  color: var(--ink-mute);
  margin: 0;
}

/* How it works — 3-step process */
.hiw-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  margin-top: 32px;
  position: relative;
}
@media (max-width: 880px) { .hiw-grid { grid-template-columns: 1fr; } }
.hiw-step {
  padding: 32px 28px;
  border-radius: 14px;
  background: var(--surface);
  border: 1px solid var(--line);
  position: relative;
  transition: transform .25s ease, border-color .25s ease;
}
.hiw-step:hover { transform: translateY(-3px); border-color: rgba(225,7,38,0.4); }
.hiw-num {
  font-family: "IBM Plex Mono", monospace;
  font-size: 42px;
  font-weight: 700;
  color: var(--red);
  line-height: 1;
  margin-bottom: 18px;
  letter-spacing: -0.02em;
}
.hiw-step h3 {
  font-size: 19px;
  font-weight: 700;
  margin-bottom: 10px;
}
.hiw-step p {
  font-size: 14px;
  color: var(--ink-dim);
  line-height: 1.65;
  margin: 0;
}

/* Built by VB Group — heritage section */
.vb-hero-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 50px;
  align-items: center;
}
@media (max-width: 900px) { .vb-hero-grid { grid-template-columns: 1fr; } }
.vb-quote {
  margin: 24px 0;
  padding: 22px 26px;
  border-left: 4px solid var(--red);
  background: rgba(225,7,38,0.05);
  font-style: italic;
  font-size: 17px;
  line-height: 1.6;
  color: var(--ink);
  border-radius: 0 8px 8px 0;
}
.vb-photo {
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 24px 60px rgba(0,0,0,0.45);
}
.vb-photo img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  aspect-ratio: 4 / 3;
}

/* Link arrow */
.link-arrow {
  display: inline-flex;
  align-items: center;
  font-family: "IBM Plex Mono", monospace;
  font-size: 13px;
  color: var(--red);
  font-weight: 600;
  text-decoration: none;
  letter-spacing: 0.04em;
  transition: transform .15s ease;
}
.link-arrow:hover { transform: translateX(4px); }

/* Final big CTA */
.final-cta {
  padding: 100px 32px;
  background:
    radial-gradient(circle at 20% 30%, rgba(225,7,38,0.12) 0%, transparent 50%),
    radial-gradient(circle at 80% 70%, rgba(225,7,38,0.06) 0%, transparent 50%),
    var(--bg);
  border-top: 1px solid var(--line);
  text-align: center;
}
.final-cta-inner {
  max-width: 880px;
  margin: 0 auto;
}
.final-cta-h2 {
  font-size: clamp(36px, 5vw, 56px);
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin-bottom: 22px;
  font-weight: 700;
}
.final-cta-h2 .accent { color: var(--red); }
.final-cta-lede {
  font-size: 17px;
  color: var(--ink-dim);
  max-width: 640px;
  margin: 0 auto 36px;
  line-height: 1.6;
}
.final-cta-actions {
  display: flex;
  gap: 14px;
  justify-content: center;
  flex-wrap: wrap;
}

/* ============================================================
   HERO — cinematic v4 mockup treatment (calibrated to match v4)
   ============================================================ */

.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  padding: 80px 0;
  background: var(--bg);
}

.hero #hero-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  opacity: 1;
  pointer-events: none;
}

/* Grid background — v4 spec */
.hero .hero-grid {
  position: absolute;
  inset: 0;
  z-index: 1;
  background-image:
    linear-gradient(to right, rgba(255,255,255,0.05) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,0.05) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: radial-gradient(ellipse 80% 50% at 50% 50%, black 30%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse 80% 50% at 50% 50%, black 30%, transparent 80%);
  opacity: 0.6;
  pointer-events: none;
}

/* Dark gradient overlay — v4 spec (2x stronger glow) */
.hero .hero-overlay {
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    radial-gradient(ellipse 80% 60% at 75% 30%, rgba(225,7,38,0.20) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 10% 80%, rgba(225,7,38,0.08) 0%, transparent 60%),
    linear-gradient(180deg, transparent 0%, rgba(0,0,0,0.4) 100%);
  pointer-events: none;
}

.hero .hero-inner {
  position: relative;
  z-index: 10;
  max-width: 1280px;
  width: 100%;
  margin: 0 auto;
  padding: 0 32px;
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 60px;
  align-items: center;
}
@media (max-width: 980px) { .hero .hero-inner { grid-template-columns: 1fr; gap: 40px; } }

.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 7px 16px 7px 12px;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 100px;
  background: rgba(255,255,255,0.04);
  backdrop-filter: blur(8px);
  font-family: "IBM Plex Mono", monospace;
  font-size: 12px;
  font-weight: 500;
  color: rgba(255,255,255,0.7);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 32px;
  opacity: 0;
  transform: translateY(20px);
  animation: heroRise 0.8s cubic-bezier(0.65,0,0.35,1) 0.2s forwards;
}
.hero-eyebrow::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--red);
  box-shadow: 0 0 12px rgba(225,7,38,0.8);
}

.hero h1 {
  font-size: clamp(44px, 6.8vw, 92px);
  font-weight: 700;
  line-height: 0.97;
  letter-spacing: -0.035em;
  color: #fff;
  margin-bottom: 28px;
  opacity: 0;
  transform: translateY(30px);
  animation: heroRise 1s cubic-bezier(0.65,0,0.35,1) 0.4s forwards;
}
.hero h1 .accent {
  color: var(--red);
  background: linear-gradient(180deg, #ff2a4a 0%, var(--red) 80%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  font-style: italic;
  font-weight: 600;
}

.hero .lede {
  font-size: clamp(17px, 1.5vw, 19px);
  color: rgba(255,255,255,0.7);
  max-width: 600px;
  margin-bottom: 32px;
  line-height: 1.6;
  opacity: 0;
  transform: translateY(20px);
  animation: heroRise 0.9s cubic-bezier(0.65,0,0.35,1) 0.7s forwards;
}

.hero .hero-cta {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-bottom: 40px;
  opacity: 0;
  transform: translateY(20px);
  animation: heroRise 0.9s cubic-bezier(0.65,0,0.35,1) 0.85s forwards;
}

.hero-meta {
  display: flex;
  align-items: center;
  gap: 32px;
  padding-top: 28px;
  border-top: 1px solid rgba(255,255,255,0.08);
  max-width: 680px;
  flex-wrap: wrap;
  opacity: 0;
  transform: translateY(20px);
  animation: heroRise 0.9s cubic-bezier(0.65,0,0.35,1) 1s forwards;
}
.hero-meta-item { display: flex; flex-direction: column; gap: 4px; }
.hero-meta-item .num {
  font-size: 28px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: #fff;
  line-height: 1;
}
.hero-meta-item .label {
  font-size: 11px;
  color: rgba(255,255,255,0.5);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.hero-meta-divider {
  width: 1px;
  height: 36px;
  background: rgba(255,255,255,0.08);
}
@media (max-width: 540px) {
  .hero-meta { gap: 16px; }
  .hero-meta-divider { display: none; }
}

@keyframes heroRise {
  to { opacity: 1; transform: translateY(0); }
}

/* ============================================================
   HERO RIGHT — floating headset with v4-spec rings + glow
   ============================================================ */
.hero-floating {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  min-height: 620px;
  opacity: 0;
  transform: translateY(30px) scale(0.96);
  animation: heroRise 1.2s cubic-bezier(0.65,0,0.35,1) 0.5s forwards;
  perspective: 1000px;
}

/* Floating headset image — v4 drop-shadow stack (much stronger) */
.hero-floating-img {
  position: relative;
  z-index: 3;
  max-width: 100%;
  width: auto;
  height: auto;
  max-height: 520px;
  object-fit: contain;
  filter:
    drop-shadow(0 40px 80px rgba(0,0,0,0.85))
    drop-shadow(0 0 100px rgba(225,7,38,0.55))
    drop-shadow(0 0 30px rgba(225,7,38,0.4));
  animation: heroFloaty 6s ease-in-out infinite;
}

@keyframes heroFloaty {
  0%, 100% { transform: translateY(0) rotate(-1deg); }
  50%      { transform: translateY(-12px) rotate(1deg); }
}

/* Three rings — v4 spec with proper sizing/opacity/spin */
.hero-ring {
  position: absolute;
  width: 90%;
  aspect-ratio: 1;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  border: 1.5px solid rgba(225,7,38,0.4);
  border-radius: 50%;
  z-index: 1;
  animation: ringspin 24s linear infinite, ringfade 4s ease-in-out infinite;
}
.hero-ring.r2 {
  width: 75%;
  border-color: rgba(225,7,38,0.55);
  animation-duration: 18s, 3s;
  animation-delay: -8s, -1s;
}
.hero-ring.r3 {
  width: 60%;
  border: 1px dashed rgba(255,255,255,0.18);
  animation-duration: 30s, 5s;
  animation-delay: -4s, -2s;
}

@keyframes ringspin {
  0%   { transform: translate(-50%, -50%) rotate(0deg); }
  100% { transform: translate(-50%, -50%) rotate(360deg); }
}
@keyframes ringfade {
  0%, 100% { opacity: 0.4; }
  50%      { opacity: 1; }
}

/* LIVE tag */
.hero-floating .hero-tag {
  position: absolute;
  left: 50%;
  bottom: 8%;
  transform: translateX(-50%);
  z-index: 3;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 18px;
  background: rgba(0,0,0,0.65);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 100px;
  font-family: "IBM Plex Mono", monospace;
  font-size: 12px;
  font-weight: 500;
  color: rgba(255,255,255,0.9);
  letter-spacing: 0.04em;
  white-space: nowrap;
}
.hero-floating .hero-tag::before {
  content: "";
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--red);
  animation: heroLivePulse 1.8s ease-in-out infinite;
  box-shadow: 0 0 12px rgba(225,7,38,0.9);
}
@keyframes heroLivePulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.4; transform: scale(0.7); }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .hero-floating-img,
  .hero-ring,
  .hero-floating .hero-tag::before {
    animation: none !important;
  }
}
