/*
Theme Name: Caring Hands Signature
Theme URI: https://caringhandssignature.com
Author: Caring Hands Signature
Author URI: https://caringhandssignature.com
Description: Compassionate, nurse-led home-care theme for Caring Hands Signature Home Health Care, Inc. Custom classic theme with WordPress-managed menus, Contact Form 7 support, featured-image hero photos, and a full purple design system extracted from the approved designs. Serving Dallas and the greater DFW area.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: caring-hands-signature
*/

/* ==========================================================================
   0. Design tokens
   ========================================================================== */
:root {
  --ink:#2a1c44;
  --deep:#4b2e73;
  --royal:#5d3a8f;
  --primary:#6b46a8;
  --violet:#9a7cc4;
  --lilac:#c9b6e6;
  --lilac-2:#d9cdec;
  --tint:#f0e9f7;
  --tint-soft:#f3eef8;
  --card:#faf8fc;
  --bg:#efedf2;
  --line:#ece8f2;
  --line-2:#e0d8ec;
  --muted:#5b5470;
  --muted-2:#9a90ab;
  --muted-3:#b6acc9;
  --eyebrow:#8a72b0;
  --eyebrow-light:#b29ad4;
  --serif:'Playfair Display', Georgia, serif;
  --sans:'Work Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --container:1200px;
  --pad-x:clamp(20px, 5vw, 40px);
  --radius-card:18px;
  --shadow-card:0 18px 44px rgba(43,28,68,0.10);
  --shadow-soft:0 12px 40px rgba(43,28,68,0.08);
}

/* ==========================================================================
   1. Reset & base
   ========================================================================== */
*,*::before,*::after { box-sizing:border-box; }
html { -webkit-text-size-adjust:100%; }
body {
  margin:0;
  font-family:var(--sans);
  font-size:16px;
  line-height:1.6;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img { max-width:100%; height:auto; display:block; }
a { color:var(--primary); }
h1,h2,h3,h4,p { margin:0; }
button { font-family:inherit; }
:focus-visible { outline:3px solid var(--violet); outline-offset:2px; }

/* ==========================================================================
   2. Layout
   ========================================================================== */
.container {
  max-width:var(--container);
  margin-inline:auto;
  padding-inline:var(--pad-x);
}
.container.w-1100 { max-width:1100px; }
.container.w-1080 { max-width:1080px; }
.container.w-1000 { max-width:1000px; }
.container.w-920  { max-width:920px; }
.container.w-900  { max-width:900px; }
.container.w-860  { max-width:860px; }
.container.w-820  { max-width:820px; }
.container.w-760  { max-width:760px; }

.section    { padding-block:clamp(54px, 9vw, 92px); }
.section.lg { padding-block:clamp(56px, 9vw, 96px); }
.section.md { padding-block:clamp(52px, 8vw, 84px); }
.section.sm { padding-block:clamp(48px, 7vw, 72px); }
.section.xs { padding-block:clamp(46px, 7vw, 70px); }

.bg-white { background:#fff; }
.bg-mist  { background:var(--bg); }
.bg-deep  { background:var(--deep); }
.bg-ink   { background:var(--ink); }
.bg-card  { background:var(--card); }
.cta-band { background:linear-gradient(120deg, #6b46a8 0%, #4b2e73 100%); }
.edge-top { border-bottom:1px solid var(--line); }

.relative { position:relative; }
.clip { overflow:hidden; }

/* Decorative blurred circles used on deep-purple heroes */
.orb { position:absolute; border-radius:50%; pointer-events:none; }
.orb.a { right:-100px; top:-120px; width:380px; height:380px; background:var(--royal); opacity:.55; }
.orb.b { right:160px; bottom:-160px; width:280px; height:280px; background:var(--primary); opacity:.35; }
.orb.c { right:-100px; top:-120px; width:360px; height:360px; background:var(--royal); opacity:.55; }
.orb.d { right:-90px; top:-110px; width:320px; height:320px; background:var(--royal); opacity:.5; }

/* ==========================================================================
   3. Typography helpers
   ========================================================================== */
.serif { font-family:var(--serif); font-weight:500; }
.italic { font-style:italic; }
.ls-tight  { letter-spacing:-0.4px; }
.ls-tighter{ letter-spacing:-0.5px; }

.eyebrow {
  font-size:12px; letter-spacing:2.5px; text-transform:uppercase;
  font-weight:600; color:var(--eyebrow);
}
.eyebrow.light { color:var(--eyebrow-light); }

.t-56 { font-size:clamp(34px,7vw,56px);   line-height:1.1;  }
.t-52 { font-size:clamp(33px,6.6vw,52px); line-height:1.12; }
.t-50 { font-size:clamp(32px,6.4vw,50px); line-height:1.12; }
.t-46 { font-size:clamp(30px,6vw,46px);   line-height:1.14; }
.t-42 { font-size:clamp(28px,5.4vw,42px); line-height:1.15; }
.t-40 { font-size:clamp(28px,5vw,40px);   line-height:1.2;  }
.t-38 { font-size:clamp(27px,4.7vw,38px); line-height:1.2;  }
.t-36 { font-size:clamp(26px,4.4vw,36px); line-height:1.2;  }
.t-34 { font-size:clamp(25px,4.2vw,34px); line-height:1.2;  }
.t-34.tall { line-height:1.25; }
.t-32 { font-size:clamp(24px,4vw,32px);   line-height:1.2;  }
.t-30 { font-size:clamp(23px,3.7vw,30px); line-height:1.2;  }
.t-26 { font-size:clamp(20px,3.2vw,26px); line-height:1.5;  }
.t-25 { font-size:clamp(20px,3vw,25px);   line-height:1.6;  }
.t-24 { font-size:24px; line-height:1.25; }
.t-23 { font-size:23px; line-height:1.25; }
.t-22 { font-size:22px; line-height:1.3;  }

.c-ink    { color:var(--ink); }
.c-white  { color:#fff; }
.c-deep   { color:var(--deep); }
.c-primary{ color:var(--primary); }
.c-lilac  { color:var(--lilac); }
.on-deep  { color:#e2d8f0; }

.lead     { font-size:18px; line-height:1.7; color:var(--muted); }
.lead.lg  { font-size:19px; }
.lead.on-deep { color:#e2d8f0; }
.body     { font-size:17px; line-height:1.8; color:var(--muted); }
.body-15  { font-size:15px; line-height:1.7; color:var(--muted); }
.note     { font-size:13px; line-height:1.6; color:var(--muted-2); }
.measure  { max-width:600px; }
.measure.sm { max-width:480px; }
.measure.lg { max-width:680px; }
.center   { text-align:center; }
.mx-auto  { margin-inline:auto; }
.stack-tight > * + * { margin-top:22px; }

/* Pull-quote on About */
.pullquote { border-left:3px solid var(--lilac); padding-left:26px; }
.pullquote p { font-family:var(--serif); font-style:italic; font-size:23px; line-height:1.5; color:var(--deep); margin:0 0 16px; }
.byline { font-size:14px; font-weight:600; color:var(--primary); }

/* ==========================================================================
   4. Buttons
   ========================================================================== */
.btn {
  display:inline-block; font-family:var(--sans); font-size:15px; font-weight:600;
  text-decoration:none; border:none; border-radius:26px; cursor:pointer;
  transition:background .2s ease, border-color .2s ease, color .2s ease;
  text-align:center; line-height:1.2;
}
.btn--primary    { background:var(--primary); color:#fff; padding:15px 32px; }
.btn--primary:hover { background:var(--deep); }
.btn--outline    { background:#fff; color:var(--deep); border:1.5px solid #cfc4e0; padding:13px 28px; }
.btn--outline:hover { border-color:var(--primary); background:#f6f2fb; }
.btn--white      { background:#fff; color:var(--deep); padding:15px 32px; }
.btn--white:hover{ background:#efe9f5; }
.btn--ghost-light{ background:rgba(255,255,255,0.08); color:#fff; border:1.5px solid rgba(255,255,255,0.45); padding:13px 28px; }
.btn--ghost-light:hover { background:rgba(255,255,255,0.18); }
.btn--outline-light { background:transparent; color:#fff; border:1.5px solid rgba(255,255,255,0.5); padding:13px 28px; }
.btn--outline-light:hover { background:rgba(255,255,255,0.12); }

.btn-row { display:flex; gap:14px; align-items:center; flex-wrap:wrap; }
.btn-row.center { justify-content:center; }

/* ==========================================================================
   5. Header
   ========================================================================== */
.site-header { position:sticky; top:0; z-index:100; font-family:var(--sans); }

.utility-strip { background:var(--deep); color:var(--lilac-2); font-size:13px; }
.utility-strip .container { display:flex; align-items:center; justify-content:space-between; gap:14px; padding-block:8px; }
.utility-strip .area { color:var(--eyebrow-light); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.utility-strip .call { color:#fff; text-decoration:none; font-weight:500; display:inline-flex; align-items:center; gap:8px; flex:none; }
.utility-strip .call:hover { color:#c9b6e6; }
.dot-phone { display:inline-block; width:15px; height:15px; border:1.5px solid currentColor; border-radius:4px; transform:rotate(-8deg); }

.header-bar { background:#fff; box-shadow:0 1px 0 var(--line); transition:box-shadow .25s ease; }
.site-header.scrolled .header-bar { box-shadow:0 6px 24px rgba(43,28,68,0.10); }
.header-bar .container { display:flex; align-items:center; justify-content:space-between; gap:16px; padding-block:16px; }

.brand { text-decoration:none; line-height:1; flex:none; display:inline-block; }
.brand .b1 { font-weight:700; color:var(--deep); letter-spacing:-0.5px; }
.brand .b2 { font-weight:300; color:var(--primary); letter-spacing:-0.5px; }
.brand.lg .b1, .brand.lg .b2 { font-size:clamp(20px,4.6vw,25px); }
.brand.sm .b1, .brand.sm .b2 { font-size:20px; }

/* Desktop nav (WordPress menu) */
.primary-nav { display:flex; align-items:center; gap:28px; }
.primary-nav ul { list-style:none; margin:0; padding:0; display:flex; align-items:center; gap:28px; }
.primary-nav li { position:relative; }
.primary-nav a {
  font-size:15px; font-weight:500; color:var(--muted); text-decoration:none;
  padding-bottom:4px; border-bottom:2px solid transparent; transition:color .2s ease; white-space:nowrap;
}
.primary-nav a:hover { color:var(--primary); }
.primary-nav .current-menu-item > a,
.primary-nav .current-menu-parent > a,
.primary-nav .current-menu-ancestor > a { color:var(--primary); border-color:var(--primary); }
.primary-nav .menu-item-has-children > a::after {
  content:"▾"; font-size:10px; color:var(--violet); margin-left:6px;
}
.primary-nav .sub-menu {
  position:absolute; top:28px; left:-16px; width:268px; list-style:none; margin:0; padding:8px;
  background:#fff; border:1px solid var(--line); border-radius:12px;
  box-shadow:0 16px 40px rgba(43,28,68,0.16);
  opacity:0; transform:translateY(-6px); pointer-events:none;
  transition:opacity .2s ease, transform .2s ease; z-index:20;
  display:flex; flex-direction:column; gap:2px;
}
.primary-nav .menu-item-has-children:hover > .sub-menu,
.primary-nav .menu-item-has-children:focus-within > .sub-menu { opacity:1; transform:none; pointer-events:auto; }
.primary-nav .sub-menu a {
  display:block; padding:11px 14px; border-radius:8px; border:none;
  font-size:14px; font-weight:500; color:var(--ink);
}
.primary-nav .sub-menu a:hover { background:var(--tint-soft); color:var(--primary); }

.nav-cta { display:inline-flex; }
.nav-cta .btn { padding:11px 22px; font-size:14px; }

/* Hamburger */
.nav-toggle {
  display:none; flex:none; width:46px; height:46px; border:none; background:var(--tint-soft);
  border-radius:12px; flex-direction:column; align-items:center; justify-content:center; gap:5px; cursor:pointer; padding:0;
}
.nav-toggle span { width:20px; height:2px; background:var(--deep); border-radius:2px; }

/* Mobile drawer */
.drawer-root { position:fixed; inset:0; z-index:300; pointer-events:none; }
.drawer-backdrop { position:absolute; inset:0; background:rgba(20,12,36,0.5); opacity:0; transition:opacity .28s ease; }
.drawer-panel {
  position:absolute; top:0; right:0; bottom:0; width:min(86vw,360px); background:#fff;
  box-shadow:-16px 0 50px rgba(43,28,68,0.24); transform:translateX(100%);
  transition:transform .3s cubic-bezier(.4,0,.2,1); display:flex; flex-direction:column; overflow-y:auto;
}
body.drawer-open .drawer-root { pointer-events:auto; }
body.drawer-open .drawer-backdrop { opacity:1; }
body.drawer-open .drawer-panel { transform:translateX(0); }
body.drawer-open { overflow:hidden; }
.drawer-head { display:flex; align-items:center; justify-content:space-between; padding:16px 18px; border-bottom:1px solid var(--line); position:sticky; top:0; background:#fff; }
.drawer-close { flex:none; width:44px; height:44px; border:none; background:var(--tint-soft); border-radius:11px; display:flex; align-items:center; justify-content:center; cursor:pointer; position:relative; padding:0; }
.drawer-close span { position:absolute; width:18px; height:2px; background:var(--deep); border-radius:2px; }
.drawer-close span:first-child { transform:rotate(45deg); }
.drawer-close span:last-child  { transform:rotate(-45deg); }
.drawer-nav { display:flex; flex-direction:column; padding:14px 14px 8px; }
.drawer-nav ul { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; }
.drawer-nav a { display:block; padding:13px 14px; border-radius:10px; text-decoration:none; font-size:16px; font-weight:600; color:var(--ink); }
.drawer-nav a:hover { background:var(--tint-soft); color:var(--primary); }
.drawer-nav .current-menu-item > a { background:var(--tint-soft); color:var(--primary); }
.drawer-nav .sub-menu { margin:0 0 6px; padding:0; list-style:none; }
.drawer-nav .sub-menu a { padding-left:22px; font-size:15px; font-weight:500; }
.drawer-nav .menu-item-has-children > a { position:relative; }
.drawer-label { font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--muted-2); font-weight:600; padding:18px 14px 8px; }
.drawer-divide { height:1px; background:var(--line); margin:14px; }
.drawer-cta { display:block; text-align:center; margin:16px 14px 8px; font-size:15px; font-weight:600; text-decoration:none; color:#fff; background:var(--primary); padding:15px 22px; border-radius:26px; }
.drawer-cta:hover { background:var(--deep); }
.drawer-call { display:flex; align-items:center; justify-content:center; gap:9px; margin:4px 14px 18px; font-size:15px; font-weight:600; text-decoration:none; color:var(--deep); padding:13px 22px; border-radius:26px; border:1.5px solid #cfc4e0; }
.drawer-call:hover { background:#f6f2fb; }

@media (max-width:960px) {
  .primary-nav, .nav-cta { display:none; }
  .nav-toggle { display:flex; }
}

/* ==========================================================================
   6. Hero blocks
   ========================================================================== */
.hero-split {
  display:grid; grid-template-columns:repeat(auto-fit, minmax(min(100%,320px),1fr));
  gap:60px; align-items:center;
}
.hero-split.gap-lg { gap:64px; }

.photo {
  border-radius:20px; overflow:hidden;
  background:repeating-linear-gradient(135deg,#e7e0f1,#e7e0f1 12px,#dccff0 12px,#dccff0 24px);
  box-shadow:0 24px 60px rgba(43,28,68,0.16);
  display:flex; align-items:flex-end; justify-content:center; padding:22px; position:relative;
}
.photo.ratio { aspect-ratio:4/5; }
.photo img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }

/* Optional cover image behind the deep-purple text heroes */
.hero-bg { position:absolute; inset:0; }
.hero-bg img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.hero-bg-veil { position:absolute; inset:0; background:linear-gradient(100deg, rgba(38,23,62,0.92) 0%, rgba(43,28,68,0.80) 55%, rgba(75,46,115,0.55) 100%); }
.photo .ph-label {
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace; font-size:12px; color:var(--primary);
  background:rgba(255,255,255,0.75); padding:7px 13px; border-radius:8px; position:relative; z-index:1;
}

/* Floating "nurse-founded" card on Home hero A */
.float-card {
  position:absolute; left:-28px; bottom:40px; background:#fff; border-radius:14px;
  box-shadow:0 16px 40px rgba(43,28,68,0.16); padding:18px 22px; display:flex; align-items:center; gap:14px;
}
.float-mark { width:44px; height:44px; border-radius:12px; background:var(--deep); display:flex; align-items:center; justify-content:center; flex:none; }
.float-mark .m1 { font-weight:700; font-size:20px; color:#fff; }
.float-mark .m2 { font-weight:300; font-size:20px; color:var(--lilac); }
.float-title { font-size:14px; font-weight:700; color:var(--ink); }
.float-sub { font-size:13px; color:var(--muted-2); }

@media (max-width:600px){ .float-card { left:0; } }

/* ==========================================================================
   7. Cards, grids, components
   ========================================================================== */
.grid { display:grid; gap:24px; }
.grid.auto-200 { grid-template-columns:repeat(auto-fit, minmax(min(100%,200px),1fr)); }
.grid.auto-220 { grid-template-columns:repeat(auto-fit, minmax(min(100%,220px),1fr)); }
.grid.auto-240 { grid-template-columns:repeat(auto-fit, minmax(min(100%,240px),1fr)); }
.grid.auto-270 { grid-template-columns:repeat(auto-fit, minmax(min(100%,270px),1fr)); }
.grid.auto-300 { grid-template-columns:repeat(auto-fit, minmax(min(100%,300px),1fr)); }
.grid.gap-18 { gap:18px; }
.grid.gap-20 { gap:20px; }
.grid.gap-28 { gap:28px; }

.icon-tile { width:52px; height:52px; border-radius:14px; background:var(--tint); display:flex; align-items:center; justify-content:center; flex:none; }
.icon-tile.sm { width:44px; height:44px; border-radius:12px; }
.icon-tile.on-deep { background:var(--primary); }
.icon-tile svg { display:block; }

/* Service snapshot card */
.service-card { background:#fff; border:1px solid var(--line); border-radius:var(--radius-card); padding:36px; transition:transform .2s ease, box-shadow .2s ease; }
.service-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-card); }
.service-card .icon-tile { margin-bottom:22px; }
.service-card h3 { font-family:var(--serif); font-weight:500; font-size:23px; color:var(--ink); margin:0 0 12px; }
.service-card p { font-size:15px; line-height:1.7; color:var(--muted); margin:0 0 20px; }
.arrow-link { font-size:15px; font-weight:600; color:var(--primary); text-decoration:none; }
.arrow-link:hover { color:var(--deep); }

/* Plain value card (philosophy / careers reasons) */
.value-card { background:#fff; border:1px solid var(--line); border-radius:var(--radius-card); padding:40px; }
.value-card .icon-tile { margin-bottom:22px; }
.value-card h3 { font-family:var(--serif); font-weight:500; font-size:22px; color:var(--ink); margin:0 0 12px; }
.value-card p { font-size:15px; line-height:1.7; color:var(--muted); margin:0; }

.reason-card { background:#fff; border:1px solid var(--line); border-radius:16px; padding:28px; }
.reason-card h3 { font-size:17px; font-weight:700; color:var(--ink); margin:0 0 8px; }
.reason-card p { font-size:14px; line-height:1.65; color:var(--muted); margin:0; }
.span-2 { grid-column:span 2; }
@media (max-width:700px){ .span-2 { grid-column:auto; } }

/* "What's included" item */
.included { display:flex; gap:18px; align-items:flex-start; background:var(--card); border:1px solid var(--line); border-radius:16px; padding:26px; }
.included.p-28 { padding:28px; }
.included h3 { font-size:17px; font-weight:700; color:var(--ink); margin:0 0 6px; }
.included p { font-size:14px; line-height:1.65; color:var(--muted); margin:0; }

/* Trust bar item */
.trust-item { display:flex; flex-direction:column; gap:12px; }
.trust-item h3 { font-size:16px; font-weight:700; color:#fff; margin:0; }
.trust-item p { font-size:14px; line-height:1.6; color:#c2b3da; margin:0; }

/* Numbered steps (Personal "how it works", About list) */
.steps { display:grid; grid-template-columns:repeat(auto-fit, minmax(min(100%,220px),1fr)); gap:28px; }
.step-num { font-family:var(--serif); font-size:clamp(23px,3.7vw,30px); color:var(--lilac); font-weight:600; margin-bottom:14px; }
.step h3 { font-size:18px; font-weight:700; color:#fff; margin:0 0 8px; }
.step p { font-size:15px; line-height:1.7; color:#d2c6e6; margin:0; }

.rows { display:flex; flex-direction:column; }
.row-item { display:flex; gap:28px; padding:28px 0; border-top:1px solid var(--line); }
.row-item:last-child { border-bottom:1px solid var(--line); }
.row-num { font-family:var(--serif); font-size:20px; color:var(--lilac); font-weight:600; width:40px; flex:none; }
.row-item h3 { font-size:18px; font-weight:700; color:var(--ink); margin:0 0 6px; }
.row-item p { font-size:15px; line-height:1.7; color:var(--muted); margin:0; }

/* Requirement checklist (Careers, dark) */
.checklist { display:grid; grid-template-columns:repeat(auto-fit, minmax(min(100%,280px),1fr)); gap:16px 48px; }
.check { display:flex; gap:14px; align-items:flex-start; padding:14px 0; border-bottom:1px solid var(--royal); }
.check-mark { width:22px; height:22px; border-radius:50%; background:var(--primary); flex:none; display:flex; align-items:center; justify-content:center; margin-top:1px; }
.check-mark::after { content:""; width:8px; height:4px; border-left:2px solid #fff; border-bottom:2px solid #fff; transform:rotate(-45deg); margin-top:-2px; }
.check span.t { font-size:16px; color:#e2d8f0; }
.check span.t .muted { color:var(--eyebrow-light); }

/* Signature panel (Home) */
.panel-feature { background:var(--deep); border-radius:24px; padding:clamp(32px,6vw,72px); position:relative; overflow:hidden; }
.panel-feature .glow { position:absolute; right:-80px; top:-80px; width:320px; height:320px; border-radius:50%; background:var(--royal); opacity:.6; }
.panel-feature .inner { position:relative; max-width:680px; }

/* Testimonials */
.quote-card { background:var(--card); border:1px solid var(--line); border-radius:var(--radius-card); padding:40px; }
.quote-mark { font-family:var(--serif); font-size:clamp(28px,5vw,40px); line-height:1; color:var(--lilac); margin-bottom:8px; }
.quote-card p { font-family:var(--serif); font-style:italic; font-size:22px; line-height:1.5; color:var(--ink); margin:0 0 24px; }
.quote-card .byline { font-size:14px; font-weight:600; color:var(--primary); }
.tag { font-size:12px; font-weight:600; letter-spacing:1px; text-transform:uppercase; color:var(--violet); background:var(--tint-soft); padding:8px 16px; border-radius:20px; }
.split-head { display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; }

/* Comparison cards (Live-In) */
.compare-card { background:#fff; border:1px solid var(--line); border-radius:var(--radius-card); padding:38px; }
.compare-card .kicker { font-size:12px; letter-spacing:2px; text-transform:uppercase; color:var(--violet); font-weight:600; margin-bottom:14px; }
.compare-card p { font-size:17px; line-height:1.75; color:var(--muted); margin:0; }

/* Callout (good-to-know) */
.callout { background:var(--card); border:1px solid var(--line); border-left:4px solid var(--violet); border-radius:12px; padding:30px 34px; }
.callout h3 { font-size:16px; font-weight:700; color:var(--deep); margin:0 0 10px; }
.callout p { font-size:16px; line-height:1.75; color:var(--muted); margin:0; }
.callout strong { color:var(--ink); }
.callout.warn { background:#fdf6ec; border-color:#f0e2c8; border-left-color:#d9a441; }
.callout.warn p { color:#8a6d2f; }
.callout.warn strong { color:#6e561f; }

/* ==========================================================================
   8. Contact details
   ========================================================================== */
.contact-list { display:flex; flex-direction:column; gap:26px; }
.contact-row { display:flex; gap:16px; align-items:flex-start; }
.contact-row .lbl { font-size:13px; color:var(--muted-2); margin-bottom:3px; }
.contact-row .val { font-size:16px; font-weight:600; color:var(--ink); line-height:1.5; }
.contact-row a.val { color:var(--deep); text-decoration:none; }
.contact-row a.val.big { font-size:18px; }
.contact-row .val .reg { font-weight:400; color:var(--muted); }
.contact-divide { border-top:1px solid #ddd5e8; padding-top:22px; }

/* ==========================================================================
   9. Forms (styled to wrap Contact Form 7 output)
   ========================================================================== */
.form-card { background:#fff; border:1px solid var(--line); border-radius:20px; padding:clamp(26px,5vw,44px); box-shadow:var(--shadow-soft); }
.form-stack { display:flex; flex-direction:column; gap:20px; }
.form-stack.gap-22 { gap:22px; }
.form-pair { display:grid; grid-template-columns:repeat(auto-fit, minmax(min(100%,220px),1fr)); gap:18px; }
.field label, .ch-label { display:block; font-size:13px; font-weight:600; color:var(--muted); margin-bottom:8px; }
.req { color:var(--violet); }

.ch-input,
.ch-form input[type=text], .ch-form input[type=email], .ch-form input[type=tel],
.ch-form input[type=file], .ch-form select, .ch-form textarea,
.wpcf7 input[type=text], .wpcf7 input[type=email], .wpcf7 input[type=tel],
.wpcf7 input[type=file], .wpcf7 select, .wpcf7 textarea {
  width:100%; box-sizing:border-box; font-family:var(--sans); font-size:15px; color:var(--ink);
  padding:13px 15px; border:1.5px solid var(--line-2); border-radius:10px; background:#fff; outline:none;
  transition:border-color .15s ease;
}
.ch-input:focus, .ch-form input:focus, .ch-form select:focus, .ch-form textarea:focus,
.wpcf7 input:focus, .wpcf7 select:focus, .wpcf7 textarea:focus { border-color:var(--primary); }
.ch-input::placeholder, .ch-form ::placeholder, .wpcf7 ::placeholder { color:#b3aac2; }
.ch-form input[type=file], .wpcf7 input[type=file] { padding:11px 15px; }
textarea.ch-input, .ch-form textarea, .wpcf7 textarea { resize:vertical; }
select.ch-input, .ch-form select, .wpcf7 select {
  appearance:none; -webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%239a7cc4' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 15px center; padding-right:38px;
}
.checkrow { display:flex; gap:22px; flex-wrap:wrap; }
.checkrow label { display:flex; align-items:center; gap:9px; font-size:15px; color:var(--ink); cursor:pointer; }
.checkrow input[type=checkbox] { width:17px; height:17px; accent-color:var(--primary); }

.btn-submit, .ch-form input[type=submit], .wpcf7 input[type=submit] {
  font-family:var(--sans); font-size:15px; font-weight:600; color:#fff; background:var(--primary);
  padding:15px 36px; border-radius:26px; border:none; cursor:pointer; transition:background .2s ease;
}
.btn-submit:hover, .ch-form input[type=submit]:hover, .wpcf7 input[type=submit]:hover { background:var(--deep); }
.form-foot { display:flex; flex-direction:column; gap:14px; align-items:flex-start; }

/* CF7 status messages */
.wpcf7 form .wpcf7-response-output { border-radius:10px; font-size:14px; margin:18px 0 0; padding:12px 16px; }

/* Success state (theme fallback) */
.form-success { text-align:center; padding:32px 8px; }
.form-success.boxed { background:#fff; border:1px solid var(--line); border-radius:20px; padding:56px 48px; box-shadow:var(--shadow-soft); }
.success-mark { width:60px; height:60px; border-radius:50%; background:var(--tint); display:flex; align-items:center; justify-content:center; margin:0 auto 22px; }
.success-mark::after { content:""; width:20px; height:10px; border-left:3px solid var(--primary); border-bottom:3px solid var(--primary); transform:rotate(-45deg); margin-top:-4px; }

/* ==========================================================================
   10. Prose (Privacy / default page content)
   ========================================================================== */
.prose-card { background:#fff; border:1px solid var(--line); border-radius:var(--radius-card); padding:clamp(28px,6vw,52px) clamp(22px,6vw,56px); box-shadow:0 1px 3px rgba(0,0,0,0.05); }
.prose h2 { font-family:var(--serif); font-weight:500; font-size:24px; color:var(--ink); margin:36px 0 12px; }
.prose h2:first-child { margin-top:0; }
.prose p { font-size:16px; line-height:1.8; color:var(--muted); margin:0 0 32px; }
.prose p.intro { font-size:17px; color:var(--ink); font-weight:500; margin-bottom:36px; }
.prose p:last-child { margin-bottom:0; }
.prose a { color:var(--primary); font-weight:600; text-decoration:none; }
.prose strong { color:var(--ink); }

/* ==========================================================================
   11. Footer
   ========================================================================== */
.site-footer { font-family:var(--sans); background:var(--ink); color:var(--lilac-2); }
.site-footer .container { padding-top:clamp(52px,8vw,72px); padding-bottom:0; }
.footer-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(min(100%,190px),1fr)); gap:40px clamp(28px,4vw,48px); padding-bottom:clamp(40px,6vw,56px); }
.footer-brand .name { line-height:1; margin-bottom:18px; }
.footer-brand .name .b1 { font-weight:700; font-size:22px; color:#fff; letter-spacing:-0.4px; }
.footer-brand .name .b2 { font-weight:300; font-size:22px; color:var(--lilac); letter-spacing:-0.4px; }
.footer-brand .sub { font-size:11px; letter-spacing:2.5px; text-transform:uppercase; color:var(--eyebrow); margin-bottom:20px; }
.footer-brand p { font-size:15px; line-height:1.7; color:var(--muted-3); margin:0; max-width:280px; }
.footer-col .head { font-size:12px; letter-spacing:2px; text-transform:uppercase; color:var(--eyebrow); font-weight:600; margin-bottom:20px; }
.footer-col ul { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:13px; }
.footer-col a { font-size:14px; color:var(--lilac-2); text-decoration:none; }
.footer-col a:hover { color:#fff; }
.footer-contact { display:flex; flex-direction:column; gap:13px; font-size:14px; line-height:1.55; }
.footer-contact span { color:var(--muted-3); }
.footer-contact a { text-decoration:none; }
.footer-contact a.phone { color:#fff; font-weight:500; }
.footer-contact a.phone:hover { color:var(--lilac); }
.footer-contact a.email { color:var(--lilac-2); }
.footer-contact a.email:hover { color:#fff; }
.footer-bar { border-top:1px solid #3d2c5c; padding:26px 0 30px; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:14px; }
.footer-bar .copy { font-size:13px; color:var(--eyebrow); }
.footer-bar .fine { font-size:12.5px; color:#6e5f8a; max-width:620px; line-height:1.6; }

/* ==========================================================================
   12. Utilities
   ========================================================================== */
.mb-0 { margin-bottom:0; }
.mb-14 { margin-bottom:14px; }
.mb-16 { margin-bottom:16px; }
.mb-18 { margin-bottom:18px; }
.mb-20 { margin-bottom:20px; }
.mb-22 { margin-bottom:22px; }
.mb-24 { margin-bottom:24px; }
.mb-28 { margin-bottom:28px; }
.mb-30 { margin-bottom:30px; }
.mb-34 { margin-bottom:34px; }
.mb-36 { margin-bottom:36px; }
.mb-40 { margin-bottom:40px; }
.mb-44 { margin-bottom:44px; }
.mb-48 { margin-bottom:48px; }
.mb-52 { margin-bottom:52px; }
.mt-24 { margin-top:24px; }
.block { display:block; }
.screen-reader-text { position:absolute !important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0; }
.skip-link { position:absolute; left:-9999px; top:0; background:#fff; color:var(--primary); padding:10px 18px; z-index:400; border-radius:0 0 8px 0; }
.skip-link:focus { left:0; }
