:root{--bg: #e8e3dc;--ink: #3f433f;--muted: #767a74;--line: #cec6bc;--card: #f7f3ed;--surface-weak: #e9e5de;--primary: #5e6761;--primary-weak: #6e7871;--disabled-bg: #bab6ae;--disabled-ink: #f3f0eb;--accent: #7c8780;--accent-soft: #dde3dc;--accent-ink: #516059;--radius-sm: 10px;--radius-md: 14px;--shadow-sm: 0 6px 14px rgba(17, 24, 39, .08);--shadow-md: 0 10px 24px rgba(17, 24, 39, .14);--h1: 36px;--h2: 28px;--h3: 22px;--text-base: 14px;--font-display: "Source Han Serif SC","Noto Serif SC", "Songti SC", serif;--font-body: "Source Han Sans SC", "Noto Sans SC", "PingFang SC", "Microsoft YaHei", sans-serif}*{box-sizing:border-box}body{margin:0;font-family:Space Grotesk,Segoe UI,system-ui,-apple-system,sans-serif;color:var(--ink);background:var(--bg)}body{font-family:var(--font-body)}button,input,select,textarea{font:inherit;font-family:inherit}.brand-title,.library-title,.section-title{font-family:var(--font-display);letter-spacing:.02em}a{color:inherit;text-decoration:none}.app-shell{min-height:100vh}.auth-page{min-height:100vh;display:grid;align-content:start;position:relative;background-color:#fafafa}.auth-bar{position:fixed;bottom:0;display:flex;align-items:center;justify-content:space-between;z-index:1;width:100%;padding:20px;background-color:#000000af}.auth-lang{display:flex;gap:8px}.auth-entry-btn{min-width:98px;padding:8px 14px}.big-logo{pointer-events:none;margin-top:20px;margin-left:20px;margin-right:20px;z-index:1}.home-particle-layer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;overflow:hidden}.home-cover-particle{position:fixed;left:0;top:0;border-radius:8px;object-fit:cover;box-shadow:0 10px 24px #3a3e3a38;pointer-events:auto;-webkit-user-select:none;user-select:none;will-change:transform,opacity;cursor:pointer;transition:box-shadow .2s ease}.home-cover-particle.is-hovered{box-shadow:0 16px 30px #3a3e3a52}.home-book-detail-modal{width:min(560px,92vw)}.travel-debug-panel{position:fixed;top:14px;right:14px;z-index:20;padding:8px 10px;border-radius:8px;border:1px solid rgba(0,0,0,.15);background:#ffffffeb;color:#2f3832;font-size:12px;line-height:1.5;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;pointer-events:none}.auth-layout{grid-template-columns:1.05fr .95fr;position:relative;z-index:3;display:flex;justify-content:center;align-items:center;margin-top:10px}.auth-hero,.auth-card{border-radius:22px;border:1px solid rgba(255,255,255,.7);box-shadow:0 14px 38px #40433f14;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.auth-hero{padding:28px;background:#f7f3ede0;display:grid;align-content:center;gap:14px}.home-title{pointer-events:none;margin-top:20px;font-size:clamp(20px,4vw,30px);line-height:1.12;color:#464b46;margin-left:50px;z-index:1;-webkit-user-select:none;user-select:none}.auth-card{width:100%;max-width:460px;justify-self:end;padding:22px;background:#f7f3eded}.auth-card-head{display:grid;gap:6px}.auth-mode-tabs{margin-top:14px;display:grid;grid-template-columns:1fr 1fr;gap:8px}.auth-mode-btn{border-radius:12px;padding:9px 10px}.auth-mode-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.auth-form{margin-top:14px;display:grid;gap:10px}.auth-submit{margin-top:2px}.auth-switch-wrap{margin-top:12px;text-align:right}.auth-switch{border:0;padding:2px 0;background:transparent;color:#667067;font-size:13px;text-decoration:underline}.app-frame{height:100vh;min-height:100vh;border:1px solid var(--line);background:var(--surface-weak);display:flex;flex-direction:column;overflow:hidden}.frame-header{display:grid;grid-template-columns:1fr auto;align-items:center;gap:12px;background:var(--card);border-bottom:1px solid var(--line);padding:14px 22px}.frame-menu-btn{display:none;width:42px;height:42px;padding:8px;min-width:0;border-radius:12px;align-items:center;justify-content:center;gap:5px;flex-direction:column}.frame-menu-btn span{width:22px;height:2px;border-radius:2px;background:#667067;transition:transform .2s ease,opacity .2s ease}.frame-menu-btn.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}.frame-menu-btn.active span:nth-child(2){opacity:0}.frame-menu-btn.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.brand{display:flex;align-items:center;gap:10px}.brand-mark{width:42px;height:42px;border-radius:13px;display:inline-flex;align-items:center;justify-content:center;padding:4px;background:linear-gradient(145deg,#8f9a92,#79867f 48%,#69756f);box-shadow:0 8px 20px #4e5a5342}.brand-logo{width:100%;height:100%;object-fit:contain;border-radius:10px;display:block;background:#ffffff14}.brand-title{font-size:var(--h2);font-weight:700;line-height:1}.brand-sub{color:var(--muted);font-size:15px}.top-actions{display:flex;align-items:center;gap:10px}.lang-switch{display:flex;gap:8px}.lang-switch .ghost.active{background:var(--primary);color:#fff;border-color:var(--primary)}.user-chip{display:flex;align-items:center;gap:10px;padding:6px 10px;border:1px solid var(--line);border-radius:999px;background:#fff}.frame-body{display:grid;grid-template-columns:220px 1fr;flex:1;min-height:0}.frame-sidebar{border-right:1px solid var(--line);background:#e9e5de;padding:10px;display:grid;align-content:start;gap:6px;min-height:0;overflow:auto}.sidebar-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);color:#555d56;font-weight:500;text-align:left;transition:background-color .2s ease,color .2s ease,transform .2s ease}.sidebar-item:hover{background:#e0e4de;color:#46534c;transform:translate(1px)}.sidebar-toggle{width:100%;border:0;background:transparent;cursor:pointer;border-radius:var(--radius-sm);padding:10px 12px;color:#555d56;font-weight:600;font-family:inherit}.sidebar-icon{width:24px;height:24px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;border:1px solid #c7cdc4;background:#ece8e1;color:#6a746d;flex:0 0 24px}.sidebar-icon svg{width:16px;height:16px}.sidebar-label{flex:1}.sidebar-arrow{opacity:.8}.sidebar-libs{display:grid;gap:6px;margin-top:-4px;margin-bottom:10px;overflow:hidden;padding:4px 0 8px;border-bottom:1px solid #d4d8d1}.sidebar-sub-action{border:0;background:transparent;color:var(--accent-ink);text-align:left;padding:4px 12px;font-size:12px;font-weight:600;cursor:pointer;border-radius:var(--radius-sm);transition:background-color .2s ease,color .2s ease}.sidebar-sub-action:hover{text-decoration:none;background:var(--accent-soft);color:#42524b}.sidebar-sub-action.is-disabled{color:#a3a9ba}.sidebar-sub-action.is-disabled:hover{text-decoration:none}.sidebar-divider{height:1px;background:#d3d6ce;margin:10px 8px}.history-table{display:grid;gap:6px}.history-head,.history-row{display:grid;grid-template-columns:1.4fr .9fr .9fr 1.2fr;gap:8px;align-items:center}.history-head{font-weight:700;color:#3d4252;padding:6px 8px;border-bottom:1px solid var(--line)}.history-row{padding:8px;border-radius:var(--radius-sm);background:#f8f9fc;font-size:14px}.member-head,.member-row{grid-template-columns:1.4fr 1fr}.request-head,.request-row{grid-template-columns:1.2fr .8fr 1fr 1.4fr}.request-actions{display:flex;gap:8px;justify-content:flex-end}.sidebar-sub-item{padding:6px 12px;border-radius:var(--radius-sm);font-size:13px;color:#616a63;transition:background-color .2s ease,color .2s ease,transform .2s ease}.sidebar-sub-item.router-link-active,.sidebar-sub-item:hover{background:#dee4dc;transform:translate(1px)}.sidebar-item.is-active,.sidebar-item.is-active .sidebar-icon,.sidebar-sub-item.is-active{background:#dde3dc;color:#4a5750;font-weight:600}.sidebar-item.is-active .sidebar-icon,.sidebar-sub-item.is-active:before{background:#8a948d;color:#fff}.sidebar-sub-item.is-active:before{content:"";width:6px;height:6px;border-radius:50%;display:inline-block;margin-right:6px}.sidebar-expand-enter-active,.sidebar-expand-leave-active{transition:max-height .25s ease,opacity .25s ease,transform .25s ease}.sidebar-expand-enter-from,.sidebar-expand-leave-to{max-height:0;opacity:0;transform:translateY(-6px)}.sidebar-expand-enter-to,.sidebar-expand-leave-from{max-height:260px;opacity:1;transform:translateY(0)}.frame-content{padding:14px;overflow:auto;min-height:0}.frame-sidebar-mask{display:none}.library-page{display:grid;gap:12px}.library-shell{padding:0;overflow:hidden}.library-topbar{background:transparent;border:0;padding:16px;display:flex;justify-content:space-between;align-items:center}.library-title{margin:0;font-size:var(--h1);line-height:1;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.library-title-row{display:inline-flex;align-items:center;gap:8px}.library-code{margin-left:6px;font-size:18px;color:#555}.copy-code-btn{margin-left:6px;padding:0}.library-name-input{min-width:240px}.library-name-edit-btn{padding:0}.library-icon-btn{width:32px;min-width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;color:#4f5d55}.library-icon-btn span{display:inline-block;width:16px;height:16px;line-height:16px;font-size:16px;text-align:center;font-weight:700;opacity:1}.library-icon-btn:hover{color:#34443c}.library-switch{color:#515151;font-weight:600}.library-top-actions{display:flex;align-items:center;gap:14px}.pending-link{display:inline-flex;align-items:center;gap:8px;color:#6b5d58;font-weight:600}.pending-btn{border:0;padding:0;background:transparent}.pending-badge{width:20px;height:20px;border-radius:50%;background:#b48379;color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:700}.avatar-dot{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#d4d8e8,#a9b5de)}.library-content{position:relative;padding:14px}.library-content.is-busy{-webkit-user-select:none;user-select:none}.busy-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1400;display:grid;place-items:center;background:#00000075;pointer-events:all}.busy-overlay-inner{display:grid;justify-items:center;gap:12px}.spinner{width:44px;height:44px;border-radius:999px;border:3px solid rgba(255,255,255,.28);border-top-color:#fff;animation:busy-spin .8s linear infinite}.busy-text{color:#fff;font-size:14px;letter-spacing:.01em}@keyframes busy-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.detail-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.detail-actions{display:flex;gap:10px}.detail-body{margin-top:14px;display:grid;grid-template-columns:260px 1fr;gap:16px}.detail-form{margin-top:14px;display:grid;gap:10px;max-width:720px}.detail-form-grid{margin-top:14px;display:grid;grid-template-columns:1fr 220px;gap:16px;max-width:980px}.detail-form-left{display:grid;gap:10px}.form-row{display:grid;grid-template-columns:110px 1fr;align-items:center;gap:10px}.form-row-note{align-items:start}.note-textarea{width:100%;min-height:200px;resize:none}.form-label{font-size:14px;color:#4f5567;font-weight:600}.isbn-cell{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}.detail-form-right{display:grid;align-content:start;gap:10px;min-width:0;max-width:100%}.detail-form-submit{grid-column:1 / -1;display:grid;gap:10px}.cover-preview{width:300px;height:400px;max-width:100%;border:1px solid var(--line);border-radius:var(--radius-md);background:#f4efe9;display:flex;align-items:center;justify-content:center;overflow:hidden}.cover-file-input{width:100%;max-width:300px}.cover-preview img{width:100%;height:100%;object-fit:contain}.cover-preview-empty{padding:8px}.inline-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}.inline-actions{display:flex;gap:8px}.inline-btn{padding:10px 14px;border-radius:var(--radius-sm);white-space:nowrap}.scanner-modal{width:min(720px,96vw)}.scanner-body{margin-top:12px;display:grid;gap:10px}.scanner-video{width:100%;max-height:62vh;border-radius:var(--radius-md);border:1px solid var(--line);background:#111827;object-fit:cover}.shelf-head{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:14px}.shelf-head h2{margin:0;font-size:var(--h2);color:#5f6b64}.shelf-controls{display:grid;grid-template-columns:1fr 170px auto auto;gap:10px;align-items:center}.tag-filter-wrap{margin-top:8px;display:flex;flex-wrap:wrap;gap:8px;grid-column:1 / -1;width:100%}.tag-chip-btn{padding:6px 12px;border-radius:999px;font-size:13px;color:#606a63;border-color:#c9d0c7;background:var(--card);transition:background-color .2s ease,color .2s ease,border-color .2s ease}.tag-chip-btn:hover{background:#dde3dc;border-color:#bec8be;color:#4f5d55}.tag-chip-btn.active,.tag-chip-btn.active:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.add-book-btn{min-width:120px;border-radius:var(--radius-md);padding:10px 14px;border:1px solid #748077;background:#7f8b83;color:#fff;font-weight:700;box-shadow:0 4px 12px #5c686138}.add-book-btn:hover{background:#8d998f;border-color:#8d998f;color:#fff}.add-book-btn:active{background:#707b73;border-color:#707b73;color:#fff}.book-grid{margin-top:14px;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px;align-items:stretch}.books-load-sentinel{width:100%;height:1px}.book-card{box-shadow:var(--shadow-sm);background:var(--card);border:1px solid #dfd8ce;border-radius:var(--radius-md);display:flex;flex-direction:column;height:100%}.book-card{overflow:hidden;transition:transform .24s ease,box-shadow .24s ease}.book-card:hover{transform:translateY(-1px);box-shadow:0 10px 20px #565f5924}.book-thumb-wrap{width:100%;aspect-ratio:2 / 3;border-radius:var(--radius-md);background:#f4efe9;overflow:hidden;border-radius:var(--radius-md) var(--radius-md) 0 0}.book-thumb{width:100%;height:100%;object-fit:cover;transition:transform .28s ease,filter .28s ease;transform-origin:center center;will-change:transform}.book-card:hover .book-thumb{transform:scale(1.08)}.book-thumb.placeholder{display:flex;align-items:center;justify-content:center;color:var(--muted)}.no-cover-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--muted);text-align:center;padding:12px}.no-cover-image{width:min(96px,55%);height:auto;object-fit:contain;opacity:.95}.book-card-title{margin-top:12px;font-size:20px;font-weight:700;line-height:1.35;min-height:2.7em;max-height:2.7em;overflow:hidden;display:-webkit-box;display:box;line-clamp:2;-webkit-line-clamp:2;box-orient:vertical;-webkit-box-orient:vertical;text-overflow:ellipsis;padding:0 12px}.book-card-author{margin-top:6px;color:#6f756f;font-size:15px;line-height:1.35;min-height:1.35em;max-height:1.35em;display:-webkit-box;display:box;line-clamp:1;-webkit-line-clamp:1;box-orient:vertical;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;padding:0 12px}.book-card-tags{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px;padding:0 12px}.book-tag-mini{font-size:12px;line-height:1;padding:4px 8px;border-radius:999px;background:#e1e6df;color:#54625a;border:1px solid #cdd6cb}.loading-row{margin-top:14px}.fav-btn{margin:auto 12px 12px;align-self:flex-start}.tag-pills{display:flex;flex-wrap:wrap;gap:8px}.tag-pill-btn{padding:6px 12px;color:#606a63;border-color:#c9d0c7;background:var(--card);transition:background-color .2s ease,color .2s ease,border-color .2s ease}.tag-pill-btn:hover{background:#dde3dc;border-color:#bec8be;color:#4f5d55}.tag-pill-btn.active,.tag-pill-btn.active:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.tag-manage-create{margin-top:12px;display:grid;grid-template-columns:1fr auto;gap:8px}.tags-tab-head{padding-left:8px;padding-right:8px}.link-card{cursor:pointer}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-md);padding:14px}.add-book-card{max-width:760px;width:100%;margin:0 auto}.profile-card,.settings-card{max-width:720px;width:100%}.setting-row{margin-top:14px;display:flex;align-items:center;justify-content:space-between}.switch{width:48px;height:28px;border-radius:999px;border:1px solid #c6cbc3;background:#dde1da;padding:2px;position:relative}.switch-knob{width:22px;height:22px;border-radius:50%;background:#fff;display:block;transition:transform .22s ease}.switch.on{background:#7e8982;border-color:#7e8982}.switch.on .switch-knob{transform:translate(20px)}.libs-empty{text-align:center;display:grid;justify-items:center;gap:10px;padding:28px 20px}.libs-empty-image{width:min(140px,70%);height:auto;opacity:.95}.section-title{margin:0 0 6px;font-size:var(--h3)}.section-sub{color:var(--muted);font-size:var(--text-base)}.input{padding:10px 12px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--card)}.input-with-hint{position:relative}.input-with-hint .input{padding-right:74px;width:100%}.input-hint{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:12px;color:#9ba3b4;pointer-events:none}button,.ghost{border-radius:var(--radius-md);padding:10px 16px;border:1px solid var(--line);background:var(--card);cursor:pointer;font-weight:600;transition:background-color .2s ease,color .2s ease,border-color .2s ease,box-shadow .2s ease}button:hover,.ghost:hover{border-color:#b7beb4;background:#f1eee8}button:active,.ghost:active{box-shadow:inset 0 2px 4px #11182714}.solid{background:var(--primary);color:#fff;border-color:var(--primary);min-width:120px}.solid:hover{background:var(--primary-weak);border-color:var(--primary-weak)}.solid.is-limit{background:var(--disabled-bg);border-color:var(--disabled-bg);color:var(--disabled-ink)}button:disabled,.ghost:disabled,.solid:disabled,.sidebar-sub-action.is-disabled{opacity:1;cursor:not-allowed;background:var(--disabled-bg);border-color:var(--disabled-bg);color:var(--disabled-ink);text-decoration:none;box-shadow:none}button:disabled:hover,.ghost:disabled:hover,.solid:disabled:hover,.sidebar-sub-action.is-disabled:hover{background:var(--disabled-bg);border-color:var(--disabled-bg);color:var(--disabled-ink)}.notice{font-size:13px;padding:10px 12px;border-radius:10px;background:#e8eee8;border:1px solid #c4d0c4;color:#5d695f}.notice.error{background:#f3e9e6;border-color:#d7bcb4;color:#8c6358}.libraries-toolbar{margin-top:10px;display:flex;gap:10px}.link-text-btn{padding:0;border:0;background:transparent;color:#5f6b64;font-weight:600;text-decoration:underline;cursor:pointer}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;padding:24px;z-index:50}.modal{width:min(460px,100%);background:var(--card);border-radius:var(--radius-md);padding:20px;border:1px solid rgba(255,255,255,.25);box-shadow:var(--shadow-md)}.modal-header{display:flex;justify-content:space-between;align-items:center}.modal-body{display:grid;grid-template-columns:220px 1fr;gap:16px;margin-top:12px}.cover{width:100%;aspect-ratio:3 / 4;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--line);background:#f4efe9;display:flex;align-items:center;justify-content:center}.cover img{width:100%;height:100%;object-fit:contain;display:block}.detail-tag-list{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px}.meta{display:grid;gap:8px}.modal-fade-enter-active,.modal-fade-leave-active{transition:opacity .28s ease}.modal-fade-enter-active .modal,.modal-fade-leave-active .modal{transition:transform .28s ease,opacity .28s ease}.modal-fade-enter-from,.modal-fade-leave-to{opacity:0}.modal-fade-enter-from .modal,.modal-fade-leave-to .modal{transform:translateY(26px);opacity:0}.page-fade-enter-active,.page-fade-leave-active,.panel-fade-enter-active,.panel-fade-leave-active{transition:opacity .25s ease,transform .25s ease}.page-fade-enter-from,.page-fade-leave-to,.panel-fade-enter-from,.panel-fade-leave-to{opacity:0;transform:translateY(10px)}.global-toast{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);z-index:1200;padding:12px 16px;border-radius:var(--radius-sm);color:#fff;background:#63766ce6;border:1px solid rgba(255,255,255,.25);box-shadow:var(--shadow-md);pointer-events:none}.toast-rise-enter-active,.toast-rise-leave-active{transition:opacity .32s ease,transform .32s ease}.toast-rise-enter-from,.toast-rise-leave-to{opacity:0;transform:translate(-50%,-42%)}.center-confirm-mask{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1190;display:flex;align-items:center;justify-content:center;background:#0003}.center-confirm{min-width:320px;max-width:min(460px,92vw);padding:14px 16px;border-radius:var(--radius-sm);color:#fff;background:#63766ceb;border:1px solid rgba(255,255,255,.25);box-shadow:var(--shadow-md)}.center-confirm-text{font-size:14px}.center-confirm-actions{margin-top:10px;display:flex;gap:8px;justify-content:flex-end}.center-confirm-actions .ghost,.center-confirm-actions .solid{padding:8px 12px;border-radius:var(--radius-sm)}.center-rise-enter-active,.center-rise-leave-active{transition:opacity .32s ease}.center-rise-enter-active .center-confirm,.center-rise-leave-active .center-confirm{transition:opacity .32s ease,transform .32s ease}.center-rise-enter-from,.center-rise-leave-to{opacity:0}.center-rise-enter-from .center-confirm,.center-rise-leave-to .center-confirm{opacity:0;transform:translateY(16px) scale(.98)}.dark-mode body{background:#111827;color:#e5e7eb}.dark-mode .app-frame,.dark-mode .frame-header,.dark-mode .frame-sidebar,.dark-mode .card,.dark-mode .modal,.dark-mode .library-topbar,.dark-mode .library-content{background:#1f2937;border-color:#374151;color:#e5e7eb}.dark-mode .sidebar-item,.dark-mode .section-sub{color:#cbd5e1}.dark-mode .sidebar-item.is-active,.dark-mode .sidebar-item:hover{background:#334155;color:#fff}.dark-mode .input,.dark-mode .ghost{background:#111827;border-color:#4b5563;color:#e5e7eb}.dark-mode .ghost:hover{background:#1f2937;border-color:#5b6473}.dark-mode .solid{background:#e5e7eb;border-color:#e5e7eb;color:#111827}.dark-mode .solid:hover{background:#f3f4f6;border-color:#f3f4f6}.dark-mode button:disabled,.dark-mode .ghost:disabled,.dark-mode .solid:disabled,.dark-mode .sidebar-sub-action.is-disabled{background:#495160;border-color:#495160;color:#b8bfcb}.dark-mode .sidebar-libs{border-bottom-color:#445063}.dark-mode .sidebar-divider{background:#445063}.dark-mode .sidebar-sub-item{color:#aeb8c8}.dark-mode .sidebar-sub-action{color:#95b3ff}.dark-mode .sidebar-sub-action:hover{background:#263249;color:#b7cbff}.dark-mode .tag-chip-btn{background:#1b2535;border-color:#3e4b63;color:#c8d2e4}.dark-mode .tag-chip-btn:hover{background:#263249;border-color:#4f6388;color:#d7e3ff}.dark-mode .tag-chip-btn.active,.dark-mode .tag-chip-btn.active:hover{background:#e5e7eb;border-color:#e5e7eb;color:#111827}.dark-mode .tag-pill-btn{background:#1b2535;border-color:#3e4b63;color:#c8d2e4}.dark-mode .tag-pill-btn:hover{background:#263249;border-color:#4f6388;color:#d7e3ff}.dark-mode .tag-pill-btn.active,.dark-mode .tag-pill-btn.active:hover{background:#e5e7eb;border-color:#e5e7eb;color:#111827}.dark-mode .book-tag-mini{background:#25324a;border-color:#3b4f72;color:#bfd2ff}.dark-mode .global-toast,.dark-mode .center-confirm{background:#1b754cf0}.dark-mode .history-row{background:#111827}@media (max-width: 1200px){.auth-layout{grid-template-columns:1fr;max-width:560px}.auth-card{justify-self:stretch;max-width:none}.shelf-head,.shelf-controls{grid-template-columns:1fr}.library-title{font-size:30px}}@media (max-width: 960px){.frame-header{position:sticky;top:0;z-index:90;grid-template-columns:auto 1fr auto;padding:12px 14px}.frame-menu-btn{display:inline-flex}.brand-title{font-size:22px}.brand-sub{font-size:12px}.top-actions .lang-switch{display:none}.frame-body{grid-template-columns:1fr;min-height:calc(100vh - 68px)}.frame-sidebar{position:fixed;left:0;top:68px;width:min(50vw,330px);height:calc(100dvh - 68px);padding:12px 10px 14px;z-index:100;transform:translate(-104%);transition:transform .25s ease;overflow:auto;box-shadow:0 18px 36px #1418142e;grid-template-columns:1fr}.frame-sidebar.is-mobile-open{transform:translate(0)}.frame-sidebar-mask{display:block;position:fixed;top:68px;left:0;right:0;bottom:0;background:#191c1a52;z-index:95}.frame-content{padding:10px}}@media (max-width: 720px){.auth-page{padding:14px;align-content:start}.auth-topbar{top:10px;left:10px;right:10px}.auth-lang{gap:6px}.auth-entry-btn{min-width:86px;padding:7px 12px}.auth-layout{width:100%;margin-top:48px}.auth-hero{display:none}.auth-card{padding:16px;border-radius:16px}.auth-mode-btn,.auth-submit,.auth-form .input{min-height:44px}.modal-body{grid-template-columns:1fr}.book-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.book-card-title{font-size:18px}.book-card-author{font-size:14px}.tag-pills{gap:6px}.tag-pill-btn{font-size:12px;padding:5px 10px;border-radius:999px}.library-topbar{padding:12px 10px}.library-content{padding:10px;overflow-x:hidden}.library-title{font-size:24px;line-height:1.2;gap:6px}.library-title-main,.library-title-code{display:flex;width:100%;align-items:center;gap:8px}.library-title-code{margin-top:4px}.library-code{margin-left:0}.detail-head{display:grid;grid-template-columns:1fr auto;align-items:center;gap:10px}.detail-head .section-title{font-size:28px;margin:0}.detail-actions{justify-content:flex-end;align-items:center}.detail-actions .ghost,.detail-actions .solid{min-width:88px;padding:10px 14px}.detail-form-grid{grid-template-columns:1fr;gap:10px;margin-top:8px}.form-row{display:grid;grid-template-columns:72px minmax(0,1fr);gap:8px;align-items:center;width:100%;max-width:100%}.form-row>.form-label{width:auto;min-width:0}.form-row>:nth-child(2){width:100%;min-width:0;max-width:100%}.form-label{font-size:16px;font-weight:700;white-space:nowrap}.isbn-cell{grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:center;width:100%;max-width:100%}.isbn-cell>.input{width:100%}.inline-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.inline-btn{width:auto;min-width:62px;min-height:44px;padding:10px 12px;flex:0 0 auto}.detail-form-right{max-width:none;width:100%;min-width:0}.cover-preview{width:100%;height:auto;aspect-ratio:3 / 4}.cover-file-input{max-width:100%;width:100%}.note-textarea{min-height:180px}.detail-form-left .input,.detail-form-left textarea{width:100%;min-height:42px;border-radius:14px}}
