:root{color-scheme:light;--font-body: "IBM Plex Sans", system-ui, -apple-system, sans-serif;--font-heading: "Fraunces", serif;--ink: #3c2f2a;--muted: #766660;--accent: #b2533e;--accent-hover: #c85f3c;--accent-soft: #d28c6f;--accent-light: #fff5f0;--color-prep: #fff9db;--color-cook: #ffecdf;--color-rest: #e3f2fd;--color-total: #e8f5e9;--color-tag: #f3f4e6;--color-portions: #fff1e6;--paper: #fdfaf7;--card: #ffffff;--ui-bg: #faf7f5;--ui-bg-dark: #f2ede9;--ui-bg-darker: #e8e2dd;--ui-border: rgba(60, 47, 42, .08);--ui-border-soft: rgba(60, 47, 42, .03);--ui-border-accent: rgba(178, 83, 62, .1);--shadow-sm: 0 2px 8px rgba(45, 30, 20, .04);--shadow-md: 0 8px 24px rgba(45, 30, 20, .08);--shadow-lg: 0 16px 48px rgba(45, 30, 20, .12);--shadow-accent: 0 4px 12px rgba(214, 109, 74, .2);--shadow-accent-lg: 0 6px 16px rgba(214, 109, 74, .3);--radius-lg: 24px;--radius-md: 16px;--radius-sm: 10px;--radius-round: 999px;--control-height: 40px;--compact-control-height: 38px;--page-gap: 12px;--header-height: 56px;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--dur-fast: .2s;--dur-mid: .3s;--focus-ring: rgba(178, 83, 62, .28)}[data-theme=sage]{--ink: #2a3130;--muted: #4d5b57;--accent: #4a7650;--accent-hover: #5d8c63;--accent-soft: #8fb894;--accent-light: #f2f7f3;--color-prep: #faf5e4;--color-cook: #fbe8d8;--color-rest: #e4eef8;--color-total: #e2f0e4;--color-tag: #eef0e4;--color-portions: #fbeee0;--paper: #f7f8f6;--card: #ffffff;--ui-bg: #f2f4f1;--ui-bg-dark: #e6e9e4;--ui-bg-darker: #d9ddd6;--ui-border: rgba(42, 49, 48, .1);--ui-border-soft: rgba(42, 49, 48, .04);--ui-border-accent: rgba(74, 118, 80, .14);--shadow-sm: 0 2px 8px rgba(42, 49, 48, .05);--shadow-md: 0 8px 24px rgba(42, 49, 48, .09);--shadow-lg: 0 16px 48px rgba(42, 49, 48, .12);--shadow-accent: 0 4px 12px rgba(74, 118, 80, .18);--shadow-accent-lg: 0 6px 16px rgba(74, 118, 80, .26);--focus-ring: rgba(74, 118, 80, .28)}[data-theme=bistro]{--ink: #111827;--muted: #4b5563;--accent: #9b2226;--accent-hover: #b42a2f;--accent-soft: #c97a7d;--accent-light: #fdf2f2;--color-prep: #f5f5f4;--color-cook: #f5f5f4;--color-rest: #f5f5f4;--color-total: #f0f0ef;--color-tag: #f5f5f4;--color-portions: #f5f5f4;--paper: #ffffff;--card: #ffffff;--ui-bg: #f9fafb;--ui-bg-dark: #f3f4f6;--ui-bg-darker: #e5e7eb;--ui-border: rgba(17, 24, 39, .1);--ui-border-soft: rgba(17, 24, 39, .04);--ui-border-accent: rgba(155, 34, 38, .12);--shadow-sm: 0 2px 8px rgba(17, 24, 39, .05);--shadow-md: 0 8px 24px rgba(17, 24, 39, .08);--shadow-lg: 0 16px 48px rgba(17, 24, 39, .12);--shadow-accent: 0 4px 12px rgba(155, 34, 38, .18);--shadow-accent-lg: 0 6px 16px rgba(155, 34, 38, .26);--focus-ring: rgba(155, 34, 38, .28)}[data-theme=vegetal]{--ink: #2c3e50;--muted: #546a7b;--accent: #4a7359;--accent-hover: #5b8a6a;--accent-soft: #8cb89a;--accent-light: #f0f7f2;--color-prep: #f0f4f0;--color-cook: #f0f4f0;--color-rest: #f0f4f0;--color-total: #e8f0ea;--color-tag: #f0f4f0;--color-portions: #f0f4f0;--paper: #f8f9fa;--card: #ffffff;--ui-bg: #f3f5f4;--ui-bg-dark: #e9edeb;--ui-bg-darker: #dde2df;--ui-border: rgba(44, 62, 80, .09);--ui-border-soft: rgba(44, 62, 80, .04);--ui-border-accent: rgba(74, 115, 89, .14);--shadow-sm: 0 2px 8px rgba(44, 62, 80, .04);--shadow-md: 0 8px 24px rgba(44, 62, 80, .07);--shadow-lg: 0 16px 48px rgba(44, 62, 80, .1);--shadow-accent: 0 4px 12px rgba(74, 115, 89, .16);--shadow-accent-lg: 0 6px 16px rgba(74, 115, 89, .24);--focus-ring: rgba(74, 115, 89, .28)}[data-theme=provence]{--ink: #4a4a4a;--muted: #6b6b6b;--accent: #c4583f;--accent-hover: #d4684f;--accent-soft: #e0a47a;--accent-light: #fef7f0;--color-prep: #faf5ee;--color-cook: #faf5ee;--color-rest: #faf5ee;--color-total: #f5efdf;--color-tag: #faf5ee;--color-portions: #faf5ee;--paper: #fcfbf9;--card: #ffffff;--ui-bg: #f8f5f1;--ui-bg-dark: #f0ebe4;--ui-bg-darker: #e6dfd6;--ui-border: rgba(74, 74, 74, .09);--ui-border-soft: rgba(74, 74, 74, .04);--ui-border-accent: rgba(196, 88, 63, .12);--shadow-sm: 0 2px 8px rgba(74, 74, 74, .04);--shadow-md: 0 8px 24px rgba(74, 74, 74, .07);--shadow-lg: 0 16px 48px rgba(74, 74, 74, .1);--shadow-accent: 0 4px 12px rgba(196, 88, 63, .18);--shadow-accent-lg: 0 6px 16px rgba(196, 88, 63, .26);--focus-ring: rgba(196, 88, 63, .28)}*,*:before,*:after{box-sizing:border-box}*{-webkit-tap-highlight-color:transparent}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}html,body,#root{min-height:100%}body{margin:0;min-height:100dvh;overflow-x:hidden;font-family:var(--font-body);line-height:1.5;color:var(--ink);background-color:var(--paper);background-image:radial-gradient(circle at 2px 2px,rgba(0,0,0,.01) 1px,transparent 0);background-size:32px 32px}h1,h2,h3{margin:0;font-family:var(--font-heading);font-weight:700;line-height:1.1}button,input,select,textarea{font:inherit;color:inherit}button{border:0;padding:0;background:none}input,select,button{transition:border-color var(--dur-fast),box-shadow var(--dur-fast),background-color var(--dur-fast),color var(--dur-fast),transform var(--dur-fast)}:focus-visible{outline:3px solid var(--focus-ring);outline-offset:2px}.app{display:flex;flex-direction:column;gap:var(--page-gap);max-width:1600px;min-height:100dvh;margin:0 auto;padding:12px 24px}.hero{position:sticky;top:0;z-index:11;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:8px;padding:8px 0;background:var(--paper)}.hero h1{font-size:clamp(1.3rem,3vw,1.6rem);letter-spacing:-.02em;color:var(--accent)}.eyebrow{margin:0;font-size:.6rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.status{padding:4px 12px;border:1px solid var(--ui-border);border-radius:var(--radius-round);background:var(--card);box-shadow:var(--shadow-sm);font-size:.75rem;color:var(--muted)}.header-right{display:flex;align-items:center;gap:8px}.admin-toggle{display:inline-flex;align-items:center;justify-content:center;height:36px;padding:0 14px;border:1px solid var(--ui-border);border-radius:var(--radius-round);background:var(--card);box-shadow:var(--shadow-sm);color:var(--muted);font-size:.8rem;font-weight:800;cursor:pointer}.admin-toggle:hover,.admin-toggle:focus-visible{border-color:var(--accent-soft);color:var(--accent);transform:translateY(-1px)}.admin-toggle.active{border-color:var(--accent);background:var(--accent);color:var(--card);box-shadow:var(--shadow-accent)}.theme-toggle{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1px solid var(--ui-border);border-radius:var(--radius-round);background:var(--card);box-shadow:var(--shadow-sm);font-size:1rem;cursor:pointer;transition:transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out)}.theme-toggle:hover{transform:scale(1.1);box-shadow:var(--shadow-md)}.controls{position:sticky;top:var(--header-height);z-index:10;display:flex;flex-direction:column;gap:10px;padding:10px 16px;border:1px solid var(--ui-border);border-radius:var(--radius-md);background:#fffcf9f2;box-shadow:var(--shadow-md);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.controls:not([style*="top: 0"]){box-shadow:0 4px 20px #00000014}.search-row{display:flex;flex-wrap:wrap;align-items:center;gap:12px}.search{position:relative;display:flex;flex:1;min-width:240px;flex-direction:column-reverse}.search label{position:absolute;top:50%;left:14px;z-index:1;transform:translateY(-50%);pointer-events:none;font-size:.9rem;color:var(--muted);transition:opacity var(--dur-fast),transform var(--dur-fast)}.search input{position:relative;z-index:2;width:100%;height:var(--control-height);padding:0 14px;border:1px solid var(--ui-border);border-radius:var(--radius-sm);background:var(--ui-bg);font-size:15px}.search input:focus,.search input:hover{border-color:var(--accent-soft);background:var(--card)}.search input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--ui-border-accent);outline:none}.search input:focus+label,.search input:not(:placeholder-shown)+label{opacity:0;transform:translate(-10px,-50%)}.view-toggle{display:flex;height:var(--control-height);align-items:center;gap:8px;padding:3px 8px;border-radius:var(--radius-sm);background:var(--ui-bg-dark)}.view-toggle label{font-size:.65rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}.view-toggle-buttons{display:flex;gap:2px;padding:2px;border-radius:6px;background:var(--ui-bg-darker)}.toggle-button{display:flex;width:32px;height:28px;align-items:center;justify-content:center;border-radius:4px;cursor:pointer;font-size:1rem;opacity:.4}.toggle-button.active{background:var(--card);box-shadow:0 2px 4px #0000001a;opacity:1}.filters{display:flex;flex-wrap:wrap;align-items:flex-end;gap:12px}.tag-filter,.sort{display:flex;flex:1;min-width:200px;max-width:300px;flex-direction:column;gap:4px}.tag-filter{position:relative}.tag-filter label,.sort label{margin-left:4px;font-size:.65rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}.tag-trigger{display:flex;min-width:180px;height:var(--compact-control-height);width:100%;align-items:center;justify-content:space-between;padding:0 14px;border:1px solid var(--ui-border);border-radius:var(--radius-sm);background:var(--ui-bg);cursor:pointer;font-size:.85rem}.tag-trigger:hover,.tag-trigger:focus-visible{border-color:var(--accent-soft);background:var(--card)}.tag-trigger span:first-child{font-weight:600;color:var(--ink)}.tag-trigger .tag-count{font-weight:800;color:var(--accent)}.sort select{height:var(--compact-control-height);width:100%;padding:0 12px;border:1px solid var(--ui-border);border-radius:var(--radius-sm);background:var(--ui-bg);cursor:pointer;font-size:.85rem}.sort select:hover,.sort select:focus-visible{border-color:var(--accent-soft);background:var(--card)}.tag-menu{position:absolute;top:calc(100% + 6px);left:0;z-index:100;display:flex;width:min(260px,90vw);max-height:350px;flex-direction:column;overflow-y:auto;padding:6px;border:1px solid var(--ui-border);border-radius:var(--radius-md);background:var(--card);box-shadow:var(--shadow-lg)}.tag-empty{padding:12px;color:var(--muted);font-size:.85rem}.tag-option{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:.9rem}.tag-option:hover{background:var(--accent-light)}.tag-option input{width:16px;height:16px;accent-color:var(--accent)}.clear,.copy,.list-empty button{height:var(--compact-control-height);padding:0 18px;border-radius:var(--radius-sm);background:var(--accent);color:var(--card);font-size:.85rem;font-weight:700;cursor:pointer;box-shadow:var(--shadow-accent)}.clear:hover,.copy:hover,.list-empty button:hover{background:var(--accent-hover);transform:translateY(-1px)}.copy:focus-visible,.list-empty button:focus-visible{background:var(--accent-hover)}.copy{padding:0 20px}.chips{display:flex;flex-wrap:wrap;gap:6px}.chip{display:flex;align-items:center;gap:6px;padding:4px 12px;border:1px solid var(--ui-border-soft);border-radius:var(--radius-round);background:var(--color-tag);cursor:pointer;font-size:.8rem;font-weight:700}.chip:hover{transform:translateY(-1px);border-color:var(--accent-soft)}.chip span{font-size:1.1rem;color:var(--accent)}.quick-tags{display:flex;gap:8px;overflow-x:auto;padding:4px 0 8px;scrollbar-width:none}.quick-tags::-webkit-scrollbar{display:none}.quick-tag-button{flex-shrink:0;padding:6px 14px;border:1px solid var(--ui-border);border-radius:var(--radius-round);background:var(--card);white-space:nowrap;color:var(--muted);font-size:.8rem;font-weight:600;cursor:pointer}.quick-tag-button:hover{border-color:var(--accent-soft);background:var(--accent-light);color:var(--accent)}.quick-tag-button.active{border-color:var(--accent);background:var(--accent);color:var(--card);box-shadow:var(--shadow-accent)}.content{display:grid;min-height:0;flex:1;grid-template-columns:380px 1fr;gap:24px}.admin-layout{flex:1;min-height:0}.admin-panel{display:flex;flex-direction:column;gap:20px;min-height:0}.admin-panel__hero{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;padding:28px;border:1px solid var(--ui-border);border-radius:var(--radius-lg);background:radial-gradient(circle at top right,rgba(178,83,62,.12),transparent 35%),linear-gradient(140deg,#fffffffa,#fff5f0f2);box-shadow:var(--shadow-md)}.admin-panel__eyebrow{margin:0 0 8px;color:var(--accent);font-size:.72rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase}.admin-panel__lede{max-width:680px;margin:10px 0 0;color:var(--muted)}.admin-panel__grid{display:grid;gap:20px;grid-template-columns:repeat(2,minmax(0,1fr))}.admin-card{display:flex;flex-direction:column;gap:14px;padding:24px;border:1px solid var(--ui-border);border-radius:var(--radius-md);background:var(--card);box-shadow:var(--shadow-sm)}.admin-card--wide{grid-column:1 / -1}.admin-card h3{font-family:var(--font-body);font-size:1rem;font-weight:800}.admin-card p{margin:0;color:var(--muted)}.admin-card__actions{display:flex;flex-wrap:wrap;gap:10px}.admin-card__hint{font-size:.85rem}.admin-panel__exit,.admin-link-button,.admin-secondary-button{display:inline-flex;align-items:center;justify-content:center;min-height:40px;padding:0 16px;border-radius:var(--radius-round);font-weight:700;text-decoration:none;cursor:pointer}.admin-panel__exit,.admin-secondary-button{border:1px solid var(--ui-border);background:var(--card);color:var(--ink)}.admin-link-button{border:1px solid var(--accent);background:var(--accent);color:var(--card);box-shadow:var(--shadow-accent)}.admin-panel__exit:hover,.admin-panel__exit:focus-visible,.admin-link-button:hover,.admin-link-button:focus-visible,.admin-secondary-button:hover,.admin-secondary-button:focus-visible{transform:translateY(-1px)}.admin-facts{display:grid;gap:12px;margin:0}.admin-facts div{padding:12px 14px;border:1px solid var(--ui-border-soft);border-radius:var(--radius-sm);background:var(--ui-bg)}.admin-facts dt{margin-bottom:4px;color:var(--muted);font-size:.72rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.admin-facts dd{margin:0;font-weight:600}.admin-checklist{margin:0;padding-left:18px}.admin-checklist li+li{margin-top:10px}.list,.detail{min-height:0}.list{display:flex;flex-direction:column;gap:12px}.list-header{margin-bottom:4px;color:var(--muted);font-size:.8rem;font-weight:600}.list-empty,.detail-empty,.detail-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;padding:60px 20px;text-align:center;color:var(--muted)}.detail-empty{height:100%;background:var(--card)}.detail-empty:before{content:"👩‍🍳";margin-bottom:8px;font-size:6rem;filter:drop-shadow(var(--shadow-md))}.detail-empty h2{font-size:2.8rem;color:var(--accent)}.detail-empty p,.detail-loading{max-width:340px;font-size:1.1rem}.card{display:flex;flex-direction:column;gap:6px;padding:18px;border:1px solid var(--ui-border);border-radius:var(--radius-md);background:var(--card);box-shadow:var(--shadow-sm);text-align:left;cursor:pointer;transition:transform var(--dur-mid) var(--ease-out),box-shadow var(--dur-mid) var(--ease-out),border-color var(--dur-mid) var(--ease-out),background-color var(--dur-mid) var(--ease-out)}.card:hover{transform:translateY(-2px);border-color:var(--accent-soft);box-shadow:var(--shadow-md)}.card.active{border-color:var(--accent);background:var(--accent-light);box-shadow:0 4px 16px var(--ui-border-accent)}.card-content{display:flex;flex-direction:column;gap:6px}.card h3{flex:1;color:var(--ink);font-family:var(--font-body);font-size:1.05rem;font-weight:700;line-height:1.3}.card mark{padding:0;border-radius:2px;background:color-mix(in srgb,var(--accent-light) 70%,#fff 30%);color:inherit}.card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.card-meta{display:flex;flex-shrink:0;align-items:center;gap:6px;margin-top:2px}.meta-time,.meta-tag-pill{display:inline-flex;align-items:center;gap:3px;padding:1px 6px;border-radius:4px;white-space:nowrap;font-size:.7rem;font-weight:700}.meta-time{background:var(--color-total);color:var(--ink)}.meta-tag-pill{max-width:100px;overflow:hidden;border:1px solid var(--ui-border-soft);background:var(--color-tag);color:var(--ink);text-overflow:ellipsis}.meta-tags-extra{color:var(--muted);font-size:.65rem;font-weight:600}.fav-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;font-size:1rem;color:var(--muted);cursor:pointer;transition:transform var(--dur-fast) var(--ease-out),color var(--dur-fast)}.fav-btn:hover{transform:scale(1.2);color:var(--accent)}.fav-btn.fav-active{color:var(--accent)}.fav-btn.fav-active:hover{transform:scale(1.2)}.preview{overflow:hidden;color:var(--muted);display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;font-size:.85rem}.tag-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.tag-row span{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border:1px solid var(--ui-border-soft);border-radius:var(--radius-round);background:var(--color-tag);color:var(--ink);font-size:.75rem;font-weight:700}.tag-row .source-tag{background:var(--ui-bg);color:var(--muted);font-weight:600;font-style:italic}.date{align-self:flex-end;color:var(--muted);font-size:.7rem}.list.compact .card{gap:4px;padding:12px 16px;border-radius:var(--radius-sm)}.list.compact .preview,.list.compact .tag-row{display:none}.list.compact .card-meta{margin-top:0}.detail{overflow:hidden;border:1px solid var(--ui-border);border-radius:var(--radius-lg);background:var(--card);box-shadow:var(--shadow-lg)}.detail-card{max-width:940px;margin:0 auto;padding:clamp(24px,6vw,60px)}.detail-header{margin-bottom:40px;text-align:center}.detail-header h2{margin-bottom:24px;color:var(--accent);font-size:clamp(2rem,5vw,3rem);letter-spacing:-.04em}.detail-description{margin:-6px auto 20px;max-width:72ch;color:var(--muted);font-size:1rem;line-height:1.45}.back{display:none;align-items:center;gap:10px;height:44px;padding:0 20px;border:1px solid var(--ui-border);border-radius:var(--radius-sm);background:var(--ui-bg-dark);color:var(--ink);font-size:.9rem;font-weight:700;cursor:pointer}.back:hover,.back:focus-visible{background:var(--ui-bg-darker)}.summary{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-bottom:40px}.summary-pill,.time-pill{display:flex;min-height:110px;min-width:140px;flex:1;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:16px;border:1px solid var(--ui-border-soft);border-radius:var(--radius-md);background-color:var(--ui-bg);text-align:center}.summary-pill:hover,.time-pill:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}.summary-pill span,.time-pill span{margin-bottom:-2px;color:var(--muted);font-size:.65rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.summary-pill strong,.time-pill strong{color:var(--ink);font-family:var(--font-body);font-size:1.1rem;font-weight:700;line-height:1.2}.portion-row{display:flex;width:100%;flex-direction:column;align-items:center;gap:12px}.portion-stepper{position:relative;display:flex;align-items:center;gap:2px;padding:4px;border:1px solid var(--ui-border);border-radius:var(--radius-round);background:var(--ui-bg-dark);transition:transform var(--dur-mid) var(--ease-spring)}.portion-adjust,.portion-reset-btn.inside{display:flex;width:38px;height:38px;align-items:center;justify-content:center;border-radius:50%;background:var(--card);color:var(--ink);font-size:1.2rem;font-weight:700;cursor:pointer;box-shadow:var(--shadow-sm)}.portion-adjust:not(:disabled):hover,.portion-reset-btn.inside:hover{transform:scale(1.1);background:var(--paper);color:var(--accent);box-shadow:var(--shadow-md)}.portion-adjust:active,.portion-reset-btn.inside:active{transform:scale(.92)}.portion-adjust:disabled{opacity:.3;cursor:not-allowed}.portion-divider{width:1px;height:20px;margin:0 4px;background:var(--ui-border)}.portion-reset-btn{position:absolute;top:50%;right:-48px;display:flex;width:32px;height:32px;align-items:center;justify-content:center;border-radius:50%;background:var(--ui-bg-darker);color:var(--accent);font-size:1.2rem;cursor:pointer;transform:translateY(-50%);animation:rotate-in .5s var(--ease-spring)}.portion-reset-btn.inside{position:static;width:38px;height:38px;transform:none;animation:scale-in .3s var(--ease-spring)}.portion-reset-btn:hover{background:var(--accent);color:var(--card);transform:translateY(-50%) rotate(180deg)}.portion-reset-btn .reset-icon{display:block}@keyframes scale-in{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}@keyframes rotate-in{0%{opacity:0;transform:translateY(-50%) rotate(-180deg) scale(0)}to{opacity:1;transform:translateY(-50%) rotate(0) scale(1)}}.time-preparation{background-color:var(--color-prep)}.time-cuisson{background-color:var(--color-cook)}.time-repos{background-color:var(--color-rest)}.time-total{border:2px solid var(--ui-border-soft);background-color:var(--color-total)}.portions-pill{background-color:var(--color-portions)}.categories-pill{background-color:var(--color-tag)}.main-content{display:flex;flex-direction:column;gap:8px}.detail-card section{margin-top:48px}.detail-card section h3{margin:0 0 18px;padding-bottom:8px;border-bottom:1px solid var(--ui-border-soft);color:var(--ink);font-size:1.8rem}.ingredients-header,.steps-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px}.ingredients-header h3,.steps-header h3{margin:0;padding:0;border:none}.ingredients-title-row{display:flex;align-items:center;gap:12px}.portion-reset{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid var(--ui-border);border-radius:50%;background:var(--ui-bg);color:var(--accent);font-size:1.2rem;cursor:pointer}.portion-reset:hover,.portion-reset:focus-visible{border-color:var(--accent-soft);background:var(--accent-light)}.ingredients-checklist,.steps-list{display:flex;flex-direction:column;gap:0}.ingredient-item{display:flex;align-items:flex-start;gap:12px;margin-left:-12px;padding:8px 12px;border-radius:var(--radius-sm);cursor:pointer}.ingredient-item:hover{background:var(--ui-bg)}.ingredient-item.checked{opacity:.3}.ingredient-item.checked span{text-decoration:line-through}.ingredient-checkbox{display:flex;width:20px;height:20px;flex-shrink:0;align-items:center;justify-content:center;margin-top:4px;border:2px solid var(--accent-soft);border-radius:4px}.ingredient-item.checked .ingredient-checkbox{border-color:var(--accent);background:var(--accent)}.ingredient-checkbox:after{content:"✓";display:none;color:#fff;font-size:14px}.ingredient-item.checked .ingredient-checkbox:after{display:block}.step-item{position:relative;margin-left:12px;padding-bottom:24px;padding-left:24px;border-left:2px solid var(--ui-border);font-size:1.1rem;line-height:1.7}.step-item:before{content:attr(data-step);position:absolute;top:0;left:-13px;z-index:1;display:flex;width:24px;height:24px;align-items:center;justify-content:center;border:2px solid var(--accent);border-radius:50%;background:var(--paper);color:var(--accent);font-size:.8rem;font-weight:700}.step-item:last-child{border-left-color:transparent}.detail-card ul{margin:0;padding-left:1.2em}.detail-card li{margin-bottom:12px;font-size:1.1rem;line-height:1.7}.back-to-top{position:fixed;right:24px;bottom:24px;z-index:100;display:flex;width:44px;height:44px;align-items:center;justify-content:center;border-radius:50%;background:var(--accent);color:#fff;font-size:1.2rem;cursor:pointer;box-shadow:var(--shadow-lg);opacity:0;pointer-events:none;transform:translateY(10px);transition:opacity var(--dur-mid),transform var(--dur-mid),background-color var(--dur-fast)}.back-to-top.visible{opacity:1;pointer-events:auto;transform:translateY(0)}.back-to-top:hover{background:var(--accent-hover);transform:translateY(-2px)}.kitchen-trigger{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border:1px solid var(--ui-border);border-radius:var(--radius-sm);background:var(--ui-bg-dark);color:var(--accent);font-size:.9rem;font-weight:700;cursor:pointer}.kitchen-trigger:hover,.kitchen-trigger:focus-visible{border-color:var(--accent-soft);background:var(--accent-light);transform:translateY(-1px)}.kitchen-overlay{position:fixed;inset:0;z-index:99999;display:flex;flex-direction:column;background-color:var(--paper);background-image:radial-gradient(circle at 2px 2px,rgba(0,0,0,.01) 1px,transparent 0);background-size:32px 32px;animation:overlay-fade-in var(--dur-mid) var(--ease-out)}@keyframes overlay-fade-in{0%{opacity:0;transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.kitchen-progress{position:fixed;top:0;left:0;z-index:1000;height:6px;background:var(--accent);box-shadow:0 0 10px #b2533e66;transition:width .4s var(--ease-spring)}.kitchen-header{position:relative;display:flex;align-items:center;justify-content:center;padding:24px 80px}.kitchen-tabs{display:flex;gap:4px;padding:4px;border-radius:var(--radius-round);background:var(--ui-bg-dark)}.kitchen-tab-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-round);color:var(--muted);font-size:.9rem;font-weight:700;cursor:pointer}.kitchen-tab-btn.active{background:var(--card);color:var(--accent);box-shadow:var(--shadow-sm)}.kitchen-tab-btn .count{padding:2px 6px;border-radius:10px;background:var(--accent);color:#fff;font-size:.7rem}.kitchen-close{position:absolute;top:50%;right:24px;z-index:10;display:flex;width:48px;height:48px;align-items:center;justify-content:center;border-radius:50%;background:var(--ui-bg-dark);color:var(--ink);font-size:2rem;cursor:pointer;transform:translateY(-50%)}.kitchen-close:hover,.kitchen-close:focus-visible{background:var(--ui-bg-darker);transform:translateY(-50%) rotate(90deg)}.kitchen-content{display:flex;width:100%;max-width:100%;flex:1;flex-direction:column;align-items:center;gap:32px;margin:0 auto;padding:80px 40px;overflow-y:auto;text-align:center;-webkit-overflow-scrolling:touch}.kitchen-content:before,.kitchen-content:after{content:"";margin:auto}.kitchen-content>*{max-width:900px;flex-shrink:0}.kitchen-step-number{color:var(--muted);font-size:.9rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase}.kitchen-step-text{color:var(--ink);font-family:var(--font-heading);font-size:clamp(2rem,6vw,3.5rem);font-weight:600;line-height:1.25}.kitchen-ingredients-view{align-items:flex-start;text-align:left}.kitchen-ingredients-checklist{display:grid;width:100%;gap:16px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));padding-bottom:40px}.kitchen-ingredient-item{display:flex;align-items:flex-start;gap:16px;padding:20px;border:2px solid transparent;border-radius:var(--radius-md);background:var(--card);box-shadow:var(--shadow-sm);cursor:pointer}.kitchen-ingredient-item:hover{border-color:var(--accent-soft);box-shadow:var(--shadow-md);transform:translateY(-2px)}.kitchen-ingredient-item.checked{opacity:.5;background:var(--ui-bg)}.kitchen-ingredient-item.checked span{text-decoration:line-through}.kitchen-ingredient-checkbox{position:relative;width:24px;height:24px;flex-shrink:0;margin-top:2px;border:2px solid var(--accent-light);border-radius:6px;background:var(--ui-bg-dark)}.kitchen-ingredient-item.checked .kitchen-ingredient-checkbox{border-color:var(--accent);background:var(--accent)}.kitchen-ingredient-checkbox:after{content:"✓";position:absolute;top:50%;left:50%;display:none;color:#fff;font-size:16px;transform:translate(-50%,-50%)}.kitchen-ingredient-item.checked .kitchen-ingredient-checkbox:after{display:block}.kitchen-ingredient-item span{color:var(--ink);font-size:1.25rem;font-weight:600;line-height:1.4}.kitchen-footer{display:flex;justify-content:center;gap:20px;padding:40px;background:linear-gradient(to top,var(--paper),transparent)}.kitchen-nav-btn{flex:1;max-width:280px;height:64px;padding:0 40px;border:1px solid var(--ui-border);border-radius:var(--radius-round);background:var(--card);color:var(--ink);font-size:1.1rem;font-weight:700;cursor:pointer;box-shadow:var(--shadow-md);transition:transform var(--dur-mid) var(--ease-spring),box-shadow var(--dur-mid) var(--ease-spring),border-color var(--dur-fast),background-color var(--dur-fast)}.kitchen-nav-btn:not(:disabled):hover{border-color:var(--accent-soft);box-shadow:var(--shadow-lg);transform:translateY(-3px)}.kitchen-nav-btn:active{transform:scale(.95)}.kitchen-nav-btn:disabled{opacity:.3;cursor:not-allowed}.kitchen-nav-btn.primary{border:0;background:var(--accent);color:#fff;box-shadow:var(--shadow-accent)}.kitchen-nav-btn.primary:not(:disabled):hover{background:var(--accent-hover);box-shadow:var(--shadow-accent-lg)}@media(min-width:901px){body{overflow:hidden}.app{height:100dvh;padding:12px 40px}.hero{position:static;padding:0;background:transparent}.controls{top:0;background:var(--card);backdrop-filter:none;-webkit-backdrop-filter:none}.list,.detail{overflow-y:auto;max-height:100%;padding-right:8px;scrollbar-color:var(--ui-border) transparent;scrollbar-width:thin}.list::-webkit-scrollbar,.detail::-webkit-scrollbar{width:6px}.list::-webkit-scrollbar-thumb,.detail::-webkit-scrollbar-thumb{border-radius:10px;background:var(--ui-border)}}@media(max-width:1024px){.kitchen-step-text{font-size:clamp(1.4rem,5vw,2.2rem)}.kitchen-content{padding:60px 24px}}@media(max-width:900px){body{overflow-y:auto}.app{height:auto;padding:12px}.content{display:block}.admin-panel__hero{flex-direction:column}.admin-panel__grid{grid-template-columns:1fr}.app.has-selection .hero,.app.has-selection .controls,.app.has-selection .list{display:none}.detail{display:block;height:auto;max-height:none;overflow:visible;border:none;border-radius:0;background:transparent;box-shadow:none}.detail::-webkit-scrollbar{display:none}.app.has-selection .detail-card{padding:20px 0}.back{display:inline-flex}.back-to-top{z-index:9999}}@media(max-width:600px){.summary-pill,.time-pill{width:calc(50% - 6px)}.detail-header h2{font-size:2.2rem}.portion-reset-btn:not(.inside){position:static;margin-top:10px;transform:none;animation:none}}.detail-actions{display:flex;justify-content:center;gap:12px;margin-bottom:16px}.detail-action-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid var(--ui-border);border-radius:var(--radius-round);background:var(--ui-bg);color:var(--muted);font-size:.85rem;font-weight:600;cursor:pointer}.detail-action-btn:hover{border-color:var(--accent-soft);background:var(--accent-light);color:var(--accent)}.detail-action-btn.fav-active{border-color:var(--accent-soft);color:var(--accent)}@media print{*{box-shadow:none!important}body{background:#fff!important;background-image:none!important;color:#000;font-size:10pt;overflow:visible!important;height:auto!important}.hero,.controls,.list,.back,.back-to-top,.kitchen-trigger,.kitchen-overlay,.detail-actions,.copy,.portion-stepper,.portion-reset,.ingredients-title-row .portion-reset{display:none!important}.app{display:block;padding:0;max-width:none;height:auto!important;min-height:0;overflow:visible!important}.content{display:block}.detail{overflow:visible!important;border:none;border-radius:0;background:#fff;max-height:none!important;height:auto!important}.detail-card{max-width:none;padding:0}.detail-header{margin-bottom:12px;text-align:left}.detail-header h2{color:#000;font-size:1.4rem;margin-bottom:4px}.detail-description{font-size:.85rem;margin:0 0 8px}.summary{gap:6px;margin-bottom:12px;justify-content:flex-start}.summary-pill,.time-pill{min-height:auto;min-width:auto;padding:6px 10px;border:1px solid #ccc;border-radius:4px;background:#f9f9f9}.summary-pill span,.time-pill span{font-size:.55rem}.summary-pill strong,.time-pill strong{font-size:.85rem}.detail-card section{margin-top:16px}.detail-card section h3{font-size:1.1rem;margin-bottom:8px;padding-bottom:4px}.ingredients-header,.steps-header{margin-bottom:8px}.ingredients-checklist{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}.ingredient-item{padding:3px 8px;gap:8px;margin-left:0;break-inside:avoid}.ingredient-checkbox{width:14px;height:14px;border-color:#999;margin-top:2px}.ingredient-item span{font-size:.85rem}.step-item{padding-bottom:10px;padding-left:20px;font-size:.85rem;line-height:1.5;break-inside:avoid}.step-item:before{width:18px;height:18px;left:-10px;font-size:.65rem}.detail-card li{font-size:.85rem;line-height:1.5;margin-bottom:4px}.main-content{gap:0}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}
