/* ============================================================
   OZMATE CONSULTANT — Master Stylesheet
   Brand: Navy #061536 · Ivory #F7F3E9 · Gold #C9A24B
   Fonts: Fraunces (headings) · Outfit (body)
   ============================================================ */

/* ---------- SHARED BASE + HOME ---------- */
:root{
  --ivory:#F7F3E9;
  --ivory-soft:#FBF8F1;
  --ivory-deep:#EFE8D6;
  --navy:#061536;
  --navy-soft:#0d2150;
  --gold:#C9A24B;
  --gold-light:#D9B968;
  --gold-deep:#A8842F;
  --ink:#1a1f2e;
  --muted:#5b6275;
  --line:rgba(6,21,54,0.10);
  --display:'Fraunces',Georgia,serif;
  --body:'Outfit',system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  background:var(--ivory);
  color:var(--ink);
  line-height:1.65;
  font-weight:300;
  overflow-x:hidden;
}
h1,h2,h3,h4,h5{font-family:var(--display);font-weight:500;line-height:1.12;letter-spacing:-0.01em}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.wrap{max-width:1240px;margin:0 auto;padding:0 32px}
.eyebrow{
  font-family:var(--body);font-weight:500;font-size:.74rem;letter-spacing:.28em;
  text-transform:uppercase;color:var(--gold-deep);display:inline-block;
}
/* ============ TOP BAR ============ */
.topbar{
  background:var(--navy);color:var(--ivory);font-size:.82rem;font-weight:300;
  letter-spacing:.02em;
}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:42px;gap:24px}
.topbar a{color:var(--ivory);opacity:.85;transition:opacity .25s}
.topbar a:hover{opacity:1;color:var(--gold-light)}
.topbar .tb-right{display:flex;gap:26px;align-items:center}
.topbar .tb-left span{color:var(--gold-light)}
@media(max-width:980px){
  .topbar .tb-left{display:none}
  .topbar .wrap{justify-content:center;gap:18px;height:auto;padding-top:8px;padding-bottom:8px}
  .topbar .tb-right{gap:18px;flex-wrap:wrap;justify-content:center}
  .topbar a{white-space:nowrap;font-size:.8rem}
}
/* ============ NAV ============ */
header.nav{
  position:sticky;top:0;z-index:100;background:rgba(247,243,233,.88);
  backdrop-filter:blur(14px);border-bottom:1px solid var(--line);
}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:78px}
.logo{display:flex;align-items:center;gap:13px}
.logo .mark{
  width:42px;height:42px;border:1.5px solid var(--navy);border-radius:50%;
  display:grid;place-items:center;position:relative;flex-shrink:0;
}
.logo .mark::after{
  content:"";position:absolute;inset:6px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,var(--gold-light),var(--gold-deep));
}
.logo .txt{font-family:var(--display);font-size:1.35rem;font-weight:600;color:var(--navy);letter-spacing:-.02em}
.logo .txt small{display:block;font-family:var(--body);font-size:.6rem;font-weight:500;
  letter-spacing:.32em;color:var(--gold-deep);text-transform:uppercase;margin-top:1px}
.logo-img{height:52px;width:auto;max-width:230px;display:block;object-fit:contain}
.logo-img-foot{height:54px;max-width:240px}
nav ul{display:flex;list-style:none;gap:38px;align-items:center}
nav a{font-size:.92rem;font-weight:400;color:var(--navy);position:relative;padding:6px 0;transition:color .25s}
nav a:hover{color:var(--gold-deep)}
nav a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1.5px;background:var(--gold);transition:width .3s}
nav a:hover::after{width:100%}
.has-drop{position:relative}
.drop{
  position:absolute;top:140%;left:50%;transform:translateX(-50%) translateY(8px);
  background:var(--ivory-soft);border:1px solid var(--line);border-radius:14px;
  padding:10px;min-width:280px;opacity:0;visibility:hidden;transition:.3s;
  box-shadow:0 24px 60px rgba(6,21,54,.16);
}
.has-drop:hover .drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.drop a{display:block;padding:12px 16px;border-radius:9px;font-size:.9rem;transition:.2s}
.drop a:hover{background:var(--ivory-deep);color:var(--navy)}
.drop a::after{display:none}
.drop a span{display:block;font-size:.74rem;color:var(--muted);margin-top:2px;font-weight:300}
.btn{
  font-family:var(--body);font-weight:500;font-size:.88rem;letter-spacing:.02em;
  padding:13px 28px;border-radius:40px;display:inline-block;transition:.3s;cursor:pointer;border:none;
}
.btn-gold{background:var(--gold);color:var(--navy)}
.btn-gold:hover{background:var(--gold-deep);color:var(--ivory);transform:translateY(-2px)}
.btn-navy{background:var(--navy);color:var(--ivory)}
.btn-navy:hover{background:var(--navy-soft);transform:translateY(-2px)}
.btn-ghost{background:transparent;border:1.5px solid var(--navy);color:var(--navy)}
.btn-ghost:hover{background:var(--navy);color:var(--ivory)}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:8px}
.burger span{width:26px;height:2px;background:var(--navy);transition:.3s}
@media(max-width:980px){
  nav ul{position:fixed;top:120px;right:24px;left:24px;flex-direction:column;gap:6px;
    background:var(--ivory-soft);border:1px solid var(--line);border-radius:18px;padding:18px;
    align-items:stretch;box-shadow:0 30px 70px rgba(6,21,54,.2);
    transform:translateY(-12px);opacity:0;visibility:hidden;transition:.3s;
    max-height:calc(100vh - 140px);overflow-y:auto}
  nav ul.open{transform:translateY(0);opacity:1;visibility:visible}
  nav a{padding:11px 8px}
  /* collapsible Services submenu on mobile */
  .has-drop > a{display:flex;justify-content:space-between;align-items:center}
  .drop{position:static;transform:none;box-shadow:none;border:none;background:transparent;
    padding:0 0 0 14px;min-width:0;margin-top:0;
    max-height:0;overflow:hidden;opacity:1;visibility:visible;transition:max-height .35s ease}
  .has-drop.open-sub .drop{max-height:520px}
  .has-drop:hover .drop{transform:none}
  .nav-cta{display:none}
  .burger{display:flex}
}
/* ============ HERO ============ */
.hero{position:relative;overflow:hidden;background:var(--navy);color:var(--ivory)}
.hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 50% at 80% 20%,rgba(201,162,75,.18),transparent 60%),
    radial-gradient(ellipse 50% 60% at 10% 90%,rgba(201,162,75,.08),transparent 60%);
}
.hero-grid{position:absolute;inset:0;opacity:.05;
  background-image:linear-gradient(var(--ivory) 1px,transparent 1px),linear-gradient(90deg,var(--ivory) 1px,transparent 1px);
  background-size:62px 62px;mask-image:radial-gradient(ellipse 70% 80% at 70% 30%,#000,transparent)}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center;
  min-height:660px;padding-top:70px;padding-bottom:70px}
.hero-eyebrow{color:var(--gold-light);letter-spacing:.28em}
.hero h1{font-size:clamp(2.6rem,5.2vw,4.3rem);font-weight:500;margin:22px 0 26px;color:var(--ivory)}
.hero h1 em{font-style:italic;color:var(--gold-light);font-weight:400}
.hero p.lead{font-size:1.13rem;font-weight:300;max-width:540px;color:rgba(247,243,233,.82);margin-bottom:38px}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}
.hero-stats{display:flex;gap:38px;margin-top:54px;flex-wrap:wrap}
.hero-stats .st .n{font-family:var(--display);font-size:2.1rem;color:var(--gold-light);font-weight:600}
.hero-stats .st .l{font-size:.82rem;color:rgba(247,243,233,.7);letter-spacing:.04em}
.hero-visual{position:relative}
.hero-card{
  background:linear-gradient(160deg,rgba(247,243,233,.07),rgba(247,243,233,.02));
  border:1px solid rgba(201,162,75,.3);border-radius:22px;padding:34px;
  backdrop-filter:blur(8px);position:relative;
}
.hero-card h3{color:var(--ivory);font-size:1.35rem;margin-bottom:8px}
.hero-card .sub{color:var(--gold-light);font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:24px}
.hero-card ul{list-style:none;display:grid;gap:14px}
.hero-card li{display:flex;gap:13px;align-items:flex-start;font-size:.96rem;color:rgba(247,243,233,.88);font-weight:300}
.hero-card li .dot{width:22px;height:22px;border-radius:50%;background:rgba(201,162,75,.18);
  display:grid;place-items:center;flex-shrink:0;margin-top:2px}
.hero-card li .dot::after{content:"";width:7px;height:7px;border-radius:50%;background:var(--gold-light)}
.hero-card .badge{position:absolute;top:-16px;right:26px;background:var(--gold);color:var(--navy);
  font-size:.72rem;font-weight:600;letter-spacing:.1em;padding:7px 16px;border-radius:30px;text-transform:uppercase}
@media(max-width:980px){.hero .wrap{grid-template-columns:1fr;gap:44px;min-height:auto}.hero-visual{max-width:480px}}
/* ============ MARQUEE / SECTORS ============ */
.sectors{background:var(--ivory-deep);border-bottom:1px solid var(--line);padding:26px 0;overflow:hidden}
.sectors-inner{display:flex;align-items:center;gap:14px}
.sectors-label{font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);white-space:nowrap;flex-shrink:0}
.marquee{overflow:hidden;flex:1;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:flex;gap:46px;width:max-content;animation:scroll 32s linear infinite}
.marquee-track span{font-family:var(--display);font-size:1.05rem;color:var(--navy);opacity:.55;white-space:nowrap;font-weight:500}
.marquee-track span::before{content:"◆";color:var(--gold);margin-right:46px;font-size:.6rem;vertical-align:middle}
@keyframes scroll{to{transform:translateX(-50%)}}
/* ============ SECTION BASE ============ */
section.block{padding:104px 0}
.sec-head{max-width:680px;margin-bottom:60px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-size:clamp(2rem,3.6vw,2.95rem);color:var(--navy);margin:16px 0 18px}
.sec-head p{color:var(--muted);font-size:1.06rem;font-weight:300}
/* ============ ABOUT ============ */
.about-grid{display:grid;grid-template-columns:0.85fr 1.1fr 1fr;gap:48px;align-items:center}
.about-photo{position:relative}
.about-photo .ap-img{border-radius:20px;overflow:hidden;aspect-ratio:3/4;box-shadow:0 30px 60px rgba(6,21,54,.18);position:relative;background:var(--navy)}
.about-photo .ap-img img{width:100%;height:100%;object-fit:cover}
.about-photo .ap-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(6,21,54,.35))}
.about-photo .ap-badge{position:absolute;bottom:-22px;right:-16px;background:var(--gold);color:var(--navy);padding:16px 22px;border-radius:14px;box-shadow:0 16px 36px rgba(6,21,54,.2)}
.about-photo .ap-badge .n{font-family:var(--display);font-size:1.6rem;font-weight:700;line-height:1}
.about-photo .ap-badge .l{font-size:.72rem;font-weight:500}
.about-text p{color:var(--muted);margin-bottom:18px;font-size:1.04rem}
.about-text p strong{color:var(--navy);font-weight:500}
.mission{background:var(--navy);color:var(--ivory);border-radius:22px;padding:42px;position:relative;overflow:hidden}
.mission::before{content:"";position:absolute;top:-40px;right:-40px;width:180px;height:180px;
  border-radius:50%;background:radial-gradient(circle,rgba(201,162,75,.2),transparent 70%)}
.mission .eyebrow{color:var(--gold-light)}
.mission h3{color:var(--ivory);font-size:1.6rem;margin:14px 0 26px;position:relative}
.mission ul{list-style:none;display:grid;gap:18px;position:relative}
.mission li{display:flex;gap:15px;align-items:flex-start;font-weight:300;color:rgba(247,243,233,.88)}
.mission li .num{font-family:var(--display);color:var(--gold-light);font-weight:600;font-size:1.05rem;flex-shrink:0}
@media(max-width:1040px){.about-grid{grid-template-columns:1fr 1fr;gap:40px}.about-photo{grid-column:1 / -1;max-width:420px}.about-photo .ap-img{aspect-ratio:16/9}}
@media(max-width:760px){.about-grid{grid-template-columns:1fr;gap:44px}.about-photo{max-width:none}}
/* ============ SERVICES ============ */
.services{background:var(--ivory-soft)}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.svc-card{
  background:var(--ivory);border:1px solid var(--line);border-radius:20px;padding:40px 34px;
  position:relative;overflow:hidden;transition:.4s;display:flex;flex-direction:column;
}
.svc-card::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;
  background:linear-gradient(90deg,var(--gold),var(--gold-deep));transform:scaleX(0);transform-origin:left;transition:transform .4s}
.svc-card:hover{transform:translateY(-8px);box-shadow:0 30px 60px rgba(6,21,54,.13);border-color:transparent}
.svc-card:hover::before{transform:scaleX(1)}
.svc-icon{width:60px;height:60px;border-radius:16px;background:var(--navy);display:grid;place-items:center;margin-bottom:26px;transition:.4s}
.svc-card:hover .svc-icon{background:var(--gold)}
.svc-icon svg{width:28px;height:28px;stroke:var(--gold-light);transition:.4s}
.svc-card:hover .svc-icon svg{stroke:var(--navy)}
.svc-card h3{font-size:1.4rem;color:var(--navy);margin-bottom:14px}
.svc-card p{color:var(--muted);font-size:.97rem;margin-bottom:22px;flex:1}
.svc-card .tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:26px}
.svc-card .tags span{font-size:.74rem;background:var(--ivory-deep);color:var(--navy-soft);padding:5px 12px;border-radius:20px;font-weight:400}
.svc-link{font-weight:500;color:var(--gold-deep);font-size:.92rem;display:inline-flex;align-items:center;gap:8px;transition:gap .3s}
.svc-link:hover{gap:14px}
.svc-link svg{width:16px;height:16px;stroke:var(--gold-deep)}
@media(max-width:980px){.svc-grid{grid-template-columns:1fr;max-width:480px;margin:0 auto}}
/* ============ WHY / FEATURES ============ */
.why{background:var(--navy);color:var(--ivory);position:relative;overflow:hidden}
.why::before{content:"";position:absolute;inset:0;opacity:.04;
  background-image:linear-gradient(var(--ivory) 1px,transparent 1px),linear-gradient(90deg,var(--ivory) 1px,transparent 1px);
  background-size:54px 54px}
.why .wrap{position:relative}
.why .sec-head h2{color:var(--ivory)}
.why .sec-head .eyebrow{color:var(--gold-light)}
.why .sec-head p{color:rgba(247,243,233,.72)}
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.why-card{border:1px solid rgba(201,162,75,.22);border-radius:18px;padding:36px;
  background:linear-gradient(160deg,rgba(247,243,233,.04),transparent);transition:.4s}
.why-card:hover{background:linear-gradient(160deg,rgba(201,162,75,.1),transparent);border-color:rgba(201,162,75,.45)}
.why-card .wn{font-family:var(--display);font-size:1.1rem;color:var(--gold-light);font-weight:600;margin-bottom:18px;
  display:flex;align-items:center;gap:12px}
.why-card .wn::before{content:"";width:34px;height:1px;background:var(--gold)}
.why-card h3{color:var(--ivory);font-size:1.3rem;margin-bottom:12px}
.why-card p{color:rgba(247,243,233,.72);font-weight:300;font-size:.97rem}
@media(max-width:780px){.why-grid{grid-template-columns:1fr}}
/* ============ STATS STRIP ============ */
.strip{background:var(--gold);color:var(--navy);padding:64px 0}
.strip-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.strip .n{font-family:var(--display);font-size:2.9rem;font-weight:700;line-height:1}
.strip .l{font-size:.92rem;font-weight:500;margin-top:8px;letter-spacing:.02em}
.strip .item{border-right:1px solid rgba(6,21,54,.15)}
.strip .item:last-child{border-right:none}
@media(max-width:780px){.strip-grid{grid-template-columns:repeat(2,1fr);gap:40px 20px}.strip .item:nth-child(2){border-right:none}}
/* ============ FAQ ============ */
.faq{background:var(--ivory-soft)}
.faq-wrap{display:grid;grid-template-columns:.85fr 1.15fr;gap:64px;align-items:start}
.acc-item{border-bottom:1px solid var(--line)}
.acc-q{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:26px 0;
  display:flex;justify-content:space-between;gap:20px;align-items:center;
  font-family:var(--display);font-size:1.18rem;font-weight:500;color:var(--navy)}
.acc-q .ic{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--gold);flex-shrink:0;
  position:relative;transition:.3s}
.acc-q .ic::before,.acc-q .ic::after{content:"";position:absolute;background:var(--gold-deep);
  top:50%;left:50%;transform:translate(-50%,-50%);transition:.3s}
.acc-q .ic::before{width:12px;height:2px}
.acc-q .ic::after{width:2px;height:12px}
.acc-item.open .acc-q .ic{background:var(--gold);border-color:var(--gold)}
.acc-item.open .acc-q .ic::before,.acc-item.open .acc-q .ic::after{background:var(--navy)}
.acc-item.open .acc-q .ic::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}
.acc-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.acc-a p{color:var(--muted);padding:0 0 26px;font-weight:300;font-size:1rem;max-width:90%}
@media(max-width:880px){.faq-wrap{grid-template-columns:1fr;gap:36px}}
/* ============ CTA / QUOTE ============ */
.quote{background:var(--navy);color:var(--ivory);position:relative;overflow:hidden}
.quote::before{content:"";position:absolute;top:-100px;right:-100px;width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(201,162,75,.16),transparent 65%)}
.quote-wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative}
.quote h2{font-size:clamp(2rem,3.6vw,2.9rem);color:var(--ivory);margin:16px 0 20px}
.quote h2 em{font-style:italic;color:var(--gold-light)}
.quote p.lead{color:rgba(247,243,233,.78);font-weight:300;font-size:1.08rem;margin-bottom:30px;max-width:460px}
.quote-contact{display:grid;gap:16px;margin-top:34px}
.quote-contact a{display:flex;align-items:center;gap:14px;color:rgba(247,243,233,.9);font-weight:300;transition:.25s}
.quote-contact a:hover{color:var(--gold-light)}
.quote-contact .ci{width:40px;height:40px;border-radius:10px;border:1px solid rgba(201,162,75,.3);
  display:grid;place-items:center;flex-shrink:0}
.quote-contact .ci svg{width:18px;height:18px;stroke:var(--gold-light)}
.qform{background:var(--ivory);border-radius:22px;padding:40px}
.qform h3{color:var(--navy);font-size:1.5rem;margin-bottom:6px}
.qform .fsub{color:var(--muted);font-size:.92rem;margin-bottom:26px;font-weight:300}
.qform .field{margin-bottom:16px}
.qform label{display:block;font-size:.8rem;color:var(--navy);font-weight:500;margin-bottom:7px;letter-spacing:.02em}
.qform input,.qform select,.qform textarea{
  width:100%;padding:13px 16px;border:1px solid var(--line);border-radius:11px;background:var(--ivory-soft);
  font-family:var(--body);font-size:.95rem;color:var(--ink);font-weight:300;transition:.25s}
.qform input:focus,.qform select:focus,.qform textarea:focus{outline:none;border-color:var(--gold);background:#fff}
.qform textarea{resize:vertical;min-height:90px}
.qform .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.qform button{width:100%;margin-top:8px;padding:15px}
@media(max-width:880px){.quote-wrap{grid-template-columns:1fr;gap:40px}.qform .row{grid-template-columns:1fr}}
/* ============ FOOTER ============ */
footer{background:#040f26;color:rgba(247,243,233,.7);padding:74px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:44px;margin-bottom:52px}
footer .logo .txt{color:var(--ivory)}
footer .fdesc{margin:22px 0 24px;font-weight:300;font-size:.95rem;max-width:300px}
footer h4{color:var(--ivory);font-family:var(--body);font-size:.82rem;letter-spacing:.18em;
  text-transform:uppercase;margin-bottom:22px;font-weight:600}
footer ul{list-style:none;display:grid;gap:13px}
footer ul a{font-weight:300;font-size:.95rem;transition:.25s}
footer ul a:hover{color:var(--gold-light);padding-left:5px}
.fcontact li{font-weight:300;font-size:.94rem;display:flex;gap:12px;align-items:flex-start;margin-bottom:14px}
.fcontact svg{width:17px;height:17px;stroke:var(--gold-light);flex-shrink:0;margin-top:4px}
.fsocial{display:flex;gap:12px;margin-top:8px}
.fsocial a{width:40px;height:40px;border:1px solid rgba(201,162,75,.3);border-radius:10px;
  display:grid;place-items:center;transition:.3s}
.fsocial a:hover{background:var(--gold);border-color:var(--gold)}
.fsocial a:hover svg{stroke:var(--navy)}
.fsocial svg{width:17px;height:17px;stroke:var(--gold-light)}
.foot-bottom{border-top:1px solid rgba(247,243,233,.1);padding-top:26px;display:flex;
  justify-content:space-between;gap:18px;flex-wrap:wrap;font-size:.86rem;font-weight:300}
.foot-bottom a:hover{color:var(--gold-light)}
@media(max-width:880px){.foot-grid{grid-template-columns:1fr 1fr;gap:36px}}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}}
/* reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s,transform .7s}
.reveal.in{opacity:1;transform:none}
/* low-opacity background image layers */
.bg-img{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.hero .bg-img{opacity:.55}
/* black-toned overlay sits between photo and content for readable text */
.hero::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(90deg,rgba(3,8,20,.92) 0%,rgba(3,8,20,.78) 42%,rgba(3,8,20,.45) 100%)}
.hero .wrap,.hero .hero-grid{position:relative;z-index:2}
.why .bg-img,.quote .bg-img,.cta-band .bg-img{opacity:15%}
.why .wrap,.quote .quote-wrap,.cta-band .wrap{position:relative;z-index:2}
.strip{position:relative;overflow:hidden}
.strip .bg-img{opacity:.09;mix-blend-mode:multiply}
.strip .wrap{position:relative;z-index:2}
/* service card photo */
.svc-card .card-img{height:170px;margin:-40px -34px 26px;overflow:hidden;position:relative;background:var(--navy)}
.svc-card .card-img img{width:100%;height:100%;object-fit:cover;opacity:.9;transition:.5s;transform:scale(1.02)}
.svc-card:hover .card-img img{transform:scale(1.08);opacity:1}
.svc-card .card-img::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(6,21,54,.1),rgba(6,21,54,.55))}

/* ---------- PAGE-SPECIFIC (service / about / blog / terms) ---------- */
.topbar{background:var(--navy);color:var(--ivory);font-size:.82rem;font-weight:300}
header.nav{position:sticky;top:0;z-index:100;background:rgba(247,243,233,.88);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
nav a.active{color:var(--gold-deep)}
nav a:hover::after,nav a.active::after{width:100%}
/* page hero */
.phero{background:var(--navy);color:var(--ivory);position:relative;overflow:hidden;padding:84px 0}
.phero::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 50% 60% at 85% 30%,rgba(201,162,75,.16),transparent 60%)}
.phero-grid{position:absolute;inset:0;opacity:.05;background-image:linear-gradient(var(--ivory) 1px,transparent 1px),linear-gradient(90deg,var(--ivory) 1px,transparent 1px);background-size:58px 58px;mask-image:radial-gradient(ellipse 70% 90% at 75% 40%,#000,transparent)}
.phero .wrap{position:relative}
.crumb{font-size:.85rem;color:rgba(247,243,233,.6);margin-bottom:22px}
.crumb a{color:var(--gold-light)}
.crumb a:hover{text-decoration:underline}
.phero h1{font-size:clamp(2.3rem,4.6vw,3.7rem);color:var(--ivory);margin-bottom:22px;max-width:760px}
.phero h1 em{font-style:italic;color:var(--gold-light);font-weight:400}
.phero p{font-size:1.1rem;color:rgba(247,243,233,.82);font-weight:300;max-width:680px}
/* sub nav */
.subnav{background:var(--ivory-deep);border-bottom:1px solid var(--line);position:sticky;top:78px;z-index:50}
.subnav .wrap{display:flex;gap:8px;overflow-x:auto;padding-top:14px;padding-bottom:14px}
.subnav a{white-space:nowrap;font-size:.88rem;font-weight:400;color:var(--navy);padding:9px 18px;border-radius:30px;transition:.25s;flex-shrink:0}
.subnav a:hover,.subnav a.on{background:var(--navy);color:var(--ivory)}
/* service blocks */
.svc{padding:88px 0;border-bottom:1px solid var(--line)}
.svc:nth-child(even){background:var(--ivory-soft)}
.svc-row{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.svc-row.flip .svc-media{order:2}
.svc-media{position:relative}
.svc-img{border-radius:20px;overflow:hidden;aspect-ratio:4/3;position:relative;box-shadow:0 30px 70px rgba(6,21,54,.18)}
.svc-img img{width:100%;height:100%;object-fit:cover}
.svc-img .ph{position:absolute;inset:0;background:linear-gradient(150deg,var(--navy),var(--navy-soft));display:grid;place-items:center}
.svc-img .ph svg{width:84px;height:84px;stroke:rgba(201,162,75,.5);stroke-width:1}
.svc-badge{position:absolute;bottom:-20px;left:-20px;background:var(--gold);color:var(--navy);padding:18px 26px;border-radius:16px;box-shadow:0 16px 40px rgba(6,21,54,.2)}
.svc-badge .bn{font-family:var(--display);font-size:1.7rem;font-weight:700;line-height:1}
.svc-badge .bl{font-size:.74rem;font-weight:500;letter-spacing:.04em}
.svc-num{font-family:var(--display);font-size:.95rem;color:var(--gold-deep);font-weight:600;letter-spacing:.05em;margin-bottom:14px;display:flex;align-items:center;gap:12px}
.svc-num::before{content:"";width:36px;height:1px;background:var(--gold)}
.svc h2{font-size:clamp(1.7rem,3vw,2.4rem);color:var(--navy);margin-bottom:18px}
.svc-body p{color:var(--muted);font-size:1.04rem;margin-bottom:18px}
.svc-body p strong{color:var(--navy);font-weight:500}
.svc-list{list-style:none;display:grid;gap:14px;margin:24px 0 30px}
.svc-list li{display:flex;gap:13px;align-items:flex-start;color:var(--ink);font-weight:300;font-size:.99rem;line-height:1.55}
.svc-list li .ck{width:22px;height:22px;border-radius:6px;background:var(--navy);display:grid;place-items:center;flex-shrink:0;margin-top:3px}
.svc-list li .ck svg{width:13px;height:13px;stroke:var(--gold-light);stroke-width:2.5}
.svc-list li > span:not(.ck){flex:1;min-width:0}
.svc-list li strong{color:var(--navy);font-weight:600}
.svc:nth-child(even) .svc-list li .ck{background:var(--gold)}
.svc:nth-child(even) .svc-list li .ck svg{stroke:var(--navy)}
.sublist{list-style:none;display:grid;gap:10px;margin:14px 0 22px}
.sublist li{padding-left:20px;position:relative;color:var(--muted);font-weight:300;font-size:.97rem}
.sublist li::before{content:"";position:absolute;left:0;top:11px;width:7px;height:7px;border-radius:50%;background:var(--gold)}
.svc-sub-h{font-family:var(--display);font-size:1.15rem;color:var(--navy);font-weight:600;margin:24px 0 8px}
/* cta band */
.cta-band{background:var(--navy);color:var(--ivory);padding:84px 0;position:relative;overflow:hidden;text-align:center}
.cta-band::before{content:"";position:absolute;top:-120px;left:50%;transform:translateX(-50%);width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(201,162,75,.14),transparent 65%)}
.cta-band .wrap{position:relative}
.cta-band h2{font-size:clamp(1.9rem,3.4vw,2.8rem);color:var(--ivory);margin:16px 0 20px}
.cta-band h2 em{font-style:italic;color:var(--gold-light)}
.cta-band p{color:rgba(247,243,233,.78);font-weight:300;max-width:560px;margin:0 auto 32px;font-size:1.08rem}
.cta-band .row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
footer{background:#040f26;color:rgba(247,243,233,.7);padding:74px 0 30px}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s,transform .7s}
.phero .bg-img{opacity:.16;mix-blend-mode:luminosity;mask-image:linear-gradient(90deg,#000 40%,transparent 95%)}
.phero .wrap,.phero .phero-grid{position:relative;z-index:2}
.cta-band .bg-img{opacity:.07}
.cta-band .wrap{position:relative;z-index:2}
/* real service-row images replace the placeholder panels */
.svc-img img{width:100%;height:100%;object-fit:cover}
.svc-img::after{content:"";position:absolute;inset:0;background:linear-gradient(160deg,rgba(6,21,54,.18),rgba(6,21,54,.42));z-index:1;pointer-events:none}
.svc-img .ph{z-index:0}
.about-hero{background:var(--navy);color:var(--ivory);position:relative;overflow:hidden;padding:96px 0 90px}
.about-hero .bg-img{opacity:.18;mix-blend-mode:luminosity;mask-image:linear-gradient(120deg,#000 35%,transparent 92%)}
.about-hero-grid{position:absolute;inset:0;opacity:.05;background-image:linear-gradient(var(--ivory) 1px,transparent 1px),linear-gradient(90deg,var(--ivory) 1px,transparent 1px);background-size:58px 58px;mask-image:radial-gradient(ellipse 70% 90% at 75% 40%,#000,transparent)}
.about-hero .wrap{position:relative;z-index:2;max-width:860px}
.about-hero .crumb{font-size:.85rem;color:rgba(247,243,233,.6);margin-bottom:22px}
.about-hero .crumb a{color:var(--gold-light)}
.about-hero h1{font-size:clamp(2.4rem,5vw,4rem);color:var(--ivory);margin-bottom:22px}
.about-hero h1 em{font-style:italic;color:var(--gold-light);font-weight:400}
.about-hero p{font-size:1.15rem;color:rgba(247,243,233,.84);font-weight:300;max-width:680px}
/* intro split */
.intro{padding:96px 0;border-bottom:1px solid var(--line)}
.intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.intro-imgs{position:relative}
.intro-imgs .big{border-radius:20px;overflow:hidden;aspect-ratio:4/5;box-shadow:0 30px 70px rgba(6,21,54,.2)}
.intro-imgs .big img{width:100%;height:100%;object-fit:cover}
.intro-imgs .small{position:absolute;bottom:-34px;right:-24px;width:54%;border-radius:16px;overflow:hidden;aspect-ratio:4/3;border:6px solid var(--ivory);box-shadow:0 24px 50px rgba(6,21,54,.22)}
.intro-imgs .small img{width:100%;height:100%;object-fit:cover}
.intro-imgs .exp{position:absolute;top:-26px;left:-22px;background:var(--gold);color:var(--navy);padding:20px 26px;border-radius:16px;box-shadow:0 18px 40px rgba(6,21,54,.2)}
.intro-imgs .exp .n{font-family:var(--display);font-size:2rem;font-weight:700;line-height:1}
.intro-imgs .exp .l{font-size:.76rem;font-weight:500}
.intro-body h2{font-size:clamp(1.9rem,3.4vw,2.7rem);color:var(--navy);margin:16px 0 22px}
.intro-body p{color:var(--muted);margin-bottom:18px;font-size:1.05rem}
.intro-body p strong{color:var(--navy);font-weight:500}
/* values */
.values{background:var(--ivory-soft);padding:96px 0;border-bottom:1px solid var(--line)}
.val-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:54px}
.val-card{background:var(--ivory);border:1px solid var(--line);border-radius:18px;padding:36px 30px;transition:.4s}
.val-card:hover{transform:translateY(-6px);box-shadow:0 26px 54px rgba(6,21,54,.12)}
.val-ic{width:56px;height:56px;border-radius:14px;background:var(--navy);display:grid;place-items:center;margin-bottom:22px}
.val-ic svg{width:26px;height:26px;stroke:var(--gold-light)}
.val-card h3{color:var(--navy);font-size:1.25rem;margin-bottom:10px}
.val-card p{color:var(--muted);font-size:.96rem}
/* mission band with image */
.mband{position:relative;overflow:hidden;background:var(--navy);color:var(--ivory);padding:96px 0}
.mband .bg-img{opacity:.12}
.mband .wrap{position:relative;z-index:2}
.mband-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px}
.mband .eyebrow{color:var(--gold-light)}
.mband h2{color:var(--ivory);font-size:clamp(1.8rem,3.2vw,2.5rem);margin:14px 0 18px}
.mband p{color:rgba(247,243,233,.78);font-weight:300;font-size:1.05rem}
.mlist{list-style:none;display:grid;gap:20px}
.mlist li{display:flex;gap:16px;align-items:flex-start}
.mlist li .num{font-family:var(--display);color:var(--gold-light);font-weight:600;font-size:1.15rem;flex-shrink:0}
.mlist li h4{color:var(--ivory);font-family:var(--display);font-size:1.1rem;margin-bottom:4px}
.mlist li p{font-size:.96rem;margin:0}
/* sectors */
.sect{padding:90px 0;text-align:center}
.sect .chips{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;max-width:880px;margin:44px auto 0}
.sect .chips span{background:var(--ivory-deep);color:var(--navy);padding:11px 22px;border-radius:30px;font-size:.95rem;font-weight:400;border:1px solid var(--line);transition:.3s}
.sect .chips span:hover{background:var(--navy);color:var(--ivory)}
.blog-hero{background:var(--navy);color:var(--ivory);position:relative;overflow:hidden;padding:88px 0 80px}
.blog-hero .bg-img{opacity:.16;mix-blend-mode:luminosity;mask-image:linear-gradient(120deg,#000 35%,transparent 92%)}
.blog-hero-grid{position:absolute;inset:0;opacity:.05;background-image:linear-gradient(var(--ivory) 1px,transparent 1px),linear-gradient(90deg,var(--ivory) 1px,transparent 1px);background-size:58px 58px;mask-image:radial-gradient(ellipse 70% 90% at 75% 40%,#000,transparent)}
.blog-hero .wrap{position:relative;z-index:2;max-width:820px}
.blog-hero .crumb{font-size:.85rem;color:rgba(247,243,233,.6);margin-bottom:22px}
.blog-hero .crumb a{color:var(--gold-light)}
.blog-hero h1{font-size:clamp(2.3rem,4.6vw,3.6rem);color:var(--ivory);margin-bottom:18px}
.blog-hero h1 em{font-style:italic;color:var(--gold-light);font-weight:400}
.blog-hero p{font-size:1.12rem;color:rgba(247,243,233,.82);font-weight:300;max-width:620px}
/* filter chips */
.bfilter{background:var(--ivory-deep);border-bottom:1px solid var(--line);position:sticky;top:78px;z-index:50}
.bfilter .wrap{display:flex;gap:8px;overflow-x:auto;padding-top:14px;padding-bottom:14px}
.bfilter button{white-space:nowrap;font-family:var(--body);font-size:.88rem;font-weight:400;color:var(--navy);padding:9px 18px;border-radius:30px;border:1px solid transparent;background:transparent;cursor:pointer;transition:.25s;flex-shrink:0}
.bfilter button:hover{background:var(--ivory)}
.bfilter button.on{background:var(--navy);color:var(--ivory)}
/* featured */
.feat{padding:84px 0 30px}
.feat-card{display:grid;grid-template-columns:1.1fr .9fr;gap:0;border-radius:22px;overflow:hidden;border:1px solid var(--line);background:var(--ivory-soft);box-shadow:0 30px 70px rgba(6,21,54,.1)}
.feat-img{position:relative;min-height:340px;background:var(--navy)}
.feat-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.feat-tag{position:absolute;top:20px;left:20px;z-index:2;background:var(--gold);color:var(--navy);font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:7px 15px;border-radius:30px}
.feat-body{padding:48px 44px;display:flex;flex-direction:column;justify-content:center}
.feat-meta{font-size:.82rem;color:var(--gold-deep);font-weight:500;letter-spacing:.04em;margin-bottom:16px}
.feat-body h2{font-size:clamp(1.6rem,2.6vw,2.2rem);color:var(--navy);margin-bottom:16px;line-height:1.18}
.feat-body p{color:var(--muted);font-size:1.02rem;margin-bottom:26px}
.read{font-weight:500;color:var(--gold-deep);display:inline-flex;align-items:center;gap:9px;transition:gap .3s}
.read:hover{gap:15px}
.read svg{width:17px;height:17px;stroke:var(--gold-deep)}
/* grid */
.posts{padding:50px 0 100px}
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.post{background:var(--ivory-soft);border:1px solid var(--line);border-radius:18px;overflow:hidden;display:flex;flex-direction:column;transition:.4s;cursor:pointer}
.post:hover{transform:translateY(-8px);box-shadow:0 28px 56px rgba(6,21,54,.13);border-color:transparent}
.post-img{height:200px;position:relative;background:var(--navy);overflow:hidden}
.post-img img{width:100%;height:100%;object-fit:cover;transition:.5s}
.post:hover .post-img img{transform:scale(1.07)}
.post-cat{position:absolute;top:14px;left:14px;background:rgba(6,21,54,.82);color:var(--gold-light);font-size:.68rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;padding:6px 13px;border-radius:30px;backdrop-filter:blur(4px)}
.post-body{padding:26px 24px 28px;display:flex;flex-direction:column;flex:1}
.post-meta{font-size:.78rem;color:var(--muted);margin-bottom:12px;letter-spacing:.02em}
.post-body h3{font-size:1.2rem;color:var(--navy);margin-bottom:10px;line-height:1.25}
.post-body p{color:var(--muted);font-size:.93rem;margin-bottom:18px;flex:1}
.post-body .read{font-size:.88rem}
.post.hide{display:none}
@media(max-width:640px){.post-grid{grid-template-columns:1fr}}
/* newsletter */
.news{background:var(--navy);color:var(--ivory);position:relative;overflow:hidden;padding:80px 0}
.news .bg-img{opacity:.08}
.news .wrap{position:relative;z-index:2;text-align:center;max-width:640px}
.news h2{color:var(--ivory);font-size:clamp(1.8rem,3.2vw,2.5rem);margin:14px 0 14px}
.news h2 em{font-style:italic;color:var(--gold-light)}
.news p{color:rgba(247,243,233,.78);font-weight:300;margin-bottom:30px}
.news-form{display:flex;gap:12px;max-width:480px;margin:0 auto;flex-wrap:wrap}
.news-form input{flex:1;min-width:220px;padding:15px 20px;border-radius:40px;border:1px solid rgba(201,162,75,.35);background:rgba(247,243,233,.06);color:var(--ivory);font-family:var(--body);font-size:.95rem}
.news-form input::placeholder{color:rgba(247,243,233,.5)}
.news-form input:focus{outline:none;border-color:var(--gold)}