/* Emerald Coast Systems Group — shared design system
   Used by index / capabilities / about / contact.
   (services.html intentionally uses its own dark sub-brand theme.) */

:root{
  --bg:#ffffff; --bg2:#f3f6f9; --navy:#0c2842; --navy2:#15395b; --ink:#0c2842;
  --body:#445466; --mut:#6a7c8e; --line:#e3e9f0; --line2:#cfd9e4;
  --acc:#0e7c64; --acc-d:#0a5e4c; --grad:linear-gradient(96deg,#0a5e4c,#0e7c64,#22b894);
  --sans:'Inter',system-ui,-apple-system,sans-serif;
  --d:'Archivo',var(--sans);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{background:var(--bg);color:var(--body);font-family:var(--sans);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-wrap:anywhere}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:1180px;margin:0 auto;padding:0 32px}
@media(max-width:560px){.wrap{padding:0 22px}}
h1,h2,h3{font-family:var(--d);color:var(--ink);font-weight:700;line-height:1.12;letter-spacing:-.02em}
.eyebrow{display:flex;flex-wrap:wrap;align-items:center;gap:11px;font-size:.77rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--acc)}
.eyebrow::before{content:"";width:28px;height:2px;border-radius:2px;background:var(--grad)}

.btn{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:.96rem;padding:15px 28px;border-radius:6px;transition:.2s cubic-bezier(.16,.8,.3,1);cursor:pointer}
.btn-acc{background:var(--acc);color:#fff}.btn-acc:hover{background:var(--acc-d)}
.btn-grad{background:var(--grad);color:#fff;box-shadow:0 12px 30px -10px rgba(14,124,100,.55)}
.btn-grad:hover{transform:translateY(-2px);box-shadow:0 18px 40px -10px rgba(34,184,148,.6)}
.btn-navy{background:var(--navy);color:#fff}.btn-navy:hover{background:var(--navy2)}
.btn-light{background:#fff;color:var(--navy)}.btn-light:hover{background:#e9eff5}
.btn-ghost{border:1.5px solid rgba(255,255,255,.55);color:#fff}.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.12)}
.btn-out{border:1.5px solid var(--line2);color:var(--navy);background:#fff}.btn-out:hover{border-color:var(--acc);color:var(--acc)}

header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.95);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--d);font-weight:700;font-size:1.08rem;color:var(--ink);letter-spacing:-.01em}
.brand svg{width:29px;height:29px;flex:none}
.links{display:flex;gap:30px}
.links a{color:var(--body);font-size:.92rem;font-weight:500;transition:.15s}.links a:hover{color:var(--acc)}
.links a.active{color:var(--acc)}
.navbtn{font-size:.89rem;font-weight:600;color:#fff;background:var(--navy);padding:10px 19px;border-radius:5px;transition:.18s}
.navbtn:hover{background:var(--navy2)}
@media(max-width:900px){
  .menu-btn{display:flex}
  .links{position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:#fff;border-bottom:1px solid var(--line);box-shadow:0 24px 44px -24px rgba(12,40,66,.4);max-height:0;overflow:hidden;transition:max-height .3s ease;z-index:60}
  .links.open{max-height:460px}
  .links a{padding:16px 32px;border-top:1px solid var(--line);font-size:1rem;color:var(--ink)}
}

/* hero (home) */
.hero{position:relative;display:flex;flex-direction:column;justify-content:center;min-height:clamp(560px,82vh,740px);color:#fff;overflow:hidden}
.hero::before{content:"";position:absolute;inset:-2.5%;background:url('../img/hero-f35-eglin.jpg') center/cover no-repeat;animation:kenburns 26s ease-in-out infinite alternate}
@keyframes kenburns{from{transform:scale(1)}to{transform:scale(1.09)}}
@media(prefers-reduced-motion:reduce){.hero::before{animation:none}}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(98deg,rgba(9,24,40,.95) 0%,rgba(10,28,46,.86) 38%,rgba(10,28,46,.5) 70%,rgba(10,28,46,.18) 100%),radial-gradient(60vw 50vw at 88% 92%,rgba(34,184,148,.16),transparent 60%)}
.hero .wrap{position:relative;z-index:2;width:100%;padding:80px 32px}
.hero .eyebrow{color:#7defce}.hero .eyebrow::before{background:linear-gradient(90deg,#22b894,#7defce)}
.hero h1{color:#fff;font-family:var(--d);font-weight:800;font-size:clamp(2.7rem,6.4vw,4.9rem);line-height:1.0;letter-spacing:-.035em;max-width:16ch;margin:22px 0 0}
.hero p{color:#d3deea;font-size:clamp(1.06rem,1.7vw,1.24rem);max-width:54ch;margin:24px 0 38px}
.hero .row{display:flex;flex-wrap:wrap;gap:14px}

/* page hero (inner pages) */
.phero{position:relative;color:#fff;overflow:hidden;background:linear-gradient(150deg,#0c2842 0%,#0a1d30 100%)}
.phero::before{content:"";position:absolute;inset:0;background:radial-gradient(54vw 44vw at 88% 8%,rgba(34,184,148,.16),transparent 60%);pointer-events:none}
.phero .wrap{position:relative;z-index:1;padding:74px 32px 64px}
.phero .eyebrow{color:#7defce}.phero .eyebrow::before{background:linear-gradient(90deg,#22b894,#7defce)}
.phero h1{color:#fff;font-size:clamp(2.1rem,4.6vw,3.4rem);margin:16px 0 0;max-width:20ch}
.phero p{color:#c4d2e0;font-size:clamp(1.04rem,1.6vw,1.2rem);max-width:60ch;margin-top:18px}
@media(max-width:560px){.phero .wrap{padding:52px 22px 44px}}

.trust{background:var(--navy);color:#cdd9e6}
.trust .wrap{display:flex;flex-wrap:wrap;gap:13px 40px;padding:20px 32px;justify-content:center}
.trust span{display:flex;align-items:center;gap:10px;font-size:.85rem;font-weight:500;color:#e6edf4}
.trust span::before{content:"";width:6px;height:6px;border-radius:50%;background:#5fdcc0;flex:none}

.sec{padding:94px 0}
.sec.alt{background:var(--bg2)}
.sec-head{max-width:760px}
.sec-head h2{font-size:clamp(1.9rem,3.3vw,2.6rem);margin-top:12px}
.sec-head p{color:var(--body);font-size:1.1rem;margin-top:15px}

.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:50px}
@media(max-width:860px){.cards{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid var(--line);border-top:3px solid var(--acc);border-radius:9px;padding:32px 28px;transition:.22s}
.card:hover{box-shadow:0 18px 42px -26px rgba(12,40,66,.45);transform:translateY(-3px)}
.card h3{font-size:1.24rem;margin-bottom:10px}
.card p{font-size:.98rem;color:var(--body)}
a.card{display:block;color:inherit}
.card .more{display:inline-block;margin-top:14px;font-size:.86rem;font-weight:700;letter-spacing:.04em;color:var(--acc)}

/* quantified proof metrics */
.metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:11px;overflow:hidden;margin-top:48px}
@media(max-width:760px){.metrics{grid-template-columns:1fr}}
.metric{background:#fff;padding:40px 32px}
.metric .fig{font-family:var(--d);font-weight:800;font-size:3.1rem;color:var(--navy);letter-spacing:-.035em;line-height:1}
.metric .fig em{font-style:normal;color:var(--acc)}
.metric h3{font-size:1.04rem;margin:14px 0 6px;font-weight:700}
.metric p{font-size:.92rem;color:var(--mut)}
.proofnote{margin-top:24px;font-size:.92rem;color:var(--mut)}

/* dark band */
.sec.dark{background:linear-gradient(165deg,#0c2842 0%,#0a1d30 100%);color:#fff;position:relative;overflow:hidden}
.sec.dark::before{content:"";position:absolute;inset:0;background:radial-gradient(50vw 40vw at 85% 10%,rgba(34,184,148,.14),transparent 60%);pointer-events:none}
.sec.dark .wrap{position:relative;z-index:1}
.sec.dark h2{color:#fff}
.sec.dark .sec-head p{color:#b9c7d6}
.sec.dark .proofnote{color:#8ea3b8}
.sec.dark .metrics{background:rgba(255,255,255,.13);border-color:rgba(255,255,255,.14)}
.sec.dark .metric{background:#0e2a47}
.sec.dark .metric .fig{color:#fff}
.sec.dark .metric .fig em{color:#5fdcc0}
.sec.dark .metric h3{color:#eef3f8}
.sec.dark .metric p{color:#a5b6c8}
.sec.dark .card{background:#0e2a47;border-color:rgba(255,255,255,.12)}
.sec.dark .card h3{color:#fff}
.sec.dark .card p{color:#a5b6c8}

.split{display:grid;grid-template-columns:1.05fr .95fr;gap:58px;align-items:center}
@media(max-width:900px){.split{grid-template-columns:1fr;gap:38px}}
.split .photo{border-radius:12px;overflow:hidden;border:1px solid var(--line2);box-shadow:0 30px 60px -36px rgba(12,40,66,.5)}
.split .photo img{width:100%;height:100%;object-fit:cover;aspect-ratio:3/2}
.statgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:11px;overflow:hidden;margin-top:44px}
.stat{background:#fff;padding:24px 26px}
.stat .big{font-family:var(--d);font-size:1.7rem;font-weight:700;color:var(--navy)}
.stat .lbl{font-size:.89rem;color:var(--mut);margin-top:3px}

.local{display:grid;grid-template-columns:1.5fr 1fr;grid-template-rows:repeat(2,minmax(165px,1fr));gap:14px;margin-top:46px}
@media(max-width:720px){.local{grid-template-columns:1fr;grid-template-rows:none}}
.local figure{position:relative;border-radius:11px;overflow:hidden;border:1px solid var(--line2);min-height:165px}
.local .big{grid-column:1;grid-row:1 / span 2}
@media(max-width:720px){.local .big{grid-column:auto;grid-row:auto;min-height:230px}}
.local img{width:100%;height:100%;object-fit:cover;transition:.6s cubic-bezier(.16,.8,.3,1)}
.local figure:hover img{transform:scale(1.05)}
.local figcaption{position:absolute;left:0;right:0;bottom:0;padding:28px 15px 12px;font-size:.8rem;font-weight:600;color:#fff;background:linear-gradient(transparent,rgba(9,24,40,.82))}

.facts{border:1px solid var(--line);border-radius:11px;overflow:hidden;margin-top:46px;background:#fff}
.frow{display:grid;grid-template-columns:.42fr 1fr;border-bottom:1px solid var(--line)}.frow:last-child{border-bottom:none}
.frow .k{padding:18px 26px;font-size:.77rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--mut);border-right:1px solid var(--line);background:var(--bg2)}
.frow .v{padding:18px 26px;font-weight:600;color:var(--ink)}
.frow .v small{font-weight:600;font-size:.78rem;color:var(--acc);border:1px solid var(--acc);border-radius:20px;padding:2px 10px;margin-left:10px;display:inline-block}
@media(max-width:560px){.frow{grid-template-columns:1fr}.frow .k{border-right:none}}

/* competency list (capabilities page) */
.comp{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:50px}
@media(max-width:860px){.comp{grid-template-columns:1fr}}
.comp .item{background:#fff;border:1px solid var(--line);border-left:3px solid var(--acc);border-radius:9px;padding:30px 28px}
.comp .item h3{font-size:1.18rem;margin-bottom:6px}
.comp .item .sub{font-size:.92rem;color:var(--mut);margin-bottom:16px}
.ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.ul li{position:relative;padding-left:24px;font-size:.96rem;color:var(--body)}
.ul li::before{content:"";position:absolute;left:0;top:.55em;width:9px;height:9px;border-radius:2px;background:var(--grad)}

/* process / steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:46px}
@media(max-width:860px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.steps{grid-template-columns:1fr}}
.step{background:#fff;border:1px solid var(--line);border-radius:10px;padding:26px 24px}
.step .n{font-family:var(--d);font-weight:800;font-size:1.05rem;color:var(--acc);letter-spacing:.04em}
.step h3{font-size:1.08rem;margin:10px 0 6px}
.step p{font-size:.93rem;color:var(--mut)}

/* ways to engage */
.engage{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
@media(max-width:860px){.engage{grid-template-columns:1fr}}
.eng{background:#fff;border:1px solid var(--line);border-radius:10px;padding:28px 26px}
.eng .pill{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:4px 12px;border-radius:20px;margin-bottom:14px}
.pill.now{color:var(--acc);background:rgba(14,124,100,.1);border:1px solid rgba(14,124,100,.3)}
.pill.soon{color:#9a6a09;background:rgba(242,179,71,.14);border:1px solid rgba(242,179,71,.5)}
.eng h3{font-size:1.12rem;margin-bottom:8px}
.eng p{font-size:.95rem;color:var(--body)}

/* leadership / team bios */
.bios{display:grid;grid-template-columns:repeat(auto-fit,minmax(232px,1fr));gap:20px;margin-top:48px}
@media(max-width:520px){.bios{grid-template-columns:1fr}}
.bio{background:#fff;border:1px solid var(--line);border-radius:11px;padding:30px 28px}
.bio .av{width:60px;height:60px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-family:var(--d);font-weight:800;color:#fff;font-size:1.3rem;letter-spacing:-.02em}
.bio h3{font-size:1.18rem;margin:18px 0 2px}
.bio .role{font-size:.85rem;font-weight:700;letter-spacing:.04em;color:var(--acc);text-transform:uppercase;margin-bottom:12px}
.bio p{font-size:.95rem;color:var(--body)}
.bio.open{border-style:dashed;border-color:var(--line2);background:var(--bg2)}
.bio.open .av{background:#dde6ef;color:var(--mut)}
.bio.open .role{color:var(--mut)}
.bio.open .tag{display:inline-block;margin-top:14px;font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--mut);border:1px dashed var(--line2);border-radius:20px;padding:3px 12px}

/* FAQ */
.faq{margin-top:46px;border:1px solid var(--line);border-radius:11px;overflow:hidden;background:#fff}
.faq details{border-bottom:1px solid var(--line)}.faq details:last-child{border-bottom:none}
.faq summary{list-style:none;cursor:pointer;padding:22px 26px;font-family:var(--d);font-weight:700;color:var(--ink);font-size:1.05rem;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--acc);line-height:1;flex:none;transition:.2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .ans{padding:0 26px 24px;font-size:.98rem;color:var(--body)}

.contact{background:var(--navy);color:#fff;padding:100px 0;text-align:center}
.contact .eyebrow{color:#5fdcc0;justify-content:center}
.contact h2{color:#fff;font-size:clamp(2rem,4vw,3rem);margin-top:13px}
.contact a.mail{display:inline-block;margin:26px 0 10px;font-family:var(--d);font-size:clamp(1.1rem,2.5vw,1.55rem);font-weight:600;color:#fff;border-bottom:2px solid rgba(255,255,255,.4);padding-bottom:5px;transition:.2s}
.contact a.mail:hover{border-color:#5fdcc0}
.contact .who{color:#a9bacd;font-size:.95rem;margin-top:8px}

footer{background:#081726;color:#7d92a8;padding:36px 0}
footer .wrap{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.83rem}
.fnav{display:flex;gap:22px;flex-wrap:wrap}.fnav a:hover{color:#cdd9e6}
.credit{margin-top:16px;font-size:.73rem;line-height:1.55;color:#576b80}
.credit a{color:#7d92a8;text-decoration:underline}

.rv{opacity:0;transform:translateY(20px);transition:.7s cubic-bezier(.16,.8,.3,1)}.rv.in{opacity:1;transform:none}

/* mobile menu button */
.nav-right{display:flex;align-items:center;gap:6px}
.menu-btn{display:none;background:none;border:0;cursor:pointer;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;padding:10px}
.menu-btn span{display:block;height:2px;width:100%;background:var(--ink);border-radius:2px;transition:.25s}
.menu-btn.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-btn.open span:nth-child(2){opacity:0}
.menu-btn.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(max-width:900px){.menu-btn{display:flex}}
.links a.only-mobile{display:none}
@media(max-width:900px){
  .nav-right .navbtn{display:none}
  .links a.only-mobile{display:block}
}
@media(max-width:560px){.brand{font-size:.96rem;gap:9px}.brand svg{width:25px;height:25px}}
@media(max-width:560px){.hero .row{flex-direction:column;align-items:stretch}.hero .row .btn{width:100%;justify-content:center}}
@media(max-width:760px){
  .hero{display:block;min-height:auto;max-width:100vw;overflow-x:hidden}
  .hero::after{background:linear-gradient(175deg,rgba(8,22,38,.93) 0%,rgba(10,28,46,.82) 100%)}
  .hero .wrap{display:block;width:100%;max-width:100%;padding:84px 22px 60px}
  .hero h1,.hero p,.hero .eyebrow,.hero .row{max-width:100%}
}
/* mobile spacing polish */
@media(max-width:760px){.sec{padding:64px 0}*{min-width:0}}
@media(max-width:560px){
  .sec{padding:52px 0}
  .hero .wrap{padding:54px 22px}
  .contact{padding:70px 0}
  .metric{padding:30px 24px}
  .frow .k{padding:14px 22px}.frow .v{padding:14px 22px}
  .sec-head h2,.contact h2{font-size:1.7rem}
  .metric .fig{font-size:2.4rem}
  .contact a.mail{font-size:1.02rem}
}
@media(max-width:760px){.statgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:420px){.statgrid{grid-template-columns:1fr}}
