:root{--teal: #0d9488;--teal-600: #0d9488;--teal-700: #0f766e;--teal-500: #14b8a6;--orange: #f97316;--orange-600: #ea580c;--lime: #84cc16;--grad-brand: linear-gradient(135deg, #14b8a6 0%, #0d9488 55%, #0f766e 100%);--grad-warm: linear-gradient(135deg, #fb923c 0%, #f97316 100%);--radius-xs: 8px;--radius-sm: 12px;--radius: 16px;--radius-lg: 22px;--radius-xl: 28px;--pill: 999px;--maxw: 760px;--ease: .2s cubic-bezier(.2, .7, .2, 1);--font: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--sat: env(safe-area-inset-top, 0px);--sab: env(safe-area-inset-bottom, 0px);--bg: #eef4f2;--bg-grad: radial-gradient(1100px 700px at 88% -8%, rgba(249, 115, 22, .1), transparent 60%), radial-gradient(900px 650px at -10% 4%, rgba(20, 184, 166, .16), transparent 55%), #eef4f2;--surface: #ffffff;--surface-2: #f4f8f6;--surface-sunken: #eaf1ee;--surface-glass: rgba(255, 255, 255, .72);--border: rgba(15, 41, 38, .1);--border-strong: rgba(15, 41, 38, .18);--text: #14302b;--text-muted: #5a6f69;--text-faint: #8aa099;--on-brand: #ffffff;--scrim: rgba(8, 28, 24, .42);--shadow-sm: 0 1px 2px rgba(13, 60, 52, .1);--shadow: 0 12px 30px -16px rgba(13, 60, 52, .3);--shadow-lg: 0 26px 60px -24px rgba(13, 60, 52, .4);--done-bg: rgba(15, 41, 38, .04);color-scheme:light}@media (prefers-color-scheme: dark){:root:not([data-theme=light]){--bg: #0a1413;--bg-grad: radial-gradient(1100px 700px at 86% -10%, rgba(249, 115, 22, .12), transparent 58%), radial-gradient(900px 650px at -8% 6%, rgba(20, 184, 166, .16), transparent 55%), #0a1413;--surface: #10201d;--surface-2: #15302b;--surface-sunken: #0d1c1a;--surface-glass: rgba(16, 32, 29, .72);--border: rgba(255, 255, 255, .08);--border-strong: rgba(255, 255, 255, .16);--text: #e7f1ee;--text-muted: #9bb1ab;--text-faint: #6a847d;--on-brand: #ffffff;--scrim: rgba(2, 10, 9, .62);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow: 0 14px 34px -18px rgba(0, 0, 0, .7);--shadow-lg: 0 26px 60px -22px rgba(0, 0, 0, .75);--done-bg: rgba(255, 255, 255, .04);color-scheme:dark}}:root[data-theme=dark]{--bg: #0a1413;--bg-grad: radial-gradient(1100px 700px at 86% -10%, rgba(249, 115, 22, .12), transparent 58%), radial-gradient(900px 650px at -8% 6%, rgba(20, 184, 166, .16), transparent 55%), #0a1413;--surface: #10201d;--surface-2: #15302b;--surface-sunken: #0d1c1a;--surface-glass: rgba(16, 32, 29, .72);--border: rgba(255, 255, 255, .08);--border-strong: rgba(255, 255, 255, .16);--text: #e7f1ee;--text-muted: #9bb1ab;--text-faint: #6a847d;--on-brand: #ffffff;--scrim: rgba(2, 10, 9, .62);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow: 0 14px 34px -18px rgba(0, 0, 0, .7);--shadow-lg: 0 26px 60px -22px rgba(0, 0, 0, .75);--done-bg: rgba(255, 255, 255, .04);color-scheme:dark}*{box-sizing:border-box}html,body,#root{height:100%}html{-webkit-text-size-adjust:100%;scrollbar-gutter:stable}body{margin:0;font-family:var(--font);background:var(--bg);background-image:var(--bg-grad);background-attachment:fixed;color:var(--text);font-size:16px;line-height:1.45;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overscroll-behavior-y:none}button,input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}button{cursor:pointer}h1,h2,h3,p{margin:0}a{color:var(--teal-700)}::selection{background:#14b8a640}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--pill)}::-webkit-scrollbar-track{background:transparent}.app{min-height:100%;display:flex;flex-direction:column}.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 16px}.app-main{flex:1;padding-bottom:calc(40px + var(--sab))}.topbar{position:sticky;top:0;z-index:30;padding-top:var(--sat);background:var(--surface-glass);backdrop-filter:saturate(160%) blur(14px);-webkit-backdrop-filter:saturate(160%) blur(14px);border-bottom:1px solid var(--border)}.topbar-inner{max-width:var(--maxw);margin:0 auto;padding:10px 16px;display:flex;align-items:center;gap:12px}.brand{display:flex;align-items:center;gap:11px;border:0;background:none;padding:4px;border-radius:var(--radius-sm)}.brand:hover{background:var(--surface-2)}.brand-logo{width:38px;height:38px;border-radius:11px;box-shadow:var(--shadow-sm);display:block}.brand-name{font-weight:800;font-size:1.18rem;letter-spacing:-.02em;line-height:1;text-align:left}.brand-name b{background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;color:transparent}.brand-sub{display:block;font-size:.7rem;font-weight:600;color:var(--text-faint);letter-spacing:.02em;margin-top:2px}.topbar-actions{margin-left:auto;display:flex;align-items:center;gap:6px}.icon-btn{width:40px;height:40px;display:grid;place-items:center;border-radius:var(--pill);border:1px solid transparent;background:none;color:var(--text-muted);transition:var(--ease)}.icon-btn:hover{background:var(--surface-2);color:var(--text)}.icon-btn svg{width:21px;height:21px}.sync-dot{position:relative}.sync-dot:after{content:"";position:absolute;right:7px;top:7px;width:8px;height:8px;border-radius:50%;background:var(--text-faint);box-shadow:0 0 0 2px var(--surface)}.sync-dot.online:after{background:var(--lime)}.sync-dot.syncing:after{background:var(--orange);animation:pulse 1s infinite}.sync-dot.offline:after{background:#f43f5e}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid var(--surface);box-shadow:var(--shadow-sm);background:var(--grad-brand);color:#fff;font-weight:700;display:grid;place-items:center;font-size:.9rem}.avatar.btn-avatar{padding:0}.toolbar{padding:18px 0 8px;display:flex;align-items:center;gap:12px}.list-switch{display:flex;align-items:center;gap:12px;background:none;border:0;padding:4px 8px 4px 4px;border-radius:var(--radius-sm);text-align:left;min-width:0}.list-switch:hover{background:var(--surface-2)}.list-switch .ls-emoji{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;font-size:1.45rem;background:var(--surface);box-shadow:var(--shadow-sm);flex:none}.ls-text{min-width:0}.list-switch h1{font-size:1.5rem;font-weight:800;letter-spacing:-.02em;display:flex;align-items:center;gap:6px;min-width:0}.list-switch h1 .ls-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.list-switch .chev{color:var(--text-faint);flex:none}.list-sub{font-size:.82rem;color:var(--text-muted);font-weight:600;margin-top:1px}.toolbar-spacer{flex:1}.add-wrap{position:relative;margin:6px 0 16px}.add-bar{display:flex;align-items:center;gap:8px;padding:6px 6px 6px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--pill);box-shadow:var(--shadow);transition:var(--ease)}.add-bar:focus-within{border-color:var(--teal-500);box-shadow:var(--shadow),0 0 0 4px #14b8a626}.add-bar .add-ico{color:var(--text-faint);flex:none}.add-input{flex:1;border:0;background:none;outline:none;font-size:1.02rem;padding:10px 0;min-width:0}.add-input::placeholder{color:var(--text-faint)}.add-send{flex:none;width:44px;height:44px;border-radius:50%;border:0;background:var(--grad-brand);color:#fff;display:grid;place-items:center;box-shadow:var(--shadow-sm);transition:var(--ease)}.add-send:hover{filter:brightness(1.06);transform:translateY(-1px)}.add-send:disabled{opacity:.45;transform:none;filter:none}.add-send svg{width:22px;height:22px}.suggest{position:absolute;left:0;right:0;top:calc(100% + 8px);z-index:25;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;padding:6px;max-height:50vh;overflow-y:auto;animation:pop .16s var(--ease)}@keyframes pop{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}.suggest-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-faint);padding:8px 12px 4px}.suggest-item{display:flex;align-items:center;gap:12px;width:100%;text-align:left;border:0;background:none;padding:10px 12px;border-radius:var(--radius-sm);color:var(--text)}.suggest-item:hover,.suggest-item.hl{background:var(--surface-2)}.suggest-item .si-emoji{font-size:1.15rem;width:26px;text-align:center;flex:none}.suggest-item .si-main{flex:1;min-width:0}.suggest-item .si-title{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.suggest-item .si-cat{font-size:.76rem;color:var(--text-muted)}.suggest-item .si-count{font-size:.72rem;font-weight:700;color:var(--teal-700);background:#14b8a61f;padding:3px 8px;border-radius:var(--pill);flex:none}.suggest-item .si-new{font-size:.72rem;font-weight:700;color:var(--orange-600);flex:none}.list-section{margin-bottom:18px}.section-label{display:flex;align-items:center;gap:8px;margin:4px 4px 10px;font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-faint)}.section-label .sl-line{flex:1;height:1px;background:var(--border)}.section-label .sl-emoji{font-size:.95rem}.items{display:flex;flex-direction:column;gap:8px}.item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:transform .12s var(--ease),opacity var(--ease),background var(--ease);position:relative;overflow:hidden}.item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--cat-color, var(--teal));opacity:.9}.item:active{transform:scale(.992)}.item-check{flex:none;width:26px;height:26px;border-radius:9px;border:2px solid var(--border-strong);background:var(--surface-2);display:grid;place-items:center;color:#fff;transition:var(--ease);padding:0}.item-check svg{width:16px;height:16px;opacity:0;transform:scale(.5);transition:var(--ease)}.item-check:hover{border-color:var(--teal-500)}.item-body{flex:1;min-width:0;text-align:left;background:none;border:0;padding:0}.item-title{font-weight:600;font-size:1rem;overflow-wrap:anywhere}.item-desc{font-size:.84rem;color:var(--text-muted);margin-top:1px;overflow-wrap:anywhere}.item-meta{display:flex;align-items:center;gap:8px;margin-top:5px}.cat-badge{display:inline-flex;align-items:center;gap:5px;font-size:.74rem;font-weight:600;padding:3px 9px;border-radius:var(--pill);color:var(--cat-color, var(--teal-700));background:color-mix(in srgb,var(--cat-color, var(--teal)) 15%,transparent)}.cat-badge .dot{width:7px;height:7px;border-radius:50%;background:var(--cat-color, var(--teal))}.item-grip{color:var(--text-faint);flex:none;opacity:.5;transition:var(--ease);width:36px;height:36px;border-radius:50%;border:0;background:none;display:grid;place-items:center}.item-grip:hover{opacity:1;background:var(--surface-2);color:var(--text)}.item.done{background:var(--done-bg);box-shadow:none}.item.done .item-check{background:var(--teal);border-color:var(--teal)}.item.done .item-check svg{opacity:1;transform:none}.item.done .item-title{text-decoration:line-through;color:var(--text-faint);text-decoration-color:var(--text-faint)}.item.done .item-desc{text-decoration:line-through;color:var(--text-faint)}.item.done:before{opacity:.3}.item.leaving{animation:itemOut .3s ease forwards}@keyframes itemOut{to{opacity:0;transform:translate(16px);height:0;padding-top:0;padding-bottom:0;margin-top:-8px;border-width:0}}.recent-toggle{display:inline-flex;align-items:center;gap:6px;border:0;background:none;color:var(--text-muted);font-weight:600;font-size:.82rem;padding:4px 6px;border-radius:var(--radius-xs)}.recent-toggle:hover{background:var(--surface-2);color:var(--text)}.recent-toggle svg{width:16px;height:16px;transition:var(--ease)}.recent-toggle.open svg{transform:rotate(180deg)}.empty{text-align:center;padding:56px 20px;color:var(--text-muted)}.empty .emoji{font-size:3rem}.empty h3{margin:12px 0 4px;color:var(--text);font-size:1.15rem}.empty p{max-width:320px;margin:0 auto;font-size:.92rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--border);background:var(--surface);color:var(--text);padding:11px 16px;border-radius:var(--pill);font-weight:700;font-size:.94rem;transition:var(--ease);box-shadow:var(--shadow-sm);text-decoration:none}.btn:hover{text-decoration:none}.btn:hover{background:var(--surface-2)}.btn:disabled{opacity:.5;cursor:default}.btn svg{width:18px;height:18px}.btn-primary{background:var(--grad-brand);color:#fff;border-color:transparent}.btn-primary:hover{background:var(--grad-brand);filter:brightness(1.05)}.btn-warm{background:var(--grad-warm);color:#fff;border-color:transparent}.btn-warm:hover{background:var(--grad-warm);filter:brightness(1.05)}.btn-ghost{background:none;box-shadow:none;border-color:transparent}.btn-ghost:hover{background:var(--surface-2)}.btn-danger{color:#e11d48;border-color:transparent;background:#e11d481a;box-shadow:none}.btn-danger:hover{background:#e11d482e}.btn-block{width:100%}.btn-sm{padding:7px 12px;font-size:.84rem}.btn-google{background:#fff;color:#1f1f1f;border:1px solid var(--border-strong);box-shadow:var(--shadow-sm)}.btn-google:hover{background:#f5f5f5}.scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:75;background:var(--scrim);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:flex-end;justify-content:center;animation:fade .18s ease}@keyframes fade{0%{opacity:0}to{opacity:1}}.sheet{width:100%;max-width:520px;background:var(--surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;box-shadow:var(--shadow-lg);padding:8px 18px calc(20px + var(--sab));max-height:92vh;display:flex;flex-direction:column;animation:slideUp .26s var(--ease)}@keyframes slideUp{0%{transform:translateY(24px);opacity:.6}to{transform:none;opacity:1}}.sheet-handle{width:42px;height:5px;border-radius:var(--pill);background:var(--border-strong);margin:6px auto 12px;flex:none}.sheet-head{display:flex;align-items:center;gap:12px;margin-bottom:14px}.sheet-title{font-size:1.2rem;font-weight:800;letter-spacing:-.01em;flex:1}.sheet-body{overflow-y:auto;-webkit-overflow-scrolling:touch}.sheet-foot{display:flex;gap:10px;padding-top:16px}.sheet-foot .btn{flex:1}.field{margin-bottom:14px}.field label.fl{display:block;font-size:.78rem;font-weight:700;color:var(--text-muted);margin:0 2px 6px}.field input,.field textarea,.field select{width:100%;border:1px solid var(--border);background:var(--surface-2);color:var(--text);border-radius:var(--radius-sm);padding:12px 14px;outline:none;transition:var(--ease)}.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--teal-500);background:var(--surface);box-shadow:0 0 0 4px #14b8a624}.field textarea{resize:vertical;min-height:64px}.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:8px}.cat-option{display:flex;flex-direction:column;align-items:center;gap:5px;padding:12px 6px;border:1.5px solid var(--border);background:var(--surface-2);border-radius:var(--radius-sm);transition:var(--ease);color:var(--text)}.cat-option .co-emoji{font-size:1.4rem}.cat-option .co-name{font-size:.76rem;font-weight:600}.cat-option:hover{border-color:var(--border-strong)}.cat-option.active{border-color:var(--cat-color, var(--teal));background:color-mix(in srgb,var(--cat-color, var(--teal)) 12%,var(--surface))}.list-cards{display:flex;flex-direction:column;gap:8px}.list-card{display:flex;align-items:center;gap:13px;padding:13px 14px;width:100%;text-align:left;background:var(--surface-2);border:1.5px solid var(--border);border-radius:var(--radius);transition:var(--ease)}.list-card:hover{border-color:var(--border-strong)}.list-card.active{border-color:var(--teal-500);background:color-mix(in srgb,var(--teal) 9%,var(--surface))}.lc-emoji{width:44px;height:44px;border-radius:13px;display:grid;place-items:center;font-size:1.35rem;background:var(--surface);box-shadow:var(--shadow-sm);flex:none}.lc-main{flex:1;min-width:0}.lc-name{font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lc-sub{font-size:.8rem;color:var(--text-muted);display:flex;align-items:center;gap:8px;margin-top:2px}.lc-sub .shared{display:inline-flex;align-items:center;gap:4px;color:var(--teal-700)}.lc-sub .shared svg{width:14px;height:14px}.lc-actions{display:flex;gap:2px;flex:none}.chips-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}.email-chip{display:inline-flex;align-items:center;gap:7px;padding:6px 6px 6px 8px;border-radius:var(--pill);background:var(--surface-2);border:1px solid var(--border);font-size:.86rem;font-weight:600}.email-chip .avatar-xs{width:22px;height:22px;border-radius:50%;background:var(--grad-brand);color:#fff;display:grid;place-items:center;font-size:.66rem;font-weight:700;flex:none}.email-chip .x{width:24px;height:24px;border-radius:50%;border:0;background:none;color:var(--text-faint);display:grid;place-items:center}.email-chip .x:hover{background:var(--surface);color:#e11d48}.share-input-row{display:flex;gap:8px}.share-input-row input{flex:1}.hint{font-size:.82rem;color:var(--text-muted);margin-top:8px;line-height:1.45}.account-head{display:flex;align-items:center;gap:14px;padding:6px 2px 16px}.avatar-lg{width:58px;height:58px;border-radius:50%;box-shadow:var(--shadow-sm);object-fit:cover;background:var(--grad-brand);color:#fff;display:grid;place-items:center;font-size:1.4rem;font-weight:700;flex:none}.acc-name{font-weight:800;font-size:1.1rem}.acc-email{color:var(--text-muted);font-size:.88rem}.acc-info{display:flex;align-items:center;gap:8px;padding:12px 14px;background:var(--surface-2);border-radius:var(--radius-sm);font-size:.88rem;color:var(--text-muted);margin-bottom:12px;line-height:1.4}.acc-info svg{flex:none;color:var(--teal)}.menu-list{display:flex;flex-direction:column;gap:2px}.menu-item{display:flex;align-items:center;gap:12px;padding:13px 12px;border:0;background:none;width:100%;text-align:left;border-radius:var(--radius-sm);color:var(--text);font-weight:600;font-size:.96rem}.menu-item:hover{background:var(--surface-2)}.menu-item svg{width:20px;height:20px;color:var(--text-muted);flex:none}.menu-item .mi-arrow{margin-left:auto;color:var(--text-faint)}.menu-item.danger{color:#e11d48}.menu-item.danger svg{color:#e11d48}.seg-row{display:flex;align-items:center;justify-content:space-between;padding:10px 12px}.seg-row .seg-label{font-weight:600}.seg{display:inline-flex;padding:3px;gap:2px;background:var(--surface-2);border-radius:var(--pill);border:1px solid var(--border)}.seg button{border:0;background:none;color:var(--text-muted);padding:7px 11px;border-radius:var(--pill);font-weight:700;font-size:.8rem;display:inline-flex;align-items:center;gap:5px}.seg button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.seg button svg{width:15px;height:15px}.toasts{position:fixed;left:0;right:0;bottom:calc(18px + var(--sab));z-index:80;display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none;padding:0 16px}.toast{pointer-events:auto;display:flex;align-items:center;gap:12px;max-width:440px;width:100%;background:var(--text);color:var(--bg);padding:12px 14px;border-radius:var(--radius);box-shadow:var(--shadow-lg);font-size:.9rem;font-weight:600;animation:slideUp .24s var(--ease)}.toast .t-action{margin-left:auto;color:var(--teal-500);font-weight:800;background:none;border:0;padding:4px 6px}.toast .t-ico{flex:none}.offline-banner{display:flex;align-items:center;justify-content:center;gap:8px;font-size:.82rem;font-weight:600;color:var(--orange-600);background:color-mix(in srgb,var(--orange) 12%,var(--surface));padding:7px 12px}.offline-banner svg{width:16px;height:16px}.loader{display:grid;place-items:center;min-height:70vh;gap:14px;color:var(--text-muted)}.spinner{width:38px;height:38px;border-radius:50%;border:3px solid var(--border);border-top-color:var(--teal);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.brand{cursor:pointer}.demo-badge{align-self:center;font-size:.66rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--orange-600);background:color-mix(in srgb,var(--orange) 16%,transparent);padding:3px 8px;border-radius:var(--pill)}.brand-logo-wrap{display:block;line-height:0;border-radius:11px;overflow:hidden;box-shadow:var(--shadow-sm);flex:none}.brand-logo-svg{display:block}.brand-logo-svg .drop{opacity:0;transform:translateY(-9px);transform-box:fill-box;transform-origin:50% 100%;transition:transform .42s cubic-bezier(.34,1.56,.64,1),opacity .3s ease}.brand:hover .brand-logo-svg .drop{opacity:1;transform:translateY(0)}.brand:hover .brand-logo-svg .d2{transition-delay:.08s}.brand:hover .brand-logo-svg .d3{transition-delay:.16s}.brand-logo-svg.playing .drop{animation:dropLoop 2.6s infinite ease}.brand-logo-svg.playing .d2{animation-delay:.2s}.brand-logo-svg.playing .d3{animation-delay:.4s}@keyframes dropLoop{0%{opacity:0;transform:translateY(-9px)}16%,68%{opacity:1;transform:translateY(0)}86%,to{opacity:0;transform:translateY(-9px)}}.account-btn{position:relative;border:0;background:none;padding:0;border-radius:50%;display:grid;place-items:center;transition:transform var(--ease)}.account-btn:hover{transform:scale(1.06)}.account-btn .avatar{transition:box-shadow var(--ease)}.account-btn:hover .avatar{box-shadow:0 0 0 3px #14b8a647,var(--shadow-sm)}.avatar.guest{background:var(--surface-2);color:var(--text-muted)}.sync-badge{position:absolute;right:-1px;bottom:-1px;width:12px;height:12px;border-radius:50%;border:2px solid var(--surface);background:var(--text-faint)}.sync-badge.online{background:var(--lime)}.sync-badge.syncing{background:var(--orange);animation:pulse 1s infinite}.sync-badge.offline{background:#f43f5e}.sync-badge.guest{display:none}.fab{position:fixed;z-index:40;right:max(18px,env(safe-area-inset-right));bottom:calc(22px + var(--sab));width:60px;height:60px;border-radius:50%;border:0;color:#fff;background:var(--grad-brand);display:grid;place-items:center;box-shadow:0 16px 32px -10px #0d948899,var(--shadow);transition:transform var(--ease),filter var(--ease)}.fab:hover{transform:translateY(-2px) scale(1.05);filter:brightness(1.06)}.fab:active{transform:scale(.94)}.fab svg{width:28px;height:28px}.qa-sticky{position:sticky;top:0;z-index:3;background:var(--surface);padding-bottom:12px;margin-bottom:2px}.qa-input{display:flex;align-items:center;gap:8px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--pill);padding:0 8px 0 14px;transition:var(--ease)}.qa-input:focus-within{border-color:var(--teal-500);background:var(--surface);box-shadow:0 0 0 4px #14b8a624}.qa-input>svg{color:var(--text-faint);flex:none}.qa-input input{flex:1;border:0;background:none;outline:none;padding:12px 0;font-size:1rem;min-width:0}.qa-clear{border:0;background:none;color:var(--text-faint);width:32px;height:32px;border-radius:50%;display:grid;place-items:center;flex:none}.qa-clear:hover{background:var(--surface-2);color:var(--text)}.qa-new{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:12px 14px;margin-bottom:16px;border:1.5px dashed var(--teal-500);background:color-mix(in srgb,var(--teal) 8%,var(--surface));border-radius:var(--radius);font-weight:600;color:var(--text)}.qa-new .qa-emoji{font-size:1.15rem}.qa-new .qa-plus{margin-left:auto;color:var(--teal-700);display:grid;place-items:center}.qa-section{margin-bottom:16px}.qa-label{display:flex;align-items:center;gap:6px;font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-faint);margin:0 2px 8px}.qa-label svg{width:14px;height:14px}.qa-grid{display:flex;flex-wrap:wrap;gap:8px}.qa-chip{display:inline-flex;align-items:center;gap:7px;padding:8px 10px 8px 12px;border:1px solid var(--border);background:var(--surface-2);border-radius:var(--pill);font-size:.9rem;font-weight:600;color:var(--text);transition:var(--ease)}.qa-chip:hover{border-color:var(--cat-color, var(--teal));background:color-mix(in srgb,var(--cat-color, var(--teal)) 13%,var(--surface))}.qa-chip .qa-emoji{font-size:1rem}.qa-chip .qa-count{font-size:.72rem;font-weight:700;color:var(--teal-700);background:#14b8a624;padding:2px 6px;border-radius:var(--pill)}.qa-chip .qa-plus{display:grid;place-items:center;color:var(--cat-color, var(--teal));margin-left:1px}.splash{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:grid;place-items:center;padding:24px;background:var(--bg);background-image:var(--bg-grad);background-attachment:fixed}.splash-inner{display:flex;flex-direction:column;align-items:center;animation:fade .4s ease}.splash-logo{border-radius:26px;overflow:hidden;box-shadow:var(--shadow-lg);animation:floaty 3s ease-in-out infinite}.splash-name{margin-top:20px;font-size:1.9rem;font-weight:800;letter-spacing:-.02em;background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;color:transparent}.splash-tagline{color:var(--text-muted);font-weight:600;font-size:.9rem;margin-top:2px}.splash-dots{display:flex;gap:7px;margin-top:24px}.splash-dots span{width:9px;height:9px;border-radius:50%;background:var(--teal);animation:dotPulse 1.2s infinite ease}.splash-dots span:nth-child(2){animation-delay:.18s;background:var(--lime)}.splash-dots span:nth-child(3){animation-delay:.36s;background:var(--orange)}@keyframes dotPulse{0%,to{transform:scale(.55);opacity:.4}50%{transform:scale(1);opacity:1}}@keyframes floaty{0%,to{transform:translateY(0)}50%{transform:translateY(-7px)}}.app-footer{border-top:1px solid var(--border);margin-top:8px;padding:22px 16px calc(26px + var(--sab));text-align:center}.footer-links{display:flex;flex-wrap:wrap;gap:4px 18px;justify-content:center;margin-bottom:10px}.footer-links button{border:0;background:none;color:var(--text-muted);font-size:.85rem;font-weight:600;padding:4px 2px}.footer-links button:hover{color:var(--teal-700);text-decoration:underline}.footer-copy{font-size:.8rem;color:var(--text-faint)}.legal{font-size:.92rem;line-height:1.55;color:var(--text)}.legal p{margin:0 0 12px}.legal .legal-note{font-size:.82rem;color:var(--text-muted);background:var(--surface-2);border-radius:var(--radius-sm);padding:10px 12px;margin-top:4px}.item-aside{display:flex;align-items:center;gap:7px;flex:none}.item-thumb{position:relative;width:38px;height:38px;border-radius:9px;overflow:hidden;border:1px solid var(--border);padding:0;background:var(--surface-2);flex:none}.item-thumb img{width:100%;height:100%;object-fit:cover;display:block}.thumb-count{position:absolute;right:2px;bottom:2px;background:#0009;color:#fff;font-size:.62rem;font-weight:700;padding:0 5px;border-radius:var(--pill)}.item.done .item-thumb{opacity:.5}.mini-avatar{border-radius:50%;object-fit:cover;display:grid;place-items:center;background:var(--grad-brand);color:#fff;font-weight:700;flex:none;border:1.5px solid var(--surface);box-shadow:var(--shadow-sm);line-height:1}.attrib{position:relative;display:inline-flex;flex:none;cursor:pointer}.attrib-tip{position:fixed;z-index:60;width:max-content;max-width:min(260px,calc(100vw - 24px));background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);padding:10px 12px;animation:pop .14s var(--ease)}.ap-row{display:flex;gap:8px;align-items:flex-start}.ap-row+.ap-row{margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}.ap-text{font-size:.78rem;line-height:1.3}.ap-text b{font-size:.7rem;color:var(--text-muted);font-weight:700;display:block}.ap-text span{color:var(--text)}.img-grid{display:flex;flex-wrap:wrap;gap:10px}.img-thumb{position:relative;width:92px;height:92px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border)}.img-thumb img{width:100%;height:100%;object-fit:cover;display:block;cursor:zoom-in}.img-remove{position:absolute;top:4px;right:4px;width:24px;height:24px;border-radius:50%;border:0;background:#0000008c;color:#fff;display:grid;place-items:center}.img-remove:hover{background:#e11d48e6}.img-add{width:92px;height:92px;border-radius:var(--radius-sm);border:1.5px dashed var(--border-strong);background:var(--surface-2);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;color:var(--text-muted);font-size:.78rem;font-weight:600;transition:var(--ease)}.img-add:hover{border-color:var(--teal-500);color:var(--text)}.img-add:disabled{opacity:.6}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;background:#000000e6;display:grid;place-items:center;padding:24px;animation:fade .16s ease}.lightbox img{max-width:100%;max-height:100%;border-radius:var(--radius-sm)}.lightbox-close{position:absolute;top:calc(14px + var(--sat));right:16px;width:44px;height:44px;border-radius:50%;border:0;background:#ffffff29;color:#fff;display:grid;place-items:center}.view-tabs-wrap{display:flex;justify-content:center;padding:16px 0 6px}.view-tabs{display:inline-flex;padding:4px;gap:4px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--pill);box-shadow:var(--shadow-sm)}.view-tabs{max-width:100%}.view-tab{display:inline-flex;align-items:center;gap:6px;padding:9px 14px;border:0;background:none;color:var(--text-muted);font-weight:700;font-size:.86rem;border-radius:var(--pill);transition:var(--ease);white-space:nowrap}@media (max-width: 360px){.view-tab{padding:9px 11px;gap:4px;font-size:.8rem}}.view-tab svg{width:18px;height:18px}.view-tab.active{background:var(--grad-brand);color:#fff;box-shadow:var(--shadow-sm)}.view-tab:not(.active):hover{color:var(--text)}.qa-chip.qa-list{border-color:var(--border-strong)}.qa-chip.qa-list .qa-count{color:var(--orange-600);background:color-mix(in srgb,var(--orange) 16%,transparent)}.stats{padding-top:4px}.stats-tiles{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}.stat-tile{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow-sm)}.st-value{font-size:1.7rem;font-weight:800;letter-spacing:-.02em;line-height:1.1;background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;color:transparent}.st-label{font-size:.8rem;color:var(--text-muted);font-weight:600;margin-top:3px}.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;box-shadow:var(--shadow-sm);margin-bottom:14px}.chart-title{font-weight:800;font-size:1rem;margin-bottom:14px}.bars{display:flex;flex-direction:column;gap:11px}.bar-row{display:grid;grid-template-columns:minmax(84px,40%) 1fr auto;align-items:center;gap:10px}.bar-name{display:flex;align-items:center;gap:7px;font-size:.88rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bar-emoji{font-size:1rem;flex:none}.bar-track{height:10px;background:var(--surface-sunken);border-radius:var(--pill);overflow:hidden}.bar-fill{display:block;height:100%;border-radius:var(--pill);min-width:5px;transition:width .5s var(--ease)}.bar-val{font-size:.82rem;font-weight:700;color:var(--text-muted);min-width:30px;text-align:right}.wk-chart{display:flex;align-items:flex-end;gap:8px;height:130px}.wk-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:7px;height:100%}.wk-bar-wrap{flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center}.wk-bar{width:100%;max-width:30px;background:var(--grad-brand);border-radius:6px 6px 0 0;min-height:3px;transition:height .5s var(--ease)}.wk-label{font-size:.74rem;font-weight:700;color:var(--text-muted)}@media (min-width: 560px){.stats-tiles{grid-template-columns:repeat(4,1fr)}}.recipe-list{display:flex;flex-direction:column;gap:10px}.recipe-card{display:flex;align-items:stretch;gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:var(--ease);overflow:hidden}.recipe-card:hover{border-color:var(--border-strong)}.rc-open{flex:1;min-width:0;display:flex;gap:12px;text-align:left;padding:10px;background:none;border:0;align-items:center}.rc-menu{flex:none;align-self:center;margin-right:4px}.rc-thumb{width:66px;height:66px;border-radius:var(--radius-sm);overflow:hidden;flex:none;background:var(--surface-2);display:grid;place-items:center}.rc-thumb img{width:100%;height:100%;object-fit:cover}.rc-thumb-ph{font-size:1.7rem;opacity:.55}.rc-body{min-width:0;flex:1}.rc-title{font-weight:700;font-size:1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rc-sub{font-size:.78rem;color:var(--text-muted);margin-top:1px}.rc-desc{font-size:.82rem;color:var(--text-faint);margin-top:5px;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.ingredient-list{display:flex;flex-direction:column;gap:6px}.ingredient-row{display:flex;align-items:center;gap:8px;padding:6px 8px;background:var(--surface-2);border:1px solid var(--border);border-left:3px solid var(--cat-color, var(--teal));border-radius:var(--radius-sm)}.ing-emoji{font-size:1rem;flex:none}.ing-name{font-weight:600;font-size:.9rem;flex:none;max-width:40%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ing-qty{flex:1;min-width:0;border:0;background:none;outline:none;font-size:.86rem;color:var(--text);padding:4px 2px}.ing-qty::placeholder{color:var(--text-faint)}.ing-remove{flex:none;width:26px;height:26px;border:0;background:none;color:var(--text-faint);border-radius:50%;display:grid;place-items:center}.ing-remove:hover{background:var(--surface);color:#e11d48}.recipe-section{margin-top:18px;padding-top:16px;border-top:1px solid var(--border)}.rs-title{display:flex;align-items:center;gap:7px;font-weight:800;font-size:.95rem;margin-bottom:12px}.rs-title svg{width:16px;height:16px;color:var(--text-muted)}.rs-select{flex:1;min-width:0;border:1px solid var(--border);background:var(--surface-2);color:var(--text);border-radius:var(--radius-sm);padding:11px 12px}.comment-list{display:flex;flex-direction:column;gap:12px;margin-bottom:12px}.comment{display:flex;gap:10px;align-items:flex-start}.comment-body{flex:1;min-width:0;background:var(--surface-2);border-radius:var(--radius-sm);padding:8px 11px}.comment-head{font-size:.78rem;color:var(--text-muted)}.comment-head b{color:var(--text)}.comment-head span{margin-left:6px}.comment-text{font-size:.9rem;margin-top:2px;overflow-wrap:anywhere}.comment-del{flex:none;width:26px;height:26px;border:0;background:none;color:var(--text-faint);border-radius:50%;display:grid;place-items:center}.comment-del:hover{background:var(--surface-2);color:#e11d48}.comment-add{display:flex;gap:8px}.comment-add input{flex:1;min-width:0;border:1px solid var(--border);background:var(--surface-2);color:var(--text);border-radius:var(--pill);padding:11px 14px;outline:none}.comment-add input:focus{border-color:var(--teal-500);background:var(--surface)}.comment-add .btn{flex:none;padding:11px 14px}.list-sort{display:flex;align-items:center;gap:8px;justify-content:flex-end;margin:2px 2px 12px}.list-sort label{font-size:.78rem;color:var(--text-muted);font-weight:600}.list-sort select{border:1px solid var(--border);background:var(--surface-2);color:var(--text);border-radius:var(--pill);padding:7px 12px;font-size:.84rem;font-weight:600}.list-sort select:hover{border-color:var(--border-strong)}.stepper{display:inline-flex;align-items:center;gap:8px}.step-btn{flex:none;width:38px;height:38px;padding:0;aspect-ratio:1;border-radius:50%;border:1px solid var(--border);background:var(--surface-2);color:var(--text);display:grid;place-items:center}.step-btn:hover{background:var(--surface);border-color:var(--border-strong)}.step-val{width:62px;text-align:center;border:1px solid var(--border);background:var(--surface-2);color:var(--text);border-radius:var(--radius-sm);padding:9px 6px;font-weight:700;font-size:1rem;-moz-appearance:textfield}.step-val::-webkit-outer-spin-button,.step-val::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.step-unit{color:var(--text-muted);font-weight:600;font-size:.9rem}.switch-row{display:flex;align-items:center;gap:12px;justify-content:space-between;padding:8px 2px}.switch-label{font-weight:600;display:block}.switch-sub{font-size:.8rem;color:var(--text-muted);display:block;margin-top:2px;max-width:360px;line-height:1.4}.switch{flex:none;width:46px;height:28px;border-radius:var(--pill);background:var(--border-strong);position:relative;cursor:pointer;transition:var(--ease)}.switch.on{background:var(--teal)}.switch-knob{position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:#fff;box-shadow:var(--shadow-sm);transition:var(--ease)}.switch.on .switch-knob{left:21px}.recipe-page{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70;background:var(--bg);background-image:var(--bg-grad);background-attachment:fixed;display:flex;flex-direction:column;animation:fade .16s ease}.rp-bar{position:sticky;top:0;z-index:2;display:flex;align-items:center;gap:8px;padding:10px 12px;padding-top:calc(10px + var(--sat));background:var(--surface-glass);backdrop-filter:saturate(160%) blur(14px);-webkit-backdrop-filter:saturate(160%) blur(14px);border-bottom:1px solid var(--border)}.rp-bar-title{flex:1;font-weight:700;font-size:1.02rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rp-actions{display:flex;gap:2px}.rp-scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.rp-content{max-width:720px;margin:0 auto;padding:18px 18px calc(48px + var(--sab))}.rp-gallery{margin-bottom:18px}.rp-hero{display:block;width:100%;border:0;padding:0;border-radius:var(--radius-lg);overflow:hidden;background:var(--surface-2);box-shadow:var(--shadow);cursor:zoom-in}.rp-hero img{width:100%;max-height:380px;object-fit:cover;display:block}.rp-thumbs{display:flex;gap:8px;margin-top:8px;flex-wrap:wrap}.rp-thumb{width:72px;height:72px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border);padding:0;background:var(--surface-2);cursor:zoom-in}.rp-thumb img{width:100%;height:100%;object-fit:cover}.rp-title{font-size:1.8rem;font-weight:800;letter-spacing:-.02em;line-height:1.15}.rp-meta{display:flex;flex-wrap:wrap;gap:8px 16px;margin:8px 0 18px;color:var(--text-muted);font-size:.86rem;font-weight:600}.rp-persons,.rp-author{display:inline-flex;align-items:center;gap:6px}.rp-section{margin-top:22px}.rp-h2{font-size:1.15rem;font-weight:800;margin-bottom:12px;display:flex;align-items:center;gap:8px}.rp-ingredients{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:5px}.rp-ingredients li{display:flex;align-items:baseline;justify-content:space-between;gap:12px;padding:9px 12px;background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--cat-color, var(--teal));border-radius:var(--radius-sm)}.rpi-name{font-weight:600;display:flex;align-items:center;gap:8px}.rpi-emoji{font-size:1rem}.rpi-qty{color:var(--text-muted);font-size:.9rem;white-space:nowrap}.md{font-size:1rem;line-height:1.65;color:var(--text)}.md p{margin:0 0 12px}.md .md-h{margin:18px 0 8px;font-weight:800;line-height:1.25}.md h3.md-h{font-size:1.2rem}.md h4.md-h{font-size:1.05rem}.md h5.md-h,.md h6.md-h{font-size:.95rem}.md ul,.md ol{margin:0 0 12px;padding-left:22px}.md li{margin:3px 0}.md code{background:var(--surface-2);border-radius:6px;padding:1px 5px;font-size:.9em}.md a{color:var(--teal-700)}.md hr{border:0;border-top:1px solid var(--border);margin:16px 0}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;border:0;background:#ffffff29;color:#fff;display:grid;place-items:center}.lightbox-nav.prev{left:12px}.lightbox-nav.next{right:12px}.lightbox-nav svg{width:24px;height:24px}.pub-bar{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 18px;padding-top:calc(12px + var(--sat));background:var(--surface-glass);backdrop-filter:saturate(160%) blur(14px);-webkit-backdrop-filter:saturate(160%) blur(14px);border-bottom:1px solid var(--border)}.pub-brand{display:inline-flex;align-items:center;gap:9px;font-weight:800;font-size:1.2rem;letter-spacing:-.02em;color:var(--text);text-decoration:none}.pub-logo{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;background:var(--grad-brand);font-size:18px}.pub-nav{display:flex;align-items:center;gap:14px}.pub-link{color:var(--text-muted);font-weight:700;font-size:.92rem;text-decoration:none}.pub-link:hover{color:var(--teal-700)}.pub-page{padding:8px 0 40px}.pub-head{margin:12px 2px 22px}.pub-head h1{font-size:1.8rem;font-weight:800;letter-spacing:-.02em}.pub-head p{color:var(--text-muted);margin-top:6px;max-width:60ch}.pub-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.pub-rcard{display:flex;flex-direction:column;text-align:left;padding:0;overflow:hidden;border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:var(--ease);cursor:pointer}.pub-rcard:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--border-strong)}.pub-rthumb{aspect-ratio:16 / 10;background:var(--surface-2);display:grid;place-items:center;overflow:hidden}.pub-rthumb img{width:100%;height:100%;object-fit:cover}.pub-rthumb-ph{font-size:40px;opacity:.6}.pub-rbody{padding:13px 15px 15px;display:flex;flex-direction:column;gap:6px}.pub-rtitle{font-weight:800;font-size:1.05rem;letter-spacing:-.01em}.pub-rexcerpt{color:var(--text-muted);font-size:.88rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.pub-rmeta{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:4px;color:var(--text-muted);font-size:.82rem;font-weight:600}.pub-rauthor{display:inline-flex;align-items:center;gap:6px;min-width:0}.pub-rauthor span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pub-rstats{display:inline-flex;align-items:center;gap:4px;flex:none}.pub-rstats svg{vertical-align:-2px}.pub-recipe{padding-top:10px}.pub-back{display:inline-flex;align-items:center;gap:6px;background:none;border:0;color:var(--text-muted);font-weight:700;font-size:.9rem;padding:6px 0;margin-bottom:6px}.pub-back:hover{color:var(--teal-700)}.pub-actions{display:flex;flex-wrap:wrap;gap:10px;margin:16px 0 4px}.pub-source{display:inline-flex;align-items:center;gap:6px;margin:2px 0 0;padding:7px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--pill);font-size:.84rem;font-weight:600;color:var(--text-muted)}.pub-source a{color:var(--teal-700);font-weight:700}.rc-badge{display:inline-flex;align-items:center;gap:4px;margin-left:8px;padding:1px 8px;border-radius:var(--pill);background:#14b8a624;color:var(--teal-700);font-weight:700;font-size:.72rem}.rc-badge svg{width:12px;height:12px}.rp-publish{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:14px 0 2px}.rp-pub-badge{display:inline-flex;align-items:center;gap:5px;padding:5px 11px;border-radius:var(--pill);background:#14b8a624;color:var(--teal-700);font-weight:700;font-size:.82rem}.pub-bar{flex-wrap:wrap}.pub-search{flex:1 1 200px;order:3;display:flex;align-items:center;gap:8px;min-width:0;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--pill);padding:8px 14px;color:var(--text-muted);transition:var(--ease)}.pub-search:focus-within{border-color:var(--teal-500);background:var(--surface);box-shadow:0 0 0 4px #14b8a624}.pub-search svg{flex:none}.pub-search input{flex:1;min-width:0;border:0;background:none;outline:none;color:var(--text);font-weight:600;font-size:.95rem}.pub-search input::-webkit-search-cancel-button{display:none}.pub-search-clear{flex:none;display:grid;place-items:center;border:0;background:none;color:var(--text-muted);padding:2px;border-radius:50%}.pub-search-clear:hover{color:var(--text)}@media (min-width: 720px){.pub-bar{flex-wrap:nowrap}.pub-search{order:0;max-width:440px;margin:0 10px}}.pub-row-title{display:flex;align-items:center;gap:8px;font-size:1.18rem;font-weight:800;letter-spacing:-.01em;margin:26px 2px 14px}.pub-row-title svg{color:var(--teal-600)}.pub-spotlight{margin:8px 0 6px}.pub-spot{display:grid;grid-template-columns:1.05fr 1fr;width:100%;text-align:left;padding:0;overflow:hidden;border:1px solid var(--border);border-radius:var(--radius-xl);background:var(--surface);box-shadow:var(--shadow);transition:var(--ease);cursor:pointer}.pub-spot:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--border-strong)}.pub-spot-media{position:relative;background:var(--surface-2);min-height:240px}.pub-spot-media img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.pub-spot-ph{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;font-size:76px;background:var(--grad-warm)}.pub-spot-info{padding:24px 26px;display:flex;flex-direction:column;gap:10px;justify-content:center}.pub-spot-tag{display:inline-flex;align-items:center;gap:6px;align-self:flex-start;padding:4px 11px;border-radius:var(--pill);background:var(--grad-warm);color:#fff;font-weight:800;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em}.pub-spot-title{font-size:1.75rem;font-weight:800;letter-spacing:-.02em;line-height:1.12}.pub-spot-excerpt{color:var(--text-muted);line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.pub-spot-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.pub-spot-cta{align-self:flex-start;margin-top:6px}@media (max-width: 640px){.pub-spot{grid-template-columns:1fr}.pub-spot-media{min-height:0;aspect-ratio:16 / 9}.pub-spot-title{font-size:1.45rem}}.pub-row-scroll{display:flex;gap:14px;overflow-x:auto;padding:2px 2px 12px;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch}.pub-row-scroll::-webkit-scrollbar{height:8px}.pub-row-scroll::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:999px}.pub-rcard-sm{flex:0 0 220px;scroll-snap-align:start}.pub-stats{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.pub-stat{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--pill);background:var(--surface-2);color:var(--text-muted);font-size:.76rem;font-weight:700}.pub-stat svg{color:var(--text-faint)}.pub-catalog{margin-top:8px}@media print{#root,.toasts,.scrim{display:none!important}.recipe-page{position:static!important;background:#fff!important;background-image:none!important}.rp-bar,.rp-comments-add,.lightbox{display:none!important}.rp-scroll{overflow:visible!important}.rp-content{max-width:100%!important}.rp-title,.rp-h2,.md,.rp-ingredients li,.rpi-qty,.comment-text{color:#000!important}.rp-ingredients li,.comment-body{border:1px solid #ccc!important;background:#fff!important}}@media (min-width: 720px){.list-switch h1{font-size:1.7rem}.scrim{align-items:center;padding:24px}.sheet{border-radius:var(--radius-xl);animation:pop .22s var(--ease);max-height:86vh}.sheet-handle{display:none}.fab{width:64px;height:64px;right:max(28px,env(safe-area-inset-right));bottom:28px}}@media (min-width: 1000px){:root{--maxw: 860px}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}
