:root {
  --deep-mauve:#5C3D4D;
  --dusty-mauve:#8E6A7A;
  --muted-rose:#C68AA1;
  --blush-pink:#E7C9D2;
  --soft-blush:#F6EDEE;
  --cream:#FDF7F8;
  --white:#FFFFFF;
  --ink:#2C2529;
  --text:#6E5C66;
  --border:#EAD7DE;
  --shadow:0 20px 60px rgba(92,61,77,.10);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:Inter,system-ui,sans-serif;
  background:var(--cream);
  color:var(--ink);
  line-height:1.65;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
nav{
  position:sticky;top:0;z-index:50;
  height:80px;padding:0 5%;
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(253,247,248,.96);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border);
}
.logo{
  font-family:"Playfair Display","Lora",serif;
  font-size:1.85rem;font-weight:700;color:var(--deep-mauve);
  letter-spacing:-.03em;
  display:flex;align-items:center;gap:.6rem;
}
.logo img{
  width:38px;height:38px;object-fit:contain;
}
.logo em{color:var(--muted-rose);font-style:italic}
.nav-links{display:flex;gap:1.6rem;align-items:center;list-style:none}
.nav-links a{font-size:.9rem;color:var(--text);font-weight:600}
.nav-cta,.btn-primary{
  background:var(--deep-mauve);color:white!important;
  padding:.8rem 1.35rem;border-radius:999px;font-weight:700;
  display:inline-flex;align-items:center;justify-content:center;
}
.btn-secondary{
  border:1.5px solid var(--deep-mauve);color:var(--deep-mauve);
  padding:.8rem 1.35rem;border-radius:999px;font-weight:700;
  display:inline-flex;align-items:center;justify-content:center;
}
section{padding:5.5rem 5%}
.container{max-width:1120px;margin:0 auto}

/* ── HERO ── */
.hero{
  min-height:calc(100vh - 80px);
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:3rem;
  align-items:center;
  padding:4rem 7%;
  background:
    radial-gradient(circle at 8% 85%, rgba(231,201,210,.55), transparent 28%),
    linear-gradient(135deg, #FDF7F8 0%, #F6EDEE 100%);
  overflow:hidden;
}
.hero-left{z-index:3;}
.hero-logo{
  width:320px;
  max-width:100%;
  display:block;
  margin-bottom:1.5rem;
  mix-blend-mode:multiply;
}
.hero-left h1{
  font-family:"Playfair Display","Lora",serif;
  font-size:clamp(2.6rem,4.5vw,4.2rem);
  line-height:1.05;
  letter-spacing:-.03em;
  color:#5C3D4D;
  margin-bottom:1.2rem;
}
.hero-left h1 span{color:#C68AA1;}
.hero-left p{
  font-size:1.1rem;
  line-height:1.7;
  color:#6E5C66;
  max-width:500px;
}
.hero-buttons{
  display:flex;
  gap:1rem;
  flex-wrap:wrap;
  margin-top:1.75rem;
}
.hero-right{
  position:relative;
  min-height:600px;
}
.woman-img{
  position:absolute;
  right:0;top:0;
  width:460px;
  height:600px;
  object-fit:cover;
  object-position:center top;
  border-radius:40px;
  box-shadow:0 30px 80px rgba(92,61,77,.16);
  z-index:1;
}
.phone-img{
  position:absolute;
  left:-70px;
  bottom:40px;
  width:310px;
  z-index:10;
  filter:drop-shadow(0 24px 56px rgba(92,61,77,.25));
}

/* ── ALONE BANNER ── */
.alone-banner{padding:2rem 7%;background:#FDF7F8;}
.alone-inner{
  max-width:1200px;margin:0 auto;
  background:linear-gradient(135deg,#5C3D4D,#C68AA1);
  color:white;border-radius:28px;
  padding:2rem 3rem;
  display:flex;align-items:center;
  justify-content:space-between;gap:2rem;
}
.alone-inner h2{font-family:"Playfair Display",serif;font-size:2rem;color:white;}
.alone-inner p{max-width:600px;color:rgba(255,255,255,.86);}

@media(max-width:900px){
  .hero{grid-template-columns:1fr;padding:3rem 6%;}
  .hero-right{min-height:auto;margin-top:2rem;}
  .woman-img{position:relative;right:auto;top:auto;width:100%;height:380px;border-radius:32px;}
  .phone-img{position:relative;left:auto;bottom:auto;width:min(280px,80%);margin:1rem auto 0;display:block;}
}
@media(max-width:800px){
  .alone-inner{flex-direction:column;align-items:flex-start;}
}
.eyebrow{
  color:var(--muted-rose);font-size:.78rem;font-weight:800;
  letter-spacing:.14em;text-transform:uppercase;margin-bottom:1rem;
}
h1,h2,h3{color:var(--deep-mauve);line-height:1.15}
h1{
  font-family:"Playfair Display","Lora",serif;
  font-size:clamp(2.6rem,6vw,5.1rem);
  letter-spacing:-.04em;margin-bottom:1.35rem;
}
h2{
  font-family:"Playfair Display","Lora",serif;
  font-size:clamp(2rem,4vw,3.35rem);
  letter-spacing:-.03em;margin-bottom:1rem;
}
.hero p,.lead{font-size:1.12rem;color:var(--text);max-width:620px}
.actions{display:flex;gap:1rem;flex-wrap:wrap;margin-top:2rem}
.trust-row{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1.5rem;color:var(--text);font-size:.9rem}

/* Hero brand block */
.hero-brand{margin-bottom:1.5rem}
.hero-brand img{width:72px;height:72px;object-fit:contain}
.brand-name{
  font-family:"Playfair Display","Lora",serif;
  font-size:clamp(2rem,4vw,3.2rem);
  color:#5C3D4D;
  line-height:1;
  letter-spacing:-.03em;
  margin-bottom:.25rem;
}
.brand-name span{color:#C68AA1;font-style:italic}
.brand-tagline{
  font-size:.75rem;font-weight:700;letter-spacing:.16em;
  text-transform:uppercase;color:var(--dusty-mauve);
  margin-bottom:1.5rem;
}

/* Logo lockup */
.logo-mark{height:44px;mix-blend-mode:multiply;background:transparent;}
.logo-lockup{display:flex;align-items:center;gap:12px}

/* Hero woman photo */
.hero-woman{
  border-radius:32px;overflow:hidden;
  box-shadow:0 30px 80px rgba(92,61,77,.18);
  position:absolute;right:-2rem;bottom:0;
  width:48%;max-height:90%;
}
.hero-woman img{width:100%;height:100%;object-fit:cover;display:block}
.hero-visual{
  position:relative;min-height:610px;border-radius:42px;
  background:
    radial-gradient(circle at 20% 20%, #E7C9D2, transparent 34%),
    radial-gradient(circle at 80% 70%, #C68AA1, transparent 38%),
    linear-gradient(160deg, #FDF7F8, #F6EDEE);
  box-shadow:var(--shadow);overflow:hidden;padding:2rem;
}
.phone{
  width:265px;min-height:540px;margin:0 auto;
  background:var(--cream);border-radius:38px;padding:18px;
  box-shadow:0 30px 80px rgba(92,61,77,.22);
  border:8px solid #fff;
}
.phone-card{
  background:#fff;border-radius:26px;padding:18px;margin-bottom:14px;
  box-shadow:0 10px 30px rgba(92,61,77,.08);
}
.phone-hero{
  background:linear-gradient(135deg,#F6EDEE,#FDF7F8);
  color:#5C3D4D;min-height:125px;
  position:relative;overflow:hidden;
}
.phone-hero strong,
.phone-hero p{position:relative;z-index:2;}
.dashboard-wave{
  position:absolute;bottom:0;left:0;right:0;
  height:62px;z-index:1;
}
.dashboard-wave svg{width:100%;height:100%;}
.site-wave-divider{
  height:90px;margin-top:-40px;overflow:hidden;
}
.site-wave-divider svg{width:100%;height:100%;}
.phone-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:9px}
.phone-tile{height:48px;border-radius:15px;background:var(--soft-blush)}
.emotional-hook {
  background:
    radial-gradient(circle at 20% 10%, rgba(231,201,210,.75), transparent 32%),
    radial-gradient(circle at 85% 70%, rgba(198,138,161,.35), transparent 35%),
    var(--cream);
}

.hook-grid {
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 2rem;
  align-items: center;
}

.quote-card {
  background: linear-gradient(135deg, #5C3D4D, #8E6A7A);
  color: white;
  border-radius: 36px;
  padding: 3rem;
  box-shadow: 0 30px 80px rgba(92,61,77,.18);
}

.quote-card p {
  font-family: "Playfair Display", serif;
  font-size: clamp(1.8rem, 4vw, 3rem);
  line-height: 1.15;
  color: white;
}

@media(max-width:880px){
  .hook-grid { grid-template-columns: 1fr; }
}

.wave{
  position:absolute;left:0;right:0;bottom:0;height:165px;
  background:
    radial-gradient(120% 90% at 10% 20%, var(--blush-pink) 0 45%, transparent 46%),
    radial-gradient(110% 90% at 65% 35%, var(--muted-rose) 0 48%, transparent 49%),
    linear-gradient(180deg,transparent 25%,var(--dusty-mauve));
  opacity:.65;
}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.35rem}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;align-items:center}
.card{
  background:rgba(255,255,255,.78);border:1px solid var(--border);
  border-radius:28px;padding:2rem;box-shadow:0 12px 40px rgba(92,61,77,.06);
}
.card-icon{font-size:2rem;margin-bottom:.9rem}
.card h3{font-size:1.2rem;margin-bottom:.55rem}
.card p{color:var(--text);font-size:.96rem}
.soft-section{background:var(--soft-blush)}
.dark-section{background:var(--deep-mauve);color:white}
.dark-section h2,.dark-section h3{color:white}
.dark-section p{color:rgba(255,255,255,.74)}
.feature-list{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:2rem}
.feature-pill{
  background:#fff;border:1px solid var(--border);border-radius:18px;
  padding:1rem;color:var(--deep-mauve);font-weight:700;text-align:center;
}
.article-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:2rem}
.article-card{
  background:#fff;border:1px solid var(--border);border-radius:26px;
  overflow:hidden;box-shadow:0 12px 40px rgba(92,61,77,.06);
}
.photo{
  height:180px;background:
    linear-gradient(135deg,rgba(92,61,77,.25),rgba(198,138,161,.4)),
    url("assets/photo-placeholder.jpg");
  background-size:cover;background-position:center;
}
.photo-doctor{background-image:linear-gradient(135deg,rgba(92,61,77,.2),rgba(198,138,161,.35)),url("assets/photo-doctor.jpg");}
.photo-perimenopause{background-image:linear-gradient(135deg,rgba(92,61,77,.2),rgba(198,138,161,.35)),url("assets/photo-perimenopause.jpg");}
.photo-symptoms{background-image:linear-gradient(135deg,rgba(92,61,77,.2),rgba(198,138,161,.35)),url("assets/photo-symptoms.jpg");}
.photo-sleep{background-image:linear-gradient(135deg,rgba(92,61,77,.2),rgba(198,138,161,.35)),url("assets/photo-sleep.jpg");}
.photo-appointment{background-image:linear-gradient(135deg,rgba(92,61,77,.2),rgba(198,138,161,.35)),url("assets/photo-appointment.png");}
.article-body{padding:1.4rem}
.article-body span{color:var(--muted-rose);font-weight:800;font-size:.75rem;text-transform:uppercase}
.article-body h3{margin:.55rem 0}
.waitlist{
  background:linear-gradient(135deg,var(--deep-mauve),var(--dusty-mauve));
  color:white;border-radius:36px;padding:3rem;text-align:center;
}
.waitlist h2{color:white}
.waitlist p{color:rgba(255,255,255,.78);margin:auto;max-width:620px}
.form{
  display:flex;gap:.7rem;max-width:520px;margin:2rem auto 0;
  background:white;padding:.45rem;border-radius:999px;
}
.form input{flex:1;border:0;padding:0 1rem;font-size:1rem;outline:0}
.form button{border:0;cursor:pointer}
footer{
  background:#2C2529;color:rgba(255,255,255,.65);
  padding:3rem 5%;font-size:.9rem;
}
.footer-inner{max-width:1120px;margin:0 auto;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.footer-links{display:flex;gap:1rem;list-style:none}

@media(max-width:880px){
  .grid-2{grid-template-columns:1fr}
  .grid-3,.article-grid,.feature-list{grid-template-columns:1fr}
  .nav-links{display:none}
  .form{border-radius:22px;flex-direction:column}
  .form input{min-height:48px}
}
