/* PH Coffee Atlas — styles. Ported from docs/MOCKUP.html (the design target):
   four solid "pop" fills, cream base, espresso ink, swipe deck. */
:root{
  --pink:#FF2D87; --cyan:#11C0EE; --lime:#7CB518; --gold:#FFB02E;
  --cream:#FFF7EE; --paper:#FFFFFF; --ink:#2a1a12; --muted:#8c7866;
  --card-line:#f0e3d2;
  --serif:"Fraunces",Georgia,serif; --sans:"Inter",system-ui,sans-serif;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%}
body{font-family:var(--sans);background:var(--cream);color:var(--ink);line-height:1.5;overflow:hidden}
h1,h2,h3,.serif{font-family:var(--serif);line-height:1.03;letter-spacing:-.02em;font-weight:600}
a{color:inherit;text-decoration:none}
:focus-visible{outline:2px solid var(--ink);outline-offset:2px}
img{display:block;max-width:100%}

/* top bar — wordmark CENTERED */
.bar{position:fixed;top:14px;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:10px 18px}
.brand{display:flex;align-items:center;gap:9px;font-family:var(--serif);font-weight:700;font-size:19px;color:var(--ink);background:rgba(255,255,255,.7);backdrop-filter:blur(8px);padding:7px 16px;border-radius:999px;box-shadow:0 4px 18px rgba(255,45,135,.18)}
.brand .m{width:26px;height:26px;border-radius:8px;background:linear-gradient(135deg,var(--pink),var(--gold));display:grid;place-items:center;font-size:14px}

/* deck */
.deck{height:100%;overflow-y:scroll;scroll-snap-type:y mandatory;scroll-behavior:smooth}
.deck::-webkit-scrollbar{display:none}
.scene{min-height:100svh;scroll-snap-align:start;position:relative;display:flex;flex-direction:column;justify-content:center;padding:88px 18px 74px;overflow:hidden;background:linear-gradient(165deg,color-mix(in srgb,var(--b1,#fff) 15%,#fff),color-mix(in srgb,var(--b2,#fff) 11%,#fff))}
.inner{width:100%;max-width:560px;margin:0 auto;position:relative;z-index:2}
.eyebrow{display:inline-block;font-size:12px;font-weight:900;letter-spacing:.14em;text-transform:uppercase;margin-bottom:13px;padding:5px 11px;border-radius:999px;background:#fff;box-shadow:0 3px 12px rgba(0,0,0,.06)}
.scene h2{font-size:clamp(30px,7vw,46px);font-weight:700;margin:0 0 10px}
.scene h2 em{font-style:normal}
.scene .lead{font-size:15.5px;font-weight:500;margin:0 0 22px;max-width:46ch;color:#5c4838}
.hl-pink{color:var(--pink)}.hl-cyan{color:var(--cyan)}.hl-lime{color:var(--lime)}.hl-gold{color:#e7950c}
.swipe-hint{position:absolute;bottom:20px;left:0;right:0;text-align:center;font-size:12px;font-weight:700;color:rgba(42,26,18,.5);z-index:3;animation:bob 1.8s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

.cta{display:inline-flex;align-items:center;gap:8px;background:var(--pink);color:#fff;font-weight:800;font-size:15px;padding:13px 22px;border-radius:999px;border:0;cursor:pointer;box-shadow:0 8px 22px rgba(255,45,135,.4);font-family:var(--sans)}
.cta.cyan{background:var(--cyan);box-shadow:0 8px 22px rgba(17,192,238,.4)}
.cta.lime{background:var(--lime);box-shadow:0 8px 22px rgba(124,181,24,.4)}

/* hero */
.heroimg{width:100%;height:200px;object-fit:cover;border-radius:24px;margin-bottom:22px;box-shadow:0 16px 40px rgba(255,45,135,.25);border:3px solid #fff}
.s-hero h1{font-size:clamp(38px,9.5vw,60px);font-weight:700;margin:0 0 16px}
.s-hero p{font-size:clamp(16px,2.4vw,19px);font-weight:500;color:#5c4838;max-width:40ch;margin:0 0 24px}

/* rails */
.rail{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;padding:4px 18px 14px;margin:0 -18px;scrollbar-width:none}
.rail::-webkit-scrollbar{display:none}
.card{scroll-snap-align:center;flex:0 0 78%;max-width:300px;background:var(--c,var(--pink));color:var(--ct,#1c1208);border-radius:24px;border:0;padding:22px;min-height:330px;display:flex;flex-direction:column;box-shadow:0 16px 32px rgba(42,26,18,.18);position:relative;overflow:hidden}
.card .k{font-size:11.5px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:inherit;opacity:.9}
.card h3{font-size:25px;margin:5px 0 4px;font-weight:700}
.card p{font-size:14px;margin:0;color:inherit;opacity:.92}
.card .sub{font-size:13px;color:inherit;opacity:.9;font-weight:700}
.card .foot{margin-top:auto;font-size:12.5px;font-weight:900;color:inherit;opacity:.95;padding-top:12px}
.tagpop{display:inline-block;font-size:11px;font-weight:800;padding:4px 10px;border-radius:999px;margin-top:8px;color:inherit;background:rgba(255,255,255,.32)}
.badge{font-size:10.5px;font-weight:900;letter-spacing:.04em;text-transform:uppercase;padding:4px 9px;border-radius:999px;display:inline-block}
.b-single{background:#ffe7b8;color:#9a6a06}.b-blend{background:#f1d9ff;color:#7a2bb0}.b-ver{background:#d9f6e3;color:#1f9d57}
.b-new{background:var(--lime);color:#fff}.b-import{background:#cdeffb;color:#0a7ba0}.b-limited{background:#ffd9b0;color:#b5630c}
.b-draft{background:rgba(255,255,255,.45);color:#6b5640}

/* photo card */
.pcard .ph{height:128px;border-radius:14px;object-fit:cover;width:100%;margin-bottom:12px;border:2px solid #fff}
.play{position:absolute;top:64px;left:50%;transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;background:rgba(255,45,135,.92);display:grid;place-items:center;color:#fff;font-size:18px;box-shadow:0 6px 18px rgba(0,0,0,.3)}

/* region cards */
.num{display:inline-grid;place-items:center;width:30px;height:30px;border-radius:9px;background:rgba(255,255,255,.78);color:#1c1208;font-weight:900;font-size:14px}
.alt{font-size:12px;color:inherit;opacity:.92;font-weight:800;margin-top:8px}

/* flavor axes */
.axes{margin:12px 0 6px}
.axis{display:grid;grid-template-columns:54px 1fr;gap:8px;align-items:center;margin:5px 0}
.axis .l{font-size:10.5px;color:inherit;opacity:.96;text-transform:capitalize;font-weight:700}
.axis .bar{height:7px;background:color-mix(in srgb,currentColor 24%,transparent);border-radius:6px;overflow:hidden}
.axis .bar i{display:block;height:100%;border-radius:6px;background:currentColor}
.axes-soon{margin:12px 0 6px;font-size:12px;font-weight:700;color:inherit;opacity:.78;background:rgba(255,255,255,.28);border-radius:12px;padding:12px 14px}
.buy{margin-top:auto;font-size:13px;font-weight:900;color:inherit;opacity:.96;padding-top:10px}
.buy span{display:block;font-weight:600;color:inherit;opacity:.62;font-size:10.5px}

/* map */
.ph-map{width:min(62vw,240px);margin:6px auto 2px}
.ph-map svg{width:100%;height:auto;filter:drop-shadow(0 10px 24px rgba(255,45,135,.28))}
.ph-island{fill:#fff;stroke:var(--cyan);stroke-width:1.6}
.ph-pin circle{fill:var(--pink);stroke:#fff;stroke-width:1.8;cursor:pointer;transition:.15s}
.ph-pin:hover circle,.ph-pin.on circle{fill:var(--lime);r:15}
.ph-pin text{fill:#fff;font:900 11px Inter,sans-serif;text-anchor:middle;dominant-baseline:central;pointer-events:none}

/* entry tiles */
.tiles{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.tile{background:var(--tc,var(--pink));color:#1c1208;border:0;border-radius:20px;padding:18px;min-height:122px;display:flex;flex-direction:column;justify-content:space-between;cursor:pointer;transition:.15s;box-shadow:0 12px 26px rgba(42,26,18,.16)}
.tile:hover{transform:translateY(-3px);box-shadow:0 18px 34px rgba(42,26,18,.24)}
.tile .ic{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-size:21px;background:rgba(255,255,255,.4)}
.tile b{font-size:15px}.tile span{font-size:12px;color:inherit;opacity:.72}

/* contribute */
.ctr{background:#fff;border-radius:24px;padding:24px;border:2px solid var(--card-line);box-shadow:0 16px 40px rgba(42,26,18,.1)}
.ctr h3{font-size:22px;margin:0 0 6px}
.ctr p{font-size:14px;color:#5c4838;margin:0 0 14px}
.row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.chip{font-size:12px;font-weight:800;padding:7px 12px;border-radius:999px}
.footn{text-align:center;font-size:12.5px;color:#5c4838;margin-top:24px;font-weight:600}
.footn a{color:var(--pink);font-weight:800}

/* dots */
.dots{position:fixed;right:11px;top:50%;transform:translateY(-50%);z-index:50;display:flex;flex-direction:column;gap:8px}
.dots button{width:8px;height:8px;padding:0;border:0;border-radius:50%;background:rgba(42,26,18,.2);cursor:pointer;transition:.2s}
.dots button.on{background:var(--pink);height:20px;border-radius:6px}
.dots button:focus-visible{outline:2px solid var(--ink);outline-offset:2px}
@media(max-width:520px){.dots{display:none}}

@media (prefers-reduced-motion:reduce){
  .deck{scroll-snap-type:none;scroll-behavior:auto}
  .swipe-hint{animation:none}
  .tile{transition:none}
}
