/* ==========================================================================
   Valcke Bowling — Brand Design System
   v0.1 — implements VALCKE BOWLING BRAND GUIDELINE v1.0
   Typeface: Nexa (brand) → Poppins as licensed web fallback (FLAGGED for approval)
   ========================================================================== */

:root {
  /* Brand palette */
  --alice-blue:    #F0F5FF;
  --periwinkle:    #C7D4FF;
  --neon-blue:     #4A5CFC;   /* accent / CTA */
  --persian-blue:  #243BBD;
  --federal-blue:  #140052;   /* deep navy-purple */
  --brunswick-blue:#00457C;

  /* Semantic tokens */
  --bg:            #ffffff;
  --bg-soft:       var(--alice-blue);
  --ink:           var(--federal-blue);
  --ink-soft:      #4a4a6a;
  --on-dark:       #ffffff;
  --accent:        var(--neon-blue);

  /* Core gradient (deep blue → purple, brand signature) */
  --grad-deep:  linear-gradient(135deg, #1a1370 0%, var(--federal-blue) 45%, #0c0238 100%);
  --grad-vivid: linear-gradient(120deg, var(--persian-blue) 0%, var(--neon-blue) 100%);

  /* Rounded geometry */
  --radius-sm: 14px;
  --radius:    22px;
  --radius-lg: 34px;
  --radius-pill: 999px;

  --shadow:    0 18px 50px -20px rgba(20,0,82,.35);
  --shadow-sm: 0 8px 24px -12px rgba(20,0,82,.28);

  --maxw: 1160px;
  --font: "Poppins", "Nexa", system-ui, -apple-system, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font);
  color: var(--ink);
  background: var(--bg);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

/* Typography — large, bold, lowercase-friendly headlines */
h1, h2, h3 { line-height: 1.05; letter-spacing: -.02em; margin: 0 0 .4em; font-weight: 800; }
h1 { font-size: clamp(2.4rem, 6vw, 4.6rem); }
h2 { font-size: clamp(1.8rem, 4vw, 3rem); }
h3 { font-size: clamp(1.15rem, 2vw, 1.5rem); font-weight: 700; }
p  { margin: 0 0 1rem; }
a  { color: inherit; text-decoration: none; }
.eyebrow {
  text-transform: uppercase; letter-spacing: .18em; font-size: .78rem;
  font-weight: 700; color: var(--neon-blue); margin-bottom: .9rem; display:block;
}
.on-dark .eyebrow { color: var(--periwinkle); }

/* Layout */
.container { max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }
section { padding: clamp(56px, 8vw, 110px) 0; position: relative; overflow: hidden; }
.section-soft { background: var(--bg-soft); }
.section-dark { background: var(--grad-deep); color: var(--on-dark); }
.lede { font-size: clamp(1.05rem, 1.6vw, 1.3rem); color: var(--ink-soft); max-width: 60ch; }
.on-dark .lede, .section-dark .lede { color: var(--periwinkle); }
.center { text-align: center; margin-inline: auto; }

/* Buttons */
.btn {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .9rem 1.6rem; border-radius: var(--radius-pill);
  font-weight: 700; font-size: .98rem; cursor: pointer; border: 2px solid transparent;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.btn:hover { transform: translateY(-2px); }
.btn-primary { background: var(--neon-blue); color: #fff; box-shadow: 0 10px 30px -8px rgba(74,92,252,.6); }
.btn-primary:hover { background: #3647e8; }
.btn-ghost { border-color: currentColor; }
.btn-ghost.on-light { color: var(--persian-blue); }
.btn-row { display: flex; flex-wrap: wrap; gap: .8rem; margin-top: 1.6rem; }

/* Circular motifs (echo the logo ball) */
.orb { position: absolute; border-radius: 50%; filter: blur(2px); opacity: .5; pointer-events:none; z-index:0; }
.orb-1 { width: 480px; height: 480px; background: radial-gradient(circle at 30% 30%, var(--neon-blue), transparent 70%); top: -160px; right: -120px; }
.orb-2 { width: 360px; height: 360px; background: radial-gradient(circle at 50% 50%, var(--persian-blue), transparent 70%); bottom: -140px; left: -100px; opacity:.35; }
.container, section > .container { position: relative; z-index: 1; }

/* Header — transparent overlay that flows over the hero, solid on scroll, hides on scroll-down */
.site-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 60;
  background: transparent; border-bottom: 1px solid transparent;
  transition: transform .35s ease, background .3s ease, border-color .3s ease, box-shadow .3s ease;
}
.site-header.solid {
  background: rgba(255,255,255,.92); backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(20,0,82,.08); box-shadow: 0 6px 24px -16px rgba(20,0,82,.4);
}
.site-header.hidden { transform: translateY(-100%); }
.nav { display: flex; align-items: center; gap: 1.4rem; padding: 16px 24px; max-width: var(--maxw); margin: 0 auto; }
.brand { display: flex; align-items: center; gap: .6rem; font-weight: 800; font-size: 1.15rem; letter-spacing: -.02em; position: relative; }
.brand .logo { height: 40px; width: auto; display: block; }
/* Dual logo: white over hero, colour when solid */
.brand .logo-color { display: none; }
.site-header.solid .brand .logo-white { display: none; }
.site-header.solid .brand .logo-color { display: block; }
.site-footer .brand .logo { height: 46px; }
@media (max-width: 880px){ .brand .logo { height: 34px; } }

.nav-links { display: flex; gap: 1.3rem; margin-left: auto; align-items: center; }
.nav-links > a, .nav-item > a { font-weight: 600; font-size: .95rem; padding: .4rem 0; position: relative; color: #fff; white-space: nowrap; }
.site-header.solid .nav-links > a, .site-header.solid .nav-item > a { color: var(--ink); }
.nav-links > a:hover, .nav-item > a:hover { color: var(--neon-blue); }
.nav-links a.nav-cta { background: var(--neon-blue); color:#fff !important; padding: .6rem 1.25rem !important; border-radius: var(--radius-pill); white-space: nowrap; line-height:1; }
.nav-links a.nav-cta:hover { background:#3647e8; }

/* Hover mega-menu */
.nav-item { position: relative; display: inline-flex; align-items: center; }
.nav-item > a::after { content: "›"; display:inline-block; transform: rotate(90deg); margin-left:.35rem; font-size:.8rem; opacity:.7; transition: transform .2s ease; }
.nav-item:hover > a::after { transform: rotate(-90deg); }
.mega {
  position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(10px);
  width: 680px; background: #fff; border-radius: var(--radius); box-shadow: var(--shadow);
  padding: 1.2rem; opacity: 0; visibility: hidden; transition: opacity .2s ease, transform .2s ease;
  display: grid; grid-template-columns: 1fr 220px; gap: 0 1.4rem; z-index: 70;
}
.nav-item:hover .mega { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(8px); }
.mega::before { content:""; position:absolute; top:-10px; left:0; right:0; height:14px; } /* hover bridge */
.mega-links { display: grid; grid-template-columns: 1fr 1fr; gap: .2rem 1.2rem; align-content: start; }
.mega-cta { position: relative; display: flex; flex-direction: column; justify-content: flex-end; gap:.55rem;
  min-height: 230px; padding: 1.1rem !important; border-radius: 16px; overflow: hidden;
  background-size: cover; background-position: center; color: #fff !important; }
.mega-cta { text-shadow: 0 1px 10px rgba(20,0,82,.45); }
.mega-cta .mega-cta-eyebrow { display:block; margin-bottom:.15rem; font-size:.66rem; text-transform:uppercase; letter-spacing:.16em; font-weight:800; opacity:.95; }
.mega-cta strong { display:block; font-size:1.15rem; line-height:1.3; font-weight:800; letter-spacing:-.01em; }
.mega-cta .mega-cta-btn { margin-top:.7rem; display:inline-block; align-self:flex-start; font-size:.78rem; font-weight:700; color:#fff; background: var(--neon-blue); padding:.45rem .85rem; border-radius:var(--radius-pill); text-shadow:none; }
.mega-cta:hover .mega-cta-btn { background:#3647e8; }
.mega a { display: block; padding: .5rem .6rem; border-radius: 10px; color: var(--federal-blue); font-weight: 600; font-size: .92rem; }
.mega a small { display:block; font-weight:400; color: var(--ink-soft); font-size:.8rem; }
.mega a:hover { background: var(--alice-blue); color: var(--neon-blue); }
.mega-links .mega-head { grid-column: 1 / -1; font-size:.72rem; text-transform:uppercase; letter-spacing:.14em; color: var(--neon-blue); font-weight:700; padding:.2rem .6rem .4rem; }

.lang-select {
  font-family: var(--font); font-weight: 600; font-size: .9rem; color: #fff;
  border: 1.5px solid rgba(255,255,255,.5); border-radius: var(--radius-pill);
  padding: .45rem .7rem; background: transparent; cursor: pointer;
}
.lang-select option { color: var(--ink); }
.site-header.solid .lang-select { color: var(--ink); border-color: rgba(20,0,82,.18); background:#fff; }
.menu-toggle { display:none; margin-left:auto; background:none; border:0; font-size:1.6rem; cursor:pointer; color:#fff; }
.site-header.solid .menu-toggle { color: var(--federal-blue); }

/* Right-edge "Get a quote" slide-in tab */
.quote-tab {
  position: fixed; right: 0; top: 50%; transform: translateY(-50%); z-index: 55;
  background: var(--neon-blue); color:#fff; font-weight:700; letter-spacing:.04em;
  writing-mode: vertical-rl; text-orientation: mixed;
  padding: 1rem .55rem; border-radius: 12px 0 0 12px; cursor: pointer;
  box-shadow: -6px 0 24px -10px rgba(74,92,252,.8); text-decoration:none;
  transition: background .2s ease, padding .2s ease;
}
.quote-tab:hover { background:#3647e8; padding-right:.8rem; }
@media (max-width: 880px){ .quote-tab { display:none; } }

/* Hero */
.hero { background: var(--grad-deep); color: var(--on-dark); padding: clamp(70px,10vw,140px) 0 clamp(60px,8vw,120px); }
.hero h1 { max-width: 16ch; }
.hero .lede { color: var(--periwinkle); }
.hero-tag { font-size: clamp(1rem,1.5vw,1.2rem); font-weight:700; color:#fff; }
.hero-stats { display:flex; flex-wrap:wrap; gap: 2.4rem; margin-top: 2.6rem; }
.hero-stats .num { font-size: 2.2rem; font-weight: 800; color:#fff; }
.hero-stats .lbl { font-size:.85rem; color: var(--periwinkle); text-transform:uppercase; letter-spacing:.1em; }

/* Cards & grids */
.grid { display: grid; gap: 1.4rem; }
.grid-2 { grid-template-columns: repeat(2,1fr); }
.grid-3 { grid-template-columns: repeat(3,1fr); }
.grid-4 { grid-template-columns: repeat(4,1fr); }
.card {
  background: #fff; border-radius: var(--radius); padding: 1.7rem;
  box-shadow: var(--shadow-sm); border: 1px solid rgba(20,0,82,.06);
  transition: transform .18s ease, box-shadow .18s ease;
}
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.card .thumb { width: 100%; height: 130px; object-fit: cover; border-radius: 14px; margin-bottom: .9rem; display:block; background: var(--grad-vivid); }
.card h3 { color: var(--persian-blue); }
.card .tag { font-size:.75rem; font-weight:700; color: var(--neon-blue); text-transform:uppercase; letter-spacing:.08em; }
.section-dark .card { background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.12); color:#fff; }
.section-dark .card h3 { color:#fff; }
.pill { display:inline-block; background: var(--periwinkle); color: var(--federal-blue); border-radius: var(--radius-pill); padding:.3rem .8rem; font-size:.8rem; font-weight:700; }

/* Works-with module (integration) */
.workswith { background: var(--grad-vivid); color:#fff; border-radius: var(--radius-lg); padding: 1.8rem; }
.workswith h3 { color:#fff; }
.chips { display:flex; flex-wrap:wrap; gap:.6rem; margin-top: 1rem; }
.chip { background: rgba(255,255,255,.18); border:1px solid rgba(255,255,255,.35); color:#fff; padding:.45rem .9rem; border-radius: var(--radius-pill); font-weight:600; font-size:.9rem; }
.chip:hover { background: rgba(255,255,255,.3); }

/* Ecosystem diagram */
.eco { display:grid; grid-template-columns: repeat(3,1fr); gap: 1rem; align-items:stretch; }
.eco .node { background: rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.16); border-radius: var(--radius); padding:1.2rem; text-align:center; }
.eco .node .h { font-weight:800; color:#fff; }
.eco .node .s { color: var(--periwinkle); font-size:.85rem; }
.eco-core { background: var(--neon-blue) !important; border-color: var(--neon-blue) !important; }

/* Split */
.split { display:grid; grid-template-columns: 1.1fr .9fr; gap: 3rem; align-items:center; }

/* Footer */
.site-footer { background: var(--grad-deep); color: var(--on-dark); padding: 64px 0 32px; }
.footer-grid { display:grid; grid-template-columns: 1.4fr repeat(3,1fr); gap: 2rem; }
.site-footer a { color: var(--periwinkle); display:block; padding:.2rem 0; font-size:.93rem; }
.site-footer a:hover { color:#fff; }
.site-footer h4 { font-size:.8rem; text-transform:uppercase; letter-spacing:.12em; color:#fff; margin:0 0 .8rem; }
.footer-bottom { margin-top: 2.6rem; padding-top: 1.4rem; border-top:1px solid rgba(255,255,255,.14); font-size:.82rem; color: var(--periwinkle); display:flex; justify-content:space-between; flex-wrap:wrap; gap:.6rem; }
.footer-tag { font-weight:800; color:#fff; font-size:1.1rem; }

/* Breadcrumb */
.crumb { font-size:.85rem; color: var(--periwinkle); margin-bottom: .8rem; }
.crumb a { color: var(--periwinkle); } .crumb a:hover { color:#fff; }

/* Utility */
.mt-0{margin-top:0}.mb-0{margin-bottom:0}.muted{color:var(--ink-soft)}
.section-dark .muted{color:var(--periwinkle)}

/* ===== WOW LAYER: imagery, glass, motion ================================= */

/* Full-bleed cinematic hero with image + gradient overlay */
.hero-cine {
  position: relative; color: #fff; isolation: isolate;
  min-height: 92vh; display: flex; align-items: center;
  padding: 120px 0 80px;
  background: var(--federal-blue);
}
.hero-cine .bg {
  position: absolute; inset: 0; z-index: -2;
  background-size: cover; background-position: center;
  transform: scale(1.05);
}
.hero-cine .scrim {
  position: absolute; inset: 0; z-index: -1;
  background:
    linear-gradient(180deg, rgba(20,0,82,.35) 0%, rgba(20,0,82,.65) 55%, rgba(12,2,56,.92) 100%),
    linear-gradient(110deg, rgba(36,59,189,.55) 0%, rgba(74,92,252,.1) 60%);
}
.hero-cine h1 { font-size: clamp(2.8rem, 7.5vw, 6rem); text-shadow: 0 4px 40px rgba(0,0,0,.35); }
.hero-cine .lede { color: #e7ecff; }
.glow-tag {
  display:inline-flex; align-items:center; gap:.5rem; font-weight:800; letter-spacing:.04em;
  background: rgba(74,92,252,.25); border:1px solid rgba(199,212,255,.5);
  color:#fff; padding:.5rem 1rem; border-radius: var(--radius-pill); backdrop-filter: blur(6px);
  font-size:.9rem; margin-bottom:1.4rem;
}
.glow-dot { width:9px; height:9px; border-radius:50%; background:var(--neon-blue); box-shadow:0 0 12px 3px var(--neon-blue); animation: pulse 2s infinite; }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.4} }

/* Glassmorphism cards (for dark sections / over imagery) */
.glass {
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.22);
  backdrop-filter: blur(14px);
  border-radius: var(--radius); padding: 1.5rem; color:#fff;
}
.glass .num { font-size: 2.4rem; font-weight: 800; }
.glass .lbl { color: var(--periwinkle); text-transform: uppercase; letter-spacing:.12em; font-size:.78rem; }

/* Image cards with overlay (product / solution tiles) */
.imgcard {
  position: relative; border-radius: var(--radius); overflow: hidden; min-height: 320px;
  display:flex; align-items:flex-end; color:#fff; box-shadow: var(--shadow);
  background:#1a1370; isolation:isolate;
}
.imgcard img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-2; transition: transform .5s ease; }
.imgcard::after { content:""; position:absolute; inset:0; z-index:-1;
  background: linear-gradient(180deg, rgba(20,0,82,0) 25%, rgba(20,0,82,.85) 100%); }
.imgcard:hover img { transform: scale(1.07); }
.imgcard .body { padding: 1.5rem; }
.imgcard h3 { color:#fff; margin-bottom:.2rem; }
.imgcard .tag { color: var(--periwinkle); }
.imgcard.tall { min-height: 460px; }

/* Media band (split image + text) */
.media { position:relative; border-radius: var(--radius-lg); overflow:hidden; min-height: 420px; box-shadow: var(--shadow); }
.media img { width:100%; height:100%; object-fit:cover; position:absolute; inset:0; }

/* Logo marquee */
.marquee { overflow:hidden; -webkit-mask-image: linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); }
.marquee-track { display:flex; align-items:center; width:max-content; animation: scrollx 40s linear infinite; will-change: transform; transform: translate3d(0,0,0); backface-visibility: hidden; }
.marquee:hover .marquee-track { animation-play-state: paused; }
.marquee .lg { font-weight:800; font-size:1.25rem; color:#fff; opacity:.85; white-space:nowrap; letter-spacing:-.01em; margin-right:3rem; }
@keyframes scrollx { from { transform: translate3d(0,0,0); } to { transform: translate3d(-50%,0,0); } }

/* Testimonial */
.quote { font-size: clamp(1.3rem,2.6vw,2rem); font-weight:700; line-height:1.3; letter-spacing:-.01em; }
.who { display:flex; align-items:center; gap:.9rem; margin-top:1.4rem; }
.who img { width:54px; height:54px; border-radius:50%; object-fit:cover; border:2px solid var(--neon-blue); }
.who .n { font-weight:700; } .who .r { color: var(--periwinkle); font-size:.9rem; }

/* Scroll reveal */
.reveal { opacity:0; transform: translateY(24px); transition: opacity .7s ease, transform .7s ease; }
.reveal.in { opacity:1; transform:none; }

/* Floating orb animation */
.orb { animation: float 9s ease-in-out infinite; }
.orb-2 { animation-duration: 12s; }
@keyframes float { 0%,100%{ transform: translateY(0) } 50%{ transform: translateY(-26px) } }

@media (prefers-reduced-motion: reduce){
  .orb,.glow-dot,.marquee-track { animation: none; }
  .reveal { opacity:1; transform:none; transition:none; }
  .hero-cine .bg { transform:none; }
}

/* ===== MORE: signature flair ============================================ */

/* Scroll progress bar */
#scrollbar { position: fixed; top: 0; left: 0; height: 4px; width: 0%; z-index: 100;
  background: linear-gradient(90deg, var(--persian-blue), var(--neon-blue)); box-shadow: 0 0 12px var(--neon-blue); }

/* Animated gradient clip-text for headline accents */
.grad-text {
  background: linear-gradient(100deg, #8fa2ff, #4A5CFC 35%, #c7d4ff 70%, #4A5CFC);
  background-size: 250% 100%;
  -webkit-background-clip: text; background-clip: text; color: transparent;
  animation: shimmer 6s linear infinite;
}
@keyframes shimmer { to { background-position: 250% 0; } }

/* Outlined "stroke" text for big statements */
.stroke-text { color: transparent; -webkit-text-stroke: 2px rgba(255,255,255,.6); }

/* Giant kinetic marquee band */
.kinetic { background: var(--neon-blue); padding: 18px 0; overflow: hidden; }
.kinetic.dark { background: var(--federal-blue); }
.kinetic-track { display: flex; width: max-content; align-items: center; animation: scrollx 38s linear infinite; will-change: transform; transform: translate3d(0,0,0); backface-visibility: hidden; }
.kinetic:hover .kinetic-track { animation-play-state: paused; }
.kinetic-track .k { font-size: clamp(2rem, 5vw, 3.6rem); font-weight: 800; letter-spacing: -.02em; color: #fff; white-space: nowrap; text-transform: uppercase; margin-right: 2.5rem; }
.kinetic-track .k.ghost { color: transparent; -webkit-text-stroke: 1.5px rgba(255,255,255,.65); }
.kinetic-track .dot { width: 16px; height: 16px; border-radius: 50%; background: #fff; flex: 0 0 auto; margin-right: 2.5rem; }

/* Neon glow */
.glow { box-shadow: 0 0 0 1px rgba(74,92,252,.5), 0 0 40px -6px rgba(74,92,252,.7); }
.btn-primary.glow:hover { box-shadow: 0 0 0 1px rgba(74,92,252,.7), 0 0 60px -4px rgba(74,92,252,.9); }

/* Tilt cards */
.tilt { transform-style: preserve-3d; transition: transform .2s ease; will-change: transform; }

/* Circular sweep motif (big rotating ring, echoes the logo ball) */
.sweep { position: absolute; border-radius: 50%; border: 1.5px dashed rgba(199,212,255,.35);
  width: 680px; height: 680px; pointer-events: none; z-index: 0; animation: spin 50s linear infinite; }
.sweep.s2 { width: 460px; height: 460px; border-color: rgba(74,92,252,.4); animation-duration: 36s; animation-direction: reverse; }
@keyframes spin { to { transform: rotate(360deg); } }

/* Strike animation (rolling ball → scattering pins) */
.strike { position: relative; height: 120px; }
.strike .ball { position: absolute; bottom: 8px; left: 0; width: 54px; height: 54px; border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, #6b7bff, var(--federal-blue) 70%);
  box-shadow: 0 0 24px rgba(74,92,252,.8), inset -6px -6px 12px rgba(0,0,0,.4);
  animation: roll 4s cubic-bezier(.4,0,.5,1) infinite; }
.strike .ball::after { content:""; position:absolute; top:34%; left:30%; width:6px; height:6px; border-radius:50%; background:rgba(255,255,255,.5); box-shadow:10px 4px 0 -1px rgba(255,255,255,.4), 4px 14px 0 -1px rgba(255,255,255,.4); }
.strike .pin { position: absolute; bottom: 10px; width: 13px; height: 38px; border-radius: 48% 48% 45% 45%/ 60% 60% 40% 40%;
  background: linear-gradient(#fff, #dbe2ff); transform-origin: bottom center; }
.strike .pin i { position:absolute; top:9px; left:0; right:0; height:5px; background: var(--neon-blue); }
.strike .p1{ right: 120px; } .strike .p2{ right: 100px; } .strike .p3{ right: 80px; } .strike .p4{ right: 60px; }
.strike .ball { }
@keyframes roll { 0%{ left:-10%; transform: rotate(0) } 55%{ left: calc(100% - 150px); transform: rotate(900deg) } 60%{ left: calc(100% - 150px) } 100%{ left: calc(100% - 150px); transform: rotate(900deg) } }
.strike.go .pin { animation: scatter 4s ease-in-out infinite; }
.strike .p1{ animation-delay:0s } .strike .p2{ animation-delay:.05s } .strike .p3{ animation-delay:.1s } .strike .p4{ animation-delay:.15s }
@keyframes scatter { 0%,52%{ transform: translateY(0) rotate(0); opacity:1 } 62%{ transform: translateY(-30px) translateX(40px) rotate(70deg); opacity:1 } 80%,100%{ transform: translateY(0) translateX(0) rotate(0); opacity:1 } }

/* Contact / quote form */
.vform-wrap { background: rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14); border-radius: var(--radius-lg); padding: clamp(1.4rem,3vw,2.2rem); margin-bottom: 2.6rem; }
.vform-wrap h3 { color:#fff; margin-bottom:.3rem; }
.vform-wrap p.sub { color: var(--periwinkle); margin-bottom: 1.2rem; }
.vform { display:grid; grid-template-columns: 1fr 1fr; gap: .9rem; }
.vform .full { grid-column: 1 / -1; }
.vform label { display:block; font-size:.78rem; text-transform:uppercase; letter-spacing:.08em; color: var(--periwinkle); margin-bottom:.3rem; font-weight:700; }
.vform input, .vform select, .vform textarea {
  width:100%; font-family: var(--font); font-size:.95rem; color:#fff; background: rgba(255,255,255,.08);
  border:1.5px solid rgba(255,255,255,.22); border-radius: 12px; padding:.7rem .8rem; box-sizing:border-box;
}
.vform input::placeholder, .vform textarea::placeholder { color: rgba(255,255,255,.5); }
.vform select option { color: var(--ink); }
.vform input:focus, .vform select:focus, .vform textarea:focus { outline:none; border-color: var(--neon-blue); background: rgba(255,255,255,.14); }
.vform textarea { min-height: 96px; resize: vertical; }
.vform .submit-row { grid-column:1 / -1; display:flex; align-items:center; gap:1rem; flex-wrap:wrap; }
.vform .note { color: var(--periwinkle); font-size:.8rem; }
.form-ok { display:none; background: var(--grad-vivid); color:#fff; border-radius: var(--radius); padding:1.2rem 1.4rem; font-weight:600; }
.form-ok.show { display:block; }
@media (max-width:880px){ .vform { grid-template-columns:1fr; } }

/* Software badge */
.soft-badge { display:inline-flex; align-items:center; gap:.45rem; background: var(--neon-blue); color:#fff;
  font-weight:700; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; padding:.35rem .8rem; border-radius: var(--radius-pill); }

/* Checkmark feature list (strengths / software features) */
.speclist { list-style:none; padding:0; margin:1rem 0 0; display:grid; gap:.6rem; }
.speclist.cols2 { grid-template-columns: 1fr 1fr; gap:.6rem 2rem; }
.speclist li { position:relative; padding-left:1.9rem; color: var(--ink-soft); font-size:.96rem; line-height:1.4; }
.speclist li::before { content:""; position:absolute; left:0; top:.15rem; width:1.2rem; height:1.2rem; border-radius:50%;
  background: var(--neon-blue); -webkit-mask: no-repeat center/0.8rem url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23fff' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E");
          mask: no-repeat center/0.8rem url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23fff' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E"); }
.speclist li strong { color: var(--federal-blue); }
.section-dark .speclist li { color: var(--periwinkle); }
.section-dark .speclist li strong { color:#fff; }
@media (max-width:880px){ .speclist.cols2 { grid-template-columns:1fr; } }

/* Brand arrow bullet for general content lists */
.card ul:not(.speclist), .muted ul, ul.muted { list-style: none; padding: 0; margin: .7rem 0 0; }
.card ul:not(.speclist) li, .muted ul li, ul.muted li { position: relative; padding-left: 1.5rem; margin: .35rem 0; line-height: 1.45; }
.card ul:not(.speclist) li::before, .muted ul li::before, ul.muted li::before {
  content: ""; position: absolute; left: 0; top: .5em; width: .8rem; height: .8rem; transform: translateY(-50%);
  background: var(--neon-blue);
  -webkit-mask: no-repeat center/contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M6 2.5 L18.5 12 L6 21.5 L2.6 18 L10.6 12 L2.6 6 Z'/%3E%3C/svg%3E");
          mask: no-repeat center/contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M6 2.5 L18.5 12 L6 21.5 L2.6 18 L10.6 12 L2.6 6 Z'/%3E%3C/svg%3E"); }
.section-dark .card ul li::before, .section-dark .muted ul li::before { background: var(--neon-blue); }

/* Video poster (links out to YouTube) */
.video-poster { position:relative; display:block; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); aspect-ratio:16/9; }
.video-poster img { width:100%; height:100%; object-fit:cover; transition: transform .5s ease; }
.video-poster::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(20,0,82,.1),rgba(20,0,82,.55)); }
.video-poster:hover img { transform: scale(1.04); }
.video-play { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:84px; height:84px; border-radius:50%;
  background: var(--neon-blue); color:#fff; display:flex; align-items:center; justify-content:center; font-size:1.8rem; padding-left:.3rem;
  box-shadow:0 10px 30px rgba(74,92,252,.5); z-index:2; transition: transform .25s ease; }
.video-poster:hover .video-play { transform:translate(-50%,-50%) scale(1.08); }
.video-cap { position:absolute; left:1.4rem; bottom:1.2rem; z-index:2; color:#fff; font-weight:700; font-size:1.05rem; text-shadow:0 1px 10px rgba(20,0,82,.5); }

/* Footer partners — laid out in a row */
.foot-partners { grid-column: 1 / -1; border-top: 1px solid rgba(255,255,255,.12); margin-top: .6rem; padding-top: 1.2rem; }
.foot-partners .partner-row { display: flex; flex-wrap: wrap; gap: .4rem 1.6rem; }
.foot-partners .partner-row a { display: inline-block; padding: .2rem 0; white-space: nowrap; }

/* "Book a demo" software band */
.demo-band { background: var(--grad-deep); color:#fff; border-radius: var(--radius-lg); padding: clamp(1.8rem,4vw,2.8rem); position:relative; overflow:hidden; }
.demo-band h2, .demo-band h3 { color:#fff; }
.demo-band .lede { color: var(--periwinkle); }
.demo-band .orb { opacity:.4; }

/* "Strength" highlight pill on cards */
.strength { display:inline-block; background: var(--alice-blue); color: var(--persian-blue); border:1px solid var(--periwinkle);
  font-weight:700; font-size:.74rem; padding:.25rem .6rem; border-radius: var(--radius-pill); margin:.15rem .3rem .15rem 0; }

/* Comparison table */
.cmp { width:100%; table-layout:fixed; border-collapse:collapse; margin-top:1.6rem; border-radius: var(--radius); overflow:hidden; box-shadow: var(--shadow-sm); background:#fff; }
.cmp thead th:first-child { width:20%; }
.cmp thead th:nth-child(2), .cmp thead th:nth-child(3) { width:40%; }
.cmp th, .cmp td { text-align:left; padding:1rem 1.2rem; border-bottom:1px solid rgba(20,0,82,.08); font-size:.96rem; }
.cmp thead th { background: var(--grad-vivid); color:#fff; font-weight:700; }
.cmp tbody th { color: var(--persian-blue); font-weight:700; width:30%; }
.cmp tbody tr:last-child td, .cmp tbody tr:last-child th { border-bottom:0; }
.cmp td { color: var(--ink-soft); }

/* Reference lightbox modal */
.imgcard.clickable { cursor:pointer; }
.imgcard.clickable .body h3::after { content:" ↗"; color:var(--neon-blue); font-size:.85em; }
.ref-modal { position:fixed; inset:0; z-index:2000; display:none; align-items:flex-start; justify-content:center; padding:5vh 1.2rem; background:rgba(20,0,82,.62); backdrop-filter:blur(6px); overflow-y:auto; }
.ref-modal.open { display:flex; }
.ref-modal .box { background:#fff; border-radius:var(--radius); max-width:880px; width:100%; overflow:hidden; box-shadow:var(--shadow-lg,0 30px 80px rgba(20,0,82,.35)); animation:refIn .3s ease; }
@keyframes refIn { from{opacity:0; transform:translateY(20px)} to{opacity:1; transform:none} }
.ref-modal .rhead { position:relative; }
.ref-modal .rhead img { width:100%; height:340px; object-fit:cover; display:block; }
.ref-modal .rclose { position:absolute; top:1rem; right:1rem; width:42px; height:42px; border-radius:50%; border:0; background:rgba(255,255,255,.92); color:var(--federal-blue); font-size:1.3rem; cursor:pointer; line-height:1; box-shadow:var(--shadow-sm); }
.ref-modal .rbody { padding:1.8rem 2rem 2rem; }
.ref-modal .rbody .tag { display:inline-block; }
.ref-modal .rbody h3 { margin:.6rem 0 .2rem; font-size:1.7rem; }
.ref-modal .rmeta { color:var(--ink-soft); font-size:.95rem; margin-bottom:1rem; }
.ref-modal .rbody p { color:var(--ink-soft); }
.ref-modal .rgall { display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:.7rem; margin:1.2rem 0; }
.ref-modal .rgall img { width:100%; height:150px; object-fit:cover; border-radius:14px; }

/* Game logo grid */
.logo-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); gap:1.1rem; }
.logo-grid figure { margin:0; background:#fff; border-radius:18px; padding:1rem; text-align:center; box-shadow:var(--shadow-sm); transition:transform .25s ease, box-shadow .25s ease; }
.logo-grid figure:hover { transform:translateY(-4px); box-shadow:var(--shadow-md,0 16px 40px rgba(20,0,82,.16)); }
.logo-grid img { width:100%; aspect-ratio:1/1; object-fit:contain; }
.logo-grid figcaption { margin-top:.6rem; font-weight:700; color:var(--persian-blue); font-size:.92rem; }

/* Open-by-design band */
.open-band { background: var(--grad-vivid); color:#fff; border-radius: var(--radius-lg); padding: clamp(1.8rem,4vw,3rem); position:relative; overflow:hidden; }
.open-band h2, .open-band h3 { color:#fff; }
.open-band .lede { color:#eaeefc; }
.open-band .pillrow { display:flex; flex-wrap:wrap; gap:.7rem; margin-top:1.4rem; }
.open-band .pillrow .chip { background:rgba(255,255,255,.16); border-color:rgba(255,255,255,.4); }

/* Big number callouts */
.num-xl { font-size: clamp(3rem, 8vw, 6rem); font-weight: 800; line-height: 1; letter-spacing: -.03em; }

@media (prefers-reduced-motion: reduce){
  .grad-text,.kinetic-track,.sweep,.strike .ball,.strike .pin { animation: none !important; }
  .strike .ball { left: calc(100% - 150px); }
}

/* Responsive */
@media (max-width: 880px){
  .sweep { display:none; }
  .strike { display:none; }
  .nav-links { position: fixed; top:0; bottom:0; right:0; left:auto; width:85%; max-width:380px; height:100vh;
    background:#fff; flex-direction:column; align-items:flex-start; overflow-y:auto;
    padding: 84px 24px 2rem; gap:.3rem; box-shadow: var(--shadow); transform: translateX(105%); transition: transform .25s ease; z-index: 90; }
  .nav-links.open { transform: translateX(0); }
  .nav-links > a, .nav-item > a { color: var(--ink) !important; width:100%; padding:.6rem 0; }
  .nav-item { display:block; width:100%; }
  .nav-item > a { display:flex; align-items:center; justify-content:space-between; }
  .nav-item > a::after { display:inline-block; transform: rotate(90deg); opacity:.6; }
  .nav-item.open > a::after { transform: rotate(-90deg); color: var(--neon-blue); opacity:1; }
  .mega { position: static; transform: none !important; opacity: 1; visibility: visible; display: none;
    width: auto; min-width: 0; box-shadow: none; padding: .2rem 0 .6rem .8rem; }
  .nav-item.open .mega { display: block; }
  .mega-links { display: block; }
  .mega-cta { display: none; }
  .mega-links .mega-head { padding-left:0; }
  .nav-links a { width:100%; padding:.6rem 0; border-bottom:1px solid rgba(20,0,82,.06); }
  .menu-toggle { display:block; position:relative; z-index:95; }
  .site-header:has(.nav-links.open) .menu-toggle { color: var(--federal-blue); }
  .lang-select { margin-left:auto; }
  .grid-2,.grid-3,.grid-4,.eco,.split,.footer-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .container { padding-left:20px; padding-right:20px; }
  .btn-row { flex-wrap: wrap; }
  .btn-row .btn { flex: 1 1 auto; text-align:center; }
}
@media (max-width: 520px){
  .footer-grid { grid-template-columns: 1fr; }
  h1 { font-size: clamp(1.9rem, 8vw, 2.6rem); }
  .cmp { font-size:.85rem; }
  .cmp th, .cmp td { padding:.7rem .6rem; }
}
