:root{
  --paper:#F7F3EC;
  --paper-2:#EFE8DA;
  --ink:#23211D;
  --ink-soft:#5A554C;
  --river:#1C5C86;
  --river-deep:#143C56;
  --sun:#E0742B;
  --sand:#D8C7A8;
  --rule:#d8cdb6;
  --max:1480px;
  --shadow:0 18px 40px -22px rgba(20,60,86,.45);
  --shadow-card:0 12px 28px -18px rgba(35,33,29,.4);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:'Inter',system-ui,sans-serif;
  color:var(--ink);
  background-color:var(--paper);
  background-image:
    radial-gradient(rgba(35,33,29,.022) 1px, transparent 1px),
    radial-gradient(rgba(35,33,29,.018) 1px, transparent 1px);
  background-size:22px 22px, 18px 18px;
  background-position:0 0, 9px 9px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3{font-family:'Saira Condensed','Inter',sans-serif;font-weight:700;line-height:1.02;margin:0;letter-spacing:.01em;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
[id]{scroll-margin-top:88px;}

.wrap{max-width:var(--max);margin:0 auto;padding:0 clamp(22px,4vw,56px);}
.wrap.bleed{max-width:none;}
.mono{font-family:'IBM Plex Mono',monospace;}
.accent{color:var(--sun);}
.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:'Saira Condensed',sans-serif;
  font-weight:600;
  font-size:16px;
  letter-spacing:.04em;
  text-transform:uppercase;
  padding:14px 24px;
  border-radius:3px;
  border:2px solid transparent;
  cursor:pointer;
  transition:.18s ease;
}
.btn-primary{background:var(--sun);color:#fff;box-shadow:0 10px 22px -12px rgba(224,116,43,.8);}
.btn-primary:hover{background:#c9621f;transform:translateY(-2px);}

header.nav{position:fixed;top:0;left:0;right:0;z-index:50;}
header.nav::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:140px;
  pointer-events:none;
  z-index:-1;
  background:linear-gradient(180deg,rgba(11,31,58,.92),rgba(11,31,58,0));
  opacity:0;
  transition:opacity .35s ease;
}
header.nav.scrolled::before{opacity:1;}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:84px;}
.brand{display:flex;align-items:center;flex:0 0 auto;}
.brand-logo{height:58px;width:auto;max-width:230px;object-fit:contain;transition:transform .2s ease;}
.brand:hover .brand-logo{transform:translateY(-1px);}
.nav-right{display:flex;align-items:center;gap:34px;}
nav.links{display:flex;align-items:center;gap:34px;}
nav.links a{
  position:relative;
  font-size:18px;
  font-weight:500;
  color:#fff;
  letter-spacing:.01em;
  padding:6px 1px;
  transition:color .2s ease;
}
nav.links a::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-3px;
  height:2px;
  background:var(--sun);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .25s ease;
}
nav.links a:hover::after,nav.links a.active::after{transform:scaleX(1);}
.menu-btn{display:none;background:none;border:0;cursor:pointer;color:#fff;padding:4px;line-height:0;}

.hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  color:var(--paper);
  overflow:hidden;
  background:var(--river-deep);
}
.hero-media{position:absolute;inset:0;z-index:0;}
.hero-media video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 1.2s ease;}
.hero-media video.ready{opacity:1;}
.hero-scrim{
  position:absolute;
  inset:0;
  z-index:1;
  background:linear-gradient(100deg, rgba(20,60,86,.84) 0%, rgba(20,60,86,.5) 40%, rgba(20,60,86,.1) 70%, rgba(224,116,43,.08) 100%);
}
.hero-scrim.bottom{background:linear-gradient(to top, var(--river-deep) 0%, rgba(20,60,86,0) 50%);}
.hero .wrap{position:relative;z-index:2;width:100%;padding-top:120px;padding-bottom:100px;}
.hero h1{font-size:clamp(46px,8vw,108px);font-weight:800;text-transform:uppercase;margin:18px 0 6px;max-width:16ch;letter-spacing:.004em;}
.hero p.lede{font-size:clamp(17px,1.6vw,22px);max-width:54ch;color:#f2ece1;font-weight:400;margin:20px 0 32px;line-height:1.55;}
.video-toggle{
  position:absolute;
  right:clamp(20px,4vw,40px);
  bottom:24px;
  z-index:3;
  width:44px;
  height:44px;
  border-radius:50%;
  border:1.5px solid rgba(255,255,255,.5);
  background:rgba(16,34,48,.34);
  backdrop-filter:blur(4px);
  color:#fff;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:background .18s ease,border-color .18s ease,transform .18s ease;
}
.video-toggle:hover{background:rgba(16,34,48,.62);border-color:#fff;transform:translateY(-1px);}
.video-toggle svg{width:15px;height:15px;}
.video-toggle .ic-play{display:none;}
.video-toggle.paused .ic-pause{display:none;}
.video-toggle.paused .ic-play{display:block;}

section{position:relative;}
.pad{padding:88px 0;}
.pad>.wrap{position:relative;z-index:1;}
.sec-head{max-width:680px;margin-bottom:44px;}
.sec-head h2{font-size:clamp(32px,4.4vw,52px);text-transform:uppercase;margin:14px 0 0;}
.sec-head p{color:var(--ink-soft);font-size:17px;margin-top:16px;}

#services{background:var(--river-deep);color:var(--paper);}
#services .sec-head h2{color:#fff;}
#services .sec-head p{color:#c4d4df;}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.card{
  background:#fffdf8;
  border:1px solid var(--rule);
  border-radius:6px;
  padding:28px 26px 26px;
  position:relative;
  transition:.2s ease;
  box-shadow:var(--shadow-card);
  overflow:hidden;
  color:var(--ink);
}
.card::before{content:"";position:absolute;left:0;top:0;height:4px;width:0;background:var(--sun);transition:width .25s ease;}
.card:hover{transform:translateY(-4px);border-color:var(--sand);}
.card:hover::before{width:100%;}
.card .ic{width:82px;height:82px;color:var(--river);margin-bottom:10px;}
.card h3{font-size:24px;text-transform:uppercase;margin:6px 0 10px;line-height:1.02;color:var(--ink);}
.card p{font-size:14.5px;color:var(--ink-soft);margin:0;}

#about{background:var(--river-deep);color:var(--paper);}
#about h2{color:#fff;}
#about p{color:#c4d4df;font-size:15.5px;}
.about-split{display:grid;grid-template-columns:.85fr 1.15fr;gap:54px;align-items:center;}
.portrait{position:relative;border:1px solid var(--rule);background:#fffdf8;padding:12px;border-radius:6px;box-shadow:var(--shadow);}
#about .portrait img{height:auto;aspect-ratio:1500/1126;object-fit:cover;object-position:center;border-radius:3px;width:100%;}

.info{background:var(--river-deep);color:var(--paper);padding:clamp(46px,6vw,74px) 0;}
.info-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:56px;align-items:start;}
.info-lead h2{font-size:clamp(34px,5vw,62px);text-transform:uppercase;margin:14px 0 0;line-height:1;}
.info-lead p{color:#c8d6df;font-size:16px;max-width:50ch;margin:20px 0 26px;}
.info-meta{font-size:14px;line-height:1.7;color:#9fb3bf;margin-bottom:22px;}

.hp-field{position:absolute !important;left:-9999px;top:-9999px;height:0;width:0;opacity:0;pointer-events:none;}
.contact-form{margin-top:26px;max-width:540px;}
#info .info-side .contact-form{margin-top:0;}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.cf-field{display:block;margin-bottom:14px;}
.cf-field span{display:block;font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#9fb3bf;margin-bottom:7px;}
.cf-field input,.cf-field textarea{
  width:100%;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(247,243,236,.18);
  border-radius:3px;
  color:#fff;
  font-family:'Inter',sans-serif;
  font-size:15px;
  line-height:1.5;
  padding:11px 13px;
  transition:border-color .18s ease, background .18s ease;
}
.cf-field input:focus,.cf-field textarea:focus{outline:none;border-color:var(--sun);background:rgba(255,255,255,.1);}
.cf-field textarea{resize:vertical;min-height:100px;}
.cf-turnstile{margin:4px 0 10px;}
.cf-actions{display:flex;align-items:center;gap:16px;margin-top:4px;flex-wrap:wrap;}
.cf-actions .btn[disabled]{opacity:.6;cursor:default;transform:none;}
.cf-status{font-size:14px;color:#9fb3bf;}
.cf-status.ok{color:#86d3a3;}
.cf-status.err{color:#e8956b;}

footer{background:#10222F;color:#b9c8d2;padding:26px 0;}
.foot-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:0;font-size:12.5px;color:#7f97a5;}
.foot-bottom .mono{letter-spacing:.04em;}

.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease;}
.reveal.in{opacity:1;transform:none;}

@media(max-width:900px){
  .svc-grid{grid-template-columns:1fr 1fr;}
}

@media(max-width:880px){
  .about-split{grid-template-columns:1fr;}
}

@media(max-width:860px){
  .menu-btn{display:block;}
  .brand-logo{height:50px;max-width:205px;}
  .nav-right{
    position:absolute;
    top:84px;
    left:0;
    right:0;
    flex-direction:column;
    align-items:stretch;
    gap:0;
    display:none;
    background:var(--river-deep);
    border-top:1px solid rgba(255,255,255,.12);
    box-shadow:0 18px 30px -20px rgba(0,0,0,.5);
    padding:6px clamp(22px,5vw,40px) 22px;
  }
  header.nav.open .nav-right{display:flex;}
  .nav-right .links{flex-direction:column;align-items:stretch;gap:0;width:100%;}
  .nav-right .links a{color:#fff;padding:15px 0;border-bottom:1px solid rgba(255,255,255,.12);font-size:18px;}
  .nav-right .links a::after{display:none;}
}

@media(max-width:820px){
  .info-grid{grid-template-columns:1fr;gap:34px;}
}

@media(max-width:600px){
  .svc-grid{grid-template-columns:1fr;}
}

@media(max-width:540px){
  .cf-row{grid-template-columns:1fr;}
}

@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  .reveal{opacity:1;transform:none;transition:none;}
}
