:root {
  color-scheme: light;
  --ml-navy: #062841;
  --ml-navy-deep: #031b2f;
  --ml-navy-soft: #0a395b;
  --ml-blue: #0c77a4;
  --ml-blue-strong: #075c84;
  --ml-sky: #3fa9da;
  --ml-sky-soft: #e7f5fb;
  --ml-green: #237544;
  --ml-green-soft: #e8f5ed;
  --ml-orange: #e87421;
  --ml-orange-soft: #fff2e6;
  --ml-purple: #765ac6;
  --ml-yellow: #f4a900;
  --ml-ink: #102b43;
  --ml-muted: #5e7184;
  --ml-muted-strong: #395368;
  --ml-line: #d6e4ee;
  --ml-line-strong: #b9d1df;
  --ml-border: var(--ml-line);
  --ml-text: var(--ml-ink);
  --ml-radius: var(--ml-radius-md);
  --ml-shadow-sm: var(--ml-shadow-soft);
  --ml-blue-bright: #1586b8;
  --ml-surface: #ffffff;
  --ml-surface-soft: #f5fbff;
  --ml-surface-warm: #fffaf5;
  --ml-shell: 1320px;
  --ml-shell-pad: 20px;
  --ml-radius-xs: 8px;
  --ml-radius-sm: 12px;
  --ml-radius-md: 16px;
  --ml-radius-lg: 22px;
  --ml-radius-xl: 28px;
  --ml-shadow-soft: 0 10px 30px rgba(6, 40, 65, 0.08);
  --ml-shadow-card: 0 16px 38px rgba(6, 40, 65, 0.12);
  --ml-shadow-hero: 0 24px 70px rgba(2, 25, 42, 0.32);
  --ml-focus: 0 0 0 3px rgba(63, 169, 218, 0.34);
  --ml-card-min: 238px;
  --ml-transition: 180ms ease;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ml-ink);
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height: 1.48;
  background: #fff;
  text-rendering: optimizeLegibility;
}
a { color: var(--ml-blue); text-underline-offset: 0.16em; }
a:hover { color: var(--ml-navy); }
img { display: block; max-width: 100%; height: auto; }
button,
input,
select,
textarea { font: inherit; }
button { cursor: pointer; }
:focus-visible { outline: none; box-shadow: var(--ml-focus); }

.ml-shell { max-width: var(--ml-shell); margin: 0 auto; padding-inline: var(--ml-shell-pad); }
.ml-site-main { min-height: 65vh; background: #fff; }
.ml-skip-link { position: absolute; left: -999px; top: 1rem; z-index: 9999; border-radius: 999px; background: #fff; color: var(--ml-navy); padding: .65rem .9rem; font-weight: 900; box-shadow: var(--ml-shadow-card); }
.ml-skip-link:focus { left: 1rem; }
.ml-visually-hidden,
.screen-reader-text { position: absolute !important; width: 1px !important; height: 1px !important; padding: 0 !important; overflow: hidden !important; clip: rect(0 0 0 0) !important; white-space: nowrap !important; border: 0 !important; }
.ml-kicker { margin: 0 0 .7rem; color: var(--ml-green); font-size: .76rem; font-weight: 950; letter-spacing: .13em; text-transform: uppercase; }
.ml-kicker-light { color: #d8f7ff; }

.ml-button,
.ml-search button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  border: 0;
  border-radius: 999px;
  padding: .78rem 1.08rem;
  color: #fff;
  background: linear-gradient(135deg, #137da8, #075475);
  box-shadow: 0 8px 22px rgba(3, 27, 47, .22);
  font-size: .88rem;
  font-weight: 950;
  line-height: 1;
  text-decoration: none;
  transition: transform var(--ml-transition), box-shadow var(--ml-transition), background var(--ml-transition);
}
.ml-button:hover,
.ml-button:focus-visible,
.ml-search button:hover { color: #fff; transform: translateY(-1px); box-shadow: 0 12px 26px rgba(3, 27, 47, .28); }
.ml-button-primary { background: linear-gradient(135deg, #0d87bc, #064f73); color: #fff; }
.ml-button-light { background: rgba(255,255,255,.94); color: var(--ml-navy); }
.ml-button-light:hover { color: var(--ml-navy); background: #fff; }

.ml-section { padding: 36px 0 48px; background: var(--ml-surface-soft); }
.ml-content,
.ml-entry { max-width: 980px; }
.ml-content { margin: 0 auto; }
.ml-entry { border: 1px solid var(--ml-line); border-radius: var(--ml-radius-lg); background: #fff; padding: clamp(22px, 4vw, 42px); box-shadow: var(--ml-shadow-soft); }
.ml-entry h1,
.ml-entry-header h1 { margin: 0 0 1rem; color: var(--ml-navy); font-family: Georgia, "Times New Roman", serif; font-size: clamp(2.1rem, 5vw, 4.2rem); line-height: .98; letter-spacing: -.04em; }
.ml-entry-content { color: var(--ml-muted-strong); }
.ml-entry-content > *:first-child { margin-top: 0; }
.ml-entry-content a { font-weight: 800; }
.ml-breadcrumbs { margin: 0 0 1rem; color: #607589; font-size: .88rem; font-weight: 800; }

.ml-card-grid,
.ml-template-plan { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1rem; }
.ml-card,
.ml-region-directory .ml-card,
.ml-template-plan .ml-card { border: 1px solid var(--ml-line); border-radius: var(--ml-radius-md); background: #fff; padding: 1rem; box-shadow: var(--ml-shadow-soft); }
.ml-link-list { columns: 2 240px; padding-left: 1.2rem; }
.ml-list-directory .ml-directory-section { margin: 0 0 2rem; }
.ml-lake-directory-wrap { overflow-x: auto; border: 1px solid var(--ml-line); border-radius: var(--ml-radius-md); background: #fff; box-shadow: var(--ml-shadow-soft); }
.ml-lake-directory { width: 100%; min-width: 620px; border-collapse: collapse; background: #fff; }
.ml-lake-directory th,
.ml-lake-directory td { border-bottom: 1px solid var(--ml-line); padding: .8rem; text-align: left; }
.ml-lake-directory th { background: #e8f5fb; color: var(--ml-navy); }
.ml-facts { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: .85rem; }
.ml-facts div { border: 1px solid var(--ml-line); border-radius: var(--ml-radius-sm); background: #fff; padding: .85rem; }
.ml-facts dt { color: var(--ml-muted); font-size: .8rem; font-weight: 900; letter-spacing: .06em; text-transform: uppercase; }
.ml-facts dd { margin: .25rem 0 0; color: var(--ml-navy); font-size: 1.12rem; font-weight: 900; }
.ml-feature-list { display: flex; flex-wrap: wrap; gap: .75rem; padding: 0; margin: 0; list-style: none; }
.ml-feature-list li { border: 1px solid var(--ml-line); border-radius: 999px; background: #fff; padding: .56rem .9rem; color: var(--ml-navy); font-weight: 900; }
.ml-recreation-panel { margin-top: 1.8rem; border: 1px solid #c9e3ef; border-radius: var(--ml-radius-md); background: #e9f6fc; padding: 1.25rem; }
.ml-recreation-panel h2 { margin: 0 0 .8rem; color: var(--ml-navy); }

.ml-site-header {
  position: sticky;
  top: 0;
  z-index: 80;
  color: #fff;
  background: linear-gradient(180deg, #08395d 0%, #052840 100%);
  border-bottom: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 4px 18px rgba(0,0,0,.18);
}
.admin-bar .ml-site-header { top: 32px; }
.ml-header-inner { min-height: 66px; display: grid; grid-template-columns: 220px minmax(0, 1fr) minmax(320px, auto); align-items: center; gap: 18px; padding-block: 8px; }
.ml-branding { min-width: 0; overflow: visible; }
.ml-brand-link { display: inline-flex; align-items: center; width: 210px; max-width: 100%; background: transparent; text-decoration: none; }
.ml-site-logo { width: 210px; height: auto; flex-shrink: 0; border-radius: 0; background: transparent; }
.ml-site-tagline { display: none !important; }
.ml-menu-toggle { display: none; width: 44px; height: 40px; border: 1px solid rgba(255,255,255,.25); border-radius: 12px; background: rgba(255,255,255,.08); color: #fff; font-size: 1.24rem; line-height: 1; }
.ml-primary-nav { min-width: 0; }
.ml-menu { display: flex; align-items: center; justify-content: center; gap: .88rem; margin: 0; padding: 0; list-style: none; white-space: nowrap; }
.ml-menu a { color: #fff; font-size: .9rem; font-weight: 950; text-decoration: none; }
.ml-menu a:hover,
.ml-menu a:focus-visible { color: #91d9f7; }
.ml-header-tools { display: flex; align-items: center; justify-content: flex-end; gap: .6rem; min-width: 0; }

.ml-search { display: flex; align-items: center; gap: .45rem; min-width: 0; }
.ml-search-header { width: min(285px, 30vw); flex: 0 1 285px; }
.ml-search-hero { display: flex; width: min(520px, 100%); }
.ml-search input { width: 100%; min-width: 0; border: 1px solid rgba(255,255,255,.24); border-radius: 999px; padding: .72rem 1rem; color: #fff; background: rgba(255,255,255,.08); font-size: .88rem; outline: none; }
.ml-search-header input::placeholder { color: rgba(255,255,255,.72); }
.ml-search input:focus { box-shadow: var(--ml-focus); border-color: rgba(255,255,255,.6); }
.ml-language { display: inline-flex; align-items: center; gap: .42rem; color: #fff; font-size: .86rem; font-weight: 950; white-space: nowrap; }
.ml-language select { min-width: 8.2rem; border: 1px solid rgba(255,255,255,.3); border-radius: 999px; color: #fff; background: rgba(255,255,255,.08); padding: .62rem 1.85rem .62rem .8rem; }
.ml-language option { color: #111; background: #fff; }

.ml-home-hero { position: relative; min-height: 458px; color: #fff; background-image: linear-gradient(90deg, rgba(2,25,42,.78) 0%, rgba(4,44,69,.50) 42%, rgba(2,23,38,.12) 100%), var(--ml-hero-bg); background-size: cover; background-position: center; overflow: hidden; }
.ml-home-hero::before { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(2,25,42,.08), rgba(2,25,42,.2)); pointer-events: none; }
.ml-home-hero::after { content: ""; position: absolute; inset: auto 0 0 0; height: 110px; background: linear-gradient(0deg, rgba(2,22,36,.45), rgba(2,22,36,0)); pointer-events: none; }
.ml-home-hero-overlay { display: none; }
.ml-home-hero-grid { position: relative; z-index: 2; display: grid; grid-template-columns: minmax(330px, .78fr) minmax(450px, 1.05fr); gap: 36px; align-items: center; padding-block: 36px; }
.ml-home-hero-copy h1 { max-width: 560px; margin: 0; color: #fff; font-family: Georgia, "Times New Roman", serif; font-size: clamp(2.35rem, 4.6vw, 4.45rem); line-height: .98; letter-spacing: -.04em; text-shadow: 0 4px 28px rgba(0,0,0,.38); }
.ml-home-hero-copy p { max-width: 490px; margin: 1rem 0 0; color: rgba(255,255,255,.94); font-size: 1.05rem; line-height: 1.46; text-shadow: 0 2px 16px rgba(0,0,0,.32); }
.ml-home-hero-actions { display: flex; flex-wrap: wrap; gap: .8rem; margin-top: 1.35rem; }

.ml-home-hero-stats { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; max-width: 540px; margin-top: 1.25rem; }
.ml-home-hero-stats span { display: grid; gap: 1px; border: 1px solid rgba(255,255,255,.22); border-radius: 14px; background: rgba(1,28,45,.36); padding: .78rem .85rem; box-shadow: 0 12px 30px rgba(0,0,0,.18); }
.ml-home-hero-stats strong { color: #fff; font-size: 1.26rem; line-height: 1; }
.ml-home-hero-stats small { color: rgba(255,255,255,.83); font-size: .72rem; font-weight: 850; line-height: 1.18; }
.ml-home-hero-actions { display: flex; flex-wrap: wrap; gap: .8rem; margin-top: 1.25rem; }
.ml-home-hero-search { max-width: 560px; margin-top: 1rem; }
.ml-home-hero-search p { margin: 0 0 .45rem; color: rgba(255,255,255,.88); font-size: .86rem; font-weight: 850; text-shadow: 0 2px 16px rgba(0,0,0,.32); }
.ml-search-hero input { border-color: rgba(255,255,255,.82); color: var(--ml-ink); background: rgba(255,255,255,.96); box-shadow: 0 14px 34px rgba(2,25,42,.2); }
.ml-search-hero input::placeholder { color: #627989; }
.ml-home-guide-card { border: 1px solid rgba(255,255,255,.82); border-radius: var(--ml-radius-lg); background: rgba(255,255,255,.96); color: var(--ml-ink); padding: clamp(18px, 2.2vw, 26px); box-shadow: var(--ml-shadow-hero); }
.ml-home-guide-copy h2 { margin: 0; color: var(--ml-navy); font-size: clamp(1.45rem, 2.25vw, 2.1rem); line-height: 1.06; letter-spacing: -.03em; }
.ml-home-guide-copy p { margin: .55rem 0 0; color: #4c6577; font-size: .98rem; line-height: 1.42; text-shadow: none; }
.ml-home-guide-links { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; margin-top: 16px; }
.ml-home-guide-links a { border: 1px solid #cfe3ec; border-radius: 14px; background: linear-gradient(180deg, #fff, #f2f9fc); padding: .8rem .85rem; color: var(--ml-navy); font-weight: 950; text-decoration: none; box-shadow: 0 8px 20px rgba(6,40,65,.08); }
.ml-home-guide-links a:hover,
.ml-home-guide-links a:focus-visible { border-color: #91d9f7; color: #064f73; transform: translateY(-1px); }
.ml-home-guide-note { margin: 16px 0 0; border-left: 4px solid var(--ml-green); border-radius: 12px; background: #edf8f1; padding: .9rem 1rem; color: #315766; font-size: .88rem; font-weight: 750; line-height: 1.38; }

.ml-home-section { padding: 18px 0 22px; background: #fff; border-bottom: 1px solid var(--ml-line); }
.ml-home-section:nth-of-type(odd) { background: #fbfdff; }
.ml-home-section-header { display: flex; align-items: flex-start; gap: 11px; margin-bottom: 12px; }
.ml-section-number { width: 24px; height: 24px; flex: 0 0 24px; display: inline-grid; place-items: center; border-radius: 8px; color: var(--ml-blue); background: rgba(6,40,65,.08); font-size: 0; }
.ml-section-number::before { content: "⌁"; font-size: 17px; font-weight: 950; line-height: 1; }
.ml-home-section-counties .ml-section-number::before { content: "▦"; font-size: 15px; }
.ml-home-section-lakes .ml-section-number::before { content: "≋"; font-size: 18px; }
.ml-home-section-recreation .ml-section-number::before { content: "◌"; font-size: 18px; }
.ml-home-section-learn .ml-section-number::before { content: "◈"; font-size: 15px; }
.ml-home-section-resources .ml-section-number::before { content: "↗"; font-size: 16px; }
.ml-home-section-header h2 { margin: 0; color: var(--ml-navy); font-size: clamp(1.35rem, 2.1vw, 1.85rem); line-height: 1.08; letter-spacing: -.02em; }
.ml-home-section-header p { margin: .18rem 0 0; color: var(--ml-muted); font-size: .92rem; }
.ml-home-grid { display: grid; gap: 14px; }
.ml-home-grid-five { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.ml-home-grid-six { grid-template-columns: repeat(6, minmax(0, 1fr)); }
.ml-home-card { min-width: 0; overflow: hidden; border: 1px solid var(--ml-line); border-radius: var(--ml-radius-md); background: #fff; box-shadow: var(--ml-shadow-soft); transition: transform var(--ml-transition), box-shadow var(--ml-transition), border-color var(--ml-transition); }
.ml-home-card:hover { transform: translateY(-3px); border-color: #8ccfe9; box-shadow: var(--ml-shadow-card); }
.ml-home-card-image { display: block; aspect-ratio: 16 / 10; overflow: hidden; background: #dcecf4; }
.ml-home-card-image img { width: 100%; height: 100%; object-fit: cover; transition: transform 280ms ease; }
.ml-home-card:hover .ml-home-card-image img { transform: scale(1.04); }
.ml-home-card-body { display: grid; gap: 7px; padding: 12px; }
.ml-home-card-body h3,
.ml-home-card-body strong { margin: 0; color: var(--ml-navy); font-size: .98rem; font-weight: 950; line-height: 1.13; }
.ml-home-card-body h3 a { color: inherit; text-decoration: none; }
.ml-home-card-body p,
.ml-home-card-body > span { margin: 0; color: #486175; font-size: .84rem; line-height: 1.35; }
.ml-home-card-body > a:not(.ml-button),
.ml-home-card-body em { color: var(--ml-blue); font-size: .83rem; font-style: normal; font-weight: 950; text-decoration: none; }
.ml-home-card-body > a:not(.ml-button)::after,
.ml-home-card-body em::after { content: " →"; }
.ml-home-card-external .ml-home-card-image { position: relative; }
.ml-external-icon { position: absolute; right: 8px; top: 8px; display: grid; place-items: center; width: 26px; height: 26px; border-radius: 999px; background: rgba(6,40,65,.84); color: #fff; font-size: .76rem; font-weight: 950; }
.ml-home-card-no-image { min-height: 100%; border-color: #cfe3ec; background: linear-gradient(180deg, #fff, #f7fbfd); }
.ml-home-card-no-image .ml-home-card-body { min-height: 190px; align-content: start; padding: 18px; }
.ml-home-source-card { border-top: 4px solid var(--ml-blue); }
.ml-home-card-badge { display: inline-flex; width: max-content; max-width: 100%; border-radius: 999px; background: rgba(34,134,74,.12); color: #176437 !important; padding: .28rem .55rem; font-size: .68rem !important; font-weight: 950; line-height: 1; letter-spacing: .06em; text-transform: uppercase; }
.ml-home-source-card .ml-home-card-body > span:not(.ml-home-card-badge) { color: #36566a; }

.ml-region-page { background: #f4f9fc; }
.ml-region-hero { position: relative; color: #fff; background-image: linear-gradient(90deg, rgba(2,25,42,.82), rgba(2,44,69,.48), rgba(2,25,42,.16)), var(--ml-region-hero-bg); background-size: cover; background-position: center; overflow: hidden; }
.ml-region-hero::after { content: ""; position: absolute; inset: auto 0 0; height: 110px; background: linear-gradient(0deg, rgba(2,22,36,.52), rgba(2,22,36,0)); pointer-events: none; }
.ml-region-hero-inner { position: relative; z-index: 1; padding-block: 44px; }
.ml-region-hero-layout { display: grid; grid-template-columns: minmax(320px, .78fr) minmax(420px, 1.02fr); gap: 32px; align-items: center; }
.ml-region-hero-copy { min-width: 0; }
.ml-region-kicker { display: inline-flex; margin: 0 0 .75rem; border: 1px solid rgba(255,255,255,.26); border-radius: 999px; background: rgba(255,255,255,.12); padding: .38rem .68rem; color: #dcf7ff; font-size: .78rem; font-weight: 950; letter-spacing: .1em; text-transform: uppercase; }
.ml-region-hero h1 { margin: 0; max-width: 620px; color: #fff; font-family: Georgia, "Times New Roman", serif; font-size: clamp(2.7rem, 6vw, 5.7rem); line-height: .94; letter-spacing: -.055em; text-shadow: 0 6px 30px rgba(0,0,0,.35); }
.ml-region-hero p:not(.ml-region-kicker) { max-width: 580px; color: rgba(255,255,255,.92); font-size: 1.04rem; text-shadow: 0 2px 16px rgba(0,0,0,.32); }
.ml-region-hero-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 20px; }
.ml-region-hero-map-card { border: 1px solid rgba(255,255,255,.38); border-radius: var(--ml-radius-lg); background: rgba(2,25,42,.24); padding: 8px; box-shadow: var(--ml-shadow-hero); backdrop-filter: blur(10px); }
.ml-region-hero-map-card .ml-region-map-svg { filter: drop-shadow(0 12px 26px rgba(0,0,0,.28)); }
.ml-region-main { padding-block: 30px 52px; }

.ml-region-intro-panel { display: grid; grid-template-columns: minmax(280px, .9fr) minmax(440px, 1.1fr); gap: 18px; align-items: stretch; margin-top: -18px; margin-bottom: 20px; border: 1px solid var(--ml-line); border-radius: var(--ml-radius-lg); background: linear-gradient(135deg, #fff, #f7fbfd); padding: 22px; box-shadow: var(--ml-shadow-soft); position: relative; z-index: 2; }
.ml-region-intro-copy h2 { margin: 0 0 .45rem; color: var(--ml-navy); font-size: clamp(1.35rem, 2.5vw, 2.05rem); letter-spacing: -.025em; line-height: 1.08; }
.ml-region-intro-copy p { margin: 0; color: var(--ml-muted); line-height: 1.55; }
.ml-region-stat-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 10px; }
.ml-region-stat-grid article { display: grid; align-content: center; gap: 3px; min-height: 110px; border: 1px solid var(--ml-line); border-radius: var(--ml-radius-sm); background: #fff; padding: 14px; box-shadow: 0 8px 20px rgba(6,40,65,.05); }
.ml-region-stat-grid strong { color: var(--ml-navy); font-size: clamp(1.1rem, 2vw, 1.55rem); font-weight: 950; line-height: 1.05; }
.ml-region-stat-grid span { color: #526b7e; font-size: .82rem; font-weight: 850; line-height: 1.28; }
.ml-region-source-note { grid-column: 1 / -1; display: flex; flex-wrap: wrap; gap: 8px 12px; align-items: center; margin: 0; border-top: 1px solid var(--ml-line); padding-top: 13px; color: #526b7e; font-size: .88rem; line-height: 1.45; }
.ml-region-source-note span { flex: 1 1 520px; }
.ml-region-source-note a { display: inline-flex; align-items: center; border: 1px solid #cfe3ec; border-radius: 999px; background: #fff; color: var(--ml-blue); padding: .42rem .68rem; font-weight: 950; text-decoration: none; }
.ml-region-source-note a:hover,
.ml-region-source-note a:focus-visible { border-color: var(--ml-region-accent, var(--ml-blue)); color: var(--ml-navy); text-decoration: none; }
.ml-region-panel-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; }
.ml-region-panel { display: flex; flex-direction: column; min-width: 0; border: 1px solid var(--ml-line); border-top: 5px solid var(--ml-region-accent, var(--ml-blue)); border-radius: var(--ml-radius-md); background: #fff; padding: 18px; box-shadow: var(--ml-shadow-soft); }
.ml-region-panel h2 { margin: 0 0 12px; color: var(--ml-navy); font-size: 1.2rem; line-height: 1.1; }
.ml-region-counties-list,
.ml-region-icon-list,
.ml-region-other-list { padding: 0; margin: 0; list-style: none; }
.ml-region-counties-list { columns: 2 130px; column-gap: 18px; }
.ml-region-counties-list li,
.ml-region-other-list li { break-inside: avoid; margin: 0 0 .38rem; }
.ml-region-counties-list a,
.ml-region-other-list a,
.ml-region-icon-list a { color: #075c8c; font-weight: 850; text-decoration: none; }
.ml-region-counties-list a:hover,
.ml-region-other-list a:hover,
.ml-region-icon-list a:hover,
.ml-region-lake-card a:hover { color: var(--ml-navy); text-decoration: underline; }
.ml-region-icon-list { display: grid; gap: 9px; }
.ml-region-icon-list a { display: grid; grid-template-columns: 30px 1fr; gap: 8px; align-items: center; }
.ml-region-icon-list span[aria-hidden="true"] { display: grid; place-items: center; width: 28px; height: 28px; border-radius: 999px; color: var(--ml-navy); background: #e8f5fb; background: color-mix(in srgb, var(--ml-region-accent, var(--ml-blue)) 16%, white); }
.ml-region-other-list { display: grid; gap: 8px; }
.ml-region-other-list a { display: block; border: 1px solid var(--ml-line); border-radius: 999px; padding: .46rem .72rem; background: #f8fbfd; }
.ml-region-panel-cta,
.ml-region-section-header > a,
.ml-region-education-cta,
.ml-regions-index-region-cta { display: inline-flex; align-items: center; gap: .25rem; width: max-content; margin-top: auto; color: var(--ml-blue); font-size: .88rem; font-weight: 950; text-decoration: none; }
.ml-region-panel-cta::after,
.ml-region-section-header > a::after,
.ml-region-education-cta::after { content: " →"; }
.ml-region-lakes-showcase,
.ml-region-education-showcase { margin-top: 24px; border: 1px solid var(--ml-line); border-radius: var(--ml-radius-lg); background: #fff; padding: 22px; box-shadow: var(--ml-shadow-soft); }
.ml-region-section-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 18px; margin-bottom: 18px; }
.ml-region-section-header h2 { margin: 0; color: var(--ml-navy); font-size: clamp(1.35rem, 2.4vw, 2.05rem); line-height: 1.08; letter-spacing: -.025em; }
.ml-region-section-header p { max-width: 720px; margin: .35rem 0 0; color: var(--ml-muted); }
.ml-region-lake-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; }
.ml-region-education-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.ml-region-lake-card,
.ml-region-education-card { overflow: hidden; border: 1px solid var(--ml-line); border-radius: var(--ml-radius-md); background: #fff; box-shadow: 0 8px 22px rgba(6,40,65,.07); transition: transform var(--ml-transition), box-shadow var(--ml-transition), border-color var(--ml-transition); }
.ml-region-lake-card:hover,
.ml-region-education-card:hover { transform: translateY(-3px); border-color: #8ccfe9; box-shadow: var(--ml-shadow-card); }
.ml-region-lake-card-text { display: grid; grid-template-columns: 42px 1fr; gap: 12px; padding: 15px; }
.ml-region-lake-rank { display: grid; place-items: center; width: 42px; height: 42px; border-radius: 14px; background: color-mix(in srgb, var(--ml-region-accent, var(--ml-blue)) 18%, #fff); color: var(--ml-navy); font-size: .86rem; font-weight: 950; letter-spacing: .04em; }
.ml-region-lake-image,
.ml-region-education-image { display: block; aspect-ratio: 16 / 10; overflow: hidden; background: #dcecf4; }
.ml-region-lake-image img,
.ml-region-education-image img { width: 100%; height: 100%; object-fit: cover; transition: transform 280ms ease; }
.ml-region-lake-card:hover .ml-region-lake-image img,
.ml-region-education-card:hover .ml-region-education-image img { transform: scale(1.04); }
.ml-region-lake-card-body,
.ml-region-education-body { display: grid; gap: 7px; padding: 13px; }
.ml-region-lake-card-text .ml-region-lake-card-body { padding: 0; }
.ml-region-education-card-text { min-height: 215px; border-top: 4px solid var(--ml-region-accent, var(--ml-blue)); background: linear-gradient(180deg, #fff, #f8fbfd); }
.ml-region-education-card-text .ml-region-education-body { min-height: 100%; align-content: start; }
.ml-region-education-badge { justify-self: start; border: 1px solid #cfe3ec; border-radius: 999px; background: #f7fbfd; padding: .28rem .54rem; color: var(--ml-blue); font-size: .72rem; font-weight: 950; text-transform: uppercase; letter-spacing: .06em; }
.ml-region-lake-card h3,
.ml-region-education-body h3 { margin: 0; color: var(--ml-navy); font-size: 1.02rem; line-height: 1.16; }
.ml-region-lake-card h3 a,
.ml-region-education-body h3 a { color: inherit; text-decoration: none; }
.ml-region-lake-county { color: var(--ml-blue); font-size: .82rem; font-weight: 950; text-decoration: none; }
.ml-region-lake-card p,
.ml-region-education-body p { margin: 0; color: #486175; font-size: .86rem; }
.ml-region-lake-meta { display: flex; flex-wrap: wrap; align-items: center; gap: .45rem .55rem; margin-top: .15rem; color: var(--ml-muted); font-size: .8rem; font-weight: 850; }
.ml-region-lake-actions { display: flex; flex-wrap: wrap; gap: 7px; margin-top: .2rem; }
.ml-region-lake-actions a { display: inline-flex; align-items: center; justify-content: center; border: 1px solid #cfe3ec; border-radius: 999px; background: #f7fbfd; color: var(--ml-blue); padding: .42rem .58rem; font-size: .76rem; font-weight: 950; text-decoration: none; }
.ml-region-lake-actions a:hover,
.ml-region-lake-actions a:focus-visible { border-color: var(--ml-region-accent, var(--ml-blue)); color: var(--ml-navy); text-decoration: none; }
.ml-region-lake-source-hint { margin: 15px 0 0; border-top: 1px solid var(--ml-line); padding-top: 12px; color: var(--ml-muted); font-size: .86rem; line-height: 1.45; }

.ml-region-map-card { position: relative; overflow: hidden; border: 1px solid var(--ml-line); border-radius: var(--ml-radius-lg); background: #fff; box-shadow: var(--ml-shadow-soft); }
.ml-region-map-head,
.ml-region-map-heading-wrap { display: grid; gap: 4px; padding: 14px 16px 8px; text-align: center; }
.ml-region-map-head h2,
.ml-region-map-heading-wrap h2 { margin: 0; color: var(--ml-navy); font-size: 1.08rem; line-height: 1.1; }
.ml-region-map-head p,
.ml-region-map-heading-wrap p { margin: 0; color: var(--ml-muted); font-size: .82rem; }
.ml-region-map-canvas { padding: 8px; }
.ml-region-map-svg,
.ml-regions-index-map-svg { width: 100%; height: auto; display: block; }
.ml-region-map-bg,
.ml-region-map-title { fill: #eef7fb; }
.ml-region-map-county rect { fill: #e8f5fb; fill: color-mix(in srgb, var(--ml-region-accent, var(--ml-blue)) 18%, #fff); stroke: rgba(6,40,65,.25); stroke-width: 1; transition: fill var(--ml-transition), stroke var(--ml-transition); }
.ml-region-map-county text { fill: var(--ml-navy); font-size: 10px; font-weight: 850; pointer-events: none; }
.ml-region-map-county:hover rect,
.ml-region-map-county:focus rect { fill: #d2edf8; fill: color-mix(in srgb, var(--ml-region-accent, var(--ml-blue)) 34%, #fff); stroke: var(--ml-region-accent, var(--ml-blue)); }
.ml-region-map-county:hover text,
.ml-region-map-county:focus text { fill: var(--ml-navy-deep); }
.ml-region-map-county:focus-visible rect { stroke-width: 2.4; }
.ml-region-source-panel { margin-top: 24px; border: 1px solid var(--ml-line); border-radius: var(--ml-radius-lg); background: #fff; padding: 22px; box-shadow: var(--ml-shadow-soft); }
.ml-region-source-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; }
.ml-region-source-card { display: grid; gap: 7px; min-height: 150px; border: 1px solid var(--ml-line); border-top: 4px solid var(--ml-region-accent, var(--ml-blue)); border-radius: var(--ml-radius-md); background: linear-gradient(180deg, #fff, #f8fbfd); padding: 16px; color: inherit; text-decoration: none; }
.ml-region-source-card strong { color: var(--ml-navy); font-size: 1rem; line-height: 1.12; }
.ml-region-source-card span { color: #486175; font-size: .86rem; line-height: 1.4; }
.ml-region-source-card:hover,
.ml-region-source-card:focus-visible { border-color: var(--ml-region-accent, var(--ml-blue)); box-shadow: var(--ml-shadow-card); transform: translateY(-2px); }

.ml-regions-index-page,
.ml-counties-index-page { background: #f4f9fc; padding: 32px 0 52px; }
.ml-regions-index-breadcrumbs { margin-bottom: 12px; }
.ml-regions-index-intro,
.ml-counties-index-hero { display: grid; grid-template-columns: minmax(320px, .86fr) minmax(520px, 1.14fr); gap: 28px; align-items: stretch; }
.ml-regions-index-copy,
.ml-counties-index-copy { border: 1px solid var(--ml-line); border-radius: var(--ml-radius-lg); background: #fff; padding: clamp(22px, 3vw, 34px); box-shadow: var(--ml-shadow-soft); }
.ml-regions-index-copy h1,
.ml-counties-index-copy h1 { margin: 0; color: var(--ml-navy); font-family: Georgia, "Times New Roman", serif; font-size: clamp(3rem, 7vw, 6rem); line-height: .9; letter-spacing: -.06em; }
.ml-regions-index-copy > p:not(.ml-kicker),
.ml-counties-index-copy > p:not(.ml-kicker) { max-width: 720px; color: var(--ml-muted-strong); font-size: 1rem; }
.ml-regions-index-stats,
.ml-counties-index-stats { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); overflow: hidden; margin-top: 18px; border: 1px solid var(--ml-line); border-radius: var(--ml-radius-md); background: #fbfdff; }
.ml-regions-index-stats article,
.ml-counties-index-stats article { min-width: 0; border-right: 1px solid var(--ml-line); border-bottom: 1px solid var(--ml-line); padding: 14px; }
.ml-regions-index-stats article:nth-child(2n),
.ml-counties-index-stats article:nth-child(2n) { border-right: 0; }
.ml-regions-index-stats article:nth-last-child(-n+2),
.ml-counties-index-stats article:nth-last-child(-n+2) { border-bottom: 0; }
.ml-regions-index-stats article > span { display: inline-grid; place-items: center; width: 28px; height: 28px; border-radius: 999px; background: var(--ml-sky-soft); color: var(--ml-blue); }
.ml-regions-index-stats strong,
.ml-counties-index-stats strong { display: block; color: var(--ml-navy); font-size: 1.12rem; font-weight: 950; }
.ml-regions-index-stats p,
.ml-counties-index-stats span,
.ml-regions-index-stats span + p { margin: .25rem 0 0; color: var(--ml-muted); font-size: .84rem; }
.ml-regions-index-map-wrap,
.ml-counties-index-map-panel { display: flex; align-items: stretch; min-width: 0; }
.ml-regions-index-correct-map { position: relative; width: 100%; min-height: 100%; margin: 0; overflow-x: auto; border: 1px solid var(--ml-line); border-radius: var(--ml-radius-lg); background: #fff; padding: 14px; box-shadow: var(--ml-shadow-soft); }
.ml-regions-index-map-stage { position: relative; width: 100%; min-width: min(620px, 100%); max-width: 850px; margin-inline: auto; line-height: 0; }
.ml-regions-index-correct-map-image { display: block; width: 100%; height: auto; object-fit: contain; border-radius: var(--ml-radius-md); background: #fff; }
.ml-regions-index-county-hotspots { position: absolute; inset: 0; pointer-events: none; }
.ml-regions-index-county-hotspot { position: absolute; display: block; border-radius: 4px; color: transparent; text-decoration: none; overflow: hidden; pointer-events: auto; }
.ml-regions-index-county-hotspot span { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); }
.ml-regions-index-county-hotspot:hover,
.ml-regions-index-county-hotspot:focus-visible { outline: 2px solid rgba(12,119,164,.85); outline-offset: 1px; background: rgba(63,169,218,.16); }
.ml-regions-index-map-legend { display: grid; gap: 0; padding: 0; margin: 0; list-style: none; }
.ml-regions-index-map-legend li { border-bottom: 1px solid var(--ml-line); padding: .7rem 0; }
.ml-regions-index-map-legend span { display: inline-block; width: 12px; height: 12px; border-radius: 999px; margin-right: .45rem; vertical-align: -1px; }
.ml-regions-index-map-legend a { font-weight: 900; text-decoration: none; }
.ml-regions-index-region-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 20px; margin-top: 24px; }
.ml-regions-index-region-card,
.ml-regions-index-deepest-card { border: 1px solid var(--ml-line); border-top: 5px solid var(--ml-region-accent, var(--ml-blue)); border-radius: var(--ml-radius-lg); background: #fff; padding: 18px; box-shadow: var(--ml-shadow-soft); }
.ml-regions-index-region-card header,
.ml-regions-index-deepest-card header { margin-bottom: 14px; }
.ml-regions-index-region-card h2,
.ml-regions-index-deepest-card h2 { margin: 0; color: var(--ml-navy); font-size: 1.45rem; letter-spacing: -.02em; }
.ml-regions-index-region-card h2 a { color: inherit; text-decoration: none; }
.ml-regions-index-region-card header p,
.ml-regions-index-deepest-card header p { margin: .35rem 0 .8rem; color: var(--ml-muted); }
.ml-regions-index-region-meta { display: flex; flex-wrap: wrap; gap: .35rem .55rem; align-items: center; margin-top: 10px !important; color: var(--ml-muted-strong) !important; font-size: .84rem; }
.ml-regions-index-region-meta strong { color: var(--ml-navy); font-weight: 950; }
.ml-regions-index-lake-list { display: grid; gap: 10px; }
.ml-regions-index-lake-row { display: grid; grid-template-columns: 86px 1fr; gap: 10px; align-items: center; border: 1px solid var(--ml-line); border-radius: var(--ml-radius-sm); background: #fbfdff; padding: 8px; }
.ml-regions-index-lake-image { display: block; aspect-ratio: 4 / 3; overflow: hidden; border-radius: 10px; background: #dcecf4; }
.ml-regions-index-lake-image img { width: 100%; height: 100%; object-fit: cover; transition: transform 280ms ease; }
.ml-regions-index-lake-row:hover img { transform: scale(1.04); }
.ml-regions-index-lake-row h3 { margin: 0; font-size: .96rem; line-height: 1.12; }
.ml-regions-index-lake-row h3 a { color: var(--ml-navy); text-decoration: none; }
.ml-regions-index-county-link { color: var(--ml-blue); font-size: .8rem; font-weight: 900; text-decoration: none; }
.ml-regions-index-lake-row p { margin: .25rem 0 0; color: var(--ml-muted); font-size: .8rem; line-height: 1.28; }
.ml-regions-index-lake-meta { display: flex; flex-wrap: wrap; gap: 3px 7px; align-items: center; color: var(--ml-navy); font-weight: 850; }
.ml-regions-index-lake-meta span { color: var(--ml-muted); }
.ml-regions-index-dnr-meta { color: var(--ml-navy) !important; font-weight: 850; }
.ml-regions-index-map-source { margin: .75rem 0 0; border-top: 1px solid var(--ml-line); padding-top: .7rem; color: var(--ml-muted); font-size: .86rem; line-height: 1.4; }
.ml-regions-index-map-source a { color: var(--ml-blue); font-weight: 950; text-decoration: none; }
.ml-regions-index-deepest-card { grid-column: 1 / -1; }
.ml-regions-index-deep-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; }
.ml-regions-index-deep-card { display: grid; grid-template-columns: 96px 1fr; gap: 10px; border: 1px solid var(--ml-line); border-radius: var(--ml-radius-sm); background: #fbfdff; padding: 8px; }
.ml-regions-index-deep-image { position: relative; display: block; aspect-ratio: 1 / 1; overflow: hidden; border-radius: 10px; background: #dcecf4; }
.ml-regions-index-deep-image img { width: 100%; height: 100%; object-fit: cover; }
.ml-regions-index-deep-image span { position: absolute; left: 7px; top: 7px; display: grid; place-items: center; width: 28px; height: 28px; border-radius: 999px; color: #fff; background: rgba(6,40,65,.82); font-weight: 950; }
.ml-regions-index-deep-card h3 { margin: 0; font-size: .96rem; line-height: 1.12; }
.ml-regions-index-deep-card h3 a { color: var(--ml-navy); text-decoration: none; }
.ml-regions-index-deep-card p { margin: .2rem 0 0; color: var(--ml-muted); font-size: .82rem; }
.ml-regions-index-deep-county { color: var(--ml-blue) !important; font-weight: 850; }
.ml-regions-index-featured-map,
.ml-regions-index-featured-map-stage { position: relative; }
.ml-regions-index-featured-map-stage > img { width: 100%; border-radius: var(--ml-radius-md); }
.ml-regions-index-featured-map-links { position: absolute; inset: 0; }
.ml-regions-index-featured-map-link { position: absolute; display: grid; place-items: center; border-radius: 999px; color: transparent; overflow: hidden; }
.ml-regions-index-featured-map-link:hover,
.ml-regions-index-featured-map-link:focus-visible { outline: 2px solid rgba(12,119,164,.8); outline-offset: 2px; background: rgba(63,169,218,.16); }
.ml-regions-index-featured-map-link span { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); }
.ml-regions-index-featured-map figcaption { margin-top: .6rem; color: var(--ml-muted); font-size: .82rem; }

.ml-counties-index-section { margin-top: 24px; }
.ml-counties-index-section-header { display: flex; justify-content: space-between; align-items: flex-end; gap: 16px; margin-bottom: 14px; }
.ml-counties-index-section-header h2 { margin: 0; color: var(--ml-navy); font-size: clamp(1.35rem, 2.4vw, 2rem); letter-spacing: -.025em; }
.ml-counties-index-section-header p { max-width: 760px; margin: .28rem 0 0; color: var(--ml-muted); }
.ml-counties-region-card-grid,
.ml-counties-planning-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 16px; }
.ml-counties-featured-grid,
.ml-counties-facts-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.ml-counties-region-card,
.ml-counties-featured-card,
.ml-counties-fact-card,
.ml-counties-planning-card { overflow: hidden; border: 1px solid var(--ml-line); border-radius: var(--ml-radius-md); background: #fff; box-shadow: var(--ml-shadow-soft); }
.ml-counties-region-card { border-top: 5px solid var(--ml-region-accent, var(--ml-blue)); }
.ml-counties-region-card-image,
.ml-counties-featured-image,
.ml-counties-planning-image { display: block; aspect-ratio: 16 / 10; overflow: hidden; background: #dcecf4; }
.ml-counties-featured-card { display: grid; grid-template-columns: 44% 1fr; }
.ml-counties-featured-image { min-height: 190px; aspect-ratio: auto; }
.ml-counties-region-card-image img,
.ml-counties-featured-image img,
.ml-counties-planning-image img { width: 100%; height: 100%; object-fit: cover; }
.ml-counties-region-card-body,
.ml-counties-featured-body,
.ml-counties-planning-body { display: grid; gap: 8px; padding: 14px; }
.ml-counties-region-card-body h3,
.ml-counties-featured-body h3,
.ml-counties-planning-body h3 { margin: 0; color: var(--ml-navy); font-size: 1rem; line-height: 1.14; }
.ml-counties-region-card-body h3 a,
.ml-counties-featured-body h3 a,
.ml-counties-planning-body h3 a { color: inherit; text-decoration: none; }
.ml-counties-region-card-body p,
.ml-counties-featured-body p,
.ml-counties-planning-body p { margin: 0; color: #486175; font-size: .86rem; }
.ml-counties-featured-body > a,
.ml-counties-planning-body > a { color: var(--ml-blue); font-size: .84rem; font-weight: 950; text-decoration: none; }
.ml-counties-featured-body > a::after,
.ml-counties-planning-body > a::after { content: " →"; }
.ml-counties-fact-card { padding: 18px; border-top: 5px solid var(--ml-green); }
.ml-counties-fact-card strong { display: block; color: var(--ml-blue); font-size: 2rem; line-height: 1; font-weight: 950; }
.ml-counties-fact-card h3 { margin: .55rem 0 .3rem; color: var(--ml-navy); }
.ml-counties-fact-card p { margin: 0; color: var(--ml-muted); }
.ml-counties-az-panel { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 16px; border: 1px solid var(--ml-line); border-radius: var(--ml-radius-lg); background: #fff; padding: 18px; box-shadow: var(--ml-shadow-soft); }
.ml-counties-az-group { display: grid; gap: 6px; align-content: start; }
.ml-counties-az-group h3 { margin: 0 0 4px; color: var(--ml-green); font-size: 1rem; }
.ml-counties-az-group a { color: #075c8c; font-size: .92rem; font-weight: 850; text-decoration: none; }
.ml-counties-az-group a:hover { color: var(--ml-navy); text-decoration: underline; }

.ml-lakes-hero { position: relative; color: #fff; background-image: linear-gradient(90deg, rgba(2,25,42,.88), rgba(2,39,64,.55), rgba(2,39,64,.20)), var(--ml-lakes-hero-bg); background-size: cover; background-position: center; overflow: hidden; }
.ml-lakes-hero::after { content: ""; position: absolute; inset: auto 0 0; height: 80px; background: linear-gradient(0deg, rgba(0,0,0,.26), transparent); pointer-events: none; }
.ml-lakes-hero-grid { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(300px, .72fr) minmax(520px, 1.28fr); gap: 34px; align-items: center; padding-block: 42px; }
.ml-lakes-hero-copy h1 { margin: 0; color: #fff; font-family: Georgia, "Times New Roman", serif; font-size: clamp(3rem, 7vw, 5.9rem); line-height: .94; letter-spacing: -.05em; text-shadow: 0 6px 28px rgba(0,0,0,.35); }
.ml-lakes-hero-copy p { max-width: 560px; color: rgba(255,255,255,.94); font-size: 1.05rem; }
.ml-lakes-hero-facts { display: grid; gap: .8rem; margin: 1.3rem 0 0; padding: 0; list-style: none; }
.ml-lakes-hero-facts li { display: grid; grid-template-columns: 36px 1fr; gap: .12rem .2rem; max-width: 440px; align-items: start; }
.ml-lakes-hero-facts li::before { content: "⌁"; display: grid; place-items: center; grid-row: span 2; width: 28px; height: 28px; border: 1px solid rgba(255,255,255,.26); border-radius: 999px; background: rgba(255,255,255,.14); font-weight: 950; }
.ml-lakes-hero-facts strong { font-weight: 950; }
.ml-lakes-hero-facts span { color: rgba(255,255,255,.84); font-size: .9rem; }
.ml-lakes-feature-panel {
  align-self: center;
  display: grid;
  gap: 16px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.82);
  border-radius: var(--ml-radius-lg);
  background: rgba(255,255,255,.96);
  color: var(--ml-ink);
  padding: clamp(18px, 2.4vw, 28px);
  box-shadow: var(--ml-shadow-hero);
}
.ml-lakes-feature-panel header { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; }
.ml-lakes-panel-kicker { margin: 0 0 .4rem; color: var(--ml-green); font-size: .76rem; font-weight: 950; letter-spacing: .13em; text-transform: uppercase; }
.ml-lakes-feature-panel h2 { margin: 0; color: var(--ml-navy); font-size: clamp(1.45rem, 2.2vw, 2.1rem); line-height: 1.06; letter-spacing: -.025em; }
.ml-lakes-feature-list { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.ml-lakes-feature-link {
  display: grid;
  gap: 4px;
  min-height: 94px;
  border: 1px solid var(--ml-line);
  border-radius: var(--ml-radius-sm);
  background: linear-gradient(180deg, #fff 0%, #f7fbff 100%);
  color: var(--ml-ink);
  padding: 13px;
  text-decoration: none;
  box-shadow: 0 4px 12px rgba(6,40,65,.06);
  transition: transform var(--ml-transition), border-color var(--ml-transition), box-shadow var(--ml-transition);
}
.ml-lakes-feature-link:hover { transform: translateY(-2px); border-color: #7ac6e8; box-shadow: 0 12px 24px rgba(6,40,65,.12); }
.ml-lakes-feature-link strong { color: var(--ml-navy); line-height: 1.15; }
.ml-lakes-feature-link span { color: var(--ml-muted); font-size: .82rem; font-weight: 850; }
.ml-lakes-feature-link em { color: var(--ml-blue); font-size: .8rem; font-style: normal; font-weight: 950; }
.ml-lakes-feature-actions { display: flex; flex-wrap: wrap; gap: .75rem; padding-top: 2px; }
.ml-lakes-index { background: #f7fbfe; padding: 28px 0 44px; }
.ml-lakes-sections { display: grid; grid-template-columns: 1fr; gap: 24px; }
.ml-lakes-category { width: 100%; border: 1px solid var(--ml-line); border-radius: var(--ml-radius-lg); background: #fff; padding: 20px 22px; box-shadow: var(--ml-shadow-soft); }
.ml-lakes-category-header { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: .35rem; }
.ml-lakes-category-header > div { display: flex; align-items: center; gap: .6rem; }
.ml-lakes-category-header h2 { margin: 0; color: var(--ml-navy); font-size: 1.6rem; line-height: 1.1; letter-spacing: -.02em; }
.ml-lakes-category-header a { color: var(--ml-blue); font-size: .85rem; font-weight: 950; text-decoration: none; }
.ml-lakes-number { display: none; }
.ml-lakes-category-intro { margin: .25rem 0 1rem; color: var(--ml-muted); font-size: .9rem; }
.ml-lakes-card-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.ml-lakes-card { display: flex; flex-direction: column; min-width: 0; overflow: hidden; border: 1px solid var(--ml-line); border-radius: var(--ml-radius-sm); background: #fff; color: var(--ml-ink); text-decoration: none; box-shadow: 0 4px 12px rgba(6,40,65,.06); transition: transform var(--ml-transition), border-color var(--ml-transition), box-shadow var(--ml-transition); }
.ml-lakes-card:hover { transform: translateY(-2px); border-color: #7ac6e8; box-shadow: 0 12px 24px rgba(6,40,65,.12); }
.ml-lakes-card img { width: 100%; height: 112px; object-fit: cover; background: #e7f2f7; }
.ml-lakes-card-body { display: grid; gap: 3px; padding: 10px 11px 11px; }
.ml-lakes-card-body strong { color: var(--ml-navy); font-size: .92rem; font-weight: 950; line-height: 1.14; }
.ml-lakes-card-body em { color: var(--ml-blue); font-size: .78rem; font-style: normal; font-weight: 900; }
.ml-lakes-card-body span { color: #385064; font-size: .76rem; line-height: 1.26; }
.ml-lakes-card-body b { margin-top: 2px; color: #006da0; font-size: .78rem; }
.ml-lakes-card-body b::after { content: " →"; }
.ml-lakes-region-links { margin-top: 24px; border: 1px solid var(--ml-line); border-radius: var(--ml-radius-lg); background: #fff; padding: 20px; box-shadow: var(--ml-shadow-soft); }
.ml-lakes-region-links header h2 { margin: 0; color: var(--ml-navy); font-size: 1.5rem; }
.ml-lakes-region-links header p { margin: .25rem 0 1rem; color: var(--ml-muted); }
.ml-lakes-region-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 14px; }
.ml-lakes-region-card { display: grid; gap: 7px; overflow: hidden; border: 1px solid var(--ml-line); border-radius: var(--ml-radius-sm); background: #fff; color: var(--ml-ink); padding-bottom: 12px; text-decoration: none; }
.ml-lakes-region-card img { width: 100%; height: 120px; object-fit: cover; }
.ml-lakes-region-card strong,
.ml-lakes-region-card span,
.ml-lakes-region-card b { padding-inline: 12px; }
.ml-lakes-region-card strong { color: var(--ml-navy); font-weight: 950; }
.ml-lakes-region-card span { color: #385064; font-size: .85rem; }
.ml-lakes-region-card b { color: #006da0; font-size: .84rem; }
.ml-lakes-region-card b::after { content: " →"; }

.ml-site-footer { background: linear-gradient(180deg, #063456 0%, #031f36 100%); color: #fff; padding: 28px 0 12px; }
.ml-site-footer a { color: rgba(255,255,255,.9); text-decoration: none; }
.ml-site-footer a:hover { color: #8ed6f3; }
.ml-footer-grid { display: grid; grid-template-columns: minmax(210px, 1.55fr) repeat(4, minmax(92px, .65fr)) minmax(220px, 1.15fr); gap: 24px; align-items: start; }
.ml-footer-brand p { max-width: 290px; margin: 10px 0; color: rgba(255,255,255,.88); }
.ml-footer-logo img { width: 300px; max-width: 100%; height: auto; background: transparent; }
.ml-footer-column { display: grid; gap: 7px; }
.ml-footer-nav { display: block; }
.ml-footer-menu { display: grid; gap: 7px; margin: 0; padding: 0; list-style: none; }
.ml-footer-column h2,
.ml-footer-news h2 { margin: 0 0 5px; color: #fff; font-size: .98rem; }
.ml-footer-column a { color: rgba(255,255,255,.86); font-size: .88rem; }
.ml-footer-news { border: 1px solid rgba(255,255,255,.28); border-radius: 12px; padding: 16px; }
.ml-footer-news p { margin: 0 0 12px; color: rgba(255,255,255,.82); font-size: .88rem; }
.ml-footer-verify-links { display: flex; flex-wrap: wrap; gap: 8px; }
.ml-footer-verify-links a { display: inline-flex; align-items: center; justify-content: center; border: 1px solid rgba(255,255,255,.28); border-radius: 999px; background: rgba(255,255,255,.08); color: #fff; padding: .58rem .75rem; font-size: .82rem; font-weight: 950; text-decoration: none; }
.ml-footer-verify-links a:hover,
.ml-footer-verify-links a:focus-visible { background: rgba(255,255,255,.16); color: #fff; }
.ml-footer-bottom { display: flex; align-items: center; justify-content: center; gap: 18px; margin-top: 20px; border-top: 1px solid rgba(255,255,255,.14); padding-top: 12px; color: rgba(255,255,255,.85); font-size: .82rem; }
.ml-footer-bottom p { margin: 0; }

@media (max-width: 1180px) {
  :root { --ml-shell-pad: 18px; }
  .ml-header-inner { grid-template-columns: 210px auto; }
  .ml-menu-toggle { display: grid; place-items: center; justify-self: end; grid-column: 2; grid-row: 1; }
  .ml-primary-nav { display: none; grid-column: 1 / -1; width: 100%; }
  .ml-primary-nav.is-open { display: block; }
  .ml-menu { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; white-space: normal; }
  .ml-menu a { display: block; border: 1px solid rgba(255,255,255,.16); border-radius: 10px; background: rgba(255,255,255,.07); padding: .65rem .75rem; text-align: center; }
  .ml-header-tools { grid-column: 1 / -1; justify-content: stretch; }
  .ml-search-header { width: auto; flex: 1 1 auto; }
  .ml-home-hero-grid,
  .ml-lakes-hero-grid,
  .ml-region-hero-layout,
  .ml-regions-index-intro,
  .ml-counties-index-hero { grid-template-columns: 1fr; }
  .ml-home-grid-five,
  .ml-home-grid-six { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .ml-region-panel-grid,
  .ml-region-source-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ml-region-intro-panel { grid-template-columns: 1fr; }
  .ml-region-stat-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ml-regions-index-deep-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .ml-counties-region-card-grid,
  .ml-counties-planning-grid,
  .ml-lakes-region-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .ml-counties-featured-grid,
  .ml-counties-facts-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ml-counties-az-panel { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .ml-footer-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

@media (max-width: 900px) {
  .admin-bar .ml-site-header { top: 46px; }
  .ml-header-inner { grid-template-columns: 1fr auto; gap: 10px; }
  .ml-brand-link,
  .ml-site-logo { width: 190px; }
  .ml-header-tools { flex-wrap: wrap; }
  .ml-language { width: auto; }
  .ml-home-hero-grid,
  .ml-region-hero-inner,
  .ml-lakes-hero-grid { padding-block: 28px; }
  .ml-home-guide-card,
  .ml-region-hero-map-card,
  .ml-lakes-feature-panel { max-width: 760px; width: 100%; justify-self: center; }
  .ml-regions-index-region-grid,
  .ml-lakes-sections { grid-template-columns: 1fr; }
  .ml-region-lake-grid,
  .ml-region-education-grid,
  .ml-region-source-grid,
  .ml-lakes-card-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ml-regions-index-deep-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ml-footer-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 760px) {
  :root { --ml-shell-pad: 16px; }
  .ml-site-header { position: sticky; }
  .ml-menu { grid-template-columns: 1fr 1fr; }
  .ml-header-tools { display: grid; grid-template-columns: 1fr; }
  .ml-search { display: grid; grid-template-columns: 1fr auto; width: 100%; }
  .ml-language { justify-content: space-between; width: 100%; }
  .ml-language select { flex: 1; min-width: 0; }
  .ml-home-hero { min-height: 0; }
  .ml-lakes-feature-list { grid-template-columns: 1fr; }
  .ml-home-hero-stats,
  .ml-home-guide-links,
  .ml-home-grid-five,
  .ml-home-grid-six,
  .ml-region-panel-grid,
  .ml-region-lake-grid,
  .ml-region-education-grid,
  .ml-region-source-grid,
  .ml-counties-region-card-grid,
  .ml-counties-featured-grid,
  .ml-counties-facts-grid,
  .ml-counties-planning-grid,
  .ml-lakes-card-grid,
  .ml-lakes-region-grid { grid-template-columns: 1fr; }
  .ml-home-section-header,
  .ml-region-section-header,
  .ml-counties-index-section-header,
  .ml-lakes-category-header { align-items: flex-start; flex-direction: column; }
  .ml-counties-featured-card { grid-template-columns: 1fr; }
  .ml-counties-featured-image { aspect-ratio: 16 / 9; min-height: 0; }
  .ml-counties-az-panel { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ml-regions-index-stats,
  .ml-counties-index-stats { grid-template-columns: 1fr 1fr; }
  .ml-regions-index-deep-grid { grid-template-columns: 1fr; }
  .ml-regions-index-lake-row,
  .ml-regions-index-deep-card { grid-template-columns: 86px 1fr; }
  .ml-lakes-hero-grid { padding-block: 28px; }
  .ml-lakes-feature-panel header { align-items: flex-start; flex-direction: column; }
  .ml-footer-grid { grid-template-columns: 1fr; }
  .ml-footer-bottom { flex-direction: column; gap: 8px; text-align: center; }
}

@media (max-width: 600px) {
  .ml-brand-link,
  .ml-site-logo { width: 168px; }
  .ml-menu { grid-template-columns: 1fr; }
  .ml-search { grid-template-columns: 1fr; }
  .ml-search button { width: 100%; }
  .ml-home-hero-stats,
  .ml-region-stat-grid { grid-template-columns: 1fr; }
  .ml-home-hero-copy h1,
  .ml-region-hero h1,
  .ml-lakes-hero-copy h1,
  .ml-regions-index-copy h1,
  .ml-counties-index-copy h1 { font-size: clamp(2.35rem, 14vw, 3.8rem); }
  .ml-home-card-body,
  .ml-region-lake-card-body,
  .ml-region-education-body,
  .ml-counties-region-card-body,
  .ml-counties-featured-body,
  .ml-counties-planning-body { padding: 13px; }
  .ml-regions-index-stats,
  .ml-counties-index-stats,
  .ml-counties-az-panel { grid-template-columns: 1fr; }
  .ml-regions-index-stats article,
  .ml-counties-index-stats article { border-right: 0; }
  .ml-regions-index-lake-row,
  .ml-regions-index-deep-card { grid-template-columns: 74px 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { transition-duration: .001ms !important; animation-duration: .001ms !important; animation-iteration-count: 1 !important; }
}

/* T009 counties index polish: source-first, map-safe, and free of weak thumbnail tiles. */
.ml-counties-index-map-panel {
  flex-direction: column;
  gap: 12px;
  border: 1px solid var(--ml-line);
  border-radius: var(--ml-radius-lg);
  background: #fff;
  padding: clamp(14px, 2vw, 18px);
  box-shadow: var(--ml-shadow-soft);
}

.ml-counties-index-map-panel h2 {
  margin: 0 0 4px;
  color: var(--ml-navy);
  font-size: clamp(1.25rem, 2.4vw, 1.7rem);
  letter-spacing: -.02em;
}

.ml-counties-index-map-panel > p {
  margin: 0;
  color: var(--ml-muted-strong);
  font-size: .92rem;
  line-height: 1.48;
}

.ml-counties-index-map-panel .ml-regions-index-correct-map {
  box-shadow: none;
}

.ml-counties-index-map-source a,
.ml-regions-index-map-source a {
  display: inline-flex;
  margin-left: 8px;
  color: var(--ml-blue);
  font-weight: 900;
  text-decoration: none;
}

.ml-counties-index-map-source a:hover,
.ml-regions-index-map-source a:hover {
  color: var(--ml-navy);
  text-decoration: underline;
}

.ml-counties-region-card-meta,
.ml-counties-featured-meta,
.ml-counties-fact-source {
  color: var(--ml-muted-strong) !important;
  font-size: .78rem !important;
  font-weight: 850;
  letter-spacing: .005em;
}

.ml-counties-fact-source {
  display: inline-flex;
  margin-top: 12px;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.ml-counties-planning-grid-text {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.ml-counties-planning-card-text {
  display: grid;
  min-height: 210px;
  border-top: 5px solid var(--ml-blue);
}

.ml-counties-planning-card-text .ml-counties-planning-body {
  align-content: start;
}

.ml-counties-source-section {
  margin-bottom: 8px;
  padding-bottom: clamp(28px, 5vw, 64px);
}

.ml-counties-source-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.ml-counties-source-card {
  display: grid;
  gap: 8px;
  min-height: 132px;
  padding: 18px;
  border: 1px solid var(--ml-line);
  border-radius: var(--ml-radius-md);
  background: #fff;
  box-shadow: var(--ml-shadow-soft);
  color: inherit;
  text-decoration: none;
}

.ml-counties-source-card strong {
  color: var(--ml-navy);
  font-size: 1rem;
}

.ml-counties-source-card span {
  color: var(--ml-muted);
  font-size: .9rem;
  line-height: 1.55;
}

.ml-counties-source-card:hover,
.ml-counties-source-card:focus-visible {
  transform: translateY(-2px);
  box-shadow: var(--ml-shadow-card);
  border-color: rgba(12, 119, 164, .42);
}

.ml-counties-az-group a:focus-visible,
.ml-counties-source-card:focus-visible {
  outline: 3px solid rgba(242, 140, 19, .45);
  outline-offset: 3px;
  border-radius: 8px;
}

@media (max-width: 980px) {
  .ml-counties-planning-grid-text,
  .ml-counties-source-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .ml-counties-planning-grid-text,
  .ml-counties-source-grid {
    grid-template-columns: 1fr;
  }

  .ml-counties-index-map-source a,
  .ml-regions-index-map-source a {
    margin: 6px 8px 0 0;
  }
}

/* T010 /lakes/ repair: source-aware feature lists instead of unverified lake-pin maps. */
.ml-lakes-feature-intro {
  margin: .9rem 0 1rem;
  color: #385064;
  font-size: .92rem;
  line-height: 1.55;
}
.ml-lakes-overview {
  max-width: 980px;
  margin: 0 0 22px;
}
.ml-lakes-overview h2 {
  margin-top: .2rem;
  color: var(--ml-navy);
  font-size: clamp(2rem, 4vw, 3.35rem);
  letter-spacing: -.045em;
}
.ml-lakes-overview p:last-child {
  max-width: 850px;
  color: #385064;
}
.ml-lakes-section-kicker {
  margin: 0 0 .3rem;
  color: var(--ml-blue);
  font-size: .72rem;
  font-weight: 950;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.ml-lakes-category {
  padding: clamp(20px, 3vw, 32px);
}
.ml-lakes-category-header {
  align-items: flex-start;
  margin-bottom: .65rem;
}
.ml-lakes-category-header h2 {
  font-size: clamp(1.65rem, 3vw, 2.35rem);
}
.ml-lakes-card-text {
  position: relative;
  min-height: 230px;
  border-color: rgba(8, 72, 106, .14);
  background:
    linear-gradient(135deg, rgba(229, 246, 252, .95), rgba(255, 255, 255, .94) 42%, rgba(244, 251, 242, .88)),
    #fff;
}
.ml-lakes-card-badge {
  display: inline-grid;
  place-items: center;
  width: 42px;
  height: 42px;
  margin: 14px 14px 0;
  border-radius: 12px;
  background: rgba(0, 109, 160, .1);
  color: var(--ml-blue);
  font-weight: 950;
}
.ml-lakes-card-text .ml-lakes-card-body {
  position: relative;
  z-index: 1;
  gap: 8px;
  padding: 12px 16px 18px;
}
.ml-lakes-card-text .ml-lakes-card-body strong {
  font-size: 1.08rem;
}
.ml-lakes-card-stat {
  display: inline-flex;
  width: fit-content;
  max-width: 100%;
  border-radius: 999px;
  background: rgba(251, 133, 0, .1);
  color: #8d4a00 !important;
  padding: .35rem .58rem;
  font-size: .76rem !important;
  font-weight: 950;
}
.ml-lakes-card-note {
  color: #385064 !important;
  font-size: .82rem !important;
  line-height: 1.4 !important;
}
.ml-lakes-source-panel {
  display: grid;
  grid-template-columns: minmax(260px, .8fr) minmax(420px, 1.2fr);
  gap: 24px;
  margin-top: 24px;
  border: 1px solid rgba(8, 72, 106, .16);
  border-radius: var(--ml-radius-lg);
  background: linear-gradient(135deg, #06223a, #083f5d 58%, #0d5b72);
  color: #fff;
  padding: clamp(22px, 4vw, 36px);
  box-shadow: var(--ml-shadow-soft);
}
.ml-lakes-source-panel h2 {
  margin: .15rem 0 .5rem;
  color: #fff;
  font-size: clamp(1.7rem, 3vw, 2.55rem);
  letter-spacing: -.035em;
}
.ml-lakes-source-panel p {
  margin: 0;
  color: rgba(255,255,255,.82);
}
.ml-lakes-source-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.ml-source-card {
  display: grid;
  gap: 6px;
  min-height: 132px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 22px;
  background: rgba(255,255,255,.1);
  color: #fff;
  padding: 16px;
  text-decoration: none;
  transition: transform var(--ml-transition), background var(--ml-transition), border-color var(--ml-transition);
}
.ml-source-card:hover {
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.36);
  background: rgba(255,255,255,.16);
}
.ml-source-card strong {
  color: #fff;
  font-size: 1rem;
  font-weight: 950;
}
.ml-source-card span {
  color: rgba(255,255,255,.8);
  font-size: .86rem;
  line-height: 1.45;
}
@media (max-width: 900px) {
  .ml-lakes-source-panel { grid-template-columns: 1fr; }
  .ml-lakes-source-grid { grid-template-columns: 1fr; }
}
@media (max-width: 680px) {
  .ml-lakes-card-text { min-height: 0; }
  .ml-lakes-card-stat { border-radius: 14px; }
}

/* T010 actual /lakes/ index cards and source trail. */
.ml-lakes-source-badge,
.ml-lakes-card-source {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  border-radius: 999px;
  background: rgba(0, 109, 160, .1);
  color: var(--ml-blue);
  padding: .38rem .62rem;
  font-size: .72rem;
  font-weight: 950;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.ml-lakes-card-grid > article.ml-lakes-card {
  display: flex;
  flex-direction: column;
  gap: .72rem;
  min-height: 260px;
  padding: 18px;
  border: 1px solid rgba(8, 72, 106, .14);
  border-radius: 24px;
  background:
    linear-gradient(145deg, rgba(229, 246, 252, .95), rgba(255,255,255,.96) 46%, rgba(242, 249, 238, .88)),
    #fff;
  box-shadow: 0 8px 22px rgba(6, 40, 65, .07);
}
.ml-lakes-card-grid > article.ml-lakes-card h3 {
  margin: 0;
  color: var(--ml-navy);
  font-size: 1.22rem;
  line-height: 1.08;
  letter-spacing: -.02em;
}
.ml-lakes-card-place,
.ml-lakes-card-stats,
.ml-lakes-card-note {
  margin: 0;
}
.ml-lakes-card-place {
  color: var(--ml-blue);
  font-size: .86rem;
  font-weight: 900;
}
.ml-lakes-card-stats {
  width: fit-content;
  border-radius: 999px;
  background: rgba(251, 133, 0, .1);
  color: #8d4a00;
  padding: .36rem .62rem;
  font-size: .78rem;
  font-weight: 950;
}
.ml-lakes-card-note {
  color: #385064;
  font-size: .86rem;
  line-height: 1.45;
}
.ml-lakes-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  margin-top: auto;
}
.ml-lakes-profile-link,
.ml-lakes-official-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  border-radius: 999px;
  padding: .55rem .8rem;
  font-size: .8rem;
  font-weight: 950;
  text-decoration: none;
}
.ml-lakes-profile-link {
  background: var(--ml-blue);
  color: #fff;
}
.ml-lakes-official-link {
  border: 1px solid rgba(0, 109, 160, .18);
  background: #fff;
  color: var(--ml-blue);
}
.ml-lakes-source-trail {
  display: grid;
  gap: 14px;
  margin-top: 24px;
  border: 1px solid rgba(8, 72, 106, .16);
  border-radius: var(--ml-radius-lg);
  background: linear-gradient(135deg, #06223a, #083f5d 58%, #0d5b72);
  color: #fff;
  padding: clamp(22px, 4vw, 36px);
  box-shadow: var(--ml-shadow-soft);
}
.ml-lakes-source-trail h2 {
  margin: .15rem 0 .1rem;
  color: #fff;
  font-size: clamp(1.7rem, 3vw, 2.55rem);
  letter-spacing: -.035em;
}
.ml-lakes-source-trail p {
  max-width: 860px;
  margin: 0;
  color: rgba(255,255,255,.82);
}
.ml-lakes-source-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
  margin-top: 8px;
}
.ml-lakes-source-card {
  display: grid;
  gap: 7px;
  min-height: 146px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 22px;
  background: rgba(255,255,255,.1);
  color: #fff;
  padding: 16px;
  text-decoration: none;
  transition: transform var(--ml-transition), background var(--ml-transition), border-color var(--ml-transition);
}
.ml-lakes-source-card:hover {
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.36);
  background: rgba(255,255,255,.16);
}
.ml-lakes-source-card strong,
.ml-lakes-source-card b {
  color: #fff;
}
.ml-lakes-source-card strong {
  font-size: .96rem;
  font-weight: 950;
  line-height: 1.16;
}
.ml-lakes-source-card span {
  color: rgba(255,255,255,.8);
  font-size: .82rem;
  line-height: 1.4;
}
.ml-lakes-source-card b {
  align-self: end;
  font-size: .78rem;
}
@media (max-width: 1080px) {
  .ml-lakes-source-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 620px) {
  .ml-lakes-source-grid { grid-template-columns: 1fr; }
  .ml-lakes-card-grid > article.ml-lakes-card { min-height: 0; }
  .ml-lakes-card-actions { flex-direction: column; align-items: stretch; }
}

/* T010 lakes index repair: source-first cards, no guessed lake-pin map, no repeated card imagery. */
.ml-lakes-feature-intro { margin: .35rem 0 1rem; color: #385064; font-size: .92rem; line-height: 1.45; }
.ml-lakes-overview,
.ml-lakes-source-trail { margin: 0 0 24px; border: 1px solid var(--ml-line); border-radius: var(--ml-radius-lg); background: #fff; padding: clamp(18px, 3vw, 28px); box-shadow: var(--ml-shadow-soft); }
.ml-lakes-overview h2,
.ml-lakes-source-trail h2 { margin: 0; color: var(--ml-navy); font-size: clamp(1.7rem, 3vw, 2.35rem); letter-spacing: -.035em; }
.ml-lakes-overview p:last-child,
.ml-lakes-source-trail > p:last-of-type { max-width: 850px; color: #385064; line-height: 1.55; }
.ml-lakes-section-kicker { margin: 0 0 .24rem; color: var(--ml-green); font-size: .72rem; font-weight: 950; letter-spacing: .12em; text-transform: uppercase; }
.ml-lakes-source-badge,
.ml-lakes-card-source { display: inline-flex; align-items: center; width: fit-content; border: 1px solid rgba(13,95,130,.18); border-radius: 999px; background: #eef8fb; color: #075d7e; padding: .35rem .62rem; font-size: .72rem; font-weight: 950; letter-spacing: .045em; text-transform: uppercase; }
.ml-lakes-card-grid { align-items: stretch; }
.ml-lakes-card { display: flex; flex-direction: column; gap: .68rem; min-height: 100%; padding: 16px; border-radius: 20px; background: linear-gradient(180deg, #ffffff, #f8fcfe); position: relative; overflow: hidden; }
.ml-lakes-card::before { content: ""; position: absolute; inset: 0 0 auto; height: 5px; background: linear-gradient(90deg, var(--ml-blue), var(--ml-green), var(--ml-orange)); }
.ml-lakes-card:hover { transform: translateY(-2px); border-color: #8ccfe7; }
.ml-lakes-card-topline { display: flex; justify-content: space-between; gap: .5rem; padding-top: .1rem; }
.ml-lakes-card h3 { margin: .1rem 0 0; color: var(--ml-navy); font-size: clamp(1.08rem, 1.5vw, 1.28rem); line-height: 1.08; letter-spacing: -.02em; }
.ml-lakes-card-place,
.ml-lakes-card-stats,
.ml-lakes-card-note { margin: 0; }
.ml-lakes-card-place { color: #0c6f96; font-size: .86rem; font-weight: 900; }
.ml-lakes-card-stats { color: #244559; font-size: .82rem; font-weight: 900; }
.ml-lakes-card-note { flex: 1 1 auto; color: #40586b; font-size: .84rem; line-height: 1.42; }
.ml-lakes-card-actions { display: flex; flex-wrap: wrap; gap: .55rem; margin-top: .2rem; }
.ml-lakes-card-actions a { display: inline-flex; align-items: center; justify-content: center; min-height: 36px; border-radius: 999px; padding: .48rem .72rem; font-size: .78rem; font-weight: 950; text-decoration: none; }
.ml-lakes-profile-link { background: var(--ml-navy); color: #fff; }
.ml-lakes-profile-link:hover { color: #fff; filter: brightness(1.08); }
.ml-lakes-official-link { border: 1px solid rgba(13,95,130,.22); background: #fff; color: #075d7e; }
.ml-lakes-source-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 12px; margin-top: 1.15rem; }
.ml-lakes-source-card { display: grid; gap: .45rem; border: 1px solid var(--ml-line); border-radius: 18px; background: #f8fcfe; padding: 15px; color: var(--ml-ink); text-decoration: none; min-height: 100%; transition: transform var(--ml-transition), border-color var(--ml-transition), box-shadow var(--ml-transition); }
.ml-lakes-source-card:hover { transform: translateY(-2px); border-color: #8ccfe7; box-shadow: 0 14px 26px rgba(6,40,65,.1); }
.ml-lakes-source-card strong { color: var(--ml-navy); font-size: .98rem; }
.ml-lakes-source-card span { color: #40586b; font-size: .82rem; line-height: 1.35; }
.ml-lakes-source-card b { color: #075d7e; font-size: .78rem; }
.ml-lakes-source-card b::after { content: " →"; }
@media (max-width: 980px) {
  .ml-lakes-source-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 680px) {
  .ml-lakes-source-grid { grid-template-columns: 1fr; }
  .ml-lakes-card { padding: 15px; }
  .ml-lakes-card-actions a { width: 100%; }
}
