@import"https://fonts.googleapis.com/css2?family=Abril+Fatface&family=Space+Grotesk:wght@300;400;600&family=Space+Mono:wght@400;700&display=swap";:root{font-family:Space Grotesk,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body{margin:0;padding:0;min-width:320px;height:100vh;overflow:hidden}:root{--coffee-dark: #2c1a12;--coffee-medium: #4c2d1e;--coffee-light: #8d5a3b;--cream: #f6e6d6;--copper: #c3622d;--copper-glow: #e07a42;--bg-dark: #0e0d0c;--bg-panel: rgba(30, 26, 24, .65);--text-main: #f0e6e0;--text-muted: #9a8e86;--border-subtle: rgba(141, 90, 59, .12);--glass-bg: rgba(14, 13, 12, .75);--shadow-deep: rgba(0, 0, 0, .6);--accent-warm: #d4813a;--green: #4ade80;--amber: #fbbf24;--red: #ef4444}#root{height:100vh;overflow:hidden;font-family:Space Grotesk,sans-serif}body{margin:0;background:var(--bg-dark);color:var(--text-main);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{height:100vh;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-dark)}@keyframes bg-move{0%{background-position:0% 0%}to{background-position:100% 100%}}.hero{position:absolute;top:14px;left:14px;right:14px;height:64px;background:#0e0d0cd9;-webkit-backdrop-filter:blur(40px) saturate(1.8);backdrop-filter:blur(40px) saturate(1.8);border:1px solid rgba(255,255,255,.05);border-bottom:1px solid rgba(141,90,59,.25);border-radius:16px;padding:0 24px;display:flex;align-items:center;justify-content:space-between;gap:20px;z-index:100;box-shadow:0 12px 40px #00000080}.hero:after{content:"";position:absolute;inset:0;border-radius:inherit;background:radial-gradient(circle at 15% 50%,rgba(224,122,66,.08) 0%,transparent 60%);pointer-events:none}.logo-container{display:flex;align-items:center;gap:10px}.logo-icon{width:32px;height:32px;filter:drop-shadow(0 0 8px rgba(224,122,66,.4))}.logo-container h1{font-family:Space Grotesk,sans-serif;font-size:1.05rem;font-weight:800;letter-spacing:.18em;color:var(--text-main);text-transform:uppercase;margin:0;background:linear-gradient(to bottom,#fff,#b7a8a0);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 10px rgba(224,122,66,.2))}.hero-left{display:flex;align-items:center;gap:14px;flex-shrink:0}.brew-stage-pill{display:flex;align-items:center;gap:6px;font-size:.72rem;font-weight:600;letter-spacing:.03em;padding:3px 10px 3px 8px;border-radius:99px;border:1px solid var(--border-subtle);background:#00000040;white-space:nowrap;color:var(--text-muted);transition:all .35s ease}.brew-stage-pill[data-stage=heating]{color:var(--copper-glow);border-color:#e07a424d}.brew-stage-pill[data-stage=saturating]{color:var(--amber);border-color:#eab0404d}.brew-stage-pill[data-stage=brewing]{color:var(--green);border-color:#3dd68c4d}.brew-stage-pill[data-stage=complete],.brew-stage-pill[data-stage=idle]{color:var(--text-muted);border-color:var(--border-subtle)}.stage-dot{width:7px;height:7px;border-radius:50%;background:currentColor;animation:pulse-dot 1.6s ease-in-out infinite}.brew-stage-pill[data-stage=complete] .stage-dot{animation:none;opacity:.5}.brew-stage-pill[data-stage=idle] .stage-dot{animation:none;opacity:.4}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.hero-center{flex:1;display:flex;justify-content:center;min-width:0}.stage-timeline{display:flex;align-items:center;gap:0;position:relative;width:100%;max-width:400px;background:#00000026;padding:8px 16px;border-radius:12px;border:1px solid rgba(255,255,255,.02)}.timeline-step{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;z-index:2}.timeline-dot{width:8px;height:8px;border-radius:50%;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);transition:all .4s cubic-bezier(.19,1,.22,1);box-shadow:0 0 0 4px #0000001a}.timeline-step.active .timeline-dot{background:var(--copper-glow);border-color:#fff;box-shadow:0 0 12px var(--copper-glow);transform:scale(1.1)}.timeline-step.done .timeline-dot{background:var(--green);border-color:var(--green);box-shadow:0 0 4px #3dd68c4d}.timeline-label{font-size:.55rem;text-transform:uppercase;letter-spacing:.06em;color:#fff3;transition:color .3s}.timeline-step.active .timeline-label{color:var(--copper-glow);text-shadow:0 0 8px rgba(224,122,66,.4)}.timeline-step.done .timeline-label{color:var(--green);opacity:.8}.timeline-track{position:absolute;top:11px;left:12.5%;right:12.5%;height:2px;background:#ffffff0a;border-radius:1px;z-index:1}.timeline-fill{height:100%;background:linear-gradient(90deg,var(--green),var(--copper-glow));border-radius:1px;transition:width .6s cubic-bezier(.34,1.56,.64,1);box-shadow:0 0 10px #e07a424d}.hero-right{display:flex;align-items:center;gap:16px;flex-shrink:0}.hero-stat{display:flex;flex-direction:column;align-items:center;gap:1px}.hero-stat-value{font-family:Space Mono,monospace;font-size:.88rem;color:var(--text-main);font-variant-numeric:tabular-nums}.hero-stat-label{font-size:.52rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.progress-ring{position:relative;width:36px;height:36px;flex-shrink:0}.progress-ring svg{transform:rotate(-90deg);width:100%;height:100%}.ring-bg{fill:none;stroke:#ffffff0f;stroke-width:3}.ring-fill{fill:none;stroke:var(--copper-glow);stroke-width:2.5;stroke-linecap:round;transition:stroke-dasharray .5s ease;filter:drop-shadow(0 0 3px var(--copper-glow))}.ring-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.52rem;font-family:Space Mono,monospace;color:var(--text-muted)}.layout{position:absolute;inset:0;overflow:hidden;z-index:1;pointer-events:none}.layout>*{pointer-events:auto}.sidebar{position:absolute;top:96px;left:14px;bottom:14px;width:290px;background:#0e0d0cd1;-webkit-backdrop-filter:blur(42px) saturate(1.8);backdrop-filter:blur(42px) saturate(1.8);border:1px solid rgba(255,255,255,.05);border-radius:18px;padding:18px;display:flex;flex-direction:column;gap:14px;z-index:90;box-shadow:0 16px 48px #0009;overflow:hidden}.sidebar::-webkit-scrollbar{display:none}.sidebar:after{content:"";position:absolute;inset:0;border-radius:inherit;background:linear-gradient(to bottom,rgba(255,255,255,.02) 0%,transparent 100%);pointer-events:none}.action-bar{display:flex;gap:10px;padding:0 0 16px;background:transparent;border-bottom:1px solid rgba(255,255,255,.05)}.sidebar-tabs{display:flex;background:#0003;border-radius:12px;padding:4px;gap:4px;margin-bottom:8px;border:1px solid rgba(255,255,255,.02)}.tab-btn{flex:1;background:transparent;border:none;font-family:inherit;font-size:.76rem;color:var(--text-muted);padding:10px 12px;border-radius:10px;cursor:pointer;transition:all .3s cubic-bezier(.19,1,.22,1);font-weight:500;display:flex;align-items:center;justify-content:center;gap:6px;z-index:1}.tab-btn.active{color:#fff;background:#ffffff0f}.tab-btn.active:after{content:"";position:absolute;bottom:0;left:20%;right:20%;height:2px;background:var(--copper-glow);border-radius:1px;box-shadow:0 0 10px var(--copper-glow)}@keyframes tab-indicator{0%{transform:scaleX(0);opacity:0}to{transform:scaleX(1);opacity:1}}.tab-icon{font-size:.85rem;line-height:1}.tab-content{display:none;flex-direction:column;gap:10px;flex:1;animation:fadeIn .3s ease}.tab-content.active{display:flex}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.mode-toggle{display:flex;justify-content:center;gap:8px;margin-bottom:8px}.sidebar .panel{background:transparent;border:none;box-shadow:none;padding:0;border-radius:0}.controls-panel{display:flex;flex-direction:column;gap:14px;flex:1;overflow-y:auto;scrollbar-width:none;padding-right:4px}.controls-panel::-webkit-scrollbar{display:none}.panel h2{font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin:8px 0 12px;display:flex;align-items:center;gap:10px;font-weight:700}.panel h2:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,rgba(141,90,59,.2),transparent)}.mode-toggle{display:flex;background:#00000059;padding:2px;border-radius:8px;border:1px solid rgba(255,255,255,.04);margin-bottom:16px}.mode-btn{flex:1;padding:6px 0;background:transparent;color:var(--text-muted);border:none;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.02em;cursor:pointer;border-radius:6px;transition:all .2s cubic-bezier(.4,0,.2,1)}.mode-btn:hover{color:var(--text-main)}.mode-btn.active{background:#ffffff0f;color:#fff;box-shadow:inset 0 0 0 1px #e07a4266}.control-desc{display:block;font-size:.66rem;color:var(--text-muted);opacity:.7;margin:-3px 0 4px;line-height:1.35}.gauge-extra{font-size:.65rem;color:var(--text-muted);font-weight:400}.pill{flex:1;padding:9px 14px;border-radius:10px;font-family:inherit;font-weight:600;font-size:.82rem;cursor:pointer;transition:all .2s cubic-bezier(.2,.8,.2,1);display:flex;align-items:center;justify-content:center;gap:5px}.btn-icon{font-size:.9em}.pill.primary{background:linear-gradient(135deg,var(--copper-glow) 0%,var(--copper) 100%);color:#fff;border:1px solid rgba(255,255,255,.15);box-shadow:0 4px 16px #c3622d4d,inset 0 1px #fff3;text-shadow:0 1px 2px rgba(0,0,0,.2)}.pill.primary:hover{transform:translateY(-2px);filter:brightness(1.1);box-shadow:0 8px 24px #c3622d73,inset 0 1px #ffffff40}.pill.primary.running{background:linear-gradient(180deg,#5a4a42,#3a3230);border-color:#ffffff0f;box-shadow:0 2px 8px #0003;color:var(--text-muted)}.pill.primary.start{background:linear-gradient(180deg,#e88a3c 0%,var(--copper) 100%);box-shadow:0 4px 18px #c3622d73,inset 0 1px #ffffff26;animation:start-glow 2s ease-in-out infinite}@keyframes start-glow{0%,to{box-shadow:0 4px 18px #c3622d73,inset 0 1px #ffffff26}50%{box-shadow:0 4px 28px #e48a3c99,inset 0 1px #fff3}}.pill.ghost{background:#ffffff08;color:var(--text-muted);border:1px solid var(--border-subtle)}.pill.ghost:hover{background:#ffffff12;color:var(--text-main);border-color:#ffffff1f}.section{margin:8px 0;padding:10px 0;border-top:1px solid rgba(141,90,59,.08)}.section:first-of-type{border-top:none;margin-top:0;padding-top:0}.section h3{margin:0 0 10px;font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:600;display:flex;align-items:center;gap:6px}.section-icon{font-size:.85rem;line-height:1;opacity:.85}.section.advanced{margin-top:4px;padding:12px;background:#00000038;border-radius:12px;border:1px solid rgba(141,90,59,.1);animation:fadeSlide .2s ease}@keyframes fadeSlide{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.preset-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.preset-card{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;background:#ffffff08;border:1px solid rgba(255,255,255,.05);cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);text-align:left}.preset-card:hover{background:#ffffff0f;border-color:#e07a424d;transform:scale(1.02);box-shadow:0 4px 20px #0000004d}.preset-card.active{background:#e07a421a;border-color:var(--copper-glow);box-shadow:inset 0 0 12px #e07a421a}.preset-icon{font-size:1.15rem;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#ffffff0a;border-radius:8px;flex-shrink:0}.preset-info{display:flex;flex-direction:column;gap:0;overflow:hidden}.preset-info strong{font-size:.76rem;color:var(--text-main);font-weight:600}.preset-info small{font-size:.6rem;color:var(--text-muted)}.accordion{border:1px solid rgba(255,255,255,.04);background:#00000026;border-radius:14px;overflow:hidden;transition:all .3s ease}.accordion:hover{border-color:#ffffff14}.accordion-header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:12px 14px;background:transparent;border:none;cursor:pointer;color:var(--text-main)}.accordion-header:hover{background:#ffffff08}.accordion-header h3{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin:0;display:flex;align-items:center;gap:6px;transition:color .2s ease}.accordion-header:hover h3{color:var(--text-main)}.chevron{font-size:1.2rem;line-height:1;color:var(--text-muted);transition:transform .25s cubic-bezier(.2,.8,.2,1),color .2s}.chevron.open{transform:rotate(90deg);color:var(--copper-glow)}.accordion-header:hover .chevron{color:var(--text-main)}.accordion .brand-list,.accordion .preset-grid{border-top:1px solid rgba(255,255,255,.05);padding:8px}.brand-list{display:flex;flex-direction:column;gap:6px;max-height:240px;overflow-y:auto;padding-right:4px}.brand-list::-webkit-scrollbar{width:3px}.brand-list::-webkit-scrollbar-thumb{background:#8d5a3b33}.brand-card{display:flex;flex-direction:column;align-items:flex-start;gap:3px;padding:10px 10px 10px 12px;background:#ffffff06;border:1px solid rgba(255,255,255,.05);border-left:3px solid transparent;border-radius:10px;text-align:left;cursor:pointer;transition:all .2s ease}.brand-card:hover{background:#ffffff0d;border-color:#8d5a3b33;border-left-color:#8d5a3b4d;transform:translate(2px)}.brand-card.active{background:#c3622d1a;border-color:#c3622d33;border-left-color:var(--copper-glow);box-shadow:0 0 14px #c3622d1f}.brand-header{width:100%;display:flex;justify-content:space-between;align-items:center;margin-bottom:2px}.brand-name{font-size:.8rem;font-weight:700;color:var(--text-main);letter-spacing:.02em}.brand-badge{font-size:.55rem;text-transform:uppercase;padding:2px 6px;border-radius:4px;font-weight:600;letter-spacing:.05em}.brand-badge.light{background:#fbbf2426;color:var(--amber);border:1px solid rgba(251,191,36,.2)}.brand-badge.medium{background:#c3622d26;color:var(--copper);border:1px solid rgba(195,98,45,.2)}.brand-badge.dark{background:#8d5a3b40;color:#bcaaa4;border:1px solid rgba(141,90,59,.3)}.brand-origin{font-family:Space Mono,monospace;font-size:.58rem;color:var(--text-muted);opacity:.8;margin-bottom:4px}.brand-desc{font-size:.65rem;line-height:1.4;color:var(--text-muted);margin:0;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.brand-card.active .brand-desc{color:#f0e6e0d9}.section-header-row{display:flex;align-items:center;gap:10px;margin-bottom:12px}.section-header-row h3{margin:0!important;color:var(--text-main)!important;font-size:.85rem!important}.step-badge{width:20px;height:20px;background:var(--copper);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;box-shadow:0 0 10px #c3622d4d}.size-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:4px}.size-card-v2{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:12px 6px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:12px;cursor:pointer;transition:all .2s cubic-bezier(.2,.8,.2,1);position:relative;min-height:80px}.size-card-v2:hover{background:#ffffff0f;border-color:#c3622d4d;transform:translateY(-2px)}.size-card-v2.active{background:#c3622d1f;border-color:var(--copper-glow);box-shadow:0 4px 20px #00000040,0 0 15px #c3622d26}.size-card-icon{font-size:1.2rem;margin-bottom:6px;opacity:.8;transition:transform .2s ease}.size-card-v2.active .size-card-icon{opacity:1;transform:scale(1.1)}.size-card-info{display:flex;flex-direction:column;align-items:center;gap:1px}.size-label{font-size:.75rem;font-weight:700;color:var(--text-muted);transition:color .2s}.size-card-v2.active .size-label{color:var(--text-main)}.size-capacity{font-size:.6rem;font-family:Space Mono,monospace;color:var(--copper);opacity:.8}.size-active-check{position:absolute;top:6px;right:8px;font-size:.65rem;color:var(--copper-glow);font-weight:900}.selected-brand-simple{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:#00000040;border:1px solid rgba(141,90,59,.15);border-radius:10px;cursor:pointer;transition:all .2s;margin-bottom:8px}.selected-brand-simple:hover{background:#ffffff0a;border-color:#8d5a3b4d}.sbs-mini-left{display:flex;flex-direction:column;gap:1px}.sbs-mini-name{font-size:.8rem;font-weight:700;color:var(--text-main)}.sbs-mini-origin{font-size:.55rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.sbs-mini-desc{font-size:.65rem;color:var(--text-muted);opacity:.7;margin:4px 0 0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:1;line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;max-width:180px}.sbs-mini-right{display:flex;align-items:center;gap:10px}.chevron-mini{font-size:1rem;color:var(--text-muted);transition:transform .2s}.chevron-mini.open{transform:rotate(90deg)}.brand-list-v2{display:flex;flex-direction:column;gap:6px;max-height:220px;overflow-y:auto;padding-right:6px;margin-top:8px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.05) transparent}.brand-item-full{display:flex;flex-direction:column;padding:12px;background:#ffffff05;border:1px solid rgba(255,255,255,.04);border-radius:10px;text-align:left;cursor:pointer;transition:all .2s cubic-bezier(.2,.8,.2,1);width:100%}.brand-item-full:hover{background:#ffffff0d;border-color:#8d5a3b33;transform:translate(2px)}.brand-item-full.active{background:#c3622d14;border-color:#c3622d4d;box-shadow:0 4px 12px #0003}.brand-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.brand-item-name{font-size:.82rem;font-weight:700;color:var(--text-main);transition:color .2s}.brand-item-full.active .brand-item-name{color:var(--copper-glow)}.roast-dot{width:8px;height:8px;border-radius:50%;box-shadow:0 0 8px #00000080}.roast-dot.light{background:#e9c46a;box-shadow:0 0 6px #e9c46a66}.roast-dot.medium{background:#a67c52;box-shadow:0 0 6px #a67c5266}.roast-dot.dark{background:#3d2b1f;border:1px solid rgba(255,255,255,.1)}.brand-item-meta{font-size:.62rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}.brand-item-desc{font-size:.68rem;line-height:1.45;color:var(--text-muted);opacity:.8;margin:0;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.brand-item-full.active .brand-item-desc{color:var(--text-main);opacity:.9}.control-group{display:flex;flex-direction:column;gap:16px;margin-top:8px}.control-v2{display:flex;flex-direction:column;gap:8px}.control-header{display:flex;justify-content:space-between;align-items:center}.control-header .label-text{font-size:.75rem;font-weight:600;color:var(--text-muted)}.control-header .label-value{font-size:.75rem;font-family:Space Mono,monospace;color:var(--copper-glow);font-weight:700}.control-header .label-value.bold{font-size:.85rem}.precision-control{display:flex;align-items:center;gap:12px}.step-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--text-muted);font-size:1rem;cursor:pointer;transition:all .2s;flex-shrink:0}.step-btn:hover{background:#c3622d26;color:var(--text-main);border-color:#c3622d4d}.step-btn:active{transform:scale(.9);background:var(--copper)}.precision-control input[type=range]{flex-grow:1;margin:0}.control{margin-bottom:8px;background:#0003;padding:10px 12px;border-radius:10px;border:1px solid rgba(255,255,255,.025);transition:border-color .25s,box-shadow .25s}.control:hover{border-color:#8d5a3b26;box-shadow:inset 0 0 16px #c3622d0a}.control label{display:flex;justify-content:space-between;margin-bottom:6px;font-size:.78rem}.label-text{color:var(--text-muted)}.label-value{color:var(--copper);font-family:Space Mono,monospace;font-size:.75rem;font-variant-numeric:tabular-nums}input[type=range]{--fill: 50%;width:100%;height:2px;background:linear-gradient(to right,var(--copper-glow) 0%,var(--copper-glow) var(--fill),rgba(255,255,255,.05) var(--fill),rgba(255,255,255,.05) 100%);border-radius:4px;appearance:none;-webkit-appearance:none;border:none;outline:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:10px;height:10px;background:#fff;border-radius:50%;cursor:pointer;box-shadow:0 0 10px var(--copper-glow);transition:all .2s cubic-bezier(.175,.885,.32,1.275);border:none}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 0 0 3px var(--copper-glow),0 2px 8px #c3622d4d}input[type=range]::-moz-range-thumb{width:14px;height:14px;background:var(--text-main);border:2px solid var(--bg-dark);border-radius:50%;cursor:pointer;box-shadow:0 0 0 2px var(--copper)}.toggle-advanced{width:100%;padding:8px 12px;margin:4px 0 0;background:transparent;border:1px solid rgba(255,255,255,.05);color:var(--text-muted);border-radius:8px;cursor:pointer;font-size:.74rem;font-weight:600;text-align:left;display:flex;align-items:center;gap:6px;transition:all .2s}.toggle-advanced:hover{background:#ffffff08;color:var(--text-main)}.adv-chevron{display:inline-block;transition:transform .2s ease;font-size:.9rem;line-height:1}.adv-chevron.open{transform:rotate(90deg)}.selected-brand-summary{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;background:linear-gradient(135deg,#c3622d14,#2c1a121f);border:1px solid rgba(195,98,45,.12);transition:all .3s ease}.selected-brand-summary.light{background:linear-gradient(135deg,#fbbf240f,#2c1a1214);border-color:#fbbf241f}.selected-brand-summary.dark{background:linear-gradient(135deg,#50321e1f,#140c0626);border-color:#8d5a3b26}.sbs-icon{font-size:1.4rem;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#ffffff0a;border-radius:10px;flex-shrink:0}.sbs-info{display:flex;flex-direction:column;gap:3px;min-width:0}.sbs-name{font-size:.85rem;font-weight:700;color:var(--text-main);letter-spacing:.01em}.sbs-meta{display:flex;align-items:center;gap:6px}.sbs-origin{font-size:.6rem;color:var(--text-muted);font-family:Space Mono,monospace;opacity:.8}.brew-guide-accordion{background:#c3622d08;border-color:#c3622d1a}.brew-guide-accordion:hover{border-color:#c3622d2e}.brew-guide-body{padding:10px 12px 12px;border-top:1px solid rgba(195,98,45,.08);display:flex;flex-direction:column;gap:10px;animation:fadeIn .2s ease}.brew-stages-mini{display:flex;flex-direction:column;gap:5px}.bsm{display:flex;align-items:center;gap:8px;font-size:.72rem;color:var(--text-muted);line-height:1.35}.bsm-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;box-shadow:0 0 4px #0003}.bsm-dot.heating{background:var(--copper-glow);box-shadow:0 0 4px #e07a424d}.bsm-dot.saturating{background:var(--amber);box-shadow:0 0 4px #fbbf244d}.bsm-dot.brewing{background:var(--green);box-shadow:0 0 4px #4ade804d}.bsm-dot.complete{background:var(--text-muted)}.tips-compact{border-top:1px solid rgba(195,98,45,.06);padding-top:8px}.tips-compact p{margin:0;font-size:.72rem;color:var(--text-muted);line-height:1.55}.tips-compact strong{color:var(--text-main)}.main-content{padding:10px;display:flex;flex-direction:column;min-height:0;height:100%;overflow:hidden;position:relative}.canvas-panel{position:absolute;inset:0;z-index:0;overflow:hidden}.canvas-panel h2{display:none}.canvas-frame{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 80%,rgba(60,45,35,.22) 0%,transparent 60%),radial-gradient(ellipse at 15% 15%,rgba(44,26,18,.25) 0%,transparent 55%),radial-gradient(circle at center,#1e1a18,#0e0d0c);overflow:hidden}.welcome-overlay{position:absolute;inset:0;z-index:30;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 50% 60%,#1e1a18eb,#0e0d0cf7 70%);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:welcome-fade-in .5s ease}@keyframes welcome-fade-in{0%{opacity:0}to{opacity:1}}.welcome-content{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;max-width:320px;padding:32px 24px}.welcome-icon{font-size:3.5rem;line-height:1;filter:drop-shadow(0 4px 16px rgba(195,98,45,.3));animation:welcome-icon-float 3s ease-in-out infinite}@keyframes welcome-icon-float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.welcome-content h2{margin:0;font-family:Abril Fatface,serif;font-size:1.7rem;font-weight:400;letter-spacing:.04em;background:linear-gradient(135deg,var(--cream) 10%,var(--copper-glow) 55%,var(--cream) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}.welcome-content p{margin:0;font-size:.85rem;line-height:1.55;color:var(--text-muted)}.welcome-content p kbd{display:inline-block;padding:1px 6px;font-size:.75rem;font-family:inherit;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:4px;color:var(--text-main);box-shadow:0 1px 2px #0003}.welcome-start{margin-top:8px;padding:10px 28px;font-size:.95rem;font-weight:600;color:#fff;background:linear-gradient(180deg,var(--copper-glow) 0%,var(--copper) 100%);border:1px solid rgba(255,255,255,.15);border-radius:99px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 20px #c3622d59,inset 0 1px #ffffff1f;animation:start-glow 2s ease-in-out infinite}.welcome-start:hover{transform:translateY(-2px);box-shadow:0 6px 28px #e48a3c80,inset 0 1px #ffffff2e}.welcome-start:active{transform:translateY(0);box-shadow:0 2px 8px #c3622d4d}.global-counter{margin-left:15px;background:#ffffff0d;padding:4px 10px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.total-brews-badge{display:flex;align-items:center;gap:6px;background:#ffffff08;padding:4px 10px;border-radius:100px;border:1px solid rgba(255,255,255,.06);width:fit-content;white-space:nowrap}.count-dot{width:5px;height:5px;border-radius:50%;background:var(--copper-glow);box-shadow:0 0 8px var(--copper-glow)}.count-val{font-family:Space Mono,monospace;font-size:.7rem;font-weight:700;color:var(--text-bright)}.count-label{font-size:.6rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:500}.hidden-completely{display:none!important}.metrics-overlay{position:absolute;top:92px;right:14px;z-index:85;width:250px;max-height:calc(100% - 110px);overflow-y:auto;background:#0e0d0cd9;-webkit-backdrop-filter:blur(40px) saturate(1.8);backdrop-filter:blur(40px) saturate(1.8);border:1px solid rgba(255,255,255,.05);border-radius:16px;padding:16px 12px;transition:opacity .4s ease,transform .4s ease;box-shadow:0 16px 48px #00000080;pointer-events:none}.metrics-overlay.hidden{opacity:0;pointer-events:none;transform:translate(12px)}.metrics-toggle{position:absolute;top:98px;right:20px;z-index:90;width:28px;height:28px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:#1e1c1acc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#ffffff80;font-size:.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.19,1,.22,1)}.metrics-toggle:hover{background:#3c3a38;color:#fff;border-color:#fff3;transform:translateY(-1px)}.metrics-toggle.active{background:#e07a4226;border-color:var(--copper-glow);color:var(--copper-glow);box-shadow:0 0 15px #e07a4233}.metrics-overlay h3{margin:0 0 12px;font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);font-weight:700;border-bottom:1px solid rgba(255,255,255,.05);padding-bottom:6px}.metrics-sparklines{display:flex;flex-direction:column;gap:16px;margin-top:14px}.sparkline-canvas{filter:drop-shadow(0 0 3px rgba(0,0,0,.4))}.metrics-panel{display:flex;flex-direction:column;gap:0;background:transparent;border:none;padding:0}.stat-grid{display:flex;flex-direction:column;gap:1px}.stat-grid>div{background:transparent;border:none;padding:3px 0;border-radius:0;display:flex;align-items:baseline;justify-content:space-between;gap:6px;position:relative;overflow:visible;border-bottom:1px solid rgba(255,255,255,.03);transition:none}.stat-grid>div:last-child{border-bottom:none}.stat-grid>div:hover{transform:none}.stat-grid>div:before{display:none}.stat-grid span{font-size:.54rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.stat-grid strong{font-family:Space Mono,monospace;font-size:.72rem;color:var(--text-main);font-weight:400;text-align:right;font-variant-numeric:tabular-nums;transition:color .3s}.val-hot{color:var(--copper-glow)!important}.val-danger{color:var(--red)!important}.val-warn{color:var(--amber)!important}.val-flow{color:var(--green)!important}.val-coffee{color:#c8884a!important}.stat-section-label{font-size:.48rem!important;text-transform:uppercase;letter-spacing:.12em;color:var(--copper)!important;font-weight:700;padding:5px 0 1px!important;border-bottom:none!important;display:block!important;opacity:.75}.stat-section-label:first-child{padding-top:0!important}.stat-value-bar{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.mini-bar{width:48px;height:2px;background:#ffffff0f;border-radius:1px;overflow:hidden}.mini-bar-fill{height:100%;background:var(--copper);border-radius:1px;transition:width .25s ease;min-width:0}.bar-flow .mini-bar-fill{background:var(--green)}.bar-water .mini-bar-fill{background:#58a}.bar-sat .mini-bar-fill{background:var(--amber)}.charts-section{margin-top:6px;display:flex;flex-direction:column;gap:4px}.chart-card{background:#ffffff05;border:1px solid rgba(255,255,255,.04);border-radius:8px;padding:4px 3px 2px;transition:border-color .2s}.chart-card:hover{border-color:#8d5a3b26}.sparkline-canvas{display:block;width:100%;border-radius:4px}.about-trigger-btn{display:flex;align-items:center;gap:6px;background:#ffffff0a;border:1px solid var(--border-subtle);border-radius:99px;padding:4px 12px 4px 10px;color:var(--text-muted);font-size:.72rem;font-weight:600;cursor:pointer;transition:all .25s ease;margin-left:10px}.about-trigger-btn:hover{background:#c3622d1f;color:var(--copper-glow);border-color:#e07a424d;box-shadow:0 0 12px #e07a4226}.about-icon{display:flex;align-items:center;justify-content:center;width:16px;height:16px;background:#ffffff14;border-radius:50%;font-size:.65rem;font-weight:700}.about-trigger-btn:hover .about-icon{background:var(--copper-glow);color:#fff}.about-dialog{max-width:380px!important;background:#191614f2!important;border:1px solid rgba(141,90,59,.25);box-shadow:0 24px 64px #0009,0 0 20px #c3622d1a;position:relative;overflow:hidden}.about-dialog h2{font-family:Space Grotesk,sans-serif;font-weight:700;letter-spacing:.15em;text-transform:uppercase;background:linear-gradient(135deg,var(--cream) 10%,var(--copper-glow) 55%,var(--cream) 100%);-webkit-background-clip:text;background-clip:text;color:transparent;font-size:1.5rem}.dialog-close{position:absolute;top:16px;right:16px;background:transparent;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;padding:4px;line-height:1;transition:all .2s;z-index:5}.dialog-close:hover{color:var(--red);transform:scale(1.1)}.about-logo-icon{animation:none!important;margin-bottom:8px;width:64px;height:64px;filter:drop-shadow(0 0 12px rgba(224,122,66,.4))}.coffee-dialog{max-width:500px!important;background:#191614f2!important;border:1px solid rgba(141,90,59,.25);box-shadow:0 24px 64px #0009,0 0 20px #c3622d1a;padding:24px;position:relative;overflow:hidden}.coffee-search-input{width:100%;padding:8px 12px;margin-bottom:12px;border:1px solid rgba(255,255,255,.1);border-radius:6px;background:#ffffff0d;color:#fff;box-sizing:border-box}.coffee-search-input::placeholder{color:#ffffff80}.coffee-properties-summary{display:block;margin-top:4px;font-size:.8rem;color:#fff9}.coffee-dialog-properties{margin-top:16px;display:flex;flex-direction:column;gap:12px}.coffee-dialog .brand-list-v2{max-height:300px}.no-results{padding:20px;text-align:center;color:#fff9}.about-body{display:flex;flex-direction:column;gap:20px;margin-top:12px}.about-body p{font-size:.9rem!important;line-height:1.6!important}.about-attribution{background:#0003;padding:16px;border-radius:12px;display:flex;flex-direction:column;align-items:center;gap:4px;border:1px solid rgba(255,255,255,.03)}.author-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.author-name{font-family:Space Grotesk,sans-serif;font-size:1.2rem;font-weight:700;color:var(--copper-glow);text-decoration:none;transition:all .2s}.author-name:hover{color:var(--text-main);text-shadow:0 0 15px rgba(224,122,66,.5)}.copyright-note{font-size:.65rem;color:var(--text-muted);opacity:.6}.about-footer-text{font-size:.75rem!important;opacity:.8}.about-footer-text a{color:var(--copper);text-decoration:none;font-weight:600;border-bottom:1px solid rgba(195,98,45,.3);transition:all .2s}.about-footer-text a:hover{color:var(--copper-glow);border-bottom-color:var(--copper-glow)}.warning-glow{background:#ff450014;border:1px solid rgba(255,69,0,.3);padding:10px;border-radius:12px;box-shadow:0 0 15px #ff45001a;transition:all .4s ease}.heat-warning{font-size:.7rem;color:#ff4500;text-transform:uppercase;font-weight:900;margin-left:8px;animation:pulse-danger 1.5s infinite}.text-danger{color:#ff4500!important;text-shadow:0 0 8px rgba(255,69,0,.4)}.text-success{color:var(--green)!important;text-shadow:0 0 8px rgba(74,222,128,.4)}.hero-stat-pending{color:var(--text-muted);font-style:italic;opacity:.7}.slider-hot::-webkit-slider-runnable-track{background:linear-gradient(90deg,gold,#ff4500,#8b0000)!important}@keyframes pulse-danger{0%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.sheet-handle{width:100%;height:24px;display:none;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.sheet-handle:before{content:"";display:block;width:34px;height:4px;background:#fff3;border-radius:2px}@media(max-width:768px){*{-webkit-tap-highlight-color:transparent}#root{height:100dvh;overflow:hidden;font-family:Space Grotesk,sans-serif}.app{height:100dvh;overflow:hidden;display:flex;flex-direction:column;position:relative;background:var(--bg-dark)}.hero{position:relative!important;top:auto;left:auto;right:auto;height:auto;min-height:50px;flex-shrink:0;border-radius:0;padding:8px 12px;gap:10px;flex-direction:column;align-items:stretch;z-index:300;border-left:none;border-right:none;border-top:none;border-bottom:1px solid rgba(141,90,59,.2);box-shadow:0 4px 20px #0006}.hero-left{display:flex;justify-content:space-between;align-items:center;gap:6px;flex-shrink:0}.logo-icon{width:20px;height:20px;flex-shrink:0}.logo-container h1{font-size:.72rem;letter-spacing:.08em;white-space:nowrap}.brew-stage-pill{font-size:.58rem;padding:2px 6px 2px 5px;white-space:nowrap}.stage-dot{width:5px;height:5px}.about-text{display:none}.about-trigger-btn{padding:4px 6px;margin-left:4px}.hero-center{display:none!important}.hero-right{display:flex;justify-content:center;gap:20px;flex-shrink:0;padding:4px 0 2px;border-top:1px solid rgba(255,255,255,.03)}.hero-stat{gap:0}.hero-stat-value{font-size:.7rem}.hero-stat-label{font-size:.42rem}.hero-stat:nth-child(3),.progress-ring,.global-counter{display:none!important}.layout{position:relative!important;flex:1;min-height:0;overflow:hidden;display:block;pointer-events:auto}.main-content{position:absolute!important;inset:0;padding:0;height:100%;overflow:hidden}.canvas-panel{position:absolute!important;inset:0;height:100%;max-height:none;z-index:0}.canvas-frame{position:absolute;inset:0}.welcome-overlay{position:absolute;z-index:250;padding-bottom:80px}.welcome-content{padding:20px 16px;gap:10px;max-width:280px}.welcome-icon{font-size:2.5rem;animation:none}.welcome-content h2{font-size:1.15rem}.welcome-content p{font-size:.75rem}.welcome-start{padding:9px 22px;font-size:.85rem;margin-top:2px}.metrics-toggle{position:absolute!important;top:8px;right:8px;z-index:120;width:34px;height:34px;border-radius:10px;pointer-events:auto}.metrics-overlay{position:absolute!important;top:50px;right:8px;width:195px;max-height:calc(100% - 60px);overflow-y:auto;border-radius:14px;padding:10px;z-index:119;pointer-events:auto;box-shadow:0 8px 32px #0009;transition:opacity .2s ease}.metrics-overlay.hidden{opacity:0;pointer-events:none;display:block}.metrics-overlay h3{font-size:.56rem;margin-bottom:6px}.stat-grid{display:flex;flex-direction:column;gap:0}.stat-grid span{font-size:.48rem}.stat-grid strong{font-size:.6rem}.stat-section-label{font-size:.42rem!important}.gauge-extra{display:none}.mini-bar{width:32px}.metrics-sparklines{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px}.sidebar{position:absolute!important;inset:auto 0 0;width:100%;max-height:68px;overflow:hidden;border-radius:18px 18px 0 0;padding:0;z-index:200;background:#0e0d0ceb;-webkit-backdrop-filter:blur(40px) saturate(1.8);backdrop-filter:blur(40px) saturate(1.8);border:1px solid rgba(255,255,255,.08);border-bottom:none;box-shadow:0 -6px 30px #00000080;display:flex;flex-direction:column;transition:max-height .38s cubic-bezier(.32,.72,0,1);gap:0}.sidebar:after{display:none}.sidebar:before{display:none}.sheet-handle{display:flex}.sidebar.sheet-open{max-height:72dvh}.sidebar-tabs{flex-shrink:0;display:flex;gap:4px;padding:4px 12px 6px;margin-bottom:0;background:transparent;border:none;border-radius:0;cursor:pointer}.tab-btn{padding:7px 10px;font-size:.7rem;border-radius:8px}.panel.controls-panel{overflow-y:auto;overflow-x:hidden;flex:1;min-height:0;padding:6px 14px 24px;scrollbar-width:none;-webkit-overflow-scrolling:touch}.panel.controls-panel::-webkit-scrollbar{display:none}.action-bar{padding:10px 0;border-bottom:1px solid rgba(255,255,255,.05);flex-shrink:0;gap:8px}.pill{padding:10px 12px;font-size:.82rem}.tab-content{gap:6px}.section{margin:4px 0;padding:8px 0}.section h3{margin-bottom:8px;font-size:.63rem}.section-header-row h3{font-size:.8rem!important}.size-grid{grid-template-columns:repeat(4,1fr);gap:5px}.size-card-v2{min-height:62px;padding:7px 3px}.size-card-icon{font-size:.85rem;margin-bottom:3px}.size-label{font-size:.6rem}.size-capacity{font-size:.5rem}.size-active-check{top:3px;right:4px;font-size:.55rem}.brand-list-v2{max-height:140px}.brand-item-full{padding:8px 10px}.brand-item-name{font-size:.75rem}.brand-item-desc{font-size:.62rem}.control-group{gap:12px;margin-top:6px}.control-v2{gap:6px}.control-header .label-text,.control-header .label-value{font-size:.7rem}.step-btn{width:28px;height:28px;font-size:1rem;border-radius:8px}input[type=range]{height:4px}input[type=range]::-webkit-slider-thumb{width:20px;height:20px}.mode-btn{font-size:.65rem}.toggle-advanced{font-size:.7rem;padding:8px 10px}.about-dialog{max-width:90vw!important}.about-dialog h2{font-size:1.05rem}}@media(min-width:769px)and (max-width:1100px){#root{height:100vh;overflow:hidden}.app{height:100vh;overflow:hidden;display:flex;flex-direction:column;position:relative}.hero{position:relative!important;top:auto;left:auto;right:auto;height:56px;flex-shrink:0;border-radius:0;border-left:none;border-right:none;border-top:none;padding:0 16px;z-index:200}.hero-center{display:none!important}.hero-right{gap:12px}.hero-stat-value{font-size:.82rem}.global-counter{margin-left:8px}.layout{position:relative!important;flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:row;pointer-events:auto}.sidebar{position:relative!important;top:auto;left:auto;bottom:auto;width:260px;flex-shrink:0;height:100%;max-height:none;border-radius:0;border-right:1px solid rgba(141,90,59,.12);border-top:none;border-left:none;border-bottom:none;overflow-y:auto;padding:14px;box-shadow:none;z-index:10;display:flex;flex-direction:column;gap:14px;transition:none}.sidebar:before{display:none}.sidebar:after{display:block}.sidebar.sheet-open{max-height:none}.panel.controls-panel{overflow-y:auto;flex:1;padding:0;scrollbar-width:none}.panel.controls-panel::-webkit-scrollbar{display:none}.main-content{position:relative!important;flex:1;min-width:0;padding:0;height:100%;overflow:hidden}.canvas-panel{position:absolute!important;inset:0;height:100%;max-height:none}.canvas-frame{position:absolute;inset:0}.metrics-toggle{position:absolute!important;top:8px;right:8px;z-index:100}.metrics-overlay{position:absolute!important;top:48px;right:8px;width:215px;max-height:calc(100% - 60px);border-radius:14px;padding:12px 10px;z-index:99;pointer-events:auto;transition:opacity .3s,transform .3s}.metrics-overlay.hidden{opacity:0;pointer-events:none;transform:translate(10px)}.size-grid{grid-template-columns:repeat(2,1fr)}.stat-grid{display:flex;flex-direction:column}.metrics-sparklines{display:flex;flex-direction:column;gap:12px}input[type=range]{height:2px}input[type=range]::-webkit-slider-thumb{width:10px;height:10px}}@media(min-width:1101px){#root{height:100vh;overflow:hidden}.app{height:100vh;overflow:hidden;display:block;position:relative;background:var(--bg-dark)}.hero{position:absolute!important;top:14px;left:14px;right:14px;height:64px;border-radius:16px;padding:0 24px;gap:20px;flex-wrap:nowrap;z-index:100;border:1px solid rgba(255,255,255,.05);border-bottom:1px solid rgba(141,90,59,.25);box-shadow:0 12px 40px #00000080}.hero-center{display:flex!important}.hero-right{gap:16px}.hero-stat-value{font-size:.88rem}.global-counter{display:flex!important;margin-left:15px}.about-text{display:inline}.about-trigger-btn{padding:4px 12px 4px 10px;margin-left:10px}.layout{position:absolute!important;inset:0;overflow:hidden;pointer-events:none;display:block}.layout>*{pointer-events:auto}.sidebar{position:absolute!important;top:96px;left:14px;bottom:14px;width:290px;height:auto;max-height:none;border-radius:18px;padding:18px;z-index:90;box-shadow:0 16px 48px #0009;border:1px solid rgba(255,255,255,.05);-webkit-backdrop-filter:blur(42px) saturate(1.8);backdrop-filter:blur(42px) saturate(1.8);background:#0e0d0cd1;display:flex;flex-direction:column;gap:14px;transition:none;overflow:hidden}.sidebar::-webkit-scrollbar{display:none}.sidebar:before{display:none}.sidebar:after{display:block}.sidebar.sheet-open{max-height:none}.panel.controls-panel{overflow-y:auto;flex:1;padding:0;scrollbar-width:none}.panel.controls-panel::-webkit-scrollbar{display:none}.main-content{position:absolute!important;inset:0;padding:10px;height:100%;overflow:hidden}.canvas-panel{position:absolute!important;inset:0;height:100%;max-height:none}.canvas-frame{position:absolute;inset:0}.metrics-toggle{position:absolute!important;top:98px;right:20px;z-index:90;width:28px;height:28px}.metrics-overlay{position:absolute!important;top:92px;right:14px;width:250px;max-height:calc(100% - 110px);border-radius:16px;padding:16px 12px;overflow-y:auto;pointer-events:auto;transition:opacity .4s ease,transform .4s ease}.metrics-overlay.hidden{opacity:0;pointer-events:none;transform:translate(12px)}.size-grid{grid-template-columns:repeat(2,1fr)}.stat-grid{display:flex;flex-direction:column;gap:1px}.metrics-sparklines{display:flex;flex-direction:column;gap:16px;margin-top:14px}input[type=range]{height:2px}input[type=range]::-webkit-slider-thumb{width:10px;height:10px}.step-btn{width:24px;height:24px;font-size:1rem}.welcome-icon{animation:welcome-icon-float 3s ease-in-out infinite}.welcome-overlay{padding-bottom:0}}
