
:root{
  --navy:#06172a;
  --navy-2:#0b233c;
  --ink:#081426;
  --muted:#5e6b7c;
  --line:#dfe5ec;
  --soft:#f5f7fa;
  --white:#fff;
  --orange:#f26a21;
  --orange-2:#ff7a2d;
  --shadow:0 18px 60px rgba(8,20,38,.12);
  --radius:18px;
  --max:1260px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;color:var(--ink);background:#fff}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:var(--max);margin:auto;padding-left:28px;padding-right:28px}
.header{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.96);border-bottom:1px solid var(--line);backdrop-filter:blur(10px)}
.nav{min-height:90px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{display:flex;align-items:center;gap:12px;font-weight:900;letter-spacing:.06em;color:var(--ink);flex:0 0 auto}
.mark{width:52px;height:32px;position:relative}
.mark svg{width:100%;height:100%}
.brand-text{line-height:.92}
.brand-text b{display:block;font-size:23px;letter-spacing:.08em}
.brand-text span{display:block;font-size:12px;letter-spacing:.36em;color:#415064;margin-top:4px}
.menu{display:flex;align-items:center;justify-content:center;gap:18px;font-size:14px;font-weight:800;flex:1 1 auto;min-width:0}
.menu a{padding:34px 0 29px;border-bottom:3px solid transparent;color:#13243a;white-space:nowrap}
.menu a.active,.menu a:hover{color:var(--orange);border-color:var(--orange)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;background:var(--orange);color:#fff;border:0;border-radius:8px;padding:14px 20px;font-size:13px;font-weight:900;text-transform:uppercase;letter-spacing:.02em;box-shadow:0 8px 20px rgba(242,106,33,.22);line-height:1.1;white-space:nowrap;flex-shrink:0}
.btn:hover{background:#d95613}
.btn.secondary{background:transparent;border:1px solid rgba(255,255,255,.6);box-shadow:none;color:#fff}
.btn.light{background:#fff;color:var(--ink);border:1px solid var(--line);box-shadow:none}
.eyebrow{color:var(--orange);font-weight:900;text-transform:uppercase;letter-spacing:.06em;font-size:14px;margin:0 0 12px}
h1,h2,h3,p{margin-top:0}
h1{font-size:62px;line-height:1.02;letter-spacing:-.045em;margin-bottom:22px}
h2{font-size:40px;line-height:1.08;letter-spacing:-.03em;margin-bottom:18px}
h3{font-size:20px;line-height:1.18;margin-bottom:10px}
p{color:var(--muted);line-height:1.7}
.lead{font-size:19px;line-height:1.65;color:#344257;max-width:720px}
.section{padding:76px 0}
.section.compact{padding:54px 0}
.dark{background:var(--navy);color:#fff}
.dark p{color:#d7e0eb}
.dark h1,.dark h2,.dark h3{color:#fff}
.hero{position:relative;overflow:hidden}
.hero.split{display:grid;grid-template-columns:1fr 1fr;min-height:520px}
.hero.split .copy{padding:86px 8% 70px max(28px,calc((100vw - var(--max))/2 + 28px));display:flex;flex-direction:column;justify-content:center}
.hero.split .media{position:relative;min-height:420px;background-size:cover;background-position:center}
.hero.dark-hero{background:linear-gradient(120deg,var(--navy) 0%,var(--navy-2) 58%,#102c4c 100%)}
.hero.dark-hero .copy{color:#fff}
.hero.dark-hero .lead{color:#d7e0eb}
.hero.light-hero{background:linear-gradient(100deg,#fff 0%,#fff 48%,#f3f6f9 100%);border-bottom:1px solid var(--line)}
.hero.light-hero .media::after,.hero.dark-hero .media::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(6,23,42,.45),rgba(6,23,42,0) 45%)}
.hero-collage{display:grid;grid-template-columns:1.1fr .9fr;gap:16px;min-height:430px}
.hero-collage .image:nth-child(1){grid-row:span 2}
.image{border-radius:var(--radius);overflow:hidden;background-size:cover;background-position:center;min-height:200px;box-shadow:var(--shadow)}
.image.flat{border-radius:0;box-shadow:none}
.pill-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.pill{border:1px solid var(--line);background:#fff;border-radius:999px;padding:9px 13px;font-size:13px;font-weight:800;color:#26364d}
.dark .pill{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.18);color:#fff}
.value-band{background:#fff;border-bottom:1px solid var(--line);box-shadow:0 8px 30px rgba(8,20,38,.04)}
.value-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.value{padding:28px;border-right:1px solid var(--line)}
.value:last-child{border-right:0}
.value .icon,.icon{font-size:30px;color:var(--orange);line-height:1;margin-bottom:12px}
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:0 8px 32px rgba(8,20,38,.06)}
.card .image{height:225px;min-height:225px;border-radius:0;box-shadow:none}
.card-body{padding:24px}
.card p{font-size:14px}
.link{font-size:13px;font-weight:900;color:var(--orange);text-transform:uppercase}
.checks{display:grid;grid-template-columns:repeat(2,1fr);gap:10px 24px;margin-top:20px}
.check{position:relative;padding-left:24px;color:#26364d;font-weight:700;font-size:14px;line-height:1.4}
.check:before{content:"✓";position:absolute;left:0;color:var(--orange);font-weight:900}
.two-col{display:grid;grid-template-columns:.9fr 1.1fr;gap:56px;align-items:center}
.two-col.equal{grid-template-columns:1fr 1fr}
.strip{background:var(--soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.mini-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.mini{padding:20px;border-left:1px solid var(--line)}
.mini:first-child{border-left:0}
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.process.five{grid-template-columns:repeat(5,1fr)}
.step{position:relative}
.num{display:inline-flex;width:34px;height:34px;border-radius:9px;background:var(--navy);color:#fff;align-items:center;justify-content:center;font-weight:900;margin-bottom:12px}
.step p{font-size:14px}
.table-list{display:grid;gap:0;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff}
.row{display:grid;grid-template-columns:.36fr .64fr;border-bottom:1px solid var(--line)}
.row:last-child{border-bottom:0}
.row>div{padding:22px}
.row .label{font-weight:900;color:var(--ink);border-right:1px solid var(--line);background:#fbfcfd}
.market-list{display:grid;gap:18px}
.market-item{display:grid;grid-template-columns:260px 1fr .9fr;gap:28px;align-items:center;border:1px solid var(--line);background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:0 8px 26px rgba(8,20,38,.05)}
.market-item .image{height:190px;min-height:190px;border-radius:0;box-shadow:none}
.market-item ul,.standards ul{margin:0;padding-left:18px;color:#37465a;line-height:1.7}
.market-item li::marker,.standards li::marker{color:var(--orange)}
.cta{background:linear-gradient(120deg,var(--navy),#09223b);color:#fff;padding:48px 0}
.cta .inner{display:flex;align-items:center;justify-content:space-between;gap:30px}
.cta p{color:#d6e1ec;margin:0}
.footer{background:#06172a;color:#fff;padding:52px 0 22px}
.footer p,.footer a{color:#c8d4e2}
.footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:36px;border-bottom:1px solid rgba(255,255,255,.14);padding-bottom:34px}
.footer h4{color:#fff;text-transform:uppercase;font-size:13px;letter-spacing:.05em;margin:0 0 14px}
.footer a{display:block;margin:8px 0;font-size:14px}
.copyright{display:flex;justify-content:space-between;gap:24px;padding-top:22px;font-size:12px;color:#aab8c8}
.form-wrap{display:grid;grid-template-columns:1fr .45fr;gap:34px;align-items:start}
.form{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow)}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.form label{display:block;font-size:12px;font-weight:900;color:#27364a;margin-bottom:6px}
.form input,.form select,.form textarea{width:100%;border:1px solid #cfd8e3;border-radius:7px;padding:13px;font:inherit;color:#16263c;background:#fff}
.form textarea{min-height:150px;grid-column:1/-1}
.form .wide{grid-column:1/-1}
.expect{background:#f8fafc;border:1px solid var(--line);border-radius:var(--radius);padding:26px}
.expect .item{border-bottom:1px solid var(--line);padding:18px 0}
.expect .item:last-child{border-bottom:0}
.logo-white .brand-text b,.logo-white .brand-text span{color:#fff}
@media(max-width:980px){
  .menu{display:none}
  .hero.split,.two-col,.form-wrap,.market-item,.cta .inner{grid-template-columns:1fr;display:grid}
  .hero.split .copy{padding:64px 28px}
  h1{font-size:48px}
  h2{font-size:34px}
  .card-grid,.mini-grid,.process,.process.five,.value-grid{grid-template-columns:1fr 1fr}
  .market-item{gap:0}
  .market-item .image{height:250px}
}
@media(max-width:640px){
  .container{padding-left:20px;padding-right:20px}
  .nav{min-height:76px}
  .brand-text b{font-size:18px}
  .brand-text span{font-size:10px}
  h1{font-size:40px}
  .section{padding:54px 0}
  .card-grid,.mini-grid,.process,.process.five,.value-grid,.form-grid,.checks{grid-template-columns:1fr}
  .value{border-right:0;border-bottom:1px solid var(--line)}
  .footer-grid{grid-template-columns:1fr}
}


/* Patch: use a clean text-only Flatirons wordmark until the final logo artwork is placed */
.text-brand {
  gap: 0;
}
.text-brand .brand-text b {
  font-size: 25px;
  letter-spacing: .12em;
}
.text-brand .brand-text span {
  letter-spacing: .36em;
}

/* Patch: ensure dark hero text remains legible */
.hero.dark-hero h1,
.hero.dark-hero h2,
.hero.dark-hero h3,
.hero.dark-hero .eyebrow {
  color: #ffffff;
}
.hero.dark-hero p,
.hero.dark-hero .lead {
  color: #d7e0eb;
}
.hero.dark-hero .copy h1 {
  color: #ffffff;
}
.hero.dark-hero .copy .lead,
.hero.dark-hero .copy p {
  color: #d7e0eb;
}

/* Patch: footer logo text stays white */
.footer .brand-text b,
.footer .brand-text span {
  color: #ffffff;
}

/* Logo image replacement */
.brand-logo{display:block;height:42px;width:auto;max-width:340px}
.logo-white .brand-logo{filter:brightness(0) invert(1)}
@media(max-width:640px){.brand-logo{height:36px}}

/* About page leadership section */
.leaders{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:30px}
.leader-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:0 8px 32px rgba(8,20,38,.06)}
.leader-photo{background:#f3f6fb;height:360px;overflow:hidden;padding:14px;display:flex;align-items:center;justify-content:center}
.leader-photo img{width:100%;height:100%;object-fit:contain;object-position:center center;filter:grayscale(100%)}
.leader-photo.jt img{object-position:center center}
.leader-body{padding:24px}
.leader-role{display:inline-block;margin-top:8px;font-size:12px;font-weight:900;letter-spacing:.16em;text-transform:uppercase;color:var(--orange)}
.leader-body p{margin:14px 0 0}
@media(max-width:980px){.leaders{grid-template-columns:1fr}}

.nav > .btn{margin-left:0;min-width:150px;text-align:center}

@media(max-width:1200px){
  .container{padding-left:24px;padding-right:24px}
  .menu{gap:14px;font-size:13px}
  .brand-logo{height:38px}
  .nav > .btn{min-width:138px;padding:13px 16px}
}



/* Final header and About-page refinements */
.nav{
  min-height:92px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}
.brand{
  display:flex;
  align-items:center;
  gap:12px;
  font-weight:900;
  letter-spacing:.06em;
  color:var(--ink);
  flex:0 0 auto;
}
.brand-logo{
  display:block;
  height:42px;
  width:auto;
  max-width:340px;
}
.logo-white .brand-logo{
  filter:brightness(0) invert(1);
}
.menu{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:18px;
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
  font-size:14px;
  font-weight:650;
  letter-spacing:.005em;
  flex:1 1 auto;
  min-width:0;
}
.menu a{
  padding:35px 0 31px;
  border-bottom:3px solid transparent;
  color:#1b2c42;
  white-space:nowrap;
}
.menu a.active,
.menu a:hover{
  color:var(--orange);
  border-color:var(--orange);
}
.nav > .btn{
  min-width:148px;
  padding:14px 18px;
  border-radius:8px;
  line-height:1.1;
  white-space:nowrap;
  flex-shrink:0;
  box-shadow:0 8px 20px rgba(242,106,33,.22);
}
h1{font-size:62px;}
h2{font-size:40px;}
.lead{font-size:19px;max-width:720px;}

.leaders{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:24px;
  margin-top:30px;
}
.leader-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:0 8px 32px rgba(8,20,38,.06);
}
.leader-photo{
  background:#f3f6fb;
  height:380px;
  overflow:hidden;
  padding:18px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.leader-photo img{
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:center center;
  filter:grayscale(100%);
}
.leader-photo.jt img{
  object-fit:contain;
  object-position:center center;
}
.leader-body{
  padding:24px;
}
.leader-role{
  display:inline-block;
  margin-top:8px;
  font-size:12px;
  font-weight:900;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--orange);
}
.leader-body p{
  margin:14px 0 0;
}
@media(max-width:1200px){
  .container{padding-left:24px;padding-right:24px}
  .menu{gap:13px;font-size:13px}
  .brand-logo{height:38px}
  .nav > .btn{min-width:136px;padding:13px 15px;font-size:12px}
  h1{font-size:54px}
  h2{font-size:36px}
}
@media(max-width:980px){
  .leaders{grid-template-columns:1fr}
}
@media(max-width:640px){
  .nav{min-height:76px}
  .brand-logo{height:34px}
  h1{font-size:40px}
  h2{font-size:32px}
  .leader-photo{height:320px}
}


/* Real uploaded logo patch */
.brand-logo{
  display:block;
  height:46px;
  width:auto;
  max-width:520px;
}
.logo-white .brand-logo{
  filter:none !important;
}
.footer .brand{
  display:inline-flex;
  align-items:center;
  padding:10px 14px;
  background:rgba(255,255,255,.97);
  border-radius:12px;
}
@media(max-width:1200px){
  .brand-logo{height:42px}
}
@media(max-width:640px){
  .brand-logo{height:34px;max-width:290px}
  .footer .brand{padding:8px 10px}
}



/* Mobile rendering fix */
*,
*::before,
*::after{
  box-sizing:border-box;
}
html,
body{
  width:100%;
  max-width:100%;
  overflow-x:hidden;
}
img{
  max-width:100%;
  height:auto;
}

/* Keep desktop intact, but prevent the header from blowing out smaller screens */
.header{
  width:100%;
}
.nav{
  max-width:100%;
}
.menu{
  min-width:0;
}

/* Tablet and phone layout */
@media(max-width:900px){
  .container{
    width:100%;
    max-width:100%;
    padding-left:20px;
    padding-right:20px;
  }

  .nav{
    min-height:auto;
    height:auto;
    display:grid;
    grid-template-columns:1fr;
    gap:14px;
    padding-top:16px;
    padding-bottom:16px;
  }

  .brand{
    justify-content:center;
    width:100%;
  }

  .brand-logo{
    height:auto;
    width:min(340px, 92vw);
    max-width:92vw;
  }

  .menu{
    order:2;
    width:100%;
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:8px;
    font-size:12px;
    line-height:1.2;
  }

  .menu a{
    display:flex;
    align-items:center;
    justify-content:center;
    min-height:42px;
    padding:10px 8px;
    border:1px solid rgba(16,31,51,.12);
    border-radius:8px;
    text-align:center;
    white-space:normal;
    background:#fff;
  }

  .menu a.active,
  .menu a:hover{
    border-color:var(--orange);
  }

  .nav > .btn{
    order:3;
    width:100%;
    max-width:360px;
    margin:0 auto;
    min-width:0;
    padding:14px 18px;
  }

  .section{
    padding-top:54px;
    padding-bottom:54px;
  }

  .hero .section,
  .light-hero .section{
    padding-top:46px;
    padding-bottom:52px;
  }

  .two-col,
  .feature,
  .split,
  .contact-grid,
  .footer-grid,
  .value-grid,
  .grid-3,
  .grid-4,
  .cards,
  .leaders{
    display:grid;
    grid-template-columns:1fr !important;
    gap:24px;
  }

  h1{
    font-size:clamp(34px, 9vw, 48px);
    line-height:1.05;
    letter-spacing:-.035em;
  }

  h2{
    font-size:clamp(28px, 7vw, 36px);
    line-height:1.12;
  }

  h3{
    font-size:22px;
  }

  .lead{
    font-size:17px;
    line-height:1.55;
  }

  p,
  li{
    font-size:16px;
    line-height:1.6;
  }

  .hero-collage{
    width:100%;
    min-height:auto;
    display:grid;
    grid-template-columns:1fr;
    gap:14px;
  }

  .hero-collage .image,
  .image,
  .photo,
  .panel-image,
  .media,
  .visual{
    width:100%;
    min-height:240px;
    border-radius:16px;
    background-size:cover;
    background-position:center;
  }

  .hero-collage .image{
    min-height:220px;
  }

  .hero-collage .image:nth-child(n+3){
    display:none;
  }

  .leader-photo{
    height:auto;
    min-height:260px;
    max-height:none;
  }

  .leader-photo img{
    width:100%;
    height:auto;
    max-height:360px;
    object-fit:contain;
  }

  .cta .inner{
    display:grid;
    grid-template-columns:1fr;
    gap:22px;
    text-align:left;
  }

  .cta .btn{
    width:100%;
    max-width:360px;
  }

  .footer{
    padding-top:42px;
  }

  .footer .brand{
    justify-content:flex-start;
    width:auto;
  }

  .footer .brand-logo{
    width:min(300px, 82vw);
  }
}

/* Very small phones */
@media(max-width:480px){
  .container{
    padding-left:16px;
    padding-right:16px;
  }

  .menu{
    grid-template-columns:1fr;
  }

  .menu a{
    min-height:40px;
  }

  .brand-logo{
    width:min(300px, 90vw);
  }

  .hero-collage .image,
  .image,
  .photo,
  .panel-image,
  .media,
  .visual{
    min-height:210px;
  }

  .section{
    padding-top:44px;
    padding-bottom:44px;
  }
}



/* Mobile navigation refinement: compact header, hidden desktop nav, hero visible sooner */
.mobile-menu{
  display:none;
}

@media(max-width:900px){
  .nav{
    display:grid !important;
    grid-template-columns:1fr auto;
    align-items:center;
    gap:12px;
    padding-top:12px;
    padding-bottom:12px;
  }

  .brand{
    justify-content:flex-start !important;
    width:auto !important;
    min-width:0;
  }

  .brand-logo{
    width:min(250px, 68vw) !important;
    max-width:68vw !important;
    height:auto !important;
  }

  .nav > .menu{
    display:none !important;
  }

  .nav > .btn{
    display:none !important;
  }

  .mobile-menu{
    display:block;
    justify-self:end;
    position:relative;
    z-index:20;
  }

  .mobile-menu summary{
    list-style:none;
    cursor:pointer;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:42px;
    padding:10px 15px;
    border-radius:999px;
    border:1px solid rgba(16,31,51,.16);
    background:#fff;
    color:#102033;
    font-size:13px;
    font-weight:800;
    letter-spacing:.02em;
    text-transform:uppercase;
    box-shadow:0 6px 18px rgba(8,20,38,.08);
  }

  .mobile-menu summary::-webkit-details-marker{
    display:none;
  }

  .mobile-menu summary::after{
    content:"";
    width:8px;
    height:8px;
    margin-left:9px;
    border-right:2px solid currentColor;
    border-bottom:2px solid currentColor;
    transform:rotate(45deg) translateY(-2px);
  }

  .mobile-menu[open] summary::after{
    transform:rotate(225deg) translateY(-1px);
  }

  .mobile-menu nav{
    position:absolute;
    right:0;
    top:52px;
    width:min(310px, calc(100vw - 32px));
    padding:10px;
    border-radius:16px;
    border:1px solid rgba(16,31,51,.12);
    background:#fff;
    box-shadow:0 18px 50px rgba(8,20,38,.18);
  }

  .mobile-menu nav a{
    display:block;
    padding:12px 13px;
    border-radius:10px;
    color:#102033;
    font-size:14px;
    font-weight:750;
    text-decoration:none;
  }

  .mobile-menu nav a:hover{
    background:#f3f6fb;
    color:var(--orange);
  }

  .hero .section,
  .light-hero .section{
    padding-top:30px !important;
    padding-bottom:44px !important;
  }

  .section{
    padding-top:46px !important;
    padding-bottom:46px !important;
  }

  h1{
    font-size:clamp(36px, 10vw, 48px) !important;
  }

  .lead{
    font-size:17px !important;
    line-height:1.55 !important;
  }

  .hero-collage{
    margin-top:8px;
  }

  .hero-collage .image{
    min-height:210px !important;
  }
}

@media(max-width:480px){
  .nav{
    gap:10px;
  }

  .brand-logo{
    width:min(230px, 66vw) !important;
    max-width:66vw !important;
  }

  .mobile-menu summary{
    min-height:40px;
    padding:9px 13px;
    font-size:12px;
  }

  .hero .section,
  .light-hero .section{
    padding-top:24px !important;
  }

  .hero-collage .image{
    min-height:190px !important;
  }
}
