/* ═══════════════════════════════════════════════
   CONVENIO SINTRADIAN — Premium Dark Glassmorphism
   Aligned with DashboardMain design system
   ═══════════════════════════════════════════════ */

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

:root {
    --cv-bg: #030712;
    --cv-card: rgba(255,255,255,0.04);
    --cv-card-hover: rgba(255,255,255,0.07);
    --cv-border: rgba(255,255,255,0.08);
    --cv-border-hover: rgba(255,255,255,0.15);
    --cv-text: #f8fafc;
    --cv-text-secondary: rgba(248,250,252,0.6);
    --cv-text-muted: rgba(248,250,252,0.4);
    --cv-accent: #7C5CFC;
    --cv-accent-light: rgba(124,92,252,0.15);
    --cv-success: #10b981;
    --cv-gold: #f59e0b;
    --cv-danger: #ef4444;
    --cv-font-sans: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    --cv-font-display: 'Outfit', var(--cv-font-sans);
    --cv-radius: 16px;
    --cv-radius-lg: 24px;
    --cv-radius-full: 9999px;
}

* { margin: 0; padding: 0; box-sizing: border-box; font-family: var(--cv-font-sans); }
html { scroll-behavior: smooth; }
body { background: var(--cv-bg); color: var(--cv-text); overflow-x: hidden; -webkit-font-smoothing: antialiased; }

/* ── Animated Background ── */
.cv-bg-orbs { position: fixed; inset: 0; pointer-events: none; z-index: 0; overflow: hidden; }
.cv-orb { position: absolute; border-radius: 50%; filter: blur(100px); opacity: 0.3; animation: cv-orb-float 14s ease-in-out infinite; }
.cv-orb-1 { width: 600px; height: 600px; background: radial-gradient(circle, #7C5CFC, transparent); top: -200px; left: -200px; }
.cv-orb-2 { width: 500px; height: 500px; background: radial-gradient(circle, #10b981, transparent); bottom: -100px; right: -100px; animation-delay: -5s; }
.cv-orb-3 { width: 400px; height: 400px; background: radial-gradient(circle, #f59e0b, transparent); top: 50%; left: 60%; animation-delay: -9s; }
.cv-orb-4 { width: 350px; height: 350px; background: radial-gradient(circle, #3b82f6, transparent); top: 30%; right: 10%; animation-delay: -3s; }
@keyframes cv-orb-float {
    0%, 100% { transform: translate(0, 0) scale(1); }
    33% { transform: translate(30px, -40px) scale(1.05); }
    66% { transform: translate(-20px, 20px) scale(0.95); }
}

/* ── Glass Cards ── */
.cv-glass { background: var(--cv-card); backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px); border: 1px solid var(--cv-border); border-radius: var(--cv-radius); box-shadow: 0 8px 32px rgba(0,0,0,0.4), inset 0 1px 0 rgba(255,255,255,0.06); transition: all 0.35s cubic-bezier(0.4,0,0.2,1); }
.cv-glass:hover { background: var(--cv-card-hover); border-color: var(--cv-border-hover); box-shadow: 0 16px 48px rgba(0,0,0,0.5), inset 0 1px 0 rgba(255,255,255,0.1); transform: translateY(-3px); }
.cv-glass-static { background: var(--cv-card); backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px); border: 1px solid var(--cv-border); border-radius: var(--cv-radius); box-shadow: 0 8px 32px rgba(0,0,0,0.4); }

/* ── Border Animation ── */
.cv-border-animated { position: relative; overflow: hidden; }
.cv-border-animated::before { content: ''; position: absolute; inset: 0; padding: 1px; border-radius: inherit; background: linear-gradient(90deg, #7C5CFC, #10b981, #f59e0b, #7C5CFC); background-size: 300% 100%; animation: cv-border-run 4s linear infinite; -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0); -webkit-mask-composite: xor; mask-composite: exclude; pointer-events: none; }
@keyframes cv-border-run { 0% { background-position: 0% 0; } 100% { background-position: 300% 0; } }

/* ── Gradient Text ── */
.cv-text-gradient { background: linear-gradient(135deg, #7C5CFC, #a78bfa); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.cv-text-gradient-green { background: linear-gradient(135deg, #34d399, #60a5fa); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.cv-text-gradient-gold { background: linear-gradient(135deg, #fbbf24, #f59e0b); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }

/* ── Glows ── */
.cv-glow-purple { box-shadow: 0 0 30px rgba(124,92,252,0.4), 0 0 60px rgba(124,92,252,0.15); }
.cv-glow-green { box-shadow: 0 0 30px rgba(16,185,129,0.4), 0 0 60px rgba(16,185,129,0.15); }
.cv-glow-gold { box-shadow: 0 0 30px rgba(245,158,11,0.4), 0 0 60px rgba(245,158,11,0.15); }

/* ── Pulse Dot ── */
.cv-pulse-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--cv-success); animation: cv-pulse 1.5s ease-out infinite; }
@keyframes cv-pulse { 0% { box-shadow: 0 0 0 0 rgba(16,185,129,0.7); } 70% { box-shadow: 0 0 0 12px rgba(16,185,129,0); } 100% { box-shadow: 0 0 0 0 rgba(16,185,129,0); } }

/* ── Shimmer ── */
.cv-shimmer { background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.04) 50%, transparent 100%); background-size: 200% 100%; animation: cv-shimmer 3s infinite linear; }
@keyframes cv-shimmer { 0% { background-position: -200% 0; } 100% { background-position: 200% 0; } }

/* ── Slide Up ── */
.cv-slide-up { opacity: 0; transform: translateY(30px); transition: all 0.6s cubic-bezier(0.4,0,0.2,1); }
.cv-slide-up.cv-visible { opacity: 1; transform: translateY(0); }

/* ── Nav ── */
.cv-nav { position: fixed; top: 0; left: 0; right: 0; z-index: 50; background: rgba(3,7,18,0.85); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px); border-bottom: 1px solid rgba(255,255,255,0.07); transition: all 0.3s; }
.cv-nav-inner { max-width: 1200px; margin: 0 auto; padding: 0 24px; display: flex; align-items: center; justify-content: space-between; height: 72px; }
.cv-nav-logo { display: flex; align-items: center; gap: 12px; }
.cv-nav-logo img { height: 40px; width: auto; border-radius: 12px; }
.cv-nav-links { display: flex; align-items: center; gap: 8px; }
.cv-nav-link { padding: 6px 14px; border-radius: var(--cv-radius-full); font-size: 13px; font-weight: 500; color: var(--cv-text-secondary); text-decoration: none; transition: all 0.2s; border: 1px solid transparent; }
.cv-nav-link:hover { color: var(--cv-text); background: rgba(255,255,255,0.06); }
.cv-nav-cta { padding: 8px 20px; border-radius: var(--cv-radius-full); font-size: 13px; font-weight: 700; color: #fff; background: var(--cv-accent); border: none; cursor: pointer; transition: all 0.2s; text-decoration: none; display: inline-flex; align-items: center; gap: 6px; box-shadow: 0 2px 12px rgba(124,92,252,0.3); }
.cv-nav-cta:hover { background: #6D4AE6; transform: translateY(-1px); box-shadow: 0 4px 20px rgba(124,92,252,0.4); }

/* ── Section ── */
.cv-section { position: relative; z-index: 1; padding: 80px 24px; }
.cv-container { max-width: 1100px; margin: 0 auto; }
.cv-divider { height: 1px; background: linear-gradient(90deg, transparent, rgba(255,255,255,0.1), transparent); max-width: 900px; margin: 0 auto; }
.cv-section-label { font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.12em; color: var(--cv-accent); margin-bottom: 12px; display: block; }
.cv-section-title { font-family: var(--cv-font-display); font-size: clamp(1.75rem, 4vw, 2.5rem); font-weight: 800; line-height: 1.2; color: var(--cv-text); margin-bottom: 16px; }

/* ── Hero ── */
.cv-hero { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding-top: 72px; }
.cv-hero-content { text-align: center; max-width: 800px; animation: cv-fade-in 0.8s ease-out; }
@keyframes cv-fade-in { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
.cv-hero-badge { display: inline-flex; align-items: center; gap: 8px; padding: 8px 20px; border-radius: var(--cv-radius-full); border: 1px solid rgba(124,92,252,0.3); background: rgba(124,92,252,0.08); margin-bottom: 32px; }
.cv-hero-title { font-family: var(--cv-font-display); font-size: clamp(2rem, 5vw, 3.5rem); font-weight: 900; line-height: 1.1; margin-bottom: 20px; }
.cv-hero-sub { font-size: clamp(1rem, 2vw, 1.2rem); color: var(--cv-text-secondary); line-height: 1.7; max-width: 650px; margin: 0 auto 40px; }
.cv-hero-buttons { display: flex; flex-wrap: wrap; gap: 16px; justify-content: center; margin-bottom: 48px; }
.cv-btn-primary { display: inline-flex; align-items: center; gap: 8px; padding: 14px 32px; border-radius: var(--cv-radius); font-size: 15px; font-weight: 700; color: #fff; background: linear-gradient(135deg, var(--cv-accent), #9F7AFF); border: none; cursor: pointer; transition: all 0.25s; box-shadow: 0 4px 20px rgba(124,92,252,0.35); text-decoration: none; }
.cv-btn-primary:hover { transform: translateY(-2px) scale(1.02); box-shadow: 0 8px 30px rgba(124,92,252,0.5); }
.cv-btn-secondary { display: inline-flex; align-items: center; gap: 8px; padding: 14px 32px; border-radius: var(--cv-radius); font-size: 15px; font-weight: 600; color: var(--cv-text); background: rgba(255,255,255,0.06); border: 1px solid var(--cv-border); cursor: pointer; transition: all 0.25s; text-decoration: none; }
.cv-btn-secondary:hover { background: rgba(255,255,255,0.1); border-color: var(--cv-border-hover); transform: translateY(-2px); }
.cv-stats-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; max-width: 600px; margin: 0 auto; }
.cv-stat-card { padding: 16px; border-radius: var(--cv-radius); text-align: center; }
.cv-stat-value { font-family: var(--cv-font-display); font-size: 1.75rem; font-weight: 900; }
.cv-stat-label { font-size: 11px; color: var(--cv-text-muted); margin-top: 4px; }

/* ── Benefit Cards ── */
.cv-benefits-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 20px; }
.cv-benefit-card { padding: 28px; border-radius: var(--cv-radius-lg); }
.cv-benefit-icon { width: 52px; height: 52px; border-radius: 14px; display: flex; align-items: center; justify-content: center; font-size: 26px; margin-bottom: 18px; }
.cv-benefit-title { font-family: var(--cv-font-display); font-size: 1.1rem; font-weight: 700; margin-bottom: 8px; }
.cv-benefit-desc { font-size: 14px; color: var(--cv-text-secondary); line-height: 1.6; }
.cv-benefit-list { list-style: none; padding: 0; margin-top: 12px; }
.cv-benefit-list li { display: flex; align-items: flex-start; gap: 8px; font-size: 13px; color: var(--cv-text-secondary); padding: 4px 0; }
.cv-benefit-list li span:first-child { color: var(--cv-accent); flex-shrink: 0; margin-top: 2px; }

/* ── Mentor IA Feature (Highlighted) ── */
.cv-mentor-feature { border-radius: var(--cv-radius-lg); padding: 40px; background: linear-gradient(135deg, rgba(124,92,252,0.08), rgba(16,185,129,0.05)); border: 1px solid rgba(124,92,252,0.2); position: relative; overflow: hidden; }
.cv-mentor-feature::after { content: ''; position: absolute; top: -50%; right: -20%; width: 400px; height: 400px; background: radial-gradient(circle, rgba(124,92,252,0.1), transparent 70%); pointer-events: none; }
.cv-mentor-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; align-items: center; }
.cv-mentor-visual { text-align: center; position: relative; z-index: 1; }
/* ── Interactive Tone Buttons ── */
.cv-tone-btn { display:flex; flex-direction:column; align-items:center; gap:4px; padding:14px 8px; border-radius:16px; border:1px solid rgba(255,255,255,0.1); background:rgba(255,255,255,0.04); cursor:pointer; transition:all 0.3s cubic-bezier(0.4,0,0.2,1); color:var(--cv-text); position:relative; overflow:hidden; font-family:var(--cv-font-sans); }
.cv-tone-btn::before { content:''; position:absolute; inset:0; border-radius:inherit; background:radial-gradient(circle at center, var(--tone-glow, rgba(255,255,255,0.1)), transparent 70%); opacity:0; transition:opacity 0.3s; }
.cv-tone-btn:hover { border-color:var(--tone-color, var(--cv-accent)); transform:translateY(-3px) scale(1.04); box-shadow:0 8px 25px var(--tone-glow, rgba(124,92,252,0.3)); }
.cv-tone-btn:hover::before { opacity:0.6; }
.cv-tone-btn:hover span:last-child { opacity:1 !important; }
.cv-tone-btn.cv-tone-active { border-color:var(--tone-color); background:rgba(255,255,255,0.08); box-shadow:0 0 20px var(--tone-glow), inset 0 0 20px rgba(255,255,255,0.03); animation:cv-tone-pulse 2s ease-in-out infinite; }
.cv-tone-btn.cv-tone-active::before { opacity:0.4; }
.cv-tone-btn.cv-tone-active span:last-child { opacity:1 !important; color:var(--tone-color); }
@keyframes cv-tone-pulse { 0%,100%{ box-shadow:0 0 15px var(--tone-glow), inset 0 0 15px rgba(255,255,255,0.02); } 50%{ box-shadow:0 0 30px var(--tone-glow), inset 0 0 25px rgba(255,255,255,0.05); } }


/* ── Pricing ── */
.cv-pricing-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 16px; }
.cv-price-card { padding: 24px; border-radius: var(--cv-radius-lg); text-align: center; transition: all 0.3s; position: relative; }
.cv-price-card.cv-featured { border-color: var(--cv-accent); background: rgba(124,92,252,0.06); }
.cv-price-level { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--cv-accent); margin-bottom: 8px; }
.cv-price-value { font-family: var(--cv-font-display); font-size: 2rem; font-weight: 900; color: var(--cv-text); }
.cv-price-period { font-size: 12px; color: var(--cv-text-muted); }
.cv-price-cargo { font-size: 13px; color: var(--cv-text-secondary); margin-top: 8px; }
.cv-price-badge { position: absolute; top: -10px; right: -10px; background: linear-gradient(135deg, #f59e0b, #d97706); color: #000; font-size: 10px; font-weight: 800; padding: 4px 10px; border-radius: var(--cv-radius-full); text-transform: uppercase; letter-spacing: 0.05em; }

/* ── QR Section ── */
.cv-qr-wrapper { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center; }
.cv-qr-image { background: #fff; border-radius: 20px; padding: 20px; display: flex; align-items: center; justify-content: center; box-shadow: 0 20px 60px rgba(0,0,0,0.5); max-width: 280px; margin: 0 auto; }
.cv-qr-image img { width: 100%; height: auto; border-radius: 8px; }
.cv-qr-steps { list-style: none; padding: 0; }
.cv-qr-steps li { display: flex; align-items: flex-start; gap: 16px; padding: 14px 0; border-bottom: 1px solid rgba(255,255,255,0.05); }
.cv-qr-step-num { width: 32px; height: 32px; border-radius: 50%; background: var(--cv-accent); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 14px; flex-shrink: 0; }

/* ── Form ── */
.cv-form-container { max-width: 700px; margin: 0 auto; }
.cv-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.cv-form-full { grid-column: 1 / -1; }
.cv-form-group { display: flex; flex-direction: column; gap: 6px; }
.cv-form-label { font-size: 12px; font-weight: 600; color: var(--cv-text-secondary); text-transform: uppercase; letter-spacing: 0.05em; }
.cv-form-label .cv-required { color: var(--cv-danger); }
.cv-form-input, .cv-form-select, .cv-form-textarea { padding: 12px 16px; border-radius: 12px; border: 1px solid var(--cv-border); background: rgba(255,255,255,0.04); color: var(--cv-text); font-size: 14px; font-family: var(--cv-font-sans); outline: none; transition: all 0.2s; width: 100%; }
.cv-form-input:focus, .cv-form-select:focus, .cv-form-textarea:focus { border-color: var(--cv-accent); box-shadow: 0 0 0 3px rgba(124,92,252,0.15); background: rgba(255,255,255,0.06); }
.cv-form-select { cursor: pointer; appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23a8a29e' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 36px; }
.cv-form-select option { background: #1a1a2e; color: #fff; }
.cv-form-textarea { min-height: 80px; resize: vertical; }
.cv-form-radio-group { display: flex; flex-direction: column; gap: 8px; }
.cv-form-radio { display: flex; align-items: center; gap: 10px; padding: 10px 14px; border-radius: 10px; border: 1px solid var(--cv-border); cursor: pointer; transition: all 0.2s; font-size: 13px; }
.cv-form-radio:hover { background: rgba(124,92,252,0.06); border-color: rgba(124,92,252,0.3); }
.cv-form-radio input[type="radio"] { accent-color: var(--cv-accent); width: 16px; height: 16px; }
.cv-form-file { position: relative; }
.cv-form-file-label { display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 24px; border: 2px dashed var(--cv-border); border-radius: 14px; cursor: pointer; transition: all 0.2s; text-align: center; }
.cv-form-file-label:hover { border-color: var(--cv-accent); background: rgba(124,92,252,0.04); }
.cv-form-file input[type="file"] { position: absolute; opacity: 0; width: 0; height: 0; }
.cv-form-submit { width: 100%; padding: 16px; border-radius: var(--cv-radius); font-size: 16px; font-weight: 800; font-family: var(--cv-font-display); color: #fff; background: linear-gradient(135deg, var(--cv-accent), #9F7AFF); border: none; cursor: pointer; transition: all 0.25s; box-shadow: 0 4px 20px rgba(124,92,252,0.35); letter-spacing: 0.02em; }
.cv-form-submit:hover { transform: translateY(-2px); box-shadow: 0 8px 30px rgba(124,92,252,0.5); }
.cv-form-submit:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }

/* ── Login Section ── */
.cv-login-container { max-width: 440px; margin: 0 auto; }
.cv-google-btn { width: 100%; padding: 14px; border-radius: 14px; font-size: 15px; font-weight: 700; color: var(--cv-text); background: rgba(255,255,255,0.06); border: 1px solid var(--cv-border); cursor: pointer; transition: all 0.2s; display: flex; align-items: center; justify-content: center; gap: 12px; }
.cv-google-btn:hover { background: rgba(255,255,255,0.1); border-color: var(--cv-border-hover); transform: translateY(-1px); }
.cv-google-btn img { width: 20px; height: 20px; }
.cv-login-divider { display: flex; align-items: center; gap: 16px; margin: 20px 0; color: var(--cv-text-muted); font-size: 12px; }
.cv-login-divider::before, .cv-login-divider::after { content: ''; flex: 1; height: 1px; background: var(--cv-border); }

/* ── Counter Banner ── */
.cv-counter-banner { display: flex; align-items: center; justify-content: center; gap: 16px; padding: 20px; border-radius: var(--cv-radius); background: linear-gradient(135deg, rgba(16,185,129,0.08), rgba(124,92,252,0.06)); border: 1px solid rgba(16,185,129,0.2); }
.cv-counter-value { font-family: var(--cv-font-display); font-size: 2.5rem; font-weight: 900; }
.cv-counter-label { font-size: 13px; color: var(--cv-text-secondary); text-align: left; }

/* ── Footer ── */
.cv-footer { text-align: center; padding: 40px 24px; color: var(--cv-text-muted); font-size: 12px; border-top: 1px solid rgba(255,255,255,0.05); }
.cv-footer a { color: var(--cv-accent); text-decoration: none; }

/* ── WhatsApp FAB ── */
.cv-wa-fab { position: fixed; bottom: 24px; right: 24px; z-index: 40; width: 56px; height: 56px; border-radius: 50%; background: #25D366; border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 20px rgba(37,211,102,0.4); transition: all 0.2s; text-decoration: none; }
.cv-wa-fab:hover { transform: scale(1.1); box-shadow: 0 6px 30px rgba(37,211,102,0.5); }
.cv-wa-fab svg { width: 28px; height: 28px; fill: #fff; }

/* ── Responsive ── */
@media (max-width: 768px) {
    .cv-stats-row { grid-template-columns: repeat(2, 1fr); }
    .cv-mentor-grid { grid-template-columns: 1fr; }
    .cv-qr-wrapper { grid-template-columns: 1fr; }
    .cv-form-grid { grid-template-columns: 1fr; }
    .cv-hero-title { font-size: 1.75rem; }
    .cv-section { padding: 48px 16px; }
    .cv-nav-link { display: none; }
    .cv-pricing-grid { grid-template-columns: 1fr 1fr; }
    .cv-mentor-sphere { width: 120px; height: 120px; }
    .cv-mentor-feature { padding: 24px; }
    .cv-hero { min-height: auto; padding-top: 100px; padding-bottom: 40px; }
    .cv-hero-content { padding: 0 8px; }
    /* Hero logos stack */
    .cv-hero-content > div:first-child {
        flex-direction: column !important;
        gap: 12px !important;
    }
    .cv-hero-content > div:first-child > div:nth-child(2) { display: none; } /* hide × divider */
    /* Flow diagram 2x2 */
    .cv-section > .cv-container > .cv-slide-up[style*="grid-template-columns:repeat(4"] {
        grid-template-columns: repeat(2, 1fr) !important;
    }
    /* Playlist/Inferno cards stack */
    .cv-section > .cv-container > div[style*="grid-template-columns:1fr 1fr"] {
        grid-template-columns: 1fr !important;
    }
    .cv-benefits-grid { grid-template-columns: 1fr; }
    .cv-benefit-card { padding: 22px; }
    .cv-glass-static[style*="padding:32px"] { padding: 20px !important; }
    .cv-glass-static[style*="padding:28px"] { padding: 20px !important; }
    .cv-nav-inner { padding: 0 16px; height: 60px; }
    .cv-nav-logo img { height: 32px; }
    .cv-counter-banner { flex-direction: column; text-align: center; gap: 8px; padding: 16px; }
    .cv-counter-value { font-size: 2rem; }
    .cv-counter-label { text-align: center; }
    .cv-price-value { font-size: 1.6rem; }
    .cv-qr-image { max-width: 220px; }
    .cv-btn-primary, .cv-btn-secondary { padding: 12px 24px; font-size: 14px; width: 100%; justify-content: center; }
    .cv-hero-buttons { flex-direction: column; align-items: stretch; gap: 10px; }
    .cv-hero-sub { font-size: 0.95rem; margin-bottom: 28px; }
    .cv-form-submit { font-size: 14px; padding: 14px; }
}
@media (max-width: 480px) {
    .cv-pricing-grid { grid-template-columns: 1fr; }
    .cv-stats-row { gap: 8px; }
    .cv-stat-card { padding: 12px 8px; }
    .cv-stat-value { font-size: 1.2rem; }
    .cv-stat-label { font-size: 10px; }
    .cv-hero-title { font-size: 1.5rem; }
    .cv-section-title { font-size: 1.4rem; }
    .cv-form-input, .cv-form-select, .cv-form-textarea { font-size: 16px; padding: 14px 14px; } /* prevent iOS zoom */
    .cv-form-radio { font-size: 14px; padding: 12px; }
    .cv-wa-fab { bottom: 16px; right: 16px; width: 48px; height: 48px; }
    .cv-wa-fab svg { width: 24px; height: 24px; }
}

/* ── Success Toast ── */
.cv-toast { position: fixed; top: 24px; right: 24px; z-index: 100; padding: 16px 24px; border-radius: 14px; background: rgba(16,185,129,0.95); color: #fff; font-weight: 600; font-size: 14px; box-shadow: 0 8px 30px rgba(0,0,0,0.3); transform: translateX(120%); transition: transform 0.4s cubic-bezier(0.4,0,0.2,1); backdrop-filter: blur(8px); }
.cv-toast.cv-show { transform: translateX(0); }
.cv-toast.cv-error { background: rgba(239,68,68,0.95); }

/* ── Loading Modal ── */
.cv-loading-modal { position: fixed; inset: 0; background: rgba(3,7,18,0.85); backdrop-filter: blur(12px); z-index: 9999; display: flex; align-items: center; justify-content: center; opacity: 0; pointer-events: none; transition: opacity 0.4s ease; text-align: center; padding: 20px; }
.cv-loading-modal.cv-active { opacity: 1; pointer-events: auto; }
.cv-loading-content { max-width: 400px; }
.cv-spinner { width: 50px; height: 50px; border: 4px solid rgba(124,92,252,0.2); border-top-color: var(--cv-accent); border-radius: 50%; animation: cv-spin 1s linear infinite; margin: 0 auto 24px; }
@keyframes cv-spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }
.cv-loading-title { font-family: var(--cv-font-display); font-size: 1.5rem; font-weight: 800; margin-bottom: 12px; color: #fff; }
.cv-loading-text { font-size: 15px; color: var(--cv-text-secondary); line-height: 1.6; }
