:root{--cream: #ffffff;--cream-deep: #e7ded0;--paper: #f3ede5;--oak: #d8cdb8;--oak-dark: #6b7280;--walnut: #374151;--sage: #d62828;--sage-deep: #b51f1f;--terracotta: #d62828;--terracotta-deep: #b51f1f;--ink: #111111;--ink-soft: #6b7280;--shadow: rgba(17, 17, 17, .12);--serif: "Montserrat", system-ui, -apple-system, sans-serif;--sans: "Montserrat", system-ui, -apple-system, sans-serif;--brand: "Montserrat", system-ui, -apple-system, sans-serif;--radius: 18px;--radius-sm: 12px}*{box-sizing:border-box;margin:0;padding:0}.splash-screen{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#fff;z-index:9999}.splash-screen img{width:44vw;max-width:240px;height:auto;animation:splashPulse 1.6s ease-in-out infinite}@keyframes splashPulse{0%,to{opacity:.85;transform:scale(.98)}50%{opacity:1;transform:scale(1)}}html,body,#root{width:100%;height:100%;overflow:hidden}body{font-family:var(--sans);color:var(--ink);background:var(--cream);-webkit-font-smoothing:antialiased}.app{position:relative;width:100%;height:100%}.scene-canvas{position:absolute;top:0;right:0;bottom:0;left:0}.topbar{position:absolute;top:0;left:0;right:0;z-index:20;display:flex;align-items:center;gap:16px;padding:14px 18px;background:linear-gradient(180deg,#fbf6eaf5,#fbf6eab8 70%,#fbf6ea00);pointer-events:none}.topbar>*{pointer-events:auto}.brand{display:flex;align-items:center;gap:10px;background:none;border:none;padding:0;margin:0;cursor:pointer;text-align:left;font:inherit;color:inherit}.brand-mark{width:54px;height:54px;display:grid;place-items:center;background:transparent;flex:0 0 auto}.brand-mark img{width:100%;height:100%;object-fit:contain}.brand-name{font-family:var(--brand);font-size:21px;font-weight:600;letter-spacing:.3px;line-height:1}.brand-sub{font-size:11.5px;color:var(--ink-soft);letter-spacing:.4px}.topbar-search{display:flex;align-items:center;gap:8px;flex:1 1 auto;max-width:420px;margin-left:auto;height:46px;padding:0 8px 0 14px;background:var(--paper);border:1px solid var(--cream-deep);border-radius:999px;box-shadow:0 5px 14px var(--shadow)}.topbar-search>span{opacity:.7;flex:0 0 auto}.topbar-search input{flex:1;min-width:0;border:none;background:transparent;font-family:var(--sans);font-size:15px;color:var(--ink);outline:none}.ts-count{font-size:12px;font-weight:800;color:var(--sage-deep);background:#d628282e;padding:2px 9px;border-radius:999px;flex:0 0 auto}.ts-clear{flex:0 0 auto;width:28px;height:28px;border-radius:50%;border:none;background:var(--cream-deep);color:var(--walnut);font-size:14px;cursor:pointer}.avatar-btn{flex:0 0 auto;width:46px;height:46px;border-radius:50%;overflow:hidden;padding:0;border:1px solid var(--cream-deep);background:linear-gradient(150deg,#e7eee1,#cfdcc6);color:var(--sage-deep);cursor:pointer;display:grid;place-items:center;box-shadow:0 5px 14px var(--shadow);transition:transform .15s ease}.avatar-btn:hover{transform:translateY(-2px)}.avatar-btn img{width:100%;height:100%;object-fit:cover}.context-pill{display:flex;align-items:center;gap:12px;padding:8px 14px 8px 8px;background:var(--paper);border:1px solid var(--cream-deep);border-radius:999px;box-shadow:0 6px 18px var(--shadow);transition:transform .15s ease;font-family:var(--sans);text-align:left;cursor:pointer}.context-pill:hover{transform:translateY(-1px)}.context-avatar{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;font-size:20px;color:var(--paper);flex:0 0 auto}.context-text{display:flex;flex-direction:column;line-height:1.15}.context-text strong{font-family:var(--serif);font-weight:600;font-size:15px}.context-text span{font-size:12px;color:var(--ink-soft)}.topbar-spacer{flex:1}.icon-btn{width:46px;height:46px;border-radius:14px;border:1px solid var(--cream-deep);background:var(--paper);color:var(--walnut);font-size:20px;cursor:pointer;display:grid;place-items:center;box-shadow:0 5px 14px var(--shadow);transition:transform .15s ease,background .2s ease}.icon-btn:hover{transform:translateY(-2px);background:#fff}.icon-btn:active{transform:translateY(0)}.view-switch{position:absolute;bottom:22px;left:50%;transform:translate(-50%);z-index:20;transition:opacity .25s ease;display:flex;gap:4px;padding:5px;background:var(--paper);border:1px solid var(--cream-deep);border-radius:999px;box-shadow:0 8px 22px var(--shadow)}.view-switch button{border:none;background:transparent;font-family:var(--sans);font-weight:700;font-size:14px;color:var(--ink-soft);padding:14px 28px;border-radius:999px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:7px}.view-switch button.active{color:#fff;background:var(--ink);box-shadow:0 4px 10px #11111140}.vs-name{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vs-caret{font-size:11px;opacity:.8;margin-left:2px}.fab{position:absolute;right:22px;bottom:22px;z-index:20;height:58px;padding:0 22px 0 18px;border:none;border-radius:999px;background:linear-gradient(150deg,var(--terracotta),var(--terracotta-deep));color:var(--paper);font-family:var(--sans);font-weight:800;font-size:15px;cursor:pointer;display:flex;align-items:center;gap:10px;box-shadow:0 10px 24px #a85f3f73;transition:transform .15s ease}.fab:hover{transform:translateY(-2px) scale(1.02)}.fab .plus{font-size:24px;line-height:1}.book-panel{position:absolute;top:0;right:0;bottom:0;width:min(380px,90vw);z-index:30;padding:86px 26px 26px;background:linear-gradient(180deg,var(--paper),var(--cream));border-left:1px solid var(--cream-deep);box-shadow:-16px 0 40px var(--shadow);display:flex;flex-direction:column;gap:16px;overflow-y:auto;animation:slideIn .35s cubic-bezier(.2,.9,.3,1)}@media (orientation: landscape) and (max-height: 600px) and (pointer: coarse){.book-panel{padding-top:54px}.view-switch.book-open{opacity:0;pointer-events:none}}@keyframes slideIn{0%{transform:translate(40px);opacity:0}to{transform:translate(0);opacity:1}}.book-panel .close{position:absolute;top:18px;right:18px;width:36px;height:36px;border-radius:50%;border:none;background:var(--cream-deep);color:var(--walnut);font-size:18px;cursor:pointer}.book-panel .title-block{display:flex;flex-direction:column;gap:6px;width:100%}.book-panel h2{font-family:var(--serif);font-weight:600;font-size:26px;line-height:1.18;color:var(--ink);width:100%;white-space:normal;overflow-wrap:anywhere;word-break:break-word;-webkit-hyphens:auto;hyphens:auto}.book-panel .author{font-size:15px;color:var(--ink-soft);font-weight:700;width:100%;overflow-wrap:anywhere}.panel-edit{display:flex;flex-direction:column;gap:12px}.book-panel .field>input,.book-panel .field>textarea{width:100%;font-family:var(--sans);font-size:15px;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid var(--cream-deep);background:var(--cream);color:var(--ink)}.book-panel .field>textarea{resize:vertical;line-height:1.4}.edit-cover{display:flex;align-items:center;gap:12px}.edit-cover img{width:52px;height:78px;object-fit:cover;border-radius:6px;box-shadow:0 4px 12px var(--shadow);flex:0 0 auto}.edit-cover .btn{cursor:pointer;margin:0;white-space:nowrap}.book-panel .field>input:focus,.book-panel .field>textarea:focus{outline:none;border-color:var(--sage)}.meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.meta-grid .cell{background:var(--paper);border:1px solid var(--cream-deep);border-radius:var(--radius-sm);padding:9px 12px}.meta-grid .cell label{display:block;font-size:10.5px;text-transform:uppercase;letter-spacing:.6px;color:var(--ink-soft);margin-bottom:2px}.meta-grid .cell span{font-size:14px;font-weight:700;color:var(--ink)}.desc{font-size:14px;line-height:1.5;color:var(--ink-soft)}.tags{display:flex;flex-wrap:wrap;gap:7px}.tag{font-size:12px;font-weight:700;padding:5px 11px;border-radius:999px;background:#d628282e;color:var(--sage-deep)}.owner-row{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#c9a66b29;border-radius:var(--radius-sm);font-size:13px}.owner-row .av{width:36px;height:36px;flex:0 0 auto;border-radius:50%;display:grid;place-items:center;color:var(--paper);font-size:16px}.owner-info{display:flex;flex-direction:column;line-height:1.2;min-width:0}.owner-info strong{font-family:var(--serif);font-weight:600;font-size:15px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.owner-info span{font-size:12px;color:var(--ink-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cover-crop{display:flex;flex-direction:column;gap:12px}.cc-stage{position:relative;width:fit-content;max-width:100%;max-height:58vh;margin:0 auto;overflow:hidden;border-radius:14px;background:#000;touch-action:none}.cc-stage img{display:block;width:auto;height:auto;max-width:100%;max-height:58vh;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.cc-box{position:absolute;border:2px solid #fff;box-shadow:0 0 0 4000px #00000073;cursor:move;touch-action:none}.cc-h{position:absolute;width:24px;height:24px;border:3px solid #fff;background:#00000040;border-radius:5px;touch-action:none}.cc-h.nw{top:-12px;left:-12px;cursor:nwse-resize}.cc-h.ne{top:-12px;right:-12px;cursor:nesw-resize}.cc-h.sw{bottom:-12px;left:-12px;cursor:nesw-resize}.cc-h.se{bottom:-12px;right:-12px;cursor:nwse-resize}.panel-cover{display:flex;justify-content:center;margin:2px 0 14px}.panel-cover img,.panel-cover .cover-ph{width:150px;height:225px;object-fit:cover;border-radius:10px;box-shadow:0 12px 30px var(--shadow)}.cover-ph{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;text-align:center;padding:8px;font-family:var(--serif);overflow:hidden}.cover-ph-q{font-size:30px;font-weight:700;line-height:1;opacity:.92}.cover-ph-t{font-size:10px;font-weight:600;line-height:1.2;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.loan-status{display:flex;align-items:center;gap:6px;padding:10px 12px;border-radius:var(--radius-sm);background:#d6282824;border:1px solid rgba(214,40,40,.3);color:var(--ink);font-size:13px;line-height:1.35}.btn:disabled{opacity:.5;cursor:not-allowed}.locked-note{font-size:12px;color:var(--ink-soft);text-align:center;line-height:1.35}.actions{margin-top:auto;display:flex;flex-direction:column;gap:9px}.actions .row{display:flex;gap:9px}.btn{flex:1;border:1px solid var(--cream-deep);background:var(--paper);color:var(--ink);font-family:var(--sans);font-weight:700;font-size:14px;padding:12px;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .18s ease}.btn:hover{transform:translateY(-1px)}.scan-cta{display:inline-flex;align-items:center;gap:8px}.ts-clear,.modal-close,.book-panel .close{display:inline-flex;align-items:center;justify-content:center}button svg,.lm-info svg,.loan-status svg{vertical-align:middle}.view-switch button,.count-pill,.update-banner,.invite-link,.dp-edit,.loan-status,.pickup-note,.di-icon,.fab .plus{display:inline-flex;align-items:center;gap:6px}.view-switch button{justify-content:center}.cp-seg{display:inline-flex;align-items:center;gap:5px;white-space:nowrap}.cp-seg+.cp-seg:before{content:"·";margin-right:5px;opacity:.55}.pickup-note{align-items:flex-start}.pickup-note svg{flex:0 0 auto;margin-top:2px}.btn.primary{background:linear-gradient(150deg,var(--sage),var(--sage-deep));color:var(--paper);border:none}.btn.warn{color:var(--oak-dark)}.btn.danger{color:var(--terracotta-deep)}.btn.toggled-off{background:var(--cream-deep);color:var(--ink-soft)}.overlay-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;z-index:40;background:#3a342b59;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fade .25s ease}@keyframes fade{0%{opacity:0}to{opacity:1}}.drawer{position:absolute;top:0;left:0;bottom:0;width:min(360px,92vw);z-index:41;background:linear-gradient(180deg,var(--paper),var(--cream));box-shadow:16px 0 40px var(--shadow);padding:22px;display:flex;flex-direction:column;gap:14px;overflow-y:auto;animation:slideLeft .32s cubic-bezier(.2,.9,.3,1)}@keyframes slideLeft{0%{transform:translate(-40px);opacity:0}to{transform:translate(0);opacity:1}}.drawer h3{font-family:var(--serif);font-weight:600;font-size:22px}.drawer .hint{font-size:13px;color:var(--ink-soft);line-height:1.45}.community-card{display:flex;align-items:center;gap:12px;padding:13px;border-radius:var(--radius);border:1px solid var(--cream-deep);background:var(--paper);cursor:pointer;transition:all .18s ease}.community-card:hover{transform:translateY(-2px);box-shadow:0 8px 18px var(--shadow)}.community-card.active{border-color:var(--sage);box-shadow:0 0 0 2px #d6282859}.community-card .crest{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;font-size:24px;color:var(--paper);flex:0 0 auto}.community-card .info strong{font-family:var(--serif);font-size:16px;font-weight:600}.community-card .info span{display:block;font-size:12.5px;color:var(--ink-soft)}.community-card .info .dist{color:var(--sage-deep);font-weight:700}.drawer .nearby-btn{margin-top:4px;padding:13px;border:1.5px dashed var(--oak);border-radius:var(--radius);background:transparent;color:var(--oak-dark);font-family:var(--sans);font-weight:800;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}.drawer .nearby-btn:hover{background:#c9a66b1f}.modal-wrap{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;background:#3a342b66;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:fade .25s ease;padding:20px;overflow-y:auto}.modal{position:relative;width:min(440px,100%);max-height:calc(100dvh - 40px);overflow-y:auto;background:linear-gradient(180deg,var(--paper),var(--cream));border-radius:24px;padding:26px;box-shadow:0 24px 60px #3a342b66;display:flex;flex-direction:column;gap:16px;margin:auto;animation:pop .3s cubic-bezier(.2,.9,.3,1)}@keyframes pop{0%{transform:scale(.94);opacity:0}to{transform:scale(1);opacity:1}}.modal h3{font-family:var(--serif);font-weight:600;font-size:24px}.modal-close{position:absolute;top:16px;right:16px;width:34px;height:34px;border-radius:50%;border:none;background:var(--cream-deep);color:var(--walnut);font-size:16px;cursor:pointer}.btn-photo{width:100%;display:flex;align-items:center;gap:13px;text-align:left;padding:13px 16px;border-radius:var(--radius-sm);border:1.5px solid var(--sage);background:#d628281a;color:var(--ink);cursor:pointer;font-family:var(--sans);transition:background .15s ease,transform .1s ease}.btn-photo:hover{background:#d628282e}.btn-photo:active{transform:scale(.99)}.btn-photo .bp-ico{font-size:24px;flex:0 0 auto}.btn-photo .bp-txt{display:flex;flex-direction:column;line-height:1.25;font-size:13px;color:var(--ink-soft)}.btn-photo .bp-txt strong{font-size:15px;font-weight:800;color:var(--sage-deep)}.scan-frame{height:150px;width:100%;border-radius:16px;background:repeating-linear-gradient(45deg,rgba(107,78,61,.05),rgba(107,78,61,.05) 12px,transparent 12px,transparent 24px),var(--cream-deep);border:2px dashed var(--oak);display:grid;place-items:center;color:var(--walnut);font-family:var(--sans);font-weight:700;font-size:15px;cursor:pointer;position:relative;overflow:hidden}.scan-frame.live{cursor:default;border-style:solid;background:#000;height:min(56vh,420px)}.scan-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.scan-cancel{position:absolute;bottom:10px;left:50%;transform:translate(-50%);border:none;background:#fbf6eaeb;color:var(--walnut);font-family:var(--sans);font-weight:700;font-size:13px;padding:7px 16px;border-radius:999px;cursor:pointer;z-index:2}.isbn-row{display:flex;gap:9px}.isbn-row input{flex:1}.isbn-row .btn{flex:0 0 auto;white-space:nowrap}.isbn-row .isbn-go{flex:0 0 auto;width:52px;padding:0;font-size:20px;display:grid;place-items:center}.note.warn{background:#d6282829;color:var(--terracotta-deep)}.pill-btn{position:relative;display:flex;align-items:center;gap:7px;height:46px;padding:0 15px;border-radius:14px;border:1px solid var(--cream-deep);background:var(--paper);color:var(--walnut);font-family:var(--sans);font-weight:700;font-size:14px;cursor:pointer;box-shadow:0 5px 14px var(--shadow);transition:transform .15s ease}.pill-btn:hover{transform:translateY(-2px)}.drawer-account{margin-top:12px;padding-top:12px;border-top:1px solid var(--cream-deep);display:flex;flex-direction:column;gap:8px}.drawer-account span{font-size:12.5px;color:var(--ink-soft)}.drawer-profile{display:flex;align-items:center;gap:12px;padding:4px 2px 14px;border-bottom:1px solid var(--cream-deep)}.dp-avatar{width:48px;height:48px;flex:0 0 auto;border-radius:50%;overflow:hidden;display:grid;place-items:center;background:linear-gradient(150deg,#e7eee1,#cfdcc6);color:var(--sage-deep)}.dp-avatar img{width:100%;height:100%;object-fit:cover}.dp-info{display:flex;flex-direction:column;line-height:1.2;min-width:0;flex:1}.dp-info strong{font-family:var(--serif);font-weight:600;font-size:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dp-info span{font-size:12px;color:var(--ink-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dp-edit{flex:0 0 auto;width:34px;height:34px;border-radius:10px;border:1px solid var(--cream-deep);background:var(--paper);cursor:pointer;font-size:15px;display:inline-flex;align-items:center;justify-content:center;gap:0;color:var(--ink)}.drawer-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 14px;border:1px solid var(--cream-deep);border-radius:14px;background:var(--paper);font-family:var(--sans);font-weight:700;font-size:14.5px;color:var(--ink);text-decoration:none;cursor:pointer;text-align:left;transition:background .15s ease}.drawer-item:hover{background:#fff}.drawer-item .di-icon{font-size:18px}.drawer-item .di-label{flex:1}.di-badge{min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:var(--terracotta);color:#fff;font-size:12px;font-weight:800;display:grid;place-items:center}.drawer-item.danger{color:var(--terracotta-deep);font-weight:700}.drawer-sec{display:flex;flex-direction:column;gap:8px}.drawer-sec h3{display:flex;align-items:center;gap:8px}.h-badge{min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:var(--terracotta);color:#fff;font-size:12px;font-weight:800;display:inline-grid;place-items:center}.loan-mini{display:flex;align-items:center;gap:10px;width:100%;padding:9px 11px;border:1px solid var(--cream-deep);border-radius:12px;background:var(--paper);cursor:pointer;text-align:left;transition:background .15s ease}.loan-mini:hover{background:#fff}.lm-icon{font-size:18px;flex:0 0 auto}.lm-cover{flex:0 0 auto;width:34px;height:50px;object-fit:cover;border-radius:5px;background:var(--cream-deep);box-shadow:0 2px 6px var(--shadow)}.lm-cover.ph{display:flex;align-items:center;justify-content:center;font-family:var(--font-serif, serif);font-size:20px;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--oak),var(--terracotta))}.lm-info{display:flex;flex-direction:column;min-width:0;line-height:1.2}.lm-info strong{font-family:var(--serif);font-weight:600;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lm-info span{font-size:12px;color:var(--ink-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lm-info .overdue{color:var(--terracotta-deep);font-weight:700}.lm-info .lm-sub{white-space:normal;overflow:visible;text-overflow:clip}.see-more{align-self:flex-start;background:none;border:none;color:var(--sage-deep);font-family:var(--sans);font-weight:700;font-size:13.5px;cursor:pointer;padding:2px 0}.loans-btn{position:relative}.loans-btn .badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 4px;border-radius:9px;background:var(--terracotta);color:#fff;font-size:11px;font-weight:800;display:grid;place-items:center;box-shadow:0 2px 6px var(--shadow)}.modal.loans{max-width:440px;max-height:80vh}.loans-body{display:flex;flex-direction:column;gap:16px;overflow-y:auto;margin:0 -6px;padding:0 6px}.loan-sec{display:flex;flex-direction:column;gap:8px}.loan-sec h4{font-family:var(--sans);font-size:12px;text-transform:uppercase;letter-spacing:.6px;color:var(--ink-soft);margin-top:6px}.loan-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--cream-deep);border-radius:var(--radius-sm);background:var(--paper)}.loan-row.muted{opacity:.7}.loan-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.loan-info strong{display:block;font-family:var(--serif);font-size:15px;font-weight:600;line-height:1.25}.loan-info>span{display:block;font-size:12.5px;color:var(--ink-soft);line-height:1.35}.loan-info .loan-dates{font-size:12px;opacity:.9}.loan-info .overdue{color:var(--terracotta-deep);font-weight:700}.loan-actions{display:flex;flex-direction:column;gap:6px;flex:0 0 auto}.btn.tiny{padding:8px 14px;font-size:13px;flex:0 0 auto;white-space:nowrap}.modal.confirm{max-width:380px;gap:14px}.confirm-actions{display:flex;gap:10px;margin-top:4px}.confirm-actions .btn{flex:1;padding:13px}.btn.danger-solid{background:linear-gradient(150deg,var(--terracotta),var(--terracotta-deep));color:var(--paper);border:none}.looking{display:flex;flex-direction:column;align-items:center;gap:12px;padding:30px 10px 18px;text-align:center}.looking strong{font-family:var(--serif);font-weight:600;font-size:20px;color:var(--ink)}.looking span{font-size:13px;color:var(--ink-soft)}.spinner{width:46px;height:46px;border-radius:50%;border:4px solid var(--cream-deep);border-top-color:var(--terracotta);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn.busy{position:relative;color:transparent}.btn.busy:after{content:"";position:absolute;width:18px;height:18px;border-radius:50%;border:2.5px solid rgba(251,246,234,.5);border-top-color:var(--paper);animation:spin .7s linear infinite}.preview{display:flex;flex-direction:column;gap:14px}.preview-card{display:flex;gap:14px}.preview-cover{flex:0 0 96px;width:96px;height:140px;border-radius:8px;overflow:hidden;box-shadow:0 6px 16px var(--shadow);background:var(--cream-deep);display:grid;place-items:center}.preview-cover img{width:100%;height:100%;object-fit:cover}.preview-cover.ph{font-size:34px}.preview-cover.as-photo{font-size:inherit;border:1.5px dashed var(--oak);background:var(--cream);color:var(--walnut);cursor:pointer;padding:8px;gap:8px;text-align:center;transition:background .15s ease,border-color .15s ease}.preview-cover.as-photo:hover{background:#fff;border-color:var(--terracotta)}.preview-cover.as-photo .ph-cam{font-size:30px}.preview-cover.as-photo .ph-txt{font-family:var(--sans);font-weight:700;font-size:11.5px;line-height:1.25}.preview-cover-wrap{display:flex;justify-content:center}.preview-hero{position:relative;width:150px;height:225px;border-radius:12px;overflow:hidden;box-shadow:0 12px 30px var(--shadow);background:var(--cream-deep);border:none;padding:0;cursor:pointer;display:grid;place-items:center}.preview-hero img{width:100%;height:100%;object-fit:cover;display:block}.preview-hero .hero-edit{position:absolute;left:0;right:0;bottom:0;background:#3a342b9e;color:#fff;font-family:var(--sans);font-size:11px;font-weight:700;padding:5px;text-align:center}.preview-hero.as-photo{border:1.6px dashed var(--oak);background:var(--cream);color:var(--walnut);display:flex;flex-direction:column;gap:10px;padding:12px;text-align:center;transition:background .15s ease,border-color .15s ease}.preview-hero.as-photo:hover{background:#fff;border-color:var(--terracotta)}.preview-hero.as-photo .ph-cam{font-size:38px}.preview-hero.as-photo .ph-txt{font-family:var(--sans);font-weight:700;font-size:13px;line-height:1.3}.modal textarea.title-input{width:100%;font-family:var(--serif);font-weight:600;font-size:17px;line-height:1.25;padding:12px 14px;border-radius:var(--radius-sm);border:1px solid var(--cream-deep);background:var(--cream);color:var(--ink);resize:none;min-height:52px;field-sizing:content}.modal textarea.title-input:focus{outline:none;border-color:var(--sage)}.preview-info{display:flex;flex-direction:column;gap:10px;min-width:0;width:100%}.preview-info input{width:100%;padding:9px 11px;font-size:14px}.preview-info input:first-child{font-family:var(--serif);font-weight:600;font-size:15px}.field{display:flex;flex-direction:column;gap:3px}.field>span{font-size:12px;font-weight:700;color:var(--ink-soft);letter-spacing:.2px}.field>input{width:100%}.preview-info .field:first-child input{font-family:var(--serif);font-weight:600;font-size:15px}.preview-info strong{font-family:var(--serif);font-size:19px;font-weight:600;line-height:1.15}.preview-info .author{font-size:14px;font-weight:700;color:var(--ink-soft)}.preview-meta{display:flex;flex-wrap:wrap;gap:6px 12px;font-size:13px;color:var(--ink-soft);font-weight:600}.tags.small .tag{font-size:11px;padding:3px 9px}.desc.clamp{display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.preview-actions{display:flex;gap:9px}.preview-actions .btn{padding:13px}.scan-frame .laser{position:absolute;left:8%;right:8%;height:3px;background:var(--terracotta);box-shadow:0 0 12px var(--terracotta);border-radius:3px;animation:scan 2s ease-in-out infinite}@keyframes scan{0%,to{top:18%}50%{top:82%}}.modal input{font-family:var(--sans);font-size:16px;padding:13px 15px;border-radius:var(--radius-sm);border:1px solid var(--cream-deep);background:var(--cream);color:var(--ink)}.modal input:focus{outline:none;border-color:var(--sage)}.modal .or{text-align:center;font-size:12px;color:var(--ink-soft);letter-spacing:1px}.modal .note{font-size:12.5px;color:var(--ink-soft);line-height:1.4;background:#c9a66b24;padding:10px 12px;border-radius:var(--radius-sm)}.hint-chip{position:absolute;top:84px;left:50%;transform:translate(-50%);z-index:15;background:#fbf6eae6;border:1px solid var(--cream-deep);border-radius:999px;padding:7px 16px;font-size:12.5px;font-weight:600;color:var(--ink-soft);box-shadow:0 4px 12px var(--shadow);pointer-events:none;animation:fade .5s ease}.loader{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:var(--cream);color:var(--walnut);font-family:var(--serif);font-size:18px;z-index:5}.modal.auth{max-width:400px}.auth-providers{display:flex;flex-direction:row;gap:9px}.btn.provider{flex:1;justify-content:center;align-items:center;gap:8px;font-weight:700;padding:12px}.btn.provider svg{flex:0 0 auto}.btn.provider .g,.btn.provider .f{display:inline-grid;place-items:center;width:22px;height:22px;border-radius:50%;font-family:var(--serif);font-weight:700;color:#fff;font-size:14px}.btn.provider .g{background:#4285f4}.btn.provider .f{background:#1877f2}.auth-form{display:flex;flex-direction:column;gap:9px}.auth-form input{font-family:var(--sans);font-size:15px;padding:12px 14px;border-radius:var(--radius-sm);border:1px solid var(--cream-deep);background:var(--cream);color:var(--ink)}.auth-form input:focus{outline:none;border-color:var(--sage)}.auth-switch{font-size:13px;color:var(--ink-soft);text-align:center}.auth-switch button{border:none;background:none;color:var(--sage-deep);font-weight:700;font-family:var(--sans);font-size:13px;cursor:pointer;text-decoration:underline}.auth-switch .muted{color:var(--ink-soft)}@media (max-width: 600px){.topbar{padding:10px 12px;gap:8px}.brand-sub{display:none}.brand-name{font-size:18px}.brand-mark{width:52px;height:52px;font-size:18px;border-radius:10px}.brand-text{display:none}.topbar-search{max-width:none;height:42px}.topbar-search input{font-size:14px}.avatar-btn,.icon-btn{width:42px;height:42px}.pill-btn{padding:0;width:44px;height:44px;justify-content:center}.pill-label{display:none}.context-pill{padding:6px 10px 6px 6px;gap:8px}.context-avatar{width:32px;height:32px;font-size:16px}.context-text{min-width:0}.context-text strong,.context-text span{max-width:96px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.view-switch{left:12px;transform:none;bottom:14px;padding:4px}.view-switch button{padding:9px 11px;font-size:12.5px}.vs-name{max-width:70px}.fab{right:12px;bottom:14px;height:52px;width:52px;padding:0;justify-content:center}.fab-label{display:none}.fab .plus{font-size:26px}}@media (max-width: 820px) and (orientation: portrait){.book-panel{top:auto;left:0;right:0;bottom:0;width:100%;height:88vh;max-height:88vh;padding:26px 18px calc(20px + env(safe-area-inset-bottom));border-left:none;border-top:1px solid var(--cream-deep);border-radius:22px 22px 0 0;box-shadow:0 -16px 44px var(--shadow);animation:sheetUp .32s cubic-bezier(.2,.9,.3,1)}.book-panel:before{content:"";position:absolute;top:8px;left:50%;transform:translate(-50%);width:42px;height:4px;border-radius:999px;background:var(--cream-deep)}.book-panel .close{top:22px;right:16px}.panel-cover{display:flex;justify-content:center;margin:4px 0 14px}.panel-cover img,.panel-cover .cover-ph{width:110px;height:165px;border-radius:10px;box-shadow:0 12px 26px var(--shadow)}.cover-ph{padding:12px;gap:8px}.cover-ph-q{font-size:44px}.cover-ph-t{font-size:12px}.book-panel h2{text-align:center;font-size:23px;padding:0 44px}.book-panel .actions{margin-top:auto}.book-panel .author{text-align:center}.view-switch{left:12px;right:12px;transform:none;bottom:calc(14px + env(safe-area-inset-bottom))}.view-switch button{flex:1;justify-content:center}.view-switch .vs-name{max-width:none}.fab{right:12px;bottom:calc(74px + env(safe-area-inset-bottom))}.topbar{padding-top:calc(10px + env(safe-area-inset-top))}}@keyframes sheetUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes coverFlip{0%{transform:rotateY(85deg) scale(.9);opacity:0}to{transform:rotateY(0) scale(1);opacity:1}}.update-banner{position:fixed;left:50%;transform:translate(-50%);bottom:calc(86px + env(safe-area-inset-bottom));z-index:40;display:flex;align-items:center;gap:6px;padding:11px 18px;white-space:nowrap;max-width:calc(100vw - 20px);border-radius:999px;border:none;background:var(--sage-deep);color:#fff;font-family:var(--sans);font-size:14px;font-weight:700;box-shadow:0 8px 24px var(--shadow);cursor:pointer;animation:fade .25s ease}.update-banner strong{text-decoration:underline}.count-pill{position:absolute;top:calc(70px + env(safe-area-inset-top));left:50%;transform:translate(-50%);z-index:12;white-space:nowrap;flex-wrap:nowrap;gap:12px;padding:6px 14px;border-radius:999px;background:#fffcf5db;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid var(--cream-deep);box-shadow:0 4px 14px var(--shadow);font-size:13px;font-weight:800;color:var(--walnut);pointer-events:none}.books-loading{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:15;display:flex;flex-direction:column;align-items:center;gap:12px;padding:22px 28px;white-space:nowrap;background:var(--paper);border:1px solid var(--cream-deep);border-radius:var(--radius);box-shadow:0 10px 30px var(--shadow);color:var(--ink-soft);font-weight:700;font-size:14px;animation:fade .2s ease}.search-bar{position:absolute;top:74px;left:50%;transform:translate(-50%);z-index:22;display:flex;align-items:center;gap:8px;width:min(460px,92vw);padding:8px 10px 8px 14px;background:var(--paper);border:1px solid var(--cream-deep);border-radius:999px;box-shadow:0 8px 22px var(--shadow);animation:fade .2s ease}.search-bar input{flex:1;min-width:0;border:none;background:transparent;font-family:var(--sans);font-size:15px;color:var(--ink);outline:none}.search-count{font-size:12px;font-weight:800;color:var(--sage-deep);background:#d628282e;padding:2px 9px;border-radius:999px;flex:0 0 auto}.search-close{flex:0 0 auto;width:28px;height:28px;border-radius:50%;border:none;background:var(--cream-deep);color:var(--walnut);font-size:14px;cursor:pointer}.landing{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;gap:22px;padding:28px 18px 40px;background:radial-gradient(120% 100% at 50% 0%,var(--paper),var(--cream) 60%,var(--cream-deep));overflow-y:auto}.landing-hook-title{font-family:var(--brand);font-size:22px;font-weight:800;color:var(--ink);margin:8px 0 4px}.landing-hook{font-size:13.5px;line-height:1.5;color:var(--ink-soft);margin:0 0 2px}.manifesto{text-align:left;margin:8px 0 6px}.manifesto p{font-size:13px;line-height:1.55;color:var(--ink-soft);margin:0 0 10px}.manifesto strong{color:var(--ink)}.ob-title{font-family:var(--brand);font-size:15px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);margin:6px 0 10px;text-align:left}.ob-list{list-style:none;margin:0 0 18px;padding:0;text-align:left;display:flex;flex-direction:column;gap:9px}.ob-list li{display:flex;align-items:center;gap:10px;font-size:13.5px;color:var(--ink)}.ob-list li>svg{color:var(--sage);flex:none}.ob-n{flex:none;width:22px;height:22px;border-radius:999px;background:var(--sage);color:#fff;font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center}.cta-big{width:100%;padding:14px;font-size:15px}.cta-micro{font-size:12px;color:var(--ink-soft);margin:8px 0 2px}.linkish{background:none;border:none;color:var(--sage);font-family:var(--sans);font-weight:700;font-size:13.5px;cursor:pointer;padding:8px;text-decoration:underline}.landing-back{position:absolute;top:14px;left:14px;display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:999px;background:var(--cream);border:1px solid var(--cream-deep);color:var(--ink);cursor:pointer}.login-h{font-family:var(--brand);font-size:19px;color:var(--ink);margin:4px 0 2px}.landing-card{position:relative;width:min(420px,100%);background:var(--paper);border:1px solid var(--cream-deep);border-radius:24px;padding:28px 26px;box-shadow:0 24px 60px var(--shadow);display:flex;flex-direction:column;gap:12px;text-align:center}.brand-mark.big{width:88px;height:88px;border-radius:0;font-size:34px;margin:0 auto}.landing-card h1{font-family:var(--brand);font-weight:600;font-size:32px;letter-spacing:.3px;line-height:1}.landing-sub{font-family:var(--brand);font-weight:500;font-size:13px;color:var(--ink-soft);margin-top:-6px}.invite-note{font-size:13.5px;line-height:1.45;color:var(--ink-soft);background:var(--cream-deep);border-radius:var(--radius-sm);padding:11px 14px;margin:4px 0}.invite-note.ok{background:#d628282e;color:var(--sage-deep);font-weight:700}.landing-card .auth-providers,.landing-card .auth-form{text-align:left}.auth-form.invite-code{margin:6px 0 2px;gap:8px}.auth-form.invite-code .btn{display:inline-flex;align-items:center;justify-content:center;gap:6px}.cover-capture{position:relative;width:100%;height:min(68vh,520px);border-radius:16px;overflow:hidden;background:#000}.cover-capture .scan-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.frame-guide{position:absolute;top:9%;height:74%;left:50%;transform:translate(-50%);aspect-ratio:2 / 3;pointer-events:none;box-shadow:0 0 0 4000px #00000047;border-radius:10px}.frame-guide .c{position:absolute;width:28px;height:28px;border:3px solid rgba(255,255,255,.95)}.frame-guide .c.tl{top:-2px;left:-2px;border-right:none;border-bottom:none;border-radius:9px 0 0}.frame-guide .c.tr{top:-2px;right:-2px;border-left:none;border-bottom:none;border-radius:0 9px 0 0}.frame-guide .c.bl{bottom:-2px;left:-2px;border-right:none;border-top:none;border-radius:0 0 0 9px}.frame-guide .c.br{bottom:-2px;right:-2px;border-left:none;border-top:none;border-radius:0 0 9px}.capture-hint{position:absolute;top:14px;left:50%;transform:translate(-50%);background:#0000008c;color:#fff;font-size:13px;font-weight:600;padding:6px 14px;border-radius:999px;white-space:nowrap}.capture-actions{position:absolute;bottom:18px;left:0;right:0;display:flex;align-items:center;justify-content:center;gap:24px}.shutter{width:66px;height:66px;border-radius:50%;background:#fff;border:4px solid rgba(255,255,255,.55);box-shadow:0 0 0 3px #00000040;cursor:pointer}.shutter:active{transform:scale(.94)}.btn.ghost{position:absolute;left:16px;bottom:30px;border:none;background:#00000080;color:#fff;font-family:var(--sans);font-weight:700;font-size:13px;padding:9px 14px;border-radius:999px;cursor:pointer}.notfound-block{display:flex;flex-direction:column;gap:10px}.notfound-opts{display:flex;flex-direction:column;gap:8px}.notfound-opts .btn{padding:13px;justify-content:center}.notfound-opts .btn small{font-weight:700;opacity:.85;margin-left:6px;font-size:11px;text-transform:uppercase;letter-spacing:.5px}.scan-stuck{position:absolute;left:12px;right:12px;bottom:54px;z-index:3;background:#0000009e;color:#fff;border-radius:14px;padding:12px;display:flex;flex-direction:column;gap:9px;text-align:center;animation:fade .3s ease}.scan-stuck span{font-size:13.5px;font-weight:700}.scan-stuck-btns{display:flex;gap:8px}.scan-stuck-btns .btn{flex:1;justify-content:center;padding:11px}.level2{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;pointer-events:none;z-index:2}.level2-target{position:absolute;width:116px;height:116px;border-radius:50%;border:2px solid rgba(255,255,255,.45);display:grid;place-items:center}.level2-target .cross{position:absolute;background:#ffffff8c}.level2-target .cross.h{width:22px;height:2px}.level2-target .cross.v{width:2px;height:22px}.level2-target.ok{border-color:#39d353e6}.level2-target.ok .cross{background:#39d353f2}.level2-bubble{position:absolute;width:26px;height:26px;border-radius:50%;background:#ffffffeb;box-shadow:0 0 8px #00000073;transition:transform .06s linear,background .15s ease}.level2-bubble.ok{background:#39d353;box-shadow:0 0 14px #39d353cc}.level2-deg{position:absolute;top:calc(50% + 78px);font-size:12px;font-weight:800;color:#fff;background:#00000080;padding:2px 10px;border-radius:999px}.level2-deg.ok{background:#2ea043}.level-perm{position:absolute;top:50px;left:50%;transform:translate(-50%);z-index:3;border:none;background:#0000009e;color:#fff;font-family:var(--sans);font-weight:700;font-size:13px;padding:9px 16px;border-radius:999px;cursor:pointer}.scan-tip{position:absolute;top:10px;left:50%;transform:translate(-50%);z-index:2;background:#00000080;color:#fff;font-size:12px;font-weight:600;padding:5px 12px;border-radius:999px;white-space:nowrap}.loan-req{display:flex;flex-direction:column;gap:10px}.loan-req label{display:flex;flex-direction:column;gap:4px;font-size:12px;font-weight:700;color:var(--ink-soft)}.loan-req input[type=date]{font-family:var(--sans);font-size:15px;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid var(--cream-deep);background:var(--paper);color:var(--ink)}.pickup-note{font-size:13px;color:var(--ink-soft);background:#c9a66b29;padding:9px 11px;border-radius:var(--radius-sm)}.loan-q{font-size:13px;font-weight:800;color:var(--ink)}.days-pick{display:flex;flex-wrap:wrap;gap:7px}.day-chip{flex:1;min-width:64px;padding:9px 8px;border-radius:999px;border:1.5px solid var(--cream-deep);background:var(--paper);color:var(--ink-soft);font-family:var(--sans);font-weight:700;font-size:13px;cursor:pointer;transition:all .12s ease}.day-chip.active{border-color:var(--sage);background:#d6282829;color:var(--sage-deep)}.accept-form{display:flex;flex-direction:column;gap:9px;margin-top:8px;padding:10px;border-radius:var(--radius-sm);background:var(--cream);border:1px solid var(--cream-deep)}.accept-form input[type=date]{font-family:var(--sans);font-size:15px;padding:9px 11px;border-radius:var(--radius-sm);border:1px solid var(--cream-deep);background:var(--paper);color:var(--ink)}.accept-form .row{display:flex;gap:8px;justify-content:flex-end}.loan-dates{font-size:11.5px;color:var(--ink-soft)}.toast{position:absolute;top:78px;left:50%;transform:translate(-50%);z-index:60;border:none;background:linear-gradient(150deg,var(--terracotta),var(--terracotta-deep));color:var(--paper);font-family:var(--sans);font-weight:800;font-size:14px;padding:12px 20px;border-radius:999px;box-shadow:0 10px 26px #a85f3f73;cursor:pointer;animation:fade .3s ease}.notif-prompt{position:fixed;top:calc(70px + env(safe-area-inset-top));left:50%;transform:translate(-50%);z-index:45;width:min(440px,calc(100vw - 20px));display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--cream-deep);border-radius:14px;box-shadow:0 12px 34px #0000002e;padding:11px 12px 11px 14px;color:var(--ink);animation:fade .3s ease}.notif-prompt>svg{color:var(--sage);flex:none}.np-text{display:flex;flex-direction:column;line-height:1.25;flex:1;min-width:0}.np-text strong{font-size:14px}.np-text span{font-size:12px;color:var(--ink-soft)}.np-go{flex:none;padding:8px 14px}.np-close{flex:none;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:999px;background:transparent;border:none;color:var(--ink-soft);cursor:pointer}.invite-link{align-self:flex-start;margin-top:5px;border:none;background:#d628282e;color:var(--sage-deep);font-family:var(--sans);font-weight:700;font-size:12px;padding:5px 11px;border-radius:999px;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:5px}.metrics{height:100%;overflow-y:auto;-webkit-overflow-scrolling:touch;background:var(--cream);color:var(--ink);font-family:var(--sans)}.metrics-head{position:sticky;top:0;z-index:5;display:flex;align-items:center;gap:12px;padding:16px 18px;background:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--cream-deep)}.metrics-back{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:999px;background:var(--paper);color:var(--ink);flex:0 0 auto}.metrics-logo{width:38px;height:38px;object-fit:contain;flex:0 0 auto}.metrics-head h1{font-family:var(--brand);font-weight:700;font-size:20px;line-height:1}.metrics-head p{font-size:13px;color:var(--ink-soft);margin-top:2px}.metrics-body{max-width:760px;margin:0 auto;padding:18px 18px 60px}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:12px}.metric-card{display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:14px 16px;background:var(--paper);border:1px solid var(--cream-deep);border-radius:16px}.metric-card svg{color:var(--terracotta)}.metric-card strong{font-family:var(--brand);font-weight:700;font-size:26px;line-height:1}.metric-card span{font-size:12.5px;color:var(--ink-soft)}.metric-row{display:flex;align-items:center;gap:10px;margin:22px 0 4px;font-size:13px;font-weight:700}.metric-row .bar{flex:1;height:10px;border-radius:999px;background:var(--cream-deep);overflow:hidden}.metric-row .bar i{display:block;height:100%;background:var(--sage);border-radius:999px}.metrics-sub{font-size:13px;color:var(--ink-soft)}.metrics-h{font-family:var(--brand);font-weight:600;font-size:16px;margin:26px 0 10px;display:flex;align-items:center;gap:7px}.owners{display:flex;flex-direction:column;gap:8px}.owner-row{display:grid;grid-template-columns:minmax(90px,1.4fr) 2fr auto;align-items:center;gap:10px}.owner-name{font-weight:700;font-size:13.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.owner-bar{height:14px;background:var(--cream-deep);border-radius:999px;overflow:hidden}.owner-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--oak),var(--terracotta));border-radius:999px}.owner-count{font-weight:800;font-size:13px;white-space:nowrap}.owner-count em{font-style:normal;font-weight:600;font-size:11px;color:var(--ink-soft)}.exchanges{display:flex;flex-direction:column;gap:8px}.exchange-row{display:flex;align-items:center;gap:9px;padding:10px 12px;background:var(--paper);border:1px solid var(--cream-deep);border-radius:12px;font-size:13px}.ex-dot{width:9px;height:9px;border-radius:999px;flex:0 0 auto}.ex-dot.lent{background:var(--terracotta)}.ex-dot.req{background:var(--oak)}.ex-title{font-weight:700;flex:0 0 auto;max-width:42%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ex-meta{color:var(--ink-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cats{display:flex;flex-wrap:wrap;gap:8px}.cat-chip{background:var(--paper);border:1px solid var(--cream-deep);border-radius:999px;padding:6px 12px;font-size:12.5px;font-weight:600}.cat-chip b{color:var(--terracotta)}.members{display:flex;flex-wrap:wrap;gap:8px}.member-chip{display:inline-flex;align-items:center;gap:8px;padding:6px 12px 6px 6px;background:var(--paper);border:1px solid var(--cream-deep);border-radius:999px;font-size:13px;font-weight:600}.member-av{width:26px;height:26px;border-radius:999px;background:var(--ink);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;overflow:hidden;flex:0 0 auto}.member-av img{width:100%;height:100%;object-fit:cover}.community-card{position:relative}.community-gear{position:absolute;top:10px;right:10px;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:999px;background:var(--paper);border:1px solid var(--cream-deep);color:var(--ink-soft);text-decoration:none;z-index:2}.community-gear:hover{color:var(--ink)}.community-qr{top:50px;cursor:pointer}.qr-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:flex;align-items:center;justify-content:center;background:#1111118c;padding:20px}.qr-modal{position:relative;width:min(360px,92vw);background:#fff;border-radius:var(--radius);padding:22px 22px 20px;text-align:center;box-shadow:0 18px 50px #00000040}.qr-modal h3{margin:0 0 4px;font-size:17px}.qr-modal .hint{margin:0 0 14px}.qr-modal-close{position:absolute;top:12px;right:12px;display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:999px;background:var(--paper);border:1px solid var(--cream-deep);color:var(--ink-soft);cursor:pointer}.qr-modal-img{width:220px;height:220px;margin:0 auto 12px;border-radius:var(--radius-sm);overflow:hidden;background:#fff;border:1px solid var(--cream-deep)}.qr-modal-img img{width:100%;height:100%;display:block}.qr-modal .qr-link{display:block;margin:0 0 14px;word-break:break-all}.qr-modal .btn.primary{display:inline-flex;align-items:center;justify-content:center;gap:6px;width:100%}.buzon-empty{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;padding:40px 16px;color:var(--ink-soft)}.buzon-empty svg{color:var(--oak)}.buzon-card{display:flex;align-items:center;gap:12px;padding:12px;background:var(--paper);border:1px solid var(--cream-deep);border-radius:16px;margin-bottom:10px}.buzon-card.done{opacity:.7}.buzon-cover{width:46px;height:64px;flex:0 0 auto;border-radius:7px;background:var(--cream-deep);display:grid;place-items:center;overflow:hidden;color:var(--ink-soft)}.buzon-cover img{width:100%;height:100%;object-fit:cover}.buzon-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.buzon-info strong{font-family:var(--brand);font-weight:600;font-size:15px;line-height:1.2}.buzon-verb{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;color:var(--terracotta)}.buzon-sub{font-size:12.5px;color:var(--ink-soft)}.buzon-btn{flex:0 0 auto;white-space:nowrap}.buzon-qr{display:flex;gap:16px;align-items:center;margin-top:18px;padding:14px;background:var(--paper);border:1px solid var(--cream-deep);border-radius:16px}.buzon-qr img{width:140px;height:140px;border-radius:10px;background:#fff;flex:0 0 auto}.buzon-qr-info{min-width:0}.buzon-qr-info .metrics-h{margin-top:0}@media (max-width: 520px){.buzon-qr{flex-direction:column;align-items:flex-start}.buzon-qr img{width:160px;height:160px;align-self:center}}.metrics-body{max-width:980px}.metrics-layout{display:grid;grid-template-columns:260px 1fr;gap:26px;align-items:start}.metrics-aside{position:sticky;top:86px;display:flex;flex-direction:column;gap:12px}.metrics-comm{font-family:var(--brand);font-weight:700;font-size:22px;line-height:1.15}.qr-box{display:flex;flex-direction:column;gap:10px;padding:16px;background:var(--paper);border:1px solid var(--cream-deep);border-radius:16px;text-align:center}.qr-box .metrics-h{margin:0;justify-content:center;font-size:14px}.qr-box img,.qr-box .qr-ph{width:100%;aspect-ratio:1;border-radius:12px;background:#fff}.qr-box .qr-ph{border:1px dashed var(--cream-deep)}.qr-box .btn{width:100%}.metrics-main{min-width:0}@media (max-width: 720px){.metrics-layout{grid-template-columns:1fr;gap:18px}.metrics-aside{position:static}.qr-box img,.qr-box .qr-ph{max-width:220px;margin:0 auto}}.buzon-card.info{background:var(--cream)}.buzon-card.info .buzon-cover{opacity:.9}.metrics-section{background:var(--paper);border:1px solid var(--cream-deep);border-radius:16px;padding:16px 18px;margin-bottom:16px}.metrics-section .metrics-h{margin-top:0}.metrics-section .metrics-grid{gap:10px}.metrics-section .metric-card{background:var(--cream)}.metrics-section .metric-row{margin:14px 0 2px}.metrics-section .exchange-row,.metrics-section .cat-chip,.metrics-section .member-chip{background:var(--cream)}.exchange-row .ex-body{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1}.exchange-row .ex-title{max-width:none;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ex-flow{font-size:12px;color:var(--ink-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ex-flow b{color:var(--ink);font-weight:700}.ex-state{flex:0 0 auto;display:flex;flex-direction:column;align-items:flex-end;text-align:right;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.3px;color:var(--terracotta)}.ex-state em{font-style:normal;font-weight:600;text-transform:none;letter-spacing:0;color:var(--ink-soft)}.qr-link{display:block;font-size:11.5px;font-weight:600;color:var(--terracotta-deep);word-break:break-all;text-decoration:none}.qr-link:hover{text-decoration:underline}.beta-badge{display:inline-block;font-family:var(--brand);font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;color:#fff;background:var(--terracotta);padding:2px 6px;border-radius:999px;vertical-align:middle;line-height:1}.beta-badge-mobile{display:none}@media (max-width: 820px) and (orientation: portrait){.beta-badge-mobile{display:inline-block;align-self:flex-start;margin-left:-4px;margin-top:2px}}
