:root{--bg-deep: #111418;--bg-elevated: #1a1e24;--bg-hover: #272d36;--fg-primary: #e8eaef;--fg-secondary: #9aa0ab;--fg-muted: #5e6470;--border-subtle: #272d36;--border-strong: #3a414c;--accent-paprika: #e2543f;--accent-paprika-hover: #ed6a56;--accent-basil: #65b377;--accent-saffron: #d4a242;--radius: 6px;--radius-sm: 4px;--radius-full: 999px;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 24px;--row-min-height: 48px;--bottom-tab-height: 60px}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;background:var(--bg-deep);color:var(--fg-primary);font-family:Inter,system-ui,-apple-system,sans-serif;font-size:15px;line-height:1.45;font-feature-settings:"tnum" 1,"cv11" 1;-webkit-tap-highlight-color:transparent;-webkit-font-smoothing:antialiased}body{min-height:100dvh}button{font-family:inherit;color:inherit;background:none;border:none;padding:0;cursor:pointer}input,textarea,select{font-family:inherit;color:inherit;font-size:16px}a{color:inherit;text-decoration:none}.serif{font-family:Lora,Georgia,serif}.tnum{font-variant-numeric:tabular-nums}.app-shell{display:flex;flex-direction:column;height:100dvh;max-width:480px;margin:0 auto;background:var(--bg-deep);position:relative;overflow:hidden}@media (min-width: 768px){.app-shell{max-width:720px;box-shadow:0 0 0 1px var(--border-subtle)}}.app-content{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding-bottom:calc(var(--bottom-tab-height) + env(safe-area-inset-bottom,0px));-webkit-overflow-scrolling:touch}.page{padding:var(--sp-3) var(--sp-4) var(--sp-4)}.page-title{font-family:Lora,serif;font-size:26px;font-weight:600;letter-spacing:-.01em;margin:var(--sp-3) 0 var(--sp-2)}.page-sub{color:var(--fg-secondary);font-size:13px;margin-bottom:var(--sp-4)}.section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--fg-muted);padding:var(--sp-3) var(--sp-4) var(--sp-1)}.divider{height:1px;background:var(--border-subtle);margin:var(--sp-2) 0}.safe-top{padding-top:env(safe-area-inset-top,0px)}.link-btn{background:transparent;color:var(--fg-muted);font-size:14px;padding:6px 8px;border-radius:var(--radius-sm);cursor:pointer;min-width:32px}.link-btn:hover{color:var(--accent-paprika);background:var(--bg-hover)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}::-webkit-scrollbar-track{background:transparent}.bottom-tab{position:fixed;bottom:0;left:0;right:0;background:var(--bg-elevated);border-top:1px solid var(--border-subtle);display:flex;z-index:20;padding-bottom:env(safe-area-inset-bottom,0px);height:calc(var(--bottom-tab-height) + env(safe-area-inset-bottom,0px));max-width:480px;margin:0 auto}@media (min-width: 768px){.bottom-tab{max-width:720px}}.bt-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--fg-muted);text-decoration:none;font-size:11px;font-weight:500;transition:color .1s ease;padding-top:4px}.bt-item:active{color:var(--fg-secondary)}.bt-icon{font-size:22px;line-height:1;filter:grayscale(.6);opacity:.7;transition:filter .1s,opacity .1s}.bt-item--active{color:var(--accent-paprika)}.bt-item--active .bt-icon{filter:none;opacity:1}.bt-label{letter-spacing:.01em}.chip-row{display:flex;flex-wrap:wrap;gap:6px;padding:var(--sp-2) 0;overflow-x:auto;scrollbar-width:none}.chip-row::-webkit-scrollbar{display:none}.chip{font-size:13px;padding:7px 12px;border-radius:var(--radius-full);background:var(--bg-hover);color:var(--fg-secondary);-webkit-user-select:none;user-select:none;white-space:nowrap;border:1px solid transparent;min-height:32px}.chip:hover{color:var(--fg-primary)}.chip--active{background:var(--accent-paprika);color:var(--bg-deep);font-weight:600}.chip--active:hover{color:var(--bg-deep);background:var(--accent-paprika-hover)}.stars{display:inline-flex;letter-spacing:-1px;line-height:1}.stars--sm{font-size:13px}.stars--md{font-size:16px}.stars--lg{font-size:20px}.star--on{color:var(--accent-saffron)}.star--off{color:var(--border-strong)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;border-radius:var(--radius);font-size:14px;font-weight:500;min-height:40px;border:1px solid transparent;transition:background-color .1s ease;-webkit-user-select:none;user-select:none;white-space:nowrap}.btn--full{width:100%}.btn--primary{background:var(--accent-paprika);color:var(--bg-deep)}.btn--primary:active,.btn--primary:hover{background:var(--accent-paprika-hover)}.btn--secondary{background:var(--bg-hover);color:var(--fg-primary);border-color:var(--border-strong)}.btn--secondary:active,.btn--secondary:hover{background:var(--border-strong)}.btn--ghost{background:transparent;color:var(--fg-secondary)}.btn--ghost:active,.btn--ghost:hover{color:var(--fg-primary);background:var(--bg-hover)}.btn--danger{background:transparent;color:var(--accent-paprika);border-color:var(--border-strong)}.btn--danger:active,.btn--danger:hover{background:var(--bg-hover)}.btn-icon{display:inline-flex;align-items:center}.snackbar{position:fixed;bottom:calc(var(--bottom-tab-height, 0px) + 12px);left:50%;transform:translate(-50%);background:var(--bg-elevated);color:var(--fg-primary);border:1px solid var(--border-strong);border-radius:12px;padding:12px 16px;display:flex;align-items:center;gap:12px;min-width:280px;max-width:90vw;z-index:200;box-shadow:0 8px 24px #0006;overflow:hidden}.snackbar-message{flex:1;font-size:14px}.snackbar-action{background:transparent;color:var(--accent-paprika);border:none;font-weight:600;font-size:14px;cursor:pointer;padding:4px 8px}.snackbar-progress{position:absolute;bottom:0;left:0;height:2px;background:var(--accent-paprika);transition:width 50ms linear}.snackbar--info{border-color:var(--accent-saffron, #d4a242)}.snackbar--success{border-color:var(--accent-basil, #65b377)}.ars-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:flex-end;justify-content:center;z-index:100}.ars-sheet{width:100%;max-width:480px;background:var(--bg-elevated);border-top:1px solid var(--border-strong);border-radius:16px 16px 0 0;padding:var(--sp-3) var(--sp-3) calc(var(--sp-4) + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;gap:var(--sp-2);animation:ars-slide-up .2s ease-out}@media (min-width: 768px){.ars-sheet{max-width:720px}}@keyframes ars-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.ars-header{display:flex;align-items:center;justify-content:space-between;padding:2px 4px 8px;border-bottom:1px solid var(--border-subtle)}.ars-title{font-family:Lora,Georgia,serif;font-size:17px;font-weight:600;color:var(--fg-primary)}.ars-close{width:40px;height:40px;background:var(--bg-deep);color:var(--fg-secondary);border:1px solid var(--border-subtle);font-size:20px;line-height:1;border-radius:999px;display:flex;align-items:center;justify-content:center;cursor:pointer}.ars-close:active{background:var(--bg-hover);color:var(--accent-paprika);border-color:var(--accent-paprika)}.ars-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:4px 0}.ars-action{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;min-height:96px;border-radius:12px;background:var(--bg-deep);border:1px solid var(--border-subtle);cursor:pointer;padding:var(--sp-3) var(--sp-2);text-align:center}.ars-action:active{background:var(--bg-hover);transform:scale(.97)}.ars-action-emoji{font-size:28px;line-height:1}.ars-action-label{font-size:14px;font-weight:600;color:var(--fg-primary)}.ars-action-sub{font-size:11px;color:var(--fg-muted)}.cb-hero{padding:6px var(--sp-4) 8px;background:var(--bg-deep)}.cb-hero-row{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3)}.cb-title{font-family:Lora,Georgia,serif;font-size:22px;font-weight:700;letter-spacing:-.015em;margin:0;line-height:1.1;color:var(--fg-primary)}.cb-add-fab{width:36px;height:36px;border-radius:999px;background:var(--accent-paprika);color:var(--bg-deep);font-size:20px;font-weight:500;display:flex;align-items:center;justify-content:center;box-shadow:0 3px 8px #e2543f40;border:none;flex-shrink:0;line-height:1;padding-bottom:2px}.cb-add-fab:active{background:var(--accent-paprika-hover);transform:scale(.96)}.cb-meta{font-size:11px;color:var(--fg-secondary);margin-top:2px}.cb-toolbar{position:sticky;top:0;background:var(--bg-deep);padding:6px var(--sp-4) 5px;border-bottom:1px solid var(--border-subtle);z-index:9}.cb-search-row{display:flex;gap:6px;align-items:center}.cb-search-wrap{flex:1;display:flex;align-items:center;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:0 10px;min-height:36px;gap:6px}.cb-search-wrap:focus-within{border-color:var(--border-strong)}.cb-search-icon{color:var(--fg-muted);font-size:13px}.cb-search-input{flex:1;background:transparent;border:none;outline:none;font-size:14px;color:var(--fg-primary);min-height:36px;padding:0;min-width:0}.cb-search-input::placeholder{color:var(--fg-muted)}.cb-search-clear{color:var(--fg-muted);font-size:12px;padding:2px 4px;border-radius:var(--radius-sm);background:transparent}.cb-search-clear:active{color:var(--fg-primary);background:var(--bg-hover)}.cb-sort-btn{position:relative;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius);font-size:16px;color:var(--fg-secondary);flex-shrink:0}.cb-sort-btn:active{background:var(--bg-hover);color:var(--fg-primary)}.cb-sort-btn--active{color:var(--accent-paprika);border-color:#e2543f66}.cb-sort-dot{position:absolute;top:5px;right:5px;width:6px;height:6px;border-radius:999px;background:var(--accent-paprika)}.cb-cat-row{display:flex;gap:5px;overflow-x:auto;scrollbar-width:none;padding-bottom:2px;margin-top:6px}.cb-cat-row::-webkit-scrollbar{display:none}.cb-body{padding:8px var(--sp-4) var(--sp-4)}.cb-cards{display:flex;flex-direction:column;gap:3px}.cb-card{display:flex;align-items:center;gap:10px;padding:6px 10px;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:8px;min-height:48px;cursor:pointer;transition:background-color .08s}.cb-card:active{background:var(--bg-hover)}.cb-card-emoji{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-deep);border-radius:6px;font-size:18px;flex-shrink:0}.cb-card-body{flex:1;min-width:0}.cb-card-name{font-family:Lora,Georgia,serif;font-size:15px;font-weight:600;color:var(--fg-primary);letter-spacing:-.005em;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cb-card-meta{font-size:11px;color:var(--fg-secondary);display:flex;gap:6px;margin-top:1px;flex-wrap:nowrap;overflow:hidden}.cb-card-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.cb-card-count{color:var(--fg-muted);font-size:11px;min-width:26px;text-align:right}.cb-empty{padding:var(--sp-5) var(--sp-4);text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--sp-2)}.cb-empty-emoji{font-size:40px;opacity:.6}.cb-empty-title{font-family:Lora,serif;font-size:18px;font-weight:600;color:var(--fg-secondary)}.cb-empty-sub{font-size:13px;color:var(--fg-muted);line-height:1.5;max-width:260px}.cb-sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:flex-end;justify-content:center;z-index:100;padding:0 0 calc(var(--bottom-tab-height) + env(safe-area-inset-bottom,0px))}.cb-sheet{background:var(--bg-elevated);border-top:1px solid var(--border-strong);border-radius:14px 14px 0 0;padding:var(--sp-4) var(--sp-4) calc(var(--sp-4) + env(safe-area-inset-bottom,0px));width:100%;max-width:480px;display:flex;flex-direction:column;gap:4px}.cb-sheet-title{font-size:18px;font-weight:600;margin-bottom:10px}.cb-sheet-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--fg-muted);margin:12px 0 4px}.cb-sort-list{display:flex;flex-direction:column;gap:2px}.cb-sort-item{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--bg-deep);border:1px solid var(--border-subtle);border-radius:var(--radius);font-size:14px;color:var(--fg-primary);min-height:44px}.cb-sort-item:active{background:var(--bg-hover)}.cb-sort-item--active{border-color:var(--accent-paprika);background:#e2543f0f;color:var(--accent-paprika);font-weight:600}.cb-sort-check{font-size:14px;color:var(--accent-paprika)}.cb-sheet-actions{display:flex;justify-content:flex-end;gap:var(--sp-2);margin-top:var(--sp-3)}.card{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius);overflow:hidden;padding:var(--sp-3)}.card--no-pad{padding:0}.card+.card{margin-top:var(--sp-3)}.card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--border-subtle)}.card-header-title{font-size:16px;font-weight:600}.card-header-right{color:var(--fg-secondary);font-size:13px;display:flex;align-items:center;gap:var(--sp-2)}.ais-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:stretch;justify-content:center;z-index:100}.ais-sheet{width:100%;max-width:480px;height:100dvh;background:var(--bg-elevated);border-left:1px solid var(--border-subtle);border-right:1px solid var(--border-subtle);padding:calc(env(safe-area-inset-top,0px) + var(--sp-2)) var(--sp-3) calc(env(safe-area-inset-bottom,0px) + var(--sp-2));display:flex;flex-direction:column;gap:var(--sp-2);animation:ais-slide-up .2s ease-out}@media (min-width: 768px){.ais-sheet{max-width:720px}}@keyframes ais-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.ais-header{display:flex;align-items:center;justify-content:space-between;padding:2px 4px 8px;border-bottom:1px solid var(--border-subtle)}.ais-title{font-family:Lora,Georgia,serif;font-size:17px;font-weight:600;color:var(--fg-primary)}.ais-close{width:40px;height:40px;background:var(--bg-deep);color:var(--fg-secondary);border:1px solid var(--border-subtle);font-size:20px;font-weight:500;line-height:1;border-radius:999px;flex-shrink:0;display:flex;align-items:center;justify-content:center;cursor:pointer}.ais-close:active{background:var(--bg-hover);color:var(--accent-paprika);border-color:var(--accent-paprika)}.ais-form{display:flex;flex-direction:column;gap:6px;padding-top:2px;flex-shrink:0}.ais-form-row{display:flex;gap:6px;align-items:center}.ais-input{background:var(--bg-deep);border:1px solid var(--border-strong);border-radius:8px;padding:10px 12px;font-size:16px;color:var(--fg-primary);min-height:42px}.ais-input:focus{outline:none;border-color:var(--accent-paprika)}.ais-input-name,.ais-input-qty{flex:1;min-width:0}.ais-input-unit{flex:2;min-width:0}.ais-ok{background:var(--accent-paprika);color:#fff;border:none;border-radius:8px;padding:0 16px;min-height:42px;font-size:15px;font-weight:600;cursor:pointer;flex-shrink:0}.ais-ok:disabled{opacity:.4;cursor:not-allowed}.ais-ok:active:not(:disabled){opacity:.85}.ais-last-added{font-size:13px;color:var(--fg-secondary);background:#65b3771a;border:1px solid rgba(101,179,119,.25);border-radius:8px;padding:8px 12px;margin-top:2px}.ais-last-added-label{color:var(--fg-muted);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.ais-last-added-value{color:var(--accent-basil);font-weight:600}.ais-suggestions-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--fg-muted);padding:6px 4px 2px}.ais-suggestions{display:flex;flex-wrap:wrap;gap:6px;overflow-y:auto;min-height:0;flex:1;padding:2px 0 8px;align-content:flex-start}.ais-suggestion{background:var(--bg-deep);color:var(--fg-primary);border:1px solid var(--border-subtle);border-radius:14px;padding:6px 12px;font-size:13px;cursor:pointer;white-space:nowrap;min-height:30px}.ais-suggestion:active{background:var(--accent-paprika);color:#fff;border-color:var(--accent-paprika)}.ais-empty{font-size:13px;color:var(--fg-muted);padding:12px;text-align:center}.eis-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--fg-muted);padding:4px 4px 0}.eis-row-2{display:grid;grid-template-columns:1fr 1fr;gap:8px}.eis-field{display:flex;flex-direction:column;gap:4px}.eis-actions{display:flex;justify-content:center;margin-top:auto;padding-top:var(--sp-3)}.eis-delete{background:transparent;color:var(--accent-paprika);border:1px solid rgba(226,84,63,.4);border-radius:8px;padding:0 16px;min-height:42px;font-size:15px;font-weight:500;cursor:pointer}.eis-delete:active{background:#e2543f1f}.eis-move{width:100%;background:var(--bg-deep);color:var(--fg-secondary);border:1.5px solid var(--border-subtle);border-radius:8px;padding:0 16px;min-height:42px;font-size:15px;font-weight:500;cursor:pointer;text-align:left}.eis-move:active{background:var(--bg-hover);border-color:var(--accent-saffron);color:var(--fg-primary)}.ecs-rating-row{display:flex;align-items:center;justify-content:space-between;padding:4px 0;flex-wrap:wrap;gap:8px}.ecs-stars{display:flex;gap:4px}.ecs-star{background:none;border:none;cursor:pointer;font-size:28px;padding:6px 4px;color:var(--border-strong);transition:color .1s}.ecs-star--on{color:var(--accent-saffron)}.ecs-rating-reset{background:none;border:none;cursor:pointer;color:var(--fg-muted);font-size:13px;padding:6px 8px;text-decoration:underline}.ecs-notes{background:var(--bg-deep);border:1px solid var(--border-strong);border-radius:8px;padding:10px 12px;font-size:16px;color:var(--fg-primary);resize:vertical;min-height:80px;font-family:inherit}.ecs-notes:focus{outline:none;border-color:var(--accent-paprika)}.ecs-save{width:100%;margin-top:var(--sp-2)}.cht-body{display:flex;flex-direction:column;gap:12px;padding:8px 0}.cht-header{padding:0 4px}.cht-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.cht-row{background:var(--bg-elevated);border-radius:10px;padding:12px;position:relative}.cht-row-head{display:flex;gap:12px;align-items:baseline;font-size:.9rem}.cht-date{font-weight:500}.cht-rating{color:var(--accent-saffron);letter-spacing:1px}.cht-duration{margin-left:auto}.cht-note{margin-top:8px;color:var(--fg-secondary);font-size:.9rem;cursor:pointer}.cht-empty{padding:24px;text-align:center}.cht-timings-toggle{background:none;border:none;color:var(--fg-muted);font-size:12px;cursor:pointer;padding:4px 0;margin-top:4px;display:block}.cht-timings{list-style:none;padding:0;margin:6px 0 0;display:flex;flex-direction:column;gap:4px}.cht-timing{display:flex;flex-wrap:wrap;gap:6px;align-items:baseline;font-size:12px;padding:6px 8px;border-radius:6px;background:var(--bg-deep)}.cht-timing--overrun{background:#d4a2421a}.cht-timing-label{flex:1;min-width:0}.cht-timing-ist{font-weight:600}.cht-timing-icon{font-size:11px}.cht-edit{background:none;border:none;color:var(--fg-secondary);font-size:16px;line-height:1;padding:6px 8px;cursor:pointer;opacity:.7;align-self:start;margin-left:auto}.cht-edit:active{opacity:1;color:var(--accent-saffron)}.add-sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:flex-end;justify-content:center;z-index:100;padding:0 0 calc(var(--bottom-tab-height) + env(safe-area-inset-bottom,0px))}.add-sheet{width:100%;max-width:480px;background:var(--bg-elevated);border-top:1px solid var(--border-strong);border-radius:14px 14px 0 0;padding:var(--sp-3) var(--sp-3) calc(var(--sp-4) + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;gap:var(--sp-2)}.add-sheet-header{display:flex;align-items:center;justify-content:space-between;padding:4px 6px 10px;border-bottom:1px solid var(--border-subtle);margin-bottom:4px}.add-sheet-title{font-size:17px;font-weight:600}.add-sheet-close{width:32px;height:32px;background:transparent;color:var(--fg-muted);font-size:14px;border-radius:999px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.add-sheet-close:active{background:var(--bg-hover)}.add-sheet-recipe-name{font-size:15px;color:var(--fg-secondary);padding:0 6px}.add-sheet-section-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--fg-muted);padding:var(--sp-1) 6px 0}.add-sheet-servings-row{display:flex;align-items:center;gap:var(--sp-2);background:var(--bg-deep);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:6px;align-self:flex-start}.add-sheet-srv-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--fg-primary);border-radius:var(--radius-sm);background:var(--bg-elevated);border:1px solid var(--border-subtle)}.add-sheet-srv-btn:hover:not(:disabled){background:var(--bg-hover)}.add-sheet-srv-btn:disabled{opacity:.35}.add-sheet-srv-val{min-width:36px;text-align:center;font-size:18px;font-weight:600}.add-sheet-preview{font-size:14px;color:var(--fg-secondary);padding:var(--sp-1) 6px}.add-sheet-toast{font-size:14px;color:var(--accent-paprika);background:#e2543f14;border:1px solid rgba(226,84,63,.2);border-radius:var(--radius-sm);padding:10px 14px}.add-sheet-actions{display:flex;justify-content:flex-end;gap:var(--sp-2);padding-top:var(--sp-2)}.add-sheet-list-section{display:flex;flex-direction:column;gap:6px}.add-sheet-list-pills{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;padding:2px 0 4px}.add-sheet-list-pills::-webkit-scrollbar{display:none}.add-sheet-list-pill{display:flex;align-items:center;gap:5px;flex-shrink:0;background:var(--bg-deep);color:var(--fg-primary);border:1.5px solid var(--border-subtle);border-radius:999px;padding:6px 12px;font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap;min-height:34px;transition:border-color .12s,background-color .12s}.add-sheet-list-pill:active{background:var(--bg-hover)}.add-sheet-list-pill:disabled{opacity:.5;cursor:default}.add-sheet-list-pill--active{border-color:var(--accent-paprika);background:#e2543f17;color:var(--accent-paprika);font-weight:600}.add-sheet-list-pill-emoji{font-size:14px;line-height:1}.add-sheet-list-pill-label{max-width:120px;overflow:hidden;text-overflow:ellipsis}.add-sheet-no-lists{display:flex;flex-direction:column;align-items:center;gap:10px;padding:var(--sp-3) 0}.add-sheet-no-lists-text{font-size:14px;color:var(--fg-secondary);text-align:center;margin:0}.add-sheet-no-lists-btn{background:var(--accent-paprika);color:#fff;border:none;border-radius:var(--radius);padding:10px 20px;font-size:14px;font-weight:600;cursor:pointer;min-height:40px}.add-sheet-no-lists-btn:active{opacity:.85}.planned-sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:flex-end;justify-content:center;z-index:100;padding:0 0 calc(var(--bottom-tab-height) + env(safe-area-inset-bottom,0px))}.planned-sheet{width:100%;max-width:480px;background:var(--bg-elevated);border-top:1px solid var(--border-strong);border-radius:14px 14px 0 0;padding:var(--sp-3) var(--sp-3) calc(var(--sp-4) + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;gap:var(--sp-2)}.planned-sheet-header{display:flex;align-items:center;justify-content:space-between;padding:4px 6px 10px;border-bottom:1px solid var(--border-subtle);margin-bottom:4px}.planned-sheet-title{font-size:17px;font-weight:600}.planned-sheet-close{width:32px;height:32px;background:transparent;color:var(--fg-muted);font-size:14px;border-radius:999px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.planned-sheet-close:active{background:var(--bg-hover)}.planned-sheet-recipe-name{font-size:15px;color:var(--fg-secondary);padding:0 6px var(--sp-1)}.planned-sheet-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-2)}.planned-bucket-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;min-height:80px;border-radius:var(--radius);background:var(--bg-deep);border:1px solid var(--border-subtle);cursor:pointer;transition:background .08s,transform .05s;padding:var(--sp-3) var(--sp-2)}.planned-bucket-btn:hover{background:var(--bg-hover)}.planned-bucket-btn:active{transform:scale(.97)}.planned-bucket-btn:disabled{opacity:.4}.planned-bucket-emoji{font-size:28px;line-height:1}.planned-bucket-label{font-size:14px;font-weight:500;color:var(--fg-primary)}.planned-sheet-cancel{margin-top:4px;background:transparent;color:var(--fg-secondary);font-size:14px;padding:12px;border-radius:10px;text-align:center;cursor:pointer;min-height:44px}.planned-sheet-cancel:active{background:var(--bg-hover);color:var(--fg-primary)}.detail-page{padding:env(safe-area-inset-top,0px) var(--sp-4) var(--sp-4);position:relative}.detail-back{position:absolute;top:calc(env(safe-area-inset-top,0px) + 8px);left:8px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#1a1e24bf;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:var(--fg-primary);border:1px solid var(--border-subtle);border-radius:999px;font-size:18px;z-index:5;cursor:pointer}.detail-back:active{background:var(--bg-hover)}.detail-more{position:absolute;top:calc(env(safe-area-inset-top,0px) + 8px);right:8px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#1a1e24bf;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:var(--fg-primary);border:1px solid var(--border-subtle);border-radius:999px;font-size:22px;font-weight:600;z-index:5;cursor:pointer;letter-spacing:-2px;padding-bottom:6px}.detail-more:active{background:var(--bg-hover)}.more-sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:flex-end;justify-content:center;z-index:100;padding:0 0 calc(var(--bottom-tab-height) + env(safe-area-inset-bottom,0px))}.more-sheet{width:100%;max-width:480px;background:var(--bg-elevated);border-top:1px solid var(--border-strong);border-radius:14px 14px 0 0;padding:var(--sp-3) var(--sp-3) calc(var(--sp-3) + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;gap:6px}.more-sheet-header{display:flex;align-items:center;justify-content:space-between;padding:4px 6px 8px;border-bottom:1px solid var(--border-subtle);margin-bottom:6px}.more-sheet-title{font-size:15px;font-weight:600;color:var(--fg-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.more-sheet-close{width:32px;height:32px;background:transparent;color:var(--fg-muted);font-size:14px;border-radius:999px;flex-shrink:0}.more-sheet-close:active{background:var(--bg-hover)}.more-action{display:flex;align-items:center;gap:12px;background:var(--bg-deep);border:1px solid var(--border-subtle);border-radius:10px;padding:12px 14px;font-size:15px;color:var(--fg-primary);text-align:left;cursor:pointer;min-height:48px;transition:background .08s}.more-action:active{background:var(--bg-hover)}.more-action--danger{color:var(--accent-paprika);border-color:#e2543f4d}.more-action--danger:active{background:#e2543f14}.more-action-icon{font-size:18px;width:24px;text-align:center;flex-shrink:0}.more-action-label{font-weight:500}.more-cancel{margin-top:6px;background:transparent;color:var(--fg-secondary);font-size:14px;padding:12px;border-radius:10px;text-align:center;cursor:pointer;min-height:44px}.more-cancel:active{background:var(--bg-hover);color:var(--fg-primary)}.detail-hero{display:flex;align-items:center;gap:var(--sp-3);padding:56px 0 var(--sp-3)}.detail-emoji{font-size:44px;width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border-radius:var(--radius);flex-shrink:0}.detail-hero-img{width:64px;height:64px;border-radius:var(--radius);object-fit:cover;flex-shrink:0}.detail-hero-meta{flex:1;min-width:0}.detail-title{font-size:24px;font-weight:600;margin:0;letter-spacing:-.015em;line-height:1.15}.detail-meta-line{display:flex;align-items:center;gap:var(--sp-2);font-size:13px;color:var(--fg-secondary);margin-top:var(--sp-1);flex-wrap:wrap}.detail-meta-line.muted{color:var(--fg-muted);font-size:12px}.detail-desc{font-size:14px;color:var(--fg-secondary);margin:var(--sp-2) 0 var(--sp-3);line-height:1.5}.detail-actions{display:flex;flex-direction:row;gap:var(--sp-2);margin-bottom:var(--sp-4);align-items:stretch}.detail-action{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:52px;border-radius:999px;border:1px solid transparent;font-size:15px;font-weight:600;cursor:pointer;padding:0 var(--sp-4);transition:background-color .1s,transform .05s}.detail-action--primary{flex:1;background:var(--accent-paprika);color:var(--bg-deep);box-shadow:0 4px 12px #e2543f40}.detail-action--primary:active{background:var(--accent-paprika-hover);transform:scale(.98)}.detail-action--secondary{width:52px;padding:0;background:var(--bg-elevated);color:var(--fg-primary);border-color:var(--border-strong);font-size:18px;flex-shrink:0}.detail-action--secondary:active{background:var(--bg-hover);transform:scale(.96)}.detail-action-icon{font-size:14px;line-height:1}.detail-action-label{letter-spacing:-.005em}.detail-tabs{display:flex;border-bottom:1px solid var(--border-subtle);margin-bottom:var(--sp-3)}.detail-tab{flex:1;padding:12px 8px;font-size:14px;font-weight:500;color:var(--fg-secondary);border-bottom:2px solid transparent;margin-bottom:-1px}.detail-tab:hover{color:var(--fg-primary)}.detail-tab--active{color:var(--accent-paprika);border-bottom-color:var(--accent-paprika)}.detail-tab-body{padding-bottom:var(--sp-4)}.servings-row{display:flex;align-items:center;justify-content:space-between;padding:0 var(--sp-1) var(--sp-3)}.servings-controls{display:flex;align-items:center;gap:var(--sp-2);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:4px}.srv-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--fg-primary);border-radius:var(--radius-sm)}.srv-btn:hover{background:var(--bg-hover)}.srv-val{min-width:28px;text-align:center;font-weight:600}.ingr-cat{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--fg-muted);padding:var(--sp-2) var(--sp-3) 4px}.ingr-section{font-family:Lora,Georgia,serif;font-size:15px;font-weight:600;color:var(--accent-paprika);padding:var(--sp-3) var(--sp-3) var(--sp-1);border-top:1px solid var(--border-subtle)}.ingr-section+.ingr-row,.ingr-cat+.ingr-row{border-top:none}.ingr-row:first-of-type~.ingr-section:first-of-type,.card>div:first-child>.ingr-section{border-top:none}.ingr-row{display:flex;justify-content:space-between;align-items:center;padding:10px var(--sp-3);min-height:44px;border-top:1px solid var(--border-subtle);font-size:15px}.ingr-row:first-of-type{border-top:none}.step-list{display:flex;flex-direction:column;gap:var(--sp-2)}.step-num{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--accent-paprika);font-weight:600;margin-bottom:6px}.step-text{font-size:15px;line-height:1.5}.history-empty{padding:8px 4px;font-size:15px}.dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:flex-end;justify-content:center;z-index:100;padding:var(--sp-3) var(--sp-3) calc(var(--bottom-tab-height) + env(safe-area-inset-bottom,0px) + var(--sp-3))}@media (min-width: 480px){.dialog-backdrop{align-items:center;padding:var(--sp-3)}}.dialog{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:var(--sp-4);width:100%;max-width:420px;display:flex;flex-direction:column;gap:var(--sp-2)}.dialog-title{font-size:18px;font-weight:600}.dialog-sub{font-size:13px;margin-bottom:var(--sp-2)}.dialog-option{display:flex;align-items:center;gap:var(--sp-2);padding:10px var(--sp-2);border-radius:var(--radius-sm);font-size:15px;cursor:pointer}.dialog-option:hover{background:var(--bg-hover)}.dialog-option input[type=checkbox]{width:20px;height:20px;accent-color:var(--accent-paprika)}.dialog-info{font-size:13px;padding:var(--sp-2) 0}.dialog-actions{display:flex;justify-content:flex-end;gap:var(--sp-2);margin-top:var(--sp-2)}.cost-counter{font-size:12px;color:var(--fg-muted);padding:6px 10px;border-radius:8px;background:var(--bg-elevated);border:1px solid var(--border-subtle);margin-bottom:var(--sp-3)}.cost-counter--warn{color:var(--accent-paprika);border-color:#e2543f4d}.import-page{padding:env(safe-area-inset-top,0px) var(--sp-4) var(--sp-4)}.import-title{font-size:22px;font-weight:600;margin:var(--sp-3) 0}.import-tabs{display:flex;gap:6px;margin-bottom:var(--sp-3);border-bottom:1px solid var(--border-subtle)}.import-tab{padding:10px 14px;background:transparent;color:var(--fg-secondary);border:none;border-bottom:2px solid transparent;cursor:pointer;font:inherit}.import-tab--active{color:var(--accent-paprika);border-bottom-color:var(--accent-paprika)}.import-textarea,.import-input{width:100%;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:10px;color:var(--fg-primary);padding:var(--sp-3);font:inherit;box-sizing:border-box}.import-textarea:focus,.import-input:focus{outline:none;border-color:var(--accent-paprika)}.import-photo-label{display:block;padding:24px;text-align:center;background:var(--bg-elevated);border:1px dashed var(--border-strong);border-radius:10px;cursor:pointer;color:var(--fg-secondary)}.import-error{color:var(--accent-paprika);margin-top:var(--sp-2);font-size:14px}.import-submit{width:100%;padding:14px;margin-top:var(--sp-3);background:var(--accent-paprika);color:var(--bg-deep);border:none;border-radius:999px;font:inherit;font-weight:600;cursor:pointer}.import-submit:disabled{opacity:.6;cursor:not-allowed}.cls-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:stretch;justify-content:center;z-index:100}.cls-sheet{width:100%;max-width:480px;height:100dvh;background:var(--bg-elevated);border-left:1px solid var(--border-subtle);border-right:1px solid var(--border-subtle);padding:calc(env(safe-area-inset-top,0px) + var(--sp-2)) var(--sp-3) calc(env(safe-area-inset-bottom,0px) + var(--sp-2));display:flex;flex-direction:column;gap:var(--sp-2);animation:ais-slide-up .2s ease-out;overflow-y:auto}@media (min-width: 768px){.cls-sheet{max-width:720px}}.cls-header{display:flex;align-items:center;justify-content:space-between;padding:2px 4px 8px;border-bottom:1px solid var(--border-subtle);flex-shrink:0}.cls-title{font-family:Lora,Georgia,serif;font-size:17px;font-weight:600;color:var(--fg-primary)}.cls-close{width:40px;height:40px;background:var(--bg-deep);color:var(--fg-secondary);border:1px solid var(--border-subtle);font-size:20px;font-weight:500;line-height:1;border-radius:999px;flex-shrink:0;display:flex;align-items:center;justify-content:center;cursor:pointer}.cls-close:active{background:var(--bg-hover);color:var(--accent-paprika);border-color:var(--accent-paprika)}.cls-section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--fg-muted);padding:4px 4px 0;flex-shrink:0}.cls-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;flex-shrink:0}.cls-market-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:12px 8px;background:var(--bg-deep);border:1.5px solid var(--border-subtle);border-radius:10px;cursor:pointer;min-height:72px;transition:border-color .12s,background-color .12s}.cls-market-btn:active:not(:disabled){background:var(--bg-hover);border-color:var(--accent-paprika)}.cls-market-btn--disabled{opacity:.45;cursor:not-allowed}.cls-market-emoji{font-size:24px;line-height:1}.cls-market-label{font-size:12px;font-weight:600;color:var(--fg-primary);text-align:center}.cls-market-active-hint{font-size:9px;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.04em}.cls-divider{height:1px;background:var(--border-subtle);margin:4px 0;flex-shrink:0}.cls-freitext-row{display:flex;gap:6px;align-items:center;flex-shrink:0}.cls-freitext-input{flex:1;min-width:0}.cls-freitext-ok{flex-shrink:0}.cls-toast{background:var(--bg-deep);border:1px solid var(--border-strong);border-radius:8px;padding:10px 14px;font-size:13px;color:var(--fg-primary);text-align:center;flex-shrink:0;animation:ais-slide-up .15s ease-out}.mis-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:flex-end;justify-content:center;z-index:110}.mis-sheet{width:100%;max-width:480px;background:var(--bg-elevated);border-top:1px solid var(--border-subtle);border-left:1px solid var(--border-subtle);border-right:1px solid var(--border-subtle);border-radius:16px 16px 0 0;padding:var(--sp-2) var(--sp-3) calc(env(safe-area-inset-bottom,0px) + var(--sp-3));display:flex;flex-direction:column;gap:var(--sp-2);animation:mis-slide-up .2s ease-out}@media (min-width: 768px){.mis-sheet{max-width:720px}}@keyframes mis-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.mis-header{display:flex;align-items:center;justify-content:space-between;padding:2px 4px 8px;border-bottom:1px solid var(--border-subtle)}.mis-title{font-family:Lora,Georgia,serif;font-size:17px;font-weight:600;color:var(--fg-primary)}.mis-close{width:40px;height:40px;background:var(--bg-deep);color:var(--fg-secondary);border:1px solid var(--border-subtle);font-size:20px;font-weight:500;line-height:1;border-radius:999px;flex-shrink:0;display:flex;align-items:center;justify-content:center;cursor:pointer}.mis-close:active{background:var(--bg-hover);color:var(--accent-paprika);border-color:var(--accent-paprika)}.mis-item-preview{font-size:13px;color:var(--fg-secondary);background:var(--bg-deep);border:1px solid var(--border-subtle);border-radius:8px;padding:8px 12px}.mis-lists{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.mis-list-btn{width:100%;display:flex;align-items:center;gap:10px;background:var(--bg-deep);color:var(--fg-primary);border:1.5px solid var(--border-subtle);border-radius:10px;padding:12px 14px;font-size:15px;font-weight:500;cursor:pointer;text-align:left;transition:border-color .1s,background-color .1s;min-height:48px}.mis-list-btn:active{background:var(--bg-hover);border-color:var(--accent-saffron)}.mis-list-emoji{font-size:20px;line-height:1;flex-shrink:0}.mis-list-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mis-list-meta{font-size:12px;color:var(--fg-muted);flex-shrink:0}.shop-hero{padding:4px var(--sp-3) 6px;background:var(--bg-deep)}.shop-hero-row{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3)}.shop-title{font-family:Lora,Georgia,serif;font-size:18px;font-weight:700;letter-spacing:-.015em;margin:0;line-height:1.1;color:var(--fg-primary)}.shop-finish-fab{width:36px;height:36px;border-radius:50%;background:var(--accent-basil);color:#fff;border:none;font-size:18px;font-weight:700;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;box-shadow:0 1px 2px #0003}.shop-finish-fab:active{opacity:.85;transform:scale(.96)}.shop-body--with-add-bar{padding-bottom:76px}.shop-add-bar{position:fixed;left:0;right:0;bottom:calc(env(safe-area-inset-bottom,0) + var(--bottom-tab-height));max-width:480px;margin:0 auto;background:var(--bg-elevated);border-top:1px solid var(--border-subtle);padding:8px 12px;z-index:30;box-shadow:0 -2px 8px #00000026}@media (min-width: 768px){.shop-add-bar{max-width:720px}}.shop-add-bar-trigger{width:100%;background:var(--accent-paprika);color:#fff;border:none;border-radius:var(--radius);padding:12px;font-size:16px;font-weight:600;cursor:pointer;min-height:44px}.shop-add-bar-trigger:active{opacity:.85}.shop-add-bar-form{display:flex;gap:6px;align-items:center}.shop-add-bar-cancel{background:none;border:none;color:var(--fg-muted);font-size:22px;line-height:1;padding:8px 10px;cursor:pointer;flex-shrink:0}.shop-add-bar-cancel:active{color:var(--accent-paprika)}.shop-suggestions{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;padding-bottom:8px;margin:0 -4px}.shop-suggestions::-webkit-scrollbar{display:none}.shop-suggestion{flex-shrink:0;background:var(--bg-deep);color:var(--fg-primary);border:1px solid var(--border-subtle);border-radius:14px;padding:6px 11px;font-size:13px;cursor:pointer;white-space:nowrap;min-height:28px}.shop-suggestion:active{background:var(--accent-paprika);color:#fff;border-color:var(--accent-paprika)}.shop-add-fab{width:36px;height:36px;border-radius:999px;background:var(--accent-paprika);color:var(--bg-deep);font-size:20px;font-weight:500;display:flex;align-items:center;justify-content:center;box-shadow:0 3px 8px #e2543f40;border:none;flex-shrink:0;line-height:1;padding-bottom:2px}.shop-add-fab:active{background:var(--accent-paprika-hover);transform:scale(.96)}.shop-meta{font-size:11px;color:var(--fg-secondary);margin-top:2px}.shop-meta-total{color:var(--fg-muted)}.shop-progress-dots{display:flex;gap:2px;margin-top:4px}.spd{flex:1;height:3px;border-radius:999px;background:var(--border-subtle);transition:background-color .2s ease}.spd--done{background:var(--accent-paprika)}.shop-progress-bar{height:3px;background:var(--border-subtle);border-radius:999px;overflow:hidden;margin-top:6px}.shop-progress-bar-fill{height:100%;background:var(--accent-paprika);transition:width .3s ease}.shop-body{padding:var(--sp-1) var(--sp-3) var(--sp-3)}.shop-add{display:flex;gap:var(--sp-2);align-items:center;margin-bottom:var(--sp-3);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:var(--sp-2)}.shop-add-input{background:var(--bg-deep);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:10px 12px;font-size:16px;color:var(--fg-primary);min-height:40px}.shop-add-input:focus{outline:none;border-color:var(--accent-paprika)}.shop-add-name{flex:1;min-width:0}.shop-add-qty{width:90px}.shop-cat{margin-bottom:var(--sp-1)}.shop-cat-head{display:flex;align-items:center;gap:4px;font-family:Lora,Georgia,serif;font-size:12px;font-weight:600;margin:0 0 2px 2px;letter-spacing:-.005em;text-transform:uppercase;opacity:.85}.shop-cat-head--basil{color:var(--accent-basil)}.shop-cat-head--paprika{color:var(--accent-paprika)}.shop-cat-head--saffron{color:var(--accent-saffron)}.shop-cat-head--muted{color:var(--fg-secondary)}.shop-cat-emoji{font-size:16px;line-height:1}.shop-cards{display:flex;flex-direction:column;gap:2px}.shop-card{display:flex;align-items:center;gap:7px;padding:2px 7px;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:6px;min-height:30px;cursor:pointer;transition:background-color .08s,border-color .08s}.shop-card:active{background:var(--bg-hover)}.shop-card--basil{border-color:#65b37738}.shop-card--paprika{border-color:#e2543f38}.shop-card--saffron{border-color:#d4a24233}.shop-card--muted{border-color:var(--border-subtle)}.checkbox{width:18px;height:18px;border:1.5px solid var(--border-strong);border-radius:5px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;background:transparent;color:var(--accent-basil);font-size:12px;font-weight:700;line-height:1;transition:background-color .1s,border-color .1s}.checkbox--checked{background:#65b3772e;border-color:var(--accent-basil)}.shop-card--basil .checkbox{border-color:#65b3778c}.shop-card--paprika .checkbox{border-color:#e2543f8c}.shop-card--saffron .checkbox{border-color:#d4a2428c}.shop-card-edit,.shop-card-delete{background:none;border:none;color:var(--fg-secondary);line-height:1;padding:6px 9px;cursor:pointer;flex-shrink:0;opacity:.85}.shop-card-edit{font-size:18px}.shop-card-delete{font-size:22px}.shop-card-edit:active{opacity:1;color:var(--accent-saffron)}.shop-card-delete:active{opacity:1;color:var(--accent-paprika)}.shop-card-body{flex:1;min-width:0}.shop-card-name{font-size:13px;font-weight:600;color:var(--fg-primary);letter-spacing:-.005em;line-height:1.2}.shop-card-src{font-size:10px;color:var(--fg-muted);font-style:italic;margin-top:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3}.shop-card-qty{font-size:12px;color:var(--fg-primary);font-weight:500;flex-shrink:0;text-align:right;min-width:44px}.shop-card--done{background:var(--bg-deep);border-color:var(--border-subtle);opacity:.75}.shop-card-name--done{text-decoration:line-through;color:var(--fg-muted);font-weight:500}.shop-card-qty--done{color:var(--fg-muted);font-weight:400}.shop-finish{padding-top:var(--sp-3)}.shop-pills{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;margin:0 -4px;padding:6px 4px 2px}.shop-pills::-webkit-scrollbar{display:none}.shop-pill{display:flex;align-items:center;gap:4px;flex-shrink:0;background:var(--bg-deep);color:var(--fg-primary);border:1.5px solid var(--border-subtle);border-radius:999px;padding:5px 10px;font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;min-height:30px;transition:border-color .12s,background-color .12s}.shop-pill:active{background:var(--bg-hover)}.shop-pill--active{border-color:var(--accent-paprika);background:#e2543f14;color:var(--accent-paprika);font-weight:600}.shop-pill--add{font-size:18px;font-weight:400;padding:4px 11px;border-style:dashed;color:var(--fg-secondary)}.shop-pill--add:active{border-color:var(--accent-paprika);color:var(--accent-paprika)}.shop-pill-emoji{font-size:13px;line-height:1}.shop-pill-label{max-width:100px;overflow:hidden;text-overflow:ellipsis}.shop-pill-count{font-size:10px;background:var(--bg-hover);border-radius:999px;padding:1px 5px;color:var(--fg-secondary)}.shop-pill--active .shop-pill-count{background:#e2543f26;color:var(--accent-paprika)}.shop-pill-check{font-size:11px;color:var(--accent-basil);font-weight:700}.shop-empty{padding:var(--sp-5) var(--sp-4);text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--sp-2)}.shop-empty-emoji{font-size:40px;opacity:.6}.shop-empty-title{font-family:Lora,serif;font-size:18px;font-weight:600;color:var(--fg-secondary)}.shop-empty-sub{font-size:13px;color:var(--fg-muted);line-height:1.5;max-width:260px}.shop-empty-cta{background:var(--accent-paprika);color:#fff;border:none;border-radius:var(--radius);padding:12px 24px;font-size:15px;font-weight:600;cursor:pointer;min-height:44px;margin-top:var(--sp-1)}.shop-empty-cta:active{opacity:.85}.shop-cat-stats{display:flex;gap:5px;overflow-x:auto;scrollbar-width:none;margin:0 -4px;padding:4px 4px 6px}.shop-cat-stats::-webkit-scrollbar{display:none}.shop-cat-stat{display:inline-flex;align-items:center;gap:3px;flex-shrink:0;background:var(--bg-deep);color:var(--fg-primary);border:1.5px solid var(--border-subtle);border-radius:999px;padding:3px 9px 3px 6px;font-size:11px;font-weight:500;cursor:pointer;white-space:nowrap;min-height:26px;transition:border-color .12s,opacity .15s}.shop-cat-stat:active{background:var(--bg-hover)}.shop-cat-stat--basil{border-color:#65b37766}.shop-cat-stat--paprika{border-color:#e2543f59}.shop-cat-stat--saffron{border-color:#d4a24259}.shop-cat-stat--muted{border-color:var(--border-subtle)}.shop-cat-stat--done{opacity:.7;border-color:var(--accent-basil)!important}.shop-cat-stat-emoji{font-size:13px;line-height:1}.shop-cat-stat-name{max-width:80px;overflow:hidden;text-overflow:ellipsis}.shop-cat-stat-count{font-size:10px;color:var(--fg-secondary);margin-left:2px}.shop-cat-stat-check{font-size:10px;color:var(--accent-basil);font-weight:700;margin-left:1px}.shop-cat-head{scroll-margin-top:80px}.shop-row-wrap{position:relative;overflow:hidden;border-radius:6px}.shop-row-bg{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;padding:0 16px;pointer-events:none;border-radius:6px}.shop-row-bg-right{background:var(--accent-paprika);justify-content:flex-end}.shop-row-bg-left{background:var(--accent-saffron);justify-content:flex-start}.shop-row-bg-icon{font-size:22px;color:#fff}.shop-agg{gap:0}.shop-agg-check-area{display:flex;align-items:center;justify-content:center;padding:6px 7px 6px 0;background:transparent;border:none;cursor:pointer;flex-shrink:0}.shop-agg-check-area:active .checkbox{border-color:var(--accent-basil)}.shop-agg-name{flex:1;min-width:0;font-size:13px;font-weight:600;color:var(--fg-primary);letter-spacing:-.005em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shop-agg-qty{font-size:12px;color:var(--fg-primary);font-weight:600;flex-shrink:0;margin-left:6px}.shop-agg-count{font-size:11px;color:var(--fg-muted);flex-shrink:0;margin-left:4px;background:var(--bg-deep);border-radius:999px;padding:1px 5px}.shop-agg-toggle{background:transparent;border:none;color:var(--fg-secondary);font-size:16px;padding:6px 8px;cursor:pointer;flex-shrink:0;line-height:1}.shop-agg-toggle:active{color:var(--fg-primary)}.shop-row-wrap--sub{margin-left:10px}.sh-hero{padding:16px;display:flex;flex-direction:column;gap:4px;position:relative;background:var(--bg-deep)}.sh-back{position:absolute;left:12px;top:16px;background:none;border:none;color:inherit;font-size:1.5rem;cursor:pointer}.sh-title{font-size:1.3rem;margin:0 0 0 32px}.sh-sub{margin-left:32px;font-size:.85rem;color:var(--fg-secondary)}.muted{color:var(--fg-secondary)}.loading{padding:48px 16px;text-align:center;color:var(--fg-secondary)}.sh-body{padding:0 16px 80px}.sh-empty{padding:48px 16px;text-align:center;color:var(--fg-muted)}.sh-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.sh-row{width:100%;text-align:left;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:12px;padding:14px;color:inherit;cursor:pointer}.sh-row:active{background:var(--bg-hover)}.sh-row-label{font-size:1rem;font-weight:500;color:var(--fg-primary)}.sh-row-meta{font-size:.85rem;margin-top:4px;color:var(--fg-secondary)}.sh-cat{margin-top:16px}.sh-cat-head{font-size:.95rem;margin:0 0 8px;color:var(--fg-muted)}.sh-items{list-style:none;padding:0;margin:0;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:12px;overflow:hidden}.sh-item{display:flex;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border-subtle);color:var(--fg-primary)}.sh-item:last-child{border-bottom:none}.sh-item--checked{opacity:.5;text-decoration:line-through}.sh-item-name{font-size:.9rem}.sh-item-qty{font-size:.85rem;color:var(--fg-secondary)}.pl-hero{padding:6px var(--sp-4) 8px;background:var(--bg-deep)}.pl-hero-row{display:flex;align-items:baseline;justify-content:space-between;gap:var(--sp-3)}.pl-title{font-family:Lora,Georgia,serif;font-size:22px;font-weight:700;letter-spacing:-.015em;margin:0;line-height:1.1;color:var(--fg-primary)}.pl-meta{font-size:12px;color:var(--fg-muted)}.pl-sub{font-size:11px;color:var(--fg-secondary);margin-top:2px}.pl-body{padding:var(--sp-2) var(--sp-4) var(--sp-4)}.pl-cat{margin-bottom:var(--sp-3)}.pl-cat-head{display:flex;align-items:center;gap:6px;font-family:Lora,Georgia,serif;font-size:14px;font-weight:600;margin:0 0 4px 2px;letter-spacing:-.005em}.pl-cat-head--paprika{color:var(--accent-paprika)}.pl-cat-head--saffron{color:var(--accent-saffron)}.pl-cat-head--basil{color:var(--accent-basil)}.pl-cat-head--muted{color:var(--fg-secondary)}.pl-cat-emoji{font-size:14px;line-height:1}.pl-cat-count{margin-left:auto;font-size:11px;color:var(--fg-muted);font-weight:500}.pl-empty{font-size:11px;color:var(--fg-muted);font-style:italic;padding:6px 2px 4px}.pl-cards{display:flex;flex-direction:column;gap:3px}.pl-card{display:flex;align-items:center;gap:10px;padding:6px 10px;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:8px;min-height:48px;cursor:pointer;transition:background-color .08s,border-color .08s}.pl-card:active{background:var(--bg-hover)}.pl-card--paprika{border-color:#e2543f38}.pl-card--saffron{border-color:#d4a24233}.pl-card--basil{border-color:#65b37738}.pl-card--muted{border-color:var(--border-subtle)}.pl-card-emoji{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-deep);border-radius:6px;font-size:18px;flex-shrink:0}.pl-card-body{flex:1;min-width:0}.pl-card-name{font-family:Lora,Georgia,serif;font-size:15px;font-weight:600;color:var(--fg-primary);letter-spacing:-.005em;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pl-card-meta{font-size:11px;color:var(--fg-secondary);display:flex;gap:6px;margin-top:1px;flex-wrap:nowrap;overflow:hidden}.pl-card-right{display:flex;align-items:center;gap:6px;flex-shrink:0}.pl-remove{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;color:var(--fg-muted);font-size:13px;border-radius:6px}.pl-remove:active{background:var(--bg-hover);color:var(--accent-paprika)}.pl-drop-over{outline:2px dashed var(--saffron);outline-offset:4px;border-radius:12px}.catalog-suggestions{padding:var(--sp-3);display:flex;flex-direction:column;gap:var(--sp-3)}.catalog-pair{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:10px;padding:var(--sp-3)}.catalog-pair-cards{display:grid;grid-template-columns:1fr auto 1fr;gap:var(--sp-2);align-items:center}.catalog-card{display:flex;flex-direction:column;padding:10px;background:var(--bg-deep);border-radius:8px}.catalog-card .muted{font-size:12px;color:var(--fg-muted)}.catalog-vs{color:var(--fg-muted)}.catalog-actions{display:flex;gap:8px;margin-top:var(--sp-2);flex-wrap:wrap}.catalog-actions button{padding:8px 12px;background:var(--bg-deep);border:1px solid var(--border-subtle);border-radius:8px;color:var(--fg-primary);cursor:pointer;flex:1;min-width:120px}.catalog-dismiss{color:var(--fg-muted)}.catalog-empty{padding:var(--sp-4);text-align:center;color:var(--fg-secondary)}.sync-conflicts{padding:16px}.sync-conflicts-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.sync-conflicts-head h2{margin:0;font-size:1.1rem;color:var(--fg-primary)}.sync-refresh{background:none;border:1px solid var(--border-strong);color:var(--fg-secondary);padding:4px 10px;border-radius:8px;cursor:pointer;font-size:13px}.sync-refresh:active{background:var(--bg-hover)}.sync-loading,.sync-empty{padding:32px;text-align:center;color:var(--fg-muted)}.sync-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.sync-row{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:12px;padding:12px;display:flex;gap:12px;align-items:flex-start}.sync-row-body{flex:1;min-width:0}.sync-row-label{font-size:.95rem;color:var(--fg-primary)}.sync-row-meta{font-size:.85rem;color:var(--fg-secondary);margin-top:2px}.sync-row-error{font-size:.8rem;color:var(--accent-paprika);margin-top:4px;font-family:ui-monospace,monospace;word-break:break-all}.sync-row-date{font-size:.75rem;color:var(--fg-muted);margin-top:4px}.sync-row-actions{display:flex;flex-direction:column;gap:6px;flex-shrink:0}.sync-btn{padding:6px 12px;border-radius:8px;border:1px solid var(--border-strong);background:none;color:var(--fg-primary);cursor:pointer;font-size:.85rem;white-space:nowrap}.sync-btn--retry{border-color:var(--accent-basil);color:var(--accent-basil)}.sync-btn--retry:active{background:#65b3771a}.sync-btn--discard{border-color:var(--accent-paprika);color:var(--accent-paprika)}.sync-btn--discard:active{background:#e2543f1a}.st-hero{padding:6px var(--sp-4) 8px;background:var(--bg-deep)}.st-hero-row{display:flex;align-items:baseline;justify-content:space-between;gap:var(--sp-3)}.st-title{font-family:Lora,Georgia,serif;font-size:22px;font-weight:700;letter-spacing:-.015em;margin:0;line-height:1.1;color:var(--fg-primary)}.st-meta{font-size:11px;color:var(--fg-muted)}.st-sub{font-size:11px;color:var(--fg-secondary);margin-top:2px}.st-body{padding:var(--sp-2) var(--sp-4) var(--sp-4)}.st-cat{margin-bottom:var(--sp-3)}.st-cat-head{display:flex;align-items:center;gap:6px;font-family:Lora,Georgia,serif;font-size:14px;font-weight:600;margin:0 0 4px 2px;letter-spacing:-.005em}.st-cat-head--paprika{color:var(--accent-paprika)}.st-cat-head--basil{color:var(--accent-basil)}.st-cat-head--saffron{color:var(--accent-saffron)}.st-cat-head--muted{color:var(--fg-secondary)}.st-cat-emoji{font-size:14px;line-height:1}.st-cards{display:flex;flex-direction:column;gap:3px}.st-card{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:8px;min-height:48px;cursor:pointer;text-align:left;width:100%;font-family:inherit;color:inherit;transition:background-color .08s}.st-card:active{background:var(--bg-hover)}.st-card--paprika{border-color:#e2543f2e}.st-card--basil{border-color:#65b3772e}.st-card--saffron{border-color:#d4a24229}.st-card--muted{border-color:var(--border-subtle)}.st-card--accent{background:#e2543f0f}.st-card--info{cursor:default}.st-card--info:active{background:var(--bg-elevated)}.st-card-body{flex:1;min-width:0}.st-card-label{font-size:14px;font-weight:600;color:var(--fg-primary);line-height:1.2}.st-card-meta{font-size:11px;color:var(--fg-secondary);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.st-card-chev{font-size:18px;color:var(--fg-muted);font-weight:300;flex-shrink:0}.st-logout{background:transparent;color:var(--accent-paprika);border:1px solid var(--border-strong);border-radius:999px;padding:12px 16px;font-size:14px;font-weight:600;width:100%;margin:var(--sp-4) 0 var(--sp-2);min-height:44px}.st-logout:active{background:#e2543f14;border-color:#e2543f66}.st-footer{font-size:10px;color:var(--fg-muted);text-align:center;padding:var(--sp-2) 0 0}.st-sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:flex-end;justify-content:center;z-index:100;padding:0 0 calc(var(--bottom-tab-height) + env(safe-area-inset-bottom,0px))}.st-sheet{width:100%;max-width:480px;background:var(--bg-elevated);border-top:1px solid var(--border-strong);border-radius:14px 14px 0 0;padding:var(--sp-4) var(--sp-4) calc(var(--sp-4) + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;gap:8px;max-height:80vh;overflow-y:auto}.st-sheet-title{font-size:18px;font-weight:600;margin-bottom:4px}.st-sheet-sub{font-size:13px;color:var(--fg-secondary);line-height:1.5;margin-bottom:var(--sp-3)}.st-link{display:flex;align-items:center;gap:8px;background:var(--bg-deep);border:1px solid var(--border-strong);border-radius:8px;padding:10px 12px;min-height:44px}.st-link-url{flex:1;font-family:ui-monospace,monospace;font-size:12px;color:var(--fg-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.st-link-copy{background:var(--accent-paprika);color:var(--bg-deep);font-size:12px;font-weight:600;padding:6px 12px;border-radius:999px;flex-shrink:0}.st-link-copy:active{background:var(--accent-paprika-hover)}.st-share-row{display:flex;gap:8px;margin-top:var(--sp-2)}.st-share-btn{flex:1;background:var(--bg-deep);border:1px solid var(--border-strong);color:var(--fg-primary);padding:12px;border-radius:8px;font-size:14px;font-weight:500;min-height:44px}.st-share-btn:active{background:var(--bg-hover)}.st-sheet-hint{font-size:11px;color:var(--fg-muted);font-style:italic;margin-top:var(--sp-3);line-height:1.5}.st-sheet-actions{display:flex;justify-content:flex-end;margin-top:var(--sp-2)}.settings-tabs{display:flex;gap:6px;margin-bottom:var(--sp-3);border-bottom:1px solid var(--border-subtle);padding:0 var(--sp-4)}.settings-tabs button{padding:10px 14px;background:transparent;color:var(--fg-secondary);border:none;border-bottom:2px solid transparent;cursor:pointer;font-family:inherit;font-size:14px}.settings-tabs button.active{color:var(--accent-paprika);border-bottom-color:var(--accent-paprika)}.settings-badge{display:inline-block;min-width:20px;padding:2px 6px;border-radius:10px;background:var(--accent-paprika);color:var(--bg-deep);font-size:11px;font-weight:600;margin-left:6px}.cooking-shell{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-deep);display:flex;flex-direction:column;z-index:50;max-width:480px;margin:0 auto;overflow:hidden}@media (min-width: 768px){.cooking-shell{max-width:720px;box-shadow:0 0 0 1px var(--border-subtle)}}.cooking-header{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);border-bottom:1px solid var(--border-subtle)}.cooking-back{width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--fg-secondary);background:transparent;border-radius:var(--radius);flex-shrink:0}.cooking-back:active{background:var(--bg-hover);color:var(--fg-primary)}.cooking-title-wrap{flex:1;min-width:0}.cooking-title-recipe{font-size:16px;font-weight:600;letter-spacing:-.005em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cooking-progress-line{display:flex;align-items:center;gap:8px;margin-top:2px}.cooking-step-count{font-size:12px;color:var(--fg-secondary);white-space:nowrap}.cooking-progress-bar{display:inline-flex;gap:3px;flex:1;margin:0 4px}.pdot{flex:1;height:3px;background:var(--border-subtle);border-radius:2px}.pdot--done{background:var(--accent-basil)}.pdot--current{background:var(--accent-paprika)}.cooking-pct{font-size:12px;color:var(--fg-secondary);min-width:36px;text-align:right}.tbanner{position:relative;background:var(--bg-elevated);border-bottom:1px solid var(--border-subtle);overflow:hidden;flex-shrink:0}.tbanner--running{background:linear-gradient(180deg,#1f1612,#1a1e24);border-bottom-color:#e2543f66;box-shadow:0 2px 12px #e2543f2e}.tbanner--done{background:linear-gradient(180deg,#15201a,#1a1e24);border-bottom-color:#65b37773;box-shadow:0 2px 16px #65b37738;animation:tbanner-pulse 1.2s ease-in-out infinite}@keyframes tbanner-pulse{0%,to{box-shadow:0 2px 16px #65b37738}50%{box-shadow:0 2px 24px #65b37773}}.tbanner-fill{position:absolute;inset:0 auto 0 0;background:#e2543f1f;transition:width 1s linear;pointer-events:none}.tbanner--done .tbanner-fill{background:#65b3772e;width:100%!important}.tbanner-content{position:relative;display:flex;align-items:center;justify-content:space-between;padding:12px var(--sp-3);gap:var(--sp-3)}.tbanner-left{display:flex;align-items:center;gap:var(--sp-3);flex:1;min-width:0}.tbanner-icon{font-size:24px;line-height:1}.tbanner-text{display:flex;flex-direction:column;min-width:0}.tbanner-time{font-size:28px;font-weight:700;letter-spacing:-.02em;line-height:1.05;color:var(--fg-primary)}.tbanner--running .tbanner-time{color:var(--accent-paprika)}.tbanner--done .tbanner-time{color:var(--accent-basil)}.tbanner-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--fg-secondary);margin-top:1px}.tbanner--done .tbanner-label{color:var(--accent-basil);font-weight:600}.tbanner-actions{display:flex;gap:6px;align-items:center;flex-shrink:0}.tbanner-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-deep);color:var(--fg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius);font-size:14px;font-weight:600}.tbanner-btn:active{background:var(--bg-hover)}.tbanner-btn--primary{background:var(--accent-paprika);color:var(--bg-deep);border-color:transparent}.tbanner-btn--primary:active{background:var(--accent-paprika-hover)}.tbanner-btn--reset{color:var(--fg-secondary)}.tbanner-btn--cancel{color:var(--fg-muted);font-size:12px}.tbanner--done .tbanner-btn--primary{background:var(--accent-basil);color:var(--bg-deep)}.cooking-body{flex:1;overflow-y:auto;padding-bottom:8px}.cooking-tab-body{padding:var(--sp-3) var(--sp-3) var(--sp-4);display:flex;flex-direction:column;gap:var(--sp-3)}.step-card{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:12px;padding:var(--sp-3) var(--sp-4)}.step-card--current{border-color:var(--border-strong)}.step-card--next{opacity:.78}.step-card-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--accent-paprika);margin-bottom:6px}.step-card--next .step-card-label{color:var(--fg-muted)}.step-card-title{font-size:22px;font-weight:600;line-height:1.25;letter-spacing:-.005em;color:var(--fg-primary)}.step-card--next .step-card-title{font-size:18px}.step-card-body{font-size:14px;color:var(--fg-secondary);line-height:1.5;margin-top:6px}.step-card-ings{margin-top:var(--sp-2)}.step-card-ings-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--fg-muted);margin-bottom:5px}.step-card-ings-list{display:flex;flex-wrap:wrap;gap:4px}.step-ing-pill{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;background:var(--bg-deep);border:1px solid var(--border-subtle);border-radius:999px;font-size:12px}.step-card--current .step-ing-pill{background:#e2543f0f;border-color:#e2543f33}.step-ing-pill-name{color:var(--fg-primary);font-weight:500}.step-card--next .step-ing-pill-name{color:var(--fg-secondary)}.step-ing-pill-qty{color:var(--fg-muted);font-size:11px}.step-card--current .step-ing-pill-qty{color:var(--accent-paprika)}.step-card-badges{display:flex;gap:6px;margin-top:var(--sp-2);flex-wrap:wrap}.step-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:var(--bg-deep);border:1px solid var(--border-subtle);border-radius:var(--radius-full);font-size:12px;color:var(--fg-secondary)}.step-card--current .step-badge--time{background:#e2543f1f;border-color:#e2543f4d;color:var(--accent-paprika)}.step-badge--button{cursor:pointer;font-weight:600;transition:background-color .1s,color .1s}.step-card--current .step-badge--button:active{background:var(--accent-paprika);color:var(--bg-deep)}.cooking-final-note{background:var(--bg-elevated);border:1px dashed var(--border-strong);border-radius:12px;padding:var(--sp-3) var(--sp-4);color:var(--fg-secondary);font-size:14px}.cooking-final-hint-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--accent-basil);margin-bottom:4px}.cooking-action-row{display:flex;gap:var(--sp-2);align-items:center;justify-content:space-between;padding:var(--sp-2) 0}.cooking-nav{background:var(--bg-elevated);color:var(--fg-secondary);border:1px solid var(--border-subtle);border-radius:999px;font-size:14px;font-weight:500;padding:0 18px;height:44px;flex-shrink:0;min-width:92px}.cooking-nav:disabled{opacity:.4}.cooking-nav:not(:disabled):active{background:var(--bg-hover);color:var(--fg-primary)}.cooking-confirm-circle{flex:1;height:64px;border-radius:999px;background:linear-gradient(180deg,var(--accent-basil) 0%,#4ea65f 100%);color:var(--bg-deep);display:flex;flex-direction:column;align-items:center;justify-content:center;font-weight:700;box-shadow:0 4px 16px #65b37740;border:none;max-width:160px;margin:0 auto}.cooking-confirm-circle:active{transform:scale(.97);box-shadow:0 2px 8px #65b37733}.cooking-confirm-icon{font-size:22px;line-height:1}.cooking-confirm-label{font-size:12px;letter-spacing:.02em;margin-top:2px}.cooking-section-head{display:flex;justify-content:space-between;align-items:center;padding:var(--sp-2) 4px}.cooking-section-title{font-family:Lora,Georgia,serif;font-size:16px;font-weight:600;color:var(--fg-primary)}.cooking-section-meta{font-size:13px;color:var(--fg-muted)}.cooking-step-list{list-style:none;padding:0;margin:0;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:12px;overflow:hidden}.cstep{display:flex;align-items:center;gap:var(--sp-3);padding:12px var(--sp-3);min-height:44px;border-bottom:1px solid var(--border-subtle);cursor:pointer;transition:background-color .08s ease}.cstep:last-child{border-bottom:none}.cstep:active{background:var(--bg-hover)}.cstep-icon{width:26px;height:26px;display:flex;align-items:center;justify-content:center;background:var(--bg-hover);color:var(--fg-secondary);border-radius:var(--radius-full);font-size:12px;font-weight:600;flex-shrink:0}.cstep-text{flex:1;font-size:14px;color:var(--fg-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cstep-time{font-size:12px;color:var(--fg-muted);background:var(--bg-deep);padding:3px 8px;border-radius:var(--radius-full);flex-shrink:0}.cstep--done .cstep-icon{background:var(--accent-basil);color:var(--bg-deep)}.cstep--done .cstep-text{color:var(--fg-muted);text-decoration:line-through}.cstep--current{background:#e2543f0f}.cstep--current .cstep-icon{background:var(--accent-paprika);color:var(--bg-deep)}.cstep--current .cstep-text{font-weight:600}.tbanner-multi{display:flex;gap:6px;padding:8px 12px;background:var(--bg-elevated);border-bottom:1px solid var(--border-subtle);flex-shrink:0}.tbanner-multi--1 .tslot{flex:1}.tbanner-multi--2 .tslot,.tbanner-multi--3 .tslot{flex:1;min-width:0;max-width:110px;padding:8px;font-size:.9rem}.tslot{display:flex;align-items:center;gap:6px;background:var(--bg-deep);border-radius:8px;padding:10px}.tslot-time{font-size:1.1rem;font-weight:600;min-width:50px}.tslot-btn{min-width:32px;padding:6px 10px;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius);color:var(--fg-primary);font-weight:600}.tslot-x{min-width:24px;padding:4px 6px;background:none;border:none;color:var(--fg-muted);cursor:pointer;font-size:12px}.tslot--ringing{animation:tslotPulse .6s infinite alternate}@keyframes tslotPulse{0%{background:var(--bg-deep)}to{background:var(--accent-paprika)}}.qt{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:12px;padding:var(--sp-3);margin-top:var(--sp-2)}.qt-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--sp-2)}.qt-title{font-size:13px;font-weight:600;color:var(--fg-secondary);text-transform:uppercase;letter-spacing:.06em}.qt-reset{background:transparent;font-size:12px;color:var(--accent-paprika);padding:4px 8px;border-radius:var(--radius-sm)}.qt-chips{display:grid;grid-template-columns:repeat(5,1fr) auto;gap:6px}.qt-chip{padding:10px 6px;background:var(--bg-deep);border:1px solid var(--border-subtle);border-radius:var(--radius);font-size:13px;font-weight:500;color:var(--fg-primary);min-height:40px}.qt-chip:active{background:var(--accent-paprika);color:var(--bg-deep);border-color:var(--accent-paprika)}.qt-chip--custom{color:var(--accent-paprika);font-weight:600}.qt-chip:disabled{opacity:.4;cursor:not-allowed}.qt-full-hint{margin-top:var(--sp-2);font-size:12px;color:var(--fg-muted);text-align:center}.qt-display{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-2) var(--sp-3);background:var(--bg-deep);border-radius:var(--radius)}.qt-display--running{border:1px solid var(--accent-paprika)}.qt-display--done{border:1px solid var(--accent-basil);background:#65b3770d}.qt-time{font-size:28px;font-weight:600;letter-spacing:-.01em}.qt-display--done .qt-time{color:var(--accent-basil)}.qt-btn{padding:10px 18px;background:var(--accent-paprika);color:var(--bg-deep);border-radius:var(--radius);font-size:14px;font-weight:600;min-height:40px}.qt-ringing{color:var(--accent-basil);font-weight:600;font-size:14px}.cooking-bottom{display:flex;background:var(--bg-elevated);border-top:1px solid var(--border-subtle);padding-bottom:env(safe-area-inset-bottom,0px)}.cbt{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 4px 10px;color:var(--fg-muted);background:transparent;font-size:11px;font-weight:500;min-height:56px}.cbt-icon{font-size:20px;line-height:1;opacity:.7;filter:grayscale(.4)}.cbt--active{color:var(--accent-paprika)}.cbt--active .cbt-icon{opacity:1;filter:none}.ingr-block{margin-bottom:var(--sp-3)}.ingr-cat-h{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--fg-muted);padding:0 4px 6px}.ingr-section-h{font-family:Lora,Georgia,serif;font-size:15px;font-weight:600;color:var(--accent-paprika);padding:0 4px 6px}.ingr-list{list-style:none;padding:0;margin:0;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius);overflow:hidden}.ingr-line{display:flex;justify-content:space-between;align-items:center;padding:10px var(--sp-3);min-height:44px;border-bottom:1px solid var(--border-subtle);font-size:15px}.ingr-line:last-child{border-bottom:none}.ingr-qty{color:var(--fg-secondary);font-size:14px}.ingr-name{color:var(--fg-primary)}.notes-hint{font-size:13px;color:var(--fg-secondary);line-height:1.5;padding:0 4px}.notes-area{width:100%;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:var(--sp-3);font-size:16px;color:var(--fg-primary);font-family:inherit;resize:vertical;min-height:180px;line-height:1.5}.notes-area:focus{outline:none;border-color:var(--accent-paprika)}.info-emoji{text-align:center;font-size:64px;margin-bottom:var(--sp-3)}.info-title{text-align:center;font-size:22px;font-weight:600;margin-bottom:var(--sp-3)}.info-meta{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:4px 0;overflow:hidden}.info-meta-row{display:flex;justify-content:space-between;padding:10px var(--sp-3);border-bottom:1px solid var(--border-subtle);font-size:14px}.info-meta-row:last-child{border-bottom:none}.info-meta-row>span:first-child{color:var(--fg-secondary)}.info-desc{font-size:14px;color:var(--fg-secondary);line-height:1.5;padding:0 4px}.cooking-empty-inline{padding:var(--sp-4);text-align:center;color:var(--fg-muted);font-size:14px}.cooking-empty{padding:var(--sp-5) var(--sp-4);text-align:center;display:flex;flex-direction:column;gap:var(--sp-3);align-items:center;margin:auto}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:flex-end;justify-content:center;z-index:60}.sheet{background:var(--bg-elevated);border-top:1px solid var(--border-strong);border-radius:14px 14px 0 0;padding:var(--sp-4) var(--sp-4) calc(var(--sp-4) + env(safe-area-inset-bottom,0px));width:100%;max-width:480px;display:flex;flex-direction:column;gap:var(--sp-2);max-height:85vh;overflow-y:auto}.sheet-actions{display:flex;justify-content:flex-end;gap:var(--sp-2);margin-top:var(--sp-3)}.finish-emoji{text-align:center;font-size:48px}.finish-title{text-align:center;font-size:22px;font-weight:600}.finish-sub{text-align:center;font-size:14px;margin-bottom:var(--sp-3)}.finish-rating-label{text-align:center;font-size:13px;color:var(--fg-secondary);margin-bottom:var(--sp-2)}.finish-rating{display:flex;justify-content:center;gap:4px;margin-bottom:var(--sp-3)}.finish-star{font-size:36px;color:var(--border-strong);padding:6px 4px;background:transparent;border:none;cursor:pointer;transition:color .1s}.finish-star--on{color:var(--accent-saffron)}.finish-label{font-size:12px;color:var(--fg-secondary);margin:var(--sp-2) 0 6px}.finish-note{width:100%;background:var(--bg-deep);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:12px;font-size:16px;color:var(--fg-primary);font-family:inherit;resize:vertical;min-height:64px}.finish-note:focus{outline:none;border-color:var(--accent-paprika)}.muted{color:var(--fg-muted)}.safe-bottom{padding-bottom:env(safe-area-inset-bottom,0px)}.finish-error{background:#e2543f1a;border:1px solid rgba(226,84,63,.35);border-radius:var(--radius-sm);color:var(--accent-paprika);font-size:13px;padding:8px 12px;text-align:center}.info-hero-img{width:100%;max-height:220px;object-fit:cover;border-radius:var(--radius);margin-bottom:var(--sp-3)}.draft-preview-banner{background:#d4a2421f;border:1px solid var(--accent-saffron);color:var(--fg-primary);padding:12px 14px;border-radius:10px;margin-bottom:var(--sp-3);font-size:14px}.ed-shell{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-deep);display:flex;flex-direction:column;z-index:40;max-width:480px;margin:0 auto;overflow:hidden}@media (min-width: 768px){.ed-shell{max-width:720px;box-shadow:0 0 0 1px var(--border-subtle)}}.ed-header{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);min-height:52px;background:var(--bg-deep);border-bottom:1px solid var(--border-subtle)}.ed-cancel{background:transparent;color:var(--fg-secondary);font-size:14px;padding:8px 12px;border-radius:var(--radius);flex-shrink:0}.ed-cancel:active{background:var(--bg-hover);color:var(--fg-primary)}.ed-title{flex:1;text-align:center;font-family:Lora,Georgia,serif;font-size:15px;font-weight:600;color:var(--fg-primary)}.ed-save{background:var(--accent-paprika);color:var(--bg-deep);font-weight:600;font-size:14px;padding:8px 16px;border-radius:999px;box-shadow:0 3px 8px #e2543f38;border:none;flex-shrink:0}.ed-save:active{background:var(--accent-paprika-hover);transform:scale(.96)}.ed-save:disabled{background:var(--bg-hover);color:var(--fg-muted);box-shadow:none;opacity:.7}.ed-body{flex:1;overflow-y:auto;padding:var(--sp-3) var(--sp-4) calc(var(--sp-5) + env(safe-area-inset-bottom,0px));-webkit-overflow-scrolling:touch}.ed-section{margin-bottom:var(--sp-4)}.ed-section-head{display:flex;align-items:center;justify-content:space-between;margin:var(--sp-3) 2px var(--sp-2)}.ed-section-title{font-family:Lora,Georgia,serif;font-size:17px;font-weight:600;margin:0;letter-spacing:-.005em;color:var(--fg-primary)}.ed-link-btn{background:transparent;color:var(--accent-paprika);font-size:13px;font-weight:500;padding:6px 8px;border-radius:var(--radius-sm)}.ed-link-btn:active{background:var(--bg-hover)}.ed-footer-note{font-size:11px;color:var(--fg-muted);text-align:center;padding:var(--sp-3) 0}.ed-dirty{color:var(--accent-paprika);font-weight:600}.ed-clean{color:var(--accent-basil)}.ed-input{background:var(--bg-deep);border:1px solid var(--border-subtle);border-radius:8px;padding:10px 12px;font-size:16px;color:var(--fg-primary);font-family:inherit;min-height:40px;width:100%}.ed-input:focus{outline:none;border-color:var(--accent-paprika)}.ed-input::placeholder{color:var(--fg-muted)}.ed-input--textarea{resize:vertical;min-height:56px;line-height:1.5}.ed-input--title{font-family:Lora,serif;font-size:18px;font-weight:600;padding:12px}select.ed-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--fg-muted) 50%),linear-gradient(135deg,var(--fg-muted) 50%,transparent 50%);background-position:calc(100% - 16px) center,calc(100% - 11px) center;background-size:5px 5px;background-repeat:no-repeat;padding-right:28px}.ed-label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--fg-muted);margin:var(--sp-3) 0 4px}.ed-row-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3)}.ed-field{display:flex;flex-direction:column}.ed-emoji-row{display:flex;gap:6px;align-items:stretch}.ed-input--emoji{width:64px;text-align:center;font-size:22px!important;padding:6px 10px!important}.ed-emoji-cat-btn{flex:1;background:var(--bg-deep);border:1px solid var(--border-subtle);border-radius:8px;color:var(--fg-secondary);font-size:12px;padding:4px 8px;cursor:pointer;text-align:left}.ed-emoji-cat-btn:active{background:var(--bg-hover);color:var(--fg-primary)}.ed-meta-card{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:10px;padding:var(--sp-3) var(--sp-3) var(--sp-4)}.ed-meta-top{display:flex;gap:10px;align-items:center}.ed-emoji-pick{width:56px;height:56px;background:var(--bg-deep);border:1px solid var(--border-strong);border-radius:10px;font-size:32px;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center}.ed-emoji-pick:active{background:var(--bg-hover)}.ed-emoji-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-top:10px;padding:8px;background:var(--bg-deep);border:1px solid var(--border-subtle);border-radius:8px}.ed-emoji-cell{height:38px;border-radius:6px;background:transparent;font-size:20px;display:flex;align-items:center;justify-content:center}.ed-emoji-cell:active{background:var(--bg-hover)}.ed-emoji-cell--active{background:var(--accent-paprika)}.ed-stepper{display:flex;align-items:center;gap:4px;background:var(--bg-deep);border:1px solid var(--border-subtle);border-radius:8px;padding:3px;min-height:40px}.ed-stepper-btn{width:32px;height:32px;background:transparent;color:var(--fg-primary);font-size:18px;border-radius:6px}.ed-stepper-btn:not(:disabled):active{background:var(--bg-hover)}.ed-stepper-btn:disabled{opacity:.3}.ed-stepper-val{flex:1;text-align:center;font-size:15px;font-weight:600}.ed-cards{display:flex;flex-direction:column;gap:6px}.ed-ing-group{display:flex;flex-direction:column;gap:4px;padding:6px 0 8px}.ed-group-head{display:flex;align-items:center;gap:8px;padding:6px 2px 4px;border-bottom:1px dashed var(--border-subtle);margin-bottom:2px}.ed-group-title{flex:1;text-align:left;font-family:Lora,serif;font-size:14px;font-weight:600;color:var(--accent-paprika);background:transparent;padding:4px 0}.ed-group-del{background:transparent;color:var(--fg-muted);width:28px;height:28px;border-radius:6px;font-size:16px}.ed-group-del:active{background:var(--bg-hover);color:var(--accent-paprika)}.ed-ing{display:grid;grid-template-columns:1fr 60px 70px 32px;gap:4px;align-items:center;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:8px;padding:4px}.ed-input--name{padding:8px 10px;font-size:16px;min-height:36px}.ed-input--qty{padding:8px;font-size:16px;min-height:36px;text-align:right}.ed-input--unit{padding:8px 22px 8px 6px;font-size:16px;min-height:36px;background-position:calc(100% - 10px) center,calc(100% - 6px) center}.ed-row-menu{width:32px;height:36px;background:transparent;color:var(--fg-muted);font-size:18px;border-radius:6px;display:flex;align-items:center;justify-content:center}.ed-row-menu:active{background:var(--bg-hover);color:var(--fg-primary)}.ed-empty-hint{font-size:12px;color:var(--fg-muted);font-style:italic;padding:6px 4px}.ed-add-btn{background:transparent;border:1px dashed var(--border-strong);color:var(--fg-secondary);padding:10px;border-radius:8px;font-size:13px;font-weight:500;margin-top:4px}.ed-add-btn:active{background:var(--bg-hover);border-color:var(--accent-paprika);color:var(--accent-paprika)}.ed-step{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:10px;padding:var(--sp-3);display:flex;flex-direction:column;gap:8px}.ed-step-head{display:flex;align-items:center;gap:8px}.ed-step-num{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--accent-paprika);flex:1}.ed-step-timer{display:flex;align-items:center;gap:4px;background:var(--bg-deep);border:1px solid var(--border-subtle);border-radius:6px;padding:0 6px 0 8px;min-height:32px}.ed-step-timer-icon{font-size:13px;color:var(--fg-muted)}.ed-input--timer{width:36px;background:transparent;border:none;padding:4px 0;font-size:16px;text-align:center;min-height:28px}.ed-input--timer:focus{outline:none}.ed-step-timer-suffix{font-size:11px;color:var(--fg-muted)}.ed-input--instruction{font-size:16px;line-height:1.5;background:var(--bg-deep)}.ed-step-links{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.ed-link-btn-small{background:transparent;color:var(--accent-paprika);font-size:12px;font-weight:500;padding:4px 8px;border-radius:6px}.ed-link-btn-small:active{background:var(--bg-hover)}.ed-link-chip{font-size:11px;background:#e2543f1a;color:var(--accent-paprika);padding:3px 8px;border-radius:999px;font-weight:500}.ed-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:flex-end;justify-content:center;z-index:100;padding:var(--sp-3)}.ed-menu{width:100%;max-width:420px;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:12px;padding:6px;display:flex;flex-direction:column;gap:2px;max-height:70vh;overflow-y:auto}.ed-menu-item{text-align:left;background:transparent;color:var(--fg-primary);font-size:14px;padding:12px 14px;border-radius:8px;min-height:44px}.ed-menu-item:not(:disabled):active{background:var(--bg-hover)}.ed-menu-item:disabled{opacity:.4}.ed-menu-item--danger{color:var(--accent-paprika)}.ed-sheet{width:100%;max-width:420px;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:14px;padding:var(--sp-4);display:flex;flex-direction:column;gap:6px;max-height:80vh;overflow-y:auto}.ed-sheet-title{font-size:17px;font-weight:600;margin-bottom:2px}.ed-sheet-sub{font-size:12px;color:var(--fg-muted);margin-bottom:var(--sp-3)}.ed-link-list{display:flex;flex-direction:column;gap:4px;margin-bottom:var(--sp-3)}.ed-link-item{display:flex;align-items:center;gap:10px;background:var(--bg-deep);border:1px solid var(--border-subtle);border-radius:8px;padding:10px 12px;text-align:left;font-size:14px;color:var(--fg-primary);min-height:44px}.ed-link-item:active{background:var(--bg-hover)}.ed-link-item--on{border-color:var(--accent-paprika);background:#e2543f0f}.ed-link-check{width:18px;text-align:center;color:var(--accent-paprika);font-weight:700}.ed-link-qty{margin-left:auto;color:var(--fg-muted);font-size:12px}.ed-sheet-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}.ed-btn-ghost{background:transparent;color:var(--fg-secondary);padding:10px 14px;border-radius:8px;font-size:14px}.ed-btn-ghost:active{color:var(--fg-primary);background:var(--bg-hover)}.ed-btn-primary{background:var(--accent-paprika);color:var(--bg-deep);padding:10px 18px;border-radius:8px;font-size:14px;font-weight:600}.ed-btn-primary:active{background:var(--accent-paprika-hover)}.editor-image-row{display:flex;gap:var(--sp-3);align-items:center;margin-bottom:var(--sp-3)}.editor-image{width:80px;height:80px;border-radius:var(--radius);object-fit:cover;flex-shrink:0}.editor-image.no-image{display:flex;align-items:center;justify-content:center;background:var(--bg-deep);border:1px solid var(--border-subtle);font-size:32px}.editor-image-upload{padding:10px 14px;background:var(--bg-elevated);border:1px dashed var(--border-strong);border-radius:8px;cursor:pointer;color:var(--fg-secondary);font-size:14px}.editor-image-upload:hover{color:var(--fg-primary)}.editor-image-hint{color:var(--fg-muted);font-size:13px;margin:0}.auth-shell{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-deep);display:flex;flex-direction:column;align-items:center;padding:calc(env(safe-area-inset-top,0px) + var(--sp-5)) var(--sp-4) calc(env(safe-area-inset-bottom,0px) + var(--sp-4));overflow-y:auto}.auth-back{position:absolute;top:calc(env(safe-area-inset-top,0px) + 12px);left:12px;width:40px;height:40px;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:999px;font-size:18px;color:var(--fg-primary)}.auth-back:active{background:var(--bg-hover)}.auth-brand{display:flex;flex-direction:column;align-items:center;gap:6px;margin:var(--sp-4) 0 var(--sp-5)}.auth-brand--small{margin:var(--sp-3) 0 var(--sp-4);gap:4px}.auth-logo{font-size:56px;line-height:1}.auth-brand--small .auth-logo{font-size:40px}.auth-brand-title{font-family:Lora,Georgia,serif;font-size:28px;font-weight:700;letter-spacing:-.02em;color:var(--fg-primary)}.auth-brand--small .auth-brand-title{font-size:20px}.auth-brand-sub{font-size:13px;color:var(--fg-secondary)}.auth-card{width:100%;max-width:380px;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:12px;padding:var(--sp-4) var(--sp-4) var(--sp-3);display:flex;flex-direction:column;gap:4px}.auth-title{font-size:22px;font-weight:600;margin:0 0 4px}.auth-sub{font-size:13px;color:var(--fg-secondary);line-height:1.5;margin-bottom:var(--sp-3)}.auth-hint{font-size:12px;color:var(--fg-muted);line-height:1.5;font-style:italic;margin:var(--sp-2) 0 var(--sp-3)}.auth-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--fg-muted);margin:var(--sp-3) 0 4px}.auth-input{background:var(--bg-deep);border:1px solid var(--border-strong);border-radius:8px;padding:12px 14px;font-size:15px;color:var(--fg-primary);width:100%;font-family:inherit;min-height:44px}.auth-input:focus{outline:none;border-color:var(--accent-paprika)}.auth-err{background:#e2543f1f;border:1px solid rgba(226,84,63,.3);color:var(--accent-paprika);padding:8px 12px;border-radius:8px;font-size:13px;margin-top:var(--sp-3)}.auth-btn{margin-top:var(--sp-3);padding:13px 16px;border-radius:999px;font-size:15px;font-weight:600;border:1px solid transparent;cursor:pointer;min-height:48px}.auth-btn--primary{background:var(--accent-paprika);color:var(--bg-deep);box-shadow:0 4px 12px #e2543f40}.auth-btn--primary:active{background:var(--accent-paprika-hover);transform:scale(.98)}.auth-btn--secondary{background:var(--bg-deep);color:var(--fg-primary);border-color:var(--border-strong)}.auth-btn--secondary:active{background:var(--bg-hover)}.auth-divider{font-size:11px;color:var(--fg-muted);text-align:center;margin:var(--sp-3) 0 0;text-transform:uppercase;letter-spacing:.1em}.auth-footer{margin-top:var(--sp-4);font-size:11px;color:var(--fg-muted);text-align:center}.cooking-recovery-banner{position:fixed;bottom:calc(env(safe-area-inset-bottom,0) + var(--bottom-tab-height));left:0;right:0;height:44px;background:var(--accent-paprika);color:#fff;display:flex;align-items:center;padding:0 16px;z-index:50;box-shadow:0 -2px 6px #0003}.crb-main{flex:1;text-align:left;background:none;border:none;color:inherit;font-size:.95rem;cursor:pointer;padding:0}.crb-dismiss{background:none;border:none;color:inherit;padding:8px 12px;font-size:1rem;cursor:pointer;opacity:.7}.eb-shell{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;text-align:center;background:var(--bg-deep);color:var(--fg-primary);font-family:Inter,sans-serif}.eb-emoji{font-size:64px;margin-bottom:16px;opacity:.7}.eb-title{font-family:Lora,Georgia,serif;font-size:24px;margin:0 0 8px}.eb-msg{color:var(--fg-secondary);margin:0 0 24px;max-width:360px;line-height:1.5}.eb-actions{display:flex;flex-direction:column;gap:8px;width:100%;max-width:320px;margin-bottom:24px}.eb-btn{padding:12px 16px;border-radius:10px;border:1px solid var(--border-strong);background:var(--bg-elevated);color:var(--fg-primary);font-size:16px;cursor:pointer}.eb-btn--primary{background:var(--accent-paprika);border-color:var(--accent-paprika);color:#fff}.eb-btn:active{opacity:.7}.eb-details{width:100%;max-width:480px;font-size:12px;color:var(--fg-muted)}.eb-details summary{cursor:pointer;padding:8px;-webkit-user-select:none;user-select:none}.eb-trace{background:var(--bg-elevated);padding:12px;border-radius:8px;text-align:left;white-space:pre-wrap;word-break:break-word;max-height:240px;overflow:auto;font-size:11px;font-family:ui-monospace,monospace}
