/* ---------- Light Theme (White Background) ---------- */
:root{
  --bg: #ffffff;
  --panel: #f7f9fc;
  --panel-alt: #eef2f7;
  --text: #1f2937;
  --muted: #6b7280;
  --line: #e5e7eb;
  --accent: #2563eb;
  --shadow: 0 10px 30px rgba(0,0,0,.08);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  color:var(--text);
  background:var(--bg);
}
a{color:inherit; text-decoration:none}
.container{width:min(1120px, 92%); margin:0 auto}

/* Top bar */
.topbar{background: var(--panel); border-bottom: 1px solid var(--line);}
.topbar-inner{display:flex; align-items:center; justify-content:space-between; padding:10px 0; gap:12px;}
.pill{display:inline-flex; align-items:center; padding:6px 10px; border:1px solid var(--line); border-radius:999px; font-size:12px; letter-spacing:.4px; background:#fff;}
.topbar-text{font-size:13px; color:var(--muted)}
.topbar-link{font-size:13px; color:var(--accent); font-weight:800}

/* Header */
.header{position:sticky; top:0; z-index:50; background:#ffffff; border-bottom:1px solid var(--line);}
.nav{display:flex; align-items:center; justify-content:space-between; padding:14px 0; gap:14px;}
.brand{display:flex; align-items:center; gap:12px}
.brand-mark{width:42px; height:42px; border-radius:12px; background: linear-gradient(135deg, rgba(37,99,235,.16), rgba(124,58,237,.14)); border: 1px solid var(--line); display:grid; place-items:center; font-weight:900; color: var(--text);}
.brand-text span{display:block; font-size:12px; color:var(--muted); margin-top:2px}
.menu{display:flex; align-items:center; gap:18px}
.menu a{font-size:14px; color:var(--muted); font-weight:700}
.menu a:hover{color:var(--text)}

/* Buttons */
.btn{display:inline-flex; align-items:center; justify-content:center; padding:12px 18px; border-radius:12px; background: var(--accent); color: #ffffff; font-weight: 900; border: 1px solid rgba(0,0,0,0); box-shadow: var(--shadow);}
.btn:hover{background:#1d4ed8}
.btn:active{transform: translateY(1px)}
.btn-small{padding:10px 14px; border-radius:12px; font-size:14px}
.btn-ghost{background: transparent; color: var(--accent); box-shadow:none; border:1px solid var(--line);}
.btn-wide{width:100%}

/* Hero */
.hero{padding:56px 0 34px}
.hero-with-image{display:grid; grid-template-columns: 1.25fr .75fr; gap:26px; align-items:center;}
.hero h1{font-size: clamp(34px, 5vw, 56px); line-height:1.02; margin:0 0 12px; letter-spacing:-.8px;}
.lead{font-size:18px; line-height:1.65; color:var(--muted); margin:0 0 18px}
.hero-cta{display:flex; gap:12px; flex-wrap:wrap; margin:16px 0 14px}
.hero-meta{display:flex; gap:10px; flex-wrap:wrap; align-items:center; color:var(--muted); margin-bottom:16px}
.hero-meta a{color:var(--accent); font-weight:900}
.dot{color:#c7cdd7}
.hero-bullets{display:grid; grid-template-columns: repeat(3, 1fr); gap:12px; margin-top:10px;}
.bullet{border:1px solid var(--line); background: #ffffff; border-radius:16px; padding:12px; box-shadow: 0 8px 18px rgba(0,0,0,.04);}
.bullet strong{display:block; font-size:14px; margin-bottom:4px}
.bullet span{display:block; font-size:13px; color:var(--muted); line-height:1.45}
.hero-image{display:flex; flex-direction:column; gap:10px; align-items:center;}
.hero-image img{width:100%; max-width: 340px; border-radius: 18px; border:1px solid var(--line); box-shadow: var(--shadow); background:#ffffff;}
.hero-caption{text-align:center;}
.hero-caption span{display:block; margin-top:4px; color: var(--muted); font-size: 13px; font-weight: 700;}

/* Sections */
.section{padding:56px 0}
.section-alt{background: var(--panel); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);}
.section-head h2{margin:0 0 8px; font-size:30px}
.section-head p{margin:0; color:var(--muted); line-height:1.65}

/* Cards */
.cards{margin-top:18px; display:grid; grid-template-columns: repeat(4, 1fr); gap:14px;}
.card{border:1px solid var(--line); background: #ffffff; border-radius:18px; padding:16px; box-shadow: 0 8px 18px rgba(0,0,0,.04);}
.card h3{margin:0 0 10px}
.card p{margin:0 0 10px; color:var(--muted); line-height:1.6}
.card ul{margin:0; padding-left:18px; color:#374151}
.card li{margin:6px 0}

/* Pricing */
.pricing{margin-top:18px; display:grid; grid-template-columns: repeat(3, 1fr); gap:14px;}
.price-card{border:1px solid var(--line); background:#ffffff; border-radius:20px; padding:18px; position:relative; box-shadow: 0 8px 18px rgba(0,0,0,.04);}
.price-card.featured{border-color: rgba(37,99,235,.35); box-shadow: 0 18px 40px rgba(37,99,235,.12);}
.tag{position:absolute; top:14px; right:14px; font-size:12px; padding:6px 10px; border-radius:999px; border:1px solid var(--line); background: var(--panel); color: var(--text); font-weight:900;}
.price{margin:10px 0 10px; display:flex; align-items:baseline; gap:8px;}
.amount{font-size:34px; font-weight:900}
.unit{color:var(--muted)}
.checklist{list-style:none; padding:0; margin:12px 0}
.checklist li{padding-left:22px; position:relative; margin:8px 0; color:#374151;}
.checklist li:before{content:"✓"; position:absolute; left:0; top:0; color: #16a34a; font-weight:900;}

/* Local */
.local-grid{margin-top: 18px; display: grid; grid-template-columns: 1.1fr .9fr; gap: 14px; align-items: start;}
.local-card{border: 1px solid var(--line); background: #ffffff; border-radius: 18px; padding: 16px; box-shadow: 0 8px 18px rgba(0,0,0,.04);}
.local-card h3{margin:0 0 10px}
.local-card ul{margin:0; padding-left:18px; color:#374151}
.local-card li{margin:8px 0; line-height:1.5}
.local-actions{margin-top: 12px; display: flex; gap: 10px; flex-wrap: wrap;}

/* Reviews */
.quotes{margin-top:18px; display:grid; grid-template-columns: repeat(3, 1fr); gap:14px;}
.quote{border:1px solid var(--line); background:#ffffff; border-radius:18px; padding:16px; margin:0; box-shadow: 0 8px 18px rgba(0,0,0,.04);}
.quote blockquote{margin:0 0 10px; color:#111827; line-height:1.6}
.quote figcaption{color:var(--muted); font-size:13px; font-weight:700}
.review-cta{margin-top: 16px; display: flex; gap: 12px; flex-wrap: wrap;}

/* FAQ */
.faq{margin-top:16px; display:grid; gap:10px}
details{border:1px solid var(--line); background:#ffffff; border-radius:16px; padding:12px 14px; box-shadow: 0 8px 18px rgba(0,0,0,.03);}
summary{cursor:pointer; font-weight:900}
details p{margin:10px 0 0; color:var(--muted); line-height:1.6}

/* Contact */
.contact-grid{display:grid; grid-template-columns: 1.1fr .9fr; gap:18px; align-items:start;}
.contact-cards{display:grid; grid-template-columns: repeat(3, 1fr); gap:12px; margin-top:14px;}
.contact-card{border:1px solid var(--line); background:#ffffff; border-radius:16px; padding:12px; box-shadow: 0 8px 18px rgba(0,0,0,.03);}
.contact-card p{margin:8px 0 0; color:var(--muted); line-height:1.45}
.contact-card a{color:var(--accent); font-weight:900}
.contact-actions{margin-top:10px}
.form{border:1px solid var(--line); background:#ffffff; border-radius:20px; padding:16px; box-shadow: 0 8px 18px rgba(0,0,0,.03);}
.form-row{display:grid; grid-template-columns: 1fr 1fr; gap:12px;}
label{display:block; font-size:13px; color:#374151; margin-bottom:10px; font-weight:900}
input, select, textarea{width:100%; margin-top:8px; padding:12px 12px; border-radius:14px; border:1px solid var(--line); background: #ffffff; color:var(--text); outline:none;}
input:focus, select:focus, textarea:focus{border-color: rgba(37,99,235,.55); box-shadow: 0 0 0 4px rgba(37,99,235,.12);}
textarea{resize:vertical}

/* Checkbox chip UI */
.fieldset{border: 1px solid var(--line); background: #ffffff; border-radius: 16px; padding: 12px; margin: 0 0 10px; box-shadow: 0 8px 18px rgba(0,0,0,.03);}
.fieldset legend{padding: 0 8px; font-weight: 900; color: #374151;}
.chip-grid{display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; margin-top: 10px;}
.chip{display: flex; align-items: center; gap: 10px; padding: 12px 12px; border-radius: 14px; border: 1px solid var(--line); background: var(--panel); cursor: pointer; user-select: none; font-weight: 800; color: var(--text);}
.chip input{width: 18px; height: 18px; margin: 0;}
.chip:has(input:checked){border-color: rgba(37,99,235,.45); background: rgba(37,99,235,.08);}
@media (max-width: 980px){ .chip-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); } }

/* Footer */
.footer{background: var(--panel-alt); border-top:1px solid var(--line); padding:22px 0;}
.footer-inner{display:grid; grid-template-columns: 1fr auto auto; gap:14px; align-items:center;}
.footer-links{display:flex; gap:14px}
.footer-links a{color:var(--muted); font-weight:900}
.footer-links a:hover{color:var(--text)}
.muted{color:var(--muted)}
.small{font-size:12px}
.micro{margin:12px 0 0; font-size:12px; color:var(--muted); line-height:1.45}

/* Sticky mobile actions */
.sticky-bar{position: fixed; left: 50%; transform: translateX(-50%); bottom: 14px; z-index: 999; width: min(520px, calc(100% - 24px)); display: grid; grid-template-columns: 1fr 1fr; gap: 10px;}
.sticky-btn{padding: 14px 12px; border-radius: 14px; text-align: center; font-weight: 900; letter-spacing: .2px; box-shadow: var(--shadow); border: 1px solid rgba(0,0,0,.06);}
.sticky-btn.call{background: #16a34a; color: #ffffff;}
.sticky-btn.book{background: var(--accent); color: #ffffff;}

/* Responsive */
@media (max-width: 980px){
  .hero-with-image{grid-template-columns: 1fr; text-align:center}
  .hero-image{margin-top:14px}
  .cards{grid-template-columns: repeat(2, 1fr)}
  .pricing{grid-template-columns: 1fr}
  .hero-bullets{grid-template-columns: 1fr}
  .local-grid{grid-template-columns: 1fr}
  .quotes{grid-template-columns: 1fr}
  .contact-grid{grid-template-columns: 1fr}
  .contact-cards{grid-template-columns: 1fr}
  .footer-inner{grid-template-columns: 1fr; text-align:center}
  .footer-links{justify-content:center}
  body{ padding-bottom: 110px; }
}
@media (min-width: 981px){ .sticky-bar{ display:none; } }
