@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700;900&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap";:root{--ink: #0d0d0d;--cream: #faf7f2;--gold: #c9a84c;--gold-light: #f0d9a0;--teal: #1a6b6b;--teal-light: #e6f4f4;--rose: #c0544a;--rose-light: #fcecea;--purple: #6b4fa0;--purple-light: #f0edf9;--slate: #3a4a5c;--mist: #e8edf3;--white: #ffffff;--radius: 16px;--shadow: 0 4px 24px rgba(13,13,13,.09);--shadow-lg: 0 8px 40px rgba(13,13,13,.16)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:DM Sans,sans-serif;background:var(--cream);color:var(--ink);min-height:100vh;-webkit-font-smoothing:antialiased}h1,h2,h3,h4{font-family:Playfair Display,serif;line-height:1.2}.app{display:flex;flex-direction:column;min-height:100vh}.nav{background:var(--ink);height:64px;padding:0 32px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;border-bottom:1px solid rgba(255,255,255,.05)}.nav-logo{font-family:Playfair Display,serif;font-size:1.45rem;font-weight:900;color:var(--gold);cursor:pointer;letter-spacing:-.5px}.nav-logo span{color:#fff}.nav-tabs{display:flex;gap:4px}.nav-tab{background:none;border:none;color:#ffffff8c;padding:8px 16px;border-radius:8px;cursor:pointer;font-family:DM Sans,sans-serif;font-size:.875rem;font-weight:500;transition:all .18s}.nav-tab:hover{color:#fff;background:#ffffff12}.nav-tab.active{color:var(--gold);background:#c9a84c1f}.nav-right{display:flex;align-items:center;gap:12px}.nav-badge{background:var(--teal);color:#fff;font-size:.75rem;font-weight:600;padding:4px 12px;border-radius:20px}.btn{padding:11px 24px;border-radius:10px;font-weight:600;font-family:DM Sans,sans-serif;font-size:.9rem;cursor:pointer;border:none;transition:all .18s;display:inline-flex;align-items:center;gap:8px;white-space:nowrap}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-gold{background:var(--gold);color:var(--ink)}.btn-gold:hover:not(:disabled){background:#d4af5e;transform:translateY(-1px);box-shadow:0 6px 20px #c9a84c4d}.btn-teal{background:var(--teal);color:#fff}.btn-teal:hover:not(:disabled){background:#155858;transform:translateY(-1px)}.btn-rose{background:var(--rose);color:#fff}.btn-rose:hover:not(:disabled){background:#a8443b;transform:translateY(-1px)}.btn-outline{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.35)}.btn-outline:hover:not(:disabled){border-color:#fff;background:#ffffff12}.btn-ghost{background:var(--mist);color:var(--slate)}.btn-ghost:hover:not(:disabled){background:#d5dde8}.btn-sm{padding:7px 16px;font-size:.82rem;border-radius:8px}.btn-danger{background:var(--rose-light);color:var(--rose)}.btn-danger:hover:not(:disabled){background:var(--rose);color:#fff}.btn-full{width:100%;justify-content:center}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.form-group label{font-size:.82rem;font-weight:600;color:var(--slate)}.form-control{padding:11px 14px;border-radius:9px;border:1.5px solid var(--mist);font-family:DM Sans,sans-serif;font-size:.92rem;background:#fff;transition:border-color .15s,box-shadow .15s;outline:none;color:var(--ink)}.form-control:focus{border-color:var(--teal);box-shadow:0 0 0 3px #1a6b6b1f}.form-control::placeholder{color:#aaa}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-error{font-size:.8rem;color:var(--rose);margin-top:4px}.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--mist)}.card-pad{padding:24px}.section-tag{font-size:.74rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--teal);margin-bottom:6px}.section-title{font-size:1.9rem;margin-bottom:6px}.section-sub{color:#777;font-size:.95rem;line-height:1.65}.pill{padding:3px 10px;border-radius:20px;font-size:.74rem;font-weight:600;display:inline-block}.pill-green{background:#e6f5e6;color:#256625}.pill-amber{background:#fff3d6;color:#960}.pill-blue{background:#def;color:#1a4d99}.pill-red{background:var(--rose-light);color:var(--rose)}.pill-purple{background:var(--purple-light);color:var(--purple)}.data-table{width:100%;border-collapse:collapse}.data-table-wrap{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.data-table th{background:var(--mist);padding:12px 16px;font-size:.75rem;font-weight:700;text-align:left;letter-spacing:.6px;text-transform:uppercase;color:var(--slate)}.data-table td{padding:12px 16px;font-size:.88rem;border-bottom:1px solid var(--mist)}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:#fafbfc}.prog-bar{height:8px;background:var(--mist);border-radius:4px;overflow:hidden}.prog-fill{height:100%;border-radius:4px;transition:width .4s ease}.spinner-wrap{display:flex;flex-direction:column;align-items:center;padding:60px 20px;gap:16px}.spinner{width:40px;height:40px;border-radius:50%;border:3px solid var(--mist);border-top-color:var(--teal);animation:spin .75s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.toast{position:fixed;bottom:24px;right:24px;z-index:500;background:var(--ink);color:#fff;padding:13px 20px;border-radius:10px;font-size:.875rem;font-weight:500;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-lg);animation:slideUp .25s ease;max-width:360px}.toast.toast-error{background:var(--rose)}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000007a;z-index:300;display:flex;align-items:center;justify-content:center;padding:24px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}}.modal{background:#fff;border-radius:var(--radius);padding:36px;max-width:460px;width:100%;box-shadow:var(--shadow-lg);animation:scaleIn .2s ease}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)}}.grade-scroll{display:flex;gap:8px;flex-wrap:wrap}.grade-pill{padding:7px 15px;border-radius:20px;border:1.5px solid var(--mist);background:#fff;cursor:pointer;font-size:.82rem;font-weight:600;transition:all .15s;color:var(--slate);font-family:DM Sans,sans-serif}.grade-pill:hover{border-color:var(--teal);color:var(--teal)}.grade-pill.active{background:var(--teal);color:#fff;border-color:var(--teal)}.drop-zone{border:2px dashed var(--mist);border-radius:12px;padding:40px;text-align:center;color:#aaa;cursor:pointer;transition:all .18s}.drop-zone:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-light)}.portal-layout{display:flex;flex:1;min-height:0}.sidebar{width:230px;background:var(--ink);padding:20px 12px;display:flex;flex-direction:column;gap:2px;flex-shrink:0}.sidebar-section{color:#ffffff4d;font-size:.68rem;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;padding:12px 12px 6px}.sidebar-btn{display:flex;align-items:center;gap:10px;color:#fff9;padding:10px 12px;border-radius:8px;cursor:pointer;font-size:.875rem;transition:all .15s;border:none;background:none;width:100%;text-align:left;font-family:DM Sans,sans-serif}.sidebar-btn:hover{background:#ffffff12;color:#fff}.sidebar-btn.active{background:#c9a84c26;color:var(--gold);font-weight:600}.portal-main{flex:1;padding:32px 36px;overflow-y:auto;background:var(--cream)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:28px}.stat-card{background:#fff;border-radius:12px;padding:20px 22px;border:1px solid var(--mist)}.stat-num{font-family:Playfair Display,serif;font-size:2rem;font-weight:700}.stat-label{font-size:.74rem;color:#999;text-transform:uppercase;letter-spacing:.5px;margin-top:2px}.stat-sub{font-size:.78rem;font-weight:600;margin-top:6px}.video-item{background:#fff;border-radius:12px;padding:16px 20px;display:flex;align-items:center;gap:16px;border:1.5px solid var(--mist);cursor:pointer;transition:all .18s}.video-item:hover{border-color:var(--gold);box-shadow:var(--shadow)}.video-thumb{width:76px;height:50px;border-radius:8px;background:var(--ink);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0;overflow:hidden}.video-info{flex:1;min-width:0}.video-title{font-weight:600;font-size:.92rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.video-meta{font-size:.77rem;color:#999;margin-top:3px}.quiz-wrap{max-width:680px}.option-btn{width:100%;padding:14px 18px;border-radius:10px;border:1.5px solid var(--mist);background:#fff;text-align:left;cursor:pointer;font-size:.92rem;font-family:DM Sans,sans-serif;transition:all .15s;display:flex;align-items:center;gap:12px;color:var(--ink)}.option-btn:hover:not(:disabled){border-color:var(--teal);background:var(--teal-light)}.option-btn.selected{border-color:var(--teal);background:var(--teal-light);color:var(--teal);font-weight:600}.option-btn.correct{border-color:#2a7a2a;background:#e6f5e6;color:#2a7a2a}.option-btn.wrong{border-color:var(--rose);background:var(--rose-light);color:var(--rose)}.option-label{width:28px;height:28px;border-radius:6px;background:var(--mist);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.78rem;flex-shrink:0}.subject-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px}.subject-card{background:#fff;border-radius:12px;padding:18px 16px;cursor:pointer;border:1.5px solid var(--mist);transition:all .18s}.subject-card:hover{border-color:var(--teal);box-shadow:var(--shadow)}.subject-card.active{border-color:var(--teal);background:var(--teal-light)}@media (max-width: 720px){.portal-layout{flex-direction:column}.sidebar{width:100%;flex-direction:row;overflow-x:auto;padding:10px 8px;gap:4px}.sidebar-section{display:none}.sidebar-btn{white-space:nowrap}.portal-main{padding:20px 16px}.form-row{grid-template-columns:1fr}.nav-tabs{display:none}.stats-grid{grid-template-columns:1fr 1fr}}.dash-hero{border-radius:var(--radius);padding:32px 36px;color:#fff;position:relative;overflow:hidden;margin-bottom:24px}.dash-hero:before{content:"";position:absolute;top:-60px;right:-60px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 65%);pointer-events:none}.dash-hero-quote{font-size:.83rem;opacity:.72;font-style:italic;margin-top:12px;line-height:1.6;max-width:520px}.stats-grid-6{display:grid;grid-template-columns:repeat(auto-fill,minmax(148px,1fr));gap:14px;margin-bottom:24px}.stat-card-v2{background:#fff;border-radius:12px;padding:18px 20px;border:1px solid var(--mist);position:relative;overflow:hidden;transition:transform .15s,box-shadow .15s}.stat-card-v2:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.stat-card-v2 .stat-accent{position:absolute;top:0;left:0;width:100%;height:3px;border-radius:12px 12px 0 0}.stat-card-v2 .stat-icon{font-size:1.5rem;margin-bottom:10px}.stat-card-v2 .stat-val{font-family:Playfair Display,serif;font-size:1.8rem;font-weight:700;line-height:1}.stat-card-v2 .stat-lbl{font-size:.72rem;color:#999;text-transform:uppercase;letter-spacing:.5px;margin-top:4px}.week-chart{display:flex;align-items:flex-end;gap:6px;height:56px}.week-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}.week-bar{width:100%;border-radius:3px 3px 0 0;transition:height .4s ease;min-height:3px}.week-label{font-size:.62rem;color:#bbb}.achievements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:12px}.badge{background:#fff;border-radius:12px;padding:16px 12px;text-align:center;border:1.5px solid var(--mist);transition:all .18s;position:relative}.badge.earned{border-color:var(--gold);background:#fffcf0}.badge.locked{opacity:.45;filter:grayscale(.8)}.badge .badge-icon{font-size:1.8rem;margin-bottom:8px}.badge .badge-name{font-size:.75rem;font-weight:700;color:var(--ink)}.badge .badge-desc{font-size:.67rem;color:#aaa;margin-top:3px;line-height:1.4}.badge.earned .badge-name{color:#8a6a00}.badge.earned:after{content:"✓";position:absolute;top:6px;right:8px;font-size:.65rem;font-weight:700;color:var(--gold)}.activity-item{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--mist)}.activity-item:last-child{border-bottom:none;padding-bottom:0}.activity-dot{width:34px;height:34px;border-radius:10px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:1rem}.child-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px}.child-card{background:#fff;border-radius:var(--radius);padding:22px 20px;border:2px solid var(--mist);cursor:pointer;transition:all .18s;text-align:center}.child-card:hover{border-color:var(--rose);box-shadow:var(--shadow)}.child-card.active{border-color:var(--rose);background:#fdf5f5}.child-avatar{width:52px;height:52px;border-radius:50%;margin:0 auto 12px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.3rem;color:#fff}.alert-card{display:flex;align-items:flex-start;gap:12px;padding:14px 18px;border-radius:12px;margin-bottom:12px;border-left:4px solid}.alert-card.warn{background:#fff8e8;border-color:var(--gold)}.alert-card.danger{background:var(--rose-light);border-color:var(--rose)}.alert-card.info{background:#e6f5e6;border-color:#2d7a2d}.section-header{margin-bottom:24px}.section-header h2{font-size:1.35rem;margin-bottom:4px}.section-header p{color:#777;font-size:.875rem}.search-wrap{position:relative}.search-wrap input{padding-left:38px}.search-wrap:before{content:"🔍";position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:.85rem}.lb-row{display:flex;align-items:center;gap:14px;padding:12px 16px;border-radius:10px;margin-bottom:8px;background:#fff;border:1.5px solid var(--mist);transition:all .15s}.lb-row:hover{border-color:var(--gold)}.lb-row.me{border-color:var(--teal);background:var(--teal-light)}.lb-rank{font-family:Playfair Display,serif;font-size:1.1rem;font-weight:700;width:28px;text-align:center;flex-shrink:0}.lb-name{flex:1;font-weight:600;font-size:.9rem}.lb-score{font-weight:700;font-size:.9rem}.quick-actions{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-bottom:24px}.quick-btn{background:#fff;border-radius:12px;padding:18px 16px;text-align:center;border:1.5px solid var(--mist);cursor:pointer;transition:all .18s;font-family:DM Sans,sans-serif}.quick-btn:hover{border-color:var(--teal);box-shadow:var(--shadow);transform:translateY(-2px)}.quick-btn .qb-icon{font-size:1.6rem;margin-bottom:8px}.quick-btn .qb-label{font-size:.8rem;font-weight:700;color:var(--slate)}.report-card{background:#fff;border-radius:var(--radius);padding:24px 28px;border:1px solid var(--mist);display:flex;align-items:center;gap:20px;margin-bottom:16px;transition:box-shadow .15s}.report-card:hover{box-shadow:var(--shadow)}.skeleton{background:linear-gradient(90deg,var(--mist) 25%,#f0f3f7 50%,var(--mist) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:8px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (max-width: 720px){.stats-grid-6{grid-template-columns:1fr 1fr}.achievements-grid,.quick-actions{grid-template-columns:repeat(3,1fr)}.child-cards{grid-template-columns:1fr 1fr}.dash-hero{padding:24px 20px}}
