: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{font-family:inherit;color:inherit}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}.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)}.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-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-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)}.header{background:var(--bg-deep);border-bottom:1px solid var(--border-subtle);position:sticky;top:0;z-index:10}.header-row{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);min-height:52px}.header-back{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--fg-secondary);border-radius:var(--radius);flex-shrink:0}.header-back:active,.header-back:hover{background:var(--bg-hover);color:var(--fg-primary)}.header-back--placeholder{pointer-events:none}.header-title-wrap{flex:1;min-width:0}.header-title{font-family:Lora,serif;font-size:18px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.005em}.header-subtitle{font-size:12px;color:var(--fg-secondary);margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-right{display:flex;align-items:center;gap:var(--sp-1);flex-shrink:0}.import-step-num{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--accent-paprika);margin-bottom:var(--sp-3)}.import-label{display:block;font-size:12px;color:var(--fg-secondary);margin:var(--sp-3) 0 6px}.import-url,.import-textarea{width:100%;background:var(--bg-deep);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:12px;font-size:15px;color:var(--fg-primary);min-height:44px;font-family:inherit}.import-url:focus,.import-textarea:focus{outline:none;border-color:var(--accent-paprika)}.import-textarea{min-height:64px;resize:vertical}.import-hint{font-size:12px;color:var(--fg-muted);line-height:1.5;margin:var(--sp-3) 0}.import-actions{display:flex;justify-content:flex-end;gap:var(--sp-2);margin-top:var(--sp-3);flex-wrap:wrap}.import-divider{text-align:center;color:var(--fg-muted);font-size:12px;text-transform:uppercase;letter-spacing:.1em;margin:var(--sp-3) 0}.import-section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--fg-muted);margin:var(--sp-4) 0 var(--sp-2)}.detected-hero{display:flex;gap:var(--sp-3);align-items:center;margin-top:var(--sp-3)}.detected-hero .detail-emoji{font-size:36px;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--bg-deep);border-radius:var(--radius);border:1px solid var(--border-subtle)}.detected-title{font-size:17px;font-weight:600}.detected-list{margin:0;padding-left:20px;font-size:14px;line-height:1.7;color:var(--fg-primary)}.detected-list li::marker{color:var(--fg-muted)}.checkbox{width:22px;height:22px;border:1.5px solid var(--border-strong);border-radius:var(--radius-sm);background:transparent;position:relative;display:inline-flex;align-items:center;justify-content:center;padding:0;cursor:pointer;transition:background-color .1s ease,border-color .1s ease;flex-shrink:0}.checkbox:hover{border-color:var(--accent-basil)}.checkbox--checked{background:var(--accent-basil);border-color:var(--accent-basil)}.checkbox-tick{position:absolute;width:6px;height:12px;border-right:2px solid var(--bg-deep);border-bottom:2px solid var(--bg-deep);transform:rotate(45deg) translate(-1px,-1px)}.shop-hero{padding:6px var(--sp-4) 8px;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:22px;font-weight:700;letter-spacing:-.015em;margin:0;line-height:1.1;color:var(--fg-primary)}.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-progress-dots{display:flex;gap:2px;margin-top:6px}.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-2) var(--sp-4) var(--sp-4)}.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:15px;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-2)}.shop-cat-head{display:flex;align-items:center;gap:5px;font-family:Lora,Georgia,serif;font-size:14px;font-weight:600;margin:0 0 4px 2px;letter-spacing:-.005em}.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:3px}.shop-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:42px;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)}.shop-card--basil .checkbox{border-color:#65b3778c}.shop-card--paprika .checkbox{border-color:#e2543f8c}.shop-card--saffron .checkbox{border-color:#d4a2428c}.shop-card-body{flex:1;min-width:0}.shop-card-name{font-size:14px;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:13px;color:var(--fg-primary);font-weight:500;flex-shrink:0;text-align:right;min-width:50px}.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-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}.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)}.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)}.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}.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-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:15px;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:15px;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)}.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:15px;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-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:14px;min-height:36px}.ed-input--qty{padding:8px;font-size:14px;min-height:36px;text-align:right}.ed-input--unit{padding:8px 22px 8px 6px;font-size:13px;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:13px;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:14px;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)}.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}
