@import"https://fonts.googleapis.com/css2?family=Geist:wght@400;500;600&family=Geist+Mono:wght@400;500&display=swap";:root{color-scheme:light;--background-100: #ffffff;--background-200: #fafafa;--primary: #171717;--secondary: #4d4d4d;--disabled: #8f8f8f;--gray-100: #f2f2f2;--gray-200: #ebebeb;--gray-300: #e6e6e6;--gray-400: #eaeaea;--gray-alpha-100: #0000000d;--gray-alpha-200: #00000015;--gray-alpha-400: #00000014;--blue-700: #006bff;--amber-100: #fff6de;--amber-700: #ffae00;--amber-900: #aa4d00;--green-100: #ecfdec;--green-700: #28a948;--red-800: #ea001d;--nav-bg: rgba(255, 255, 255, .92);--field-bg: #ffffff;--instruction-border: #ffd889;--tip-bg: #f5f9ff;--tip-border: #b8d3ff;--tip-text: #003f8f;--active-pill-text: #107d32;--timer-display-text: #111111;--radius-sm: 6px;--radius-md: 12px;--shadow-card: 0 2px 2px rgba(0, 0, 0, .04);--focus-ring: 0 0 0 2px #ffffff, 0 0 0 4px #006bff;--ease-pop: cubic-bezier(.175, .885, .32, 1.1);font-family:Geist,Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:var(--background-100);color:var(--primary);overflow-x:hidden}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}:focus-visible{outline:none;box-shadow:var(--focus-ring)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.app{color-scheme:light;min-height:100vh;background:var(--background-100);overflow-x:clip}.app[data-theme=dark]{color-scheme:dark;--background-100: #0a0a0a;--background-200: #111111;--primary: #ededed;--secondary: #a1a1a1;--disabled: #666666;--gray-100: #171717;--gray-200: #1f1f1f;--gray-300: #2a2a2a;--gray-400: #333333;--gray-alpha-100: #ffffff12;--gray-alpha-200: #ffffff1f;--gray-alpha-400: #ffffff2e;--blue-700: #52a8ff;--amber-100: #2b1b00;--amber-700: #ffb224;--amber-900: #f59e0b;--green-100: #0d2f17;--green-700: #47d16c;--red-800: #ff5d6c;--nav-bg: rgba(10, 10, 10, .9);--field-bg: #0f0f0f;--instruction-border: #5a3a09;--tip-bg: #08182f;--tip-border: #164d9f;--tip-text: #b7d3ff;--active-pill-text: #9ff5b0;--timer-display-text: #ffffff;--shadow-card: 0 2px 2px rgba(0, 0, 0, .28);--focus-ring: 0 0 0 2px #0a0a0a, 0 0 0 4px #52a8ff}.top-nav{position:sticky;top:0;z-index:10;display:grid;grid-template-columns:280px 1fr auto;align-items:center;height:64px;border-bottom:1px solid var(--gray-alpha-200);background:var(--nav-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.brand{display:inline-flex;align-items:center;height:64px;padding:0 24px;color:var(--primary);font-size:20px;font-weight:600;line-height:26px;letter-spacing:-.4px;text-decoration:none}.tabs{display:flex;align-items:stretch;height:64px;gap:8px}.tab{position:relative;border:0;background:transparent;color:var(--secondary);padding:0 16px;font-size:14px;font-weight:500}.tab.active{color:var(--primary)}.tab.active:after{content:"";position:absolute;left:10px;right:10px;bottom:0;height:2px;background:var(--primary)}.nav-actions{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:0 24px}.brew-progress-sticky{position:sticky;top:64px;z-index:9;display:grid;gap:8px;padding:10px 24px;border-bottom:1px solid var(--gray-alpha-200);background:var(--nav-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.brew-progress-meta{display:flex;align-items:center;justify-content:space-between;gap:16px;color:var(--secondary);font-size:13px;line-height:18px}.brew-progress-meta strong{color:var(--primary);font-family:Geist Mono,ui-monospace,SFMono-Regular,Menlo,monospace;font-weight:500}.button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;border-radius:var(--radius-sm);padding:0 10px;border:1px solid transparent;font-size:14px;font-weight:500;line-height:20px;transition:background .15s var(--ease-pop),border-color .15s var(--ease-pop),transform .15s var(--ease-pop)}.button:hover{transform:translateY(-1px)}.button.primary{background:var(--primary);color:var(--background-100);min-width:144px}.button.secondary{background:var(--background-100);color:var(--primary);border-color:var(--gray-alpha-400)}.button.secondary:hover{background:var(--background-200);border-color:var(--gray-alpha-200)}.button.small,.button.compact{min-height:32px;padding:0 10px;font-size:13px}.button.wide{width:100%}.mobile-brew-controls{display:none}.workspace{display:grid;grid-template-columns:minmax(248px,280px) minmax(0,1fr) minmax(336px,392px);min-height:calc(100vh - 64px)}.rail{min-width:0;background:var(--background-100)}.rail-left{border-right:1px solid var(--gray-alpha-200);padding:18px}.rail-right{border-left:1px solid var(--gray-alpha-200);padding:18px}.guide-panel{min-width:0;padding:24px 18px 32px;scroll-margin-top:92px}.guide-panel:focus{outline:none}.panel,.instruction-panel{border:1px solid var(--gray-alpha-200);border-radius:var(--radius-sm);background:var(--background-100);box-shadow:var(--shadow-card)}.panel{padding:16px;margin-bottom:18px}.panel h2,.section-header h2{margin:0;font-size:14px;font-weight:600;line-height:20px;letter-spacing:-.28px}.panel-header,.section-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.label-muted{margin:0 0 4px;color:var(--secondary);font-size:13px;line-height:16px}.panel-header h2{margin:0;font-size:16px;font-weight:600;line-height:24px;letter-spacing:-.32px}.summary-list{display:grid;gap:14px;margin:0}.summary-row{display:flex;align-items:center;justify-content:space-between;gap:16px;font-size:14px;line-height:20px}.summary-row dt,.equipment-list li{display:flex;align-items:center;gap:10px;color:var(--primary)}.summary-row dd{margin:0;color:var(--secondary);text-align:right}.progress-block{margin-top:20px;padding-top:16px;border-top:1px solid var(--gray-alpha-100)}.progress-label{display:flex;justify-content:space-between;margin-bottom:10px;color:var(--secondary);font-size:13px}.progress-track{height:8px;overflow:hidden;border-radius:9999px;background:var(--gray-200)}.progress-track span{display:block;height:100%;border-radius:inherit;background:var(--primary);transition:width .15s linear}.equipment-list,.recipe-list,.log-list{list-style:none;padding:0;margin:0}.equipment-list{display:grid;gap:14px;color:var(--primary);font-size:14px}.notes-panel textarea{min-height:152px;width:100%;resize:vertical;border:0;background:transparent;color:var(--secondary);line-height:20px}.notes-panel textarea:focus-visible{box-shadow:none}.timer-hero{padding:0 22px 20px}.timer-sticky{position:sticky;top:64px;z-index:8;margin:0 -22px;padding:20px 22px 18px;border-bottom:1px solid var(--gray-alpha-100);background:var(--nav-bg);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}.app[data-brew-active=true] .timer-sticky{top:112px}.step-label{display:flex;align-items:center;gap:8px;color:var(--primary);font-size:16px;line-height:24px}.state-dot{width:12px;height:12px;border-radius:9999px;background:var(--amber-900)}.state-dot.idle{background:var(--disabled)}.state-dot.complete{background:var(--green-700)}.state-dot.paused{background:var(--amber-700)}.timer-row{display:flex;align-items:center;justify-content:space-between;gap:24px;margin-top:18px}.time-display{font-family:Geist Mono,ui-monospace,SFMono-Regular,Menlo,monospace;font-size:clamp(64px,7.5vw,92px);font-weight:500;line-height:1;letter-spacing:-4px;color:var(--timer-display-text)}.timer-actions{display:flex;gap:10px}.icon-button{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;width:74px;height:74px;border:1px solid var(--gray-alpha-200);border-radius:var(--radius-sm);background:var(--background-100);color:var(--primary);font-size:13px}.vertical-timeline{position:relative;display:grid;gap:14px;margin:24px 0 0;padding:4px 0 4px 44px}.vertical-timeline-track,.vertical-timeline-fill{position:absolute;top:18px;left:15px;width:3px;height:calc(100% - 36px);border-radius:9999px;background:var(--gray-200)}.vertical-timeline-fill{bottom:auto;max-height:calc(100% - 36px);background:var(--amber-900);transform-origin:top;transition:height .24s linear}.vertical-timeline-cursor{position:absolute;left:7px;width:19px;height:19px;border:3px solid var(--background-100);border-radius:9999px;background:var(--amber-900);box-shadow:0 0 0 1px var(--amber-900),0 8px 18px var(--gray-alpha-200);transform:translateY(-50%);transition:top .24s linear}.timeline-step{position:relative;display:grid;min-height:72px}.timeline-node{position:absolute;left:-40px;top:10px;z-index:1;display:grid;place-items:center;width:24px;height:24px;border:2px solid var(--gray-300);border-radius:9999px;background:var(--background-100);color:var(--secondary);font-family:Geist Mono,ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;line-height:1;transition:border-color .18s var(--ease-pop),color .18s var(--ease-pop),background .18s var(--ease-pop)}.timeline-step.complete .timeline-node{border-color:var(--amber-900);color:var(--amber-900)}.timeline-step.in-progress .timeline-node{border-color:var(--amber-900);background:var(--amber-100);color:var(--amber-900)}.timeline-step-card{display:grid;grid-template-columns:minmax(120px,.8fr) minmax(0,1.4fr);gap:14px;align-items:start;padding:12px 14px;border:1px solid var(--gray-alpha-200);border-radius:var(--radius-sm);background:var(--background-100);box-shadow:var(--shadow-card);transition:border-color .18s var(--ease-pop),background .18s var(--ease-pop)}.timeline-step.in-progress .timeline-step-card{border-color:color-mix(in srgb,var(--amber-900) 48%,var(--gray-alpha-200));background:var(--amber-100)}.timeline-step-card>div{display:grid;gap:4px}.timeline-step-card strong{color:var(--primary);font-size:14px;font-weight:600;line-height:20px}.timeline-step-card span,.timeline-step-card dt,.timeline-step-card dd,.target-strip{font-family:Geist Mono,ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px;line-height:18px}.timeline-step-card span,.timeline-step-card dt{color:var(--secondary)}.timeline-step-card dl{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:0}.timeline-step-card dl div{display:grid;gap:4px}.timeline-step-card dd{margin:0;color:var(--primary);font-weight:500}.target-strip{display:grid;grid-template-columns:auto 1fr auto 1fr;gap:10px;align-items:center;margin-top:18px;padding-top:16px;border-top:1px solid var(--gray-alpha-100);color:var(--secondary)}.target-strip strong{color:var(--primary);font-weight:500}.instruction-panel{display:grid;grid-template-columns:auto 1fr;gap:20px;margin-top:20px;padding:20px}.instruction-icon{display:grid;place-items:center;width:44px;height:44px;border:1px solid var(--instruction-border);border-radius:var(--radius-sm);background:var(--amber-100);color:var(--amber-900)}.instruction-panel h2{margin:0 0 8px;font-size:24px;font-weight:600;line-height:32px;letter-spacing:-.96px}.instruction-panel p{max-width:680px;margin:0;color:var(--secondary);font-size:14px;line-height:20px}.metric-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:18px}.metric-grid div{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;min-height:40px;padding:0 12px;border:1px solid var(--gray-alpha-200);border-radius:var(--radius-sm);color:var(--secondary);font-size:14px}.metric-grid strong{color:var(--primary);font-weight:500}.tip{display:flex;align-items:center;gap:8px;margin-top:16px;padding:14px 16px;border:1px solid #b8d3ff;border-color:var(--tip-border);border-radius:var(--radius-sm);color:var(--tip-text);background:var(--tip-bg);font-size:14px;line-height:20px}.controls-panel{padding-bottom:6px}.control-row{display:grid;grid-template-columns:118px minmax(0,1fr);gap:10px;align-items:center;min-height:48px;border-bottom:1px solid var(--gray-alpha-100)}.control-row label{display:flex;align-items:center;gap:10px;color:var(--primary);font-size:14px}.number-wrap,.select-wrap{display:grid;grid-template-columns:auto 1fr auto;align-items:center;min-height:34px;border:1px solid var(--gray-alpha-200);border-radius:var(--radius-sm);background:var(--field-bg);overflow:hidden}.number-wrap span{padding:0 10px;color:var(--secondary);font-family:Geist Mono,ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px}.number-wrap input,.select-wrap select,.slider-row select{width:100%;min-width:0;height:34px;border:0;background:transparent;color:var(--primary);font-family:Geist Mono,ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px;text-align:right}.number-wrap input::-webkit-outer-spin-button,.number-wrap input::-webkit-inner-spin-button{margin:0;-webkit-appearance:none;-moz-appearance:none;appearance:none}.number-wrap input[type=number]{-webkit-appearance:textfield;-moz-appearance:textfield;appearance:textfield}.number-wrap input{padding:0 8px}.number-wrap input:focus-visible,.select-wrap select:focus-visible,.slider-row select:focus-visible{box-shadow:none}.select-wrap{grid-template-columns:1fr auto;padding-right:8px}.select-wrap select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0 8px;font-family:Geist,Inter,ui-sans-serif,system-ui,sans-serif;text-align:left}.slider-row{grid-template-columns:118px minmax(0,1fr);padding:9px 0}.slider-row select{height:30px;text-align:right;font-family:Geist,Inter,ui-sans-serif,system-ui,sans-serif}.slider-row input[type=range]{grid-column:2;width:100%;accent-color:var(--primary)}.range-labels{grid-column:2;display:flex;justify-content:space-between;color:var(--secondary);font-size:12px;line-height:16px}.segmented{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--gray-alpha-200);border-radius:var(--radius-sm);overflow:hidden}.segmented button{height:32px;border:0;border-right:1px solid var(--gray-alpha-100);background:var(--field-bg);color:var(--secondary);font-family:Geist Mono,ui-monospace,SFMono-Regular,Menlo,monospace}.segmented button:last-child{border-right:0}.segmented button.selected{background:var(--primary);color:var(--background-100)}.control-footer{padding-top:14px}.recipe-list{display:grid}.recipe-list li{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:10px;min-height:60px;border-bottom:1px solid var(--gray-alpha-100)}.recipe-list li>button:first-child{display:grid;gap:4px;min-width:0;border:0;background:transparent;text-align:left}.recipe-list strong{color:var(--primary);font-size:14px;font-weight:600;line-height:20px}.recipe-list span,.empty-state{color:var(--secondary);font-size:13px;line-height:18px}.active-pill{padding:2px 8px;border-radius:9999px;background:var(--green-100);color:var(--active-pill-text);font-size:12px;line-height:16px}.ghost-icon{display:grid;place-items:center;width:32px;height:32px;border:0;border-radius:var(--radius-sm);background:transparent;color:var(--secondary)}.ghost-icon:hover{background:var(--gray-alpha-100);color:var(--red-800)}.link-button{display:inline-flex;align-items:center;gap:8px;min-height:40px;border:0;background:transparent;color:var(--blue-700);font-size:14px;font-weight:500}.log-list{display:grid;gap:10px}.log-list li{display:grid;grid-template-columns:1fr auto;gap:4px 12px;padding-bottom:10px;border-bottom:1px solid var(--gray-alpha-100);font-size:13px}.log-list small{grid-column:1 / -1;color:var(--secondary)}.expert-mobile{display:grid;gap:16px}@media(max-width:1180px){.top-nav{grid-template-columns:auto 1fr}.tabs{justify-content:center}.nav-actions{grid-column:1 / -1;justify-content:flex-start;height:56px;border-top:1px solid var(--gray-alpha-100);background:var(--background-100)}.brew-progress-sticky,.timer-sticky{top:120px}.app[data-brew-active=true] .timer-sticky{top:168px}.workspace{grid-template-columns:260px minmax(0,1fr)}.rail-right{display:none}}@media(min-width:1181px)and (max-width:1320px){.top-nav{grid-template-columns:260px 1fr auto}.workspace{grid-template-columns:minmax(236px,260px) minmax(0,1fr) minmax(308px,360px)}.rail-left,.rail-right,.guide-panel{padding-left:14px;padding-right:14px}.time-display{font-size:clamp(58px,7vw,82px)}.control-row,.slider-row{grid-template-columns:104px minmax(0,1fr)}}@media(max-width:760px){.app{padding-bottom:88px}.top-nav{position:static;grid-template-columns:1fr;height:auto}.brand{height:56px;padding:0 16px}.tabs,.nav-actions{justify-content:flex-start;height:auto;padding:0 16px}.tabs{border-top:1px solid var(--gray-alpha-100);overflow-x:auto}.tab{height:48px}.nav-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;padding-top:10px;padding-bottom:10px;overflow:visible}.nav-actions .button{min-width:0;white-space:nowrap}.nav-start{display:none}.brew-progress-sticky{top:0;padding:10px 16px}.workspace{display:block}.rail-left{border-right:0;border-bottom:1px solid var(--gray-alpha-200)}.guide-panel{padding:16px;scroll-margin-top:56px}.timer-hero{padding:0 0 18px}.timer-sticky{top:0;margin:0 -16px;padding:18px 16px 16px}.app[data-brew-active=true] .timer-sticky{top:45px}.timer-row,.instruction-panel{display:block}.time-display{font-size:clamp(54px,18vw,68px);letter-spacing:-2px;overflow-wrap:anywhere}.timer-actions{display:none}.vertical-timeline{margin-top:18px;padding-left:34px}.vertical-timeline-track,.vertical-timeline-fill{left:11px}.vertical-timeline-cursor{left:3px}.timeline-node{left:-34px}.timeline-step-card{grid-template-columns:1fr;gap:10px;padding:12px}.timeline-step-card dl{grid-template-columns:repeat(3,minmax(0,1fr))}.timeline-step-card strong,.timeline-step-card span,.timeline-step-card dt,.timeline-step-card dd{overflow-wrap:anywhere}.target-strip,.metric-grid{grid-template-columns:1fr}.instruction-icon{margin-bottom:16px}.control-row{grid-template-columns:1fr;gap:8px;padding:10px 0}.slider-row input[type=range],.range-labels{grid-column:1}.mobile-brew-controls{position:fixed;right:0;bottom:0;left:0;z-index:20;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;padding:12px 16px calc(12px + env(safe-area-inset-bottom));border-top:1px solid var(--gray-alpha-200);background:var(--nav-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.mobile-brew-controls .button{min-width:0}.mobile-brew-controls .button.secondary{min-width:92px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important}}
