*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary: #1a73e8;--color-bg: #ffffff;--color-text: #202124;--color-text-dim: #5f6368;--color-border: #e0e0e0;--color-success: #34a853;--color-error: #d93025;--font-sans: "Google Sans", Roboto, Arial, sans-serif;--font-mono: "Roboto Mono", monospace}.error-banner{position:fixed;bottom:16px;left:50%;transform:translate(-50%);z-index:9999;display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--color-error);color:#fff;border-radius:8px;box-shadow:0 4px 12px #0003;font-size:14px;max-width:min(480px,90vw);animation:slideUp .2s ease}.error-banner button{background:none;border:none;color:#fff;cursor:pointer;padding:0;display:flex;align-items:center;flex-shrink:0}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);min-height:100vh;min-height:100dvh}#root{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}.login-root{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--color-bg)}.login-card{display:flex;flex-direction:column;align-items:center;gap:16px;padding:48px 40px}.login-logo{font-size:44px;font-weight:700;letter-spacing:-1px;-webkit-user-select:none;user-select:none}.login-logo-i{color:#4285f4}.login-logo-n{color:#ea4335}.login-logo-b{color:#fbbc05}.login-logo-i2{color:#4285f4}.login-logo-b2{color:#34a853}.login-logo-l{color:#ea4335}.login-logo-i3{color:#4285f4}.login-logo-o{color:#fbbc05}.login-subtitle{font-size:16px;color:var(--color-text-dim);margin-bottom:8px}.login-btn-google{display:flex;align-items:center;gap:10px;padding:10px 24px;background:#fff;border:1px solid var(--color-border);border-radius:4px;font-family:var(--font-sans);font-size:14px;font-weight:500;color:var(--color-text);cursor:pointer;box-shadow:0 1px 3px #0000001a;transition:box-shadow .15s,background .15s}.login-btn-google:hover{box-shadow:0 2px 6px #00000026;background:#f8f8f8}.book-card{display:flex;align-items:center;gap:16px;padding:12px 16px;cursor:pointer;border-bottom:1px solid var(--color-border);transition:background .1s;position:relative}.book-card:hover{background:#f5f5f5}.book-card-cover{width:48px;height:68px;object-fit:cover;flex-shrink:0;background:#f0f0f0}.book-card-info{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}.book-card-title{font-size:15px;font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.book-card-author{font-size:13px;color:var(--color-text-dim)}.book-card-year{font-size:12px;color:#9e9e9e}.book-card-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0}.book-card-stats{display:flex;gap:8px}.book-card-stat{display:flex;align-items:center;gap:3px;font-size:12px;color:#9e9e9e}.book-card-stat .material-icons{font-size:14px}.book-card-badge{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:600;color:var(--color-success);flex-shrink:0;letter-spacing:.04em}.modal-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}@media (min-width: 600px){.modal-overlay{align-items:center}.modal-sheet{max-width:480px;border-radius:8px;max-height:90dvh}}.modal-sheet{background:#fff;width:100%;max-height:95dvh;display:flex;flex-direction:column;border-radius:16px 16px 0 0;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:8px;border-bottom:1px solid var(--color-border);flex-shrink:0}.modal-btn-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--color-text-dim);border-radius:50%;transition:background .1s}.modal-btn-icon:hover{background:#f0f0f0}.modal-btn-save--active{color:var(--color-primary)!important}.modal-body{padding:16px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:10px}.modal-cover{width:100px;height:140px;object-fit:cover;align-self:center;margin-bottom:8px;background:#f0f0f0}.modal-field{width:100%;border:none;border-bottom:1px solid var(--color-border);padding:6px 0;font-family:var(--font-sans);font-size:15px;color:var(--color-text);background:transparent;outline:none;transition:border-color .15s}.modal-field:focus{border-bottom-color:var(--color-primary)}.modal-field--title{font-size:18px;font-weight:500}.modal-field--small{flex:1}.modal-field--textarea{resize:none;border:1px solid var(--color-border);padding:8px;border-radius:4px;font-size:14px}.modal-row{display:flex;gap:16px}.modal-section{display:flex;flex-direction:column;gap:8px;padding-top:8px;border-top:1px solid var(--color-border)}.modal-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-dim);font-weight:600}.modal-status-group{display:flex;gap:8px}.modal-status-btn{padding:6px 14px;border:1px solid var(--color-border);border-radius:16px;background:none;font-size:13px;cursor:pointer;color:var(--color-text-dim);transition:all .15s}.modal-status-btn--active{border-color:var(--color-primary);color:var(--color-primary);background:#e8f0fe}.modal-stars{display:flex;gap:4px}.modal-star{font-size:24px;cursor:pointer;color:#e0e0e0;transition:color .1s;line-height:1;-webkit-user-select:none;user-select:none}.modal-star--active,.modal-star:hover{color:#fbbc05}.modal-trama{font-size:13px;color:var(--color-text-dim);line-height:1.6}.modal-footer{padding:12px 16px;border-top:1px solid var(--color-border);flex-shrink:0}.modal-btn-add,.modal-btn-delete{width:100%;padding:14px;border:none;border-radius:4px;font-family:var(--font-sans);font-size:14px;font-weight:600;letter-spacing:.08em;cursor:pointer;transition:background .15s}.modal-btn-add{background:var(--color-primary);color:#fff}.modal-btn-add:hover{background:#1557b0}.modal-btn-delete{background:#fce8e6;color:#d93025}.modal-btn-delete:hover{background:#f5c6c2}.modal-btn-discussion{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;margin-top:8px;padding:10px;border:1px solid var(--color-border);border-radius:4px;background:none;font-family:var(--font-sans);font-size:13px;font-weight:500;color:var(--color-text-dim);cursor:pointer;transition:background .15s,color .15s}.modal-btn-discussion:hover{background:#f5f5f5;color:var(--color-text)}.modal-btn-discussion .material-icons{font-size:18px}.scanner-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;z-index:300;display:flex;align-items:flex-end;justify-content:center}.scanner-sheet{background:#fff;width:100%;max-width:480px;border-radius:16px 16px 0 0;overflow:hidden;padding-bottom:24px}.scanner-header{display:flex;align-items:center;gap:12px;padding:8px 16px;border-bottom:1px solid var(--color-border)}.scanner-close{background:none;border:none;cursor:pointer;color:var(--color-text-dim);display:flex;align-items:center}.scanner-title{font-size:16px;font-weight:500;color:var(--color-text)}.scanner-reader{width:100%}.scanner-hint{text-align:center;font-size:13px;color:var(--color-text-dim);padding:12px 16px 0}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:98}.sidebar{position:fixed;top:0;left:0;width:280px;height:100dvh;background:#fff;z-index:99;transform:translate(-100%);transition:transform .25s ease;display:flex;flex-direction:column;box-shadow:2px 0 8px #00000026}.sidebar--open{transform:translate(0)}.sidebar-header{padding:20px 16px 12px;border-bottom:1px solid var(--color-border)}.sidebar-logo{font-size:20px;font-weight:700;color:var(--color-primary)}.sidebar-user{display:flex;align-items:center;gap:12px;padding:16px;border-bottom:1px solid var(--color-border)}.sidebar-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover}.sidebar-user-name{font-size:14px;font-weight:500;color:var(--color-text)}.sidebar-user-email{font-size:12px;color:var(--color-text-dim)}.sidebar-nav{padding:8px 0}.sidebar-item{display:flex;align-items:center;gap:16px;width:100%;padding:14px 16px;background:none;border:none;cursor:pointer;font-family:var(--font-sans);font-size:14px;color:var(--color-text);transition:background .1s}.sidebar-item:hover{background:#f5f5f5}.sidebar-item .material-icons{color:var(--color-text-dim)}.sidebar-badge{margin-left:auto;background:var(--color-primary);color:#fff;border-radius:12px;padding:2px 8px;font-size:12px;font-weight:600}.sidebar-toggle-row{cursor:default;pointer-events:none}.sidebar-toggle{margin-left:auto;position:relative;display:inline-flex;align-items:center;width:40px;height:22px;cursor:pointer;pointer-events:all;flex-shrink:0}.sidebar-toggle input{opacity:0;width:0;height:0;position:absolute}.sidebar-toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:#ccc;border-radius:22px;transition:background .2s}.sidebar-toggle-slider:before{content:"";position:absolute;width:16px;height:16px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform .2s}.sidebar-toggle input:checked+.sidebar-toggle-slider{background:var(--color-primary)}.sidebar-toggle input:checked+.sidebar-toggle-slider:before{transform:translate(18px)}.sidebar-footer{margin-top:auto;border-top:1px solid var(--color-border);padding:8px 0}.sidebar-logout,.sidebar-logout .material-icons{color:#d93025}.search-page{min-height:100dvh;display:flex;flex-direction:column;align-items:center;padding-top:30dvh;padding-bottom:calc(56px + env(safe-area-inset-bottom));transition:padding-top .3s ease;position:relative}.search-page--active{padding-top:0;align-items:stretch}.search-hamburger{position:fixed;top:12px;left:12px;background:none;border:none;cursor:pointer;color:var(--color-text-dim);z-index:10;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .1s}.search-hamburger:hover{background:#f0f0f0}.search-logo{font-size:54px;font-weight:700;letter-spacing:-2px;margin-bottom:24px;-webkit-user-select:none;user-select:none}.search-bar-wrapper{display:flex;align-items:center;width:calc(100% - 32px);max-width:580px;border:1px solid var(--color-border);border-radius:24px;padding:0 16px;background:#fff;box-shadow:0 1px 6px #0000001a;height:48px;gap:8px;flex-shrink:0;margin:8px 16px}.search-page--active .search-bar-wrapper{margin:8px 16px 0;max-width:none;border-radius:4px;box-shadow:none;border-color:var(--color-border)}.search-bar-icon{color:var(--color-text-dim);flex-shrink:0}.search-bar-input{flex:1;border:none;outline:none;font-family:var(--font-sans);font-size:16px;color:var(--color-text);background:transparent}.search-bar-input::placeholder{color:#bdbdbd}.search-bar-clear,.search-bar-scan{background:none;border:none;cursor:pointer;color:var(--color-text-dim);display:flex;align-items:center;flex-shrink:0}.search-results{flex:1;width:100%;overflow-y:auto;margin-top:4px}.search-status{padding:24px 16px;color:var(--color-text-dim);font-size:14px;text-align:center}.library-page{min-height:100dvh;display:flex;flex-direction:column;background:var(--color-bg);padding-bottom:calc(56px + env(safe-area-inset-bottom))}.library-topbar{display:flex;align-items:center;gap:8px;padding:8px;border-bottom:1px solid var(--color-border);position:sticky;top:0;background:#fff;z-index:10}.library-topbar-title{flex:1;font-size:20px;font-weight:500;color:var(--color-text);padding-left:8px}.library-hamburger,.library-search-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--color-text-dim);border-radius:50%;flex-shrink:0;transition:background .1s}.library-hamburger:hover,.library-search-btn:hover{background:#f0f0f0}.library-loading{padding:48px 16px;text-align:center;color:var(--color-text-dim);font-size:14px}.library-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:48px 16px;color:var(--color-text-dim)}.library-empty p{font-size:16px}.library-empty-btn{padding:10px 24px;background:var(--color-primary);color:#fff;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer}.library-filter{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--color-border);background:#fff;position:sticky;top:57px;z-index:9}.library-filter-icon{color:var(--color-text-dim);font-size:20px;flex-shrink:0}.library-filter-input{flex:1;border:none;outline:none;font-family:var(--font-sans);font-size:14px;color:var(--color-text);background:transparent}.library-filter-input::placeholder{color:var(--color-text-dim)}.library-filter-clear{background:none;border:none;cursor:pointer;color:var(--color-text-dim);display:flex;align-items:center;padding:2px}.library-filter-clear .material-icons{font-size:18px}.library-group-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px 6px;font-size:13px;font-weight:600;color:var(--color-text-dim);background:#fafafa;border-bottom:1px solid var(--color-border);position:sticky;top:105px;z-index:5}.library-group-count{background:#e0e0e0;color:var(--color-text-dim);border-radius:10px;padding:1px 8px;font-size:12px}.bp-page{min-height:100dvh;display:flex;flex-direction:column;background:var(--color-bg);padding-bottom:32px}.bp-loading,.bp-not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;min-height:100dvh;padding:24px;color:var(--color-text-dim);text-align:center}.bp-not-found p{font-size:16px}.bp-not-found-hint{font-size:14px;color:var(--color-text-dim)}.bp-topbar{display:flex;align-items:center;padding:8px;position:sticky;top:0;background:#fff;border-bottom:1px solid var(--color-border);z-index:10}.bp-back{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--color-text-dim);border-radius:50%;transition:background .1s}.bp-back:hover{background:#f0f0f0}.bp-back-btn{margin-top:8px;padding:10px 20px;border:1px solid var(--color-border);border-radius:4px;background:none;font-family:var(--font-sans);font-size:14px;cursor:pointer;color:var(--color-text-dim)}.bp-hero{display:flex;gap:16px;padding:20px 16px;border-bottom:1px solid var(--color-border)}.bp-cover{width:90px;height:128px;object-fit:cover;border-radius:4px;flex-shrink:0;box-shadow:0 2px 8px #00000026}.bp-meta{display:flex;flex-direction:column;gap:4px;justify-content:center}.bp-title{font-size:18px;font-weight:600;color:var(--color-text);line-height:1.3;margin:0}.bp-author{font-size:14px;color:var(--color-text-dim);margin:0}.bp-details{font-size:12px;color:#bdbdbd;margin:0}.bp-trama{padding:16px;border-bottom:1px solid var(--color-border)}.bp-trama p{font-size:14px;color:var(--color-text-dim);line-height:1.6;margin:0;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.bp-discussion{display:flex;flex-direction:column;padding:0 0 24px}.bp-discussion-header{display:flex;align-items:center;gap:8px;padding:14px 16px 10px;font-size:14px;font-weight:600;color:var(--color-text-dim);border-bottom:1px solid var(--color-border)}.bp-discussion-header .material-icons{font-size:18px}.bp-discussion-count{margin-left:auto;background:#e0e0e0;color:var(--color-text-dim);border-radius:10px;padding:1px 8px;font-size:12px}.bp-error{display:flex;align-items:center;justify-content:space-between;gap:8px;margin:12px 16px 0;padding:10px 14px;background:#fce8e6;border-radius:4px;font-size:13px;color:#d93025}.bp-error button{background:none;border:none;cursor:pointer;color:#d93025;display:flex;align-items:center;flex-shrink:0}.bp-compose{margin:16px 16px 0;border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.bp-compose-input{width:100%;padding:12px;border:none;outline:none;font-family:var(--font-sans);font-size:14px;color:var(--color-text);resize:none;line-height:1.5;box-sizing:border-box}.bp-compose-input::placeholder{color:#bdbdbd}.bp-compose-footer{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-top:1px solid var(--color-border);background:#fafafa;gap:8px;flex-wrap:wrap}.bp-status-pills{display:flex;gap:6px;flex-wrap:wrap}.bp-status-pill{padding:4px 10px;border:1px solid var(--color-border);border-radius:12px;background:none;font-size:12px;cursor:pointer;color:var(--color-text-dim);transition:all .15s;white-space:nowrap}.bp-status-pill--active{border-color:var(--color-primary);color:var(--color-primary);background:#e8f0fe}.bp-send-btn{padding:6px 18px;background:var(--color-primary);color:#fff;border:none;border-radius:4px;font-family:var(--font-sans);font-size:13px;font-weight:500;cursor:pointer;transition:background .15s;white-space:nowrap;flex-shrink:0}.bp-send-btn:disabled{background:#c5cae9;cursor:not-allowed}.bp-compose-blocked{display:flex;align-items:center;gap:8px;margin:16px 16px 0;padding:12px 14px;background:#f5f5f5;border-radius:8px;font-size:13px;color:var(--color-text-dim);line-height:1.4}.bp-compose-blocked .material-icons{font-size:18px;flex-shrink:0}.bp-empty-comments{display:flex;flex-direction:column;align-items:center;gap:8px;padding:40px 16px;color:var(--color-text-dim);text-align:center}.bp-empty-comments .material-icons{font-size:40px;color:#e0e0e0}.bp-empty-comments p{font-size:14px;margin:0}.bp-comments-list{display:flex;flex-direction:column}.bp-comment{padding:14px 16px;border-bottom:1px solid var(--color-border)}.bp-comment-header{display:flex;align-items:center;gap:8px;margin-bottom:6px;flex-wrap:wrap}.bp-comment-username{font-size:13px;font-weight:600;color:var(--color-text)}.bp-comment-status{font-size:11px;font-weight:500;padding:2px 8px;border-radius:10px;background:#f5f5f5}.bp-comment-time{font-size:11px;color:#bdbdbd;margin-left:auto}.bp-comment-delete{background:none;border:none;cursor:pointer;color:#bdbdbd;display:flex;align-items:center;padding:2px;transition:color .1s}.bp-comment-delete:hover{color:#d93025}.bp-comment-delete .material-icons{font-size:18px}.bp-comment-text{font-size:14px;color:var(--color-text);line-height:1.6;margin:0;white-space:pre-wrap;word-break:break-word}.bp-comment-spoiler-badge{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;padding:2px 6px;border-radius:4px;background:#fff3e0;color:#e65100;border:1px solid #ffcc80}.bp-spoiler-hidden{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#fafafa;border:1px dashed #e0e0e0;border-radius:6px;font-size:13px;color:var(--color-text-dim)}.bp-spoiler-hidden .material-icons{font-size:16px;flex-shrink:0}.bp-spoiler-reveal{margin-left:auto;background:none;border:1px solid var(--color-border);border-radius:4px;padding:3px 10px;font-size:12px;cursor:pointer;color:var(--color-text-dim);flex-shrink:0}.bp-spoiler-reveal:hover{background:#f0f0f0}.bp-spoiler-toggle{display:flex;align-items:center;gap:4px;padding:4px 10px;border:1px solid var(--color-border);border-radius:12px;background:none;font-size:12px;cursor:pointer;color:var(--color-text-dim);transition:all .15s;white-space:nowrap;flex-shrink:0}.bp-spoiler-toggle .material-icons{font-size:14px}.bp-spoiler-toggle:hover,.bp-spoiler-toggle--active{background:#fff3e0;border-color:#ffcc80;color:#e65100}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:56px;background:#fff;border-top:1px solid var(--color-border);display:flex;z-index:50;padding-bottom:env(safe-area-inset-bottom)}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:none;border:none;cursor:pointer;color:var(--color-text-dim);font-family:var(--font-sans);transition:color .15s;-webkit-tap-highlight-color:transparent}.bottom-nav-item--active{color:var(--color-primary)}.bottom-nav-item--active .material-icons{font-variation-settings:"FILL" 1}.bottom-nav-label{font-size:11px;font-weight:500;line-height:1}
