/* ═══════════════════════════════
   HOMORA — SHARED STYLESHEET
   ═══════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --green:#2D7D46;
  --green-light:#4CAF6A;
  --green-pale:#E8F5ED;
  --green-dark:#1F5A31;
  --blue:#1470F7;
  --blue-pale:#EBF3FF;
  --amber:#F59E0B;
  --amber-pale:#FEF3C7;
  --rose:#E84393;
  --rose-pale:#FDE8F3;
  --teal:#0EA5E9;
  --text:#0F1117;
  --text-muted:#6B7280;
  --text-light:#9CA3AF;
  --border:#E5E7EB;
  --bg-gray:#F9FAFB;
  --bg-gray-2:#FAFAFA;
  --radius:16px;
  --radius-sm:10px;
}

html { scroll-behavior: smooth; }
body {
  font-family: 'Inter', sans-serif;
  background: #fff;
  color: var(--text);
  overflow-x: hidden;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

/* ── Animations ── */
@keyframes orb1 { 0%,100%{transform:translate(0,0) scale(1)} 33%{transform:translate(60px,-80px) scale(1.15)} 66%{transform:translate(-40px,40px) scale(0.9)} }
@keyframes orb2 { 0%,100%{transform:translate(0,0) scale(1)} 33%{transform:translate(-80px,50px) scale(1.1)} 66%{transform:translate(50px,-60px) scale(0.85)} }
@keyframes orb3 { 0%,100%{transform:translate(0,0) scale(1)} 50%{transform:translate(40px,60px) scale(1.2)} }
@keyframes float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-16px)} }
@keyframes float2 { 0%,100%{transform:translateY(0) rotate(0deg)} 50%{transform:translateY(-20px) rotate(4deg)} }
@keyframes fadeUp { from{opacity:0;transform:translateY(32px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeIn { from{opacity:0} to{opacity:1} }
@keyframes slideInLeft { from{opacity:0;transform:translateX(-40px)} to{opacity:1;transform:translateX(0)} }
@keyframes slideInRight { from{opacity:0;transform:translateX(40px)} to{opacity:1;transform:translateX(0)} }
@keyframes ping { 0%{transform:scale(1);opacity:0.8} 100%{transform:scale(2.2);opacity:0} }
@keyframes langDrop { from{opacity:0;transform:translateY(-8px)} to{opacity:1;transform:translateY(0)} }

.animate-in { opacity:0; }
.animate-in.visible { animation:fadeUp 0.8s cubic-bezier(.16,1,.3,1) forwards; }
.animate-in-left { opacity:0; }
.animate-in-left.visible { animation:slideInLeft 0.8s cubic-bezier(.16,1,.3,1) forwards; }
.animate-in-right { opacity:0; }
.animate-in-right.visible { animation:slideInRight 0.8s cubic-bezier(.16,1,.3,1) forwards; }

/* ── NAV ── */
nav {
  position:fixed; top:0; left:0; right:0; z-index:100;
  background:rgba(255,255,255,0.88); backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(0,0,0,0.06); transition:box-shadow 0.3s;
}
nav.scrolled { box-shadow:0 4px 24px rgba(0,0,0,0.08); }
.nav-inner {
  max-width:1200px; margin:0 auto; padding:0 24px;
  height:72px; display:flex; align-items:center; justify-content:space-between;
}
.nav-logo { display:flex; align-items:center; gap:10px; text-decoration:none; }
.nav-logo img { height:34px; width:auto; }
.nav-links { display:flex; align-items:center; gap:24px; }
.nav-links a, .nav-dropdown-trigger {
  text-decoration:none; color:var(--text-muted); font-size:14px; font-weight:500;
  transition:color 0.2s; background:none; border:none; cursor:pointer; font-family:inherit;
  display:inline-flex; align-items:center; gap:4px;
}
.nav-links a:hover, .nav-dropdown-trigger:hover { color:var(--text); }
.nav-links a.active { color:var(--green); }
.nav-right { display:flex; align-items:center; gap:12px; }

/* Nav mega-dropdown */
.nav-dropdown { position:relative; }
.nav-dropdown-menu {
  position:absolute; top:calc(100% + 16px); left:50%; transform:translateX(-50%);
  background:#fff; border:1px solid var(--border); border-radius:14px;
  box-shadow:0 16px 40px rgba(0,0,0,0.12); min-width:280px;
  opacity:0; visibility:hidden; transition:all 0.2s; padding:8px;
}
.nav-dropdown:hover .nav-dropdown-menu {
  opacity:1; visibility:visible; top:calc(100% + 8px);
}
.nav-dropdown-menu a {
  display:flex; align-items:center; gap:12px;
  padding:10px 14px; border-radius:10px; font-size:14px;
  color:var(--text); transition:background 0.15s; text-decoration:none;
}
.nav-dropdown-menu a:hover { background:var(--bg-gray); color:var(--green); }
.nav-dropdown-menu a .icon {
  width:32px; height:32px; border-radius:8px; display:flex;
  align-items:center; justify-content:center; font-size:16px; flex-shrink:0;
}

/* Language switcher */
.lang-switcher { position:relative; }
.lang-btn {
  display:flex; align-items:center; gap:6px;
  background:#F9FAFB; border:1px solid var(--border);
  border-radius:50px; padding:6px 14px; cursor:pointer;
  font-size:14px; font-weight:600; color:var(--text);
  transition:all 0.2s; white-space:nowrap; font-family:inherit;
}
.lang-btn:hover { background:#F3F4F6; border-color:#D1D5DB; }
.lang-flag { font-size:16px; }
.lang-arrow { font-size:10px; color:var(--text-muted); transition:transform 0.2s; }
.lang-switcher.open .lang-arrow { transform:rotate(180deg); }
.lang-dropdown {
  position:absolute; top:calc(100% + 8px); right:0;
  background:#fff; border:1px solid var(--border);
  border-radius:14px; box-shadow:0 16px 40px rgba(0,0,0,0.12);
  overflow:hidden; display:none; min-width:180px;
  animation:langDrop 0.2s ease; z-index:1000;
}
.lang-switcher.open .lang-dropdown { display:block; }
.lang-option {
  display:flex; align-items:center; gap:10px;
  padding:11px 16px; cursor:pointer; font-size:14px; font-weight:500;
  transition:background 0.15s; color:var(--text);
}
.lang-option:hover { background:#F9FAFB; }
.lang-option.active { background:var(--green-pale); color:var(--green); font-weight:700; }
.lang-option .flag { font-size:18px; }
.lang-option .check { margin-left:auto; font-size:12px; }

.nav-cta {
  background:var(--green); color:#fff; border:none; cursor:pointer;
  padding:10px 22px; border-radius:50px; font-size:15px; font-weight:600;
  text-decoration:none; transition:all 0.2s; white-space:nowrap;
}
.nav-cta:hover { background:var(--green-light); transform:translateY(-1px); box-shadow:0 6px 20px rgba(45,125,70,0.3); }

@media(max-width:900px) { .nav-links { display:none } }

/* Mobile menu */
.mobile-menu-toggle { display:none; background:none; border:none; cursor:pointer; padding:8px; font-size:24px; color:var(--text); }
@media(max-width:900px) { .mobile-menu-toggle { display:block; } }
.mobile-menu {
  position:fixed; top:72px; left:0; right:0; bottom:0;
  background:#fff; z-index:99; padding:24px; overflow-y:auto;
  transform:translateX(100%); transition:transform 0.3s;
}
.mobile-menu.open { transform:translateX(0); }
.mobile-menu a { display:block; padding:14px 0; border-bottom:1px solid var(--border); color:var(--text); text-decoration:none; font-weight:500; }

/* ── Hero ── */
.hero { position:relative; overflow:hidden; padding-top:72px; background:#fff; }
.hero-bg { position:absolute; inset:0; overflow:hidden; z-index:0; }
.hero-grid {
  position:absolute; inset:0;
  background-image:linear-gradient(rgba(0,0,0,0.025) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,0.025) 1px,transparent 1px);
  background-size:64px 64px;
}
.orb { position:absolute; border-radius:50%; filter:blur(90px); }
.orb-1 { width:700px;height:700px; background:radial-gradient(circle,rgba(45,125,70,0.18) 0%,transparent 70%); top:-15%;right:-10%; animation:orb1 12s ease-in-out infinite; }
.orb-2 { width:600px;height:600px; background:radial-gradient(circle,rgba(20,112,247,0.14) 0%,transparent 70%); bottom:-20%;left:-5%; animation:orb2 10s ease-in-out infinite 2s; }
.orb-3 { width:450px;height:450px; background:radial-gradient(circle,rgba(245,158,11,0.12) 0%,transparent 70%); top:30%;left:35%; animation:orb3 14s ease-in-out infinite 1s; }
.orb-4 { width:350px;height:350px; background:radial-gradient(circle,rgba(232,67,147,0.10) 0%,transparent 70%); top:10%;left:20%; animation:orb1 16s ease-in-out infinite 4s; }

.hero-home { min-height:100vh; display:flex; align-items:center; }
.hero-page { padding:120px 24px 80px; }

.hero-content { position:relative;z-index:1; max-width:1200px;margin:0 auto;padding:80px 24px; }
.hero-content.two-col { display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center; }
@media(max-width:900px) { .hero-content.two-col{grid-template-columns:1fr;gap:40px;padding:48px 20px} }

.hero-badge {
  display:inline-flex;align-items:center;gap:8px;
  background:var(--green-pale);border:1px solid rgba(45,125,70,0.2);
  border-radius:50px;padding:6px 14px;margin-bottom:24px;
  font-size:13px;font-weight:600;color:var(--green);
}
.hero-badge::before { content:'';width:6px;height:6px;border-radius:50%;background:var(--green);flex-shrink:0;animation:ping 1.5s ease infinite; }
.hero-badge.amber { background:var(--amber-pale); color:#92400E; border-color:rgba(245,158,11,0.3); }
.hero-badge.amber::before { background:var(--amber); }
.hero-badge.blue { background:var(--blue-pale); color:var(--blue); border-color:rgba(20,112,247,0.2); }
.hero-badge.blue::before { background:var(--blue); }

.hero-title {
  font-family:'Fraunces',Georgia,serif;
  font-size:clamp(2.6rem,5vw,4rem); font-weight:600; line-height:1.15; letter-spacing:-0.02em;
  color:var(--text); margin-bottom:20px;
}
.hero-title em { font-style:italic; color:var(--green); }
.hero-sub { font-size:18px;color:var(--text-muted);line-height:1.7;margin-bottom:24px;max-width:560px; }

.hero-features {
  display:flex; flex-wrap:wrap; gap:20px 28px; margin-bottom:32px; font-size:14px; color:var(--text);
}
.hero-feature {
  display:inline-flex; align-items:center; gap:8px; font-weight:500;
}
.hero-feature svg { width:18px; height:18px; color:var(--green); }

.hero-actions { display:flex;align-items:center;gap:16px;flex-wrap:wrap; }

.btn-primary {
  display:inline-flex;align-items:center;gap:8px;
  background:var(--green);color:#fff;padding:14px 28px;border-radius:50px;font-size:16px;font-weight:600;
  text-decoration:none;border:none;cursor:pointer;
  transition:all 0.25s cubic-bezier(.16,1,.3,1); box-shadow:0 4px 20px rgba(45,125,70,0.25);
}
.btn-primary:hover { background:var(--green-light);transform:translateY(-2px);box-shadow:0 8px 30px rgba(45,125,70,0.35); }
.btn-primary.large { padding:16px 32px; font-size:17px; }

.btn-secondary {
  display:inline-flex;align-items:center;gap:8px;color:var(--text);font-size:16px;font-weight:500;
  text-decoration:none;padding:14px 4px;border-bottom:2px solid transparent;transition:border-color 0.2s,color 0.2s;
}
.btn-secondary:hover { border-color:var(--green);color:var(--green); }

.btn-outline {
  display:inline-flex; align-items:center; gap:8px;
  background:#fff; color:var(--text); border:1.5px solid var(--border);
  padding:13px 26px; border-radius:50px; font-size:15px; font-weight:600;
  text-decoration:none; transition:all 0.2s;
}
.btn-outline:hover { border-color:var(--green); color:var(--green); background:var(--green-pale); }

.btn-whatsapp {
  display:inline-flex;align-items:center;gap:10px;background:#25D366;color:#fff;
  padding:14px 28px;border-radius:50px;font-size:16px;font-weight:600;
  text-decoration:none;transition:all 0.25s ease;box-shadow:0 4px 20px rgba(37,211,102,0.3);
}
.btn-whatsapp:hover { background:#20BA5A;transform:translateY(-2px);box-shadow:0 8px 28px rgba(37,211,102,0.35); }

.hero-stats { display:flex;gap:32px;margin-top:40px;flex-wrap:wrap; }
.hero-stat-num { font-size:28px;font-weight:800;color:var(--text);line-height:1; }
.hero-stat-label { font-size:13px;color:var(--text-muted);margin-top:2px; }

.hero-visual { position:relative; }
.hero-img-wrap { border-radius:24px;overflow:hidden;box-shadow:0 32px 80px rgba(0,0,0,0.15),0 8px 24px rgba(0,0,0,0.08);aspect-ratio:4/3; }
.hero-img-wrap img { width:100%;height:100%;object-fit:cover; }
.hero-float-card {
  position:absolute;background:#fff;border-radius:14px;padding:14px 18px;
  box-shadow:0 16px 40px rgba(0,0,0,0.12),0 2px 8px rgba(0,0,0,0.06);
  display:flex;align-items:center;gap:12px;font-size:14px;font-weight:500;
}
.card-tax { bottom:-20px;left:-30px;animation:float 5s ease-in-out infinite 0.5s; }
.card-rating { top:-16px;right:-20px;animation:float2 6s ease-in-out infinite 1.5s; }
.hero-float-card-icon { width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0; }

/* ── Trust Bar ── */
.trust-bar { padding:40px 24px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:#FAFAFA; }
.trust-bar-inner { max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:32px;text-align:center; }
@media(max-width:640px) { .trust-bar-inner{grid-template-columns:repeat(2,1fr)} }
.trust-item-num { font-size:36px;font-weight:800;color:var(--text); }
.trust-item-num span { background:linear-gradient(135deg,var(--green),var(--blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text; }
.trust-item-label { font-size:14px;color:var(--text-muted);margin-top:4px;font-weight:500; }

/* ── Sections ── */
section { padding:100px 24px; }
.section-inner { max-width:1200px;margin:0 auto; }
.section-inner-narrow { max-width:860px; margin:0 auto; }
.section-header { text-align:center; margin-bottom:56px; }
.section-header .section-sub { margin:0 auto; }
.section-tag { display:inline-block;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:var(--green);margin-bottom:12px; }
.section-tag.amber { color:#92400E; }
.section-tag.blue { color:var(--blue); }
.section-title { font-family:'Fraunces',Georgia,serif;font-size:clamp(2rem,3.5vw,2.8rem);font-weight:600;line-height:1.2;letter-spacing:-0.02em;color:var(--text);margin-bottom:16px; }
.section-title em { font-style:italic;color:var(--green); }
.section-sub { font-size:17px;color:var(--text-muted);max-width:560px;line-height:1.7; }

/* ── Service Cards (grid) ── */
.services-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px; }
.service-card { border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);background:#fff;transition:all 0.4s cubic-bezier(.16,1,.3,1);cursor:pointer;text-decoration:none;color:inherit;display:block; }
.service-card:hover { transform:translateY(-8px);box-shadow:0 32px 64px rgba(0,0,0,0.10),0 8px 16px rgba(0,0,0,0.05);border-color:transparent; }
.service-img-wrap { overflow:hidden; }
.service-img { width:100%;height:200px;object-fit:cover;transition:transform 0.5s ease;display:block; }
.service-card:hover .service-img { transform:scale(1.05); }
.service-card-body { padding:20px 22px 24px; }
.service-card-icon { width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:12px; }
.service-card-title { font-size:17px;font-weight:700;margin-bottom:6px; }
.service-card-desc { font-size:14px;color:var(--text-muted);line-height:1.6; }
.service-card-link { display:inline-flex;align-items:center;gap:4px;margin-top:14px;font-size:14px;font-weight:600;color:var(--green);transition:gap 0.2s; }
.service-card:hover .service-card-link { gap:8px; }

/* ── Tax Section ── */
.tax-box { background:linear-gradient(135deg,#F0FDF4 0%,#EBF3FF 100%);border-radius:32px;overflow:hidden; }
.tax-inner { display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:center; }
@media(max-width:768px) { .tax-inner{grid-template-columns:1fr} .tax-img-side{display:none} }
.tax-content { padding:64px 56px; }
@media(max-width:768px) { .tax-content{padding:48px 32px} }
.tax-badge { display:inline-flex;align-items:center;gap:8px;background:var(--amber-pale);border:1px solid rgba(245,158,11,0.3);border-radius:50px;padding:6px 14px;margin-bottom:20px;font-size:13px;font-weight:700;color:#92400E; }
.tax-number { font-size:clamp(4rem,8vw,7rem);font-weight:900;line-height:1;margin-bottom:8px;background:linear-gradient(135deg,var(--green),var(--blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text; }
.tax-title { font-family:'Fraunces',serif;font-size:clamp(1.6rem,2.5vw,2.2rem);font-weight:600;color:var(--text);margin-bottom:16px;line-height:1.3; }
.tax-desc { font-size:16px;color:var(--text-muted);line-height:1.7;margin-bottom:20px; }
.tax-img-side { height:100%;min-height:400px; }
.tax-img-side img { width:100%;height:100%;object-fit:contain;padding:32px; }

/* ── How It Works ── */
.how-grid { display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center; }
@media(max-width:900px) { .how-grid{grid-template-columns:1fr} }
.how-steps { display:flex;flex-direction:column;margin-top:40px; }
.how-step { display:flex;gap:20px;position:relative;padding-bottom:36px; }
.how-step:last-child { padding-bottom:0; }
.how-step-line { position:absolute;left:19px;top:48px;bottom:0;width:2px;background:linear-gradient(to bottom,var(--green),transparent); }
.how-step:last-child .how-step-line { display:none; }
.how-step-num { width:40px;height:40px;border-radius:50%;flex-shrink:0;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:15px;position:relative;z-index:1; }
.how-step-body { padding-top:8px; }
.how-step-title { font-size:18px;font-weight:700;margin-bottom:6px; }
.how-step-desc { font-size:15px;color:var(--text-muted);line-height:1.6; }
.how-img { border-radius:24px;overflow:hidden;box-shadow:0 24px 60px rgba(0,0,0,0.12); }
.how-img img { width:100%;height:100%;object-fit:cover;display:block; }

/* ── Feature columns (3 across) ── */
.feature-cols { display:grid;grid-template-columns:repeat(3,1fr);gap:24px; }
@media(max-width:768px) { .feature-cols{grid-template-columns:1fr} }
.feature-col {
  background:#fff; border:1px solid var(--border); border-radius:var(--radius);
  padding:28px; transition:all 0.3s ease;
}
.feature-col:hover { border-color:transparent; box-shadow:0 20px 40px rgba(0,0,0,0.08); transform:translateY(-4px); }
.feature-col-icon {
  width:48px;height:48px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-size:22px; margin-bottom:16px;
  background:var(--green-pale); color:var(--green);
}
.feature-col h3 { font-size:18px;font-weight:700;margin-bottom:8px; }
.feature-col p { font-size:14px;color:var(--text-muted);line-height:1.7; }

/* ── Inclusion Lists (for service pages) ── */
.inclusion-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:40px; }
@media(max-width:768px) { .inclusion-grid{grid-template-columns:1fr} }
.inclusion-block h3 {
  font-family:'Fraunces',serif;
  font-size:22px; font-weight:600; margin-bottom:16px;
  color:var(--text); display:flex; align-items:center; gap:10px;
}
.inclusion-block h3 .icon { width:32px;height:32px;border-radius:8px;background:var(--green-pale);display:flex;align-items:center;justify-content:center;font-size:16px; color:var(--green); }
.inclusion-list { list-style:none; padding:0; }
.inclusion-list li {
  display:flex; align-items:flex-start; gap:10px;
  padding:8px 0; font-size:14.5px; color:var(--text); line-height:1.6;
}
.inclusion-list li::before {
  content:''; width:18px; height:18px; flex-shrink:0; margin-top:3px;
  background:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%232D7D46'%3E%3Cpath d='M9 16.2L4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4L9 16.2z'/%3E%3C/svg%3E") center/contain no-repeat;
}

/* ── Pricing Table ── */
.pricing-card {
  background:#fff; border:1px solid var(--border); border-radius:var(--radius);
  overflow:hidden; margin-bottom:32px;
}
.pricing-card-header {
  padding:24px 28px; background:var(--bg-gray);
  border-bottom:1px solid var(--border);
  display:flex; align-items:center; gap:14px;
}
.pricing-card-header .icon {
  width:40px;height:40px;border-radius:10px;background:var(--green-pale);
  display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--green);
}
.pricing-card-header h3 { font-size:18px;font-weight:700; }
.pricing-table { width:100%; border-collapse:collapse; }
.pricing-table th, .pricing-table td {
  text-align:left; padding:14px 28px; border-bottom:1px solid var(--border);
  font-size:14.5px;
}
.pricing-table th { color:var(--text-muted); font-weight:600; font-size:12px; text-transform:uppercase; letter-spacing:0.05em; background:var(--bg-gray-2); }
.pricing-table tr:last-child td { border-bottom:none; }
.pricing-table .price { font-weight:700; color:var(--text); text-align:right; white-space:nowrap; }
.pricing-table tr:hover { background:var(--bg-gray-2); }

/* ── FAQ ── */
.faq-list { max-width:800px; margin:0 auto; }
.faq-item {
  border:1px solid var(--border); border-radius:12px;
  background:#fff; margin-bottom:12px; overflow:hidden;
  transition:all 0.2s;
}
.faq-item:hover { border-color:#D1D5DB; }
.faq-item.open { border-color:var(--green); box-shadow:0 8px 24px rgba(45,125,70,0.08); }
.faq-q {
  padding:20px 24px; cursor:pointer; font-weight:600; font-size:15.5px; color:var(--text);
  display:flex; justify-content:space-between; align-items:center; gap:16px;
}
.faq-q::after {
  content:'+'; font-size:22px; font-weight:400; color:var(--text-muted); transition:transform 0.2s;
  flex-shrink:0;
}
.faq-item.open .faq-q::after { transform:rotate(45deg); color:var(--green); }
.faq-a {
  max-height:0; overflow:hidden; transition:max-height 0.3s ease, padding 0.3s ease;
  padding:0 24px; font-size:15px; color:var(--text-muted); line-height:1.7;
}
.faq-item.open .faq-a { max-height:600px; padding-bottom:20px; }

/* ── Before/After ── */
.ba-container { position:relative;border-radius:24px;overflow:hidden;max-width:800px;margin:0 auto;cursor:col-resize;box-shadow:0 24px 60px rgba(0,0,0,0.12); }
.ba-img { width:100%;display:block; }
.ba-after-overlay { position:absolute;top:0;left:0;height:100%;overflow:hidden; }
.ba-after-overlay img { height:100%;width:auto;max-width:none;position:absolute;top:0;left:0; }
.ba-divider { position:absolute;top:0;height:100%;width:3px;background:#fff;transform:translateX(-50%);display:flex;align-items:center;justify-content:center; }
.ba-handle { width:44px;height:44px;border-radius:50%;background:#fff;box-shadow:0 4px 16px rgba(0,0,0,0.2);display:flex;align-items:center;justify-content:center;font-size:18px;user-select:none; }
.ba-label { position:absolute;top:16px;background:rgba(0,0,0,0.6);color:#fff;font-size:12px;font-weight:700;padding:4px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:0.05em; }
.ba-label-before { left:16px; }
.ba-label-after { right:16px; }

/* ── Locations ── */
.locations-grid { display:grid;grid-template-columns:repeat(4,1fr);gap:20px; }
@media(max-width:768px) { .locations-grid{grid-template-columns:repeat(2,1fr)} }
.location-card { border-radius:16px;overflow:hidden;position:relative;aspect-ratio:3/4;cursor:pointer; }
.location-card img { width:100%;height:100%;object-fit:cover;transition:transform 0.4s ease; }
.location-card:hover img { transform:scale(1.05); }
.location-overlay { position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,0.65) 0%,transparent 50%);display:flex;flex-direction:column;justify-content:flex-end;padding:20px; }
.location-name { color:#fff;font-size:18px;font-weight:700; }
.location-sub { color:rgba(255,255,255,0.8);font-size:13px;margin-top:2px; }

/* ── Testimonials ── */
.testimonials-bg { background:linear-gradient(135deg,#F9FAFB 0%,#F0FDF4 100%); }
.testimonials-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:24px; }
@media(max-width:768px) { .testimonials-grid{grid-template-columns:1fr} }
.testimonial-card { background:#fff;border-radius:var(--radius);padding:28px;border:1px solid var(--border);transition:all 0.3s ease; }
.testimonial-card:hover { transform:translateY(-4px);box-shadow:0 20px 40px rgba(0,0,0,0.07); }
.testimonial-stars { color:#F59E0B;font-size:16px;margin-bottom:14px;letter-spacing:2px; }
.testimonial-text { font-size:15px;color:var(--text);line-height:1.7;margin-bottom:20px;font-style:italic; }
.testimonial-author { display:flex;align-items:center;gap:12px; }
.testimonial-avatar { width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--blue));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:16px;flex-shrink:0; }
.testimonial-name { font-weight:700;font-size:15px; }
.testimonial-role { font-size:13px;color:var(--text-muted); }

/* ── CTA ── */
.cta-section { position:relative;text-align:center;overflow:hidden;background:#fff; }
.cta-bg { position:absolute;inset:0;overflow:hidden;z-index:0; }
.cta-orb-1 { position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(45,125,70,0.15) 0%,transparent 70%);filter:blur(80px);top:-100px;right:-100px;animation:orb1 12s ease-in-out infinite; }
.cta-orb-2 { position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(20,112,247,0.12) 0%,transparent 70%);filter:blur(80px);bottom:-80px;left:-60px;animation:orb2 14s ease-in-out infinite 3s; }
.cta-inner { position:relative;z-index:1; }
.cta-title { font-family:'Fraunces',serif;font-size:clamp(2.2rem,4vw,3.5rem);font-weight:600;line-height:1.15;letter-spacing:-0.02em;color:var(--text);margin-bottom:16px; }
.cta-title em { font-style:italic;color:var(--green); }
.cta-sub { font-size:18px;color:var(--text-muted);max-width:480px;margin:0 auto 36px;line-height:1.6; }
.cta-buttons { display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap; }

/* ── Footer ── */
footer { background:var(--text);color:rgba(255,255,255,0.7);padding:64px 24px 32px; }
.footer-inner { max-width:1200px;margin:0 auto; }
.footer-grid { display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px; }
@media(max-width:768px) { .footer-grid{grid-template-columns:1fr 1fr;gap:32px} }
.footer-brand img { height:32px;margin-bottom:14px;filter:brightness(0) invert(1);opacity:0.9; }
.footer-brand p { font-size:14px;line-height:1.7;max-width:260px; margin-bottom:14px; }
.footer-brand address { font-style:normal; font-size:13px; line-height:1.8; color:rgba(255,255,255,0.5); }
.footer-col-title { color:#fff;font-size:14px;font-weight:700;margin-bottom:16px; }
.footer-col a { display:block;color:rgba(255,255,255,0.6);font-size:14px;text-decoration:none;margin-bottom:10px;transition:color 0.2s; }
.footer-col a:hover { color:#fff; }
.footer-bottom { border-top:1px solid rgba(255,255,255,0.1);padding-top:24px;display:flex;justify-content:space-between;align-items:center;font-size:13px;flex-wrap:wrap;gap:12px; }

[id] { scroll-margin-top:80px; }
.wa-float { position:fixed;bottom:24px;right:24px;z-index:999;width:56px;height:56px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;text-decoration:none;box-shadow:0 8px 24px rgba(37,211,102,0.4);transition:transform 0.2s,box-shadow 0.2s; }
.wa-float:hover { transform:scale(1.1);box-shadow:0 12px 32px rgba(37,211,102,0.5); }

/* Service-page hero specific */
.service-hero { padding:140px 24px 80px; position:relative; }
.service-hero-content { max-width:1200px; margin:0 auto; display:grid; grid-template-columns:1.2fr 1fr; gap:64px; align-items:center; position:relative; z-index:1; }
@media(max-width:900px) { .service-hero-content{grid-template-columns:1fr} }

.breadcrumb { font-size:13px; color:var(--text-muted); margin-bottom:20px; }
.breadcrumb a { color:var(--text-muted); text-decoration:none; transition:color 0.2s; }
.breadcrumb a:hover { color:var(--green); }
.breadcrumb .sep { margin:0 8px; color:#D1D5DB; }
.breadcrumb .current { color:var(--text); font-weight:500; }

/* Utility */
.mt-16 { margin-top:16px; }
.mt-24 { margin-top:24px; }
.mt-32 { margin-top:32px; }
.center { text-align:center; }
