@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Outfit:wght@400;500;600;700;800&display=swap";:root{--brand-primary: #5d5791;--brand-primary-light: #6c5ce7;--brand-primary-dark: #4a4275;--brand-lavender: #edeafe;--brand-lavender-dark: #ddd8fc;--accent-blue: #4e8ef7;--accent-green: #43b56a;--accent-purple: #9a5cf5;--accent-pink: #ff6b9d;--accent-orange: #ff9f43;--accent-teal: #00d2d3;--bg-primary: #f9f6ff;--bg-secondary: #f5f6fa;--bg-card: #ffffff;--bg-glass: rgba(255, 255, 255, .75);--bg-glass-strong: rgba(255, 255, 255, .92);--text-primary: #1a1a2e;--text-secondary: #6b7280;--text-tertiary: #9ca3af;--text-on-brand: #ffffff;--border-light: rgba(93, 87, 145, .1);--border-medium: rgba(93, 87, 145, .2);--shadow-sm: 0 1px 3px rgba(93, 87, 145, .06);--shadow-md: 0 4px 12px rgba(93, 87, 145, .08);--shadow-lg: 0 8px 30px rgba(93, 87, 145, .12);--shadow-xl: 0 12px 40px rgba(93, 87, 145, .16);--shadow-brand: 0 4px 20px rgba(108, 92, 231, .3);--shadow-glow: 0 0 30px rgba(108, 92, 231, .15);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-2xl: 24px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--max-width: 1200px;--header-height: 64px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--text-primary);background-color:var(--bg-primary);line-height:1.6;min-height:100vh;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:Outfit,Inter,sans-serif;font-weight:700;line-height:1.3}a{text-decoration:none;color:var(--brand-primary-light)}button{cursor:pointer;font-family:Inter,sans-serif;border:none;outline:none}input,select,textarea{font-family:Inter,sans-serif;font-size:.95rem}img{max-width:100%;height:auto}.container{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-md)}.glass-card{background:var(--bg-glass-strong);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-xl);border:1px solid var(--border-light);box-shadow:var(--shadow-lg)}.gradient-bg{background:linear-gradient(135deg,#eff3ff,#f7f3ff,#fff0f7)}.gradient-brand{background:linear-gradient(135deg,var(--brand-primary) 0%,var(--brand-primary-light) 100%)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:12px 24px;border-radius:var(--radius-md);font-weight:600;font-size:.95rem;transition:all var(--transition-normal);position:relative;overflow:hidden}.btn-primary{background:linear-gradient(135deg,var(--brand-primary) 0%,var(--brand-primary-light) 100%);color:var(--text-on-brand);box-shadow:var(--shadow-brand)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 25px #6c5ce766}.btn-primary:active{transform:translateY(0)}.btn-outline{background:transparent;color:var(--brand-primary);border:2px solid var(--brand-primary)}.btn-outline:hover{background:var(--brand-lavender);transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--text-secondary);padding:8px 16px}.btn-ghost:hover{background:var(--brand-lavender);color:var(--brand-primary)}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.btn-sm{padding:8px 16px;font-size:.85rem;border-radius:var(--radius-sm)}.btn-lg{padding:16px 32px;font-size:1.05rem;border-radius:var(--radius-lg)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.input-group{display:flex;flex-direction:column;gap:var(--space-xs)}.input-group label{font-size:.875rem;font-weight:600;color:var(--text-secondary)}.input-field{width:100%;padding:12px 16px;border:2px solid var(--border-light);border-radius:var(--radius-md);font-size:.95rem;background:var(--bg-card);color:var(--text-primary);transition:all var(--transition-fast)}.input-field:focus{outline:none;border-color:var(--brand-primary-light);box-shadow:0 0 0 3px #6c5ce726}.input-field::placeholder{color:var(--text-tertiary)}.input-field.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-light);box-shadow:var(--shadow-sm);padding:var(--space-lg);transition:all var(--transition-normal)}.card:hover{box-shadow:var(--shadow-md)}.card-interactive:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);cursor:pointer}.tab-bar{display:flex;background:var(--bg-card);border-radius:var(--radius-full);padding:4px;box-shadow:var(--shadow-md);gap:2px}.tab-item{flex:1;padding:10px 16px;border-radius:var(--radius-full);font-weight:600;font-size:.85rem;text-align:center;color:var(--text-secondary);background:transparent;transition:all var(--transition-normal);border:none;cursor:pointer}.tab-item.active{background:linear-gradient(135deg,var(--brand-primary) 0%,var(--brand-primary-light) 100%);color:#fff;box-shadow:0 4px 12px #6c5ce759}.tab-item:not(.active):hover{background:var(--brand-lavender);color:var(--brand-primary)}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600}.badge-success{background:#43b56a1f;color:var(--accent-green)}.badge-warning{background:#ff9f431f;color:var(--accent-orange)}.badge-danger{background:#ef44441f;color:#ef4444}.badge-info{background:#4e8ef71f;color:var(--accent-blue)}.spinner{width:40px;height:40px;border:3px solid var(--brand-lavender);border-top-color:var(--brand-primary-light);border-radius:50%;animation:spin .8s linear infinite}.spinner-sm{width:20px;height:20px;border-width:2px}.loading-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-3xl);color:var(--text-secondary)}.toast{position:fixed;bottom:24px;right:24px;padding:14px 24px;border-radius:var(--radius-md);font-weight:500;font-size:.9rem;color:#fff;z-index:10000;box-shadow:var(--shadow-xl);animation:slideUp .3s ease}.toast-success{background:var(--accent-green)}.toast-error{background:#ef4444}.toast-warning{background:var(--accent-orange)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-fade-in{animation:fadeIn .5s ease}.animate-fade-in-up{animation:fadeInUp .5s ease}.animate-pulse{animation:pulse 2s ease-in-out infinite}@media(max-width:768px){:root{--space-lg: 16px;--space-xl: 24px;--space-2xl: 32px}.tab-item{padding:8px 10px;font-size:.75rem}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--brand-lavender-dark);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--brand-primary)}#root{min-height:100vh}.splash-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f9f6ff,#eff3ff,#f7f3ff);position:relative;overflow:hidden}.splash-bg-orbs{position:absolute;inset:0;pointer-events:none}.splash-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.3;animation:floatOrb 8s ease-in-out infinite}.orb-1{width:300px;height:300px;background:#6c5ce7;top:-50px;right:-50px;animation-delay:0s}.orb-2{width:250px;height:250px;background:#ff6b9d;bottom:-30px;left:-30px;animation-delay:-3s}.orb-3{width:200px;height:200px;background:#43b56a;top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:-5s}@keyframes floatOrb{0%,to{transform:translateY(0)}50%{transform:translateY(-30px)}}.splash-content{display:flex;flex-direction:column;align-items:center;gap:24px;z-index:1}.splash-logo{text-align:center}.splash-logo-icon{font-size:64px;margin-bottom:12px;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.splash-title{font-family:Outfit,sans-serif;font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,#5d5791,#6c5ce7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.splash-subtitle{font-size:1rem;color:var(--text-secondary);margin-top:4px;font-weight:500}.splash-loader{height:4px;background:linear-gradient(90deg,#5d5791,#6c5ce7,#9a5cf5);border-radius:4px;max-width:200px}.splash-loading-text{font-size:.85rem;color:var(--text-tertiary);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.auth-page-container{min-height:100vh;width:100%;display:flex;background-color:var(--bg-primary);overflow:hidden;position:relative}.auth-split-layout{display:flex;width:100%;height:100vh}.auth-left-panel{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:var(--space-2xl);position:relative;z-index:10;background:#fff6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.auth-right-panel{flex:1.2;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--brand-primary-dark),var(--brand-primary));color:#fff;padding:var(--space-3xl)}.auth-showcase-content{position:relative;z-index:2;max-width:500px;text-align:center}.showcase-title{font-size:3rem;font-weight:800;margin-bottom:var(--space-md);line-height:1.1;background:linear-gradient(to right,#fff,#e0e7ff);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;color:transparent}.showcase-desc{font-size:1.2rem;opacity:.9;line-height:1.6;font-weight:300}.auth-card-modern{width:100%;max-width:440px;background:#ffffffd9;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.6);border-radius:var(--radius-2xl);padding:var(--space-2xl);box-shadow:0 20px 50px #5d57911a,0 10px 20px #5d57910d,inset 0 0 0 1px #ffffff80;transition:transform .3s ease,box-shadow .3s ease}.auth-card-modern:hover{transform:translateY(-5px);box-shadow:0 25px 60px #5d579126,0 15px 30px #5d57911a,inset 0 0 0 1px #fff9}.auth-tabs-modern{display:flex;background:var(--bg-secondary);padding:6px;border-radius:var(--radius-lg);margin-bottom:var(--space-xl);position:relative}.auth-tab-modern{flex:1;position:relative;border:none;background:none;padding:10px;font-weight:600;font-size:.95rem;color:var(--text-tertiary);z-index:2;transition:color .2s ease;cursor:pointer}.auth-tab-modern.active{color:var(--brand-primary)}.auth-tab-indicator{position:absolute;top:6px;bottom:6px;left:6px;width:calc(50% - 6px);background:#fff;border-radius:var(--radius-md);box-shadow:0 2px 8px #00000014;z-index:1;transition:transform .25s cubic-bezier(.4,0,.2,1)}.auth-blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:.6;z-index:0;animation:float 20s infinite alternate cubic-bezier(.4,0,.2,1)}.blob-1{top:-10%;left:-10%;width:500px;height:500px;background:conic-gradient(from 0deg,var(--brand-primary-light),var(--accent-purple));animation-duration:25s}.blob-2{bottom:-10%;right:-10%;width:400px;height:400px;background:conic-gradient(from 180deg,var(--accent-blue),var(--brand-lavender));animation-duration:30s;animation-delay:-5s}.floating-circle{position:absolute;border-radius:50%;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}@keyframes float{0%{transform:translate(0) rotate(0)}50%{transform:translate(30px,40px) rotate(10deg)}to{transform:translate(-20px,20px) rotate(-10deg)}}@media(max-width:960px){.auth-split-layout{flex-direction:column;min-height:100vh;height:auto}.auth-right-panel{display:none}.auth-left-panel{padding:var(--space-md);background:transparent;min-height:100vh;justify-content:center}.auth-card-modern{box-shadow:0 10px 30px #5d57911a,0 4px 10px #5d57910d;background:#ffffffe6;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:var(--space-lg);margin:var(--space-md) auto}.auth-blob{filter:blur(40px);opacity:.5}}@media(max-width:480px){.auth-left-panel{padding:var(--space-sm)}.auth-card-modern{padding:var(--space-md);width:100%;border-radius:var(--radius-xl)}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:24px}.auth-bg{position:fixed;inset:0;pointer-events:none;z-index:0;background:linear-gradient(135deg,#f9f6ff,#eff3ff 40%,#fff5f9)}.auth-bg-blob{position:absolute;border-radius:50%;filter:blur(100px);opacity:.25}.blob-1{width:400px;height:400px;background:linear-gradient(135deg,#6c5ce7,#a29cfc);top:-100px;right:-100px;animation:blobFloat1 12s ease-in-out infinite}.blob-2{width:350px;height:350px;background:linear-gradient(135deg,#ff6b9d,#ffc3d4);bottom:-80px;left:-80px;animation:blobFloat2 14s ease-in-out infinite}.blob-3{width:250px;height:250px;background:linear-gradient(135deg,#43b56a,#7deba0);top:30%;left:10%;animation:blobFloat3 16s ease-in-out infinite}.blob-4{width:200px;height:200px;background:linear-gradient(135deg,#ff9f43,#ffd29c);bottom:20%;right:15%;animation:blobFloat1 10s ease-in-out infinite reverse}@keyframes blobFloat1{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-30px) scale(1.05)}66%{transform:translate(-20px,20px) scale(.95)}}@keyframes blobFloat2{0%,to{transform:translate(0) scale(1)}50%{transform:translate(40px,-40px) scale(1.1)}}@keyframes blobFloat3{0%,to{transform:translate(0)}50%{transform:translate(-30px,30px)}}.floating-shape{position:absolute;border-radius:50%;opacity:.1;animation:floatShape 20s ease-in-out infinite}.shape-1{width:12px;height:12px;background:#6c5ce7;top:15%;left:20%;animation-delay:0s}.shape-2{width:8px;height:8px;background:#ff6b9d;top:25%;right:30%;animation-delay:-3s}.shape-3{width:16px;height:16px;background:#43b56a;bottom:30%;left:15%;animation-delay:-5s;border-radius:4px}.shape-4{width:10px;height:10px;background:#ff9f43;top:60%;right:20%;animation-delay:-8s}.shape-5{width:14px;height:14px;background:#6c5ce7;bottom:15%;right:40%;animation-delay:-11s;border-radius:4px}.shape-6{width:6px;height:6px;background:#9a5cf5;top:45%;left:40%;animation-delay:-14s}@keyframes floatShape{0%,to{transform:translateY(0) rotate(0)}25%{transform:translateY(-20px) rotate(90deg)}50%{transform:translateY(10px) rotate(180deg)}75%{transform:translateY(-15px) rotate(270deg)}}.auth-container{display:flex;flex-direction:column;align-items:center;gap:20px;width:100%;max-width:440px;z-index:1}.auth-brand{text-align:center}.brand-icon-wrapper{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,#5d5791,#6c5ce7);display:flex;align-items:center;justify-content:center;margin:0 auto 12px;box-shadow:0 8px 24px #6c5ce74d}.brand-icon{font-size:36px;filter:grayscale(0)}.brand-name{font-family:Outfit,sans-serif;font-size:1.75rem;font-weight:800;background:linear-gradient(135deg,#5d5791,#6c5ce7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.brand-badge{display:inline-block;padding:4px 14px;background:var(--brand-lavender);color:var(--brand-primary);border-radius:999px;font-size:.75rem;font-weight:600;margin-top:4px}.welcome-note{text-align:center;padding:0 16px}.welcome-emojis{display:flex;justify-content:center;gap:8px;font-size:1.3rem;margin-bottom:6px}.welcome-note p{font-size:.9rem;color:var(--text-secondary);line-height:1.5}.auth-card{width:100%;padding:28px}.auth-tabs{display:flex;background:var(--bg-secondary);border-radius:999px;padding:4px;margin-bottom:24px}.auth-tab{flex:1;padding:10px 16px;border:none;border-radius:999px;font-weight:600;font-size:.9rem;color:var(--text-secondary);background:transparent;cursor:pointer;transition:all .25s ease}.auth-tab.active{background:linear-gradient(135deg,var(--brand-primary) 0%,var(--brand-primary-light) 100%);color:#fff;box-shadow:0 4px 12px #6c5ce74d}.auth-tab:not(.active):hover{color:var(--brand-primary)}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-submit{width:100%;margin-top:8px}.auth-error{display:flex;align-items:flex-start;gap:8px;padding:12px 16px;background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:12px;color:#dc2626;font-size:.875rem}.auth-success{display:flex;align-items:flex-start;gap:8px;padding:12px 16px;background:#43b56a14;border:1px solid rgba(67,181,106,.2);border-radius:12px;color:#059669;font-size:.875rem}.auth-forgot-link{display:block;text-align:center;margin-top:8px;font-size:.85rem;color:var(--brand-primary-light);background:none;border:none;cursor:pointer;font-weight:500}.auth-forgot-link:hover{text-decoration:underline}.auth-redirect-text{text-align:center;font-size:.85rem;color:var(--text-secondary)}.auth-link{background:none;border:none;color:var(--brand-primary-light);font-weight:600;cursor:pointer;font-size:inherit}.auth-link:hover{text-decoration:underline}.field-error{font-size:.8rem;color:#dc2626}.password-wrapper{position:relative}.password-wrapper .input-field{padding-right:44px}.password-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px;display:flex;align-items:center}.password-toggle:hover{color:var(--brand-primary)}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:480px){.auth-container{gap:16px}.auth-card{padding:20px}.brand-icon-wrapper{width:60px;height:60px}.brand-icon{font-size:28px}.brand-name{font-size:1.5rem}}.wizard-page{min-height:100vh;padding:24px;position:relative;overflow:hidden;background:linear-gradient(135deg,#f9f6ff,#eff3ff,#f7f3ff)}@media(min-width:1024px){.wizard-page{padding:60px 40px}}.wizard-bg{position:fixed;inset:0;pointer-events:none}.wizard-bg-orb{position:absolute;border-radius:50%;filter:blur(100px);opacity:.2}.orb-a{width:350px;height:350px;background:#6c5ce7;top:-80px;left:-80px;animation:blobFloat1 12s ease-in-out infinite}.orb-b{width:300px;height:300px;background:#ff6b9d;bottom:-60px;right:-60px;animation:blobFloat2 14s ease-in-out infinite}.wizard-container{max-width:600px;margin:0 auto;position:relative;z-index:1;transition:max-width .4s ease}@media(min-width:1024px){.wizard-container{max-width:1000px}.wizard-step:not(.has-packages){max-width:600px;margin-left:auto;margin-right:auto}}.wizard-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.step-indicator{display:flex;align-items:center;justify-content:center;flex:1;gap:0}.step-item{display:flex;align-items:center}.step-dot{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#e5e7eb;color:#9ca3af;transition:all .3s ease;flex-shrink:0}.step-dot.active{width:42px;height:42px;background:var(--brand-lavender);color:var(--brand-primary);border:2px solid var(--brand-primary);box-shadow:0 0 16px #6c5ce740}.step-dot.completed{background:var(--brand-primary);color:#fff}.step-line{width:24px;height:2px;background:#e5e7eb;transition:background .3s ease}.step-line.completed{background:var(--brand-primary)}.wizard-step-content{min-height:400px}.wizard-step{background:var(--bg-glass-strong);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-xl);border:1px solid var(--border-light);box-shadow:var(--shadow-lg);padding:24px}@media(min-width:1024px){.wizard-step{padding:40px}}.step-title-section{text-align:center;margin-bottom:24px}.step-emoji{font-size:32px;display:block;margin-bottom:4px}.step-title-section h2{font-family:Outfit,sans-serif;font-size:1.4rem;margin-bottom:4px}.step-title-section p{color:var(--text-secondary);font-size:.9rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:540px){.form-row{grid-template-columns:1fr}}.wizard-step select.input-field{color:var(--text-primary);background-color:#fff;-webkit-appearance:none;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='%236b7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.wizard-step select.input-field option{background:#fff;color:#1a1a2e;padding:8px 12px}.wizard-step select.input-field option:disabled{color:#9ca3af}.wizard-step select.input-field:disabled{background-color:#f3f4f6;color:#9ca3af;cursor:not-allowed}.field-success{font-size:.8rem;color:var(--accent-green)}.input-field.success{border-color:var(--accent-green)}.field-error{font-size:.78rem;color:#dc2626;margin-top:4px}.edit-validation-hint{display:block;font-size:.78rem;margin-top:5px;font-weight:600}.edit-validation-hint.error{color:#dc2626}.edit-validation-hint.ok{color:#16a34a}.edit-field-input.edit-field-error{border-color:#fca5a5;background:#fff8f8;box-shadow:0 0 0 3px #dc262614}.packages-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px;width:100%;margin-bottom:24px}.package-card{padding:24px;cursor:pointer;border:2px solid #f3f4f6;display:flex;flex-direction:column;gap:16px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);background:#fff;border-radius:24px;box-shadow:0 4px 12px #00000008}.package-card:hover{transform:translateY(-8px);border-color:var(--brand-primary-light);box-shadow:0 12px 24px #6c5ce71f}.package-card.selected{border-color:var(--brand-primary);background:#fff;box-shadow:0 12px 24px #6c5ce726}.package-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.package-badge{font-size:12px;font-weight:600;padding:4px 8px;border-radius:12px;text-transform:uppercase;letter-spacing:.5px}.package-badge.monthly{background:#e0f2fe;color:#0284c7}.package-badge.yearly{background:#dcfce7;color:#16a34a}.package-badge.one_time{background:#f3e8ff;color:#9333ea}.discount-badge{background:#ffedd5;color:#c2410c;font-size:11px;font-weight:700;padding:2px 6px;border-radius:4px}.package-name{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0;line-height:1.3}.package-pricing{display:flex;flex-direction:column;gap:2px}.main-price{font-size:1.3rem;font-weight:800;color:var(--text-primary)}.registration-fee{font-size:.85rem;color:var(--text-secondary)}.savings-text{font-size:.85rem;color:#16a34a;font-weight:600}.package-desc{font-size:.9rem;color:var(--text-secondary);line-height:1.5;margin:0}.package-features{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.package-features li{display:flex;align-items:start;gap:8px;font-size:.9rem;color:var(--text-primary)}.feature-icon{color:var(--brand-primary);min-width:14px;margin-top:3px}.package-check{position:absolute;top:16px;right:16px;width:28px;height:28px;background:var(--brand-primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(var(--brand-primary-rgb),.3)}.payment-summary{margin-bottom:24px}.payment-summary h3{font-size:1rem;margin-bottom:12px}.payment-line{display:flex;justify-content:space-between;padding:12px 0;border-top:1px solid var(--border-light)}.payment-amount{font-weight:700;color:var(--brand-primary)}.school-section{background:#fff6;border:1px solid var(--border-light);border-radius:12px;padding:16px;margin-top:24px}.school-section-header{display:flex;align-items:center;gap:8px;margin-bottom:16px;color:var(--text-primary)}.school-section-header h3{margin:0;font-size:.95rem;font-weight:600;color:var(--brand-primary);display:flex;align-items:center;gap:8px}.optional-badge{background:#ffffff80;border:1px solid var(--border-light);color:var(--brand-primary);opacity:.8;font-size:.7rem;padding:2px 8px;border-radius:12px;font-weight:500;margin-left:auto}.ps-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f0edff,#f7f3ff,#edf4ff);z-index:100;overflow:hidden;padding:16px}.ps-bg-blob{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;animation:psFloat 20s ease-in-out infinite alternate}.ps-blob-1{width:500px;height:500px;top:-15%;left:-10%;background:radial-gradient(circle,rgba(108,92,231,.18) 0%,transparent 70%);animation-duration:22s}.ps-blob-2{width:400px;height:400px;bottom:-10%;right:-5%;background:radial-gradient(circle,rgba(67,181,106,.15) 0%,transparent 70%);animation-duration:28s;animation-delay:-5s}.ps-blob-3{width:300px;height:300px;top:40%;left:60%;background:radial-gradient(circle,rgba(78,142,247,.12) 0%,transparent 70%);animation-duration:18s;animation-delay:-10s}@keyframes psFloat{0%{transform:translate(0) scale(1)}50%{transform:translate(30px,40px) scale(1.05)}to{transform:translate(-20px,20px) scale(.97)}}.ps-confetti{position:fixed;top:0;pointer-events:none;z-index:9999}.ps-dialog{position:relative;z-index:10;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;background:#fffffff5;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-radius:28px;border:1px solid rgba(255,255,255,.8);box-shadow:0 32px 80px #5d57912e,0 8px 24px #5d57911a,inset 0 1px #ffffffe6;overflow:hidden;display:flex;flex-direction:column}.ps-dialog::-webkit-scrollbar{width:4px}.ps-dialog::-webkit-scrollbar-thumb{background:var(--brand-lavender-dark);border-radius:4px}.ps-state-center{display:flex;flex-direction:column;align-items:center;text-align:center;padding:52px 40px;gap:16px}.ps-loader-ring{color:var(--brand-primary-light)}.ps-title{font-family:Outfit,sans-serif;font-size:1.6rem;font-weight:700;color:var(--text-primary)}.ps-title-error{color:#c0392b}.ps-subtitle{font-size:.95rem;color:var(--text-secondary);max-width:380px;line-height:1.6}.ps-progress-bar{width:100%;max-width:280px;height:6px;background:var(--brand-lavender);border-radius:99px;overflow:hidden;margin-top:8px}.ps-progress-fill{height:100%;background:linear-gradient(90deg,var(--brand-primary),var(--brand-primary-light));border-radius:99px}.ps-error-icon{font-size:60px;line-height:1}.ps-error-note{background:#ff9f431a;border:1px solid rgba(255,159,67,.3);border-radius:12px;padding:14px 18px;font-size:.875rem;color:#7a5700;text-align:left;max-width:400px;line-height:1.6}.ps-success-banner{background:linear-gradient(135deg,var(--brand-primary-dark) 0%,var(--brand-primary-light) 100%);padding:36px 36px 28px;display:flex;align-items:flex-start;gap:20px;color:#fff;position:relative;overflow:hidden}.ps-success-banner:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 10%,rgba(255,255,255,.12) 0%,transparent 50%),radial-gradient(circle at 10% 90%,rgba(255,255,255,.08) 0%,transparent 50%)}.ps-success-banner>*{position:relative;z-index:1}.ps-check-circle{flex-shrink:0;color:#43e08a;filter:drop-shadow(0 0 12px rgba(67,224,138,.5));margin-top:4px}.ps-success-label{display:inline-flex;align-items:center;gap:5px;font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:#ffffff2e;border:1px solid rgba(255,255,255,.25);border-radius:99px;padding:4px 12px;margin-bottom:10px;color:#fffffff2}.ps-success-title{font-family:Outfit,sans-serif;font-size:1.75rem;font-weight:800;color:#fff;line-height:1.2;margin-bottom:6px}.ps-success-sub{font-size:.9rem;color:#fffc;line-height:1.5}.ps-details-section{padding:24px 32px;border-bottom:1px solid var(--border-light)}.ps-section-label{display:flex;align-items:center;gap:6px;font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--brand-primary);margin-bottom:16px}.ps-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.ps-detail-item{display:flex;align-items:flex-start;gap:10px;background:var(--brand-lavender);border:1px solid rgba(93,87,145,.1);border-radius:12px;padding:12px 14px}.ps-detail-icon{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--brand-primary),var(--brand-primary-light));color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ps-detail-item>div:last-child{display:flex;flex-direction:column;gap:2px;min-width:0}.ps-detail-key{font-size:.7rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.ps-detail-value{font-size:.9rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ps-mono{font-family:Courier New,monospace;font-size:.8rem!important;color:var(--brand-primary)!important}.ps-amount{color:var(--accent-green)!important;font-size:1rem!important;font-weight:700!important}.ps-status-badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:99px;font-size:.72rem;font-weight:700;text-transform:capitalize;background:#43b56a24;color:var(--accent-green);border:1px solid rgba(67,181,106,.3)}.ps-no-data-notice{display:flex;align-items:flex-start;gap:12px;padding:16px;background:#4e8ef714;border:1px solid rgba(78,142,247,.2);border-radius:12px;font-size:.875rem;color:var(--text-secondary);line-height:1.6}.ps-no-data-notice strong{color:var(--accent-blue)}.ps-no-data-notice svg{color:var(--accent-blue);margin-top:2px;flex-shrink:0}.ps-next-hint{display:flex;align-items:center;justify-content:center;gap:10px;padding:18px 32px;border-bottom:1px solid var(--border-light);flex-wrap:wrap;row-gap:8px}.ps-hint-step{display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--text-secondary);font-weight:500}.ps-hint-num{width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,var(--brand-primary),var(--brand-primary-light));color:#fff;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ps-hint-arrow{color:var(--text-tertiary);font-weight:300;font-size:1rem}.ps-actions{display:flex;gap:12px;padding:24px 32px;flex-wrap:wrap}.ps-btn-register{flex:1;min-width:200px;justify-content:center;font-size:.95rem;padding:14px 24px;border-radius:14px;background:linear-gradient(135deg,var(--brand-primary-dark),var(--brand-primary-light));box-shadow:0 6px 20px #6c5ce759}.ps-btn-register:hover{transform:translateY(-2px);box-shadow:0 10px 28px #6c5ce773}.ps-btn-home{min-width:160px;justify-content:center;border-radius:14px;padding:14px 20px}@media(max-width:600px){.ps-dialog{border-radius:20px;max-height:95vh}.ps-success-banner{padding:28px 20px 22px;flex-direction:column;text-align:center;align-items:center}.ps-success-title{font-size:1.4rem}.ps-details-section{padding:20px}.ps-detail-grid{grid-template-columns:1fr}.ps-next-hint{flex-direction:column;gap:6px}.ps-hint-arrow{transform:rotate(90deg)}.ps-actions{flex-direction:column;padding:20px}.ps-btn-register,.ps-btn-home{width:100%;min-width:unset}.ps-state-center{padding:36px 24px}}.pc-blob-1{background:radial-gradient(circle,rgba(239,68,68,.12) 0%,transparent 70%)!important}.pc-blob-2{background:radial-gradient(circle,rgba(255,159,67,.12) 0%,transparent 70%)!important}.pc-banner{background:linear-gradient(135deg,#c0392b,#e74c3c 60%,#ff6b6b);padding:36px 36px 28px;display:flex;align-items:flex-start;gap:20px;color:#fff;position:relative;overflow:hidden}.pc-banner:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 10%,rgba(255,255,255,.12) 0%,transparent 50%),radial-gradient(circle at 10% 90%,rgba(255,255,255,.08) 0%,transparent 50%)}.pc-banner>*{position:relative;z-index:1}.pc-icon{flex-shrink:0;color:#fffffff2;filter:drop-shadow(0 0 12px rgba(255,100,100,.4));margin-top:4px}.pc-label{display:inline-flex;align-items:center;gap:5px;font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:#ffffff2e;border:1px solid rgba(255,255,255,.25);border-radius:99px;padding:4px 12px;margin-bottom:10px;color:#fffffff2}.pc-title{font-family:Outfit,sans-serif;font-size:1.75rem;font-weight:800;color:#fff;line-height:1.2;margin-bottom:6px}.pc-sub{font-size:.9rem;color:#ffffffd1;line-height:1.5}.pc-info-section{padding:24px 32px;border-bottom:1px solid var(--border-light);display:flex;flex-direction:column;gap:12px}.pc-info-box{display:flex;align-items:flex-start;gap:12px;background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:12px;padding:16px}.pc-info-icon{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.pc-info-box strong{display:block;font-size:.875rem;font-weight:700;color:var(--text-primary);margin-bottom:4px}.pc-info-box p{font-size:.825rem;color:var(--text-secondary);line-height:1.5;margin:0}.pc-btn-retry{background:linear-gradient(135deg,#c0392b,#e74c3c)!important;box-shadow:0 6px 20px #e74c3c59!important}.pc-btn-retry:hover{box-shadow:0 10px 28px #e74c3c73!important}@media(max-width:600px){.pc-banner{padding:28px 20px 22px;flex-direction:column;text-align:center;align-items:center}.pc-title{font-size:1.4rem}.pc-info-section{padding:20px}}.dashboard-container{display:flex;min-height:100vh;background-color:var(--bg-primary)}.sidebar{width:260px;background:#fff;border-right:1px solid var(--border-light);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;z-index:50;transition:transform .3s ease}.sidebar-header{height:80px;display:flex;align-items:center;padding:0 24px;gap:12px;border-bottom:1px solid var(--border-light)}.sidebar-close-btn{display:none;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;border-radius:8px}.sidebar-close-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.brand-icon-sm{width:36px;height:36px;background:linear-gradient(135deg,var(--brand-primary),var(--brand-primary-light));border-radius:10px;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.2rem}.brand-text{font-family:Outfit,sans-serif;font-weight:700;font-size:1.2rem;color:var(--brand-primary-dark)}.sidebar-nav{flex:1;padding:24px 16px;display:flex;flex-direction:column;gap:8px}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:12px;color:var(--text-secondary);font-weight:500;font-size:.95rem;font-family:inherit;transition:all .2s ease;position:relative;background:transparent;width:100%;text-align:left;border:none;cursor:pointer}.nav-item:hover{background:var(--brand-lavender);color:var(--brand-primary)}.nav-item.active{background:linear-gradient(90deg,var(--brand-lavender),transparent);color:var(--brand-primary);font-weight:600}.active-indicator{position:absolute;left:0;top:10%;bottom:0;height:80%;width:4px;background:var(--brand-primary);border-radius:0 4px 4px 0}.sidebar-footer{padding:24px 16px;border-top:1px solid var(--border-light)}.nav-item.warning:hover{background:#fef2f2;color:#ef4444}.dashboard-main{flex:1;display:flex;flex-direction:column;min-width:0}.dashboard-header{height:80px;display:flex;align-items:center;justify-content:space-between;padding:0 32px;background:#fffc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:sticky;top:0;z-index:40;border-bottom:1px solid var(--border-light)}.header-search{flex:1;max-width:400px}.header-user{display:flex;align-items:center;gap:16px}.user-info{text-align:right}.user-name{display:block;font-weight:600;font-size:.9rem;color:var(--text-primary)}.user-role{display:block;font-size:.75rem;color:var(--text-tertiary)}.user-avatar{width:40px;height:40px;background:var(--brand-lavender);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--brand-primary);font-weight:600;border:2px solid white;box-shadow:var(--shadow-sm)}.dashboard-content{flex:1;padding:32px;overflow-y:auto}.menu-toggle{display:none;background:none;border:none;color:var(--text-secondary)}@media(max-width:768px){.sidebar{position:fixed;left:0;top:0;bottom:0;transform:translate(-100%);box-shadow:var(--shadow-xl)}.sidebar.open{transform:translate(0)}.dashboard-header{padding:0 16px}.menu-toggle{display:block;margin-right:16px}.dashboard-content{padding:16px}.sidebar-close-btn{display:block}}.modal-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100}.modal-content{background:#fff;width:90%;max-width:500px;border-radius:20px;padding:32px;position:relative;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl)}.modal-close{position:absolute;top:20px;right:20px;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:50%;transition:all .2s}.modal-close:hover{background:var(--bg-secondary);color:var(--text-primary)}.modal-header{margin-bottom:24px;text-align:center}.modal-header h2{font-size:1.5rem;color:var(--text-primary);margin-bottom:4px}.modal-header p{color:var(--text-secondary);font-size:.9rem}.profile-form{display:flex;flex-direction:column;gap:16px}.form-group label{display:block;font-size:.9rem;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.input-wrapper{display:flex;align-items:center;gap:12px;background:var(--bg-secondary);padding:12px 16px;border-radius:12px;border:1px solid transparent;transition:all .2s}.input-wrapper:focus-within{background:#fff;border-color:var(--brand-primary);box-shadow:0 0 0 3px #6c5ce71a}.input-wrapper input{border:none;background:none;flex:1;font-size:.95rem;color:var(--text-primary);outline:none}.btn-primary{margin-top:8px;background:var(--brand-primary);color:#fff;border:none;padding:14px;border-radius:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s}.btn-primary:hover{background:var(--brand-primary-dark)}.btn-primary:disabled{opacity:.7;cursor:not-allowed}.message-banner{padding:12px;border-radius:8px;margin-bottom:16px;font-size:.9rem;text-align:center}.message-banner.success{background:#ecfdf5;color:#059669}.message-banner.error{background:#fef2f2;color:#dc2626}.notif-bell-btn{position:relative;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;border:none;background:#6c5ce71a;color:var(--text-primary, #1a1a2e);cursor:pointer;transition:background .2s,transform .15s;flex-shrink:0}.notif-bell-btn:hover{background:#6c5ce733;transform:scale(1.08)}.notif-badge{position:absolute;top:3px;right:3px;min-width:18px;height:18px;padding:0 4px;border-radius:9px;background:#ff6b6b;color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1;box-shadow:0 0 0 2px #fff;animation:badge-pop .3s cubic-bezier(.34,1.56,.64,1)}@keyframes badge-pop{0%{transform:scale(0)}to{transform:scale(1)}}@keyframes bell-shake{0%,to{transform:rotate(0)}20%{transform:rotate(-12deg)}40%{transform:rotate(12deg)}60%{transform:rotate(-8deg)}80%{transform:rotate(8deg)}}.notif-bell-btn.has-unread svg{animation:bell-shake .6s ease-in-out}.notif-panel-wrapper{position:relative}.notif-panel{position:absolute;top:calc(100% + 10px);right:0;width:360px;max-height:480px;background:#fff;border-radius:16px;box-shadow:0 8px 40px #00000029;border:1px solid rgba(108,92,231,.1);overflow:hidden;display:flex;flex-direction:column;z-index:1000;transform-origin:top right}.notif-panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid #f0f0f0;background:linear-gradient(135deg,#6c5ce7,#a29bfe);color:#fff}.notif-panel-header h3{font-size:15px;font-weight:700;margin:0;letter-spacing:.02em}.notif-panel-actions{display:flex;align-items:center;gap:8px}.notif-action-btn{background:#fff3;border:none;color:#fff;font-size:11px;font-weight:600;padding:4px 10px;border-radius:20px;cursor:pointer;transition:background .2s;white-space:nowrap}.notif-action-btn:hover{background:#ffffff59}.notif-list{overflow-y:auto;flex:1;max-height:380px}.notif-list::-webkit-scrollbar{width:4px}.notif-list::-webkit-scrollbar-track{background:transparent}.notif-list::-webkit-scrollbar-thumb{background:#e0e0e0;border-radius:4px}.notif-item{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-bottom:1px solid #f7f7f7;cursor:pointer;transition:background .15s;position:relative}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:#fafafa}.notif-item.unread{background:#f5f3ff}.notif-item.unread:hover{background:#ede9fe}.notif-unread-dot{position:absolute;top:16px;right:14px;width:7px;height:7px;border-radius:50%;background:#6c5ce7;flex-shrink:0}.notif-icon{flex-shrink:0;width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;background:#f0eeff}.notif-body{flex:1;min-width:0}.notif-title{font-size:13px;font-weight:600;color:#1a1a2e;line-height:1.4;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notif-message{font-size:12px;color:#6b7280;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notif-time{font-size:10px;color:#9ca3af;margin-top:4px;display:block}.notif-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:#9ca3af;text-align:center;gap:10px}.notif-empty .notif-empty-icon{font-size:36px;opacity:.5}.notif-empty p{font-size:13px;margin:0}.notif-type-topic_completed .notif-icon{background:#e8f8ee}.notif-type-high_score .notif-icon{background:#fff5e9}.notif-type-streak_milestone .notif-icon{background:#fff0f0}.notif-type-milestone .notif-icon{background:#ebf2ff}.milestone-backdrop{position:fixed;inset:0;background:#0a0a1eb3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px}.milestone-modal{background:linear-gradient(145deg,#1a1a2e,#16213e);border-radius:28px;padding:40px 32px;max-width:420px;width:100%;text-align:center;position:relative;overflow:hidden;box-shadow:0 24px 80px #6c5ce766;color:#fff}.milestone-confetti{position:absolute;inset:0;background:radial-gradient(circle at 20% 20%,rgba(255,215,0,.15) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(108,92,231,.3) 0%,transparent 50%);pointer-events:none}.milestone-emoji{font-size:72px;display:block;margin-bottom:16px;animation:milestone-bounce .8s cubic-bezier(.34,1.56,.64,1)}@keyframes milestone-bounce{0%{transform:scale(0) rotate(-15deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}.milestone-headline{font-size:26px;font-weight:800;margin-bottom:8px;background:linear-gradient(135deg,gold,orange);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.milestone-sub{font-size:15px;color:#ffffffb3;margin-bottom:4px}.milestone-topic-name{font-size:20px;font-weight:700;color:#a29bfe;margin-bottom:24px;padding:8px 16px;background:#6c5ce733;border-radius:12px;display:inline-block}.milestone-close-btn{background:linear-gradient(135deg,#6c5ce7,#a29bfe);color:#fff;border:none;padding:14px 32px;border-radius:50px;font-size:16px;font-weight:700;cursor:pointer;transition:transform .15s,box-shadow .2s;box-shadow:0 6px 20px #6c5ce766}.milestone-close-btn:hover{transform:translateY(-2px);box-shadow:0 10px 28px #6c5ce780}.milestone-stars{display:flex;justify-content:center;gap:6px;margin-bottom:16px}.milestone-star{font-size:22px;animation:star-pop .4s ease forwards;opacity:0}.milestone-star:nth-child(1){animation-delay:.2s}.milestone-star:nth-child(2){animation-delay:.35s}.milestone-star:nth-child(3){animation-delay:.5s}@keyframes star-pop{0%{transform:scale(0) rotate(-45deg);opacity:0}60%{transform:scale(1.3) rotate(15deg);opacity:1}to{transform:scale(1) rotate(0);opacity:1}}.heatmap-card{padding:20px}.heatmap-grid{display:flex;gap:3px;overflow-x:auto;padding-bottom:4px}.heatmap-week{display:flex;flex-direction:column;gap:3px}.heatmap-day{width:13px;height:13px;border-radius:3px;background:#f0eeff;transition:transform .1s;cursor:default;flex-shrink:0}.heatmap-day:hover{transform:scale(1.4)}.heatmap-day.level-1{background:#c4b5fd}.heatmap-day.level-2{background:#8b5cf6}.heatmap-day.level-3{background:#6c5ce7}.heatmap-legend{display:flex;align-items:center;gap:6px;margin-top:10px;font-size:11px;color:#9ca3af;justify-content:flex-end}.heatmap-legend-box{width:12px;height:12px;border-radius:3px}.streak-highlight-card{background:linear-gradient(135deg,#ff9f43,#ff6b6b);border-radius:16px;padding:0;overflow:hidden}.streak-highlight-card .stat-card{background:transparent;border:none;box-shadow:none}@media(max-width:640px){.notif-panel{width:calc(100vw - 32px);right:-60px}}.home-dashboard{display:flex;flex-direction:column;gap:24px}.hero-banner{position:relative;overflow:hidden;background:linear-gradient(135deg,#1e1b4b,#312e81 45%,#4c1d95);border-radius:24px;padding:36px 40px;color:#fff;box-shadow:0 12px 40px #6c5ce759}.hero-orb{position:absolute;border-radius:50%;filter:blur(60px);pointer-events:none}.hero-orb-1{width:300px;height:300px;background:#a78bfa40;top:-80px;right:-60px;animation:orbFloat1 8s ease-in-out infinite}.hero-orb-2{width:200px;height:200px;background:#fbbf2426;bottom:-60px;left:100px;animation:orbFloat2 6s ease-in-out infinite}.hero-orb-3{width:160px;height:160px;background:#34d39926;top:20px;left:250px;animation:orbFloat1 10s ease-in-out infinite reverse}@keyframes orbFloat1{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-20px) scale(1.08)}}@keyframes orbFloat2{0%,to{transform:translate(0) scale(1)}50%{transform:translate(18px) scale(1.05)}}.hero-content{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}.hero-text{flex:1}.hero-date{font-size:.8rem;font-weight:600;color:#ffffff80;text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px}.hero-title{font-size:2rem;font-weight:800;line-height:1.15;margin-bottom:8px;color:#fff}.hero-name{background:linear-gradient(90deg,#a78bfa,#f9a8d4,#fbbf24);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;background-size:200% auto;animation:shimmerText 4s linear infinite}@keyframes shimmerText{0%{background-position:0% center}to{background-position:200% center}}.hero-subtitle{font-size:.9rem;color:#fff9;line-height:1.5}.hero-add-btn{display:flex;align-items:center;gap:10px;padding:12px 22px;background:#ffffff26;color:#fff;border:1.5px solid rgba(255,255,255,.3);border-radius:14px;font-size:.9rem;font-weight:700;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-family:Outfit,sans-serif;white-space:nowrap;transition:background .2s,border-color .2s}.hero-add-btn:hover{background:#ffffff40;border-color:#ffffff80}.metrics-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.metric-card{position:relative;background:var(--mc-bg);border-radius:18px;padding:18px 20px;border:1.5px solid color-mix(in srgb,var(--mc-color) 15%,transparent);overflow:hidden;display:flex;align-items:center;gap:14px;cursor:default;transition:box-shadow .25s}.mc-icon-wrap{width:46px;height:46px;border-radius:14px;background:color-mix(in srgb,var(--mc-color) 18%,white);color:var(--mc-color);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 12px var(--mc-glow)}.mc-body{display:flex;flex-direction:column;min-width:0}.mc-value{font-size:1.6rem;font-weight:800;color:var(--mc-color);line-height:1;letter-spacing:-.03em}.mc-label{font-size:.72rem;font-weight:700;color:color-mix(in srgb,var(--mc-color) 70%,#555);text-transform:uppercase;letter-spacing:.05em;margin-top:3px}.mc-glow-ring{position:absolute;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,var(--mc-glow) 0%,transparent 70%);right:-30px;top:50%;transform:translateY(-50%);pointer-events:none}.bento-grid{display:grid;grid-template-columns:1fr 340px;gap:20px;align-items:start}.bento-left{display:flex;flex-direction:column;gap:20px}.bento-card{background:#fff;border-radius:22px;border:1px solid #eeedf8;box-shadow:0 2px 16px #0000000d;overflow:hidden}.bento-card-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 0}.bento-card-title{display:flex;align-items:center;gap:9px;font-size:.95rem;font-weight:700;color:var(--text-primary)}.bento-title-icon{color:var(--brand-primary)}.chart-subtitle{font-size:.75rem;font-weight:600;color:var(--text-tertiary)}.champions-card{padding-bottom:24px}.btn-add-child-sm{display:flex;align-items:center;gap:6px;padding:7px 14px;background:var(--brand-primary);color:#fff;border:none;border-radius:10px;font-size:.8rem;font-weight:700;cursor:pointer;transition:all .2s;font-family:Outfit,sans-serif}.btn-add-child-sm:hover{background:#5849bf;transform:translateY(-1px)}.children-grid-modern{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;padding:16px 24px}.player-card{position:relative;background:#fff;border-radius:18px;padding:20px 18px;overflow:hidden;border:1.5px solid #f0eefb;box-shadow:0 2px 10px #0000000a;cursor:pointer;display:flex;flex-direction:column;align-items:center;text-align:center;transition:border-color .25s,box-shadow .25s}.player-card:hover{border-color:#6c5ce74d}.player-card-bg{position:absolute;top:0;left:0;right:0;height:72px;background:linear-gradient(135deg,#ede9fe,#fce7f3);z-index:0}.player-header{position:absolute;top:12px;left:12px;right:12px;display:flex;justify-content:space-between;align-items:center;z-index:2}.status-dot{width:9px;height:9px;border-radius:50%;border:2px solid white;box-shadow:0 0 0 1px #0000000f}.status-dot.online{background-color:#00d2d3;box-shadow:0 0 8px #00d2d3}.status-dot.web{background-color:#43b56a}.platform-badge{background:#ffffffe6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:3px 8px;border-radius:8px;font-size:.68rem;font-weight:700;color:var(--text-secondary)}.player-edit-btn{margin-left:auto;width:26px;height:26px;border-radius:7px;border:1.5px solid rgba(108,92,231,.2);background:#ffffffe6;color:var(--brand-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.player-edit-btn:hover{background:var(--brand-primary);color:#fff;border-color:var(--brand-primary);transform:scale(1.1)}.player-avatar-wrapper{position:relative;z-index:1;margin-top:18px;margin-bottom:10px}.player-avatar{width:72px;height:72px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.2rem;border:3px solid white;box-shadow:0 6px 18px #0000001a}.player-level-badge{position:absolute;bottom:-4px;left:50%;transform:translate(-50%);background:var(--brand-primary);color:#fff;font-size:.65rem;font-weight:800;padding:2px 8px;border-radius:10px;border:2px solid white;white-space:nowrap}.player-info h3{font-size:1rem;font-weight:700;color:var(--text-primary);margin-bottom:2px}.player-username{font-size:.8rem;color:var(--text-tertiary);margin-bottom:6px}.player-darjah{display:inline-block;background:#f5f3ff;color:var(--brand-primary);font-size:.7rem;font-weight:700;padding:3px 10px;border-radius:8px;margin-bottom:12px}.player-stats-mini{display:flex;gap:12px;margin-bottom:14px;background:#fafafa;padding:6px 14px;border-radius:10px;border:1px solid #f0eefb}.p-stat{display:flex;align-items:center;gap:5px;font-weight:700;font-size:.85rem;color:var(--text-primary)}.btn-view-profile{background:#fff;border:1px solid #e5e7eb;color:var(--text-secondary);padding:7px 14px;border-radius:10px;font-size:.8rem;font-weight:700;display:flex;align-items:center;gap:6px;transition:all .2s;width:100%;justify-content:center;font-family:Outfit,sans-serif}.player-card:hover .btn-view-profile{background:var(--brand-primary);color:#fff;border-color:var(--brand-primary)}.chart-bento-card{padding-bottom:20px}.chart-wrap{padding:16px 20px 0}.chart-tooltip{background:#1e1b4b;color:#fff;border-radius:12px;padding:10px 14px;font-size:.82rem;box-shadow:0 8px 24px #0003}.chart-tooltip-label{font-weight:800;margin-bottom:6px;color:#ffffffb3;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.chart-tooltip-row{font-weight:700;margin:2px 0}.rankings-bento-card{padding-bottom:0;position:sticky;top:90px}.rankings-list{display:flex;flex-direction:column;gap:4px;padding:14px 20px}.rank-item{position:relative;display:flex;align-items:center;gap:12px;padding:14px;border-radius:16px;transition:background .2s;cursor:default;overflow:hidden}.rank-item:hover{background:#fafaf8}.rank-item-top{background:linear-gradient(135deg,#fffbeb,#fff7e6);border:1.5px solid rgba(245,158,11,.25)}.rank-top-glow{position:absolute;inset:0;background:radial-gradient(ellipse at 0% 50%,rgba(245,158,11,.08),transparent 70%);pointer-events:none}.rank-pos{font-size:1.2rem;flex-shrink:0;width:26px;text-align:center}.rank-avatar-circle{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}.rank-details{flex:1;min-width:0}.rank-name{font-size:.88rem;font-weight:700;color:var(--text-primary);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rank-sub{font-size:.72rem;color:var(--text-tertiary);display:block;margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rank-bar-track{height:5px;background:#f0eefb;border-radius:4px;overflow:hidden}.rank-bar-fill{height:100%;border-radius:4px;min-width:6px}.rank-score-col{display:flex;flex-direction:column;align-items:flex-end;flex-shrink:0}.rank-score-num{font-size:1rem;font-weight:800;color:var(--text-primary);line-height:1}.rank-score-lbl{font-size:.65rem;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em}.family-totals{display:flex;gap:0;border-top:1px solid #f0eefb;margin-top:4px}.family-total-chip{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:14px 10px;text-align:center}.family-total-chip+.family-total-chip{border-left:1px solid #f0eefb}.ft-val{font-size:1.25rem;font-weight:800;color:var(--text-primary);line-height:1}.ft-lbl{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-tertiary)}.empty-dashboard-state{text-align:center;padding:40px 24px}.empty-icon-circle{width:80px;height:80px;background:#f5f3ff;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--brand-primary);margin:0 auto 20px}.empty-dashboard-state h3{font-size:1.2rem;font-weight:700;margin-bottom:8px}.empty-dashboard-state p{color:var(--text-secondary);margin-bottom:24px;font-size:.9rem}.loading-state{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px;color:var(--text-secondary)}.error-state-card{text-align:center;padding:32px;background:#fef2f2;border-radius:16px;color:#b91c1c;margin:16px 24px}.dashboard-banners{display:flex;flex-direction:column;gap:12px}.dashboard-banner{padding:16px;border-radius:16px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}.dashboard-banner.warning{background:#fffcf5;border:1px solid #fed7aa}.dashboard-banner.danger{background:#fef2f2;border:1px solid #fecaca}.banner-icon-circle{width:40px;height:40px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;font-size:1.2rem;box-shadow:0 2px 5px #0000000f}.banner-text{flex:1;min-width:200px}.banner-text strong{display:block;font-size:.95rem;margin-bottom:2px}.banner-text p{font-size:.85rem;color:var(--text-secondary);margin:0}.btn-banner{padding:8px 16px;background:var(--accent-orange, #f97316);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:.85rem;cursor:pointer;display:flex;align-items:center;gap:6px;white-space:nowrap}.btn-banner.danger{background:#ef4444}.pending-banner{flex-direction:column;align-items:stretch}.pending-banner-row{display:flex;align-items:center;gap:16px;width:100%;flex-wrap:wrap}.pending-banner-row .banner-text{flex:1}.pending-packages-list{margin-top:12px;border-top:1px dashed #fed7aa;padding-top:12px;display:flex;flex-direction:column;gap:8px}.pending-packages-hint{font-size:.8rem;color:var(--text-secondary);margin:0 0 6px}.pending-package-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;background:#fff;border:1px solid #fed7aa;border-radius:12px}.pending-pkg-info{display:flex;align-items:center;gap:10px;min-width:0}.pending-pkg-num{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--brand-primary),#a78bfa);color:#fff;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.pending-pkg-info strong{font-size:.9rem;color:var(--text-primary);font-weight:700;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pending-pkg-grade{font-size:.75rem;color:var(--text-secondary);margin-top:2px;display:block}.pending-pkg-btn{flex-shrink:0;white-space:nowrap;display:inline-flex;align-items:center;gap:6px}.edit-modal-overlay{position:fixed;inset:0;z-index:1000;background:#0a081e8c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:20px}.edit-modal-panel{background:#fff;border-radius:24px;box-shadow:0 24px 60px #0003,0 8px 24px #6c5ce71f;width:100%;max-width:500px;overflow:hidden;display:flex;flex-direction:column}.edit-modal-header{display:flex;align-items:center;justify-content:space-between;padding:24px 28px 18px;border-bottom:1px solid #f0eefb;background:linear-gradient(135deg,#f5f3ff,#fafafe)}.edit-modal-header-info{display:flex;align-items:center;gap:16px}.edit-modal-avatar{width:54px;height:54px;background:#fff;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.8rem;box-shadow:0 4px 12px #0000000f;border:1.5px solid rgba(108,92,231,.12)}.edit-modal-title{font-size:1.2rem;font-weight:800;color:var(--text-primary);margin-bottom:4px}.edit-modal-subtitle{margin:0}.edit-platform-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:700}.edit-platform-badge.web{background:#e8f5e9;color:#2e7d32}.edit-platform-badge.app{background:#e3f2fd;color:#1565c0}.edit-modal-close{width:36px;height:36px;border-radius:10px;border:none;background:#0000000f;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.edit-modal-close:hover{background:#fee2e2;color:#dc2626}.edit-toast{margin:14px 28px 0;padding:12px 16px;border-radius:12px;font-size:.875rem;font-weight:600;display:flex;align-items:center;gap:10px}.edit-toast.success{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.edit-toast.error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.edit-modal-form{padding:20px 28px 28px;display:flex;flex-direction:column;gap:18px}.edit-field-group{display:flex;flex-direction:column;gap:8px}.edit-field-label{font-size:.82rem;font-weight:700;color:var(--text-secondary);display:flex;align-items:center;gap:6px;text-transform:uppercase;letter-spacing:.04em}.edit-field-optional{font-weight:500;text-transform:none;letter-spacing:0;color:var(--text-tertiary);font-size:.78rem;margin-left:2px}.edit-field-input{width:100%;padding:11px 14px;border:1.5px solid #e5e7eb;border-radius:12px;font-size:.9rem;color:var(--text-primary);background:#fafafa;transition:all .2s;font-family:Outfit,sans-serif;box-sizing:border-box}.edit-field-input:focus{outline:none;border-color:var(--brand-primary);background:#fff;box-shadow:0 0 0 3px #6c5ce71a}.edit-input-prefix-wrap{display:flex;align-items:center;border:1.5px solid #e5e7eb;border-radius:12px;background:#fafafa;overflow:hidden;transition:all .2s}.edit-input-prefix-wrap:focus-within{border-color:var(--brand-primary);background:#fff;box-shadow:0 0 0 3px #6c5ce71a}.edit-input-prefix{padding:11px 4px 11px 14px;font-size:.9rem;color:var(--text-tertiary);font-weight:700;background:transparent;flex-shrink:0}.edit-field-input.prefix{border:none;border-radius:0;background:transparent;box-shadow:none;padding-left:4px}.edit-field-input.prefix:focus{outline:none;box-shadow:none}.edit-field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.edit-gender-group{display:flex;gap:8px}.edit-gender-btn{flex:1;padding:9px 12px;border-radius:10px;border:1.5px solid #e5e7eb;background:#fafafa;color:var(--text-secondary);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:Outfit,sans-serif}.edit-gender-btn.active{background:var(--brand-primary);color:#fff;border-color:var(--brand-primary);box-shadow:0 4px 12px #6c5ce740}.edit-gender-btn:hover:not(.active){border-color:var(--brand-primary);color:var(--brand-primary)}.edit-modal-footer{display:flex;gap:12px;justify-content:flex-end;padding-top:4px}.btn-edit-cancel{padding:10px 22px;border-radius:12px;border:1.5px solid #e5e7eb;background:#fff;color:var(--text-secondary);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:Outfit,sans-serif}.btn-edit-cancel:hover:not(:disabled){background:#f3f4f6}.btn-edit-save{padding:10px 22px;border-radius:12px;border:none;background:var(--brand-primary);color:#fff;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px;font-family:Outfit,sans-serif;box-shadow:0 4px 14px #6c5ce74d}.btn-edit-save:hover:not(:disabled){background:#5849bf;transform:translateY(-1px)}.btn-edit-save:disabled,.btn-edit-cancel:disabled{opacity:.6;cursor:not-allowed}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:spin .8s linear infinite}@media(max-width:1200px){.metrics-row{grid-template-columns:repeat(2,1fr)}.bento-grid{grid-template-columns:1fr}.rankings-bento-card{position:static}}@media(max-width:768px){.hero-banner{padding:20px;border-radius:20px}.hero-title{font-size:1.35rem}.hero-add-btn{padding:10px 16px;font-size:.85rem}.metrics-row{grid-template-columns:repeat(2,1fr);gap:10px}.mc-value{font-size:1.3rem}.children-grid-modern{grid-template-columns:1fr}.edit-modal-panel{border-radius:20px}.edit-field-row{grid-template-columns:1fr}.edit-modal-header,.edit-modal-form{padding-left:20px;padding-right:20px}}@media(max-width:480px){.hero-banner{padding:16px}.hero-title{font-size:1.2rem}.hero-date{font-size:.7rem;margin-bottom:4px}.hero-subtitle{font-size:.8rem;margin-top:4px}.metrics-row{grid-template-columns:1fr 1fr}.hero-orb{display:none}}.cs-container{display:flex;min-height:100vh;background-color:var(--bg-primary)}.cs-sidebar{width:260px;background:#fff;border-right:1px solid var(--border-light);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;z-index:50;transition:transform .3s ease;flex-shrink:0}.cs-sidebar-header{height:80px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;border-bottom:1px solid var(--border-light)}.cs-sidebar-close{display:none;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;border-radius:8px}.cs-sidebar-close:hover{background:var(--bg-secondary);color:var(--text-primary)}.cs-sidebar-profile{padding:24px 20px;text-align:center;border-bottom:1px solid var(--border-light)}.cs-profile-avatar{width:64px;height:64px;font-size:36px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f0eeff,#fff0f7);border-radius:50%;border:3px solid #E8E4FF;margin:0 auto 12px}.cs-profile-name{font-size:1.05rem;font-weight:700;color:var(--text-primary);margin:0 0 4px}.cs-profile-meta{font-size:.78rem;color:var(--text-tertiary);display:block}.cs-sidebar-nav{flex:1;padding:20px 16px;display:flex;flex-direction:column;gap:4px}.cs-nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:12px;color:var(--text-secondary);font-weight:500;font-size:.9rem;transition:all .2s ease;position:relative;background:transparent;width:100%;text-align:left;cursor:pointer;border:none}.cs-nav-item:hover{background:var(--brand-lavender);color:var(--brand-primary)}.cs-nav-item.active{background:linear-gradient(90deg,var(--brand-lavender),transparent);color:var(--brand-primary);font-weight:600}.cs-active-indicator{position:absolute;left:0;top:10%;height:80%;width:4px;background:var(--brand-primary);border-radius:0 4px 4px 0}.cs-nav-label{white-space:nowrap}.cs-nav-item.warning:hover{background:#fef2f2;color:#ef4444}.cs-sidebar-footer{padding:16px;border-top:1px solid var(--border-light);display:flex;flex-direction:column;gap:2px}.cs-sidebar-overlay{position:fixed;inset:0;background:#00000080;z-index:40}.cs-main{flex:1;display:flex;flex-direction:column;min-width:0}.cs-header{height:80px;display:flex;align-items:center;justify-content:space-between;padding:0 32px;background:#fffc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:sticky;top:0;z-index:30;border-bottom:1px solid var(--border-light)}.cs-header-title{font-size:1.2rem;font-weight:700;color:var(--text-primary);margin:0 0 0 8px}.cs-menu-toggle{display:none;background:none;border:none;color:var(--text-secondary);cursor:pointer;margin-right:8px}.cs-header-actions{display:flex;align-items:center;gap:16px}.cs-refresh-btn{background:none;border:1px solid var(--border-light);color:var(--text-secondary);width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.cs-refresh-btn:hover{background:var(--brand-lavender);color:var(--brand-primary);border-color:var(--brand-primary);transform:rotate(90deg)}.cs-refresh-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.cs-header-user{display:flex;align-items:center;gap:12px}.cs-user-info{text-align:right}.cs-user-name{display:block;font-weight:600;font-size:.9rem;color:var(--text-primary)}.cs-user-role{display:block;font-size:.73rem;color:var(--text-tertiary)}.cs-user-avatar{width:40px;height:40px;background:var(--brand-lavender);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--brand-primary);font-weight:600;font-size:.95rem;border:2px solid white;box-shadow:var(--shadow-sm)}.cs-content{flex:1;padding:28px 32px 48px;overflow-y:auto}.tab-inner{display:flex;flex-direction:column;gap:20px}.card-title{font-size:1rem;font-weight:700;margin-bottom:16px;color:var(--text-primary)}.stats-summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:8px}.stat-card.horizontal{display:flex;align-items:center;gap:16px;padding:16px 20px;background:#fff;border-radius:16px;border:1px solid rgba(0,0,0,.03);box-shadow:0 4px 12px #00000008;position:relative;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);text-align:left}.stat-card.horizontal:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 12px 24px #00000014;border-color:var(--color)}.stat-card.horizontal:after{content:"";position:absolute;top:0;right:0;bottom:0;width:4px;background:var(--color);opacity:.6}.stat-icon-wrapper{width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--accent);color:var(--color);flex-shrink:0;transition:transform .3s ease}.stat-card.horizontal:hover .stat-icon-wrapper{transform:rotate(-10deg) scale(1.1)}.stat-content{display:flex;flex-direction:column;justify-content:center;min-width:0}.stat-value{font-family:Outfit,sans-serif;font-size:1.35rem;font-weight:800;line-height:1.1;color:var(--text-primary);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stat-label{font-size:.8rem;color:var(--text-tertiary);font-weight:600;letter-spacing:.01em;text-transform:uppercase}.dash-grid-2col{display:grid;grid-template-columns:1fr 1fr;gap:20px}.dash-progress-card{padding:24px}.dash-progress-body{display:flex;align-items:center;gap:24px}.dash-pie-wrapper{position:relative;flex-shrink:0}.dash-pie-center{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.dash-pie-percent{font-family:Outfit,sans-serif;font-size:1.4rem;font-weight:800;color:var(--brand-primary)}.dash-progress-info{display:flex;flex-direction:column;gap:10px}.dash-progress-stat{display:flex;align-items:center;gap:8px;font-size:.88rem;color:var(--text-secondary)}.dash-progress-stat strong{color:var(--text-primary)}.text-success{color:#43b56a}.text-muted{color:#d0d5dd}.text-warning{color:#ff9f43}.dash-chart-card{padding:24px}.empty-chart-msg{text-align:center;padding:40px 16px;color:var(--text-tertiary);font-size:.88rem}.dash-bar-card,.dash-recent-card{padding:24px}.dash-recent-list{display:flex;flex-direction:column;gap:8px}.dash-recent-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;transition:background .15s}.dash-recent-item:hover{background:#fafafa}.dash-recent-score{width:40px;height:40px;border-radius:50%;border:2.5px solid;display:flex;align-items:center;justify-content:center;font-family:Outfit,sans-serif;font-weight:800;font-size:.85rem;background:#fff;flex-shrink:0}.dash-recent-info{flex:1;min-width:0}.dash-recent-name{display:block;font-size:.85rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-recent-date{font-size:.73rem;color:var(--text-tertiary)}.dash-recent-correct{font-size:.78rem;font-weight:600;color:#43b56a;flex-shrink:0}.progress-bar-container{width:100%;height:8px;background:#f0eeff;border-radius:100px;overflow:hidden}.progress-bar-large{height:12px}.progress-bar-sm{height:6px;margin-top:8px}.progress-bar-fill{height:100%;border-radius:100px;background:linear-gradient(90deg,#6c5ce7,#a29bfe);transition:width .6s cubic-bezier(.4,0,.2,1);min-width:0}.topic-progress-card{padding:24px}.topic-progress-list{display:flex;flex-direction:column;gap:14px}.topic-progress-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.topic-name{font-size:.85rem;font-weight:600;color:var(--text-primary);flex:1;margin-right:12px;line-height:1.3}.topic-count{font-size:.78rem;font-weight:700;color:var(--brand-primary);white-space:nowrap;background:#f0eeff;padding:2px 10px;border-radius:100px}.quest-topics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:16px}.quest-topic-group{padding:20px}.quest-topic-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.quest-topic-title-row{display:flex;align-items:center;gap:10px;flex:1}.quest-topic-icon{font-size:20px}.quest-topic-name{font-size:.95rem;font-weight:700;color:var(--text-primary)}.quest-topic-badge{font-size:.78rem;font-weight:700;color:var(--brand-primary);background:#f0eeff;padding:3px 12px;border-radius:100px;white-space:nowrap}.quest-topic-badge.complete{background:#e8f8ee;color:#43b56a}.quest-subtopic-list{margin-top:14px;display:flex;flex-direction:column;gap:4px;padding-left:4px}.quest-subtopic-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:10px;transition:background .15s;font-size:.86rem}.quest-subtopic-item:hover{background:#fafafa}.quest-subtopic-item.done{background:#f0fff4}.subtopic-check.done{color:#43b56a}.subtopic-check.pending{color:#d0d5dd}.subtopic-name{font-weight:500;color:var(--text-primary)}.quest-subtopic-item.done .subtopic-name{color:#43b56a}.quest-list{display:flex;flex-direction:column;gap:8px}.quest-item{display:flex;align-items:center;gap:14px;padding:16px}.quest-icon{font-size:24px;flex-shrink:0}.quest-info{flex:1}.quest-info h4{font-size:.95rem;font-weight:600;margin-bottom:2px}.quest-info p{font-size:.8rem;color:var(--text-tertiary)}.quest-score{text-align:right}.quest-score-value{display:block;font-weight:700;font-size:1.1rem;color:var(--brand-primary)}.quest-xp{font-size:.75rem;color:var(--accent-green);font-weight:600}.rank-left-col{display:flex;flex-direction:column;gap:16px}.rank-highlight{display:flex;align-items:center;gap:16px;padding:24px;background:linear-gradient(135deg,#f0eeff,#fff0f7);border:1px solid #E8E4FF}.rank-medal{flex-shrink:0}.rank-medal-icon{font-size:2.2rem}.rank-position-number{font-family:Outfit,sans-serif;font-size:2rem;font-weight:800;color:var(--brand-primary)}.rank-details{flex:1}.rank-details h3{font-size:1.05rem;font-weight:700}.rank-score{font-size:.85rem;color:var(--text-secondary);margin-top:2px}.rank-position-tag{font-size:.8rem;font-weight:700;color:var(--brand-primary);background:#fff;padding:6px 16px;border-radius:100px;white-space:nowrap;box-shadow:0 2px 8px #6c5ce71f}.podium-card{padding:24px}.podium{display:flex;flex-direction:column;gap:8px}.podium-item{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:12px;background:#fafafe;transition:all .15s}.podium-item:hover{background:#f0eeff}.podium-1{background:linear-gradient(135deg,#fff7e6,#fffaee);border:1px solid #FFDC73}.podium-2{background:linear-gradient(135deg,#f8f8fa,#f0f0f4);border:1px solid #DDDDE2}.podium-3{background:linear-gradient(135deg,#fff5ee,#fff8f3);border:1px solid #FFCBA4}.podium-medal{font-size:1.4rem;flex-shrink:0}.podium-name{flex:1;font-weight:600;font-size:.9rem}.podium-score{font-weight:700;color:var(--brand-primary);font-size:.9rem}.leaderboard-card{padding:24px}.leaderboard{display:flex;flex-direction:column;gap:4px}.leaderboard-row{display:flex;align-items:center;gap:12px;padding:11px 16px;border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border-light);transition:all .2s}.leaderboard-row:hover{background:#fafafe}.leaderboard-row.top-1{background:linear-gradient(135deg,#fff7e6,#fff0cc);border-color:#ffdc73}.leaderboard-row.top-2{background:linear-gradient(135deg,#f5f5f8,#eeeef2);border-color:#c0c0c8}.leaderboard-row.top-3{background:linear-gradient(135deg,#fff5ee,#ffe8d6);border-color:#ffcba4}.leaderboard-row.is-child{border:2px solid var(--brand-primary);background:#f8f6ff;box-shadow:0 2px 8px #6c5ce71f}.lb-rank{font-size:1rem;width:34px;text-align:center;font-weight:700;flex-shrink:0}.lb-name{flex:1;font-weight:500;font-size:.88rem}.lb-school{display:block;font-size:.73rem;color:#aaa;margin-top:1px}.lb-score{font-weight:700;color:var(--brand-primary);font-size:.9rem;white-space:nowrap}.latih-list{display:flex;flex-direction:column;gap:6px}.latih-item{display:flex;align-items:center;gap:16px;padding:12px 0;border-bottom:1px solid #F5F5F5;transition:background .15s}.latih-item:last-child{border-bottom:none}.latih-item:hover{background:#fafafe;border-radius:10px;padding-left:8px;padding-right:8px}.latih-score-ring{width:46px;height:46px;border-radius:50%;border:3px solid;display:flex;align-items:center;justify-content:center;font-family:Outfit,sans-serif;font-weight:800;font-size:.9rem;background:#fff;flex-shrink:0}.latih-info{flex:1;min-width:0}.latih-info h4{font-size:.88rem;font-weight:600;margin-bottom:3px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.latih-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.latih-tag{font-size:.7rem;font-weight:600;color:var(--brand-primary);background:#f0eeff;padding:2px 8px;border-radius:6px}.latih-date{font-size:.73rem;color:var(--text-tertiary);display:flex;align-items:center;gap:4px}.latih-result{text-align:right;flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:2px}.latih-correct-count{font-size:.73rem;color:var(--text-tertiary);font-weight:500}.latih-score-value{font-family:Outfit,sans-serif;font-weight:700;font-size:.9rem}.card-subtitle{font-size:.8rem;color:var(--text-tertiary);margin:-10px 0 16px}.latih-item.clickable{cursor:pointer;border-bottom:1px solid #F5F5F5;padding:12px 0;transition:all .2s}.latih-item.clickable:hover{background:#fafafe;border-radius:10px;padding-left:8px;padding-right:8px}.latih-item.clickable:last-child{border-bottom:none}.latih-arrow{color:var(--text-tertiary);transform:rotate(180deg);flex-shrink:0;opacity:.4;transition:opacity .2s,transform .2s}.latih-item.clickable:hover .latih-arrow{opacity:1;color:var(--brand-primary);transform:rotate(180deg) translate(2px)}.lt-summary-card{padding:16px 20px 14px;border-left:4px solid var(--brand-primary)}.lt-summary-top{display:flex;align-items:center;gap:14px;margin-bottom:12px}.lt-summary-score-ring{width:52px;height:52px;border-radius:50%;border:3px solid;display:flex;align-items:center;justify-content:center;font-family:Outfit,sans-serif;font-weight:800;font-size:1.1rem;background:#fff;flex-shrink:0}.lt-summary-info{flex:1;min-width:0}.lt-summary-title{font-size:1rem;font-weight:700;margin:0 0 4px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lt-summary-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.lt-mini-tag{font-size:.68rem;font-weight:600;color:var(--brand-primary);background:#f0eeff;padding:2px 6px;border-radius:5px}.lt-summary-date{display:flex;align-items:center;gap:4px;font-size:.7rem;color:var(--text-tertiary)}.lt-summary-bottom{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.lt-stat-pills{display:flex;gap:6px;flex-wrap:wrap;flex:1}.lt-stat-pill{font-size:.72rem;font-weight:600;padding:3px 10px;border-radius:100px;white-space:nowrap}.lt-stat-pill.correct{color:#43b56a;background:#e8f8ee}.lt-stat-pill.wrong{color:#ff6b6b;background:#fee}.lt-stat-pill.neutral{color:var(--text-secondary);background:var(--bg-secondary)}.lt-score-bar{display:flex;align-items:center;gap:8px;flex-shrink:0}.lt-score-bar-track{width:100px;height:6px;background:#eeecf9;border-radius:100px;overflow:hidden}.lt-score-bar-fill{height:100%;border-radius:100px;transition:width .4s ease}.lt-score-bar-pct{font-family:Outfit,sans-serif;font-size:.8rem;font-weight:800;min-width:36px}.lt-detail-back{display:flex;align-items:center;gap:8px;background:none;border:none;color:var(--text-secondary);font-size:.88rem;font-weight:600;cursor:pointer;padding:10px 16px;border-radius:10px;transition:all .15s;margin-bottom:4px}.lt-detail-back:hover{background:var(--brand-lavender);color:var(--brand-primary)}.lt-detail-header{padding:28px}.lt-detail-title-row{display:flex;align-items:center;gap:20px;margin-bottom:24px}.lt-detail-score-ring{width:64px;height:64px;border-radius:50%;border:4px solid;display:flex;align-items:center;justify-content:center;font-family:Outfit,sans-serif;font-weight:800;font-size:1.3rem;background:#fff;flex-shrink:0}.lt-detail-title-info h2{font-size:1.15rem;font-weight:700;margin:0 0 6px;color:var(--text-primary)}.lt-detail-date{display:flex;align-items:center;gap:6px;font-size:.82rem;color:var(--text-tertiary)}.lt-detail-stats{display:flex;gap:12px;flex-wrap:wrap}.lt-detail-stat{flex:1;min-width:80px;text-align:center;padding:14px 8px;background:var(--bg-secondary);border-radius:12px}.lt-detail-stat-value{display:block;font-family:Outfit,sans-serif;font-size:1.4rem;font-weight:800;margin-bottom:2px;color:var(--brand-primary)}.lt-detail-stat-label{font-size:.72rem;font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.03em}.lt-questions-list{display:flex;flex-direction:column;gap:16px}.lt-question-card{padding:24px;position:relative;border-left:4px solid transparent}.lt-question-card.correct{border-left-color:#43b56a}.lt-question-card.wrong{border-left-color:#ff6b6b}.lt-q-header{display:flex;align-items:center;gap:10px;margin-bottom:14px}.lt-q-number{font-family:Outfit,sans-serif;font-weight:800;font-size:.9rem;color:var(--brand-primary);background:#f0eeff;padding:4px 12px;border-radius:8px}.lt-q-badge{font-size:.78rem;font-weight:700;padding:3px 12px;border-radius:100px}.lt-q-badge.correct{color:#43b56a;background:#e8f8ee}.lt-q-badge.wrong{color:#ff6b6b;background:#fee}.lt-q-points{font-size:.75rem;font-weight:600;color:var(--text-tertiary);margin-left:auto}.lt-q-text{font-size:.95rem;line-height:1.6;color:var(--text-primary);margin-bottom:16px;word-break:break-word}.lt-q-text img{max-width:100%;border-radius:8px;margin:8px 0}.lt-q-image-wrapper{margin-bottom:16px;text-align:center}.lt-q-image{max-width:100%;max-height:320px;object-fit:contain;border-radius:10px;border:1px solid var(--border-light)}.lt-q-options{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}.lt-q-option{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:10px;border:1px solid var(--border-light);background:var(--bg-card);transition:all .15s;font-size:.9rem}.lt-q-option.correct{background:#e8f8ee;border-color:#43b56a}.lt-q-option.wrong{background:#fee;border-color:#ff6b6b}.lt-q-option.selected{box-shadow:0 0 0 2px #6c5ce726}.lt-q-option-label{font-family:Outfit,sans-serif;font-weight:700;font-size:.85rem;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#f0eeff;color:var(--brand-primary);flex-shrink:0}.lt-q-option.correct .lt-q-option-label{background:#43b56a;color:#fff}.lt-q-option.wrong .lt-q-option-label{background:#ff6b6b;color:#fff}.lt-q-option-text{flex:1;color:var(--text-primary);line-height:1.4;word-break:break-word}.lt-q-option-text img{max-width:100%;max-height:120px;object-fit:contain;border-radius:6px;margin:4px 0}.lt-q-option-icon{flex-shrink:0}.lt-q-option-icon.correct{color:#43b56a}.lt-q-option-icon.wrong{color:#ff6b6b}.lt-q-explanation{font-size:.82rem;color:var(--text-secondary);padding:10px 14px;background:#fff9f0;border-radius:8px;border-left:3px solid #FF9F43;margin-top:4px}.lt-q-explanation strong{color:var(--text-primary)}.lt-detail-layout{display:flex;gap:20px;align-items:stretch;margin-top:8px}.lt-numpad{flex-shrink:0;width:162px;overflow-y:auto;scrollbar-width:none;background:#fff;border-radius:18px;border:1px solid #eef2f6;box-shadow:0 4px 20px #0000000f,0 1px 4px #0000000a;padding:14px 12px 12px;display:flex;flex-direction:column;gap:10px}.lt-numpad::-webkit-scrollbar{display:none}.lt-numpad-header{font-size:.6rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:#94a3b8;text-align:center;padding-bottom:10px;border-bottom:1px solid #f1f5f9}.lt-numpad-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px}.lt-numpad-btn{aspect-ratio:1;border:none;border-radius:10px;font-size:.82rem;font-weight:700;cursor:pointer;min-height:40px;font-family:Outfit,sans-serif;line-height:1;transition:transform .14s cubic-bezier(.34,1.56,.64,1),box-shadow .14s ease,background .14s ease}.lt-numpad-btn.correct{background:#f0fdf4;color:#16a34a;border:1.5px solid #bbf7d0}.lt-numpad-btn.wrong{background:#fff5f5;color:#dc2626;border:1.5px solid #fecaca}.lt-numpad-btn:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 4px 10px #00000014}.lt-numpad-btn:active{transform:scale(.96)}.lt-numpad-btn.active.correct{background:#22c55e;color:#fff;border-color:#22c55e;transform:scale(1.12);box-shadow:0 0 0 3px #22c55e33,0 4px 12px #22c55e4d}.lt-numpad-btn.active.wrong{background:#ef4444;color:#fff;border-color:#ef4444;transform:scale(1.12);box-shadow:0 0 0 3px #ef444433,0 4px 12px #ef44444d}.lt-numpad-legend{display:flex;align-items:center;justify-content:center;gap:5px;padding-top:8px;border-top:1px solid #f1f5f9;font-size:.62rem;font-weight:600;color:#94a3b8;letter-spacing:.03em}.lt-legend-dot{display:inline-block;width:7px;height:7px;border-radius:50%}.lt-legend-dot.correct{background:#22c55e}.lt-legend-dot.wrong{background:#ef4444}.lt-ql-card.lt-ql-active{box-shadow:0 0 0 2px #6c5ce7,0 6px 20px #6c5ce71f;transform:translate(3px);transition:box-shadow .3s ease,transform .3s ease}.lt-ql-scroll{flex:1;min-width:0;max-height:calc(100vh - 260px);min-height:400px;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:8px;padding-right:4px;scrollbar-width:thin;scrollbar-color:#e2e8f0 transparent}.lt-ql-scroll::-webkit-scrollbar{width:4px}.lt-ql-scroll::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:4px}.lt-ql-card{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-light);border-left:3px solid transparent;padding:12px 16px;transition:box-shadow .15s}.lt-ql-card:hover{box-shadow:0 2px 10px #6c5ce70f}.lt-ql-card.correct{border-left-color:#43b56a}.lt-ql-card.wrong{border-left-color:#ff6b6b}.lt-ql-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.lt-ql-num{font-family:Outfit,sans-serif;font-weight:800;font-size:.78rem;color:var(--brand-primary);background:#f0eeff;padding:2px 9px;border-radius:6px}.lt-ql-badge{font-size:.7rem;font-weight:700;padding:2px 10px;border-radius:100px}.lt-ql-badge.correct{color:#43b56a;background:#e8f8ee}.lt-ql-badge.wrong{color:#ff6b6b;background:#fee}.lt-ql-pts{font-size:.68rem;font-weight:600;color:var(--text-tertiary);margin-left:auto}.lt-ql-question{font-size:.88rem;line-height:1.5;color:var(--text-primary);margin-bottom:10px;word-break:break-word}.lt-ql-question img{max-width:100%;border-radius:6px;margin:4px 0}.lt-ql-img-wrap{margin-bottom:10px;text-align:center}.lt-ql-img{max-width:100%;max-height:220px;object-fit:contain;border-radius:8px;border:1px solid var(--border-light)}.lt-ql-options{display:flex;flex-direction:column;gap:5px;margin-bottom:6px}.lt-ql-opt{display:flex;align-items:center;gap:10px;padding:7px 12px;border-radius:8px;border:1px solid var(--border-light);background:var(--bg-card);font-size:.83rem;transition:all .12s}.lt-ql-opt.correct{background:#e8f8ee;border-color:#43b56a}.lt-ql-opt.wrong{background:#fee;border-color:#ff6b6b}.lt-ql-opt-lbl{font-family:Outfit,sans-serif;font-weight:700;font-size:.75rem;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#f0eeff;color:var(--brand-primary);flex-shrink:0}.lt-ql-opt.correct .lt-ql-opt-lbl{background:#43b56a;color:#fff}.lt-ql-opt.wrong .lt-ql-opt-lbl{background:#ff6b6b;color:#fff}.lt-ql-opt-txt{flex:1;color:var(--text-primary);line-height:1.4;word-break:break-word}.lt-ql-opt-txt img{max-width:100%;max-height:80px;object-fit:contain;border-radius:4px}.lt-ql-icon{flex-shrink:0}.lt-ql-icon.correct{color:#43b56a}.lt-ql-icon.wrong{color:#ff6b6b}.lt-ql-note{font-size:.75rem;color:var(--text-secondary);padding:6px 10px;background:#fff9f0;border-radius:6px;border-left:2px solid #FF9F43;margin-top:2px}.lt-ql-note.correct{background:#f0faf4;border-left-color:#43b56a}.lt-ql-note strong{color:var(--text-primary)}.no-data{text-align:center;padding:56px 24px;color:var(--text-tertiary)}.no-data-icon{font-size:48px;display:block;margin-bottom:12px;opacity:.6}.no-data p{font-size:.9rem}.error-state{text-align:center;padding:48px 24px;color:var(--text-tertiary)}.error-icon{font-size:36px;display:block;margin-bottom:8px}.error-state p{font-size:.85rem;color:#ff6b6b}.loading-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;gap:12px;color:var(--text-tertiary)}@media(max-width:1024px){.stats-summary-grid{grid-template-columns:repeat(2,1fr)}.dash-grid-2col,.quest-topics-grid{grid-template-columns:1fr}}@media(max-width:768px){.cs-sidebar{position:fixed;left:0;top:0;bottom:0;transform:translate(-100%);box-shadow:var(--shadow-xl)}.cs-sidebar.open{transform:translate(0)}.cs-sidebar-close,.cs-menu-toggle{display:block}.cs-header{padding:0 16px}.cs-content{padding:16px}.stats-summary-grid{grid-template-columns:repeat(2,1fr);gap:10px}.rank-highlight{flex-direction:column;text-align:center}.rank-position-tag{align-self:center}.latih-item{flex-wrap:wrap;gap:10px}.latih-info h4{white-space:normal}}@media(max-width:480px){.stats-summary-grid{grid-template-columns:1fr 1fr;gap:8px}.stat-value{font-size:1.2rem}.stat-icon-wrapper{width:38px;height:38px}.stat-card{padding:16px 12px 14px}.cs-content{padding:12px}}.ach-hero{display:flex;align-items:center;padding:32px;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:20px;border:none;color:#fff;overflow:hidden;position:relative;margin-bottom:24px}.ach-hero:after{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M54.627 0l.83.83L14.333 41.953l-1.07-1.07L54.627 0zm-27.464 0l.707.707L13.88 13.88l-.707-.707L27.163 0zM8.406 51.543l.707.707-8.407 8.407-.707-.707 8.407-8.407zm27.464 0l.707.707-8.407 8.407-.707-.707 8.407-8.407zM.163 15.228l.707.707L-.707 16.142l-.707-.707.87-1.207zm25.307 43.109l.707.707-8.407 8.407-.707-.707 8.407-8.407zM.163 45.228l.707.707L-.707 46.142l-.707-.707.87-1.207z' fill='%23ffffff' fill-opacity='0.03' fill-rule='evenodd'/%3E%3C/svg%3E")}.ach-hero-left{display:flex;align-items:center;gap:32px;position:relative;z-index:1}.ach-ring-wrap{position:relative;width:110px;height:110px;flex-shrink:0}.ach-ring-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.ach-ring-num{font-family:Outfit,sans-serif;font-size:1.8rem;font-weight:800;line-height:1}.ach-ring-den{font-size:.8rem;color:#ffffff80;font-weight:600}.ach-hero-title{font-family:Outfit,sans-serif;font-size:1.6rem;font-weight:800;color:#fff;margin:0 0 6px}.ach-hero-sub{font-size:.9rem;color:#ffffffb3;margin:0 0 16px}.ach-hero-pills{display:flex;flex-wrap:wrap;gap:10px}.ach-hero-pill{font-size:.75rem;font-weight:700;padding:6px 14px;border-radius:100px;background:#ffffff14;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff}.ach-hero-pill.gold{background:#ff9f4333;color:#ff9f43}.ach-hero-pill.purple{background:#6c5ce733;color:#a29bfe}.ach-section{margin-bottom:32px}.ach-section-header{display:flex;align-items:center;gap:12px;margin-bottom:18px;padding-left:4px}.ach-section-title{font-family:Outfit,sans-serif;font-size:1.1rem;font-weight:700;color:#2d3436;margin:0}.ach-filter-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:24px}.ach-filter-btn{padding:8px 18px;border-radius:12px;border:1px solid #e2e8f0;background:#fff;color:#64748b;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);font-family:Outfit,sans-serif}.ach-filter-btn:hover{background:#f8fafc;border-color:#cbd5e1;transform:translateY(-1px)}.ach-filter-btn.active{background:#6c5ce7;color:#fff;border-color:#6c5ce7;box-shadow:0 4px 12px #6c5ce740}.ach-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.ach-card{display:flex;gap:16px;padding:20px;border-radius:16px;border:1px solid #eef2f6;background:#fff;position:relative;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #00000005}.ach-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0000000f}.ach-card.unlocked{border-color:#d1fae5;background-color:#fff;box-shadow:0 4px 12px #10b9810d}.ach-card.unlocked:before{content:"";position:absolute;top:0;left:0;bottom:0;width:4px;background:#10b981}.ach-shimmer{position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(16,185,129,.03),transparent);animation:achShimmer 4s infinite}.ach-badge-wrap{width:60px;height:60px;flex-shrink:0;position:relative}.ach-badge-img,.ach-badge-emoji{width:60px;height:60px;border-radius:14px;background:#f8fafc;display:flex;align-items:center;justify-content:center;font-size:1.6rem;transition:transform .3s}.ach-card:hover .ach-badge-img,.ach-card:hover .ach-badge-emoji{transform:scale(1.1) rotate(5deg)}.ach-card.unlocked .ach-badge-emoji{background:#ecfdf5;color:#10b981}.ach-info{flex:1;min-width:0}.ach-type-pill{display:inline-flex;align-items:center;font-size:.65rem;font-weight:800;padding:2px 8px;border-radius:6px;margin-bottom:8px;text-transform:uppercase;letter-spacing:.05em}.ach-title{font-family:Outfit,sans-serif;font-size:1rem;font-weight:700;color:#1e293b;margin:0 0 4px;line-height:1.2}.ach-desc{font-size:.8rem;color:#64748b;margin:0 0 12px;line-height:1.4}.ach-progress-track{width:100%;height:6px;background:#f1f5f9;border-radius:100px;margin-bottom:6px;overflow:hidden}.ach-progress-fill{height:100%;border-radius:100px;transition:width 1s cubic-bezier(.4,0,.2,1)}.ach-progress-label{display:block;text-align:right;font-size:.75rem;font-weight:700;margin-bottom:12px;color:#94a3b8}.ach-card.unlocked .ach-progress-label{color:#10b981}.ach-footer{display:flex;align-items:center;gap:12px;margin-top:4px}.ach-coins{font-size:.75rem;font-weight:700;color:#f59e0b;background:#fffbeb;padding:4px 10px;border-radius:8px;border:1px solid #fef3c7}.ach-date{font-size:.75rem;color:#10b981;font-weight:600;display:flex;align-items:center;gap:4px}.medal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:20px}.medal-card{padding:24px 16px;border-radius:20px;background:#fff;border:1px solid #eef2f6;text-align:center;transition:all .3s}.medal-card.unlocked{border-color:#fef3c7;background:linear-gradient(to bottom,#fff,#fffbeb);box-shadow:0 8px 20px #f59e0b14}.medal-img{width:80px;height:80px;margin-bottom:12px;filter:drop-shadow(0 4px 8px rgba(0,0,0,.1))}.medal-title{font-size:.9rem;font-weight:700;color:#1e293b;margin-bottom:8px}@media(max-width:640px){.ach-hero{padding:20px;flex-direction:column;text-align:center}.ach-hero-left{flex-direction:column;gap:16px}.ach-grid{grid-template-columns:1fr}}@media(max-width:768px){.lt-detail-layout{flex-direction:column;align-items:stretch;gap:10px}.lt-numpad{width:100%;flex-direction:column;padding:10px 12px 8px;border-radius:14px;gap:8px;overflow:visible}.lt-numpad-header{writing-mode:horizontal-tb;font-size:.58rem;border-bottom:1px solid #f1f5f9;border-right:none;padding:0 0 6px;text-align:left;letter-spacing:.1em}.lt-numpad-grid{display:flex;flex-direction:row;flex-wrap:nowrap;overflow-x:auto;gap:5px;padding-bottom:4px;scrollbar-width:none;grid-template-columns:unset;grid-auto-rows:unset}.lt-numpad-grid::-webkit-scrollbar{display:none}.lt-numpad-btn{flex-shrink:0;width:32px;height:32px;min-height:unset;aspect-ratio:unset;border-radius:8px;font-size:.75rem}.lt-numpad-btn.active.correct,.lt-numpad-btn.active.wrong{transform:scale(1.15)}.lt-numpad-legend{border-top:1px solid #f1f5f9;border-left:none;padding:6px 0 0;flex-direction:row;font-size:.6rem;justify-content:flex-start;gap:8px}.lt-ql-scroll{max-height:calc(100vh - 340px);min-height:280px}.lt-summary-card{padding:12px 14px 10px}.lt-summary-top{gap:10px;margin-bottom:8px}.lt-summary-score-ring{width:42px;height:42px;font-size:.95rem;border-width:2.5px}.lt-summary-title{font-size:.88rem;margin-bottom:3px}.lt-summary-meta{gap:4px}.lt-mini-tag{font-size:.62rem;padding:1px 5px}.lt-summary-date{font-size:.62rem}.lt-summary-bottom{gap:6px}.lt-stat-pills{gap:4px}.lt-stat-pill{font-size:.65rem;padding:3px 7px}.lt-ql-card{padding:10px 12px;border-radius:10px}.lt-ql-header{margin-bottom:6px;gap:6px}.lt-ql-num{font-size:.7rem;width:24px;height:24px}.lt-ql-badge{font-size:.65rem;padding:2px 8px}.lt-ql-question{font-size:.83rem;margin-bottom:8px;line-height:1.45}.lt-ql-options{gap:4px;margin-bottom:4px}.lt-ql-opt{padding:6px 10px;gap:8px;font-size:.79rem;border-radius:7px}.lt-ql-opt-lbl{width:20px;height:20px;font-size:.7rem}.lt-ql-note{font-size:.72rem;padding:5px 8px}.lt-ql-img{max-height:160px}.lt-detail-back{font-size:.8rem;padding:6px 0}}.lt-dashboard{gap:18px}.lt-hero-card{display:flex;align-items:center;gap:20px;background:linear-gradient(135deg,#5d5791,#6c5ce7 60%,#8b7cf8);border-radius:20px;padding:20px 24px;box-shadow:0 6px 24px #5d579147,0 2px 8px #0000000f;color:#fff;position:relative;overflow:hidden}.lt-hero-card:before{content:"";position:absolute;top:-40px;right:-40px;width:180px;height:180px;border-radius:50%;background:#ffffff14;pointer-events:none}.lt-hero-card:after{content:"";position:absolute;bottom:-30px;left:120px;width:140px;height:140px;border-radius:50%;background:#ffffff0f;pointer-events:none}.lt-hero-left{flex-shrink:0}.lt-hero-right{flex:1;min-width:0}.lt-hero-title{font-size:1.25rem;font-weight:800;margin:0 0 6px;color:#fff;letter-spacing:.01em}.lt-hero-subtitle{font-size:.85rem;color:#ffffffd9;margin:0 0 16px;font-weight:500}.lt-hero-tiles{display:flex;gap:12px;flex-wrap:wrap}.lt-hero-tile{display:flex;flex-direction:row;align-items:center;gap:14px;background:#ffffff1f;border:1px solid rgba(255,255,255,.15);border-radius:16px;padding:14px 20px;flex:1;min-width:140px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:transform .25s cubic-bezier(.4,0,.2,1),background .2s}.lt-hero-tile:hover{transform:translateY(-3px);background:#ffffff2e}.lt-hero-tile-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.lt-hero-tile-icon.correct{background:#4ade8033;color:#4ade80}.lt-hero-tile-icon.wrong{background:#ff878733;color:#ff8787}.lt-hero-tile-icon.trophy{background:#ffd43b33;color:#ffd43b}.lt-hero-tile-text{display:flex;flex-direction:column}.lt-hero-tile-lbl{font-size:.72rem;color:#fffc;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px}.lt-hero-tile-val{font-family:Outfit,sans-serif;font-size:1.45rem;font-weight:800;color:#fff;line-height:1}.lt-dash-row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.lt-panel{background:#fff;border-radius:20px;padding:20px 24px;box-shadow:0 2px 12px #0000000a;border:1px solid rgba(0,0,0,.04)}.lt-panel-header{display:flex;align-items:center;gap:10px;margin-bottom:16px}.lt-panel-icon{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}.lt-panel-title{font-size:.95rem;font-weight:700;color:var(--text-primary)}.lt-panel-empty{font-size:.83rem;color:var(--text-tertiary);text-align:center;padding:20px 0}.lt-week-strip{display:flex;justify-content:space-between;align-items:flex-end;gap:6px;min-height:60px;margin-bottom:12px}.lt-day-col{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;position:relative}.lt-day-bar-wrap{display:flex;align-items:flex-end;height:44px}.lt-day-bar{width:28px;background:#e8e8f0;border-radius:6px;transition:height .4s cubic-bezier(.4,0,.2,1),background .3s;min-height:4px}.lt-day-col.active .lt-day-bar{background:linear-gradient(180deg,#8b7cf8,#6c5ce7)}.lt-day-col.today .lt-day-bar{background:linear-gradient(180deg,#8b7cf8,#5d5791);box-shadow:0 2px 8px #6c5ce74d}.lt-day-label{font-size:.7rem;color:var(--text-tertiary);font-weight:600}.lt-day-col.active .lt-day-label{color:#6c5ce7}.lt-day-col.today .lt-day-label{color:#5d5791;font-weight:700}.lt-day-count{position:absolute;top:-2px;font-size:.62rem;font-weight:800;color:#6c5ce7;background:#f0eeff;border-radius:100px;padding:0 4px;white-space:nowrap}.lt-week-footer{border-top:1px solid #F5F5F5;padding-top:10px}.lt-week-info{font-size:.78rem;color:var(--brand-primary);background:#f0eeff;border-radius:100px;padding:5px 12px;font-weight:600}.lt-topic-list{display:flex;flex-direction:column;gap:12px}.lt-topic-row-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.lt-topic-name{font-size:.84rem;font-weight:600;color:var(--text-primary);flex:1;margin-right:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lt-topic-pct{font-size:.84rem;font-weight:800;flex-shrink:0}.lt-topic-bar-track{width:100%;height:7px;background:#f2f2f7;border-radius:100px;overflow:hidden}.lt-topic-bar-fill{height:100%;border-radius:100px;transition:width .8s cubic-bezier(.4,0,.2,1)}.lt-highlights-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.lt-highlight-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fafafa;border-radius:14px;border:1px solid #F0F0F0;transition:transform .2s,box-shadow .2s}.lt-highlight-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000000f}.lt-highlight-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}.lt-highlight-text{display:flex;flex-direction:column;gap:2px;min-width:0}.lt-highlight-label{font-size:.72rem;color:var(--text-tertiary);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.lt-highlight-val{font-size:.88rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lt-chart-card{padding:18px 24px}.lt-history-card{padding:0;overflow:hidden}.lt-history-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:18px 24px;background:none;border:none;cursor:pointer;font-size:1rem;font-weight:700;color:var(--text-primary);border-radius:20px;transition:background .15s}.lt-history-toggle:hover{background:#fafafa}.lt-toggle-chevron{font-size:1.1rem;color:var(--text-tertiary);transition:transform .3s ease}.lt-history-card .card-subtitle{padding:0 24px;font-size:.8rem;color:var(--text-tertiary);margin:0 0 12px}.lt-history-card .latih-list{padding:0 16px 16px}@media(max-width:900px){.lt-hero-card{flex-direction:column;align-items:flex-start;gap:16px;padding:24px 20px}.lt-dash-row2,.lt-highlights-grid{grid-template-columns:1fr}.lt-hero-tiles{gap:8px}.lt-hero-tile{min-width:120px;padding:10px 14px;gap:10px}}@media(max-width:600px){.lt-hero-tiles{width:100%;gap:8px}.lt-hero-tile{flex:1 1 100%}.lt-week-strip{gap:3px}.lt-day-bar{width:22px}.lt-highlights-grid{grid-template-columns:1fr;gap:10px}}.qt-dashboard{gap:18px}.qt-hero-card{display:flex;align-items:center;gap:24px;background:linear-gradient(135deg,#5d5791,#6c5ce7 55%,#8b7cf8);border-radius:20px;padding:22px 28px;color:#fff;box-shadow:0 6px 24px #5d579147;position:relative;overflow:hidden}.qt-hero-card:before{content:"";position:absolute;top:-30px;right:-30px;width:160px;height:160px;border-radius:50%;background:#ffffff12;pointer-events:none}.qt-hero-ring{flex-shrink:0}.qt-hero-info{flex:1;min-width:0}.qt-hero-title{font-size:1.15rem;font-weight:800;margin:0 0 4px;color:#fff}.qt-hero-sub{font-size:.82rem;color:#fffc;margin:0 0 14px}.qt-hero-pills{display:flex;align-items:center;gap:0;background:#ffffff21;border:1px solid rgba(255,255,255,.18);border-radius:14px;padding:10px 16px;width:fit-content;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.qt-hero-pill{display:flex;align-items:center;gap:8px;padding:0 16px}.qt-hero-pill:first-child{padding-left:0}.qt-hero-pill:last-child{padding-right:0}.qt-hero-divider{width:1px;height:28px;background:#ffffff40}.qt-pill-val{font-family:Outfit,sans-serif;font-size:1.15rem;font-weight:800;color:#fff}.qt-pill-lbl{font-size:.72rem;color:#fffc;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.qt-body{display:grid;grid-template-columns:1fr 380px;gap:16px;align-items:start}.qt-col-header{display:flex;align-items:center;gap:8px;font-size:.9rem;font-weight:700;color:var(--text-primary);margin-bottom:12px;padding:14px 18px;background:#fff;border-radius:14px 14px 0 0;border-bottom:1px solid #F2F2F7}.qt-col-badge{margin-left:auto;font-size:.73rem;font-weight:700;color:var(--brand-primary);background:#f0eeff;border-radius:100px;padding:3px 10px}.qt-topic-col{background:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000a;border:1px solid rgba(0,0,0,.04);overflow:hidden}.qt-topic-list{padding:6px 0 10px}.qt-topic-row{display:flex;align-items:center;gap:14px;padding:12px 18px;background:none;border:none;border-left:3px solid transparent;width:100%;text-align:left;cursor:pointer;transition:background .18s,border-color .2s}.qt-topic-row:hover{background:#fafafa;border-left-color:var(--tc1, #6c5ce7)}.qt-topic-row.selected{background:linear-gradient(90deg,color-mix(in srgb,var(--tc1, #6c5ce7) 8%,white),#fff);border-left-color:var(--tc1, #6c5ce7)}.qt-topic-row.complete .qt-topic-row-name{color:#43b56a}.qt-topic-icon-wrap{width:40px;height:40px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}.qt-topic-row-info{flex:1;min-width:0;text-align:left}.qt-topic-row-name{display:block;font-size:.92rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.qt-topic-row-sub{display:block;font-size:.75rem;color:var(--text-tertiary);margin-top:2px}.qt-done-badge{display:flex;align-items:center;gap:5px;font-size:.75rem;font-weight:700;color:#43b56a;background:#e8f8ee;border-radius:100px;padding:5px 11px;white-space:nowrap;flex-shrink:0}.qt-subtopic-expand{padding:4px 18px 10px 72px;display:flex;flex-direction:column;gap:4px}.qt-sub-item{display:flex;align-items:center;gap:9px;padding:6px 12px;border-radius:10px;font-size:.85rem;transition:background .15s}.qt-sub-item.done{background:#f0fff4}.qt-sub-item:not(.done):hover{background:#fafafa}.qt-sub-dot{flex-shrink:0}.qt-sub-dot.done{color:#43b56a}.qt-sub-dot:not(.done){color:#d0d5dd}.qt-sub-name{font-weight:500;color:var(--text-primary)}.qt-sub-item.done .qt-sub-name{color:#43b56a}.qt-history-col{background:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000a;border:1px solid rgba(0,0,0,.04);overflow:hidden;position:sticky;top:90px}.qt-history-title-text{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.qt-history-summary{display:flex;justify-content:space-around;padding:14px 16px;background:linear-gradient(135deg,#f7f5ff,#f0eeff);border-bottom:1px solid #EAE6FF}.qt-hs-item{display:flex;flex-direction:column;align-items:center;gap:3px}.qt-hs-val{font-family:Outfit,sans-serif;font-size:1.3rem;font-weight:800;color:var(--text-primary);line-height:1}.qt-hs-lbl{font-size:.68rem;color:var(--text-tertiary);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.qt-history-list{padding:8px 12px 14px;display:flex;flex-direction:column;gap:4px;max-height:520px;overflow-y:auto}.qt-history-empty{text-align:center;padding:32px 16px;color:var(--text-tertiary);font-size:.84rem;display:flex;flex-direction:column;align-items:center}.qt-history-item{display:flex;align-items:center;gap:10px;padding:10px;border-radius:12px;transition:background .15s}.qt-history-item:hover{background:#fafafa}.qt-hi-icon{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.qt-hi-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.qt-hi-name{font-size:.87rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.qt-hi-topic{font-size:.74rem;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.qt-hi-badges{display:flex;align-items:center;gap:6px;margin-top:2px;flex-wrap:wrap}.qt-hi-badge{display:inline-flex;align-items:center;gap:3px;font-size:.7rem;font-weight:600;border-radius:100px;padding:2px 7px}.qt-hi-badge.plays{background:#f0eeff;color:#6c5ce7}.qt-hi-badge.stars{background:#fffbea;color:#b38600;display:flex;gap:1px}.qt-hi-badge.pts{background:#e8f4ff;color:#0984e3}.qt-hi-date{font-size:.68rem;color:var(--text-tertiary);white-space:nowrap;text-align:right;flex-shrink:0}@media(max-width:1024px){.qt-body{grid-template-columns:1fr}.qt-history-col{position:static}}@media(max-width:600px){.qt-hero-card{flex-direction:column;align-items:flex-start;padding:18px 16px}.qt-hero-pills{flex-wrap:wrap;gap:8px}.qt-hero-divider{display:none}.qt-hero-pill{padding:0 8px}}.page-enter{opacity:0}.page-enter-active{opacity:1;transition:opacity .3s ease}.page-exit{opacity:1}.page-exit-active{opacity:0;transition:opacity .3s ease}select.input-field{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%239CA3AF' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:16px;padding-right:40px}select.input-field:disabled{opacity:.6;cursor:not-allowed}a:hover{text-decoration:underline}:focus-visible{outline:2px solid var(--brand-primary-light);outline-offset:2px}button:focus-visible{outline:2px solid var(--brand-primary-light);outline-offset:2px}
