:root{--navy:#1f3864;--blue:#2e5496;--green:#2e7d32;--amber:#e08a00;--red:#c62828;--bg:#f4f6fb;--card:#ffffff;--line:#e2e8f4;--text:#1c2433;--muted:#6b7689}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.app{max-width:1200px;margin:0 auto;padding:24px 20px 60px}.topbar{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:16px}.topbar h1{margin:0;font-size:28px;color:var(--navy)}.sub{margin:4px 0 0;color:var(--muted);font-size:14px}.tabs button{border:1px solid var(--line);background:#fff;padding:8px 16px;border-radius:8px;cursor:pointer;font-size:14px;margin-left:8px;color:var(--navy)}.tabs button.on{background:var(--navy);color:#fff;border-color:var(--navy)}.cards{display:flex;gap:12px;flex-wrap:wrap;margin:22px 0}.stat{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 18px;display:flex;flex-direction:column;min-width:96px}.stat .num{font-size:26px;font-weight:700;line-height:1}.stat .lbl{font-size:12px;color:var(--muted);margin-top:4px;text-transform:uppercase;letter-spacing:.04em}.stat.navy .num{color:var(--navy)}.stat.green .num{color:var(--green)}.stat.amber .num{color:var(--amber)}.stat.red .num{color:var(--red)}.stat.progress{flex:1;min-width:200px;justify-content:center}.bar{height:10px;background:#e7ecf6;border-radius:6px;overflow:hidden}.fill{height:100%;background:linear-gradient(90deg,var(--green),#43a047)}.stat.progress span{font-size:13px;color:var(--muted);margin-top:6px}.filters{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end;margin:8px 0 4px}.search{flex:1;min-width:220px;padding:10px 12px;border:1px solid var(--line);border-radius:8px;font-size:14px}.sel{display:flex;flex-direction:column;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.sel select,.actions select,.actions input{margin-top:3px;padding:8px 10px;border:1px solid var(--line);border-radius:8px;font-size:14px;background:#fff;color:var(--text)}.count{color:var(--muted);font-size:13px;margin:10px 2px}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.book{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:6px;border-left:4px solid var(--line)}.book.read{border-left-color:var(--green)}.book.reading{border-left-color:var(--amber)}.book-top{display:flex;gap:12px;align-items:flex-start}.book-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.cover{width:62px;height:92px;flex:none;border-radius:5px;object-fit:cover;box-shadow:0 2px 6px #141e372e;background:#e7ecf6}.cover.placeholder{display:flex;align-items:center;justify-content:center;padding:6px;color:#fff;text-align:center;overflow:hidden}.cover.placeholder span{font-size:9px;line-height:1.2;font-weight:600;display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical;overflow:hidden}.book-head{display:flex;justify-content:space-between;gap:8px;align-items:flex-start}.book h3{margin:0;font-size:15px;line-height:1.3}.author{margin:0;color:var(--blue);font-size:13px;font-weight:600}.meta{margin:0;color:var(--muted);font-size:12px}.sub-meta{margin:0;color:#9aa3b2;font-size:11px}.isbn{margin-left:auto;color:#aab2c0;font-size:10px;letter-spacing:.02em;align-self:center}.notes{margin:2px 0 0;color:#8a93a4;font-size:11px;font-style:italic}.pill{font-size:10px;padding:2px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:.04em;background:#eef1f7;color:var(--muted);white-space:nowrap}.pill.read{background:#e6f4ea;color:var(--green)}.pill.reading{background:#fdf0dc;color:var(--amber)}.stars{display:flex;gap:2px;align-items:center}.star{background:none;border:none;cursor:pointer;font-size:18px;color:#d4d9e3;padding:0;line-height:1}.star.on{color:#f5b301}.actions{display:flex;gap:8px;margin-top:6px;flex-wrap:wrap}.actions select{flex:1}.finish{background:var(--green);color:#fff;border:none;border-radius:8px;padding:8px 12px;cursor:pointer;font-size:13px;font-weight:600}.finish:hover{filter:brightness(1.05)}.log h2{color:var(--navy)}.muted{color:var(--muted);font-weight:400;font-size:15px}.empty{color:var(--muted);background:#fff;border:1px dashed var(--line);border-radius:12px;padding:24px;text-align:center}.log table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden}.log th{background:var(--navy);color:#fff;text-align:left;padding:10px 14px;font-size:13px}.log td{padding:10px 14px;border-top:1px solid var(--line);font-size:14px}.log tr:nth-child(2n) td{background:#f8fafd}.tabs .account{margin-left:12px;font-size:12px;color:var(--muted)}.tabs .account.local{color:#b0863a}.link{background:none;border:none;color:var(--blue);cursor:pointer;font-size:12px;padding:0;text-decoration:underline}.muted.small{font-size:12px;margin-top:-6px}.splash{min-height:70vh;display:flex;align-items:center;justify-content:center;padding:24px}.signin-card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:36px 32px;max-width:380px;text-align:center;box-shadow:0 6px 24px #141e3714}.signin-card h1{color:var(--navy);margin:0 0 8px}.signin-card p{color:var(--muted);font-size:14px;margin:0 0 22px}.google-btn{background:var(--navy);color:#fff;border:none;border-radius:10px;padding:12px 20px;font-size:15px;font-weight:600;cursor:pointer}.google-btn:hover{filter:brightness(1.08)}footer{margin-top:36px;color:var(--muted);font-size:12px;text-align:center}
