/* css/pages/shop.css — page-scoped styles for /shop.
   Extracted from the inline <style> block in shop.html as part of the
   MPA migration.

   The warm palette overrides (--ink #1a1410, --gold2 #a08855, cream
   --card, gold-tinted --line) are re-scoped to `.shop-page` so they
   only apply within the storefront wrapper — nav, footer, and other
   pages keep the global styles.css palette. Same approach as the cart
   page migration (see /css/pages/cart.css).

   The nav-cart and body font/background rules from the legacy file
   were dropped — both already exist in /css/styles.css. */

.shop-page{
  --ink:#1a1410; --ink2:#2e251c; --muted:#6f6052; --muted2:#8a7c6c;
  --gold:#b89640; --gold2:#a08855;
  --page-bg:#fbf9f3; --card:#fdfcf9;
  --line:rgba(184,150,78,0.18);
  --line2:rgba(184,150,78,0.32);
  --font-display:'Fraunces', Georgia, serif;
}

/* ── Hero ──────────────────────────────────────────────────────── */
.shop-hero{
  max-width:760px;margin:48px auto 32px;padding:0 24px;
  text-align:center;
}
.shop-hero .eyebrow{
  font-family:var(--font-display);
  font-size:10px;letter-spacing:3.5px;font-weight:600;
  color:var(--gold2);text-transform:uppercase;margin-bottom:14px;
}
.shop-hero h1{
  font-family:var(--font-display);
  font-size:48px;font-weight:300;font-style:italic;
  letter-spacing:-0.8px;line-height:1.1;
  margin:0 0 18px;color:var(--ink);
}
.shop-hero .divider{
  width:36px;height:1px;background:var(--gold2);
  margin:0 auto 22px;opacity:0.65;
}
.shop-hero p{
  font-size:14px;color:var(--muted);max-width:560px;
  margin:0 auto;line-height:1.65;letter-spacing:0.1px;
}

/* ── Dual paths (Kits / Bottles / Recipe PDF) ──────────────────── */
.dual-paths-wrap-eyebrow{
  text-align:center;font-family:var(--font-display);
  font-size:10px;letter-spacing:3px;font-weight:600;
  color:var(--gold2);text-transform:uppercase;margin:36px 0 18px;
}
.dual-paths{
  max-width:1180px;margin:0 auto 0;padding:0 24px;
  display:grid;grid-template-columns:repeat(3, 1fr);gap:20px;
}
@media (max-width:980px){.dual-paths{grid-template-columns:1fr 1fr}}
@media (max-width:680px){.dual-paths{grid-template-columns:1fr}}

.path-card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:2px;
  padding:40px 32px 36px;
  display:flex;flex-direction:column;align-items:center;text-align:center;
  cursor:pointer;
  transition:border-color .25s, transform .25s, box-shadow .25s;
}
.path-card:hover{
  border-color:var(--line2);
  transform:translateY(-2px);
  box-shadow:0 12px 30px rgba(40,28,12,0.06);
}
.path-card .label{
  font-family:var(--font-display);
  font-size:10px;font-weight:600;letter-spacing:3px;
  color:var(--gold2);text-transform:uppercase;margin-bottom:14px;
}
.path-card h2{
  font-family:var(--font-display);
  font-size:26px;font-weight:400;font-style:italic;
  margin:0 0 16px;letter-spacing:-0.3px;color:var(--ink);
}
.path-card p{
  font-size:13px;color:var(--muted);line-height:1.65;
  margin:0 0 22px;max-width:340px;
}
.path-card .price-from{
  font-family:var(--font-display);
  font-size:18px;font-weight:300;color:var(--ink);
  margin-bottom:24px;letter-spacing:-0.1px;
}
.path-card .price-from b{font-weight:500}
.path-card .price-from .sep{
  margin:0 8px;color:var(--muted);opacity:0.6;font-size:14px;
}
.path-card .cta{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 30px;
  background:var(--ink);color:#fff;
  border:none;border-radius:0;
  font-family:inherit;
  font-size:10.5px;font-weight:600;
  letter-spacing:2.5px;text-transform:uppercase;
  cursor:pointer;transition:all .25s;
}
.path-card .cta:hover{
  background:var(--gold2);transform:translateY(-1px);
}
.path-card .cta-arrow{font-size:13px;line-height:1;transition:transform .25s}
.path-card .cta:hover .cta-arrow{transform:translateX(3px)}

/* ── Bottle-order modal ────────────────────────────────────────── */
.rx-modal-overlay{
  display:none;position:fixed;inset:0;z-index:2000;
  background:rgba(20,14,8,0.5);
  align-items:center;justify-content:center;padding:20px;
  animation:rxFadeIn .15s ease-out;
}
.rx-modal-overlay.open{display:flex}
@keyframes rxFadeIn{from{opacity:0}to{opacity:1}}
.rx-modal{
  background:var(--card);max-width:520px;width:100%;
  border-radius:6px;padding:30px 32px 28px;
  max-height:90vh;overflow-y:auto;
  box-shadow:0 16px 48px rgba(20,14,8,0.25);
  animation:rxSlideUp .2s ease-out;
}
@keyframes rxSlideUp{from{transform:translateY(12px);opacity:0}to{transform:none;opacity:1}}
.rx-modal-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:18px}
.rx-modal-eyebrow{
  font-family:var(--font-display);
  font-size:10px;letter-spacing:3px;font-weight:600;
  color:var(--gold2);text-transform:uppercase;
}
.rx-modal-close{
  background:transparent;border:none;cursor:pointer;
  font-size:24px;line-height:1;color:var(--muted);
  padding:0;width:28px;height:28px;
}
.rx-modal-close:hover{color:var(--ink)}
.rx-modal h3{
  font-family:var(--font-display);
  font-size:24px;font-weight:300;font-style:italic;
  margin:0 0 8px;color:var(--ink);
}
.rx-modal .rx-modal-sub{
  font-size:13px;color:var(--muted);line-height:1.55;
  margin:0 0 22px;
}
.rx-field-label{
  display:block;
  font-family:var(--font-display);
  font-size:10px;letter-spacing:2px;font-weight:600;
  color:var(--gold2);text-transform:uppercase;
  margin:18px 0 10px;
}
.rx-option-grid{
  display:grid;grid-template-columns:repeat(5,1fr);gap:8px;
}
@media (max-width:720px){.rx-option-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:480px){.rx-option-grid{grid-template-columns:repeat(2,1fr)}}
.rx-option{
  padding:14px 10px;text-align:center;cursor:pointer;
  border:1px solid var(--line);border-radius:4px;
  transition:border-color .15s, background .15s;
  font-size:13px;color:var(--ink);
}
.rx-option:hover{border-color:var(--gold2)}
.rx-option.active{
  border-color:var(--ink);background:var(--ink);color:#fff;
}
.rx-option .opt-main{font-weight:600;font-size:14px;display:block}
.rx-option .opt-sub{font-size:11px;color:var(--muted);margin-top:3px;display:block}
.rx-option.active .opt-sub{color:rgba(255,255,255,0.7)}
.rx-conc-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:8px;
}
/* Prompt textarea + hint — matches the /create prompt area: cream
   surface, soft sepia border, italic Fraunces placeholder, focus
   deepens the border to ink. The hint sits just below as a small
   editorial cue without competing with the field. */
.rx-modal-textarea{
  width:100%;display:block;
  background:#fdfcf9;
  border:1px solid rgba(140,100,60,0.25);
  border-radius:4px;
  padding:14px 16px;
  font-family:var(--font-display, Georgia, serif);
  font-style:italic;font-weight:400;
  font-size:15px;color:var(--ink);
  line-height:1.55;letter-spacing:0.1px;
  resize:vertical;min-height:84px;
  outline:none;
  transition:border-color .2s ease, background .2s ease;
}
.rx-modal-textarea::placeholder{
  color:var(--muted);font-style:italic;
}
.rx-modal-textarea:hover{
  border-color:rgba(140,100,60,0.40);
  background:#fffdf8;
}
.rx-modal-textarea:focus{
  border-color:var(--ink);
  background:#fffdf8;
}
.rx-modal-textarea.is-invalid{
  border-color:rgba(176,60,60,0.65);
  background:rgba(176,60,60,0.04);
}
.rx-modal-hint{
  font-size:11.5px;color:var(--muted);
  margin:6px 2px 0;letter-spacing:0.2px;
  font-family:'Inter',system-ui,-apple-system,sans-serif;
}

.rx-modal-summary{
  margin:24px 0 18px;padding:14px 16px;
  background:rgba(184,150,78,0.08);
  border:1px solid rgba(184,150,78,0.25);
  border-radius:4px;
  font-size:13px;color:var(--ink);
}
.rx-modal-summary b{font-weight:600}
.rx-modal-actions{display:flex;gap:10px;margin-top:18px}
.rx-modal-btn{
  flex:1;padding:13px 16px;
  font-family:inherit;font-size:11px;font-weight:600;
  letter-spacing:2px;text-transform:uppercase;
  border:none;border-radius:0;cursor:pointer;
  transition:background .15s;
}
.rx-modal-btn.primary{background:var(--ink);color:#fff}
.rx-modal-btn.primary:hover{background:var(--gold2)}
.rx-modal-btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--line2)}
.rx-modal-btn.ghost:hover{border-color:var(--ink)}
.rx-signin-prompt{
  background:rgba(184,150,78,0.05);
  border:1px solid rgba(184,150,78,0.25);
  border-radius:4px;padding:18px 20px;margin-bottom:20px;
}
.rx-signin-prompt p{
  font-size:13px;color:var(--ink);margin:0 0 14px;line-height:1.55;
}
.rx-signin-prompt .rx-signin-actions{display:flex;gap:8px;flex-wrap:wrap}
.rx-signin-prompt .rx-signin-actions a{
  flex:1;padding:10px 14px;text-align:center;text-decoration:none;
  font-family:inherit;font-size:10.5px;font-weight:600;
  letter-spacing:1.8px;text-transform:uppercase;
  border-radius:0;transition:background .15s;min-width:120px;
}
.rx-signin-prompt .rx-signin-actions .primary{background:var(--ink);color:#fff}
.rx-signin-prompt .rx-signin-actions .primary:hover{background:var(--gold2)}
.rx-signin-prompt .rx-signin-actions .secondary{
  background:transparent;color:var(--ink);
  border:1px solid var(--line2);
}
.rx-signin-prompt .rx-signin-actions .secondary:hover{border-color:var(--ink)}

/* ── Promises strip (unused in template but preserved for parity) ─ */
.shop-promises{
  max-width:760px;margin:28px auto 0;padding:0 24px;
  text-align:center;
  font-family:var(--font-display);
  font-size:10px;color:var(--muted);
  letter-spacing:1.8px;text-transform:uppercase;font-weight:500;
}
.shop-promises .sep{margin:0 10px;opacity:0.5}

/* ── Kits grid section ─────────────────────────────────────────── */
.grid-header{
  max-width:1180px;margin:80px auto 18px;padding:0 24px;
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:16px;
}
.grid-header .grid-title-wrap .eyebrow{
  font-family:var(--font-display);
  font-size:10px;letter-spacing:3px;font-weight:600;
  color:var(--gold2);text-transform:uppercase;margin-bottom:10px;
}
.grid-header h2{
  font-family:var(--font-display);
  font-size:32px;font-weight:300;font-style:italic;
  letter-spacing:-0.5px;line-height:1.1;
  margin:0 0 8px;color:var(--ink);
}
.grid-header .grid-subtitle{
  font-size:13px;color:var(--muted);line-height:1.55;
  max-width:520px;margin:0;
}
.filter-bar{
  display:flex;gap:10px;
  font-size:12px;color:var(--muted);
}
.filter-bar select{
  padding:9px 28px 9px 4px;
  border:none;
  border-bottom:1px solid var(--line2);
  border-radius:0;
  background:transparent;color:var(--ink);
  font:inherit;font-size:12px;letter-spacing:0.4px;
  cursor:pointer;
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='none' stroke='%23a08855' stroke-width='1.4' d='M1 1l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 4px center;
  transition:border-color .2s;
}
.filter-bar select:focus{outline:none;border-bottom-color:var(--gold2)}

/* ── Kit tiles ─────────────────────────────────────────────────── */
.kit-grid{
  max-width:1180px;margin:0 auto 80px;padding:0 24px;
  display:grid;grid-template-columns:repeat(3, 1fr);gap:22px;
}
@media (max-width:980px){.kit-grid{grid-template-columns:repeat(2, 1fr)}}
@media (max-width:640px){.kit-grid{grid-template-columns:1fr}}

.kit-tile{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:2px;
  overflow:hidden;
  cursor:pointer;text-decoration:none;color:inherit;
  transition:transform .25s, box-shadow .25s, border-color .25s;
  display:flex;flex-direction:column;
  position:relative;
}
.kit-tile:hover{
  transform:translateY(-2px);
  border-color:var(--line2);
  box-shadow:0 12px 30px rgba(40,28,12,0.08);
}
.kit-tile .tile-banner{
  /* Source images are 3:1 landscape compositions. Match the banner
     aspect ratio to the image so nothing is cropped and no whitespace
     bars appear. Width fills the tile naturally. */
  aspect-ratio: 800 / 267;
  background:var(--accent, #e6dac6);
  position:relative;overflow:hidden;
}
.kit-tile .tile-banner img{
  width:100%;height:100%;
  object-fit:contain;object-position:center;
  display:block;
  transition:transform .35s ease;
}
.kit-tile:hover .tile-banner img{transform:scale(1.03);}
.kit-tile .tile-body{
  padding:22px 24px 22px;display:flex;flex-direction:column;flex:1;
}
.kit-tile .tile-name{
  font-family:var(--font-display);
  font-size:20px;font-weight:400;font-style:italic;
  margin:0 0 8px;letter-spacing:-0.2px;color:var(--ink);
}
.kit-tile .tile-vibe{
  font-size:12.5px;color:var(--muted);
  line-height:1.55;margin:0 0 18px;min-height:38px;
}
.kit-tile .tile-stats{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:14px;padding-top:12px;
  border-top:1px solid var(--line);
}
.kit-tile .stat-pill{
  font-family:var(--font-display);
  font-size:9.5px;font-weight:600;
  padding:0;background:transparent;
  color:var(--gold2);letter-spacing:1.6px;
  text-transform:uppercase;border:none;
}
.kit-tile .tile-price{
  font-family:var(--font-display);
  font-size:18px;font-weight:300;color:var(--ink);
  letter-spacing:-0.1px;
}
.kit-tile .tile-cta{
  margin-top:auto;padding:12px 14px;
  background:var(--ink);color:#fff;
  border-radius:0;text-align:center;
  font-family:inherit;
  font-size:10px;font-weight:600;
  letter-spacing:2.2px;text-transform:uppercase;
  transition:background .25s;
}
.kit-tile:hover .tile-cta{background:var(--gold2)}

/* ── How it works ──────────────────────────────────────────────── */
.how-strip{
  max-width:1180px;margin:0 auto 80px;padding:60px 24px;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.how-strip .how-header{
  text-align:center;margin-bottom:48px;
}
.how-strip .how-header .eyebrow{
  font-family:var(--font-display);
  font-size:10px;letter-spacing:3px;font-weight:600;
  color:var(--gold2);text-transform:uppercase;margin-bottom:12px;
}
.how-strip .how-header h2{
  font-family:var(--font-display);
  font-size:28px;font-weight:300;font-style:italic;
  letter-spacing:-0.4px;margin:0;color:var(--ink);
}
.how-grid{
  display:grid;grid-template-columns:repeat(3, 1fr);gap:48px;
  max-width:920px;margin:0 auto;
}
@media (max-width:720px){.how-grid{grid-template-columns:1fr;gap:32px}}
.how-step{
  padding-left:18px;
  border-left:1px solid var(--line2);
}
.how-step .num{
  font-family:var(--font-display);
  font-size:10px;font-weight:600;
  color:var(--gold2);letter-spacing:2.2px;
  text-transform:uppercase;margin-bottom:8px;
}
.how-step h3{
  font-family:var(--font-display);
  font-size:18px;font-weight:400;font-style:italic;
  margin:0 0 8px;letter-spacing:-0.1px;color:var(--ink);
}
.how-step p{
  font-size:12.5px;color:var(--muted);
  line-height:1.6;margin:0;
}

/* ── Pro upsell ────────────────────────────────────────────────── */
.pro-upsell{
  max-width:920px;margin:0 auto 80px;padding:28px 32px;
  background:var(--card);
  border:1px solid var(--line);
  border-radius:2px;
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;
}
@media (max-width:720px){
  .pro-upsell{flex-direction:column;text-align:center;padding:24px 22px}
}
.pro-upsell .text{
  font-size:13px;color:var(--ink2);line-height:1.6;
}
.pro-upsell .text b{font-weight:600;color:var(--ink)}
.pro-upsell .text .pro-label{
  display:block;
  font-family:var(--font-display);
  font-size:10px;letter-spacing:2.5px;font-weight:600;
  color:var(--gold2);text-transform:uppercase;margin-bottom:6px;
}
.pro-upsell a{
  padding:12px 26px;background:var(--ink);color:#fff;
  border-radius:0;text-decoration:none;
  font-family:inherit;
  font-size:10.5px;font-weight:600;
  letter-spacing:2.2px;text-transform:uppercase;
  white-space:nowrap;
  transition:all .25s;
}
.pro-upsell a:hover{
  background:var(--gold2);transform:translateY(-1px);
}
