*,:after,:before{box-sizing:border-box;margin:0;padding:0}body,html{height:100%;font-family:var(--font);font-size:var(--fs-base);line-height:var(--lh-base);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}.screen{position:fixed;inset:0;display:flex;flex-direction:column;transition:opacity .35s var(--ease-in-out),transform .35s var(--ease-in-out)}.screen.hidden{opacity:0;pointer-events:none}.screen.active{opacity:1;pointer-events:all}.screen-results.hidden{transform:translateY(var(--s-6))}.screen-results.active{transform:translateY(0)}.screen-quiz{background:var(--bg);overflow:hidden}.quiz-header{justify-content:space-between;padding:var(--s-6) var(--s-8) 0}.quiz-header,.quiz-main{display:flex;align-items:center;position:relative;z-index:2}.quiz-main{flex:1 1;flex-direction:column;justify-content:center;padding:var(--s-8) var(--s-6);gap:var(--s-10)}.question-wrap{width:100%;max-width:640px;position:relative}.question{display:flex;flex-direction:column;align-items:center;gap:var(--s-10)}.question.hidden{display:none}.question.entering{animation:slideInRight .32s var(--ease-out) both}.question.exiting{animation:slideOutLeft .24s var(--ease-in-out) both}.question.entering-from-right{animation:slideInLeft .32s var(--ease-out) both}.question.exiting-to-right{animation:slideOutRight .24s var(--ease-in-out) both}@keyframes slideInRight{0%{opacity:0;transform:translateX(48px)}to{opacity:1;transform:translateX(0)}}@keyframes slideOutLeft{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(-48px)}}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-48px)}to{opacity:1;transform:translateX(0)}}@keyframes slideOutRight{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(48px)}}.question-eyebrow{font-family:var(--font-display);font-size:clamp(var(--fs-lg),4.5vw,var(--fs-xl));font-weight:400;color:var(--text);letter-spacing:-.02em;text-align:center;line-height:var(--lh-snug)}.btn-group{display:flex;gap:var(--s-6);justify-content:center;flex-wrap:wrap;width:100%}.choice-btn{--btn-color:var(--text-muted);display:flex;flex-direction:column;align-items:center;gap:var(--s-2);padding:var(--s-8) var(--s-6);min-width:190px;max-width:220px;flex:1 1;background:color-mix(in srgb,var(--btn-color) 9%,var(--surface));border:none;border-bottom:2px solid transparent;border-radius:0;cursor:pointer;transition:border-color var(--dur-2) var(--ease-out),background var(--dur-2) var(--ease-out);text-align:center;font-family:var(--font);position:relative;overflow:hidden}.choice-btn:before{display:none}.choice-btn:hover{border-bottom-color:var(--btn-color)}.choice-btn:active{opacity:.85}.choice-btn[data-color=fruity]{--btn-color:var(--c-fruity)}.choice-btn[data-color=rich]{--btn-color:var(--c-rich)}.choice-btn[data-color=clean]{--btn-color:var(--c-clean)}.choice-btn[data-color=fermented]{--btn-color:var(--c-fermented)}.choice-btn[data-color=clean-rich]{--btn-color:var(--c-clean-rich)}.choice-btn[data-color=earthy]{--btn-color:var(--c-earthy)}.choice-btn.selected{border-bottom-color:var(--btn-color);background:color-mix(in srgb,var(--btn-color) 12%,var(--surface))}.btn-icon{font-size:var(--fs-xl);line-height:1}.btn-label{font-size:var(--fs-md);font-weight:500;color:var(--text);letter-spacing:-.01em}.btn-sub{font-size:var(--fs-xs);font-weight:300;color:var(--text-muted);letter-spacing:.01em}.quiz-footer{display:flex;align-items:center;justify-content:space-between;min-height:var(--s-10);width:100%;max-width:640px}.back-btn,.flavor-shortcut-btn,.restart-btn{background:none;border:none;font-family:var(--font);font-size:var(--fs-sm);font-weight:400;color:var(--text-muted);cursor:pointer;padding:var(--s-2) var(--s-3);border-radius:var(--r-1);transition:color var(--dur-1),background var(--dur-1);white-space:nowrap}.back-btn:hover,.restart-btn:hover{color:var(--text);background:rgba(30,33,30,.05)}.flavor-shortcut-btn{margin-left:auto}.flavor-shortcut-btn:hover{color:var(--text);background:rgba(30,33,30,.05)}.back-btn.hidden{visibility:hidden;pointer-events:none}.bean-list-empty,.bean-quirky-callout{list-style:none;padding:var(--s-8) var(--s-4);text-align:center;font-size:var(--fs-sm);color:var(--text-muted);line-height:var(--lh-base)}.bean-quirky-callout{font-style:italic}.reveal-overlay{position:absolute;inset:0;background:var(--bg);pointer-events:none;opacity:0;z-index:10;transition:opacity var(--dur-2) ease}.reveal-overlay.active{opacity:1;pointer-events:all}.screen-results{background:var(--bg);overflow:hidden}.results-header{column-gap:var(--s-4);row-gap:0;padding:var(--s-4) var(--s-6);border-bottom:1px solid var(--border);background:var(--bg);flex-shrink:0;flex-wrap:wrap}.results-header,.results-meta{display:flex;align-items:center}.results-meta{flex:1 1;gap:var(--s-2);flex-wrap:wrap}.results-meta-label{font-size:var(--fs-xs);color:var(--text-muted)}.bean-sheet-count{display:none}.results-tag{display:inline-flex;align-items:center;gap:var(--s-1);padding:var(--s-1) var(--s-3);border-radius:var(--r-pill);font-size:var(--fs-xs);font-weight:500;color:#fff}.results-tag--tappable{border:none;font-family:var(--font);cursor:pointer;transition:opacity var(--dur-1) ease}.results-tag--tappable:hover{opacity:.82}.results-tag--tappable:active{opacity:.65}.results-wheel-link{font-family:var(--font);font-size:var(--fs-sm);font-weight:400;color:var(--text-muted);text-decoration:none;white-space:nowrap;padding:var(--s-2) var(--s-3);border-radius:var(--r-1);transition:color var(--dur-1),background var(--dur-1)}.results-wheel-link:hover{color:var(--text);background:rgba(30,33,30,.05)}.chain-item{display:inline-flex;align-items:center;gap:var(--s-2)}.chain-sep{font-size:var(--fs-xs);color:var(--text-muted);flex-shrink:0}.results-body{flex:1 1;display:flex;overflow:hidden}.results-wheel-panel{flex:0 0 66.667%;position:relative;border-right:1px solid var(--border);background:var(--bg);overflow:hidden}.results-wheel-panel.wheel-anchored #discover-wheel-container{left:0;top:100%}.results-wheel-panel.wheel-instant #discover-wheel-container{transition:none}#discover-wheel-container{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);cursor:-webkit-grab;cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none;touch-action:none;transition:left 1.4s var(--ease-out),top 1.4s var(--ease-out),width 1.4s var(--ease-out),height 1.4s var(--ease-out)}#discover-wheel-container:active{cursor:-webkit-grabbing;cursor:grabbing}#discover-wheel-container.wheel-drag-end svg{pointer-events:none}@property --wheel-wipe-angle{syntax:"<angle>";inherits:false;initial-value:1turn}#discover-wheel-container.wheel-clock-wipe{--wheel-wipe-end-angle:360deg;--wheel-wipe-duration:1.4s;--wheel-wipe-easing:var(--ease-out);-webkit-mask-image:conic-gradient(from 0deg at 50% 50%,#000 0 var(--wheel-wipe-angle),transparent var(--wheel-wipe-angle) 1turn);mask-image:conic-gradient(from 0deg at 50% 50%,#000 0 var(--wheel-wipe-angle),transparent var(--wheel-wipe-angle) 1turn);animation:wheel-clock-wipe var(--wheel-wipe-duration) var(--wheel-wipe-easing) both}.results-wheel-panel.wheel-anchored #discover-wheel-container.wheel-clock-wipe{--wheel-wipe-end-angle:100deg;--wheel-wipe-duration:0.5s;--wheel-wipe-easing:linear}@keyframes wheel-clock-wipe{0%{--wheel-wipe-angle:0deg}to{--wheel-wipe-angle:var(--wheel-wipe-end-angle)}}#discover-wheel-container svg{width:100%;height:100%;overflow:visible}.results-list-panel{flex:0 0 33.333%;overflow-y:auto;padding:var(--s-3) 0;background:var(--bg)}.bean-sheet-header{display:none}.bean-sheet-content{min-height:0}.bean-roaster-filter{margin-bottom:var(--s-2);padding:0 var(--s-3)}.bean-roaster-filter select{min-width:132px;max-width:100%;height:var(--s-8);border:0;border-bottom:1px solid var(--border-strong);border-radius:0;background-color:transparent;color:var(--text-muted);font:inherit;font-size:var(--fs-sm);padding:0 0 2px}.bean-roaster-filter select:focus-visible{outline:none;border-bottom-color:var(--accent)}.bean-list{list-style:none;display:flex;flex-direction:column}.bean-card{background:transparent;border:none;border-bottom:1px solid var(--border);padding:var(--s-3);cursor:pointer;transition:background var(--dur-1);position:relative}.bean-card:hover{background:rgba(30,33,30,.025)}.bean-card.selected{cursor:default}.bean-card.selected,.bean-card.selected:hover{background:transparent}.bean-tier-divider{padding:var(--s-2) var(--s-3);font-size:var(--fs-xs);color:var(--text-muted);border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--surface);list-style:none}.bean-row{display:flex;align-items:flex-start;gap:var(--s-3);transition:gap var(--dur-2) var(--ease-out)}.bean-card.selected .bean-row{gap:14px}.bean-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:var(--fs-micro);font-weight:700;color:var(--surface-2);letter-spacing:.02em;overflow:hidden;transition:width var(--dur-2) var(--ease-out),height var(--dur-2) var(--ease-out)}.bean-card.selected .bean-avatar{width:40px;height:40px}.bean-avatar img{width:100%;height:100%;object-fit:cover}.bean-info{flex:1 1;min-width:0}.bean-roaster{font-size:var(--fs-xs);font-weight:400;color:var(--text-muted);line-height:var(--lh-snug);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:font-size var(--dur-2) var(--ease-out)}.bean-card.selected .bean-roaster{font-size:var(--fs-sm)}.bean-flavor-dots{display:flex;gap:4px;align-items:center;margin-bottom:var(--s-1)}.bean-flavor-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}.bean-name{font-family:var(--font-display);font-size:18px;font-style:italic;font-weight:400;color:var(--text);line-height:var(--lh-snug);transition:font-size var(--dur-2) var(--ease-out)}.bean-card.selected .bean-name{font-size:28px}.bean-origin{font-size:var(--fs-micro);color:var(--text-subtle);margin-top:var(--s-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bean-right{display:flex;flex-direction:column;align-items:flex-end;gap:0;flex-shrink:0}.bean-price{font-size:var(--fs-sm);font-weight:600;color:var(--text);white-space:nowrap}.bean-weight{font-size:var(--fs-xs);font-weight:400;color:var(--text-muted);white-space:nowrap}.bean-thumb{width:var(--s-12);height:var(--s-12);border-radius:var(--r-1);overflow:hidden;flex-shrink:0}.bean-thumb img{width:100%;height:100%;object-fit:cover}.bean-thumb-placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--surface-sunk) 0,#D4D9D0 100%)}.bean-notes-row{display:flex;align-items:center;gap:var(--s-3);flex-wrap:nowrap;overflow:hidden;margin-top:var(--s-3)}.note-more{font-size:var(--fs-micro);opacity:.7;flex-shrink:0;white-space:nowrap}.note-chip,.note-more{color:var(--text-muted)}.note-chip{display:inline-flex;align-items:center;gap:var(--s-1);font-size:var(--fs-xs);font-weight:300}.note-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.note-chip--fuzzy{border-bottom:1px dashed var(--text-subtle);cursor:inherit}.note-chip--overflow{display:none}.bean-card.selected .bean-notes-row{flex-wrap:wrap;overflow:visible}.bean-card.selected .note-chip--overflow{display:inline-flex}.bean-card.selected .note-more{display:none}.bean-detail{display:grid;grid-template-rows:0fr;overflow:hidden;opacity:0;transition:grid-template-rows var(--dur-3) var(--ease-out),opacity var(--dur-3) ease,margin-top var(--dur-3)}.bean-card.selected .bean-detail{grid-template-rows:1fr;opacity:1;margin-top:var(--s-3)}.bean-detail-inner{overflow:hidden;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:var(--s-1)}.roaster-location-minimap{display:flex;align-items:center;gap:var(--s-3);margin-top:var(--s-1)}.roaster-location-map-button{border:0;padding:0;background:transparent;font:inherit;cursor:zoom-in;flex:0 0 112px;height:48px}.roaster-location-map-button:focus-visible{outline:1px solid var(--accent);outline-offset:2px}.roaster-location-map{width:112px;height:48px;flex:0 0 112px;object-fit:cover;border:1px solid var(--border)}.roaster-location-map--empty{display:flex;align-items:center;justify-content:center;font-size:var(--fs-micro);color:var(--text-muted);background:transparent}.roaster-location-meta{min-width:0;display:flex;flex-direction:column;gap:2px}.roaster-location-kicker{font-size:var(--fs-micro);color:var(--text-subtle);text-transform:uppercase;letter-spacing:.08em}.roaster-location-place{font-size:var(--fs-xs);color:var(--text-muted)}.roaster-map-modal{position:fixed;inset:0;z-index:40;display:flex;align-items:center;justify-content:center;padding:var(--s-6);background:rgba(26,20,16,.52);cursor:zoom-out}.roaster-map-modal-inner{width:min(920px,100%);max-height:calc(100vh - var(--s-12));display:flex;flex-direction:column;gap:var(--s-3);padding:var(--s-4);border:1px solid var(--border);background:var(--bg);cursor:default}.roaster-map-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--s-4)}.roaster-map-modal-title{margin:0;font-size:var(--fs-base);font-weight:500;color:var(--text);line-height:var(--lh-snug)}.roaster-map-modal-actions{display:flex;align-items:center;gap:var(--s-4);flex-shrink:0}.roaster-map-modal-gmaps{font-size:var(--fs-sm);color:var(--text-muted);text-decoration:none}.roaster-map-modal-gmaps:hover{color:var(--text)}.roaster-map-modal-gmaps:focus-visible{outline:1px solid var(--accent);outline-offset:2px}.roaster-map-modal-close{border:0;padding:0;background:transparent;color:var(--text-muted);font:inherit;font-size:var(--fs-sm);cursor:pointer}.roaster-map-modal-close:hover{color:var(--text)}.roaster-map-modal-close:focus-visible{outline:1px solid var(--accent);outline-offset:2px}.roaster-map-modal-gl{width:100%;height:clamp(320px,52vh,560px);border:1px solid var(--border)}.roaster-map-popup .mapboxgl-popup-content{padding:var(--s-2) var(--s-3);background:var(--bg);border:1px solid var(--border);border-radius:0;box-shadow:0 2px 8px rgba(30,33,30,.1);font-family:var(--font-jost),sans-serif;font-size:var(--fs-sm);font-weight:500;color:var(--text)}.roaster-map-popup .mapboxgl-popup-tip{border-top-color:var(--bg)}.note-match-table{width:100%;border-collapse:collapse;margin-top:var(--s-1);font-size:var(--fs-xs)}.note-match-table th{color:var(--text);font-weight:600;text-align:left}.note-match-table td,.note-match-table th{padding:2px var(--s-2) 2px 0;min-width:0;overflow-wrap:anywhere;vertical-align:baseline}.note-match-original{color:var(--text-muted)}.note-match-status{color:var(--text)}.note-match-status--fuzzy{color:var(--accent)}.note-match-status--unmatched{color:var(--text-subtle)}.bean-meta-row{display:flex;gap:var(--s-4);flex-wrap:wrap;padding-top:var(--s-3)}.bean-meta-item{font-size:var(--fs-xs);color:var(--text-muted)}.bean-meta-item strong{color:var(--text);font-weight:500}.bean-description{font-size:var(--fs-xs);color:var(--text-muted);line-height:var(--lh-base);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.bean-cta{display:inline-flex;align-items:center;gap:var(--s-1);font-size:var(--fs-xs);font-weight:600;color:var(--accent);text-decoration:none;margin-top:var(--s-1);transition:gap var(--dur-1);cursor:pointer}.bean-cta:hover{gap:var(--s-2)}.bean-cta-unavailable{color:var(--text-muted);font-weight:400;cursor:default}#discover-wheel-container [role=button]:focus{outline:3px solid var(--accent);outline-offset:3px}#discover-wheel-container [role=button]:focus:not(:focus-visible){outline:none}#discover-wheel-container [role=button]:focus-visible{outline:3px solid var(--accent);outline-offset:3px;filter:drop-shadow(0 0 3px rgba(58,42,26,.35))}.arc-label{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;dominant-baseline:middle;font-weight:400}.arc-label-inner{letter-spacing:.06em;text-transform:uppercase}.arc-label-leaf,.arc-label-mid{letter-spacing:.01em}@media (max-width:680px){.btn-group{flex-direction:column;align-items:center;gap:0}.choice-btn{max-width:320px;width:100%;flex-direction:row;text-align:left;gap:var(--s-4);border-bottom:none;border-left:2px solid transparent}.choice-btn.selected,.choice-btn:hover{border-left-color:var(--btn-color);border-bottom-color:transparent}.btn-icon{font-size:var(--fs-lg)}.results-body{--bean-sheet-height:min(42vh,360px);position:relative;flex-direction:column;overflow:hidden}.results-body.bean-sheet-expanded{--bean-sheet-height:min(72vh,640px)}.results-wheel-panel{position:absolute;inset:0;flex:none;width:100%;min-height:0;aspect-ratio:auto;padding:var(--s-2) var(--s-2) calc(var(--bean-sheet-height) + var(--s-4));border-right:none;border-bottom:none}.results-wheel-panel.wheel-anchored #discover-wheel-container{top:calc(100% - var(--bean-sheet-height) - var(--s-4))}.results-list-panel{position:absolute;inset:auto 0 0;z-index:20;display:flex;flex:none;flex-direction:column;height:calc(var(--bean-sheet-height) + env(safe-area-inset-bottom));min-height:184px;max-height:calc(100% - var(--s-4));padding:0 0 env(safe-area-inset-bottom);overflow:hidden;border-top:1px solid var(--border-strong);border-radius:var(--r-5) var(--r-5) 0 0;box-shadow:0 -8px 24px rgba(30,33,30,.1),0 -2px 6px rgba(30,33,30,.04);transition:height var(--dur-3) var(--ease-out)}.bean-sheet-header{position:relative;min-height:56px;padding:var(--s-6) var(--s-3) var(--s-2);border-bottom:1px solid var(--border);background:var(--surface);cursor:ns-resize;touch-action:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.bean-sheet-handle,.bean-sheet-header{display:flex;justify-content:center;align-items:center}.bean-sheet-handle{position:absolute;top:var(--s-2);left:50%;width:var(--s-16);height:var(--s-4);padding:0;border:0;border-radius:var(--r-pill);background:transparent;transform:translateX(-50%)}.bean-sheet-handle span{width:var(--s-10);height:4px;border-radius:var(--r-pill);background:var(--border-strong)}.bean-sheet-handle:focus-visible{outline:none;box-shadow:var(--ring)}.bean-sheet-title{min-width:0;overflow:hidden;color:var(--text);font-size:var(--fs-sm);font-weight:600;line-height:var(--lh-snug);text-align:center;text-overflow:ellipsis;white-space:nowrap;display:flex;align-items:baseline;gap:var(--s-2)}.bean-sheet-count{display:inline;font-size:var(--fs-xs);font-weight:400;color:var(--text-muted)}.results-meta-label{display:none}.bean-sheet-content{flex:1 1;min-height:0;overflow-y:auto;padding:var(--s-2) 0 var(--s-3);-webkit-overflow-scrolling:touch}.results-header{padding:var(--s-3) var(--s-4);flex-wrap:nowrap}.results-meta{flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;min-width:0;-webkit-mask-image:linear-gradient(90deg,black calc(100% - 72px),transparent);mask-image:linear-gradient(90deg,black calc(100% - 72px),transparent)}.results-meta::-webkit-scrollbar{display:none}.results-wheel-link{display:none}.results-body.bean-sheet-expanded .wheel-tooltip{opacity:0!important}}.wheel-tooltip{position:fixed;z-index:100;pointer-events:none;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-2);padding:var(--s-2) var(--s-3);box-shadow:var(--shadow-3);opacity:0;transition:opacity var(--dur-1) ease;max-width:220px}.wheel-tooltip.visible{opacity:1}.wheel-tooltip .tooltip-name{font-size:var(--fs-base);font-weight:600;color:var(--text);white-space:nowrap}.wheel-tooltip .tooltip-path{font-size:var(--fs-xs);color:var(--text-muted);margin-top:var(--s-1)}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;transition-duration:.01ms!important}}