/* page-programs.css — rules unique to 02-Programs.html (loads after main.css) */
:root{--bg:#0c1018;--dark:#161e2c;--mid:#1e2c44;--prod-bg:#0d0b1c;
  --nav-bg:rgba(12,16,24,.97);
  --acc:#a848e8;--acc-l:#cc88ff;--acc-dim:rgba(168,72,232,.12);
  --grad:linear-gradient(135deg,#D63AF0,#7B2FC9);
  --wh:#e2def4;--wh80:rgba(226,222,244,.80);--wh72:rgba(226,222,244,.72);
  --wh60:rgba(226,222,244,.60);--wh40:rgba(226,222,244,.40);
  --wh14:rgba(226,222,244,.14);--wh08:rgba(226,222,244,.08);
  --lt:#0c0818;--lt-m:#362060;--lt-a:#7020b8;--light:#f4f0ff;
  --nav-h:70px;--r:22px;--r2:16px;--gap:12px;
  --ff:'Fraunces',Georgia,serif;--fb:'Jost',system-ui,sans-serif;}
body{font-family:var(--fb);background:var(--bg);color:var(--wh);overflow-x:hidden;
  line-height:1.5;font-size:15px;
  background-image:radial-gradient(ellipse at 70% 0%,rgba(80,40,140,.12) 0%,transparent 55%)}
h1,h2,h3,h4{font-family:var(--ff);font-weight:700;line-height:1.05}
.btn-main{background:var(--grad);color:#fff;padding:12px 22px;border-radius:100px;font-size:13px;
  font-weight:600;display:inline-flex;align-items:center;gap:6px;transition:.22s;white-space:nowrap}
.pg-hero{margin:var(--gap);border-radius:var(--r);background:var(--dark);
  padding:64px 60px 52px;position:relative;overflow:hidden}
.pg-hero::before{content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse at 80% 50%,rgba(168,72,232,.15) 0%,transparent 60%)}
.pg-hero::after{content:'';position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(237,232,255,.02) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(237,232,255,.02) 1px,transparent 1px);
  background-size:56px 56px}
.pg-hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,680px) 1fr;gap:40px;align-items:center}
.pg-hero-content{min-width:0}
.pg-hero-inner h1{font-size:clamp(28px,4.2vw,54px);color:var(--wh);margin-bottom:14px;line-height:1.04}
.pg-hero-inner h1 em{font-style:italic;font-weight:300;color:var(--acc-l)}
.pg-hero-inner p{font-size:16px;color:var(--wh72);line-height:1.8;margin-bottom:24px;font-weight:300}
.pg-hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.pg-stat-val{font-family:var(--ff);font-size:36px;font-weight:700;line-height:1;
  background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.pg-stat-lbl{font-size:12px;color:var(--wh40);margin-top:4px}
.filter-sticky{position:sticky;top:var(--nav-h);z-index:50;
  background:rgba(12,16,24,.97);border-bottom:1px solid var(--wh08);
  backdrop-filter:blur(20px);padding:0 20px;}
.filter-inner{display:flex;align-items:center;gap:8px;padding:10px 0;overflow-x:auto;
  -webkit-overflow-scrolling:touch;}
.filter-inner::-webkit-scrollbar{display:none}
.filter-label{font-size:10px;color:var(--wh40);letter-spacing:.15em;text-transform:uppercase;
  padding-right:10px;border-right:1px solid var(--wh08);margin-right:4px;flex-shrink:0;font-weight:600}
.fchip{padding:7px 16px;border-radius:100px;font-size:12px;font-weight:600;
  border:1px solid var(--wh14);color:var(--wh40);cursor:pointer;transition:.2s;white-space:nowrap;flex-shrink:0}
.fchip:hover{color:var(--wh);border-color:var(--wh40)}
.fchip.active{background:var(--grad);color:#fff;border-color:transparent}
.fchip-count{font-size:10px;opacity:.7;margin-left:3px}
.search-wrap{display:flex;align-items:center;gap:6px;margin-left:auto;
  background:var(--wh08);border:1px solid var(--wh08);border-radius:8px;padding:7px 14px;flex-shrink:0}
.search-wrap input{background:none;border:none;outline:none;font-family:var(--fb);
  font-size:12px;color:var(--wh);width:160px}
.search-wrap input::placeholder{color:var(--wh40)}
.cat-sec{margin:var(--gap) var(--gap) 0;border-radius:var(--r);position:relative;overflow:hidden}
.cat-sec.dark{background:var(--dark)}
.cat-sec.mid{background:var(--mid)}
.cat-sec.prod{background:var(--prod-bg);border:1px solid var(--wh08)}
.cat-sec.light{background:var(--light)}
.cat-sec-inner{padding:40px 36px}
.cat-sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:28px;flex-wrap:wrap}
.cat-sec-head h2{font-size:clamp(20px,2.8vw,34px);color:var(--wh);line-height:1.08}
.cat-sec-head h2 em{font-style:italic;font-weight:300;color:var(--acc-l)}
.cat-sec-head.light-head h2{color:var(--lt)}
.cat-sec-head.light-head h2 em{color:var(--lt-a)}
.cat-sec-desc{font-size:13px;color:var(--wh60);max-width:360px;line-height:1.6}
.cat-count-badge{font-size:11px;color:var(--acc-l);border:1px solid rgba(168,72,232,.3);
  padding:3px 10px;border-radius:100px;flex-shrink:0}
.pgrid4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;justify-content:center}
.pgrid3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.pcard{background:rgba(237,232,255,.05);border:1px solid var(--wh08);border-radius:var(--r2);
  overflow:hidden;transition:.28s;display:flex;flex-direction:column;cursor:pointer;
  position:relative;}
.pcard:hover{background:rgba(237,232,255,.09);transform:translateY(-4px);
  box-shadow:0 14px 36px rgba(168,72,232,.18);border-color:rgba(168,72,232,.28)}
.pcard.unavailable{opacity:.5;cursor:not-allowed}
.pcard.unavailable:hover{transform:none;box-shadow:none;background:rgba(237,232,255,.05)}
.pcard-img{height:175px;position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;}
.pcard-img img{width:100%;height:100%;object-fit:cover;transition:transform .35s}
.pcard:hover .pcard-img img{transform:scale(1.05)}
.pcard-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  font-family:var(--ff);font-size:32px;font-weight:700;letter-spacing:-.02em;
  background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  opacity:.35;user-select:none;}
.pcard-img.cat-weight{background:rgba(168,72,232,.08)}
.pcard-img.cat-peptide{background:rgba(72,168,232,.08)}
.pcard-img.cat-caps{background:rgba(72,232,168,.08)}
.pcard-img.cat-otc{background:rgba(232,168,72,.08)}
.pcard-rx{position:absolute;top:8px;right:8px;font-size:9px;font-weight:700;
  color:var(--acc-l);border:1px solid rgba(168,72,232,.3);padding:2px 7px;border-radius:3px;
  background:rgba(12,16,24,.85)}
.pcard-featured{position:absolute;top:8px;left:8px;font-size:9px;font-weight:700;
  color:#fff;padding:3px 8px;border-radius:3px;background:linear-gradient(135deg,#D63AF0,#7B2FC9)}
.pcard-unavail-tag{position:absolute;top:8px;left:8px;font-size:9px;font-weight:700;
  color:var(--wh40);padding:3px 8px;border-radius:3px;background:rgba(237,232,255,.1);border:1px solid var(--wh14)}
.pcard-body{padding:14px 16px;display:flex;flex-direction:column;flex:1}
.pcard-cat{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--acc);
  margin-bottom:5px;font-weight:600}
.pcard-name{font-family:var(--ff);font-size:15px;font-weight:700;color:var(--wh);
  margin-bottom:7px;line-height:1.25}
.pcard-desc{font-size:12px;color:var(--wh60);line-height:1.6;margin-bottom:12px;flex:1}
.pcard-foot{display:flex;justify-content:space-between;align-items:center;gap:8px;
  padding-top:10px;border-top:1px solid var(--wh08);margin-top:auto}
.pcard-price{font-family:var(--ff);font-size:15px;font-weight:700;color:var(--wh72)}
.pcard-btn{font-size:11px;font-weight:700;background:var(--grad);color:#fff;
  padding:8px 12px;border-radius:6px;transition:.2s;display:inline-block;white-space:nowrap}
.pcard-btn:hover{opacity:.88}
.pcard-btn.otc-btn{background:var(--grad);border:none;color:#fff}
.feat-card{background:rgba(168,72,232,.08);border:1px solid rgba(168,72,232,.28);
  border-radius:var(--r2);overflow:hidden;
  display:grid;grid-template-columns:42% 58%;
  margin-bottom:12px;transition:.25s;cursor:pointer;position:relative;}
.feat-card:hover{transform:translateY(-3px);box-shadow:0 18px 48px rgba(168,72,232,.2)}
.feat-card-img{overflow:hidden;position:relative;min-height:200px;max-height:320px}
.feat-card-img img{width:100%;height:100%;object-fit:contain;padding:12px;box-sizing:border-box;transition:transform .35s}
.feat-card:hover .feat-card-img img{transform:scale(1.04)}
.feat-card-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(ellipse at 40% 60%,rgba(168,72,232,.2),transparent 65%),#111926;
  font-family:var(--ff);font-size:48px;font-weight:700;opacity:.25;
  background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.feat-card-body{padding:28px 28px 24px;display:flex;flex-direction:column;justify-content:center;position:relative;z-index:1}
.feat-card-tag{font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  margin-bottom:10px;background:var(--grad);-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text;display:inline-block}
.feat-card-name{font-family:var(--ff);font-size:clamp(16px,2vw,26px);font-weight:700;
  color:var(--wh);margin-bottom:8px;line-height:1.15}
.feat-card-name em{font-style:italic;font-weight:300;color:var(--acc-l);display:block}
.feat-card-desc{font-size:13px;color:var(--wh72);line-height:1.7;margin-bottom:14px}
.feat-card-price{font-family:var(--ff);font-size:22px;font-weight:700;color:var(--wh);margin-bottom:14px}
.feat-card-price small{font-family:var(--fb);font-size:12px;color:var(--wh40);font-weight:300}
.feat-card-note{font-size:11px;color:var(--wh40);font-style:italic;margin-top:10px;line-height:1.55}
.pcard-light{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:var(--r2);
  overflow:hidden;transition:.28s;display:flex;flex-direction:column;cursor:pointer;}
.pcard-light:hover{transform:translateY(-4px);box-shadow:0 14px 36px rgba(112,32,184,.15);border-color:rgba(112,32,184,.2)}
.pcard-light .pcard-img{background:var(--light-off,#f8f5ff)}
.pcard-light .pcard-cat{color:var(--lt-a)}
.pcard-light .pcard-name{color:var(--lt)}
.pcard-light .pcard-desc{color:var(--lt-m)}
.pcard-light .pcard-foot{border-top-color:rgba(0,0,0,.08)}
.pcard-light .pcard-price{color:var(--lt)}
.subsec{margin-bottom:8px;margin-top:20px;padding-bottom:8px;border-bottom:1px solid var(--wh08);
  display:flex;align-items:center;gap:10px}
.subsec:first-of-type{margin-top:0}
.subsec-title{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--acc-l)}
.subsec-line{flex:1;height:1px;background:var(--wh08)}
.disclaimer{margin:var(--gap);padding:16px 24px;border-radius:var(--r2);
  background:rgba(168,72,232,.06);border:1px solid rgba(168,72,232,.15);
  display:flex;align-items:flex-start;gap:12px;}
.disclaimer::before{content:'⚠';font-size:14px;flex-shrink:0;margin-top:2px;color:var(--acc-l);opacity:.7}
.disclaimer p{font-size:12px;color:var(--wh60);line-height:1.65}
.intake-cta{margin:var(--gap);border-radius:var(--r);
  background:radial-gradient(ellipse at 20% 50%,rgba(168,72,232,.18) 0%,transparent 55%),#0b091a;
  padding:56px 52px;display:grid;grid-template-columns:1fr auto;gap:40px;align-items:center;
  position:relative;overflow:hidden;}
.intake-cta::before{content:'';position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(237,232,255,.02) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(237,232,255,.02) 1px,transparent 1px);
  background-size:56px 56px;}
.intake-cta-text{position:relative;z-index:1}
.intake-cta-text h2{font-size:clamp(20px,2.8vw,36px);color:var(--wh);margin-bottom:10px}
.intake-cta-text h2 em{font-style:italic;font-weight:300;color:var(--acc-l)}
.intake-cta-text p{font-size:14px;color:var(--wh60);max-width:440px;line-height:1.7}
.intake-cta-right{position:relative;z-index:1;flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:8px}
.intake-note{font-size:11px;color:var(--wh40);text-align:right;font-style:italic}
.foot-tag{font-size:12px;color:var(--wh40);line-height:1.6}
.foot-prog-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 12px}
.foot-prog-grid a{font-size:12px;color:var(--wh40);transition:.2s;line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
@media(max-width:1024px){
  .pgrid4{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:768px){
  .pg-hero{margin:8px;border-radius:16px;padding:40px 20px 32px}
  .pg-hero-stats{gap:14px}
  .pg-stat-val{font-size:28px}
  .cat-sec{margin:8px 8px 0;border-radius:16px}
  .cat-sec-inner{padding:28px 18px}
  .pgrid4,.pgrid3{grid-template-columns:1fr;gap:10px}
  .feat-card{grid-template-columns:1fr}
  .feat-card-img{max-height:240px}
  .feat-card-img{min-height:180px}
  .pcard-img{height:160px}
  .disclaimer{margin:8px;border-radius:12px}
  .intake-cta{margin:8px;border-radius:16px;padding:36px 20px;grid-template-columns:1fr;gap:20px}
  .intake-cta-right{align-items:flex-start}
  .intake-note{text-align:left}
}
@media(max-width:480px){
  .pgrid4,.pgrid3{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr}
}
/* ── Programs hero right-side image (v5.4) ── */
.pg-hero{position:relative}
.pg-hero-img{justify-self:center;align-self:center;max-height:320px;max-width:100%;width:auto;object-fit:contain;filter:drop-shadow(0 18px 40px rgba(0,0,0,.45));pointer-events:none}
@media(max-width:900px){.pg-hero-img{display:none}}

/* ── Featured card tag above image (v5.8.2) ── */
.feat-card-tag-top{grid-column:1/-1;font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:16px 24px 8px;color:var(--acc-l)}

.feat-card-body .btn-main{max-width:280px;text-align:center}
