.navbar{display:flex;justify-content:space-between;align-items:center;padding:12px 24px;background:var(--color-card);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:100}.navbar-brand{font-size:20px;font-weight:700;color:var(--color-primary);text-decoration:none}.navbar-links{display:flex;align-items:center;gap:16px}.navbar-link{color:var(--color-text-muted);font-size:14px}.app-layout{min-height:100vh;background:#fff}.app-main{max-width:var(--max-width-reader);margin:0 auto;padding:24px 20px}.admin-layout{min-height:100vh;background:var(--color-admin-bg)}.admin-container{display:flex;max-width:var(--max-width-admin);margin:0 auto}.admin-sidebar{width:200px;padding:20px 16px 20px 24px;flex-shrink:0;position:sticky;top:56px;height:calc(100vh - 56px);overflow-y:auto}.admin-nav-link{display:block;padding:8px 12px;margin-bottom:4px;border-radius:6px;color:var(--color-text-muted);font-size:14px;text-decoration:none;transition:all .15s}.admin-nav-link:hover{background:#0000000d;color:var(--color-text);text-decoration:none}.admin-nav-link.active{background:var(--color-primary);color:#fff}.admin-main{flex:1;padding:24px 24px 24px 12px;min-width:0}.admin-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.admin-page-header h1{margin:0}.admin-actions{display:flex;gap:8px;align-items:center}.admin-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:16px}.stat-number{font-size:32px;font-weight:700;color:var(--color-primary)}.admin-sub-nav{display:flex;gap:16px}.admin-select{padding:4px 8px;border-radius:4px;border:1px solid var(--color-border);font-size:14px;font-family:var(--font-ui)}.admin-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.admin-card-header h2{margin:0}.admin-filter-bar{display:flex;gap:16px;align-items:center;flex-wrap:wrap;font-size:14px;margin-bottom:16px}.admin-form .form-group{margin-bottom:4px}.admin-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;font-size:13px}.admin-table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.admin-tab-bar{display:flex;gap:0;margin-bottom:20px;border-bottom:2px solid var(--color-border);overflow-y:hidden}.admin-detail-footer{position:sticky;bottom:0;background:var(--color-card);padding:12px 0;border-top:1px solid var(--color-border);margin-top:16px;display:flex;gap:12px;align-items:center;z-index:10}.navbar-hamburger{display:none}.admin-page h1{font-size:24px;margin-bottom:20px}.admin-page h2{font-size:18px;margin:20px 0 12px}.admin-card{background:var(--color-card);border-radius:8px;padding:20px;border:1px solid var(--color-border);margin-bottom:16px}.admin-table{width:100%;border-collapse:collapse;font-size:14px}.admin-table th{text-align:left;padding:10px 12px;border-bottom:2px solid var(--color-border);font-weight:600}.admin-table td{padding:10px 12px;border-bottom:1px solid var(--color-border)}.admin-table tr:hover{background:#00000005}.admin-form label{display:block;font-size:12px;font-weight:600;margin-bottom:4px;color:var(--color-text-muted)}.admin-form input,.admin-form select,.admin-form textarea{width:100%;padding:6px 8px;border:1px solid var(--color-border);border-radius:6px;font-size:16px;margin-bottom:8px;font-family:var(--font-ui)}.admin-form textarea{min-height:80px;resize:vertical}.admin-form .form-row{display:flex;gap:12px}.admin-form .form-row>*{flex:1}.status-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:12px;font-weight:600}.status-in_review{background:#ffeaa7;color:#856404}.status-published_ai_voice{background:#dfe6e9;color:#2d3436}.status-published_manual_voice{background:#a29bfe;color:#fff}.status-published_manual_voice_music{background:#6c5ce7;color:#fff}.status-success{background:#d4edda;color:#155724}.status-partial{background:#fff3cd;color:#856404}.status-failed{background:#f8d7da;color:#721c24}.status-polly{background:#dfe6e9;color:#2d3436}.status-elevenlabs{background:#d0e4ff;color:#1347b8}.dashboard-mobile-nav{display:none}@media (max-width: 768px){.dashboard-mobile-nav{display:flex!important}.dashboard-debug-btn{display:none}.navbar{padding:10px 16px}.app-main{padding-left:16px;padding-right:16px}.navbar-hamburger{display:block;background:none;border:none;font-size:22px;cursor:pointer;padding:4px 8px;margin-right:8px;color:var(--color-text)}.navbar-links{gap:10px}.navbar-link{font-size:13px}.admin-sidebar{position:fixed;top:0;left:-260px;width:260px;height:100vh;z-index:200;background:var(--color-card);border-right:1px solid var(--color-border);transition:left .25s ease;padding-top:60px}.admin-sidebar.open{left:0}.admin-sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:199}.admin-main{padding:16px 12px}.admin-page h1{font-size:20px;margin-bottom:16px}.admin-page-header{flex-direction:column;align-items:flex-start;gap:12px}.admin-card-header{flex-direction:column;align-items:flex-start;gap:8px}.admin-actions{flex-wrap:wrap}.admin-card{padding:16px 12px}.admin-table-scroll{margin:0 -12px;padding:0 12px}.admin-card-grid{grid-template-columns:1fr}.admin-filter-bar{flex-direction:column;align-items:flex-start;gap:10px}.admin-info-grid{grid-template-columns:1fr}.admin-form .form-row{flex-direction:column;gap:0}.admin-sub-nav{flex-wrap:wrap;gap:10px}.admin-tab-bar{overflow-x:auto}}.invite-form{display:flex;flex-direction:column;gap:8px}.invite-field{display:flex;flex-direction:column;gap:4px}.invite-label{font-size:12px;font-weight:600;color:var(--color-text-muted)}.invite-required{color:var(--color-love)}.invite-input{width:100%;box-sizing:border-box;padding:6px 8px;font-size:13px;border-radius:6px;border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text);font-family:inherit}.invite-input:focus{outline:2px solid var(--color-primary-light);outline-offset:-2px}.invite-readonly{background:#f5f5f5;color:var(--color-text-muted)}.invite-textarea{min-height:110px;resize:vertical;font-family:inherit}.invite-hint{font-size:11px;color:var(--color-text-muted)}.invite-preview{white-space:pre-wrap;padding:10px;min-height:80px;border:1px solid var(--color-border);border-radius:6px;font-size:13px}.invite-error{font-size:11px;color:var(--color-love)}.invite-toast-wrap{position:fixed;right:16px;bottom:16px;z-index:1100}.page-reader{position:relative}.ra-word{transition:background-color .12s ease;border-radius:2px;padding:0 1px}.ra-word-active{background-color:#ffd54f80}.page-title{font-weight:700;line-height:1.3;margin-bottom:4px}.page-title.font-sm{font-size:calc(var(--font-size-sm) * 1.5)}.page-title.font-md{font-size:calc(var(--font-size-md) * 1.5)}.page-title.font-lg{font-size:calc(var(--font-size-lg) * 1.5)}.page-title.font-xl{font-size:calc(var(--font-size-xl) * 1.5)}.page-title.font-xxl{font-size:calc(var(--font-size-xxl) * 1.5)}.reader-toolbar{display:flex;justify-content:space-between;align-items:flex-end;padding:8px 0 5px;border-bottom:1px solid var(--color-border);margin-bottom:.8em}.reader-toolbar:has(+.rtm-player.rtm-active){margin-bottom:0}.home-next{display:flex;flex-direction:column;align-items:center;gap:12px;margin-top:32px;margin-bottom:40px}.home-welcome-back{color:var(--color-text-muted);font-size:.9em;margin:0}.home-next-btn.btn{padding:15px 30px;font-size:21px;border-radius:10px}.font-controls{display:flex;gap:4px}.font-btn{background:none;border:1px solid var(--color-primary);border-radius:4px;padding:4px 10px;font-size:13px;cursor:pointer;color:var(--color-primary)}.font-btn-lg{font-size:17px}.font-btn:hover{background:#1a56db0f}.font-btn:disabled{opacity:.4;cursor:not-allowed}.sentence-end-icons{display:inline-block;margin-left:3px;vertical-align:baseline;white-space:nowrap}.sentence-icon-slot{display:inline-block;vertical-align:baseline;line-height:1;margin-bottom:-6px;border-bottom:2px solid #378add}.sentence-icon-slot+.sentence-icon-slot{margin-left:6px}.sentence-end-icons button{background:none;border:none;cursor:pointer;padding:0;line-height:1;opacity:.75;transition:opacity .15s}.sentence-end-icons button:hover{opacity:1}.sentence-end-icons button[data-icon-type=footnote],.sentence-end-icons button[data-icon-type=comment]{position:relative;top:-.5em;vertical-align:baseline}.sentence-leading-emoji{display:inline-block;font-size:.85em;margin:0 3px;position:relative;top:-.5em;vertical-align:baseline;line-height:1}.bottom-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:200;display:flex;align-items:flex-end;justify-content:center}.bottom-sheet{background:#fff;border-radius:18px 18px 0 0;width:100%;max-width:640;padding:20px 22px 28px;box-shadow:0 -4px 24px #0000001f}.bottom-sheet-scrollable{max-height:65vh;display:flex;flex-direction:column}.footnote-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0000004d;display:flex;align-items:flex-end;justify-content:center}.footnote-popup{background:#fff;border-radius:16px 16px 0 0;padding:24px;max-width:500px;width:100%;max-height:60vh;overflow-y:auto;position:relative}.footnote-close{position:absolute;top:12px;right:16px;background:none;border:none;font-size:24px;cursor:pointer;color:var(--color-text-muted)}.footnote-item{margin-bottom:16px}.footnote-text{font-family:var(--font-body);line-height:1.6;margin-bottom:8px}.footnote-link{display:inline-block;color:var(--color-primary);font-weight:500;font-size:14px}.page-rating{padding:16px 0;border-top:1px solid var(--color-border);margin-top:24px}.rating-inline{display:flex;align-items:center;gap:12px}.rating-prompt{font-size:14px;color:var(--color-text-muted);margin:0}.rating-buttons{display:flex;gap:8px}.rating-btn{background:none;border:1px solid var(--color-border);border-radius:8px;padding:6px 12px;font-size:16px;cursor:pointer;transition:all .15s}.rating-btn:hover{background:#0000000d;border-color:var(--color-primary)}.page-comment{margin-top:16px}.page-comment textarea{width:100%;padding:10px;border:1px solid var(--color-border);border-radius:8px;font-family:var(--font-ui);font-size:14px;resize:vertical}.comment-actions{margin-top:8px;text-align:right}.audio-player-bar{position:sticky;bottom:0;background:var(--color-card);border-top:1px solid var(--color-border);padding:10px 0;z-index:50;margin-top:24px}.audio-controls{display:flex;align-items:center;gap:12px;padding:0}.audio-ctrl-btn{background:none;border:1px solid var(--color-border);border-radius:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-primary);transition:background .15s,border-color .15s}.audio-ctrl-btn:hover{background:#1a56db0f;border-color:var(--color-primary)}.audio-time{font-size:13px;font-family:var(--font-ui);color:var(--color-text-muted);min-width:80px}.choice-links{margin-top:32px;border-top:1px solid var(--color-border);padding-top:16px}.whats-next{font-size:.9em;color:var(--color-text);margin-bottom:8px;font-weight:700}.choice-link{display:block;color:var(--color-primary);font-size:1em;text-decoration:none;padding:6px 0;cursor:pointer}.choice-link:hover{text-decoration:underline}.choice-link-return{color:var(--color-accent)}.media-block{margin:.4em 0}.media-block img{max-width:100%;height:auto;border-radius:8px}.media-block figcaption{font-size:14px;color:var(--color-text-muted);margin-top:8px;text-align:center;font-family:var(--font-ui)}.media-block.audio audio{width:100%}.btn{display:inline-flex;align-items:center;gap:6px;border:none;border-radius:6px;font-weight:500;font-size:13px;transition:all .15s;background-image:linear-gradient(to bottom,#ffffff1f,#00000014);box-shadow:0 1px 2px #0000001a,inset 0 1px #ffffff26;text-shadow:0 1px 1px rgba(0,0,0,.1);letter-spacing:.01em}.btn-sm{padding:5px 10px;font-size:12px}.btn-md{padding:7px 14px;font-size:13px}.btn-lg{padding:10px 20px;font-size:14px}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover{background-color:var(--color-primary-hover);box-shadow:0 2px 4px #00000026,inset 0 1px #ffffff1a}.btn-secondary{background-color:var(--color-secondary);color:var(--color-text);text-shadow:none}.btn-secondary:hover{background-color:var(--color-secondary-hover);box-shadow:0 2px 4px #0000001a,inset 0 1px #fff3}.btn-ghost{background:none;color:var(--color-primary);background-image:none;box-shadow:none;text-shadow:none}.btn-ghost:hover{background:#1a56db0f}.btn-danger{background-color:var(--color-love);color:#fff}.btn-danger:hover{background-color:var(--color-danger-hover);box-shadow:0 2px 4px #00000026,inset 0 1px #ffffff1a}.btn-primary-outline{background:transparent;color:var(--color-primary);border:1px solid var(--color-primary);background-image:none;box-shadow:none;text-shadow:none}.btn-primary-outline:hover{background:#1a56db14;box-shadow:none}.btn-danger-outline{background:transparent;color:#e74c3c;border:1px solid #e74c3c;background-image:none;box-shadow:none;text-shadow:none}.btn-danger-outline:hover{background:#e74c3c14;box-shadow:none}.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#00000080;display:flex;align-items:center;justify-content:center;padding:20px}.modal-content{background:var(--color-card);border-radius:12px;max-width:600px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:8px 16px;border-bottom:1px solid var(--color-border)}.modal-header h3{margin:0;font-size:14px}.modal-close{background:none;border:none;font-size:20px;color:var(--color-text-muted);cursor:pointer}.modal-body{padding:16px}.modal-footer{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--color-border);justify-content:flex-end;flex-wrap:wrap}.progress-bar{height:4px;background:var(--color-border);border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:var(--color-primary);border-radius:2px;transition:width .3s}.spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite;margin:40px auto}@media (max-width: 768px){.modal-overlay{padding:16px}.modal-content{max-width:calc(100vw - 32px);border-radius:8px}.modal-body{padding:16px}.modal-header{padding:12px 16px}}.ib-input{width:100%;padding:7px 10px;border:1px solid var(--color-border);border-radius:6px;font-size:16px;font-family:var(--font-ui);color:var(--color-text);background:var(--color-card);outline:none;transition:border-color .15s}.ib-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #1a56db1a}.ib-input.error{border-color:var(--color-love)}.rtm-player{position:sticky;top:var(--navbar-height, 56px);z-index:90;background:var(--color-card, #fff);border-bottom:1px solid var(--color-border);max-height:0;opacity:0;overflow:hidden;transition:max-height .45s ease,opacity .3s ease}.rtm-player.rtm-active{max-height:72px;opacity:1;margin-bottom:.8em}.rtm-row{display:flex;align-items:center;gap:8px;padding:10px 0;font-family:var(--font-ui)}.rtm-speed{flex-shrink:0;display:flex;align-items:center;gap:2px;background:#f3f4f6;border-radius:999px;padding:2px}.rtm-speed-btn{width:28px;height:28px;border-radius:999px;background:none;border:none;color:var(--color-text);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .15s}.rtm-speed-btn:hover:not(:disabled){background:#e5e7eb}.rtm-speed-btn:disabled{opacity:.3;cursor:not-allowed}.rtm-speed-value{width:44px;text-align:center;font-size:13px;font-weight:500;font-variant-numeric:tabular-nums;color:var(--color-text)}.rtm-time{flex-shrink:0;font-size:12px;color:var(--color-text-muted);font-variant-numeric:tabular-nums}.rtm-progress{flex:1;position:relative;height:6px;background:#e5e7eb;border-radius:999px;cursor:pointer}.rtm-progress-fill{position:absolute;top:0;left:0;height:100%;background:var(--color-text);border-radius:999px;transition:width .15s linear}.rtm-progress-thumb{position:absolute;top:50%;transform:translateY(-50%);width:14px;height:14px;border-radius:50%;background:var(--color-text);box-shadow:0 1px 3px #0000002e;transition:transform .15s}.rtm-progress:hover .rtm-progress-thumb{transform:translateY(-50%) scale(1.1)}.rtm-icon-btn{flex-shrink:0;width:32px;height:32px;border-radius:50%;background:none;border:none;cursor:pointer;color:var(--color-text);display:inline-flex;align-items:center;justify-content:center;transition:background .15s}.rtm-icon-btn:hover{background:#f3f4f6}.rtm-play{flex-shrink:0;width:40px;height:40px;border-radius:50%;background:var(--color-text);color:#fff;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .15s}.rtm-play:hover{background:#4b5563}.rtm-vf-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;background:#f3f4f6;color:var(--color-text-muted);border:1px solid transparent;cursor:pointer;flex-shrink:0}.rtm-vf-chip.rtm-vf-on{background:#eef2ff;color:#3730a3;border-color:#c7d2fe}.rtm-vf-chip.rtm-vf-listening{background:#dcfce7;color:#14532d;border-color:#86efac}.rtm-vf-chip.rtm-vf-unsupported{cursor:default;opacity:.7}.feedback-hint-toast-body p{margin:0}.feedback-hint-toast-body p+p{margin-top:.6em}:root{--color-primary: #1a56db;--color-card: #ffffff;--color-primary-bg: #eff6ff;--color-selected-bg: #f5f8ff;--color-success: #059669;--color-success-bg: #d1fae5;--color-danger: #dc2626;--color-danger-bg: #fef2f2;--color-danger-outline: #fca5a5;--color-warning-bg: #fef3c7;--color-warning-border: #fde68a;--color-border-subtle: #eef0f3;--badge-info-bg: #e6f0ff;--badge-info-fg: #0b4098;--badge-warn-bg: #fff0e6;--badge-warn-fg: #a04a00;--text-warn: #9a6400;--input-h: 28px;--input-px: 6px;--btn-h-default: 34px;--btn-h-xs: 24px;--topbar-h: 56px;--sidebar-w: 110px;--panel-w: 480px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--font-ui: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-body: Georgia, "Times New Roman", serif;--z-popover: 30;--z-notifications: 200;--z-modal-backdrop: 900;--z-modal: 901;--z-toast: 600}.ibook-v4{--color-primary-hover: #1747b5;--color-text: #111827;--color-text-muted: #6b7280;--color-border: #e5e7eb;--color-border-strong: #d1d5db;--color-bg: #f9fafb}*{box-sizing:border-box}html,body{margin:0;padding:0;background:#fff;color:var(--color-text);font-family:var(--font-ui);font-size:14px;height:100%}:where(.btn){-moz-appearance:none;appearance:none;-webkit-appearance:none;display:inline-flex;align-items:center;justify-content:center;gap:6px;height:var(--btn-h-default);padding:0 14px;margin:0;font-family:inherit;font-size:14px;font-weight:600;line-height:1;color:inherit;background-color:transparent;background-image:none;border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;border:1px solid transparent;transition:background .12s,border-color .12s}.btn.primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn.primary:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.btn.primary-outline{background:#fff;color:var(--color-primary);border-color:var(--color-primary)}.btn.primary-outline:hover{background:var(--color-primary-bg)}.btn.secondary{background:#fff;color:#374151;border-color:var(--color-border-strong)}.btn.secondary:hover{background:var(--color-bg);border-color:#9ca3af}.btn.danger-outline{background:#fff;color:#b91c1c;border-color:var(--color-danger-outline)}.btn.danger-outline:hover{background:var(--color-danger-bg)}.btn.ghost{background:transparent;color:var(--color-text-muted);border-color:transparent}.btn.ghost:hover{background:var(--color-bg);color:var(--color-text)}.btn[disabled]{opacity:.45;cursor:not-allowed}.btn.xs{height:var(--btn-h-xs);padding:0 10px;font-size:12px;font-weight:600}.btn .spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.btn.is-saved{background:var(--color-success)!important;border-color:var(--color-success)!important;opacity:1!important}.kv{display:flex;flex-direction:column;gap:5px}.kv-row{display:flex;align-items:center;gap:14px}.kv-row .k{flex:0 0 110px;font-size:13px;color:var(--color-text-muted);line-height:1.3}.kv-row .v{flex:1;min-width:0}.kv-row.stack{align-items:stretch;flex-direction:column;gap:4px}.kv-row.stack .k{flex:none}.kv-row.view .v .muted{font-size:13px;color:var(--color-text-muted)}.kv input[type=text],.kv input[type=search],.kv select,.kv textarea{width:100%;height:var(--input-h);padding:0 var(--input-px);font-size:14px;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-family:inherit;background:#fff;box-sizing:border-box}.kv input:focus,.kv select:focus,.kv textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #1a56db26}.kv textarea{height:auto;min-height:72px;padding:6px var(--input-px);line-height:1.55;resize:vertical}.kv .muted{font-size:13px;color:var(--color-text-muted)}.kv .check-label{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--color-text)}.kv .check-label input[type=checkbox]{transform:translateY(2px)}.kv select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:calc(var(--input-px) + 18px);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6' fill='none'><path d='M1 1l4 4 4-4' stroke='%236b7280' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-repeat:no-repeat;background-position:right calc(var(--input-px) + 2px) center;background-color:#fff}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#11182780;z-index:var(--z-modal-backdrop);animation:mb-fade-in .16s ease-out}@keyframes mb-fade-in{0%{opacity:0}to{opacity:1}}.modal-wrap{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;padding:16px;pointer-events:none}.modal{pointer-events:auto;background:#fff;border-radius:var(--radius-xl);box-shadow:0 25px 60px #00000040,0 8px 20px #0000001f;width:560px;max-width:100%;max-height:calc(100vh - 48px);display:flex;flex-direction:column;overflow:hidden;animation:m-scale-in .18s cubic-bezier(.2,.8,.2,1)}@keyframes m-scale-in{0%{opacity:0;transform:translateY(6px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-head{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:6px 8px 6px 14px;border-bottom:1px solid var(--color-border);background:var(--color-bg)}.modal-head h2{margin:0;font-size:13px;font-weight:600;color:var(--color-text);letter-spacing:-.005em}.modal-head .sub{font-size:11.5px;color:var(--color-text-muted);margin-left:6px;font-weight:500}.modal-head .close-x{all:unset;display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:var(--radius-md);color:#9ca3af;cursor:pointer;font-size:13px}.modal-head .close-x:hover{background:#e5e7eb;color:var(--color-text)}.modal-body{flex:1;min-height:0;overflow-y:auto;padding:12px 14px 14px}.modal-foot{flex:0 0 auto;display:flex;align-items:center;gap:8px;padding:10px 14px;border-top:1px solid var(--color-border);background:#fff}.modal-foot .primary-wide{flex:1;min-width:120px}.modal-foot .spacer{flex:1}body.modal-open{overflow:hidden}.toast{position:fixed;top:72px;right:20px;left:auto;bottom:auto;transform:translateY(-8px);padding:10px 36px 10px 12px;background:var(--color-warning-bg);color:var(--color-text);font-size:13px;font-weight:500;border:1px solid var(--color-warning-border);border-radius:var(--radius-lg);box-shadow:0 10px 30px #00000024;opacity:0;transition:opacity .18s,transform .18s;pointer-events:auto;z-index:var(--z-toast);display:flex;align-items:center;gap:10px;max-width:380px;overflow:hidden}.toast.on{opacity:1;transform:translateY(0)}.toast .t-icon{flex-shrink:0;width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:700}.toast.success .t-icon{background:var(--color-success-bg);color:var(--color-success)}.toast.error .t-icon{background:#fee2e2;color:var(--color-danger)}.toast.info .t-icon{background:var(--color-primary-bg);color:var(--color-primary)}.toast.loading .t-icon{background:#f3f4f6;color:#6b7280}.toast.loading .t-icon:after{content:"";width:12px;height:12px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .7s linear infinite}.toast .t-msg{line-height:1.4}.toast .t-close{all:unset;position:absolute;top:6px;right:8px;width:20px;height:20px;border-radius:var(--radius-sm);font-size:12px;color:var(--color-text-muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.toast .t-close:hover{background:var(--color-bg);color:var(--color-text)}.toast .t-progress{position:absolute;left:0;bottom:0;height:3px;width:100%;transform-origin:left center;animation-name:toast-shrink;animation-timing-function:linear;animation-fill-mode:forwards;background:var(--color-primary)}.toast.success .t-progress{background:var(--color-success)}.toast.error .t-progress{background:var(--color-danger)}.toast.info .t-progress{background:var(--color-primary)}.toast.persistent .t-progress{display:none}.toast:hover .t-progress{animation-play-state:paused}@keyframes toast-shrink{0%{transform:scaleX(1)}to{transform:scaleX(0)}}@media (max-width: 430px){.toast{top:56px;right:12px;max-width:calc(100% - 24px)}}.shell{display:flex;flex-direction:column;height:100vh}.topbar{flex:0 0 var(--topbar-h);display:flex;align-items:center;justify-content:space-between;padding:0 16px 0 8px;background:#fff;border-bottom:1px solid var(--color-border);gap:8px;position:relative}.topbar-left{display:flex;align-items:center;gap:4px}.topbar .brand{font-size:22px;font-weight:700;color:var(--color-text);letter-spacing:-.02em}.topbar-right{display:flex;align-items:center;gap:10px}.topbar-toggle,.topbar-bell{all:unset;position:relative;width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-md);cursor:pointer;color:var(--color-text)}.topbar-toggle:hover,.topbar-bell:hover{background:var(--color-bg)}.avatar{all:unset;width:36px;height:36px;border-radius:50%;background:var(--color-primary);color:#fff;font-size:14px;font-weight:600;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.avatar:hover{background:var(--color-primary-hover)}.shell-body{flex:1;display:flex;min-height:0}.sidebar{flex:0 0 var(--sidebar-w);padding:16px 8px;background:#fff;border-right:1px solid var(--color-border);overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:2px;transition:flex-basis .16s ease}.shell.sidebar-collapsed .sidebar{flex-basis:0;padding:0;border-right:none;overflow:hidden}.nav-item{display:block;padding:8px 10px;font-size:13px;font-weight:500;color:var(--color-text-muted);border-radius:var(--radius-md);text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-item:hover{background:var(--color-bg);color:var(--color-text)}.nav-item.active{background:var(--color-primary);color:#fff}.content{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden;background:#fff}.bell-badge{position:absolute;top:3px;right:3px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:var(--color-danger);color:#fff;font-size:10px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 0 0 2px #fff}.bell-badge.hidden{display:none}.notif-menu{position:absolute;top:48px;right:16px;width:360px;max-height:60vh;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:0 14px 40px #00000024;z-index:var(--z-notifications);display:flex;flex-direction:column;overflow:hidden}.notif-menu[hidden]{display:none}.notif-head{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--color-border)}.notif-head h4{margin:0;font-size:14px;font-weight:600;color:var(--color-text)}.notif-body{flex:1;overflow-y:auto}.notif-item{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;border-bottom:1px solid var(--color-border-subtle);cursor:pointer}.notif-item:hover{background:var(--color-bg)}.notif-item.unread{background:var(--color-selected-bg)}.notif-icon{flex-shrink:0;width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:var(--color-primary-bg);color:var(--color-primary);font-size:14px}.notif-icon.feedback{background:#fef3c7;color:#92400e}.notif-icon.invite{background:var(--color-success-bg);color:var(--color-success)}.notif-icon.login{background:#e5e7eb;color:#4b5563}.notif-icon.publish{background:var(--color-primary-bg);color:var(--color-primary)}.notif-text{flex:1;min-width:0;font-size:13px;line-height:1.4;color:var(--color-text)}.notif-text strong{font-weight:600}.notif-time{margin-top:3px;font-size:11.5px;color:var(--color-text-muted)}.notif-dot{flex-shrink:0;width:8px;height:8px;border-radius:50%;background:var(--color-primary);margin-top:6px}.notif-item:not(.unread) .notif-dot{visibility:hidden}.popover{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:0 14px 40px #00000024;z-index:var(--z-popover);display:flex;flex-direction:column;overflow:hidden;max-height:60vh}.popover-head{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--color-border)}.popover-head h4{margin:0;font-size:13px;font-weight:600;color:var(--color-text)}.popover-body{padding:6px 6px 8px;overflow-y:auto}.popover-check{display:flex;align-items:center;gap:10px;padding:6px 10px;font-size:13px;color:var(--color-text);border-radius:var(--radius-sm);cursor:pointer;-webkit-user-select:none;user-select:none}.popover-check:hover{background:var(--color-bg)}.popover-check input{margin:0;cursor:pointer}.app-split{display:flex;gap:0;align-items:stretch;flex:1;min-width:0;min-height:0}.list-col{flex:1;min-width:0;border-right:1px solid var(--color-border);display:flex;flex-direction:column;overflow:hidden;container-type:inline-size;container-name:list-col}@container list-col (max-width: 640px){.pagelist-actions{justify-content:flex-start!important;flex-basis:100%}}.panel-col{flex:0 0 var(--panel-w);display:flex;min-height:0;min-width:0;position:relative}.panel-resizer{position:absolute;left:-3px;top:0;bottom:0;width:6px;cursor:col-resize;z-index:40}.panel-resizer:before{content:"";position:absolute;left:3px;top:0;bottom:0;width:1px;background:transparent;transition:background .12s}.panel-resizer:hover:before,.panel-resizer.active:before{background:var(--color-primary)}.panel{background:#fff;display:flex;flex-direction:column;overflow:hidden;flex:1;min-height:0;animation:panelIn .18s ease-out}@keyframes panelIn{0%{opacity:0;transform:translate(8px)}to{opacity:1;transform:translate(0)}}.panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 16px 6px;border-bottom:1px solid var(--color-border-subtle)}.panel-head h2{margin:0;font-size:24px;font-weight:600;color:var(--color-text);letter-spacing:-.01em;line-height:1.25}.panel-actions{display:flex;flex-wrap:wrap;gap:6px;padding:14px 16px 10px;flex:0 0 auto}.panel-tabs{display:flex;gap:18px;padding:0 18px;border-bottom:1px solid var(--color-border);background:#fff;flex:0 0 auto}.panel-tab{all:unset;padding:10px 0;font-size:13px;font-weight:500;color:var(--color-text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.panel-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.panel-body{flex:1;overflow-y:auto;padding:16px 18px 24px}.panel-foot{flex:0 0 auto;display:flex;align-items:center;gap:8px;padding:10px 16px;border-top:1px solid var(--color-border);background:#fff;box-shadow:0 -1px #00000005}.panel-foot .primary-wide{flex:1;min-width:120px}.panel-foot .spacer{flex:1}.card{background:var(--color-card);display:flex;flex-direction:column;flex:1;min-height:0}.card-scroll{flex:1;min-height:0;overflow-y:auto}.row{display:grid;grid-template-columns:1fr auto;gap:12px;padding:12px 16px;border-top:1px solid var(--color-border-subtle);cursor:pointer;transition:background .1s}.row:hover{background:var(--color-bg)}.row.selected{background:var(--color-primary-bg)}.r1{font-size:15px;font-weight:500;color:var(--color-text);line-height:1.35}.r2{margin-top:3px;font-size:12.5px;color:var(--color-text-muted);line-height:1.5}.sep{margin:0 6px;color:var(--color-border-strong)}.search-wrap{flex:1;min-width:0;max-width:320px}.search-input{all:unset;box-sizing:border-box;height:34px;width:240px;padding:0 var(--input-px) 0 calc(var(--input-px) + 22px);font-size:14px;background:#fff url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='15' height='15' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='11' cy='11' r='8'/><line x1='21' y1='21' x2='16.65' y2='16.65'/></svg>") no-repeat 11px center;border:1px solid var(--color-border-strong);border-radius:var(--radius-md);color:var(--color-text);font-family:inherit}.search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #1a56db26}.search-input.xs{height:24px;font-size:12px;padding:0 var(--input-px) 0 calc(var(--input-px) + 18px);background-size:12px 12px;background-position:8px center}.row-select{height:26px;font-size:12px;padding:0 var(--input-px);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);background:#fff;color:var(--color-text);font-family:inherit}.count-pill{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 6px;border-radius:9px;font-size:11px;font-weight:600;margin-left:4px;background:#1a56db1f;color:var(--color-primary)}.admin-page{flex:1;min-width:0;min-height:0;display:flex;flex-direction:column}.admin-page.scrollable{display:block;overflow-y:auto;padding:20px 24px 24px}*{margin:0;padding:0;box-sizing:border-box}.home-page-content p{margin-bottom:1em}:root{--color-bg: #faf9f6;--color-text: #1a1a1a;--color-text-muted: #666;--color-primary: #1a56db;--color-primary-light: #6ea8fe;--color-accent: #d4a373;--color-border: #e0ddd5;--color-card: #fff;--color-love: #e74c3c;--color-like: #27ae60;--color-dislike: #95a5a6;--color-footnote: #8e44ad;--color-highlight: rgba(212, 163, 115, .15);--color-admin-bg: #f0f2f5;--color-primary-hover: #1347b8;--color-secondary: #e8e6e1;--color-secondary-hover: #d8d5ce;--color-danger-hover: #c0392b;--font-body: "Georgia", "Times New Roman", serif;--font-ui: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-sm: 16px;--font-size-md: 19px;--font-size-lg: 22px;--font-size-xl: 26px;--font-size-xxl: 30px;--max-width-reader: 680px;--max-width-admin: 1100px;--z-dropdown: 100}body{font-family:var(--font-ui);background:var(--color-bg);color:var(--color-text);line-height:1.6;overflow-x:hidden}input,select,textarea{font-size:16px}@media (max-width: 767px){.hide-on-mobile{display:none}}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:var(--font-ui)}.reader-content{font-family:var(--font-body);line-height:1.8;color:var(--color-text);max-width:100%;padding-left:0;padding-right:0;box-sizing:border-box;overflow-wrap:break-word;word-break:break-word}.reader-content p{margin-bottom:1.2em}.reader-content h1,.reader-content h2,.reader-content h3{font-family:var(--font-ui);margin:1.5em 0 .5em}.reader-content img{max-width:100%;border-radius:8px;margin:0}.reader-content .notion-color-gray{color:#9b9a97}.reader-content .notion-color-brown{color:#64473a}.reader-content .notion-color-orange{color:#d9730d}.reader-content .notion-color-yellow{color:#dfab01}.reader-content .notion-color-green{color:#0f7b6c}.reader-content .notion-color-blue{color:#0b6e99}.reader-content .notion-color-purple{color:#6940a5}.reader-content .notion-color-pink{color:#ad1a72}.reader-content .notion-color-red{color:#e03e3e}.audio-tag{display:none}.font-sm{font-size:var(--font-size-sm)}.font-md{font-size:var(--font-size-md)}.font-lg{font-size:var(--font-size-lg)}.font-xl{font-size:var(--font-size-xl)}.font-xxl{font-size:var(--font-size-xxl)}.sentence{cursor:pointer;transition:background .2s;border-radius:2px;padding:1px 0}.sentence:hover,.sentence.footnote-open{background:var(--color-highlight)}.home-page-content .sentence{cursor:default;transition:none;padding:0}.home-page-content .sentence:hover{background:none}.sentence.admin-disliked{border-bottom:2px solid rgba(231,76,60,.6)}.karaoke .sentence{opacity:.4;transition:opacity .3s}.karaoke .sentence.active{opacity:1;background:var(--color-highlight)}.debug-filename{font-size:.7rem;color:#999;font-weight:400;white-space:nowrap;align-self:flex-start}.debug-filename-badge{position:fixed;top:50px;right:8px;font-family:SF Mono,Fira Code,Consolas,monospace;font-size:10.5px;color:#6b7280;background:#ffffffd1;border-radius:3px;padding:1px 5px;z-index:9999;pointer-events:none;line-height:1.4}.panel-section{margin-bottom:16px}.panel-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.panel-section-header h3{margin:0;font-size:16px;font-weight:600}.section-divider{border:none;border-top:1px solid var(--color-border);margin:20px 0}.empty-state{color:var(--color-text-muted);font-size:14px;text-align:center;padding:20px 0}.avatar-circle{width:36px;height:36px;border-radius:50%;background-color:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem;cursor:pointer;flex-shrink:0}.avatar-menu-wrap{position:relative}.avatar-dropdown{position:absolute;top:calc(100% + 6px);right:0;background:#fff;border:1px solid var(--color-border);border-radius:8px;box-shadow:0 4px 16px #0000001f;min-width:180px;z-index:var(--z-dropdown);padding:6px 0}.avatar-dropdown-item{display:block;width:100%;padding:8px 16px;font-size:14px;color:var(--color-text);background:none;border:none;text-align:left;cursor:pointer;text-decoration:none}.avatar-dropdown-item:hover{background:#0000000a;text-decoration:none}.avatar-dropdown-greeting{padding:8px 16px;font-size:13px;color:var(--color-text-muted);border-bottom:1px solid var(--color-border)}.analytics-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.metric-card{background:var(--color-admin-bg);border-radius:8px;padding:16px;text-align:center}.metric-label{display:block;font-size:12px;color:var(--color-text-muted);margin-bottom:4px}.metric-value{display:block;font-size:24px;font-weight:700;color:var(--color-primary)}
