:root{--color-primary:#8b5cf6;--color-primary-light:#a78bfa;--color-primary-dark:#7c3aed;--color-secondary:#06b6d4;--color-secondary-light:#22d3ee;--color-accent:#06b6d4;--color-accent-light:#22d3ee;--color-success:#10b981;--color-success-light:#34d399;--color-info:#06b6d4;--color-info-light:#22d3ee;--color-danger:#ef4444;--color-warning:#f59e0b;--bg-deep:#030712;--bg-base:#111827;--bg-elevated:#1f2937;--bg-hover:#334155;--bg-active:#475569;--text-primary:#f8fafc;--text-secondary:#cbd5e1;--text-muted:#94a3b8;--text-disabled:#64748b;--border-default:#334155;--border-light:#475569;--border-focus:var(--color-primary);--gradient-primary:linear-gradient(135deg,#8b5cf6,#06b6d4);--gradient-secondary:linear-gradient(135deg,#06b6d4,#22d3ee);--gradient-success:linear-gradient(135deg,#10b981,#06b6d4);--gradient-card:linear-gradient(145deg,rgba(139,92,246,.08),rgba(6,182,212,.04));--gradient-glow:radial-gradient(ellipse at top,rgba(139,92,246,.15),transparent 60%);--shadow-sm:0 2px 8px rgba(0,0,0,.2);--shadow-md:0 8px 24px rgba(0,0,0,.25);--shadow-lg:0 16px 48px rgba(0,0,0,.3);--shadow-glow:0 0 40px rgba(139,92,246,.2);--shadow-glow-success:0 0 30px rgba(16,185,129,.25);--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--radius-sm:6px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-display:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--transition-fast:150ms ease;--transition-base:250ms ease;--transition-slow:400ms ease}*,:after,:before{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;padding:0;font-family:var(--font-sans);background:var(--bg-base);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;background-image:var(--gradient-glow);background-attachment:fixed}body,h1,h2,h3,h4,h5,h6{color:var(--text-primary)}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:1.2;margin:0 0 var(--space-md)}h1{font-size:2.25rem;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}h2{font-size:1.75rem}h3{font-size:1.25rem}h3,p{color:var(--text-secondary)}p{margin:0 0 var(--space-md)}a{color:var(--color-info-light);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-light)}button{cursor:pointer;font-family:inherit;font-size:inherit;transition:all var(--transition-fast)}button:disabled{cursor:not-allowed;opacity:.5}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-weight:600;border:none;transition:all var(--transition-fast)}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-glow)}.btn-success{background:var(--gradient-success);color:#fff}.btn-success:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-glow-success)}.btn-outline{background:transparent;border:2px solid var(--border-default);color:var(--text-primary)}.btn-outline:hover:not(:disabled){border-color:var(--color-primary);background:rgba(139,92,246,.1)}.card{background:var(--gradient-card);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-md);transition:all var(--transition-base);position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(139,92,246,.5),transparent);opacity:0;transition:opacity var(--transition-base)}.card:hover{border-color:var(--border-light);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.card:hover:before{opacity:1}.card-interactive{cursor:pointer}.card-interactive:hover{box-shadow:var(--shadow-lg),var(--shadow-glow)}input,select,textarea{font-family:inherit;font-size:1rem;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border:2px solid var(--border-default);background:var(--bg-deep);color:var(--text-primary);transition:all var(--transition-fast);outline:none}input:focus,select:focus,textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(139,92,246,.2)}input::placeholder,textarea::placeholder{color:var(--text-disabled)}select{cursor:pointer}label{display:block;margin-bottom:var(--space-xs);font-weight:500;color:var(--text-secondary)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes badgePulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}@keyframes glow{0%,to{box-shadow:0 0 20px rgba(139,92,246,.3)}50%{box-shadow:0 0 40px rgba(139,92,246,.5)}}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fadeIn{animation:fadeIn var(--transition-base) ease-out}.animate-fadeInUp{animation:fadeInUp var(--transition-slow) ease-out}.pulse-animation{animation:pulse 1.5s ease-in-out infinite}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-float{animation:float 3s ease-in-out infinite}.animate-glow{animation:glow 2s ease-in-out infinite}.text-gradient{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.text-gradient-secondary{background:var(--gradient-secondary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.text-muted{color:var(--text-muted)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-danger{color:var(--color-danger)}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-deep);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb{background:var(--bg-hover);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--bg-active)}::selection{background:rgba(139,92,246,.3);color:var(--text-primary)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.toast-container{position:fixed;top:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast{display:flex;align-items:center;gap:12px;padding:14px 20px;border-radius:var(--radius-md);background:var(--bg-elevated);border:1px solid var(--border-default);box-shadow:var(--shadow-lg);pointer-events:auto;animation:toastSlideIn .3s ease-out;max-width:400px}.toast.toast-exit{animation:toastSlideOut .2s ease-in forwards}.toast-success{border-color:rgba(16,185,129,.5);background:linear-gradient(135deg,rgba(16,185,129,.15),var(--bg-elevated))}.toast-error{border-color:rgba(239,68,68,.5);background:linear-gradient(135deg,rgba(239,68,68,.15),var(--bg-elevated))}.toast-info{border-color:rgba(6,182,212,.5);background:linear-gradient(135deg,rgba(6,182,212,.15),var(--bg-elevated))}.toast-warning{border-color:rgba(245,158,11,.5);background:linear-gradient(135deg,rgba(245,158,11,.15),var(--bg-elevated))}.toast-icon{font-size:1.25rem;flex-shrink:0}.toast-message{flex:1 1;font-size:.95rem;color:var(--text-primary)}.toast-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.toast-close:hover{color:var(--text-primary);background:var(--bg-hover)}@keyframes toastSlideIn{0%{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}@keyframes toastSlideOut{0%{transform:translateX(0);opacity:1}to{transform:translateX(100%);opacity:0}}.skeleton{background:linear-gradient(90deg,var(--bg-elevated) 25%,var(--bg-hover) 50%,var(--bg-elevated) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}.skeleton-text{height:1em;margin-bottom:.5em}.skeleton-text:last-child{width:70%}.skeleton-title{height:1.5em;width:60%;margin-bottom:1em}.skeleton-avatar{width:48px;height:48px;border-radius:var(--radius-full)}.skeleton-card{height:120px;border-radius:var(--radius-lg)}.skeleton-button{height:44px;width:120px;border-radius:var(--radius-md)}.recording-indicator{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.4);border-radius:var(--radius-full);color:#fca5a5;font-weight:600;font-size:.9rem}.recording-dot{width:10px;height:10px;background:#ef4444;border-radius:50%;animation:recordingPulse 1s ease-in-out infinite}@keyframes recordingPulse{0%,to{transform:scale(1);opacity:1;box-shadow:0 0 0 0 rgba(239,68,68,.7)}50%{transform:scale(1.1);opacity:.8;box-shadow:0 0 0 8px rgba(239,68,68,0)}}.audio-waveform{display:flex;align-items:center;gap:3px;height:24px}.audio-waveform-bar{width:3px;background:var(--color-primary);border-radius:2px;animation:waveform .8s ease-in-out infinite}.audio-waveform-bar:first-child{animation-delay:0s}.audio-waveform-bar:nth-child(2){animation-delay:.1s}.audio-waveform-bar:nth-child(3){animation-delay:.2s}.audio-waveform-bar:nth-child(4){animation-delay:.3s}.audio-waveform-bar:nth-child(5){animation-delay:.4s}@keyframes waveform{0%,to{height:8px}50%{height:24px}}.btn-lift{transition:all var(--transition-fast)}.btn-lift:hover:not(:disabled){transform:translateY(-3px);box-shadow:var(--shadow-lg),var(--shadow-glow)}.btn-lift:active:not(:disabled){transform:translateY(-1px)}.hover-scale{transition:transform var(--transition-fast)}.hover-scale:hover{transform:scale(1.02)}.hover-glow{transition:all var(--transition-base)}.hover-glow:hover{box-shadow:var(--shadow-glow)}.card-pop{transition:all var(--transition-base)}.card-pop:hover{transform:translateY(-4px) scale(1.01);box-shadow:var(--shadow-lg),0 0 30px rgba(139,92,246,.15)}.stagger-item{opacity:0;animation:fadeInUp .4s ease-out forwards}.stagger-item:first-child{animation-delay:.05s}.stagger-item:nth-child(2){animation-delay:.1s}.stagger-item:nth-child(3){animation-delay:.15s}.stagger-item:nth-child(4){animation-delay:.2s}.stagger-item:nth-child(5){animation-delay:.25s}.stagger-item:nth-child(6){animation-delay:.3s}.stagger-item:nth-child(7){animation-delay:.35s}.stagger-item:nth-child(8){animation-delay:.4s}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:var(--radius-full);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge-success{background:rgba(16,185,129,.15);color:#34d399;border:1px solid rgba(16,185,129,.3)}.status-badge-warning{background:rgba(245,158,11,.15);color:#fbbf24;border:1px solid rgba(245,158,11,.3)}.status-badge-error{background:rgba(239,68,68,.15);color:#fca5a5;border:1px solid rgba(239,68,68,.3)}.status-badge-info{background:rgba(6,182,212,.15);color:#22d3ee;border:1px solid rgba(6,182,212,.3)}.status-badge-neutral{background:rgba(100,116,139,.15);color:#94a3b8;border:1px solid rgba(100,116,139,.3)}.status-dot{width:8px;height:8px;border-radius:50%}.status-dot-active{background:#10b981;animation:statusPulse 2s ease-in-out infinite}.status-dot-warning{background:#f59e0b;animation:statusPulse 1.5s ease-in-out infinite}.status-dot-error{background:#ef4444}@keyframes statusPulse{0%,to{opacity:1}50%{opacity:.5}}.progress-bar{height:8px;background:var(--bg-hover);border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill{height:100%;background:var(--gradient-primary);border-radius:var(--radius-full);transition:width var(--transition-slow)}.progress-bar-animated .progress-bar-fill{background:linear-gradient(90deg,var(--color-primary),var(--color-secondary),var(--color-primary));background-size:200% 100%;animation:shimmer 2s infinite}.progress-ring{transform:rotate(-90deg)}.progress-ring-circle{fill:none;stroke:var(--bg-hover);stroke-width:4}.progress-ring-progress{fill:none;stroke:url(#progressGradient);stroke-width:4;stroke-linecap:round;transition:stroke-dashoffset var(--transition-slow)}.glass{background:rgba(30,41,59,.7);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.glass,.glass-light{border:1px solid hsla(0,0%,100%,.1)}.glass-light{background:hsla(0,0%,100%,.05);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.counter-animate{display:inline-block;transition:all var(--transition-base)}.counter-animate.counting{animation:counterPop .3s ease-out}@keyframes counterPop{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}@media (max-width:600px){.toast-container{top:auto;bottom:20px;right:10px;left:10px}.toast{max-width:none}}.hover-lift{transition:transform var(--transition-base),box-shadow var(--transition-base)}.hover-lift:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.stagger-fade-in{opacity:0;animation:staggerFadeIn .3s ease-out forwards}@keyframes staggerFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.bounce-in{animation:bounceIn .5s cubic-bezier(.175,.885,.32,1.275)}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{transform:scale(1.05)}70%{transform:scale(.9)}to{opacity:1;transform:scale(1)}}.btn-pulse{animation:subtlePulse 2s ease-in-out infinite}.btn-pulse:hover{animation:none}@keyframes subtlePulse{0%,to{box-shadow:0 4px 15px rgba(139,92,246,.3)}50%{box-shadow:0 4px 25px rgba(139,92,246,.5)}}.scale-in{animation:scaleIn .3s ease-out}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.slide-in-right{animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}.fade-in{animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.shimmer{background:linear-gradient(90deg,hsla(0,0%,100%,0),hsla(0,0%,100%,.05) 50%,hsla(0,0%,100%,0));background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.focus-glow:focus{outline:none;box-shadow:0 0 0 3px rgba(139,92,246,.3)}.gradient-text-animate{background:linear-gradient(135deg,#a78bfa,#22d3ee,#a78bfa);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradientFlow 3s linear infinite}@keyframes gradientFlow{0%{background-position:0}to{background-position:200%}}@keyframes celebrationFadeIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes celebrationFadeOut{0%{opacity:1}to{opacity:0}}@keyframes confettiFall{0%{transform:translateY(-100%) rotate(0deg);opacity:1}to{transform:translateY(100vh) rotate(2turn);opacity:0}}.celebration-overlay{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:rgba(3,7,18,.85);animation:celebrationFadeIn .3s ease-out,celebrationFadeOut .3s ease-in 1.7s forwards}.celebration-content{text-align:center;animation:celebrationFadeIn .4s ease-out}.celebration-emoji{font-size:72px;display:block;margin-bottom:16px;animation:bounce .6s ease-in-out}.celebration-text{font-size:24px;font-weight:700;color:#f8fafc;margin:0}.celebration-subtext{font-size:16px;color:#94a3b8;margin:8px 0 0}.confetti-piece{position:fixed;top:-10px;width:10px;height:10px;border-radius:2px;animation:confettiFall 2s linear forwards;z-index:10000}.bottom-nav{display:none}@media (max-width:900px){.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:1000;background:rgba(17,24,39,.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--border-default);padding:8px 0 calc(8px + env(safe-area-inset-bottom));justify-content:space-around}.bottom-nav,.bottom-nav-item{display:flex;align-items:center}.bottom-nav-item{flex-direction:column;gap:4px;padding:6px 12px;border:none;background:transparent;color:var(--text-muted);font-size:11px;font-weight:500;text-decoration:none;cursor:pointer;transition:color .15s ease;min-width:64px;min-height:44px}.bottom-nav-item.active{color:var(--color-primary-light)}.bottom-nav-item:hover{color:var(--text-secondary)}.bottom-nav-icon,.bottom-nav-icon svg{width:24px;height:24px}.bottom-nav-icon svg{fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.dashboard{padding-bottom:80px!important}[role=button],a,button{min-height:44px}.action-btn,.btn{padding:14px 20px}.activity-item{padding:14px;margin-bottom:2px}input,select,textarea{padding:14px 16px;font-size:16px}}.page-transition-enter{opacity:0}.page-transition-enter-active{opacity:1;transition:opacity .2s ease-in}.page-transition-exit{opacity:1}.page-transition-exit-active{opacity:0;transition:opacity .2s ease-out}.streak-display{display:flex;align-items:center;gap:10px;padding:16px 20px;background:linear-gradient(135deg,rgba(251,146,60,.15),rgba(239,68,68,.1));border:1px solid rgba(251,146,60,.3);border-radius:16px;margin-bottom:20px}.streak-flame{font-size:32px;animation:float 2s ease-in-out infinite}.streak-info{flex:1 1}.streak-count{font-size:24px;font-weight:700;color:#fb923c}.streak-label{font-size:13px;color:var(--text-muted)}.streak-prompt{font-size:12px;color:#fbbf24;margin-top:2px}.badges-section{margin-bottom:24px}.badges-section h3{font-size:16px;color:var(--text-primary);margin:0 0 12px}.badges-row{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.badges-row::-webkit-scrollbar{display:none}.badge-item{display:flex;flex-direction:column;align-items:center;gap:6px;min-width:80px;padding:12px 8px;border-radius:12px;text-align:center;flex-shrink:0}.badge-item.earned{background:rgba(139,92,246,.1);border:1px solid rgba(139,92,246,.3)}.badge-item.locked{background:rgba(71,85,105,.2);border:1px solid rgba(71,85,105,.3);opacity:.5}.badge-icon{font-size:28px}.badge-label{font-size:11px;color:var(--text-muted);line-height:1.2}.badge-item.earned .badge-label{color:var(--text-secondary)}.category-progress-section{margin-bottom:24px}.category-progress-section h3{font-size:16px;color:var(--text-primary);margin:0 0 12px}.category-progress-list{display:grid;grid-gap:10px;gap:10px}.category-progress-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--gradient-card);border:1px solid var(--border-default);border-radius:12px}.category-progress-emoji{font-size:20px;flex-shrink:0}.category-progress-info{flex:1 1;min-width:0}.category-progress-name{font-size:14px;color:var(--text-primary);font-weight:500}.category-progress-bar{height:6px;background:rgba(139,92,246,.15);border-radius:3px;overflow:hidden;margin-top:6px}.category-progress-fill{height:100%;background:linear-gradient(90deg,#8b5cf6,#06b6d4);border-radius:3px;transition:width .5s ease}.category-progress-count{font-size:13px;color:var(--text-muted);white-space:nowrap}.category-encouragement{font-size:12px;color:#fbbf24;margin-top:2px}.interview-progress{display:flex;align-items:center;gap:12px;padding:12px 16px;background:rgba(30,41,59,.6);border-radius:12px;margin-bottom:12px}.interview-progress-bar{flex:1 1;height:6px;background:rgba(139,92,246,.2);border-radius:3px;overflow:hidden}.interview-progress-fill{height:100%;background:linear-gradient(90deg,#8b5cf6,#22c55e);border-radius:3px;transition:width .5s ease}.interview-progress-text{font-size:13px;color:var(--text-muted);white-space:nowrap;font-weight:600}@media (max-width:900px){.skeleton-card-mobile{height:100px;border-radius:16px}.skeleton-card-mobile,.skeleton-stat-mobile{background:linear-gradient(90deg,var(--bg-elevated) 25%,var(--bg-hover) 50%,var(--bg-elevated) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.skeleton-stat-mobile{height:80px;border-radius:12px}.skeleton-button-mobile{height:56px;border-radius:16px;background:linear-gradient(90deg,var(--bg-elevated) 25%,var(--bg-hover) 50%,var(--bg-elevated) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}}.recording-pause-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:12px;border:2px solid #fbbf24;background:rgba(251,191,36,.1);color:#fbbf24;font-weight:600;font-size:14px;cursor:pointer;transition:all .15s ease;min-height:44px}.recording-pause-btn:hover{background:rgba(251,191,36,.2)}.recording-pause-btn.paused{border-color:#22c55e;color:#22c55e;background:rgba(34,197,94,.1);animation:subtlePulse 2s ease-in-out infinite}