/* ============================================================
   Александра Мамедова — психолог · Design System
   Snapshot tokens from sashamd.com brief (08_ТЗ)
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Raleway:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap');

:root{
  --bg:#FFFFFF;
  --bg-alt:#FBFBF9;
  --bg-warm:#F4F0E9;          /* warm beige wash for section variety */
  --primary:#0D4547;
  --primary-hover:#093536;
  --ink:#292913;
  --beige:#B49B75;
  --beige-soft:#E7DCCB;
  --coral:#F95D51;
  --muted:#6B6B6B;
  --line:#EBEBEB;
  --line-warm:#E3DBCE;

  --container:1160px;
  --radius-pill:30px;
  --radius-card:18px;
  --radius-img:20px;

  --shadow-sm:0 1px 3px rgba(41,41,19,.04), 0 6px 24px rgba(41,41,19,.05);
  --shadow-md:0 10px 40px rgba(41,41,19,.08);

  --ff:'Raleway', Arial, sans-serif;
  --sp-section:clamp(64px, 9vw, 116px);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth; -webkit-text-size-adjust:100%;}
body{
  margin:0;
  font-family:var(--ff);
  font-weight:400;
  font-size:17px;
  line-height:1.65;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%; display:block;}
a{color:inherit; text-decoration:none;}
button{font-family:inherit;}
::selection{background:var(--beige-soft); color:var(--ink);}

/* ---------- Layout ---------- */
.container{width:100%; max-width:var(--container); margin:0 auto; padding:0 24px;}
.container-narrow{max-width:720px;}
.section{padding:var(--sp-section) 0;}
.section--alt{background:var(--bg-alt);}
.section--warm{background:var(--bg-warm);}
.section--ink{background:var(--ink); color:#EDEAE0;}

/* ---------- Type ---------- */
h1,h2,h3,h4{font-weight:600; line-height:1.12; color:var(--ink); margin:0;}
.h1{font-size:clamp(34px, 5vw, 56px); line-height:1.08; letter-spacing:-.01em; font-weight:600;}
.h2{font-size:clamp(26px, 3.4vw, 38px); letter-spacing:-.005em;}
.eyebrow{
  font-size:13px; font-weight:600; letter-spacing:.22em; text-transform:uppercase;
  color:var(--beige); margin:0 0 18px;
}
.section-title{
  font-size:clamp(24px, 3.2vw, 34px); font-weight:600; text-transform:uppercase;
  letter-spacing:.06em; line-height:1.18; color:var(--ink);
}
.section--ink .section-title, .section--ink h2, .section--ink h3{color:#FFFFFF;}
.lead{font-size:clamp(18px,2vw,21px); line-height:1.6; color:var(--ink);}
.muted{color:var(--muted);}
p{margin:0 0 1em;}
p:last-child{margin-bottom:0;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-weight:600; font-size:16px; letter-spacing:.01em;
  padding:16px 30px; border-radius:var(--radius-pill);
  border:1.5px solid transparent; cursor:pointer; text-align:center;
  transition:background .25s, color .25s, border-color .25s, transform .15s;
}
.btn:active{transform:translateY(1px);}
.btn--primary{background:var(--primary); color:#fff; border-color:var(--primary);}
.btn--primary:hover{background:var(--primary-hover); border-color:var(--primary-hover);}
.btn--ghost{background:transparent; color:var(--primary); border-color:var(--primary);}
.btn--ghost:hover{background:var(--primary); color:#fff;}
.btn--light{background:#fff; color:var(--primary); border-color:#fff;}
.btn--light:hover{background:transparent; color:#fff; border-color:rgba(255,255,255,.6);}
.btn--sm{padding:12px 22px; font-size:14px;}
.btn--block{display:flex; width:100%;}

.trust-line{font-size:14px; color:var(--muted); letter-spacing:.02em;}
.dot-sep::before{content:"·"; margin:0 8px; color:var(--beige);}

/* ---------- Pills / tags ---------- */
.pill{
  display:inline-flex; align-items:center; gap:8px;
  font-size:13px; font-weight:500; letter-spacing:.04em;
  padding:8px 16px; border-radius:var(--radius-pill);
  border:1px solid var(--line-warm); color:var(--ink);
}
.pill--primary{border-color:var(--primary); color:var(--primary);}

/* ---------- Header ---------- */
.site-header{
  position:sticky; top:0; z-index:60; background:rgba(255,255,255,.92);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex; align-items:center; gap:22px; height:74px;}
.brand b{white-space:nowrap;}
.brand{display:flex; flex-direction:column; line-height:1; margin-right:auto;}
.brand b{font-weight:600; font-size:18px; letter-spacing:.02em; color:var(--ink);}
.brand span{font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--beige); margin-top:5px;}
.nav-links{display:flex; align-items:center; gap:24px; list-style:none; margin:0; padding:0;}
.nav-links a{font-size:15px; color:var(--ink); position:relative; padding:6px 0; transition:color .2s; white-space:nowrap;}
.nav-links a:hover{color:var(--primary);}
.nav-links a.active{color:var(--primary);}
.nav-links a.active::after{content:""; position:absolute; left:0; right:0; bottom:-2px; height:2px; background:var(--primary);}
.has-dd{position:relative;}
.dd-toggle{display:inline-flex; align-items:center; gap:6px; background:none; border:none; cursor:pointer; font-size:15px; color:var(--ink); padding:6px 0;}
.dd-toggle svg{transition:transform .2s;}
.has-dd.open .dd-toggle svg{transform:rotate(180deg);}
.dd-menu{
  position:absolute; top:calc(100% + 14px); left:50%; transform:translateX(-50%) translateY(8px);
  background:#fff; border:1px solid var(--line); border-radius:14px; box-shadow:var(--shadow-md);
  padding:10px; min-width:248px; opacity:0; visibility:hidden; transition:.2s;
}
.has-dd.open .dd-menu{opacity:1; visibility:visible; transform:translateX(-50%) translateY(0);}
.dd-menu a{display:block; padding:11px 14px; border-radius:9px; font-size:14.5px; color:var(--ink);}
.dd-menu a:hover{background:var(--bg-alt); color:var(--primary);}
.nav-cta{display:flex; align-items:center; gap:14px;}
.socials{display:flex; gap:12px;}
.socials a{width:34px; height:34px; display:grid; place-items:center; border:1px solid var(--line); border-radius:50%; color:var(--ink); transition:.2s;}
.socials a:hover{background:var(--primary); border-color:var(--primary); color:#fff;}
.burger{display:none; background:none; border:none; cursor:pointer; padding:8px; color:var(--ink);}

/* ---------- Hero ---------- */
.hero{position:relative; background:#EFE9E1;}
.hero-bg{position:absolute; inset:0; background-size:cover; background-position:right center; }
.hero-bg::after{content:""; position:absolute; inset:0;
  background:linear-gradient(90deg, rgba(243,239,232,.96) 0%, rgba(243,239,232,.86) 30%, rgba(243,239,232,.30) 55%, rgba(243,239,232,0) 72%);}
.hero-inner{position:relative; z-index:2; padding:clamp(70px,11vw,140px) 0; max-width:620px;}
.hero h1{margin-bottom:22px;}
.hero .lead{max-width:520px; margin-bottom:30px; color:#3a3a26;}
.hero-cta{display:flex; flex-wrap:wrap; align-items:center; gap:18px; margin-bottom:16px;}
.hero-meta{font-size:14px; color:#56563f; letter-spacing:.02em; max-width:430px;}

/* On narrow screens the text column overlaps Alexandra's photo — strengthen the scrim so copy stays readable */
@media(max-width:860px){
  .hero-bg{background-position:right -60px center;}
  .hero-bg::after{background:linear-gradient(180deg, rgba(243,239,232,.95) 0%, rgba(243,239,232,.92) 55%, rgba(243,239,232,.86) 100%);}
  .hero-inner{max-width:none;}
  .hero .lead{color:#33331f;}
  .hero-meta{color:#454534;}
}

/* page hero (inner pages) */
.page-hero{padding:clamp(48px,7vw,84px) 0 clamp(36px,5vw,56px); background:var(--bg-warm);}
.page-hero .eyebrow{color:var(--beige);}
.page-hero .lead{max-width:640px; margin-top:18px; color:#454532;}
.breadcrumbs{font-size:13px; color:var(--muted); margin-bottom:20px; letter-spacing:.02em;}
.breadcrumbs a:hover{color:var(--primary);}

/* ---------- Intro / speech bubble ---------- */
.intro-row{display:grid; grid-template-columns:auto 1fr; gap:44px; align-items:center;}
.intro-portrait{width:190px; height:190px; border-radius:50%; object-fit:cover; border:6px solid #fff; box-shadow:var(--shadow-md);}
.bubble{
  position:relative; background:var(--bg-alt); border:1px solid var(--line-warm);
  border-radius:20px; padding:26px 30px; font-size:19px; line-height:1.55;
}
.bubble::before{content:""; position:absolute; left:-11px; top:42px; width:22px; height:22px;
  background:var(--bg-alt); border-left:1px solid var(--line-warm); border-bottom:1px solid var(--line-warm);
  transform:rotate(45deg);}
.stats-row{display:flex; flex-wrap:wrap; gap:38px; margin-top:24px;}
.stat b{display:block; font-size:clamp(30px,4vw,42px); font-weight:600; color:var(--primary); line-height:1;}
.stat span{font-size:13.5px; color:var(--muted); letter-spacing:.03em; margin-top:6px; display:block;}

/* ---------- Pain list ---------- */
.pain-grid{display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:8px;}
.pain-item{
  display:flex; gap:14px; align-items:flex-start; padding:20px 22px;
  background:#fff; border:1px solid var(--line); border-radius:14px;
}
.pain-item .q{color:var(--beige); font-size:24px; line-height:1; font-weight:600;}
.pain-item p{font-size:16px; margin:0; color:#3a3a2c;}

/* ---------- Cards (barriers / how I work) ---------- */
.card-grid{display:grid; gap:24px;}
.cols-3{grid-template-columns:repeat(3,1fr);}
.cols-2{grid-template-columns:repeat(2,1fr);}
.card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius-card);
  padding:32px; box-shadow:var(--shadow-sm);
}
.card .num{font-size:13px; font-weight:600; letter-spacing:.18em; color:var(--beige); display:block; margin-bottom:16px;}
.card h3{font-size:20px; margin-bottom:12px; line-height:1.25;}
.card p{font-size:15.5px; color:#4a4a3a; margin:0;}

/* ---------- Format / alternating media rows ---------- */
.media-row{display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,5vw,72px); align-items:center;}
.media-row + .media-row{margin-top:clamp(48px,6vw,96px);}
.media-row__img{position:relative;}
.media-row__img img{width:100%; border-radius:var(--radius-img); object-fit:cover; aspect-ratio:4/3; position:relative; z-index:2;}
.media-row__img.tall img{aspect-ratio:3/4;}
.media-row__img::after{content:""; position:absolute; border-radius:var(--radius-img); background:var(--beige); opacity:.5; z-index:1;}
.media-row__img.frame-br::after{right:-22px; bottom:-22px; width:62%; height:70%;}
.media-row__img.frame-bl::after{left:-22px; bottom:-22px; width:62%; height:70%;}
.media-row.reverse .media-row__img{order:2;}
.media-row__body .eyebrow{margin-bottom:14px;}
.media-row__body h2{margin-bottom:18px;}
.feature-list{list-style:none; margin:18px 0 26px; padding:0; display:grid; gap:13px;}
.feature-list li{position:relative; padding-left:30px; font-size:16px; color:#3f3f30;}
.feature-list li::before{content:""; position:absolute; left:0; top:9px; width:14px; height:14px; border-radius:50%; border:2px solid var(--beige);}
.feature-list.check li::before{border:none; left:2px; top:4px; width:16px; height:16px;
  background:no-repeat center/contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230D4547' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");}
.price-note{font-size:14px; color:var(--muted); margin-top:6px;}

/* ---------- Pricing cards ---------- */
.price-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px;}
.price-card{background:#fff; border:1px solid var(--line); border-radius:var(--radius-card); padding:34px 30px; text-align:center; position:relative;}
.price-card.featured{border-color:var(--primary); box-shadow:var(--shadow-md);}
.price-card .tag{position:absolute; top:-13px; left:50%; transform:translateX(-50%); background:var(--primary); color:#fff; font-size:12px; letter-spacing:.08em; text-transform:uppercase; padding:5px 16px; border-radius:var(--radius-pill);}
.price-card h3{font-size:19px; margin-bottom:14px;}
.price-card .price{font-size:40px; font-weight:600; color:var(--primary); line-height:1;}
.price-card .price small{font-size:16px; color:var(--muted); font-weight:400;}
.price-card .per{font-size:14px; color:var(--muted); margin:8px 0 22px;}

/* ---------- Offer block ---------- */
.offer{background:var(--ink); color:#ECE8DD; border-radius:24px; padding:clamp(36px,5vw,60px); position:relative; overflow:hidden;}
.offer .eyebrow{color:var(--beige);}
.offer h2{color:#fff; margin-bottom:20px;}
.offer-grid{display:grid; grid-template-columns:1.3fr 1fr; gap:48px; align-items:center;}
.offer ul{list-style:none; margin:0 0 28px; padding:0; display:grid; gap:14px;}
.offer ul li{padding-left:30px; position:relative; color:#D9D4C6; font-size:16.5px;}
.offer ul li::before{content:""; position:absolute; left:0; top:4px; width:16px; height:16px;
  background:no-repeat center/contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23B49B75' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");}
.offer-trust{border-top:1px solid rgba(255,255,255,.14); padding-top:18px; font-size:14px; color:#B7B2A3; letter-spacing:.02em;}
.offer-card{background:#11201f; border:1px solid rgba(180,155,117,.3); border-radius:18px; padding:30px;}
.offer-card .big{font-size:clamp(32px,4vw,46px); font-weight:600; color:#fff; line-height:1;}
.offer-card .big span{color:var(--beige);}

/* ---------- CTA band ---------- */
.cta-band{position:relative; overflow:hidden;}
.cta-band .media-row__img img{aspect-ratio:3/4;}

/* ---------- Reviews ---------- */
.reviews-track{display:flex; gap:24px; overflow-x:auto; scroll-snap-type:x mandatory; padding:6px 2px 18px; scrollbar-width:none;}
.reviews-track::-webkit-scrollbar{display:none;}
.review-card{flex:0 0 calc(50% - 12px); scroll-snap-align:start; background:#fff; border:1px solid var(--line); border-radius:var(--radius-card); padding:32px; box-shadow:var(--shadow-sm);}
.review-card .quote-mark{font-size:46px; line-height:.6; color:var(--beige); font-weight:700; display:block; margin-bottom:8px; font-family:Georgia, serif;}
.review-card p{font-size:16px; color:#3f3f30; margin-bottom:20px;}
.review-card .who{display:flex; align-items:center; gap:12px; border-top:1px solid var(--line); padding-top:16px;}
.review-card .who b{font-size:15px; display:block; margin-bottom:2px;}
.review-card .who span{font-size:13px; color:var(--muted);}
.review-card .avatar{width:42px; height:42px; border-radius:50%; background:var(--beige-soft); color:var(--primary); display:grid; place-items:center; font-weight:600; font-size:17px;}
.slider-nav{display:flex; gap:12px; margin-top:6px;}
.slider-nav button{width:48px; height:48px; border-radius:50%; border:1.5px solid var(--line-warm); background:#fff; cursor:pointer; color:var(--ink); display:grid; place-items:center; transition:.2s;}
.slider-nav button:hover{background:var(--primary); border-color:var(--primary); color:#fff;}
.reviews-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:24px;}
.reviews-grid .review-card{flex:none;}

/* ---------- Blog ---------- */
.blog-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:28px;}
.post-card{background:#fff; border:1px solid var(--line); border-radius:var(--radius-card); overflow:hidden; box-shadow:var(--shadow-sm); transition:transform .2s, box-shadow .2s;}
.post-card:hover{transform:translateY(-4px); box-shadow:var(--shadow-md);}
.post-card .thumb{aspect-ratio:16/10; background:var(--beige-soft);}
.post-card .pad{padding:24px 26px 28px;}
.post-card .cat{font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--beige); font-weight:600;}
.post-card h3{font-size:19px; margin:12px 0 10px; line-height:1.3;}
.post-card p{font-size:15px; color:var(--muted); margin:0;}
.read-more{display:inline-flex; gap:8px; align-items:center; color:var(--primary); font-weight:600; font-size:15px; margin-top:16px;}

/* ---------- Certificate gallery ---------- */
.cert-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:20px;}
.cert-item{background:#fff; border:1px solid var(--line); border-radius:14px; padding:14px; box-shadow:var(--shadow-sm); cursor:zoom-in;}
.cert-item img{width:100%; aspect-ratio:4/3; object-fit:cover; border-radius:8px;}
.cert-item .cap{font-size:13.5px; color:var(--ink); margin-top:12px; line-height:1.4; font-weight:500;}
.cert-item .cap span{display:block; color:var(--muted); font-weight:400; font-size:12.5px; margin-top:3px;}

/* lightbox */
.lightbox{position:fixed; inset:0; background:rgba(20,20,12,.9); z-index:200; display:none; align-items:center; justify-content:center; padding:30px; cursor:zoom-out;}
.lightbox.open{display:flex;}
.lightbox img{max-width:92vw; max-height:90vh; border-radius:8px; box-shadow:0 30px 80px rgba(0,0,0,.5);}

/* ---------- Accordion ---------- */
.accordion{border-top:1px solid var(--line);}
.acc-item{border-bottom:1px solid var(--line);}
.acc-q{width:100%; background:none; border:none; cursor:pointer; text-align:left; display:flex; justify-content:space-between; align-items:center; gap:20px; padding:24px 4px; font-size:18px; font-weight:600; color:var(--ink); font-family:inherit;}
.acc-q .ico{flex:0 0 auto; width:24px; height:24px; position:relative;}
.acc-q .ico::before,.acc-q .ico::after{content:""; position:absolute; background:var(--primary); transition:transform .25s;}
.acc-q .ico::before{top:11px; left:2px; right:2px; height:2px;}
.acc-q .ico::after{left:11px; top:2px; bottom:2px; width:2px;}
.acc-item.open .acc-q .ico::after{transform:scaleY(0);}
.acc-a{max-height:0; overflow:hidden; transition:max-height .3s ease; }
.acc-a-inner{padding:0 4px 24px; font-size:16px; color:#4a4a3a; max-width:760px;}

/* ---------- Forms ---------- */
.form-card{background:#fff; border:1px solid var(--line); border-radius:var(--radius-card); padding:clamp(28px,4vw,44px); box-shadow:var(--shadow-sm);}
.field{margin-bottom:20px;}
.field label{display:block; font-size:14px; font-weight:600; margin-bottom:8px; color:var(--ink);}
.field label .opt{color:var(--muted); font-weight:400;}
.field input, .field textarea, .field select{
  width:100%; font-family:inherit; font-size:16px; color:var(--ink);
  padding:14px 16px; border:1.5px solid var(--line-warm); border-radius:12px; background:#fff; transition:border-color .2s;
}
.field input:focus, .field textarea:focus, .field select:focus{outline:none; border-color:var(--primary);}
.field textarea{min-height:104px; resize:vertical;}
.consent{display:flex; gap:12px; align-items:flex-start; font-size:13.5px; color:var(--muted); margin-bottom:24px; line-height:1.5;}
.consent input{width:20px; height:20px; flex:0 0 auto; margin-top:1px; accent-color:var(--primary);}
.consent a{color:var(--primary); text-decoration:underline;}

/* booking steps */
.steps{display:flex; gap:10px; margin-bottom:30px;}
.step-dot{display:flex; align-items:center; gap:10px; font-size:14px; color:var(--muted);}
.step-dot b{width:28px; height:28px; border-radius:50%; display:grid; place-items:center; background:var(--bg-alt); border:1.5px solid var(--line-warm); font-size:14px; color:var(--muted);}
.step-dot.active b{background:var(--primary); border-color:var(--primary); color:#fff;}
.step-dot.active{color:var(--ink); font-weight:600;}
.booking-step{display:none;}
.booking-step.active{display:block; animation:fade .35s ease;}
@keyframes fade{from{opacity:0; transform:translateY(8px);} to{opacity:1; transform:none;}}
.cal-mock{border:1px solid var(--line); border-radius:14px; padding:24px; background:var(--bg-alt);}
.cal-head{display:flex; justify-content:space-between; align-items:center; margin-bottom:18px; font-weight:600;}
.cal-grid{display:grid; grid-template-columns:repeat(7,1fr); gap:8px;}
.cal-grid .dow{font-size:12px; color:var(--muted); text-align:center; padding-bottom:4px;}
.cal-day{aspect-ratio:1; display:grid; place-items:center; border-radius:9px; font-size:14px; border:1px solid transparent; cursor:pointer; transition:.15s;}
.cal-day.avail{background:#fff; border-color:var(--line-warm); color:var(--ink);}
.cal-day.avail:hover{border-color:var(--primary); color:var(--primary);}
.cal-day.sel{background:var(--primary); color:#fff; border-color:var(--primary);}
.cal-day.off{color:#c9c9c0;}
.slots{display:flex; flex-wrap:wrap; gap:10px; margin-top:20px;}
.slot{padding:10px 18px; border:1.5px solid var(--line-warm); border-radius:var(--radius-pill); background:#fff; cursor:pointer; font-size:14px; transition:.15s;}
.slot:hover{border-color:var(--primary); color:var(--primary);}
.slot.sel{background:var(--primary); color:#fff; border-color:var(--primary);}
.notice{background:#EAF1F0; border:1px solid #cfe0de; border-radius:10px; padding:12px 16px; font-size:13.5px; color:#1c4e4d; margin-top:16px;}

/* ---------- Quests / numbered list ---------- */
.quest-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px;}
.quest{display:flex; gap:16px; padding:22px; background:#fff; border:1px solid var(--line); border-radius:14px;}
.quest b{flex:0 0 auto; width:38px; height:38px; border-radius:50%; background:var(--bg-warm); color:var(--primary); display:grid; place-items:center; font-weight:600;}
.quest p{font-size:15px; margin:0; color:#41412f;}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink); color:#C9C5B8; padding:72px 0 30px; font-size:15px;}
.footer-grid{display:grid; grid-template-columns:1.6fr 1fr 1fr auto; gap:48px; padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,.12);}
.site-footer .brand b{color:#fff;}
.site-footer p{color:#9E9A8D; max-width:300px; margin-top:18px;}
.footer-col h4{font-size:13px; letter-spacing:.16em; text-transform:uppercase; color:var(--beige); margin-bottom:18px; font-weight:600;}
.footer-col ul{list-style:none; margin:0; padding:0; display:grid; gap:11px;}
.footer-col a:hover{color:#fff;}
.footer-cta .btn{margin-bottom:18px;}
.footer-bottom{display:flex; justify-content:space-between; align-items:center; padding-top:26px; font-size:13px; color:#85816f; gap:16px; flex-wrap:wrap;}
.footer-bottom a:hover{color:#fff;}
.site-footer .socials a{border-color:rgba(255,255,255,.2); color:#C9C5B8;}
.site-footer .socials a:hover{background:var(--beige); border-color:var(--beige); color:var(--ink);}

/* ---------- Sticky mobile CTA ---------- */
.mobile-cta{position:fixed; left:0; right:0; bottom:0; z-index:55; padding:12px 16px calc(12px + env(safe-area-inset-bottom)); background:rgba(255,255,255,.95); backdrop-filter:blur(8px); border-top:1px solid var(--line); display:none;}

/* ---------- Cookie banner ---------- */
.cookie{position:fixed; left:16px; right:16px; bottom:16px; z-index:120; max-width:560px; margin:0 auto; background:#fff; border:1px solid var(--line); border-radius:16px; box-shadow:var(--shadow-md); padding:20px 24px; display:none; align-items:center; gap:20px; flex-wrap:wrap;}
.cookie.show{display:flex;}
.cookie p{font-size:13.5px; color:var(--muted); margin:0; flex:1 1 240px;}
.cookie .cookie-btns{display:flex; gap:10px;}

/* ---------- Misc ---------- */
.center{text-align:center;}
.mt-cta{margin-top:40px;}
.section-head{max-width:680px; margin-bottom:48px;}
.section-head.center{margin-left:auto; margin-right:auto;}
.divider{height:1px; background:var(--line); border:0; margin:0;}
.anchor-target{scroll-margin-top:100px;}

/* article */
.article-body{max-width:680px; margin:0 auto; font-size:18px; line-height:1.75;}
.article-body h2{font-size:26px; margin:42px 0 16px; text-transform:none; letter-spacing:0;}
.article-body p{margin-bottom:1.3em; color:#34342a;}
.article-meta{font-size:14px; color:var(--muted); margin-bottom:8px; letter-spacing:.04em;}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .cols-3{grid-template-columns:1fr 1fr;}
  .price-grid, .reviews-grid, .blog-grid, .cert-grid, .quest-grid{grid-template-columns:1fr 1fr;}
  .offer-grid{grid-template-columns:1fr; gap:30px;}
  .footer-grid{grid-template-columns:1fr 1fr; gap:36px;}
}
@media(max-width:1010px){
  .nav-links, .nav .socials, .nav .has-dd{display:none;}
  .burger{display:block;}
  .nav-cta .btn{display:none;}
  .media-row, .media-row.reverse{grid-template-columns:1fr; gap:30px;}
  .media-row.reverse .media-row__img{order:0;}
  .pain-grid{grid-template-columns:1fr;}
  .intro-row{grid-template-columns:1fr; gap:28px; text-align:center;}
  .intro-portrait{margin:0 auto;}
  .bubble::before{display:none;}
  .stats-row{justify-content:center;}
  .review-card{flex:0 0 86%;}
  .mobile-cta{display:block;}
  body.has-mobile-cta{padding-bottom:78px;}
}
@media(max-width:620px){
  .cols-3, .price-grid, .reviews-grid, .blog-grid, .cert-grid, .quest-grid, .cols-2{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  body{font-size:16px;}
  .btn{width:100%;}
  .hero-cta .btn{width:auto;}
}

/* mobile drawer */
.drawer{position:fixed; inset:0; z-index:100; background:rgba(20,20,12,.4); opacity:0; visibility:hidden; transition:.25s;}
.drawer.open{opacity:1; visibility:visible;}
.drawer-panel{position:absolute; top:0; right:0; bottom:0; width:min(330px,86vw); background:#fff; padding:26px 24px; transform:translateX(100%); transition:transform .3s; overflow-y:auto;}
.drawer.open .drawer-panel{transform:none;}
.drawer-panel .close{position:absolute; top:20px; right:20px; background:none; border:none; cursor:pointer; color:var(--ink);}
.drawer-panel nav{display:flex; flex-direction:column; gap:4px; margin-top:40px;}
.drawer-panel nav a{padding:13px 8px; font-size:17px; border-bottom:1px solid var(--line);}
.drawer-panel .sub{font-size:13px; text-transform:uppercase; letter-spacing:.14em; color:var(--beige); margin:18px 8px 6px;}
.drawer-panel .btn{margin-top:24px;}
.drawer-panel .socials{margin-top:24px; justify-content:center;}

/* ============================================================
   Groups page components (timeline, chips, hook, checklist, gallery)
   ============================================================ */
/* manifest pull-quote layout */
.manifest{display:grid; grid-template-columns:1.2fr 1fr; gap:clamp(36px,5vw,72px); align-items:center;}
.manifest__aside{font-family:var(--ff); font-size:clamp(22px,2.4vw,28px); line-height:1.35; font-weight:600; color:var(--primary); border-left:3px solid var(--beige); padding-left:26px;}
@media(max-width:860px){.manifest{grid-template-columns:1fr; gap:28px;} .manifest__aside{padding-left:20px;}}

/* emotional hook (inverted) */
.hook{background:var(--ink); color:#ECE8DD; border-radius:24px; padding:clamp(44px,6vw,80px) clamp(28px,5vw,72px); text-align:center;}
.hook .eyebrow{color:var(--beige);}
.hook__q{max-width:880px; margin:0 auto; display:grid; gap:clamp(22px,3vw,34px);}
.hook__q p{font-size:clamp(22px,2.9vw,34px); line-height:1.3; font-weight:600; color:#fff; margin:0;}
.hook__q p span{color:var(--beige);}

/* chips */
.chips{display:flex; flex-wrap:wrap; gap:14px; margin-top:8px;}
.chip{display:flex; align-items:center; gap:12px; padding:16px 22px; background:#fff; border:1px solid var(--line); border-radius:var(--radius-pill); font-size:16px; color:#3a3a2c; box-shadow:var(--shadow-sm);}
.chip::before{content:""; flex:0 0 auto; width:9px; height:9px; border-radius:50%; background:var(--primary);}

/* timeline */
.timeline{position:relative; max-width:840px; margin:0 auto;}
.timeline::before{content:""; position:absolute; left:31px; top:8px; bottom:8px; width:2px; background:linear-gradient(var(--beige), var(--line-warm));}
.tl-step{position:relative; display:grid; grid-template-columns:64px 1fr; gap:26px; padding-bottom:44px;}
.tl-step:last-child{padding-bottom:0;}
.tl-step__num{position:relative; z-index:2; width:64px; height:64px; border-radius:50%; background:var(--primary); color:#fff; display:grid; place-items:center; font-size:20px; font-weight:600; box-shadow:0 0 0 6px var(--bg-warm);}
.tl-step__body h3{font-size:20px; margin:8px 0 10px;}
.tl-step__body p{font-size:16px; color:#45453a; margin:0;}
.tl-note{display:flex; gap:14px; align-items:flex-start; max-width:840px; margin:8px auto 0; padding:20px 24px; background:#fff; border:1px dashed var(--line-warm); border-radius:14px; font-size:15.5px; color:#55554a; font-style:italic;}
.tl-note b{font-style:normal;}
@media(max-width:620px){
  .timeline::before{left:23px;}
  .tl-step{grid-template-columns:48px 1fr; gap:18px;}
  .tl-step__num{width:48px; height:48px; font-size:17px;}
}

/* checklist cards */
.checklist{display:grid; grid-template-columns:1fr 1fr; gap:16px;}
.check-card{display:flex; gap:16px; align-items:flex-start; padding:24px 26px; background:#fff; border:1px solid var(--line); border-radius:14px; box-shadow:var(--shadow-sm);}
.check-card__ic{flex:0 0 auto; width:30px; height:30px; border-radius:50%; background:var(--bg-warm); display:grid; place-items:center;}
.check-card p{font-size:16px; margin:0; color:#3a3a2c;}
@media(max-width:760px){.checklist{grid-template-columns:1fr;}}

/* mint notification */
.mint{display:flex; gap:14px; align-items:flex-start; padding:18px 22px; background:#EAF3EE; border:1px solid #CDE5D8; border-radius:12px; color:#1d5341; font-size:15.5px; margin-top:22px;}
.mint b{flex:0 0 auto; margin-top:1px;}

/* review screenshot gallery (masonry columns) */
.shot-gallery{columns:3; column-gap:20px;}
.shot-gallery .shot{break-inside:avoid; margin-bottom:20px; background:#fff; border:1px solid var(--line); border-radius:12px; padding:8px; box-shadow:var(--shadow-sm); cursor:zoom-in;}
.shot-gallery .shot img{width:100%; border-radius:8px; display:block;}
@media(max-width:900px){.shot-gallery{columns:2;}}
@media(max-width:560px){.shot-gallery{columns:1;}}
