:root{
  --navy:#13314f; --navy-deep:#0c2236; --gold:#c8a24b; --gold-deep:#a87f2c;
  --cream:#f9f3e7; --cream-2:#f3ead7; --card:#fffdf8; --ink:#1b2733;
  --muted:#5d6b78; --line:#e6dcc6; --shadow:0 6px 22px rgba(12,34,54,.08);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--cream);color:var(--ink);
  font-family:Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;line-height:1.55;}
a{color:var(--navy)}
.serif{font-family:"Cormorant Garamond",Georgia,serif}
.wrap{max-width:1120px;margin:0 auto;padding:0 20px}

/* top bar */
.topbar{background:var(--navy-deep);color:#fff}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:56px}
.brand{font-family:"Cormorant Garamond",serif;font-size:22px;letter-spacing:.3px}
.brand b{font-weight:600}.brand i{color:var(--gold);font-style:italic}
.topbar a.back{color:#e9dec3;text-decoration:none;font-size:13.5px;border:1px solid rgba(233,222,195,.35);
  padding:7px 13px;border-radius:999px}
.topbar a.back:hover{background:rgba(233,222,195,.12)}

/* hero */
.hero{background:linear-gradient(180deg,var(--navy) 0%,var(--navy-deep) 100%);color:#fff;
  padding:54px 0 60px;text-align:center;position:relative}
.hero h1{font-family:"Cormorant Garamond",serif;font-weight:600;font-size:clamp(34px,5vw,52px);
  margin:0 0 10px;line-height:1.08}
.hero h1 i{color:var(--gold);font-style:italic}
.hero p.lede{max-width:620px;margin:0 auto 18px;color:#dfe7ee;font-size:17px}
.eyebrow{letter-spacing:.32em;text-transform:uppercase;font-size:11.5px;color:var(--gold);
  font-weight:600;margin-bottom:14px}
.motto{margin-top:18px;color:var(--gold);font-family:"Cormorant Garamond",serif;
  font-size:18px;letter-spacing:.18em;text-transform:uppercase}
.hero .lockmsg{margin-top:18px;font-size:13px;color:#c9d4de;opacity:.9}

/* controls */
.controls{position:sticky;top:0;z-index:20;background:var(--cream-2);
  border-bottom:1px solid var(--line);box-shadow:0 2px 10px rgba(12,34,54,.04)}
.controls .wrap{display:flex;flex-wrap:wrap;gap:12px;align-items:center;padding:16px 20px}
.field{display:flex;flex-direction:column;gap:4px}
.field label{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:600}
.controls input[type=text],.controls select{font:inherit;padding:10px 12px;border:1px solid var(--line);
  border-radius:10px;background:#fff;color:var(--ink);min-width:170px}
.controls input[type=text]{min-width:260px}
.controls input:focus,.controls select:focus{outline:2px solid var(--gold);border-color:var(--gold)}
.search-field{flex:1 1 260px}
.search-field input{width:100%}
.toggle-group{display:flex;gap:6px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:4px}
.toggle-group button{font:inherit;font-size:13.5px;border:0;background:transparent;color:var(--muted);
  padding:7px 14px;border-radius:7px;cursor:pointer}
.toggle-group button.active{background:var(--navy);color:#fff}
.chk{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--ink);cursor:pointer;user-select:none}
.chk input{width:17px;height:17px;accent-color:var(--gold)}
.btn-clear{font:inherit;font-size:13.5px;background:transparent;border:1px solid var(--line);
  color:var(--muted);padding:9px 14px;border-radius:10px;cursor:pointer}
.btn-clear:hover{border-color:var(--gold);color:var(--gold-deep)}

/* results */
.results{padding:26px 0 60px}
.count{color:var(--muted);font-size:14px;margin:4px 2px 18px}
.count b{color:var(--ink)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:18px}
.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:20px 20px 18px;
  box-shadow:var(--shadow);display:flex;flex-direction:column;gap:10px}
.card h3{font-family:"Cormorant Garamond",serif;font-weight:600;font-size:23px;margin:0;color:var(--navy-deep)}
.card .cred{font-size:13.5px;color:var(--muted);line-height:1.5}
.card .loc{font-size:14px;color:var(--ink);display:flex;gap:7px;align-items:flex-start}
.card .loc svg{flex:none;margin-top:3px}
.badges{display:flex;flex-wrap:wrap;gap:7px;margin-top:2px}
.badge{font-size:11.5px;font-weight:600;letter-spacing:.02em;padding:4px 10px;border-radius:999px;border:1px solid}
.b-inperson{background:#eef4ee;color:#2f6b3a;border-color:#cfe3d2}
.b-online{background:#eef1f7;color:#33507e;border-color:#cdd8ea}
.b-ins{background:#fbf2da;color:#8a6a18;border-color:#ecdcae}
.ins-detail{font-size:12.5px;color:var(--muted);margin-top:-2px}
.card .link{margin-top:auto;padding-top:6px}
.card .link a{display:inline-flex;align-items:center;gap:7px;font-size:14px;font-weight:600;
  color:var(--gold-deep);text-decoration:none}
.card .link a:hover{text-decoration:underline}
.card .link span.plain{font-size:13.5px;color:var(--muted)}
.empty{text-align:center;color:var(--muted);padding:60px 20px;font-size:16px}

/* footer */
footer{background:var(--navy-deep);color:#cdd8e2;padding:30px 0 40px;font-size:13.5px}
footer .wrap{display:flex;flex-wrap:wrap;gap:18px;justify-content:space-between;align-items:center}
footer a{color:#e9dec3}
.crisis{background:rgba(200,162,75,.12);border:1px solid rgba(200,162,75,.4);color:#f2e8cf;
  padding:12px 16px;border-radius:12px;max-width:560px}
@media(max-width:640px){
  .controls input[type=text],.search-field{min-width:0}
  .grid{grid-template-columns:1fr}
}

/* password gate */
body.locked{overflow:hidden}
body.locked .topbar,body.locked .hero,body.locked .controls,body.locked .results,body.locked footer{display:none}
.gate{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:24px;
  background:linear-gradient(180deg,var(--navy) 0%,var(--navy-deep) 100%)}
.gate-card{background:var(--card);border:1px solid var(--line);border-radius:20px;box-shadow:0 24px 60px rgba(0,0,0,.35);
  width:100%;max-width:430px;padding:40px 34px 30px;text-align:center}
.gate-brand{font-family:"Cormorant Garamond",serif;font-size:22px;color:var(--navy-deep);margin-bottom:18px}
.gate-brand b{font-weight:600}.gate-brand i{color:var(--gold-deep);font-style:italic}
.gate-lock{width:64px;height:64px;border-radius:50%;background:var(--cream-2);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.gate-card h2{font-weight:600;font-size:30px;margin:0 0 8px;color:var(--navy-deep)}
.gate-sub{color:var(--muted);font-size:14.5px;margin:0 auto 22px;max-width:330px;line-height:1.5}
#gate-form{display:flex;flex-direction:column;gap:10px}
#gate-input{font:inherit;font-size:16px;text-align:center;padding:13px 14px;border:1px solid var(--line);
  border-radius:11px;background:#fff;color:var(--ink)}
#gate-input:focus{outline:2px solid var(--gold);border-color:var(--gold)}
#gate-form button{font:inherit;font-weight:600;font-size:15px;padding:13px 14px;border:0;border-radius:11px;
  background:var(--navy);color:#fff;cursor:pointer}
#gate-form button:hover{background:var(--navy-deep)}
.gate-error{display:none;color:#b3261e;font-size:13.5px;margin-top:2px}
.gate-note{color:var(--muted);font-size:13px;margin:20px 0 0}
.gate-note a{color:var(--gold-deep);font-weight:600}
