/* style.css V1.2 — 2026-06-13 — girouard.org rebuild (+ records page) */

:root {
  --parchment: #f6f1e5;
  --panel: #fffdf7;
  --ink: #2e2418;
  --soft: #6b5d49;
  --maroon: #7a1f1f;
  --gold: #b08d3f;
  --line: #ddd2bc;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  background: var(--parchment);
  color: var(--ink);
  font: 17px/1.65 Georgia, 'Times New Roman', serif;
}

header {
  background: var(--maroon);
  color: #f4ead3;
  padding: 1.1rem 1.5rem 0;
}

.brand { display: flex; align-items: center; gap: 1rem; max-width: 900px; margin: 0 auto; }
.crest { width: 64px; height: 64px; }
.site-name { display: block; font-size: 1.6rem; font-weight: bold; letter-spacing: .02em; }
.tagline { display: block; font-size: .85rem; color: #d9c08a; font-style: italic; }

nav { max-width: 900px; margin: .9rem auto 0; display: flex; flex-wrap: wrap; }
nav a {
  color: #f4ead3; text-decoration: none; padding: .55rem .9rem;
  font-size: .95rem; border-bottom: 3px solid transparent;
}
nav a:hover { color: #fff; }
nav a.active { border-bottom-color: var(--gold); color: #fff; font-weight: bold; }

.subnav {
  background: var(--panel); border-bottom: 1px solid var(--line);
  padding: .5rem 1.5rem; font-size: .85rem;
}
.subnav a {
  display: inline-block; color: var(--soft); text-decoration: none;
  padding: .15rem .5rem; border-radius: 3px;
}
.subnav a:hover { color: var(--maroon); }
.subnav a.here { color: var(--maroon); font-weight: bold; }
.subnav { max-width: 100%; }
.subnav a + a { margin-left: .1rem; }

main {
  max-width: 760px; margin: 2rem auto 3rem; padding: 0 1.25rem;
}

h1, h2, h3 { font-family: Georgia, serif; color: var(--maroon); line-height: 1.25; }
h2 { font-size: 1.6rem; margin: 1.6rem 0 .6rem; }
h3 { font-size: 1.2rem; margin: 1.4rem 0 .4rem; }

a { color: var(--maroon); }
a:hover { color: var(--gold); }

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

main img {
  display: block; margin: 1rem auto; border: 1px solid var(--line);
  border-radius: 3px; background: var(--panel); padding: 4px;
}

main table {
  border-collapse: collapse; margin: 1.2rem auto; background: var(--panel);
  font-size: .92rem; width: 100%;
}
main td, main th {
  border: 1px solid var(--line); padding: .4rem .65rem; text-align: left;
  vertical-align: top;
}
main tr:first-child td { background: #efe6cf; font-weight: bold; }

ul { padding-left: 1.4rem; }
li { margin: .35rem 0; }

.notice {
  background: var(--panel); border: 1px solid var(--line);
  border-left: 4px solid var(--gold); padding: .9rem 1.1rem; border-radius: 3px;
  font-size: .95rem;
}

#gsearch {
  width: 100%; padding: .6rem .8rem; font: inherit; color: var(--ink);
  background: var(--panel); border: 1px solid var(--line); border-radius: 4px;
}
#gsearch:focus { outline: 2px solid var(--gold); }
.pid { color: var(--soft); font-size: .8em; font-weight: normal; }
.pending { font-style: normal; }
#gresults ul { list-style: none; padding: 0; columns: 2; }
table.pcard td:first-child {
  font-weight: bold; white-space: nowrap; width: 6.5rem; background: #efe6cf;
}

/* records search page */
.rcontrols { display: flex; flex-wrap: wrap; gap: .5rem; margin: 1rem 0; }
#rsearch {
  flex: 1 1 16rem; min-width: 12rem; padding: .6rem .8rem; font: inherit;
  color: var(--ink); background: var(--panel); border: 1px solid var(--line);
  border-radius: 4px;
}
#rsearch:focus, #rjuris:focus, #revent:focus { outline: 2px solid var(--gold); }
#rjuris, #revent {
  padding: .6rem .5rem; font: inherit; font-size: .92rem; color: var(--ink);
  background: var(--panel); border: 1px solid var(--line); border-radius: 4px;
}
.rcount { color: var(--soft); font-size: .9rem; margin: .4rem 0 .8rem; }
.rhint { color: var(--soft); font-style: italic; }
.rlist { list-style: none; padding: 0; }
.rlist li {
  background: var(--panel); border: 1px solid var(--line);
  border-left: 4px solid var(--gold); border-radius: 3px;
  padding: .6rem .85rem; margin: .55rem 0;
}
.rname { font-weight: bold; color: var(--maroon); font-size: 1.02rem; }
.rmeta { font-size: .9rem; color: var(--ink); margin-top: .15rem; }
.rrel { font-size: .82rem; color: var(--soft); margin-top: .15rem; }
.rlink {
  display: inline-block; margin-top: .35rem; font-size: .82rem;
  text-decoration: none;
}
.rlink:hover { text-decoration: underline; }

footer {
  background: #efe6cf; border-top: 1px solid var(--line);
  color: var(--soft); font-size: .85rem; text-align: center;
  padding: 1.2rem 1rem 1.6rem; margin-top: 2rem;
}
footer a { color: var(--soft); }

@media (max-width: 640px) {
  body { font-size: 16px; }
  .site-name { font-size: 1.25rem; }
  .crest { width: 48px; height: 48px; }
  nav a { padding: .5rem .6rem; font-size: .88rem; }
  main { margin-top: 1.2rem; }
}
