/* ==========================================================================
   Leecom Plumbing & Handyman — shared design system
   ========================================================================== */

:root{
  --green:#2f9e33;
  --green-dark:#237a26;
  --green-light:#eaf6ea;
  --navy:#0d2b4e;
  --navy-deep:#071a30;
  --whatsapp:#25D366;
  --whatsapp-dark:#1ebc59;
  --ink:#10233f;
  --body-text:#5c6570;
  --light-bg:#f6f8f9;
  --border:#e6e9ed;
  --shadow:0 16px 40px rgba(10,30,55,.10);
  --radius-lg:18px;
  --radius-md:12px;
  --radius-sm:8px;
  --ease:cubic-bezier(.4,0,.2,1);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:'Inter',sans-serif;
  color:var(--body-text);
  background:#fff;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ text-decoration:none; color:inherit; }
ul{ list-style:none; margin:0; padding:0; }
h1,h2,h3,h4,h5{ font-family:'Poppins',sans-serif; color:var(--ink); margin:0; line-height:1.2; }
p{ margin:0; }
button{ font-family:inherit; cursor:pointer; }
.container{ max-width:1200px; margin:0 auto; padding:0 24px; }

/* -------------------- Buttons -------------------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-weight:700; font-size:14px; letter-spacing:.02em;
  padding:14px 26px; border-radius:var(--radius-sm);
  transition:transform .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease);
  border:2px solid transparent; white-space:nowrap;
}
.btn svg{ width:16px; height:16px; flex-shrink:0; }
.btn:hover{ transform:translateY(-2px); }
.btn-primary{ background:var(--green); color:#fff; box-shadow:0 10px 24px rgba(47,158,51,.32); }
.btn-primary:hover{ background:var(--green-dark); }
.btn-whatsapp{ background:var(--whatsapp); color:#fff; box-shadow:0 10px 24px rgba(37,211,102,.3); }
.btn-whatsapp:hover{ background:var(--whatsapp-dark); }
.btn-outline{ border-color:var(--green); color:var(--green); background:#fff; }
.btn-outline:hover{ background:var(--green-light); }
.btn-outline-light{ border-color:rgba(255,255,255,.4); color:#fff; background:transparent; }
.btn-outline-light:hover{ background:rgba(255,255,255,.1); }
.btn-navy{ background:var(--navy); color:#fff; }
.btn-navy:hover{ background:var(--navy-deep); }
.btn-block{ width:100%; }
.btn-sm{ padding:10px 18px; font-size:12.5px; }

/* -------------------- Utility bar -------------------- */
.utility-bar{ background:var(--navy); color:#cfd8e3; font-size:12px; padding:9px 0; }
.utility-bar .container{ display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:8px 20px; }
.utility-left{ display:flex; align-items:center; gap:8px; font-weight:500; }
.utility-left svg{ width:14px; height:14px; color:var(--green); flex-shrink:0; }
.utility-right{ display:none; align-items:center; gap:20px; }
@media (min-width:860px){ .utility-right{ display:flex; } }
.utility-right .u-hours{ display:flex; align-items:center; gap:6px; }
.utility-right svg{ width:13px; height:13px; color:var(--green); }
.utility-social{ display:flex; align-items:center; gap:10px; }
.utility-social a{ width:24px; height:24px; border-radius:50%; background:rgba(255,255,255,.08); position:relative; color:#fff; }
.utility-social svg{ width:12px; height:12px; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); }
.utility-social a:hover{ background:var(--green); }

/* -------------------- Header -------------------- */
.site-header{ position:sticky; top:0; z-index:100; background:#fff; border-bottom:1px solid var(--border); }
.nav-row{ display:flex; align-items:center; justify-content:space-between; padding-top:12px; padding-bottom:12px; gap:16px; }
.brand{ display:flex; align-items:center; gap:10px; color:var(--ink); flex-shrink:0; }
.brand-mark{ width:42px; height:auto; flex-shrink:0; object-fit:contain; display:block; }
.brand-text{ line-height:1.05; }
.brand-name{ font-family:'Poppins',sans-serif; font-weight:800; font-size:17px; letter-spacing:.01em; color:var(--navy); }
.brand-name .hl{ color:var(--green); }
.brand-tag{ display:block; font-size:8.5px; letter-spacing:.04em; text-transform:uppercase; color:#8a94a3; margin-top:2px; font-weight:600; }

.nav-links{ display:none; align-items:center; gap:26px; }
@media (min-width:960px){ .nav-links{ display:flex; } }
.nav-links a{ font-size:14px; font-weight:600; color:#38424f; padding:6px 0; position:relative; }
.nav-links a.active, .nav-links a:hover{ color:var(--green); }
.nav-links a.active::after{ content:""; position:absolute; left:0; right:0; bottom:-6px; height:2px; background:var(--green); }

.nav-actions{ display:none; align-items:center; gap:20px; }
@media (min-width:1180px){ .nav-actions{ display:flex; } }
.nav-call{ display:flex; align-items:center; gap:10px; }
.nav-call-icon{ width:38px; height:38px; border-radius:50%; background:var(--green-light); color:var(--green); position:relative; flex-shrink:0; }
.nav-call-icon svg{ width:17px; height:17px; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); }
.nav-call-text .label{ font-size:10.5px; color:#8a94a3; display:block; }
.nav-call-text strong{ font-size:14.5px; color:var(--ink); font-weight:800; }

.nav-toggle{ display:flex; align-items:center; justify-content:center; width:40px; height:40px; border-radius:8px; border:1px solid var(--border); background:transparent; color:var(--ink); flex-shrink:0; }
@media (min-width:960px){ .nav-toggle{ display:none; } }
.nav-toggle svg{ width:20px; height:20px; }

.mobile-menu{ max-height:0; overflow:hidden; background:#fff; transition:max-height .3s var(--ease); border-top:1px solid var(--border); }
.mobile-menu.open{ max-height:460px; }
.mobile-menu-inner{ display:flex; flex-direction:column; gap:4px; padding:16px 24px 24px; }
.mobile-menu-inner a{ color:#38424f; font-weight:600; padding:12px 0; border-bottom:1px solid var(--border); }
.mobile-menu-inner a.active{ color:var(--green); }
.mobile-menu-inner .btn{ margin-top:14px; }
@media (min-width:960px){ .mobile-menu{ display:none; } }

/* -------------------- Hero (home) -------------------- */
.hero{ background:var(--navy); position:relative; overflow:hidden; }
.hero-grid{ display:grid; grid-template-columns:1fr; gap:0; }
@media (min-width:960px){ .hero-grid{ grid-template-columns:1.1fr .9fr; align-items:stretch; } }
.hero-copy{ padding:44px 0 36px; position:relative; z-index:2; }
@media (min-width:960px){ .hero-copy{ padding:64px 0 48px; } }
.hero-copy .container{ padding-right:24px; }
.eyebrow{ display:inline-flex; align-items:center; gap:8px; font-size:12px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--green); margin-bottom:14px; }
.eyebrow::before{ content:""; width:22px; height:2px; background:var(--green); display:inline-block; }
.hero-title{ font-size:30px; font-weight:800; color:#fff; letter-spacing:-.01em; }
@media (min-width:600px){ .hero-title{ font-size:38px; } }
@media (min-width:1100px){ .hero-title{ font-size:44px; } }
.hero-sub{ margin-top:16px; font-size:15.5px; color:#c3cddb; max-width:460px; line-height:1.65; }
.hero-actions{ margin-top:26px; display:flex; flex-wrap:wrap; gap:14px; }
.hero-media{ position:relative; min-height:260px; }
@media (min-width:960px){ .hero-media{ min-height:100%; } }
.hero-media img{ width:100%; height:100%; object-fit:cover; display:block; min-height:260px; }

/* -------------------- Stats bar (under hero) -------------------- */
.stats-bar{ background:var(--navy-deep); border-top:1px solid rgba(255,255,255,.08); position:relative; z-index:2; }
.stats-grid{ display:grid; grid-template-columns:1fr 1fr; gap:22px 16px; padding-top:26px; padding-bottom:26px; }
@media (min-width:760px){ .stats-grid{ grid-template-columns:repeat(4,1fr); } }
.stat-item{ display:flex; align-items:center; gap:12px; }
.stat-icon{ width:42px; height:42px; border-radius:10px; background:rgba(47,158,51,.16); color:var(--green); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.stat-icon svg{ width:20px; height:20px; }
.stat-item h5{ color:#fff; font-size:13px; font-weight:700; margin:0; }
.stat-item p{ font-size:11.5px; color:#9aa7b8; margin-top:2px; }

/* -------------------- Section heading -------------------- */
.section-head{ text-align:center; max-width:640px; margin:0 auto 44px; }
.section-title{ font-size:26px; font-weight:800; margin-top:8px; }
@media (min-width:700px){ .section-title{ font-size:32px; } }
.section{ padding:68px 0; }
.section-alt{ background:var(--light-bg); }

/* -------------------- Services grid (icon cards, no photo) -------------------- */
.services-grid{ display:grid; grid-template-columns:1fr; gap:20px; }
@media (min-width:560px){ .services-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:980px){ .services-grid{ grid-template-columns:repeat(4,1fr); } }
.service-card{
  background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:30px 22px; text-align:center;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
}
.service-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); border-color:transparent; }
.service-icon{ width:56px; height:56px; border-radius:50%; background:var(--green-light); color:var(--green); position:relative; margin:0 auto 18px; }
.service-icon svg{ width:26px; height:26px; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); }
.service-card h3{ font-size:15.5px; font-weight:700; margin-bottom:8px; }
.service-card p{ font-size:13px; line-height:1.55; }

/* -------------------- Quote panel (split CTA + form) -------------------- */
.quote-panel{ display:grid; grid-template-columns:1fr; border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow); }
@media (min-width:860px){ .quote-panel{ grid-template-columns:.85fr 1.15fr; } }
.quote-info{ background:var(--navy); color:#fff; padding:36px 30px; position:relative; overflow:hidden; }
.quote-info h3{ color:#fff; font-size:24px; font-weight:800; }
.quote-info > p{ margin-top:12px; font-size:14px; color:#c3cddb; line-height:1.6; max-width:340px; }
.quote-checklist{ margin-top:22px; display:flex; flex-direction:column; gap:12px; }
.quote-checklist li{ display:flex; align-items:center; gap:10px; font-size:13.5px; color:#e4eaf1; font-weight:600; }
.quote-checklist .chk{ width:20px; height:20px; border-radius:50%; background:var(--green); color:#fff; position:relative; flex-shrink:0; }
.quote-checklist .chk svg{ width:11px; height:11px; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); }
.quote-form-wrap{ background:#fff; padding:32px 26px; }
.form-row{ display:grid; grid-template-columns:1fr; gap:14px; margin-bottom:14px; }
@media (min-width:520px){ .form-row{ grid-template-columns:1fr 1fr; } }
.field input, .field select, .field textarea{
  width:100%; border:1px solid var(--border); border-radius:var(--radius-sm); padding:13px 15px;
  font-family:inherit; font-size:14px; color:var(--ink); background:#fff;
}
.field textarea{ resize:vertical; min-height:110px; margin-bottom:16px; }
.field input:focus, .field select:focus, .field textarea:focus{ outline:2px solid var(--green); outline-offset:1px; }
.form-status{ margin-top:12px; font-size:13px; font-weight:600; }
.form-note-inline{ margin-top:14px; font-size:12px; color:var(--body-text); display:flex; align-items:center; gap:6px; }
.form-note-inline svg{ width:13px; height:13px; color:var(--green); flex-shrink:0; }

/* -------------------- Recent work gallery -------------------- */
.gallery-head{ display:flex; flex-wrap:wrap; align-items:flex-end; justify-content:space-between; gap:16px; margin-bottom:32px; }
.gallery-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
@media (min-width:760px){ .gallery-grid{ grid-template-columns:repeat(5,1fr); } }
.gallery-card{ border-radius:var(--radius-md); overflow:hidden; aspect-ratio:1/1; box-shadow:var(--shadow); position:relative; background:linear-gradient(135deg,var(--navy),var(--navy-deep)); display:flex; align-items:center; justify-content:center; }
.gallery-card img{ width:100%; height:100%; object-fit:cover; transition:transform .4s var(--ease); }
.gallery-card:hover img{ transform:scale(1.08); }
.gallery-card .placeholder-icon{ color:rgba(255,255,255,.5); }
.gallery-card .placeholder-icon svg{ width:34px; height:34px; }
.gallery-card .placeholder-label{ position:absolute; bottom:0; left:0; right:0; padding:10px 12px 8px; font-size:11px; font-weight:700; color:#fff; background:linear-gradient(0deg, rgba(0,0,0,.55), transparent); text-align:left; }

/* -------------------- Why choose us -------------------- */
.why-bar{ background:var(--light-bg); padding:44px 0; }
.why-grid{ display:grid; grid-template-columns:1fr 1fr; gap:28px 16px; text-align:center; }
@media (min-width:860px){ .why-grid{ grid-template-columns:repeat(4,1fr); } }
.why-item{ display:flex; flex-direction:column; align-items:center; gap:10px; }
.why-icon{ width:52px; height:52px; border-radius:50%; background:#fff; color:var(--green); position:relative; box-shadow:var(--shadow); }
.why-icon svg{ width:24px; height:24px; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); }
.why-item h5{ font-size:14px; font-weight:700; }
.why-item p{ font-size:12.5px; line-height:1.5; }

/* -------------------- CTA bar -------------------- */
.cta-bar{ background:var(--green); position:relative; overflow:hidden; }
.cta-bar.cta-navy{ background:var(--navy); }
.cta-bar-inner{ padding-top:26px; padding-bottom:26px; display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:18px; }
.cta-left{ display:flex; align-items:center; gap:16px; color:#fff; }
.cta-icon{ width:50px; height:50px; border-radius:50%; background:rgba(255,255,255,.16); color:#fff; position:relative; flex-shrink:0; }
.cta-icon svg{ width:22px; height:22px; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); }
.cta-left h3{ color:#fff; font-size:18px; font-weight:800; }
.cta-left p{ font-size:13px; color:rgba(255,255,255,.9); margin-top:2px; }
.cta-actions{ display:flex; flex-wrap:wrap; align-items:center; gap:12px; }

/* -------------------- Footer -------------------- */
.site-footer{ background:var(--navy-deep); color:#93a0b3; padding-top:56px; }
.footer-grid{ display:grid; grid-template-columns:1fr; gap:36px; padding-bottom:36px; border-bottom:1px solid rgba(255,255,255,.08); }
@media (min-width:760px){ .footer-grid{ grid-template-columns:1.3fr 1fr 1.2fr 1.2fr; } }
.footer-brand .brand{ margin-bottom:14px; color:#fff; }
.footer-brand .brand-name{ color:#fff; }
.footer-brand .brand-tag{ color:#7c8aa0; }
.footer-brand p{ font-size:13.5px; line-height:1.7; max-width:280px; margin-top:14px; }
.footer-social{ display:flex; gap:10px; margin-top:20px; }
.footer-social a{ width:36px; height:36px; border-radius:50%; border:1px solid rgba(255,255,255,.18); position:relative; color:#fff; }
.footer-social a:hover{ background:var(--green); border-color:var(--green); }
.footer-social svg{ width:16px; height:16px; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); }
.footer-col h5{ color:#fff; font-size:13px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; margin-bottom:18px; }
.footer-col ul li{ margin-bottom:12px; }
.footer-col ul a{ font-size:13.5px; color:#93a0b3; }
.footer-col ul a:hover{ color:#fff; }
.footer-contact li{ display:flex; align-items:flex-start; gap:10px; font-size:13.5px; }
.footer-contact svg{ width:15px; height:15px; color:var(--green); flex-shrink:0; margin-top:2px; }
.footer-bottom{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:10px; padding:22px 0; font-size:12.5px; color:#5f6c80; }

/* -------------------- Page hero (about / contact) -------------------- */
.page-hero{ background:var(--navy); position:relative; min-height:320px; display:flex; align-items:stretch; overflow:hidden; }
.page-hero-media{ position:absolute; inset:0; z-index:0; overflow:hidden; }
.page-hero-media img{ width:100%; height:100%; object-fit:cover; }
.page-hero-media::after{ content:""; position:absolute; inset:0; background:linear-gradient(100deg, var(--navy) 0%, rgba(13,43,78,.7) 45%, rgba(13,43,78,.1) 100%); }
.page-hero-copy{ position:relative; z-index:1; width:100%; display:flex; align-items:center; padding:44px 0; }
.page-hero-copy .container{ width:100%; }
.page-hero-copy .inner{ max-width:560px; }
.page-hero-title{ font-size:28px; font-weight:800; color:#fff; letter-spacing:-.01em; }
@media (min-width:600px){ .page-hero-title{ font-size:38px; } }
.page-hero-copy p{ margin-top:14px; font-size:14.5px; color:#c3cddb; line-height:1.6; max-width:460px; }
.page-hero-actions{ margin-top:22px; display:flex; flex-wrap:wrap; gap:12px; }

/* -------------------- About: split content -------------------- */
.split-2{ display:grid; grid-template-columns:1fr; gap:40px; }
@media (min-width:900px){ .split-2{ grid-template-columns:1.05fr .95fr; align-items:start; } }
.mini-eyebrow{ font-size:12px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--green); margin-bottom:10px; display:block; }
.split-2 h3{ font-size:26px; font-weight:800; margin-bottom:16px; }
.split-2 p{ font-size:14.5px; line-height:1.75; }
.split-2 p + p{ margin-top:14px; }
.signature{ font-family:'Georgia',serif; font-style:italic; color:var(--green); font-size:22px; margin-top:22px; display:block; }
.tagline-strong{ font-size:13.5px; font-weight:700; color:var(--ink); margin-top:4px; display:block; }

.value-grid-2{ display:grid; grid-template-columns:1fr; gap:0; }
@media (min-width:480px){ .value-grid-2{ grid-template-columns:1fr 1fr; } }
.value-item{ padding:22px 20px; border-bottom:1px solid var(--border); }
@media (min-width:480px){
  .value-item:nth-child(odd){ border-right:1px solid var(--border); }
}
.value-item .value-icon{ width:44px; height:44px; border-radius:10px; background:var(--green-light); color:var(--green); display:flex; align-items:center; justify-content:center; margin-bottom:14px; }
.value-item .value-icon svg{ width:20px; height:20px; }
.value-item h4{ font-size:13.5px; font-weight:800; letter-spacing:.03em; text-transform:uppercase; }
.value-item p{ font-size:13px; line-height:1.55; margin-top:8px; }

/* -------------------- Team section -------------------- */
.team-split{ display:grid; grid-template-columns:1fr; gap:32px; align-items:center; }
@media (min-width:900px){ .team-split{ grid-template-columns:1fr 1.1fr; } }
.team-media{ border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow); aspect-ratio:16/10; }
.team-media img{ width:100%; height:100%; object-fit:cover; }
.team-media.placeholder{ background:linear-gradient(135deg, var(--navy), var(--navy-deep)); display:flex; align-items:center; justify-content:center; gap:14px; padding:20px; }
.team-avatar{ width:64px; height:64px; border-radius:50%; background:rgba(255,255,255,.12); border:2px solid rgba(255,255,255,.25); position:relative; color:#fff; }
.team-avatar svg{ width:28px; height:28px; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); }
.team-copy h3{ font-size:24px; font-weight:800; margin-bottom:14px; }
.team-copy p{ font-size:14.5px; line-height:1.7; }

/* -------------------- Areas we serve -------------------- */
.areas-split{ display:grid; grid-template-columns:1fr; gap:28px; margin-top:60px; }
@media (min-width:860px){ .areas-split{ grid-template-columns:.8fr 1.2fr; align-items:center; } }
.areas-info{ background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg); padding:26px 24px; }
.areas-info-head{ display:flex; align-items:center; gap:10px; margin-bottom:6px; }
.areas-info-head .pin{ width:34px; height:34px; border-radius:50%; background:var(--green-light); color:var(--green); position:relative; flex-shrink:0; }
.areas-info-head .pin svg{ width:16px; height:16px; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); }
.areas-info-head h4{ font-size:15.5px; font-weight:800; }
.areas-info > p{ font-size:13px; margin:10px 0 14px; }
.areas-checklist{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.areas-checklist li{ display:flex; align-items:center; gap:8px; font-size:13.5px; font-weight:600; color:var(--ink); }
.areas-checklist svg{ width:16px; height:16px; color:var(--green); flex-shrink:0; }
.city-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
@media (min-width:560px){ .city-grid{ grid-template-columns:repeat(4,1fr); } }
.city-card{ position:relative; border-radius:var(--radius-md); overflow:hidden; aspect-ratio:3/4; background:linear-gradient(155deg, var(--green) 0%, var(--navy) 100%); display:flex; align-items:flex-end; }
.city-card img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform .4s var(--ease); }
.city-card:hover img{ transform:scale(1.08); }
.city-card span{ position:relative; z-index:2; display:block; width:100%; padding:12px 10px; font-size:13px; font-weight:800; color:#fff; text-align:center; background:linear-gradient(0deg, rgba(0,0,0,.55), transparent 70%); }

/* -------------------- Contact page -------------------- */
.contact-grid{ display:grid; grid-template-columns:1fr; gap:24px; align-items:start; }
@media (min-width:960px){ .contact-grid{ grid-template-columns:1.15fr .85fr; } }
.form-panel{ background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg); padding:32px 26px; box-shadow:var(--shadow); }
.form-panel h3{ font-size:22px; font-weight:800; margin-bottom:20px; }

.info-panel{ background:var(--navy); border-radius:var(--radius-lg); padding:30px 26px; color:#fff; }
.info-panel h3{ color:#fff; font-size:20px; font-weight:800; margin-bottom:18px; }
.info-row{ display:flex; align-items:flex-start; gap:14px; padding:16px 0; border-bottom:1px solid rgba(255,255,255,.1); }
.info-row:first-of-type{ padding-top:0; }
.info-row:last-child{ border-bottom:0; }
.info-row-icon{ width:40px; height:40px; border-radius:50%; background:var(--green); color:#fff; position:relative; flex-shrink:0; }
.info-row-icon svg{ width:18px; height:18px; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); }
.info-row h4{ font-size:13px; font-weight:700; color:#c3cddb; text-transform:uppercase; letter-spacing:.03em; }
.info-row strong{ display:block; font-size:15px; color:#fff; margin-top:4px; font-weight:700; }
.info-row span{ font-size:12.5px; color:#9aa7b8; margin-top:3px; display:block; }

.map-section{ margin-top:24px; background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow); position:relative; }
.map-frame{ height:280px; }
.map-frame iframe{ width:100%; height:100%; border:0; display:block; }
.map-here-card{ position:absolute; top:20px; left:20px; background:#fff; border-radius:var(--radius-md); padding:18px 20px; box-shadow:var(--shadow); max-width:240px; z-index:2; }
.map-here-card .pin-label{ display:flex; align-items:center; gap:6px; color:var(--green); font-weight:800; font-size:13px; margin-bottom:8px; }
.map-here-card .pin-label svg{ width:14px; height:14px; }
.map-here-card address{ font-style:normal; font-size:13px; color:var(--ink); line-height:1.5; }
.map-here-card a{ display:inline-flex; align-items:center; gap:5px; margin-top:10px; font-size:12.5px; font-weight:700; color:var(--navy); border-top:1px solid var(--border); padding-top:10px; width:100%; }
.map-here-card a svg{ width:12px; height:12px; }
@media (max-width:640px){ .map-here-card{ position:static; margin:16px; max-width:none; box-shadow:none; border:1px solid var(--border); } }

/* -------------------- FAQ -------------------- */
.faq-cta-grid{ display:grid; grid-template-columns:1fr; gap:24px; align-items:start; }
@media (min-width:900px){ .faq-cta-grid{ grid-template-columns:1.3fr 1fr; } }
.faq-grid{ display:flex; flex-direction:column; gap:12px; }
.faq-item{ background:#fff; border:1px solid var(--border); border-radius:var(--radius-md); overflow:hidden; }
.faq-q{ width:100%; display:flex; align-items:center; justify-content:space-between; gap:12px; padding:18px 20px; font-size:14.5px; font-weight:700; color:var(--ink); background:none; border:0; text-align:left; }
.faq-q svg{ width:18px; height:18px; color:var(--green); flex-shrink:0; transition:transform .25s var(--ease); }
.faq-item.open .faq-q svg{ transform:rotate(45deg); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .3s var(--ease); }
.faq-item.open .faq-a{ max-height:200px; }
.faq-a-inner{ padding:0 20px 18px; font-size:13.5px; line-height:1.6; }

.quality-panel{ position:relative; border-radius:var(--radius-lg); overflow:hidden; min-height:280px; display:flex; align-items:center; justify-content:center; text-align:center; padding:36px 28px; background:linear-gradient(160deg, var(--navy) 0%, var(--navy-deep) 100%); }
.quality-panel::before{ content:""; position:absolute; inset:0; background:radial-gradient(circle at 30% 20%, rgba(47,158,51,.18), transparent 55%); }
.quality-icon{ width:64px; height:64px; border-radius:50%; background:var(--green); color:#fff; margin:0 auto 20px; position:relative; z-index:2; }
.quality-icon svg{ width:30px; height:30px; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); }
.quality-panel h3{ color:#fff; font-size:21px; font-weight:800; line-height:1.35; position:relative; z-index:2; }
.quality-panel p{ color:#c3cddb; font-size:13.5px; margin-top:12px; position:relative; z-index:2; }
