:root{--bg: radial-gradient(circle at 15% 10%, #eef3ff 0, #f7fbff 40%, #ffffff 100%);--surface: rgba(255, 255, 255, .86);--surface-strong: rgba(255, 255, 255, .96);--ink: #0f172a;--muted: #64748b;--primary: #0d99ff;--danger: #e11d48;--border: rgba(15, 23, 42, .1);--shadow: 0 14px 40px rgba(15, 23, 42, .1);--radius: 16px;--radius-sm: 12px;--tap: 44px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--ink);background:var(--bg)}*{box-sizing:border-box}html,body{margin:0;min-height:100%}button,input,select,textarea{font:inherit}a{color:inherit;text-decoration:none}.subtle,.muted{color:var(--muted)}.small{font-size:13px}.tiny{font-size:12px}.dot{padding:0 6px;opacity:.6}.badge{margin-left:8px;padding:2px 8px;border-radius:999px;border:1px solid var(--border);background:#0d99ff14;color:var(--primary);font-weight:700;font-size:12px}.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;border:1px solid rgba(13,153,255,.25);background:#0d99ff14;color:var(--primary);font-size:12px;font-weight:700}.pill.ghost{border-color:var(--border);background:#0f172a0a;color:var(--muted)}.btn{min-height:var(--tap);padding:10px 14px;border-radius:14px;border:1px solid var(--border);background:#ffffffd9;color:var(--ink);box-shadow:0 10px 24px #0f172a0f;cursor:pointer}.btn.primary{border:none;background:linear-gradient(135deg,#0d99ff,#3f7cff);color:#fff;box-shadow:0 12px 30px #0d99ff4d}.btn.ghost{background:transparent;box-shadow:none}.btn.danger,.btn.ghost.danger{color:var(--danger);border-color:#e11d4840}.btn:disabled{opacity:.6;cursor:not-allowed}.w-full{width:100%}.input{width:100%;min-height:var(--tap);padding:10px 12px;border-radius:14px;border:1px solid var(--border);background:#ffffffeb;box-shadow:0 10px 24px #0f172a0a}.textarea{resize:vertical;min-height:110px}.icon-btn{width:var(--tap);height:var(--tap);display:grid;place-items:center;border-radius:14px;border:1px solid var(--border);background:#ffffffbf;cursor:pointer}.icon-btn.danger{color:var(--danger);border-color:#e11d4840}.stack{display:flex;flex-direction:column}.gap{gap:10px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.inline{display:flex;gap:10px;align-items:center}.field{display:flex;flex-direction:column;gap:6px}.field-label{font-size:13px;color:var(--muted)}.toggle{display:flex;gap:10px;align-items:center}.toggle input{width:18px;height:18px}.banner{padding:10px 12px;border-radius:14px;border:1px solid var(--border);background:#fffc;margin:10px 0}.banner.error{border-color:#e11d4840;background:#e11d4814;color:#9f1239}.skeleton{color:var(--muted);padding:18px 4px}.empty{padding:28px 14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface-strong);box-shadow:var(--shadow);text-align:center}.empty-title{font-size:18px;font-weight:800;margin-bottom:6px}.empty-inline{padding:10px 4px}.shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:22px}.card{width:100%;max-width:520px;background:var(--surface-strong);border:1px solid var(--border);border-radius:22px;padding:22px;box-shadow:var(--shadow)}.title{margin:0 0 4px;font-size:26px}.subtitle{margin:0 0 18px;color:var(--muted)}.form{display:flex;flex-direction:column;gap:12px}.form label{display:flex;flex-direction:column;gap:6px;color:var(--muted);font-size:14px}.form button.primary,.primary{border:none;background:linear-gradient(135deg,#0d99ff,#3f7cff);color:#fff}.ghost{background:transparent}.hint{color:var(--muted);font-size:14px}.error{color:#9f1239;font-size:14px}.screen-center{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--muted)}.loader{width:32px;height:32px;border-radius:50%;border:3px solid rgba(15,23,42,.12);border-top-color:var(--primary);animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app{min-height:100dvh;display:flex;flex-direction:column}.app-center{justify-content:center;padding:18px}.center-card{width:100%;max-width:520px;margin:0 auto;background:var(--surface-strong);border:1px solid var(--border);border-radius:22px;padding:22px;box-shadow:var(--shadow)}.h1{margin:0 0 10px;font-size:24px}.app-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:calc(12px + var(--safe-top)) 14px 12px;background:#ffffffbf;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.app-title{font-weight:800;letter-spacing:-.02em}.group-pill{display:flex;align-items:baseline;gap:8px;padding:10px 12px;border-radius:14px;border:1px solid var(--border);background:#ffffffbf;cursor:pointer}.group-pill-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.group-pill-name{font-weight:800}.group-pill-caret{color:var(--muted)}.avatar-dot{width:28px;height:28px;border-radius:12px;background:#0f172a14;display:grid;place-items:center;font-weight:900}.app-main{flex:1;padding:14px 14px calc(86px + var(--safe-bottom));width:100%;max-width:980px;margin:0 auto}.toast{position:fixed;left:50%;transform:translate(-50%);top:calc(10px + var(--safe-top));z-index:50;max-width:min(520px,calc(100vw - 24px));padding:10px 12px;border-radius:16px;border:1px solid var(--border);background:#ffffffeb;box-shadow:var(--shadow);color:var(--ink)}.toast.error{border-color:#e11d4840;color:#9f1239}.toast.success{border-color:#0d99ff40;color:#075985}.bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:30;display:flex;justify-content:space-around;gap:6px;padding:8px 10px calc(10px + var(--safe-bottom));background:#ffffffc7;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-top:1px solid var(--border)}.nav-item{flex:1;max-width:140px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px;border-radius:16px;color:var(--muted)}.nav-item svg{width:22px;height:22px;fill:currentColor}.nav-item span{font-size:12px;font-weight:700}.nav-item.active{color:var(--primary);background:#0d99ff1a}.page,.page-toolbar{display:flex;flex-direction:column;gap:10px}.toolbar-row{display:flex;gap:10px;align-items:center}.toolbar-row .input{flex:1}.sections,.cards{display:flex;flex-direction:column;gap:12px}.split{display:grid;grid-template-columns:1fr;gap:12px;align-items:start}.split.two{grid-template-columns:1fr}.split-col{min-width:0}.section{background:var(--surface-strong);border:1px solid var(--border);border-radius:var(--radius);padding:12px;box-shadow:0 10px 24px #0f172a0f}.section-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.section-title{font-weight:900}.section-meta{color:var(--muted);font-weight:800;font-size:13px}.rows{display:flex;flex-direction:column;gap:10px}.row{display:flex;gap:12px;align-items:flex-start;padding:12px;border-radius:16px;border:1px solid var(--border);background:#ffffffd9}.row.done{opacity:.65}.row.done .row-title{text-decoration:line-through}.row-main{flex:1;min-width:0}.row-title{font-weight:900;word-break:break-word}.row-sub{margin-top:3px;display:flex;flex-wrap:wrap;gap:0;align-items:center;font-size:13px}.link{color:var(--primary);font-weight:800}.check{width:var(--tap);height:var(--tap);border-radius:16px;border:1px solid var(--border);background:#ffffffb3;display:grid;place-items:center;cursor:pointer}.check-box{width:18px;height:18px;border-radius:6px;border:2px solid rgba(15,23,42,.3);position:relative}.check-box.checked{border-color:#0d99ffa6;background:#0d99ff2e}.check-box.checked:after{content:"";position:absolute;left:5px;top:1px;width:5px;height:10px;border:solid rgba(13,153,255,.9);border-width:0 2px 2px 0;transform:rotate(45deg)}.fab{position:fixed;right:16px;bottom:calc(76px + var(--safe-bottom));width:56px;height:56px;border-radius:18px;border:none;background:linear-gradient(135deg,#0d99ff,#3f7cff);color:#fff;font-size:32px;line-height:0;box-shadow:0 18px 40px #0d99ff59;cursor:pointer}.fab:disabled{opacity:.5;cursor:not-allowed}.card-msg{background:var(--surface-strong);border:1px solid var(--border);border-radius:var(--radius);padding:14px;box-shadow:0 10px 24px #0f172a0f}.card-msg-top{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px}.card-msg-body{font-size:16px;font-weight:800;line-height:1.35;white-space:pre-wrap}.card-msg-bottom{margin-top:12px;display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}.card-msg-actions{display:flex;gap:10px;flex-wrap:wrap}.segmented{display:flex;gap:6px;padding:6px;border-radius:18px;border:1px solid var(--border);background:#fff9}.seg{flex:1;min-height:var(--tap);padding:10px 12px;border-radius:14px;border:1px solid transparent;background:transparent;color:var(--muted);font-weight:900;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}.seg.active{background:#0d99ff1a;color:var(--primary);border-color:#0d99ff2e}.seg-count{font-size:12px;opacity:.9}.dashboard{width:100%;max-width:1200px;margin:0 auto;padding:18px;display:flex;flex-direction:column;gap:16px}.dashboard.single-panel .grid{grid-template-columns:1fr}.topbar{position:sticky;top:12px;z-index:10;display:flex;flex-direction:column;gap:12px;padding:12px 14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface-strong);box-shadow:var(--shadow)}.brand{display:flex;align-items:center;gap:12px}.logo{width:36px;height:36px;border-radius:12px;background:#0d99ff1f;color:var(--primary);display:grid;place-items:center;font-weight:900}.actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.user{display:flex;gap:8px;align-items:center}.view-switch{display:flex;gap:8px;flex-wrap:wrap}.view-switch .ghost.active{color:var(--primary);border-color:#0d99ff47;background:#0d99ff14}.grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.panel{background:var(--surface-strong);border:1px solid var(--border);border-radius:var(--radius);padding:14px;box-shadow:0 10px 24px #0f172a0f}.panel-head{display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:space-between}.panel-head h3{margin:0}.panel-subhead{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:8px}.inline-form{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.inline-form input,.inline-form select{min-height:var(--tap);padding:8px 10px;border-radius:12px;border:1px solid var(--border);background:#ffffffe6}.inline-form button.primary{border:none;background:linear-gradient(135deg,#0d99ff,#3f7cff);color:#fff;padding:8px 12px;border-radius:12px}.tiny-btn{min-height:30px;padding:6px 10px;border-radius:10px;border:1px solid var(--border);background:#ffffffb3;font-size:12px;cursor:pointer}.ghost.tiny-btn{background:transparent;box-shadow:none}.message-columns{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}.message{border:1px solid var(--border);background:#ffffffd9;border-radius:16px;padding:12px;display:flex;flex-direction:column;gap:8px}.message.pinned{border-color:#0d99ff40;background:#0d99ff14}.message.ghost{background:#fff9}.message-body{font-weight:700}.message-actions{display:flex;gap:8px;flex-wrap:wrap}.item{display:flex;gap:10px;align-items:flex-start;padding:10px 12px;border-radius:14px;border:1px solid var(--border);background:#ffffffd9}.item.completed{opacity:.65}.item.completed .item-name{text-decoration:line-through}.item-name{font-weight:800}.member{display:flex;gap:12px;align-items:center;padding:10px;border-radius:14px;border:1px solid var(--border);background:#fffc}.pinned-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.pinned-card{border:1px solid var(--border);background:#ffffffd9;border-radius:16px;padding:12px;display:flex;flex-direction:column;gap:8px}.pinned-card-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.pinned-card-title{font-weight:900}.pinned-card-actions{display:flex;gap:8px}.store-card{background:var(--surface-strong);border:1px solid var(--border);border-radius:var(--radius);padding:14px;box-shadow:0 10px 24px #0f172a0f}.store-top{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}.store-name{font-weight:900;font-size:16px}.store-deps{margin-top:12px;display:flex;flex-direction:column;gap:10px}.store-main{flex:1;min-width:0}.chips{display:flex;flex-wrap:wrap;gap:8px}.chip{padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:#0f172a0a;font-weight:800;font-size:12px;color:var(--muted)}.chip-btn{cursor:pointer}.chip-btn.add{color:var(--primary);border-color:#0d99ff47;background:#0d99ff14}.favorites-bar{display:flex;gap:8px;overflow-x:auto;padding:2px 2px 6px;scroll-snap-type:x proximity}.favorites-bar>*{scroll-snap-align:start}.favorites-bar::-webkit-scrollbar{height:6px}.favorites-bar::-webkit-scrollbar-thumb{background:#0f172a2e;border-radius:999px}.avatar{width:42px;height:42px;border-radius:16px;background:#0f172a0f;display:grid;place-items:center;font-weight:900}.sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;background:#02061773;display:flex;align-items:flex-end;justify-content:center;padding:14px;padding-bottom:calc(14px + var(--safe-bottom))}.sheet{width:min(720px,100%);max-height:85dvh;overflow:auto;background:#fffffffa;border-radius:24px;border:1px solid var(--border);box-shadow:0 24px 60px #0000004d}.sheet-head{position:sticky;top:0;z-index:1;display:flex;justify-content:space-between;align-items:center;gap:10px;padding:14px;border-bottom:1px solid var(--border);background:#fffffff5;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.sheet-title{font-weight:900}.sheet-body{padding:14px}.sheet-footer{padding:14px;border-top:1px solid var(--border)}.sheet-section{display:flex;flex-direction:column;gap:10px}.sheet-section-title{font-weight:900;color:var(--muted);font-size:13px;text-transform:uppercase;letter-spacing:.08em}.list{display:flex;flex-direction:column;gap:8px}.list-row{text-align:left;display:flex;justify-content:space-between;gap:10px;align-items:center;padding:12px;border-radius:16px;border:1px solid var(--border);background:#ffffffd9;cursor:pointer}.list-row.active{border-color:#0d99ff4d;background:#0d99ff14}.row-meta{font-size:12px;color:var(--primary);font-weight:900}.shop-center{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:22px}.shop-app{min-height:100dvh;display:flex;flex-direction:column}.shop-header{position:sticky;top:0;z-index:30;padding:calc(12px + var(--safe-top)) 14px 10px;background:#ffffffc7;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}.shop-header-row{display:grid;grid-template-columns:1fr 1fr var(--tap) var(--tap);gap:10px;align-items:center}.shop-chip{min-height:var(--tap);padding:10px 12px;border-radius:16px;border:1px solid var(--border);background:#ffffffd9;box-shadow:0 10px 24px #0f172a0d;cursor:pointer;text-align:left;display:grid;grid-template-columns:1fr auto;gap:6px 10px;align-items:baseline}.shop-chip:disabled{opacity:.6;cursor:not-allowed}.shop-chip-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.shop-chip-value{font-weight:900;letter-spacing:-.01em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shop-chip-caret{color:var(--muted)}.shop-favs{margin-top:10px;display:flex;gap:8px;overflow-x:auto;padding:2px 2px 6px;scroll-snap-type:x proximity}.shop-favs>*{scroll-snap-align:start}.shop-favs::-webkit-scrollbar{height:6px}.shop-favs::-webkit-scrollbar-thumb{background:#0f172a2e;border-radius:999px}.shop-tools{margin-top:10px;display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:center}.shop-tools .btn{width:auto}.shop-tools .input{box-shadow:0 10px 24px #0f172a0a}.shop-storebar{margin-top:10px;display:flex;justify-content:space-between;align-items:center;gap:10px}.shop-storebar .btn{width:auto}.shop-main{flex:1;width:100%;max-width:900px;margin:0 auto;padding:12px 14px calc(92px + var(--safe-bottom))}.shop-content{display:flex;flex-direction:column;gap:14px}.shop-section{background:var(--surface-strong);border:1px solid var(--border);border-radius:var(--radius);padding:10px;box-shadow:0 10px 24px #0f172a0f}.shop-section-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;padding:6px 6px 10px}.shop-section-title{font-weight:900}.shop-section-meta{color:var(--muted);font-weight:900;font-size:13px}.shop-rows{display:flex;flex-direction:column;gap:10px}.shop-row{display:grid;grid-template-columns:var(--tap) 1fr var(--tap);gap:10px;align-items:center;padding:12px;border-radius:18px;border:1px solid var(--border);background:#ffffffe6}.shop-row.done{opacity:.65}.shop-row.done .shop-row-title{text-decoration:line-through}.shop-check{position:relative;width:var(--tap);height:var(--tap);border-radius:18px;border:1px solid var(--border);background:#ffffffbf;display:grid;place-items:center;cursor:pointer}.shop-check input{position:absolute;opacity:0;width:1px;height:1px}.shop-check-ui{width:18px;height:18px;border-radius:7px;border:2px solid rgba(15,23,42,.3);position:relative}.shop-check input:checked+.shop-check-ui,.shop-check-ui.checked{border-color:#0d99ffa6;background:#0d99ff2e}.shop-check input:checked+.shop-check-ui:after,.shop-check-ui.checked:after{content:"";position:absolute;left:5px;top:1px;width:5px;height:10px;border:solid rgba(13,153,255,.9);border-width:0 2px 2px 0;transform:rotate(45deg)}.shop-row-main{min-width:0}.shop-row-title{font-weight:900;letter-spacing:-.01em;word-break:break-word}.shop-row-sub{margin-top:3px;font-size:13px;display:flex;flex-wrap:wrap;gap:0;align-items:center}.shop-addbar{position:fixed;left:0;right:0;bottom:0;z-index:35;padding:10px 12px calc(10px + var(--safe-bottom));background:#fffc;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid var(--border)}.shop-addbar-inner{width:100%;max-width:900px;margin:0 auto;display:grid;grid-template-columns:auto 1fr auto auto;gap:10px;align-items:center}.qty-stepper{display:grid;grid-template-columns:34px 42px 34px;height:var(--tap);border-radius:16px;border:1px solid var(--border);background:#ffffffe0;overflow:hidden}.qty-stepper button{border:none;background:transparent;cursor:pointer;font-size:18px}.qty-stepper span{display:grid;place-items:center;font-weight:900;color:var(--ink);border-left:1px solid var(--border);border-right:1px solid var(--border)}.shop-addbar .btn{width:auto}@media (min-width: 980px){.app-main{padding-left:18px;padding-right:18px}.bottom-nav{left:50%;transform:translate(-50%);max-width:980px;border-radius:20px 20px 0 0}.fab{right:calc(50% - 472px)}}@media (max-width: 520px){.grid-2{grid-template-columns:1fr}.toolbar-row,.inline{flex-direction:column;align-items:stretch}.btn{width:100%}}@media (min-width: 900px){.split.two{grid-template-columns:1fr 1fr}}
