:root{--bg: #14181d;--panel: #1c232b;--card: #232c36;--border: #313c47;--text: #e8edf2;--muted: #8fa0b0;--accent: #f5a623;--ferment: #e8873a;--ferment-dark: #c26a1f;--lager: #3a8fe8;--lager-dark: #1f66c2;--danger: #e05252}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;overflow:hidden;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text)}.app{max-width:1200px;margin:0 auto;padding:0 20px;height:100vh;display:flex;flex-direction:column}main{flex:1;min-height:0;display:flex;flex-direction:column;overflow-y:auto;padding-bottom:20px}.app-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;padding:20px 0}.app-header h1{margin:0;font-size:22px}.tabs{display:flex;gap:6px}.tabs button{background:var(--panel);color:var(--muted);border:1px solid var(--border);padding:8px 16px;border-radius:8px;cursor:pointer;font-size:14px}.tabs button.active{background:var(--accent);color:#1a1a1a;border-color:var(--accent);font-weight:600}.banner{padding:10px 14px;border-radius:8px;margin-bottom:16px;cursor:pointer}.banner.error{background:#3a1e1e;border:1px solid var(--danger);color:#f3b4b4}.banner.notice{background:#1e2f3a;border:1px solid var(--lager);color:#b4d8f3}.tabs .signout{margin-left:8px;border-color:var(--border)}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.login-card{width:100%;max-width:360px;display:flex;flex-direction:column;gap:12px;margin-bottom:0}.login-card h1{margin:0;font-size:22px;text-align:center}.login-sub{margin:0;text-align:center;color:var(--muted)}.login-card .banner{cursor:default;margin-bottom:0}.login-toggle{text-align:center;color:var(--muted);font-size:13px;margin:4px 0 0}.login-toggle button,.link-btn{background:none;border:none;color:var(--accent);cursor:pointer;font-size:13px;padding:0;text-decoration:underline}.link-btn{align-self:center}.login-card code{background:var(--bg);padding:1px 5px;border-radius:4px;font-size:12px}.login-help{margin:4px 0 0;text-align:center;color:var(--muted);font-size:13px}.admin-user-form,.admin-user-list{max-width:720px}.admin-user-row{display:flex;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px solid var(--border);color:var(--muted);font-size:13px}.admin-user-row strong{color:var(--text)}.admin-badge{margin-left:8px;padding:2px 7px;border-radius:999px;background:var(--accent);color:#1a1a1a;font-size:11px;font-weight:700}.panel{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:20px}.panel h2{margin-top:0}.card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:16px;margin-bottom:20px}.card h3{margin:0 0 12px;font-size:15px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:14px}label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted)}label.checkbox{flex-direction:row;align-items:center;gap:8px;color:var(--text);align-self:end}input,select{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:8px 10px;font-size:14px;width:100%}label.checkbox input{width:auto}input:focus,select:focus{outline:none;border-color:var(--accent)}button{font-family:inherit}button.primary{background:var(--accent);color:#1a1a1a;border:none;padding:9px 18px;border-radius:8px;font-weight:600;cursor:pointer}button.danger{background:transparent;color:var(--danger);border:1px solid var(--danger);padding:5px 10px;border-radius:6px;cursor:pointer;font-size:13px}.table{width:100%;border-collapse:collapse}.table th,.table td{text-align:left;padding:8px;border-bottom:1px solid var(--border);font-size:14px}.table th{color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.03em}.table td.center{text-align:center}.table input,.table select{padding:6px 8px;font-size:13px}.empty{color:var(--muted);text-align:center;padding:20px}.form-grid label.wide{grid-column:1 / -1}.brew-data-grid+.table-scroll{display:none}.brew-data-grid{width:100%;height:calc(100vh - 145px);min-height:420px}.brew-data-grid .ag-root-wrapper{border-radius:0}.brew-data-grid .ag-header-cell-text{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.grid-link{color:var(--accent);text-decoration:none}.grid-delete{border:0;background:transparent;color:#e98383;cursor:pointer}.table-scroll{overflow-x:auto}.brewlog-table{min-width:1400px}.brewlog-table th,.brewlog-table td{padding:6px;white-space:nowrap}.brewlog-table input,.brewlog-table select{min-width:70px}.brewlog-table .col-name input{min-width:130px;font-weight:600}.brewlog-table .col-num input{min-width:60px;width:70px}.brewlog-table .col-comment input{min-width:200px}.brewlog-table .col-link{text-align:center}.brewlog-table .col-link a{color:var(--accent);font-size:16px;text-decoration:none}.brewlog-table .muted{color:var(--muted)}.legend{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:13px;margin-bottom:14px}.swatch{display:inline-block;width:16px;height:12px;border-radius:3px;margin-left:10px}.swatch.ferment{background:var(--ferment)}.swatch.lager{background:var(--lager)}.swatch.conflict{background:repeating-linear-gradient(45deg,rgba(224,82,82,.55),rgba(224,82,82,.55) 4px,transparent 4px,transparent 8px);border:1px solid var(--danger)}.conflict-banner{background:#3a1e1e;border:1px solid var(--danger);border-radius:8px;padding:10px 14px;margin-bottom:14px;color:#f3b4b4;font-size:13px}.conflict-banner strong{display:block;margin-bottom:6px;color:#f6c2c2}.conflict-banner ul{margin:0;padding-left:18px}.conflict-flag{color:var(--danger)}.timeline-panel{flex:1;min-height:0;display:flex;flex-direction:column}.timeline{border:1px solid var(--border);border-radius:10px;overflow:hidden;flex:1;min-height:0;display:flex;flex-direction:column}.timeline-scroll{flex:1;overflow:auto}.timeline-inner{min-width:min-content}.chamber-label{width:180px;min-width:180px;padding:8px 12px;border-right:1px solid var(--border);background:var(--card);position:sticky;left:0;z-index:2;display:flex;flex-direction:column;justify-content:center}.chamber-name{font-weight:600;font-size:14px}.chamber-title{display:flex;align-items:center;gap:6px}.expand-btn{display:inline-flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--muted);cursor:pointer;padding:2px;border-radius:6px;line-height:0}.expand-btn svg{transition:transform .15s ease}.expand-btn.open svg{transform:rotate(90deg)}.expand-btn:hover{background:#ffffff14;color:var(--text)}.chamber-meta{font-size:11px;color:var(--muted);margin-top:2px}.timeline-header-row,.timeline-row{display:flex}.timeline-header-row{position:sticky;top:0;z-index:4;background:var(--card)}.header-corner{display:flex;align-items:center;font-weight:600;color:var(--muted);z-index:6}.header-tracks{flex-shrink:0}.month-band{display:flex;border-bottom:1px solid var(--border)}.month-cell{flex-shrink:0;padding:6px 8px;font-size:12px;font-weight:600;color:var(--text);border-right:1px solid var(--border);white-space:nowrap;overflow:hidden}.day-band{display:flex}.day-cell{flex-shrink:0;text-align:center;font-size:11px;color:var(--muted);padding:4px 0;border-right:1px solid rgba(255,255,255,.03)}.day-cell.weekend{background:#ffffff08}.timeline-row{border-top:1px solid var(--border)}.timeline-row:nth-of-type(odd) .track{background:#ffffff04}.timeline-row:nth-of-type(2n) .track{background:#0000002e}.timeline-row:nth-of-type(2n) .chamber-label{background:#1e262f}.track{position:relative;flex-shrink:0;height:76px}.gridline{position:absolute;top:0;bottom:0;border-right:1px solid rgba(255,255,255,.04)}.gridline.weekend{background:#ffffff08}.lane-guide{position:absolute;left:0;right:0;border-bottom:1px dashed rgba(255,255,255,.07);z-index:0;pointer-events:none}.today-marker{position:absolute;top:0;bottom:0;width:2px;background:var(--accent);z-index:1}.conflict-overlay{position:absolute;top:0;bottom:0;background:repeating-linear-gradient(45deg,#e052528c,#e052528c 5px,#e052522e 5px,#e052522e 10px);z-index:2;pointer-events:none}.bar{position:absolute;top:14px;height:48px;border-radius:6px;display:flex;align-items:center;padding:0 8px;overflow:hidden;z-index:1;box-shadow:0 1px 3px #0006;cursor:grab;-webkit-user-select:none;user-select:none}.bar.dragging{cursor:grabbing;z-index:3;opacity:.9;box-shadow:0 4px 12px #00000080;pointer-events:none}.track.drop-ok{box-shadow:inset 0 0 0 2px #3a8fe8b3;background:#3a8fe814}.track.drop-bad{box-shadow:inset 0 0 0 2px #e05252b3;background:#e0525214;cursor:not-allowed}.bar.ferment{background:linear-gradient(var(--ferment),var(--ferment-dark))}.bar.lager{background:linear-gradient(var(--lager),var(--lager-dark))}.bar-label{font-size:12px;font-weight:600;color:#fff;white-space:nowrap;text-shadow:0 1px 2px rgba(0,0,0,.4)}.app{max-width:none;margin:0;padding:0;display:grid;grid-template-columns:224px minmax(0,1fr)}.app-header{grid-row:1;height:100vh;padding:28px 18px 18px;background:#101418;border-right:1px solid #2b333b;display:flex;flex-direction:column;align-items:stretch;flex-wrap:nowrap}.app-header h1{font-size:0;line-height:1.25;padding:0 10px 24px;border-bottom:1px solid var(--border)}.app-header h1:before{content:"BREWERY OPS";font-size:15px;letter-spacing:.11em}.tabs{margin-top:18px;display:flex;flex:1;flex-direction:column;gap:3px}.tabs button{width:100%;padding:10px 12px;border:0;border-radius:4px;background:transparent;text-align:left}.tabs button:nth-child(2){order:1}.tabs button:nth-child(1){order:2}.tabs button:nth-child(3){order:3;margin-top:18px}.tabs button:nth-child(4){order:4}.tabs button.active{background:#2e353a;color:#f3f0e9;border-left:3px solid var(--accent)}.tabs .signout{order:10;margin:auto 0 0;color:var(--muted);border-top:1px solid var(--border);border-radius:0}.app>.banner{position:fixed;z-index:30;top:16px;right:20px}.app>main{grid-column:2;grid-row:1;padding:30px 34px}.panel{padding:0;border:0;border-radius:0;background:transparent}.page-heading{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:22px;padding-bottom:16px;border-bottom:1px solid var(--border)}.page-heading h2,.modal-header h3{margin:3px 0 0;font-size:24px;letter-spacing:-.025em}.eyebrow{color:var(--accent);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.modal-backdrop{position:fixed;z-index:50;top:0;right:0;bottom:0;left:0;padding:32px;display:grid;place-items:center;background:#07090bc7}.modal{width:min(920px,100%);max-height:calc(100vh - 64px);overflow:auto;overflow-x:hidden;background:#1c2227;border:1px solid #3b454e;box-shadow:0 24px 80px #0000008c}.modal-header{position:sticky;z-index:2;top:0;display:flex;align-items:center;justify-content:space-between;padding:20px 22px 16px;background:#1c2227;border-bottom:1px solid var(--border)}.modal-close{width:34px;height:34px;border:1px solid var(--border);background:transparent;color:var(--muted);cursor:pointer}.modal .add-form{margin:0;padding:22px;border:0;border-radius:0;background:transparent}.add-form label:has(+datalist),.add-form datalist{display:none}.method-select+label,.method-select.compact+input{display:none}.method-select.compact{display:block}.method-select.compact select{min-width:150px}.style-picker-field{position:relative;min-width:0}.field-label{display:block;margin-bottom:6px;color:var(--muted);font-size:13px}.style-picker-trigger{width:100%;min-height:36px;padding:8px 10px;display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);cursor:pointer;text-align:left}.style-picker-trigger:focus,.style-picker-trigger[aria-expanded=true]{outline:none;border-color:var(--accent)}.style-picker-trigger .placeholder{color:#6f7d89}.style-picker-menu{position:absolute;z-index:20;top:calc(100% + 6px);right:0;width:min(680px,calc(100vw - 128px));height:390px;display:grid;grid-template-columns:245px 1fr;overflow:hidden;background:#151a1f;border:1px solid #46515b;box-shadow:0 18px 48px #0000007a}.style-category-list,.style-child-list{overflow-y:auto;padding:7px}.style-category-list{border-right:1px solid var(--border);background:#11161a}.style-category-list button,.style-child-list button{width:100%;display:flex;align-items:center;gap:10px;padding:9px 10px;border:0;border-radius:3px;background:transparent;color:var(--text);cursor:pointer;text-align:left}.style-category-list button{justify-content:space-between;color:var(--muted)}.style-category-list button:hover,.style-category-list button.active{background:#293138;color:var(--text)}.style-child-list button:hover,.style-child-list button.selected{background:#293138}.style-child-list button.selected{box-shadow:inset 3px 0 var(--accent)}.style-menu-title{position:sticky;top:-7px;margin:-7px -7px 6px;padding:12px 14px;background:#1b2228;border-bottom:1px solid var(--border);color:var(--muted);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.style-code{width:30px;flex:0 0 30px;color:var(--accent);font-size:12px;font-variant-numeric:tabular-nums}@media (max-width: 760px){.app{grid-template-columns:1fr;grid-template-rows:auto minmax(0,1fr)}.app-header{width:100%;height:auto;padding:12px 14px}.app-header h1{display:none}.tabs{margin:0;flex-direction:row;overflow-x:auto}.tabs button,.tabs button:nth-child(3){width:auto;margin-top:0;white-space:nowrap}.tabs .signout{margin:0 0 0 auto;border:0}.app>main{grid-column:1;grid-row:2;padding:20px 14px}.modal-backdrop{padding:0}.modal{max-height:100vh;height:100vh}.style-picker-menu{position:fixed;top:96px;right:12px;bottom:12px;left:12px;width:auto;height:auto;grid-template-columns:minmax(130px,42%) 1fr}}
