/* ============================================
   QuantumBlox - Design System
   Single CSS file for the entire site
   Purple/Dark Tech Theme
   ============================================ */

/* Iconos animados (SVG line-md) que reemplazan Font Awesome donde habia
   equivalente. Se dimensionan por font-size del contenedor igual que <i>
   de FA. La clase .qb-aicn mantiene baseline/inline-block.
   max-width/max-height son un GUARDRAIL: aunque el SVG no tenga viewBox o
   width intrinseco, NUNCA se expande mas que el cap (evitaba "bolas
   moradas gigantes" en cards cuando el badge contenia el icono). */
.qb-aicn {
    display: inline-block !important;
    vertical-align: -0.18em;
    width: 1em;
    height: 1em;
    max-width: 24px;
    max-height: 24px;
    line-height: 0;
    flex-shrink: 0;
    object-fit: contain;
}
/* En contextos donde se usaba font-size 0 (boton solo icono) forzamos minimo */
button .qb-aicn, a .qb-aicn {
    min-width: 14px;
    min-height: 14px;
}

/* Lotties inline (usados como iconos pequenos en nav/links). Misma logica
   de cap que .qb-aicn: nunca expanden mas alla del max. */
.qb-lottie-inline {
    display: inline-block;
    vertical-align: -0.32em;
    width: 1.4em;
    height: 1.4em;
    max-width: 28px;
    max-height: 28px;
    line-height: 0;
    flex-shrink: 0;
}


/* ===========================================
   1. CSS VARIABLES
   =========================================== */

:root {
    /* ── iOS 26 Liquid Glass · Purple ── */

    /* Backgrounds: gradiente profundo morado-negro */
    --bg: #0a0612;
    --bg-deep: #060410;
    --bg-surface: rgba(20, 12, 35, 0.75);
    --bg-card: rgba(255, 255, 255, 0.045);
    --bg-card-hover: rgba(255, 255, 255, 0.075);
    --border: rgba(168, 85, 247, 0.22);
    --border-subtle: rgba(255, 255, 255, 0.08);
    --border-glow: rgba(185, 117, 255, 0.45);

    /* Purple palette - iOS 26 vivid */
    --purple: #b975ff;
    --purple-dark: #8b3df0;
    --purple-light: #d4a8ff;
    --purple-dim: rgba(185, 117, 255, 0.14);
    --purple-glow: rgba(185, 117, 255, 0.4);

    /* Accent magenta para CTAs criticos */
    --accent: #d946ef;
    --accent-dark: #b820d4;
    --accent-glow: rgba(217, 70, 239, 0.4);

    /* Focus ring */
    --focus-ring: 0 0 0 3px rgba(185, 117, 255, 0.55);

    /* Status */
    --green: #34d399;
    --green-dim: rgba(52, 211, 153, 0.14);
    --red: #fb7185;
    --red-dim: rgba(251, 113, 133, 0.14);
    --yellow: #fbbf24;
    --yellow-dim: rgba(251, 191, 36, 0.14);
    --blue: #60a5fa;

    /* Text - jerarquia con opacity (iOS) */
    --text: #ffffff;
    --text-secondary: rgba(255, 255, 255, 0.72);
    --text-muted: rgba(255, 255, 255, 0.45);

    /* ── LIQUID GLASS LAYERS ── */
    --glass-1: rgba(255, 255, 255, 0.04);
    --glass-2: rgba(255, 255, 255, 0.07);
    --glass-3: rgba(255, 255, 255, 0.11);
    --glass-purple: rgba(168, 85, 247, 0.08);
    --glass-bg: rgba(255, 255, 255, 0.06);
    --glass-border: rgba(255, 255, 255, 0.14);
    --glass-border-strong: rgba(255, 255, 255, 0.22);
    --glass-blur: blur(40px) saturate(1.8);
    --glass-blur-md: blur(24px) saturate(1.6);
    --glass-blur-sm: blur(12px) saturate(1.4);

    /* Radii continuos (iOS smooth corners) */
    --radius-xs: 8px;
    --radius-sm: 12px;
    --radius-md: 18px;
    --radius-lg: 24px;
    --radius-xl: 32px;
    --radius-2xl: 40px;
    --radius-pill: 999px;

    /* Layout */
    --nav-height: 72px;

    /* Easing - spring suave Apple */
    --ease: cubic-bezier(0.32, 0.72, 0, 1);
    --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
    --spring: cubic-bezier(0.5, 1.4, 0.4, 1);

    /* Sombras Liquid Glass */
    --shadow-glass-sm: 0 1px 2px rgba(0,0,0,0.4), inset 0 1px 0 rgba(255,255,255,0.06);
    --shadow-glass-md: 0 8px 24px rgba(0,0,0,0.45), 0 2px 6px rgba(0,0,0,0.3), inset 0 1px 0 rgba(255,255,255,0.08);
    --shadow-glass-lg: 0 24px 60px rgba(0,0,0,0.55), 0 8px 20px rgba(0,0,0,0.35), inset 0 1px 0 rgba(255,255,255,0.1);
    --shadow-glass-xl: 0 40px 100px rgba(0,0,0,0.65), 0 16px 32px rgba(0,0,0,0.4), inset 0 1px 0 rgba(255,255,255,0.12);
    --shadow-purple-glow: 0 0 40px rgba(185,117,255,0.4), 0 12px 32px rgba(185,117,255,0.18);
}


/* ===========================================
   2. RESET + BASE
   =========================================== */

*,
*::before,
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
}

body {
    font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Display', 'SF Pro Text', 'Inter', 'Segoe UI', Roboto, sans-serif;
    background:
        radial-gradient(1200px 800px at 15% -10%, rgba(168,85,247,0.18) 0%, transparent 55%),
        radial-gradient(900px 700px at 95% 10%, rgba(217,70,239,0.12) 0%, transparent 50%),
        radial-gradient(800px 900px at 50% 110%, rgba(124,58,237,0.18) 0%, transparent 55%),
        var(--bg);
    background-attachment: fixed;
    color: var(--text);
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    min-height: 100vh;
    min-height: 100dvh;
    overflow-x: hidden;
    letter-spacing: -0.011em;
}

a {
    color: inherit;
    text-decoration: none;
}

button {
    cursor: pointer;
    font-family: inherit;
    border: none;
    background: none;
}

input,
select,
textarea {
    font-family: inherit;
    font-size: 16px; /* prevents iOS zoom on focus */
}

img {
    max-width: 100%;
    display: block;
}

ul, ol {
    list-style: none;
}

h1, h2, h3, h4, h5, h6 {
    line-height: 1.2;
    font-weight: 700;
}

/* Scrollbar */
::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}

::-webkit-scrollbar-track {
    background: var(--bg);
}

::-webkit-scrollbar-thumb {
    background: var(--purple-dim);
    border-radius: 3px;
}

::-webkit-scrollbar-thumb:hover {
    background: var(--purple);
}

/* Firefox scrollbar */
* {
    scrollbar-width: thin;
    scrollbar-color: var(--purple-dim) var(--bg);
}

/* Selection */
::selection {
    background: var(--purple);
    color: var(--text);
}

::-moz-selection {
    background: var(--purple);
    color: var(--text);
}


/* ===========================================
   3. NAVIGATION (.site-nav)
   =========================================== */

.site-nav {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: var(--nav-height);
    z-index: 1000;
    backdrop-filter: blur(20px) saturate(1.4);
    -webkit-backdrop-filter: blur(20px) saturate(1.4);
    background: rgba(5, 5, 5, 0.85);
    border-bottom: 1px solid var(--border);
    transition: height 0.3s var(--ease), background 0.3s var(--ease);
}

.site-nav.scrolled {
    height: 56px;
    background: rgba(5, 5, 5, 0.95);
}

/* Nav inner container */
.nav-inner {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 24px;
    height: 100%;
}

/* Brand / Logo */
.nav-brand {
    display: flex;
    align-items: center;
    gap: 10px;
    text-decoration: none;
}

.nav-logo-img {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    object-fit: cover;
}

.nav-brand-text {
    font-size: 17px;
    font-weight: 700;
    letter-spacing: 1.5px;
    color: var(--text);
}

.nav-brand-text .accent {
    color: var(--purple);
}

/* Nav links */
.nav-links {
    display: flex;
    gap: 6px;
    align-items: center;
}

.nav-link {
    padding: 8px 14px;
    font-size: 14px;
    font-weight: 500;
    color: var(--text-secondary);
    border-radius: var(--radius-sm);
    transition: all 0.25s var(--ease);
    display: flex;
    align-items: center;
    gap: 6px;
    white-space: nowrap;
}

.nav-link:hover {
    color: var(--text);
    background: rgba(255, 255, 255, 0.06);
}

.nav-link.active {
    color: var(--purple);
    background: var(--purple-dim);
}

.nav-link i {
    font-size: 13px;
}

/* Nav auth buttons */
.nav-auth {
    display: flex;
    gap: 8px;
    align-items: center;
}

.btn-nav {
    padding: 8px 18px;
    font-size: 13px;
    font-weight: 600;
    border-radius: var(--radius-sm);
    border: none;
    transition: all 0.25s var(--ease);
    cursor: pointer;
    white-space: nowrap;
}

.btn-nav-outline {
    background: transparent;
    border: 1px solid var(--border);
    color: var(--text-secondary);
}

.btn-nav-outline:hover {
    border-color: var(--purple);
    color: var(--purple);
}

.btn-nav-fill {
    background: linear-gradient(135deg, var(--purple), var(--purple-dark));
    color: var(--text);
    border: none;
}

.btn-nav-fill:hover {
    box-shadow: 0 4px 20px var(--purple-glow);
    transform: translateY(-1px);
}

.btn-nav-outline:focus-visible,
.btn-nav-fill:focus-visible {
    outline: none;
    box-shadow: var(--focus-ring);
}

/* Nav user info (logged in state) */
.nav-user-info {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 4px 12px 4px 4px;
    border: 1px solid var(--purple-dim);
    border-radius: 999px;
    background: rgba(168, 85, 247, 0.06);
    text-decoration: none;
    max-width: 200px;
    transition: background 0.2s, border-color 0.2s, transform 0.2s;
}

.nav-user-info:hover {
    background: rgba(168, 85, 247, 0.15);
    border-color: var(--purple);
    transform: translateY(-1px);
}

.nav-user-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 2px solid var(--purple-dim);
    object-fit: cover;
    flex-shrink: 0;
}

.nav-user-name {
    font-size: 14px;
    font-weight: 600;
    color: var(--text);
    max-width: 130px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Hamburger (mobile) */
.hamburger {
    display: none;
    background: none;
    border: none;
    padding: 8px;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
}

.hamburger span {
    width: 22px;
    height: 2px;
    background: rgba(255, 255, 255, 0.8);
    border-radius: 2px;
    transition: all 0.3s var(--ease);
    display: block;
}

.hamburger.active span:nth-child(1) {
    transform: rotate(45deg) translate(5px, 5px);
}

.hamburger.active span:nth-child(2) {
    opacity: 0;
}

.hamburger.active span:nth-child(3) {
    transform: rotate(-45deg) translate(5px, -5px);
}

/* Mobile menu */
.mobile-menu {
    display: none;
    position: fixed;
    top: var(--nav-height);
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(5, 5, 5, 0.95);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    z-index: 999;
    padding: 20px;
    flex-direction: column;
    gap: 4px;
    overflow-y: auto;
}

.mobile-menu.open {
    display: flex;
}

.mobile-link {
    padding: 14px 18px;
    font-size: 16px;
    color: var(--text-secondary);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    gap: 12px;
    transition: all 0.2s var(--ease);
}

.mobile-link:hover,
.mobile-link.active {
    color: var(--text);
    background: var(--purple-dim);
}

.mobile-link i {
    width: 20px;
    text-align: center;
}

.mobile-auth {
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    gap: 8px;
}


/* ===========================================
   4. FOOTER (.site-footer)
   =========================================== */

.site-footer {
    background: var(--bg-surface);
    border-top: 1px solid var(--border);
    padding: 60px 0 0;
}

.footer-inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
    display: grid;
    grid-template-columns: 2fr repeat(4, 1fr);
    gap: 40px;
}

/* Footer brand column */
.footer-brand {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.footer-logo-img {
    width: 40px;
    height: 40px;
    border-radius: 10px;
}

.footer-brand-name {
    font-size: 18px;
    font-weight: 800;
    letter-spacing: 2px;
    color: var(--text);
}

.footer-brand p {
    font-size: 13px;
    color: var(--text-muted);
    line-height: 1.6;
}

/* Discord link in footer */
.footer-discord {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    background: rgba(88, 101, 242, 0.12);
    border: 1px solid rgba(88, 101, 242, 0.25);
    border-radius: var(--radius-sm);
    font-size: 13px;
    font-weight: 600;
    color: #5865F2;
    transition: all 0.25s var(--ease);
    margin-top: 8px;
}

.footer-discord:hover {
    background: rgba(88, 101, 242, 0.2);
}

/* Footer columns */
.footer-col h4 {
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--text-muted);
    margin-bottom: 16px;
}

.footer-col a {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 0;
    font-size: 14px;
    color: var(--text-secondary);
    transition: color 0.2s var(--ease);
}

.footer-col a:hover {
    color: var(--purple);
}

.footer-col a i {
    width: 16px;
    text-align: center;
    font-size: 13px;
}

/* Footer bottom bar */
.footer-bottom {
    max-width: 1200px;
    margin: 40px auto 0;
    padding: 20px 24px;
    border-top: 1px solid var(--border);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 16px;
}

.footer-bottom p {
    font-size: 12px;
    color: var(--text-muted);
}

.footer-payments {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 12px;
    color: var(--text-muted);
}

.payment-logo {
    height: 20px;
    object-fit: contain;
    filter: brightness(0.8);
}


/* ===========================================
   5. GLASS COMPONENTS
   =========================================== */

/* Glass card */
.glass-card {
    background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-xl);
    padding: 32px;
    position: relative;
    overflow: hidden;
    transition: all 0.3s var(--ease);
}

.glass-card:hover {
    border-color: rgba(255, 255, 255, 0.12);
}

/* Glass button */
.glass-btn {
    background: rgba(255, 255, 255, 0.04);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-md);
    padding: 12px 24px;
    color: var(--text-secondary);
    font-size: 14px;
    font-weight: 600;
    transition: all 0.25s var(--ease);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.glass-btn:hover {
    border-color: var(--purple);
    color: var(--purple);
    background: var(--purple-dim);
}

/* Glass badge */
.glass-badge {
    background: var(--purple-dim);
    border: 1px solid rgba(168, 85, 247, 0.2);
    border-radius: 20px;
    padding: 6px 14px;
    font-size: 12px;
    font-weight: 600;
    color: var(--purple);
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

/* Glass stat */
.glass-stat {
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    padding: 24px;
    text-align: center;
    transition: all 0.3s var(--ease);
}

.glass-stat:hover {
    border-color: var(--border-glow);
    transform: translateY(-2px);
}

.glass-stat .stat-value {
    font-size: 28px;
    font-weight: 800;
    color: var(--text);
    margin-bottom: 4px;
}

.glass-stat .stat-label {
    font-size: 13px;
    color: var(--text-muted);
}


/* ===========================================
   6. BUTTONS
   =========================================== */

/* Primary button */
.btn-primary {
    background: linear-gradient(135deg, var(--purple), var(--purple-dark));
    color: var(--text);
    border: none;
    border-radius: var(--radius-md);
    padding: 14px 28px;
    font-size: 15px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.3s var(--ease);
    display: inline-flex;
    align-items: center;
    gap: 8px;
    white-space: nowrap;
}

.btn-primary:hover {
    box-shadow: 0 6px 24px var(--purple-glow);
    transform: translateY(-2px);
}

.btn-primary:active {
    transform: translateY(0) scale(0.98);
}

.btn-primary:focus-visible {
    outline: none;
    box-shadow: 0 6px 24px var(--purple-glow), var(--focus-ring);
}

.btn-primary:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}

/* High-contrast CTA — for critical conversion points (buy, checkout final) */
.btn-cta {
    background: linear-gradient(135deg, var(--accent), var(--accent-dark));
    color: #fff;
    border: none;
    border-radius: var(--radius-md);
    padding: 14px 28px;
    font-size: 15px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.3s var(--ease);
    display: inline-flex;
    align-items: center;
    gap: 8px;
    white-space: nowrap;
    box-shadow: 0 4px 14px var(--accent-glow);
}
.btn-cta:hover {
    box-shadow: 0 8px 28px var(--accent-glow);
    transform: translateY(-2px);
}
.btn-cta:active {
    transform: translateY(0) scale(0.98);
}
.btn-cta:focus-visible {
    outline: none;
    box-shadow: 0 6px 24px var(--accent-glow), 0 0 0 3px rgba(244, 63, 94, 0.45);
}
.btn-cta:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}
.btn-cta.btn-lg { padding: 16px 34px; font-size: 16px; }

/* Outline button */
.btn-outline {
    background: transparent;
    border: 1px solid var(--border);
    color: var(--text-secondary);
    border-radius: var(--radius-md);
    padding: 14px 28px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.25s var(--ease);
    display: inline-flex;
    align-items: center;
    gap: 8px;
    white-space: nowrap;
}

.btn-outline:hover {
    border-color: var(--purple);
    color: var(--purple);
}

.btn-outline:active {
    transform: scale(0.98);
}

.btn-outline:focus-visible {
    outline: none;
    border-color: var(--purple);
    color: var(--purple);
    box-shadow: var(--focus-ring);
}

.btn-outline:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* Button sizes */
.btn-sm {
    padding: 8px 16px;
    font-size: 13px;
}

.btn-lg {
    padding: 16px 32px;
    font-size: 16px;
}

/* Icon-only button */
.btn-icon {
    width: 40px;
    height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-sm);
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    color: var(--text-secondary);
    cursor: pointer;
    transition: all 0.25s var(--ease);
    padding: 0;
}

.btn-icon:hover {
    border-color: var(--purple);
    color: var(--purple);
    background: var(--purple-dim);
}

/* Danger button */
.btn-danger {
    background: linear-gradient(135deg, var(--red), #dc2626);
    color: var(--text);
    border: none;
    border-radius: var(--radius-md);
    padding: 14px 28px;
    font-size: 15px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.3s var(--ease);
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.btn-danger:hover {
    box-shadow: 0 6px 24px var(--red-dim);
    transform: translateY(-2px);
}

/* Success button */
.btn-success {
    background: linear-gradient(135deg, var(--green), #16a34a);
    color: var(--text);
    border: none;
    border-radius: var(--radius-md);
    padding: 14px 28px;
    font-size: 15px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.3s var(--ease);
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.btn-success:hover {
    box-shadow: 0 6px 24px var(--green-dim);
    transform: translateY(-2px);
}

/* Button group */
.btn-group {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}


/* ===========================================
   7. ANIMATIONS + KEYFRAMES
   =========================================== */

/* Reveal on scroll */
.reveal {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.6s var(--ease), transform 0.6s var(--ease);
}

.reveal.visible {
    opacity: 1;
    transform: translateY(0);
}

.reveal-delay-1 { transition-delay: 0.1s; }
.reveal-delay-2 { transition-delay: 0.2s; }
.reveal-delay-3 { transition-delay: 0.3s; }
.reveal-delay-4 { transition-delay: 0.4s; }

/* Keyframes */
@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}

@keyframes glow {
    0%, 100% {
        box-shadow: 0 0 15px var(--purple-glow);
    }
    50% {
        box-shadow: 0 0 30px var(--purple-glow);
    }
}

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

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

@keyframes shimmer {
    0% {
        background-position: -200% 0;
    }
    100% {
        background-position: 200% 0;
    }
}

@keyframes marquee {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-50%);
    }
}

@keyframes slideInRight {
    from {
        transform: translateX(100%);
        opacity: 0;
    }
    to {
        transform: translateX(0);
        opacity: 1;
    }
}

@keyframes scaleIn {
    from {
        transform: scale(0.95);
        opacity: 0;
    }
    to {
        transform: scale(1);
        opacity: 1;
    }
}

@keyframes pulse {
    0%, 100% {
        opacity: 1;
    }
    50% {
        opacity: 0.5;
    }
}

@keyframes slideDown {
    from {
        transform: translateY(-10px);
        opacity: 0;
    }
    to {
        transform: translateY(0);
        opacity: 1;
    }
}

/* Animation utility classes */
.float {
    animation: float 4s ease-in-out infinite;
}

.glow-pulse {
    animation: glow 2s ease-in-out infinite;
}

.shimmer {
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.04), transparent);
    background-size: 200% 100%;
    animation: shimmer 1.5s infinite;
}

.fade-in {
    animation: fadeIn 0.5s var(--ease) forwards;
}

.scale-in {
    animation: scaleIn 0.3s var(--spring) forwards;
}


/* ===========================================
   8. TILT CARD
   =========================================== */

.tilt-card {
    position: relative;
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    padding: 28px 24px;
    transition: transform 0.3s var(--ease), box-shadow 0.3s var(--ease), border-color 0.3s var(--ease);
    transform-style: preserve-3d;
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(0,0,0,0.3);
}

.tilt-card:hover {
    border-color: rgba(168,85,247,0.4);
    box-shadow: 0 12px 40px rgba(168,85,247,0.15);
    transform: translateY(-4px);
}


/* ===========================================
   9. TOAST NOTIFICATIONS
   =========================================== */

.toast-container {
    position: fixed;
    top: 24px;
    right: 24px;
    z-index: 10000;
    display: flex;
    flex-direction: column;
    gap: 10px;
    pointer-events: none;
}

.toast {
    background: rgba(17, 17, 22, 0.95);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: 14px 20px;
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 300px;
    font-size: 14px;
    color: var(--text);
    animation: slideInRight 0.4s var(--spring);
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.4);
    pointer-events: auto;
}

.toast.success {
    border-left: 3px solid var(--green);
}

.toast.success i {
    color: var(--green);
}

.toast.error {
    border-left: 3px solid var(--red);
}

.toast.error i {
    color: var(--red);
}

.toast.info {
    border-left: 3px solid var(--blue);
}

.toast.info i {
    color: var(--blue);
}

.toast.warning {
    border-left: 3px solid var(--yellow);
}

.toast.warning i {
    color: var(--yellow);
}

.toast-close {
    margin-left: auto;
    background: none;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    padding: 4px;
    font-size: 14px;
    transition: color 0.2s;
}

.toast-close:hover {
    color: var(--text);
}


/* ===========================================
   10. MODAL
   =========================================== */

.modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    z-index: 9999;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
}

.modal-overlay.open {
    display: flex;
}

.modal-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-xl);
    padding: 40px;
    max-width: 500px;
    width: 90%;
    animation: scaleIn 0.3s var(--spring);
    position: relative;
    max-height: 90vh;
    overflow-y: auto;
}

.modal-close {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-sm);
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    color: var(--text-muted);
    cursor: pointer;
    transition: all 0.2s;
    font-size: 16px;
}

.modal-close:hover {
    color: var(--text);
    border-color: var(--border);
}

.modal-title {
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 8px;
}

.modal-desc {
    font-size: 14px;
    color: var(--text-secondary);
    margin-bottom: 24px;
    line-height: 1.6;
}

.modal-actions {
    display: flex;
    gap: 12px;
    justify-content: flex-end;
    margin-top: 24px;
}


/* ===========================================
   11. FORMS
   =========================================== */

.form-group {
    margin-bottom: 20px;
}

.form-label {
    display: block;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--text-muted);
    margin-bottom: 8px;
}

.form-input,
.form-select {
    width: 100%;
    padding: 12px 16px;
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-md);
    color: var(--text);
    font-size: 16px;
    outline: none;
    transition: all 0.25s var(--ease);
}

.form-input:focus,
.form-select:focus {
    border-color: var(--purple);
    box-shadow: 0 0 0 3px var(--purple-dim);
}

.form-input::placeholder {
    color: var(--text-muted);
}

.form-select {
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2371717a' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 36px;
}

.form-select option {
    background: var(--bg-card);
    color: var(--text);
}

textarea.form-input {
    resize: vertical;
    min-height: 100px;
}

.form-hint {
    font-size: 12px;
    color: var(--text-muted);
    margin-top: 6px;
}

.form-error {
    font-size: 12px;
    color: var(--red);
    margin-top: 6px;
}

.form-input.error,
.form-select.error {
    border-color: var(--red);
    box-shadow: 0 0 0 3px var(--red-dim);
}

.form-input.success,
.form-select.success {
    border-color: var(--green);
    box-shadow: 0 0 0 3px var(--green-dim);
}

/* Checkbox and radio */
.form-check {
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    font-size: 14px;
    color: var(--text-secondary);
}

.form-check input[type="checkbox"],
.form-check input[type="radio"] {
    width: 18px;
    height: 18px;
    accent-color: var(--purple);
    cursor: pointer;
}

/* Search input */
.form-search {
    position: relative;
}

.form-search .form-input {
    padding-left: 40px;
}

.form-search i {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--text-muted);
    font-size: 14px;
    pointer-events: none;
}


/* ===========================================
   12. TABLES
   =========================================== */

.table-wrap {
    overflow-x: auto;
    border-radius: var(--radius-lg);
    border: 1px solid var(--border);
}

table {
    width: 100%;
    border-collapse: collapse;
}

th {
    text-align: left;
    padding: 12px 16px;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--text-muted);
    border-bottom: 1px solid var(--border);
    white-space: nowrap;
    background: var(--bg-surface);
}

td {
    padding: 12px 16px;
    font-size: 14px;
    border-bottom: 1px solid var(--border-subtle);
    color: var(--text-secondary);
}

tr:last-child td {
    border-bottom: none;
}

tr:hover td {
    background: rgba(168, 85, 247, 0.03);
}

td.text-right,
th.text-right {
    text-align: right;
}


/* ===========================================
   13. BADGES
   =========================================== */

.badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
    white-space: nowrap;
}

.badge-green {
    background: var(--green-dim);
    color: var(--green);
}

.badge-red {
    background: var(--red-dim);
    color: var(--red);
}

.badge-yellow {
    background: var(--yellow-dim);
    color: var(--yellow);
}

.badge-purple {
    background: var(--purple-dim);
    color: var(--purple);
}

.badge-blue {
    background: rgba(59, 130, 246, 0.12);
    color: var(--blue);
}

.badge-outline {
    background: transparent;
    border: 1px solid var(--border);
    color: var(--text-secondary);
}


/* ===========================================
   14. TABS
   =========================================== */

.tabs {
    display: flex;
    gap: 4px;
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-md);
    padding: 4px;
    overflow-x: auto;
}

.tab {
    padding: 10px 20px;
    font-size: 14px;
    font-weight: 600;
    color: var(--text-secondary);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all 0.25s var(--ease);
    border: none;
    background: none;
    white-space: nowrap;
}

.tab.active {
    color: var(--text);
    background: var(--purple);
    box-shadow: 0 2px 12px var(--purple-glow);
}

.tab:hover:not(.active) {
    color: var(--text);
    background: rgba(255, 255, 255, 0.06);
}

.tab-content {
    display: none;
}

.tab-content.active {
    display: block;
    animation: fadeIn 0.3s var(--ease);
}


/* ===========================================
   15. STAR RATING
   =========================================== */

.stars {
    display: flex;
    gap: 4px;
}

.star {
    font-size: 24px;
    color: var(--text-muted);
    cursor: pointer;
    transition: color 0.2s var(--ease), transform 0.2s var(--ease);
}

.star.active,
.star:hover {
    color: #fbbf24;
}

.star:hover {
    transform: scale(1.15);
}


/* ===========================================
   16. CURRENCY BUTTONS
   =========================================== */

.currency-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-sm);
    font-size: 13px;
    font-weight: 500;
    color: var(--text-secondary);
    cursor: pointer;
    transition: all 0.25s var(--ease);
}

.currency-btn:hover {
    border-color: var(--border);
    color: var(--text);
}

.currency-btn.active {
    border-color: var(--purple);
    color: var(--purple);
    background: var(--purple-dim);
}

.currency-btn img {
    width: 20px;
    height: 14px;
    border-radius: 2px;
    object-fit: cover;
}

.currency-selector {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}


/* ===========================================
   17. SECTION / CONTAINER / HERO
   =========================================== */

/* Container */
.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
}

/* Section headings */
.section-title {
    font-size: 28px;
    font-weight: 800;
    margin-bottom: 12px;
    color: var(--text);
}

.section-subtitle {
    font-size: 16px;
    color: var(--text-secondary);
    margin-bottom: 40px;
    line-height: 1.6;
}

.section-badge {
    /* Reuses .glass-badge styling */
    background: var(--purple-dim);
    border: 1px solid rgba(168, 85, 247, 0.2);
    border-radius: 20px;
    padding: 6px 14px;
    font-size: 12px;
    font-weight: 600;
    color: var(--purple);
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 16px;
}

.section-header {
    text-align: center;
    margin-bottom: 48px;
}

/* Hero */
/* Hero landing (home.html) — solo aplica cuando tiene .hero-content adentro.
   Otras paginas con .hero simple (comprar, grupo, etc.) NO se ven afectadas. */
.hero:has(.hero-content) {
    min-height: calc(100vh - var(--nav-height));
    padding-top: var(--nav-height);
    display: flex;
    align-items: center;
    position: relative;
    overflow: hidden;
}

.hero-content {
    max-width: 1200px;
    margin: 0 auto;
    padding: 80px 24px;
    position: relative;
    z-index: 2;
}

.hero-title {
    font-size: 48px;
    font-weight: 900;
    line-height: 1.1;
    margin-bottom: 20px;
}

.hero-subtitle {
    font-size: 18px;
    color: var(--text-secondary);
    line-height: 1.6;
    margin-bottom: 32px;
    max-width: 600px;
}

.hero-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.hero-bg {
    position: absolute;
    inset: 0;
    z-index: 1;
    overflow: hidden;
}

/* Main content offset for fixed nav */
.main-content {
    padding-top: var(--nav-height);
    min-height: calc(100vh - var(--nav-height));
}

/* Page section spacing */
.page-section {
    padding: 80px 0;
}


/* ===========================================
   18. PACKAGE CARD
   =========================================== */

.pkg-card {
    background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-xl);
    padding: 32px;
    position: relative;
    overflow: hidden;
    cursor: pointer;
    transition: all 0.3s var(--ease);
}

.pkg-card:hover {
    border-color: var(--border-glow);
    transform: translateY(-4px);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.3);
}

.pkg-badge {
    position: absolute;
    top: -1px;
    right: 16px;
    background: var(--purple);
    color: var(--text);
    font-size: 10px;
    font-weight: 700;
    padding: 4px 10px;
    border-radius: 0 0 8px 8px;
    letter-spacing: 0.5px;
    text-transform: uppercase;
}

.pkg-card .pkg-icon {
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--purple-dim);
    border-radius: var(--radius-md);
    margin-bottom: 16px;
    font-size: 24px;
    color: var(--purple);
}

.pkg-card .pkg-name {
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 4px;
}

.pkg-card .pkg-amount {
    font-size: 14px;
    color: var(--text-secondary);
    margin-bottom: 16px;
}

.pkg-card .pkg-price {
    font-size: 28px;
    font-weight: 800;
    color: var(--purple);
}

.pkg-card .pkg-price-sub {
    font-size: 13px;
    color: var(--text-muted);
}

/* Package grid */
.pkg-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 20px;
}


/* ===========================================
   19. LOADING SKELETON
   =========================================== */

.skeleton {
    background: linear-gradient(90deg, var(--bg-card), rgba(255, 255, 255, 0.06), var(--bg-card));
    background-size: 200% 100%;
    animation: shimmer 1.5s infinite;
    border-radius: var(--radius-sm);
}

.skeleton-text {
    height: 14px;
    margin-bottom: 8px;
    border-radius: 4px;
}

.skeleton-text.short {
    width: 60%;
}

.skeleton-title {
    height: 24px;
    margin-bottom: 12px;
    width: 80%;
    border-radius: 4px;
}

.skeleton-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
}

.skeleton-card {
    height: 200px;
    border-radius: var(--radius-lg);
}

/* Spinner */
.spinner {
    width: 24px;
    height: 24px;
    border: 2px solid var(--border);
    border-top-color: var(--purple);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

.spinner-lg {
    width: 40px;
    height: 40px;
    border-width: 3px;
}

.loading-overlay {
    position: absolute;
    inset: 0;
    background: rgba(5, 5, 5, 0.7);
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: inherit;
    z-index: 10;
}


/* ===========================================
   20. TOOLTIP
   =========================================== */

.tooltip {
    position: relative;
}

.tooltip::after {
    content: attr(data-tooltip);
    position: absolute;
    bottom: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%) translateY(4px);
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 6px 12px;
    font-size: 12px;
    color: var(--text-secondary);
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s, transform 0.2s;
    z-index: 100;
}

.tooltip:hover::after {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}


/* ===========================================
   21. PROGRESS BAR
   =========================================== */

.progress-bar {
    width: 100%;
    height: 6px;
    background: var(--glass-bg);
    border-radius: 3px;
    overflow: hidden;
}

.progress-bar .progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--purple), var(--purple-light));
    border-radius: 3px;
    transition: width 0.5s var(--ease);
}

.progress-bar.success .progress-fill {
    background: linear-gradient(90deg, var(--green), #34d399);
}


/* ===========================================
   22. DIVIDERS
   =========================================== */

.divider {
    height: 1px;
    background: var(--border);
    margin: 24px 0;
}

.divider-text {
    display: flex;
    align-items: center;
    gap: 16px;
    color: var(--text-muted);
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.divider-text::before,
.divider-text::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--border);
}


/* ===========================================
   23. DROPDOWN
   =========================================== */

.dropdown {
    position: relative;
    display: inline-block;
}

.dropdown-menu {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    min-width: 200px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: 6px;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-4px);
    transition: all 0.2s var(--ease);
    z-index: 100;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4);
}

.dropdown.open .dropdown-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.dropdown-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    font-size: 14px;
    color: var(--text-secondary);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all 0.15s;
    border: none;
    background: none;
    width: 100%;
}

.dropdown-item:hover {
    color: var(--text);
    background: var(--purple-dim);
}

.dropdown-item i {
    width: 16px;
    text-align: center;
    font-size: 13px;
}

.dropdown-divider {
    height: 1px;
    background: var(--border);
    margin: 4px 0;
}


/* ===========================================
   24. ALERT / NOTICE
   =========================================== */

.alert {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 16px 20px;
    border-radius: var(--radius-md);
    font-size: 14px;
    line-height: 1.5;
}

.alert-info {
    background: rgba(59, 130, 246, 0.08);
    border: 1px solid rgba(59, 130, 246, 0.2);
    color: var(--blue);
}

.alert-success {
    background: var(--green-dim);
    border: 1px solid rgba(34, 197, 94, 0.2);
    color: var(--green);
}

.alert-warning {
    background: var(--yellow-dim);
    border: 1px solid rgba(245, 158, 11, 0.2);
    color: var(--yellow);
}

.alert-error {
    background: var(--red-dim);
    border: 1px solid rgba(239, 68, 68, 0.2);
    color: var(--red);
}

.alert i {
    font-size: 16px;
    margin-top: 2px;
}


/* ===========================================
   25. AVATAR
   =========================================== */

.avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--border);
}

.avatar-sm {
    width: 28px;
    height: 28px;
}

.avatar-lg {
    width: 56px;
    height: 56px;
}

.avatar-xl {
    width: 80px;
    height: 80px;
}

.avatar-group {
    display: flex;
}

.avatar-group .avatar {
    margin-left: -8px;
    border: 2px solid var(--bg);
}

.avatar-group .avatar:first-child {
    margin-left: 0;
}


/* ===========================================
   26. TOGGLE SWITCH
   =========================================== */

.toggle {
    position: relative;
    width: 44px;
    height: 24px;
    display: inline-block;
}

.toggle input {
    opacity: 0;
    width: 0;
    height: 0;
}

.toggle-slider {
    position: absolute;
    inset: 0;
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: 12px;
    cursor: pointer;
    transition: all 0.3s var(--ease);
}

.toggle-slider::after {
    content: '';
    position: absolute;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: var(--text-secondary);
    top: 2px;
    left: 2px;
    transition: all 0.3s var(--ease);
}

.toggle input:checked + .toggle-slider {
    background: var(--purple-dim);
    border-color: var(--purple);
}

.toggle input:checked + .toggle-slider::after {
    background: var(--purple);
    transform: translateX(20px);
}


/* ===========================================
   27. TAG / CHIP
   =========================================== */

.tag {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 12px;
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: 20px;
    font-size: 12px;
    font-weight: 500;
    color: var(--text-secondary);
}

.tag-remove {
    background: none;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    padding: 0;
    font-size: 14px;
    line-height: 1;
    transition: color 0.2s;
}

.tag-remove:hover {
    color: var(--red);
}

.tag-purple {
    background: var(--purple-dim);
    border-color: rgba(168, 85, 247, 0.2);
    color: var(--purple);
}


/* ===========================================
   28. ACCORDION
   =========================================== */

.accordion-item {
    border-bottom: 1px solid var(--border);
}

.accordion-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 0;
    cursor: pointer;
    font-size: 15px;
    font-weight: 600;
    color: var(--text);
    transition: color 0.2s;
    background: none;
    border: none;
    width: 100%;
    text-align: left;
}

.accordion-header:hover {
    color: var(--purple);
}

.accordion-icon {
    font-size: 12px;
    color: var(--text-muted);
    transition: transform 0.3s var(--ease);
}

.accordion-item.open .accordion-icon {
    transform: rotate(180deg);
}

.accordion-body {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s var(--ease);
}

.accordion-body-inner {
    padding: 0 0 16px;
    font-size: 14px;
    color: var(--text-secondary);
    line-height: 1.7;
}


/* ===========================================
   29. EMPTY STATE
   =========================================== */

.empty-state {
    text-align: center;
    padding: 60px 24px;
}

.empty-state-icon {
    font-size: 48px;
    color: var(--text-muted);
    margin-bottom: 16px;
    opacity: 0.5;
}

.empty-state-title {
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 8px;
}

.empty-state-desc {
    font-size: 14px;
    color: var(--text-muted);
    margin-bottom: 24px;
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
}


/* ===========================================
   30. MARQUEE (Scrolling Banner)
   =========================================== */

.marquee {
    overflow: hidden;
    white-space: nowrap;
}

.marquee-inner {
    display: inline-flex;
    animation: marquee 30s linear infinite;
}

.marquee-item {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 0 24px;
    font-size: 14px;
    color: var(--text-secondary);
}

.marquee:hover .marquee-inner {
    animation-play-state: paused;
}


/* ===========================================
   31. COUNTDOWN TIMER
   =========================================== */

.countdown {
    display: flex;
    gap: 12px;
}

.countdown-unit {
    text-align: center;
}

.countdown-value {
    font-size: 28px;
    font-weight: 800;
    color: var(--text);
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-md);
    padding: 12px 16px;
    min-width: 56px;
    display: block;
}

.countdown-label {
    font-size: 11px;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-top: 6px;
}


/* ===========================================
   32. STEP INDICATOR
   =========================================== */

.steps {
    display: flex;
    align-items: center;
    gap: 0;
}

.step {
    display: flex;
    align-items: center;
    gap: 8px;
}

.step-number {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 13px;
    font-weight: 700;
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    color: var(--text-muted);
    flex-shrink: 0;
}

.step-label {
    font-size: 13px;
    color: var(--text-muted);
    white-space: nowrap;
}

.step-line {
    flex: 1;
    height: 1px;
    background: var(--border);
    margin: 0 12px;
    min-width: 24px;
}

.step.active .step-number {
    background: var(--purple);
    border-color: var(--purple);
    color: var(--text);
}

.step.active .step-label {
    color: var(--text);
}

.step.completed .step-number {
    background: var(--green-dim);
    border-color: var(--green);
    color: var(--green);
}

.step-line.completed {
    background: var(--green);
}


/* ===========================================
   33. PRICING TABLE
   =========================================== */

.pricing-card {
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-xl);
    padding: 32px;
    text-align: center;
    transition: all 0.3s var(--ease);
    position: relative;
}

.pricing-card:hover {
    border-color: var(--border-glow);
    transform: translateY(-4px);
}

.pricing-card.featured {
    border-color: var(--purple);
    box-shadow: 0 0 40px var(--purple-glow);
}

.pricing-card.featured::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg, var(--purple), var(--purple-light));
}

.pricing-name {
    font-size: 16px;
    font-weight: 600;
    color: var(--text-secondary);
    margin-bottom: 8px;
}

.pricing-price {
    font-size: 40px;
    font-weight: 900;
    color: var(--text);
    margin-bottom: 4px;
}

.pricing-price span {
    font-size: 16px;
    font-weight: 500;
    color: var(--text-muted);
}

.pricing-features {
    margin: 24px 0;
    text-align: left;
}

.pricing-feature {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 0;
    font-size: 14px;
    color: var(--text-secondary);
}

.pricing-feature i {
    color: var(--green);
    font-size: 13px;
    width: 16px;
    text-align: center;
}

.pricing-feature.disabled {
    color: var(--text-muted);
    opacity: 0.5;
}

.pricing-feature.disabled i {
    color: var(--text-muted);
}


/* ===========================================
   34. CARD VARIANTS
   =========================================== */

/* Solid card */
.card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 24px;
    transition: all 0.3s var(--ease);
}

.card:hover {
    border-color: var(--border-glow);
}

/* Clickable card */
.card-link {
    display: block;
    cursor: pointer;
}

.card-link:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
}

/* Card header */
.card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
}

.card-title {
    font-size: 16px;
    font-weight: 700;
}

/* Card body padding */
.card-body {
    font-size: 14px;
    color: var(--text-secondary);
    line-height: 1.6;
}

/* Card footer */
.card-footer {
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid var(--border-subtle);
    display: flex;
    align-items: center;
    justify-content: space-between;
}


/* ===========================================
   35. NOTIFICATION DOT
   =========================================== */

.notification-dot {
    position: relative;
}

.notification-dot::after {
    content: '';
    position: absolute;
    top: -2px;
    right: -2px;
    width: 8px;
    height: 8px;
    background: var(--red);
    border-radius: 50%;
    border: 2px solid var(--bg);
}

.notification-count {
    position: absolute;
    top: -6px;
    right: -6px;
    min-width: 18px;
    height: 18px;
    background: var(--red);
    border-radius: 9px;
    font-size: 10px;
    font-weight: 700;
    color: var(--text);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 4px;
    border: 2px solid var(--bg);
}


/* ===========================================
   36. SCROLLBAR TRACK (for custom scrollable areas)
   =========================================== */

.custom-scroll {
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: var(--purple-dim) transparent;
}

.custom-scroll::-webkit-scrollbar {
    width: 4px;
}

.custom-scroll::-webkit-scrollbar-track {
    background: transparent;
}

.custom-scroll::-webkit-scrollbar-thumb {
    background: var(--purple-dim);
    border-radius: 2px;
}


/* ===========================================
   37. CODE BLOCK
   =========================================== */

.code-block {
    background: var(--bg-surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: 16px 20px;
    font-family: 'JetBrains Mono', 'Fira Code', monospace;
    font-size: 13px;
    color: var(--text-secondary);
    overflow-x: auto;
    line-height: 1.7;
}

code {
    font-family: 'JetBrains Mono', 'Fira Code', monospace;
    font-size: 13px;
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: 4px;
    padding: 2px 6px;
    color: var(--purple-light);
}


/* ===========================================
   38. RESPONSIVE
   =========================================== */

@media (max-width: 1024px) {
    .nav-links {
        gap: 2px;
    }

    .nav-link {
        font-size: 13px;
        padding: 6px 10px;
    }

    .footer-inner {
        grid-template-columns: 1fr 1fr;
        gap: 32px;
    }

    .hero-title {
        font-size: 36px;
    }

    .pkg-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .grid-3 {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .nav-links {
        display: none;
    }

    .nav-auth {
        display: none;
    }

    .hamburger {
        display: flex;
    }

    .footer-inner {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .footer-bottom {
        flex-direction: column;
        text-align: center;
    }

    .hero {
        min-height: auto;
    }

    .hero-content {
        padding: 40px 20px;
    }

    .hero-title {
        font-size: 28px;
    }

    .hero-subtitle {
        font-size: 16px;
    }

    .section-title {
        font-size: 22px;
    }

    .glass-card {
        padding: 24px;
    }

    .pkg-grid {
        grid-template-columns: 1fr;
    }

    .grid-2,
    .grid-3 {
        grid-template-columns: 1fr;
    }

    .modal-card {
        padding: 28px;
    }

    .page-section {
        padding: 48px 0;
    }

    .steps {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }

    .step-line {
        display: none;
    }

    .countdown-value {
        font-size: 22px;
        padding: 8px 12px;
        min-width: 44px;
    }

    .pricing-card {
        padding: 24px;
    }

    .tabs {
        overflow-x: auto;
    }
}

@media (max-width: 480px) {
    .nav-brand-text {
        font-size: 14px;
    }

    .nav-logo-img {
        width: 30px;
        height: 30px;
    }

    .container {
        padding: 0 16px;
    }

    .glass-card {
        padding: 20px;
        border-radius: var(--radius-lg);
    }

    .btn-primary,
    .btn-outline {
        padding: 12px 20px;
        font-size: 14px;
        width: 100%;
        justify-content: center;
    }

    .btn-group {
        flex-direction: column;
    }

    .section-title {
        font-size: 20px;
    }

    .section-subtitle {
        font-size: 14px;
    }

    .toast {
        min-width: auto;
        margin: 0 16px;
    }

    .toast-container {
        right: 0;
        left: 0;
    }

    .hero-title {
        font-size: 24px;
    }

    .hero-actions {
        flex-direction: column;
    }

    .modal-card {
        padding: 20px;
        width: 95%;
    }

    .countdown {
        gap: 8px;
    }

    .alert {
        padding: 12px 16px;
        font-size: 13px;
    }

    table {
        font-size: 13px;
    }

    th, td {
        padding: 10px 12px;
    }
}

/* ── Extra-narrow phones (≤420px) ── */
@media (max-width: 420px) {
    :root {
        --nav-height: 60px;
    }

    .container {
        padding: 0 12px;
    }

    .nav-brand-text {
        font-size: 13px;
    }

    .nav-logo-img {
        width: 26px;
        height: 26px;
    }

    .nav-user-info {
        max-width: 150px;
        padding: 3px 10px 3px 3px;
    }

    .nav-user-name {
        max-width: 90px;
        font-size: 12px;
    }

    .hero-title {
        font-size: 20px;
        line-height: 1.25;
    }

    .hero-subtitle,
    .hero-description {
        font-size: 13px;
    }

    .hero {
        padding: 40px 0 28px;
    }

    .section-title {
        font-size: 18px;
    }

    .section-subtitle {
        font-size: 13px;
    }

    .glass-card {
        padding: 16px;
        border-radius: var(--radius-md);
    }

    .btn-primary,
    .btn-outline {
        padding: 11px 16px;
        font-size: 13px;
    }

    .tab-btn {
        padding: 8px 12px;
        font-size: 13px;
    }

    /* Paquetes: una sola columna a <420 */
    .packages-grid,
    .package-grid,
    .pkg-grid {
        grid-template-columns: 1fr !important;
        gap: 12px;
    }

    /* Stats apilados */
    .stats-grid,
    .stat-grid,
    .profile-stats {
        grid-template-columns: 1fr !important;
        gap: 10px;
    }

    .modal-card {
        padding: 16px;
        width: 96%;
        max-height: 92vh;
    }

    .modal-header h2,
    .modal-header h3 {
        font-size: 17px;
    }

    table {
        font-size: 12px;
    }

    th, td {
        padding: 8px 10px;
    }

    .toast {
        font-size: 13px;
        padding: 10px 14px;
    }
}

/* ================================================================
   ACETERNITY TOOL CARDS
   Iconos de autenticacion y metodos de pago
   ================================================================ */
.qb-tool-card {
    width: min(680px, 100%);
    margin: 0 auto;
    padding: 26px;
    border: 1px solid rgba(255,255,255,.11);
    border-radius: 24px;
    background:
        linear-gradient(145deg, rgba(35,29,43,.7), rgba(15,13,21,.82)),
        rgba(40,40,40,.7);
    box-shadow:
        inset 2px 4px 16px rgba(248,248,248,.055),
        0 22px 60px rgba(0,0,0,.3);
    overflow: hidden;
}
.qb-payment-tools-grid { grid-template-columns: 1fr !important; }
.qb-tool-visual {
    position: relative;
    min-height: 230px;
    display: grid;
    place-items: center;
    overflow: hidden;
    border-radius: 19px;
    background:
        radial-gradient(circle at 50% 48%, rgba(168,85,247,.16), transparent 26%),
        radial-gradient(circle at 50% 50%, rgba(255,255,255,.07), transparent 56%);
    -webkit-mask-image: radial-gradient(64% 68% at 50% 50%, #fff 0%, transparent 100%);
    mask-image: radial-gradient(64% 68% at 50% 50%, #fff 0%, transparent 100%);
}
.qb-auth-tool-visual {
    min-height: 132px;
    margin: -2px 0 14px;
    -webkit-mask-image: radial-gradient(72% 78% at 50% 50%, #fff 0%, transparent 100%);
    mask-image: radial-gradient(72% 78% at 50% 50%, #fff 0%, transparent 100%);
}
.qb-tool-icons {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
}
.qb-tool-circle {
    width: 66px;
    height: 66px;
    flex: 0 0 auto;
    display: grid;
    place-items: center;
    padding: 12px;
    border: 1px solid rgba(255,255,255,.1);
    border-radius: 50%;
    background: rgba(248,248,248,.025);
    box-shadow:
        inset 0 0 9px rgba(248,248,248,.2),
        0 28px 25px -17px rgba(0,0,0,.5),
        0 0 24px rgba(168,85,247,.07);
    animation: qbToolCircleSequence 5.4s cubic-bezier(.22,1,.36,1) infinite;
    will-change: transform, box-shadow;
}
.qb-tool-circle-xs { width: 42px; height: 42px; padding: 8px; }
.qb-tool-circle-sm { width: 48px; height: 48px; padding: 9px; }
.qb-tool-circle-md { width: 56px; height: 56px; padding: 10px; }
.qb-tool-circle-main {
    width: 74px;
    height: 74px;
    padding: 13px;
    border-color: rgba(192,132,252,.24);
    background: rgba(168,85,247,.08);
}
.qb-auth-tool-visual .qb-tool-circle-main {
    width: 64px;
    height: 64px;
    cursor: pointer;
    user-select: none;
}
.qb-tool-circle img,
.qb-tool-circle svg {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: contain;
}
.qb-tool-circle img[alt="Mercado Pago"],
.qb-tool-circle img[alt="Wompi"],
.qb-pay-logo-circle img[alt="Mercado Pago"],
.qb-pay-logo-circle img[alt="Wompi"] {
    transform: scale(1.34);
}
.qb-discord-circle {
    color: #fff;
    background: linear-gradient(145deg, rgba(88,101,242,.35), rgba(71,82,196,.18));
}
.qb-discord-circle i { font-size: 25px; }
.qb-tool-step-1 { animation-delay: 0s; }
.qb-tool-step-2 { animation-delay: .65s; }
.qb-tool-step-3 { animation-delay: 1.3s; }
.qb-tool-step-4 { animation-delay: 1.95s; }
.qb-tool-step-5 { animation-delay: 2.6s; }
@keyframes qbToolCircleSequence {
    0%, 11%, 100% { transform: translateY(0) scale(1); }
    5.5% {
        transform: translateY(-8px) scale(1.1);
        box-shadow:
            inset 0 0 12px rgba(255,255,255,.28),
            0 30px 30px -16px rgba(0,0,0,.58),
            0 0 28px rgba(168,85,247,.2);
    }
}
.qb-tool-beam {
    position: absolute;
    z-index: 1;
    top: 48%;
    left: 50%;
    width: 1px;
    height: 150px;
    transform: translate(-50%, -18%);
    background: linear-gradient(to bottom, transparent, #a855f7 42%, #22d3ee 70%, transparent);
    animation: qbToolBeamMove 3.6s ease-in-out infinite;
}
@keyframes qbToolBeamMove {
    0%, 100% { opacity: .25; transform: translate(-50%, -30%); }
    50% { opacity: .9; transform: translate(-50%, -5%); }
}
.qb-tool-beam span {
    position: absolute;
    width: 3px;
    height: 3px;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 0 8px #a855f7;
    animation: qbToolSparkle 3.8s linear infinite;
}
.qb-tool-beam span:nth-child(1) { left:-15px; top:14%; animation-delay:0s; }
.qb-tool-beam span:nth-child(2) { left:9px; top:31%; animation-delay:.7s; }
.qb-tool-beam span:nth-child(3) { left:-7px; top:52%; animation-delay:1.4s; }
.qb-tool-beam span:nth-child(4) { left:14px; top:69%; animation-delay:2.1s; }
.qb-tool-beam span:nth-child(5) { left:-12px; top:84%; animation-delay:2.8s; }
@keyframes qbToolSparkle {
    0%, 100% { opacity:0; transform:scale(.2) translateY(0); }
    35% { opacity:1; transform:scale(1.25) translateY(-5px); }
    72% { opacity:.25; transform:scale(.5) translateY(-16px); }
}
.qb-tool-title {
    margin: 18px 0 7px;
    color: #fff;
    font-size: 1.18rem;
    font-weight: 800;
    letter-spacing: -.02em;
}
.qb-tool-description {
    max-width: 560px;
    margin: 0 auto;
    color: rgba(231,225,242,.62);
    font-size: .86rem;
    line-height: 1.6;
}
.qb-payment-tool-card { text-align: center; }

.btn-pay-method {
    justify-content: flex-start !important;
    padding: 12px 16px !important;
    border-radius: 18px !important;
    background:
        linear-gradient(145deg, rgba(255,255,255,.065), rgba(255,255,255,.025)) !important;
}
.btn-pay-method > span:last-child {
    display: flex;
    align-items: baseline;
    gap: 7px;
    text-align: left;
}
.btn-pay-method small {
    color: rgba(255,255,255,.58);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .04em;
}
.qb-pay-logo-circle {
    width: 46px;
    height: 46px;
    flex: 0 0 46px;
    display: grid;
    place-items: center;
    padding: 8px;
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 50%;
    background: rgba(248,248,248,.035);
    box-shadow: inset 0 0 8px rgba(255,255,255,.15), 0 12px 20px rgba(0,0,0,.22);
    transition: transform 220ms cubic-bezier(.22,1,.36,1), box-shadow 220ms ease;
}
.qb-pay-logo-circle img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
}
.btn-pay-method:hover:not(:disabled) .qb-pay-logo-circle {
    transform: translateY(-3px) scale(1.1);
    box-shadow: inset 0 0 10px rgba(255,255,255,.22), 0 15px 24px rgba(168,85,247,.18);
}

@media (max-width: 600px) {
    .qb-tool-card { padding: 18px 14px; border-radius: 20px; }
    .qb-tool-visual { min-height: 180px; }
    .qb-auth-tool-visual { min-height: 120px; }
    .qb-tool-icons { gap: 6px; }
    .qb-tool-circle-xs { width: 35px; height: 35px; padding: 6px; }
    .qb-tool-circle-sm { width: 42px; height: 42px; padding: 8px; }
    .qb-tool-circle-md { width: 48px; height: 48px; padding: 8px; }
    .qb-tool-circle-main { width: 62px; height: 62px; padding: 11px; }
}

@media (prefers-reduced-motion: reduce) {
    .qb-tool-circle, .qb-tool-beam, .qb-tool-beam span { animation: none !important; }
}


/* ===========================================
   39. UTILITY CLASSES
   =========================================== */

/* Text colors */
.text-purple { color: var(--purple); }
.text-green { color: var(--green); }
.text-red { color: var(--red); }
.text-yellow { color: var(--yellow); }
.text-blue { color: var(--blue); }
.text-muted { color: var(--text-muted); }
.text-secondary { color: var(--text-secondary); }

/* Text alignment */
.text-center { text-align: center; }
.text-left { text-align: left; }
.text-right { text-align: right; }

/* Font weight */
.font-bold { font-weight: 700; }
.font-semibold { font-weight: 600; }
.font-medium { font-weight: 500; }
.font-normal { font-weight: 400; }

/* Font size */
.text-xs { font-size: 12px; }
.text-sm { font-size: 14px; }
.text-base { font-size: 16px; }
.text-lg { font-size: 18px; }
.text-xl { font-size: 24px; }
.text-2xl { font-size: 32px; }

/* Margin top */
.mt-1 { margin-top: 4px; }
.mt-2 { margin-top: 8px; }
.mt-3 { margin-top: 12px; }
.mt-4 { margin-top: 16px; }
.mt-5 { margin-top: 24px; }
.mt-6 { margin-top: 32px; }
.mt-7 { margin-top: 48px; }
.mt-8 { margin-top: 64px; }

/* Margin bottom */
.mb-1 { margin-bottom: 4px; }
.mb-2 { margin-bottom: 8px; }
.mb-3 { margin-bottom: 12px; }
.mb-4 { margin-bottom: 16px; }
.mb-5 { margin-bottom: 24px; }
.mb-6 { margin-bottom: 32px; }
.mb-7 { margin-bottom: 48px; }
.mb-8 { margin-bottom: 64px; }

/* Padding */
.p-1 { padding: 4px; }
.p-2 { padding: 8px; }
.p-3 { padding: 12px; }
.p-4 { padding: 16px; }
.p-5 { padding: 24px; }
.p-6 { padding: 32px; }

/* Flexbox */
.flex { display: flex; }
.flex-center { display: flex; align-items: center; justify-content: center; }
.flex-between { display: flex; align-items: center; justify-content: space-between; }
.flex-col { display: flex; flex-direction: column; }
.flex-wrap { flex-wrap: wrap; }
.items-center { align-items: center; }
.items-start { align-items: flex-start; }
.items-end { align-items: flex-end; }
.justify-center { justify-content: center; }
.justify-between { justify-content: space-between; }
.justify-end { justify-content: flex-end; }
.flex-1 { flex: 1; }

/* Gap */
.gap-xs { gap: 4px; }
.gap-sm { gap: 8px; }
.gap-md { gap: 16px; }
.gap-lg { gap: 24px; }
.gap-xl { gap: 32px; }

/* Grid */
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }

/* Width */
.w-full { width: 100%; }
.w-auto { width: auto; }
.max-w-sm { max-width: 400px; }
.max-w-md { max-width: 600px; }
.max-w-lg { max-width: 800px; }

/* Display */
.hidden { display: none; }
.block { display: block; }
.inline-block { display: inline-block; }
.inline-flex { display: inline-flex; }

/* Position */
.relative { position: relative; }
.absolute { position: absolute; }
.sticky { position: sticky; top: 0; }

/* Overflow */
.overflow-hidden { overflow: hidden; }
.overflow-auto { overflow: auto; }
.overflow-x-auto { overflow-x: auto; }

/* Border */
.border { border: 1px solid var(--border); }
.border-top { border-top: 1px solid var(--border); }
.border-bottom { border-bottom: 1px solid var(--border); }
.rounded-sm { border-radius: var(--radius-sm); }
.rounded-md { border-radius: var(--radius-md); }
.rounded-lg { border-radius: var(--radius-lg); }
.rounded-xl { border-radius: var(--radius-xl); }
.rounded-full { border-radius: 9999px; }

/* Opacity */
.opacity-50 { opacity: 0.5; }
.opacity-75 { opacity: 0.75; }

/* Cursor */
.cursor-pointer { cursor: pointer; }
.cursor-not-allowed { cursor: not-allowed; }

/* Truncate text */
.truncate {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.line-clamp-2 {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.line-clamp-3 {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Whitespace */
.nowrap { white-space: nowrap; }

/* Visually hidden but accessible */
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0;
}

/* Transition helper */
.transition {
    transition: all 0.25s var(--ease);
}

/* Gradient text */
.gradient-text {
    background: linear-gradient(135deg, var(--purple), var(--purple-light));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* No select */
.no-select {
    -webkit-user-select: none;
    user-select: none;
}


/* ===========================================
   39b. ACCESSIBILITY (a11y)
   =========================================== */

/* Universal focus-visible ring for interactive elements that don't define their own */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[role="button"]:focus-visible,
[tabindex]:focus-visible {
    outline: none;
    box-shadow: var(--focus-ring);
    border-radius: 6px;
}

/* Nav chip focus */
.nav-user-info:focus-visible {
    outline: none;
    box-shadow: var(--focus-ring);
    border-color: var(--purple);
}

/* Respect prefers-reduced-motion — disable transforms and shorten transitions */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
    .btn-primary:hover,
    .btn-cta:hover,
    .btn-nav-fill:hover,
    .nav-user-info:hover {
        transform: none !important;
    }
}

/* Public stock overview injected by scripts/main.js */
.qb-stock-section {
    position: relative;
    z-index: 2;
    width: min(1180px, calc(100% - 40px));
    margin: 76px auto;
    color: #f8f5ff;
}
.qb-stock-shell {
    position: relative;
    overflow: hidden;
    padding: 32px;
    border: 1px solid rgba(185, 117, 255, .22);
    border-radius: 28px;
    background:
        radial-gradient(circle at 8% 0%, rgba(168, 85, 247, .16), transparent 36%),
        linear-gradient(145deg, rgba(18, 13, 27, .96), rgba(8, 8, 13, .98));
    box-shadow: 0 24px 70px rgba(0, 0, 0, .38), inset 0 1px rgba(255, 255, 255, .04);
}
.qb-stock-shell::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: linear-gradient(110deg, transparent 35%, rgba(236, 72, 153, .06), transparent 65%);
    transform: translateX(-100%);
    animation: qbStockSweep 8s ease-in-out infinite;
}
.qb-stock-head {
    position: relative;
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 24px;
    margin-bottom: 24px;
}
.qb-stock-kicker {
    margin: 0 0 8px;
    color: #b975ff;
    font-size: .75rem;
    font-weight: 800;
    letter-spacing: .14em;
    text-transform: uppercase;
}
.qb-stock-title {
    margin: 0;
    color: #fff;
    font-size: clamp(1.65rem, 3vw, 2.35rem);
    line-height: 1.05;
    letter-spacing: -.035em;
}
.qb-stock-subtitle {
    max-width: 620px;
    margin: 10px 0 0;
    color: rgba(235, 229, 244, .62);
    font-size: .92rem;
    line-height: 1.55;
}
.qb-stock-total {
    min-width: 190px;
    padding: 16px 20px;
    border: 1px solid rgba(255, 255, 255, .09);
    border-radius: 18px;
    background: rgba(255, 255, 255, .045);
    text-align: right;
}
.qb-stock-total-label {
    display: block;
    color: rgba(235, 229, 244, .58);
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
}
.qb-stock-total-value {
    display: block;
    margin-top: 5px;
    color: #fff;
    font-size: 1.55rem;
    font-weight: 850;
}
.qb-stock-grid {
    position: relative;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(205px, 1fr));
    gap: 14px;
}
.qb-stock-card {
    min-height: 142px;
    padding: 18px;
    border: 1px solid rgba(255, 255, 255, .075);
    border-radius: 19px;
    background: rgba(255, 255, 255, .035);
    transition: transform 260ms ease, border-color 260ms ease, background 260ms ease;
}
.qb-stock-card:hover {
    transform: translateY(-4px);
    border-color: rgba(185, 117, 255, .34);
    background: rgba(185, 117, 255, .065);
}
.qb-stock-card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 18px;
}
.qb-stock-card-name {
    overflow: hidden;
    color: rgba(248, 245, 255, .82);
    font-size: .82rem;
    font-weight: 750;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.qb-stock-dot {
    flex: 0 0 auto;
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: #ef4444;
    box-shadow: 0 0 13px rgba(239, 68, 68, .55);
}
.qb-stock-dot.is-online {
    background: #22ff88;
    box-shadow: 0 0 14px rgba(34, 255, 136, .68);
    animation: qbStockPulse 2s ease-in-out infinite;
}
.qb-stock-card-value {
    color: #fff;
    font-size: 1.65rem;
    font-weight: 850;
    letter-spacing: -.035em;
}
.qb-stock-card-unit {
    margin-top: 7px;
    color: #b975ff;
    font-size: .75rem;
    font-weight: 750;
}
.qb-stock-foot {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-top: 18px;
    color: rgba(235, 229, 244, .45);
    font-size: .72rem;
}
.qb-stock-refresh {
    border: 0;
    padding: 7px 11px;
    color: #cda7ff;
    background: transparent;
    font: inherit;
    font-weight: 750;
    cursor: pointer;
}
.qb-stock-loading {
    grid-column: 1 / -1;
    padding: 30px 10px;
    color: rgba(235, 229, 244, .62);
    text-align: center;
}
@keyframes qbStockPulse {
    50% { opacity: .58; transform: scale(1.35); }
}
@keyframes qbStockSweep {
    0%, 55% { transform: translateX(-100%); }
    80%, 100% { transform: translateX(100%); }
}
@media (max-width: 700px) {
    .qb-stock-section {
        width: min(100% - 24px, 1180px);
        margin: 52px auto;
    }
    .qb-stock-shell { padding: 22px 16px; border-radius: 22px; }
    .qb-stock-head { align-items: stretch; flex-direction: column; }
    .qb-stock-total { min-width: 0; text-align: left; }
    .qb-stock-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .qb-stock-card { min-height: 124px; padding: 15px; }
    .qb-stock-card-value { font-size: 1.25rem; }
}
@media (max-width: 390px) {
    .qb-stock-grid { grid-template-columns: 1fr; }
}
@media (prefers-reduced-motion: reduce) {
    .qb-stock-shell::before,
    .qb-stock-dot.is-online { animation: none; }
}

/* Developer/owner session tools shown only on the home page */
.qb-admin-tools {
    width: min(1180px, calc(100% - 40px));
    margin: 72px auto;
    color: #f8f5ff;
}
.qb-admin-tools-shell {
    padding: 30px;
    border: 1px solid rgba(185,117,255,.25);
    border-radius: 26px;
    background:
        radial-gradient(circle at 95% 0%, rgba(139,61,240,.18), transparent 38%),
        linear-gradient(145deg, rgba(23,13,39,.97), rgba(8,7,13,.98));
    box-shadow: 0 26px 80px rgba(0,0,0,.42);
}
.qb-admin-tools-head {
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:18px;
    margin-bottom:22px;
}
.qb-admin-tools-kicker {
    color:#cda7ff;
    font-size:.72rem;
    font-weight:800;
    letter-spacing:.12em;
    text-transform:uppercase;
}
.qb-admin-tools h2 { margin:7px 0;font-size:clamp(1.5rem,3vw,2.15rem);color:#fff; }
.qb-admin-tools p { margin:0;color:rgba(235,229,244,.62);line-height:1.55; }
.qb-admin-tools-role {
    flex:0 0 auto;
    padding:8px 12px;
    border-radius:999px;
    border:1px solid rgba(34,255,136,.22);
    background:rgba(34,255,136,.08);
    color:#6ee7b7;
    font-size:.72rem;
    font-weight:800;
    text-transform:uppercase;
}
.qb-admin-lab-grid {
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:14px;
}
.qb-admin-lab-field label {
    display:block;
    margin:0 0 7px;
    color:rgba(248,245,255,.78);
    font-size:.76rem;
    font-weight:700;
}
.qb-admin-lab-field small {
    display:block;
    margin:7px 2px 0;
    color:rgba(231,225,242,.58);
    font-size:.69rem;
    line-height:1.45;
}
.qb-admin-lab-check {
    grid-column:1/-1;
    display:flex;
    align-items:flex-start;
    gap:11px;
    padding:13px 14px;
    border:1px solid rgba(192,132,252,.2);
    border-radius:15px;
    background:rgba(168,85,247,.065);
    color:rgba(248,245,255,.88);
    cursor:pointer;
}
.qb-admin-lab-check input {
    width:18px;
    height:18px;
    margin:2px 0 0;
    accent-color:#a855f7;
    flex:0 0 auto;
}
.qb-admin-lab-check strong {
    display:block;
    font-size:.78rem;
}
.qb-admin-lab-check small {
    display:block;
    margin-top:4px;
    color:rgba(231,225,242,.58);
    font-size:.69rem;
    line-height:1.45;
}
.qb-admin-lab-field input,
.qb-admin-lab-field select {
    width:100%;
    min-height:50px;
    padding:0 14px;
    border:1px solid rgba(255,255,255,.12);
    border-radius:15px;
    background:rgba(255,255,255,.045);
    color:#fff;
    font:inherit;
}
.qb-admin-lab-actions {
    display:flex;
    align-items:center;
    gap:10px;
    flex-wrap:wrap;
    margin-top:18px;
}
.qb-admin-lab-send,
.qb-admin-session-logout {
    min-height:46px;
    padding:0 18px;
    border-radius:999px;
    font:inherit;
    font-weight:750;
    cursor:pointer;
}
.qb-admin-lab-send {
    border:1px solid rgba(255,255,255,.15);
    background:linear-gradient(135deg,#a855f7,#8b3df0);
    color:#fff;
    box-shadow:0 10px 28px rgba(139,61,240,.28);
}
.qb-admin-session-logout {
    border:1px solid rgba(255,255,255,.12);
    background:rgba(255,255,255,.05);
    color:rgba(255,255,255,.8);
}
.qb-admin-lab-result {
    display:none;
    margin-top:16px;
    padding:14px;
    border-radius:14px;
    background:rgba(255,255,255,.04);
    color:rgba(255,255,255,.75);
    font:12px/1.55 ui-monospace,SFMono-Regular,Consolas,monospace;
    white-space:pre-wrap;
    overflow-wrap:anywhere;
}
@media(max-width:700px) {
    .qb-admin-tools { width:min(100% - 24px,1180px);margin:52px auto; }
    .qb-admin-tools-shell { padding:21px 16px; }
    .qb-admin-tools-head { flex-direction:column; }
    .qb-admin-lab-grid { grid-template-columns:1fr; }
}


/* ===========================================
   40. PRINT STYLES
   =========================================== */

@media print {
    .site-nav,
    .site-footer,
    .hamburger,
    .mobile-menu,
    .toast-container,
    .modal-overlay {
        display: none !important;
    }

    body {
        background: white;
        color: black;
    }

    .main-content {
        padding-top: 0;
    }

    .glass-card,
    .card {
        border: 1px solid #ccc;
        background: white;
    }

    a {
        color: black;
        text-decoration: underline;
    }
}


/* ================================================================
   iOS 26 · LIQUID GLASS · PURPLE THEME
   Override layer · aplicado a todo el sitio
   ================================================================ */

:root {
    /* Spacing scale 4/8 */
    --sp-1: 4px;  --sp-2: 8px;  --sp-3: 12px;
    --sp-4: 16px; --sp-5: 20px; --sp-6: 24px;
    --sp-8: 32px; --sp-10: 40px; --sp-12: 48px;
    --sp-16: 64px; --sp-20: 80px; --sp-24: 96px;

    /* Type scale (iOS-like) */
    --text-xs: 12px; --text-sm: 13px; --text-base: 15px;
    --text-md: 17px; --text-lg: 19px; --text-xl: 22px;
    --text-2xl: 28px; --text-3xl: 36px; --text-4xl: 48px; --text-display: 64px;
}

/* ── Tipografia base ── */
html { -webkit-text-size-adjust: 100%; }
h1, h2, h3, .display, .heading {
    letter-spacing: -0.025em;
    line-height: 1.1;
    font-weight: 800;
}
h4, h5, h6 { letter-spacing: -0.018em; line-height: 1.25; font-weight: 700; }
p, li, dd { line-height: 1.55; color: var(--text-secondary); }
strong, b { color: var(--text); }

/* Numeros tabulares */
.tabular, [class*="price"], [class*="rbx"], [class*="amount"],
.calc-result-value, .rate-box-value, .pkg-price, .pkg-robux {
    font-variant-numeric: tabular-nums;
    font-feature-settings: 'tnum';
    letter-spacing: -0.02em;
}

/* Selection */
::selection { background: var(--purple-glow); color: #fff; }
::-moz-selection { background: var(--purple-glow); color: #fff; }

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        transition-duration: 0.01ms !important;
    }
}

/* Touch optimization */
button, a, [role="button"], input, select, textarea {
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
}

/* ── Focus accesible ── */
*:focus { outline: none; }
*:focus-visible {
    outline: 2px solid var(--purple);
    outline-offset: 2px;
    border-radius: var(--radius-sm);
}
button:focus-visible, a.btn:focus-visible, [role="button"]:focus-visible,
.btn:focus-visible, .btn-primary:focus-visible, .btn-nav:focus-visible {
    outline-offset: 3px;
    box-shadow: 0 0 0 4px rgba(185,117,255,0.3);
}

/* ── Press feedback global ── */
button:not(:disabled):active,
.btn:not(:disabled):active,
[role="button"]:not(:disabled):active,
a.btn:active, .pkg-btn-buy:not(:disabled):active,
.btn-pay:not(:disabled):active {
    transform: scale(0.97);
    transition: transform 80ms var(--ease-out);
}

button:disabled, .btn:disabled, [aria-disabled="true"] {
    opacity: 0.4;
    cursor: not-allowed !important;
    pointer-events: none;
}

/* ================================================================
   LIQUID GLASS NAV - barra superior translucida con blur fuerte
   ================================================================ */
.main-nav, nav.main-nav, .navbar, header.site-header {
    background: rgba(10, 6, 18, 0.55) !important;
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border-bottom: 1px solid var(--glass-border);
    box-shadow: 0 1px 0 rgba(255,255,255,0.04) inset, 0 8px 32px rgba(0,0,0,0.4);
}

/* ================================================================
   LIQUID GLASS CARDS - todas las superficies elevadas
   ================================================================ */
.glass-card, .card, .package-card, .vouch-card, .group-card,
.feature-card, .qb-card, .stats-card, .pkg-card,
.calc-card, .reviews-card, .profile-card, .rate-box, .roblox-card {
    background: var(--glass-2) !important;
    backdrop-filter: var(--glass-blur-md);
    -webkit-backdrop-filter: var(--glass-blur-md);
    border: 1px solid var(--glass-border) !important;
    border-radius: var(--radius-lg) !important;
    box-shadow: var(--shadow-glass-md);
    transition: transform 320ms var(--ease),
                box-shadow 320ms var(--ease),
                border-color 320ms var(--ease),
                background 320ms var(--ease);
    position: relative;
    isolation: isolate;
}

/* Highlight superior (efecto cristal Apple) */
.glass-card::before, .card::before, .package-card::before, .pkg-card::before,
.vouch-card::before, .group-card::before, .feature-card::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    padding: 1px;
    background: linear-gradient(180deg, rgba(255,255,255,0.18) 0%, rgba(255,255,255,0.02) 30%, transparent 70%);
    -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
            mask-composite: exclude;
    pointer-events: none;
    z-index: 1;
}

.glass-card:hover, .card:hover, .package-card:hover, .pkg-card:hover,
.vouch-card:hover, .group-card:hover, .feature-card:hover {
    transform: translateY(-3px);
    background: var(--glass-3) !important;
    border-color: var(--glass-border-strong) !important;
    box-shadow: var(--shadow-glass-lg), 0 0 0 1px var(--purple-glow) inset;
}

/* ================================================================
   BOTONES PILL Liquid Glass
   ================================================================ */
.btn, .btn-primary, .btn-nav, .btn-buy, .pkg-btn-buy,
.btn-wz-next, .btn-pay, button.btn,
.btn-nav-fill, .btn-nav-outline {
    border-radius: var(--radius-pill) !important;
    font-weight: 600 !important;
    letter-spacing: -0.01em;
    transition: transform 200ms var(--ease),
                box-shadow 200ms var(--ease),
                background 200ms var(--ease),
                border-color 200ms var(--ease),
                filter 200ms var(--ease) !important;
    position: relative;
    overflow: hidden;
}

/* Boton primary: gradiente morado con sheen interior */
.btn-primary, .btn-buy, .pkg-btn-buy, .btn-wz-next, .btn-pay,
.btn-nav-fill, button[class*="primary"]:not(.btn-nav-outline) {
    background: linear-gradient(135deg, var(--purple) 0%, var(--purple-dark) 50%, #7c3aed 100%) !important;
    color: #fff !important;
    border: 1px solid rgba(255,255,255,0.18) !important;
    box-shadow:
        0 8px 24px rgba(185,117,255,0.4),
        0 2px 6px rgba(0,0,0,0.3),
        inset 0 1px 0 rgba(255,255,255,0.25),
        inset 0 -1px 0 rgba(0,0,0,0.25) !important;
}
.btn-primary:hover:not(:disabled), .btn-buy:hover:not(:disabled),
.pkg-btn-buy:hover:not(:disabled), .btn-wz-next:hover:not(:disabled),
.btn-pay:hover:not(:disabled), .btn-nav-fill:hover {
    transform: translateY(-2px);
    box-shadow:
        0 14px 36px rgba(185,117,255,0.55),
        0 4px 10px rgba(0,0,0,0.35),
        inset 0 1px 0 rgba(255,255,255,0.3) !important;
    filter: brightness(1.08);
}

/* Boton outline / secondary: glass sutil */
.btn-nav-outline, .btn-secondary, .btn-wz-back, .btn-wz-skip {
    background: var(--glass-2) !important;
    backdrop-filter: var(--glass-blur-sm);
    -webkit-backdrop-filter: var(--glass-blur-sm);
    border: 1px solid var(--glass-border-strong) !important;
    color: var(--text) !important;
    box-shadow: var(--shadow-glass-sm) !important;
}
.btn-nav-outline:hover, .btn-secondary:hover,
.btn-wz-back:hover, .btn-wz-skip:hover {
    background: var(--glass-3) !important;
    border-color: var(--purple-glow) !important;
    transform: translateY(-1px);
}

/* ================================================================
   INPUTS estilo iOS 26
   ================================================================ */
input:not([type="checkbox"]):not([type="radio"]):not([type="range"]):not([type="color"]),
textarea, select {
    background: var(--glass-1) !important;
    backdrop-filter: var(--glass-blur-sm);
    -webkit-backdrop-filter: var(--glass-blur-sm);
    border: 1px solid var(--glass-border) !important;
    border-radius: var(--radius-md) !important;
    color: var(--text) !important;
    padding: 14px 16px !important;
    font-size: 16px !important;
    font-family: inherit !important;
    transition: border-color 200ms var(--ease),
                background 200ms var(--ease),
                box-shadow 200ms var(--ease) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}
input:not([type="checkbox"]):not([type="radio"]):focus,
textarea:focus, select:focus {
    border-color: var(--purple) !important;
    background: var(--glass-2) !important;
    box-shadow: 0 0 0 4px rgba(185,117,255,0.18), inset 0 1px 0 rgba(255,255,255,0.06) !important;
}
input::placeholder, textarea::placeholder {
    color: rgba(255,255,255,0.32);
    font-weight: 400;
}

/* ================================================================
   MODALES Liquid Glass premium
   ================================================================ */
.modal-overlay, .auth-overlay, .checkout-overlay,
[class*="overlay"][style*="backdrop"], [class*="modal-bg"] {
    background: rgba(6, 4, 16, 0.55) !important;
    backdrop-filter: blur(40px) saturate(1.8) !important;
    -webkit-backdrop-filter: blur(40px) saturate(1.8) !important;
}
.modal-content, .auth-card, .checkout-card,
[class*="modal-card"], .modal {
    background: rgba(20, 12, 35, 0.85) !important;
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border-strong) !important;
    border-radius: var(--radius-xl) !important;
    box-shadow: var(--shadow-glass-xl), 0 0 0 1px rgba(255,255,255,0.04) inset !important;
}

/* ================================================================
   BADGES / PILLS uniformes
   ================================================================ */
.badge, .pill, [class*="badge-"], .pkg-badge, .vouch-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 11px !important;
    border-radius: var(--radius-pill);
    font-size: 11px;
    font-weight: 700;
    line-height: 1.4;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    border: 1px solid currentColor;
    background: rgba(0,0,0,0.2);
}

/* ================================================================
   TITULOS con gradiente
   ================================================================ */
.gradient-text, .hero-title-accent, .pkg-most-popular .pkg-title,
[class*="hero-title"] [class*="gradient"], [class*="brand-gradient"] {
    background: linear-gradient(135deg, var(--purple-light) 0%, var(--purple) 45%, var(--accent) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    letter-spacing: -0.03em;
}

/* ================================================================
   SCROLLBAR pulida iOS
   ================================================================ */
::-webkit-scrollbar { width: 12px; height: 12px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
    background: rgba(185,117,255,0.35);
    border-radius: 999px;
    border: 3px solid transparent;
    background-clip: padding-box;
    transition: background 200ms ease;
}
::-webkit-scrollbar-thumb:hover {
    background: rgba(185,117,255,0.6);
    background-clip: padding-box;
}

/* ================================================================
   FOOTER Liquid Glass
   ================================================================ */
footer, .site-footer, .footer {
    background: rgba(10, 6, 18, 0.6) !important;
    backdrop-filter: var(--glass-blur-md);
    -webkit-backdrop-filter: var(--glass-blur-md);
    border-top: 1px solid var(--glass-border);
}

/* ================================================================
   TOAST iOS-style
   ================================================================ */
.toast, .qb-toast {
    background: rgba(20, 12, 35, 0.92) !important;
    backdrop-filter: var(--glass-blur-md);
    -webkit-backdrop-filter: var(--glass-blur-md);
    border: 1px solid var(--glass-border-strong) !important;
    border-radius: var(--radius-md) !important;
    box-shadow: var(--shadow-glass-lg) !important;
    animation-duration: 220ms !important;
    animation-timing-function: var(--spring) !important;
}

/* ================================================================
   SKELETON
   ================================================================ */
.skeleton {
    background: linear-gradient(90deg,
        var(--glass-1) 0%,
        var(--glass-3) 50%,
        var(--glass-1) 100%);
    background-size: 200% 100%;
    animation: skel-shimmer 1.6s ease-in-out infinite;
    border-radius: var(--radius-md);
}
@keyframes skel-shimmer {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* ================================================================
   IMAGENES crisp
   ================================================================ */
img { image-rendering: -webkit-optimize-contrast; }

/* ================================================================
   LINKS sutiles
   ================================================================ */
a:not(.btn):not([class*="btn-"]) {
    color: var(--purple-light);
    transition: color 180ms ease;
}
a:not(.btn):not([class*="btn-"]):hover {
    color: var(--purple);
}

/* ================================================================
   STATUS COLORS - feedback con icono no solo color
   ================================================================ */
.text-success, [class*="success"] { color: var(--green); }
.text-error, [class*="error"] { color: var(--red); }
.text-warning, [class*="warning"] { color: var(--yellow); }

/* ================================================================
   MOBILE responsive
   ================================================================ */
@media (max-width: 640px) {
    h1, .display { font-size: clamp(30px, 7.5vw, 44px); }
    h2 { font-size: clamp(22px, 5.5vw, 30px); }
    .container, .main-content > .inner {
        padding-left: var(--sp-4);
        padding-right: var(--sp-4);
    }
    .glass-card, .card, .package-card, .pkg-card {
        border-radius: var(--radius-md) !important;
    }
    input:not([type="checkbox"]):not([type="radio"]):focus,
    textarea:focus, select:focus {
        font-size: 16px !important; /* evita zoom iOS */
    }
}

@media (prefers-reduced-motion: reduce) {
    .glass-card:hover, .card:hover, .package-card:hover { transform: none; }
    button:active, .btn:active { transform: none; }
}

/* ================================================================
   Estados especificos preservados
   ================================================================ */
.wz-success {
    background: var(--green-dim) !important;
    border: 1px solid rgba(52,211,153,0.35) !important;
    color: var(--green) !important;
    border-radius: var(--radius-md) !important;
    padding: 12px 14px !important;
}
.wz-error {
    background: var(--red-dim) !important;
    border: 1px solid rgba(251,113,133,0.35) !important;
    color: var(--red) !important;
    border-radius: var(--radius-md) !important;
    padding: 12px 14px !important;
}


/* ====================================================================
   FINAL POLISH · iOS 26 cohesive states across the entire site
   Cubre: skeleton, empty, error, status-icon, login-prompt, spinner,
   profile-header, btn-danger, mobile drawer, tooltips
   ==================================================================== */

/* ── Spinner consistente ── */
.spinner, .qb-spinner, [class*="spinner"]:not([class*="-"]) {
    border: 2px solid rgba(255,255,255,0.1) !important;
    border-top-color: var(--purple, #b975ff) !important;
}

/* ── Status icons (checkout-resultado, etc.) ── */
.status-icon {
    width: 88px !important;
    height: 88px !important;
    border-radius: 28px !important;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 24px;
    font-size: 36px !important;
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    box-shadow: var(--shadow-glass-md, 0 8px 24px rgba(0,0,0,0.45));
}
.status-icon.loading {
    background: linear-gradient(135deg, rgba(185,117,255,0.18), rgba(217,70,239,0.12)) !important;
    border: 1px solid rgba(185,117,255,0.35) !important;
    color: var(--purple-light, #d4a8ff) !important;
}
.status-icon.approved, .status-icon.success {
    background: linear-gradient(135deg, rgba(52,211,153,0.18), rgba(16,185,129,0.12)) !important;
    border: 1px solid rgba(52,211,153,0.35) !important;
    color: var(--green, #34d399) !important;
}
.status-icon.failed, .status-icon.error {
    background: linear-gradient(135deg, rgba(251,113,133,0.18), rgba(239,68,68,0.12)) !important;
    border: 1px solid rgba(251,113,133,0.35) !important;
    color: var(--red, #fb7185) !important;
}
.status-icon.pending, .status-icon.warning {
    background: linear-gradient(135deg, rgba(251,191,36,0.2), rgba(245,158,11,0.12)) !important;
    border: 1px solid rgba(251,191,36,0.35) !important;
    color: var(--yellow, #fbbf24) !important;
}

/* ── Login prompt (profile sin sesion) ── */
.login-prompt {
    text-align: center;
    padding: 64px 32px !important;
    max-width: 480px;
    margin: 0 auto;
    background: var(--glass-2);
    backdrop-filter: var(--glass-blur-md, blur(40px) saturate(1.6));
    -webkit-backdrop-filter: blur(40px) saturate(1.6);
    border: 1px solid var(--glass-border-strong, rgba(255,255,255,0.18));
    border-radius: var(--radius-xl, 32px);
    box-shadow: var(--shadow-glass-lg, 0 24px 60px rgba(0,0,0,0.55));
    position: relative;
}
.login-prompt-icon {
    width: 80px;
    height: 80px;
    border-radius: 26px;
    background: linear-gradient(135deg, var(--purple, #b975ff), var(--accent, #d946ef));
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 30px;
    margin-bottom: 20px;
    box-shadow: 0 12px 32px rgba(185,117,255,0.45), inset 0 1px 0 rgba(255,255,255,0.3);
}
.login-prompt h2 {
    font-size: 24px;
    font-weight: 800;
    letter-spacing: -0.025em;
    margin-bottom: 10px;
}
.login-prompt p {
    color: rgba(255,255,255,0.65);
    font-size: 14.5px;
    line-height: 1.55;
    margin-bottom: 24px;
}

/* ── Profile header card ── */
.profile-header {
    background: var(--glass-2) !important;
    backdrop-filter: var(--glass-blur-md, blur(24px) saturate(1.6)) !important;
    -webkit-backdrop-filter: blur(24px) saturate(1.6) !important;
    border: 1px solid var(--glass-border, rgba(255,255,255,0.14)) !important;
    border-radius: var(--radius-xl, 32px) !important;
    padding: 28px !important;
    box-shadow: var(--shadow-glass-md);
}
.profile-avatar {
    border: 2px solid rgba(185,117,255,0.35) !important;
    box-shadow: 0 8px 24px rgba(185,117,255,0.25);
}

/* ── Botones danger (logout) ── */
.btn-danger, button.btn-danger {
    background: linear-gradient(135deg, var(--red, #fb7185) 0%, #e11d48 100%) !important;
    color: #fff !important;
    border: 1px solid rgba(255,255,255,0.18) !important;
    border-radius: var(--radius-pill, 999px) !important;
    font-weight: 600 !important;
    padding: 10px 20px !important;
    box-shadow: 0 4px 14px rgba(251,113,133,0.4), inset 0 1px 0 rgba(255,255,255,0.2) !important;
    transition: transform 200ms var(--ease-out, cubic-bezier(0.16,1,0.3,1)),
                box-shadow 200ms var(--ease-out),
                filter 200ms ease !important;
}
.btn-danger:hover:not(:disabled) {
    transform: translateY(-1px);
    box-shadow: 0 8px 24px rgba(251,113,133,0.55), inset 0 1px 0 rgba(255,255,255,0.25) !important;
    filter: brightness(1.08);
}

/* ── Empty states uniformes ── */
.empty-state, [class*="empty-state"]:not([class*="empty-state-"]) {
    background: var(--glass-1, rgba(255,255,255,0.03));
    border: 1px solid var(--glass-border, rgba(255,255,255,0.08));
    border-radius: var(--radius-lg, 24px);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    text-align: center;
    padding: 64px 28px;
    color: rgba(255,255,255,0.55);
}

/* ── Skeleton uniforme ── */
.skeleton, .skeleton-card, .skeleton-stat, [class*="skeleton-"] {
    background: linear-gradient(90deg,
        rgba(255,255,255,0.03) 0%,
        rgba(255,255,255,0.08) 50%,
        rgba(255,255,255,0.03) 100%) !important;
    background-size: 200% 100% !important;
    animation: skel-shimmer 1.6s ease-in-out infinite !important;
    border-radius: var(--radius-md, 18px) !important;
}

/* ── Glow underline en links inline ── */
a.inline-link, a[class*="brand"] {
    position: relative;
    transition: color 200ms ease;
}

/* ── Mobile drawer/menu ── */
.mobile-menu, [class*="mobile-drawer"], [class*="mobile-nav"] {
    background: rgba(20,12,35,0.92) !important;
    backdrop-filter: blur(40px) saturate(1.8) !important;
    -webkit-backdrop-filter: blur(40px) saturate(1.8) !important;
    border-right: 1px solid var(--glass-border, rgba(255,255,255,0.14)) !important;
}
.mobile-link, [class*="mobile-link"] {
    border-radius: var(--radius-pill, 999px) !important;
    transition: all 220ms cubic-bezier(0.32,0.72,0,1) !important;
}
.mobile-link:hover {
    background: rgba(185,117,255,0.12) !important;
    color: #fff !important;
}

/* ── Tooltips (genericos) ── */
[data-tooltip] {
    position: relative;
}
[data-tooltip]:hover::after {
    content: attr(data-tooltip);
    position: absolute;
    bottom: calc(100% + 6px);
    left: 50%;
    transform: translateX(-50%);
    background: rgba(20,12,35,0.95);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(255,255,255,0.18);
    border-radius: 10px;
    padding: 6px 10px;
    font-size: 12px;
    color: rgba(255,255,255,0.9);
    white-space: nowrap;
    pointer-events: none;
    z-index: 100;
    box-shadow: 0 8px 24px rgba(0,0,0,0.4);
}

/* ── Pagination/load-more buttons ── */
.btn-load-more, [class*="load-more"] button {
    background: var(--glass-2) !important;
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid var(--glass-border-strong, rgba(255,255,255,0.18)) !important;
    border-radius: var(--radius-pill, 999px) !important;
    padding: 12px 24px;
    color: #fff;
    font-weight: 600;
    transition: all 220ms cubic-bezier(0.32,0.72,0,1);
}
.btn-load-more:hover:not(:disabled), [class*="load-more"] button:hover:not(:disabled) {
    background: var(--glass-3) !important;
    border-color: var(--purple-glow, rgba(185,117,255,0.4)) !important;
    transform: translateY(-1px);
}

/* ── Tables (vouches, orders) ── */
table th {
    font-weight: 600 !important;
    font-size: 0.72rem !important;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: rgba(255,255,255,0.55) !important;
    padding: 14px 16px !important;
    border-bottom: 1px solid rgba(255,255,255,0.1);
    background: rgba(255,255,255,0.02);
}
table td {
    padding: 14px 16px !important;
    font-size: 0.9rem;
    border-bottom: 1px solid rgba(255,255,255,0.05);
}

/* ── Smooth content fade-in en mobile (mejora percepcion) ── */
@media (max-width: 768px) {
    .glass-card, .card, .package-card, .pkg-card {
        animation: qbCardFadeIn 280ms cubic-bezier(0.32,0.72,0,1) both;
    }
}
@keyframes qbCardFadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ── No subrayar links en footer (reemplaza con opacity hover) ── */
footer a, .site-footer a {
    text-decoration: none;
    transition: color 180ms ease;
}
footer a:hover, .site-footer a:hover {
    color: var(--purple-light, #d4a8ff) !important;
}

/* ── Inputs numericos: quitar flechas/spinners nativos en TODOS los browsers ── */
input[type="number"] {
    text-align: left;
    font-variant-numeric: tabular-nums;
    -moz-appearance: textfield !important;
    appearance: textfield !important;
}
input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button {
    -webkit-appearance: none !important;
    appearance: none !important;
    margin: 0 !important;
    display: none !important;
}

/* Inputs date/time/search: tambien ocultamos iconos nativos que rompen el iOS look */
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration,
input[type="search"]::-webkit-search-results-button,
input[type="search"]::-webkit-search-results-decoration {
    -webkit-appearance: none;
    appearance: none;
}
input::-ms-clear,
input::-ms-reveal {
    display: none !important;
    width: 0 !important;
    height: 0 !important;
}

/* ── Focus dentro de modales: ring mas visible ── */
.modal *:focus-visible,
.modal-content *:focus-visible,
.auth-card *:focus-visible {
    outline: 2px solid var(--purple, #b975ff);
    outline-offset: 3px;
    box-shadow: 0 0 0 4px rgba(185,117,255,0.25);
}

/* ── Dropdowns nativos (select) consistentes ── */
select {
    cursor: pointer;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%23b975ff' stroke-width='1.6' stroke-linecap='round'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 14px center !important;
    background-size: 12px 8px !important;
    padding-right: 36px !important;
    appearance: none !important;
    -webkit-appearance: none !important;
}
select option {
    background: #1a0e2e;
    color: #fff;
}

/* ── Print: oculta elementos no esenciales ── */
@media print {
    .main-nav, footer, .site-footer, .mobile-menu, .modal-overlay { display: none !important; }
    body { background: white !important; color: black !important; }
}


/* ====================================================================
   100% RESPONSIVE · Mobile-first comprehensive layer
   Garantiza buen funcionamiento en iOS Safari, Chrome Android, Edge, FF
   Breakpoints sistematicos: 360 / 480 / 640 / 768 / 1024 / 1280
   ==================================================================== */

/* Soporte safe-area iOS (notch / home indicator) */
@supports (padding: env(safe-area-inset-top)) {
    body {
        padding-left: env(safe-area-inset-left);
        padding-right: env(safe-area-inset-right);
    }
    .main-nav, .nav, header.site-header, .navbar {
        padding-left: max(16px, env(safe-area-inset-left)) !important;
        padding-right: max(16px, env(safe-area-inset-right)) !important;
    }
    footer, .site-footer {
        padding-bottom: max(24px, env(safe-area-inset-bottom)) !important;
    }
    .modal-overlay, .auth-overlay {
        padding-top: env(safe-area-inset-top) !important;
        padding-bottom: env(safe-area-inset-bottom) !important;
    }
}

/* Prevent horizontal scroll en cualquier dispositivo */
html, body { max-width: 100%; overflow-x: hidden; }

/* iOS: deshabilita zoom on input focus (font-size >= 16px) */
input, textarea, select {
    font-size: max(16px, 1em);
}

/* Tap highlight transparente en mobile */
* { -webkit-tap-highlight-color: transparent; }

/* 360px: pantallas muy pequenas */
@media (max-width: 360px) {
    .container, .main-content > .inner, .nav-inner, main { padding-left: 12px !important; padding-right: 12px !important; }
    h1, .display { font-size: clamp(26px, 8vw, 36px) !important; }
    h2 { font-size: clamp(20px, 6.5vw, 26px) !important; }
    .glass-card, .card, .package-card { padding: 16px !important; }
    .btn, .btn-primary, button { padding: 10px 16px !important; font-size: 14px !important; }
}

/* 480px: phones */
@media (max-width: 480px) {
    .modal, .auth-card, .modal-content {
        max-width: 100% !important;
        margin: 8px !important;
        padding: 24px 20px !important;
        border-radius: 24px !important;
    }
    /* Force all grids to single column */
    .reviews-grid, .stats-row, .packages-grid, .currency-row, .form-row {
        grid-template-columns: 1fr !important;
        gap: 12px !important;
    }
    /* CTAs full-width */
    .btn-primary, .btn-buy, .btn-pay, .pkg-btn-buy, .btn-wz-next, .btn-submit {
        width: 100%;
        justify-content: center;
    }
    /* Hero pill badge full-width-friendly */
    .hero-badge { font-size: 11px !important; padding: 5px 12px !important; }
    /* Inputs full-height */
    input, textarea, select { padding: 12px 14px !important; }
    /* Nav stays compact */
    .main-nav, .nav { height: 60px !important; }
    .main-content { padding-top: 60px !important; }
    .nav-logo-text, [class*="brand-name"] { font-size: 14px !important; }
    /* Footer columns stack */
    .footer-inner, .footer-grid { grid-template-columns: 1fr !important; gap: 24px !important; text-align: center; }
}

/* 640px: phablets / small tablets portrait */
@media (max-width: 640px) {
    .reviews-grid, .vouches-grid {
        grid-template-columns: 1fr !important;
    }
    .pkg-card, .package-card, .group-card {
        padding: 18px !important;
    }
    /* Wizard steps mas compactos */
    .wizard-step { padding: 18px 20px 22px !important; }
    .wz-title { font-size: 18px !important; }
    .wz-sub { font-size: 13px !important; }
    /* Tablas: scroll horizontal en lugar de squish */
    .price-table-wrap, .data-table-wrap {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
    /* Modal close button accesible */
    .modal-close, .auth-card button[onclick*="close"] {
        width: 44px !important;
        height: 44px !important;
    }
}

/* 768px: tablets portrait */
@media (max-width: 768px) {
    /* Mobile menu toggle visible */
    .nav-mobile-toggle, .nav-burger { display: inline-flex !important; }
    /* Desktop nav links hidden */
    .nav-links, .main-nav .nav-menu { display: none !important; }
    /* Promo banner glass: padding mas comodo en tablet/mobile */
    #qbPromoBanner {
        font-size: 13px;
        padding: 11px 14px;
    }
    /* Hero buttons stack */
    .hero-buttons, .hero-cta {
        flex-direction: column;
        gap: 10px;
    }
    .hero-buttons > * { width: 100%; text-align: center; }
}

/* 1024px+: desktop */
@media (min-width: 1024px) {
    .nav-mobile-toggle, .nav-burger { display: none !important; }
}

/* Landscape phones (low height): reducir hero */
@media (max-height: 500px) and (orientation: landscape) {
    .hero { min-height: auto !important; padding: 40px 16px !important; }
    .modal, .auth-card { max-height: 90vh !important; overflow-y: auto !important; }
}

/* High-DPI displays: SVG flags + iconos crisp */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
    .qb-flag { image-rendering: -webkit-optimize-contrast; }
}

/* Hover-capable devices solamente: hover effects */
@media (hover: hover) {
    .glass-card:hover, .card:hover, .package-card:hover { /* effects */ }
}
@media (hover: none) {
    /* Touch devices: solo press feedback, no hover lift */
    .glass-card:hover, .card:hover, .package-card:hover, .vouch-card:hover {
        transform: none !important;
    }
}

/* ================================================================
   FLOATING DOCK NAVIGATION
   Isla dinamica inspirada en Aceternity FloatingDock
   ================================================================ */
.site-nav.qb-floating-dock {
    position: fixed !important;
    top: 14px !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    height: auto !important;
    padding: 0 14px !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    pointer-events: none;
    z-index: 9000 !important;
}
.site-nav.qb-floating-dock .nav-inner {
    width: max-content !important;
    max-width: min(1120px, calc(100vw - 28px)) !important;
    min-height: 58px !important;
    margin: 0 auto !important;
    padding: 7px 9px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 7px !important;
    border: 1px solid rgba(255,255,255,.14) !important;
    border-radius: 22px !important;
    background:
        radial-gradient(circle at 50% -30%, rgba(168,85,247,.2), transparent 52%),
        rgba(12,9,19,.78) !important;
    box-shadow:
        0 18px 55px rgba(0,0,0,.42),
        0 0 0 1px rgba(168,85,247,.07) inset,
        inset 0 1px 0 rgba(255,255,255,.1) !important;
    backdrop-filter: blur(28px) saturate(1.55) !important;
    -webkit-backdrop-filter: blur(28px) saturate(1.55) !important;
    pointer-events: auto;
    transition: border-color 220ms ease, background 220ms ease, transform 220ms ease, box-shadow 220ms ease !important;
}
.site-nav.qb-floating-dock.scrolled .nav-inner {
    background: rgba(10,7,16,.9) !important;
    border-color: rgba(185,117,255,.28) !important;
    box-shadow: 0 20px 65px rgba(0,0,0,.55), 0 0 34px rgba(168,85,247,.1) !important;
}
.site-nav.qb-floating-dock .nav-brand {
    width: 44px !important;
    height: 44px !important;
    padding: 4px !important;
    display: grid !important;
    place-items: center !important;
    flex: 0 0 auto !important;
    border-radius: 15px !important;
    background: linear-gradient(145deg, rgba(168,85,247,.27), rgba(99,102,241,.13)) !important;
    border: 1px solid rgba(192,132,252,.2) !important;
    transition: transform 240ms cubic-bezier(.2,.8,.2,1), background 200ms ease !important;
}
.site-nav.qb-floating-dock .nav-brand:hover { transform: translateY(-5px) scale(1.12) !important; }
.site-nav.qb-floating-dock .nav-brand .nav-logo-img {
    width: 34px !important;
    height: 34px !important;
    border-radius: 11px !important;
}
.site-nav.qb-floating-dock .nav-brand-text { display: none !important; }
.site-nav.qb-floating-dock .nav-links {
    display: flex !important;
    align-items: center !important;
    gap: 4px !important;
}
.site-nav.qb-floating-dock .nav-link,
.site-nav.qb-floating-dock .btn-nav,
.site-nav.qb-floating-dock .nav-user-info,
.site-nav.qb-floating-dock .nav-brand {
    position: relative !important;
    width: var(--dock-size, 44px) !important;
    height: var(--dock-size, 44px) !important;
    min-width: var(--dock-size, 44px) !important;
    padding: 0 !important;
    display: grid !important;
    place-items: center !important;
    border: 0 !important;
    border-radius: 50% !important;
    background: transparent !important;
    color: rgba(233,225,244,.72) !important;
    font-size: 0 !important;
    box-shadow: none !important;
    overflow: visible !important;
    transform-origin: center bottom;
    transition:
        width 120ms ease,
        height 120ms ease,
        min-width 120ms ease,
        color 180ms ease,
        background 180ms ease !important;
}
.site-nav.qb-floating-dock .nav-link img,
.site-nav.qb-floating-dock .nav-link i,
.site-nav.qb-floating-dock .nav-link lottie-player,
.site-nav.qb-floating-dock .qb-dock-auth-icon {
    width: 22px !important;
    height: 22px !important;
    min-width: 22px !important;
    min-height: 22px !important;
    max-width: 22px !important;
    max-height: 22px !important;
    display: block !important;
    object-fit: contain !important;
    font-size: 18px !important;
    line-height: 1 !important;
    filter: saturate(.85);
    transition: filter 180ms ease, transform 180ms ease !important;
    vertical-align: middle !important;
}
/* Override defensivo para que .qb-aicn no fuerce 1em (0px con font-size:0). */
.site-nav.qb-floating-dock .nav-link img.qb-aicn,
.site-nav.qb-floating-dock .nav-link .qb-aicn {
    width: 22px !important;
    height: 22px !important;
    max-width: 22px !important;
    max-height: 22px !important;
    display: block !important;
}
.site-nav.qb-floating-dock .btn-nav span { display: none !important; }
.site-nav.qb-floating-dock .nav-link:hover,
.site-nav.qb-floating-dock .btn-nav:hover,
.site-nav.qb-floating-dock .nav-user-info:hover {
    color: #fff !important;
    background: rgba(255,255,255,.06) !important;
}
.site-nav.qb-floating-dock .nav-link:hover img,
.site-nav.qb-floating-dock .nav-link:hover i,
.site-nav.qb-floating-dock .nav-link:hover lottie-player,
.site-nav.qb-floating-dock .btn-nav:hover img { filter: saturate(1.2) brightness(1.18); transform: scale(1.04); }
.site-nav.qb-floating-dock .nav-link.active {
    color: #fff !important;
    background: linear-gradient(135deg, rgba(168,85,247,.32), rgba(244,63,94,.22)) !important;
    box-shadow: 0 0 18px rgba(168,85,247,.35) !important;
}
/* Indicador "dot" debajo del item activo (estilo macOS dock app abierta). */
.site-nav.qb-floating-dock .nav-link.active::before {
    content: '';
    position: absolute;
    bottom: -10px;
    left: 50%;
    transform: translateX(-50%);
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: linear-gradient(135deg, #c084fc, #f472b6);
    box-shadow: 0 0 8px rgba(192,132,252,.7);
    pointer-events: none;
}
.site-nav.qb-floating-dock .nav-link::after,
.site-nav.qb-floating-dock .btn-nav::after,
.site-nav.qb-floating-dock .nav-user-info::after,
.site-nav.qb-floating-dock .nav-brand::after {
    content: attr(data-tooltip);
    position: absolute;
    left: 50%;
    bottom: calc(100% + 14px);
    top: auto;
    z-index: 4;
    padding: 7px 14px;
    border: 0;
    border-radius: 999px;
    background: rgba(255,255,255,0.98);
    color: #0a0810;
    font-family: inherit;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.01em;
    line-height: 1;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transform: translate(-50%, 6px) scale(.94);
    transition: opacity 160ms ease, transform 220ms cubic-bezier(0.22, 1, 0.36, 1);
    box-shadow: 0 10px 28px rgba(0,0,0,0.45);
}
/* El brand usa data-tooltip (lo setea main.js a 'QuantumBlox'). */
.site-nav.qb-floating-dock .nav-link:hover::after,
.site-nav.qb-floating-dock .btn-nav:hover::after,
.site-nav.qb-floating-dock .nav-user-info:hover::after,
.site-nav.qb-floating-dock .nav-brand:hover::after {
    opacity: 1;
    transform: translate(-50%, 0) scale(1);
}
.site-nav.qb-floating-dock .nav-auth {
    display: flex !important;
    gap: 4px !important;
    margin-left: 8px !important;
    position: relative;
}
/* Defensa contra accessory icons (Discord/Google) que pudo haber inyectado
   una version vieja de main.js que el browser tenga cacheada. */
.site-nav.qb-floating-dock .qb-dock-accessory,
.site-nav.qb-floating-dock .qb-dock-accessory-link {
    display: none !important;
}
.site-nav.qb-floating-dock .nav-auth.qb-auth-hidden { display: none !important; }
/* Register: tint sutil estilo Aceternity (no boton agresivo). */
.site-nav.qb-floating-dock .btn-nav-fill {
    background: linear-gradient(135deg, rgba(168,85,247,.22), rgba(244,63,94,.16)) !important;
    color: #fff !important;
}
.site-nav.qb-floating-dock .btn-nav-fill:hover {
    background: linear-gradient(135deg, rgba(168,85,247,.35), rgba(244,63,94,.25)) !important;
}

/* Brand: preserva su gradient (mi rule general lo puso transparent). */
.site-nav.qb-floating-dock .nav-brand {
    background: linear-gradient(135deg, rgba(168,85,247,.25), rgba(244,63,94,.18)) !important;
    padding: 4px !important;
    margin-right: 4px !important;
}
.site-nav.qb-floating-dock .nav-brand:hover {
    background: linear-gradient(135deg, rgba(168,85,247,.4), rgba(244,63,94,.28)) !important;
}
/* Logo dentro del brand: circulo tambien. */
.site-nav.qb-floating-dock .nav-brand .nav-logo-img {
    border-radius: 50% !important;
    width: 30px !important;
    height: 30px !important;
}
.site-nav.qb-floating-dock .nav-user-info {
    margin-left: 4px !important;
    border-color: rgba(192,132,252,.22) !important;
    background: rgba(168,85,247,.13) !important;
}
.site-nav.qb-floating-dock .nav-user-info:not(.qb-user-visible) { display: none !important; }
.site-nav.qb-floating-dock .nav-user-avatar {
    width: 32px !important;
    height: 32px !important;
    border-radius: 11px !important;
}
.site-nav.qb-floating-dock .nav-user-name { display: none !important; }
.site-nav.qb-floating-dock .hamburger { display: none !important; }
.site-nav.qb-floating-dock + .mobile-menu { display: none !important; }

@media (max-width: 900px) {
    .site-nav.qb-floating-dock {
        top: auto !important;
        bottom: max(12px, env(safe-area-inset-bottom)) !important;
        padding: 0 10px !important;
    }
    .site-nav.qb-floating-dock .nav-inner {
        width: min-content !important;
        max-width: calc(100vw - 20px) !important;
        min-height: 60px !important;
        justify-content: flex-start !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        scrollbar-width: none;
        border-radius: 22px !important;
    }
    .site-nav.qb-floating-dock .nav-inner::-webkit-scrollbar { display: none; }
    .site-nav.qb-floating-dock .nav-brand { display: none !important; }
    .site-nav.qb-floating-dock .nav-links { display: flex !important; }
    .site-nav.qb-floating-dock .nav-link,
    .site-nav.qb-floating-dock .btn-nav,
    .site-nav.qb-floating-dock .nav-user-info {
        width: 43px !important;
        height: 43px !important;
        min-width: 43px !important;
    }
    .site-nav.qb-floating-dock .nav-auth { display: flex !important; }
    .site-nav.qb-floating-dock .nav-link::after,
    .site-nav.qb-floating-dock .btn-nav::after,
    .site-nav.qb-floating-dock .nav-user-info::after { display: none !important; }
    body { padding-bottom: 82px; }
    body.qb-has-promo { padding-bottom: 136px !important; }
    body.qb-has-promo .site-nav.qb-floating-dock {
        bottom: calc(66px + env(safe-area-inset-bottom)) !important;
    }
    body.qb-checkout-page .site-nav.qb-floating-dock,
    body.qb-checkout-page.qb-has-promo .site-nav.qb-floating-dock {
        top: 12px !important;
        bottom: auto !important;
    }
    body.qb-checkout-page { padding-bottom: 0; }
    body.qb-checkout-page.qb-has-promo { padding-bottom: 54px !important; }
}

@media (max-width: 420px) {
    .site-nav.qb-floating-dock .nav-inner { padding: 6px !important; gap: 2px !important; }
    .site-nav.qb-floating-dock .nav-link,
    .site-nav.qb-floating-dock .btn-nav,
    .site-nav.qb-floating-dock .nav-user-info {
        width: 41px !important;
        height: 41px !important;
        min-width: 41px !important;
        border-radius: 13px !important;
    }
}

/* Modo oscuro forzado (siempre dark) */
@media (prefers-color-scheme: light) {
    body { color-scheme: dark; }
}

/* Prevent layout shift cuando carga el font de Inter */
.fonts-loading body { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif; }

/* Sticky bottom CTA en mobile (cuando aplique) */
@media (max-width: 640px) {
    .sticky-cta-mobile {
        position: sticky;
        bottom: 0;
        background: rgba(20,12,35,0.92);
        backdrop-filter: blur(40px);
        -webkit-backdrop-filter: blur(40px);
        border-top: 1px solid rgba(255,255,255,0.12);
        padding: 12px 16px max(12px, env(safe-area-inset-bottom));
        z-index: 100;
    }
}

/* iOS Safari: fix 100vh issue */
.full-height, [class*="full-height"] {
    height: 100vh;
    height: 100dvh;
    min-height: 100vh;
    min-height: 100dvh;
}

/* Smooth momentum scrolling iOS */
.scroll-y, [class*="scroll"] {
    -webkit-overflow-scrolling: touch;
}

/* Desktop: max content width consistent */
@media (min-width: 1280px) {
    .main, .container, [class*="container"]:not([class*="-container-"]) {
        max-width: 1200px;
    }
}


/* ====================================================================
   ANIMATION LAYER · Movement & 3D polish across the site
   ==================================================================== */

@keyframes qb-fade-up {
    from { opacity: 0; transform: translate3d(0, 32px, 0); }
    to   { opacity: 1; transform: translate3d(0, 0, 0); }
}
@keyframes qb-fade-down {
    from { opacity: 0; transform: translate3d(0, -32px, 0); }
    to   { opacity: 1; transform: translate3d(0, 0, 0); }
}
@keyframes qb-fade-left {
    from { opacity: 0; transform: translate3d(-32px, 0, 0); }
    to   { opacity: 1; transform: translate3d(0, 0, 0); }
}
@keyframes qb-fade-right {
    from { opacity: 0; transform: translate3d(32px, 0, 0); }
    to   { opacity: 1; transform: translate3d(0, 0, 0); }
}
@keyframes qb-zoom-in {
    from { opacity: 0; transform: scale3d(0.92, 0.92, 1); }
    to   { opacity: 1; transform: scale3d(1, 1, 1); }
}
@keyframes qb-flip-up {
    from { opacity: 0; transform: perspective(800px) rotateX(20deg) translateY(20px); }
    to   { opacity: 1; transform: perspective(800px) rotateX(0) translateY(0); }
}
@keyframes qb-float {
    0%, 100% { transform: translateY(0); }
    50%      { transform: translateY(-8px); }
}
@keyframes qb-glow-pulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(185,117,255,0.4); }
    50%      { box-shadow: 0 0 24px 4px rgba(185,117,255,0.3); }
}
@keyframes qb-shimmer-bg {
    0%, 100% { background-position: 0% 50%; }
    50%      { background-position: 100% 50%; }
}

/* Scroll-reveal: elementos con .animate-on-scroll fade-up al verse */
.animate-on-scroll {
    opacity: 0;
    transform: translate3d(0, 28px, 0);
    transition: opacity 700ms cubic-bezier(0.16, 1, 0.3, 1),
                transform 700ms cubic-bezier(0.16, 1, 0.3, 1);
    will-change: opacity, transform;
}
.animate-on-scroll.is-visible,
.animate-on-scroll.aos-visible {
    opacity: 1;
    transform: translate3d(0, 0, 0);
}

/* Variantes */
.animate-on-scroll[data-anim="fade-down"]    { animation: none; transform: translate3d(0, -28px, 0); }
.animate-on-scroll[data-anim="fade-left"]    { transform: translate3d(-28px, 0, 0); }
.animate-on-scroll[data-anim="fade-right"]   { transform: translate3d(28px, 0, 0); }
.animate-on-scroll[data-anim="zoom-in"]      { transform: scale3d(0.92, 0.92, 1); }
.animate-on-scroll[data-anim="flip-up"]      { transform: perspective(800px) rotateX(20deg) translateY(20px); }
.animate-on-scroll.is-visible { transform: translate3d(0, 0, 0) scale3d(1, 1, 1) rotateX(0); }

/* Stagger automatico para grid de cards */
.animate-on-scroll.is-visible > * {
    animation: qb-fade-up 600ms cubic-bezier(0.16, 1, 0.3, 1) both;
}
.animate-on-scroll.is-visible > *:nth-child(1) { animation-delay: 0ms; }
.animate-on-scroll.is-visible > *:nth-child(2) { animation-delay: 50ms; }
.animate-on-scroll.is-visible > *:nth-child(3) { animation-delay: 100ms; }
.animate-on-scroll.is-visible > *:nth-child(4) { animation-delay: 150ms; }
.animate-on-scroll.is-visible > *:nth-child(5) { animation-delay: 200ms; }
.animate-on-scroll.is-visible > *:nth-child(6) { animation-delay: 250ms; }
.animate-on-scroll.is-visible > *:nth-child(7) { animation-delay: 300ms; }
.animate-on-scroll.is-visible > *:nth-child(8) { animation-delay: 350ms; }

/* 3D card tilt en hover (cards y package cards) */
@media (hover: hover) and (pointer: fine) {
    .glass-card, .package-card, .pkg-card, .vouch-card, .group-card,
    .review-card, .game-card, .feature-card, .kpi-card {
        transform-style: preserve-3d;
        transform: perspective(1000px) rotateX(0) rotateY(0) translateZ(0);
        transition: transform 320ms cubic-bezier(0.32, 0.72, 0, 1),
                    box-shadow 320ms cubic-bezier(0.32, 0.72, 0, 1),
                    border-color 320ms cubic-bezier(0.32, 0.72, 0, 1) !important;
    }
    .glass-card:hover, .package-card:hover, .pkg-card:hover,
    .vouch-card:hover, .group-card:hover, .review-card:hover,
    .game-card:hover, .feature-card:hover, .kpi-card:hover {
        transform: perspective(1000px) translateY(-4px) translateZ(10px) !important;
    }
}

/* Botones primary con shimmer animado al hover */
.btn-primary, .btn-buy, .pkg-btn-buy, .btn-wz-next, .btn-pay,
.btn-nav-fill, .btn-cta, .btn-submit {
    position: relative;
    overflow: hidden;
    isolation: isolate;
}
.btn-primary::before, .btn-buy::before, .pkg-btn-buy::before,
.btn-wz-next::before, .btn-pay::before, .btn-nav-fill::before,
.btn-cta::before, .btn-submit::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(110deg, transparent 35%, rgba(255,255,255,0.35) 50%, transparent 65%);
    transform: translateX(-150%);
    pointer-events: none;
    z-index: 0;
    transition: transform 700ms cubic-bezier(0.16, 1, 0.3, 1);
}
.btn-primary:hover::before, .btn-buy:hover::before, .pkg-btn-buy:hover::before,
.btn-wz-next:hover::before, .btn-pay:hover::before, .btn-nav-fill:hover::before,
.btn-cta:hover::before, .btn-submit:hover::before {
    transform: translateX(150%);
}
.btn-primary > *, .btn-buy > *, .pkg-btn-buy > *,
.btn-wz-next > *, .btn-pay > *, .btn-nav-fill > *,
.btn-cta > *, .btn-submit > * {
    position: relative;
    z-index: 1;
}

/* Icono flotante en hero/branding (logo) */
.brand-logo {
    transition: transform 480ms cubic-bezier(0.32, 0.72, 0, 1),
                filter 320ms ease;
}
.brand-logo:hover {
    transform: scale(1.08) rotate(-3deg);
    filter: drop-shadow(0 8px 20px rgba(185,117,255,0.55));
}

/* Inputs con focus glow expansivo */
input:not([type="checkbox"]):not([type="radio"]):not([type="range"]):focus,
textarea:focus, select:focus {
    animation: qb-glow-pulse 1.6s ease-out 1;
}

/* Loading dots animation */
@keyframes qb-dot-bounce {
    0%, 80%, 100% { transform: scale(0.6); opacity: 0.4; }
    40%           { transform: scale(1); opacity: 1; }
}
.qb-loading-dots {
    display: inline-flex;
    gap: 4px;
    align-items: center;
}
.qb-loading-dots span {
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--purple, #b975ff);
    animation: qb-dot-bounce 1.2s ease-in-out infinite;
}
.qb-loading-dots span:nth-child(2) { animation-delay: 0.15s; }
.qb-loading-dots span:nth-child(3) { animation-delay: 0.3s; }

/* Headings gradient con animacion sutil al cargar */
h1, h2 {
    background-size: 200% 100%;
    animation: qb-shimmer-bg 12s ease-in-out infinite;
}

/* Iconos circulares: pulso suave (hero icons, status icons) */
[class*="hero-badge"] i,
.status-icon,
.empty-state-icon,
.login-prompt-icon,
.write-locked-icon {
    transition: transform 280ms cubic-bezier(0.5, 1.4, 0.4, 1);
}
[class*="hero-badge"]:hover i,
.status-icon:hover,
.empty-state-icon:hover {
    transform: scale(1.12) rotate(8deg);
}

/* Reduced motion: deshabilita TODO el motion decorativo */
@media (prefers-reduced-motion: reduce) {
    .animate-on-scroll, .animate-on-scroll > *,
    h1, h2, .brand-logo, .qb-loading-dots span,
    .btn-primary::before, .btn-buy::before, .pkg-btn-buy::before {
        animation: none !important;
        transition: none !important;
        opacity: 1 !important;
        transform: none !important;
    }
}

/* ================================================================
   FLOATING LABEL FIELD (Uiverse port - liyaxu123)
   Letras del label suben de a una al hacer focus / cuando hay valor.
   Adaptado al tema morado QuantumBlox.
   ================================================================ */
.qb-float-field {
    position: relative;
    margin: 8px 0 22px;
    width: 100%;
}
.qb-float-field input {
    background: transparent;
    border: 0;
    border-bottom: 2px solid rgba(255, 255, 255, 0.22);
    display: block;
    width: 100%;
    padding: 14px 0 10px;
    font-size: 16px;
    color: #fff;
    font-family: inherit;
    transition: border-bottom-color 220ms ease;
}
.qb-float-field input:focus,
.qb-float-field input:valid {
    outline: 0;
    border-bottom-color: #b975ff;
}
.qb-float-field label {
    position: absolute;
    top: 14px;
    left: 0;
    margin: 0;
    pointer-events: none;
    user-select: none;
    line-height: 1;
}
.qb-float-field label span {
    display: inline-block;
    font-size: 16px;
    min-width: 4px;
    color: rgba(255, 255, 255, 0.55);
    font-weight: 600;
    transition: transform 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55),
                color 0.3s ease;
}
.qb-float-field input:focus + label span,
.qb-float-field input:valid + label span {
    color: #b975ff;
    transform: translateY(-28px);
}
/* Mensaje de error: empuja un poco hacia abajo */
.qb-float-field + .qb-float-error {
    margin-top: -10px;
    margin-bottom: 14px;
    font-size: 12.5px;
    color: #fca5a5;
}

/* ================================================================
   GO BACK BUTTON (Uiverse AKAspidey01 - morado QuantumBlox)
   El icono cuadrado morado expande sobre el texto al hover.
   Reusable globalmente: aplica tambien a .btn-wz-back y .ck-back.
   ================================================================ */
.qb-go-back,
.btn-wz-back,
.ck-back.is-go-back {
    position: relative;
    background: rgba(255,255,255,0.06);
    color: #fff;
    text-align: center;
    width: 168px;
    height: 50px;
    border-radius: 14px;
    font-size: 15px;
    font-weight: 700;
    border: 1px solid rgba(255,255,255,0.10);
    cursor: pointer;
    overflow: hidden;
    box-shadow: 0 6px 18px rgba(0,0,0,0.25);
    transition: box-shadow 220ms ease, transform 180ms ease;
    display: inline-block;
    padding: 0;
    font-family: inherit;
}
.qb-go-back p,
.btn-wz-back > * {
    margin: 0;
    transform: translateX(10px);
    pointer-events: none;
}
.qb-go-back .qb-go-back-icon {
    position: absolute;
    left: 4px;
    top: 4px;
    height: calc(100% - 8px);
    width: calc(25% - 4px);
    border-radius: 10px;
    background: linear-gradient(135deg, #b975ff, #8b3df0);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.25);
    transition: width 480ms cubic-bezier(0.32, 0.72, 0, 1);
    pointer-events: none;
}
.qb-go-back .qb-go-back-icon svg { width: 22px; height: 22px; }
.qb-go-back .qb-go-back-icon svg path { fill: #ffffff; }
.qb-go-back:hover .qb-go-back-icon,
.btn-wz-back:hover::before,
.ck-back.is-go-back:hover::before { width: calc(100% - 8px); }
.qb-go-back:hover,
.btn-wz-back:hover,
.ck-back.is-go-back:hover {
    box-shadow: 0 10px 26px rgba(139, 61, 240, 0.42);
}
.qb-go-back:active,
.btn-wz-back:active,
.ck-back.is-go-back:active { transform: translateY(1px); }
.qb-go-back:focus-visible,
.btn-wz-back:focus-visible,
.ck-back.is-go-back:focus-visible {
    outline: 2px solid #b975ff;
    outline-offset: 3px;
}
/* Variante compacta */
.qb-go-back.sm {
    width: 140px;
    height: 44px;
    font-size: 13.5px;
    border-radius: 12px;
}
.qb-go-back.sm .qb-go-back-icon svg { width: 19px; height: 19px; }
/* Variante "light" (fondo blanco, contraste alto) */
.qb-go-back.light {
    background: rgba(255,255,255,0.94);
    color: #18102e;
    border: 0;
    box-shadow: 0 6px 18px rgba(0,0,0,0.32);
}

/* ---- Wizard back buttons en comprar.html: como no podemos cambiar el
   HTML, los estilizamos con icono pseudo-elemento + label. El icono
   morado se expande sobre el texto al hover (efecto Uiverse simplificado). ---- */
.btn-wz-back {
    width: 140px;
    height: 44px;
    padding: 0 8px 0 44px;
    text-align: center;
    color: #fff;
    font-size: 13.5px;
    font-weight: 700;
    line-height: 44px;
    text-decoration: none;
    white-space: nowrap;
}
.btn-wz-back > * {
    pointer-events: none;
    transform: translateX(4px);
}
.btn-wz-back > img,
.btn-wz-back > i { display: none !important; }
.btn-wz-back::before {
    content: '';
    position: absolute;
    left: 4px; top: 4px;
    height: calc(100% - 8px);
    width: 32px;
    border-radius: 10px;
    background:
        url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1024 1024" width="18" height="18"><path d="M224 480h640a32 32 0 1 1 0 64H224a32 32 0 0 1 0-64z" fill="white"/><path d="m237.248 512 265.408 265.344a32 32 0 0 1-45.312 45.312l-288-288a32 32 0 0 1 0-45.312l288-288a32 32 0 1 1 45.312 45.312L237.248 512z" fill="white"/></svg>') center / 18px no-repeat,
        linear-gradient(135deg, #b975ff, #8b3df0);
    z-index: 10;
    transition: width 480ms cubic-bezier(0.32, 0.72, 0, 1);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.25);
}
.btn-wz-back:hover::before { width: calc(100% - 8px); }
