/*
Theme Name: Primrose Rehab and Wellness
Theme URI: https://primroserehab.org
Author: Primrose Rehab and Wellness
Description: Custom plugin-minimal theme for Primrose Rehab and Wellness. Elementor-ready body, theme-owned header, footer, and form shortcodes that persist to custom DB tables.
Version: 1.0.36
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: primrose-rehab
*/

/* ---------- tokens ---------- */
:root{
  --teal:#0F6E56;
  --teal-dark:#0A4D3D;
  --teal-darker:#063A2E;
  --mint:#E1F5EE;
  --amber:#BA7517;
  --amber-light:#FAEEDA;
  --ink:#1F1F1D;
  --ink-2:#5F5E5A;
  --bg:#FFFFFF;
  --cream:#EEF6F1;
  --border:#D9D5CB;
  --serif:'DM Serif Display', Georgia, 'Times New Roman', serif;
  --sans:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --maxw:1180px;
  --readw:680px;
  --r-card:12px;
  --r-btn:8px;
  --shadow-card:0 2px 6px rgba(0,0,0,0.06);

  /* Elementor global typography variables — override its "Roboto" fallback.
   * Elementor widgets use var(--e-global-typography-*-font-family, "Roboto").
   * With Default Fonts disabled, the var is unset and Roboto wins. Defining
   * the variables here makes every widget resolve to our brand fonts. */
  --e-global-typography-primary-font-family:'DM Serif Display';
  --e-global-typography-primary-font-weight:700;
  --e-global-typography-secondary-font-family:'DM Serif Display';
  --e-global-typography-secondary-font-weight:700;
  --e-global-typography-text-font-family:'Inter';
  --e-global-typography-text-font-weight:400;
  --e-global-typography-accent-font-family:'Inter';
  --e-global-typography-accent-font-weight:500;
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--bg);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img,svg{display:block;max-width:100%}
a{color:var(--teal);text-decoration:none}
a:hover{text-decoration:underline}
button{font-family:inherit}

a:focus-visible,button:focus-visible,summary:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{
  outline:2px solid var(--teal);
  outline-offset:3px;
  border-radius:4px;
}

h1,h2,h3,h4{font-family:var(--serif);font-weight:700;color:var(--ink);line-height:1.15;margin:0}
h1{font-size:clamp(36px,5vw,52px);letter-spacing:-0.01em;line-height:1.1}
h2{font-size:clamp(28px,3.4vw,36px);letter-spacing:-0.005em;line-height:1.2}
h3{font-size:22px;line-height:1.3}
h4{font-size:18px;line-height:1.3}
p{margin:0}

/* Elementor heading widget — force our typography. Elementor's per-page
 * generated CSS uses .elementor-{post} .elementor-element selectors, which
 * are higher specificity than .elementor-widget-heading alone — so the only
 * reliable hammer here is !important. */
.elementor-widget-heading .elementor-heading-title,
.elementor-widget-heading h1.elementor-heading-title,
.elementor-widget-heading h2.elementor-heading-title,
.elementor-widget-heading h3.elementor-heading-title,
.elementor-widget-heading h4.elementor-heading-title,
.elementor-widget-heading h5.elementor-heading-title,
.elementor-widget-heading h6.elementor-heading-title,
.elementor-widget-heading div.elementor-heading-title,
.elementor-widget-heading span.elementor-heading-title,
.elementor-widget-heading p.elementor-heading-title{
  font-family:var(--serif) !important;
  font-weight:700;
  color:var(--ink);
  line-height:1.15;
  margin:0;
}
body.elementor-page,
body.elementor-page .elementor-widget,
body.elementor-page .elementor-widget-text-editor,
body.elementor-page .elementor-widget-text-editor p,
body.elementor-page .elementor-widget-button .elementor-button{
  font-family:var(--sans) !important;
}

/* Make button icons inherit the button text color so the WhatsApp/phone icons
 * appear in teal/white as the variant expects, instead of Elementor's defaults. */
.elementor-widget-button .elementor-button .elementor-button-icon,
.elementor-widget-button .elementor-button .elementor-button-icon i,
.elementor-widget-button .elementor-button .elementor-button-icon svg{
  color:inherit;
  fill:currentColor;
}
.elementor-widget-heading.eyebrow .elementor-heading-title,
.elementor-widget-heading .elementor-heading-title.eyebrow{
  font-family:var(--sans);
  font-size:13px;
  font-weight:600;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--amber);
}
.elementor-widget-heading.stat__n .elementor-heading-title{font-family:var(--serif);font-size:36px;color:var(--teal);line-height:1;margin-bottom:0}
.elementor-widget-heading.post__title .elementor-heading-title{font-family:var(--serif);font-size:20px;color:var(--ink);line-height:1.25}
.elementor-widget-heading.post__title .elementor-heading-title a{color:var(--ink)}
.elementor-widget-heading.post__title .elementor-heading-title a:hover{color:var(--teal);text-decoration:none}
.elementor-widget-text-editor{font-family:var(--sans)}

.eyebrow{font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--amber);margin:0 0 16px}
.lead{font-size:18px;color:var(--ink-2);line-height:1.65;max-width:var(--readw)}
.muted{color:var(--ink-2)}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 28px;
  font-size:16px;font-weight:500;
  border-radius:var(--r-btn);
  border:1.5px solid transparent;
  cursor:pointer;
  transition:background .15s ease,color .15s ease,border-color .15s ease;
  line-height:1;
  white-space:nowrap;
}
.btn--primary{background:var(--teal);color:#fff;border-color:var(--teal)}
.btn--primary:hover{background:var(--teal-dark);border-color:var(--teal-dark);text-decoration:none;color:#fff}
.btn--secondary{background:#fff;color:var(--teal);border-color:var(--teal)}
.btn--secondary:hover{background:var(--mint);text-decoration:none;color:var(--teal)}
.btn--on-dark{background:#fff;color:var(--teal-dark);border-color:#fff}
.btn--on-dark:hover{background:var(--mint);border-color:var(--mint);text-decoration:none;color:var(--teal-dark)}
.btn--outline-on-dark{background:transparent;color:#fff;border-color:#fff}
.btn--outline-on-dark:hover{background:#fff;color:var(--teal-dark);text-decoration:none}
.btn--block{width:100%;justify-content:center}
.btn--sm{padding:10px 18px;font-size:14px}

/* ---------- Elementor button widget compatibility ----------
 * When .btn / .btn--primary etc. are applied to an Elementor button widget,
 * the class lands on the outer .elementor-widget div, not the inner <a>.
 * Pipe the styles through to the actual <a class="elementor-button"> and
 * neutralise Elementor's default gray fill on the wrapper.
 */
.elementor-widget-button.btn,
.elementor-widget-button[class*="btn--"]{
  background:transparent !important;
  border:0 !important;
  padding:0 !important;
  border-radius:0 !important;
}
.elementor-widget-button.btn .elementor-button,
.elementor-widget-button[class*="btn--"] .elementor-button{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 28px;
  font-size:16px;font-weight:500;
  line-height:1;
  border-radius:var(--r-btn);
  border:1.5px solid transparent;
  background:transparent;
  text-decoration:none;
  transition:background .15s ease,color .15s ease,border-color .15s ease;
}
.elementor-widget-button.btn--primary .elementor-button{background:var(--teal);color:#fff;border-color:var(--teal)}
.elementor-widget-button.btn--primary .elementor-button:hover{background:var(--teal-dark);border-color:var(--teal-dark);color:#fff}
.elementor-widget-button.btn--secondary .elementor-button{background:#fff;color:var(--teal);border-color:var(--teal)}
.elementor-widget-button.btn--secondary .elementor-button:hover{background:var(--mint);color:var(--teal)}
.elementor-widget-button.btn--on-dark .elementor-button{background:#fff;color:var(--teal-dark);border-color:#fff}
.elementor-widget-button.btn--on-dark .elementor-button:hover{background:var(--mint);border-color:var(--mint);color:var(--teal-dark)}
.elementor-widget-button.btn--outline-on-dark .elementor-button{background:transparent;color:#fff;border-color:#fff}
.elementor-widget-button.btn--outline-on-dark .elementor-button:hover{background:#fff;color:var(--teal-dark)}
/* Hero CTAs — force buttons left-aligned within their columns */
.hero__ctas .elementor-button-wrapper{text-align:left}
.hero__ctas .elementor-widget-button{width:auto}
.hero__ctas .elementor-widget-wrap{align-content:flex-start;justify-content:flex-start}

.elementor-widget-button.card__more,
.elementor-widget-button.post__more{background:transparent !important}
.elementor-widget-button.card__more .elementor-button,
.elementor-widget-button.post__more .elementor-button{
  background:transparent;color:var(--teal);border:0;padding:0;
  font-weight:500;font-size:15px;
}
.elementor-widget-button.card__more .elementor-button:hover,
.elementor-widget-button.post__more .elementor-button:hover{background:transparent;color:var(--teal-dark)}

/* skip link */
.skip{position:absolute;left:-999px;top:0;background:var(--teal);color:#fff;padding:10px 16px;border-radius:0 0 8px 0;z-index:100}
.skip:focus{left:0}

/* ---------- utility bar ---------- */
.ubar{background:var(--teal);color:#fff;font-size:14px}
.ubar__inner{display:flex;justify-content:space-between;align-items:center;height:40px;gap:16px}
.ubar a{color:#fff;display:inline-flex;align-items:center;gap:8px;font-weight:500}
.ubar a:hover{text-decoration:underline}
@media (max-width:720px){ .ubar{display:none} }

/* ---------- header ---------- */
.hdr{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--border)}
.hdr__inner{display:flex;align-items:center;justify-content:space-between;gap:24px;height:100px}
.logo{display:flex;flex-direction:column;line-height:1;text-decoration:none;color:var(--ink)}
.logo:hover{text-decoration:none}
.logo__mark{font-family:var(--serif);font-size:26px;color:var(--teal);letter-spacing:-0.01em}
.logo__sub{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-2);margin-top:4px}
.custom-logo-link{display:inline-flex}
.custom-logo{max-height:100px;width:auto}

.nav{display:flex;align-items:center;gap:28px;list-style:none;margin:0;padding:0}
.nav li{position:relative}
.nav a{color:var(--ink);font-size:15px;font-weight:500;display:inline-block;padding:6px 0}
.nav a:hover{color:var(--teal);text-decoration:none}
.nav .current-menu-item > a,
.nav .current-menu-ancestor > a{color:var(--teal)}
.nav .sub-menu{
  position:absolute;top:100%;left:0;
  display:none;
  background:#fff;border:1px solid var(--border);border-radius:8px;
  padding:8px 0;min-width:220px;
  box-shadow:var(--shadow-card);
  list-style:none;margin:0;
}
.nav li:hover > .sub-menu,
.nav li:focus-within > .sub-menu{display:block}
.nav .sub-menu a{display:block;padding:8px 16px;font-size:14px}

.hdr__actions{display:flex;align-items:center;gap:8px}
.hdr__toggle{
  display:none;
  background:transparent;border:1px solid var(--border);
  width:40px;height:40px;border-radius:8px;
  align-items:center;justify-content:center;cursor:pointer;
}
.hdr__toggle svg{color:var(--ink)}

@media (max-width:980px){
  .hdr__cta .btn{padding:10px 16px;font-size:14px}
  .hdr__toggle{display:inline-flex}
  .nav{
    display:none;
    position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:stretch;
    background:#fff;border-bottom:1px solid var(--border);
    padding:12px 24px 20px;gap:0;
    box-shadow:var(--shadow-card);
  }
  .nav.is-open{display:flex}
  .nav li{border-bottom:1px solid var(--border)}
  .nav li:last-child{border-bottom:0}
  .nav a{padding:14px 0;display:block}
  .nav .sub-menu{position:static;display:block;border:0;box-shadow:none;padding:0 0 0 12px}
}
@media (max-width:720px){
  .hdr__inner{height:72px;gap:12px}
  .custom-logo{max-height:56px}
  .logo__mark{font-size:22px}
  .logo__sub{font-size:10px}
  .hdr__cta .btn span.label{display:none}
  .hdr__cta .btn{padding:10px;border-radius:999px}
}

/* ---------- breadcrumb (theme-rendered, every non-home page) ---------- */
.crumb{background:var(--cream);padding:16px 0;font-size:14px;color:var(--ink-2)}
.crumb .wrap{display:flex;align-items:center;flex-wrap:wrap;gap:6px;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.crumb a{color:var(--teal);font-weight:500}
.crumb a:hover{text-decoration:underline}
.crumb svg{color:var(--ink-2)}
.crumb [aria-current="page"]{color:var(--ink-2)}

/* ---------- main content area (Elementor renders inside .site-main) ---------- */
.site-main{min-height:40vh}
.entry-content{max-width:var(--maxw);margin:0 auto;padding:48px 24px}
.entry-content > * + *{margin-top:24px}

/* ---------- footer ---------- */
.ft{background:var(--teal-dark);color:#fff;padding:72px 0 0}
.ft a{color:#cfe6dd}
.ft a:hover{color:#fff}
.ft__grid{display:grid;grid-template-columns:1.3fr 1fr 1.2fr 1.1fr;gap:48px;padding-bottom:56px}
.ft h4{
  font-family:var(--sans);font-size:13px;font-weight:600;
  letter-spacing:0.12em;text-transform:uppercase;
  color:#a4cdbf;margin-bottom:18px;
}
.ft__col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;font-size:15px}
.ft__blurb{color:#cfe6dd;font-size:15px;line-height:1.6;margin:14px 0 20px;max-width:32ch}
.ft__social{display:flex;gap:10px}
.ft__social a{
  width:38px;height:38px;border-radius:999px;
  border:1px solid #2c6b58;background:var(--teal-dark);
  display:inline-flex;align-items:center;justify-content:center;color:#fff;
}
.ft__social a:hover{background:var(--teal);border-color:var(--teal)}
.ft__logo{display:flex;flex-direction:column;line-height:1}
.ft__logo .m{font-family:var(--serif);font-size:28px;color:#fff}
.ft__logo .s{font-size:11px;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;color:#a4cdbf;margin-top:6px}
.news{display:flex;flex-direction:column;gap:10px}
.news p{color:#cfe6dd;font-size:14px;line-height:1.5}
.news__form{display:flex;gap:8px;background:#fff;border-radius:8px;padding:4px;align-items:center}
.news__form input{
  flex:1;border:0;background:transparent;padding:10px 12px;font:inherit;font-size:14px;color:var(--ink);outline:none;
}
.news__form input::placeholder{color:var(--ink-2)}
.news__form button{
  background:var(--teal);color:#fff;border:0;border-radius:6px;padding:10px 16px;font-weight:500;font-size:14px;cursor:pointer;
}
.news__form button:hover{background:var(--teal-dark)}
.news__msg{font-size:13px;color:#cfe6dd;min-height:1em}
.news__msg.is-error{color:#ffd7c2}
.ft__contact{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px;font-size:15px;color:#cfe6dd}
.ft__contact li{display:flex;gap:10px;align-items:flex-start}
.ft__contact svg{color:#a4cdbf;flex-shrink:0;margin-top:3px}

.ft__bar{background:var(--teal-darker);padding:18px 0}
.ft__bar__inner{display:flex;justify-content:space-between;align-items:center;gap:16px;color:#cfe6dd;font-size:13px}
.ft__bar ul{list-style:none;margin:0;padding:0;display:flex;gap:20px}
@media (max-width:920px){
  .ft__grid{grid-template-columns:1fr 1fr;gap:40px}
}
@media (max-width:560px){
  .ft__grid{grid-template-columns:1fr}
  .ft__bar__inner{flex-direction:column;align-items:flex-start}
}

/* ---------- sticky WhatsApp ---------- */
.wa-stick{
  position:fixed;right:16px;bottom:16px;
  width:56px;height:56px;
  background:var(--teal);color:#fff;
  border-radius:999px;
  display:none;align-items:center;justify-content:center;
  z-index:80;
  box-shadow:0 4px 12px rgba(0,0,0,0.18);
  border:1px solid var(--teal-dark);
}
.wa-stick:hover{background:var(--teal-dark);text-decoration:none;color:#fff}
@media (max-width:720px){ .wa-stick{display:inline-flex} }

/* =========================================================================
 * Page sections — utility classes for Elementor body content.
 * Apply these classes via Elementor's "CSS Classes" field on Sections/Containers.
 * ====================================================================== */

/* Neutralise CSS Grid layout when row-grid utility classes are applied to
 * Elementor sections. Elementor sections wrap their columns inside
 * .elementor-container; setting display:grid on the section makes that
 * container the single grid item and collapses all columns to 1/Nth width.
 * The Elementor column system already provides the grid — let it. */
.elementor-section.hero__grid,
.elementor-section.about__grid,
.elementor-section.stats,
.elementor-section.trust__row,
.elementor-section.cards-3,
.elementor-section.ask__grid,
.elementor-section.blog__row,
.elementor-section.accred__row,
.elementor-section.map__grid,
.elementor-section.hero__ctas,
.elementor-section.finalcta__ctas{
  display:block !important;
  grid-template-columns:none !important;
  gap:0 !important;
}

/* Force visible gaps between card columns. Elementor saves _margin on a
 * column but emits it onto .elementor-element-populated; combined with the
 * inner wrap's width:100% and the card chrome painted on the populated
 * wrap, the margin produces no visible gap. Use flex-gap on the
 * .elementor-container instead — deterministic across renderers. */
.elementor-section.cards-3 > .elementor-container,
.elementor-section.blog__row > .elementor-container{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:24px !important;
}
.elementor-section.cards-3 > .elementor-container > .elementor-column,
.elementor-section.blog__row > .elementor-container > .elementor-column{
  flex:0 0 calc((100% - 48px) / 3) !important;
  max-width:calc((100% - 48px) / 3) !important;
  margin:0 !important;
  width:auto !important;
}
@media (max-width:820px){
  .elementor-section.cards-3 > .elementor-container > .elementor-column,
  .elementor-section.blog__row > .elementor-container > .elementor-column{
    flex:0 0 100% !important;
    max-width:100% !important;
  }
}

/* 5-card accreditations row — 4 gaps × 16px = 64px */
.elementor-section.accred__row > .elementor-container{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:16px !important;
}
.elementor-section.accred__row > .elementor-container > .elementor-column{
  flex:0 0 calc((100% - 64px) / 5) !important;
  max-width:calc((100% - 64px) / 5) !important;
  margin:0 !important;
  width:auto !important;
}
@media (max-width:980px){
  .elementor-section.accred__row > .elementor-container > .elementor-column{
    flex:0 0 calc((100% - 32px) / 3) !important;
    max-width:calc((100% - 32px) / 3) !important;
  }
}
@media (max-width:560px){
  .elementor-section.accred__row > .elementor-container > .elementor-column{
    flex:0 0 calc((100% - 16px) / 2) !important;
    max-width:calc((100% - 16px) / 2) !important;
  }
}


.pr-section{padding:80px 0}
@media (max-width:720px){ .pr-section{padding:56px 0} }

/* shared section heads */
.shead{margin-bottom:40px;max-width:var(--readw)}
.shead h2{margin-bottom:12px}
.shead p{font-size:18px;color:var(--ink-2)}
.shead--center{margin-left:auto;margin-right:auto;text-align:center}

/* ---------- hero ---------- */
.hero{background:var(--cream);padding:88px 0}
@media (max-width:720px){ .hero{padding:48px 0} }
.hero__grid{display:grid;grid-template-columns:1.15fr 1fr;gap:64px;align-items:center}
.hero__h1{margin:0 0 20px}
.elementor-widget-heading.hero__h1 .elementor-heading-title{
  font-size:clamp(36px,5vw,52px);
  letter-spacing:-0.01em;
  line-height:1.1;
  max-width:18ch;
}
.hero__sub{margin-bottom:32px}
.hero__ctas{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:18px}
.hero__trust{font-size:14px;color:var(--ink-2);display:flex;align-items:center;gap:8px}
.hero__img{aspect-ratio:4/5;border-radius:var(--r-card);overflow:hidden;background:var(--mint);border:1px solid var(--border)}
.hero__img img{width:100%;height:100%;object-fit:cover}
@media (max-width:920px){
  .hero__grid{grid-template-columns:1fr;gap:40px}
  .hero__img{aspect-ratio:16/11;max-height:420px}
}

/* ---------- trust bar ---------- */
.trust{background:var(--mint);padding:36px 0}
/* Brand-style icon-box widget when it has the .trust__item modifier */
.elementor-widget-icon-box.trust__item .elementor-icon-box-wrapper{
  text-align:center;
}
.elementor-widget-icon-box.trust__item .elementor-icon{
  background:transparent !important;
  color:var(--teal) !important;
  width:auto;height:auto;
  font-size:28px;
  padding:0;border:0;
}
.elementor-widget-icon-box.trust__item .elementor-icon i,
.elementor-widget-icon-box.trust__item .elementor-icon svg{color:var(--teal);fill:currentColor}
.elementor-widget-icon-box.trust__item .elementor-icon-box-title,
.elementor-widget-icon-box.trust__item .elementor-icon-box-title a{
  font-family:var(--sans) !important;
  font-size:14px !important;
  font-weight:600;
  color:var(--ink);
  line-height:1.25;
}
.elementor-widget-icon-box.trust__item .elementor-icon-box-title a:hover{color:var(--teal);text-decoration:none}
.elementor-widget-icon-box.trust__item .elementor-icon-box-description{
  font-size:12px;
  color:var(--ink-2);
  line-height:1.3;
}

/* Brand-style icon widget when it has the .card__icon modifier
 * (used in .cards-3 awareness cards and similar). Overrides Elementor's
 * default stacked-icon background/color which would otherwise render gray. */
.elementor-widget-icon.card__icon{text-align:left}
.elementor-widget-icon.card__icon .elementor-icon-wrapper{display:inline-block}
.elementor-widget-icon.card__icon .elementor-icon{
  background-color:var(--mint) !important;
  color:var(--teal) !important;
  width:48px;height:48px;
  border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:20px;
  padding:0;
}
.elementor-widget-icon.card__icon .elementor-icon i,
.elementor-widget-icon.card__icon .elementor-icon svg{
  color:var(--teal) !important;
  fill:currentColor;
  width:auto;height:auto;
}
.trust__row{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.trust__item{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;padding:12px;color:var(--ink);font-size:14px;font-weight:500;border-radius:8px}
.trust__item:hover{background:#d3eee2;text-decoration:none;color:var(--ink)}
.trust__icon{flex-shrink:0;color:var(--teal)}
.trust__lbl{font-weight:600;line-height:1.25}
.trust__sub{font-size:12px;color:var(--ink-2);font-weight:400;line-height:1.3}
@media (max-width:780px){
  .trust__row{grid-template-columns:repeat(3,1fr);gap:16px}
}
@media (max-width:520px){
  .trust__row{grid-template-columns:repeat(2,1fr)}
}
/* Trust strip — flex column with default align-items:stretch so children
 * take full width, then text-align:center handles horizontal centering
 * for the icon, title, and description uniformly. */
.elementor-section.trust .elementor-widget-icon-box.trust__item{
  width:100% !important;
}
.elementor-section.trust .elementor-widget-icon-box.trust__item .elementor-icon-box-wrapper{
  display:flex !important;
  flex-direction:column !important;
  gap:12px !important;
}
.elementor-section.trust .elementor-widget-icon-box.trust__item .elementor-icon-box-icon{
  text-align:center !important;
  margin:0 !important;
}
.elementor-section.trust .elementor-widget-icon-box.trust__item .elementor-icon-box-content{
  display:flex !important;
  flex-direction:column !important;
  align-items:center !important;
  text-align:center !important;
}
.elementor-section.trust .elementor-widget-icon-box.trust__item .elementor-icon-box-title,
.elementor-section.trust .elementor-widget-icon-box.trust__item .elementor-icon-box-title a,
.elementor-section.trust .elementor-widget-icon-box.trust__item .elementor-icon-box-description{
  margin:0 !important;
  text-align:center !important;
}

/* ---------- about / welcome ---------- */
.about{background:#fff;padding:80px 0}
@media (max-width:720px){ .about{padding:56px 0} }
.about__grid{display:grid;grid-template-columns:1.3fr 1fr;gap:64px;align-items:start}
.about__copy p{color:var(--ink-2);font-size:17px;margin-bottom:18px}
.about__copy strong{color:var(--ink);font-weight:600}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:32px}
.stat{background:#fff;border:1px solid var(--border);border-radius:var(--r-card);padding:24px}
.stat__n{font-family:var(--serif);font-size:36px;color:var(--teal);line-height:1;margin-bottom:8px}
.stat__l{font-size:14px;color:var(--ink-2);line-height:1.4}
.about__img{border-radius:var(--r-card);overflow:hidden;border:1px solid var(--border);background:var(--mint);aspect-ratio:4/5}
.about__img img{width:100%;height:100%;object-fit:cover}
@media (max-width:920px){
  .about__grid{grid-template-columns:1fr;gap:40px}
  .stats{grid-template-columns:1fr;gap:12px}
  .about__img{aspect-ratio:16/11;max-height:360px}
}

/* ---------- prevention / differentiator ---------- */
.prev{background:var(--cream);padding:80px 0}
@media (max-width:720px){ .prev{padding:56px 0} }
.prev__inner{max-width:760px}
.prev p{font-size:18px;color:var(--ink-2);margin:0 0 28px}

/* ---------- awareness cards / generic 3-up ---------- */
.aware{background:#fff;padding:80px 0}
@media (max-width:720px){ .aware{padding:56px 0} }
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{background:#fff;border:1px solid var(--border);border-radius:var(--r-card);padding:28px;display:flex;flex-direction:column;gap:14px;transition:border-color .15s ease}
.card:hover{border-color:#bdb8a8}
.card__icon{width:48px;height:48px;border-radius:999px;background:var(--mint);color:var(--teal);display:flex;align-items:center;justify-content:center}
.card h3{font-size:20px}
.card p{color:var(--ink-2);font-size:16px}
.card__more{margin-top:auto;color:var(--teal);font-weight:500;font-size:15px;display:inline-flex;align-items:center;gap:6px}
.card__more:hover{gap:10px;text-decoration:none}
@media (max-width:820px){ .cards-3{grid-template-columns:1fr} }

/* ---------- contact ask section ---------- */
.ask{background:var(--cream);padding:80px 0}
@media (max-width:720px){ .ask{padding:56px 0} }
.ask__grid{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:start}
.ask__sub{font-size:18px;color:var(--ink-2);margin-bottom:32px}
.ask__img{border-radius:var(--r-card);overflow:hidden;border:1px solid var(--border);background:var(--mint);aspect-ratio:4/5}
.ask__img img{width:100%;height:100%;object-fit:cover}
@media (max-width:920px){
  .ask__grid{grid-template-columns:1fr;gap:36px}
  .ask__img{aspect-ratio:16/11;max-height:360px;order:-1}
}

/* ---------- blog row ---------- */
.blog{background:#fff;}
@media (max-width:720px){ .blog{padding:56px 0} }
.blog__row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:32px}
.post{background:#fff;border:1px solid var(--border);border-radius:var(--r-card);overflow:hidden;display:flex;flex-direction:column}
.post__img{aspect-ratio:16/9;background:var(--mint);overflow:hidden}
.post__img img{width:100%;height:100%;object-fit:cover}
.post__body{padding:22px;display:flex;flex-direction:column;gap:10px;flex:1}

/* When .post is applied to an Elementor column there is no .post__body wrap —
 * give the column card chrome and pad every widget except the image. */
.elementor-column.post,
.elementor-column.post > .elementor-element-populated{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-card);
  overflow:hidden;
}
.elementor-column.post > .elementor-element-populated{border:0;padding:0 0 22px}
.elementor-column.post .elementor-widget:not(.post__img){padding-left:22px;padding-right:22px}
.elementor-column.post .elementor-widget.post__date{padding-top:18px}
.post__date{font-size:13px;color:var(--ink-2)}
.post__title{font-family:var(--serif);font-size:20px;font-weight:700;color:var(--ink);line-height:1.25}
.post__title a{color:var(--ink)}
.post__title a:hover{color:var(--teal);text-decoration:none}
.post__by{font-size:14px;color:var(--ink-2)}
.post__more{margin-top:auto;color:var(--teal);font-weight:500;font-size:15px;padding-top:6px}
.blog__more{text-align:center}
@media (max-width:820px){ .blog__row{grid-template-columns:1fr} }

/* ---------- accreditations row ---------- */
.accred{background:var(--cream);padding:80px 0}
@media (max-width:720px){ .accred{padding:56px 0} }
.accred__row{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;align-items:center;margin-bottom:48px}
.accred__logo{background:#fff;border:1px solid var(--border);border-radius:var(--r-card);padding:24px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;min-height:120px;color:var(--ink);font-weight:600;font-size:14px;text-align:center;line-height:1.25;transition:border-color .15s ease}
.accred__logo:hover{border-color:var(--teal);text-decoration:none;color:var(--ink)}
.accred__logo span.lvl{font-size:12px;font-weight:400;color:var(--ink-2);letter-spacing:0.04em}
.accred__photo{border-radius:var(--r-card);overflow:hidden;border:1px solid var(--border);background:var(--mint)}
.accred__photo img{width:100%;height:100%;object-fit:cover;aspect-ratio:21/9;display:block}
@media (max-width:820px){
  .accred__row{grid-template-columns:repeat(2,1fr)}
}

/* ---------- final CTA (dark teal) ---------- */
.finalcta{background:var(--teal-dark);color:#fff;padding:96px 0;text-align:center}
.finalcta h2{color:#fff;max-width:18ch;margin:0 auto 18px}
.finalcta p{color:#cfe6dd;max-width:600px;margin:0 auto 32px;font-size:18px}
.finalcta__ctas{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.finalcta__note{margin-top:24px;font-size:14px;color:#a4cdbf}

/* Elementor-scoped overrides for the dark CTA section */
.elementor-section.finalcta .elementor-widget-heading .elementor-heading-title{
  color:#fff !important;
  max-width:18ch;
  margin:0 auto 18px;
  text-align:center;
}
.elementor-section.finalcta .elementor-widget-text-editor p{
  color:#cfe6dd !important;
  text-align:center;
}
.elementor-section.finalcta .elementor-widget-text-editor.finalcta__note p{
  color:#a4cdbf !important;
  font-size:14px;
}

/* Put both CTAs on a single horizontal row, centred. The buttons are
 * separate widgets inside one column; widget-wrap stacks them by default. */
.elementor-section.finalcta__ctas .elementor-element-populated > .elementor-widget-wrap,
.elementor-section.finalcta__ctas .elementor-widget-wrap{
  display:flex !important;
  flex-direction:row !important;
  flex-wrap:wrap !important;
  gap:12px !important;
  justify-content:center !important;
  align-items:center !important;
}
.elementor-section.finalcta__ctas .elementor-widget-button{
  width:auto !important;
  flex:0 0 auto !important;
}

/* ---------- map ---------- */
.map{background:#fff;padding:80px 0}
@media (max-width:720px){ .map{padding:56px 0} }
.map__grid{display:grid;grid-template-columns:1.4fr 1fr;gap:32px;align-items:stretch}
.map__embed{border-radius:var(--r-card);overflow:hidden;border:1px solid var(--border);background:var(--mint);height:400px}
.map__embed iframe{width:100%;height:100%;border:0;display:block}
.visit{background:var(--mint);border-radius:var(--r-card);padding:32px;display:flex;flex-direction:column;gap:10px}
.visit h3{font-family:var(--serif);font-size:24px;margin-bottom:6px}
.visit p,.visit address{font-style:normal;color:var(--ink);font-size:16px;line-height:1.6;margin:0}
.visit strong{font-weight:600}
.visit a{color:var(--teal-dark);font-weight:500}
.visit__cta{margin-top:14px}
.visit__block{display:flex;flex-direction:column;gap:4px}
.visit__label{font-size:12px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-2)}
.visit__value{font-size:16px;color:var(--ink)}
.visit__divider{height:1px;background:rgba(15,110,86,0.15);margin:6px 0}
@media (max-width:820px){
  .map__grid{grid-template-columns:1fr;gap:24px}
  .map__embed{height:320px}
}

/* ---------- shortcode forms ---------- */
.pr-form{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-card);
  padding:32px;display:flex;flex-direction:column;gap:14px;
}
.pr-form .field{display:flex;flex-direction:column;gap:6px}
.pr-form label{font-size:14px;font-weight:500;color:var(--ink)}
.pr-form .req{color:var(--amber);margin-left:2px}
.pr-form input,.pr-form textarea,.pr-form select{
  font-family:inherit;font-size:16px;color:var(--ink);
  background:#fff;border:1px solid var(--border);border-radius:8px;
  padding:12px 14px;
  transition:border-color .15s ease;
  width:100%;
}
.pr-form input:focus,.pr-form textarea:focus,.pr-form select:focus{border-color:var(--teal);outline:none;box-shadow:0 0 0 3px rgba(15,110,86,0.15)}
.pr-form textarea{resize:vertical;min-height:110px}
.pr-form__row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:560px){ .pr-form__row{grid-template-columns:1fr} }
.pr-form .help{font-size:13px;color:var(--ink-2)}
.pr-form .checkbox{display:flex;gap:10px;align-items:flex-start;font-size:14px;color:var(--ink-2)}
.pr-form .checkbox input{width:auto;margin-top:3px}
.pr-form__hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.pr-form__note{font-size:13px;color:var(--ink-2);margin-top:2px}
.pr-form__error{
  background:#fff5f0;border:1px solid #f3c0a5;color:#7a3b16;
  padding:10px 14px;border-radius:8px;font-size:14px;
}
.pr-form__success{
  background:var(--mint);border:1px solid #b9e0d0;color:var(--teal-darker);
  padding:18px 20px;border-radius:8px;
}
.pr-form__success h3{margin-bottom:6px;font-family:var(--serif)}

@media (max-width:720px){
  .pr-form{padding:24px}
}

/* ============================================================
 * Treatment page (/treatment/)
 * Approach (4-pillar grid), Conditions (2x2), Phases (4-col),
 * Daily life (2-panel), Team (5-col), Family programme, FAQ.
 * ============================================================ */

/* Section vertical rhythm — every Treatment section gets the same 80/56 padding.
 * (Hero, trust and finalcta keep their own existing padding rules.) */
.elementor-section.approach,
.elementor-section.cond,
.elementor-section.phases-sec,
.elementor-section.daily,
.elementor-section.team-sec,
.elementor-section.family,
.elementor-section.faq{padding-top:80px;padding-bottom:80px}
@media (max-width:720px){
  .elementor-section.approach,
  .elementor-section.cond,
  .elementor-section.phases-sec,
  .elementor-section.daily,
  .elementor-section.team-sec,
  .elementor-section.family,
  .elementor-section.faq{padding-top:56px;padding-bottom:56px}
}

/* Inner section heads are always centred — the JSON omits the .shead--center
 * modifier because every head in this design is centred. */
.elementor-section.shead{
  margin-left:auto !important;margin-right:auto !important;
  text-align:center;
}
.elementor-section.shead .elementor-widget-heading .elementor-heading-title,
.elementor-section.shead .elementor-widget-text-editor{
  text-align:center;
}
.elementor-section.shead .elementor-widget-text-editor p{
  font-size:18px;color:var(--ink-2);max-width:var(--readw);margin:0 auto;
}

/* Shared: approach copy block — heading centred, intro constrained to readable width */
.elementor-section.approach__copy{margin-bottom:48px !important}
.elementor-section.approach__copy .elementor-widget-heading .elementor-heading-title{
  text-align:center;
}
.elementor-section.approach__copy .elementor-widget-heading{margin-bottom:24px}
.elementor-section.approach__copy .elementor-widget-text-editor{
  max-width:var(--readw);
  margin-left:auto;margin-right:auto;
}
.elementor-section.approach__copy .elementor-widget-text-editor p{
  font-size:17px;color:var(--ink-2);margin-bottom:18px;
}
.elementor-section.approach__copy .elementor-widget-text-editor p:last-child{margin-bottom:0}

/* Pillars — 4-col grid */
.elementor-section.pillars > .elementor-container{
  display:flex !important;flex-wrap:wrap !important;gap:20px !important;
}
.elementor-section.pillars > .elementor-container > .elementor-column{
  flex:0 0 calc((100% - 60px) / 4) !important;
  max-width:calc((100% - 60px) / 4) !important;
  margin:0 !important;width:auto !important;
}
.elementor-column.pillar > .elementor-element-populated{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-card);
  padding:28px !important;
}
.elementor-column.pillar .elementor-widget:not(:last-child){margin-bottom:12px !important}
.elementor-column.pillar .elementor-widget:last-child{margin-bottom:0 !important}
.elementor-widget-icon.pillar__icon .elementor-icon{
  background:transparent !important;color:var(--teal) !important;
  width:auto;height:auto;font-size:32px;padding:0;
}
.elementor-widget-icon.pillar__icon{text-align:left}
.elementor-widget-icon.pillar__icon .elementor-icon-wrapper{display:inline-block}
.elementor-widget-icon.pillar__icon .elementor-icon i,
.elementor-widget-icon.pillar__icon .elementor-icon svg{color:var(--teal) !important;fill:currentColor}
.elementor-column.pillar .elementor-widget-heading .elementor-heading-title{font-size:20px}
.elementor-column.pillar .elementor-widget-text-editor p{color:var(--ink-2);font-size:15px;line-height:1.6}
@media (max-width:980px){
  .elementor-section.pillars > .elementor-container > .elementor-column{
    flex:0 0 calc((100% - 20px) / 2) !important;
    max-width:calc((100% - 20px) / 2) !important;
  }
}
@media (max-width:560px){
  .elementor-section.pillars > .elementor-container > .elementor-column{
    flex:0 0 100% !important;max-width:100% !important;
  }
}

/* Conditions — 2x2 (two rows of two) */
.elementor-section.cond__row > .elementor-container{
  display:flex !important;flex-wrap:wrap !important;gap:24px !important;
}
.elementor-section.cond__row > .elementor-container > .elementor-column{
  flex:0 0 calc((100% - 24px) / 2) !important;
  max-width:calc((100% - 24px) / 2) !important;
  margin:0 !important;width:auto !important;
}
.elementor-section.cond__row{margin-bottom:24px}
.elementor-section.cond__row:last-of-type{margin-bottom:0}
.elementor-column.cond__card > .elementor-element-populated{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-card);
  padding:32px !important;
}
.elementor-column.cond__card .elementor-widget:not(:last-child){margin-bottom:14px !important}
.elementor-column.cond__card .elementor-widget:last-child{margin-bottom:0 !important}
.elementor-widget-icon.cond__icon .elementor-icon{
  background:transparent !important;color:var(--teal) !important;
  width:auto;height:auto;font-size:32px;padding:0;
}
.elementor-widget-icon.cond__icon{text-align:left}
.elementor-widget-icon.cond__icon .elementor-icon-wrapper{display:inline-block}
.elementor-widget-icon.cond__icon .elementor-icon i,
.elementor-widget-icon.cond__icon .elementor-icon svg{color:var(--teal) !important;fill:currentColor}
.elementor-column.cond__card .elementor-widget-heading .elementor-heading-title{font-size:22px}
.elementor-column.cond__card .elementor-widget-text-editor p{color:var(--ink-2);font-size:17px}
/* The "more" link rendered as an Elementor button but styled like a plain text link */
.elementor-widget-button.cond__more{margin-top:auto}
.elementor-widget-button.cond__more .elementor-button{
  background:transparent !important;color:var(--teal) !important;
  border:0 !important;padding:8px 0 0 !important;
  font-weight:500;font-size:15px;
}
.elementor-widget-button.cond__more .elementor-button:hover{
  background:transparent !important;color:var(--teal-dark) !important;text-decoration:underline;
}
@media (max-width:820px){
  .elementor-section.cond__row > .elementor-container > .elementor-column{
    flex:0 0 100% !important;max-width:100% !important;
  }
}

/* Phases — 4-col with numbered circles */
.elementor-section.phases > .elementor-container{
  display:flex !important;flex-wrap:wrap !important;gap:16px !important;
}
.elementor-section.phases > .elementor-container > .elementor-column{
  flex:0 0 calc((100% - 48px) / 4) !important;
  max-width:calc((100% - 48px) / 4) !important;
  margin:0 !important;width:auto !important;
}
.elementor-column.phase > .elementor-element-populated{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-card);
  padding:28px !important;
}
.elementor-column.phase .elementor-widget:not(:last-child){margin-bottom:8px !important}
.elementor-column.phase .elementor-widget:last-child{margin-bottom:0 !important}
.elementor-column.phase .elementor-widget-heading.phase__n .elementor-heading-title{
  width:40px;height:40px;border-radius:999px;
  background:var(--teal);color:#fff !important;
  font-family:var(--serif);font-size:18px;
  display:inline-flex;align-items:center;justify-content:center;
  line-height:1;margin-bottom:8px;
}
.elementor-column.phase .elementor-widget-heading.phase__pre .elementor-heading-title{
  font-family:var(--sans) !important;
  font-size:12px !important;font-weight:600 !important;
  letter-spacing:0.1em;text-transform:uppercase;color:var(--teal);
}
.elementor-column.phase .elementor-widget-heading.phase__name .elementor-heading-title{
  font-family:var(--serif);font-size:20px;line-height:1.25;color:var(--ink);
}
.elementor-column.phase .elementor-widget-text-editor.phase__days p{
  font-size:13px;color:var(--ink-2);margin:2px 0 6px;
}
.elementor-column.phase .elementor-widget-text-editor:not(.phase__days) p{
  color:var(--ink-2);font-size:15px;line-height:1.55;
}
.elementor-widget-text-editor.phases__after{max-width:var(--readw);margin:36px auto 0 !important}
.elementor-widget-text-editor.phases__after p{font-size:16px;color:var(--ink-2);text-align:center}
@media (max-width:980px){
  .elementor-section.phases > .elementor-container > .elementor-column{
    flex:0 0 calc((100% - 16px) / 2) !important;
    max-width:calc((100% - 16px) / 2) !important;
  }
}
@media (max-width:560px){
  .elementor-section.phases > .elementor-container > .elementor-column{
    flex:0 0 100% !important;max-width:100% !important;
  }
}

/* Daily life — 2-panel */
.elementor-section.daily__row > .elementor-container{
  display:flex !important;flex-wrap:wrap !important;gap:24px !important;
}
.elementor-section.daily__row > .elementor-container > .elementor-column{
  flex:0 0 calc((100% - 24px) / 2) !important;
  max-width:calc((100% - 24px) / 2) !important;
  margin:0 !important;width:auto !important;
}
.elementor-column.panel > .elementor-element-populated{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-card);
  padding:32px !important;
}
.elementor-column.panel .elementor-widget:not(:last-child){margin-bottom:12px !important}
.elementor-column.panel .elementor-widget:last-child{margin-bottom:0 !important}
.elementor-column.panel .elementor-widget-heading .elementor-heading-title{font-size:22px;margin-bottom:18px}
.elementor-widget-icon-list.panel__list .elementor-icon-list-items{
  display:flex;flex-direction:column;gap:12px;list-style:none;margin:0;padding:0;
}
.elementor-widget-icon-list.panel__list .elementor-icon-list-item{
  display:grid !important;grid-template-columns:20px 1fr;gap:12px;
  align-items:start;font-size:16px;color:var(--ink);
}
.elementor-widget-icon-list.panel__list .elementor-icon-list-icon{margin-top:4px}
.elementor-widget-icon-list.panel__list .elementor-icon-list-icon i,
.elementor-widget-icon-list.panel__list .elementor-icon-list-icon svg{color:var(--teal) !important;fill:currentColor;font-size:18px}
.elementor-widget-icon-list.panel__list .elementor-icon-list-text{color:var(--ink);line-height:1.55}
.elementor-widget-text-editor.daily__after{max-width:var(--readw);margin:32px auto 0 !important}
.elementor-widget-text-editor.daily__after p{font-size:16px;color:var(--ink-2);text-align:center}
@media (max-width:820px){
  .elementor-section.daily__row > .elementor-container > .elementor-column{
    flex:0 0 100% !important;max-width:100% !important;
  }
}

/* Team — 5-col */
.elementor-section.team > .elementor-container{
  display:flex !important;flex-wrap:wrap !important;gap:16px !important;
}
.elementor-section.team > .elementor-container > .elementor-column{
  flex:0 0 calc((100% - 64px) / 5) !important;
  max-width:calc((100% - 64px) / 5) !important;
  margin:0 !important;width:auto !important;
}
.elementor-column.role > .elementor-element-populated{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-card);
  padding:28px !important;
}
.elementor-column.role .elementor-widget:not(:last-child){margin-bottom:10px !important}
.elementor-column.role .elementor-widget:last-child{margin-bottom:0 !important}
.elementor-widget-icon.role__icon .elementor-icon{
  background:transparent !important;color:var(--teal) !important;
  width:auto;height:auto;font-size:32px;padding:0;
}
.elementor-widget-icon.role__icon{text-align:left}
.elementor-widget-icon.role__icon .elementor-icon-wrapper{display:inline-block}
.elementor-widget-icon.role__icon .elementor-icon i,
.elementor-widget-icon.role__icon .elementor-icon svg{color:var(--teal) !important;fill:currentColor}
.elementor-column.role .elementor-widget-heading .elementor-heading-title{font-family:var(--serif);font-size:18px}
.elementor-column.role .elementor-widget-text-editor p{font-size:14px;color:var(--ink-2);line-height:1.5}
@media (max-width:980px){
  .elementor-section.team > .elementor-container > .elementor-column{
    flex:0 0 calc((100% - 16px) / 2) !important;
    max-width:calc((100% - 16px) / 2) !important;
  }
}
@media (max-width:520px){
  .elementor-section.team > .elementor-container > .elementor-column{
    flex:0 0 100% !important;max-width:100% !important;
  }
}

/* Family programme — mint split */
.elementor-column.family__copy .elementor-widget-heading.eyebrow .elementor-heading-title{color:var(--teal)}
.elementor-column.family__copy .elementor-widget-text-editor p{color:var(--ink);font-size:17px;margin-bottom:18px}
.elementor-widget-image.family__img img{
  border-radius:var(--r-card);border:1px solid #cfe7dc;background:#fff;
  aspect-ratio:4/5;width:100%;object-fit:cover;
}
@media (max-width:920px){
  .elementor-widget-image.family__img img{aspect-ratio:16/11;max-height:380px}
}

/* FAQ — Elementor toggle widget styled like the design accordion */
.elementor-widget-toggle.faq__list{max-width:820px;margin:0 auto}
.elementor-widget-toggle.faq__list .elementor-toggle{display:flex;flex-direction:column;gap:12px}
.elementor-widget-toggle.faq__list .elementor-toggle-item{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-card);
  overflow:hidden;
}
.elementor-widget-toggle.faq__list .elementor-tab-title{
  padding:22px 28px !important;
  font-family:var(--serif) !important;
  font-size:19px !important;font-weight:700 !important;
  color:var(--ink) !important;border:0 !important;
  display:flex;justify-content:space-between;align-items:center;gap:24px;
}
.elementor-widget-toggle.faq__list .elementor-tab-title .elementor-toggle-icon{color:var(--teal)}
.elementor-widget-toggle.faq__list .elementor-tab-content{
  padding:0 28px 24px !important;
  color:var(--ink-2);font-size:16px;
  border:0 !important;
}
.elementor-widget-toggle.faq__list .elementor-tab-content p{margin:0;max-width:680px;line-height:1.6}

/* FAQ "see all" centred row */
.elementor-section.faq__more > .elementor-container{justify-content:center}
.elementor-section.faq__more{margin-top:32px}
.elementor-section.faq__more .elementor-widget-button .elementor-button-wrapper{text-align:center}

/* ============================================================
 * Admissions page (/admissions/)
 * Hero stats, cost card, payment cards, numbered steps,
 * bring/don't-bring, involuntary aside, pro-bono, form, FAQ.
 * ============================================================ */

/* Section vertical rhythm — every Admissions section gets 80/56 padding */
.elementor-section.ad__hero{
  background-color:#fff !important;
  padding-top:80px;padding-bottom:64px;
}
.elementor-section.cost-sec,
.elementor-section.pay-sec,
.elementor-section.proc,
.elementor-section.bring,
.elementor-section.invol,
.elementor-section.pb,
.elementor-section.form-sec{padding-top:80px;padding-bottom:80px}
@media (max-width:720px){
  .elementor-section.ad__hero{padding-top:48px;padding-bottom:48px}
  .elementor-section.cost-sec,
  .elementor-section.pay-sec,
  .elementor-section.proc,
  .elementor-section.bring,
  .elementor-section.invol,
  .elementor-section.pb,
  .elementor-section.form-sec{padding-top:56px;padding-bottom:56px}
}

/* Admissions hero — every direct child of the central column is centred */
.elementor-section.ad__hero .elementor-column.ad__heroc{text-align:center}
.elementor-section.ad__hero .elementor-widget-heading .elementor-heading-title{
  text-align:center !important;
}
.elementor-section.ad__hero .elementor-widget-text-editor,
.elementor-section.ad__hero .elementor-widget-text-editor p{
  text-align:center !important;
}
.elementor-section.ad__hero .elementor-widget-heading.hero__h1 .elementor-heading-title{
  max-width:none !important;margin:0 auto 18px !important;
}
.elementor-section.ad__hero .elementor-widget-text-editor.hero__sub p{
  max-width:640px !important;margin:0 auto 0 !important;
}
.elementor-section.ad__hero .elementor-widget-text-editor.hero__trust p{
  font-size:14px;color:var(--ink-2);max-width:640px;margin:18px auto 0 !important;
}

/* Hero stats — 3 mint pill cards. Neutralise homepage .stat chrome on the column. */
.elementor-section.hero__stats{margin:36px auto !important;max-width:760px}
.elementor-section.hero__stats > .elementor-container{
  display:flex !important;flex-wrap:wrap !important;gap:16px !important;
}
.elementor-section.hero__stats > .elementor-container > .elementor-column{
  flex:0 0 calc((100% - 32px) / 3) !important;
  max-width:calc((100% - 32px) / 3) !important;
  margin:0 !important;width:auto !important;
}
.elementor-section.hero__stats .elementor-column.stat{
  background:transparent !important;border:0 !important;padding:0 !important;
  box-shadow:none !important;
}
.elementor-section.hero__stats .elementor-column.stat > .elementor-element-populated{
  background:var(--mint) !important;border:0 !important;
  border-radius:var(--r-card) !important;
  padding:24px 18px !important;text-align:center !important;
}
.elementor-section.hero__stats .elementor-column.stat .elementor-widget-heading.stat__big .elementor-heading-title{
  font-family:var(--serif);color:var(--teal);line-height:1.05;margin:0 0 8px;
  text-align:center !important;
}
.elementor-section.hero__stats .elementor-column.stat .elementor-widget-heading.stat__big--lg .elementor-heading-title{font-size:32px}
.elementor-section.hero__stats .elementor-column.stat .elementor-widget-heading.stat__big--md .elementor-heading-title{font-size:28px}
.elementor-section.hero__stats .elementor-column.stat .elementor-widget-text-editor.stat__lbl p{
  font-size:14px;color:var(--ink);font-weight:500;margin:0;text-align:center !important;
}
.elementor-section.hero__stats .elementor-column.stat .elementor-widget:not(:last-child){margin-bottom:0 !important}
@media (max-width:720px){
  .elementor-section.hero__stats > .elementor-container > .elementor-column{
    flex:0 0 100% !important;max-width:100% !important;
  }
}

/* Hero CTAs row — defeats the homepage .hero__ctas left-align rule (L194-196) */
.elementor-section.hero__ctas{max-width:760px;margin:0 auto !important}
.elementor-section.hero__ctas .elementor-element-populated > .elementor-widget-wrap,
.elementor-section.hero__ctas .elementor-widget-wrap{
  display:flex !important;flex-direction:row !important;flex-wrap:wrap !important;
  gap:12px !important;justify-content:center !important;align-items:center !important;
  align-content:center !important;
}
.elementor-section.hero__ctas .elementor-widget-button{width:auto !important;flex:0 0 auto !important}
.elementor-section.hero__ctas .elementor-button-wrapper{text-align:center !important}

/* Cost card — sibling header + body sections styled as one connected card */
.elementor-section.cost-card__hdr,
.elementor-section.cost-card__body{
  max-width:980px;margin-left:auto !important;margin-right:auto !important;
}
.elementor-section.cost-card__hdr{
  background:var(--teal-dark) !important;color:#fff !important;
  padding:36px 32px !important;text-align:center;
  border-radius:var(--r-card) var(--r-card) 0 0;
}
.elementor-section.cost-card__hdr .elementor-widget-heading.cost-card__lbl .elementor-heading-title{
  font-family:var(--sans) !important;font-size:14px !important;font-weight:600 !important;
  letter-spacing:0.12em;text-transform:uppercase;color:#a4cdbf;margin:0 0 12px;
}
.elementor-section.cost-card__hdr .elementor-widget-heading.cost-card__price .elementor-heading-title{
  font-family:var(--serif);font-size:clamp(44px,7vw,56px);line-height:1;
  color:#fff;margin:0 0 10px;
}
.elementor-section.cost-card__hdr .elementor-widget-text-editor.cost-card__sub p{
  font-size:16px;color:#cfe6dd;margin:0;
}
.elementor-section.cost-card__body{
  background:#fff !important;
  border:1px solid var(--border);border-top:0;
  padding:36px !important;
  border-radius:0 0 var(--r-card) var(--r-card);
  box-shadow:0 2px 6px rgba(0,0,0,0.06);
}
.elementor-section.cost-card__body .elementor-widget-heading h3{font-size:20px;margin:0 0 18px}
.elementor-column.cost-card__col .elementor-widget:not(:last-child){margin-bottom:0 !important}
@media (max-width:820px){
  .elementor-section.cost-card__hdr,
  .elementor-section.cost-card__body{padding:28px !important}
}

/* listic — generic icon-list patterns used in cost / bring / invol sections */
.elementor-widget-icon-list .elementor-icon-list-items{
  display:flex;flex-direction:column;gap:12px;list-style:none;margin:0;padding:0;
}
.elementor-widget-icon-list.listic .elementor-icon-list-item{
  display:grid !important;grid-template-columns:20px 1fr;gap:12px;align-items:start;
  font-size:16px;color:var(--ink);line-height:1.55;
}
.elementor-widget-icon-list.listic .elementor-icon-list-icon{margin-top:4px}
.elementor-widget-icon-list.listic--check .elementor-icon-list-icon i,
.elementor-widget-icon-list.listic--check .elementor-icon-list-icon svg{color:var(--teal) !important;font-size:18px}
.elementor-widget-icon-list.listic--minus .elementor-icon-list-icon i,
.elementor-widget-icon-list.listic--minus .elementor-icon-list-icon svg{color:var(--ink-2) !important;font-size:18px}
.elementor-widget-icon-list.listic .elementor-icon-list-text{color:var(--ink);line-height:1.55}

/* Cost note paragraph */
.elementor-widget-text-editor.cost-note{max-width:600px;margin:24px auto 0 !important}
.elementor-widget-text-editor.cost-note p{font-size:14px;color:var(--ink-2);text-align:center}

/* Payment grid — 3-col cards */
.elementor-section.pay-grid > .elementor-container{
  display:flex !important;flex-wrap:wrap !important;gap:20px !important;
}
.elementor-section.pay-grid > .elementor-container > .elementor-column{
  flex:0 0 calc((100% - 40px) / 3) !important;
  max-width:calc((100% - 40px) / 3) !important;
  margin:0 !important;width:auto !important;
}
.elementor-column.pay-card > .elementor-element-populated{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-card);
  padding:32px !important;
}
.elementor-column.pay-card .elementor-widget:not(:last-child){margin-bottom:14px !important}
.elementor-column.pay-card .elementor-widget:last-child{margin-bottom:0 !important}
.elementor-widget-icon.pay-card__icon .elementor-icon{
  background:transparent !important;color:var(--teal) !important;
  width:auto;height:auto;font-size:32px;padding:0;
}
.elementor-widget-icon.pay-card__icon{text-align:left}
.elementor-widget-icon.pay-card__icon .elementor-icon i,
.elementor-widget-icon.pay-card__icon .elementor-icon svg{color:var(--teal) !important;fill:currentColor}
.elementor-column.pay-card .elementor-widget-heading .elementor-heading-title{font-size:20px}
.elementor-column.pay-card .elementor-widget-text-editor p{color:var(--ink);font-size:16px}
.elementor-column.pay-card .elementor-widget-text-editor.pay-card__sub p{
  color:var(--ink-2);font-size:14px;
}
/* Inline-link button (no real button chrome) */
.elementor-widget-button.pay-card__link .elementor-button{
  background:transparent !important;color:var(--teal) !important;
  border:0 !important;padding:8px 0 0 !important;
  font-weight:500;font-size:15px;
}
.elementor-widget-button.pay-card__link .elementor-button:hover{
  background:transparent !important;color:var(--teal-dark) !important;text-decoration:underline;
}
@media (max-width:900px){
  .elementor-section.pay-grid > .elementor-container > .elementor-column{
    flex:0 0 100% !important;max-width:100% !important;
  }
}

/* Steps timeline — each step is its own row with number + content */
.elementor-section.step{
  max-width:880px;margin:0 auto 16px !important;
  background:#fff;border:1px solid var(--border);border-radius:var(--r-card);
}
.elementor-section.step > .elementor-container{padding:28px}
.elementor-column.step__n-col{align-self:flex-start}
.elementor-column.step__n-col > .elementor-element-populated{padding:0 !important}
.elementor-column.step__n-col .elementor-widget-heading.step__n .elementor-heading-title{
  width:48px;height:48px;border-radius:999px;
  background:var(--teal);color:#fff !important;
  font-family:var(--serif);font-size:22px;
  display:inline-flex;align-items:center;justify-content:center;
  line-height:1;
}
.elementor-column.step__body > .elementor-element-populated{padding:0 !important}
.elementor-column.step__body .elementor-widget:not(:last-child){margin-bottom:6px !important}
.elementor-column.step__body .elementor-widget:last-child{margin-bottom:0 !important}
.elementor-column.step__body .elementor-widget-heading.step__name .elementor-heading-title{
  font-family:var(--serif);font-size:22px;color:var(--ink);margin:0 0 6px;
}
.elementor-column.step__body .elementor-widget-text-editor.step__dur p{
  font-size:13px;color:var(--ink-2);font-weight:500;margin:0 0 12px;
}
.elementor-column.step__body .elementor-widget-text-editor:not(.step__dur) p{
  color:var(--ink);font-size:16px;
}
.elementor-widget-text-editor.steps__after{max-width:600px;margin:32px auto 0 !important}
.elementor-widget-text-editor.steps__after p{font-size:14px;color:var(--ink-2);text-align:center}

/* Bring grid — 2-col card layout */
.elementor-section.bring-grid > .elementor-container{
  display:flex !important;flex-wrap:wrap !important;gap:24px !important;
}
.elementor-section.bring-grid > .elementor-container > .elementor-column{
  flex:0 0 calc((100% - 24px) / 2) !important;
  max-width:calc((100% - 24px) / 2) !important;
  margin:0 !important;width:auto !important;
}
.elementor-column.bring-card > .elementor-element-populated{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-card);
  padding:32px !important;
}
.elementor-column.bring-card .elementor-widget-heading .elementor-heading-title{font-size:20px;margin:0 0 18px}
.elementor-column.bring-card .elementor-widget:not(:last-child){margin-bottom:0 !important}
.elementor-widget-text-editor.bring-after{max-width:var(--readw);margin:28px auto 0 !important}
.elementor-widget-text-editor.bring-after p{font-size:16px;color:var(--ink-2);text-align:center}
@media (max-width:820px){
  .elementor-section.bring-grid > .elementor-container > .elementor-column{
    flex:0 0 100% !important;max-width:100% !important;
  }
}

/* Involuntary section — copy + mint aside */
.elementor-column.invol__copy .elementor-widget-heading.eyebrow .elementor-heading-title{color:var(--amber)}
.elementor-column.invol__copy .elementor-widget-heading h2{margin-bottom:18px}
.elementor-column.invol__copy .elementor-widget-text-editor p{color:var(--ink);font-size:17px}
.elementor-column.invol__copy .elementor-widget:not(:last-child){margin-bottom:18px !important}
.elementor-column.invol__copy .elementor-widget:last-child{margin-bottom:0 !important;margin-top:8px}
.elementor-column.invol__aside > .elementor-element-populated{
  background:var(--mint) !important;border-radius:var(--r-card);
  padding:32px !important;
}
.elementor-column.invol__aside .elementor-widget-heading h3{margin:0 0 18px;font-size:20px}
.elementor-column.invol__aside .elementor-widget:not(:last-child){margin-bottom:0 !important}

/* Pro-bono — split, mint bg */
.elementor-column.pb__copy .elementor-widget-heading.eyebrow .elementor-heading-title{color:var(--teal)}
.elementor-column.pb__copy .elementor-widget-heading h2{margin-bottom:18px}
.elementor-column.pb__copy .elementor-widget-text-editor p{color:var(--ink);font-size:17px}
.elementor-column.pb__copy .elementor-widget:not(:last-child){margin-bottom:18px !important}
.elementor-column.pb__copy .elementor-widget:last-child{margin-bottom:0 !important;margin-top:8px}
.elementor-widget-image.pb__img img{
  border-radius:var(--r-card);border:1px solid #cfe7dc;background:#fff;
  aspect-ratio:4/5;width:100%;object-fit:cover;
}
@media (max-width:920px){
  .elementor-widget-image.pb__img img{aspect-ratio:16/11;max-height:380px}
}

/* Admissions form shortcode wrap — centre and constrain */
.elementor-widget.form-card-wrap{max-width:720px;margin:0 auto !important}

/* ============================================================
   Single blog post (single.php)
   ============================================================ */

/* article header */
.ahdr{padding:64px 0 32px;background:#fff}
.ahdr__inner{max-width:680px;margin:0 auto;text-align:center}
.ahdr__cat{display:inline-block;background:var(--mint);color:var(--teal-dark);font-size:12px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;padding:6px 14px;border-radius:999px;margin-bottom:20px;text-decoration:none}
.ahdr__cat:hover{background:var(--teal);color:#fff;text-decoration:none}
.ahdr h1{font-family:var(--serif);font-size:clamp(34px,4.6vw,48px);letter-spacing:-0.01em;line-height:1.12;color:var(--ink);margin:0 auto 18px;max-width:22ch;font-weight:700}
.ahdr__lead{font-size:19px;color:var(--ink-2);line-height:1.6;margin:0 auto 28px;max-width:680px}
.ahdr__meta{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:14px;color:var(--ink-2);font-size:14px}
.ahdr__meta__sep{width:3px;height:3px;background:#8A8881;border-radius:999px;flex-shrink:0}
.ahdr__author{display:inline-flex;align-items:center;gap:10px}
.ahdr__avatar{width:32px;height:32px;border-radius:999px;background:var(--mint);color:var(--teal-dark);display:inline-flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:14px;overflow:hidden}
.ahdr__avatar img{width:100%;height:100%;object-fit:cover;border-radius:999px}
.ahdr__author strong{font-weight:600;color:var(--ink);font-family:var(--sans)}

/* featured image */
.ahero{padding:0 0 16px;background:#fff}
.ahero__fig{max-width:1180px;margin:0 auto;padding:0 24px}
.ahero__img{width:100%;aspect-ratio:16/9;object-fit:cover;background:var(--mint);border-radius:var(--r-card);border:1px solid var(--border);display:block}
.ahero__cap{max-width:680px;margin:12px auto 0;font-size:13px;color:var(--ink-2);text-align:center;line-height:1.5;font-style:italic}

/* body wrap */
.abody{padding:48px 0 80px;background:#fff}
.abody__inner{max-width:680px;margin:0 auto;padding:0 24px}

/* prose — long-form typography for the_content() */
.prose{font-size:18.5px;line-height:1.75;color:var(--ink)}
.prose p{margin:0 0 22px}
.prose p:last-child{margin-bottom:0}
.prose h2{font-family:var(--serif);font-weight:700;color:var(--ink);margin:48px 0 16px;font-size:clamp(24px,2.8vw,30px);line-height:1.2}
.prose h2:first-child{margin-top:0}
.prose h3{font-family:var(--serif);font-weight:700;color:var(--ink);margin:36px 0 12px;font-size:21px;line-height:1.3}
.prose a{color:var(--teal);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
.prose a:hover{text-decoration-thickness:2px}
.prose strong{font-weight:600}
.prose em{font-style:italic}
.prose ul,.prose ol{margin:0 0 22px;padding-left:24px}
.prose ul li,.prose ol li{margin-bottom:8px;line-height:1.7}
.prose ul li::marker{color:var(--teal)}
.prose hr{border:0;height:1px;background:#E7E3DA;margin:40px auto;max-width:60%}
.prose img{border-radius:var(--r-card);max-width:100%;height:auto}
.prose figure{margin:30px 0;text-align:center}
.prose figcaption{font-size:13px;color:var(--ink-2);font-style:italic;margin-top:10px;line-height:1.5}
.prose .wp-block-image{margin:30px 0}

/* drop-cap (opt-in via .prose--dropcap) */
.prose--dropcap > p:first-of-type::first-letter{font-family:var(--serif);font-size:64px;line-height:0.9;color:var(--teal);float:left;margin:8px 12px 0 0;padding-top:4px}

/* content advisory callout */
.advis{margin:0 0 32px;padding:18px 22px;border-radius:var(--r-card);background:var(--amber-light, #FAEEDA);border:1px solid #e9d6b3;display:grid;grid-template-columns:24px 1fr;gap:14px;align-items:start;font-size:14.5px;color:var(--ink);line-height:1.55}
.advis svg{color:var(--amber);margin-top:3px}
.advis strong{font-weight:600}

/* pull quote */
.pquote{margin:36px 0;padding:8px 0 8px 28px;border-left:4px solid var(--teal);font-family:var(--serif);font-size:26px;line-height:1.35;color:var(--teal-darker);letter-spacing:-0.005em}
.pquote cite{display:block;margin-top:14px;font-family:var(--sans);font-style:normal;font-size:14px;font-weight:500;color:var(--ink-2);letter-spacing:0}
.pquote cite::before{content:"— "}

/* default blockquote inside prose */
.prose blockquote{margin:28px 0;padding:18px 22px;background:var(--cream);border-radius:8px;font-size:17px;color:var(--ink);line-height:1.65;font-style:italic;border:1px solid #E7E3DA}
.prose blockquote p{margin-bottom:10px}
.prose blockquote p:last-child{margin-bottom:0}
.prose blockquote cite{display:block;margin-top:8px;font-style:normal;font-size:13.5px;font-weight:500;color:var(--ink-2)}
.prose blockquote cite::before{content:"— "}

/* info callout */
.info{margin:30px 0;padding:22px 24px;border-radius:var(--r-card);background:var(--cream);border:1px solid #E7E3DA;display:grid;grid-template-columns:28px 1fr;gap:14px;align-items:start}
.info svg{color:var(--teal);margin-top:4px}
.info h4{font-family:var(--sans);font-size:13px;font-weight:600;color:var(--ink);text-transform:uppercase;letter-spacing:0.08em;margin:0 0 6px}
.info p{font-size:15.5px;color:var(--ink-2);margin:0 0 6px;line-height:1.6}
.info p:last-child{margin-bottom:0}

/* key takeaway box (dark) */
.takeaway{margin:30px 0;padding:24px 26px;border-radius:var(--r-card);background:var(--teal-dark);color:#fff}
.takeaway h4{font-family:var(--sans);font-size:12px;font-weight:600;color:#a4cdbf;text-transform:uppercase;letter-spacing:0.1em;margin:0 0 10px}
.takeaway p{font-family:var(--serif);font-size:20px;line-height:1.4;color:#fff;margin:0}

/* inline figure within prose */
.pfig{margin:30px 0;text-align:center}
.pfig img{width:100%;border-radius:var(--r-card);background:var(--mint);border:1px solid #E7E3DA;aspect-ratio:16/10;object-fit:cover}
.pfig figcaption{font-size:13px;color:var(--ink-2);font-style:italic;margin-top:10px;line-height:1.5}

/* soft inline CTA */
.softcta{margin:36px 0;padding:22px 24px;border-radius:var(--r-card);background:var(--mint);border:1px solid #cfe6dc;display:grid;grid-template-columns:1fr auto;gap:18px;align-items:center}
.softcta p{font-size:15.5px;color:var(--ink);line-height:1.55;margin:0}
.softcta p strong{display:block;font-family:var(--serif);font-size:18px;color:var(--ink);font-weight:700;margin-bottom:2px}
@media (max-width:560px){.softcta{grid-template-columns:1fr}.softcta .btn{justify-self:start}}

/* author bio card */
.abio{margin:48px auto 0;max-width:680px;padding:28px;background:var(--cream);border-radius:var(--r-card);border:1px solid #E7E3DA;display:grid;grid-template-columns:64px 1fr;gap:20px;align-items:start}
.abio__photo{width:64px;height:64px;border-radius:999px;background:var(--mint);color:var(--teal-dark);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:22px;overflow:hidden;flex-shrink:0}
.abio__photo img{width:100%;height:100%;object-fit:cover;border-radius:999px}
.abio__role{font-size:12px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:var(--teal);margin-bottom:6px}
.abio h3{font-family:var(--sans);font-size:17px;font-weight:600;margin:0 0 8px}
.abio p{font-size:15px;color:var(--ink-2);line-height:1.6;margin:0}
@media (max-width:560px){.abio{grid-template-columns:1fr;text-align:center}.abio__photo{margin:0 auto}}

/* share / tag strip */
.ashare{max-width:680px;margin:32px auto 0;padding:18px 0;border-top:1px solid #E7E3DA;border-bottom:1px solid #E7E3DA;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px;font-size:14px;color:var(--ink-2)}
.ashare__tags{display:flex;flex-wrap:wrap;gap:6px}
.ashare__tag{font-size:12px;font-weight:500;background:var(--cream);color:var(--ink-2);padding:5px 12px;border-radius:999px;border:1px solid #E7E3DA;text-decoration:none}
.ashare__tag:hover{background:var(--mint);color:var(--teal);border-color:var(--teal);text-decoration:none}
.ashare__links{display:flex;gap:8px}
.ashare__links a{width:36px;height:36px;border-radius:999px;border:1px solid var(--border);background:#fff;display:inline-flex;align-items:center;justify-content:center;color:var(--ink-2)}
.ashare__links a:hover{color:var(--teal);border-color:var(--teal);text-decoration:none}

/* closing CTA (dark, full-width) */
.closing{background:var(--teal-dark);color:#fff;padding:80px 0;text-align:center}
.closing h2{font-family:var(--serif);font-weight:700;color:#fff;max-width:22ch;margin:0 auto 16px;font-size:clamp(28px,3.4vw,36px);line-height:1.2}
.closing p{color:#cfe6dd;max-width:560px;margin:0 auto 28px;font-size:17px;line-height:1.65}
.closing__ctas{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.closing__note{margin-top:18px;font-size:13px;color:#a4cdbf}

/* related posts */
.related{background:var(--cream);padding:80px 0}
.related__head{text-align:center;margin:0 auto 40px;max-width:680px;padding:0 24px}
.related__head h2{font-family:var(--serif);font-weight:700;color:var(--ink);font-size:clamp(28px,3.4vw,36px);margin:0 0 8px;line-height:1.2}
.related__head p{font-size:16px;color:var(--ink-2);margin:0}
.related__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1180px;margin:0 auto;padding:0 24px}
.rpost{background:#fff;border:1px solid var(--border);border-radius:var(--r-card);overflow:hidden;display:flex;flex-direction:column;color:var(--ink);transition:transform .15s,border-color .15s;text-decoration:none}
.rpost:hover{transform:translateY(-2px);border-color:var(--teal);text-decoration:none;color:var(--ink)}
.rpost__img{aspect-ratio:16/10;background:var(--mint);object-fit:cover;width:100%;display:block;border:0}
.rpost__body{padding:20px 22px 22px;display:flex;flex-direction:column;gap:8px;flex:1}
.rpost__cat{font-size:11px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--teal)}
.rpost h3{font-family:var(--serif);font-weight:700;color:var(--ink);font-size:18px;line-height:1.3;margin:0}
.rpost__exc{color:var(--ink-2);font-size:14.5px;line-height:1.55;flex:1;margin:0}
.rpost__meta{font-size:12.5px;color:#8A8881;margin-top:4px}
@media (max-width:920px){.related__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.related__grid{grid-template-columns:1fr}}

/* ============================================================
   Blog index (home.php — dynamic posts page)
   ============================================================ */

/* hero */
.bl-hero{background:#fff;padding:40px 0 32px;text-align:center}
.bl-hero__eb{font-size:13px;font-weight:600;letter-spacing:0.13em;text-transform:uppercase;color:var(--amber);margin:0 0 16px}
.bl-hero__h1{font-family:var(--serif);font-weight:700;color:var(--ink);font-size:clamp(36px,5vw,52px);line-height:1.1;letter-spacing:-0.01em;margin:0 auto 20px;max-width:760px}
.bl-hero__lead{font-size:18px;color:var(--ink-2);line-height:1.65;margin:0 auto;max-width:760px}

/* topic chips */
.bl-topics{background:#fff;padding:0 0 24px}
.bl-chips{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.bl-chip{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:999px;border:1px solid var(--border);background:#fff;color:var(--ink);font-size:14px;font-weight:500;text-decoration:none;transition:background .15s,border-color .15s,color .15s}
.bl-chip:hover{background:var(--mint);border-color:var(--teal);color:var(--teal);text-decoration:none}
.bl-chip span{font-size:12px;color:var(--ink-2);background:var(--cream);padding:1px 8px;border-radius:999px}
.bl-chip--active{background:var(--teal);border-color:var(--teal);color:#fff}
.bl-chip--active:hover{background:var(--teal-dark);border-color:var(--teal-dark);color:#fff}
.bl-chip--active span{background:rgba(255,255,255,0.2);color:#fff}

/* featured post */
.bl-featured{background:#fff;padding:24px 0 40px}
.bl-feat-card{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.bl-feat-img{display:block;border-radius:var(--r-card);overflow:hidden;line-height:0}
.bl-feat-img img{width:100%;aspect-ratio:16/10;object-fit:cover;display:block;transition:transform .25s}
.bl-feat-img:hover img{transform:scale(1.02)}
.bl-feat-img__placeholder{display:block;aspect-ratio:16/10;background:var(--mint);width:100%}
.bl-feat-pre{display:block;font-size:12px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--amber);margin:0 0 12px}
.bl-feat-h{font-family:var(--serif);font-weight:700;color:var(--ink);font-size:clamp(24px,2.8vw,32px);line-height:1.2;margin:0 0 14px}
.bl-feat-h a{color:inherit;text-decoration:none}
.bl-feat-h a:hover{color:var(--teal)}
.bl-feat-exc{font-size:16px;color:var(--ink-2);line-height:1.65;margin:0 0 18px}
.bl-feat-meta{display:flex;flex-wrap:wrap;gap:16px;font-size:13px;color:var(--ink-2);margin:0 0 20px}
@media (max-width:820px){.bl-feat-card{grid-template-columns:1fr;gap:24px}}

/* post grid */
.bl-grid-sec{background:#fff;padding:40px 0 64px}
.bl-grid-head{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:12px;padding-bottom:14px;border-bottom:1px solid var(--border);margin-bottom:32px}
.bl-grid-head h2{font-family:var(--serif);font-weight:700;color:var(--ink);font-size:28px;margin:0}
.bl-grid-head span{font-size:14px;color:var(--ink-2)}
.bl-post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:920px){.bl-post-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.bl-post-grid{grid-template-columns:1fr}}
.bl-post-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-card);overflow:hidden;display:flex;flex-direction:column;transition:transform .15s,border-color .15s}
.bl-post-card:hover{transform:translateY(-2px);border-color:var(--teal)}
.bl-post-img{position:relative;display:block;line-height:0;aspect-ratio:16/10;overflow:hidden}
.bl-post-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .25s}
.bl-post-card:hover .bl-post-img img{transform:scale(1.04)}
.bl-post-img__placeholder{display:block;width:100%;height:100%;background:var(--mint)}
.bl-post-tag{position:absolute;left:14px;top:14px;background:rgba(255,255,255,0.95);color:var(--teal);font-size:11px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;padding:5px 11px;border-radius:999px;z-index:1}
.bl-post-body{padding:22px;display:flex;flex-direction:column;gap:10px;flex:1}
.bl-post-meta{display:flex;justify-content:space-between;gap:10px;font-size:13px;color:var(--ink-2);flex-wrap:wrap}
.bl-post-title{font-family:var(--serif);font-weight:700;color:var(--ink);font-size:20px;line-height:1.25;margin:0}
.bl-post-title a{color:inherit;text-decoration:none}
.bl-post-title a:hover{color:var(--teal)}
.bl-post-exc{font-size:15px;color:var(--ink-2);line-height:1.55;margin:0}
.bl-post-more{margin-top:auto;color:var(--teal);font-weight:500;font-size:14px;padding-top:6px;text-decoration:none}
.bl-post-more:hover{color:var(--teal-dark)}

/* pagination */
.bl-pagination{display:flex;justify-content:center;flex-wrap:wrap;gap:6px;margin-top:48px}
.bl-pagination span a,.bl-pagination span .current,.bl-pagination span .dots{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:38px;padding:0 12px;border-radius:8px;border:1px solid var(--border);background:#fff;font-size:14px;font-weight:500;color:var(--ink);text-decoration:none;transition:background .15s,border-color .15s,color .15s}
.bl-pagination span a:hover{background:var(--mint);border-color:var(--teal);color:var(--teal);text-decoration:none}
.bl-pagination span .current{background:var(--teal);border-color:var(--teal);color:#fff}
.bl-pagination span .dots{border:0;background:transparent;color:var(--ink-2)}

/* empty state */
.bl-empty{text-align:center;padding:60px 24px;background:var(--cream);border-radius:var(--r-card);color:var(--ink-2);font-size:17px;line-height:1.6;max-width:680px;margin:0 auto}

/* awareness channels */
.bl-channels{background:var(--cream);padding:80px 0}
.bl-channels__head{text-align:center;max-width:680px;margin:0 auto 48px}
.bl-channels__eb{font-size:13px;font-weight:600;letter-spacing:0.13em;text-transform:uppercase;color:var(--teal);margin:0 0 12px}
.bl-channels__head h2{font-family:var(--serif);font-weight:700;color:var(--ink);font-size:clamp(28px,3.4vw,36px);line-height:1.2;margin:0 0 12px}
.bl-channels__head p{font-size:18px;color:var(--ink-2);margin:0;line-height:1.65}
.bl-channels__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.bl-chan{background:#fff;border:1px solid var(--border);border-radius:var(--r-card);padding:32px 28px;display:flex;flex-direction:column;gap:10px;color:var(--ink);text-decoration:none;transition:transform .15s,box-shadow .15s,border-color .15s}
.bl-chan:hover{transform:translateY(-2px);border-color:var(--teal);box-shadow:0 8px 24px rgba(0,0,0,0.06);text-decoration:none;color:var(--ink)}
.bl-chan__icon{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px;background:var(--mint);color:var(--teal);margin-bottom:6px}
.bl-chan h3{font-family:var(--serif);font-weight:700;color:var(--ink);font-size:20px;margin:0 0 4px;line-height:1.3}
.bl-chan p{font-size:14px;color:var(--ink-2);line-height:1.55;margin:0;flex:1}
.bl-chan__cta{color:var(--teal);font-weight:500;font-size:14px;margin-top:6px}
@media (max-width:820px){.bl-channels__grid{grid-template-columns:1fr}}

/* final CTA */
.bl-final{background:#fff;padding:64px 0;text-align:center}
.bl-final__eb{font-size:13px;font-weight:600;letter-spacing:0.13em;text-transform:uppercase;color:var(--teal);margin:0 0 16px}
.bl-final h2{font-family:var(--serif);font-weight:700;color:var(--ink);font-size:clamp(28px,3.4vw,36px);line-height:1.2;margin:0 auto 18px;max-width:22ch}
.bl-final p{font-size:18px;color:var(--ink-2);line-height:1.65;margin:0 auto 32px;max-width:620px}
.bl-final__ctas{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
@media (max-width:560px){.bl-final__ctas{flex-direction:column;align-items:center}.bl-final__ctas .btn{width:100%;max-width:280px;justify-content:center}}

/* ============================================================
   Legal pages (template-legal.php)
   ============================================================ */

/* title block */
.ptitle{padding:56px 0 32px;border-bottom:1px solid #E7E3DA;background:#fff}
.ptitle h1{font-family:var(--serif);font-weight:700;color:var(--ink);font-size:clamp(34px,4.4vw,46px);letter-spacing:-0.01em;line-height:1.15;margin:0 0 14px;max-width:18ch}
.ptitle p{font-size:18px;color:var(--ink-2);max-width:680px;margin:0;line-height:1.65}
.ptitle__meta{display:flex;flex-wrap:wrap;gap:10px 22px;margin-top:24px;font-size:13px;color:var(--ink-2)}
.ptitle__meta span{display:inline-flex;align-items:center;gap:8px}
.ptitle__meta strong{font-weight:600;color:var(--ink);font-family:var(--sans)}
.ptitle__meta svg{color:var(--teal)}

/* 2-col layout */
.ply{padding:48px 0 80px;background:#fff}
.ply__grid{display:grid;grid-template-columns:260px 1fr;gap:64px;align-items:start}
@media (max-width:980px){.ply__grid{grid-template-columns:1fr;gap:40px}}

/* TOC */
.toc{position:sticky;top:120px;align-self:start}
.toc h2{font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-2);margin:0 0 14px}
.toc ol{list-style:none;margin:0;padding:0;counter-reset:t;display:flex;flex-direction:column;gap:6px;border-left:1px solid #E7E3DA}
.toc ol li{counter-increment:t}
.toc ol li a{display:flex;gap:8px;align-items:baseline;padding:6px 0 6px 16px;font-size:14px;color:var(--ink-2);text-decoration:none;border-left:2px solid transparent;margin-left:-1px;line-height:1.45}
.toc ol li a:hover{color:var(--teal);border-left-color:var(--mint);text-decoration:none}
.toc ol li a::before{content:counter(t, decimal-leading-zero);font-family:var(--serif);color:var(--teal);font-size:12px;flex-shrink:0}
@media (max-width:980px){.toc{position:static;border:1px solid #E7E3DA;padding:24px;border-radius:var(--r-card);background:var(--cream)}.toc ol{border-left:none;gap:4px}}

/* content column */
.pcontent{max-width:760px;counter-reset:lsec;font-size:16.5px;color:var(--ink);line-height:1.7}
.pcontent h2{counter-increment:lsec;display:flex;gap:14px;align-items:baseline;margin:48px 0 18px;padding-top:36px;border-top:1px solid #E7E3DA;scroll-margin-top:120px;font-family:var(--serif);font-weight:700;font-size:clamp(24px,2.6vw,28px);line-height:1.25;color:var(--ink)}
.pcontent h2:first-of-type{margin-top:0;padding-top:0;border-top:0}
.pcontent h2::before{content:counter(lsec, decimal-leading-zero);font-family:var(--serif);color:var(--teal);font-size:18px;flex-shrink:0;font-weight:400}
.pcontent h3{font-family:var(--serif);font-weight:700;font-size:19px;line-height:1.3;margin:24px 0 10px;color:var(--ink)}
.pcontent p{margin:0 0 16px}
.pcontent ul,.pcontent ol{margin:0 0 16px;padding-left:24px}
.pcontent ul li,.pcontent ol li{margin-bottom:8px;line-height:1.65}
.pcontent ul li::marker{color:var(--teal)}
.pcontent strong{font-weight:600}
.pcontent a{color:var(--teal);text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px}
.pcontent a:hover{text-decoration-thickness:2px}

/* table */
.ptab{width:100%;border-collapse:collapse;font-size:15px;margin:8px 0 20px;border:1px solid #E7E3DA;border-radius:8px;overflow:hidden}
.ptab thead{background:var(--cream)}
.ptab th{text-align:left;font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:0.04em;text-transform:uppercase;color:var(--ink-2);padding:12px 16px;border-bottom:1px solid #E7E3DA}
.ptab td{padding:14px 16px;border-bottom:1px solid #E7E3DA;vertical-align:top;color:var(--ink);line-height:1.55}
.ptab tr:last-child td{border-bottom:0}
.ptab td:first-child{font-weight:500;width:34%}
@media (max-width:560px){
  .ptab,.ptab thead,.ptab tbody,.ptab tr,.ptab th,.ptab td{display:block}
  .ptab thead{display:none}
  .ptab tr{border-bottom:1px solid #E7E3DA;padding:12px 0}
  .ptab tr:last-child{border-bottom:0}
  .ptab td{padding:6px 4px;border-bottom:0;width:auto}
  .ptab td:first-child{font-weight:600;color:var(--teal);width:auto}
  .ptab td[data-label]::before{content:attr(data-label);display:block;font-size:11px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:var(--ink-2);margin-bottom:2px}
}

/* callout */
.callout{margin:20px 0;padding:22px 24px;border-radius:var(--r-card);border:1px solid #E7E3DA;background:var(--cream);display:grid;grid-template-columns:32px 1fr;gap:14px;align-items:start}
.callout svg{color:var(--teal);margin-top:4px}
.callout h3{font-family:var(--sans);font-size:14px;font-weight:600;color:var(--ink);text-transform:uppercase;letter-spacing:0.08em;margin:0 0 6px}
.callout p{font-size:15px;color:var(--ink-2);margin:0 0 6px;line-height:1.6}
.callout p:last-child{margin-bottom:0}
.callout--note{background:var(--amber-light, #FAEEDA);border-color:#e9d6b3}
.callout--note svg{color:var(--amber)}

/* rights grid */
.rights{list-style:none;padding:0;margin:0 0 16px;display:grid;grid-template-columns:1fr 1fr;gap:14px}
.rights li{padding:16px 18px;border:1px solid #E7E3DA;border-radius:8px;background:#fff;display:flex;flex-direction:column;gap:6px}
.rights li strong{font-family:var(--sans);font-size:15px;font-weight:600;color:var(--ink);display:flex;align-items:center;gap:8px}
.rights li strong svg{color:var(--teal);flex-shrink:0}
.rights li span{font-size:14px;color:var(--ink-2);line-height:1.55}
@media (max-width:720px){.rights{grid-template-columns:1fr}}
