/* ═══════════════════════════════════════════════════════════════
   CostaCraft Design System v3.0 — Production Ready
═══════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Plus+Jakarta+Sans:wght@400;500;600;700;800;900&display=swap');

/* ─── Custom Properties ─── */
:root {
  --bg:        #060810;
  --bg-2:      #0a0e1a;
  --surface:   #0d1121;
  --surface-2: #111827;
  --card:      rgba(13,17,33,0.75);
  --card-hov:  rgba(17,24,39,0.95);
  --border:    rgba(55,65,81,0.45);
  --border-l:  rgba(75,85,99,0.6);
  --border-hi: rgba(99,102,241,0.35);

  --indigo:   #6366f1;
  --indigo-l: #818cf8;
  --indigo-d: #4f46e5;
  --purple:   #a855f7;
  --purple-l: #c084fc;
  --green:    #22c55e;
  --discord:  #5865F2;

  --text:   #f1f5f9;
  --text-2: #cbd5e1;
  --text-3: #94a3b8;
  --text-4: #64748b;
  --text-5: #475569;

  --font-body:    'Inter', system-ui, -apple-system, sans-serif;
  --font-display: 'Plus Jakarta Sans', 'Inter', sans-serif;

  --r-sm:   6px;
  --r-md:   10px;
  --r-lg:   14px;
  --r-xl:   20px;
  --r-2xl:  28px;
  --r-full: 9999px;

  --shadow-xs: 0 1px 4px rgba(0,0,0,0.25);
  --shadow-sm: 0 2px 10px rgba(0,0,0,0.3);
  --shadow-md: 0 8px 32px rgba(0,0,0,0.45);
  --shadow-lg: 0 16px 60px rgba(0,0,0,0.55);
  --glow-i:    0 0 40px rgba(99,102,241,0.2);
  --glow-p:    0 0 40px rgba(168,85,247,0.2);

  --ease-out: cubic-bezier(0.16,1,0.3,1);
  --ease-bounce: cubic-bezier(0.34,1.56,0.64,1);
}

/* ─── Reset ─── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--text);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  line-height: 1.6;
}
img,svg,video { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
button { cursor:pointer; font-family:inherit; border:none; background:none; }
input,textarea,select { font-family:inherit; font-size:inherit; }
ul { list-style:none; }
h1,h2,h3,h4,h5,h6 { font-family:var(--font-display); line-height:1.15; }

/* ─── Scrollbar ─── */
::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:var(--bg-2); }
::-webkit-scrollbar-thumb { background:linear-gradient(180deg,var(--indigo),var(--purple)); border-radius:var(--r-full); }

/* ─── Selection ─── */
::selection { background:rgba(99,102,241,0.28); color:#fff; }

/* ─── Focus visible ─── */
:focus-visible { outline:2px solid var(--indigo-l); outline-offset:3px; border-radius:var(--r-sm); }

/* ─── Typography helpers ─── */
.text-gradient {
  background:linear-gradient(135deg,var(--indigo-l),var(--purple-l));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}

/* ═══════════════════════════
   LOADER
═══════════════════════════ */
#cc-loader {
  position:fixed; inset:0; z-index:99999;
  background:radial-gradient(ellipse at 50% 50%, #0a0d1f 0%, #050810 100%);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px;
  transition: opacity 0.55s var(--ease-out), transform 0.55s var(--ease-out);
}
#cc-loader.hide { opacity:0; pointer-events:none; transform:scale(1.03); }

.loader-ring {
  width:52px; height:52px; border-radius:50%;
  border:2.5px solid rgba(99,102,241,0.15);
  border-top-color:var(--indigo);
  animation:spin .8s linear infinite;
}
.loader-text { font-size:0.7rem; font-weight:700; letter-spacing:0.14em; text-transform:uppercase; color:var(--indigo-l); opacity:0.8; }
.loader-bar-wrap { width:100px; height:2px; background:rgba(255,255,255,0.07); border-radius:var(--r-full); overflow:hidden; }
.loader-bar-fill { height:100%; background:linear-gradient(90deg,var(--indigo),var(--purple)); border-radius:var(--r-full); animation:loader-progress 1.1s ease-in-out infinite; }

@keyframes spin { to { transform:rotate(360deg); } }
@keyframes loader-progress { 0%{width:0;opacity:1} 70%{width:80%} 100%{width:100%;opacity:0} }

/* ═══════════════════════════
   NAVBAR
═══════════════════════════ */
.navbar {
  position:fixed; top:0; left:0; right:0; z-index:500;
  height:68px;
  transition: background 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
}
.navbar.scrolled {
  background:rgba(6,8,16,0.92);
  backdrop-filter:blur(24px); -webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid rgba(99,102,241,0.1);
  box-shadow:0 4px 28px rgba(0,0,0,0.35);
}
.navbar-inner {
  max-width:1260px; margin:0 auto; padding:0 24px;
  height:100%; display:flex; align-items:center; gap:24px;
}

/* Logo */
.logo { display:flex; align-items:center; gap:9px; flex-shrink:0; transition:transform 0.2s var(--ease-bounce); }
.logo:hover { transform:scale(1.03); }
.logo img { width:38px; height:38px; object-fit:contain; filter:drop-shadow(0 0 10px rgba(99,102,241,0.45)); transition:filter 0.3s; }
.logo:hover img { filter:drop-shadow(0 0 16px rgba(99,102,241,0.7)); }
.logo-text { font-family:var(--font-display); font-size:1.1rem; font-weight:800; line-height:1; }
.logo-text span:first-child { color:rgba(255,255,255,0.9); }
.logo-text .accent { background:linear-gradient(135deg,var(--indigo-l),var(--purple-l)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.logo-text .dot { color:var(--purple-l); }

/* Desktop nav links */
.nav-desktop { display:flex; align-items:center; gap:1px; }
@media (max-width:1023px) { .nav-desktop { display:none; } }

.nav-link-d {
  position:relative; padding:7px 13px;
  font-size:0.85rem; font-weight:500; color:var(--text-3);
  border-radius:var(--r-md);
  transition:color 0.15s, background 0.15s;
}
.nav-link-d:hover { color:var(--text); background:rgba(255,255,255,0.055); }
.nav-link-d.active { color:var(--indigo-l); background:rgba(99,102,241,0.1); }
.nav-link-d.active::after {
  content:''; position:absolute; bottom:3px; left:50%; transform:translateX(-50%);
  width:14px; height:2px; background:var(--indigo-l); border-radius:var(--r-full);
}

/* Nav right */
.nav-actions { display:flex; align-items:center; gap:8px; margin-left:auto; }
@media (max-width:1023px) { .nav-actions { display:none; } }

/* ─── Language Switcher (FIXED & POLISHED) ─── */
.lang-switcher { position:relative; }

.lang-btn {
  display:flex; align-items:center; gap:6px;
  padding:6px 11px; font-size:0.8rem; font-weight:600;
  color:var(--text-3); cursor:pointer;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  transition:all 0.15s;
  user-select:none; white-space:nowrap;
}
.lang-btn:hover { color:var(--text); background:rgba(255,255,255,0.08); border-color:var(--border-l); }
.lang-btn .chevron-icon { transition:transform 0.22s ease; flex-shrink:0; }
.lang-btn.open { color:var(--indigo-l); background:rgba(99,102,241,0.1); border-color:var(--border-hi); }
.lang-btn.open .chevron-icon { transform:rotate(180deg); }

.lang-dropdown {
  position:absolute; top:calc(100% + 7px); right:0;
  min-width:168px;
  background:rgba(8,11,22,0.98);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border:1px solid var(--border);
  border-radius:var(--r-xl);
  padding:5px;
  box-shadow:var(--shadow-lg), 0 0 0 1px rgba(255,255,255,0.03);
  z-index:600;
  /* Hidden state */
  opacity:0; visibility:hidden;
  transform:translateY(-8px) scale(0.97);
  transform-origin:top right;
  transition:opacity 0.2s ease, transform 0.2s var(--ease-out), visibility 0.2s;
  pointer-events:none;
}
.lang-dropdown.open {
  opacity:1; visibility:visible;
  transform:translateY(0) scale(1);
  pointer-events:auto;
}
.lang-dropdown a {
  display:flex; align-items:center; gap:9px;
  padding:8px 11px; font-size:0.82rem; font-weight:500;
  color:var(--text-3); border-radius:var(--r-md);
  transition:all 0.13s;
}
.lang-dropdown a:hover { color:var(--text); background:rgba(255,255,255,0.065); }
.lang-dropdown a.current { color:var(--indigo-l); background:rgba(99,102,241,0.11); }
.lang-dropdown a.current svg { color:var(--indigo-l); margin-left:auto; }
.lang-divider { height:1px; background:var(--border); margin:4px 6px; }
.lang-secondary { opacity:0.75 !important; }
.lang-secondary:hover { opacity:1 !important; }

/* Nav buttons */
.btn-wa {
  display:flex; align-items:center; gap:6px;
  padding:7px 13px; font-size:0.8rem; font-weight:600;
  color:var(--green); background:rgba(34,197,94,0.08);
  border:1px solid rgba(34,197,94,0.2); border-radius:var(--r-md);
  transition:all 0.15s;
}
.btn-wa:hover { color:#fff; background:rgba(34,197,94,0.18); border-color:rgba(34,197,94,0.45); }

.btn-panel {
  display:flex; align-items:center; gap:6px;
  padding:8px 16px; font-size:0.8rem; font-weight:700;
  color:#fff; background:linear-gradient(135deg,var(--indigo-d),var(--indigo));
  border-radius:var(--r-md);
  transition:all 0.2s;
  box-shadow:0 2px 14px rgba(99,102,241,0.3);
}
.btn-panel:hover { background:linear-gradient(135deg,var(--indigo),var(--purple)); transform:translateY(-1px); box-shadow:0 4px 20px rgba(99,102,241,0.4); }

/* ─── Mobile Toggle ─── */
.mobile-toggle {
  display:none; width:40px; height:40px;
  align-items:center; justify-content:center;
  border:1px solid var(--border); border-radius:var(--r-md);
  background:rgba(255,255,255,0.04); color:var(--text-3);
  margin-left:auto; transition:all 0.15s;
}
.mobile-toggle:hover { background:rgba(255,255,255,0.08); color:var(--text); }
@media (max-width:1023px) { .mobile-toggle { display:flex; } }

.burger-wrap { display:flex; flex-direction:column; gap:4.5px; pointer-events:none; }
.burger-line { display:block; width:19px; height:2px; background:currentColor; border-radius:2px; transition:all 0.3s var(--ease-out); transform-origin:center; }

/* ─── Mobile Overlay ─── */
.mobile-overlay {
  display:none; position:fixed; inset:0; z-index:480;
  background:rgba(0,0,0,0.6); backdrop-filter:blur(3px);
  opacity:0; transition:opacity 0.3s ease; pointer-events:none;
}
.mobile-overlay.open { opacity:1; pointer-events:auto; }
@media (max-width:1023px) { .mobile-overlay { display:block; } }

/* ─── Mobile Drawer ─── */
.mobile-drawer {
  position:fixed; top:0; right:0; bottom:0; z-index:510;
  width:290px; max-width:88vw;
  display:flex; flex-direction:column;
  background:rgba(6,8,16,0.99);
  border-left:1px solid rgba(99,102,241,0.12);
  transform:translateX(100%);
  transition:transform 0.32s var(--ease-out);
  overflow-y:auto;
}
.mobile-drawer.open { transform:translateX(0); }

.drawer-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 18px 14px;
  border-bottom:1px solid rgba(255,255,255,0.055);
  flex-shrink:0;
}
.drawer-close {
  width:32px; height:32px; display:flex; align-items:center; justify-content:center;
  border-radius:var(--r-md); color:var(--text-4); transition:all 0.15s;
}
.drawer-close:hover { background:rgba(255,255,255,0.07); color:var(--text); }

.drawer-nav { flex:1; padding:12px 14px; display:flex; flex-direction:column; gap:2px; }
.drawer-link {
  display:flex; align-items:center; gap:11px;
  padding:11px 13px; border-radius:var(--r-lg);
  font-size:0.9rem; font-weight:500; color:var(--text-3);
  transition:all 0.13s;
}
.drawer-link:hover { color:var(--text); background:rgba(255,255,255,0.055); }
.drawer-link.active { color:var(--indigo-l); background:rgba(99,102,241,0.11); }
.drawer-icon { font-size:1rem; width:20px; text-align:center; flex-shrink:0; }

.drawer-lang-section {
  padding:10px 14px 12px;
  border-top:1px solid rgba(255,255,255,0.055);
  flex-shrink:0;
}
.drawer-lang-label {
  font-size:0.68rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase;
  color:var(--text-5); padding:0 4px 7px;
}
.drawer-lang-grid { display:grid; grid-template-columns:1fr 1fr; gap:5px; }
.drawer-lang-btn {
  display:flex; align-items:center; gap:7px;
  padding:8px 10px; border-radius:var(--r-md);
  font-size:0.8rem; font-weight:500; color:var(--text-4);
  border:1px solid transparent; transition:all 0.13s;
}
.drawer-lang-btn:hover { color:var(--text); background:rgba(255,255,255,0.055); border-color:var(--border); }
.drawer-lang-btn.current { color:var(--indigo-l); background:rgba(99,102,241,0.11); border-color:rgba(99,102,241,0.28); }

.drawer-footer {
  padding:12px 14px 20px; border-top:1px solid rgba(255,255,255,0.055);
  display:flex; flex-direction:column; gap:7px; flex-shrink:0;
}
.drawer-btn-wa {
  display:flex; align-items:center; justify-content:center; gap:8px;
  padding:12px; border-radius:var(--r-lg);
  font-weight:700; font-size:0.875rem; color:#fff;
  background:var(--accent); transition:background 0.15s;
}
.drawer-btn-wa:hover { background:#16a34a; }
.drawer-btn-panel {
  display:flex; align-items:center; justify-content:center; gap:8px;
  padding:12px; border-radius:var(--r-lg);
  font-weight:700; font-size:0.875rem; color:#fff;
  background:var(--indigo); transition:background 0.15s;
}
.drawer-btn-panel:hover { background:var(--indigo-d); }

/* ═══════════════════════════
   LAYOUT
═══════════════════════════ */
.container { max-width:1260px; margin:0 auto; padding:0 24px; }
@media (max-width:639px) { .container { padding:0 16px; } }

.section { padding:80px 0; }
.section-surface { background:var(--surface); }
.section-dark { background:var(--bg); }

.grid-bg {
  background-image:
    linear-gradient(rgba(99,102,241,0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(99,102,241,0.035) 1px, transparent 1px);
  background-size:52px 52px;
}

/* ─── Reveal animations ─── */
.reveal-up, .reveal-left, .reveal-right, .reveal-scale {
  opacity:0;
  transition:opacity 0.65s var(--ease-out), transform 0.65s var(--ease-out);
}
.reveal-up    { transform:translateY(28px); }
.reveal-left  { transform:translateX(-28px); }
.reveal-right { transform:translateX(28px); }
.reveal-scale { transform:scale(0.92); }
.revealed { opacity:1 !important; transform:none !important; }

/* ─── Buttons ─── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:12px 26px; font-size:0.9375rem; font-weight:700;
  border-radius:var(--r-full); font-family:var(--font-display);
  transition:all 0.25s var(--ease-out);
  cursor:pointer; white-space:nowrap; text-decoration:none;
  position:relative; overflow:hidden;
}
.btn::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,0.08),rgba(255,255,255,0));
  opacity:0; transition:opacity 0.2s;
}
.btn:hover::after { opacity:1; }

.btn-primary {
  background:linear-gradient(135deg,var(--indigo-d),var(--indigo));
  color:#fff; box-shadow:0 4px 22px rgba(99,102,241,0.32);
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 32px rgba(99,102,241,0.45); }
.btn-primary:active { transform:translateY(0); }

.btn-secondary {
  background:rgba(255,255,255,0.055);
  color:var(--text-2); border:1px solid var(--border);
}
.btn-secondary:hover { background:rgba(255,255,255,0.09); color:#fff; border-color:var(--border-hi); transform:translateY(-2px); }

.btn-green {
  background:linear-gradient(135deg,#16a34a,#22c55e);
  color:#fff; box-shadow:0 4px 22px rgba(34,197,94,0.3);
}
.btn-green:hover { transform:translateY(-2px); box-shadow:0 8px 32px rgba(34,197,94,0.42); }

.btn-lg { padding:15px 32px; font-size:1rem; }
.btn-sm { padding:8px 18px; font-size:0.8125rem; }

/* ─── Section Headers ─── */
.section-eyebrow {
  display:inline-flex; align-items:center; gap:7px;
  font-size:0.73rem; font-weight:700; letter-spacing:0.11em; text-transform:uppercase;
  color:var(--indigo-l);
  background:rgba(99,102,241,0.09);
  border:1px solid rgba(99,102,241,0.22);
  border-radius:var(--r-full); padding:4px 13px;
  margin-bottom:14px;
}
.section-title { font-size:clamp(1.75rem,3.5vw,2.6rem); font-weight:800; color:var(--text); margin-bottom:14px; }
.section-sub { font-size:1.0625rem; color:var(--text-3); line-height:1.72; max-width:560px; }

.section-header { text-align:center; margin-bottom:52px; }
.section-header .section-sub { margin:0 auto; }

/* ─── Tags ─── */
.tag {
  display:inline-flex; align-items:center; gap:5px;
  font-size:0.73rem; font-weight:700; padding:4px 11px;
  border-radius:var(--r-full); margin-bottom:12px;
  background:rgba(99,102,241,0.1); color:var(--indigo-l);
  border:1px solid rgba(99,102,241,0.22);
}
.tag-p { background:rgba(168,85,247,0.1); color:var(--purple-l); border-color:rgba(168,85,247,0.22); }

/* ─── Cards ─── */
.card {
  background:var(--card);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border:1px solid var(--border); border-radius:var(--r-xl);
  transition:all 0.28s var(--ease-out);
}
.card:hover { background:var(--card-hov); border-color:var(--border-hi); transform:translateY(-3px); box-shadow:var(--shadow-md); }

/* ═══════════════════════════
   HERO
═══════════════════════════ */
.hero {
  min-height:100vh; position:relative; overflow:hidden;
  display:flex; align-items:center; justify-content:center;
  padding:100px 0 80px;
}
#particles-canvas { position:absolute; inset:0; width:100%; height:100%; pointer-events:none; z-index:0; }

.hero-orb {
  position:absolute; border-radius:50%; filter:blur(90px);
  animation:orb-pulse 5s ease-in-out infinite; pointer-events:none; z-index:0;
}
.hero-orb-1 { width:560px; height:560px; background:rgba(99,102,241,0.07); top:-10%; left:-12%; }
.hero-orb-2 { width:480px; height:480px; background:rgba(168,85,247,0.07); bottom:0; right:-10%; animation-delay:2.5s; }
@keyframes orb-pulse { 0%,100%{opacity:.5;transform:scale(1)} 50%{opacity:.8;transform:scale(1.06)} }

.hero .container { position:relative; z-index:1; width:100%; }
.hero-inner { text-align:center; max-width:860px; margin:0 auto; }

.hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(99,102,241,0.09); border:1px solid rgba(99,102,241,0.24);
  border-radius:var(--r-full); padding:6px 16px;
  font-size:0.82rem; font-weight:600; color:var(--indigo-l);
  margin-bottom:22px;
}
.pulse-dot {
  width:7px; height:7px; border-radius:50%; background:var(--indigo-l); position:relative; flex-shrink:0;
}
.pulse-dot::after {
  content:''; position:absolute; inset:-3px; border-radius:50%;
  background:var(--indigo-l); opacity:.4;
  animation:ping 1.6s ease infinite;
}
@keyframes ping { 0%{transform:scale(1);opacity:.4} 100%{transform:scale(2.4);opacity:0} }

.hero-title {
  font-size:clamp(2.4rem,6vw,4.4rem); font-weight:900; line-height:1.08;
  letter-spacing:-0.025em; color:var(--text); margin-bottom:18px;
}
.title-gradient {
  background:linear-gradient(90deg,var(--indigo-l),var(--purple-l),var(--indigo-l));
  background-size:200%;
  animation:gradient-pan 4s ease infinite;
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
@keyframes gradient-pan { 0%,100%{background-position:0% 50%} 50%{background-position:100% 50%} }

.hero-sub { font-size:clamp(1rem,2vw,1.18rem); color:var(--text-3); max-width:580px; margin:0 auto 36px; line-height:1.72; }

.hero-ctas { display:flex; flex-wrap:wrap; gap:12px; justify-content:center; margin-bottom:52px; }

.hero-stats {
  display:flex; justify-content:center; gap:44px;
  padding-top:36px; border-top:1px solid rgba(255,255,255,0.055);
  flex-wrap:wrap; gap:32px;
}
.stat-item { text-align:center; }
.stat-num { font-size:1.9rem; font-weight:900; font-family:var(--font-display); color:var(--text); font-variant-numeric:tabular-nums; }
.stat-label { font-size:0.78rem; color:var(--text-4); margin-top:2px; letter-spacing:0.04em; }

.scroll-hint {
  display:flex; flex-direction:column; align-items:center; gap:7px;
  color:var(--text-5); font-size:0.7rem; letter-spacing:0.1em; text-transform:uppercase;
  margin-top:44px;
}
.scroll-hint-line {
  width:1px; height:32px;
  background:linear-gradient(180deg,var(--text-5),transparent);
  animation:scroll-anim 2s ease-in-out infinite;
}
@keyframes scroll-anim { 0%,100%{opacity:.4;transform:scaleY(1)} 50%{opacity:.9;transform:scaleY(.55)} }

/* ═══════════════════════════
   FEATURE CARDS
═══════════════════════════ */
.features-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(272px,1fr));
  gap:18px;
}
.feature-card {
  background:rgba(13,17,33,0.55); border:1px solid var(--border);
  border-radius:var(--r-xl); padding:26px;
  transition:all 0.28s var(--ease-out);
}
.feature-card:hover {
  background:rgba(17,24,39,0.85); border-color:var(--border-hi);
  transform:translateY(-4px); box-shadow:var(--shadow-md);
}
.feature-icon {
  width:50px; height:50px;
  background:rgba(99,102,241,0.12); border:1px solid rgba(99,102,241,0.2);
  border-radius:var(--r-lg);
  display:flex; align-items:center; justify-content:center;
  font-size:1.4rem; margin-bottom:15px;
  transition:all 0.25s;
}
.feature-card:hover .feature-icon { background:rgba(99,102,241,0.2); transform:scale(1.06); }
.feature-card-title { font-weight:700; font-size:0.975rem; color:var(--text); margin-bottom:7px; font-family:var(--font-display); }
.feature-card-desc { font-size:0.865rem; color:var(--text-3); line-height:1.66; }

/* ═══════════════════════════
   PLAN CARDS
═══════════════════════════ */
.plans-group { margin-bottom:16px; }
.plans-header {
  display:flex; align-items:flex-end; justify-content:space-between;
  margin-bottom:28px; flex-wrap:wrap; gap:12px;
}
.plans-title { font-size:clamp(1.5rem,2.5vw,2rem); font-weight:800; color:var(--text); margin-top:8px; margin-bottom:4px; }
.plans-sub { color:var(--text-3); font-size:0.9375rem; }
.see-all-link { font-size:0.85rem; color:var(--indigo-l); font-weight:600; transition:color 0.15s, gap 0.15s; display:flex; align-items:center; gap:4px; flex-shrink:0; }
.see-all-link:hover { color:var(--indigo); }
.see-all-link-p { color:var(--purple-l); }
.see-all-link-p:hover { color:var(--purple); }

.plans-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(268px,1fr)); gap:18px; }

.plan-card {
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--r-2xl); padding:26px;
  display:flex; flex-direction:column; gap:18px;
  position:relative; overflow:hidden;
  transition:transform 0.25s var(--ease-out), box-shadow 0.25s, border-color 0.25s;
}
.plan-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-md); }
.plan-card.featured { border-color:var(--indigo); box-shadow:0 0 0 1px var(--indigo),0 8px 40px rgba(99,102,241,0.14); }
.plan-card.featured:hover { box-shadow:0 0 0 1px var(--indigo),0 16px 50px rgba(99,102,241,0.24); }
.plan-card[data-color="p"].featured { border-color:var(--purple); box-shadow:0 0 0 1px var(--purple),0 8px 40px rgba(168,85,247,0.14); }
.plan-card[data-color="p"].featured:hover { box-shadow:0 0 0 1px var(--purple),0 16px 50px rgba(168,85,247,0.24); }

.plan-card-top { position:absolute; top:0; left:0; right:0; height:3px; }

.plan-badge-wrap { position:absolute; top:18px; right:18px; }
.plan-badge {
  display:inline-flex; align-items:center; gap:4px;
  font-size:0.68rem; font-weight:700; letter-spacing:0.07em; text-transform:uppercase;
  padding:3px 9px; border-radius:var(--r-full); border:1px solid;
}
.plan-badge-i { background:rgba(99,102,241,0.12); color:var(--indigo-l); border-color:rgba(99,102,241,0.28); }
.plan-badge-p { background:rgba(168,85,247,0.12); color:var(--purple-l); border-color:rgba(168,85,247,0.28); }

.plan-header { flex-shrink:0; }
.plan-name { font-size:1.15rem; font-weight:800; color:var(--text); font-family:var(--font-display); }
.plan-desc { font-size:0.845rem; color:var(--text-3); margin-top:4px; }

.plan-price { display:flex; align-items:baseline; gap:5px; }
.plan-price-num { font-size:2rem; font-weight:900; color:var(--text); font-family:var(--font-display); font-variant-numeric:tabular-nums; }
.plan-price-period { font-size:0.845rem; color:var(--text-4); }

.plan-divider { height:1px; background:linear-gradient(90deg,transparent,var(--border),transparent); flex-shrink:0; }

.plan-features { display:flex; flex-direction:column; gap:9px; flex:1; }
.plan-feature-item { display:flex; align-items:center; gap:9px; font-size:0.855rem; color:var(--text-2); }
.plan-check {
  width:17px; height:17px; flex-shrink:0; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
}
.plan-check-i { background:rgba(99,102,241,0.14); color:var(--indigo-l); }
.plan-check-p { background:rgba(168,85,247,0.14); color:var(--purple-l); }

.plan-cta {
  display:flex; align-items:center; justify-content:center;
  width:100%; padding:13px; font-weight:700; font-size:0.9rem;
  border-radius:var(--r-lg); color:#fff; font-family:var(--font-display);
  transition:all 0.22s var(--ease-out);
  position:relative; overflow:hidden;
}
.plan-cta-i { background:linear-gradient(135deg,var(--indigo-d),var(--indigo)); box-shadow:0 3px 14px rgba(99,102,241,0.22); }
.plan-cta-i:hover { background:linear-gradient(135deg,var(--indigo),var(--purple)); box-shadow:0 6px 22px rgba(99,102,241,0.38); transform:translateY(-1px); }
.plan-cta-p { background:linear-gradient(135deg,#7c3aed,var(--purple)); box-shadow:0 3px 14px rgba(168,85,247,0.22); }
.plan-cta-p:hover { background:linear-gradient(135deg,var(--purple),var(--purple-l)); box-shadow:0 6px 22px rgba(168,85,247,0.38); transform:translateY(-1px); }

/* ═══════════════════════════
   CTA SECTION
═══════════════════════════ */
.cta-banner {
  position:relative; overflow:hidden;
  background:radial-gradient(ellipse at 50% -10%, rgba(99,102,241,0.1) 0%, transparent 65%);
  border:1px solid rgba(99,102,241,0.14);
  border-radius:var(--r-2xl); padding:68px 48px;
  text-align:center;
}
@media (max-width:639px) { .cta-banner { padding:44px 22px; } }
.cta-glow {
  position:absolute; top:-60px; left:50%; transform:translateX(-50%);
  width:400px; height:200px; border-radius:50%;
  background:rgba(99,102,241,0.08); filter:blur(60px); pointer-events:none;
}
.cta-inner { position:relative; z-index:1; }
.cta-title { font-size:clamp(1.75rem,3.5vw,2.6rem); font-weight:900; color:var(--text); margin-bottom:14px; }
.cta-sub { font-size:1.05rem; color:var(--text-3); max-width:520px; margin:0 auto 32px; line-height:1.7; }
.cta-btns { display:flex; flex-wrap:wrap; gap:12px; justify-content:center; margin-bottom:18px; }
.cta-payment-note { font-size:0.78rem; color:var(--text-5); }

/* ═══════════════════════════
   PAGE HERO
═══════════════════════════ */
.page-hero {
  padding:130px 0 60px; text-align:center;
  background:radial-gradient(ellipse at 50% 0%,rgba(99,102,241,0.07) 0%,transparent 65%);
  position:relative;
}
.page-hero-title { font-size:clamp(1.9rem,4vw,3rem); font-weight:900; margin-bottom:14px; margin-top:12px; }
.page-hero-sub { font-size:1.05rem; color:var(--text-3); max-width:500px; margin:0 auto; line-height:1.7; }

/* ═══════════════════════════
   FOOTER
═══════════════════════════ */
.footer { background:var(--surface); border-top:1px solid var(--border); padding:60px 0 28px; }
.footer-grid {
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:44px;
  padding-bottom:44px; border-bottom:1px solid var(--border); margin-bottom:28px;
}
@media (max-width:1023px) { .footer-grid { grid-template-columns:1fr 1fr; gap:32px; } }
@media (max-width:639px) { .footer-grid { grid-template-columns:1fr; gap:28px; } }

.footer-logo { text-decoration:none; }
.footer-brand-desc { font-size:0.855rem; color:var(--text-3); line-height:1.7; margin-top:11px; }
.footer-social { display:flex; gap:8px; margin-top:18px; }
.footer-social-btn {
  width:34px; height:34px; display:flex; align-items:center; justify-content:center;
  border-radius:var(--r-md); background:rgba(255,255,255,0.045); border:1px solid var(--border);
  color:var(--text-3); transition:all 0.15s;
}
.footer-social-btn:hover { background:rgba(99,102,241,0.14); border-color:rgba(99,102,241,0.28); color:var(--indigo-l); }

.footer-heading { font-size:0.7rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--text-4); margin-bottom:14px; }
.footer-links { display:flex; flex-direction:column; gap:9px; }
.footer-links a { font-size:0.855rem; color:var(--text-3); transition:color 0.13s; }
.footer-links a:hover { color:var(--indigo-l); }

.footer-bottom { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:10px; }
.footer-bottom p { font-size:0.8rem; color:var(--text-5); }
.footer-bottom-links { display:flex; gap:18px; }
.footer-bottom-links a { font-size:0.8rem; color:var(--text-5); transition:color 0.13s; }
.footer-bottom-links a:hover { color:var(--text-3); }

/* ═══════════════════════════
   FAB DIAL
═══════════════════════════ */
#cc-dial { position:fixed; right:20px; bottom:22px; z-index:450; display:flex; flex-direction:column; align-items:flex-end; gap:9px; }
.dial-items { display:flex; flex-direction:column; gap:7px; align-items:flex-end; }
.dial-item-btn {
  display:flex; align-items:center; gap:9px;
  padding:9px 15px; border-radius:var(--r-full);
  font-size:0.855rem; font-weight:700; color:#fff;
  box-shadow:var(--shadow-md); white-space:nowrap;
  animation:dial-slide-in 0.3s var(--ease-out);
  transition:transform 0.2s var(--ease-out), box-shadow 0.2s;
}
.dial-item-btn:hover { transform:translateX(-3px); }
@keyframes dial-slide-in { from{opacity:0;transform:translateX(16px) scale(0.9)} to{opacity:1;transform:none} }
.dial-discord { background:var(--discord); box-shadow:0 4px 18px rgba(88,101,242,0.38); }
.dial-wa { background:#25D366; box-shadow:0 4px 18px rgba(37,211,102,0.38); }

.dial-toggle {
  width:54px; height:54px; border-radius:50%;
  background:linear-gradient(135deg,var(--indigo-d),var(--indigo));
  color:#fff; display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 20px rgba(99,102,241,0.45);
  transition:all 0.25s var(--ease-out);
}
.dial-toggle:hover { transform:scale(1.07); box-shadow:0 6px 28px rgba(99,102,241,0.55); }
.dial-toggle.open { background:linear-gradient(135deg,#374151,#4b5563); }

/* ═══════════════════════════
   FORMS
═══════════════════════════ */
.form-group { display:flex; flex-direction:column; gap:5px; margin-bottom:14px; }
.form-label { font-size:0.845rem; font-weight:600; color:var(--text-2); }
.form-input, .form-textarea, .form-select {
  width:100%; background:rgba(13,17,33,0.65); border:1.5px solid var(--border);
  border-radius:var(--r-md); padding:11px 14px; color:var(--text);
  font-size:0.9375rem; outline:none;
  transition:border-color 0.18s, box-shadow 0.18s, background 0.18s;
}
.form-input::placeholder, .form-textarea::placeholder { color:var(--text-5); }
.form-input:hover, .form-textarea:hover { border-color:var(--border-l); }
.form-input:focus, .form-textarea:focus {
  border-color:var(--indigo); background:rgba(17,24,39,0.8);
  box-shadow:0 0 0 3px rgba(99,102,241,0.14);
}
.form-input.error, .form-textarea.error { border-color:#ef4444; box-shadow:0 0 0 3px rgba(239,68,68,0.12); }
.form-textarea { resize:vertical; min-height:118px; }
.form-error { font-size:0.78rem; color:#f87171; margin-top:3px; min-height:16px; }

.submit-btn { width:100%; border-radius:var(--r-lg); padding:14px; font-size:0.95rem; margin-top:4px; }
.submit-btn:disabled { opacity:0.65; cursor:not-allowed; transform:none !important; }

/* ═══════════════════════════
   CONTACT PAGE
═══════════════════════════ */
.contact-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start;
}
@media (max-width:767px) { .contact-grid { grid-template-columns:1fr; gap:32px; } }

.contact-section-h { font-size:1.4rem; font-weight:800; color:var(--text); margin-bottom:22px; font-family:var(--font-display); }
.contact-channels { display:flex; flex-direction:column; gap:11px; }
.contact-form-card { padding:30px; }

.contact-channel {
  display:flex; align-items:center; gap:15px;
  padding:18px; background:rgba(13,17,33,0.5); border:1px solid var(--border);
  border-radius:var(--r-xl); transition:all 0.25s var(--ease-out);
}
.contact-channel:hover { background:rgba(17,24,39,0.85); transform:translateY(-2px); box-shadow:var(--shadow-sm); }
.contact-ch-icon { width:48px; height:48px; border-radius:var(--r-lg); display:flex; align-items:center; justify-content:center; font-size:1.4rem; flex-shrink:0; }
.cc-wa { background:rgba(34,197,94,0.12); border:1px solid rgba(34,197,94,0.2); }
.cc-dc { background:rgba(88,101,242,0.12); border:1px solid rgba(88,101,242,0.2); }
.cc-mail { background:rgba(56,189,248,0.12); border:1px solid rgba(56,189,248,0.2); }
.cc-wa-link:hover { border-color:rgba(34,197,94,0.38); }
.cc-dc-link:hover { border-color:rgba(88,101,242,0.38); }
.cc-mail-link:hover { border-color:rgba(56,189,248,0.38); }
.contact-ch-name { font-weight:700; font-size:0.975rem; color:var(--text); }
.contact-ch-desc { font-size:0.845rem; color:var(--text-3); margin-top:2px; }
.contact-ch-arrow { margin-left:auto; color:var(--text-4); flex-shrink:0; transition:transform 0.18s; }
.contact-channel:hover .contact-ch-arrow { transform:translateX(3px); color:var(--text-2); }

/* ═══════════════════════════
   ABOUT PAGE
═══════════════════════════ */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:start; }
@media (max-width:767px) { .about-grid { grid-template-columns:1fr; gap:40px; } }
.about-text { font-size:1.025rem; color:var(--text-2); line-height:1.8; margin-top:14px; }
.about-stats-grid { display:grid; grid-template-columns:1fr 1fr; gap:11px; margin-top:28px; }
.about-stat {
  padding:20px; text-align:center;
  background:rgba(13,17,33,0.5); border:1px solid var(--border);
  border-radius:var(--r-xl); transition:all 0.22s;
}
.about-stat:hover { border-color:var(--border-hi); transform:translateY(-2px); }
.about-stat-num { font-size:2rem; font-weight:900; color:var(--text); font-family:var(--font-display); }
.about-stat-lbl { font-size:0.78rem; color:var(--text-4); margin-top:3px; }

.team-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:18px; max-width:560px; margin:0 auto; }
.team-card { text-align:center; padding:30px 22px; }
.team-avatar { width:90px; height:90px; border-radius:50%; object-fit:cover; margin:0 auto 14px; border:2px solid rgba(99,102,241,0.28); box-shadow:0 0 20px rgba(99,102,241,0.18); }
.team-name { font-weight:800; font-size:1.05rem; color:var(--text); font-family:var(--font-display); }
.team-role { font-size:0.83rem; color:var(--indigo-l); margin-top:4px; font-weight:600; }
.team-desc { font-size:0.845rem; color:var(--text-3); margin-top:9px; line-height:1.65; }

/* ═══════════════════════════
   LEGAL PAGES
═══════════════════════════ */
.legal-card { padding:44px; max-width:780px; margin:0 auto; }
@media (max-width:639px) { .legal-card { padding:26px 18px; } }
.legal-content h2 { font-size:1.05rem; font-weight:700; color:var(--text); margin:28px 0 9px; font-family:var(--font-display); }
.legal-content h2:first-child { margin-top:0; }
.legal-content p { color:var(--text-3); line-height:1.78; margin-bottom:14px; font-size:0.9rem; }
.legal-content a { color:var(--indigo-l); border-bottom:1px solid rgba(99,102,241,0.3); transition:border-color 0.13s; }
.legal-content a:hover { border-color:var(--indigo-l); }

/* ═══════════════════════════
   404 PAGE
═══════════════════════════ */
.error-page {
  min-height:80vh; display:flex; align-items:center; justify-content:center;
  padding:120px 24px 80px; text-align:center;
}
.error-inner { max-width:480px; }
.error-code {
  font-size:clamp(5.5rem,14vw,10rem); font-weight:900; font-family:var(--font-display); line-height:1;
  background:linear-gradient(135deg,var(--indigo-l),var(--purple-l));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.error-title { font-size:1.65rem; font-weight:800; color:var(--text); margin:14px 0 10px; font-family:var(--font-display); }
.error-sub { color:var(--text-3); line-height:1.7; margin-bottom:30px; }

/* ═══════════════════════════
   TOAST
═══════════════════════════ */
.toast {
  position:fixed; bottom:90px; right:20px; z-index:600;
  padding:13px 18px; border-radius:var(--r-lg);
  font-weight:600; font-size:0.875rem; color:#fff;
  box-shadow:var(--shadow-lg); max-width:300px;
  transform:translateY(12px) scale(0.95); opacity:0;
  transition:all 0.3s var(--ease-out); pointer-events:none;
}
.toast.show { transform:translateY(0) scale(1); opacity:1; }
.toast-success { background:linear-gradient(135deg,#15803d,#16a34a); }
.toast-error   { background:linear-gradient(135deg,#b91c1c,#dc2626); }

/* ═══════════════════════════
   UTILITIES
═══════════════════════════ */
.visually-hidden { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0; }

/* ─── Responsive ─── */
@media (max-width:767px) {
  .section { padding:60px 0; }
  .hero { padding:88px 0 64px; }
  .hero-stats { gap:22px; }
  .stat-num { font-size:1.6rem; }
  .page-hero { padding:110px 0 48px; }
  .cta-banner { padding:40px 20px; }
  .plans-header { flex-direction:column; align-items:flex-start; }
}
@media (max-width:479px) {
  .hero-ctas { flex-direction:column; align-items:center; }
  .btn-lg { width:100%; max-width:320px; }
  .footer-grid { grid-template-columns:1fr; }
}

/* ─── Reduced motion ─── */
@media (prefers-reduced-motion:reduce) {
  .hero-orb, .pulse-dot::after, .loader-ring, .title-gradient,
  .scroll-hint-line, .orb-pulse { animation:none !important; }
  .reveal-up, .reveal-left, .reveal-right, .reveal-scale { opacity:1 !important; transform:none !important; }
  * { transition-duration:0.01ms !important; }
}

/* ─── Smart Nav Hide ─── */
.navbar { transition: background 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease, transform 0.4s cubic-bezier(0.16,1,0.3,1); }
.navbar.nav-hidden { transform: translateY(-100%); }

/* ─── Button Spinner ─── */
.btn-spinner {
  display: inline-block;
  width: 14px; height: 14px;
  border: 2px solid rgba(255,255,255,0.3);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spin .7s linear infinite;
  margin-right: 6px;
  vertical-align: middle;
  flex-shrink: 0;
}

/* ─── Loader Logo Animation ─── */
@keyframes loader-logo-scale {
  from { transform: scale(0.6) rotate(-5deg); opacity: 0; }
  to   { transform: scale(1) rotate(0deg); opacity: 1; }
}
.loader-logo { animation: loader-logo-scale 0.5s cubic-bezier(0.34,1.56,0.64,1) forwards; }
.loader-logo-ring {
  position: absolute; inset: -14px; border-radius: 50%;
  border: 1px solid rgba(99,102,241,0.25);
  animation: spin 2.5s linear infinite;
}
.loader-logo-ring::before {
  content: ''; position: absolute;
  top: -1px; left: 28%;
  width: 18px; height: 2px;
  background: linear-gradient(90deg, #6366f1, #a855f7);
  border-radius: 2px;
}

/* ─── plan-card glow effect ─── */
.plan-card::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(600px circle at var(--mouse-x,50%) var(--mouse-y,50%),
    rgba(99,102,241,0.07), transparent 40%);
  opacity: 0; transition: opacity 0.4s; border-radius: inherit; z-index: 0;
}
.plan-card[data-color="p"]::before {
  background: radial-gradient(600px circle at var(--mouse-x,50%) var(--mouse-y,50%),
    rgba(168,85,247,0.07), transparent 40%);
}
.plan-card:hover::before { opacity: 1; }
.plan-card > * { position: relative; z-index: 1; }

/* ─── Featured card shimmer ─── */
.plan-card.featured::after {
  content: '';
  position: absolute; top: 0; left: -100%; width: 60%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.04), transparent);
  animation: card-shimmer 3.5s ease-in-out infinite;
  z-index: 0; pointer-events: none;
}
@keyframes card-shimmer { 0%{left:-60%} 100%{left:160%} }

/* ─── Section beam divider ─── */
.section-beam-divider {
  width: 100%; height: 1px;
  background: linear-gradient(90deg, transparent 0%, rgba(99,102,241,0.3) 30%, rgba(168,85,247,0.3) 70%, transparent 100%);
  position: relative;
}
.section-beam-divider::before {
  content: ''; position: absolute; left: 50%; top: -2px; transform: translateX(-50%);
  width: 6px; height: 6px; background: #6366f1; border-radius: 50%;
  box-shadow: 0 0 12px rgba(99,102,241,0.7);
}

/* ═══════════════════════════════════════════════════════════════
   FINAL AUDIT ADDITIONS — missing classes + polish
═══════════════════════════════════════════════════════════════ */

/* ── Scrubber Section ── */
.mc-scrub-section { position: relative; }
.mc-scrub-sticky {
  position: sticky; top: 0; height: 100vh; width: 100%;
  overflow: hidden; background: #000;
  display: flex; align-items: center; justify-content: center;
}
.mc-scrub-canvas { width: 100%; height: 100%; object-fit: cover; display: block; }
.mc-scrub-sticky::before {
  content: ''; position: absolute; bottom: 0; left: 0; right: 0;
  height: 35%; background: linear-gradient(to top, #060810 0%, transparent 100%);
  z-index: 3; pointer-events: none;
}
.mc-scrub-sticky::after {
  content: ''; position: absolute; top: 0; left: 0; right: 0;
  height: 18%; background: linear-gradient(to bottom, #060810 0%, transparent 100%);
  z-index: 3; pointer-events: none;
}

/* ── Infra Canvas ── */
.infra-canvas-wrap { position: relative; width: 100%; }
.infra-canvas { width: 100%; display: block; border-radius: 16px; background: rgba(6,8,16,0.6); border: 1px solid rgba(55,65,81,0.3); }

/* ── Metric Rings ── */
.metric-item { display: flex; flex-direction: column; align-items: center; gap: 10px; }
.metric-label { font-size: 0.72rem; font-weight: 600; color: var(--text-4); text-transform: uppercase; letter-spacing: 0.08em; text-align: center; }

/* ── Footer Brand (grid first child) ── */
.footer-brand { display: flex; flex-direction: column; }

/* ── cc-dial ── */
#cc-dial { position: fixed; right: 20px; bottom: 22px; z-index: 450; display: flex; flex-direction: column; align-items: flex-end; gap: 9px; }

/* ── Contact Page Extras ── */
.contact-section-h { font-size: 1.35rem; font-weight: 800; color: var(--text); margin-bottom: 20px; font-family: var(--font-display); }
.contact-channels { display: flex; flex-direction: column; gap: 10px; }
.contact-channel {
  display: flex; align-items: center; gap: 14px; padding: 17px;
  background: rgba(13,17,33,0.55); border: 1px solid rgba(55,65,81,0.4);
  border-radius: 18px; transition: all 0.25s cubic-bezier(0.16,1,0.3,1);
  text-decoration: none; color: inherit;
}
.contact-channel:hover { background: rgba(17,24,39,0.9); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.cc-wa-link:hover   { border-color: rgba(34,197,94,0.35); }
.cc-dc-link:hover   { border-color: rgba(88,101,242,0.35); }
.cc-mail-link:hover { border-color: rgba(56,189,248,0.35); }
.contact-ch-icon { width: 46px; height: 46px; border-radius: 14px; display: flex; align-items: center; justify-content: center; font-size: 1.3rem; flex-shrink: 0; }
.contact-ch-name { font-weight: 700; font-size: 0.95rem; color: var(--text); }
.contact-ch-desc { font-size: 0.82rem; color: var(--text-4); margin-top: 2px; }
.contact-ch-arrow { flex-shrink: 0; transition: transform 0.2s; color: var(--text-5); }
.contact-channel:hover .contact-ch-arrow { transform: translateX(4px); color: var(--text-2); }
.contact-form-card { padding: 30px; }

/* ── About Page Extras ── */
.about-stat {
  padding: 20px; text-align: center;
  background: rgba(13,17,33,0.5); border: 1px solid var(--border);
  border-radius: var(--r-xl); transition: all 0.22s;
}
.about-stat:hover { border-color: var(--border-hi); transform: translateY(-2px); }
.about-stat-num { font-size: 2rem; font-weight: 900; color: var(--text); font-family: var(--font-display); }
.about-stat-lbl { font-size: 0.75rem; color: var(--text-4); margin-top: 3px; letter-spacing: 0.05em; }
.about-stats-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 11px; }
.team-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 18px; max-width: 560px; margin: 0 auto; }
.team-card { text-align: center; padding: 30px 22px; }
.team-avatar { width: 90px; height: 90px; border-radius: 50%; object-fit: cover; margin: 0 auto 14px; border: 2px solid rgba(99,102,241,0.3); box-shadow: 0 0 20px rgba(99,102,241,0.18); }
.team-name { font-weight: 800; font-size: 1.05rem; color: var(--text); font-family: var(--font-display); }
.team-role { font-size: 0.83rem; color: var(--indigo-l); margin-top: 4px; font-weight: 600; }
.team-desc { font-size: 0.845rem; color: var(--text-3); margin-top: 9px; line-height: 1.65; }

/* ── Legal Pages ── */
.legal-card { padding: 44px; max-width: 780px; margin: 0 auto; }
.legal-content h2 { font-size: 1.05rem; font-weight: 700; color: var(--text); margin: 28px 0 9px; font-family: var(--font-display); }
.legal-content h2:first-child { margin-top: 0; }
.legal-content p { color: var(--text-3); line-height: 1.78; margin-bottom: 14px; font-size: 0.9rem; }
.legal-content a { color: var(--indigo-l); border-bottom: 1px solid rgba(99,102,241,0.3); }
.legal-content a:hover { border-color: var(--indigo-l); }

/* ── 404 Page ── */
.error-page { min-height: 80vh; display: flex; align-items: center; justify-content: center; padding: 120px 24px 80px; text-align: center; }
.error-inner { max-width: 480px; }
.error-code {
  font-size: clamp(5.5rem, 14vw, 10rem); font-weight: 900; font-family: var(--font-display); line-height: 1;
  background: linear-gradient(135deg, var(--indigo-l), var(--purple-l));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.error-title { font-size: 1.65rem; font-weight: 800; color: var(--text); margin: 14px 0 10px; font-family: var(--font-display); }
.error-sub { color: var(--text-3); line-height: 1.7; margin-bottom: 30px; }

/* ── Trust Marquee ── */
.trust-strip { display: flex; overflow: hidden; align-items: center; mask-image: linear-gradient(90deg, transparent 0%, black 8%, black 92%, transparent 100%); }
.trust-scroll { display: flex; gap: 32px; animation: trust-marquee 22s linear infinite; flex-shrink: 0; white-space: nowrap; }
@keyframes trust-marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.trust-item { display: flex; align-items: center; gap: 7px; font-size: 0.75rem; font-weight: 600; color: rgba(255,255,255,0.28); white-space: nowrap; flex-shrink: 0; }
.trust-item svg { color: var(--indigo); flex-shrink: 0; }

/* ── Plans ── */
.plans-group { margin-bottom: 0; }
.plans-header { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 28px; flex-wrap: wrap; gap: 12px; }
.plans-title { font-size: clamp(1.5rem, 2.5vw, 2rem); font-weight: 800; color: var(--text); margin-top: 8px; margin-bottom: 4px; }
.plans-sub { color: var(--text-3); font-size: 0.9375rem; }
.plans-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(268px, 1fr)); gap: 18px; }
.see-all-link { font-size: 0.85rem; color: var(--indigo-l); font-weight: 600; display: flex; align-items: center; gap: 4px; flex-shrink: 0; transition: color 0.15s; }
.see-all-link:hover { color: var(--indigo); }
.see-all-link-p { color: var(--purple-l); }
.see-all-link-p:hover { color: var(--purple); }

/* ── Scrub Text Layer ── */
.scrub-text-layer {
  position: absolute; inset: 0; z-index: 10;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  pointer-events: none; opacity: 0; transform: translateY(28px);
  transition: opacity 0.55s cubic-bezier(0.16,1,0.3,1), transform 0.55s cubic-bezier(0.16,1,0.3,1);
}
.scrub-text-layer.visible { opacity: 1; transform: translateY(0); }
.scrub-text-layer .btn { pointer-events: auto; }
.scrub-eyebrow {
  font-size: 0.7rem; font-weight: 700; letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--indigo-l); margin-bottom: 12px; display: block;
}
.scrub-headline {
  font-family: var(--font-display); font-size: clamp(1.9rem, 5vw, 3.5rem);
  font-weight: 900; color: #fff; text-align: center; line-height: 1.1;
  letter-spacing: -0.02em; text-shadow: 0 2px 40px rgba(0,0,0,0.8);
  max-width: 700px; padding: 0 24px;
}
.scrub-sub {
  font-size: 1.05rem; color: rgba(255,255,255,0.58); margin-top: 14px;
  text-align: center; max-width: 500px; padding: 0 24px; line-height: 1.68;
}
.scrub-progress-track { width: 120px; height: 2px; background: rgba(255,255,255,0.1); border-radius: 2px; overflow: hidden; }
.scrub-progress-fill { height: 100%; background: linear-gradient(90deg, var(--indigo), var(--purple)); border-radius: 2px; width: 0%; transition: width 0.06s linear; }

/* ── Terminal ── */
.terminal-block { background: #080c18; border: 1px solid rgba(99,102,241,0.15); border-radius: 14px; overflow: hidden; }
.terminal-header { display: flex; align-items: center; gap: 7px; padding: 12px 16px; background: rgba(99,102,241,0.05); border-bottom: 1px solid rgba(99,102,241,0.08); }
.terminal-dot { width: 11px; height: 11px; border-radius: 50%; }
.terminal-dot-r { background: #ff5f57; }
.terminal-dot-y { background: #febc2e; }
.terminal-dot-g { background: #28c840; }
.terminal-title { font-size: 0.72rem; font-weight: 600; color: rgba(255,255,255,0.28); margin: 0 auto; letter-spacing: 0.04em; }
.terminal-body { padding: 20px; font-family: 'JetBrains Mono','Fira Code',monospace; font-size: 0.78rem; line-height: 1.78; color: rgba(255,255,255,0.55); }
.terminal-line { display: block; }
.terminal-prompt { color: var(--indigo-l); }
.terminal-cmd    { color: #a5f3fc; }
.terminal-output { color: rgba(255,255,255,0.4); }
.terminal-success { color: var(--green); }
.terminal-cursor { display: inline-block; width: 8px; height: 14px; background: var(--indigo); vertical-align: middle; margin-left: 2px; animation: type-cursor 0.8s step-end infinite; }
@keyframes type-cursor { 50% { opacity: 0; } }

/* ── Speed Bars ── */
.speed-bar-wrap { display: flex; flex-direction: column; gap: 14px; }
.speed-bar-item { display: flex; flex-direction: column; gap: 6px; }
.speed-bar-label { display: flex; justify-content: space-between; font-size: 0.78rem; color: rgba(255,255,255,0.5); font-weight: 500; }
.speed-bar-track { height: 5px; background: rgba(255,255,255,0.07); border-radius: 5px; overflow: hidden; }
.speed-bar-fill { height: 100%; border-radius: 5px; width: 0%; transition: width 1.4s cubic-bezier(0.16,1,0.3,1); }

/* ── Metric Rings SVG ── */
.metrics-row { display: flex; gap: 28px; flex-wrap: wrap; justify-content: center; margin-top: 40px; }
.metric-ring-wrap { position: relative; width: 80px; height: 80px; flex-shrink: 0; }
.metric-ring-svg { width: 100%; height: 100%; transform: rotate(-90deg); }
.metric-ring-bg { fill: none; stroke: rgba(99,102,241,0.1); stroke-width: 4; }
.metric-ring-fill { fill: none; stroke-width: 4; stroke-linecap: round; stroke-dasharray: 226; stroke-dashoffset: 226; transition: stroke-dashoffset 1.5s cubic-bezier(0.16,1,0.3,1); }
.metric-ring-label { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; line-height: 1.1; }
.metric-ring-val { font-size: 0.88rem; font-weight: 800; color: #fff; font-family: var(--font-display); }
.metric-ring-unit { font-size: 0.56rem; color: rgba(255,255,255,0.38); font-weight: 600; }

/* ── Floating Badges ── */
.floating-badge {
  position: absolute; display: flex; align-items: center; gap: 7px;
  padding: 8px 14px; background: rgba(8,11,22,0.88);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(99,102,241,0.22); border-radius: 30px;
  font-size: 0.78rem; font-weight: 700; color: rgba(255,255,255,0.82);
  box-shadow: 0 8px 24px rgba(0,0,0,0.4); white-space: nowrap;
}
.floating-badge-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--green); box-shadow: 0 0 8px rgba(34,197,94,0.6); animation: status-blink 2s ease-in-out infinite; }
@keyframes status-blink { 0%,100%{opacity:1} 50%{opacity:0.3} }

/* ── Latency badge ── */
.latency-badge { display: inline-flex; align-items: center; gap: 5px; padding: 3px 9px; border-radius: 20px; font-size: 0.72rem; font-weight: 700; background: rgba(34,197,94,0.1); border: 1px solid rgba(34,197,94,0.25); color: var(--green); }

/* ── Glass panels ── */
.glass-panel { background: rgba(13,17,33,0.65); backdrop-filter: blur(20px) saturate(160%); -webkit-backdrop-filter: blur(20px) saturate(160%); border: 1px solid rgba(255,255,255,0.06); box-shadow: 0 8px 32px rgba(0,0,0,0.3), inset 0 1px 0 rgba(255,255,255,0.04); }

/* ── Hero Orbs ── */
.hero-orb { position: absolute; border-radius: 50%; filter: blur(88px); animation: orb-pulse 5s ease-in-out infinite; pointer-events: none; z-index: 0; }
.hero-orb-1 { width: 560px; height: 560px; background: rgba(99,102,241,0.07); top: -10%; left: -12%; }
.hero-orb-2 { width: 480px; height: 480px; background: rgba(168,85,247,0.07); bottom: 0; right: -10%; animation-delay: 2.5s; }
@keyframes orb-pulse { 0%,100%{opacity:.5;transform:scale(1)} 50%{opacity:.8;transform:scale(1.06)} }

/* ── GPU layer ── */
.gpu-layer { will-change: transform, opacity; transform: translateZ(0); backface-visibility: hidden; }

/* ── Cursor glow ── */
#cursor-glow {
  position: fixed; width: 380px; height: 380px; border-radius: 50%;
  background: radial-gradient(circle, rgba(99,102,241,0.055) 0%, transparent 70%);
  pointer-events: none; z-index: 1; transform: translate(-50%, -50%);
  transition: opacity 0.4s ease; will-change: left, top; opacity: 1;
}

/* ── Scroll Progress Bar ── */
#scroll-progress-bar {
  position: fixed; top: 0; left: 0; height: 2px;
  background: linear-gradient(90deg, #6366f1, #a855f7, #22c55e);
  z-index: 9999; transform-origin: left; transform: scaleX(0);
  pointer-events: none; width: 100%;
}

/* ── Responsive additions ── */
@media (max-width: 767px) {
  .legal-card { padding: 24px 18px; }
  .contact-form-card { padding: 22px 18px !important; }
  .mc-scrub-section .scrub-headline { font-size: clamp(1.5rem, 7vw, 2.2rem); }
  .floating-badge { display: none; }
  .metrics-row { gap: 18px; }
  .plans-header { flex-direction: column; align-items: flex-start; }
  .trust-scroll { animation-duration: 16s; }
}

/* ── Smooth page reveal on load ── */
body { animation: body-reveal 0.4s ease forwards; }
@keyframes body-reveal { from { opacity: 0; } to { opacity: 1; } }

/* ── Green (Web Hosting) plan card tokens ─────────────────────── */
.plan-badge-g{background:rgba(99,102,241,.12);color:#818cf8;border-color:rgba(99,102,241,.28)}
.plan-card[data-color="g"]{border-color:rgba(99,102,241,.12)}
.plan-card[data-color="g"]:hover{border-color:rgba(99,102,241,.3);box-shadow:0 8px 40px rgba(99,102,241,.08)}
.plan-card[data-color="g"].featured{border-color:#6366f1;box-shadow:0 0 0 1px #6366f1,0 8px 40px rgba(99,102,241,.12)}
.plan-card[data-color="g"].featured:hover{box-shadow:0 0 0 1px #6366f1,0 16px 50px rgba(99,102,241,.22)}
.plan-card[data-color="g"]::before{background:radial-gradient(600px circle at var(--mouse-x,50%) var(--mouse-y,50%),rgba(99,102,241,.07),transparent 40%)}
.plan-check-g{background:rgba(34,197,94,.14);color:#22c55e}
.plan-cta-g{background:linear-gradient(135deg,#15803d,#22c55e);color:#fff;box-shadow:0 3px 14px rgba(34,197,94,.2)}
.plan-cta-g:hover{background:linear-gradient(135deg,#22c55e,#4ade80);box-shadow:0 6px 22px rgba(34,197,94,.36);transform:translateY(-1px)}
.see-all-link-g{color:#22c55e}
.see-all-link-g:hover{color:#16a34a}
.tag-g{background:rgba(34,197,94,.1);color:#22c55e;border-color:rgba(34,197,94,.22)}

/* ── Speed bar ─────────────────────────────────────────────────── */
.speed-bar-wrap{display:flex;flex-direction:column;gap:14px}
.speed-bar-item{}
.speed-bar-label{display:flex;justify-content:space-between;font-size:.8rem;color:#94a3b8;margin-bottom:6px;font-weight:500}
.speed-bar-track{height:6px;background:rgba(255,255,255,.06);border-radius:99px;overflow:hidden}
.speed-bar-fill{height:100%;border-radius:99px;width:0;transition:width 1.2s cubic-bezier(.25,.46,.45,.94)}

/* ── Latency badge ─────────────────────────────────────────────── */
.latency-badge{background:rgba(34,197,94,.15);color:#22c55e;font-size:.78rem;font-weight:700;padding:2px 10px;border-radius:99px;border:1px solid rgba(34,197,94,.3)}

/* ── Floating badge (web hero) ─────────────────────────────────── */
.floating-badge{position:absolute;display:inline-flex;align-items:center;gap:7px;background:rgba(8,12,22,.9);border:1px solid rgba(34,197,94,.3);border-radius:30px;padding:6px 14px;font-size:.72rem;font-weight:700;color:#f1f5f9;backdrop-filter:blur(12px);box-shadow:0 4px 20px rgba(0,0,0,.4);animation:float 3s ease-in-out infinite}
.floating-badge-dot{width:7px;height:7px;border-radius:50%;background:#22c55e;box-shadow:0 0 10px rgba(34,197,94,.7);animation:pulse 1.5s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}

/* ── Plans grid 6-col ──────────────────────────────────────────── */
.plans-grid-6{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}

/* ── bg-beam placeholder (used in web hero) ───────────────────── */
.bg-beam{pointer-events:none}

/* ── Green (Web Hosting) plan card tokens ─────────────────────── */
.plan-badge-g{background:rgba(99,102,241,.12);color:#818cf8;border-color:rgba(99,102,241,.28)}
.plan-card[data-color="g"]{border-color:rgba(99,102,241,.12)}
.plan-card[data-color="g"]:hover{border-color:rgba(99,102,241,.3);box-shadow:0 8px 40px rgba(99,102,241,.08)}
.plan-card[data-color="g"].featured{border-color:#6366f1;box-shadow:0 0 0 1px #6366f1,0 8px 40px rgba(99,102,241,.12)}
.plan-card[data-color="g"].featured:hover{box-shadow:0 0 0 1px #6366f1,0 16px 50px rgba(99,102,241,.22)}
.plan-card[data-color="g"]::before{background:radial-gradient(600px circle at var(--mouse-x,50%) var(--mouse-y,50%),rgba(99,102,241,.07),transparent 40%)}
.plan-check-g{background:rgba(34,197,94,.14);color:#22c55e}
.plan-cta-g{background:linear-gradient(135deg,#15803d,#22c55e);color:#fff;box-shadow:0 3px 14px rgba(34,197,94,.2)}
.plan-cta-g:hover{background:linear-gradient(135deg,#22c55e,#4ade80);box-shadow:0 6px 22px rgba(34,197,94,.36);transform:translateY(-1px)}
.see-all-link-g{color:#22c55e}
.see-all-link-g:hover{color:#16a34a}
.tag-g{background:rgba(34,197,94,.1);color:#22c55e;border-color:rgba(34,197,94,.22)}
.speed-bar-wrap{display:flex;flex-direction:column;gap:14px}
.speed-bar-label{display:flex;justify-content:space-between;font-size:.8rem;color:#94a3b8;margin-bottom:6px;font-weight:500}
.speed-bar-track{height:6px;background:rgba(255,255,255,.06);border-radius:99px;overflow:hidden}
.speed-bar-fill{height:100%;border-radius:99px;width:0;transition:width 1.2s cubic-bezier(.25,.46,.45,.94)}
.latency-badge{background:rgba(34,197,94,.15);color:#22c55e;font-size:.78rem;font-weight:700;padding:2px 10px;border-radius:99px;border:1px solid rgba(34,197,94,.3)}
.floating-badge{position:absolute;display:inline-flex;align-items:center;gap:7px;background:rgba(8,12,22,.9);border:1px solid rgba(34,197,94,.3);border-radius:30px;padding:6px 14px;font-size:.72rem;font-weight:700;color:#f1f5f9;backdrop-filter:blur(12px);box-shadow:0 4px 20px rgba(0,0,0,.4);animation:float 3s ease-in-out infinite}
.floating-badge-dot{width:7px;height:7px;border-radius:50%;background:#22c55e;box-shadow:0 0 10px rgba(34,197,94,.7);animation:pulse 1.5s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
.plans-grid-6{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}

/* ── Enhanced motion / scroll reveals ─────────────────────── */
.cinematic-reveal{opacity:0;transform:translateY(24px);transition:opacity .6s cubic-bezier(.25,.46,.45,.94),transform .6s cubic-bezier(.25,.46,.45,.94)}
.cinematic-reveal.visible{opacity:1;transform:translateY(0)}

/* ── Logo glow ─────────────────────────────────────────────── */
.logo img{transition:filter .3s,transform .3s}
.logo:hover img{filter:drop-shadow(0 0 12px rgba(99,102,241,.6));transform:scale(1.05)}
.logo-text .accent{background:linear-gradient(135deg,#6366f1,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ── MC hero section ────────────────────────────────────────── */
.mc-hero-section{position:relative;overflow:hidden;min-height:90vh;display:flex;align-items:center;justify-content:center;padding:100px 0 80px;background:#060810}
.mc-hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 20% 60%,rgba(99,102,241,.09) 0%,transparent 60%),radial-gradient(ellipse 50% 40% at 80% 30%,rgba(168,85,247,.07) 0%,transparent 60%)}
.mc-hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;position:relative;z-index:1}
@media(max-width:1023px){.mc-hero-grid{grid-template-columns:1fr;gap:36px}}

/* ── Counter animation ─────────────────────────────────────── */
@keyframes countUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
[data-counter].visible{animation:countUp .4s ease forwards}

/* ── Dial item buttons ─────────────────────────────────────── */
.dial-item-btn{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:30px;font-size:.8rem;font-weight:700;text-decoration:none;transition:all .2s;white-space:nowrap}
.dial-discord{background:rgba(88,101,242,.15);border:1px solid rgba(88,101,242,.3);color:#7289da}
.dial-discord:hover{background:rgba(88,101,242,.25);border-color:rgba(88,101,242,.5)}
.dial-wa{background:rgba(37,211,102,.12);border:1px solid rgba(37,211,102,.3);color:#25d166}
.dial-wa:hover{background:rgba(37,211,102,.22);border-color:rgba(37,211,102,.5)}
.dial-toggle{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,#4338ca,#6366f1);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(99,102,241,.4);transition:all .2s}
.dial-toggle:hover{transform:scale(1.08);box-shadow:0 6px 28px rgba(99,102,241,.6)}
#cc-dial{position:fixed;bottom:24px;right:24px;z-index:1000;display:flex;flex-direction:column;align-items:flex-end;gap:8px}

/* ── Scroll progress bar ───────────────────────────────────── */
#scroll-progress-bar{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,#6366f1,#a78bfa);z-index:9999;width:0;transition:width .1s linear}

/* ── Mobile: disable parallax/fixed backgrounds under 1024px ── */
@media (max-width: 1023px) {
  *[style*="background-attachment: fixed"],
  *[style*="background-attachment:fixed"] {
    background-attachment: scroll !important;
  }
  .parallax, [data-parallax] {
    background-attachment: scroll !important;
    transform: none !important;
  }
  /* Disable heavy animations on mobile for performance */
  .cinematic-reveal {
    transition-duration: 0.3s;
  }
  /* Ensure MC plans section has clean dark background on mobile */
  .plans-section, .mc-plans-section, section[id="planes"] {
    background-image: none !important;
  }
}

/* ── Enterprise plan star badge ──────────────────────────────── */
.plan-badge-enterprise {
  background: rgba(250,204,21,.12);
  color: #facc15;
  border-color: rgba(250,204,21,.28);
}

/* ── Minecraft Visual Enhancements ──────────────────────────── */

/* Floating particle effect for MC hero */
.mc-particle {
  position: absolute;
  width: 4px;
  height: 4px;
  background: rgba(99,102,241,.6);
  border-radius: 50%;
  pointer-events: none;
  animation: mc-float var(--dur, 6s) ease-in-out var(--delay, 0s) infinite;
}
@keyframes mc-float {
  0%, 100% { transform: translateY(0) translateX(0); opacity: 0; }
  10% { opacity: 1; }
  50% { transform: translateY(calc(var(--dy, -60px))) translateX(calc(var(--dx, 10px))); opacity: .7; }
  90% { opacity: 0; }
}

/* MC block hover glow effect */
.mc-block-glow {
  transition: box-shadow .3s, transform .2s;
}
.mc-block-glow:hover {
  box-shadow: 0 0 20px rgba(99,102,241,.4);
  transform: translateY(-2px);
}

/* MC hero pixel grid overlay */
.mc-pixel-overlay {
  position: absolute;
  inset: 0;
  background-image: 
    linear-gradient(rgba(99,102,241,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(99,102,241,.03) 1px, transparent 1px);
  background-size: 32px 32px;
  pointer-events: none;
  opacity: 0;
  transition: opacity 1s;
}
.mc-pixel-overlay.visible { opacity: 1; }

/* MC Glow badges and accents */
.mc-glow-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(99,102,241,.1);
  border: 1px solid rgba(99,102,241,.25);
  border-radius: 30px;
  padding: 5px 14px;
  font-size: .73rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #818cf8;
}
.mc-glow-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #6366f1;
  display: inline-block;
  box-shadow: 0 0 8px rgba(99,102,241,.7);
  animation: mc-pulse 2s ease-in-out infinite;
}
@keyframes mc-pulse {
  0%, 100% { opacity: 1; box-shadow: 0 0 8px rgba(99,102,241,.7); }
  50% { opacity: .6; box-shadow: 0 0 14px rgba(99,102,241,1); }
}

/* Wolf decoration */
.mc-wolf-decoration {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 80px;
  opacity: .7;
  pointer-events: none;
  filter: drop-shadow(0 0 10px rgba(99,102,241,.3));
}

/* MC Plan card pixel corner accent */
.plan-card[data-color="i"]::after {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: 32px;
  height: 32px;
  background: linear-gradient(135deg, transparent 50%, rgba(99,102,241,.08) 50%);
  border-radius: 0 14px 0 0;
  pointer-events: none;
}

/* MC Hero frame canvas */
#mc-frame-canvas {
  width: 100%;
  max-width: 480px;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 24px 80px rgba(0,0,0,.5), 0 0 0 1px rgba(99,102,241,.15);
  display: block;
}
#mc-frame-canvas img {
  width: 100%;
  height: auto;
  display: block;
}

/* Mobile MC improvements */
@media (max-width: 767px) {
  .mc-hero-grid > div:last-child {
    display: none; /* Hide right panel on very small screens */
  }
  .plans-grid-mc {
    grid-template-columns: 1fr 1fr !important;
  }
}
@media (max-width: 479px) {
  .plans-grid-mc {
    grid-template-columns: 1fr !important;
  }
}

/* ════════════════════════════════════════════════════════════════
   HOSTING WEB — Rediseño Visual Profesional (Cloudflare / Vercel)
   Paleta: azul oscuro + negro + morado/violeta. Verde solo para estados.
   ════════════════════════════════════════════════════════════════ */

/* ── Web hero: cambiar de verde a azul/índigo ─────────────────── */
.web-hero-bg {
  background:
    radial-gradient(ellipse 55% 50% at 20% 60%, rgba(99,102,241,.09) 0%, transparent 60%),
    radial-gradient(ellipse 50% 40% at 80% 30%, rgba(59,130,246,.07) 0%, transparent 60%) !important;
}
.web-mockup {
  border-color: rgba(99,102,241,.2) !important;
  box-shadow: 0 24px 80px rgba(0,0,0,.5), 0 0 0 1px rgba(99,102,241,.08) !important;
}
.web-bar {
  background: rgba(99,102,241,.05) !important;
  border-bottom-color: rgba(99,102,241,.1) !important;
}
.web-perf {
  background: rgba(99,102,241,.08) !important;
}
/* Override the green trust strip border for web hosting */
.web-trust-strip-wrap {
  border-top-color: rgba(99,102,241,.1) !important;
  border-bottom-color: rgba(99,102,241,.1) !important;
  background: rgba(8,11,20,.95) !important;
}

/* ── Web feature cards: de verde a índigo ─────────────────────── */
.feat-icon-web {
  background: rgba(99,102,241,.1) !important;
  border-color: rgba(99,102,241,.2) !important;
  color: #818cf8 !important;
}
.feat-card-web:hover {
  border-color: rgba(99,102,241,.25) !important;
}

/* ── Tech badges: neutral dark en lugar de verde ──────────────── */
.tech-badge {
  background: rgba(15,20,40,.8) !important;
  border-color: rgba(99,102,241,.18) !important;
  color: rgba(255,255,255,.6) !important;
}
.tech-badge:hover {
  background: rgba(99,102,241,.1) !important;
  border-color: rgba(99,102,241,.35) !important;
  color: #c7d2fe !important;
}

/* ── Web plan cards: mutar color de acento a índigo ───────────── */
.web-plan-indigo .plan-check { background: rgba(99,102,241,.14) !important; color: #818cf8 !important; }
.web-plan-indigo.plan-card { border-color: rgba(99,102,241,.12) !important; }
.web-plan-indigo.plan-card:hover { border-color: rgba(99,102,241,.3) !important; box-shadow: 0 8px 40px rgba(99,102,241,.08) !important; }
.web-plan-indigo.plan-card.featured { border-color: #6366f1 !important; box-shadow: 0 0 0 1px #6366f1, 0 8px 40px rgba(99,102,241,.15) !important; }
.web-plan-indigo .plan-cta { background: linear-gradient(135deg,#4338ca,#6366f1) !important; color: #fff !important; box-shadow: 0 3px 14px rgba(99,102,241,.2) !important; }
.web-plan-indigo .plan-cta:hover { background: linear-gradient(135deg,#6366f1,#818cf8) !important; box-shadow: 0 6px 22px rgba(99,102,241,.36) !important; transform: translateY(-1px) !important; }
.web-plan-indigo .plan-badge { background: rgba(99,102,241,.12) !important; color: #818cf8 !important; border-color: rgba(99,102,241,.28) !important; }
.web-plan-indigo.plan-card::before { background: radial-gradient(600px circle at var(--mouse-x,50%) var(--mouse-y,50%), rgba(99,102,241,.07), transparent 40%) !important; }

/* ── Latency section indigo accent ────────────────────────────── */
.web-latency-badge {
  background: rgba(99,102,241,.15) !important;
  color: #818cf8 !important;
  border-color: rgba(99,102,241,.3) !important;
}
.web-latency-status {
  background: rgba(99,102,241,.06) !important;
  border-color: rgba(99,102,241,.2) !important;
}
.web-latency-dot {
  background: #6366f1 !important;
  box-shadow: 0 0 10px rgba(99,102,241,.6) !important;
}

/* ── Grid pattern overlay for web hero (Vercel-like) ─────────────*/
.web-grid-overlay {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(99,102,241,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(99,102,241,.04) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events: none;
  -webkit-mask-image: radial-gradient(ellipse 80% 80% at 50% 0%, black 40%, transparent 100%);
  mask-image: radial-gradient(ellipse 80% 80% at 50% 0%, black 40%, transparent 100%);
}

/* ── Floating badge: índigo para Hosting Web ──────────────────── */
.web-floating-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: rgba(8,12,22,.9);
  border: 1px solid rgba(99,102,241,.3);
  border-radius: 30px;
  padding: 6px 14px;
  font-size: .72rem;
  font-weight: 700;
  color: #f1f5f9;
  backdrop-filter: blur(12px);
  box-shadow: 0 4px 20px rgba(0,0,0,.4);
  animation: float 3s ease-in-out infinite;
}

/* ── Compare table hover indigo ───────────────────────────────── */
.compare-web tr:hover td { background: rgba(99,102,241,.04) !important; }
.compare-web .cy { color: #818cf8 !important; font-weight: 700 !important; }
.compare-web .hl td { background: rgba(99,102,241,.05) !important; }

/* ── Web tag override ─────────────────────────────────────────── */
.tag-web { background: rgba(99,102,241,.1); color: #818cf8; border: 1px solid rgba(99,102,241,.22); border-radius: 30px; display: inline-flex; align-items: center; gap: 6px; padding: 4px 12px; font-size: .72rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }

/* ── Inline link override ─────────────────────────────────────── */
.web-link-indigo { color: #818cf8 !important; }
.web-link-indigo:hover { color: #6366f1 !important; }

/* ── See-all link indigo ──────────────────────────────────────── */
.see-all-link-web { color: #818cf8; }
.see-all-link-web:hover { color: #6366f1; }

/* ════════════════════════════════════════════════════════════════
   WEB HERO — Beam / Aurora animation (Vercel-inspired)
   ════════════════════════════════════════════════════════════════ */
.web-beam-wrap {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
}
.web-beam {
  position: absolute;
  width: 1px;
  background: linear-gradient(to bottom, transparent, rgba(99,102,241,.4), transparent);
  animation: web-beam-fall var(--dur, 8s) linear var(--delay, 0s) infinite;
  opacity: 0;
}
@keyframes web-beam-fall {
  0%   { transform: translateY(-100%); opacity: 0; }
  10%  { opacity: 1; }
  90%  { opacity: .6; }
  100% { transform: translateY(200%); opacity: 0; }
}

/* ── Professional Infrastructure Badge ────────────────────────── */
.infra-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(8,12,22,.95);
  border: 1px solid rgba(99,102,241,.25);
  border-radius: 8px;
  padding: 8px 14px;
  font-size: .72rem;
  font-weight: 700;
  color: #94a3b8;
  letter-spacing: .04em;
}
.infra-badge-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #22c55e;
  box-shadow: 0 0 8px rgba(34,197,94,.7);
  animation: mc-pulse 2s ease-in-out infinite;
}

/* ── Paleta de colores global — reducir exceso de verde ───────── */
/* Las secciones de características ya no usan verde puro como fondo */
/* Los estados activos (live, uptime) mantienen verde */
/* Solo plan cards de Hosting Web -> cambio a indigo ya aplicado */

/* ── Section titles: asegurar que el gradiente no sea verde ───── */
.title-gradient {
  background: linear-gradient(135deg, #6366f1, #a78bfa) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
}

/* ── Reducir verde en homepage: feature icons ya son indigo ────── */
/* Los iconos de features en homepage usan rgba(99,102,241) ya */

/* ── Footer links: normalizar ─────────────────────────────────── */
.footer-links a:hover { color: #818cf8; }

/* ── Mobile web hero optimization ────────────────────────────── */
@media (max-width: 1023px) {
  .web-beam { display: none; }
  .web-grid-overlay { opacity: .5; }
}

/* ════════════════════════════════════════════════════════════════
   MOBILE FINAL FIXES — All pages
   ════════════════════════════════════════════════════════════════ */

/* MC hero: stack on mobile, hide frame animation on small screens */
@media (max-width: 767px) {
  .mc-hero-grid { grid-template-columns: 1fr !important; gap: 32px !important; }
  .mc-hero-grid > div:last-child { display: none !important; }
  .plans-grid-mc { grid-template-columns: 1fr 1fr !important; gap: 12px !important; }
  .plan-card { padding: 18px 14px !important; }
  .plan-price { font-size: 1.7rem !important; }
}
@media (max-width: 479px) {
  .plans-grid-mc { grid-template-columns: 1fr !important; }
  .mc-feat-grid { grid-template-columns: 1fr !important; }
  .mc-stats-grid { grid-template-columns: 1fr 1fr !important; }
}

/* Web hosting hero: stack on mobile */
@media (max-width: 1023px) {
  .web-hero-grid { grid-template-columns: 1fr !important; }
  .web-hero-grid > div:last-child { display: none !important; }
  .web-feat-grid { grid-template-columns: 1fr 1fr !important; }
}
@media (max-width: 639px) {
  .web-feat-grid { grid-template-columns: 1fr !important; }
  .plans-grid-6 { grid-template-columns: 1fr !important; }
}

/* Plans section: never overlap cards on mobile */
@media (max-width: 639px) {
  .plan-card { break-inside: avoid; }
  section#planes { padding: 40px 0 !important; }
}

/* Staff and admin: full-width on mobile */
@media (max-width: 767px) {
  .sidebar { display: none !important; }
  .main-area { width: 100% !important; }
}

/* Reduce large font sizes on mobile */
@media (max-width: 639px) {
  .hero-title { font-size: clamp(1.8rem, 7vw, 3rem) !important; }
  .mc-hero-title { font-size: clamp(2rem, 8vw, 3.5rem) !important; }
  .section-title { font-size: clamp(1.5rem, 6vw, 2.2rem) !important; }
}
