:root{color-scheme:dark;--bg0: #030812;--bg1: #0a1220;--panel: rgba(10, 18, 32, .82);--panel-strong: rgba(10, 18, 32, .95);--stroke: rgba(148, 163, 184, .2);--stroke-strong: rgba(148, 163, 184, .32);--text: rgba(240, 245, 250, .98);--muted: rgba(166, 180, 200, .96);--muted2: rgba(148, 163, 184, .78);--brand: #22d3ee;--brand2: #0ea5e9;--brand3: #06b6d4;--success: #10b981;--warn: #f59e0b;--danger: #ef4444;--radius-xl: 24px;--radius-lg: 18px;--radius-md: 14px;--shadow: 0 20px 60px rgba(0, 0, 0, .6);--shadow-soft: 0 8px 24px rgba(0, 0, 0, .32);--shadow-lg: 0 24px 80px rgba(0, 0, 0, .75);--ring: 0 0 0 3px rgba(34, 211, 238, .35);font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";font-size:15px;line-height:1.6}*,*:before,*:after{box-sizing:border-box}html,body{height:100%}body{margin:0;color:var(--text);background:radial-gradient(1400px 800px at 8% 6%,rgba(34,211,238,.15),transparent 60%),radial-gradient(1000px 700px at 92% 12%,rgba(14,165,233,.12),transparent 55%),radial-gradient(900px 700px at 45% 92%,rgba(167,139,250,.1),transparent 60%),linear-gradient(180deg,var(--bg0),var(--bg1));background-attachment:fixed}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:#0f172a99}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#22d3eeb3,#0ea5e980);border-radius:999px;border:2px solid rgba(15,23,42,.8)}::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#22d3eee6,#0ea5e9b3)}.holdbar{position:sticky;top:12px;z-index:50;margin-bottom:14px;gap:8px;background:#080e16a6;-webkit-backdrop-filter:blur(14px) saturate(140%);backdrop-filter:blur(14px) saturate(140%);border:1px solid rgba(255,255,255,.08);box-shadow:0 12px 40px #00000073;border-radius:16px;padding:10px 12px}.holdbarRow{display:flex;align-items:center;gap:10px}.holdbar__segmented{display:flex;align-items:center;gap:8px}.holdbarRow{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.holdbar__search{flex:1;min-width:180px;max-width:560px}.holdbar__actions{display:flex;align-items:center;gap:8px}.segmented{display:flex;gap:6px;padding:4px;border-radius:14px;background:#ffffff05;border:1px solid rgba(255,255,255,.08)}.segBtn{height:32px;padding:0 12px;border-radius:12px;background:transparent;border:1px solid rgba(255,255,255,.08);color:#ffffffc7}.segBtn:hover{background:#ffffff0f;border-color:#ffffff2e}.segBtnActive{background:linear-gradient(135deg,#22d3ee24,#0ea5e914);border:1px solid rgba(34,211,238,.9);color:#f1f5f9;font-weight:800;box-shadow:0 10px 28px #00000059,0 0 0 1px #ffffff1f,0 0 0 4px #22d3ee38}.btn-active,.holdbar .btn[aria-expanded=true],.holdbar .btn[aria-pressed=true]{background:linear-gradient(135deg,#22d3ee2e,#0ea5e91a);border-color:#22d3ee8c;box-shadow:0 12px 28px #00000059,0 0 0 1px #ffffff1a,0 0 0 6px #22d3ee2e;color:#f8fafc}.holdbar .btn-primary{background:linear-gradient(135deg,#22d3ee80,#0ea5e959);border-color:#22d3eeb3;box-shadow:0 14px 32px #00000073,0 0 0 1px #ffffff14}.holdbar .btn-primary:hover{border-color:#22d3eee6;box-shadow:0 16px 38px #0000008c,0 0 0 1px #ffffff1f}.segBtn:focus-visible{outline:2px solid rgba(16,185,129,.55);outline-offset:2px}.label-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.label-row h2,.label-row h3{margin:0}.muted-inline{color:var(--muted);font-size:13px}.fadeUp{animation:fadeUp .26s ease both}@keyframes fadeUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.holdbar input[type=text],.holdbar input[type=search],.holdbar select{height:38px;font-size:14px;padding:8px 10px;background:#0003;border:1px solid rgba(255,255,255,.1);border-radius:12px}.holdbar input:focus,.holdbar select:focus,.input:focus{outline:none;border-color:#10b98166;box-shadow:0 0 0 2px #10b98140}.holdbar .btn,.holdbar button{height:36px;padding:0 10px;gap:8px;border-radius:12px;font-size:14px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1)}.holdbar .btn:hover,.holdbar button:hover{background:#ffffff1a}@media(max-width:900px){.holdbar{min-height:56px;gap:6px}.holdbar__actions{gap:6px}}.ingredient-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}.ingredient-chip{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:6px;padding:8px 10px;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:#ffffff0a;min-height:38px}.ingredient-chip__name{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ingredient-chip__meta{font-size:12px;color:var(--muted);white-space:nowrap}.ingredient-chip__remove{border:none;background:transparent;color:#f87171;cursor:pointer;font-size:16px;line-height:1;padding:4px 6px}.ingredient-chip__remove:hover{background:#f871711f;border-radius:8px}.costs-grid{display:grid;gap:10px}.cost-row{display:grid;grid-template-columns:1.2fr .55fr .75fr .75fr .7fr auto;gap:10px;align-items:center;padding:10px 12px;border:1px solid rgba(255,255,255,.08);border-radius:14px;background:#ffffff05;box-shadow:0 12px 28px #0000003d;transition:background .16s ease,border-color .16s ease,transform .16s ease,box-shadow .16s ease}.cost-row:hover{background:#ffffff0a;border-color:#22d3ee47;transform:translateY(-1px);box-shadow:0 16px 36px #00000052}.cost-label{display:block;font-size:11px;color:var(--muted2);margin-bottom:4px;letter-spacing:.01em}.cost-price{display:flex;flex-direction:column;gap:2px;font-size:13px}.cost-unit-price{font-weight:700;letter-spacing:-.01em}.cost-unit-sub{font-size:11px;color:var(--muted2)}.cost-actions{display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap}@media(max-width:960px){.cost-row{grid-template-columns:1fr 1fr;align-items:flex-start}.cost-actions{justify-content:flex-start}}@media(max-width:640px){.cost-row{grid-template-columns:1fr}}.card-grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:14px}.card-grid-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}.field{display:flex;flex-direction:column;gap:6px}.field-label{font-size:11px;color:var(--muted2);letter-spacing:.01em}.pillStat{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:#ffffff0a;font-weight:700;font-size:12px}.list-card{border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:12px;background:#ffffff08;display:grid;gap:10px;transition:background .16s ease,border-color .16s ease,transform .16s ease,box-shadow .16s ease}.list-card:hover{background:#ffffff0f;border-color:#22d3ee33;transform:translateY(-1px);box-shadow:0 14px 32px #00000042}.list-item-row{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center}.list-item-title{font-weight:800;letter-spacing:-.01em}.list-item-meta{font-size:12px;color:var(--muted2);display:flex;gap:8px;flex-wrap:wrap}.ghost-input{border:1px dashed rgba(255,255,255,.2);background:#ffffff05;color:var(--text)}.upload-box{border:1px dashed rgba(255,255,255,.25);border-radius:14px;padding:16px;background:#ffffff05;display:grid;gap:8px;justify-items:start}.tiny-label{font-size:11px;color:var(--muted2)}.stack-sm{display:grid;gap:8px}.inline-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.appShell{min-height:100vh;display:grid;grid-template-columns:290px 1fr;gap:18px;padding:16px}@media(max-width:980px){.appShell{grid-template-columns:1fr;padding:12px}}.glass{background:var(--panel);border:1px solid var(--stroke);border-radius:var(--radius-xl);box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.sidebar{padding:20px;position:sticky;top:16px;max-height:calc(100vh - 32px);display:flex;flex-direction:column;gap:16px;background:linear-gradient(180deg,#0a1220f2,#0a1220e0);border:1px solid var(--stroke-strong);border-radius:var(--radius-xl);box-shadow:var(--shadow-soft);overflow-y:auto;overflow-x:hidden;scrollbar-width:none;-ms-overflow-style:none}.sidebar::-webkit-scrollbar{display:none}@media(max-width:980px){.sidebar{position:relative;max-height:none;top:auto}}.brandRow{display:flex;align-items:center;gap:12px;padding:8px 10px;border-radius:18px;background:radial-gradient(circle at top left,rgba(34,211,238,.22),transparent 65%),#02061766;border:1px solid rgba(148,163,184,.2)}.brandLogo{width:40px;height:40px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,#22d3ee4d,#38bdf81f);border:1px solid rgba(34,211,238,.25);color:#e2e8f0f5;font-weight:900;font-size:18px}.brandTitle{font-weight:900;letter-spacing:-.03em;line-height:1;font-size:18px;color:var(--brand);text-shadow:0 0 24px rgba(255,255,255,.1)}.brandSubtitle{margin-top:2px;font-size:12px;color:var(--muted2);letter-spacing:.05em;text-transform:uppercase}.nav{display:grid;gap:8px;margin-top:6px}.navItem{position:relative;display:flex;align-items:center;gap:10px;padding:10px 12px 10px 14px;border-radius:14px;border:1px solid rgba(148,163,184,.14);background:#ffffff04;transition:transform .18s cubic-bezier(.23,1,.32,1),border-color .18s ease,background .18s ease,box-shadow .18s ease;cursor:pointer}.navItem:before{content:"";position:absolute;inset:8px auto 8px 8px;width:4px;border-radius:999px;background:transparent;transition:background .18s ease}.navItem:hover{transform:translate(2px) translateY(-1px);border-color:#22d3ee59;background:#ffffff0d;box-shadow:0 8px 18px #070a1659}.navItem.navItemActive{border-color:#22d3ee80;background:#ffffff14;box-shadow:0 0 0 1px var(--brand) inset,0 10px 24px #070a1680}.navItem.navItemActive:before{background:linear-gradient(180deg,var(--brand),var(--brand2));box-shadow:0 0 12px var(--brand)}.navItem:focus-visible{outline:none;box-shadow:var(--ring)}.navIcon{width:34px;height:34px;border-radius:12px;display:grid;place-items:center;border:1px solid rgba(148,163,184,.2);background:#ffffff08;color:#e2e8f0e6;font-size:15px}.navText{display:grid;gap:2px}.navText strong{font-size:13px;letter-spacing:-.01em}.navText span{font-size:12px;color:var(--muted2)}.navLabel{font-weight:800;letter-spacing:-.01em}.profilePanel{margin-top:16px;display:grid;gap:12px;padding:16px;border-radius:var(--radius-lg);background:linear-gradient(150deg,#22d3ee1f,#0ea5e90f);border:1px solid rgba(34,211,238,.32);box-shadow:0 8px 32px #00000059}.profilePanel__header{display:flex;align-items:center;justify-content:space-between;gap:8px}.profilePanel__title{display:flex;align-items:center;gap:8px;font-weight:800;font-size:13px}.profilePanel__actions{display:grid;grid-template-columns:1fr auto;gap:8px}.profilePanel__hint{font-size:11px}.sidebarFooter{margin-top:auto;padding:10px 12px;border-radius:16px;border:1px solid rgba(148,163,184,.12);background:#02061733;color:var(--muted2);font-size:12px;flex-shrink:0}.main{padding:20px}.content{padding:20px;overflow-y:auto}.mainInner{max-width:1200px;margin:0 auto 32px}.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:18px 22px;border-radius:var(--radius-xl);background:radial-gradient(circle at top left,rgba(255,255,255,.12),transparent 60%),var(--panel-strong);border:1px solid var(--stroke-strong);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);margin-bottom:20px;animation:fadeUp .26s ease both}.topbarTitle{display:grid;gap:4px}.topbarTitle h1{margin:0;font-size:22px;font-weight:900;letter-spacing:-.02em}.topbarTitle p{margin:0;font-size:12px;color:var(--muted2)}.topbarActions{display:flex;gap:10px;align-items:center}@media(max-width:680px){.topbar{flex-direction:column}.topbarActions{width:100%;justify-content:flex-start;flex-wrap:wrap}}.card{position:relative;background:radial-gradient(circle at 12% 8%,rgba(34,211,238,.14),transparent 45%),linear-gradient(180deg,#0a1220f0,#0a1220db);border:1px solid var(--stroke-strong);border-radius:var(--radius-xl);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:20px;animation:fadeUp .26s ease both;overflow:hidden}.card:before{content:"";position:absolute;inset:-1px;border-radius:inherit;border-top:1px solid rgba(148,163,184,.4);opacity:.6;pointer-events:none}.card+.card{margin-top:16px}.mainInner>.card:first-of-type{box-shadow:var(--shadow-lg);border-color:var(--stroke-strong)}.card h2,.sectionTitle{margin:0 0 14px;font-size:16px;font-weight:800;letter-spacing:-.01em;display:inline-flex;align-items:center;gap:10px;color:var(--text)}.card h2:after,.sectionTitle:after{content:"";height:3px;width:40px;border-radius:999px;background:var(--brand);opacity:.8}.sectionTitle{margin-bottom:10px}.muted{color:var(--muted2);font-size:12px;margin:0}.input,select.input,textarea.input{width:100%;padding:10px 14px;border-radius:14px;background:#02061759;border:1px solid rgba(148,163,184,.26);color:var(--text);outline:none;font-weight:500;transition:border-color .16s ease,box-shadow .16s ease,background .16s ease}.input::-moz-placeholder{color:#94a3b8a6}.input::placeholder{color:#94a3b8a6}.input:focus-visible{border-color:var(--brand);box-shadow:0 0 0 3px #ffffff26;background:#02061773;outline:none}.btn{padding:10px 14px;border-radius:14px;border:1px solid rgba(148,163,184,.22);background:#02061759;color:var(--text);cursor:pointer;font-weight:600;transition:transform .18s cubic-bezier(.23,1,.32,1),border-color .18s ease,background .18s ease,box-shadow .18s ease}.btn:hover{transform:translateY(-2px);border-color:#22d3ee59;background:#02061773;box-shadow:0 12px 28px #0f172aa6}.btn:active{transform:translateY(0);box-shadow:0 6px 18px #0f172a8c}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.btn:focus-visible{outline:none;box-shadow:var(--ring)}.btn-sm{padding:8px 10px;border-radius:12px;font-size:12px}.btn-primary{background:radial-gradient(circle at top left,rgba(255,255,255,.3),transparent 55%),linear-gradient(135deg,#fff3,#ffffff14);border-color:var(--brand);box-shadow:0 12px 32px #00000080;color:#fff}.btn-primary:hover{border-color:var(--brand2);box-shadow:0 16px 44px #0009}.btn-danger{border-color:#fb718580;background:#fb718514;color:#fecdd3f2}.btn-ghost{background:transparent}.chips{display:flex;gap:8px;flex-wrap:wrap}.chip{padding:6px 12px;font-size:12px;border-radius:999px;background:#02061752;border:1px solid rgba(148,163,184,.24);color:var(--muted);font-weight:600;transition:border-color .14s ease,background .14s ease,transform .14s ease}.chip:hover{border-color:#22d3ee80;background:#0206176b;transform:translateY(-1px)}.gridCards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}@media(max-width:1100px){.gridCards{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}}@media(max-width:680px){.gridCards{grid-template-columns:1fr;gap:14px}}.recipeCard{padding:16px;border-radius:var(--radius-lg);border:1px solid rgba(148,163,184,.22);background:linear-gradient(135deg,#0a1220d9,#0a1220bf);transition:transform .2s cubic-bezier(.23,1,.32,1),border-color .2s ease,background .2s ease,box-shadow .2s ease;cursor:pointer}.recipeCard:hover{transform:translateY(-4px) scale(1.01);border-color:var(--brand);background:linear-gradient(135deg,#0a1220f2,#0a1220e0);box-shadow:0 16px 40px #0f172ad9}.recipeCard:focus-visible{outline:none;border-color:#22d3eee6;box-shadow:0 0 0 1px #22d3ee80,0 16px 34px #0f172ae6}.recipeCardTitle{font-weight:900;letter-spacing:-.02em;margin:0;font-size:14px}.recipeCardMeta{margin:8px 0 0;font-size:12px;color:var(--muted2)}.recipeCard-main{display:flex;flex-direction:column;gap:10px}.recipeCard-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.recipeCard-avatar{width:56px;height:56px;border-radius:16px;overflow:hidden;border:1px solid rgba(148,163,184,.18);background:#02061752;display:grid;place-items:center;flex-shrink:0}.recipeCard-avatar-img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.recipeCard-avatar-fallback{font-size:22px;opacity:.85}.recipeCard-content{flex:1;min-width:0}.recipeCard-header-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.recipeCard-category-pill{font-size:10px;text-transform:uppercase;letter-spacing:.08em;padding:4px 10px;border-radius:999px;border-color:#22d3eeb3;background:#082f4999;color:#e2e8f0e6;white-space:nowrap}.recipeCard-rating-row{display:flex;align-items:center;gap:8px;margin-top:6px;flex-wrap:wrap}.recipeCard-rating-small{font-size:12px}.recipeCard-dates{margin-top:6px;font-size:11px}.recipeCard-actions{margin-top:10px;padding-top:8px;border-top:1px solid rgba(148,163,184,.22);display:flex;width:100%;justify-content:flex-end;align-items:center;gap:8px;flex-wrap:wrap}.recipeCard-actions-secondary{display:flex;gap:8px;flex-wrap:wrap}.recipeCard-actions .btn-sm{padding:6px 10px;border-radius:999px;font-size:11px}@media(max-width:720px){.recipeCard-actions{justify-content:flex-start}}.recipeCardStars{font-size:12px;letter-spacing:1px;display:inline-flex;align-items:center}.recipeCardStars-filled{color:#fbbf24;text-shadow:0 0 8px rgba(250,204,21,.5);font-weight:600}.recipeCardStars-empty{color:#94a3b873}.hr{border:0;border-top:1px solid rgba(148,163,184,.18);margin:14px 0}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes toastIn{0%{opacity:0;transform:translate(24px) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.75}}*{--transition-fast: .14s;--transition-base: .18s;--transition-slow: .22s}.toastHost{position:fixed;right:18px;bottom:18px;display:grid;gap:10px;width:min(360px,calc(100vw - 32px));z-index:9999}.toast{position:relative;padding:14px 40px 14px 16px;border-radius:16px;border:1px solid rgba(148,163,184,.24);background:#020617a6;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--shadow-soft);animation:toastIn .22s cubic-bezier(.23,1,.32,1) both}.toastTitle{font-weight:900;letter-spacing:-.01em;font-size:13px}.toastMsg{margin-top:4px;font-size:12px;color:#94a3b8e0;line-height:1.4}.toastX{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:12px;border:1px solid rgba(148,163,184,.16);background:#02061740;color:#e2e8f0d9;cursor:pointer}.toast-success{border-color:#10b98166;box-shadow:0 0 0 1px #10b9812e inset,var(--shadow-soft)}.toast-error{border-color:#ef444466;box-shadow:0 0 0 1px #ef44442e inset,var(--shadow-soft)}.toast-info{border-color:#22d3ee66;box-shadow:0 0 0 1px #22d3ee2e inset,var(--shadow-soft)}@keyframes toastIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.modalOverlay{position:fixed;inset:0;background:#020617b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:grid;place-items:center;padding:18px;z-index:9998;animation:fadeUp .18s ease both}.modalCard{width:min(520px,100%);background:linear-gradient(135deg,#0f172af2,#0a1220e6);border:1px solid rgba(148,163,184,.28);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:20px}.modalTitle{font-weight:900;letter-spacing:-.02em;font-size:15px}.modalMsg{margin-top:6px;color:#94a3b8db;font-size:13px;line-height:1.35}.modalActions{display:flex;gap:10px;justify-content:flex-end;margin-top:14px}.text-truncate-1,.text-truncate-2,.text-truncate-3{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-box-orient:vertical;word-break:break-word;overflow-wrap:anywhere}.text-truncate-1{line-clamp:1;-webkit-line-clamp:1}.text-truncate-2{line-clamp:2;-webkit-line-clamp:2}.text-truncate-3{line-clamp:4;-webkit-line-clamp:4}.rating-stars{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.rating-star{border-radius:999px;min-width:34px;height:34px;font-size:18px;display:flex;align-items:center;justify-content:center;padding:0;border-color:#94a3b880;background:#0f172acc;color:#64748b;transition:transform .12s ease-out,box-shadow .15s ease-out,background .15s ease-out,color .15s ease-out,border-color .15s ease-out}.rating-star--active{color:#fbbf24;border-color:#facc15e6;background:radial-gradient(circle at top,#facc1538,#0f172af2);box-shadow:0 0 18px #facc1540}.rating-star:hover{transform:translateY(-1px) scale(1.03);box-shadow:0 10px 25px #0f172a73}.rating-star:active{transform:translateY(0) scale(.93)}.rating-value{margin-left:6px;font-size:12px}.timer-chip{background:#0f172ae6;border-color:#94a3b880}.timer-chip--running{border-color:#38bdf8e6;background:radial-gradient(circle at top left,#38bdf829,#0f172af2)}.chip-kind{background:#0f172ae6;border-color:#94a3b899}.card-main-recipe{box-shadow:0 24px 80px #0f172ab3}.recipe-header-main{min-width:0}.recipe-category{font-size:12px}.recipe-title{margin-top:4px}.recipe-meta-chips{display:flex;gap:10px;margin-top:10px;flex-wrap:wrap}.recipe-dates{margin-top:8px;font-size:11px;display:flex;gap:12px}.recipe-image-wrapper{width:260px;max-width:100%;height:220px;border-radius:18px;overflow:hidden;border:1px solid rgba(148,163,184,.18);background:radial-gradient(circle at top,#0f172a,#0f172acc);display:flex;align-items:center;justify-content:center;flex-shrink:0}.recipe-image{max-width:100%;max-height:100%;width:auto;height:auto;-o-object-fit:contain;object-fit:contain;display:block;transition:transform .16s ease-out,filter .16s ease-out}.recipe-image-wrapper:hover .recipe-image{transform:scale(1.02);filter:saturate(1.08)}.recipe-image-empty{font-size:28px;opacity:.75;text-align:center;padding:8px}.recipe-rating{flex:1;min-width:0}.recipe-rating-label{font-size:11px;margin-bottom:6px}.ingredients-header{align-items:flex-end}.ingredients-counter{font-size:12px}.ingredients-list{display:grid;grid-template-columns:minmax(0,1fr);gap:8px}.ingredient-item{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:10px;align-items:center;padding:10px;cursor:pointer}.ingredient-item--checked{opacity:.85}.ingredient-checkbox{width:18px;height:18px}.ingredient-main{min-width:0}.ingredient-name{font-weight:600;letter-spacing:-.01em}.ingredient-item--checked .ingredient-name{text-decoration:line-through}.ingredient-qty{font-size:12px;margin-top:2px}.ingredient-qty-chip{justify-self:end;font-variant-numeric:tabular-nums;opacity:.9}.steps-list{display:flex;flex-direction:column;gap:12px}.step-card{padding:12px;width:100%}.step-card--active{border:1px solid rgba(34,211,238,.5);background:radial-gradient(circle at top left,rgba(34,211,238,.12),transparent)}.step-card-header{display:flex;gap:12px;align-items:center;justify-content:space-between;flex-wrap:wrap}.step-card-header-left{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.step-title{font-weight:900;letter-spacing:-.02em}.step-kind-chip{font-size:12px;font-weight:700;display:inline-flex;align-items:center;gap:6px}.step-description{line-height:1.4;margin-top:6px}.step-temperature{font-size:12px;margin-top:6px}.step-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}.cookmode-card{padding:18px}.cookmode-label{font-size:12px}.cookmode-title{margin-top:6px}.cookmode-progress{margin-top:10px}.cookmode-progress-bar{height:10px;border-radius:999px;background:#94a3b824;overflow:hidden;border:1px solid rgba(148,163,184,.14)}.cookmode-progress-fill{height:100%;background:linear-gradient(90deg,#38bdf8,#5eead4);transition:width .25s ease-out}.cookmode-progress-text{margin-top:6px;font-size:12px}.cookmode-grid{margin-top:18px;display:grid;gap:16px;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr)}.cookmode-step{min-width:0}.cookmode-step-header{display:flex;align-items:center;gap:10px;margin-bottom:10px;flex-wrap:wrap}.cookmode-step-title{font-weight:800;letter-spacing:-.02em}.cookmode-step-kind{font-size:12px;font-weight:700;display:inline-flex;align-items:center;gap:6px}.cookmode-step-description{line-height:1.5;max-width:100%;white-space:normal;overflow-wrap:break-word;word-break:break-word}.cookmode-right{display:flex;flex-direction:column;gap:12px}.cookmode-meta-row{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;flex-wrap:wrap}.cookmode-meta-label{font-size:11px}.cookmode-timer{font-variant-numeric:tabular-nums;font-size:18px;margin-top:4px}.cookmode-temp{margin-top:4px}.cookmode-timer-actions{display:flex;gap:10px;flex-wrap:wrap}.cookmode-step-nav{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}.layout-row-between{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.layout-row-start{display:flex;align-items:flex-start;gap:16px;flex-wrap:wrap}.layout-row-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.page-header{margin-bottom:12px}.page-title{margin:0;font-size:18px;letter-spacing:-.02em}.page-subtitle{margin:2px 0 0;font-size:12px;color:var(--muted2)}.card-soft{background:#0f172adb;border-radius:var(--radius-xl);border:1px solid rgba(148,163,184,.23);padding:14px;box-shadow:0 12px 30px #0f172ab3}.form-grid{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(0,1fr);gap:14px;align-items:flex-start}@media(max-width:900px){.form-grid{grid-template-columns:minmax(0,1fr)}}.field-label{font-size:12px;color:var(--muted2);margin-bottom:4px}.field-input,.field-select,.field-textarea{width:100%;padding:8px 10px;border-radius:12px;background:#02061752;border:1px solid rgba(148,163,184,.24);color:var(--text);outline:none;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.field-input::-moz-placeholder,.field-textarea::-moz-placeholder{color:#94a3b8a6}.field-input::placeholder,.field-textarea::placeholder{color:#94a3b8a6}.field-input:focus-visible,.field-select:focus-visible,.field-textarea:focus-visible{border-color:#22d3eecc;box-shadow:var(--ring);background:#02061766;outline:none}.field-textarea{resize:vertical;min-height:70px}.section-header{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px}.ingredients-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}.ingredient-row{display:grid;grid-template-columns:auto minmax(0,1.8fr) minmax(0,.7fr) minmax(0,.7fr) minmax(0,1.3fr) auto;gap:8px;align-items:center;padding:8px 10px;border-radius:14px;background:#0f172ae6;border:1px solid rgba(148,163,184,.2)}.step-index{font-size:12px;width:20px;text-align:right;color:var(--muted2);font-variant-numeric:tabular-nums}.steps-list{display:flex;flex-direction:column;gap:10px;margin-top:8px}.step-card{border-radius:18px;border:1px solid rgba(148,163,184,.2);background:#0f172af2;padding:12px 14px;display:flex;flex-direction:column;gap:10px}.step-header{display:flex;justify-content:space-between;gap:10px;align-items:flex-start;flex-wrap:wrap}.step-header-content{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.step-index-circle{width:26px;height:26px;border-radius:999px;border:1px solid rgba(34,211,238,.7);display:grid;place-items:center;font-size:12px;color:var(--brand);background:#082f49bf;box-shadow:0 0 0 1px #0f172ae6}.step-kind-select{max-width:180px}.step-meta-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:4px}.step-footer{display:flex;justify-content:flex-end;margin-top:6px}.actions-row{margin-top:12px;display:flex;justify-content:flex-end;gap:10px}.emptyState{margin-top:4px;padding:28px 16px;border-radius:var(--radius-lg);border:1px dashed rgba(148,163,184,.32);background:#0f172ad9;text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px}.emptyState-icon{font-size:30px}.emptyState-title{margin:0;font-size:15px;letter-spacing:-.01em}.emptyState-text{margin:0;font-size:13px;color:var(--muted2);max-width:360px}.ingredient-usage-tag{font-size:11px;padding:2px 8px;border-radius:999px;border:1px solid rgba(148,163,184,.45);background:#0f172ae6;color:var(--muted2);white-space:nowrap}.step-ingredients-selector{margin-top:10px;padding:10px;border-radius:14px;border:1px dashed rgba(148,163,184,.35);background:radial-gradient(circle at top left,#22d3ee1f,#0f172af5)}.step-ingredients-selector-header{display:flex;justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:6px}.step-ingredients-selector-hint{font-size:11px;color:var(--muted2)}.step-ingredient-chip{border-radius:999px;padding:4px 9px;font-size:11px;border:1px solid rgba(148,163,184,.45);background:#0f172af2;display:inline-flex;align-items:center;gap:6px;cursor:pointer;transition:background .13s ease,border-color .13s ease,transform 80ms ease}.step-ingredient-chip:hover{transform:translateY(-1px);border-color:#5eead4cc}.step-ingredient-chip--active{border-color:#5eead4f2;background:radial-gradient(circle at top left,#2dd4bf59,#0f172afa)}.step-ingredient-chip-dot{width:8px;height:8px;border-radius:999px;background:#5eead4f2}.ingredients-warning{margin-top:8px;font-size:12px;padding:6px 10px;border-radius:10px;background:#facc150f;color:#facc15}.step-ingredients-chips{display:flex;flex-wrap:wrap;gap:6px}.step-ingredient-chip{border-radius:999px;padding:4px 9px;font-size:11px;border:1px solid rgba(148,163,184,.45);background:#0f172af2;display:inline-flex;align-items:center;gap:6px;cursor:pointer;transition:background .13s ease,border-color .13s ease,transform 80ms ease,box-shadow .12s ease,color .12s ease;color:var(--muted2)}.step-ingredient-chip:hover{transform:translateY(-1px)}.step-ingredient-chip--active{border-color:#2563eb;background:radial-gradient(circle at top left,#2563eb5c,#0f172a);color:#dbeafe}.step-ingredient-chip--used-elsewhere{border-color:#dc2626;background:radial-gradient(circle at top left,#dc26265c,#0f172a);color:#fee2e2}.step-ingredient-chip--unused{border-color:#eab308;background:radial-gradient(circle at top left,#eab3083d,#0f172a);color:#fef9c3}.step-ingredient-chip-dot{width:8px;height:8px;border-radius:999px;background:currentColor}.step-ingredient-chip-label{white-space:nowrap}.settings-grid{display:grid;gap:20px}.settings-grid-inner{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.surface{background:#0f172a99;border:1px solid rgba(148,163,184,.2);border-radius:var(--radius-lg);padding:14px}.setting-tile{display:flex;justify-content:space-between;align-items:center;gap:16px}.setting-tile__text{flex:1}.setting-title{font-weight:800;font-size:14px;margin:0}.switch{position:relative;width:50px;height:28px;cursor:pointer}.switch input{display:none}.switch span{position:absolute;inset:0;background:#334155cc;border-radius:999px;border:1px solid rgba(148,163,184,.3);transition:all .2s ease}.switch span:after{content:"";position:absolute;width:22px;height:22px;border-radius:999px;background:#e2e8f0f2;top:2px;left:2px;transition:all .2s ease;box-shadow:0 2px 6px #0006}.switch input:checked+span{background:linear-gradient(135deg,#ffffff4d,#ffffff26);border-color:var(--brand)}.switch input:checked+span:after{left:calc(100% - 24px)}.accent-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:8px}.accent-swatch{position:relative;height:60px;border-radius:14px;border:2px solid rgba(148,163,184,.3);background:#0f172acc;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:8px}.accent-swatch span:first-child{width:24px;height:24px;border-radius:8px}.accent-swatch:nth-child(1) span:first-child{background:linear-gradient(135deg,#22d3ee,#0ea5e9)}.accent-swatch:nth-child(2) span:first-child{background:linear-gradient(135deg,#10b981,#059669)}.accent-swatch:nth-child(3) span:first-child{background:linear-gradient(135deg,#f59e0b,#d97706)}.accent-swatch:nth-child(4) span:first-child{background:linear-gradient(135deg,#f43f5e,#e11d48)}.accent-swatch__label{font-size:11px;font-weight:700;color:var(--muted2);text-align:center;letter-spacing:-.01em}.accent-swatch:hover{border-color:#22d3ee99;transform:translateY(-2px);box-shadow:0 8px 20px #0f172a80}.accent-swatch--active{border-color:var(--brand);background:radial-gradient(circle at top left,#ffffff1a,#0f172af2);box-shadow:0 0 0 1px var(--brand) inset,0 8px 24px #082f4980}.section-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:12px}.badge{padding:6px 12px;border-radius:999px;background:#ffffff14;border:1px solid var(--brand);color:var(--brand);font-size:12px;font-weight:700;white-space:nowrap}.stack{display:flex;flex-direction:column;gap:8px}.control-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}[data-compact=true]{--radius-xl: 18px;--radius-lg: 14px;--radius-md: 10px;--gap-xs: 4px;--gap-sm: 6px;--gap-md: 8px}[data-compact=true] *{gap:var(--gap-md)!important}[data-compact=true] .sidebar{padding:8px 4px}[data-compact=true] .navItem{padding:6px 10px;font-size:13px;gap:8px}[data-compact=true] .navItem-icon{width:20px;height:20px;font-size:14px}[data-compact=true] .navItem-label{display:none}[data-compact=true] .navItem.active:before,[data-compact=true] .navItem.active:after{width:3px}[data-compact=true] .outlet{padding:12px}[data-compact=true] .topbar{padding:8px 12px;gap:8px}[data-compact=true] .card,[data-compact=true] .panel,[data-compact=true] .settings-group{padding:12px;gap:8px;margin-bottom:8px}[data-compact=true] .card h2,[data-compact=true] .card h3,[data-compact=true] .panel h2,[data-compact=true] .panel h3{font-size:14px;margin:0 0 6px}[data-compact=true] .card p,[data-compact=true] .panel p{font-size:13px;margin:0}[data-compact=true] .form-group,[data-compact=true] label{gap:4px;margin-bottom:6px}[data-compact=true] input,[data-compact=true] select,[data-compact=true] textarea{padding:6px 8px;font-size:13px}[data-compact=true] .btn,[data-compact=true] button{padding:6px 12px;font-size:13px;gap:6px}[data-compact=true] table{font-size:13px}[data-compact=true] tr{height:32px}[data-compact=true] td,[data-compact=true] th{padding:6px 8px}[data-compact=true] .recipeCard{padding:10px}[data-compact=true] .recipeCard-title{font-size:13px;margin-bottom:4px}[data-compact=true] .recipeCard-meta{font-size:11px;gap:4px}[data-compact=true] .grid{gap:8px}[data-compact=true] .gridCols-2{grid-template-columns:repeat(2,1fr)}[data-compact=true] .gridCols-3{grid-template-columns:repeat(3,1fr)}[data-compact=true] .modal-header{padding:8px 12px;gap:8px}[data-compact=true] .modal-body{padding:12px}[data-compact=true] .modal-footer{padding:8px 12px;gap:8px}[data-compact=true] .p-xs{padding:2px}[data-compact=true] .p-sm{padding:4px}[data-compact=true] .p-md{padding:8px}[data-compact=true] .p-lg{padding:12px}[data-compact=true] .m-xs{margin:2px}[data-compact=true] .m-sm{margin:4px}[data-compact=true] .m-md{margin:8px}[data-compact=true] .m-lg{margin:12px}[data-compact=true] .gap-xs{gap:4px}[data-compact=true] .gap-sm{gap:6px}[data-compact=true] .gap-md{gap:8px}[data-compact=true] .gap-lg{gap:12px}.profiles-list{display:flex;flex-direction:column;gap:8px}.profile-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:var(--radius-lg);background:#ffffff0a;border:1px solid var(--stroke);transition:all .16s ease}.profile-item:hover{background:#ffffff14;border-color:var(--stroke-strong)}.profile-item span{font-weight:500;flex:1}.profile-actions{display:flex;gap:6px}.profile-actions .btn{padding:4px 8px;font-size:14px;border-radius:6px}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .16s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:linear-gradient(135deg,var(--panel-strong),rgba(10,18,32,.9));border:1px solid var(--stroke);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:420px;width:90%;max-height:80vh;overflow-y:auto;animation:slideUp .2s cubic-bezier(.16,1,.3,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--stroke);gap:12px}.modal-header h3{margin:0;font-size:16px;font-weight:600;flex:1}.modal-body{padding:20px}.modal-footer{display:flex;gap:10px;justify-content:flex-end;padding:12px 20px;border-top:1px solid var(--stroke)}.modal-footer .btn{min-width:80px}.outlet-container{display:flex;flex-direction:column;gap:20px}.fridge-hero{background:linear-gradient(135deg,#22d3ee1a,#0ea5e90d);border:1px solid var(--stroke);border-radius:var(--radius-lg);padding:24px;display:flex;align-items:flex-start;justify-content:space-between;gap:24px}.fridge-hero__content h1{font-size:28px;font-weight:700;margin:0 0 6px;letter-spacing:-.01em}.fridge-subtitle{color:var(--muted2);font-size:14px;margin:0}.fridge-stats{display:flex;gap:16px}.stat{background:#ffffff0a;border:1px solid var(--stroke);border-radius:12px;padding:16px 20px;text-align:center;min-width:140px}.stat__label{font-size:11px;color:var(--muted2);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.stat__value{font-size:28px;font-weight:700;color:var(--brand)}.fridge-panel{display:flex;flex-direction:column;gap:16px;max-height:70vh;overflow-y:auto}.panel-title{font-size:18px;font-weight:700;margin:0}.fridge-add-form{background:#ffffff05;border:1px solid var(--stroke);border-radius:var(--radius-md);padding:14px}.fridge-input-grid{display:grid;grid-template-columns:1.5fr .8fr 1fr auto;gap:10px;align-items:flex-end}.fridge-input-grid .btn{white-space:nowrap}.fridge-items-container{flex:1;min-height:200px;overflow-y:auto}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;color:var(--muted2)}.empty-state__icon{font-size:48px;margin-bottom:12px;opacity:.7}.empty-state__text{font-weight:600;margin-bottom:6px}.empty-state__hint{font-size:13px;color:var(--muted)}.fridge-items-list{display:flex;flex-direction:column;gap:8px}.fridge-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:#ffffff08;border:1px solid var(--stroke);border-radius:10px;transition:all .12s ease}.fridge-item:hover{background:#ffffff0f;border-color:var(--brand)}.fridge-item__info{flex:1}.fridge-item__name{font-weight:600;margin-bottom:2px}.fridge-item__qty{font-size:12px;color:var(--muted2)}.fridge-synonyms{border-top:1px solid var(--stroke);padding-top:12px}.fridge-syn-editor{margin-top:12px;background:#ffffff05;border:1px solid var(--stroke);border-radius:var(--radius-md);padding:12px}.fridge-syn-editor textarea{width:100%;min-height:120px;resize:vertical;font-family:Monaco,Menlo,monospace;font-size:12px}.fridge-filters{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.fridge-filters input{flex:1;min-width:200px}.fridge-filters select{min-width:140px}.filter-checkbox{display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.filter-checkbox input[type=checkbox]{cursor:pointer}.recipes-section{border-top:1px solid var(--stroke);padding-top:16px}.recipes-section__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid var(--stroke)}.recipes-section__header.ready{border-bottom-color:#10b98166}.recipes-section__header.partial{border-bottom-color:#f59e0b4d}.recipes-section__title{font-weight:700;font-size:15px}.missing-items{background:#f59e0b14;border:1px solid rgba(245,158,11,.3);border-radius:10px;padding:12px;margin-bottom:14px}.missing-chips{display:flex;flex-wrap:wrap;gap:6px}.recipes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;margin-bottom:12px}.recipe-card{position:relative;background:linear-gradient(135deg,#ffffff0d,#ffffff05);border:1px solid var(--stroke);border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:8px;transition:all .2s ease;text-decoration:none;color:inherit;cursor:pointer}.recipe-card:hover{border-color:var(--brand);background:linear-gradient(135deg,#22d3ee1f,#22d3ee0a);transform:translateY(-4px);box-shadow:0 8px 24px #22d3ee26}.recipe-card.ready{border-color:#10b98166;background:linear-gradient(135deg,#10b98114,#10b98105)}.recipe-card.ready:hover{border-color:#10b981cc;box-shadow:0 8px 24px #10b98133}.recipe-card.partial{border-color:#f59e0b4d;background:linear-gradient(135deg,#f59e0b0d,#f59e0b03)}.recipe-card.partial:hover{border-color:#f59e0bb3;box-shadow:0 8px 24px #f59e0b26}.recipe-card__header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.recipe-card__title{font-weight:700;font-size:14px;margin:0;flex:1;line-height:1.3}.recipe-card__coverage{background:var(--brand);color:var(--bg0);font-weight:700;font-size:11px;padding:4px 8px;border-radius:6px;white-space:nowrap}.recipe-card__category{font-size:12px;color:var(--muted2);margin:0;text-transform:capitalize}.recipe-card__rating{font-size:12px;color:var(--warn);font-weight:600}.recipe-card__missing{font-size:11px;color:var(--muted);line-height:1.4}.recipe-card__cta{margin-top:4px;font-size:12px;font-weight:600;color:var(--brand);display:flex;align-items:center;gap:4px}.recipes-more{font-size:12px;color:var(--muted2);text-align:center;padding:8px 0;font-style:italic}@media(max-width:1200px){.recipes-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.fridge-hero{flex-direction:column;align-items:stretch}.fridge-stats{width:100%}}@media(max-width:768px){.twoCol{grid-template-columns:1fr!important}.fridge-input-grid,.recipes-grid{grid-template-columns:1fr}.fridge-hero{padding:16px}.fridge-stats{gap:8px}.stat{min-width:100px;padding:12px 16px}}.modalScrollArea{overflow-y:auto;overflow-x:hidden}.modalScrollArea::-webkit-scrollbar{width:6px}.modalScrollArea::-webkit-scrollbar-track{background:#0f172a66}.modalScrollArea::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#22d3ee99,#0ea5e966);border-radius:999px;border:2px solid rgba(15,23,42,.6)}.modalScrollArea::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#22d3eecc,#0ea5e999)}.modalScrollArea{scrollbar-width:thin;scrollbar-color:rgba(14,165,233,.5) rgba(15,23,42,.4)}
