/* ============================================================
   TrueSelf — frontend styles
   Palette + type matched to the product page reference.
   ============================================================ */

:root{
  --cream:        #F4EEE3;
  --cream-soft:   #FBF7EF;
  --panel:        #FCFAF4;
  --tan:          #C9A87E;
  --tan-deep:     #B68B4F;
  --gold:         #B98A4F;
  --gold-soft:    #C5A06A;
  --ink:          #2C2823;
  --ink-soft:     #5A5249;
  --line:         #E4D9C6;
  --green:        #6E7257;
  --white:        #ffffff;
  --radius:       14px;
  --radius-sm:    9px;
  --shadow:       0 18px 50px rgba(70,55,30,.10);
  --serif:        "Playfair Display", Georgia, serif;
  --sans:         "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.15;margin:0}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.serif{font-family:var(--serif)}
.italic-gold{font-family:var(--serif);font-style:italic;color:var(--gold)}

/* ---------- Announcement bar ---------- */
.announce{
  background:var(--ink);
  color:var(--cream);
  text-align:center;
  font-size:13px;
  letter-spacing:.04em;
  padding:9px 16px;
}

/* ---------- Header ---------- */
.site-header{
  background:var(--cream);
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:60;
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;padding:16px 24px;max-width:1180px;margin:0 auto;
}
.logo{font-family:var(--serif);font-size:30px;font-weight:600;letter-spacing:-.5px}
.logo em{font-style:italic;color:var(--gold)}
.main-nav{display:flex;gap:24px;font-size:14px;color:var(--ink-soft)}
.main-nav a:hover{color:var(--ink)}
.header-right{display:flex;align-items:center;gap:18px;font-size:13px}
.header-right .phone{color:var(--ink-soft)}
.header-right .phone strong{color:var(--ink);font-weight:600}
.cart-btn{
  position:relative;background:none;border:none;cursor:pointer;
  font-size:14px;color:var(--ink);display:flex;align-items:center;gap:7px;
}
.cart-count{
  background:var(--gold);color:#fff;border-radius:999px;
  min-width:19px;height:19px;font-size:11px;display:inline-flex;
  align-items:center;justify-content:center;padding:0 5px;font-weight:600;
}

/* ---------- Hero / product ---------- */
.product-hero{padding:40px 0 60px}
.product-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:start}

/* gallery */
.gallery .main-image{
  background:var(--panel);border-radius:var(--radius);overflow:hidden;
  aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow);
}
.gallery .main-image img{width:100%;height:100%;object-fit:cover;transition:opacity .3s}
.thumbs{display:flex;gap:12px;margin-top:14px;flex-wrap:wrap}
.thumbs .thumb{
  width:84px;height:84px;border-radius:var(--radius-sm);overflow:hidden;
  background:var(--panel);cursor:pointer;border:2px solid transparent;
}
.thumbs .thumb.active{border-color:var(--gold)}
.thumbs .thumb img{width:100%;height:100%;object-fit:cover}

/* info column */
.product-info{background:var(--panel);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow)}
.product-info .eyebrow{font-family:var(--serif);font-style:italic;color:var(--gold);font-size:20px}
.product-info h1{font-size:34px;margin:4px 0 10px}
.price-row{display:flex;align-items:baseline;gap:10px;margin-bottom:14px}
.price-row .price{font-size:26px;font-weight:700;font-family:var(--serif)}
.price-row .suffix{color:var(--ink-soft);font-size:14px}
.product-info .desc{color:var(--ink-soft);font-size:15px;margin-bottom:18px}

.benefits{list-style:none;margin:0 0 22px;padding:0;display:grid;gap:9px}
.benefits li{display:flex;gap:10px;align-items:flex-start;font-size:14.5px}
.benefits li svg{flex:0 0 18px;margin-top:3px;color:var(--gold)}

/* variant cards */
.variant-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:18px}
.variant-card{
  position:relative;border:1.5px solid var(--line);border-radius:var(--radius-sm);
  padding:14px 12px;cursor:pointer;background:#fff;transition:.18s;text-align:left;
}
.variant-card:hover{border-color:var(--gold-soft)}
.variant-card.selected{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold)}
.variant-card .vc-title{font-weight:600;font-size:13.5px}
.variant-card .vc-sub{font-size:11px;color:var(--ink-soft)}
.variant-card .vc-price{font-family:var(--serif);font-weight:700;font-size:17px;margin-top:8px}
.variant-card .vc-after{font-size:11px;color:var(--ink-soft)}
.variant-card .vc-feats{margin:8px 0 0;padding:0;list-style:none;font-size:11px;color:var(--ink-soft);display:grid;gap:3px}
.variant-card .vc-badge{
  position:absolute;top:-9px;right:10px;background:var(--gold);color:#fff;
  font-size:10px;font-weight:600;padding:3px 8px;border-radius:999px;letter-spacing:.03em;
}

/* ---- tab-based variant selector ---- */
.variant-tabs{
  display:flex;gap:4px;background:var(--cream-soft);border:1px solid var(--line);
  border-radius:14px;padding:5px;margin:4px 0 18px;
}
.vtab{
  flex:1;border:none;background:transparent;padding:13px 8px;border-radius:10px;
  font-family:var(--serif);font-size:15px;font-weight:600;color:var(--ink-soft);
  cursor:pointer;transition:.18s;
}
.vtab:hover{color:var(--ink)}
.vtab.active{
  background:linear-gradient(180deg,var(--tan),var(--tan-deep));color:#fff;
  box-shadow:0 6px 16px rgba(150,110,60,.28);
}
.vpanel{margin-bottom:18px}
.vpanel-body{display:none}
.vpanel-body.active{display:block;animation:vpfade .25s ease}
@keyframes vpfade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.vp-priceline{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.vp-price{font-family:var(--serif);font-size:34px;font-weight:700;color:var(--gold);line-height:1}
.vp-suffix{font-size:15px;color:var(--ink-soft)}
.vp-badge{
  background:var(--tan);color:#fff;font-size:11px;font-weight:600;
  padding:4px 10px;border-radius:6px;align-self:center;letter-spacing:.02em;
}
.vp-after{font-family:var(--serif);font-style:italic;color:var(--gold-soft);font-size:14px;margin-top:5px}
.vp-feats{list-style:none;margin:16px 0 0;padding:0;display:grid;gap:13px}
.vp-feats li{display:flex;align-items:center;gap:11px;font-size:14px;color:var(--ink)}
.vp-feats svg{flex:0 0 20px;color:var(--gold)}

/* ---- subscription options (Shopify style) ---- */
.sub-options{display:grid;gap:10px;margin-bottom:18px}
.sub-opt{
  display:flex;align-items:flex-start;gap:12px;border:1.5px solid var(--line);
  border-radius:12px;padding:14px 16px;cursor:pointer;background:#fff;
  transition:.18s;position:relative;
}
.sub-opt:hover{border-color:var(--gold-soft)}
.sub-opt.selected{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold);background:var(--cream-soft)}
.sub-opt input{position:absolute;opacity:0;pointer-events:none}
.so-radio{
  flex:0 0 18px;height:18px;border-radius:50%;border:2px solid var(--line);
  margin-top:2px;position:relative;transition:.18s;
}
.sub-opt.selected .so-radio{border-color:var(--gold)}
.sub-opt.selected .so-radio::after{content:"";position:absolute;top:3px;left:3px;right:3px;bottom:3px;border-radius:50%;background:var(--gold)}
.so-main{flex:1;display:flex;flex-direction:column;gap:3px}
.so-title{font-weight:600;font-size:14.5px;color:var(--ink)}
.so-title em{
  font-style:normal;background:var(--green);color:#fff;font-size:11px;
  padding:2px 8px;border-radius:5px;margin-left:6px;
}
.so-sub{font-size:12.5px;color:var(--ink-soft)}
.so-freq{font-size:12.5px;color:var(--ink-soft);margin-top:7px;display:none;align-items:center;gap:6px}
.sub-opt.selected .so-freq{display:flex}
.so-freq select{border:1px solid var(--line);border-radius:7px;padding:5px 8px;font-size:12.5px;background:#fff;color:var(--ink)}
.so-price{font-family:var(--serif);font-weight:700;font-size:16px;color:var(--ink);white-space:nowrap}
.atc-arrow{font-size:18px;line-height:1}
.ci-sub{display:inline-block;background:var(--green);color:#fff;font-size:10px;padding:2px 7px;border-radius:5px;margin-top:3px}

.badge-row{display:flex;gap:18px;flex-wrap:wrap;margin-bottom:16px;font-size:12px;color:var(--ink-soft)}.badge-row span{display:flex;align-items:center;gap:6px}
.badge-row svg{color:var(--gold)}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--sans);font-weight:600;font-size:15px;cursor:pointer;
  border:none;border-radius:999px;padding:16px 28px;transition:.18s;
}
.btn-primary{background:linear-gradient(180deg,var(--gold-soft),var(--tan-deep));color:#fff;width:100%}
.btn-primary:hover{filter:brightness(1.05)}
.btn-outline{background:#fff;border:1.5px solid var(--line);color:var(--ink)}
.affirm{font-size:12.5px;color:var(--ink-soft);margin-top:12px;text-align:center}

/* accordions in product info */
.accordion{border-top:1px solid var(--line);margin-top:22px}
.accordion .acc-item{border-bottom:1px solid var(--line)}
.accordion .acc-head{
  width:100%;background:none;border:none;text-align:left;cursor:pointer;
  padding:15px 2px;font-size:14.5px;font-weight:600;display:flex;
  justify-content:space-between;align-items:center;color:var(--ink);
}
.accordion .acc-head .pm{font-size:20px;color:var(--gold);transition:.2s}
.accordion .acc-item.open .pm{transform:rotate(45deg)}
.accordion .acc-body{max-height:0;overflow:hidden;transition:max-height .3s ease;color:var(--ink-soft);font-size:14px}
.accordion .acc-body .acc-inner{padding:0 2px 16px}

/* mini review */
.mini-review{margin-top:22px;background:#fff;border-radius:var(--radius-sm);padding:16px;border:1px solid var(--line)}
.mini-review .stars{color:var(--gold);font-size:14px}
.mini-review .rv-name{font-weight:600;font-size:13px;margin-top:4px}
.mini-review p{font-size:13px;color:var(--ink-soft);margin:6px 0 0}

/* ---------- Generic section ---------- */
section.block{padding:72px 0}
.block.bg-cream{background:var(--cream)}
.block.bg-tan{background:var(--tan);color:#fff}
.block.bg-dark{background:#3a322a;color:var(--cream)}
.block.bg-green{background:var(--green);color:#fff}
.block .sec-title{font-size:34px;text-align:center;margin-bottom:8px}
.block .sec-title .accent{font-style:italic;color:var(--gold)}
.block.bg-tan .sec-title .accent,.block.bg-green .sec-title .accent{color:#fff;opacity:.85}
.block .sec-sub{text-align:center;color:var(--ink-soft);max-width:680px;margin:0 auto 38px}
.block.bg-tan .sec-sub,.block.bg-green .sec-sub,.block.bg-dark .sec-sub{color:rgba(255,255,255,.85)}

/* what-is two column */
.what-is{display:grid;grid-template-columns:1.2fr .9fr;gap:48px;align-items:center}
.what-is h2{font-size:30px;margin-bottom:16px}
.what-is p{color:var(--ink-soft)}
.what-is .ghost-img{opacity:.5}
.btn-pill-gold{background:var(--gold-soft);color:#fff;border-radius:8px;padding:11px 26px;display:inline-block;margin-top:18px;font-size:14px;font-weight:600}

/* who-for */
.who-for{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.who-for ul{list-style:none;padding:0;margin:0;display:grid;gap:14px}
.who-for li{display:flex;gap:12px;align-items:flex-start}
.who-for li svg{flex:0 0 20px;margin-top:3px}
.who-for .who-img{border-radius:var(--radius);overflow:hidden}

/* how-it-works */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;align-items:start}
.steps .step{text-align:center}
.steps .step .num{
  width:54px;height:54px;border-radius:50%;border:2px solid var(--gold);
  color:var(--gold);font-family:var(--serif);font-size:20px;font-weight:600;
  display:flex;align-items:center;justify-content:center;margin:0 auto 16px;
}
.steps .step .icon{width:88px;height:88px;border-radius:50%;overflow:hidden;margin:0 auto 14px;background:#fff}
.steps .step h4{font-size:18px;margin-bottom:6px}
.steps .step p{font-size:14px;color:var(--ink-soft)}
.steps .arrow{display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:22px}

/* stack */
.stack-row{display:flex;justify-content:center;gap:30px;flex-wrap:wrap;margin-top:30px}
.stack-row .stack-card{width:240px;background:rgba(255,255,255,.08);border-radius:var(--radius);padding:18px;text-align:center}
.stack-row .stack-card img{border-radius:var(--radius-sm);margin-bottom:12px;aspect-ratio:1;object-fit:cover}
.stack-row .stack-card h4{font-size:16px;color:#fff}

/* results */
.results{display:grid;grid-template-columns:1fr .8fr;gap:48px;align-items:center}
.results .res-list{display:grid;gap:20px}
.results .res-item{display:flex;gap:16px;align-items:flex-start}
.results .res-item .rn{font-family:var(--serif);font-size:28px;color:var(--gold);line-height:1;flex:0 0 auto}
.results .res-item p{margin:0;font-size:15px}
.results .res-img{border-radius:var(--radius);overflow:hidden}

/* doctors slider */
.slider{position:relative}
.slider-track{display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:10px;scrollbar-width:none}
.slider-track::-webkit-scrollbar{display:none}
.doctor-card{flex:0 0 300px;scroll-snap-align:start;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.doctor-card img{aspect-ratio:1.3;object-fit:cover;width:100%}
.doctor-card .dc-body{padding:18px}
.doctor-card h4{font-size:18px}
.doctor-card .dc-role{color:var(--gold);font-size:13px;font-weight:600;margin:3px 0 8px}
.doctor-card p{font-size:13px;color:var(--ink-soft)}
.slider-nav{display:flex;gap:10px;justify-content:flex-end;margin-bottom:16px}
.slider-nav button{width:40px;height:40px;border-radius:50%;border:1.5px solid var(--line);background:#fff;cursor:pointer;font-size:16px;color:var(--ink)}
.slider-nav button:hover{border-color:var(--gold)}

/* testimonials slider */
.testi-card{flex:0 0 320px;scroll-snap-align:start;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.testi-card img{aspect-ratio:1.2;object-fit:cover;width:100%}
.testi-card .tc-body{padding:18px}
.testi-card .tc-name{font-weight:600;font-size:14px}
.testi-card .tc-result{color:var(--gold);font-size:13px;margin-bottom:8px}
.testi-card p{font-size:13px;color:var(--ink-soft)}
.trust-line{text-align:center;color:var(--ink-soft);margin-bottom:8px;font-size:14px}
.trust-line strong{color:var(--ink)}

/* faq */
.faq-wrap{max-width:820px;margin:0 auto}

/* cta */
.cta-form{max-width:520px;margin:24px auto 0;display:flex;gap:10px}
.cta-form input{flex:1;border:none;border-radius:8px;padding:15px 16px;font-size:15px}
.cta-form button{white-space:nowrap}
.cta-note{text-align:center;font-size:13px;opacity:.85;margin-top:12px}

/* disclaimer */
.disclaimer{font-size:12px;color:var(--ink-soft);text-align:center;max-width:820px;margin:0 auto;padding:24px 0}

/* ---------- Footer ---------- */
.site-footer{background:var(--cream);border-top:1px solid var(--line);padding:56px 0 0}
.footer-cols{display:grid;grid-template-columns:repeat(3,1fr) 1.3fr;gap:30px}
.footer-cols h5{font-size:13px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:14px}
.footer-cols a{display:block;font-size:14px;color:var(--ink-soft);margin-bottom:9px}
.footer-cols a:hover{color:var(--ink)}
.footer-brand{font-family:var(--serif);font-size:90px;line-height:1;text-align:center;padding:30px 0 10px;color:var(--ink)}
.footer-brand em{font-style:italic;color:var(--gold)}
.footer-bottom{border-top:1px solid var(--line);padding:18px 0;text-align:center;font-size:12px;color:var(--ink-soft)}

/* ---------- Cart drawer ---------- */
.drawer-overlay{position:fixed;inset:0;background:rgba(30,25,18,.45);opacity:0;visibility:hidden;transition:.25s;z-index:90}
.drawer-overlay.open{opacity:1;visibility:visible}
.cart-drawer{
  position:fixed;top:0;right:0;height:100%;width:420px;max-width:92vw;background:var(--cream);
  z-index:100;transform:translateX(100%);transition:transform .3s ease;display:flex;flex-direction:column;
  box-shadow:-20px 0 60px rgba(0,0,0,.18);
}
.cart-drawer.open{transform:translateX(0)}
.cart-drawer .cd-head{display:flex;justify-content:space-between;align-items:center;padding:20px 22px;border-bottom:1px solid var(--line)}
.cart-drawer .cd-head h3{font-size:20px}
.cart-drawer .cd-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--ink)}
.cart-drawer .cd-items{flex:1;overflow-y:auto;padding:8px 22px}
.cd-item{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--line)}
.cd-item img{width:64px;height:64px;border-radius:8px;object-fit:cover;background:var(--panel)}
.cd-item .ci-info{flex:1}
.cd-item .ci-info .t{font-size:14px;font-weight:600}
.cd-item .ci-info .v{font-size:12px;color:var(--ink-soft)}
.cd-item .ci-qty{display:flex;align-items:center;gap:8px;margin-top:6px;font-size:13px}
.cd-item .ci-qty button{width:24px;height:24px;border:1px solid var(--line);background:#fff;border-radius:6px;cursor:pointer}
.cd-item .ci-price{font-weight:600;font-size:14px}
.cd-item .ci-remove{background:none;border:none;color:var(--ink-soft);cursor:pointer;font-size:12px;text-decoration:underline}
.cd-empty{text-align:center;color:var(--ink-soft);padding:50px 0}
.cart-drawer .cd-foot{padding:20px 22px;border-top:1px solid var(--line)}
.cd-subtotal{display:flex;justify-content:space-between;font-size:16px;margin-bottom:14px}
.cd-subtotal strong{font-family:var(--serif)}

/* toast */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;padding:12px 22px;border-radius:999px;font-size:14px;opacity:0;visibility:hidden;transition:.25s;z-index:120}
.toast.show{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .product-grid{grid-template-columns:1fr;gap:30px}
  .what-is,.who-for,.results{grid-template-columns:1fr;gap:28px}
  .steps{grid-template-columns:1fr}
  .steps .arrow{display:none}
  .main-nav{display:none}
  .footer-cols{grid-template-columns:1fr 1fr}
  .footer-brand{font-size:54px}
  .variant-cards{grid-template-columns:1fr}
}
