*{box-sizing:border-box;margin:0;padding:0}:root{color-scheme:dark}html,body{height:100%}body{background:var(--bg, #16100c);color:var(--text, #f3ece4);font-family:var(--font, "Space Grotesk"),system-ui,sans-serif;-webkit-font-smoothing:antialiased;line-height:1.45}.mono{font-family:Space Mono,ui-monospace,monospace;font-variant-ligatures:none}.overline{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}h1,h2,h3{font-weight:600;letter-spacing:-.01em}::selection{background:var(--accent);color:#16100c}.app{display:flex;min-height:100vh;background:radial-gradient(120% 80% at 100% 0%,color-mix(in oklab,var(--accent) 7%,transparent),transparent 60%),var(--bg)}.sidebar{width:232px;flex-shrink:0;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:28px;padding:26px 18px;border-right:1px solid var(--line)}.brand{display:flex;align-items:center;gap:11px;padding:4px 10px}.brand-mark{width:22px;height:22px;border-radius:6px;background:var(--accent);box-shadow:0 0 0 4px color-mix(in oklab,var(--accent) 18%,transparent);position:relative}.brand-mark:after{content:"";position:absolute;inset:7px 7px auto auto;width:8px;height:8px;border-radius:50%;background:var(--bg)}.brand-name{font-weight:700;letter-spacing:.22em;font-size:15px}.nav{display:flex;flex-direction:column;gap:3px}.nav-item{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:11px;color:var(--muted);font-size:14.5px;font-weight:500;transition:background .15s,color .15s;text-align:left;width:100%}.nav-item:hover,.nav-item.active{background:var(--surface);color:var(--text)}.nav-item.active .nav-icon{color:var(--accent)}.nav-icon{display:flex}.nav-label{flex:1}.nav-badge{font-size:9.5px;padding:2px 6px;border-radius:20px;background:var(--surface2);color:var(--muted);letter-spacing:.08em}.sidebar-foot{margin-top:auto;padding:14px 12px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:5px}.sidebar-gear{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.main{flex:1;min-width:0;display:flex;flex-direction:column}.screen{width:100%;max-width:1080px;margin:0 auto;padding:40px 48px 80px;flex:1}.card,.panel,.featured,.gear-chip,.complete-card,.gear-card,.empty-glyph{background:var(--surface);border:1px solid var(--line)}.surf-glass .card,.surf-glass .panel,.surf-glass .featured,.surf-glass .gear-card,.surf-glass .complete-card{background:color-mix(in oklab,var(--surface) 62%,transparent);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.surf-flat .card,.surf-flat .panel,.surf-flat .featured,.surf-flat .gear-card,.surf-flat .complete-card{border-color:transparent;background:var(--surface)}.stripes{background-image:repeating-linear-gradient(135deg,color-mix(in oklab,var(--line) 55%,transparent) 0 1px,transparent 1px 9px);background-color:var(--surface2)}.lib-header{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:30px}.lib-title{font-size:30px;margin-top:6px}.gear-chip{display:flex;align-items:center;gap:11px;padding:10px 15px;border-radius:999px}.gear-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px color-mix(in oklab,var(--accent) 16%,transparent)}.gear-chip-name{font-size:13px;font-weight:600;white-space:nowrap}.gear-chip-sub{font-size:10.5px;color:var(--muted)}.featured{display:grid;grid-template-columns:220px 1fr;gap:4px;align-items:stretch;border-radius:var(--radius);overflow:hidden;text-align:left;width:100%;margin-bottom:30px;transition:border-color .2s,transform .2s}.featured:hover{border-color:color-mix(in oklab,var(--accent) 50%,var(--line))}.featured-mark{display:flex;align-items:center;justify-content:center}.featured-body{padding:28px 30px;display:flex;flex-direction:column;gap:10px}.featured-title{font-size:26px}.featured-blurb{color:var(--muted);font-size:14.5px;max-width:52ch}.featured-foot{display:flex;align-items:center;gap:12px;margin-top:auto;padding-top:10px;font-size:13px;color:var(--muted)}.featured-cta{margin-left:auto;color:var(--accent);font-weight:700}.dot-sep{width:3px;height:3px;border-radius:50%;background:var(--line);flex-shrink:0}.filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:22px}.pill{padding:8px 15px;border-radius:999px;border:1px solid var(--line);font-size:13px;font-weight:500;color:var(--muted);transition:all .15s}.pill:hover{color:var(--text);border-color:var(--muted)}.pill.active{background:var(--accent);color:#16100c;border-color:var(--accent);font-weight:600}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(252px,1fr));gap:18px}.recipe-card{border-radius:var(--radius);overflow:hidden;text-align:left;display:flex;flex-direction:column;transition:transform .2s,border-color .2s;padding:0}.recipe-card:hover{transform:translateY(-3px);border-color:color-mix(in oklab,var(--accent) 45%,var(--line))}.card-thumb{height:128px;display:flex;align-items:center;justify-content:center;position:relative}.card-method{position:absolute;left:14px;bottom:12px;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}.card-body{padding:17px 18px 18px;display:flex;flex-direction:column;gap:7px;flex:1}.card-top{display:flex;flex-direction:column;gap:2px}.card-title{font-size:17px}.card-author{font-size:12px;color:var(--muted)}.card-blurb{font-size:13px;color:var(--muted);flex:1}.card-foot{display:flex;align-items:center;gap:9px;font-size:12px;color:var(--muted);margin-top:4px}.ratio{color:var(--text);font-weight:700}.diff{display:inline-flex;align-items:center;gap:4px}.diff-dot{width:5px;height:5px;border-radius:50%}.diff-label{font-size:11.5px;color:var(--muted);margin-left:2px}.stat{display:flex;flex-direction:column;gap:3px}.stat-val{font-size:22px;font-weight:700;letter-spacing:-.02em}.stat-unit{font-size:13px;color:var(--muted);margin-left:2px;font-weight:400}.stat-label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.back{display:inline-flex;align-items:center;gap:6px;color:var(--muted);font-size:13.5px;font-weight:500;margin-bottom:26px;transition:color .15s}.back:hover{color:var(--text)}.detail-grid{display:grid;grid-template-columns:1fr 296px;gap:32px;align-items:start}.detail-hero{display:flex;gap:22px;align-items:center;margin-bottom:20px}.detail-hero-mark{width:104px;height:104px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;flex-shrink:0}.detail-title{font-size:34px;margin:5px 0 8px}.detail-author{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}.author-name{font-weight:600;font-size:14.5px}.author-note{font-size:12px;color:var(--muted)}.detail-blurb{font-size:16px;color:var(--text);opacity:.82;max-width:62ch;margin-bottom:26px;text-wrap:pretty}.stat-row{display:flex;gap:30px;flex-wrap:wrap;padding:22px 0 26px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-bottom:26px}.panel{border-radius:var(--radius);padding:22px 24px;margin-bottom:18px}.panel-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:18px}.panel-head h3{font-size:16px}.grindscale{margin-bottom:22px}.grindscale-track{position:relative;height:30px;display:flex;align-items:center;justify-content:space-between;padding:0 4px}.grindscale-tick{background:var(--line);border-radius:50%;flex-shrink:0}.grindscale-marker{position:absolute;top:50%;width:14px;height:14px;border-radius:50%;background:var(--accent);transform:translate(-50%,-50%);box-shadow:0 0 0 5px color-mix(in oklab,var(--accent) 20%,transparent);transition:left .3s}.grindscale-ends{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);margin-top:8px}.grindscale-now{color:var(--accent);font-weight:700}.grinder{display:flex;flex-direction:column;gap:16px;padding-top:20px;border-top:1px solid var(--line)}.grinder-head{display:flex;flex-direction:column;gap:8px}.grinder-select{position:relative;display:flex;align-items:center;gap:10px;padding:12px 14px;border:1px solid var(--line);border-radius:11px;background:var(--surface2);transition:border-color .15s;outline:none}.grinder-select:hover,.grinder-select:focus{border-color:var(--muted)}.grinder-name{font-weight:600;font-size:14.5px;flex:1}.grinder-kind{font-size:10.5px;color:var(--muted);padding:3px 8px;border-radius:20px;background:var(--surface)}.chev{color:var(--muted);transition:transform .2s}.chev.open{transform:rotate(180deg)}.grinder-menu{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:30;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:6px;box-shadow:0 18px 50px #00000080;max-height:320px;overflow:auto}.grinder-opt{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:10px 11px;border-radius:8px;transition:background .12s}.grinder-opt:hover{background:var(--surface2)}.grinder-opt.sel{background:color-mix(in oklab,var(--accent) 14%,transparent)}.grinder-opt-name{font-size:13.5px;font-weight:600}.grinder-opt-note{font-size:10.5px;color:var(--muted);margin-top:2px}.grinder-opt-kind{font-size:10px;color:var(--muted)}.grinder-readout{display:flex;align-items:center;gap:22px;padding:20px 22px;border-radius:13px;background:linear-gradient(135deg,color-mix(in oklab,var(--accent) 13%,var(--surface2)),var(--surface2));border:1px solid color-mix(in oklab,var(--accent) 30%,var(--line))}.readout-val{font-size:46px;font-weight:700;line-height:1;letter-spacing:-.03em;color:var(--accent)}.readout-unit{font-size:16px;color:var(--muted);margin-left:7px;font-weight:400}.readout-meta{display:flex;flex-direction:column;gap:5px}.readout-target{font-size:12px;color:var(--text);opacity:.8}.readout-ok{font-size:11px;color:var(--muted)}.readout-warn{font-size:11px;color:var(--accent)}.steplist{list-style:none;display:flex;flex-direction:column}.steprow{display:flex;align-items:flex-start;gap:14px;padding:13px 0;border-top:1px solid var(--line)}.steprow:first-child{border-top:none}.step-time{font-size:12.5px;color:var(--muted);width:38px;flex-shrink:0;padding-top:2px}.step-kind{width:8px;height:8px;border-radius:50%;margin-top:6px;flex-shrink:0;background:var(--accent)}.step-kind[data-kind=wait],.step-kind[data-kind=swirl]{background:var(--line)}.step-kind[data-kind=done]{background:var(--text)}.step-text{flex:1}.step-title{font-size:14.5px;font-weight:600}.step-cue{font-size:13px;color:var(--muted);margin-top:1px}.step-water{font-size:13px;font-weight:700;color:var(--text);padding-top:2px}.detail-side{position:sticky;top:28px}.side-sticky{display:flex;flex-direction:column;gap:16px}.equip-list{list-style:none;display:flex;flex-direction:column;gap:10px}.equip-list li{font-size:13px;color:var(--muted);padding-left:16px;position:relative}.equip-list li:before{content:"";position:absolute;left:0;top:7px;width:5px;height:5px;border-radius:1px;background:var(--accent)}.brew-cta{display:flex;flex-direction:column;align-items:center;gap:3px;padding:17px;border-radius:13px;background:var(--accent);color:#16100c;font-weight:700;font-size:15.5px;transition:filter .15s,transform .1s;width:100%}.brew-cta:hover{filter:brightness(1.07)}.brew-cta:active{transform:scale(.99)}.brew-cta-sub{font-size:11px;font-weight:400;opacity:.7}.brew-cta.inline{flex-direction:row}.brew{max-width:1180px;padding:30px 48px 60px;position:relative}.brew-top{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:20px;margin-bottom:30px}.brew-top .back{margin-bottom:0;justify-self:start}.brew-title-wrap{display:flex;flex-direction:column;align-items:center;gap:2px;justify-self:center}.brew-recipe-name{font-weight:600;font-size:16px;white-space:nowrap}.brew-grind{justify-self:end;padding:9px 15px;border-radius:999px;border:1px solid color-mix(in oklab,var(--accent) 40%,var(--line));color:var(--accent);font-size:13px;font-weight:700;white-space:nowrap}.brew-stage{display:grid;grid-template-columns:360px 1fr;gap:56px;align-items:center;min-height:440px}.brew-left{display:flex;flex-direction:column;align-items:center;gap:30px}.ring-wrap{position:relative}.ring-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}.ring-time{font-size:56px;font-weight:700;letter-spacing:-.03em;line-height:1}.ring-total{font-size:14px;color:var(--muted)}.ring-step{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-top:10px}.brew-controls{display:flex;align-items:center;gap:14px}.ctrl{display:inline-flex;align-items:center;justify-content:center;gap:9px;border-radius:999px;transition:all .15s}.ctrl.ghost{width:50px;height:50px;border:1px solid var(--line);color:var(--muted)}.ctrl.ghost:hover{border-color:var(--muted);color:var(--text)}.ctrl.primary{padding:0 26px;height:56px;background:var(--accent);color:#16100c;font-weight:700;font-size:15px;min-width:150px}.ctrl.primary:hover{filter:brightness(1.07)}.brew-right{display:flex;flex-direction:column;gap:18px}.brew-now{padding:26px 28px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--line);border-left:3px solid var(--accent)}.brew-now.done{border-left-color:var(--text)}.brew-now-title{font-size:27px;margin:8px 0 7px}.brew-now-cue{font-size:15.5px;color:var(--text);opacity:.82}.water{margin-top:18px}.water-row{display:flex;justify-content:space-between;font-size:13px;color:var(--muted);margin-bottom:8px}.water-target{color:var(--accent);font-weight:700;font-size:15px}.water-track{height:7px;border-radius:999px;background:var(--surface2);overflow:hidden}.water-fill{height:100%;background:var(--accent);border-radius:999px;transition:width .5s}.brew-next{display:flex;align-items:center;gap:12px;padding:14px 22px;border-radius:12px;border:1px dashed var(--line)}.brew-next-title{font-weight:600;font-size:14.5px;margin-left:auto}.brew-steplist{display:flex;flex-direction:column;gap:2px}.brew-step{display:flex;align-items:center;gap:14px;padding:11px 16px;border-radius:10px;color:var(--muted);transition:all .2s}.brew-step.past{opacity:.4}.brew-step.active{background:var(--surface);color:var(--text)}.brew-step-time{font-size:12.5px;width:38px}.brew-step.active .brew-step-time{color:var(--accent)}.brew-step-title{font-size:14px;font-weight:500;flex:1}.brew-step-water{font-size:12.5px;font-weight:700}.complete{display:flex;align-items:center;justify-content:center;min-height:80vh}.complete-card{border-radius:24px;padding:46px 50px;text-align:center;max-width:460px;width:100%;display:flex;flex-direction:column;align-items:center;gap:12px}.complete-mark{width:96px;height:96px;border-radius:20px;display:flex;align-items:center;justify-content:center;margin-bottom:6px}.complete-title{font-size:28px}.complete-sub{font-size:14.5px;color:var(--muted);max-width:36ch}.rating{display:flex;gap:7px;margin:8px 0}.star{transition:transform .12s}.star:hover{transform:scale(1.14)}.star.on{filter:drop-shadow(0 2px 8px color-mix(in oklab,var(--accent) 40%,transparent))}.complete-stats{display:flex;gap:34px;justify-content:center;padding:18px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);width:100%;margin:6px 0 4px}.complete-stats .stat{align-items:center}.complete-actions{display:flex;gap:12px;width:100%;margin-top:6px}.ghost-btn{flex:1;padding:15px;border-radius:12px;border:1px solid var(--line);font-weight:600;font-size:14.5px;color:var(--text);transition:border-color .15s}.ghost-btn:hover{border-color:var(--muted)}.complete-actions .brew-cta{flex:1.4}.gear-search{display:flex;align-items:center;gap:9px;padding:10px 14px;border-radius:999px;border:1px solid var(--line);background:var(--surface);min-width:260px;transition:border-color .15s}.gear-search:focus-within{border-color:var(--muted)}.gear-search-icon{color:var(--muted);flex-shrink:0}.gear-search-input{flex:1;background:none;border:none;outline:none;color:var(--text);font-family:inherit;font-size:14px}.gear-search-input::placeholder{color:var(--muted)}.gear-search-clear{color:var(--muted);font-size:12px;line-height:1;padding:2px;transition:color .15s}.gear-search-clear:hover{color:var(--text)}.gear-empty{color:var(--muted);font-size:14px;padding:30px 0}.equip-intro{font-size:16px;color:var(--muted);max-width:56ch;margin-bottom:28px;text-wrap:pretty}.gear-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(264px,1fr));gap:16px}.gear-card{border-radius:var(--radius);padding:22px;text-align:left;display:flex;flex-direction:column;gap:6px;transition:transform .2s,border-color .2s}.gear-card:hover{transform:translateY(-3px);border-color:var(--muted)}.gear-card.sel{border-color:var(--accent);background:color-mix(in oklab,var(--accent) 8%,var(--surface))}.gear-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.gear-card-kind{font-size:10.5px;color:var(--muted);padding:3px 9px;border-radius:20px;background:var(--surface2)}.gear-card-active{font-size:10.5px;color:var(--accent);font-weight:700}.gear-card-name{font-size:18px;font-weight:600}.gear-card-brand{font-size:11.5px;color:var(--muted)}.gear-card-note{font-size:13px;color:var(--muted);margin-top:6px;flex:1}.gear-card-spec{font-size:11px;color:var(--text);opacity:.55;margin-top:10px;padding-top:12px;border-top:1px solid var(--line)}.empty-screen{display:flex;align-items:center;justify-content:center;min-height:78vh}.empty-inner{text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px;max-width:420px}.empty-glyph{width:100px;height:100px;border-radius:24px;display:flex;align-items:center;justify-content:center;color:var(--accent)}.empty-title{font-size:26px}.empty-line{font-size:15px;color:var(--muted);text-wrap:pretty}.empty-badge{font-size:11px;padding:6px 13px;border-radius:20px;border:1px solid var(--line);color:var(--muted);margin-top:4px}@media (max-width: 920px){.detail-grid{grid-template-columns:1fr}.detail-side{position:static}.brew-stage{grid-template-columns:1fr;gap:36px}.brew-left{order:-1}.featured{grid-template-columns:1fr}.featured-mark{height:150px}}@media (max-width: 720px){.sidebar{display:none}.screen,.brew{padding:28px 22px 60px}}
