/* products/css/sleep-styles.css */

:root{
  --sl-accent: #6D28D9; 
  --sl-accent-2: #C026D3; 
  --sl-accent-soft: rgba(109,40,217,.16);
  --sl-accent-line: rgba(109,40,217,.34);

  --sl-ink: #0f172a;
  --sl-ink-soft: rgba(15,23,42,.65);

  --paper: #f6f5f2;
}

.accent{ color: var(--sl-accent); }

/* Layout helper */
.grid-2{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 22px;
  align-items:start;
}
@media (max-width: 960px){
  .grid-2{ grid-template-columns: 1fr; }
}

.card{
  border: 1px solid rgba(15,23,42,.10);
  box-shadow: 0 18px 44px rgba(15,23,42,.08);
}

.paper-band{
  background:
    radial-gradient(900px 520px at 12% 10%, var(--sl-accent-soft), transparent 55%),
    radial-gradient(760px 460px at 92% 18%, rgba(192,38,211,.12), transparent 58%),
    linear-gradient(180deg, var(--paper, #eef2ff), #fff);
}

#overview .section-title{
  margin-bottom: 10px;
  position:relative;
}
#overview .section-title h2{
  position:relative;
  display:inline-block;
}
#overview .section-title h2::after{
  content:"";
  display:block;
  height: 3px;
  width: clamp(120px, 26vw, 220px);
  margin-top: 10px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--sl-accent), rgba(192,38,211,.55));
  opacity:.95;
}

/* Quick facts chips */
.facts-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top: 16px;
}
.fact-chip{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.12);
  background: rgba(255,255,255,.9);
  color: rgba(15,23,42,.82);
  font-weight: 800;
  font-size: 12px;
}
.fact-chip strong{
  font-weight: 950;
  color: rgba(15,23,42,.90);
}

/* Ingredients disclosure */
.ingredients{
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 14px;
  background:
    radial-gradient(520px 260px at 10% 0%, rgba(109,40,217,.10), transparent 55%),
    #fff;
  padding: 12px 14px;
}
.ingredients summary{
  cursor:pointer;
  font-weight: 900;
}
.ingredients summary::-webkit-details-marker{ display:none; }

/* Supplement facts */
.supplement-facts{ padding: 16px; }
.supplement-head{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:12px;
}
.supplement-media{
  margin:12px 0 0;
  border-radius: 14px;
  border: 1px solid rgba(15,23,42,.10);
  background: #fff;
  overflow: hidden;
}
.supplement-media img{
  width:100%;
  height:auto;
  display:block;
}
@media (hover:hover) and (pointer:fine){
  .supplement-media img{
    cursor: zoom-in;
    transition: transform .18s ease;
    transform-origin: center top;
  }
  .supplement-media img:hover{ transform: scale(1.04); }
}

/* Buttons */
.btn--brand{
  background: linear-gradient(135deg, var(--sl-accent), var(--sl-accent-2));
  border-color: rgba(109,40,217,.10);
  color: #fff;
}
.btn--brand:hover{ filter: brightness(.98); }

/* ===== Featured 2.0 ===== */
.featured2{
  padding: 44px 0;
}
.featured2-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:16px;
  margin-bottom: 14px;
}
.featured2-head .muted{max-width:760px;margin:0}

.featured2-shell{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 18px;
  align-items: stretch;
}

.featured2-media{
  margin:0;
  border-radius: 20px;
  overflow:hidden;
  position:relative;
  box-shadow: 0 18px 44px rgba(15,23,42,.10);
  border: 1px solid rgba(15,23,42,.08);
  background: #fff;
}
.featured2-media img{
  width:100%;
  height:100%;
  object-fit: cover;
  aspect-ratio: 4 / 3;
  display:block;
  transform: scale(1.01);
}
/* nocturnal glaze */
.featured2-media::after{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(640px 380px at 22% 22%, rgba(109,40,217,.22), transparent 55%),
    radial-gradient(520px 360px at 82% 70%, rgba(192,38,211,.14), transparent 55%);
  pointer-events:none;
}

.featured2-body{
  border-radius: 20px;
  border: 1px solid rgba(15,23,42,.08);
  background:
    radial-gradient(520px 320px at 15% 10%, rgba(109,40,217,.12), transparent 55%),
    radial-gradient(520px 320px at 90% 30%, rgba(192,38,211,.10), transparent 55%),
    #fff;
  box-shadow: 0 18px 44px rgba(15,23,42,.08);
  padding: 18px;
  display:flex;
  flex-direction:column;
  gap: 14px;
}

.featured2-info h3{
  margin: 6px 0 10px;
  font-size: 22px;
  line-height:1.2;
}
.featured2-points{
  margin: 12px 0 0;
  padding-left: 18px;
  color: rgba(15,23,42,.72);
  line-height:1.6;
}
.featured2-points li::marker{ color: rgba(109,40,217,.95); }

/* Packs */
.packs{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.pack{
  text-decoration:none;
  border-radius: 16px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.92);
  padding: 14px;
  display:flex;
  flex-direction:column;
  gap: 10px;
  position:relative;
  box-shadow: 0 12px 30px rgba(15,23,42,.06);
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
  color: inherit;
}

.pack:hover{
  transform: translateY(-2px);
  border-color: rgba(109,40,217,.35);
  box-shadow: 0 18px 44px rgba(15,23,42,.09);
}

.pack-top{ text-align:center; }

.pack-kicker{
  font-size: 12px;
  font-weight: 850;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(15,23,42,.55);
}
.pack-title{
  margin-top: 6px;
  font-weight: 950;
  font-size: 18px;
}
.pack-sub{ margin-top: 2px; }

.pack-price{
  display:flex;
  justify-content:center;
  align-items:baseline;
  gap: 2px;
  margin-top: 2px;
}
.pack-dollar, .pack-cents{
  font-weight: 900;
  font-size: 14px;
  transform: translateY(-7px);
  opacity:.9;
}
.pack-main{
  font-weight: 950;
  font-size: 36px;
  line-height: 1;
}

.pack-cta{
  margin-top: 2px;
  text-align:center;
  font-weight: 900;
  border-radius: 12px;
  padding: 10px 12px;
  border: 2px solid rgba(109,40,217,.35);
  color: rgba(15,23,42,.92);
  background: #fff;
}

.pack--best{
  border-color: rgba(109,40,217,.52);
  box-shadow: 0 18px 46px rgba(109,40,217,.14);
  background:
    radial-gradient(420px 240px at 50% 0%, rgba(109,40,217,.16), transparent 60%),
    #fff;
}

.pack--best .pack-cta{
  background: linear-gradient(135deg, var(--sl-accent), var(--sl-accent-2));
  border-color: rgba(109,40,217,.10);
  color: #fff;
}

.pack-badge{
  position:absolute;
  left: 12px;
  top: 12px;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .10em;
  text-transform: uppercase;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(109,40,217,.12);
  border: 1px solid rgba(109,40,217,.26);
  color: rgba(15,23,42,.88);
}

@media (max-width: 980px){
  .featured2-shell{ grid-template-columns: 1fr; }
  .featured2-media img{ aspect-ratio: 16 / 9; }
  .packs{ grid-template-columns: 1fr; }
  .pack{ padding: 14px 16px; }
}

section[id]{ scroll-margin-top: 120px; }

   @media (max-width: 960px){
      #featured-product .grid-2{ grid-template-columns:1fr; }
      .featured-media img{ width:100%; }
    }

    @media (min-width: 1024px){
      #overview .section-title{ margin-top: 46px; }
      #featured-product{ margin-top: -48px; }
      #how-it-works{ margin-top: -36px; }
    }
    @media (max-width: 1023px){
      #featured-product{ margin-top: -62px; }
      #how-it-works{ margin-top: -62px; }
    }
    @media (max-width: 980px){
  #how-it-works{
    margin-top: 26px;
    padding-top: 42px;
  }
}
.btn--brand {
  display: inline-block;
  padding: 14px 32px;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  text-decoration: none;
  color: #ffffff !important;
  text-align: center;
  
  background: linear-gradient(135deg, #4B2C5E 0%, #7B3F61 100%);
  
  border-radius: 15px;
  
  box-shadow: 0 4px 15px rgba(75, 44, 94, 0.3);
  
  transition: all 0.4s ease-in-out;
  border: none;
  cursor: pointer;
  position: relative;
  overflow: hidden;
}

.btn--brand:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(123, 63, 97, 0.5);
  background: linear-gradient(135deg, #5D3775 0%, #8E4970 100%);
  letter-spacing: 2px; 
}

@keyframes breathing {
  0% { box-shadow: 0 0 0 0 rgba(75, 44, 94, 0.4); }
  70% { box-shadow: 0 0 0 10px rgba(75, 44, 94, 0); }
  100% { box-shadow: 0 0 0 0 rgba(75, 44, 94, 0); }
}

.btn--brand {
  animation: breathing 3s infinite;
}
.featured-media img{
  width:100%;
  height:100%;
  object-fit: cover;
  aspect-ratio: 4 / 3;
  display:block;
  transform: scale(1.15);
}

@media (max-width: 960px){
  .featured-media img{
    aspect-ratio: 16 / 9;
    transform: scale(1.1);
    min-height: 320px;
  }
}

