@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;600;700&display=swap');

:root{
  --bg:#05080f;--bg2:#080d18;--bg3:#0c1220;
  --glass:rgba(255,255,255,.04);--glass2:rgba(255,255,255,.07);
  --b:rgba(255,255,255,.08);--b2:rgba(255,255,255,.14);
  --blue:#2563eb;--blue2:#3b82f6;--blue3:#60a5fa;
  --green:#10b981;--green2:#34d399;
  --gold:#f59e0b;--gold2:#fbbf24;
  --purple:#8b5cf6;--red:#ef4444;
  --t1:#f9fafb;--t2:#9ca3af;--t3:#4b5563;
  --f:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  --mono:'JetBrains Mono',monospace;
  --r:14px;--r2:22px;--r3:32px;
  --tr:all .3s cubic-bezier(.4,0,.2,1);
  --sh:0 4px 32px rgba(0,0,0,.5);
  --sh2:0 8px 56px rgba(0,0,0,.6);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:17px}
body{font-family:var(--f);background:var(--bg);color:var(--t1);
  -webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.65}
img{max-width:100%;display:block}
a{text-decoration:none;transition:var(--tr)}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--blue);border-radius:3px}

/* ── UTILITY ── */
.container{max-width:1200px;margin:0 auto;padding:0 28px}
.container-sm{max-width:860px;margin:0 auto;padding:0 28px}
.sec{padding:100px 0}.sec-sm{padding:68px 0}
.gt{background:linear-gradient(135deg,var(--blue2),var(--blue3));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.gt-g{background:linear-gradient(135deg,var(--green),var(--green2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.gt-gold{background:linear-gradient(135deg,var(--gold),var(--gold2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.s-label{font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--blue3);margin-bottom:14px;display:block}
.s-title{font-size:clamp(2rem,3.8vw,3rem);font-weight:800;letter-spacing:-.04em;line-height:1.1;margin-bottom:18px}
.s-sub{color:var(--t2);font-size:1.1rem;line-height:1.75;max-width:560px}
.s-head{margin-bottom:60px}
.s-head.center{text-align:center}.s-head.center .s-sub{margin:0 auto}
.mono{font-family:var(--mono)}
.chip{display:inline-flex;align-items:center;gap:5px;background:var(--glass);border:1px solid var(--b);padding:4px 14px;border-radius:100px;font-size:.8rem;color:var(--t2)}

/* ── ANIMATED BACKGROUND PARTICLES ── */
@keyframes float1{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-20px) rotate(180deg)}}
@keyframes float2{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-30px) rotate(-180deg)}}
@keyframes float3{0%,100%{transform:translateY(0)}50%{transform:translateY(-15px)}}
.hero-particle{position:absolute;border-radius:50%;pointer-events:none;opacity:.15}
.hp1{width:300px;height:300px;background:radial-gradient(circle,var(--blue),transparent);top:10%;left:5%;animation:float1 8s ease-in-out infinite}
.hp2{width:200px;height:200px;background:radial-gradient(circle,var(--green),transparent);bottom:15%;right:8%;animation:float2 10s ease-in-out infinite}
.hp3{width:150px;height:150px;background:radial-gradient(circle,var(--purple),transparent);top:50%;left:40%;animation:float3 6s ease-in-out infinite}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:15px 30px;
  border-radius:100px;font-family:var(--f);font-weight:700;font-size:.95rem;
  cursor:pointer;border:none;transition:var(--tr);letter-spacing:-.01em;white-space:nowrap}
.btn-primary{background:linear-gradient(135deg,var(--blue),var(--blue2));color:#fff;box-shadow:0 4px 24px rgba(37,99,235,.4)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 36px rgba(37,99,235,.55);color:#fff}
.btn-green{background:linear-gradient(135deg,var(--green),var(--green2));color:#000;font-weight:800;box-shadow:0 4px 24px rgba(16,185,129,.35)}
.btn-green:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 10px 36px rgba(16,185,129,.5);color:#000}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#000;font-weight:800;box-shadow:0 4px 24px rgba(245,158,11,.35)}
.btn-gold:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 10px 36px rgba(245,158,11,.5);color:#000}
.btn-ghost{background:transparent;color:var(--t1);border:1.5px solid rgba(255,255,255,.2)}
.btn-ghost:hover{border-color:var(--blue2);color:var(--blue3);background:rgba(59,130,246,.08)}
.btn-sm{padding:11px 22px;font-size:.85rem}
.btn-lg{padding:17px 38px;font-size:1rem}
.btn-xl{padding:19px 46px;font-size:1.05rem}
.btn-full{width:100%;justify-content:center}

/* ── NAVBAR ── */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;height:70px;
  display:flex;align-items:center;
  background:rgba(5,8,15,.88);backdrop-filter:blur(28px) saturate(200%);
  -webkit-backdrop-filter:blur(28px);border-bottom:1px solid var(--b);transition:var(--tr)}
.navbar.scrolled{background:rgba(5,8,15,.98);box-shadow:var(--sh)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;
  width:100%;max-width:1200px;margin:0 auto;padding:0 28px}

/* LOGO — fixed proper display */
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.nav-logo-img{
  height:38px;width:auto;
  border-radius:8px;
  background:#fff;
  padding:3px 6px;
  object-fit:contain;
  display:block;
}
.nav-logo-text{font-size:1.2rem;font-weight:800;letter-spacing:-.04em;color:var(--t1);line-height:1}
.nav-logo-text span{background:linear-gradient(135deg,var(--blue2),var(--green));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

.nav-links{display:flex;align-items:center;gap:2px;list-style:none}
.nav-links>li{position:relative}
.nav-links a{color:rgba(249,250,251,.7);font-size:.9rem;font-weight:500;
  padding:9px 14px;border-radius:9px;display:flex;align-items:center;gap:5px;transition:var(--tr)}
.nav-links a:hover,.nav-links a.active{color:var(--t1);background:rgba(255,255,255,.07)}
.nav-links .has-drop>a::after{content:'▾';font-size:.7rem;opacity:.5;margin-left:2px;transition:var(--tr)}
.nav-links .has-drop:hover>a::after{transform:rotate(180deg)}

.dropdown{position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%);
  background:rgba(8,12,24,.97);border:1px solid var(--b2);border-radius:var(--r2);
  padding:8px;min-width:220px;opacity:0;visibility:hidden;transition:var(--tr);
  box-shadow:var(--sh2);backdrop-filter:blur(24px);pointer-events:none}
.has-drop:hover .dropdown{opacity:1;visibility:visible;top:calc(100% + 6px);pointer-events:auto}
.dropdown a{color:var(--t2);font-size:.88rem;padding:10px 14px;border-radius:9px;
  display:flex;align-items:center;gap:10px;white-space:nowrap;transition:var(--tr)}
.dropdown a:hover{color:var(--t1);background:rgba(37,99,235,.14)}
.dropdown a .di{font-size:1rem;width:22px;text-align:center}

.nav-actions{display:flex;align-items:center;gap:10px}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px}
.hamburger span{width:23px;height:2px;background:var(--t1);border-radius:2px;transition:var(--tr)}

/* mobile menu */
.mob-overlay{display:none;position:fixed;inset:0;z-index:999;
  background:rgba(5,8,15,.98);backdrop-filter:blur(24px);
  flex-direction:column;align-items:center;justify-content:flex-start;
  padding:80px 24px 40px;overflow-y:auto}
.mob-overlay.open{display:flex}
.mob-close{position:absolute;top:22px;right:22px;font-size:1.6rem;
  cursor:pointer;color:var(--t2);background:none;border:none;padding:4px}

/* Mobile grid menu container & grid classes */
.mob-menu-container {
  width: 100%;
  max-width: 480px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.mob-nav-header {
  text-align: center;
  margin-bottom: 8px;
}
.mob-menu-section {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.mob-section-title {
  font-size: 0.82rem;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--blue3);
  letter-spacing: 0.05em;
  padding-bottom: 6px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  text-align: left;
}
.mob-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
}
.mob-grid-link {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--t1);
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.05);
  padding: 10px 12px;
  border-radius: 8px;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 6px;
  transition: all 0.2s ease;
}
.mob-grid-link:hover {
  background: rgba(59, 130, 246, 0.08);
  border-color: rgba(59, 130, 246, 0.2);
  color: var(--blue3);
}
.mob-grid-flat {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
}
.mob-flat-link {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--t1);
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.05);
  padding: 10px 12px;
  border-radius: 8px;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 6px;
  transition: all 0.2s ease;
}
.mob-flat-link:hover {
  background: rgba(249, 115, 22, 0.08);
  border-color: rgba(249, 115, 22, 0.2);
  color: var(--primary);
}


/* ── ANNOUNCE BAR ── */
.ann-bar{background:linear-gradient(90deg,#1d4ed8 0%,var(--blue2) 40%,var(--green) 100%);
  text-align:center;padding:10px 20px;font-size:.82rem;font-weight:600;
  color:#fff;letter-spacing:.01em;position:relative;z-index:1001}
.ann-bar a{color:#fff;text-decoration:underline;text-underline-offset:2px}

/* ── HERO ── */
.hero{min-height:100vh;display:flex;align-items:center;
  padding-top:70px;position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-glow{position:absolute;border-radius:50%;filter:blur(90px);opacity:.35}
.hero-glow.g1{width:700px;height:700px;
  background:radial-gradient(circle,rgba(37,99,235,.4),transparent 70%);
  top:-150px;left:-150px;animation:float1 12s ease-in-out infinite}
.hero-glow.g2{width:600px;height:600px;
  background:radial-gradient(circle,rgba(16,185,129,.25),transparent 70%);
  bottom:-100px;right:-100px;animation:float2 14s ease-in-out infinite}
.hero-glow.g3{width:500px;height:500px;
  background:radial-gradient(circle,rgba(139,92,246,.2),transparent 70%);
  top:50%;left:45%;transform:translate(-50%,-50%);animation:float3 9s ease-in-out infinite}
.hero-grid{position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(37,99,235,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(37,99,235,.06) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 30%,transparent 100%)}
.hero-content{position:relative;z-index:1;max-width:780px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:9px;
  background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.25);
  color:var(--green2);padding:7px 18px;border-radius:100px;font-size:.82rem;
  font-weight:600;margin-bottom:28px;animation:fadeUp .6s ease both}
.hero-eyebrow .dot{width:7px;height:7px;background:var(--green);border-radius:50%;
  animation:pulse-dot 2s infinite}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.75)}}
.hero h1{font-size:clamp(2.6rem,5.5vw,4.4rem);font-weight:800;
  letter-spacing:-.05em;line-height:1.04;margin-bottom:24px;
  animation:fadeUp .7s ease .1s both}
.hero-desc{font-size:clamp(1.05rem,1.8vw,1.22rem);color:var(--t2);
  line-height:1.78;max-width:600px;margin-bottom:42px;
  animation:fadeUp .7s ease .2s both}
.hero-btns{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:60px;
  animation:fadeUp .7s ease .3s both}
.hero-stats{display:flex;flex-wrap:wrap;gap:44px;animation:fadeUp .7s ease .4s both}
.hs-item strong{display:block;font-size:2.1rem;font-weight:800;letter-spacing:-.05em;
  background:linear-gradient(135deg,var(--t1),var(--t2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hs-item span{font-size:.82rem;color:var(--t3);margin-top:2px;display:block}

/* ── GEO PILL ── */
.geo-pill{display:inline-flex;align-items:center;gap:8px;
  background:rgba(16,185,129,.08);border:1px solid rgba(16,185,129,.2);
  color:var(--green2);padding:7px 18px;border-radius:100px;font-size:.82rem;
  font-weight:500;margin-bottom:26px}

/* ── TRUST MARQUEE ── */
.trust-bar{padding:18px 0;border-top:1px solid var(--b);border-bottom:1px solid var(--b);
  background:var(--bg2);overflow:hidden}
.trust-track{display:flex;gap:56px;width:max-content;
  animation:mq-scroll 32s linear infinite}
.trust-item{display:flex;align-items:center;gap:10px;color:var(--t3);
  font-size:.84rem;font-weight:500;white-space:nowrap}
.trust-item .d{width:4px;height:4px;background:var(--blue2);border-radius:50%;flex-shrink:0}
@keyframes mq-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── CARDS ── */
.card{background:var(--glass);border:1px solid var(--b);border-radius:var(--r2);
  transition:var(--tr);overflow:hidden;position:relative}
.card::before{content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(37,99,235,.04),transparent);
  opacity:0;transition:var(--tr);border-radius:var(--r2)}
.card:hover::before{opacity:1}
.card:hover{border-color:rgba(59,130,246,.4);transform:translateY(-5px);
  box-shadow:0 16px 48px rgba(37,99,235,.18)}
.card-top, .card-accent{height:3px;background:linear-gradient(90deg,var(--blue),var(--green));
  opacity:0;transition:var(--tr)}
.card:hover .card-top, .card:hover .card-accent{opacity:1}
.card-body{padding:30px}
.card-icon{font-size:2.4rem;margin-bottom:18px;transition:transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275), filter 0.3s ease}
.card:hover .card-icon{transform:scale(1.15) translateY(-3px);filter:drop-shadow(0 0 10px rgba(96,165,250,0.45))}
.card:hover .btn-ghost{border-color:#3b82f6!important;color:#60a5fa!important;background:rgba(59,130,246,.08)!important}
.card-title{font-size:1.1rem;font-weight:700;letter-spacing:-.02em;margin-bottom:10px}
.card-desc{font-size:.92rem;color:var(--t2);line-height:1.7}
.card-price{font-size:1.7rem;font-weight:800;letter-spacing:-.04em;
  color:var(--green2);margin-top:16px}
.card-price small{font-size:.78rem;font-weight:400;color:var(--t3)}

/* ── IPv4 HIGHLIGHT ── */
.ipv4-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:linear-gradient(135deg,rgba(16,185,129,.15),rgba(37,99,235,.1));
  border:1px solid rgba(16,185,129,.4);
  color:var(--green2);padding:4px 12px;border-radius:8px;
  font-family:var(--mono);font-size:.92rem;font-weight:700;
  letter-spacing:.02em;white-space:nowrap;
}
.ipv4-big{
  display:inline-block;
  font-family:var(--mono);font-size:1.5rem;font-weight:800;
  color:var(--green2);letter-spacing:-.02em;
  text-shadow:0 0 20px rgba(16,185,129,.5);
}
.sv.green{color:var(--green2);font-weight:700}
.sv.ip-highlight{
  color:var(--green2) !important;
  font-size:.95rem !important;
  font-weight:800 !important;
  font-family:var(--mono);
  text-shadow:0 0 12px rgba(16,185,129,.4);
}

/* ── PRICING CARDS ── */
.p-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;align-items:start}
.p-card{
  background:linear-gradient(145deg,rgba(255,255,255,.04),rgba(255,255,255,.02));
  border:1px solid var(--b);border-radius:var(--r2);padding:34px;
  position:relative;transition:var(--tr);
}
.p-card::before{
  content:'';position:absolute;inset:0;border-radius:var(--r2);
  background:linear-gradient(135deg,rgba(37,99,235,.05),rgba(16,185,129,.02));
  opacity:0;transition:var(--tr);
}
.p-card:hover::before{opacity:1}
.p-card:hover{border-color:rgba(59,130,246,.45);transform:translateY(-6px);
  box-shadow:0 20px 60px rgba(37,99,235,.2)}
.p-card.featured{
  background:linear-gradient(145deg,rgba(37,99,235,.14),rgba(16,185,129,.06));
  border-color:rgba(37,99,235,.5);
  box-shadow:0 8px 48px rgba(37,99,235,.25);
  transform:scale(1.03);
}
.p-card.featured:hover{transform:scale(1.03) translateY(-5px)}
.p-card.hot{
  background:linear-gradient(145deg,rgba(245,158,11,.1),rgba(251,191,36,.04));
  border-color:rgba(245,158,11,.45);
}
.best-tag{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  background:linear-gradient(135deg,var(--blue),var(--blue2));color:#fff;
  font-size:.7rem;font-weight:800;padding:5px 20px;border-radius:100px;
  letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;
  box-shadow:0 4px 16px rgba(37,99,235,.55);
}
.hot-tag{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#000}
.p-tier{font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--t3);margin-bottom:6px}
.p-name{font-size:1.2rem;font-weight:800;letter-spacing:-.03em;margin-bottom:20px;line-height:1.2}

/* spec table */
.spec-tbl{border:1px solid var(--b);border-radius:var(--r);overflow:hidden;margin-bottom:20px}
.spec-row{display:flex;justify-content:space-between;align-items:center;
  padding:10px 16px;border-bottom:1px solid var(--b);font-size:.88rem;transition:var(--tr)}
.spec-row:last-child{border-bottom:none}
.spec-row:hover{background:rgba(255,255,255,.03)}
.spec-row.hl{background:rgba(37,99,235,.08)}
.sk{color:var(--t2);font-size:.85rem}
.sv{font-weight:600;font-family:var(--mono);font-size:.84rem;color:var(--t1)}
.sv.green{color:var(--green2)}

/* price */
.anc{display:flex;align-items:baseline;gap:9px;margin-bottom:5px}
.anc-label{font-size:.78rem;color:var(--t3)}
.anc-was{font-size:.92rem;color:var(--t3);text-decoration:line-through;font-family:var(--mono)}
.p-price{display:flex;align-items:baseline;gap:3px;margin-bottom:6px}
.p-sym{font-size:1.4rem;font-weight:800;color:var(--green2);align-self:flex-start;margin-top:5px}
.p-num{font-size:3.2rem;font-weight:800;letter-spacing:-.06em;color:var(--t1);line-height:1}
.p-per{font-size:.85rem;color:var(--t2);align-self:flex-end;margin-bottom:5px}
.save-chip{
  display:inline-block;background:rgba(16,185,129,.12);border:1px solid rgba(16,185,129,.28);
  color:var(--green2);font-size:.74rem;font-weight:700;padding:4px 12px;
  border-radius:100px;margin-bottom:20px}
.feat-ul{list-style:none;margin-bottom:24px}
.feat-ul li{display:flex;align-items:flex-start;gap:10px;padding:7px 0;
  font-size:.9rem;border-bottom:1px solid rgba(255,255,255,.04)}
.feat-ul li:last-child{border-bottom:none}
.feat-ul li .ck{color:var(--green2);flex-shrink:0;margin-top:2px;font-size:.95rem}
.feat-ul li span{color:var(--t2)}.feat-ul li strong{color:var(--t1)}
.urgency{background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.22);
  border-radius:8px;padding:10px 14px;font-size:.82rem;color:var(--gold2);
  text-align:center;margin-bottom:16px}
.p-note{text-align:center;font-size:.74rem;color:var(--t3);margin-top:9px}

/* ── LOCATION BADGE ── */
.loc-badge{
  display:inline-flex;align-items:center;gap:5px;
  background:rgba(59,130,246,.1);border:1px solid rgba(59,130,246,.25);
  color:var(--blue3);padding:3px 10px;border-radius:6px;
  font-size:.78rem;font-weight:600;
}

/* ── COMPARISON ── */
.cmp-wrap{overflow-x:auto;border-radius:var(--r2);border:1px solid var(--b)}
.cmp-tbl{width:100%;border-collapse:collapse;min-width:580px}
.cmp-tbl th{background:rgba(255,255,255,.03);padding:16px 18px;text-align:center;
  font-size:.74rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;
  color:var(--t2);border-bottom:1px solid var(--b)}
.cmp-tbl th.hl{background:rgba(37,99,235,.1);color:var(--blue3)}
.cmp-tbl th:first-child{text-align:left}
.cmp-tbl td{padding:13px 18px;border-bottom:1px solid var(--b);
  font-size:.9rem;color:var(--t2);text-align:center}
.cmp-tbl td:first-child{text-align:left;color:var(--t1);font-weight:600}
.cmp-tbl td.hl{background:rgba(37,99,235,.04);color:var(--t1);font-weight:700}
.cy{color:var(--green2);font-weight:700}.cn{color:var(--red)}.cm{color:var(--gold)}

/* ── FAQ ── */
.faq-wrap{max-width:780px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--b);padding:22px 0}
.faq-q{display:flex;justify-content:space-between;align-items:center;cursor:pointer;
  font-weight:700;font-size:1rem;gap:18px;transition:var(--tr);letter-spacing:-.01em;
  user-select:none}
.faq-q:hover{color:var(--blue3)}
.faq-tog{font-size:1.4rem;color:var(--blue2);flex-shrink:0;transition:var(--tr);font-weight:300;
  width:28px;height:28px;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--b);border-radius:50%;}
.faq-item.open .faq-tog{transform:rotate(45deg);background:rgba(37,99,235,.12);border-color:var(--blue2)}
.faq-a{display:none;padding-top:14px;color:var(--t2);font-size:.94rem;line-height:1.8}
.faq-item.open .faq-a{display:block;animation:fadeUp .3s ease both}

/* ── TESTIMONIALS ── */
.testi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:22px}
.testi-card{background:var(--glass);border:1px solid var(--b);border-radius:var(--r2);
  padding:30px;transition:var(--tr);position:relative;overflow:hidden}
.testi-card::before{content:'❝';position:absolute;top:16px;right:20px;
  font-size:3rem;color:rgba(37,99,235,.12);font-family:Georgia,serif;line-height:1}
.testi-card:hover{border-color:rgba(59,130,246,.35);transform:translateY(-3px)}
.stars{color:var(--gold);font-size:.9rem;letter-spacing:3px;margin-bottom:16px}
.testi-text{font-size:.93rem;color:var(--t2);line-height:1.78;margin-bottom:20px;font-style:italic}
.testi-author{display:flex;align-items:center;gap:13px}
.testi-avatar{width:42px;height:42px;border-radius:50%;
  background:linear-gradient(135deg,var(--blue),var(--green));
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:.9rem;color:#fff;flex-shrink:0}
.testi-name{font-weight:700;font-size:.9rem}
.testi-role{font-size:.78rem;color:var(--t3);margin-top:2px}
.testi-flag{margin-left:auto;font-size:1.3rem}

/* ── WHY CARDS ── */
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}
.why-card{background:var(--glass);border:1px solid var(--b);border-radius:var(--r2);
  padding:30px 26px;text-align:center;transition:var(--tr);position:relative;overflow:hidden}
.why-card::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);
  width:60%;height:2px;background:linear-gradient(90deg,transparent,var(--blue),transparent);
  opacity:0;transition:var(--tr)}
.why-card:hover::after{opacity:1}
.why-card:hover{border-color:rgba(59,130,246,.38);transform:translateY(-6px) scale(1.01);
  box-shadow:0 16px 48px rgba(37,99,235,.22);
  background:rgba(255,255,255,.06);
  backdrop-filter:blur(12px)}
.why-icon{font-size:2.4rem;margin-bottom:16px;
  filter:drop-shadow(0 0 8px rgba(37,99,235,.3))}
.why-card h3{font-size:1rem;font-weight:700;margin-bottom:9px;letter-spacing:-.01em}
.why-card p{font-size:.87rem;color:var(--t2);line-height:1.65}

/* ── CTA BANNER ── */
.cta-box{
  background:linear-gradient(135deg,rgba(37,99,235,.15),rgba(16,185,129,.08));
  border:1px solid rgba(37,99,235,.28);border-radius:var(--r3);
  padding:70px 44px;text-align:center;position:relative;overflow:hidden;
}
.cta-box::before{content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 80% at 50% 50%,rgba(37,99,235,.08),transparent 70%)}
.cta-box::after{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;
  background:radial-gradient(ellipse 40% 40% at 70% 30%,rgba(16,185,129,.05),transparent 60%)}
.cta-box h2{font-size:clamp(1.9rem,3.2vw,2.8rem);font-weight:800;
  letter-spacing:-.04em;margin-bottom:16px;position:relative;z-index:1}
.cta-box p{color:var(--t2);font-size:1.05rem;max-width:500px;
  margin:0 auto 34px;position:relative;z-index:1;line-height:1.75}
.cta-btns{display:flex;justify-content:center;flex-wrap:wrap;gap:14px;position:relative;z-index:1}
.risk-line{margin-top:18px;font-size:.8rem;color:var(--t3);
  display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;position:relative;z-index:1}

/* ── FOOTER ── */
.footer{background:var(--bg2);border-top:1px solid var(--b);padding:64px 0 24px}
.footer-grid{display:grid;grid-template-columns:2fr repeat(3,1fr);gap:44px;margin-bottom:52px}
.f-logo{font-size:1.25rem;font-weight:800;letter-spacing:-.04em;color:var(--t1);margin-bottom:14px}
.f-logo span{background:linear-gradient(135deg,var(--blue2),var(--green));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.f-desc{color:var(--t2);font-size:.88rem;line-height:1.75;max-width:250px;margin-bottom:22px}
.f-links{display:flex;gap:16px;flex-wrap:wrap}
.f-links a{color:var(--t3);font-size:.85rem;transition:var(--tr)}
.f-links a:hover{color:var(--t1)}
.f-col h4{font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--t3);margin-bottom:18px}
.f-col ul{list-style:none}
.f-col ul li{margin-bottom:11px}
.f-col ul li a{color:var(--t2);font-size:.88rem;transition:var(--tr)}
.f-col ul li a:hover{color:var(--t1)}
.footer-btm{border-top:1px solid var(--b);padding-top:24px;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.footer-btm p{font-size:.8rem;color:var(--t3)}
.f-badges{display:flex;gap:9px;flex-wrap:wrap}
.f-badge{background:var(--glass);border:1px solid var(--b);padding:4px 12px;
  border-radius:100px;font-size:.72rem;color:var(--t3)}

/* ── WA FLOAT ── */
.wa-btn{position:fixed;bottom:28px;right:28px;z-index:9999;
  width:58px;height:58px;border-radius:50%;background:#25d366;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 24px rgba(37,211,102,.55);transition:var(--tr);
  cursor:pointer;animation:wa-pulse 2.5s infinite}
.wa-btn svg{width:30px;height:30px;fill:#fff}
.wa-btn:hover{transform:scale(1.12);box-shadow:0 8px 36px rgba(37,211,102,.75)}
@keyframes wa-pulse{0%,100%{box-shadow:0 4px 24px rgba(37,211,102,.55)}
  50%{box-shadow:0 4px 40px rgba(37,211,102,.8)}}

/* ── AI ASSISTANT WIDGET ── */
.km-ai{
  position:fixed;bottom:100px;right:28px;z-index:9998;
  width:54px;height:54px;border-radius:50%;
  background:linear-gradient(135deg,#0a1020,#1e3a5f);
  border:1.5px solid rgba(245,158,11,.65);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;box-shadow:0 4px 20px rgba(245,158,11,.25), inset 0 1px 0 rgba(255,255,255,.1);
  transition:var(--tr);font-size:1.4rem;
  animation:ai-pulse 3s ease-in-out infinite;
}
.km-ai:hover{transform:scale(1.1);box-shadow:0 8px 32px rgba(245,158,11,.5);border-color:rgba(245,158,11,.9)}
@keyframes ai-pulse{0%,100%{box-shadow:0 4px 20px rgba(245,158,11,.2), 0 0 0 1px rgba(245,158,11,.1)}
  50%{box-shadow:0 4px 36px rgba(245,158,11,.4), 0 0 15px rgba(245,158,11,.3)}}
.km-ai-panel{
  position:fixed;bottom:168px;right:28px;z-index:9998;
  width:300px;background:linear-gradient(145deg,rgba(6,10,20,.85),rgba(10,16,32,.92)) !important;
  border:1px solid rgba(245,158,11,.3) !important;border-radius:20px;
  box-shadow:0 24px 70px rgba(0,0,0,.65),0 0 0 1px rgba(245,158,11,.15),inset 0 1px 0 rgba(255,255,255,.08) !important;
  display:none;overflow:hidden;
  backdrop-filter:blur(20px) saturate(180%) !important;
  -webkit-backdrop-filter:blur(20px) saturate(180%) !important;
}
.km-ai-panel.open{display:flex;flex-direction:column;animation:fadeUp .3s ease}
.km-ai-header{
  background:linear-gradient(135deg,#060a14,#0e1628) !important;
  border-bottom:2px solid #f59e0b !important;
  padding:14px 18px;display:flex;align-items:center;gap:10px;
}
.km-ai-header-icon{font-size:1.3rem}
.km-ai-header-text{flex:1}
.km-ai-header-text strong{display:block;font-size:.9rem;font-weight:700;color:#fff}
.km-ai-header-text span{font-size:.72rem;color:rgba(255,255,255,.75)}
.km-ai-close{color:rgba(255,255,255,.75);cursor:pointer;font-size:1.1rem;
  background:none;border:none;padding:2px;line-height:1}
.km-ai-body{padding:16px;flex:1}
.km-ai-input{
  width:100%;background:rgba(255,255,255,.06);border:1px solid var(--b2);
  border-radius:10px;padding:10px 14px;color:var(--t1);font-size:.88rem;
  font-family:var(--f);outline:none;transition:var(--tr);resize:none;
}
.km-ai-input:focus{border-color:rgba(245,158,11,.6) !important;background:rgba(245,158,11,.05) !important;box-shadow:0 0 10px rgba(245,158,11,.15) !important}
.km-ai-hint{font-size:.74rem;color:var(--t3);margin-bottom:10px;line-height:1.5}
.km-ai-results{display:flex;flex-wrap:wrap;gap:7px;margin-top:12px;min-height:40px}
.km-ai-tag{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(245,158,11,.08) !important;border:1px solid rgba(245,158,11,.25) !important;
  color:#fbbf24 !important;padding:6px 14px;border-radius:100px;
  font-size:.8rem;font-weight:600;cursor:pointer;transition:var(--tr);
  white-space:nowrap;text-decoration:none;
}
.km-ai-tag:hover{background:rgba(245,158,11,.18) !important;border-color:#f59e0b !important;
  transform:translateY(-1px);color:#fff !important}
.km-ai-tag .tag-icon{font-size:.85rem}
.km-ai-footer{padding:10px 16px;border-top:1px solid var(--b);
  font-size:.72rem;color:var(--t3);text-align:center}

/* ── REVEAL ANIMATIONS ── */
.rv{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.rv.vis{opacity:1;transform:translateY(0)}
.rv.d1{transition-delay:.1s}.rv.d2{transition-delay:.2s}
.rv.d3{transition-delay:.3s}.rv.d4{transition-delay:.4s}

/* fade left/right */
.rv-l{opacity:0;transform:translateX(-30px);transition:opacity .7s ease,transform .7s ease}
.rv-l.vis{opacity:1;transform:translateX(0)}
.rv-r{opacity:0;transform:translateX(30px);transition:opacity .7s ease,transform .7s ease}
.rv-r.vis{opacity:1;transform:translateX(0)}

/* scale in */
.rv-s{opacity:0;transform:scale(.92);transition:opacity .7s ease,transform .7s ease}
.rv-s.vis{opacity:1;transform:scale(1)}

@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}

/* ── BG SECTIONS ── */
.bg1{background:var(--bg)}.bg2{background:var(--bg2)}.bg3{background:var(--bg3)}

/* ── LEGAL CONTENT ── */
.legal-body h2{color:var(--t1);font-size:1.2rem;font-weight:700;margin:32px 0 12px;letter-spacing:-.02em}
.legal-body p{color:var(--t2);line-height:1.8;margin-bottom:12px}
.legal-body ul{color:var(--t2);padding-left:24px;margin-top:10px;display:flex;flex-direction:column;gap:8px;line-height:1.7}
.legal-body a{color:var(--blue3)}

/* ── RESPONSIVE ── */
@media(max-width:1024px){.footer-grid{grid-template-columns:1fr 1fr;gap:36px}}
@media(max-width:768px){
  html{font-size:16px}
  .sec{padding:68px 0}.sec-sm{padding:46px 0}
  .nav-links,.nav-actions .btn-primary{display:none}
  .hamburger{display:flex}
  .p-grid{grid-template-columns:1fr}
  .p-card.featured{transform:scale(1)}
  .p-card.featured:hover{transform:translateY(-4px)}
  .footer-grid{grid-template-columns:1fr}
  .cta-box{padding:44px 24px}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .hero-stats{gap:28px}
  .hero-btns{flex-direction:column}
  .hero-btns .btn{width:100%;justify-content:center}
  .km-ai-panel{width:calc(100vw - 40px);right:20px}
}
@media(max-width:480px){
  .why-grid{grid-template-columns:1fr}
  .container{padding:0 18px}
  .testi-grid{grid-template-columns:1fr}
}

/* ── ANN BAR + NAVBAR FIX ── */
body{padding-top:0}
.ann-bar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:8px 20px;height:36px;
  background:linear-gradient(90deg,#1d4ed8,#2563eb 40%,#059669 100%);
  text-align:center;font-size:.78rem;font-weight:600;color:#fff;
  box-shadow:0 2px 8px rgba(0,0,0,.3);display:flex;align-items:center;justify-content:center}
.ann-bar a{color:#fff;text-decoration:underline;text-underline-offset:2px}
.navbar{position:fixed;top:36px!important;left:0;right:0;z-index:1001;height:70px}
.hero,.page-top{padding-top:106px!important}
.hero[style*="padding-top"]{padding-top:108px!important}

/* ── BUTTON FIX — always visible ── */
.btn-primary,.btn-gold,.btn-green,.btn-ghost{
  display:inline-flex!important;align-items:center;justify-content:center;
  padding:14px 28px;border-radius:100px;font-weight:700;font-size:.92rem;
  cursor:pointer;border:none;text-decoration:none;transition:all .28s ease;
  white-space:nowrap;letter-spacing:-.01em;
  position:relative; z-index: 20;
}
.btn-full{width:100%!important;display:flex!important}
.btn-primary{background:linear-gradient(135deg,#4f46e5,#2563eb)!important;
  color:#fff!important;box-shadow:0 4px 24px rgba(79,70,229,.45)!important}
.btn-primary:hover{transform:translateY(-2px)!important;
  box-shadow:0 10px 32px rgba(37,99,235,.55)!important;color:#fff!important}
.btn-gold{background:linear-gradient(135deg,#f59e0b,#fbbf24)!important;
  color:#000!important;font-weight:800!important;
  box-shadow:0 4px 20px rgba(245,158,11,.4)!important}
.btn-gold:hover{transform:translateY(-2px) scale(1.02)!important;
  box-shadow:0 10px 32px rgba(245,158,11,.55)!important;color:#000!important}
.btn-green{background:linear-gradient(135deg,#10b981,#34d399)!important;
  color:#000!important;font-weight:800!important;
  box-shadow:0 4px 20px rgba(16,185,129,.35)!important}
.btn-ghost{background:transparent!important;color:#f9fafb!important;
  border:1.5px solid rgba(255,255,255,.22)!important}
.btn-ghost:hover{border-color:#3b82f6!important;color:#60a5fa!important;
  background:rgba(59,130,246,.08)!important}

/* ── WOW: AURORA BACKGROUND ── */
@keyframes aurora{
  0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}
}
.hero{background:linear-gradient(-45deg,#05080f,#0c1a3a,#051a1a,#0a0519);
  background-size:400% 400%;animation:aurora 18s ease infinite}

/* ── WOW: GLOWING CARDS ── */
.p-card{transition:all .35s cubic-bezier(.4,0,.2,1)!important;
  position:relative;overflow:hidden}
.p-card::after{content:'';position:absolute;inset:-1px;border-radius:23px;
  background:linear-gradient(135deg,rgba(37,99,235,.4),rgba(16,185,129,.2),rgba(139,92,246,.3));
  opacity:0;transition:opacity .35s ease;z-index:-1;filter:blur(8px)}
.p-card:hover::after{opacity:1}
.p-card.featured::after{opacity:.6}

/* ── WOW: SHIMMER ON BUTTONS ── */
.btn-gold,.btn-primary,.btn-green{position:relative;overflow:hidden}
.btn-gold::after,.btn-primary::after,.btn-green::after{
  content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent);
  transform:skewX(-20deg);animation:btn-shimmer 3s ease infinite}
@keyframes btn-shimmer{0%{left:-100%}60%,100%{left:200%}}

/* ── WOW: FLOATING ORBS ── */
.orb{position:absolute;border-radius:50%;filter:blur(60px);pointer-events:none;
  mix-blend-mode:screen;animation:orb-float 10s ease-in-out infinite}
.orb1{width:400px;height:400px;background:rgba(37,99,235,.2);
  top:-100px;left:-100px;animation-delay:0s}
.orb2{width:300px;height:300px;background:rgba(16,185,129,.15);
  bottom:-80px;right:-60px;animation-delay:3s}
.orb3{width:250px;height:250px;background:rgba(139,92,246,.12);
  top:40%;left:30%;animation-delay:6s}
@keyframes orb-float{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(30px,-20px) scale(1.1)}
  66%{transform:translate(-20px,15px) scale(.95)}
}

/* ── WOW: SPEC ROW HOVER ── */
.spec-row{cursor:default;border-left:3px solid transparent;
  transition:all .2s ease!important}
.spec-row:hover{border-left-color:#2563eb;background:rgba(37,99,235,.07)!important;
  padding-left:20px!important}
.spec-row.hl{border-left-color:#10b981!important}

/* ── WOW: HERO TEXT GLOW ── */
.hero h1{text-shadow:0 0 80px rgba(37,99,235,.15)}
.gt,.gt-g,.gt-gold{filter:drop-shadow(0 0 20px currentColor);filter:none}

/* ── WOW: CARD 3D TILT (via JS) ── */
.tilt-card{transform-style:preserve-3d;transform:perspective(1000px)}

/* ── MOBILE RESPONSIVE FIXES ── */
@media(max-width:768px){
  .ann-bar{font-size:.72rem;padding:8px 14px}
  .navbar{top:34px!important}
  .hero{padding-top:104px!important}
  .p-grid{grid-template-columns:1fr!important}
  .p-card.featured{transform:none!important}
  .hero h1{font-size:2rem!important}
  .hero-btns{flex-direction:column!important}
  .hero-btns .btn{width:100%!important}
  .cta-box{padding:36px 20px!important}
  .footer-grid{grid-template-columns:1fr!important}
  .s-title{font-size:1.8rem!important}
  .why-grid{grid-template-columns:1fr 1fr!important}
  .km-ai-panel{width:calc(100vw - 32px)!important;right:16px!important;bottom:140px!important}
}
@media(max-width:480px){
  .why-grid{grid-template-columns:1fr!important}
  .hero-stats{gap:20px!important}
  .p-num{font-size:2.4rem!important}
}
@media(min-width:769px) and (max-width:1024px){
  .p-grid{grid-template-columns:repeat(2,1fr)!important}
  .footer-grid{grid-template-columns:1fr 1fr!important}
}

/* ── CURSOR GLOW ── */
.cursor-glow{width:20px;height:20px;border-radius:50%;
  background:rgba(37,99,235,.6);position:fixed;pointer-events:none;
  z-index:9999;transition:transform .1s ease;mix-blend-mode:screen;
  box-shadow:0 0 20px rgba(37,99,235,.8);display:none}
@media(hover:hover){.cursor-glow{display:block}}

/* ── SCROLL PROGRESS BAR ── */
.scroll-progress{position:fixed;top:0;left:0;height:3px;z-index:2000;
  background:linear-gradient(90deg,#2563eb,#10b981,#8b5cf6);
  transition:width .1s linear}

/* ── PAGE LOAD ANIMATION ── */
@keyframes page-in{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
main,section{animation:page-in .5s ease both}

/* ══ V4 FIXES ══ */

/* Hero spacing - universal fix for all pages */
.page-hero{padding-top:160px!important;padding-bottom:70px!important;min-height:60vh}
.hero{padding-top:160px!important}
section.hero{padding-top:160px!important}

/* Featured card - fix tag clipping */
.p-grid{overflow:visible!important;align-items:start}
.p-card{overflow:visible!important;margin-top:20px}
.p-card.featured{margin-top:20px;transform:scale(1.02)!important}
.p-card.featured:hover{transform:scale(1.02) translateY(-5px)!important}
.best-tag{
  position:relative!important;top:auto!important;left:auto!important;
  transform:none!important;display:block;text-align:center;
  margin:-48px auto 16px!important;width:fit-content;
  z-index:10;
}

/* Professional color system upgrade */
:root{
  --bg:#03060d;--bg2:#060b16;--bg3:#091120;
  --blue:#2563eb;--blue2:#3b82f6;--blue3:#60a5fa;
  --green:#059669;--green2:#10b981;--green3:#34d399;
  --gold:#d97706;--gold2:#f59e0b;--gold3:#fbbf24;
  --purple:#7c3aed;--purple2:#8b5cf6;
  --t1:#f8fafc;--t2:#94a3b8;--t3:#475569;
  --b:rgba(148,163,184,.1);--b2:rgba(148,163,184,.18);
  --glass:rgba(15,23,42,.6);
  --sh-blue:0 0 40px rgba(37,99,235,.25);
  --sh-green:0 0 40px rgba(5,150,105,.2);
}

/* Stripe-inspired gradient hero */
.hero,.page-hero-wrap{
  background:radial-gradient(ellipse 80% 50% at 20% 20%,rgba(37,99,235,.18),transparent 60%),
    radial-gradient(ellipse 60% 60% at 80% 80%,rgba(124,58,237,.12),transparent 60%),
    radial-gradient(ellipse 50% 50% at 50% 50%,rgba(5,150,105,.08),transparent 70%),
    #03060d!important;
}

/* Card upgrade - Linear/Notion style */
.card,.p-card{
  background:linear-gradient(145deg,rgba(15,23,42,.8),rgba(9,17,32,.9))!important;
  backdrop-filter:blur(12px)!important;
  border:1px solid rgba(148,163,184,.12)!important;
}
.p-card:hover{
  border-color:rgba(59,130,246,.4)!important;
  box-shadow:0 20px 60px rgba(37,99,235,.2),0 0 0 1px rgba(59,130,246,.2)!important;
}
.p-card.featured{
  background:linear-gradient(145deg,rgba(37,99,235,.15),rgba(9,17,32,.95))!important;
  border-color:rgba(59,130,246,.5)!important;
  box-shadow:0 0 0 1px rgba(59,130,246,.4),0 24px 80px rgba(37,99,235,.25)!important;
}

/* Button upgrades - Stripe style */
.btn-primary{
  background:linear-gradient(135deg,#1d4ed8,#2563eb,#3b82f6)!important;
  box-shadow:0 1px 2px rgba(0,0,0,.4),0 4px 16px rgba(37,99,235,.4),inset 0 1px 0 rgba(255,255,255,.1)!important;
}
.btn-gold{
  background:linear-gradient(135deg,#b45309,#d97706,#f59e0b)!important;
  box-shadow:0 1px 2px rgba(0,0,0,.4),0 4px 16px rgba(217,119,6,.4),inset 0 1px 0 rgba(255,255,255,.1)!important;
}
.btn-green{
  background:linear-gradient(135deg,#047857,#059669,#10b981)!important;
  box-shadow:0 1px 2px rgba(0,0,0,.4),0 4px 16px rgba(5,150,105,.35),inset 0 1px 0 rgba(255,255,255,.1)!important;
}

/* Typing animation for hero */
.typing-wrap{display:inline-block}
.typing-cursor{display:inline-block;width:3px;height:1em;
  background:var(--blue3);margin-left:2px;vertical-align:middle;
  animation:cursor-blink .7s step-end infinite}
@keyframes cursor-blink{0%,100%{opacity:1}50%{opacity:0}}


/* Sticky bottom CTA bar */
.sticky-cta{
  position:fixed;bottom:0;left:0;right:0;z-index:9980;
  background:linear-gradient(90deg,rgba(9,17,32,.97),rgba(15,23,42,.97));
  border-top:1px solid rgba(59,130,246,.25);
  padding:10px 24px;display:none;align-items:center;
  justify-content:space-between;gap:14px;flex-wrap:wrap;
  backdrop-filter:blur(16px);
  animation:slide-up .4s ease both;
}
.sticky-cta.show{display:flex}
@keyframes slide-up{from{transform:translateY(100%)}to{transform:translateY(0)}}
.sticky-cta-text{font-size:.88rem;color:var(--t2)}
.sticky-cta-text strong{color:var(--t1)}
.sticky-cta-actions{display:flex;gap:10px}
.sticky-close{background:none;border:none;color:var(--t3);cursor:pointer;
  padding:4px 8px;font-size:1.1rem;line-height:1}

/* Exit intent overlay */
.exit-overlay{
  position:fixed;inset:0;z-index:10000;
  background:radial-gradient(circle at center, rgba(30, 20, 50, 0.4) 0%, rgba(3, 6, 13, 0.9) 100%);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  display:none;align-items:center;justify-content:center;padding:24px;
  transition:all .3s ease;
}
.exit-overlay.show{display:flex}
.exit-box.glowing-auto {
  max-width:480px;width:100%;text-align:center;
  position:relative;
  animation:exit-pop .5s cubic-bezier(.34,1.56,.64,1) both;
  background:transparent !important;
  border:none !important;
  box-shadow:none !important;
  padding:1.5px !important;
  border-radius:24px !important;
  overflow:visible !important;
}

/* Rotating Border Layer */
.exit-box.glowing-auto::before {
  content:'';
  position:absolute;inset:0;
  border-radius:24px;
  background:conic-gradient(from 0deg, #ff5e00, #ff007f, #00f2fe, #ff5e00);
  animation:spinBorder 4s linear infinite;
  z-index:0;
  pointer-events:none;
}

/* Rotating Glow Shadow Layer */
.exit-box.glowing-auto::after {
  content:'';
  position:absolute;inset:-15px;
  border-radius:30px;
  background:conic-gradient(from 0deg, #ff5e00, #ff007f, #00f2fe, #ff5e00);
  animation:spinBorder 4s linear infinite;
  z-index:-1;
  filter:blur(35px);
  opacity:0.65;
  pointer-events:none;
}

@keyframes spinBorder {
  0% { transform:rotate(0deg); }
  100% { transform:rotate(360deg); }
}

.exit-glass-content {
  position:relative;
  z-index:2;
  background:rgba(10, 15, 30, 0.65) !important;
  backdrop-filter:blur(40px) !important;
  -webkit-backdrop-filter:blur(40px) !important;
  border-radius:23px !important;
  padding:44px 32px 32px 32px !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.1), 0 30px 70px rgba(0,0,0,0.8) !important;
  overflow:hidden;
}

@keyframes exit-pop{from{opacity:0;transform:scale(.8) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}

.exit-badge {
  position:absolute;
  top:-14px;
  left:50%;
  transform:translateX(-50%);
  z-index:10;
  background:linear-gradient(135deg, rgba(255, 94, 0, 0.2) 0%, rgba(255, 0, 127, 0.2) 100%);
  border:1px solid rgba(255, 94, 0, 0.4);
  box-shadow:0 4px 15px rgba(255, 94, 0, 0.25);
  color:#ff9f68;
  font-size:0.78rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0.08em;
  padding:6px 18px;
  border-radius:100px;
  white-space:nowrap;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}

.exit-icon-wrapper {
  display:flex;
  justify-content:center;
  margin-bottom:20px;
}

.exit-3d-sphere {
  position:relative;
  width:80px;
  height:80px;
  border-radius:50%;
  background:radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.2) 0%, rgba(255, 255, 255, 0) 70%),
             radial-gradient(circle at 70% 70%, rgba(0, 242, 254, 0.2) 0%, rgba(255, 0, 127, 0.15) 100%),
             rgba(255, 255, 255, 0.03);
  border:1.5px solid rgba(255, 255, 255, 0.15);
  box-shadow:0 20px 40px rgba(0, 0, 0, 0.4),
             inset 0 -8px 20px rgba(0, 242, 254, 0.15),
             inset 0 8px 20px rgba(255, 255, 255, 0.2);
  display:flex;
  align-items:center;
  justify-content:center;
  animation:floatSphere 3s ease-in-out infinite;
}

.exit-3d-inner {
  font-size:3rem;
  filter:drop-shadow(0 8px 16px rgba(0,0,0,0.3));
  line-height:1;
}

@keyframes floatSphere {
  0%, 100% { transform:translateY(0); }
  50% { transform:translateY(-8px); }
}

.exit-title {
  font-size:2.1rem;
  font-weight:900;
  letter-spacing:-0.04em;
  margin-bottom:10px;
  background:linear-gradient(135deg, #ff007f, #ff5e00, #00f2fe);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  filter:drop-shadow(0 2px 10px rgba(255, 94, 0, 0.35));
}

.discount-code-box {
  background:rgba(255, 255, 255, 0.02);
  border:1.5px dashed rgba(255, 255, 255, 0.12);
  border-radius:16px;
  padding:16px 20px;
  margin-bottom:24px;
  text-align:left;
  transition:all 0.3s ease;
}

.discount-code-box:hover {
  background:rgba(255, 255, 255, 0.04);
  border-color:rgba(255, 94, 0, 0.3);
}

.discount-header {
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:10px;
}

.discount-tag {
  font-size:0.72rem;
  font-weight:800;
  color:#a1a1aa;
  letter-spacing:0.05em;
}

.discount-expiry {
  font-size:0.7rem;
  font-weight:600;
  color:#ef4444;
  background:rgba(239, 68, 68, 0.1);
  padding:2px 8px;
  border-radius:100px;
}

.discount-body {
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
}

.discount-code-value {
  font-family:'Courier New', Courier, monospace;
  font-size:1.5rem;
  font-weight:900;
  color:#00f2fe;
  letter-spacing:0.1em;
  text-shadow:0 0 10px rgba(0, 242, 254, 0.3);
}

.discount-copy-btn {
  background:rgba(255, 255, 255, 0.08);
  border:1px solid rgba(255, 255, 255, 0.12);
  color:#fff;
  font-size:0.8rem;
  font-weight:700;
  padding:8px 16px;
  border-radius:8px;
  cursor:pointer;
  transition:all 0.2s ease;
}

.discount-copy-btn:hover {
  background:#fff;
  color:#03060d;
  border-color:#fff;
}

.discount-copy-btn.copied {
  background:#10b981;
  color:#fff;
  border-color:#10b981;
}

.discount-subtext {
  font-size:0.75rem;
  color:#71717a;
  margin-top:8px;
  margin-bottom:0;
  line-height:1.4;
}

.exit-action-btns {
  display:flex;
  flex-direction:column;
  gap:12px;
  margin-bottom:16px;
}

.btn-electric-orange {
  background:linear-gradient(135deg, #ff5e00, #ff8c00);
  color:#fff !important;
  font-weight:800;
  border:none;
  border-radius:12px;
  box-shadow:0 0 20px rgba(255, 94, 0, 0.35), 0 4px 10px rgba(0, 0, 0, 0.3);
  transition:all 0.3s ease;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  width:100%;
  padding:16px 24px;
  font-size:1rem;
  text-shadow:0 1px 2px rgba(0,0,0,0.2);
  position:relative;
  overflow:hidden;
}

.btn-electric-orange:hover {
  background:linear-gradient(135deg, #ff6a00, #ffa500);
  box-shadow:0 0 30px rgba(255, 94, 0, 0.55), 0 6px 15px rgba(0, 0, 0, 0.4);
  transform:translateY(-2px);
}

.btn-electric-orange:active {
  transform:translateY(0);
}

.btn-ghost-premium {
  background:rgba(255, 255, 255, 0.05);
  border:1px solid rgba(255, 255, 255, 0.1);
  color:#e4e4e7 !important;
  font-weight:600;
  border-radius:12px;
  transition:all 0.2s ease;
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  padding:14px 24px;
  font-size:0.95rem;
}

.btn-ghost-premium:hover {
  background:rgba(255, 255, 255, 0.08);
  border-color:rgba(255, 255, 255, 0.2);
  color:#fff !important;
}

.exit-skip-text {
  background:none;
  border:none;
  font-size:0.8rem;
  color:#71717a;
  cursor:pointer;
  transition:color 0.2s ease;
}

.exit-skip-text:hover {
  color:#a1a1aa;
}

/* KM Assistant Chat */
.km-chat-btn{
  position:fixed;bottom:28px;right:96px;z-index:9997;
  width:56px;height:56px;border-radius:50%;
  background:linear-gradient(135deg,#0a1020,#1e3a5f);
  border:1.5px solid rgba(245,158,11,.65);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;box-shadow:0 4px 20px rgba(245,158,11,.25), inset 0 1px 0 rgba(255,255,255,.1);
  transition:all .3s ease;font-size:1.4rem;
  animation:km-pulse 3s ease-in-out infinite;
}
.km-chat-btn:hover{transform:scale(1.1);box-shadow:0 8px 32px rgba(245,158,11,.5);border-color:rgba(245,158,11,.9)}
@keyframes km-pulse{0%,100%{box-shadow:0 4px 20px rgba(245,158,11,.2), 0 0 0 1px rgba(245,158,11,.1)}
  50%{box-shadow:0 4px 36px rgba(245,158,11,.4), 0 0 15px rgba(245,158,11,.3)}}
.km-chat-badge{
  position:absolute;top:-4px;right:-4px;width:18px;height:18px;
  background:#ef4444;border-radius:50%;border:2px solid #03060d;
  display:flex;align-items:center;justify-content:center;
  font-size:.6rem;font-weight:800;color:#fff;
}
.km-chat-panel{
  position:fixed;bottom:100px;right:16px;z-index:9996;
  width:360px;max-height:560px;
  background:linear-gradient(145deg,rgba(6,10,20,.85),rgba(10,16,32,.92)) !important;
  border:1px solid rgba(245,158,11,.3) !important;border-radius:20px;
  box-shadow:0 24px 70px rgba(0,0,0,.65),0 0 0 1px rgba(245,158,11,.15),inset 0 1px 0 rgba(255,255,255,.08) !important;
  display:none;flex-direction:column;overflow:hidden;
  backdrop-filter:blur(20px) saturate(180%) !important;
  -webkit-backdrop-filter:blur(20px) saturate(180%) !important;
}
.km-chat-panel.open{display:flex;animation:chat-open .35s cubic-bezier(.34,1.56,.64,1) both}
@keyframes chat-open{from{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}

.km-chat-header{
  background:linear-gradient(135deg,#060a14,#0e1628) !important;
  border-bottom:2px solid #f59e0b !important;
  padding:16px 18px;display:flex;align-items:center;gap:12px;flex-shrink:0;
}
.km-chat-avatar{
  width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,.2);border:2px solid rgba(255,255,255,.3);
  display:flex;align-items:center;justify-content:center;font-size:1.3rem;
}
.km-chat-info{flex:1}
.km-chat-info strong{display:block;font-size:.92rem;font-weight:700;color:#fff}
.km-chat-info span{font-size:.72rem;color:rgba(255,255,255,.75);display:flex;align-items:center;gap:4px}
.km-status-dot{width:6px;height:6px;background:#4ade80;border-radius:50%;display:inline-block}
.km-chat-close{color:rgba(255,255,255,.75);background:none;border:none;
  cursor:pointer;font-size:1.2rem;padding:2px;line-height:1}

.km-chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;
  scrollbar-width:thin;scrollbar-color:rgba(245,158,11,.3) transparent}
.km-msg{display:flex;gap:8px;align-items:flex-end;max-width:100%;animation:msg-in .3s ease both}
@keyframes msg-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.km-msg.bot{flex-direction:row}
.km-msg.user{flex-direction:row-reverse}
.km-msg-avatar{width:28px;height:28px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,#1e3a5f,#f59e0b);
  display:flex;align-items:center;justify-content:center;font-size:.8rem}
.km-msg-bubble{max-width:260px;padding:10px 14px;border-radius:16px;font-size:.86rem;line-height:1.55}
.km-msg.bot .km-msg-bubble{
  background:rgba(15,23,42,.65);border:1px solid rgba(245,158,11,.2);
  color:var(--t1);border-bottom-left-radius:4px;
}
.km-msg.user .km-msg-bubble{
  background:linear-gradient(135deg,#1e3a5f,#1e40af);
  border:1px solid rgba(99,130,246,.3);
  color:#fff;border-bottom-right-radius:4px;
}
.km-msg-bubble a{color:var(--blue3);text-decoration:underline}
.km-typing{display:flex;gap:5px;padding:12px 14px;background:rgba(15,23,42,.65);
  border:1px solid rgba(245,158,11,.2);border-radius:16px;border-bottom-left-radius:4px;
  width:fit-content}
.km-typing span{width:6px;height:6px;background:var(--t3);border-radius:50%;
  animation:typing-dot 1.2s ease infinite}
.km-typing span:nth-child(2){animation-delay:.2s}
.km-typing span:nth-child(3){animation-delay:.4s}
@keyframes typing-dot{0%,100%{transform:translateY(0);opacity:.4}50%{transform:translateY(-4px);opacity:1}}

.km-quick-replies{padding:0 16px 10px;display:flex;flex-wrap:wrap;gap:7px}
.km-qr{background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.25);
  color:#fbbf24;padding:6px 14px;border-radius:100px;font-size:.78rem;
  font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap;
  font-family:inherit}
.km-qr:hover{background:rgba(245,158,11,.18);border-color:#f59e0b;color:#fff}

.km-chat-input-wrap{padding:12px 16px;border-top:1px solid rgba(148,163,184,.1);
  display:flex;gap:10px;align-items:center;flex-shrink:0}
.km-chat-input{flex:1;background:rgba(30,41,59,.8);border:1px solid rgba(148,163,184,.15);
  border-radius:12px;padding:10px 14px;color:var(--t1);font-size:.86rem;
  font-family:inherit;outline:none;resize:none;transition:all .2s ease;
  max-height:80px;overflow-y:auto;}
.km-chat-input:focus{border-color:rgba(245,158,11,.5);background:rgba(30,41,59,.95)}
.km-chat-send{width:36px;height:36px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,#f59e0b,#d97706);border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;color:#fff;font-size:.9rem;
  transition:all .2s ease}
.km-chat-send:hover{transform:scale(1.08);box-shadow:0 4px 12px rgba(245,158,11,.5)}
.km-chat-send:disabled{opacity:.5;cursor:not-allowed;transform:none}

.km-powered{padding:8px;text-align:center;font-size:.68rem;color:var(--t3);
  border-top:1px solid rgba(148,163,184,.06)}

/* Country pages badge */
.country-hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(5,150,105,.1);border:1px solid rgba(5,150,105,.25);
  color:var(--green3);padding:7px 18px;border-radius:100px;
  font-size:.82rem;font-weight:600;margin-bottom:24px;
}

/* Mobile fixes */
@media(max-width:768px){
  .km-chat-panel{width:calc(100vw - 20px);right:10px;bottom:90px}
  .sp-toast{left:12px;max-width:calc(100vw - 24px)}
  .sticky-cta{padding:10px 16px}
  .exit-box.glowing-auto{padding:1.5px !important}
  .exit-glass-content{padding:36px 20px 24px 20px !important}
  .km-chat-btn{right:80px}
}

/* ══ V4 BUG FIXES ══ */

/* Country cards - premium look */
.country-grid-4{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:20px;
}
.country-card{
  position:relative;overflow:hidden;
  background:linear-gradient(145deg,rgba(15,23,42,.9),rgba(9,17,32,.95));
  border:1px solid rgba(148,163,184,.1);
  border-radius:20px;padding:0;
  text-decoration:none;color:var(--t1);
  display:block;transition:all .35s ease;
  cursor:pointer;
}
.country-card:hover{
  border-color:rgba(59,130,246,.4);
  transform:translateY(-6px);
  box-shadow:0 20px 60px rgba(0,0,0,.4),0 0 0 1px rgba(59,130,246,.2);
}
.cc-flag{
  font-size:3.2rem;padding:28px 24px 0;
  position:relative;z-index:1;
  filter:drop-shadow(0 4px 12px rgba(0,0,0,.4));
  transition:transform .35s ease;
}
.country-card:hover .cc-flag{transform:scale(1.15) rotate(-3deg)}
.cc-glow{
  position:absolute;top:-40px;right:-40px;
  width:180px;height:180px;border-radius:50%;
  filter:blur(50px);opacity:.25;transition:opacity .35s ease;
  pointer-events:none;
}
.country-card:hover .cc-glow{opacity:.5}
.cc-glow-blue{background:radial-gradient(circle,#2563eb,transparent)}
.cc-glow-purple{background:radial-gradient(circle,#7c3aed,transparent)}
.cc-glow-green{background:radial-gradient(circle,#059669,transparent)}
.cc-glow-gold{background:radial-gradient(circle,#d97706,transparent)}
.cc-body{padding:16px 24px 24px;position:relative;z-index:1}
.cc-name{
  font-size:1.1rem;font-weight:800;letter-spacing:-.03em;
  color:var(--t1);margin-bottom:8px;
}
.cc-desc{font-size:.85rem;color:var(--t2);line-height:1.6;margin-bottom:14px}
.cc-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.cc-tag{
  background:rgba(148,163,184,.08);border:1px solid rgba(148,163,184,.12);
  color:var(--t2);padding:3px 10px;border-radius:100px;
  font-size:.72rem;font-weight:500;
}
.country-card:hover .cc-tag{
  background:rgba(59,130,246,.1);border-color:rgba(59,130,246,.2);color:var(--blue3);
}
.cc-cta{
  font-size:.85rem;font-weight:700;
  color:var(--blue3);display:flex;align-items:center;gap:6px;
  transition:gap .25s ease;
}
.country-card:hover .cc-cta{gap:10px}

/* Social proof — realistic, subtle */
.sp-toast{
  position:fixed;bottom:88px;left:20px;z-index:9990;
  background:rgba(15,23,42,.95);
  border:1px solid rgba(148,163,184,.15);
  border-left:3px solid var(--green2);
  border-radius:12px;padding:12px 16px;max-width:260px;
  display:none;align-items:center;gap:11px;
  box-shadow:0 8px 32px rgba(0,0,0,.5);backdrop-filter:blur(16px);
  animation:toast-in .35s ease both, sp-pulse 3s ease-in-out 0.5s infinite;
  transition:transform .3s cubic-bezier(.34,1.56,.64,1);
}
.sp-toast:hover{
  transform:translateY(-4px);
}
.sp-toast.show{display:flex}
@keyframes toast-in{from{opacity:0;transform:translateX(-16px)}to{opacity:1;transform:translateX(0)}}
@keyframes sp-pulse{
  0%,100%{
    box-shadow:0 8px 32px rgba(0,0,0,.5);
    border-color:rgba(148,163,184,.15);
  }
  50%{
    box-shadow:0 8px 32px rgba(0,0,0,.5), 0 0 12px rgba(16,185,129,.25);
    border-color:rgba(16,185,129,.35);
  }
}
.sp-avatar{
  width:34px;height:34px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,#1e3a5f,#2d5986);
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.78rem;color:#90cdf4;
  border:1px solid rgba(59,130,246,.2);
}
.sp-name{font-size:.8rem;font-weight:600;color:var(--t1);letter-spacing:-.01em}
.sp-action{font-size:.74rem;color:var(--t2);margin-top:2px;line-height:1.4}
.sp-time{font-size:.68rem;color:var(--green3);margin-top:3px;display:flex;align-items:center;gap:4px}
.sp-time::before{content:'';width:5px;height:5px;background:var(--green3);border-radius:50%;display:inline-block}

/* Announce bar click behavior */
.ann-bar{cursor:pointer}
.ann-bar a{pointer-events:none}

/* WhatsApp flood fix — dual option style */
.dual-cta{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.dual-cta .btn-wa{
  background:rgba(37,211,102,.12);border:1px solid rgba(37,211,102,.3);
  color:#4ade80;padding:10px 18px;border-radius:100px;font-size:.85rem;
  font-weight:600;cursor:pointer;text-decoration:none;transition:all .25s ease;
  display:inline-flex;align-items:center;gap:6px;
}
.dual-cta .btn-wa:hover{background:rgba(37,211,102,.2);color:#86efac}

/* Exit overlay fix */
.exit-overlay{
  align-items:center!important;
  justify-content:center!important;
}
#exit-close{
  position:absolute;top:16px;right:16px;
  background:rgba(148,163,184,.1)!important;
  border:1px solid rgba(148,163,184,.2)!important;
  border-radius:50%!important;
  width:32px!important;height:32px!important;
  display:flex!important;align-items:center!important;justify-content:center!important;
  cursor:pointer!important;color:var(--t2)!important;
  font-size:1rem!important;z-index:1!important;
  transition:all .2s ease!important;
}
#exit-close:hover{background:rgba(239,68,68,.15)!important;color:#f87171!important;border-color:rgba(239,68,68,.3)!important}

/* Announce bar popup */
.ann-popup{
  position:fixed;top:80px;left:50%;transform:translateX(-50%);
  z-index:10000;background:rgba(9,17,32,.98);
  border:1px solid rgba(59,130,246,.35);border-radius:16px;
  padding:24px 28px;max-width:420px;width:calc(100vw - 40px);
  box-shadow:0 20px 60px rgba(0,0,0,.6);backdrop-filter:blur(20px);
  display:none;
  animation:ann-drop .35s cubic-bezier(.34,1.56,.64,1) both;
}
.ann-popup.show{display:block}
@keyframes ann-drop{from{opacity:0;transform:translateX(-50%) translateY(-20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.ann-popup h4{font-size:1rem;font-weight:800;margin-bottom:10px;letter-spacing:-.02em}
.ann-popup p{color:var(--t2);font-size:.88rem;margin-bottom:16px;line-height:1.6}
.ann-popup-btns{display:flex;gap:10px;flex-wrap:wrap}
.ann-popup-close{position:absolute;top:12px;right:12px;background:none;border:none;
  color:var(--t3);cursor:pointer;font-size:1rem;padding:4px;line-height:1}

@media(max-width:768px){
  .country-grid-4{grid-template-columns:repeat(2,1fr);gap:14px}
  .cc-flag{font-size:2.4rem;padding:20px 18px 0}
  .cc-body{padding:12px 18px 18px}
}
@media(max-width:480px){
  .country-grid-4{grid-template-columns:1fr}
}

/* ══ V4 FINAL FIXES ══ */

/* Universal hero top spacing — works on ALL pages */
.hero, section.hero, .page-hero {
  padding-top: 168px !important;
  padding-bottom: 80px !important;
}
@media(max-width:768px){
  .hero, section.hero, .page-hero {
    padding-top: 140px !important;
    padding-bottom: 56px !important;
  }
}

/* ── GLASSMORPHISM CTA BOXES ── */
.cta-box {
  background: linear-gradient(135deg,
    rgba(37,99,235,.18) 0%,
    rgba(15,23,42,.95) 40%,
    rgba(9,17,32,.98) 100%) !important;
  border: 1px solid rgba(59,130,246,.3) !important;
  box-shadow:
    0 0 0 1px rgba(59,130,246,.15),
    0 32px 80px rgba(0,0,0,.5),
    inset 0 1px 0 rgba(255,255,255,.06) !important;
  backdrop-filter: blur(20px) !important;
  position: relative;
  overflow: hidden;
}
.cta-box::before {
  content: '';
  position: absolute;
  top: -80px; left: -80px;
  width: 300px; height: 300px;
  background: radial-gradient(circle, rgba(37,99,235,.2), transparent 70%);
  pointer-events: none;
}
.cta-box::after {
  content: '';
  position: absolute;
  bottom: -60px; right: -60px;
  width: 240px; height: 240px;
  background: radial-gradient(circle, rgba(16,185,129,.12), transparent 70%);
  pointer-events: none;
}
.cta-box h2, .cta-box p, .cta-box .cta-btns, .cta-box .risk-line {
  position: relative; z-index: 1;
}

/* ── GAMING CTA BOX ── */
.cta-box.gaming-cta {
  background: linear-gradient(135deg,
    rgba(16,185,129,.12) 0%,
    rgba(9,17,32,.97) 40%,
    rgba(5,8,15,.98) 100%) !important;
  border-color: rgba(16,185,129,.3) !important;
}
.cta-box.gaming-cta::before {
  background: radial-gradient(circle, rgba(16,185,129,.2), transparent 70%);
}
.cta-box.gaming-cta::after {
  background: radial-gradient(circle, rgba(245,158,11,.1), transparent 70%);
}
.gaming-icons {
  display: flex;
  justify-content: center;
  gap: 16px;
  margin-bottom: 20px;
  font-size: 2rem;
}
.gaming-icon-item {
  animation: game-float 3s ease-in-out infinite;
  display: inline-block;
  filter: drop-shadow(0 0 8px rgba(16,185,129,.4));
}
.gaming-icon-item:nth-child(2){animation-delay:.5s}
.gaming-icon-item:nth-child(3){animation-delay:1s}
.gaming-icon-item:nth-child(4){animation-delay:1.5s}
@keyframes game-float {
  0%,100%{transform:translateY(0) scale(1)}
  50%{transform:translateY(-6px) scale(1.1)}
}
.gaming-server-stat {
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.25);
  color:var(--green3);padding:5px 14px;border-radius:100px;font-size:.8rem;font-weight:600;
}

/* ── MICRO ANIMATIONS ── */

/* Fade in up for all rv elements */
.rv { transition: opacity .65s ease, transform .65s ease; }

/* Subtle number pulse on stats */
.hs-item strong {
  animation: stat-glow 4s ease-in-out infinite;
}
@keyframes stat-glow {
  0%,100%{filter:brightness(1)}
  50%{filter:brightness(1.3) drop-shadow(0 0 8px rgba(59,130,246,.4))}
}

/* Card shimmer on hover */
.card::after, .p-card::after {
  content:'';
  position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.04) 50%,transparent 60%);
  transform:translateX(-100%);transition:transform .6s ease;pointer-events:none;
}
.card:hover::after, .p-card:hover::after {
  transform:translateX(100%);
}

/* Animated border on featured card */
@keyframes border-spin {
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}
.p-card.featured {
  background-size:200% 200%;
}

/* Smooth scroll target offset */
[id] { scroll-margin-top: 120px; }

/* Spec row slide animation */
.spec-row {
  transition: background .2s ease, padding-left .2s ease, border-left-color .2s ease !important;
}

/* Button press effect */
.btn:active { transform: translateY(1px) scale(.98) !important; }

/* Why card icon bounce */
.why-card:hover .why-icon {
  animation: icon-bounce .4s cubic-bezier(.34,1.56,.64,1);
}
@keyframes icon-bounce {
  0%{transform:scale(1)}
  50%{transform:scale(1.25) rotate(-5deg)}
  100%{transform:scale(1)}
}

/* Testimonial card subtle float */
.testi-card:hover {
  transform: translateY(-5px) !important;
  box-shadow: 0 16px 48px rgba(0,0,0,.4) !important;
}

/* FAQ item expand animation */
.faq-a { animation: faq-expand .3s ease both; }
@keyframes faq-expand {
  from{opacity:0;transform:translateY(-8px)}
  to{opacity:1;transform:translateY(0)}
}

/* Page load fade */
body { animation: body-in .4s ease both; }
@keyframes body-in {
  from{opacity:0}
  to{opacity:1}
}

/* Gradient text shimmer on headings */
.gt, .gt-g, .gt-gold {
  background-size: 200% 100%;
  animation: text-shimmer 4s linear infinite;
}
@keyframes text-shimmer {
  0%{background-position:0% 50%}
  100%{background-position:200% 50%}
}

/* ── HERO GEO PILL FIX ── */
.geo-pill { margin-bottom: 20px; display: inline-flex; }

/* ── BLOG CARD FIX — ensure link works ── */
.card a, .card-title a { color: var(--t1) !important; }
.card:hover .card-title a { color: var(--blue3) !important; }

/* ══ ENERGETIC ORANGE HERO UPGRADE ══ */
.hero,.page-hero,section.hero{padding-top:168px!important;padding-bottom:80px!important;
  background:radial-gradient(ellipse 80% 60% at 10% 20%,rgba(249,115,22,.18) 0%,transparent 55%),
    radial-gradient(ellipse 60% 50% at 85% 15%,rgba(234,88,12,.15) 0%,transparent 55%),
    radial-gradient(ellipse 50% 60% at 50% 90%,rgba(245,158,11,.10) 0%,transparent 60%),
    #020817!important}
.hero h1{font-size:clamp(2.6rem,5.5vw,4.6rem)!important;font-weight:800!important;letter-spacing:-.055em!important;line-height:1.02!important;
  background:linear-gradient(135deg,#ffffff 0%,#f8fafc 45%,#ffedd5 75%,#fed7aa 100%)!important;
  -webkit-background-clip:text!important;-webkit-text-fill-color:transparent!important;background-clip:text!important}
.hero-glow.g1{background:radial-gradient(circle,rgba(249,115,22,.4),rgba(245,158,11,.2),transparent 70%)!important;width:750px!important;height:750px!important;top:-200px!important;left:-200px!important;opacity:.45!important;filter:blur(100px)!important}
.hero-grid{background-image:linear-gradient(rgba(249,115,22,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(249,115,22,.05) 1px,transparent 1px)!important;background-size:56px 56px!important}
.hero-eyebrow{background:rgba(249,115,22,.08)!important;border-color:rgba(249,115,22,.25)!important;color:#ffb070!important}
.hero-desc{color:#cbd5e1!important;font-size:clamp(1rem,1.8vw,1.2rem)!important}
.geo-pill{background:rgba(249,115,22,.08)!important;border-color:rgba(249,115,22,.22)!important;color:#ffb070!important}

/* ── HERO EYEBROW DOT UPGRADE ── */
.hero-eyebrow .dot { background: #f97316 !important; }

/* ── SQUARES CANVAS BACKGROUND ── */
.squares-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  pointer-events: none;
  z-index: 1;
}
.hero-glow {
  z-index: 0 !important;
}
/* Hide static grid when JS is loaded */
.hero-bg-js-loaded .hero-grid {
  display: none !important;
}

/* Cursor-Position Glowing CTA Button Style */
.btn-interactive-glow {
  position: relative;
  background: linear-gradient(135deg, #f97316, #ea580c) !important;
  border: 1px solid rgba(253, 186, 116, 0.4) !important;
  color: #ffffff !important;
  overflow: hidden;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  transition: transform 0.25s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.25s ease !important;
  box-shadow: 0 4px 20px rgba(234, 88, 12, 0.4), 0 0 0 1px rgba(251, 146, 60, 0.15) !important;
  cursor: pointer;
  z-index: 1;
  isolation: isolate;
}
.btn-interactive-glow:hover {
  transform: translateY(-2px) scale(1.02) !important;
  box-shadow: 0 10px 30px rgba(234, 88, 12, 0.55), 0 0 15px rgba(249, 115, 22, 0.35) !important;
}
.btn-interactive-glow::before {
  content: '';
  position: absolute;
  inset: -1px;
  background: radial-gradient(
    100px circle at var(--x, 50%) var(--y, 50%),
    rgba(255, 255, 255, 0.35) 0%,
    rgba(253, 186, 116, 0.15) 50%,
    transparent 100%
  ) !important;
  opacity: 0;
  transition: opacity 0.3s ease;
  z-index: 2;
  pointer-events: none;
}
.btn-interactive-glow:hover::before {
  opacity: 1;
}
.btn-interactive-glow .btn-arrow {
  transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important;
  margin-left: 2px;
}
.btn-interactive-glow:hover .btn-arrow {
  transform: translateX(4px);
}

.hero .btn-primary{background:linear-gradient(135deg,#f97316,#ea580c)!important;box-shadow:0 4px 24px rgba(234,88,12,.4)!important}
.hero .btn-primary:hover{box-shadow:0 10px 40px rgba(234,88,12,.55)!important}
.hs-item strong{background:linear-gradient(135deg,#fed7aa,#f97316)!important;-webkit-background-clip:text!important;-webkit-text-fill-color:transparent!important;background-clip:text!important}
.gt{background:linear-gradient(135deg,#fdba74,#f97316,#ea580c)!important;-webkit-background-clip:text!important;-webkit-text-fill-color:transparent!important;background-clip:text!important}
.best-tag{background:linear-gradient(135deg,#ea580c,#f97316)!important;box-shadow:0 4px 16px rgba(234,88,12,.4)!important}
.p-card.featured{background:linear-gradient(145deg,rgba(234,88,12,.14),rgba(249,115,22,.08),rgba(9,17,32,.97))!important;border-color:rgba(249,115,22,.5)!important;box-shadow:0 0 0 1px rgba(249,115,22,.3),0 24px 80px rgba(234,88,12,.25)!important}
.nav-logo-text span{background:linear-gradient(135deg,#fdba74,#f97316)!important;-webkit-background-clip:text!important;-webkit-text-fill-color:transparent!important;background-clip:text!important}
.f-logo span{background:linear-gradient(135deg,#fdba74,#f97316)!important;-webkit-background-clip:text!important;-webkit-text-fill-color:transparent!important;background-clip:text!important}
.badge-pill{background:rgba(249,115,22,.12)!important;border-color:rgba(249,115,22,.3)!important;color:#f97316!important}
::-webkit-scrollbar-thumb{background:#ea580c!important}
@media(max-width:768px){.hero h1{font-size:2.2rem!important}}

/* ══ V6 COMPREHENSIVE FIXES ══ */

/* ── Less dark, more refined bg ── */
:root {
  --bg: #060a14 !important;
  --bg2: #0a1020 !important;
  --bg3: #0e1628 !important;
}
body { background: #060a14 !important; }

/* ── Remove ALL pink/purple #6F26A1 from non-hero ── */
/* Replace with blue-teal instead */
.badge-pill, .s-label, .geo-pill {
  background: rgba(37,99,235,.1) !important;
  border-color: rgba(37,99,235,.25) !important;
  color: #60a5fa !important;
}

/* ── Geo pill: 20px margin-top on ALL pages ── */
.geo-pill {
  margin-top: 20px !important;
  margin-bottom: 20px !important;
}
.hero-eyebrow {
  margin-top: 20px !important;
  margin-bottom: 20px !important;
}
.hero .s-label {
  margin-top: 20px !important;
}

/* ── SERVICE CARDS — Premium Glassmorphism ── */
.card {
  background: linear-gradient(145deg,
    rgba(255,255,255,.06) 0%,
    rgba(255,255,255,.02) 100%) !important;
  border: 1px solid rgba(99,130,246,.25) !important;
  border-radius: 20px !important;
  backdrop-filter: blur(16px) saturate(180%) !important;
  -webkit-backdrop-filter: blur(16px) saturate(180%) !important;
  box-shadow:
    0 0 0 1px rgba(99,130,246,.1),
    0 4px 24px rgba(0,0,0,.3),
    inset 0 1px 0 rgba(255,255,255,.08) !important;
  transition: all .35s cubic-bezier(.4,0,.2,1) !important;
  position: relative;
  overflow: visible !important;
}
.card:hover {
  background: linear-gradient(145deg,
    rgba(99,130,246,.12) 0%,
    rgba(99,130,246,.04) 100%) !important;
  border-color: rgba(99,130,246,.55) !important;
  box-shadow:
    0 0 0 1px rgba(99,130,246,.3),
    0 8px 32px rgba(37,99,235,.25),
    0 0 60px rgba(37,99,235,.1),
    inset 0 1px 0 rgba(255,255,255,.12) !important;
  transform: translateY(-6px) !important;
}
.card-top, .card-accent {
  height: 2px !important;
  background: linear-gradient(90deg,
    rgba(37,99,235,.8), rgba(139,92,246,.6), rgba(16,185,129,.8)) !important;
  opacity: 0 !important;
  border-radius: 2px 2px 0 0 !important;
  transition: opacity .35s ease !important;
}
.card:hover .card-top, .card:hover .card-accent { opacity: 1 !important; }

/* Card glow on hover */
.card::after {
  content: '' !important;
  position: absolute !important;
  inset: -1px !important;
  border-radius: 21px !important;
  background: linear-gradient(135deg,
    rgba(37,99,235,.15), rgba(139,92,246,.1), rgba(16,185,129,.12)) !important;
  opacity: 0 !important;
  transition: opacity .35s ease !important;
  z-index: -1 !important;
  filter: blur(12px) !important;
}
.card:hover::after { opacity: 1 !important; }

/* ── CLIENT STORIES / TESTIMONIALS ── */
.testi-card {
  background: linear-gradient(145deg,
    rgba(255,255,255,.05),
    rgba(255,255,255,.02)) !important;
  border: 1px solid rgba(148,163,184,.12) !important;
  backdrop-filter: blur(12px) !important;
  transition: all .3s ease !important;
}
.testi-card:hover {
  border-color: rgba(99,130,246,.4) !important;
  background: linear-gradient(145deg,
    rgba(99,130,246,.1),
    rgba(255,255,255,.03)) !important;
  box-shadow:
    0 8px 32px rgba(37,99,235,.15),
    0 0 0 1px rgba(99,130,246,.2),
    inset 0 1px 0 rgba(255,255,255,.1) !important;
  transform: translateY(-4px) !important;
}

/* ── PRICING CARDS — refined ── */
.p-card {
  background: linear-gradient(145deg,
    rgba(15,23,42,.9),
    rgba(9,17,32,.95)) !important;
  border: 1px solid rgba(148,163,184,.12) !important;
  backdrop-filter: blur(12px) !important;
}
.p-card:hover {
  border-color: rgba(99,130,246,.45) !important;
  box-shadow:
    0 0 0 1px rgba(99,130,246,.2),
    0 20px 60px rgba(37,99,235,.2) !important;
}
.p-card.featured {
  background: linear-gradient(145deg,
    rgba(37,99,235,.14),
    rgba(139,92,246,.06),
    rgba(9,17,32,.97)) !important;
  border-color: rgba(99,130,246,.5) !important;
  box-shadow:
    0 0 0 1px rgba(99,130,246,.35),
    0 24px 80px rgba(37,99,235,.25) !important;
}

/* ── WHY CARDS glassmorphism ── */
.why-card {
  background: linear-gradient(145deg,
    rgba(255,255,255,.05),
    rgba(255,255,255,.02)) !important;
  border: 1px solid rgba(148,163,184,.1) !important;
  backdrop-filter: blur(10px) !important;
}
.why-card:hover {
  border-color: rgba(99,130,246,.4) !important;
  background: linear-gradient(145deg,
    rgba(37,99,235,.1),
    rgba(255,255,255,.03)) !important;
}

/* ── NAVBAR dropdown fix — prevent disappear on scroll ── */
.navbar { position: fixed !important; top: 0 !important; }
.nav-links .has-drop { position: relative !important; }
.dropdown {
  position: absolute !important;
  pointer-events: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
  transition: opacity .2s ease, visibility .2s ease, top .2s ease !important;
  top: calc(100% + 8px) !important;
  z-index: 9999 !important;
}
.has-drop:hover .dropdown,
.has-drop:focus-within .dropdown {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  top: calc(100% + 4px) !important;
}
/* Extended hover area to prevent gap */
.has-drop::after {
  content: '' !important;
  position: absolute !important;
  bottom: -8px !important;
  left: 0 !important;
  right: 0 !important;
  height: 12px !important;
  display: block !important;
}

/* ── VPS "Need more power" highlight box ── */
.upgrade-box {
  background: linear-gradient(135deg,
    rgba(37,99,235,.15) 0%,
    rgba(16,185,129,.08) 100%) !important;
  border: 1px solid rgba(37,99,235,.4) !important;
  border-radius: 16px !important;
  padding: 22px 28px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
  box-shadow:
    0 0 0 1px rgba(37,99,235,.15),
    0 8px 32px rgba(37,99,235,.12) !important;
  animation: upgrade-pulse 3s ease-in-out infinite !important;
}
@keyframes upgrade-pulse {
  0%,100%{box-shadow:0 0 0 1px rgba(37,99,235,.15),0 8px 32px rgba(37,99,235,.12)}
  50%{box-shadow:0 0 0 1px rgba(37,99,235,.3),0 8px 40px rgba(37,99,235,.22)}
}

/* ── Radio reseller CTA box ── */
.reseller-cta-box {
  background: linear-gradient(135deg,
    rgba(245,158,11,.12) 0%,
    rgba(16,185,129,.06) 100%) !important;
  border: 1px solid rgba(245,158,11,.35) !important;
  border-radius: 14px !important;
  padding: 20px 24px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 14px !important;
  flex-wrap: wrap !important;
  box-shadow: 0 4px 20px rgba(245,158,11,.1) !important;
}

/* ── CTA boxes — enhanced ── */
.cta-box {
  background: linear-gradient(135deg,
    rgba(37,99,235,.12) 0%,
    rgba(139,92,246,.06) 50%,
    rgba(9,17,32,.98) 100%) !important;
  border: 1px solid rgba(37,99,235,.25) !important;
  backdrop-filter: blur(20px) !important;
}

/* ── Remove pink/purple from non-hero badges ── */
.badge-green, .badge-pill { background: rgba(37,99,235,.1) !important; color: #60a5fa !important; border-color: rgba(37,99,235,.25) !important; }
.badge-gold { background: rgba(245,158,11,.12) !important; color: #fbbf24 !important; border-color: rgba(245,158,11,.3) !important; }

/* ── Services section card link buttons fix ── */
.card-body .btn, .card .btn {
  display: inline-flex !important;
  align-items: center !important;
  text-decoration: none !important;
  cursor: pointer !important;
}

/* ── Page headers label margin ── */
.page-hero .s-label,
.page-hero .geo-pill,
.page-hero .hero-eyebrow {
  margin-top: 20px !important;
}

/* ── Better glow on headings ── */
.s-title { letter-spacing: -.035em !important; }

@media(max-width:768px){.upgrade-box{flex-direction:column;text-align:center}.reseller-cta-box{flex-direction:column;text-align:center}}

.badge-gold { background: rgba(245,158,11,.12) !important; color: #fbbf24 !important; border-color: rgba(245,158,11,.3) !important; }

/* ── Services section card link buttons fix ── */
.card-body .btn, .card .btn, .p-card .btn {
  display: inline-flex !important;
  align-items: center !important;
  text-decoration: none !important;
  cursor: pointer !important;
  position: relative !important;
  z-index: 10 !important;
  pointer-events: auto !important;
}

/* ── Page headers label margin ── */
.page-hero .s-label,
.page-hero .geo-pill,
.page-hero .hero-eyebrow {
  margin-top: 20px !important;
}

/* ── Better glow on headings ── */
.s-title { letter-spacing: -.035em !important; }

@media(max-width:768px){.upgrade-box{flex-direction:column;text-align:center}.reseller-cta-box{flex-direction:column;text-align:center}}

/* ── PREMIUM INTERACTIVE GLOWING EDGE CARDS ── */
.glowing-card-mesh-border {
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  z-index: -2;
  mask-image: conic-gradient(from var(--pointer-deg) at center, black 25%, transparent 40%, transparent 60%, black 75%);
  -webkit-mask-image: conic-gradient(from var(--pointer-deg) at center, black 25%, transparent 40%, transparent 60%, black 75%);
  opacity: calc((var(--pointer-d) - var(--color-sens)) / (100 - var(--color-sens)));
  transition: opacity 0.25s ease-out;
  pointer-events: none;
}

.glowing-card-mesh-border::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background:
    radial-gradient(at 80% 55%, hsla(268,100%,76%,1) 0px, transparent 50%),
    radial-gradient(at 69% 34%, hsla(349,100%,74%,1) 0px, transparent 50%),
    radial-gradient(at 8% 6%, hsla(136,100%,78%,1) 0px, transparent 50%),
    radial-gradient(at 41% 38%, hsla(192,100%,64%,1) 0px, transparent 50%),
    radial-gradient(at 86% 85%, hsla(186,100%,74%,1) 0px, transparent 50%),
    radial-gradient(at 82% 18%, hsla(52,100%,65%,1) 0px, transparent 50%),
    radial-gradient(at 51% 4%, hsla(12,100%,72%,1) 0px, transparent 50%),
    linear-gradient(#c299ff 0 100%);
  -webkit-mask: 
    linear-gradient(#fff 0 0) content-box, 
    linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
}

.glowing-card-glow {
  position: absolute;
  inset: -40px;
  pointer-events: none;
  z-index: -1;
  mask-image: conic-gradient(from var(--pointer-deg) at center, black 2.5%, transparent 10%, transparent 90%, black 97.5%);
  -webkit-mask-image: conic-gradient(from var(--pointer-deg) at center, black 2.5%, transparent 10%, transparent 90%, black 97.5%);
  opacity: calc((var(--pointer-d) - var(--glow-sens)) / (100 - var(--glow-sens)));
  mix-blend-mode: var(--glow-blend);
  transition: opacity 0.25s ease-out;
  border-radius: inherit;
}

.glowing-card-glow::before {
  content: "";
  position: absolute;
  inset: 40px;
  border-radius: inherit;
  box-shadow: 
    inset 0 0 0 1px hsl(var(--glow-color) / 100%),
    inset 0 0 1px 0 hsl(var(--glow-color) / calc(var(--glow-boost) + 60%)),
    inset 0 0 3px 0 hsl(var(--glow-color) / calc(var(--glow-boost) + 50%)),
    inset 0 0 6px 0 hsl(var(--glow-color) / calc(var(--glow-boost) + 40%)),
    inset 0 0 15px 0 hsl(var(--glow-color) / calc(var(--glow-boost) + 30%)),
    inset 0 0 25px 2px hsl(var(--glow-color) / calc(var(--glow-boost) + 20%)),
    inset 0 0 50px 2px hsl(var(--glow-color) / calc(var(--glow-boost) + 10%)),
    0 0 1px 0 hsl(var(--glow-color) / calc(var(--glow-boost) + 60%)),
    0 0 3px 0 hsl(var(--glow-color) / calc(var(--glow-boost) + 50%)),
    0 0 6px 0 hsl(var(--glow-color) / calc(var(--glow-boost) + 40%)),
    0 0 15px 0 hsl(var(--glow-color) / calc(var(--glow-boost) + 30%)),
    0 0 25px 2px hsl(var(--glow-color) / calc(var(--glow-boost) + 20%)),
    0 0 50px 2px hsl(var(--glow-color) / calc(var(--glow-boost) + 10%));
}

.card:not(:hover):not(.animating):not(.auto-glow) .glowing-card-mesh-border,
.card:not(:hover):not(.animating):not(.auto-glow) .glowing-card-glow,
.p-card:not(:hover):not(.animating):not(.auto-glow) .glowing-card-mesh-border,
.p-card:not(:hover):not(.animating):not(.auto-glow) .glowing-card-glow,
.cta-box:not(:hover):not(.animating):not(.auto-glow) .glowing-card-mesh-border,
.cta-box:not(:hover):not(.animating):not(.auto-glow) .glowing-card-glow {
  opacity: 0 !important;
  transition: opacity 0.75s ease-in-out;
}

/* --- Glowing Card Dynamic Wrapper Overrides --- */
.card.glowing-initialized,
.p-card.glowing-initialized,
.cta-box.glowing-initialized {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  overflow: visible !important;
}

/* Ensure content container is relative and clips nested elements */
.glowing-card-content-container {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
  z-index: 1;
}

/* .card content container styling */
.card.glowing-initialized > .glowing-card-content-container {
  background: linear-gradient(145deg,
    rgba(255,255,255,.06) 0%,
    rgba(255,255,255,.02) 100%) !important;
  border: 1px solid rgba(99,130,246,.25) !important;
  border-radius: 20px !important;
  backdrop-filter: blur(16px) saturate(180%) !important;
  -webkit-backdrop-filter: blur(16px) saturate(180%) !important;
  box-shadow:
    0 0 0 1px rgba(99,130,246,.1),
    0 4px 24px rgba(0,0,0,.3),
    inset 0 1px 0 rgba(255,255,255,.08) !important;
  padding: 0 !important;
  transition: all .35s cubic-bezier(.4,0,.2,1) !important;
}

.card.glowing-initialized:hover > .glowing-card-content-container {
  background: linear-gradient(145deg,
    rgba(99,130,246,.12) 0%,
    rgba(99,130,246,.04) 100%) !important;
  border-color: rgba(99,130,246,.55) !important;
  box-shadow:
    0 0 0 1px rgba(99,130,246,.3),
    0 8px 32px rgba(37,99,235,.25),
    0 0 60px rgba(37,99,235,.1),
    inset 0 1px 0 rgba(255,255,255,.12) !important;
}

/* .p-card content container styling */
.p-card.glowing-initialized > .glowing-card-content-container {
  background: linear-gradient(145deg, rgba(15,23,42,.8), rgba(9,17,32,.9)) !important;
  border: 1px solid rgba(148,163,184,.12) !important;
  border-radius: 24px !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  padding: 34px !important;
  transition: all .35s cubic-bezier(.4,0,.2,1) !important;
}

.p-card.glowing-initialized.featured > .glowing-card-content-container {
  background: linear-gradient(145deg,
    rgba(109,40,217,.14),
    rgba(37,99,235,.08),
    rgba(9,17,32,.97)) !important;
  border: 1px solid rgba(124,58,237,.5) !important;
  box-shadow:
    0 0 0 1px rgba(124,58,237,.3),
    0 24px 80px rgba(109,40,217,.25) !important;
}

.p-card.glowing-initialized:hover > .glowing-card-content-container {
  border-color: rgba(59,130,246,.4) !important;
  box-shadow: 0 20px 60px rgba(37,99,235,.2), 0 0 0 1px rgba(59,130,246,.2) !important;
}

.p-card.glowing-initialized.featured:hover > .glowing-card-content-container {
  border-color: rgba(59,130,246,.6) !important;
  box-shadow: 0 0 0 1px rgba(59,130,246,.5), 0 24px 80px rgba(37,99,235,.3) !important;
}

/* .cta-box content container styling */
.cta-box.glowing-initialized > .glowing-card-content-container {
  background: linear-gradient(135deg,
    rgba(37,99,235,.12) 0%,
    rgba(139,92,246,.06) 50%,
    rgba(9,17,32,.98) 100%) !important;
  border: 1px solid rgba(37,99,235,.25) !important;
  border-radius: 24px !important;
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  box-shadow:
    0 0 0 1px rgba(59,130,246,.15),
    0 32px 80px rgba(0,0,0,.5),
    inset 0 1px 0 rgba(255,255,255,.06) !important;
  padding: 70px 44px !important;
  transition: all .35s cubic-bezier(.4,0,.2,1) !important;
}

@media(max-width:768px){
  .cta-box.glowing-initialized > .glowing-card-content-container {
    padding: 44px 24px !important;
  }
}
@media(max-width:600px){
  .cta-box.glowing-initialized > .glowing-card-content-container {
    padding: 36px 20px !important;
  }
}

/* Fix glowing cards layout shift caused by relative badge elements */
.glowing-initialized > .best-tag,
.glowing-initialized > .hot-tag,
.glowing-initialized > .badge-green,
.glowing-initialized > .badge-pill,
.glowing-initialized > .badge-gold {
  position: absolute !important;
  top: -14px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  margin: 0 !important;
  z-index: 10;
}

/* Ensure glowing border containers inherit the exact border-radius of the inner content container */
.card.glowing-initialized {
  border-radius: 20px !important;
}
.p-card.glowing-initialized {
  border-radius: 20px !important;
}
.cta-box.glowing-initialized {
  border-radius: 24px !important;
}

/* Disable legacy hover/featured pseudo-element glows when premium glowing system is active */
.card.glowing-initialized::before,
.card.glowing-initialized::after,
.p-card.glowing-initialized::before,
.p-card.glowing-initialized::after,
.cta-box.glowing-initialized::before,
.cta-box.glowing-initialized::after {
  display: none !important;
  content: none !important;
  opacity: 0 !important;
}

/* Elegant Locations sub-footer link bar */
.footer-loc {
  border-top: 1px solid var(--b);
  padding: 18px 0;
  margin-top: 32px;
  display: flex;
  gap: 12px 24px;
  flex-wrap: wrap;
  font-size: .8rem;
  color: var(--t3);
  align-items: center;
}
.footer-loc span {
  font-weight: 700;
  color: var(--t2);
  letter-spacing: .06em;
  text-transform: uppercase;
  font-size: .75rem;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.footer-loc a {
  color: var(--t3);
  transition: var(--tr);
  text-decoration: none;
  font-weight: 500;
}
.footer-loc a:hover {
  color: var(--blue3);
  text-shadow: 0 0 10px rgba(96,165,250,0.35);
}
@media(max-width: 768px) {
  .footer-loc {
    justify-content: center;
    text-align: center;
    gap: 12px 18px;
    padding: 16px 0;
  }
}

/* Upgrade Promotion Card Component */
.upgrade-promo-card {
  margin-top: 64px;
  padding: 40px;
  background: rgba(15, 23, 42, 0.45);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-radius: 24px;
  text-align: center;
  position: relative;
  overflow: hidden;
  transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  box-shadow: 0 12px 40px -10px rgba(0, 0, 0, 0.6), inset 0 1px 0 0 rgba(255, 255, 255, 0.05);
}

/* VPS to Dedicated variation */
.upgrade-promo-card.vps-upgrade {
  border: 1px solid rgba(249, 115, 22, 0.15);
}
.upgrade-promo-card.vps-upgrade::before {
  content: '';
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: radial-gradient(circle, rgba(249, 115, 22, 0.08) 0%, transparent 60%);
  opacity: 0.8;
  pointer-events: none;
  animation: pulseUpgradeGlow 6s ease-in-out infinite alternate;
}
.upgrade-promo-card.vps-upgrade:hover {
  transform: translateY(-5px);
  border-color: rgba(249, 115, 22, 0.45);
  box-shadow: 0 20px 48px -8px rgba(0, 0, 0, 0.7), 0 0 30px rgba(249, 115, 22, 0.2), inset 0 1px 0 0 rgba(255, 255, 255, 0.08);
}
.upgrade-promo-card.vps-upgrade .upgrade-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(249, 115, 22, 0.12);
  border: 1px solid rgba(249, 115, 22, 0.3);
  color: #f97316;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 6px 14px;
  border-radius: 99px;
  margin-bottom: 20px;
}

/* Radio to Reseller variation */
.upgrade-promo-card.radio-upgrade {
  border: 1px solid rgba(245, 158, 11, 0.15);
}
.upgrade-promo-card.radio-upgrade::before {
  content: '';
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: radial-gradient(circle, rgba(245, 158, 11, 0.08) 0%, transparent 60%);
  opacity: 0.8;
  pointer-events: none;
  animation: pulseUpgradeGlow 6s ease-in-out infinite alternate;
}
.upgrade-promo-card.radio-upgrade:hover {
  transform: translateY(-5px);
  border-color: rgba(245, 158, 11, 0.45);
  box-shadow: 0 20px 48px -8px rgba(0, 0, 0, 0.7), 0 0 30px rgba(245, 158, 11, 0.2), inset 0 1px 0 0 rgba(255, 255, 255, 0.08);
}
.upgrade-promo-card.radio-upgrade .upgrade-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(245, 158, 11, 0.12);
  border: 1px solid rgba(245, 158, 11, 0.3);
  color: #f59e0b;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 6px 14px;
  border-radius: 99px;
  margin-bottom: 20px;
}

.upgrade-promo-card h3 {
  font-size: 1.75rem;
  color: var(--t1);
  margin-bottom: 12px;
  font-weight: 800;
  letter-spacing: -0.02em;
}
.upgrade-promo-card p {
  color: var(--t2);
  font-size: 1rem;
  max-width: 650px;
  margin: 0 auto 28px;
  line-height: 1.6;
}

@keyframes pulseUpgradeGlow {
  0% { transform: scale(0.95); opacity: 0.6; }
  100% { transform: scale(1.05); opacity: 0.9; }
}




