:root{--bg: #f5f4ef;--surface: #ffffff;--surface-2: #faf9f4;--surface-3: #efede4;--border: #e3e0d3;--border-strong: #cfcbb9;--text: #1a1f17;--text-2: #5a5f53;--text-3: #8b8f80;--accent: #2d5016;--accent-hover: #3a6a1d;--accent-soft: #e6ecdd;--accent-ink: #1f3a0e;--malt: #b8860b;--malt-soft: #f6e9c4;--wort: #c97a2b;--wort-soft: #f6dcc2;--rust: #9c3a2a;--rust-soft: #f3d5cd;--info: #2e5a8a;--info-soft: #d8e4f0;--radius-sm: 4px;--radius: 6px;--radius-lg: 10px;--shadow-sm: 0 1px 0 rgba(20,25,15,.04), 0 1px 2px rgba(20,25,15,.06);--shadow: 0 1px 2px rgba(20,25,15,.05), 0 4px 14px rgba(20,25,15,.06);--shadow-lg: 0 6px 28px rgba(20,25,15,.12);--font: "Sarabun", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--mono: "IBM Plex Mono", ui-monospace, "SF Mono", Menlo, monospace;--density-row: 40px;--sidebar-w: 232px}[data-theme=dark]{--bg: #11140e;--surface: #181c14;--surface-2: #1f231a;--surface-3: #262b1f;--border: #2d3326;--border-strong: #3d4533;--text: #ecebe2;--text-2: #a8a89a;--text-3: #6f7363;--accent: #8fb463;--accent-hover: #a3c478;--accent-soft: #2a3a18;--accent-ink: #d4e6b3;--malt-soft: #3a2f0e;--wort-soft: #3a2410;--rust-soft: #3a1a14;--info-soft: #122740;--shadow-sm: 0 1px 0 rgba(0,0,0,.4);--shadow: 0 1px 2px rgba(0,0,0,.4), 0 4px 14px rgba(0,0,0,.3)}[data-density=compact]{--density-row: 32px}[data-density=comfortable]{--density-row: 48px}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--font);font-size:14px;color:var(--text);background:var(--bg);line-height:1.5;-webkit-font-smoothing:antialiased}button,input,select,textarea{font:inherit;color:inherit}input,select,textarea{font-family:var(--font)}.num,.mono{font-family:var(--mono);font-feature-settings:"tnum"}.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}.app[data-sidebar=collapsed]{--sidebar-w: 60px}.sidebar{background:var(--surface);border-right:1px solid var(--border);position:sticky;top:0;height:100vh;display:flex;flex-direction:column;overflow:hidden}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:16px 16px 14px;border-bottom:1px solid var(--border);min-height:56px}.brand-mark{width:28px;height:28px;background:var(--accent);color:#fff;border-radius:6px;display:grid;place-items:center;font-weight:700;font-size:14px;flex-shrink:0;font-family:var(--mono)}.brand-name{font-weight:600;letter-spacing:-.01em;white-space:nowrap}.brand-sub{font-size:11px;color:var(--text-3);letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}.sidebar-nav{flex:1;padding:12px 8px;overflow-y:auto}.nav-group{margin-bottom:14px}.nav-label{padding:0 10px 6px;font-size:10.5px;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;font-weight:600;white-space:nowrap}.app[data-sidebar=collapsed] .nav-label{visibility:hidden;height:6px}.nav-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:var(--radius);color:var(--text-2);cursor:pointer;font-size:13.5px;border:none;background:none;width:100%;text-align:left;white-space:nowrap;position:relative}.nav-item:hover{background:var(--surface-3);color:var(--text)}.nav-item.active{background:var(--accent-soft);color:var(--accent-ink);font-weight:600}[data-theme=dark] .nav-item.active{color:var(--accent-ink)}.nav-item svg{flex-shrink:0}.nav-item .badge{margin-left:auto;background:var(--accent);color:#fff;font-size:10.5px;padding:1px 6px;border-radius:10px;font-family:var(--mono)}.app[data-sidebar=collapsed] .nav-item span:not(.badge){display:none}.app[data-sidebar=collapsed] .nav-item .badge{position:absolute;top:2px;right:2px;padding:0 4px}.sidebar-foot{padding:10px;border-top:1px solid var(--border);display:flex;align-items:center;gap:10px}.avatar{width:28px;height:28px;border-radius:50%;background:var(--surface-3);display:grid;place-items:center;font-weight:600;font-size:12px;color:var(--text-2);flex-shrink:0}.avatar.amber{background:var(--malt-soft);color:var(--malt)}.foot-user-name{font-size:13px;font-weight:500;white-space:nowrap}.foot-user-role{font-size:11px;color:var(--text-3);white-space:nowrap}.app[data-sidebar=collapsed] .sidebar-foot>*:not(.avatar){display:none}.main{display:flex;flex-direction:column;min-width:0}.topbar{height:56px;flex-shrink:0;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:16px;position:sticky;top:0;z-index:10}.crumb{font-size:13px;color:var(--text-2);display:flex;align-items:center;gap:6px}.crumb strong{color:var(--text);font-weight:600}.topbar-spacer{flex:1}.company-switch{display:flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-2);cursor:pointer;font-size:13px;min-width:200px}.company-switch:hover{border-color:var(--border-strong)}.company-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0}.company-label{flex:1}.company-label .name{font-weight:600}.company-label .sub{font-size:11px;color:var(--text-3)}.icon-btn{width:34px;height:34px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface-2);display:grid;place-items:center;cursor:pointer;color:var(--text-2)}.icon-btn:hover{background:var(--surface-3);color:var(--text)}.icon-btn .dot{position:absolute;width:6px;height:6px;border-radius:50%;background:var(--rust);top:8px;right:8px}.page{flex:1;padding:24px 28px 64px;overflow-x:auto;max-width:100%}.page-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:20px;gap:16px;flex-wrap:wrap}.page-title{font-size:22px;font-weight:700;letter-spacing:-.015em;margin:0 0 4px}.page-sub{color:var(--text-2);font-size:13px}.page-actions{display:flex;gap:8px}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;font-size:13px;font-weight:500;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);cursor:pointer;color:var(--text);white-space:nowrap}.btn:hover{background:var(--surface-3)}.btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn.primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn.danger{color:var(--rust);border-color:var(--rust-soft);background:var(--rust-soft)}.btn.ghost{background:transparent;border-color:transparent;padding:6px 8px}.btn.ghost:hover{background:var(--surface-3)}.btn.sm{padding:4px 10px;font-size:12.5px}.btn.icon{padding:6px}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:var(--radius);border:none;background:transparent;color:var(--text-3);cursor:pointer;transition:background .15s,color .15s}.btn-icon:hover{background:var(--surface-3);color:var(--text-1)}.field{display:flex;flex-direction:column;gap:6px}.field label,.label{font-size:12px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.04em}.input,.select,textarea.input{padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);font-size:13.5px;outline:none;width:100%;color:var(--text)}.input:focus,.select:focus,textarea.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.input.error,.select.error{border-color:var(--rust)}.input::placeholder{color:var(--text-3)}.input-search{padding-left:32px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%238b8f80' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='11' cy='11' r='8'/><path d='m21 21-4.3-4.3'/></svg>");background-repeat:no-repeat;background-position:10px center}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.card-head{padding:14px 18px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);gap:12px}.card-title{font-size:14px;font-weight:600;margin:0;display:flex;align-items:center;gap:8px}.card-body{padding:18px}.card-body.flush{padding:0}.tbl-wrap{overflow-x:auto}.tbl{width:100%;border-collapse:collapse;font-size:13.5px}.tbl thead th{text-align:left;font-size:11.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);font-weight:600;padding:10px 14px;background:var(--surface-2);border-bottom:1px solid var(--border);white-space:nowrap;position:sticky;top:0}.tbl tbody td{padding:0 14px;border-bottom:1px solid var(--border);height:var(--density-row);vertical-align:middle}.tbl tbody tr:hover{background:var(--surface-2)}.tbl tbody tr.selected{background:var(--accent-soft)}.tbl tbody tr:last-child td{border-bottom:none}.tbl td .row-actions{display:flex;gap:2px;opacity:0;transition:opacity .12s}.tbl tbody tr:hover .row-actions{opacity:1}.tbl .num{text-align:right;font-family:var(--mono)}.tbl .checkbox-col{width:32px;padding-right:0}.tag{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;padding:2px 8px;border-radius:999px;background:var(--surface-3);color:var(--text-2);letter-spacing:.02em;white-space:nowrap}.tag.green{background:var(--accent-soft);color:var(--accent-ink)}.tag.amber{background:var(--malt-soft);color:var(--malt)}.tag.rust{background:var(--rust-soft);color:var(--rust)}.tag.wort{background:var(--wort-soft);color:var(--wort)}.tag.info{background:var(--info-soft);color:var(--info)}.tag .dot{width:6px;height:6px;border-radius:50%;background:currentColor}.kpis{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:16px}.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px}.kpi-label{font-size:11.5px;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.kpi-value{font-size:24px;font-weight:700;letter-spacing:-.02em;font-family:var(--mono);margin-top:6px}.kpi-delta{font-size:11.5px;color:var(--text-3);margin-top:4px;font-family:var(--mono)}.kpi-delta.up{color:var(--accent)}.kpi-delta.down{color:var(--rust)}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:18px}.tab{padding:8px 14px;font-size:13px;font-weight:500;color:var(--text-2);border:none;background:none;cursor:pointer;position:relative;border-bottom:2px solid transparent;margin-bottom:-1px}.tab:hover{color:var(--text)}.tab.active{color:var(--accent);font-weight:600;border-bottom-color:var(--accent)}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#14190f66;z-index:100;display:grid;place-items:center;padding:20px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:560px;max-height:86vh;overflow:auto;box-shadow:var(--shadow-lg);border:1px solid var(--border)}.modal.lg{max-width:880px}.modal-head{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:16px;font-weight:600;margin:0}.modal-body{padding:20px}.modal-foot{padding:14px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;background:var(--surface-2)}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.grid-form{display:grid;grid-template-columns:1fr 1fr;gap:14px 16px}.grid-form .full{grid-column:1 / -1}.tanks{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:14px}.tank{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:12px;cursor:pointer;position:relative;transition:transform .12s,border-color .12s}.tank:hover{border-color:var(--accent);transform:translateY(-2px)}.tank-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.tank-id{font-weight:700;font-family:var(--mono);font-size:13px}.tank-size{font-size:11px;color:var(--text-3);font-family:var(--mono)}.tank-vessel{width:100%;height:140px;position:relative}.tank-vessel svg{width:100%;height:100%;display:block}.tank-foot{margin-top:10px;text-align:center}.tank-beer{font-size:12.5px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tank-stage{font-size:10.5px;color:var(--text-3);font-family:var(--mono);text-transform:uppercase;letter-spacing:.04em;margin-top:2px}.tank-progress{height:3px;background:var(--surface-3);border-radius:2px;margin-top:8px;overflow:hidden}.tank-progress>div{height:100%;background:var(--accent);transition:width .4s}.timeline{display:grid;grid-template-columns:110px 1fr;gap:12px}.tl-day{font-size:12px;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-weight:600;padding-top:4px}.tl-day .date{display:block;font-size:18px;color:var(--text);font-family:var(--mono);font-weight:700;letter-spacing:-.01em}.tl-day .month{font-size:11px}.tl-events{display:flex;flex-direction:column;gap:8px}.tl-event{padding:10px 12px;border-left:3px solid var(--accent);background:var(--surface-2);border-radius:0 var(--radius) var(--radius) 0;display:flex;gap:12px;align-items:center;cursor:pointer}.tl-event:hover{background:var(--surface-3)}.tl-event.amber{border-left-color:var(--malt)}.tl-event.info{border-left-color:var(--info)}.tl-event.wort{border-left-color:var(--wort)}.tl-event-body{flex:1;min-width:0}.tl-event-title{font-weight:600;font-size:13.5px}.tl-event-sub{font-size:11.5px;color:var(--text-3);font-family:var(--mono)}.bar-chart{display:flex;align-items:flex-end;gap:6px;height:140px;padding:8px 0}.bar-chart .bar{flex:1;background:var(--accent-soft);border-radius:3px 3px 0 0;position:relative;min-height:4px;transition:background .12s}.bar-chart .bar.active,.bar-chart .bar:hover{background:var(--accent)}.chart-labels{display:flex;gap:6px;font-size:10.5px;color:var(--text-3);font-family:var(--mono);margin-top:4px}.chart-labels span{flex:1;text-align:center}.stack{display:flex;flex-direction:column;gap:12px}.row{display:flex;align-items:center;gap:10px}.row.wrap{flex-wrap:wrap}.row.between{justify-content:space-between}.spacer{flex:1}.muted{color:var(--text-3)}.tiny{font-size:11.5px}.small{font-size:12.5px}.divider{height:1px;background:var(--border);margin:14px 0}.right{text-align:right}.empty-state{padding:60px 20px;text-align:center;color:var(--text-3)}.empty-state svg{opacity:.5;margin-bottom:12px}.check{width:16px;height:16px;border:1.5px solid var(--border-strong);border-radius:3px;background:var(--surface);cursor:pointer;display:inline-grid;place-items:center;flex-shrink:0}.check.checked{background:var(--accent);border-color:var(--accent)}.check.checked:after{content:"";width:8px;height:4px;border-left:2px solid white;border-bottom:2px solid white;transform:rotate(-45deg) translate(1px,-1px)}.brand-pill{display:inline-flex;align-items:center;gap:6px;background:var(--surface-3);font-size:11px;padding:2px 8px;border-radius:999px;color:var(--text-2)}.brand-pill .dot{width:6px;height:6px;border-radius:50%}
