
:root{
  --bg:#0b1220;
  --bg-soft:#111a2b;
  --card:#ffffff;
  --card-soft:#f4f7fb;
  --text:#0f172a;
  --muted:#475569;
  --border:#d7e0ea;
  --line:#e6edf5;
  --accent:#f97316;
  --accent-dark:#c2410c;
  --navy:#0b1220;
  --success:#0f766e;
  --radius:22px;
  --shadow:0 18px 50px rgba(15,23,42,.10);
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Inter",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--text);
  background:#fff;
  line-height:1.6;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
p{margin:0 0 1rem}
ul,ol{margin:0;padding-left:1.2rem}
.container{width:min(var(--max), calc(100% - 2rem));margin-inline:auto}
.narrow{width:min(820px,100%);margin-inline:auto}
.sr-only{position:absolute;left:-9999px}
.topbar{
  background:var(--navy);
  color:#dce4ef;
  font-size:.95rem;
}
.topbar a{color:#fff}
.topbar-inner{
  display:flex;
  justify-content:space-between;
  gap:1rem;
  padding:.65rem 0;
  align-items:center;
}
.topbar-inner p{margin:0}
.site-header{
  position:sticky;
  top:0;
  z-index:40;
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(15,23,42,.08);
}
.nav-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:1rem 0;
}
.brand{
  display:flex;
  align-items:center;
  gap:.85rem;
}
.brand-mark{
  width:54px;
  height:54px;
  display:grid;
  place-items:center;
  border-radius:16px;
  background:linear-gradient(135deg, var(--accent), #f59e0b);
  color:#fff;
  font-family:"Barlow Condensed", sans-serif;
  font-weight:800;
  font-size:1.5rem;
  letter-spacing:.03em;
  box-shadow:var(--shadow);
}
.brand-text{
  display:flex;
  flex-direction:column;
  line-height:1;
}
.brand-text strong{
  font-family:"Barlow Condensed", sans-serif;
  font-size:1.65rem;
  letter-spacing:.02em;
  color:var(--navy);
}
.brand-text small{
  margin-top:.15rem;
  color:var(--muted);
  font-size:.92rem;
}
.desktop-nav{
  display:flex;
  align-items:center;
  gap:1rem;
}
.desktop-nav > a,
.nav-dropdown > button,
.lang-switch{
  border:none;
  background:none;
  padding:.5rem .15rem;
  font:inherit;
  color:var(--text);
  cursor:pointer;
}
.desktop-nav > a:hover,
.nav-dropdown > button:hover,
.lang-switch:hover{color:var(--accent-dark)}
.nav-dropdown{position:relative}
.nav-dropdown-menu{
  position:absolute;
  top:calc(100% + .6rem);
  left:0;
  min-width:270px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  box-shadow:var(--shadow);
  padding:.7rem;
  display:none;
}
.nav-dropdown:hover .nav-dropdown-menu,
.nav-dropdown:focus-within .nav-dropdown-menu{display:grid;gap:.35rem}
.nav-dropdown-menu a{
  padding:.7rem .85rem;
  border-radius:12px;
}
.nav-dropdown-menu a:hover{background:var(--card-soft)}
.nav-toggle{
  display:none;
  width:48px;
  height:48px;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
  align-items:center;
  justify-content:center;
  gap:4px;
  flex-direction:column;
}
.nav-toggle span{
  display:block;
  width:18px;
  height:2px;
  background:var(--navy);
  border-radius:999px;
}
.mobile-menu{
  display:none;
  border-top:1px solid var(--line);
  background:#fff;
}
.mobile-menu.is-open{display:block}
.mobile-menu-inner{
  padding:1rem 0 1.2rem;
  display:grid;
  gap:.9rem;
}
.mobile-menu details summary{
  list-style:none;
  cursor:pointer;
}
.mobile-submenu{
  display:grid;
  gap:.55rem;
  padding:.75rem 0 .25rem .5rem;
}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  padding:.85rem 1.2rem;
  border-radius:999px;
  background:var(--accent);
  color:#fff;
  font-weight:700;
  border:1px solid transparent;
  box-shadow:0 10px 25px rgba(249,115,22,.2);
}
.btn:hover{background:var(--accent-dark)}
.btn-outline{
  background:transparent;
  color:var(--navy);
  border-color:var(--border);
  box-shadow:none;
}
.btn-outline:hover{border-color:var(--accent);color:var(--accent-dark);background:#fff7ed}
.btn-ghost{
  background:#fff;
  color:var(--navy);
  border-color:var(--border);
  box-shadow:none;
}
.btn-small{min-height:42px;padding:.7rem 1rem}
.btn-full{width:100%}
.breadcrumbs{
  display:flex;
  align-items:center;
  gap:.55rem;
  padding:1rem 0 0;
  color:var(--muted);
  font-size:.95rem;
}
.hero{
  background:
    radial-gradient(circle at top right, rgba(249,115,22,.18), transparent 30%),
    linear-gradient(180deg, #fff, #f7fafc 92%);
  padding:3.2rem 0 2.3rem;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:2rem;
  align-items:center;
}
.eyebrow,
.section-kicker{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  padding:.45rem .8rem;
  border-radius:999px;
  background:#fff7ed;
  border:1px solid #fed7aa;
  color:var(--accent-dark);
  font-weight:700;
  font-size:.9rem;
}
.hero h1{
  margin:.8rem 0 1rem;
  font-family:"Barlow Condensed", sans-serif;
  font-size:clamp(3rem, 6vw, 5rem);
  line-height:.95;
  letter-spacing:.01em;
  color:var(--navy);
}
.hero-text{
  color:var(--muted);
  font-size:1.1rem;
  max-width:62ch;
}
.cta-row{
  display:flex;
  flex-wrap:wrap;
  gap:.85rem;
  margin:1.35rem 0 1.1rem;
}
.hero-points{
  display:flex;
  flex-wrap:wrap;
  gap:.7rem;
  padding:0;
  list-style:none;
}
.hero-points li{
  padding:.6rem .9rem;
  border-radius:999px;
  background:#fff;
  border:1px solid var(--line);
  color:var(--muted);
  font-weight:600;
}
.hero-card{
  display:flex;
  justify-content:flex-end;
}
.hero-card-inner{
  width:min(100%, 420px);
  background:linear-gradient(160deg, var(--navy), #122239 70%);
  color:#fff;
  border-radius:32px;
  padding:1.7rem;
  box-shadow:var(--shadow);
}
.hero-card h2{
  margin:.8rem 0 .6rem;
  font-family:"Barlow Condensed", sans-serif;
  font-size:2.2rem;
  line-height:.95;
}
.hero-card p{color:#dce4ef}
.hero-card ul{
  list-style:none;
  padding:0;
  margin:1rem 0 0;
  display:grid;
  gap:.65rem;
}
.badge{
  display:inline-flex;
  padding:.45rem .75rem;
  border-radius:999px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.18);
  font-weight:700;
}
.section{padding:4.5rem 0}
.section-alt{background:var(--card-soft)}
.section h2{
  margin:.9rem 0 .85rem;
  font-family:"Barlow Condensed", sans-serif;
  font-size:clamp(2rem, 4vw, 3rem);
  line-height:1;
  color:var(--navy);
}
.section-intro{
  max-width:70ch;
  color:var(--muted);
  margin-bottom:1.5rem;
}
.service-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:1rem;
}
.service-grid.two-up{grid-template-columns:repeat(2, minmax(0,1fr))}
.service-card,
.feature-card,
.review-card,
.contact-card,
.areas-panel{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:1.35rem;
  box-shadow:0 10px 28px rgba(15,23,42,.05);
}
.service-card h3,
.feature-card h3,
.review-card strong,
.contact-card h3,
.related-links h3{
  margin:0 0 .45rem;
  font-size:1.1rem;
  line-height:1.25;
}
.text-link{
  display:inline-flex;
  margin-top:.4rem;
  color:var(--accent-dark);
  font-weight:700;
}
.feature-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:1rem;
}
.two-col{
  display:grid;
  grid-template-columns:1fr .95fr;
  gap:1.2rem;
  align-items:start;
}
.process-list{
  display:grid;
  gap:1rem;
  padding-left:1.1rem;
}
.process-list li{
  padding-left:.2rem;
}
.process-list p{color:var(--muted);margin:.35rem 0 0}
.city-grid{
  list-style:none;
  padding:0;
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:.7rem;
  margin-top:1rem;
}
.city-grid li{
  padding:.8rem .9rem;
  background:var(--card-soft);
  border:1px solid var(--line);
  border-radius:16px;
  font-weight:600;
}
.review-placeholder{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:1rem;
}
.faq-list{
  display:grid;
  gap:.75rem;
}
.faq-list details{
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  padding:1rem 1rem;
}
.faq-list summary{
  cursor:pointer;
  font-weight:700;
  list-style:none;
}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list p{margin-top:.75rem;color:var(--muted)}
.contact-grid{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:1.2rem;
  align-items:start;
}
.section-contact{
  background:linear-gradient(180deg, #fff7ed 0%, #ffffff 100%);
}
.contact-copy{
  padding:1rem 0;
}
.contact-list{
  list-style:none;
  padding:0;
  display:grid;
  gap:.55rem;
  color:var(--muted);
}
.contact-card{
  border:1px solid #fed7aa;
}
.contact-form{
  display:grid;
  gap:.9rem;
}
.contact-form label{
  display:grid;
  gap:.35rem;
  font-weight:600;
}
.contact-form input,
.contact-form select,
.contact-form textarea{
  width:100%;
  min-height:48px;
  padding:.85rem 1rem;
  border:1px solid var(--border);
  border-radius:16px;
  font:inherit;
  background:#fff;
  color:var(--text);
}
.contact-form textarea{min-height:140px;resize:vertical}
.form-split{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:.85rem;
}
.form-status{
  min-height:1.4rem;
  font-weight:600;
}
.form-status.success{color:var(--success)}
.form-status.error{color:#b91c1c}
.related-links ul,
.footer-list{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:.55rem;
}
.related-links{
  margin-top:1.15rem;
  padding-top:1rem;
  border-top:1px solid var(--line);
}
.site-footer{
  background:var(--navy);
  color:#dbe6f4;
  padding:3rem 0 1.2rem;
}
.site-footer a{color:#fff}
.footer-grid{
  display:grid;
  grid-template-columns:1.2fr .9fr .9fr;
  gap:1.5rem;
}
.footer-brand .brand-text strong,
.footer-brand .brand-text small{color:#fff}
.footer-bottom{
  margin-top:1.6rem;
  padding-top:1rem;
  border-top:1px solid rgba(255,255,255,.12);
  color:#aac0d8;
}
@media (max-width: 1080px){
  .service-grid,
  .feature-grid,
  .review-placeholder{grid-template-columns:repeat(2, minmax(0,1fr))}
}
@media (max-width: 900px){
  .desktop-nav{display:none}
  .nav-toggle{display:flex}
  .hero-grid,
  .two-col,
  .contact-grid,
  .footer-grid{grid-template-columns:1fr}
  .hero-card{justify-content:stretch}
  .service-grid.two-up,
  .service-grid,
  .feature-grid,
  .review-placeholder{grid-template-columns:1fr}
}
@media (max-width: 640px){
  .topbar-inner{flex-direction:column;align-items:flex-start}
  .hero{padding-top:2.3rem}
  .section{padding:3.5rem 0}
  .city-grid,
  .form-split{grid-template-columns:1fr}
  .cta-row{flex-direction:column}
  .btn,.btn-outline,.btn-ghost{width:100%}
}

/* ─── GALLERY ─── */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}
.gallery-item{border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3;cursor:pointer;position:relative}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.gallery-item:hover img{transform:scale(1.04)}
.gallery-item figcaption{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(11,18,32,.85));color:#fff;font-size:.82rem;padding:.6rem .8rem;opacity:0;transition:opacity .3s}
.gallery-item:hover figcaption{opacity:1}

/* ─── LIGHTBOX ─── */
.lb-overlay{display:none;position:fixed;inset:0;background:rgba(11,18,32,.94);z-index:999;align-items:center;justify-content:center;padding:1rem}
.lb-overlay.is-open{display:flex}
.lb-overlay img{max-width:92vw;max-height:88vh;border-radius:12px;object-fit:contain}
.lb-close{position:absolute;top:1.2rem;right:1.4rem;background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;line-height:1}

/* ─── REVIEWS ─── */
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem}
.review-card-real{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem;display:flex;flex-direction:column;gap:.85rem;box-shadow:var(--shadow)}
.review-card-real.featured{border-color:var(--accent);box-shadow:0 18px 50px rgba(249,115,22,.12)}
.review-stars{color:#f59e0b;font-size:1.1rem;letter-spacing:.05em}
.review-text{color:var(--muted);line-height:1.65;font-size:.95rem;flex:1}
.review-footer{display:flex;align-items:center;gap:.75rem;margin-top:.25rem}
.review-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#f59e0b);color:#fff;font-weight:700;font-size:1rem;display:grid;place-items:center;flex-shrink:0}
.review-name{font-weight:600;font-size:.92rem;color:var(--navy)}
.review-loc{font-size:.8rem;color:var(--muted)}

/* ─── FLOATING WHATSAPP ─── */
.wa-float{position:fixed;bottom:1.4rem;right:1.4rem;z-index:200;width:56px;height:56px;border-radius:50%;background:#25d366;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 24px rgba(37,211,102,.45);transition:transform .2s,box-shadow .2s;text-decoration:none}
.wa-float:hover{transform:scale(1.08);box-shadow:0 10px 32px rgba(37,211,102,.55)}
.wa-float svg{width:30px;height:30px;fill:#fff}

@media(max-width:767px){
  .reviews-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}
  .wa-float{bottom:1rem;right:1rem;width:50px;height:50px}
}

/* ─── VISUAL PHOTO BANNER ─── */
.photo-banner{position:relative;width:100%;height:420px;overflow:hidden;border-radius:0}
.photo-banner img{width:100%;height:100%;object-fit:cover;display:block}
.photo-banner-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(11,18,32,.82) 0%,rgba(11,18,32,.45) 55%,rgba(11,18,32,.18) 100%);display:flex;align-items:center}
.photo-banner-copy{padding:2.5rem;max-width:520px;color:#fff}
.photo-banner-copy .badge{display:inline-block;background:var(--accent);color:#fff;font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.35rem .85rem;border-radius:999px;margin-bottom:1rem}
.photo-banner-copy h2{font-family:"Barlow Condensed",sans-serif;font-size:2.2rem;font-weight:800;line-height:1.1;margin:0 0 .75rem;color:#fff}
.photo-banner-copy p{color:#c8d6e8;font-size:1rem;margin:0 0 1.25rem;line-height:1.6}
.photo-banner-copy .btn{background:var(--accent);color:#fff;border-color:transparent}
.photo-banner-copy .btn:hover{background:var(--accent-dark)}

/* ─── SVG ICON FEATURE CARDS ─── */
.feature-card .card-icon{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,#fff3e8,#fde8d0);display:flex;align-items:center;justify-content:center;margin-bottom:1rem;flex-shrink:0}
.feature-card .card-icon svg{width:26px;height:26px;stroke:var(--accent);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.feature-card h3{margin-top:0}

/* ─── VISUAL TRUST BAR ─── */
.trust-bar{background:var(--navy);padding:1.5rem 0}
.trust-bar-inner{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;align-items:center}
.trust-pill{display:flex;align-items:center;gap:.6rem;color:#fff;font-size:.9rem;font-weight:600;background:rgba(255,255,255,.08);border-radius:999px;padding:.55rem 1.1rem;border:1px solid rgba(255,255,255,.12)}
.trust-pill svg{width:18px;height:18px;stroke:#f97316;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}

/* ─── CHECKLIST VISUAL ─── */
.visual-checklist{display:grid;gap:.75rem;margin-top:1.5rem}
.visual-checklist li{display:flex;align-items:flex-start;gap:.85rem;background:#fff;border:1px solid var(--line);border-radius:14px;padding:1rem 1.2rem;list-style:none}
.vc-icon{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--accent),#f59e0b);display:grid;place-items:center;flex-shrink:0}
.vc-icon svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}
.vc-text strong{display:block;font-size:.95rem;color:var(--navy);margin-bottom:.2rem}
.vc-text span{font-size:.875rem;color:var(--muted);line-height:1.5}

/* ─── SPLIT PHOTO SECTION ─── */
.split-photo{display:grid;grid-template-columns:1fr 1fr;gap:0;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.split-photo img{width:100%;height:340px;object-fit:cover;display:block}
.split-photo-content{background:var(--navy);padding:2.5rem;display:flex;flex-direction:column;justify-content:center;gap:1rem}
.split-photo-content h2{font-family:"Barlow Condensed",sans-serif;font-size:1.9rem;font-weight:800;color:#fff;margin:0;line-height:1.15}
.split-photo-content p{color:#c8d6e8;margin:0;line-height:1.65}
.split-photo-content .btn{align-self:flex-start}

/* ─── STATS ROW ─── */
.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin:2rem 0}
.stat-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:1.5rem;text-align:center;box-shadow:var(--shadow)}
.stat-num{font-family:"Barlow Condensed",sans-serif;font-size:2.4rem;font-weight:800;color:var(--accent);line-height:1}
.stat-label{font-size:.82rem;color:var(--muted);margin-top:.4rem}

@media(max-width:767px){
  .photo-banner{height:280px}
  .photo-banner-copy h2{font-size:1.6rem}
  .split-photo{grid-template-columns:1fr}
  .split-photo img{height:220px}
  .trust-bar-inner{gap:.6rem}
  .trust-pill{font-size:.8rem;padding:.4rem .85rem}
}

/* ─── VISUAL ENHANCEMENTS ─── */

/* Page Photo Strips */
.photo-strip{display:grid;gap:1rem}
.photo-strip.duo{grid-template-columns:1fr 1fr}
.photo-strip.trio{grid-template-columns:1fr 1fr 1fr}
.photo-strip figure{margin:0;border-radius:var(--radius);overflow:hidden;position:relative;aspect-ratio:4/3}
.photo-strip figure.tall{aspect-ratio:3/4}
.photo-strip figure.wide{aspect-ratio:16/7}
.photo-strip img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s}
.photo-strip figure:hover img{transform:scale(1.03)}
.photo-strip figcaption{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(11,18,32,.82));color:#fff;font-size:.8rem;padding:.6rem .9rem;letter-spacing:.02em}

/* Icon Feature Cards */
.icon-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem}
.icon-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.75rem 1.5rem;display:flex;flex-direction:column;gap:.75rem;box-shadow:var(--shadow)}
.icon-card .ic-icon{width:56px;height:56px;border-radius:16px;display:grid;place-items:center;font-size:1.6rem;flex-shrink:0}
.icon-card h3{font-size:1.05rem;font-weight:700;color:var(--navy);margin:0}
.icon-card p{color:var(--muted);font-size:.93rem;line-height:1.6;margin:0;flex:1}
.ic-orange{background:#fff7ed;color:var(--accent)}
.ic-blue{background:#eff6ff;color:#2563eb}
.ic-green{background:#f0fdf4;color:#16a34a}
.ic-red{background:#fef2f2;color:#dc2626}
.ic-purple{background:#faf5ff;color:#7c3aed}
.ic-teal{background:#f0fdfa;color:#0d9488}
.ic-yellow{background:#fefce8;color:#ca8a04}
.ic-gray{background:#f8fafc;color:#475569}

/* Hero Visual Split */
.hero-photo-split{display:grid;grid-template-columns:1fr 1fr;gap:0;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.hero-photo-split img{width:100%;height:320px;object-fit:cover;display:block}

/* Stats Bar */
.stats-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border-radius:var(--radius);overflow:hidden;margin:2.5rem 0}
.stat-item{background:#fff;padding:1.5rem 1rem;text-align:center}
.stat-number{font-family:'Barlow Condensed',sans-serif;font-size:2.2rem;font-weight:800;color:var(--accent);line-height:1}
.stat-label{font-size:.8rem;color:var(--muted);margin-top:.35rem;letter-spacing:.03em;text-transform:uppercase}

/* Process Visual */
.process-visual{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.5rem;counter-reset:step}
.process-step{position:relative;padding:1.5rem;background:#fff;border-radius:var(--radius);border:1px solid var(--line);counter-increment:step}
.process-step::before{content:counter(step);position:absolute;top:-14px;left:1.25rem;width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;font-weight:800;font-size:.85rem;display:grid;place-items:center;font-family:'Barlow Condensed',sans-serif}
.process-step h4{margin:0 0 .5rem;font-size:1rem;color:var(--navy)}
.process-step p{margin:0;font-size:.9rem;color:var(--muted)}

/* Highlight Box */
.highlight-box{background:linear-gradient(135deg,#fff7ed,#fff);border:1.5px solid #fed7aa;border-radius:var(--radius);padding:2rem;display:flex;gap:1.25rem;align-items:flex-start}
.highlight-box .hb-icon{font-size:2rem;flex-shrink:0;margin-top:.1rem}
.highlight-box h3{margin:0 0 .4rem;color:var(--navy)}
.highlight-box p{margin:0;color:var(--muted);line-height:1.65}

/* Emergency Banner */
.emergency-banner{background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff;border-radius:var(--radius);padding:2rem;text-align:center;margin:2rem 0}
.emergency-banner h3{font-family:'Barlow Condensed',sans-serif;font-size:1.8rem;margin:0 0 .5rem;letter-spacing:.02em}
.emergency-banner p{margin:0 0 1.25rem;opacity:.9}

/* Comparison Table */
.compare-table{width:100%;border-collapse:collapse;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.compare-table th{background:var(--navy);color:#fff;padding:.9rem 1.1rem;text-align:left;font-size:.9rem;letter-spacing:.03em}
.compare-table td{padding:.85rem 1.1rem;border-bottom:1px solid var(--line);font-size:.92rem}
.compare-table tr:last-child td{border-bottom:none}
.compare-table tr:nth-child(even) td{background:var(--card-soft)}
.compare-table .good{color:#16a34a;font-weight:700}
.compare-table .bad{color:#dc2626}

/* Checklist */
.check-list{list-style:none;padding:0;display:grid;gap:.6rem}
.check-list li{display:flex;gap:.75rem;align-items:flex-start;padding:.7rem 1rem;background:#fff;border-radius:12px;border:1px solid var(--line);font-size:.93rem}
.check-list li::before{content:'✓';color:#16a34a;font-weight:800;flex-shrink:0;margin-top:.05rem}

/* Responsive */
@media(max-width:767px){
  .photo-strip.duo,.photo-strip.trio{grid-template-columns:1fr}
  .stats-bar{grid-template-columns:repeat(2,1fr)}
  .hero-photo-split{grid-template-columns:1fr}
  .hero-photo-split img{height:200px}
  .process-visual{grid-template-columns:1fr}
  .icon-grid{grid-template-columns:1fr}
}


/* ─── TRUST BAR ─── */
.trust-bar{background:var(--navy);padding:1rem 0;margin-top:0}
.trust-bar-inner{display:flex;flex-wrap:wrap;gap:1.5rem;align-items:center;justify-content:center}
.trust-item{display:flex;align-items:center;gap:.6rem;color:#dce4ef;font-size:.92rem;white-space:nowrap}
.trust-item strong{color:#fff;font-size:1.1rem}
.trust-icon{width:28px;height:28px;flex-shrink:0}

/* ─── WORK PHOTOS STRIP ─── */
.work-strip{display:grid;gap:1rem}
.work-strip.cols-2{grid-template-columns:1fr 1fr}
.work-strip.cols-3{grid-template-columns:1fr 1fr 1fr}
.work-photo{border-radius:var(--radius);overflow:hidden;position:relative;aspect-ratio:4/3;cursor:pointer}
.work-photo img{width:100%;height:100%;object-fit:cover;transition:transform .45s ease}
.work-photo:hover img{transform:scale(1.05)}
.work-photo-label{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(11,18,32,.88));color:#fff;font-size:.8rem;font-weight:600;padding:.55rem .75rem;letter-spacing:.02em}

/* ─── FEATURE ICON CARDS ─── */
.icon-feature-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem}
.icon-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem;display:flex;flex-direction:column;gap:.85rem;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s}
.icon-card:hover{transform:translateY(-3px);box-shadow:0 24px 60px rgba(15,23,42,.13)}
.icon-card-head{display:flex;align-items:center;gap:.85rem}
.icon-card-ico{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;flex-shrink:0}
.icon-card-ico svg{width:26px;height:26px}
.icon-card h3{margin:0;font-size:1.05rem;color:var(--navy)}
.icon-card p{margin:0;color:var(--muted);font-size:.93rem;line-height:1.6}

/* ─── STAT NUMBERS ─── */
.stat-row{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center;margin:2rem 0}
.stat-item{text-align:center;padding:1.25rem 1.75rem;background:var(--card-soft);border-radius:var(--radius)}
.stat-num{font-family:"Barlow Condensed",sans-serif;font-size:2.5rem;font-weight:800;color:var(--accent);line-height:1}
.stat-label{font-size:.83rem;color:var(--muted);margin-top:.35rem}

@media(max-width:767px){
  .work-strip.cols-3{grid-template-columns:1fr 1fr}
  .work-strip.cols-2{grid-template-columns:1fr}
  .trust-bar-inner{gap:1rem}
  .trust-item{font-size:.82rem}
}
@media(max-width:480px){
  .work-strip.cols-3{grid-template-columns:1fr}
}

/* ─── PHOTO SHOWCASE ─── */
.photo-showcase{padding:3rem 0;background:var(--bg-soft) /* dark band */}
.photo-showcase .container{display:flex;flex-direction:column;gap:1.5rem}
.photo-showcase-header{text-align:center}
.photo-showcase-header .section-kicker{color:#f97316}
.photo-showcase-header h2{color:#fff;margin:.5rem 0}
.photo-showcase-header p{color:#94a3b8;max-width:600px;margin:0 auto}
.photo-grid{display:grid;gap:1rem}
.photo-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.photo-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.photo-grid.cols-4{grid-template-columns:repeat(2,1fr)}
.photo-tile{border-radius:16px;overflow:hidden;position:relative;aspect-ratio:4/3;cursor:pointer}
.photo-tile img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.photo-tile:hover img{transform:scale(1.04)}
.photo-tile figcaption{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(11,18,32,.9));color:#fff;font-size:.82rem;font-weight:600;padding:.75rem 1rem;opacity:0;transition:opacity .3s}
.photo-tile:hover figcaption{opacity:1}
.photo-tile.tall{aspect-ratio:3/4}
.photo-tile.wide{aspect-ratio:16/7}

/* ─── SVG SERVICE ICONS ─── */
.svc-icon-band{padding:2.5rem 0;background:var(--card-soft)}
.svc-icon-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1.5rem;text-align:center}
.svc-icon-item{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem 1rem;background:#fff;border-radius:20px;border:1px solid var(--line);transition:box-shadow .25s,transform .25s}
.svc-icon-item:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.svc-icon-item svg{width:52px;height:52px}
.svc-icon-item strong{font-size:.9rem;color:var(--navy);line-height:1.3}
.svc-icon-item p{font-size:.8rem;color:var(--muted);margin:0;line-height:1.4}

/* ─── VISUAL STATS BAR ─── */
.stats-bar{background:linear-gradient(135deg,var(--accent) 0%,#f59e0b 100%);padding:2rem 0}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1.5rem;text-align:center}
.stat-item{color:#fff}
.stat-num{font-family:"Barlow Condensed",Impact,Arial Black,sans-serif;font-size:2.2rem;font-weight:800;line-height:1;display:block}
.stat-label{font-size:.85rem;opacity:.9;margin-top:.2rem}

/* ─── TRUST BADGES ─── */
.trust-badges{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.5rem}
.trust-badge{display:inline-flex;align-items:center;gap:.5rem;background:#fff;border:1px solid var(--line);border-radius:999px;padding:.5rem 1rem;font-size:.85rem;font-weight:600;color:var(--navy)}
.trust-badge svg{width:18px;height:18px;color:var(--accent)}

/* ─── SECTION WITH PHOTO SPLIT ─── */
.split-photo-section{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.split-photo-section .photo-col{border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3}
.split-photo-section .photo-col img{width:100%;height:100%;object-fit:cover}
.split-photo-section .content-col{display:flex;flex-direction:column;gap:1.25rem}

/* ─── PROCESS VISUAL ─── */
.process-visual{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;position:relative}
.process-step{text-align:center;padding:1.75rem 1.25rem;background:#fff;border-radius:20px;border:1px solid var(--line);position:relative}
.process-step-num{width:44px;height:44px;border-radius:50%;background:var(--accent);color:#fff;font-weight:800;font-size:1.2rem;display:grid;place-items:center;margin:0 auto 1rem}
.process-step h3{font-size:1rem;margin:0 0 .5rem;color:var(--navy)}
.process-step p{font-size:.88rem;color:var(--muted);margin:0}

@media(max-width:767px){
  .photo-grid.cols-2,.photo-grid.cols-3,.photo-grid.cols-4{grid-template-columns:1fr}
  .split-photo-section{grid-template-columns:1fr}
  .split-photo-section .photo-col{order:-1}
  .stat-num{font-size:2.2rem}
  .process-visual{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
  .process-visual{grid-template-columns:1fr}
}

/* Safety */
svg{max-width:100%;height:auto}
.svc-icon-item svg,.svc-icon-band svg{width:52px!important;height:52px!important}

/* Stats bar photo split — mobile stack */
@media(max-width:640px){
  .stats-bar > div > div{grid-template-columns:1fr!important}
  .stats-bar > div > div > div:last-child{min-height:200px!important}
}

/* ═══════════════════════════════════════
   MOBILE OPTIMIZATION — Phones & Tablets
   ═══════════════════════════════════════ */

/* ── Hide topbar on mobile — saves ~42px of precious screen space ── */
@media(max-width:767px){
  .topbar{ display:none }
}

/* ── Compact nav on mobile ── */
@media(max-width:767px){
  .nav-row{ padding:.6rem 0 }
  .brand-mark{ width:42px;height:42px;font-size:1.2rem;border-radius:12px }
  .brand-text strong{ font-size:1.35rem }
  .brand-text small{ font-size:.8rem }
  .site-header{ position:sticky;top:0;z-index:40 }
}

/* ── Hero section mobile ── */
@media(max-width:767px){
  .hero{ padding:2rem 0 }
  .hero-grid{
    grid-template-columns:1fr!important;
    gap:1.5rem;
  }
  .hero h1{ font-size:1.75rem!important;line-height:1.2 }
  .hero-text{ font-size:.95rem }
  .hero-card{ display:none } /* hide the dark info card on mobile — saves space */
  .eyebrow{ font-size:.78rem }
  .cta-row{ flex-wrap:wrap;gap:.6rem }
  .cta-row .btn{ flex:1;min-width:140px;text-align:center;font-size:.88rem;padding:.7rem .9rem }
  .hero-points{ flex-wrap:wrap;gap:.4rem .75rem }
  .hero-points li{ font-size:.82rem }
}

/* ── Service grid mobile ── */
@media(max-width:767px){
  .service-grid{ grid-template-columns:1fr }
  .feature-grid{ grid-template-columns:1fr }
  .section{ padding:2rem 0 }
  .section-intro{ font-size:.95rem }
}

/* ── Two column sections stack on mobile ── */
@media(max-width:767px){
  .two-col{ grid-template-columns:1fr!important;gap:2rem }
  .split-photo-section{ grid-template-columns:1fr!important }
  .contact-grid{ grid-template-columns:1fr!important;gap:2rem }
}

/* ── Gallery mobile ── */
@media(max-width:767px){
  .gallery-grid{ grid-template-columns:1fr 1fr;gap:.6rem }
  .photo-grid.cols-2,
  .photo-grid.cols-3,
  .photo-grid.cols-4{ grid-template-columns:1fr 1fr }
}

/* ── Reviews mobile ── */
@media(max-width:767px){
  .reviews-grid{ grid-template-columns:1fr }
}

/* ── Process steps mobile ── */
@media(max-width:767px){
  .process-visual{ grid-template-columns:1fr 1fr }
  .stats-grid{ grid-template-columns:1fr 1fr }
}

/* ── City grid mobile ── */
@media(max-width:767px){
  .city-grid{ columns:2;gap:.5rem }
}

/* ── Form mobile ── */
@media(max-width:767px){
  .form-split{ grid-template-columns:1fr!important }
  .contact-card{ padding:1.25rem }
}

/* ── Footer mobile ── */
@media(max-width:767px){
  .footer-grid{ grid-template-columns:1fr!important;gap:1.5rem }
  .footer-bottom{ text-align:center;font-size:.8rem }
}

/* ── WhatsApp + Review buttons mobile — don't overlap ── */
@media(max-width:767px){
  .wa-float{ bottom:.85rem;right:.85rem;width:46px;height:46px }
  a[style*="Reseña Google"],
  a[title*="Reseña"]{
    bottom:4.5rem!important;
    right:.85rem!important;
    font-size:.72rem!important;
    padding:.45rem .7rem!important;
  }
}

/* ── Tablet (768–1023px) ── */
@media(min-width:768px) and (max-width:1023px){
  .topbar{ font-size:.82rem }
  .topbar-inner{ flex-direction:column;gap:.25rem;padding:.5rem 0;text-align:center }
  .hero-grid{ grid-template-columns:1fr 1fr;gap:1.5rem }
  .service-grid{ grid-template-columns:1fr 1fr }
  .feature-grid{ grid-template-columns:1fr 1fr }
  .contact-grid{ grid-template-columns:1fr 1fr }
  .gallery-grid{ grid-template-columns:repeat(3,1fr) }
}

/* ── Large screens (1200px+) ── */
@media(min-width:1200px){
  .hero-grid{ gap:3rem }
  .hero h1{ font-size:2.8rem }
}

/* ── Touch targets — iOS & Android ── */
@media(max-width:767px){
  a,button,select,input[type="submit"]{
    min-height:44px; /* Apple HIG minimum touch target */
  }
  .nav-toggle{ width:44px;height:44px }
  details summary{ min-height:44px;display:flex;align-items:center }
}

/* ── Smooth scrolling & safe area insets (iPhone notch) ── */
html{ scroll-behavior:smooth }
body{
  padding-bottom:env(safe-area-inset-bottom);
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
}
