:root{--color-bg:#0f0f0f;--color-surface:#1a1a1a;--color-surface-hover:#222;--color-border:#2a2a2a;--color-text:#e5e5e5;--color-text-muted:#888;--color-accent:#d4a853;--color-accent-hover:#e0b963;--color-success:#4ade80;--color-warning:#fbbf24;--color-error:#f87171}*{margin:0;padding:0;box-sizing:border-box}.recharts-surface,.recharts-wrapper,.recharts-wrapper svg{outline:none}body,html{background-color:var(--color-bg);color:var(--color-text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}.nav{justify-content:space-between;padding:1rem 2rem;border-bottom:1px solid var(--color-border);background-color:var(--color-surface)}.nav,.nav-brand{display:flex;align-items:center}.nav-logo{height:36px;width:auto;object-fit:contain}.nav-hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:4px}.nav-hamburger span{display:block;width:22px;height:2px;background-color:var(--color-text);border-radius:2px;transition:opacity .15s}.nav-links{display:flex;gap:2rem;list-style:none}.nav-links a{color:var(--color-text-muted);font-size:.9rem;font-weight:500;transition:color .15s}.nav-links a.active,.nav-links a:hover{color:var(--color-text)}@media (max-width:640px){.nav{flex-wrap:wrap;position:relative}.nav-hamburger{display:flex}.nav-links{display:none;width:100%;flex-direction:column;gap:0;padding:.5rem 0;border-top:1px solid var(--color-border);margin-top:.5rem}.nav-links--open{display:flex}.nav-links li a{display:block;padding:.75rem 0;font-size:1rem}}.page{max-width:1200px;margin:0 auto;padding:2rem}.page-title{font-size:1.75rem;font-weight:700;margin-bottom:.5rem}.page-subtitle{color:var(--color-text-muted);font-size:.95rem;margin-bottom:2rem}.artwork-header{display:flex;gap:2rem;align-items:flex-start;margin-bottom:2rem;flex-wrap:wrap}@media (max-width:480px){.artwork-header{flex-direction:column;align-items:center}.artwork-header>div{width:100%;text-align:left}}.card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;padding:1.25rem}.card-title{font-size:1rem;font-weight:600;margin-bottom:.5rem}.tap-grid{display:grid;grid-template-columns:repeat(6,1fr);grid-gap:.75rem;gap:.75rem;margin-bottom:2rem}@media (max-width:640px){.tap-grid{grid-template-columns:1fr;gap:.5rem}.tap-card{display:flex;align-items:center;text-align:left;padding:.75rem 1rem;gap:.75rem}.tap-number{flex-shrink:0;margin-bottom:0;min-width:3.5rem}.tap-body{flex:1 1;display:flex;flex-direction:column;gap:.4rem}.tap-body,.tap-content{min-width:0}.tap-beer-name,.tap-empty,.tap-style{white-space:normal;overflow:visible;text-overflow:clip}.tap-empty{flex:1 1}.keg-level{width:100%;margin-top:0}}.tap-card{display:block;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;padding:.75rem .5rem;text-align:center;min-width:0;transition:border-color .15s}.tap-card.active,.tap-card:hover{border-color:var(--color-accent)}.tap-number{font-size:.7rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.4rem}.tap-beer-name{font-weight:600;font-size:.85rem;margin-bottom:.2rem}.tap-beer-name,.tap-style{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tap-style{font-size:.75rem}.tap-empty,.tap-style{color:var(--color-text-muted)}.tap-empty{font-style:italic;font-size:.8rem}.keg-level{height:6px;background-color:var(--color-border);border-radius:3px;margin-top:.75rem;overflow:hidden}.keg-level-fill{height:100%;background-color:var(--color-accent);border-radius:3px;transition:width .3s}.section{margin-bottom:2rem}.section-title{font-weight:600;margin-bottom:1rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.85rem}.batch-list{display:flex;flex-direction:column;gap:.75rem}.batch-row{display:flex;align-items:center;justify-content:space-between;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;padding:1rem 1.25rem;transition:border-color .15s}.batch-row:hover{border-color:var(--color-accent)}.batch-info{display:flex;flex-direction:column;gap:.15rem}.batch-name{font-weight:600}.batch-meta{font-size:.85rem;color:var(--color-text-muted)}.status-badge{display:inline-block;padding:.2rem .6rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.status-badge.fermenting{background-color:rgba(132,204,22,.2);color:#84cc16}.status-badge.conditioning{background-color:rgba(99,102,241,.2);color:#6366f1}.status-badge.on_tap{background-color:rgba(234,179,8,.2);color:#eab308}.status-badge.finished{background-color:hsla(0,0%,53%,.15);color:var(--color-text-muted)}.status-badge.brewing{background-color:rgba(249,115,22,.2);color:#f97316}.status-badge.planning{background-color:hsla(0,0%,53%,.1);color:var(--color-text-muted)}.table-wrapper{overflow-x:auto}table{width:100%;border-collapse:collapse}th{text-align:left;font-size:.8rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}td,th{padding:.75rem 1rem;border-bottom:1px solid var(--color-border)}td{font-size:.9rem}tr:hover td{background-color:var(--color-surface-hover)}.srm-table{border-collapse:collapse;border:1px solid var(--color-border);width:auto}.srm-table td,.srm-table th{border:none;text-align:center;vertical-align:middle}.srm-table .axis-header,.srm-table tbody td:not(.axis-label-x):not(.axis-label-y){width:2.25rem;height:2.25rem;min-width:2.25rem;padding:0}.srm-table .axis-label-y span{display:block;writing-mode:vertical-rl;transform:rotate(180deg);white-space:nowrap}.other-stuff-link{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1.25rem;font-size:.95rem;color:var(--color-text);transition:background-color .15s,color .15s}.other-stuff-link:hover{background-color:var(--color-surface-hover);color:var(--color-accent)}.other-stuff-arrow,.other-stuff-external{flex-shrink:0;margin-left:.75rem;color:var(--color-text-muted);font-size:.85rem}.other-stuff-link:hover .other-stuff-arrow,.other-stuff-link:hover .other-stuff-external{color:var(--color-accent)}.notes-content{color:var(--color-text);line-height:1.7;font-size:.95rem}.notes-content h2{font-size:1.2rem;font-weight:600;margin:1.5rem 0 .5rem}.notes-content p{margin-bottom:.75rem}.notes-content ol,.notes-content ul{padding-left:1.5rem;margin-bottom:.75rem}.admin-shell{display:flex;flex-direction:column;min-height:100vh}.admin-topbar{display:flex;align-items:center;justify-content:space-between;padding:0 2rem;height:52px;background-color:var(--color-surface);border-bottom:1px solid var(--color-border);flex-shrink:0}.admin-topbar-brand{font-weight:700;font-size:1rem;color:var(--color-accent);letter-spacing:.02em}.admin-topbar-actions{display:flex;align-items:center;gap:1.25rem}.admin-topbar-link{font-size:.85rem;color:var(--color-text-muted);background:none;border:none;cursor:pointer;font-family:inherit;transition:color .15s}.admin-topbar-link:hover{color:var(--color-text)}.admin-topbar-logout{color:var(--color-error)}.admin-topbar-logout:hover{color:var(--color-error);opacity:.8}.admin-content{flex:1 1;padding:2rem;min-width:0;max-width:1100px;width:100%}.admin-page-title{font-size:1.5rem;font-weight:700;margin-bottom:1.5rem}.admin-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.admin-page-header .admin-page-title{margin-bottom:0}.admin-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));grid-gap:1rem;gap:1rem}.admin-dash-card{display:block;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;padding:1.25rem;transition:border-color .15s}.admin-dash-card:hover{border-color:var(--color-accent)}.admin-dash-card-label{font-weight:600;font-size:1rem;margin-bottom:.35rem}.admin-dash-card-desc{font-size:.85rem;color:var(--color-text-muted)}.admin-form{max-width:800px;display:flex;flex-direction:column;gap:1rem}.admin-form-row{display:flex;gap:1rem;flex-wrap:wrap}.admin-form-row .admin-field{flex:1 1;min-width:140px}.admin-field{display:flex;flex-direction:column;gap:.35rem}.admin-field-inline{flex-direction:row;align-items:center}.admin-label{font-size:.8rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.admin-input{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:6px;padding:.5rem .75rem;color:var(--color-text);font-size:.9rem;font-family:inherit;width:100%;max-width:100%;min-width:0;transition:border-color .15s}.admin-input:focus{outline:none;border-color:var(--color-accent)}.admin-textarea{resize:vertical}.admin-textarea-lg{min-height:400px}.admin-btn{display:inline-block;background-color:var(--color-accent);color:#0f0f0f;border:none;border-radius:6px;padding:.55rem 1.1rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:background-color .15s;text-decoration:none}.admin-btn:hover{background-color:var(--color-accent-hover)}.admin-btn:disabled{opacity:.6;cursor:default}.admin-btn-sm{padding:.4rem .85rem;font-size:.85rem;align-self:flex-start}.admin-form-actions{display:flex;align-items:center;gap:1rem}.admin-link{color:var(--color-accent);font-size:.9rem;cursor:pointer;background:none;border:none;padding:0;font-family:inherit;text-decoration:none}.admin-link:hover{text-decoration:underline}.admin-error,.admin-link-danger{color:var(--color-error)}.admin-error{font-size:.85rem}.admin-table-wrap{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-size:.9rem}.admin-table th{text-align:left;padding:.6rem .75rem;font-size:.78rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.admin-table td,.admin-table th{border-bottom:1px solid var(--color-border)}.admin-table td{padding:.7rem .75rem}.admin-table tr:hover td{background-color:var(--color-surface-hover)}.admin-table-actions{display:flex;gap:.75rem;align-items:center;white-space:nowrap}.admin-tap-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:1rem;gap:1rem}.admin-tap-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;padding:1.25rem;display:flex;flex-direction:column;gap:.75rem}.admin-tap-card-title{font-weight:700;font-size:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--color-border)}.admin-tap-volumes{display:grid;grid-template-columns:1fr 1fr;grid-gap:.75rem;gap:.75rem}.admin-input-date{width:75%;max-width:75%}.admin-login-wrap{height:100vh;height:100dvh;overflow:hidden;display:flex;align-items:center;justify-content:center;background-color:var(--color-bg)}.admin-login-box{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;padding:2.5rem;width:100%;max-width:360px;display:flex;flex-direction:column;gap:1rem}.admin-login-title{font-size:1.5rem;font-weight:700}.admin-login-sub{color:var(--color-text-muted);font-size:.9rem;margin-top:-.5rem}.sortable-th{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;white-space:nowrap}.sortable-th:hover{color:var(--color-text)}.sort-arrow{font-size:.75rem;color:var(--color-text-muted);margin-left:.25rem}.admin-section{margin-top:2.5rem;padding-top:2rem;border-top:1px solid var(--color-border)}.admin-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.admin-section-title{font-size:1.1rem;font-weight:600;margin-bottom:.25rem}.admin-section-sub{font-size:.82rem;color:var(--color-text-muted);margin-bottom:1rem}.admin-empty{font-size:.9rem;color:var(--color-text-muted);margin-top:.5rem}.admin-artwork-wrap{display:flex;align-items:flex-start;gap:1rem;flex-wrap:wrap}.admin-artwork-preview{border:1px solid var(--color-border);border-radius:6px;overflow:hidden;background:var(--color-surface)}.admin-artwork-img{display:block;width:140px;height:140px;object-fit:cover}.admin-artwork-actions{display:flex;flex-direction:column;gap:.6rem;justify-content:flex-start;padding-top:.25rem}.admin-artwork-path{font-size:.8rem;color:var(--color-text-muted);word-break:break-all}.admin-photo-grid{display:flex;flex-wrap:wrap;gap:.75rem}.admin-photo-item{position:relative;border-radius:6px;overflow:hidden;border:1px solid var(--color-border)}.admin-photo-img{display:block;width:140px;height:140px;object-fit:cover}.admin-photo-remove{position:absolute;top:4px;right:4px;background:rgba(0,0,0,.7);color:#fff;border:none;border-radius:50%;width:22px;height:22px;font-size:.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.admin-photo-remove:hover{background:rgba(220,38,38,.9)}.admin-note-add-form{display:flex;gap:1rem;align-items:flex-end;flex-wrap:wrap;margin-bottom:1.25rem;padding:1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px}.admin-note-list{display:flex;flex-direction:column;gap:.5rem}.admin-note-row{display:flex;gap:1rem;align-items:flex-start;padding:.75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:6px}.admin-note-meta{font-size:.8rem;color:var(--color-text-muted);white-space:nowrap;min-width:160px}.admin-note-text{flex:1 1;font-size:.9rem;line-height:1.5;white-space:pre-wrap}.admin-note-actions{display:flex;gap:.75rem;flex-shrink:0}.admin-note-edit{display:flex;gap:.75rem;flex-wrap:wrap;flex:1 1;align-items:flex-start}.admin-note-edit-actions{display:flex;gap:.75rem;align-items:center;padding-top:.25rem}.admin-event-form{margin-bottom:1.5rem;padding:1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;display:flex;flex-direction:column;gap:.75rem}.admin-event-list{display:flex;flex-direction:column;gap:.5rem}.admin-event-row{display:flex;gap:.75rem;align-items:flex-start;padding:.75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:6px;transition:opacity .15s}.admin-event-body{flex:1 1;min-width:0}.admin-event-header-row{display:flex;gap:.75rem;align-items:center;margin-bottom:.2rem}.admin-event-type{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-accent);font-weight:600}.admin-event-date{font-size:.8rem;color:var(--color-text-muted)}.admin-event-title{font-weight:600;font-size:.9rem;margin-bottom:.25rem}.admin-event-stats{display:flex;gap:1rem;font-size:.82rem;color:var(--color-text-muted);margin-bottom:.2rem}.admin-event-desc{font-size:.85rem;color:var(--color-text-muted);margin-top:.2rem}.admin-event-actions{display:flex;gap:.75rem;flex-shrink:0}.admin-btn-secondary{display:inline-block;background:none;color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:6px;padding:.5rem 1rem;font-size:.9rem;font-weight:500;cursor:pointer;transition:border-color .15s,color .15s;font-family:inherit;text-decoration:none}.admin-btn-secondary:hover{border-color:var(--color-accent);color:var(--color-accent)}.admin-link-btn{background:none;border:none;color:var(--color-accent);font-size:.85rem;cursor:pointer;font-family:inherit;padding:0;text-decoration:none}.admin-link-btn:hover{text-decoration:underline}.admin-link-btn-danger{color:var(--color-error)}.admin-tab-bar{display:flex;gap:0;border-bottom:1px solid var(--color-border);margin-bottom:1.5rem}.admin-tab{background:none;border:none;border-bottom:2px solid transparent;color:var(--color-text-muted);font-size:.95rem;font-family:inherit;padding:.6rem 1.25rem;cursor:pointer;transition:color .15s,border-color .15s;margin-bottom:-1px}.admin-tab:hover{color:var(--color-text)}.admin-tab.active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.admin-subsection{margin-bottom:2rem}.admin-subsection-title{font-size:.95rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.admin-inline-form{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;padding:1rem;margin:.25rem 0;display:flex;flex-direction:column;gap:.75rem}.load-more-btn{display:block;margin-top:.75rem;background:none;border:1px solid var(--color-border);border-radius:6px;color:var(--color-text-muted);font-size:.85rem;padding:.5rem 1rem;cursor:pointer;transition:border-color .15s,color .15s;font-family:inherit}.load-more-btn:hover{border-color:var(--color-accent);color:var(--color-accent)}.empty-state,.loading{text-align:center;padding:3rem;color:var(--color-text-muted)}.empty-state{font-style:italic}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));grid-gap:.75rem;gap:.75rem}@media (max-width:480px){.photo-grid{grid-template-columns:repeat(2,1fr)}}.glossary-tip{position:relative;display:inline;border-bottom:1px dotted var(--color-accent);cursor:help}.glossary-tip:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);background:var(--color-surface);border:1px solid var(--color-border);border-radius:6px;padding:.5rem .75rem;font-size:.82rem;font-weight:400;line-height:1.55;color:var(--color-text-muted);width:280px;max-width:min(280px,85vw);white-space:normal;text-align:left;z-index:200;pointer-events:none;opacity:0;transition:opacity .15s ease}.glossary-tip:focus-visible:after,.glossary-tip:hover:after{opacity:1}