/* ============================================
   PsikoTest Pro v4 — Professional Clinical UI
   ============================================ */

:root {
    --bg-primary: #060612;
    --bg-secondary: #0c0c24;
    --bg-tertiary: #111130;
    --text-primary: #e4e4f0;
    --text-secondary: #8e8eb8;
    --text-muted: #5c5c8a;
    --accent: #6C63FF;
    --accent2: #00D4AA;
    --accent3: #FF6B9D;
    --warn: #FFB84D;
    --success: #4ADE80;
    --danger: #FF4757;
    --glass-bg: rgba(255,255,255,0.03);
    --glass-border: rgba(255,255,255,0.06);
    --glass-hover: rgba(255,255,255,0.08);
    --font-display: 'Outfit', sans-serif;
    --font-body: 'Inter', sans-serif;
    --font-mono: 'JetBrains Mono', monospace;
    --radius-sm: 8px;
    --radius-md: 12px;
    --radius-lg: 16px;
    --radius-xl: 24px;
    --radius-full: 9999px;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;}
body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;overflow-x:hidden;line-height:1.6;}

/* Particle Canvas */
#particles-canvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none;}

/* ============ TOP BAR ============ */
.top-bar{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(6,6,18,0.85);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--glass-border);padding:0 24px;height:56px;}
.top-bar-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:100%;}
.top-logo{display:flex;align-items:center;gap:10px;}
.logo-mark{width:28px;height:28px;}
.logo-mark svg{width:100%;height:100%;}
.logo-text{font-family:var(--font-display);font-weight:700;font-size:1.05rem;color:var(--text-primary);letter-spacing:-0.3px;}
.pro-badge{font-size:0.55rem;font-weight:700;background:linear-gradient(135deg,var(--accent3),var(--warn));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:2px;vertical-align:super;margin-left:2px;}
.top-nav{display:flex;align-items:center;gap:16px;font-size:0.82rem;}
.nav-item{color:var(--text-muted);cursor:pointer;transition:color 0.2s;font-weight:500;}
.nav-item:hover,.nav-item.active{color:var(--text-primary);}
.nav-divider{color:var(--glass-border);font-size:0.7rem;}
.nav-status{color:var(--accent2);font-size:0.75rem;font-weight:600;font-family:var(--font-mono);}

/* ============ SECTIONS ============ */
.section{display:none;min-height:100vh;padding:80px 20px 40px;position:relative;z-index:1;animation:sectionIn 0.7s ease-out;}
.section.active{display:block;}
#results.active{display:block;}
@keyframes sectionIn{from{opacity:0;transform:translateY(40px);}to{opacity:1;transform:translateY(0);}}
.container{max-width:960px;margin:0 auto;}
.results-container{max-width:1000px;margin:0 auto;}

/* ============ GLASS CARD ============ */
.glass-card{background:var(--glass-bg);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:0 8px 40px rgba(0,0,0,0.3);padding:28px;transition:all 0.3s ease;}
.glass-card:hover{border-color:rgba(255,255,255,0.1);box-shadow:0 12px 56px rgba(0,0,0,0.4);}

/* ============ LANDING ============ */
.landing-layout{display:flex;flex-direction:column;gap:48px;padding-top:40px;}

/* Hero Badge Row */
.hero-badge-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px;}
.clinical-badge{font-size:0.72rem;font-weight:600;padding:5px 14px;background:rgba(108,99,255,0.08);border:1px solid rgba(108,99,255,0.15);border-radius:var(--radius-full);color:var(--accent);letter-spacing:0.3px;}

/* Hero Title */
.hero-title{font-family:var(--font-display);font-size:3.2rem;font-weight:900;line-height:1.15;margin-bottom:20px;letter-spacing:-1px;}
.gradient-text{background:linear-gradient(135deg,var(--accent) 0%,var(--accent2) 60%,var(--accent) 100%);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradientShift 4s ease infinite;}
@keyframes gradientShift{0%,100%{background-position:0% center;}50%{background-position:200% center;}}

.hero-desc{font-size:0.95rem;color:var(--text-secondary);line-height:1.8;max-width:640px;margin-bottom:32px;}

/* Hero Stats */
.hero-stats{display:flex;align-items:center;gap:0;margin-bottom:36px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:20px 0;overflow:hidden;}
.stat-item{flex:1;text-align:center;}
.stat-number{display:block;font-family:var(--font-display);font-size:2rem;font-weight:800;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.stat-label{font-size:0.72rem;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:1px;margin-top:2px;display:block;}
.stat-divider{width:1px;height:40px;background:var(--glass-border);}

/* Hero Buttons */
.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;background:linear-gradient(135deg,var(--accent),#5048e5);color:white;border:none;border-radius:var(--radius-full);font-family:var(--font-body);font-size:0.95rem;font-weight:600;cursor:pointer;transition:all 0.3s;position:relative;overflow:hidden;box-shadow:0 4px 20px rgba(108,99,255,0.3);}
.btn-primary::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,0.15),transparent 60%);opacity:0;transition:opacity 0.3s;}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(108,99,255,0.45);}
.btn-primary:hover::after{opacity:1;}
.btn-primary:disabled{opacity:0.4;cursor:not-allowed;transform:none;box-shadow:none;}
.btn-large{padding:16px 36px;font-size:1.05rem;}

.btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;background:transparent;color:var(--text-primary);border:1px solid var(--glass-border);border-radius:var(--radius-full);font-family:var(--font-body);font-size:0.95rem;font-weight:500;cursor:pointer;transition:all 0.3s;}
.btn-secondary:hover{background:var(--glass-bg);border-color:rgba(255,255,255,0.15);transform:translateY(-2px);}
.btn-secondary:disabled{opacity:0.3;cursor:not-allowed;transform:none;}

.btn-back{display:inline-flex;align-items:center;gap:6px;background:none;border:none;color:var(--text-muted);font-family:var(--font-body);font-size:0.85rem;cursor:pointer;transition:color 0.2s;margin-bottom:20px;}
.btn-back:hover{color:var(--text-primary);}

.hero-note{font-size:0.78rem;color:var(--text-muted);margin-top:16px;}

/* ============ FLOATING CATEGORY CARDS ============ */
.category-showcase{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:12px;}

.float-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:20px 14px;text-align:center;cursor:default;transition:all 0.4s cubic-bezier(0.34,1.56,0.64,1);position:relative;overflow:hidden;}
.float-card::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,rgba(108,99,255,0.08),transparent 70%);opacity:0;transition:opacity 0.4s;}
.float-card:hover{transform:translateY(-8px) scale(1.03);border-color:rgba(108,99,255,0.3);box-shadow:0 20px 40px rgba(0,0,0,0.3);}
.float-card:hover::before{opacity:1;}
.fc-icon{display:block;font-size:2.2rem;margin-bottom:8px;animation:iconFloat 6s ease-in-out infinite;position:relative;z-index:1;}
.fc-label{font-family:var(--font-display);font-size:0.82rem;font-weight:600;line-height:1.4;color:var(--text-primary);position:relative;z-index:1;}
.fc-label small{font-size:0.65rem;font-weight:400;color:var(--text-muted);display:block;margin-top:2px;}

/* Each card floats at different timing */
.fc-1 .fc-icon{animation-delay:0s;}
.fc-2 .fc-icon{animation-delay:-0.8s;}
.fc-3 .fc-icon{animation-delay:-1.6s;}
.fc-4 .fc-icon{animation-delay:-2.4s;}
.fc-5 .fc-icon{animation-delay:-3.2s;}
.fc-6 .fc-icon{animation-delay:-4s;}
.fc-7 .fc-icon{animation-delay:-4.8s;}
.fc-8 .fc-icon{animation-delay:-5.6s;}

@keyframes iconFloat{
    0%,100%{transform:translateY(0) rotate(0deg);}
    25%{transform:translateY(-8px) rotate(3deg);}
    50%{transform:translateY(-3px) rotate(-2deg);}
    75%{transform:translateY(-10px) rotate(1deg);}
}

/* Pulsing glow on hover */
.float-card:hover .fc-icon{animation:iconPulse 1.5s ease-in-out infinite;}
@keyframes iconPulse{
    0%,100%{transform:scale(1);filter:drop-shadow(0 0 0px transparent);}
    50%{transform:scale(1.15);filter:drop-shadow(0 0 12px rgba(108,99,255,0.5));}
}

/* ============ METHODOLOGY ============ */
.methodology-section{margin-top:8px;}
.method-title{font-family:var(--font-display);font-size:1.1rem;font-weight:700;display:flex;align-items:center;gap:8px;margin-bottom:24px;color:var(--text-primary);}
.method-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;}
.method-item{padding:20px;background:rgba(255,255,255,0.02);border:1px solid rgba(255,255,255,0.04);border-radius:var(--radius-md);transition:all 0.3s;}
.method-item:hover{border-color:rgba(108,99,255,0.15);background:rgba(108,99,255,0.03);}
.method-num{font-family:var(--font-mono);font-size:0.7rem;font-weight:600;color:var(--accent);margin-bottom:8px;letter-spacing:1px;}
.method-item h4{font-family:var(--font-display);font-size:0.92rem;font-weight:600;margin-bottom:6px;}
.method-item p{font-size:0.8rem;color:var(--text-muted);line-height:1.6;}

/* ============ DEMOGRAPHICS ============ */
.section-header{text-align:center;margin-bottom:28px;}
.section-header h2{font-family:var(--font-display);font-size:1.8rem;font-weight:700;margin-bottom:8px;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.section-header p{color:var(--text-secondary);font-size:0.9rem;}
.demographics-form{max-width:520px;margin:0 auto;}
.form-group{margin-bottom:24px;}
.form-group>label{display:block;font-weight:500;margin-bottom:8px;color:var(--text-primary);font-size:0.9rem;}
.select-wrapper{position:relative;}
.select-wrapper::after{content:'▾';position:absolute;right:16px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;}
.select-wrapper select{width:100%;padding:12px 18px;background:rgba(255,255,255,0.03);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-body);font-size:0.9rem;appearance:none;cursor:pointer;transition:all 0.2s;}
.select-wrapper select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(108,99,255,0.12);}
.select-wrapper select option{background:var(--bg-secondary);color:var(--text-primary);}
.radio-group{display:flex;flex-direction:column;gap:8px;}
.radio-option{display:flex;align-items:center;gap:12px;padding:12px 18px;background:rgba(255,255,255,0.02);border:1px solid var(--glass-border);border-radius:var(--radius-md);cursor:pointer;transition:all 0.2s;font-size:0.9rem;}
.radio-option:hover{background:rgba(108,99,255,0.04);border-color:rgba(108,99,255,0.15);}
.radio-option input[type="radio"]{display:none;}
.radio-custom{width:18px;height:18px;border-radius:50%;border:2px solid var(--text-muted);position:relative;transition:all 0.2s;flex-shrink:0;}
.radio-option input:checked+.radio-custom{border-color:var(--accent);}
.radio-option input:checked+.radio-custom::after{content:'';position:absolute;top:50%;left:50%;width:8px;height:8px;background:var(--accent);border-radius:50%;transform:translate(-50%,-50%);animation:popIn 0.2s ease;}
@keyframes popIn{from{transform:translate(-50%,-50%) scale(0);}to{transform:translate(-50%,-50%) scale(1);}}

/* ============ PROGRESS ============ */
.progress-container{margin-bottom:24px;}
.progress-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;}
.progress-category{font-family:var(--font-display);font-weight:600;font-size:0.88rem;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.progress-count{font-size:0.8rem;color:var(--text-muted);font-weight:500;font-family:var(--font-mono);}
.progress-bar{height:5px;background:rgba(255,255,255,0.05);border-radius:var(--radius-full);overflow:hidden;margin-bottom:12px;}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:var(--radius-full);width:0%;transition:width 0.5s cubic-bezier(0.4,0,0.2,1);position:relative;}
.progress-fill::after{content:'';position:absolute;right:0;top:0;width:24px;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.4));border-radius:var(--radius-full);}
.progress-sections{display:flex;justify-content:space-between;padding:0 2px;}
.section-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.06);border:1.5px solid rgba(255,255,255,0.08);transition:all 0.3s;}
.section-dot.active{background:var(--accent);border-color:var(--accent);box-shadow:0 0 8px rgba(108,99,255,0.5);}
.section-dot.completed{background:var(--success);border-color:var(--success);box-shadow:0 0 6px rgba(74,222,128,0.3);}

/* ============ QUESTION CARD ============ */
.question-card{margin-bottom:24px;animation:cardIn 0.4s ease-out;}
@keyframes cardIn{from{opacity:0;transform:translateX(30px);}to{opacity:1;transform:translateX(0);}}
.question-number{font-family:var(--font-mono);font-size:0.72rem;font-weight:600;text-transform:uppercase;letter-spacing:2px;color:var(--accent);margin-bottom:12px;}
.question-text{font-family:var(--font-display);font-size:1.25rem;font-weight:600;line-height:1.55;margin-bottom:12px;color:var(--text-primary);}
.question-context{margin-bottom:24px;}
.context-badge{display:inline-block;padding:4px 14px;background:rgba(108,99,255,0.08);border:1px solid rgba(108,99,255,0.15);border-radius:var(--radius-full);font-size:0.7rem;color:var(--accent);font-weight:500;font-family:var(--font-mono);}

.answers-grid{display:flex;flex-direction:column;gap:8px;}
.answer-option{display:flex;align-items:center;gap:14px;padding:14px 20px;background:rgba(255,255,255,0.02);border:1px solid var(--glass-border);border-radius:var(--radius-md);cursor:pointer;transition:all 0.25s;font-size:0.92rem;position:relative;}
.answer-option:hover{border-color:rgba(108,99,255,0.25);transform:translateX(4px);background:rgba(108,99,255,0.03);}
.answer-option.selected{border-color:var(--accent);background:rgba(108,99,255,0.08);}
.answer-option .answer-indicator{width:20px;height:20px;border-radius:50%;border:2px solid var(--text-muted);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all 0.2s;}
.answer-option.selected .answer-indicator{border-color:var(--accent);background:var(--accent);}
.answer-option.selected .answer-indicator::after{content:'✓';color:white;font-size:0.65rem;font-weight:700;}
.answer-option .answer-text{font-weight:400;transition:all 0.2s;}
.answer-option.selected .answer-text{font-weight:500;color:var(--text-primary);}

.question-nav{display:flex;justify-content:space-between;align-items:center;}

/* ============ RESULTS ============ */
.results-header{text-align:center;margin-bottom:36px;}
.results-badge{display:inline-block;font-family:var(--font-mono);font-size:0.7rem;font-weight:600;letter-spacing:3px;padding:6px 18px;background:rgba(108,99,255,0.1);border:1px solid rgba(108,99,255,0.2);border-radius:var(--radius-full);color:var(--accent);margin-bottom:16px;}
.results-title{font-family:var(--font-display);font-size:2rem;font-weight:800;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px;}
.results-subtitle{color:var(--text-secondary);font-size:0.9rem;}
.results-date{font-family:var(--font-mono);font-size:0.75rem;color:var(--text-muted);margin-top:8px;}

/* Risk Dashboard */
.risk-dashboard{margin-bottom:28px;animation:fadeUp 0.6s ease-out 0.1s both;}
.risk-dashboard-header{margin-bottom:28px;}
.risk-dashboard-header h3{font-family:var(--font-display);font-size:1.2rem;font-weight:700;display:flex;align-items:center;gap:8px;margin-bottom:4px;}
.risk-dashboard-header p{font-size:0.8rem;color:var(--text-muted);}

.risk-bars{display:flex;flex-direction:column;gap:18px;}
.risk-item{animation:riskIn 0.5s ease-out both;}
@keyframes riskIn{from{opacity:0;transform:translateX(-20px);}to{opacity:1;transform:translateX(0);}}
.risk-item:nth-child(1){animation-delay:0.2s;}.risk-item:nth-child(2){animation-delay:0.28s;}.risk-item:nth-child(3){animation-delay:0.36s;}.risk-item:nth-child(4){animation-delay:0.44s;}.risk-item:nth-child(5){animation-delay:0.52s;}.risk-item:nth-child(6){animation-delay:0.6s;}.risk-item:nth-child(7){animation-delay:0.68s;}.risk-item:nth-child(8){animation-delay:0.76s;}.risk-item:nth-child(9){animation-delay:0.84s;}.risk-item:nth-child(10){animation-delay:0.92s;}.risk-item:nth-child(11){animation-delay:1.0s;}.risk-item:nth-child(12){animation-delay:1.08s;}.risk-item:nth-child(13){animation-delay:1.16s;}

.risk-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px;}
.risk-name{font-family:var(--font-display);font-size:0.85rem;font-weight:600;display:flex;align-items:center;gap:8px;}
.risk-name .risk-icon{font-size:1rem;}
.risk-percentage{font-family:var(--font-mono);font-size:0.95rem;font-weight:700;}
.risk-bar-track{height:10px;background:rgba(255,255,255,0.04);border-radius:var(--radius-full);overflow:hidden;}
.risk-bar-fill{height:100%;border-radius:var(--radius-full);width:0%;transition:width 1.5s cubic-bezier(0.4,0,0.2,1);position:relative;}
.risk-bar-fill::after{content:'';position:absolute;right:0;top:0;width:20px;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.3));border-radius:var(--radius-full);}
.risk-bar-fill.risk-low{background:linear-gradient(90deg,#4ADE80,#34D399);}
.risk-bar-fill.risk-mild{background:linear-gradient(90deg,#FBBF24,#F59E0B);}
.risk-bar-fill.risk-moderate{background:linear-gradient(90deg,#FB923C,#F97316);}
.risk-bar-fill.risk-high{background:linear-gradient(90deg,#F87171,#EF4444);}
.risk-bar-fill.risk-severe{background:linear-gradient(90deg,#EF4444,#DC2626);}
.risk-sublabel{font-size:0.7rem;color:var(--text-muted);margin-top:3px;font-family:var(--font-mono);}

.pct-low{color:#4ADE80;}.pct-mild{color:#FBBF24;}.pct-moderate{color:#FB923C;}.pct-high{color:#F87171;}.pct-severe{color:#EF4444;}

/* Pulse animation for high risk bars */
.risk-bar-fill.risk-high,.risk-bar-fill.risk-severe{animation:barPulse 2s ease-in-out infinite;}
@keyframes barPulse{0%,100%{filter:brightness(1);}50%{filter:brightness(1.3);}}

/* Psychologist Card */
.psychologist-card{margin-bottom:28px;animation:fadeUp 0.6s ease-out 0.3s both;}
@keyframes fadeUp{from{opacity:0;transform:translateY(30px);}to{opacity:1;transform:translateY(0);}}

.verdict-banner{display:flex;align-items:center;gap:20px;padding:20px;border-radius:var(--radius-md);margin-bottom:20px;}
.verdict-banner.verdict-go{background:linear-gradient(135deg,rgba(239,68,68,0.12),rgba(255,107,157,0.06));border:1px solid rgba(239,68,68,0.2);}
.verdict-banner.verdict-consider{background:linear-gradient(135deg,rgba(251,191,36,0.12),rgba(245,158,11,0.06));border:1px solid rgba(251,191,36,0.2);}
.verdict-banner.verdict-ok{background:linear-gradient(135deg,rgba(74,222,128,0.12),rgba(52,211,153,0.06));border:1px solid rgba(74,222,128,0.2);}
.verdict-icon{font-size:2.8rem;flex-shrink:0;animation:verdictPulse 2s ease-in-out infinite;}
@keyframes verdictPulse{0%,100%{transform:scale(1);}50%{transform:scale(1.1);}}
.verdict-text h3{font-family:var(--font-display);font-size:1.2rem;font-weight:700;margin-bottom:4px;}
.verdict-banner.verdict-go .verdict-text h3{color:#F87171;}
.verdict-banner.verdict-consider .verdict-text h3{color:#FBBF24;}
.verdict-banner.verdict-ok .verdict-text h3{color:var(--success);}
.verdict-text p{font-size:0.88rem;color:var(--text-secondary);line-height:1.6;}

.verdict-reasons{display:flex;flex-direction:column;gap:8px;}
.verdict-reason{display:flex;align-items:flex-start;gap:8px;font-size:0.85rem;color:var(--text-secondary);padding:10px 14px;background:rgba(255,255,255,0.02);border-radius:var(--radius-sm);border-left:3px solid var(--accent);line-height:1.5;}
.verdict-reason .reason-icon{flex-shrink:0;margin-top:1px;}

.verdict-contact{margin-top:20px;padding:14px 20px;background:rgba(108,99,255,0.06);border:1px solid rgba(108,99,255,0.12);border-radius:var(--radius-md);font-size:0.82rem;color:var(--text-secondary);line-height:1.7;}
.verdict-contact strong{color:var(--accent);}

/* Results Grid */
.results-section-title{font-family:var(--font-display);font-size:1.05rem;font-weight:600;color:var(--text-muted);margin-bottom:20px;padding-bottom:8px;border-bottom:1px solid var(--glass-border);}
.results-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:28px;}
.result-card{text-align:center;animation:fadeUp 0.5s ease-out both;}
.result-card-wide{grid-column:1/-1;}
.result-header{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:16px;flex-wrap:wrap;}
.result-icon{font-size:1.3rem;}
.result-header h3{font-family:var(--font-display);font-size:0.95rem;font-weight:600;}
.result-scale{font-family:var(--font-mono);font-size:0.6rem;padding:2px 8px;background:rgba(108,99,255,0.08);border:1px solid rgba(108,99,255,0.15);border-radius:var(--radius-full);color:var(--accent);}

.gauge-container{position:relative;width:100px;height:100px;margin:0 auto 12px;}
.gauge{width:100%;height:100%;transform:rotate(-90deg);}
.gauge-bg{fill:none;stroke:rgba(255,255,255,0.04);stroke-width:7;}
.gauge-fill{fill:none;stroke-width:7;stroke-linecap:round;stroke-dasharray:326.73;stroke-dashoffset:326.73;transition:stroke-dashoffset 1.5s cubic-bezier(0.4,0,0.2,1);}
.gauge-value{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-display);font-size:1.4rem;font-weight:700;}

.result-level{font-family:var(--font-display);font-size:0.85rem;font-weight:600;margin-bottom:6px;padding:3px 14px;border-radius:var(--radius-full);display:inline-block;}
.result-level.level-low{color:var(--success);background:rgba(74,222,128,0.08);}
.result-level.level-mild{color:var(--warn);background:rgba(255,184,77,0.08);}
.result-level.level-moderate{color:#FF8C42;background:rgba(255,140,66,0.08);}
.result-level.level-high{color:var(--danger);background:rgba(255,71,87,0.08);}
.result-level.level-good{color:var(--success);background:rgba(74,222,128,0.08);}
.result-desc{font-size:0.78rem;color:var(--text-muted);line-height:1.6;max-width:300px;margin:0 auto;}

/* Recommendation */
.recommendation{margin-bottom:28px;border-left:3px solid var(--accent);}
.rec-header{display:flex;align-items:center;gap:8px;margin-bottom:14px;color:var(--accent);}
.rec-header h3{font-family:var(--font-display);font-size:1.05rem;font-weight:600;}
.rec-text{font-size:0.88rem;color:var(--text-secondary);line-height:1.8;}
.rec-text ul{list-style:none;margin-top:14px;}
.rec-text ul li{padding:6px 0 6px 20px;position:relative;}
.rec-text ul li::before{content:'→';position:absolute;left:0;color:var(--accent);font-weight:600;}

/* Disclaimer */
.disclaimer{margin-bottom:28px;border-left:3px solid var(--warn);}
.disclaimer h4{font-family:var(--font-display);margin-bottom:8px;font-size:0.95rem;color:var(--warn);}
.disclaimer p{font-size:0.82rem;color:var(--text-secondary);line-height:1.7;}
.disclaimer-sub{margin-top:8px;font-size:0.78rem!important;color:var(--text-muted)!important;}

.results-actions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;}

/* ============ RESPONSIVE ============ */
@media(max-width:768px){
    .hero-title{font-size:2.2rem;}
    .category-showcase{grid-template-columns:repeat(2,1fr);}
    .method-grid{grid-template-columns:1fr;}
    .results-grid{grid-template-columns:1fr;}
    .result-card-wide{grid-column:1;}
    .hero-stats{flex-wrap:wrap;gap:0;}
    .stat-divider{display:none;}
    .stat-item{min-width:50%;padding:10px 0;}
    .verdict-banner{flex-direction:column;text-align:center;}
}
@media(max-width:480px){
    .hero-title{font-size:1.8rem;}
    .section{padding:70px 14px 30px;}
    .glass-card{padding:20px;}
    .category-showcase{grid-template-columns:1fr 1fr;}
    .question-nav{flex-direction:column;gap:10px;}
    .question-nav button{width:100%;justify-content:center;}
    .hero-badge-row{justify-content:center;}
}

/* Scrollbar */
::-webkit-scrollbar{width:6px;}
::-webkit-scrollbar-track{background:var(--bg-primary);}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.08);border-radius:var(--radius-full);}

/* Confetti */
.confetti-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:999;overflow:hidden;}
.confetti{position:absolute;width:8px;height:8px;border-radius:2px;animation:confettiFall 3s ease-in forwards;}
@keyframes confettiFall{0%{transform:translateY(-10vh) rotate(0);opacity:1;}100%{transform:translateY(110vh) rotate(720deg);opacity:0;}}

/* ============ START BUTTON GLOW (Gemini-style) ============ */
.btn-shimmer{position:relative;overflow:hidden;}
.btn-star{margin-left:8px;font-size:1.1rem;display:inline-block;}

/* On Click Animation */
.btn-shimmer.clicked{pointer-events:none;}
.btn-shimmer.clicked::after{
    content:'';
    position:absolute;
    top:50%;
    left:50%;
    width:0;
    height:0;
    background:radial-gradient(circle, rgba(255,255,255,0.8) 0%, transparent 70%);
    transform:translate(-50%, -50%);
    animation:clickFlash 0.6s ease-out forwards;
    border-radius:50%;
    z-index:1;
}
@keyframes clickFlash{
    0%{width:0;height:0;opacity:1;}
    50%{width:300px;height:300px;opacity:0.8;}
    100%{width:600px;height:600px;opacity:0;}
}

.btn-shimmer.clicked .btn-star{
    animation:starPop 0.6s ease-out forwards;
    position:relative;
    z-index:2;
}
@keyframes starPop{
    0%{transform:scale(1) rotate(0deg);opacity:1;}
    50%{transform:scale(5) rotate(180deg);opacity:1;}
    100%{transform:scale(10) rotate(360deg);opacity:0;}
}

/* ============ ANSWER SHAKE ============ */
.answer-option.shake{animation:answerShake 0.35s ease;}
@keyframes answerShake{0%{transform:translateX(5px);}20%{transform:translateX(-4px);}40%{transform:translateX(3px);}60%{transform:translateX(-2px);}80%{transform:translateX(1px);}100%{transform:translateX(0);}}

/* ============ SLIDE TRANSITIONS ============ */
@keyframes slideOutLeft{from{opacity:1;transform:translateX(0);}to{opacity:0;transform:translateX(-70px);}}
@keyframes slideOutRight{from{opacity:1;transform:translateX(0);}to{opacity:0;transform:translateX(70px);}}
@keyframes slideInLeft{from{opacity:0;transform:translateX(-70px);}to{opacity:1;transform:translateX(0);}}
@keyframes slideInRight{from{opacity:0;transform:translateX(70px);}to{opacity:1;transform:translateX(0);}}

/* ============ SPLASH SCREEN (GROK STYLE) ============ */
.splash-screen {
    position: fixed;
    inset: 0;
    background: #060612; /* Match primary bg */
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity 0.8s ease-in-out, visibility 0.8s;
    visibility: hidden;
    opacity: 0;
}
.splash-screen.active {
    visibility: visible;
    opacity: 1;
}

.splash-content {
    font-family: var(--font-mono);
    font-size: 2rem;
    font-weight: 500;
    color: var(--accent);
    display: flex;
    align-items: center;
    gap: 8px;
}
.splash-content .bracket {
    color: var(--text-muted);
    font-weight: 300;
}
.splash-content .cursor {
    display: inline-block;
    width: 10px;
    height: 1.2em;
    background-color: var(--accent);
    animation: blink 1s step-end infinite;
    vertical-align: middle;
}
@keyframes blink {
    0%, 100% { opacity: 1; }
    50% { opacity: 0; }
}

/* ============ AUTH SCREEN ============ */
.auth-screen {
    position: fixed;
    inset: 0;
    background: radial-gradient(circle at center, #0c0c24 0%, #060612 100%);
    z-index: 9998;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity 0.5s, visibility 0.5s;
    visibility: hidden;
    opacity: 0;
}
.auth-screen.active {
    visibility: visible;
    opacity: 1;
}

.auth-container {
    width: 100%;
    max-width: 420px;
    padding: 40px;
    position: relative;
    overflow: hidden;
}
.auth-logo {
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-display);
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: 30px;
}

.auth-form {
    display: none;
    animation: fadeUp 0.4s ease-out forwards;
}
.auth-form.active {
    display: block;
}
.auth-form h2 {
    font-family: var(--font-display);
    font-size: 1.8rem;
    margin-bottom: 8px;
    color: var(--text-primary);
}
.auth-form p {
    color: var(--text-muted);
    font-size: 0.9rem;
    margin-bottom: 24px;
}
.auth-form .form-group {
    margin-bottom: 20px;
}
.auth-form input {
    width: 100%;
    padding: 14px 16px;
    background: rgba(255,255,255,0.03);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-md);
    color: white;
    font-family: var(--font-body);
    font-size: 1rem;
    transition: all 0.2s;
}
.auth-form input:focus {
    outline: none;
    border-color: var(--accent);
    background: rgba(108,99,255,0.05);
}
.auth-error {
    color: var(--danger);
    font-size: 0.85rem;
    margin-bottom: 16px;
    min-height: 20px;
}
.auth-switch {
    margin-top: 24px;
    text-align: center;
    font-size: 0.9rem;
    color: var(--text-muted);
}
.auth-switch span {
    color: var(--accent);
    cursor: pointer;
    font-weight: 600;
}
.auth-switch span:hover {
    text-decoration: underline;
}

/* Update main app display to allow override */
#main-app.active {
    display: block !important;
    opacity: 1 !important;
}
/* ============ AI ASSISTANT CHAT UI ============ */
.ai-fab {
    position: fixed;
    bottom: 30px;
    right: 30px;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background: linear-gradient(135deg, #6C63FF, #00D4AA);
    color: white;
    font-size: 1.8rem;
    border: none;
    box-shadow: 0 10px 25px rgba(108, 99, 255, 0.4);
    cursor: pointer;
    z-index: 1000;
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    display: flex;
    align-items: center;
    justify-content: center;
}
.ai-fab:hover { transform: scale(1.1); }
.ai-fab.hidden { transform: scale(0); opacity: 0; pointer-events: none; }

.ai-chat-container {
    position: fixed;
    bottom: 30px;
    right: 30px;
    width: 380px;
    max-width: calc(100vw - 40px);
    height: 550px;
    max-height: calc(100vh - 40px);
    background: rgba(15, 23, 42, 0.95);
    backdrop-filter: blur(20px);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 20px;
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.5);
    z-index: 1001;
    display: flex;
    flex-direction: column;
    transform: translateY(20px) scale(0.9);
    opacity: 0;
    pointer-events: none;
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    overflow: hidden;
}
.ai-chat-container.open {
    transform: translateY(0) scale(1);
    opacity: 1;
    pointer-events: all;
}

.ai-chat-header {
    padding: 15px 20px;
    background: rgba(255, 255, 255, 0.05);
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    display: flex;
    align-items: center;
    gap: 15px;
}
.ai-avatar {
    width: 40px;
    height: 40px;
    background: linear-gradient(135deg, #6C63FF, #00D4AA);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
}
.ai-title {
    flex: 1;
    font-weight: 600;
    font-size: 1.1rem;
}
.ai-close-btn {
    background: none;
    border: none;
    color: var(--text-muted);
    font-size: 1.2rem;
    cursor: pointer;
    transition: color 0.2s;
}
.ai-close-btn:hover { color: white; }

.ai-chat-body {
    flex: 1;
    padding: 20px;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 15px;
    scroll-behavior: smooth;
}
.ai-msg {
    max-width: 85%;
    padding: 12px 16px;
    border-radius: 15px;
    font-size: 0.95rem;
    line-height: 1.5;
    animation: slideInUp 0.3s ease;
}
.ai-msg.user {
    align-self: flex-end;
    background: var(--primary);
    color: white;
    border-bottom-right-radius: 5px;
}
.ai-msg:not(.user) {
    align-self: flex-start;
    background: rgba(255, 255, 255, 0.1);
    border-bottom-left-radius: 5px;
    border: 1px solid rgba(255, 255, 255, 0.05);
}
.ai-msg strong { color: var(--accent); }

.ai-chat-input {
    padding: 15px;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    display: flex;
    gap: 10px;
    background: rgba(0, 0, 0, 0.2);
}
.ai-chat-input input {
    flex: 1;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 10px;
    padding: 10px 15px;
    color: white;
    font-family: inherit;
    font-size: 0.95rem;
}
.ai-chat-input input:focus { outline: none; border-color: var(--primary); }
.ai-chat-input button {
    background: var(--primary);
    color: white;
    border: none;
    border-radius: 10px;
    padding: 0 20px;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.2s;
}
.ai-chat-input button:hover { background: #5b54d6; }

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

/* SPACE TIME FABRIC GRID (Animated Login Background) */
.space-time-bg {
    position: absolute;
    inset: -50%;
    background-image: 
        linear-gradient(rgba(108, 99, 255, 0.4) 1px, transparent 1px),
        linear-gradient(90deg, rgba(108, 99, 255, 0.4) 1px, transparent 1px);
    background-size: 50px 50px;
    transform: perspective(600px) rotateX(60deg) translateY(0px) translateZ(-200px);
    animation: spaceGrid 6s linear infinite;
    z-index: 0;
}
.space-time-bg::after {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at center, transparent 0%, #060612 60%);
}
@keyframes spaceGrid {
    0% { transform: perspective(600px) rotateX(60deg) translateY(0px) translateZ(-200px); }
    100% { transform: perspective(600px) rotateX(60deg) translateY(50px) translateZ(-200px); }
}

/* ============ FLUID UI & HOVER EFFECTS ============ */
html { scroll-behavior: smooth; }
.btn-primary, .btn-secondary, .start-btn { 
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1); 
}
.btn-primary:hover, .start-btn:hover { 
    transform: translateY(-3px) scale(1.02); 
    box-shadow: 0 8px 25px rgba(108, 99, 255, 0.4); 
}
.btn-secondary:hover { 
    transform: translateY(-2px); 
    background: rgba(255, 255, 255, 0.1); 
}
.float-card { 
    transition: all 0.4s cubic-bezier(0.25, 0.8, 0.25, 1); 
}
.float-card:hover { 
    transform: translateY(-8px) scale(1.03); 
    box-shadow: 0 15px 35px rgba(108, 99, 255, 0.2); 
    border-color: rgba(108, 99, 255, 0.5); 
    background: rgba(255, 255, 255, 0.05);
}
.nav-item { 
    transition: color 0.3s ease, text-shadow 0.3s ease; 
}
.nav-item:hover:not(.active) { 
    color: white; 
    text-shadow: 0 0 10px rgba(108,99,255,0.5); 
}

/* ============ NEW ANIMATIONS & FANCY RADIOS ============ */
.btn-star {
    display: inline-block;
    animation: starSpin 4s infinite ease-in-out;
    transform-origin: center center;
}
@keyframes starSpin {
    0%, 70% { transform: rotate(0deg); }
    80% { transform: rotate(-25deg) scale(1.15); }
    90% { transform: rotate(25deg) scale(1.15); }
    100% { transform: rotate(0deg); }
}

.fancy-radio-group {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 10px;
}
.fancy-radio {
    flex: 1;
    min-width: 100px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 12px;
    padding: 16px 12px;
    text-align: center;
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
    display: flex;
    justify-content: center;
    align-items: center;
}
.fancy-radio:hover {
    background: rgba(255,255,255,0.08);
    transform: translateY(-2px);
}
.fancy-radio input {
    display: none;
}
.fancy-radio:has(input:checked) {
    background: rgba(108, 99, 255, 0.2);
    border-color: var(--accent);
    box-shadow: 0 0 20px rgba(108, 99, 255, 0.3);
    color: white;
    transform: translateY(-4px) scale(1.02);
}
/* ============ MAGIC BUTTON ANIMATIONS ============ */
.magic-btn {
    position: relative;
    overflow: hidden;
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}
.magic-btn.clicked {
    animation: magicPulse 0.8s ease-out forwards;
}
.magic-btn.clicked::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 300%;
    height: 300%;
    background: conic-gradient(from 0deg, #ff4757, #fbbf24, #00D4AA, #6C63FF, #ff4757);
    transform: translate(-50%, -50%) scale(0);
    border-radius: 50%;
    animation: rainbowBurst 0.8s ease-out forwards;
    z-index: 0;
    opacity: 0.8;
}
.magic-btn.clicked > span {
    position: relative;
    z-index: 1;
    color: white !important;
}
.magic-btn.clicked .btn-star {
    animation: starGrowSpin 0.8s ease-out forwards;
    display: inline-block;
}
@keyframes magicPulse {
    0% { transform: scale(1); box-shadow: 0 0 20px rgba(108,99,255,0.5); }
    50% { transform: scale(1.1); box-shadow: 0 0 50px rgba(0,212,170,0.8), 0 0 100px rgba(108,99,255,0.8); }
    100% { transform: scale(1); box-shadow: 0 0 0 rgba(108,99,255,0); }
}
@keyframes rainbowBurst {
    0% { transform: translate(-50%, -50%) scale(0) rotate(0deg); opacity: 1; }
    100% { transform: translate(-50%, -50%) scale(1) rotate(360deg); opacity: 0; }
}
@keyframes starGrowSpin {
    0% { transform: scale(1) rotate(0deg); color: inherit; text-shadow: none; }
    50% { transform: scale(3) rotate(180deg); color: #fbbf24; text-shadow: 0 0 20px #fbbf24; }
    100% { transform: scale(0) rotate(360deg); opacity: 0; }
}
/* ========================================= */
/* CINEMATIC ENVELOPE ANIMATION              */
/* ========================================= */

.cinematic-overlay {
    position: fixed;
    top: 0; left: 0; width: 100vw; height: 100vh;
    pointer-events: none;
    z-index: 9999;
}

.glowing-orb {
    position: absolute;
    width: 20px;
    height: 20px;
    background: radial-gradient(circle, #fff 20%, #00d4aa 60%, rgba(0,212,170,0) 100%);
    border-radius: 50%;
    box-shadow: 0 0 20px #00d4aa, 0 0 40px #00d4aa;
    will-change: transform, opacity, left, top;
    transition: all 0.6s cubic-bezier(0.25, 1, 0.5, 1);
    z-index: 10000;
}

.magic-star {
    position: absolute;
    font-size: 30px;
    color: #fbbf24;
    text-shadow: 0 0 20px #fbbf24;
    will-change: transform, opacity;
    animation: starPulse 1s infinite alternate;
    z-index: 10000;
}

@keyframes starPulse {
    from { transform: scale(1) rotate(0deg); }
    to { transform: scale(1.5) rotate(20deg); }
}

.envelope-wrapper {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%) scale(0);
    width: 120px;
    height: 80px;
    perspective: 1000px;
    will-change: transform, opacity;
    z-index: 9998;
}

.envelope {
    width: 100%;
    height: 100%;
    background: #e2e8f0;
    border-radius: 4px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.5);
    position: relative;
    transform-style: preserve-3d;
}

/* Envelope Flap */
.envelope::before {
    content: '';
    position: absolute;
    top: 0; left: 0;
    width: 0; height: 0;
    border-left: 60px solid transparent;
    border-right: 60px solid transparent;
    border-top: 45px solid #cbd5e1;
    transform-origin: top;
    transition: transform 0.4s ease-in-out;
    z-index: 3;
}

/* Envelope body shapes to make it look realistic */
.envelope::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0;
    width: 0; height: 0;
    border-left: 60px solid transparent;
    border-right: 60px solid transparent;
    border-bottom: 45px solid #f8fafc;
    z-index: 2;
}

/* Envelope Open State */
.envelope-wrapper.open .envelope::before {
    transform: rotateX(180deg);
}

@keyframes envelopeAppear {
    0% { transform: translate(-50%, -50%) scale(0); opacity: 0; }
    50% { transform: translate(-50%, -50%) scale(1.2); opacity: 1; }
    100% { transform: translate(-50%, -50%) scale(1); opacity: 1; }
}

@keyframes envelopeDrop {
    0% { transform: translate(-50%, -50%) scale(1); opacity: 1; }
    100% { transform: translate(-50%, 150vh) scale(0.8) rotate(15deg); opacity: 0; }
}

@keyframes envelopeDropFromTop {
    0% { transform: translate(-50%, -150vh) scale(0.8) rotate(-15deg); opacity: 0; }
    80% { transform: translate(-50%, -50%) scale(1.1) rotate(5deg); opacity: 1; }
    100% { transform: translate(-50%, -50%) scale(1) rotate(0deg); opacity: 1; }
}

@keyframes envelopeShake {
    0%, 100% { transform: translate(-50%, -50%) rotate(0deg); }
    25% { transform: translate(-50%, -50%) rotate(-5deg); }
    75% { transform: translate(-50%, -50%) rotate(5deg); }
}

/* We hide the option temporarily if it's the "ghost" target */
.answer-option.ghost-hole {
    opacity: 0 !important;
    visibility: hidden;
}
/* ========================================= */
/* TITAN CINEMATIC ENVELOPE V2               */
/* ========================================= */

.cinematic-overlay {
    position: fixed;
    top: 0; left: 0; width: 100vw; height: 100vh;
    pointer-events: none;
    z-index: 9999;
}

.glowing-orb {
    position: absolute;
    width: 24px;
    height: 24px;
    background: radial-gradient(circle, #ffffff 20%, #ff00ff 60%, rgba(255,0,255,0) 100%);
    border-radius: 50%;
    box-shadow: 0 0 30px #ff00ff, 0 0 60px #00ffff;
    will-change: transform, opacity, left, top;
    transition: all 0.8s cubic-bezier(0.25, 1, 0.5, 1);
    z-index: 10000;
}

.magic-star {
    position: absolute;
    font-size: 36px;
    color: #00ffff;
    text-shadow: 0 0 30px #00ffff, 0 0 60px #ff00ff;
    will-change: transform, opacity;
    animation: starPulse 1s infinite alternate;
    z-index: 10000;
}

@keyframes starPulse {
    from { transform: scale(1) rotate(0deg); }
    to { transform: scale(1.8) rotate(45deg); filter: hue-rotate(90deg); }
}

.envelope-wrapper {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%) scale(0);
    width: 140px;
    height: 90px;
    perspective: 1000px;
    will-change: transform, opacity;
    z-index: 9998;
}

.envelope {
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, #1e1e2f, #2a2a4a);
    border: 2px solid #00ffff;
    border-radius: 6px;
    box-shadow: 0 0 30px rgba(0, 255, 255, 0.5), inset 0 0 15px rgba(255, 0, 255, 0.3);
    position: relative;
    transform-style: preserve-3d;
}

/* Envelope Flap */
.envelope::before {
    content: '';
    position: absolute;
    top: 0; left: 0;
    width: 0; height: 0;
    border-left: 70px solid transparent;
    border-right: 70px solid transparent;
    border-top: 50px solid rgba(0, 255, 255, 0.8);
    transform-origin: top;
    transition: transform 0.5s ease-in-out;
    z-index: 3;
    filter: drop-shadow(0 5px 10px rgba(255,0,255,0.5));
}

/* Envelope body shapes to make it look realistic */
.envelope::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0;
    width: 0; height: 0;
    border-left: 70px solid transparent;
    border-right: 70px solid transparent;
    border-bottom: 50px solid rgba(255, 0, 255, 0.4);
    z-index: 2;
}

/* Envelope Open State */
.envelope-wrapper.open .envelope::before {
    transform: rotateX(180deg);
}

@keyframes envelopeAppear {
    0% { transform: translate(-50%, -50%) scale(0) rotate(-10deg); opacity: 0; }
    50% { transform: translate(-50%, -50%) scale(1.3) rotate(5deg); opacity: 1; filter: drop-shadow(0 0 40px #ff00ff); }
    100% { transform: translate(-50%, -50%) scale(1) rotate(0deg); opacity: 1; filter: drop-shadow(0 0 20px #00ffff); }
}

@keyframes envelopeDrop {
    0% { transform: translate(-50%, -50%) scale(1); opacity: 1; }
    20% { transform: translate(-50%, -60%) scale(1.1); opacity: 1; }
    100% { transform: translate(-50%, 150vh) scale(0.6) rotate(25deg); opacity: 0; filter: blur(5px); }
}

@keyframes envelopeDropFromTop {
    0% { transform: translate(-50%, -150vh) scale(0.6) rotate(-25deg); opacity: 0; filter: blur(5px); }
    80% { transform: translate(-50%, -40%) scale(1.1) rotate(5deg); opacity: 1; filter: drop-shadow(0 0 40px #ff00ff); }
    100% { transform: translate(-50%, -50%) scale(1) rotate(0deg); opacity: 1; filter: drop-shadow(0 0 20px #00ffff); }
}

@keyframes envelopeShake {
    0%, 100% { transform: translate(-50%, -50%) rotate(0deg); }
    25% { transform: translate(-50%, -50%) rotate(-8deg) scale(1.05); }
    75% { transform: translate(-50%, -50%) rotate(8deg) scale(1.05); }
}

/* We hide the option temporarily if it's the "ghost" target */
.answer-option.ghost-hole {
    opacity: 0 !important;
    visibility: hidden;
}

.answer-fly-up {
    animation: flyUpMorph 0.8s forwards cubic-bezier(0.25, 1, 0.5, 1);
    pointer-events: none;
}

@keyframes flyUpMorph {
    0% { transform: translateY(0) scale(1); opacity: 1; }
    50% { transform: translateY(-80px) scale(0.8); opacity: 0.8; filter: brightness(2) hue-rotate(90deg); }
    100% { transform: translateY(-120px) scale(0); opacity: 0; }
}

/* PREMIUM MARIFETLER GRID */
.premium-feature-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 30px; margin-top: 40px; }
.premium-card { background: rgba(20, 20, 30, 0.6); backdrop-filter: blur(20px); border: 1px solid rgba(255,255,255,0.05); border-radius: 20px; padding: 40px 30px; text-align: center; position: relative; overflow: hidden; transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275); }
.premium-card:hover { transform: translateY(-10px) scale(1.02); border-color: rgba(255,255,255,0.2); box-shadow: 0 20px 40px rgba(0,0,0,0.5); }
.card-glow { position: absolute; top: -50px; left: -50px; width: 150px; height: 150px; background: var(--c); filter: blur(80px); opacity: 0.15; transition: opacity 0.4s; }
.premium-card:hover .card-glow { opacity: 0.3; }
.card-icon { font-size: 3rem; margin-bottom: 20px; filter: drop-shadow(0 0 10px currentColor); }
.card-title { font-family: var(--font-display); font-size: 1.3rem; margin-bottom: 15px; color: #fff; }
.card-desc { font-size: 0.95rem; color: var(--text-muted); line-height: 1.6; }


/* CYBER CAPSULE ANIMATION */
.cyber-capsule-wrapper { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); width: 120px; height: 120px; perspective: 1000px; z-index: 1000; }
.cyber-capsule { width: 100%; height: 100%; position: relative; transform-style: preserve-3d; transition: transform 0.6s cubic-bezier(0.175, 0.885, 0.32, 1.275); }
.cyber-capsule::before { content: ''; position: absolute; inset: 0; background: rgba(20, 20, 30, 0.8); border: 2px solid var(--accent); border-radius: 20px; transform: rotateX(45deg) rotateY(45deg); box-shadow: 0 0 30px rgba(108, 99, 255, 0.5), inset 0 0 20px rgba(108, 99, 255, 0.5); backdrop-filter: blur(10px); }
.capsule-core { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 40px; height: 40px; background: var(--accent); border-radius: 50%; filter: blur(15px); opacity: 0; transition: opacity 0.3s; }
.cyber-capsule-wrapper.open .cyber-capsule { transform: scale(1.1) rotateX(10deg) rotateY(10deg); }
.cyber-capsule-wrapper.sealed .cyber-capsule { transform: scale(0.8) rotateX(180deg) rotateY(360deg); }
.cyber-capsule-wrapper.sealed .capsule-core { opacity: 1; }
.cyber-flash { position: fixed; inset: 0; background: #fff; z-index: 9999; animation: flashAnim 0.5s ease-out forwards; pointer-events: none; }
@keyframes flashAnim { 0% { opacity: 0.8; } 100% { opacity: 0; } }
@keyframes capsuleAppear { 0% { transform: translate(-50%, -50%) scale(0) rotate(-45deg); opacity: 0; filter: drop-shadow(0 0 0 transparent); } 50% { transform: translate(-50%, -50%) scale(1.2) rotate(15deg); opacity: 1; filter: drop-shadow(0 0 50px var(--accent)); } 100% { transform: translate(-50%, -50%) scale(1) rotate(0deg); opacity: 1; filter: drop-shadow(0 0 30px var(--accent)); } }
@keyframes capsuleWarp { 0% { transform: translate(-50%, -50%) scale(1); opacity: 1; filter: brightness(1); } 20% { transform: translate(-50%, -40%) scale(1.1); filter: brightness(2); } 100% { transform: translate(-50%, -150vh) scale(0.2) rotate(45deg); opacity: 0; filter: blur(10px); } }


@keyframes capsuleDropFromTop { 0% { transform: translate(-50%, -150vh) scale(0.6) rotate(-25deg); opacity: 0; filter: blur(5px); } 80% { transform: translate(-50%, -40%) scale(1.1) rotate(5deg); opacity: 1; filter: drop-shadow(0 0 40px var(--accent)); } }
@keyframes capsuleShake { 0%, 100% { transform: translate(-50%, -40%) scale(1.1) rotate(5deg); } 25% { transform: translate(-50%, -40%) scale(1.15) rotate(-5deg); } 75% { transform: translate(-50%, -40%) scale(1.15) rotate(15deg); } }


/* NEON ENVELOPE COMET ANIMATION */
.neon-envelope-wrapper { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); width: 140px; height: 100px; perspective: 1000px; z-index: 1000; }
.neon-envelope { width: 100%; height: 100%; position: relative; background: rgba(10,10,20,0.9); border: 2px solid #ff00ff; border-radius: 5px; box-shadow: 0 0 20px #ff00ff, inset 0 0 15px #ff00ff; transform-style: preserve-3d; }
.neon-envelope::before { content: ''; position: absolute; top: 0; left: 0; width: 0; height: 0; border-left: 70px solid transparent; border-right: 70px solid transparent; border-top: 60px solid rgba(255,0,255,0.8); border-bottom: 0 solid transparent; transform-origin: top; transition: transform 0.5s ease-in-out; z-index: 2; filter: drop-shadow(0 5px 10px rgba(0,0,0,0.5)); }
.neon-envelope-wrapper.open .neon-envelope::before { transform: rotateX(180deg); }
.comet-ball { position: absolute; width: 24px; height: 24px; background: #fff; border-radius: 50%; box-shadow: 0 0 30px #00ffff, 0 0 60px #00ffff; z-index: 1001; transition: all 0.5s ease-in-out; }
.comet-tail { position: absolute; top: 50%; left: 50%; width: 100px; height: 4px; background: linear-gradient(90deg, #00ffff, transparent); transform-origin: left center; transform: translateY(-50%) rotate(180deg); opacity: 0; transition: opacity 0.2s; }
.star-flash { position: absolute; width: 100px; height: 100px; background: radial-gradient(circle, #fff 0%, #00ffff 40%, transparent 80%); border-radius: 50%; transform: translate(-50%, -50%) scale(0); z-index: 1002; }
@keyframes flashBurst { 0% { transform: translate(-50%, -50%) scale(0); opacity: 1; } 50% { transform: translate(-50%, -50%) scale(2); opacity: 0.8; } 100% { transform: translate(-50%, -50%) scale(0); opacity: 0; } }
@keyframes neonEnvelopeDrop { 0% { transform: translate(-50%, -50%) scale(1); opacity: 1; } 100% { transform: translate(-50%, 150vh) scale(0.8) rotate(20deg); opacity: 0; } }
@keyframes neonEnvelopeDropFromTop { 0% { transform: translate(-50%, -150vh) scale(0.8) rotate(-20deg); opacity: 0; } 100% { transform: translate(-50%, -50%) scale(1) rotate(0deg); opacity: 1; } }


@keyframes rainbowFlash { 0% { background-color: #ff00ff; box-shadow: 0 0 20px #ff00ff; transform: scale(1.05); } 25% { background-color: #00ffff; box-shadow: 0 0 20px #00ffff; transform: scale(1.1); } 50% { background-color: #ffff00; box-shadow: 0 0 20px #ffff00; transform: scale(1.15); } 75% { background-color: #ff0000; box-shadow: 0 0 20px #ff0000; transform: scale(1.1); } 100% { background-color: var(--accent); box-shadow: 0 0 10px var(--accent); transform: scale(1); } }


.premium-card { transform-style: preserve-3d; transition: transform 0.6s cubic-bezier(0.25, 1, 0.5, 1), box-shadow 0.6s cubic-bezier(0.25, 1, 0.5, 1), border-color 0.6s; }
.premium-card:hover { transform: translateY(-15px) scale(1.05) rotateX(5deg) rotateY(5deg); border-color: var(--c); box-shadow: 0 30px 60px rgba(0,0,0,0.8), 0 0 40px var(--c); z-index: 10; }
.card-glow { transition: all 0.6s cubic-bezier(0.25, 1, 0.5, 1); }
.premium-card:hover .card-glow { opacity: 0.6; transform: scale(1.5); filter: blur(100px); }
.fancy-radio-group { display: flex; flex-wrap: wrap; gap: 15px; margin-top: 10px; }
.fancy-radio { display: inline-block; cursor: pointer; position: relative; }
.fancy-radio input { position: absolute; opacity: 0; cursor: pointer; }
.fancy-radio span { display: inline-block; padding: 12px 25px; background: rgba(20,20,30,0.6); border: 2px solid rgba(255,255,255,0.1); border-radius: 30px; font-weight: 500; color: #aaa; transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275); backdrop-filter: blur(10px); }
.fancy-radio input:checked + span { background: rgba(108,99,255,0.2); border-color: var(--accent); color: #fff; box-shadow: 0 0 20px rgba(108,99,255,0.4), inset 0 0 10px rgba(108,99,255,0.4); transform: scale(1.1) translateY(-3px); }
.fancy-radio:hover span { border-color: rgba(255,255,255,0.3); color: #fff; }

