
:root{
  --ink:#0b2f35;
  --muted:#5e6d71;
  --border:#e6eaec;
  --bg:#ffffff;
  --card:#ffffff;
  --teal:#0b7a87;
  --teal2:#075f69;
  --gold:#d7a63a;
  --shadow: 0 12px 30px rgba(5, 70, 78, 0.10);
  --radius: 18px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);
  font-size:15px;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Helvetica Neue", Helvetica;}
a{color:var(--teal);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{letter-spacing:-0.01em}

.shell{display:flex;min-height:100vh}
.sidebar{
  width:280px; border-right:1px solid var(--border);
  background:linear-gradient(180deg,#fff, #fbfdfe);
  padding:18px 16px; position:sticky; top:0; height:100vh;
}
.brand{
  display:flex; align-items:center; gap:10px; padding:10px 10px 14px;
}
.brand img{height:48px;width:auto}
.brand .tag{font-size:12px;color:var(--muted);margin-top:2px}
.side-nav{display:flex;flex-direction:column;gap:6px;padding:8px}
.side-nav a{
  padding:10px 12px; border-radius:12px; font-weight:700; color:var(--teal2);
}
.side-nav a.active, .side-nav a:hover{background:rgba(11,122,135,.08);text-decoration:none}
.side-foot{margin-top:auto; padding:10px 12px; color:var(--muted); font-size:12px}

.main{flex:1; display:flex; flex-direction:column}
.topbar{
  display:none;
  position:sticky; top:0; z-index:20;
  background:rgba(255,255,255,.92); backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--border);
}
.topbar-inner{display:flex; align-items:center; justify-content:space-between; padding:12px 16px}
.topbrand{display:flex; align-items:center; gap:10px}
.topbrand img{height:42px}
.iconbtn{
  border:1px solid var(--border); background:#fff; border-radius:12px;
  padding:10px 12px; cursor:pointer; font-weight:800; color:var(--teal2);
}
.drawer{
  display:none; border-bottom:1px solid var(--border); background:#fff;
}
.drawer a{display:block; padding:12px 16px; font-weight:800; color:var(--teal2)}
.drawer a.active{background:rgba(11,122,135,.08)}

.wrap{max-width:1100px;margin:0 auto;padding:28px 22px; width:100%}

/* Hero image */
.hero-banner{margin:18px 0 18px 0;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--border); background:#fff;}
.hero-banner img{display:block;width:100%;height:160px;object-fit:cover}

.hero h1{font-size:2.25rem;margin:0 0 12px}
.lead{font-size:1.0rem; line-height:1.65; color:var(--muted); max-width:860px}
.card{background:var(--card); border:1px solid var(--border); border-radius:var(--radius); box-shadow:var(--shadow)}
.pad{padding:18px}
.grid-2{display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:20px}
@media (max-width:980px){ .grid-2{grid-template-columns:1fr} }

/* Find page */
.search-block{margin-top:22px}
.search-row{
  display:flex; gap:14px; align-items:stretch; margin-top:12px; flex-wrap:wrap;
  padding:10px; border:1px solid var(--border); border-radius:18px;
  background:rgba(255,255,255,.75);
}
.search-input{
  flex:1; min-width:260px;
  border:1px solid var(--border); border-radius:999px; padding:14px 18px;
  font-size:1.0rem; outline:none;
}
.search-input:focus{border-color:rgba(11,122,135,.45); box-shadow:0 0 0 4px rgba(11,122,135,.12)}
.btn{
  border:0; border-radius:999px; padding:14px 22px; font-weight:900;
  cursor:pointer; font-size:1rem;
}
.btn.primary{background:linear-gradient(180deg,var(--teal),var(--teal2)); color:#fff}
.btn.primary:hover{filter:brightness(1.03)}
.meta{margin-top:14px; color:var(--muted); font-size:0.98rem; line-height:1.6}
.meta strong{color:var(--ink)}
.results{margin-top:20px; display:grid; grid-template-columns:1fr; gap:12px}
.result-card{padding:14px 16px}
.result-top{display:flex; align-items:flex-start; justify-content:space-between; gap:10px}
.result-name{font-weight:900; font-size:1.05rem}
.badge{
  font-size:12px; font-weight:900; padding:6px 10px; border-radius:999px;
  background:rgba(215,166,58,.16); color:#6a4a05; border:1px solid rgba(215,166,58,.28);
  white-space:nowrap;
}
.result-sub{color:var(--muted); margin-top:6px; line-height:1.5}
.kv{display:flex; gap:14px; flex-wrap:wrap; margin-top:8px; color:var(--muted); font-size:0.95rem}
.kv span{display:inline-flex; gap:6px; align-items:center}
.fineprint{margin-top:22px; color:var(--muted); font-size:0.92rem; line-height:1.6}

.footer{padding:18px 22px; border-top:1px solid var(--border); color:var(--muted); font-size:12px; width:100%; text-align:center}

/* Mobile: switch to topbar + drawer */
@media (max-width:860px){
  .sidebar{display:none}
  .topbar{display:block}
  .wrap{padding:22px 16px}
  .hero h1{font-size:1.9rem}
}

.details{margin-top:12px;padding:10px 12px;border:1px solid var(--border);border-radius:14px;background:#fff}
.details summary{cursor:pointer;font-weight:800;color:var(--teal2);}
.kvline{margin-top:8px;color:var(--muted);font-size:0.95rem;line-height:1.45}
.kvline .k{font-weight:800;color:var(--ink)}

.row{margin-top:8px;color:var(--muted);font-size:0.98rem;line-height:1.5}
.row .lbl{font-weight:900;color:var(--ink);margin-right:6px}

/* Admin UI helpers */
.table{width:100%;border-collapse:separate;border-spacing:0 6px}
.table thead th{font-size:.9rem;color:var(--muted);text-align:left;padding:0 10px}
.table tbody tr{background:#fff;border-radius:14px;box-shadow:0 6px 20px rgba(0,0,0,.05)}
.table tbody td{padding:8px 10px;vertical-align:top}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width: 720px){.grid2{grid-template-columns:1fr}}
.btn-danger{background:#c0392b;color:#fff}
.btn-ghost{background:transparent;border:1px solid rgba(0,0,0,.12);color:var(--ink)}
.tabs{display:flex;gap:10px;align-items:center;margin-top:10px}
.tab-btn{border:1px solid rgba(0,0,0,.12);background:#fff;border-radius:999px;padding:10px 14px;font-weight:800;cursor:pointer}
.tab-btn.active{background:rgba(0,128,128,.08);border-color:rgba(0,128,128,.25)}
.modal{position:fixed;inset:0;background:rgba(0,0,0,.35);display:flex;align-items:center;justify-content:center;padding:18px;z-index:9999}
.modal-card{max-width:720px;width:100%;background:#fff;border-radius:18px;box-shadow:0 20px 60px rgba(0,0,0,.25);padding:16px}
.select{padding:8px 10px;border:1px solid var(--border);border-radius:10px;background:#fff;}

/* tighter admin layout */
.topbar{padding:14px 18px;}
.side{padding:14px 12px;}
.card.pad{padding:14px;}

/* modal form */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 14px;margin-top:10px;}
.form-grid .field{display:flex;flex-direction:column;gap:6px;}
.form-grid label{font-size:13px;color:#2a2a2a;}
.form-grid input{width:100%;}

/* ---------
   Forms
--------- */
.form{display:flex;flex-direction:column;gap:10px;}
.lbl{font-size:13px;color:#2a2a2a;font-weight:800;display:block;margin:10px 0 6px;}
.form .lbl:first-child{margin-top:0;}
.form .grid2 .lbl{margin-top:0;}
.input{width:100%;padding:10px 12px;border:1px solid #d7dde3;border-radius:12px;background:#fff;font-size:14px;}
.input:focus{outline:none;border-color:#0b6a73;box-shadow:0 0 0 3px rgba(11,106,115,.15);}
textarea.input{resize:vertical;min-height:120px;}
textarea.input{resize:vertical;min-height:140px;}
.row{display:flex;gap:12px;align-items:center;flex-wrap:wrap;}
.fineprint{font-size:13px;color:#5a6b73;}
@media (max-width: 700px){
  .form-grid{grid-template-columns:1fr;}
}


/* Admin polish */
.admin-form input, .admin-form textarea, .admin-form select{
  width:100%;
  padding:12px 14px;
  border:1px solid rgba(15,23,42,.18);
  border-radius:14px;
  background:#fff;
  outline:none;
}
.admin-form input:focus, .admin-form textarea:focus, .admin-form select:focus{
  border-color:rgba(11,122,135,.45);
  box-shadow:0 0 0 4px rgba(11,122,135,.12);
}
.admin-form .btn{
  padding:12px 16px;
  border-radius:999px;
}
.admin-table td, .admin-table th{
  padding:12px 10px;
}
.admin-table tr{
  border-bottom:1px solid rgba(15,23,42,.08);
}
.admin-toolbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.admin-toolbar .left{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.admin-toolbar .right{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.small-muted{font-size:13px; color:rgba(15,23,42,.6);}


.table.compact th, .table.compact td{padding:10px 12px;font-size:14px;}
.table.compact tr{height:auto;}


.admin .table th, .admin .table td{padding:10px 12px;}
.admin .table th{font-size:13px;}
.admin .table td{font-size:14px;}


/* === UI Polish v28 === */

/* Slightly smaller base body text */
body {
  font-size: 15px;
  line-height: 1.45;
}

/* Tighter spacing under headings */
h1, h2, h3 {
  margin-bottom: 0.4em;
}

/* Search box highlight container */
.search-box-wrap {
  border: 2px solid #0d7f86; /* MDHIN teal */
  border-radius: 16px;
  padding: 14px;
  margin: 18px 0 14px 0;
  background: #f9fefe;
}

/* Reduce spacing around helper text */
.search-helper,
.search-note {
  margin-top: 8px;
  margin-bottom: 8px;
  font-size: 0.9em;
}

/* Input height balance */
.search-box-wrap input[type="text"] {
  font-size: 15px;
  padding: 14px 16px;
}

/* Button alignment */
.search-box-wrap button {
  padding: 14px 22px;
}


.join-note{margin-top:14px;padding:14px 16px;background:rgba(11,122,135,.06);border:1px solid rgba(11,122,135,.25);border-left:4px solid var(--brand);border-radius:12px;color:var(--ink);font-size:.95rem;line-height:1.5}
.join-note strong{display:block;margin-bottom:4px}


/* PUBLIC TOP NAV OVERRIDES V2 */
/* Public pages: remove left rail, use top nav, sticky footer (UI only) */
body.public .shell{display:flex;flex-direction:column;min-height:100vh}
body.public .sidebar{display:none !important}
body.public .main{flex:1;min-height:100vh;display:flex;flex-direction:column}

body.public .topbar{position:sticky;top:0;z-index:30;background:#fff;border-bottom:1px solid var(--border)}
body.public .topbar-inner{max-width:1100px;margin:0 auto;padding:12px 22px;display:flex;align-items:center;gap:14px}
body.public .topbrand img{height:34px;width:auto;display:block}

body.public .topnav{display:flex;gap:10px;align-items:center;margin-left:auto}
body.public .topnav a{font-weight:800;color:var(--teal2);text-decoration:none;padding:8px 10px;border-radius:12px}
body.public .topnav a.active, body.public .topnav a:hover{background:rgba(11,122,135,.08)}

body.public #menuBtn{display:none}

body.public .drawer{display:none;border-bottom:1px solid var(--border);background:#fff}
body.public .drawer.open{display:block}

body.public .footer{display:none !important}
body.public .site-footer{margin-top:auto;padding:14px 0;border-top:1px solid var(--border);background:#fff}
body.public .site-footer .footer-inner{max-width:1100px;margin:0 auto;padding:0 22px;display:flex;flex-wrap:wrap;justify-content:space-between;gap:10px;color:var(--muted);font-size:13px}

body.public .wrap{max-width:1100px;margin:0 auto;padding:22px 22px;width:100%}

/* Mobile */
@media (max-width: 900px){
  body.public .topbar-inner{padding:12px 14px}
  body.public .wrap{padding:18px 14px}
  body.public .topnav{display:none}
  body.public #menuBtn{display:inline-flex;align-items:center}
}


/* PUBLIC TOP NAV OVERRIDES V3 */

/* Force topbar visible on desktop for PUBLIC pages and move logo to top-right */
body.public .topbar{display:block !important; position:sticky; top:0; z-index:50; background:#fff; border-bottom:1px solid var(--border)}
body.public .topbar-inner{max-width:1100px; margin:0 auto; padding:10px 22px; display:flex; align-items:center; gap:12px; justify-content:flex-start}
/* Menu button left (mobile), nav center/left, logo right */
body.public #menuBtn{margin-right:6px}
body.public .topnav{display:flex; gap:10px; align-items:center; margin-right:auto}
body.public .topbrand{margin-left:auto; display:flex; align-items:center}
body.public .topbrand img{height:34px}

/* Reduce excessive top whitespace on public pages */
body.public .wrap{padding-top:16px}
body.public .hero-banner{margin-top:10px}

@media (max-width:900px){
  body.public .topbar-inner{padding:10px 14px}
  body.public .topnav{display:none}
  body.public #menuBtn{display:inline-flex !important}
}


/* PUBLIC HEADER SPACING FIX */
/* Tighten space between top nav and hero on public pages */
body.public .topbar{margin-bottom:0}
body.public .wrap{padding-top:10px}
body.public .hero,
body.public .hero-wrap,
body.public .hero-card{margin-top:0 !important;padding-top:0 !important}

/* If hero image is inside a card, reduce radius spacing */
body.public .hero img,
body.public .hero-illustration{margin-top:0}

/* Reduce accidental spacer divs */
body.public .spacer,
body.public .mt-lg,
body.public .mt-xl{margin-top:0 !important}

/* Mobile even tighter */
@media (max-width:900px){
  body.public .wrap{padding-top:6px}
}


/* PUBLIC MAIN HEIGHT FIX */
/* Fix: main was taking 100vh and pushing content below fold */
body.public .shell{min-height:100vh;display:flex;flex-direction:column}
body.public .main{flex:0 !important;min-height:auto !important;display:block !important}
body.public .wrap{flex:1 0 auto}
body.public .site-footer{margin-top:auto}


/* HIDE DETAILS EXPANDER ON FIND RESULTS */
body.public details.details{display:none !important;}


/* FORCE TOPNAV VISIBILITY */
/* Ensure top horizontal nav is visible on public pages when present. */
body.public .topnav { display:flex; gap:14px; align-items:center; }
@media (max-width: 820px){
  body.public .topnav { display:none; }
}


/* JOIN PAGE STYLES */
.lede{color:var(--muted);max-width:72ch}
.req{color:#b00020;font-weight:800;margin-left:4px}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.field label{display:block;font-weight:800;margin:0 0 6px 0}
.field input{width:100%}
@media (max-width:820px){
  .form-grid{grid-template-columns:1fr}
}
