:root{
  --bg:#f7f2ea;
  --card:#ffffff;
  --text:#111111;
  --muted:#3a3a3a;
  --line:#e6ddd3;
  --accent:#111111;
  --accent2:#f2c200;
  --shadow: 0 12px 34px rgba(0,0,0,.10);
  --radius:18px;
  --max:1120px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Apple Color Emoji","Segoe UI Emoji";
    background: radial-gradient(1000px 600px at 15% -10%, rgba(139,107,90,.12), transparent 55%),
              radial-gradient(900px 650px at 90% 0%, rgba(0,0,0,.06), transparent 50%),
              var(--bg);
  color:var(--text);
  line-height:1.6;
}
a{color:inherit}
.container{max-width:var(--max); margin:0 auto; padding:0 18px}
.site-header{
  position:sticky; top:0; z-index:20;
  background: rgba(244,237,230,.88);
  backdrop-filter: blur(10px);
  border-bottom:1px solid rgba(230,217,207,.85);
}
.header__inner{
  display:flex; gap:12px; align-items:center; justify-content:space-between;
  padding:12px 0;
}
.brand{display:flex; align-items:center; gap:10px; text-decoration:none}
.brand__text{font-weight:750; letter-spacing:.2px}
.nav{display:flex; gap:14px; align-items:center}
.nav__link{
  text-decoration:none; color:var(--muted); font-weight:600;
  padding:8px 10px; border-radius:12px;
}
.nav__link:hover{background:rgba(0,0,0,.04); color:var(--text)}
.nav__link.is-active{background:rgba(0,0,0,.06); color:var(--text); border:1px solid rgba(0,0,0,.12)}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:10px 14px; border-radius:14px;
  border:1px solid rgba(0,0,0,.12);
  text-decoration:none; font-weight:750;
  box-shadow: none;
}
.btn--primary{
  background: linear-gradient(135deg, rgba(0,0,0,.92), rgba(0,0,0,.78));
  border:1px solid rgba(0,0,0,.22); color: #f4ede6;
}
.btn--primary:hover{filter:brightness(1.05)}
.btn--ghost{background:rgba(0,0,0,.04)}
.nav__toggle{display:none; background:transparent; color:var(--text); border:1px solid rgba(0,0,0,.14); border-radius:14px; padding:10px 12px; font-size:18px}
.mobile-nav{border-bottom:1px solid rgba(230,217,207,.85); background:rgba(11,15,20,.92)}
.mobile-nav__inner{display:grid; gap:10px; padding:14px 18px}
.mobile-nav a{color:var(--muted); text-decoration:none; padding:10px 12px; border-radius:12px; border:1px solid rgba(0,0,0,.10)}
.mobile-nav a:hover{color:var(--text); background:rgba(0,0,0,.04)}

.hero{
  padding:56px 0 24px;
}
.hero__grid{display:grid; grid-template-columns: 1.1fr .9fr; gap:26px; align-items:center}
.hero__kicker{color:var(--accent2); font-weight:750; letter-spacing:.25px; text-transform:uppercase; font-size:12px}
h1{font-size:42px; line-height:1.12; margin:10px 0 12px}
h2{font-size:28px; line-height:1.2; margin:0 0 10px}
h3{font-size:18px; margin:0 0 8px}
p{color:var(--muted); margin:0 0 12px}
.hero__bullets{display:grid; gap:8px; margin:16px 0}
.bullet{display:flex; gap:10px; align-items:flex-start; color:var(--muted)}
.bullet span{color:var(--text)}
.hero__cta{display:flex; gap:12px; flex-wrap:wrap; margin-top:16px}
.card{
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.80));
  border:1px solid rgba(0,0,0,.10);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.hero__media{overflow:hidden}
.hero__media img{width:100%; height:360px; object-fit:cover; display:block}
.section{padding:26px 0}
.grid3{display:grid; grid-template-columns: repeat(3, 1fr); gap:16px}
.grid2{display:grid; grid-template-columns: repeat(2, 1fr); gap:16px}
.tile{padding:16px}
.tile__title{display:flex; align-items:center; justify-content:space-between; gap:10px}
.tile__title a{text-decoration:none}
.kpi{color:var(--text); font-weight:800}
.hr{height:1px; background:rgba(230,217,207,.95); margin:14px 0}
.list{margin:0; padding-left:18px; color:var(--muted)}
.list li{margin:6px 0}
.badges{display:flex; flex-wrap:wrap; gap:8px; margin-top:10px}
.badge{font-size:12px; color:var(--muted); border:1px solid rgba(0,0,0,.12); padding:6px 10px; border-radius:999px; background:rgba(255,255,255,.03)}
.callout{padding:16px; display:flex; gap:16px; align-items:center; justify-content:space-between}
.callout p{margin:0}
.table{
  width:100%; border-collapse:collapse; overflow:hidden;
  border-radius: 14px; border:1px solid rgba(0,0,0,.10);
}
.table th,.table td{padding:10px 12px; border-bottom:1px solid rgba(255,255,255,.08); text-align:left; vertical-align:top}
.table th{color:var(--text); font-size:13px; letter-spacing:.2px}
.table td{color:var(--muted)}
.faq details{border:1px solid rgba(0,0,0,.10); border-radius:14px; padding:12px 14px; background:rgba(255,255,255,.03)}
.faq details + details{margin-top:10px}
.faq summary{cursor:pointer; font-weight:750; color:var(--text)}
.faq summary::-webkit-details-marker{display:none}
.faq p{margin:8px 0 0}
.breadcrumbs{font-size:13px; color:var(--muted); margin-top:6px}
.breadcrumbs a{color:var(--muted); text-decoration:none}
.breadcrumbs a:hover{color:var(--text)}
.page-hero{padding:34px 0 18px}
.page-hero__grid{display:grid; grid-template-columns: 1.05fr .95fr; gap:20px; align-items:center}
.page-hero img{width:100%; height:280px; object-fit:cover; display:block; border-radius: var(--radius)}
.proscons{display:grid; grid-template-columns: 1fr 1fr; gap:16px}
.note{font-size:13px; color:var(--muted)}
.site-footer{border-top:1px solid var(--line); margin-top:40px; padding:26px 0; background:var(--bg); color:var(--text)}
.footer__grid{display:grid; grid-template-columns: 1.2fr 1fr 1fr 1fr; gap:16px}
.footer__brand{font-weight:850}
.footer__heading{font-weight:800; margin-bottom:8px}
.footer__link{display:block; text-decoration:none; color:var(--muted); margin:6px 0}
.footer__link:hover{color:var(--text)}
.footer__small{color:var(--muted); font-size:12px}
.footer__bottom{display:flex; justify-content:space-between; gap:12px; flex-wrap:wrap; margin-top:14px; padding-top:14px; border-top:1px solid rgba(255,255,255,.08); color:var(--muted); font-size:12px}

@media (max-width: 980px){
  .hero__grid,.page-hero__grid{grid-template-columns: 1fr}
  .grid3{grid-template-columns: 1fr}
  .grid2{grid-template-columns: 1fr}
  .footer__grid{grid-template-columns: 1fr 1fr}
  h1{font-size:34px}
  .nav{display:none}
  .nav__toggle{display:inline-flex}
  .hero__media img{height:280px}
}
@media (max-width: 520px){
  .footer__grid{grid-template-columns: 1fr}
}
/* Sticky CTA (Call/Text) */
.sticky-cta{
  position:fixed;
  left:50%;
  transform:translateX(-50%);
  bottom:12px;
  display:flex;
  gap:10px;
  padding:10px;
  border-radius: 999px;
  background: rgba(255,255,255,.85);
  border:1px solid rgba(0,0,0,.10);
  box-shadow: 0 14px 40px rgba(0,0,0,.14);
  z-index:40;
}
.sticky-cta .btn{border-radius:999px; padding:10px 16px}
@media (min-width: 900px){
  .sticky-cta{display:none}
}

.header__cta{white-space:nowrap}
.header__cta-text{white-space:nowrap}



/* Service page readability upgrades: modular cards + spacing (scoped) */
.page-service .service-main{
  background: linear-gradient(180deg, rgba(255,255,255,.0), rgba(255,255,255,.0));
}
.page-service .section--service{
  padding: 22px 0;
}
@media (min-width: 860px){
  .page-service .section--service{ padding: 30px 0; }
}
.page-service .service-card{
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) - 4px);
  box-shadow: 0 10px 28px rgba(0,0,0,.06);
  padding: 20px;
}
@media (min-width: 860px){
  .page-service .service-card{ padding: 28px; }
}
.page-service .service-card h2{
  margin-top: 0;
}
.page-service .service-card p{
  max-width: 70ch;
}
.page-service .service-card .list{
  margin: 14px 0 0;
}
.page-service .service-card .grid2{
  margin-top: 14px;
}
.page-service .service-card .tile{
  background: rgba(246,241,234,.65);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 14px;
}
.page-service .service-card .tile h3{
  margin-top: 0;
}
.page-service .service-card .callout{
  border-radius: 14px;
}
/* Related services + service areas: increase scanability */
.page-service .service-card ul{ padding-left: 18px; }
.page-service .service-card li{ margin: 8px 0; }
.page-service .service-card a{ text-underline-offset: 3px; }






@media (max-width: 980px){
  .site-footer .footer__inner{grid-template-columns: 1fr 1fr;}
}
@media (max-width: 560px){
  .site-footer .footer__inner{grid-template-columns: 1fr;}
}



/* Footer (light) — enforced */
.site-footer .footer__inner{display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:18px; align-items:start}
.site-footer .footer__col h3, .site-footer .footer__col h4{margin:0 0 10px}
.site-footer .footer__col p, .site-footer .footer__col li{color:var(--muted)}
.site-footer a{color:var(--text); text-decoration:none}
.site-footer a:hover{color:var(--accent2); text-decoration:underline}
.site-footer .footer__list{list-style:none; padding:0; margin:0}
.site-footer .footer__list li{margin:6px 0}
@media (max-width: 860px){
  .site-footer .footer__inner{grid-template-columns:1fr}
}


/* === Footer: Light theme (Apopka Lodge Masonry Craftsman) === */
.site-footer{
  background: var(--bg) !important;
  color: var(--text) !important;
  border-top: 1px solid var(--line) !important;
}
.site-footer h3{ color: var(--text) !important; }
.site-footer p,
.site-footer li{ color: var(--muted) !important; }
.site-footer a{ color: var(--text) !important; }
.site-footer a:hover{ color: var(--accent2) !important; }
.site-footer .footer__bottom{
  border-top: 1px solid var(--line) !important;
}
.site-footer .footer__bottom p{ color: var(--muted) !important; }



/* === Footer Theme Override (Light) — Apopka Lodge Masonry Craftsman === */
.site-footer{
  background: #f6f1e8 !important;
  color: #141414 !important;
  border-top: 1px solid rgba(0,0,0,.10) !important;
}
.site-footer h3,
.site-footer strong{
  color: #141414 !important;
}
.site-footer p,
.site-footer li{
  color: rgba(20,20,20,.88) !important;
}
.site-footer .muted{
  color: rgba(20,20,20,.70) !important;
}
.site-footer a{
  color: #141414 !important;
  text-decoration: underline !important;
  text-underline-offset: 2px;
}
.site-footer a:hover{
  color: var(--accent2) !important;
}
.site-footer .footer__bottom{
  border-top: 1px solid rgba(0,0,0,.10) !important;
  margin-top: 18px;
  padding-top: 14px;
}
.site-footer .footer__bottom p{
  margin: 0;
}
/* mobile footer grid */
@media (max-width: 860px){
  .site-footer .footer__inner{grid-template-columns: 1fr 1fr !important;}
}
@media (max-width: 520px){
  .site-footer .footer__inner{grid-template-columns: 1fr !important;}
}


/* ===== Footer (Warm Stone) ===== */
.site-footer{
  background:#E7E1D8;
  color:#3A332C;
  border-top:1px solid rgba(0,0,0,.06);
}
.site-footer .footer__inner{
  display:grid;
  grid-template-columns: 1.6fr 1fr 1.2fr;
  gap:24px;
  align-items:start;
}
.site-footer h3, .site-footer h4{color:#3A332C; margin:0 0 10px;}
.site-footer p{margin:0 0 10px; color:rgba(58,51,44,.85);}
.site-footer a{
  color:#3A332C;
  text-decoration:none;
  border-bottom:1px solid transparent;
}
.site-footer a:hover{
  color:#B7791F;
  border-bottom-color:rgba(183,121,31,.55);
}
.site-footer .footer__sep{opacity:.55;}
.site-footer .footer__list{list-style:none; padding:0; margin:0;}
.site-footer .footer__list li{margin:6px 0; color:rgba(58,51,44,.85);}
.site-footer .footer__hours{margin-top:14px;}
.site-footer .footer__details{
  background:rgba(255,255,255,.35);
  border:1px solid rgba(0,0,0,.06);
  border-radius:14px;
  padding:12px 14px;
}
.site-footer .footer__details summary{
  cursor:pointer;
  font-weight:800;
  list-style:none;
}
.site-footer .footer__details summary::-webkit-details-marker{display:none;}
.site-footer .footer__areas-list{
  margin-top:10px;
  columns:2;
  column-gap:18px;
}
.site-footer .footer__areas-list li{break-inside:avoid;}
.site-footer .footer__note{margin-top:10px; color:rgba(58,51,44,.75);}
.site-footer .footer__bottom{
  margin-top:18px;
  padding-top:14px;
  border-top:1px solid rgba(0,0,0,.06);
  color:rgba(58,51,44,.70);
  font-size:12px;
}
@media (max-width: 900px){
  .site-footer .footer__inner{grid-template-columns:1fr 1fr;}
  .site-footer .footer__areas{grid-column:1 / -1;}
}
@media (max-width: 560px){
  .site-footer .footer__inner{grid-template-columns:1fr;}
  .site-footer .footer__areas-list{columns:1;}
}


/* Featured Knowledge Center card (comparison guide) */
.card.featured{
  display:grid;
  grid-template-columns: 1.25fr .85fr;
  gap: 18px;
  align-items: stretch;
  padding: 18px;
}
.card.featured h2{ margin-top:0; }
.featured__bullets{
  margin: 10px 0 12px;
  padding-left: 18px;
  color: var(--muted);
}
.featured__bullets li{ margin: 6px 0; }
.featured__cta{ margin-top: 12px; }
.featured__media{
  border-radius: calc(var(--radius) - 6px);
  overflow: hidden;
  background: rgba(0,0,0,.03);
  min-height: 220px;
}
.featured__media img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}
@media (max-width: 860px){
  .card.featured{ grid-template-columns: 1fr; }
  .featured__media{ min-height: 200px; }
}
