:root{
  --primary:#0F3D57;
  --secondary:#1FA2A6;
  --accent:#F4A261;
  --bg:#F8F9FA;
  --text:#212529;
}
.body-placeholder{}
body{
  color:#fff;
  background: linear-gradient(90deg, rgba(15,61,87,1) 0%, rgba(31,162,166,1) 100%);
  font-family:'Lato',system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
}
.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff !important}
.logo-placeholder{background:linear-gradient(135deg,var(--secondary),var(--primary));background-repeat:no-repeat;background-position:center;background-size:contain}
.card h5{color:var(--primary)}

/* Hero */
.hero-section{position:relative;overflow:hidden;padding:4rem 0}
.hero-bg{position:absolute;inset:0;background-position:center;background-size:cover;filter:contrast(1.05) saturate(.95);opacity:0.95}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,61,87,0.6),rgba(31,162,166,0.45));mix-blend-mode:multiply}
.hero-section .container{position:relative;z-index:2}
.hero-section .display-4{color:#fff}

/* Quick stats card */
.quick-stats{border-radius:12px}
.quick-stats .stat{min-width:60px}

/* Service cards */
.service-card{display:flex;flex-direction:column;border:0}
.service-card .service-img{height:160px;background-size:contain;background-position:center;background-repeat:no-repeat;background-color:var(--bg)}
.service-card h5{color:var(--primary)}

/* Service card visual improvements */
.service-card{transition:transform .18s ease,box-shadow .18s ease}
.service-card:hover{transform:translateY(-6px);box-shadow:0 22px 48px rgba(15,61,87,0.12)}

/* Make service cards visually separate from their surrounding container while keeping
   the same white card color. Adds a subtle border and lift to create contrast. */
.service-card > .p-4.bg-white{
  background:#fff;
  border-radius:12px;
  border:1px solid rgba(15,61,87,0.10);
  box-shadow:0 18px 48px rgba(15,61,87,0.12);
  transition:box-shadow .18s ease,transform .18s ease;
  position:relative;
}
.service-card > .p-4.bg-white::before{
  content:'';
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:6px;
  border-radius:12px 12px 0 0;
  background:linear-gradient(90deg,var(--secondary),var(--primary));
  opacity:0.12;
  pointer-events:none;
}
.service-card > .p-4.bg-white:focus-within,
.service-card > .p-4.bg-white:hover{
  box-shadow:0 28px 64px rgba(15,61,87,0.16);
  transform:translateY(-6px);
}

@media(max-width:576px){
  .service-card > .p-4.bg-white::before{height:4px}
}
.service-icon{width:64px;height:64px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(31,162,166,0.12),rgba(15,61,87,0.06));box-shadow:0 6px 18px rgba(15,61,87,0.06);}
.service-icon img{width:42px;height:42px;display:block}
.service-card .small-list{margin-top:.5rem;margin-bottom:1rem;padding-left:1.1rem}
.service-card .small-list li{margin-bottom:.35rem}

@media(max-width:768px){
  .service-icon{width:56px;height:56px}
  .service-icon img{width:36px;height:36px}
}

/* Service icon animations (subtle) */
.service-icon img{will-change:transform,opacity}
.service-icon img.icon-elec{animation:elecPulse 1.8s infinite ease-in-out}
.service-icon img.icon-fire{animation:fireFlicker 1.6s infinite ease-in-out}
.service-icon img.icon-water{animation:waterDrop 2.2s infinite cubic-bezier(.2,.9,.2,1)}
.service-icon img{opacity:0.98}

/* Generic reveal animation for hero elements */
@keyframes fadeUp{
  0%{opacity:0;transform:translateY(10px) scale(0.995)}
  60%{opacity:1;transform:translateY(-4px) scale(1.002)}
  100%{opacity:1;transform:translateY(0) scale(1)}
}
.reveal{
  opacity:0;
  animation-name:fadeUp;
  animation-duration:640ms;
  animation-fill-mode:both;
  animation-timing-function:cubic-bezier(.2,.9,.2,1);
  animation-delay:var(--delay,0s);
}
.reveal:hover{transform:none}

/* Continuous subtle floating animation for logos/cards
   - Use by adding `loop` alongside `reveal` to get entrance + continuous motion
   - Or use `loop-only` if you want continuous motion without entrance fade
*/
@keyframes floatY{
  0%{transform:translateY(0) scale(1)}
  50%{transform:translateY(-6px) scale(1.002)}
  100%{transform:translateY(0) scale(1)}
}
.loop-only{
  animation-name:floatY;
  animation-duration:var(--loop-duration,6s);
  animation-timing-function:ease-in-out;
  animation-iteration-count:infinite;
  animation-delay:var(--delay,0s);
  will-change:transform;
}

/* Combine entrance fade with continuous float when both classes present */
.reveal.loop{
  animation: fadeUp 640ms cubic-bezier(.2,.9,.2,1) both var(--delay,0s),
             floatY var(--loop-duration,6s) ease-in-out var(--delay,0s) infinite;
  will-change:transform,opacity;
}

/* Prominent CTA for savings */
.btn-savings{
  background: linear-gradient(90deg, #F4A261 0%, #FFB36B 100%);
  color: #0F3D57;
  border: none;
  padding: .5rem .9rem;
  border-radius: 10px;
  font-weight: 800;
  box-shadow: 0 10px 28px rgba(244,162,97,0.12);
}
.btn-savings:hover{transform:translateY(-2px);filter:brightness(0.98)}

/* Quote CTA card styling */
.quote-card{background:linear-gradient(180deg,#ffffff,#fbfbfd);border-radius:12px;border:1px solid rgba(15,61,87,0.04)}
.quote-card h4{color:var(--primary)}
.quote-cta{padding-left:1.2rem;padding-right:1.2rem}
@media(max-width:576px){.quote-cta{display:block;width:100%}}

/* Make quote card more visible: accent bar, stronger shadow and larger CTA */
.quote-card{position:relative;padding:1.75rem;border-radius:12px;box-shadow:0 20px 54px rgba(15,61,87,0.12)}
.quote-card::before{content:'';position:absolute;left:0;top:0;border-radius:12px 0 0 12px;height:100%;width:8px;background:linear-gradient(180deg,var(--secondary),var(--primary));}
.quote-hero-icon{width:54px;height:54px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--secondary),var(--primary));color:#fff;font-size:1.25rem;flex-shrink:0}
.quote-card p, .quote-card ul{color:rgba(15,61,87,0.85)}
.quote-cta{background:linear-gradient(90deg,#F4A261 0%, #FFB36B 100%);color:#0F3D57;border:none;padding:.7rem 1.1rem;font-weight:800;border-radius:10px;box-shadow:0 12px 36px rgba(244,162,97,0.14)}
.quote-cta:hover{transform:translateY(-3px);box-shadow:0 20px 48px rgba(244,162,97,0.18)}

@media(min-width:768px){
  .quote-cta{font-size:1.02rem}
}

/* Footer */
.site-footer{background:linear-gradient(180deg,var(--primary),#0b3a46);color:#fff;padding:3.25rem 0;text-shadow:0 1px 2px rgba(0,0,0,0.24)}
.site-footer .footer-top{display:flex;gap:2.25rem;flex-wrap:wrap;padding:1.5rem 0 1.75rem;border-bottom:1px solid rgba(255,255,255,0.12)}
.site-footer .footer-col{flex:1;min-width:220px;padding:0 8px}
.site-footer .footer-col > *{margin-bottom:0.85rem}
.site-footer .footer-logo{display:flex;align-items:flex-start;gap:.9rem}
.site-footer .logo-placeholder{width:44px;height:44px;border-radius:8px}
.site-footer h6{color:#fff;font-weight:800;margin-bottom:.6rem;font-size:1.02rem}
.site-footer p,.site-footer .small{color:#ffffff;font-weight:600;opacity:0.95}
.site-footer .footer-links a{display:block;color:#ffffff;padding:.28rem 0;text-decoration:none;font-weight:700}
.site-footer .footer-links a:hover{color:#fff;text-decoration:none;opacity:1}

/* Force any muted/footer text to pure white for maximum visibility */
.site-footer *{color:#ffffff !important}
.site-footer a{color:#ffffff !important}
.site-footer .footer-links a{background:transparent;padding:.18rem 0;border-radius:4px}
.site-footer .footer-links a:hover{background:rgba(255,255,255,0.06);color:#fff !important}
.site-footer .social-icons a{background:rgba(255,255,255,0.10)}
.site-footer .social-icons a:hover{background:rgba(255,255,255,0.18)}
.site-footer .social-icons a{display:inline-flex;width:44px;height:44px;align-items:center;justify-content:center;border-radius:10px;background:rgba(255,255,255,0.12);color:#fff;margin-right:.6rem;text-decoration:none;font-size:1.05rem}
.site-footer .social-icons a:hover{background:rgba(255,255,255,0.24);transform:translateY(-2px)}
.site-footer .footer-legal{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;font-size:.95rem;color:#ffffff}
@media(max-width:768px){.site-footer{padding:2rem 0}.site-footer .footer-legal{flex-direction:column;gap:.5rem;text-align:center}}

/* Responsive footer: stack columns and allow tagline wrapping on small screens */
@media (max-width:768px) {
  .site-footer{padding:2rem 0}
  .site-footer .footer-top{flex-direction:column;gap:1rem;padding-bottom:0;border-bottom:0}
  .site-footer .footer-col{min-width:0;padding:10px 0}
  .site-footer .footer-logo{align-items:flex-start}
  .site-footer .footer-logo .small{white-space:normal}
  /* Make each footer column visually distinct on mobile */
  .site-footer .footer-col{background:transparent;padding:12px 0}
  .site-footer .footer-col + .footer-col{border-top:1px solid rgba(255,255,255,0.06);padding-top:16px}
  /* Stack quick links vertically on mobile for clarity */
  .site-footer .footer-links{display:block}
  .site-footer .footer-links a{display:block;margin-right:0;padding:.22rem 0}
  /* Make icons slightly larger and more tappable */
  .site-footer .social-icons a{width:48px;height:48px;border-radius:10px;margin-right:.5rem;font-size:1.1rem}
}

/* Extra small screens: tighten spacing and ensure no overlap */
@media (max-width:420px){
  .site-footer .footer-col > *{margin-bottom:.6rem}
  .site-footer h6{font-size:0.98rem}
  .site-footer .footer-links a{padding:.18rem 0}
}

/* Trust badges */
.trust-badges img{opacity:.9;filter:grayscale(0.05);}

/* Testimonials */
.testimonials blockquote{background:linear-gradient(180deg,#fff,#fbfbfb);border-left:4px solid var(--accent)}

/* Small layout improvements */
.navbar-brand .logo-placeholder{background:linear-gradient(135deg,var(--secondary),var(--primary));}

/* Use project root logo.png where logo-placeholder exists. Falls back to gradient if missing. */
.logo-placeholder{background-image: url('../logo.png')}

/* Image-based site logo (larger for better visibility) */
.site-logo{display:inline-block;width:96px;height:96px;border-radius:12px;object-fit:contain;box-shadow:0 18px 48px rgba(15,61,87,0.22);border:2px solid rgba(255,255,255,0.08);background:rgba(255,255,255,0.02);padding:6px}
.navbar-brand .site-logo{box-shadow:0 18px 48px rgba(15,61,87,0.22)}

/* Remove boxed/container styling for the navbar logo so it sits flush in the nav */
.navbar .site-logo{box-shadow:none !important;border:0 !important;padding:0 !important;background:transparent !important;border-radius:6px;height:72px;width:auto;max-width:96px;object-fit:contain}


/* Hide old pseudo-element loader logo and use a real <img> instead */
.site-loader .loader-brand::before{display:none !important}
.loader-logo{display:block;width:140px;height:140px;border-radius:12px;object-fit:contain;box-shadow:0 22px 64px rgba(15,61,87,0.32);border:4px solid rgba(255,255,255,0.06);}

.card.shadow-sm{border:0}

/* Provider logos grid: 3-up responsive card layout, PNGs assume transparent background */
.providers-section{padding:2.25rem 0;background:transparent}
.providers-section .providers-title{margin-bottom:1rem;color:#fff;font-weight:800}
.providers-section .providers-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;align-items:center;justify-items:center;max-width:1200px;margin:0 auto}
.providers-section .provider-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0.5rem;background:transparent;border-radius:8px;box-shadow:none;border:0;transition:transform .18s ease,filter .18s ease}
.providers-section .provider-card:hover{transform:translateY(-6px);filter:brightness(1.02)}
.providers-section .provider-card img{width:260px;max-width:90%;height:auto;max-height:180px;object-fit:contain;display:block}
.providers-section .provider-name{margin-top:.6rem;color:#fff;font-weight:800;font-size:1rem;text-align:center}

@media(max-width:991px){
  .providers-section .providers-grid{grid-template-columns:repeat(2,1fr)}
  .providers-section .provider-card img{width:200px;max-height:140px}
}
@media(max-width:576px){
  /* Keep provider logos two-up on narrow/mobile view for better visual balance */
  .providers-section .providers-grid{grid-template-columns:repeat(2,1fr);gap:1rem}
  .providers-section .provider-card img{width:140px;max-height:100px}
  /* Ensure provider grid remains available site-wide on mobile, but hide the hero's compact partner badges
     so the hero banner changes only affect the hero area. Utilities (fire/water/electricity) remain visible. */
  .providers-section{display:block !important}
  /* Hide only the hero's compact partner badges on mobile; keep other d-lg-none uses available */
  .hero-section .welcome-box .hero-partners{display:none !important}
}

/* Providers ribbon (transparent, dark-theme friendly, stacked logo + name) */
.providers-ribbon{--flow-duration:32s;padding:1rem 0;background:transparent;color:#fff}
.providers-ribbon .flow-track{align-items:center}
.providers-ribbon .flow-group{gap:48px;padding:14px 0}
.providers-ribbon .flow-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:12px 18px;border-radius:8px;background:transparent;box-shadow:none;color:#fff;font-weight:800}
.providers-ribbon .flow-item .flow-img{width:220px;height:auto;max-height:140px;object-fit:contain;padding:4px;background:transparent;border-radius:6px}
.providers-ribbon .flow-item .provider-name{margin-top:8px;color:#fff;font-weight:800;font-size:1rem;letter-spacing:0.2px}
.providers-ribbon .connector{display:none}

@media(max-width:992px){
  .providers-ribbon .flow-item .flow-img{width:160px;max-height:100px}
  .providers-ribbon .flow-item{padding:10px 12px}
}
@media(max-width:576px){
  .providers-ribbon{--flow-duration:48s}
  .providers-ribbon .flow-item .flow-img{width:120px;max-height:80px}
  .providers-ribbon .flow-item{padding:8px 10px}
}

/* Info cards: 'Why choose us' and 'How it works' */
.info-card{
  background: linear-gradient(180deg,#ffffff,#fbfcfd);
  border-radius:12px;
  padding:1.5rem;
  border:1px solid rgba(15,61,87,0.10);
  box-shadow:0 18px 48px rgba(15,61,87,0.10);
  position:relative;
}
.info-card h5{color:var(--primary);font-weight:700;margin-bottom:.5rem}
.info-icon{width:56px;height:56px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--secondary),var(--primary));color:#fff;flex-shrink:0;font-size:1.25rem}
.info-card::before{
  content:'';
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:6px;
  border-radius:12px 12px 0 0;
  background:linear-gradient(90deg,var(--secondary),var(--primary));
  opacity:0.12;
  pointer-events:none;
}
.info-card:hover{box-shadow:0 28px 64px rgba(15,61,87,0.16);transform:translateY(-6px)}

@media(max-width:576px){
  .info-card::before{height:4px}
}
.info-card .list-check{padding-left:0;list-style:none;margin:0}
.list-check li{display:flex;gap:.75rem;align-items:flex-start;margin-bottom:.6rem}
.list-check li i{color:var(--secondary);margin-top:3px}

/* Advisor label block used in info-card */
.info-label-block h6{color:var(--primary);font-weight:800;margin:0;font-size:1rem}
.info-label-block .small{color:rgba(15,61,87,0.72)}

.mission-card{display:flex;gap:12px;align-items:flex-start;background:linear-gradient(180deg,#fff,#fbfbfd);border-radius:12px;padding:1.25rem;border:1px solid rgba(15,61,87,0.04);box-shadow:0 10px 28px rgba(15,61,87,0.06)}
.mission-card h5{margin:0 0 .35rem 0;color:var(--primary);font-weight:800}
.mission-card p{margin:0;color:rgba(15,61,87,0.82)}
.mission-card .mission-icon{width:64px;height:64px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--secondary),var(--primary));color:#fff;font-size:1.25rem;flex-shrink:0}
.mission-card .d-flex{gap:12px}
@media(max-width:576px){.mission-card .mission-icon{width:52px;height:52px;font-size:1.05rem}}

/* Small icon tile style used across contact and mission blocks */
.mission-icon{
  width:48px;
  height:48px;
  border-radius:10px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(180deg,#e9f4ef,#dff0e8);
  color:#007a3d;
  font-size:1.1rem;
}

.content-card a{color:inherit;text-decoration:none}

/* Clickable mission cards: ensure full-card click, left-icon layout, and hover/focus affordance */
.mission-card{ text-decoration:none; color:inherit; transition:transform .18s ease, box-shadow .18s ease; }
.mission-card:hover{ transform:translateY(-6px); box-shadow:0 20px 48px rgba(15,61,87,0.08); }
a.mission-card, a.mission-card *{ text-decoration:none; color:inherit; }
a.mission-card:focus{ outline:3px solid rgba(31,162,166,0.12); outline-offset:4px }
.mission-card .mission-icon{ flex-shrink:0; width:56px; height:56px }
.mission-card h5{margin-top:0;margin-bottom:.25rem}
.mission-card p{margin-bottom:0}

/* Utility flow ribbon (animated right-to-left) */
.utility-flow{position:relative;overflow:hidden;height:76px;background:linear-gradient(90deg,var(--primary),#0b6b8a);border-bottom:1px solid rgba(0,0,0,0.06)}
.utility-flow .flow-track{display:flex;align-items:center;padding:0;white-space:nowrap;will-change:transform}
.utility-flow .flow-group{display:flex;align-items:center;gap:36px;padding:12px 0}
.utility-flow .flow-item{display:inline-flex;align-items:center;gap:12px;padding:8px 16px;border-radius:999px;background:linear-gradient(180deg,rgba(255,255,255,0.03),rgba(255,255,255,0.01));box-shadow:0 8px 24px rgba(0,0,0,0.08);color:#fff;font-weight:700;font-size:0.98rem}
.utility-flow .flow-item .flow-img{width:30px;height:30px;object-fit:contain;border-radius:6px;background:rgba(255,255,255,0.03);padding:4px}
.utility-flow .flow-item .flow-text{display:inline-block}
.utility-flow .connector{width:44px;height:2px;background:linear-gradient(90deg, rgba(255,255,255,0.22), rgba(255,255,255,0.06));border-radius:2px}

/* subtle bobbing on icons */
@keyframes bob{0%{transform:translateY(0)}50%{transform:translateY(-4px)}100%{transform:translateY(0)}}
.utility-flow .flow-img{animation:bob 3.2s ease-in-out infinite}

/* Duplicate track for seamless looping */
.utility-flow .flow-track > .flow-group{flex:0 0 auto}

.utility-flow{--flow-duration:28s;--flow-width:200%}
@keyframes flowLeft{0%{transform:translateX(0)}100%{transform:translateX(calc(-1 * var(--flow-width)))}}
.utility-flow .flow-track{animation:flowLeft var(--flow-duration) linear infinite}
.utility-flow .flow-track.track-fast{animation-duration:12s}

/* Hero-specific darker style */
.hero-section + .utility-flow{background:linear-gradient(90deg, rgba(15,61,87,0.18), rgba(31,162,166,0.1));border-top:1px solid rgba(255,255,255,0.02)}

@media(max-width:768px){.utility-flow{height:60px}.utility-flow .flow-item{padding:6px 10px;font-size:.86rem}.utility-flow .connector{width:28px}}

/* Slow the ribbon animation on narrow mobile viewports for better readability */
@media(max-width:576px){
  .utility-flow{--flow-duration:48s}
  /* Ensure any 'track-fast' variant uses the same (slower) duration on mobile */
  .utility-flow .flow-track.track-fast{animation-duration:var(--flow-duration)}
}

/* Brand item styling inside flow */
.utility-flow .flow-brand{display:inline-flex;align-items:center;gap:12px;padding:10px 18px;border-radius:999px;background:linear-gradient(90deg,rgba(255,255,255,0.04),rgba(255,255,255,0.01));box-shadow:0 10px 30px rgba(0,0,0,0.06);font-weight:800}
.utility-flow .flow-brand .brand-logo{display:none}
.utility-flow .flow-brand .brand-text{color:#fff;font-weight:800;font-size:1.02rem;letter-spacing:0.2px}

.step-list{padding-left:0;margin:0;list-style:none}
.step-item{display:flex;gap:12px;align-items:flex-start;margin-bottom:12px}
.step-index{
  width:36px;
  height:36px;
  min-width:36px;
  min-height:36px;
  aspect-ratio:1/1;
  border-radius:50%;
  background:var(--secondary);
  color:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  flex:0 0 auto;
  line-height:1;
  padding:0;
}
.step-item .step-desc{color:var(--text)}

@media(max-width:576px){
  .info-icon{width:48px;height:48px;font-size:1.05rem}
  .step-index{
    width:32px;
    height:32px;
    min-width:32px;
    min-height:32px;
    aspect-ratio:1/1;
  }
}

/* Subtle card wrapper for main content (light gray, not pure white) */
.content-card{
  background: linear-gradient(180deg,#fbfcfd,#f3f6f8);
  color: var(--text);
  border-radius:12px;
  padding:2rem;
  box-shadow:0 10px 30px rgba(15,61,87,0.04);
  border:1px solid rgba(15,61,87,0.04);
}

@media(max-width:768px){
  .content-card{padding:1.25rem}
}

/* Ensure white cards inside the dark content-card remain readable */
.content-card .bg-white,
.content-card .card{
  background:#fff;
  color:var(--text);
}

/* Highlighted support panel used on quote page */
.support-card{
  background:linear-gradient(180deg,#ffffff,#fbfbfd);
  border-left:6px solid var(--secondary);
  border-radius:12px;
  padding:1.25rem;
  box-shadow:0 18px 46px rgba(15,61,87,0.06);
  color:var(--text);
}
.support-card h5{color:var(--primary);margin-bottom:.25rem}
.support-card p{color:rgba(15,61,87,0.78);margin-bottom:.75rem}
.support-cta{display:flex;gap:.6rem;flex-direction:column}
.support-cta .btn{width:100%;padding:.66rem .9rem;border-radius:10px;font-weight:800}
.support-cta .btn-email{background:#ffffff;color:var(--primary);box-shadow:0 10px 28px rgba(15,61,87,0.06);border:1px solid rgba(15,61,87,0.06)}
.support-cta .btn-whatsapp{background:linear-gradient(90deg,#25D366,#19B858);color:#fff;border:none}
.support-note{font-size:.9rem;color:rgba(15,61,87,0.6);margin-top:.6rem}

@media(min-width:768px){
  .support-cta{flex-direction:row}
  .support-cta .btn{width:auto;flex:1}
}

/* Desktop layout tweaks: avoid stretched aside, center support card and equalise button sizes */
@media(min-width:992px){
  .support-card{max-width:380px;margin-left:auto;margin-right:auto}
  .support-card .support-cta{align-items:stretch}
  .support-card .support-cta .btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px}
  .support-card p{margin-bottom:.9rem}
}

@media(min-width:1200px){
  .support-card{max-width:420px}
}

/* Section background option 1 */
.section-bg-1{
  background: linear-gradient(180deg, #f7fbfc 0%, #eef6f8 100%);
  border-radius: 12px;
  padding: 2rem;
}

@media(min-width:992px){
  .section-bg-1{padding:3rem}
}

/* Navbar styling */
.navbar{
  background: linear-gradient(90deg, rgba(15,61,87,1) 0%, rgba(31,162,166,1) 100%);
}
.navbar .navbar-brand{color: #fff}
.navbar .navbar-brand .fw-semibold{color:#fff}
.navbar .logo-placeholder{box-shadow:0 4px 14px rgba(15,61,87,0.14)}
.navbar .nav-link{color:rgba(255,255,255,0.9);padding:0.5rem 0.75rem;border-radius:6px;transition:all .18s ease}
.navbar .nav-link:hover{color:#fff;background:rgba(255,255,255,0.06);transform:translateY(-2px);box-shadow:0 6px 18px rgba(15,61,87,0.08)}
.navbar .nav-link.active{background:rgba(255,255,255,0.15);color:#fff;font-weight:600}
.navbar .navbar-toggler{border-color:rgba(255,255,255,0.15)}
.navbar .navbar-toggler-icon{background-image:none}
.navbar .navbar-toggler span{display:block;width:22px;height:2px;background:#fff;margin:4px 0;border-radius:2px}

/* Facebook navbar icon (visible on all sizes, placed beside brand) */
.nav-fb{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:8px;background:rgba(255,255,255,0.06);color:#fff;text-decoration:none;margin-left:.6rem;transition:all .18s ease}
.nav-fb .bi{font-size:1.15rem}
.nav-fb:hover{background:rgba(255,255,255,0.14);transform:translateY(-2px)}
@media(max-width:576px){.nav-fb{width:46px;height:46px;border-radius:10px}.nav-fb .bi{font-size:1.25rem}}

/* Generic social icon used in the header (fb/email/whatsapp) */
.nav-social{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:8px;background:rgba(255,255,255,0.06);color:#fff;text-decoration:none;margin-left:.4rem;transition:all .18s ease}
.nav-social .bi{font-size:1.15rem}
.nav-social:hover{background:rgba(255,255,255,0.14);transform:translateY(-2px)}
@media(max-width:576px){.nav-social{width:42px;height:42px;border-radius:10px}.nav-social .bi{font-size:1.18rem}}

/* When the social icons are moved into the collapsed navbar menu, make them smaller and match nav-link spacing */
.nav-item#nav-social-li .nav-social{
  width:34px;
  height:34px;
  border-radius:6px;
  padding:0.15rem;
  background:transparent;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.nav-item#nav-social-li .nav-social .bi{font-size:1rem}
.nav-item#nav-social-li .nav-social:hover{background:rgba(255,255,255,0.04);transform:none}

/* Visual separation for social row inside collapsed menu to show it's a distinct section */
.nav-item#nav-social-li{
  border-top:1px solid rgba(255,255,255,0.06);
  margin-top:0.5rem;
  padding-top:0.5rem;
  justify-content:center;
  width:100%;
}
.nav-item#nav-social-li .nav-link{background:transparent}

/* When the FB icon is moved into the collapsed navbar menu, make it smaller and match nav-link spacing */
.nav-item#nav-fb-li .nav-fb{
  width:34px;
  height:34px;
  border-radius:6px;
  padding:0.15rem;
  background:transparent;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.nav-item#nav-fb-li .nav-fb .bi{font-size:1rem}
.nav-item#nav-fb-li .nav-fb:hover{background:rgba(255,255,255,0.04);transform:none}

/* Mobile menu override to match gradient */
@media (max-width: 991px){
  .navbar-collapse{background:linear-gradient(180deg, rgba(15,61,87,1), rgba(31,162,166,1));padding:1rem;border-radius:8px}
  .navbar .nav-link{color:rgba(255,255,255,0.95)}
}

/* Fancy underline on hover for desktop */
@media (min-width: 992px){
  .navbar .nav-link::after{content:'';display:block;height:3px;width:0;background:linear-gradient(90deg,var(--accent),#fff);border-radius:3px;transition:width .22s ease;margin-top:6px}
  .navbar .nav-link:hover::after{width:100%}
}

/* CTA adjustments to stand out on hero */
.hero-section .btn-warning{background:var(--accent);border-color:var(--accent);color:#0F3D57}
.hero-section .btn-outline-light{border-color:rgba(255,255,255,0.35);color:#fff}

/* Fix hover for outline-light on dark hero to avoid white-on-white */
.hero-section .btn-outline-light:hover,
.hero-section .btn-outline-light:focus{
  background: rgba(255,255,255,0.12) !important;
  color: #fff !important;
  border-color: rgba(255,255,255,0.6) !important;
}

/* Ensure service card outline-primary keeps visible text on hover */
.service-card .btn-outline-primary:hover,
.service-card .btn-outline-primary:focus{
  background: var(--primary) !important;
  color: #fff !important;
  border-color: var(--primary) !important;
}

/* Prevent accidental white background for outline buttons in other dark areas */
.btn-outline-light:hover{background:rgba(255,255,255,0.08)}

/* Centered hero welcome */
.hero-center{min-height:480px;display:flex;align-items:center;justify-content:center;text-align:center;padding:4rem 0}
.hero-center .welcome-box{z-index:3;color:#fff;max-width:880px}
.hero-center .welcome-title{font-size:2.1rem;font-weight:800;margin-bottom:.5rem;text-shadow:0 6px 18px rgba(0,0,0,0.35)}
.hero-center .welcome-sub{font-size:1.15rem;opacity:.95;margin-bottom:1.25rem}

/* Inline headline: 'Welcome to' + brand */
.hero-headline{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap}
.welcome-phrase{font-size:1.6rem;color:#fff;font-weight:900;padding:6px 12px;border-radius:10px;background:linear-gradient(90deg,rgba(255,255,255,0.06),rgba(255,255,255,0.02));box-shadow:0 10px 28px rgba(15,61,87,0.18);letter-spacing:0.6px;text-shadow:0 6px 20px rgba(0,0,0,0.35)}
.hero-headline .brand-name{display:inline-flex;align-items:center;gap:10px}
.hero-headline .brand-name .brand-v,.hero-headline .brand-name .brand-switch,.hero-headline .brand-name .brand-suffix{padding:8px 12px}

@media(min-width:992px){
  .welcome-phrase{font-size:2.4rem}
  .hero-headline .brand-name .brand-v{font-size:1.6rem}
  .hero-headline .brand-name .brand-switch{font-size:1.45rem}
  .hero-headline .brand-name .brand-suffix{font-size:1.4rem}
  .hero-center .welcome-title{font-size:1.35rem}
}

@media(max-width:768px){
  .hero-headline{gap:10px}
  .welcome-phrase{font-size:1.25rem;padding:6px 10px}
  .hero-center .welcome-title{font-size:1.4rem}
}

/* Site loading overlay */
.site-loader{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,rgba(15,61,87,0.98),rgba(31,162,166,0.96));z-index:99999;transition:opacity .6s ease,visibility .6s ease;opacity:1;visibility:visible}
.site-loader.loaded{opacity:0;visibility:hidden;pointer-events:none}
.site-loader .loader-inner{display:flex;flex-direction:column;align-items:center;gap:14px;padding:18px;color:#fff}
.site-loader .loader-brand .brand-name{display:inline-flex;align-items:center;gap:8px;font-weight:900;font-size:1.36rem}
.site-loader .loader-brand .brand-name .brand-v{padding:6px 10px;background:rgba(255,255,255,0.06);border-radius:8px}
.site-loader .loader-quote{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,0.03);padding:8px 12px;border-radius:999px;box-shadow:0 10px 30px rgba(0,0,0,0.08);font-weight:700}
.site-loader .loader-icon{width:28px;height:28px;object-fit:contain;border-radius:6px;background:rgba(255,255,255,0.02);padding:4px}
.site-loader .loader-brand{display:flex;flex-direction:column;align-items:center;gap:8px}
/* The loader is visible on all viewports. Navbar logo container was adjusted separately. */

.site-loader .loader-brand::before{content:'';display:block;width:72px;height:72px;border-radius:10px;background:linear-gradient(135deg,rgba(31,162,166,0.18),rgba(15,61,87,0.22));box-shadow:0 8px 26px rgba(0,0,0,0.14);animation:elecPulse 1.6s infinite ease-in-out}
.site-loader .loader-brand .brand-name{display:inline-flex;align-items:center;gap:8px;font-weight:900;font-size:1.6rem}
.site-loader .loader-text{background:transparent;color:#fff;font-weight:700;padding:6px 10px;border-radius:6px;text-align:center}
.site-loader .loader-icons{display:flex;gap:18px;align-items:center;justify-content:center;margin-top:10px}
.site-loader .loader-icon{width:56px;height:56px;object-fit:contain;border-radius:10px;background:rgba(255,255,255,0.02);padding:10px;animation:fireFlicker 1.6s infinite ease-in-out}
.site-loader .quote-text{margin-left:6px;font-size:0.98rem}

@media(max-width:576px){
  .site-loader .loader-brand .brand-name{font-size:1.05rem}
  .site-loader .quote-text{font-size:0.9rem}
  .site-loader .loader-icon{width:22px;height:22px}
  .site-loader .loader-brand::before{width:36px;height:36px}
}

/* OR badge between CTAs and contact panel */
.or-badge{
  display:inline-block;
  background:rgba(255,255,255,0.06);
  color:#fff;
  padding:8px 18px;
  border-radius:999px;
  font-weight:800;
  box-shadow:0 8px 20px rgba(15,61,87,0.12);
  border:1px solid rgba(255,255,255,0.06);
  margin:14px auto;
  text-align:center;
}
@media(min-width:992px){
  .or-badge{margin:18px auto; padding:10px 22px; font-size:1.05rem}
}

.or-badge .or-main{font-weight:900}
.or-badge .or-sub{font-weight:600;opacity:0.9;margin-left:10px;font-size:0.95rem}
.or-badge .or-sub::before{content:'—';margin-right:8px;opacity:0.6}

/* Phone badge styling (hero) */
.phone-badge{
  display:inline-block;
  background:linear-gradient(90deg, rgba(255,255,255,0.10), rgba(255,255,255,0.04));
  color:#fff;
  padding:8px 12px;
  border-radius:10px;
  font-weight:800;
  box-shadow:0 10px 28px rgba(15,61,87,0.18);
  border:1px solid rgba(255,255,255,0.08);
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease;
  text-decoration:none;
}
.phone-badge:hover,.phone-badge:focus{transform:translateY(-3px);box-shadow:0 14px 36px rgba(15,61,87,0.22);background:linear-gradient(90deg, rgba(255,255,255,0.16), rgba(255,255,255,0.06));}
.hero-center .phone-badge{font-size:1.05rem}

@media(max-width:576px){
  .site-logo{width:72px;height:72px}
  .site-loader .loader-brand .brand-name{font-size:1.05rem}
  .site-loader .quote-text{font-size:0.9rem}
  .site-loader .loader-icon{width:48px;height:48px;padding:6px}
  .site-loader .loader-brand::before{width:72px;height:72px}
  .loader-logo{width:96px;height:96px}
}
.contact-panel .contact-item{display:flex;align-items:center;gap:12px}
.contact-panel .vr{width:1px;height:48px;background:rgba(255,255,255,0.08)}
.contact-panel .contact-text{color:rgba(255,255,255,0.92);font-weight:600}
.contact-panel .btn-outline-light{border-color:rgba(255,255,255,0.18);color:#fff}

/* Inline contact buttons */
.contact-inline{display:flex;gap:12px;align-items:center;justify-content:center;margin-top:8px}
.btn-whatsapp{background:#25D366;border-color:#25D366;color:#fff;font-weight:700;border-radius:10px;padding:8px 14px;display:inline-flex;align-items:center;gap:10px;text-decoration:none}
.btn-whatsapp i{font-size:1.1rem}
.btn-whatsapp:hover{filter:brightness(0.95)}
.btn-email{background:#ffffff;color:var(--primary);border:none;padding:8px 12px;border-radius:10px;display:inline-flex;align-items:center;gap:8px;text-decoration:none;font-weight:700;box-shadow:0 8px 24px rgba(15,61,87,0.12)}
.btn-email i{font-size:1.05rem;color:var(--primary)}

/* Keep mission-card icon white when mission-card is used as an email button */
.mission-card.btn-email .mission-icon i{color:#fff !important}

@media(max-width:768px){
  .contact-inline{flex-direction:row;gap:10px}
  .contact-panel{padding:12px}
}
@media(max-width:768px){.contact-panel{flex-direction:column;gap:10px;padding:12px}.contact-panel .vr{display:none;height:0}}

.rotating-icons{display:flex;gap:24px;align-items:center;justify-content:center;margin-top:1rem}
.rotating-icons .icon{width:120px;height:120px;border-radius:14px;background:transparent;padding:14px;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 36px rgba(15,61,87,0.14);transform:scale(0.98);opacity:1;transition:transform .35s ease,opacity .35s ease}
.rotating-icons .icon img{max-width:80%;max-height:80%}
.rotating-icons .icon.active{transform:scale(1.02);opacity:1}

/* Per-icon animations */
.rotating-icons .icon{background:transparent;opacity:1}
.rotating-icons .icon img{max-width:64%;max-height:64%;display:block}

.icon-fire{animation:fireFlicker 1.4s infinite ease-in-out;}
.icon-water{animation:waterDrop 2.2s infinite cubic-bezier(.2,.9,.2,1);}
.icon-elec{animation:elecPulse 1.6s infinite ease-in-out;}

@keyframes fireFlicker{
  0%{transform:translateY(0) scale(0.98);filter:drop-shadow(0 6px 12px rgba(244,162,97,0.06));opacity:0.95}
  25%{transform:translateY(-4px) scale(1.03);opacity:1}
  50%{transform:translateY(0) scale(0.99);opacity:0.92}
  75%{transform:translateY(-2px) scale(1.02);opacity:1}
  100%{transform:translateY(0) scale(0.98);opacity:0.95}
}

@keyframes waterDrop{
  0%{transform:translateY(-18px) scaleY(0.98);opacity:0}
  20%{transform:translateY(-6px) scaleY(1.02);opacity:1}
  55%{transform:translateY(8px) scaleY(0.96);opacity:0.95}
  75%{transform:translateY(2px) scaleY(1.00);opacity:0.98}
  100%{transform:translateY(0) scaleY(1);opacity:1}
}

@keyframes elecPulse{
  0%{transform:scale(0.96);filter:drop-shadow(0 0 0 rgba(31,162,166,0.0));opacity:0.92}
  40%{transform:scale(1.08);filter:drop-shadow(0 8px 20px rgba(31,162,166,0.14));opacity:1}
  70%{transform:scale(0.99);filter:drop-shadow(0 4px 12px rgba(31,162,166,0.08));opacity:0.98}
  100%{transform:scale(1);filter:drop-shadow(0 0 0 rgba(31,162,166,0));opacity:0.95}
}

/* small responsive tweaks */
@media(max-width:480px){
  .rotating-icons{gap:14px}
  .rotating-icons .icon{width:84px;height:84px;padding:8px}
  .rotating-icons .icon img{max-width:78%;max-height:78%}
  .rotating-icons .icon{box-shadow:0 10px 30px rgba(15,61,87,0.18);border:1px solid rgba(255,255,255,0.06)}
}

/* small caption under icons */
.rotating-icons .caption{color:#fff;margin-left:8px;font-weight:700}

@media(max-width:768px){
  .hero-center{padding:3rem 1.25rem;min-height:420px}
  .hero-center .welcome-title{font-size:1.6rem}
  .rotating-icons .icon{width:92px;height:92px;padding:10px}
  .rotating-icons .icon img{max-width:72%;max-height:72%}
}

/* Brand split: V | Switch | 4ultd */
.brand-name{display:inline-flex;align-items:center;gap:6px;line-height:1}
.brand-name .brand-v{font-weight:800;background:var(--secondary);color:#fff;font-size:1.15rem;letter-spacing:0.4px;padding:4px 8px;border-radius:6px;box-shadow:0 6px 18px rgba(31,162,166,0.12)}
.brand-name .brand-switch{font-weight:800;background:rgba(255,255,255,0.08);color:#fff;font-size:1.02rem;padding:4px 8px;border-radius:6px;border:1px solid rgba(255,255,255,0.06)}
.brand-name .brand-suffix{font-weight:800;color:#0F3D57;background:var(--accent);padding:4px 8px;border-radius:6px}

/* Slightly larger brand on desktop */
@media(min-width:992px){
  .navbar .brand-name .brand-v{font-size:1.25rem}
  .navbar .brand-name .brand-switch{font-size:1.12rem}
  .navbar .brand-name .brand-suffix{font-size:1.05rem}
}

/* Highlighted promise banner (global) */
.promise-banner{
  background:linear-gradient(180deg,#ffffff,#fbfbfd);
  border-left:8px solid var(--secondary);
  padding:14px 18px;
  border-radius:10px;
  box-shadow:0 14px 36px rgba(15,61,87,0.06);
  color:var(--text);
  margin-bottom:1.25rem;
  display:flex;
  align-items:flex-start;
  gap:12px;
}
.promise-icon{width:46px;height:46px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--secondary),var(--primary));color:#fff;font-size:1.15rem}
.promise-content h5{margin:0;font-weight:800;color:var(--primary);font-size:1.05rem}
.promise-content p{margin:0;color:rgba(15,61,87,0.88);font-weight:600}
@media(max-width:576px){
  .promise-banner{flex-direction:row;gap:10px;padding:12px}
  .promise-icon{width:42px;height:42px}
  .promise-content h5{font-size:1rem}
}

/* Emphasize brand visibility */
.navbar .brand-name{font-family:'Lato',system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-weight:700}

/* Hero */
.hero-section{background:linear-gradient(135deg,var(--primary),var(--secondary));}
.hero-section .display-5{color: #fff}

/* Footer — ensure footer links remain visible on the dark background */
.site-footer a{color:#ffffff !important;opacity:0.95}
.site-footer a:hover{color:var(--accent) !important;opacity:1}

/* Small layout improvements */
.navbar-brand .logo-placeholder{background:linear-gradient(135deg,var(--secondary),var(--primary));}

.card.shadow-sm{border:0}
