/* Wild Pitch Camp — rugged outdoor aesthetic, server-rendered, no build step. */
:root{
  --forest:#2A4A2E;          /* deeper forest green */
  --forest-deep:#162819;     /* near-black green */
  --moss:#5C7A4A;            /* lighter moss accent */
  --tan:#E8DCC0;             /* warm tan / sand */
  --paper:#FBF6E9;           /* cream paper */
  --paper-2:#F4ECD8;         /* darker cream for bands */
  --sienna:#C7521B;          /* burnt sienna */
  --sienna-deep:#8E3A12;
  --rust:#A8431F;
  --ink:#1A1A18;
  --muted:#5C5A52;
  --muted-2:#7A7770;
  --rule:#D9CFB5;
  --shadow-sm:0 1px 2px rgba(22,40,25,.08);
  --shadow:0 1px 2px rgba(22,40,25,.08),0 10px 28px -14px rgba(22,40,25,.22);
  --shadow-lg:0 4px 8px rgba(22,40,25,.1),0 20px 50px -20px rgba(22,40,25,.3);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--paper); color:var(--ink);
  font:16px/1.65 "Inter",ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
.container{max-width:1180px;margin:0 auto;padding:0 24px}
a{color:var(--forest);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .15s,color .15s}
a:hover{color:var(--sienna);border-bottom-color:var(--sienna)}
h1,h2,h3,h4{font-family:"Zilla Slab",Georgia,"Iowan Old Style",serif;color:var(--forest-deep);line-height:1.18;font-weight:700;letter-spacing:-.005em}
h1{font-size:2.5rem;margin:.2em 0 .4em}
h2{font-size:1.65rem;margin:1.7em 0 .55em}
h3{font-size:1.18rem;margin:1.3em 0 .35em}
h4{font-size:1rem;margin:1em 0 .35em;text-transform:uppercase;letter-spacing:.08em}
p{margin:0 0 1em}
strong{color:var(--forest-deep)}
.kicker{font-family:"Inter",sans-serif;text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;color:var(--sienna);font-weight:700;margin:0 0 .2em}

/* Topographic strip — subtle SVG line pattern used on header & footer */
.topo-strip{
  height:8px;
  background-image:
    repeating-linear-gradient(135deg, rgba(255,255,255,.18) 0 1px, transparent 1px 7px),
    linear-gradient(180deg,#162819,#2A4A2E);
  border-bottom:1px solid rgba(0,0,0,.25);
}
.topo-strip-light{
  background-image:
    repeating-linear-gradient(135deg, rgba(255,255,255,.08) 0 1px, transparent 1px 7px),
    linear-gradient(180deg,#0F1E12,#162819);
  border-bottom:none; border-top:1px solid rgba(0,0,0,.4);
}

/* Header */
.site-header{background:var(--forest-deep);color:var(--paper)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:72px;gap:24px;flex-wrap:wrap}
.brand{display:inline-flex;align-items:center;gap:12px;color:var(--paper)!important;font-size:1.15rem;border:none;white-space:nowrap;flex-shrink:0}
.brand:hover{color:var(--paper)!important;border:none}
.brand-mark{display:inline-flex;flex-shrink:0;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}
.brand-text{font-family:"Zilla Slab",serif;font-weight:600;letter-spacing:.005em;white-space:nowrap}
.brand-text strong{font-weight:700;color:#fff}
.primary-nav{display:flex;flex-wrap:wrap;gap:0 22px;justify-content:flex-end}
.primary-nav a{color:var(--paper);font-weight:600;font-size:.95rem;border:none;border-bottom:2px solid transparent;padding-bottom:2px}
.primary-nav a:hover{color:#fff;border-bottom-color:var(--sienna)}
@media (max-width:640px){
  .header-inner{height:auto;padding:12px 0;gap:10px;justify-content:space-between}
  .brand{font-size:1.05rem}
  .primary-nav{flex:1 1 auto;justify-content:flex-end;gap:4px 14px;font-size:.85rem}
  .primary-nav a{font-size:.85rem}
}
@media (max-width:480px){
  .header-inner{flex-direction:column;align-items:flex-start;gap:6px}
  .primary-nav{justify-content:flex-start;width:100%;gap:4px 16px}
}

/* Main */
.site-main{padding:32px 24px 64px;min-height:60vh}

/* Hero */
.hero{
  position:relative; margin:-32px -24px 40px; padding:120px 24px 130px;
  background-size:cover;background-position:center;color:var(--paper);
  border-bottom:5px solid var(--forest-deep);
  overflow:hidden;
}
@media (max-width:640px){
  .hero{padding:64px 20px 72px;margin:-32px -24px 28px}
  .hero h1{font-size:2.2rem}
  .hero .lede{font-size:1.02rem}
  .hero-cta .btn{display:block;margin:8px 0}
}
.hero::after{
  content:""; position:absolute; inset:auto 0 0 0; height:60px;
  background-image:repeating-linear-gradient(90deg, rgba(255,255,255,.06) 0 1px, transparent 1px 8px);
  pointer-events:none;
}
.hero-inner{max-width:820px;margin:0 auto;text-align:center;position:relative;z-index:2}
.hero h1{color:#fff;font-size:3.4rem;margin:0 0 .25em;text-shadow:0 2px 14px rgba(0,0,0,.55);letter-spacing:-.01em}
.hero .lede{font-size:1.22rem;line-height:1.55;color:#F8F1DC;text-shadow:0 1px 6px rgba(0,0,0,.6),0 0 24px rgba(0,0,0,.45)}
.hero .lede strong{color:#fff;background:rgba(22,40,25,.45);padding:1px 6px;border-radius:3px}
.hero-cta{margin-top:30px}
.btn{display:inline-block;background:var(--sienna);color:#fff!important;padding:13px 26px;border-radius:4px;font-weight:700;letter-spacing:.03em;margin:0 6px;border:2px solid var(--sienna);font-family:"Inter",sans-serif;text-transform:uppercase;font-size:.88rem;transition:background .15s,border-color .15s,transform .15s}
.btn:hover{background:var(--sienna-deep);border-color:var(--sienna-deep);text-decoration:none;border-bottom-color:var(--sienna-deep)}
.btn-ghost{background:transparent;border:2px solid var(--paper);color:var(--paper)!important}
.btn-ghost:hover{background:var(--paper);color:var(--forest-deep)!important;border-color:var(--paper)}

/* Bands */
.band{margin:54px 0}
.band h2{margin-top:0}
.band-lede{color:var(--muted);max-width:760px;margin-bottom:1.4em;font-size:1.04rem}
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px}
@media (max-width:780px){.split{grid-template-columns:1fr}}

/* Grids and cards */
.grid{display:grid;gap:18px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:920px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}.grid-2{grid-template-columns:1fr}}
@media (max-width:520px){.grid-3,.grid-4{grid-template-columns:1fr}}
.card{
  display:block;background:#fff;border:1px solid var(--rule);border-radius:6px;
  padding:22px;color:var(--ink);transition:transform .15s ease,box-shadow .15s ease,border-color .15s;
  box-shadow:var(--shadow-sm);border-left:4px solid var(--moss);
}
.card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-left-color:var(--sienna);text-decoration:none}
.card h2,.card h3{margin-top:.2em;color:var(--forest-deep)}
.card p{color:var(--muted);font-size:.95rem;margin:0 0 .6em;line-height:1.55}
.card-tag{display:inline-block;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--sienna);font-weight:700;margin-bottom:10px;font-family:"Inter",sans-serif}
.more{color:var(--sienna);font-weight:700;font-size:.88rem;text-transform:uppercase;letter-spacing:.06em}

/* State cards */
.state-card{display:flex;flex-direction:column;align-items:flex-start;border-left-width:4px}
.state-card .state-code{font:700 1.55rem/1 "Zilla Slab",serif;color:var(--sienna);margin-bottom:4px}
.state-card .state-name{font-weight:600;margin:6px 0 4px;color:var(--forest-deep);font-size:1.05rem}
.state-card .state-count{color:var(--muted);font-size:.85rem}
.state-card.is-empty{opacity:.55}

/* State directory list */
.state-meta{display:flex;flex-wrap:wrap;gap:18px;color:var(--muted);font-size:.95rem;margin-bottom:24px;padding:16px 18px;background:var(--paper-2);border:1px solid var(--rule);border-radius:6px}
.state-meta strong{color:var(--forest-deep)}
.state-meta-tag{display:inline-block;padding:3px 9px;border-radius:3px;background:var(--forest);color:#fff;font-size:.78rem;font-weight:600;letter-spacing:.04em}

/* State quick-nav strip */
.state-quicknav{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:0 0 28px}
@media (max-width:780px){.state-quicknav{grid-template-columns:1fr}}
.state-quicknav a{display:block;background:#fff;border:1px solid var(--rule);border-left:4px solid var(--forest);border-radius:4px;padding:14px 16px;color:var(--ink)}
.state-quicknav a:hover{border-left-color:var(--sienna);text-decoration:none}
.state-quicknav .qn-label{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--sienna);font-weight:700}
.state-quicknav .qn-title{font-family:"Zilla Slab",serif;font-weight:600;font-size:1.05rem;color:var(--forest-deep);margin-top:3px}

.site-list{list-style:none;padding:0;margin:0;border-top:1px solid var(--rule)}
.site-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 0;border-bottom:1px solid var(--rule)}
.site-row-main{flex:1;color:var(--ink);border:none}
.site-row-main h3{margin:0 0 4px;font-size:1.05rem;color:var(--forest-deep);font-family:"Zilla Slab",serif}
.site-row-meta{margin:0;color:var(--muted);font-size:.88rem}
.site-row a{border:none}
.site-row a:hover{text-decoration:none;color:inherit}
.site-row a:hover h3{color:var(--sienna)}
.site-row-badges .badge{display:inline-block;padding:4px 10px;border-radius:3px;font-size:.74rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;font-family:"Inter",sans-serif}
.badge-free{background:#DBE8C8;color:#2A4A2E;border:1px solid #B5CFA0}
.badge-maybe{background:#F2DDC4;color:#8E3A12;border:1px solid #E0C29A}

/* Two-column layout (main + sidebar) */
.layout-with-side{display:grid;grid-template-columns:1fr 320px;gap:40px;align-items:start}
@media (max-width:920px){.layout-with-side{grid-template-columns:1fr}}
.sidebar{position:sticky;top:24px}
.sidebar .card{margin-bottom:18px}

/* Resources sidebar */
.resources h3{font-family:"Inter",sans-serif;color:var(--forest-deep);font-size:.95rem;text-transform:uppercase;letter-spacing:.08em;margin:0 0 12px;padding-bottom:10px;border-bottom:2px solid var(--sienna)}
.resources .link-list{margin:0;font-size:.92rem}
.resources .link-list li{padding:8px 0;border-bottom:1px dashed var(--rule);line-height:1.4}
.resources .link-list li:last-child{border:none;padding-bottom:0}
.resources-fine{color:var(--muted-2);font-size:.78rem;margin:12px 0 0;line-height:1.5;font-style:italic}

/* Campsite page */
.campsite-hero{padding:0 0 18px;border-bottom:2px solid var(--rule);margin-bottom:26px}
.campsite-hero h1{margin:0 0 .3em}
.campsite-sub{color:var(--muted);font-size:1.04rem;margin:0}
.campsite-grid{display:grid;grid-template-columns:1fr 320px;gap:40px;align-items:start}
@media (max-width:920px){.campsite-grid{grid-template-columns:1fr}}
.campsite-prose p{font-size:1.04rem;line-height:1.72}
.campsite-side{position:sticky;top:24px}
.campsite-side .card{padding:20px;margin-bottom:18px}
.facts h3{margin-top:0;font-family:"Inter",sans-serif;color:var(--forest-deep);font-size:.95rem;text-transform:uppercase;letter-spacing:.08em;padding-bottom:10px;border-bottom:2px solid var(--sienna)}
.facts dl{display:grid;grid-template-columns:auto 1fr;gap:8px 14px;margin:8px 0 0;font-size:.92rem}
.facts dt{color:var(--muted);font-weight:600}
.facts dd{margin:0;color:var(--ink)}
.link-list{list-style:none;padding:0;margin:8px 0 0;font-size:.92rem}
.link-list li{padding:5px 0;border-bottom:1px dashed var(--rule)}
.link-list li:last-child{border:none}

/* Region page */
.region-areas{background:var(--paper-2);border:1px solid var(--rule);border-left:4px solid var(--moss);padding:18px 22px;border-radius:4px;margin:24px 0}
.region-areas h3{margin-top:0}
.region-areas ul{margin:0;padding-left:1.1em}

/* Rules page */
.rules-fact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin:24px 0}
@media (max-width:680px){.rules-fact-grid{grid-template-columns:1fr}}
.rules-fact{background:#fff;border:1px solid var(--rule);border-left:4px solid var(--sienna);padding:14px 18px;border-radius:4px}
.rules-fact h4{margin:0 0 4px;color:var(--sienna);font-size:.74rem;letter-spacing:.1em}
.rules-fact p{margin:0;font-size:.95rem}
.agency-list{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 0;list-style:none;padding:0}
.agency-list li{background:var(--forest);color:#fff;padding:5px 12px;border-radius:3px;font-size:.82rem;font-weight:500}

/* Breadcrumb */
.breadcrumb{font-size:.85rem;color:var(--muted);margin-bottom:18px}
.breadcrumb ol{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:6px}
.breadcrumb a{border:none;color:var(--muted)}
.breadcrumb a:hover{color:var(--sienna)}
.breadcrumb li:not(:last-child)::after{content:" / ";color:var(--rule);margin-left:6px}

/* Page lede */
.page-lede{font-size:1.12rem;color:var(--muted);max-width:780px;margin:.2em 0 1.6em;line-height:1.65}

/* Empty state */
.empty-state{background:#fff;border:1px dashed var(--rule);border-radius:6px;padding:24px}

/* Long-form prose (guides, managers) */
.guide{max-width:800px}
.guide h2{padding-top:.5em;border-top:1px solid var(--rule);margin-top:2em}
.guide h2:first-of-type{border-top:none;padding-top:0;margin-top:1em}
.guide p{font-size:1.04rem;line-height:1.72}

/* Footer */
.site-footer{background:var(--forest-deep);color:var(--paper);margin-top:64px;padding:0 0 24px}
.site-footer h4{color:#fff;font-family:"Inter",sans-serif;text-transform:uppercase;letter-spacing:.1em;font-size:.82rem;margin:0 0 14px;padding-bottom:8px;border-bottom:2px solid var(--sienna);display:inline-block}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin:6px 0}
.site-footer a{color:var(--paper);border:none}
.site-footer a:hover{color:#fff;border-bottom:1px solid var(--sienna)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px;padding:40px 0 24px;border-bottom:1px solid rgba(245,236,216,.15)}
@media (max-width:780px){.footer-grid{grid-template-columns:1fr}}
.footer-fine{color:rgba(245,236,216,.65);font-size:.82rem;padding-top:18px}
.footer-fine p{margin:0}
