/* Next Matter Pro shared stylesheet (v6)
   Shared marketing stylesheet.
   Uses Google's free Inter font with clear, consistent type sizing.
   Navy palette is slightly lighter while preserving white-text readability.
   Large headline weights reduced for better readability.
*/

/* Design tokens */
:root{
  --navy:#1D4F86;
  --deep:#164274;
  --midnight:#0B2A4A;
  --ink:#081D33;

  --navy-rgb:29,79,134;
  --deep-rgb:22,66,116;
  --midnight-rgb:11,42,74;

  --white:#fff;
  --ice:#DCE8F5;
  --ice-2:#EEF4FA;
  --blue-light:#AFCBE8;
  --slate:#6B7280;
  --border:#d6dfeb;

  --line-w:rgba(255,255,255,.15);
  --shadow:0 26px 70px rgba(0,0,0,.22);
  --shadow-soft:0 14px 36px rgba(0,0,0,.16);

  --container:1180px;

  --font-main:"Inter",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;

  --text-xs:.75rem;
  --text-sm:.875rem;
  --text-base:1rem;
  --text-md:1.0625rem;
  --text-lg:1.1875rem;
  --text-xl:1.375rem;
  --text-2xl:1.75rem;
  --text-3xl:2.25rem;
  --text-4xl:3rem;

  --scroll-progress:0;
  --justice-y:0px;
  --justice-rotate:0deg;
  --justice-scale:1.02;
  --mouse-tilt-x:0px;
  --mouse-tilt-y:0px;
}

/* Base reset */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  min-height:100vh;
  font-family:var(--font-main);
  color:#fff;
  font-size:16px;
  font-weight:400;
  line-height:1.65;
  letter-spacing:-.01em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  background:
    radial-gradient(circle at 70% 40%,rgba(var(--navy-rgb),.50),rgba(var(--navy-rgb),0) 42%),
    linear-gradient(135deg,var(--midnight) 0%,var(--deep) 46%,var(--navy) 100%);
  overflow-x:hidden;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-12;
  pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:46px 46px;
  mask-image:linear-gradient(to bottom,rgba(0,0,0,.95),rgba(0,0,0,.28),transparent);
}

img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3,p{margin-top:0}
button,input,select,textarea{font-family:var(--font-main)}

.container{
  width:min(var(--container),calc(100% - 40px));
  margin:0 auto;
}

/* Skip link */
.skip-link{
  position:absolute;
  left:16px;
  top:-80px;
  z-index:999;
  padding:12px 16px;
  border-radius:999px;
  background:#fff;
  color:var(--deep);
  font-size:var(--text-sm);
  font-weight:800;
  transition:top .18s ease;
}
.skip-link:focus{top:16px}

/* Scroll progress bar */
.scroll-bar{
  position:fixed;
  top:0;
  left:0;
  width:calc(var(--scroll-progress) * 100%);
  height:3px;
  z-index:500;
  background:linear-gradient(90deg,#fff,#DCE8F5,#AFCBE8);
  box-shadow:0 0 18px rgba(220,232,245,.6);
  will-change:width;
}

/* Courthouse background */
.bg-stage{
  position:fixed;
  inset:0;
  z-index:-9;
  pointer-events:none;
  overflow:hidden;
  contain:strict;
}
.bg-stage::before{
  content:"";
  position:absolute;
  left:30%;
  top:40%;
  width:min(70vw,820px);
  height:min(70vw,820px);
  border-radius:999px;
  background:radial-gradient(circle,rgba(255,255,255,.12),transparent 64%);
  transform:translate(-50%,-50%);
}

.j-halo{
  position:fixed;
  left:-10%;
  top:50%;
  width:min(70vw,860px);
  height:min(70vw,860px);
  z-index:-8;
  border-radius:999px;
  pointer-events:none;
  opacity:.45;
  background:
    radial-gradient(circle at 50% 50%,rgba(255,255,255,.22) 0 10%,transparent 11%),
    radial-gradient(circle at 50% 50%,rgba(220,232,245,.16) 0 34%,transparent 58%);
  transform:translateY(-50%);
  contain:layout paint;
}

.j-bloom{
  position:fixed;
  left:-15%;
  top:50%;
  width:min(80vw,960px);
  height:min(80vw,960px);
  z-index:-10;
  border-radius:999px;
  pointer-events:none;
  opacity:.32;
  background:radial-gradient(circle at 60% 50%,rgba(174,203,232,.20) 0%,rgba(var(--navy-rgb),.10) 38%,transparent 64%);
  transform:translateY(-50%);
  contain:layout paint;
}

.j-glass{
  position:fixed;
  left:-18%;
  top:50%;
  width:min(58vw,720px);
  height:min(94vh,840px);
  transform:translateY(-50%);
  z-index:-7;
  pointer-events:none;
  opacity:.6;
  contain:layout paint;
}
@keyframes jFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-22px)}}
@keyframes colGlow{0%,100%{box-shadow:inset 0 1px 0 rgba(255,255,255,.4)}50%{box-shadow:inset 0 1px 0 rgba(255,255,255,.55)}}
.j-float{position:absolute;inset:0;animation:jFloat 10s ease-in-out infinite}
.j-monument{position:absolute;inset:0;width:100%;height:100%}
.m-pc,.m-fr,.m-en,.m-col,.m-st,.m-base{
  position:absolute;
  display:block;
  background:linear-gradient(145deg,rgba(255,255,255,.78),rgba(220,232,245,.28) 42%,rgba(255,255,255,.10));
  border:1px solid rgba(255,255,255,.34);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.5),0 22px 50px rgba(0,0,0,.16);
}
.m-pc{
  left:10%;
  right:10%;
  top:2%;
  height:86px;
  clip-path:polygon(50% 0%,100% 100%,0% 100%);
  background:linear-gradient(170deg,rgba(255,255,255,.82),rgba(220,232,245,.38) 52%,rgba(255,255,255,.14));
}
.m-fr{
  left:6%;
  right:6%;
  top:calc(2% + 86px);
  height:18px;
  border-radius:4px 4px 0 0;
  background:repeating-linear-gradient(90deg,rgba(255,255,255,.52) 0,rgba(255,255,255,.52) 8px,rgba(220,232,245,.16) 8px,rgba(220,232,245,.16) 14px);
  border:1px solid rgba(255,255,255,.28);
}
.m-en{left:4%;right:4%;top:calc(2% + 104px);height:46px;border-radius:6px}
.m-col{top:calc(2% + 160px);width:11%;height:44%;border-radius:999px;animation:colGlow 9s ease-in-out infinite}
.m-c1{left:6%}
.m-c2{left:23%;animation-delay:1.2s}
.m-c3{left:40%;animation-delay:.6s}
.m-c4{left:57%;animation-delay:1.8s}
.m-c5{right:6%;animation-delay:.3s}
.m-col::before,.m-col::after{
  content:"";
  position:absolute;
  left:50%;
  width:150%;
  height:28px;
  transform:translateX(-50%);
  border-radius:999px;
  background:rgba(255,255,255,.2);
  border:1px solid rgba(255,255,255,.26);
}
.m-col::before{top:-15px}
.m-col::after{bottom:-15px}
.m-st{left:4%;right:4%;bottom:calc(7% + 52px);height:38px;border-radius:6px}
.m-base{border-radius:6px}
.m-b1{left:2%;right:2%;bottom:calc(7% + 10px);height:42px}
.m-b2{left:0;right:0;bottom:7%;height:52px;border-radius:8px}

/* Header / nav */
main,.site-header,.site-footer{position:relative;z-index:2}
.site-header{
  position:sticky;
  top:0;
  z-index:80;
  background:rgba(var(--midnight-rgb),.94);
  border-bottom:1px solid rgba(255,255,255,.12);
  box-shadow:0 12px 34px rgba(0,0,0,.18);
}
.header-inner{
  min-height:84px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}
.brand{
  display:inline-flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  min-width:0;
}
.brand-clean{
  position:relative;
  padding:8px 16px 8px 9px;
  border-radius:999px;
  background:rgba(255,255,255,.94);
  border:1px solid rgba(255,255,255,.2);
  box-shadow:0 12px 26px rgba(0,0,0,.16);
  overflow:hidden;
  gap:12px;
}
.brand-clean::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg,transparent,rgba(220,232,245,.76),transparent);
  transform:translateX(-130%);
  transition:transform .6s ease;
}
.brand-clean:hover::before{transform:translateX(130%)}
.site-logo{
  position:relative;
  z-index:1;
  width:auto;
  max-width:198px;
  max-height:58px;
  object-fit:contain;
}
.brand-name{
  position:relative;
  z-index:1;
  color:var(--deep);
  font-size:1.0625rem;
  font-weight:850;
  letter-spacing:-.035em;
  line-height:1;
  white-space:nowrap;
}
.desktop-nav{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.header-pill-link{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:38px;
  padding:9px 13px;
  border-radius:999px;
  font-size:.75rem;
  font-weight:800;
  line-height:1;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.08);
  color:#fff;
  white-space:nowrap;
  box-shadow:0 8px 18px rgba(0,0,0,.12);
  overflow:hidden;
  transition:transform .18s,box-shadow .18s,border-color .18s,background .18s;
}
.header-pill-link::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.18) 42%,transparent 72%);
  transform:translateX(-120%);
  transition:transform .5s;
}
.header-pill-link:hover{
  transform:translateY(-1px);
  border-color:rgba(255,255,255,.28);
  background:rgba(255,255,255,.14);
  box-shadow:0 14px 30px rgba(0,0,0,.18);
}
.header-pill-link:hover::before{transform:translateX(120%)}
.header-pill-link span{position:relative;z-index:1}
.header-pill-link.is-current{
  background:rgba(255,255,255,.18);
  border-color:rgba(255,255,255,.28);
}
.header-pill-link.is-primary{
  background:#fff;
  border-color:#fff;
  color:var(--deep);
  box-shadow:0 16px 34px rgba(0,0,0,.2);
}
.pill-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:22px;
  height:22px;
  border-radius:999px;
  background:rgba(255,255,255,.16);
  font-size:.8125rem;
  line-height:1;
  flex:0 0 22px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.18);
}
.header-pill-link.is-primary .pill-icon{background:rgba(var(--navy-rgb),.1)}
.header-pill-link.with-icon .pill-icon{
  width:18px;
  height:18px;
  font-size:.625rem;
  flex:0 0 18px;
}
.mobile-menu-toggle,.mobile-menu-close{
  display:none;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.1);
  color:#fff;
  box-shadow:0 10px 22px rgba(0,0,0,.16);
  cursor:pointer;
  padding:0;
  transition:transform .18s,box-shadow .18s,border-color .18s,background .18s;
}
.mobile-menu-toggle:hover,.mobile-menu-close:hover{
  transform:translateY(-1px);
  border-color:rgba(255,255,255,.28);
}
.mobile-menu-toggle svg,.mobile-menu-close svg{
  width:18px;
  height:18px;
  stroke:#fff;
  fill:none;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.mobile-menu-backdrop,.mobile-menu-sheet{display:none}
.mobile-menu-panel{display:grid;gap:8px}
.mobile-menu-panel .header-pill-link{
  width:100%;
  justify-content:flex-start;
  padding:13px 14px;
  font-size:.8125rem;
  box-shadow:none;
}

/* Hero */
.hero{
  position:relative;
  min-height:840px;
  display:flex;
  align-items:center;
  overflow:hidden;
  isolation:isolate;
  background:
    radial-gradient(circle at 14% 16%,rgba(220,232,245,.16),rgba(220,232,245,0) 32%),
    linear-gradient(135deg,rgba(var(--midnight-rgb),.86) 0%,rgba(var(--deep-rgb),.78) 48%,rgba(var(--navy-rgb),.72) 100%);
}
.hero::before{
  content:"";
  position:absolute;
  inset:38px;
  z-index:-2;
  border-radius:50px;
  pointer-events:none;
  background:linear-gradient(135deg,rgba(255,255,255,.105),rgba(255,255,255,.035));
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 42px 120px rgba(0,0,0,.2),inset 0 1px 0 rgba(255,255,255,.18);
}
.hero::after{
  content:"";
  position:absolute;
  right:-210px;
  bottom:-260px;
  width:720px;
  height:720px;
  z-index:-3;
  border-radius:999px;
  background:radial-gradient(circle,rgba(220,232,245,.16),transparent 68%);
}
.hero-grid{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(360px,.72fr);
  gap:54px;
  align-items:center;
  padding:102px 0 90px;
}

/* Page hero */
.page-hero{
  position:relative;
  padding:78px 0 56px;
  background:
    radial-gradient(circle at 16% 14%,rgba(220,232,245,.14),transparent 32%),
    linear-gradient(135deg,rgba(var(--midnight-rgb),.84),rgba(var(--navy-rgb),.66));
}
.page-hero h1{
  margin:8px 0 14px;
  font-size:clamp(38px,5.2vw,72px);
  font-weight:800;
  line-height:1;
  letter-spacing:-.055em;
  text-wrap:balance;
  text-shadow:0 24px 64px rgba(0,0,0,.22);
}
.page-hero .hero-text{
  max-width:780px;
  color:rgba(255,255,255,.86);
  font-size:clamp(1rem,1.3vw,1.1875rem);
  line-height:1.75;
}
.breadcrumbs{
  font-size:.92rem;
  color:#d6e5f6;
  margin-bottom:6px;
}
.breadcrumbs a{color:#d6e5f6}

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  width:max-content;
  max-width:100%;
  margin:0 0 14px;
  padding:7px 13px;
  border-radius:999px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.16);
  color:#fff;
  box-shadow:0 12px 28px rgba(0,0,0,.12);
  font-size:.72rem;
  font-weight:850;
  letter-spacing:.13em;
  text-transform:uppercase;
}
.eyebrow::before{
  content:"";
  width:8px;
  height:8px;
  border-radius:999px;
  background:#fff;
  box-shadow:0 0 0 6px rgba(255,255,255,.12);
}

.hero h1{
  max-width:930px;
  margin-bottom:22px;
  color:#fff;
  font-size:clamp(52px,7.7vw,112px);
  font-weight:800;
  line-height:.96;
  letter-spacing:-.065em;
  text-wrap:balance;
  text-shadow:0 26px 70px rgba(0,0,0,.3);
}
.hero-text{
  max-width:780px;
  color:rgba(255,255,255,.86);
  font-size:clamp(1.0625rem,1.45vw,1.3125rem);
  line-height:1.8;
}

.hero-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:30px;
}
.btn{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:56px;
  padding:14px 22px;
  border-radius:999px;
  font-size:.875rem;
  font-weight:850;
  letter-spacing:-.01em;
  overflow:hidden;
  cursor:pointer;
  border:0;
  font-family:inherit;
  transition:transform .22s,box-shadow .22s,border-color .22s,background .22s;
}
.btn:hover{transform:translateY(-3px) scale(1.01)}
.btn-primary{
  color:var(--deep);
  border:1px solid rgba(255,255,255,.78);
  background:#fff;
  box-shadow:0 20px 48px rgba(0,0,0,.24);
}
.btn-secondary{
  color:#fff;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.1);
  box-shadow:0 16px 38px rgba(0,0,0,.16);
}
.btn-primary .pill-icon{background:rgba(var(--navy-rgb),.1)}
.btn-secondary .pill-icon{background:rgba(255,255,255,.14)}
.btn::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.44) 42%,transparent 74%);
  transform:translateX(-120%);
  transition:transform .58s;
}
.btn:hover::before{transform:translateX(120%)}
.btn span{position:relative;z-index:1}

.hero-points{
  display:grid;
  gap:12px;
  max-width:850px;
  margin:32px 0 0;
  padding:0;
  list-style:none;
}
.hero-points li{
  position:relative;
  padding:15px 16px 15px 50px;
  border-radius:22px;
  background:linear-gradient(160deg,rgba(var(--deep-rgb),.92),rgba(var(--midnight-rgb),.88));
  border:1px solid rgba(255,255,255,.20);
  box-shadow:0 12px 30px rgba(0,0,0,.30);
  color:rgba(255,255,255,.94);
  font-size:.875rem;
  line-height:1.65;
}
.hero-points li::before{
  content:"";
  position:absolute;
  left:17px;
  top:19px;
  width:18px;
  height:18px;
  border-radius:999px;
  background:radial-gradient(circle at center,var(--deep) 0 24%,transparent 27%),#fff;
  box-shadow:0 0 0 6px rgba(255,255,255,.12);
}

.hero-shell{
  position:relative;
  display:grid;
  gap:14px;
  padding:17px;
  border-radius:36px;
  background:linear-gradient(160deg,rgba(var(--deep-rgb),.94),rgba(var(--midnight-rgb),.90));
  border:1px solid rgba(255,255,255,.22);
  box-shadow:0 38px 100px rgba(0,0,0,.34),inset 0 1px 0 rgba(255,255,255,.18);
}
.hero-shell::before{
  content:"";
  position:absolute;
  inset:-13px;
  border-radius:46px;
  z-index:-1;
  background:linear-gradient(135deg,rgba(255,255,255,.14),rgba(220,232,245,.12),rgba(255,255,255,.06));
  opacity:.76;
  filter:blur(14px);
}
.hero-shell::after{
  content:"LIVE FILE OPERATIONS";
  position:absolute;
  right:22px;
  top:-16px;
  padding:8px 13px;
  border-radius:999px;
  background:#fff;
  color:var(--deep);
  font-size:.625rem;
  font-weight:850;
  letter-spacing:.14em;
  box-shadow:0 16px 34px rgba(0,0,0,.24);
}
.shell-card{
  position:relative;
  overflow:hidden;
  padding:22px;
  border-radius:28px;
  background:linear-gradient(160deg,rgba(var(--navy-rgb),.86),rgba(var(--midnight-rgb),.82));
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 18px 42px rgba(0,0,0,.30);
}
.shell-card::before{
  content:"";
  position:absolute;
  right:-70px;
  top:-70px;
  width:180px;
  height:180px;
  border-radius:999px;
  background:radial-gradient(circle,rgba(255,255,255,.16),transparent 68%);
  pointer-events:none;
}
.shell-title,.shell-subtitle{
  margin-bottom:15px;
  color:#fff;
  font-size:.875rem;
  font-weight:850;
  letter-spacing:-.02em;
}
.shell-metrics{
  position:relative;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.shell-metric{
  position:relative;
  min-height:132px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:16px;
  padding:18px;
  border-radius:25px;
  background:linear-gradient(160deg,rgba(var(--navy-rgb),.78),rgba(var(--deep-rgb),.74));
  border:1px solid rgba(255,255,255,.16);
  overflow:hidden;
  transition:transform .25s,box-shadow .25s;
}
.shell-metric:hover{
  transform:translateY(-4px);
  box-shadow:0 18px 36px rgba(0,0,0,.18);
}
.shell-metric::after{
  content:"";
  position:absolute;
  right:-32px;
  bottom:-32px;
  width:94px;
  height:94px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
}
.shell-metric strong{
  color:#fff;
  font-size:clamp(32px,4vw,50px);
  font-weight:800;
  line-height:.96;
  letter-spacing:-.055em;
}
.shell-metric span{
  color:rgba(255,255,255,.86);
  font-size:.75rem;
  font-weight:750;
  line-height:1.35;
}
.shell-card-soft{background:linear-gradient(160deg,rgba(var(--midnight-rgb),.92),rgba(var(--midnight-rgb),.88))}
.shell-list{
  display:grid;
  gap:0;
  margin:0;
  padding:0;
  list-style:none;
}
.shell-list li{
  padding:12px 0;
  border-bottom:1px solid rgba(255,255,255,.10);
  color:rgba(255,255,255,.92);
  font-size:.8125rem;
  line-height:1.55;
}
.shell-list li:last-child{
  border-bottom:0;
  padding-bottom:0;
}

/* Trust strip */
.trust-strip{
  position:relative;
  padding:28px 0;
  background:rgba(var(--midnight-rgb),.62);
  border-top:1px solid rgba(255,255,255,.1);
  border-bottom:1px solid rgba(255,255,255,.1);
}
.trust-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
}
.trust-grid div{
  min-height:76px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:17px;
  border-radius:999px;
  background:rgba(255,255,255,.085);
  border:1px solid rgba(255,255,255,.12);
  font-size:.8125rem;
  font-weight:800;
  text-align:center;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.1);
}

/* Sections */
.section{
  position:relative;
  padding:96px 0;
  border-bottom:1px solid rgba(255,255,255,.08);
  content-visibility:auto;
  contain-intrinsic-size:0 700px;
  background:linear-gradient(135deg,rgba(var(--midnight-rgb),.78),rgba(var(--deep-rgb),.72));
}
.section-light,.section-soft{
  background:linear-gradient(135deg,rgba(var(--midnight-rgb),.82),rgba(var(--deep-rgb),.74));
}
.section-dark{
  background:
    radial-gradient(circle at 12% 4%,rgba(255,255,255,.06),transparent 32%),
    radial-gradient(circle at 86% 12%,rgba(220,232,245,.06),transparent 30%),
    linear-gradient(135deg,rgba(var(--ink),.92),rgba(var(--midnight-rgb),.86) 74%);
}
.section .container{
  position:relative;
  z-index:1;
}
.section-head{
  max-width:900px;
  margin-bottom:36px;
}
.section-head h2,.intro-grid h2,.callout h2,.about-grid h2{
  margin-bottom:14px;
  color:#fff;
  font-size:clamp(34px,4.4vw,62px);
  font-weight:800;
  line-height:1;
  letter-spacing:-.055em;
  text-wrap:balance;
  text-shadow:0 24px 64px rgba(0,0,0,.22);
}
.section-head p,.intro p,.callout p,.about-grid p{
  color:rgba(255,255,255,.92);
  font-size:1rem;
  line-height:1.8;
}

/* Cards */
.card-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:18px;
}
.service-card-grid,.services-top-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
.card{
  position:relative;
  overflow:hidden;
  min-height:280px;
  padding:30px;
  border-radius:32px;
  background:linear-gradient(160deg,rgba(var(--deep-rgb),.94),rgba(var(--midnight-rgb),.90));
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 22px 60px rgba(0,0,0,.32);
  transition:transform .24s,box-shadow .24s,border-color .24s;
}
.card::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(135deg,rgba(255,255,255,.06),transparent 38%),
    radial-gradient(circle at 82% 12%,rgba(220,232,245,.06),transparent 26%);
}
.card::after{
  content:"";
  position:absolute;
  right:-40px;
  bottom:-40px;
  width:120px;
  height:120px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  pointer-events:none;
}
.card:hover{
  transform:translateY(-8px);
  box-shadow:0 36px 84px rgba(0,0,0,.42);
  border-color:rgba(255,255,255,.32);
}
.card h3{
  position:relative;
  margin-bottom:13px;
  color:#fff;
  font-size:1.3125rem;
  font-weight:800;
  line-height:1.18;
  letter-spacing:-.035em;
}
.card h3::before{
  content:"";
  display:block;
  width:46px;
  height:5px;
  margin-bottom:18px;
  border-radius:999px;
  background:linear-gradient(90deg,#fff,rgba(255,255,255,0));
}
.card p{
  position:relative;
  margin-bottom:0;
  color:rgba(255,255,255,.90);
  font-size:.875rem;
  line-height:1.75;
}
.card.light{
  background:linear-gradient(160deg,rgba(var(--deep-rgb),.92),rgba(var(--midnight-rgb),.88));
  border-color:rgba(255,255,255,.20);
  box-shadow:0 20px 52px rgba(0,0,0,.30);
}
.card.light p{color:rgba(255,255,255,.92)}

/* Intro / About / Callout */
.intro-grid,.about-grid,.contact-grid{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0,.78fr) minmax(0,1.05fr);
  gap:42px;
  align-items:start;
  padding:46px;
  border-radius:42px;
  background:linear-gradient(160deg,rgba(var(--deep-rgb),.94),rgba(var(--midnight-rgb),.90));
  border:1px solid rgba(255,255,255,.20);
  box-shadow:0 26px 70px rgba(0,0,0,.32);
}
.intro{
  display:grid;
  gap:18px;
}
.intro p{
  margin:0;
  color:rgba(255,255,255,.92);
}
.callout{
  position:relative;
  overflow:hidden;
  padding:clamp(40px,6vw,86px);
  border-radius:46px;
  background:linear-gradient(160deg,rgba(var(--deep-rgb),.96),rgba(var(--midnight-rgb),.92));
  border:1px solid rgba(255,255,255,.22);
  box-shadow:0 34px 90px rgba(0,0,0,.36);
}
.callout::before{
  content:"";
  position:absolute;
  right:-120px;
  top:-120px;
  width:320px;
  height:320px;
  border-radius:999px;
  background:radial-gradient(circle at center,rgba(255,255,255,.18),transparent 60%);
  pointer-events:none;
}
.callout > *{
  position:relative;
  z-index:1;
}
.callout p{
  max-width:720px;
  margin-bottom:24px;
}

/* Forms */
.form-panel,.form-card{
  position:relative;
  padding:30px;
  border-radius:32px;
  background:linear-gradient(160deg,rgba(var(--deep-rgb),.94),rgba(var(--midnight-rgb),.90));
  border:1px solid rgba(255,255,255,.20);
  box-shadow:0 26px 70px rgba(0,0,0,.32);
  color:#fff;
}
.form-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
label{
  display:flex;
  flex-direction:column;
  gap:6px;
  font-size:.8125rem;
  font-weight:750;
  color:#fff;
}
label.full{grid-column:1 / -1}
input,select,textarea{
  width:100%;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.08);
  border-radius:14px;
  padding:13px 14px;
  font:inherit;
  color:#fff;
}
input::placeholder,textarea::placeholder{color:rgba(255,255,255,.55)}
input:focus,select:focus,textarea:focus{
  outline:0;
  border-color:rgba(255,255,255,.45);
  background:rgba(255,255,255,.14);
  box-shadow:0 0 0 4px rgba(220,232,245,.1);
}
textarea{
  resize:vertical;
  min-height:140px;
}
input[type=file]{
  padding:10px 12px;
  background:rgba(255,255,255,.06);
  cursor:pointer;
}
.form-alert{
  display:none;
  margin-top:14px;
  padding:12px 14px;
  border-radius:14px;
  background:rgba(255,80,80,.12);
  border:1px solid rgba(255,120,120,.3);
  color:#ffe6e6;
  font-size:.8125rem;
}
.form-alert.show{display:block}
.submit-success{
  display:flex;
  flex-direction:column;
  gap:4px;
  margin-top:14px;
  padding:14px;
  border-radius:14px;
  background:rgba(120,220,160,.12);
  border:1px solid rgba(140,230,180,.3);
  color:#e7ffe9;
  font-size:.8125rem;
}
.submit-success[hidden]{display:none !important}
.submit-success strong{font-weight:800}
form .btn-primary{
  width:auto;
  margin-top:18px;
}

/* Contact page layout */
.contact-layout{
  display:grid;
  grid-template-columns:minmax(280px,.8fr) minmax(0,1fr);
  gap:24px;
  align-items:start;
}
.contact-summary{
  display:grid;
  gap:18px;
}
.material-card,.summary-card{
  padding:26px;
  border-radius:28px;
  background:linear-gradient(160deg,rgba(var(--deep-rgb),.94),rgba(var(--midnight-rgb),.90));
  border:1px solid rgba(255,255,255,.20);
  box-shadow:0 20px 50px rgba(0,0,0,.32);
}
.summary-card h3{
  margin-bottom:10px;
  color:#fff;
  font-size:1.375rem;
  font-weight:800;
  line-height:1.18;
  letter-spacing:-.03em;
}
.summary-card p{
  color:rgba(255,255,255,.92);
  font-size:.875rem;
}
.summary-meta{
  display:grid;
  gap:12px;
  margin-top:18px;
}
.summary-meta-row{
  display:grid;
  grid-template-columns:90px 1fr;
  gap:14px;
  align-items:center;
  padding-top:12px;
  border-top:1px dashed rgba(255,255,255,.14);
}
.summary-meta-label{
  font-size:.6875rem;
  font-weight:800;
  letter-spacing:.12em;
  color:rgba(255,255,255,.6);
  text-transform:uppercase;
}
.summary-meta-value a{
  color:#d6e5f6;
  font-weight:700;
}
.summary-meta-value a:hover{color:#fff}
.booking-panel{
  padding:22px;
  border-radius:24px;
  background:linear-gradient(160deg,rgba(var(--deep-rgb),.92),rgba(var(--ink),.90));
  border:1px solid rgba(255,255,255,.18);
}
.booking-panel p{
  color:rgba(255,255,255,.88);
  font-size:.875rem;
}
.booking-panel h4{
  margin:0 0 6px;
  font-size:1rem;
  font-weight:800;
  color:#fff;
}
.booking-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:14px;
}

/* Career layout */
.career-layout{
  display:grid;
  grid-template-columns:minmax(280px,.8fr) minmax(0,1fr);
  gap:24px;
  align-items:start;
}
.career-card{
  padding:26px;
  border-radius:28px;
  background:linear-gradient(160deg,rgba(var(--deep-rgb),.94),rgba(var(--midnight-rgb),.90));
  border:1px solid rgba(255,255,255,.20);
  box-shadow:0 20px 50px rgba(0,0,0,.32);
}
.career-intro-shell h2{
  font-size:clamp(26px,3vw,38px);
  font-weight:800;
  line-height:1.05;
  letter-spacing:-.045em;
  margin-bottom:10px;
}
.career-intro-shell p{
  color:rgba(255,255,255,.92);
  font-size:.875rem;
  margin-bottom:14px;
}
.list-check{
  padding-left:18px;
  color:rgba(255,255,255,.92);
}
.list-check li{margin-bottom:8px}

/* Intake wizard */
.intake-shell{
  display:grid;
  gap:20px;
}
.support-strip{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}
.support-pill-card{
  padding:16px 18px;
  border-radius:22px;
  background:linear-gradient(160deg,rgba(var(--deep-rgb),.92),rgba(var(--midnight-rgb),.88));
  border:1px solid rgba(255,255,255,.18);
}
.support-pill-card strong{
  display:block;
  font-size:.6875rem;
  font-weight:800;
  letter-spacing:.12em;
  color:rgba(255,255,255,.6);
  text-transform:uppercase;
  margin-bottom:6px;
}
.support-pill-card a,.support-pill-card span{
  color:#fff;
  font-size:.84375rem;
  font-weight:600;
}
.intake-card{
  padding:30px;
  border-radius:32px;
  background:linear-gradient(160deg,rgba(var(--deep-rgb),.94),rgba(var(--midnight-rgb),.90));
  border:1px solid rgba(255,255,255,.20);
  box-shadow:0 26px 70px rgba(0,0,0,.32);
}
.intake-top{margin-bottom:18px}
.progress-wrap{display:grid;gap:8px}
.progress-label{
  font-size:.6875rem;
  font-weight:800;
  letter-spacing:.14em;
  color:rgba(255,255,255,.6);
  text-transform:uppercase;
}
.progress-track{
  height:6px;
  background:rgba(255,255,255,.1);
  border-radius:999px;
  overflow:hidden;
}
.progress-bar{
  height:100%;
  width:0%;
  background:linear-gradient(90deg,#fff,#DCE8F5);
  border-radius:999px;
  transition:width .3s ease;
}
.step{display:none}
.step.active{
  display:block;
  animation:fadeInUp .4s ease;
}
@keyframes fadeInUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.start-panel{
  padding:26px;
  border-radius:24px;
  background:linear-gradient(160deg,rgba(var(--deep-rgb),.86),rgba(var(--ink),.82));
  border:1px solid rgba(255,255,255,.16);
  text-align:center;
}
.start-inner{
  max-width:560px;
  margin:0 auto;
}
.start-badge{
  display:inline-block;
  margin-bottom:10px;
  padding:6px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  font-size:.6875rem;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.start-panel h2{
  font-size:clamp(26px,3.2vw,38px);
  font-weight:800;
  line-height:1.05;
  letter-spacing:-.045em;
  margin-bottom:10px;
}
.start-panel p{
  color:rgba(255,255,255,.78);
  font-size:.875rem;
  margin-bottom:16px;
}
.question-title{
  font-size:clamp(22px,2.4vw,28px);
  font-weight:800;
  line-height:1.12;
  letter-spacing:-.035em;
  margin-bottom:8px;
}
.question-copy{
  color:rgba(255,255,255,.72);
  font-size:.875rem;
  margin-bottom:18px;
}
.choice-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.choice-button{
  position:relative;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding:18px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.18);
  background:linear-gradient(160deg,rgba(var(--deep-rgb),.78),rgba(var(--midnight-rgb),.74));
  color:#fff;
  text-align:left;
  cursor:pointer;
  font:inherit;
  transition:transform .2s,border-color .2s,background .2s;
}
.choice-button:hover{
  transform:translateY(-2px);
  border-color:rgba(255,255,255,.32);
  background:rgba(255,255,255,.1);
}
.choice-button.is-selected{
  border-color:#fff;
  background:rgba(255,255,255,.18);
  box-shadow:0 14px 32px rgba(0,0,0,.18);
}
.choice-main{
  display:flex;
  flex-direction:column;
  gap:4px;
  flex:1;
}
.choice-main strong{
  font-size:.875rem;
  font-weight:800;
  color:#fff;
}
.choice-main span{
  font-size:.78125rem;
  color:rgba(255,255,255,.7);
  line-height:1.5;
}
.choice-check{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:26px;
  height:26px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  font-size:.75rem;
  opacity:0;
  transition:opacity .2s;
}
.choice-button.is-selected .choice-check{
  opacity:1;
  background:#fff;
  color:var(--deep);
}
.field-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.field{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.field.full{grid-column:1 / -1}
.field label{
  font-size:.75rem;
  font-weight:750;
  color:rgba(255,255,255,.78);
}
.summary-box{
  display:grid;
  gap:8px;
  margin-bottom:18px;
  padding:18px;
  border-radius:18px;
  background:linear-gradient(160deg,rgba(var(--deep-rgb),.92),rgba(var(--ink),.90));
  border:1px solid rgba(255,255,255,.16);
}
.summary-item{
  display:grid;
  grid-template-columns:160px 1fr;
  gap:12px;
  font-size:.8125rem;
  color:rgba(255,255,255,.85);
}
.summary-item strong{
  font-weight:800;
  color:rgba(255,255,255,.6);
  font-size:.6875rem;
  letter-spacing:.1em;
  text-transform:uppercase;
}
.alert{
  display:none;
  margin-top:14px;
  padding:12px 14px;
  border-radius:14px;
  background:rgba(255,80,80,.12);
  border:1px solid rgba(255,120,120,.3);
  color:#ffe6e6;
  font-size:.8125rem;
}
.alert.show{display:block}
.intake-actions{
  display:flex;
  justify-content:space-between;
  gap:10px;
  margin-top:18px;
}
.intake-actions-inline{margin-top:14px}
.wizard-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:48px;
  padding:12px 20px;
  border-radius:999px;
  border:0;
  background:#fff;
  color:var(--deep);
  font-size:.84375rem;
  font-weight:800;
  cursor:pointer;
  font-family:inherit;
  box-shadow:0 16px 34px rgba(0,0,0,.2);
  transition:transform .2s,box-shadow .2s;
}
.wizard-btn:hover{transform:translateY(-2px)}
.wizard-btn.secondary{
  background:rgba(255,255,255,.1);
  color:#fff;
  border:1px solid rgba(255,255,255,.18);
}
.wizard-btn:disabled{
  opacity:.5;
  cursor:not-allowed;
}
.submission-complete-panel{
  padding:32px;
  text-align:center;
}

/* Blog */
.blog-hero,.post-hero{
  padding:68px 0 40px;
  background:
    radial-gradient(circle at 16% 14%,rgba(220,232,245,.14),transparent 32%),
    linear-gradient(135deg,rgba(var(--midnight-rgb),.84),rgba(var(--navy-rgb),.66));
}
.blog-hero h1,.post-hero h1{
  font-size:clamp(38px,4.8vw,64px);
  font-weight:800;
  line-height:1;
  letter-spacing:-.055em;
  margin-bottom:10px;
}
.blog-empty{
  padding:60px 0;
  text-align:center;
  color:rgba(255,255,255,.7);
}
.blog-columns{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:30px;
  padding:50px 0;
}
.blog-section-head{margin-bottom:24px}
.blog-section-kicker{
  font-size:.6875rem;
  font-weight:800;
  letter-spacing:.14em;
  color:rgba(255,255,255,.6);
  text-transform:uppercase;
  margin-bottom:6px;
}
.blog-section-head h2{
  font-size:clamp(24px,3vw,34px);
  font-weight:800;
  line-height:1.08;
  letter-spacing:-.04em;
  margin-bottom:6px;
}
.blog-section-head p{
  color:rgba(255,255,255,.7);
  font-size:.875rem;
}
.blog-grid{
  display:grid;
  gap:20px;
}
.blog-card{
  overflow:hidden;
  border-radius:26px;
  background:linear-gradient(160deg,rgba(var(--deep-rgb),.94),rgba(var(--midnight-rgb),.90));
  border:1px solid rgba(255,255,255,.20);
  box-shadow:0 18px 44px rgba(0,0,0,.28);
  transition:transform .24s,box-shadow .24s;
}
.blog-card:hover{
  transform:translateY(-4px);
  box-shadow:0 30px 60px rgba(0,0,0,.40);
}
.blog-card-image img{
  width:100%;
  height:200px;
  object-fit:cover;
}
.blog-card-content{padding:22px}
.blog-meta{
  font-size:.75rem;
  color:rgba(255,255,255,.6);
  margin-bottom:8px;
}
.blog-card h2{
  font-size:1.25rem;
  font-weight:800;
  line-height:1.18;
  letter-spacing:-.03em;
  color:#fff;
  margin-bottom:10px;
}
.blog-author{
  display:flex;
  align-items:center;
  gap:8px;
  margin-bottom:10px;
}
.blog-author-photo{
  width:28px;
  height:28px;
  border-radius:999px;
  object-fit:cover;
}
.blog-author-name{
  font-size:.75rem;
  font-weight:700;
  color:rgba(255,255,255,.78);
}
.blog-excerpt{
  color:rgba(255,255,255,.74);
  font-size:.84375rem;
  line-height:1.6;
  margin-bottom:14px;
}
.blog-fallback{padding:40px 0 80px}

/* Post */
.post-inner{
  max-width:820px;
  margin:0 auto;
}
.post-author{
  display:flex;
  align-items:center;
  gap:12px;
  margin-top:16px;
}
.post-author-photo{
  width:42px;
  height:42px;
  border-radius:999px;
  object-fit:cover;
}
.post-author-meta{
  display:flex;
  flex-direction:column;
  gap:2px;
}
.post-author-name{
  font-size:.875rem;
  font-weight:750;
}
.post-author-date{
  font-size:.75rem;
  color:rgba(255,255,255,.7);
}
.post-excerpt{
  margin-top:14px;
  font-size:1.0625rem;
  color:rgba(255,255,255,.84);
  line-height:1.65;
}
.post-wrap{padding:30px 0 80px}
.post-shell{
  max-width:820px;
  margin:0 auto;
}
.post-back-link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-bottom:18px;
  color:rgba(255,255,255,.78);
  font-weight:700;
  font-size:.8125rem;
}
.post-back-link:hover{color:#fff}
.post-card{
  padding:36px;
  border-radius:32px;
  background:linear-gradient(160deg,rgba(var(--deep-rgb),.96),rgba(var(--midnight-rgb),.92));
  border:1px solid rgba(255,255,255,.20);
  box-shadow:0 26px 70px rgba(0,0,0,.34);
}
.post-body{
  color:rgba(255,255,255,.94);
  line-height:1.75;
  font-size:1rem;
}
.post-body h2,.post-body h3,.post-body h4{
  color:#fff;
  font-weight:800;
  line-height:1.16;
  letter-spacing:-.03em;
  margin-top:1.4em;
  margin-bottom:.5em;
}
.post-body p{margin:0 0 1em}
.post-body img{
  border-radius:18px;
  margin:1em 0;
}
.post-body a{
  color:#d6e5f6;
  text-decoration:underline;
}
.post-body ul,.post-body ol{
  padding-left:22px;
  margin:0 0 1em;
}
.post-body li{margin-bottom:6px}
.post-body blockquote{
  margin:1em 0;
  padding:14px 18px;
  border-left:3px solid rgba(255,255,255,.4);
  background:rgba(255,255,255,.06);
  border-radius:0 14px 14px 0;
}

/* Team grid */
.team-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,320px));
  gap:18px;
  margin-top:24px;
  justify-content:center;
}
.team-card{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  padding:28px 22px;
  border-radius:26px;
  background:linear-gradient(160deg,rgba(var(--deep-rgb),.94),rgba(var(--midnight-rgb),.90));
  border:1px solid rgba(255,255,255,.20);
  box-shadow:0 18px 44px rgba(0,0,0,.28);
  transition:transform .24s,box-shadow .24s;
}
.team-card:hover{
  transform:translateY(-4px);
  box-shadow:0 30px 60px rgba(0,0,0,.40);
}
.team-photo-shell{
  display:flex;
  justify-content:center;
  width:100%;
  margin-bottom:18px;
}
.team-photo{
  width:160px;
  height:160px;
  border-radius:999px;
  background:linear-gradient(135deg,rgba(255,255,255,.18),rgba(220,232,245,.06));
  border:2px solid rgba(255,255,255,.22);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  box-shadow:0 14px 30px rgba(0,0,0,.28);
}
.team-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:999px;
}
.team-photo span{
  font-size:3rem;
  font-weight:800;
  color:rgba(255,255,255,.7);
}
.team-card-content{
  display:flex;
  flex-direction:column;
  align-items:center;
  width:100%;
}
.team-card-content h3{
  font-size:1.1875rem;
  font-weight:800;
  line-height:1.18;
  color:#fff;
  margin-bottom:6px;
}
.team-title{
  font-size:.75rem;
  font-weight:750;
  letter-spacing:.10em;
  text-transform:uppercase;
  color:rgba(220,232,245,.78);
  margin-bottom:12px;
}
.team-bio{
  color:rgba(255,255,255,.88);
  font-size:.84375rem;
  line-height:1.65;
  margin-bottom:0;
  max-width:32ch;
}

/* Policy pages */
.policy-layout{
  display:grid;
  grid-template-columns:240px 1fr;
  gap:30px;
  align-items:start;
  padding:50px 0;
}
.toc{
  position:sticky;
  top:104px;
  display:grid;
  gap:6px;
  padding:20px;
  border-radius:22px;
  background:linear-gradient(160deg,rgba(var(--deep-rgb),.92),rgba(var(--midnight-rgb),.88));
  border:1px solid rgba(255,255,255,.18);
}
.toc h2{
  font-size:.8125rem;
  font-weight:800;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:rgba(255,255,255,.6);
  margin-bottom:8px;
}
.toc a{
  display:block;
  padding:6px 0;
  font-size:.8125rem;
  color:rgba(255,255,255,.78);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.toc a:hover{color:#fff}
.policy-card{
  padding:36px;
  border-radius:32px;
  background:linear-gradient(160deg,rgba(var(--deep-rgb),.96),rgba(var(--midnight-rgb),.92));
  border:1px solid rgba(255,255,255,.20);
  box-shadow:0 26px 70px rgba(0,0,0,.34);
  color:rgba(255,255,255,.94);
  line-height:1.75;
}
.policy-card h2,.policy-card h3{
  color:#fff;
  font-weight:800;
  line-height:1.16;
  letter-spacing:-.03em;
  margin-top:1.6em;
}
.policy-card a{
  color:#d6e5f6;
  text-decoration:underline;
}
.policy-hero{
  padding:60px 0 30px;
}
.policy-hero h1{
  font-size:clamp(32px,4vw,52px);
  font-weight:800;
  line-height:1.04;
  letter-spacing:-.045em;
}
.badge-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:14px;
}
.badge{
  padding:6px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.14);
  font-size:.71875rem;
  font-weight:750;
  letter-spacing:.05em;
}

/* Footer */
.site-footer{
  position:relative;
  overflow:hidden;
  padding:60px 0;
  background:
    radial-gradient(circle at 12% 0%,rgba(255,255,255,.1),transparent 34%),
    linear-gradient(135deg,var(--midnight),var(--deep));
  border-top:1px solid rgba(255,255,255,.1);
}
.footer-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(260px,1.2fr) minmax(180px,.8fr) minmax(220px,.9fr);
  gap:18px;
  align-items:start;
}
.footer-brand{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:12px;
  border-radius:24px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.1);
}
.footer-logo{
  max-width:220px;
  max-height:62px;
}
.footer-brand .brand-name{color:#fff}
.footer-copy{
  max-width:340px;
  margin:18px 0 0;
  color:rgba(255,255,255,.76);
  font-size:.875rem;
  line-height:1.75;
}
.footer-links,.footer-contact-group,.footer-contact{
  display:flex;
  flex-direction:column;
  gap:9px;
}
.footer-pill-label{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:max-content;
  margin-bottom:8px;
  padding:6px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.14);
  font-size:.6875rem;
  font-weight:800;
  letter-spacing:.1em;
  text-transform:uppercase;
}
.footer-links a,.footer-contact-group a{
  color:rgba(255,255,255,.82);
  font-size:.875rem;
}
.footer-links a:hover,.footer-contact-group a:hover{
  color:#fff;
  text-decoration:underline;
}
.footer-social-links{
  display:flex;
  flex-wrap:wrap;
  gap:7px;
  margin-top:8px;
}
.footer-social-button{
  display:inline-flex;
  align-items:center;
  gap:7px;
  min-height:32px;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.12);
  color:#fff !important;
  font-size:.75rem;
  font-weight:800;
  text-decoration:none !important;
  transition:transform .18s,background .18s,border-color .18s;
}
.footer-social-button:hover{
  transform:translateY(-1px);
  background:rgba(255,255,255,.15);
  border-color:rgba(255,255,255,.2);
}
.footer-social-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:18px;
  height:18px;
  border-radius:999px;
  background:#DCE8F5;
  color:var(--navy);
  font-size:.625rem;
  font-weight:800;
  flex:0 0 18px;
}
.footer-disclaimer{
  margin-top:12px;
  max-width:340px;
  color:rgba(255,255,255,.76);
  font-size:.75rem;
  line-height:1.7;
}

/* Reveal / stagger animations */
.reveal{
  opacity:0;
  transform:translateY(36px);
  transition:opacity .7s ease,transform .7s cubic-bezier(.2,.8,.2,1);
}
.reveal.is-visible{
  opacity:1;
  transform:none;
}
.reveal[data-reveal=left]{transform:translateX(-40px)}
.reveal[data-reveal=right]{transform:translateX(40px)}
.reveal[data-reveal=zoom]{transform:scale(.94)}
.reveal[data-reveal=left].is-visible,.reveal[data-reveal=right].is-visible,.reveal[data-reveal=zoom].is-visible{transform:none}
.stagger > *{
  opacity:0;
  transform:translateY(28px);
  transition:opacity .65s,transform .65s cubic-bezier(.2,.8,.2,1);
}
.stagger.is-visible > *{
  opacity:1;
  transform:none;
}
.stagger.is-visible > *:nth-child(1){transition-delay:.04s}
.stagger.is-visible > *:nth-child(2){transition-delay:.12s}
.stagger.is-visible > *:nth-child(3){transition-delay:.2s}
.stagger.is-visible > *:nth-child(4){transition-delay:.28s}
.stagger.is-visible > *:nth-child(5){transition-delay:.36s}

/* Cookie banner */
.cookie-banner{
  position:fixed;
  left:14px;
  right:14px;
  bottom:14px;
  z-index:200;
  display:none;
  padding:18px 22px;
  border-radius:22px;
  background:rgba(var(--midnight-rgb),.98);
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 24px 50px rgba(0,0,0,.4);
  color:#fff;
  max-width:560px;
  margin:0 auto;
}
.cookie-banner.show{display:block}
.cookie-banner p{
  margin:0 0 10px;
  font-size:.8125rem;
  color:rgba(255,255,255,.82);
  line-height:1.55;
}
.cookie-banner a{
  color:#d6e5f6;
  text-decoration:underline;
}
.cookie-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.cookie-actions button{
  flex:1;
  min-height:38px;
  padding:8px 14px;
  border-radius:999px;
  border:0;
  font-weight:750;
  font-size:.75rem;
  cursor:pointer;
  font-family:inherit;
}
.cookie-accept{
  background:#fff;
  color:var(--deep);
}
.cookie-decline{
  background:rgba(255,255,255,.1);
  color:#fff;
  border:1px solid rgba(255,255,255,.18);
}

/* Responsive */
@media (max-width:1180px){
  .card-grid,.service-card-grid,.services-top-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .team-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .site-logo{max-width:160px}
  .brand-name{font-size:.9375rem}
}

@media (max-width:1100px){
  .hero-grid{grid-template-columns:1fr}
  .hero-shell{max-width:740px}
  .footer-grid{grid-template-columns:1fr 1fr}
  .footer-grid > div:first-child{grid-column:1 / -1}
  .j-glass{opacity:.6}
  .j-monument{width:min(88vw,760px);height:min(88vh,760px)}
  .blog-columns{grid-template-columns:1fr}
  .policy-layout{grid-template-columns:1fr}
  .toc{position:static;display:none}
  .contact-layout,.career-layout{grid-template-columns:1fr}
  .support-strip{grid-template-columns:1fr}
  .intro-grid,.about-grid,.contact-grid{grid-template-columns:1fr}
}

@media (max-width:980px){
  .desktop-nav{display:none}
  .mobile-menu-toggle{
    display:inline-flex;
    margin-left:auto;
    z-index:121;
  }
  .mobile-menu-backdrop{
    position:fixed;
    inset:0;
    background:rgba(var(--midnight-rgb),.52);
    opacity:0;
    pointer-events:none;
    transition:opacity .2s;
    z-index:119;
  }
  .mobile-menu-sheet{
    position:fixed;
    top:0;
    right:0;
    width:min(372px,90vw);
    height:100vh;
    display:block;
    padding:88px 14px 18px;
    overflow-y:auto;
    transform:translateX(100%);
    transition:transform .24s;
    z-index:120;
    background:linear-gradient(145deg,rgba(var(--midnight-rgb),.98),rgba(var(--deep-rgb),.96));
    border-left:1px solid rgba(255,255,255,.1);
    box-shadow:-18px 0 44px rgba(0,0,0,.24);
  }
  .mobile-menu-close{
    position:absolute;
    top:18px;
    right:14px;
    display:inline-flex;
  }
  body.mobile-menu-open{overflow:hidden}
  body.mobile-menu-open .mobile-menu-backdrop{
    display:block;
    opacity:1;
    pointer-events:auto;
  }
  body.mobile-menu-open .mobile-menu-sheet{transform:translateX(0)}
  .hero{min-height:auto}
  .hero::before{
    inset:18px;
    border-radius:32px;
  }
  .hero-grid{
    gap:36px;
    padding:72px 0 60px;
  }
  .hero h1{
    font-size:clamp(44px,10vw,72px);
    line-height:1;
    letter-spacing:-.052em;
  }
  .hero-actions{
    flex-direction:column;
    align-items:stretch;
  }
  .hero-actions .btn{width:100%}
  .trust-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .j-glass{opacity:.5}
  .j-monument{width:min(96vw,680px);height:min(82vh,680px)}
  .brand-name{display:none}
  .form-grid,.field-grid,.choice-grid{grid-template-columns:1fr}
  .summary-meta-row,.summary-item{grid-template-columns:1fr}
}

@media (max-width:640px){
  .container{width:min(100% - 28px,var(--container))}
  .header-inner{min-height:74px}
  .brand-clean{padding:8px 10px}
  .site-logo{
    max-width:160px !important;
    max-height:48px !important;
  }
  .hero-grid{padding:48px 0 42px}
  .hero h1{
    letter-spacing:-.045em;
    line-height:1.02;
  }
  .page-hero h1,
  .blog-hero h1,
  .post-hero h1,
  .policy-hero h1{
    letter-spacing:-.04em;
    line-height:1.04;
  }
  .section-head h2,.intro-grid h2,.callout h2,.about-grid h2{
    letter-spacing:-.045em;
    line-height:1.04;
  }
  .hero-text{font-size:1rem}
  .shell-metrics{grid-template-columns:1fr}
  .hero-shell{border-radius:28px}
  .trust-grid,.card-grid,.service-card-grid,.services-top-grid,.footer-grid,.team-grid{grid-template-columns:1fr}
  .section{padding:64px 0}
  .intro-grid,.about-grid,.contact-grid,.callout,.intake-card,.policy-card,.post-card,.form-panel,.form-card,.summary-card,.material-card,.career-card{
    padding:24px;
    border-radius:24px;
  }
  .mobile-menu-sheet{
    width:100vw;
    border-left:none;
    padding-top:82px;
  }
  .j-glass{opacity:.36}
  .j-monument{
    width:520px;
    height:620px;
  }
  .j-bloom{opacity:.26}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation:none !important;
    transition:none !important;
    scroll-behavior:auto !important;
  }
  .reveal,.stagger > *{
    opacity:1 !important;
    transform:none !important;
  }
  .j-glass,.j-float,.j-halo,.j-bloom,.bg-stage::before,.bg-stage::after{
    transform:none !important;
    animation:none !important;
  }
}