:root{--bg: #eef2f7;--bg-2: #ffffff;--bg-3: #f1f5f9;--line: #dbe2ec;--line-strong: #c4cedb;--text: #10233b;--muted: #62748b;--accent: #2563eb;--accent-2: #1d4ed8;--accent-soft: #e7effe;--navy: #0d1b2e;--navy-2: #132741;--danger: #dc2b4b;--ok: #0f9d6b;--warn: #d97a06;--shadow-sm: 0 1px 2px rgba(16, 35, 59, .06), 0 1px 3px rgba(16, 35, 59, .05);--shadow-md: 0 4px 14px rgba(16, 35, 59, .08);--shadow-lg: 0 12px 32px rgba(16, 35, 59, .14);color-scheme:light}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);font:15px/1.45 system-ui,-apple-system,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;overscroll-behavior:none}html.auth-page,html.auth-page body{background:var(--navy)}#root{display:flex;flex-direction:column}button{font:inherit;color:var(--text);background:var(--bg-2);border:1px solid var(--line-strong);border-radius:9px;padding:9px 14px;cursor:pointer;touch-action:manipulation;transition:transform .08s ease,box-shadow .15s ease,background .15s ease,border-color .15s ease,color .15s ease}button:hover{border-color:var(--accent)}button:active:not(:disabled){transform:scale(.96)}button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button:disabled{opacity:.45;cursor:default}button.primary{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600;box-shadow:0 1px 2px #2563eb59}button.primary:hover{background:var(--accent-2);border-color:var(--accent-2)}button.danger{color:var(--danger);border-color:transparent;background:transparent}button.danger:hover{background:#dc2b4b17;border-color:transparent}button.ghost{background:transparent;border-color:transparent}button.ghost:hover{background:var(--bg-3);border-color:transparent}button.active{background:var(--accent);color:#fff;border-color:var(--accent)}.icon-btn{width:40px;height:40px;min-width:40px;padding:0;display:grid;place-items:center;border-radius:10px}.icon-btn.round{border-radius:50%}input,select{font:inherit;color:var(--text);background:var(--bg-2);border:1px solid var(--line-strong);border-radius:9px;padding:10px 12px;width:100%;transition:border-color .15s ease,box-shadow .15s ease}input:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}label{display:block;font-size:13px;color:var(--muted);margin:10px 0 4px}a{color:var(--accent-2)}.center{flex:1;display:grid;place-items:center;padding:20px}.card{background:var(--bg-2);border:1px solid var(--line);border-radius:16px;padding:24px;width:100%;max-width:380px;box-shadow:var(--shadow-md)}.card h1{margin:0 0 4px;font-size:20px}.sub{color:var(--muted);font-size:13px;margin-bottom:8px}.err{color:var(--danger);font-size:13px;margin:8px 0 0;min-height:16px}.row{display:flex;gap:8px;align-items:center}.row.wrap{flex-wrap:wrap}.spacer{flex:1}header.app{display:flex;align-items:center;gap:10px;padding:11px 16px;background:#ffffffd9;-webkit-backdrop-filter:saturate(1.4) blur(10px);backdrop-filter:saturate(1.4) blur(10px);border-bottom:1px solid var(--line);padding-top:max(11px,env(safe-area-inset-top));position:sticky;top:0;z-index:10}header.app .brand{font-weight:700;letter-spacing:-.01em;display:flex;align-items:center;gap:9px}.brand-mark{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,var(--navy),var(--navy-2));box-shadow:0 2px 6px #0d1b2e59}.viz-logo{display:inline-flex;align-items:center;gap:9px}.viz-tile{display:grid;place-items:center;border-radius:9px;background:linear-gradient(150deg,var(--navy),var(--navy-2));box-shadow:0 2px 8px #0d1b2e66;flex:0 0 auto}.viz-wordmark{font-weight:800;font-size:17px;letter-spacing:.24em;color:var(--text)}.badge{font-size:11px;font-weight:600;padding:2px 9px;border-radius:999px;border:1px solid var(--line-strong);color:var(--muted);background:var(--bg-3);white-space:nowrap}.badge.owner{color:var(--accent);border-color:transparent;background:var(--accent-soft)}.badge.shared{color:var(--accent-2);border-color:transparent;background:#e3edff}.library{flex:1;min-height:0;padding:18px 16px 32px;overflow:auto;width:100%;max-width:1100px;margin:0 auto}.library h2{font-size:19px;letter-spacing:-.01em}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px;margin-top:16px}.plan-card{background:var(--bg-2);border:1px solid var(--line);border-radius:16px;padding:15px;display:flex;flex-direction:column;gap:9px;box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease}.plan-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--line-strong)}.plan-card:active{transform:translateY(0)}.plan-card h3{margin:0;font-size:16px;word-break:break-word;letter-spacing:-.01em}.plan-card .meta{color:var(--muted);font-size:12px;display:flex;align-items:center;gap:6px}.plan-actions{display:flex;align-items:center;gap:6px;margin-top:4px}.plan-actions .open{gap:6px;padding:8px 14px;display:inline-flex;align-items:center}.offline-chip{display:inline-flex;align-items:center;gap:4px;color:var(--ok);font-weight:600}.offline-chip:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--ok)}.here-card{display:flex;align-items:center;gap:13px;padding:14px 16px;border-radius:16px;background:linear-gradient(135deg,var(--accent),#3b82f6);color:#fff;box-shadow:0 8px 22px #2563eb47;cursor:pointer;transition:transform .14s ease,box-shadow .14s ease;margin-bottom:20px}.here-card:hover{transform:translateY(-2px);box-shadow:0 12px 28px #2563eb5c}.here-card:active{transform:translateY(0)}.here-pin{width:42px;height:42px;min-width:42px;border-radius:12px;display:grid;place-items:center;background:#ffffff38}.here-eyebrow{font-size:11px;text-transform:uppercase;letter-spacing:.09em;opacity:.85;font-weight:600;display:flex;align-items:center;gap:6px}.here-name{font-size:17px;font-weight:700;letter-spacing:-.01em;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.here-dist{font-size:12.5px;opacity:.85}.here-go{width:34px;height:34px;min-width:34px;border-radius:50%;display:grid;place-items:center;background:#ffffff38}.live-dot{width:7px;height:7px;border-radius:50%;background:#fff;box-shadow:0 0 #ffffffb3;animation:live-pulse 1.8s ease-out infinite}@keyframes live-pulse{0%{box-shadow:0 0 #fff9}70%{box-shadow:0 0 0 7px #fff0}to{box-shadow:0 0 #fff0}}@media (prefers-reduced-motion: reduce){.live-dot{animation:none}}.viewer{flex:1;position:relative;overflow:hidden;background:#dde3ec;background-image:radial-gradient(circle at 1px 1px,rgba(16,35,59,.05) 1px,transparent 0);background-size:22px 22px;touch-action:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}#stage{position:absolute;top:0;left:0;transform-origin:0 0;will-change:transform}#stage canvas.page{display:block;position:absolute;top:0;left:0;box-shadow:0 6px 26px #10233b38}#stage canvas.ink{position:absolute;top:0;left:0}.note{position:absolute;transform:translate(-50%,-100%);background:var(--warn);color:#3a2c00;border-radius:8px 8px 8px 0;padding:4px 7px;font-size:12px;max-width:180px;box-shadow:0 2px 8px #0006;cursor:pointer;white-space:pre-wrap;word-break:break-word}.gps-dot{position:absolute;width:16px;height:16px;margin:-8px 0 0 -8px;border-radius:50%;background:var(--accent);border:2px solid #06232a;box-shadow:0 0 0 2px var(--accent)}.gps-acc{position:absolute;border-radius:50%;border:1.5px solid rgba(56,189,248,.7);background:#38bdf81f;pointer-events:none}.cal-marker{position:absolute;width:14px;height:14px;margin:-7px 0 0 -7px;border-radius:50%;background:transparent;border:2px solid var(--warn);box-shadow:0 0 0 1px #06232a}.cal-marker .lbl{position:absolute;left:16px;top:-4px;font-size:11px;color:var(--warn);white-space:nowrap}.cal-marker.bad{border-color:var(--danger)}.cal-marker.bad .lbl{color:var(--danger)}.cal-marker.dragging{border-color:var(--accent);background:#22d3ee40;box-shadow:0 0 0 2px var(--accent)}.trash-zone{position:absolute;top:max(14px,env(safe-area-inset-top));left:50%;transform:translate(-50%);z-index:40;display:flex;align-items:center;gap:8px;padding:12px 18px;border-radius:999px;background:#fffffff2;border:1.5px dashed var(--danger);color:var(--danger);font-size:13px;pointer-events:none;transition:transform .12s,background .12s}.trash-zone.hot{background:var(--danger);border-style:solid;color:#fff;transform:translate(-50%) scale(1.1)}.bottombar{position:absolute;left:50%;transform:translate(-50%);bottom:max(12px,env(safe-area-inset-bottom));display:flex;align-items:center;gap:6px;background:#ffffffd1;-webkit-backdrop-filter:blur(14px) saturate(1.3);backdrop-filter:blur(14px) saturate(1.3);border:1px solid var(--line);border-radius:18px;padding:7px;z-index:20;max-width:calc(100vw - 20px);overflow-x:auto;box-shadow:var(--shadow-lg)}.leftbar{position:absolute;left:max(10px,env(safe-area-inset-left));top:50%;transform:translateY(-50%);display:flex;flex-direction:column;align-items:center;gap:6px;background:#ffffffd1;-webkit-backdrop-filter:blur(14px) saturate(1.3);backdrop-filter:blur(14px) saturate(1.3);border:1px solid var(--line);border-radius:18px;padding:7px;z-index:20;box-shadow:var(--shadow-lg)}.follow-fab{position:absolute;right:max(16px,env(safe-area-inset-right));bottom:calc(max(14px,env(safe-area-inset-bottom)) + 2px);width:58px;height:58px;padding:0;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;gap:9px;background:var(--bg-2);color:#1391bb;border:1px solid var(--line);box-shadow:var(--shadow-lg);z-index:25;transition:transform .1s ease,background .15s,color .15s,box-shadow .15s}.follow-fab svg{width:26px;height:26px}.follow-fab:hover{border-color:#38bdf8}.follow-fab:active{transform:scale(.93)}.follow-fab.following{background:#38bdf8;color:#fff;border-color:#38bdf8;box-shadow:0 8px 22px #38bdf873}.follow-fab.uncal{background:#38bdf8;color:#fff;border-color:#38bdf8;box-shadow:0 8px 22px #38bdf866;animation:fab-nudge 2.6s ease-in-out infinite}@keyframes fab-nudge{0%,92%,to{box-shadow:0 8px 22px #38bdf866}96%{box-shadow:0 8px 22px #38bdf866,0 0 0 8px #38bdf824}}@media (prefers-reduced-motion: reduce){.follow-fab.uncal{animation:none}}.tool-btn{position:relative;flex:0 0 auto;width:46px;height:46px;display:grid;place-items:center;padding:0;border-radius:13px;border:1px solid transparent;background:#10233b0d;color:var(--tool, var(--text));cursor:pointer;transition:background .15s,color .15s,box-shadow .15s,transform .08s}.tool-btn:hover:not(:disabled){background:#10233b17;border-color:transparent}.tool-btn:active:not(:disabled){transform:scale(.92)}.tool-btn:disabled{opacity:.35;cursor:default;color:var(--muted)}.tool-btn.active{background:var(--tool, var(--accent));color:#0b1220;box-shadow:0 0 0 3px color-mix(in srgb,var(--tool, var(--accent)) 32%,transparent)}.tool-btn .swatch-dot{position:absolute;right:4px;bottom:4px;width:10px;height:10px;border-radius:50%;border:1.5px solid var(--bg-2);pointer-events:none}.tool-div{width:1px;align-self:stretch;background:var(--line);margin:5px 2px}.bar-caret{flex:0 0 auto;display:grid;place-items:center;border:none;background:transparent;color:var(--muted);cursor:pointer;border-radius:8px}.bar-caret:hover{color:var(--text);background:#94a3b81f}.bottombar .bar-caret{width:24px;height:46px}.leftbar .bar-caret{width:46px;height:22px}.bar-reopen{position:absolute;z-index:20;display:grid;place-items:center;background:#ffffffd1;-webkit-backdrop-filter:blur(14px) saturate(1.3);backdrop-filter:blur(14px) saturate(1.3);border:1px solid var(--line);color:var(--muted);cursor:pointer;box-shadow:var(--shadow-md)}.bar-reopen:hover{color:var(--text)}.bar-reopen.bottom{left:50%;transform:translate(-50%);bottom:max(12px,env(safe-area-inset-bottom));width:58px;height:28px;border-radius:14px}.bar-reopen.left{left:0;top:50%;transform:translateY(-50%);width:26px;height:54px;border-radius:0 14px 14px 0;border-left:none}.bar-reopen.right{right:0;top:50%;transform:translateY(-50%);width:42px;height:54px;border-radius:14px 0 0 14px;border-right:none;color:var(--text)}.layers-panel{position:absolute;right:max(10px,env(safe-area-inset-right));top:50%;transform:translateY(-50%);width:240px;max-width:calc(100vw - 20px);max-height:80vh;overflow:auto;display:flex;flex-direction:column;gap:4px;padding:10px;background:#ffffffd1;-webkit-backdrop-filter:blur(14px) saturate(1.3);backdrop-filter:blur(14px) saturate(1.3);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-lg);z-index:22}.layers-head{display:flex;align-items:center;gap:8px;color:var(--text);font-weight:600;font-size:14px;padding:2px 2px 6px;border-bottom:1px solid var(--line);margin-bottom:4px}.layers-list{display:flex;flex-direction:column;gap:1px}.layer-icon-btn{flex:0 0 auto;width:30px;height:30px;display:grid;place-items:center;border:none;background:transparent;color:var(--muted);border-radius:8px;cursor:pointer}.layer-icon-btn:hover:not(:disabled){background:#94a3b829;color:var(--text)}.layer-icon-btn:disabled{opacity:.35;cursor:default}.layer-icon-btn.on{color:var(--accent, var(--tool))}.layer-icon-btn.danger:hover:not(:disabled){color:#ef4444;background:#ef44441f}.layer-row{border-radius:10px}.layer-row.active{background:color-mix(in srgb,var(--accent, var(--tool)) 14%,transparent)}.layer-main-row{display:flex;align-items:center;gap:1px;min-height:38px}.layer-check{flex:0 0 auto;width:18px;height:18px;margin:0 6px;border:2px solid var(--muted);border-radius:5px;background:transparent;cursor:pointer}.layer-check.on{background:var(--accent, var(--tool));border-color:var(--accent, var(--tool));box-shadow:inset 0 0 0 2px #fff}.layer-check:disabled{opacity:.3;cursor:default}.layer-dot{flex:0 0 auto;width:10px;height:10px;border-radius:50%;margin:0 2px;box-shadow:0 0 0 1px #0000001f}.layer-name{flex:1;min-width:0;display:flex;align-items:center;gap:7px;height:38px;padding:0 4px;border:none;background:transparent;color:var(--text);cursor:pointer;text-align:left}.layer-name:disabled{cursor:default}.layer-name-text{flex:1;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.layer-active-dot{flex:0 0 auto;width:6px;height:6px;border-radius:50%;background:var(--accent, var(--tool))}.layer-count{flex:0 0 auto;font-size:11px;color:var(--muted);font-variant-numeric:tabular-nums;background:#10233b17;border-radius:999px;padding:1px 7px}.layer-rename{flex:1;min-width:0;height:30px;font:inherit;font-size:14px;color:var(--text);background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:0 8px}.layer-types{display:flex;flex-direction:column;padding:0 0 4px 30px}.layer-type-row{display:flex;align-items:center;gap:6px;height:30px;padding:0 4px;border:none;background:transparent;color:var(--text);font-size:13px;cursor:pointer;border-radius:8px}.layer-type-row:hover:not(:disabled){background:#94a3b81a}.layer-type-row>span:nth-child(2){flex:1;text-align:left}.layer-add{display:flex;align-items:center;gap:6px;height:34px;margin-top:2px;padding:0 8px;border:1px dashed var(--line);background:transparent;color:var(--muted);border-radius:9px;font-size:13px;cursor:pointer}.layer-add:hover{color:var(--text);border-color:var(--muted)}.layer-add-row{display:flex;margin-top:2px}.layer-actionbar{display:flex;align-items:center;gap:6px;margin-top:6px;padding-top:6px;border-top:1px solid var(--line)}.layer-actionbar button{display:inline-flex;align-items:center;gap:4px;font-size:13px;padding:5px 9px;border:1px solid var(--line);background:var(--bg);color:var(--text);border-radius:8px;cursor:pointer}.layer-actionbar button:disabled{opacity:.4;cursor:default}.layer-actionbar button.danger:not(:disabled){color:#ef4444;border-color:color-mix(in srgb,#ef4444 40%,var(--line))}.layers-fixed{display:flex;flex-direction:column;gap:1px;margin-top:6px;padding-top:6px;border-top:1px solid var(--line)}.layer-fixed-row{display:flex;align-items:center;gap:7px;height:34px;padding:0 4px;border:none;background:transparent;color:var(--text);font-size:13px;cursor:pointer;border-radius:8px}.layer-fixed-row:hover{background:#94a3b81a}.layer-fixed-row>span:last-child{flex:1;text-align:left}.layer-confirm{margin-top:6px;padding:8px;background:#94a3b81a;border-radius:10px;font-size:12px}.layer-confirm p{margin:0 0 8px;color:var(--text)}.layer-confirm button{font-size:12px;padding:5px 8px;border:1px solid var(--line);background:var(--bg);color:var(--text);border-radius:8px;cursor:pointer}.layer-confirm button.danger{color:#ef4444;border-color:color-mix(in srgb,#ef4444 40%,var(--line))}.layer-confirm button.ghost{border-color:transparent;background:transparent;color:var(--muted)}.merge-choices{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.merge-choices button{display:flex;align-items:center;gap:7px;width:100%;text-align:left}.layer-menu-actions{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:8px}.layer-menu-actions button{display:inline-flex;align-items:center;gap:6px;justify-content:flex-start;font-size:13px;padding:7px 9px;border:1px solid var(--line);background:var(--bg);color:var(--text);border-radius:8px;cursor:pointer}.layer-menu-actions button:disabled{opacity:.4;cursor:default}.layer-menu-actions button.danger{color:#ef4444;border-color:color-mix(in srgb,#ef4444 40%,var(--line))}.layer-row.menu-open{background:color-mix(in srgb,var(--accent, var(--tool)) 8%,transparent)}.layer-picker{display:inline-flex;align-items:center;gap:8px;margin-top:10px;font-size:13px;color:var(--muted)}.layer-picker select{font:inherit;color:var(--text);background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:5px 8px}.photo-pin{position:absolute;width:54px;height:54px;transform-origin:left bottom;border-radius:10px;border:2px solid #34d399;background:#0b1220;overflow:hidden;box-shadow:0 3px 10px #00000080;cursor:pointer}.photo-pin:after{content:"";position:absolute;left:8px;bottom:-7px;width:12px;height:12px;background:#34d399;transform:rotate(45deg)}.photo-pin img{width:100%;height:100%;object-fit:cover;display:block}.photo-pop-wrap{position:fixed;inset:0;z-index:50;display:grid;place-items:center;padding:14px;background:transparent}.photo-pop{max-width:400px;display:flex;flex-direction:column;gap:9px;padding:12px;box-shadow:var(--shadow-lg);animation:note-in .2s cubic-bezier(.22,1,.36,1) both;transform-origin:50% 60%}.photo-pop-img{width:100%;max-height:38vh;object-fit:contain;border-radius:10px;background:#0b1220;cursor:zoom-in}.photo-pop-cap{font-size:13px;color:var(--text)}.photo-actions{display:flex;gap:6px}.photo-action{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:7px 4px;font-size:11.5px;border-radius:10px}.photo-action.on{border-color:var(--accent);color:var(--accent)}.photo-action.light{flex:0 0 auto;flex-direction:row;gap:7px;font-size:13px;padding:9px 16px;background:#ffffff24;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);color:#fff}.share-menu{position:absolute;bottom:calc(100% + 8px);left:0;width:230px;max-width:none;padding:6px;display:flex;flex-direction:column;gap:4px;box-shadow:var(--shadow-lg);animation:island-in-up .2s cubic-bezier(.22,1,.36,1) both;z-index:6}.share-menu button{display:flex;align-items:center;gap:8px;text-align:left;font-size:13px;border:none;background:none;padding:8px 9px;border-radius:8px}.share-menu button small{color:var(--muted);font-size:11px;margin-left:auto}.share-vizi-mark{display:grid;place-items:center;color:var(--accent)}.photo-comments{border-top:1px solid var(--bg-3);padding-top:8px;display:flex;flex-direction:column;gap:8px}.photo-comments-list{max-height:26vh;overflow-y:auto;display:flex;flex-direction:column;gap:8px}.photo-comment{display:flex;gap:7px;align-items:flex-start}.photo-comment-body{flex:1;min-width:0}.photo-comment-head{display:flex;align-items:center;gap:5px;font-size:12px}.photo-comment-name{font-weight:600}.photo-comment-del{width:20px;height:20px;min-width:20px;margin-left:auto}.photo-comment-text{font-size:13px;line-height:1.45;white-space:pre-wrap;word-break:break-word;user-select:text;-webkit-user-select:text}.mention{color:var(--accent);font-weight:600}.photo-comment-input{position:relative;display:flex;gap:7px;align-items:center}.photo-comment-input input{flex:1;font-size:13px;padding:8px 10px}.photo-comment-input .note-done{width:32px;height:32px;min-width:32px}.mention-pop{position:absolute;bottom:calc(100% + 6px);left:0;right:44px;max-width:none;padding:5px;display:flex;flex-direction:column;gap:2px;box-shadow:var(--shadow-lg);z-index:6}.mention-row{display:flex;align-items:center;gap:8px;border:none;background:none;padding:6px 8px;border-radius:8px;font-size:13px;text-align:left}.mention-row .muted{margin-left:auto;font-size:11.5px}.photo-full{position:fixed;inset:0;z-index:60;background:#050a12f5;display:grid;place-items:center}.photo-full img{max-width:100vw;max-height:100vh;object-fit:contain}.photo-full-close{position:absolute;top:max(14px,env(safe-area-inset-top));right:14px;width:40px;height:40px;padding:0;display:grid;place-items:center;border-radius:50%;border:1px solid rgba(255,255,255,.3);background:#ffffff24;color:#fff}.photo-full-bar{position:absolute;bottom:max(18px,env(safe-area-inset-bottom));left:50%;transform:translate(-50%);display:flex;gap:10px}.photo-full-bar .share-menu{bottom:calc(100% + 10px)}.place-choice{display:flex;align-items:center;gap:12px;width:100%;text-align:left;margin-top:8px;padding:12px 14px}.place-choice span{display:flex;flex-direction:column;line-height:1.3}.place-choice small{font-weight:400;font-size:12px;opacity:.75}.place-choice:disabled{opacity:.5}.marker{position:absolute;padding:0;border:none;background:none;cursor:pointer;transform-origin:center;display:grid;place-items:center;line-height:0}.marker-note{width:30px;height:30px;border-radius:9px;background:var(--warn);color:#3a2c00;box-shadow:0 2px 8px #00000080,0 0 0 1.5px #0b12208c}.marker-photo{width:46px;height:46px;border-radius:9px;overflow:hidden;background:#0b1220;box-shadow:0 2px 8px #0000008c,0 0 0 2px #34d399}.marker-photo img{width:100%;height:100%;object-fit:cover;display:block}.marker-cluster{min-width:34px;height:34px;padding:0 9px;border-radius:999px;display:flex;align-items:center;gap:4px;font-weight:700;font-size:13px;font-variant-numeric:tabular-nums;box-shadow:0 2px 10px #0000008c,0 0 0 2px #0b122099}.marker-cluster.notes{background:var(--warn);color:#3a2c00}.marker-cluster.photos{background:#34d399;color:#05271b}.marker-cluster.mixed{background:var(--accent);color:#06232a}.marker-cluster-icon{display:grid;place-items:center}.pen-anchor{position:relative}.pen-anchor .tool-btn{transition:background .34s cubic-bezier(.22,1,.36,1),color .34s cubic-bezier(.22,1,.36,1),box-shadow .34s cubic-bezier(.22,1,.36,1),transform .34s cubic-bezier(.22,1,.36,1)}.pen-anchor .tool-btn.active{transform:scale(1.05)}.pen-anchor .tool-btn.active:active{transform:scale(.94)}.pen-ext{align-self:stretch;display:grid;grid-template-rows:0fr;margin:-6px -7px 0;transition:grid-template-rows .34s cubic-bezier(.22,1,.36,1),margin-top .34s cubic-bezier(.22,1,.36,1)}.pen-ext.open{grid-template-rows:1fr;margin-top:0}.pen-ext-inner{overflow:hidden;min-height:0;display:flex;flex-direction:column;align-items:center;gap:6px}.bar-group{display:flex;flex-direction:column;align-items:center;gap:4px;padding:5px;margin:3px 0 2px;border-radius:16px;background:#10233b14}.bar-group .tool-btn{background:transparent}.bar-group .tool-btn:hover:not(:disabled){background:#10233b14}.pen-ext-item{position:relative}.pen-sub{opacity:0;transform:translateY(-8px) scale(.85);pointer-events:none;transition:opacity .22s ease,transform .3s cubic-bezier(.22,1,.36,1),background .15s,box-shadow .15s}.pen-ext.open .pen-sub{opacity:1;transform:none;pointer-events:auto}.pen-ext.open .pen-ext-item:nth-child(1) .pen-sub{transition-delay:.1s,.1s,0s,0s}.pen-ext.open .pen-ext-item:nth-child(2) .pen-sub{transition-delay:.18s,.18s,0s,0s}.hue-disc{border-radius:50%;background:radial-gradient(circle closest-side,#fff,#ffffffe6 14%,#ffffff6b 46%,#fff0 80%),conic-gradient(from 0deg,#ed4545,#ee943a,#e6e633,#85da2f,#2dd22d,#26d980,#29e0e0,#3994ef,#5555ec,#9c4ee9,#e740e7,#ec4196,#ed4545)}.pen-size-dot{border-radius:50%;box-shadow:0 0 0 1px #10233b1f;transition:width .15s ease,height .15s ease,background .15s ease}.leftbar .pen-island{position:absolute;left:56px;width:212px;padding:12px;box-shadow:var(--shadow-lg);animation:island-in .22s cubic-bezier(.22,1,.36,1) both}.leftbar .pen-island.closing{animation:island-out .17s ease both;pointer-events:none}@keyframes island-in{0%{opacity:0;transform:translate(-10px) scale(.97)}}@keyframes island-out{to{opacity:0;transform:translate(-10px) scale(.97)}}.size-slider-wrap{margin-top:12px;padding-top:12px;border-top:1px solid var(--bg-3)}.size-track{position:relative;height:26px}.size-cone{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}.size-slider{position:relative;appearance:none;display:block;width:100%;height:26px;margin:0;background:transparent;outline:none;padding:0;border:none}.size-slider::-webkit-slider-thumb{appearance:none;width:calc(14px + 12px * var(--k, .5));height:calc(14px + 12px * var(--k, .5));border-radius:50%;background:var(--pen, var(--text));border:2.5px solid var(--bg-2);box-shadow:0 1px 5px #10233b59;cursor:pointer;transition:width .12s ease,height .12s ease,background .15s ease}.size-slider::-moz-range-thumb{width:calc(14px + 12px * var(--k, .5));height:calc(14px + 12px * var(--k, .5));border-radius:50%;background:var(--pen, var(--text));border:2.5px solid var(--bg-2);box-shadow:0 1px 5px #10233b59;cursor:pointer}.pen-island .swatch{width:26px;height:26px;min-width:26px;flex:0 0 auto;padding:0;border:none;border-radius:50%}.pen-island .hue-swatch{box-shadow:0 0 0 1px #10233b2e}.pen-island .hue-swatch.on{box-shadow:0 0 0 2px var(--bg-2),0 0 0 4px var(--text)}.swatch-wrap{position:relative;display:inline-flex}.swatch-trash{position:absolute;inset:-3px;border:none;padding:0;border-radius:50%;background:var(--danger);color:#fff;display:grid;place-items:center;cursor:pointer;box-shadow:0 3px 10px #dc2b4b73;animation:trash-pop .16s ease-out}.swatch-trash:hover{border:none;background:var(--danger)}@keyframes trash-pop{0%{transform:scale(.4);opacity:0}}.hue-wheel-reveal{display:grid;grid-template-rows:0fr;transition:grid-template-rows .32s cubic-bezier(.22,1,.36,1)}.hue-wheel-reveal.open{grid-template-rows:1fr}.hue-wheel-clip{overflow:hidden;min-height:0}.hue-wheel-wrap{margin-top:12px;padding-top:12px;border-top:1px solid var(--bg-3);display:flex;flex-direction:column;align-items:center;opacity:0;transform:translateY(-6px);pointer-events:none;transition:opacity .24s ease,transform .3s cubic-bezier(.22,1,.36,1)}.hue-wheel-reveal.open .hue-wheel-wrap{opacity:1;transform:none;pointer-events:auto;transition-delay:.08s,.08s}.hue-wheel-box{position:relative;width:100%;display:flex;justify-content:center}.pen-island .hue-wheel-box .wheel-current{position:absolute;top:-2px;left:2px;box-shadow:0 0 0 1px #10233b33}.wheel-save{position:absolute;top:-4px;right:0;width:30px;height:30px;padding:0;border:none;background:none;display:grid;place-items:center;cursor:pointer;filter:drop-shadow(0 1px 1.5px rgba(16,35,59,.5))}.wheel-save:hover{background:none;border:none}.color-chip-wrap{position:relative;display:flex;flex-direction:column;align-items:flex-start;gap:8px}.color-chip-wrap:not(.float){flex:1}.color-chip{width:30px;height:30px;min-width:30px;padding:0;border:none;border-radius:50%;box-shadow:0 0 0 1px #10233b40;cursor:pointer}.color-chip-wrap .pen-island{width:100%;padding:12px;animation:island-in-up .22s cubic-bezier(.22,1,.36,1) both}.color-chip-wrap .pen-island.closing{animation:island-out-up .17s ease both;pointer-events:none}.color-chip-wrap.float .pen-island{position:absolute;bottom:calc(100% + 10px);left:-6px;width:244px;box-shadow:var(--shadow-lg);z-index:5}.hue-wheel{width:148px;height:148px;box-shadow:0 0 0 1px #10233b26,var(--shadow-sm);cursor:crosshair;touch-action:none}.hue-light{width:100%;margin-top:12px;appearance:none;height:10px;border-radius:6px;background:linear-gradient(90deg,#000,gray,#fff);outline:none;padding:0;border:none}.hue-light::-webkit-slider-thumb{appearance:none;width:18px;height:18px;border-radius:50%;background:var(--bg-2);border:2px solid var(--text);cursor:pointer}.swatch{width:28px;height:28px;min-width:28px;padding:0;border-radius:8px}.pagebar{position:absolute;top:max(10px,env(safe-area-inset-top));left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;background:#ffffffd1;-webkit-backdrop-filter:blur(14px) saturate(1.3);backdrop-filter:blur(14px) saturate(1.3);border:1px solid var(--line);border-radius:10px;padding:6px 10px;z-index:20}.overlay{position:fixed;inset:0;background:#0d1b2e59;display:grid;place-items:center;z-index:50;padding:16px}.panel{background:#ffffffd1;-webkit-backdrop-filter:blur(14px) saturate(1.3);backdrop-filter:blur(14px) saturate(1.3);border:1px solid var(--line);border-radius:14px;padding:18px;width:100%;max-width:460px;max-height:90vh;overflow:auto}.panel h2{margin:0 0 4px;font-size:17px}.side-panel{position:absolute;top:0;right:0;bottom:0;width:min(360px,90vw);background:var(--bg-2);border-left:1px solid var(--line);z-index:30;padding:16px;overflow:auto;padding-top:max(16px,env(safe-area-inset-top))}@media (max-width: 560px){.side-panel{inset:auto 0 0;width:100%;max-height:58vh;border-left:none;border-top:1px solid var(--line);border-radius:18px 18px 0 0;padding-top:14px;box-shadow:0 -10px 30px #10233b24}}.pick-banner{position:absolute;top:calc(max(10px,env(safe-area-inset-top)) + 6px);left:50%;transform:translate(-50%);width:min(520px,calc(100vw - 16px));display:flex;align-items:center;gap:12px;padding:12px 14px;background:#ffffffe6;backdrop-filter:blur(14px) saturate(1.2);border:1px solid var(--accent);border-radius:14px;box-shadow:var(--shadow-lg);z-index:45}.pick-banner-main{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.pick-banner b{font-size:14px}.pick-banner p{margin:2px 0 0;font-size:12px;color:var(--muted)}.pick-dot{flex:0 0 auto;width:14px;height:14px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px #22d3ee47;animation:pick-pulse 1.4s ease-in-out infinite}@keyframes pick-pulse{0%,to{box-shadow:0 0 0 3px #22d3ee4d}50%{box-shadow:0 0 0 7px #22d3ee14}}@media (prefers-reduced-motion: reduce){.pick-dot{animation:none}}.list{list-style:none;padding:0;margin:10px 0}.list li{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--bg-3)}.pill{font-size:11px;padding:2px 8px;border-radius:999px;border:1px solid var(--line);color:var(--muted)}.measure-bar{position:absolute;left:50%;transform:translate(-50%);bottom:calc(max(12px,env(safe-area-inset-bottom)) + 64px);width:min(560px,calc(100vw - 16px));background:#ffffffd1;-webkit-backdrop-filter:blur(14px) saturate(1.3);backdrop-filter:blur(14px) saturate(1.3);border:1px solid var(--line);border-radius:12px;padding:8px 10px;z-index:21}.measure-bar button{padding:6px 10px}.measure-bar .icon-btn,.measure-help .icon-btn{width:34px;height:34px;padding:0;display:grid;place-items:center}.measure-help .icon-btn{width:26px;height:26px}.seg-icons button{display:grid;place-items:center}.measure-help{position:absolute;bottom:calc(100% + 10px);left:0;right:0;max-width:none;padding:12px 14px;font-size:13px;box-shadow:var(--shadow-lg);animation:island-in-up .22s cubic-bezier(.22,1,.36,1) both;z-index:5}.measure-help ul{margin:8px 0 0;padding-left:18px;display:grid;gap:6px}.measure-help li svg{vertical-align:-2px}.measure-readout{font-size:14px;align-self:center;min-height:20px}.seg{display:flex}.seg button{border-radius:0;border-right-width:0}.seg button:first-child{border-radius:8px 0 0 8px}.seg button:last-child{border-radius:0 8px 8px 0;border-right-width:1px}.measure-banner{position:absolute;top:calc(max(10px,env(safe-area-inset-top)) + 52px);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:10px;background:#ffffffd1;-webkit-backdrop-filter:blur(14px) saturate(1.3);backdrop-filter:blur(14px) saturate(1.3);border:1px solid var(--warn);border-radius:10px;padding:8px 12px;z-index:21;font-size:13px;max-width:calc(100vw - 20px)}.measure-tag{position:absolute;background:#0f172ae6;border:1px solid var(--accent);color:var(--accent);border-radius:6px;padding:1px 6px;font-size:11px;font-family:ui-monospace,SF Mono,Menlo,monospace;white-space:nowrap;pointer-events:none;transform-origin:center}.measure-style{margin-top:8px;padding-top:8px;border-top:1px solid var(--line)}.swatch-row{display:flex;align-items:center;gap:8px;margin-bottom:4px}.swatch-label{font-size:12px;color:var(--muted);width:44px;flex:0 0 auto}.swatches{display:flex;gap:6px;flex-wrap:wrap}.swatch{width:22px;height:22px;padding:0;border-radius:50%;border:2px solid transparent;box-shadow:0 0 0 1px #00000026;cursor:pointer}.swatch.on{border-color:var(--text);box-shadow:0 0 0 1px var(--text)}.measure-label-input{flex:1;min-width:0;font:inherit;font-size:14px;color:var(--text);background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:6px 10px}.measure-save{display:inline-flex;align-items:center;gap:5px;flex:0 0 auto}.measure-editor-readout{font-size:20px;font-weight:600;color:var(--accent-2);font-family:ui-monospace,SF Mono,Menlo,monospace}.measure-chip{position:absolute;display:flex;flex-direction:column;align-items:center;gap:1px;max-width:180px;padding:3px 8px;background:#fffffff0;border:1.5px solid var(--accent);border-radius:9px;box-shadow:0 2px 8px #0000002e;cursor:pointer;transform-origin:center}.measure-chip-label{font-size:12px;font-weight:600;color:var(--text);max-width:164px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.measure-chip-value{font-size:11px;color:var(--muted);font-family:ui-monospace,SF Mono,Menlo,monospace;white-space:nowrap}.toasts{position:fixed;bottom:16px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:8px;z-index:100;width:min(420px,92vw)}.toast{background:var(--bg-2);border:1px solid var(--line);border-left-width:4px;border-radius:10px;padding:11px 13px;font-size:14px;box-shadow:var(--shadow-lg)}.toast.error{border-left-color:var(--danger)}.toast.success{border-left-color:var(--ok)}.toast.info{border-left-color:var(--accent-2)}.toast.warn{border-left-color:var(--warn)}.hint{color:var(--muted);font-size:12px;margin-top:6px}.good{color:var(--ok)}.bad{color:var(--danger)}.avatar{display:inline-block;flex:0 0 auto;border-radius:50%;object-fit:cover;background:var(--bg-3);box-shadow:0 0 0 1px #00000014}.avatar-fallback{display:grid;place-items:center;color:#fff;font-weight:700;letter-spacing:.02em;line-height:1;user-select:none}.profile-chip{display:inline-flex;align-items:center;gap:8px;padding:3px 10px 3px 3px;border:1px solid var(--line);background:var(--bg-2);border-radius:999px;cursor:pointer;color:var(--text);max-width:46vw}.profile-chip:hover{border-color:var(--accent)}.profile-chip-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-head{display:flex;flex-direction:column;align-items:center;gap:10px;margin:6px 0 16px}.profile-pic-actions{display:flex;gap:8px}.profile-pic-actions button{font-size:13px;padding:6px 12px}.share-name{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.field{display:flex;flex-direction:column;gap:4px;margin-top:10px}.field>span{font-size:12px;color:var(--muted)}.field input:disabled{opacity:.7}.byline{display:flex;align-items:center;gap:8px;font-size:13px;min-width:0}.byline-name{font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.byline-when{color:var(--muted);font-size:12px;white-space:nowrap}.byline-panel{margin:2px 0 12px;padding-bottom:10px;border-bottom:1px solid var(--bg-3)}.byline-photo{align-self:flex-start;padding:5px 10px 5px 5px;background:#0f172a8c;border-radius:999px;backdrop-filter:blur(6px)}.byline-photo .byline-name{color:#fff}.byline-photo .byline-when{color:#ffffffb3}.pw-field{position:relative}.pw-field input{padding-right:40px}.pw-toggle{position:absolute;right:4px;top:50%;transform:translateY(-50%);background:transparent;border:none;padding:4px 6px;font-size:15px;line-height:1;cursor:pointer;display:grid;place-items:center;color:var(--muted)}.pw-toggle:hover{color:var(--text)}.pw-toggle:hover{border:none}.avail{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:14px;font-weight:700}.avail-available{color:var(--ok)}.avail-taken,.avail-invalid{color:var(--danger)}.avail-checking{color:var(--muted)}.pw-rules{list-style:none;padding:0;margin:8px 0 0;font-size:12px}.pw-rules li{color:var(--muted);padding:2px 0;display:flex;align-items:center;gap:6px}.pw-rules li span{width:14px;text-align:center}.pw-rules li.ok{color:var(--ok)}.pw-rules li.no{color:var(--danger)}.offline-banner{background:var(--warn);color:#3a2c00;text-align:center;font-size:13px;padding:4px}.muted{color:var(--muted)}.mono{font-family:ui-monospace,SF Mono,Menlo,monospace}.spin{width:22px;height:22px;border:3px solid var(--bg-3);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-shell{flex:1;min-height:100dvh;display:grid;place-items:center;padding:32px 20px calc(32px + env(safe-area-inset-bottom));color:#e8eef7;background:radial-gradient(900px 500px at 85% -10%,rgba(37,99,235,.3),transparent 60%),radial-gradient(700px 480px at -10% 110%,rgba(59,130,246,.2),transparent 60%),repeating-linear-gradient(0deg,rgba(255,255,255,.03) 0 1px,transparent 1px 34px),repeating-linear-gradient(90deg,rgba(255,255,255,.03) 0 1px,transparent 1px 34px),linear-gradient(160deg,var(--navy) 20%,var(--navy-2) 100%)}.auth-body{width:100%;max-width:380px}.auth-logo{margin-bottom:26px}.auth-logo .viz-wordmark{letter-spacing:.26em}.auth-eyebrow{color:#7ea6f7;font-size:11.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin:0 0 8px}.auth-body h1{margin:0 0 8px;font-size:27px;letter-spacing:-.02em;color:#fff}.auth-sub{color:#e8eef7a8;font-size:14px;line-height:1.5;margin:0 0 20px}.auth-label{display:block;font-size:13px;font-weight:600;color:#e8eef7e6;margin:14px 0 6px}.auth-field{position:relative}.auth-field>.auth-field-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted);display:grid;place-items:center;pointer-events:none}.auth-field input{width:100%;padding-left:40px;height:46px;border-radius:10px}.auth-field .pw-toggle{position:absolute;right:6px;top:50%;transform:translateY(-50%)}.auth-submit{width:100%;height:48px;margin-top:18px;display:inline-flex;align-items:center;justify-content:center;gap:9px;font-size:15px;border-radius:11px}.auth-footer-card{display:flex;align-items:flex-start;gap:12px;margin-top:24px;padding:14px 16px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:13px}.auth-footer-card b{display:block;font-size:14px;color:#fff}.auth-footer-card p{margin:2px 0 4px;color:#e8eef79e;font-size:13px}.auth-footer-card a{color:#7ea6f7;font-weight:600;font-size:13px;text-decoration:none}.auth-footer-card a:hover{text-decoration:underline}.auth-footer-icon{width:36px;height:36px;min-width:36px;border-radius:10px;display:grid;place-items:center;background:#ffffff14;color:#e8eef7cc;border:1px solid rgba(255,255,255,.14)}.auth-shell .hint{color:#e8eef794}.auth-shell .pw-rules li{color:#e8eef79e}.auth-shell .pw-rules li.ok{color:#4ade80}.auth-shell .pw-rules li.no{color:#fb7185}.auth-shell .good{color:#4ade80}.auth-shell .bad{color:#fb7185}.lib-greet{margin:4px 2px 18px}.lib-greet h1{margin:0;font-size:22px;letter-spacing:-.02em;color:var(--navy)}.lib-greet p{margin:4px 0 0;color:var(--muted);font-size:13.5px}.plan-search{flex:1;min-width:140px;max-width:340px;height:40px;border-radius:10px}.note-card-anchor{position:absolute;width:0;height:0;transform-origin:0 0;z-index:6}.note-card{position:absolute;left:-125px;bottom:16px;width:250px;background:#fffbeb;border:1.5px solid #f4cf67;border-radius:13px;padding:10px 10px 8px;box-shadow:0 10px 28px #7852063d;animation:note-in .24s cubic-bezier(.22,1,.36,1) both;transform-origin:50% calc(100% + 16px)}.note-card.closing{animation:note-out .17s ease both;pointer-events:none}@keyframes note-in{0%{transform:scale(.08);opacity:0}}@keyframes note-out{to{transform:scale(.08);opacity:0}}.note-card-tail{position:absolute;left:50%;bottom:-9px;width:16px;height:16px;transform:translate(-50%) rotate(45deg);background:#fffbeb;border-right:1.5px solid #f4cf67;border-bottom:1.5px solid #f4cf67;border-bottom-right-radius:4px}.note-card textarea{display:block;width:100%;min-height:84px;max-height:220px;overflow-y:auto;resize:none;border:none;outline:none;background:transparent;font-family:inherit;font-size:14px;line-height:1.5;color:var(--text);padding:2px}.note-card-view{max-height:240px;overflow-y:auto;white-space:pre-wrap;word-break:break-word;font-size:14px;line-height:1.5;color:var(--text);padding:2px;user-select:text;-webkit-user-select:text;cursor:text}.note-card-bar{display:flex;align-items:center;gap:6px;margin-top:6px;padding-top:7px;border-top:1px solid var(--note-divider, rgba(217, 165, 32, .28));min-height:30px}.note-card-bar .byline{font-size:12px}.note-icon{width:30px;height:30px;min-width:30px;padding:0;display:grid;place-items:center;border:none;background:transparent;color:var(--muted);border-radius:8px;cursor:pointer}.note-icon:hover{background:#7852061a;color:var(--text);border:none}.note-icon.danger{color:var(--danger)}.note-done{width:34px;height:34px;min-width:34px;padding:0;display:grid;place-items:center;border:none;border-radius:50%;background:var(--accent);color:#fff;cursor:pointer;box-shadow:0 2px 8px #2563eb66}.note-done:hover{background:var(--accent-2);border:none}.note-done:disabled{opacity:.4}.note-card .pen-island{position:absolute;left:8px;bottom:46px;width:228px;padding:12px;box-shadow:var(--shadow-lg);animation:island-in-up .22s cubic-bezier(.22,1,.36,1) both;z-index:2}.note-card .pen-island.closing{animation:island-out-up .17s ease both;pointer-events:none}@keyframes island-in-up{0%{opacity:0;transform:translateY(8px) scale(.97)}}@keyframes island-out-up{to{opacity:0;transform:translateY(8px) scale(.97)}}.note-card .layer-picker{margin-top:0;font-size:12px}.note-card .layer-picker select{padding:3px 6px;font-size:12px;max-width:110px}.page-shell{flex:1;display:flex;flex-direction:column;min-height:0}.page-title{margin:0;font-size:17px;letter-spacing:-.01em}.share-stack{display:flex;align-items:center;min-height:22px}.share-stack-item{display:inline-flex;border-radius:50%;box-shadow:0 0 0 2px var(--bg-2);margin-left:-7px}.share-stack-item:first-child{margin-left:0}.share-stack-more{margin-left:5px;font-size:11.5px;font-weight:600;color:var(--muted)}.shared-via{font-size:12px;font-weight:600;color:var(--accent-2)}.team-list{display:flex;flex-direction:column;gap:10px;margin-top:10px}.team-h2{font-size:17px;letter-spacing:-.01em;margin:26px 0 0}.team-h2:first-of-type{margin-top:4px}.team-card{background:var(--bg-2);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-sm);overflow:hidden}.team-card-head{display:flex;align-items:center;gap:11px;width:100%;text-align:left;border:none;background:none;padding:12px 14px;cursor:pointer}.team-card-info{flex:1;min-width:0}.team-card-name{font-weight:650;font-size:15px}.team-card-meta{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:7px}.pending-chip{background:var(--accent-soft);color:var(--accent);font-weight:700;font-size:11px;padding:1px 8px;border-radius:999px}.team-card-body{padding:4px 14px 14px;border-top:1px solid var(--bg-3)}.team-section{margin-top:12px}.team-section h4{margin:0 0 6px;font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.team-row{display:flex;align-items:center;gap:9px;padding:5px 0}.team-row-name{font-size:14px;display:flex;flex-direction:column;line-height:1.25;min-width:0}.team-row-name small{font-size:11.5px}.team-pic-btn{width:56px;height:56px;min-width:56px;border-radius:50%;padding:0;display:grid;place-items:center;overflow:hidden;border:1.5px dashed var(--line-strong);background:var(--bg-3);color:var(--muted);cursor:pointer}.shared-plan-ico{width:38px;height:38px;min-width:38px;border-radius:12px;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent)}.pill2{position:relative;display:grid;grid-template-columns:1fr 1fr;background:var(--bg-3);border:1px solid var(--line);border-radius:999px;padding:4px}.pill2-thumb{position:absolute;top:4px;bottom:4px;left:4px;width:calc(50% - 4px);border-radius:999px;background:var(--bg-2);box-shadow:var(--shadow-sm);transition:transform .24s cubic-bezier(.22,1,.36,1)}.pill2.create .pill2-thumb{transform:translate(100%)}.pill2 button{position:relative;z-index:1;border:none;background:none;padding:9px 6px;font-size:13.5px;font-weight:600;color:var(--muted);display:flex;align-items:center;justify-content:center;gap:7px;border-radius:999px}.pill2 button.on{color:var(--text)}.team-find{margin-top:10px}.team-find-body{margin-top:12px;animation:island-in-up .2s cubic-bezier(.22,1,.36,1) both}.team-results{margin-top:8px;display:flex;flex-direction:column}.bell-wrap,.bell-btn{position:relative}.bell-badge{position:absolute;top:-3px;right:-5px;min-width:17px;height:17px;padding:0 4px;border-radius:999px;background:var(--danger);color:#fff;font-size:10.5px;font-weight:700;display:grid;place-items:center;box-shadow:0 0 0 2px var(--bg-2)}.bell-catch{position:fixed;inset:0;z-index:40}.bell-pop{position:absolute;top:calc(100% + 8px);right:-54px;width:min(340px,calc(100vw - 20px));max-width:none;padding:10px;box-shadow:var(--shadow-lg);z-index:41;animation:island-in-up .2s cubic-bezier(.22,1,.36,1) both}.bell-viewall{width:100%;margin-top:6px;font-size:13px}.notif-list{display:flex;flex-direction:column;gap:4px;margin-top:4px}.notif-row{display:flex;align-items:center;gap:9px;padding:8px;border-radius:12px}.notif-row.unseen{background:var(--accent-soft)}.notif-ico{width:30px;height:30px;min-width:30px;border-radius:50%;display:grid;place-items:center;background:var(--bg-3);color:var(--accent)}.notif-main{flex:1;min-width:0;border:none;background:none;padding:0;text-align:left;display:flex;flex-direction:column;gap:1px;cursor:pointer}.notif-text{font-size:13.5px;line-height:1.35}.notif-when{font-size:11.5px;color:var(--muted)}.notif-actions{display:flex;gap:5px}.notif-actions .icon-btn{width:30px;height:30px;min-width:30px;padding:0;display:grid;place-items:center}.profile-teams{margin-top:14px;padding-top:12px;border-top:1px solid var(--bg-3)}.profile-teams-label{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:700}.profile-team-cards{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.profile-team-card{display:flex;align-items:center;gap:8px;border:1px solid var(--line);background:var(--bg-3);border-radius:999px;padding:5px 12px 5px 6px;font-size:13px;cursor:pointer}.profile-team-name{max-width:130px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600}.profile-team-n{color:var(--muted);font-size:11.5px}.share-pop-wrap{position:fixed;inset:0;z-index:50;display:grid;place-items:center;padding:14px;background:transparent}.share-pop{max-width:380px;padding:14px;box-shadow:var(--shadow-lg);animation:note-in .2s cubic-bezier(.22,1,.36,1) both;transform-origin:50% 70%}.pill3{position:relative;display:grid;grid-template-columns:1fr 1fr 1fr;background:var(--bg-3);border:1px solid var(--line);border-radius:999px;padding:4px}.pill3-thumb{position:absolute;top:4px;bottom:4px;left:4px;width:calc(33.333% - 3px);border-radius:999px;background:var(--bg-2);box-shadow:var(--shadow-sm);transition:transform .24s cubic-bezier(.22,1,.36,1)}.pill3.team .pill3-thumb{transform:translate(100%)}.pill3.export .pill3-thumb{transform:translate(200%)}.pill3 button{position:relative;z-index:1;border:none;background:none;padding:8px 4px;font-size:12.5px;font-weight:600;color:var(--muted);display:flex;align-items:center;justify-content:center;gap:6px;border-radius:999px}.pill3 button.on{color:var(--text)}.share-tab-body{margin-top:12px;display:flex;flex-direction:column;gap:8px;animation:island-in-up .2s cubic-bezier(.22,1,.36,1) both}.export-layers{display:flex;flex-direction:column;gap:5px;max-height:34vh;overflow-y:auto}.export-layer{display:flex;align-items:center;gap:9px;border:1px solid var(--line);background:var(--bg-2);border-radius:11px;padding:8px 11px;font-size:13.5px;color:var(--muted);cursor:pointer}.export-layer.on{color:var(--text);border-color:var(--accent);background:var(--accent-soft)}.export-layer-dot{width:10px;height:10px;min-width:10px;border-radius:50%}.export-layer-name{flex:1;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.export-go{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px}
