:root{--bg:#121212;--canvas:#1a1a1a;--card:#242424;--border:#ffffff14;--accent:#c9a227;--accent-dim:#c9a22740;--text:#ededed;--text-muted:#a0a0a0;--text-data:#ededed}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}#root{min-height:100vh}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:inherit}.layout{min-height:100vh;display:flex}.sidebar{background:var(--canvas);border-right:1px solid var(--border);flex-direction:column;align-items:center;gap:.5rem;width:64px;padding:1.25rem 0;display:flex}.sidebar a{width:40px;height:40px;color:var(--text-muted);border-radius:8px;justify-content:center;align-items:center;transition:color .15s,background .15s;display:flex}.sidebar a:hover,.sidebar a.active{color:var(--accent);background:var(--accent-dim)}.main-wrap{flex-direction:column;flex:1;min-width:0;display:flex}.header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.5rem;display:flex}.header-logo{color:var(--text);align-items:center;gap:.5rem;font-size:1.25rem;font-weight:700;display:flex}.header-logo-icon{width:28px;height:28px;color:var(--accent)}.header-logo span{color:var(--accent)}.header-right{align-items:center;gap:.75rem;display:flex}.greeting{color:var(--text);font-size:.9375rem;font-weight:500}.avatar{background:linear-gradient(135deg, var(--accent) 0%, #8b6914 100%);border-radius:50%;flex-shrink:0;width:40px;height:40px}.content{flex:1;padding:1.5rem}.card{background:var(--card);border:1px solid var(--border);border-radius:12px;margin-bottom:1.25rem;padding:1.25rem}.section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem;font-size:.8125rem;font-weight:600}.data-font{color:var(--accent);font-family:JetBrains Mono,ui-monospace,monospace}.text-muted{color:var(--text-muted);font-size:.9375rem}.dashboard-grid{grid-template-columns:1fr 320px;align-items:start;gap:1.5rem;display:grid}@media (width<=900px){.dashboard-grid{grid-template-columns:1fr}}.dashboard-main,.dashboard-side{min-width:0}.bean-card-featured{background:var(--card);border:1px solid var(--border);border-radius:12px;margin-bottom:1.5rem;display:flex;overflow:hidden}.bean-card-featured-img{width:140px;min-height:140px;color:var(--text-muted);background:linear-gradient(#2a2a2a 0%,#1f1f1f 100%);flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;display:flex}.bean-card-featured-body{flex-direction:column;flex:1;gap:.5rem;padding:1.25rem 1.25rem 1.25rem 1rem;display:flex;position:relative}.bean-card-featured-name{color:var(--text);font-size:1.125rem;font-weight:600}.bean-card-featured-meta{color:var(--text-muted);font-size:.8125rem}.bean-card-featured-progress-wrap{margin-top:auto}.bean-card-featured-progress{background:#ffffff14;border-radius:3px;height:6px;overflow:hidden}.bean-card-featured-progress-fill{background:var(--accent);border-radius:3px;height:100%}.bean-card-featured-remaining{color:var(--text-muted);margin-top:.35rem;font-size:.8125rem}.bean-card-featured-remaining .data-font{color:var(--accent)}.card-actions{position:absolute;top:1rem;right:1rem}.card-actions-btn{width:32px;height:32px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;display:flex}.card-actions-btn:hover{color:var(--text);background:#ffffff0f}.bean-card-compact{background:var(--card);border:1px solid var(--border);color:inherit;border-radius:12px;justify-content:space-between;align-items:center;gap:.75rem;padding:1rem 1.25rem;text-decoration:none;transition:border-color .15s,background .15s;display:flex}.bean-card-compact:hover{border-color:var(--accent-dim);background:#ffffff05}.bean-card-compact-name{color:var(--text);font-size:.9375rem;font-weight:600}.bean-card-compact-meta{color:var(--text-muted);margin-top:.15rem;font-size:.8125rem}.bean-card-compact-arrow{color:var(--text-muted);flex-shrink:0}.inventory-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.bean-card{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden}.bean-card-img{height:100px;color:var(--text-muted);background:linear-gradient(#2a2a2a 0%,#1f1f1f 100%);justify-content:center;align-items:center;font-size:.75rem;display:flex}.bean-card-body{padding:.75rem 1rem}.bean-card-name{color:var(--text);margin-bottom:.25rem;font-size:.9375rem;font-weight:600}.bean-card-weight{font-size:.875rem}.bean-card-progress{background:#ffffff14;border-radius:2px;height:4px;margin-top:.5rem;overflow:hidden}.bean-card-progress-fill{background:var(--accent);border-radius:2px;height:100%}.recent-list{margin:0;padding:0;list-style:none}.recent-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.75rem 0;display:flex}.recent-item:last-child{border-bottom:none}.recent-bean{color:var(--text);font-weight:500}.recent-meta{color:var(--text-muted);font-size:.8125rem}.recent-data{font-size:.8125rem}.brew-mini-card{border:1px solid var(--border);color:inherit;background:#ffffff08;border-radius:10px;margin-bottom:.75rem;padding:1rem 1.25rem;text-decoration:none;transition:border-color .15s,background .15s;display:block;position:relative}.brew-mini-card:last-child{margin-bottom:0}.brew-mini-card:hover{border-color:var(--accent-dim);background:#ffffff0d}.brew-mini-card-time{color:var(--text-muted);margin-bottom:.25rem;font-size:.8125rem}.brew-mini-card-bean{color:var(--text);font-size:.9375rem;font-weight:600}.brew-mini-card-type{color:var(--text-muted);margin-top:.2rem;font-size:.8125rem}.brew-mini-card-dose{color:var(--text-muted);margin-top:.35rem;font-size:.8125rem}.brew-mini-card-taste{color:var(--text-muted);margin-top:.35rem;font-size:.8125rem;font-style:italic}.brew-mini-card-rating{color:var(--accent);letter-spacing:.05em;margin-top:.5rem;font-size:.875rem}.brew-mini-card-actions{position:absolute;top:.75rem;right:.75rem}.bar-chart-wrap{align-items:flex-end;gap:.5rem;height:120px;padding:.5rem 0;display:flex}.bar-chart-bar{background:#ffffff14;border-radius:6px 6px 0 0;flex:1;min-width:0;min-height:4px;transition:background .2s}.bar-chart-bar.highlight{background:var(--accent)}.bar-chart-labels{gap:.5rem;margin-top:.5rem;display:flex}.bar-chart-label{text-align:center;color:var(--text-muted);flex:1;font-size:.75rem}.insight-card{background:var(--accent-dim);border:1px solid #c9a22759;border-radius:12px;align-items:flex-start;gap:.75rem;margin-bottom:1rem;padding:1rem 1.25rem;display:flex}.insight-card-icon{color:var(--accent);flex-shrink:0;font-size:1.25rem}.insight-card-text{color:var(--text);font-size:.9375rem}.discovery-card{background:var(--card);border:1px solid var(--border);color:inherit;border-radius:12px;align-items:center;gap:1rem;padding:1.25rem;text-decoration:none;transition:border-color .15s;display:flex}.discovery-card:hover{border-color:var(--accent-dim)}.discovery-card-icon{background:var(--accent-dim);width:40px;height:40px;color:var(--accent);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.discovery-card-title{color:var(--text);font-size:.9375rem;font-weight:600}.discovery-card-badge{color:#1a1a1a;background:var(--accent);border-radius:4px;margin-left:.5rem;padding:.2rem .5rem;font-size:.6875rem;font-weight:600}.chart-container{min-height:120px}.page-title{color:var(--text);margin-bottom:1.25rem;font-size:1.25rem;font-weight:600}.form-group{margin-bottom:1rem}.form-group label{color:var(--text-muted);margin-bottom:.35rem;font-size:.8125rem;display:block}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.form-actions{flex-wrap:wrap;gap:.75rem;margin-top:1.5rem;display:flex}input,select,textarea{border:1px solid var(--border);background:var(--canvas);width:100%;color:var(--text);border-radius:8px;padding:.6rem .75rem;font-size:.9375rem}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-dim);outline:none}.btn{cursor:pointer;border:none;border-radius:8px;padding:.6rem 1.25rem;font-size:.9375rem;font-weight:600}.btn-primary{background:var(--accent);color:#1a1a1a}.btn-secondary{color:var(--accent);border:1px solid var(--accent);background:0 0}.btn-ghost{color:var(--text-muted);background:0 0}.btn-ghost:hover{color:var(--text)}.bean-list{margin:0;padding:0;list-style:none}.bean-list-item{border-bottom:1px solid var(--border)}.bean-list-item:last-child{border-bottom:none}.bean-list-link{color:inherit;justify-content:space-between;align-items:center;padding:.75rem 0;display:flex}.bean-list-link:hover{background:#ffffff05}.bean-list-name{font-weight:500}.brew-list-info{flex-direction:column;gap:.15rem;display:flex}.brew-row{color:inherit;justify-content:space-between;align-items:center;padding:.75rem 0;text-decoration:none;display:flex}.brew-toolbar{flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.brew-filters{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.brew-group-toggle.active{color:var(--accent);border-color:var(--accent)}.brew-group-section{margin-bottom:1.5rem}.brew-group-section:last-child{margin-bottom:0}.brew-group-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin:0 0 .5rem;font-size:.8125rem;font-weight:600}.detail-list{margin:0 0 1.5rem}.detail-list dt{color:var(--text-muted);margin-top:.5rem;font-size:.8125rem}.detail-list dd{margin:.25rem 0 0}.detail-list dt.ratio-label,.detail-list dd.ratio-value{color:var(--text-muted)}.detail-list dd.ratio-value{font-family:JetBrains Mono,ui-monospace,monospace}.toggle{border:1px solid var(--border);border-radius:8px;margin-bottom:1rem;display:flex;overflow:hidden}.toggle button{color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex:1;padding:.6rem 1rem;font-weight:500}.toggle button.active{background:var(--accent);color:#1a1a1a}.section-label{color:var(--text-muted);margin-bottom:.5rem;font-size:.8125rem;display:block}.chips{flex-wrap:wrap;gap:.5rem;display:flex}.chip{border:1px solid var(--border);cursor:pointer;background:var(--canvas);color:var(--text-muted);border-radius:20px;padding:.4rem .75rem;font-size:.8125rem}.chip.active{border-color:var(--accent);background:var(--accent-dim);color:var(--accent)}.ratio-display{padding:.5rem 0}.ratio-label{color:var(--text-muted);margin-right:.5rem;font-size:.8125rem}.ratio-value{color:var(--text-muted);font-family:JetBrains Mono,ui-monospace,monospace;font-size:.875rem}.temperature-input-row{align-items:center;gap:.75rem;display:flex}.temperature-input-row .data-input{flex:1;min-width:0}.temperature-unit-chips{flex-shrink:0;margin:0}.star-rating-icons-wrap{align-items:center;margin-top:.25rem;display:flex}.star-rating-icons{align-items:center;gap:.1rem;display:inline-flex}.star-rating-icon-cell{flex-shrink:0;width:22px;height:22px;display:inline-block;position:relative}.star-rating-icon-cell .star-rating-empty{color:var(--text-muted);opacity:.4;pointer-events:none;position:absolute;top:0;left:0}.star-rating-icon-cell .star-rating-filled{color:var(--accent);pointer-events:none;position:absolute;top:0;left:0}.star-rating-hit{cursor:pointer;z-index:1;background:0 0;border:none;padding:0;position:absolute;inset:0}.star-rating-hit-half{width:50%}.star-rating-hit-half.left{left:0}.star-rating-hit-half.right{left:auto;right:0}.taste-slider-wrap{margin-top:.25rem}.taste-slider-root{align-items:center;width:100%;height:20px;margin-bottom:.5rem;display:flex;position:relative}.taste-slider-track{background:var(--border);border-radius:1px;flex:1;height:2px;position:relative}.taste-slider-range{background:var(--accent);border-radius:1px;height:100%;position:absolute}.taste-slider-thumb{background:var(--accent);width:12px;height:12px;box-shadow:0 0 0 1px var(--border);cursor:grab;border-radius:50%;display:block}.taste-slider-thumb:focus{outline:none}.taste-slider-thumb[data-dragging]{cursor:grabbing}.taste-slider-labels{justify-content:space-between;gap:.5rem;display:flex}.taste-slider-label{text-align:center;color:var(--text-muted);flex:1;padding:.2rem 0;font-size:.75rem;transition:color .15s}.taste-slider-label.active{color:var(--accent)}.data-input{font-family:JetBrains Mono,ui-monospace,monospace}.roaster-custom-input{border:1px solid var(--border);background:var(--canvas);width:100%;color:var(--text);border-radius:8px;margin-top:.5rem;padding:.6rem .75rem;font-size:.9375rem}.inventory-list{margin:0;padding:0;list-style:none}.inventory-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.5rem 0;display:flex}.inventory-row:last-child{border-bottom:none}.inventory-name{font-weight:500}.inventory-date{font-size:.8125rem}.fix-card{background:var(--accent-dim);border-left:3px solid var(--accent);border-radius:8px;margin-bottom:.75rem;padding:1rem 1.25rem}.fix-card h3{color:var(--text);margin:0 0 .25rem;font-size:.9375rem;font-weight:600}.fix-card p{color:var(--text-muted);margin:0 0 .5rem;font-size:.8125rem}.fix-cta{color:var(--accent);font-size:.8125rem;font-weight:600}.tabs{border-bottom:1px solid var(--border);gap:.25rem;margin-bottom:1.5rem;display:flex}.tabs button{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:.6rem 1rem;font-weight:500}.tabs button.active{color:var(--accent);border-bottom-color:var(--accent)}.roaster-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.roaster-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:1.25rem}.roaster-card h3{color:var(--text);margin:0 0 .25rem;font-size:1rem;font-weight:600}.roaster-card p{color:var(--text-muted);margin:0 0 .75rem;font-size:.8125rem}.roaster-link{color:var(--accent);font-size:.8125rem;font-weight:600}.visit-item{background:var(--card);border:1px solid var(--border);border-radius:8px;margin-bottom:.5rem;padding:.75rem 1rem}.visit-item-name{color:var(--text);font-weight:600}.visit-item-meta{color:var(--text-muted);font-size:.8125rem}
