:root{--bg: #0b0f17;--surface: #11161f;--surface-alt: #161c28;--border: #222b3a;--text: #ffffff;--muted: #aab4c4;--faint: #6b7686;--primary: #2f7fff;--accent: #7cc4ff;--success: #46d39a;--warn: #ffb454;--danger: #ff6b6b}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased}.center{display:flex;align-items:center;justify-content:center;height:100vh}.muted{color:var(--muted)}.small{font-size:13px}.app{display:flex;height:100vh}.sidebar{width:248px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:22px 16px}.brand{font-size:22px;font-weight:800;letter-spacing:.3px;padding:6px 10px 22px}.brand-lg{font-size:30px;padding:0 0 8px}.nav{display:flex;flex-direction:column;gap:4px}.nav-item{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:transparent;border:0;cursor:pointer;color:var(--muted);font-size:15px;font-weight:600;padding:11px 12px;border-radius:10px;transition:background .12s,color .12s}.nav-item:hover{background:var(--surface-alt);color:var(--text)}.nav-item.active{background:#2f7fff29;color:var(--text)}.nav-icon{font-size:17px}.sidebar-footer{margin-top:auto;display:flex;flex-direction:column;gap:10px;padding-top:18px}.email{color:var(--faint);font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:0 4px}.content{flex:1;overflow:auto;padding:40px 48px}.page-title{font-size:30px;font-weight:800;margin:0 0 24px}.section{font-size:13px;text-transform:uppercase;letter-spacing:.5px;color:var(--faint);margin:32px 0 12px}.card-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}@media(max-width:1100px){.card-grid{grid-template-columns:repeat(2,1fr)}}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:20px}.stat-label{color:var(--faint);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:30px;font-weight:800;margin-top:8px}.stat-value.success{color:var(--success)}.stat-value.warn{color:var(--warn)}.stat-sub{color:var(--muted);font-size:13px;margin-top:2px}.list{display:flex;flex-direction:column;gap:8px}.list-row{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px 18px}.row-name{font-weight:700}.row-sub{color:var(--muted);font-size:13px;margin-top:2px}.row-sub.accent{color:var(--accent)}.recipe .make{text-align:center;min-width:64px}.make-num{color:var(--success);font-size:24px;font-weight:900}.make-label{color:var(--faint);font-size:11px}.badge{display:inline-block;font-size:11px;font-weight:800;padding:3px 9px;border-radius:999px}.badge.warn{color:var(--warn);background:#ffb45424}.empty{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:32px;text-align:center;color:var(--muted)}.table{width:100%;border-collapse:collapse}.table th{text-align:left;color:var(--faint);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:0 16px 12px}.table th.num,.table td.num{text-align:right}.table td{padding:14px 16px;border-top:1px solid var(--border)}.cell-main{display:flex;align-items:center;gap:12px}.thumb{width:40px;height:40px;border-radius:8px;object-fit:cover;background:#fff}.thumb-fallback{display:flex;align-items:center;justify-content:center;background:var(--surface-alt);color:var(--accent);font-weight:800}.panel{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:22px;margin-bottom:18px;max-width:560px}.panel-title{font-size:13px;text-transform:uppercase;letter-spacing:.5px;color:var(--faint);margin-bottom:14px}.kv{display:flex;justify-content:space-between;padding:9px 0;border-top:1px solid var(--border)}.kv:first-of-type{border-top:0}.btn{border:0;border-radius:12px;cursor:pointer;background:var(--primary);color:#fff;font-size:15px;font-weight:700;padding:12px 18px;transition:opacity .12s,transform .05s}.btn:hover{opacity:.9}.btn:active{transform:scale(.98)}.btn.ghost{background:var(--surface-alt);color:var(--text)}.btn.danger{background:#ff6b6b26;color:var(--danger)}.page-head{display:flex;align-items:center;justify-content:space-between}.meals-layout{display:grid;grid-template-columns:320px 1fr;gap:22px;margin-top:22px;align-items:start}@media(max-width:980px){.meals-layout{grid-template-columns:1fr}}.recipe-list{display:flex;flex-direction:column;gap:8px}.recipe-list.empty-pane{padding:24px;color:var(--muted);background:var(--surface);border:1px solid var(--border);border-radius:14px}.recipe-item{display:flex;align-items:center;justify-content:space-between;gap:12px;text-align:left;cursor:pointer;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px 16px;color:var(--text);transition:border-color .12s,background .12s}.recipe-item:hover{border-color:var(--faint)}.recipe-item.active{border-color:var(--primary);background:#2f7fff1a}.recipe-item-main{min-width:0}.editor-pane{position:sticky;top:0}.editor,.editor-empty{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:22px}.editor-empty{text-align:center;color:var(--muted);padding:56px 22px}.editor-empty-icon{font-size:40px;margin-bottom:8px}.editor-empty p{margin:0 0 16px}.editor-head{display:flex;align-items:center;gap:16px;margin-bottom:8px}.editor-name{flex:1;background:var(--surface-alt);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:20px;font-weight:700;padding:12px 14px}.editor-name:focus{outline:none;border-color:var(--primary)}.makeable-pill{flex-shrink:0;color:var(--muted);font-size:13px;background:var(--surface-alt);border:1px solid var(--border);border-radius:999px;padding:8px 14px}.makeable-num{color:var(--success);font-weight:900;font-size:16px}.field-label{color:var(--faint);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin:20px 0 10px}.chips{display:flex;flex-wrap:wrap;gap:8px}.chip{cursor:pointer;background:var(--surface-alt);border:1px solid var(--border);border-radius:999px;color:var(--muted);font-size:14px;font-weight:700;padding:8px 16px;transition:all .12s}.chip:hover{color:var(--text)}.chip.active{background:#2f7fff29;border-color:var(--primary);color:var(--text)}.ing-list{display:flex;flex-direction:column;gap:8px}.ing-row{display:flex;align-items:center;gap:12px;background:var(--surface-alt);border:1px solid var(--border);border-radius:12px;padding:10px 14px}.ing-row.limiter{border-color:var(--warn)}.ing-name{flex:1;min-width:0;font-weight:600;display:flex;align-items:center;gap:10px}.ing-stock{color:var(--faint);font-size:12px;font-weight:600;flex-shrink:0}.amount-input{width:64px;text-align:right;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:14px;font-weight:700;padding:7px 9px}.amount-input:focus{outline:none;border-color:var(--primary)}.unit-toggle{display:flex;background:var(--surface);border-radius:8px;padding:2px;gap:2px}.unit-toggle button{border:0;cursor:pointer;background:transparent;color:var(--faint);font-size:12px;font-weight:700;padding:6px 9px;border-radius:6px}.unit-toggle button:hover{color:var(--text)}.unit-toggle button.active{background:var(--primary);color:#fff}.ing-remove{border:0;background:transparent;color:var(--danger);cursor:pointer;font-size:15px;font-weight:700;padding:6px}.image-row{display:flex;align-items:center;gap:14px;margin-bottom:18px}.recipe-image{width:120px;height:120px;flex-shrink:0;cursor:pointer;border:1px dashed var(--border);border-radius:14px;background-size:cover;background-position:center;background-color:var(--surface-alt);display:flex;align-items:center;justify-content:center}.recipe-image:hover{border-color:var(--primary)}.image-hint{color:var(--faint);font-size:14px;font-weight:700}.image-clear{border:0;background:transparent;color:var(--danger);cursor:pointer;font-size:13px;font-weight:700}.recipe-thumb{width:44px;height:44px;flex-shrink:0;border-radius:10px;object-fit:cover;background:var(--surface-alt)}.recipe-thumb-fallback{display:flex;align-items:center;justify-content:center;font-size:20px}.picker{margin-top:12px}.picker-search{width:100%;background:var(--surface-alt);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:14px;padding:11px 14px}.picker-search:focus{outline:none;border-color:var(--primary)}.picker-results{display:flex;flex-direction:column;gap:4px;margin-top:8px}.picker-item{display:flex;align-items:center;justify-content:space-between;cursor:pointer;text-align:left;background:transparent;border:0;border-radius:8px;padding:10px 12px;color:var(--text);font-size:14px}.picker-item:hover{background:var(--surface-alt)}.picker-add{color:var(--accent);font-size:18px;font-weight:800}.picker-empty{padding:10px 12px}.editor-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:24px}.btn:disabled{opacity:.5;cursor:default}.login{display:flex;align-items:center;justify-content:center;height:100vh;padding:24px}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:24px;padding:40px;width:420px;max-width:100%;text-align:center}.login-card h1{font-size:22px;margin:8px 0 10px}.login-card p{margin:0 auto 20px;max-width:320px;line-height:1.5}.qr-frame{background:#fff;border-radius:18px;padding:20px;width:max-content;margin:8px auto 20px;line-height:0}.qr-placeholder{width:232px;height:232px;display:flex;align-items:center;justify-content:center;font-size:40px;color:var(--faint)}
