:root,:root[data-theme=light]{--bg:#f8fafc;--surface:#fff;--surface2:#f1f5f9;--text-pri:#1a1a2e;--text-sec:#6b7280;--text-ter:#9ca3af;--text-checked:#9ca3af;--divider:#e5e7eb;--divider-soft:#f1f5f9;--sidebar-bg:#f1f5f9;--nav-selected-bg:#fff;--nav-selected-shadow:0 1px 2px #1414280f;--count-pill-bg:#ffffffbf;--count-pill-border:transparent;--wash-alpha:.08;--wash-border-alpha:.15;--progress-track:#e5e7eb}:root[data-theme=dark]{--bg:#0a0907;--surface:#221f1c;--surface2:#2f2b27;--text-pri:#fbf9f5;--text-sec:#b8b3ac;--text-ter:#878178;--text-checked:#787269;--divider:#3a3631;--divider-soft:#2b2824;--sidebar-bg:#ffffff05;--nav-selected-bg:#ffffff14;--nav-selected-shadow:none;--count-pill-bg:transparent;--count-pill-border:currentColor;--wash-alpha:.14;--wash-border-alpha:.28;--progress-track:#ffffff14}:root{--primary:#1a73e8;--primary-hov:#1557b0;--accent:#f97316;--accent-dk:#ea580c;--success:#16a34a;--warning:#d97706;--error:#dc2626;--mic-gradient:radial-gradient(circle at 30% 30%, #fb923c, #f97316);--font:ui-rounded, -apple-system, "SF Pro Rounded", "SF Pro", system-ui, sans-serif;--mono:ui-monospace, "SF Mono", Menlo, monospace}*{box-sizing:border-box}html,body,#root{height:100%}body{background:var(--bg);color:var(--text-pri);font-family:var(--font);-webkit-font-smoothing:antialiased;margin:0}button{font-family:var(--font)}input,textarea{font-family:var(--font);color:var(--text-pri)}.shell{height:100dvh;display:flex}.sidebar{border-right:1px solid var(--divider);background:var(--sidebar-bg);flex-direction:column;flex-shrink:0;width:240px;padding:18px 12px 14px;display:flex}.logo-row{align-items:center;gap:9px;padding:0 8px 18px;display:flex}.logo-mark{background:var(--mic-gradient);border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.logo-name{letter-spacing:-.3px;font-size:16px;font-weight:700}.nav-section{color:var(--text-ter);letter-spacing:.8px;text-transform:uppercase;padding:4px 12px 6px;font-size:10px;font-weight:700}.nav-row{width:100%;color:var(--text-sec);cursor:pointer;letter-spacing:-.1px;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:10px;padding:8px 12px;font-size:14px;font-weight:500;display:flex}.nav-row.selected{background:var(--nav-selected-bg);box-shadow:var(--nav-selected-shadow);color:var(--text-pri);font-weight:600}.nav-row .nav-label{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.nav-count{color:var(--text-ter);font-size:12px}.shopping-pill{letter-spacing:.4px;text-transform:uppercase;color:var(--accent-dk);background:#f9731624;border-radius:4px;padding:2px 6px;font-size:9px;font-weight:700}.nav-new{color:var(--text-ter);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:8px 12px;font-size:13px;font-weight:500;display:flex}.sidebar-footer{border-top:1px solid var(--divider);cursor:pointer;background:0 0;border-bottom:none;border-left:none;border-right:none;align-items:center;gap:10px;width:100%;padding:10px 8px 0;display:flex}.avatar{color:#fff;background:#6366f1;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.sidebar-footer .name{min-width:0;color:var(--text-pri);letter-spacing:-.1px;text-overflow:ellipsis;white-space:nowrap;text-align:left;flex:1;font-size:13px;font-weight:600;overflow:hidden}.main{flex-direction:column;flex:1;min-width:0;display:flex;position:relative;overflow:hidden}.screen{flex:1;overflow-y:auto}.mobile-top{border-bottom:1px solid var(--divider);background:var(--surface);z-index:10;align-items:center;gap:8px;padding:10px 12px;display:none;position:sticky;top:0}.mobile-top .title{letter-spacing:-.3px;text-align:center;flex:1;font-size:17px;font-weight:700}.icon-btn-plain{cursor:pointer;color:var(--text-pri);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:6px;display:flex}.screen-head{align-items:flex-start;gap:16px;padding:26px 32px 0;display:flex}.screen-title{letter-spacing:-.5px;margin:0;font-size:26px;font-weight:700}.screen-sub{color:var(--text-sec);margin-top:3px;font-size:13px;font-weight:500}.progress-track{background:var(--progress-track);border-radius:100px;max-width:420px;height:4px;margin-top:12px;overflow:hidden}.progress-fill{background:var(--success);border-radius:100px;height:100%;transition:width .25s}.head-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.btn-accent{background:var(--mic-gradient);color:#fff;cursor:pointer;letter-spacing:-.1px;border:none;border-radius:12px;align-items:center;gap:8px;padding:10px 16px;font-size:14px;font-weight:600;display:flex;box-shadow:0 4px 12px #f9731659}.btn-outline{background:var(--surface);color:var(--text-pri);border:1px solid var(--divider);cursor:pointer;border-radius:12px;align-items:center;gap:8px;padding:10px 14px;font-size:14px;font-weight:500;display:flex}.btn-primary{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:12px 16px;font-size:14px;font-weight:600;display:flex;box-shadow:0 4px 12px #1a73e84d}.btn-primary:hover{background:var(--primary-hov)}.btn-square{background:var(--surface);border:1px solid var(--divider);cursor:pointer;width:38px;height:38px;color:var(--text-pri);border-radius:12px;justify-content:center;align-items:center;display:flex}button:disabled{opacity:.55;cursor:default}.cat-columns{align-items:flex-start;gap:16px;padding:22px 32px 32px;display:flex}.cat-col{flex:1;min-width:0}.cat-card{background:var(--surface);border:1px solid var(--divider);border-radius:14px;margin-bottom:14px;overflow:hidden}.cat-head{align-items:center;gap:10px;padding:10px 16px;display:flex}.cat-emoji{font-size:15px}.cat-label{letter-spacing:.2px;text-transform:uppercase;flex:1;font-size:12px;font-weight:700}.count-pill{letter-spacing:.2px;background:var(--count-pill-bg);font-variant-numeric:tabular-nums;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:700}.item-row{border-top:.5px solid var(--divider-soft);align-items:center;gap:12px;padding:10px 16px;display:flex}.item-row:first-of-type{border-top:none}.checkbox{border:1.8px solid var(--divider);cursor:pointer;background:0 0;border-radius:11px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;padding:0;transition:background .12s ease-out,border-color .12s ease-out;display:flex}.checkbox.checked{background:var(--success);border-color:var(--success)}.item-name{letter-spacing:-.1px;text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:15px;font-weight:500;overflow:hidden}.item-row.checked .item-name{color:var(--text-checked);text-decoration:line-through}.qty-badge{color:var(--text-sec);background:var(--surface2);border-radius:6px;flex-shrink:0;padding:3px 8px;font-size:12px;font-weight:500}.item-row.checked .qty-badge{color:var(--text-checked);background:0 0;text-decoration:line-through}.item-delete{color:var(--text-ter);cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;padding:3px 5px;display:none}.item-row:hover .item-delete{display:block}.item-delete:hover{color:var(--error);background:var(--surface2)}.empty-state{text-align:center;padding:80px 24px}.empty-state h2{letter-spacing:-.4px;margin:0 0 6px;font-size:22px;font-weight:700}.empty-state p{color:var(--text-sec);margin:0;font-size:14px}.overlay{z-index:40;-webkit-backdrop-filter:blur(2px);background:#0f0e0d73;position:fixed;inset:0}.modal{z-index:41;background:var(--surface);border-radius:20px;width:460px;max-width:calc(100vw - 32px);padding:22px 26px 28px;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 24px 60px #00000059,0 4px 12px #00000026}.sheet{z-index:41;background:var(--surface);padding-bottom:max(20px, env(safe-area-inset-bottom));border-radius:20px 20px 0 0;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -10px 40px #14142826}.drag-handle{justify-content:center;padding:8px 0 4px;display:flex}.drag-handle:after{content:"";background:var(--divider);border-radius:3px;width:36px;height:5px}.close-circle{background:var(--surface2);cursor:pointer;width:30px;height:30px;color:var(--text-sec);border:none;border-radius:15px;justify-content:center;align-items:center;display:flex}.voice-top{justify-content:space-between;align-items:center;display:flex}.voice-timer{font-family:var(--mono);color:var(--text-sec);letter-spacing:.5px;font-size:13px}.voice-title{letter-spacing:-.4px;text-align:center;margin-top:14px;font-size:22px;font-weight:700}.live-dot{background:var(--accent);vertical-align:middle;border-radius:4px;width:8px;height:8px;margin-right:10px;animation:1.6s ease-in-out infinite pulse-dot;display:inline-block;box-shadow:0 0 0 4px #f9731638}@keyframes pulse-dot{0%,to{box-shadow:0 0 0 4px #f9731638}50%{box-shadow:0 0 0 7px #f973161a}}.voice-sub{color:var(--text-sec);text-align:center;margin-top:4px;font-size:13px}.waveform-wrap{justify-content:center;align-items:center;height:80px;margin:10px 0 4px;padding:0 24px;display:flex}.voice-controls{justify-content:center;align-items:center;gap:16px;margin-top:6px;display:flex}.voice-cancel,.voice-accept{cursor:pointer;border:none;border-radius:22px;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.voice-cancel{background:var(--surface2);color:var(--text-sec)}.voice-accept{background:var(--success);color:#fff}.voice-stop{background:var(--mic-gradient);border:4px solid var(--surface);cursor:pointer;border-radius:34px;justify-content:center;align-items:center;width:68px;height:68px;display:flex;box-shadow:0 0 0 8px #f973162e,0 8px 20px #f9731666}.voice-hint{color:var(--text-ter);text-align:center;margin-top:14px;font-size:11px}.kbd{font-family:var(--mono);background:var(--surface2);border-radius:4px;padding:2px 6px;font-size:10px}.spinner{border:3px solid #f9731626;border-top-color:var(--accent);border-radius:50%;width:68px;height:68px;margin:18px auto 6px;animation:.9s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.tips{min-height:20px;color:var(--text-sec);text-align:center;font-size:13px}.qa-head{justify-content:space-between;align-items:center;padding:8px 20px 4px;display:flex}.qa-title{color:var(--text-sec);letter-spacing:-.1px;font-size:15px;font-weight:600}.qa-done{color:var(--primary);cursor:pointer;background:0 0;border:none;font-size:15px;font-weight:600}.qa-field-wrap{padding:14px 20px 4px}.qa-field{background:var(--surface2);border:1.5px solid #1a73e866;border-radius:14px;align-items:center;gap:10px;padding:12px 16px;display:flex}.qa-field input{letter-spacing:-.2px;background:0 0;border:none;outline:none;flex:1;min-width:0;font-size:19px;font-weight:500}.qa-hint{color:var(--text-ter);letter-spacing:-.05px;padding:6px 24px 10px;font-size:11px}.qa-hint code{font-family:var(--mono);color:var(--text-sec)}.suggest-strip{border-top:.5px solid var(--divider);background:var(--surface2);scrollbar-width:none;align-items:center;gap:8px;padding:8px 12px;display:flex;overflow-x:auto}.suggest-strip::-webkit-scrollbar{display:none}.suggest-pill{background:var(--surface);border:1px solid var(--divider);color:var(--text-pri);cursor:pointer;letter-spacing:-.1px;border-radius:100px;flex-shrink:0;padding:7px 14px;font-size:14px;font-weight:500}.fab-dock{bottom:max(18px, env(safe-area-inset-bottom));z-index:30;background:color-mix(in srgb, var(--surface) 65%, transparent);-webkit-backdrop-filter:blur(16px);border:.5px solid #ffffff80;border-radius:36px;align-items:center;gap:6px;padding:6px;display:none;position:fixed;left:50%;transform:translate(-50%);box-shadow:0 8px 24px #0000002e,0 2px 6px #00000014}.fab-mic{background:var(--mic-gradient);cursor:pointer;border:none;border-radius:30px;justify-content:center;align-items:center;width:60px;height:60px;display:flex;box-shadow:0 6px 14px #f973166b}.fab-plus{cursor:pointer;width:44px;height:60px;color:var(--text-pri);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.menu{z-index:45;background:var(--surface);border:1px solid var(--divider);border-radius:12px;min-width:180px;margin-top:6px;padding:5px;position:absolute;box-shadow:0 12px 32px #00000024}.menu-item{cursor:pointer;text-align:left;width:100%;color:var(--text-pri);background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;padding:9px 12px;font-size:14px;font-weight:500;display:flex}.menu-item:hover{background:var(--surface2)}.menu-item.danger{color:var(--error)}.dialog-title{letter-spacing:-.3px;margin:0 0 6px;font-size:18px;font-weight:700}.dialog-sub{color:var(--text-sec);margin:0 0 14px;font-size:13px}.text-input{background:var(--surface2);border:1.5px solid var(--divider);border-radius:12px;outline:none;width:100%;padding:11px 14px;font-size:15px}.text-input:focus{border-color:#1a73e866}.dialog-actions{justify-content:flex-end;gap:8px;margin-top:16px;display:flex}.notice-banner{color:var(--warning);background:#d977061a;border:1px solid #d9770640;border-radius:10px;margin:0 32px 12px;padding:9px 14px;font-size:13px;font-weight:500}.recipe-grid{grid-template-columns:repeat(3,1fr);align-content:start;gap:16px;padding:22px 32px 32px;display:grid}.recipe-card{background:var(--surface);border:1px solid var(--divider);cursor:pointer;text-align:left;border-radius:16px;padding:0;overflow:hidden}.recipe-cover{justify-content:center;align-items:center;height:120px;font-size:44px;display:flex}.recipe-body{padding:12px 14px 14px}.recipe-title{letter-spacing:-.2px;text-overflow:ellipsis;white-space:nowrap;font-size:15px;font-weight:600;overflow:hidden}.recipe-meta{color:var(--text-sec);justify-content:space-between;align-items:center;margin-top:5px;font-size:12px;display:flex}.recipe-add{cursor:pointer;width:26px;height:26px;color:var(--primary);background:#1a73e81a;border:none;border-radius:13px;justify-content:center;align-items:center;display:flex}.import-bar{gap:8px;max-width:640px;margin:16px 32px 0;display:flex}.import-field{background:var(--surface);border:1px solid var(--divider);border-radius:12px;flex:1;align-items:center;gap:10px;padding:10px 14px;display:flex}.import-field input{background:0 0;border:none;outline:none;flex:1;min-width:0;font-size:14px}.import-field input::placeholder{color:var(--text-ter)}.import-camera{border:1px solid var(--divider);background:var(--surface);cursor:pointer;width:40px;height:40px;color:var(--primary);border-radius:12px;justify-content:center;align-items:center;display:flex}.breadcrumb{color:var(--text-sec);align-items:center;gap:6px;margin-bottom:16px;font-size:13px;font-weight:500;display:flex}.breadcrumb button{color:var(--text-sec);cursor:pointer;background:0 0;border:none;padding:0;font-size:13px;font-weight:500}.breadcrumb .current{color:var(--text-pri);font-weight:600}.meta-label{color:var(--text-sec);letter-spacing:.6px;text-transform:uppercase;font-size:10px;font-weight:700}.meta-value{margin-top:2px;font-size:15px;font-weight:700}.ing-card{background:var(--surface);border:1px solid var(--divider);border-radius:14px;margin-bottom:14px;padding:4px 16px}.ing-head{border-bottom:.5px solid var(--divider-soft);justify-content:space-between;padding:12px 0 8px;font-size:13px;font-weight:700;display:flex}.ing-row{border-top:.5px solid var(--divider-soft);align-items:center;gap:12px;padding:10px 0;display:flex}.ing-row:first-of-type{border-top:none}.ing-check{background:var(--primary);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.ing-name{flex:1;font-size:14px;font-weight:500}.ing-qty{color:var(--text-sec);font-size:12px;font-weight:500}.settings-wrap{max-width:560px;padding:26px 32px}.settings-section{color:var(--text-sec);letter-spacing:.6px;text-transform:uppercase;padding:22px 4px 8px;font-size:11px;font-weight:700}.segmented{background:var(--surface2);border:1px solid var(--divider);border-radius:11px;gap:3px;max-width:320px;padding:3px;display:flex}.segmented button{color:var(--text-sec);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;padding:7px 10px;font-size:13px;font-weight:500}.segmented button.active{background:var(--surface);color:var(--text-pri);font-weight:600;box-shadow:0 1px 2px #00000014}.settings-card{background:var(--surface);border:1px solid var(--divider);border-radius:14px;overflow:hidden}.settings-row{cursor:pointer;width:100%;color:var(--text-pri);text-align:left;background:0 0;border:none;align-items:center;gap:12px;padding:13px 14px;font-size:14px;font-weight:500;display:flex}.settings-row+.settings-row{border-top:.5px solid var(--divider-soft)}.settings-row.danger{color:var(--error)}.settings-icon{width:30px;height:30px;color:var(--primary);background:#1a73e824;border-radius:8px;justify-content:center;align-items:center;display:flex}.center-screen{place-items:center;min-height:100dvh;padding:24px;display:grid}.auth-card{background:var(--surface);border:1px solid var(--divider);border-radius:20px;flex-direction:column;gap:12px;width:100%;max-width:360px;padding:30px 28px;display:flex;box-shadow:0 4px 24px #0000000f}.auth-logo{justify-content:center;align-items:center;gap:10px;margin-bottom:8px;display:flex}.auth-logo .logo-mark{border-radius:10px;width:36px;height:36px}.auth-logo .logo-name{font-size:20px}.auth-card input{background:var(--surface2);border:1.5px solid var(--divider);border-radius:10px;outline:none;width:100%;margin-bottom:8px;padding:11px 12px;font-size:15px}.auth-card input:focus{border-color:#1a73e866}.auth-divider{text-align:center;color:var(--text-ter);margin:4px 0;font-size:13px}.link-btn{color:var(--primary);cursor:pointer;background:0 0;border:none;padding:4px;font-size:14px}.error-text{color:var(--error);margin:4px 0 0;font-size:14px}.muted{color:var(--text-sec)}.small{font-size:13px}@media (width<=1099px){.cat-columns{flex-direction:column;gap:0}.recipe-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=899px){.sidebar{display:none}.mobile-top,.fab-dock{display:flex}.screen-head{flex-direction:column;padding:18px 16px 0}.head-actions{display:none}.head-actions.mobile-keep{display:flex}.cat-columns{padding:16px 16px 120px}.recipe-grid{grid-template-columns:1fr;padding:16px}.import-bar{margin:16px 16px 0}.settings-wrap{padding:18px 16px}.notice-banner{margin:0 16px 12px}.modal.sheet-on-mobile{width:100%;max-width:100%;padding-bottom:max(28px, env(safe-area-inset-bottom));border-radius:20px 20px 0 0;top:auto;bottom:0;left:0;transform:none}}
