:root{--bg:#f7f6f3;--panel:#fff;--text:#2b2a33;--text-muted:#6b6878;--border:#e6e4ea;--accent:#2f7a55;--accent-soft:#2f7a551a;--danger:#b14a4a;--md-primary:#2f7a55;--md-on-primary:#fff;--md-primary-container:#b3f1c8;--md-on-primary-container:#002112;--md-secondary-container:#d3e8d6;--md-on-secondary-container:#0d1f12;--md-surface:#f6fbf3;--md-on-surface:#181d18;--md-surface-container-low:#f0f5ee;--md-surface-container:#eaefe8;--md-surface-container-high:#e4eae2;--md-on-surface-variant:#424942;--md-outline:#717971;--md-outline-variant:#c0c8be;--md-error:#ba1a1a;--md-on-error:#fff;--md-error-container:#ffdad6;--md-on-error-container:#410002;--md-shape-xs:4px;--md-shape-sm:8px;--md-shape-md:12px;--md-shape-lg:16px;--md-shape-xl:28px;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font:16px/1.5 system-ui,-apple-system,Segoe UI,Roboto,sans-serif}@media (prefers-color-scheme:dark){:root{--bg:#14141a;--panel:#1d1d25;--text:#e6e4ea;--text-muted:#9b98a8;--border:#2c2c36;--accent:#4cc18a;--accent-soft:#4cc18a26;--danger:#e07878;--md-primary:#98d6ae;--md-on-primary:#003822;--md-primary-container:#1f5132;--md-on-primary-container:#b3f1c8;--md-secondary-container:#384b3c;--md-on-secondary-container:#d3e8d6;--md-surface:#101510;--md-on-surface:#dfe4dd;--md-surface-container-low:#181d18;--md-surface-container:#1c211c;--md-surface-container-high:#272b27;--md-on-surface-variant:#c0c8be;--md-outline:#8b938b;--md-outline-variant:#424942;--md-error:#ffb4ab;--md-on-error:#690005;--md-error-container:#93000a;--md-on-error-container:#ffdad6}}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);margin:0}#root{min-height:100vh}h1,h2,h3{color:var(--text);margin:0;font-weight:600}p{margin:0}button{font:inherit;cursor:pointer}input,textarea,select{font:inherit;color:inherit;background:var(--bg);border:1px solid var(--border);border-radius:6px;width:100%;padding:8px 10px}input:focus,textarea:focus,select:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:#0000}textarea{resize:vertical;font-family:inherit}.asteroid-wrap{flex-direction:column;gap:12px;max-width:820px;margin:0 auto;padding:24px 20px 40px;display:flex}.asteroid-header{justify-content:space-between;align-items:center;display:flex}.asteroid-canvas{border:1px solid var(--border);border-radius:8px;width:100%;display:block}.asteroid-controls{text-align:center}.touch-controls{-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:10px 4px;display:flex}.touch-left{gap:10px;display:flex}.touch-btn{border:1px solid var(--border);width:68px;height:68px;color:var(--text);cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;background:#8080801f;border-radius:14px;justify-content:center;align-items:center;font-size:22px;display:flex}.touch-btn:active{border-color:var(--text-muted);background:#8080804d}.touch-thrust{font-size:20px}.touch-fire{color:#ff7850e6;background:#ff50321f;border-color:#ff503259;width:84px;height:84px;font-size:32px}.landing{flex-direction:column;max-width:1180px;min-height:100vh;margin:0 auto;padding:0 32px;display:flex}.landing-top{justify-content:space-between;align-items:center;padding:40px 0 0;display:flex}.landing-brand{align-items:center;gap:10px;display:flex}.landing-mark{color:var(--text);font-size:22px;line-height:1}.landing-name{letter-spacing:.06em;text-transform:uppercase;color:var(--text);font-size:15px;font-weight:600}.landing-user{align-items:center;gap:12px;display:flex}.landing-hero{object-fit:cover;object-position:center 40%;width:100%;height:44vh;margin-top:28px;display:block}.landing-main{flex:1;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);gap:64px;padding:40px 0;display:grid}.landing-left,.landing-right{flex-direction:column;justify-content:center;display:flex}.landing-banner{border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:32px;padding:14px 0;overflow:hidden}.landing-banner-track{white-space:nowrap;color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase;padding-left:100%;font-size:13px;animation:16s linear infinite landing-marquee;display:inline-block}.landing-banner-track>*{vertical-align:middle}.landing-banner-track .pac{background:conic-gradient(from 290deg,#fc0 0deg 320deg,#0000 320deg 360deg);border-radius:50%;width:20px;height:20px;margin-left:14px;display:inline-block}.landing-banner-track .ghost-svg{margin-left:8px}@keyframes landing-marquee{0%{transform:translate(0)}to{transform:translate(-100%)}}@media (prefers-reduced-motion:reduce){.landing-banner-track{animation:none}}.landing-list{flex-direction:column;display:flex}.landing-row{border-top:1px solid var(--border);grid-template-columns:32px 1fr auto;align-items:center;gap:20px;padding:20px 0;display:grid}.landing-row:last-child{border-bottom:1px solid var(--border)}.landing-index{color:var(--text-muted);font-variant-numeric:tabular-nums;padding-top:2px;font-size:12px}.landing-info{flex-direction:column;gap:3px;display:flex}.landing-feature-name{color:var(--text);letter-spacing:-.01em;font-size:17px;font-weight:500}.landing-feature-desc{color:var(--text-muted);font-size:13px}.landing-open{border:1px solid var(--text);color:var(--text);letter-spacing:.04em;text-transform:uppercase;background:0 0;border-radius:0;padding:6px 16px;font-size:13px;font-weight:500;transition:background .15s,color .15s}.landing-open:hover{background:var(--text);color:var(--bg)}.landing-soon{color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;font-size:11px}.landing-footer{color:var(--text-muted);border-top:1px solid var(--border);padding:32px 0;font-size:12px}@media (width<=900px){.landing-main{grid-template-columns:1fr;gap:32px}}@media (width<=520px){.landing{padding:0 20px}.landing-row{grid-template-columns:24px 1fr auto;gap:12px}}.app{max-width:1100px;margin:0 auto;padding:24px 20px 64px}.app-header{flex-direction:column;gap:16px;margin-bottom:24px;display:flex}.signin-screen{justify-content:center;align-items:center;min-height:100vh;display:flex}.signin-card{background:var(--panel);border:1px solid var(--border);text-align:center;border-radius:16px;flex-direction:column;align-items:center;gap:16px;width:100%;max-width:360px;padding:48px 40px;display:flex}.signin-card h1{font-size:24px}.google-signin-btn{color:#3c4043;cursor:pointer;background:#fff;border:1px solid #dadce0;border-radius:8px;align-items:center;gap:10px;margin-top:8px;padding:10px 20px;font-size:15px;font-weight:500;display:flex}.google-signin-btn:hover{background:#f8f9fa;box-shadow:0 1px 3px #0000001f}.user-menu{align-self:flex-end;align-items:center;gap:10px;display:flex}.user-avatar{object-fit:cover;border-radius:50%;width:28px;height:28px}.brand{align-items:center;gap:14px;display:flex}.brand-mark{color:var(--accent);font-size:36px;line-height:1}.brand h1{letter-spacing:-.2px;font-size:22px}.tabs{border-bottom:1px solid var(--border);-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;gap:4px;display:flex;overflow:auto hidden}.tabs::-webkit-scrollbar{display:none}.tab{color:var(--text-muted);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;flex:none;margin-bottom:-1px;padding:10px 16px;font-weight:500}.tab:hover{color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.panel{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:20px}.panel-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.panel-header h2{font-size:20px}.header-actions{gap:8px;display:flex}.muted{color:var(--text-muted)}.small{font-size:13px}.empty-state{color:var(--text-muted);text-align:center;padding:32px 8px}.restore-banner{border:1px solid var(--border);border-left:4px solid var(--accent);background:#f4f7ff;border-radius:6px;align-items:center;gap:16px;margin-bottom:12px;padding:12px 16px;font-size:14px;display:flex}.restore-banner-actions{align-items:center;gap:12px;margin-left:auto;display:flex}button.primary{background:var(--accent);color:#fff;border:1px solid var(--accent);border-radius:6px;padding:8px 14px;font-weight:500}button.primary:hover{filter:brightness(1.05)}button.secondary{color:var(--text);border:1px solid var(--border);background:0 0;border-radius:6px;padding:8px 14px}button.secondary:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}button.danger{color:var(--danger);border:1px solid var(--border);background:0 0;border-radius:6px;padding:8px 14px}button.danger:hover{border-color:var(--danger);background:#b14a4a1a}button.link-btn{color:var(--accent);background:0 0;border:none;padding:6px 0;font-weight:500}button.link-btn:hover{text-decoration:underline}button.icon-btn{border:1px solid var(--border);width:32px;height:32px;color:var(--text-muted);background:0 0;border-radius:6px;justify-content:center;align-items:center;font-size:18px;display:inline-flex}button.icon-btn:hover:not(:disabled){color:var(--danger);border-color:var(--danger)}button.icon-btn:disabled{opacity:.4;cursor:not-allowed}.recipe-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;margin:0;padding:0;list-style:none;display:grid}.recipe-card{border:1px solid var(--border);background:var(--bg);border-radius:10px;transition:border-color .15s}.recipe-card:hover{border-color:var(--accent)}.card-button{text-align:left;width:100%;color:inherit;background:0 0;border:none;flex-direction:column;gap:6px;padding:16px;display:flex}.card-button h3{font-size:16px}.meta-row{color:var(--text-muted);flex-wrap:wrap;gap:12px;font-size:14px;display:flex}.meta-row.small{font-size:13px}.meta-row a{color:var(--accent)}.recipe-detail h2{margin-bottom:8px;font-size:24px}.recipe-detail h3{margin:20px 0 8px;font-size:16px}.ingredient-list{margin:0;padding:0;list-style:none}.ingredient-list li{border-bottom:1px solid var(--border);grid-template-columns:100px 1fr;gap:12px;padding:6px 0;display:grid}.qty-cell{color:var(--text-muted);font-variant-numeric:tabular-nums}.instructions{background:var(--bg);border:1px solid var(--border);white-space:pre-wrap;border-radius:8px;margin:0;padding:12px 14px;font-family:inherit;font-size:14px;line-height:1.6}.recipe-form{flex-direction:column;gap:16px;display:flex}.form-row label{color:var(--text-muted);flex-direction:column;gap:6px;font-size:14px;font-weight:500;display:flex}.form-row.two-col{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-row.three-col{grid-template-columns:1fr 1fr 1fr;gap:12px;display:grid}@media (width<=600px){.form-row.three-col{grid-template-columns:1fr}}.field-label{color:var(--text-muted);margin-bottom:6px;font-size:14px;font-weight:500;display:block}.meal-type-toggles{flex-wrap:wrap;gap:6px;display:flex}.meal-type-toggles.compact .type-toggle{padding:3px 8px;font-size:11px}.type-toggle{border:1px solid var(--border);color:var(--text-muted);text-transform:capitalize;background:0 0;border-radius:999px;padding:5px 12px;font-size:12px;font-weight:500}.type-toggle:hover:not(.on){color:var(--text);border-color:var(--accent)}.type-toggle.on{background:var(--accent-soft);color:var(--accent);border-color:var(--accent)}.meal-type-badge{text-transform:capitalize;background:var(--accent-soft);color:var(--accent);border:1px solid var(--accent);border-radius:999px;align-items:center;padding:2px 10px;font-size:12px;font-weight:600;display:inline-flex}.meal-type-badge.mt-breakfast,.type-toggle.on.mt-breakfast{color:#b86b00;background:#ffb03c1f;border-color:#b86b0073}.meal-type-badge.mt-lunch,.type-toggle.on.mt-lunch{color:#1f6fbf;background:#3c91e61f;border-color:#1f6fbf73}.meal-type-badge.mt-dinner,.type-toggle.on.mt-dinner{color:#2f7a55;background:#2f7a551f;border-color:#2f7a5573}.meal-type-badge.mt-dessert,.type-toggle.on.mt-dessert{color:#a8377f;background:#c850a01f;border-color:#a8377f73}.meal-type-badge.mt-appetizer,.type-toggle.on.mt-appetizer{color:#6e4eb0;background:#966ec81f;border-color:#6e4eb073}@media (prefers-color-scheme:dark){.meal-type-badge.mt-breakfast,.type-toggle.on.mt-breakfast{color:#ffc266}.meal-type-badge.mt-lunch,.type-toggle.on.mt-lunch{color:#6cb1f0}.meal-type-badge.mt-dinner,.type-toggle.on.mt-dinner{color:#6dd6a3}.meal-type-badge.mt-dessert,.type-toggle.on.mt-dessert{color:#e69cc8}.meal-type-badge.mt-appetizer,.type-toggle.on.mt-appetizer{color:#b59eea}}.ingredients{border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:8px;padding:14px;display:flex}.ingredients legend{color:var(--text-muted);padding:0 6px;font-size:14px;font-weight:500}.ingredient-row{grid-template-columns:80px 100px 1fr 32px;align-items:center;gap:8px;display:grid}.ingredient-row .qty{text-align:right}.form-actions{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding-top:8px;display:flex}.bulk-table-wrap{border:1px solid var(--border);border-radius:8px;overflow-x:auto}.bulk-table{border-collapse:collapse;width:100%;font-size:13px}.bulk-table th,.bulk-table td{border-bottom:1px solid var(--border);vertical-align:top;text-align:left;padding:8px}.bulk-table thead th{text-transform:uppercase;letter-spacing:.4px;color:var(--text-muted);background:var(--bg);font-size:12px;font-weight:600;position:sticky;top:0}.bulk-table tbody tr:last-child td{border-bottom:none}.th-hint{text-transform:none;letter-spacing:normal;color:var(--text-muted);margin-top:2px;font-size:11px;font-weight:400}.bulk-table input,.bulk-table textarea{width:100%;padding:6px 8px;font-size:13px}.bulk-table th:first-child,.bulk-table td:first-child{width:auto}.bulk-table th:nth-child(2),.bulk-table td:nth-child(2){width:40px}.bulk-hint{margin-bottom:12px}.bulk-edit-table th:first-child,.bulk-edit-table td:first-child{min-width:150px}.bulk-edit-table th:nth-child(2),.bulk-edit-table td:nth-child(2){width:auto;min-width:190px}.bulk-edit-table th:nth-child(3),.bulk-edit-table td:nth-child(3){width:70px;min-width:70px}.bulk-edit-table th:nth-child(4),.bulk-edit-table td:nth-child(4){min-width:90px}.bulk-edit-table th:nth-child(5),.bulk-edit-table td:nth-child(5){min-width:160px}.bulk-edit-table th:nth-child(6),.bulk-edit-table td:nth-child(6),.bulk-edit-table th:nth-child(7),.bulk-edit-table td:nth-child(7){min-width:180px}.bulk-edit-table th:nth-child(8),.bulk-edit-table td:nth-child(8){min-width:200px}.servings-input{width:60px}.bulk-table-actions{margin:12px 0 16px}.week-nav{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.week-nav h2{min-width:180px;font-size:18px}.view-toggle{border:1px solid var(--border);border-radius:8px;display:inline-flex;overflow:hidden}.view-toggle .toggle{color:var(--text-muted);border:none;border-right:1px solid var(--border);background:0 0;padding:8px 14px;font-weight:500}.view-toggle .toggle:last-child{border-right:none}.view-toggle .toggle:hover:not(.active){color:var(--text);background:var(--accent-soft)}.view-toggle .toggle.active{background:var(--accent);color:#fff}.week-tabs{z-index:5;scrollbar-width:none;background:var(--panel);flex-wrap:nowrap;gap:6px;margin:-8px 0 12px;padding:8px 0;display:flex;position:sticky;top:0;overflow-x:auto}.week-tabs::-webkit-scrollbar{display:none}.week-tabs .week-tab{flex:none}.week-tab{border:1px solid var(--border);color:var(--text-muted);background:0 0;border-radius:999px;padding:6px 14px;font-size:13px;font-weight:500}.week-tab:hover:not(.active){color:var(--text);border-color:var(--accent)}.week-tab.active{background:var(--accent-soft);color:var(--accent);border-color:var(--accent)}.weeks-stack{flex-direction:column;gap:20px;display:flex}.week-block-label{text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);margin-bottom:8px;padding-left:4px;font-size:13px;font-weight:600}.meal-grid{background:var(--border);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:1px;display:flex;overflow:hidden}.meal-grid-header,.meal-grid-row{background:var(--border);grid-template-columns:140px repeat(3,1fr);gap:1px;display:grid}.slot-header{background:var(--panel);text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);padding:10px 12px;font-size:13px;font-weight:600}.day-label{background:var(--panel);padding:12px;font-size:14px;font-weight:500}.meal-cell{background:var(--panel);flex-direction:column;gap:4px;padding:10px;display:flex}.meal-cell select{padding:6px 8px;font-size:13px}.meal-meta{color:var(--text-muted);font-size:12px}.meta-toggle{color:var(--text-muted);text-align:left;background:0 0;border:none;align-items:center;gap:4px;width:100%;padding:2px 0;font-size:12px;display:flex}.meta-summary{white-space:nowrap;flex:0 auto;min-width:0;max-width:160px;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,#000 70%,#0000);mask-image:linear-gradient(90deg,#000 70%,#0000)}.meta-toggle:hover,.meal-meta.open .meta-toggle{color:var(--accent)}.meta-toggle .chevron{font-size:10px;line-height:1}.meta-ingredients{flex-direction:column;gap:2px;max-height:180px;margin:0;padding:4px 0 0;list-style:none;display:flex;overflow-y:auto}.meta-ingredients li{grid-template-columns:56px 1fr;gap:6px;font-size:12px;line-height:1.35;display:grid}.meta-ingredients .qty-cell{text-align:right;font-size:12px}.planner-actions{justify-content:flex-end;gap:8px;margin-top:16px;display:flex}.cell-slot-label{display:none}@media (width<=720px){.meal-grid-header,.meal-grid-row{grid-template-columns:100px repeat(3,1fr)}.ingredient-row{grid-template-columns:60px 80px 1fr 32px}}@media (width<=560px){.app{padding:16px 12px 48px}.panel{padding:14px}.meal-grid-header{display:none}.meal-grid-row{flex-direction:column;gap:1px;display:flex}.day-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);background:var(--accent-soft);padding:10px 14px;font-size:13px;font-weight:600}.meal-cell{gap:8px;padding:12px 14px}.cell-slot-label{text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);font-size:11px;font-weight:600;display:block}.meal-cell select{width:100%;min-height:44px;padding:10px 12px;font-size:16px}.meta-summary{white-space:normal;max-width:none;-webkit-mask-image:none;mask-image:none}.meta-toggle{min-height:32px;padding:6px 0}.panel-header{margin-bottom:14px}.planner-actions{flex-direction:column-reverse}.planner-actions button{width:100%;min-height:44px}}.shopping-list{margin:0;padding:0;list-style:none}.shopping-list li{border-bottom:1px solid var(--border)}.shopping-list label{cursor:pointer;grid-template-columns:24px 100px 1fr auto;align-items:center;gap:12px;padding:10px 4px;display:grid}.shopping-list input[type=checkbox]{cursor:pointer;width:18px;height:18px}.shopping-list .item-name{font-weight:500}.shopping-list li.checked .item-name,.shopping-list li.checked .qty-cell{opacity:.55;text-decoration:line-through}.robotina-wrap{flex-direction:column;gap:18px;max-width:720px;margin:0 auto;padding:24px 20px 40px;display:flex}.robotina-header{grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;display:grid}.robotina-header h2{text-align:center;font-size:20px}.robotina-error{border:1px solid var(--danger);color:var(--danger);background:#b14a4a1f;border-radius:8px;padding:10px 12px;font-size:14px}.robotina-device{background:var(--panel);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:4px;padding:14px 16px;display:flex}.robotina-device-name{letter-spacing:.5px;font-size:22px}.robotina-status{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.robotina-stat{background:var(--panel);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:4px;min-width:0;padding:12px 14px;display:flex}.robotina-stat strong{text-overflow:ellipsis;white-space:nowrap;font-size:18px;overflow:hidden}.robotina-actions{flex-wrap:wrap;gap:10px;display:flex}.robotina-actions button{border-radius:8px;flex:120px;padding:10px 14px}@media (width<=560px){.robotina-status{grid-template-columns:repeat(2,minmax(0,1fr))}}.robotina-collapse{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:10px 14px}.robotina-collapse summary{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;font-weight:600;list-style:none;display:flex}.robotina-collapse summary:before{content:"▸";transition:transform .15s;display:inline-block}.robotina-collapse[open] summary:before{transform:rotate(90deg)}.robotina-list{flex-direction:column;gap:8px;margin:10px 0 0;padding:0;list-style:none;display:flex}.robotina-list li{border-bottom:1px solid var(--border);grid-template-columns:1fr auto auto;align-items:baseline;gap:12px;padding:6px 0;display:grid}.robotina-list li:last-child{border-bottom:none}.robotina-map-wrap{border-radius:8px;margin-top:10px;position:relative;overflow:hidden}.robotina-map{background:radial-gradient(#0000 0%,#0000002e 100%),repeating-linear-gradient(0deg,#0000 0 23px,#ffffff29 23px 24px),repeating-linear-gradient(90deg,#0000 0 23px,#ffffff29 23px 24px),linear-gradient(#4a86c8 0%,#2f63a0 100%);border:1px solid #1f4a82;border-radius:8px;justify-content:center;padding:8px;display:flex;box-shadow:inset 0 0 18px #0003}.jetsons-car{top:var(--top,30%);opacity:0;pointer-events:none;filter:drop-shadow(0 4px 4px #00000059);width:18%;min-width:120px;max-width:220px;transform:translate3d(var(--from-x), 0, 0) scale(var(--scale-x), var(--scale-y)) rotate(var(--tilt));animation:jetsons-fly var(--duration,5s) cubic-bezier(.4, .1, .6, .9) forwards;will-change:transform, opacity;position:absolute;left:0}@keyframes jetsons-fly{0%{opacity:0;transform:translate3d(var(--from-x), 0, 0) scale(var(--scale-x), var(--scale-y)) rotate(var(--tilt))}18%{opacity:1}50%{transform:translate3d(calc((var(--from-x) + var(--to-x)) / 2), -8px, 0) scale(var(--scale-x), var(--scale-y)) rotate(var(--tilt))}82%{opacity:1}to{opacity:0;transform:translate3d(var(--to-x), 0, 0) scale(var(--scale-x), var(--scale-y)) rotate(var(--tilt))}}@media (prefers-reduced-motion:reduce){.jetsons-car{display:none}}.robotina-map svg{width:100%;height:auto;max-height:60vh}.robotina-map-controls{align-items:center;gap:8px;margin-top:8px;display:flex}.map-indicator{border-radius:50%;flex-shrink:0;width:10px;height:10px;display:inline-block;box-shadow:0 0 0 1px #00000026}.map-indicator--live{background:#2bb673;box-shadow:0 0 0 1px #00000026,0 0 6px #2bb67380}.map-indicator--cached{background:#d9444f;box-shadow:0 0 0 1px #00000026}.map-indicator--loading{background:#e6a52c;animation:1.1s ease-in-out infinite map-indicator-pulse;box-shadow:0 0 0 1px #00000026}@keyframes map-indicator-pulse{0%,to{opacity:1}50%{opacity:.35}}.robotina-map-controls .link-btn{margin-left:auto}.robotina-room-chips{flex-wrap:wrap;gap:8px;margin:8px 0;display:flex}.room-chip{border:2px solid var(--border);color:#1a1a1a;cursor:pointer;background:#fff;border-radius:999px;min-width:44px;padding:6px 14px;font-size:14px;font-weight:600;transition:transform 60ms,background-color 80ms}.room-chip:hover{transform:translateY(-1px)}.room-chip--selected{color:#fff;box-shadow:0 1px 2px #00000026}.robotina-room-actions{align-items:center;gap:12px;margin-top:6px;display:flex}.account-section{margin:24px 0}.account-section h2{margin:0 0 12px;font-size:1.1rem}.account-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.account-row{border:1px solid var(--border,#e5e7eb);background:var(--surface,#fff);border-radius:8px;align-items:center;gap:12px;padding:10px 12px;display:flex}.notif-row{border:1px solid var(--border,#e5e7eb);background:var(--surface,#fff);border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;display:flex}.notif-row>div:first-child,.account-info{flex:auto;min-width:0}.account-actions{flex-shrink:0;gap:8px;display:flex}.extract-row{align-items:stretch;gap:8px;display:flex}.extract-row input{flex:auto;min-width:0}.extract-row button{white-space:nowrap;flex-shrink:0}.account-subhead{margin:8px 0;font-size:.95rem;font-weight:600}.metrics-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.metrics-list li{align-items:baseline;gap:12px;display:flex}.metrics-label{flex:auto}.metrics-value{font-variant-numeric:tabular-nums;text-align:right;min-width:3em;font-weight:600}.m3{background:var(--md-surface);color:var(--md-on-surface)}.m3.app{max-width:760px;padding:8px 12px 64px}.m3 .app-header{background:var(--md-surface);margin-bottom:8px;padding:4px 4px 8px}.m3 .brand{align-items:center;gap:4px;min-height:64px}.m3 .brand-mark{width:40px;height:40px;color:var(--md-on-surface);border-radius:9999px;justify-content:center;align-items:center;margin-right:8px;font-size:22px;transition:background .12s;display:inline-flex}.m3 .brand-mark:hover,.m3 .brand button:hover .brand-mark{background:#0000000f}.m3 .brand button{background:0 0;border:none;padding:0}.m3 .brand h1{letter-spacing:0;font-size:22px;font-weight:400;line-height:28px}.m3 .brand .muted{color:var(--md-on-surface-variant);margin-top:2px;font-size:14px;line-height:20px}.m3 .account-section{background:var(--md-surface-container-low);border-radius:var(--md-shape-lg);margin:12px 0;padding:16px 8px 8px}.m3 .account-section h2{letter-spacing:.15px;color:var(--md-on-surface);margin:0 0 12px;padding:0 12px;font-size:16px;font-weight:500;line-height:24px}.m3 .account-subhead{letter-spacing:.1px;color:var(--md-on-surface-variant);margin:8px 0;padding:0 12px;font-size:14px;font-weight:500;line-height:20px}.m3 .account-list{gap:4px}.m3 .account-row{background:var(--md-surface-container);border-radius:var(--md-shape-md);border:none;gap:16px;min-height:64px;padding:12px 16px}.m3 .account-row .user-avatar{border:1px solid var(--md-outline-variant);width:40px;height:40px}.m3 .account-info>div:first-child{font-size:16px;font-weight:400;line-height:24px}.m3 .account-info .muted{color:var(--md-on-surface-variant);font-size:14px;line-height:20px}.m3 button.primary{background:var(--md-primary);color:var(--md-on-primary);letter-spacing:.1px;border:none;border-radius:9999px;height:40px;padding:0 24px;font-size:14px;font-weight:500;transition:filter .12s,background .12s}.m3 button.primary:hover:not(:disabled){filter:brightness(.94)}.m3 button.primary:disabled{color:#00000061;background:#0000001f}.m3 button.secondary{color:var(--md-primary);letter-spacing:.1px;background:0 0;border:none;border-radius:9999px;height:40px;padding:0 16px;font-size:14px;font-weight:500}.m3 button.secondary:hover:not(:disabled){background:#2f7a5514}.m3 button.secondary:disabled{color:#00000061}.m3 .settings-link{background:var(--md-surface-container);border-radius:var(--md-shape-md);cursor:pointer;text-align:left;width:100%;color:inherit;border:none;grid-template-columns:40px 1fr 24px;align-items:center;gap:16px;padding:14px 16px;font-family:inherit;transition:background .12s;display:grid}.m3 .settings-link:hover{background:var(--md-surface-container-high)}.m3 .settings-link-icon{color:var(--md-on-surface-variant);font-size:24px}.m3 .settings-link-info>div:first-child{letter-spacing:.15px;font-size:16px;font-weight:500;line-height:24px}.m3 .settings-link-info .muted{color:var(--md-on-surface-variant);font-size:13px;line-height:18px}.m3 .settings-link-go{color:var(--md-on-surface-variant);justify-self:end;font-size:20px}.m3 .notif-row{background:var(--md-surface-container);border-radius:var(--md-shape-md);border:none;gap:16px;padding:16px}.m3 .notif-row>div:first-child>div:first-child{font-size:16px;font-weight:400;line-height:24px}.m3 .notif-row .muted{color:var(--md-on-surface-variant);font-size:14px;line-height:20px}.m3 .metrics-list{background:var(--md-surface-container);border-radius:var(--md-shape-md);margin:0;padding:8px 16px;list-style:none}.m3 .metrics-list li{border-bottom:1px solid var(--md-outline-variant);grid-template-columns:1fr auto auto;align-items:baseline;gap:12px;padding:10px 0;display:grid}.m3 .metrics-list li:last-child{border-bottom:none}.m3 .metrics-label{font-size:14px;line-height:20px}.m3 .metrics-value{font-variant-numeric:tabular-nums;font-size:14px;font-weight:600}.m3 .metrics-list .muted{color:var(--md-on-surface-variant);font-size:12px}@media (prefers-color-scheme:dark){.m3 button.primary:disabled{color:#ffffff61;background:#ffffff1f}.m3 button.secondary:hover:not(:disabled){background:#98d6ae1f}.m3 .brand-mark:hover,.m3 .brand button:hover .brand-mark{background:#ffffff14}}.material-symbols-outlined{font-variation-settings:"FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;-webkit-user-select:none;user-select:none;line-height:1}.landing.m3{--md-primary:#98d6ae;--md-on-primary:#003822;--md-primary-container:#1f5132;--md-on-primary-container:#b3f1c8;--md-secondary-container:#384b3c;--md-on-secondary-container:#d3e8d6;--md-surface:#101510;--md-on-surface:#dfe4dd;--md-surface-container-low:#181d18;--md-surface-container:#1c211c;--md-surface-container-high:#272b27;--md-on-surface-variant:#c0c8be;--md-outline:#8b938b;--md-outline-variant:#424942;background:var(--md-surface);color:var(--md-on-surface)}.landing.m3 .landing-top{padding:24px 0 0}.landing.m3 .landing-brand{align-items:center;gap:12px}.landing.m3 .landing-mark{color:var(--md-primary);font-size:28px}.landing.m3 .landing-name{letter-spacing:.5px;text-transform:uppercase;color:var(--md-on-surface);font-size:14px;font-weight:500}.landing.m3 .landing-user .link-btn{color:var(--md-on-surface-variant);border-radius:9999px;padding:8px 12px;font-size:14px;transition:background .12s}.landing.m3 .landing-user .link-btn:hover{color:var(--md-on-surface);background:#ffffff0f}.landing.m3 .landing-iconbtn{width:40px;height:40px;color:var(--md-on-surface-variant);cursor:pointer;background:0 0;border:none;border-radius:9999px;justify-content:center;align-items:center;transition:background .12s,color .12s;display:inline-flex}.landing.m3 .landing-iconbtn:hover{color:var(--md-on-surface);background:#ffffff0f}.landing.m3 .landing-iconbtn .material-symbols-outlined{font-size:22px}.landing.m3 .landing-hero{border-radius:var(--md-shape-xl);filter:brightness(.92)saturate(.95)}.landing.m3 .landing-main{padding:32px 0}.landing.m3 .landing-list{gap:8px}.landing.m3 .landing-row{background:var(--md-surface-container-low);border-radius:var(--md-shape-lg);cursor:pointer;text-align:left;color:inherit;border:none;grid-template-columns:56px 1fr 40px;align-items:center;gap:16px;width:100%;padding:16px 20px;font-family:inherit;transition:background .14s,transform .14s;display:grid}.landing.m3 .landing-row:hover:not(:disabled){background:var(--md-surface-container)}.landing.m3 .landing-row:active:not(:disabled){background:var(--md-surface-container-high);transform:scale(.995)}.landing.m3 .landing-row:disabled{opacity:.55;cursor:not-allowed}.landing.m3 .landing-icon{background:var(--md-primary-container);width:48px;height:48px;color:var(--md-on-primary-container);border-radius:9999px;justify-content:center;align-items:center;display:inline-flex}.landing.m3 .landing-icon .material-symbols-outlined{font-size:26px}.landing.m3 .landing-info{flex-direction:column;gap:2px;min-width:0;display:flex}.landing.m3 .landing-feature-name{letter-spacing:.15px;color:var(--md-on-surface);font-size:16px;font-weight:500;line-height:24px}.landing.m3 .landing-feature-desc{color:var(--md-on-surface-variant);letter-spacing:.25px;font-size:14px;line-height:20px}.landing.m3 .landing-go{width:40px;height:40px;color:var(--md-on-surface-variant);border-radius:9999px;justify-content:center;align-items:center;display:inline-flex}.landing.m3 .landing-row:hover .landing-go{color:var(--md-primary)}.landing.m3 .landing-go .material-symbols-outlined{font-size:22px}.landing.m3 .landing-banner{border-color:var(--md-outline-variant)}.landing.m3 .landing-banner-track{color:var(--md-on-surface-variant)}.landing.m3 .landing-footer{border-color:var(--md-outline-variant);color:var(--md-on-surface-variant)}@media (width<=520px){.landing.m3 .landing-row{grid-template-columns:48px 1fr 32px;gap:12px;padding:12px 14px}.landing.m3 .landing-icon{width:40px;height:40px}.landing.m3 .landing-icon .material-symbols-outlined{font-size:22px}}.robotina-wrap.m3{background:var(--md-surface);color:var(--md-on-surface);gap:12px;padding:12px 16px 56px}.robotina-wrap.m3 .robotina-header{min-height:56px;margin-bottom:4px}.robotina-wrap.m3 .robotina-header h2{letter-spacing:0;color:var(--md-on-surface);font-size:22px;font-weight:400;line-height:28px}.robotina-wrap.m3 .rb-iconbtn{width:40px;height:40px;color:var(--md-on-surface);cursor:pointer;background:0 0;border:none;border-radius:9999px;justify-content:center;justify-self:start;align-items:center;padding:0;transition:background .12s;display:inline-flex}.robotina-wrap.m3 .rb-iconbtn:hover{background:var(--md-surface-container)}.robotina-wrap.m3 .rb-iconbtn .material-symbols-outlined{font-size:24px}.robotina-wrap.m3 .rb-map-section{flex-direction:column;gap:6px;display:flex}.robotina-wrap.m3 .rb-map-card{background:var(--md-surface-container-low);border-radius:var(--md-shape-lg);padding:6px;overflow:hidden}.robotina-wrap.m3 .rb-map-card .robotina-map{border-radius:var(--md-shape-md);border:none}.rb-map-viewport{touch-action:none;-webkit-user-select:none;user-select:none;border-radius:var(--md-shape-md);position:relative;overflow:hidden}.rb-map-pan{transform-origin:0 0;will-change:transform}.rb-map-zoom{z-index:2;flex-direction:column;gap:4px;display:flex;position:absolute;top:8px;right:8px}.rb-map-zoom button{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0000008c;border:none;border-radius:9999px;justify-content:center;align-items:center;width:36px;height:36px;padding:0;transition:background .12s,transform .12s;display:inline-flex}.rb-map-zoom button:hover:not(:disabled){background:#000000bf}.rb-map-zoom button:active:not(:disabled){transform:scale(.94)}.rb-map-zoom button:disabled{opacity:.35;cursor:not-allowed}.rb-map-zoom button .material-symbols-outlined{font-size:20px}.robotina-wrap.m3 .rb-map-placeholder{height:50vh;min-height:280px;color:var(--md-on-surface-variant);flex-direction:column;justify-content:center;align-items:center;gap:8px;display:flex}.robotina-wrap.m3 .rb-map-placeholder .material-symbols-outlined{font-size:40px}.robotina-wrap.m3 .robotina-map-controls{margin-top:0;padding:0 4px}.robotina-wrap.m3 .rb-map-controls--top{flex-wrap:wrap;justify-content:center;margin-bottom:4px}.robotina-wrap.m3 .rb-room-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.robotina-wrap.m3 .rb-room-row{align-items:center;gap:6px;min-width:0;display:flex}.robotina-wrap.m3 .rb-room-select{background:var(--md-surface-container);cursor:pointer;text-align:left;min-width:0;font:inherit;color:var(--md-on-surface);border:1px solid #0000;border-radius:9999px;flex:auto;align-items:center;gap:10px;padding:8px 12px;transition:background .12s,color .12s;display:flex}.robotina-wrap.m3 .rb-room-select:hover:not(:disabled){background:var(--md-surface-container-high)}.robotina-wrap.m3 .rb-room-select--selected{color:#fff;font-weight:600}.robotina-wrap.m3 .rb-room-swatch{border-radius:9999px;flex-shrink:0;width:18px;height:18px;display:inline-block;box-shadow:inset 0 0 0 1px #0003}.robotina-wrap.m3 .rb-room-icon{color:#fff;border-radius:9999px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:inline-flex;box-shadow:inset 0 0 0 1px #0003}.robotina-wrap.m3 .rb-room-icon .material-symbols-outlined{font-size:18px}.robotina-wrap.m3 .rb-room-edit-form{background:var(--md-surface-container);border-radius:var(--md-shape-md);flex-direction:column;flex:auto;gap:8px;min-width:0;padding:6px;display:flex}.robotina-wrap.m3 .rb-room-edit-top{align-items:center;gap:6px;min-width:0;display:flex}.robotina-wrap.m3 .rb-icon-picker{flex-wrap:wrap;gap:4px;display:flex}.robotina-wrap.m3 .rb-icon-opt{background:var(--md-surface-container-low);width:36px;height:36px;color:var(--md-on-surface-variant);cursor:pointer;border:none;border-radius:9999px;justify-content:center;align-items:center;padding:0;transition:background .12s,color .12s;display:inline-flex}.robotina-wrap.m3 .rb-icon-opt:hover{background:var(--md-surface-container-high)}.robotina-wrap.m3 .rb-icon-opt--selected{background:var(--md-primary);color:var(--md-on-primary)}.robotina-wrap.m3 .rb-icon-opt .material-symbols-outlined{font-size:20px}.robotina-wrap.m3 .rb-room-name{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:14px;line-height:20px;overflow:hidden}.robotina-wrap.m3 .rb-iconbtn--inline{flex-shrink:0;width:36px;height:36px}.robotina-wrap.m3 .rb-iconbtn--inline .material-symbols-outlined{font-size:20px}.robotina-wrap.m3 .rb-room-input{border:1px solid var(--md-outline-variant);background:var(--md-surface-container);min-width:0;height:36px;color:var(--md-on-surface);font:inherit;border-radius:18px;outline:none;flex:auto;padding:0 12px}.robotina-wrap.m3 .rb-room-input:focus{border-color:var(--md-primary);outline:2px solid var(--md-primary);outline-offset:-1px}.robotina-wrap.m3 .robotina-map-controls .link-btn{color:var(--md-primary)}.robotina-wrap.m3 .rb-status-pill{background:var(--md-surface-container);color:var(--md-on-surface);white-space:nowrap;border-radius:9999px;align-items:center;gap:4px;padding:2px 10px 2px 6px;font-size:11px;line-height:16px;display:inline-flex}.robotina-wrap.m3 .rb-status-pill--active{background:var(--md-primary-container);color:var(--md-on-primary-container)}.robotina-wrap.m3 .rb-status-pill .material-symbols-outlined{font-size:14px}.robotina-wrap.m3 .rb-status-pill-label{letter-spacing:.4px;text-transform:uppercase;color:var(--md-on-surface-variant);font-size:9px}.robotina-wrap.m3 .rb-status-pill--active .rb-status-pill-label{color:var(--md-on-primary-container);opacity:.8}.robotina-wrap.m3 .rb-status-pill-value{font-weight:600}.robotina-wrap.m3 .robotina-actions{flex-wrap:wrap;gap:8px;display:flex}.robotina-wrap.m3 .robotina-actions button{flex:0 auto}.robotina-wrap.m3 .rb-btn-icon{align-items:center;gap:6px;display:inline-flex}.robotina-wrap.m3 .rb-btn-icon .material-symbols-outlined{font-size:18px}.robotina-wrap.m3 .rb-actions-icons{flex-wrap:wrap;justify-content:center;gap:12px;margin:4px 0;display:flex}.robotina-wrap.m3 .rb-action{background:var(--md-secondary-container);width:56px;height:56px;color:var(--md-on-secondary-container);cursor:pointer;border:none;border-radius:9999px;justify-content:center;align-items:center;padding:0;transition:filter .12s,transform .12s,background .12s;display:inline-flex;position:relative}.robotina-wrap.m3 .rb-action:hover:not(:disabled){filter:brightness(.97)}.robotina-wrap.m3 .rb-action:active:not(:disabled){transform:scale(.94)}.robotina-wrap.m3 .rb-action:disabled{opacity:.4;cursor:not-allowed}.robotina-wrap.m3 .rb-action .material-symbols-outlined{font-size:28px}.robotina-wrap.m3 .rb-action--primary{background:var(--md-primary);color:var(--md-on-primary)}.robotina-wrap.m3 .rb-action--danger{background:var(--md-error-container);color:var(--md-on-error-container)}.robotina-wrap.m3 .rb-action-badge{background:var(--md-error);min-width:22px;height:22px;color:var(--md-on-error);text-align:center;box-shadow:0 0 0 2px var(--md-surface);border-radius:9999px;padding:0 6px;font-size:12px;font-weight:600;line-height:22px;position:absolute;top:-2px;right:-2px}@media (width<=520px){.robotina-wrap.m3 .rb-action{width:52px;height:52px}.robotina-wrap.m3 .rb-action .material-symbols-outlined{font-size:26px}}.robotina-wrap.m3 button.primary{background:var(--md-primary);color:var(--md-on-primary);letter-spacing:.1px;cursor:pointer;border:none;border-radius:9999px;height:40px;padding:0 20px;font-size:14px;font-weight:500;transition:filter .12s}.robotina-wrap.m3 button.primary:hover:not(:disabled){filter:brightness(.95)}.robotina-wrap.m3 button.primary:disabled{color:#00000061;cursor:not-allowed;background:#0000001f}.robotina-wrap.m3 button.secondary{background:var(--md-secondary-container);color:var(--md-on-secondary-container);letter-spacing:.1px;cursor:pointer;border:none;border-radius:9999px;height:40px;padding:0 20px;font-size:14px;font-weight:500;transition:filter .12s}.robotina-wrap.m3 button.secondary:hover:not(:disabled){filter:brightness(.97)}.robotina-wrap.m3 button.secondary:disabled{opacity:.55;cursor:not-allowed}.robotina-wrap.m3 button.danger{background:var(--md-error-container);color:var(--md-on-error-container);letter-spacing:.1px;cursor:pointer;border:none;border-radius:9999px;height:40px;padding:0 20px;font-size:14px;font-weight:500;transition:filter .12s}.robotina-wrap.m3 button.danger:hover:not(:disabled){filter:brightness(.97)}.robotina-wrap.m3 button.danger:disabled{opacity:.55;cursor:not-allowed}.robotina-wrap.m3 .robotina-collapse{background:var(--md-surface-container-low);border-radius:var(--md-shape-md);border:none;padding:12px 16px}.robotina-wrap.m3 .robotina-collapse summary{color:var(--md-on-surface);align-items:center;gap:12px;font-size:15px;font-weight:500;display:flex}.robotina-wrap.m3 .robotina-collapse summary:before{display:none}.robotina-wrap.m3 .robotina-collapse summary>.material-symbols-outlined{color:var(--md-on-surface-variant);flex-shrink:0;font-size:20px}.robotina-wrap.m3 .robotina-collapse[open] summary{margin-bottom:8px}.robotina-wrap.m3 .robotina-error{background:var(--md-error-container);color:var(--md-on-error-container);border-radius:var(--md-shape-md);border:none}@media (width<=520px){.robotina-wrap.m3{padding:8px 12px 48px}.robotina-wrap.m3 .rb-map-placeholder{height:45vh;min-height:240px}}.recipes-m3{background:var(--md-surface);color:var(--md-on-surface);border-radius:var(--md-shape-lg);box-shadow:0 1px 2px #0000000d, 0 0 0 1px var(--md-outline-variant);border:none;padding:20px}.recipes-m3 .rc-hero{border-bottom:1px solid var(--md-outline-variant);flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;padding:4px 4px 16px;display:flex}.recipes-m3 .rc-hero-text{flex-direction:column;gap:4px;min-width:0;display:flex}.recipes-m3 .rc-hero-title{letter-spacing:0;color:var(--md-on-surface);font-size:28px;font-weight:400;line-height:36px}.recipes-m3 .rc-hero-sub{color:var(--md-on-surface-variant);margin:0;font-size:14px;line-height:20px}.recipes-m3 .rc-hero-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.recipes-m3 .rc-iconbtn{background:var(--md-surface-container);width:40px;height:40px;color:var(--md-on-surface-variant);cursor:pointer;border:none;border-radius:9999px;justify-content:center;align-items:center;transition:background .12s,color .12s;display:inline-flex}.recipes-m3 .rc-iconbtn:hover{background:var(--md-surface-container-high);color:var(--md-on-surface)}.recipes-m3 .rc-iconbtn .material-symbols-outlined{font-size:22px}.recipes-m3 .rc-fab{background:var(--md-primary-container);color:var(--md-on-primary-container);letter-spacing:.1px;cursor:pointer;border:none;border-radius:16px;align-items:center;gap:8px;height:56px;padding:0 20px 0 16px;font-size:14px;font-weight:500;transition:filter .12s,box-shadow .12s;display:inline-flex;box-shadow:0 1px 2px #0000001a,0 1px 3px 1px #00000014}.recipes-m3 .rc-fab:hover{filter:brightness(.97);box-shadow:0 2px 4px #00000024,0 1px 6px 2px #0000001a}.recipes-m3 .rc-fab .material-symbols-outlined{font-size:24px}.recipes-m3 .rc-toolbar{align-items:center;gap:12px;margin-bottom:12px;display:flex}.recipes-m3 .rc-search{background:var(--md-surface-container);border-radius:9999px;flex:1;align-items:center;gap:8px;height:48px;padding:0 16px;transition:background .12s,box-shadow .12s;display:flex}.recipes-m3 .rc-search:focus-within{background:var(--md-surface-container-high);box-shadow:0 0 0 2px var(--md-primary)}.recipes-m3 .rc-search-icon{color:var(--md-on-surface-variant);flex-shrink:0;font-size:22px}.recipes-m3 .rc-search input{min-width:0;color:var(--md-on-surface);background:0 0;border:none;outline:none;flex:1;padding:0;font-size:15px}.recipes-m3 .rc-search input::placeholder{color:var(--md-on-surface-variant)}.recipes-m3 .rc-search input::-webkit-search-decoration{appearance:none}.recipes-m3 .rc-search input::-webkit-search-cancel-button{appearance:none}.recipes-m3 .rc-search-clear{width:28px;height:28px;color:var(--md-on-surface-variant);cursor:pointer;background:0 0;border:none;border-radius:9999px;justify-content:center;align-items:center;display:inline-flex}.recipes-m3 .rc-search-clear:hover{color:var(--md-on-surface);background:#0000000f}.recipes-m3 .rc-search-clear .material-symbols-outlined{font-size:18px}.recipes-m3 .rc-filter-btn{background:var(--md-surface-container);height:48px;color:var(--md-on-surface);letter-spacing:.1px;cursor:pointer;border:none;border-radius:9999px;align-items:center;gap:8px;padding:0 20px;font-size:14px;font-weight:500;transition:background .12s,color .12s;display:inline-flex}.recipes-m3 .rc-filter-btn:hover{background:var(--md-surface-container-high)}.recipes-m3 .rc-filter-btn.open,.recipes-m3 .rc-filter-btn.has-active{background:var(--md-secondary-container);color:var(--md-on-secondary-container)}.recipes-m3 .rc-filter-btn .material-symbols-outlined{font-size:20px}.recipes-m3 .rc-filter-count{background:var(--md-primary);min-width:20px;height:20px;color:var(--md-on-primary);border-radius:9999px;justify-content:center;align-items:center;padding:0 6px;font-size:12px;font-weight:600;display:inline-flex}.recipes-m3 .rc-filter-panel{background:var(--md-surface-container-low);border-radius:var(--md-shape-md);margin-bottom:16px;padding:12px 16px 14px}.recipes-m3 .rc-filter-head{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.recipes-m3 .rc-filter-title{letter-spacing:.1px;color:var(--md-on-surface-variant);text-transform:uppercase;font-size:13px;font-weight:500}.recipes-m3 .rc-filter-clear{color:var(--md-primary);cursor:pointer;background:0 0;border:none;border-radius:9999px;padding:4px 8px;font-size:13px;font-weight:500}.recipes-m3 .rc-filter-clear:hover{background:#2f7a5514}.recipes-m3 .rc-chip-row{flex-wrap:wrap;gap:8px;display:flex}.recipes-m3 .rc-chip{border:1px solid var(--md-outline);height:32px;color:var(--md-on-surface-variant);letter-spacing:.1px;cursor:pointer;background:0 0;border-radius:8px;align-items:center;gap:6px;padding:0 14px;font-size:13px;font-weight:500;transition:background .12s,color .12s,border-color .12s;display:inline-flex}.recipes-m3 .rc-chip:hover{background:#0000000a}.recipes-m3 .rc-chip.on{background:var(--md-secondary-container);color:var(--md-on-secondary-container);border-color:#0000;padding-left:8px}.recipes-m3 .rc-chip-check{font-size:18px}.recipes-m3 .rc-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;display:grid}.recipes-m3 .rc-card{background:var(--md-surface-container-low);border-radius:var(--md-shape-md);border:none;transition:background .12s,box-shadow .12s,transform .12s}.recipes-m3 .rc-card:hover{background:var(--md-surface-container);transform:translateY(-1px);box-shadow:0 1px 2px #0000001a,0 1px 4px 1px #0000000f}.recipes-m3 .rc-card .card-button{gap:6px;padding:12px 14px}.recipes-m3 .rc-card .card-button h3{letter-spacing:.15px;color:var(--md-on-surface);font-size:14px;font-weight:500;line-height:20px}.recipes-m3 .rc-card .card-button .muted{color:var(--md-on-surface-variant);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:12px;line-height:16px;display:-webkit-box;overflow:hidden}.recipes-m3 .rc-card-foot{border-top:1px solid var(--md-outline-variant);color:var(--md-on-surface-variant);flex-wrap:wrap;align-items:center;gap:8px 10px;margin-top:auto;padding-top:6px;display:flex}.recipes-m3 .rc-card-foot .meal-type-badge{padding:1px 8px;font-size:11px}.recipes-m3 .rc-card-stat{align-items:center;gap:3px;font-size:12px;font-weight:500;display:inline-flex}.recipes-m3 .rc-card-stat .material-symbols-outlined{font-size:15px}.recipes-m3 .rc-empty{text-align:center;flex-direction:column;align-items:center;gap:8px;padding:48px 16px;display:flex}.recipes-m3 .rc-empty-icon{color:var(--md-outline);margin-bottom:4px;font-size:56px}.recipes-m3 .rc-empty-title{color:var(--md-on-surface);margin:0;font-size:18px;font-weight:500}.recipes-m3 .rc-empty-sub{color:var(--md-on-surface-variant);margin:0 0 8px;font-size:14px}.recipes-m3 .rc-pagination{border-top:1px solid var(--md-outline-variant);justify-content:center;align-items:center;gap:8px;margin-top:20px;padding-top:16px;display:flex}.recipes-m3 .rc-page-nav{background:var(--md-surface-container);width:40px;height:40px;color:var(--md-on-surface);cursor:pointer;border:none;border-radius:9999px;justify-content:center;align-items:center;transition:background .12s,opacity .12s;display:inline-flex}.recipes-m3 .rc-page-nav:hover:not(:disabled){background:var(--md-surface-container-high)}.recipes-m3 .rc-page-nav:disabled{opacity:.4;cursor:not-allowed}.recipes-m3 .rc-page-nav .material-symbols-outlined{font-size:22px}.recipes-m3 .rc-page-info{color:var(--md-on-surface-variant);font-variant-numeric:tabular-nums;padding:0 12px;font-size:14px}.recipes-m3 .rc-page-count{color:var(--md-on-surface-variant);opacity:.8;margin-left:4px}.recipes-m3.chef-panel .rc-toolbar{margin-bottom:20px}.recipes-m3 .chef-pick{flex-direction:column;gap:10px;display:flex}.recipes-m3 .chef-pick-header{justify-content:space-between;align-items:center;padding:0 2px;display:flex}.recipes-m3 .chef-pick-label{letter-spacing:.6px;text-transform:uppercase;color:var(--md-primary);align-items:center;gap:8px;font-size:13px;font-weight:500;display:inline-flex}.recipes-m3 .chef-pick-label .material-symbols-outlined{font-size:18px}.recipes-m3 .chef-pick-grid{grid-template-columns:1fr}.recipes-m3 .chef-pick-grid .rc-card{background:var(--md-secondary-container)}.recipes-m3 .chef-pick-grid .rc-card .card-button h3{color:var(--md-on-secondary-container);font-size:18px;line-height:24px}.recipes-m3 .chef-pick-grid .rc-card .card-button .muted{color:var(--md-on-secondary-container);opacity:.8}.recipes-m3 .chef-pick-grid .rc-card-foot{color:var(--md-on-secondary-container);border-top-color:#0000001f}.recipes-m3 .chef-results-head{margin-bottom:8px;padding:0 2px}.recipes-m3 .chef-results-count{color:var(--md-on-surface-variant);font-size:13px}@media (prefers-color-scheme:dark){.recipes-m3 .chef-pick-grid .rc-card-foot{border-top-color:#ffffff24}}.recipes-m3 .rc-back{color:var(--md-primary);align-items:center;gap:4px;display:inline-flex}.recipes-m3 .rc-back .material-symbols-outlined{font-size:20px}.recipes-m3.recipes-detail-panel .recipe-detail h2{font-size:26px;font-weight:400;line-height:32px}@media (prefers-color-scheme:dark){.recipes-m3 .rc-search-clear:hover,.recipes-m3 .rc-chip:hover{background:#ffffff0f}.recipes-m3 .rc-filter-clear:hover{background:#98d6ae1f}}@media (width<=520px){.recipes-m3{padding:16px 14px}.recipes-m3 .rc-hero-title{font-size:24px;line-height:32px}.recipes-m3 .rc-fab{height:48px;padding:0 18px 0 14px}.recipes-m3 .rc-fab-label{display:none}.recipes-m3 .rc-toolbar{flex-wrap:wrap}.recipes-m3 .rc-search{height:44px}.recipes-m3 .rc-filter-btn{height:44px;padding:0 16px}.recipes-m3 .rc-filter-label{display:none}.recipes-m3 .rc-grid{grid-template-columns:1fr}.recipes-m3 .rc-page-info{padding:0 4px;font-size:13px}.recipes-m3 .rc-page-count{display:none}}.inbox-wrap.m3{--md-primary:#2f7a55;--md-on-primary:#fff;--md-primary-container:#b3f1c8;--md-on-primary-container:#002112;--md-secondary-container:#d3e8d6;--md-on-secondary-container:#0d1f12;--md-surface:#f6fbf3;--md-on-surface:#181d18;--md-surface-container-low:#f0f5ee;--md-surface-container:#eaefe8;--md-surface-container-high:#e4eae2;--md-on-surface-variant:#424942;--md-outline:#717971;--md-outline-variant:#c0c8be;background:var(--md-surface);min-height:100vh;color:var(--md-on-surface);max-width:760px;margin:0 auto;padding:12px 20px 64px}@media (prefers-color-scheme:dark){.inbox-wrap.m3{--md-primary:#98d6ae;--md-on-primary:#003822;--md-primary-container:#1f5132;--md-on-primary-container:#b3f1c8;--md-secondary-container:#384b3c;--md-on-secondary-container:#d3e8d6;--md-surface:#101510;--md-on-surface:#dfe4dd;--md-surface-container-low:#181d18;--md-surface-container:#1c211c;--md-surface-container-high:#272b27;--md-on-surface-variant:#c0c8be;--md-outline:#8b938b;--md-outline-variant:#424942}}.inbox-wrap.m3 .inbox-top{align-items:center;gap:12px;padding:4px 0 16px;display:flex}.inbox-wrap.m3 .inbox-back{width:40px;height:40px;color:var(--md-on-surface);cursor:pointer;background:0 0;border:none;border-radius:9999px;justify-content:center;align-items:center;transition:background .12s;display:inline-flex}.inbox-wrap.m3 .inbox-back:hover{background:#0000000f}.inbox-wrap.m3 .inbox-back .material-symbols-outlined{font-size:24px}.inbox-wrap.m3 .inbox-title-block{flex-direction:column;gap:2px;display:flex}.inbox-wrap.m3 .inbox-eyebrow{letter-spacing:.6px;text-transform:uppercase;color:var(--md-on-surface-variant);font-size:11px;font-weight:500}.inbox-wrap.m3 .inbox-title{letter-spacing:0;color:var(--md-on-surface);margin:0;font-size:28px;font-weight:400;line-height:36px}.inbox-wrap.m3 .inbox-main{flex-direction:column;gap:12px;display:flex}.inbox-wrap.m3 .inbox-empty{background:var(--md-surface-container-low);border-radius:var(--md-shape-lg);text-align:center;flex-direction:column;align-items:center;gap:6px;padding:56px 24px;display:flex}.inbox-wrap.m3 .inbox-empty-icon{color:var(--md-primary);margin-bottom:6px;font-size:64px}.inbox-wrap.m3 .inbox-empty-title{color:var(--md-on-surface);margin:0;font-size:20px;font-weight:500}.inbox-wrap.m3 .inbox-empty-sub{color:var(--md-on-surface-variant);max-width:380px;margin:0;font-size:14px;line-height:20px}.inbox-wrap.m3 .inbox-empty-note{color:var(--md-on-surface-variant);opacity:.8;margin-top:12px;font-size:12px}.inbox-wrap.m3 .inbox-count{letter-spacing:.5px;text-transform:uppercase;color:var(--md-on-secondary-container);background:var(--md-secondary-container);border-radius:9999px;margin-left:auto;padding:4px 12px;font-size:12px;font-weight:500}.inbox-wrap.m3 .inbox-loading{text-align:center;padding:40px 16px}.inbox-wrap.m3 .inbox-error{background:var(--md-error-container);color:var(--md-on-error-container);border-radius:var(--md-shape-md);align-items:center;gap:10px;margin-bottom:12px;padding:12px 16px;font-size:13px;display:flex}.inbox-wrap.m3 .inbox-error .material-symbols-outlined{font-size:20px}.inbox-wrap.m3 .inbox-section{margin-top:16px}.inbox-wrap.m3 .inbox-section:first-child{margin-top:0}.inbox-wrap.m3 .inbox-section-title{letter-spacing:.8px;text-transform:uppercase;color:var(--md-on-surface-variant);margin:0 4px 8px;font-size:12px;font-weight:500}.inbox-wrap.m3 .proposal-list{flex-direction:column;gap:10px;display:flex}.inbox-wrap.m3 .proposal-card{background:var(--md-surface-container-low);border-radius:var(--md-shape-md);flex-direction:column;gap:8px;padding:14px 16px;transition:background .12s;display:flex}.inbox-wrap.m3 .proposal-card:hover{background:var(--md-surface-container)}.inbox-wrap.m3 .proposal-type{letter-spacing:.8px;text-transform:uppercase;border-radius:9999px;align-self:flex-start;align-items:center;gap:6px;padding:2px 10px 2px 6px;font-size:11px;font-weight:600;display:inline-flex}.inbox-wrap.m3 .proposal-type--event{color:var(--md-primary);background:#2f7a5524}.inbox-wrap.m3 .proposal-type--reminder{color:#a8377f;background:#c850a024}.inbox-wrap.m3 .proposal-type .material-symbols-outlined{font-size:16px}.inbox-wrap.m3 .proposal-title{letter-spacing:.15px;color:var(--md-on-surface);margin:0;font-size:16px;font-weight:500;line-height:22px}.inbox-wrap.m3 .proposal-when,.inbox-wrap.m3 .proposal-where{color:var(--md-on-surface-variant);align-items:center;gap:6px;font-size:13px;display:inline-flex}.inbox-wrap.m3 .proposal-when .material-symbols-outlined,.inbox-wrap.m3 .proposal-where .material-symbols-outlined{font-size:16px}.inbox-wrap.m3 .proposal-desc{color:var(--md-on-surface-variant);-webkit-line-clamp:3;-webkit-box-orient:vertical;margin:0;font-size:13px;line-height:18px;display:-webkit-box;overflow:hidden}.inbox-wrap.m3 .proposal-source{border-top:1px solid var(--md-outline-variant);flex-direction:column;gap:1px;padding-top:8px;display:flex}.inbox-wrap.m3 .proposal-source-from{color:var(--md-on-surface);font-size:12px;font-weight:500}.inbox-wrap.m3 .proposal-source-subj{color:var(--md-on-surface-variant);text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.inbox-wrap.m3 .proposal-actions{justify-content:flex-end;gap:8px;margin-top:2px;display:flex}.inbox-wrap.m3 .proposal-btn{letter-spacing:.1px;cursor:pointer;border:none;border-radius:9999px;height:36px;padding:0 16px;font-size:13px;font-weight:500;transition:filter .12s,background .12s}.inbox-wrap.m3 .proposal-btn--secondary{color:var(--md-on-surface-variant);background:0 0}.inbox-wrap.m3 .proposal-btn--secondary:hover:not(:disabled){background:#0000000f}.inbox-wrap.m3 .proposal-btn--primary{background:var(--md-primary);color:var(--md-on-primary)}.inbox-wrap.m3 .proposal-btn--primary:hover:not(:disabled){filter:brightness(.94)}.inbox-wrap.m3 .proposal-btn:disabled{opacity:.5;cursor:not-allowed}@media (prefers-color-scheme:dark){.inbox-wrap.m3 .inbox-back:hover,.inbox-wrap.m3 .proposal-btn--secondary:hover:not(:disabled){background:#ffffff0f}.inbox-wrap.m3 .proposal-type--reminder{color:#e69cc8}}@media (width<=520px){.inbox-wrap.m3{padding:8px 14px 48px}.inbox-wrap.m3 .inbox-title{font-size:24px;line-height:32px}.inbox-wrap.m3 .inbox-empty{padding:40px 18px}.inbox-wrap.m3 .proposal-card{padding:12px 14px}.inbox-wrap.m3 .proposal-actions{justify-content:stretch}.inbox-wrap.m3 .proposal-btn{flex:1}}
