/* ============================================================
   NEXO THEME — ne- prefix
   Palette: Purple #a855f7, Cyan #06b6d4 | Space Grotesk + Syne
   Signature: glassmorphism cards, gradient text, 3-tier VIP cards
   ============================================================ */

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

/* ── Variables ─────────────────────────────────────────────── */
:root {--ne_cyan-lt:   rgba(103,232,249,1);--ne_r-lg:      16px;--ne_purple:    #a855f7;--ne_shadow:    0 8px 32px rgba(0,0,0,.5);--ne_text:      #e2e8f0;--ne_purple-dk: #7c3aed;--ne_glow-p:    0 0 30px rgba(168,85,247,.25);--ne_muted:     #94a3b8;--ne_bg2:       rgba(13,13,32,1);--ne_bg:        #060610;--ne_glass-bd:  rgba(255,255,255,.1);--ne_cyan:      rgba(6,182,212,1);--ne_glass:     rgba(255,255,255,.05);--ne_r:         10px;--ne_white:     #ffffff;--ne_glow-c:    0 0 30px rgba(6,182,212,.25)}

/* ── Reset ──────────────────────────────────────────────────── */
*, *::before, *::after {padding: 0;box-sizing: border-box;margin: 0}
html { scroll-behavior: smooth; }
body {min-height: 100vh;overflow-x: hidden;font-family: 'Space Grotesk', sans-serif;line-height: 1.6;background: var(--ne_bg);color: var(--ne_text);font-size: 16px;pointer-events:auto;isolation:auto;user-select:auto;outline-offset:0}
img {max-width: 100%;display: block;height: auto}
a {color: var(--ne_cyan);text-decoration: none}
a:hover { text-decoration: underline; }

/* ── Background orbs ────────────────────────────────────────── */
body::before,
body::after {position: fixed;border-radius: 50%;pointer-events: none;content: '';z-index: 0}
body::before {width: 600px;height: 600px;top: -200px;left: -200px;background: radial-gradient(circle, rgba(168,85,247,.15) 0%, transparent 70%)}
body::after {bottom: -150px;background: radial-gradient(circle, rgba(6,182,212,.12) 0%, transparent 70%);height: 500px;width: 500px;right: -150px}

/* ── Typography ─────────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {color: var(--ne_white);font-family: 'Syne', sans-serif;line-height: 1.15;font-weight: 700}
h1 {font-size: clamp(2.2rem, 5vw, 3.8rem);font-weight: 800}
h2 { font-size: clamp(1.7rem, 3.5vw, 2.6rem); }
h3 { font-size: clamp(1.2rem, 2.5vw, 1.7rem); }
p  { color: var(--ne_text); }

/* Gradient text utility */
.ne-grad {color: transparent;-webkit-text-fill-color: transparent;-webkit-background-clip: text;background-clip: text;background-image: linear-gradient(135deg, var(--ne_purple) 0%, var(--ne_cyan) 100%)}

/* ── Layout ─────────────────────────────────────────────────── */
.ne-container {margin: 0 auto;position: relative;z-index: 1;max-width: 1160px;width: 100%;padding: 0 20px}
.ne-section   { padding: 80px 0; }

/* ── Glass card mixin ───────────────────────────────────────── */
.ne-glass {background: var(--ne_glass);backdrop-filter: blur(12px);border: 1px solid var(--ne_glass-bd);-webkit-backdrop-filter: blur(12px);border-radius: var(--ne_r-lg)}

/* ── Nav ────────────────────────────────────────────────────── */
.ne-nav {top: 0;z-index: 100;-webkit-backdrop-filter: blur(16px);backdrop-filter: blur(16px);border-bottom: 1px solid var(--ne_glass-bd);position: sticky;background: rgba(6,6,16,.85)}
.ne-nav__inner {max-width: 1160px;height: 64px;justify-content: space-between;margin: 0 auto;align-items: center;padding: 0 20px;display: flex}
.ne-nav__logo {font-size: 1.5rem;display: flex;font-family: 'Syne', sans-serif;gap: 6px;font-weight: 800;align-items: center}
.ne-nav__logo-text { color: var(--ne_white); }
.ne-nav__logo-dot {background: linear-gradient(135deg, var(--ne_purple), var(--ne_cyan));width: 8px;height: 8px;border-radius: 50%}
.ne-nav__links {display: flex;list-style: none;gap: 28px}
.ne-nav__links a {color: var(--ne_muted);letter-spacing: .02em;font-size: .88rem;font-weight: 500;transition: color .2s}
.ne-nav__links a:hover {color: var(--ne_white);text-decoration: none}
.ne-nav__cta {padding: 9px 22px;color: var(--ne_white) !important;font-size: .85rem;background: linear-gradient(135deg, var(--ne_purple), var(--ne_cyan));border-radius: 50px;transition: opacity .2s, transform .2s;font-weight: 600}
.ne-nav__cta:hover {text-decoration: none;opacity: .9;transform: translateY(-1px)}
.ne-burger {display: none;gap: 5px;background: none;border: none;padding: 4px;cursor: pointer;flex-direction: column}
.ne-burger span {background: var(--ne_text);display: block;transition: all .3s;height: 2px;width: 24px}

/* ── Hero ────────────────────────────────────────────────────── */
.ne-hero {padding: 80px 0 70px;position: relative}
.ne-hero__inner {grid-template-columns: 1fr 420px;align-items: center;display: grid;gap: 60px}
.ne-hero__eyebrow {color: var(--ne_purple);gap: 8px;background: rgba(168,85,247,.1);text-transform: uppercase;font-size: .78rem;letter-spacing: .06em;margin-bottom: 20px;padding: 5px 16px;align-items: center;font-weight: 600;border-radius: 50px;display: inline-flex;border: 1px solid rgba(168,85,247,.25)}
.ne-hero__h1 { margin-bottom: 18px; }
.ne-hero__lead {font-size: 1.08rem;margin-bottom: 32px;max-width: 500px;color: var(--ne_muted)}
.ne-hero__actions {margin-bottom: 40px;gap: 14px;display: flex;flex-wrap: wrap}
.ne-hero__trust {flex-wrap: wrap;display: flex;gap: 20px}
.ne-hero__trust-item {align-items: center;font-size: .82rem;gap: 5px;color: var(--ne_muted);display: flex}
.ne-hero__trust-item::before {font-weight: 700;color: var(--ne_cyan);content: '✓'}

/* Rating glass card */
.ne-rating-card {padding: 28px;box-shadow: var(--ne_glow-p);text-align: center}
.ne-rating-card__score {font-size: 4.5rem;margin-bottom: 4px;font-family: 'Syne', sans-serif;line-height: 1;font-weight: 800}
.ne-rating-card__max {font-size: 1.2rem;color: var(--ne_muted);margin-bottom: 12px}
.ne-rating-card__stars {margin-bottom: 14px;font-size: 1.4rem;color: #fbbf24;letter-spacing: 4px}
.ne-rating-card__label {color: var(--ne_muted);margin-bottom: 20px;font-size: .82rem}
.ne-rating-rows {flex-direction: column;gap: 10px;display: flex;text-align: left}
.ne-rating-row {display: flex;gap: 10px;align-items: center;font-size: .85rem}
.ne-rating-row__name {flex-shrink: 0;color: var(--ne_muted);width: 100px}
.ne-rating-row__bar {border-radius: 3px;height: 5px;background: rgba(255,255,255,.1);flex: 1}
.ne-rating-row__fill {border-radius: 3px;height: 100%;background: linear-gradient(90deg, var(--ne_purple), var(--ne_cyan))}
.ne-rating-row__val {text-align: right;font-size: .82rem;font-weight: 600;color: var(--ne_white);width: 32px}

/* ── Buttons ─────────────────────────────────────────────────── */
.ne-btn {align-items: center;border-radius: 50px;font-family: 'Space Grotesk', sans-serif;cursor: pointer;display: inline-flex;border: none;gap: 8px;padding: 14px 28px;font-weight: 600;font-size: .95rem;text-decoration: none !important;transition: all .2s}
.ne-btn--primary {color: var(--ne_white);background: linear-gradient(135deg, var(--ne_purple) 0%, var(--ne_cyan) 100%);box-shadow: var(--ne_glow-p)}
.ne-btn--primary:hover {opacity: .9;transform: translateY(-2px);box-shadow: 0 8px 30px rgba(168,85,247,.4)}
.ne-btn--ghost {border: 1px solid var(--ne_glass-bd);backdrop-filter: blur(8px);background: var(--ne_glass);color: var(--ne_text)}
.ne-btn--ghost:hover {border-color: var(--ne_purple);color: var(--ne_purple)}
.ne-btn--sm {font-size: .85rem;padding: 9px 20px}
.ne-btn--full {width: 100%;justify-content: center}

/* ── Feature Cards ───────────────────────────────────────────── */
.ne-features { position: relative; }
.ne-features__head {text-align: center;margin-bottom: 48px}
.ne-features__head p {color: var(--ne_muted);margin-top: 10px}
.ne-features__grid {gap: 20px;grid-template-columns: repeat(3, 1fr);display: grid}
.ne-feat-card {padding: 28px 24px;transition: transform .2s, box-shadow .2s}
.ne-feat-card:hover {box-shadow: var(--ne_glow-p);transform: translateY(-4px)}
.ne-feat-card__icon {width: 50px;display: flex;border-radius: var(--ne_r);font-size: 1.6rem;align-items: center;height: 50px;justify-content: center;background: linear-gradient(135deg, rgba(168,85,247,.2), rgba(6,182,212,.2));margin-bottom: 18px}
.ne-feat-card__title {font-weight: 700;color: var(--ne_white);margin-bottom: 10px;font-family: 'Syne', sans-serif;font-size: 1.15rem}
.ne-feat-card__text {font-size: .9rem;line-height: 1.65;color: var(--ne_muted)}

/* ── VIP Tiers ────────────────────────────────────────────────── */
.ne-vip { position: relative; }
.ne-vip__head {margin-bottom: 48px;text-align: center}
.ne-vip__head p {margin-top: 10px;color: var(--ne_muted)}
.ne-vip__grid {grid-template-columns: repeat(3, 1fr);display: grid;gap: 22px;align-items: start}
.ne-vip-card {transition: transform .2s;overflow: hidden;position: relative;padding: 32px 24px}
.ne-vip-card:hover { transform: translateY(-5px); }
.ne-vip-card--featured {border-color: var(--ne_purple) !important;box-shadow: var(--ne_glow-p), 0 0 0 1px var(--ne_purple)}
.ne-vip-card--featured::before {right: 0;padding: 6px;position: absolute;font-size: .65rem;background: linear-gradient(135deg, var(--ne_purple), var(--ne_cyan));content: 'MAIS POPULAR';text-align: center;left: 0;font-weight: 700;top: 0;color: var(--ne_white);letter-spacing: .12em}
.ne-vip-card--featured .ne-vip-card__inner { padding-top: 14px; }
.ne-vip-card__inner {display: flex;flex-direction: column;gap: 12px}
.ne-vip-card__tier {gap: 6px;letter-spacing: .1em;font-size: .75rem;font-weight: 700;align-items: center;text-transform: uppercase;display: inline-flex}
.ne-vip-card--silver .ne-vip-card__tier { color: #94a3b8; }
.ne-vip-card--gold   .ne-vip-card__tier { color: var(--ne_purple); }
.ne-vip-card--black  .ne-vip-card__tier { color: var(--ne_cyan); }
.ne-vip-card__bonus {font-size: 2.2rem;font-family: 'Syne', sans-serif;font-weight: 800;line-height: 1}
.ne-vip-card__bonus-sub {margin-top: 2px;font-size: .82rem;color: var(--ne_muted)}
.ne-vip-card__features {margin: 4px 0;display: flex;gap: 8px;list-style: none;flex-direction: column}
.ne-vip-card__features li {font-size: .88rem;display: flex;gap: 8px;align-items: center;color: var(--ne_muted)}
.ne-vip-card__features li::before {color: var(--ne_cyan);flex-shrink: 0;content: '✓';font-weight: 700}

/* ── FAQ ─────────────────────────────────────────────────────── */
.ne-faq { position: relative; }
.ne-faq__head {margin-bottom: 48px;text-align: center}
.ne-faq__head p {margin-top: 10px;color: var(--ne_muted)}
.ne-faq__list {flex-direction: column;gap: 10px;max-width: 760px;margin: 0 auto;display: flex}
.ne-faq-item {border-radius: var(--ne_r);border: 1px solid var(--ne_glass-bd);background: var(--ne_glass);transition: border-color .2s;overflow: hidden}
.ne-faq-item:focus-within { border-color: var(--ne_purple); }
.ne-faq-item__q {padding: 18px 22px;font-size: .98rem;font-family: 'Space Grotesk', sans-serif;justify-content: space-between;text-align: left;align-items: center;width: 100%;display: flex;font-weight: 600;cursor: pointer;border: none;background: none;gap: 16px;color: var(--ne_white)}
.ne-faq-item__q:hover { color: var(--ne_cyan); }
.ne-faq-item__icon {border: 1px solid var(--ne_glass-bd);align-items: center;border-radius: 50%;display: flex;flex-shrink: 0;height: 24px;color: var(--ne_purple);font-size: .75rem;transition: transform .3s;justify-content: center;width: 24px}
.ne-faq-item[data-open] .ne-faq-item__icon { transform: rotate(180deg); }
.ne-faq-item__a {max-height: 0;transition: max-height .35s ease, padding .35s ease;padding: 0 22px;overflow: hidden}
.ne-faq-item[data-open] .ne-faq-item__a {max-height: 400px;padding: 0 22px 18px}
.ne-faq-item__a p {line-height: 1.7;color: var(--ne_muted);font-size: .9rem}

/* ── Payments ────────────────────────────────────────────────── */
.ne-payments__head {text-align: center;margin-bottom: 40px}
.ne-payments__head p {margin-top: 10px;color: var(--ne_muted)}
.ne-pay-grid {display: grid;gap: 14px;grid-template-columns: repeat(5, 1fr)}
.ne-pay-card {transition: transform .2s, box-shadow .2s;text-align: center;padding: 20px 14px}
.ne-pay-card:hover {transform: translateY(-3px);box-shadow: var(--ne_glow-c)}
.ne-pay-card__icon {font-size: 1.8rem;margin-bottom: 8px}
.ne-pay-card__name {color: var(--ne_text);font-size: .8rem;font-weight: 600}
.ne-pay-card__time {color: var(--ne_muted);margin-top: 4px;font-size: .72rem}

/* ── CTA section ─────────────────────────────────────────────── */
.ne-cta-section {position: relative;text-align: center;padding: 80px 0;overflow: hidden}
.ne-cta-section::before {content: '';background: radial-gradient(ellipse at center, rgba(168,85,247,.18) 0%, transparent 70%);inset: 0;pointer-events: none;position: absolute}
.ne-cta-section__border {margin: 0 auto;max-width: 700px;box-shadow: var(--ne_glow-p);padding: 50px 40px}
.ne-cta-section h2 { margin-bottom: 14px; }
.ne-cta-section p {max-width: 500px;font-size: 1.05rem;color: var(--ne_muted);margin-right: auto;margin-left: auto;margin-bottom: 28px}
.ne-cta-section .ne-btn--primary {padding: 16px 36px;font-size: 1.05rem}

/* ── Footer ─────────────────────────────────────────────────── */
.ne-footer {position: relative;border-top: 1px solid var(--ne_glass-bd);background: rgba(6,6,16,.95);padding: 54px 0 28px}
.ne-footer__grid {margin-bottom: 44px;grid-template-columns: 1.5fr 1fr 1fr 1fr;gap: 40px;display: grid}
.ne-footer__logo {font-size: 1.5rem;font-family: 'Syne', sans-serif;font-weight: 800;margin-bottom: 14px}
.ne-footer__desc {color: var(--ne_muted);line-height: 1.65;font-size: .85rem}
.ne-footer__col h4 {text-transform: uppercase;font-size: .72rem;letter-spacing: .1em;font-weight: 700;margin-bottom: 14px;color: var(--ne_muted)}
.ne-footer__col ul {display: flex;flex-direction: column;gap: 8px;list-style: none}
.ne-footer__col ul a {color: var(--ne_muted);font-size: .88rem;transition: color .2s}
.ne-footer__col ul a:hover {color: var(--ne_white);text-decoration: none}
.ne-footer__bottom {flex-wrap: wrap;justify-content: space-between;display: flex;border-top: 1px solid var(--ne_glass-bd);gap: 12px;padding-top: 22px;align-items: center}
.ne-footer__copy {color: var(--ne_muted);font-size: .8rem}
.ne-footer__warn {color: var(--ne_muted);font-size: .75rem;max-width: 500px;text-align: right}

/* ── Sticky CTA ─────────────────────────────────────────────── */
.sf-sticky-cta {box-shadow: 0 -4px 20px rgba(0,0,0,.5);position: fixed;z-index: 200;background: linear-gradient(135deg, var(--ne_purple-dk) 0%, #0e7490 100%);right: 0;transition: transform .4s cubic-bezier(.22,1,.36,1);transform: translateY(100%);bottom: 0;left: 0}
.sf-sticky-cta.is-visible { transform: translateY(0); }
.sf-sticky-cta__inner {display: flex;max-width: 1160px;padding: 12px 20px;align-items: center;margin: 0 auto;gap: 16px;justify-content: space-between}
.sf-sticky-cta__text {font-size: .92rem;color: var(--ne_white);font-weight: 600}
.sf-sticky-cta__text span { color: var(--ne_cyan-lt); }
.sf-sticky-cta__actions {display: flex;align-items: center;gap: 12px}
.sf-sticky-cta__close {padding: 4px;color: rgba(255,255,255,.7);cursor: pointer;background: none;line-height: 1;border: none;font-size: 1.1rem}
.sf-sticky-cta__close:hover { color: rgb(255,255,255); }

/* ── Legal pages ─────────────────────────────────────────────── */
.ne-page-hero {border-bottom: 1px solid var(--ne_glass-bd);padding: 50px 0 40px}
.ne-page-hero__tag {letter-spacing: .1em;color: var(--ne_purple);text-transform: uppercase;font-weight: 700;margin-bottom: 10px;font-size: .75rem}
.ne-content {max-width: 780px;margin: 0 auto}
.ne-content h2 {font-size: 1.6rem;margin: 36px 0 12px}
.ne-content h3 {font-size: 1.2rem;margin: 28px 0 10px;color: var(--ne_text)}
.ne-content p  {color: var(--ne_muted);margin-bottom: 16px}
.ne-content ul, .ne-content ol { margin: 0 0 16px 22px; }
.ne-content li {font-size: .95rem;margin-bottom: 8px;color: var(--ne_muted)}
.ne-content a  { color: var(--ne_cyan); }

/* ── Login ───────────────────────────────────────────────────── */
.ne-login-wrap {min-height: 80vh;padding: 60px 20px;align-items: center;justify-content: center;display: flex}
.ne-login-card {max-width: 440px;box-shadow: var(--ne_glow-p);width: 100%;padding: 44px 40px}
.ne-login-card h2 {text-align: center;margin-bottom: 8px}
.ne-login-card__sub {color: var(--ne_muted);font-size: .92rem;text-align: center;margin-bottom: 28px}
.ne-form {gap: 16px;display: flex;flex-direction: column}
.ne-form label {color: var(--ne_text);display: block;font-size: .82rem;font-weight: 600;margin-bottom: 6px}
.ne-form input {border-radius: var(--ne_r);background: rgba(255,255,255,.04);font-size: .95rem;font-family: 'Space Grotesk', sans-serif;color: var(--ne_white);transition: border-color .2s;width: 100%;padding: 12px 16px;border: 1px solid var(--ne_glass-bd)}
.ne-form input:focus {border-color: var(--ne_purple);outline: none}
.ne-form__hint {margin-top: 4px;color: var(--ne_muted);font-size: .78rem;text-align: center}

/* ── Mobile ──────────────────────────────────────────────────── */
.ne-nav__mobile { display: none; }
@media (max-width: 900px) {
  .ne-hero__inner { grid-template-columns: 1fr; }
  .ne-rating-card { max-width: 420px; }
  .ne-features__grid { grid-template-columns: repeat(2, 1fr); }
  .ne-vip__grid {max-width: 400px;grid-template-columns: 1fr;margin: 0 auto}
  .ne-pay-grid { grid-template-columns: repeat(3, 1fr); }
  .ne-footer__grid { grid-template-columns: 1fr 1fr; }
  .ne-nav__links { display: none; }
  .ne-nav__cta { display: none; }
  .ne-burger { display: flex; }
  .ne-nav__mobile {padding: 16px 20px;background: var(--ne_bg2);border-top: 1px solid var(--ne_glass-bd);gap: 12px;display: none;flex-direction: column}
  .ne-nav__mobile.is-open { display: flex; }
  .ne-nav__mobile a {color: var(--ne_text);border-bottom: 1px solid var(--ne_glass-bd);font-size: .95rem;padding: 8px 0}
}
@media (max-width: 540px) {
  .ne-features__grid { grid-template-columns: 1fr; }
  .ne-pay-grid { grid-template-columns: repeat(2, 1fr); }
  .ne-footer__grid { grid-template-columns: 1fr; }
  .ne-cta-section__border { padding: 36px 22px; }
  .ne-login-card { padding: 28px 22px; }
}

/* siteforge-footer-overlap-guard: stable mobile footer layout + sticky CTA clearance */
:where(footer,[class*='-footer']){position:relative;overflow:visible;z-index:1}
:where([class*='footer__grid'],[class*='footer__strip'],[class*='footer__bar']){min-width:0}
:where([class*='footer__grid'],[class*='footer__strip'],[class*='footer__bar'])>*{max-width:100%;min-width:0}
:where([class*='footer__brandblock'],[class*='footer__summary'],[class*='footer__meta'],[class*='footer__copy'],[class*='footer__warn'],[class*='linkstack']){overflow-wrap:anywhere;word-break:break-word}
@media(max-width:760px){
  .sf-has-sticky-cta :where([class*='-shell']),.sf-has-sticky-cta main{padding-bottom:calc(140px + env(safe-area-inset-bottom,0px)) !important}
  .sf-has-sticky-cta main~footer,.sf-has-sticky-cta :where(footer,[class$='-footer']){padding-bottom:calc(112px + env(safe-area-inset-bottom,0px)) !important}
  :where([class*='footer__grid'],[class*='footer__strip'],[class*='footer__bar']){display:grid !important;grid-template-columns:1fr !important;align-items:start !important;gap:16px !important}
  :where([class*='footer__summary'],[class*='footer__bottom']){align-items:flex-start;display:flex;flex-direction:column;text-align:left;gap:10px}
  :where([class*='footer__brand']){float:none !important;clear:both;max-height:110px;max-width:110px;margin-bottom:12px}
}
