:root{
  --ink:#0B1E2D;
  --panel:#142C3F;
  --panel-2:#102536;
  --gold:#C9A86A;
  --parchment:#EDE7DC;
  --slate:#7A8B96;
  --pine:#1F4A3D;
  --rule: rgba(237,231,220,0.14);
  --rule-strong: rgba(201,168,106,0.45);
}

*{margin:0;padding:0;box-sizing:border-box;}

html{scroll-behavior:smooth;}

body{
  background:var(--ink);
  color:var(--parchment);
  font-family:'Inter',sans-serif;
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.01ms !important; animation-iteration-count:1 !important; transition-duration:0.01ms !important; scroll-behavior:auto !important;}
}

a{color:inherit; text-decoration:none;}
:focus-visible{outline:2px solid var(--gold); outline-offset:3px;}

.wrap{max-width:1120px; margin:0 auto; padding:0 28px;}

h1,h2,h3{font-family:'Fraunces',serif; font-weight:500; letter-spacing:-0.01em;}

.mono{font-family:'JetBrains Mono', monospace;}

/* ---------- Header ---------- */
header{
  position:fixed; top:0; left:0; right:0; z-index:50;
  background:rgba(11,30,45,0.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--rule);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 28px;
  max-width:1120px; margin:0 auto;
}
.brand{
  display:flex; align-items:center; gap:10px;
  font-family:'Fraunces',serif; font-weight:600; font-size:1.05rem;
  letter-spacing:0.01em;
}
.brand .mark{
  width:11px;height:11px;border:1.5px solid var(--gold);
  transform:rotate(45deg); flex-shrink:0;
}
nav.links{display:flex; gap:32px; align-items:center;}
nav.links a{
  font-size:0.875rem; color:var(--slate); transition:color .25s ease;
  letter-spacing:0.01em;
}
nav.links a:hover, nav.links a.active{color:var(--parchment);}
.nav-cta{
  font-size:0.8rem; font-weight:500; color:var(--ink) !important;
  background:var(--gold); padding:9px 18px; border-radius:2px;
  letter-spacing:0.02em;
}
.nav-cta:hover{background:#dabb7e;}

.menu-btn{display:none; background:none; border:none; color:var(--parchment); font-size:1.5rem; cursor:pointer;}

@media (max-width: 760px){
  nav.links{
    position:fixed; top:62px; left:0; right:0; bottom:0;
    background:var(--ink); flex-direction:column; justify-content:flex-start;
    padding:36px 28px; gap:26px; display:none;
    border-top:1px solid var(--rule);
    z-index:60;
    overflow-y:auto;
  }
  nav.links.open{display:flex;}
  .menu-btn{display:block; position:relative; z-index:61;}
}

/* ---------- Page hero (sub-pages) ---------- */
.page-hero{
  position:relative;
  padding:158px 0 70px;
  overflow:hidden;
  border-bottom:1px solid var(--rule);
}
.page-hero::before{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 600px 400px at 85% 0%, rgba(201,168,106,0.10), transparent 60%),
    radial-gradient(ellipse 500px 500px at 0% 100%, rgba(31,74,61,0.18), transparent 60%);
  pointer-events:none;
}
.page-hero h1{
  font-size:clamp(2rem, 4.2vw, 3.2rem);
  line-height:1.08;
  max-width:740px;
  color:var(--parchment);
}
.page-hero p.lede{
  margin-top:22px; max-width:560px; font-size:1.05rem; color:var(--slate);
}

/* ---------- Hero (home only) ---------- */
.hero{
  position:relative;
  padding:168px 0 110px;
  overflow:hidden;
  border-bottom:1px solid var(--rule);
}
.hero::before{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 600px 400px at 85% 0%, rgba(201,168,106,0.10), transparent 60%),
    radial-gradient(ellipse 500px 500px at 0% 100%, rgba(31,74,61,0.18), transparent 60%);
  pointer-events:none;
}
.eyebrow{
  font-family:'JetBrains Mono',monospace; font-size:0.78rem; color:var(--gold);
  letter-spacing:0.12em; text-transform:uppercase; margin-bottom:22px;
  display:flex; align-items:center; gap:10px;
}
.eyebrow::before{content:"§"; opacity:0.7;}

.hero h1{
  font-size:clamp(2.4rem, 5.2vw, 4.1rem);
  line-height:1.06;
  max-width:780px;
  color:var(--parchment);
}
.hero h1 em{font-style:italic; color:var(--gold); font-weight:500;}

.hero p.lede{
  margin-top:26px; max-width:540px; font-size:1.08rem; color:var(--slate);
}

.hero-ctas{display:flex; gap:16px; margin-top:42px; flex-wrap:wrap;}
.btn-primary, .btn-secondary{
  display:inline-flex; align-items:center; gap:8px;
  padding:14px 26px; font-size:0.92rem; font-weight:500;
  border-radius:2px; transition:all .25s ease; letter-spacing:0.01em;
}
.btn-primary{background:var(--gold); color:var(--ink);}
.btn-primary:hover{background:#dabb7e; transform:translateY(-1px);}
.btn-secondary{border:1px solid var(--rule-strong); color:var(--parchment);}
.btn-secondary:hover{border-color:var(--gold); color:var(--gold);}

/* Ledger line — signature element */
.ledger{
  margin-top:80px;
  border-top:1px solid var(--rule);
}
.ledger-row{
  display:grid; grid-template-columns: 28px 1fr auto;
  gap:18px; align-items:baseline;
  padding:15px 0;
  border-bottom:1px solid var(--rule);
  opacity:0; transform:translateY(8px);
  animation: ledgerIn 0.6s ease forwards;
}
.ledger-row:nth-child(1){animation-delay:0.15s;}
.ledger-row:nth-child(2){animation-delay:0.35s;}
.ledger-row:nth-child(3){animation-delay:0.55s;}
.ledger-row:nth-child(4){animation-delay:0.75s; border-bottom:none;}
@keyframes ledgerIn{to{opacity:1; transform:translateY(0);}}

.ledger-row .idx{font-family:'JetBrains Mono',monospace; font-size:0.78rem; color:var(--slate);}
.ledger-row .label{font-size:0.95rem; color:var(--parchment);}
.ledger-row .val{font-family:'JetBrains Mono',monospace; font-size:0.85rem; color:var(--gold); text-align:right; white-space:nowrap;}

/* ---------- Section shared ---------- */
section{padding:108px 0;}
.section-head{max-width:620px; margin-bottom:64px;}
.section-head .eyebrow{margin-bottom:18px;}
.section-head h2{font-size:clamp(1.8rem,3.4vw,2.6rem); color:var(--parchment);}
.section-head p{color:var(--slate); margin-top:18px; font-size:1.02rem;}

/* ---------- Services ---------- */
.services{border-bottom:1px solid var(--rule);}
.service-list{border-top:1px solid var(--rule);}
.service{
  display:grid; grid-template-columns: 1.1fr 2fr;
  gap:48px;
  padding:46px 0;
  border-bottom:1px solid var(--rule);
}
.service .stitle{
  font-family:'Fraunces',serif; font-size:1.5rem; color:var(--parchment);
}
.service .stitle .num{
  display:block; font-family:'JetBrains Mono',monospace; font-size:0.78rem;
  color:var(--gold); margin-bottom:10px; letter-spacing:0.05em;
}
.service .sbody p{color:var(--slate); font-size:1rem; max-width:520px;}
.service .sbody ul{margin-top:18px; display:flex; flex-direction:column; gap:10px;}
.service .sbody li{
  font-size:0.92rem; color:var(--parchment); display:flex; gap:10px; align-items:baseline;
}
.service .sbody li::before{content:"—"; color:var(--gold); flex-shrink:0;}

@media (max-width:760px){
  .service{grid-template-columns:1fr; gap:18px;}
}

/* ---------- About ---------- */
.about{border-bottom:1px solid var(--rule); background:var(--panel-2);}
.about-grid{display:grid; grid-template-columns: 1.3fr 1fr; gap:64px; align-items:start;}
.about p{color:var(--slate); font-size:1.02rem; margin-bottom:18px; max-width:560px;}
.about p strong{color:var(--parchment); font-weight:500;}

.cred-card{
  background:var(--panel); border:1px solid var(--rule); border-radius:2px;
  padding:30px;
}
.cred-card .ct{font-family:'JetBrains Mono',monospace; font-size:0.72rem; color:var(--gold); letter-spacing:0.1em; text-transform:uppercase; margin-bottom:20px;}
.cred-row{display:flex; justify-content:space-between; padding:11px 0; border-bottom:1px solid var(--rule); font-size:0.88rem;}
.cred-row:last-child{border-bottom:none;}
.cred-row .k{color:var(--slate);}
.cred-row .v{font-family:'JetBrains Mono',monospace; color:var(--parchment); text-align:right;}

@media (max-width:760px){.about-grid{grid-template-columns:1fr; gap:40px;}}

/* ---------- Insurance ---------- */
.insurance{border-bottom:1px solid var(--rule); background:var(--panel-2);}
.insurance-grid{display:grid; grid-template-columns:1.3fr 1fr; gap:64px; align-items:start;}
.insurance p{color:var(--slate); font-size:1rem; max-width:540px; margin-bottom:18px;}
.insurance p strong{color:var(--parchment); font-weight:500;}
@media (max-width:760px){.insurance-grid{grid-template-columns:1fr; gap:36px;}}

/* ---------- Who We Serve ---------- */
.who{border-bottom:1px solid var(--rule);}
.who-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--rule); border:1px solid var(--rule);}
.who-card{background:var(--ink); padding:34px 30px;}
.who-card .num{display:block; font-size:0.78rem; color:var(--gold); margin-bottom:16px; letter-spacing:0.05em;}
.who-card h3{font-size:1.1rem; color:var(--parchment); margin-bottom:10px; font-weight:500;}
.who-card p{color:var(--slate); font-size:0.92rem;}
@media (max-width:900px){.who-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:600px){.who-grid{grid-template-columns:1fr;}}

/* ---------- FAQ ---------- */
.faq{border-bottom:1px solid var(--rule);}
.faq-list{border-top:1px solid var(--rule);}
.faq-item{border-bottom:1px solid var(--rule); padding:22px 0;}
.faq-item summary{
  cursor:pointer; font-family:'Fraunces',serif; font-size:1.08rem; color:var(--parchment);
  list-style:none; display:flex; justify-content:space-between; align-items:center; gap:20px;
}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::after{
  content:"+"; font-family:'Inter',sans-serif; font-size:1.3rem; color:var(--gold);
  flex-shrink:0; transition:transform .25s ease;
}
.faq-item[open] summary::after{transform:rotate(45deg);}
.faq-item p{color:var(--slate); font-size:0.95rem; margin-top:16px; max-width:680px;}

/* ---------- Contact form ---------- */
.contact-section{border-bottom:1px solid var(--rule);}
.contact-grid{display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start;}
.form-field{margin-bottom:20px;}
.form-field label{display:block; font-size:0.82rem; color:var(--slate); margin-bottom:8px; letter-spacing:0.01em;}
.form-field input, .form-field textarea{
  width:100%; background:var(--panel); border:1px solid var(--rule); color:var(--parchment);
  padding:13px 15px; font-family:'Inter',sans-serif; font-size:0.95rem; border-radius:2px;
  transition:border-color .2s ease;
}
.form-field input:focus, .form-field textarea:focus{border-color:var(--gold); outline:none;}
.form-field textarea{resize:vertical; min-height:110px;}
.form-submit{
  background:var(--gold); color:var(--ink); border:none; padding:14px 28px;
  font-size:0.92rem; font-weight:500; border-radius:2px; cursor:pointer;
  transition:background .25s ease; letter-spacing:0.01em;
}
.form-submit:hover{background:#dabb7e;}
.form-submit:disabled{opacity:0.6; cursor:not-allowed;}
.form-status{margin-top:16px; font-size:0.88rem;}
.form-status.success{color:#8fbf9f;}
.form-status.error{color:#d98a8a;}

@media (max-width:760px){.contact-grid{grid-template-columns:1fr; gap:40px;}}

/* ---------- CTA band ---------- */
.cta-band{
  border-bottom:1px solid var(--rule);
  position:relative;
}
.cta-band::before{
  content:"";
  position:absolute; inset:0;
  background:radial-gradient(ellipse 700px 300px at 50% 0%, rgba(201,168,106,0.08), transparent 65%);
  pointer-events:none;
}
.cta-inner{text-align:center; max-width:680px; margin:0 auto;}
.cta-inner h2{font-size:clamp(1.9rem,4vw,2.8rem); margin-bottom:20px;}
.cta-inner p{color:var(--slate); font-size:1.05rem; margin-bottom:38px;}

/* ---------- Contact / Footer ---------- */
footer{padding:80px 0 40px;}
.foot-grid{display:grid; grid-template-columns: 1.2fr 1fr 1fr; gap:48px; padding-bottom:56px; border-bottom:1px solid var(--rule);}
.foot-col h3{font-family:'JetBrains Mono',monospace; font-size:0.72rem; color:var(--gold); letter-spacing:0.1em; text-transform:uppercase; margin-bottom:20px; font-weight:500;}
.foot-col p, .foot-col a{color:var(--slate); font-size:0.92rem; display:block; margin-bottom:10px; transition:color .2s ease;}
.foot-col a:hover{color:var(--parchment);}
.foot-brand{font-family:'Fraunces',serif; font-size:1.2rem; color:var(--parchment); margin-bottom:14px;}
.foot-bottom{
  display:flex; justify-content:space-between; align-items:center;
  padding-top:28px; font-size:0.8rem; color:var(--slate); flex-wrap:wrap; gap:12px;
}
@media (max-width:760px){.foot-grid{grid-template-columns:1fr; gap:36px;}}
