/* ============================================================
   CHD Hypnotherapy — peacock-light.css
   A calm, light, peacock-accented system. Shared by every page.
   ============================================================ */

/* ---------- Brand font (self-hosted) ---------- */
/* Lexend: calm, highly legible sans, used for everything. Variable weight 300–600. */
@font-face{
  font-family:"Lexend";
  src:url("/assets/fonts/lexend-variable.woff2") format("woff2");
  font-weight:300 600; font-style:normal; font-display:swap;
}

/* ---------- Design tokens ---------- */
:root{
  /* Peacock accent palette (accents only — never large fills) */
  --teal:#0f6b6b;          /* primary: headings, links */
  --deep:#0b2e39;          /* secondary headings */
  --turq:#2aa6a1;          /* highlight */
  --bright-teal:#40c6c0;   /* hover / highlight */
  --royal:#1f3f8f;         /* sparing accent */
  --purple:#4b2e83;        /* sparing accent */
  --gold:#caa94b;          /* CTA buttons + hairline borders only */
  --gold-deep:#a8862f;     /* gold text on light, for AA */

  /* Light, restful canvas */
  --paper:#f1f6f7;         /* soft paper */
  --paper-2:#e9f1f1;       /* slightly deeper paper for banding */
  --white:#ffffff;
  --tint:#f7fbfb;          /* pale teal-tinted white (cards) */
  --ink:#071016;           /* deep ink body text */
  --ink-soft:#33474e;      /* muted body text */
  --ink-faint:#5c6f75;     /* captions / meta */
  --line:#dbe7e7;          /* hairline dividers */

  /* Soft peacock gradient — number badges / accent fills (kept deep for AA on white text) */
  --grad-peacock:linear-gradient(125deg,#0d6b6b 0%,#125f86 50%,#1f3f8f 100%);
  /* Vivid peacock gradient — light-background accents only (hero heading, dividers) */
  --grad-peacock-vivid:linear-gradient(120deg,#0f6b6b 0%,#1f9b95 34%,#2360a8 68%,#1f3f8f 100%);
  /* Deep peacock feature band — the single full-depth moment */
  --grad-band:linear-gradient(135deg,#0a2c37 0%,#0d5054 38%,#123158 78%,#1a3a7d 100%);
  --grad-glow:radial-gradient(60% 60% at 70% 20%,rgba(64,198,192,.20),transparent 70%);

  /* Form */
  --radius-lg:22px;
  --radius:16px;
  --radius-sm:11px;
  --shadow-sm:0 1px 2px rgba(11,46,57,.04), 0 2px 8px rgba(11,46,57,.05);
  --shadow:0 6px 24px rgba(11,46,57,.07), 0 2px 6px rgba(11,46,57,.04);
  --shadow-lg:0 18px 50px rgba(11,46,57,.10), 0 6px 16px rgba(11,46,57,.06);

  /* Rhythm */
  --maxw:1140px;
  --measure:64ch;
  --gut:clamp(20px,5vw,40px);
  --section:clamp(64px,9vw,118px);

  --font:"Lexend",-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;
  font-family:var(--font);
  font-weight:300;
  font-size:clamp(17px,1.05vw + 14px,19px);
  line-height:1.75;
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:var(--teal);text-decoration:none;transition:color .2s ease}
a:hover{color:var(--bright-teal)}
h1,h2,h3,h4{line-height:1.18;font-weight:500;color:var(--deep);margin:0 0 .5em;letter-spacing:-.01em;text-wrap:balance}
p{margin:0 0 1.1em}
ul,ol{margin:0 0 1.1em;padding-left:1.2em}
li{margin:.35em 0}
li::marker{color:var(--teal)}
strong{font-weight:600;color:var(--deep)}

/* ---------- Accessibility ---------- */
.skip-link{
  position:absolute;left:14px;top:-60px;z-index:200;
  background:var(--deep);color:#fff;padding:12px 18px;border-radius:10px;
  font-size:.95rem;transition:top .2s ease;
}
.skip-link:focus{top:14px;color:#fff}
:focus-visible{outline:3px solid var(--turq);outline-offset:3px;border-radius:6px}

/* ---------- Layout helpers ---------- */
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut)}
.narrow{max-width:760px}
.measure{max-width:var(--measure)}
.section{padding-block:var(--section)}
.section--tint{background:var(--paper-2)}
.center{text-align:center}
.stack > * + *{margin-top:1.1em}

.eyebrow{
  display:inline-flex;align-items:center;gap:.55em;
  font-size:.8rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--teal);margin:0 0 1.1em;
}
.eyebrow::before{content:"";width:30px;height:2px;background:linear-gradient(90deg,var(--teal),var(--gold));border-radius:2px}
.center .eyebrow::before{display:none}

h1{font-size:clamp(2.15rem,5.2vw,3.5rem);font-weight:600;letter-spacing:-.02em}
h2{font-size:clamp(1.62rem,3.4vw,2.45rem);font-weight:500}
h3{font-size:clamp(1.18rem,1.6vw,1.4rem);font-weight:600}
.lead{font-size:clamp(1.12rem,1.4vw,1.32rem);line-height:1.7;color:var(--ink-soft);font-weight:300}
.muted{color:var(--ink-faint)}
.gradient-text{
  background:var(--grad-peacock-vivid);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:var(--teal);
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:var(--font);font-size:1rem;font-weight:500;line-height:1;
  padding:.95em 1.5em;border-radius:999px;border:1.5px solid transparent;
  cursor:pointer;transition:transform .2s ease,background .2s ease,box-shadow .2s ease,color .2s ease;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px)}
.btn--gold{
  background:linear-gradient(165deg,#e2c977 0%,#caa94b 50%,#b3902f 100%);
  color:var(--deep);
  box-shadow:0 6px 18px rgba(168,134,47,.36),inset 0 1px 0 rgba(255,255,255,.40);
}
.btn--gold:hover{
  background:linear-gradient(165deg,#eed68a 0%,#d6b657 50%,#bf9a37 100%);
  color:var(--deep);
  box-shadow:0 12px 30px rgba(168,134,47,.46),inset 0 1px 0 rgba(255,255,255,.52);
}
.btn--teal{background:var(--teal);color:#fff}
.btn--teal:hover{background:#0d7a78;color:#fff}
.btn--ghost{background:transparent;color:var(--teal);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--turq);color:var(--teal);background:var(--tint)}
.btn--lg{padding:1.1em 1.9em;font-size:1.05rem}
.btn svg{width:1.05em;height:1.05em;flex:none}

.link-arrow{display:inline-flex;align-items:center;gap:.4em;font-weight:500;color:var(--teal)}
.link-arrow svg{width:1em;height:1em;transition:transform .2s ease}
.link-arrow:hover svg{transform:translateX(4px)}

/* ============================================================
   HEADER / NAV
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(241,246,247,.82);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--line);
}
.site-header__inner{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  min-height:74px;
}
.brand{display:inline-flex;align-items:center;gap:.7rem;color:var(--deep)}
.brand:hover{color:var(--deep)}
.brand__mark{width:44px;height:44px;flex:none}
.brand__text{display:flex;flex-direction:column;line-height:1.05}
.brand__name{font-weight:600;font-size:1.02rem;letter-spacing:-.01em;color:var(--deep);white-space:nowrap}
.brand__role{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--teal);font-weight:500}

.nav{display:flex;align-items:center;gap:.2rem}
.nav__list{display:flex;align-items:center;gap:.1rem;list-style:none;margin:0;padding:0}
.nav__link{
  display:inline-block;padding:.55em .8em;border-radius:9px;
  font-size:.96rem;font-weight:400;color:var(--ink-soft);
}
.nav__link:hover{color:var(--teal);background:var(--tint)}
.nav__link[aria-current="page"]{color:var(--teal);font-weight:600;position:relative}
.nav__link[aria-current="page"]::after{
  content:"";position:absolute;left:.8em;right:.8em;bottom:.34em;height:2px;border-radius:2px;
  background:linear-gradient(90deg,var(--teal),var(--gold));
}
.nav__cta{margin-left:.6rem}

.nav-toggle{
  display:none;align-items:center;justify-content:center;
  width:46px;height:46px;border:1px solid var(--line);border-radius:12px;
  background:var(--white);cursor:pointer;color:var(--deep);
}
.nav-toggle svg{width:22px;height:22px}
.nav-toggle .icon-close{display:none}
.nav-toggle[aria-expanded="true"] .icon-open{display:none}
.nav-toggle[aria-expanded="true"] .icon-close{display:block}

@media (max-width:1120px){
  .nav-toggle{display:inline-flex}
  .nav{
    position:fixed;inset:74px 0 auto 0;
    background:rgba(241,246,247,.97);
    backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
    border-bottom:1px solid var(--line);
    flex-direction:column;align-items:stretch;gap:0;
    padding:.6rem var(--gut) 1.6rem;
    transform:translateY(-12px);opacity:0;visibility:hidden;
    transition:opacity .25s ease,transform .25s ease,visibility .25s;
    max-height:calc(100vh - 74px);overflow:auto;
  }
  .nav.is-open{transform:translateY(0);opacity:1;visibility:visible}
  .nav__list{flex-direction:column;align-items:stretch;gap:0;width:100%}
  .nav__link{padding:.95em .4em;border-radius:0;border-bottom:1px solid var(--line);font-size:1.08rem}
  .nav__link[aria-current="page"]{background:transparent}
  .nav__link[aria-current="page"]::after{display:none}
  .nav__cta{margin:1.1rem 0 0;width:100%}
  .nav__cta .btn{width:100%}
}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;overflow:hidden;padding-block:clamp(56px,8vw,104px) var(--section)}
.hero::before{content:"";position:absolute;inset:0;background:var(--grad-glow);pointer-events:none}
.hero__inner{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,68px);align-items:center}
.hero__copy{max-width:42ch}
.hero h1{margin-bottom:.4em}
.hero .lead{margin-bottom:1.7em}
.hero__actions{display:flex;flex-wrap:wrap;gap:.8rem}
.hero__reassure{margin-top:1.8rem;font-size:.95rem;color:var(--ink-faint);display:flex;align-items:center;gap:.6em}
.hero__reassure svg{width:1.1em;height:1.1em;color:var(--teal);flex:none}

.hero--center .hero__inner{grid-template-columns:1fr;justify-items:center;text-align:center}
.hero--center .hero__copy{max-width:56ch}
.hero--center .hero__actions{justify-content:center}
.hero--center .hero__reassure{justify-content:center}

@media (max-width:860px){
  .hero__inner{grid-template-columns:1fr;text-align:center;justify-items:center}
  .hero__copy{max-width:54ch}
  .hero__actions{justify-content:center}
  .hero__reassure{justify-content:center}
  .hero__media{width:100%;max-width:520px}
}

/* Page hero (interior pages) */
.pagehero{position:relative;overflow:hidden;padding-block:clamp(52px,7vw,92px) clamp(40px,5vw,64px)}
.pagehero::before{content:"";position:absolute;inset:0;background:var(--grad-glow);pointer-events:none}
.pagehero__inner{position:relative;max-width:56ch}
.pagehero--center .pagehero__inner{margin-inline:auto;text-align:center}
.pagehero h1{margin-bottom:.35em}

/* ============================================================
   PHOTO PLACEHOLDERS
   ============================================================ */
.photo{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  background:
    linear-gradient(135deg,rgba(15,107,107,.10),rgba(31,63,143,.10)),
    var(--paper-2);
  border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  min-height:320px;color:var(--teal);
}
.photo__label{
  display:flex;flex-direction:column;align-items:center;gap:.7rem;text-align:center;
  padding:1.5rem;color:var(--ink-faint);
}
.photo__label svg{width:34px;height:34px;color:var(--turq);opacity:.85}
.photo__label span{font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;font-weight:500}
.photo__label em{font-style:normal;font-size:.92rem;color:var(--ink-faint);max-width:24ch;line-height:1.5}
.photo__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.photo--tall{min-height:440px}
.photo--wide{min-height:300px;aspect-ratio:16/10}
.photo--round{border-radius:50%;aspect-ratio:1;min-height:0}

.hero__media{position:relative}
.hero__media .photo{min-height:clamp(320px,42vw,460px)}
.hero__media .badge{
  position:absolute;left:-14px;bottom:22px;
  background:var(--white);border:1px solid var(--line);border-radius:16px;
  box-shadow:var(--shadow);padding:.85rem 1.1rem;display:flex;align-items:center;gap:.7rem;
}
.hero__media .badge svg{width:22px;height:22px;color:var(--gold-deep)}
.hero__media .badge span{font-size:.86rem;line-height:1.3;color:var(--ink-soft)}
.hero__media .badge strong{display:block;color:var(--deep)}

/* ============================================================
   CARDS
   ============================================================ */
.grid{display:grid;gap:clamp(18px,2.4vw,26px)}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}
@media (max-width:880px){.grid--3,.grid--4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.grid--2,.grid--3,.grid--4{grid-template-columns:1fr}}

.card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(22px,2.6vw,32px);box-shadow:var(--shadow-sm);
  transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
  display:flex;flex-direction:column;
}
.card--link:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:#cfe0e0}
.card h3{margin-bottom:.45em}
.card p{color:var(--ink-soft);font-size:.98rem}
.card .link-arrow{margin-top:auto;padding-top:.6em}

.card__icon{
  width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;
  margin-bottom:1.1rem;background:linear-gradient(140deg,rgba(15,107,107,.18),rgba(42,166,161,.10));color:var(--teal);
}
.card__icon svg{width:26px;height:26px}
.card__icon--royal{background:linear-gradient(140deg,rgba(31,63,143,.18),rgba(31,63,143,.08));color:var(--royal)}
.card__icon--purple{background:linear-gradient(140deg,rgba(75,46,131,.18),rgba(75,46,131,.08));color:var(--purple)}
.card__icon--gold{background:linear-gradient(140deg,rgba(202,169,75,.24),rgba(202,169,75,.12));color:var(--gold-deep)}

/* Soft feature panel (rounded, light) */
.panel{
  background:var(--tint);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(26px,4vw,52px);
}
.panel--white{background:var(--white);box-shadow:var(--shadow)}

/* ---------- Trust strip ---------- */
.trust{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:center;
  gap:clamp(1.2rem,4vw,3.2rem);padding-block:1.4rem;
}
.trust__item{display:flex;align-items:center;gap:.65rem;color:var(--ink-soft);font-size:.96rem}
.trust__item svg{width:22px;height:22px;color:var(--teal);flex:none}
.trust__item strong{color:var(--deep);font-weight:600}

/* ---------- Two-column split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center}
.split--media-first .split__media{order:-1}
@media (max-width:860px){
  .split{grid-template-columns:1fr;gap:clamp(26px,5vw,40px)}
  .split--media-first .split__media{order:0}
}

/* ---------- Steps (3-stage method) ---------- */
.steps{display:grid;gap:clamp(16px,2.2vw,22px);counter-reset:step}
.step{
  display:grid;grid-template-columns:auto 1fr;gap:1.2rem;align-items:start;
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(20px,2.6vw,28px);box-shadow:var(--shadow-sm);
}
.step__num{
  width:46px;height:46px;border-radius:50%;flex:none;
  display:flex;align-items:center;justify-content:center;
  font-weight:600;font-size:1.05rem;color:#fff;background:var(--grad-peacock);
}
.step h3{margin-bottom:.3em}
.step p{color:var(--ink-soft);margin-bottom:0}
.step__q{color:var(--teal);font-weight:500;font-style:italic}

/* ---------- Checklist ---------- */
.checks{list-style:none;padding:0;margin:0;display:grid;gap:.75rem}
.checks li{display:grid;grid-template-columns:auto 1fr;gap:.75rem;align-items:start;margin:0;color:var(--ink-soft)}
.checks svg{width:22px;height:22px;color:var(--teal);margin-top:.18em;flex:none}

/* ---------- Testimonials ---------- */
.quote{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(24px,3vw,34px);box-shadow:var(--shadow-sm);position:relative;
  display:flex;flex-direction:column;
}
.quote__mark{font-size:3rem;line-height:.6;color:var(--gold-deep);font-weight:600;margin-bottom:.2em;font-family:Georgia,serif}
.quote__mark--close{align-self:flex-end;margin-top:.35em;margin-bottom:0;line-height:0}
.quote p{color:var(--ink);font-size:1.02rem;font-weight:300}
.quote p + p{margin-top:.85em}

/* Featured testimonial (full width across the top) */
.quote--feature{background:var(--tint);text-align:center;margin-bottom:clamp(18px,2.4vw,26px)}
.quote--feature p{max-width:64ch;margin-inline:auto;text-align:left}
.quote--feature .quote__who{text-align:center}
.quote--feature .quote__mark--close{align-self:center;margin-top:.2em}
.quote__who{margin-top:auto;padding-top:1rem;font-size:.9rem;color:var(--ink-faint);font-weight:500}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;background:var(--paper-2)}
.cta-band::before{content:"";position:absolute;inset:0;background:var(--grad-glow)}
.cta-band__inner{position:relative;text-align:center;max-width:60ch;margin-inline:auto}
.cta-band h2{margin-bottom:.4em}
.cta-band .hero__actions{justify-content:center;margin-top:1.6rem}

/* ============================================================
   FORMS
   ============================================================ */
.form{display:grid;gap:1.15rem}
.field{display:grid;gap:.45rem}
.field label{font-weight:500;color:var(--deep);font-size:.96rem}
.field .hint{font-size:.84rem;color:var(--ink-faint);font-weight:300}
.field input,.field textarea,.field select{
  font-family:var(--font);font-size:1rem;color:var(--ink);
  padding:.85em 1em;border:1.5px solid var(--line);border-radius:12px;
  background:var(--white);transition:border-color .2s ease,box-shadow .2s ease;width:100%;
}
.field textarea{min-height:140px;resize:vertical}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--turq);box-shadow:0 0 0 4px rgba(42,166,161,.14)
}
.field--row{display:grid;grid-template-columns:1fr 1fr;gap:1.15rem}
@media (max-width:600px){.field--row{grid-template-columns:1fr}}
.form__note{font-size:.85rem;color:var(--ink-faint)}
.form__success{
  display:none;background:rgba(42,166,161,.10);border:1px solid var(--turq);
  border-radius:14px;padding:1.1rem 1.3rem;color:var(--deep);
}
.form__success.is-visible{display:block}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--grad-band);color:#cfe0e2;padding-block:clamp(48px,6vw,72px) 2rem;margin-top:0}
.site-footer a{color:#dbe9ea}
.site-footer a:hover{color:var(--bright-teal)}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:clamp(28px,5vw,56px)}
@media (max-width:760px){.footer__grid{grid-template-columns:1fr;gap:34px}}
.footer__brand .brand__name{color:#fff}
.footer__brand .brand__role{color:var(--bright-teal)}
.footer__brand p{color:#aecdd0;font-size:.95rem;max-width:34ch;margin-top:1rem}
.footer__col h4{color:#fff;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:1rem}
.footer__col ul{list-style:none;padding:0;margin:0;display:grid;gap:.6rem}
.footer__col li{margin:0}
.footer__col a{font-size:.96rem;color:#bcd6d8}
.footer__contact{font-style:normal;color:#bcd6d8;font-size:.96rem;line-height:1.8}
.footer__contact a{display:inline}
.memberships{display:flex;align-items:center;gap:1.6rem;margin-top:1.4rem;flex-wrap:wrap}
.member-logo{display:block;opacity:.82;transition:opacity .25s ease}
.member-logo:hover,.member-logo:focus-visible{opacity:1}
.member-logo img{display:block;height:36px;width:auto}
.member-logo--square img{height:56px}
.footer__feather{width:20px;height:20px;color:var(--bright-teal)}
.footer__bottom{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;
  border-top:1px solid rgba(255,255,255,.12);margin-top:clamp(34px,5vw,52px);padding-top:1.6rem;
  font-size:.85rem;color:#a6c6c9;
}
.footer__bottom nav{display:flex;flex-wrap:wrap;gap:1.2rem}
.footer__bottom a{color:#aecdd0}

/* ============================================================
   GENTLE REVEALS
   ============================================================ */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .7s ease,transform .7s ease}
.reveal.is-in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}
.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}
.reveal.d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
}

/* ---------- Misc ---------- */
.divider{height:1px;background:linear-gradient(90deg,transparent,var(--line) 14%,rgba(15,107,107,.38) 50%,var(--line) 86%,transparent);border:0;margin-block:var(--section)}
.tag{
  display:inline-flex;align-items:center;gap:.4em;font-size:.82rem;font-weight:500;
  padding:.35em .8em;border-radius:999px;background:var(--tint);
  border:1px solid var(--line);color:var(--teal);
}
.tag svg{width:.95em;height:.95em}
.note-card{
  background:var(--white);border:1px solid var(--line);border-left:3px solid var(--gold);
  border-radius:var(--radius);padding:clamp(20px,2.6vw,28px);box-shadow:var(--shadow-sm);
}
.map-embed{
  width:100%;min-height:340px;border:1px solid var(--line);border-radius:var(--radius-lg);
  background:var(--paper-2);overflow:hidden;
}
.map-embed iframe{width:100%;height:100%;min-height:340px;border:0;display:block}

/* ---------- Smoking cost calculator ---------- */
.calc-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(24px,4vw,48px);align-items:start}
@media (max-width:860px){.calc-grid{grid-template-columns:1fr}}
.calc-inputs{display:grid;gap:1.15rem}
.calc-value{font-weight:600;color:var(--teal)}
.calc-inputs input[type="range"]{
  width:100%;height:6px;border-radius:3px;appearance:none;-webkit-appearance:none;
  background:linear-gradient(90deg,var(--teal),var(--turq));outline-offset:4px;cursor:pointer;
}
.calc-inputs input[type="range"]::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;width:22px;height:22px;border-radius:50%;
  background:var(--white);border:3px solid var(--teal);box-shadow:var(--shadow-sm);
}
.calc-inputs input[type="range"]::-moz-range-thumb{
  width:16px;height:16px;border-radius:50%;
  background:var(--white);border:3px solid var(--teal);box-shadow:var(--shadow-sm);
}
.calc-results{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(12px,1.8vw,18px)}
@media (max-width:480px){.calc-results{grid-template-columns:1fr}}
.calc-card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.1rem 1.2rem;box-shadow:var(--shadow-sm);text-align:center;
}
.calc-card h3{font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);font-weight:500;margin-bottom:.3em}
.calc-number{font-size:clamp(1.4rem,2.4vw,1.8rem);font-weight:600;color:var(--teal);margin:0}
.calc-card-wide{grid-column:1 / -1}
.calc-card-warning{border-color:var(--gold);background:var(--tint)}
.calc-card-warning .calc-number{color:var(--gold-deep)}
.calc-disclaimer{font-size:.85rem;color:var(--ink-faint);margin-top:1.2rem}

.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,24px)}
@media (max-width:880px){.price-grid{grid-template-columns:1fr}}
.price{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(26px,3vw,36px);box-shadow:var(--shadow-sm);text-align:center;
  display:flex;flex-direction:column;gap:.4rem;
}
.price--feature{border-color:var(--gold);box-shadow:var(--shadow)}
.price__amount{font-size:clamp(2.2rem,4vw,2.9rem);font-weight:600;color:var(--teal);line-height:1}
.price__amount span{font-size:1rem;font-weight:400;color:var(--ink-faint)}
.price h3{margin:.2em 0}
.price p{color:var(--ink-soft);font-size:.95rem;margin-bottom:.4em}

/* ============================================================
   Richer peacock background wash (site-wide, June 2026)
   A soft gradient over the paper base, plus a stronger glow on
   hero / page-hero sections. Tinted sections keep their banding.
   ============================================================ */
body{
  background:
    radial-gradient(120% 78% at 88% -6%, rgba(31,155,149,.18), transparent 58%),
    radial-gradient(95% 70% at -5% 6%, rgba(35,96,168,.13), transparent 55%),
    var(--paper);
  background-attachment:fixed;
}
.hero::before,
.pagehero::before{
  background:
    radial-gradient(58% 60% at 72% 16%, rgba(64,198,192,.32), transparent 70%),
    radial-gradient(42% 52% at 10% 0%, rgba(31,63,143,.18), transparent 72%);
}
