/*
Theme Name: Bella Mente
Theme URI: https://bellamentegroup.com
Author: Bella Mente Inc.
Author URI: https://bellamentegroup.com
Description: A warm, person-centered custom theme for Bella Mente Inc., a Minnesota 245D-licensed home care agency serving communities statewide. Built to match the Bella Mente brand: dusty rose, terracotta, and soft cream with elegant serif headings.
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: bella-mente
*/

/* ============================================================
   BELLA MENTE - Brand Design System
   Palette pulled from the new brochure / color schema
   ============================================================ */
:root {
  --bm-cream:        #F1EBE3;
  --bm-cream-2:      #EAE2D8;
  --bm-card:         #FBF8F4;
  --bm-rose:         #CDA194;
  --bm-rose-deep:    #BB8B7C;
  --bm-blush:        #E8C8C0;
  --bm-blush-light:  #F3DCD5;
  --bm-terracotta:   #A9744E;
  --bm-terracotta-2: #8F5F3E;
  --bm-ink:          #34302B;
  --bm-muted:        #6E655E;
  --bm-line:         #E0D5C9;
  --bm-white:        #FFFFFF;

  --bm-serif: "Playfair Display", Georgia, "Times New Roman", serif;
  --bm-sans:  "Lato", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

  --bm-radius:    18px;
  --bm-radius-lg: 28px;
  --bm-radius-pill: 999px;
  --bm-shadow:    0 10px 30px rgba(52, 48, 43, 0.08);
  --bm-shadow-sm: 0 4px 14px rgba(52, 48, 43, 0.07);
  --bm-maxw:      1140px;
}

*,*::before,*::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--bm-sans);
  font-size: 18px;
  line-height: 1.7;
  color: var(--bm-ink);
  background: var(--bm-cream);
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--bm-terracotta); text-decoration: none; transition: color .2s ease; }
a:hover { color: var(--bm-terracotta-2); }

h1,h2,h3,h4 { font-family: var(--bm-serif); color: var(--bm-ink); font-weight: 600; line-height: 1.15; margin: 0 0 .5em; }
h1 { font-size: clamp(2.4rem, 5vw, 3.6rem); }
h2 { font-size: clamp(1.9rem, 3.4vw, 2.6rem); }
h3 { font-size: clamp(1.3rem, 2vw, 1.6rem); }
p  { margin: 0 0 1.1em; }

.bm-wrap { max-width: var(--bm-maxw); margin: 0 auto; padding: 0 24px; }
.bm-narrow { max-width: 780px; margin: 0 auto; padding: 0 24px; }
.bm-eyebrow { font-family: var(--bm-sans); text-transform: uppercase; letter-spacing: .22em; font-size: .78rem; font-weight: 700; color: var(--bm-terracotta); margin: 0 0 .8rem; }
.bm-center { text-align: center; }

.bm-btn { display: inline-block; font-family: var(--bm-sans); font-weight: 700; letter-spacing: .02em; font-size: 1rem; padding: 14px 30px; border-radius: var(--bm-radius-pill); border: 2px solid transparent; cursor: pointer; transition: all .2s ease; }
.bm-btn--primary { background: var(--bm-terracotta); color: #fff; }
.bm-btn--primary:hover { background: var(--bm-terracotta-2); color: #fff; transform: translateY(-1px); }
.bm-btn--ghost { background: transparent; color: var(--bm-ink); border-color: var(--bm-rose); }
.bm-btn--ghost:hover { background: var(--bm-rose); color: #fff; }
.bm-btn--light { background: var(--bm-card); color: var(--bm-ink); }
.bm-btn--light:hover { background: #fff; }

/* ── Header ─────────────────────────────────────── */
.bm-header { position: sticky; top: 0; z-index: 50; background: rgba(241,235,227,0.96); backdrop-filter: blur(8px); border-bottom: 1px solid var(--bm-line); }
.bm-header__inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 12px 28px; max-width: var(--bm-maxw); margin: 0 auto; }
.bm-brand { display: flex; align-items: center; flex-shrink: 0; }
.bm-brand img, .bm-brand svg { height: 54px; width: auto; }

/* ── Primary nav ────────────────────────────────── */
.bm-nav { display: flex; align-items: center; gap: 36px; }
.bm-nav__links { list-style: none; display: flex; align-items: center; gap: 30px; margin: 0; padding: 0; }
.bm-nav__link { font-family: var(--bm-sans); font-weight: 600; font-size: .95rem; color: var(--bm-ink); letter-spacing: .01em; white-space: nowrap; }
.bm-nav__link:hover { color: var(--bm-terracotta); }
.bm-nav__link--active { color: var(--bm-terracotta) !important; border-bottom: 2px solid var(--bm-terracotta); padding-bottom: 1px; }

/* ── Nav action buttons ─────────────────────────── */
.bm-nav__actions { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.bm-btn--outline { background: transparent; color: var(--bm-terracotta); border: 2px solid var(--bm-terracotta); }
.bm-btn--outline:hover { background: var(--bm-terracotta); color: #fff; }

/* ── Hamburger ──────────────────────────────────── */
.bm-burger { display: none; background: none; border: 0; cursor: pointer; padding: 8px; }
.bm-burger span { display: block; width: 26px; height: 2.5px; background: var(--bm-ink); margin: 5px 0; border-radius: 2px; transition: .25s; }

.bm-hero { position: relative; overflow: hidden; background: radial-gradient(120% 90% at 85% -10%, var(--bm-blush-light) 0%, transparent 55%), radial-gradient(90% 80% at -10% 110%, var(--bm-blush) 0%, transparent 50%), var(--bm-cream); padding: 90px 0 100px; }
.bm-hero__grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 56px; align-items: center; }
.bm-hero h1 { margin-bottom: .3em; }
.bm-hero p.lead { font-size: 1.2rem; color: var(--bm-muted); max-width: 38ch; }
.bm-hero__cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 26px; }
.bm-hero__card { background: var(--bm-card); border-radius: var(--bm-radius-lg); box-shadow: var(--bm-shadow); padding: 36px; text-align: center; }
.bm-hero__card .swirl { width: 64px; margin: 0 auto 10px; }
.bm-hero__card h3 { letter-spacing: .12em; text-transform: uppercase; font-family: var(--bm-sans); font-size: .8rem; color: var(--bm-muted); }
.bm-hero__card .phone { font-family: var(--bm-serif); font-size: 2rem; color: var(--bm-terracotta); margin: 6px 0; }
.bm-hero__card .sub { font-weight: 700; letter-spacing: .1em; font-size: .9rem; }
.bm-hero__card hr { border: 0; border-top: 1px solid var(--bm-line); margin: 22px 0; }
.bm-hero__card .contact-line { font-size: .98rem; color: var(--bm-ink); margin: 4px 0; }

.bm-section { padding: 84px 0; }
.bm-section--alt { background: var(--bm-cream-2); }
.bm-section--rose { background: var(--bm-rose); color: #fff; }
.bm-section--rose h2, .bm-section--rose h3 { color: #fff; }
.bm-section--rose .bm-eyebrow { color: #fff; opacity: .9; }
.bm-section__head { max-width: 720px; margin: 0 auto 52px; text-align: center; }
.bm-section__head p { color: var(--bm-muted); font-size: 1.1rem; }
.bm-section--rose .bm-section__head p { color: rgba(255,255,255,.92); }

.bm-grid { display: grid; gap: 26px; }
.bm-grid--3 { grid-template-columns: repeat(3, 1fr); }
.bm-grid--2 { grid-template-columns: repeat(2, 1fr); }
.bm-grid--4 { grid-template-columns: repeat(4, 1fr); }

.bm-card { background: var(--bm-card); border: 1px solid var(--bm-line); border-radius: var(--bm-radius); padding: 30px; box-shadow: var(--bm-shadow-sm); transition: transform .2s ease, box-shadow .2s ease; }
.bm-card:hover { transform: translateY(-4px); box-shadow: var(--bm-shadow); }
.bm-card .num { display: inline-flex; align-items: center; justify-content: center; width: 42px; height: 42px; border-radius: 50%; background: var(--bm-blush); color: var(--bm-terracotta-2); font-family: var(--bm-serif); font-weight: 700; font-size: 1.2rem; margin-bottom: 14px; }
.bm-card h3 { margin-bottom: .4em; }
.bm-card p { color: var(--bm-muted); margin: 0; font-size: 1rem; }

.bm-pills { display: flex; flex-direction: column; gap: 16px; }
.bm-pill { background: var(--bm-blush); color: var(--bm-ink); border-radius: var(--bm-radius-pill); padding: 16px 28px; text-align: center; font-weight: 700; font-size: 1.02rem; }

.bm-service { background: var(--bm-card); border: 1px solid var(--bm-line); border-radius: var(--bm-radius); padding: 34px; box-shadow: var(--bm-shadow-sm); }
.bm-service h3 { color: var(--bm-terracotta-2); }
.bm-service ul { margin: 14px 0 0; padding: 0; list-style: none; }
.bm-service li { padding: 9px 0 9px 30px; position: relative; border-bottom: 1px solid var(--bm-line); color: var(--bm-ink); font-size: 1.02rem; }
.bm-service li:last-child { border-bottom: 0; }
.bm-service li::before { content: ""; position: absolute; left: 4px; top: 17px; width: 10px; height: 10px; border-radius: 50%; background: var(--bm-rose); }

.bm-cta { background: radial-gradient(100% 120% at 0% 0%, var(--bm-blush) 0%, transparent 55%), var(--bm-terracotta); color: #fff; border-radius: var(--bm-radius-lg); padding: 56px; text-align: center; }
.bm-cta h2 { color: #fff; }
.bm-cta p { color: rgba(255,255,255,.95); max-width: 60ch; margin-left: auto; margin-right: auto; }
.bm-cta .phone-big { font-family: var(--bm-serif); font-size: clamp(2rem,4vw,2.8rem); margin: 10px 0 4px; }

.bm-note { background: var(--bm-blush-light); border-left: 4px solid var(--bm-rose); border-radius: 12px; padding: 20px 24px; color: var(--bm-ink); font-size: 1rem; }

.bm-page-hero { background: radial-gradient(110% 90% at 90% -20%, var(--bm-blush-light) 0%, transparent 55%), var(--bm-cream-2); padding: 70px 0 60px; text-align: center; }
.bm-content { padding: 70px 0; }
.bm-content :where(h2,h3) { margin-top: 1.4em; }
.bm-content ul, .bm-content ol { padding-left: 1.3em; }
.bm-content blockquote { border-left: 4px solid var(--bm-rose); margin: 1.4em 0; padding: .4em 1.2em; color: var(--bm-muted); font-style: italic; }

.bm-contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 44px; align-items: start; }
.bm-contact-card { background: var(--bm-card); border:1px solid var(--bm-line); border-radius: var(--bm-radius); padding: 30px; box-shadow: var(--bm-shadow-sm); }
.bm-contact-item { display:flex; gap:14px; align-items:flex-start; padding: 14px 0; border-bottom:1px solid var(--bm-line); }
.bm-contact-item:last-child { border-bottom:0; }
.bm-contact-item .ico { color: var(--bm-terracotta); flex: 0 0 auto; margin-top:3px; }
.bm-contact-item strong { display:block; }

.bm-footer { background: var(--bm-ink); color: #E9E2DA; padding: 64px 0 28px; }
.bm-footer a { color: var(--bm-blush); }
.bm-footer a:hover { color: #fff; }
.bm-footer__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 40px; }
.bm-footer h4 { color: #fff; font-family: var(--bm-sans); text-transform: uppercase; letter-spacing: .14em; font-size: .82rem; }
.bm-footer ul { list-style: none; padding: 0; margin: 0; }
.bm-footer li { margin: 8px 0; }
.bm-footer .brandline { font-family: var(--bm-serif); font-size: 1.4rem; color:#fff; letter-spacing:.06em; }
.bm-footer__bottom { border-top: 1px solid rgba(255,255,255,.14); margin-top: 44px; padding-top: 20px; display:flex; flex-wrap:wrap; gap:10px; justify-content: space-between; font-size: .85rem; color: #B9AFA5; }

@media (max-width: 960px) {
  .bm-hero__grid { grid-template-columns: 1fr; gap: 36px; }
  .bm-grid--3, .bm-grid--4 { grid-template-columns: repeat(2, 1fr); }
  .bm-footer__grid { grid-template-columns: 1fr 1fr; }
  .bm-contact-grid { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  body { font-size: 17px; }
  .bm-burger { display: block; }
  .bm-nav { position: absolute; top: 100%; right: 0; left: 0; background: var(--bm-cream); border-bottom: 1px solid var(--bm-line); flex-direction: column; align-items: stretch; gap: 0; display: none; padding: 8px 0 16px; }
  .bm-nav.is-open { display: flex; }
  .bm-nav__links { flex-direction: column; align-items: stretch; gap: 0; }
  .bm-nav__links li { padding: 0 24px; }
  .bm-nav__link { display: block; padding: 12px 0; border-bottom: 1px solid var(--bm-line); font-size: 1rem; }
  .bm-nav__actions { flex-direction: column; align-items: stretch; padding: 12px 24px 0; gap: 8px; }
  .bm-nav__actions .bm-btn { text-align: center; }
  .bm-grid--3, .bm-grid--4, .bm-grid--2 { grid-template-columns: 1fr; }
  .bm-footer__grid { grid-template-columns: 1fr; }
  .bm-cta { padding: 40px 24px; }
}
.aligncenter { margin-left:auto; margin-right:auto; }
.screen-reader-text { position:absolute; left:-9999px; }
