:root{
  --green:#0c4a3b;
  --green2:#09251e;
  --gold:#c99b4a;
  --paper:#f6efe0;
  --ink:#151b18;
  --muted:#606961;
  --navy:#07131e;
}

*{box-sizing:border-box}

html{scroll-behavior:smooth}

body{
  margin:0;
  font-family:Inter,system-ui,sans-serif;
  background:var(--navy);
  color:#fff;
  overflow-x:hidden;
}

body:before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  opacity:.28;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 250 250' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.7' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.25'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}

/* FIXED FULL-WIDTH NAVBAR */

.header{
  position:fixed;
  top:0;
  left:0;
  width:100%;
  height:86px;

  display:flex;
  align-items:center;
  justify-content:space-between;

  padding:0 max(5vw,48px);

  z-index:9999;

  background:var(--paper);
  border-bottom:1px solid rgba(201,155,74,.22);

  box-shadow:0 8px 28px rgba(0,0,0,.10);
}

.brand{
  display:flex;
  align-items:center;
  text-decoration:none;
}

.brand img{
  height: 90px;px;
  width:auto;
  display:block;
  object-fit:contain;
}

.brand span{
  width:46px;
  height:46px;
  border-radius:50%;

  display:grid;
  place-items:center;

  background:linear-gradient(135deg,#0b3d32,#0f5a48);
  color:#d8b164;

  font:700 24px "Cormorant Garamond",serif;
  border:none;
}

.brand b{
  font-size:17px;
  color:var(--ink);
  font-weight:700;
}

.brand em{
  color:#9a6625;
  font-style:italic;
}

nav{
  display:flex;
  align-items:center;
  gap:34px;
}

nav a{
  color:#333a38;
  text-decoration:none;
  font-size:15px;
  font-weight:700;
  transition:.25s;
}

nav a:hover{
  color:var(--green);
}

/* CONFIDENTIAL DISCUSSION BUTTON */

.pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;

  padding:13px 24px;
  border-radius:999px;

  background:transparent;
  border:1px solid rgba(201,155,74,.65);

  color:#c99b4a;

  font-weight:800;
  transition:.25s ease;
}

.pill:hover{
  background:var(--green);
  border-color:var(--green);
  color:#f7e7b5;
}

/* HERO */

.hero{
  min-height:100vh;
  position:relative;

  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(360px,.75fr);
  align-items:center;
  gap:44px;

  padding:176px max(5vw,48px) 90px;

  background:
    radial-gradient(circle at 80% 20%,rgba(201,155,74,.24),transparent 28%),
    linear-gradient(135deg,#08131e 0%,#09221d 55%,#06100e 100%);
}

.hero-bg{
  position:absolute;
  inset:0;

  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:72px 72px;
  mask-image:linear-gradient(to bottom,#000,transparent 90%);
}

.hero-copy,
.hero-card{
  position:relative;
  z-index:1;
}

.kicker,
.section-label{
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:12px;
  font-weight:800;
  color:var(--gold);
  margin:0 0 18px;
}

.kicker:before{
  content:"";
  display:inline-block;
  width:34px;
  height:1px;
  background:var(--gold);
  margin-right:10px;
  vertical-align:middle;
}

h1,h2,h3{
  font-family:'Cormorant Garamond',serif;
  line-height:1.02;
  margin:0;
}

h1{
  font-size:clamp(56px,8vw,116px);
  letter-spacing:-.06em;
  max-width:960px;

  background:linear-gradient(135deg,#fff9e6,#d6ad61 50%,#fff0c6);
  -webkit-background-clip:text;
  color:transparent;
}

h2{
  font-size:clamp(42px,5.6vw,78px);
  letter-spacing:-.045em;
}

h3{font-size:34px}

.lead{
  font-size:20px;
  line-height:1.65;
  color:rgba(255,255,255,.72);
  max-width:710px;
  margin:28px 0 0;
}

.actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-top:34px;
}

.btn{
  border:0;
  border-radius:999px;
  padding:15px 21px;
  text-decoration:none;
  font-weight:800;

  display:inline-flex;
  align-items:center;
  justify-content:center;

  cursor:pointer;
}

.primary{
  background:linear-gradient(135deg,#d6ad61,#f4d895,#b37832);
  color:#111b12;
  box-shadow:0 18px 45px rgba(201,155,74,.28);
}

.secondary{
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.08);
  color:#fff;
}

.badges{
  display:flex;
  gap:9px;
  flex-wrap:wrap;
  margin-top:28px;
}

.badges span{
  font-size:12px;
  border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.07);
  padding:9px 12px;
  border-radius:999px;
  color:rgba(255,255,255,.78);
}

/* HERO CARDS */

.hero-card{height:560px}

.glass-card,
.stat{
  position:absolute;
  border:1px solid rgba(255,255,255,.14);
  background:linear-gradient(145deg,rgba(255,255,255,.15),rgba(255,255,255,.055));
  backdrop-filter:blur(22px);
  box-shadow:0 30px 95px rgba(0,0,0,.32);
}

.large{
  left:0;
  right:42px;
  top:54px;
  border-radius:34px;
  padding:38px;
  min-height:330px;
}

.large small{
  color:var(--gold);
  letter-spacing:.16em;
  text-transform:uppercase;
  font-weight:800;
}

.large h3{
  font-size:46px;
  margin:35px 0;
  color:#fff;
}

.large span{
  display:inline-flex;
  margin:0 6px 8px 0;
  padding:9px 12px;
  border-radius:999px;
  border:1px solid rgba(201,155,74,.32);
  color:#f2d89c;
  font-size:12px;
}

.stat{
  border-radius:24px;
  padding:22px;
}

.stat b{
  display:block;
  font-family:'Cormorant Garamond',serif;
  font-size:38px;
  color:var(--gold);
  line-height:1;
}

.stat small{color:rgba(255,255,255,.68)}

.s1{
  right:0;
  top:8px;
}

.s2{
  left:22px;
  bottom:55px;
}

/* TICKER */

.ticker{
  display:flex;
  gap:36px;
  overflow:hidden;
  white-space:nowrap;

  padding:18px max(5vw,48px);

  border-block:1px solid rgba(201,155,74,.18);
  background:rgba(255,255,255,.045);

  color:#e5c17c;
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:12px;
  font-weight:800;
}

/* SECTIONS */

.section{
  padding:108px max(5vw,48px);
}

.light{
  background:var(--paper);
  color:var(--ink);
}

.dark{
  background:linear-gradient(180deg,#07131e,#0b1e2c);
  color:#fff;
}

.split{
  display:grid;
  grid-template-columns:280px 1fr;
  gap:70px;
}

.split p:not(.section-label){
  color:var(--muted);
  font-size:18px;
  line-height:1.7;
  max-width:850px;
}

.grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-top:52px;
}

.cards article{
  min-height:270px;
  padding:32px;
  border-radius:28px;
  border:1px solid rgba(255,255,255,.11);
  background:
    radial-gradient(circle at top right,rgba(201,155,74,.18),transparent 40%),
    rgba(255,255,255,.06);
}

.cards b,
.timeline b{
  color:var(--gold);
}

.cards h3{
  margin:24px 0 14px;
}

.cards p,
.timeline p,
.contact p{
  color:rgba(255,255,255,.68);
  line-height:1.65;
}

/* OUR APPROACH SECTION */

.approach-panel{
  display:grid;
  grid-template-columns:1fr 420px;
  gap:64px;
  align-items:center;

  max-width:1180px;
  margin:0 auto;

  padding:56px 58px;

  border-radius:32px;
  background:#fff8ea;
  border:1px solid rgba(112,77,32,.14);

  box-shadow:0 22px 70px rgba(74,48,16,.10);
}

.approach-copy{
  max-width:700px;
}

.approach-copy h2{
  margin-bottom:20px;
}

.approach-copy p:not(.kicker){
  max-width:680px;
  color:var(--muted);
  font-size:17px;
  line-height:1.65;
}

.approach-list{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.approach-item{
  position:relative;

  display:grid;
  grid-template-columns:52px 1fr;
  align-items:center;
  gap:16px;

  min-height:84px;
  padding:20px 24px;

  border-radius:18px;

  background:linear-gradient(135deg,#0b3d32,#0f5a48);
  border:1px solid rgba(12,74,59,.65);

  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.05),
    0 12px 28px rgba(12,74,59,.18);

  transition:all .25s ease;
}

.approach-item::before{
  content:"";
  position:absolute;
  left:0;
  top:18px;
  bottom:18px;
  width:4px;
  border-radius:4px;
  background:linear-gradient(180deg,#f1d38b,#c89b46);
}

.approach-item:hover{
  transform:translateX(6px);
  background:linear-gradient(135deg,#04221b,#126351);
}

.approach-item b{
  color:#d8b164;
  font-size:15px;
  font-weight:800;
  letter-spacing:.04em;
}

.approach-item span{
  color:#f5e3b0;
  font-size:18px;
  font-weight:600;
  letter-spacing:-.02em;
}

/* OLD STEPS IF STILL USED */

.panel{
  display:grid;
  grid-template-columns:minmax(0,1fr) 440px;
  gap:64px;
  align-items:center;
  background:#fff8ea;
  border:1px solid rgba(112,77,32,.15);
  border-radius:32px;
  padding:48px 56px;
  box-shadow:0 24px 70px rgba(74,48,16,.1);
}

.panel p{
  color:var(--muted);
  line-height:1.7;
  max-width:720px;
}

.steps{
  display:grid;
  gap:14px;
}

.steps p{
  margin:0;
  padding:19px;
  border-radius:20px;
  background:linear-gradient(135deg,#11281f,#0b4b3b);
  color:#fff;
}

.steps b{
  color:var(--gold);
  margin-right:12px;
}

/* TIMELINE */

.timeline{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  margin-top:52px;
  border-radius:28px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.11);
}

.timeline div{
  padding:28px;
  min-height:230px;
  background:rgba(255,255,255,.055);
  border-right:1px solid rgba(255,255,255,.1);
}

.timeline div:last-child{border:0}

.timeline h3{
  font-size:27px;
  margin:20px 0 12px;
}

/* LEADERSHIP */

.leadership .leader-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px;
  margin-top:48px;
}

.leader-grid article{
  padding:36px;
  border-radius:30px;
  background:#fff8ea;
  border:1px solid rgba(112,77,32,.15);
  box-shadow:0 24px 70px rgba(74,48,16,.1);
}

.avatar{
  width:78px;
  height:78px;
  border-radius:22px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,var(--green),#06130f);
  color:var(--gold);
  font:700 30px 'Cormorant Garamond',serif;
  margin-bottom:26px;
}

.leader-grid strong{
  display:block;
  color:#9a6625;
  margin:10px 0 14px;
}

.leader-grid p{
  color:var(--muted);
  line-height:1.65;
}

/* CONTACT */

.contact{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:60px;
}

.contact form{
  display:grid;
  gap:14px;
}

.contact input,
.contact select,
.contact textarea{
  width:100%;
  border:1px solid rgba(255,255,255,.14);
  border-radius:16px;
  padding:16px;
  font:inherit;
  background:rgba(255,255,255,.08);
  color:#fff;
  outline:none;
}

.contact input::placeholder,
.contact textarea::placeholder{
  color:rgba(255,255,255,.55);
}

.contact select{
  color:rgba(255,255,255,.75);
}

/* FOOTER */

.footer{
    background:#06100e;
    border-top:1px solid rgba(255,255,255,.08);
    padding:32px max(5vw,48px);
    color:rgba(255,255,255,.70);
}

.footer-top{
    display:flex;
    justify-content:space-between;
    align-items:center;
    margin-bottom:18px;
    flex-wrap:wrap;
    gap:10px;
}

.footer-top strong{
    color:#f7e7b5;
    font-size:17px;
    font-weight:700;
}

.footer-top span{
    color:#c99b4a;
    font-size:14px;
    letter-spacing:.05em;
}

.footer-disclaimer{
    margin:0;
    font-size:13px;
    line-height:1.8;
    color:rgba(255,255,255,.60);
    max-width:1100px;
}

.footer small{
    display:block;
    margin-top:18px;
    color:rgba(255,255,255,.45);
    font-size:12px;
}

/* RESPONSIVE */

@media(max-width:1050px){
  nav{display:none}

  .hero,
  .split,
  .panel,
  .contact,
  .approach-panel{
    grid-template-columns:1fr;
  }

  .hero-card{height:450px}

  .grid,
  .timeline,
  .leader-grid{
    grid-template-columns:1fr!important;
  }

  .timeline div{
    border-right:0;
    border-bottom:1px solid rgba(255,255,255,.1);
    min-height:auto;
  }

  .section{
    padding:82px 28px;
  }

  .hero{
    padding:150px 28px 70px;
  }

  .ticker{
    padding-inline:28px;
  }
}

@media(max-width:620px){
  .header{
    height:70px;
    padding:0 18px;
  }

  .brand b{font-size:14px}

  .brand span{
    width:38px;
    height:38px;
  }

  .hero-card{height:430px}

  .large{
    right:0;
    padding:25px;
  }

  .large h3{font-size:34px}

  .s1{
    right:0;
    top:0;
  }

  .s2{
    left:0;
    bottom:20px;
  }

  .actions .btn{
    width:100%;
  }

  footer{
    display:block;
  }

  .panel,
  .approach-panel{
    padding:28px;
    gap:32px;
  }

  .approach-item{
    grid-template-columns:42px 1fr;
    padding:17px 18px;
    min-height:72px;
  }

  .approach-item span{
    font-size:15px;
  }
}