/* ==========================================================================
   MED BILLS — Design Tokens
   Ledger-statement aesthetic: navy + claims-paper cream, oxidized teal accent.
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&family=Inter:wght@400;500;600;700;800&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

:root{
  /* Color */
  --navy:        #0F2438;
  --navy-deep:   #081522;
  --paper:       #F7F3EC;
  --paper-dim:   #EFE9DD;
  --ink:         #1C1B19;
  --ink-soft:    #4A4742;
  --teal:        #1A6B5C;
  --teal-deep:   #134F44;
  --teal-bright: #2E9683;
  --clay:        #B8602F;
  --clay-soft:   #E8DCC9;
  --line:        rgba(28,27,25,0.12);
  --line-on-navy:rgba(247,243,236,0.16);

  /* Type */
  --f-display: 'Fraunces', Georgia, serif;
  --f-body:    'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --f-mono:    'IBM Plex Mono', 'SF Mono', monospace;

  /* Scale */
  --container: 1180px;
  --radius: 3px;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--f-body);
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4{ font-family:var(--f-display); margin:0; font-weight:600; line-height:1.08; letter-spacing:-0.01em; }
p{ margin:0; }
button{ font-family:inherit; cursor:pointer; }

:focus-visible{ outline:2px solid var(--teal-bright); outline-offset:3px; }

.wrap{ max-width:var(--container); margin:0 auto; padding:0 32px; }

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

/* ---------- Eyebrow / mono labels ---------- */
.eyebrow{
  font-family:var(--f-mono);
  font-size:12px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--teal);
  display:flex;
  align-items:center;
  gap:10px;
}
.eyebrow::before{
  content:'';
  width:18px; height:1px;
  background:var(--teal);
  display:inline-block;
}
.eyebrow.on-navy{ color:var(--teal-bright); }
.eyebrow.on-navy::before{ background:var(--teal-bright); }

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky; top:0; z-index:100;
  background:var(--navy);
  border-bottom:1px solid var(--line-on-navy);
}
.nav-row{
  display:flex; align-items:center; justify-content:space-between;
  height:76px;
}
.brand{
  display:flex; align-items:center; gap:10px;
  font-family:var(--f-display); font-weight:700; font-size:21px;
  color:var(--paper);
}
.brand img{ height:34px; width:auto; display:block; }
.brand .mark{
  color:var(--teal-bright);
  font-family:var(--f-mono);
  font-size:14px;
  border:1px solid var(--teal-bright);
  padding:2px 6px;
  border-radius:2px;
  letter-spacing:0;
}
.nav-links{ display:flex; align-items:center; gap:28px; }
.nav-links a{
  font-size:14px; font-weight:500; color:rgba(247,243,236,0.78);
  transition:color .15s ease;
  position:relative;
}
.nav-links a:hover{ color:var(--paper); }
.nav-links a.active{ color:var(--paper); }
.nav-links a.active::after{
  content:''; position:absolute; left:0; right:0; bottom:-28px;
  height:2px; background:var(--teal-bright);
}
.nav-cta{
  font-family:var(--f-mono); font-size:13px; font-weight:500;
  color:var(--navy); background:var(--teal-bright);
  padding:10px 20px; border-radius:2px;
  border:1px solid var(--teal-bright);
  transition:background .15s ease, color .15s ease;
}
.nav-cta:hover{ background:transparent; color:var(--teal-bright); }
.nav-toggle{ display:none; }

/* ---------- Mega menu ---------- */
.has-mega{ position:relative; }
.has-mega > a{ display:flex; align-items:center; gap:5px; }
.mega-caret{ width:8px; height:8px; border-right:1.5px solid currentColor; border-bottom:1.5px solid currentColor; transform:rotate(45deg) translateY(-2px); opacity:0.7; transition:transform .15s ease; }
.has-mega:hover .mega-caret{ transform:rotate(225deg) translateY(2px); }

.mega-panel{
  position:absolute; top:calc(100% + 1px); left:50%; transform:translateX(-50%) translateY(8px);
  width:620px; background:var(--paper); border:1px solid var(--line); border-radius:6px;
  box-shadow:0 30px 60px -20px rgba(8,21,34,0.35);
  padding:22px; opacity:0; pointer-events:none; transition:opacity .15s ease, transform .15s ease;
  z-index:50;
}
.has-mega:hover .mega-panel{ opacity:1; pointer-events:auto; transform:translateX(-50%) translateY(0); }
.mega-grid{ display:grid; grid-template-columns:1fr 1fr; gap:4px; }
.mega-item{
  display:flex; flex-direction:column; gap:3px; padding:12px 14px; border-radius:4px;
  color:var(--ink); transition:background .12s ease;
}
.mega-item:hover{ background:var(--paper-dim); }
.mega-item .mi-num{ font-family:var(--f-mono); font-size:10.5px; color:var(--teal); }
.mega-item .mi-title{ font-size:14px; font-weight:600; color:var(--ink); }
.mega-item .mi-desc{ font-size:12px; color:var(--ink-soft); line-height:1.4; }
.mega-foot{ margin-top:14px; padding-top:14px; border-top:1px solid var(--line); display:flex; justify-content:space-between; align-items:center; }
.mega-foot a{ font-family:var(--f-mono); font-size:12px; color:var(--teal-deep); }
.mega-foot a:hover{ color:var(--teal); }

@media (max-width:1080px){
  .mega-panel{ position:static !important; transform:none !important; width:100% !important; left:auto !important; box-shadow:none; border:none; background:transparent; padding:8px 0 0; opacity:1 !important; pointer-events:auto; display:none; }
  .has-mega.open .mega-panel{ display:block; }
  .has-mega:hover .mega-panel{ transform:none !important; }
  .mega-grid{ grid-template-columns:1fr; }
  .mega-caret{ display:none; }
}

@media (max-width: 1080px){
  .nav-links{
    position:fixed; inset:76px 0 0 0; background:var(--navy);
    flex-direction:column; align-items:flex-start; gap:0;
    padding:8px 32px 32px;
    transform:translateY(-8px); opacity:0; pointer-events:none;
    transition:opacity .18s ease, transform .18s ease;
    overflow-y:auto;
  }
  .nav-links.open{ opacity:1; pointer-events:auto; transform:translateY(0); }
  .nav-links a{ width:100%; padding:16px 0; border-bottom:1px solid var(--line-on-navy); }
  .nav-links a.active::after{ display:none; }
  .nav-cta{ margin-top:20px; display:inline-block; }
  .nav-toggle{
    display:flex; flex-direction:column; gap:5px; background:none; border:0; padding:8px;
  }
  .nav-toggle span{ width:22px; height:2px; background:var(--paper); display:block; }
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--f-mono); font-size:13px; font-weight:500; letter-spacing:0.02em;
  padding:14px 26px; border-radius:2px; border:1px solid transparent;
  transition:transform .15s ease, background .15s ease, color .15s ease, border-color .15s ease;
}
.btn:hover{ transform:translateY(-1px); }
.btn-primary{ background:var(--teal); color:var(--paper); border-color:var(--teal); }
.btn-primary:hover{ background:var(--teal-deep); border-color:var(--teal-deep); }
.btn-ghost-navy{ background:transparent; color:var(--paper); border-color:var(--line-on-navy); }
.btn-ghost-navy:hover{ border-color:var(--teal-bright); color:var(--teal-bright); }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn-ghost:hover{ border-color:var(--teal); color:var(--teal); }
.btn-arrow{ transition:transform .15s ease; }
.btn:hover .btn-arrow{ transform:translateX(3px); }

/* ---------- Hero ---------- */
.hero{
  background:var(--navy);
  color:var(--paper);
  position:relative;
  overflow:hidden;
  padding:88px 0 0;
}
.hero::before{
  content:'';
  position:absolute; inset:0;
  background-image:
    linear-gradient(var(--line-on-navy) 1px, transparent 1px),
    linear-gradient(90deg, var(--line-on-navy) 1px, transparent 1px);
  background-size:64px 64px;
  opacity:0.6;
  -webkit-mask-image:linear-gradient(180deg, rgba(0,0,0,0.4), transparent 65%);
  mask-image:linear-gradient(180deg, rgba(0,0,0,0.4), transparent 65%);
  pointer-events:none;
}
.hero-inner{ position:relative; display:grid; grid-template-columns:1.1fr 0.9fr; gap:48px; align-items:end; }
.hero h1{
  font-size:clamp(36px, 4.6vw, 60px);
  color:var(--paper);
  margin-top:18px;
}
.hero h1 em{ font-style:italic; color:var(--teal-bright); }
.hero-sub{
  font-size:17px; color:rgba(247,243,236,0.72);
  max-width:46ch; margin-top:20px; line-height:1.6;
}
.hero-ctas{ display:flex; gap:14px; margin-top:34px; flex-wrap:wrap; }

.hero-figure{
  position:relative;
  padding-bottom:48px;
}

/* ---------- Hero slider ---------- */
.hero-slider{ position:relative; }
.hero-slide{
  position:absolute; inset:0;
  opacity:0; pointer-events:none; visibility:hidden;
  transition:opacity .5s ease;
}
.hero-slide.is-active{
  position:relative; opacity:1; pointer-events:auto; visibility:visible;
}
.hero-slide-photo{
  border-radius:6px; overflow:hidden;
  box-shadow:0 30px 60px -20px rgba(0,0,0,0.5);
  aspect-ratio:16/10.4;
}
.hero-slide-photo img{
  width:100%; height:100%; object-fit:cover; display:block;
}
.hero-dots{
  display:flex; gap:8px; justify-content:center;
  position:absolute; left:0; right:0; bottom:14px;
}
.hero-dot{
  width:7px; height:7px; border-radius:50%;
  background:rgba(247,243,236,0.35); border:none; padding:0; cursor:pointer;
  transition:background .15s ease, transform .15s ease;
}
.hero-dot.is-active{ background:var(--teal-bright); transform:scale(1.3); }
.hero-dot:hover{ background:rgba(247,243,236,0.6); }

.claim-card{
  background:var(--paper);
  color:var(--ink);
  border-radius:4px;
  padding:26px 26px 22px;
  box-shadow:0 30px 60px -20px rgba(0,0,0,0.5);
  font-family:var(--f-mono);
}
.claim-card .cc-head{
  display:flex; justify-content:space-between; align-items:center;
  font-size:11px; letter-spacing:0.08em; text-transform:uppercase; color:var(--ink-soft);
  border-bottom:1px solid var(--line); padding-bottom:14px; margin-bottom:16px;
}
.claim-card .cc-status{ color:var(--teal); font-weight:600; }
.claim-row{ display:flex; justify-content:space-between; font-size:13px; padding:9px 0; border-bottom:1px dashed var(--line); }
.claim-row:last-of-type{ border-bottom:none; }
.claim-row .lbl{ color:var(--ink-soft); }
.claim-row .val{ font-weight:600; }
.claim-total{
  display:flex; justify-content:space-between; align-items:baseline;
  margin-top:16px; padding-top:16px; border-top:1px solid var(--ink);
}
.claim-total .lbl{ font-size:12px; letter-spacing:0.06em; text-transform:uppercase; color:var(--ink-soft); font-family:var(--f-mono); }
.claim-total .val{ font-size:26px; font-weight:700; font-family:var(--f-display); color:var(--teal-deep); }

/* ---------- Ledger strip (signature element) ---------- */
.ledger{
  background:var(--navy);
  color:var(--paper);
  font-family:var(--f-mono);
  border-top:1px solid var(--line-on-navy);
}
.ledger-inner{
  display:grid; grid-template-columns:repeat(4,1fr);
}
.ledger-item{
  padding:30px 28px;
  border-right:1px solid rgba(247,243,236,0.14);
}
.ledger-item:last-child{ border-right:none; }
.ledger-num{ font-size:28px; font-weight:600; color:var(--teal-bright); letter-spacing:-0.02em; }
.ledger-label{ font-size:11.5px; color:rgba(247,243,236,0.62); margin-top:6px; letter-spacing:0.03em; line-height:1.4; }

@media (max-width: 860px){
  .ledger-inner{ grid-template-columns:repeat(2,1fr); }
  .ledger-item{ border-bottom:1px solid rgba(247,243,236,0.14); }
}

/* ---------- Section scaffolding ---------- */
section{ padding:96px 0; }
.section-head{ max-width:640px; margin-bottom:56px; }
.section-head h2{ font-size:clamp(28px,3.2vw,40px); margin-top:16px; color:var(--ink); }
.section-head p{ margin-top:16px; font-size:16px; color:var(--ink-soft); line-height:1.65; }
.section-head.center{ margin-left:auto; margin-right:auto; text-align:center; }
.section-head.center .eyebrow{ justify-content:center; }
.section-head.center .eyebrow::before{ display:none; }

.section-dark{ background:var(--navy); color:var(--paper); border-top:1px solid var(--line-on-navy); border-bottom:1px solid var(--line-on-navy); }
.section-dark .section-head h2{ color:var(--paper); }
.section-dark .section-head p{ color:rgba(247,243,236,0.68); }
.section-paper-dim{ background:var(--paper-dim); }

/* ---------- Pain / problem grid ---------- */
.pain-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.pain-card{ background:var(--paper); padding:36px 32px; }
.pain-card .pc-tag{ font-family:var(--f-mono); font-size:11px; color:var(--clay); letter-spacing:0.06em; text-transform:uppercase; }
.pain-card h3{ font-size:19px; margin-top:14px; color:var(--ink); }
.pain-card p{ font-size:14.5px; color:var(--ink-soft); margin-top:10px; line-height:1.6; }

@media (max-width:860px){ .pain-grid{ grid-template-columns:1fr; } }

/* ---------- Process / claim lifecycle ---------- */
.process{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; counter-reset:step; position:relative; }
.process::before{
  content:''; position:absolute; top:34px; left:0; right:0; height:1px; background:var(--line);
}
.step{ position:relative; padding-right:24px; }
.step-num{
  width:68px; height:68px; border-radius:50%;
  background:var(--paper); border:1px solid var(--line);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--f-mono); font-size:13px; color:var(--teal); font-weight:600;
  position:relative; z-index:1; margin-bottom:22px;
}
.step h4{ font-size:16.5px; color:var(--ink); }
.step p{ font-size:14px; color:var(--ink-soft); margin-top:8px; line-height:1.55; }

@media (max-width:860px){
  .process{ grid-template-columns:1fr; gap:36px; }
  .process::before{ display:none; }
}

/* ---------- Services grid ---------- */
.svc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.svc-card{
  border:1px solid var(--line); border-radius:4px; padding:32px 28px;
  background:var(--paper); transition:border-color .15s ease, transform .15s ease, box-shadow .4s ease;
  scroll-margin-top:100px;
}
.svc-card:hover{ border-color:var(--teal); transform:translateY(-3px); }
.svc-card:target{ box-shadow:0 0 0 2px var(--teal-bright); }
.svc-index{ font-family:var(--f-mono); font-size:12px; color:var(--teal); }
.svc-card h3{ font-size:20px; margin-top:14px; color:var(--ink); }
.svc-card p{ font-size:14.5px; color:var(--ink-soft); margin-top:12px; line-height:1.6; }
.svc-meta{ margin-top:18px; padding-top:16px; border-top:1px dashed var(--line); font-family:var(--f-mono); font-size:11.5px; color:var(--ink-soft); }

@media (max-width:980px){ .svc-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:640px){ .svc-grid{ grid-template-columns:1fr; } }

/* ---------- Quote / proof block ---------- */
.proof-block{ display:grid; grid-template-columns:0.9fr 1.1fr; gap:64px; align-items:center; }
.proof-figure{
  background:var(--navy); color:var(--paper); border-radius:6px; padding:40px;
  font-family:var(--f-mono);
}
.proof-figure .pf-row{ display:flex; justify-content:space-between; padding:14px 0; border-bottom:1px solid rgba(247,243,236,0.14); font-size:13.5px; }
.proof-figure .pf-row:last-child{ border-bottom:none; }
.proof-figure .pf-row .val{ color:var(--teal-bright); font-weight:600; }

@media (max-width:900px){ .proof-block{ grid-template-columns:1fr; } }

/* ---------- Logo / client strip ---------- */
.client-strip{
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:28px;
  padding:28px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line);
}
.client-strip span{ font-family:var(--f-mono); font-size:13px; color:var(--ink-soft); letter-spacing:0.02em; }

/* ---------- CTA band ---------- */
.cta-band{
  background:var(--teal-deep); color:var(--paper);
  border-radius:6px; padding:64px 56px;
  display:flex; align-items:center; justify-content:space-between; gap:40px; flex-wrap:wrap;
}
.cta-band h2{ font-size:clamp(24px,3vw,34px); color:var(--paper); max-width:18ch; }
.cta-band p{ color:rgba(247,243,236,0.75); margin-top:10px; max-width:42ch; }

/* ---------- Footer social icons ---------- */
.footer-social{
  display:flex; align-items:center; gap:14px;
  padding:24px 0 20px; border-top:1px solid var(--line-on-navy);
  margin-top:0;
}
.footer-social a{
  width:36px; height:36px; border-radius:50%;
  border:1px solid var(--line-on-navy);
  display:flex; align-items:center; justify-content:center;
  color:rgba(247,243,236,0.55);
  transition:border-color .15s ease, color .15s ease, background .15s ease;
}
.footer-social a:hover{ border-color:var(--teal-bright); color:var(--teal-bright); background:rgba(46,150,131,0.08); }
.footer-social svg{ width:16px; height:16px; fill:currentColor; display:block; }

/* ---------- Footer ---------- */
.site-footer{ background:var(--navy-deep); color:rgba(247,243,236,0.62); padding:64px 0 28px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; padding-bottom:48px; border-bottom:1px solid var(--line-on-navy); }
.footer-grid h5{ font-family:var(--f-mono); font-size:11.5px; letter-spacing:0.08em; text-transform:uppercase; color:rgba(247,243,236,0.45); margin-bottom:18px; }
.footer-grid li{ margin-bottom:11px; font-size:14px; }
.footer-grid a:hover{ color:var(--teal-bright); }
.footer-brand{ font-family:var(--f-display); font-size:20px; color:var(--paper); margin-bottom:14px; }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; padding-top:24px; font-size:12.5px; flex-wrap:wrap; gap:12px; }

@media (max-width:860px){
  .footer-grid{ grid-template-columns:1fr 1fr; }
}

/* ---------- Page hero (interior pages) ---------- */
.page-hero{ background:var(--navy); color:var(--paper); padding:128px 0 64px; position:relative; overflow:hidden; }
.page-hero::before{
  content:'';
  position:absolute; inset:0;
  background-image:linear-gradient(var(--line-on-navy) 1px, transparent 1px), linear-gradient(90deg, var(--line-on-navy) 1px, transparent 1px);
  background-size:64px 64px;
  opacity:0.6;
  -webkit-mask-image:linear-gradient(180deg, rgba(0,0,0,0.35), transparent 65%);
  mask-image:linear-gradient(180deg, rgba(0,0,0,0.35), transparent 65%);
}
.page-hero-inner{ position:relative; }
.page-hero h1{ font-size:clamp(32px,4.2vw,48px); color:var(--paper); margin-top:16px; max-width:18ch; }
.page-hero p{ margin-top:16px; color:rgba(247,243,236,0.7); max-width:56ch; font-size:16px; line-height:1.65; }
.breadcrumb{ font-family:var(--f-mono); font-size:12px; color:rgba(247,243,236,0.5); list-style:none; padding:0; margin:0; display:flex; align-items:center; gap:8px; }
.breadcrumb li::after{ content:'/'; margin-left:8px; opacity:0.5; }
.breadcrumb li:last-child::after{ display:none; }
.breadcrumb a{ color:rgba(247,243,236,0.5); }
.breadcrumb a:hover{ color:var(--teal-bright); }

/* ---------- People strip (human touch) ---------- */
.people-strip{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.person-card{
  border:1px solid var(--line); border-radius:4px; padding:24px;
  background:var(--paper); text-align:left;
}
.person-avatar{
  width:52px; height:52px; border-radius:50%;
  background:var(--teal-deep); color:var(--paper);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--f-display); font-weight:600; font-size:18px;
  margin-bottom:16px;
}
.person-card h4{ font-size:15.5px; color:var(--ink); }
.person-card .role{ font-family:var(--f-mono); font-size:11.5px; color:var(--teal); margin-top:4px; letter-spacing:0.02em; }
.person-card p{ font-size:13.5px; color:var(--ink-soft); margin-top:10px; line-height:1.55; }

@media (max-width:980px){ .people-strip{ grid-template-columns:1fr 1fr; } }
@media (max-width:640px){ .people-strip{ grid-template-columns:1fr; } }

/* ---------- Legal pages ---------- */
.legal-body{ max-width:760px; }
.legal-body h2{ font-size:22px; color:var(--ink); margin-top:44px; margin-bottom:14px; }
.legal-body h2:first-child{ margin-top:0; }
.legal-body p{ font-size:15px; color:var(--ink-soft); line-height:1.75; margin-bottom:14px; }
.legal-body ul{ margin-bottom:14px; }
.legal-body li{ font-size:15px; color:var(--ink-soft); line-height:1.75; padding-left:22px; position:relative; margin-bottom:8px; }
.legal-body li::before{ content:'—'; position:absolute; left:0; color:var(--teal); }
.legal-updated{ font-family:var(--f-mono); font-size:12px; color:var(--ink-soft); margin-bottom:32px; display:block; }

/* ---------- Form status ---------- */
.form-status{ font-family:var(--f-mono); font-size:13px; margin-top:14px; display:none; padding:12px 14px; border-radius:3px; }
.form-status.show{ display:block; }
.form-status.ok{ background:rgba(26,107,92,0.1); color:var(--teal-deep); border:1px solid rgba(26,107,92,0.25); }
.form-status.err{ background:rgba(184,96,47,0.1); color:var(--clay); border:1px solid rgba(184,96,47,0.25); }
.grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; }
@media (max-width:860px){ .grid-2{ grid-template-columns:1fr; gap:36px; } }

.tag-list{ display:flex; flex-wrap:wrap; gap:10px; margin-top:18px; }
.tag{
  font-family:var(--f-mono); font-size:12px; padding:7px 14px; border:1px solid var(--line);
  border-radius:20px; color:var(--ink-soft);
}

.divider{ height:1px; background:var(--line); margin:0; }

/* Form */
.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.form-grid .full{ grid-column:1 / -1; }
.field label{ display:block; font-family:var(--f-mono); font-size:11.5px; text-transform:uppercase; letter-spacing:0.06em; color:var(--ink-soft); margin-bottom:8px; }
.field input, .field select, .field textarea{
  width:100%; border:1px solid var(--line); background:var(--paper); border-radius:2px;
  padding:13px 14px; font-family:var(--f-body); font-size:14.5px; color:var(--ink);
  transition:border-color .15s ease;
}
.field input:focus, .field select:focus, .field textarea:focus{ border-color:var(--teal); outline:none; }
.field textarea{ resize:vertical; min-height:120px; }

@media (max-width:700px){ .form-grid{ grid-template-columns:1fr; } }

/* Contact info card */
.info-row{ display:flex; gap:16px; padding:20px 0; border-bottom:1px solid var(--line); }
.info-row:last-child{ border-bottom:none; }
.info-row .ico{
  width:38px; height:38px; border-radius:50%; background:var(--teal-deep); color:var(--paper);
  display:flex; align-items:center; justify-content:center; font-family:var(--f-mono); font-size:13px; flex-shrink:0;
}
.info-row h4{ font-size:14px; color:var(--ink); margin-bottom:4px; }
.info-row p{ font-size:14px; color:var(--ink-soft); }

/* About — timeline */
.timeline{ position:relative; padding-left:32px; }
.timeline::before{ content:''; position:absolute; left:5px; top:6px; bottom:6px; width:1px; background:var(--line); }
.t-item{ position:relative; padding-bottom:40px; }
.t-item:last-child{ padding-bottom:0; }
.t-item::before{
  content:''; position:absolute; left:-32px; top:4px; width:11px; height:11px; border-radius:50%;
  background:var(--paper); border:2px solid var(--teal);
}
.t-year{ font-family:var(--f-mono); font-size:12px; color:var(--teal); letter-spacing:0.04em; }
.t-item h4{ font-size:17px; margin-top:6px; color:var(--ink); }
.t-item p{ font-size:14.5px; color:var(--ink-soft); margin-top:6px; line-height:1.6; max-width:56ch; }

/* ---------- Track record cards (light variant) ---------- */
.track-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.track-card{
  background:var(--paper); border:1px solid var(--line); border-radius:6px;
  padding:32px 28px; transition:border-color .15s ease, transform .15s ease;
}
.track-card:hover{ border-color:var(--teal); transform:translateY(-2px); }
.track-mark{
  width:44px; height:44px; border-radius:50%;
  background:var(--teal-deep); color:var(--paper);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--f-mono); font-size:13px; font-weight:600;
  margin-bottom:18px;
}
.track-card h3{ font-size:18px; color:var(--ink); }
.track-card p{ font-size:14px; color:var(--ink-soft); margin-top:10px; line-height:1.6; }

@media (max-width:860px){ .track-grid{ grid-template-columns:1fr; } }

/* Values grid (about) */
.values-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.value-card h3{ font-size:18px; color:var(--paper); }
.value-card .vi{ font-family:var(--f-mono); font-size:24px; color:var(--teal-bright); }
.value-card p{ font-size:14px; color:rgba(247,243,236,0.65); margin-top:10px; line-height:1.6; }
@media (max-width:860px){ .values-grid{ grid-template-columns:1fr; } }

/* Responsive section padding */
@media (max-width:700px){
  section{ padding:64px 0; }
  .hero{ padding:140px 0 0; }
  .hero-inner{ grid-template-columns:1fr; }
  .ledger-inner{ grid-template-columns:1fr 1fr; }
  .pain-grid{ grid-template-columns:1fr; }
  .cta-band{ padding:40px 28px; flex-direction:column; align-items:flex-start; }
}
