/* Cygnet Controls — shared stylesheet */
:root {
  --blue-50: #e6f1fb;
  --blue-100: #b5d4f4;
  --blue-200: #85b7eb;
  --blue-400: #378add;
  --blue-600: #185fa5;
  --blue-800: #0c447c;
  --blue-900: #042c53;
  --gray-50: #f7f6f2;
  --gray-100: #d3d1c7;
  --gray-400: #888780;
  --gray-600: #5f5e5a;
  --gray-800: #444441;
  --gray-900: #2c2c2a;
  --white: #ffffff;
  --nav-h: 88px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: 'Barlow', sans-serif; color: var(--gray-900); background: var(--white); overflow-x: hidden; }

/* ─── NAV ─────────────────────────────────────────────────────────────────── */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  height: var(--nav-h);
  background: var(--blue-900);
  border-bottom: 2px solid var(--blue-600);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 40px;
}
.nav-logo {
  display: flex; align-items: center; gap: 14px; text-decoration: none; flex-shrink: 0;
}

.nav-links {
  display: flex; align-items: stretch; height: var(--nav-h); gap: 2px;
}
.nav-link {
  display: flex; align-items: center; padding: 0 20px;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 13px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase;
  color: var(--blue-100); text-decoration: none; cursor: pointer;
  border-bottom: 3px solid transparent;
  transition: color .2s, border-color .2s;
  white-space: nowrap;
}
.nav-link:hover { color: #fff; border-bottom-color: var(--blue-400); }
.nav-link.active { color: #fff; border-bottom-color: var(--blue-400); }
.nav-cta {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 12px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  padding: 9px 20px; background: var(--blue-600); color: #fff;
  border: 1.5px solid var(--blue-400); text-decoration: none;
  transition: background .2s;
}
.nav-cta:hover { background: var(--blue-400); }

/* ─── HERO SLIDER ────────────────────────────────────────────────────────── */
.hero {
  margin-top: var(--nav-h);
  position: relative; height: 580px; overflow: hidden;
  background: var(--blue-900);
}
.slides { display: flex; height: 100%; transition: transform .7s cubic-bezier(.77,0,.18,1); }
.slide {
  min-width: 100%; height: 100%; position: relative;
  display: flex; align-items: flex-end;
}
.slide-bg {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
}
.slide-pattern {
  position: absolute; inset: 0; opacity: .04;
  background-image:
    linear-gradient(var(--blue-400) 1px, transparent 1px),
    linear-gradient(90deg, var(--blue-400) 1px, transparent 1px);
  background-size: 48px 48px;
}
.slide-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(4,44,83,.92) 0%, rgba(4,44,83,.55) 60%, rgba(4,44,83,.1) 100%);
}
.slide-illustration {
  position: absolute; right: 0; top: 0; bottom: 0; width: 55%;
  display: flex; align-items: center; justify-content: center;
}
.slide-icon-cluster {
  position: relative; width: 320px; height: 320px;
}
.sic-center {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  width: 120px; height: 120px; background: var(--blue-800);
  border: 2px solid var(--blue-600);
  display: flex; align-items: center; justify-content: center;
}
.sic-center i { font-size: 56px; color: var(--blue-200); }
.sic-orbit {
  position: absolute; border: 1px solid rgba(181,212,244,.2);
  border-radius: 50%;
}
.sic-dot {
  position: absolute; width: 8px; height: 8px;
  background: var(--blue-400); border-radius: 50%;
}
.sic-node {
  position: absolute; width: 60px; height: 60px;
  background: var(--blue-800); border: 1px solid var(--blue-600);
  display: flex; align-items: center; justify-content: center;
}
.sic-node i { font-size: 24px; color: var(--blue-400); }
.slide-content {
  position: relative; z-index: 2; padding: 0 64px 60px; max-width: 600px;
}
.slide-eyebrow {
  font-family: 'DM Mono', monospace; font-size: 10px; letter-spacing: .22em;
  text-transform: uppercase; color: var(--blue-400);
  display: flex; align-items: center; gap: 10px; margin-bottom: 14px;
}
.slide-eyebrow::before {
  content: ''; display: block; width: 28px; height: 1px; background: var(--blue-400);
}
.slide-title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 58px; font-weight: 800; letter-spacing: .02em; text-transform: uppercase;
  color: #f0ece4; line-height: .95; margin-bottom: 16px;
}
.slide-title em { color: var(--blue-200); font-style: normal; display: block; }
.slide-desc {
  font-size: 15px; color: var(--blue-100); font-weight: 300; line-height: 1.65;
  max-width: 420px; margin-bottom: 28px;
}
.slide-btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 12px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
  padding: 12px 24px; background: var(--blue-600); color: #fff;
  border: 1.5px solid var(--blue-400); text-decoration: none;
  transition: background .2s;
}
.slide-btn:hover { background: var(--blue-400); }
.slide-btn i { font-size: 16px; }

.hero-controls {
  position: absolute; bottom: 24px; right: 40px; z-index: 10;
  display: flex; align-items: center; gap: 8px;
}
.hero-dot {
  width: 6px; height: 6px; background: rgba(181,212,244,.35);
  cursor: pointer; transition: background .2s, width .3s;
  border: none; padding: 0;
}
.hero-dot.active { width: 24px; background: var(--blue-400); }
.hero-progress {
  position: absolute; bottom: 0; left: 0; right: 0; height: 3px; background: rgba(181,212,244,.15);
}
.hero-progress-bar {
  height: 100%; background: var(--blue-400);
  animation: progress 7s linear infinite;
}
@keyframes progress { from { width: 0 } to { width: 100% } }

.stripe { height: 4px; background: repeating-linear-gradient(90deg,#185fa5 0,#185fa5 20px,#b5d4f4 20px,#b5d4f4 40px); }

/* ─── WHO WE ARE ─────────────────────────────────────────────────────────── */
.who {
  display: grid; grid-template-columns: 1fr 1fr; align-items: stretch;
  min-height: 440px;
}
.who-content {
  padding: 72px 64px 72px 64px; background: var(--white);
  display: flex; flex-direction: column; justify-content: center;
}
.section-eyebrow {
  font-family: 'DM Mono', monospace; font-size: 10px; letter-spacing: .2em;
  text-transform: uppercase; color: var(--blue-600);
  display: flex; align-items: center; gap: 10px; margin-bottom: 18px;
}
.section-eyebrow::before {
  content: ''; display: block; width: 24px; height: 1px; background: var(--blue-600);
}
.section-title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 42px; font-weight: 800; letter-spacing: .03em; text-transform: uppercase;
  color: var(--blue-900); line-height: 1; margin-bottom: 20px;
}
.section-title span { color: var(--blue-600); }
.section-body {
  font-size: 15px; color: var(--gray-600); font-weight: 300; line-height: 1.75;
  margin-bottom: 18px;
}
.who-stats {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 1px;
  background: var(--gray-100); border: .5px solid var(--gray-100);
  margin-top: 32px;
}
.who-stat {
  background: var(--gray-50); padding: 18px 16px;
}
.who-stat-n {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 36px; font-weight: 800; color: var(--blue-800); line-height: 1;
}
.who-stat-l {
  font-size: 10px; letter-spacing: .15em; text-transform: uppercase;
  color: var(--gray-400); margin-top: 3px;
}
.who-visual {
  background: var(--blue-900); position: relative; overflow: hidden;
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 40px;
}
.who-grid-bg {
  position: absolute; inset: 0; opacity: .05;
  background-image:
    linear-gradient(var(--blue-400) 1px, transparent 1px),
    linear-gradient(90deg, var(--blue-400) 1px, transparent 1px);
  background-size: 32px 32px;
}
.who-values {
  position: relative; z-index: 2;
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
}
.who-val {
  background: rgba(12,68,124,.7); border: .5px solid rgba(181,212,244,.2);
  border-left: 2px solid var(--blue-600); padding: 14px 16px;
}
.who-val-h {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 13px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
  color: #f0ece4; margin-bottom: 4px;
}
.who-val-p { font-size: 11px; color: var(--blue-200); line-height: 1.5; }

/* ─── SERVICES ───────────────────────────────────────────────────────────── */
.services { background: var(--gray-50); padding: 80px 64px; }
.services-header { text-align: center; margin-bottom: 52px; }
.services-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 2px;
  background: var(--gray-100);
}
.srv {
  background: var(--white); padding: 32px 24px 28px;
  border-top: 3px solid transparent;
  transition: border-color .25s, background .25s;
  cursor: default;
}
.srv:hover { background: var(--blue-50); border-top-color: var(--blue-600); }
.srv { color: inherit; text-decoration: none; display: block; }
.srv-icon {
  width: 52px; height: 52px; background: var(--blue-50);
  border: .5px solid var(--blue-100);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 20px;
}
.srv-icon i { font-size: 26px; color: var(--blue-600); }
.srv-name {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 18px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase;
  color: var(--blue-900); margin-bottom: 10px; line-height: 1.1;
}
.srv-desc { font-size: 12.5px; color: var(--gray-600); line-height: 1.65; margin-bottom: 16px; }
.srv-list { list-style: none; }
.srv-list li {
  display: flex; align-items: flex-start; gap: 8px;
  font-size: 11.5px; color: var(--gray-800); padding: 4px 0;
  border-bottom: .5px solid #eeede8; line-height: 1.4;
}
.srv-list li:last-child { border-bottom: none; }
.srv-list i { color: var(--blue-600); font-size: 13px; flex-shrink: 0; margin-top: 1px; }

/* ─── WORK GALLERY ───────────────────────────────────────────────────────── */
.work { padding: 80px 64px; background: var(--white); }
.work-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 36px; }
.work-link {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 12px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  color: var(--blue-600); text-decoration: none;
  display: flex; align-items: center; gap: 6px;
}
.work-link:hover { color: var(--blue-800); }
.work-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  grid-template-rows: 260px 200px;
  gap: 4px;
}
.work-item {
  background: var(--blue-900); overflow: hidden; position: relative;
  cursor: default;
}
.work-item:hover .work-item-overlay { opacity: 1; }
.work-item.span-row { grid-row: span 2; }
.work-item-bg {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
}
.work-item-pattern {
  position: absolute; inset: 0; opacity: .06;
  background-image:
    linear-gradient(var(--blue-400) 1px, transparent 1px),
    linear-gradient(90deg, var(--blue-400) 1px, transparent 1px);
  background-size: 24px 24px;
}
.work-item-illustration {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
}
.work-item-illustration i {
  font-size: 64px; color: rgba(181,212,244,.15);
}
.work-item.span-row .work-item-illustration i { font-size: 110px; }
.work-item-overlay {
  position: absolute; inset: 0; background: rgba(4,44,83,.85);
  display: flex; flex-direction: column; justify-content: flex-end; padding: 20px;
  opacity: 0; transition: opacity .3s;
}
.work-item-label {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 20px 20px 16px;
  background: linear-gradient(transparent, rgba(4,44,83,.88));
}
.work-item-tag {
  font-size: 8.5px; letter-spacing: .14em; text-transform: uppercase;
  font-weight: 700; color: var(--blue-400); margin-bottom: 4px;
}
.work-item-name {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 16px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase;
  color: #f0ece4; line-height: 1.1;
}
.work-item.span-row .work-item-name { font-size: 22px; }
.work-item-desc {
  font-size: 11px; color: var(--blue-200); line-height: 1.5; margin-top: 4px;
}

/* ─── FORMATS BAND ───────────────────────────────────────────────────────── */
.formats-band { background: var(--blue-900); padding: 52px 64px; }
.formats-band-inner { display: grid; grid-template-columns: 280px 1fr; gap: 48px; align-items: center; }
.formats-label {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 32px; font-weight: 800; text-transform: uppercase;
  color: #f0ece4; letter-spacing: .04em; line-height: 1;
  border-right: 1px solid rgba(181,212,244,.2); padding-right: 48px;
}
.formats-label span { display: block; color: var(--blue-200); }
.formats-pills { display: flex; gap: 3px; flex-wrap: wrap; }
.format-pill {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 20px; background: rgba(12,68,124,.6);
  border: .5px solid rgba(181,212,244,.2); flex: 1; min-width: 140px;
}
.format-pill i { font-size: 24px; color: var(--blue-200); flex-shrink: 0; }
.format-pill-name {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 14px; font-weight: 700; letter-spacing: .07em; text-transform: uppercase;
  color: #f0ece4;
}
.format-pill-sub { font-size: 10px; color: var(--blue-400); letter-spacing: .06em; text-transform: uppercase; margin-top: 1px; }

/* ─── FOOTER ─────────────────────────────────────────────────────────────── */
.footer { background: #01111f; border-top: 3px solid var(--blue-600); }
.footer-top { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 48px; padding: 56px 64px 48px; }
.footer-brand-name {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 22px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  color: #f0ece4; margin-bottom: 4px;
}
.footer-brand-sub {
  font-size: 9px; letter-spacing: .2em; text-transform: uppercase;
  color: var(--blue-400); margin-bottom: 16px;
}
.footer-brand-desc {
  font-size: 12.5px; color: var(--blue-200); line-height: 1.7; font-weight: 300;
  margin-bottom: 20px;
}
.footer-contact-row {
  display: flex; align-items: center; gap: 12px;
  font-size: 17px; color: var(--blue-100); margin-bottom: 12px;
}
.footer-contact-row i { font-size: 20px; color: var(--blue-400); flex-shrink: 0; }
.footer-col-head {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 11px; font-weight: 700; letter-spacing: .2em; text-transform: uppercase;
  color: var(--blue-400); border-bottom: .5px solid rgba(181,212,244,.2);
  padding-bottom: 10px; margin-bottom: 16px;
}
.footer-links { list-style: none; }
.footer-links li { margin-bottom: 9px; }
.footer-links a {
  font-size: 13px; color: var(--blue-200); text-decoration: none;
  display: flex; align-items: center; gap: 7px;
  transition: color .2s;
}
.footer-links a:hover { color: #fff; }
.footer-links i { font-size: 13px; color: var(--blue-600); }
.footer-bottom {
  background: #010c15; border-top: .5px solid rgba(181,212,244,.15);
  padding: 16px 64px; display: flex; justify-content: space-between; align-items: center;
}
.footer-copy { font-size: 11px; color: var(--gray-400); letter-spacing: .06em; }
.footer-terms { display: flex; gap: 20px; }
.footer-terms span { font-size: 11px; color: var(--blue-400); letter-spacing: .06em; }

/* ── HAMBURGER ── */
.nav-ham{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:10px;margin-left:8px;}
.nav-ham span{display:block;width:24px;height:2px;background:#f0ece4;border-radius:2px;transition:transform .25s,opacity .25s;}
.nav-ham.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-ham.open span:nth-child(2){opacity:0;}
.nav-ham.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
.nav-mob{display:none;position:fixed;top:var(--nav-h);left:0;right:0;background:var(--blue-900);border-top:1px solid rgba(181,212,244,.15);z-index:98;flex-direction:column;padding:6px 0 20px;box-shadow:0 8px 24px rgba(0,0,0,.4);}
.nav-mob.open{display:flex;}
.nav-mob a{font-family:'Barlow Condensed',sans-serif;font-size:17px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--blue-100);text-decoration:none;padding:15px 28px;border-bottom:.5px solid rgba(181,212,244,.08);}
.nav-mob a:last-child{border-bottom:none;}
.nav-mob a:hover{color:#fff;background:rgba(181,212,244,.06);}
.nav-mob .mob-cta{background:var(--blue-600);color:#fff !important;margin:14px 20px 0;text-align:center;padding:13px 20px !important;border:none;}

/* ── TABLET (≤900px) ── */
@media(max-width:900px){
  .nav-links,.nav-cta{display:none;}
  .nav-ham{display:flex;}
  .nav{padding:0 20px;}
  .hero{height:480px;}
  .slide-illustration{display:none;}
  .slide-overlay{background:linear-gradient(to right,rgba(4,44,83,.94) 0%,rgba(4,44,83,.8) 100%);}
  .slide-content{padding:0 28px 52px;max-width:100%;}
  .slide-title{font-size:40px;}
  .slide-desc{font-size:13px;}
  .hero-controls{right:20px;}
  .who{grid-template-columns:1fr;}
  .who-visual{min-height:260px;}
  .who-content{padding:52px 28px;}
  .who-stats{grid-template-columns:repeat(3,1fr);}
  .services{padding:52px 28px;}
  .services-grid{grid-template-columns:1fr 1fr;}
  .work{padding:52px 28px;}
  .work-header{flex-direction:column;align-items:flex-start;gap:12px;}
  .work-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto;}
  .work-item.span-row{grid-row:span 1;}
  .footer-top{grid-template-columns:1fr;padding:44px 28px 32px;gap:36px;}
  .footer-top>div:first-child{flex-direction:column;align-items:flex-start;gap:20px;}
  .footer-bottom{padding:14px 28px;flex-direction:column;align-items:flex-start;gap:6px;}
  /* subpages */
  .page-hero{padding:90px 28px 60px;}
  .page-hero-title{font-size:40px;}
  .page-hero-sub{font-size:14px;}
  .page-sec{padding:52px 28px;}
  .page-two{grid-template-columns:1fr;gap:28px;}
  .page-three{grid-template-columns:1fr 1fr;gap:16px;}
  .page-four{grid-template-columns:1fr 1fr;gap:12px;}
  .stat-band{grid-template-columns:1fr 1fr;}
  .stat-cell{border-right:.5px solid rgba(181,212,244,.15);border-bottom:.5px solid rgba(181,212,244,.15);}
  .contact-grid{grid-template-columns:1fr;gap:36px;}
  .about-grid{grid-template-columns:1fr;gap:28px;}
  .value-grid{grid-template-columns:1fr 1fr;}
  .work-grid-page{grid-template-columns:1fr 1fr;}
  .cta-band{flex-direction:column;padding:44px 28px;gap:20px;}
}

/* ── MOBILE (≤560px) ── */
@media(max-width:560px){
  .hero{height:540px;}
  .slide-title{font-size:32px;}
  .slide-eyebrow{font-size:9px;}
  .slide-desc{font-size:12px;}
  .slide-btn{font-size:11px;padding:10px 18px;}
  .section-title{font-size:34px;}
  .services-grid{grid-template-columns:1fr;}
  .srv{padding:24px 20px 20px;}
  .work-grid{grid-template-columns:1fr;}
  .work-item.span-row .work-item-name{font-size:17px;}
  .who-stats{grid-template-columns:repeat(3,1fr);}
  .who-stat-n{font-size:28px;}
  .who-content{padding:40px 20px;}
  .services{padding:44px 20px;}
  .work{padding:44px 20px;}
  .page-hero{padding:80px 20px 52px;}
  .page-hero-title{font-size:30px;}
  .page-sec{padding:44px 20px;}
  .page-three,.page-four{grid-template-columns:1fr;}
  .stat-band{grid-template-columns:1fr 1fr;}
  .stat-n{font-size:32px;}
  .value-grid{grid-template-columns:1fr;}
  .work-grid-page{grid-template-columns:1fr;}
  .contact-grid{gap:28px;}
  .footer-top{padding:36px 20px 28px;}
  .footer-bottom{padding:14px 20px;}
  .footer-copy{font-size:10px;}
  .b-cover-stats{grid-template-columns:repeat(2,1fr);}
}

/* ── A11Y & PERF ── */
.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}
a:focus-visible,button:focus-visible,.srv:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--blue-200);outline-offset:2px;}
.slides{will-change:transform;}
@media(prefers-reduced-motion:reduce){
  .slides{transition:none;}
  .hero-progress-bar{animation:none!important;}
}

/* ── Subpage layout (page-hero, cards, contact, etc.) ── */
.page-hero{background:var(--blue-900);padding:100px 64px 72px;position:relative;overflow:hidden;margin-top:var(--nav-h);}
.page-hero-pattern{position:absolute;inset:0;opacity:.04;background-image:linear-gradient(var(--blue-400) 1px,transparent 1px),linear-gradient(90deg,var(--blue-400) 1px,transparent 1px);background-size:48px 48px;}
.page-hero-stripe{position:absolute;bottom:0;left:0;right:0;height:4px;background:repeating-linear-gradient(90deg,#185fa5 0,#185fa5 20px,#b5d4f4 20px,#b5d4f4 40px);}
.page-hero-eyebrow{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--blue-400);display:flex;align-items:center;gap:10px;margin-bottom:14px;}
.page-hero-eyebrow::before{content:'';display:block;width:28px;height:1px;background:var(--blue-400);}
.page-hero-title{font-family:'Barlow Condensed',sans-serif;font-size:52px;font-weight:800;letter-spacing:.03em;text-transform:uppercase;color:#f0ece4;line-height:.95;margin-bottom:16px;}
.page-hero-title em{color:var(--blue-200);font-style:normal;}
.page-hero-sub{font-size:16px;color:var(--blue-100);font-weight:300;line-height:1.65;max-width:620px;}
.page-sec{padding:72px 64px;}
.page-sec.gray{background:var(--gray-50);}
.page-sec.blue{background:var(--blue-50);}
.page-sec.dark{background:var(--blue-900);}
.page-sh{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--blue-600);display:flex;align-items:center;gap:10px;margin-bottom:16px;}
.page-sh::before{content:'';display:block;width:24px;height:1px;background:var(--blue-600);}
.page-sh.light{color:var(--blue-200);}
.page-sh.light::before{background:var(--blue-200);}
.page-title{font-family:'Barlow Condensed',sans-serif;font-size:40px;font-weight:800;letter-spacing:.03em;text-transform:uppercase;color:var(--blue-900);line-height:1;margin-bottom:20px;}
.page-title span{color:var(--blue-600);}
.page-title.light{color:#f0ece4;}
.page-title.light span{color:var(--blue-200);}
.page-body{font-size:15px;color:var(--gray-600);font-weight:300;line-height:1.75;margin-bottom:16px;}
.page-two{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;}
.page-three{display:grid;grid-template-columns:1fr 1fr 1fr;gap:24px;}
.page-four{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:16px;}
.cap-card{background:#fff;border:.5px solid var(--gray-100);border-top:3px solid var(--blue-600);padding:24px;}
.cap-card-icon{font-size:28px;color:var(--blue-600);margin-bottom:12px;}
.cap-card-title{font-family:'Barlow Condensed',sans-serif;font-size:17px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--blue-900);margin-bottom:8px;}
.cap-card-body{font-size:12.5px;color:var(--gray-600);line-height:1.6;}
.check-list{list-style:none;margin-top:16px;}
.check-list li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--gray-800);padding:8px 0;border-bottom:.5px solid #eeede8;line-height:1.5;}
.check-list li:last-child{border-bottom:none;}
.check-list i{color:var(--blue-600);font-size:16px;flex-shrink:0;margin-top:2px;}
.check-list.light li{color:var(--blue-100);border-bottom-color:rgba(181,212,244,.2);}
.check-list.light i{color:var(--blue-400);}
.stat-band{display:grid;grid-template-columns:repeat(4,1fr);background:var(--blue-900);border-top:.5px solid rgba(181,212,244,.1);}
.stat-cell{padding:32px 24px;text-align:center;border-right:.5px solid rgba(181,212,244,.15);}
.stat-cell:last-child{border-right:none;}
.stat-n{font-family:'Barlow Condensed',sans-serif;font-size:40px;font-weight:800;color:#f0ece4;line-height:1;}
.stat-l{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--blue-400);margin-top:4px;}
.cta-band{background:var(--blue-600);padding:56px 64px;display:flex;justify-content:space-between;align-items:center;gap:32px;}
.cta-band-h{font-family:'Barlow Condensed',sans-serif;font-size:30px;font-weight:800;text-transform:uppercase;color:#f0ece4;letter-spacing:.04em;margin-bottom:6px;}
.cta-band-sub{font-size:14px;color:var(--blue-100);line-height:1.5;}
.cta-band-btn{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:14px 28px;background:var(--blue-900);color:#fff;border:1.5px solid var(--blue-400);text-decoration:none;white-space:nowrap;flex-shrink:0;}
.cta-band-btn:hover{background:var(--blue-800);}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;}
.contact-form{display:flex;flex-direction:column;gap:16px;}
.cf-field{display:flex;flex-direction:column;gap:6px;}
.cf-label{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--blue-600);font-weight:600;}
.cf-input{background:var(--gray-50);border:.5px solid var(--gray-100);border-bottom:2px solid var(--gray-100);padding:10px 14px;font-size:14px;color:var(--gray-900);font-family:'Barlow',sans-serif;outline:none;transition:border-color .2s;}
.cf-input:focus{border-bottom-color:var(--blue-600);}
.cf-textarea{min-height:140px;resize:vertical;}
.cf-submit{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:14px 32px;background:var(--blue-600);color:#fff;border:none;cursor:pointer;align-self:flex-start;transition:background .2s;}
.cf-submit:hover{background:var(--blue-800);}
.contact-info-block{display:flex;flex-direction:column;gap:20px;}
.ci-item{display:flex;align-items:flex-start;gap:14px;}
.ci-icon{width:40px;height:40px;background:var(--blue-50);border:.5px solid var(--blue-100);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.ci-icon i{font-size:20px;color:var(--blue-600);}
.ci-label{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--blue-400);margin-bottom:4px;}
.ci-val{font-size:15px;color:var(--gray-800);}
.ci-val a{color:var(--gray-800);text-decoration:none;}
.ci-val a:hover{color:var(--blue-600);}
.work-grid-page{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;}
.work-page-item{background:var(--blue-900);position:relative;aspect-ratio:4/3;overflow:hidden;}
.work-page-item:hover .wpi-overlay{opacity:1;}
.wpi-pattern{position:absolute;inset:0;opacity:.06;background-image:linear-gradient(var(--blue-400) 1px,transparent 1px),linear-gradient(90deg,var(--blue-400) 1px,transparent 1px);background-size:24px 24px;}
.wpi-icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;}
.wpi-icon i{font-size:72px;color:rgba(181,212,244,.12);}
.wpi-overlay{position:absolute;inset:0;background:rgba(4,44,83,.88);opacity:0;transition:opacity .3s;display:flex;flex-direction:column;justify-content:flex-end;padding:20px;}
.wpi-label{position:absolute;bottom:0;left:0;right:0;padding:16px 18px 14px;background:linear-gradient(transparent,rgba(4,44,83,.9));}
.wpi-tag{font-size:8.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--blue-400);margin-bottom:3px;}
.wpi-name{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#f0ece4;line-height:1.1;}
.wpi-desc{font-size:11px;color:var(--blue-200);line-height:1.5;margin-top:4px;}
.about-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:48px;align-items:center;}
.about-img{background:var(--blue-50);border:.5px solid var(--blue-100);min-height:360px;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:12px;}
.about-img i{font-size:80px;color:var(--blue-200);}
.about-img-label{font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--blue-400);}
.value-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.val-card{padding:20px;background:rgba(255,255,255,.05);border:.5px solid rgba(181,212,244,.2);border-left:2px solid var(--blue-600);}
.val-card-h{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:#f0ece4;margin-bottom:6px;}
.val-card-p{font-size:12px;color:var(--blue-200);line-height:1.6;}

/* ── Featured Projects cards (image-led, clickable) ── */
.sim-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:4px;}
.sim-card{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--blue-900);border:none;padding:0;cursor:pointer;display:block;width:100%;text-align:left;}
.sim-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .4s ease;}
.sim-card:hover img{transform:scale(1.04);}
.sim-card-label{position:absolute;bottom:0;left:0;right:0;padding:18px 20px 16px;background:linear-gradient(transparent,rgba(4,44,83,.92));z-index:2;display:block;}
.sim-card-tag{display:block;font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--blue-200);margin-bottom:4px;}
.sim-card-name{display:block;font-family:'Barlow Condensed',sans-serif;font-size:19px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#f0ece4;line-height:1.05;}
.sim-card-cue{position:absolute;top:14px;right:14px;z-index:2;width:36px;height:36px;border-radius:50%;background:rgba(4,44,83,.7);border:1px solid rgba(181,212,244,.35);display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.85);transition:opacity .3s,transform .3s;}
.sim-card:hover .sim-card-cue,.sim-card:focus-visible .sim-card-cue{opacity:1;transform:scale(1);}
.sim-card-cue i{font-size:18px;color:#f0ece4;}
@media(max-width:760px){.sim-grid{grid-template-columns:1fr;}}

/* ── Gallery / lightbox ── */
.gal-overlay{position:fixed;inset:0;z-index:2000;background:rgba(2,17,31,.94);display:none;align-items:center;justify-content:center;padding:32px;}
.gal-overlay.open{display:flex;}
@media(min-width:1500px){
  .gal-overlay{padding:48px;}
  .gal-dialog{max-width:1700px;grid-template-columns:1.8fr 1fr;}
}
.gal-dialog{position:relative;width:100%;max-width:1400px;max-height:92vh;background:var(--blue-900);border:1px solid rgba(181,212,244,.18);display:grid;grid-template-columns:1.6fr 1fr;overflow:hidden;}
.gal-imgwrap{background:#01111f;display:flex;align-items:center;justify-content:center;min-height:340px;max-height:92vh;}
.gal-imgwrap img{width:100%;height:100%;max-height:92vh;object-fit:contain;display:block;}
.gal-info{padding:40px 36px;display:flex;flex-direction:column;justify-content:center;overflow-y:auto;}
.gal-tag{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--blue-400);margin-bottom:12px;display:flex;align-items:center;gap:10px;}
.gal-tag::before{content:'';display:block;width:22px;height:1px;background:var(--blue-400);}
.gal-title{font-family:'Barlow Condensed',sans-serif;font-size:30px;font-weight:800;letter-spacing:.03em;text-transform:uppercase;color:#f0ece4;line-height:1;margin-bottom:16px;}
.gal-desc{font-size:14px;color:var(--blue-100);font-weight:300;line-height:1.7;margin-bottom:20px;}
.gal-specs{list-style:none;}
.gal-specs li{display:flex;align-items:flex-start;gap:10px;font-size:13.5px;color:var(--blue-100);padding:8px 0;border-bottom:.5px solid rgba(181,212,244,.18);line-height:1.5;}
.gal-specs li:last-child{border-bottom:none;}
.gal-specs i{color:var(--blue-400);font-size:16px;flex-shrink:0;margin-top:2px;}
.gal-close{position:absolute;top:14px;right:14px;z-index:5;width:42px;height:42px;background:rgba(2,17,31,.6);border:1px solid rgba(181,212,244,.25);color:#f0ece4;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;}
.gal-close:hover{background:var(--blue-600);}
.gal-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:48px;height:48px;background:rgba(2,17,31,.6);border:1px solid rgba(181,212,244,.25);color:#f0ece4;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;}
.gal-nav:hover{background:var(--blue-600);}
.gal-prev{left:14px;}
.gal-next{right:14px;}
.gal-counter{position:absolute;bottom:14px;left:18px;z-index:5;font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.12em;color:var(--blue-200);}
@media(max-width:820px){
  .gal-dialog{grid-template-columns:1fr;grid-template-rows:auto 1fr;max-height:92vh;overflow-y:auto;}
  .gal-imgwrap{min-height:240px;max-height:42vh;}
  .gal-imgwrap img{max-height:42vh;}
  .gal-info{padding:28px 24px;}
  .gal-title{font-size:24px;}
  .gal-nav{width:40px;height:40px;font-size:20px;}
}

/* ── 3-cell stat band (centered) ── */
.stat-band.stat-3{grid-template-columns:repeat(3,1fr);}
@media(max-width:560px){.stat-band.stat-3{grid-template-columns:1fr;}}
