@import"https://fonts.googleapis.com/css2?family=Titan+One&family=Nunito:wght@400;500;600;700;800;900&family=Caveat:wght@400;500;600;700&family=DM+Mono:wght@400;500&family=Style+Script&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bubble-pink: #ff6fb5;--bubble-pink-soft: #ffd3e6;--bubble-blue: #6ec1ff;--bubble-blue-soft: #d3ecff;--bubble-lilac: #c39bff;--bubble-lilac-soft:#ecdcff;--bubble-mint: #8be8c8;--bubble-mint-soft: #d6f7e9;--bubble-butter: #ffe26f;--bubble-butter-soft:#fff4c2;--bubble-coral: #ff9670;--bubble-coral-soft:#ffd9c8;--ink: #2a1a3e;--ink-2: #5a4a73;--ink-3: #8e82a3;--ink-4: #c5bdd6;--paper: #fffaf5;--paper-2:#fff3f7;--paper-3:#f0eaff;--cloud: #ffffff;--color-bg: #fef4fb;--color-surface: #fff3f7;--color-border: #f1e4ee;--color-text: #2a1a3e;--color-muted: #8e82a3;--color-accent: #ff6fb5;--color-header-bg: #ff6fb5;--color-header-fg: #ffffff;--color-s: #6ec1ff;--color-s-bg: #d3ecff;--color-c: #ff6fb5;--color-c-bg: #ffd3e6;--color-m: #3ec98a;--color-m-bg: #d6f7e9;--color-y: #ff9670;--color-y-bg: #ffd9c8;--color-a: #c39bff;--color-a-bg: #ecdcff;--subject-english: #ff6fb5;--subject-math: #3ec98a;--subject-science: #6ec1ff;--subject-socstu: #c39bff;--subject-arts: #ff9670;--subject-sel: #ffe26f;--subject-islamic: #8be8c8;--font: "Nunito", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-display: "Titan One", "Nunito", system-ui, sans-serif;--font-hand: "Caveat", cursive;--font-mono: "DM Mono", ui-monospace, monospace;--radius: 22px;--radius-input: 16px;--radius-modal: 32px;--shadow: 0 2px 6px rgba(82,30,90,.08);--shadow-md: 0 6px 18px rgba(82,30,90,.1);--shadow-lg: 0 16px 36px rgba(82,30,90,.14);--shadow-sticker: 0 4px 0 rgba(42,26,62,.15);--glow-pink: 0 0 0 4px rgba(255,111,181,.25);--glow-blue: 0 0 0 4px rgba(110,193,255,.3);--ease-soft: cubic-bezier(.4, 0, .2, 1);--ease-bounce: cubic-bezier(.34, 1.56, .64, 1)}body{font-family:var(--font);background:var(--color-bg);color:var(--color-text);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}.site-header{background:var(--bubble-coral-soft);color:var(--ink);padding:0 24px;height:72px;display:flex;align-items:center;gap:14px;position:sticky;top:0;z-index:100;border-bottom:1.5px solid #ffc4a8;box-shadow:0 2px 12px #ff967026}.header-logo{display:flex;align-items:center;gap:8px;cursor:pointer;flex-shrink:0}.header-icon{display:flex;align-items:center;flex-shrink:0}.header-icon svg{transform-origin:bottom center;animation:rock 2.8s ease-in-out infinite}@keyframes rock{0%{transform:rotate(-4deg)}50%{transform:rotate(4deg)}to{transform:rotate(-4deg)}}.header-brand{display:flex;flex-direction:row;align-items:baseline;gap:.4rem;line-height:1}.header-title{font-family:Style Script,cursive;font-size:2.48rem;font-weight:700;color:#703d57;letter-spacing:.08em;line-height:1}.header-tagline{font-family:var(--font-hand);font-size:1.2rem;font-weight:500;color:var(--bubble-pink);line-height:1}.header-subtitle{font-size:.78rem;color:var(--ink-3)}.header-spacer{flex:1}.legend{display:flex;align-items:center;gap:12px}.legend-item{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--ink-2)}.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.legend-dot.s{background:var(--color-s)}.legend-dot.c{background:var(--bubble-lilac)}.legend-dot.m{background:var(--color-m)}.legend-dot.y{background:var(--color-y)}.legend-dot.a{background:var(--color-a)}.app-layout{display:flex;min-height:calc(100vh - 72px);position:relative}.sidebar{width:220px;flex-shrink:0;background:var(--cloud);border-right:1.5px solid var(--color-border);position:sticky;top:72px;height:calc(100vh - 72px);overflow:hidden;display:flex;flex-direction:row;transition:width .25s ease}.sidebar-inner{flex:1;overflow-y:auto;padding:16px 10px 32px;display:flex;flex-direction:column;gap:2px;min-width:0}.sidebar-collapse-btn{position:sticky;top:calc(50vh - 36px);left:0;align-self:flex-start;width:18px;height:72px;background:var(--cloud);border:1.5px solid var(--color-border);border-left:none;border-radius:0 10px 10px 0;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink-3);z-index:10;padding:0;flex-shrink:0;transition:color .15s}.sidebar-collapse-btn:hover{color:var(--ink)}.sidebar-collapse-btn svg{transition:transform .25s ease}.app-layout.sidebar-collapsed .sidebar{width:0;border-right-color:transparent}.app-layout.sidebar-collapsed .sidebar-collapse-btn svg{transform:rotate(180deg)}.sidebar-section-label{font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-4);padding:12px 10px 6px}.sidebar-grade-btn{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:12px;border:none;background:none;width:100%;text-align:left;font-family:var(--font);font-size:.875rem;font-weight:600;color:var(--ink-2);cursor:pointer;transition:background .15s,color .15s}.sidebar-grade-btn:hover{background:var(--color-surface);color:var(--ink)}.sidebar-grade-btn.active{background:var(--bubble-pink-soft);color:#c2185b;font-weight:700}.sidebar-grade-dot{width:26px;height:26px;border-radius:8px;flex-shrink:0}.sidebar-divider{height:1px;background:var(--color-border);margin:10px 8px}.sidebar-toggle-btn{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:10px;border:none;background:none;width:100%;text-align:left;font-family:var(--font);font-size:.8rem;font-weight:700;color:var(--ink-2);cursor:pointer;transition:background .15s,opacity .15s}.sidebar-toggle-btn:hover{background:var(--color-surface)}.sidebar-toggle-btn .toggle-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.sidebar-toggle-btn.off{opacity:.38}.sidebar-toggle-btn.assigned:not(.off){background:var(--color-surface)}.sidebar-toggle-btn:not(.assigned):not(.off):after{content:"gap";font-size:.6rem;color:var(--ink-4);margin-left:auto;font-style:italic}.sidebar-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:5px 10px;border-radius:10px;transition:opacity .15s,background .15s}.sidebar-toggle-row.assigned{background:var(--color-surface)}.sidebar-toggle-row.off{opacity:.35}.sidebar-toggle-label{display:flex;align-items:center;gap:7px;font-size:.8rem;font-weight:700;color:var(--ink-2)}.sidebar-toggle-short{font-size:.7rem;font-weight:800;color:var(--ink-3);min-width:20px}.sidebar-toggle-long{color:var(--ink-2)}.islamic-src-btn{padding:5px 12px;border-radius:999px;border:1.5px solid var(--color-border);background:var(--color-surface);font-family:var(--font);font-size:.78rem;font-weight:700;color:var(--color-muted);cursor:pointer;transition:border-color .15s,background .15s,color .15s}.islamic-src-btn--active{border-color:var(--subject-islamic);background:var(--subject-islamic);color:#1a5c4a}.islamic-src-btn:hover:not(.islamic-src-btn--active){border-color:var(--subject-islamic);color:#1a5c4a}.sidebar-back-btn{margin-top:auto;padding-top:16px;display:flex;align-items:center;gap:6px;background:none;border:none;font-family:var(--font);font-size:.82rem;font-weight:600;color:var(--ink-3);cursor:pointer;padding-left:10px;transition:color .15s}.sidebar-back-btn:hover{color:var(--ink)}.app-main{flex:1;min-width:0;background:var(--cloud);padding:36px 48px 80px}.curriculum-hero{margin-bottom:32px}.curriculum-title{font-family:var(--font-display);font-size:52px;line-height:1;letter-spacing:-.01em;color:var(--ink);font-weight:400;margin-top:6px}.toolbar{background:var(--cloud);border-bottom:1.5px solid var(--color-border);display:flex;flex-direction:column;position:sticky;top:72px;z-index:99}.toolbar-row{display:flex;align-items:center;padding:0 24px;overflow-x:auto}.toolbar-row--grades{min-height:48px;border-bottom:1px solid var(--color-border)}.toolbar-row--syllabus{min-height:44px;gap:12px}.grade-tabs{display:flex;gap:0;flex-shrink:0}.grade-tab{background:none;border:none;border-bottom:3px solid transparent;padding:0 18px;height:48px;font-family:var(--font);font-size:.875rem;font-weight:600;color:var(--color-muted);cursor:pointer;white-space:nowrap;transition:color .18s,border-color .18s;border-radius:0}.grade-tab:hover{color:var(--color-text)}.grade-tab.active{color:var(--bubble-pink);border-bottom-color:var(--bubble-pink);font-weight:800}.toolbar-divider{width:1px;height:28px;background:var(--color-border);margin:0 16px;flex-shrink:0}.syllabus-label{font-size:.75rem;color:var(--color-muted);text-transform:uppercase;letter-spacing:.08em;flex-shrink:0;font-weight:700}.syllabus-toggles{display:flex;align-items:center;gap:8px;flex-shrink:0}.toggle-btn{display:flex;align-items:center;gap:6px;padding:5px 14px;border:1.5px solid;border-radius:999px;font-family:var(--font);font-size:.8rem;font-weight:700;cursor:pointer;transition:all .18s var(--ease-soft);letter-spacing:.02em}.toggle-btn.toggle-s{background:var(--color-s-bg);border-color:var(--color-s);color:#0d5b9c}.toggle-btn.toggle-c{background:var(--color-c-bg);border-color:var(--color-c);color:#c2185b}.toggle-btn.toggle-m{background:var(--color-m-bg);border-color:var(--color-m);color:#1e7a52}.toggle-btn.toggle-y{background:var(--color-y-bg);border-color:var(--color-y);color:#a8421e}.toggle-btn.toggle-a{background:var(--color-a-bg);border-color:var(--color-a);color:#5a2ea0}.toggle-btn.off{background:var(--color-bg);border-color:var(--color-border);color:var(--color-muted);opacity:.6}.toggle-dot{width:8px;height:8px;border-radius:50%;background:currentColor;transition:opacity .18s}.main-content{max-width:860px;margin:0 auto;padding:32px 24px 80px}.grade-heading{font-size:1.5rem;font-weight:800;color:var(--color-text);margin-bottom:4px;letter-spacing:-.02em}.grade-description{font-size:.875rem;color:var(--color-muted);margin-bottom:28px}.subject-accordion{display:flex;flex-direction:column;gap:10px}.subject-card{background:var(--cloud);border:1.5px solid var(--color-border);border-radius:var(--radius);overflow:hidden;transition:box-shadow .22s var(--ease-soft),transform .22s var(--ease-soft)}.subject-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.subject-color-dot{width:30px;height:30px;border-radius:10px;flex-shrink:0}.subject-header{width:100%;display:flex;align-items:center;gap:12px;padding:16px 20px;background:none;border:none;cursor:pointer;text-align:left;transition:background .15s}.subject-header:hover{background:var(--color-surface)}.subject-title{font-size:1rem;font-weight:700;color:var(--color-text);flex:1}.subject-meta{font-size:.75rem;color:var(--color-muted);flex-shrink:0}.subject-chevron{color:var(--color-muted);display:flex;align-items:center;transition:transform .2s var(--ease-soft);flex-shrink:0}.subject-header.open .subject-chevron{transform:rotate(180deg)}.subject-body{padding:8px 20px 20px;border-top:1px solid var(--color-border)}.subject-body[hidden]{display:none}.topic-block{padding:16px 0;border-bottom:1px solid var(--color-border)}.topic-block:last-child{border-bottom:none;padding-bottom:0}.topic-block.topic-empty{display:none}.topic-title{font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.11em;color:var(--bubble-pink);margin-bottom:10px}.outcomes-list{list-style:none;display:flex;flex-direction:column;gap:8px}.outcome-item{display:flex;align-items:flex-start;gap:10px;transition:opacity .15s}.outcome-item.hidden-source{display:none}.badge-group{display:flex;gap:3px;flex-shrink:0;margin-top:1px}.source-badge{flex-shrink:0;font-size:.68rem;font-weight:800;letter-spacing:.04em;padding:2px 7px;border-radius:999px;line-height:1.6;cursor:default;transition:opacity .15s}.source-badge.badge-dim{opacity:.28}.badge-s{background:var(--color-s-bg);color:#0d5b9c}.badge-c{background:var(--color-c-bg);color:#c2185b}.badge-m{background:var(--color-m-bg);color:#1e7a52}.badge-y{background:var(--color-y-bg);color:#a8421e}.badge-a{background:var(--color-a-bg);color:#5a2ea0}.outcome-text{font-size:.9rem;color:var(--color-text);line-height:1.55}.outcome-label{display:flex;align-items:flex-start;gap:10px;cursor:pointer;width:100%}.outcome-check{flex-shrink:0;margin-top:3px;width:15px;height:15px;accent-color:var(--bubble-pink);cursor:pointer}.outcome-check:disabled{opacity:.35;cursor:default}.outcome-check:checked+.outcome-text{color:var(--color-muted);text-decoration:line-through;text-decoration-color:var(--bubble-pink-soft)}.no-profile-banner{background:var(--bubble-blue-soft);border:1.5px solid var(--bubble-blue);color:#0d5b9c;border-radius:var(--radius-input);padding:12px 18px;font-size:.875rem;font-weight:600;margin-bottom:20px}.header-user{display:flex;align-items:center;gap:10px;flex-shrink:0}.header-email{font-size:.75rem;color:var(--ink-3);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logout-btn{background:#2a1a3e0f;border:1px solid rgba(42,26,62,.15);color:var(--ink-2);border-radius:999px;padding:4px 12px;font-family:var(--font);font-size:.75rem;font-weight:600;cursor:pointer;transition:background .15s}.logout-btn:hover{background:#2a1a3e1f}.header-username{font-size:.82rem;font-weight:600;color:var(--ink-2);flex-shrink:0;white-space:nowrap}.header-user-cog-wrap{position:relative;flex-shrink:0}.header-user-cog{display:flex;align-items:center;justify-content:center;width:30px;height:30px;background:#2a1a3e0f;border:1px solid rgba(42,26,62,.15);border-radius:50%;color:var(--ink-2);cursor:pointer;transition:background .15s;padding:0}.header-user-cog:hover{background:#2a1a3e21}.header-user-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1.5px solid rgba(42,26,62,.12);border-radius:10px;box-shadow:0 4px 20px #2a1a3e1f;min-width:140px;z-index:200;overflow:hidden}.header-user-dropdown.hidden{display:none}.header-user-dropdown-item{display:block;width:100%;padding:10px 16px;text-align:left;background:none;border:none;font-family:var(--font);font-size:.82rem;font-weight:600;color:var(--ink-2);cursor:pointer}.header-user-dropdown-item:hover{background:var(--color-surface)}.header-user-dropdown-item--danger{color:#e05}.profile-selector{position:relative;flex-shrink:0;margin-right:12px}.profile-select-btn{display:flex;align-items:center;gap:6px;background:#2a1a3e0f;border:1px solid rgba(42,26,62,.15);color:var(--ink);border-radius:999px;padding:5px 14px 5px 10px;font-family:var(--font);font-size:.85rem;font-weight:700;cursor:pointer;transition:background .15s;white-space:nowrap}.profile-select-btn:hover{background:#2a1a3e1f}.profile-btn-icon{font-size:.9rem}.profile-chevron{font-size:.7rem;opacity:.7}.profile-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:220px;background:var(--cloud);border:1.5px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:200;overflow:hidden}.profile-dropdown.hidden{display:none}.profile-option{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 14px;background:none;border:none;text-align:left;cursor:pointer;font-family:var(--font);font-size:.875rem;color:var(--color-text);transition:background .12s}.profile-option:hover{background:var(--color-surface)}.profile-option.active{background:var(--bubble-pink-soft);color:#c2185b;font-weight:700}.profile-option-name{flex:1}.profile-option-grade{font-size:.75rem;color:var(--color-muted);margin-right:8px}.profile-option-delete{background:none;border:none;color:var(--color-muted);font-size:1rem;line-height:1;padding:0 2px;cursor:pointer;border-radius:4px;opacity:0;transition:opacity .15s,color .15s}.profile-option:hover .profile-option-delete{opacity:1}.profile-option-delete:hover{color:#ff5b7f}.profile-option-settings{background:none;border:none;color:var(--color-muted);line-height:1;padding:0 2px;cursor:pointer;border-radius:4px;opacity:0;transition:opacity .15s,color .15s;display:flex;align-items:center}.profile-option:hover .profile-option-settings{opacity:1}.profile-option-settings:hover{color:var(--ink-1)}.profile-dropdown-divider{height:1px;background:var(--color-border);margin:4px 0}.profile-new-btn{color:var(--bubble-pink)!important;font-weight:700!important}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg);padding:24px}.login-card{background:var(--cloud);border:1.5px solid var(--color-border);border-radius:var(--radius-modal);box-shadow:var(--shadow-lg);padding:48px 40px;text-align:center;max-width:380px;width:100%}.login-logo{display:flex;justify-content:center;margin-bottom:16px}.login-title{font-family:var(--font-display);font-size:1.6rem;color:var(--bubble-lilac);margin-bottom:8px}.login-desc{font-size:.9rem;color:var(--color-muted);margin-bottom:28px;line-height:1.5}.login-btn{background:var(--bubble-pink);color:#fff;border:none;border-radius:999px;padding:12px 32px;font-family:var(--font);font-size:.95rem;font-weight:800;cursor:pointer;transition:opacity .18s,transform .12s var(--ease-soft);box-shadow:var(--shadow-sticker);width:100%}.login-btn:hover{opacity:.92}.login-btn:active{transform:translateY(2px);box-shadow:none}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-input{display:block;width:100%;box-sizing:border-box;padding:11px 16px;border:1.5px solid var(--color-border);border-radius:var(--radius-input);font-family:var(--font);font-size:1rem;color:var(--color-text);background:var(--color-bg);margin-bottom:14px;outline:none;transition:border-color .15s,box-shadow .15s}.login-input:focus{border-color:var(--bubble-pink);box-shadow:var(--glow-pink)}.login-back{background:none;border:none;color:var(--color-muted);font-family:var(--font);font-size:.85rem;cursor:pointer;margin-top:12px;padding:4px 0}.login-back:hover{color:var(--color-text)}.login-error{color:#ff5b7f;font-size:.85rem;margin-top:8px;min-height:1.2em}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#2a1a3e73;display:flex;align-items:center;justify-content:center;z-index:500;padding:24px}.modal-card{background:var(--cloud);border:1.5px solid var(--color-border);border-radius:var(--radius-modal);box-shadow:var(--shadow-lg);padding:32px;width:100%;max-width:360px}.modal-title{font-size:1.1rem;font-weight:800;color:var(--color-text);margin-bottom:20px}.modal-label{display:flex;flex-direction:column;gap:6px;font-size:.8rem;font-weight:800;color:var(--color-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:14px}.modal-input{font-family:var(--font);font-size:.9rem;color:var(--color-text);background:var(--color-bg);border:1.5px solid var(--color-border);border-radius:var(--radius-input);padding:8px 12px;outline:none;transition:border-color .15s,box-shadow .15s;width:100%}.modal-input:focus{border-color:var(--bubble-pink);box-shadow:var(--glow-pink)}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:24px}.modal-btn{padding:8px 20px;border-radius:999px;font-family:var(--font);font-size:.85rem;font-weight:700;cursor:pointer;transition:opacity .15s,transform .12s var(--ease-soft);border:none}.modal-cancel{background:var(--color-surface);color:var(--color-muted);border:1.5px solid var(--color-border)}.modal-save{background:var(--bubble-pink);color:#fff;box-shadow:var(--shadow-sticker)}.modal-save:hover{opacity:.9}.modal-save:active{transform:translateY(2px);box-shadow:none}.modal-cancel:hover{opacity:.85}.empty-state{text-align:center;padding:64px 24px;color:var(--color-muted);font-size:.9rem}.back-btn{background:none;border:none;color:var(--color-muted);font-family:var(--font);font-size:.9rem;font-weight:600;cursor:pointer;padding:4px 0;transition:color .15s}.back-btn:hover{color:var(--color-text)}.dashboard-main{max-width:900px;margin:0 auto;padding:40px 32px 80px}.dashboard-hero{margin-bottom:32px}.dashboard-hero-title{font-family:var(--font-display);font-size:26px;line-height:1;letter-spacing:-.01em;color:var(--ink);font-weight:400;margin-top:6px}.dashboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.dashboard-title{font-size:1rem;font-weight:800;color:var(--ink-3);text-transform:uppercase;letter-spacing:.1em}.dashboard-add-btn{background:var(--bubble-pink);color:#fff;border:none;border-radius:999px;padding:9px 20px;font-family:var(--font);font-size:.88rem;font-weight:800;cursor:pointer;box-shadow:var(--shadow-sticker);transition:opacity .18s,transform .12s var(--ease-soft)}.dashboard-add-btn:hover{opacity:.9}.dashboard-add-btn:active{transform:translateY(2px);box-shadow:none}.dashboard-header-actions{display:flex;align-items:center;gap:8px}.dash-view-btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:1.5px solid var(--cloud);border-radius:10px;background:none;color:var(--ink-3);cursor:pointer;transition:background .12s,color .12s,border-color .12s}.dash-view-btn:hover{background:var(--cloud);color:var(--ink)}.dash-view-btn--active{background:var(--ink);color:#fff;border-color:var(--ink)}.dash-table-loading{text-align:center;padding:48px 0;color:var(--ink-3);font-size:.88rem}.dash-mobile-list{display:flex;flex-direction:column;gap:10px}.dash-mobile-row{background:var(--cloud);border:1.5px solid var(--color-border);border-radius:14px;padding:14px;display:flex;flex-direction:column;gap:10px}.dash-mobile-stats{display:flex;flex-direction:column;gap:6px}.dash-mobile-stat{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--paper);border:1.5px solid var(--color-border);border-radius:10px;cursor:pointer;transition:background .12s,border-color .12s;text-align:left;width:100%}.dash-mobile-stat:hover{background:var(--bubble-mint-soft);border-color:var(--bubble-mint)}.dash-mobile-stat-label{font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3)}.dash-mobile-stat-val{font-size:.85rem;font-weight:700;color:var(--ink)}.dash-table-wrap{border-radius:16px;border:1.5px solid var(--cloud);overflow:hidden;overflow-x:auto}.dash-table{width:100%;border-collapse:collapse;font-size:.85rem}.dash-th{padding:9px 14px;text-align:left;font-size:.67rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);background:var(--cloud);white-space:nowrap}.dash-tr{border-top:1px solid var(--cloud)}.dash-tr:first-child{border-top:none}.dash-td{padding:12px 14px;vertical-align:middle}.dash-student-cell{display:flex;align-items:center;gap:10px}.dash-avatar{width:32px!important;height:32px!important;font-size:.82rem!important;flex-shrink:0}.dash-student-info{display:flex;flex-direction:column;gap:1px}.dash-cell-main{font-weight:700;color:var(--ink);display:block}.dash-cell-sub{font-size:.74rem;color:var(--ink-3);display:block}.dash-td--link{cursor:pointer;transition:background .1s}.dash-td--link:hover{background:var(--bubble-mint-soft)}.dash-td--muted{color:var(--ink-3);font-size:.8rem}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.dashboard-empty{color:var(--color-muted);font-size:.95rem;padding:40px 0}.student-card{background:var(--cloud);border:1.5px solid var(--color-border);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;gap:16px;box-shadow:var(--shadow);transition:box-shadow .22s var(--ease-soft),transform .22s var(--ease-soft)}.student-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.student-card-header{display:flex;align-items:center;gap:12px}.student-avatar{width:44px;height:44px;border-radius:50%;background:var(--bubble-pink);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:800;flex-shrink:0}.student-name{font-weight:800;font-size:1rem;color:var(--color-text)}.student-grade{font-size:.82rem;color:var(--color-muted);margin-top:2px}.student-delete{margin-left:auto;background:none;border:none;color:var(--color-muted);font-size:1.2rem;cursor:pointer;padding:4px 6px;border-radius:8px;line-height:1;flex-shrink:0;transition:color .15s,background .15s}.student-delete:hover{color:#ff5b7f;background:#ffe0ea}.student-card-actions{display:flex;gap:8px;overflow:hidden}.student-action-btn{flex:1 1 0;min-width:0;padding:9px 6px;border-radius:var(--radius-input);border:1.5px solid var(--color-border);background:var(--color-bg);color:var(--color-text);font-family:var(--font);font-size:.82rem;font-weight:700;cursor:pointer;transition:background .15s,border-color .15s;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.student-action-btn:hover{background:var(--color-surface);border-color:var(--bubble-pink-soft)}.yardstick-container{max-width:960px;margin:0 auto;padding:32px 24px 80px}.yardstick-hero{display:flex;align-items:center;gap:16px;margin-bottom:28px}.yardstick-avatar{width:56px;height:56px;border-radius:50%;background:var(--bubble-pink);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;flex-shrink:0}.yardstick-name{font-size:1.6rem;font-weight:800;color:var(--color-text)}.yardstick-grade{font-size:.9rem;color:var(--color-muted);margin-top:2px}.yardstick-age-control{display:flex;align-items:center;gap:16px;flex-wrap:wrap;background:var(--cloud);border:1.5px solid var(--color-border);border-radius:var(--radius);padding:14px 20px;margin-bottom:24px;box-shadow:var(--shadow)}.age-control-label{font-size:.88rem;color:var(--color-muted);font-weight:600}.age-stepper{display:flex;align-items:center;gap:12px}.age-step-btn{width:32px;height:32px;border-radius:50%;border:1.5px solid var(--color-border);background:var(--color-bg);color:var(--color-text);font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s}.age-step-btn:hover:not(:disabled){background:var(--color-surface);border-color:var(--bubble-pink-soft)}.age-step-btn:disabled{opacity:.35;cursor:not-allowed}.age-display{font-size:1.2rem;font-weight:800;color:var(--color-text);display:flex;align-items:center;gap:8px}.age-badge{font-size:.72rem;font-weight:700;background:var(--bubble-pink);color:#fff;padding:2px 8px;border-radius:999px}.age-badge--offset{background:var(--bubble-coral)}.age-reset-btn{background:none;border:none;color:var(--color-muted);font-family:var(--font);font-size:.82rem;cursor:pointer;text-decoration:underline;padding:0}.age-reset-btn:hover{color:var(--color-text)}.yardstick-summary{font-size:.95rem;color:var(--color-text);line-height:1.65;margin-bottom:28px;font-style:italic;padding:16px 20px;background:var(--cloud);border-left:4px solid var(--bubble-pink);border-radius:0 var(--radius) var(--radius) 0;box-shadow:var(--shadow)}.yardstick-columns{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:32px}.yardstick-col{background:var(--cloud);border:1.5px solid var(--color-border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.yardstick-col-header{padding:12px 16px;font-weight:800;font-size:.9rem;color:#fff}.yardstick-social{background:var(--bubble-blue)}.yardstick-physical{background:#2baf90}.yardstick-cognitive{background:var(--bubble-lilac)}.yardstick-language{background:var(--bubble-coral)}.yardstick-list{list-style:none;padding:12px 16px 16px;display:flex;flex-direction:column;gap:8px}.yardstick-list li{font-size:.875rem;color:var(--color-text);line-height:1.5;padding-left:14px;position:relative}.yardstick-list li:before{content:"•";position:absolute;left:0;color:var(--bubble-pink)}.yardstick-attribution{font-size:.8rem;color:var(--color-muted);text-align:center}.settings-btn{background:none;border:none;color:var(--ink-2);font-size:1.1rem;cursor:pointer;padding:6px;border-radius:8px;line-height:1;display:flex;align-items:center;transition:background .15s,color .15s}.settings-btn:hover{background:#2a1a3e14;color:var(--ink)}.settings-bar{background:var(--bubble-mint-soft);border-bottom:1.5px solid var(--bubble-mint);padding:10px 24px;display:flex;align-items:center;gap:14px}.settings-bar-label{font-size:.875rem;color:#1e7a52;font-weight:600;flex:1}.settings-bar-toggle{border:none;border-radius:999px;padding:5px 14px;font-family:var(--font);font-size:.8rem;font-weight:700;cursor:pointer}.settings-bar-toggle--off{background:#fff;color:#ff5b7f;border:1.5px solid #ffb3c6}.settings-bar-toggle--off:hover{background:#fff0f4}.settings-row{display:flex;align-items:center;gap:16px;padding:16px 0;border-top:1px solid var(--color-border);margin-top:4px}.settings-row-label{display:flex;align-items:center;font-size:.95rem;font-weight:700;color:var(--color-text);margin-bottom:3px}.settings-row-desc{font-size:.8rem;color:var(--color-muted)}.toggle-switch{position:relative;display:inline-flex;align-items:center;flex-shrink:0}.toggle-switch input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.toggle-track{display:inline-block;width:34px;height:18px;border-radius:999px;background:var(--color-border);transition:background .2s;position:relative;cursor:pointer}.toggle-track:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;transition:left .2s;box-shadow:0 1px 3px #0003}.toggle-switch input:checked+.toggle-track{background:var(--bubble-pink)}.toggle-switch input:checked+.toggle-track:after{left:18px}.student-quran-toggle{padding-top:4px;border-top:1px solid var(--color-border)}.toggle-label{display:flex;align-items:center;justify-content:space-between;font-size:.75rem;color:var(--color-muted);gap:8px}.student-action-btn--off{opacity:.4;cursor:default;pointer-events:none}.quran-container{max-width:800px;margin:0 auto;padding:32px 24px 80px}.quran-hero{display:flex;align-items:center;gap:16px;margin-bottom:32px}.quran-title{font-size:1.6rem;font-weight:800;color:var(--color-text)}.quran-subtitle{font-size:.88rem;color:var(--color-muted);margin-top:2px}.quran-section{margin-bottom:36px}.quran-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.quran-section-title{font-size:1.05rem;font-weight:800;color:var(--color-text)}.quran-add-btn{background:var(--bubble-pink);color:#fff;border:none;border-radius:999px;padding:7px 16px;font-family:var(--font);font-size:.83rem;font-weight:800;cursor:pointer;box-shadow:var(--shadow-sticker);transition:opacity .18s,transform .12s var(--ease-soft)}.quran-add-btn:hover{opacity:.9}.quran-add-btn:active{transform:translateY(2px);box-shadow:none}.quran-empty{color:var(--color-muted);font-size:.9rem;padding:16px 0}.surah-card{background:var(--cloud);border:1.5px solid var(--color-border);border-radius:var(--radius);overflow:hidden;margin-bottom:10px;box-shadow:var(--shadow);transition:box-shadow .22s var(--ease-soft)}.surah-card--memorized{border-left:4px solid var(--bubble-mint)}.surah-progress-header,.surah-memorized-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;cursor:pointer;-webkit-user-select:none;user-select:none;gap:12px;transition:background .12s}.surah-progress-header:hover,.surah-memorized-header:hover{background:var(--paper-2)}.surah-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.surah-number{width:32px;height:32px;border-radius:50%;background:var(--bubble-lilac);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:800;flex-shrink:0}.surah-number--done{background:var(--bubble-mint);font-size:.9rem}.surah-name{font-weight:800;font-size:.95rem;color:var(--color-text);display:block}.surah-english{font-size:.78rem;color:var(--color-muted);display:block;margin-top:1px}.surah-progress-meta{display:flex;align-items:center;gap:10px;flex-shrink:0}.surah-progress-bar{width:80px;height:6px;background:var(--color-border);border-radius:999px;overflow:hidden}.surah-progress-fill{height:100%;background:var(--bubble-pink);border-radius:999px;transition:width .3s var(--ease-bounce)}.surah-progress-text{font-size:.78rem;font-weight:700;color:var(--color-muted);white-space:nowrap}.surah-chevron{color:var(--color-muted);font-size:1.2rem;transition:transform .2s var(--ease-soft);flex-shrink:0}.surah-progress-header.open .surah-chevron,.surah-memorized-header.open .surah-chevron{transform:rotate(90deg)}.surah-body{padding:16px 18px 20px;border-top:1px solid var(--color-border)}.surah-body[hidden]{display:none}.ayah-grid{display:flex;flex-wrap:wrap;gap:8px}.ayah-cell{display:flex;align-items:center;gap:5px;cursor:pointer;padding:4px 8px;border-radius:10px;border:1.5px solid var(--color-border);background:var(--color-bg);transition:border-color .12s,background .12s}.ayah-cell:hover{border-color:var(--bubble-pink-soft);background:#fff6fa}.ayah-cell:has(input:checked){border-color:var(--bubble-mint);background:var(--bubble-mint-soft)}.ayah-check{width:14px;height:14px;accent-color:var(--bubble-mint);cursor:pointer;flex-shrink:0}.ayah-num{font-size:.78rem;font-weight:700;color:var(--color-text)}.review-table{width:100%;border-collapse:collapse;font-size:.875rem}.review-table th{text-align:left;padding:6px 10px;font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--color-muted);border-bottom:1.5px solid var(--color-border)}.review-table td{padding:8px 10px;border-bottom:1px solid var(--color-border);color:var(--color-text)}.review-table tr:last-child td{border-bottom:none}.surah-review-meta{display:flex;align-items:center;gap:10px;flex-shrink:0}.review-meta-text{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.review-last-date{font-size:.78rem;color:var(--color-muted)}.review-last-pct{font-size:.82rem;font-weight:800}.add-review-btn{background:var(--color-bg);border:1.5px solid var(--color-border);color:var(--color-text);border-radius:999px;padding:5px 12px;font-family:var(--font);font-size:.78rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s}.add-review-btn:hover{background:var(--color-surface);border-color:var(--bubble-pink-soft)}.slider-wrap{display:flex;flex-direction:column;gap:10px;padding:10px 0 4px}.pct-slider{width:100%;accent-color:var(--bubble-pink);cursor:pointer;height:6px}.slider-display{display:flex;align-items:center;gap:12px}.slider-pct{font-size:1.4rem;font-weight:800;color:var(--color-text);min-width:54px}.slider-strength{font-size:.9rem;font-weight:700}.surah-remove-btn{background:none;border:none;color:var(--color-muted);font-size:1rem;line-height:1;cursor:pointer;padding:2px 6px;border-radius:6px;opacity:0;transition:opacity .15s,color .15s,background .15s;flex-shrink:0}.surah-progress-header:hover .surah-remove-btn,.surah-memorized-header:hover .surah-remove-btn{opacity:1}.surah-remove-btn:hover{color:#ff5b7f!important;background:#ffe0ea;opacity:1!important}.surah-notes{margin-top:16px;padding-top:14px;border-top:1px solid var(--color-border)}.surah-notes-label{display:block;font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--bubble-pink);margin-bottom:6px}.surah-notes-input{width:100%;resize:vertical;font-family:var(--font);font-size:.875rem;line-height:1.55;color:var(--color-text);background:var(--color-bg);border:1.5px solid var(--color-border);border-radius:var(--radius-input);padding:8px 12px;transition:border-color .15s,box-shadow .15s;box-sizing:border-box;outline:none}.surah-notes-input:focus{border-color:var(--bubble-pink);box-shadow:var(--glow-pink)}.surah-notes-status{display:block;font-size:.75rem;color:var(--color-muted);margin-top:4px;min-height:1em}.modal-card--wide{max-width:520px}.add-tabs{display:flex;border-bottom:2px solid var(--color-border);margin-bottom:16px}.add-tab{background:none;border:none;padding:8px 20px;font-family:var(--font);font-size:.9rem;font-weight:700;color:var(--color-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s}.add-tab--active{color:var(--bubble-pink);border-bottom-color:var(--bubble-pink)}.add-tab-body{min-height:220px}.add-status-row{display:flex;align-items:center;gap:8px;margin:14px 0 0;padding-top:14px;border-top:1px solid var(--color-border)}.add-status-label{font-size:.82rem;color:var(--color-muted);margin-right:4px}.add-status-btn{padding:5px 14px;border-radius:999px;border:1.5px solid var(--color-border);background:var(--color-bg);color:var(--color-muted);font-family:var(--font);font-size:.82rem;font-weight:700;cursor:pointer;transition:all .15s}.add-status-btn--active{border-color:var(--bubble-pink);background:var(--bubble-pink);color:#fff}.juz-list{display:flex;flex-direction:column;gap:6px;max-height:320px;overflow-y:auto}.juz-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border:1.5px solid var(--color-border);border-radius:var(--radius-input);background:var(--color-bg);cursor:pointer;text-align:left;transition:border-color .15s,background .15s;gap:12px;width:100%;font-family:var(--font)}.juz-item:hover{border-color:var(--bubble-pink-soft);background:var(--color-surface)}.juz-item--selected{border-color:var(--bubble-mint);background:var(--bubble-mint-soft)}.juz-item--selected:hover{border-color:var(--bubble-mint)}.juz-num{font-size:.9rem;font-weight:700;color:var(--color-text)}.juz-half{font-size:.75rem;font-weight:400;color:var(--color-muted);margin-left:6px}.juz-range{font-size:.78rem;color:var(--color-muted)}.surah-pick-list{max-height:280px;overflow-y:auto;margin-top:10px;border:1.5px solid var(--color-border);border-radius:var(--radius-input);overflow-x:hidden}.surah-pick-item{display:flex;align-items:center;gap:10px;width:100%;padding:9px 14px;border-bottom:1px solid var(--color-border);cursor:pointer;transition:background .12s;font-family:var(--font)}.surah-pick-item:last-child{border-bottom:none}.surah-pick-item:hover{background:var(--color-surface)}.surah-pick-check{width:16px;height:16px;accent-color:var(--bubble-pink);flex-shrink:0;cursor:pointer}.surah-pick-num{width:28px;height:28px;border-radius:50%;background:var(--bubble-lilac);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:800;flex-shrink:0}.surah-pick-name{font-weight:700;font-size:.88rem;color:var(--color-text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.surah-pick-en{font-size:.76rem;color:var(--color-muted);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.surah-pick-ayahs{font-size:.74rem;color:var(--color-muted);white-space:nowrap}.dashboard-list{display:flex;flex-direction:column;gap:20px}.soc-card{background:var(--cloud);border:1.5px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.soc-card-header{display:flex;align-items:center;gap:14px;padding:18px 20px 14px}.soc-card-header--collapsible{cursor:pointer;-webkit-user-select:none;user-select:none}.soc-card-chevron{display:flex;align-items:center;color:var(--color-muted);transition:transform .2s ease;margin-left:2px}.soc-card--collapsed .soc-card-chevron{transform:rotate(-90deg)}.soc-card--collapsed .soc-tabs,.soc-card--collapsed .soc-panel{display:none}.soc-avatar{width:44px;height:44px;border-radius:50%;background:var(--bubble-pink);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.15rem;font-weight:800;flex-shrink:0}.soc-card-info{flex:1;min-width:0}.soc-card-header-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.soc-gear-btn{background:none;border:none;color:var(--ink-4);cursor:pointer;padding:5px;border-radius:8px;display:flex;align-items:center;transition:background .14s,color .14s}.soc-gear-btn:hover{background:var(--color-surface);color:var(--ink-2)}.soc-tabs{display:flex;border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border);background:var(--color-bg);overflow-x:auto;scrollbar-width:none}.soc-tabs::-webkit-scrollbar{display:none}.soc-tab{flex:1;padding:10px 12px;background:none;border:none;border-bottom:2.5px solid transparent;font-family:var(--font);font-size:.8rem;font-weight:700;color:var(--color-muted);cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s,background .15s;letter-spacing:.02em}.soc-tab:hover{color:var(--color-text);background:var(--color-surface)}.soc-tab--active{color:var(--bubble-pink);border-bottom-color:var(--bubble-pink);background:var(--cloud)}.soc-panel{padding:16px 20px 0;display:flex;flex-direction:column}.soc-panel>*{animation:soc-fadein .15s ease}@keyframes soc-fadein{0%{opacity:0}to{opacity:1}}.soc-panel-loading,.soc-empty{color:var(--color-muted);font-size:.88rem;padding:32px 0;text-align:center;flex:1}.soc-tab-footer{margin-top:auto;padding:10px 0 14px;display:flex;justify-content:flex-end}.soc-see-more{background:none;border:none;color:var(--bubble-pink);font-family:var(--font);font-size:.78rem;font-weight:700;cursor:pointer;padding:0;transition:opacity .15s}.soc-see-more:hover{opacity:.75}.soc-card-footer{border-top:1px solid var(--color-border);padding:8px 20px;background:var(--color-bg)}.soc-quran-toggle-row{display:flex;align-items:center;gap:8px;width:fit-content;cursor:pointer}.soc-quran-toggle-label{font-size:.72rem;font-weight:700;color:var(--ink-4);text-transform:uppercase;letter-spacing:.08em}.soc-milestones{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;flex:1}.soc-milestone-col{background:var(--color-bg);border-radius:14px;overflow:hidden}.soc-milestone-head{padding:7px 12px;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:#fff}.soc-milestone-head--social{background:var(--bubble-blue)}.soc-milestone-head--physical{background:#2baf90}.soc-milestone-head--cognitive{background:var(--bubble-lilac)}.soc-milestone-head--language{background:var(--bubble-coral)}.soc-milestone-list{list-style:none;padding:8px 12px;display:flex;flex-direction:column;gap:5px}.soc-milestone-list li{font-size:.78rem;color:var(--color-text);line-height:1.45;padding-left:12px;position:relative}.soc-milestone-list li:before{content:"•";position:absolute;left:0;color:var(--bubble-pink)}.soc-memorising-list{display:flex;flex-direction:column;gap:14px;flex:1}.soc-surah-item{display:flex;flex-direction:column;gap:10px;padding-bottom:14px;border-bottom:1px solid var(--color-border)}.soc-surah-item:last-of-type{border-bottom:none}.soc-surah-meta{display:flex;align-items:center;justify-content:space-between;gap:12px}.soc-surah-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.soc-surah-progress-wrap{display:flex;align-items:center;gap:8px;flex-shrink:0}.soc-more-note{font-size:.78rem;color:var(--color-muted);font-style:italic}.soc-review-card{display:flex;flex-direction:column;gap:10px;flex:1}.soc-review-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.soc-review-surah{display:flex;align-items:center;gap:12px}.soc-check-badge{font-size:.72rem;font-weight:800;background:var(--bubble-butter);color:var(--ink);padding:3px 10px;border-radius:999px;white-space:nowrap;flex-shrink:0}.soc-review-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.soc-review-last{font-size:.82rem;color:var(--color-muted)}.soc-review-pct{font-size:.82rem;font-weight:700}.soc-log-review-btn{background:var(--bubble-pink);color:#fff;border:none;border-radius:999px;padding:8px 22px;font-family:var(--font);font-size:.85rem;font-weight:800;cursor:pointer;box-shadow:var(--shadow-sticker);align-self:flex-start;transition:opacity .15s,transform .12s var(--ease-soft)}.soc-log-review-btn:hover{opacity:.9}.soc-log-review-btn:active{transform:translateY(2px);box-shadow:none}.soc-review-divider{border:none;border-top:1px solid var(--color-border);margin:10px 0}.soc-curr-sections{display:grid;grid-template-columns:repeat(auto-fill,minmax(max(160px,calc(50% - 6px)),1fr));gap:12px;flex:1}.soc-curr-section{display:flex;flex-direction:column}.soc-curr-header{display:flex;align-items:center;justify-content:space-between;background:none;border:none;cursor:pointer;padding:0;margin-bottom:6px;width:100%;text-align:left}.soc-curr-chevron{font-size:.75rem;color:var(--ink-3);flex-shrink:0}.soc-curr-body[hidden]{display:none}.soc-curr-subject{display:inline-block;font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;padding:2px 8px;border-radius:99px}.soc-curr-topic{font-size:.88rem;font-weight:700;color:var(--ink);margin-bottom:7px;line-height:1.3}.soc-curr-outcomes{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.soc-curr-outcome{display:flex;align-items:center;gap:10px;padding:9px 11px;background:#fff;border:1.5px solid var(--color-border);border-radius:14px;cursor:pointer;transition:transform .18s var(--ease-soft, ease),box-shadow .18s var(--ease-soft, ease)}.soc-curr-outcome:hover{transform:translateY(-1px);box-shadow:0 4px 12px #2a1a3e17}.soc-curr-outcome--done{opacity:.7}.soc-curr-circle{flex-shrink:0;width:24px;height:24px;border-radius:50%;border:2px solid var(--ink-4);background:transparent;display:flex;align-items:center;justify-content:center;padding:0;cursor:pointer;transition:border-color .15s,background .15s}.soc-curr-circle--done{background:var(--color-m, #3ec98a);border-color:var(--color-m, #3ec98a)}.soc-curr-outcome-text{flex:1;font-size:.82rem;font-weight:600;color:var(--ink);line-height:1.35}.soc-curr-outcome--done .soc-curr-outcome-text{text-decoration:line-through;text-decoration-color:var(--ink-4);color:var(--ink-3)}.soc-syllabus-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px;width:100%}.soc-syllabus-item{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 0}.soc-syllabus-check{width:15px;height:15px;accent-color:var(--bubble-pink);cursor:pointer;flex-shrink:0}.soc-syllabus-label{font-size:.88rem;font-weight:600;color:var(--color-text)}.header-name{font-family:var(--font);font-size:.85rem;font-weight:700;color:var(--color-muted)}.onboarding-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#2a1a3e85;display:flex;align-items:center;justify-content:center;z-index:600;padding:24px}.onboarding-card{background:var(--cloud);border:1.5px solid var(--color-border);border-radius:var(--radius-modal);box-shadow:var(--shadow-lg);padding:36px 32px 28px;width:100%;max-width:380px;display:flex;flex-direction:column;gap:0}.ob-progress{display:flex;gap:8px;justify-content:center;margin-bottom:28px}.ob-dot{width:8px;height:8px;border-radius:50%;background:var(--color-border);transition:background .2s,transform .2s}.ob-dot--active{background:var(--bubble-pink);transform:scale(1.25)}.ob-dot--done{background:var(--bubble-mint)}.ob-eyebrow{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--color-muted);margin:0 0 6px}.ob-title{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--color-text);line-height:1.2;margin:0 0 20px}.ob-sub{font-size:.88rem;font-weight:600;color:var(--color-muted);margin:16px 0 10px}.ob-name-input{margin-bottom:4px}.ob-choices{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:4px}.ob-choice{padding:9px 20px;border-radius:999px;border:1.5px solid var(--color-border);background:var(--color-surface);font-family:var(--font);font-size:.88rem;font-weight:700;color:var(--color-muted);cursor:pointer;transition:border-color .15s,background .15s,color .15s,box-shadow .15s}.ob-choice--active{border-color:var(--bubble-pink);background:var(--bubble-pink);color:#fff;box-shadow:var(--shadow-sticker)}.ob-choice:hover:not(.ob-choice--active){border-color:var(--bubble-pink);color:var(--bubble-pink)}.ob-stepper{display:flex;align-items:center;gap:18px;margin:8px 0 20px}.ob-step-btn{width:36px;height:36px;border-radius:50%;border:1.5px solid var(--color-border);background:var(--color-surface);font-size:1.2rem;font-weight:700;color:var(--color-text);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .15s}.ob-step-btn:disabled{opacity:.35;cursor:default}.ob-step-btn:not(:disabled):hover{border-color:var(--bubble-pink);color:var(--bubble-pink)}.ob-step-val{font-family:var(--font-display);font-size:2rem;font-weight:700;color:var(--color-text);min-width:2ch;text-align:center}.ob-track-list{display:flex;flex-direction:column;gap:10px;margin:4px 0 8px}.ob-track-item{display:flex;align-items:center;gap:14px;padding:12px 14px;border:1.5px solid var(--color-border);border-radius:12px;cursor:pointer;transition:border-color .15s,background .15s}.ob-track-item:has(input:checked){border-color:var(--bubble-lilac);background:var(--bubble-lilac-soft)}.ob-track-item input[type=checkbox]{width:18px;height:18px;flex-shrink:0;accent-color:var(--bubble-lilac)}.ob-track-info{display:flex;flex-direction:column;gap:2px}.ob-track-name{font-size:.9rem;font-weight:700;color:var(--ink)}.ob-track-desc{font-size:.78rem;color:var(--ink-3)}.ob-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:28px}.ob-skip{display:block;text-align:center;margin-top:12px;font-size:.82rem;font-weight:600;color:var(--color-muted);background:none;border:none;cursor:pointer;text-decoration:underline;text-underline-offset:3px;padding:0;font-family:var(--font);transition:color .15s}.ob-skip:hover{color:var(--bubble-pink)}.ob-child-label{font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--bubble-purple, #b388ff);margin-bottom:4px}.ob-quran-row{display:flex;align-items:center;gap:10px;margin-top:14px;padding-top:14px;border-top:1px solid var(--color-border);font-size:.88rem;font-weight:600;color:var(--color-muted)}@media (max-width: 600px){.site-header{padding:0 16px}.header-brand{flex-direction:column;gap:0}.soc-tab{flex:none;padding:10px 14px}.soc-tabs{-webkit-mask-image:linear-gradient(to right,black 80%,transparent 100%);mask-image:linear-gradient(to right,black 80%,transparent 100%)}.header-title,.header-tagline{display:none}.header-icon svg{width:56px;height:56px}.curriculum-title{font-size:32px}.header-subtitle,.header-email{display:none}.toolbar-row{padding:0 12px}.grade-tab{padding:0 12px;font-size:.82rem}.main-content{padding:20px 16px 60px}.subject-header{padding:14px 16px}.subject-body{padding:8px 16px 16px}.toggle-btn{padding:4px 10px;font-size:.75rem}.toggle-long{display:none}.login-card{padding:36px 24px}.yardstick-columns,.dashboard-grid{grid-template-columns:1fr}.yardstick-age-control{gap:10px}.soc-milestones{grid-template-columns:1fr}.soc-curr-subject{min-width:100px}}.nawawi-container{max-width:960px;margin:0 auto;padding:32px 24px 80px}.nawawi-hero{display:flex;align-items:center;gap:16px;margin-bottom:36px}.nawawi-hero-info{flex:1}.nawawi-title{font-size:1.6rem;font-weight:800;color:var(--color-text)}.nawawi-subtitle{font-size:.88rem;color:var(--color-muted);margin-top:2px}.nawawi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.nawawi-card{background:var(--cloud);border:1.5px solid var(--color-border);border-radius:14px;padding:20px;display:flex;flex-direction:column;gap:14px;box-shadow:0 2px 8px #2a1a3e0d}.nawawi-card-header{display:flex;align-items:center;gap:10px}.nawawi-num{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:var(--bubble-lilac);color:#fff;font-size:.85rem;font-weight:800;flex-shrink:0}.nawawi-topic{font-size:.95rem;font-weight:700;color:var(--ink)}.nawawi-arabic{font-size:1.25rem;line-height:2;color:var(--ink);font-family:Amiri,Scheherazade New,Traditional Arabic,serif;background:var(--paper-3);border-radius:8px;padding:14px 16px;text-align:right}.nawawi-english{font-size:.875rem;line-height:1.7;color:var(--ink-2);flex:1}.nawawi-narrator-ar{font-size:.8rem;color:var(--ink-3);margin-top:6px;text-align:right;font-family:Amiri,Scheherazade New,serif}.nawawi-narrator-en{display:block;font-size:.78rem;color:var(--ink-3);margin-top:5px;font-style:italic}.nawawi-card-footer{display:flex;flex-direction:row;align-items:center;gap:14px;margin-top:auto;padding-top:12px;border-top:1px solid var(--color-border)}.nawawi-counter{display:flex;align-items:center;gap:10px;flex-shrink:0}.nawawi-progress-bar{flex:1;position:relative;height:30px;background:var(--color-border);border-radius:15px;overflow:hidden}.nawawi-progress-fill{position:absolute;left:0;top:0;bottom:0;background:var(--bubble-lilac);border-radius:15px;transition:width .3s ease}.nawawi-progress-label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:800;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.4);z-index:1;pointer-events:none}.nawawi-dec,.nawawi-inc{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;border:1.5px solid var(--color-border);background:var(--cloud);font-size:1.2rem;font-weight:700;color:var(--ink);cursor:pointer;transition:background .15s,border-color .15s;line-height:1}.nawawi-inc{border-color:var(--bubble-lilac);color:var(--bubble-lilac)}.nawawi-inc:hover{background:var(--bubble-lilac-soft)}.nawawi-dec:hover:not(:disabled){background:var(--paper-2)}.nawawi-dec:disabled{opacity:.35;cursor:default}.nawawi-count{font-size:1.1rem;font-weight:800;color:var(--ink);min-width:24px;text-align:center}@media (max-width: 740px){.nawawi-grid{grid-template-columns:1fr}}@media (max-width: 740px){.sidebar{position:absolute;top:0;left:0;height:100%;z-index:50;box-shadow:4px 0 16px #0000001f}.sidebar-collapse-btn{position:fixed;top:50vh;transform:translateY(-50%);left:220px;transition:left .25s ease,color .15s}.app-layout.sidebar-collapsed .sidebar-collapse-btn{left:0}}.soc-nawawi-suggest{padding:10px 0;display:flex;flex-direction:column;gap:10px}.soc-nawawi-suggest-header{display:flex;align-items:center;gap:8px}.soc-nawawi-topic{font-size:.88rem;font-weight:700;color:var(--ink)}.soc-nawawi-arabic{font-size:1rem;line-height:2;color:var(--ink);font-family:Amiri,Scheherazade New,Traditional Arabic,serif;background:var(--paper-3);border-radius:8px;padding:10px 14px;text-align:right}.soc-nawawi-english{font-size:.82rem;line-height:1.65;color:var(--ink-2)}.soc-nawawi-narrator-ar{font-size:.75rem;color:var(--ink-3);margin-top:5px;text-align:right;font-family:Amiri,Scheherazade New,serif}.soc-nawawi-narrator-en{display:block;font-size:.73rem;color:var(--ink-3);margin-top:4px;font-style:italic}.soc-nawawi-progress-bar{width:100%;position:relative;height:26px;background:var(--color-border);border-radius:13px;overflow:hidden}.soc-nawawi-progress-fill{position:absolute;left:0;top:0;bottom:0;background:var(--bubble-lilac);border-radius:13px;transition:width .3s ease}.soc-nawawi-progress-label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:800;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.4);z-index:1;pointer-events:none}.soc-nawawi-counter-row{display:flex;align-items:center;justify-content:space-between}.soc-nawawi-counter{display:flex;align-items:center;gap:8px}.soc-nawawi-dec,.soc-nawawi-inc{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;border:1.5px solid var(--color-border);background:var(--cloud);font-size:1.1rem;font-weight:700;color:var(--ink);cursor:pointer;transition:background .15s;line-height:1}.soc-nawawi-inc{border-color:var(--bubble-lilac);color:var(--bubble-lilac)}.soc-nawawi-inc:hover{background:var(--bubble-lilac-soft)}.soc-nawawi-dec:hover:not(:disabled){background:var(--paper-2)}.soc-nawawi-dec:disabled{opacity:.35;cursor:default}.soc-nawawi-count{font-size:1rem;font-weight:800;color:var(--ink);min-width:20px;text-align:center}.soc-nawawi-nav{display:flex;gap:6px}.soc-nawawi-prev,.soc-nawawi-next{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;border:1.5px solid var(--color-border);background:var(--cloud);font-size:1rem;color:var(--ink-2);cursor:pointer;transition:background .15s,color .15s}.soc-nawawi-prev:hover,.soc-nawawi-next:hover{background:var(--paper-2);color:var(--ink)}.hisnul-container{max-width:720px;margin:0 auto;padding:24px 16px 60px}.hisnul-hero{display:flex;align-items:center;gap:16px;margin-bottom:28px}.hisnul-hero-info{display:flex;flex-direction:column;gap:4px}.hisnul-title{font-family:Nunito,sans-serif;font-size:1.5rem;font-weight:800;color:var(--ink)}.hisnul-subtitle{font-size:.9rem;color:var(--ink-2);font-weight:600}.hisnul-stats{font-size:.8rem;color:var(--ink-3);margin-left:auto;text-align:right}.hisnul-section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);margin-bottom:12px}.hisnul-review-section{margin-bottom:28px}.hisnul-review-card{background:var(--cloud);border:1.5px solid var(--bubble-mint);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:10px}.hisnul-review-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.hisnul-chapter-badge{background:var(--bubble-mint);color:#0d7a6e;font-size:.7rem;font-weight:700;padding:2px 7px;border-radius:20px}.hisnul-chapter-title-small{font-size:.82rem;font-weight:600;color:var(--ink-2)}.hisnul-review-meta{display:flex;gap:12px;font-size:.78rem;color:var(--ink-3);flex-wrap:wrap}.hisnul-log-btn{align-self:flex-start;background:var(--bubble-mint);color:#0d7a6e;border:none;border-radius:8px;padding:6px 14px;font-size:.8rem;font-weight:700;cursor:pointer}.hisnul-log-btn:hover{background:var(--bubble-mint-soft)}.hisnul-chapters{display:flex;flex-direction:column;gap:8px}.hisnul-chapter-card{background:var(--cloud);border:1.5px solid var(--color-border);border-radius:12px;overflow:hidden}.hisnul-chapter-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:none;border:none;cursor:pointer;gap:12px;text-align:left}.hisnul-chapter-toggle:hover{background:var(--paper-3)}.hisnul-chapter-toggle-left{display:flex;align-items:center;gap:10px}.hisnul-chapter-toggle-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.hisnul-chapter-num{background:var(--bubble-mint-soft);color:#0d7a6e;font-size:.7rem;font-weight:700;width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.hisnul-chapter-name{font-size:.9rem;font-weight:700;color:var(--ink)}.hisnul-chapter-progress{font-size:.75rem;color:var(--ink-3)}.hisnul-chevron{font-size:.8rem;color:var(--ink-3)}.hisnul-duas-list{display:flex;flex-direction:column;border-top:1px solid var(--color-border)}.hisnul-duas-list[hidden]{display:none}.hisnul-dua-item{padding:16px;border-bottom:1px solid var(--color-border);display:flex;flex-direction:column;gap:10px}.hisnul-dua-item:last-child{border-bottom:none}.hisnul-dua-item--memorized{background:#f0fdf8}.hisnul-dua-arabic{font-family:Amiri,Scheherazade New,serif;font-size:1.2rem;line-height:2;color:var(--ink);text-align:right}.hisnul-dua-english{font-size:.875rem;line-height:1.7;color:var(--ink-2)}.hisnul-dua-note{font-size:.75rem;color:var(--ink-3);font-style:italic}.hisnul-dua-footer{display:flex;flex-direction:column;gap:8px}.hisnul-dua-mem-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.hisnul-memorized-badge{background:var(--bubble-mint-soft);color:#0d7a6e;font-size:.72rem;font-weight:700;padding:2px 8px;border-radius:20px}.hisnul-last-review{font-size:.75rem;color:var(--ink-3)}.hisnul-dua-actions{display:flex;gap:8px}.hisnul-review-btn{background:var(--bubble-mint-soft);color:#0d7a6e;border:none;border-radius:7px;padding:5px 12px;font-size:.78rem;font-weight:700;cursor:pointer}.hisnul-review-btn:hover{background:var(--bubble-mint)}.hisnul-mem-btn{background:var(--color-border);color:var(--ink-2);border:none;border-radius:7px;padding:5px 12px;font-size:.78rem;font-weight:600;cursor:pointer;align-self:flex-start}.hisnul-mem-btn:hover{background:var(--bubble-mint-soft);color:#0d7a6e}.hisnul-unmem-btn{background:none;color:var(--ink-3);border:1px solid var(--color-border);border-radius:7px;padding:5px 10px;font-size:.75rem;cursor:pointer}.hisnul-unmem-btn:hover{background:var(--paper-2);color:var(--ink)}.soc-hisnul-suggest{display:flex;flex-direction:column;gap:10px}.soc-hisnul-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.soc-hisnul-chapter{font-size:.82rem;font-weight:600;color:var(--ink-2)}.soc-hisnul-arabic{font-family:Amiri,Scheherazade New,serif;font-size:1rem;line-height:1.9;color:var(--ink);text-align:right;direction:rtl;background:var(--paper-3);border-radius:8px;padding:10px 12px}.soc-hisnul-english{font-size:.82rem;line-height:1.65;color:var(--ink-2)}.soc-hisnul-log-btn{align-self:flex-start;background:var(--bubble-mint-soft);color:#0d7a6e;border:none;border-radius:8px;padding:6px 14px;font-size:.8rem;font-weight:700;cursor:pointer}.soc-hisnul-log-btn:hover{background:var(--bubble-mint)}.soc-section-label,.soc-hisnul-section-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--ink-3);margin-bottom:4px}.soc-tab-section-hd{display:inline-block;font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;padding:2px 9px;border-radius:99px;margin-bottom:10px;margin-top:14px}.soc-tab-section-hd:first-child{margin-top:0}.soc-tab-section-hd--review{background:var(--bubble-blue);color:#fff}.soc-tab-section-hd--mem{background:#2baf90;color:#fff}.soc-quran-sections{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-start}.soc-quran-col{flex:1 1 160px;min-width:0;background:var(--color-bg);border-radius:14px;overflow:hidden}.soc-quran-col .soc-tab-section-hd{display:block;border-radius:0;margin:0;padding:7px 12px}.soc-quran-col-body{padding:8px 10px}.hisnul-progress-section{margin-bottom:28px;display:flex;flex-direction:column;gap:12px}.hisnul-mem-log-btn{align-self:flex-start;background:var(--bubble-mint);color:#0d7a6e;border:none;border-radius:8px;padding:6px 14px;font-size:.8rem;font-weight:700;cursor:pointer}.hisnul-mem-log-btn:hover{opacity:.85}.scroll-top-btn{position:fixed;bottom:24px;right:24px;z-index:1000;width:44px;height:44px;border-radius:50%;background:var(--color-primary, #ff6fb5);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px #0000002e;opacity:0;pointer-events:none;transform:translateY(10px);transition:opacity .2s ease,transform .2s ease}.scroll-top-btn.visible{opacity:1;pointer-events:auto;transform:translateY(0)}.scroll-top-btn:hover{filter:brightness(1.08)}
