
:root{
  --navy:#07182a;--navy2:#0b2238;--ink:#f7edd5;--gold:#c89a43;--gold2:#e6c070;--line:#8c6a32;
  --paper:#fbf5e8;--panel:#0a1e32;--panel2:#0d2944;--blue:#0c4d8f;--bronze:#7b5934;--muted:#b8c7d4;
  --shadow:0 12px 36px rgba(0,0,0,.35);--softShadow:0 6px 18px rgba(0,0,0,.25)
}
*{box-sizing:border-box} html,body{margin:0;height:100%;font-family:Georgia,"Times New Roman",serif;background:#061321;color:var(--ink);overflow:hidden}
button,select,input{font-family:inherit}.masthead{height:116px;display:flex;align-items:center;gap:18px;padding:14px 24px;background:linear-gradient(180deg,#061629,#09233b);border-bottom:2px solid var(--line);box-shadow:var(--softShadow);position:relative;z-index:50}
.masthead:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 75% 20%,rgba(255,255,255,.08),transparent 30%);pointer-events:none}.seal{width:78px;height:78px;border:2px solid var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gold2);font-size:38px;box-shadow:inset 0 0 0 4px rgba(200,154,67,.15)}
.titleblock{flex:1;min-width:320px}.titleblock h1{margin:0;color:#fff7dd;text-transform:uppercase;letter-spacing:.8px;font-size:34px;line-height:1.05}.titleblock p{margin:6px 0 0;color:var(--gold2);font-variant:small-caps;letter-spacing:1px;font-size:16px}.topnav{display:flex;gap:10px;align-items:center}.topnav .nav{background:transparent;color:#f8ecd0;border:0;border-bottom:2px solid transparent;padding:10px 12px;text-transform:uppercase;letter-spacing:.08em;cursor:pointer}.topnav .nav.active,.topnav .nav:hover{color:var(--gold2);border-bottom-color:var(--gold)}
.tokenNotice{position:absolute;top:126px;left:50%;transform:translateX(-50%);z-index:1000;background:#fff9e6;color:#1b1b1b;border:2px solid #c89a43;border-radius:12px;padding:12px 18px;box-shadow:var(--shadow);max-width:760px}.tokenNotice code{background:#eee;padding:2px 5px;border-radius:4px}
.app{height:calc(100vh - 158px);display:grid;grid-template-columns:390px 1fr 0;transition:grid-template-columns .25s ease;position:relative}.app.left-collapsed{grid-template-columns:54px 1fr 0}.app.right-open{grid-template-columns:390px 1fr 410px}.app.left-collapsed.right-open{grid-template-columns:54px 1fr 410px}
.leftPanel{background:linear-gradient(180deg,#082038,#06172a);border-right:1px solid var(--line);position:relative;overflow:hidden}.panelToggle{position:absolute;top:12px;left:10px;z-index:2;width:34px;height:34px;border:1px solid var(--line);background:#0e2c48;color:var(--gold2);border-radius:7px;cursor:pointer}.panelInner{height:100%;overflow-y:auto;padding:18px 18px 22px 70px;scrollbar-color:var(--gold) #081927}.app.left-collapsed .panelInner{display:none}.panelInner h2{margin:0 0 12px;text-transform:uppercase;color:var(--gold2);font-size:18px;letter-spacing:.03em}.metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin:8px 0 15px}.metric{border:1px solid rgba(200,154,67,.45);border-radius:10px;background:rgba(255,255,255,.04);padding:8px;text-align:center}.metric strong{display:block;color:#fff;font-size:19px}.metric span{display:block;color:var(--muted);font-size:11px;line-height:1.2}
label{display:block;color:var(--gold2);text-transform:uppercase;font-size:12px;margin:10px 0 5px;letter-spacing:.07em}.searchRow{display:grid;grid-template-columns:1fr 38px;gap:6px}input,select{width:100%;background:#0c2944;color:#fff;border:1px solid rgba(200,154,67,.5);border-radius:8px;padding:10px 11px;font-size:14px}input::placeholder{color:#9eb2c4}#clearSearch{border:1px solid rgba(200,154,67,.5);border-radius:8px;background:#0c2944;color:var(--gold2);font-size:22px;cursor:pointer}.filters{display:grid;gap:7px;margin-top:8px}.quickSearches{display:flex;flex-wrap:wrap;gap:7px;margin:14px 0}.quickSearches button{border:1px solid var(--line);border-radius:999px;background:#081927;color:#fff1d1;padding:7px 10px;cursor:pointer}.quickSearches button:hover{background:#163854;color:#fff}.resultSummary{border-top:1px solid rgba(200,154,67,.35);border-bottom:1px solid rgba(200,154,67,.35);padding:10px 0;color:#d7e2ed;font-size:14px;margin:4px 0 8px}.listBlock{display:grid;gap:7px}.townItem,.recordItem{background:rgba(255,255,255,.055);border:1px solid rgba(200,154,67,.25);border-radius:10px;padding:9px 10px;cursor:pointer;color:#f7edd5}.townItem:hover,.recordItem:hover{border-color:var(--gold);background:rgba(200,154,67,.12)}.townItem{display:grid;grid-template-columns:1fr auto;gap:8px}.townItem strong,.recordItem strong{display:block;color:#fff;font-size:15px}.townItem span,.recordItem span{font-size:12px;color:#b9c9d6}.badge{background:#113d65;border:1px solid rgba(230,192,112,.65);border-radius:999px;color:#fff;padding:2px 8px;font-size:12px;align-self:start}.matchHint{font-style:italic;color:#e6c070!important;margin-top:3px;display:block}.mapWrap{position:relative;min-width:0}#map{position:absolute;inset:0;background:linear-gradient(135deg,#5f785f,#1e4050)}.mapBadge{position:absolute;top:16px;left:50%;transform:translateX(-50%);z-index:3;background:rgba(7,24,42,.9);border:1px solid var(--line);color:#fff7dd;border-radius:8px;padding:11px 16px;text-align:center;box-shadow:var(--softShadow);font-size:14px}.legend{position:absolute;right:18px;bottom:22px;z-index:3;background:rgba(7,24,42,.93);border:1px solid var(--line);border-radius:8px;padding:12px 14px;color:#fff;box-shadow:var(--softShadow);display:grid;gap:7px;font-size:13px}.legendCircle,.legendDot{display:inline-block;border-radius:50%;border:2px solid #fff;margin-right:8px;vertical-align:middle}.legendCircle{width:18px;height:18px;background:#0c4d8f}.legendDot{width:9px;height:9px;background:#0c4d8f}.legendStar{color:var(--gold);margin-right:8px}.rightPanel{background:linear-gradient(180deg,#081927,#05131f);border-left:1px solid var(--line);overflow:auto;position:relative;box-shadow:-8px 0 24px rgba(0,0,0,.25)}.closeRight{position:absolute;right:12px;top:10px;background:transparent;border:0;color:var(--gold2);font-size:30px;cursor:pointer;z-index:2}.profileHero{min-height:142px;padding:26px 44px 20px 22px;background:linear-gradient(135deg,rgba(200,154,67,.28),rgba(7,24,42,.35)),url('')}.profileHero h2{margin:0;color:var(--gold2);font-size:26px;line-height:1.08}.profileHero p{margin:6px 0 0;color:#bde6ff;font-size:15px}.profileBody{padding:16px 18px 28px}.field{display:grid;grid-template-columns:132px 1fr;gap:10px;border-bottom:1px solid rgba(200,154,67,.22);padding:9px 0}.fieldLabel{color:#e7c577;font-size:12px;text-transform:uppercase;letter-spacing:.04em}.fieldValue{color:#fff;line-height:1.35;white-space:pre-wrap}.empty{color:#9db0c1;text-align:center;border:1px dashed rgba(200,154,67,.4);border-radius:10px;padding:20px;margin-top:10px}.accordion{margin-top:14px;border:1px solid rgba(200,154,67,.35);border-radius:10px;overflow:hidden}.accordion summary{padding:10px 12px;cursor:pointer;background:rgba(200,154,67,.12);color:var(--gold2);font-weight:bold}.allFields{padding:6px 12px}.footer{height:42px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;background:#061321;border-top:1px solid var(--line);color:var(--gold2);font-variant:small-caps;letter-spacing:.04em;font-size:14px}.mapboxgl-popup-content{font-family:Georgia,"Times New Roman",serif;background:#fffdf8;color:#111;border:1px solid #c89a43;border-radius:8px;padding:12px}.mapboxgl-popup-content h3{margin:0 0 6px;color:#07182a}.mapboxgl-popup-content button{border:0;background:#0c4d8f;color:white;border-radius:6px;padding:7px 9px;margin-top:6px;cursor:pointer}.mapboxgl-ctrl-group{box-shadow:var(--softShadow)!important}.mapboxgl-ctrl button{font-family:sans-serif}
@media(max-width:900px){.masthead{height:auto;min-height:110px}.titleblock h1{font-size:24px}.topnav{display:none}.app,.app.right-open{grid-template-columns:1fr;height:calc(100vh - 152px)}.leftPanel{position:absolute;left:0;top:0;bottom:0;width:min(390px,92vw);z-index:15;transform:translateX(0);transition:transform .2s}.app.left-collapsed .leftPanel{transform:translateX(-336px)}.rightPanel{position:absolute;right:0;top:0;bottom:0;width:min(410px,92vw);z-index:20;transform:translateX(100%);transition:transform .2s}.app.right-open .rightPanel{transform:translateX(0)}.mapBadge{left:60px;right:16px;transform:none}.legend{display:none}}


/* Memorial atlas refinements */
.masthead{background:linear-gradient(90deg,#061629 0%,#09233b 45%,#061629 100%)}
.seal{font-size:34px;background:radial-gradient(circle,#12304e 0%,#07182a 68%)}
.topnav .nav.muted{opacity:.72}.topnav .nav.muted:hover{opacity:1}
.selectedResults{border:1px solid rgba(200,154,67,.42);border-radius:14px;background:linear-gradient(180deg,rgba(14,44,72,.75),rgba(7,24,42,.72));padding:10px;margin:8px 0 12px;box-shadow:0 8px 20px rgba(0,0,0,.18)}
.resultSummary{border:0;margin:0 0 8px;padding:0 0 9px;color:#f8ecd0;border-bottom:1px solid rgba(200,154,67,.28)}
.resultSummary strong{display:block;color:var(--gold2);font-size:17px;letter-spacing:.02em}.resultSummary span{display:block;color:#b8c7d4;font-size:12px;margin-top:3px}
.recordResults{max-height:42vh;overflow-y:auto;padding-right:4px;scrollbar-color:var(--gold) #081927}.recordItem{background:rgba(255,255,255,.07);border-color:rgba(230,192,112,.32)}
.recordItem strong{font-size:16px;color:#fff6d7}.recordItem:hover{transform:translateY(-1px)}
.townIndex{margin-top:10px;border:1px solid rgba(200,154,67,.35);border-radius:14px;overflow:hidden;background:rgba(255,255,255,.035)}
.townIndex summary{cursor:pointer;list-style:none;padding:11px 12px;color:var(--gold2);font-weight:bold;text-transform:uppercase;letter-spacing:.04em;background:rgba(200,154,67,.10);border-bottom:1px solid rgba(200,154,67,.25)}
.townIndex summary::-webkit-details-marker{display:none}.townIndex summary:before{content:'▸';display:inline-block;margin-right:8px;transition:transform .2s}.townIndex[open] summary:before{transform:rotate(90deg)}
.townResults{padding:10px;max-height:38vh;overflow-y:auto;scrollbar-color:var(--gold) #081927}.townItem strong{font-size:16px}.townItem span{font-size:13px}
.profileHero{min-height:185px;display:grid;grid-template-columns:112px 1fr;gap:16px;align-items:end;padding:20px 46px 20px 18px;background:linear-gradient(90deg,rgba(8,25,39,.98),rgba(8,25,39,.72)),radial-gradient(circle at 20% 20%,rgba(230,192,112,.18),transparent 35%),linear-gradient(135deg,#13293d,#061321);border-bottom:1px solid var(--line)}
.portrait{width:112px;height:132px;border:1px solid rgba(230,192,112,.52);border-radius:12px;background:linear-gradient(180deg,rgba(251,245,232,.16),rgba(0,0,0,.24)),radial-gradient(circle at 50% 35%,rgba(230,192,112,.25),transparent 34%);position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px rgba(255,255,255,.05)}
.portrait:before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,transparent 0 42%,rgba(200,154,67,.14) 43% 47%,transparent 48%)}
.portrait .head{position:absolute;left:34px;top:28px;width:45px;height:50px;border-radius:48% 48% 44% 44%;background:#151413;box-shadow:0 0 0 2px rgba(230,192,112,.12)}
.portrait .shoulders{position:absolute;left:18px;bottom:0;width:78px;height:54px;border-radius:50% 50% 0 0;background:#151413}
.heroText h2{font-size:27px;color:var(--gold2);margin:0 0 5px;line-height:1.05}.heroPlace{color:#78d8ff!important;font-size:15px!important}.heroService{color:#fff!important;font-size:15px!important}.tagRow{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.tagRow span{border:1px solid rgba(230,192,112,.45);border-radius:999px;padding:4px 8px;color:#fff7dd;background:rgba(200,154,67,.12);font-size:12px}
.field{grid-template-columns:145px 1fr}.fieldLabel{color:#f0cd7d}.fieldValue{color:#fffaf0}.mapBadge{background:rgba(7,24,42,.92);border-color:rgba(230,192,112,.65)}
@media(max-width:900px){.selectedResults{margin-left:0}.recordResults{max-height:34vh}.profileHero{grid-template-columns:88px 1fr}.portrait{width:88px;height:105px}.portrait .head{left:27px;top:22px;width:35px;height:40px}.portrait .shoulders{left:13px;width:62px;height:42px}.heroText h2{font-size:22px}}


/* Connecticut Heritage & Memory revision */
:root{
  --navy:#102A43;--navy2:#0B1F33;--ink:#F8F1E7;--gold:#B58A4A;--gold2:#D2B06A;--line:#7A1F2B;
  --paper:#F8F1E7;--panel:#0B1F33;--panel2:#102A43;--blue:#102A43;--bronze:#B58A4A;--muted:#C8D2DC;
}
.seal,.mapBadge,.legend,.mapNote{display:none!important;}
.masthead{height:74px!important;min-height:74px!important;padding:10px 18px!important;background:linear-gradient(90deg,#0B1F33 0%,#102A43 55%,#1A2634 100%)!important;border-bottom:2px solid var(--gold)!important;}
.titleblock h1{font-size:25px!important;letter-spacing:.04em!important;line-height:1!important;color:#F8F1E7!important;}
.titleblock p{font-size:12px!important;color:#D2B06A!important;margin-top:5px!important;}
.topnav .nav{font-size:12px!important;padding:8px 10px!important;color:#F8F1E7!important;}
.topnav .nav.active,.topnav .nav:hover{color:#D2B06A!important;border-bottom-color:#7A1F2B!important;}
.leftPanel,.rightPanel{background:linear-gradient(180deg,#102A43,#0B1F33)!important;}
.panelToggle,input,select,#clearSearch{background:#102A43!important;border-color:rgba(181,138,74,.75)!important;}
.quickSearches button{background:#0B1F33!important;border-color:#B58A4A!important;color:#F8F1E7!important;}
.quickSearches button:hover{background:#7A1F2B!important;color:#fff!important;}
#resetButton{background:#7A1F2B!important;color:#fff!important;border:2px solid #D2B06A!important;font-weight:bold!important;box-shadow:0 0 0 1px rgba(255,255,255,.12) inset;}
.resultSummary strong,.panelInner h2,.townIndex summary,.profileHero h2{color:#D2B06A!important;}
.townItem:hover,.recordItem:hover{border-color:#D2B06A!important;background:rgba(122,31,43,.30)!important;}
.badge{background:#7A1F2B!important;border-color:#D2B06A!important;color:#fff!important;}
.footer{background:#0B1F33!important;color:#D2B06A!important;border-top-color:#B58A4A!important;}
@media(max-width:900px){
  .masthead{height:54px!important;min-height:54px!important;overflow:hidden!important;padding:7px 12px!important;cursor:pointer;}
  .masthead.expanded{height:auto!important;min-height:96px!important;}
  .titleblock h1{font-size:18px!important;}
  .titleblock p{display:none!important;}
  .masthead.expanded .titleblock p{display:block!important;}
  .app,.app.right-open{height:calc(100vh - 96px)!important;}
}


/* Revision: make Heritage & Memory burgundy visible in menus and restore dropdown arrows */
.filters select,
select {
  background-color: #7A1F2B !important;
  color: #F8F1E7 !important;
  border: 1.5px solid #B58A4A !important;
  border-radius: 10px !important;
  padding-right: 42px !important;
  appearance: auto !important;
  -webkit-appearance: menulist !important;
  -moz-appearance: auto !important;
}

/* Keep quick-search reset visually distinct */
#resetButton {
  background: #F8F1E7 !important;
  color: #7A1F2B !important;
  border: 2px solid #B58A4A !important;
  font-weight: 800 !important;
  box-shadow: 0 0 0 2px rgba(122,31,43,.35) inset !important;
}

/* Quick-search buttons stay heritage blue/bronze */
.quickSearches button:not(#resetButton) {
  background: #102A43 !important;
  color: #F8F1E7 !important;
  border-color: #B58A4A !important;
}


/* Revision 3: restore neutral dropdowns with visible arrows */
.filters select,
select {
  background-color: #102A43 !important;
  color: #F8F1E7 !important;
  border: 1.5px solid #B58A4A !important;
  border-radius: 10px !important;
  padding-right: 42px !important;
  appearance: auto !important;
  -webkit-appearance: menulist !important;
  -moz-appearance: auto !important;
}

/* Blended Heritage & Memory banner */
.masthead {
  background: linear-gradient(90deg,#102A43 0%, #162F4A 45%, #7A1F2B 100%) !important;
  border-bottom: 2px solid #B58A4A !important;
}
.masthead:after {
  background: radial-gradient(circle at 85% 30%,rgba(248,241,231,.12),transparent 34%) !important;
}

/* Retractable top banner */
.mastheadToggle {
  position: fixed;
  top: 8px;
  right: 10px;
  z-index: 2000;
  width: 34px;
  height: 28px;
  border-radius: 8px;
  border: 1px solid #B58A4A;
  background: #7A1F2B;
  color: #F8F1E7;
  font-weight: bold;
  cursor: pointer;
  box-shadow: 0 4px 12px rgba(0,0,0,.28);
}
body.masthead-collapsed .masthead {
  height: 0 !important;
  min-height: 0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  border-bottom: 0 !important;
  overflow: hidden !important;
}
body.masthead-collapsed .app {
  height: calc(100vh - 42px) !important;
}
body.masthead-collapsed .footer {
  height: 42px !important;
}

/* Reset remains clear but not confused with dropdowns */
#resetButton {
  background: #F8F1E7 !important;
  color: #7A1F2B !important;
  border: 2px solid #B58A4A !important;
  font-weight: 800 !important;
}


/* Connecticut Template Standard: final shared button style */
#resetButton {
  background: #7A1F2B !important;
  color: #F8F1E7 !important;
  border: 2px solid #B58A4A !important;
  font-weight: 900 !important;
  box-shadow: 0 0 0 1px rgba(248,241,231,.18) inset, 0 4px 10px rgba(0,0,0,.25) !important;
}

.quickSearches button:not(#resetButton) {
  background: #102A43 !important;
  color: #F8F1E7 !important;
  border: 1.5px solid #B58A4A !important;
}

.quickSearches button:not(#resetButton):hover {
  background: #7A1F2B !important;
  color: #F8F1E7 !important;
}

/* FINAL PUBLIC TEMPLATE LOCK — North Carolina after Virginia/CT cleanup */
:root{
  --navy:#102A43;
  --navy2:#0B1F33;
  --ink:#F8F1E7;
  --paper:#F8F1E7;
  --gold:#B58A4A;
  --gold2:#D2B06A;
  --line:#7A1F2B;
  --panel:#0B1F33;
  --panel2:#102A43;
  --muted:#C8D2DC;
  --shadow:0 12px 36px rgba(0,0,0,.35);
  --softShadow:0 6px 18px rgba(0,0,0,.25);
}

html,body{
  margin:0!important;
  width:100%!important;
  height:100%!important;
  background:#061321!important;
  color:#F8F1E7!important;
  overflow:hidden!important;
  font-family:Georgia,"Times New Roman",serif!important;
}

.footer,
#footerStats,
.metrics,
#metrics,
.panelInner > h2,
.mapBadge,
.legend,
.mapNote,
.openTownList,
#openTownList,
.showRecords,
#showRecords,
.infoPopup,
.townPopup,
.mapboxgl-popup,
.mapboxgl-popup-content{
  display:none!important;
  visibility:hidden!important;
  pointer-events:none!important;
}

.masthead,
#masthead{
  height:74px!important;
  min-height:74px!important;
  padding:10px 18px!important;
  display:flex!important;
  align-items:center!important;
  gap:18px!important;
  background:linear-gradient(90deg,#102A43 0%,#162F4A 45%,#7A1F2B 100%)!important;
  border-bottom:2px solid #B58A4A!important;
  box-shadow:var(--softShadow)!important;
  position:relative!important;
  z-index:50!important;
  overflow:hidden!important;
}

.masthead:after,
#masthead:after{
  content:""!important;
  position:absolute!important;
  inset:0!important;
  background:radial-gradient(circle at 85% 30%,rgba(248,241,231,.12),transparent 34%)!important;
  pointer-events:none!important;
}

.titleblock{flex:1!important;min-width:0!important;}

.titleblock h1{
  margin:0!important;
  color:#F8F1E7!important;
  text-transform:uppercase!important;
  letter-spacing:.04em!important;
  font-size:25px!important;
  line-height:1!important;
  font-weight:700!important;
}

.titleblock p{
  margin:5px 0 0!important;
  color:#D2B06A!important;
  font-variant:small-caps!important;
  letter-spacing:1px!important;
  font-size:12px!important;
}

.topnav{display:flex!important;gap:10px!important;align-items:center!important;}

.topnav .nav{
  background:transparent!important;
  color:#F8F1E7!important;
  border:0!important;
  border-bottom:2px solid transparent!important;
  border-radius:0!important;
  box-shadow:none!important;
  padding:8px 10px!important;
  text-transform:uppercase!important;
  letter-spacing:.08em!important;
  font-size:12px!important;
  cursor:pointer!important;
}

.topnav .nav.active,
.topnav .nav:hover{
  color:#D2B06A!important;
  border-bottom-color:#7A1F2B!important;
  background:transparent!important;
}

#mastheadToggle,
.mastheadToggle{
  position:fixed!important;
  top:80px!important;
  left:50%!important;
  right:auto!important;
  transform:translateX(-50%)!important;
  z-index:3000!important;
  width:34px!important;
  height:26px!important;
  border-radius:8px!important;
  border:1px solid #B58A4A!important;
  background:#7A1F2B!important;
  color:#F8F1E7!important;
  font-weight:900!important;
  line-height:1!important;
  cursor:pointer!important;
  box-shadow:0 4px 12px rgba(0,0,0,.28)!important;
}

body.masthead-collapsed #mastheadToggle,
body.masthead-collapsed .mastheadToggle{top:8px!important;}

body.masthead-collapsed .masthead,
body.masthead-collapsed #masthead{
  height:0!important;
  min-height:0!important;
  padding-top:0!important;
  padding-bottom:0!important;
  border-bottom:0!important;
}

.app{
  height:calc(100vh - 74px)!important;
  display:grid!important;
  grid-template-columns:390px 1fr 0!important;
  transition:grid-template-columns .25s ease!important;
  position:relative!important;
  min-height:0!important;
  background:#061321!important;
}

body.masthead-collapsed .app{height:100vh!important;}
.app.left-collapsed{grid-template-columns:54px 1fr 0!important;}
.app.right-open{grid-template-columns:390px 1fr 410px!important;}
.app.left-collapsed.right-open{grid-template-columns:54px 1fr 410px!important;}

.leftPanel{
  background:linear-gradient(180deg,#102A43,#0B1F33)!important;
  border-right:1px solid #B58A4A!important;
  position:relative!important;
  overflow:hidden!important;
  min-height:0!important;
}

.panelInner{
  height:100%!important;
  overflow-y:auto!important;
  padding:12px 18px 22px 70px!important;
  scrollbar-color:#B58A4A #081927!important;
}

.app.left-collapsed .panelInner{display:none!important;}

.panelToggle,
#leftToggle,
#panelToggle,
.sidebarToggle{
  width:44px!important;
  height:44px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  background:#7A1F2B!important;
  border:1.5px solid #D2B06A!important;
  border-radius:10px!important;
  color:#F8F1E7!important;
  font-size:22px!important;
  font-weight:700!important;
  cursor:pointer!important;
  box-shadow:0 2px 6px rgba(0,0,0,.25), inset 0 1px 0 rgba(255,255,255,.08)!important;
  position:absolute!important;
  top:12px!important;
  left:10px!important;
  z-index:2000!important;
}

label{
  display:block!important;
  color:#D2B06A!important;
  text-transform:uppercase!important;
  font-size:12px!important;
  margin:0 0 5px!important;
  letter-spacing:.07em!important;
}

.searchRow{
  display:grid!important;
  grid-template-columns:1fr 44px!important;
  gap:8px!important;
  margin-top:2px!important;
  margin-bottom:10px!important;
}

input,
select,
#clearSearch{
  width:100%!important;
  min-height:44px!important;
  background:#0B1F33!important;
  color:#F8F1E7!important;
  border:1.5px solid #B58A4A!important;
  border-radius:8px!important;
  padding:12px 14px!important;
  font-size:16px!important;
  box-shadow:none!important;
}

select{
  appearance:auto!important;
  -webkit-appearance:menulist!important;
  -moz-appearance:auto!important;
}

#clearSearch{
  min-width:44px!important;
  font-size:20px!important;
  cursor:pointer!important;
  padding:0!important;
}

.filters{
  display:grid!important;
  gap:8px!important;
  margin-top:8px!important;
}

.quickSearches{
  display:flex!important;
  flex-wrap:wrap!important;
  gap:7px!important;
  margin:12px 0!important;
}

.quickSearches button{
  border:1.5px solid #B58A4A!important;
  border-radius:999px!important;
  background:#0B1F33!important;
  color:#F8F1E7!important;
  padding:7px 10px!important;
  cursor:pointer!important;
  font-weight:400!important;
  box-shadow:none!important;
}

.quickSearches button:hover{
  background:#7A1F2B!important;
  color:#F8F1E7!important;
}

#resetButton{
  background:#7A1F2B!important;
  color:#F8F1E7!important;
  border:2px solid #D2B06A!important;
  border-radius:999px!important;
  font-weight:900!important;
  box-shadow:0 0 0 1px rgba(248,241,231,.18) inset,0 4px 10px rgba(0,0,0,.25)!important;
}

.selectedResults,
.townIndex{
  border:1px solid rgba(181,138,74,.35)!important;
  border-radius:12px!important;
  background:rgba(255,255,255,.035)!important;
  box-shadow:none!important;
}

.selectedResults{
  padding:10px!important;
  margin:8px 0 12px!important;
}

.recordResults{
  max-height:42vh!important;
  overflow-y:auto!important;
  padding-right:4px!important;
  scrollbar-color:#B58A4A #081927!important;
}

.townResults{
  padding:10px!important;
  max-height:38vh!important;
  overflow-y:auto!important;
  scrollbar-color:#B58A4A #081927!important;
}

.mapWrap{
  position:relative!important;
  min-width:0!important;
  min-height:0!important;
  background:#061321!important;
}

#map{
  position:absolute!important;
  inset:0!important;
  background:linear-gradient(135deg,#5f785f,#1e4050)!important;
}

.rightPanel{
  background:linear-gradient(180deg,#102A43,#0B1F33)!important;
  border-left:1px solid #B58A4A!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  -webkit-overflow-scrolling:touch!important;
  position:relative!important;
  min-height:0!important;
  max-height:100%!important;
  box-shadow:-8px 0 24px rgba(0,0,0,.25)!important;
  scrollbar-color:#B58A4A #081927!important;
}

.closeRight{
  position:absolute!important;
  right:12px!important;
  top:10px!important;
  z-index:2200!important;
  background:transparent!important;
  border:0!important;
  color:#D2B06A!important;
  font-size:30px!important;
  cursor:pointer!important;
}

.profileHero{
  min-height:185px!important;
  display:grid!important;
  grid-template-columns:112px minmax(0,1fr)!important;
  gap:16px!important;
  align-items:end!important;
  padding:20px 46px 20px 18px!important;
  background:linear-gradient(90deg,rgba(8,25,39,.98),rgba(8,25,39,.72)),radial-gradient(circle at 20% 20%,rgba(210,176,106,.18),transparent 35%),linear-gradient(135deg,#13293d,#061321)!important;
  border-bottom:1px solid #B58A4A!important;
}

.portrait{
  width:112px!important;
  height:132px!important;
  grid-column:1!important;
  grid-row:1!important;
  align-self:end!important;
  justify-self:start!important;
  border:1px solid rgba(210,176,106,.52)!important;
  border-radius:12px!important;
  background:linear-gradient(180deg,rgba(248,241,231,.10),rgba(0,0,0,.18)),radial-gradient(circle at 50% 35%,rgba(210,176,106,.18),transparent 34%),linear-gradient(135deg,#1a2430,#0B1F33)!important;
  position:relative!important;
  overflow:hidden!important;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.05)!important;
}

.portrait:before{
  content:""!important;
  position:absolute!important;
  inset:0!important;
  background:linear-gradient(135deg,transparent 0 42%,rgba(181,138,74,.12) 43% 47%,transparent 48%),radial-gradient(circle at 50% 38%,rgba(248,241,231,.05),transparent 42%)!important;
  pointer-events:none!important;
}

.portrait .head{
  position:absolute!important;
  left:34px!important;
  top:24px!important;
  width:42px!important;
  height:48px!important;
  border-radius:50%!important;
  background:#111!important;
  box-shadow:0 0 18px rgba(0,0,0,.35)!important;
}

.portrait .shoulders{
  position:absolute!important;
  left:18px!important;
  bottom:0!important;
  width:76px!important;
  height:52px!important;
  border-radius:55% 55% 0 0!important;
  background:#111!important;
}

.heroText{
  grid-column:2!important;
  grid-row:1!important;
  align-self:end!important;
  min-width:0!important;
}

.profileHero h2,
.heroText h2{
  margin:0 0 5px!important;
  color:#D2B06A!important;
  font-size:27px!important;
  line-height:1.05!important;
}

.profileHero p,
.heroText p{
  margin:6px 0 0!important;
  color:#F8F1E7!important;
  font-size:15px!important;
}

.profileBody{
  min-height:0!important;
  overflow:visible!important;
  padding:16px 18px 40px!important;
}

.field{
  display:grid!important;
  grid-template-columns:145px 1fr!important;
  gap:10px!important;
  border-bottom:1px solid rgba(181,138,74,.22)!important;
  padding:9px 0!important;
}

.fieldLabel{
  color:#D2B06A!important;
  font-size:12px!important;
  text-transform:uppercase!important;
  letter-spacing:.04em!important;
}

.fieldValue{
  color:#F8F1E7!important;
  line-height:1.35!important;
  white-space:pre-wrap!important;
}

@media(max-width:900px){
  .masthead,#masthead{
    height:54px!important;
    min-height:54px!important;
    padding:7px 12px!important;
  }
  .titleblock h1{font-size:18px!important;}
  .titleblock p,.topnav{display:none!important;}
  #mastheadToggle,.mastheadToggle{top:60px!important;}
  body.masthead-collapsed #mastheadToggle,
  body.masthead-collapsed .mastheadToggle{top:8px!important;}
  .app,.app.right-open{
    grid-template-columns:1fr!important;
    height:calc(100vh - 54px)!important;
  }
  body.masthead-collapsed .app{height:100vh!important;}
  .leftPanel{
    position:absolute!important;
    left:0!important;
    top:0!important;
    bottom:0!important;
    width:min(390px,92vw)!important;
    z-index:15!important;
    transform:translateX(0)!important;
    transition:transform .2s!important;
  }
  .app.left-collapsed .leftPanel{transform:translateX(-336px)!important;}
  .rightPanel{
    position:absolute!important;
    right:0!important;
    top:0!important;
    bottom:0!important;
    width:min(410px,92vw)!important;
    z-index:20!important;
    transform:translateX(100%)!important;
    transition:transform .2s!important;
  }
  .app.right-open .rightPanel{transform:translateX(0)!important;}
  .profileHero{
    grid-template-columns:88px minmax(0,1fr)!important;
    gap:12px!important;
    padding:16px 42px 16px 14px!important;
  }
  .portrait{width:88px!important;height:105px!important;}
  .portrait .head{
    left:27px!important;
    top:22px!important;
    width:35px!important;
    height:40px!important;
  }
  .portrait .shoulders{
    left:13px!important;
    width:62px!important;
    height:42px!important;
  }
  .profileHero h2,.heroText h2{font-size:22px!important;}
}

/* SAFE FLOATING STATE DIRECTORY
   Positioned bottom-center to avoid the profile-panel X and the left hamburger toggle. */
.stateDirectory{
  position:fixed!important;
  left:50%!important;
  right:auto!important;
  bottom:18px!important;
  top:auto!important;
  transform:translateX(-50%)!important;
  z-index:9000!important;
  font-family:Georgia,"Times New Roman",serif!important;
}

.stateDirectoryButton{
  min-width:104px!important;
  height:38px!important;
  padding:0 14px!important;
  border-radius:10px!important;
  border:1.5px solid #D2B06A!important;
  background:#7A1F2B!important;
  color:#F8F1E7!important;
  font-weight:900!important;
  cursor:pointer!important;
  box-shadow:0 4px 14px rgba(0,0,0,.34)!important;
  opacity:1!important;
  visibility:visible!important;
  pointer-events:auto!important;
}

.stateDirectoryMenu{
  position:absolute!important;
  left:50%!important;
  bottom:46px!important;
  transform:translateX(-50%)!important;
  width:210px!important;
  max-height:56vh!important;
  overflow-y:auto!important;
  border:1px solid #B58A4A!important;
  border-radius:12px!important;
  background:#0B1F33!important;
  box-shadow:0 10px 26px rgba(0,0,0,.38)!important;
}

.stateDirectoryMenu a{
  display:block!important;
  padding:10px 12px!important;
  color:#F8F1E7!important;
  text-decoration:none!important;
  border-bottom:1px solid rgba(181,138,74,.25)!important;
  font-size:14px!important;
  background:#0B1F33!important;
}

.stateDirectoryMenu a:hover{
  background:#7A1F2B!important;
  color:#F8F1E7!important;
}

@media(max-width:900px){
  .stateDirectory{
    bottom:12px!important;
  }
  .stateDirectoryMenu{
    width:190px!important;
    max-height:52vh!important;
  }
}
