@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap";:root{--bg: #FAFAF8;--text: #1a1a1a;--text-muted: #6b7280;--card-bg: #ffffff;--font: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--radius: 1rem;--radius-sm: .5rem;--radius-full: 9999px;--shadow: 0 4px 16px rgba(0, 0, 0, .06);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .12);--yellow: #FFE80F;--lime: #CDED1E;--green: #87E22C;--emerald: #3DD658;--teal: #04C49E;--cyan: #019FBF;--blue: #0153B9;--purple: #6B5CE7;--pink: #FF6B9D;--gradient: linear-gradient(135deg, #FFE80F, #CDED1E, #87E22C, #3DD658, #04C49E, #019FBF, #0153B9)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:1rem}.loading-spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top-color:var(--teal);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-text{color:#dc2626;font-weight:600}.login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg)}.login-card{background:var(--card-bg);border-radius:var(--radius);padding:2rem;max-width:400px;width:90%;box-shadow:var(--shadow-lg)}.login-card h1{margin:0 0 .5rem}.login-card p{color:var(--text-muted);margin:0 0 1.5rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.25rem;font-weight:500;font-size:.875rem}.form-group input{width:100%;padding:.5rem .75rem;border:1px solid #e5e5e5;border-radius:var(--radius-sm);font-size:1rem;font-family:var(--font)}.form-group input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px #04c49e26}.form-error{color:#dc2626;font-size:.875rem;padding:.5rem;background:#fef2f2;border-radius:var(--radius-sm);margin-bottom:1rem}.login-card .btn-primary{width:100%;margin-top:0}.login-card .btn-primary:disabled{opacity:.7;cursor:not-allowed}.btn-primary{background:var(--gradient);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:var(--radius-full);font-weight:600;font-size:.95rem;cursor:pointer;font-family:var(--font)}.study-layout{display:flex;height:100vh;overflow:hidden}.study-panel{flex:1;overflow-y:auto;padding:1.5rem;min-width:0}.chat-panel{width:420px;flex-shrink:0;border-left:1px solid #e5e7eb;display:flex;flex-direction:column;background:var(--card-bg)}.chat-toggle,.chat-backdrop{display:none}.subject-cards-container{max-width:700px;margin:0 auto}.cards-header{text-align:center;margin-bottom:2rem}.cards-header h1{font-size:2rem;font-weight:800;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.25rem}.cards-header p{color:var(--text-muted);font-size:1.05rem}.subject-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.subject-card{background:var(--card-bg);border:2px solid #e5e7eb;border-radius:var(--radius);padding:1.25rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;cursor:pointer;transition:all .2s ease;position:relative;font-family:var(--font)}.subject-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--card-colour)}.subject-card.highlighted{border-color:var(--card-colour);box-shadow:0 0 0 3px color-mix(in srgb,var(--card-colour) 30%,transparent),var(--shadow-lg);animation:glow 2s ease-in-out infinite alternate}@keyframes glow{0%{box-shadow:0 0 0 3px color-mix(in srgb,var(--card-colour) 20%,transparent)}to{box-shadow:0 0 0 6px color-mix(in srgb,var(--card-colour) 35%,transparent),var(--shadow-lg)}}.subject-icon{font-size:2rem;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--card-colour) 12%,white);border-radius:14px}.subject-name{font-weight:700;font-size:.95rem;text-align:center}.last-score{font-size:.75rem;font-weight:600;color:var(--card-colour);opacity:.85}.study-badge{position:absolute;top:-8px;right:-8px;background:var(--card-colour);color:#fff;font-size:.7rem;font-weight:700;padding:3px 8px;border-radius:var(--radius-full);text-shadow:0 1px 1px rgba(0,0,0,.15)}.reminder-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:60}.reminder-box{background:#fff;border-radius:var(--radius);padding:2rem;max-width:380px;text-align:center;box-shadow:var(--shadow-lg)}.reminder-box p{margin-bottom:1.25rem;font-size:1rem;line-height:1.5}.mascot-selector{margin-bottom:1.5rem}.mascot-active{display:flex;align-items:center;gap:.75rem;background:#fff;border:2px solid var(--border);border-radius:var(--radius);padding:.75rem 1rem;cursor:pointer;width:100%;text-align:left;transition:border-color .2s}.mascot-active:hover{border-color:var(--primary)}.mascot-thumb{width:48px;height:48px;border-radius:50%;object-fit:cover}.mascot-info{display:flex;flex-direction:column;gap:.15rem}.mascot-info strong{font-size:.95rem}.mascot-info small{font-size:.8rem;color:var(--text-secondary)}.mascot-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.mascot-option{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:1rem .5rem;background:#fff;border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:transform .15s,border-color .2s}.mascot-option:hover{transform:scale(1.03)}.mascot-option.active{border-width:3px;box-shadow:var(--shadow)}.mascot-option img{width:64px;height:64px;border-radius:50%;object-fit:cover}.mascot-option span{font-weight:700;font-size:.85rem;text-align:center}.mascot-option small{font-size:.75rem;color:var(--text-secondary)}.study-view-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.session-header .back-btn{background:none;border:1px solid #e5e7eb;padding:.5rem 1rem;border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font);font-weight:600;font-size:.9rem}.back-btn:hover{background:#f3f4f6}.study-view-header h2{font-size:1.4rem;font-weight:800}.empty-curricula{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.empty-curricula p:first-child{font-size:1.1rem;font-weight:600;color:var(--text);margin-bottom:.5rem}.curricula-item{background:var(--card-bg);border:1px solid #e5e7eb;border-radius:var(--radius);padding:1.25rem;margin-bottom:1rem}.curricula-item h3{font-size:1.05rem;margin-bottom:.5rem}.curricula-strand{color:var(--text-muted);font-size:.88rem;margin-bottom:.5rem}.curricula-text{line-height:1.6;font-size:.95rem}.curricula-image{max-width:100%;border-radius:var(--radius-sm);margin-top:.75rem}.chat-container{display:flex;flex-direction:column;height:100%}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid #e5e7eb;flex-shrink:0}.chat-header h3{font-size:1rem;font-weight:700}.chat-header-info{display:flex;align-items:center;gap:.75rem}.chat-mascot{flex-shrink:0}.chat-mascot img{width:32px;height:32px;border-radius:50%;object-fit:cover}.chat-subject-badge{font-size:.72rem;font-weight:700;color:#fff;padding:2px 8px;border-radius:var(--radius-full)}.close-chat-btn{background:none;border:none;font-size:1.1rem;cursor:pointer;color:var(--text-muted);padding:.25rem;display:none}.chat-placeholder{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;text-align:center;color:var(--text-muted)}.chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem;background:#fafafa}.msg{display:flex;max-width:88%}.msg.user{align-self:flex-end}.msg.assistant{align-self:flex-start}.msg .bubble{padding:.75rem 1rem;border-radius:.75rem;font-size:.92rem;line-height:1.5;box-shadow:0 1px 2px #0000000d}.msg.user .bubble{background:#e8f1ff;border:1px solid #cfe0ff;border-bottom-right-radius:4px}.msg.assistant .bubble{background:#fff;border:1px solid #e5e7eb;border-bottom-left-radius:4px}.msg.nudge .bubble{background:#fffbeb;border-color:#fde68a;font-style:italic}.msg.error .bubble{background:#fef2f2;border-color:#fecaca;color:#dc2626}.msg-image{max-width:200px;border-radius:var(--radius-sm);margin-bottom:.5rem;display:block}.msg-text{white-space:pre-wrap;word-break:break-word}.typing-dot{display:inline-block;color:var(--teal);animation:pulse 1s ease-in-out infinite;margin-left:4px}@keyframes pulse{0%,to{opacity:.3}50%{opacity:1}}.chat-input-area{border-top:1px solid #e5e7eb;padding:.75rem 1rem;flex-shrink:0;background:#fff}.image-preview-strip{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:.5rem;align-items:center}.image-preview{position:relative;display:inline-block}.image-preview img{height:60px;border-radius:var(--radius-sm);border:1px solid #e5e7eb;display:block}.add-more-image{width:60px;height:60px;border:1px dashed #cbd5e1;border-radius:var(--radius-sm);background:#f8fafc;color:#64748b;font-size:1.4rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.add-more-image:hover{background:#f1f5f9;color:#334155}.msg-image-strip{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:.5rem}.msg-image-strip.single .msg-image{max-width:200px}.msg-image-strip.multi .msg-image{max-width:120px;height:90px;object-fit:cover;margin-bottom:0}.remove-image{position:absolute;top:-6px;right:-6px;width:20px;height:20px;border-radius:50%;background:#dc2626;color:#fff;border:none;font-size:.7rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.input-row{display:flex;gap:.5rem;align-items:center}.input-row input[type=text]{flex:1;padding:.6rem .8rem;border:1px solid #e5e7eb;border-radius:var(--radius-sm);font-size:.95rem;font-family:var(--font)}.input-row input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px #04c49e26}.upload-btn{background:none;border:1px solid #e5e7eb;border-radius:var(--radius-sm);padding:.5rem;cursor:pointer;font-size:1.1rem;flex-shrink:0}.upload-btn:hover{background:#f3f4f6}.upload-btn:disabled{opacity:.4;cursor:not-allowed}.upload-btn:disabled:hover{background:none}.send-btn{background:var(--gradient);color:#fff;border:none;padding:.6rem 1.2rem;border-radius:var(--radius-full);font-weight:600;font-size:.9rem;cursor:pointer;font-family:var(--font);flex-shrink:0}.send-btn:disabled{opacity:.5;cursor:not-allowed}.study-timer{flex-shrink:0;border-bottom:1px solid #e5e7eb}.timer-bar{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;background:#f0fdf4;font-size:.82rem;font-weight:600}.timer-round{color:var(--emerald)}.timer-clock{color:var(--text);font-variant-numeric:tabular-nums}.timer-action{background:var(--emerald);color:#fff;border:none;padding:.3rem .8rem;border-radius:var(--radius-full);font-size:.78rem;font-weight:700;cursor:pointer;font-family:var(--font)}.timer-prompt{display:flex;gap:.5rem;padding:.5rem 1rem;background:#fffbeb;border-bottom:1px solid #fde68a}.timer-prompt button{flex:1;padding:.4rem .75rem;border:1px solid #e5e7eb;border-radius:var(--radius-sm);background:#fff;font-size:.82rem;font-weight:600;cursor:pointer;font-family:var(--font)}.timer-prompt button:first-child{background:var(--teal);color:#fff;border-color:var(--teal)}.quiz-content{padding:1rem 1.5rem 2rem;display:flex;flex-direction:column;gap:1rem}.quiz-progress{display:flex;align-items:center;gap:1rem}.quiz-progress-bar{flex:1;height:8px;background:#e8ecef;border-radius:4px;overflow:hidden}.quiz-progress-fill{height:100%;border-radius:4px;transition:width .3s ease}.quiz-progress-text{font-size:.82rem;color:#888;white-space:nowrap;font-weight:600}.quiz-topic-badge{font-size:.8rem;color:#666;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.quiz-bonus-badge{background:var(--yellow);color:#333;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:10px}.quiz-marks{color:#999;font-size:.78rem}.quiz-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 2px 12px #0000000f;border:1px solid #e8ecef}.quiz-question-text{font-size:1.05rem;font-weight:600;color:#222;line-height:1.5;margin-bottom:1rem}.quiz-options{display:flex;flex-direction:column;gap:.5rem}.quiz-option{text-align:left;padding:.75rem 1rem;border:2px solid #e0e4e8;border-radius:12px;background:#fff;font-size:.92rem;cursor:pointer;transition:all .15s;font-family:inherit;color:#333}.quiz-option:hover:not(:disabled){border-color:var(--teal);background:#f0faf8}.quiz-option.selected{border-color:var(--blue);background:#eef4ff;font-weight:600}.quiz-option.correct{border-color:var(--green);background:#e8f8ec;color:#1a7a2e;font-weight:600}.quiz-option.wrong{border-color:#e74c3c;background:#fdf0ef;color:#c0392b}.quiz-feedback{font-size:.88rem;font-weight:600;margin-top:.75rem}.quiz-feedback.correct{color:#1a7a2e}.quiz-feedback.wrong{color:#c0392b}.quiz-match-grid{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.quiz-match-row{display:flex;align-items:center;gap:.75rem}.quiz-match-term{flex:1;font-weight:600;font-size:.9rem}.quiz-match-row select{flex:1;padding:.5rem;border:2px solid #e0e4e8;border-radius:8px;font-family:inherit;font-size:.85rem;background:#fff}.quiz-match-answers{margin-top:.5rem}.quiz-match-answer{font-size:.88rem;margin:.25rem 0;color:#333}.quiz-textarea{width:100%;padding:.75rem;border:2px solid #e0e4e8;border-radius:12px;font-family:inherit;font-size:.9rem;resize:vertical;margin-bottom:.75rem}.quiz-textarea:focus{outline:none;border-color:var(--teal)}.quiz-model-answer{background:#f0faf8;border:1px solid var(--teal);border-radius:12px;padding:.75rem 1rem;margin-top:.5rem}.quiz-model-answer p{font-size:.88rem;color:#333;line-height:1.5;margin:.25rem 0}.quiz-workbook-prompt{background:#fff8e1;border:1px solid #ffd54f;border-radius:12px;padding:.75rem 1rem;font-size:.9rem;font-weight:600;color:#5d4037;margin-bottom:.75rem}.btn-check{padding:.6rem 1.25rem;border:none;border-radius:10px;background:var(--teal);color:#fff;font-family:inherit;font-size:.88rem;font-weight:600;cursor:pointer}.btn-check:hover{opacity:.9}.btn-primary{padding:.7rem 1.5rem;border:none;border-radius:12px;background:var(--teal);color:#fff;font-family:inherit;font-size:.95rem;font-weight:700;cursor:pointer}.quiz-nav{display:flex;justify-content:space-between;gap:1rem;padding-top:.5rem}.quiz-nav-btn{padding:.6rem 1.25rem;border:2px solid #e0e4e8;border-radius:10px;background:#fff;font-family:inherit;font-size:.88rem;font-weight:600;cursor:pointer;color:#555}.quiz-nav-btn:disabled{opacity:.4;cursor:default}.quiz-nav-btn.primary{background:var(--teal);color:#fff;border-color:var(--teal)}.quiz-nav-btn.primary:hover{opacity:.9}.quiz-finished{display:flex;flex-direction:column;align-items:center;padding:3rem 1.5rem;text-align:center;gap:.75rem}.quiz-finished-icon{font-size:3rem}.quiz-finished h3{font-size:1.5rem;color:#222}.quiz-score-summary{background:#f0faf8;border-radius:16px;padding:1.5rem 2.5rem;margin:.5rem 0}.quiz-score-big{font-size:2.5rem;font-weight:800;color:var(--teal)}.quiz-score-summary p{color:#888;font-size:.88rem}@media (max-width: 768px){.study-layout{flex-direction:column;position:relative}.study-panel{flex:1;height:100vh;padding:1rem}.chat-panel{position:fixed;top:0;right:0;bottom:0;width:calc(100% - 40px);transform:translate(100%);transition:transform .3s ease;z-index:50;border-left:none;box-shadow:-4px 0 20px #00000026}.chat-panel.open{transform:translate(0)}.chat-backdrop{display:block;position:fixed;top:0;left:0;width:40px;height:100%;z-index:49;background:transparent}.chat-toggle{display:flex;position:fixed;bottom:1.5rem;right:1.5rem;width:56px;height:56px;border-radius:50%;background:var(--gradient);color:#fff;border:none;align-items:center;justify-content:center;font-size:1.5rem;box-shadow:var(--shadow-lg);cursor:pointer;z-index:40}.close-chat-btn{display:block}.subject-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.cards-header h1{font-size:1.5rem}}@media (max-width: 400px){.subject-grid{grid-template-columns:repeat(2,1fr)}.subject-card{padding:1rem}.subject-icon{font-size:1.5rem;width:44px;height:44px}.subject-name{font-size:.85rem}}.content-tabs{display:flex;border-bottom:2px solid #eee;margin-bottom:.5rem;gap:0}.content-tab{flex:1;padding:.6rem .5rem;border:none;border-bottom:3px solid transparent;background:none;font-size:.85rem;font-weight:600;color:#666;cursor:pointer;transition:color .15s,border-color .15s;display:flex;align-items:center;justify-content:center;gap:.3rem}.content-tab:hover,.content-tab.active{color:#333}.content-tab-icon{font-size:1rem}.flashcard-content{padding:.5rem 0}.flashcard-topics{display:flex;gap:.5rem;overflow-x:auto;padding:0 0 .75rem;-webkit-overflow-scrolling:touch}.flashcard-topic-btn{flex-shrink:0;padding:.4rem .9rem;border-radius:20px;border:1.5px solid #e0e0e0;background:#fff;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s}.flashcard-topic-btn.active{border-color:transparent}.flashcard{perspective:800px;cursor:pointer;margin:1rem 0;min-height:220px}.flashcard-inner{position:relative;width:100%;min-height:220px;transition:transform .5s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d}.flashcard.flipped .flashcard-inner{transform:rotateY(180deg)}.flashcard .flashcard-front,.flashcard .flashcard-back{position:absolute;top:0;right:0;bottom:0;left:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:16px;padding:2rem 1.5rem;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;box-shadow:0 2px 12px #00000014}.flashcard .flashcard-front{background:#fff;border:2px solid #e8e8e8}.flashcard .flashcard-back{background:linear-gradient(135deg,#f0f7ff,#e8f4f8);border:2px solid #c8dff0;transform:rotateY(180deg)}.flashcard-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#999;margin-bottom:.75rem}.flashcard-text{font-size:1.15rem;line-height:1.5;color:#333;margin:0}.flashcard-hint{font-size:.75rem;color:#bbb;margin-top:auto;padding-top:1rem}.flashcard-source{font-size:.75rem;color:#888;margin-top:auto;padding-top:.75rem}.flashcard-actions{display:flex;gap:.75rem;justify-content:center;margin:.5rem 0}.flashcard-btn{flex:1;max-width:180px;padding:.7rem 1rem;border-radius:12px;border:2px solid;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .15s}.flashcard-btn.review{background:#fff;border-color:#e0a800;color:#c49000}.flashcard-btn.review:active{background:#fef9e7}.flashcard-btn.mastered{background:#e8f8ef;border-color:#27ae60;color:#1e8449}.flashcard-btn.mastered:active{background:#d4efdf}.diagram-content{padding:.5rem 0}.diagram-instructions{font-size:.9rem;color:#555;margin:.5rem 0 1rem;text-align:center}.diagram-workspace{margin:.5rem 0}.diagram-image-container{position:relative;width:100%;border-radius:12px;overflow:hidden;background:#f5f5f5;border:2px solid #e0e0e0;touch-action:none;user-select:none;-webkit-user-select:none}.diagram-image{width:100%;display:block;pointer-events:none}.diagram-placeholder{padding:3rem 1.5rem;text-align:center;color:#888}.diagram-placeholder p:first-child{font-size:1.5rem;margin-bottom:.5rem}.diagram-label{position:absolute;transform:translate(-50%,-50%);padding:.3rem .6rem;border-radius:6px;font-size:.75rem;font-weight:600;white-space:nowrap;z-index:10;pointer-events:auto;transition:background .2s,border-color .2s}.diagram-label.placed{background:#e3f2fd;border:2px solid #2196f3;color:#1565c0;cursor:grab;box-shadow:0 2px 6px #2196f333}.diagram-label.placed.correct{background:#e8f5e9;border-color:#4caf50;color:#2e7d32}.diagram-label.placed.wrong{background:#ffebee;border-color:#f44336;color:#c62828}.diagram-label.target{background:#4caf5026;border:2px dashed #4caf50;color:#2e7d32;font-size:.65rem;z-index:5}.diagram-label-bank{margin-top:1rem;padding:1rem;background:#fafafa;border-radius:12px;border:1.5px solid #e8e8e8}.diagram-label-bank-title{font-size:.8rem;font-weight:600;color:#666;margin-bottom:.6rem}.diagram-label-bank-items{display:flex;flex-wrap:wrap;gap:.5rem}.diagram-label.bank{position:relative;transform:none;background:#fff;border:2px solid #e0e0e0;color:#333;cursor:grab;padding:.4rem .8rem;border-radius:8px;font-size:.8rem;font-weight:500;touch-action:none;user-select:none;-webkit-user-select:none}.diagram-label.bank:active{cursor:grabbing}.diagram-label.bank.placed-away{opacity:.35;cursor:default;border-style:dashed}.btn-check{display:block;width:100%;max-width:300px;margin:1rem auto;padding:.75rem 1.5rem;border-radius:12px;border:none;background:#2196f3;color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s}.btn-check:active{background:#1976d2}.diagram-score{text-align:center;margin:.5rem 0}.session-view{padding:.5rem 0;max-width:700px;margin:0 auto}.session-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.session-info{display:flex;align-items:center;gap:.75rem}.session-info h2{font-size:1.3rem;font-weight:800}.session-label{font-size:.78rem;font-weight:600;color:var(--text-muted);background:#f3f4f6;padding:2px 10px;border-radius:var(--radius-full)}.session-progress{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.progress-bar{flex:1;height:8px;background:#e8ecef;border-radius:4px;overflow:hidden}.progress-fill{height:100%;border-radius:4px;transition:width .4s ease}.progress-text{font-size:.82rem;color:var(--text-muted);font-weight:600;white-space:nowrap}.session-mascot-indicator{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;border-radius:var(--radius-full);border:2px solid;width:fit-content;margin-bottom:1rem}.session-mascot-indicator img{width:28px;height:28px;border-radius:50%;object-fit:cover}.session-mascot-indicator span{font-size:.8rem;font-weight:600}.session-item{transition:opacity .3s ease}.session-item.fade-in{opacity:1}.session-item.fade-out{opacity:0}.session-loading,.session-error,.session-all-done{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;gap:1rem;text-align:center}.btn-secondary{padding:.7rem 1.5rem;border:2px solid #e5e7eb;border-radius:12px;background:#fff;font-family:var(--font);font-size:.95rem;font-weight:600;cursor:pointer;color:var(--text)}.btn-secondary:hover{background:#f3f4f6}.next-btn{display:block;width:100%;max-width:320px;margin:1.5rem auto 0;font-size:1rem}.session-flashcard{display:flex;flex-direction:column;gap:1rem}.flashcard-topic{font-size:.8rem;font-weight:600;color:var(--text-muted)}.flashcard-card{background:var(--card-bg);border:2px solid #e8e8e8;border-radius:16px;padding:1.5rem 1.25rem;text-align:center;display:flex;flex-direction:column;justify-content:center;box-shadow:0 2px 12px #0000000f}.flashcard-card.flipped{border-color:var(--teal);background:linear-gradient(135deg,#f0f7ff,#e8f4f8)}.flashcard-question{font-size:1.1rem;font-weight:600;line-height:1.5;color:var(--text)}.flashcard-answer{font-size:1rem;line-height:1.5;color:#333;margin-top:.5rem}.flashcard-input-area{display:flex;gap:.5rem}.flashcard-input{flex:1;padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:12px;font-size:.95rem;font-family:var(--font)}.flashcard-input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px #04c49e26}.flashcard-result,.quiz-result{padding:.5rem 1rem;border-radius:12px;text-align:center}.flashcard-result.correct,.quiz-result.correct{background:#e8f8ef}.flashcard-result.incorrect,.quiz-result.incorrect{background:#fdf0ef}.result-text{font-weight:700;font-size:1rem}.correct-text{color:#1a7a2e}.incorrect-text{color:#c0392b}.check-error{margin-top:.75rem;padding:.6rem .9rem;background:#fdf0ef;border:1px solid #f3c9c4;border-radius:10px;color:#c0392b;font-size:.95rem;text-align:center}.correct-answer{font-size:.9rem;color:#333;margin-top:.5rem;font-weight:500}.mascot-feedback{display:flex;align-items:flex-start;gap:.75rem;background:#fffbeb;border:1px solid #fde68a;border-radius:12px;padding:.75rem 1rem;font-size:.9rem;font-weight:500;font-style:italic;color:#92400e}.mascot-feedback-img{width:40px;height:40px;border-radius:50%;object-fit:cover;flex-shrink:0}.mascot-feedback p{margin:0}.previous-answer{display:flex;flex-direction:column;gap:.25rem;padding:.6rem 1rem;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;margin-bottom:.75rem}.previous-answer-label{font-size:.75rem;font-weight:600;color:#991b1b;text-transform:uppercase;letter-spacing:.03em}.previous-answer-text{font-size:.9rem;color:#dc2626}.retype-area{display:flex;flex-direction:column;gap:.5rem}.retype-prompt{font-size:.88rem;font-weight:600;color:var(--text-muted)}.flashcard-proceed{text-align:center;padding:.5rem}.proceed-check{color:var(--emerald);font-weight:700;font-size:.9rem}.session-quiz{display:flex;flex-direction:column;gap:1rem}.quiz-topic{font-size:.8rem;font-weight:600;color:var(--text-muted)}.quiz-question{background:var(--card-bg);border:1px solid #e8ecef;border-radius:16px;padding:1.5rem;box-shadow:0 2px 12px #0000000f}.quiz-question p{font-size:1.05rem;font-weight:600;color:#222;line-height:1.5}.quiz-page-link{display:inline-flex;align-items:center;margin-top:.75rem;padding:.4rem .75rem;border:1px solid #c7d2fe;border-radius:999px;background:#eef2ff;color:#4338ca;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s}.quiz-page-link:hover{background:#e0e7ff;border-color:#a5b4fc}.quiz-text-answer{display:flex;gap:.5rem;align-items:flex-end;flex-wrap:wrap}.quiz-text-input{resize:none;overflow:hidden;line-height:1.4;min-height:2.75rem;font-family:inherit;width:100%;flex:1 1 100%}.quiz-options.submitted .quiz-option{cursor:default;pointer-events:none}.quiz-photo-btn{padding:.6rem .9rem;font-size:.9rem;border:1px solid var(--border, #e0e0e0);background:var(--surface, #fff);border-radius:8px;cursor:pointer;white-space:nowrap}.quiz-photo-btn:hover:not(:disabled){background:var(--surface-hover, #f5f5f5)}.quiz-photo-btn:disabled{opacity:.6;cursor:not-allowed}.extraction-replace-prompt{margin-top:.75rem;padding:.75rem;background:var(--surface-hover, #f5f5f5);border-radius:8px;font-size:.9rem}.extraction-replace-prompt p{margin:0 0 .5rem}.extraction-replace-actions{display:flex;gap:.5rem}.extraction-error{margin-top:.75rem;padding:.6rem .75rem;background:#fff4f4;border:1px solid #f5c6cb;border-radius:8px;font-size:.88rem;color:#842029}.extraction-issues{margin-top:.75rem;padding:.6rem .75rem;background:#fff8e6;border:1px solid #ffe1a8;border-radius:8px;font-size:.88rem;color:#5c3a00;line-height:1.5}.extraction-issues strong{display:block;margin-bottom:.25rem}.extraction-issues em{font-style:normal;font-weight:600;color:#7a4a00}.multi-input-rows{display:flex;flex-direction:column;gap:4px}.multi-input-row{display:flex;align-items:center;gap:10px;padding:8px 0}.multi-input-label{font-size:.85rem;color:var(--text-muted);min-width:24px;white-space:nowrap;font-weight:600}.multi-input-value{font-size:1.3rem;font-weight:600;min-width:40px;text-align:center}.multi-input-field{width:100px;padding:8px;border:2px solid #ddd;border-radius:8px;font-size:1.1rem;text-align:center;transition:border-color .2s,background .2s}.multi-input-field:focus{border-color:var(--primary);outline:none}.multi-input-field.correct{border-color:var(--emerald);background:#eafaf1}.multi-input-field.wrong{border-color:#e74c3c;background:#ffeaea}.multi-input-field.submitted{display:inline-flex;align-items:center;justify-content:center;font-weight:700}.multi-input-result{font-size:1.2rem;width:24px;text-align:center}.multi-input-rows.matching .multi-input-value{min-width:100px;text-align:left;font-size:1rem}.multi-input-rows.matching .multi-input-field{width:60px}.multi-input-field.input-small,.multi-input-rows.matching .multi-input-field.input-small{width:160px}.multi-input-field.input-medium,.multi-input-rows.matching .multi-input-field.input-medium{width:320px;max-width:100%}.multi-input-field.input-large,.multi-input-rows.matching .multi-input-field.input-large{width:100%;min-height:72px;resize:vertical;font-family:inherit;line-height:1.4}.multi-input-check-btn{width:100%;margin-top:8px}.nina-reminder{background:#eafaf1;border:1px solid var(--emerald);border-radius:12px;padding:12px 16px;margin-bottom:.5rem}.nina-reminder-label{font-weight:700;color:var(--emerald);font-size:.85rem;margin-bottom:4px}.nina-reminder p:last-child{font-size:.95rem;color:#333;line-height:1.4}.parent-question-context{font-size:.8rem;color:var(--text-muted);font-style:italic;margin-bottom:.25rem}.multi-input-single-form{display:flex;align-items:center;gap:10px}.multi-input-row.single{flex-wrap:wrap;gap:10px}.session-workbook-task .workbook-view-btn{display:block;margin:1rem auto;font-size:1rem}.workbook-task-actions{display:flex;gap:12px;margin-top:1.5rem}.workbook-task-actions button{flex:1;padding:14px;font-size:1.05rem;border-radius:12px}.workbook-did-it{background:var(--emerald)!important;color:#fff!important}.workbook-need-help{background:#f5f5f5!important;color:#333!important;border:1px solid #ddd!important}.page-viewer-nav{display:flex;align-items:center;justify-content:center;gap:16px;padding:12px;background:#000000b3;position:fixed;bottom:0;left:0;right:0;z-index:1001}.page-nav-btn{background:#fff;color:#333;border:none;border-radius:8px;padding:8px 16px;font-size:.95rem;font-weight:600;cursor:pointer}.page-nav-btn:disabled{opacity:.3;cursor:default}.page-nav-label{color:#fff;font-size:.95rem;font-weight:600}.session-summary{display:flex;flex-direction:column;align-items:center;padding:2rem 1rem;gap:1.5rem;text-align:center}.summary-header{display:flex;flex-direction:column;align-items:center;gap:1rem}.summary-header h2{font-size:1.5rem;font-weight:800}.summary-mascot img{width:80px;height:80px;border-radius:50%;object-fit:cover;box-shadow:var(--shadow)}.summary-score{display:flex;flex-direction:column;align-items:center;gap:.5rem}.score-circle{width:120px;height:120px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:6px solid var(--score-colour, var(--teal));background:#fff}.score-number{font-size:2rem;font-weight:800;color:var(--text)}.score-detail{font-size:.9rem;color:var(--text-muted)}.celebration-message{font-size:1rem;font-weight:500;color:var(--text);max-width:400px}.topic-breakdown{width:100%;max-width:500px;text-align:left}.topic-breakdown h3{font-size:1rem;margin-bottom:.75rem}.topic-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.topic-name{font-size:.85rem;font-weight:500;min-width:100px;flex-shrink:0}.topic-bar-container{flex:1;height:8px;background:#e8ecef;border-radius:4px;overflow:hidden}.topic-bar{height:100%;border-radius:4px;transition:width .5s ease}.topic-score{font-size:.8rem;font-weight:600;color:var(--text-muted);min-width:30px;text-align:right}.email-note{font-size:.85rem;color:var(--text-muted);font-style:italic}.calendar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.calendar-modal{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-lg);max-width:960px;width:100%;max-height:90vh;overflow-y:auto;padding:1.5rem}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.calendar-header h2{font-size:1.2rem;font-weight:800}.close-btn{background:none;border:none;font-size:1.2rem;cursor:pointer;color:var(--text-muted);padding:.25rem}.calendar-loading{display:flex;justify-content:center;padding:2rem}.calendar-grid{display:flex;flex-direction:column;gap:2px}.calendar-row{display:grid;grid-template-columns:78px repeat(5,1fr);gap:3px}.calendar-row.current-week{outline:2px solid var(--teal);outline-offset:1px;border-radius:4px}.calendar-cell{padding:.35rem .25rem;font-size:.72rem;text-align:center;border-radius:4px;min-height:52px;display:flex;flex-direction:column;align-items:stretch;justify-content:center;gap:2px}.week-label{background:#f3f4f6;font-weight:700;gap:1px}.week-label .week-number{font-size:.85rem}.week-label .week-dates{font-size:.58rem;color:var(--text-muted);font-weight:500}.day-header{background:#f3f4f6;font-weight:700;color:var(--text-muted);min-height:26px;justify-content:center}.cell-none{background:#fafafa;border:1px dashed #e5e7eb}.cell-sessions{background:#fff;border:1px solid #e5e7eb}.cell-holiday{background:#eef2f7;border:1px solid #dbe1ea;color:#6b7280}.cell-holiday .cell-label{font-size:.6rem;font-weight:600}.cell-reserved{background:#fff8e1;border:1px dashed #e0b64d;color:#7a5a10}.cell-reserved .cell-label{font-weight:700;font-size:.68rem}.cell-reserved .cell-sub{font-size:.56rem;color:#a67c00}.cell-assessment{background:#fde8e8;border:1px solid #f1a8a8;color:#8a1f1f}.cell-assessment .cell-label{font-weight:700;font-size:.6rem;padding:0 2px}.session-stack{display:flex;flex-direction:column;gap:2px;margin-top:2px}.calendar-session{background:#fff;border:1px solid #e5e7eb;border-left:3px solid var(--session-colour, #888);border-radius:3px;padding:2px 4px;font-size:.58rem;display:flex;justify-content:space-between;align-items:center;gap:3px;line-height:1.1;position:relative;text-align:left}.calendar-session.clickable{cursor:pointer}.calendar-session.clickable:hover{background:#f3f4f6;box-shadow:0 1px 3px #0000001a}.calendar-session.completed{background:#e8f8ef;border-color:var(--emerald)}.calendar-session.mind_map{background:#fef3c7;border-color:#f59e0b}.calendar-session.test_exam{background:#ede9fe;border-color:#8b5cf6}.calendar-session-subject{font-weight:600;color:#111;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.calendar-session-badge{font-weight:700;color:var(--text-muted);flex-shrink:0}.calendar-session-check{color:var(--emerald);font-weight:700;flex-shrink:0}.calendar-empty{text-align:center;padding:2rem;color:var(--text-muted)}@media (max-width: 720px){.calendar-modal{padding:.9rem;max-width:100%}.calendar-row{grid-template-columns:56px repeat(5,1fr);gap:2px}.calendar-cell{font-size:.65rem;min-height:46px}.calendar-session{font-size:.52rem}.week-label .week-dates{display:none}}.cards-header-top{display:flex;align-items:center;justify-content:space-between}.header-actions{display:flex;gap:.5rem}.btn-icon{background:none;border:1px solid #e5e7eb;border-radius:var(--radius-sm);padding:.4rem .6rem;font-size:1.1rem;cursor:pointer;transition:background .15s}.btn-icon:hover{background:#f3f4f6}.btn-logout{font-style:normal;font-size:.9rem;font-weight:600}.session-progress-badge{font-size:.72rem;font-weight:600;color:var(--text-muted);margin-top:.25rem}.test-mode-section{margin-top:1rem;text-align:center;display:flex;flex-direction:column;gap:1rem;align-items:stretch}.btn-create-account{background:none;border:2px solid var(--teal);border-radius:var(--radius);padding:.7rem 1.5rem;font-family:var(--font);font-size:.95rem;font-weight:600;color:var(--teal);cursor:pointer;transition:all .15s}.btn-create-account:hover{background:var(--teal);color:#fff}.signup-step-indicator{color:var(--text-muted);font-size:.85rem;margin-top:-.25rem;margin-bottom:1rem}.signup-actions{display:flex;gap:.5rem;margin-top:1rem}.signup-actions .btn-primary,.signup-actions .btn-secondary{flex:1}.login-card select{width:100%;padding:.7rem .85rem;border:1px solid #d1d5db;border-radius:var(--radius);font-family:var(--font);font-size:.95rem;background:#fff;cursor:pointer}.btn-test-mode{background:none;border:2px dashed #d1d5db;border-radius:var(--radius);padding:.6rem 1.5rem;font-family:var(--font);font-size:.88rem;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .15s}.btn-test-mode:hover{border-color:var(--teal);color:var(--teal)}.test-email-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100}.test-email-card{background:var(--card-bg);border-radius:var(--radius);padding:2rem;max-width:400px;width:90%;box-shadow:var(--shadow-lg)}.test-email-card h2{margin-bottom:.5rem}.test-email-card p{color:var(--text-muted);margin-bottom:1rem;font-size:.9rem}.test-email-actions{display:flex;gap:.5rem;margin-top:1rem}.test-email-actions .btn-primary,.test-email-actions .btn-secondary{flex:1}.subject-overview{max-width:700px;margin:0 auto;padding:.5rem 0}.overview-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.overview-header h2{font-size:1.3rem;font-weight:800}.term-tabs{display:inline-flex;background:#f3f4f6;border-radius:999px;padding:4px;gap:2px}.term-tab{border:none;background:transparent;padding:8px 18px;font-size:.95rem;font-weight:600;color:#6b7280;border-radius:999px;cursor:pointer;transition:background .15s,color .15s}.term-tab:hover{color:#111827}.term-tab.active{background:var(--tab-colour, #4f46e5);color:#fff;box-shadow:0 1px 3px #00000026}.mind-map-card{background:var(--card-bg);border:2px solid #e8ecef;border-radius:var(--radius);overflow:hidden;cursor:pointer;margin-bottom:1.5rem;transition:box-shadow .15s;height:180px;position:relative}.mind-map-card:hover{box-shadow:var(--shadow)}.mind-map-iframe-thumb{border:none;display:block;pointer-events:none;width:1200px;height:900px;position:absolute;left:50%;top:50%;transform-origin:center center;transform:translate(-50%,-50%) scale(var(--thumb-scale, .33))}.mind-map-label{display:block;padding:.5rem 1rem;font-size:.78rem;font-weight:600;color:var(--text-muted);text-align:center;background:#fafafa}.session-mind-map .mind-map-preview{background:var(--card-bg);border:2px solid #e8ecef;border-radius:var(--radius);overflow:hidden;position:relative}.session-mind-map .mind-map-iframe{width:1200px;height:900px;border:none;display:block;transform-origin:0 0}.session-list{margin-bottom:1.5rem}.session-list h3{font-size:1rem;font-weight:700;margin-bottom:.75rem}.session-card{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.75rem 1rem;margin-bottom:.5rem;background:var(--card-bg);border:2px solid #e8ecef;border-radius:12px;cursor:pointer;font-family:var(--font);transition:all .15s;text-align:left}.session-card:hover{box-shadow:0 2px 8px #0000000f}.session-card.completed{border-color:#c8e6c9;background:#fafff9}.session-card.next{border-color:var(--card-colour, var(--teal));box-shadow:0 0 0 1px var(--card-colour, var(--teal)),0 2px 8px #0000000f}.session-card.not_started{opacity:.65}.session-card.not_started:hover{opacity:.85}.session-card-left{display:flex;align-items:center;gap:.75rem;min-width:0}.session-number{font-size:.85rem;font-weight:800;color:var(--text-muted);min-width:24px;text-align:center}.session-card-info{display:flex;flex-direction:column;gap:2px;min-width:0}.session-topic{font-size:.88rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.session-type{font-size:.72rem;font-weight:500;color:var(--text-muted);text-transform:capitalize}.session-card-right{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.score-badge{font-size:.75rem;font-weight:700;padding:2px 8px;border-radius:20px}.completed-badge{background:#e8f8ef;color:#1a7a2e}.best-badge{background:#fff8e1;color:#b8860b}.next-badge{background:#e8f1ff;color:var(--blue)}.test-exam-card{opacity:.45;border-style:dashed;cursor:default}.test-exam-card:hover{box-shadow:none}.fullscreen-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem;cursor:pointer}.fullscreen-close{position:fixed;top:1rem;right:1rem;background:#ffffffe6;border:none;border-radius:50%;width:40px;height:40px;font-size:1.2rem;cursor:pointer;z-index:201;display:flex;align-items:center;justify-content:center}.fullscreen-image{max-width:95vw;max-height:90vh;object-fit:contain;border-radius:8px;cursor:default}.mind-map-iframe-full{width:1200px;height:900px;flex-shrink:0;border:none;border-radius:8px;background:#f8f9fa;cursor:default;transform-origin:center center;transform:scale(var(--full-scale, 1))}.page-link{color:var(--blue);text-decoration:underline;cursor:pointer;font-weight:600}.page-link:hover{color:var(--teal)}.page-viewer-content{display:flex;align-items:center;justify-content:center;cursor:default}.page-viewer-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;color:#fff}.page-viewer-error{display:flex;flex-direction:column;align-items:center;gap:1rem;color:#fff;font-size:1rem}.page-range-cta{display:flex;align-items:center;gap:.85rem;width:100%;padding:.85rem 1rem;margin:.5rem 0 1rem;background:var(--card-bg);border:2px solid var(--subject-colour, var(--teal));border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;font-family:inherit;text-align:left;transition:transform .1s ease,box-shadow .1s ease}.page-range-cta:hover{transform:translateY(-1px);box-shadow:0 6px 18px #0000001a}.page-range-cta-icon{font-size:1.5rem}.page-range-cta-text{display:flex;flex-direction:column;gap:.15rem;flex:1}.page-range-cta-title{font-weight:700;color:var(--subject-colour, var(--text));font-size:.98rem}.page-range-cta-sub{font-size:.82rem;color:var(--text-muted)}.page-range-cta-chev{color:var(--subject-colour, var(--text));font-weight:700;font-size:1.15rem}.page-range-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.page-range-modal{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-lg);max-width:460px;width:100%;padding:1.5rem}.page-range-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.page-range-header h2{font-size:1.15rem;font-weight:800;margin:0}.page-range-description{font-size:.9rem;color:var(--text-muted);margin:0 0 1rem;line-height:1.4}.page-range-label{display:block;font-size:.85rem;font-weight:700;margin-bottom:.35rem;color:var(--text)}.page-range-input{width:100%;padding:.7rem .9rem;border:2px solid #e0e4e8;border-radius:10px;font-family:inherit;font-size:1rem;box-sizing:border-box}.page-range-input:focus{outline:none;border-color:var(--teal)}.page-range-hint{font-size:.8rem;color:var(--text-muted);margin:.4rem 0 0}.page-range-error{color:#c0392b;font-size:.88rem;margin:.75rem 0 0}.page-range-actions{display:flex;justify-content:flex-end;gap:.6rem;margin-top:1.25rem}.page-range-actions .btn-primary:disabled{opacity:.6;cursor:not-allowed}.page-range-recent-cta{display:flex;align-items:center;gap:.85rem;width:100%;padding:.9rem 1rem;margin:0 0 1rem;background:var(--card-bg);border:2px solid var(--subject-colour, var(--teal));border-radius:var(--radius);cursor:pointer;font-family:inherit;text-align:left;transition:transform .1s ease,box-shadow .1s ease;box-shadow:var(--shadow)}.page-range-recent-cta:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 18px #0000001a}.page-range-recent-cta:disabled{opacity:.6;cursor:not-allowed}.page-range-recent-icon{font-size:1.4rem;line-height:1}.page-range-recent-text{display:flex;flex-direction:column;gap:.15rem;flex:1}.page-range-recent-title{font-weight:700;color:var(--subject-colour, var(--text));font-size:.98rem}.page-range-recent-sub{font-size:.82rem;color:var(--text-muted)}.teacher-message-textarea{width:100%;min-height:180px;padding:.7rem .9rem;border:2px solid #e0e4e8;border-radius:10px;font-family:inherit;font-size:.95rem;line-height:1.45;box-sizing:border-box;resize:vertical}.teacher-message-textarea:focus{outline:none;border-color:var(--teal)}.teacher-message-link{display:block;margin:.85rem auto 0;background:none;border:none;padding:.25rem .5rem;color:var(--text-muted);font-family:inherit;font-size:.85rem;text-decoration:underline;cursor:pointer}.teacher-message-link:hover:not(:disabled){color:var(--text)}.teacher-message-link:disabled{opacity:.6;cursor:not-allowed}.teacher-message-bullets{list-style:none;margin:0 0 1rem;padding:0}.teacher-message-bullets li{margin-bottom:.4rem}.teacher-message-bullets label{display:flex;align-items:flex-start;gap:.55rem;padding:.5rem .6rem;background:#f7f9fb;border-radius:8px;cursor:pointer;font-size:.92rem;line-height:1.35}.teacher-message-bullets input[type=checkbox]{margin-top:.2rem;flex:0 0 auto}.teacher-message-bullet-text{flex:1;color:var(--text)}.teacher-message-bullet-pages{font-size:.78rem;color:var(--text-muted);white-space:nowrap}.teacher-message-skipping{margin:0 0 1rem;padding:.55rem .75rem;background:#fffbeb;border:1px solid #fde68a;border-radius:8px;color:#92400e;font-size:.85rem;cursor:help}.teacher-message-info{background:#f0f4ff;border:1px solid #dbe4f0;border-radius:10px;padding:.75rem .9rem;font-size:.85rem;color:#1e3a8a;line-height:1.4}.teacher-message-info strong{display:block;margin-bottom:.35rem;color:#1e40af}.teacher-message-info ul{margin:0;padding-left:1.1rem}.teacher-message-info li{margin-bottom:.25rem}.teacher-message-info li:last-child{margin-bottom:0}.mascot-active-row{display:flex;align-items:stretch;gap:.5rem}.mascot-active-row .mascot-active{flex:1}.mascot-breathe-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.15rem;background:#fff;border:2px solid var(--mascot-colour, #e5e7eb);border-radius:var(--radius);padding:.5rem .85rem;cursor:pointer;font-family:inherit;transition:transform .15s,box-shadow .2s}.mascot-breathe-btn:hover{transform:scale(1.04);box-shadow:var(--shadow)}.breathe-icon{font-size:1.25rem;line-height:1}.breathe-label{font-size:.7rem;font-weight:700;color:#4b5563}.breathing-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#fafaf8,#fff);z-index:1000;display:flex;align-items:center;justify-content:center;padding:1.5rem;overflow:hidden}.breathing-overlay:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 45%,var(--breath-glow) 0%,transparent 60%);pointer-events:none;opacity:.8}.breathing-close{position:absolute;top:1rem;right:1rem;width:40px;height:40px;border-radius:50%;border:none;background:#0000000f;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text);z-index:2}.breathing-close:hover{background:#0000001f}.breathing-intro,.breathing-outro{position:relative;z-index:1;max-width:28rem;display:flex;flex-direction:column;align-items:center;text-align:center;gap:.85rem;animation:breathFadeIn .4s ease-out}@keyframes breathFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.breathing-mascot-static{position:relative;width:140px;height:140px;display:flex;align-items:center;justify-content:center;margin-bottom:.5rem}.breathing-mascot-static img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 6px 24px var(--breath-glow))}.breathing-ornament{position:absolute;bottom:-4px;right:-4px;background:#fff;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;box-shadow:var(--shadow)}.breathing-intro h2,.breathing-outro h2{font-size:1.6rem;font-weight:800;color:var(--text);margin-bottom:.25rem}.breathing-intro p{font-size:1.05rem;line-height:1.5;color:#374151}.breathing-begin{margin-top:1rem;background:var(--breath-colour);color:var(--text);border:none;border-radius:var(--radius-full);padding:.85rem 2.5rem;font-size:1.05rem;font-weight:800;font-family:inherit;cursor:pointer;box-shadow:0 6px 20px var(--breath-glow);transition:transform .15s,box-shadow .2s}.breathing-begin:hover{transform:scale(1.04);box-shadow:0 8px 28px var(--breath-glow)}.breathing-meta{font-size:.8rem;color:var(--text-muted);margin-top:.25rem}.breathing-stage{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:2.5rem}.breathing-cycle{font-size:.85rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted)}.breathing-circle{position:relative;width:240px;height:240px;display:flex;align-items:center;justify-content:center;transition:transform 3s cubic-bezier(.45,0,.55,1);transform:scale(.7)}.breathing-circle.phase-in,.breathing-circle.phase-hold-in{transform:scale(1)}.breathing-circle.phase-out,.breathing-circle.phase-hold-out{transform:scale(.7)}.breathing-ring{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:radial-gradient(circle,var(--breath-glow) 0%,transparent 70%);border:3px solid var(--breath-colour);box-shadow:0 0 60px var(--breath-glow),inset 0 0 40px var(--breath-glow)}.breathing-mascot{position:relative;width:75%;height:75%;object-fit:contain;filter:drop-shadow(0 4px 16px var(--breath-glow))}.breathing-label{font-size:1.5rem;font-weight:700;color:var(--text);letter-spacing:.02em;animation:labelFade .4s ease-out}@keyframes labelFade{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 480px){.breathing-circle{width:200px;height:200px}.breathing-mascot-static{width:110px;height:110px}.breathing-intro h2,.breathing-outro h2{font-size:1.4rem}.breathing-intro p{font-size:1rem}}@media (prefers-reduced-motion: reduce){.breathing-circle{transition:none}}.focus-guard-overlay{z-index:1100}.focus-guard-content h2{margin-bottom:.1rem}.focus-guard-ai{min-height:1.5em;font-style:italic;color:#4b5563;opacity:0;transform:translateY(4px);transition:opacity .45s ease-out,transform .45s ease-out}.focus-guard-ai.visible{opacity:1;transform:translateY(0)}.focus-guard-content .breathing-begin{color:#fff}.celebration-overlay{z-index:1100}.celebration-ai{min-height:1.5em;font-size:1.05rem;color:#1f2937;opacity:0;transform:translateY(4px);transition:opacity .45s ease-out,transform .45s ease-out;margin:.5rem 0 1.25rem}.celebration-ai.visible{opacity:1;transform:translateY(0)}.celebration-affirmation{margin:.25rem 0 1.5rem;font-size:.95rem;color:#374151}.celebration-affirmation-label{display:block;font-size:.8rem;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.3rem}.celebration-affirmation strong{display:block;font-size:1.1rem;color:#111827}
