:root{--bg:#f4f5f7;--text:#1f2430;--muted:#5d6778;--dark:#111827;--primary:#b3263b;--primary-dark:#8f1f31;--line:#e3e6ea;--card:#ffffff;--accent:#f6d37a;--charcoal:#23272f;--charcoal-soft:#2d333b}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text);line-height:1.6}a{text-decoration:none;color:inherit}img{max-width:100%;display:block}
.wrap{max-width:1200px;margin:0 auto;padding:0 20px}.site-header{position:sticky;top:0;z-index:1000;background:#efd2d6;border-bottom:1px solid #d1a1a8;box-shadow:0 8px 24px rgba(15,23,42,.06)}.nav-wrap{display:flex;align-items:center;justify-content:space-between;gap:20px;min-height:110px;flex-wrap:wrap}.brand{display:flex;align-items:center;gap:16px}.brand-mark{width:68px;height:68px;border-radius:18px;background:linear-gradient(135deg,#8f1f31,#c03a52);display:grid;place-items:center;color:#fff;font-weight:800;font-size:24px;box-shadow:0 10px 24px rgba(143,31,49,.25)}.brand-text strong{display:block;font-size:1.5rem;line-height:1.1;font-weight:800;color:#161616}.brand-text small{display:block;font-size:.95rem;line-height:1.15;color:#3a3a3a}.top-nav{display:flex;gap:14px;flex-wrap:wrap;justify-content:flex-end}.top-nav a{color:#161616;font-weight:600;padding:8px 12px;border-radius:999px}.top-nav a:hover,.top-nav a.active{color:#8f1f31;background:#f6e2e5}
.hero,.sub-hero{background:linear-gradient(135deg,#b3263b 0%,#8f1f31 100%);color:#fff}.hero{padding:76px 0 68px}.sub-hero{padding:56px 0}.hero-grid{display:grid;grid-template-columns:1.2fr .9fr;gap:30px;align-items:center}.hero h1,.sub-hero h1{font-size:46px;line-height:1.08;margin:0 0 14px}.lead{font-size:19px;color:#e5e7eb;margin-bottom:16px}.eyebrow{display:inline-block;margin:0 0 12px;color:var(--accent);font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:12px}.chip-row,.cta-row{display:flex;gap:10px;flex-wrap:wrap}.chip{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);padding:8px 12px;border-radius:999px;font-size:12px;text-transform:uppercase;letter-spacing:.06em}.btn,.btn:visited,.btn:link{display:inline-flex;align-items:center;justify-content:center;background:var(--primary);color:#fff !important;padding:11px 20px;border-radius:999px;font-weight:600;border:1px solid var(--primary);letter-spacing:.01em;box-shadow:0 10px 22px rgba(179,38,59,.20);transition:transform .2s ease,box-shadow .2s ease,background .2s ease,border-color .2s ease;text-decoration:none}.btn:hover,.btn:focus{transform:translateY(-1px);box-shadow:0 14px 28px rgba(179,38,59,.24);background:var(--primary-dark);border-color:var(--primary-dark)}.btn-secondary{background:transparent;border-color:rgba(255,255,255,.72);box-shadow:none}.btn-secondary:hover,.btn-secondary:focus{background:rgba(255,255,255,.10);border-color:#fff}.btn-block{width:100%;margin-top:10px}
.contact-card,.panel,.service-card,.gallery-card,.stat-box,.scope-card{background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:0 12px 30px rgba(17,24,39,.06)}.contact-card{padding:24px;color:var(--text)}.contact-card h3{margin-top:0}.contact-card a{color:var(--primary)}
.section{padding:72px 0}.section-alt{background:#f6f7f9}.section-dark{background:linear-gradient(180deg,#2b3037 0%,#23272f 100%);color:#ffffff}.section-dark .section-heading p,.section-dark p{color:#e5e7eb}.section-heading{max-width:760px;margin-bottom:28px}.section-heading h2,.section h2{font-size:34px;line-height:1.15;margin:0 0 12px}.section-heading p{color:#5e6773}.stats-grid,.service-grid,.gallery-grid,.scope-grid{display:grid;gap:22px}.stats-grid{grid-template-columns:repeat(4,1fr)}.service-grid{grid-template-columns:repeat(3,1fr)}.gallery-grid{grid-template-columns:repeat(3,1fr)}.scope-grid{grid-template-columns:repeat(3,1fr)}.stat-box,.scope-card{padding:22px}.stat-box strong,.scope-card strong{display:block;margin-bottom:10px;font-size:18px}.service-card{overflow:hidden}.service-card img,.service-card .placeholder{width:100%;height:230px;object-fit:cover}.service-card-body{padding:18px}.service-card h3{margin:0 0 8px;font-size:22px}.service-card p{margin:0 0 14px;color:#5e6773}.text-link{color:var(--primary);font-weight:700}.two-col,.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:26px;align-items:start}.bullet-list{padding-left:18px}.bullet-list li{margin-bottom:8px}.hero-media img{width:100%;height:420px;object-fit:cover;border-radius:20px;border:1px solid rgba(255,255,255,.12);box-shadow:0 18px 45px rgba(0,0,0,.25)}.gallery-card{overflow:hidden}.gallery-card img,.gallery-card .placeholder{width:100%;height:250px;object-fit:cover}.gallery-copy{padding:18px}.gallery-copy h3{margin:0 0 8px;font-size:21px}.gallery-copy p{margin:0;color:#5e6773}.placeholder{display:grid;place-items:center;background:linear-gradient(135deg,#2b3037,#4d5663);color:#fff;font-weight:800;text-align:center;padding:20px;font-size:28px}.placeholder.small{height:250px;font-size:22px}
.quote-form{display:grid;gap:14px}.quote-form label{display:grid;gap:8px;font-weight:700}.quote-form input,.quote-form select,.quote-form textarea{width:100%;padding:12px 14px;border-radius:12px;border:1px solid #d5d9e0;background:#fff;color:#111827;font:inherit}.contact-lines p{margin:.3rem 0}.cta-panel{text-align:center;padding:28px}.site-footer{background:#1a1e24;color:#f1f3f5;padding-top:40px}.footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:28px}.footer-grid h3,.footer-grid h4{color:#fff;margin-top:0}.footer-bottom{padding:18px 20px;border-top:1px solid rgba(255,255,255,.08);margin-top:18px;font-size:14px}.muted{color:var(--muted)}
@media (max-width:1050px){.top-nav{display:none}.hero h1,.sub-hero h1{font-size:38px}.stats-grid{grid-template-columns:repeat(2,1fr)}.service-grid,.gallery-grid,.scope-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:760px){.hero-grid,.two-col,.contact-grid,.footer-grid{grid-template-columns:1fr}.service-grid,.gallery-grid,.stats-grid,.scope-grid{grid-template-columns:1fr}.hero h1,.sub-hero h1{font-size:32px}.section{padding:56px 0}.hero-media img{height:280px}}
.brand{display:flex;align-items:center;gap:0;text-decoration:none}.brand-logo{display:block;height:72px;width:auto;max-width:min(52vw,460px);object-fit:contain}.brand-mark,.brand-text{display:none}.nav-wrap{row-gap:12px}@media (max-width: 900px){.brand-logo{height:60px;max-width:70vw}.nav-wrap{justify-content:center}.top-nav{justify-content:center}}


.topbar{background:#111827;color:#fff;font-size:14px}.topbar .wrap{display:flex;gap:18px;justify-content:space-between;align-items:center;min-height:46px;flex-wrap:wrap}.topbar a{color:#fff}.topbar-left,.topbar-right{display:flex;gap:18px;align-items:center;flex-wrap:wrap}.topbar strong{color:#f6d37a}.hero-contact-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}.hero-contact-link{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.2);padding:10px 14px;border-radius:999px;color:#fff;font-weight:700}.hero-contact-link:hover{background:rgba(255,255,255,.2)}.contact-card .mini-title{margin:18px 0 8px;font-size:14px;letter-spacing:.08em;text-transform:uppercase;color:#5d6778}.contact-action-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}.info-list,.license-list{padding-left:18px;margin:10px 0 0}.info-list li,.license-list li{margin-bottom:8px}.contact-badge{display:inline-block;background:#fbe9ec;color:#8f1f31;border:1px solid #efc2ca;padding:8px 12px;border-radius:999px;font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.04em;margin-bottom:10px}.contact-note{margin-top:10px;color:#5d6778;font-size:14px}.success-note{display:none;margin-top:12px;padding:12px 14px;border-radius:12px;background:#edf8f0;border:1px solid #b5dfc1;color:#1f5130;font-weight:700}.quote-form .helper{font-size:14px;color:#5d6778;font-weight:400;margin-top:-4px}.footer-grid-large{grid-template-columns:1.2fr 1fr 1.2fr}.footer-list{list-style:none;padding:0;margin:0}.footer-list li{margin-bottom:7px}.footer-list a{color:#f1f3f5}.footer-list strong{color:#fff}.license-columns{columns:2;column-gap:24px}.license-columns li{break-inside:avoid}@media (max-width:760px){.topbar .wrap,.topbar-left,.topbar-right{justify-content:center}.contact-action-grid{grid-template-columns:1fr}.license-columns{columns:1}}


/* Center titles across all pages */
.section-heading,
.section-heading h1,
.section-heading h2,
.section-heading h3,
.service-card h3,
.gallery-copy h3,
.contact-card h3,
.panel h3,
.sub-hero,
.sub-hero h1,
.hero h1{
  text-align:center;
}

/* Make only the "Why Clients Choose Us" eyebrow larger */
.section-heading .eyebrow{
  font-size:24px;
  line-height:1.1;
}


/* Make "Why Clients Choose Us" black */
.section-heading .eyebrow{
  color:#000;
}


/* Make only the Services eyebrow 3x bigger */
.sub-hero .eyebrow{
  font-size:36px;
  line-height:1.1;
}


/* Make hero eyebrow 2x, centered, full line */
.hero .eyebrow{
  font-size:24px;
  line-height:1.15;
  text-align:center;
  display:block;
  width:100%;
}


/* Organized CTA alignment */
.cta-row,
.hero-contact-row,
.contact-action-grid{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  justify-content:center;
  align-items:center;
}
.hero-contact-row{
  margin-top:16px;
}
.contact-action-grid .btn,
.cta-row .btn,
.hero-contact-link{
  min-width:190px;
  text-align:center;
  justify-content:center;
}
.hero-contact-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 18px;
  border-radius:8px;
  border:2px solid var(--primary);
  background:#fff;
  color:var(--primary);
  font-weight:700;
}


/* Make hero contact links green */
.hero-contact-link{
  background:#16a34a !important;
  border-color:#16a34a !important;
  color:#111827 !important;
}


/* Upgrade hero chips style */
.chip-row{
  justify-content:center;
  gap:14px;
  margin:18px 0 8px;
}
.chip{
  background:#ffffff;
  color:#111827;
  border:2px solid #16a34a;
  padding:10px 18px;
  border-radius:999px;
  font-size:13px;
  font-weight:700;
  letter-spacing:.05em;
  box-shadow:0 8px 20px rgba(0,0,0,.08);
}


/* Align the three hero chips evenly */
.chip-row{
  display:flex;
  flex-wrap:nowrap;
  justify-content:center;
  align-items:center;
  gap:14px;
  margin:18px 0 8px;
}
.chip-row .chip{
  min-width:220px;
  text-align:center;
}
@media (max-width:760px){
  .chip-row{
    flex-wrap:wrap;
  }
}


/* Make all buttons green across all pages */
.btn{
  background:#16a34a !important;
  border-color:#16a34a !important;
  color:#111827 !important;
}
.btn-secondary{
  background:#16a34a !important;
  border-color:#16a34a !important;
  color:#ffffff !important;
}
.btn:hover,
.btn-secondary:hover{
  background:#15803d !important;
  border-color:#15803d !important;
  color:#ffffff !important;
}


/* Full-line impact hero labels */



/* Full-line labels across all service pages */


/* Global one-line labels: exact same size across service pages */
.full-line-label,
.impact-hero-line{
  display:block;
  width:100%;
  text-align:center;
  margin:18px 0 8px;
  font-size:11px;
  font-weight:700;
  letter-spacing:0;
  color:#ffffff;
  white-space:nowrap;
  line-height:1.1;
  text-transform:uppercase;
}

/* Per-page fine tuning so every page fits cleanly while keeping the same size */
.full-line-backflow{letter-spacing:-0.01em;}
.full-line-electrical{letter-spacing:-0.01em;}
.full-line-fire-alarm{letter-spacing:-0.01em;}
.full-line-general-contracting{letter-spacing:-0.015em;}
.full-line-home-inspections{letter-spacing:-0.015em;}
.full-line-hvac{letter-spacing:-0.01em;}
.full-line-roofing{letter-spacing:-0.01em;}
.full-line-shell-structural{letter-spacing:-0.02em;}
.full-line-solar-panels{letter-spacing:-0.015em;}
.full-line-tile{letter-spacing:-0.015em;}

/* Home page refinement */
.home-eyebrow{
  white-space:nowrap;
  font-size:11px;
  letter-spacing:0.08em;
}
.home-contact-badge{
  white-space:nowrap;
}

/* Responsive refinement */
@media (max-width: 992px){
  .full-line-label,
  .impact-hero-line{
    font-size:10px;
  }
  .home-eyebrow{
    font-size:10px;
    letter-spacing:0.06em;
  }
}

@media (max-width: 768px){
  .full-line-label,
  .impact-hero-line{
    font-size:9px;
  }
  .home-eyebrow,
  .home-contact-badge{
    font-size:10px;
    letter-spacing:0.04em;
    white-space:nowrap;
  }
}

@media (max-width: 480px){
  .full-line-label,
  .impact-hero-line{
    font-size:8px;
  }
  .home-eyebrow,
  .home-contact-badge{
    font-size:9px;
    letter-spacing:0.02em;
  }
}



/* Premium pass for one-line labels across pages */
.full-line-label,
.impact-hero-line,
.home-main-line{
  display:block;
  width:100%;
  text-align:center;
  margin:18px 0 10px;
  font-size:11.5px;
  font-weight:700;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#8ec5ff;
  white-space:nowrap;
  line-height:1.12;
  font-family:inherit;
  text-shadow:0 1px 10px rgba(0,0,0,0.16);
}

.home-main-line{
  margin:14px 0 6px;
}

.home-eyebrow{
  white-space:nowrap;
  font-size:11px;
  letter-spacing:0.12em;
  font-weight:700;
}

.home-contact-badge{
  white-space:nowrap;
  letter-spacing:0.06em;
}

.full-line-backflow{letter-spacing:0.07em;}
.full-line-electrical{letter-spacing:0.07em;}
.full-line-fire-alarm{letter-spacing:0.07em;}
.full-line-general-contracting{letter-spacing:0.06em;}
.full-line-home-inspections{letter-spacing:0.06em;}
.full-line-hvac{letter-spacing:0.07em;}
.full-line-roofing{letter-spacing:0.07em;}
.full-line-shell-structural{letter-spacing:0.04em;}
.full-line-solar-panels{letter-spacing:0.06em;}
.full-line-tile{letter-spacing:0.06em;}

@media (max-width: 992px){
  .full-line-label,
  .impact-hero-line,
  .home-main-line{
    font-size:10.5px;
    letter-spacing:0.06em;
  }

  .home-eyebrow{
    font-size:10.5px;
    letter-spacing:0.10em;
  }
}

@media (max-width: 768px){
  .full-line-label,
  .impact-hero-line,
  .home-main-line{
    font-size:9px;
    letter-spacing:0.04em;
  }

  .home-eyebrow,
  .home-contact-badge{
    font-size:9.25px;
    letter-spacing:0.05em;
    white-space:nowrap;
  }
}

@media (max-width: 480px){
  .full-line-label,
  .impact-hero-line,
  .home-main-line{
    font-size:8px;
    letter-spacing:0.02em;
  }

  .home-eyebrow,
  .home-contact-badge{
    font-size:8.5px;
    letter-spacing:0.03em;
  }
}



/* Two-color premium preview */
.full-line-label,
.impact-hero-line,
.home-main-line{
  color:#ffffff;
}

.line-sep{
  color:#000000;
  display:inline-block;
  padding:0 0.18em;
  font-weight:700;
  text-shadow:0 1px 10px rgba(0,0,0,0.14);
}

.home-eyebrow .line-sep,
.home-contact-badge .line-sep{
  color:#000000;
}



/* Floating WhatsApp button */
.whatsapp-float{
  position:fixed;
  right:22px;
  bottom:22px;
  z-index:9999;
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:12px 16px;
  border-radius:999px;
  background:#25D366;
  color:#fff !important;
  font-weight:700;
  box-shadow:0 14px 32px rgba(37,211,102,.32);
  text-decoration:none;
  animation:whatsappPulse 1.8s infinite;
}
.whatsapp-float:hover{
  background:#1ebe5d;
  transform:translateY(-1px) scale(1.02);
}
.whatsapp-float svg{
  width:22px;
  height:22px;
  flex:0 0 22px;
  fill:currentColor;
}
.whatsapp-float-text{
  white-space:nowrap;
  line-height:1;
}
@keyframes whatsappPulse{
  0%{box-shadow:0 0 0 0 rgba(37,211,102,.45),0 14px 32px rgba(37,211,102,.28)}
  70%{box-shadow:0 0 0 14px rgba(37,211,102,0),0 14px 32px rgba(37,211,102,.28)}
  100%{box-shadow:0 0 0 0 rgba(37,211,102,0),0 14px 32px rgba(37,211,102,.28)}
}
#phg-assistant.is-open .phg-assistant-bubble{
  width:116px;
  height:116px;
  border-radius:26px;
  box-shadow:0 22px 48px rgba(15,23,42,.34);
  transform:translateY(-4px);
}
#phg-assistant.is-open .phg-assistant-bubble img{
  border-radius:22px;
}

@media (max-width:640px){
  .whatsapp-float{
    right:14px;
    bottom:14px;
    padding:12px 14px;
  }
  .whatsapp-float-text{
    font-size:14px;
  }
}

/* All site buttons green with black text, keep floating WhatsApp green with white text */
.btn,
.btn:visited,
.btn:link,
.btn-secondary,
.hero-contact-link{
  background:#25D366 !important;
  border-color:#25D366 !important;
  color:#111827 !important;
  box-shadow:0 10px 24px rgba(37,211,102,.22) !important;
}

.btn:hover,
.btn:focus,
.btn-secondary:hover,
.btn-secondary:focus,
.hero-contact-link:hover,
.hero-contact-link:focus{
  background:#1ebe5d !important;
  border-color:#1ebe5d !important;
  color:#111827 !important;
}

.whatsapp-float,
.whatsapp-float:visited,
.whatsapp-float:link{
  background:#25D366 !important;
  border-color:#25D366 !important;
  color:#ffffff !important;
}

.whatsapp-float:hover,
.whatsapp-float:focus{
  background:#1ebe5d !important;
  border-color:#1ebe5d !important;
  color:#ffffff !important;
}


/* Force floating WhatsApp button text and icon to black */
.whatsapp-float,
.whatsapp-float:link,
.whatsapp-float:visited,
.whatsapp-float:hover,
.whatsapp-float:focus,
.whatsapp-float:active,
.whatsapp-float span,
.whatsapp-float .whatsapp-float-text,
.whatsapp-float svg{
  color:#111827 !important;
  fill:#111827 !important;
}


/* Floating Call Office button */
.call-float{
  position:fixed;
  right:22px;
  bottom:88px;
  z-index:9998;
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:12px 16px;
  border-radius:999px;
  background:#25D366;
  color:#111827 !important;
  font-weight:700;
  box-shadow:0 14px 32px rgba(37,211,102,.22);
  text-decoration:none;
}
.call-float:hover,
.call-float:focus{
  background:#1ebe5d;
  border-color:#1ebe5d;
  color:#111827 !important;
  transform:translateY(-1px) scale(1.02);
}
.call-float svg{
  width:20px;
  height:20px;
  flex:0 0 20px;
  fill:currentColor;
}
.call-float-text{
  white-space:nowrap;
  line-height:1;
}
@media (max-width:640px){
  .call-float{
    right:14px;
    bottom:92px;
    padding:12px 14px;
  }
  .call-float-text{
    font-size:14px;
  }
}


/* Floating Email button */
.email-float{
  position:fixed;
  right:22px;
  bottom:154px;
  z-index:9997;
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:12px 16px;
  border-radius:999px;
  background:#25D366;
  color:#111827 !important;
  font-weight:700;
  box-shadow:0 14px 32px rgba(37,211,102,.22);
  text-decoration:none;
}
.email-float:hover,
.email-float:focus{
  background:#1ebe5d;
  border-color:#1ebe5d;
  color:#111827 !important;
  transform:translateY(-1px) scale(1.02);
}
.email-float svg{
  width:20px;
  height:20px;
  flex:0 0 20px;
  fill:currentColor;
}
.email-float-text{
  white-space:nowrap;
  line-height:1;
}
@media (max-width:640px){
  .email-float{
    right:14px;
    bottom:142px;
    padding:12px 14px;
  }
  .email-float-text{
    font-size:14px;
  }
}


/* Center footer content for cleaner alignment */
.site-footer{
  text-align:center !important;
}
.footer-grid,
.footer-grid-large{
  text-align:center !important;
  align-items:start !important;
}
.site-footer h3,
.site-footer h4,
.site-footer p,
.site-footer li,
.site-footer .footer-bottom{
  text-align:center !important;
}
.site-footer .footer-list{
  list-style-position:inside;
  padding-left:0 !important;
  margin-left:0 !important;
}
.site-footer .license-columns{
  columns:1 !important;
}
.footer-bottom{
  text-align:center !important;
}


/* Refined bordered navigation buttons */
.top-nav{
  gap:10px !important;
  flex-wrap:wrap;
  justify-content:center;
}

.top-nav a{
  display:inline-flex !important;
  align-items:center;
  justify-content:center;
  padding:10px 14px !important;
  border:1.5px solid rgba(255,255,255,.22) !important;
  border-radius:999px !important;
  background:rgba(255,255,255,.04) !important;
  box-shadow:0 8px 18px rgba(0,0,0,.12);
  transition:all .22s ease;
}

.top-nav a:hover,
.top-nav a:focus{
  border-color:#25D366 !important;
  background:rgba(37,211,102,.14) !important;
  color:#ffffff !important;
  transform:translateY(-1px);
}

.top-nav a.active{
  border-color:#25D366 !important;
  background:#25D366 !important;
  color:#111827 !important;
  box-shadow:0 10px 22px rgba(37,211,102,.28);
}

@media (max-width: 900px){
  .top-nav{
    gap:8px !important;
  }
  .top-nav a{
    padding:9px 12px !important;
    font-size:13px;
  }
}


/* Center and rebalance home hero headline so it does not clip */
.hero h1{
  max-width: 980px;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.18;
  text-wrap: balance;
}
.hero .lead{
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}


/* Center and rebalance Home Inspection hero copy */
.sub-hero .lead{
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  text-wrap: balance;
}


/* Center and rebalance Roofing hero copy */
.sub-hero .lead{
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  text-wrap: balance;
}


/* Keep the last word of Roofing headline visually centered */
.keep-together{
  display:inline-block;
  white-space:nowrap;
}


/* Center and rebalance Plumbing hero copy */
.sub-hero .lead{
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  text-wrap: balance;
}


/* Align multiline service-page headline line starts while keeping the block centered */
.sub-hero h1{
  max-width: 980px;
  margin-left: auto;
  margin-right: auto;
  text-align: left !important;
  text-wrap: balance;
}
.sub-hero .wrap,
.sub-hero .hero-grid{
  justify-items: center;
}


/* Manual line control for cleaner service-page headline starts */
.sub-hero h1 br{
  display:block;
}


/* Floating direct-call buttons for PALMA HIGH-GRADE contacts */
.call-float-office{
  bottom:286px !important;
}
.call-float-nelson{
  bottom:220px !important;
}
.call-float-carmelo{
  bottom:154px !important;
}
.call-float-ramon{
  bottom:88px !important;
}
.email-float{
  bottom:286px !important;
}

@media (max-width:640px){
  .call-float-office{
    bottom:270px !important;
  }
  .call-float-nelson{
    bottom:206px !important;
  }
  .call-float-carmelo{
    bottom:142px !important;
  }
  .call-float-ramon{
    bottom:78px !important;
  }
  .email-float{
    bottom:270px !important;
  }
}

/* Position floating Email button on the left side */
.email-float{
  left:22px !important;
  right:auto !important;
}

@media (max-width:640px){
  .email-float{
    left:14px !important;
    right:auto !important;
  }
}


/* Floating left action buttons below Email Us */
.left-action-float{
  position:fixed;
  left:22px;
  right:auto;
  z-index:9996;
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:12px 16px;
  border-radius:999px;
  background:#25D366;
  color:#111827 !important;
  font-weight:700;
  box-shadow:0 14px 32px rgba(37,211,102,.22);
  text-decoration:none;
}
.left-action-float:hover,
.left-action-float:focus{
  background:#1ebe5d;
  border-color:#1ebe5d;
  color:#111827 !important;
  transform:translateY(-1px) scale(1.02);
}
.left-action-float svg{
  width:20px;
  height:20px;
  flex:0 0 20px;
  fill:currentColor;
}
.left-action-float-text{
  white-space:nowrap;
  line-height:1;
}
.left-action-see-page{
  bottom:220px !important;
}
.left-action-view-service{
  bottom:154px !important;
}
.left-action-send-request{
  bottom:88px !important;
}
@media (max-width:640px){
  .left-action-float{
    left:14px;
    right:auto;
    padding:12px 14px;
  }
  .left-action-float-text{
    font-size:14px;
  }
  .left-action-see-page{
    bottom:206px !important;
  }
  .left-action-view-service{
    bottom:142px !important;
  }
  .left-action-send-request{
    bottom:78px !important;
  }
}


/* PALMA update: smaller floating buttons - keep text labels unchanged */
.whatsapp-float,
.call-float,
.email-float,
.left-action-float{
  padding:6px 9px !important;
  gap:6px !important;
  font-size:12px !important;
  line-height:1 !important;
  min-height:auto !important;
}
.whatsapp-float svg,
.call-float svg,
.email-float svg,
.left-action-float svg{
  width:14px !important;
  height:14px !important;
  flex:0 0 14px !important;
}
.whatsapp-float-text,
.call-float-text,
.email-float-text,
.left-action-float-text{
  font-size:12px !important;
  line-height:1 !important;
}
@media (max-width:640px){
  .whatsapp-float,
  .call-float,
  .email-float,
  .left-action-float{
    padding:5px 8px !important;
    gap:5px !important;
    font-size:11px !important;
  }
  .whatsapp-float svg,
  .call-float svg,
  .email-float svg,
  .left-action-float svg{
    width:13px !important;
    height:13px !important;
    flex:0 0 13px !important;
  }
  .whatsapp-float-text,
  .call-float-text,
  .email-float-text,
  .left-action-float-text{
    font-size:11px !important;
  }
}

/* PALMA update: tighten floating button stacks to save screen space */
.whatsapp-float{
  bottom:18px !important;
}
.call-float-ramon{
  bottom:46px !important;
}
.call-float-carmelo{
  bottom:74px !important;
}
.call-float-nelson{
  bottom:102px !important;
}
.left-action-send-request{
  bottom:18px !important;
}
.left-action-view-service{
  bottom:46px !important;
}
.left-action-see-page{
  bottom:74px !important;
}
@media (max-width:640px){
  .whatsapp-float{
    bottom:12px !important;
  }
  .call-float-ramon{
    bottom:38px !important;
  }
  .call-float-carmelo{
    bottom:64px !important;
  }
  .call-float-nelson{
    bottom:90px !important;
  }
  .left-action-send-request{
    bottom:12px !important;
  }
  .left-action-view-service{
    bottom:38px !important;
  }
  .left-action-see-page{
    bottom:64px !important;
  }
}

/* PALMA final footer alignment: place all action buttons centered directly above copyright */
.footer-floating-buttons{
  display:flex !important;
  justify-content:center !important;
  align-items:center !important;
  flex-wrap:wrap !important;
  gap:8px !important;
  width:100% !important;
  max-width:1180px !important;
  padding:18px 20px 6px !important;
  margin:8px auto 0 !important;
  text-align:center !important;
  box-sizing:border-box !important;
}
.footer-floating-buttons .whatsapp-float,
.footer-floating-buttons .call-float,
.footer-floating-buttons .email-float,
.footer-floating-buttons .left-action-float{
  position:static !important;
  left:auto !important;
  right:auto !important;
  bottom:auto !important;
  top:auto !important;
  z-index:1 !important;
  display:inline-flex !important;
  margin:0 !important;
  transform:none !important;
  animation:none !important;
  padding:6px 9px !important;
  gap:6px !important;
  font-size:12px !important;
  line-height:1 !important;
  min-height:auto !important;
  white-space:nowrap !important;
}
.footer-floating-buttons .whatsapp-float:hover,
.footer-floating-buttons .call-float:hover,
.footer-floating-buttons .email-float:hover,
.footer-floating-buttons .left-action-float:hover,
.footer-floating-buttons .whatsapp-float:focus,
.footer-floating-buttons .call-float:focus,
.footer-floating-buttons .email-float:focus,
.footer-floating-buttons .left-action-float:focus{
  transform:none !important;
}
.footer-floating-buttons svg{
  width:14px !important;
  height:14px !important;
  flex:0 0 14px !important;
}
.footer-floating-buttons .whatsapp-float-text,
.footer-floating-buttons .call-float-text,
.footer-floating-buttons .email-float-text,
.footer-floating-buttons .left-action-float-text{
  font-size:12px !important;
  line-height:1 !important;
}
.site-footer .footer-bottom{
  margin-top:6px !important;
  padding-top:14px !important;
  text-align:center !important;
}
@media (max-width:640px){
  .footer-floating-buttons{
    gap:6px !important;
    padding:14px 12px 6px !important;
  }
  .footer-floating-buttons .whatsapp-float,
  .footer-floating-buttons .call-float,
  .footer-floating-buttons .email-float,
  .footer-floating-buttons .left-action-float{
    padding:5px 8px !important;
    gap:5px !important;
    font-size:11px !important;
  }
}

/* PALMA correction: keep footer buttons in the same centered position, but make them floating/fixed */
.footer-floating-buttons{
  position:fixed !important;
  left:50% !important;
  right:auto !important;
  bottom:42px !important;
  transform:translateX(-50%) !important;
  z-index:99999 !important;
  display:flex !important;
  justify-content:center !important;
  align-items:center !important;
  flex-wrap:wrap !important;
  gap:8px !important;
  width:auto !important;
  max-width:calc(100vw - 28px) !important;
  padding:8px 10px !important;
  margin:0 !important;
  text-align:center !important;
  box-sizing:border-box !important;
  pointer-events:auto !important;
}
.footer-floating-buttons .whatsapp-float,
.footer-floating-buttons .call-float,
.footer-floating-buttons .email-float,
.footer-floating-buttons .left-action-float{
  position:relative !important;
  left:auto !important;
  right:auto !important;
  bottom:auto !important;
  top:auto !important;
  z-index:100000 !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  margin:0 !important;
  transform:none !important;
  animation:none !important;
  white-space:nowrap !important;
}
.footer-floating-buttons .whatsapp-float:hover,
.footer-floating-buttons .call-float:hover,
.footer-floating-buttons .email-float:hover,
.footer-floating-buttons .left-action-float:hover,
.footer-floating-buttons .whatsapp-float:focus,
.footer-floating-buttons .call-float:focus,
.footer-floating-buttons .email-float:focus,
.footer-floating-buttons .left-action-float:focus{
  transform:translateY(-1px) scale(1.02) !important;
}
body{
  padding-bottom:118px !important;
}
@media (max-width:640px){
  .footer-floating-buttons{
    bottom:34px !important;
    gap:6px !important;
    max-width:calc(100vw - 18px) !important;
    padding:6px 8px !important;
  }
  body{
    padding-bottom:150px !important;
  }
}

/* PALMA final correction: floating footer buttons aligned, one single line, lowered 1/4 inch */
.footer-floating-buttons{
  position:fixed !important;
  left:50% !important;
  right:auto !important;
  bottom:18px !important;
  transform:translateX(-50%) !important;
  z-index:99999 !important;
  display:flex !important;
  flex-direction:row !important;
  justify-content:center !important;
  align-items:center !important;
  flex-wrap:nowrap !important;
  gap:6px !important;
  width:auto !important;
  max-width:calc(100vw - 16px) !important;
  padding:6px 8px !important;
  margin:0 !important;
  text-align:center !important;
  box-sizing:border-box !important;
  pointer-events:auto !important;
  overflow:visible !important;
}
.footer-floating-buttons .whatsapp-float,
.footer-floating-buttons .call-float,
.footer-floating-buttons .email-float,
.footer-floating-buttons .left-action-float{
  position:relative !important;
  left:auto !important;
  right:auto !important;
  bottom:auto !important;
  top:auto !important;
  z-index:100000 !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  flex:0 0 auto !important;
  margin:0 !important;
  transform:none !important;
  animation:none !important;
  white-space:nowrap !important;
  padding:5px 8px !important;
  gap:5px !important;
  font-size:11px !important;
  line-height:1 !important;
  min-height:auto !important;
}
.footer-floating-buttons svg{
  width:13px !important;
  height:13px !important;
  flex:0 0 13px !important;
}
.footer-floating-buttons .whatsapp-float-text,
.footer-floating-buttons .call-float-text,
.footer-floating-buttons .email-float-text,
.footer-floating-buttons .left-action-float-text{
  font-size:11px !important;
  line-height:1 !important;
  white-space:nowrap !important;
}
.footer-floating-buttons .whatsapp-float:hover,
.footer-floating-buttons .call-float:hover,
.footer-floating-buttons .email-float:hover,
.footer-floating-buttons .left-action-float:hover,
.footer-floating-buttons .whatsapp-float:focus,
.footer-floating-buttons .call-float:focus,
.footer-floating-buttons .email-float:focus,
.footer-floating-buttons .left-action-float:focus{
  transform:translateY(-1px) scale(1.02) !important;
}
body{
  padding-bottom:96px !important;
}
@media (max-width:900px){
  .footer-floating-buttons{
    bottom:10px !important;
    gap:4px !important;
    max-width:calc(100vw - 10px) !important;
    padding:5px 5px !important;
  }
  .footer-floating-buttons .whatsapp-float,
  .footer-floating-buttons .call-float,
  .footer-floating-buttons .email-float,
  .footer-floating-buttons .left-action-float{
    padding:5px 6px !important;
    gap:4px !important;
    font-size:10px !important;
  }
  .footer-floating-buttons svg{
    width:12px !important;
    height:12px !important;
    flex-basis:12px !important;
  }
  .footer-floating-buttons .whatsapp-float-text,
  .footer-floating-buttons .call-float-text,
  .footer-floating-buttons .email-float-text,
  .footer-floating-buttons .left-action-float-text{
    font-size:10px !important;
  }
  body{
    padding-bottom:120px !important;
  }
}
@media (max-width:520px){
  .footer-floating-buttons{
    transform:translateX(-50%) scale(.84) !important;
    transform-origin:center bottom !important;
    max-width:118vw !important;
  }
}


/* PALMA correction: only Home-style floating buttons, no extra footer/action buttons. */
.footer-floating-buttons{display:none !important;}
.call-float-office,.email-float,.left-action-float{display:none !important;}
.whatsapp-float,.call-float{position:fixed !important;left:auto !important;right:22px !important;z-index:99999 !important;display:inline-flex !important;align-items:center !important;justify-content:center !important;padding:6px 9px !important;gap:6px !important;font-size:12px !important;line-height:1 !important;min-height:auto !important;border-radius:999px !important;background:#25D366 !important;color:#111827 !important;text-decoration:none !important;white-space:nowrap !important;box-shadow:0 14px 32px rgba(37,211,102,.22) !important;}
.whatsapp-float{bottom:18px !important;}
.call-float-ramon{bottom:46px !important;}
.call-float-carmelo{bottom:74px !important;}
.call-float-nelson{bottom:102px !important;}
.whatsapp-float svg,.call-float svg{width:14px !important;height:14px !important;flex:0 0 14px !important;fill:currentColor !important;}
.whatsapp-float-text,.call-float-text{font-size:12px !important;line-height:1 !important;white-space:nowrap !important;}
.whatsapp-float:hover,.call-float:hover,.whatsapp-float:focus,.call-float:focus{background:#1ebe5d !important;color:#111827 !important;transform:translateY(-1px) scale(1.02) !important;}
@media (max-width:640px){.whatsapp-float,.call-float{right:14px !important;padding:5px 8px !important;gap:5px !important;font-size:11px !important;}.whatsapp-float{bottom:12px !important;}.call-float-ramon{bottom:38px !important;}.call-float-carmelo{bottom:64px !important;}.call-float-nelson{bottom:90px !important;}.whatsapp-float svg,.call-float svg{width:13px !important;height:13px !important;flex-basis:13px !important;}.whatsapp-float-text,.call-float-text{font-size:11px !important;}}


/* PALMA final requested: four floating buttons centered directly above copyright. */
.footer-floating-buttons{
  position:fixed !important;
  left:50% !important;
  right:auto !important;
  bottom:48px !important;
  transform:translateX(-50%) !important;
  z-index:999999 !important;
  display:flex !important;
  flex-direction:row !important;
  flex-wrap:nowrap !important;
  justify-content:center !important;
  align-items:center !important;
  gap:8px !important;
  width:auto !important;
  max-width:calc(100vw - 20px) !important;
  margin:0 !important;
  padding:7px 9px !important;
  box-sizing:border-box !important;
  pointer-events:auto !important;
}
.footer-floating-buttons .whatsapp-float,
.footer-floating-buttons .call-float{
  position:relative !important;
  left:auto !important;
  right:auto !important;
  top:auto !important;
  bottom:auto !important;
  z-index:1000000 !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  flex:0 0 auto !important;
  margin:0 !important;
  padding:7px 11px !important;
  gap:6px !important;
  min-height:0 !important;
  line-height:1 !important;
  white-space:nowrap !important;
  text-decoration:none !important;
  transform:none !important;
  animation:none !important;
}
.footer-floating-buttons .whatsapp-float svg,
.footer-floating-buttons .call-float svg{
  width:14px !important;
  height:14px !important;
  flex:0 0 14px !important;
}
.footer-floating-buttons .whatsapp-float-text,
.footer-floating-buttons .call-float-text{
  display:inline !important;
  font-size:12px !important;
  line-height:1 !important;
  white-space:nowrap !important;
}
.footer-floating-buttons .whatsapp-float:hover,
.footer-floating-buttons .call-float:hover,
.footer-floating-buttons .whatsapp-float:focus,
.footer-floating-buttons .call-float:focus{
  transform:translateY(-1px) scale(1.02) !important;
}
.call-float-office,
.email-float,
.left-action-float{
  display:none !important;
}
body{
  padding-bottom:120px !important;
}
@media (max-width:700px){
  .footer-floating-buttons{
    bottom:42px !important;
    gap:5px !important;
    padding:5px !important;
    max-width:calc(100vw - 10px) !important;
  }
  .footer-floating-buttons .whatsapp-float,
  .footer-floating-buttons .call-float{
    padding:6px 7px !important;
    gap:4px !important;
  }
  .footer-floating-buttons .whatsapp-float svg,
  .footer-floating-buttons .call-float svg{
    width:12px !important;
    height:12px !important;
    flex-basis:12px !important;
  }
  .footer-floating-buttons .whatsapp-float-text,
  .footer-floating-buttons .call-float-text{
    font-size:10px !important;
  }
}
@media (max-width:430px){
  .footer-floating-buttons{
    transform:translateX(-50%) scale(.88) !important;
    transform-origin:center bottom !important;
    max-width:114vw !important;
  }
}

/* PALMA requested adjustment: lower the four floating footer buttons approximately one inch while keeping the same centered alignment. */
.footer-floating-buttons{
  bottom:12px !important;
}
@media (max-width:700px){
  .footer-floating-buttons{
    bottom:8px !important;
  }
}

/* PALMA update: Office floating button added and aligned in one single floating line. */
.footer-floating-buttons{
  position:fixed !important;
  left:50% !important;
  right:auto !important;
  bottom:12px !important;
  transform:translateX(-50%) !important;
  z-index:99999 !important;
  display:flex !important;
  flex-direction:row !important;
  justify-content:center !important;
  align-items:center !important;
  flex-wrap:nowrap !important;
  gap:5px !important;
  width:auto !important;
  max-width:calc(100vw - 12px) !important;
  padding:5px 6px !important;
  margin:0 !important;
  overflow:visible !important;
  pointer-events:auto !important;
}
.footer-floating-buttons .whatsapp-float,
.footer-floating-buttons .call-float,
.footer-floating-buttons .call-float-office,
.footer-floating-buttons .email-float,
.footer-floating-buttons .left-action-float{
  position:relative !important;
  left:auto !important;
  right:auto !important;
  bottom:auto !important;
  top:auto !important;
  z-index:100000 !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  flex:0 0 auto !important;
  margin:0 !important;
  transform:none !important;
  animation:none !important;
  padding:5px 7px !important;
  gap:4px !important;
  font-size:11px !important;
  line-height:1 !important;
  min-height:auto !important;
  border-radius:999px !important;
  background:#25D366 !important;
  color:#111827 !important;
  text-decoration:none !important;
  white-space:nowrap !important;
  box-shadow:0 14px 32px rgba(37,211,102,.22) !important;
}
.footer-floating-buttons svg{
  width:13px !important;
  height:13px !important;
  flex:0 0 13px !important;
  fill:currentColor !important;
}
.footer-floating-buttons .whatsapp-float-text,
.footer-floating-buttons .call-float-text,
.footer-floating-buttons .email-float-text,
.footer-floating-buttons .left-action-float-text{
  font-size:11px !important;
  line-height:1 !important;
  white-space:nowrap !important;
}
.footer-floating-buttons .whatsapp-float:hover,
.footer-floating-buttons .call-float:hover,
.footer-floating-buttons .call-float-office:hover,
.footer-floating-buttons .whatsapp-float:focus,
.footer-floating-buttons .call-float:focus,
.footer-floating-buttons .call-float-office:focus{
  background:#1ebe5d !important;
  color:#111827 !important;
  transform:translateY(-1px) scale(1.02) !important;
}
body{padding-bottom:96px !important;}
@media (max-width:640px){
  .footer-floating-buttons{
    bottom:10px !important;
    transform:translateX(-50%) scale(.78) !important;
    transform-origin:center bottom !important;
    max-width:128vw !important;
    gap:4px !important;
    padding:4px !important;
  }
  body{padding-bottom:110px !important;}
}

/* PALMA GALLERY ADD-ON - gallery button/slider only; original template remains unchanged. */
.gallery-hero-button-wrap { margin-top: 18px; }
.gallery-hero-button { display: inline-flex; align-items: center; justify-content: center; letter-spacing: .08em; }
.palma-gallery-section { scroll-margin-top: 120px; }
.palma-gallery-slider { max-width: 1080px; margin: 0 auto; }
.gallery-stage { position: relative; overflow: hidden; border-radius: 22px; background: transparent; box-shadow: none; border: 0; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 22px; align-items: center; }
.gallery-slide { display: none; min-width: 0; animation: palmaGalleryMove .45s ease; }
.gallery-slide.active, .gallery-slide.active-next { display: block; }
.gallery-slide img { width: 100%; height: 385px; object-fit: contain; display: block; background: transparent; }
@keyframes palmaGalleryMove { from { opacity: .35; transform: translateX(28px); } to { opacity: 1; transform: translateX(0); } }
.gallery-arrow { position: absolute; top: 50%; transform: translateY(-50%); width: 46px; height: 46px; border: 0; border-radius: 999px; background: rgba(0,0,0,.42); color: #fff; font-size: 26px; line-height: 1; cursor: pointer; display: grid; place-items: center; transition: background .2s ease, transform .2s ease; z-index: 3; }
.gallery-arrow:hover { background: rgba(0,0,0,.68); transform: translateY(-50%) scale(1.05); }
.gallery-prev { left: 8px; }
.gallery-next { right: 8px; }
.gallery-dots { display: flex; justify-content: center; flex-wrap: wrap; gap: 9px; margin: 18px 0 14px; }
.gallery-dot { width: 10px; height: 10px; border: 0; border-radius: 999px; background: rgba(0,0,0,.28); cursor: pointer; }
.gallery-dot.active { background: #111; width: 28px; }
.gallery-thumbs { display: grid; grid-template-columns: repeat(8, 1fr); gap: 10px; }
.gallery-thumb { border: 2px solid transparent; border-radius: 12px; padding: 0; overflow: hidden; cursor: pointer; background: transparent; opacity: .72; }
.gallery-thumb.active { border-color: #111; opacity: 1; }
.gallery-thumb img { width: 100%; height: 64px; object-fit: cover; display: block; }
@media (max-width: 760px) {
  .palma-gallery-slider { max-width: 94%; }
  .gallery-stage { grid-template-columns: 1fr; gap: 0; }
  .gallery-slide.active-next { display: none; }
  .gallery-slide img { height: 245px; }
  .gallery-thumbs { grid-template-columns: repeat(4, 1fr); }
  .gallery-thumb img { height: 64px; }
}
@media (max-width: 480px) {
  .gallery-slide img { height: 200px; }
  .gallery-arrow { width: 38px; height: 38px; font-size: 21px; }
  .gallery-thumbs { grid-template-columns: repeat(3, 1fr); }
}


/* PALMA portfolio gallery group-info update */
.portfolio-gallery-layout {
  display: grid;
  grid-template-columns: minmax(250px, 0.72fr) minmax(0, 1.75fr);
  gap: 28px;
  align-items: start;
}
.project-info-panel {
  min-height: 385px;
  display: flex;
  align-items: flex-start;
}
.project-info-card {
  display: none;
  width: 100%;
  background: #ffffff;
  border: 1px solid rgba(17, 24, 39, .10);
  border-radius: 22px;
  padding: 26px;
  box-shadow: 0 12px 30px rgba(17, 24, 39, .06);
}
.project-info-card.active {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}
.project-info-card h3 {
  margin: 4px 0 16px;
  font-size: 26px;
  line-height: 1.12;
  color: #111827;
}
.project-info-card p {
  margin: 0 0 12px;
  color: #4b5563;
  line-height: 1.55;
}
.project-info-card .project-note {
  margin-top: 8px;
  padding-top: 14px;
  border-top: 1px solid rgba(17, 24, 39, .10);
  font-size: 14px;
}
.portfolio-gallery-layout .palma-gallery-slider {
  max-width: 100%;
}
.portfolio-gallery-layout .gallery-stage {
  min-height: 385px;
}
@media (max-width: 980px) {
  .portfolio-gallery-layout {
    grid-template-columns: 1fr;
  }
  .project-info-panel {
    min-height: 0;
  }
}
@media (max-width: 760px) {
  .project-info-card {
    padding: 20px;
  }
  .project-info-card h3 {
    font-size: 22px;
  }
}


/* PALMA GALLERY LITERATURE BESIDE PHOTOS - final override */
.portfolio-gallery-layout{display:grid;grid-template-columns:minmax(255px,.70fr) minmax(0,1.85fr);gap:28px;align-items:start;}
.project-info-panel{min-height:385px;display:flex;align-items:flex-start;}
.project-info-card{display:none;width:100%;background:#fff;border:1px solid rgba(17,24,39,.10);border-radius:22px;padding:26px;box-shadow:0 12px 30px rgba(17,24,39,.06);margin-top:0;}
.project-info-card.active{display:flex;flex-direction:column;justify-content:flex-start;}
.portfolio-gallery-layout .palma-gallery-slider{max-width:100%;margin:0;}
.portfolio-gallery-layout .gallery-stage{min-height:385px;}
@media(max-width:980px){.portfolio-gallery-layout{grid-template-columns:1fr}.project-info-panel{min-height:0}}

/* PALMA MOBILE GALLERY AUTOPLAY FIX - keeps template unchanged, only improves mobile movement */
@media (max-width: 760px) {
  .portfolio-gallery-layout .gallery-stage {
    overflow: hidden;
    touch-action: pan-y;
  }
  .gallery-slide.active {
    display: block !important;
    animation: palmaMobileGallerySlide .55s ease both !important;
  }
  .gallery-slide.active-next {
    display: none !important;
  }
}
@keyframes palmaMobileGallerySlide {
  from { opacity: .15; transform: translateX(42px); }
  to { opacity: 1; transform: translateX(0); }
}


/* PALMA BRAVO SUPERMARKET - horizontal contracting photo set */
.bravo-horizontal-showcase{margin:8px 0 30px;padding:24px;background:#ffffff;border:1px solid rgba(17,24,39,.10);border-radius:22px;box-shadow:0 12px 30px rgba(17,24,39,.06);}
.bravo-project-copy{max-width:920px;margin-bottom:18px;}
.bravo-project-copy h3{margin:4px 0 10px;font-size:26px;line-height:1.15;color:#111827;}
.bravo-project-copy p{margin:0 0 10px;color:#4b5563;line-height:1.55;}
.bravo-photo-row{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px;align-items:stretch;}
.bravo-photo-card{overflow:hidden;border-radius:16px;border:1px solid rgba(17,24,39,.10);background:#fff;box-shadow:0 8px 20px rgba(17,24,39,.06);}
.bravo-photo-card img{width:100%;height:170px;object-fit:cover;display:block;aspect-ratio:16/9;}
@media(max-width:1100px){.bravo-photo-row{grid-template-columns:repeat(3,minmax(0,1fr));}.bravo-photo-card img{height:190px;}}
@media(max-width:760px){.bravo-horizontal-showcase{padding:18px;}.bravo-photo-row{grid-template-columns:1fr;}.bravo-photo-card img{height:230px;}}

/* Bravo Supermarket gallery addition - horizontal presentation */
.gallery-slide[data-project="bravo-supermarket"] img{object-fit:contain;background:#fff;aspect-ratio:16/9;}
.gallery-thumb img{object-fit:cover;}

/* Button-only refinement: smaller, cleaner buttons without changing the template */
.top-nav{
  gap:7px 8px !important;
}
.top-nav a{
  padding:4px 8px !important;
  font-size:13px !important;
  line-height:1.15 !important;
  font-weight:600 !important;
  border-radius:999px !important;
}
.btn,
.btn:visited,
.btn:link,
.btn-secondary,
.hero-contact-link{
  padding:7px 13px !important;
  min-width:auto !important;
  font-size:13px !important;
  line-height:1.15 !important;
  font-weight:600 !important;
  border-width:1px !important;
  box-shadow:0 6px 14px rgba(37,211,102,.16) !important;
}
.cta-row,
.hero-contact-row,
.contact-action-grid{
  gap:8px !important;
}
.contact-action-grid .btn,
.cta-row .btn,
.hero-contact-link{
  min-width:132px !important;
}
.btn-block{
  width:auto !important;
  max-width:210px !important;
  margin-left:auto !important;
  margin-right:auto !important;
}
.whatsapp-float,
.call-float,
.email-float,
.left-action-float{
  padding:4px 7px !important;
  gap:4px !important;
  font-size:10px !important;
  line-height:1 !important;
  font-weight:600 !important;
  box-shadow:0 7px 16px rgba(37,211,102,.16) !important;
}
.whatsapp-float svg,
.call-float svg,
.email-float svg,
.left-action-float svg{
  width:11px !important;
  height:11px !important;
  flex:0 0 11px !important;
}
.whatsapp-float-text,
.call-float-text,
.email-float-text,
.left-action-float-text{
  font-size:10px !important;
  line-height:1 !important;
}
.whatsapp-float{
  bottom:12px !important;
  right:14px !important;
}
.call-float-ramon{
  bottom:34px !important;
}
.call-float-carmelo{
  bottom:56px !important;
}
.call-float-nelson{
  bottom:78px !important;
}
@media (max-width:760px){
  .top-nav a{
    padding:4px 7px !important;
    font-size:12px !important;
  }
  .btn,
  .btn:visited,
  .btn:link,
  .btn-secondary,
  .hero-contact-link{
    padding:6px 11px !important;
    font-size:12px !important;
  }
  .contact-action-grid .btn,
  .cta-row .btn,
  .hero-contact-link{
    min-width:118px !important;
  }
}

/* Button-only refinement: smaller, thinner buttons without changing the template/layout structure. */
.top-nav{
  gap:5px !important;
}
.top-nav a{
  padding:5px 8px !important;
  font-size:11.5px !important;
  font-weight:600 !important;
  line-height:1.15 !important;
  border-width:1px !important;
  box-shadow:0 3px 8px rgba(0,0,0,.08) !important;
}

.btn,
.btn:visited,
.btn:link,
.btn-secondary,
.hero-contact-link{
  padding:7px 13px !important;
  font-size:13px !important;
  font-weight:600 !important;
  line-height:1.15 !important;
  border-width:1px !important;
  box-shadow:0 5px 12px rgba(37,211,102,.16) !important;
}
.cta-row,
.hero-contact-row,
.contact-action-grid{
  gap:7px !important;
}
.cta-row .btn,
.contact-action-grid .btn,
.hero-contact-link{
  min-width:130px !important;
}
.btn-block{
  margin-top:8px !important;
  padding-top:8px !important;
  padding-bottom:8px !important;
}

.footer-floating-buttons{
  bottom:8px !important;
  gap:4px !important;
  padding:3px 4px !important;
  transform:translateX(-50%) scale(.90) !important;
  transform-origin:center bottom !important;
}
.footer-floating-buttons .whatsapp-float,
.footer-floating-buttons .call-float,
.footer-floating-buttons .call-float-office,
.footer-floating-buttons .email-float,
.footer-floating-buttons .left-action-float,
.whatsapp-float,
.call-float,
.call-float-office,
.email-float,
.left-action-float{
  padding:4px 6px !important;
  gap:3px !important;
  font-size:10.5px !important;
  line-height:1 !important;
  border-width:1px !important;
  min-height:0 !important;
  box-shadow:0 6px 14px rgba(37,211,102,.16) !important;
}
.footer-floating-buttons svg,
.whatsapp-float svg,
.call-float svg,
.call-float-office svg,
.email-float svg,
.left-action-float svg{
  width:11px !important;
  height:11px !important;
  flex:0 0 11px !important;
}
.footer-floating-buttons .whatsapp-float-text,
.footer-floating-buttons .call-float-text,
.footer-floating-buttons .email-float-text,
.footer-floating-buttons .left-action-float-text,
.whatsapp-float-text,
.call-float-text,
.email-float-text,
.left-action-float-text{
  font-size:10.5px !important;
  line-height:1 !important;
  white-space:nowrap !important;
}
body{
  padding-bottom:72px !important;
}

@media (max-width:900px){
  .top-nav{
    gap:4px !important;
  }
  .top-nav a{
    padding:5px 7px !important;
    font-size:11px !important;
  }
  .btn,
  .btn:visited,
  .btn:link,
  .btn-secondary,
  .hero-contact-link{
    padding:6px 11px !important;
    font-size:12px !important;
  }
  .cta-row .btn,
  .contact-action-grid .btn,
  .hero-contact-link{
    min-width:112px !important;
  }
}

@media (max-width:640px){
  .footer-floating-buttons{
    bottom:6px !important;
    gap:3px !important;
    padding:2px 3px !important;
    transform:translateX(-50%) scale(.72) !important;
    transform-origin:center bottom !important;
    max-width:136vw !important;
  }
  .footer-floating-buttons .whatsapp-float,
  .footer-floating-buttons .call-float,
  .footer-floating-buttons .call-float-office,
  .footer-floating-buttons .email-float,
  .footer-floating-buttons .left-action-float,
  .whatsapp-float,
  .call-float,
  .call-float-office,
  .email-float,
  .left-action-float{
    padding:4px 5px !important;
    gap:3px !important;
    font-size:9.5px !important;
  }
  .footer-floating-buttons svg,
  .whatsapp-float svg,
  .call-float svg,
  .call-float-office svg,
  .email-float svg,
  .left-action-float svg{
    width:10px !important;
    height:10px !important;
    flex-basis:10px !important;
  }
  .footer-floating-buttons .whatsapp-float-text,
  .footer-floating-buttons .call-float-text,
  .footer-floating-buttons .email-float-text,
  .footer-floating-buttons .left-action-float-text,
  .whatsapp-float-text,
  .call-float-text,
  .email-float-text,
  .left-action-float-text{
    font-size:9.5px !important;
  }
  body{
    padding-bottom:58px !important;
  }
}

/* PALMA requested header spacing: move navigation buttons up and start them to the right of the logo. CSS-only; template/HTML remains unchanged. */
@media (min-width:1051px){
  .site-header .nav-wrap{
    display:grid !important;
    grid-template-columns:auto minmax(0,1fr) !important;
    align-items:start !important;
    justify-content:stretch !important;
    column-gap:14px !important;
    row-gap:0 !important;
    min-height:0 !important;
    padding-top:6px !important;
    padding-bottom:6px !important;
    flex-wrap:nowrap !important;
  }
  .site-header .brand{
    align-self:start !important;
    margin:0 !important;
    padding:0 !important;
  }
  .site-header .brand-logo{
    margin:0 !important;
  }
  .site-header .top-nav{
    align-self:start !important;
    align-content:flex-start !important;
    align-items:flex-start !important;
    justify-content:flex-start !important;
    gap:4px 5px !important;
    margin:0 !important;
    padding-top:1px !important;
    max-width:100% !important;
  }
  .site-header .top-nav a{
    padding:4px 7px !important;
    font-size:11px !important;
    line-height:1.05 !important;
    box-shadow:0 3px 9px rgba(0,0,0,.07) !important;
  }
}

/* Added compact Pool Care navigation item beside Contact, keeping the existing template structure unchanged. */
@media (min-width:1051px){
  .site-header .top-nav a{
    padding-left:6px !important;
    padding-right:6px !important;
  }
}


/* Luxury Pools navigation label spacing: keeps the added button compact without changing the template. */
@media (min-width:1051px){
  .site-header .top-nav a{
    font-size:10.8px !important;
  }
}

/* Darker button shadows only - keeps the same template, size, spacing and position. */
.top-nav a,
.site-header .top-nav a{
  box-shadow:0 4px 11px rgba(0,0,0,.20) !important;
}
.top-nav a:hover,
.top-nav a:focus,
.site-header .top-nav a:hover,
.site-header .top-nav a:focus{
  box-shadow:0 5px 13px rgba(0,0,0,.24) !important;
}
.top-nav a.active,
.site-header .top-nav a.active{
  box-shadow:0 5px 14px rgba(0,0,0,.26) !important;
}
.btn,
.btn:visited,
.btn:link,
.btn-secondary,
.hero-contact-link{
  box-shadow:0 6px 15px rgba(0,0,0,.22) !important;
}
.btn:hover,
.btn:focus,
.btn-secondary:hover,
.btn-secondary:focus,
.hero-contact-link:hover,
.hero-contact-link:focus{
  box-shadow:0 8px 18px rgba(0,0,0,.26) !important;
}
.whatsapp-float,
.call-float,
.email-float,
.left-action-float{
  box-shadow:0 8px 18px rgba(0,0,0,.22) !important;
}

/* Added HOA Associatin menu button: compact spacing only, so the header/template stays intact. */
@media (min-width:1051px){
  .site-header .top-nav{
    gap:4px 4px !important;
  }
  .site-header .top-nav a.hoa-nav-link{
    padding-left:5px !important;
    padding-right:5px !important;
    font-size:10.2px !important;
    letter-spacing:-.02em !important;
    white-space:nowrap !important;
  }
}

/* MOBILE NAVIGATION FIX - MAY 2026 */
@media (max-width:1050px){
  .top-nav{
    display:flex !important;
    width:100%;
    justify-content:center;
    align-items:center;
    flex-wrap:wrap;
    gap:10px;
    padding:12px 0;
  }

  .top-nav a{
    font-size:14px;
    padding:10px 14px;
  }

  .nav-wrap{
    flex-direction:column;
    align-items:center;
  }
}

@media (max-width:600px){
  .top-nav{
    gap:8px;
  }

  .top-nav a{
    width:100%;
    text-align:center;
    max-width:320px;
    font-size:13px;
  }

  .hero h1,
  .sub-hero h1{
    font-size:32px !important;
    line-height:1.15;
  }

  .wrap{
    padding:0 14px;
  }
}

.electrical-photo-9 img{height:330px!important;object-fit:contain!important;object-position:center center!important;background:#f6f7f9}.electrical-photo-9 .service-card-body{padding-top:14px}


/* Kelven floating call button - added to final call name list */
.call-float-kelven{bottom:46px !important;}
.call-float-ramon{bottom:74px !important;}
.call-float-carmelo{bottom:102px !important;}
.call-float-nelson{bottom:130px !important;}
@media (max-width:640px){
  .call-float-kelven{bottom:38px !important;}
  .call-float-ramon{bottom:64px !important;}
  .call-float-carmelo{bottom:90px !important;}
  .call-float-nelson{bottom:116px !important;}
}

/* PALMA SAFE RESPONSIVE PUBLISH FIX - desktop template unchanged */
*{box-sizing:border-box;}
img,video,iframe{max-width:100%;}

@media (max-width: 900px){
  html,body{max-width:100%;overflow-x:hidden;}
  .wrap{width:100%;max-width:100%;padding-left:16px;padding-right:16px;}
  .nav-wrap{display:flex;flex-direction:column;align-items:center;gap:12px;}
  .brand{display:flex;justify-content:center;max-width:100%;}
  .brand-logo{max-width:160px;height:auto;}
  .top-nav{width:100%;display:flex;flex-wrap:wrap;justify-content:center;gap:8px;}
  .top-nav a{font-size:13px;padding:9px 12px;line-height:1.15;white-space:normal;text-align:center;}
  .hero-grid,.two-col,.contact-grid,.footer-grid,.footer-grid-large{grid-template-columns:1fr;}
  .hero-media img,.sub-hero .hero-media img{width:100%;height:auto;max-height:420px;object-fit:cover;object-position:center;}
  .service-grid,.gallery-grid,.scope-grid,.stats-grid{grid-template-columns:1fr 1fr;gap:18px;}
}

@media (max-width: 640px){
  .topbar .wrap{display:flex;flex-direction:column;gap:6px;text-align:center;}
  .topbar-left,.topbar-right{justify-content:center;flex-wrap:wrap;}
  .top-nav{flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start;padding-bottom:8px;-webkit-overflow-scrolling:touch;}
  .top-nav a{flex:0 0 auto;font-size:12px;padding:8px 10px;white-space:nowrap;}
  .hero,.sub-hero{padding-top:36px;padding-bottom:36px;}
  .hero h1,.sub-hero h1{font-size:30px;line-height:1.12;}
  .lead{font-size:16px;line-height:1.5;}
  .section{padding-top:42px;padding-bottom:42px;}
  .section-heading h2,.section h2{font-size:26px;line-height:1.16;}
  .service-grid,.gallery-grid,.scope-grid,.stats-grid{grid-template-columns:1fr;}
  .service-card img,.gallery-card img{width:100%;height:auto;max-height:340px;object-fit:cover;object-position:center;}
  .btn,.btn-secondary,.btn-block{width:100%;max-width:340px;margin-left:auto;margin-right:auto;}
  .footer-floating-buttons{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding-left:12px;padding-right:12px;}
  .footer-floating-buttons a,.footer-floating-buttons .whatsapp-float,.footer-floating-buttons .call-float,.footer-floating-buttons .call-float-office,.footer-floating-buttons .email-float,.footer-floating-buttons .left-action-float{width:100%;min-width:0;justify-content:center;font-size:11px;padding:8px 7px;white-space:nowrap;}
}

@media (max-width: 380px){
  .hero h1,.sub-hero h1{font-size:26px;}
  .footer-floating-buttons{grid-template-columns:1fr;}
}

/* Palma High-Grade Professional Virtual Assistant */
.palma-assistant-widget{position:fixed;right:22px;bottom:22px;z-index:10000;font-family:Arial,Helvetica,sans-serif;color:#162033}.palma-assistant-launcher{border:0;background:linear-gradient(135deg,#0f52ba,#0b3f91);color:#fff;border-radius:999px;padding:10px 16px 10px 10px;display:flex;align-items:center;gap:10px;box-shadow:0 18px 45px rgba(8,32,72,.34);cursor:pointer;min-width:230px;transition:transform .2s ease,box-shadow .2s ease}.palma-assistant-launcher:hover{transform:translateY(-2px);box-shadow:0 22px 55px rgba(8,32,72,.42)}.palma-assistant-launcher img{width:58px;height:58px;border-radius:50%;object-fit:cover;border:3px solid #fff;background:#fff}.palma-assistant-launcher span{display:block;text-align:left;line-height:1.1}.palma-assistant-launcher strong{display:block;font-size:15px}.palma-assistant-launcher small{display:block;font-size:12px;opacity:.92;margin-top:3px}.palma-assistant-pulse{position:absolute;right:10px;top:8px;width:13px;height:13px;border-radius:50%;background:#22c55e;border:2px solid #fff;box-shadow:0 0 0 0 rgba(34,197,94,.55);animation:palmaPulse 1.9s infinite}@keyframes palmaPulse{70%{box-shadow:0 0 0 12px rgba(34,197,94,0)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}}.palma-assistant-box{display:none;width:382px;max-width:calc(100vw - 28px);margin-bottom:14px;background:#fff;border:1px solid rgba(15,23,42,.1);border-radius:24px;overflow:hidden;box-shadow:0 30px 80px rgba(15,23,42,.28)}.palma-assistant-box.is-open{display:block;animation:palmaSlideUp .22s ease}@keyframes palmaSlideUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.palma-assistant-hero{background:linear-gradient(135deg,#111827 0%,#0f52ba 64%,#b3263b 100%);color:#fff;padding:18px 18px 16px;position:relative}.palma-assistant-close{position:absolute;right:14px;top:12px;border:0;background:rgba(255,255,255,.14);color:#fff;width:32px;height:32px;border-radius:50%;font-size:22px;line-height:28px;cursor:pointer}.palma-assistant-profile{display:flex;align-items:center;gap:13px;padding-right:34px}.palma-assistant-profile img{width:78px;height:78px;border-radius:18px;object-fit:cover;border:3px solid rgba(255,255,255,.92);background:#fff}.palma-assistant-title strong{display:block;font-size:18px;line-height:1.12}.palma-assistant-title span{display:inline-flex;align-items:center;gap:6px;margin-top:7px;font-size:12px;background:rgba(255,255,255,.14);padding:5px 9px;border-radius:999px}.palma-assistant-title span:before{content:'';width:8px;height:8px;background:#22c55e;border-radius:50%;display:inline-block}.palma-lang{display:flex;gap:8px;margin-top:14px}.palma-lang button{border:1px solid rgba(255,255,255,.35);background:transparent;color:#fff;padding:6px 12px;border-radius:999px;font-weight:700;cursor:pointer}.palma-lang button.active{background:#fff;color:#0f52ba}.palma-assistant-body{padding:18px}.palma-assistant-widget[data-lang="en"] .es,.palma-assistant-widget[data-lang="es"] .en{display:none}.palma-greeting{font-size:15px;line-height:1.45;margin:0 0 14px;color:#273244}.palma-service-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin:12px 0 15px}.palma-service-grid button{border:1px solid #d7deea;background:#f7f9fc;border-radius:13px;padding:10px 8px;font-weight:800;color:#1f2937;cursor:pointer;text-align:center;font-size:13px}.palma-service-grid button:hover{border-color:#0f52ba;color:#0f52ba;background:#eef5ff}.palma-action-row{display:grid;grid-template-columns:1fr;gap:9px}.palma-action{display:flex;align-items:center;justify-content:center;border-radius:14px;padding:12px 14px;font-weight:900;text-decoration:none}.palma-whatsapp{background:#25D366;color:#082c14}.palma-call{background:#b3263b;color:#fff}.palma-email{background:#111827;color:#fff}.palma-note{margin:13px 0 0;color:#5d6778;font-size:12px;line-height:1.35;text-align:center}.palma-assistant-full{display:none;width:112px;position:absolute;right:16px;bottom:74px;filter:drop-shadow(0 16px 24px rgba(0,0,0,.22));pointer-events:none}@media (min-width:900px){.palma-assistant-widget{right:26px;bottom:24px}.palma-assistant-full{display:block}.palma-assistant-box.is-open + .palma-assistant-launcher .palma-assistant-full{display:none}}@media (max-width:520px){.palma-assistant-widget{right:12px;bottom:12px}.palma-assistant-launcher{min-width:0;padding:9px 12px 9px 9px}.palma-assistant-launcher img{width:50px;height:50px}.palma-assistant-launcher strong{font-size:14px}.palma-assistant-box{width:calc(100vw - 24px);border-radius:20px}.palma-service-grid{grid-template-columns:1fr 1fr}.palma-assistant-profile img{width:68px;height:68px}}

/* Palma High-Grade compact professional assistant */
#palma-assistant-widget{position:fixed;right:16px;bottom:16px;z-index:99999;font-family:Arial,Helvetica,sans-serif;color:#17202a}
#palma-assistant-bubble{width:58px;height:58px;border-radius:999px;border:3px solid #16a34a;background:#fff;padding:0;cursor:pointer;box-shadow:0 10px 24px rgba(0,0,0,.22);overflow:hidden;display:flex;align-items:center;justify-content:center}
#palma-assistant-bubble img{width:100%;height:100%;object-fit:cover;border-radius:999px}
#palma-assistant-panel{display:none;width:292px;max-width:calc(100vw - 24px);height:365px;max-height:calc(100vh - 96px);background:#fff;border:1px solid #dfe4ea;border-radius:16px;box-shadow:0 16px 40px rgba(0,0,0,.28);overflow:hidden;margin-bottom:10px}
#palma-assistant-panel.palma-open{display:flex;flex-direction:column}
.palma-assistant-head{display:flex;align-items:center;gap:9px;background:linear-gradient(135deg,#0f172a,#15803d);color:#fff;padding:9px 10px;min-height:58px}
.palma-assistant-head img{width:38px;height:38px;border-radius:999px;object-fit:cover;border:2px solid rgba(255,255,255,.85);flex:0 0 auto}
.palma-assistant-head strong{display:block;font-size:13px;line-height:1.1}
.palma-assistant-head span{display:block;font-size:11px;opacity:.9;line-height:1.1;margin-top:2px}
.palma-close{margin-left:auto;background:rgba(255,255,255,.14);border:0;color:#fff;width:25px;height:25px;border-radius:999px;font-size:18px;line-height:1;cursor:pointer}
#palma-assistant-log{flex:1;overflow:auto;background:#f8fafc;padding:10px;display:flex;flex-direction:column;gap:8px}
.palma-message{font-size:12px;line-height:1.35;padding:8px 9px;border-radius:12px;max-width:94%;white-space:pre-wrap;word-wrap:break-word}
.palma-bot{align-self:flex-start;background:#fff;border:1px solid #e5e7eb;color:#1f2937}
.palma-user{align-self:flex-end;background:#dcfce7;border:1px solid #86efac;color:#14532d}
.palma-input-row{display:flex;gap:6px;padding:8px;background:#fff;border-top:1px solid #e5e7eb}
.palma-input-row input{flex:1;min-width:0;border:1px solid #d1d5db;border-radius:999px;padding:8px 10px;font-size:12px;outline:none}
.palma-input-row input:focus{border-color:#16a34a;box-shadow:0 0 0 2px rgba(22,163,74,.12)}
.palma-input-row button{width:34px;height:34px;border:0;border-radius:999px;background:#16a34a;color:#fff;font-size:14px;cursor:pointer;font-weight:700;display:flex;align-items:center;justify-content:center}
.palma-input-row button:hover{background:#15803d}
@media (max-width:480px){#palma-assistant-widget{right:10px;bottom:10px}#palma-assistant-bubble{width:52px;height:52px}#palma-assistant-panel{width:270px;height:335px}.palma-message{font-size:11.5px}.palma-assistant-head{padding:8px}.palma-assistant-head img{width:34px;height:34px}}

/* Final fix: compact working Palma assistant */
#palma-assistant-widget{position:fixed!important;right:16px!important;bottom:16px!important;z-index:99999!important;font-family:Arial,Helvetica,sans-serif!important;color:#17202a!important}
#palma-assistant-bubble{width:58px!important;height:58px!important;border-radius:999px!important;border:3px solid #16a34a!important;background:#fff!important;padding:0!important;cursor:pointer!important;box-shadow:0 10px 24px rgba(0,0,0,.22)!important;overflow:hidden!important;display:flex!important;align-items:center!important;justify-content:center!important}
#palma-assistant-bubble img{width:100%!important;height:100%!important;object-fit:cover!important;border-radius:999px!important}
#palma-assistant-panel{display:none!important;width:292px!important;max-width:calc(100vw - 24px)!important;height:365px!important;max-height:calc(100vh - 96px)!important;background:#fff!important;border:1px solid #dfe4ea!important;border-radius:16px!important;box-shadow:0 16px 40px rgba(0,0,0,.28)!important;overflow:hidden!important;margin-bottom:10px!important}
#palma-assistant-panel.palma-open{display:flex!important;flex-direction:column!important}
.palma-assistant-head{display:flex!important;align-items:center!important;gap:9px!important;background:linear-gradient(135deg,#0f172a,#15803d)!important;color:#fff!important;padding:9px 10px!important;min-height:58px!important}
.palma-assistant-head img{width:38px!important;height:38px!important;border-radius:999px!important;object-fit:cover!important;border:2px solid rgba(255,255,255,.85)!important;flex:0 0 auto!important}
.palma-assistant-head strong{display:block!important;font-size:13px!important;line-height:1.1!important;text-align:left!important;color:#fff!important}
.palma-assistant-head span{display:block!important;font-size:10.5px!important;opacity:.9!important;line-height:1.1!important;margin-top:2px!important;text-align:left!important;color:#fff!important}
.palma-close{margin-left:auto!important;border:0!important;background:rgba(255,255,255,.15)!important;color:#fff!important;width:26px!important;height:26px!important;border-radius:999px!important;font-size:18px!important;line-height:1!important;cursor:pointer!important;flex:0 0 auto!important}
#palma-assistant-log{flex:1!important;overflow:auto!important;background:#f8fafc!important;padding:10px!important;display:flex!important;flex-direction:column!important;gap:8px!important}
.palma-message{max-width:92%!important;padding:8px 10px!important;border-radius:12px!important;font-size:12px!important;line-height:1.35!important;text-align:left!important}
.palma-bot{align-self:flex-start!important;background:#fff!important;border:1px solid #e5e7eb!important;color:#1f2937!important}
.palma-user{align-self:flex-end!important;background:#15803d!important;color:#fff!important}
.palma-input-row{display:flex!important;gap:6px!important;padding:8px!important;background:#fff!important;border-top:1px solid #e5e7eb!important;margin:0!important}
.palma-input-row input{flex:1!important;border:1px solid #d1d5db!important;border-radius:999px!important;padding:8px 10px!important;font-size:12px!important;outline:none!important;min-width:0!important}
.palma-input-row input:focus{border-color:#15803d!important;box-shadow:0 0 0 2px rgba(21,128,61,.12)!important}
.palma-input-row button{width:34px!important;height:34px!important;border-radius:999px!important;border:0!important;background:#15803d!important;color:#fff!important;font-size:14px!important;cursor:pointer!important;flex:0 0 auto!important;display:flex!important;align-items:center!important;justify-content:center!important;padding:0!important}
@media (max-width:480px){#palma-assistant-widget{right:10px!important;bottom:10px!important}#palma-assistant-bubble{width:52px!important;height:52px!important}#palma-assistant-panel{width:270px!important;height:335px!important}.palma-message{font-size:11.5px!important}.palma-assistant-head{padding:8px!important}.palma-assistant-head img{width:34px!important;height:34px!important}}


/* === Palma Assistant final compact override === */
#palma-assistant-widget{
  position:fixed !important;
  right:16px !important;
  bottom:16px !important;
  z-index:99999 !important;
  font-family:Arial,Helvetica,sans-serif !important;
  color:#17202a !important;
}
#palma-assistant-bubble{
  width:62px !important;
  height:62px !important;
  border-radius:16px !important;
  border:2px solid #ffffff !important;
  background:linear-gradient(135deg,#0f172a,#0f52ba) !important;
  padding:3px !important;
  cursor:pointer !important;
  box-shadow:0 14px 34px rgba(15,23,42,.32) !important;
  overflow:hidden !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
}
#palma-assistant-bubble img{
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  border-radius:12px !important;
  display:block !important;
}
#palma-assistant-panel{
  display:none !important;
  width:248px !important;
  max-width:calc(100vw - 28px) !important;
  height:282px !important;
  max-height:calc(100vh - 104px) !important;
  background:#fff !important;
  border:1px solid #d8dee8 !important;
  border-radius:16px !important;
  box-shadow:0 18px 44px rgba(0,0,0,.22) !important;
  overflow:hidden !important;
  margin-bottom:8px !important;
}
#palma-assistant-panel.palma-open{
  display:flex !important;
  flex-direction:column !important;
}
.palma-assistant-head{
  display:flex !important;
  align-items:center !important;
  gap:8px !important;
  background:linear-gradient(135deg,#111827,#15803d) !important;
  color:#fff !important;
  padding:8px 10px !important;
  min-height:54px !important;
}
.palma-assistant-head img{
  width:34px !important;
  height:34px !important;
  border-radius:10px !important;
  object-fit:cover !important;
  border:1px solid rgba(255,255,255,.88) !important;
  flex:0 0 auto !important;
}
.palma-assistant-title-wrap{min-width:0 !important;flex:1 1 auto !important;}
.palma-assistant-head strong{
  display:block !important;
  font-size:12.5px !important;
  line-height:1.08 !important;
  text-align:left !important;
  color:#fff !important;
}
.palma-assistant-head span{
  display:block !important;
  font-size:10px !important;
  opacity:.92 !important;
  line-height:1.1 !important;
  margin-top:2px !important;
  text-align:left !important;
  color:#fff !important;
}
.palma-close{
  border:0 !important;
  background:rgba(255,255,255,.15) !important;
  color:#fff !important;
  width:24px !important;
  height:24px !important;
  border-radius:999px !important;
  cursor:pointer !important;
  font-size:18px !important;
  line-height:1 !important;
  flex:0 0 auto !important;
}
#palma-assistant-log{
  flex:1 !important;
  overflow:auto !important;
  background:#f8fafc !important;
  padding:8px !important;
  display:flex !important;
  flex-direction:column !important;
  gap:7px !important;
}
.palma-message{
  font-size:11.5px !important;
  line-height:1.38 !important;
  padding:8px 9px !important;
  border-radius:12px !important;
  max-width:92% !important;
  text-align:left !important;
}
.palma-bot{
  background:#ffffff !important;
  color:#1f2937 !important;
  border:1px solid #e4e9f1 !important;
  align-self:flex-start !important;
}
.palma-user{
  background:#dcfce7 !important;
  color:#14532d !important;
  border:1px solid #bbf7d0 !important;
  align-self:flex-end !important;
}
.palma-input-row{
  display:grid !important;
  grid-template-columns:1fr 34px !important;
  gap:6px !important;
  padding:8px !important;
  border-top:1px solid #e6ebf2 !important;
  background:#fff !important;
}
#palma-assistant-input{
  width:100% !important;
  border:1px solid #d4dbe5 !important;
  border-radius:10px !important;
  padding:9px 10px !important;
  font-size:11.5px !important;
  outline:none !important;
}
#palma-assistant-send{
  border:0 !important;
  border-radius:10px !important;
  background:#15803d !important;
  color:#fff !important;
  font-size:16px !important;
  cursor:pointer !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
}
#palma-assistant-send:hover{background:#166534 !important;}
@media (max-width:480px){
  #palma-assistant-widget{right:10px !important;bottom:10px !important;}
  #palma-assistant-bubble{width:58px !important;height:58px !important;border-radius:14px !important;}
  #palma-assistant-bubble img{border-radius:10px !important;}
  #palma-assistant-panel{width:236px !important;height:270px !important;max-height:calc(100vh - 92px) !important;}
  .palma-assistant-head{padding:8px !important;}
  .palma-message{font-size:11px !important;}
  #palma-assistant-input{font-size:11px !important;padding:8px 9px !important;}
}


/* ===== Palma High-Grade Assistant: elegant framed floating widget ===== */
#phg-assistant,
#phg-assistant *{
  box-sizing:border-box;
}
#phg-assistant{
  position:fixed;
  right:16px;
  bottom:16px;
  z-index:100000;
  font-family:Arial, Helvetica, sans-serif;
  pointer-events:none;
  min-width:170px;
  min-height:178px;
}
#phg-assistant .phg-assistant-panel,
#phg-assistant .phg-assistant-bubble{
  pointer-events:auto;
}
#phg-assistant .phg-bubble-frame{
  position:absolute;
  right:0;
  bottom:0;
  width:164px;
  padding:8px 8px 10px;
  border-radius:24px;
  background:linear-gradient(180deg,rgba(255,255,255,.99),rgba(248,250,252,.98));
  border:1px solid #d9e1ea;
  box-shadow:0 18px 42px rgba(15,23,42,.18);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  pointer-events:none;
}
#phg-assistant .phg-assistant-bubble{
  position:relative;
  width:98px;
  height:98px;
  border:none;
  padding:4px;
  border-radius:24px;
  background:linear-gradient(135deg,#0f172a,#0f52ba);
  box-shadow:0 16px 36px rgba(15,23,42,.24);
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:width .22s ease, height .22s ease, border-radius .22s ease, transform .22s ease, box-shadow .22s ease;
  z-index:3;
}
#phg-assistant .phg-assistant-bubble img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position:center center;
  border-radius:20px;
  border:2px solid rgba(255,255,255,.95);
  background:#fff;
}
#phg-assistant .phg-bubble-caption{
  width:100%;
  padding:0 4px 1px;
  text-align:center;
  pointer-events:none;
}
#phg-assistant .phg-bubble-caption strong{
  display:block;
  font-size:11.5px;
  line-height:1.15;
  color:#0f172a;
}
#phg-assistant .phg-bubble-caption span{
  display:block;
  margin-top:2px;
  font-size:9.5px;
  line-height:1.2;
  color:#475569;
}
#phg-assistant .phg-online-dot{
  position:absolute;
  right:6px;
  bottom:6px;
  width:14px;
  height:14px;
  border-radius:50%;
  background:#22c55e;
  border:2px solid #fff;
  box-shadow:0 0 0 0 rgba(34,197,94,.5);
  animation:phgPulse 1.9s infinite;
}
@keyframes phgPulse{
  70%{box-shadow:0 0 0 10px rgba(34,197,94,0)}
  100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}
}
#phg-assistant .phg-assistant-panel{
  position:absolute;
  right:0;
  bottom:164px;
  width:300px;
  max-width:calc(100vw - 24px);
  height:360px;
  max-height:calc(100vh - 120px);
  background:#fff;
  border:1px solid #d9e1ea;
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 20px 48px rgba(15,23,42,.24);
  display:flex;
  flex-direction:column;
  opacity:0;
  visibility:hidden;
  transform:translateY(10px) scale(.98);
  transition:opacity .18s ease, transform .18s ease, visibility .18s ease;
}
#phg-assistant .phg-assistant-panel.is-open{
  opacity:1;
  visibility:visible;
  transform:translateY(0) scale(1);
}
#phg-assistant .phg-assistant-header{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  min-height:0;
  padding:8px 8px 0;
  background:transparent;
  color:#17202a;
}
#phg-assistant .phg-assistant-header img,
#phg-assistant .phg-assistant-header-text{
  display:none;
}
#phg-assistant .phg-assistant-close{
  width:28px;
  height:28px;
  flex:0 0 auto;
  border:none;
  border-radius:999px;
  background:#eef2f7;
  color:#475569;
  font-size:20px;
  line-height:1;
  cursor:pointer;
}
#phg-assistant .phg-assistant-log{
  flex:1 1 auto;
  overflow:auto;
  background:#f8fafc;
  padding:10px;
  display:flex;
  flex-direction:column;
  gap:8px;
}
#phg-assistant .phg-msg{
  max-width:92%;
  padding:9px 10px;
  border-radius:13px;
  font-size:12px;
  line-height:1.4;
  text-align:left;
  word-break:break-word;
}
#phg-assistant .phg-bot{
  align-self:flex-start;
  background:#fff;
  color:#1f2937;
  border:1px solid #e4e9f1;
}
#phg-assistant .phg-user{
  align-self:flex-end;
  background:#dcfce7;
  color:#14532d;
  border:1px solid #bbf7d0;
}
#phg-assistant .phg-typing{
  display:inline-flex;
  align-items:center;
  gap:4px;
  min-width:46px;
}
#phg-assistant .phg-typing span{
  width:6px;
  height:6px;
  border-radius:50%;
  background:#94a3b8;
  display:block;
  animation:phgTyping 1.2s infinite ease-in-out;
}
#phg-assistant .phg-typing span:nth-child(2){
  animation-delay:.16s;
}
#phg-assistant .phg-typing span:nth-child(3){
  animation-delay:.32s;
}
@keyframes phgTyping{
  0%,80%,100%{opacity:.35; transform:translateY(0)}
  40%{opacity:1; transform:translateY(-3px)}
}
#phg-assistant .phg-assistant-form{
  display:grid;
  grid-template-columns:1fr 38px;
  gap:6px;
  padding:9px;
  border-top:1px solid #e6ebf2;
  background:#fff;
}
#phg-assistant .phg-assistant-form input{
  width:100%;
  min-width:0;
  border:1px solid #d4dbe5;
  border-radius:10px;
  padding:10px 11px;
  font-size:12px;
  color:#17202a;
  outline:none;
}
#phg-assistant .phg-assistant-form input:focus{
  border-color:#0f52ba;
  box-shadow:0 0 0 3px rgba(15,82,186,.12);
}
#phg-assistant .phg-assistant-form button{
  border:none;
  border-radius:10px;
  background:#15803d;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:17px;
  cursor:pointer;
}
#phg-assistant .phg-assistant-form button:hover{
  background:#166534;
}
#phg-assistant.is-open .phg-bubble-frame{
  box-shadow:0 22px 48px rgba(15,23,42,.22);
  transform:translateY(-3px);
}
#phg-assistant.is-open .phg-assistant-bubble{
  width:108px;
  height:108px;
  border-radius:26px;
  box-shadow:0 22px 44px rgba(15,23,42,.28);
}
#phg-assistant.is-open .phg-assistant-bubble img{
  border-radius:22px;
}
@media (max-width:640px){
  #phg-assistant{
    right:12px;
    bottom:12px;
    min-width:152px;
    min-height:166px;
  }
  #phg-assistant .phg-bubble-frame{
    width:148px;
    padding:7px 7px 9px;
    border-radius:22px;
  }
  #phg-assistant .phg-assistant-bubble{
    width:88px;
    height:88px;
    border-radius:22px;
  }
  #phg-assistant .phg-assistant-bubble img{
    border-radius:18px;
  }
  #phg-assistant .phg-bubble-caption strong{
    font-size:10.5px;
  }
  #phg-assistant .phg-bubble-caption span{
    font-size:9px;
  }
  #phg-assistant .phg-assistant-panel{
    width:272px;
    height:334px;
    bottom:152px;
  }
  #phg-assistant.is-open .phg-bubble-frame{
    transform:translateY(-2px);
  }
  #phg-assistant.is-open .phg-assistant-bubble{
    width:94px;
    height:94px;
    border-radius:23px;
  }
  #phg-assistant.is-open .phg-assistant-bubble img{
    border-radius:19px;
  }
}

/* Palma Assistant clickable phone links */
#phg-assistant .phg-phone-link,
a.phg-phone-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:4px;
  margin:2px 2px;
  padding:3px 7px;
  border-radius:999px;
  background:#eef5ff;
  border:1px solid #cfe0f8;
  color:#0f52ba;
  font-weight:800;
  text-decoration:none;
  cursor:pointer;
  white-space:nowrap;
}
#phg-assistant .phg-phone-link::before,
a.phg-phone-link::before{
  content:"☎";
  font-size:11px;
  line-height:1;
}
#phg-assistant .phg-phone-link:hover,
a.phg-phone-link:hover{
  color:#fff;
  background:#15803d;
  border-color:#15803d;
}
