/* ============================================================
   PATRIOT MANAGEMENT GROUP LLC — Site Stylesheet
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Source+Serif+4:opsz,wght@8..60,400;8..60,600;8..60,700;8..60,900&family=Public+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@500;600&display=swap');

:root{
  --navy:        #0A2540;
  --navy-2:      #0F3159;
  --navy-3:      #123B6B;
  --red:         #9E2323;
  --red-2:       #C22E2E;
  --blue:        #1F6FB2;
  --blue-ice:    #6FA8D6;
  --parchment:   #F3F0E8;
  --parchment-2: #EAE5D8;
  --ink:         #1B2126;
  --slate:       #5C6672;
  --line:        #DBD4C4;
  --line-dark:   #21395B;
  --white:       #FFFFFF;

  --serif: 'Source Serif 4', Georgia, serif;
  --sans: 'Public Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --mono: 'IBM Plex Mono', 'SF Mono', monospace;

  --maxw: 1180px;
}

*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  margin:0;
  font-family: var(--sans);
  color: var(--ink);
  background: var(--parchment);
  -webkit-font-smoothing: antialiased;
}
img{ max-width:100%; display:block; }
a{ color: inherit; text-decoration:none; }
h1,h2,h3,h4{ font-family: var(--serif); margin:0; color: var(--navy); }
p{ margin:0; }
ul{ margin:0; padding:0; list-style:none; }

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

/* ---------- Utility banner (signature strip) ---------- */
.utility-bar{
  background: var(--navy);
  color: #B9C9DC;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .11em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--line-dark);
}
.utility-bar .wrap{
  display:flex;
  justify-content: space-between;
  align-items:center;
  padding-top:8px;
  padding-bottom:8px;
  flex-wrap: wrap;
  gap:6px;
}
.utility-bar b{ color:#fff; font-weight:600; }
.utility-bar .seg{ display:flex; gap:22px; flex-wrap:wrap; }
.utility-bar .dot{ color: var(--red-2); }

/* ---------- Header ---------- */
header.site-header{
  background: var(--parchment);
  border-bottom: 1px solid var(--line);
  position: sticky;
  top:0;
  z-index: 50;
}
header.site-header .wrap{
  display:flex;
  align-items:center;
  justify-content: space-between;
  padding-top:16px;
  padding-bottom:16px;
}
.brand{ display:flex; align-items:center; gap:12px; }
.brand img{ height:40px; width:auto; }
.brand-text{ font-family: var(--serif); font-weight:700; font-size:17px; color: var(--navy); line-height:1.15; }
.brand-text span{ display:block; font-family: var(--mono); font-size:9.5px; letter-spacing:.14em; color: var(--slate); font-weight:500; margin-top:2px; }

nav.main-nav ul{ display:flex; gap:34px; align-items:center; }
nav.main-nav a{
  font-size: 14.5px;
  font-weight: 600;
  color: var(--navy);
  position:relative;
  padding: 4px 0;
}
nav.main-nav a.active{ color: var(--red); }
nav.main-nav a.active::after{
  content:"";
  position:absolute; left:0; right:0; bottom:-4px;
  height:2px; background: var(--red);
}
nav.main-nav a:not(.active):hover{ color: var(--blue); }

.nav-cta{
  background: var(--navy);
  color:#fff !important;
  padding: 10px 20px;
  border-radius: 3px;
  font-size: 13.5px;
  letter-spacing:.02em;
}
.nav-cta:hover{ background: var(--red); color:#fff; }

.menu-toggle{ display:none; background:none; border:none; cursor:pointer; padding:6px; }
.menu-toggle span{ display:block; width:24px; height:2px; background:var(--navy); margin:5px 0; }

/* ---------- Eyebrow / badges ---------- */
.badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 7px 14px;
  border: 1px solid rgba(255,255,255,.35);
  border-radius: 2px;
  color: #DCE7F2;
}
.badge.on-light{ border-color: var(--line); color: var(--navy-2); background: rgba(31,111,178,.06); }
.badge .sq{ width:6px; height:6px; background: var(--red-2); display:inline-block; }

/* ---------- Hero ---------- */
.hero{
  background: linear-gradient(155deg, var(--navy) 0%, var(--navy-2) 55%, var(--navy-3) 100%);
  color:#fff;
  position:relative;
  overflow:hidden;
  padding: 84px 0 96px;
}
.hero::before{
  content:"";
  position:absolute;
  right:-120px; top:-80px;
  width:620px; height:620px;
  background: url('../assets/motif.svg') no-repeat center / contain;
  opacity:.14;
  pointer-events:none;
}
.hero .wrap{ position:relative; z-index:2; display:grid; grid-template-columns: 1.15fr .85fr; gap:56px; align-items:center; }
.hero h1{
  color:#fff;
  font-size: clamp(34px, 4.4vw, 52px);
  line-height:1.12;
  font-weight:700;
  margin: 20px 0 22px;
  max-width: 620px;
}
.hero h1 em{ font-style:normal; color: var(--blue-ice); }
.hero p.lede{
  color:#C7D4E3;
  font-size:16.5px;
  line-height:1.65;
  max-width: 540px;
  margin-bottom: 34px;
}
.hero-actions{ display:flex; gap:14px; flex-wrap:wrap; }
.btn{
  display:inline-block;
  font-family: var(--sans);
  font-weight:700;
  font-size:14.5px;
  padding: 14px 26px;
  border-radius:3px;
  border: 1.5px solid transparent;
  cursor:pointer;
}
.btn-primary{ background: var(--red-2); color:#fff; }
.btn-primary:hover{ background: #AD2828; }
.btn-outline{ border-color: rgba(255,255,255,.5); color:#fff; }
.btn-outline:hover{ border-color:#fff; background: rgba(255,255,255,.08); }
.btn-outline.on-light{ border-color: var(--navy); color: var(--navy); }
.btn-outline.on-light:hover{ background: var(--navy); color:#fff; }

.hero-panel{
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.18);
  border-radius:4px;
  padding: 26px 26px 10px;
}
.hero-panel .panel-label{ font-family: var(--mono); font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:#8FAAC7; margin-bottom:18px; display:block;}
.hero-panel .snap-row{ display:flex; justify-content:space-between; padding:13px 0; border-top:1px solid rgba(255,255,255,.12); font-size:13.5px; }
.hero-panel .snap-row:first-of-type{ border-top:none; }
.hero-panel .snap-row .k{ color:#9FB4CB; }
.hero-panel .snap-row .v{ color:#fff; font-weight:600; text-align:right; }

/* ---------- Section scaffolding ---------- */
section{ padding: 88px 0; }
.section-head{ max-width: 700px; margin-bottom: 46px; }
.eyebrow{
  font-family: var(--mono);
  font-size: 11.5px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--red);
  display:flex; align-items:center; gap:10px;
  margin-bottom: 14px;
}
.eyebrow::before{ content:""; width:26px; height:2px; background: var(--red); display:inline-block; }
.eyebrow.on-dark{ color: var(--blue-ice); }
.eyebrow.on-dark::before{ background: var(--blue-ice); }
h2.section-title{ font-size: clamp(26px,3vw,36px); line-height:1.2; }
.section-sub{ color: var(--slate); font-size:15.5px; margin-top:14px; line-height:1.65; }

.on-navy{ background: var(--navy); color:#fff; }
.on-navy h2, .on-navy h3, .on-navy h4{ color:#fff; }
.on-navy .section-sub{ color:#AFC0D3; }
.on-parchment-2{ background: var(--parchment-2); }

/* ---------- Capability "case file" cards ---------- */
.capability{
  display:grid;
  grid-template-columns: 92px 1fr;
  gap: 26px;
  border: 1px solid var(--line);
  background: var(--white);
  border-radius: 4px;
  padding: 28px 30px;
  margin-bottom: 18px;
  position:relative;
}
.capability::before{
  content: attr(data-tag);
  position:absolute;
  top:-11px; left:26px;
  background: var(--navy);
  color:#DCE7F2;
  font-family: var(--mono);
  font-size:10px;
  letter-spacing:.12em;
  padding:4px 10px;
  border-radius:2px;
}
.cap-icon{
  width:64px; height:64px;
  border-radius:4px;
  display:flex; align-items:center; justify-content:center;
  background: var(--navy);
}
.cap-icon.red{ background: var(--red); }
.cap-icon svg{ width:30px; height:30px; }
.capability h3{ font-size:20px; margin-bottom:9px; }
.capability p{ color: var(--slate); font-size:15px; line-height:1.65; margin-bottom:13px; }
.tag-row{ display:flex; flex-wrap:wrap; gap:8px 18px; }
.tag-row span{
  font-family: var(--mono);
  font-size:10.5px;
  letter-spacing:.06em;
  text-transform: uppercase;
  color: var(--blue);
  font-weight:600;
}
.tag-row span:not(:last-child)::after{ content:"·"; margin-left:18px; color: var(--line); }

/* ---------- Stat band ---------- */
.stat-band{
  background: var(--navy-2);
  border-top:1px solid var(--line-dark);
  border-bottom:1px solid var(--line-dark);
  padding: 46px 0 38px;
}
.stat-grid{ display:grid; grid-template-columns: repeat(4,1fr); gap:0; }
.stat{ text-align:center; padding: 0 18px; border-left:1px solid rgba(255,255,255,.14); }
.stat:first-child{ border-left:none; }
.stat .num{ font-family: var(--serif); font-size: clamp(26px,3vw,36px); font-weight:700; color:#fff; }
.stat .num.red{ color: var(--red-2); }
.stat .lab{ font-size:12.5px; color:#9FB4CB; margin-top:8px; line-height:1.5; }
.stat-disclaimer{ text-align:center; font-size:11.5px; color:#7C93AC; margin-top:26px; font-style:italic; }

/* ---------- Checklist grid ---------- */
.check-grid{ display:grid; grid-template-columns: 1fr 1fr; gap: 26px 44px; }
.check-item{ display:flex; gap:14px; }
.check-item .mark{
  flex-shrink:0; width:26px; height:26px; border-radius:3px;
  background: var(--blue); color:#fff; display:flex; align-items:center; justify-content:center;
  font-size:14px; font-weight:700; margin-top:2px;
}
.check-item h4{ font-size:16px; margin-bottom:5px; color: var(--navy); }
.check-item p{ font-size:14px; color: var(--slate); line-height:1.6; }

/* ---------- Leadership cards ---------- */
.lead-grid{ display:grid; grid-template-columns: repeat(3,1fr); gap:20px; }
.lead-card{ background:#fff; border:1px solid var(--line); border-radius:4px; padding:26px; }
.lead-card .li-icon{
  width:42px; height:42px; border-radius:50%;
  background: var(--navy); color:#fff;
  display:flex; align-items:center; justify-content:center;
  margin-bottom:16px; font-family:var(--mono); font-size:15px; font-weight:700;
}
.lead-card.red .li-icon{ background: var(--red); }
.lead-card h4{ font-size:15.5px; margin-bottom:9px; letter-spacing:.01em; }
.lead-card p{ font-size:13.8px; color: var(--slate); line-height:1.6; }

/* ---------- Snapshot table ---------- */
.snapshot-box{ background: var(--navy); border-radius:4px; padding:34px 38px; color:#fff; }
.snap-grid{ display:grid; grid-template-columns: 1fr 1fr; gap: 24px 40px; }
.snap-grid .k{ font-family: var(--mono); font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; color:#8FAAC7; margin-bottom:6px; }
.snap-grid .v{ font-size:15px; font-weight:600; }

/* ---------- CTA band ---------- */
.cta-band{
  background: linear-gradient(120deg, var(--navy) 0%, var(--navy-3) 100%);
  color:#fff;
  padding: 66px 0;
  text-align:center;
}
.cta-band h2{ color:#fff; margin-bottom:16px; }
.cta-band p{ color:#C7D4E3; max-width:560px; margin: 0 auto 30px; font-size:15.5px; line-height:1.6; }
.cta-actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ---------- Footer ---------- */
footer.site-footer{ background: var(--navy); color:#B9C9DC; padding: 56px 0 0; }
.footer-grid{ display:grid; grid-template-columns: 1.4fr 1fr 1fr; gap:40px; padding-bottom:40px; border-bottom:1px solid var(--line-dark); }
.footer-brand .brand-text{ color:#fff; }
.footer-brand .brand-text span{ color:#8FAAC7; }
.footer-brand p{ margin-top:16px; font-size:13.5px; line-height:1.7; color:#9FB4CB; max-width:320px; }
.footer-col h5{ font-family: var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:#8FAAC7; margin-bottom:16px; }
.footer-col li{ margin-bottom:11px; font-size:14px; }
.footer-col a:hover{ color:#fff; }
.footer-bottom{
  display:flex; justify-content:space-between; align-items:center;
  padding: 20px 0 26px; font-size:11.5px; color:#7C93AC; flex-wrap:wrap; gap:10px;
  font-family: var(--mono); letter-spacing:.02em;
}

/* ---------- Page hero (interior pages) ---------- */
.page-hero{
  background: linear-gradient(155deg, var(--navy) 0%, var(--navy-2) 100%);
  color:#fff; padding: 62px 0 58px; position:relative; overflow:hidden;
}
.page-hero::before{
  content:"";
  position:absolute; right:-100px; top:-100px; width:420px; height:420px;
  background: url('../assets/motif.svg') no-repeat center / contain;
  opacity:.12;
}
.page-hero .wrap{ position:relative; z-index:2; }
.page-hero h1{ color:#fff; font-size: clamp(30px,3.6vw,44px); margin: 16px 0 14px; max-width:680px; }
.page-hero p{ color:#C7D4E3; max-width:600px; font-size:15.5px; line-height:1.65; }

/* ---------- Contact page ---------- */
.contact-grid{ display:grid; grid-template-columns: 1fr 1fr; gap:50px; }
.info-card{ background:#fff; border:1px solid var(--line); border-radius:4px; padding:24px 26px; margin-bottom:16px; display:flex; gap:16px; align-items:flex-start; }
.info-card .ic{ width:38px; height:38px; border-radius:50%; background: var(--navy); flex-shrink:0; display:flex; align-items:center; justify-content:center; }
.info-card .ic svg{ width:18px; height:18px; }
.info-card h4{ font-size:14.5px; color: var(--navy); margin-bottom:5px; }
.info-card p, .info-card a{ font-size:14.5px; color: var(--slate); line-height:1.5; }
.info-card a:hover{ color: var(--blue); }

form.contact-form{ background:#fff; border:1px solid var(--line); border-radius:4px; padding:32px; }
.form-row{ margin-bottom:18px; }
.form-row label{ display:block; font-size:12.5px; font-weight:600; text-transform:uppercase; letter-spacing:.06em; color: var(--navy); margin-bottom:7px; font-family: var(--mono); }
.form-row input, .form-row select, .form-row textarea{
  width:100%; padding:12px 14px; border:1px solid var(--line); border-radius:3px;
  font-family: var(--sans); font-size:14.5px; color: var(--ink); background: var(--parchment);
}
.form-row input:focus, .form-row select:focus, .form-row textarea:focus{ outline:2px solid var(--blue); outline-offset:1px; }
.form-row textarea{ resize: vertical; min-height:120px; }
.two-col{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-note{ font-size:12.5px; color: var(--slate); margin-top:14px; }

/* ---------- Responsive ---------- */
@media (max-width: 920px){
  .hero .wrap{ grid-template-columns: 1fr; }
  .hero-panel{ order:-1; }
  .stat-grid{ grid-template-columns: 1fr 1fr; row-gap:28px; }
  .stat{ border-left:none; }
  .check-grid{ grid-template-columns: 1fr; }
  .lead-grid{ grid-template-columns: 1fr 1fr; }
  .footer-grid{ grid-template-columns: 1fr 1fr; }
  .contact-grid{ grid-template-columns:1fr; }
  .snap-grid{ grid-template-columns: 1fr; }
}
@media (max-width: 680px){
  nav.main-nav{ display:none; position:absolute; top:100%; left:0; right:0; background: var(--parchment); border-bottom:1px solid var(--line); padding:14px 32px 22px; }
  nav.main-nav.open{ display:block; }
  nav.main-nav ul{ flex-direction:column; align-items:flex-start; gap:16px; }
  .menu-toggle{ display:block; }
  .capability{ grid-template-columns: 1fr; }
  .lead-grid{ grid-template-columns: 1fr; }
  .footer-grid{ grid-template-columns: 1fr; }
  .two-col{ grid-template-columns: 1fr; }
  .utility-bar .seg{ gap:12px; }
}
