:root{--color-bg: #fdfcfa;--color-bg-alt: #f7f5f2;--color-surface: #ffffff;--color-surface-raised: #ffffff;--color-text: #1c1917;--color-text-secondary: #44403c;--color-text-muted: #78716c;--color-accent: #92400e;--color-accent-hover: #78350f;--color-accent-light: #fef3c7;--color-border: #e7e5e4;--color-border-strong: #d6d3d1;--color-muted: var(--color-text-muted);--font-heading: "Playfair Display", Georgia, "Times New Roman", serif;--font-body: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "SF Mono", ui-monospace, monospace;--font-sans: var(--font-body);--text-xs: clamp(.75rem, .7rem + .25vw, .8125rem);--text-sm: clamp(.875rem, .825rem + .25vw, .9375rem);--text-base: clamp(1rem, .95rem + .25vw, 1.0625rem);--text-lg: clamp(1.125rem, 1.05rem + .375vw, 1.25rem);--text-xl: clamp(1.25rem, 1.15rem + .5vw, 1.5rem);--text-2xl: clamp(1.5rem, 1.35rem + .75vw, 1.875rem);--text-3xl: clamp(1.875rem, 1.65rem + 1.125vw, 2.5rem);--text-4xl: clamp(2.25rem, 1.9rem + 1.75vw, 3.25rem);--leading-tight: 1.2;--leading-snug: 1.35;--leading-normal: 1.6;--leading-relaxed: 1.75;--tracking-tight: -.025em;--tracking-normal: 0;--tracking-wide: .025em;--tracking-wider: .05em;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--space-4xl: 6rem;--container-sm: 640px;--container-md: 768px;--container-lg: 960px;--container-xl: 1120px;--content-width: 65ch;--radius: 8px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px;--shadow: 0 1px 3px rgba(28, 25, 23, .04);--shadow-sm: 0 1px 2px rgba(28, 25, 23, .04);--shadow-md: 0 2px 8px rgba(28, 25, 23, .06), 0 1px 2px rgba(28, 25, 23, .04);--shadow-lg: 0 4px 16px rgba(28, 25, 23, .08), 0 2px 4px rgba(28, 25, 23, .04);--shadow-xl: 0 8px 32px rgba(28, 25, 23, .1), 0 4px 8px rgba(28, 25, 23, .05);--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .4s;--ease-out: cubic-bezier(.33, 1, .68, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1)}*,*:before,*:after{box-sizing:border-box}*{margin:0}html{font-size:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth}body{font-family:var(--font-body);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text);background:var(--color-bg);min-height:100vh;display:flex;flex-direction:column}img,picture,video,canvas,svg{display:block;max-width:100%;height:auto}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:600;line-height:var(--leading-tight);letter-spacing:var(--tracking-tight);color:var(--color-text)}h1{font-size:var(--text-3xl);font-weight:700}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}a{color:var(--color-accent);text-decoration:none;transition:color var(--duration-fast) var(--ease-out)}a:hover{color:var(--color-accent-hover)}a:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:var(--radius-sm)}.container{width:100%;max-width:var(--container-md);margin-inline:auto;padding-inline:var(--space-md)}.container--narrow{max-width:var(--container-sm)}.container--wide{max-width:var(--container-lg)}.container--xl{max-width:var(--container-xl)}.prose{max-width:var(--content-width)}.skip-link{position:absolute;top:-3rem;left:var(--space-md);z-index:1000;padding:var(--space-sm) var(--space-md);background:var(--color-text);color:var(--color-bg);font-size:var(--text-sm);font-weight:500;border-radius:var(--radius-md);transition:top var(--duration-normal) var(--ease-out)}.skip-link:focus{top:var(--space-md);outline:none;box-shadow:0 0 0 3px var(--color-accent-light);color:var(--color-bg)}.site-header{position:sticky;top:0;z-index:100;background:#fdfcfaeb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border)}.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding-block:var(--space-md);max-width:var(--container-xl)}.logo{display:flex;align-items:center;transition:opacity var(--duration-fast) var(--ease-out)}.logo:hover{opacity:.8;text-decoration:none}.logo-img{height:32px;width:auto}.nav-links{display:flex;align-items:center;gap:var(--space-xs);list-style:none;padding:0;margin:0}.nav-links li{display:flex}.nav-links a{display:block;padding:var(--space-sm) var(--space-md);font-size:var(--text-sm);font-weight:500;color:var(--color-text-secondary);border-radius:var(--radius-md);transition:all var(--duration-fast) var(--ease-out)}.nav-links a:hover{color:var(--color-text);background:var(--color-bg-alt);text-decoration:none}.nav-links a[aria-current=page]{color:var(--color-accent);background:var(--color-accent-light)}.nav-links a.nav-dropdown__trigger[aria-current=page]{color:var(--color-accent);background:transparent}.nav-instagram{display:flex;align-items:center;justify-content:center;padding:var(--space-sm);color:var(--color-text-muted)}.nav-instagram:hover{color:var(--color-accent)}.nav-instagram svg{display:block}.nav-dropdown{position:relative}.nav-links .nav-dropdown__trigger{display:flex;align-items:center;gap:4px}.nav-dropdown__trigger svg{transition:transform var(--duration-fast) var(--ease-out)}.nav-dropdown:hover .nav-dropdown__trigger svg,.nav-dropdown:focus-within .nav-dropdown__trigger svg{transform:rotate(180deg)}.nav-dropdown__menu{position:absolute;top:100%;left:50%;transform:translate(-50%);min-width:200px;padding:var(--space-sm);background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-xl);opacity:0;visibility:hidden;translate:0 4px;transition:opacity var(--duration-fast) var(--ease-out),visibility var(--duration-fast) var(--ease-out),translate var(--duration-fast) var(--ease-out);z-index:100}.nav-dropdown:hover .nav-dropdown__menu,.nav-dropdown:focus-within .nav-dropdown__menu{opacity:1;visibility:visible;translate:0 0}.nav-dropdown__group{padding:var(--space-xs) 0}.nav-dropdown__group+.nav-dropdown__group{border-top:1px solid var(--color-border)}.nav-dropdown__label{display:block;padding:var(--space-xs) var(--space-sm);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:var(--tracking-wider);color:var(--color-text-muted)}.nav-dropdown__menu a{display:block;padding:6px var(--space-sm);font-size:var(--text-sm);color:var(--color-text-secondary);border-radius:var(--radius-sm);transition:background var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out)}.nav-dropdown__menu a:hover{background:var(--color-bg-alt);color:var(--color-text);text-decoration:none}@media(max-width:768px){.site-header .container{flex-wrap:wrap}.nav-links{width:100%;justify-content:flex-start;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin-inline:calc(-1 * var(--space-md));padding-inline:var(--space-md);gap:0}.nav-links::-webkit-scrollbar{display:none}.nav-links a{white-space:nowrap;padding:var(--space-xs) var(--space-sm)}.nav-dropdown__menu{display:none}}.main{flex:1}.main>.container:first-child,.main>section:first-child+.container{padding-top:var(--space-2xl)}@media(min-width:768px){.main>.container:first-child,.main>section:first-child+.container{padding-top:var(--space-3xl)}}.site-footer{margin-top:var(--space-3xl);padding-block:var(--space-2xl);background:var(--color-bg-alt);border-top:1px solid var(--color-border)}.site-footer .container{max-width:var(--container-xl)}.footer-content{display:flex;flex-direction:column;gap:var(--space-xl)}@media(min-width:768px){.footer-content{flex-direction:row;justify-content:space-between;align-items:flex-start}}.footer-brand{display:flex;flex-direction:column;gap:var(--space-md)}.footer-logo{display:inline-flex}.footer-logo-img{height:28px;width:auto}.footer-brand p{font-size:var(--text-sm);color:var(--color-text-muted);max-width:32ch;line-height:var(--leading-relaxed)}.footer-nav{display:flex;flex-wrap:wrap;gap:var(--space-sm) var(--space-lg)}.site-footer a{font-size:var(--text-sm);color:var(--color-text-secondary);transition:color var(--duration-fast) var(--ease-out)}.site-footer a:hover{color:var(--color-accent)}.footer-social{display:flex;gap:var(--space-md)}.social-link{display:inline-flex;align-items:center;gap:var(--space-sm);font-size:var(--text-sm);font-weight:500;color:var(--color-text-secondary);padding:var(--space-sm) var(--space-md);background:var(--color-surface);border-radius:var(--radius-md);transition:all var(--duration-fast) var(--ease-out)}.social-link:hover{background:var(--color-accent-light);color:var(--color-accent);text-decoration:none}.social-link svg{flex-shrink:0}.site-footer p{font-size:var(--text-sm);color:var(--color-text-muted);max-width:40ch;line-height:var(--leading-relaxed)}.card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);transition:all var(--duration-normal) var(--ease-out)}.card:hover{box-shadow:var(--shadow-md);border-color:var(--color-border-strong)}.card h2,.card h3{margin-top:0;font-family:var(--font-heading)}.card-link{display:block;color:inherit;text-decoration:none}.card-link:hover{text-decoration:none}.card-link:hover .card,.card-link:hover.card{box-shadow:var(--shadow-lg);border-color:var(--color-border-strong);transform:translateY(-2px)}.card-link:focus-visible{outline:none}.card-link:focus-visible .card,.card-link:focus-visible.card{outline:2px solid var(--color-accent);outline-offset:2px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);min-height:2.75rem;padding:var(--space-sm) var(--space-lg);font-size:var(--text-sm);font-weight:600;line-height:1.25;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);text-decoration:none}.btn:hover{background:var(--color-bg-alt);border-color:var(--color-text-muted);text-decoration:none}.btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.btn:active{transform:translateY(1px)}.btn--primary{color:var(--color-bg);background:var(--color-accent);border-color:var(--color-accent)}.btn--primary:hover{background:var(--color-accent-hover);border-color:var(--color-accent-hover)}.btn--ghost{background:transparent;border-color:transparent}.btn--ghost:hover{background:var(--color-bg-alt);border-color:transparent}.btn--sm{min-height:2.25rem;padding:var(--space-xs) var(--space-md);font-size:var(--text-xs)}.btn--lg{min-height:3.25rem;padding:var(--space-md) var(--space-xl);font-size:var(--text-base)}label{display:block;font-size:var(--text-sm);font-weight:500;color:var(--color-text-secondary);margin-bottom:var(--space-xs)}input,select,textarea{width:100%;min-height:2.75rem;padding:var(--space-sm) var(--space-md);font-size:var(--text-base);color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);transition:all var(--duration-fast) var(--ease-out)}input:hover,select:hover,textarea:hover{border-color:var(--color-text-muted)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light)}input::placeholder{color:var(--color-text-muted)}select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2378716c' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-md) center;padding-right:calc(var(--space-md) * 2 + 16px)}.form-group{margin-bottom:var(--space-lg)}.badge{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);font-size:var(--text-xs);font-weight:600;letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--color-bg);background:var(--color-accent);border-radius:var(--radius-sm)}.tag{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);font-size:var(--text-xs);font-weight:500;color:var(--color-text-secondary);background:var(--color-bg-alt);border-radius:var(--radius-full);transition:all var(--duration-fast) var(--ease-out)}.tag:hover{background:var(--color-border)}.tags{display:flex;flex-wrap:wrap;gap:var(--space-xs);list-style:none;padding:0;margin:0}.tags li{display:flex}.content{max-width:var(--content-width)}.content>*+*{margin-top:var(--space-lg)}.content h1{font-size:var(--text-3xl);margin-top:0;margin-bottom:var(--space-lg)}.content h2{font-size:var(--text-2xl);margin-top:var(--space-2xl);margin-bottom:var(--space-md)}.content h3{font-size:var(--text-xl);margin-top:var(--space-xl);margin-bottom:var(--space-sm)}.content p{line-height:var(--leading-relaxed)}.content ul,.content ol{padding-left:var(--space-lg)}.content li{margin-bottom:var(--space-sm)}.content li::marker{color:var(--color-accent)}.content blockquote{padding-left:var(--space-lg);border-left:3px solid var(--color-accent);color:var(--color-text-secondary);font-style:italic}.content code{font-family:var(--font-mono);font-size:.9em;padding:.125em .375em;background:var(--color-bg-alt);border-radius:var(--radius-sm)}.content pre{padding:var(--space-lg);background:var(--color-text);color:var(--color-bg);border-radius:var(--radius-lg);overflow-x:auto}.content pre code{background:transparent;padding:0}.content a{text-decoration:underline;text-decoration-color:var(--color-accent-light);text-underline-offset:2px;transition:text-decoration-color var(--duration-fast) var(--ease-out)}.content a:hover{text-decoration-color:var(--color-accent)}.ratio-calc{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:var(--shadow-lg)}.ratio-calc__methods{display:flex;flex-wrap:wrap;gap:3px;background:var(--color-bg-alt);border-radius:var(--radius-md);padding:3px;margin-bottom:var(--space-md)}.ratio-calc__chip{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);padding:6px var(--space-sm);border:none;border-radius:6px;background:transparent;color:var(--color-text-muted);font-size:13px;font-weight:500;font-family:var(--font-body);white-space:nowrap;cursor:pointer;flex:1 0 auto;min-width:max-content;transition:background var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.ratio-calc__chip:hover{color:var(--color-text-secondary)}.ratio-calc__chip--active{background:var(--color-surface);color:var(--color-text);font-weight:600;box-shadow:var(--shadow-sm)}.ratio-calc__field{margin-bottom:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border:1px solid transparent;transition:background var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out)}.ratio-calc__field--result{background:var(--color-accent-light);border-color:color-mix(in srgb,var(--color-accent) 25%,transparent)}.ratio-calc__label{display:block;font-size:13px;font-weight:600;color:var(--color-text);margin-bottom:6px;letter-spacing:var(--tracking-wide)}.ratio-calc__unit{font-weight:400;color:var(--color-text-muted)}.ratio-calc__stepper{display:flex;align-items:center;gap:6px}.ratio-calc__step-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;flex-shrink:0;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;font-family:var(--font-body);transition:background var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out)}.ratio-calc__step-btn:hover{background:var(--color-bg-alt);border-color:var(--color-border-strong);color:var(--color-text)}.ratio-calc__step-btn:active{background:var(--color-accent-light)}.ratio-calc__input{flex:1;min-width:0;height:46px;text-align:center;font-size:var(--text-lg);font-family:var(--font-mono);font-weight:600;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:0 var(--space-sm);transition:border-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out);-moz-appearance:textfield}.ratio-calc__input::-webkit-outer-spin-button,.ratio-calc__input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.ratio-calc__input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-accent) 15%,transparent)}.ratio-calc__ratio{text-align:center;margin-bottom:var(--space-md);padding:var(--space-sm) 0}.ratio-calc__ratio-display{display:block;font-family:var(--font-mono);font-size:var(--text-2xl);font-weight:700;color:var(--color-text);letter-spacing:var(--tracking-tight);margin-bottom:var(--space-sm)}.ratio-calc__slider-wrap{display:flex;align-items:center;gap:var(--space-sm)}.ratio-calc__slider-label{font-size:11px;font-family:var(--font-mono);color:var(--color-text-muted);flex-shrink:0;min-width:3ch}.ratio-calc__slider{-webkit-appearance:none;appearance:none;flex:1;height:4px;border-radius:var(--radius-full);background:linear-gradient(to right,var(--color-accent) 0%,var(--color-accent) var(--fill, 50%),var(--color-border) var(--fill, 50%),var(--color-border) 100%);outline:none;cursor:pointer}.ratio-calc__slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--color-accent);border:2px solid var(--color-surface);box-shadow:var(--shadow-md);cursor:pointer;transition:transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.ratio-calc__slider::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:var(--shadow-lg)}.ratio-calc__slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--color-accent);border:2px solid var(--color-surface);box-shadow:var(--shadow-md);cursor:pointer;transition:transform var(--duration-fast) var(--ease-out)}.ratio-calc__slider::-moz-range-track{height:4px;border-radius:var(--radius-full);background:transparent}.ratio-calc__slider:focus-visible{outline:2px solid var(--color-accent);outline-offset:4px;border-radius:var(--radius-full)}.ratio-calc__helper{font-size:12px;color:var(--color-text-muted);text-align:center;margin-bottom:var(--space-sm)}.ratio-calc__unit-toggle{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);margin-top:2px;margin-bottom:var(--space-sm)}.ratio-calc__unit-label{font-size:12px;font-weight:400;color:var(--color-text-muted);transition:color var(--duration-fast) var(--ease-out)}.ratio-calc__unit-label--active{font-weight:600;color:var(--color-text)}.ratio-calc__toggle-track{position:relative;width:36px;height:20px;border-radius:10px;border:none;background:var(--color-border);cursor:pointer;padding:0;transition:background var(--duration-fast) var(--ease-out)}.ratio-calc__toggle-track[aria-checked=true]{background:var(--color-accent)}.ratio-calc__toggle-thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;pointer-events:none;transition:left var(--duration-fast) var(--ease-out)}.ratio-calc__toggle-thumb--on{left:calc(100% - 18px)}.ratio-calc__converted{display:block;text-align:center;font-size:13px;color:var(--color-text-muted);margin-top:4px}.ratio-calc__reset{display:block;width:auto;margin-left:auto;padding:6px var(--space-md);font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--color-text-muted);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:color var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out)}.ratio-calc__reset:hover{color:var(--color-text);border-color:var(--color-border-strong);background:var(--color-bg-alt)}@media(min-width:768px){.ratio-calc{padding:var(--space-lg)}}.cold-brew-calc{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:var(--shadow-lg)}.cold-brew-calc__modes{display:flex;background:var(--color-bg-alt);border-radius:var(--radius-md);padding:3px;margin-bottom:var(--space-md)}.cold-brew-calc__mode{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);padding:6px var(--space-sm);border:none;border-radius:6px;background:transparent;color:var(--color-text-muted);font-size:13px;font-weight:500;font-family:var(--font-body);white-space:nowrap;cursor:pointer;flex:1;min-width:0;transition:background var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.cold-brew-calc__mode:hover{color:var(--color-text-secondary)}.cold-brew-calc__mode--active{background:var(--color-surface);color:var(--color-text);font-weight:600;box-shadow:var(--shadow-sm)}.cold-brew-calc__field{margin-bottom:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border:1px solid transparent;transition:background var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out)}.cold-brew-calc__field--result{background:var(--color-accent-light);border-color:color-mix(in srgb,var(--color-accent) 25%,transparent)}.cold-brew-calc__label{display:block;font-size:13px;font-weight:600;color:var(--color-text);margin-bottom:6px;letter-spacing:var(--tracking-wide)}.cold-brew-calc__unit{font-weight:400;color:var(--color-text-muted)}.cold-brew-calc__stepper{display:flex;align-items:center;gap:6px}.cold-brew-calc__step-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;flex-shrink:0;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;font-family:var(--font-body);transition:background var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out)}.cold-brew-calc__step-btn:hover{background:var(--color-bg-alt);border-color:var(--color-border-strong);color:var(--color-text)}.cold-brew-calc__step-btn:active{background:var(--color-accent-light)}.cold-brew-calc__input{flex:1;min-width:0;height:46px;text-align:center;font-size:var(--text-lg);font-family:var(--font-mono);font-weight:600;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:0 var(--space-sm);transition:border-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out);-moz-appearance:textfield}.cold-brew-calc__input::-webkit-outer-spin-button,.cold-brew-calc__input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.cold-brew-calc__input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-accent) 15%,transparent)}.cold-brew-calc__ratio{text-align:center;margin-bottom:var(--space-md);padding:var(--space-sm) 0}.cold-brew-calc__ratio-display{display:block;font-family:var(--font-mono);font-size:var(--text-2xl);font-weight:700;color:var(--color-text);letter-spacing:var(--tracking-tight);margin-bottom:var(--space-sm)}.cold-brew-calc__slider-wrap{display:flex;align-items:center;gap:var(--space-sm)}.cold-brew-calc__slider-label{font-size:11px;font-family:var(--font-mono);color:var(--color-text-muted);flex-shrink:0;min-width:3ch}.cold-brew-calc__slider{-webkit-appearance:none;appearance:none;flex:1;height:4px;border-radius:var(--radius-full);background:linear-gradient(to right,var(--color-accent) 0%,var(--color-accent) var(--fill, 50%),var(--color-border) var(--fill, 50%),var(--color-border) 100%);outline:none;cursor:pointer}.cold-brew-calc__slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--color-accent);border:2px solid var(--color-surface);box-shadow:var(--shadow-md);cursor:pointer;transition:transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.cold-brew-calc__slider::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:var(--shadow-lg)}.cold-brew-calc__slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--color-accent);border:2px solid var(--color-surface);box-shadow:var(--shadow-md);cursor:pointer;transition:transform var(--duration-fast) var(--ease-out)}.cold-brew-calc__slider::-moz-range-track{height:4px;border-radius:var(--radius-full);background:transparent}.cold-brew-calc__slider:focus-visible{outline:2px solid var(--color-accent);outline-offset:4px;border-radius:var(--radius-full)}.cold-brew-calc__helper{font-size:12px;color:var(--color-text-muted);text-align:center;margin-bottom:var(--space-sm)}.cold-brew-calc__divider{border-top:1px solid var(--color-border);margin:var(--space-md) 0;padding-top:var(--space-md)}.cold-brew-calc__section-label{font-size:13px;font-weight:600;color:var(--color-text);margin-bottom:var(--space-sm)}.cold-brew-calc__info-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm)}.cold-brew-calc__info-card{background:var(--color-bg-alt);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);text-align:center}.cold-brew-calc__info-value{font-family:var(--font-mono);font-size:var(--text-lg);font-weight:600;color:var(--color-text)}.cold-brew-calc__info-label{font-size:12px;color:var(--color-text-muted);margin-top:2px}.cold-brew-calc__steep{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-bg-alt);border-radius:var(--radius-md);font-size:13px;color:var(--color-text-secondary);margin-top:var(--space-md)}.cold-brew-calc__steep-icon{flex-shrink:0;color:var(--color-text-muted)}.cold-brew-calc__reset{display:block;width:auto;margin-left:auto;margin-top:var(--space-md);padding:6px var(--space-md);font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--color-text-muted);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:color var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out)}.cold-brew-calc__reset:hover{color:var(--color-text);border-color:var(--color-border-strong);background:var(--color-bg-alt)}@media(min-width:768px){.cold-brew-calc{padding:var(--space-lg)}}.espresso-calc{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:var(--shadow-lg)}.espresso-calc__shot-type{text-align:center;font-size:var(--text-sm);font-weight:600;color:var(--color-accent);margin-bottom:var(--space-md);letter-spacing:var(--tracking-wide)}.espresso-calc__field{margin-bottom:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border:1px solid transparent;transition:background var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out)}.espresso-calc__field--result{background:var(--color-accent-light);border-color:color-mix(in srgb,var(--color-accent) 25%,transparent)}.espresso-calc__label{display:block;font-size:13px;font-weight:600;color:var(--color-text);margin-bottom:6px;letter-spacing:var(--tracking-wide)}.espresso-calc__unit{font-weight:400;color:var(--color-text-muted)}.espresso-calc__stepper{display:flex;align-items:center;gap:6px}.espresso-calc__step-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;flex-shrink:0;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;font-family:var(--font-body);transition:background var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out)}.espresso-calc__step-btn:hover{background:var(--color-bg-alt);border-color:var(--color-border-strong);color:var(--color-text)}.espresso-calc__step-btn:active{background:var(--color-accent-light)}.espresso-calc__input{flex:1;min-width:0;height:46px;text-align:center;font-size:var(--text-lg);font-family:var(--font-mono);font-weight:600;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:0 var(--space-sm);transition:border-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out);-moz-appearance:textfield}.espresso-calc__input::-webkit-outer-spin-button,.espresso-calc__input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.espresso-calc__input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-accent) 15%,transparent)}.espresso-calc__ratio{text-align:center;margin-bottom:var(--space-md);padding:var(--space-sm) 0}.espresso-calc__ratio-display{display:block;font-family:var(--font-mono);font-size:var(--text-2xl);font-weight:700;color:var(--color-text);letter-spacing:var(--tracking-tight);margin-bottom:var(--space-sm)}.espresso-calc__slider-wrap{display:flex;align-items:center;gap:var(--space-sm)}.espresso-calc__slider-label{font-size:11px;font-family:var(--font-mono);color:var(--color-text-muted);flex-shrink:0;min-width:3ch}.espresso-calc__slider{-webkit-appearance:none;appearance:none;flex:1;height:4px;border-radius:var(--radius-full);background:linear-gradient(to right,var(--color-accent) 0%,var(--color-accent) var(--fill, 50%),var(--color-border) var(--fill, 50%),var(--color-border) 100%);outline:none;cursor:pointer}.espresso-calc__slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--color-accent);border:2px solid var(--color-surface);box-shadow:var(--shadow-md);cursor:pointer;transition:transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.espresso-calc__slider::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:var(--shadow-lg)}.espresso-calc__slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--color-accent);border:2px solid var(--color-surface);box-shadow:var(--shadow-md);cursor:pointer;transition:transform var(--duration-fast) var(--ease-out)}.espresso-calc__slider::-moz-range-track{height:4px;border-radius:var(--radius-full);background:transparent}.espresso-calc__slider:focus-visible{outline:2px solid var(--color-accent);outline-offset:4px;border-radius:var(--radius-full)}.espresso-calc__helper{font-size:12px;color:var(--color-text-muted);text-align:center;margin-bottom:var(--space-sm)}.espresso-calc__time-section{margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--color-border)}.espresso-calc__time-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.espresso-calc__time-label{font-size:13px;font-weight:600;color:var(--color-text)}.espresso-calc__time-value{font-family:var(--font-mono);font-size:var(--text-lg);font-weight:600}.espresso-calc__time-bar{position:relative;height:8px;border-radius:var(--radius-full);background:linear-gradient(to right,#f59e0b 0% 15%,#22c55e 15% 65%,#ef4444 65% 100%);margin-bottom:var(--space-xs)}.espresso-calc__time-marker{position:absolute;top:-6px;width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid var(--color-text);transform:translate(-6px);transition:left var(--duration-fast) var(--ease-out)}.espresso-calc__time-zones{display:flex;justify-content:space-between;font-size:11px;color:var(--color-text-muted)}.espresso-calc__grind-hint{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-bg-alt);border-radius:var(--radius-md);font-size:13px;color:var(--color-text-secondary);margin-top:var(--space-sm)}.espresso-calc__reset{display:block;width:auto;margin-left:auto;margin-top:var(--space-md);padding:6px var(--space-md);font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--color-text-muted);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:color var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out)}.espresso-calc__reset:hover{color:var(--color-text);border-color:var(--color-border-strong);background:var(--color-bg-alt)}@media(min-width:768px){.espresso-calc{padding:var(--space-lg)}}.pour-over-calc{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:var(--shadow-lg)}.pour-over-calc__field{margin-bottom:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border:1px solid transparent;transition:background var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out)}.pour-over-calc__field--result{background:var(--color-accent-light);border-color:color-mix(in srgb,var(--color-accent) 25%,transparent)}.pour-over-calc__label{display:block;font-size:13px;font-weight:600;color:var(--color-text);margin-bottom:6px;letter-spacing:var(--tracking-wide)}.pour-over-calc__unit{font-weight:400;color:var(--color-text-muted)}.pour-over-calc__stepper{display:flex;align-items:center;gap:6px}.pour-over-calc__step-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;flex-shrink:0;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;font-family:var(--font-body);transition:background var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out)}.pour-over-calc__step-btn:hover{background:var(--color-bg-alt);border-color:var(--color-border-strong);color:var(--color-text)}.pour-over-calc__step-btn:active{background:var(--color-accent-light)}.pour-over-calc__input{flex:1;min-width:0;height:46px;text-align:center;font-size:var(--text-lg);font-family:var(--font-mono);font-weight:600;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:0 var(--space-sm);transition:border-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out);-moz-appearance:textfield}.pour-over-calc__input::-webkit-outer-spin-button,.pour-over-calc__input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.pour-over-calc__input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-accent) 15%,transparent)}.pour-over-calc__ratio{text-align:center;margin-bottom:var(--space-md);padding:var(--space-sm) 0}.pour-over-calc__ratio-display{display:block;font-family:var(--font-mono);font-size:var(--text-2xl);font-weight:700;color:var(--color-text);letter-spacing:var(--tracking-tight);margin-bottom:var(--space-sm)}.pour-over-calc__slider-wrap{display:flex;align-items:center;gap:var(--space-sm)}.pour-over-calc__slider-label{font-size:11px;font-family:var(--font-mono);color:var(--color-text-muted);flex-shrink:0;min-width:3ch}.pour-over-calc__slider{-webkit-appearance:none;appearance:none;flex:1;height:4px;border-radius:var(--radius-full);background:linear-gradient(to right,var(--color-accent) 0%,var(--color-accent) var(--fill, 50%),var(--color-border) var(--fill, 50%),var(--color-border) 100%);outline:none;cursor:pointer}.pour-over-calc__slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--color-accent);border:2px solid var(--color-surface);box-shadow:var(--shadow-md);cursor:pointer;transition:transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.pour-over-calc__slider::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:var(--shadow-lg)}.pour-over-calc__slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--color-accent);border:2px solid var(--color-surface);box-shadow:var(--shadow-md);cursor:pointer;transition:transform var(--duration-fast) var(--ease-out)}.pour-over-calc__slider::-moz-range-track{height:4px;border-radius:var(--radius-full);background:transparent}.pour-over-calc__slider:focus-visible{outline:2px solid var(--color-accent);outline-offset:4px;border-radius:var(--radius-full)}.pour-over-calc__helper{font-size:12px;color:var(--color-text-muted);text-align:center;margin-bottom:var(--space-sm)}.pour-over-calc__schedule{margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--color-border)}.pour-over-calc__schedule-title{font-size:13px;font-weight:600;color:var(--color-text);margin-bottom:var(--space-sm)}.pour-over-calc__timeline{display:flex;flex-direction:column;gap:0;position:relative;padding-left:24px}.pour-over-calc__phase{position:relative;padding:8px 0 8px var(--space-md)}.pour-over-calc__phase:before{content:"";position:absolute;left:-18px;top:0;bottom:0;width:2px;background:var(--color-border)}.pour-over-calc__phase:first-child:before{top:14px}.pour-over-calc__phase:last-child:before{bottom:calc(100% - 14px)}.pour-over-calc__phase-dot{position:absolute;left:-22px;top:12px;width:10px;height:10px;border-radius:50%;background:var(--color-border);border:2px solid var(--color-surface)}.pour-over-calc__phase--active .pour-over-calc__phase-dot{background:var(--color-accent)}.pour-over-calc__phase-name{font-size:13px;font-weight:600;color:var(--color-text)}.pour-over-calc__phase-detail{display:flex;justify-content:space-between;align-items:center;margin-top:2px}.pour-over-calc__phase-grams{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:600;color:var(--color-accent)}.pour-over-calc__phase-time{font-size:12px;color:var(--color-text-muted)}.pour-over-calc__brew-time{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-bg-alt);border-radius:var(--radius-md);font-size:13px;color:var(--color-text-secondary);margin-top:var(--space-md)}.pour-over-calc__reset{display:block;width:auto;margin-left:auto;margin-top:var(--space-md);padding:6px var(--space-md);font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--color-text-muted);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:color var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out)}.pour-over-calc__reset:hover{color:var(--color-text);border-color:var(--color-border-strong);background:var(--color-bg-alt)}@media(min-width:768px){.pour-over-calc{padding:var(--space-lg)}}.french-press-calc{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:var(--shadow-lg)}.french-press-calc__servings{display:flex;background:var(--color-bg-alt);border-radius:var(--radius-md);padding:3px;margin-bottom:var(--space-md)}.french-press-calc__serving{display:inline-flex;align-items:center;justify-content:center;padding:6px var(--space-sm);border:none;border-radius:6px;background:transparent;color:var(--color-text-muted);font-size:13px;font-weight:500;font-family:var(--font-body);white-space:nowrap;cursor:pointer;flex:1;min-width:0;transition:background var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.french-press-calc__serving:hover{color:var(--color-text-secondary)}.french-press-calc__serving--active{background:var(--color-surface);color:var(--color-text);font-weight:600;box-shadow:var(--shadow-sm)}.french-press-calc__field{margin-bottom:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border:1px solid transparent;transition:background var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out)}.french-press-calc__field--result{background:var(--color-accent-light);border-color:color-mix(in srgb,var(--color-accent) 25%,transparent)}.french-press-calc__label{display:block;font-size:13px;font-weight:600;color:var(--color-text);margin-bottom:6px;letter-spacing:var(--tracking-wide)}.french-press-calc__unit{font-weight:400;color:var(--color-text-muted)}.french-press-calc__stepper{display:flex;align-items:center;gap:6px}.french-press-calc__step-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;flex-shrink:0;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;font-family:var(--font-body);transition:background var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out)}.french-press-calc__step-btn:hover{background:var(--color-bg-alt);border-color:var(--color-border-strong);color:var(--color-text)}.french-press-calc__step-btn:active{background:var(--color-accent-light)}.french-press-calc__input{flex:1;min-width:0;height:46px;text-align:center;font-size:var(--text-lg);font-family:var(--font-mono);font-weight:600;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:0 var(--space-sm);transition:border-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out);-moz-appearance:textfield}.french-press-calc__input::-webkit-outer-spin-button,.french-press-calc__input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.french-press-calc__input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-accent) 15%,transparent)}.french-press-calc__ratio{text-align:center;margin-bottom:var(--space-md);padding:var(--space-sm) 0}.french-press-calc__ratio-display{display:block;font-family:var(--font-mono);font-size:var(--text-2xl);font-weight:700;color:var(--color-text);letter-spacing:var(--tracking-tight);margin-bottom:var(--space-sm)}.french-press-calc__slider-wrap{display:flex;align-items:center;gap:var(--space-sm)}.french-press-calc__slider-label{font-size:11px;font-family:var(--font-mono);color:var(--color-text-muted);flex-shrink:0;min-width:3ch}.french-press-calc__slider{-webkit-appearance:none;appearance:none;flex:1;height:4px;border-radius:var(--radius-full);background:linear-gradient(to right,var(--color-accent) 0%,var(--color-accent) var(--fill, 50%),var(--color-border) var(--fill, 50%),var(--color-border) 100%);outline:none;cursor:pointer}.french-press-calc__slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--color-accent);border:2px solid var(--color-surface);box-shadow:var(--shadow-md);cursor:pointer;transition:transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.french-press-calc__slider::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:var(--shadow-lg)}.french-press-calc__slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--color-accent);border:2px solid var(--color-surface);box-shadow:var(--shadow-md);cursor:pointer;transition:transform var(--duration-fast) var(--ease-out)}.french-press-calc__slider::-moz-range-track{height:4px;border-radius:var(--radius-full);background:transparent}.french-press-calc__slider:focus-visible{outline:2px solid var(--color-accent);outline-offset:4px;border-radius:var(--radius-full)}.french-press-calc__helper{font-size:12px;color:var(--color-text-muted);text-align:center;margin-bottom:var(--space-sm)}.french-press-calc__steep-section{margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--color-border)}.french-press-calc__steep-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.french-press-calc__steep-label{font-size:13px;font-weight:600;color:var(--color-text)}.french-press-calc__steep-value{font-family:var(--font-mono);font-size:var(--text-lg);font-weight:600;color:var(--color-text)}.french-press-calc__flavor-note{font-size:12px;color:var(--color-text-muted);text-align:center;margin-top:var(--space-xs);font-style:italic;transition:opacity var(--duration-fast) var(--ease-out)}.french-press-calc__grind-ref{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--color-bg-alt);border-radius:var(--radius-md);margin-top:var(--space-md)}.french-press-calc__grind-text{font-size:13px;color:var(--color-text-secondary)}.french-press-calc__grind-scale{display:flex;gap:4px;align-items:center}.french-press-calc__grind-dot{width:6px;height:6px;border-radius:50%;background:var(--color-border)}.french-press-calc__grind-dot--active{width:8px;height:8px;background:var(--color-accent)}.french-press-calc__grind-dot--highlight{background:var(--color-accent)}.french-press-calc__reset{display:block;width:auto;margin-left:auto;margin-top:var(--space-md);padding:6px var(--space-md);font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--color-text-muted);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:color var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out)}.french-press-calc__reset:hover{color:var(--color-text);border-color:var(--color-border-strong);background:var(--color-bg-alt)}@media(min-width:768px){.french-press-calc{padding:var(--space-lg)}}.bt-wrap{text-align:center;display:flex;flex-direction:column;align-items:center;padding:var(--space-md);background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.bt-phase{animation:bt-fadeIn var(--duration-fast) var(--ease-out);width:100%}@keyframes bt-fadeIn{0%{opacity:0}to{opacity:1}}.bt-sound-toggle{position:absolute;top:var(--space-sm);right:var(--space-sm);background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:var(--space-xs);border-radius:var(--radius-sm);transition:color var(--duration-fast) var(--ease-out);line-height:1}.bt-sound-toggle:hover{color:var(--color-accent)}.bt-quickstart{margin-bottom:var(--space-lg);text-align:left}.bt-quickstart__label{display:block;font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--color-text-muted);margin-bottom:var(--space-sm)}.bt-quickstart__chips{display:flex;gap:var(--space-sm);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:2px}.bt-quickstart__chips::-webkit-scrollbar{display:none}.bt-quickstart__chip{display:flex;flex-direction:column;gap:2px;padding:var(--space-sm) var(--space-md);background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;font-size:var(--text-sm);transition:all var(--duration-fast) var(--ease-out)}.bt-quickstart__chip:hover{border-color:var(--color-accent);background:var(--color-accent-light)}.bt-quickstart__method{font-weight:600;color:var(--color-text)}.bt-quickstart__amounts{font-family:"JetBrains Mono",var(--font-mono);font-size:var(--text-xs);color:var(--color-text-muted)}.bt-method-chips{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-bottom:var(--space-lg);justify-content:center}.bt-chip{padding:var(--space-sm) var(--space-md);border:2px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-surface);cursor:pointer;font-size:var(--text-sm);font-weight:500;color:var(--color-text-secondary);transition:all var(--duration-fast) var(--ease-out);white-space:nowrap}.bt-chip:hover{border-color:var(--color-accent);color:var(--color-text)}.bt-chip--active{border-color:var(--color-accent);background:var(--color-accent-light);color:var(--color-accent);font-weight:600}.bt-chip:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.bt-recipe-meta{display:flex;justify-content:center;gap:var(--space-md);margin-bottom:var(--space-lg);font-size:var(--text-sm);color:var(--color-text-muted)}.bt-recipe-meta span{background:var(--color-bg-alt);padding:2px var(--space-sm);border-radius:var(--radius-sm)}.bt-scaler{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md);margin-bottom:var(--space-lg);max-width:320px;margin-inline:auto}.bt-scaler__label{display:block;font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--color-text-muted);margin-bottom:var(--space-xs)}.bt-scaler__stepper{display:flex;align-items:center;gap:var(--space-xs);background:var(--color-bg-alt);border-radius:var(--radius-md);padding:var(--space-xs)}.bt-scaler__btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;flex-shrink:0;transition:all var(--duration-fast) var(--ease-out)}.bt-scaler__btn:hover{background:var(--color-border);color:var(--color-text)}.bt-scaler__input{width:100%;min-width:0;text-align:center;border:none;background:transparent;font-family:"JetBrains Mono",var(--font-mono);font-size:var(--text-lg);font-weight:700;color:var(--color-text);-moz-appearance:textfield}.bt-scaler__input::-webkit-inner-spin-button,.bt-scaler__input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.bt-scaler__value{flex:1;text-align:center;font-family:"JetBrains Mono",var(--font-mono);font-size:var(--text-lg);font-weight:700;color:var(--color-text)}.bt-scaler__unit{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:500;flex-shrink:0}.bt-scaler__field--derived .bt-scaler__stepper{background:var(--color-accent-light)}.bt-steps{text-align:left;margin-bottom:var(--space-lg)}.bt-steps__title{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--color-text-muted);margin-bottom:var(--space-sm)}.bt-steps__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-xs)}.bt-steps__item{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--text-sm);color:var(--color-text-secondary);padding:var(--space-sm) var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md)}.bt-steps__num{display:flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;flex-shrink:0;background:var(--color-accent);color:var(--color-bg);font-size:var(--text-xs);font-weight:600;border-radius:var(--radius-full)}.bt-steps__label{flex:1;font-weight:500;color:var(--color-text)}.bt-steps__pour-badge{font-family:"JetBrains Mono",var(--font-mono);font-size:var(--text-xs);font-weight:600;color:var(--color-accent);background:var(--color-accent-light);padding:2px var(--space-sm);border-radius:var(--radius-sm)}.bt-steps__dur{font-family:"JetBrains Mono",var(--font-mono);font-size:var(--text-xs);color:var(--color-text-muted);flex-shrink:0}.bt-start-btn{width:100%;max-width:320px;margin-bottom:var(--space-lg)}.bt-ghost-btn{background:none;border:none;color:var(--color-text-muted);font-size:var(--text-sm);cursor:pointer;padding:var(--space-sm) var(--space-md);transition:color var(--duration-fast) var(--ease-out)}.bt-ghost-btn:hover{color:var(--color-accent)}.bt-history{width:100%;margin-top:var(--space-sm);text-align:left}.bt-history__toggle{display:flex;align-items:center;gap:var(--space-xs);width:100%;padding:var(--space-sm) 0;background:none;border:none;font-size:var(--text-sm);font-weight:500;color:var(--color-text-muted);cursor:pointer;transition:color var(--duration-fast) var(--ease-out)}.bt-history__toggle:hover{color:var(--color-accent)}.bt-history__list{display:flex;flex-direction:column;gap:var(--space-sm);margin-top:var(--space-sm)}.bt-history__entry{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-bg-alt);border-radius:var(--radius-md);font-size:var(--text-sm)}.bt-history__info{display:flex;flex-direction:column;gap:2px;min-width:0}.bt-history__method{font-weight:600;color:var(--color-text)}.bt-history__detail{font-family:"JetBrains Mono",var(--font-mono);font-size:var(--text-xs);color:var(--color-text-muted)}.bt-history__stars{font-size:var(--text-xs);color:var(--color-accent)}.bt-history__notes{font-size:var(--text-xs);color:var(--color-text-muted);font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}.bt-history__actions{display:flex;align-items:center;gap:var(--space-xs);flex-shrink:0}.bt-history__use{font-size:var(--text-xs);font-weight:600;color:var(--color-accent);background:none;border:1px solid var(--color-accent);border-radius:var(--radius-sm);padding:2px var(--space-sm);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.bt-history__use:hover{background:var(--color-accent);color:#fff}.bt-history__delete{display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:4px;border-radius:var(--radius-sm);transition:color var(--duration-fast) var(--ease-out)}.bt-history__delete:hover{color:var(--color-danger, #c53030)}.bt-brewing-card{text-align:center}.bt-brewing-header{display:flex;align-items:center;justify-content:center;gap:var(--space-xs);font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-md);flex-wrap:wrap}.bt-brewing-header__method{font-weight:600;color:var(--color-text)}.bt-brewing-header__sep{color:var(--color-border)}.bt-brewing-header__amounts{font-family:"JetBrains Mono",var(--font-mono);font-size:var(--text-xs)}.bt-brewing-header__step{font-size:var(--text-xs);font-weight:600}.bt-brewing-header__stop{display:flex;align-items:center;justify-content:center;margin-left:var(--space-xs);width:28px;height:28px;border:none;border-radius:var(--radius-sm);background:var(--color-bg-alt);color:var(--color-text-muted);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.bt-brewing-header__stop:hover{background:var(--color-border);color:var(--color-text)}.bt-circle-wrap{position:relative;width:150px;height:150px;margin:0 auto var(--space-sm)}.bt-circle-svg{width:100%;height:100%;transform:rotate(-90deg)}.bt-circle-bg{fill:none;stroke:var(--color-bg-alt);stroke-width:6}.bt-circle-progress{fill:none;stroke:var(--color-accent);stroke-width:6;stroke-linecap:round;transition:stroke-dashoffset 1s linear}.bt-circle-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.bt-countdown{display:block;font-family:"JetBrains Mono",var(--font-mono);font-size:1.75rem;font-weight:700;line-height:1;color:var(--color-text);letter-spacing:-.02em}.bt-step-label{display:block;font-size:var(--text-xs);font-weight:500;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:var(--tracking-wide);margin-top:2px}.bt-pour-badge{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-md);background:var(--color-accent-light);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:500;color:var(--color-accent);margin-bottom:var(--space-sm)}.bt-pour-badge__value{font-family:"JetBrains Mono",var(--font-mono);font-weight:700}.bt-instruction{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:var(--leading-relaxed);max-width:40ch;margin:0 auto var(--space-sm)}.bt-timeline{display:flex;justify-content:center;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm);padding:0;list-style:none}.bt-timeline-dot{width:10px;height:10px;border-radius:var(--radius-full);background:var(--color-border);transition:all var(--duration-fast) var(--ease-out)}.bt-timeline-dot--done{background:var(--color-accent)}.bt-timeline-dot--active{background:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light);transform:scale(1.3)}.bt-controls{display:flex;align-items:center;justify-content:center;gap:var(--space-lg);margin-top:var(--space-sm);margin-bottom:var(--space-md)}.bt-ctrl-btn{display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;transition:all var(--duration-fast) var(--ease-out);line-height:1}.bt-ctrl-main{width:56px;height:56px;border-radius:var(--radius-full);background:var(--color-accent);color:#fff;box-shadow:var(--shadow-md)}.bt-ctrl-main:hover{background:var(--color-accent-hover);transform:scale(1.05)}.bt-ctrl-main:active{transform:scale(.97)}.bt-ctrl-small{width:40px;height:40px;border-radius:var(--radius-full);background:var(--color-bg-alt);color:var(--color-text-secondary)}.bt-ctrl-small:hover{background:var(--color-border);color:var(--color-text)}.bt-ctrl-small:disabled{opacity:.3;cursor:not-allowed}.bt-instruction-screen{padding:var(--space-md) 0}.bt-instruction-step-label{font-family:var(--font-heading);font-size:var(--text-xl);font-weight:600;margin-bottom:var(--space-md)}.bt-instruction-text{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:var(--leading-relaxed);max-width:40ch;margin:0 auto var(--space-lg)}.bt-complete-icon{width:72px;height:72px;margin:0 auto var(--space-md);display:flex;align-items:center;justify-content:center;background:var(--color-accent-light);color:var(--color-accent);border-radius:var(--radius-full);animation:bt-scaleIn .4s var(--ease-out)}@keyframes bt-scaleIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.bt-complete-heading{font-family:var(--font-heading);font-size:var(--text-xl);font-weight:700;margin-bottom:var(--space-xs)}.bt-complete-time{font-family:"JetBrains Mono",var(--font-mono);font-size:var(--text-lg);color:var(--color-text-muted);margin-bottom:var(--space-lg)}.bt-complete-log{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg)}.bt-complete-saved{font-size:var(--text-sm);font-weight:600;color:var(--color-accent);margin-bottom:var(--space-md)}.bt-complete-actions{display:flex;gap:var(--space-sm);align-items:center;justify-content:center}.bt-rating{display:flex;gap:var(--space-xs)}.bt-rating__star{background:none;border:none;cursor:pointer;color:var(--color-border);padding:2px;transition:color var(--duration-fast) var(--ease-out)}.bt-rating__star:hover,.bt-rating__star--filled{color:var(--color-accent)}.bt-notes__input{width:100%;max-width:320px;padding:var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-alt);font-family:inherit;font-size:var(--text-sm);color:var(--color-text);resize:vertical;line-height:var(--leading-relaxed)}.bt-notes__input::placeholder{color:var(--color-text-muted)}.bt-notes__input:focus{outline:2px solid var(--color-accent);outline-offset:-1px}@media(prefers-reduced-motion:reduce){.bt-phase,.bt-complete-icon{animation:none}.bt-circle-progress{transition:none}.bt-timeline-dot--active,.bt-ctrl-main:hover,.bt-ctrl-main:active{transform:none}}@media(min-width:520px){.bt-circle-wrap{width:170px;height:170px}.bt-countdown{font-size:2rem}.bt-scaler{max-width:360px}}.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}.muted{color:var(--color-text-muted)}.small{font-size:var(--text-sm);color:var(--color-text-muted)}.text-center{text-align:center}.text-balance{text-wrap:balance}.back{display:inline-flex;align-items:center;gap:var(--space-xs);font-size:var(--text-sm);font-weight:500;color:var(--color-text-muted);margin-bottom:var(--space-lg);transition:color var(--duration-fast) var(--ease-out)}.back:hover{color:var(--color-accent);text-decoration:none}.cross-links{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-xl)}.cross-links a{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-md);font-size:var(--text-sm);font-weight:500;color:var(--color-text-secondary);background:var(--color-bg-alt);border-radius:var(--radius-full);transition:all var(--duration-fast) var(--ease-out)}.cross-links a:hover{background:var(--color-accent-light);color:var(--color-accent);text-decoration:none}.link-list{list-style:none;padding:0;margin:0}.link-list li{margin-bottom:var(--space-sm)}.link-list a{font-weight:500}.breadcrumb{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-xs);font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-lg)}.breadcrumb a{color:var(--color-text-muted);transition:color var(--duration-fast) var(--ease-out)}.breadcrumb a:hover{color:var(--color-accent)}.breadcrumb span[aria-hidden]{color:var(--color-border-strong)}.section{margin-bottom:var(--space-3xl)}.section:last-child{margin-bottom:0}.grid{display:grid;gap:var(--space-md)}.grid--2{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.grid--3{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.details{display:grid;grid-template-columns:auto 1fr;gap:var(--space-sm) var(--space-lg)}.details dt{font-size:var(--text-sm);font-weight:600;color:var(--color-text-muted)}.details dd{margin:0}
