*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --gold:#C8960A;--gold-lt:#F0C93A;--gold-bg:#FDF8EC;
  --navy:#1A2744;--navy-lt:#2C3E6B;
  --slate:#4A5568;--gray:#5F6B7C;
  --light:#EAEBEE;--border:#C8CDD8;--white:#FFFFFF;
  --font-d:"Frank Ruhl Libre",serif;--font-b:"Heebo",sans-serif;
  --sh-sm:0 2px 8px rgba(26,39,68,.07);
  --sh-md:0 8px 32px rgba(26,39,68,.12);
  --sh-lg:0 18px 54px rgba(26,39,68,.22);
  --r:14px;
  --focus-ring:0 0 0 3px #F0C93A;
}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-b);color:var(--navy);line-height:1.7;
  -webkit-font-smoothing:antialiased;
  background-color:#1a1e28;
  background-image:url("../assets/images/img_01_bg.png");
  background-size:cover;
  background-attachment:fixed;
  background-position:center;
}
body::before{
  content:"";position:fixed;inset:0;
  background:rgba(10,14,24,0.45);
  z-index:0;pointer-events:none;
}
.nav,.section-wrap,.footer,.wa-float,.a11y-trigger,.a11y-modal-wrap,.modal-wrap{position:relative;z-index:1}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{font-family:inherit}
.skip-link{position:absolute;top:-100px;right:0;left:0;background:var(--navy);color:var(--white);padding:12px 20px;text-align:center;font-size:15px;font-weight:600;z-index:9999;transition:top .2s}
.skip-link:focus{top:0}
.container{max-width:1100px;margin:0 auto;padding:0 24px}
.section{padding:88px 0}
.section-tag{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);background:var(--gold-bg);padding:6px 16px;border-radius:20px;border:1px solid rgba(200,150,10,.25);margin-bottom:20px}
.section-tag::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--gold);flex-shrink:0}
.section-title{font-family:var(--font-d);font-size:clamp(28px,4vw,42px);font-weight:700;color:var(--navy);line-height:1.25;margin-bottom:16px}
.section-subtitle{font-size:17px;color:var(--slate);max-width:560px;line-height:1.75}
.divider{width:52px;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-lt));border-radius:2px;margin:20px 0}
:focus-visible{outline:3px solid var(--gold-lt);outline-offset:3px;border-radius:4px}

/* NAV */
.nav{position:fixed;top:0;right:0;left:0;z-index:900;background:rgba(255,255,255,.97);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);transition:box-shadow .3s}
.nav.scrolled{box-shadow:var(--sh-sm)}
.nav-inner{display:flex;align-items:center;gap:20px;height:68px;max-width:1100px;margin:0 auto;padding:0 24px}
.nav-logo{display:flex;align-items:center;gap:10px;font-family:var(--font-d);color:var(--navy);line-height:1.2}
.nav-logo img{width:40px;height:40px;object-fit:contain;border-radius:50%}
.nav-logo-text{display:flex;flex-direction:column;gap:2px}
.nav-logo-name{font-size:16px;font-weight:700;line-height:1.15}
.nav-logo-sub{font-size:12px;font-weight:700;color:var(--navy);line-height:1.2;letter-spacing:.01em}
.nav-links{display:flex;gap:22px;margin-inline-start:auto}
.nav-links a{font-size:14px;font-weight:500;color:var(--slate);transition:color .2s;padding:4px 0;cursor:pointer;background:none;border:none}
.nav-links a:hover{color:var(--navy)}
.nav-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}
.nav-linkedin{width:28px;height:28px;border-radius:6px;background:#0A66C2;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}
.nav-linkedin:hover{background:#004182;transform:translateY(-1px)}
.nav-linkedin svg{width:14px;height:14px;fill:white}
.nav-cta{display:flex;align-items:center;gap:8px;background:var(--gold);color:var(--white);padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;transition:all .2s;white-space:nowrap}
.nav-cta:hover{background:#9e7508}

/* NFPA badge — uses logo image if present, otherwise falls back to text badge */
.nav-nfpa{display:flex;align-items:center;justify-content:center;height:36px;border-radius:8px;transition:all .2s;flex-shrink:0;overflow:hidden}
.nav-nfpa img{height:36px;width:auto;display:block;object-fit:contain}
.nav-nfpa .nfpa-text{display:none;padding:0 12px;background:#C8102E;color:#fff;font-size:11px;font-weight:800;letter-spacing:.08em;height:100%;align-items:center;border-radius:8px}
.nav-nfpa.nfpa-fallback{background:transparent}
.nav-nfpa.nfpa-fallback .nfpa-text{display:flex}
.nav-nfpa:hover{transform:translateY(-1px);filter:brightness(1.08)}
.nav-nfpa.nfpa-fallback:hover .nfpa-text{background:#a80d24}

/* Language switcher — minimal, blends into the white nav bar */
.nav-lang{display:flex;gap:2px;flex-shrink:0}
.lang-btn{display:flex;align-items:center;gap:4px;background:transparent;border:none;padding:3px 5px;border-radius:4px;cursor:pointer;font-family:inherit;font-size:10px;font-weight:600;color:var(--gray);letter-spacing:.05em;transition:opacity .2s,color .2s;line-height:1;opacity:.55}
.lang-btn:hover{opacity:.95;color:var(--navy)}
.lang-btn.active{opacity:1;color:var(--navy)}
.lang-btn .lang-flag{width:14px;height:10px;border-radius:2px;overflow:hidden;flex-shrink:0;box-shadow:0 0 0 1px rgba(0,0,0,.06)}
.bico{width:18px;height:18px;flex-shrink:0}

/* HERO */
.hero-wrap{background:transparent}
.hero{padding:136px 0 96px}
.hero-grid{display:grid;grid-template-columns:1fr 400px;gap:56px;align-items:center}
.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:13px;font-weight:600;letter-spacing:.1em;color:var(--gold-lt);margin-bottom:20px}
.hero-eyebrow::before{content:"";width:30px;height:2px;background:var(--gold-lt)}
.hero-title{font-family:var(--font-d);font-size:clamp(34px,5vw,56px);font-weight:900;line-height:1.15;color:#fff;margin-bottom:22px}
.hero-title em{font-style:normal;color:var(--gold-lt)}
.hero-sub{font-size:17px;color:rgba(255,255,255,.88);line-height:1.8;margin-bottom:34px;max-width:510px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.btn-p{display:inline-flex;align-items:center;gap:9px;background:var(--gold);color:var(--white);padding:13px 26px;border-radius:10px;font-size:15px;font-weight:700;transition:all .2s;box-shadow:0 4px 20px rgba(200,150,10,.35);border:2px solid transparent;cursor:pointer}
.btn-p:hover{background:#9e7508;transform:translateY(-2px)}
.btn-s{display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.1);color:#fff;padding:13px 26px;border-radius:10px;font-size:15px;font-weight:700;border:2px solid rgba(255,255,255,.35);transition:all .2s;cursor:pointer}
.btn-s:hover{background:rgba(255,255,255,.18);transform:translateY(-2px)}
.hero-trust{display:flex;align-items:center;gap:20px;margin-top:38px;padding-top:30px;border-top:1px solid rgba(255,255,255,.18);flex-wrap:wrap}
.trust-stat{text-align:center}
.trust-num{font-family:var(--font-d);font-size:26px;font-weight:700;color:#fff;line-height:1}
.trust-label{font-size:13px;color:rgba(255,255,255,.65);margin-top:3px}
.trust-sep{width:1px;height:38px;background:rgba(255,255,255,.2);flex-shrink:0}
.hero-card{background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.2);border-radius:20px;padding:32px;backdrop-filter:blur(12px)}
.hero-card-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:8px;padding:8px 12px;font-size:12px;font-weight:500;color:rgba(255,255,255,.85);margin-top:8px;margin-bottom:18px}
.badge-dot{width:7px;height:7px;border-radius:50%;background:#22c55e;flex-shrink:0;animation:blink 2s infinite}
.badge-dot.offline{background:#e53e3e;animation:blink-red 1.5s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
@keyframes blink-red{0%,100%{opacity:1}50%{opacity:.2}}
.hero-card-title{font-family:var(--font-d);font-size:17px;font-weight:700;color:#fff;margin-bottom:18px}
.hero-card-items{display:flex;flex-direction:column;gap:11px;list-style:none}
.hero-card-items li{display:flex;align-items:flex-start;gap:9px;font-size:13px;color:rgba(255,255,255,.88)}
.hero-card-items li::before{content:"✓";width:19px;height:19px;border-radius:5px;background:var(--gold);color:var(--white);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}

/* section backgrounds — white/light are fully transparent; navy keeps its tint for contrast */
.section-white{background:transparent}
.section-light{background:transparent}
.section-navy{background:rgba(26,39,68,0.55);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}

/* text colors adjusted for transparent/dark sections (image shows through) */
.section-white .section-title,
.section-light .section-title,
.section-navy .section-title{color:#fff;text-shadow:0 2px 18px rgba(0,0,0,.35)}
.section-white .section-subtitle,
.section-light .section-subtitle,
.section-navy .section-subtitle{color:rgba(255,255,255,.92)}
.section-white .clients-note,
.section-light .clients-note{color:rgba(255,255,255,.82)}

/* about section adjustments — apply to both light and navy variants */
.section-light .af-title,
.section-navy .af-title{color:#fff}
.section-light .af-text,
.section-navy .af-text{color:rgba(255,255,255,.85)}
.section-light .af-icon,
.section-navy .af-icon{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.22)}

/* process section adjustments */
.section-white .pstep-title{color:#fff}
.section-white .pstep-text{color:rgba(255,255,255,.82)}
.section-white .pstep-num{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.3);color:#fff}
.section-white .process-steps::before{background:rgba(255,255,255,.22)}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:68px;align-items:center}
.about-img{position:relative;border-radius:20px;overflow:hidden;min-height:460px;background:linear-gradient(135deg,var(--navy) 0%,var(--navy-lt) 100%)}
.about-portrait{width:100%;height:100%;object-fit:cover;object-position:center 20%;display:block;position:absolute;inset:0}
.about-img .about-badge{z-index:2}
.about-badge{position:absolute;bottom:18px;right:18px;background:var(--gold);color:var(--white);border-radius:12px;padding:11px 16px;font-size:12px;font-weight:700;box-shadow:var(--sh-md)}
.about-badge strong{display:block;font-size:21px;font-family:var(--font-d);line-height:1}
.about-feats{display:flex;flex-direction:column;gap:18px;margin-top:30px;list-style:none}
.af{display:flex;gap:13px;align-items:flex-start}
.af-icon{width:42px;height:42px;border-radius:11px;background:var(--white);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.af-icon svg{width:20px;height:20px}
.af-title{font-size:14px;font-weight:700;color:var(--navy);margin-bottom:2px}
.af-text{font-size:13px;color:var(--slate);line-height:1.6}

/* SERVICES */
.srv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:22px;margin-top:48px;list-style:none}
.srv-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:28px 24px;transition:all .25s;position:relative;overflow:hidden;cursor:pointer;text-align:start;width:100%;font:inherit;color:inherit;display:block}
.srv-card::after{content:"";position:absolute;bottom:0;right:0;left:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-lt));transform:scaleX(0);transform-origin:right;transition:transform .3s}
html[dir="ltr"] .srv-card::after{transform-origin:left}
.srv-card:hover,.srv-card:focus-visible{transform:translateY(-4px);box-shadow:var(--sh-md);border-color:transparent}
.srv-card:hover::after,.srv-card:focus-visible::after{transform:scaleX(1)}
.srv-icon{width:56px;height:56px;border-radius:13px;background:var(--gold-bg);border:1px solid rgba(200,150,10,.15);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.srv-icon img{width:36px;height:36px;object-fit:contain}
.srv-icon-dual{width:56px;height:56px;border-radius:13px;background:var(--gold-bg);border:1px solid rgba(200,150,10,.15);display:flex;align-items:center;justify-content:center;margin-bottom:18px;gap:3px}
.srv-icon-dual img{width:24px;height:24px;object-fit:contain}
.srv-title{font-size:16px;font-weight:700;color:var(--navy);margin-bottom:8px;font-family:var(--font-d)}
.srv-text{font-size:13px;color:var(--slate);line-height:1.65}
.srv-more{display:inline-flex;align-items:center;gap:6px;margin-top:14px;font-size:12px;font-weight:700;color:var(--gold);letter-spacing:.02em}
.srv-more::after{content:"←";transition:transform .2s}
.srv-card:hover .srv-more::after{transform:translateX(-3px)}

/* WHY */
.why-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:20px;margin-top:48px;list-style:none}
.why-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.15);border-radius:var(--r);padding:26px 22px;transition:all .25s}
.why-card:hover{background:rgba(255,255,255,.12);transform:translateY(-3px)}
.why-num{font-family:var(--font-d);font-size:40px;font-weight:900;color:var(--gold-lt);line-height:1;margin-bottom:10px;opacity:.7}
.why-title{font-size:15px;font-weight:700;color:var(--white);margin-bottom:7px}
.why-text{font-size:13px;color:rgba(255,255,255,.8);line-height:1.65}

/* CLIENTS */
.clients-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-top:44px;list-style:none}
.client-card{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:20px 18px;display:flex;align-items:center;gap:10px;transition:all .22s}
.client-card:hover{border-color:var(--gold);box-shadow:var(--sh-sm);transform:translateY(-2px)}
.client-dot{width:8px;height:8px;border-radius:50%;background:var(--gold);flex-shrink:0}
.client-name{font-size:13px;font-weight:600;color:var(--navy);line-height:1.35}
.clients-note{text-align:center;margin-top:24px;font-size:13px;color:var(--slate)}

/* PROCESS */
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:52px;position:relative;list-style:none}
.process-steps::before{content:"";position:absolute;top:27px;right:13%;left:13%;height:2px;background:var(--border);z-index:0}
.pstep{text-align:center;padding:0 14px;position:relative;z-index:1;cursor:pointer;background:none;border:none;font:inherit;color:inherit;width:100%}
.pstep-num{width:54px;height:54px;border-radius:50%;background:var(--white);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-family:var(--font-d);font-size:19px;font-weight:700;color:var(--navy);margin:0 auto 18px;transition:all .25s}
.pstep:hover .pstep-num,.pstep:focus-visible .pstep-num{background:var(--gold);color:var(--white);border-color:var(--gold)}
.pstep-title{font-size:14px;font-weight:700;color:var(--navy);margin-bottom:7px}
.pstep-text{font-size:12px;color:var(--slate);line-height:1.6}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:68px;align-items:start}
.contact-methods{display:flex;flex-direction:column;gap:14px;margin-top:30px}
.cm{display:flex;align-items:center;gap:14px;background:var(--white);border:1px solid var(--border);border-radius:12px;padding:16px 18px;transition:all .2s;text-decoration:none;color:inherit}
.cm:hover{border-color:var(--gold);transform:translateX(-4px);box-shadow:var(--sh-sm)}
.cm-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ic-wa{background:#1a7a3c}.ic-phone{background:var(--navy)}.ic-mail{background:#7a5a08}
.cm-icon svg{width:19px;height:19px}
.cm-label{font-size:11px;color:var(--slate);margin-bottom:1px;font-weight:600}
.cm-value{font-size:14px;font-weight:700;color:var(--navy)}
.cm-hours{font-size:11px;color:var(--gray);margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}
.cm-arr{margin-inline-start:auto;opacity:.3;width:15px;height:15px;flex-shrink:0}
.contact-form{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:32px;display:flex;flex-direction:column;gap:15px}
.fg{display:flex;flex-direction:column;gap:5px}
.fl{font-size:13px;font-weight:700;color:var(--navy)}
.fi,.ft,.fs{width:100%;padding:12px 14px;border:2px solid var(--border);border-radius:8px;font-family:var(--font-b);font-size:14px;color:var(--navy);background:var(--white);transition:border-color .2s;appearance:none}
.fi:focus,.ft:focus,.fs:focus{outline:none;border-color:var(--gold);box-shadow:var(--focus-ring)}
.ft{min-height:96px;resize:vertical}
.req{color:#b30000;font-weight:700}
.fsub{background:var(--gold);color:var(--white);border:2px solid var(--gold);padding:13px 26px;border-radius:10px;font-family:var(--font-b);font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;width:100%}
.fsub:hover{background:#9e7508;border-color:#9e7508;transform:translateY(-2px)}
.form-ok{display:none;color:#0d5e1e;background:#d0f0da;padding:12px 16px;border-radius:8px;font-size:14px;font-weight:600;text-align:center;border:1px solid #1a7a3c}

/* GENERIC MODAL (services + process + more) */
.modal-wrap{display:none;position:fixed;inset:0;background:rgba(10,14,24,.72);backdrop-filter:blur(6px);z-index:1000;align-items:flex-start;justify-content:center;padding:5vh 18px;overflow-y:auto}
.modal-wrap.open{display:flex;animation:modal-fade .22s ease}
@keyframes modal-fade{from{opacity:0}to{opacity:1}}
.modal{background:var(--white);border-radius:18px;max-width:780px;width:100%;height:min(640px,90vh);padding:0;position:relative;box-shadow:var(--sh-lg);overflow:hidden;display:flex;flex-direction:column;animation:modal-slide .28s cubic-bezier(.2,.9,.3,1.05)}
@keyframes modal-slide{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
.modal-hd{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-lt) 100%);color:#fff;padding:34px 40px 30px;position:relative;text-align:start}
.modal-hd .modal-icon{width:54px;height:54px;border-radius:13px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.modal-hd .modal-icon img{width:32px;height:32px;object-fit:contain;filter:brightness(0) invert(1)}
.modal-tag{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.12em;color:var(--gold-lt);text-transform:uppercase;margin-bottom:8px}
.modal-title{font-family:var(--font-d);font-size:28px;font-weight:700;line-height:1.2;margin:0}
.modal-sub{margin-top:10px;font-size:15px;color:rgba(255,255,255,.85);line-height:1.7}
.modal-body{padding:32px 40px 36px;flex:1;overflow-y:auto;min-height:0;text-align:start}
.modal-body p{font-size:15px;color:var(--slate);line-height:1.8;margin-bottom:14px}
.modal-body h3{font-family:var(--font-d);font-size:17px;font-weight:700;color:var(--navy);margin:22px 0 10px}
.modal-body ul{list-style:none;display:flex;flex-direction:column;gap:9px;margin:8px 0 18px}
.modal-body ul li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--slate);line-height:1.65}
.modal-body ul li::before{content:"✓";flex-shrink:0;width:20px;height:20px;border-radius:5px;background:var(--gold-bg);color:var(--gold);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;margin-top:2px}
.modal-body .modal-note{background:var(--gold-bg);border-inline-start:3px solid var(--gold);padding:14px 18px;border-radius:8px;margin-top:22px;font-size:14px;color:var(--navy);line-height:1.65}
.modal-body .modal-note strong{color:var(--gold);margin-inline-end:4px}

/* Project gallery inside modal — stacked images */
.modal-body .proj-modal-gallery{display:flex;flex-direction:column;gap:14px;margin-bottom:22px}
.modal-body .proj-modal-gallery img{width:100%;height:auto;border-radius:10px;display:block;box-shadow:0 4px 14px rgba(26,39,68,.12)}

/* Career list — aligned columns (check / role / dash / description) */
/* Role column is fixed-width (matches the shortest title) — longer titles wrap to 2 lines */
.modal-body .career-list{list-style:none;display:grid;grid-template-columns:20px 128px auto 1fr;column-gap:10px;row-gap:14px;margin:8px 0 18px;padding:0;align-items:start}
.modal-body .career-list li{display:contents}
.modal-body .career-list li::before{display:none}
.modal-body .career-check{width:20px;height:20px;border-radius:5px;background:var(--gold-bg);color:var(--gold);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;margin-top:2px}
.modal-body .career-role{font-weight:700;color:var(--navy);line-height:1.5;font-size:14px;word-wrap:break-word}
.modal-body .career-dash{color:var(--slate);line-height:1.65;font-size:14px}
.modal-body .career-desc{color:var(--slate);line-height:1.65;font-size:14px}

/* Mobile — stack cleanly when modal is narrow */
@media(max-width:620px){
  .modal-body .career-list{display:block}
  .modal-body .career-list li{display:block;position:relative;padding-right:30px;margin-bottom:12px;line-height:1.65}
  .modal-body .career-check{position:absolute;right:0;top:2px;margin-top:0}
  .modal-body .career-role,.modal-body .career-dash,.modal-body .career-desc{display:inline}
  .modal-body .career-dash{margin:0 2px}
}
.modal-foot{border-top:1px solid var(--border);padding:20px 40px;display:flex;gap:10px;flex-wrap:wrap;background:#fafbfc}
.modal-cta{display:inline-flex;align-items:center;gap:8px;background:var(--gold);color:#fff;padding:11px 22px;border-radius:9px;font-size:14px;font-weight:700;transition:all .2s;cursor:pointer;border:2px solid transparent}
.modal-cta:hover{background:#9e7508;transform:translateY(-1px)}
.modal-cta-s{display:inline-flex;align-items:center;gap:8px;background:#fff;color:var(--navy);padding:11px 22px;border-radius:9px;font-size:14px;font-weight:700;border:2px solid var(--border);transition:all .2s;cursor:pointer}
.modal-cta-s:hover{border-color:var(--navy)}
.modal-close{position:absolute;top:16px;inset-inline-end:16px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);color:#fff;width:36px;height:36px;border-radius:10px;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:2}
.modal-close:hover{background:rgba(255,255,255,.25)}
body.modal-open{overflow:hidden}

/* ACCESSIBILITY MODAL (separate styling kept) */
.a11y-modal-wrap{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:1000;align-items:center;justify-content:center;padding:24px}
.a11y-modal-wrap.open{display:flex}
.a11y-modal{background:var(--white);border-radius:16px;max-width:680px;width:100%;max-height:80vh;overflow-y:auto;padding:36px;position:relative;text-align:start}
.a11y-modal h2{font-family:var(--font-d);font-size:24px;font-weight:700;color:var(--navy);margin-bottom:8px}
.a11y-modal h3{font-size:15px;font-weight:700;color:var(--navy);margin:20px 0 8px;font-family:var(--font-d)}
.a11y-modal p,.a11y-modal li{font-size:14px;color:var(--slate);line-height:1.75}
.a11y-modal ul{list-style:none;display:flex;flex-direction:column;gap:5px}
.a11y-modal ul li::before{content:"✓ ";color:var(--gold);font-weight:700}
.a11y-modal a{color:var(--navy);text-decoration:underline}
.a11y-close{position:absolute;top:16px;inset-inline-end:16px;background:none;border:none;font-size:22px;cursor:pointer;color:var(--slate);padding:4px 8px;border-radius:6px}
.a11y-close:hover{background:var(--light)}

/* FOOTER */
.footer{background:rgba(26,39,68,0.85);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:rgba(255,255,255,.65);padding:44px 0 28px;position:relative;z-index:1}
.footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:18px}
.footer-logo{display:flex;align-items:center;gap:10px;color:var(--white);font-family:var(--font-d);line-height:1.3}
.footer-logo img{width:34px;height:34px;object-fit:contain;border-radius:50%}
.footer-logo-text{display:flex;flex-direction:column;gap:2px}
.footer-logo-name{font-size:15px;font-weight:700;line-height:1.15}
.footer-logo-sub{font-size:12px;font-weight:700;color:var(--white);line-height:1.2}
.footer-links{display:flex;gap:22px;flex-wrap:wrap}
.footer-links a{font-size:13px;transition:color .2s;color:rgba(255,255,255,.7);cursor:pointer;background:none;border:none;font-family:inherit}
.footer-links a:hover{color:var(--white)}
.footer-bottom{display:flex;align-items:center;justify-content:center;gap:16px;width:100%;margin-top:22px;padding-top:22px;border-top:1px solid rgba(255,255,255,.1)}
.footer-copy{font-size:12px;color:rgba(255,255,255,.55);text-align:center}
.footer-linkedin{width:28px;height:28px;border-radius:6px;background:#0A66C2;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}
.footer-linkedin:hover{background:#004182;transform:translateY(-1px)}
.footer-linkedin svg{width:14px;height:14px;fill:white}

/* PROJECTS GRID */
.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:22px;margin-top:40px;list-style:none;text-align:start}
.proj-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;transition:all .25s;position:relative;cursor:pointer;font:inherit;color:inherit;text-align:start;width:100%;padding:0;display:flex;flex-direction:column}
.proj-card:not([data-modal]){cursor:default}
.proj-card:hover,.proj-card:focus-visible{transform:translateY(-4px);box-shadow:var(--sh-md);border-color:transparent}
.proj-img{position:relative;aspect-ratio:16/10;overflow:hidden;background:linear-gradient(135deg,var(--navy) 0%,var(--navy-lt) 100%)}
.proj-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}
.proj-card:hover .proj-img img{transform:scale(1.04)}
.proj-img-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.3)}
.proj-img-ph svg{width:48px;height:48px}
.proj-year{position:absolute;top:12px;left:12px;background:rgba(0,0,0,.55);color:#fff;font-size:11px;font-weight:700;padding:4px 10px;border-radius:999px;backdrop-filter:blur(4px)}
.proj-body{padding:22px 22px 24px;display:flex;flex-direction:column;gap:8px;flex:1}
.proj-meta{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:4px}
.proj-tag{font-size:11px;font-weight:700;color:var(--gold);background:var(--gold-bg);padding:3px 9px;border-radius:999px;border:1px solid rgba(200,150,10,.2);letter-spacing:.02em}
.proj-title{font-family:var(--font-d);font-size:17px;font-weight:700;color:var(--navy);line-height:1.3;margin:0}
.proj-desc{font-size:13px;color:var(--slate);line-height:1.6;margin:0}
.proj-more{margin-top:auto;padding-top:12px;font-size:12px;font-weight:700;color:var(--gold);letter-spacing:.02em;display:inline-flex;align-items:center;gap:6px}
.proj-more::after{content:"←";transition:transform .2s}
.proj-card:hover .proj-more::after{transform:translateX(-3px)}

/* PLACEHOLDER / TEASER sections (projects, podcast, licensing) */
.placeholder-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.18);border-radius:var(--r);padding:44px 32px;margin-top:36px;text-align:center;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.placeholder-card p{color:rgba(255,255,255,.85);font-size:16px;line-height:1.8;max-width:640px;margin:0 auto}
.placeholder-card .ph-badge{display:inline-block;background:var(--gold);color:#fff;font-size:12px;font-weight:700;letter-spacing:.1em;padding:5px 14px;border-radius:999px;margin-bottom:18px}
.teaser-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:22px}
.teaser-actions .btn-p,.teaser-actions .btn-s{cursor:pointer}

/* COOKIE BANNER */
.cookie-banner{position:fixed;bottom:0;right:0;left:0;z-index:950;background:rgba(26,39,68,0.97);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;padding:16px 20px;box-shadow:0 -8px 24px rgba(0,0,0,0.25);animation:slide-up .3s ease}
@keyframes slide-up{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}
.cookie-banner-inner{max-width:1100px;margin:0 auto;display:flex;gap:16px;align-items:center;flex-wrap:wrap;justify-content:space-between}
.cookie-banner-text{font-size:13px;line-height:1.55;flex:1;min-width:240px;color:rgba(255,255,255,.9);margin:0}
.cookie-banner-text a{color:var(--gold-lt);text-decoration:underline}
.cookie-banner-text a:hover{color:#fff}
.cookie-banner-actions{display:flex;gap:8px;flex-shrink:0}
.cookie-btn{padding:9px 18px;border-radius:8px;font-family:inherit;font-size:13px;font-weight:700;cursor:pointer;transition:all .2s;border:1px solid transparent}
.cookie-btn-accept{background:var(--gold);color:#fff;border-color:var(--gold)}
.cookie-btn-accept:hover{background:#9e7508;border-color:#9e7508}
.cookie-btn-deny{background:transparent;color:rgba(255,255,255,.85);border-color:rgba(255,255,255,.3)}
.cookie-btn-deny:hover{background:rgba(255,255,255,.1);color:#fff}
@media(max-width:600px){
  .cookie-banner-inner{flex-direction:column;align-items:stretch}
  .cookie-banner-actions{justify-content:stretch}
  .cookie-btn{flex:1}
}

/* WA FLOAT */
.wa-float{position:fixed;bottom:26px;inset-inline-end:26px;z-index:800;width:56px;height:56px;border-radius:50%;background:#1a7a3c;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 22px rgba(26,122,60,.45);transition:all .2s;animation:wa-pulse 2.5s infinite}
.wa-float:hover{transform:scale(1.1);animation:none}
.wa-float svg{width:28px;height:28px}
@keyframes wa-pulse{0%,100%{box-shadow:0 4px 22px rgba(26,122,60,.45)}50%{box-shadow:0 4px 34px rgba(26,122,60,.7)}}

@media(prefers-reduced-motion:no-preference){
  .fade-up{opacity:0;transform:translateY(26px);transition:opacity .6s ease,transform .6s ease}
  .fade-up.vis{opacity:1;transform:translateY(0)}
  .fade-up:nth-child(1){transition-delay:.00s}.fade-up:nth-child(2){transition-delay:.07s}
  .fade-up:nth-child(3){transition-delay:.14s}.fade-up:nth-child(4){transition-delay:.21s}
  .fade-up:nth-child(5){transition-delay:.28s}.fade-up:nth-child(6){transition-delay:.35s}
  .fade-up:nth-child(7){transition-delay:.42s}.fade-up:nth-child(8){transition-delay:.49s}
}
@media(prefers-reduced-motion:reduce){
  .fade-up{opacity:1;transform:none}
  *{animation-duration:.01ms !important;transition-duration:.01ms !important}
}
/* Hamburger menu button — hidden on desktop, visible on mobile */
.nav-menu-btn{display:none;background:transparent;border:none;width:36px;height:36px;padding:0;cursor:pointer;position:relative;flex-shrink:0;margin-inline-start:4px}
.nav-menu-btn span{display:block;width:22px;height:2px;background:var(--navy);border-radius:2px;margin:5px auto;transition:all .25s}
.nav-menu-btn[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-menu-btn[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-menu-btn[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:900px){
  .hero-grid,.about-grid,.contact-grid{grid-template-columns:1fr;gap:36px}
  .hero{padding:118px 0 60px}
  .process-steps{grid-template-columns:1fr 1fr;gap:28px}
  .process-steps::before{display:none}
  .nav-menu-btn{display:block}
  /* mobile drawer menu */
  .nav-links{display:flex;flex-direction:column;gap:0;position:fixed;top:68px;right:0;left:0;background:rgba(255,255,255,.98);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:8px 20px 16px;transform:translateY(-120%);transition:transform .3s ease;box-shadow:0 8px 20px rgba(26,39,68,.12);max-height:calc(100vh - 68px);overflow-y:auto;margin:0}
  .nav.menu-open .nav-links{transform:translateY(0)}
  .nav-links a{padding:14px 8px;border-bottom:1px solid var(--border);font-size:15px;text-align:start}
  .nav-links a:last-child{border-bottom:none}
  .modal-hd,.modal-body,.modal-foot{padding-left:26px;padding-right:26px}
  .modal-title{font-size:23px}
  /* allow nav to wrap sub-row if items crowd */
  .nav-inner{gap:12px}
  .nav-logo-sub{display:none}
}
@media(max-width:600px){
  .section{padding:58px 0}
  .hero-title{font-size:30px}
  .hero-actions{flex-direction:column}
  .btn-p,.btn-s{justify-content:center;width:100%}
  .hero-trust{flex-wrap:wrap;justify-content:center;gap:20px}
  .trust-sep{display:none}
  .process-steps{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr 1fr}
  .clients-grid{grid-template-columns:1fr 1fr}
  .footer-inner{flex-direction:column;text-align:center}
  .footer-links{justify-content:center}
  .modal-wrap{padding:3vh 10px}
  .modal-foot .modal-cta,.modal-foot .modal-cta-s{width:100%;justify-content:center}
  .nav-cta span{display:none} /* show only WhatsApp icon on very narrow */
  .nav-cta{padding:10px 12px}
  .nav-logo img{width:34px;height:34px}
  .nav-logo-name{font-size:14px}
  .nav-nfpa{display:none} /* hide NFPA badge on very narrow screens */
  .hero-card{padding:24px}
  .proj-grid{grid-template-columns:1fr}
}
@media(max-width:380px){
  .nav-linkedin{display:none}
  .lang-btn span{display:none} /* show only flag on extra narrow */
}
@media(forced-colors:active){
  .btn-p,.btn-s,.nav-cta{border:2px solid ButtonText}
}
