/* ============================================================
   PAGES — hero, standard, targeted, featured, QA, news, footer
   ============================================================ */

/* ---------- HERO ---------- */
.hero{ background:var(--black); color:var(--on-dark); position:relative; overflow:hidden; display:flex; align-items:center; }
.molbg{ position:absolute; inset:0; width:100%; height:100%; opacity:.7; pointer-events:none; }
.hero__vsep{ position:absolute; top:0; bottom:0; left:54%; width:1px; background:linear-gradient(180deg,transparent,var(--line-dark),transparent); }
.hero__inner{ display:grid; grid-template-columns:1.05fr 0.95fr; align-items:center; gap:40px; padding-top:clamp(40px,4.5vw,60px); padding-bottom:clamp(36px,4vw,52px); position:relative; z-index:2; width:100%; }
.hero__eyebrow{ color:var(--gold); margin:0 0 18px; }
.hero__title{ font-size:clamp(40px, 5vw, 74px); margin:0; }
.hero__title span{ color:#5d5d63; }
.hero__sub{ max-width:420px; color:var(--on-dark-soft); font-size:16px; line-height:1.7; margin:20px 0 26px; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:14px; }
/* trust badges: compact horizontal band beneath the hero copy */
.hero__trust{ display:flex; flex-wrap:wrap; gap:12px 28px; margin-top:32px; padding-top:22px; border-top:1px solid var(--line-darker); }
.trust{ display:flex; flex-direction:row; align-items:center; gap:10px; }
.trust__ic{ color:var(--gold); opacity:.9; display:grid; place-items:center; }
.trust__t{ font-family:var(--display); font-weight:600; font-size:10px; letter-spacing:0.18em; text-transform:uppercase; color:var(--on-dark-soft); line-height:1.4; }
.hero__stage{ position:relative; display:grid; place-items:center; min-height:380px; }
.hero__product{ cursor:pointer; position:relative; z-index:2; }
.hero__plinth{ position:absolute; bottom:8%; left:50%; transform:translateX(-50%); width:300px; height:300px; border-radius:50%;
  background:radial-gradient(ellipse at center, rgba(197,160,127,0.16), rgba(0,0,0,0) 62%); filter:blur(6px); }
.hero__stage .vial{ position:relative; z-index:2; animation:floaty 6s var(--ease) infinite; }
@keyframes floaty{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-12px); } }
@media (prefers-reduced-motion: reduce){ .hero__stage .vial{ animation:none; } }
.hero__badge{ position:absolute; top:6%; right:2%; z-index:3; color:var(--gold); border:1px solid var(--line-dark); padding:8px 12px; background:rgba(0,0,0,0.55); backdrop-filter:blur(6px); }

/* ---------- STANDARD ---------- */
.std{ background:var(--paper); color:var(--on-light); padding:clamp(48px,6vw,84px) 0; }
.std__grid{ display:grid; grid-template-columns:0.85fr 1.15fr; gap:clamp(32px,5vw,72px); align-items:start; }
.std__title{ font-size:clamp(34px,3.6vw,52px); margin:14px 0 18px; }
.std__body{ color:var(--on-light-soft); font-size:16px; max-width:380px; margin-bottom:24px; }
.std__pillars{ display:grid; grid-template-columns:repeat(2,1fr); gap:0; border-top:1px solid var(--line-light); border-left:1px solid var(--line-light); }
.pillar{ padding:26px 24px; border-bottom:1px solid var(--line-light); border-right:1px solid var(--line-light); }
.pillar__ic{ display:block; color:var(--on-light); margin-bottom:16px; }
.pillar__t{ font-family:var(--display); font-weight:700; font-size:13px; letter-spacing:0.2em; text-transform:uppercase; margin:0 0 12px; }
.pillar__d{ color:var(--on-light-soft); font-size:13.5px; line-height:1.6; margin:0; }
@media (min-width:1100px){ .std__pillars{ grid-template-columns:repeat(4,1fr); } }

/* ---------- TARGETED ---------- */
.targ{ background:var(--paper-2); color:var(--on-light); padding:clamp(44px,5.5vw,76px) 0; }
.targ__head{ text-align:center; margin-bottom:32px; }
.targ__title{ font-size:clamp(30px,3.4vw,46px); margin:10px 0 0; }
.targ__grid{ display:grid; grid-template-columns:repeat(5,1fr); gap:14px; }
.catcard{ display:flex; flex-direction:column; text-align:left; background:var(--white); border:1px solid var(--line-light); transition:transform .5s var(--ease), box-shadow .5s var(--ease), border-color .4s; cursor:pointer; }
.catcard:hover{ transform:translateY(-6px); box-shadow:0 30px 60px -28px rgba(0,0,0,0.3); border-color:var(--gold); }
.catcard__art{ position:relative; aspect-ratio:1/0.62; background:linear-gradient(150deg,#f7f6f3,#dedbd4); display:grid; place-items:center; overflow:hidden; }
.catcard__big{ color:#9a948b; transition:transform .6s var(--ease), color .4s; }
.catcard:hover .catcard__big{ transform:scale(1.08) rotate(-3deg); color:var(--gold-dim); }
.catcard__idx{ position:absolute; top:14px; right:16px; font-family:var(--display); font-weight:700; font-size:11px; letter-spacing:0.2em; color:var(--on-light-faint); }
.catcard__body{ padding:18px 20px 20px; position:relative; }
.catcard__t{ font-family:var(--display); font-weight:700; font-size:15px; letter-spacing:0.14em; margin:0 0 6px; }
.catcard__tag{ color:var(--on-light-soft); font-size:13px; margin:0; }
.catcard__arr{ position:absolute; right:22px; bottom:26px; color:var(--on-light); transition:transform .45s var(--ease), color .3s; }
.catcard:hover .catcard__arr{ transform:translateX(5px); color:var(--gold-dim); }

/* ---------- FEATURED ---------- */
.feat{ display:grid; grid-template-columns:1fr 1fr; min-height:600px; }
.feat__media{ position:relative; background:linear-gradient(140deg,#15151a,#060608); display:grid; place-items:center; overflow:hidden; padding:60px 30px; }
.feat__glow{ position:absolute; width:min(420px,60%); aspect-ratio:1; border-radius:50%; background:radial-gradient(ellipse at center, rgba(197,160,127,0.2), rgba(0,0,0,0) 64%); filter:blur(8px); }
.feat__pack{ position:relative; z-index:2; cursor:pointer; }
.feat__info{ background:var(--white); display:flex; align-items:center; padding:clamp(40px,7vw,100px); }
.feat__name{ font-size:clamp(46px,5vw,76px); margin:16px 0 14px; color:var(--on-light); }
.feat__blend{ font-family:var(--display); font-weight:600; letter-spacing:0.14em; font-size:15px; color:var(--gold-dim); margin:0; }
.feat__mg{ font-family:var(--display); font-weight:700; font-size:30px; letter-spacing:0.04em; margin:18px 0; color:var(--on-light); }
.feat__mg span{ font-size:16px; color:var(--on-light-faint); margin-left:2px; }
.feat__desc{ color:var(--on-light-soft); font-size:15.5px; line-height:1.7; max-width:400px; margin:0 0 22px; }
.feat__price{ font-family:var(--display); font-weight:700; font-size:24px; margin-bottom:30px; color:var(--on-light); }
.feat__cta{ display:flex; align-items:center; gap:26px; flex-wrap:wrap; }

/* ---------- QUALITY BAR ---------- */
.qa{ background:var(--obsidian); color:var(--on-dark); padding:clamp(40px,5vw,64px) 0; border-top:1px solid var(--line-darker); }
.qa__lead{ text-align:center; color:var(--gold); margin:0 0 32px; }
.qa__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; }
.qaitem{ display:flex; gap:18px; padding:6px 32px; border-left:1px solid var(--line-dark); }
.qaitem:first-child{ border-left:0; }
.qaitem__ic{ color:var(--gold); flex:none; }
.qaitem__t{ font-family:var(--display); font-weight:700; font-size:12px; letter-spacing:0.16em; text-transform:uppercase; margin:2px 0 9px; color:var(--on-dark); }
.qaitem__d{ color:var(--on-dark-soft); font-size:13px; line-height:1.55; margin:0; }

/* ---------- NEWSLETTER (compact band, fused with footer) ---------- */
.news{ background:var(--ink); color:var(--on-dark); position:relative; padding:clamp(36px,4.5vw,56px) 0; overflow:hidden; border-bottom:1px solid var(--line-darker); }
.news__rule{ display:none; }
.news__inner{ display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center; }
.news__title{ font-size:clamp(26px,3vw,40px); margin:10px 0 0; }
.news__sub{ color:var(--on-dark-soft); font-size:14.5px; max-width:380px; margin:0 0 18px; }
.news__form{ display:flex; gap:12px; max-width:440px; }
.news__form input{ flex:1; background:rgba(255,255,255,0.06); border:1px solid var(--line-dark); padding:0 18px; height:52px; font-size:14px; letter-spacing:0.04em; color:var(--on-dark); transition:border-color .3s; }
.news__form input::placeholder{ color:var(--on-dark-faint); }
.news__form input:focus{ outline:none; border-color:var(--gold); }
.news__form .btn{ height:52px; }
.news__done{ display:flex; align-items:center; gap:10px; font-family:var(--display); font-weight:600; letter-spacing:0.08em; font-size:14px; color:var(--gold); padding:16px 0; }
.news__fine{ font-size:11.5px; color:var(--on-dark-faint); margin:12px 0 0; letter-spacing:0.02em; }

/* ---------- FOOTER ---------- */
.ftr{ background:var(--black); color:var(--on-dark); padding:clamp(40px,5vw,64px) 0 32px; }
.ftr__top{ display:grid; grid-template-columns:1fr 1.5fr; gap:48px; padding-bottom:40px; border-bottom:1px solid var(--line-darker); }
.ftr__tag{ font-family:var(--display); font-weight:500; letter-spacing:0.1em; font-size:13px; line-height:2; color:var(--on-dark-soft); margin:26px 0 0; }
.ftr__social{ display:flex; gap:10px; margin-top:30px; }
.ftr__soc{ width:42px; height:42px; display:grid; place-items:center; border:1px solid var(--line-dark); color:var(--on-dark-soft); transition:color .3s, border-color .3s, background .3s; }
.ftr__soc:hover{ color:var(--gold); border-color:var(--gold); background:rgba(197,160,127,0.06); }
.ftr__cols{ display:grid; grid-template-columns:repeat(4,1fr); gap:30px; }
.ftr__h{ font-family:var(--display); font-weight:700; font-size:11px; letter-spacing:0.24em; text-transform:uppercase; color:var(--gold); margin:0 0 22px; }
.ftr__col ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:6px; }
.ftr__col a{ display:inline-block; padding:5px 0; font-size:13.5px; color:var(--on-dark-soft); letter-spacing:0.03em; cursor:pointer; transition:color .25s; }
.ftr__col a:hover{ color:var(--on-dark); }
.ftr__bottom{ display:flex; justify-content:space-between; align-items:center; gap:20px; padding-top:30px; flex-wrap:wrap; }
.ftr__copy{ font-size:12px; color:var(--on-dark-faint); letter-spacing:0.03em; margin:0; }
.ftr__ruo{ display:flex; align-items:center; gap:10px; }
.ftr__ruo span{ font-family:var(--display); font-weight:600; font-size:9.5px; letter-spacing:0.18em; color:var(--on-dark-faint); }

/* ---------- responsive ---------- */
@media (max-width: 1100px){
  .qa__grid{ grid-template-columns:repeat(2,1fr); gap:34px 0; }
  .qaitem:nth-child(odd){ border-left:0; padding-left:0; }
  .qaitem:nth-child(even){ padding-left:32px; }
  .targ__grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width: 900px){
  .hero__inner{ grid-template-columns:1fr; gap:8px; padding-top:36px; padding-bottom:32px; }
  .hero__vsep{ display:none; }
  /* copy first, product shot after — message + CTA visible immediately */
  .hero__stage{ min-height:0; margin-top:28px; }
  .hero__stage .vial, .hero__stage img{ max-height:300px; }
  .hero__title{ font-size:clamp(34px,9vw,54px); }
  .std__grid{ grid-template-columns:1fr; gap:32px; }
  .feat{ grid-template-columns:1fr; }
  .feat__media{ min-height:400px; }
  .news__inner{ grid-template-columns:1fr; gap:22px; }
}
@media (max-width: 680px){
  .targ__grid{ grid-template-columns:repeat(2,1fr); gap:10px; }
  .catcard__big{ width:36px; height:36px; }
  .catcard__t{ font-size:14px; letter-spacing:0.12em; }
  .catcard__tag{ font-size:11.5px; }
  .catcard__body{ padding:14px 14px 16px; }
  .catcard__arr{ right:14px; bottom:16px; }
  .std__pillars{ grid-template-columns:1fr; }
  .qa__grid{ grid-template-columns:1fr; gap:22px 0; }
  .qaitem{ border-left:0; padding-left:0; } .qaitem:nth-child(even){ padding-left:0; }
  .ftr__top{ grid-template-columns:1fr; gap:36px; }
  .ftr__cols{ grid-template-columns:repeat(2,1fr); gap:26px 20px; }
  .ftr__soc{ width:46px; height:46px; }
  .hero__trust{ gap:10px 20px; }
  .feat__pack{ transform:scale(0.88); }
}
@media (max-width: 360px){
  .targ__grid{ grid-template-columns:1fr; }
}
