.coffee-page{font-family:Inter,sans-serif;background-color:#fdfbf5;color:#4a3f35;min-height:100vh;text-align:left;margin:-1rem -.5rem;padding:0}@media(min-width:640px){.coffee-page{margin:-1rem}}.coffee-page h1,.coffee-page h2,.coffee-page h3{font-family:Lora,serif}.coffee-header{position:relative;text-align:center;padding:2rem 1rem;background-color:#efebe4}.coffee-title{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;color:#4a3f35;margin-bottom:.5rem}.coffee-subtitle{font-size:.9rem;color:#6d5d4d}.coffee-section{margin-bottom:4rem}.coffee-section-title{font-size:2.25rem;font-weight:700;margin-bottom:2rem;text-align:center}.coffee-card{background-color:#fff;border-radius:.5rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;border:1px solid #f3f4f6}.coffee-card-padded{padding:2rem}.coffee-dashed-box{background-color:#fdfbf5;border-radius:.5rem;border:2px dashed #d1d5db}.coffee-card-title{font-size:1.5rem;font-weight:700;margin-bottom:.5rem;font-family:Lora,serif}.coffee-accent-text{color:#a37e61;font-weight:600}.coffee-label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.25rem}.coffee-select{width:100%;padding:.5rem;border:1px solid #d1d5db;border-radius:.375rem;box-shadow:0 1px 2px #0000000d;background-color:#fff;color:#4a3f35;font-family:Inter,sans-serif}.coffee-select:focus{outline:none;border-color:#a37e61;box-shadow:0 0 0 2px #a37e6133}.coffee-btn{background-color:#a37e61;color:#fff;font-weight:700;padding:.75rem 2rem;border-radius:.5rem;border:none;cursor:pointer;box-shadow:0 4px 6px -1px #0000001a;transition:background-color .3s;font-family:Inter,sans-serif;font-size:1rem}.coffee-btn:hover{background-color:#8e6a4f}.coffee-result-box{background-color:#fdfbf5;border-radius:.5rem;padding:1.5rem;border:2px dashed #d1d5db}.coffee-tab-active{background-color:#a37e61;color:#fff}.coffee-tab-inactive{background-color:#efebe4;color:#4a3f35;cursor:pointer}.coffee-tab-inactive:hover{background-color:#e0d8cf;color:#a37e61}.coffee-back-link{position:absolute;top:1rem;left:1rem;font-size:.875rem;font-weight:600;color:#6d5d4d;background:none;border:none;cursor:pointer;padding:0;font-family:Inter,sans-serif;transition:color .2s;text-decoration:none}.coffee-back-link:hover{color:#a37e61}.coffee-footer{text-align:center;padding:1.5rem;margin-top:3rem;background-color:#efebe4;color:#6d5d4d}.brew-layout{position:relative}.brew-table-container{will-change:transform}.brew-table-container--collapsed{position:fixed;top:4rem;right:1rem;z-index:50;width:-moz-fit-content;width:fit-content;background:#efebe4;border-radius:.75rem;padding:.75rem;box-shadow:0 8px 32px #4a3f352e}.brew-table-hint{text-align:center;font-size:.875rem;margin-bottom:1rem;overflow:hidden;transition:opacity .25s ease,max-height .25s ease,margin-bottom .25s ease}.brew-table-hint--hidden{opacity:0;max-height:0;width:0;margin-bottom:0;pointer-events:none;overflow:hidden}@media(max-width:639px){.brew-table-container--collapsed{position:sticky;top:3rem;right:auto;left:0;width:100%;border-radius:0;padding:.5rem;box-shadow:0 2px 8px #4a3f351f;overflow-x:auto}}@media(prefers-reduced-motion:reduce){.brew-table-container{transition:none!important;transform:none!important}}.brew-recipe-container{opacity:0;pointer-events:none;max-height:0;overflow:hidden;transition:opacity .35s ease .2s,max-height 0s ease .55s}.brew-recipe-container--visible{opacity:1;pointer-events:auto;max-height:none;overflow:visible;transition:opacity .35s ease .2s,max-height 0s ease 0s;padding-right:calc(327px + 2.5rem);padding-top:1rem}@media(max-width:639px){.brew-recipe-container--visible{padding-right:0;margin-top:1rem}}.brew-table-wrapper{width:100%}.brew-table-wrapper--mini{width:-moz-fit-content;width:fit-content}.brew-table-grid{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:auto;gap:.5rem;width:100%}.brew-table-wrapper--mini .brew-table-grid{gap:3px;grid-template-columns:repeat(6,52px);grid-template-rows:repeat(3,52px)}@media(max-width:639px){.brew-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.brew-table-grid{grid-template-columns:repeat(6,minmax(80px,1fr));grid-template-rows:repeat(3,80px);width:-moz-max-content;width:max-content}.brew-table-wrapper--mini .brew-table-grid{grid-template-columns:repeat(6,44px);grid-template-rows:repeat(3,44px)}}@media(max-width:400px){.brew-table-grid{grid-template-columns:repeat(6,72px);grid-template-rows:repeat(3,72px)}}.brew-table-viewall{margin-top:.25rem;padding:.35rem .85rem;font-size:.75rem;border-radius:.4rem;align-self:flex-end}.brew-cell{position:relative;border-radius:.5rem;border:2px solid transparent;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;padding:.35rem .25rem .25rem;aspect-ratio:1;font-family:Inter,sans-serif;overflow:hidden;text-align:center;width:100%}.brew-cell:hover:not(.brew-cell--locked){transform:translateY(-2px) scale(1.04);box-shadow:0 6px 18px #4a3f3538;border-color:#fff6}.brew-cell--selected{border-color:#a37e61!important;box-shadow:0 0 0 3px #a37e6173,0 6px 18px #4a3f3540!important;transform:translateY(-2px) scale(1.04)!important}.brew-cell--locked{cursor:default;opacity:.65;filter:grayscale(.3)}.brew-cell__corners{position:absolute;top:.3rem;left:.3rem;right:.3rem;display:flex;justify-content:space-between;align-items:flex-start}.brew-cell__ratio,.brew-cell__serving{font-size:.6rem;opacity:.85;font-weight:600;line-height:1}.brew-cell__name{font-size:.85rem;font-weight:700;font-family:Lora,serif;line-height:1.1;margin-top:.5rem}.brew-cell__category{font-size:.48rem;text-transform:uppercase;letter-spacing:.06em;opacity:.8;margin-top:auto;padding-top:.2rem}.brew-cell__locked-mark{font-size:1.5rem;font-weight:700;opacity:.5;line-height:1;margin-bottom:.1rem}.brew-cell--mini{min-height:unset;aspect-ratio:1;padding:.15rem;border-radius:.3rem;border-width:1.5px}.brew-cell--mini .brew-cell__corners{top:.15rem;left:.15rem;right:.15rem}.brew-cell--mini .brew-cell__ratio,.brew-cell--mini .brew-cell__serving{font-size:.42rem}.brew-cell--mini .brew-cell__name{font-size:.52rem;margin-top:.3rem}.brew-cell--mini .brew-cell__category{font-size:.32rem;padding-top:.1rem}.brew-cell--mini .brew-cell__locked-mark{font-size:.9rem}.brew-recipe{display:flex;flex-direction:column;gap:1.5rem;animation:brew-recipe-in .3s ease both}@keyframes brew-recipe-in{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}.brew-recipe__header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap}.brew-recipe__title{font-family:Lora,serif;font-size:clamp(1.25rem,3vw,1.75rem);font-weight:700;color:#4a3f35;margin:0}.brew-recipe__badge{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;padding:.25rem .65rem;border-radius:999px;white-space:nowrap;flex-shrink:0;margin-top:.25rem}.brew-recipe__ingredients{display:flex;flex-direction:column;gap:1rem}.brew-recipe__ingredients-row{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}@media(max-width:480px){.brew-recipe__ingredients-row{grid-template-columns:repeat(2,1fr)}}.brew-recipe__ingredient-item{display:flex;flex-direction:column;gap:.2rem}.brew-recipe__ingredient-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:#6d5d4d;font-weight:600}.brew-recipe__ingredient-value{font-size:1.1rem;font-weight:700;color:#4a3f35;font-family:Lora,serif}.brew-recipe__grind-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem}.brew-recipe__unit-toggle{display:flex;border-radius:.4rem;overflow:hidden;border:1px solid #d1d5db}.brew-recipe__unit-btn{padding:.3rem .65rem;font-size:.75rem;font-weight:600;background:#fff;color:#6d5d4d;border:none;cursor:pointer;transition:background .15s,color .15s;font-family:Inter,sans-serif}.brew-recipe__unit-btn--active{background:#a37e61;color:#fff}.brew-recipe__section-title{font-family:Lora,serif;font-size:1rem;font-weight:700;color:#4a3f35;margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.05em}.brew-recipe__step-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem}.brew-recipe__step{padding:.65rem .85rem;border-radius:.4rem;border-left:3px solid #d1d5db;background:#fdfbf5;transition:border-color .2s,background .2s}.brew-recipe__step--active{border-left-color:#a37e61;background:#fff8f2;box-shadow:0 1px 4px #a37e611f}.brew-recipe__step--done{border-left-color:#5b8a7a;opacity:.65}.brew-recipe__step-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.brew-recipe__step-num{width:1.4rem;height:1.4rem;border-radius:50%;background:#d1d5db;color:#4a3f35;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.brew-recipe__step--active .brew-recipe__step-num{background:#a37e61;color:#fff}.brew-recipe__step--done .brew-recipe__step-num{background:#5b8a7a;color:#fff}.brew-recipe__step-label{font-weight:700;font-size:.875rem;color:#4a3f35;flex:1}.brew-recipe__step-duration{font-size:.75rem;font-weight:600;color:#a37e61;font-family:Inter,monospace}.brew-recipe__step-instruction{font-size:.85rem;color:#6d5d4d;margin:0;line-height:1.5}.brew-recipe__tip-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.brew-recipe__tip{font-size:.875rem;color:#4a3f35;line-height:1.5;padding-left:1.1rem;position:relative}.brew-recipe__tip:before{content:"•";position:absolute;left:0;color:#a37e61;font-weight:700}.brew-recipe__flavor{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.brew-recipe__flavor-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;color:#6d5d4d;font-weight:600}.brew-recipe__flavor-tags{display:flex;gap:.4rem;flex-wrap:wrap}.brew-recipe__flavor-tag{font-size:.75rem;padding:.2rem .6rem;border-radius:999px;background:#efebe4;color:#4a3f35;font-weight:600}.grind-indicator{display:flex;align-items:flex-end;gap:.5rem}.grind-indicator__segments{display:flex;align-items:flex-end;gap:3px}.grind-indicator__seg{width:10px;border-radius:2px 2px 0 0;background:#d1d5db;transition:background .2s}.grind-indicator__seg--active{background:#a37e61}.grind-indicator__label{font-size:.8rem;font-weight:600;color:#4a3f35}.brew-timer{margin-top:1.5rem;border-radius:.75rem;overflow:hidden}@keyframes step-blink{0%{background-color:transparent}18%{background-color:#a37e6159}36%{background-color:transparent}54%{background-color:#a37e6159}72%{background-color:transparent}to{background-color:transparent}}.brew-timer--blink{animation:step-blink .7s ease}@media(prefers-reduced-motion:reduce){.brew-timer--blink,.brew-recipe{animation:none}.brew-cell,.brew-mini-panel{transition:none}}.brew-timer__inner{padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.75rem}.brew-timer__dots{display:flex;gap:.3rem;flex-wrap:wrap}.brew-timer__dot{width:8px;height:8px;border-radius:50%;display:inline-block;transition:background .2s}.brew-timer__dot--prep{background:#d1d5db;opacity:.35}.brew-timer__dot--upcoming{background:#d1d5db}.brew-timer__dot--active{background:#a37e61;transform:scale(1.3)}.brew-timer__dot--done{background:#5b8a7a}.brew-timer__step-info{display:flex;align-items:baseline;gap:.5rem}.brew-timer__step-num{font-size:.7rem;color:#6d5d4d;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.brew-timer__step-name{font-family:Lora,serif;font-size:1.1rem;font-weight:700;color:#4a3f35}.brew-timer__display{display:flex;align-items:baseline;gap:1rem;flex-wrap:wrap}.brew-timer__time{font-size:clamp(2rem,6vw,3rem);font-weight:700;font-family:Inter,monospace;color:#4a3f35;line-height:1;display:flex;align-items:baseline;gap:.4rem}.brew-timer__time--open{color:#6d5d4d}.brew-timer__open-label{font-size:.75rem;font-weight:600;color:#6d5d4d;text-transform:uppercase;letter-spacing:.05em}.brew-timer__total{font-size:.8rem;color:#6d5d4d;font-weight:600}.brew-timer__controls{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.brew-timer__btn{padding:.5rem 1.1rem;border-radius:.4rem;border:none;cursor:pointer;font-weight:700;font-size:.875rem;font-family:Inter,sans-serif;transition:background .15s}.brew-timer__btn--primary{background:#a37e61;color:#fff}.brew-timer__btn--primary:hover{background:#8e6a4f}.brew-timer__btn--advance{background:#efebe4;color:#4a3f35}.brew-timer__btn--advance:hover{background:#e0d8cf}.brew-timer__btn--reset{background:transparent;color:#6d5d4d;border:1px solid #d1d5db}.brew-timer__btn--reset:hover{background:#f5f5f5}.brew-timer__shortcuts{font-size:.7rem;color:#9ca3af;margin:0}.brew-timer__shortcuts kbd{display:inline-block;padding:.1rem .3rem;border-radius:3px;border:1px solid #d1d5db;background:#f9f9f9;color:#4a3f35;font-size:.65rem;font-family:Inter,monospace}
