/* ===========================================================
   RADIANT CLEANING SERVICES — Core Stylesheet
   Brand: sage green + warm cream, hand-drawn botanical line art
   Display: Fraunces (organic, high-contrast serif)
   Body: Outfit (clean humanist sans)
   =========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700;1,9..144,400;1,9..144,500&family=Outfit:wght@300;400;500;600;700&display=swap');

:root{
  /* ---- Color tokens, drawn from the actual logo + business card ---- */
  --sage-deep:   #555A46;   /* logo circle green — primary brand */
  --sage-dark:   #3D4032;   /* deep sage for headers/footer */
  --sage-mid:    #767C61;   /* mid sage for secondary text/borders */
  --sage-pale:   #DDE0D2;   /* pale sage for soft section backgrounds */
  --cream:       #E3D9CD;   /* business card cream — base background */
  --cream-light: #F4EFE7;   /* lighter cream for cards */
  --cream-white: #FBF9F5;   /* near-white warm base */
  --ink:         #2B2D23;   /* warm near-black for body text */
  --gold:        #C9A857;   /* honey gold accent — CTAs, stars, highlights */
  --gold-deep:   #A98A3F;   /* darker gold for hover states */
  --terracotta:  #B6663F;   /* small accent for warmth, used sparingly */

  --radius-arch: 999px 999px 24px 24px;
  --radius-soft: 20px;
  --radius-pill: 999px;

  --shadow-soft: 0 12px 32px -16px rgba(43,45,35,0.25);
  --shadow-card: 0 8px 24px -12px rgba(43,45,35,0.18);

  --container: 1160px;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:'Outfit', sans-serif;
  background:var(--cream);
  color:var(--ink);
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4{
  font-family:'Fraunces', serif;
  font-weight:600;
  line-height:1.15;
  margin:0 0 .5em;
  color:var(--sage-dark);
  letter-spacing:-0.01em;
}
h1{ font-size:clamp(2.4rem, 5vw, 3.6rem); font-weight:600; }
h2{ font-size:clamp(1.8rem, 3.2vw, 2.6rem); }
h3{ font-size:1.3rem; }
p{ margin:0 0 1em; }
.eyebrow{
  font-family:'Outfit',sans-serif;
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:.78rem;
  font-weight:600;
  color:var(--gold-deep);
  display:inline-block;
  margin-bottom:.85em;
}
.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 24px;
}
section{ padding:88px 0; }
@media (max-width:720px){
  section{ padding:56px 0; }
  body{ font-size:16px; }
}

:focus-visible{
  outline:3px solid var(--gold-deep);
  outline-offset:3px;
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:'Outfit',sans-serif;
  font-weight:600;
  font-size:.98rem;
  padding:14px 28px;
  border-radius:var(--radius-pill);
  border:2px solid transparent;
  cursor:pointer;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease, color .15s ease;
}
.btn-primary{
  background:var(--sage-deep);
  color:var(--cream-white);
}
.btn-primary:hover{
  background:var(--sage-dark);
  transform:translateY(-2px);
  box-shadow:var(--shadow-soft);
}
.btn-gold{
  background:var(--gold);
  color:var(--sage-dark);
}
.btn-gold:hover{
  background:var(--gold-deep);
  color:var(--cream-white);
  transform:translateY(-2px);
  box-shadow:var(--shadow-soft);
}
.btn-outline{
  background:transparent;
  border-color:var(--sage-deep);
  color:var(--sage-deep);
}
.btn-outline:hover{
  background:var(--sage-deep);
  color:var(--cream-white);
}
.btn-row{ display:flex; flex-wrap:wrap; gap:14px; }

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky; top:0; z-index:200;
  background:rgba(251,249,245,0.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(85,90,70,0.12);
}
.nav-bar{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 24px;
  max-width:var(--container);
  margin:0 auto;
}
.brand{ display:flex; align-items:center; gap:12px; }
.brand img{ width:52px; height:52px; border-radius:50%; }
.brand-name{
  font-family:'Fraunces',serif;
  font-size:1.18rem;
  font-weight:600;
  color:var(--sage-dark);
  line-height:1.1;
}
.brand-name span{
  display:block;
  font-family:'Outfit',sans-serif;
  font-size:.7rem;
  font-weight:500;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--sage-mid);
}
.nav-links{
  display:flex; align-items:center; gap:28px;
}
.nav-links a{
  font-size:.92rem; font-weight:500; color:var(--ink);
  position:relative; padding:4px 0;
}
.nav-links a:hover{ color:var(--sage-deep); }
.nav-links .dropdown{ position:relative; }
.dropdown-menu{
  position:absolute; top:100%; left:0;
  background:var(--cream-white);
  border-radius:14px;
  box-shadow:var(--shadow-soft);
  padding:10px;
  min-width:230px;
  opacity:0; visibility:hidden; transform:translateY(8px);
  transition:all .18s ease;
}
.dropdown:hover .dropdown-menu,
.dropdown:focus-within .dropdown-menu{
  opacity:1; visibility:visible; transform:translateY(0);
}
.dropdown-menu a{
  display:block; padding:9px 12px; border-radius:8px; font-size:.9rem;
}
.dropdown-menu a:hover{ background:var(--cream); }
.nav-cta{ display:flex; align-items:center; gap:14px; }
.nav-phone{
  font-weight:600; font-size:.92rem; color:var(--sage-dark);
  display:flex; align-items:center; gap:6px;
}
.menu-toggle{
  display:none;
  background:none; border:none; cursor:pointer;
  font-size:1.6rem; color:var(--sage-dark);
}
@media (max-width: 980px){
  .nav-links{
    position:fixed; inset:64px 0 0 0;
    background:var(--cream-white);
    flex-direction:column; align-items:flex-start;
    padding:24px; gap:4px;
    transform:translateX(100%);
    transition:transform .25s ease;
    overflow-y:auto;
  }
  .nav-links.open{ transform:translateX(0); }
  .nav-links a{ width:100%; padding:14px 8px; border-bottom:1px solid rgba(85,90,70,.1); }
  .dropdown-menu{ position:static; opacity:1; visibility:visible; transform:none; box-shadow:none; display:none; }
  .dropdown.open .dropdown-menu{ display:block; }
  .menu-toggle{ display:block; }
  .nav-phone span.txt{ display:none; }
}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  background:linear-gradient(165deg, var(--sage-deep) 0%, var(--sage-dark) 100%);
  color:var(--cream-white);
  overflow:hidden;
  padding:96px 0 110px;
}
.hero::before{
  content:'';
  position:absolute; inset:0;
  background-image:radial-gradient(circle at 85% 18%, rgba(201,168,87,0.18), transparent 45%),
                    radial-gradient(circle at 8% 90%, rgba(255,255,255,0.06), transparent 40%);
  pointer-events:none;
}
.hero-grid{
  position:relative; z-index:1;
  display:grid; grid-template-columns:1.15fr .85fr; gap:48px; align-items:center;
}
.hero h1{ color:#fff; }
.hero-sub{ font-size:1.15rem; color:rgba(251,249,245,0.88); max-width:540px; margin-bottom:1.6em; }
.hero-badges{ display:flex; flex-wrap:wrap; gap:10px; margin-top:28px; }
.hero-badge{
  background:rgba(255,255,255,0.1);
  border:1px solid rgba(255,255,255,0.2);
  padding:8px 16px;
  border-radius:var(--radius-pill);
  font-size:.82rem; font-weight:500;
  display:flex; align-items:center; gap:6px;
}
.hero-art{
  position:relative;
  display:flex; align-items:center; justify-content:center;
}
.hero-art-circle{
  width:min(360px, 90%);
  aspect-ratio:1;
  border-radius:50%;
  background:radial-gradient(circle at 35% 30%, rgba(255,255,255,0.14), transparent 60%), rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.18);
  display:flex; align-items:center; justify-content:center;
  padding:32px;
}
.hero-art-circle img{ width:100%; }
@media (max-width:860px){
  .hero-grid{ grid-template-columns:1fr; }
  .hero-art{ order:-1; }
  .hero-art-circle{ width:min(260px,70%); margin:0 auto; }
}

/* ---------- Section helpers ---------- */
.section-head{ max-width:680px; margin-bottom:48px; }
.section-head.center{ margin-left:auto; margin-right:auto; text-align:center; }
.bg-cream-light{ background:var(--cream-light); }
.bg-sage{ background:var(--sage-deep); color:var(--cream-white); }
.bg-sage h2, .bg-sage h3{ color:var(--cream-white); }
.bg-pale{ background:var(--sage-pale); }

/* arched divider motif echoing the logo's stem shape */
.arch-divider{
  width:64px; height:88px;
  margin:0 auto 28px;
  border:3px solid var(--gold);
  border-bottom:none;
  border-radius:32px 32px 0 0;
  opacity:.85;
}

/* ---------- Cards ---------- */
.grid{ display:grid; gap:28px; }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.grid-2{ grid-template-columns:repeat(2,1fr); }
.grid-4{ grid-template-columns:repeat(4,1fr); }
@media (max-width:900px){
  .grid-3, .grid-4{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:620px){
  .grid-2, .grid-3, .grid-4{ grid-template-columns:1fr; }
}

.card{
  background:var(--cream-white);
  border-radius:var(--radius-soft);
  padding:32px 28px;
  box-shadow:var(--shadow-card);
  border:1px solid rgba(85,90,70,0.08);
}
.card .icon-mark{
  width:52px; height:52px;
  border-radius:50%;
  background:var(--sage-pale);
  color:var(--sage-deep);
  display:flex; align-items:center; justify-content:center;
  font-size:1.4rem;
  margin-bottom:18px;
}
.card h3{ margin-bottom:.4em; }
.card p{ color:var(--sage-mid); margin-bottom:0; font-size:.96rem; }
.card.center{ text-align:center; }
.card.center .icon-mark{ margin-left:auto; margin-right:auto; }

/* ---------- Service list rows ---------- */
.service-row{
  display:flex; align-items:flex-start; gap:16px;
  padding:18px 0;
  border-bottom:1px solid rgba(85,90,70,0.14);
}
.service-row:last-child{ border-bottom:none; }
.service-row .dot{
  width:8px;height:8px;border-radius:50%;background:var(--gold);
  margin-top:9px; flex-shrink:0;
}
.service-row h4{ font-family:'Outfit',sans-serif; font-weight:600; margin:0 0 4px; font-size:1.02rem; color:var(--sage-dark); }
.service-row p{ margin:0; color:var(--sage-mid); font-size:.93rem; }

/* ---------- Reviews ---------- */
.review-card{
  background:var(--cream-white);
  border-radius:var(--radius-soft);
  padding:28px;
  box-shadow:var(--shadow-card);
  display:flex; flex-direction:column; gap:14px;
}
.stars{ color:var(--gold); font-size:1.05rem; letter-spacing:2px; }
.review-card p{ color:var(--ink); font-size:.96rem; margin:0; flex-grow:1; }
.reviewer{ display:flex; align-items:center; gap:10px; margin-top:4px; }
.reviewer-avatar{
  width:38px;height:38px;border-radius:50%;
  background:var(--sage-deep); color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:'Fraunces',serif; font-weight:600;
}
.reviewer-name{ font-weight:600; font-size:.9rem; }
.reviewer-meta{ font-size:.78rem; color:var(--sage-mid); }

/* ---------- FAQ accordion ---------- */
.faq-item{
  border-bottom:1px solid rgba(85,90,70,0.16);
}
.faq-item:first-child{ border-top:1px solid rgba(85,90,70,0.16); }
.faq-q{
  width:100%; text-align:left;
  background:none; border:none; cursor:pointer;
  padding:20px 4px;
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  font-family:'Fraunces',serif; font-size:1.05rem; font-weight:500;
  color:var(--sage-dark);
}
.faq-q .plus{
  flex-shrink:0;
  width:28px;height:28px;border-radius:50%;
  border:1.5px solid var(--sage-mid);
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem; color:var(--sage-deep);
  transition:transform .2s ease;
}
.faq-item.open .faq-q .plus{ transform:rotate(45deg); }
.faq-a{
  max-height:0; overflow:hidden;
  transition:max-height .25s ease;
}
.faq-a p{ padding:0 4px 20px; color:var(--sage-mid); margin:0; font-size:.95rem; }
.faq-item.open .faq-a{ max-height:400px; }

/* ---------- CTA band ---------- */
.cta-band{
  background:linear-gradient(120deg, var(--sage-dark), var(--sage-deep));
  color:#fff; border-radius:28px;
  padding:56px 40px;
  display:flex; align-items:center; justify-content:space-between; gap:32px;
  flex-wrap:wrap;
}
.cta-band h2{ color:#fff; margin-bottom:.3em; }
.cta-band p{ color:rgba(255,255,255,.85); margin:0; }

/* ---------- Contact ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start; }
@media (max-width:860px){ .contact-grid{ grid-template-columns:1fr; } }
.contact-info-item{ display:flex; gap:14px; align-items:flex-start; margin-bottom:22px; }
.contact-info-item .ic{
  width:42px;height:42px;border-radius:50%;
  background:var(--sage-pale); color:var(--sage-deep);
  display:flex;align-items:center;justify-content:center; flex-shrink:0;
}
form.contact-form{
  background:var(--cream-white);
  border-radius:var(--radius-soft);
  padding:32px;
  box-shadow:var(--shadow-card);
  display:grid; gap:16px;
}
.contact-form label{ font-size:.85rem; font-weight:600; color:var(--sage-dark); display:block; margin-bottom:6px; }
.contact-form input, .contact-form select, .contact-form textarea{
  width:100%; padding:12px 14px;
  border:1.5px solid rgba(85,90,70,.25);
  border-radius:10px;
  font-family:'Outfit',sans-serif; font-size:.95rem;
  background:var(--cream-light);
  color:var(--ink);
}
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus{
  outline:none; border-color:var(--sage-deep);
}
.row-2{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media (max-width:480px){ .row-2{ grid-template-columns:1fr; } }

/* ---------- Service areas ---------- */
.area-chip{
  display:inline-flex; align-items:center; gap:8px;
  background:var(--cream-white);
  border:1px solid rgba(85,90,70,.18);
  padding:10px 18px; border-radius:var(--radius-pill);
  font-size:.9rem; font-weight:500;
}
.area-chips{ display:flex; flex-wrap:wrap; gap:12px; }

/* ---------- Footer ---------- */
footer{
  background:var(--sage-dark); color:rgba(251,249,245,0.85);
  padding:64px 0 28px;
}
.footer-grid{
  display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px;
  margin-bottom:48px;
}
@media (max-width:780px){ .footer-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:480px){ .footer-grid{ grid-template-columns:1fr; } }
footer h4{ color:#fff; font-family:'Outfit',sans-serif; font-size:.85rem; text-transform:uppercase; letter-spacing:.1em; margin-bottom:16px; }
footer a{ display:block; font-size:.9rem; padding:6px 0; color:rgba(251,249,245,0.78); }
footer a:hover{ color:var(--gold); }
.footer-brand{ display:flex; gap:12px; align-items:center; margin-bottom:14px; }
.footer-brand img{ width:46px; height:46px; border-radius:50%; }
.footer-bottom{
  border-top:1px solid rgba(251,249,245,0.14);
  padding-top:24px;
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px;
  font-size:.82rem; color:rgba(251,249,245,0.6);
}

/* ---------- Page hero (interior pages, shorter) ---------- */
.page-hero{
  background:linear-gradient(165deg, var(--sage-deep), var(--sage-dark));
  color:#fff; padding:64px 0 72px; position:relative; overflow:hidden;
}
.page-hero::before{
  content:'';
  position:absolute; inset:0;
  background:radial-gradient(circle at 90% 10%, rgba(201,168,87,0.16), transparent 45%);
}
.page-hero .container{ position:relative; z-index:1; }
.breadcrumb{ font-size:.82rem; color:rgba(255,255,255,.7); margin-bottom:18px; }
.breadcrumb a{ color:rgba(255,255,255,.9); }
.breadcrumb a:hover{ color:var(--gold); }
.page-hero h1{ color:#fff; max-width:760px; }
.page-hero .sub{ max-width:620px; color:rgba(255,255,255,.85); font-size:1.08rem; }

/* sticky mobile call bar */
.mobile-call-bar{
  display:none;
  position:fixed; bottom:0; left:0; right:0; z-index:300;
  background:var(--sage-dark);
  padding:12px 16px;
  box-shadow:0 -6px 20px rgba(0,0,0,.18);
  align-items:center; gap:10px;
}
.mobile-call-bar a{
  flex:1; text-align:center; padding:12px; border-radius:12px;
  font-weight:600; font-size:.92rem;
}
.mobile-call-bar .call{ background:var(--gold); color:var(--sage-dark); }
.mobile-call-bar .quote{ background:rgba(255,255,255,0.12); color:#fff; border:1px solid rgba(255,255,255,.3); }
@media (max-width:720px){
  .mobile-call-bar{ display:flex; }
  body{ padding-bottom:74px; }
}

.divider-leaf{
  display:flex; align-items:center; justify-content:center; gap:14px;
  margin:0 auto 32px; color:var(--sage-mid);
}
.divider-leaf::before, .divider-leaf::after{
  content:''; height:1px; width:60px; background:rgba(85,90,70,.3);
}

.two-col{ display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; }
@media (max-width:860px){ .two-col{ grid-template-columns:1fr; } }

.list-check{ display:grid; gap:12px; }
.list-check li{ display:flex; gap:10px; align-items:flex-start; font-size:.96rem; }
.list-check li .ck{
  width:22px;height:22px;border-radius:50%; background:var(--sage-pale); color:var(--sage-deep);
  display:flex; align-items:center; justify-content:center; flex-shrink:0; font-size:.7rem; margin-top:2px;
}
