*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}[hidden]{display:none!important}@font-face{font-family:Outfit;font-style:normal;font-weight:400;font-display:swap;src:url(/static/fonts/QGYyz_MVcBeNP4NjuGObqx1XmO1I4TC1C4E.ttf) format("truetype")}@font-face{font-family:Outfit;font-style:normal;font-weight:500;font-display:swap;src:url(/static/fonts/QGYyz_MVcBeNP4NjuGObqx1XmO1I4QK1C4E.ttf) format("truetype")}@font-face{font-family:Outfit;font-style:normal;font-weight:600;font-display:swap;src:url(/static/fonts/QGYyz_MVcBeNP4NjuGObqx1XmO1I4e6yC4E.ttf) format("truetype")}@font-face{font-family:Outfit;font-style:normal;font-weight:700;font-display:swap;src:url(/static/fonts/QGYyz_MVcBeNP4NjuGObqx1XmO1I4deyC4E.ttf) format("truetype")}:root{--bg: #F3EDE4;--surface: #FBF8F3;--border: rgba(168, 101, 92, .18);--text: #3D2B24;--muted: #756C60;--accent: #A8655C;--accent-hover: #8F5349;--accent-light: #F5E8E5;--select: #5D2510;--select-light: #F5E0D8;--pour-bg: #EDE5DA;--summary-hover: #E5DCD0;--error-bg: #fff5f2;--error-border: #f5c6b8;--error-text: #9b2c0e;--flavor-tag-bg: #f0f7f0;--flavor-tag-border: #c8e0c8;--flavor-tag-text: #3a6b3a;--history-card-bg: #FBF8F3;--history-card-title: #3D2B24;--history-card-shadow: rgba(61, 43, 36, .04);--radius: 8px;--gap: 20px;--header-bg: #3D2B24;--header-text: #EDE1D2;--header-muted: #B8A48E;--accent-deep: #5D2510}html[data-theme=dark]{--bg: #1C1815;--surface: #262220;--border: rgba(168, 101, 92, .22);--text: #EDE1D2;--muted: #9E9080;--accent: #C4796F;--accent-hover: #D4897F;--accent-light: #2D2220;--select: #C49080;--select-light: #2A2018;--pour-bg: #221F1C;--summary-hover: #2E2A26;--error-bg: #2d1510;--error-border: #6b2c1a;--error-text: #f09070;--flavor-tag-bg: #1e3020;--flavor-tag-border:#3a5c3a;--flavor-tag-text: #7dc97d;--history-card-bg: #262220;--history-card-title: #EDE1D2;--history-card-shadow: rgba(0, 0, 0, .18);--header-bg: #1C1815;--header-text: #EDE1D2;--header-muted: #9E9080;--accent-deep: #C49080}@media(prefers-color-scheme:dark){html:not([data-theme=light]){--bg: #1C1815;--surface: #262220;--border: rgba(168, 101, 92, .22);--text: #EDE1D2;--muted: #9E9080;--accent: #C4796F;--accent-hover: #D4897F;--accent-light: #2D2220;--select: #C49080;--select-light: #2A2018;--pour-bg: #221F1C;--summary-hover: #2E2A26;--error-bg: #2d1510;--error-border: #6b2c1a;--error-text: #f09070;--flavor-tag-bg: #1e3020;--flavor-tag-border:#3a5c3a;--flavor-tag-text: #7dc97d;--history-card-bg: #262220;--history-card-title: #EDE1D2;--history-card-shadow: rgba(0, 0, 0, .18);--header-bg: #1C1815;--header-text: #EDE1D2;--header-muted: #9E9080;--accent-deep: #C49080}}body{font-family:Outfit,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;display:grid;grid-template-columns:380px 1fr;grid-template-rows:auto 1fr}body[data-page=history],body[data-page=history-detail],body[data-page=brew-share],body[data-page=catalog-roaster],body[data-page=catalog-coffee]{grid-template-columns:1fr}.site-header{grid-column:1 / -1;padding:18px 28px;background:var(--header-bg);border-bottom:none;display:flex;align-items:center;gap:10px}.site-header h1{font-size:1.15rem;font-weight:700;letter-spacing:-.3px;color:var(--header-text)}.site-header span{font-size:.85rem;color:var(--header-muted)}.site-logo{font-size:1.15rem;font-weight:700;letter-spacing:-.3px;color:var(--header-text);text-decoration:none}.site-logo:hover{color:var(--accent)}.site-logo:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.header-back{font-size:.88rem;color:var(--header-muted);margin-left:16px}.header-back:hover{color:var(--header-text)}.header-back:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.site-header{display:block;padding:18px 28px 16px}.site-header-row{display:flex;align-items:center;gap:18px}.site-brand{display:flex;flex-direction:column;gap:8px;min-width:0}.site-primary-nav{display:flex;align-items:center;gap:10px;margin-left:auto}.site-nav-link{font-size:.88rem;font-weight:600;color:var(--header-text);text-decoration:none;padding:8px 14px;border-radius:999px;border:1px solid rgba(237,225,210,.14);background:#ede1d20a;transition:color .15s,background .15s,border-color .15s,transform .15s}.site-nav-link:hover,.site-nav-link.is-active{color:var(--header-text);background:#ede1d21f;border-color:#ede1d247}.site-nav-link:hover{transform:translateY(-1px)}.site-header-actions{display:flex;align-items:center;gap:10px}.site-subtitle{margin:0;max-width:34rem;font-size:.85rem;color:var(--header-muted)}.site-more-btn,.session-trigger-btn,.site-menu-close,.site-menu-action,.site-menu-link{display:inline-flex;align-items:center;font-family:inherit}.site-more-btn{display:none;padding:6px 12px;font-size:.8rem;font-weight:600;color:var(--header-text);background:#ede1d21f;border:1px solid rgba(237,225,210,.12);border-radius:999px;cursor:pointer}.site-more-btn:hover{background:#ede1d22e}.session-status-slot{display:flex;align-items:center}.session-trigger-btn{padding:6px 14px;font-size:.8rem;font-weight:600;color:var(--header-text);background:transparent;border:1px solid rgba(237,225,210,.24);border-radius:999px;cursor:pointer;transition:border-color .15s,background .15s}.session-trigger-btn:hover{background:#ede1d214;border-color:#ede1d259}.session-trigger-btn--account{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--header-muted)}.session-trigger-btn--icon{width:40px;height:40px;padding:0;justify-content:center;color:var(--header-text)}.session-trigger-icon{display:inline-flex;align-items:center;justify-content:center}.session-trigger-icon svg{width:17px;height:17px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}.site-menu-dialog{border:1px solid var(--border);border-radius:18px;box-shadow:0 18px 48px #0000002e;padding:18px 18px 20px;width:min(420px,calc(100vw - 24px));background:var(--surface);color:var(--text)}.site-menu-dialog::backdrop{background:#00000047;backdrop-filter:blur(2px)}.site-menu-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.site-menu-close{padding:6px 10px;font-size:.8rem;color:var(--muted);background:none;border:1px solid var(--border);border-radius:999px;cursor:pointer}.site-menu-body{display:flex;flex-direction:column;gap:14px}.site-menu-section{display:flex;flex-direction:column;gap:10px;padding-top:2px}.site-menu-section+.site-menu-section{border-top:1px solid var(--border);padding-top:14px}.site-menu-section-label{margin:0;font-size:.74rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}.site-menu-copy,.site-menu-note{margin:0;font-size:.86rem;color:var(--muted);line-height:1.45}.site-menu-account-email{margin:0;font-size:.9rem;font-weight:600;color:var(--text)}.site-menu-link,.site-menu-action{display:inline-flex;align-items:center;justify-content:center;align-self:flex-start;min-height:38px;padding:0 14px;font-size:.86rem;font-weight:600;text-decoration:none;border-radius:999px}.site-menu-link{color:var(--text);background:var(--bg);border:1px solid var(--border)}.site-menu-action{color:var(--header-text);background:var(--accent);border:1px solid var(--accent);cursor:pointer}.site-menu-signin-form{display:flex;gap:8px;align-items:center;width:100%;max-width:320px}.site-menu-signin-input{flex:1;min-width:0;padding:9px 12px;font-size:.84rem;font-family:inherit;border:1px solid var(--border);border-radius:999px;background:var(--bg);color:var(--text)}.site-menu-signin-input:focus{outline:2px solid var(--accent);border-color:var(--accent)}#form-panel{background:var(--surface);border-right:1px solid var(--border);overflow-y:auto;padding:16px 16px 24px;display:flex;flex-direction:column;gap:6px}details.section{border:1px solid var(--border);border-radius:var(--radius)}details.section summary{display:flex;align-items:center;gap:10px;padding:11px 14px;cursor:pointer;list-style:none;user-select:none;background:var(--pour-bg);transition:background .12s;border-radius:calc(var(--radius) - 1px) calc(var(--radius) - 1px) 0 0}details.section summary::-webkit-details-marker{display:none}details.section summary:hover{background:var(--summary-hover)}details.section[open] summary{border-bottom:1px solid var(--border)}.section-num{width:20px;height:20px;background:var(--accent-deep);color:var(--header-text);font-size:.68rem;font-weight:700;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}details.section.secondary .section-num{background:var(--muted)}.section-title{font-size:.8rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text);flex:1}.section-desc{font-size:.72rem;color:var(--muted)}.chevron{width:10px;height:10px;border-right:2px solid var(--muted);border-bottom:2px solid var(--muted);transform:rotate(45deg);transition:transform .15s;margin-right:2px}details.section[open] .chevron{transform:rotate(-135deg)}.section-body{padding:14px 14px 16px}.fields{display:flex;flex-direction:column;gap:11px}.field{display:flex;flex-direction:column;gap:4px}.field label,.field-label{font-size:.78rem;font-weight:500;color:var(--muted)}.process-picker{position:relative}.process-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:7px 10px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);font-size:.88rem;font-family:inherit;color:var(--text);cursor:pointer;text-align:left}.process-trigger:hover{border-color:var(--muted)}.process-trigger[aria-expanded=true]{border-color:var(--accent);outline:none}.process-placeholder{color:var(--muted);font-style:italic}.process-chevron{flex-shrink:0;color:var(--muted);transition:transform .15s}.process-trigger[aria-expanded=true] .process-chevron{transform:rotate(180deg)}.process-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:50;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 16px #0000001a;padding:10px;display:flex;flex-direction:column;gap:8px}.process-group{display:flex;flex-direction:column;gap:6px}.process-group-label{display:flex;align-items:center;gap:8px;font-size:.62rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);white-space:nowrap}.process-group-label:before,.process-group-label:after{content:"";flex:1;height:1px;background:var(--border)}.process-pills{display:flex;flex-wrap:wrap;gap:6px}.process-opt-input{position:absolute;opacity:0;width:1px;height:1px;pointer-events:none}.process-opt-input:focus-visible+label{outline:2px solid var(--accent);outline-offset:2px}input[type=text],input[type=date],input[type=number],input[type=email],select{width:100%;font-size:.88rem;font-family:inherit;color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:7px 10px;outline:none;transition:border-color .15s;appearance:none;-webkit-appearance:none}input[type=text]:hover:not(:disabled),input[type=date]:hover:not(:disabled),input[type=number]:hover:not(:disabled),input[type=email]:hover:not(:disabled),select:hover:not(:disabled),textarea:hover:not(:disabled){border-color:var(--accent);background:var(--surface)}input[type=text]:focus,input[type=date]:focus,input[type=number]:focus,input[type=email]:focus,select:focus{border-color:var(--accent);background:var(--surface)}select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23756C60'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-color:var(--bg);padding-right:28px;cursor:pointer}.row-2{display:grid;grid-template-columns:1fr 1fr;gap:8px}.roast-options{display:flex;flex-wrap:wrap;gap:4px}.roast-options input[type=radio]{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.roast-options input[type=radio]:focus-visible+label{outline:2px solid var(--accent);outline-offset:2px}.roast-options label{font-family:Georgia,Times New Roman,serif;font-size:.73rem;line-height:1.3;padding:4px 9px;border:1px solid var(--border);border-radius:20px;cursor:pointer;background:var(--bg);color:var(--muted);font-weight:500;transition:all .12s;white-space:nowrap}.roast-options label:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.roast-options input[type=radio]:checked+label{background:var(--accent);border-color:var(--accent);color:#fff}.process-pills label{font-family:Georgia,Times New Roman,serif;font-size:.73rem;line-height:1.3}.process-pills label:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.flavor-options{display:flex;flex-direction:column;gap:4px}.flavor-options input[type=radio]{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.flavor-options input[type=radio]:focus-visible+label{outline:2px solid var(--accent);outline-offset:2px}.flavor-options label{font-size:.8rem;padding:7px 11px;border:1px solid var(--border);border-radius:6px;cursor:pointer;background:var(--bg);color:var(--muted);transition:all .12s}.flavor-options input[type=radio]:checked+label{background:var(--select-light);border-color:var(--select);color:var(--select);font-weight:600}.check-row{display:flex;align-items:center;gap:8px;cursor:pointer}.check-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.check-row span{font-size:.88rem}.slider-row{display:flex;align-items:center;gap:10px}.slider-row input[type=range]{flex:1;padding:0;background:none;border:none;cursor:pointer;appearance:auto;-webkit-appearance:auto;accent-color:var(--accent)}.slider-val{font-size:.85rem;font-weight:600;color:var(--accent);min-width:28px;text-align:right}.cascade-indent{padding-left:12px;border-left:2px solid var(--border);display:flex;flex-direction:column;gap:8px}.yield-presets{display:flex;gap:5px;margin-bottom:6px;flex-wrap:wrap}.mode-row{display:flex;align-items:center;gap:10px;flex-wrap:nowrap}.mode-row label{flex:0 0 auto;margin:0;display:flex;align-items:center;min-height:28px}.mode-picker{display:flex;gap:5px;margin-bottom:0;flex-wrap:nowrap}.mode-picker .yield-btn{flex:0 0 auto}.yield-btn{font-size:.74rem;padding:3px 9px;border:1px solid var(--border);border-radius:20px;cursor:pointer;background:var(--bg);color:var(--muted);font-family:inherit;transition:all .12s}.yield-btn:hover{border-color:var(--accent);color:var(--accent)}.yield-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.yield-btn.active{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.mode-desc{font-size:.76rem;color:transparent;font-style:italic;line-height:1.35;padding:0 1px;transition:color .1s;display:none}.mode-desc.hovered{color:var(--muted);display:block}.hint{font-size:.72rem;color:var(--muted);font-style:italic}.cal-picker{position:relative}.cal-trigger{width:100%;font-size:.88rem;font-family:inherit;color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:7px 10px;text-align:left;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:border-color .15s}.cal-trigger:hover,.cal-trigger:focus{outline:none;border-color:var(--accent)}.cal-trigger.has-value{background:var(--surface)}.cal-trigger-placeholder{color:var(--muted)}.cal-dropdown{position:fixed;z-index:200;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 16px #0000001a;padding:12px;width:348px}.cal-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.cal-nav-btn{background:none;border:1px solid var(--border);border-radius:4px;width:26px;height:26px;cursor:pointer;font-size:.9rem;color:var(--muted);display:flex;align-items:center;justify-content:center;transition:all .12s}.cal-nav-btn:hover{border-color:var(--accent);color:var(--accent)}.cal-nav-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.cal-nav-btn:disabled{opacity:.3;cursor:not-allowed}.cal-months{display:grid;grid-template-columns:1fr 1fr;gap:12px}.cal-month-title{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);text-align:center;margin-bottom:6px}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px}.cal-dow{font-size:.62rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);text-align:center;padding:2px 0 4px}.cal-day{font-size:.78rem;text-align:center;padding:4px 2px;border-radius:4px;cursor:pointer;color:var(--text);transition:background .1s;line-height:1.4}.cal-day:hover:not(.cal-day-empty):not(.cal-day-future){background:var(--pour-bg)}.cal-day:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.cal-day-empty{cursor:default}.cal-day-future{color:var(--border);cursor:not-allowed}.cal-day-today{font-weight:700;color:var(--accent)}.cal-day-selected{background:var(--accent)!important;color:#fff!important;font-weight:600;border-radius:4px}#submit-btn{width:100%;padding:11px;background:var(--accent);color:#fff;font-size:.95rem;font-weight:600;font-family:inherit;border:none;border-radius:var(--radius);cursor:pointer;transition:background .15s;letter-spacing:.01em;margin-top:6px}#submit-btn:hover{background:var(--accent-hover)}#submit-btn:disabled{opacity:.5;cursor:not-allowed}#results-panel{overflow-y:auto;padding:24px 28px}.placeholder{height:100%;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:.9rem}.error-box{background:var(--error-bg);border:1px solid var(--error-border);border-radius:var(--radius);padding:14px 16px;color:var(--error-text);font-size:.875rem}.error-box strong{display:block;margin-bottom:6px}.error-box ul{padding-left:18px}.error-box li{margin-top:3px}.recipe-sets{display:flex;flex-direction:column;gap:32px}.recipe-set-header{margin-bottom:16px}.recipe-set-header h2{font-size:1.1rem;font-weight:700}.tag{font-size:.75rem;padding:3px 9px;border-radius:20px;background:var(--pour-bg);color:var(--muted);border:1px solid var(--border)}.tag.flavor{background:var(--flavor-tag-bg);border-color:var(--flavor-tag-border);color:var(--flavor-tag-text)}.recipes-grid{display:flex;flex-direction:column;gap:16px}.recipe-card{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--surface)}.recipe-card-header{padding:14px 16px;background:var(--pour-bg);border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:16px;align-items:center}.recipe-card-header h3{font-size:.95rem;font-weight:700;flex:1;min-width:160px}.stats{display:flex;flex-wrap:wrap;gap:12px}.stat{display:flex;flex-direction:column;align-items:center;gap:1px}.stat-val{font-size:.95rem;font-weight:700;color:var(--accent)}.stat-key{font-size:.68rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.recipe-card-body{padding:14px 16px}.recipe-keyinfo{display:grid;grid-template-columns:repeat(3,1fr);border-bottom:1px solid var(--border);background:var(--surface)}.keyinfo-item{padding:16px 18px;display:flex;flex-direction:column;gap:4px;border-right:1px solid var(--border)}.keyinfo-item:last-child{border-right:none}.keyinfo-value{font-size:1.45rem;font-weight:700;color:var(--text);letter-spacing:-.02em;line-height:1}.keyinfo-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted)}.notes{font-size:.82rem;color:var(--muted);margin-bottom:14px;font-style:italic;line-height:1.5}.filter-prep{font-size:.8rem;color:var(--muted);margin-bottom:10px}.pro-tips{margin-top:8px;padding-left:18px;font-size:.8rem;color:var(--muted);line-height:1.6}.pours-table{width:100%;border-collapse:collapse;font-size:.83rem}.pours-table th{text-align:left;font-size:.68rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);padding:4px 6px 6px;border-bottom:1px solid var(--border)}.pours-table td{padding:7px 6px;border-bottom:1px solid var(--pour-bg);vertical-align:top}.pours-table tr:last-child td{border-bottom:none}.pour-time{white-space:nowrap;font-variant-numeric:tabular-nums;color:var(--accent);font-weight:600}.pour-weight{white-space:nowrap;font-variant-numeric:tabular-nums}.pour-total{white-space:nowrap;font-variant-numeric:tabular-nums;font-weight:600}.pour-action{line-height:1.45}.brew-table{width:100%;border-collapse:collapse;font-size:.85rem}.brew-table thead tr{background:var(--bg)}.brew-table th{padding:10px 14px;text-align:left;font-size:.72rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border)}.brew-table td{padding:12px 14px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:top}.brew-table tbody tr:last-child td{border-bottom:none}.brew-table tbody tr:nth-child(2n){background:var(--bg)}@media(min-width:541px){.brew-table .th-step,.brew-table .td-step{width:20%;white-space:nowrap}.brew-table .th-amount,.brew-table .td-amount,.brew-table .th-timing,.brew-table .td-timing{width:15%;white-space:nowrap}.brew-table .th-tech,.brew-table .td-tech{width:50%}}.step-name{display:flex;align-items:center;gap:8px}.step-num{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;background:var(--accent-light);color:var(--accent);border-radius:50%;font-size:.72rem;font-weight:700;flex-shrink:0}.step-name-text{font-weight:600}.brew-technique{font-size:.78rem;color:var(--muted);margin-top:2px}.amount-badge{display:inline-block;background:var(--select-light);color:var(--select);border-radius:4px;padding:2px 7px;font-size:.78rem;font-weight:600}.timing-text{font-variant-numeric:tabular-nums;font-size:.82rem}.recipe-footer{font-size:.78rem;color:var(--muted);padding:10px 14px;border-top:1px solid var(--border);font-style:italic}@media(max-width:540px){.brew-table thead tr{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-areas:"step amount timing"}.brew-table tbody tr{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-areas:"step amount timing" "tech tech tech";border-bottom:1px solid var(--border)}.brew-table tbody tr:last-child{border-bottom:none}.brew-table td{border-bottom:none}.brew-table .th-step,.brew-table .td-step{grid-area:step}.brew-table .th-amount,.brew-table .td-amount{grid-area:amount}.brew-table .th-timing,.brew-table .td-timing{grid-area:timing}.brew-table .th-tech{display:none}.brew-table .td-tech{grid-area:tech;padding-top:0;padding-bottom:10px;font-size:.78rem;color:var(--muted)}}.spinner{width:22px;height:22px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}.loading{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--muted);font-size:.875rem}.loading-msg{transition:opacity .2s ease}.loading-msg--out{opacity:0}.feedback-box{margin-top:24px;padding:20px 24px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;gap:14px}.feedback-prompt{font-size:.85rem;font-weight:600;color:var(--muted)}.feedback-rating{display:flex;flex-wrap:wrap;gap:6px}.rating-btn{padding:5px 13px;font-size:.82rem;font-family:inherit;background:var(--bg);color:var(--muted);border:1px solid var(--border);border-radius:20px;cursor:pointer;transition:background .12s,border-color .12s,color .12s;white-space:nowrap}.rating-btn:hover{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}.rating-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.rating-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.feedback-escape-link{align-self:flex-start;padding:0;border:0;background:none;color:var(--accent);font-size:.82rem;font-weight:600;font-family:inherit;cursor:pointer;text-decoration:underline;text-underline-offset:2px}.feedback-escape-link:hover{color:var(--accent-hover)}.feedback-escape-link:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}.feedback-escape-link.active{color:var(--text);text-decoration-thickness:2px}.feedback-subprompt{margin-top:-6px;font-size:.8rem;color:var(--muted)}.feedback-notes{width:100%;font-size:.85rem;font-family:inherit;color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:7px 10px;resize:vertical;outline:none;transition:border-color .15s}.feedback-notes:focus{border-color:var(--accent);background:var(--surface)}.feedback-submit{align-self:flex-start;padding:7px 16px;background:var(--accent);color:#fff;font-size:.85rem;font-weight:600;font-family:inherit;border:none;border-radius:6px;cursor:pointer;transition:background .15s}.feedback-submit:hover{background:var(--accent-hover)}.feedback-submit:disabled{opacity:.5;cursor:not-allowed}.feedback-thanks{font-size:.85rem;color:var(--muted);font-style:italic}.feedback-outcome-badge{display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:.78rem;font-weight:600}.feedback-outcome-badge--detail{margin-bottom:4px}.taste-section{border-top:1px solid var(--border);padding-top:14px;display:flex;flex-direction:column;gap:16px}.taste-questions{display:flex;flex-direction:column;gap:10px}.taste-section-title{font-size:.8rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.taste-card{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:6px;padding:12px 14px;display:flex;flex-direction:column;gap:8px}.taste-card-label{font-size:.8rem;font-weight:600;color:var(--text)}.taste-q-hint{font-size:.78rem;color:var(--muted);font-style:italic}.taste-expand-link{background:none;border:1px solid var(--accent);color:var(--accent);font-size:.8rem;font-weight:600;font-family:inherit;cursor:pointer;padding:6px 12px;border-radius:6px;align-self:flex-start;transition:background .12s,color .12s}.taste-expand-link:hover{background:var(--accent-light)}.taste-expand-link:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.spectrum-control{display:flex;flex-direction:column;gap:6px}.spectrum-track{display:flex;border:1px solid var(--border);border-radius:20px;overflow:hidden}.spectrum-btn{flex:1;padding:6px 4px;font-size:.74rem;font-family:inherit;background:var(--bg);color:var(--muted);border:none;border-right:1px solid var(--border);cursor:pointer;transition:background .15s,color .15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.spectrum-btn:last-child{border-right:none}.spectrum-btn:hover:not(.active){background:var(--pour-bg);color:var(--text)}.spectrum-btn:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.spectrum-btn.active{background:var(--sp-bg, var(--select));color:var(--sp-fg, #fff);font-weight:600}[data-color=neutral]{--sp-bg: var(--select);--sp-fg: #fff}[data-color=strength-1]{--sp-bg: #5a8fb0;--sp-fg: #fff}[data-color=strength-2]{--sp-bg: #7098a8;--sp-fg: #fff}[data-color=strength-4]{--sp-bg: #b87020;--sp-fg: #fff}[data-color=strength-5]{--sp-bg: #7a3010;--sp-fg: #fff}[data-color=acidity-1]{--sp-bg: #b8a020;--sp-fg: #fff}[data-color=acidity-2]{--sp-bg: #c8b840;--sp-fg: #3a3000}[data-color=acidity-4]{--sp-bg: #8b8070;--sp-fg: #fff}[data-color=acidity-5]{--sp-bg: #5a5050;--sp-fg: #fff}[data-color=bitterness-1]{--sp-bg: #5a8fb0;--sp-fg: #fff}[data-color=bitterness-2]{--sp-bg: #7098a8;--sp-fg: #fff}[data-color=bitterness-4]{--sp-bg: #8b6240;--sp-fg: #fff}[data-color=bitterness-5]{--sp-bg: #4a2e1e;--sp-fg: #fff}[data-color=sweetness-1]{--sp-bg: #8898a8;--sp-fg: #fff}[data-color=sweetness-3]{--sp-bg: #c89020;--sp-fg: #fff}[data-color=body-1]{--sp-bg: #5a8fb0;--sp-fg: #fff}[data-color=body-3]{--sp-bg: #7a5030;--sp-fg: #fff}.spectrum-selected-label{font-size:.78rem;color:var(--muted);font-style:italic;min-height:1.2em}.seg-row{display:flex;border:1px solid var(--border);border-radius:6px;overflow:hidden;width:100%}.seg-btn{flex:1;height:34px;border:none;border-right:1px solid var(--border);background:var(--bg);color:var(--muted);font-size:.75rem;cursor:pointer;transition:background .12s,color .12s;padding:0 4px;text-align:center;line-height:1.2;font-family:inherit}.seg-btn:last-child{border-right:none}.seg-btn:hover{background:var(--accent-light);color:var(--accent)}.seg-btn:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.seg-btn.active{background:var(--accent);color:#fff;font-weight:600}.seg-desc{min-height:1.3em;font-size:.76rem;color:transparent;font-style:italic;line-height:1.35;transition:color .1s;padding:0 1px}.seg-desc.hovered{color:var(--muted)}.seg-desc.selected{color:var(--accent);font-style:normal;font-weight:500}.offnote-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.offnote-card{display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 4px;border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;background:var(--bg);transition:background .12s,border-color .12s;font-family:inherit}.offnote-card:hover:not(.active){background:var(--pour-bg);border-color:var(--muted)}.offnote-card:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.offnote-card.active{background:var(--accent-light);border-color:var(--accent)}.offnote-card .offnote-icon{font-size:1.1rem;line-height:1}.offnote-card .offnote-label{font-size:.72rem;color:var(--text);text-align:center;line-height:1.3}.offnote-chip{border:1px solid var(--border);border-radius:6px;background:var(--bg);padding:8px 6px;font-size:.73rem;color:var(--muted);cursor:pointer;text-align:center;transition:all .12s;display:flex;flex-direction:column;gap:3px;align-items:center;font-family:inherit;line-height:1.3}.offnote-chip .icon{font-size:1rem}.offnote-chip:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.offnote-chip:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.offnote-chip.active{border-color:var(--accent);background:var(--accent-light);color:var(--accent);font-weight:600}.theme-toggle,.units-toggle{display:inline-flex;align-self:flex-start;gap:2px;background:#ede1d21f;border-radius:20px;padding:2px;flex-shrink:0}.theme-toggle{margin-left:0}.theme-toggle button,.units-toggle button{background:transparent;border:none;border-radius:18px;padding:4px 10px;font-size:.75rem;font-family:inherit;color:var(--header-muted);cursor:pointer;transition:background .15s,color .15s}.theme-toggle button.active,.units-toggle button.active{background:var(--accent);color:var(--header-text);box-shadow:none}.header-feedback-btn{padding:6px 16px;font-size:.8rem;font-weight:600;font-family:inherit;color:var(--header-text);background:var(--accent);border:1px solid var(--accent);border-radius:20px;cursor:pointer;transition:all .15s;flex-shrink:0}.header-feedback-btn:hover{background:var(--accent-hover);border-color:var(--accent-hover)}#app-feedback-dialog{border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 32px #0000001f;padding:22px 24px;width:min(420px,90vw);background:var(--surface);color:var(--text)}#app-feedback-dialog[open]{display:flex;flex-direction:column;gap:12px}#app-feedback-dialog::backdrop{background:#00000059;backdrop-filter:blur(2px)}.dialog-title{font-size:.95rem;font-weight:700}#app-feedback-msg{width:100%;font-size:.88rem;font-family:inherit;color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:8px 10px;resize:vertical;outline:none;transition:border-color .15s}#app-feedback-msg:focus{border-color:var(--accent);background:var(--surface)}.dialog-actions{display:flex;justify-content:flex-end;gap:8px}.dialog-actions button{padding:7px 18px;font-size:.85rem;font-weight:600;font-family:inherit;border-radius:6px;cursor:pointer;transition:all .15s}#app-feedback-cancel{background:none;border:1px solid var(--border);color:var(--muted)}#app-feedback-cancel:hover{border-color:var(--text);color:var(--text)}#app-feedback-submit{background:var(--accent);border:1px solid var(--accent);color:#fff}#app-feedback-submit:hover{background:var(--accent-hover);border-color:var(--accent-hover)}#app-feedback-submit:disabled{opacity:.5;cursor:not-allowed}.dialog-alt-contact{margin:-2px 0 0;font-size:.82rem;color:var(--muted)}.dialog-alt-contact a{color:var(--accent);text-decoration-thickness:1px;text-underline-offset:2px}#session-status{display:flex;align-items:center;gap:8px;flex-wrap:wrap;flex-shrink:0}.session-save-btn{padding:5px 12px;font-size:.78rem;font-weight:600;font-family:inherit;color:var(--accent);background:transparent;border:1px solid var(--accent);border-radius:20px;cursor:pointer;white-space:nowrap;transition:background .15s,color .15s}.session-save-btn:hover{background:var(--accent-light)}.session-save-btn:disabled{opacity:.5;cursor:not-allowed}.session-link-anchor{display:inline-block;max-width:220px;padding:4px 8px;font-size:.72rem;font-family:monospace;color:var(--text);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-decoration:none;vertical-align:middle}.session-link-anchor:hover{text-decoration:underline;color:var(--accent)}.session-copy-btn{padding:4px 10px;font-size:.75rem;font-family:inherit;font-weight:600;color:var(--text);background:var(--border);border:1px solid var(--border);border-radius:20px;cursor:pointer;white-space:nowrap;transition:background .15s}.session-copy-btn:hover{background:var(--summary-hover)}.session-hint{font-size:.72rem;color:var(--muted);flex-basis:100%;line-height:1.4}.session-history-link{font-size:.8rem;font-weight:600;color:var(--header-muted);text-decoration:none;white-space:nowrap}.session-history-link:hover{text-decoration:underline;color:var(--header-text)}.session-signout-btn{padding:0;font-size:.78rem;font-family:inherit;color:var(--header-muted);background:none;border:none;cursor:pointer;white-space:nowrap;text-decoration:underline}.session-signout-btn:hover{color:var(--header-text)}.session-signout-btn:disabled{opacity:.5;cursor:not-allowed}.session-error{font-size:.78rem;color:var(--error-text);flex-basis:100%;margin:0}.session-email-form{display:flex;gap:4px;align-items:center}.session-email-input{padding:4px 10px;font-size:.78rem;font-family:inherit;border:1px solid var(--border);border-radius:20px;background:var(--bg);color:var(--text);width:190px}.session-email-input:focus{outline:2px solid var(--accent);border-color:var(--accent)}.session-email-btn{padding:5px 12px;font-size:.78rem;font-weight:600;font-family:inherit;color:#fff;background:var(--accent);border:none;border-radius:20px;cursor:pointer;white-space:nowrap;transition:background .15s}.session-email-btn:hover{background:var(--accent-hover)}.session-email-btn:disabled{opacity:.5;cursor:not-allowed}.session-sent-msg{font-size:.78rem;color:var(--muted);white-space:nowrap}.session-email-display{font-size:.75rem;color:var(--muted);white-space:nowrap}.email-prompt-banner{padding:14px 16px;background:var(--accent-light);border-top:1px solid var(--border);border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;align-items:center;gap:8px}.email-prompt-text{font-size:.85rem;color:var(--text);flex-basis:100%;margin:0}.email-prompt-form{display:flex;gap:6px;align-items:center;flex-wrap:wrap;flex:1}.email-prompt-input{padding:6px 12px;font-size:.82rem;font-family:inherit;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);min-width:190px;flex:1}.email-prompt-input:focus{outline:2px solid var(--accent);border-color:var(--accent)}.email-prompt-btn{padding:6px 16px;font-size:.82rem;font-weight:600;font-family:inherit;color:#fff;background:var(--accent);border:none;border-radius:var(--radius);cursor:pointer;white-space:nowrap;transition:background .15s}.email-prompt-btn:hover{background:var(--accent-hover)}.email-prompt-btn:disabled{opacity:.5;cursor:not-allowed}.email-prompt-dismiss{padding:0;font-size:.78rem;font-family:inherit;color:var(--muted);background:none;border:none;cursor:pointer;white-space:nowrap;text-decoration:underline}.email-prompt-dismiss:hover{color:var(--text)}.email-prompt-sent{font-size:.83rem;color:var(--text);margin:0;flex-basis:100%}#profiles-bar{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.5rem}.profiles-row,.profiles-save-row{display:flex;gap:.5rem;align-items:center}.profiles-row select{flex:1;min-width:0}.profiles-save-row input[type=text]{flex:1;min-width:0;padding:.35rem .6rem;border:1px solid var(--border);border-radius:4px;background:var(--bg);color:var(--text);font-size:.9rem}.profiles-save-row input[type=text]:focus{outline:2px solid var(--accent);outline-offset:1px}#profiles-delete-btn{padding:.35rem .7rem;font-size:.85rem;border:1px solid var(--border);border-radius:4px;background:transparent;color:var(--muted);cursor:pointer;white-space:nowrap}#profiles-delete-btn:hover{color:var(--text);background:var(--summary-hover)}#profiles-delete-btn:disabled{opacity:.5;cursor:not-allowed}#profiles-save-btn{padding:.35rem .75rem;font-size:.85rem;border:1px solid var(--accent);border-radius:4px;background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap}#profiles-save-btn:hover{background:var(--accent-hover)}#profiles-save-btn:disabled{opacity:.5;cursor:not-allowed}.profiles-error{margin:0;font-size:.82rem;color:var(--error-text)}#coffees-bar{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:.5rem}.catalog-link-banner{margin-bottom:1rem;padding:14px 16px;border:1px solid var(--accent);border-radius:var(--radius);background:var(--accent-light);display:flex;gap:14px;align-items:center;justify-content:space-between}.catalog-link-copy{display:flex;flex-direction:column;gap:4px}.catalog-link-title,.catalog-link-text{margin:0}.catalog-link-title{font-size:.78rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--accent)}.catalog-link-text{font-size:.9rem;line-height:1.45}.field.catalog-field-locked{opacity:.72}.field.catalog-field-locked .hint{color:var(--muted)}@media(max-width:640px){.catalog-link-banner{flex-direction:column;align-items:flex-start}}#coffees-delete-btn{padding:.35rem .7rem;font-size:.85rem;border:1px solid var(--border);border-radius:4px;background:transparent;color:var(--muted);cursor:pointer;white-space:nowrap}#coffees-delete-btn:hover{color:var(--text);background:var(--summary-hover)}#coffees-delete-btn:disabled{opacity:.5;cursor:not-allowed}.coffees-save-prompt{display:flex;align-items:center;gap:.5rem;margin-top:.75rem;padding:.6rem .75rem;border:1px solid var(--accent);border-radius:6px;font-size:.88rem;color:var(--text);background:var(--surface);flex-wrap:wrap}.coffees-save-prompt span{flex:1;min-width:0}.coffees-save-prompt #coffees-save-yes{padding:.3rem .65rem;font-size:.85rem;border:1px solid var(--accent);border-radius:4px;background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap}.coffees-save-prompt #coffees-save-yes:hover{background:var(--accent-light)}.coffees-save-prompt #coffees-save-yes:disabled{opacity:.5;cursor:not-allowed}.coffees-save-prompt #coffees-save-no{padding:.3rem .5rem;font-size:.85rem;border:none;background:transparent;color:var(--muted);cursor:pointer;line-height:1}.coffees-save-prompt #coffees-save-no:hover{color:var(--text)}.coffees-save-hint{display:flex;align-items:center;gap:.5rem;margin-top:.75rem;padding:.5rem .75rem;border:1px solid var(--border);border-radius:6px;font-size:.85rem;color:var(--muted);background:var(--surface)}.coffees-save-hint span{flex:1;min-width:0}.coffees-save-hint button{padding:.3rem .5rem;font-size:.85rem;border:none;background:transparent;color:var(--muted);cursor:pointer;line-height:1;flex-shrink:0}.coffees-save-hint button:hover{color:var(--text)}@media(max-width:768px){body{grid-template-columns:1fr;grid-template-rows:auto auto 1fr}.site-header{padding:12px 16px 14px}.site-header-row{display:grid;grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"brand brand" "nav actions";gap:10px 12px;align-items:center;position:relative}.site-brand{grid-area:brand;padding-right:68px}.site-primary-nav{grid-area:nav;display:flex;margin-left:0;min-width:0}.site-nav-link{padding:7px 12px;font-size:.82rem}.site-more-btn{position:absolute;top:0;right:0;display:inline-flex;align-items:center;justify-content:center}.site-header-actions{grid-area:actions;margin-left:0;width:auto;justify-self:end}.site-subtitle{max-width:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}#session-status[data-session-state=active]{display:none!important}.header-feedback-btn,.session-trigger-btn{flex:0 0 auto}.site-menu-dialog{width:min(420px,calc(100vw - 16px));padding:16px}.site-menu-signin-form{flex-direction:column;align-items:stretch}#form-panel{border-right:none;border-bottom:1px solid var(--border);overflow-y:visible;padding:12px 12px 20px}#results-panel{padding:16px 12px}.cal-dropdown{width:calc(100vw - 24px);left:12px!important;right:12px!important}.cal-months{grid-template-columns:1fr}.pours-table th,.pours-table td{padding-left:4px;padding-right:4px}.recipe-card-header h3{min-width:0}.feedback-box{padding:14px 12px}.offnote-grid{grid-template-columns:repeat(2,1fr)}}.history-page{max-width:900px;margin:0 auto;padding:24px 16px;font-size:15px}.hist-header{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:24px}.hist-title{font-size:1.6em;font-weight:700;margin-bottom:4px}.since{font-size:.9em;color:var(--muted);margin-bottom:6px}.hist-groups{display:flex;flex-direction:column;gap:24px}.hist-day-group{display:flex;flex-direction:column;gap:12px}.hist-day-heading{font-size:.82rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}.hist-card-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px}.hist-card{display:flex;flex-direction:column;gap:12px;padding:16px;border:1px solid var(--border);border-radius:calc(var(--radius) + 2px);background:var(--history-card-bg);box-shadow:0 1px 0 var(--history-card-shadow)}.hist-card--archived{opacity:.92;background:var(--surface)}.hist-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.hist-card-heading{min-width:0}.hist-time{margin:0 0 4px;font-size:.78rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}.hist-card-title{margin:0;font-size:1.18rem;line-height:1.2;color:var(--history-card-title)}.hist-card-title-link{color:inherit;text-decoration:none}.hist-card-title-link:hover{color:var(--select)}.hist-card-roaster{margin:6px 0 0;font-size:.92rem;color:var(--history-card-title)}.hist-card-rating{flex-shrink:0;display:flex;align-items:center;min-height:32px}.hist-card-tags,.hist-card-stats,.hist-card-actions{display:flex;flex-wrap:wrap;gap:8px}.hist-tag,.hist-stat{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:999px;font-size:.82rem}.hist-tag{border:1px solid var(--border);background:var(--bg);color:var(--text)}.hist-tag--muted{color:var(--muted);background:var(--bg)}.hist-stat{background:var(--pour-bg);color:var(--text)}.stars{color:var(--accent);letter-spacing:1px}.nostars{color:var(--muted)}.hist-card-note{margin:0;font-size:.88rem;line-height:1.45;color:var(--muted)}.hist-card-action{display:inline-flex;align-items:center;justify-content:center;min-height:36px;padding:0 12px;border:1px solid var(--border);border-radius:999px;background:none;color:var(--text);font-size:.84rem;font-family:inherit;text-decoration:none;cursor:pointer;white-space:nowrap}.hist-card-action:hover{border-color:var(--accent);color:var(--accent);text-decoration:none}.hist-card-action--quiet{color:var(--muted)}.empty{color:var(--muted);font-style:italic;padding:24px 0;text-align:center}.pagination{margin-top:20px;display:flex;gap:16px;font-size:.9em}.brew-again-link{font-family:inherit}.history-detail-page{display:flex;flex-direction:column;gap:18px}.brew-header{margin-bottom:0}.hist-card--detail{gap:14px}.brew-title{font-size:1.5rem;font-weight:700}.brew-origin{font-size:.9rem;color:var(--muted)}.detail-section{padding:18px 20px;border:1px solid var(--border);border-radius:calc(var(--radius) + 2px);background:var(--history-card-bg)}.detail-section-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.detail-section-title{margin:0;font-size:1rem;font-weight:700;color:var(--history-card-title)}.detail-section--recipes{padding-top:16px}.detail-section--recipes #history-recipe-sets:empty:before{content:"Recipe data unavailable for this brew.";color:var(--muted);font-style:italic}.feedback-detail{margin-top:0}.big-stars{font-size:1.4em;letter-spacing:2px;color:var(--accent)}.feedback-comment{margin-top:10px;font-size:.88em;color:var(--text);line-height:1.5}.taste-lines{margin-top:12px;display:flex;flex-direction:column;gap:6px}.taste-line{font-size:.82em}.taste-q{color:var(--muted)}.taste-a{color:var(--text);margin-left:4px}.rate-section{margin-top:0;display:flex;flex-direction:column;gap:14px}.rate-heading{font-size:1em;font-weight:600;margin:0}.rate-stars-row{display:flex;flex-wrap:wrap;gap:6px}.rate-notes{width:100%;box-sizing:border-box}.taste-opts-scale,.taste-opts-choice{display:flex;flex-wrap:wrap;gap:6px}.taste-opt-label{display:inline-block;padding:5px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:.82em;cursor:pointer;color:var(--text);background:var(--bg)}.taste-opt-label:hover{border-color:var(--accent);color:var(--accent)}.taste-opt-label.checked{background:var(--select-light);border-color:var(--select);color:var(--select);font-weight:600}.action-row{margin-top:0;display:flex;gap:12px;align-items:center;flex-wrap:wrap}.brew-again-btn{color:var(--text)}.brew-again-btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600;font-size:.95rem;padding:11px 22px}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-secondary{display:inline-block;font-family:inherit;font-weight:600;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-decoration:none;text-align:center;cursor:pointer;transition:color .15s,background .15s,border-color .15s,box-shadow .15s}.btn-secondary:hover:not(:disabled){color:var(--accent);background:var(--accent-light);border-color:var(--accent)}.btn-secondary:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn-secondary:disabled{color:var(--muted);background:var(--surface);border-color:var(--border);opacity:.65;cursor:not-allowed}.remove-btn:hover{border-color:var(--error-text);color:var(--error-text)}.unavailable{color:var(--muted);font-style:italic;padding:24px 0}.remove-confirm{display:none;gap:8px;align-items:center}.dialog-cancel{color:var(--text)}.dialog-confirm{background:var(--error-text);border:none;border-radius:var(--radius);padding:7px 16px;font-size:.88em;cursor:pointer;color:#fff;font-family:inherit}.share-btn{color:var(--text)}.share-panel{margin-top:16px;display:flex;flex-direction:column;gap:10px}.share-url-row{display:flex;gap:8px;align-items:center}.share-url-input{flex:1;font-family:monospace;font-size:.82em;padding:7px 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--input-bg);color:var(--text)}.share-copy-btn{background:none;border:1px solid var(--border);border-radius:var(--radius);padding:7px 14px;font-size:.82em;cursor:pointer;font-family:inherit;color:var(--text)}.share-copy-btn:hover{background:var(--pour-bg)}.revoke-share-btn{background:none;border:none;padding:0;font-size:.82em;color:var(--muted);cursor:pointer;font-family:inherit;text-decoration:underline;text-underline-offset:2px;align-self:flex-start}.revoke-share-btn:hover{color:var(--error-text)}.history-shell{display:grid;grid-template-columns:minmax(220px,260px) minmax(0,1fr);gap:0 32px;max-width:1180px;margin:0 auto;padding:24px 28px}.history-shell .history-page{max-width:none;margin:0;padding:0}.history-shell,.history-page,.brew-sidebar,.hist-groups,.hist-day-group,.hist-card-list,.hist-card,.hist-card-header,.hist-card-heading,.hist-card-title,.hist-card-roaster{min-width:0}.brew-sidebar{position:sticky;top:84px;align-self:start}.brew-sidebar-heading{font-size:.78em;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-bottom:10px}details.brew-sidebar>summary.brew-sidebar-heading{list-style:none;cursor:default}details.brew-sidebar>summary.brew-sidebar-heading::-webkit-details-marker{display:none}details.brew-sidebar>summary.brew-sidebar-heading::marker{content:""}.brew-sidebar-empty{font-size:.85em;color:var(--muted);font-style:italic}.brew-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.brew-entry{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--history-card-bg)}.brew-entry-link{flex:1;min-width:0;text-decoration:none;color:inherit}.brew-entry-link:hover .brew-entry-name{color:var(--select)}.brew-entry.is-selected{border-color:var(--select);background:var(--select-light)}.brew-entry.is-selected .brew-entry-name{color:var(--select);font-weight:600}.brew-entry-name{display:block;font-size:.88em;line-height:1.3;color:var(--history-card-title)}.brew-entry-meta{display:block;font-size:.74em;color:var(--muted);margin-top:4px}.brew-coffee-archive-btn,.brew-coffee-unarchive-btn{flex-shrink:0;background:none;border:none;padding:0 2px;font-size:.72em;color:var(--muted);cursor:pointer;opacity:0;transition:opacity .15s;font-family:inherit}.brew-entry:hover .brew-coffee-archive-btn,.brew-entry:hover .brew-coffee-unarchive-btn{opacity:1}.brew-coffee-archive-btn:hover,.brew-coffee-unarchive-btn:hover{color:var(--text)}.brew-archived-section{margin-top:16px}.brew-archived-toggle{font-size:.78em;color:var(--muted);cursor:pointer;list-style:none;padding:4px 0}.brew-archived-toggle::-webkit-details-marker{display:none}.brew-archived-toggle:before{content:"\25b8  ";font-size:.8em}details[open] .brew-archived-toggle:before{content:"\25be  "}.brew-list--archived .brew-entry-name{color:var(--muted)}.brew-archive-btn,.brew-unarchive-btn{background:none;cursor:pointer}.brew-archived-rows{margin-top:24px}.brew-archived-rows-toggle{font-size:.88em;color:var(--muted);cursor:pointer;list-style:none;padding:4px 0}.brew-archived-rows-toggle::-webkit-details-marker{display:none}.brew-archived-rows-toggle:before{content:"\25b8  ";font-size:.8em}details[open] .brew-archived-rows-toggle:before{content:"\25be  "}.brew-filter-clear{display:inline-block;font-size:.85em;color:var(--select);margin-bottom:12px}@media(max-width:768px){.history-shell{grid-template-columns:1fr;gap:18px;width:100%;max-width:none;margin:0;padding:12px 16px 24px}.history-shell>*{justify-self:stretch;width:100%}.brew-sidebar{position:static;padding-top:0}details.brew-sidebar>summary.brew-sidebar-heading{cursor:pointer;user-select:none;display:flex;align-items:center;justify-content:space-between;padding:11px 14px;background:var(--history-card-bg);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:0;font-size:.82em}details.brew-sidebar>summary.brew-sidebar-heading:after{content:"\25b8";font-size:.75em;flex-shrink:0;margin-left:8px}details.brew-sidebar[open]>summary.brew-sidebar-heading{border-radius:var(--radius) var(--radius) 0 0;border-bottom-color:var(--border);margin-bottom:10px}details.brew-sidebar[open]>summary.brew-sidebar-heading:after{content:"\25be"}details.brew-sidebar[open]{border:1px solid var(--border);border-radius:var(--radius);padding-bottom:12px}details.brew-sidebar[open] .brew-list,details.brew-sidebar[open] .brew-sidebar-empty{padding-left:10px;padding-right:10px}.brew-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;overflow:visible;padding-bottom:0}.brew-entry{min-height:100%;padding:10px}.hist-header{margin-bottom:18px}.hist-card-list{grid-template-columns:1fr;gap:10px}.hist-card{padding:12px}.hist-card-header{flex-direction:column;gap:6px}.hist-card-title{font-size:1.05rem}.hist-card-roaster{font-size:.86rem}.hist-card-tags,.hist-card-stats,.hist-card-actions{gap:6px}.hist-tag,.hist-stat{min-height:26px;padding:0 9px;font-size:.78rem;max-width:100%}.hist-card-rating{min-height:0}.hist-card-actions{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px}.hist-card-action{width:100%;min-width:0}.brew-coffee-archive-btn,.brew-coffee-unarchive-btn,.brew-archived-section{display:none}}@media(max-width:520px){.brew-list{grid-template-columns:1fr}}.catalog-page{max-width:860px;margin:0 auto;padding:32px 24px 64px}.catalog-header{margin-bottom:32px}.catalog-breadcrumb{font-size:.875rem;color:var(--muted);margin-bottom:12px}.catalog-breadcrumb a{color:var(--muted)}.catalog-title{font-size:1.75rem;font-weight:700;letter-spacing:-.5px;margin-bottom:8px}.catalog-description{color:var(--muted);line-height:1.6;margin-top:8px;max-width:560px}.catalog-website-link{display:inline-block;margin-top:8px;font-size:.875rem}.catalog-section-title{font-size:1rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:16px}.catalog-empty{color:var(--muted);font-style:italic;padding:24px 0}.catalog-bag-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.catalog-bag-card{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;text-decoration:none;color:inherit;background:var(--surface);transition:border-color .15s}.catalog-bag-card:hover{border-color:var(--accent)}.catalog-bag-image{aspect-ratio:1/1;background:var(--bg-alt, var(--border));overflow:hidden}.catalog-bag-image img{width:100%;height:100%;object-fit:cover}.catalog-bag-image--placeholder:after{content:"\2615";display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:2rem;opacity:.3}.catalog-bag-info{padding:12px}.catalog-bag-name{font-weight:600;margin-bottom:4px}.catalog-bag-desc{font-size:.85rem;color:var(--muted);margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.catalog-bag-meta{font-size:.8rem;color:var(--muted)}.catalog-coffee-header{display:flex;gap:24px;margin-bottom:32px;align-items:flex-start}.catalog-coffee-image{flex-shrink:0;width:180px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}.catalog-coffee-image img{width:100%;height:auto;display:block}.catalog-coffee-meta{flex:1}.catalog-store-link{display:inline-flex;align-items:center;justify-content:center;margin-top:12px;font-size:.875rem;padding:6px 14px}.catalog-profile-list{display:flex;flex-direction:column;gap:12px}.catalog-profile-card{border:1px solid var(--border);border-radius:var(--radius);padding:16px;background:var(--surface)}.catalog-profile-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;gap:12px}.catalog-profile-name{font-weight:600;font-size:1rem}.catalog-brew-btn{flex-shrink:0;font-size:.85rem;padding:6px 14px}.catalog-brew-btn.is-selected{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.catalog-profile-params{display:flex;flex-wrap:wrap;gap:6px}.catalog-brew-panel{margin-top:18px;padding:18px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.catalog-brew-selection{margin:-4px 0 14px;color:var(--muted)}.catalog-brew-actions{margin-top:14px}.catalog-brew-actions .brew-again-btn{padding:10px 18px;font-size:.9rem;font-weight:600;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.catalog-brew-actions .brew-again-btn:hover:not(:disabled){color:var(--accent);background:var(--accent-light);border-color:var(--accent)}.catalog-brew-actions .brew-again-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.brew-origin{margin:6px 0 10px;color:var(--muted)}.brew-origin a{color:inherit}@media(max-width:560px){.catalog-coffee-header{flex-direction:column}.catalog-coffee-image{width:100%;max-width:320px}.catalog-bag-grid{grid-template-columns:1fr}}
