/* ============================================
   NexaOps — Black × Blue Design System
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Sora:wght@400;600;700;800;900&family=JetBrains+Mono:wght@400;500;600&display=swap');

:root {
  --bg:         #000000;
  --surface:    #07080f;
  --surface-2:  #0b0d1c;
  --surface-3:  #0f1128;
  --border:     #141829;
  --border-hi:  #1c2b4a;
  --primary:    #2563eb;
  --primary-d:  #1d4ed8;
  --primary-h:  #3b82f6;
  --secondary:  #38bdf8;
  --accent:     #7dd3fc;
  --success:    #22d37a;
  --warning:    #f59e0b;
  --text:       #ddeeff;
  --text-muted: #6a8db8;
  --text-faint: #263859;
  --grad:       linear-gradient(135deg, #1d4ed8 0%, #38bdf8 100%);
  --grad-45:    linear-gradient(45deg,  #1d4ed8, #2563eb, #38bdf8);
  --nav-h:      68px;
  --max-w:      1280px;
  --r:          12px;
  --r-lg:       20px;
  --shadow:     0 8px 40px rgba(0,0,0,0.7);
  --glow:       0 0 60px rgba(37,99,235,0.3);
  --glow-s:     0 0 24px rgba(37,99,235,0.2);
  --glow-c:     0 0 40px rgba(56,189,248,0.2);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; overflow-anchor: none; }

body {
  font-family: 'Inter', system-ui, sans-serif;
  background: var(--bg);
  color: var(--text);
  overflow-x: clip;
  line-height: 1.65;
}

::-webkit-scrollbar { width: 4px; }
::-webkit-scrollbar-track { background: var(--surface); }
::-webkit-scrollbar-thumb { background: var(--primary); border-radius: 2px; }

/* ---- TYPOGRAPHY ---- */
h1,h2,h3,h4,h5 { font-family:'Sora',sans-serif; line-height:1.15; font-weight:700; color:var(--text); }
h1 { font-size: clamp(2.6rem,7vw,5.2rem); }
h2 { font-size: clamp(1.9rem,4.5vw,3rem); }
h3 { font-size: clamp(1.15rem,2.5vw,1.6rem); }
h4 { font-size: 1.05rem; }
p  { color: var(--text-muted); line-height: 1.8; }
a  { color: inherit; text-decoration: none; }

.gradient-text {
  background: var(--grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.accent-text { color: var(--secondary); }

/* ---- LAYOUT ---- */
.container { max-width: var(--max-w); margin: 0 auto; padding: 0 40px; width: 100%; }
.section { padding: 100px 0; }
.section-inner { max-width: var(--max-w); margin: 0 auto; padding: 0 40px; }

.section-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.68rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--secondary);
  margin-bottom: 16px;
  padding: 5px 14px;
  background: rgba(56,189,248,0.07);
  border: 1px solid rgba(56,189,248,0.16);
  border-radius: 999px;
}
.section-label::before { content: '//'; opacity: 0.55; font-size: 0.65rem; margin-right: 2px; }
.section-title { margin-bottom: 16px; }
.section-desc {
  font-size: 1.08rem;
  color: var(--text-muted);
  max-width: 580px;
  margin-bottom: 56px;
  line-height: 1.8;
}

/* ---- NAVBAR ---- */
.navbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  height: var(--nav-h);
  display: flex; align-items: center;
  padding: 0 40px;
  transition: background 0.3s, border 0.3s;
}
.navbar.scrolled {
  background: rgba(0,0,0,0.92);
  -webkit-backdrop-filter: blur(24px) saturate(1.6);
  backdrop-filter: blur(24px) saturate(1.6);
  box-shadow: 0 1px 0 var(--border);
}
.navbar .inner {
  display: flex; align-items: center; justify-content: space-between;
  width: 100%; max-width: var(--max-w); margin: 0 auto;
}

.logo {
  font-family:'Sora',sans-serif; font-size:1.45rem; font-weight:900;
  background: var(--grad);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text; letter-spacing:-0.02em;
}

.nav-links { display:flex; align-items:center; gap:4px; list-style:none; }
.nav-links > li { display:flex; align-items:center; }
.nav-links > li > a {
  display:flex; align-items:center;
  color:var(--text-muted); font-size:0.88rem; font-weight:500;
  padding: 8px 14px; border-radius:8px;
  transition: color 0.2s, background 0.2s;
}
.nav-links > li > a:hover,
.nav-links > li > a.active { color:var(--text); background:rgba(255,255,255,0.06); }

/* Dropdown */
.dropdown { position:relative; }
.dropdown-toggle {
  display:flex; align-items:center; gap:5px; cursor:pointer;
  color:var(--text-muted); font-size:0.88rem; font-weight:500;
  padding: 8px 14px; border-radius:8px;
  transition: color 0.2s, background 0.2s;
  -webkit-user-select:none;
  user-select:none;
}
.dropdown-toggle:hover { color:var(--text); background:rgba(255,255,255,0.065); }
.dropdown-arrow { font-size:0.65rem; transition:transform 0.3s; }
.dropdown:hover .dropdown-arrow { transform:rotate(180deg); }

.dropdown-menu {
  position:absolute; top:calc(100% + 10px); left:50%;
  transform: translateX(-50%) translateY(-6px);
  background:var(--surface-2); border:1px solid var(--border);
  border-radius:14px; padding:8px; min-width:190px;
  opacity:0; visibility:hidden;
  transition: opacity 0.22s, transform 0.22s, visibility 0.22s;
  box-shadow:var(--shadow);
}
.dropdown:hover .dropdown-menu {
  opacity:1; visibility:visible;
  transform: translateX(-50%) translateY(0);
}
.dropdown-menu a {
  display:flex; align-items:center; gap:10px;
  padding: 10px 14px; border-radius:9px;
  font-size:0.85rem; color:var(--text-muted);
  transition: background 0.2s, color 0.2s;
}
.dropdown-menu a:hover { background:rgba(37,99,235,0.12); color:var(--secondary); }
.dropdown-menu .dm-icon { font-size:1rem; }

.nav-right { display:flex; align-items:center; gap:12px; }
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:4px; background:none; border:none; }
.hamburger span { display:block; width:22px; height:2px; background:var(--text); border-radius:2px; transition:all 0.3s; }

/* ---- BUTTONS ---- */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding: 13px 26px; border-radius:9px;
  font-weight:600; font-size:0.92rem; cursor:pointer;
  transition: all 0.3s; border:none; text-decoration:none;
  white-space: nowrap;
}
.btn-primary {
  background: var(--primary); color:#fff;
  box-shadow: 0 4px 20px rgba(37,99,235,0.4);
}
.btn-primary:hover { background: var(--primary-h); transform:translateY(-2px); box-shadow:0 8px 32px rgba(37,99,235,0.55); }
.btn-outline {
  background:transparent; color:var(--text);
  border:1px solid var(--border-hi);
}
.btn-outline:hover { border-color:var(--secondary); color:var(--secondary); background:rgba(56,189,248,0.06); transform:translateY(-2px); }
.btn-ghost { background:transparent; color:var(--text-muted); }
.btn-ghost:hover { color:var(--text); background:rgba(255,255,255,0.05); }
.btn-kd {
  background: linear-gradient(135deg, #6e0014, #8b001e);
  color: #fff; box-shadow: 0 4px 20px rgba(139,0,30,0.4);
}
.btn-kd:hover { transform:translateY(-2px); box-shadow:0 8px 32px rgba(139,0,30,0.6); }
.btn-lee {
  background: linear-gradient(135deg, #c87300, #e68a00);
  color: #fff; box-shadow: 0 4px 20px rgba(200,115,0,0.4);
}
.btn-lee:hover { transform:translateY(-2px); box-shadow:0 8px 32px rgba(200,115,0,0.6); }
.btn-sm { padding: 9px 18px; font-size:0.83rem; }
.btn-lg { padding: 16px 36px; font-size:1rem; }

/* ---- HERO SECTION ---- */
.hero {
  position:relative; min-height:100vh;
  display:flex; align-items:center;
  overflow:hidden; padding-top:var(--nav-h);
  background: var(--bg);
  contain: layout;
}
/* blue dot grid overlay */
.hero::after {
  content:'';
  position:absolute; inset:0; z-index:0;
  background-image:
    radial-gradient(circle, rgba(37,99,235,0.12) 1px, transparent 1px);
  background-size: 48px 48px;
  pointer-events:none;
}
#hero-canvas {
  position:absolute; top:0; left:0; width:100%; height:100%;
  z-index:1; pointer-events:none;
}
.hero-orbs { position:absolute; inset:0; z-index:0; overflow:hidden; pointer-events:none; }
.orb {
  position:absolute; border-radius:50%;
  filter:blur(80px); animation:floatOrb 10s ease-in-out infinite;
}
.orb-1 { width:700px; height:700px; background:radial-gradient(circle,rgba(37,99,235,0.22) 0%,transparent 70%); top:-200px; right:-200px; animation-delay:0s; }
.orb-2 { width:500px; height:500px; background:radial-gradient(circle,rgba(56,189,248,0.13) 0%,transparent 70%); bottom:-100px; left:-100px; animation-delay:4s; }
.orb-3 { width:350px; height:350px; background:radial-gradient(circle,rgba(29,78,216,0.16) 0%,transparent 70%); top:40%; left:35%; animation-delay:8s; }
@keyframes floatOrb {
  0%,100% { transform:translate(0,0) scale(1); }
  33%      { transform:translate(25px,-35px) scale(1.06); }
  66%      { transform:translate(-18px,20px) scale(0.94); }
}

.hero-content {
  position:relative; z-index:2;
  max-width:var(--max-w); margin:0 auto; padding:0 40px;
  width:100%;
}
.hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(37,99,235,0.1); border:1px solid rgba(37,99,235,0.25);
  padding:6px 16px; border-radius:999px;
  font-family:'JetBrains Mono',monospace;
  font-size:0.72rem; font-weight:500; letter-spacing:0.08em;
  color:var(--secondary); margin-bottom:28px;
  animation:fadeUp 0.6s ease both;
}
.badge-dot { width:6px; height:6px; border-radius:50%; background:var(--secondary); animation:pulseDot 2s infinite; }
@keyframes pulseDot { 0%,100%{ opacity:1;transform:scale(1); } 50%{ opacity:0.45;transform:scale(0.75); } }

.hero h1 { margin-bottom:22px; animation:fadeUp 0.6s ease 0.08s both; }
.typed-wrap { display:inline; }
.typed-text { color:var(--secondary); }
.typed-cursor { color:var(--primary); animation:blink 1s step-start infinite; }
@keyframes blink { 0%,100%{opacity:1;} 50%{opacity:0;} }

.hero-sub {
  font-size:clamp(1rem,2vw,1.18rem);
  color:var(--text-muted); max-width:580px;
  margin-bottom:40px; animation:fadeUp 0.6s ease 0.16s both;
}
.hero-actions {
  display:flex; flex-wrap:wrap; gap:14px;
  margin-bottom:72px; animation:fadeUp 0.6s ease 0.24s both;
}
.hero-stats { display:flex; flex-wrap:wrap; gap:48px; animation:fadeUp 0.6s ease 0.32s both; }
.stat-item .num {
  display:block; font-size:3rem; font-weight:900;
  font-family:'Sora',sans-serif; line-height:1;
  background:var(--grad); -webkit-background-clip:text;
  -webkit-text-fill-color:transparent; background-clip:text;
}
.stat-item .label {
  font-size:0.8rem; color:var(--text-muted); margin-top:4px; display:block;
}

/* ---- SERVICES OVERVIEW ---- */
.services-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:28px;
}
.service-card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:44px 32px 36px;
  text-align:center; transition:all 0.35s ease;
  position:relative; overflow:hidden; cursor:pointer;
  text-decoration:none; display:block;
}
.service-card::before {
  content:''; position:absolute; top:0; left:0; right:0;
  height:1px; background:var(--grad);
  transform:scaleX(0); transform-origin:left;
  transition:transform 0.35s ease;
}
.service-card:hover { transform:translateY(-10px); box-shadow:0 24px 64px rgba(0,0,0,0.55),var(--glow); border-color:var(--border-hi); }
.service-card:hover::before { transform:scaleX(1); }

.scard-icon {
  font-size:3.6rem; display:block; margin:0 auto 20px;
  filter:drop-shadow(0 0 24px rgba(37,99,235,0.4));
}
.service-card h3 { font-size:1.45rem; margin-bottom:14px; }
.service-card p { font-size:0.88rem; line-height:1.75; margin-bottom:26px; }
.scard-tags { display:flex; flex-wrap:wrap; gap:8px; justify-content:center; margin-bottom:28px; }
.tag {
  background:rgba(37,99,235,0.09); border:1px solid rgba(37,99,235,0.22);
  color:var(--accent); padding:4px 12px; border-radius:999px;
  font-size:0.72rem; font-weight:500;
}
.scard-arrow { color:var(--secondary); font-size:0.85rem; font-weight:600; }

/* ---- FEATURES ---- */
.features-section { background:var(--surface); }
.features-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:32px; }
.feature-item { display:flex; gap:20px; align-items:flex-start; }
.feat-icon {
  flex-shrink:0; width:50px; height:50px; border-radius:11px;
  background:rgba(37,99,235,0.1); border:1px solid rgba(37,99,235,0.22);
  display:flex; align-items:center; justify-content:center; font-size:1.3rem;
}
.feat-body h4 { margin-bottom:6px; font-size:1rem; }
.feat-body p { font-size:0.86rem; }

/* ---- MONETIZATION BANNER ---- */
.mono-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.mono-card {
  background:var(--surface-2); border:1px solid var(--border);
  border-radius:16px; padding:28px 22px; text-align:center;
}
.mono-card .mono-icon { font-size:2.2rem; display:block; margin-bottom:14px; }
.mono-card h4 { font-size:0.95rem; margin-bottom:8px; }
.mono-card p { font-size:0.8rem; }

/* ---- CTA BANNER ---- */
.cta-banner {
  background:var(--surface-2); border:1px solid var(--border);
  border-radius:24px; padding:72px 48px; text-align:center;
  position:relative; overflow:hidden;
}
.cta-banner::before {
  content:''; position:absolute; top:-100px; left:50%; transform:translateX(-50%);
  width:600px; height:400px;
  background:radial-gradient(circle,rgba(37,99,235,0.16),transparent 70%);
  pointer-events:none;
}
.cta-banner::after {
  content:''; position:absolute; bottom:-80px; right:-80px;
  width:400px; height:400px;
  background:radial-gradient(circle,rgba(56,189,248,0.08),transparent 70%);
  pointer-events:none;
}
.cta-banner > * { position:relative; z-index:1; }
.cta-banner h2 { margin-bottom:16px; }
.cta-banner p { max-width:500px; margin:0 auto 36px; }
.btn-group { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ---- PAGE HERO (inner pages) ---- */
.page-hero {
  padding: calc(var(--nav-h) + 80px) 40px 80px;
  text-align:center; position:relative; overflow:hidden;
}
.page-hero::before {
  content:''; position:absolute; top:0; left:50%; transform:translateX(-50%);
  width:900px; height:500px;
  background:radial-gradient(ellipse,rgba(37,99,235,0.14),transparent 70%);
  pointer-events:none;
}
.page-hero::after {
  content:''; position:absolute; inset:0; z-index:0;
  background-image: radial-gradient(circle, rgba(37,99,235,0.06) 1px, transparent 1px);
  background-size: 48px 48px;
  pointer-events:none;
}
.page-hero .ph-inner { position:relative; z-index:1; max-width:720px; margin:0 auto; }
.breadcrumb {
  display:flex; align-items:center; gap:8px; justify-content:center;
  font-size:0.75rem; font-family:'JetBrains Mono',monospace;
  color:var(--text-muted); margin-bottom:18px;
}
.breadcrumb a { color:var(--secondary); }
.breadcrumb span { color:var(--text-faint); }
.breadcrumb > span:last-child { color:var(--text); font-weight:500; }

/* ---- CARDS / INFO CARDS ---- */
.card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:16px; padding:32px; transition:all 0.3s;
}
.card:hover { border-color:var(--border-hi); box-shadow:var(--glow); transform:translateY(-4px); }
.card-icon {
  width:52px; height:52px; border-radius:11px;
  background:rgba(37,99,235,0.1); border:1px solid rgba(37,99,235,0.22);
  display:flex; align-items:center; justify-content:center;
  font-size:1.4rem; margin-bottom:18px;
}
.card h3 { margin-bottom:12px; }
.card p { font-size:0.88rem; }

/* ---- SERVICE LIST ---- */
.svc-list { list-style:none; display:flex; flex-direction:column; gap:10px; }
.svc-list li {
  display:flex; align-items:flex-start; gap:10px;
  font-size:0.875rem; color:var(--text-muted);
}
.svc-list li::before { content:'▸'; color:var(--secondary); flex-shrink:0; margin-top:2px; }

/* ---- PRICING CARDS ---- */
.pricing-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.pricing-card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:20px; padding:36px 28px; text-align:center; transition:all 0.3s;
}
.pricing-card.featured {
  border-color:var(--primary); background:rgba(37,99,235,0.05);
  box-shadow:var(--glow); transform:scale(1.03);
}
.pricing-card .badge-featured {
  display:inline-block; background:var(--grad); color:#fff;
  font-size:0.68rem; font-weight:700; padding:3px 12px;
  border-radius:999px; text-transform:uppercase; letter-spacing:0.07em;
  margin-bottom:12px;
}
.pricing-card h3 { font-size:1.1rem; margin-bottom:4px; }
.pricing-card .price {
  font-size:3rem; font-weight:900; font-family:'Sora',sans-serif;
  background:var(--grad); -webkit-background-clip:text;
  -webkit-text-fill-color:transparent; background-clip:text;
  line-height:1; margin:18px 0 6px;
}
.pricing-card .price-unit { font-size:0.82rem; color:var(--text-muted); margin-bottom:22px; }
.pricing-card ul { list-style:none; text-align:left; display:flex; flex-direction:column; gap:10px; margin-bottom:28px; }
.pricing-card ul li { font-size:0.85rem; color:var(--text-muted); display:flex; gap:8px; align-items:flex-start; }
.pricing-card ul li::before { content:'✓'; color:var(--success); flex-shrink:0; font-weight:700; }

/* ---- SYSTEMS GRID (D&D page) ---- */
.systems-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.system-chip {
  background:var(--surface-2); border:1px solid var(--border);
  border-radius:12px; padding:18px 20px;
  display:flex; align-items:center; gap:12px;
  transition:all 0.25s;
}
.system-chip:hover { border-color:var(--primary); background:rgba(37,99,235,0.07); }
.system-chip .chip-icon { font-size:1.4rem; }
.system-chip span { font-size:0.85rem; font-weight:500; }

/* ---- DIVIDERS ---- */
.divider { border:none; height:1px; background:var(--border); }
.divider-gradient { border:none; height:1px; background:linear-gradient(90deg,transparent,var(--primary),transparent); margin:60px 0; }

/* ---- FOOTER ---- */
.footer { background:var(--surface); border-top:1px solid var(--border); padding:64px 0 28px; }
.footer .inner { max-width:var(--max-w); margin:0 auto; padding:0 40px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:40px; margin-bottom:44px; }
.footer-brand .logo-f { font-family:'Sora',sans-serif; font-size:1.3rem; font-weight:900; background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.footer-brand p { font-size:0.82rem; margin-top:12px; max-width:260px; }
.footer-col h5 { font-size:0.72rem; font-weight:600; text-transform:uppercase; letter-spacing:0.14em; font-family:'JetBrains Mono',monospace; color:var(--text-muted); margin-bottom:16px; }
.footer-col a { display:block; color:var(--text-muted); font-size:0.83rem; padding:4px 0; transition:color 0.2s; }
.footer-col a:hover { color:var(--secondary); }
.footer-bottom { border-top:1px solid var(--border); padding-top:26px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:16px; }
.footer-bottom p { font-size:0.78rem; }
.footer-socials { display:flex; gap:12px; }
.footer-socials a { color:var(--text-muted); font-size:1rem; transition:color 0.2s; }
.footer-socials a:hover { color:var(--secondary); }

/* ---- SCROLL REVEAL ---- */
.reveal { opacity:0; transition:opacity 0.7s ease; will-change:opacity; }
.reveal.visible { opacity:1; will-change:auto; }
.reveal-d1 { transition-delay:0.1s; }
.reveal-d2 { transition-delay:0.2s; }
.reveal-d3 { transition-delay:0.3s; }
.reveal-d4 { transition-delay:0.4s; }

/* ---- KEYFRAMES ---- */
@keyframes fadeUp { from{opacity:0;transform:translateY(22px);}to{opacity:1;transform:translateY(0);} }
@keyframes blink { 0%,49%{opacity:1} 50%,100%{opacity:0} }

/* ---- TWO-COL LAYOUT ---- */
.two-col { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.two-col.reverse .col-visual { order:-1; }

/* ---- HIGHLIGHT BOX ---- */
.highlight-box {
  background:rgba(37,99,235,0.07); border:1px solid rgba(37,99,235,0.18);
  border-radius:16px; padding:28px 24px; margin-bottom:16px;
}
.highlight-box h4 { color:var(--secondary); margin-bottom:10px; }

/* ---- GRID HELPERS ---- */
.grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }

/* ── MOBILE ── */
@media(max-width:1024px) {
  .mono-grid, .grid-4 { grid-template-columns:repeat(2,1fr); }
  .systems-grid { grid-template-columns:repeat(2,1fr); }
  .pricing-grid { grid-template-columns:1fr; max-width:420px; margin:0 auto; }
  .pricing-card.featured { transform:scale(1); }
  .two-col { gap:40px; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:32px; }
}
@media(max-width:768px) {
  .container, .section-inner, .footer .inner { padding:0 20px; }
  .section { padding:72px 0; }
  .hero-content { padding:0 20px; }
  .navbar { padding:0 20px; }
  .nav-links { display:none; }
  .hamburger { display:flex; }
  .services-grid, .grid-3, .grid-2, .features-grid { grid-template-columns:1fr; }
  .mono-grid, .grid-4, .systems-grid, .tech-grid { grid-template-columns:1fr; }
  .two-col { grid-template-columns:1fr; gap:32px; }
  .two-col.reverse .col-visual { order:0; }
  .hero-stats { gap:28px; }
  .page-hero { padding:calc(var(--nav-h) + 48px) 20px 48px; }
  .cta-banner { padding:48px 24px; }
  .footer-grid { grid-template-columns:1fr; gap:24px; }
  h1 { font-size:2.4rem; }
  h2 { font-size:1.8rem; }
}

/* ── MOBILE NAV OPEN ── */
/* ── TECH SKILL GRID ── */
.tech-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.tech-badge {
  background:var(--surface-2); border:1px solid var(--border);
  border-radius:10px; padding:14px 18px;
  display:flex; align-items:center; gap:10px;
  font-size:0.84rem; font-weight:500; transition:all 0.25s;
}
.tech-badge:hover { border-color:var(--primary); color:var(--secondary); background:rgba(37,99,235,0.06); }
.tech-badge .tb-icon { font-size:1.2rem; }

/* ── CONTACT CARDS ── */
.contact-card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:20px; padding:48px 36px; text-align:center;
  transition:all 0.3s; position:relative; overflow:hidden;
}
.contact-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:var(--grad); transform:scaleX(0); transform-origin:left; transition:transform 0.35s;
}
.contact-card:hover { transform:translateY(-6px); box-shadow:var(--glow); border-color:var(--border-hi); }
.contact-card:hover::before { transform:scaleX(1); }
.contact-card .cc-icon { font-size:2.8rem; display:block; margin-bottom:20px; }
.contact-card h3 { margin-bottom:10px; }
.contact-card p { font-size:0.875rem; margin-bottom:24px; }

/* ── FAQ ── */
.faq-item { border-bottom:1px solid var(--border); padding:24px 0; }
.faq-item:first-child { padding-top:0; }
.faq-item h4 { font-size:1rem; margin-bottom:10px; color:var(--text); }
.faq-item p  { font-size:0.875rem; }

/* ── MOBILE NAV ── */
.nav-links.open {
  display:flex; flex-direction:column; align-items:flex-start;
  position:fixed; top:var(--nav-h); left:0; right:0; bottom:0;
  background:rgba(0,0,0,0.97); -webkit-backdrop-filter:blur(20px); backdrop-filter:blur(20px);
  padding:32px 24px; gap:6px; z-index:9999; overflow-y:auto;
}
.nav-links.open > li > a,
.nav-links.open .dropdown-toggle { font-size:1.1rem; padding:14px 18px; color:var(--text); }
.nav-links.open > li:nth-child(2) { margin-top:16px; }
.nav-links.open .dropdown-menu {
  position:static; opacity:1; visibility:visible;
  transform:none; border:none; background:transparent;
  box-shadow:none; padding:0 0 0 24px;
}
.nav-links.open .dropdown-menu a {
  color:var(--text); font-size:0.95rem;
}

/* ── JS-driven dropdown ── */
.dropdown.is-open .dropdown-menu {
  opacity:1; visibility:visible; transform:translateX(-50%) translateY(0);
}
/* Prevent desktop transform from applying inside mobile nav */
.nav-links.open .dropdown.is-open .dropdown-menu {
  transform:none;
}
.dropdown.is-open .dropdown-arrow { transform:rotate(180deg); }

/* ── SERVICE DETAIL CARDS (inner pages) ── */
.service-detail-card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:16px; padding:28px 24px;
  display:flex; flex-direction:column; gap:12px;
  transition:all 0.3s; position:relative; overflow:hidden;
}
.service-detail-card::before {
  content:''; position:absolute; left:0; top:0; bottom:0; width:2px;
  background:var(--grad); transform:scaleY(0); transition:transform 0.3s;
  transform-origin:top;
}
.service-detail-card:hover {
  border-color:var(--border-hi); box-shadow:var(--glow-s); transform:translateY(-3px);
}
.service-detail-card:hover::before { transform:scaleY(1); }
.sdc-top { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; }
.sdc-icon { font-size:1.8rem; flex-shrink:0; }
.price-range {
  background:rgba(56,189,248,0.08); border:1px solid rgba(56,189,248,0.22);
  color:var(--secondary); font-size:0.7rem; font-weight:600;
  font-family:'JetBrains Mono',monospace;
  padding:3px 10px; border-radius:999px; white-space:nowrap; flex-shrink:0;
}
.service-detail-card h4 { font-size:1rem; margin:0; }
.service-detail-card p  { font-size:0.85rem; margin:0; line-height:1.7; }
.sdc-tags { display:flex; flex-wrap:wrap; gap:6px; }
.sdc-tags .tag { font-size:0.7rem; }

/* ── CATEGORY SECTIONS ── */
.cat-section { margin-bottom:72px; }
.cat-section:last-child { margin-bottom:0; }
.cat-header {
  display:flex; align-items:center; gap:16px;
  margin-bottom:32px; padding-bottom:16px; border-bottom:1px solid var(--border);
}
.cat-header-icon { font-size:2rem; }
.cat-header-text h3 { margin:0; font-size:1.4rem; }
.cat-header-text p  { margin:4px 0 0; font-size:0.85rem; }

/* ── INFO NOTE ── */
.info-note {
  background:rgba(56,189,248,0.05); border:1px solid rgba(56,189,248,0.18);
  border-radius:12px; padding:18px 22px;
  display:flex; gap:12px; align-items:flex-start;
  font-size:0.86rem; color:var(--text-muted);
}
.info-note .note-icon { font-size:1.2rem; flex-shrink:0; margin-top:2px; }

/* ── AFFILIATE CARDS (homepage) ── */
.affiliate-card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:20px; padding:44px 32px 36px;
  text-align:center; transition:all 0.38s ease;
  position:relative; overflow:hidden; text-decoration:none; display:block;
}
.affiliate-card::before {
  content:''; position:absolute; top:0; left:0; right:0;
  height:2px; transform:scaleX(0); transform-origin:left; transition:transform 0.35s ease;
}
.affiliate-card.lee::before { background:linear-gradient(90deg,#ffb340,#ff7b00); }
.affiliate-card.dnd::before { background:linear-gradient(90deg,#8b001e,#6e1af7); }
.affiliate-card:hover { transform:translateY(-8px); box-shadow:0 24px 64px rgba(0,0,0,0.55); border-color:var(--border-hi); }
.affiliate-card:hover::before { transform:scaleX(1); }
.affiliate-card .aff-icon { font-size:3.4rem; display:block; margin:0 auto 20px; }
.affiliate-card h3 { font-size:1.35rem; margin-bottom:12px; }
.affiliate-card p  { font-size:0.88rem; line-height:1.75; margin-bottom:24px; }
.affiliate-card .aff-arrow { color:var(--text-muted); font-size:0.85rem; font-weight:600; }
.affiliate-card.lee:hover .aff-arrow { color:#ffb340; }
.affiliate-card.dnd:hover .aff-arrow { color:#8b3cf7; }

/* ── AFFILIATE PAGE THEMES ── */
.page-hero.lee-theme::before  { background:radial-gradient(ellipse,rgba(255,179,64,0.16),transparent 70%); }
.page-hero.dnd-theme::before  { background:radial-gradient(ellipse,rgba(139,0,30,0.2),transparent 70%); }
.lee-accent { color:#ffb340; }
.dnd-accent { color:#8b001e; }

/* ── D&D SESSION CARDS ── */
.session-card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:16px; padding:28px 24px;
  transition:all 0.3s; position:relative; overflow:hidden;
}
.session-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,#8b001e,#6e1af7);
}
.session-card:hover { border-color:rgba(139,0,30,0.4); box-shadow:0 8px 32px rgba(139,0,30,0.18); transform:translateY(-4px); }
.session-card .sc-icon { font-size:2.2rem; margin-bottom:14px; display:block; }
.session-card h4 { font-size:1.05rem; margin-bottom:8px; }
.session-card p  { font-size:0.85rem; }
.session-card .sc-price { margin-top:14px; font-size:0.78rem; font-weight:600; color:#8b3cf7; }

/* ── SYSTEM BADGES (D&D page) ── */
.system-badges { display:flex; flex-wrap:wrap; gap:10px; }
.sys-badge {
  background:rgba(110,26,247,0.1); border:1px solid rgba(110,26,247,0.22);
  color:var(--text); font-size:0.82rem; font-weight:500;
  padding:7px 16px; border-radius:8px; display:flex; align-items:center; gap:8px;
}

/* ── VAN SERVICE LIST (Lee page) ── */
.van-svc-list { list-style:none; display:flex; flex-direction:column; gap:10px; }
.van-svc-list li {
  display:flex; align-items:flex-start; gap:10px;
  font-size:0.88rem; color:var(--text-muted); line-height:1.6;
}
.van-svc-list li .vi { font-size:1rem; flex-shrink:0; margin-top:2px; }

/* ── LOCAL PAGE – BOOKING NOTE ── */
.local-booking {
  background:rgba(37,99,235,0.06); border:1px solid rgba(37,99,235,0.2);
  border-radius:14px; padding:24px 28px; margin-top:48px;
}
.local-booking h4 { color:var(--secondary); margin-bottom:10px; }
.local-booking p  { font-size:0.86rem; }

@media(max-width:768px) {
  .cat-header { flex-direction:column; align-items:flex-start; gap:10px; }
}

/* ── HIGHLIGHT BOXES ── */
.highlight-box {
  background:rgba(37,99,235,0.07); border:1px solid rgba(37,99,235,0.18);
  border-radius:16px; padding:28px 24px; margin-bottom:16px;
}
.highlight-box h4 { color:var(--secondary); margin-bottom:10px; }
.highlight-box-alt {
  background:rgba(56,189,248,0.05); border:1px solid rgba(56,189,248,0.15);
  border-radius:16px; padding:28px 24px;
}
.highlight-box-alt h4 { color:var(--accent); margin-bottom:10px; }

/* ══ UTILITY & OVERRIDE CLASSES ══ */

/* Padding */
.pt-0  { padding-top: 0; }
.pt-48 { padding-top: 48px; }
.pt-64 { padding-top: 64px; }
.pt-72 { padding-top: 72px; }

/* Margin helpers */
.mt-8  { margin-top: 8px; }
.mt-10 { margin-top: 10px; }
.mt-14 { margin-top: 14px; }
.mt-16 { margin-top: 16px; }
.mt-18 { margin-top: 18px; }
.mt-22 { margin-top: 22px; }
.mb-20 { margin-bottom: 20px; }
.mb-24 { margin-bottom: 24px; }
.mb-48 { margin-bottom: 48px; }
.mb-56 { margin-bottom: 56px; }

/* Typography helpers */
.text-secondary { color: var(--secondary); }
.text-base      { color: var(--text); }
.c-muted        { color: var(--text-muted); }
.link-accent    { color: var(--secondary); font-weight: 600; }
.cursor-default { cursor: default; }
.note-sm        { margin-top: 22px; font-size: 0.82rem; color: var(--text-muted); }

/* Page hero description paragraph */
.ph-desc { font-size: 1.05rem; max-width: 640px; margin: 18px auto 0; }

/* Highlight box variants */
.highlight-box-first { margin-bottom: 20px; }
.highlight-box-alt   { border-color: rgba(0,217,245,0.22); background: rgba(0,217,245,0.06); }
.hb-text             { font-size: 0.86rem; margin-top: 8px; }

/* Affiliate accent colours */
.label-lee { color: #ffb340; }
.label-kd  { color: #c0132e; }

/* Button row layouts */
.btn-row        { margin-top: 28px; display: flex; gap: 14px; flex-wrap: wrap; }
.btn-row-32     { margin-top: 32px; display: flex; gap: 14px; flex-wrap: wrap; }
.btn-row-center { margin-top: 32px; display: flex; gap: 14px; flex-wrap: wrap; justify-content: center; }

/* Lee affiliate — card accents */
.card-lee      { border-top: 3px solid #ffb340; }
.card-icon-lee { background: rgba(255,179,64,0.1); border-color: rgba(255,179,64,0.25); }
.card-icon-md  { font-size: 1.6rem; }

/* CTA banner accent borders */
.cta-banner-lee { border-color: rgba(255,179,64,0.25); }
.cta-banner-kd  { border-color: rgba(139,0,30,0.25); }

/* Format badge row */
.format-badge-row { margin-top: 22px; display: flex; flex-wrap: wrap; gap: 10px; }

/* Centred max-width card */
.card-wide { max-width: 800px; margin: 0 auto; }
