*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #0E8A7D;--primary-dark: #0A6E64;--primary-light: #E6F7F5;--secondary: #1B2A4A;--accent: #D4A853;--success: #10B981;--danger: #EF4444;--bg: #FBF8F4;--surface: #FFFFFF;--border: #E2E8F0;--text: #1B2A4A;--text-muted: #64748B;--text-light: #94A3B8;--sidebar-width: 240px;--topbar-height: 64px;--radius: 10px;--shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.04);--shadow-lg: 0 10px 30px rgba(0,0,0,.1), 0 4px 10px rgba(0,0,0,.05)}html,body,#root{height:100%}body{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background-color:var(--bg);color:var(--text);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3}.login-page{min-height:100vh;background:#1b2a4a;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px}.login-container{width:100%;max-width:560px}.login-brand{text-align:center;margin-bottom:32px}.login-title{display:inline-flex;align-items:baseline;gap:3px;margin-bottom:6px}.login-title-v{display:inline-flex}.login-title-rest{font-family:"DM Serif Display",serif;font-size:52px;color:#fff;letter-spacing:1px;font-weight:400}.login-tagline{font-size:14px;color:#e8734a99}.role-selection-title{font-size:15.3px;font-weight:700;color:#fff;margin-bottom:16px}.role-cards{display:flex;flex-direction:column;gap:10px}.role-card{display:flex;align-items:center;gap:14px;padding:18px 20px;background:#0e8a7d;border:none;border-radius:12px;text-align:left;transition:background .15s;width:100%}.role-card:hover{background:#10a08f}.role-card-label{font-size:22px;font-weight:700;color:#fff;margin-bottom:2px}.role-card-desc{font-size:13px;color:#fffc;line-height:1.4}.role-card-arrow{margin-left:auto;color:#fff;flex-shrink:0;transition:transform .15s}.role-card:hover .role-card-arrow{color:#fff;transform:translate(2px)}.back-btn{display:flex;align-items:center;gap:4px;background:none;border:none;color:#fff9;font-size:13px;font-weight:500;padding:0;margin-bottom:16px;transition:color .15s}.back-btn:hover{color:#fff}.login-role-badge{display:inline-flex;align-items:center;gap:6px;background:#0e8a7d33;color:#0e8a7d;font-size:12.5px;font-weight:600;padding:5px 12px;border-radius:99px;margin-bottom:20px}.login-form{display:flex;flex-direction:column;gap:14px}.form-group{display:flex;flex-direction:column;gap:5px}.form-label{font-size:13px;font-weight:500;color:#fffc}.form-input{padding:10px 14px;border:1.5px solid rgba(255,255,255,.2);border-radius:8px;font-size:14px;font-family:inherit;color:#fff;background:#ffffff14;transition:border-color .15s,box-shadow .15s;outline:none}.form-input:focus{border-color:#0e8a7d;box-shadow:0 0 0 3px #0e8a7d33}.form-input::placeholder{color:#ffffff59}.form-error{font-size:12.5px;color:#fca5a5;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:7px;padding:9px 12px}.login-btn{padding:11px;background:#0e8a7d;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;margin-top:4px;transition:background .15s,transform .1s}.login-btn:hover:not(:disabled){background:#0a6e64}.login-btn:active:not(:disabled){transform:scale(.99)}.login-btn:disabled{opacity:.7;cursor:not-allowed}.demo-hint{font-size:12px;color:#ffffffb3;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:7px;padding:10px 12px;margin-top:12px;line-height:1.5}.signup-toggle{text-align:center;font-size:13px;color:#fff9;margin-top:14px}.signup-toggle-link{background:none;border:none;color:#0e8a7d;font-size:13px;font-weight:600;padding:0;cursor:pointer;text-decoration:underline;text-underline-offset:2px}.signup-toggle-link:hover{color:#10a08f}.parent-signup-note{font-size:12px;color:#fff9;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:7px;padding:10px 12px;margin-top:12px;line-height:1.5;text-align:center}.login-footer{margin-top:24px;font-size:12px;color:#e8734a99}.sidebar{width:var(--sidebar-width);min-height:100vh;background:#2a3f6b;color:#ffffffd9;display:flex;flex-direction:column;flex-shrink:0;position:fixed;left:0;top:0;bottom:0;z-index:100;overflow-y:auto}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:20px 16px 16px;border-bottom:1px solid rgba(255,255,255,.15)}.sidebar-logo-icon{flex-shrink:0}.sidebar-brand-name{display:block;font-family:"DM Serif Display",serif;font-size:16px;font-weight:400;color:#fff;letter-spacing:-.3px}.sidebar-brand-role{display:block;font-size:11px;color:#fff9;font-weight:500;margin-top:1px}.sidebar-user{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.15);margin-bottom:8px}.sidebar-avatar{width:34px;height:34px;background:#e8734a;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:#fff;flex-shrink:0}.sidebar-user-name{display:block;font-size:13px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-email{display:block;font-size:11px;color:#fff9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-info{min-width:0}.sidebar-nav{flex:1;padding:0 8px}.sidebar-nav-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#fff;padding:8px 8px 6px}.sidebar-nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;font-size:13.5px;font-weight:500;color:#fff;background:#1b2a4a;transition:background .15s,color .15s;margin-bottom:6px}.sidebar-nav-item:hover{background:#1b2a4acc;color:#fff}.sidebar-nav-item.active{background:#0e8a7d;color:#fff}.sidebar-nav-icon{display:flex;align-items:center;flex-shrink:0;opacity:.85}.sidebar-nav-item.active .sidebar-nav-icon{opacity:1}.sidebar-logout{display:flex;align-items:center;gap:10px;padding:14px 20px;background:none;border:none;border-top:1px solid rgba(255,255,255,.15);color:#ffffffb3;font-size:13.5px;font-weight:500;width:100%;text-align:left;transition:color .15s,background .15s;cursor:pointer}.sidebar-logout:hover{color:#fff;background:#ffffff26}@media print{.sidebar{display:none!important}}.app-layout{display:flex;min-height:100vh}.main-content{flex:1;margin-left:var(--sidebar-width);padding:32px;min-height:100vh;max-width:calc(100vw - var(--sidebar-width))}@media print{.main-content{margin-left:0;padding:0;max-width:100%}}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:28px}.page-title{font-size:22px;font-weight:700;color:var(--text);letter-spacing:-.3px}.page-subtitle{font-size:13.5px;color:var(--text-muted);margin-top:4px}.page-header-action{flex-shrink:0}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:13.5px;font-weight:500;border:none;cursor:pointer;transition:background .15s,transform .1s}.btn:active{transform:scale(.98)}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-outline{background:transparent;color:var(--text);border:1px solid var(--border)}.btn-outline:hover{background:var(--bg)}.btn-danger-outline{background:transparent;color:#dc2626;border:1px solid #DC2626}.btn-danger-outline:hover{background:#fef2f2}.instructor-dashboard{max-width:900px}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:32px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}.stat-value{font-size:28px;font-weight:800;letter-spacing:-.5px;margin-bottom:4px}.stat-label{font-size:12.5px;font-weight:500;color:var(--text-muted);margin-bottom:6px}.stat-coming-soon{font-size:10.5px;color:var(--text-light);font-style:italic}.section-title{font-size:15px;font-weight:700;color:var(--text);margin-bottom:12px}.roster-mini{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.roster-mini-card{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;color:var(--text);transition:border-color .15s,box-shadow .15s,transform .1s;box-shadow:var(--shadow)}.roster-mini-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translate(2px)}.roster-mini-avatar{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0}.roster-mini-info{flex:1;min-width:0}.roster-mini-name{font-size:14px;font-weight:600;color:var(--text)}.roster-mini-level{font-size:12px;color:var(--text-muted)}.roster-mini-meta{display:flex;align-items:center;gap:8px;color:var(--text-light);font-size:12px}.roster-mini-sessions{font-size:11.5px;color:var(--text-muted)}.dashboard-notice{display:flex;gap:12px;align-items:flex-start;background:#fffbeb;border:1px solid #FDE68A;border-radius:var(--radius);padding:16px;font-size:13.5px;color:#92400e;line-height:1.5}.notice-icon{font-size:20px;flex-shrink:0;margin-top:1px}.roster-page{max-width:900px}.roster-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.student-card{background:var(--surface);border:1.5px solid var(--border);border-radius:12px;overflow:hidden;display:flex;flex-direction:column;color:var(--text);box-shadow:var(--shadow);transition:box-shadow .15s,border-color .15s,transform .12s}.student-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.student-card-header{padding:20px 20px 12px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between}.student-avatar{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff;box-shadow:0 2px 8px #00000026}.student-status-badge{font-size:11px;font-weight:600;background:#ecfdf5;color:#059669;border:1px solid #A7F3D0;padding:3px 9px;border-radius:99px}.student-card-body{padding:14px 20px;flex:1}.student-name{font-size:16px;font-weight:700;color:var(--text);margin-bottom:3px;letter-spacing:-.2px}.student-grade{font-size:12.5px;color:var(--text-muted);margin-bottom:3px}.student-unit{font-size:12.5px;font-weight:500;color:var(--primary);margin-bottom:12px}.student-meta{display:flex;flex-direction:column;gap:4px}.student-meta-item{display:flex;align-items:center;gap:5px;font-size:11.5px;color:var(--text-muted)}.student-card-footer{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;border-top:1px solid var(--border);font-size:13px;font-weight:600;color:var(--primary);background:var(--primary-light);transition:background .15s}.student-card:hover .student-card-footer{background:#dbeafe}.add-student-page{max-width:760px}.add-student-form{display:flex;flex-direction:column;gap:24px}.as-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}.as-section-title{font-size:14px;font-weight:700;color:var(--text);margin:0 0 4px;text-transform:uppercase;letter-spacing:.05em}.as-section-desc{font-size:13px;color:var(--text-muted);margin:0 0 16px;line-height:1.5}.as-field-row{display:flex;gap:16px;flex-wrap:wrap}.as-field{display:flex;flex-direction:column;gap:6px;flex:1;min-width:180px}.as-field label{font-size:12.5px;font-weight:600;color:var(--text-muted)}.as-field input,.as-field select,.as-field textarea{padding:8px 12px;border:1.5px solid var(--border);border-radius:8px;font-size:14px;color:var(--text);background:var(--bg);font-family:inherit;transition:border-color .15s}.as-field input:focus,.as-field select:focus,.as-field textarea:focus{outline:none;border-color:var(--primary);background:var(--surface)}.as-field textarea{resize:vertical}.as-field--error input,.as-field--error select{border-color:var(--danger)}.as-error{font-size:12px;color:var(--danger)}.as-level-cards{display:flex;gap:16px;flex-wrap:wrap;margin-top:12px}.as-level-card{flex:1;min-width:220px;display:flex;gap:12px;padding:16px;border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color .15s,background .15s;background:var(--bg)}.as-level-card input[type=radio]{margin-top:2px;accent-color:var(--primary);flex-shrink:0}.as-level-card--active{border-color:var(--primary);background:var(--primary-light)}.as-level-name{font-size:14px;font-weight:700;color:var(--text);margin-bottom:4px}.as-level-desc{font-size:12.5px;color:var(--text-muted);line-height:1.5}.as-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:8px}.si-page{display:flex;flex-direction:column;gap:24px}.si-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;box-shadow:var(--shadow)}.si-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.si-card-header-right{display:flex;align-items:center;gap:10px}.si-card-title{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;margin:0}.si-saved-badge{font-size:12px;font-weight:600;color:#059669;background:#d1fae5;border:1px solid #A7F3D0;border-radius:20px;padding:2px 10px}.si-detail-list{display:flex;flex-direction:column;margin:0;padding:0}.si-detail-row{display:grid;grid-template-columns:180px 1fr;gap:16px;padding:11px 0;border-bottom:1px solid var(--border);align-items:baseline}.si-detail-row:last-child{border-bottom:none;padding-bottom:0}.si-detail-row dt{font-size:11.5px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.si-detail-row dd{font-size:14px;color:var(--text);margin:0;line-height:1.5}.si-age{color:var(--text-muted);font-size:13px;margin-left:8px}.si-empty{color:var(--text-light);font-style:italic}.si-email-link{color:var(--primary);text-decoration:none}.si-email-link:hover{text-decoration:underline}.si-notes-row dd{line-height:1.6}.si-edit-form{display:flex;flex-direction:column;gap:16px}.si-field-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}.si-field{display:flex;flex-direction:column;gap:5px}.si-field--error .si-input{border-color:var(--danger)}.si-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.si-input{padding:8px 10px;border:1px solid var(--border);border-radius:6px;font-size:13.5px;color:var(--text);background:var(--bg);width:100%;box-sizing:border-box;font-family:inherit}.si-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-light)}.si-textarea{resize:vertical;line-height:1.5}.si-error{font-size:11.5px;color:var(--danger);font-weight:500}.si-level-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.si-level-option{display:flex;gap:10px;align-items:flex-start;padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;background:var(--bg);transition:border-color .15s,background .15s}.si-level-option input[type=radio]{display:none}.si-level-option--active{border-color:var(--primary);background:var(--primary-light)}.si-level-name{font-size:13px;font-weight:600;color:var(--text);margin-bottom:2px}.si-level-desc{font-size:11.5px;color:var(--text-muted);line-height:1.4}.si-edit-actions{display:flex;gap:8px;justify-content:flex-end;padding-top:4px;border-top:1px solid var(--border);margin-top:4px}.si-section-title{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;margin:0 0 10px}.si-quick-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.si-quick-card{display:flex;flex-direction:column;align-items:flex-start;gap:3px;padding:16px 36px 14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:left;transition:border-color .15s,box-shadow .15s;position:relative;box-shadow:var(--shadow)}.si-quick-card:hover{border-color:var(--primary);box-shadow:0 2px 8px #2563eb1a}.si-quick-icon{font-size:22px;margin-bottom:6px}.si-quick-label{font-size:13.5px;font-weight:700;color:var(--text)}.si-quick-sub{font-size:12px;color:var(--text-muted)}.si-quick-arrow{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--text-light)}.si-actions{display:flex;gap:10px}@media(max-width:700px){.si-quick-grid{grid-template-columns:repeat(2,1fr)}.si-detail-row{grid-template-columns:140px 1fr}.si-level-row{grid-template-columns:1fr}}.ah-page{display:flex;flex-direction:column;gap:12px}.ah-card{display:flex;align-items:center;gap:20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;box-shadow:var(--shadow);transition:border-color .15s,box-shadow .15s;flex-wrap:wrap}.ah-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md)}.ah-card-header{display:flex;gap:16px;flex:1;align-items:flex-start;min-width:240px}.ah-card-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#1b2a4a;flex-shrink:0}.ah-icon-phonogram{background:#eff6ff}.ah-icon-pa{background:#fdf4ff}.ah-icon-rw{background:#fef9ec}.ah-icon-ss{background:#f0fdf4}.ah-card-info{flex:1}.ah-card-title{font-size:15px;font-weight:700;color:var(--text);margin:0 0 4px}.ah-card-desc{font-size:13px;color:var(--text-muted);margin:0 0 6px;line-height:1.5}.ah-card-status{font-size:12.5px;font-weight:600}.ah-status-done{color:#059669}.ah-card-actions{flex-shrink:0;display:flex;gap:8px;flex-wrap:wrap;align-items:center}.ah-action-btn{display:flex;align-items:center;gap:6px;white-space:nowrap}.ah-integration-note{display:flex;gap:12px;align-items:flex-start;background:#eff6ff;border:1px solid #BFDBFE;border-radius:var(--radius);padding:14px 18px;font-size:13px;color:#0a6e64;line-height:1.6}.ah-note-icon{font-size:18px;flex-shrink:0;margin-top:1px}.ah-btn-active{background:#eff6ff;border-color:var(--primary);color:var(--primary)}.ah-results-panel{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;margin-bottom:8px}.ah-results-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:12px;display:flex;align-items:center;gap:10px}.ah-results-print-btn{margin-left:auto;display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:600;color:var(--text-muted);background:var(--surface);border:1px solid var(--border);border-radius:6px;cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s,background .15s}.ah-results-print-btn:hover{color:var(--primary);border-color:var(--primary);background:#eff6ff}.ah-results-score{font-size:12px;font-weight:600;color:var(--primary);background:#eff6ff;border-radius:20px;padding:2px 10px}.ah-results-stopped-note{font-size:12px;color:#dc2626;background:#fef2f2;border-radius:6px;padding:6px 10px;margin-bottom:10px}.ah-results-category{margin-bottom:10px}.ah-results-cat-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:5px}.ah-results-skill-grid{display:flex;flex-wrap:wrap;gap:6px}.ah-results-skill-item{display:flex;align-items:center;gap:3px;background:var(--surface);border:1px solid var(--border);border-radius:5px;padding:3px 7px;font-size:12px}.ah-results-skill-label{color:var(--text);font-weight:500}.ah-results-status{font-weight:700;font-size:11px}.ah-results-legend{display:flex;gap:14px;margin-top:10px;font-size:11px;font-weight:600}.ah-pa-results-list{display:flex;flex-direction:column;gap:5px}.ah-pa-level-row{display:flex;align-items:center;gap:10px;padding:6px 10px;border-radius:6px;font-size:13px}.ah-pa-pass{background:#ecfdf5}.ah-pa-fail{background:#fef2f2}.ah-pa-level-num{font-weight:700;min-width:52px;font-size:12px;color:var(--text-muted)}.ah-pa-level-name{font-weight:600;flex:1}.ah-pa-level-group{color:var(--text-muted);font-size:12px;flex:1}.ah-pa-score{font-size:11px;color:var(--text-muted)}.ah-pa-result-badge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:10px}.ah-badge-pass{background:#d1fae5;color:#065f46}.ah-badge-fail{background:#fee2e2;color:#991b1b}.ah-pa-history{margin-top:16px;padding-top:14px;border-top:1px solid var(--border)}.ah-pa-history-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:8px}.ah-pa-history-entry{border:1px solid var(--border);border-radius:6px;margin-bottom:6px;overflow:hidden}.ah-pa-history-toggle{display:flex;align-items:center;gap:10px;width:100%;padding:8px 12px;background:var(--surface);border:none;cursor:pointer;font-size:13px;color:var(--text);text-align:left}.ah-pa-history-toggle:hover{background:#f8fafc}.ah-pa-history-date{font-weight:600;flex-shrink:0}.ah-pa-history-summary{flex:1;color:var(--text-muted);font-size:12px}.ah-pa-history-chevron{flex-shrink:0;display:flex;align-items:center;transition:transform .15s}.ah-pa-history-chevron--open{transform:rotate(90deg)}.ah-pa-history-detail{padding:8px 12px 12px;display:flex;flex-direction:column;gap:5px;border-top:1px solid var(--border)}.ah-rw-results-grid{display:flex;flex-wrap:wrap;gap:6px}.ah-rw-word{padding:4px 10px;border-radius:6px;font-size:13px;font-weight:500}.ah-rw-correct{background:#d1fae5;color:#065f46}.ah-rw-error{background:#fee2e2;color:#991b1b}.ah-rw-not-tested{background:#f1f5f9;color:#94a3b8;border:1px solid #E2E8F0}.rw-print-lists{display:none}@media print{.ah-page .ah-card,.ah-page .ah-results-panel,.ah-page .ah-integration-note{display:none!important}.rw-print-lists{display:block}.rw-print-header{text-align:center;margin-bottom:24pt;border-bottom:2pt solid #000;padding-bottom:12pt}.rw-print-title{font-size:24pt;font-weight:700;margin:0 0 4pt;color:#000}.rw-print-student{font-size:14pt;color:#444}.rw-print-list{margin-bottom:24pt}.rw-print-list--break{page-break-after:always}.rw-print-list-title{font-size:18pt;font-weight:700;margin:0 0 12pt;border-bottom:1pt solid #ccc;padding-bottom:6pt;color:#000}.rw-print-words-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10pt 20pt}.rw-print-word{font-size:16pt;font-family:Georgia,serif;font-weight:600;color:#000}}.ah-introduced-words{display:flex;flex-wrap:wrap;align-items:center;gap:4px;margin-top:6px}.ah-introduced-label{font-size:12px;color:var(--text-muted);margin-right:4px}.ah-introduced-chip{display:inline-block;background:#fef3c7;border:1px solid #f59e0b;color:#92400e;border-radius:4px;padding:1px 8px;font-size:12px;font-weight:500}.ah-locked-badge{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:#059669;background:#ecfdf5;border:1px solid #A7F3D0;border-radius:99px;padding:4px 12px;white-space:nowrap}.ah-rw-list-section{padding:12px 0;border-bottom:1px solid var(--border)}.ah-rw-list-section:last-child{border-bottom:none;padding-bottom:0}.ah-rw-list-header{display:flex;align-items:center;gap:10px;margin-bottom:8px;font-size:13px}.ah-rw-list-date,.ah-pa-progress{font-size:12px;color:var(--text-muted)}.ah-pa-progress--ready{color:var(--success);font-weight:600}.ah-icon-fluency{background:#f0fdfa}.ah-icon-nwf{background:#fff7ed}.ah-icon-upper-level{background:#f5f3ff}.ah-form-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;margin-bottom:8px}.ah-form-section{font-size:13px;font-weight:700;color:var(--text);margin:16px 0 8px;padding-bottom:4px;border-bottom:1px solid var(--border)}.ah-form-section:first-child{margin-top:0}.ah-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.ah-form-field{display:flex;flex-direction:column;gap:4px}.ah-form-field label{font-size:12px;font-weight:600;color:var(--text-muted)}.ah-form-field select,.ah-form-field input[type=text],.ah-form-field input[type=number],.ah-form-field input[type=date]{padding:6px 10px;border:1px solid var(--border);border-radius:6px;font-size:13px;color:var(--text);background:var(--bg)}.ah-form-field select:focus,.ah-form-field input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #2563eb1a}.ah-auto-calc{display:inline-block;font-size:12px;font-weight:600;color:var(--primary);background:#eff6ff;border-radius:20px;padding:2px 10px;margin-top:4px}.ah-radio-group{display:flex;flex-direction:column;gap:6px}.ah-radio-item{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:var(--text);cursor:pointer;padding:6px 10px;border-radius:6px;border:1px solid transparent;transition:background .1s,border-color .1s}.ah-radio-item:hover{background:var(--bg)}.ah-radio-item.ah-radio-selected{background:#eff6ff;border-color:var(--primary)}.ah-radio-item input[type=radio]{margin-top:2px;flex-shrink:0}.ah-radio-label{font-weight:600;margin-right:4px}.ah-radio-desc{color:var(--text-muted);font-size:12px}.ah-checkbox-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.ah-checkbox-item{display:flex;align-items:flex-start;gap:6px;font-size:12.5px;color:var(--text);cursor:pointer;padding:4px 8px;border-radius:4px}.ah-checkbox-item:hover{background:var(--bg)}.ah-checkbox-item input[type=checkbox]{margin-top:2px;flex-shrink:0}.ah-form-actions{display:flex;gap:8px;margin-top:16px;padding-top:12px;border-top:1px solid var(--border)}.ah-results-table{width:100%;border-collapse:collapse;font-size:12.5px}.ah-results-table th,.ah-results-table td{padding:6px 10px;text-align:left;border-bottom:1px solid var(--border)}.ah-results-table th{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--bg)}.ah-results-table tr:hover{background:var(--bg)}.ah-results-table tr.ah-clickable-row{cursor:pointer}.ah-results-row-expand{padding:10px 16px;background:var(--bg);border-bottom:1px solid var(--border);font-size:12px;color:var(--text-muted);display:flex;flex-wrap:wrap;gap:6px 16px}.ah-legacy-badge{font-size:10px;font-weight:600;color:#94a3b8;background:#f1f5f9;border:1px solid #E2E8F0;border-radius:4px;padding:1px 6px;margin-left:6px}.ah-fluency-chart,.ah-nwf-chart{margin:12px 0}.ah-fluency-chart h4,.ah-nwf-chart h4{font-size:13px;font-weight:700;color:var(--text);margin:0 0 8px;display:flex;align-items:center;gap:6px}.ah-bench-legend{font-size:11px;color:var(--text-muted);margin-top:4px;font-style:italic}.lp-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:16px}.lp-empty{text-align:center;padding:48px 24px;background:var(--surface);border:1.5px dashed var(--border);border-radius:12px;display:flex;flex-direction:column;align-items:center}.lp-empty-icon{font-size:36px;margin-bottom:12px}.lp-empty-title{font-size:16px;font-weight:700;color:var(--text);margin-bottom:6px}.lp-empty-sub{font-size:13.5px;color:var(--text-muted)}.lp-list{display:flex;flex-direction:column;gap:8px}.lp-card{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;color:var(--text);box-shadow:var(--shadow);transition:border-color .15s,box-shadow .15s,transform .1s}.lp-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translate(2px)}.lp-card-icon{width:40px;height:40px;background:var(--primary-light);color:var(--primary);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.lp-card-body{flex:1}.lp-card-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px}.lp-card-meta{display:flex;gap:12px}.lp-meta-item{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-muted)}.lp-card>svg:last-child{color:var(--text-light);flex-shrink:0}.sl-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:16px}.sl-form{background:var(--surface);border:1.5px solid var(--primary);border-radius:var(--radius);padding:20px;margin-bottom:24px;box-shadow:0 0 0 3px #2563eb14;display:flex;flex-direction:column;gap:12px}.sl-form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.sl-empty{text-align:center;padding:48px 24px;background:var(--surface);border:1.5px dashed var(--border);border-radius:12px;display:flex;flex-direction:column;align-items:center}.sl-empty-icon{font-size:36px;margin-bottom:12px}.sl-empty-title{font-size:16px;font-weight:700;color:var(--text);margin-bottom:6px}.sl-empty-sub{font-size:13.5px;color:var(--text-muted)}.sl-list{display:flex;flex-direction:column;gap:8px}.sl-entry{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.sl-entry.open{border-color:var(--primary)}.sl-entry-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;width:100%;background:none;border:none;cursor:pointer;text-align:left;transition:background .15s}.sl-entry-header:hover{background:var(--bg)}.sl-entry-left{display:flex;align-items:flex-start;gap:12px}.sl-entry-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:5px}.sl-entry-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px}.sl-entry-meta{display:flex;gap:12px}.sl-entry-meta span{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-muted)}.sl-chevron{color:var(--text-light);transition:transform .2s;flex-shrink:0}.sl-chevron.open{transform:rotate(90deg)}.sl-entry-body{padding:14px 16px 16px;border-top:1px solid var(--border);background:#fafbfc;display:flex;flex-direction:column;gap:12px}.sl-detail-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:3px}.sl-detail-value{font-size:13.5px;color:var(--text);line-height:1.55}.sl-entry-actions{display:flex;justify-content:flex-end;padding-top:8px;border-top:1px solid var(--border);margin-top:4px}.sl-delete-btn{background:none;border:1px solid #DC2626;color:#dc2626;font-size:12px;font-weight:600;padding:4px 12px;border-radius:6px;cursor:pointer;transition:background .15s}.sl-delete-btn:hover{background:#fef2f2}.sl-published-badge{display:inline-block;margin-left:8px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;background:#eff6ff;color:var(--primary);border:1px solid #BFDBFE;border-radius:4px;padding:1px 6px;vertical-align:middle}.sl-red-word{font-weight:700;color:#dc2626;font-size:15px}.sl-notes-input{margin-top:4px;width:100%;box-sizing:border-box}.sl-notes-actions{display:flex;gap:8px;margin-top:8px}.sl-notes-save{font-size:12px;padding:4px 12px}.sl-accuracy-row{display:flex;gap:12px;margin-bottom:12px;flex-wrap:wrap}.sl-accuracy-block{flex:1;min-width:140px;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:10px 14px;text-align:center}.sl-accuracy-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:4px}.sl-accuracy-pct{font-size:28px;font-weight:700;line-height:1;margin-bottom:4px}.sl-acc-high{color:var(--success)}.sl-acc-mid{color:var(--accent)}.sl-acc-low{color:var(--danger)}.sl-accuracy-sub{font-size:12px;color:var(--text-muted)}.sl-errors-table{display:flex;flex-direction:column;gap:8px;margin-top:6px}.sl-error-group{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:8px 10px}.sl-error-group-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}.sl-error-chips{display:flex;flex-wrap:wrap;gap:6px}.sl-error-chip{display:inline-flex;align-items:center;gap:3px;background:#fee2e2;border:1px solid #fca5a5;color:#991b1b;border-radius:4px;padding:2px 8px;font-size:12px;font-weight:500}.sl-error-chip em{color:#7f1d1d;font-style:italic}.invite-parent-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;margin-bottom:24px;box-shadow:var(--shadow)}.invite-parent-section .progress-section-title{display:flex;align-items:center;gap:6px}.invite-section-desc{font-size:13px;color:var(--text-muted);margin-bottom:14px;line-height:1.5}.invite-unavailable .invite-section-desc{margin-bottom:0;font-style:italic}.invite-form{display:flex;gap:8px;align-items:stretch}.invite-email-input{flex:1}.invite-send-btn{display:flex;align-items:center;gap:6px;white-space:nowrap;padding:10px 16px;font-size:13px}.invite-link-box{margin-top:12px;background:#f0fdf4;border:1px solid #A7F3D0;border-radius:8px;padding:12px 14px}.invite-link-label{font-size:12.5px;font-weight:600;color:#059669;margin-bottom:8px}.invite-link-row{display:flex;gap:8px}.invite-link-input{flex:1;font-size:12px;padding:8px 10px;background:#fff;color:var(--text)}.invite-copy-btn{display:flex;align-items:center;gap:4px;white-space:nowrap;padding:8px 12px;font-size:12.5px}.invite-list{margin-top:16px}.invite-list-title{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.invite-list-item{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px}.invite-list-item:last-child{border-bottom:none}.invite-list-email{color:var(--text);font-weight:500}.invite-status-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:99px;text-transform:capitalize}.invite-status-pending{background:#fffbeb;color:#d97706;border:1px solid #FDE68A}.invite-status-accepted{background:#ecfdf5;color:#059669;border:1px solid #A7F3D0}.invite-status-expired{background:#fef2f2;color:#dc2626;border:1px solid #FECACA}.progress-section-title{font-size:14px;font-weight:700;color:var(--text);margin-bottom:12px}.progress-snapshot-5{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:28px}@media(max-width:1200px){.progress-snapshot-5{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.progress-snapshot-5{grid-template-columns:repeat(2,1fr)}}.snap-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;display:flex;gap:12px;align-items:flex-start;box-shadow:var(--shadow)}.snap-icon{width:38px;height:38px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.snap-body{flex:1;min-width:0}.snap-label{font-size:11.5px;font-weight:600;color:var(--text-muted);margin-bottom:2px;text-transform:uppercase;letter-spacing:.05em}.snap-value{font-size:24px;font-weight:800;letter-spacing:-.5px;margin-bottom:2px;color:var(--text);display:flex;align-items:center;gap:6px}.snap-value-text{font-size:14px;font-weight:600;line-height:1.4;letter-spacing:0}.snap-bench{font-size:11px;color:var(--text-light)}.snap-progress-bar{margin-top:6px;height:4px;background:#e2e8f0;border-radius:2px;overflow:hidden}.snap-progress-fill{height:100%;background:#059669;border-radius:2px;transition:width .3s ease}.trend-arrow{font-size:12px;line-height:1}.trend-up{color:#059669}.trend-down{color:#dc2626}.trend-flat{color:var(--text-muted);font-size:10px}.btn-orf-log{margin-top:6px;padding:4px 10px;font-size:11.5px;font-weight:600;color:#0d9488;background:#f0fdfa;border:1px solid #99F6E4;border-radius:6px;cursor:pointer;transition:background .15s,border-color .15s}.btn-orf-log:hover{background:#ccfbf1;border-color:#5eead4}.orf-modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.orf-modal{background:#fff;border-radius:12px;padding:24px 28px;width:360px;max-width:90vw;box-shadow:0 20px 60px #00000026}.orf-modal-title{font-size:16px;font-weight:700;color:var(--text);margin-bottom:18px}.orf-modal-field{margin-bottom:14px}.orf-modal-field label{display:block;font-size:12.5px;font-weight:600;color:var(--text-muted);margin-bottom:5px}.orf-modal-field .form-input{width:100%}.orf-modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:18px}.orf-chart-title{font-size:14px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:6px;margin:0 0 12px}.orf-bench-legend{margin-top:8px;font-size:11px;color:var(--text-muted, #94A3B8);font-style:italic;text-align:right}.snap-bench--norm{font-weight:600;color:#0e8a7d;font-size:10.5px}.print-practice-dialog{background:#fff;border-radius:12px;padding:24px 28px;width:380px;max-width:90vw;box-shadow:0 20px 60px #00000026}.print-practice-dialog-title{font-size:16px;font-weight:700;color:var(--text);margin:0 0 8px}.print-practice-dialog-desc{font-size:13px;color:var(--text-muted);margin:0 0 14px;line-height:1.5}.print-practice-checkbox{display:flex;align-items:center;gap:8px;font-size:13.5px;font-weight:500;color:var(--text);cursor:pointer;padding:8px 0}.print-practice-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:#059669}.portal-preview-section{margin-top:4px}.portal-preview-header{margin-bottom:16px}.portal-preview-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.portal-preview-title{font-size:15px;font-weight:700;color:var(--text)}.portal-preview-subtitle{font-size:13px;color:var(--text-muted);margin-top:2px}.portal-skills-text{font-size:12.5px;line-height:1.7;color:var(--text-muted)}.student-profile{max-width:960px}.profile-not-found{text-align:center;padding:60px 20px;color:var(--text-muted)}.profile-breadcrumb{display:flex;align-items:center;gap:6px;margin-bottom:16px;font-size:13px}.breadcrumb-link{display:flex;align-items:center;gap:3px;color:var(--primary);font-weight:500;transition:opacity .15s}.breadcrumb-link:hover{opacity:.75}.breadcrumb-sep{color:var(--text-light)}.breadcrumb-current{color:var(--text-muted);font-weight:500}.profile-header{background:var(--surface);border:1px solid var(--border);border-left:4px solid;border-radius:var(--radius);padding:20px 24px;display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:10px;box-shadow:var(--shadow)}.profile-header-left{display:flex;align-items:flex-start;gap:16px}.profile-avatar{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:#fff;flex-shrink:0;box-shadow:0 2px 8px #00000026}.profile-name{font-size:20px;font-weight:800;letter-spacing:-.3px;color:var(--text);margin-bottom:2px}.profile-grade{font-size:13px;color:var(--text-muted);margin-bottom:3px}.profile-level{font-size:13px;font-weight:600;margin-bottom:10px}.profile-stats{display:flex;gap:14px;flex-wrap:wrap}.profile-stat{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-muted)}.profile-header-actions{display:flex;align-items:center;gap:8px;flex-shrink:0;padding-top:4px}.profile-note{background:#fffbeb;border:1px solid #FDE68A;border-radius:8px;padding:10px 14px;font-size:13px;color:#92400e;margin-bottom:16px;line-height:1.5}.profile-note-label{font-weight:600;margin-right:6px}.profile-tabs{display:flex;border-bottom:2px solid var(--border);margin-bottom:24px;gap:0}.profile-tab{padding:10px 20px;font-size:13.5px;font-weight:500;color:var(--text-muted);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:color .15s,border-color .15s}.profile-tab:hover{color:var(--text)}.profile-tab.active{font-weight:600}.profile-tab-content{min-height:300px}.visual-card{display:flex;flex-direction:column;align-items:center;border:3px solid #1E3A5F;border-radius:16px;padding:16px 12px;background:#fff;cursor:default;transition:box-shadow .15s}.visual-card[role=button]{cursor:pointer}.visual-card[role=button]:hover{box-shadow:0 4px 16px #0000001f}.visual-card[role=button]:focus-visible{outline:2px solid var(--primary, #0E8A7D);outline-offset:2px}.vc-label{font-family:Georgia,Times New Roman,serif;font-weight:900;color:#1e3a5f;text-align:center;line-height:1.1}.vc-sound{color:#475569;font-style:italic;text-align:center}.vc-image{display:flex;align-items:center;justify-content:center}.vc-image img{width:100%;height:100%;object-fit:contain}.vc-keyword{font-weight:700;color:#1e3a5f;text-align:center;border-top:2px solid #E2E8F0;width:100%;-webkit-print-color-adjust:exact;print-color-adjust:exact}.vc-meaning{font-style:italic;color:#64748b;text-align:center;width:100%}.vc--small{width:120px;min-height:150px;padding:10px 8px;gap:4px}.vc--small .vc-label{font-size:22px;letter-spacing:1px}.vc--small .vc-sound{font-size:11px}.vc--small .vc-image{width:70px;height:70px}.vc--small .vc-keyword{font-size:12px;padding-top:6px;letter-spacing:.5px}.vc--small .vc-meaning{font-size:10px}.vc--medium{width:180px;min-height:220px;padding:14px 12px;gap:6px}.vc--medium .vc-label{font-size:36px;letter-spacing:2px}.vc--medium .vc-sound{font-size:14px}.vc--medium .vc-image{width:110px;height:110px}.vc--medium .vc-keyword{font-size:16px;padding-top:8px;letter-spacing:1px}.vc--medium .vc-meaning{font-size:12px}.vc--large{width:260px;min-height:340px;padding:24px 20px;gap:8px}.vc--large .vc-label{font-size:56px;letter-spacing:3px;margin-bottom:4px}.vc--large .vc-sound{font-size:18px;margin-bottom:6px}.vc--large .vc-image{width:160px;height:160px}.vc--large .vc-keyword{font-size:28px;padding-top:12px;letter-spacing:2px}.vc--large .vc-meaning{font-size:16px;margin-top:4px}@media print{.vc--print-full{break-before:page;width:260pt!important;min-height:auto;padding:28pt 24pt;margin:0 auto;border:3px solid #1E3A5F;-webkit-print-color-adjust:exact;print-color-adjust:exact}.vc--print-full .vc-label{font-size:64pt;letter-spacing:4pt}.vc--print-full .vc-sound{font-size:20pt;margin-bottom:12pt}.vc--print-full .vc-image{width:160pt;height:160pt}.vc--print-full .vc-keyword{font-size:36pt;padding-top:16pt;letter-spacing:2pt}.vc--print-full .vc-meaning{font-size:16pt;margin-top:6pt}.vc--print-grid{width:2.8in!important;min-height:3.5in;padding:.2in;border:2px solid #1E3A5F;page-break-inside:avoid;-webkit-print-color-adjust:exact;print-color-adjust:exact}.vc--print-grid .vc-label{font-size:28pt;letter-spacing:2pt}.vc--print-grid .vc-sound{font-size:10pt}.vc--print-grid .vc-image{width:1.5in;height:1.5in}.vc--print-grid .vc-keyword{font-size:16pt;padding-top:6pt;letter-spacing:1pt}.vc--print-grid .vc-meaning{font-size:9pt}}.lpe-page{max-width:1300px}.lpe-error{padding:40px;color:var(--text-muted)}.lpe-topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;gap:16px}.lpe-topbar-left{display:flex;align-items:center;gap:6px;font-size:13.5px}.lpe-back{display:flex;align-items:center;gap:3px;color:var(--primary);font-weight:600;transition:opacity .15s}.lpe-back:hover{opacity:.75}.lpe-topbar-sep{color:var(--text-light)}.lpe-topbar-label{color:var(--text-muted);font-weight:500}.lpe-topbar-right{display:flex;align-items:center;gap:8px}.btn-saved{background:#059669!important}.lpe-markup-btn{display:flex;align-items:center;gap:5px;font-size:13px}.lpe-markup-btn--active{background:#fef2f2!important;border-color:#ef4444!important;color:#b91c1c!important;font-weight:700}.lpe-autopop-banner{background:#eff6ff;border:1px solid #BFDBFE;border-radius:var(--radius);padding:12px 16px;font-size:13px;color:#0a6e64;margin-bottom:10px;line-height:1.5}.lpe-error-suggestion{background:#fffbeb;border:1px solid #FDE68A;border-radius:var(--radius);padding:10px 14px;font-size:13px;color:#92400e;margin-bottom:10px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.lpe-suggestion-link{background:none;border:none;color:#d97706;font-weight:700;cursor:pointer;padding:0;font-size:13px;text-decoration:underline}.lpe-suggestion-link:hover{color:#92400e}.lpe-suggestion-dismiss{background:none;border:none;color:#b45309;cursor:pointer;font-size:14px;padding:0 2px;margin-left:auto}.lpe-markup-banner{background:#fff1f2;border:1px solid #FECDD3;border-radius:var(--radius);padding:10px 14px;font-size:13px;color:#9f1239;margin-bottom:10px;font-weight:500}.lpe-time-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;margin-bottom:14px;box-shadow:var(--shadow)}.lpe-time-info{display:flex;align-items:center;gap:16px;margin-bottom:8px}.lpe-time-total{font-size:18px;font-weight:800;color:var(--text);letter-spacing:-.3px}.lpe-time-total.over{color:#ef4444}.lpe-time-split{font-size:12.5px;color:var(--text-muted)}.lpe-progress-track{height:8px;background:var(--bg);border-radius:4px;overflow:hidden}.lpe-progress-fill{height:100%;border-radius:4px;background:#0e8a7d;transition:width .3s ease,background .3s}.lpe-progress-fill.lpe-good{background:#10b981}.lpe-progress-fill.lpe-over{background:#ef4444}.lpe-over-warn{font-size:12px;color:#ef4444;font-weight:600;margin-top:6px;display:block}.lpe-plan-header{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:14px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:12px}.lpe-plan-header-top{display:grid;grid-template-columns:160px 200px 1fr;gap:12px;align-items:end}.lpe-plan-header-info{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;align-items:start;padding-top:10px;border-top:1px solid var(--border)}.lpe-prevalent-errors{display:flex;flex-direction:column;gap:6px}.lpe-prevalent-errors-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.lpe-error-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.lpe-columns{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:start}.lpe-col{display:flex;flex-direction:column;gap:10px}.lpe-col-header{display:flex;align-items:center;justify-content:center;padding:9px 14px;border-radius:8px;font-size:13.5px;font-weight:800;letter-spacing:.08em;color:#fff;text-transform:uppercase;margin-bottom:2px}.lpe-col-header--blue{background:linear-gradient(135deg,#0a6e64,#0e8a7d)}.lpe-col-header--purple{background:linear-gradient(135deg,#1b2a4a,#2a3f6a)}.lpe-section{background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden;box-shadow:var(--shadow)}.lpe-section--blue{border-top:3px solid #0E8A7D}.lpe-section--purple{border-top:3px solid #7C3AED}.lpe-section-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bg);border-bottom:1px solid var(--border)}.lpe-section-header--blue{border-left:3px solid #0E8A7D}.lpe-section-header--purple{border-left:3px solid #7C3AED}.lpe-section-title-row{display:flex;align-items:center;gap:8px}.lpe-section-title{font-size:13px;font-weight:700;color:var(--text)}.lpe-toggle{width:18px;height:18px;border-radius:5px;border:2px solid var(--border);background:var(--surface);cursor:pointer;flex-shrink:0;accent-color:var(--primary)}.time-control{display:flex;align-items:center;gap:5px}.time-btn{width:22px;height:22px;border-radius:5px;border:1px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-muted);transition:border-color .15s,color .15s}.time-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.time-btn:disabled{opacity:.5;cursor:default}.time-value{font-size:12px;font-weight:700;color:var(--text);min-width:42px;text-align:center}.lpe-section-body{padding:12px 14px;display:flex;flex-direction:column;gap:10px}.lpe-field{display:flex;flex-direction:column;gap:4px}.lpe-field-label{font-size:11.5px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.lpe-field-hint{font-weight:400;text-transform:none;letter-spacing:0;font-style:italic;color:var(--text-light)}.lpe-input{padding:7px 10px;border:1.5px solid var(--border);border-radius:7px;font-size:13px;font-family:inherit;color:var(--text);background:var(--surface);outline:none;resize:vertical;transition:border-color .15s;line-height:1.5;width:100%;box-sizing:border-box}.lpe-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px #2563eb1a}.lpe-input:disabled,.lpe-select:disabled{opacity:.7;cursor:default;background:var(--bg)}.lpe-input--full{width:100%}.lpe-select{cursor:pointer;appearance:auto}.lpe-skill-concept-display{margin-top:4px;padding:6px 10px;font-size:13px;color:var(--text-muted);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);font-style:italic}.lpe-skill-concept-placeholder{margin-top:4px;padding:6px 10px;font-size:12px;color:var(--text-light);background:var(--bg);border:1px dashed var(--border);border-radius:var(--radius);font-style:italic}.lpe-note{font-size:12.5px;color:#0d47a1;background:#e3f2fd;border-left:4px solid #1565C0;padding:12px;border-radius:6px;margin-bottom:8px;line-height:1.5}.lpe-teacher-script{font-size:12.5px;color:#1b5e20;background:#e8f5e9;border-left:4px solid #2E7D32;padding:12px;border-radius:6px;margin-bottom:8px;line-height:1.55}.lpe-steps-list{margin:0 0 8px;padding:12px 12px 12px 30px;font-size:12.5px;color:#0d47a1;line-height:1.7;background:#e3f2fd;border-left:4px solid #1565C0;border-radius:6px}.lpe-steps-list li{margin-bottom:2px}.lpe-display-text{font-size:12.5px;color:var(--text);background:#f8fafc;border:1px solid var(--border);border-radius:7px;padding:8px 11px;line-height:1.6}.lpe-display-text--objective{background:#eff6ff;border-color:#bfdbfe;color:#1e3a8a}.lpe-display-text--template{background:#f5f3ff;border-color:#ddd6fe;color:#4c1d95;font-style:italic}.lpe-display-text--method{background:#e3f2fd;border:none;border-left:4px solid #1565C0;border-radius:6px;color:#0d47a1;margin-bottom:8px;padding:12px}.lpe-display-text--prompt{background:#ecfdf5;border-color:#a7f3d0;color:#064e3b;font-style:italic}.lpe-subsection{display:flex;flex-direction:column;gap:7px;padding-top:10px;border-top:1px solid var(--border)}.lpe-subsection-title{font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#7c3aed}.lpe-chip-list{display:flex;flex-wrap:wrap;gap:6px;min-height:36px;padding:4px 0;align-items:center}.lpe-chip{display:inline-flex;align-items:center;gap:4px;background:#eff6ff;border:1px solid #BFDBFE;border-radius:20px;padding:3px 10px 3px 12px;font-size:12.5px;font-weight:600;color:#0a6e64;white-space:nowrap}.lpe-chip-x{background:none;border:none;color:#93c5fd;cursor:pointer;font-size:14px;padding:0;line-height:1;display:flex;align-items:center;transition:color .15s}.lpe-chip-x:hover{color:#ef4444}.lpe-chip--markable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .1s,border-color .1s}.lpe-chip--markable:hover{background:#fef3c7;border-color:#fde68a}.lpe-chip--error{background:#fee2e2!important;border-color:#fecaca!important;color:#b91c1c!important;text-decoration:line-through;-webkit-print-color-adjust:exact;print-color-adjust:exact}.lpe-chip-add-row{display:flex;align-items:center;gap:4px}.lpe-chip-input{width:80px;padding:3px 7px;border:1.5px solid var(--primary);border-radius:20px;font-size:12.5px;font-family:inherit;outline:none;background:#fff}.lpe-chip-add-confirm{width:24px;height:24px;border-radius:50%;background:var(--primary);border:none;color:#fff;font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.lpe-chip-add-confirm:hover{background:var(--primary-dark)}.lpe-chip-cancel{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:13px;padding:0 2px}.lpe-chip-add-btn{display:inline-flex;align-items:center;gap:3px;background:none;border:1.5px dashed var(--border);border-radius:20px;padding:3px 11px;font-size:12px;color:var(--text-muted);cursor:pointer;transition:border-color .15s,color .15s}.lpe-chip-add-btn:hover{border-color:var(--primary);color:var(--primary)}.lpe-chip-wrap--draggable{cursor:grab;touch-action:none}.lpe-chip-wrap--draggable:active{cursor:grabbing}.lpe-chip-drag-handle{color:#94a3b8;font-size:14px;line-height:1;cursor:grab;-webkit-user-select:none;user-select:none;margin-right:2px;transition:color .15s}.lpe-chip-wrap--draggable:hover .lpe-chip-drag-handle{color:#475569}.lpe-chip-dragging{opacity:.35}.lpe-chip-drop-target>.lpe-chip{box-shadow:-3px 0 0 0 var(--primary);border-color:var(--primary)}.lpe-chip-drag-clone{box-shadow:0 4px 12px #0000002e;border-radius:20px;background:#eff6ff;transform:scale(1.05)}.skill-selector{position:relative;flex:1;min-width:0}.skill-selector--prominent{display:flex;align-items:center;gap:4px;flex:1;min-width:0}.lts-skill-chip{flex:1;min-width:0;display:flex;flex-direction:column;align-items:flex-start;cursor:pointer;padding:2px 4px;border-radius:6px;transition:background .12s}.lts-skill-chip:hover{background:#eff6ff}.lts-skill-label{font-size:20px;font-weight:800;color:var(--text);line-height:1.1;letter-spacing:-.01em;font-family:inherit}.lts-skill-sound{font-size:11px;color:var(--text-muted);font-weight:500;line-height:1.2;margin-top:1px}.lts-auto-badge{display:inline-block;margin-left:6px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#6b7280;background:#f3f4f6;border:1px solid #D1D5DB;border-radius:8px;padding:1px 5px;vertical-align:middle}.skill-selector--auto .lts-skill-chip{background:#f9fafb;border-color:#d1d5db}.skill-selector--auto .lts-skill-label{color:#374151}.skill-selector-input-row{display:flex;align-items:center;gap:4px}.skill-selector-input{flex:1;min-width:0}.skill-selector-badge{font-size:11px;font-weight:700;color:var(--primary);background:#eff6ff;border:1px solid #BFDBFE;border-radius:12px;padding:2px 8px;white-space:nowrap;flex-shrink:0}.skill-selector-clear{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:16px;padding:0 2px;line-height:1;flex-shrink:0;transition:color .15s}.skill-selector-clear:hover{color:#ef4444}.skill-selector-dropdown{position:absolute;top:calc(100% + 3px);left:0;right:0;background:#fff;border:1.5px solid var(--primary);border-radius:8px;box-shadow:0 4px 16px #0000001f;z-index:200;overflow:hidden;max-height:260px;overflow-y:auto}.skill-selector-option{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:none;border:none;text-align:left;cursor:pointer;font-family:inherit;font-size:13px;transition:background .1s;border-bottom:1px solid var(--border)}.skill-selector-option:last-child{border-bottom:none}.skill-selector-option:hover,.skill-selector-option--active{background:#eff6ff}.skill-selector-option-label{font-weight:700;color:var(--text);min-width:30px}.skill-selector-option-sound{font-size:12px;color:var(--primary);font-weight:600}.skill-selector-option-keyword{font-size:11.5px;color:var(--text-muted);font-style:italic;margin-left:auto}.lpe-last-taught-row{display:flex;flex-direction:column;gap:6px}.lpe-last-taught-row-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.lpe-last-taught-boxes{display:flex;gap:8px}.lpe-last-taught-box{flex:1;display:flex;align-items:center;gap:6px;background:#f8fafc;border:1px solid var(--border);border-radius:8px;padding:6px 8px;min-height:52px}.lpe-last-taught-num{font-size:11px;font-weight:800;color:var(--primary);background:#eff6ff;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.lpe-weaving-in-row{display:flex;align-items:center;gap:8px}.lpe-na-label{display:flex;align-items:center;gap:5px;font-size:12.5px;font-weight:600;color:var(--text-muted);white-space:nowrap;cursor:pointer}.lpe-prior-knowledge-row{display:flex;align-items:center;gap:8px}.lpe-rotation-lists-row{margin-bottom:2px}.lpe-rotation-lists-label{margin-bottom:6px}.lpe-rotation-boxes{display:flex;gap:12px;flex-wrap:wrap}.lpe-rotation-box{flex:1;min-width:200px;display:flex;flex-direction:column;gap:5px}.lpe-rotation-box-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.lpe-rotation-box-actions{display:flex;align-items:center;gap:8px}.lpe-rotation-word-count{font-size:11.5px;color:#059669;font-weight:600}.lpe-rotation-skill-tag{display:inline-flex;align-items:center;margin-left:6px;background:#f0fdf4;border:1px solid #BBF7D0;border-radius:10px;padding:1px 7px;font-size:10.5px;font-weight:700;color:#15803d;letter-spacing:.02em}.lpe-sync-btn{font-size:12px!important;padding:4px 10px!important;white-space:nowrap;flex-shrink:0}.lpe-sync-all-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:10px 14px;background:linear-gradient(135deg,#e6f7f5,#f0fdf4);border:1.5px solid #A7DAD5;border-radius:var(--radius);margin-bottom:2px}.lpe-sync-all-btn{display:inline-flex;align-items:center;gap:7px;background:var(--primary);color:#fff;border:none;padding:8px 18px;border-radius:7px;font-size:14px;font-weight:700;cursor:pointer;letter-spacing:.01em;white-space:nowrap;flex-shrink:0;transition:background .15s,opacity .15s}.lpe-sync-all-btn:hover:not(:disabled){background:var(--primary-dark)}.lpe-sync-all-btn:disabled{opacity:.7;cursor:not-allowed}.lpe-sync-all-btn--loading{background:#64748b}@keyframes lpe-spin{to{transform:rotate(360deg)}}.lpe-sync-all-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:lpe-spin .7s linear infinite}.lpe-sync-all-hint{font-size:12px;color:#0a6e64;line-height:1.4;flex:1;min-width:180px}.lpe-sync-all-badge{display:inline-flex;align-items:center;gap:5px;font-size:12.5px;font-weight:700;padding:4px 10px;border-radius:20px;white-space:nowrap}.lpe-sync-all-badge--ok{background:#d1fae5;color:#065f46}.lpe-sync-all-badge--warn{background:#fef9ec;border:1px solid #FDE68A;color:#78350f;white-space:normal;font-weight:500;max-width:520px;border-radius:8px}.lpe-sync-all-badge--error{background:#fee2e2;color:#991b1b;max-width:400px;white-space:normal;font-weight:500}.lpe-sync-all-unverified{font-weight:600;color:#92400e;cursor:help}.lpe-sync-all-clean{font-weight:500;color:#065f46}.lpe-sync-all-dismiss{background:none;border:none;cursor:pointer;color:#991b1b;font-size:12px;padding:0 0 0 6px;flex-shrink:0}.lpe-word-chip--unverified{background:#fef3c7!important;border-color:#f59e0b!important;color:#78350f!important}.lpe-word-chip-warn-icon{font-size:10px;margin-right:2px;opacity:.85}.lpe-unverified-panel{margin-top:8px;background:#fffbeb;border:1.5px solid #FDE68A;border-radius:7px;padding:8px 10px}.lpe-unverified-panel-hdr{font-size:11px;font-weight:700;color:#92400e;margin-bottom:7px;display:flex;align-items:center;gap:4px}.lpe-unverified-items{display:flex;flex-direction:column;gap:5px}.lpe-unverified-item{display:flex;align-items:center;gap:6px;flex-wrap:wrap;position:relative}.lpe-unverified-word{font-size:13px;font-weight:700;color:#b45309;background:#fef3c7;border:1px solid #FCD34D;border-radius:5px;padding:2px 7px;min-width:48px;text-align:center}.lpe-unverified-btn{font-size:11.5px;font-weight:600;padding:2px 8px;border-radius:5px;cursor:pointer;border:1px solid;white-space:nowrap;transition:background .12s}.lpe-unverified-btn--replace{background:#fff;border-color:#d97706;color:#92400e}.lpe-unverified-btn--replace:hover,.lpe-unverified-btn--replace.active{background:#fef3c7}.lpe-unverified-btn--keep{background:#fff;border-color:#6b7280;color:#374151}.lpe-unverified-btn--keep:hover{background:#f9fafb}.lpe-unverified-dropdown{position:absolute;top:calc(100% + 4px);left:0;z-index:20;background:#fff;border:1.5px solid #FDE68A;border-radius:8px;box-shadow:0 4px 16px #0000001f;padding:8px;min-width:200px}.lpe-unverified-dropdown-hint{font-size:10.5px;font-weight:600;color:#6b7280;margin-bottom:5px;text-transform:uppercase;letter-spacing:.05em}.lpe-unverified-suggestions{display:flex;flex-wrap:wrap;gap:5px}.lpe-unverified-suggestion{font-size:13px;font-weight:500;padding:3px 10px;border-radius:5px;border:1px solid #D1D5DB;background:#f9fafb;cursor:pointer;color:var(--text);transition:background .1s,border-color .1s}.lpe-unverified-suggestion:hover{background:#eff6ff;border-color:var(--primary);color:var(--primary)}.lpe-unverified-no-suggestions{font-size:12px;color:#6b7280;font-style:italic}.lpe-multi-skill-badge{display:inline-flex;align-items:center;margin-left:8px;background:#eff6ff;border:1px solid #BFDBFE;border-radius:20px;padding:1px 8px;font-size:10.5px;font-weight:700;color:#0a6e64;letter-spacing:.03em;font-style:normal}.lpe-multi-skill-row{display:flex;align-items:center;gap:6px;margin-top:5px}.lpe-multi-skill-remove{flex-shrink:0;width:24px;height:24px;border:1px solid #FCA5A5;border-radius:50%;background:#fef2f2;color:#dc2626;font-size:14px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.lpe-multi-skill-remove:hover{background:#fee2e2}.lpe-multi-skill-add{margin-top:7px;font-size:11.5px;font-weight:600;color:var(--primary);background:#eff6ff;border:1px dashed #93C5FD;border-radius:6px;padding:5px 12px;cursor:pointer;font-family:inherit;transition:background .15s,border-color .15s;width:100%;text-align:left}.lpe-multi-skill-add:hover{background:#dbeafe;border-color:var(--primary)}.lpe-gen-btn{margin-left:6px;font-size:11px;padding:2px 8px;border:1px solid var(--border);border-radius:12px;background:#f8fafc;color:var(--text-muted);cursor:pointer;font-family:inherit;font-weight:600;transition:background .15s,color .15s;vertical-align:middle}.lpe-gen-btn:hover{background:#eff6ff;color:var(--primary);border-color:#bfdbfe}.lpe-word-chips{display:flex;flex-wrap:wrap;gap:6px;padding:8px 0;min-height:40px}.lpe-word-chip{display:inline-flex;align-items:center;background:#f1f5f9;border:1.5px solid var(--border);border-radius:6px;padding:4px 10px;font-size:13px;font-weight:500;color:var(--text);cursor:pointer;transition:background .15s,border-color .15s}.lpe-word-chip:hover{background:#fee2e2;border-color:#fca5a5}.lpe-word-chip--error{background:#fee2e2;border-color:#ef4444;color:#b91c1c;font-weight:700;text-decoration:line-through}.lpe-wor-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}.lpe-wor-list{display:flex;flex-direction:column;gap:4px}.lpe-wor-list--optional{opacity:.6}.lpe-wor-list--optional:has(.lpe-wor-optional-toggle:checked){opacity:1}.lpe-wor-optional-toggle{margin-right:4px;cursor:pointer;accent-color:var(--primary)}.lpe-wor-list-label{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center}.lpe-wor-startat{display:flex;flex-direction:column;gap:3px;margin-top:4px}.lpe-wor-startat--only{margin-top:6px;padding:8px;background:#fffbeb;border:1px solid #FDE68A;border-radius:6px}.lpe-startat-label{font-size:10.5px;font-weight:600;color:#d97706;text-transform:uppercase;letter-spacing:.05em}.lpe-spell-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.lpe-spell-list{display:flex;flex-direction:column;gap:4px}.lpe-sentence-criteria{padding-top:8px;border-top:1px solid var(--border)}.lpe-rw-markup-area{margin-top:8px;padding:8px 10px;background:#fffbeb;border:1px solid #FDE68A;border-radius:6px}.lpe-rw-markup-hint{font-size:11px;font-weight:600;color:#92400e;margin-bottom:6px}.lpe-rw-markup-hint--dim{font-weight:400;font-style:italic;color:#b45309}.lpe-rw-first-missed-note{margin-top:6px;padding:4px 8px;background:#fef2f2;border:1px solid #FECACA;border-radius:4px;font-size:11.5px;color:#991b1b}.lpe-rw-errors-summary{margin-top:4px;padding:4px 8px;background:#fef2f2;border:1px solid #FECACA;border-radius:4px;font-size:11.5px;color:#7f1d1d}.lpe-rw-script{display:flex;flex-direction:column;gap:6px;background:#fff7ed;border:1px solid #FED7AA;border-radius:8px;padding:12px 14px}.lpe-script-step{display:flex;align-items:flex-start;gap:8px;font-size:12.5px;color:var(--text);line-height:1.5}.lpe-script-role{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;border-radius:50%;background:#ea580c;color:#fff;font-size:11px;font-weight:800;flex-shrink:0;margin-top:1px}.lpe-rw-word{font-size:15px;font-weight:800;color:#b91c1c;letter-spacing:.5px}.lpe-script-check .lpe-script-role{background:#059669}.lpe-manual-note{font-size:12px;color:#4a3500;background:#fff9c4;border-left:4px solid #F9A825;border-radius:6px;padding:12px;margin-bottom:8px;line-height:1.55}.lpe-pa-level-badge{display:inline-flex;align-items:center;background:#eff6ff;border:1px solid #BFDBFE;border-radius:20px;padding:3px 12px;font-size:11.5px;font-weight:700;color:#0a6e64;letter-spacing:.03em}.lpe-word-chip-wrap{display:flex;flex-direction:column;gap:3px;align-items:flex-start}.lpe-student-said{width:100px;padding:3px 7px;border:1.5px solid #EF4444;border-radius:5px;font-size:11.5px;font-family:inherit;color:#b91c1c;background:#fef2f2;outline:none;font-style:italic}.lpe-student-said::placeholder{color:#fca5a5}.lpe-student-said:focus{border-color:#dc2626;box-shadow:0 0 0 2px #ef444426}.lpe-inline-btn{background:none;border:none;color:var(--primary);cursor:pointer;padding:0;font-size:inherit;font-weight:600;text-decoration:underline}.lpe-passage-error-note{font-size:11.5px;color:#9f1239;font-style:italic;padding:4px 0}.btn{display:inline-flex;align-items:center;gap:6px;font-size:13.5px;font-weight:600;padding:7px 16px;border-radius:var(--radius);border:none;cursor:pointer;transition:background .15s,opacity .15s;font-family:inherit}.btn-secondary{background:var(--bg);border:1.5px solid var(--border);color:var(--text)}.btn-secondary:hover{background:#e5e7eb}.btn-danger{background:#dc2626;border:1.5px solid #B91C1C;color:#fff}.btn-danger:hover{background:#b91c1c}.btn-danger-outline{background:transparent;border:1.5px solid #EF4444;color:#dc2626;font-size:13px;padding:6px 14px;border-radius:var(--radius);cursor:pointer;font-weight:600;transition:background .15s,color .15s}.btn-danger-outline:hover{background:#fef2f2;color:#b91c1c}.lpe-spell-backup{margin-top:6px;padding:6px 8px;background:#f0fdf4;border:1px solid #BBF7D0;border-radius:6px}.lpe-spell-backup-label{font-size:10px;font-weight:700;color:#059669;text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}.lpe-redword-repeat-note{margin-top:6px;font-size:11px;color:#059669;font-weight:600;padding:4px 8px;background:#d1fae5;border-radius:5px}.lpe-sentence-gen-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px;gap:8px}.lpe-sentence-gen-hint{font-size:11px;color:var(--text-muted);font-style:italic}.lpe-accuracy-badge{display:inline-flex;align-items:center;margin-top:6px;padding:3px 9px;border-radius:4px;font-size:11.5px;font-weight:600;letter-spacing:.01em}.lpe-acc--high{background:#d1fae5;color:#065f46}.lpe-acc--mid{background:#fef3c7;color:#92400e}.lpe-acc--low{background:#fee2e2;color:#991b1b}.lpe-word-chip--used{background:#d1fae5;border-color:#10b981;color:#065f46}.lpe-spell-backup-hint{font-size:10.5px;font-weight:400;color:var(--text-muted);margin-left:4px}.lpe-sentence-markup{display:flex;flex-wrap:wrap;gap:5px;padding:8px 10px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);min-height:38px;align-items:center}.lpe-sent-word-group{display:inline-flex;align-items:center;gap:3px}.lpe-sent-word-chip{padding:3px 8px;border:1px solid var(--border);border-radius:4px;background:var(--surface);cursor:pointer;font-size:13px;color:var(--text);font-family:inherit;transition:background .12s,border-color .12s}.lpe-sent-word-chip:hover{background:#e0e7ff;border-color:var(--primary)}.lpe-sent-word-chip--error{background:#fee2e2;border-color:#ef4444;color:#991b1b}.lpe-student-said--sentence{width:72px;font-size:11px}.lpe-new-learning-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px}.lpe-new-red-word-row{display:flex;align-items:center;gap:8px}.lpe-new-red-word-row .lpe-input{flex:1}.lpe-reflection-check{display:flex;align-items:center;gap:6px;margin-top:10px;font-size:13px;font-weight:600;color:var(--text);cursor:pointer;-webkit-user-select:none;user-select:none}.lpe-reflection-check input[type=checkbox]{width:16px;height:16px;cursor:pointer}.lpe-student-reading-page{display:none}.lpe-pleasure-reading{padding-top:10px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:7px}.lpe-visual-card-page,.lpe-student-print{display:none}@media print{.no-print,.lpe-topbar,.lpe-time-bar,.lpe-autopop-banner,.lpe-error-suggestion,.lpe-markup-banner{display:none!important}body{background:#fff;font-size:10pt}.lpe-page{max-width:100%;padding:0}.lpe-plan-header{box-shadow:none;border:1px solid #ddd;break-inside:avoid;margin-bottom:10px}.lpe-columns{display:block;gap:0}.lpe-col{width:100%}.lpe-col--review{break-after:page}.lpe-wor-grid{grid-template-columns:repeat(5,1fr)}.lpe-spell-grid{grid-template-columns:repeat(3,1fr)}.lpe-wor-list--optional{display:none}.lpe-wor-list--optional:has(.lpe-wor-optional-toggle:checked){display:flex}.lpe-col-header{-webkit-print-color-adjust:exact;print-color-adjust:exact}.lpe-section{box-shadow:none;break-inside:auto;border:1px solid #ddd;margin-bottom:6px}.lpe-section-header{break-after:avoid}.lpe-section-body{padding:8px 10px;gap:6px}.lpe-field{gap:2px;margin-bottom:4px}.lpe-subsection{padding-top:6px;gap:5px}.lpe-wor-grid,.lpe-spell-grid{gap:6px}.skill-selector-dropdown,.lpe-gen-btn,.lpe-sync-btn,.lpe-wor-optional-toggle{display:none!important}.lpe-section--blue{border-top:2px solid #0E8A7D;-webkit-print-color-adjust:exact;print-color-adjust:exact}.lpe-section--purple{border-top:2px solid #7C3AED;-webkit-print-color-adjust:exact;print-color-adjust:exact}.lpe-chip-add-btn,.lpe-chip-x,.lpe-chip-add-row,.lpe-chip-drag-handle{display:none!important}.lpe-chip{background:#eff6ff;border:1px solid #BFDBFE;-webkit-print-color-adjust:exact;print-color-adjust:exact}.lpe-word-chip--error{background:#fee2e2;border-color:#ef4444;-webkit-print-color-adjust:exact;print-color-adjust:exact}.lpe-input{border:1px solid #ddd;background:transparent;resize:none}.lpe-rw-script{background:#fff7ed;border:1px solid #FED7AA;-webkit-print-color-adjust:exact;print-color-adjust:exact}.lpe-student-reading-page{display:block!important;break-before:page;padding:20mm 16mm;font-family:inherit}.student-reading-passage{font-size:16pt;color:#111;line-height:2.2;white-space:pre-wrap;padding:16px;border:1px solid #ddd;border-radius:6px;margin-top:16px;-webkit-print-color-adjust:exact;print-color-adjust:exact}.student-print-section--teacher{background:#fffde7;border:1px solid #FDD835;border-left:4px solid #F9A825;border-radius:6px;padding:10px 12px;-webkit-print-color-adjust:exact;print-color-adjust:exact}.student-print-teacher-prompt{font-size:11pt;font-style:italic;color:#7c5e00;margin-bottom:8px;font-weight:600}.student-print-section--auditory{break-before:column;column-span:all;margin-top:16pt}.student-print-auditory-grid{display:flex;flex-wrap:wrap;gap:10pt 16pt;margin-top:8pt}.student-print-word--auditory{display:inline-block;font-size:36pt;font-weight:900;color:#1e3a5f;letter-spacing:2pt;line-height:1.2;-webkit-print-color-adjust:exact;print-color-adjust:exact}.student-print-word--nl{font-size:20pt;font-weight:700}.student-print-word--kinesthetic{font-size:28pt;font-weight:800;color:#1e3a5f}.lpe-student-print{display:block!important;break-before:page;padding:20mm 16mm;font-family:inherit}.student-print-header{text-align:center;border-bottom:2px solid #333;padding-bottom:12px;margin-bottom:20px}.student-print-header h1{font-size:16pt;font-weight:800;margin:0 0 4px;color:#111}.student-print-header h2{font-size:13pt;font-weight:600;margin:0;color:#444}.student-print-page-break{break-after:avoid}.student-print-section{break-inside:avoid;margin-bottom:18px}.student-print-section-title{font-size:12pt;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:#0a6e64;border-bottom:1.5px solid #BFDBFE;padding-bottom:4px;margin-bottom:10px;-webkit-print-color-adjust:exact;print-color-adjust:exact}.student-print-section{break-inside:avoid;margin-bottom:16px}.student-print-words{display:flex;flex-direction:column;gap:3px;padding:2px 0}.student-print-word{display:block;font-size:16pt;font-weight:600;color:#111;padding:2px 0;line-height:1.5}.student-word-error{color:#b91c1c;text-decoration:line-through;-webkit-print-color-adjust:exact;print-color-adjust:exact}.student-print-sentence{font-size:14pt;color:#111;margin-bottom:14px;line-height:1.8;border-bottom:1px dashed #ccc;padding-bottom:10px}.student-print-sentence--nl{font-size:20pt;font-weight:600;line-height:2;margin-bottom:18px;padding-bottom:12px}.student-print-passage{font-size:13pt;color:#111;line-height:1.9;white-space:pre-wrap;padding:12px;border:1px solid #ddd;border-radius:6px}.student-print-redword{font-size:48pt;font-weight:900;color:#b91c1c;text-align:center;padding:20px;letter-spacing:4px;-webkit-print-color-adjust:exact;print-color-adjust:exact}.lpe-display-text,.lpe-display-text--objective,.lpe-display-text--template,.lpe-display-text--prompt{background:transparent;border:1px solid #ddd}.lpe-note,.lpe-display-text--method,.lpe-steps-list{background:#e3f2fd;border-left:4px solid #1565C0;color:#0d47a1;-webkit-print-color-adjust:exact;print-color-adjust:exact}.lpe-teacher-script{background:#e8f5e9;border-left:4px solid #2E7D32;color:#1b5e20;-webkit-print-color-adjust:exact;print-color-adjust:exact}.lpe-manual-note{background:#fff9c4;border-left:4px solid #F9A825;color:#4a3500;-webkit-print-color-adjust:exact;print-color-adjust:exact}.lpe-pa-level-badge{background:#eff6ff;border:1px solid #BFDBFE;-webkit-print-color-adjust:exact;print-color-adjust:exact}.lpe-passage-error-note{display:none!important}.student-word-said{font-size:10pt;color:#b91c1c;font-style:italic;-webkit-print-color-adjust:exact;print-color-adjust:exact}}.response-sheet{display:none}@media print{.response-sheet{display:block;break-before:page;padding:8mm 12mm;font-family:inherit;font-size:10pt}.rs-header{border-bottom:2px solid #111;padding-bottom:6px;margin-bottom:10px}.rs-title{font-size:13pt;font-weight:800;text-align:center;margin-bottom:6px;color:#111}.rs-name-date-row{display:flex;align-items:center;gap:10px}.rs-label{font-size:10pt;font-weight:700;white-space:nowrap}.rs-blank-line{border-bottom:1.5px solid #333;flex:1;height:16pt;display:inline-block}.rs-blank-line--long{min-width:180pt}.rs-blank-line--short{min-width:90pt}.rs-blank-line--sound{min-width:40pt;height:14pt}.rs-section{margin-bottom:7px}.rs-section--no-break-after{break-after:avoid}.rs-section-title{font-size:10pt;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:#0a6e64;border-bottom:1.5px solid #BFDBFE;padding-bottom:2px;margin-bottom:5px;break-after:avoid;-webkit-print-color-adjust:exact;print-color-adjust:exact}.rs-sounds-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:5px 12px}.rs-lines{display:flex;flex-direction:column;gap:3px}.rs-lines--numbered{gap:4px}.rs-lines--wide .rs-blank-line{min-width:100%}.rs-line-row{display:flex;align-items:flex-end;gap:6px}.rs-num{font-size:9pt;font-weight:700;min-width:18pt;text-align:right;color:#555;flex-shrink:0}.rs-line-row .rs-blank-line{flex:1}.lpe-visual-card-page{display:flex!important;flex-direction:column;align-items:center;break-before:page;padding:20mm 16mm;min-height:60vh}}.lpe-rw-wordlist{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0;padding:8px;background:var(--bg);border-radius:var(--radius);border:1px solid var(--border)}.lpe-rw-wordlist-chip{display:inline-block;padding:3px 10px;background:#fff;border:1px solid var(--border);border-radius:6px;font-size:13px;font-weight:500;color:var(--text)}.lpe-rw-missed-section{margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}.lpe-rw-missed-label{font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:8px;display:flex;align-items:center;gap:4px;flex-wrap:wrap}.lpe-rw-missed-inputs{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.lpe-rw-missed-input-row{display:flex;align-items:center;gap:6px}.lpe-rw-missed-num{font-size:12px;font-weight:600;color:var(--text-muted);min-width:16px}.lpe-rw-missed-input{flex:1;font-size:13px;padding:5px 8px;height:30px}.lpe-rw-missed-note{font-size:11.5px;border-radius:5px;padding:5px 9px;line-height:1.4}.lpe-rw-missed-note--warn{background:#fef9c3;color:#854d0e;border:1px solid #FDE047}.lpe-rw-missed-note--ok{background:#f0fdf4;color:#166534;border:1px solid #BBF7D0}.lpe-delete-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000}.lpe-delete-modal{background:#fff;border-radius:14px;padding:28px 32px 24px;max-width:440px;width:calc(100% - 32px);box-shadow:0 8px 40px #0003;display:flex;flex-direction:column;gap:10px}.lpe-delete-modal-icon{font-size:28px;line-height:1;color:#dc2626}.lpe-delete-modal-title{font-size:18px;font-weight:700;color:var(--text);margin:0}.lpe-delete-modal-body{font-size:14px;color:var(--text);margin:0}.lpe-delete-modal-list{margin:0;padding-left:20px;font-size:13.5px;color:var(--text);display:flex;flex-direction:column;gap:4px}.lpe-delete-modal-warning{font-size:13px;color:var(--text-muted);background:#fff7ed;border:1px solid #FED7AA;border-radius:6px;padding:8px 12px;margin:2px 0 0}.lpe-delete-modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:6px}.lpe-publish-modal{background:#fff;border-radius:14px;padding:28px 32px 24px;max-width:480px;width:calc(100% - 32px);box-shadow:0 8px 40px #0003;display:flex;flex-direction:column;gap:12px}.lpe-publish-modal-title{font-size:18px;font-weight:700;color:var(--text);margin:0}.lpe-publish-modal-desc{font-size:14px;color:var(--text-muted);margin:0}.lpe-publish-checks{display:flex;flex-direction:column;gap:6px;padding:10px 0}.lpe-publish-check-row{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--text);cursor:pointer;padding:4px 0}.lpe-publish-check-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.lpe-publish-notes{display:flex;flex-direction:column;gap:6px}.lpe-publish-notes-label{font-size:13px;font-weight:600;color:var(--text)}.lpe-publish-notes-input{width:100%;border:1px solid var(--border);border-radius:8px;padding:10px 12px;font-size:14px;font-family:inherit;resize:vertical;min-height:60px;color:var(--text)}.lpe-publish-notes-input::placeholder{color:var(--text-muted)}.lpe-publish-notes-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.lpe-wor-list-sublabel{font-size:11px;color:var(--text-muted);font-style:italic;margin-top:4px;display:block}.lp-global-empty{text-align:center;padding:48px 24px;color:var(--text-muted);background:var(--surface);border:1.5px dashed var(--border);border-radius:12px;display:flex;flex-direction:column;align-items:center}.lp-global-list{display:flex;flex-direction:column;gap:8px}.lp-global-card{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;color:var(--text);box-shadow:var(--shadow);transition:border-color .15s,box-shadow .15s,transform .1s}.lp-global-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translate(2px)}.lp-global-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0}.lp-global-body{flex:1}.lp-global-student{font-size:11.5px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px}.lp-global-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px}.lp-global-meta{display:flex;gap:12px}.lp-global-meta span{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-muted)}.lp-status{font-size:11px;font-weight:600;padding:3px 9px;border-radius:99px;flex-shrink:0}.lp-status-completed{background:#ecfdf5;color:#059669}.lp-status-draft{background:#fffbeb;color:#d97706}.lp-status-active{background:var(--primary-light);color:var(--primary)}.lp-global-card>svg:last-child{color:var(--text-light);flex-shrink:0}.tr-page{padding:0 24px 48px;max-width:1200px;margin:0 auto}.tr-folder-grid{display:flex;flex-direction:column;gap:12px}.tr-folder{display:flex;align-items:center;gap:16px;width:100%;padding:20px 24px;background:var(--surface, #fff);border:1px solid var(--border, #E2E8F0);border-radius:var(--radius, 10px);cursor:pointer;text-align:left;transition:all .15s}.tr-folder:hover:not(.tr-folder--disabled){border-color:var(--primary, #0E8A7D);box-shadow:0 2px 12px #3b82f61a}.tr-folder--disabled{opacity:.55;cursor:default}.tr-folder-icon{flex-shrink:0;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--bg, #F8FAFC);border-radius:12px;color:var(--primary, #0E8A7D)}.tr-folder--disabled .tr-folder-icon{color:var(--text-muted, #94A3B8)}.tr-folder-text{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}.tr-folder-label{font-size:16px;font-weight:700;color:var(--text, #1a1a1a)}.tr-folder-desc{font-size:13px;color:var(--text-muted, #94A3B8);line-height:1.4}.tr-folder-meta{flex-shrink:0;display:flex;align-items:center;gap:8px;color:var(--text-muted, #94A3B8)}.tr-folder-badge{font-size:12px;font-weight:600;padding:4px 10px;border-radius:12px;background:var(--bg, #F8FAFC);color:var(--text-muted, #94A3B8)}.tr-folder-badge--soon{background:#fff7ed;color:#c2410c}.tr-back-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;margin-bottom:16px;font-size:13px;font-weight:600;color:var(--primary, #0E8A7D);background:none;border:none;border-radius:var(--radius, 10px);cursor:pointer;transition:background .15s}.tr-back-btn:hover{background:var(--bg, #F8FAFC)}.tr-print-all-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:600;color:#fff;background:var(--primary, #0E8A7D);border:none;border-radius:var(--radius, 10px);cursor:pointer;transition:background .15s}.tr-print-all-btn:hover{background:var(--primary-dark, #0A6E64)}.tr-search-bar{position:relative;margin-bottom:16px}.tr-search-input{width:100%;padding:10px 40px 10px 14px;font-size:14px;border:1px solid var(--border, #E2E8F0);border-radius:var(--radius, 10px);background:var(--surface, #fff);color:var(--text, #1a1a1a);outline:none;transition:border-color .15s}.tr-search-input:focus{border-color:var(--primary, #0E8A7D)}.tr-search-input::placeholder{color:var(--text-muted, #94A3B8)}.tr-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:20px;color:var(--text-muted, #94A3B8);cursor:pointer;padding:4px 8px;line-height:1}.tr-category-pills{display:flex;gap:8px;overflow-x:auto;padding-bottom:8px;margin-bottom:24px;scrollbar-width:thin}.tr-category-pills::-webkit-scrollbar{height:4px}.tr-category-pills::-webkit-scrollbar-thumb{background:var(--border, #E2E8F0);border-radius:2px}.tr-pill{flex-shrink:0;padding:6px 14px;font-size:13px;font-weight:500;border:1px solid var(--border, #E2E8F0);border-radius:20px;background:var(--surface, #fff);color:var(--text, #1a1a1a);cursor:pointer;white-space:nowrap;transition:all .15s}.tr-pill:hover{background:var(--bg, #F8FAFC)}.tr-pill--active{background:var(--primary, #0E8A7D);color:#fff;border-color:var(--primary, #0E8A7D)}.tr-pill--active:hover{background:var(--primary-dark, #0A6E64)}.tr-card-sections{display:flex;flex-direction:column;gap:32px}.tr-section-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.tr-section-title{font-size:18px;font-weight:700;color:var(--text, #1a1a1a);margin:0}.tr-section-count{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 8px;font-size:12px;font-weight:600;color:var(--text-muted, #94A3B8);background:var(--bg, #F8FAFC);border-radius:12px}.tr-card-grid{display:flex;flex-wrap:wrap;gap:12px}.tr-no-results{text-align:center;color:var(--text-muted, #94A3B8);font-size:15px;padding:40px 0}.tr-modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.tr-modal{position:relative;background:#fff;border-radius:16px;padding:32px 28px 24px;display:flex;flex-direction:column;align-items:center;gap:20px;max-width:360px;width:100%;box-shadow:0 20px 60px #0003}.tr-modal-close{position:absolute;top:10px;right:14px;background:none;border:none;font-size:26px;color:var(--text-muted, #94A3B8);cursor:pointer;line-height:1;padding:4px}.tr-modal-close:hover{color:var(--text, #1a1a1a)}.tr-modal-print{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;font-size:14px;font-weight:600;color:#fff;background:var(--primary, #0E8A7D);border:none;border-radius:var(--radius, 10px);cursor:pointer;transition:background .15s}.tr-modal-print:hover{background:var(--primary-dark, #0A6E64)}.tr-mat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-top:8px}.tr-mat-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 12px 14px;background:var(--surface, #fff);border:1px solid var(--border, #E2E8F0);border-radius:var(--radius, 10px);cursor:pointer;text-align:center;transition:all .15s}.tr-mat-card:hover{border-color:var(--primary, #0E8A7D);box-shadow:0 2px 12px #3b82f61a}.tr-mat-thumb{width:160px;height:110px}.tr-mat-thumb svg{width:100%;height:100%}.tr-mat-label{font-size:14px;font-weight:700;color:var(--text, #1a1a1a)}.tr-mat-desc{font-size:12px;color:var(--text-muted, #94A3B8);line-height:1.4}.tr-modal--mat{max-width:500px}.tr-mat-preview{width:400px;max-width:100%;height:280px}.tr-mat-preview svg{width:100%;height:100%}.tr-mat-modal-label{font-size:20px;font-weight:700;color:var(--text, #1a1a1a);margin:0}.tr-mat-modal-desc{font-size:14px;color:var(--text-muted, #94A3B8);margin:0;text-align:center;line-height:1.4}.tr-passage-grid{display:flex;flex-direction:column;gap:10px}.tr-passage-skill{display:flex;align-items:center;gap:14px;padding:8px 0}.tr-passage-skill-label{flex-shrink:0;width:80px;font-size:16px;font-weight:700;color:var(--text, #1a1a1a)}.tr-passage-skill-sound{font-size:12px;font-weight:400;color:var(--text-muted, #94A3B8)}.tr-passage-pair{display:flex;gap:10px;flex:1;min-width:0}.tr-passage-card{flex:1;display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--surface, #fff);border:1px solid var(--border, #E2E8F0);border-radius:var(--radius, 10px);cursor:pointer;text-align:left;transition:all .15s;min-width:0}.tr-passage-card:hover{border-color:var(--primary, #0E8A7D);box-shadow:0 2px 8px #3b82f61a}.tr-passage-level{flex-shrink:0;font-size:11px;font-weight:700;padding:3px 8px;border-radius:6px;text-transform:uppercase;letter-spacing:.5px}.tr-passage-level--1{background:#dbeafe;color:#0a6e64}.tr-passage-level--2{background:#fef3c7;color:#b45309}.tr-passage-title{font-size:14px;font-weight:500;color:var(--text, #1a1a1a);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tr-print-cat-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:600;color:var(--primary, #0E8A7D);background:none;border:1px solid var(--border, #E2E8F0);border-radius:6px;cursor:pointer;margin-left:auto;transition:all .15s}.tr-print-cat-btn:hover{background:var(--bg, #F8FAFC);border-color:var(--primary, #0E8A7D)}.tr-passage-reader{background:var(--surface, #fff);border:1px solid var(--border, #E2E8F0);border-radius:var(--radius, 10px);padding:32px 40px;max-width:720px}.tr-passage-para{font-family:Georgia,Times New Roman,serif;font-size:20px;line-height:2;color:var(--text, #1a1a1a);text-indent:28px;margin:0 0 8px}.tr-passage-para:first-child{text-indent:0}.tr-passage-questions{max-width:720px;margin-top:24px;padding:20px 24px;background:#f8fafc;border:1px solid var(--border, #E2E8F0);border-radius:var(--radius, 10px)}.tr-passage-q-heading{font-size:16px;font-weight:700;color:var(--text, #1a1a1a);margin:0 0 12px}.tr-passage-q{font-size:15px;line-height:1.6;color:var(--text, #1a1a1a);margin-bottom:8px}.tr-passage-q:last-child{margin-bottom:0}.tr-passage-q-label{font-weight:700;color:var(--primary, #0E8A7D)}.tr-nwf-preview{max-width:720px;overflow-x:auto}.tr-nwf-table{border-collapse:collapse;width:100%;background:var(--surface, #fff);border:1px solid var(--border, #E2E8F0);border-radius:var(--radius, 10px)}.tr-nwf-cell{font-family:Times New Roman,Georgia,serif;font-size:22px;font-style:italic;padding:10px 20px;text-align:center;border-bottom:1px solid #f0f0f0;color:var(--text, #1a1a1a)}.tr-nwf-table tr:last-child .tr-nwf-cell{border-bottom:none}.tr-nwf-arrow{font-style:normal;font-size:14px;color:#666;margin-right:4px}.tr-orf-copy-toggle{display:flex;gap:8px;margin-bottom:20px}.tr-orf-teacher{background:var(--surface, #fff);border:1px solid var(--border, #E2E8F0);border-radius:var(--radius, 10px);padding:28px 32px;max-width:720px}.tr-orf-line{display:flex;align-items:baseline;margin-bottom:2px}.tr-orf-text{flex:1;font-family:Times New Roman,Georgia,serif;font-size:18px;line-height:2;color:var(--text, #1a1a1a)}.tr-orf-wc{flex-shrink:0;width:40px;text-align:right;font-size:12px;font-weight:700;color:var(--text-muted, #94A3B8);font-family:Arial,sans-serif}.tr-orf-wc-badge{flex-shrink:0;font-size:11px;font-weight:600;padding:2px 8px;border-radius:8px;background:#f1f5f9;color:var(--text-muted, #94A3B8);margin-left:auto}.tr-norms-wrap{max-width:600px}.tr-norms-table{width:100%;border-collapse:collapse;background:var(--surface, #fff);border:1px solid var(--border, #E2E8F0);border-radius:var(--radius, 10px);overflow:hidden}.tr-norms-table thead tr{background:#1e3a5f}.tr-norms-table th{padding:10px 14px;font-size:13px;font-weight:600;color:#fff;text-align:center}.tr-norms-table td{padding:8px 14px;font-size:14px;text-align:center;border-bottom:1px solid #f0f0f0;color:var(--text, #1a1a1a)}.tr-norms-grade{font-weight:700;background:#f8fafc;border-right:2px solid #CBD5E1}.tr-norms-p50 td{background:#dbeafe;font-weight:700}.tr-norms-citation{margin-top:14px;font-size:12px;color:var(--text-muted, #94A3B8);font-style:italic;line-height:1.5}.tr-print-grid{display:none}@media print{.tr-page>*:not(.tr-print-grid){display:none!important}.tr-modal-overlay,.tr-folder-grid{display:none!important}.tr-print-grid{display:flex!important;flex-wrap:wrap;justify-content:center;gap:.15in;padding:0}}.assess-loading{padding:40px;color:var(--text-muted);text-align:center}.assess-page{display:flex;flex-direction:column;gap:20px;max-width:900px}.assess-topbar{display:flex;align-items:flex-start;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;box-shadow:var(--shadow);flex-wrap:wrap}.assess-back{display:flex;align-items:center;gap:4px;font-size:13px;color:var(--primary);background:none;border:none;cursor:pointer;padding:4px 0;font-weight:600;white-space:nowrap}.assess-back:hover{text-decoration:underline}.assess-title-block{flex:1;min-width:200px}.assess-title{font-size:18px;font-weight:700;color:var(--text);margin:0 0 2px}.assess-subtitle{font-size:12.5px;color:var(--text-muted)}.assess-topbar-actions{display:flex;gap:10px;align-items:center;flex-shrink:0}.assess-progress-bar{height:10px;background:var(--border);border-radius:99px;overflow:hidden;position:relative}.assess-progress-inner{height:100%;background:var(--success);border-radius:99px;transition:width .3s ease}.assess-progress-label{position:absolute;right:0;top:-20px;font-size:12px;color:var(--text-muted)}.assess-legend{display:flex;gap:8px;flex-wrap:wrap}.assess-legend-item{font-size:11.5px;font-weight:600;padding:4px 10px;border-radius:99px;border:1px solid currentColor}.assess-categories{display:flex;flex-direction:column;gap:20px}.assess-category{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}.assess-cat-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:0 0 14px}.assess-skill-grid{display:flex;flex-wrap:wrap;gap:8px}.assess-skill-tile{display:flex;flex-direction:column;align-items:center;gap:2px;padding:10px 14px;border:2px solid;border-radius:8px;cursor:pointer;min-width:60px;transition:transform .1s,box-shadow .1s;background:var(--bg)}.assess-skill-tile:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.assess-skill-label{font-size:16px;font-weight:700;color:var(--text);font-family:Georgia,serif}.assess-skill-sound{font-size:10px;color:var(--text-muted)}.assess-skill-status{font-size:10px;font-weight:700;margin-top:2px}.assess-bottom-actions{display:flex;justify-content:flex-end;gap:12px;padding:8px 0}.btn-success{background:var(--success);color:#fff;border:1px solid var(--success)}.pa-level-progress{display:flex;gap:8px;align-items:center;padding:12px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-wrap:wrap}.pa-level-dot{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;background:var(--border);color:var(--text-muted);border:2px solid transparent}.pa-dot-auto{background:#059669;color:#fff;border-color:#059669}.pa-dot-notauto{background:#fffbeb;color:#d97706;border-color:#d97706}.pa-dot-pass{background:#ecfdf5;color:#059669;border-color:#059669}.pa-dot-fail{background:#fef2f2;color:#dc2626;border-color:#dc2626}.pa-dot-active{background:var(--primary-light);color:var(--primary);border-color:var(--primary)}.pa-dot-discontinued{background:#f1f5f9;color:#94a3b8;border-color:#cbd5e1}.pa-level-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.pa-level-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:14px}.pa-level-badge{background:var(--primary);color:#fff;font-size:12px;font-weight:700;padding:4px 10px;border-radius:99px;flex-shrink:0}.pa-level-name{font-size:18px;font-weight:700;color:var(--text);margin:0;flex:1}.pa-pass-threshold{font-size:12.5px;color:var(--text-muted);font-weight:600;flex-shrink:0}.pa-instruction-box{margin:20px 24px;background:#eff6ff;border:1px solid #BFDBFE;border-radius:8px;padding:14px 16px;font-size:13.5px;color:#0a6e64;line-height:1.5}.pa-tasks{display:flex;flex-direction:column;gap:0;padding:0 24px 24px}.pa-task{display:flex;align-items:center;gap:16px;padding:14px 16px;border:1.5px solid var(--border);border-radius:8px;margin-bottom:8px;transition:background .15s,border-color .15s;flex-wrap:wrap}.pa-task-pass{background:#ecfdf5;border-color:#6ee7b7}.pa-task-fail{background:#fef2f2;border-color:#fecaca}.pa-task-prompt{font-size:14px;font-weight:600;color:var(--text);flex:1;min-width:150px}.pa-task-expected{font-size:12.5px;color:var(--text-muted);display:flex;gap:8px;align-items:center;flex-wrap:wrap}.pa-task-label{font-weight:700;color:var(--text)}.pa-task-example{font-style:italic;opacity:.7}.pa-task-buttons{display:flex;gap:8px;flex-shrink:0}.pa-btn-auto,.pa-btn-correct,.pa-btn-incorrect{padding:6px 14px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;border:2px solid;transition:all .1s;background:var(--surface)}.pa-btn-auto{border-color:#d97706;color:#d97706}.pa-btn-correct{border-color:#059669;color:#059669}.pa-btn-incorrect{border-color:#dc2626;color:#dc2626}.pa-btn-auto.pa-btn-active{background:#d97706;color:#fff}.pa-btn-correct.pa-btn-active{background:#059669;color:#fff}.pa-btn-incorrect.pa-btn-active{background:#dc2626;color:#fff}.pa-level-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.pa-answered{font-size:13px;color:var(--text-muted);font-weight:600}.pa-complete-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:48px 32px;text-align:center;box-shadow:var(--shadow)}.pa-complete-icon{width:64px;height:64px;border-radius:50%;background:#ecfdf5;color:#059669;font-size:28px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.pa-complete-card h2{margin:0 0 8px;font-size:22px;color:var(--text)}.pa-complete-card p{color:var(--text-muted);margin:0 0 24px}.pa-complete-actions{display:flex;justify-content:center;gap:12px}.pa-instruction-note{background:#fffbeb;border:1px solid #FCD34D;border-radius:8px;padding:10px 18px;font-size:13.5px;color:#92400e;text-align:center;line-height:1.5}.rw-done-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.rw-stats-bar{display:flex;gap:12px;flex-wrap:wrap;align-items:center;padding:12px 20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.rw-stat{font-size:13px;font-weight:600;padding:4px 12px;border-radius:99px;background:var(--bg);color:var(--text-muted)}.rw-stat-correct{background:#ecfdf5;color:#059669}.rw-stat-error,.rw-stat-streak--warn{background:#fef2f2;color:#dc2626}.rw-word-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:48px 32px;text-align:center;box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:center;gap:20px}.rw-word-number{font-size:12.5px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.rw-word-display{font-size:56px;font-weight:800;color:var(--text);font-family:Georgia,serif;letter-spacing:.02em}.rw-word-student-view{font-size:72px;color:var(--primary)}.rw-word-instruction{font-size:14px;color:var(--text-muted);max-width:400px}.rw-trail{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;max-height:150px;overflow-y:auto}.rw-trail-label{width:100%;text-align:center;font-size:11px;color:#94a3b8;margin-bottom:2px}.rw-trail-word{font-size:13px;padding:4px 10px;border-radius:99px;font-weight:600;border:none;cursor:pointer;transition:opacity .15s,transform .1s}.rw-trail-word:hover{opacity:.75;transform:scale(1.06)}.rw-trail-correct{background:#ecfdf5;color:#059669}.rw-trail-error{background:#fef2f2;color:#dc2626}.rw-mark-buttons{display:flex;gap:20px}.rw-btn-correct,.rw-btn-error{padding:14px 36px;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;border:3px solid;transition:all .1s}.rw-btn-correct{border-color:#059669;color:#059669;background:#ecfdf5}.rw-btn-correct:hover{background:#059669;color:#fff}.rw-btn-error{border-color:#dc2626;color:#dc2626;background:#fef2f2}.rw-btn-error:hover{background:#dc2626;color:#fff}.rw-stop-row{margin-top:8px}.rw-btn-stop{background:none;border:none;color:var(--text-muted);font-size:12.5px;cursor:pointer;text-decoration:underline}.rw-done-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:48px 32px;text-align:center;box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:center;gap:16px}.rw-done-icon{font-size:48px}.rw-done-card h2{font-size:22px;color:var(--text);margin:0}.rw-done-card p{color:var(--text-muted);margin:0}.rw-first-missed{background:#fef3c7;border:1px solid #FCD34D;border-radius:8px;padding:14px 20px;font-size:14px;color:#92400e;line-height:1.6}.rw-next-lesson-note{font-size:12.5px;color:#d97706;font-style:italic}.rw-summary{display:flex;gap:24px;font-size:15px}.rw-summary-row{display:flex;gap:8px;align-items:center;color:var(--text-muted)}.rw-summary-row strong{color:var(--text);font-size:18px}.rw-list-picker{display:flex;flex-direction:column;gap:20px}.rw-list-picker-hint{font-size:14px;color:var(--text-muted);background:#eff6ff;border:1px solid #BFDBFE;border-radius:var(--radius);padding:12px 16px;line-height:1.6}.rw-list-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.rw-list-card{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);padding:16px;cursor:pointer;text-align:left;transition:border-color .15s,box-shadow .15s}.rw-list-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md)}.rw-list-card--selected{border-color:var(--primary);background:#eff6ff}.rw-list-card--mastered{border-color:#059669!important;background:#f0fdf4;opacity:.75;cursor:not-allowed}.rw-list-card--mastered:hover{border-color:#059669!important;box-shadow:none}.rw-list-mastered-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;color:#059669;background:#dcfce7;border-radius:99px;padding:2px 8px;margin-top:6px}.rw-list-card-num{font-size:15px;font-weight:700;color:var(--text);margin-bottom:4px}.rw-list-card-date{font-size:11px;color:var(--text-muted);margin-top:4px}.rw-list-card-range{font-size:12px;color:var(--text-muted);margin-bottom:6px}.rw-list-card-preview{font-size:12px;color:var(--text-muted);font-style:italic}.rw-list-start-btn{align-self:flex-start}.rw-done-list-label{font-size:14px;color:var(--text-muted);font-weight:600}.rw-mastery-note{font-size:14px;color:#059669;font-weight:600}@media print{.assess-topbar,.assess-legend,.assess-progress-bar,.assess-bottom-actions,.assess-skill-status{display:none!important}.assess-skill-tile{border:1.5px solid #ccc;background:#fff}}.ul-stepper{display:flex;gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:8px 12px;box-shadow:var(--shadow);overflow-x:auto}.ul-step{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 10px;border-radius:8px;border:1px solid transparent;background:none;cursor:pointer;flex:1;min-width:70px;transition:background .15s,border-color .15s}.ul-step:hover{background:var(--bg)}.ul-step--active{background:#eff6ff;border-color:var(--primary)}.ul-step--done{background:#ecfdf5;border-color:#a7f3d0}.ul-step-letter{font-size:16px;font-weight:800;color:var(--text-muted)}.ul-step--active .ul-step-letter{color:var(--primary)}.ul-step--done .ul-step-letter{color:#059669}.ul-step-title{font-size:9px;font-weight:600;color:var(--text-muted);text-align:center;line-height:1.2}.ul-step--active .ul-step-title{color:var(--primary)}.ul-section-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.ul-section-header{padding:16px 20px 12px;border-bottom:1px solid var(--border)}.ul-section-title{font-size:16px;font-weight:700;color:var(--text);margin:0 0 2px}.ul-section-subtitle{font-size:12.5px;color:var(--text-muted)}.ul-section-body{padding:16px 20px 20px}.ul-concept-grid{display:flex;flex-direction:column;gap:6px}.ul-concept-row{display:flex;align-items:center;gap:12px;padding:6px 10px;border-radius:6px;background:var(--bg)}.ul-concept-label{flex:1;font-size:13px;font-weight:500;color:var(--text);min-width:160px}.ul-concept-buttons{display:flex;gap:6px}.ul-concept-btn{padding:4px 12px;border-radius:6px;border:1px solid var(--border);background:var(--surface);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;color:var(--text-muted)}.ul-concept-btn:hover{border-color:var(--primary)}.ul-concept-btn--yes.ul-concept-btn--selected{background:#d1fae5;border-color:#059669;color:#065f46}.ul-concept-btn--no.ul-concept-btn--selected{background:#fee2e2;border-color:#dc2626;color:#991b1b}.ul-concept-btn--partial.ul-concept-btn--selected{background:#fef3c7;border-color:#d97706;color:#92400e}.ul-sound-grid{display:flex;flex-direction:column;gap:0}.ul-sound-header-row{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--bg);border-radius:6px 6px 0 0;border-bottom:1px solid var(--border)}.ul-sound-header-label{flex:1;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);min-width:140px}.ul-sound-header-col{width:100px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);text-align:center}.ul-sound-row{display:flex;align-items:center;gap:8px;padding:5px 10px;border-bottom:1px solid #f1f5f9}.ul-sound-row:last-child{border-bottom:none}.ul-sound-label{flex:1;font-size:13px;font-weight:500;color:var(--text);min-width:140px;display:flex;align-items:center;gap:8px}.ul-affix-type{font-size:10px;font-weight:600;color:var(--text-muted);background:#f1f5f9;border-radius:4px;padding:1px 6px}.ul-error-toggle{width:100px;padding:4px 8px;border-radius:6px;border:1px solid var(--border);background:var(--surface);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;color:var(--text-muted);text-align:center}.ul-error-toggle:hover{border-color:var(--text-muted);color:var(--text)}.ul-error-toggle--reading:hover{border-color:#dc2626;color:#dc2626}.ul-error-toggle--reading.ul-error-toggle--active{background:#fee2e2;border-color:#dc2626;color:#991b1b;font-weight:700}.ul-error-toggle--spelling:hover{border-color:#2563eb;color:#2563eb}.ul-error-toggle--spelling.ul-error-toggle--active{background:#dbeafe;border-color:#2563eb;color:#1e40af;font-weight:700}.ul-error-toggle--meaning:hover{border-color:#059669;color:#059669}.ul-error-toggle--meaning.ul-error-toggle--active{background:#d1fae5;border-color:#059669;color:#065f46;font-weight:700}.ul-word-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px}.ul-word-grid--rules{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.ul-word-tile{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 16px;border-radius:10px;border:2px solid var(--border);background:var(--surface);cursor:pointer;transition:all .15s}.ul-word-tile:hover{border-color:var(--primary);box-shadow:0 2px 8px #2563eb1a}.ul-word-tile--error{background:#fee2e2;border-color:#dc2626}.ul-word-tile--spelling-error{background:#dbeafe;border-color:#2563eb}.ul-word-tile--disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.ul-word-num{font-size:10px;font-weight:700;color:var(--text-muted)}.ul-word-text{font-size:18px;font-weight:700;font-family:Georgia,serif;color:var(--text)}.ul-word-tile--error .ul-word-text{color:#991b1b;text-decoration:line-through}.ul-word-tile--spelling-error .ul-word-text{color:#1e40af}.ul-word-rule{font-size:10px;font-weight:600;color:var(--primary);background:#eff6ff;border-radius:4px;padding:1px 8px}.ul-word-rule--non-example{color:#64748b;background:#f1f5f9;font-weight:400;font-style:italic}.ul-word-status{font-size:11px;font-weight:600;color:#059669}.ul-word-tile--error .ul-word-status{color:#dc2626}.ul-word-tile--spelling-error .ul-word-status{color:#2563eb}.ul-word-tile--disabled .ul-word-status{color:var(--text-muted)}.ul-ceiling-banner{background:#fef2f2;border:1px solid #FECACA;border-radius:8px;padding:10px 16px;margin-bottom:12px;font-size:13px;font-weight:600;color:#991b1b;display:flex;align-items:center;gap:12px;flex-wrap:wrap}.ul-ceiling-reset{font-size:12px;font-weight:600;color:var(--primary);background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:4px 12px;cursor:pointer;margin-left:auto}.ul-ceiling-reset:hover{border-color:var(--primary);background:#eff6ff}.ul-error-count{font-size:13px;color:var(--text-muted);margin-bottom:10px}.ul-section-h{display:flex;flex-direction:column;gap:20px}.ul-h-group-title{font-size:14px;font-weight:700;color:var(--text);margin:0 0 8px}.ul-h-group-note{font-size:12px;font-weight:500;color:var(--text-muted)}.ul-section-i-instruction{font-size:13px;color:var(--text-muted);margin-bottom:16px;line-height:1.5}.ul-nonsense-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.ul-nonsense-word{padding:12px 16px;border-radius:10px;border:2px solid var(--border);background:var(--surface);font-size:18px;font-weight:700;font-family:Georgia,serif;color:var(--text);text-align:center}.ul-nav{display:flex;gap:10px;align-items:center}.ul-notes-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;box-shadow:var(--shadow)}.ul-notes-label{display:block;font-size:12px;font-weight:700;color:var(--text-muted);margin-bottom:6px}.ul-notes-textarea{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:6px;font-size:13px;color:var(--text);background:var(--bg);resize:vertical;font-family:inherit}.ul-notes-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #2563eb1a}.ss-page{display:flex;flex-direction:column;gap:20px;max-width:860px}.ss-topbar{display:flex;align-items:flex-start;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;box-shadow:var(--shadow)}.ss-back{display:flex;align-items:center;gap:4px;font-size:13px;color:var(--primary);background:none;border:none;cursor:pointer;padding:4px 0;font-weight:600;white-space:nowrap}.ss-back:hover{text-decoration:underline}.ss-title-block{flex:1}.ss-title{font-size:18px;font-weight:700;color:var(--text);margin:0 0 2px}.ss-subtitle{font-size:12.5px;color:var(--text-muted)}.ss-legend-bar{display:flex;gap:20px;align-items:center;flex-wrap:wrap;padding:12px 20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.ss-legend-row{display:flex;align-items:center;gap:8px}.ss-legend-label{font-size:13px;color:var(--text-muted);font-weight:600}.ss-legend-total{margin-left:auto}.ss-badge{width:26px;height:26px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;cursor:pointer;border:2px solid transparent;transition:all .1s;flex-shrink:0}.ss-badge-reading{background:#fee2e2;color:#dc2626;border-color:#dc2626}.ss-badge-spelling{background:#dbeafe;color:#2563eb;border-color:#2563eb}.ss-badge-meaning{background:#dcfce7;color:#059669;border-color:#059669}.ss-badge-off{background:var(--bg);color:var(--text-light);border-color:var(--border)}.ss-badge-off:hover{border-color:var(--text-muted)}.ss-categories{display:flex;flex-direction:column;gap:16px}.ss-category{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.ss-cat-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--border);background:var(--bg)}.ss-cat-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:0}.ss-cat-progress{font-size:12px;font-weight:700;color:var(--text-muted);background:var(--border);padding:2px 8px;border-radius:99px}.ss-skill-rows{display:flex;flex-direction:column}.ss-skill-row{display:flex;align-items:center;gap:12px;padding:10px 20px;border-bottom:1px solid var(--border);transition:background .1s}.ss-skill-row:last-child{border-bottom:none}.ss-skill-row--known{background:#fafffe}.ss-skill-info{flex:1;display:flex;align-items:baseline;gap:10px}.ss-skill-label{font-size:15px;font-weight:700;color:var(--text);font-family:Georgia,serif;min-width:48px}.ss-skill-sound{font-size:12px;color:var(--text-muted);min-width:48px}.ss-skill-keyword{font-size:12px;color:var(--text-light);font-style:italic}.ss-skill-badges{display:flex;gap:6px;flex-shrink:0}.invite-status{text-align:center;padding:20px 0}.invite-status-icon{font-size:36px;margin-bottom:12px}.invite-status-title{font-size:17px;font-weight:700;color:var(--text);margin-bottom:6px}.invite-status-text{font-size:13.5px;color:var(--text-muted);line-height:1.5}.invite-context{background:#f0f4ff;border:1px solid #BFDBFE;border-radius:8px;padding:12px 14px;margin-bottom:20px}.invite-context-text{font-size:13.5px;color:var(--text);line-height:1.5}.invite-context-text strong{font-weight:600}.parent-child-card{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;margin-bottom:24px;box-shadow:var(--shadow)}.parent-child-avatar{width:46px;height:46px;background:linear-gradient(135deg,#1b2a4a,#0e8a7d);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff;flex-shrink:0}.parent-child-name{font-size:16px;font-weight:700;color:var(--text);margin-bottom:2px}.parent-child-status{font-size:12.5px;color:var(--text-muted)}.parent-child-badge{margin-left:auto;background:#ecfdf5;color:#059669;font-size:12px;font-weight:600;padding:4px 10px;border-radius:99px;border:1px solid #A7F3D0}.pd-loading{text-align:center;color:var(--text-muted);padding:40px 20px;font-size:14px}.pd-empty{text-align:center;color:var(--text-muted);padding:48px 20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.pd-empty-icon{margin-bottom:12px;color:var(--text-light)}.pd-empty p{margin:0;font-size:14px;max-width:360px;margin-inline:auto;line-height:1.5}.pd-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:20px}.pd-metric-card{display:flex;align-items:flex-start;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.pd-metric-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.pd-metric-label{font-size:12px;color:var(--text-muted);margin-bottom:4px;text-transform:uppercase;letter-spacing:.02em;font-weight:500}.pd-metric-value{font-size:22px;font-weight:700;color:var(--text);line-height:1.2}.pd-metric-skill{font-size:15px;font-weight:600;line-height:1.35}.pd-metric-sub{font-size:13px;font-weight:400;color:var(--text-muted)}.pd-latest-session{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:20px;box-shadow:var(--shadow)}.pd-latest-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--border)}.pd-latest-title{margin:0;font-size:15px;font-weight:700;color:var(--text)}.pd-latest-date{font-size:13px;color:var(--text-muted);font-weight:500}.pd-latest-body{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}.pd-latest-row{display:flex;align-items:baseline;gap:10px}.pd-latest-label{font-size:12.5px;color:var(--text-muted);min-width:120px;flex-shrink:0}.pd-latest-val{font-size:14px;color:var(--text);font-weight:500}.pd-accuracy strong{font-weight:700}.pd-dot{color:var(--text-light)}.pd-note{font-weight:400;font-style:italic;color:var(--text-muted)}.pd-latest-link{display:inline-flex;align-items:center;gap:4px;font-size:13px;font-weight:600;color:var(--primary);text-decoration:none}.pd-latest-link:hover{text-decoration:underline}.pd-orf-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:20px;box-shadow:var(--shadow)}.pd-orf-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.pd-orf-title{margin:0;font-size:15px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:6px}.pd-orf-desc{margin:0 0 16px;font-size:13px;color:var(--text-muted);line-height:1.4}.pd-orf-chart{width:100%;min-height:200px}.pd-orf-note{margin-top:12px;padding:10px 14px;background:#fef3c7;border:1px solid #FDE68A;border-radius:8px;font-size:13px;color:#92400e;line-height:1.4;margin-bottom:12px}@media(max-width:640px){.pd-metrics{grid-template-columns:1fr}.pd-latest-row{flex-direction:column;gap:2px}.pd-latest-label{min-width:unset}}.section-page{max-width:800px}.coming-soon-banner{display:flex;align-items:flex-start;gap:10px;background:#eff6ff;border:1px solid #BFDBFE;border-radius:var(--radius);padding:13px 16px;font-size:13.5px;color:#0a6e64;margin-bottom:24px;line-height:1.5}.section-grid{display:flex;flex-direction:column;gap:10px}.sl-global-list{display:flex;flex-direction:column;gap:8px}.sl-global-card{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;color:var(--text);box-shadow:var(--shadow);transition:border-color .15s,box-shadow .15s,transform .1s}.sl-global-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translate(2px)}.sl-global-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0}.sl-global-body{flex:1}.sl-global-student{font-size:11.5px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px}.sl-global-focus{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px}.sl-global-meta{display:flex;gap:12px}.sl-global-meta span{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-muted)}.sl-global-card>svg:last-child{color:var(--text-light);flex-shrink:0}.progress-metrics{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:28px}@media(max-width:560px){.progress-metrics{grid-template-columns:1fr}}.progress-metric-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px 18px;box-shadow:var(--shadow);display:flex;align-items:center;gap:14px}.progress-metric-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:20px}.progress-metric-icon.skills{background:#ecfdf5;color:#059669}.progress-metric-icon.sessions{background:#e6f7f5;color:#0e8a7d}.progress-metric-icon.accuracy{background:#f5f3ff;color:#7c3aed}.progress-metric-icon.current{background:#fffbeb;color:#d97706}.progress-metric-body{display:flex;flex-direction:column}.progress-metric-value{font-size:24px;font-weight:700;color:var(--text);line-height:1.2;display:flex;align-items:center;gap:6px}.progress-metric-label{font-size:12px;color:var(--text-muted);margin-top:2px}.trend-arrow{font-size:18px;font-weight:700}.trend-arrow.up{color:#059669}.trend-arrow.down{color:#dc2626}.trend-arrow.flat{color:#9ca3af}.orf-chart-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;margin-bottom:28px;box-shadow:var(--shadow)}.orf-chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.orf-chart-title{font-size:14px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:6px;margin:0}.orf-chart-desc{font-size:13px;color:var(--text-muted);margin:0 0 12px;line-height:1.4}.orf-chart-container{width:100%;min-height:230px}.progress-skills-section{margin-top:8px}.progress-skills-title{font-size:15px;font-weight:600;color:var(--text);margin-bottom:12px}.progress-skills-groups{display:flex;flex-direction:column;gap:4px}.skill-group{border:1px solid var(--border);border-radius:8px;overflow:hidden}.skill-group-header{display:flex;align-items:center;gap:8px;width:100%;background:var(--surface);border:none;padding:10px 14px;font-size:14px;font-weight:600;color:var(--text);cursor:pointer;text-align:left;transition:background .15s}.skill-group-header:hover{background:var(--bg)}.skill-group-chevron{display:inline-flex;color:var(--text-muted);transition:transform .2s ease;flex-shrink:0}.skill-group-name{flex:1}.skill-group-count{font-size:12px;font-weight:700;color:#059669;background:#ecfdf5;padding:2px 8px;border-radius:99px}.skill-group-body{border-top:1px solid var(--border);padding:8px 14px 10px;display:flex;flex-direction:column;gap:4px}.skill-group-item{font-size:13px;color:var(--text-muted);padding:3px 0;line-height:1.5}.orf-encouragement-note{background:#fffbeb;border:1px solid #FDE68A;border-radius:8px;padding:10px 14px;margin-top:12px;font-size:13px;color:#92400e;font-style:italic;line-height:1.5}.progress-loading,.progress-empty{text-align:center;padding:48px 16px;color:var(--text-light);font-size:14px}.progress-empty-icon{font-size:32px;margin-bottom:8px;opacity:.4}.portal-entry-card{background:#f8fafc;border:1px solid var(--border);border-radius:var(--radius);padding:20px 22px;margin-bottom:12px}.portal-entry-latest{background:#fafffe;border-left:4px solid #059669}.pe-header{margin-bottom:16px}.pe-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.pe-title{font-size:16px;font-weight:700;color:var(--text)}.pe-date{font-size:12px;font-weight:500;color:var(--text-muted);margin-top:2px}.btn-print-report{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:600;color:var(--primary);background:#eff6ff;border:1px solid #BFDBFE;border-radius:8px;cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s}.btn-print-report:hover{background:#dbeafe;border-color:#93c5fd}.pe-row-2col{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid #E2E8F0}@media(max-width:640px){.pe-row-2col{grid-template-columns:1fr;gap:12px}}.pe-col-label{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.pe-col-value{font-size:14px;color:var(--text);line-height:1.5}.pe-accuracy-summary strong{font-weight:800}.pe-dot{color:var(--text-light)}.pe-section{margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid #E2E8F0}.pe-section-label{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;display:flex;align-items:center;gap:5px}.pe-practice-instruction{font-size:13px;color:var(--text-muted);font-style:italic;margin:0 0 10px}.pe-word-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3px 12px}@media(max-width:640px){.pe-word-grid{grid-template-columns:repeat(3,1fr)}}.pe-word-item{font-size:13.5px;color:var(--text);padding:3px 0}.pe-progress-bar-wrap{display:flex;align-items:center;gap:12px;margin-bottom:8px}.pe-progress-bar{flex:1;height:10px;background:#e2e8f0;border-radius:99px;overflow:hidden}.pe-progress-bar-fill{height:100%;background:#059669;border-radius:99px;transition:width .3s ease}.pe-progress-text{font-size:12.5px;color:var(--text-muted);white-space:nowrap}.pe-recently-learned{font-size:12.5px;color:var(--text-muted);line-height:1.6}.pe-recently-label{font-weight:600}.pe-quick-stats{font-size:12.5px;color:var(--text-muted);padding:10px 0 0;margin-top:4px}.pe-quick-stats strong{color:var(--text)}.pe-teacher-note{background:#fffbeb;border:1px solid #FDE68A;border-radius:8px;padding:10px 14px;margin-top:14px}.pe-note-label{font-size:11px;font-weight:700;color:#92400e;text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px;display:flex;align-items:center;gap:5px}.pe-note-text{font-size:13.5px;color:#92400e;font-style:italic;line-height:1.5}.pe-details-toggle{display:inline-flex;align-items:center;gap:4px;background:none;border:none;font-size:12.5px;font-weight:600;color:var(--primary);cursor:pointer;padding:8px 0 0;transition:color .15s}.pe-details-toggle:hover{color:var(--primary-dark)}.pe-full-details{margin-top:14px;padding-top:14px;border-top:1px solid #E2E8F0;display:flex;flex-direction:column;gap:14px}.portal-section{padding-top:0}.portal-section-label{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;display:flex;align-items:center;gap:5px}.portal-section-content{font-size:13.5px;color:var(--text);line-height:1.6}.portal-accuracy-line{margin:0 0 4px;font-size:13px}.portal-word-list{margin-bottom:10px}.portal-word-list:last-child{margin-bottom:0}.portal-word-list-label{font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:4px}.portal-word-chips{display:flex;flex-wrap:wrap;gap:6px}.portal-word-chip{display:inline-block;padding:4px 12px;font-size:13px;font-weight:500;background:#fff;border:1px solid #E2E8F0;border-radius:8px;color:var(--text)}.portal-word-chip-practice{background:#fef3c7;border-color:#fde68a;color:#92400e}.portal-passage{font-style:italic;white-space:pre-wrap;background:#fff;border:1px solid #E2E8F0;border-radius:8px;padding:10px 14px;font-size:13px;line-height:1.7;color:var(--text)}.pe-col-passage .portal-passage{font-size:12.5px;padding:8px 12px}.btn-print-practice{display:inline-flex;align-items:center;gap:6px;margin-top:12px;padding:7px 14px;font-size:12.5px;font-weight:600;color:var(--primary);background:#eff6ff;border:1px solid #BFDBFE;border-radius:6px;cursor:pointer;transition:background .15s,border-color .15s}.btn-print-practice:hover{background:#dbeafe;border-color:#93c5fd}.portal-past-section{margin-top:20px}.portal-past-heading{font-size:13px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px}.portal-past-list{display:flex;flex-direction:column;gap:4px}.portal-past-entry{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.portal-past-entry-toggle{display:flex;align-items:center;gap:8px;width:100%;background:#f8fafc;border:none;font-size:13.5px;color:var(--text);cursor:pointer;padding:10px 14px;text-align:left;transition:background .15s}.portal-past-entry-toggle:hover{background:#f1f5f9}.portal-past-chevron{display:inline-flex;color:var(--text-muted);transition:transform .2s ease;flex-shrink:0}.portal-past-entry-date{font-size:12px;font-weight:600;color:var(--text-muted);min-width:60px}.portal-past-entry-skill{font-size:13px;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.portal-past-entry .portal-entry-card{margin-bottom:0;border:none;border-top:1px solid var(--border);border-radius:0}.portal-empty{border:2px dashed #CBD5E1;border-radius:var(--radius);padding:32px 20px;text-align:center;color:var(--text-muted);font-size:14px;font-style:italic;background:#f8fafc}.session-loading{text-align:center;padding:48px 16px;color:var(--text-light);font-size:14px}.print-dialog-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.print-dialog{background:#fff;border-radius:12px;padding:24px 28px;max-width:400px;width:90%;box-shadow:0 20px 60px #0003}.print-dialog-title{font-size:16px;font-weight:700;margin:0 0 8px}.print-dialog-desc{font-size:13.5px;color:var(--text-muted);margin:0 0 14px;line-height:1.5}.print-dialog-checkbox{display:flex;align-items:center;gap:8px;font-size:13.5px;cursor:pointer;margin-bottom:16px}.print-dialog-actions{display:flex;justify-content:flex-end;gap:8px}.pe-fluency-section{background:#f0fdfa;border:1px solid #99F6E4;border-radius:8px;padding:14px 16px;margin-bottom:16px}.pe-fluency-summary{margin-bottom:8px}.pe-fluency-line{font-size:13.5px;color:var(--text);margin:0 0 4px;line-height:1.5}.pe-fluency-benchmark{font-size:13.5px;font-weight:600;color:#0d9488;margin:0 0 6px;line-height:1.5}.pe-fluency-chart{background:#fff;border:1px solid #E2E8F0;border-radius:8px;padding:12px 14px;margin-top:10px}.pe-fluency-chart-title{font-size:13px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:5px;margin:0 0 8px}.pe-fluency-encouragement{background:#fffbeb;border:1px solid #FDE68A;border-radius:8px;padding:10px 14px;margin-top:10px;font-size:13px;color:#92400e;font-style:italic;line-height:1.5}.notes-thread{display:flex;flex-direction:column;gap:14px;margin-bottom:16px}.note-bubble{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px 16px;max-width:88%;box-shadow:var(--shadow)}.note-bubble-right{align-self:flex-end;background:var(--primary-light);border-color:#bfdbfe}.note-meta{display:flex;align-items:center;gap:8px;margin-bottom:6px}.note-author{font-size:13px;font-weight:600;color:var(--text)}.note-role-tag{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;background:var(--primary-light);color:var(--primary);padding:1px 6px;border-radius:99px}.note-bubble-right .note-role-tag{background:#dbeafe}.note-date{font-size:11.5px;color:var(--text-light);margin-left:auto}.note-text{font-size:13.5px;color:var(--text);line-height:1.6}.note-compose{display:flex;gap:10px;align-items:center;margin-top:8px}.note-compose-input{flex:1;display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--surface);border:1.5px solid var(--border);border-radius:8px;color:var(--text-light);font-size:13.5px;cursor:not-allowed}
