/* ═══════════════════════════════════════════════════════════════════
   FORCE SHOP — Shared Stylesheet
   The Force for Health® Network · Commerce Engine (replaces WooCommerce)
   Brand colors mirror /_shared-assets/ffh-theme.css
   ═══════════════════════════════════════════════════════════════════ */

:root{
  --navy:#0f2044; --orange:#e8450a; --orange-2:#c73a08; --green:#16a34a;
  --gold:#f59e0b; --gold-2:#fbbf24; --red:#dc2626; --blue:#2563eb; --purple:#7c3aed;
  --bg:#f4f6fa; --surface:#ffffff; --sunken:#eef1f7;
  --text:#1a2238; --text-soft:#455370; --muted:#6b7a99;
  --border:#e2e8f0; --border-strong:#cbd5e1;
  --shadow-sm:0 1px 4px rgba(15,32,68,.06);
  --shadow-md:0 2px 12px rgba(15,32,68,.08);
  --shadow-lg:0 8px 30px rgba(15,32,68,.14);
  --sans:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  --radius:16px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);background:var(--bg);color:var(--text);line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:inherit}
img{max-width:100%;display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 22px}

/* ── PUBLIC NAV BAR (Sign In / Sign Up / Learn More + Jump to) ── */
.nav-bar{position:sticky;top:0;z-index:100;background:var(--navy);height:60px;display:flex;align-items:center;justify-content:space-between;padding:0 22px;box-shadow:0 2px 12px rgba(15,32,68,.18)}
.nav-logo img{height:44px}
.nav-right{display:flex;align-items:center;gap:10px}
.nav-link{color:rgba(255,255,255,.85);font-size:.84rem;font-weight:600;text-decoration:none;padding:7px 10px;border-radius:8px;transition:background .15s}
.nav-link:hover{background:rgba(255,255,255,.1)}
.nav-cta{background:var(--orange);color:#fff;padding:8px 16px;border-radius:24px;font-size:.84rem;font-weight:700;text-decoration:none;transition:background .2s}
.nav-cta:hover{background:var(--orange-2)}
.nav-jump{position:relative}
.nav-jump summary{list-style:none;cursor:pointer;color:rgba(255,255,255,.85);font-size:.84rem;font-weight:600;padding:7px 10px;border-radius:8px}
.nav-jump summary::-webkit-details-marker{display:none}
.nav-jump summary:hover{background:rgba(255,255,255,.1)}
.nav-jump ul{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border-radius:12px;box-shadow:var(--shadow-lg);min-width:220px;padding:8px 0;margin:0;list-style:none;z-index:200}
.nav-jump ul li a{display:block;padding:9px 16px;font-size:.85rem;color:var(--navy);text-decoration:none}
.nav-jump ul li a:hover{background:var(--sunken)}
.cart-pill{position:relative;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);color:#fff;font-size:.84rem;font-weight:700;padding:7px 14px;border-radius:24px;text-decoration:none;display:inline-flex;align-items:center;gap:7px;transition:background .15s}
.cart-pill:hover{background:rgba(255,255,255,.22)}
.cart-count{background:var(--gold);color:var(--navy);font-size:.72rem;font-weight:800;min-width:19px;height:19px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;padding:0 5px}

/* ── HERO ── */
.hero{position:relative;background:linear-gradient(135deg,#0f2044 0%,#1a3a6e 60%,#0d9488 130%);color:#fff;padding:64px 0 72px;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 20%,rgba(245,158,11,.22),transparent 45%);pointer-events:none}
.hero .wrap{position:relative;z-index:1;display:grid;grid-template-columns:1.3fr .9fr;gap:36px;align-items:center}
.hero h1{font-size:2.7rem;line-height:1.08;margin:0 0 14px;font-weight:800;letter-spacing:-.5px}
.hero p.lead{font-size:1.12rem;color:rgba(255,255,255,.9);margin:0 0 24px;max-width:560px}
.hero .badges{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:26px}
.hero .badge{background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.22);border-radius:30px;padding:6px 14px;font-size:.8rem;font-weight:600}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700;font-size:.95rem;padding:13px 26px;border-radius:30px;border:none;cursor:pointer;text-decoration:none;transition:transform .12s,box-shadow .2s,background .2s}
.btn:hover{transform:translateY(-2px)}
.btn-orange{background:var(--orange);color:#fff;box-shadow:0 6px 18px rgba(232,69,10,.4)}
.btn-orange:hover{background:var(--orange-2)}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.4)}
.btn-ghost:hover{background:rgba(255,255,255,.2)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:#1a3a6e}
.btn-gold{background:var(--gold);color:var(--navy)}
.btn-gold:hover{background:var(--gold-2)}
.btn-block{width:100%}
.btn-sm{padding:9px 18px;font-size:.85rem}

/* Coach host card in hero */
.coach-card{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:20px;padding:22px;backdrop-filter:blur(6px)}
.coach-card .coach-row{display:flex;gap:14px;align-items:center;margin-bottom:12px}
.coach-card img.avatar{width:64px;height:64px;border-radius:50%;border:3px solid var(--gold);object-fit:cover;background:#fff}
.coach-card .coach-name{font-weight:800;font-size:1.05rem}
.coach-card .coach-role{font-size:.78rem;color:rgba(255,255,255,.8)}
.coach-card .coach-quote{font-size:.92rem;color:rgba(255,255,255,.92);font-style:italic}

/* ── SECTION SCAFFOLD ── */
section{padding:52px 0}
.section-head{text-align:center;max-width:680px;margin:0 auto 34px}
.section-head .kicker{color:var(--orange);font-weight:800;font-size:.78rem;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:8px}
.section-head h2{font-size:1.95rem;margin:0 0 10px;font-weight:800;color:var(--navy);letter-spacing:-.3px}
.section-head p{color:var(--text-soft);font-size:1.02rem;margin:0}
.alt{background:var(--surface)}

/* ── CATEGORY TABS / CHIPS ── */
.cat-tabs{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:30px}
.cat-tab{background:var(--surface);border:1.5px solid var(--border);color:var(--text-soft);font-weight:700;font-size:.85rem;padding:9px 18px;border-radius:24px;cursor:pointer;transition:all .15s}
.cat-tab:hover{border-color:var(--orange);color:var(--orange)}
.cat-tab.active{background:var(--navy);border-color:var(--navy);color:#fff}

/* category group cards (browse-by) */
.browse-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:18px}
.browse-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px;text-decoration:none;transition:transform .15s,box-shadow .2s;display:block;border-top:4px solid var(--orange)}
.browse-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.browse-card .bc-icon{font-size:2rem;margin-bottom:10px}
.browse-card .bc-title{font-weight:800;color:var(--navy);font-size:1.05rem;margin-bottom:4px}
.browse-card .bc-sub{color:var(--muted);font-size:.85rem}

/* ── PRODUCT GRID ── */
.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(245px,1fr));gap:22px}
.product{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .15s,box-shadow .2s}
.product:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.product .thumb{aspect-ratio:1/1;background:linear-gradient(135deg,var(--sunken),#dde6f2);display:flex;align-items:center;justify-content:center;font-size:3.4rem;position:relative}
.product .ptag{position:absolute;top:10px;left:10px;background:var(--navy);color:#fff;font-size:.68rem;font-weight:800;letter-spacing:.5px;text-transform:uppercase;padding:4px 9px;border-radius:7px}
.product .ptag.sub{background:var(--purple)}
.product .ptag.course{background:var(--blue)}
.product .ptag.merch{background:var(--orange)}
.product .ptag.ticket{background:var(--green)}
.product .pbody{padding:16px;display:flex;flex-direction:column;flex:1}
.product .pname{font-weight:800;color:var(--navy);font-size:1rem;margin:0 0 4px;line-height:1.25}
.product .pdesc{color:var(--muted);font-size:.83rem;margin:0 0 12px;flex:1}
.product .pfoot{display:flex;align-items:center;justify-content:space-between;gap:10px}
.product .price{font-weight:800;color:var(--navy);font-size:1.15rem}
.product .price small{font-weight:600;color:var(--muted);font-size:.72rem}
.product .coin-chip{display:inline-flex;align-items:center;gap:4px;background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;font-size:.7rem;font-weight:700;padding:3px 7px;border-radius:20px;margin-top:8px}
.product .coin-chip img{width:15px;height:15px}

/* ── PRICING / SUBSCRIPTION TIERS ── */
.tier-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:22px;align-items:stretch}
.tier{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:28px 24px;display:flex;flex-direction:column;position:relative}
.tier.featured{border-color:var(--orange);box-shadow:0 10px 34px rgba(232,69,10,.16);transform:scale(1.03)}
.tier .pop{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--orange);color:#fff;font-size:.7rem;font-weight:800;letter-spacing:.5px;text-transform:uppercase;padding:5px 14px;border-radius:20px}
.tier .tname{font-weight:800;font-size:1.2rem;color:var(--navy)}
.tier .tprice{font-size:2.3rem;font-weight:800;color:var(--navy);margin:10px 0 2px}
.tier .tprice span{font-size:.95rem;font-weight:600;color:var(--muted)}
.tier .tnote{color:var(--muted);font-size:.82rem;margin-bottom:16px}
.tier ul{list-style:none;padding:0;margin:0 0 22px;flex:1}
.tier ul li{padding:7px 0 7px 26px;position:relative;font-size:.9rem;color:var(--text-soft);border-bottom:1px solid var(--border)}
.tier ul li::before{content:"✓";position:absolute;left:0;color:var(--green);font-weight:800}

/* ── COUPON FIELD ── */
.coupon-row{display:flex;gap:8px;margin:14px 0}
.coupon-row input{flex:1;padding:11px 14px;border:1.5px solid var(--border);border-radius:10px;font-size:.9rem;font-family:inherit}
.coupon-row input:focus{outline:none;border-color:var(--orange)}
.coupon-msg{font-size:.82rem;font-weight:700;margin-top:6px;min-height:18px}
.coupon-msg.ok{color:var(--green)}
.coupon-msg.bad{color:var(--red)}

/* ── AFFILIATE TIER DIAGRAM ── */
.aff-flow{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:30px 0}
.aff-node{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px;text-align:center}
.aff-node .num{width:42px;height:42px;border-radius:50%;background:var(--navy);color:#fff;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 12px}
.aff-node.t1 .num{background:var(--orange)}
.aff-node.t2 .num{background:var(--purple)}
.aff-pct{font-size:2rem;font-weight:800;color:var(--navy)}

/* ── REWARDS TOAST + MODAL ── */
.ffh-toast-stack{position:fixed;right:18px;bottom:18px;z-index:9999;display:flex;flex-direction:column;gap:10px;max-width:340px}
.ffh-toast{background:#fff;border-radius:14px;box-shadow:var(--shadow-lg);border-left:5px solid var(--gold);padding:14px 16px;display:flex;gap:12px;align-items:center;animation:toastIn .35s ease;cursor:default}
.ffh-toast img{width:42px;height:42px;flex-shrink:0}
.ffh-toast .tt{font-weight:800;color:var(--navy);font-size:.92rem;line-height:1.2}
.ffh-toast .ts{color:var(--muted);font-size:.8rem}
@keyframes toastIn{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}
.ffh-modal-back{position:fixed;inset:0;background:rgba(15,32,68,.55);z-index:10000;display:none;align-items:center;justify-content:center;padding:20px}
.ffh-modal-back.open{display:flex}
.ffh-modal{background:#fff;border-radius:22px;max-width:440px;width:100%;padding:34px 30px;text-align:center;box-shadow:var(--shadow-lg);animation:toastIn .3s ease}
.ffh-modal img.celebrate{width:96px;height:96px;margin:0 auto 14px}
.ffh-modal h3{font-size:1.4rem;color:var(--navy);margin:0 0 8px;font-weight:800}
.ffh-modal p{color:var(--text-soft);margin:0 0 20px}
.ffh-modal .x{position:absolute}

/* ── FOOTER ── */
footer.shop-foot{background:var(--navy);color:rgba(255,255,255,.82);padding:48px 0 30px;margin-top:30px}
footer.shop-foot .cols{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:30px}
footer.shop-foot img.flogo{height:50px;margin-bottom:14px}
footer.shop-foot h4{color:#fff;font-size:.85rem;text-transform:uppercase;letter-spacing:1px;margin:0 0 12px}
footer.shop-foot a{display:block;color:rgba(255,255,255,.7);text-decoration:none;font-size:.88rem;padding:4px 0}
footer.shop-foot a:hover{color:var(--gold)}
footer.shop-foot .legal{border-top:1px solid rgba(255,255,255,.12);margin-top:30px;padding-top:18px;font-size:.78rem;color:rgba(255,255,255,.55);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
.pay-marks{display:flex;gap:10px;align-items:center;font-size:.78rem;color:rgba(255,255,255,.6)}
.pay-marks b{color:#fff}

/* ── DEMO BANNER ── */
.demo-banner{background:var(--gold-2);color:var(--navy);text-align:center;font-size:.82rem;font-weight:700;padding:8px 14px}
.demo-banner a{color:var(--orange-2);font-weight:800}

/* ── RESPONSIVE ── */
@media(max-width:860px){
  .hero .wrap{grid-template-columns:1fr;gap:26px}
  .hero h1{font-size:2.05rem}
  .aff-flow{grid-template-columns:1fr}
  footer.shop-foot .cols{grid-template-columns:1fr 1fr}
  .tier.featured{transform:none}
}
@media(max-width:560px){
  .nav-link.hide-sm{display:none}
  footer.shop-foot .cols{grid-template-columns:1fr}
}
