/* RedCyfer Civic — accessible municipal theme.
   Per-city colors come in as --primary/--accent (set inline per tenant);
   everything else is contrast-safe by construction. WCAG 2.1 AA. */
:root{
  --primary:#1c3f5f; --primary-ink:#ffffff;
  --accent:#8a1f2b;  --accent-ink:#ffffff;
  --paper:#f7f6f3; --card:#ffffff; --ink:#1a1c20; --muted:#565b63; --line:#dcdad4;
  --link:#0b4a8f; --link-hover:#083766;
  --focus:#ffbf47;                 /* high-contrast focus ring */
  --info:#0b4a8f; --info-bg:#eaf1f9;
  --warn:#8a5a00; --warn-bg:#fbf1dc;
  --emerg:#a1121f; --emerg-bg:#fbe6e6;
  --serif:Georgia,'Iowan Old Style','Times New Roman',serif;
  --sans:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --wrap:1120px;
}
*{box-sizing:border-box}
html{font-size:100%;-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--paper);line-height:1.6;font-size:1.0625rem}
h1,h2,h3,h4{font-family:var(--serif);line-height:1.2;color:var(--ink);text-wrap:balance;margin:0 0 .5em}
h1{font-size:2.1rem}h2{font-size:1.6rem}h3{font-size:1.25rem}
p,ul,ol{margin:0 0 1rem}
a{color:var(--link);text-underline-offset:2px}
a:hover{color:var(--link-hover)}
img{max-width:100%;height:auto}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 1.25rem}

/* focus — visible, high contrast, everywhere */
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,[tabindex]:focus-visible{
  outline:3px solid var(--focus);outline-offset:2px;border-radius:2px}

/* skip link */
.skip{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;padding:.7rem 1rem;z-index:100}
.skip:focus{left:.5rem;top:.5rem}

/* utility bar */
.util{background:var(--primary);color:var(--primary-ink);font-size:.85rem}
.util .wrap{display:flex;flex-wrap:wrap;gap:.4rem 1.4rem;padding-top:.4rem;padding-bottom:.4rem}
.util a{color:var(--primary-ink);text-decoration:underline}

/* masthead */
.mast{background:var(--card);border-bottom:4px solid var(--primary)}
.mast .wrap{display:flex;align-items:center;gap:1rem;padding-top:1rem;padding-bottom:1rem}
.seal{width:64px;height:64px;flex:0 0 auto;border-radius:50%;background:var(--primary);color:var(--primary-ink);
  display:grid;place-items:center;font-family:var(--serif);font-weight:700;font-size:1.5rem}
.mast .name{font-family:var(--serif);font-weight:700;font-size:1.6rem;line-height:1.1;color:var(--ink)}
.mast .tag{color:var(--muted);font-size:.95rem}

/* primary nav */
.nav{background:var(--primary);position:relative}
.nav .wrap{display:flex;flex-wrap:wrap;gap:0}
.nav a{color:var(--primary-ink);text-decoration:none;font-weight:600;padding:.85rem 1rem;display:block}
.nav a:hover{background:rgba(255,255,255,.14)}
.nav a[aria-current="page"]{background:var(--accent);color:var(--accent-ink)}
.navtoggle{display:none}

/* alert banner */
.alert{border-bottom:1px solid var(--line)}
.alert .wrap{padding:.8rem 1.25rem;display:flex;gap:.6rem;align-items:baseline}
.alert.info{background:var(--info-bg)}.alert.info .tag{color:var(--info)}
.alert.warning{background:var(--warn-bg)}.alert.warning .tag{color:var(--warn)}
.alert.emergency{background:var(--emerg-bg)}.alert.emergency .tag{color:var(--emerg)}
.alert .tag{font-weight:800;text-transform:uppercase;font-size:.75rem;letter-spacing:.5px;white-space:nowrap}
.alert a{font-weight:700}

/* layout */
main{display:block}
.hero{background:var(--primary);color:var(--primary-ink);padding:2.4rem 0}
.hero h1{color:var(--primary-ink);font-size:2.4rem;margin-bottom:.3rem}
.hero p{color:var(--primary-ink);opacity:.92;font-size:1.15rem;max-width:60ch;margin:0}
.section{padding:2.2rem 0}
.section.alt{background:var(--card);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.grid{display:grid;gap:1.1rem}
.g-2{grid-template-columns:repeat(2,1fr)}.g-3{grid-template-columns:repeat(3,1fr)}.g-4{grid-template-columns:repeat(4,1fr)}
.card-b{background:var(--card);border:1px solid var(--line);border-radius:8px;padding:1.1rem 1.2rem}
.card-b :is(h2,h3){margin-bottom:.3rem}
.eyebrow{font-size:.78rem;text-transform:uppercase;letter-spacing:1px;color:var(--accent);font-weight:700;margin-bottom:.3rem}

/* services quick-actions */
.svc{display:flex;gap:.7rem;align-items:center;background:var(--card);border:1px solid var(--line);
  border-left:4px solid var(--accent);border-radius:8px;padding:1rem 1.1rem;text-decoration:none;color:var(--ink)}
.svc:hover{background:#fbfaf8}
.svc .ico{flex:0 0 auto;width:34px;height:34px;color:var(--primary)}
.svc .t{font-weight:700;color:var(--ink)}.svc .d{color:var(--muted);font-size:.9rem}

/* content + sidebar */
.content{display:grid;grid-template-columns:1fr 300px;gap:2.5rem;padding:2.2rem 0;align-items:start}
.prose{max-width:70ch}
.prose h2{margin-top:1.6rem}.prose h3{margin-top:1.2rem}
.prose img{border-radius:6px;margin:1rem 0}
.prose ul,.prose ol{padding-left:1.3rem}
.aside{background:var(--card);border:1px solid var(--line);border-radius:8px;padding:1.1rem 1.2rem}
.aside h2{font-size:1.1rem}
.aside ul{list-style:none;padding:0;margin:0}
.aside li{padding:.4rem 0;border-bottom:1px solid var(--line)}
.aside li:last-child{border:none}

/* breadcrumb */
.crumbs{font-size:.9rem;color:var(--muted);padding:.8rem 0}
.crumbs ol{list-style:none;display:flex;flex-wrap:wrap;gap:.4rem;margin:0;padding:0}
.crumbs li::after{content:"›";margin-left:.4rem;color:var(--muted)}
.crumbs li:last-child::after{content:""}

/* lists of things (news, docs, directory) */
.rows{list-style:none;margin:0;padding:0}
.rows li{padding:1rem 0;border-bottom:1px solid var(--line)}
.rows .date{color:var(--muted);font-size:.85rem}
.rows :is(h2,h3){margin:.1rem 0 .2rem;font-size:1.2rem}
.rows :is(h2,h3) a{text-decoration:none}.rows :is(h2,h3) a:hover{text-decoration:underline}
.doc{display:flex;justify-content:space-between;gap:1rem;align-items:baseline;flex-wrap:wrap}
.doc .meta{color:var(--muted);font-size:.85rem;white-space:nowrap}
.flag{display:inline-block;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px;
  padding:.1rem .45rem;border-radius:3px;background:var(--warn-bg);color:var(--warn)}
.people{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.1rem;list-style:none;padding:0;margin:0}
.person{background:var(--card);border:1px solid var(--line);border-radius:8px;padding:1rem 1.1rem}
.person .role{color:var(--accent);font-weight:700;font-size:.9rem}

/* tables (documents/data) */
.tbl-wrap{overflow-x:auto}
table.data{width:100%;border-collapse:collapse}
table.data caption{text-align:left;font-weight:700;margin-bottom:.5rem}
table.data th,table.data td{text-align:left;padding:.6rem .7rem;border-bottom:1px solid var(--line)}
table.data th{border-bottom:2px solid var(--ink)}

/* forms */
.field{margin-bottom:1rem}
.field label{display:block;font-weight:700;margin-bottom:.3rem}
.field .req{color:var(--accent)}
.field input,.field textarea{width:100%;font-size:1rem;font-family:inherit;padding:.6rem .7rem;border:1px solid #9aa0a6;border-radius:5px;background:#fff;color:var(--ink)}
.btn{display:inline-block;background:var(--accent);color:var(--accent-ink);font-weight:700;font-size:1rem;
  padding:.7rem 1.4rem;border:none;border-radius:6px;cursor:pointer;text-decoration:none}
.btn:hover{filter:brightness(.92)}
.formstatus{margin-top:.6rem;font-weight:600}
.formstatus.ok{color:#1a6b34}.formstatus.err{color:var(--emerg)}

/* footer */
.foot{background:var(--primary);color:var(--primary-ink);margin-top:2rem}
.foot a{color:var(--primary-ink)}
.foot .wrap{display:grid;grid-template-columns:2fr 1fr 1fr;gap:1.5rem;padding-top:2rem;padding-bottom:1.5rem}
.foot h2{color:var(--primary-ink);font-size:1.05rem}
.foot ul{list-style:none;padding:0;margin:0}.foot li{padding:.2rem 0}
.foot .fine{border-top:1px solid rgba(255,255,255,.25);padding:1rem 0;font-size:.85rem;opacity:.9;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);border:0}

@media (max-width:860px){
  .content{grid-template-columns:1fr}
  .foot .wrap{grid-template-columns:1fr}
  .g-3,.g-4{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:600px){
  .g-2,.g-3,.g-4{grid-template-columns:1fr}
  .nav .wrap{flex-direction:column}
  .nav a{border-top:1px solid rgba(255,255,255,.15)}
}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
@media print{.util,.nav,.skip,.foot .fine{display:none}body{background:#fff}}
