:root{--cream: #f4ecd8;--cream-deep: #ece0c6;--paper: #fbf6ea;--oak: #c9a66b;--oak-dark: #a9854c;--walnut: #6b4e3d;--sage: #7c9473;--sage-deep: #5f7758;--terracotta: #c77b58;--terracotta-deep: #a85f3f;--ink: #3a342b;--ink-soft: #6c6354;--shadow: rgba(58, 52, 43, .18);--serif: "Fraunces", Georgia, "Times New Roman", serif;--sans: "Nunito", system-ui, -apple-system, sans-serif;--radius: 18px;--radius-sm: 12px}*{box-sizing:border-box;margin:0;padding:0}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}.brand-mark{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:#fff;overflow:hidden;box-shadow:0 4px 12px var(--shadow);flex:0 0 auto}.brand-mark img{width:100%;height:100%;object-fit:contain}.brand-name{font-family:var(--serif);font-size:22px;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:#7c94732e;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;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:var(--paper);background:linear-gradient(150deg,var(--sage),var(--sage-deep));box-shadow:0 4px 10px #5f775866}.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)}@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}.book-panel h2{font-family:var(--serif);font-weight:600;font-size:26px;line-height:1.18;color:var(--ink)}.book-panel .author{font-size:15px;color:var(--terracotta-deep);font-weight:700}.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:#7c94732e;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:100%;max-height:58vh;overflow:hidden;border-radius:14px;background:#000;display:flex;justify-content:center;touch-action:none}.cc-stage img{width:100%;height:auto;max-height:58vh;object-fit:contain;display:block;-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:flex-start;margin:0 0 6px}.panel-cover img{width:60px;height:90px;object-fit:cover;border-radius:7px;box-shadow:0 6px 16px var(--shadow)}.loan-status{display:flex;align-items:center;gap:6px;padding:10px 12px;border-radius:var(--radius-sm);background:#c77b5824;border:1px solid rgba(199,123,88,.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)}.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 #7c947359}.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:absolute;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;background:#3a342b66;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:fade .25s ease;padding:20px}.modal{position:relative;width:min(440px,100%);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;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}.scan-frame{height:190px;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}.note.warn{background:#c77b5829;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}.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);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-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}.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-info{display:flex;flex-direction:column;gap:7px;min-width:0;flex:1;justify-content:center}.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}.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(--terracotta-deep)}.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(--paper);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(--paper);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:34px;height:34px;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}}.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:#7c94732e;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:grid;place-items:center;padding:20px;background:radial-gradient(120% 100% at 50% 0%,#fbf6ea,var(--cream) 60%,var(--cream-deep));overflow-y:auto}.landing-card{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:64px;height:64px;border-radius:18px;font-size:34px;margin:0 auto}.landing-card h1{font-family:var(--serif);font-weight:600;font-size:34px;line-height:1}.landing-sub{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:#7c94732e;color:var(--sage-deep);font-weight:700}.landing-card .auth-providers,.landing-card .auth-form{text-align:left}.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-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}.invite-link{align-self:flex-start;margin-top:5px;border:none;background:#7c94732e;color:var(--sage-deep);font-family:var(--sans);font-weight:700;font-size:12px;padding:5px 11px;border-radius:999px;cursor:pointer}
