/* Forest Preserves of Winnebago County - Stoa prototype
   Self-contained stylesheet. System fonts only, no external requests. */

:root {
  --ink: #1b2a1f;
  --moss: #2f5a3a;
  --moss-dk: #234430;
  --moss-deep: #16291d;
  --sun: #c9772b;
  --sun-dk: #8b4a12;
  --paper: #f7f5ef;
  --paper-2: #efece2;
  --card: #ffffff;
  --line: #d9d4c7;
  --muted: #515a4e;
  --focus: #1351d8;
  --leaf: #4e7a4f;
  --maxw: 1120px;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font: 17px/1.65 system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  color: var(--ink);
  background: var(--paper);
}

h1, h2, h3 { font-family: Georgia, "Times New Roman", serif; line-height: 1.18; color: var(--moss-deep); }
h1 { font-size: clamp(1.9rem, 5vw, 3rem); margin: 0 0 .5rem; letter-spacing: -.01em; }
h2 { font-size: clamp(1.4rem, 3.2vw, 2rem); margin: 0 0 .75rem; }
h3 { font-size: 1.2rem; margin: 0 0 .4rem; }
p { margin: 0 0 1rem; }

a { color: var(--moss-dk); }
a:hover { color: var(--sun-dk); }

img { max-width: 100%; height: auto; display: block; }

/* ---- accessibility helpers ---- */
.skip {
  position: absolute; left: -999px; top: auto;
  background: #fff; color: var(--ink); padding: 12px 16px;
  border: 2px solid var(--focus); border-radius: 8px; z-index: 100;
  font-weight: 700; text-decoration: none;
}
.skip:focus { left: 12px; top: 12px; }

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

.visually-hidden {
  position: absolute !important; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden; clip: rect(0 0 0 0);
  white-space: nowrap; border: 0;
}

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

/* ---- prototype banner ---- */
.proto {
  background: #fef0dd; color: #5a3410; border-bottom: 2px solid var(--sun);
  font-size: .9rem; text-align: center; padding: 10px 16px;
}
.proto a { color: #5a3410; }

/* ---- skip / util bar ---- */
.util {
  background: var(--moss-deep); color: #e9efe5; font-size: .85rem;
}
.util .wrap { display: flex; flex-wrap: wrap; gap: 6px 18px; justify-content: space-between; padding-block: 8px; }
.util a { color: #fff; }

/* ---- header / brand ---- */
.site-header { background: #fff; border-bottom: 1px solid var(--line); }
.brand-row { display: flex; align-items: center; gap: 14px; padding-block: 16px; }
.brand {
  display: flex; align-items: center; gap: 12px;
  text-decoration: none; color: var(--moss-deep);
}
.brand .mark {
  flex: 0 0 auto; width: 52px; height: 52px; border-radius: 50%;
  background: var(--moss); color: #fff; display: grid; place-items: center;
  font-size: 28px;
}
.brand .name { font-family: Georgia, serif; font-weight: 700; font-size: 1.3rem; line-height: 1.1; }
.brand .sub { display: block; font-family: system-ui, sans-serif; font-weight: 400; font-size: .8rem; color: var(--muted); letter-spacing: .02em; }

/* ---- primary nav ---- */
.nav-toggle {
  margin-left: auto; display: none; align-items: center; gap: 8px;
  background: var(--moss); color: #fff; border: 0; border-radius: 8px;
  padding: 12px 16px; font-size: 1rem; font-weight: 600; cursor: pointer; min-height: 44px;
}
.primary-nav { border-top: 1px solid var(--line); background: #fff; }
.primary-nav ul {
  display: flex; flex-wrap: wrap; gap: 2px; list-style: none; margin: 0; padding: 0;
  max-width: var(--maxw); margin-inline: auto; padding-inline: 12px;
}
.primary-nav a {
  display: inline-block; padding: 13px 16px; min-height: 44px;
  text-decoration: none; font-weight: 600; color: var(--moss-dk); border-radius: 8px;
}
.primary-nav a:hover { background: var(--paper-2); }
.primary-nav a[aria-current="page"] {
  color: var(--moss-deep); box-shadow: inset 0 -3px 0 var(--sun);
}

/* ---- hero ---- */
.hero { background: var(--moss); color: #fff; }
.hero.photo-hero {
  background-image:
    linear-gradient(90deg, rgba(22, 41, 29, .92) 0%, rgba(22, 41, 29, .76) 48%, rgba(22, 41, 29, .3) 100%),
    url("https://static.wixstatic.com/media/16e5c7_104fc687701544a78a87dd21b9db19b6~mv2.jpg/v1/fill/w_1600,h_1000,al_c,q_85/OLS_5668%20seward%20bluffs%20fall%20David%20C%20Olson.jpg");
  background-position: center;
  background-size: cover;
}
.hero.golf-hero {
  background-image:
    linear-gradient(90deg, rgba(70, 39, 9, .94) 0%, rgba(70, 39, 9, .74) 45%, rgba(70, 39, 9, .2) 100%),
    url("https://static.wixstatic.com/media/b9514d_5f4c25982d6b4185808b69cad79629e6~mv2_d_2496_1664_s_2.jpg/v1/fill/w_1800,h_1050,al_c,q_85/b9514d_5f4c25982d6b4185808b69cad79629e6~mv2_d_2496_1664_s_2.jpg");
  background-position: center;
  background-size: cover;
}
.hero .wrap { padding-block: clamp(40px, 7vw, 72px); }
.hero h1 { color: #fff; max-width: 18ch; }
.hero p { font-size: 1.18rem; max-width: 52ch; color: #eaf1e6; }
.hero-cta { margin-top: 1.4rem; display: flex; flex-wrap: wrap; gap: 12px; }

.btn {
  display: inline-flex; align-items: center; gap: 8px; min-height: 52px;
  padding: 13px 26px; border-radius: 10px; font-weight: 700; font-size: 1.05rem;
  text-decoration: none; cursor: pointer; border: 2px solid transparent;
}
.btn-sun { background: var(--sun); color: #241200; }
.btn-sun:hover { background: var(--sun-dk); color: #fff; }
.btn-ghost { background: transparent; color: #fff; border-color: #ffffff; }
.btn-ghost:hover { background: rgba(255,255,255,.14); color: #fff; }
.btn-moss { background: var(--moss); color: #fff; }
.btn-moss:hover { background: var(--moss-dk); color: #fff; }

/* ---- generic page header band ---- */
.pagehead { background: var(--moss-deep); color: #fff; }
.pagehead .wrap { padding-block: clamp(34px, 5vw, 52px); }
.pagehead h1 { color: #fff; }
.pagehead p { color: #d8e2d3; max-width: 60ch; margin: 0; }
.crumbs { font-size: .85rem; color: #b9c8b2; margin: 0 0 .6rem; }
.crumbs a { color: #e4ecdf; }

/* ---- main / sections ---- */
main { display: block; }
.section { padding-block: clamp(36px, 6vw, 60px); }
.eyebrow {
  text-transform: uppercase; letter-spacing: .14em; font-size: .8rem;
  font-weight: 700; color: var(--sun-dk); font-family: system-ui, sans-serif; margin: 0 0 .4rem;
}

/* ---- tile grid ---- */
.tiles { display: grid; gap: 18px; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); list-style: none; margin: 0; padding: 0; }
.tile {
  display: block; background: var(--card); border: 1px solid var(--line);
  border-left: 5px solid var(--moss); border-radius: 12px; padding: 22px;
  text-decoration: none; color: var(--ink); height: 100%;
}
.tile:hover { border-color: var(--moss); box-shadow: 0 6px 20px rgba(22,41,29,.10); transform: translateY(-2px); }
.tile .ico { font-size: 30px; line-height: 1; }
.tile h3 { margin: .5rem 0 .3rem; color: var(--moss-dk); }
.tile p { margin: 0; color: var(--muted); font-size: .97rem; }

/* ---- two-column layout ---- */
.cols { display: grid; gap: 30px; grid-template-columns: minmax(0,1.6fr) minmax(0,1fr); align-items: start; }
.card {
  background: var(--card); border: 1px solid var(--line); border-radius: 12px;
  padding: 22px; box-shadow: 0 3px 12px rgba(22,41,29,.05);
}
.card.accent { border-top: 4px solid var(--sun); }

/* ---- stats ---- */
.stats { display: grid; gap: 16px; grid-template-columns: repeat(auto-fit, minmax(150px,1fr)); list-style: none; margin: 0; padding: 0; }
.stats li { background: var(--card); border: 1px solid var(--line); border-radius: 12px; padding: 18px; text-align: center; }
.stats .num { font-family: Georgia, serif; font-size: 2.2rem; font-weight: 700; color: var(--moss); display: block; }
.stats .lbl { font-size: .9rem; color: var(--muted); }

/* ---- official photo strips ---- */
.photo-grid {
  display: grid;
  gap: 16px;
  grid-template-columns: 1.2fr .8fr .8fr;
}
.photo-card {
  min-height: 250px;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid var(--line);
  background: var(--moss-deep);
  color: #fff;
  position: relative;
  display: flex;
  align-items: flex-end;
  isolation: isolate;
}
.photo-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--photo);
  background-size: cover;
  background-position: center;
  z-index: -2;
}
.photo-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,.06), rgba(0,0,0,.74));
  z-index: -1;
}
.photo-card.featured { min-height: 350px; grid-row: span 2; }
.photo-card div { padding: 20px; }
.photo-card h3 { color: #fff; margin: 0 0 .25rem; }
.photo-card p { color: #edf4eb; margin: 0; font-size: .95rem; }
.mobile-proof {
  display: grid;
  gap: 18px;
  grid-template-columns: minmax(0, 1.05fr) minmax(260px, .95fr);
  align-items: center;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 22px;
}
.phone-stack {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.phone-stat {
  border-radius: 14px;
  background: var(--moss-deep);
  color: #fff;
  padding: 18px;
  min-height: 150px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.phone-stat strong {
  display: block;
  font-family: Georgia, serif;
  font-size: clamp(2.2rem, 6vw, 3.4rem);
  line-height: 1;
  color: #ffd28a;
}
.phone-stat span { color: #e9efe5; }

/* ---- preserve finder demo ---- */
.finder { background: var(--card); border: 1px solid var(--line); border-radius: 14px; padding: 22px; }
.finder .controls { display: grid; gap: 16px; grid-template-columns: minmax(0,2fr) minmax(0,1fr); align-items: end; }
.field label { display: block; font-weight: 700; font-size: .9rem; margin-bottom: 6px; color: var(--moss-deep); }
.field input[type="search"], .field select {
  width: 100%; min-height: 48px; padding: 10px 14px; font-size: 1rem;
  border: 2px solid var(--line); border-radius: 9px; background: #fff; color: var(--ink);
}
.field input[type="search"]:focus, .field select:focus { border-color: var(--moss); }

.filterbar { display: flex; flex-wrap: wrap; gap: 10px 20px; margin: 18px 0 6px; align-items: center; }
.filterbar fieldset { border: 0; margin: 0; padding: 0; display: flex; flex-wrap: wrap; gap: 8px 16px; align-items: center; }
.filterbar legend { font-weight: 700; font-size: .9rem; color: var(--moss-deep); padding: 0; margin-right: 6px; float: left; }
.chk { display: inline-flex; align-items: center; gap: 7px; font-size: .95rem; min-height: 44px; cursor: pointer; }
.chk input { width: 20px; height: 20px; accent-color: var(--moss); }

.results-meta { margin: 14px 0; font-weight: 600; color: var(--moss-deep); }
.btn-link {
  background: none; border: 0; color: var(--moss-dk); text-decoration: underline;
  cursor: pointer; font: inherit; padding: 8px 4px; min-height: 44px;
}

.preserve-list { display: grid; gap: 16px; grid-template-columns: repeat(auto-fill, minmax(280px,1fr)); list-style: none; margin: 0; padding: 0; }
.preserve {
  background: var(--card); border: 1px solid var(--line); border-radius: 12px; padding: 18px;
  border-top: 4px solid var(--leaf);
}
.preserve h3 { margin: 0 0 .25rem; }
.preserve .loc { color: var(--muted); font-size: .9rem; margin: 0 0 .6rem; }
.preserve .amen { display: flex; flex-wrap: wrap; gap: 6px; margin: .6rem 0 0; padding: 0; list-style: none; }
.amen li {
  font-size: .8rem; background: var(--paper-2); border: 1px solid var(--line);
  border-radius: 999px; padding: 3px 10px; color: var(--moss-deep);
}
.badge-acc { background: #e3f0e3; border-color: #b9d8b9; color: #1f4a26; font-weight: 600; }
.no-results { padding: 22px; background: var(--paper-2); border: 1px dashed var(--line); border-radius: 12px; }

.demo-note {
  font-size: .85rem; color: var(--muted); margin-top: 14px;
  border-left: 3px solid var(--sun); padding-left: 12px;
}

/* ---- calendar ---- */
.cal { width: 100%; border-collapse: collapse; background: #fff; border: 1px solid var(--line); }
.cal caption { text-align: left; font-family: Georgia, serif; font-size: 1.3rem; color: var(--moss-deep); padding: 12px 8px; }
.cal th { background: var(--moss); color: #fff; font-size: .8rem; text-transform: uppercase; letter-spacing: .05em; padding: 8px 4px; }
.cal td { border: 1px solid var(--line); vertical-align: top; padding: 6px; height: 88px; width: 14.28%; }
.cal td .daynum { font-weight: 700; font-size: .85rem; color: var(--muted); }
.cal td.is-out { background: var(--paper-2); }
.cal .ev {
  display: block; margin-top: 4px; font-size: .76rem; line-height: 1.25;
  background: var(--leaf); color: #fff; border-radius: 5px; padding: 3px 5px; text-decoration: none;
}
.cal .ev.golf { background: var(--sun-dk); }
.cal .ev.vol { background: var(--moss-dk); }

.eventlist { list-style: none; margin: 0; padding: 0; }
.eventlist li { border-bottom: 1px solid var(--line); padding: 14px 0; display: flex; gap: 16px; }
.eventlist .date { flex: 0 0 64px; text-align: center; background: var(--paper-2); border-radius: 8px; padding: 8px 4px; }
.eventlist .date .mo { display: block; font-size: .72rem; text-transform: uppercase; letter-spacing: .06em; color: var(--sun-dk); font-weight: 700; }
.eventlist .date .dy { display: block; font-family: Georgia, serif; font-size: 1.5rem; font-weight: 700; color: var(--moss-deep); }

/* ---- news / list rows ---- */
.newsrow { border-bottom: 1px solid var(--line); padding: 16px 0; }
.newsrow .meta { font-size: .82rem; color: var(--muted); display: flex; gap: 10px; align-items: center; margin-bottom: .3rem; }
.pill { background: var(--paper-2); border: 1px solid var(--line); border-radius: 999px; padding: 2px 10px; font-size: .72rem; text-transform: uppercase; letter-spacing: .07em; font-weight: 700; color: var(--moss-deep); }

/* ---- forms ---- */
.form-grid { display: grid; gap: 16px; grid-template-columns: repeat(2, 1fr); }
.form-grid .full { grid-column: 1 / -1; }
.form-field label { display: block; font-weight: 700; margin-bottom: 6px; }
.form-field .req { color: var(--sun-dk); }
.form-field input, .form-field select, .form-field textarea {
  width: 100%; min-height: 48px; padding: 11px 14px; font-size: 1rem;
  border: 2px solid var(--line); border-radius: 9px; background: #fff; color: var(--ink); font-family: inherit;
}
.form-field textarea { min-height: 130px; resize: vertical; }
.form-field input:focus, .form-field select:focus, .form-field textarea:focus { border-color: var(--moss); }
.hint { font-size: .85rem; color: var(--muted); margin-top: 4px; }
.form-status { margin-top: 16px; padding: 14px 18px; border-radius: 10px; font-weight: 600; }
.form-status.ok { background: #e3f0e3; border: 1px solid #b9d8b9; color: #1f4a26; }
.form-status.err { background: #fdeede; border: 1px solid #e7c79a; color: #7a4410; }

/* ---- audit table ---- */
.tbl { width: 100%; table-layout: fixed; border-collapse: collapse; background: #fff; border: 1px solid var(--line); font-size: .95rem; }
.tbl caption { text-align: left; padding: 10px 4px; color: var(--muted); font-size: .9rem; overflow-wrap: anywhere; }
.tbl th, .tbl td { text-align: left; padding: 11px 14px; border-bottom: 1px solid var(--line); vertical-align: top; overflow-wrap: anywhere; }
.tbl thead th { background: var(--moss); color: #fff; }
.tbl tbody tr:nth-child(even) { background: var(--paper); }
.sev { font-weight: 700; border-radius: 6px; padding: 2px 9px; font-size: .8rem; white-space: nowrap; }
.sev-a { background: #fce4cf; color: #7a3a08; }
.sev-aa { background: #e7eef9; color: #1c3c73; }

/* ---- callout ---- */
.callout {
  background: var(--moss-deep);
  color: #eaf1e6;
  border-radius: 14px;
  padding: clamp(24px, 4vw, 36px);
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(180px, .7fr);
  gap: 24px;
  align-items: center;
}
.callout h2 { color: #ffd28a; }
.callout p { color: #d8e2d3; }
.callout .mission-stats {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.mission-stats li {
  border-top: 1px solid rgba(255,255,255,.24);
  padding-top: 10px;
  color: #eaf1e6;
}
.mission-stats strong {
  display: block;
  color: #ffd28a;
  font-family: Georgia, serif;
  font-size: 1.7rem;
  line-height: 1;
}

/* ---- footer ---- */
.site-footer { background: var(--moss-deep); color: #d5e0cf; margin-top: 48px; }
.site-footer .wrap { padding-block: 36px; }
.foot-grid { display: grid; gap: 26px; grid-template-columns: repeat(auto-fit, minmax(190px,1fr)); }
.site-footer h2 { color: #fff; font-size: 1rem; font-family: system-ui, sans-serif; text-transform: uppercase; letter-spacing: .08em; margin: 0 0 .6rem; }
.site-footer a { color: #fff; }
.site-footer ul { list-style: none; margin: 0; padding: 0; }
.site-footer li { margin-bottom: .4rem; }
.foot-legal {
  border-top: 1px solid #2e4a37; margin-top: 28px; padding-top: 18px;
  font-size: .85rem; color: #aebfa6; display: flex; flex-wrap: wrap; gap: 8px 18px; justify-content: space-between;
}

/* ---- responsive ---- */
@media (max-width: 820px) {
  .cols { grid-template-columns: 1fr; }
  .finder .controls { grid-template-columns: 1fr; }
  .form-grid { grid-template-columns: 1fr; }
  .photo-grid { grid-template-columns: 1fr; }
  .photo-card, .photo-card.featured { min-height: 260px; grid-row: auto; }
  .mobile-proof { grid-template-columns: 1fr; }
  .phone-stack { grid-template-columns: 1fr; }
  .callout { grid-template-columns: 1fr; }
  .nav-toggle { display: inline-flex; }
  .primary-nav { display: none; }
  .primary-nav.open { display: block; }
  .primary-nav ul { flex-direction: column; padding-inline: 0; }
  .primary-nav a { display: block; border-radius: 0; border-bottom: 1px solid var(--line); }
  .cal td { height: auto; font-size: .8rem; }
}
