:root{--bg: #f6f7f3;--panel: #ffffff;--ink: #20242a;--muted: #68717a;--line: #dde3df;--accent: #2c756c;--accent-2: #b06b3c;--accent-3: #6b5c9a;--danger: #b3261e;--success: #23724a;--gold-soft: #f3ead7}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input,textarea,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed}a{color:inherit}.boot,.auth-shell{min-height:100vh;display:grid;place-items:center}.auth-panel{width:min(440px,calc(100vw - 32px));background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:28px;box-shadow:0 18px 60px #20242a14}.brand-row,.side-brand{display:flex;align-items:center;gap:12px}.brand-mark{width:48px;height:48px;display:grid;place-items:center;color:#fff;background:var(--accent);border-radius:999px}.brand-mark.small{width:36px;height:36px}h1,h2,h3{margin:0}h2{font-size:21px}h3{font-size:14px}p{color:var(--muted);line-height:1.6}.auth-form,.stack,.admin-stack{display:grid;gap:16px}.auth-form{margin-top:26px}label{display:grid;gap:8px;color:var(--muted);font-size:14px}input,textarea,select{width:100%;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);padding:11px 12px;outline:none}textarea{min-height:128px;resize:vertical;line-height:1.6}input:focus,textarea:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2c756c1f}.primary-btn{border:0;background:var(--accent);color:#fff;border-radius:8px;padding:12px 16px;display:inline-flex;align-items:center;justify-content:center;gap:8px;text-decoration:none}.primary-btn.compact{padding:10px 14px;white-space:nowrap}.primary-btn:disabled{opacity:.55}.link-btn,.logout-btn{border:0;background:transparent;color:var(--accent);padding:10px 0}.quiet-note,.muted{color:var(--muted);font-size:13px}.error-box,.success-box{border-radius:8px;padding:11px 12px;font-size:14px}.error-box{background:#fff0ef;color:var(--danger);border:1px solid #ffd3cf}.success-box{background:#ecf8f1;color:var(--success);border:1px solid #c9ecd8}.status-note{width:fit-content;border:1px solid var(--line);border-radius:8px;padding:8px 10px;color:var(--muted);background:#f8f7f2;font-size:13px}.status-note.success{color:var(--success);border-color:#c9ecd8;background:#ecf8f1}.app-shell{min-height:100vh;display:grid;grid-template-columns:260px 1fr}.sidebar{background:#fff;border-right:1px solid var(--line);padding:22px;display:flex;flex-direction:column;gap:26px}.side-brand span,.user-line span{display:block;color:var(--muted);font-size:12px;overflow:hidden;text-overflow:ellipsis}nav{display:grid;gap:8px}nav button,.logout-btn{display:flex;align-items:center;gap:10px;border:0;border-radius:8px;padding:11px 12px;background:transparent;color:var(--muted);text-align:left}.nav-group-label{color:var(--muted);font-size:12px;font-weight:700;margin:10px 0 2px;padding:0 12px}nav button.active{background:#e8f2ef;color:var(--accent)}.side-user{margin-top:auto;display:grid;gap:12px}.balance-pill{display:inline-flex;align-items:center;gap:8px;background:var(--gold-soft);color:#7a4a24;border-radius:999px;padding:8px 12px;width:fit-content}.role-badge,.self-tag,.status-pill,.balance-summary{width:fit-content;border-radius:999px;font-size:12px;font-weight:700}.role-badge{background:#e8f2ef;color:var(--accent);padding:6px 10px}.self-tag{display:inline-flex;margin-left:8px;background:var(--gold-soft);color:#7a4a24;padding:3px 7px}.status-pill{display:inline-flex;background:#f3f4f1;color:var(--muted);padding:3px 8px}.status-pill.success{background:#ecf8f1;color:var(--success)}.status-pill.muted{background:#f3f4f1;color:var(--muted)}.balance-summary{margin-top:12px;background:var(--gold-soft);color:#7a4a24;padding:8px 12px}.user-line{display:flex;align-items:center;gap:8px;min-width:0}.main-panel{padding:26px;overflow:auto}.panel{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:20px}.modal-backdrop{position:fixed;inset:0;z-index:30;display:grid;place-items:center;padding:20px;background:#1118275c}.modal-panel{width:min(420px,100%);display:grid;gap:14px;border:1px solid var(--line);border-radius:8px;background:#fff;padding:20px;box-shadow:0 24px 70px #1118272e}.modal-panel h3,.modal-panel p{margin:0}.modal-panel p{color:var(--muted)}.modal-actions{display:flex;justify-content:flex-end;gap:10px}.panel.narrow{max-width:780px}.panel-head,.toolbar-panel{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}.panel-head{margin-bottom:16px}.toolbar-panel{align-items:center}.workbench-grid{display:grid;grid-template-columns:minmax(380px,.9fr) minmax(500px,1.1fr);gap:18px}.preset-details summary{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer;font-weight:800}.preset-details summary::-webkit-details-marker{display:none}.preset-details summary:before{content:"+";width:24px;height:24px;border:1px solid var(--line);border-radius:8px;display:grid;place-items:center;color:var(--accent)}.preset-details[open] summary:before{content:"-"}.preset-details summary span{margin-right:auto}.preset-details summary small{color:var(--muted);font-weight:700}.preset-list{display:grid;gap:10px;margin-top:14px}.preset-row{border:1px solid var(--line);background:#fafbf9;border-radius:8px;padding:9px;display:flex;align-items:center;gap:10px;text-align:left;color:var(--ink)}.preset-row:hover{border-color:var(--accent);box-shadow:0 10px 26px #20242a14}.preset-row img{width:58px;height:58px;flex:0 0 58px;object-fit:cover;border-radius:6px;background:#ece8de}.preset-row span{min-width:0;display:grid;gap:4px}.preset-row strong{font-size:15px}.preset-row small{color:var(--muted);font-size:12px}.ai-form,.admin-form{display:grid;grid-template-columns:repeat(2,minmax(180px,1fr));gap:14px;align-items:end}.ai-form .wide,.admin-form .wide{grid-column:1 / -1}.panel>.admin-form{margin-bottom:14px}.small-textarea{min-height:96px}.result-panel{min-height:520px}.empty{border:1px dashed var(--line);border-radius:8px;padding:36px 24px;display:grid;justify-items:center;gap:12px;color:var(--muted)}.cocktail-card{--accent: #d3a95f;display:grid;grid-template-columns:220px 1fr;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:#fff}.cocktail-visual{min-height:100%;display:grid;place-items:center;color:#fff}.cocktail-visual img{width:100%;height:100%;min-height:260px;object-fit:cover}.cocktail-body{padding:18px;display:grid;gap:14px}.card-title-row,.card-foot,.entry-meta,.tavern-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.card-title-row{justify-content:space-between}.card-title-row strong{color:var(--accent);font-size:14px}.mood-chip{display:inline-flex;width:fit-content;background:#f4f1e8;color:#7a4a24;border-radius:999px;padding:4px 9px;font-size:12px;margin-bottom:6px}.tag-row{display:flex;flex-wrap:wrap;gap:8px}.quote-lead{color:#4e5660;font-weight:700;line-height:1.7}.tag-row span{border:1px solid color-mix(in srgb,var(--accent) 45%,var(--line));color:var(--accent);border-radius:999px;padding:4px 8px;font-size:12px}.recipe-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.recipe-grid ul,.recipe-grid ol{margin:8px 0 0;padding-left:18px;color:var(--muted);line-height:1.7}.recipe-grid li{margin-bottom:5px}.recipe-grid b{color:var(--ink);margin-right:8px}blockquote{margin:0;border-left:3px solid var(--accent);padding-left:12px;color:#4e5660;line-height:1.6}blockquote span{display:block;color:var(--muted);font-size:12px;margin-top:4px}.card-foot{justify-content:flex-end;border-top:1px solid var(--line);padding-top:12px}.card-foot>span{margin-right:auto;color:var(--muted);font-size:13px}.card-action-group{display:inline-flex;align-items:center;gap:8px}.action-hint{font-size:16px;line-height:1}.search-form,.inline-form{display:flex;align-items:center;gap:10px}.search-form{min-width:min(520px,100%)}.search-form input,.inline-form input,.inline-form select{max-width:320px}.tavern-grid,.entry-list{display:grid;gap:16px}.pagination-bar{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap;color:var(--muted);font-size:13px;margin-top:14px}.pagination-bar span{margin-right:auto}.tavern-item,.entry-row{display:grid;gap:10px}.tavern-meta,.entry-meta{color:var(--muted);font-size:13px}.note-line{margin:0;background:#f8f7f2;border:1px solid var(--line);border-radius:8px;padding:10px 12px}.admin-grid{display:grid;grid-template-columns:repeat(2,minmax(320px,1fr));gap:18px}.admin-form button{width:fit-content}.mini-list{display:grid;gap:8px;margin-top:14px}.mini-list span{border:1px solid var(--line);border-radius:8px;color:var(--muted);font-size:13px;padding:8px 10px}.action-row{display:flex;gap:8px;flex-wrap:wrap}.detail-filter{margin-bottom:14px}.mini-btn{border:1px solid var(--line);background:#fff;color:var(--accent);border-radius:8px;padding:7px 9px;font-size:13px;display:inline-flex;align-items:center;gap:6px;text-decoration:none}.mini-btn+.mini-btn{margin-left:8px}.mini-btn:disabled{cursor:not-allowed;opacity:.45}.mini-btn.danger{color:var(--danger)}.export-links{display:flex;gap:8px;flex-wrap:wrap}.export-links a{color:var(--accent);text-decoration:none;font-weight:600}.report-grid{display:grid;grid-template-columns:repeat(7,minmax(90px,1fr));gap:10px;margin-bottom:14px}.metric{border:1px solid var(--line);border-radius:8px;padding:12px;background:#fafbfc}.metric span{display:block;color:var(--muted);font-size:12px;margin-bottom:6px}.metric strong{font-size:22px}.json-box{white-space:pre-wrap;word-break:break-word;margin:0;line-height:1.65;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;background:#f6f7f9;border-radius:8px;padding:12px;max-height:420px;overflow:auto}.table-wrap{overflow:auto}table{width:100%;border-collapse:collapse;font-size:14px}th,td{text-align:left;border-bottom:1px solid var(--line);padding:10px;vertical-align:top}th{color:var(--muted);font-weight:600}.positive{color:var(--success)}.negative{color:var(--danger)}.detail-cell{max-width:360px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width:1120px){.workbench-grid,.admin-grid{grid-template-columns:1fr}.report-grid{grid-template-columns:repeat(2,minmax(120px,1fr))}}@media(max-width:900px){.app-shell{grid-template-columns:1fr}.sidebar{position:static}.toolbar-panel,.panel-head{display:grid}.ai-form,.admin-form,.recipe-grid,.cocktail-card{grid-template-columns:1fr}.cocktail-visual img{max-height:280px}.search-form,.inline-form{align-items:stretch;flex-direction:column}.search-form input,.inline-form input,.inline-form select{max-width:none}}
