/*
Theme Name: VPU Field Manifest
Theme URI: https://veteranspatriotsunited.org
Author: Veterans & Patriots United
Description: Custom theme for Veterans & Patriots United, built around the "Field Manifest" design system — navy/brass/canvas palette, stencil headers, manifest-style content blocks.
Version: 1.0
Requires PHP: 7.4
Text Domain: vpu-field-manifest
*/

/* ============================================================
   VETERANS & PATRIOTS UNITED — SITE DESIGN SYSTEM
   "Field Manifest" theme
   Shared by: index.html, our-story.html, our-vision.html,
              calendar.html, donate.html
   ============================================================ */

:root{
  --navy:        #1B2430;
  --navy-deep:   #131A23;
  --canvas:      #EFE7D4;
  --canvas-line: #DCD0B4;
  --paper:       #F8F4E9;
  --brass:       #B5872E;
  --brass-light: #D7AC52;
  --rescue:      #8C3B2E;
  --rescue-light:#B5594A;
  --ink:         #211C12;
  --ink-soft:    #4A4636;
  --white:       #FFFFFF;
  --radius: 2px;
  --max: 1080px;
}

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

body{
  margin:0;
  background:var(--canvas);
  color:var(--ink);
  font-family:'Source Serif 4', Georgia, serif;
  line-height:1.55;
}

.eyebrow{
  font-family:'JetBrains Mono', monospace;
  font-size:0.72rem;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--brass);
  font-weight:500;
}

h1,h2,h3,h4{
  font-family:'Oswald', sans-serif;
  text-transform:uppercase;
  letter-spacing:0.01em;
  color:var(--navy);
  margin:0;
}

a{color:inherit;}
img{max-width:100%; display:block;}

:focus-visible{
  outline: 3px solid var(--brass);
  outline-offset: 3px;
}

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

/* ===== Top info strip ===== */
.topstrip{
  background:var(--navy-deep);
  color:var(--canvas);
  font-family:'JetBrains Mono', monospace;
  font-size:0.7rem;
  letter-spacing:0.08em;
  text-transform:uppercase;
  padding:8px 0;
}
.topstrip .wrap{display:flex; justify-content:space-between; flex-wrap:wrap; gap:6px;}
.topstrip span{opacity:0.75;}

/* ===== Site nav ===== */
.nav{
  background:var(--navy-deep);
  border-bottom:2px solid var(--brass);
  position:sticky;
  top:0;
  z-index:50;
}
.nav-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 24px;
}
.nav-logo{
  font-family:'Oswald', sans-serif;
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
}
.nav-logo img{
  height:32px;
  width:auto;
  display:block;
}
.nav-logo-text{
  display:flex;
  flex-direction:column;
  line-height:1.1;
}
.nav-logo-text .name{
  font-size:1.05rem;
  font-weight:600;
  color:var(--paper);
  letter-spacing:0.04em;
  text-transform:uppercase;
}
.nav-logo-text .tag{
  font-family:'JetBrains Mono', monospace;
  font-size:0.58rem;
  letter-spacing:0.1em;
  color:var(--brass-light);
  text-transform:uppercase;
  margin-top:4px;
}
.nav-toggle{
  display:none;
  background:transparent;
  border:1px solid var(--brass);
  color:var(--brass-light);
  font-family:'JetBrains Mono', monospace;
  font-size:0.7rem;
  letter-spacing:0.08em;
  text-transform:uppercase;
  padding:8px 14px;
  cursor:pointer;
}
.nav-links{
  list-style:none;
  display:flex;
  gap:28px;
  margin:0;
  padding:0;
  align-items:center;
}
.nav-links a{
  font-family:'JetBrains Mono', monospace;
  font-size:0.76rem;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#C7C0AC;
  text-decoration:none;
  padding-bottom:4px;
  border-bottom:2px solid transparent;
  transition:color .15s ease, border-color .15s ease;
}
.nav-links a:hover,
.nav-links a[aria-current="page"],
.nav-links .current-menu-item > a,
.nav-links .current_page_item > a{
  color:var(--brass-light);
  border-color:var(--brass-light);
}
.nav-give{
  background:var(--brass);
  color:var(--navy-deep) !important;
  padding:8px 16px !important;
  border-radius:var(--radius);
  border-bottom:none !important;
}
.nav-give:hover{background:var(--brass-light); color:var(--navy-deep) !important;}

@media (max-width:820px){
  .nav-toggle{display:inline-flex;}
  .nav-links{
    position:absolute;
    top:100%; left:0; right:0;
    background:var(--navy-deep);
    flex-direction:column;
    align-items:flex-start;
    gap:0;
    border-bottom:2px solid var(--brass);
    max-height:0;
    overflow:hidden;
    transition:max-height .25s ease;
  }
  .nav-links.open{max-height:340px;}
  .nav-links li{width:100%;}
  .nav-links a{display:block; padding:14px 24px; border-bottom:1px solid rgba(255,255,255,0.06) !important;}
  .nav-give{margin:10px 24px; display:inline-block; width:calc(100% - 48px); text-align:center;}
}

/* ===== Generic hero ===== */
.hero{
  position:relative;
  overflow:hidden;
  color:var(--canvas);
  padding:72px 0 64px;
}
.hero::before{
  content:"";
  position:absolute; inset:0;
  background-image:var(--hero-photo, url('https://veteranspatriotsunited.org/wp-content/uploads/2022/01/IMG_1571.webp'));
  background-size:cover;
  background-position:center;
  filter:grayscale(55%) brightness(0.5) contrast(1.05);
  z-index:0;
}
.hero::after{
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(160deg, rgba(27,36,48,0.78), rgba(19,26,35,0.9)),
    repeating-linear-gradient(135deg, rgba(255,255,255,0.025) 0 2px, transparent 2px 14px);
  z-index:1;
}
.hero-inner{position:relative; z-index:2;}
.hero.hero-compact{padding:54px 0 48px;}

.badge{
  display:inline-flex; align-items:center; gap:8px;
  border:1px solid var(--brass);
  color:var(--brass-light);
  font-family:'JetBrains Mono', monospace;
  font-size:0.7rem;
  letter-spacing:0.14em;
  text-transform:uppercase;
  padding:6px 14px;
  margin-bottom:26px;
}
.badge::before{
  content:"";
  width:7px; height:7px; border-radius:50%;
  background:var(--brass-light);
}

.hero h1{
  color:var(--paper);
  font-size:clamp(2.1rem, 5vw, 3.6rem);
  line-height:1.04;
  max-width:780px;
  font-weight:600;
}
.hero h1 em{font-style:normal; color:var(--brass-light);}
.hero p.lede{
  font-family:'Source Serif 4', serif;
  font-size:1.18rem;
  max-width:600px;
  color:#D9D3C2;
  margin-top:22px;
}
.hero-cta{
  margin-top:36px;
  display:flex;
  flex-wrap:wrap;
  gap:16px;
  align-items:center;
}
.hero-note{
  margin-top:18px;
  font-family:'JetBrains Mono', monospace;
  font-size:0.72rem;
  letter-spacing:0.04em;
  color:#9B9582;
}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:'JetBrains Mono', monospace;
  font-size:0.85rem;
  letter-spacing:0.06em;
  text-transform:uppercase;
  text-decoration:none;
  padding:15px 28px;
  border-radius:var(--radius);
  border:1px solid transparent;
  cursor:pointer;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.btn:hover{transform:translateY(-2px);}
.btn-brass{background:var(--brass); color:var(--navy-deep); font-weight:500;}
.btn-brass:hover{box-shadow:0 8px 22px -8px rgba(213,172,82,0.55);}
.btn-ghost{background:transparent; border-color:rgba(239,231,212,0.35); color:var(--canvas);}
.btn-ghost:hover{border-color:var(--brass-light); color:var(--brass-light);}
.btn-rescue{background:var(--rescue); color:var(--paper);}
.btn-rescue:hover{box-shadow:0 8px 22px -8px rgba(140,59,46,0.55);}
.btn-navy{background:var(--navy); color:var(--paper);}
.btn-navy:hover{box-shadow:0 8px 22px -8px rgba(27,36,48,0.5);}
.btn-outline-dark{background:transparent; border-color:var(--navy); color:var(--navy);}
.btn-outline-dark:hover{background:var(--navy); color:var(--paper);}

/* ===== Section scaffolding ===== */
section{padding:64px 0;}
.section-tight{padding:44px 0;}
.section-head{margin-bottom:36px; max-width:680px;}
.section-head h2{font-size:clamp(1.5rem,3vw,2.1rem); margin-top:10px;}
.section-head p{color:var(--ink-soft); margin-top:14px; font-size:1.05rem;}
.section-alt{background:var(--paper);}

/* ===== Two-up grid (fund cards, vision split, etc.) ===== */
.grid-2{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1px;
  background:var(--canvas-line);
  border:1px solid var(--canvas-line);
}
@media(max-width:760px){.grid-2{grid-template-columns:1fr;}}

.grid-3{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1px;
  background:var(--canvas-line);
  border:1px solid var(--canvas-line);
}
@media(max-width:900px){.grid-3{grid-template-columns:1fr;}}

.card{
  background:var(--paper);
  padding:38px 34px 34px;
  display:flex;
  flex-direction:column;
}
.card .tag{
  font-family:'JetBrains Mono', monospace;
  font-size:0.68rem;
  letter-spacing:0.14em;
  text-transform:uppercase;
  padding:4px 10px;
  width:fit-content;
  margin-bottom:18px;
}
.card .tag.brass{background:rgba(181,135,46,0.14); color:var(--brass);}
.card .tag.rescue{background:rgba(140,59,46,0.12); color:var(--rescue);}
.card .tag.navy{background:rgba(27,36,48,0.08); color:var(--navy);}
.card h3{font-size:1.5rem; margin-bottom:14px;}
.card p{color:var(--ink-soft); flex-grow:1; margin-bottom:24px;}
.card .btn{align-self:flex-start;}
.widget-slot{margin-top:22px;}

/* ===== Manifest (numbered row list) ===== */
.manifest{border-top:1px solid var(--ink);}
.manifest-row{
  display:grid;
  grid-template-columns:64px 1.4fr 2fr 1fr;
  gap:20px;
  align-items:start;
  padding:26px 0;
  border-bottom:1px solid var(--canvas-line);
}
.manifest-row.no-figure{grid-template-columns:64px 1.4fr 2.8fr;}
@media(max-width:760px){
  .manifest-row, .manifest-row.no-figure{grid-template-columns:1fr; gap:6px; padding:22px 0;}
  .manifest-row .num{order:-1;}
}
.manifest .num{
  font-family:'JetBrains Mono', monospace;
  color:var(--brass);
  font-size:0.85rem;
  border:1px solid var(--brass);
  width:40px; height:40px;
  display:flex; align-items:center; justify-content:center;
}
.manifest h4{font-family:'Oswald', sans-serif; text-transform:uppercase; font-size:1.05rem; color:var(--navy); margin:4px 0 0;}
.manifest .desc{color:var(--ink-soft); font-size:0.97rem;}
.manifest .figure{font-family:'JetBrains Mono', monospace; font-size:0.85rem; color:var(--ink); text-align:right;}
@media(max-width:760px){.manifest .figure{text-align:left;}}
.manifest .figure .label{display:block; color:var(--ink-soft); font-size:0.68rem; letter-spacing:0.06em; text-transform:uppercase; margin-bottom:3px;}
.manifest-foot{font-family:'JetBrains Mono', monospace; font-size:0.78rem; color:var(--ink-soft); padding-top:20px; max-width:560px;}

/* ===== Standing Order box (recurring commitments / rituals) ===== */
.standing-order{
  border:1px solid var(--brass);
  background:var(--paper);
  padding:30px 32px;
  position:relative;
}
.standing-order::before{
  content:"STANDING ORDER";
  position:absolute;
  top:-11px; left:24px;
  background:var(--canvas);
  padding:0 10px;
  font-family:'JetBrains Mono', monospace;
  font-size:0.65rem;
  letter-spacing:0.16em;
  color:var(--brass);
}
.standing-order h4{font-size:1.15rem; margin-bottom:8px;}
.standing-order p{color:var(--ink-soft); margin:0;}
.standing-order + .standing-order{margin-top:18px;}

/* ===== Stat row ===== */
.stat-row{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(180px,1fr));
  gap:1px;
  background:var(--canvas-line);
  border:1px solid var(--canvas-line);
}
.stat{
  background:var(--navy);
  color:var(--canvas);
  padding:30px 26px;
  text-align:left;
}
.stat .num{
  font-family:'Oswald', sans-serif;
  font-size:2.1rem;
  color:var(--brass-light);
  font-weight:600;
  line-height:1;
}
.stat .lab{
  margin-top:8px;
  font-family:'JetBrains Mono', monospace;
  font-size:0.68rem;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#A9A28E;
}

/* ===== Photo grid ===== */
.photo-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:6px;
}
.photo-grid img{
  width:100%; height:100%;
  aspect-ratio:1/1;
  object-fit:cover;
  filter:grayscale(15%);
  transition:filter .2s ease;
}
.photo-grid a:hover img{filter:grayscale(0%);}
@media(max-width:640px){.photo-grid{grid-template-columns:repeat(2,1fr);}}

/* ===== Press grid ===== */
.press-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
}
@media(max-width:760px){.press-grid{grid-template-columns:1fr;}}
.press-item{
  display:block;
  text-decoration:none;
  color:inherit;
  border:1px solid var(--canvas-line);
  background:var(--paper);
}
.press-item img{aspect-ratio:16/10; object-fit:cover; width:100%;}
.press-item .press-body{padding:16px 18px;}
.press-item .eyebrow{font-size:0.62rem;}
.press-item p{margin:8px 0 0; font-size:0.92rem; color:var(--ink-soft);}

/* ===== Vision before/after rail ===== */
.transition-rail{
  display:flex;
  align-items:stretch;
  gap:0;
  border:1px solid var(--canvas-line);
}
.transition-rail .state{
  flex:1;
  padding:32px 28px;
  background:var(--paper);
}
.transition-rail .state.from{color:var(--ink-soft);}
.transition-rail .state.to{background:var(--navy); color:var(--canvas);}
.transition-rail .state.to h4{color:var(--paper);}
.transition-rail .arrow{
  width:56px;
  display:flex; align-items:center; justify-content:center;
  background:var(--brass);
  color:var(--navy-deep);
  font-family:'JetBrains Mono', monospace;
  font-size:1.2rem;
}
@media(max-width:700px){
  .transition-rail{flex-direction:column;}
  .transition-rail .arrow{width:100%; height:36px;}
}
.transition-rail h4{font-size:0.95rem; margin-bottom:10px;}
.transition-rail p{margin:0; font-size:0.95rem;}

/* ===== Calendar frame ===== */
.calendar-frame{
  border:1px solid var(--ink);
  background:var(--paper);
  padding:10px;
}
.calendar-frame iframe{width:100%; height:600px; border:0; display:block;}

/* ===== Recurring / CTA banner ===== */
.recurring{background:var(--navy); color:var(--canvas);}
.recurring .wrap{display:flex; justify-content:space-between; align-items:center; gap:32px; flex-wrap:wrap;}
.recurring h2{color:var(--paper); font-size:1.7rem; max-width:480px;}
.recurring p{color:#C7C0AC; max-width:440px; margin-top:10px;}

/* ===== Trust bar ===== */
.trust{border-top:1px solid var(--canvas-line); border-bottom:1px solid var(--canvas-line); background:var(--paper);}
.trust .wrap{display:flex; flex-wrap:wrap; gap:32px; justify-content:space-between; padding:30px 24px;}
.trust-item{display:flex; gap:12px; align-items:flex-start; max-width:240px;}
.trust-item .mark{font-family:'Oswald', sans-serif; font-size:1.4rem; color:var(--brass); line-height:1;}
.trust-item .t{font-family:'JetBrains Mono', monospace; font-size:0.72rem; letter-spacing:0.06em; text-transform:uppercase; color:var(--ink-soft); margin-top:4px;}
.trust-item strong{display:block; font-family:'Oswald', sans-serif; text-transform:uppercase; font-size:0.85rem; color:var(--navy); letter-spacing:0.03em;}

/* ===== Partner logo strip ===== */
.partners{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(140px, 1fr));
  gap:28px;
  align-items:center;
}
.partners img{filter:grayscale(100%); opacity:0.7; transition:opacity .2s ease, filter .2s ease;}
.partners a:hover img{filter:grayscale(0%); opacity:1;}

/* ===== Verse / closing ===== */
.verse{text-align:center; padding:70px 24px;}
.verse blockquote{
  font-family:'Source Serif 4', serif;
  font-style:italic;
  font-size:1.3rem;
  max-width:620px;
  margin:0 auto;
  color:var(--navy);
}
.verse cite{
  display:block; margin-top:16px;
  font-family:'JetBrains Mono', monospace;
  font-style:normal; font-size:0.78rem;
  letter-spacing:0.1em; text-transform:uppercase;
  color:var(--brass);
}

/* ===== Footer ===== */
footer{
  background:var(--navy-deep);
  color:#8C8775;
  padding:36px 0;
  font-family:'JetBrains Mono', monospace;
  font-size:0.74rem;
}
footer .wrap{display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px;}
footer a{color:#C7C0AC; text-decoration:none;}
footer a:hover{color:var(--brass-light);}

/* ===== Scroll reveal ===== */
.reveal{opacity:0; transform:translateY(14px); transition:opacity 0.6s ease, transform 0.6s ease;}
.reveal.in{opacity:1; transform:translateY(0);}

/* ===== Generic editable content (page.php / index.php fallback) ===== */
.entry-content{max-width:760px;}
.entry-content p{margin:0 0 20px; color:var(--ink-soft); font-size:1.05rem;}
.entry-content h2,.entry-content h3{margin-top:36px; margin-bottom:14px;}
.entry-content ul,.entry-content ol{color:var(--ink-soft); padding-left:22px;}
.entry-content img{margin:24px 0; border:1px solid var(--canvas-line);}
.entry-content a{color:var(--brass); text-decoration:underline;}
