/* ── TOKENS ─────────────────────────────────────────────── */
:root {
  --navy:      #001530;
  --navy-mid:  #002857;
  --blue:      #003F7F;
  --blue-b:    #005EB8;
  --gold:      #FFC72C;
  --gold-d:    #D4A010;
  --gold-dim:  rgba(255,199,44,0.12);
  --gold-line: rgba(255,199,44,0.22);
  --white:     #FFFFFF;
  --text:      rgba(255,255,255,0.85);
  --muted:     rgba(255,255,255,0.45);
  --dim:       rgba(255,255,255,0.22);
  --border:    rgba(255,255,255,0.09);
  --surface:   rgba(255,255,255,0.04);
  --surface2:  rgba(255,255,255,0.07);
  --teal:      #00C9A7;
  --green:     #38A169;
  --sidebar-w: 260px;
  --sidebar-collapsed: 64px;
  --topbar-h: 64px;
}

/* ── RESET ─────────────────────────────────────────────── */
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  font-family:'DM Sans',sans-serif;
  background:var(--navy);
  color:var(--white);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* ── LAYOUT SHELL ───────────────────────────────────────── */
.app-shell{display:flex;min-height:100vh;}

/* ── SIDEBAR ─────────────────────────────────────────────── */
.sidebar{
  position:fixed;top:0;left:0;bottom:0;
  width:var(--sidebar-w);
  background:#001020;
  border-right:1px solid rgba(255,255,255,0.08);
  display:flex;flex-direction:column;
  z-index:200;
  transition:width .28s cubic-bezier(.4,0,.2,1);
  overflow:hidden;
}
.sidebar.collapsed{width:var(--sidebar-collapsed);}
.sidebar.collapsed .sb-label,
.sidebar.collapsed .sb-section-title,
.sidebar.collapsed .sb-brand-text,
.sidebar.collapsed .sb-county-toggle,
.sidebar.collapsed .sb-sub{display:none;}
/* Icon rail: badges + lock pseudo still sat in flex with margin-left:auto → misaligned icons */
.sidebar.collapsed .sb-badge,
.sidebar.collapsed a.tg-gated::after{display:none;}
.sidebar.collapsed .sb-item{
  justify-content:center;
  align-items:center;
  padding:9px 0;
  gap:0;
  border-left-color:transparent;
}
.sidebar.collapsed .sb-item:hover,
.sidebar.collapsed .sb-item.active{border-left-color:transparent;}
.sidebar.collapsed .sb-icon{margin:0;}
.sidebar.collapsed .sb-brand{
  justify-content:center;
  padding-left:0;
  padding-right:0;
}

/* Sidebar brand */
.sb-brand{
  display:flex;align-items:center;gap:12px;
  padding:18px 20px 14px;
  border-bottom:2px solid rgba(255,199,44,0.2);
  flex-shrink:0;min-height:var(--topbar-h);
  text-decoration:none;color:inherit;
  cursor:pointer;
  box-sizing:border-box;
}
a.sb-brand:hover .sb-brand-text{color:#fff;}
a.sb-brand:hover .sb-logo-mark{filter:brightness(1.05);}
.sb-logo-mark{
  width:32px;height:32px;border-radius:9px;
  background:var(--gold);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.sb-logo-mark svg{width:18px;height:18px;}
.sb-brand-text{
  font-family:'DM Serif Display',serif;
  font-size:15px;color:#fff;letter-spacing:-0.1px;white-space:nowrap;
}
.sb-brand-text span{color:var(--gold);}

/* Toggle button */
.sb-toggle{
  position:absolute;top:18px;right:-14px;
  width:28px;height:28px;border-radius:50%;
  background:#001530;border:1.5px solid rgba(255,255,255,0.12);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;z-index:201;transition:all .2s;
  color:rgba(255,255,255,0.5);font-size:12px;
}
.sb-toggle:hover{border-color:var(--gold);color:var(--gold);}
.sb-toggle-icon{display:block;flex-shrink:0;}

/* Sidebar scroll area */
.sb-scroll{flex:1;overflow-y:auto;overflow-x:hidden;padding:12px 0 20px;}
.sb-scroll::-webkit-scrollbar{width:3px;}
.sb-scroll::-webkit-scrollbar-track{background:transparent;}
.sb-scroll::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.1);border-radius:2px;}

/* Section headers */
.sb-section{margin-bottom:4px;}
.sb-section-title{
  font-family:'JetBrains Mono',monospace;
  font-size:9px;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;
  color:rgba(255,199,44,0.5);padding:10px 20px 4px;
  white-space:nowrap;
}

/* Nav items */
.sb-item{
  display:flex;align-items:center;gap:12px;
  padding:9px 20px;
  cursor:pointer;
  border-left:2px solid transparent;
  transition:all .18s;
  text-decoration:none;color:inherit;
  white-space:nowrap;
}
.sb-item:hover{
  background:rgba(255,255,255,0.05);
  border-left-color:rgba(255,199,44,0.4);
}
.sb-item.active{
  background:rgba(255,199,44,0.08);
  border-left-color:var(--gold);
}
.sb-icon{
  width:32px;height:32px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-size:15px;flex-shrink:0;
  background:rgba(255,255,255,0.06);
  transition:background .18s;
}
.sb-item:hover .sb-icon,
.sb-item.active .sb-icon{background:rgba(255,199,44,0.12);}
.sb-label{
  font-size:13px;font-weight:500;
  color:rgba(255,255,255,0.65);
  transition:color .18s;
}
.sb-item:hover .sb-label,
.sb-item.active .sb-label{color:#fff;}
.sb-badge{
  margin-left:auto;
  font-size:10px;font-weight:700;
  padding:2px 7px;border-radius:10px;
  background:rgba(0,201,167,0.15);color:var(--teal);
  border:1px solid rgba(0,201,167,0.2);
  flex-shrink:0;
}
.sb-badge.gold{background:rgba(255,199,44,0.12);color:var(--gold);border-color:rgba(255,199,44,0.25);}

/* County sub-items — must reset <button> UA styles (otherwise light bg + inherited light text) */
.sb-county-toggle{
  display:flex;align-items:center;gap:10px;
  width:100%;
  padding:7px 20px 7px 24px;
  cursor:pointer;transition:all .18s;
  font-family:inherit;font-size:12px;font-weight:600;
  color:rgba(255,255,255,0.55);
  text-transform:uppercase;letter-spacing:0.08em;
  text-align:left;
  background:transparent;border:none;
  -webkit-appearance:none;appearance:none;
}
.sb-county-toggle:hover{color:rgba(255,255,255,0.7);}
.sb-county-toggle .ct-arrow{
  font-size:10px;transition:transform .2s;flex-shrink:0;
}
.sb-county-toggle.open .ct-arrow{transform:rotate(90deg);}
.sb-sub{padding-left:8px;overflow:hidden;max-height:0;transition:max-height .25s ease;}
.sb-sub.open{max-height:min(92vh,3600px);}
.sb-sub-item{
  display:flex;align-items:center;gap:10px;
  padding:6px 20px 6px 32px;
  cursor:pointer;text-decoration:none;color:inherit;
  font-size:12.5px;color:rgba(255,255,255,0.45);
  transition:color .15s;
  white-space:nowrap;
}
.sb-sub-item:hover{color:rgba(255,255,255,0.8);}
.sb-dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,0.2);flex-shrink:0;}

/* Sidebar footer */
.sb-footer{
  padding:12px 20px 16px;
  border-top:1px solid rgba(255,255,255,0.07);
  flex-shrink:0;
}
.sb-cta{
  display:block;text-align:center;
  background:var(--gold);color:#001530;
  font-size:12px;font-weight:700;
  padding:9px 14px;border-radius:8px;
  text-decoration:none;letter-spacing:0.2px;
  transition:all .2s;white-space:nowrap;
}
.sb-cta:hover{background:#FFD54F;}
.sidebar.collapsed .sb-footer{padding:12px 8px 16px;}
.sidebar.collapsed .sb-cta{font-size:0;padding:9px;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;}
.sidebar.collapsed .sb-cta::after{content:'→';font-size:16px;}

/* ── MAIN CONTENT ───────────────────────────────────────── */
.main{
  margin-left:var(--sidebar-w);
  flex:1;
  transition:margin-left .28s cubic-bezier(.4,0,.2,1);
}
.main.collapsed{margin-left:var(--sidebar-collapsed);}

/* ── TOPBAR ─────────────────────────────────────────────── */
.topbar{
  position:sticky;top:0;z-index:100;
  background:rgba(0,21,48,0.9);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(255,255,255,0.08);
  border-bottom:1px solid rgba(255,199,44,0.15);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 40px;height:var(--topbar-h);
  gap:24px;
}
.topbar-title{
  font-family:'DM Serif Display',serif;
  font-size:16px;color:rgba(255,255,255,0.7);
  letter-spacing:-0.1px;
}
a.topbar-title{
  text-decoration:none;color:inherit;
  cursor:pointer;
  transition:color .18s;
}
a.topbar-title:hover{color:rgba(255,255,255,0.95);}
.topbar-title span{color:var(--gold);}
.topbar-right{display:flex;align-items:center;gap:16px;}
.topbar-link{
  font-size:13px;font-weight:500;color:rgba(255,255,255,0.45);
  text-decoration:none;transition:color .18s;
}
.topbar-link:hover{color:#fff;}
.btn-hub{
  font-size:13px;font-weight:700;
  color:#001530;background:var(--gold);
  padding:8px 20px;border-radius:8px;
  text-decoration:none;letter-spacing:0.1px;
  box-shadow:0 2px 12px rgba(255,199,44,0.3);
  transition:all .2s;white-space:nowrap;
}
.btn-hub:hover{background:#FFD54F;box-shadow:0 4px 20px rgba(255,199,44,0.45);}

/* ── PAGE CONTENT ───────────────────────────────────────── */
.page-content{padding:56px 48px 80px;}

/* ── HERO ─────────────────────────────────────────────── */
.hero{
  display:grid;grid-template-columns:1fr 1fr;
  align-items:center;gap:56px;
  padding:60px 48px 72px;
  position:relative;overflow:hidden;
  background:linear-gradient(135deg,rgba(0,40,87,0.5) 0%,rgba(0,21,48,0) 100%);
  border-bottom:1px solid rgba(255,255,255,0.06);
}
.hero::before{
  content:'';position:absolute;
  top:-150px;right:-100px;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(0,63,127,0.5) 0%,transparent 65%);
  pointer-events:none;
}
.hero::after{
  content:'';position:absolute;
  bottom:-80px;left:20%;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,199,44,0.05) 0%,transparent 65%);
  pointer-events:none;
}
.hero-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.02) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.02) 1px,transparent 1px);
  background-size:60px 60px;pointer-events:none;
}
.hero-inner{position:relative;z-index:2;}
.hero-kicker{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'JetBrains Mono',monospace;
  font-size:10.5px;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--gold);margin-bottom:20px;
}
.hero-kicker::before{content:'';width:24px;height:1px;background:var(--gold);flex-shrink:0;}
.hero-h1{
  font-family:'DM Serif Display',serif;
  font-size:clamp(34px,3.8vw,52px);
  line-height:1.1;letter-spacing:-0.8px;color:#fff;
  margin-bottom:20px;
}
.hero-h1 em{font-style:italic;color:var(--gold);}
.hero-sub{
  font-size:16px;color:rgba(255,255,255,0.5);
  line-height:1.75;max-width:430px;margin-bottom:36px;font-weight:300;
}
.hero-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.btn-primary{
  font-size:14px;font-weight:700;color:#001530;background:var(--gold);
  padding:12px 26px;border-radius:9px;text-decoration:none;
  box-shadow:0 4px 20px rgba(255,199,44,0.35);
  transition:all .22s;display:inline-flex;align-items:center;gap:8px;
}
.btn-primary:hover{background:#FFD54F;transform:translateY(-1px);box-shadow:0 8px 28px rgba(255,199,44,0.5);}
.btn-secondary{
  font-size:14px;font-weight:600;color:rgba(255,255,255,0.65);
  border:1px solid rgba(255,255,255,0.18);
  padding:11px 24px;border-radius:9px;text-decoration:none;
  transition:all .22s;display:inline-flex;align-items:center;gap:8px;
}
.btn-secondary:hover{color:#fff;border-color:rgba(255,255,255,0.4);}

/* Hero stats */
.hero-stats{
  display:flex;gap:32px;flex-wrap:wrap;
  padding-top:32px;margin-top:32px;
  border-top:1px solid rgba(255,255,255,0.08);
}
.hero-stat .n{
  font-family:'DM Serif Display',serif;
  font-size:28px;color:var(--gold);line-height:1;
}
.hero-stat .l{
  font-size:10.5px;font-weight:600;letter-spacing:0.1em;
  text-transform:uppercase;color:rgba(255,255,255,0.28);margin-top:4px;
}

/* Hero preview panel */
.hero-right{position:relative;z-index:2;}
.dashboard-preview{
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:16px;overflow:hidden;
  box-shadow:0 24px 64px rgba(0,0,0,0.45);
}
.dash-topbar{
  background:rgba(0,40,87,0.6);
  padding:11px 16px;
  display:flex;align-items:center;gap:9px;
  border-bottom:1px solid rgba(255,255,255,0.07);
}
.dash-dot{width:9px;height:9px;border-radius:50%;}
.dash-title{
  margin-left:6px;font-size:11px;font-weight:600;
  color:rgba(255,255,255,0.4);flex:1;text-align:center;
  font-family:'JetBrains Mono',monospace;
}
.dash-body{padding:18px;}
.dash-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin-bottom:14px;}
.dash-kpi{
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.07);
  border-radius:9px;padding:11px 12px;
}
.dk-val{font-family:'DM Serif Display',serif;font-size:22px;color:#fff;line-height:1;margin-bottom:3px;}
.dk-val.gold{color:var(--gold);}
.dk-val.teal{color:var(--teal);}
.dk-lbl{font-size:9px;color:#8A9BB5;text-transform:uppercase;letter-spacing:0.1em;font-weight:600;}
.dash-grants{display:flex;flex-direction:column;gap:7px;margin-bottom:12px;}
.grant-row{
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.07);
  border-radius:8px;padding:10px 12px;
  display:flex;align-items:center;gap:10px;
}
.grant-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.grant-name{font-size:11.5px;font-weight:600;color:rgba(255,255,255,0.8);flex:1;}
.grant-dead{font-size:9.5px;color:#8A9BB5;font-family:'JetBrains Mono',monospace;}
.grant-score{
  font-size:9.5px;font-weight:700;padding:2px 7px;border-radius:12px;
  background:rgba(255,199,44,0.15);color:var(--gold);
}
.grant-score.open{background:rgba(0,201,167,0.12);color:var(--teal);}
.dash-note{
  background:linear-gradient(90deg,rgba(0,63,127,0.45),rgba(0,63,127,0.18));
  border:1px solid rgba(255,199,44,0.15);
  border-radius:8px;padding:11px 12px;
  display:flex;align-items:center;gap:9px;
}
.pulse{width:7px;height:7px;border-radius:50%;background:var(--gold);animation:pulse 1.8s ease-in-out infinite;flex-shrink:0;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:0.5;transform:scale(0.85);}}
.dash-note-text{font-size:11px;color:rgba(255,255,255,0.55);}
.dash-note-text span{color:var(--gold);font-weight:600;}

/* ── SECTION COMMON ─────────────────────────────────────── */
.section{padding:72px 48px;}
.section-kicker{
  font-family:'JetBrains Mono',monospace;
  font-size:10.5px;font-weight:500;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--gold);margin-bottom:12px;
  display:flex;align-items:center;gap:10px;
}
.section-kicker::after{content:'';flex:1;height:1px;background:var(--gold-line);}
.section-h2{
  font-family:'DM Serif Display',serif;
  font-size:clamp(28px,2.8vw,40px);
  line-height:1.15;letter-spacing:-0.4px;
  color:#fff;margin-bottom:12px;
}
.section-sub{
  font-size:15px;color:rgba(255,255,255,0.42);
  line-height:1.72;max-width:500px;font-weight:300;
  margin-bottom:44px;
}

/* ── ANCHOR SECTIONS ───────────────────────────────────── */
.anchor-section{
  scroll-margin-top:80px;
  padding:72px 48px;
  border-top:1px solid rgba(255,255,255,0.05);
}
.anchor-section:nth-child(even){
  background:rgba(0,40,87,0.18);
}

/* ── FEATURE CARDS (3-up from image) ───────────────────── */
.feature-strip{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:18px;margin-top:36px;
}
.feat-card{
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:16px;
  padding:28px 24px 22px;
  display:flex;flex-direction:column;gap:12px;
  position:relative;overflow:hidden;
  text-decoration:none;color:inherit;
  transition:all .28s;
}
.feat-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:var(--fc-accent, var(--gold));opacity:0;transition:opacity .3s;
}
.feat-card:hover{
  border-color:rgba(255,255,255,0.16);
  background:rgba(255,255,255,0.055);
  transform:translateY(-3px);
  box-shadow:0 14px 36px rgba(0,0,0,0.28);
}
.feat-card:hover::before{opacity:1;}
.feat-icon{
  width:44px;height:44px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-size:20px;
  background:var(--fc-icon-bg, rgba(255,199,44,0.1));
  flex-shrink:0;
}
.feat-title{font-size:16px;font-weight:700;color:#fff;letter-spacing:-0.15px;line-height:1.3;}
.feat-desc{font-size:13.5px;color:rgba(255,255,255,0.45);line-height:1.65;font-weight:300;flex:1;}
.feat-link{
  display:flex;align-items:center;gap:6px;
  font-size:12.5px;font-weight:700;color:var(--gold);
  text-decoration:none;
  padding-top:12px;border-top:1px solid rgba(255,255,255,0.07);
  transition:gap .2s;margin-top:auto;
}
.feat-card:hover .feat-link{gap:10px;}

/* ── MODULE GRID (intelligence hub) ───────────────────── */
.module-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:18px;margin-bottom:18px;
}
.module-card{
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:16px;padding:28px 24px 22px;
  transition:all .3s;position:relative;overflow:hidden;
  display:flex;flex-direction:column;gap:12px;
  text-decoration:none;color:inherit;
}
.module-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:var(--mc-accent,var(--gold));opacity:0;transition:opacity .3s;
}
.module-card:hover{
  border-color:rgba(255,255,255,0.16);background:rgba(255,255,255,0.05);
  transform:translateY(-3px);box-shadow:0 16px 40px rgba(0,0,0,0.3);
}
.module-card:hover::before{opacity:1;}
.mc-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;}
.mc-icon{
  width:42px;height:42px;border-radius:11px;
  display:flex;align-items:center;justify-content:center;
  font-size:19px;flex-shrink:0;
  background:var(--mc-icon-bg,rgba(255,199,44,0.12));
}
.mc-badge{
  font-family:'JetBrains Mono',monospace;
  font-size:9px;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;
  padding:3px 8px;border-radius:16px;
  background:var(--mc-badge-bg,rgba(255,199,44,0.12));
  color:var(--mc-badge-color,var(--gold));
  border:1px solid var(--mc-badge-border,rgba(255,199,44,0.25));
  white-space:nowrap;
}
.mc-title{font-size:16px;font-weight:700;color:#fff;line-height:1.3;letter-spacing:-0.15px;}
.mc-desc{font-size:13px;color:rgba(255,255,255,0.42);line-height:1.65;font-weight:300;flex:1;}
.mc-tabs{display:flex;flex-wrap:wrap;gap:5px;margin-top:4px;}
.mc-tab{
  font-size:10.5px;font-weight:500;padding:3px 8px;border-radius:16px;
  background:rgba(255,255,255,0.07);color:rgba(255,255,255,0.42);
  border:1px solid rgba(255,255,255,0.08);
}
.mc-link{
  display:flex;align-items:center;gap:6px;
  font-size:12.5px;font-weight:700;color:var(--gold);
  text-decoration:none;margin-top:auto;
  padding-top:12px;border-top:1px solid rgba(255,255,255,0.08);
  transition:gap .2s;
}
.module-card:hover .mc-link{gap:10px;}

/* Tools row */
.tools-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.tool-card{
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:12px;padding:20px 22px;
  display:flex;align-items:flex-start;gap:14px;
  transition:all .25s;text-decoration:none;color:inherit;
}
.tool-card:hover{
  background:rgba(255,255,255,0.05);
  border-color:rgba(255,199,44,0.2);
  transform:translateY(-2px);box-shadow:0 10px 28px rgba(0,0,0,0.25);
}
.tool-icon{
  width:42px;height:42px;border-radius:11px;
  display:flex;align-items:center;justify-content:center;
  font-size:19px;flex-shrink:0;
  background:var(--mc-icon-bg,rgba(255,199,44,0.1));
}
.tool-body{flex:1;min-width:0;}
.tool-title{font-size:14.5px;font-weight:700;color:#fff;margin-bottom:5px;letter-spacing:-0.1px;}
.tool-desc{font-size:12.5px;color:rgba(255,255,255,0.42);line-height:1.6;font-weight:300;}
.tool-arrow{color:rgba(255,255,255,0.22);font-size:17px;flex-shrink:0;margin-top:2px;transition:all .2s;}
.tool-card:hover .tool-arrow{color:var(--gold);}

/* ── GRANT DIRECTORY ─────────────────────────────────── */
.dir-header{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:24px;flex-wrap:wrap;margin-bottom:28px;
}
.dir-updated{
  font-family:'JetBrains Mono',monospace;
  font-size:10px;color:rgba(255,255,255,0.2);white-space:nowrap;flex-shrink:0;
}
.filter-bar{
  display:flex;gap:7px;flex-wrap:wrap;
  margin-bottom:32px;padding-bottom:22px;
  border-bottom:1px solid rgba(255,255,255,0.07);
}
.filter-btn{
  padding:7px 15px;border-radius:18px;
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(255,255,255,0.04);
  font-size:12px;font-weight:600;color:rgba(255,255,255,0.48);
  cursor:pointer;transition:all .18s;
  font-family:'DM Sans',sans-serif;white-space:nowrap;
}
.filter-btn:hover{border-color:rgba(255,255,255,0.26);color:#fff;background:rgba(255,255,255,0.07);}
.filter-btn.active{background:var(--blue);color:#fff;border-color:var(--blue);}
.filter-btn.active-gold{background:var(--gold);color:#001530;border-color:var(--gold);}
.dir-section-wrap{margin-bottom:44px;}
.dir-section-hdr{
  display:flex;align-items:center;gap:12px;
  margin-bottom:18px;padding-bottom:10px;
  border-bottom:1px solid rgba(255,255,255,0.07);
}
.dir-section-icon{
  width:34px;height:34px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-size:15px;flex-shrink:0;background:rgba(255,255,255,0.06);
}
.dir-section-title{
  font-family:'DM Serif Display',serif;
  font-size:18px;color:#fff;font-weight:400;flex:1;
}
.dir-count{
  background:rgba(255,255,255,0.07);padding:2px 10px;border-radius:16px;
  font-size:10.5px;font-weight:700;color:rgba(255,255,255,0.35);
  border:1px solid rgba(255,255,255,0.08);
}
.grant-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr));
  gap:12px;
}
.grant-card{
  border:1px solid rgba(255,255,255,0.08);border-radius:11px;padding:18px;
  transition:all .22s;background:rgba(255,255,255,0.03);position:relative;
}
.grant-card:hover{border-color:rgba(255,199,44,0.2);background:rgba(255,255,255,0.05);transform:translateY(-2px);}
.grant-card .badge{
  display:inline-block;padding:2px 8px;border-radius:4px;
  font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:0.4px;margin-bottom:9px;
}
.badge-open   {background:rgba(0,201,167,0.12);color:#00C9A7;}
.badge-upcoming{background:rgba(255,199,44,0.1);color:var(--gold);}
.badge-closed {background:rgba(229,62,62,0.1);color:#FC8181;}
.badge-ongoing{background:rgba(0,94,184,0.2);color:#7EB8FF;}
.grant-card h3{font-size:13.5px;font-weight:700;color:#fff;margin-bottom:5px;line-height:1.35;}
.grant-card .agency{font-size:11px;color:rgba(255,199,44,0.65);font-weight:600;margin-bottom:8px;}
.grant-card .desc{font-size:12px;color:rgba(255,255,255,0.38);line-height:1.55;margin-bottom:10px;font-weight:300;}
.grant-card .meta{display:flex;gap:12px;flex-wrap:wrap;font-size:10.5px;color:rgba(255,255,255,0.28);}
.grant-card .meta strong{color:rgba(255,255,255,0.55);}
.grant-card .link{
  display:inline-block;margin-top:10px;
  font-size:11.5px;font-weight:700;color:var(--gold);
  text-decoration:none;transition:color .18s;
}
.grant-card .link:hover{color:#FFD54F;}
.grant-card .link::after{content:' →';}
.dir-divider{height:1px;background:rgba(255,255,255,0.05);margin:36px 0;}

/* ── CITY DASHBOARD SECTION ─────────────────────────── */
.county-tabs{
  display:flex;gap:8px;flex-wrap:wrap;
  margin-bottom:24px;
}
.county-tab{
  padding:7px 16px;border-radius:18px;
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(255,255,255,0.04);
  font-size:12px;font-weight:600;color:rgba(255,255,255,0.48);
  cursor:pointer;transition:all .18s;
}
.county-tab:hover{border-color:rgba(255,255,255,0.26);color:#fff;}
.county-tab.active{background:rgba(0,63,127,0.6);color:#fff;border-color:rgba(0,94,184,0.4);}
.city-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:10px;
}
.city-card{
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:10px;padding:16px 18px;
  display:flex;align-items:flex-start;gap:12px;
  text-decoration:none;color:inherit;
  transition:all .22s;cursor:default;
}
a.city-card{cursor:pointer;}
.city-card:hover{
  background:rgba(255,255,255,0.06);
  border-color:rgba(255,199,44,0.2);
  transform:translateY(-2px);
}
.city-icon{
  width:36px;height:36px;border-radius:9px;
  background:rgba(0,63,127,0.4);
  display:flex;align-items:center;justify-content:center;
  font-size:16px;flex-shrink:0;
}
.city-name{font-size:13px;font-weight:600;color:rgba(255,255,255,0.8);}
.city-meta{font-size:10.5px;color:rgba(255,255,255,0.35);margin-top:2px;}
.city-arrow{color:rgba(255,255,255,0.2);margin-left:auto;font-size:14px;transition:color .18s;}
.city-card:hover .city-arrow{color:var(--gold);}

/* ── HOW IT WORKS ───────────────────────────────────── */
.how-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:2px;margin-top:12px;
  position:relative;
}
.how-grid::before{
  content:'';position:absolute;
  top:32px;left:calc(12.5% + 20px);right:calc(12.5% + 20px);
  height:1px;background:rgba(255,199,44,0.2);
  pointer-events:none;
}
.how-step{
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:14px;padding:28px 22px;
  display:flex;flex-direction:column;align-items:flex-start;gap:14px;
  position:relative;
}
.step-num{
  width:40px;height:40px;border-radius:50%;
  background:rgba(255,199,44,0.1);
  border:1.5px solid rgba(255,199,44,0.3);
  display:flex;align-items:center;justify-content:center;
  font-family:'DM Serif Display',serif;
  font-size:18px;color:var(--gold);
  flex-shrink:0;
}
.step-title{font-size:15px;font-weight:700;color:#fff;line-height:1.3;}
.step-desc{font-size:13px;color:rgba(255,255,255,0.42);line-height:1.6;font-weight:300;}

/* ── SIGNUP ─────────────────────────────────────────── */
.signup-wrap{
  background:rgba(0,40,87,0.3);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:20px;padding:48px;
  display:grid;grid-template-columns:1fr 1fr;gap:48px;
  align-items:center;
}
.signup-form{position:relative;display:flex;flex-direction:column;gap:10px;}
/* Honeypot for FormSubmit — off-screen, not display:none (fewer bot skips) */
.tg-form-honey-wrap{
  position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;
}
.tg-form-honey-wrap input{width:1px;height:1px;opacity:0;}
.signup-captcha{
  display:flex;flex-direction:column;gap:6px;
  margin:4px 0 2px;
  padding:12px 14px;
  border-radius:8px;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
}
.signup-captcha-label{
  font-size:12.5px;
  color:rgba(255,255,255,0.55);
  font-weight:500;
}
.signup-captcha-label strong{color:var(--gold);font-weight:700;}
.signup-captcha-input{
  max-width:120px;
  padding:10px 14px;border-radius:8px;
  border:1.5px solid rgba(255,255,255,0.12);
  background:rgba(255,255,255,0.06);
  color:#fff;font-size:13.5px;
  font-family:'DM Sans',sans-serif;outline:none;
}
.signup-captcha-input:focus{border-color:var(--gold);}
.signup-btn:disabled{opacity:0.75;cursor:not-allowed;}
.form-row{display:flex;gap:10px;}
.signup-form input,.signup-form select{
  flex:1;padding:10px 14px;border-radius:8px;
  border:1.5px solid rgba(255,255,255,0.12);
  background:rgba(255,255,255,0.06);
  color:#fff;font-size:13.5px;
  font-family:'DM Sans',sans-serif;outline:none;transition:border-color .2s;
}
.signup-form input::placeholder{color:rgba(255,255,255,0.3);}
.signup-form select{color:rgba(255,255,255,0.6);}
.signup-form select option{color:#333;background:#fff;}
.signup-form input:focus,.signup-form select:focus{border-color:var(--gold);}
.signup-btn{
  padding:12px 24px;
  background:var(--gold);color:var(--navy);
  border:none;border-radius:8px;
  font-size:14px;font-weight:700;
  cursor:pointer;font-family:'DM Sans',sans-serif;
  transition:all .2s;
}
.signup-btn:hover{background:#FFD54F;transform:translateY(-1px);}
.signup-note{font-size:11px;color:var(--dim);text-align:center;}

/* ── FOOTER ─────────────────────────────────────────── */
.footer{
  padding:32px 48px;
  border-top:1px solid rgba(255,255,255,0.06);
  display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
}
.footer-brand{
  font-family:'DM Serif Display',serif;
  font-size:15px;color:rgba(255,255,255,0.45);white-space:nowrap;
}
.footer-brand span{color:var(--gold);}
.footer-links{display:flex;flex-wrap:wrap;gap:5px 20px;}
.footer-links a{font-size:12px;color:rgba(255,255,255,0.22);text-decoration:none;transition:color .18s;}
.footer-links a:hover{color:rgba(255,255,255,0.55);}
.footer-copy{font-size:11px;color:rgba(255,255,255,0.18);text-align:right;line-height:1.6;}

/* ── RESPONSIVE ─────────────────────────────────────── */
@media(max-width:1100px){
  .sidebar{width:var(--sidebar-collapsed);}
  .sidebar .sb-label,.sidebar .sb-section-title,.sidebar .sb-brand-text,
  .sidebar .sb-county-toggle,.sidebar .sb-sub{display:none;}
  /* Same as .collapsed: narrow width via breakpoint, not only via class */
  .sidebar .sb-badge,
  .sidebar a.tg-gated::after{display:none;}
  .sidebar .sb-item{
    justify-content:center;
    align-items:center;
    padding:10px 0;
    gap:0;
    border-left-color:transparent;
  }
  .sidebar .sb-item:hover,
  .sidebar .sb-item.active{border-left-color:transparent;}
  .sidebar .sb-icon{margin:0;}
  .sidebar .sb-brand{justify-content:center;padding-left:0;padding-right:0;}
  .sidebar .sb-footer{padding:12px 8px 16px;}
  .sidebar .sb-cta{font-size:0;padding:9px;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;}
  .sidebar .sb-cta::after{content:'→';font-size:16px;}
  .main{margin-left:var(--sidebar-collapsed);}
  .hero{grid-template-columns:1fr;padding:48px 32px 56px;}
  .hero-right{display:none;}
  .module-grid,.feature-strip,.how-grid{grid-template-columns:1fr;}
  .tools-grid{grid-template-columns:1fr;}
  .signup-wrap{grid-template-columns:1fr;}
  .section,.anchor-section{padding-left:32px;padding-right:32px;}
}
@media(max-width:700px){
  .topbar{padding:0 20px;}
  .hero,.section,.anchor-section{padding-left:20px;padding-right:20px;}
  .footer{flex-direction:column;text-align:center;padding:24px 20px;}
  .footer-copy{text-align:center;}
  .module-grid{grid-template-columns:1fr;}
  .how-grid::before{display:none;}
}

/* ── ANIMATIONS ─────────────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(18px);}to{opacity:1;transform:none;}}
.fade-up{opacity:0;animation:fadeUp .65s ease both;}
.fade-1{animation-delay:.08s;}
.fade-2{animation-delay:.18s;}
.fade-3{animation-delay:.28s;}
.fade-4{animation-delay:.38s;}
.fade-5{animation-delay:.48s;}

/* Hub gated links + nested county/city nav (from sidebar-nav patterns) */
.sidebar a.tg-gated{display:flex;align-items:center;gap:8px;}
.sidebar a.tg-gated::after{
  content:"";
  width:12px;height:12px;margin-left:auto;flex-shrink:0;opacity:.72;
  background-color:currentColor;
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 17a2 2 0 1 0 0-4 2 2 0 0 0 0 4zm6-7h-1V8a5 5 0 0 0-10 0v2H6a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-8a2 2 0 0 0-2-2zm-7-2a3 3 0 0 1 6 0v2H11V8z'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 17a2 2 0 1 0 0-4 2 2 0 0 0 0 4zm6-7h-1V8a5 5 0 0 0-10 0v2H6a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-8a2 2 0 0 0-2-2zm-7-2a3 3 0 0 1 6 0v2H11V8z'/%3E%3C/svg%3E") center/contain no-repeat;
}
.sidebar .sb-city{border-bottom:1px solid rgba(255,255,255,0.06);}
.sidebar .sb-city:last-child{border-bottom:none;}
.sidebar button.sb-city-hdr{
  display:flex;align-items:center;gap:8px;width:100%;
  padding:8px 12px 8px 24px;border:none;background:transparent;
  cursor:pointer;font-family:inherit;text-align:left;
  color:rgba(255,255,255,0.5);font-size:11.5px;font-weight:600;
  transition:all .15s;
  -webkit-appearance:none;appearance:none;
}
.sidebar button.sb-city-hdr:hover{background:rgba(255,255,255,0.05);color:rgba(255,255,255,0.88);}
.sidebar button.sb-city-hdr .sbi-lbl{flex:1;}
.sidebar button.sb-city-hdr .chev{font-size:8px;opacity:.65;transition:transform .2s;}
.sidebar button.sb-city-hdr.open .chev{transform:rotate(90deg);}
.sidebar .sb-city-sub{display:none;background:rgba(0,0,0,0.14);}
.sidebar .sb-city-sub.open{display:block;}
.sidebar a.sb-sub-item.sb-leaf{padding:6px 12px 6px 34px;font-size:11.5px;}
.sidebar button.sb-sub-item.sb-leaf.coming{
  width:100%;text-align:left;font-style:italic;color:rgba(255,255,255,0.38);cursor:default;
  background:transparent;border:none;font-family:inherit;
  -webkit-appearance:none;appearance:none;
}
.sb-more-row{padding:8px 12px 10px 24px;font-size:11px;color:rgba(255,255,255,0.38);font-style:italic;}

/* City grid: dashboard + brief links */
.city-links{font-size:11px;margin-top:6px;line-height:1.5;}
.city-links a{color:rgba(255,199,44,0.8);text-decoration:none;font-weight:600;margin-right:10px;}
.city-links a:hover{color:var(--gold);text-decoration:underline;}
.city-coming{font-size:10.5px;color:rgba(255,255,255,0.35);margin-top:6px;}
.coming-badge{
  font-size:8.5px;background:rgba(255,255,255,0.1);
  color:rgba(255,255,255,0.5);border-radius:3px;padding:1px 5px;
  margin-left:6px;font-style:normal;font-weight:600;
}

/* Embedded in platform hub iframe — main page supplies its own chrome */
html.tg-hub-embed .tg-index-root .sidebar{display:none!important;}
html.tg-hub-embed .tg-index-root .main{margin-left:0!important;}
