:root {
  --navy-950: #06172b;
  --navy-900: #0a2039;
  --navy-800: #123454;
  --navy-700: #205074;
  --paper: #f7f5f0;
  --white: #fff;
  --ink: #172638;
  --muted: #687687;
  --line: #e1e7e8;
  --saffron: #ef7d24;
  --saffron-dark: #d96813;
  --saffron-soft: #fff1e4;
  --green: #179965;
  --green-soft: #e4f7ed;
  --red: #d74e46;
  --red-soft: #ffedeb;
  --blue-soft: #e6f2f8;
  --shadow: 0 15px 45px rgba(11, 34, 56, .1);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { background: var(--paper); color: var(--ink); font-family: "DM Sans", Arial, sans-serif; margin: 0; }
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }
.container { margin: 0 auto; max-width: 1220px; padding: 0 22px; }
.site-header { background: rgba(255, 255, 255, .97); border-bottom: 1px solid var(--line); position: sticky; top: 0; z-index: 20; }
.header-inner { align-items: center; display: flex; height: 70px; justify-content: space-between; }
.brand { align-items: center; display: flex; gap: 10px; }
.brand-mark { align-items: center; background: var(--navy-900); border-bottom: 4px solid var(--green); border-radius: 8px; color: var(--white); display: flex; font: 800 14px/1 "Manrope", Arial; height: 42px; justify-content: center; letter-spacing: -1px; width: 44px; }
.brand strong { color: var(--navy-900); display: block; font: 800 17px/1 "Manrope", Arial; letter-spacing: -.6px; }
.brand strong b { color: var(--saffron-dark); }
.brand small { color: var(--saffron-dark); display: block; font-size: 7px; font-weight: 800; letter-spacing: .55px; margin-top: 5px; text-transform: uppercase; }
.desktop-nav { display: flex; gap: 19px; margin-left: auto; margin-right: 22px; }
.desktop-nav a, .header-link { color: var(--muted); font-size: 11px; font-weight: 800; }
.desktop-nav a:hover, .header-link:hover { color: var(--saffron-dark); }
.primary-button, .button { align-items: center; background: var(--saffron); border: 0; border-radius: 7px; color: var(--white); display: inline-flex; font-size: 12px; font-weight: 800; gap: 8px; justify-content: center; min-height: 42px; padding: 0 15px; }
.button:hover, .primary-button:hover { background: var(--saffron-dark); }
.button-dark { background: var(--navy-900); }
.button-dark:hover { background: var(--navy-800); }
.button-green { background: var(--green); }
.button-green:hover { background: #11774f; }
.button-outline { background: transparent; border: 1px solid rgba(255, 255, 255, .34); }
.button-soft { background: var(--saffron-soft); color: var(--saffron-dark); }
.button-block { width: 100%; }
.hero { background: var(--navy-950); color: var(--white); overflow: hidden; padding: 74px 0 64px; position: relative; }
.hero::before { background-image: linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px); background-size: 46px 46px; content: ""; inset: 0; position: absolute; }
.hero::after { background: radial-gradient(circle, rgba(25,153,101,.18), transparent 67%); content: ""; height: 620px; position: absolute; right: -260px; top: -180px; width: 620px; }
.hero-grid { align-items: center; display: grid; gap: 55px; grid-template-columns: minmax(0, 1.12fr) minmax(340px, .88fr); position: relative; z-index: 1; }
.eyebrow, .section-kicker { color: var(--saffron); font-size: 10px; font-weight: 800; letter-spacing: 1.4px; margin: 0; text-transform: uppercase; }
.hero h1 { font: 800 clamp(50px, 6vw, 74px)/.98 "Manrope", Arial; letter-spacing: -4px; margin: 18px 0 8px; }
.hero h1 span { color: var(--saffron); display: block; font: italic 400 .55em/1.15 Georgia, serif; letter-spacing: -1px; margin-top: 14px; }
.hero p:not(.eyebrow) { color: #c7d3dd; font-size: 15px; line-height: 1.65; max-width: 600px; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 9px; margin-top: 25px; }
.campaign-tags { color: #9eb0bf; display: flex; flex-wrap: wrap; font-size: 11px; font-weight: 700; gap: 13px; margin-top: 33px; }
.campaign-tags b:first-child { color: #7fd09f; }
.hero-panel { background: rgba(255,255,255,.97); border-radius: 16px; box-shadow: 0 24px 55px rgba(0,0,0,.26); color: var(--ink); overflow: hidden; }
.hero-image { background-image: linear-gradient(145deg, rgba(5,23,38,.04), rgba(5,23,38,.48)), url("../civic-issues-strip.png"); background-position: center, 0 center; background-size: cover, 400% 100%; height: 182px; padding: 16px; }
.pill { background: var(--red); border-radius: 30px; color: var(--white); display: inline-flex; font-size: 9px; font-weight: 800; letter-spacing: .75px; padding: 7px 9px; text-transform: uppercase; }
.hero-panel-body { padding: 17px; }
.hero-panel h2 { color: var(--navy-900); font: 800 18px/1.35 "Manrope", Arial; letter-spacing: -.65px; margin: 7px 0; }
.meta { color: #8793a0; font-size: 9px; font-weight: 800; letter-spacing: .3px; text-transform: uppercase; }
.location { color: var(--muted); font-size: 11px; font-weight: 700; margin: 0; }
.support-row { align-items: center; border-top: 1px solid var(--line); display: flex; justify-content: space-between; margin-top: 14px; padding-top: 12px; }
.support-row strong { color: var(--navy-900); }
.support-row span { color: var(--muted); font-size: 11px; }
.progress { background: #e7ecec; border-radius: 20px; height: 6px; margin: 9px 0; overflow: hidden; }
.progress i { background: linear-gradient(90deg, var(--saffron), #f4a343); display: block; height: 100%; }
.stats { background: var(--white); border-bottom: 1px solid var(--line); }
.learning-section { background: var(--white); padding: 22px 0; }
.carousel-shell { background: var(--navy-900); border-radius: 14px; box-shadow: var(--shadow); color: var(--white); overflow: hidden; }
.carousel-top { align-items: center; background: rgba(255,255,255,.06); display: flex; justify-content: space-between; padding: 14px 18px; }
.carousel-top h2 { font: 800 20px/1.1 "Manrope", Arial; letter-spacing: -.7px; margin: 5px 0 0; }
.carousel-dots { display: flex; gap: 6px; }
.carousel-dots button { background: rgba(255,255,255,.28); border: 0; border-radius: 50%; height: 8px; padding: 0; width: 8px; }
.carousel-dots button.active { background: var(--saffron); width: 22px; border-radius: 20px; }
.carousel-slide { display: none; min-height: 190px; padding: 24px; }
.carousel-slide.active { display: block; }
.carousel-slide h3 { font: 800 28px/1.12 "Manrope", Arial; letter-spacing: -1px; margin: 9px 0; max-width: 720px; }
.carousel-slide p:not(.eyebrow) { color: #c1cfda; font-size: 13px; line-height: 1.55; max-width: 750px; }
.carousel-slide .button { margin-top: 8px; }
.theme-saffron { background: linear-gradient(135deg, #8c3e11, #d96a1d); }
.theme-green { background: linear-gradient(135deg, #0d4736, #167b58); }
.theme-blue { background: linear-gradient(135deg, #0b2f50, #1c648f); }
.theme-red { background: linear-gradient(135deg, #6f292c, #a8413e); }
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.stat { border-left: 1px solid var(--line); padding: 20px 23px; }
.stat:last-child { border-right: 1px solid var(--line); }
.stat strong { color: var(--navy-900); display: block; font: 800 23px/1 "Manrope", Arial; letter-spacing: -1px; }
.stat span { color: var(--muted); font-size: 9px; font-weight: 800; letter-spacing: .45px; text-transform: uppercase; }
.section { padding: 68px 0; }
.section-white { background: var(--white); }
.section-navy { background: var(--navy-900); color: var(--white); }
.section-heading { align-items: end; display: flex; justify-content: space-between; margin-bottom: 23px; }
.section-heading h2, .page-hero h1, .content-card h1 { color: var(--navy-900); font: 800 29px/1.18 "Manrope", Arial; letter-spacing: -1.3px; margin: 8px 0 4px; }
.section-navy .section-heading h2 { color: var(--white); }
.section-heading p:not(.section-kicker), .page-hero p, .content-card p { color: var(--muted); font-size: 13px; line-height: 1.6; margin: 0; }
.section-navy .section-heading p:not(.section-kicker) { color: #abc0cf; }
.text-link { color: var(--saffron-dark); font-size: 11px; font-weight: 800; }
.issue-grid, .campaign-grid, .score-grid, .watch-grid { display: grid; gap: 15px; grid-template-columns: repeat(3, 1fr); }
.issue-card, .content-card, .score-card, .watch-card { background: var(--white); border: 1px solid var(--line); border-radius: 11px; overflow: hidden; }
.issue-card-image { background-image: linear-gradient(145deg, rgba(6,23,43,.03), rgba(6,23,43,.34)), url("../civic-issues-strip.png"); background-size: cover, 400% 100%; height: 115px; }
.issue-card:nth-child(2) .issue-card-image { background-position: center, 33.333% center; }
.issue-card:nth-child(3) .issue-card-image { background-position: center, 66.666% center; }
.issue-card-body { padding: 14px; }
.issue-card h3 { color: var(--navy-900); font: 800 14px/1.38 "Manrope", Arial; letter-spacing: -.3px; margin: 7px 0; }
.card-foot { align-items: center; display: flex; justify-content: space-between; margin-top: 13px; }
.status { border-radius: 30px; display: inline-flex; font-size: 9px; font-weight: 800; padding: 5px 8px; }
.status-orange { background: var(--saffron-soft); color: var(--saffron-dark); }
.status-green { background: var(--green-soft); color: #11764e; }
.status-red { background: var(--red-soft); color: var(--red); }
.status-blue { background: var(--blue-soft); color: #28749d; }
.campaign-card { border-radius: 13px; color: var(--white); min-height: 178px; padding: 20px; position: relative; }
.campaign-card h3 { font: 800 22px/1.1 "Manrope", Arial; letter-spacing: -.8px; margin: 12px 0 8px; }
.campaign-card p { color: rgba(255,255,255,.76); font-size: 12px; line-height: 1.5; margin: 0 0 15px; }
.campaign-card .button { background: rgba(255,255,255,.15); border: 1px solid rgba(255,255,255,.27); }
.campaign-orange { background: linear-gradient(135deg, #d96419, #f3993c); }
.campaign-red { background: linear-gradient(135deg, #9f3032, #db5750); }
.campaign-blue { background: linear-gradient(135deg, #16446a, #2677a7); }
.score-card, .watch-card { padding: 17px; }
.movement-grid { display: grid; gap: 13px; grid-template-columns: repeat(4, 1fr); }
.movement-card { background: var(--white); border: 1px solid var(--line); border-radius: 11px; padding: 17px; }
.movement-card span { color: var(--saffron); font: 800 12px/1 "Manrope", Arial; }
.movement-card h3 { color: var(--navy-900); font: 800 15px/1.25 "Manrope", Arial; margin: 12px 0 6px; }
.movement-card p { color: var(--muted); font-size: 11px; line-height: 1.5; min-height: 48px; }
.score-head { align-items: center; display: flex; justify-content: space-between; }
.score-card h3, .watch-card h3 { color: var(--navy-900); font: 800 16px/1.2 "Manrope", Arial; margin: 5px 0; }
.score-number { align-items: center; background: var(--green-soft); border-radius: 50%; color: var(--green); display: flex; font: 800 19px/1 "Manrope", Arial; height: 51px; justify-content: center; width: 51px; }
.score-card p, .watch-card p { color: var(--muted); font-size: 11px; line-height: 1.5; }
.watch-grid { grid-template-columns: repeat(4, 1fr); }
.watch-card b { color: var(--saffron-dark); display: block; font-size: 11px; margin-top: 13px; }
.legal-strip { background: var(--saffron-soft); border: 1px solid #f5dac2; border-radius: 14px; display: grid; gap: 24px; grid-template-columns: 1fr 1.2fr; padding: 25px; }
.legal-strip h2 { color: var(--navy-900); font: 800 24px/1.2 "Manrope", Arial; letter-spacing: -.8px; margin: 7px 0; }
.legal-strip p, .legal-strip li { color: var(--muted); font-size: 12px; line-height: 1.55; }
.legal-strip ul { margin: 0; padding-left: 18px; }
.page-hero { background: var(--navy-950); color: var(--white); padding: 46px 0; }
.page-hero h1 { color: var(--white); font-size: 36px; margin-top: 9px; }
.page-hero p { color: #b6c7d4; max-width: 730px; }
.page-shell { margin: 0 auto; max-width: 1060px; padding: 40px 20px 70px; }
.two-column { align-items: start; display: grid; gap: 20px; grid-template-columns: 1fr 300px; }
.content-card { padding: 20px; }
.narrow-card { margin: 0 auto; max-width: 730px; }
.form-grid { display: grid; gap: 12px; grid-template-columns: repeat(2, 1fr); }
.full { grid-column: 1 / -1; }
label, legend { color: var(--navy-800); display: block; font-size: 11px; font-weight: 800; }
input, select, textarea { background: var(--white); border: 1px solid #d8e0e2; border-radius: 6px; color: var(--ink); display: block; font-size: 12px; margin-top: 6px; outline: none; padding: 11px; width: 100%; }
input:focus, select:focus, textarea:focus { border-color: var(--saffron); box-shadow: 0 0 0 3px rgba(239,125,36,.12); }
textarea { line-height: 1.5; resize: vertical; }
.checkbox-row { align-items: flex-start; display: flex; font-size: 11px; gap: 8px; line-height: 1.45; margin-top: 9px; }
.checkbox-row input { flex: 0 0 auto; margin: 2px 0 0; width: auto; }
.consent-box { background: #fafbfa; border: 1px solid var(--line); border-radius: 8px; margin: 18px 0; padding: 14px; }
.consent-box legend { background: var(--white); padding: 0 5px; }
.helper { color: var(--muted); font-size: 10px; line-height: 1.5; margin-top: 6px; }
.alert { border-radius: 7px; font-size: 12px; line-height: 1.5; margin-bottom: 15px; padding: 12px 14px; }
.alert ul { margin: 7px 0 0; padding-left: 17px; }
.alert-danger { background: var(--red-soft); color: #9e3834; }
.alert-info { background: var(--blue-soft); color: #245e7c; }
.info-panel { background: var(--navy-900); border-radius: 11px; color: var(--white); padding: 18px; }
.info-panel h3 { font: 800 18px/1.25 "Manrope", Arial; margin: 7px 0; }
.info-panel p, .info-panel li { color: #b4c7d5; font-size: 11px; line-height: 1.55; }
.info-panel ul { padding-left: 16px; }
.success-card { text-align: center; }
.success-mark { align-items: center; background: var(--green-soft); border-radius: 50%; color: var(--green); display: flex; font-size: 24px; height: 54px; justify-content: center; margin: 0 auto 10px; width: 54px; }
.report-code { color: var(--navy-900); font: 800 25px/1 "Manrope", Arial; letter-spacing: -1px; margin: 14px 0; }
.file-grid { display: grid; gap: 12px; grid-template-columns: 1fr 1fr; margin-top: 16px; }
.data-row { border-bottom: 1px solid var(--line); display: grid; gap: 13px; grid-template-columns: 170px 1fr; padding: 10px 0; }
.data-row span { color: var(--muted); font-size: 11px; font-weight: 800; }
.data-row strong { color: var(--navy-900); font-size: 12px; }
.admin-shell { margin: 0 auto; max-width: 1250px; padding: 28px 20px 70px; }
.admin-grid { display: grid; gap: 12px; grid-template-columns: repeat(4, 1fr); margin: 17px 0 25px; }
.admin-stat { background: var(--white); border: 1px solid var(--line); border-radius: 9px; padding: 15px; }
.admin-stat strong { color: var(--navy-900); display: block; font: 800 25px/1 "Manrope", Arial; }
.admin-stat span { color: var(--muted); font-size: 9px; font-weight: 800; text-transform: uppercase; }
.table-wrap { overflow: auto; }
table { border-collapse: collapse; min-width: 780px; width: 100%; }
th, td { border-bottom: 1px solid var(--line); font-size: 11px; padding: 10px 8px; text-align: left; vertical-align: top; }
th { color: var(--muted); font-size: 9px; letter-spacing: .55px; text-transform: uppercase; }
td strong { color: var(--navy-900); }
code, pre { background: #f3f5f5; border-radius: 5px; font-family: Consolas, monospace; font-size: 11px; padding: 2px 4px; }
pre { line-height: 1.6; overflow: auto; padding: 13px; white-space: pre-wrap; }
.toolbar { align-items: center; display: flex; flex-wrap: wrap; gap: 8px; justify-content: space-between; margin-bottom: 13px; }
.toolbar div { display: flex; flex-wrap: wrap; gap: 7px; }
.inline-form { align-items: end; display: grid; gap: 9px; grid-template-columns: 1fr 1fr auto; margin-top: 13px; }
footer { background: var(--navy-950); color: #a1b2c0; padding: 31px 0 18px; }
.footer-top { align-items: center; display: flex; justify-content: space-between; }
.footer-brand strong { color: var(--white); }
.hashtags { display: flex; flex-wrap: wrap; gap: 11px; }
.hashtags b { color: #83cfa1; font-size: 10px; }
.footer-disclaimer { border-top: 1px solid rgba(255,255,255,.11); color: #91a5b5; font-size: 10px; line-height: 1.55; margin: 22px 0 0; padding-top: 16px; }
.footer-bottom { display: flex; font-size: 10px; justify-content: space-between; margin-top: 15px; }

@media (max-width: 900px) {
  .desktop-nav { display: none; }
  .hero-grid { gap: 30px; grid-template-columns: 1fr; }
  .hero-panel { max-width: 580px; }
  .issue-grid, .campaign-grid, .score-grid { grid-template-columns: repeat(2, 1fr); }
  .movement-grid { grid-template-columns: repeat(2, 1fr); }
  .watch-grid { grid-template-columns: repeat(2, 1fr); }
  .two-column { grid-template-columns: 1fr; }
  .info-panel { order: -1; }
}

@media (max-width: 570px) {
  .container { padding: 0 15px; }
  .header-inner { height: 63px; }
  .brand-mark { height: 37px; width: 39px; }
  .brand strong { font-size: 14px; }
  .brand small { font-size: 6px; }
  .site-header .primary-button { font-size: 10px; min-height: 36px; padding: 0 10px; }
  .hero { padding: 48px 0 36px; }
  .hero h1 { font-size: 49px; letter-spacing: -3px; }
  .hero p:not(.eyebrow) { font-size: 13px; }
  .hero-actions { display: grid; grid-template-columns: 1fr 1fr; }
  .hero-actions .button { padding: 0 8px; }
  .hero-image { height: 154px; }
  .hero-panel h2 { font-size: 16px; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .stat { border-bottom: 1px solid var(--line); padding: 15px; }
  .stat strong { font-size: 20px; }
  .section { padding: 48px 0; }
  .section-heading h2 { font-size: 24px; }
  .section-heading .text-link { display: none; }
  .issue-grid, .campaign-grid, .score-grid, .watch-grid, .form-grid, .file-grid { grid-template-columns: 1fr; }
  .movement-grid { grid-template-columns: 1fr; }
  .carousel-slide { min-height: 225px; padding: 18px; }
  .carousel-slide h3 { font-size: 23px; }
  .legal-strip { grid-template-columns: 1fr; padding: 18px; }
  .full { grid-column: auto; }
  .page-hero { padding: 35px 0; }
  .page-hero h1 { font-size: 30px; }
  .page-shell { padding: 25px 14px 55px; }
  .content-card { padding: 16px; }
  .data-row { gap: 4px; grid-template-columns: 1fr; }
  .admin-grid { grid-template-columns: repeat(2, 1fr); }
  .inline-form { grid-template-columns: 1fr; }
  .footer-top, .footer-bottom { align-items: flex-start; flex-direction: column; gap: 12px; }
}
