:root,[data-theme=dark]{color-scheme:dark;--bg: #07090d;--bg-deep: #030304;--bg-app-gradient-from: #0a0d12;--panel: #11161d;--panel-2: #171c24;--panel-3: #202833;--surface: #10151d;--surface-hover: #111620;--surface-input: #090d13;--surface-thumb: #0d1118;--surface-overlay: rgba(16, 21, 29, .85);--ink: #f6f7f9;--ink-strong: #ffffff;--ink-secondary: #e7ebf0;--ink-tertiary: #dce2ea;--ink-on-accent: #07090d;--ink-on-accent-alt: #171006;--muted: #a7afbb;--faint: #727b89;--line: #28313d;--line-soft: #1b222d;--line-visual: #29303b;--accent: #ffb24f;--accent-2: #ff9e2f;--accent-border: #ffbd65;--accent-gradient: linear-gradient(180deg, #ffc977, #ffa336);--green: #74d99b;--danger: #ff6969;--danger-bg: #2a1719;--danger-text: #ffdede;--danger-progress: #ffdada;--pill-bg: #27313d;--pill-text: #d5dbe4;--thumb-item-bg: #151b24;--thumb-item-text: #e8ecf1;--thumb-image-bg: #080b10;--meter-track: #2c3542;--visual-heading: #dce1e9;--visual-frame-bg: #070a0f;--avatar-bg: #000000;--shadow-alpha: .4;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}[data-theme=light]{color-scheme:light;--bg: #f5f6f8;--bg-deep: #ebedf0;--bg-app-gradient-from: #eef0f3;--panel: #ffffff;--panel-2: #f0f1f4;--panel-3: #e4e6eb;--surface: #f8f9fb;--surface-hover: #eef0f3;--surface-input: #ffffff;--surface-thumb: #e8eaee;--surface-overlay: rgba(255, 255, 255, .88);--ink: #1a1d23;--ink-strong: #111318;--ink-secondary: #374151;--ink-tertiary: #4b5563;--ink-on-accent: #ffffff;--ink-on-accent-alt: #ffffff;--muted: #6b7280;--faint: #9ca3af;--line: #d1d5db;--line-soft: #e5e7eb;--line-visual: #d1d5db;--accent: #e8930a;--accent-2: #d07d00;--accent-border: #d4880a;--accent-gradient: linear-gradient(180deg, #f5a623, #e08800);--green: #16a34a;--danger: #dc2626;--danger-bg: #fef2f2;--danger-text: #991b1b;--danger-progress: #b91c1c;--pill-bg: #e5e7eb;--pill-text: #374151;--thumb-item-bg: #f0f1f4;--thumb-item-text: #374151;--thumb-image-bg: #e5e7eb;--meter-track: #d1d5db;--visual-heading: #374151;--visual-frame-bg: #f0f1f4;--avatar-bg: #e5e7eb;--shadow-alpha: .1}*{box-sizing:border-box}body{margin:0;min-width:320px;background:var(--bg);color:var(--ink)}button,input,select{font:inherit}button{color:inherit}button:disabled,.disabled{cursor:not-allowed;opacity:.55}h1,h2,p{margin:0}.icon{width:20px;height:20px;flex:0 0 auto}.app{height:100vh;min-height:100vh;overflow:hidden;background:linear-gradient(180deg,var(--bg-app-gradient-from) 0%,var(--bg) 100%)}.toastError{position:fixed;top:16px;left:50%;z-index:100;max-width:min(760px,calc(100vw - 32px));transform:translate(-50%);padding:11px 14px;border:1px solid rgb(255 105 105 / 46%);border-radius:8px;background:var(--danger-bg);color:var(--danger-text);box-shadow:0 16px 42px #00000057;font-size:13px;line-height:1.4}.appBrand{display:flex;align-items:center;min-width:0;gap:16px}.appBrand.compact{min-width:260px;gap:12px}.brandMark,.uploadIcon{display:grid;place-items:center;color:var(--accent)}.brandMark{position:relative;width:38px;height:38px;flex-shrink:0}button.brandHomeButton{background:none;border:none;cursor:pointer;padding:0;transition:color .15s ease,transform .15s ease}button.brandHomeButton:hover{color:var(--ink-strong);transform:scale(1.05)}.brandMark .icon{width:34px;height:34px}.brandMark:has(img){width:72px;height:72px}.brandMark img{width:68px;height:68px;object-fit:contain;border-radius:14px;position:relative;transition:transform .2s cubic-bezier(.34,1.56,.64,1)}.appBrand:hover .brandMark img{transform:scale(1.05) rotate(-1deg)}.brandText{display:flex;flex-direction:column;gap:2px;min-width:0}.appBrand h1{overflow:hidden;font-size:22px;font-weight:820;letter-spacing:0;text-overflow:ellipsis;white-space:nowrap;display:flex;gap:0}.appBrand:not(.compact) h1{font-family:Inter,ui-sans-serif,system-ui,-apple-system,sans-serif;font-size:34px;font-weight:900;letter-spacing:-.035em;line-height:1.1;overflow:visible;padding-bottom:2px}.brandManga{color:var(--ink-strong)}.brandGlass{color:var(--accent)}.appBrand p,.subtleLine{color:var(--muted);font-size:13.5px;line-height:1.4;letter-spacing:.005em}.simpleTopBar{display:flex;align-items:center;min-height:128px;padding:0 28px;border-bottom:1px solid var(--line-soft);background:var(--surface)}.libraryView{height:100vh;overflow:auto;padding:28px clamp(18px,4vw,54px) 42px}.libraryTop{display:flex;align-items:center;justify-content:space-between;gap:18px;max-width:1280px;margin:0 auto 26px}.libraryIntro{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(280px,.6fr);gap:18px;max-width:1280px;margin:0 auto 28px}.uploadDropzone{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;min-height:158px;gap:18px;padding:24px;border:1px dashed rgb(255 178 79 / 58%);border-radius:8px;background:linear-gradient(180deg,var(--panel-2),var(--surface));cursor:pointer;transition:border-color .16s ease,background .16s ease,box-shadow .16s ease}.uploadDropzone:not(.hasFiles):hover,.uploadDropzone.dragging{border-color:var(--accent);background:linear-gradient(180deg,var(--panel-3),var(--panel));box-shadow:0 0 16px #ffb24f1f}.uploadDropzone.dragging{border-style:solid}.uploadDropzone.hasFiles{display:block;cursor:default;border-style:solid;border-color:var(--line);background:var(--panel)}.uploadDropzone input,.buttonLike input{display:none}.uploadIcon{width:56px;height:56px;border:1px solid rgb(255 178 79 / 44%);border-radius:8px;background:#ffb24f1a}.uploadIcon .icon{width:28px;height:28px}.uploadDropzone strong,.libraryStats strong,.emptyLibrary strong{display:block;color:var(--ink-strong);font-size:20px;font-weight:780}.uploadDropzone small{display:block;margin-top:6px;color:var(--muted);font-size:13px}.uploadHelpText{margin-top:6px;color:var(--muted);font-size:13px}.uploadHelpText .textLink{background:none;border:none;padding:0;color:var(--accent);text-decoration:underline;cursor:pointer;font-weight:600}.uploadHelpText .textLink:hover{color:var(--accent-2)}.uploadStatusHeader{display:flex;align-items:center;gap:12px;padding-bottom:16px;border-bottom:1px solid var(--line);margin-bottom:20px}.uploadStatusHeader .icon{color:var(--accent);width:24px;height:24px}.uploadStatusHeader .statusText strong{font-size:18px}.uploadStatusHeader .statusText span{color:var(--muted);font-size:13px}.uploadConfigForm{display:flex;flex-direction:column;gap:16px}.uploadConfigForm .formField{display:flex;flex-direction:column;gap:6px}.uploadConfigForm .formFieldRow{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 600px){.uploadConfigForm .formFieldRow{grid-template-columns:1fr}}.uploadConfigForm label{color:var(--ink);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.uploadConfigForm input[type=text],.uploadConfigForm select{width:100%;height:38px;padding:0 12px;border:1px solid var(--line);border-radius:6px;background:var(--surface-input);color:var(--ink);font-size:14px;outline:none;transition:border-color .16s ease}.uploadConfigForm input[type=text]:focus,.uploadConfigForm select:focus{border-color:var(--accent)}.uploadConfigForm select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%23a7afbb'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:16px;padding-right:36px}.secondarySelectWrapper{margin-top:8px;display:flex;flex-direction:column;gap:6px}.warningBanner{display:flex;align-items:center;gap:6px;color:var(--danger);font-size:12px;font-weight:500;margin:0;background:#ff696914;padding:6px 10px;border-radius:4px;border:1px solid rgba(255,105,105,.2)}.uploadFormActions{display:flex;gap:12px;margin-top:10px;padding-top:16px;border-top:1px solid var(--line)}.actionButton{height:40px;padding:0 20px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .16s ease,border-color .16s ease,opacity .16s;border:none}.actionButton:disabled{cursor:not-allowed;opacity:.5}.actionButton.primary{background:var(--accent);color:var(--ink-on-accent)}.actionButton.primary:not(:disabled):hover{background:var(--accent-2)}.actionButton.secondary{background:transparent;border:1px solid var(--line);color:var(--ink)}.actionButton.secondary:not(:disabled):hover{background:var(--panel-2);border-color:var(--muted)}.libraryStats{display:grid;align-content:center;gap:8px;padding:24px;border:1px solid var(--line-soft);border-radius:8px;background:var(--surface)}.libraryStats span{color:var(--accent);font-size:44px;font-weight:820;line-height:1}.libraryStats p,.emptyLibrary p,.materialMeta,.taskProgressDetail,.quotaBadge small{color:var(--muted);font-size:13px;line-height:1.35}.librarySection{max-width:1280px;margin:0 auto}.sectionHeader{display:flex;align-items:end;justify-content:space-between;gap:12px;margin-bottom:14px}.sectionHeader h2{color:var(--ink-strong);font-size:17px;font-weight:780}.sectionHeader span{color:var(--muted);font-size:13px}.libraryTitleWrapper{display:flex;align-items:center;gap:8px}.infoTooltip{position:relative;display:inline-flex;align-items:center;justify-content:center;color:var(--faint);cursor:help;transition:color .15s ease;padding:2px}.infoTooltip:hover{color:var(--accent)}.infoTooltip .icon{width:15px;height:15px}.infoTooltip:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%,4px);z-index:50;padding:6px 10px;border-radius:6px;background:var(--panel-3);border:1px solid var(--line);color:var(--ink);font-size:12px;font-weight:500;line-height:1.4;white-space:nowrap;pointer-events:none;opacity:0;box-shadow:0 6px 18px #00000073;transition:opacity .15s ease,transform .15s ease}.infoTooltip:hover:after{opacity:1;transform:translate(-50%)}.infoTooltip:before{content:"";position:absolute;bottom:calc(100% + 4px);left:50%;transform:translate(-50%,4px);z-index:51;border-width:5px;border-style:solid;border-color:var(--panel-3) transparent transparent transparent;pointer-events:none;opacity:0;transition:opacity .15s ease,transform .15s ease}.infoTooltip:hover:before{opacity:1;transform:translate(-50%)}.emptyLibrary{display:grid;place-items:center;gap:10px;min-height:260px;padding:36px;border:1px solid var(--line-soft);border-radius:8px;background:var(--surface);color:var(--muted);text-align:center}.emptyLibrary .icon{width:38px;height:38px;color:var(--accent)}.libraryGrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:20px}.materialCard{position:relative;display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--line-soft);border-radius:12px;overflow:visible;padding:12px;transition:transform .22s cubic-bezier(.25,.46,.45,.94),border-color .22s ease,box-shadow .22s ease}.materialCard:hover{transform:translateY(-5px);border-color:#ffb24f59;box-shadow:0 12px 28px #00000073}.materialCard.active{border-color:var(--accent);box-shadow:0 0 0 1px #ffb24f33,0 8px 24px #ffb24f26}.materialCoverContainer{position:relative;width:100%;aspect-ratio:3 / 4;border-radius:6px 12px 12px 6px;overflow:hidden;background:var(--surface-thumb);box-shadow:0 5px 12px #0006,0 1px 3px #0003;transition:box-shadow .22s ease}.materialCard:hover .materialCoverContainer{box-shadow:0 15px 30px #0009,0 4px 8px #0000004d}.materialCover{width:100%;height:100%;border:none;background:transparent;padding:0;cursor:pointer;display:block}.materialCover img{width:100%;height:100%;object-fit:cover;filter:saturate(.9) contrast(1.05);transition:transform .3s ease}.materialCard:hover .materialCover img{transform:scale(1.03)}.materialCover .icon{width:32px;height:32px;color:var(--faint);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.materialCoverContainer:after{content:"";position:absolute;top:0;left:0;bottom:0;width:12px;background:linear-gradient(to right,#00000073,#0000001a 15%,#ffffff14 25%,#0000 45%,#00000026 75%,#0000);pointer-events:none;z-index:1}.statusIconBadge{position:absolute;top:8px;right:8px;display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;box-shadow:0 4px 10px #0006;z-index:2;color:var(--ink-strong);transition:transform .2s ease}.statusIconBadge.pending{background:#ffb24f;color:#0d1117}.statusIconBadge.completed{background:#74d99b;color:#0d1117}.statusIconBadge.failed{background:#ff6969;color:var(--ink-strong)}.statusIconBadge .icon{width:14px;height:14px}.statusIconBadge.pending .icon{animation:spinner-pulse 1.8s infinite linear}@keyframes spinner-pulse{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.materialBody{display:flex;flex-direction:column;gap:6px;padding-top:10px;min-width:0}.materialHeaderRow{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%}.materialTitle{flex:1;min-width:0;padding:0;border:0;background:transparent;color:var(--ink-strong);cursor:pointer;text-align:left}.materialTitle strong{display:block;overflow:hidden;font-size:14px;font-weight:700;text-overflow:ellipsis;white-space:nowrap;transition:color .15s ease}.materialTitle:hover strong{color:var(--accent)}.materialMeta{display:flex;align-items:center;gap:5px;color:var(--muted);font-size:12px}.bulletSeparator{color:var(--faint);font-size:8px}.materialMenuContainer{position:relative;display:inline-block}.menuToggleButton{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid transparent;border-radius:6px;background:transparent;color:var(--muted);cursor:pointer;transition:all .15s ease}.menuToggleButton:hover,.menuToggleButton.active{color:var(--ink-strong);background:var(--panel-3);border-color:var(--line)}.menuToggleButton .icon{width:16px;height:16px}.cardDropdownMenu{position:absolute;bottom:calc(100% + 8px);right:0;z-index:10;min-width:120px;padding:4px;border:1px solid var(--line);border-radius:8px;background:var(--panel-2);box-shadow:0 10px 25px #00000080;display:flex;flex-direction:column;gap:2px;animation:scale-up .12s ease-out}@keyframes scale-up{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.cardDropdownMenu button{display:flex;align-items:center;gap:8px;width:100%;min-height:auto;height:32px;padding:0 8px;border:0;border-radius:5px;background:transparent;color:var(--ink);cursor:pointer;font-size:13px;font-weight:500;text-align:left;transition:background .15s ease,color .15s ease}.cardDropdownMenu button:hover{background:var(--panel-3);color:var(--ink-strong)}.cardDropdownMenu button.dangerText:hover{background:var(--danger-bg);color:var(--danger)}.cardDropdownMenu button .icon{width:14px;height:14px;color:var(--faint);transition:color .15s ease}.cardDropdownMenu button:hover .icon{color:var(--muted)}.cardDropdownMenu button.dangerText .icon{color:#ff69698c}.cardDropdownMenu button.dangerText:hover .icon{color:var(--danger)}.readerLeftBlock,.readerCenterBlock,.readerRightBlock,.readerPager,.taskProgressTop,.taskProgressDetail{display:flex;align-items:center}.renameForm button,.iconTextButton,.iconButton{min-height:36px;border:1px solid var(--line);border-radius:7px;background:var(--panel-3);color:var(--ink-secondary);cursor:pointer;font-size:13px;font-weight:680}.iconTextButton{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:0 11px}.iconTextButton .icon{width:17px;height:17px}.iconButton{display:inline-grid;place-items:center;width:40px;padding:0}.iconButton.active{border-color:#ffb24fb3;color:var(--accent)}.primaryButton{border-color:var(--accent-border);background:var(--accent-gradient);color:var(--ink-on-accent-alt)}.dangerText{color:var(--danger)}.buttonLike{position:relative}.statusPill,.openPill{display:inline-flex;align-items:center;min-height:23px;padding:0 8px;border-radius:999px;background:var(--pill-bg);color:var(--pill-text);font-size:12px;font-weight:740;text-transform:capitalize}.statusPill.pending,.statusPill.running{background:#ffb24f24;color:var(--accent)}.statusPill.completed{background:#74d99b24;color:var(--green)}.statusPill.failed{background:#ff696924;color:var(--danger)}.openPill{background:#74d99b1f;color:var(--green)}.renameForm{display:flex;flex-direction:column;gap:6px;width:100%}.renameForm input{width:100%;height:32px;padding:0 8px;border:1px solid var(--line);border-radius:6px;outline:0;background:var(--surface-input);color:var(--ink);font-size:13px}.renameForm input:focus{border-color:var(--accent)}.renameFormActions{display:flex;justify-content:flex-end;gap:4px}.renameFormActions .iconButton{width:32px;height:32px;min-height:auto}.quotaBadge{display:grid;grid-template-columns:auto auto;align-items:center;gap:2px 9px;min-width:142px;padding:10px 12px;border:1px solid var(--line-soft);border-radius:8px;background:var(--surface)}.quotaBadge span{color:var(--muted);font-size:12px;font-weight:720;text-transform:capitalize}.quotaBadge strong{color:var(--ink-strong);font-size:15px}.quotaBadge small{grid-column:1 / -1}.taskProgress{display:grid;width:min(360px,42vw);gap:6px;padding:9px 10px;border:1px solid var(--line-soft);border-radius:8px;background:var(--surface)}.taskProgressTop,.taskProgressDetail{justify-content:space-between;gap:12px}.taskProgressTop span:last-child{color:var(--ink-tertiary);font-size:12px;font-weight:720}.taskProgressDetail{min-width:0}.taskProgressDetail span:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.taskProgress p{color:var(--danger-progress);font-size:12px;line-height:1.35}.meter{height:4px;overflow:hidden;border-radius:999px;background:var(--meter-track)}.meter div{height:100%;border-radius:inherit;background:var(--accent);transition:width .22s ease}.reader{display:grid;grid-template-rows:auto minmax(0,1fr) auto;height:100vh;min-height:0;overflow:hidden;background:var(--bg-deep)}.readerToolbar{display:grid;grid-template-columns:1fr auto 1fr;gap:18px;align-items:center;min-height:104px;padding:14px 18px;border-bottom:1px solid var(--line-soft);background:var(--surface)}.readerLeftBlock{justify-content:flex-start;min-width:0;gap:18px}.readerStatusLine{display:flex;align-items:center;min-width:0;gap:10px}.readerCenterBlock{justify-content:center}.readerRightBlock{justify-content:flex-end;gap:12px}.readerPager{gap:6px}.readerTranslationControls{display:flex;align-items:center;gap:8px;min-width:0}.languageSelect{width:min(210px,24vw);height:36px;padding:0 34px 0 11px;border:1px solid var(--line);border-radius:7px;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:var(--panel-3);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%23a7afbb'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 11px center;background-size:15px;color:var(--ink-secondary);font-size:13px;font-weight:650}.languageSelect:focus{border-color:var(--accent)}.languageSelect:disabled{opacity:.55;cursor:not-allowed}.translateButton{white-space:nowrap}.pageWrap{display:flex;flex-direction:column;align-items:center;min-height:0;height:100%;overflow:auto;padding:14px;background:var(--bg-deep);position:relative}.pageContainer{display:flex;justify-content:center;align-items:flex-start;width:100%;height:100%;min-height:0;flex:1}.viewportControls{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--surface-overlay);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:30px;z-index:10;margin-bottom:12px;box-shadow:0 4px 16px #00000059;flex-shrink:0}.viewportControls .iconButton.compact{width:28px;height:28px;min-height:auto;border-radius:50%;background:transparent;border-color:transparent}.viewportControls .iconButton.compact:hover{background:var(--panel-3);border-color:var(--line)}.viewportControls .zoomSlider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100px;height:4px;border-radius:2px;background:var(--line);outline:none;cursor:pointer;transition:opacity .15s ease}.viewportControls .zoomSlider:disabled{opacity:.4;cursor:not-allowed}.viewportControls .zoomSlider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background:var(--accent);cursor:pointer;transition:transform .1s ease,background-color .15s ease}.viewportControls .zoomSlider:not(:disabled)::-webkit-slider-thumb:hover{transform:scale(1.2);background:var(--accent-2)}.viewportControls .zoomSlider::-moz-range-thumb{width:12px;height:12px;border:0;border-radius:50%;background:var(--accent);cursor:pointer;transition:transform .1s ease,background-color .15s ease}.viewportControls .zoomSlider:not(:disabled)::-moz-range-thumb:hover{transform:scale(1.2);background:var(--accent-2)}.viewportControls .manualInputWrap{display:flex;align-items:center;position:relative}.viewportControls .zoomManualInput{width:52px;height:24px;padding:0 4px;border:1px solid var(--line);border-radius:4px;background:#090d1399;color:var(--ink);font-size:12px;font-weight:600;text-align:center;outline:none;transition:all .15s ease}.viewportControls .zoomManualInput:focus{border-color:var(--accent);background:#090d13}.viewportControls .zoomManualInput:disabled{border-color:transparent;background:transparent;color:var(--muted);cursor:not-allowed;font-weight:500}.viewportControls .iconButton.compact:disabled{opacity:.3;cursor:not-allowed;background:transparent;border-color:transparent}.viewportControls .lockUnlockButton{color:var(--muted);background:transparent;border-color:transparent}.viewportControls .lockUnlockButton:hover{color:#fff;background:var(--panel-3);border-color:var(--line)}.viewportControls .lockUnlockButton.locked{color:var(--accent)}.viewportControls .lockUnlockButton.locked:hover{color:var(--accent-2);background:#ffb24f1a;border-color:#ffb24f4d}.viewportControls .separator{width:1px;height:16px;background:var(--line);margin:0 4px}.viewportControls .controlButton{padding:4px 10px;font-size:12px;font-weight:600;border-radius:15px;border:1px solid transparent;background:transparent;color:var(--muted);cursor:pointer;transition:all .15s ease}.viewportControls .controlButton:hover{color:var(--ink-strong);background:var(--panel-3)}.viewportControls .controlButton.active{color:var(--accent);background:#ffb24f1a;border-color:#ffb24f4d}.bubbleSettingsContainer{position:relative;display:inline-block}.bubbleSettingsPopover{position:absolute;top:calc(100% + 12px);right:50%;transform:translate(50%);z-index:20;width:220px;padding:16px;border:1px solid var(--line);border-radius:12px;background:var(--panel-2);box-shadow:0 10px 30px #0009;display:flex;flex-direction:column;gap:14px;animation:slide-down-fade .15s ease-out}@keyframes slide-down-fade{0%{opacity:0;transform:translate(50%,-8px)}to{opacity:1;transform:translate(50%)}}.settingItem{display:flex;flex-direction:column;gap:6px}.checkboxLabel{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;font-weight:500;color:var(--muted);-webkit-user-select:none;user-select:none}.checkboxLabel:hover{color:var(--ink-strong)}.checkboxLabel input[type=checkbox]{width:15px;height:15px;accent-color:var(--accent);cursor:pointer}.settingItem label{display:flex;justify-content:space-between;font-size:12px;font-weight:600;color:var(--muted)}.settingItem label span{color:var(--accent);font-weight:700}.settingItem input[type=range]{-webkit-appearance:none;width:100%;height:6px;border-radius:3px;background:var(--line);outline:none}.settingItem input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;transition:transform .1s ease,background-color .15s ease}.settingItem input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2);background:var(--accent-2)}.page{position:relative;width:min(100%,920px);min-width:min(100%,280px);align-self:flex-start;overflow:hidden;background:#fff;box-shadow:0 0 0 1px #ffffff12,0 18px 55px #0000006b}.page img{display:block;width:100%;-webkit-user-select:none;user-select:none}.translatedPage img{height:100%;object-fit:contain}.originalPage img{height:auto}.overlay,.region,.mask,.translation{position:absolute}.overlay,.mask{top:0;right:0;bottom:0;left:0}.region{overflow:visible}.mask{background:#fff;border-radius:3px}.translation{display:flex;align-items:center;justify-content:center;overflow:hidden;color:#050505;font-family:Hiragino Sans GB,PingFang SC,Noto Sans CJK SC,Microsoft YaHei,sans-serif;font-weight:650;letter-spacing:0;line-height:1.08;text-align:center;white-space:normal;overflow-wrap:anywhere;word-break:break-word}.translation span{display:block;max-width:100%}.translation.vertical{writing-mode:vertical-lr;text-orientation:upright;line-height:1.05;overflow-wrap:normal;word-break:normal}.translation.vertical span{max-height:100%}.debug .region{outline:2px solid rgb(255 178 79 / 78%)}.debug .mask{background:#ffffffe0;box-shadow:inset 0 0 0 1px #ff6969d1}.debug .region:before{content:attr(data-id);position:absolute;top:-20px;left:0;z-index:2;min-width:20px;height:20px;padding:0 6px;border-radius:4px 4px 0 0;background:var(--accent);color:var(--ink-on-accent-alt);font:750 12px/20px ui-sans-serif,system-ui,sans-serif}.thumbnailStrip{min-height:0;background:var(--surface-thumb);display:flex;flex-direction:column}.thumbnailRail{position:relative;height:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;background:var(--surface-thumb);border-top:1px solid var(--line-soft);-webkit-user-select:none;user-select:none;flex-shrink:0}.thumbnailRail:hover{background:var(--surface-hover)}.thumbnailRailLine{position:absolute;left:0;right:0;top:50%;height:1px;background:var(--line);opacity:.5}.thumbnailRail:hover .thumbnailRailLine{background:var(--accent);opacity:.8}.thumbnailCollapseHandle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center;width:36px;height:14px;border:1px solid var(--line);border-radius:10px;background:var(--panel-2);color:var(--muted);cursor:pointer;padding:0;transition:all .15s ease}.thumbnailRail:hover .thumbnailCollapseHandle{color:var(--ink-strong);border-color:var(--accent);background:var(--panel-3);box-shadow:0 0 6px #ffb24f4d}.thumbnailCollapseHandle .icon{width:12px;height:12px}.thumbnailScroller{display:flex;height:160px;gap:10px;overflow-x:auto;overflow-y:hidden;padding:12px 16px;scrollbar-color:var(--accent) transparent;scrollbar-width:thin}.thumbnailItem{display:grid;grid-template-rows:minmax(0,1fr) auto;flex:0 0 86px;gap:6px;padding:6px;border:1px solid transparent;border-radius:8px;background:var(--thumb-item-bg);color:var(--thumb-item-text);cursor:pointer}.thumbnailItem:hover,.thumbnailItem.selected{border-color:#ffb24fb3;background:#ffb24f14}.thumbnailImage{display:grid;place-items:center;min-height:0;overflow:hidden;border-radius:5px;background:var(--thumb-image-bg);color:var(--faint)}.thumbnailImage img{width:100%;height:100%;object-fit:contain}.thumbnailMeta{display:flex;align-items:center;justify-content:space-between;gap:5px;min-width:0}.thumbnailMeta strong{color:var(--ink-strong);font-size:13px;line-height:1}.thumbnailMeta small{overflow:hidden;color:var(--muted);font-size:10px;text-overflow:ellipsis;text-transform:capitalize;white-space:nowrap}.thumbnailItem.running .thumbnailMeta small,.thumbnailItem.pending .thumbnailMeta small{color:var(--accent)}.thumbnailItem.completed .thumbnailMeta small{color:var(--green)}.thumbnailItem.failed .thumbnailMeta small{color:var(--danger)}.visualLab{min-height:100vh;overflow:auto;padding:24px;background:var(--bg);color:var(--ink)}.visualIntro{display:grid;gap:5px;max-width:1120px;margin:0 auto 24px}.singleVisual{padding:16px 24px}.singleVisual .visualIntro{margin-bottom:14px}.visualIntro span{color:var(--accent);font-size:13px;font-weight:760}.visualIntro strong{color:var(--ink-strong);font-size:24px;letter-spacing:0}.visualPanel{display:grid;gap:12px;max-width:1280px;margin:0 auto 26px}.visualPanel h2{color:var(--visual-heading);font-size:14px;font-weight:760}.visualFrame{position:relative;overflow:hidden;border:1px solid var(--line-visual);border-radius:8px;background:var(--visual-frame-bg);box-shadow:0 18px 55px #00000040}.visualLibraryFrame{height:760px}.visualLibraryFrame .libraryView{height:100%}.visualPageFrame{width:min(100%,940px);height:620px}.visualPageFrame .pageWrap{height:100%}.visualStripFrame{width:min(100%,940px);height:176px}.visualFullReaderFrame{width:min(100%,1040px);height:760px}.visualFullReaderFrame .reader{height:100%}@media (max-width: 1100px){.libraryIntro{grid-template-columns:1fr}.readerToolbar{grid-template-columns:1fr auto;gap:12px}.readerLeftBlock{flex-wrap:wrap;align-items:flex-start}.readerCenterBlock{grid-column:span 2;justify-content:center;width:100%;padding-top:8px;border-top:1px solid var(--line-soft)}.readerRightBlock{justify-content:flex-end}.languageSelect{width:min(200px,30vw)}.taskProgress{width:min(360px,100%)}}@media (max-width: 720px){.libraryView{padding:18px 12px 28px}.libraryTop,.sectionHeader{align-items:flex-start;flex-direction:column}.libraryGrid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px}.appBrand:not(.compact) h1{font-size:28px}.brandMark:has(img){width:56px;height:56px}.brandMark img{width:52px;height:52px}.appBrand{gap:14px}.reader{grid-template-rows:auto minmax(0,1fr) auto}.thumbnailScroller{height:140px}.readerToolbar{padding:12px}.readerLeftBlock{display:flex;flex-direction:column;align-items:flex-start;width:100%;min-width:0}.readerStatusLine{width:100%}.appBrand.compact{width:100%;min-width:0}.appBrand h1{font-size:18px}.readerCenterBlock{grid-column:span 2;justify-content:center;width:100%}.readerRightBlock{grid-column:span 2;justify-content:space-between;width:100%}.readerTranslationControls{flex:1}.languageSelect{width:100%;min-width:0}.readerPager{width:100%;justify-content:center}.iconTextButton{min-height:38px;padding:0 9px}.pageWrap{padding:8px}.thumbnailScroller{padding:10px 12px}.thumbnailItem{flex-basis:76px}}@media (max-width: 460px){.uploadDropzone{grid-template-columns:1fr;min-height:150px}.libraryGrid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px}.readerLeftBlock{gap:10px}.readerStatusLine{display:grid}.readerPager{width:100%}.readerRightBlock,.readerTranslationControls{align-items:stretch;flex-direction:column}.quotaBadge,.taskProgress{width:100%}}.accountMenuContainer{display:flex;align-items:center;gap:12px;position:relative}.themeToggleButton{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:1px solid var(--line);background:var(--panel-3);color:var(--muted);cursor:pointer;transition:all .2s ease}.themeToggleButton:hover{color:var(--ink-strong);background:var(--line);border-color:var(--faint);transform:scale(1.05)}.themeToggleButton .icon{width:18px;height:18px}.profileTrigger{display:flex;align-items:center;gap:10px;padding:6px 14px 6px 6px;border-radius:30px;border:1px solid var(--line);background:var(--panel-2);cursor:pointer;transition:all .2s ease}.profileTrigger:hover,.profileTrigger.active{background:var(--panel-3);border-color:var(--faint);box-shadow:0 4px 12px #0003}.profileAvatar{width:28px;height:28px;border-radius:50%;object-fit:cover;background:var(--avatar-bg);border:1px solid var(--line)}.profileName{font-size:14px;font-weight:600;color:var(--ink);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profileChevron{display:flex;align-items:center;justify-content:center;color:var(--muted);transition:transform .2s ease}.profileTrigger.active .profileChevron{transform:rotate(180deg)}.profileChevron .icon{width:14px;height:14px}.accountDropdownMenu{position:absolute;top:calc(100% + 8px);right:0;z-index:999;min-width:160px;padding:6px;border-radius:12px;border:1px solid var(--line);background:var(--panel-2);box-shadow:0 12px 30px #00000080;display:flex;flex-direction:column;gap:4px;animation:dropdown-scale-up .15s ease-out}@keyframes dropdown-scale-up{0%{opacity:0;transform:scale(.95) translateY(-5px)}to{opacity:1;transform:scale(1) translateY(0)}}.menuItem{display:flex;align-items:center;gap:10px;width:100%;height:38px;padding:0 12px;border:0;border-radius:8px;background:transparent;color:var(--muted);font-size:14px;font-weight:500;text-align:left;cursor:pointer;transition:all .15s ease}.menuItem:hover{background:var(--panel-3);color:var(--ink-strong)}.menuItem .icon{width:16px;height:16px;color:var(--faint);transition:color .15s ease}.menuItem:hover .icon{color:var(--ink-strong)}.menuItem.dangerText{color:var(--danger)}.menuItem.dangerText:hover{background:#ff69691a;color:var(--danger)}.menuItem.dangerText .icon{color:#ff6969b3}.menuItem.dangerText:hover .icon{color:var(--danger)}.menuDivider{height:1px;background:var(--line);margin:4px 0}.modalOverlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#05070acc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fade-in .2s ease-out}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.quotaModalContent{position:relative;width:100%;max-width:440px;border-radius:16px;border:1px solid var(--line);background:var(--panel-2);box-shadow:0 20px 50px #0009;padding:28px;display:flex;flex-direction:column;gap:24px;animation:modal-slide-up .25s cubic-bezier(.16,1,.3,1)}@keyframes modal-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modalCloseButton{position:absolute;top:18px;right:18px;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;border:0;background:transparent;color:var(--muted);cursor:pointer;transition:all .2s ease}.modalCloseButton:hover{color:var(--ink-strong);background:var(--panel-3)}.modalCloseButton .icon{width:20px;height:20px}.modalProfileSection{display:flex;align-items:center;gap:18px;border-bottom:1px solid var(--line-soft);padding-bottom:20px}.modalProfileAvatar{width:64px;height:64px;border-radius:50%;object-fit:cover;border:2px solid var(--line);background:var(--avatar-bg)}.modalProfileDetails{display:flex;flex-direction:column;gap:4px}.modalProfileDetails h2{font-size:18px;font-weight:700;color:var(--ink-strong)}.modalEmail{font-size:13px;color:var(--muted)}.tierBadge{display:inline-flex;align-self:flex-start;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:2px 8px;border-radius:4px;margin-top:4px}.tierBadge.guest{background:var(--pill-bg);color:var(--pill-text)}.tierBadge.free{background:#74d99b26;color:var(--green)}.tierBadge.premium{background:#ffb24f26;color:var(--accent)}.quotaStatsGrid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.statCard{padding:14px 18px;border-radius:12px;border:1px solid var(--line-soft);background:var(--surface);display:flex;flex-direction:column;gap:6px}.statLabel{font-size:12px;font-weight:600;color:var(--muted)}.statValue{font-size:24px;font-weight:700}.statValue.remaining{color:var(--green)}.statValue.limit{color:var(--ink-strong)}.quotaProgressSection{display:flex;flex-direction:column;gap:10px}.progressLabelRow{display:flex;justify-content:space-between;font-size:13px;font-weight:600;color:var(--muted)}.progressLabelRow strong{color:var(--ink-strong)}.stackedProgressBar{display:flex;height:10px;border-radius:5px;overflow:hidden;background:var(--line)}.progressSegment{height:100%;transition:width .3s ease}.progressSegment.consumed{background:var(--accent)}.progressSegment.reserved{background:var(--accent);opacity:.55}.progressSegment.remaining{background:var(--green)}.progressLegend{display:flex;flex-wrap:wrap;gap:12px;font-size:12px;color:var(--muted);margin-top:4px}.legendItem{display:flex;align-items:center;gap:6px}.legendDot{width:8px;height:8px;border-radius:50%}.legendDot.consumed{background:var(--accent)}.legendDot.reserved{background:var(--accent);opacity:.55}.legendDot.remaining{background:var(--green)}.quotaInfoCard{display:flex;align-items:flex-start;gap:12px;padding:14px;border-radius:10px;background:#a7afbb0a;border:1px dashed var(--line)}.quotaInfoCard .icon{color:var(--accent);flex-shrink:0;width:18px;height:18px;margin-top:1px}.infoText{font-size:12px;line-height:1.45;color:var(--muted)}.infoText p{margin:0}.resetTimeText{margin-top:2px}.resetTimeText strong{color:var(--ink-strong)}.modalPromoSection{border-top:1px solid var(--line-soft);padding-top:20px;display:flex;flex-direction:column;gap:12px;align-items:center;text-align:center}.modalPromoSection p{font-size:13px;color:var(--muted)}.upgradePromoButton{width:100%;height:40px;border:1px solid var(--accent);border-radius:8px;background:linear-gradient(180deg,#ffb24f1a,#ffb24f05);color:var(--accent);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.upgradePromoButton:hover{background:var(--accent-gradient);color:var(--ink-on-accent-alt);border-color:var(--accent-border);box-shadow:0 4px 15px #ffb24f33}
