/* Ember Coffee Passport — shared styles. Tokens match ember-microsite-barista-training. */
:root{
  --espresso:#2A2520;--bean:#3D3630;--taupe:#494540;--stone:#B8AEA3;
  --ember:#DF603D;--caramel:#BB5C42;--peach:#E8A87C;--peach-soft:#F7E4DE;
  --cream:#F5F2ED;--linen:#EBE6DB;--paper:#FFFDFA;--ink:#2A2520;--muted:#7d7268;
  --line:#E4DBCE;--good:#3f6b3a;--good-bg:#E7EDE3;
  --display:'Fraunces',Georgia,'Times New Roman',serif;
  --sans:'Sofia Sans',-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --shadow:0 1px 2px rgba(42,37,32,.05),0 6px 22px rgba(42,37,32,.08);
  --shadow-lg:0 2px 6px rgba(42,37,32,.06),0 18px 50px rgba(42,37,32,.13);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--cream);line-height:1.5;-webkit-font-smoothing:antialiased}

/* ---------- hero ---------- */
header.hero{position:relative;background:var(--espresso);color:var(--cream);overflow:hidden;
  padding:calc(env(safe-area-inset-top) + 26px) 22px 34px}
.hero-grain{position:absolute;inset:0;opacity:.55;background:radial-gradient(circle at 16% 12%,rgba(223,96,61,.20),transparent 46%)}
.hero .wrap{position:relative;z-index:2;max-width:860px;margin:0 auto}
.brandbar{display:flex;align-items:center;gap:12px;margin-bottom:22px}
.brandbar img{height:38px;width:auto;display:block}
.brandbar .div{width:1px;height:22px;background:rgba(245,242,237,.25)}
.brandbar .kicker{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--peach);font-weight:700}
.brandbar a.back{margin-left:auto;color:var(--peach);font-size:13px;font-weight:700;text-decoration:none;white-space:nowrap}
.brandbar a.back:hover{text-decoration:underline}
.hero h1{font-family:var(--display);font-weight:600;font-size:clamp(30px,7vw,46px);line-height:1.05;letter-spacing:-.015em;margin:0 0 12px}
.hero p.lede{font-size:17px;max-width:52ch;margin:0 0 8px;color:#ece3d8}

/* ---------- layout ---------- */
main{max-width:860px;margin:0 auto;padding:26px 22px calc(env(safe-area-inset-bottom) + 70px)}
.card{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:22px;box-shadow:var(--shadow);margin:0 0 18px}
h2{font-family:var(--display);font-weight:600;font-size:24px;margin:34px 0 12px}
h3{font-family:var(--display);font-weight:600;font-size:19px;margin:0 0 8px}
p.sub{color:var(--muted);font-size:14.5px;margin:0 0 18px}

/* ---------- two doors ---------- */
.doors{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:22px 0 6px}
@media(max-width:680px){.doors{grid-template-columns:1fr}}
a.door{display:block;background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:0;overflow:hidden;
  text-decoration:none;color:var(--ink);box-shadow:var(--shadow);transition:transform .15s ease,box-shadow .15s ease}
a.door img.door-img{display:block;width:100%;height:158px;object-fit:cover;object-position:center 42%}
a.door .door-body{padding:20px 22px 22px}
a.door:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
a.door .tag{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--taupe);background:var(--linen);border:1px solid var(--line);border-radius:999px;padding:4px 12px;margin-bottom:12px}
a.door h3{font-size:22px}
a.door p{color:var(--muted);font-size:14.5px;margin:6px 0 16px}
a.door .go{display:block;margin-left:auto;width:fit-content;font-size:14px;padding:11px 22px}

/* ---------- map ---------- */
.map-wrap{background:var(--paper);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);
  padding:14px;overflow:hidden}
.map-wrap svg{display:block;width:100%;height:auto}
.map-land{fill:#E7DFD1;stroke:#D8CDBA;stroke-width:.6}
.map-belt{fill:rgba(223,96,61,.05)}
.map-belt-line{stroke:var(--peach);stroke-width:1;stroke-dasharray:5 5;opacity:.8}
.origin-dot{fill:var(--ember);stroke:var(--paper);stroke-width:1.6;cursor:pointer;transition:r .12s ease}
.origin-dot.dim{fill:var(--stone);opacity:.5}
.origin-dot.active{fill:var(--caramel)}
.origin-pulse{fill:none;stroke:var(--ember);stroke-width:1.2;opacity:.5}
.origin-label{font-family:var(--sans);font-size:11px;font-weight:700;fill:var(--taupe);pointer-events:none}

/* ---------- filters ---------- */
.filters{display:flex;flex-wrap:wrap;gap:16px;margin:16px 0}
.filter-group{flex:1;min-width:190px}
.filter-group label{display:block;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:7px}
.seg{display:flex;background:var(--linen);border-radius:999px;padding:3px;gap:2px}
.seg button{flex:1;border:0;background:transparent;font:inherit;font-size:12.5px;font-weight:700;color:var(--muted);
  border-radius:999px;padding:7px 4px;cursor:pointer;-webkit-tap-highlight-color:transparent;white-space:nowrap}
.seg button.on{background:var(--paper);color:var(--ink);box-shadow:0 1px 3px rgba(42,37,32,.14)}

/* ---------- coffee cards ---------- */
.coffee-grid{display:grid;grid-template-columns:1fr;gap:14px;margin:16px 0 18px}
.coffee-card{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:18px;box-shadow:var(--shadow)}
.coffee-card .origin{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--caramel);margin-bottom:5px}
.coffee-card h4{font-family:var(--display);font-weight:600;font-size:17px;margin:0 0 6px;line-height:1.2}
.coffee-card .notes{font-size:13px;color:var(--muted);margin:0 0 10px}
.coffee-card .meters{display:flex;gap:10px;font-size:11px;color:var(--muted);margin-bottom:12px}
.coffee-card .meters b{color:var(--taupe)}
.coffee-card a.buy{font-size:13px;font-weight:700;color:var(--ember);text-decoration:none}
.coffee-card a.buy:hover{text-decoration:underline}
.match-badge{float:right;font-size:11px;font-weight:800;color:var(--good);background:var(--good-bg);border-radius:999px;padding:3px 10px}

/* ---------- quiz / dial forms ---------- */
.q-step{display:none}
.q-step.on{display:block;animation:fadein .25s ease}
@keyframes fadein{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.q-count{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--caramel);margin-bottom:8px}
.q-title{font-family:var(--display);font-weight:600;font-size:clamp(21px,5vw,27px);margin:0 0 18px;line-height:1.15}
.opts{display:grid;gap:10px}
.opts button{display:flex;align-items:center;gap:12px;text-align:left;font:inherit;font-size:15.5px;font-weight:600;
  background:var(--paper);color:var(--ink);border:1.5px solid var(--line);border-radius:13px;padding:15px 17px;cursor:pointer;
  transition:border-color .12s ease,background .12s ease;-webkit-tap-highlight-color:transparent}
.opts button:hover{border-color:var(--peach)}
.opts button.picked{border-color:var(--ember);background:var(--peach-soft)}
.opts .emoji{font-size:21px;flex:none}
.q-nav{display:flex;justify-content:space-between;align-items:center;margin-top:20px}
.q-nav .backbtn{border:0;background:none;font:inherit;font-weight:700;color:var(--muted);cursor:pointer;padding:8px 0}
.progress-dots{display:flex;gap:6px}
.progress-dots i{width:8px;height:8px;border-radius:50%;background:var(--linen);border:1px solid var(--line)}
.progress-dots i.done{background:var(--ember);border-color:var(--ember)}

/* ---------- buttons ---------- */
.btn{display:inline-block;font:inherit;font-size:15px;font-weight:800;color:#fff;background:var(--ember);
  border:0;border-radius:999px;padding:14px 28px;cursor:pointer;text-decoration:none;text-align:center;
  box-shadow:0 4px 14px rgba(223,96,61,.35);transition:background .12s ease;-webkit-tap-highlight-color:transparent}
.btn:hover{background:var(--caramel)}
.btn.ghost{background:transparent;color:var(--ember);border:1.5px solid var(--ember);box-shadow:none}
.btn.taupe{background:var(--taupe);box-shadow:0 4px 14px rgba(73,69,64,.3)}
.btn.taupe:hover{background:var(--bean)}
.btn:disabled{opacity:.5;cursor:default}

/* ---------- results / brew card ---------- */
.result-hero{background:var(--espresso);color:var(--cream);border-radius:16px;padding:24px;margin-bottom:18px;position:relative;overflow:hidden}
.result-hero::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% 15%,rgba(223,96,61,.25),transparent 55%)}
.result-hero *{position:relative;z-index:1}
.result-hero .kicker{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--peach);font-weight:700;margin-bottom:8px}
.result-hero h2{color:var(--cream);margin:0 0 6px;font-size:clamp(24px,6vw,32px)}
.result-hero p{color:#ece3d8;margin:0;font-size:15px}
.brew-line{display:flex;justify-content:space-between;align-items:baseline;padding:13px 2px;border-bottom:1px solid var(--line);gap:14px}
.brew-line:last-child{border-bottom:0}
.brew-line .k{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);flex:none}
.brew-line .v{font-size:15.5px;font-weight:700;text-align:right}
.fix-callout{background:var(--peach-soft);border:1px solid #EFCBB8;border-radius:13px;padding:16px 18px;margin:16px 0;font-size:15px}
.fix-callout b{color:var(--caramel)}
.locked{position:relative;filter:blur(4px);pointer-events:none;user-select:none}

/* ---------- email gate ---------- */
.gate{background:var(--paper);border:1.5px solid var(--peach);border-radius:16px;padding:22px;box-shadow:var(--shadow-lg);margin:18px 0}
.gate h3{font-size:20px}
.gate p{color:var(--muted);font-size:14.5px;margin:6px 0 14px}
.gate form{display:flex;gap:10px}
@media(max-width:560px){.gate form{flex-direction:column}}
.gate input[type=email]{flex:1;font:inherit;font-size:15px;padding:13px 16px;border:1.5px solid var(--line);border-radius:999px;background:var(--cream);min-width:0}
.gate input[type=email]:focus{outline:none;border-color:var(--ember)}
.gate .fine{font-size:12px;color:var(--muted);margin:10px 0 0}
.gate .err{color:#a33;font-size:13px;font-weight:700;margin-top:8px;display:none}

/* ---------- misc ---------- */
.human-note{display:flex;gap:12px;align-items:flex-start;background:var(--paper);border:1px solid var(--line);
  border-radius:14px;padding:16px 18px;margin:16px 0;font-size:14.5px}
.human-note .face{flex:none;width:38px;height:38px;border-radius:50%;background:var(--espresso);color:var(--peach);
  display:flex;align-items:center;justify-content:center;font-weight:800;font-size:15px}
footer.site{max-width:860px;margin:0 auto;padding:0 22px 40px;color:var(--muted);font-size:12.5px;text-align:center}
footer.site a{color:var(--caramel)}
.crosslink{display:block;text-align:center;margin:26px 0 0;font-size:14.5px}
.crosslink a{color:var(--ember);font-weight:700}

/* ---------- grower/method imagery ---------- */
.coffee-card.has-img{display:flex;gap:20px;align-items:center}
.coffee-card.has-img img.grower{width:168px;aspect-ratio:4/5;object-fit:cover;border-radius:12px;flex:none;background:var(--linen)}
@media(max-width:560px){.coffee-card.has-img img.grower{width:112px}}
.coffee-card.has-img h4{font-size:21px}
.coffee-card .blurb{font-size:14.5px;color:var(--ink);margin:0 0 12px;max-width:56ch}
.coffee-card.has-img .cc-body{flex:1;min-width:0}

/* ---------- gated grid prompt ---------- */
.grid-prompt{grid-column:1/-1;background:var(--paper);border:1.5px dashed var(--peach);border-radius:16px;
  padding:34px 24px;text-align:center}
.grid-prompt h3{margin:0 0 6px}
.grid-prompt p{color:var(--muted);font-size:14.5px;margin:0;max-width:46ch;margin-inline:auto}

/* ---------- dial-in result hero with method photo ---------- */
.result-hero{display:flex;gap:22px;align-items:center}
.result-hero .rh-text{flex:1}
.result-hero img.rh-img{width:150px;aspect-ratio:4/5;object-fit:cover;border-radius:12px;
  border:3px solid rgba(245,242,237,.3);flex:none;box-shadow:0 8px 24px rgba(0,0,0,.3)}
@media(max-width:620px){
  .result-hero{flex-direction:column-reverse;align-items:stretch}
  .result-hero img.rh-img{width:100%;height:170px;aspect-ratio:auto}
}

/* ---------- THE FIX hero panel ---------- */
.fix-hero{position:relative;background:linear-gradient(135deg,var(--peach-soft) 0%,#FBF3E8 60%,var(--paper) 100%);
  border:2px solid var(--ember);border-radius:18px;padding:26px 28px;margin:0 0 18px;
  box-shadow:var(--shadow-lg);overflow:hidden}
.fix-hero::before{content:"☕";position:absolute;right:-14px;bottom:-24px;font-size:120px;opacity:.07;transform:rotate(-12deg)}
.fix-hero .fh-kicker{display:inline-block;font-size:11px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;
  color:#fff;background:var(--ember);border-radius:999px;padding:5px 14px}
.fix-hero .big{font-family:var(--display);font-weight:600;font-size:clamp(26px,6.5vw,40px);
  line-height:1.08;color:var(--espresso);margin:14px 0 10px;letter-spacing:-.01em}
.fix-hero .detail{font-size:15.5px;margin:0 0 10px;max-width:58ch}
.fix-hero .why{font-size:12.5px;color:var(--muted);margin:0;font-weight:600}

/* ---------- metafield content: vibe chip, review, producer story ---------- */
.origin .vibe{display:inline-block;margin-left:10px;font-size:10.5px;font-weight:800;letter-spacing:.08em;
  text-transform:uppercase;color:var(--caramel);background:var(--cream);border:1px solid var(--line);
  border-radius:999px;padding:2px 9px;vertical-align:middle}
.review-quote{background:var(--cream);border-left:3px solid var(--gold,#C99A3C);border-radius:0 10px 10px 0;
  padding:12px 16px;margin:4px 0 12px}
.review-quote .stars{color:#C99A3C;font-size:13px;letter-spacing:2px;margin-bottom:4px}
.review-quote .q{margin:0 0 4px;font-size:14.5px;font-style:italic}
.review-quote .a{margin:0;font-size:12.5px;color:var(--muted);font-weight:700}
.producer-note{font-size:13.5px;color:var(--muted);margin:0 0 12px;max-width:60ch}
.producer-note b{color:var(--caramel)}

/* ---------- dial hero beans backdrop ---------- */
.hero-beans::before{content:"";position:absolute;inset:0;background:url(assets/site/beans-texture.jpg) center/cover;opacity:.18}
.hero-beans .hero-grain{background:linear-gradient(180deg,rgba(42,37,32,.55),rgba(42,37,32,.82)),radial-gradient(circle at 16% 12%,rgba(223,96,61,.25),transparent 46%);opacity:1}
