/* ===== Calm Space Care Homes — shared styles ===== */
:root{
  --bg:#F4F3EE;
  --band:#E9EAE3;
  --card:#FFFFFF;
  --green:#1C7A35;
  --green-deep:#15662B;
  --mint:#CFE7D2;
  --mint-soft:#E7F2E8;
  --ink:#3e3e38;          /* headings */
  --body:#5f5f57;         /* body text */
  --muted:#85857b;        /* captions */
  --line:#e3e2d9;
  --radius:22px;
  --shadow:0 14px 40px rgba(40,55,40,.08);
  --shadow-lg:0 24px 60px rgba(40,55,40,.13);
  --maxw:1140px;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;background:var(--bg);color:var(--body);
  font-family:'Nunito',system-ui,sans-serif;
  font-size:18px;line-height:1.65;-webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{color:var(--ink);font-weight:900;letter-spacing:-.012em;line-height:1.06;margin:0;}
p{margin:0 0 1.1em;text-wrap:pretty;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
.container{max-width:var(--maxw);margin:0 auto;padding:0 28px;}
.eyebrow{font-size:13px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--green);margin:0 0 14px;}
.accent{color:var(--green);}
section{padding:88px 0;}
.lead{font-size:21px;line-height:1.6;color:var(--body);}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;cursor:pointer;white-space:nowrap;
  background:var(--green);color:#fff;font-family:inherit;font-weight:800;font-size:16px;
  padding:14px 26px;border-radius:999px;border:none;transition:.18s ease;
}
.btn:hover{background:var(--green-deep);transform:translateY(-1px);box-shadow:0 10px 24px rgba(28,122,53,.28);}
.btn-outline{
  display:inline-flex;align-items:center;gap:9px;cursor:pointer;white-space:nowrap;
  background:#fff;color:var(--ink);font-family:inherit;font-weight:800;font-size:16px;
  padding:12px 24px;border-radius:999px;border:2px solid var(--line);transition:.18s ease;
}
.btn-outline:hover{border-color:var(--green);color:var(--green);transform:translateY(-1px);}
.btn-sm{padding:9px 18px;font-size:14px;}

/* ---------- placeholders ---------- */
.ph{
  background-color:#e7e6dd;
  background-image:repeating-linear-gradient(45deg,#dedcd1 0 13px,#e9e8df 13px 26px);
  display:flex;align-items:center;justify-content:center;text-align:center;
  color:#9a988c;font-family:ui-monospace,Menlo,monospace;font-size:12px;
  letter-spacing:.04em;text-transform:uppercase;border-radius:var(--radius);padding:18px;
}
/* real photos */
.photo{overflow:hidden;border-radius:var(--radius);background:#e7e6dd;}
.photo img{width:100%;height:100%;object-fit:cover;display:block;}
/* in side-by-side feature cards, the photo fills the text column's height
   instead of imposing its own intrinsic (portrait) height */
.home-feature .photo{position:relative;}
.home-feature .photo img{position:absolute;inset:0;}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(233,234,227,.86);backdrop-filter:blur(10px);border-bottom:1px solid rgba(0,0,0,.04);}
.site-header .container{display:flex;align-items:center;justify-content:space-between;height:84px;}
.nav-links{display:flex;gap:28px;list-style:none;margin:0;padding:0;font-size:15px;font-weight:700;white-space:nowrap;}
.nav-links a{color:var(--ink);position:relative;padding:4px 0;transition:.15s;}
.nav-links a:hover{color:var(--green);}
.nav-links a.active{color:var(--green);}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-3px;height:2.5px;background:var(--green);border-radius:2px;}
.nav-right{display:flex;align-items:center;gap:20px;}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:6px;}
.menu-toggle span{display:block;width:24px;height:2.5px;background:var(--ink);border-radius:2px;margin:5px 0;transition:.2s;}

/* ---------- logo ---------- */
.logo{display:flex;flex-direction:column;gap:3px;line-height:1;}
.logo .wm{font-weight:900;letter-spacing:.02em;font-size:21px;color:var(--green);display:flex;align-items:center;gap:9px;}
.logo .leaf{width:24px;height:15px;border-radius:1px 13px 1px 13px;background:var(--green);opacity:.85;flex:none;}
.logo .sub{font-size:9px;letter-spacing:.44em;font-weight:800;color:var(--green);padding-left:1px;}
.logo .rule{height:3px;width:104px;background:var(--green);border-radius:2px;margin-top:3px;}
.logo--lg .wm{font-size:30px;}
.logo--lg .leaf{width:33px;height:21px;}
.logo--lg .sub{font-size:12px;letter-spacing:.5em;}
.logo--lg .rule{width:150px;height:4px;}
/* real logo image */
.logo-link{display:inline-flex;align-items:center;}
.logo-img{height:44px;width:auto;display:block;}
.footer-logo .logo-img,.logo-img--lg{height:60px;}

/* ---------- footer ---------- */
.site-footer{background:var(--band);padding:64px 0 36px;margin-top:0;}
.footer-top{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:36px;align-items:start;}
.footer-top h4{font-size:14px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:16px;font-weight:800;}
.footer-links{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px;font-size:15px;font-weight:600;}
.footer-links a:hover{color:var(--green);}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line);margin-top:44px;padding-top:24px;font-size:13.5px;color:var(--muted);font-weight:600;}

/* ---------- cards & bits ---------- */
.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:30px;}
.pill{display:inline-flex;align-items:center;gap:8px;background:var(--mint-soft);color:var(--green-deep);font-weight:800;font-size:13px;padding:7px 15px;border-radius:999px;letter-spacing:.02em;}
.badge-good{display:inline-flex;align-items:center;gap:10px;background:#fff;border-radius:16px;padding:12px 18px;box-shadow:var(--shadow);}
.badge-good .tick{width:40px;height:40px;border-radius:11px;background:var(--mint);color:var(--green-deep);display:flex;align-items:center;justify-content:center;font-weight:900;font-size:20px;flex:none;}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.2,.7,.3,1),transform .7s cubic-bezier(.2,.7,.3,1);}
.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.08s;}.reveal.d2{transition-delay:.16s;}.reveal.d3{transition-delay:.24s;}.reveal.d4{transition-delay:.32s;}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none;}}

/* ---------- decorative blobs ---------- */
.blob{position:absolute;border-radius:50%;background:var(--mint-soft);z-index:0;pointer-events:none;}

/* ---------- quote / feedback carousel ---------- */
.quote-card{background:var(--mint-soft);border-radius:18px;padding:24px 26px;margin:0;}
.quote-card p{font-size:18px;line-height:1.5;color:var(--ink);font-weight:700;margin:0 0 12px;text-wrap:pretty;}
.quote-card figcaption{font-size:14px;color:var(--green-deep);font-weight:700;letter-spacing:.01em;}

.feedback{max-width:780px;margin:0 auto;text-align:center;}
.fb-tabs{display:inline-flex;background:var(--band);border-radius:999px;padding:5px;gap:4px;margin-bottom:30px;}
.fb-tab{border:none;background:transparent;font-family:inherit;font-weight:800;font-size:15px;color:var(--body);padding:10px 24px;border-radius:999px;cursor:pointer;transition:.18s ease;white-space:nowrap;}
.fb-tab:hover{color:var(--green);}
.fb-tab.active{background:#fff;color:var(--green);box-shadow:0 4px 14px rgba(40,55,40,.1);}
.fb-card{position:relative;background:#fff;border-radius:24px;box-shadow:var(--shadow);padding:44px 52px 48px;min-height:230px;display:flex;flex-direction:column;justify-content:center;margin:0;overflow:hidden;}
.fb-card::after{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--green-deep);}
.fb-mark{font-family:Georgia,'Times New Roman',serif;font-size:80px;line-height:1;color:var(--mint);height:34px;display:block;}
.fb-slide{margin:0;opacity:0;transform:translateY(8px);transition:opacity .35s ease,transform .35s ease;}
.fb-slide.show{opacity:1;transform:none;}
.fb-quote{font-size:clamp(20px,2.4vw,25px);line-height:1.45;color:var(--ink);font-weight:800;margin:10px 0 18px;text-wrap:pretty;}
.fb-attr{font-size:15px;color:var(--green-deep);font-weight:800;letter-spacing:.01em;}
.fb-controls{display:flex;align-items:center;justify-content:center;gap:18px;margin-top:26px;}
.fb-arrow{width:46px;height:46px;border-radius:50%;border:2px solid var(--line);background:#fff;color:var(--ink);font-size:24px;line-height:1;cursor:pointer;transition:.18s ease;display:flex;align-items:center;justify-content:center;padding:0 0 3px;}
.fb-arrow:hover{border-color:var(--green);color:var(--green);transform:translateY(-1px);}
.fb-dots{display:flex;gap:9px;align-items:center;}
.fb-dot{width:9px;height:9px;border-radius:50%;border:none;background:var(--line);cursor:pointer;padding:0;transition:.18s ease;}
.fb-dot:hover{background:var(--mint);}
.fb-dot.active{background:var(--green);transform:scale(1.25);}
@media (prefers-reduced-motion:reduce){.fb-slide{transition:none;}}
@media (max-width:560px){.fb-card{padding:32px 26px 36px;}}

/* ---------- forms ---------- */
.field{margin-bottom:18px;}
.field label{display:block;font-size:14px;font-weight:700;color:var(--ink);margin-bottom:7px;}
.field input,.field textarea,.field select{
  width:100%;font-family:inherit;font-size:16px;color:var(--ink);
  background:#fff;border:1.5px solid var(--line);border-radius:14px;padding:13px 16px;transition:.15s;
}
.field textarea{min-height:120px;resize:vertical;}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 4px rgba(28,122,53,.1);}

/* ---------- responsive ---------- */
@media (max-width:980px){
  section{padding:60px 0;}
  .nav-links{position:fixed;inset:84px 0 auto 0;white-space:normal;background:var(--band);flex-direction:column;gap:0;padding:8px 0;border-bottom:1px solid var(--line);transform:translateY(-130%);transition:.28s ease;box-shadow:var(--shadow);}
  .nav-links.open{transform:none;}
  .nav-links li{padding:0 28px;}
  .nav-links a{display:block;padding:14px 0;border-bottom:1px solid rgba(0,0,0,.05);}
  .nav-links a.active::after{display:none;}
  .menu-toggle{display:block;}
  .footer-top{grid-template-columns:1fr 1fr;gap:28px;}
  .intro-grid,.four-grid,.home-feature,.home-detail,.redvale-cards,.three-grid,.form-2col,.contact-grid,.feedback-grid{grid-template-columns:1fr !important;}
  .home-detail .reveal{position:static !important;}
  .four-grid{gap:18px;}
  .home-feature .ph{min-height:240px !important;}
}
@media (max-width:560px){
  body{font-size:17px;}
  .footer-top{grid-template-columns:1fr;}
  .footer-bottom{flex-direction:column;gap:10px;text-align:center;}
}
