@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap");@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+Arabic:wght@400;500;600;700&display=swap");:root{--teal:#14b8a6;--teal-dark:#0d9488;--teal-light:#ccfbf1;--teal-bg:#f0fdfa;--sidebar-w:72px;--text:#1e293b;--muted:#64748b;--border:#e2e8f0;--card-shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.06);--radius:12px}*{box-sizing:border-box;margin:0;padding:0}body.app-shell{display:flex;position:fixed;inset:0}.page-shell,body.app-shell,html.app-shell{overflow:hidden}.page-shell{display:flex;position:fixed;inset:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f8fafc;color:var(--text)}.sidebar{width:var(--sidebar-w);background:#fff;-webkit-border-end:1px solid var(--border);border-inline-end:1px solid var(--border);flex-direction:column;padding:12px 0;gap:4px;flex-shrink:0;z-index:50}.sidebar,.sidebar-logo{display:flex;align-items:center}.sidebar-logo{width:40px;height:40px;margin-bottom:12px;justify-content:center}.sidebar-logo img{width:36px;height:36px;object-fit:contain}.nav-icon{width:44px;height:44px;border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;gap:2px;color:var(--muted);font-size:18px;transition:all .15s;border:none;background:none}.nav-icon:hover{background:#f1f5f9;color:var(--text)}.nav-icon.active{background:var(--teal-light);color:var(--teal)}.nav-icon span.label{font-size:9px;font-weight:600;letter-spacing:.02em}.sidebar-bottom{margin-top:auto}.desktop-only-nav,.sidebar-bottom{display:flex;flex-direction:column;gap:4px;align-items:center}.mobile-only-nav{display:none}.lang-globe-btn,.lang-globe-wrap{position:relative}.lang-globe-dropdown{position:absolute;bottom:calc(100% + 8px);inset-inline-end:0;background:#fff;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.18);padding:8px;display:flex;flex-direction:column;gap:2px;min-width:120px;z-index:200;animation:fadeIn .15s ease}.lang-globe-item{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:8px;border:none;background:transparent;cursor:pointer;font-size:13px;font-weight:500;color:var(--text);transition:background .12s;width:100%}.lang-globe-item:hover{background:#f1f5f9}.lang-globe-item.active{background:var(--teal-light);color:var(--teal);font-weight:700}.lang-globe-item.signout{color:var(--muted)}.lang-globe-item.signout:hover{background:#fee2e2;color:#ef4444}.lang-globe-divider{height:1px;background:var(--border);margin:4px 0}.main-area{min-width:0;overflow:hidden}#view-browse,.main-area{flex:1 1;min-height:0;display:flex;flex-direction:column}#view-browse{overflow-y:auto;overflow-x:hidden}#view-browse::-webkit-scrollbar{width:5px}#view-browse::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.browse-hero{padding:32px 40px 28px;color:#fff;position:relative;overflow:hidden;background:linear-gradient(135deg,#14b8a6,#0d9488);flex-shrink:0}.browse-hero:after{content:"";position:absolute;inset-inline-end:-20px;top:-20px;width:200px;height:200px;background:hsla(0,0%,100%,.06);border-radius:50%}.browse-hero-row{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:12px;position:relative;z-index:1}.browse-hero-content{position:relative;z-index:1;flex:1 1;min-width:0}.browse-hero-title{font-size:28px;font-weight:800;margin:0 0 6px;line-height:1.2}.browse-hero-subtitle{opacity:.85;font-size:14px;margin:0;line-height:1.5}.browse-hero-note{font-size:13px;margin-top:8px;opacity:.75;line-height:1.4}.browse-hero-note strong{font-weight:700;opacity:1}.browse-hero-note .model-number{font-weight:400;opacity:.7}.browse-header-row{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:12px;position:relative;z-index:1}.ask-gali-hero{background:hsla(0,0%,100%,.15);border:1.5px solid hsla(0,0%,100%,.35);color:#fff;padding:8px 18px;border-radius:24px;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:background .15s;white-space:nowrap;flex-shrink:0;align-self:flex-start;margin-top:4px}.ask-gali-hero:hover{background:hsla(0,0%,100%,.25)}.filter-bar{padding:16px 40px;border-bottom:1px solid var(--border);gap:8px;flex-wrap:wrap;position:-webkit-sticky;position:sticky;top:0;z-index:10}.filter-bar,.filter-btn{background:#fff;display:flex;align-items:center}.filter-btn{padding:7px 18px;border-radius:24px;font-size:13px;font-weight:600;border:1.5px solid var(--border);color:var(--muted);cursor:pointer;transition:all .15s;gap:6px;white-space:nowrap;flex-shrink:0}.filter-btn:hover{border-color:var(--teal);color:var(--teal)}.filter-btn.active{background:var(--teal);color:#fff;border-color:var(--teal)}.filter-count{font-size:11px;opacity:.75}.filter-divider{width:1px;height:24px;background:var(--border);margin:0 4px}.more-filters-btn{-webkit-margin-start:auto;margin-inline-start:auto;padding:7px 16px;border-radius:24px;font-size:13px;font-weight:600;border:1.5px solid var(--border);background:#fff;color:var(--muted);cursor:pointer}.browse-content{padding:24px 40px 40px}.browse-section{margin-bottom:36px}.browse-section-header{margin-bottom:16px}.browse-section-header h2{font-size:20px}.browse-section-nav{display:flex;align-items:center;gap:8px}.browse-all-btn{padding:5px 14px;border-radius:20px;font-size:13px;font-weight:600;border:1.5px solid var(--border);background:#fff;color:var(--teal);cursor:pointer;transition:all .15s}.browse-all-btn:hover{background:var(--teal-light)}.scroll-btn{width:32px;height:32px;border-radius:50%;border:1.5px solid var(--border);background:#fff;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.scroll-btn:hover{background:var(--teal);color:#fff;border-color:var(--teal)}.cards-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(200px,100%),1fr));grid-gap:16px;gap:16px;max-width:100%}.exp-card{background:#fff;border-radius:var(--radius);border:1px solid var(--border);cursor:pointer;transition:transform .18s,box-shadow .18s;overflow:hidden;display:flex;flex-direction:column}.exp-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.1)}.card-header-area{padding:16px 16px 0;display:flex;align-items:flex-start;justify-content:space-between}.card-icon-wrap{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center}.card-icon{font-size:28px;line-height:1}.card-exp-number{font-size:11px;font-weight:700;padding:3px 8px;border-radius:10px;letter-spacing:.02em}.card-body{padding:12px 16px 8px;flex:1 1}.card-section-badge{display:inline-block;color:#fff;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:3px 10px;border-radius:12px;margin-bottom:8px}.card-title{font-size:15px;font-weight:700;color:var(--text);margin-bottom:6px;line-height:1.3}.card-desc{font-size:12px;color:var(--muted);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-footer{padding:10px 16px 14px;display:flex;flex-wrap:wrap;gap:6px;border-top:1px solid var(--border);margin-top:auto}.card-meta-badge{font-size:11px;color:var(--muted);background:#f8fafc;padding:3px 8px;border-radius:8px;white-space:nowrap}.exp-card-done{position:absolute;top:-5px;inset-inline-end:-5px;width:20px;height:20px;background:#22c55e;color:#fff;border-radius:50%;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid #fff;line-height:1}.card-icon-wrap{position:relative}.card-progress-badge{position:absolute;top:8px;inset-inline-end:8px;padding:3px 8px;border-radius:12px;font-size:11px;font-weight:600;display:flex;align-items:center;gap:4px;z-index:2}.card-progress-badge.good{background:#d1fae5;color:#047857}.card-progress-badge.mid{background:#fef3c7;color:#92400e}.card-progress-badge.low{background:#fee2e2;color:#b91c1c}.gali-help-btn{margin-top:8px;padding:6px 12px;font-size:12px;font-weight:600;color:#0d9488;background:#f0fdfa;border:1px solid #99f6e4;border-radius:6px;cursor:pointer;transition:all .15s ease}.gali-help-btn:hover{background:#ccfbf1;border-color:#5eead4}.quiz-score-wrap{background:#f8fafc;border:1px solid var(--border);border-radius:12px;padding:12px 16px;margin-bottom:20px}.quiz-score-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;flex-wrap:wrap;gap:4px}.quiz-score-text{font-size:13px;font-weight:600;color:var(--text)}.quiz-score-result{font-size:13px;font-weight:600;color:var(--primary)}.quiz-score-bar{height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden}.quiz-score-fill{height:100%;background:linear-gradient(90deg,#22c55e,#16a34a);border-radius:4px;transition:width .5s ease}.quiz-reset-btn{display:block;margin-top:10px;-webkit-margin-start:auto;margin-inline-start:auto;background:none;border:1.5px solid var(--border);color:var(--muted);font-size:12px;font-weight:600;padding:5px 14px;border-radius:20px;cursor:pointer;transition:border-color .15s,color .15s}.quiz-reset-btn:hover{border-color:var(--primary);color:var(--primary)}.browse-progress-wrap{display:flex;align-items:center;gap:10px;margin-top:10px}.browse-progress-bar{flex:1 1;height:6px;background:hsla(0,0%,100%,.25);border-radius:3px;overflow:hidden;max-width:200px}.browse-progress-fill{height:100%;background:hsla(0,0%,100%,.9);border-radius:3px;transition:width .5s ease}.browse-progress-label{font-size:12px;color:hsla(0,0%,100%,.85);font-weight:500;white-space:nowrap}#view-experiment{overflow:hidden;display:none}#view-experiment,.exp-view{flex:1 1;flex-direction:column;min-height:0}.exp-view{display:flex;min-width:0}.exp-teal-header{padding:20px 32px 0;color:#fff;flex-shrink:0;overflow:hidden}.exp-header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.back-btn{background:hsla(0,0%,100%,.15);border:1.5px solid hsla(0,0%,100%,.3);color:#fff;padding:6px 14px;border-radius:20px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.back-btn:hover{background:hsla(0,0%,100%,.25)}.ask-gali-btn{border:1.5px solid hsla(0,0%,100%,.35);padding:7px 18px;border-radius:24px;display:flex;align-items:center;gap:6px;transition:background .15s}.ask-gali-btn:hover{background:hsla(0,0%,100%,.28)}.exp-h1{font-size:26px;font-weight:800;margin-bottom:4px}.exp-subtitle{font-size:13px;opacity:.85;margin-bottom:10px}.exp-badges{gap:8px;margin-bottom:14px}.exp-badge{background:hsla(0,0%,100%,.18);padding:4px 12px;font-size:11px}.main-tabs{display:flex;gap:2px;border-bottom:none;flex-wrap:wrap;overflow:hidden}.main-tab{padding:10px 20px;border:none;background:hsla(0,0%,100%,.1);color:hsla(0,0%,100%,.75);font-size:13px;font-weight:600;border-radius:10px 10px 0 0;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:6px}.main-tab:hover{background:hsla(0,0%,100%,.2);color:#fff}.main-tab.active{background:#fff;color:var(--teal)}.exp-body{overflow:hidden;background:#f8fafc}.exp-body,.exp-main-col{flex:1 1;min-height:0;display:flex}.exp-main-col{min-width:0;overflow-y:auto;overflow-x:hidden;padding:24px;flex-direction:column;gap:16px}.exp-main-col::-webkit-scrollbar{width:5px}.exp-main-col::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.tab-pane{display:none}.tab-pane.active{display:block}.content-card{background:#fff;border-radius:var(--radius);border:1px solid var(--border);padding:24px;box-shadow:var(--card-shadow)}.content-card h3{font-size:16px;font-weight:700;color:var(--text);margin-bottom:10px;margin-top:18px}.content-card h3:first-child{margin-top:0}.content-card h4.section-subhead{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin:14px 0 6px;border-bottom:1px solid var(--border);padding-bottom:4px}.content-card p{font-size:14px;color:#475569;line-height:1.7;margin-bottom:10px}.content-card ol,.content-card ul{-webkit-margin-start:20px;margin-inline-start:20px;margin-bottom:10px}.content-card li{font-size:14px;color:#475569;line-height:1.7;margin-bottom:4px}.concept-list li{font-size:14px;color:#1e293b;line-height:1.7;margin-bottom:6px;-webkit-padding-start:4px;padding-inline-start:4px}.clean-eq-list li{font-size:14px;color:#1e293b;line-height:1.8}.content-card li.num{list-style:decimal}.empty{font-style:italic;font-size:13px}.empty,.hint-text{color:var(--muted)}.hint-text{font-size:12px;margin-bottom:8px}.formula-box{background:var(--teal-bg);border:1px solid var(--teal-light);border-radius:8px;padding:10px 16px;margin:12px 0;display:flex;align-items:center;gap:10px}.formula-box .fl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--teal);flex-shrink:0}.formula-box code{font-family:Courier New,monospace;font-size:14px;font-weight:600;color:var(--text)}.right-panel{width:340px;background:#fff;-webkit-border-start:1px solid var(--border);border-inline-start:1px solid var(--border);flex-direction:column;overflow:hidden}.right-panel,.rp-tabs{flex-shrink:0;display:flex}.rp-tabs{border-bottom:1px solid var(--border)}.rp-tab{flex:1 1;padding:12px;font-size:13px;font-weight:600;background:none;color:var(--muted);cursor:pointer;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .14s}.rp-tab:hover{color:var(--text)}.rp-tab.active{color:var(--teal);border-bottom-color:var(--teal)}.rp-pane{display:none;flex:1 1;overflow-y:auto;overflow-x:hidden;padding:16px;min-height:0}.rp-pane::-webkit-scrollbar{width:4px}.rp-pane::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.rp-pane.active{display:block}.rp-section h4{font-size:13px;font-weight:700;color:var(--text);margin-bottom:10px}.eq-grid{grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px}.eq-item{padding:10px;gap:4px}.eq-emoji{font-size:28px}.eq-name{line-height:1.3}.cb-label{width:130px}.cb-bar-wrap{height:8px;background:#f1f5f9;border-radius:4px}.cb-bar{border-radius:4px;transition:width .4s ease}.cb-pct{width:30px}.misc-list{gap:8px}.misconception{font-size:12px;border-radius:6px}.misconception.wrong{background:#fef2f2;color:#991b1b;-webkit-border-start:3px solid #ef4444;border-inline-start:3px solid #ef4444}.hook-box{-webkit-border-start:4px solid var(--teal);border-inline-start:4px solid var(--teal)}.khan-link{background:#fff7ed;border:1px solid #fed7aa;color:#c2410c;font-size:12px;font-weight:600;transition:all .15s;cursor:pointer}.khan-link:hover{background:#ffedd5;border-color:#fb923c;color:#9a3412;transform:translateX(2px)}.khan-link:active{background:#fed7aa}.khan-icon{font-size:10px;flex-shrink:0;color:#f97316}.khan-title{line-height:1.3}.khan-note{font-size:11px;color:#9ca3af;margin:4px 0 0;text-align:center}.rp-pane#rpp-chat-placeholder{padding:0}.chat-messages{flex:1 1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px;min-height:0;max-height:320px}.chat-messages::-webkit-scrollbar{width:3px}.chat-messages::-webkit-scrollbar-thumb{background:var(--border)}.chat-msg{display:flex;gap:8px;align-items:flex-start}.chat-msg.user{flex-direction:row-reverse}.gali-avatar{font-size:12px}.chat-bubble{max-width:85%;padding:10px 14px;border-radius:12px;font-size:13px;line-height:1.6}.gali-bubble{background:#f8fafc;border:1px solid var(--border);color:var(--text)}.user-bubble{background:var(--teal);color:#fff;border-radius:12px;border-end-end-radius:2px}.gali-bubble ul{-webkit-margin-start:16px;margin-inline-start:16px;margin-top:4px}.gali-bubble li{margin-bottom:3px}.gali-bubble ol{-webkit-margin-start:16px;margin-inline-start:16px;margin-top:4px}.gali-bubble blockquote{-webkit-border-start:3px solid var(--teal);border-inline-start:3px solid var(--teal);-webkit-padding-start:8px;padding-inline-start:8px;color:var(--muted);margin:6px 0}.chat-formula{background:var(--teal-bg);padding:6px 10px;border-radius:6px;font-family:monospace;font-size:13px;margin:6px 0;font-weight:600}.chat-quick-btns{padding:8px 12px;display:flex;gap:6px;flex-wrap:wrap;border-top:1px solid var(--border)}.quick-btn{padding:5px 10px;border-radius:20px;font-size:11px;font-weight:600;border:1.5px solid var(--border);background:#fff;color:var(--muted);cursor:pointer;transition:all .14s}.quick-btn:hover{background:var(--teal-light);border-color:var(--teal);color:var(--teal)}.chat-tone-btns{padding:4px 12px;display:flex;gap:5px;flex-wrap:wrap}.tone-btn{padding:4px 10px;border-radius:14px;font-size:11px;font-weight:600;border:1.5px solid var(--border);background:#fff;color:var(--muted);cursor:pointer;transition:all .14s}.tone-btn:hover{background:#f8fafc}.tone-btn.active{background:var(--teal-light);border-color:var(--teal);color:var(--teal)}.chat-input-row{padding:10px 12px;border-top:1px solid var(--border);display:flex;gap:6px}.chat-input{flex:1 1;padding:9px 12px;border-radius:8px;border:1.5px solid var(--border);font-size:13px;outline:none;transition:border .15s}.chat-input:focus{border-color:var(--teal)}.chat-submit{padding:9px 16px;background:var(--teal);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s;white-space:nowrap}.chat-submit:hover{background:var(--teal-dark)}.chat-thinking{display:flex;gap:4px;padding:8px 12px;align-items:center}.dot{width:6px;height:6px;border-radius:50%;background:var(--teal);animation:bounce .8s infinite}.dot:nth-child(2){animation-delay:.15s}.dot:nth-child(3){animation-delay:.3s}@keyframes bounce{0%,80%,to{transform:scale(.8);opacity:.6}40%{transform:scale(1.2);opacity:1}}.results-form{display:flex;flex-direction:column;gap:20px}.conclusion-section h4,.obs-section h4,.results-table-wrap h4{font-size:14px;font-weight:700;color:var(--text);margin-bottom:10px}.table-scroll{overflow-x:auto}.data-entry-table{border-collapse:collapse;width:100%;font-size:13px}.data-entry-table th{background:#f8fafc;padding:8px 10px;border:1px solid var(--border);font-weight:600;color:var(--muted);font-size:11px;white-space:nowrap}.data-entry-table td{padding:0}.data-entry-table td,.row-num{border:1px solid var(--border)}.row-num{background:#f8fafc;padding:6px 10px;font-size:12px;color:var(--muted);font-weight:600;text-align:center}.data-cell{width:100%;border:none;padding:7px 10px;font-size:13px;outline:none;background:transparent;text-align:center}.data-cell:focus{background:var(--teal-bg)}.data-cell.valid{background:#f0fdf4}.data-cell.invalid{background:#fef2f2}.table-actions{display:flex;gap:8px;margin-top:8px}.obs-field{margin-bottom:12px}.obs-field label{font-size:13px;color:var(--text);margin-bottom:4px;display:block;line-height:1.5}.conclusion-section textarea,.obs-field textarea,.personal-notes,.teacher-notes-input{width:100%;max-width:100%;box-sizing:border-box;border:1.5px solid var(--border);border-radius:8px;padding:10px 12px;font-size:13px;font-family:inherit;outline:none;transition:border .15s;resize:vertical;line-height:1.6}.conclusion-section textarea:focus,.obs-field textarea:focus,.personal-notes:focus,.teacher-notes-input:focus{border-color:var(--teal)}.btn-secondary{padding:7px 16px;border-radius:8px;border:1.5px solid var(--border);background:#fff;color:var(--text);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.btn-secondary:hover{background:#f8fafc;border-color:var(--teal);color:var(--teal)}.btn-check-results{width:100%;padding:12px;background:var(--teal);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:700;cursor:pointer;transition:background .15s;display:flex;align-items:center;justify-content:center;gap:6px}.btn-check-results:hover{background:var(--teal-dark)}.ai-results-feedback{background:var(--teal-bg);border:1px solid var(--teal-light)}.rf-header{padding:8px 14px;font-size:12px;display:flex;align-items:center;gap:6px}.rf-body{padding:12px 14px}.rf-hint{background:rgba(20,184,166,.08);color:var(--teal-dark)}.rf-expected,.rf-hint{padding:8px 14px}.questions-tab{display:flex;flex-direction:column;gap:24px}.q-section h3{font-size:16px;font-weight:700;color:var(--text);margin-bottom:14px}.q-item,.q-open{display:flex;gap:12px;margin-bottom:16px;align-items:flex-start}.q-check-icon{width:20px;height:20px;border-radius:50%;background:var(--teal);color:#fff;font-size:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}.q-content{flex:1 1}.q-text{font-size:14px;color:var(--text);margin-bottom:8px;line-height:1.5}.q-answers{display:flex;flex-direction:column;gap:6px}.q-btn{text-align:start;padding:8px 14px;border-radius:8px;border:1.5px solid var(--border);background:#fff;font-size:13px;color:#475569;cursor:pointer;transition:all .14s}.q-btn:hover:not(:disabled){background:var(--teal-bg);border-color:var(--teal)}.q-btn.correct{background:#dcfce7;border-color:#16a34a;color:#15803d;font-weight:600}.q-btn.wrong{background:#fee2e2;border-color:#ef4444;color:#dc2626}.q-btn:disabled{cursor:default}.q-feedback{font-size:12px;margin-top:6px;padding:6px 10px;border-radius:6px;display:none;line-height:1.5}.q-feedback.show{display:block}.q-feedback.correct{background:#dcfce7;color:#15803d}.q-feedback.wrong{background:#fff7ed;color:#92400e}.q-open textarea{width:100%;border:1.5px solid var(--border);border-radius:8px;padding:8px 12px;font-size:13px;font-family:inherit;outline:none;transition:border .15s;resize:vertical}.q-open textarea:focus{border-color:var(--teal)}.teacher-only{display:none}body.teacher-mode .teacher-only{display:block}.teacher-notes-input{background:#fffbeb}.teacher-mode-bar{display:none;background:#f59e0b;color:#fff;padding:6px 24px;font-size:12px;font-weight:700;text-align:center;letter-spacing:.03em;position:fixed;top:0;inset-inline:0;z-index:299;height:auto;width:100%}body.teacher-mode .teacher-mode-bar{display:block}body.teacher-mode{padding-top:32px}body.teacher-mode .sidebar{top:32px;height:calc(100vh - 32px)}body.teacher-mode .page-shell{top:32px;bottom:0}.course-quiz-panel{background:var(--card-bg,#fff);border:1px solid var(--border);border-radius:var(--radius,12px);padding:24px;margin:8px 16px 16px}.course-quiz-panel h3{font-size:18px;font-weight:700;margin-bottom:4px}.course-quiz-panel .quiz-meta{font-size:13px;color:var(--muted);margin-bottom:20px}.quiz-question{border-top:1px solid var(--border);padding:16px 0}.quiz-question-header{display:flex;align-items:center;gap:8px;margin-bottom:10px;font-weight:600}.difficulty-badge{font-size:11px;padding:2px 8px;border-radius:12px;font-weight:600}.difficulty-easy{background:#dcfce7;color:#166534}.difficulty-medium{background:#fef3c7;color:#92400e}.difficulty-hard{background:#fee2e2;color:#991b1b}.quiz-options{display:flex;flex-direction:column;gap:8px;-webkit-margin-start:8px;margin-inline-start:8px}.quiz-option{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:8px;cursor:pointer;transition:background .15s;border:1px solid transparent;background:none;text-align:start;font-size:14px;width:100%}.quiz-option:hover:not(:disabled){background:rgba(20,184,166,.08)}.quiz-option.selected{background:rgba(20,184,166,.12);font-weight:600}.quiz-option.correct{background:#dcfce7;border-color:#22c55e}.quiz-option.incorrect{background:#fee2e2;border-color:#ef4444}.quiz-short-answer{width:100%;max-width:400px;padding:10px 14px;border:1px solid var(--border);border-radius:8px;font-size:14px}.quiz-short-answer:focus{outline:none;border-color:var(--teal)}.quiz-explanation{margin-top:8px;padding:10px 14px;background:rgba(20,184,166,.06);border-radius:8px;font-size:13px;color:var(--text);line-height:1.5}.quiz-score{text-align:center;padding:20px;margin-top:16px;background:linear-gradient(135deg,rgba(20,184,166,.08),rgba(20,184,166,.02));border-radius:12px}.quiz-score-big{font-size:32px;font-weight:800;color:var(--teal)}.tf-options{display:flex;gap:16px}.tf-option{padding:8px 24px;border:2px solid var(--border);border-radius:8px;cursor:pointer;font-weight:600;transition:all .15s;background:none;font-size:14px}.tf-option.selected,.tf-option:hover:not(:disabled){border-color:var(--teal)}.tf-option.selected{background:rgba(20,184,166,.1)}.tf-option.correct{background:#dcfce7;border-color:#22c55e}.tf-option.incorrect{background:#fee2e2;border-color:#ef4444}.quiz-progress{font-size:12px;color:var(--muted)}.quiz-progress.completed{color:var(--teal);font-weight:600}[dir=rtl] .quiz-short-answer{text-align:end}.robotics-section-divider{height:1px;background:var(--border);margin:1rem 0 1.25rem}.search-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:100;display:none;align-items:flex-start;justify-content:center;padding-top:80px}.search-overlay.open{display:flex}.search-box{background:#fff;border-radius:16px;width:600px;max-width:95vw;box-shadow:0 20px 60px rgba(0,0,0,.2);overflow:hidden}.search-input-wrap{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid var(--border)}.search-main-input{flex:1 1;border:none;font-size:16px;color:var(--text);outline:none}.search-close-btn{background:none;border:none;font-size:20px;color:var(--muted);cursor:pointer}.search-results{max-height:400px;overflow-y:auto}.search-item{padding:12px 20px;cursor:pointer;border-bottom:1px solid #f8fafc;display:flex;align-items:center;gap:12px;transition:background .12s}.search-item:hover{background:#f8fafc}.search-item-emoji{font-size:24px;width:36px;text-align:center}.search-item-section{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px}.search-item-title{font-size:14px;font-weight:600;color:var(--text)}.search-item-desc{font-size:12px;color:var(--muted)}.teacher-toggle{position:fixed;bottom:80px;inset-inline-end:24px;z-index:40;background:var(--teal);color:#fff;border:none;border-radius:50%;width:52px;height:52px;font-size:20px;cursor:pointer;box-shadow:0 4px 16px rgba(20,184,166,.4);transition:all .2s}.teacher-toggle:hover{transform:scale(1.08);box-shadow:0 6px 20px rgba(20,184,166,.5)}.toast{position:fixed;bottom:80px;inset-inline-end:24px;background:var(--text);color:#fff;padding:10px 20px;border-radius:10px;font-size:13px;font-weight:600;z-index:200;opacity:0;transition:opacity .3s;pointer-events:none}.toast.show{opacity:1}.mobile-panel-btn{display:none}@media(max-width:900px){.right-panel{display:none}.right-panel.mobile-open{display:flex;position:fixed;bottom:56px;inset-inline:0;height:50vh;width:100%;-webkit-border-start:none;border-inline-start:none;border-top:1px solid var(--border);box-shadow:0 -4px 20px rgba(0,0,0,.12);z-index:45;background:#fff;flex-direction:column}.mobile-panel-btn{display:flex;align-items:center;gap:6px;position:fixed;bottom:68px;inset-inline-end:16px;z-index:44;background:var(--teal);color:#fff;border:none;border-radius:24px;padding:8px 16px;font-size:13px;font-weight:600;box-shadow:0 4px 14px rgba(20,184,166,.4);cursor:pointer;transition:all .2s}.mobile-panel-btn:hover{background:var(--teal-dark)}.teacher-toggle{bottom:68px;inset-inline-end:80px}.toast{bottom:68px}.gali-modal-overlay{align-items:flex-end;padding:0}.gali-modal{width:100%;max-width:100%;border-radius:20px 20px 0 0;height:85vh;max-height:85vh;animation:slideSheet .25s ease}}@media(max-width:768px){html.app-shell{overflow-x:hidden;overflow-y:auto}body.app-shell{overflow-x:hidden;overflow-y:auto;width:100%;padding-bottom:calc(56px + env(safe-area-inset-bottom,0px))}.page-shell,body.app-shell{position:static;height:auto;min-height:100vh;flex-direction:column}.page-shell{overflow:visible}.main-area{order:1;width:100%}#view-browse,.main-area{flex:none;overflow:visible}#view-browse{display:flex;flex-direction:column}.exp-view{overflow:visible}.exp-body{flex-direction:column}.exp-body,.exp-main-col{overflow:visible;min-height:unset}.exp-main-col{height:auto;max-height:none;padding:14px 12px 32px;gap:14px}.sidebar{order:2;width:100%;height:calc(56px + env(safe-area-inset-bottom,0px));flex-direction:row;-webkit-border-end:none;border-inline-end:none;border-top:1px solid var(--border);padding:0 8px env(safe-area-inset-bottom,0);position:fixed;bottom:0;inset-inline:0;z-index:50;gap:0;background:#fff}.sidebar-logo{display:none}[data-tour=sidebar-nav]{display:flex;flex:4 1;gap:0}.sidebar-bottom{margin-top:0;-webkit-margin-start:0;margin-inline-start:0;flex-direction:row;gap:0;flex:1 1}.desktop-only-nav,.mobile-nav-hide{display:none!important}.lang-globe-wrap,.mobile-only-nav{display:flex;flex:1 1}.lang-globe-wrap .lang-globe-btn{flex:1 1;width:100%}.nav-icon{flex:1 1;width:auto;min-width:44px;height:56px;border-radius:0;gap:3px;font-size:20px;padding:6px 4px}.nav-icon span.label{font-size:9px}.signout-btn{flex:1 1;height:56px;border-radius:0;font-size:20px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:none;border:none;color:var(--muted);cursor:pointer}.signout-btn:after{content:"Exit";font-size:9px;font-weight:600;letter-spacing:.02em}.lang-globe-dropdown{bottom:calc(100% + 12px);inset-inline-end:-8px}.browse-hero{padding:calc(20px + env(safe-area-inset-top,0px)) 16px 20px}.browse-hero-title{font-size:22px;margin-bottom:4px}.browse-hero-subtitle{font-size:13px}.browse-header-row,.browse-hero-row{gap:8px;flex-direction:column}.ask-gali-hero{padding:7px 14px;font-size:12px;align-self:flex-start}.filter-bar{padding:10px 12px;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:6px;scrollbar-width:none;position:-webkit-sticky;position:sticky;top:0;z-index:10}.filter-bar::-webkit-scrollbar{display:none}.filter-divider,.more-filters-btn{display:none}.browse-content{padding:14px 12px 24px}.browse-section{margin-bottom:28px}.browse-section-header h2{font-size:17px}.cards-row{grid-template-columns:repeat(2,1fr);gap:10px}.card-icon{font-size:24px}.card-icon-wrap{width:44px;height:44px;border-radius:10px}.card-header-area{padding:12px 12px 0}.card-body{padding:10px 12px 6px}.card-title{font-size:13px}.card-desc{font-size:11px}.card-footer{padding:8px 12px 10px;gap:4px}.card-meta-badge{font-size:10px;padding:2px 6px}.card-section-badge{font-size:9px;padding:2px 8px}.exp-teal-header{padding:calc(12px + env(safe-area-inset-top,0px)) 14px 0}.exp-header-top{margin-bottom:10px}.back-btn{font-size:12px;padding:5px 10px}.ask-gali-btn{font-size:12px;padding:6px 12px}.exp-h1{font-size:20px;margin-bottom:4px}.exp-subtitle{font-size:12px;margin-bottom:8px}.exp-badges{gap:6px;margin-bottom:10px;flex-wrap:wrap}.exp-badge{font-size:10px;padding:3px 10px}.main-tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:2px;padding-bottom:0}.main-tabs::-webkit-scrollbar{display:none}.main-tab{padding:9px 14px;font-size:12px;white-space:nowrap;flex-shrink:0;border-radius:8px 8px 0 0}.content-card{padding:16px;margin-bottom:0}.content-card h3{font-size:15px;margin-top:16px}.content-card h3:first-child{margin-top:0}.content-card li,.content-card p{font-size:13px;line-height:1.65}.khan-inline-section{margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}.khan-inline-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:10px;display:flex;align-items:center;gap:6px}.khan-links{gap:8px}.khan-link{font-size:13px;padding:10px 14px}.right-panel.mobile-open{bottom:calc(56px + env(safe-area-inset-bottom,0px))}.mobile-panel-btn{bottom:calc(70px + env(safe-area-inset-bottom,0px));inset-inline-end:12px;padding:7px 14px;font-size:12px}.chat-messages{max-height:calc(40vh - 120px)}.search-overlay{padding-top:16px;align-items:flex-start}.search-box{border-radius:12px;width:calc(100% - 16px);max-width:100%;margin:0 8px}.search-input-wrap{padding:12px 14px}.search-main-input{font-size:15px}.search-results{max-height:60vh}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.data-entry-table{min-width:400px}.q-text{font-size:13px}.q-btn{font-size:12px;padding:8px 12px;text-align:start}.teacher-toggle{inset-inline-end:12px;width:44px;height:44px;font-size:18px}.teacher-toggle,.toast{bottom:calc(120px + env(safe-area-inset-bottom,0px))}}@media(max-width:390px){.browse-hero-title{font-size:20px}.exp-h1{font-size:18px}.main-tab{padding:7px 11px;font-size:11px}.cards-row{grid-template-columns:1fr 1fr;gap:10px}.card-icon{font-size:22px}.card-icon-wrap{width:40px;height:40px}.content-card{padding:12px}}.section-subhead{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:8px}.q-section{margin-bottom:24px}.conclusion-section textarea,.obs-section textarea{width:100%;border:1.5px solid var(--border);border-radius:8px;padding:8px 12px;font-size:13px;font-family:inherit;outline:none;transition:border .15s;resize:vertical;margin-top:4px}.conclusion-section textarea:focus,.obs-section textarea:focus{border-color:var(--teal)}.misconception{display:flex;gap:8px;align-items:flex-start;padding:8px 10px;border-radius:8px;margin-bottom:6px;font-size:13px;line-height:1.5}.misconception.wrong{background:#fff7ed;color:#92400e}.mc-icon{font-weight:700;flex-shrink:0}.data-cell.valid{border-color:#16a34a!important;background:#dcfce715}.clean-eq-list{list-style:none;padding:0}.personal-notes{width:100%;border:1.5px solid var(--border);border-radius:8px;padding:10px 14px;font-size:14px;font-family:inherit;outline:none;transition:border .15s;resize:vertical;line-height:1.6}.personal-notes:focus{border-color:var(--teal)}.exp-view{overflow:hidden}.data-entry-table tbody tr:nth-child(2n){background:#fafafa}.browse-section{margin-bottom:32px}.browse-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.browse-section-header h2{font-size:18px;font-weight:700;color:var(--text)}.ai-results-feedback{margin-top:12px;border:1.5px solid var(--teal-light);border-radius:10px;overflow:hidden}.rf-header{background:var(--teal);color:#fff;padding:10px 16px;font-size:13px;font-weight:700}.rf-body{padding:12px 16px;font-size:13px;line-height:1.6;color:var(--text)}.rf-hint{background:var(--teal-bg);color:#0d9488;border-top:1px solid var(--teal-light)}.rf-expected,.rf-hint{padding:8px 16px;font-size:12px}.rf-expected{background:#f8fafc;color:var(--muted);border-top:1px solid var(--border)}.teacher-notes-section{border:2px solid #f59e0b;border-radius:12px;padding:16px;margin-top:16px}.q-check-icon.correct{background:#16a34a}.q-check-icon.wrong{background:#ef4444}.exp-badge{display:inline-flex;align-items:center;gap:4px;background:hsla(0,0%,100%,.2);border:1px solid hsla(0,0%,100%,.3);color:#fff;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600}.exp-badges{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.ask-gali-btn{background:hsla(0,0%,100%,.15);border:1.5px solid hsla(0,0%,100%,.4);color:#fff;padding:7px 14px;border-radius:20px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.ask-gali-btn:hover{background:hsla(0,0%,100%,.25)}.rp-section{padding-bottom:16px;border-bottom:1px solid var(--border);margin-bottom:16px}.rp-section:last-child{border-bottom:none}.hook-box{background:var(--teal-bg);-webkit-border-start:3px solid var(--teal);border-inline-start:3px solid var(--teal);border-radius:0 8px 8px 0;padding:10px 14px;font-size:13px;line-height:1.6;color:var(--text)}.khan-links{display:flex;flex-direction:column;gap:6px}.khan-link{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#f8fafc;border-radius:8px;text-decoration:none;font-size:13px;color:var(--text);border:1px solid var(--border);transition:all .14s}.khan-link:hover{background:var(--teal-bg);border-color:var(--teal)}.khan-icon{color:var(--teal);font-size:16px}.khan-title{font-weight:500}.misc-list{display:flex;flex-direction:column;gap:6px}.smart-tray-banner{display:flex;align-items:flex-start;gap:8px;background:#f0fdf4;border:1px solid #86efac;border-radius:8px;padding:10px 12px;margin-bottom:12px}.smart-tray-icon{font-size:18px;flex-shrink:0;margin-top:1px}.smart-tray-body{flex:1 1;min-width:0}.smart-tray-title{font-size:12px;font-weight:700;color:#166534;display:flex;flex-wrap:wrap;align-items:center;gap:4px;line-height:1.4}.smart-tray-pill{background:#16a34a;color:#fff;font-size:11px;font-weight:600;padding:1px 7px;border-radius:12px;white-space:nowrap}.smart-tray-subtitle{font-size:11px;color:#166534;opacity:.7;margin-top:2px;line-height:1.3}.eq-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));grid-gap:8px;gap:8px}.eq-item{display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 6px;background:#f8fafc;border-radius:8px;text-align:center;border:1px solid var(--border)}.eq-emoji{font-size:24px}.eq-name{font-size:11px;color:var(--muted);font-weight:500;line-height:1.2}.eq-atp-code{font-size:10px;color:#94a3b8;font-weight:600;letter-spacing:.02em;margin-top:2px}.eq-atp-label{background:#e2e8f0;color:#64748b;font-size:9px;font-weight:700;padding:1px 4px;border-radius:3px;letter-spacing:.03em;text-transform:uppercase}.eq-sensor-btn{margin-top:4px;font-size:10px;font-weight:600;color:#0e7490;background:#ecfeff;border:1px solid #a5f3fc;border-radius:12px;padding:2px 7px;cursor:pointer;transition:background .15s,border-color .15s;white-space:nowrap;line-height:1.5}.eq-sensor-btn:hover{background:#cffafe;border-color:#67e8f9}.eq-sensor-btn.open{background:#cffafe;border-color:#22d3ee;color:#0c4a6e}.eq-sensor-panel{margin-top:6px;background:#ecfeff;border:1px solid #a5f3fc;border-radius:6px;padding:6px 8px;text-align:start;width:100%;box-sizing:border-box}.eq-sensor-name{font-size:10px;color:#0c4a6e;line-height:1.4;margin-bottom:2px}.eq-sensor-desc{font-size:10px;color:#0e7490;line-height:1.3;opacity:.9}.cb-list{flex-direction:column}.cb-list,.cb-row{display:flex;gap:8px}.cb-row{align-items:center}.cb-label{font-size:12px;color:var(--text);width:140px;flex-shrink:0}.cb-bar-wrap{flex:1 1;height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden}.cb-bar{height:100%;border-radius:3px;transition:width .4s}.cb-pct{font-size:11px;color:var(--muted);width:32px;text-align:end;flex-shrink:0}.gali-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:300;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.gali-modal{background:#fff;border-radius:16px;width:520px;max-width:100%;height:600px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 64px rgba(0,0,0,.2);animation:slideUp .2s ease}@keyframes slideUp{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.gali-modal-header{background:linear-gradient(135deg,var(--teal) 0,var(--teal-dark) 100%);padding:14px 16px;gap:10px}.gali-modal-avatar,.gali-modal-header{display:flex;align-items:center;flex-shrink:0}.gali-modal-avatar{width:34px;height:34px;border-radius:50%;background:hsla(0,0%,100%,.22);color:#fff;font-size:14px;font-weight:800;justify-content:center;border:1.5px solid hsla(0,0%,100%,.35)}.gali-modal-header-title{flex:1 1;color:#fff;font-size:15px;font-weight:700;letter-spacing:.01em}.gali-modal-context-badge{background:hsla(0,0%,100%,.18);border:1px solid hsla(0,0%,100%,.32);color:#fff;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}.gali-modal-close{background:none;border:none;color:hsla(0,0%,100%,.75);font-size:18px;cursor:pointer;padding:4px 6px;line-height:1;border-radius:6px;transition:all .15s;flex-shrink:0}.gali-modal-close:hover{color:#fff;background:hsla(0,0%,100%,.15)}.gali-voice-toggle{background:none;border:none;color:hsla(0,0%,100%,.65);font-size:16px;cursor:pointer;padding:4px 6px;line-height:1;border-radius:6px;transition:all .15s;flex-shrink:0}.gali-voice-toggle:hover{color:#fff;background:hsla(0,0%,100%,.15)}.gali-voice-toggle.active{color:#fff;background:hsla(0,0%,100%,.2);border:1px solid hsla(0,0%,100%,.35)}.gali-mic-btn{width:36px;height:36px;border-radius:8px;border:1.5px solid var(--border);background:#fff;font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;color:var(--muted)}.gali-mic-btn:hover:not(:disabled){border-color:var(--teal);color:var(--teal);background:var(--teal-bg)}.gali-mic-btn:disabled{opacity:.4;cursor:not-allowed}.gali-mic-btn.listening{border-color:#ef4444;color:#ef4444;background:#fef2f2;animation:micPulse 1s ease-in-out infinite}.chat-input.listening-pulse{border-color:#ef4444;animation:inputPulse 1s ease-in-out infinite}@keyframes micPulse{0%,to{box-shadow:0 0 0 0 rgba(239,68,68,.4)}50%{box-shadow:0 0 0 5px rgba(239,68,68,0)}}@keyframes inputPulse{0%,to{border-color:#ef4444}50%{border-color:rgba(239,68,68,.35)}}.gali-modal-notice{padding:8px 14px;background:#fff7ed;border-bottom:1px solid #fed7aa;font-size:12px;color:#92400e;flex-shrink:0}.gali-modal-notice code{background:#fef3c7;padding:1px 5px;border-radius:4px;font-size:11px}.gali-modal-messages{flex:1 1;overflow-y:auto;padding:14px 12px;display:flex;flex-direction:column;gap:10px;min-height:0}.gali-modal-messages::-webkit-scrollbar{width:4px}.gali-modal-messages::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.gali-cursor{display:inline-block;width:2px;height:14px;background:var(--teal);-webkit-margin-start:2px;margin-inline-start:2px;vertical-align:middle;animation:blink .8s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes slideSheet{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.gali-inline-code{background:#f1f5f9;color:#0f172a;padding:2px 6px;border-radius:4px;font-family:ui-monospace,monospace;font-size:12px;font-weight:600}.gali-para{margin:0 0 5px;line-height:1.6}.gali-para:last-child{margin-bottom:0}.gali-list{margin:4px 0 6px;-webkit-margin-start:16px;margin-inline-start:16px;padding:0;line-height:1.6}.gali-list li{margin-bottom:3px}.gali-avatar{width:28px;height:28px;border-radius:50%;background:var(--teal);color:#fff;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.nav-icon.gali-nav span:first-child{color:var(--teal)}.landing-root{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#f8fafc;padding:40px 20px;position:relative;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,sans-serif}.landing-bg-orb{position:absolute;top:-160px;inset-inline-end:-160px;width:560px;height:560px;background:radial-gradient(circle,rgba(20,184,166,.13) 0,rgba(20,184,166,.04) 55%,transparent 75%);border-radius:50%;pointer-events:none;z-index:0}.landing-card{position:relative;z-index:1;background:#fff;border:1px solid var(--border);border-radius:20px;box-shadow:0 8px 40px rgba(0,0,0,.07),0 2px 8px rgba(0,0,0,.04);padding:52px 48px 48px;width:100%;max-width:440px;display:flex;flex-direction:column;align-items:center;gap:0}.landing-logo-wrap{margin-bottom:36px;display:flex;align-items:center;justify-content:center}.landing-logo{height:56px;width:auto;object-fit:contain;display:block}.landing-brand{text-align:center;margin-bottom:40px}.landing-title{font-size:32px;font-weight:800;color:var(--text);letter-spacing:-.02em;line-height:1.1;margin-bottom:10px}.landing-tagline{font-size:15px;color:var(--muted);line-height:1.6;font-weight:400}.landing-signin-btn{width:100%;padding:13px 24px;background:var(--teal);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:700;cursor:pointer;transition:background .15s,transform .1s,box-shadow .15s;display:flex;align-items:center;justify-content:center;gap:8px;letter-spacing:.01em;box-shadow:0 4px 14px rgba(20,184,166,.3)}.landing-signin-btn:hover:not(:disabled){background:var(--teal-dark);transform:translateY(-1px);box-shadow:0 6px 18px rgba(20,184,166,.38)}.landing-signin-btn:active:not(:disabled){transform:translateY(0)}.landing-signin-btn:disabled{opacity:.65;cursor:default}.landing-form{width:100%;gap:14px}.landing-field,.landing-form{display:flex;flex-direction:column}.landing-field{gap:5px}.landing-label{font-size:12px;font-weight:600;color:var(--muted);letter-spacing:.03em;text-transform:uppercase}.landing-input{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:8px;font-size:14px;font-family:inherit;color:var(--text);background:#fff;outline:none;transition:border .15s,box-shadow .15s}.landing-input:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(20,184,166,.12)}.landing-input:disabled{background:#f8fafc;color:var(--muted)}.landing-input::placeholder{color:#cbd5e1}.landing-error{font-size:13px;color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:7px;padding:8px 12px;margin:0;line-height:1.5}.landing-spinner{display:inline-block;width:18px;height:18px;border:2.5px solid hsla(0,0%,100%,.35);border-top-color:#fff;border-radius:50%;animation:landing-spin .65s linear infinite}@keyframes landing-spin{to{transform:rotate(1turn)}}.landing-pitch{width:100%;margin-top:24px;padding-top:24px;border-top:1px solid var(--border);display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center}.landing-pitch-desc{font-size:13px;color:var(--text);line-height:1.65;font-weight:400;margin:0}.landing-subjects{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:4px 8px;font-size:11px;font-weight:700;color:var(--teal);letter-spacing:.06em;text-transform:uppercase}.landing-dot{color:#cbd5e1;font-weight:400;font-size:13px}.landing-pitch-value{font-size:13px;color:var(--muted);line-height:1.55;margin:0}.landing-pitch-cta{font-size:14px;font-weight:800;color:var(--text);line-height:1.4;letter-spacing:-.01em;margin:0}.landing-credits-box{width:100%;background:#f4faf8;border:1px solid #9fe1cb;border-radius:12px;padding:1rem 1.2rem;text-align:center}.landing-credits-built{color:#0f6e56;font-size:13px;font-weight:600;margin:0 0 6px}.landing-credits-label{color:#888;font-size:11px;text-transform:uppercase;letter-spacing:.08em;margin:0 0 8px}.landing-credits-badges{display:flex;flex-wrap:wrap;justify-content:center;gap:6px}.landing-credits-badge{background:#fff;border:1px solid #c8e8e0;border-radius:6px;padding:3px 10px;font-size:12px;font-weight:500;color:#0d2d2d}.landing-footer{position:relative;z-index:1;margin-top:32px;font-size:12px;color:#cbd5e1;letter-spacing:.02em}.signout-btn{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);font-size:16px;transition:all .15s;border:none;background:none}.signout-btn:hover{background:#fef2f2;color:#dc2626}.signout-btn title{display:none}@media(max-width:500px){.landing-card{padding:36px 24px 32px}.landing-title{font-size:28px}.landing-logo{height:44px}.landing-pitch{margin-top:20px;padding-top:20px;gap:8px}.landing-pitch-desc{font-size:12.5px}.landing-pitch-cta{font-size:13px}.landing-subjects{font-size:10px}}.lang-switcher{flex-direction:column;margin-bottom:6px}.lang-btn,.lang-switcher{display:flex;gap:4px;align-items:center}.lang-btn{padding:5px 8px;border-radius:8px;border:1px solid transparent;cursor:pointer;font-size:11px;font-weight:500;line-height:1;background:transparent;color:var(--muted);transition:all .15s;white-space:nowrap;width:44px;justify-content:center}.lang-btn:hover{background:rgba(20,184,166,.12);color:var(--teal)}.lang-btn.active{background:rgba(20,184,166,.18);color:var(--teal);border-color:rgba(20,184,166,.35);font-weight:700}.lang-flag{font-size:13px;line-height:1}.lang-label{font-size:10px;font-weight:700;letter-spacing:.04em}@media(max-width:768px){.lang-switcher{flex-direction:row;margin-bottom:0;gap:2px}.lang-btn{width:36px;padding:4px 6px}}.lang-globe-item .lang-flag{font-size:16px}.lang-globe-item .lang-label{font-size:12px}.landing-lang{position:fixed;top:16px;inset-inline-end:20px;z-index:100}.landing-lang .lang-switcher{flex-direction:row;gap:4px;background:hsla(0,0%,100%,.9);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:10px;padding:6px 8px;box-shadow:0 2px 12px rgba(0,0,0,.08)}.landing-lang .lang-btn{color:#475569;width:auto;padding:4px 10px}.landing-lang .lang-btn.active{background:var(--teal);color:#fff;border-color:var(--teal)}.app-main{flex:1 1;min-width:0;min-height:0;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column}.app-main::-webkit-scrollbar{width:5px}.app-main::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.browse-header{padding:32px 40px 28px;color:#fff;position:relative;overflow:hidden;flex-shrink:0}.browse-header:after{content:"";position:absolute;inset-inline-end:-20px;top:-20px;width:200px;height:200px;background:hsla(0,0%,100%,.06);border-radius:50%}.browse-header-content{position:relative;z-index:1}.browse-title{font-size:28px;font-weight:800;margin-bottom:6px}.browse-subtitle{opacity:.85;font-size:14px;margin:0}.filter-group{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.ai-header,.robotics-header{background:linear-gradient(135deg,#14b8a6,#0d9488)}.courses-note{color:hsla(0,0%,100%,.85);font-size:.85rem;margin-top:6px;margin-bottom:0}.courses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:20px;gap:20px;padding:24px}.course-card{display:flex;flex-direction:column;background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:20px;text-decoration:none;color:inherit;transition:transform .18s ease,box-shadow .18s ease;cursor:pointer;gap:14px}.course-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.1)}.course-card-header{display:flex;align-items:flex-start;justify-content:space-between}.course-icon-circle{width:52px;height:52px;border-radius:50%;background:#e6f7f5;display:flex;align-items:center;justify-content:center;flex-shrink:0}.course-icon{font-size:1.5rem;line-height:1}.course-provider-badge{background:#f3f4f6;color:#374151;font-size:.7rem;font-weight:600;padding:3px 8px;border-radius:20px;letter-spacing:.02em;white-space:nowrap}.course-card-body{display:flex;flex-direction:column;gap:8px;flex:1 1}.course-category-badge{display:inline-block;color:#fff;font-size:.65rem;font-weight:700;letter-spacing:.08em;padding:3px 8px;border-radius:4px;width:-moz-fit-content;width:fit-content;text-transform:uppercase}.course-title{font-size:1rem;font-weight:700;color:#111827;margin:0;line-height:1.3}.course-description{font-size:.85rem;color:#6b7280;line-height:1.5;margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.course-card-footer{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}.course-meta-badge{background:#f3f4f6;color:#374151;font-weight:500}.course-free-badge,.course-meta-badge{font-size:.72rem;padding:4px 8px;border-radius:6px;white-space:nowrap}.course-free-badge{background:#10b981;color:#fff;font-weight:600}.courses-footer-note{text-align:center;padding:20px 24px 32px;color:#9ca3af;font-size:.85rem}@media (max-width:600px){.courses-grid{grid-template-columns:1fr;padding:16px;gap:14px}}[dir=rtl] body{font-family:Noto Sans Arabic,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}[dir=rtl],[dir=rtl] .exp-card{text-align:end}[dir=rtl] .back-btn,[dir=rtl] .card-header-area,[dir=rtl] .filter-bar{flex-direction:row-reverse}[dir=rtl] .search-input{text-align:end;direction:rtl}.chat-formula,.code-block,.equation,.formula,.formula-box code,.gali-inline-code,code,pre{direction:ltr;unicode-bidi:-webkit-isolate;unicode-bidi:isolate;text-align:start}[dir=rtl] .data-table input,[dir=rtl] .data-table td,[dir=rtl] .data-table th,[dir=rtl] .experiment-number{direction:ltr;text-align:start}[dir=rtl] .browse-hero-content{text-align:end}[dir=rtl] .browse-hero-row{flex-direction:row-reverse}[dir=rtl] .lang-switcher{direction:ltr}[dir=rtl] .gali-messages{text-align:end}[dir=rtl] .gali-input-row,[dir=rtl] .tab-bar{flex-direction:row-reverse}[dir=rtl] .nav-icon{direction:ltr}[dir=rtl] .signout-btn{transform:scaleX(-1)}.card-reset-btn{position:absolute;top:8px;inset-inline-start:8px;width:28px;height:28px;border-radius:50%;border:1px solid #ddd;background:#fff;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;z-index:2;color:#666}.exp-card:hover .card-reset-btn{opacity:1}.card-reset-btn:hover{background:#fee2e2;border-color:#fca5a5;color:#dc2626}.reset-all-btn{padding:8px 16px;border-radius:8px;border:1px solid hsla(0,0%,100%,.4);background:hsla(0,0%,100%,.15);color:#fff;font-size:14px;cursor:pointer;transition:all .2s}.reset-all-btn:hover{background:hsla(0,0%,100%,.25);border-color:hsla(0,0%,100%,.6)}.concept-mastery-card{background:#fff;border-radius:var(--radius);padding:1.25rem;box-shadow:var(--card-shadow);margin-bottom:1.5rem}.concept-mastery-title{font-size:1.1rem;font-weight:600;color:var(--text);margin-bottom:1rem}.concept-mastery-list{display:flex;flex-direction:column;gap:.6rem}.concept-mastery-row{display:flex;align-items:center;gap:.75rem}.concept-mastery-label{font-size:.85rem;font-weight:500;color:var(--text);min-width:160px;flex-shrink:0}.concept-mastery-bar-wrap{flex:1 1;height:10px;background:#e2e8f0;border-radius:5px;overflow:hidden}.concept-mastery-bar-fill{height:100%;border-radius:5px;transition:width .4s ease}.concept-mastery-pct{font-size:.8rem;font-weight:600;min-width:55px;text-align:end}.trend-chart-card{background:#fff;border-radius:var(--radius);padding:1rem;box-shadow:var(--card-shadow)}.trend-chart-card svg{display:block}.achievements-grid{display:flex;flex-wrap:wrap;gap:.75rem}.achievement-badge{display:flex;flex-direction:column;align-items:center;gap:4px;width:90px;padding:.75rem .5rem;background:#fff;border-radius:var(--radius);box-shadow:0 2px 8px rgba(0,0,0,.08);text-align:center;transition:transform .15s}.achievement-badge:hover{transform:translateY(-2px)}.achievement-badge.locked{filter:grayscale(1);opacity:.45}.achievement-icon{font-size:1.75rem;line-height:1}.achievement-label{font-size:.7rem;font-weight:600;color:var(--text);line-height:1.2}.achievement-badge.locked .achievement-label{color:var(--muted)}.weak-areas-card{background:#fff;border-radius:var(--radius);padding:1rem 1.25rem;box-shadow:var(--card-shadow);gap:.75rem}.weak-area-row,.weak-areas-card{display:flex;flex-direction:column}.weak-area-row{gap:2px}.weak-area-info{display:flex;justify-content:space-between;align-items:center}.weak-area-label{font-size:.9rem;font-weight:600;color:var(--text)}.weak-area-pct{font-size:.85rem;font-weight:700}.weak-area-links{display:flex;align-items:center;gap:.5rem}.weak-area-exp-link{background:none;border:none;color:var(--teal);font-weight:600;font-size:.8rem;cursor:pointer;padding:0;text-decoration:underline}.weak-area-exp-link:hover{color:var(--teal-dark)}.quiz-score-breakdown{font-size:.85rem;color:var(--muted);margin-top:.5rem;font-weight:500}[dir=rtl] .concept-mastery-pct{text-align:start}[dir=rtl] .weak-area-links{flex-direction:row-reverse}[dir=rtl] .achievements-grid{direction:rtl}.concept-mastery-toggle{display:block;margin:16px auto 0;padding:8px 24px;background:transparent;border:1px solid var(--border);border-radius:var(--radius);color:var(--teal);cursor:pointer;font-size:14px;font-weight:500;transition:background .15s,border-color .15s}.concept-mastery-toggle:hover{background:var(--teal-bg);border-color:var(--teal)}.performance-trend svg text{-webkit-user-select:none;-moz-user-select:none;user-select:none}.performance-trend circle{transition:r .2s ease}.classroom-table{width:100%;border-collapse:collapse}.classroom-table td,.classroom-table th{padding:12px 16px;text-align:start;border-bottom:1px solid var(--border)}.classroom-table th{font-weight:600;color:var(--muted);font-size:13px;text-transform:uppercase}.classroom-table tr:hover{background:rgba(20,184,166,.04);cursor:pointer}.grade-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1000;display:flex;align-items:center;justify-content:center}.grade-modal{background:#fff;border-radius:var(--radius);padding:32px;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.2)}.grade-modal h3{margin:0 0 24px}.criteria-row{display:flex;align-items:center;gap:12px;margin-bottom:16px}.criteria-label{width:120px;font-size:14px;color:var(--text)}.criteria-slider{flex:1 1;accent-color:var(--teal)}.criteria-value{width:30px;text-align:center;font-weight:600}.dist-bar{height:28px;border-radius:4px;background:var(--teal);transition:width .5s ease;min-width:2px}.dist-row{display:flex;align-items:center;gap:12px;margin-bottom:8px}.dist-label{width:70px;font-size:13px;color:var(--muted);text-align:end}.dist-count{font-size:13px;color:var(--text);min-width:80px}.student-rank{width:32px;height:32px;border-radius:50%;background:var(--border);justify-content:center;font-size:13px;font-weight:600}.student-rank,.xp-toast{display:flex;align-items:center}.xp-toast{position:fixed;bottom:24px;inset-inline-end:24px;gap:8px;background:linear-gradient(135deg,#14b8a6,#0d9488);color:#fff;padding:10px 18px;border-radius:24px;font-weight:700;font-size:15px;box-shadow:0 4px 20px rgba(20,184,166,.4);z-index:10000;pointer-events:none}.xp-toast-enter{animation:xpSlideIn .4s cubic-bezier(.34,1.56,.64,1)}.xp-toast-exit{animation:xpSlideOut .3s ease-in forwards}@keyframes xpSlideIn{0%{transform:translateY(20px) scale(.8);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}@keyframes xpSlideOut{to{transform:translateY(-10px) scale(.9);opacity:0}}.xp-toast-icon{font-size:18px}.xp-toast-perfect{background:linear-gradient(135deg,#f59e0b,#d97706)}.celebration-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:10001;pointer-events:none}.celebration-enter{animation:celebFadeIn .3s ease}.celebration-exit{animation:celebFadeOut .5s ease forwards}@keyframes celebFadeIn{0%{opacity:0}to{opacity:1}}@keyframes celebFadeOut{to{opacity:0}}.confetti-container{position:fixed;inset:0;overflow:hidden;pointer-events:none}.confetti-piece{position:absolute;top:-10px;left:var(--x);width:10px;height:10px;background:var(--color);animation:confettiFall 3s var(--delay) ease-in forwards;transform:rotate(var(--rotation))}.confetti-piece:nth-child(odd){width:6px;height:14px;border-radius:2px}.confetti-piece:nth-child(2n){border-radius:50%}@keyframes confettiFall{0%{transform:translateY(0) rotate(0deg);opacity:1}to{transform:translateY(100vh) rotate(2turn);opacity:0}}.level-up-card{background:#fff;border-radius:20px;padding:40px 48px;text-align:center;box-shadow:0 20px 60px rgba(0,0,0,.15);animation:levelUpPop .5s cubic-bezier(.34,1.56,.64,1)}.level-up-icon{font-size:64px;margin-bottom:12px}.level-up-label{font-size:14px;font-weight:600;color:var(--teal);text-transform:uppercase;letter-spacing:2px;margin-bottom:4px}.level-up-title{font-size:28px;font-weight:800;color:#1a1a2e;margin-bottom:4px}.level-up-subtitle{font-size:14px;color:var(--muted)}@keyframes levelUpPop{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}.streak-card{background:#fff;border-radius:20px;padding:32px 40px;text-align:center;box-shadow:0 20px 60px rgba(0,0,0,.15);animation:levelUpPop .5s cubic-bezier(.34,1.56,.64,1)}.streak-flame{font-size:56px;margin-bottom:8px}.streak-days{font-size:24px;font-weight:800;color:#f97316}.streak-bonus{font-size:16px;font-weight:600;color:var(--teal);margin-top:4px}.xp-bar-container{background:#fff;border-radius:var(--radius);padding:16px 20px;border:1px solid var(--border);margin-bottom:20px}.xp-bar-header{gap:12px;margin-bottom:10px}.xp-bar-header,.xp-level-badge{display:flex;align-items:center}.xp-level-badge{width:48px;height:48px;border-radius:50%;border:3px solid;flex-direction:column;justify-content:center;background:#f0fdfa;flex-shrink:0}.xp-level-icon{font-size:20px;line-height:1}.xp-level-num{font-size:10px;font-weight:800;color:var(--muted)}.xp-level-info{flex:1 1}.xp-level-title{font-weight:700;font-size:15px;color:#1a1a2e}.xp-level-xp{font-size:13px;color:var(--muted)}.xp-streak-badge{background:linear-gradient(135deg,#fef3c7,#fde68a);padding:6px 12px;border-radius:16px;font-weight:700;font-size:14px;color:#92400e}.xp-progress-bar{height:8px;background:#e5e7eb;border-radius:4px;position:relative;overflow:hidden}.xp-progress-fill{height:100%;border-radius:4px;transition:width .6s cubic-bezier(.34,1.56,.64,1)}.xp-progress-label{font-size:11px;color:var(--muted);margin-top:4px;text-align:end}.daily-goal{display:flex;align-items:center;gap:10px;margin-top:12px;padding-top:10px;border-top:1px solid var(--border)}.daily-goal-label{font-size:13px;font-weight:600;color:var(--muted);white-space:nowrap}.daily-goal-dots{display:flex;gap:6px}.daily-goal-dot{width:14px;height:14px;border-radius:50%;background:#e5e7eb;transition:background .3s,transform .3s}.daily-goal-dot.completed{background:var(--teal);transform:scale(1.1)}@media (max-width:600px){.level-up-card{padding:28px 24px}.level-up-icon{font-size:48px}.level-up-title{font-size:22px}.streak-card{padding:24px 28px}.xp-toast{bottom:16px;inset-inline-end:16px;font-size:13px;padding:8px 14px}}.equipment-filter{margin-bottom:16px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}.equipment-filter-label{font-size:13px;font-weight:600;color:var(--muted);white-space:nowrap}.equipment-filter-chips{display:flex;gap:8px;flex-wrap:wrap}.equipment-chip{display:flex;align-items:center;gap:6px;padding:6px 14px;border:1.5px solid #e5e7eb;border-radius:20px;background:#fff;cursor:pointer;transition:all .2s;font-size:13px}.equipment-chip:hover{border-color:var(--teal);background:#f0fdfa}.equipment-chip.active{border-color:var(--teal);background:var(--teal);color:#fff}.equipment-chip-icon{font-size:14px}.equipment-chip-label{font-weight:500}.equipment-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:2px 8px;border-radius:10px;font-weight:500}.equipment-badge.mobile-lab{background:#dbeafe;color:#1e40af}.equipment-badge.arduino-kit{background:#fef3c7;color:#92400e}.equipment-badge.basic-supplies{background:#d1fae5;color:#065f46}.equipment-badge.none{background:#f3f4f6;color:#6b7280}.equipment-empty-state{text-align:center;padding:48px 24px;color:var(--muted)}.equipment-empty-state h3{font-size:16px;font-weight:600;margin:0 0 8px;color:var(--text)}.equipment-empty-state p{font-size:14px;margin:0}.print-btn{width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;flex-shrink:0;opacity:.5}.print-btn:hover{opacity:1;background:#f8fafc;border-color:var(--teal);color:var(--teal)}.exp-header-top .print-btn{border-color:hsla(0,0%,100%,.2);background:transparent;color:hsla(0,0%,100%,.5);opacity:1}.exp-header-top .print-btn:hover{background:hsla(0,0%,100%,.15);border-color:hsla(0,0%,100%,.5);color:#fff}@media print{body.app-shell,html.app-shell{overflow:auto!important}.page-shell,body.app-shell,html.app-shell{position:static!important;height:auto!important}.page-shell{overflow:visible!important}.ask-gali-btn,.ask-gali-hero,.back-btn,.btn-secondary,.gali-fab,.gali-help-btn,.gali-modal,.gali-modal-overlay,.main-tabs,.mobile-panel-btn,.nav-icon,.notes-tab-wrap,.print-btn,.quiz-reset-btn,.right-panel,.search-overlay,.sidebar,.sidebar-bottom,.teacher-mode-bar,[data-noprint]{display:none!important}.exp-body,.exp-main-col,.exp-view,.main-area{width:100%!important;max-width:100%!important;margin:0!important;padding:0!important;overflow:visible!important;display:block!important;position:static!important;height:auto!important;min-height:0!important}.exp-teal-header{padding:24px 20px!important;page-break-after:avoid;break-after:avoid}.exp-h1{font-size:22px!important}.exp-subtitle{font-size:13px!important}.exp-header-top{display:none!important}.tab-pane{display:block!important}.content-card{box-shadow:none!important;border:none!important;padding:12px 0!important}table{border-collapse:collapse!important;width:100%!important}td,th{border:1px solid #999!important;padding:6px 10px!important}*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}.q-btn{border:1px solid #ccc!important;background:#fff!important}.q-btn.correct{background:#d1fae5!important;border-color:#059669!important}.q-btn.wrong{background:#fee2e2!important;border-color:#ef4444!important}.q-feedback,.q-item,.q-open{page-break-inside:avoid;break-inside:avoid}.classroom-table{width:100%!important}@page{margin:1.5cm}.q-section,.score-dist-bar{page-break-inside:avoid;break-inside:avoid}.q-section{page-break-before:auto;break-before:auto}}.tour-overlay{position:fixed;inset:0;z-index:9999;pointer-events:auto}.tour-svg{position:fixed;inset:0;width:100%;height:100%;pointer-events:none}.tour-tooltip{position:fixed;width:320px;background:#fff;border-radius:14px;box-shadow:0 8px 32px rgba(0,0,0,.18),0 2px 8px rgba(0,0,0,.08);padding:18px 20px 16px;z-index:10000;animation:tourFadeIn .2s ease}@keyframes tourFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.tour-arrow-bottom:before,.tour-arrow-left:before,.tour-arrow-right:before,.tour-arrow-top:before{content:"";position:absolute;width:14px;height:14px;background:#fff;transform:rotate(45deg);box-shadow:-2px -2px 4px rgba(0,0,0,.06)}.tour-arrow-top:before{top:-7px;left:40px}.tour-arrow-bottom:before{bottom:-7px;left:40px;box-shadow:2px 2px 4px rgba(0,0,0,.06)}.tour-arrow-left:before{left:-7px;top:28px}.tour-arrow-right:before{right:-7px;top:28px;box-shadow:2px -2px 4px rgba(0,0,0,.06)}.tour-tooltip-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.tour-step-badge{font-size:11px;font-weight:600;color:#0f766e;background:#f0fdfa;padding:2px 10px;border-radius:10px}.tour-skip-btn{background:none;border:none;font-size:13px;color:#94a3b8;cursor:pointer;padding:2px 6px}.tour-skip-btn:hover{color:#475569}.tour-title{font-size:16px;font-weight:700;color:#1e293b;margin:0 0 6px}.tour-text{font-size:13.5px;line-height:1.5;color:#64748b;margin:0 0 16px}.tour-footer{display:flex;justify-content:space-between;align-items:center}.tour-dots{display:flex;gap:6px}.tour-dot{width:7px;height:7px;border-radius:50%;background:#e2e8f0;transition:background .15s}.tour-dot.active{background:#0f766e;transform:scale(1.15)}.tour-btns{display:flex;gap:8px}.tour-btn-back{background:none;border:1.5px solid #e2e8f0;border-radius:8px;padding:6px 14px;font-size:13px;font-weight:600;color:#64748b;cursor:pointer}.tour-btn-back:hover{border-color:#cbd5e1}.tour-btn-next{background:#0f766e;border:none;border-radius:8px;padding:6px 18px;font-size:13px;font-weight:600;color:#fff;cursor:pointer}.tour-btn-next:hover{background:#0d6d66}.restart-tour-btn{position:fixed;bottom:24px;right:24px;width:36px;height:36px;border-radius:50%;background:#0f766e;color:#fff;border:none;font-size:16px;font-weight:700;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.15);z-index:200;display:flex;align-items:center;justify-content:center}.restart-tour-btn:hover{background:#0d6d66}@media (max-width:768px){.tour-tooltip{width:calc(100vw - 32px);max-width:340px;left:50%!important;transform:translateX(-50%)}.tour-arrow-left:before,.tour-arrow-right:before{display:none}.restart-tour-btn{bottom:calc(68px + env(safe-area-inset-bottom,0px));right:12px}}.role-selector-overlay{position:fixed;inset:0;z-index:9999;background:#f8fafc;display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(16px);transition:opacity .4s ease,transform .4s ease}.role-selector-overlay.role-visible{opacity:1;transform:translateY(0)}.role-selector-container{width:100%;max-width:680px;padding:32px 24px;gap:32px}.role-selector-container,.role-selector-header{display:flex;flex-direction:column;align-items:center}.role-selector-header{gap:8px;text-align:center}.role-selector-logo{width:auto;height:44px;object-fit:contain;margin-bottom:4px}.role-selector-welcome{font-size:24px;font-weight:700;color:var(--text)}.role-selector-subtitle{font-size:15px;color:var(--muted);font-weight:500}.role-selector-cards{display:grid;grid-template-columns:1fr 1fr;grid-gap:20px;gap:20px;width:100%}.role-card{position:relative;display:flex;flex-direction:column;align-items:center;gap:12px;padding:36px 24px;border-radius:var(--radius);border:1px solid var(--border);background:#fff;box-shadow:var(--card-shadow);cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;text-align:center}.role-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.08)}.role-card:active{transform:scale(.98)}.role-card-student:hover{border-color:#0f766e}.role-card-teacher:hover{border-color:#d97706}.role-card-icon{font-size:48px;line-height:1}.role-card-title{font-size:20px;font-weight:700;color:var(--text)}.role-card-desc{font-size:13px;color:var(--muted);line-height:1.5;max-width:220px}.role-card-student:hover .role-card-title{color:#0f766e}.role-card-teacher:hover .role-card-title{color:#d97706}.role-card:after{content:"";position:absolute;bottom:0;left:16px;right:16px;height:4px;border-radius:2px;opacity:0;transition:opacity .2s ease}.role-card-student:after{background:#0f766e}.role-card-teacher:after{background:#d97706}.role-card:hover:after{opacity:1}.switch-role-btn{width:44px;height:44px;border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;gap:2px;color:var(--muted);font-size:18px;transition:all .15s;border:none;background:none}.switch-role-btn:hover{background:#f1f5f9;color:var(--text)}.switch-role-btn span.label{font-size:9px;font-weight:600;letter-spacing:.02em}@media(max-width:600px){.role-selector-cards{grid-template-columns:1fr}.role-selector-welcome{font-size:20px}.role-card{padding:28px 20px}}.teacher-tour .teacher-badge{color:#92400e;background:#fef3c7}.teacher-tour .teacher-dot-active{background:#d97706!important}.teacher-tour .teacher-btn-next{background:#d97706}.teacher-tour .teacher-btn-next:hover{background:#b45309}.restart-teacher-tour-btn{display:inline-flex;align-items:center;gap:6px;margin-top:12px;background:none;border:1.5px solid #d97706;color:#92400e;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.restart-teacher-tour-btn:hover{background:#fef3c7}.passions-onboarding{position:relative;width:100%;flex:1 1 auto;min-height:100dvh;display:flex;align-items:flex-start;justify-content:center;padding:32px 16px 48px;background:#f8fafc}.passions-card{width:100%;max-width:680px;margin:0 auto;background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--card-shadow);padding:32px 32px 28px;display:flex;flex-direction:column;gap:20px;animation:passions-card-in .35s cubic-bezier(.2,.8,.2,1) both}.passions-logo{display:block;margin:0 auto;height:44px;width:auto;object-fit:contain}.passions-welcome{display:flex;align-items:flex-start;gap:14px;padding:14px 16px;border-radius:var(--radius);border:1px solid var(--teal-light);background:var(--teal-bg)}.passions-welcome-avatar{flex-shrink:0;width:36px;height:36px;border-radius:50%;background:var(--teal);color:#fff;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center}.passions-welcome-text{display:flex;flex-direction:column;gap:6px;min-width:0;text-align:start}.passions-welcome-greeting{font-size:15px;font-weight:700;color:var(--text);line-height:1.3}.passions-welcome-line{font-size:14px;color:var(--text);line-height:1.5;opacity:.85}[dir=rtl] .passions-welcome-text{text-align:start}@keyframes passions-card-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.passions-header{display:flex;flex-direction:column;gap:6px;text-align:center;align-items:center}.passions-title{font-size:26px;font-weight:800;color:var(--text);line-height:1.2}.passions-subtitle{font-size:15px;color:var(--muted);line-height:1.5;max-width:440px}.passions-counter{display:inline-flex;align-items:center;gap:10px;margin-top:6px;padding:6px 14px;border-radius:999px;background:#f1f5f9;font-size:13px;font-weight:600;color:var(--muted);transition:all .2s ease}.passions-counter-active{background:var(--teal-light);color:var(--teal-dark)}.passions-counter-dots{display:inline-flex;gap:5px}.passions-counter-dot{width:8px;height:8px;border-radius:50%;background:#cbd5e1;transition:all .25s cubic-bezier(.2,.8,.2,1)}.passions-counter-dot-filled{background:var(--teal);transform:scale(1.25)}.passions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));grid-gap:12px;gap:12px}.passion-tile{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:18px 10px 14px;border-radius:var(--radius);border:1px solid var(--border);background:#fff;color:var(--text);font-size:14px;font-weight:600;cursor:pointer;box-shadow:var(--card-shadow);transition:transform .18s cubic-bezier(.2,.8,.2,1),box-shadow .18s ease,border-color .18s ease,background .18s ease;overflow:hidden;min-height:108px}.passion-tile:hover:not(:disabled):not(.passion-tile-active){border-color:var(--teal);box-shadow:0 4px 12px rgba(20,184,166,.15)}.passion-tile-emoji{font-size:34px;line-height:1;transition:transform .25s cubic-bezier(.2,.8,.2,1)}.passion-tile:hover:not(:disabled) .passion-tile-emoji{transform:scale(1.08)}.passion-tile-label{position:relative;z-index:1;text-align:center;line-height:1.15;font-size:13px;font-weight:600;letter-spacing:-.01em}.passion-tile-check{position:absolute;top:8px;right:8px;width:22px;height:22px;border-radius:50%;background:var(--teal);color:#fff;font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.5);transition:all .2s cubic-bezier(.2,.8,.2,1)}.passion-tile-active{border-color:var(--teal);background:var(--teal-bg)}.passion-tile-active .passion-tile-check{opacity:1;transform:scale(1)}.passion-tile-disabled{opacity:.4;cursor:not-allowed}.passion-tile:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(20,184,166,.35)}.passions-custom-wrap{display:flex;flex-direction:column;gap:6px}.passions-custom-label{font-size:13px;font-weight:600;color:var(--muted)}.passions-custom-input{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius);font-size:15px;font-family:inherit;background:#fff;transition:all .15s ease}.passions-custom-input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(20,184,166,.18)}.passions-actions{display:flex;gap:12px;margin-top:4px}.passions-skip-btn{flex:0 0 auto;padding:13px 22px;border-radius:var(--radius);background:transparent;border:1px solid var(--border);color:var(--muted);font-size:15px;font-weight:600;cursor:pointer;transition:all .15s ease}.passions-skip-btn:hover{background:#f1f5f9;color:var(--text);border-color:#cbd5e1}.passions-continue-btn{flex:1 1 auto;padding:13px 22px;border-radius:var(--radius);background:var(--teal);border:none;color:#fff;font-size:15px;font-weight:700;cursor:pointer;transition:background .15s ease;display:inline-flex;align-items:center;justify-content:center;gap:8px;letter-spacing:.01em}.passions-continue-btn:hover{background:var(--teal-dark)}.passions-continue-arrow{transition:transform .18s ease;display:inline-block}.passions-continue-btn:hover .passions-continue-arrow{transform:translateX(3px)}[dir=rtl] .passions-continue-arrow{transform:scaleX(-1)}[dir=rtl] .passions-continue-btn:hover .passions-continue-arrow{transform:scaleX(-1) translateX(3px)}@media (max-width:480px){.passions-card{padding:24px 18px 20px;gap:16px}.passions-logo{height:40px}.passions-title{font-size:22px}.passions-welcome{padding:12px 14px;gap:12px}.passions-welcome-avatar{width:32px;height:32px;font-size:14px}.passions-welcome-greeting{font-size:14px}.passions-welcome-line{font-size:13px}.passions-grid{grid-template-columns:repeat(2,1fr);gap:10px}.passion-tile{min-height:100px;padding:16px 8px 12px}.passion-tile-emoji{font-size:30px}}.page-loading{display:flex;align-items:center;justify-content:center;height:100vh;background:#f8fafc}.page-loading-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--teal);border-radius:50%;animation:page-loading-spin .8s linear infinite}@keyframes page-loading-spin{to{transform:rotate(1turn)}}