:root{--y:#FFCA08;--k:#000;--w:#fff}
*{box-sizing:border-box;margin:0;padding:0;border-radius:0}
[hidden]{display:none !important}
#sm-boot{position:fixed;inset:0;z-index:9999;background:var(--y);display:flex;align-items:center;justify-content:center;transition:opacity .35s ease;padding:env(safe-area-inset-top,0) 0 0}
#sm-boot.gone{opacity:0;pointer-events:none}
#sm-boot-logo{width:128px;height:128px;object-fit:contain;animation:bootpulse 1s ease-in-out infinite alternate}
@keyframes bootpulse{from{opacity:.55;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
html,body{background:var(--y);color:var(--k);font-family:-apple-system,'Helvetica Neue',Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;height:100%;overflow:hidden;overscroll-behavior:none}
body{max-width:520px;margin:0 auto;height:100%}
.an{font-family:'Anton',Impact,sans-serif;text-transform:uppercase;line-height:.92;letter-spacing:.5px}
.cap{font-weight:800;text-transform:uppercase;letter-spacing:.5px}
.lab{font-weight:800;font-size:11px;letter-spacing:.8px;text-transform:uppercase;opacity:.6}
/* app shell: each active screen is a fixed full-height column = header (fixed) + scrollable body.
   The page itself never scrolls, so the header can never jitter in WKWebView. */
.screen{display:none}
.screen.active{display:flex;flex-direction:column;position:fixed;top:0;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:520px;background:var(--y);animation:fade .26s ease both}
.scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding-bottom:calc(34px + env(safe-area-inset-bottom,0px))}

/* header */
.hd{display:flex;align-items:center;gap:9px;padding:14px 16px 8px}
.hd img{width:38px;height:38px;display:block}
.hd .an{font-size:25px}
.sub{padding:0 16px 12px;border-bottom:3px solid var(--k)}
.sub span{font-size:11px;letter-spacing:2px}
.hd-back{display:flex;align-items:center;gap:9px;padding:14px 16px 10px;border-bottom:3px solid var(--k)}
.hd-back .an{font-size:24px}
.bx{width:36px;height:36px;background:var(--k);border:none;display:flex;align-items:center;justify-content:center;color:var(--y);font-size:20px;flex:none}

/* header sits at the top of the flex column (does not scroll); pad for the notch / Dynamic Island */
.topbar,.hd-back{flex:none;background:var(--y);z-index:5}
.topbar{padding-top:env(safe-area-inset-top,0px)}
.hd-back{padding-top:calc(14px + env(safe-area-inset-top,0px))}

/* news carousel (rotating, up to 3, arrows + auto-scroll) - same width as other blocks */
.news{position:relative;margin:12px 16px 14px}
.news-view{overflow:hidden}
.news-track{display:flex;transition:transform .45s ease}
.news-slide{flex:0 0 100%;padding:12px 38px 14px;box-shadow:inset 0 0 0 3px var(--k)}
.news-slide.nv0{background:var(--y);color:var(--k)}
.news-slide.nv1{background:var(--w);color:var(--k)}
.news-slide.nv2{background:var(--y);color:var(--k)}
.news-tag{display:inline-block;background:var(--k);color:var(--y);font-weight:800;font-size:10px;letter-spacing:1px;padding:3px 7px}
.news-slide.nv1 .news-tag{color:var(--w)}
.news-t{font-size:21px;margin-top:8px;color:inherit}
.news-b{font-weight:600;font-size:13px;margin-top:4px;line-height:1.4}
.news-arrow{position:absolute;top:0;bottom:0;width:30px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--k);font-family:'Anton',Impact,sans-serif;font-size:26px;line-height:1;cursor:pointer;z-index:3;padding:0}
.news-arrow.left{left:0}
.news-arrow.right{right:0}
.news-dots{position:absolute;left:0;right:0;bottom:-12px;display:flex;gap:6px;justify-content:center}
.news-dots .nd{width:7px;height:7px;background:var(--k);opacity:.3;cursor:pointer}
.news-dots .nd.on{opacity:.9}
.tmrw{font-weight:700;font-size:12px;letter-spacing:.4px;text-transform:uppercase;opacity:.6;margin-top:5px}

/* prevent iOS Safari focus-zoom: form controls >= 16px */
input,select,textarea{font-size:16px}

/* blocks */
.hours{margin:0 16px;background:var(--w);border:3px solid var(--k);padding:13px 15px;display:flex;align-items:center;justify-content:space-between}
.hours .an{font-size:22px;margin-top:2px}
.pill{background:var(--k);color:var(--y);font-weight:800;font-size:10px;letter-spacing:.6px;text-transform:uppercase;padding:6px 10px}
.pill.closed{background:#000}
.order{margin:12px 16px;background:var(--k);color:var(--y);padding:16px;text-align:center;display:block;text-decoration:none}
.order .s{font-weight:800;font-size:11px;letter-spacing:1px;opacity:.8}
.order .an{color:var(--y);font-size:27px;margin-top:2px}
.order .u{font-weight:600;font-size:11px;opacity:.8;margin-top:4px}

/* buttons */
.row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:0 16px 12px}
.btn{font-family:'Anton',Impact,sans-serif;text-transform:uppercase;letter-spacing:.6px;text-align:center;padding:14px;font-size:17px;display:flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;text-decoration:none;width:100%}
.btn.bk{background:var(--k);color:var(--y)}
.btn.yl{background:var(--y);color:var(--k);border:3px solid var(--k)}
.btn.ol{background:transparent;color:var(--k);border:3px solid var(--k)}
.contacts{display:flex;gap:16px;justify-content:center;padding:4px 0 16px}
.contacts a{text-decoration:none;color:var(--k)}
.subtext{font-weight:600;font-size:12.5px;text-align:center;margin:0 24px 14px;opacity:.8;line-height:1.4}
.foot{border-top:3px solid var(--k);margin-top:6px;padding:14px 16px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.fbtn{border:2.5px solid var(--k);background:transparent;color:var(--k);font-family:'Anton',Impact,sans-serif;text-transform:uppercase;letter-spacing:.4px;font-size:13px;text-align:center;padding:11px 6px;text-decoration:none;cursor:pointer;display:block}

/* find us */
.addr{margin:12px 16px 0;background:var(--y);border:3px solid var(--k);padding:14px}
.addr .an{font-size:19px;margin-top:3px}
.stack{display:grid;grid-template-columns:1fr;gap:8px;margin:0 16px}
.rule{height:3px;background:var(--k);margin:14px 16px}

/* share / photo */
.shoot{padding:8px 16px 0}
.frame-wrap{margin:8px 16px 0;display:flex;justify-content:center}
#sm-canvas{width:100%;max-width:460px;height:auto;display:block;background:var(--w);border:3px solid var(--k);touch-action:none;cursor:grab;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}
.frame-wrap,#sm-cardwrap,.empty{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}
.empty{margin:8px 16px 0;border:3px solid var(--k);background:var(--w);aspect-ratio:1/1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;cursor:pointer}
.empty .an{font-size:26px}
.empty .lab{opacity:.7}
.mini{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:12px 16px 0;align-items:center}
.mc{display:flex;align-items:center;gap:8px}
.seg{display:flex;flex:1}
.seg button{flex:1;border:2.5px solid var(--k);background:transparent;color:var(--k);font-family:'Anton',Impact,sans-serif;padding:7px 0;cursor:pointer;border-left-width:0}
.seg button:first-child{border-left-width:2.5px}
.seg button.on{background:var(--k);color:var(--y)}
.cols{display:flex;align-items:center;gap:9px;margin:12px 16px 0;flex-wrap:wrap}
.sw{width:32px;height:32px;border:2.5px solid var(--k);cursor:pointer}
.sw.auto{width:auto;padding:0 10px;height:32px;background:transparent;color:var(--k);font-family:'Anton',Impact,sans-serif;font-size:13px}
.sw.on{outline:3px solid var(--k);outline-offset:2px}
.sw.auto.on{background:var(--k);color:var(--y);outline:none}
.hint{font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.5px;opacity:.55;margin:8px 16px 0;text-align:center}
.sr{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* hours card (tappable -> calendar) */
.hours{width:calc(100% - 32px);margin:12px 16px 0;font-family:inherit;color:var(--k);text-align:left;cursor:pointer;overflow:visible}
.chev{font-family:'Anton',Impact,sans-serif;font-size:22px;line-height:1;flex:none;min-width:14px;text-align:center}

/* working-hours calendar (banner style) */
.cal-head{display:flex;align-items:baseline;justify-content:space-between;padding:14px 16px 4px}
.cal-head .an{font-size:42px}
.cal-head #sm-cal-year{font-size:24px;border-bottom:4px solid var(--k);line-height:1.15;padding-bottom:2px}
.cal-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;padding:0 12px;margin-top:6px}
.cal-dow span{font-weight:800;font-size:9px;letter-spacing:.5px;text-align:center;opacity:.7}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;padding:4px 12px 0}
.cal-cell{aspect-ratio:1/1;border:1px solid rgba(0,0,0,.25);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:2px}
.cal-empty{border:none}
.cal-d{font-family:'Anton',Impact,sans-serif;font-size:16px;line-height:1}
.cal-h{font-size:7px;font-weight:700;letter-spacing:.2px;text-align:center;line-height:1.1}
.cal-a{background:var(--y)}
.cal-b{background:var(--w)}
.cal-c{background:#FCEABB}
.cal-x{background:var(--k);color:var(--y)}
.cal-x .cal-h{font-size:7.5px}
.cal-today{outline:3px solid var(--k);outline-offset:-3px}
.cal-legend{display:grid;grid-template-columns:1fr 1fr;gap:9px;padding:16px 16px 0}
.lg{display:flex;align-items:center;gap:8px;font-weight:700;font-size:12px}
.lg-sw{width:22px;height:22px;border:2.5px solid var(--k);flex:none}
.cal-note{margin:18px 16px 26px;border-top:3px solid var(--k);padding-top:12px}
.cal-note .an{font-size:22px}
.cal-note p{font-weight:600;font-size:12.5px;margin-top:6px;opacity:.85;line-height:1.4}

/* caption + hashtags box */
.cap-box{margin:12px 16px 0;border:2.5px solid var(--k);background:var(--w);padding:10px 12px 12px}
.cap-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:7px}
.cap-copy{display:flex;align-items:center;gap:5px;background:var(--k);color:var(--y);border:none;font-family:'Anton',Impact,sans-serif;font-size:12px;letter-spacing:.6px;padding:6px 9px;cursor:pointer}
.cap-copy svg{display:block}
.cap-box p{font-weight:600;font-size:12.5px;line-height:1.5;white-space:pre-wrap;word-break:break-word}

/* footer legal */
.legal{padding:16px 16px 28px;text-align:center}
.legal-links{display:flex;gap:8px;justify-content:center;align-items:center;font-size:11px;font-weight:700}
.legal-links button,.legal-links a{background:none;border:none;color:var(--k);font:inherit;cursor:pointer;text-decoration:underline;padding:0;opacity:.75}
.legal-links span{opacity:.45}
.legal-rights{font-size:10px;opacity:.6;margin-top:9px;font-weight:600}
.legal-rights a{color:var(--k);text-decoration:underline}

/* ---------- motion polish (smoother nav + tactile feel) ---------- */
*{-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth}
body{-webkit-overflow-scrolling:touch}
/* fade only (no transform on the screen, so position:sticky header stays put) */
.screen.active{animation:fade .26s ease both}
@keyframes fade{from{opacity:0}to{opacity:1}}
.btn,.fbtn,.order,.hours,.bx,.sw,.seg button,.news-arrow,.cap-copy,.pill,.legal-links button,.legal-links a{transition:transform .1s ease,opacity .15s ease}
.btn:active,.fbtn:active,.order:active,.hours:active,.bx:active,.cap-copy:active,.seg button:active,.sw:active{transform:scale(.96)}
.fbtn,.btn,.order,.hours,.bx,.news-arrow,.sw,.seg button{-webkit-user-select:none;user-select:none}
@media (prefers-reduced-motion:reduce){.screen.active{animation:none}html{scroll-behavior:auto}}

/* Brew Guide */
.brew-methods{margin:14px 16px 12px}
.brew-methods button{font-size:12px;padding:9px 2px;letter-spacing:.3px}
.brew-card{margin:0 16px 12px;background:var(--w);border:3px solid var(--k);padding:14px}
.brew-amt-lab{display:flex;justify-content:center}
.brew-amt{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:8px}
.brew-amt button{width:50px;height:50px;border:none;background:var(--k);color:var(--y);font-family:'Anton',Impact,sans-serif;font-size:26px;line-height:1;cursor:pointer;flex:none}
.brew-amt>span{flex:1;text-align:center}
.brew-amt b{font-family:'Anton',Impact,sans-serif;font-size:40px}
.brew-amt .u{font-size:14px;opacity:.55;margin-left:5px;font-weight:700}
.brew-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:16px;border-top:2px solid rgba(0,0,0,.1);padding-top:14px}
.brew-stats>div{display:flex;flex-direction:column;gap:3px}
.brew-stats .an{font-size:19px}
.brew-timer{text-align:center}
.brew-clock{font-family:'Anton',Impact,sans-serif;font-size:58px;line-height:1}
.brew-stepnow{font-weight:700;font-size:14px;margin:4px 0 12px;min-height:19px}
.brew-steps{margin-top:14px;display:flex;flex-direction:column;gap:7px;text-align:left}
.brew-srow{display:flex;gap:11px;align-items:center;font-size:13px;font-weight:600;padding:8px 10px;background:rgba(0,0,0,.05);border:2px solid transparent}
.brew-srow.on{background:var(--y);border-color:var(--k)}
.brew-srow .bt{font-family:'Anton',Impact,sans-serif;min-width:40px;font-size:15px}

/* Find your cup quiz */
#sm-quiz-body{padding:18px 16px}
.quiz-prog{font-weight:800;font-size:11px;letter-spacing:.8px;text-transform:uppercase;opacity:.55;text-align:center}
.quiz-q{font-size:30px;text-align:center;margin:10px 0 20px}
.quiz-opts{display:flex;flex-direction:column;gap:10px}
.quiz-opt{font-size:16px;padding:16px}
.quiz-result{text-align:center}
.quiz-rname{font-size:40px;margin-top:4px}
.quiz-desc{font-weight:600;font-size:14px;line-height:1.45;margin:12px 4px 0;opacity:.9}
.quiz-bar{margin:14px 0 0;background:var(--k);color:var(--y);font-weight:700;font-size:13px;padding:11px 12px;letter-spacing:.3px}

/* About gallery: 1 column on mobile, 2 per row on desktop */
.about-gallery{display:grid;grid-template-columns:1fr;gap:12px;margin:18px 16px 4px}
.about-gallery img{width:100%;height:auto;display:block}
@media(min-width:600px){.about-gallery{grid-template-columns:1fr 1fr}}
