/* ==========================================================================
   shared.css — JCG shared styles across all pages
   Extracted from inline <style> blocks to eliminate duplication.
   Includes: fonts, reset, variables, nav, footer, WhatsApp FAB,
   scroll animations, buttons, section utilities, and responsive base.
   ========================================================================== */

/* === Self-hosted Inter (replaces Google Fonts render-blocking CSS) === */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/inter/v18/UcCO3FwrK3iLTeHuS_nVMrMxCp50SjIw2boKoduKmMEVuLyfAZ9hiA.woff2) format('woff2');
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/inter/v18/UcCO3FwrK3iLTeHuS_nVMrMxCp50SjIw2boKoduKmMEVuI2fAZ9hiA.woff2) format('woff2');
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/inter/v18/UcCO3FwrK3iLTeHuS_nVMrMxCp50SjIw2boKoduKmMEVuGKYAZ9hiA.woff2) format('woff2');
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/inter/v18/UcCO3FwrK3iLTeHuS_nVMrMxCp50SjIw2boKoduKmMEVuFuYAZ9hiA.woff2) format('woff2');
}

/* === Self-hosted DM Sans (replaces Playfair Display for headings) === */
@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/dmsans/v15/rP2Yp2ywxg089UriI5-g4vlH9VoD8CmcqZG40F9JadbnoEwAopxhS23PjQ.woff2) format('woff2');
}
@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/dmsans/v15/rP2Yp2ywxg089UriI5-g4vlH9VoD8CmcqZG40F9JadbnoEwAkJxhS23PjQ.woff2) format('woff2');
}
@font-face {
  font-family: 'DM Sans';
  font-style: italic;
  font-weight: 700;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/dmsans/v15/rP2Xp2ywxg089UriCZaSExd4Fv9GgTcgGBimSJbMQr0HvFnuEw7ELWI.woff2) format('woff2');
}

/* === CSS Reset & Root Variables === */
:root{
--navy:#0f4a2c;--navy-mid:#1a6b40;--navy-dark:#0a3520;
--red:#c72127;--red-glow:#e8363d;--red-dark:#a01b20;
--green:#12a84e;--green-glow:#1ec463;--green-dark:#109247;
--white:#fff;--off-white:#f2faf5;
--gray-50:#eaf5ee;--gray-100:#c8e6d2;--gray-400:#5a9e74;--gray-500:#3d8a5c;--gray-600:#2d6b45;--gray-700:#245a3a;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:'Inter',system-ui,sans-serif;color:var(--gray-700);line-height:1.6;background:#fff;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
.container{max-width:1240px;margin:0 auto;padding:0 2rem}

/* === Navigation (subpages — always solid bg) === */
.nav{position:fixed;top:0;left:0;right:0;z-index:200;padding:1.2rem 0;transition:all .4s;background:rgba(10,53,32,.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 1px 0 rgba(18,168,78,.25),0 4px 20px rgba(0,0,0,.3)}
.nav .container{display:flex;align-items:center;justify-content:space-between}
.nav-logo img{height:34px;filter:brightness(0) invert(1)}
.nav-links{display:flex;align-items:center;gap:2.2rem}
.nav-links a{font-size:.8rem;font-weight:500;color:rgba(255,255,255,.65);letter-spacing:.4px;transition:color .3s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--green);transition:width .3s}
.nav-links a:hover{color:#fff}
.nav-links a:hover::after{width:100%}
.nav-links a.active{color:#fff}
.nav-links a.active::after{width:100%}
.nav-cta{padding:.55rem 1.6rem!important;background:var(--red)!important;color:#fff!important;font-weight:600!important;border-radius:6px;letter-spacing:.2px;transition:all .3s!important;box-shadow:0 4px 15px rgba(199,33,39,.3)}
.nav-cta::after{display:none!important}
.nav-cta:hover{background:var(--green)!important;transform:translateY(-1px);box-shadow:0 6px 25px rgba(16,146,71,.45)}
.hamburger{display:none;cursor:pointer;flex-direction:column;gap:6px;z-index:201}
.hamburger span{width:26px;height:2px;background:#fff;transition:.3s;border-radius:2px}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,6px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-6px)}
.mobile-overlay{display:none;position:fixed;inset:0;z-index:199;background:rgba(15,23,18,.97);backdrop-filter:blur(30px);flex-direction:column;align-items:center;justify-content:center;gap:2rem}
.mobile-overlay.open{display:flex}
.mobile-overlay a{font-size:1.4rem;font-weight:600;color:rgba(255,255,255,.8);transition:color .3s}
.mobile-overlay a:hover{color:#fff}

/* === Section Utilities === */
.sec{padding:6rem 0}
.sec-light{background:#fff}
.sec-alt{background:var(--off-white)}
.sec-warm{background:var(--gray-50)}
.sec-dark{background:var(--navy);color:#fff}
.sec-tag{display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--red);margin-bottom:.8rem}
.sec-dark .sec-tag{color:var(--red-glow)}
.sec-title{font-family:'DM Sans','Inter',system-ui,sans-serif;font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:800;color:var(--navy);line-height:1.15}
.sec-dark .sec-title{color:#fff}
.sec-subtitle{font-size:.95rem;color:var(--gray-400);max-width:520px;margin-top:.6rem;line-height:1.8}

/* === Button Base === */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 2rem;font-family:inherit;font-size:.85rem;font-weight:600;border:none;border-radius:6px;cursor:pointer;transition:all .3s;letter-spacing:.3px}
.btn-red{background:var(--red);color:#fff;font-weight:700;box-shadow:0 4px 15px rgba(199,33,39,.3)}
.btn-red:hover{background:var(--red-glow);transform:translateY(-2px);box-shadow:0 8px 25px rgba(199,33,39,.4)}

/* === Page Hero (shared across about, gallery, contact) === */
.page-hero .container{position:relative;z-index:2}
.page-hero .breadcrumb{font-size:.75rem;color:rgba(255,255,255,.45);margin-bottom:1.2rem;letter-spacing:.5px}
.page-hero .breadcrumb a{color:rgba(255,255,255,.55);transition:color .3s}
.page-hero .breadcrumb a:hover{color:#fff}
.page-hero h1{font-family:'DM Sans','Inter',system-ui,sans-serif;font-size:clamp(2.4rem,4.5vw,3.6rem);font-weight:800;color:#fff;line-height:1.12;max-width:620px}
.page-hero h1 em{font-style:italic;color:var(--green-glow)}
.page-hero .hero-sub{font-size:1.05rem;color:rgba(255,255,255,.6);max-width:520px;margin-top:1.2rem;line-height:1.85}
.page-hero .hero-accent{width:60px;height:3px;background:var(--red);border-radius:2px;margin-top:1.8rem}

/* === CTA Section (shared across about, services, gallery, contact) === */
.cta-section{position:relative;padding:5.5rem 0;overflow:hidden;text-align:center}
.cta-section::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 100%)}
.cta-section::after{content:'';position:absolute;inset:0;background:repeating-linear-gradient(-45deg,transparent,transparent 40px,rgba(255,255,255,.02) 40px,rgba(255,255,255,.02) 41px)}
.cta-section .container{position:relative;z-index:2}
.cta-section h2{font-family:'DM Sans','Inter',system-ui,sans-serif;font-size:clamp(1.6rem,3vw,2.4rem);font-weight:800;color:#fff;margin-bottom:.6rem}
.cta-section p{color:rgba(255,255,255,.65);font-size:.95rem;margin-bottom:2rem}

/* === Footer === */
.footer{background:var(--navy-dark);padding:4rem 0 2rem;color:rgba(255,255,255,.5)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:2.5rem;margin-bottom:3rem}
.footer-brand img{height:38px;filter:brightness(0) invert(1);margin-bottom:1rem}
.footer-brand p{font-size:.82rem;line-height:1.8;max-width:260px}
.footer h6{font-size:.75rem;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:rgba(255,255,255,.2);margin-bottom:1.2rem}
.footer a{display:block;font-size:.82rem;color:rgba(255,255,255,.4);margin-bottom:.6rem;transition:color .3s}
.footer a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding-top:2rem;display:flex;justify-content:space-between;align-items:center}
.footer-bottom p{font-size:.75rem;color:rgba(255,255,255,.25)}
.footer-socials{display:flex;gap:.5rem}
.footer-socials a{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.08);border-radius:8px;margin-bottom:0;transition:all .3s}
.footer-socials a:hover{border-color:rgba(255,255,255,.2);background:rgba(255,255,255,.05)}
.footer-socials svg{width:14px;height:14px;fill:rgba(255,255,255,.4)}

/* === WhatsApp FAB === */
.wa-fab{position:fixed;bottom:1.5rem;right:1.5rem;z-index:90;width:54px;height:54px;background:#25D366;border-radius:16px;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px rgba(37,211,102,.4);transition:all .3s}
.wa-fab:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 10px 30px rgba(37,211,102,.5)}
.wa-fab svg{width:26px;height:26px;fill:#fff}

/* === Scroll Reveal Animations === */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.reveal.vis{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-40px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.reveal-left.vis{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(40px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.reveal-right.vis{opacity:1;transform:translateX(0)}
.stagger>*{opacity:0;transform:translateY(20px);transition:opacity .5s cubic-bezier(.16,1,.3,1),transform .5s cubic-bezier(.16,1,.3,1)}
.stagger.vis>*:nth-child(1){transition-delay:.05s}
.stagger.vis>*:nth-child(2){transition-delay:.1s}
.stagger.vis>*:nth-child(3){transition-delay:.15s}
.stagger.vis>*:nth-child(4){transition-delay:.2s}
.stagger.vis>*:nth-child(5){transition-delay:.25s}
.stagger.vis>*:nth-child(6){transition-delay:.3s}
.stagger.vis>*:nth-child(7){transition-delay:.35s}
.stagger.vis>*:nth-child(8){transition-delay:.4s}
.stagger.vis>*:nth-child(9){transition-delay:.45s}
.stagger.vis>*{opacity:1;transform:translateY(0)}

/* === Reduced Motion === */
@media(prefers-reduced-motion:reduce){
  .reveal,.reveal-left,.reveal-right,.stagger>*{opacity:1;transform:none;transition:none}
}

/* === Responsive — Shared Components === */
@media(max-width:1024px){
  .nav-links{display:none}.hamburger{display:flex}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:1rem;text-align:center}
}
