*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--primary:#1a56db;--primary-dark:#1e429f;--primary-light:#ebf5ff;--success:#0e9f6e;--warning:#e3a008;--danger:#e02424;--bg:#f3f4f6;--surface:#ffffff;--border:#e5e7eb;--text:#111827;--text-muted:#6b7280;--radius:10px;--shadow:0 1px 4px rgba(0,0,0,.08);font-family:Segoe UI,Hiragino Sans,Meiryo,sans-serif}body{background:var(--bg);color:var(--text);min-height:100vh}body.wordbank-lock-scroll{overflow:hidden}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh}.spinner{width:36px;height:36px;border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.navbar{background:var(--primary-dark);color:#fff;padding:.75rem 1.5rem;position:-webkit-sticky;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px rgba(0,0,0,.2)}.navbar,.navbar-inner{display:flex;flex-direction:column;gap:.75rem}.navbar-inner{width:100%;max-width:1140px;margin:0 auto}.navbar-top{display:flex;align-items:center;justify-content:space-between;gap:1rem}.navbar-brand a{color:#fff;font-size:1.1rem;font-weight:700;text-decoration:none;display:inline-flex;align-items:center;gap:.55rem}.brand-mark{width:28px;height:28px;border-radius:6px;object-fit:cover;background:rgba(255,255,255,.12);padding:2px}.navbar-toggle{display:none;border:1px solid rgba(255,255,255,.35);background:rgba(255,255,255,.08);border-radius:8px;width:38px;height:34px;padding:0;cursor:pointer;color:#fff;font-size:1.1rem;line-height:34px;text-align:center;font-weight:700}.navbar-links{display:flex;gap:.5rem;width:100%;flex-wrap:wrap}.navbar-links a{color:rgba(255,255,255,.8);text-decoration:none;padding:.35rem .75rem;border-radius:6px;font-size:.9rem;transition:background .15s}.navbar-links a.active,.navbar-links a:hover{background:rgba(255,255,255,.15);color:#fff}.navbar-user{display:flex;align-items:center;gap:.75rem}.navbar-mobile-footer{display:none}.user-name{font-size:.85rem;color:rgba(255,255,255,.8);max-width:180px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn-logout{background:transparent;border:1px solid rgba(255,255,255,.4);color:#fff;border-radius:6px;padding:.3rem .75rem;font-size:.8rem;cursor:pointer;transition:background .15s}.btn-logout:hover{background:rgba(255,255,255,.15)}.page-container{max-width:900px;margin:0 auto;padding:1.5rem 1rem}.page-title{font-size:1.6rem;font-weight:700;margin-bottom:.25rem}.page-subtitle,.subtitle{color:var(--text-muted);font-size:.95rem;margin-bottom:1rem}.center-content{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1rem}.btn-primary{background:var(--primary);color:#fff;border:none;border-radius:var(--radius);padding:.65rem 1.4rem;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s;display:inline-flex;align-items:center;gap:.4rem;text-decoration:none}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);padding:.65rem 1.4rem;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s;display:inline-flex;align-items:center;gap:.4rem;text-decoration:none}.btn-secondary:hover{background:var(--bg)}.btn-link{background:none;border:none;color:var(--primary);cursor:pointer;font-size:.9rem;font-weight:500;text-decoration:none;padding:.2rem .4rem;border-radius:4px}.btn-link:hover{text-decoration:underline}.btn-back{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.9rem;margin-bottom:1rem;padding:0}.btn-back:hover{color:var(--text)}.btn-full{width:100%;justify-content:center}.btn-large{padding:.9rem 2rem;font-size:1.05rem}.field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem}.field label{font-size:.85rem;font-weight:600;color:var(--text-muted)}.field input,.field select,input[type=search]{border:1px solid var(--border);border-radius:var(--radius);padding:.6rem .85rem;font-size:.95rem;transition:border-color .15s;background:var(--surface);width:100%}.field input:focus,.field select:focus,input[type=search]:focus{outline:none;border-color:var(--primary)}.error-msg{color:var(--danger);font-size:.85rem;margin:.5rem 0}.success-msg{color:var(--success);font-size:.9rem;margin:.5rem 0}.warn-msg{color:var(--warning);font-size:.85rem;margin:.4rem 0}.saved-msg{color:var(--success);font-weight:600;font-size:.9rem}.hint{color:var(--text-muted);font-size:.85rem;margin-bottom:.5rem}.hint code{background:var(--bg);padding:.1rem .4rem;border-radius:4px;font-size:.82rem}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e3a5f,#1a56db);padding:1rem}.login-card{background:var(--surface);border-radius:16px;padding:2.5rem 2rem;width:100%;max-width:420px;box-shadow:0 8px 32px rgba(0,0,0,.2)}.login-header{text-align:center;margin-bottom:2rem}.login-logo{width:70px;height:70px;object-fit:cover;border-radius:12px;margin-bottom:.5rem}.login-header h1{font-size:1.6rem;font-weight:700;color:var(--text)}.login-header p{color:var(--text-muted);font-size:.9rem;margin-top:.25rem}.login-form{display:flex;flex-direction:column}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));grid-gap:1rem;gap:1rem;margin:1.5rem 0}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1rem;text-align:center;box-shadow:var(--shadow)}.stat-card.stat-due{border-color:var(--warning);background:#fffbeb}.stat-card.stat-done{border-color:var(--success);background:#f0fdf4}.stat-number{font-size:2rem;font-weight:700;color:var(--text)}.stat-label{font-size:.8rem;color:var(--text-muted);margin-top:.25rem;font-weight:500}.stage-breakdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;margin:1rem 0;box-shadow:var(--shadow)}.stage-breakdown h2{font-size:1rem;font-weight:600;margin-bottom:1rem}.stage-bars{display:flex;flex-direction:column;gap:.6rem}.stage-row{display:grid;grid-template-columns:80px 1fr 40px;align-items:center;grid-gap:.75rem;gap:.75rem}.stage-label{font-size:.82rem;color:var(--text-muted);font-weight:500}.stage-bar-track{height:10px;background:var(--bg);border-radius:5px;overflow:hidden}.stage-bar-svg{width:100%;height:10px;display:block}.stage-bar-bg{fill:var(--bg)}.stage-count{font-size:.82rem;font-weight:600;text-align:right}.home-header{margin-bottom:1rem}.home-header h1{font-size:1.5rem;font-weight:700}.home-actions{display:flex;flex-direction:column;gap:.75rem;align-items:flex-start;margin-top:1.5rem}.done-banner{background:#f0fdf4;border:1px solid var(--success);border-radius:var(--radius);padding:1rem 1.25rem;font-weight:600;color:#065f46;font-size:.95rem}.info-banner{background:#eff6ff;border:1px solid #93c5fd;border-radius:var(--radius);padding:.85rem 1rem;color:#1e3a8a;font-size:.92rem}.study-page{max-width:680px}.study-progress{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem}.study-progress span{font-size:.85rem;color:var(--text-muted);white-space:nowrap}.progress-bar{flex:1 1;height:8px;background:var(--border);border-radius:4px;overflow:hidden}.progress-svg{width:100%;height:8px;display:block}.progress-track{fill:var(--border)}.progress-value{fill:var(--primary)}.flashcard{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:2rem 1.75rem;box-shadow:0 4px 16px rgba(0,0,0,.08);min-height:280px;display:flex;flex-direction:column;align-items:center;gap:.75rem;text-align:center}.card-tag{background:var(--primary-light);color:var(--primary);border-radius:20px;padding:.2rem .75rem;font-size:.78rem;font-weight:600}.card-chunk-en{font-size:1.9rem;font-weight:700;color:var(--text);margin-top:.5rem}.card-pronunciation{font-size:.95rem;color:var(--text-muted);font-style:italic}.btn-reveal{margin-top:1.5rem;background:var(--primary);color:#fff;border:none;border-radius:30px;padding:.75rem 2.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s}.btn-reveal:hover{background:var(--primary-dark)}.card-revealed{display:flex;flex-direction:column;gap:.5rem;align-items:center;width:100%}.card-chunk-ja{font-size:1.4rem;font-weight:700;color:var(--primary-dark)}.card-word{font-size:1rem;color:var(--text)}.card-conjugation{color:var(--text-muted);font-size:.9rem}.card-meaning{font-size:.85rem;color:var(--text-muted);background:var(--bg);border-radius:8px;padding:.5rem .75rem}.card-examples,.card-meaning{text-align:left;width:100%}.example-en{font-size:.88rem;color:var(--text);font-style:italic;margin-bottom:.2rem}.example-ja{font-size:.85rem;color:var(--text-muted)}.answer-buttons{display:grid;grid-template-columns:1fr 1fr 1fr;grid-gap:.75rem;gap:.75rem;margin-top:1.25rem;width:100%}.btn-good,.btn-not-yet,.btn-okay{border:none;border-radius:var(--radius);padding:.85rem .5rem;font-size:.9rem;font-weight:700;cursor:pointer;transition:opacity .15s;display:flex;flex-direction:column;align-items:center;gap:.25rem}.btn-not-yet{background:#fef2f2;color:var(--danger);border:2px solid #fecaca}.btn-okay{background:#fff7ed;color:var(--warning);border:2px solid #fed7aa}.btn-good{background:#f0fdf4;color:var(--success);border:2px solid #bbf7d0}.btn-not-yet:hover{background:#fee2e2}.btn-okay:hover{background:#ffedd5}.btn-good:hover{background:#dcfce7}.btn-good span:first-child,.btn-not-yet span:first-child,.btn-okay span:first-child{font-size:1.3rem}.session-done{text-align:center}.done-icon{font-size:4rem;margin-bottom:1rem}.session-done h2{font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.session-done p{color:var(--text-muted);margin-bottom:.5rem}.done-actions{display:flex;gap:1rem;justify-content:center;margin-top:1.5rem;flex-wrap:wrap}.settings-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;margin-bottom:1rem;box-shadow:var(--shadow)}.settings-section h2{font-size:1rem;font-weight:600;margin-bottom:.75rem}.level-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.btn-level{background:var(--bg);border:2px solid var(--border);border-radius:8px;padding:.55rem 1.25rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .15s}.btn-level.active{background:var(--primary);color:#fff}.btn-level.active,.btn-level:hover:not(.active){border-color:var(--primary)}.steps-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.steps-header h2{margin-bottom:0}.step-grid{display:flex;flex-wrap:wrap;gap:.5rem}.step-chip{display:flex;align-items:center;gap:.4rem;background:var(--bg);border:2px solid var(--border);border-radius:8px;padding:.4rem .75rem;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s}.step-chip input{display:none}.step-chip.checked{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.settings-actions{gap:1rem;margin-top:1rem}.list-header,.settings-actions{display:flex;align-items:center}.list-header{justify-content:space-between;margin-bottom:1rem}.search-bar{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:1rem}.search-bar input{max-width:360px}.search-bar select{border:1px solid var(--border);border-radius:var(--radius);padding:.6rem .85rem;font-size:.95rem;background:var(--surface);min-width:180px}.search-bar select:focus{outline:none;border-color:var(--primary)}.student-table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border)}.student-table{width:100%;border-collapse:collapse;background:var(--surface);font-size:.88rem}.student-table th{background:var(--bg);padding:.65rem 1rem;text-align:left;font-weight:600;color:var(--text-muted);font-size:.8rem;text-transform:uppercase}.student-table td,.student-table th{border-bottom:1px solid var(--border)}.student-table td{padding:.7rem 1rem}.student-table tr:last-child td{border-bottom:none}.student-table tr:hover td{background:var(--bg)}.td-name{font-weight:600}.td-email{color:var(--text-muted);font-size:.85rem}.td-due{color:var(--warning);font-weight:600}.td-time{font-size:.82rem;white-space:nowrap}.empty-row,.td-time{color:var(--text-muted)}.empty-row{text-align:center;padding:2rem!important}.empty-note{color:var(--text-muted);font-style:italic}.count-note{color:var(--text-muted);font-size:.85rem;margin-top:.75rem}.row-success td{background:#f0fdf4}.row-error td{background:#fef2f2}.result-good{color:var(--success);font-weight:600}.result-bad{color:var(--danger);font-weight:600}.result-ok{color:var(--warning);font-weight:600}.card-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow)}.card-section h2{font-size:1.05rem;font-weight:600;margin-bottom:1rem}.upload-area{border:2px dashed var(--border);border-radius:var(--radius);padding:2rem;text-align:center;cursor:pointer;color:var(--text-muted);margin:.75rem 0;transition:border-color .15s}.upload-area:hover{border-color:var(--primary);color:var(--primary)}.bulk-preview{margin:1rem 0;max-height:300px;overflow-y:auto}.dashboard-header{justify-content:space-between;margin-bottom:1rem}.dashboard-actions,.dashboard-header{display:flex;align-items:center;flex-wrap:wrap;gap:.75rem}.range-select-wrap{display:inline-flex;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.82rem;font-weight:600}.range-select-wrap select{border:1px solid var(--border);background:var(--surface);border-radius:8px;padding:.4rem .55rem;font-size:.84rem;color:var(--text)}.range-select-wrap select:focus{outline:none;border-color:var(--primary)}.dashboard-table-section,.log-section{margin-top:2rem}.log-table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border)}.student-detail-header{margin-bottom:1rem}.student-detail-header h1{font-size:1.6rem;font-weight:700}.student-detail-top{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.4rem}.student-header-actions{display:flex;align-items:flex-start;justify-content:flex-end;gap:.5rem;flex-wrap:wrap}.student-header-actions>button{min-width:138px;justify-content:center}.btn-compact{border-radius:8px}.student-meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:.6rem;gap:.6rem;margin:.25rem 0 .55rem}.student-meta-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:.6rem .75rem;display:flex;flex-direction:column;gap:.1rem;box-shadow:var(--shadow)}.meta-label{font-size:.74rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);font-weight:700}.meta-value{font-size:1rem;color:var(--text);line-height:1.2}.meta-subvalue{font-size:.84rem;color:var(--primary-dark);font-weight:600}.student-edit-panel{margin-top:.75rem;border:1px solid var(--border);background:var(--surface);border-radius:10px;padding:.85rem;box-shadow:var(--shadow)}.student-edit-panel h3{font-size:.95rem;margin-bottom:.6rem}.field-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:.75rem;gap:.75rem}.compact-level-buttons{margin-bottom:.75rem}.wordbank-edit-box{background:#f8fafc;border:1px solid var(--border);border-radius:10px;padding:.8rem}.wordbank-page{height:calc(100vh - var(--wordbank-navbar-h, 76px));height:calc(100svh - var(--wordbank-navbar-h, 76px));height:calc(100dvh - var(--wordbank-navbar-h, 76px));display:flex;flex-direction:column;overflow:hidden;padding-top:.75rem;padding-bottom:.5rem}.wordbank-table-section{flex:1 1;min-height:0;display:flex;flex-direction:column;padding:.9rem .9rem .5rem;margin-bottom:0}.wordbank-table-wrap{flex:1 1;min-height:0;overflow:auto}.wordbank-page .page-subtitle,.wordbank-table-section .search-bar{margin-bottom:.5rem}.wordbank-table-section .student-table{font-size:.8rem}.wordbank-table-section .student-table th{padding:.38rem .6rem;font-size:.72rem;line-height:1.15}.wordbank-table-section .student-table td{padding:.28rem .6rem;line-height:1.15}.wordbank-level-label-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:.65rem;gap:.65rem;margin-bottom:.75rem}.wordbank-header-actions{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap}.wordbank-table-wrap::-webkit-scrollbar{width:6px;height:6px}.wordbank-table-wrap::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:999px}.wordbank-table-wrap::-webkit-scrollbar-track{background:transparent}.wordbank-table-wrap .student-table th{position:-webkit-sticky;position:sticky;top:0;z-index:1}.class-card{display:flex;flex-direction:column;gap:.6rem}.class-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.class-add-student-row{display:grid;grid-template-columns:1fr auto;grid-gap:.6rem;gap:.6rem;align-items:end}.class-add-student-row .field{margin-bottom:0}.help-card p{margin-bottom:.5rem}.help-card ul{margin:.3rem 0 .75rem 1.2rem;color:var(--text)}.help-card li{margin:.2rem 0}.reset-password-row{gap:1rem;margin-top:.75rem}.delete-confirm-row,.reset-password-row{display:flex;align-items:center;flex-wrap:wrap}.delete-confirm-row{gap:.5rem;font-size:.82rem;color:var(--text-muted)}.btn-danger{background:#ef4444;color:#fff;border:none;border-radius:var(--radius);padding:.65rem 1.4rem;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s}.btn-danger.btn-compact,.btn-secondary.btn-compact{padding:.45rem .85rem;font-size:.82rem;line-height:1.2}.btn-danger-mt{margin-top:.75rem}.btn-danger:hover{background:#dc2626}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.password-form{max-width:400px;display:flex;flex-direction:column;gap:.75rem}.create-form{max-width:480px}.modal-backdrop{position:fixed;inset:0;background:rgba(17,24,39,.45);display:flex;align-items:center;justify-content:center;padding:1rem;z-index:300}.password-modal{width:min(460px,100%);background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:0 14px 40px rgba(0,0,0,.25);padding:1.1rem}.password-modal h3{font-size:1.05rem;margin-bottom:.35rem}.password-modal input{width:100%;border:1px solid var(--border);border-radius:var(--radius);padding:.65rem .85rem;font-size:.95rem;margin-top:.5rem}.password-modal input:focus{outline:none;border-color:var(--primary)}.password-modal-actions{margin-top:.8rem;display:flex;gap:.6rem;justify-content:flex-end;flex-wrap:wrap}.metric-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:1rem;gap:1rem;margin:1rem 0 1.5rem}.metric-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow)}.metric-panel h2{font-size:1rem;margin-bottom:.35rem}.metric-subtitle{color:var(--text-muted);font-size:.82rem;margin-bottom:.75rem}.stage-distribution-list{display:flex;flex-direction:column;gap:.6rem}.stage-dist-row{display:grid;grid-template-columns:110px 1fr 84px;grid-gap:.6rem;gap:.6rem;align-items:center}.stage-dist-label{display:flex;align-items:center;gap:.4rem;font-size:.84rem;color:var(--text-muted)}.stage-dot{width:10px;height:10px;display:inline-block}.stage-dist-bar{width:100%;height:10px}.stage-dist-track{fill:var(--bg)}.stage-dist-value{font-size:.82rem;color:var(--text);text-align:right;font-weight:600}.class-chart-wrap{width:100%;overflow-x:auto}.class-chart{width:100%;min-width:520px;height:auto}.class-chart-label{fill:var(--text-muted);font-size:12px;font-weight:600}.class-chart-track{fill:var(--bg)}.class-chart-bar{fill:var(--primary)}.class-chart-bar.selected{fill:var(--primary-dark)}.class-chart-hitbox{cursor:pointer}.class-chart-value{fill:var(--text);font-size:12px;font-weight:700}.student-accuracy-row{grid-template-columns:160px 1fr 92px}.student-accuracy-fill{fill:var(--primary-dark)}@media (max-width:900px){.navbar{padding:.75rem 1rem}.page-container{padding:1.25rem .9rem}.dashboard-header,.list-header,.steps-header{flex-direction:column;align-items:stretch}.dashboard-actions{width:100%;justify-content:stretch}.dashboard-actions .btn-primary{width:100%;justify-content:center}.range-select-wrap{width:100%;justify-content:space-between}.range-select-wrap select{flex:1 1;min-width:0}.search-bar input,.search-bar select{max-width:none;width:100%}.wordbank-header-actions{width:100%;flex-direction:row;align-items:center;flex-wrap:nowrap}.wordbank-header-actions>button{width:auto;flex:1 1;min-width:0;justify-content:center;padding:.55rem .5rem;font-size:.86rem}}@media (max-width:700px){body.wordbank-lock-scroll{overflow:hidden}.navbar{gap:.5rem}.navbar-top{flex-wrap:nowrap;align-items:center}.navbar-brand{min-width:0;flex:1 1}.navbar-brand a{min-width:0}.navbar-toggle{display:inline-flex;flex-direction:column;justify-content:center;align-items:stretch;flex-shrink:0}.navbar-user{display:none}.navbar-links{display:none;flex-direction:column;gap:.35rem;padding-top:.25rem}.navbar-links.open{display:flex}.navbar-links a{width:100%;padding:.55rem .75rem}.navbar-mobile-footer{display:flex;flex-direction:column;gap:.5rem;margin-top:.25rem;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.18)}.navbar-mobile-footer .user-name{display:block;max-width:none}.navbar-mobile-footer .btn-logout{width:100%}.study-progress{flex-wrap:wrap;align-items:flex-start}.study-progress span{white-space:normal;width:100%}.flashcard{padding:1.5rem 1rem;min-height:0}.answer-buttons{grid-template-columns:1fr}.reset-password-row,.settings-actions{align-items:stretch}.reset-password-row>*,.settings-actions>*{width:100%}.student-detail-top{flex-direction:column;align-items:stretch}.student-header-actions{justify-content:stretch}.student-header-actions>*{width:100%;justify-content:center}.student-header-actions>button{min-width:0}.delete-confirm-row{align-items:stretch}.delete-confirm-row>*{width:100%}.password-form{max-width:none}.password-modal-actions>*{width:100%;justify-content:center}.field-row{grid-template-columns:1fr}.class-card-head{flex-direction:column;align-items:stretch}.class-card-head .btn-secondary{width:100%;justify-content:center}.class-add-student-row{grid-template-columns:1fr}.class-add-student-row>button{width:100%}.wordbank-page{display:block;height:var(--wordbank-page-h,calc(100dvh - var(--wordbank-navbar-h, 76px)));overflow-y:auto;overflow-x:hidden;padding-bottom:.1rem}.wordbank-page::-webkit-scrollbar{width:0;height:0}.wordbank-table-section{position:-webkit-sticky;position:sticky;top:.35rem;height:calc(var(--wordbank-page-h, 100dvh) - .45rem);display:flex;flex-direction:column;padding-bottom:.1rem}.wordbank-table-wrap{position:relative;top:auto;height:auto;max-height:none;flex:1 1;min-height:0;overflow:auto}}@media (max-width:600px){.navbar{gap:.5rem}.navbar-top{align-items:center}.navbar-brand{min-width:0}.navbar-brand a span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.navbar-user{width:auto}.login-card{padding:2rem 1.25rem}.home-header h1,.page-title,.session-done h2,.student-detail-header h1{font-size:1.35rem}.card-chunk-en{font-size:1.5rem}.card-chunk-ja{font-size:1.15rem}.answer-buttons{gap:.5rem}.stat-grid{grid-template-columns:repeat(2,1fr)}.metric-grid{grid-template-columns:1fr}.stage-row{grid-template-columns:70px 1fr 32px;gap:.5rem}.stage-dist-row{grid-template-columns:94px 1fr 70px}.student-accuracy-row{grid-template-columns:112px 1fr 72px}}@media (max-width:480px){.page-container{padding:1rem .75rem 1.5rem}.stat-grid{grid-template-columns:1fr}.done-actions{flex-direction:column}.done-actions .btn-primary,.done-actions .btn-secondary{width:100%;justify-content:center}.steps-header{gap:.5rem}.student-table td,.student-table th{padding:.6rem .65rem}.class-chart-wrap{overflow-x:hidden}.class-chart{min-width:0}.stage-row{grid-template-columns:1fr}.stage-count{text-align:left}.stage-dist-row,.student-accuracy-row{grid-template-columns:1fr;gap:.35rem}.stage-dist-label{min-width:0}.stage-dist-value{text-align:left}}