*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #ffffff;--bg-secondary: #f5f5f7;--bg-tertiary: #e8e8ed;--text-primary: #1d1d1f;--text-secondary: #6e6e73;--text-tertiary: #86868b;--accent: #0071e3;--accent-hover: #0077ed;--accent-light: rgba(0, 113, 227, .08);--green: #34c759;--yellow: #ff9f0a;--red: #ff3b30;--border: rgba(0, 0, 0, .06);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .04), 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--radius: 12px;--radius-sm: 8px;--transition: .25s ease;--max-width: 720px;--font: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Helvetica Neue", Helvetica, Arial, sans-serif}html,body{font-family:var(--font);color:var(--text-primary);background:var(--bg-secondary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}.layout{min-height:100vh;display:flex;flex-direction:column}.page-content{flex:1;max-width:var(--max-width);width:100%;margin:0 auto;padding:24px 20px 100px}.page-title{font-size:28px;font-weight:700;letter-spacing:-.5px;margin-bottom:24px;color:var(--text-primary)}.tab-bar{position:fixed;bottom:0;left:0;right:0;background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border);display:flex;justify-content:center;gap:0;padding:8px 0 calc(8px + env(safe-area-inset-bottom));z-index:100}.tab-bar a{display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px 24px;text-decoration:none;color:var(--text-tertiary);font-size:10px;font-weight:500;transition:color var(--transition)}@media(max-width:720px){.tab-bar a{padding:4px 12px}}@media(max-width:480px){.tab-bar a{padding:4px 5px;font-size:9px;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}}.tab-bar a.active{color:var(--accent)}.tab-bar a svg{width:24px;height:24px}.tab-icon-wrap{position:relative;display:inline-flex;width:28px;height:24px;align-items:center;justify-content:center}.tab-notification-badge{position:absolute;top:-5px;right:-9px;min-width:17px;height:17px;padding:0 5px;border:2px solid rgba(255,255,255,.92);border-radius:999px;background:var(--accent);color:#fff;box-shadow:0 2px 5px #0071e347;font-size:10px;font-weight:700;line-height:13px;text-align:center;font-variant-numeric:tabular-nums}.card{background:var(--bg);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:20px;transition:box-shadow var(--transition),transform var(--transition)}.card:hover{box-shadow:var(--shadow-md)}.card-clickable{cursor:pointer}.card-clickable:hover{transform:translateY(-1px)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border:none;border-radius:980px;font-size:14px;font-weight:500;font-family:var(--font);cursor:pointer;transition:all var(--transition);line-height:1.2}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{background:var(--bg-tertiary);color:var(--text-tertiary);cursor:not-allowed}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary)}.btn-secondary:hover{background:var(--bg-tertiary)}.btn-danger{background:#ff3b301a;color:var(--red)}.btn-danger:hover{background:#ff3b3026}.btn-small{padding:6px 14px;font-size:13px}.input{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:15px;font-family:var(--font);background:var(--bg);color:var(--text-primary);transition:border-color var(--transition),box-shadow var(--transition);outline:none}.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}textarea.input{min-height:120px;resize:vertical;line-height:1.6}.admin-page{min-width:0}.admin-page .card{max-width:100%}.admin-tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:20px;overflow-x:auto;-webkit-overflow-scrolling:touch}.admin-tab{flex:0 0 auto;padding:10px 16px;border:none;background:transparent;color:var(--text-secondary);font-size:14px;font-weight:500;font-family:var(--font);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color var(--transition),border-color var(--transition);white-space:nowrap}.admin-tab:hover{color:var(--text-primary)}.admin-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.admin-banner{padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}.admin-banner.success{background:#34c75914;color:var(--green)}.admin-banner.error{background:#ff3b3014;color:var(--red)}.admin-section-title{font-size:17px;font-weight:600;margin:24px 0 12px}.admin-section-title:first-child{margin-top:0}.admin-block{margin-bottom:28px}.admin-block-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.admin-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.admin-toolbar-label{font-size:13px;color:var(--text-secondary)}.admin-toolbar-count{font-size:13px;color:var(--text-secondary);margin-left:auto}.admin-search{flex:1;min-width:160px}.admin-sort{flex:0 0 auto;width:auto}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-bottom:16px}.stat-card{background:var(--bg);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px}.stat-card-label{font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em}.stat-card-value{font-size:28px;font-weight:600;margin-top:4px;line-height:1.1}.stat-card-sub{font-size:12px;color:var(--text-tertiary);margin-top:2px}.sparkline{width:100%;margin-top:8px;display:block}.admin-chart-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px;margin-bottom:16px}.admin-chart-card{padding:16px}.admin-chart-title{font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:12px}.bar-chart{display:flex;align-items:flex-end;gap:2px}.bar-chart-col{flex:1;display:flex;align-items:flex-end;height:100%;min-width:2px}.bar-chart-bar{width:100%;border-radius:2px 2px 0 0;min-height:1px}.bar-list{display:flex;flex-direction:column;gap:8px}.bar-row{display:grid;grid-template-columns:minmax(70px,110px) 1fr auto;align-items:center;gap:10px}.bar-row-label{font-size:13px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bar-row-track{height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden}.bar-row-fill{height:100%;border-radius:4px}.bar-row-value{font-size:12px;color:var(--text-secondary);font-variant-numeric:tabular-nums}.admin-card-flush{padding:0!important;overflow:hidden}.admin-table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.admin-table{width:100%;border-collapse:collapse;font-size:13px;min-width:560px}.admin-table-compact{min-width:420px}.admin-table thead tr{border-bottom:1px solid var(--border);background:var(--bg-secondary)}.admin-table th{text-align:left;padding:10px 14px;font-weight:600;color:var(--text-secondary);white-space:nowrap}.admin-table td{padding:10px 14px;border-bottom:1px solid var(--border);vertical-align:middle}.admin-table tbody tr:last-child td{border-bottom:none}.admin-nowrap{white-space:nowrap}.admin-empty{padding:20px;color:var(--text-secondary);font-size:14px;text-align:center}.admin-user-cell{display:flex;align-items:center;gap:10px}.admin-avatar{width:28px;height:28px;border-radius:50%;flex-shrink:0}.admin-user-name{font-weight:500}.admin-user-email{font-size:12px;color:var(--text-tertiary)}.admin-badges{display:flex;gap:4px;flex-wrap:wrap}.admin-activity{font-size:12px;color:var(--text-secondary);font-variant-numeric:tabular-nums;white-space:nowrap}.admin-mini-select{width:auto;padding:4px 8px;font-size:12px}.admin-batch-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:10px 14px;margin-bottom:12px;background:var(--accent-light, rgba(0, 113, 227, .08));border-radius:var(--radius-sm)}.admin-batch-count{font-size:13px;font-weight:600}.admin-batch-cap{display:inline-flex;align-items:center;gap:6px}.admin-batch-cap .input{width:150px;padding:6px 10px;font-size:13px}.admin-check-col{width:32px;text-align:center}.admin-row-suspended td{opacity:.55}.admin-row-suspended td.admin-check-col,.admin-row-suspended td:last-child{opacity:1}.admin-cap{cursor:pointer;font-variant-numeric:tabular-nums}.admin-cap:hover{text-decoration:underline dotted}.admin-cap.over{color:var(--red);font-weight:600}.admin-cap-edit{display:inline-flex;align-items:center;gap:6px}.admin-cap-edit .input{width:100px;padding:6px 10px;font-size:13px}.admin-code{background:var(--bg-secondary);padding:2px 8px;border-radius:4px;cursor:pointer;font-family:ui-monospace,monospace}.admin-row-actions{display:flex;gap:6px;flex-wrap:wrap}.admin-form-card{display:flex;flex-direction:column;gap:12px}.admin-invite-form{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}.admin-field{display:flex;flex-direction:column;gap:4px;font-size:13px;color:var(--text-secondary)}.admin-field input{width:120px}.admin-group-form{display:grid;grid-template-columns:1fr 2fr auto;gap:8px}.admin-import-grid{display:grid;grid-template-columns:1fr 2fr 64px;gap:8px}.admin-import-row{display:flex;gap:8px;align-items:center}.admin-color{padding:4px;min-height:42px}.admin-hint{font-size:13px;color:var(--text-secondary)}.admin-list-name{display:inline-flex;align-items:center;gap:8px}.admin-dot{width:10px;height:10px;border-radius:50%;display:inline-block}.admin-edit-name{display:flex;align-items:center;gap:8px}.admin-edit-name .admin-color{width:44px;flex-shrink:0}.admin-append{display:flex;flex-direction:column;gap:8px;padding:8px 0}.admin-append textarea{min-height:80px}.mode-toggle{display:inline-flex;background:var(--bg-tertiary);border-radius:980px;padding:3px;position:relative}.mode-toggle button{padding:6px 18px;border:none;border-radius:980px;font-size:13px;font-weight:500;font-family:var(--font);cursor:pointer;background:transparent;color:var(--text-secondary);transition:all var(--transition);position:relative;z-index:1}.mode-toggle button.active{color:var(--text-primary);background:var(--bg);box-shadow:var(--shadow-sm)}.settings-switch{position:relative;flex:0 0 auto;width:48px;height:28px;border:0;border-radius:999px;background:var(--bg-tertiary);cursor:pointer;transition:background var(--transition)}.settings-switch span{position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:var(--bg);box-shadow:var(--shadow-sm);transition:transform var(--transition)}.settings-switch.active{background:var(--accent)}.settings-switch.active span{transform:translate(20px)}.profile-page{max-width:620px;margin:0 auto}.profile-topbar{position:relative;display:flex;align-items:center;justify-content:flex-start;margin:-4px 0 14px}.profile-stack{display:flex;flex-direction:column;gap:14px}.profile-avatar-button{display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;border:1px solid var(--border);background:var(--accent-light);color:var(--accent);font-family:var(--font);font-size:17px;font-weight:700;overflow:hidden;box-shadow:var(--shadow-sm);cursor:pointer;padding:0}.profile-avatar-button img{width:100%;height:100%;object-fit:cover}.profile-menu{position:absolute;top:calc(100% + 8px);left:0;z-index:20;width:min(280px,calc(100vw - 40px));padding:12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);box-shadow:var(--shadow-lg)}.profile-menu-email{padding:2px 2px 10px;color:var(--text-secondary);font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-menu-signout{width:100%;display:flex;align-items:center;justify-content:center;min-height:38px;border:none;border-radius:999px;background:#ff3b301a;color:var(--red);font-family:var(--font);font-size:14px;font-weight:600;cursor:pointer}.settings-section{display:flex;flex-direction:column;gap:14px}.settings-section-header h2{font-size:17px;font-weight:650}.settings-section-header p{color:var(--text-secondary);font-size:13px;margin-top:2px}.settings-list{display:flex;flex-direction:column;gap:8px}.settings-list-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-secondary)}.settings-actions{display:flex;flex-direction:column;gap:10px}.settings-actions .btn{width:100%}.progress-bar{height:4px;background:var(--bg-tertiary);border-radius:2px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--accent);border-radius:2px;transition:width var(--transition)}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:980px;font-size:12px;font-weight:500}.status-badge.pending{background:var(--bg-tertiary);color:var(--text-secondary)}.status-badge.analyzed{background:#0071e31a;color:var(--accent)}.status-badge.attempted,.status-badge.in_progress{background:#ff9f0a1a;color:var(--yellow)}.status-badge.scored,.status-badge.completed{background:#34c7591a;color:var(--green)}.score-circle{position:relative;display:inline-flex;align-items:center;justify-content:center}.score-circle svg{transform:rotate(-90deg)}.score-circle .score-value{position:absolute;font-size:20px;font-weight:700;color:var(--text-primary)}.phrase-highlight{background:#0071e31a;border-bottom:2px solid var(--accent);cursor:pointer;position:relative;padding:1px 2px;border-radius:3px;transition:background var(--transition)}.phrase-highlight:hover{background:#0071e333}.vocab-highlight{border-bottom:2px solid var(--yellow);border-radius:3px;cursor:help}.phrase-tooltip.vocab-tooltip{display:grid;gap:7px;position:fixed;bottom:auto;box-sizing:border-box;font-family:var(--font);line-height:1.45;white-space:normal;max-height:min(220px,45vh);overflow-y:auto;overflow-x:hidden;overflow-wrap:anywhere;transform:none;z-index:1000}.vocab-highlight.is-active{background-image:linear-gradient(#ffffff29,#ffffff29)}.vocab-tooltip .alt-item{display:grid;gap:5px;overflow-wrap:anywhere}.phrase-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--text-primary);color:#fff;padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;white-space:nowrap;z-index:10;box-shadow:var(--shadow-lg)}.phrase-tooltip:after{content:"";position:absolute;top:100%;left:var(--tooltip-arrow-left, 50%);transform:translate(-50%);border:6px solid transparent;border-top-color:var(--text-primary)}.vocab-tooltip[data-placement=below]:after{top:auto;bottom:100%;border-top-color:transparent;border-bottom-color:var(--text-primary)}.phrase-tooltip .alt-label{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:#fff9;margin-bottom:4px}.phrase-tooltip .alt-item{padding:2px 0}.phrase-tooltip-add{display:block;width:100%;margin-top:8px;padding:6px 0 2px;border:none;border-top:1px solid rgba(255,255,255,.15);background:transparent;color:#ffffffd9;font-size:12px;font-weight:500;font-family:var(--font);cursor:pointer;text-align:left;transition:color var(--transition)}.phrase-tooltip-add:hover{color:#fff}.phrase-tooltip-saved{margin-top:8px;padding:6px 0 2px;border-top:1px solid rgba(255,255,255,.15);color:var(--green);font-size:12px;font-weight:600}.phrase-tooltip .vocab-list-picker{white-space:normal;margin-top:8px}.vocab-sheet{position:fixed;left:14px;right:14px;bottom:calc(148px + env(safe-area-inset-bottom));z-index:1001;display:grid;grid-template-columns:minmax(0,1fr) auto;column-gap:12px;row-gap:5px;align-items:start;max-height:min(30vh,180px);padding:13px 14px;border-radius:14px;background:var(--text-primary);color:#fff;box-shadow:var(--shadow-lg);font-family:var(--font);font-size:14px;line-height:1.4;overflow-y:auto}.vocab-sheet .alt-label{grid-column:1 / 2;font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:#ffffff9e}.vocab-sheet .alt-item{grid-column:1 / -1;display:grid;gap:6px;overflow-wrap:anywhere}.vocab-pronunciation-row{display:flex;align-items:center;gap:8px;min-width:0}.vocab-audio-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid rgba(255,255,255,.24);border-radius:999px;background:#ffffff1a;color:#fff;padding:0;cursor:pointer}.vocab-audio-btn svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.vocab-audio-btn svg path:first-child{fill:currentColor;stroke:none}.vocab-audio-btn:active{transform:scale(.96)}.vocab-ipa{min-width:0;color:#ffffffb8;font-size:13px;overflow-wrap:anywhere}.vocab-definition{display:block}.vocab-sheet-close{grid-column:2 / 3;grid-row:1 / 2;border:none;background:transparent;color:#ffffffc7;font:inherit;font-size:13px;line-height:1;padding:2px 0 6px 8px;cursor:pointer}@media(min-width:641px)and (hover:hover)and (pointer:fine){.vocab-sheet{display:none}}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-secondary) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:skeleton-pulse 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes skeleton-pulse{0%{background-position:200% 0}to{background-position:-200% 0}}.feedback-section{margin-top:20px}.feedback-criteria{display:grid;gap:8px;margin-top:12px}.criteria-item{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--bg-secondary);border-radius:var(--radius-sm)}.criteria-name{font-size:13px;font-weight:600;text-transform:capitalize;min-width:100px}.criteria-score{font-size:14px;font-weight:700;min-width:30px}.criteria-comment{font-size:13px;color:var(--text-secondary);flex:1}.suggestions-list,.strengths-list{list-style:none;margin-top:8px}.suggestions-list li,.strengths-list li{padding:6px 0;font-size:14px;color:var(--text-secondary);display:flex;align-items:flex-start;gap:8px}.suggestions-list li:before{content:"→";color:var(--accent);font-weight:600}.strengths-list li:before{content:"✓";color:var(--green);font-weight:600}.empty-state{text-align:center;padding:48px 20px;color:var(--text-secondary)}.empty-state p{font-size:15px;margin-top:8px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000052;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px;z-index:200;animation:modal-fade-in .18s ease}.modal-panel{background:var(--bg);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:24px;width:100%;max-width:560px;max-height:calc(100vh - 64px);overflow-y:auto;animation:modal-pop-in .18s ease}.modal-close{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:50%;background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:background var(--transition)}.modal-close:hover{background:var(--bg-tertiary)}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-pop-in{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.vocab-due-badge{font-size:11px;font-weight:600;color:#fff;background:var(--accent);padding:2px 8px;border-radius:980px;flex-shrink:0}.vocab-status-badge{font-size:11px;font-weight:500;padding:2px 8px;border-radius:980px}.vocab-status-badge.pending{background:#ff9f0a1f;color:var(--yellow)}.vocab-status-badge.failed{background:#ff3b301a;color:var(--red)}.register-badge{font-size:11px;font-weight:500;color:var(--text-tertiary);background:var(--bg-tertiary);padding:2px 8px;border-radius:980px;white-space:nowrap}.reader-selection-result .register-badge{display:inline-block;margin-top:6px}.vocab-mastery-dots{display:inline-flex;align-items:center;gap:3px}.vocab-mastery-dot{width:7px;height:7px;border-radius:50%;background:var(--bg-tertiary)}.vocab-mastery-dot.filled{background:var(--accent)}.vocab-mastery-label{font-size:11px;color:var(--text-tertiary);margin-left:4px}.vocab-mastered-badge{font-size:11px;font-weight:600;color:var(--green);background:#34c7591a;padding:2px 8px;border-radius:980px}.vocab-option{width:100%;text-align:left;padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);font-size:14px;font-family:var(--font);line-height:1.5;color:var(--text-primary);cursor:pointer;transition:all var(--transition)}.vocab-option:hover:not(:disabled){border-color:var(--accent);background:var(--accent-light)}.vocab-option:disabled{cursor:default}.vocab-option.selected{border-color:var(--accent);background:var(--accent-light)}.vocab-option.correct{border-color:var(--green);background:#34c7591a;color:var(--text-primary);font-weight:500}.vocab-option.wrong{border-color:var(--red);background:#ff3b3014}.vocab-option.dimmed{opacity:.5}.vocab-list-picker{display:flex;flex-direction:column;gap:4px;padding:8px;background:var(--bg);border-radius:var(--radius-sm);min-width:200px;max-height:220px;overflow-y:auto}.vocab-list-picker-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);padding:2px 6px}.vocab-list-picker-item{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;padding:8px 10px;border:none;border-radius:6px;background:transparent;font-size:13px;font-weight:500;font-family:var(--font);color:var(--text-primary);cursor:pointer;transition:background var(--transition);text-align:left}.vocab-list-picker-item:hover:not(:disabled){background:var(--bg-secondary)}.vocab-list-picker-item:disabled{opacity:.5;cursor:default}.vocab-list-picker-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vocab-list-picker-count{font-size:11px;color:var(--text-tertiary);flex-shrink:0}.vocab-list-picker-add{color:var(--accent)}.vocab-list-picker-new{display:flex;gap:6px;padding:4px 2px}.vocab-list-picker-new .input{padding:7px 10px;font-size:13px}.vocab-list-picker-loading,.vocab-list-picker-error{font-size:12px;color:var(--text-tertiary);padding:6px}.vocab-list-picker-error{color:var(--red)}.reader-selection-save{margin-top:8px;border-top:1px solid var(--border);padding-top:4px}.bookshelf-grid{display:grid;gap:14px}.book-card{display:grid;grid-template-columns:88px minmax(0,1fr);gap:16px}.book-cover{width:88px;aspect-ratio:2 / 3;border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-secondary);box-shadow:inset 0 0 0 1px var(--border)}.book-cover img{width:100%;height:100%;object-fit:cover;display:block}.book-cover-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#e8f1ff,#f7f7f7);color:var(--accent);font-size:32px;font-weight:700}.book-card-body{min-width:0}.library-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px}.library-header-actions{display:flex;align-items:center;gap:8px}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid var(--border);border-radius:999px;background:var(--bg);color:var(--text-secondary);cursor:pointer;transition:background var(--transition),color var(--transition)}.icon-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.icon-btn-sm{width:26px;height:26px;font-size:17px;line-height:1}.library-filter-bar{display:flex;align-items:baseline;gap:10px;margin:-10px 0 18px}.library-filter-back{border:none;background:none;padding:0;color:var(--accent);font-size:13px;font-weight:500;cursor:pointer}.library-filter-name{font-size:15px;font-weight:650}.library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(118px,1fr));gap:20px 16px}.library-cell .book-cover{position:relative;width:100%;cursor:pointer;box-shadow:var(--shadow-sm),inset 0 0 0 1px var(--border);transition:box-shadow var(--transition)}.library-cell .book-cover:hover{box-shadow:var(--shadow-md),inset 0 0 0 1px var(--border)}.library-cell-footer{display:flex;align-items:center;justify-content:space-between;margin-top:4px;min-height:28px}.library-cell-progress{font-size:12px;color:var(--text-tertiary)}.book-finished-badge{position:absolute;right:6px;bottom:6px;display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:999px;background:var(--text-primary);color:#fff;box-shadow:0 0 0 2px #ffffffd9}.book-card .book-cover{position:relative}.book-menu-btn{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;width:28px;height:28px;border:none;border-radius:999px;background:none;color:var(--text-tertiary);cursor:pointer;transition:background var(--transition),color var(--transition)}.book-menu-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.menu-layer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:transparent}.menu-popover{position:fixed;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:6px;max-height:60vh;overflow-y:auto}.menu-sheet{inset:auto 0 0 0;border-radius:var(--radius) var(--radius) 0 0;padding:10px 10px calc(10px + env(safe-area-inset-bottom));max-height:70vh}.menu-layer:has(.menu-sheet){background:#00000040}.menu-title{padding:8px 10px 6px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-tertiary)}.menu-title-row{display:flex;align-items:center;justify-content:space-between}.menu-item{display:flex;align-items:center;gap:8px;width:100%;border:none;border-radius:var(--radius-sm);background:none;padding:9px 10px;font-size:14px;color:var(--text-primary);text-align:left;cursor:pointer;transition:background var(--transition)}.menu-item:hover{background:var(--bg-secondary)}.menu-item-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.menu-item-destructive{color:var(--red)}.menu-item-accent{color:var(--accent);font-weight:500}.menu-check{width:16px;flex:0 0 auto;color:var(--accent);font-weight:600}.menu-count{flex:0 0 auto;font-size:12px;color:var(--text-tertiary)}.menu-divider{height:1px;margin:6px 4px;background:var(--border)}.menu-empty{padding:10px;font-size:13px;color:var(--text-tertiary)}.menu-inline-form{padding:4px 6px 6px}.menu-inline-form input{width:100%;border:1px solid var(--border);border-radius:var(--radius-sm);padding:7px 9px;font-size:14px;font-family:inherit;background:var(--bg-secondary)}.menu-inline-form input:focus{outline:none;border-color:var(--accent);background:var(--bg)}.book-title{font-size:17px;font-weight:650;line-height:1.25;overflow-wrap:anywhere}.book-author{color:var(--text-secondary);font-size:13px;margin-top:4px}.book-meta-row{display:flex;justify-content:space-between;gap:12px;color:var(--text-tertiary);font-size:12px;margin-top:6px}.reader-finished-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:10px 0;padding:12px 16px;border-radius:12px;background:#34c7591f;color:var(--text-primary, #1d1d1f);font-size:14px;font-weight:550}.page-content:has(.reader-shell){max-width:1040px;padding-top:0}.reader-shell{max-width:960px;margin:0 auto;padding-bottom:18px}.reader-top-bar{position:sticky;top:0;z-index:30;display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:12px;padding:8px 0 7px;background:#f5f5f7eb;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}.reader-title-stack{min-width:0;text-align:left}.reader-book-title{font-size:14px;font-weight:650;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reader-book-progress{display:flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reader-icon-btn{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:34px;padding:0 12px;border:1px solid var(--border);border-radius:980px;background:#ffffffb8;color:var(--text-secondary);font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer}.reader-icon-btn:hover,.reader-icon-btn.active{background:var(--bg);color:var(--accent);border-color:#0071e33d}.reader-settings-popover{position:fixed;right:max(14px,calc((100vw - 420px)/2));bottom:calc(132px + env(safe-area-inset-bottom));z-index:45;width:min(360px,calc(100vw - 28px));margin:0 0 12px auto;padding:14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);box-shadow:var(--shadow-md)}.reader-settings-popover label{display:grid;grid-template-columns:90px minmax(0,1fr);align-items:center;gap:12px;color:var(--text-secondary);font-size:13px;font-weight:600}.reader-settings-popover label+label{margin-top:10px}.reader-page-label{color:var(--text-secondary);font-size:13px;white-space:nowrap}.reader-word-list-popover{position:fixed;left:50%;bottom:calc(132px + env(safe-area-inset-bottom));transform:translate(-50%);z-index:44;width:min(540px,calc(100vw - 28px));max-height:min(360px,45vh);margin:0;padding:12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);box-shadow:var(--shadow-md);overflow-y:auto}.reader-ai-panel{position:fixed;right:max(14px,calc((100vw - 960px)/2));bottom:calc(132px + env(safe-area-inset-bottom));z-index:48;display:grid;grid-template-rows:auto auto minmax(160px,1fr) auto auto;width:min(560px,calc(100vw - 28px));height:min(680px,calc(100vh - 184px));height:min(680px,calc(100dvh - 184px));max-height:min(680px,calc(100vh - 184px));max-height:min(680px,calc(100dvh - 184px));border:1px solid var(--border);border-radius:var(--radius-sm);background:#fffffff5;box-shadow:var(--shadow-lg);overflow:hidden;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}.reader-ai-header-actions{display:flex;align-items:center;gap:6px}.reader-ai-panel>*{min-width:0}.reader-ai-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 12px 8px 14px;border-bottom:1px solid var(--border)}.reader-ai-header h2{margin:0;font-size:15px;font-weight:700}.reader-ai-header p{margin:2px 0 0;color:var(--text-tertiary);font-size:12px}.reader-ai-icon-btn{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;width:34px;height:34px;border:none;border-radius:999px;background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:background var(--transition),color var(--transition),opacity var(--transition)}.reader-ai-icon-btn:hover{background:var(--bg-tertiary);color:var(--accent)}.reader-ai-icon-btn.active{background:var(--accent-light);color:var(--accent)}.reader-ai-icon-btn.primary{background:var(--accent);color:#fff}.reader-ai-icon-btn.primary:hover{background:var(--accent-hover);color:#fff}.reader-ai-icon-btn.recording{background:var(--red);color:#fff;animation:mic-pulse 1.5s ease-in-out infinite}.reader-ai-icon-btn:disabled{opacity:.4;cursor:not-allowed;animation:none}.reader-ai-icon-btn svg,.reader-ai-state>svg{width:19px;height:19px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}@media(min-width:1180px){.page-content:has(.reader-shell.ai-pinned){max-width:none}.reader-shell.ai-pinned{max-width:none;margin-left:max(20px,calc((100vw - 1248px)/2));margin-right:calc(460px + max(20px,calc((100vw - 1248px)/2)))}.reader-shell.ai-pinned .reader-page,.reader-shell.ai-pinned .reader-top-bar{width:100%;max-width:760px;margin-left:auto;margin-right:auto}.reader-ai-panel.pinned{top:76px;right:max(20px,calc((100vw - 1248px)/2));bottom:calc(92px + env(safe-area-inset-bottom));width:420px;height:auto;max-height:none}}@media(max-width:1179px){.reader-ai-pin-btn{display:none}}.reader-ai-scope{display:grid;grid-template-columns:1fr 1fr;gap:4px;margin:10px 12px 8px;padding:4px;border-radius:999px;background:var(--bg-secondary)}.reader-ai-scope button{min-width:0;height:30px;border:none;border-radius:999px;background:transparent;color:var(--text-secondary);font-family:var(--font);font-size:12px;font-weight:650;cursor:pointer}.reader-ai-scope button.active{background:var(--bg);color:var(--accent);box-shadow:0 1px 3px #00000014}.reader-ai-messages{min-height:0;padding:4px 12px 12px;overflow-y:auto;overflow-x:hidden}.reader-ai-state{display:grid;justify-items:center;gap:8px;padding:28px 20px;color:var(--text-secondary);text-align:center}.reader-ai-state.muted{color:var(--text-tertiary)}.reader-ai-state strong{color:var(--text-primary);font-size:14px}.reader-ai-state p{max-width:320px;margin:0;font-size:13px;line-height:1.45}.reader-ai-progress{width:min(260px,100%);height:6px;overflow:hidden;border-radius:999px;background:var(--bg-tertiary)}.reader-ai-progress span{display:block;height:100%;min-width:2px;border-radius:inherit;background:var(--accent);transition:width .2s ease}.reader-ai-message{width:fit-content;max-width:86%;box-sizing:border-box;margin-bottom:10px;padding:9px 11px;border-radius:14px;font-size:13px;line-height:1.45;overflow-wrap:anywhere;word-break:break-word}.reader-ai-message-row{display:grid;width:fit-content;max-width:86%;margin-bottom:10px;gap:4px}.reader-ai-message-row.user{justify-items:end;margin-left:auto}.reader-ai-message-row.assistant{justify-items:start;margin-right:auto}.reader-ai-message-row .reader-ai-message{max-width:100%;margin-bottom:0}.reader-ai-message p{margin:0;white-space:pre-wrap;overflow-wrap:anywhere;word-break:break-word}.reader-ai-message.user{margin-left:auto;border-bottom-right-radius:5px;background:var(--accent);color:#fff}.reader-ai-message.assistant{margin-right:auto;border-bottom-left-radius:5px;background:var(--bg-secondary);color:var(--text-primary)}.reader-ai-message.pending{display:inline-flex;align-items:center;gap:8px}.reader-ai-message-actions{display:flex;align-items:center;gap:4px;min-height:26px;opacity:.76}.reader-ai-message-actions button{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border:none;border-radius:999px;background:transparent;color:var(--text-tertiary);cursor:pointer;transition:background var(--transition),color var(--transition),opacity var(--transition)}.reader-ai-message-actions button:hover,.reader-ai-message-actions button.is-confirmed{background:var(--bg-secondary);color:var(--accent)}.reader-ai-message-actions button:disabled{opacity:.35;cursor:not-allowed}.reader-ai-message-actions svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.reader-ai-error{margin:0 12px 8px;padding:8px 10px;max-width:calc(100% - 24px);box-sizing:border-box;border-radius:8px;background:#ff3b3014;color:var(--red);font-size:12px;font-weight:600;overflow-wrap:anywhere;word-break:break-word;white-space:pre-wrap}.reader-ai-editing{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:0 12px 8px;padding:8px 10px;border-radius:8px;background:var(--accent-light);color:var(--text-secondary);font-size:12px}.reader-ai-editing span{min-width:0;line-height:1.35}.reader-ai-editing button{flex-shrink:0;border:none;border-radius:999px;background:var(--bg);color:var(--accent);font-family:var(--font);font-size:12px;font-weight:650;padding:5px 10px;cursor:pointer}.reader-ai-editing button:disabled{opacity:.45;cursor:not-allowed}.reader-ai-composer{position:relative;display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:7px;align-items:end;padding:10px 12px 12px;border-top:1px solid var(--border);background:#ffffffe6}.reader-ai-composer textarea{min-height:42px;max-height:118px;padding:11px 12px;border:1px solid var(--border);border-radius:18px;background:var(--bg);color:var(--text-primary);font-family:var(--font);font-size:13px;line-height:1.4;resize:none;outline:none}.reader-ai-composer textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0071e31f}.reader-ai-composer textarea:disabled{color:var(--text-tertiary);background:var(--bg-secondary)}.reader-ai-recording{position:absolute;right:94px;bottom:17px;display:flex;align-items:center;gap:6px;pointer-events:none}.reader-ai-spinner{width:16px;height:16px;border:2px solid rgba(0,113,227,.18);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}.word-list-coverage{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px;width:100%}.word-list-coverage button{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:4px 8px;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#ffffff8f;color:var(--text-primary);font-family:var(--font);text-align:left;opacity:.82;cursor:pointer;transition:border-color var(--transition),background var(--transition),opacity var(--transition)}.word-list-coverage button.active,.word-list-coverage button:hover{opacity:1;background:var(--bg)}.word-list-coverage span{width:9px;height:9px;border-radius:50%;grid-row:span 2}.word-list-coverage strong{min-width:0;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.word-list-coverage small{color:var(--text-secondary);font-size:11px}.reader-page{max-width:760px;min-height:58vh;margin:0 auto;padding:16px 14px 20px;color:var(--text-primary);background:transparent;outline:none}.reader-paragraph{margin-bottom:1.25em}.reader-block-heading{margin:1.8em 0 1em}.reader-paragraph:last-child{margin-bottom:0}.reader-paragraph p,.reader-heading,.reader-list-item,.reader-figure figcaption{margin:0;font-family:Georgia,Times New Roman,serif;overflow-wrap:break-word}.reader-heading{color:var(--text-primary);font-weight:650;line-height:1.18}.reader-heading-1{font-size:1.45em}.reader-heading-2{font-size:1.28em}.reader-heading-3,.reader-heading-4,.reader-heading-5,.reader-heading-6{font-size:1.12em}.reader-page a{color:var(--accent);text-decoration:underline;text-decoration-thickness:.08em;text-underline-offset:.12em}.reader-list-item{display:grid;grid-template-columns:2.2em minmax(0,1fr);gap:.2em;margin:0}.reader-list-marker{color:var(--text-primary);text-align:right;-webkit-user-select:none;user-select:none}.reader-list-text{min-width:0}.reader-figure{margin:1.2em 0 1.45em}.reader-figure img{display:block;width:100%;max-height:min(58vh,560px);object-fit:contain;border-radius:var(--radius-sm)}.reader-figure figcaption{margin-top:.55em;color:var(--text-secondary);font-size:.82em;line-height:1.45}.reader-bottom-bar{position:fixed;left:0;right:0;bottom:calc(72px + env(safe-area-inset-bottom));z-index:60;display:flex;align-items:center;justify-content:center;gap:8px;width:auto;max-width:none;margin:0;padding:0 12px;pointer-events:none}.reader-bottom-bar .reader-page-label{text-align:center;overflow:hidden;text-overflow:ellipsis}.reader-center-nav{display:flex;align-items:center;justify-content:center;gap:4px;min-width:0;max-width:calc(100vw - 112px);padding:6px;border:1px solid var(--border);border-radius:980px;background:#ffffffe0;box-shadow:var(--shadow-md);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);pointer-events:auto}.reader-nav-btn{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;width:36px;height:36px;border:none;border-radius:999px;background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:background var(--transition),color var(--transition),opacity var(--transition)}.reader-page-nav-btn{width:42px;height:42px;background:#ffffffe0;box-shadow:var(--shadow-md);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);pointer-events:auto}.reader-center-nav .reader-nav-btn{background:transparent}.reader-nav-btn.primary{background:var(--accent);color:#fff}.reader-nav-btn.active,.reader-nav-btn:hover{background:var(--bg-tertiary);color:var(--accent)}.reader-nav-btn.primary:hover{background:var(--accent-hover);color:#fff}.reader-nav-btn:disabled{opacity:.38;cursor:not-allowed}.reader-nav-icon{width:10px;height:10px;border-right:2px solid currentColor;border-bottom:2px solid currentColor}.reader-nav-icon.prev{transform:rotate(135deg);margin-left:3px}.reader-nav-icon.next{transform:rotate(-45deg);margin-right:3px}.reader-tool-btn{position:relative}.reader-tool-btn svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.reader-term-badge{position:absolute;right:-8px;top:-4px;min-width:22px;max-width:none;height:18px;padding:0 5px;border:1px solid var(--bg);border-radius:999px;background:var(--accent);color:#fff;font-size:10px;font-weight:700;line-height:16px;white-space:nowrap}.reader-selection-menu{position:fixed;z-index:80;width:min(360px,calc(100vw - 28px));max-height:min(420px,calc(100vh - 96px));padding:10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fffffff7;box-shadow:var(--shadow-lg);overflow-y:auto;transform:translate(-50%);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}.reader-selection-menu.above{transform:translate(-50%,-100%)}.reader-selection-menu.below{transform:translate(-50%)}.reader-selection-text{max-height:92px;overflow-y:auto;padding:4px 2px 10px;color:var(--text-primary);font-family:Georgia,Times New Roman,serif;font-size:15px;line-height:1.45;overflow-wrap:anywhere}.reader-selection-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.reader-selection-menu button{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-width:0;height:34px;border:1px solid var(--border);border-radius:var(--radius-sm);padding:0 8px;background:var(--bg-secondary);color:var(--text-primary);font-family:var(--font);font-size:12px;font-weight:650;cursor:pointer}.reader-selection-menu button:hover:not(:disabled){background:var(--bg-tertiary)}.reader-selection-menu button.is-confirmed{border-color:#0071e357;background:var(--accent-light);color:var(--accent);box-shadow:0 0 0 3px #0071e31a}.reader-selection-menu button:disabled{cursor:not-allowed;opacity:.58}.reader-selection-menu button svg{width:15px;height:15px;flex:0 0 auto;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.reader-selection-error,.reader-selection-result{margin-top:10px;padding-top:10px;border-top:1px solid var(--border);font-size:13px;line-height:1.5}.reader-selection-error{color:var(--danger);overflow-wrap:anywhere}.reader-selection-result{color:var(--text-primary);overflow-wrap:break-word}.reader-selection-result p{margin:0}.reader-selection-result p+p{margin-top:8px}.reader-selection-images{margin-top:10px;padding-top:10px;border-top:1px solid var(--border);display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.reader-selection-image{display:block;aspect-ratio:1 / 1;overflow:hidden;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-tertiary)}.reader-selection-image img{width:100%;height:100%;object-fit:cover;display:block}@media(hover:none),(pointer:coarse),(max-width:640px){.reader-selection-menu{left:12px!important;right:12px;top:auto!important;bottom:calc(116px + env(safe-area-inset-bottom));z-index:120;width:auto;max-height:min(42vh,360px);transform:none!important}.reader-selection-text{max-height:84px}.reader-selection-actions{gap:8px}.reader-selection-menu button{height:38px}}.reader-drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70;background:#0000002e}.reader-toc-drawer{width:min(360px,86vw);height:100%;padding:0 18px 18px;background:var(--bg);box-shadow:var(--shadow-lg);overflow-y:auto}.reader-drawer-header{position:sticky;top:0;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0 -18px 16px;padding:calc(18px + env(safe-area-inset-top)) 18px 14px;border-bottom:1px solid rgba(0,0,0,.04);background:#fffffff0;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}.reader-drawer-header h2{font-size:20px}.reader-toc-list{display:flex;flex-direction:column;gap:6px}.reader-toc-list button{display:flex;flex-direction:column;gap:3px;width:100%;padding:11px 12px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-primary);font-family:var(--font);text-align:left;cursor:pointer}.reader-toc-list button:hover,.reader-toc-list button.active{background:var(--accent-light)}.reader-toc-list button:disabled{cursor:default;opacity:.64}.reader-toc-list button:disabled:hover{background:transparent}.reader-toc-node,.reader-toc-children{display:flex;flex-direction:column;gap:4px}.reader-toc-list small{color:var(--text-secondary)}@media(max-width:640px){.library-grid{grid-template-columns:repeat(3,1fr);gap:12px 10px}.library-cell-footer{min-height:24px;margin-top:2px}.library-cell-progress{font-size:11px}.book-finished-badge{width:17px;height:17px;right:4px;bottom:4px}.page-content:has(.admin-page){padding-left:16px;padding-right:16px;overflow-x:hidden}.admin-page .page-title{font-size:24px;margin-bottom:18px}.admin-page section{min-width:0}.admin-page .card{padding:16px;overflow-x:auto!important;-webkit-overflow-scrolling:touch}.admin-page .card[style*="padding: 0"]{padding:0}.admin-form-grid,.admin-form-grid-color,.admin-group-form,.admin-import-grid{grid-template-columns:1fr!important}.admin-form-grid input[type=color],.admin-import-grid .admin-color{width:100%;max-width:112px}.admin-field input{width:100%}.stat-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.admin-page .input{min-width:0!important;width:100%}.admin-page input[type=file].input{font-size:13px}.admin-page .btn{max-width:100%}.book-card{grid-template-columns:72px minmax(0,1fr);gap:12px}.book-cover{width:72px}.page-content:has(.reader-shell){padding-left:14px;padding-right:14px}.reader-top-bar{grid-template-columns:auto minmax(0,1fr)}.reader-title-stack{text-align:left}.study-strip,.reader-bottom-bar{max-width:100%}.study-strip{flex-direction:column}.word-list-coverage{grid-template-columns:1fr}.reader-page{padding-left:4px;padding-right:4px}.reader-ai-panel{left:14px;right:14px;width:auto;bottom:calc(126px + env(safe-area-inset-bottom));height:min(680px,calc(100vh - 148px));height:min(680px,calc(100dvh - 148px));max-height:min(620px,calc(100vh - 168px));max-height:min(680px,calc(100dvh - 148px))}.reader-ai-message,.reader-ai-message-row{max-width:92%}.reader-bottom-bar{gap:6px;padding:0 10px}.reader-center-nav{gap:3px;max-width:calc(100vw - 104px);padding:5px}.reader-nav-btn{width:34px;height:34px}.reader-page-nav-btn{width:40px;height:40px}}.error-message{background:#ff3b3014;color:var(--red);padding:12px 16px;border-radius:var(--radius-sm);font-size:14px;margin-bottom:16px}.example-block{background:#34c7590f;border-left:3px solid var(--green);padding:16px;border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin-top:16px}.example-block .label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--green);margin-bottom:8px}.example-block p{font-size:15px;line-height:1.6;color:var(--text-primary)}.example-chevron{transition:transform var(--transition);flex-shrink:0}.example-chevron-expanded{transform:rotate(90deg)}.example-body{overflow:hidden;max-height:2000px;opacity:1;transition:max-height .3s ease,opacity .2s ease}.example-body-collapsed{max-height:0;opacity:0}.improved-block{background:#0071e30f;border-left:3px solid var(--accent);padding:16px;border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin-top:16px}.improved-block .label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--accent);margin-bottom:8px}.improved-block p{font-size:15px;line-height:1.6;color:var(--text-primary)}.textarea-wrapper{position:relative}.mic-btn{position:absolute;bottom:10px;right:10px;width:36px;height:36px;border-radius:50%;border:none;background:var(--bg-secondary);color:var(--text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition);z-index:2}.mic-btn:hover{background:var(--bg-tertiary);color:var(--text-secondary)}.mic-btn.recording{background:var(--red);color:#fff;animation:mic-pulse 1.5s ease-in-out infinite}.mic-btn.recording:hover{background:#e0342b;color:#fff}.mic-btn:disabled{opacity:.4;cursor:not-allowed;animation:none}@keyframes mic-pulse{0%,to{box-shadow:0 0 #ff3b3066}50%{box-shadow:0 0 0 8px #ff3b3000}}.recording-indicator{position:absolute;bottom:14px;right:54px;display:flex;align-items:center;gap:8px;z-index:2}.recording-timer{font-size:13px;font-weight:600;font-variant-numeric:tabular-nums;color:var(--text-secondary)}.recording-timer.warning{color:var(--red)}.waveform-canvas{display:block;flex-shrink:0}.play-btn{display:inline-flex;align-items:center;gap:5px;height:26px;padding:0 10px;border:none;border-radius:980px;background:var(--bg-secondary);color:var(--text-tertiary);font-family:var(--font);font-size:11px;font-variant-numeric:tabular-nums;cursor:pointer;transition:all var(--transition);flex-shrink:0}.play-btn:hover{background:var(--bg-tertiary);color:var(--text-secondary)}.play-btn-error{color:#e55}.play-btn-time{color:var(--text-tertiary);font-weight:500;letter-spacing:.01em}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.mt-24{margin-top:24px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.text-secondary{color:var(--text-secondary)}.text-small{font-size:13px}
