/* index(23).html */
:root {
    --bg: #0d0f12;
    --bg2: #141720;
    --bg3: #1c2030;
    --accent: #4fc38a;
    --accent2: #2a7a55;
    --accent-dim: rgba(79,195,138,0.12);
    --accent-border: rgba(79,195,138,0.25);
    --text: #e8eaf0;
    --text2: #8b909e;
    --text3: #555b6e;
    --border: rgba(255,255,255,0.07);
    --border2: rgba(255,255,255,0.12);
    --red: #e05555;
    --amber: #d4943a;
    --blue: #4a8fd4;
    --radius: 10px;
    --radius-lg: 16px;
  }
  * { margin: 0; padding: 0; box-sizing: border-box; }
  html { scroll-behavior: smooth; }
  body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;
    background: var(--bg);
    color: var(--text);
    font-size: 16px;
    line-height: 1.7;
    overflow-x: hidden;
  }
  h1,h2,h3,h4,h5 { font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif; line-height: 1.2; }

  /* NAV */
  nav {
    position: fixed; top: 0; left: 0; right: 0; z-index: 100;
    background: rgba(13,15,18,0.92);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--border);
    padding: 0 2rem;
    height: 60px;
    display: flex; align-items: center; justify-content: space-between;
  }
  .nav-logo {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;
    font-size: 22px; font-weight: 800;
    color: var(--text);
    text-decoration: none;
    letter-spacing: -0.2px;
  }
  .nav-logo span { color: var(--accent); }
  .nav-links { display: flex; gap: 2rem; list-style: none; }
  .nav-links a {
    color: var(--text2); text-decoration: none;
    font-size: 14px; font-weight: 500;
    transition: color 0.2s;
  }
  .nav-links a:hover { color: var(--accent); }
  .nav-cta {
    background: var(--accent);
    color: #0d1a12;
    padding: 8px 18px;
    border-radius: var(--radius);
    font-size: 14px; font-weight: 700;
    text-decoration: none;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;
    transition: opacity 0.2s;
  }
  .nav-cta:hover { opacity: 0.85; }

  /* HERO */
  .hero {
    min-height: 100vh;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    text-align: center;
    padding: 100px 2rem 60px;
    position: relative;
    overflow: hidden;
  }
  .hero-grid {
    position: absolute; inset: 0; pointer-events: none;
    background-image:
      linear-gradient(rgba(79,195,138,0.04) 1px, transparent 1px),
      linear-gradient(90deg, rgba(79,195,138,0.04) 1px, transparent 1px);
    background-size: 60px 60px;
    mask-image: radial-gradient(ellipse 80% 60% at 50% 40%, black 30%, transparent 80%);
  }
  .hero-badge {
    display: inline-flex; align-items: center; gap: 8px;
    background: var(--accent-dim);
    border: 1px solid var(--accent-border);
    color: var(--accent);
    padding: 6px 16px; border-radius: 999px;
    font-size: 13px; font-weight: 500;
    margin-bottom: 2rem;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;
  }
  .hero-badge::before {
    content: '';
    width: 6px; height: 6px;
    background: var(--accent);
    border-radius: 50%;
    display: inline-block;
  }
  .hero h1 {
    font-size: clamp(42px, 7vw, 80px);
    font-weight: 800;
    color: var(--text);
    letter-spacing: -0.8px;
    margin-bottom: 1.5rem;
    max-width: 900px;
  }
  .hero h1 .accent { color: var(--accent); }
  .hero p {
    font-size: 18px;
    color: var(--text2);
    max-width: 560px;
    margin: 0 auto 2.5rem;
    font-weight: 300;
    line-height: 1.8;
  }
  .hero-actions { display: flex; gap: 1rem; flex-wrap: wrap; justify-content: center; }
  .btn-primary {
    background: var(--accent);
    color: #0a1a10;
    padding: 14px 28px;
    border-radius: var(--radius);
    font-size: 15px; font-weight: 700;
    text-decoration: none;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;
    transition: opacity 0.2s, transform 0.2s;
    display: inline-block;
  }
  .btn-primary:hover { opacity: 0.88; transform: translateY(-1px); }
  .btn-secondary {
    background: transparent;
    color: var(--text);
    padding: 14px 28px;
    border-radius: var(--radius);
    font-size: 15px; font-weight: 500;
    text-decoration: none;
    border: 1px solid var(--border2);
    transition: border-color 0.2s, transform 0.2s;
    display: inline-block;
  }
  .btn-secondary:hover { border-color: var(--accent); transform: translateY(-1px); }
  .hero-stats {
    display: flex; gap: 3rem; margin-top: 4rem;
    flex-wrap: wrap; justify-content: center;
  }
  .stat { text-align: center; }
  .stat-num {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;
    font-size: 32px; font-weight: 800;
    color: var(--accent);
    display: block;
  }
  .stat-label { font-size: 13px; color: var(--text3); }

  /* SECTION BASE */
  section { padding: 80px 2rem; }
  .container { max-width: 1100px; margin: 0 auto; }
  .section-label {
    font-size: 12px; font-weight: 700; letter-spacing: 2px;
    color: var(--accent); text-transform: uppercase;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;
    margin-bottom: 0.75rem;
  }
  .section-title {
    font-size: clamp(28px, 4vw, 42px);
    font-weight: 800; letter-spacing: -0.4px;
    color: var(--text);
    margin-bottom: 1rem;
  }
  .section-sub {
    font-size: 17px; color: var(--text2);
    max-width: 560px;
    line-height: 1.8; font-weight: 300;
  }

  /* FEATURES */
  .features-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 1.5rem;
    margin-top: 3rem;
  }
  .feature-card {
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 1.75rem;
    transition: border-color 0.2s, transform 0.2s;
  }
  .feature-card:hover { border-color: var(--accent-border); transform: translateY(-2px); }
  .feature-icon {
    width: 44px; height: 44px;
    background: var(--accent-dim);
    border: 1px solid var(--accent-border);
    border-radius: var(--radius);
    display: flex; align-items: center; justify-content: center;
    margin-bottom: 1.25rem;
    font-size: 20px;
  }
  .feature-card h3 {
    font-size: 17px; font-weight: 700;
    color: var(--text);
    margin-bottom: 0.5rem;
  }
  .feature-card p { font-size: 14px; color: var(--text2); line-height: 1.7; }

  /* STATE LOOKUP */
  .lookup-section { background: var(--bg2); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
  .lookup-box {
    background: var(--bg3);
    border: 1px solid var(--border2);
    border-radius: var(--radius-lg);
    padding: 2.5rem;
    max-width: 700px;
    margin: 3rem auto 0;
  }
  .lookup-box h3 {
    font-size: 22px; font-weight: 700; margin-bottom: 0.5rem;
  }
  .lookup-box p { font-size: 14px; color: var(--text2); margin-bottom: 1.5rem; }
  .lookup-row { display: flex; gap: 1rem; flex-wrap: wrap; }
  .lookup-row select, .lookup-row input {
    flex: 1; min-width: 160px;
    background: var(--bg);
    border: 1px solid var(--border2);
    color: var(--text);
    padding: 12px 16px;
    border-radius: var(--radius);
    font-size: 15px;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;
    outline: none;
    transition: border-color 0.2s;
    appearance: none;
  }
  .lookup-row select:focus, .lookup-row input:focus { border-color: var(--accent); }
  .lookup-row select option { background: var(--bg2); }
  .lookup-btn {
    background: var(--accent);
    color: #0a1a10;
    border: none;
    padding: 12px 24px;
    border-radius: var(--radius);
    font-size: 15px; font-weight: 700;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;
    cursor: pointer;
    white-space: nowrap;
    transition: opacity 0.2s;
  }
  .lookup-btn:hover { opacity: 0.85; }
  .topic-chips { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 1.25rem; }
  .chip {
    background: var(--bg);
    border: 1px solid var(--border2);
    color: var(--text2);
    padding: 6px 14px;
    border-radius: 999px;
    font-size: 13px;
    cursor: pointer;
    transition: all 0.2s;
  }
  .chip:hover, .chip.active { background: var(--accent-dim); border-color: var(--accent); color: var(--accent); }

  /* COMMUNITY */
  .posts-grid {
    display: grid; gap: 1rem;
    margin-top: 3rem;
  }
  .post-card {
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 1.5rem;
    display: flex; gap: 1.25rem;
    transition: border-color 0.2s;
  }
  .post-card:hover { border-color: var(--border2); }
  .post-vote {
    display: flex; flex-direction: column; align-items: center; gap: 4px;
    min-width: 40px;
  }
  .vote-btn {
    background: var(--bg3); border: 1px solid var(--border);
    color: var(--text3); width: 32px; height: 32px;
    border-radius: 8px; cursor: pointer; font-size: 14px;
    display: flex; align-items: center; justify-content: center;
    transition: all 0.2s;
  }
  .vote-btn:hover { border-color: var(--accent); color: var(--accent); }
  .vote-count { font-size: 13px; font-weight: 700; color: var(--text2); }
  .post-body { flex: 1; }
  .post-meta { display: flex; align-items: center; gap: 8px; margin-bottom: 0.5rem; flex-wrap: wrap; }
  .post-tag {
    font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px;
    padding: 3px 10px; border-radius: 999px;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;
  }
  .tag-travel { background: rgba(74,143,212,0.15); color: var(--blue); }
  .tag-housing { background: rgba(212,148,58,0.15); color: var(--amber); }
  .tag-employment { background: rgba(79,195,138,0.15); color: var(--accent); }
  .tag-legal { background: rgba(224,85,85,0.15); color: var(--red); }
  .post-state {
    font-size: 12px; color: var(--text3);
    background: var(--bg3);
    padding: 3px 10px; border-radius: 999px;
    border: 1px solid var(--border);
  }
  .post-card h4 { font-size: 16px; font-weight: 500; color: var(--text); margin-bottom: 0.4rem; }
  .post-card p { font-size: 14px; color: var(--text2); line-height: 1.6; }
  .post-footer { display: flex; gap: 1rem; margin-top: 0.75rem; font-size: 13px; color: var(--text3); }
  .post-footer span { display: flex; align-items: center; gap: 4px; }

  /* LAW STATUS INDICATORS */
  .dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; flex-shrink: 0; }
  .dot-red { background: var(--red); }
  .dot-amber { background: var(--amber); }
  .dot-green { background: var(--accent); }

  /* DONATE */
  .donate-section { background: var(--bg); }
  .donate-box {
    background: var(--bg2);
    border: 1px solid var(--accent-border);
    border-radius: var(--radius-lg);
    padding: 3rem;
    text-align: center;
    max-width: 600px;
    margin: 0 auto;
    position: relative;
    overflow: hidden;
  }
  .donate-box::before {
    content: '';
    position: absolute; top: 0; left: 0; right: 0; height: 2px;
    background: linear-gradient(90deg, transparent, var(--accent), transparent);
  }
  .donate-box h2 { font-size: 28px; font-weight: 800; margin-bottom: 1rem; }
  .donate-box p { color: var(--text2); margin-bottom: 2rem; font-weight: 300; }
  .donate-amounts { display: flex; gap: 0.75rem; justify-content: center; flex-wrap: wrap; margin-bottom: 1.5rem; }
  .amount-btn {
    background: var(--bg3);
    border: 1px solid var(--border2);
    color: var(--text);
    padding: 10px 20px;
    border-radius: var(--radius);
    font-size: 15px; font-weight: 700;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;
    cursor: pointer;
    transition: all 0.2s;
  }
  .amount-btn:hover, .amount-btn.active { background: var(--accent-dim); border-color: var(--accent); color: var(--accent); }
  .donate-note { font-size: 13px; color: var(--text3); margin-top: 1rem; }

  /* FOOTER */
  footer {
    background: var(--bg2);
    border-top: 1px solid var(--border);
    padding: 3rem 2rem;
  }
  .footer-inner {
    max-width: 1100px; margin: 0 auto;
    display: flex; justify-content: space-between; align-items: center;
    flex-wrap: wrap; gap: 1.5rem;
  }
  .footer-logo { font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif; font-size: 20px; font-weight: 800; }
  .footer-logo span { color: var(--accent); }
  .footer-links { display: flex; gap: 1.5rem; flex-wrap: wrap; }
  .footer-links a { font-size: 14px; color: var(--text3); text-decoration: none; transition: color 0.2s; }
  .footer-links a:hover { color: var(--accent); }
  .footer-disclaimer { font-size: 12px; color: var(--text3); max-width: 1100px; margin: 1.5rem auto 0; padding-top: 1.5rem; border-top: 1px solid var(--border); }

  /* SUBMIT FORM */
  .submit-section { background: var(--bg2); border-top: 1px solid var(--border); }
  .submit-form {
    background: var(--bg3);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 2rem;
    max-width: 700px;
    margin: 3rem auto 0;
  }
  .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-bottom: 1rem; }
  .form-group { display: flex; flex-direction: column; gap: 6px; margin-bottom: 1rem; }
  .form-group label { font-size: 13px; font-weight: 500; color: var(--text2); font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif; }
  .form-group input, .form-group select, .form-group textarea {
    background: var(--bg);
    border: 1px solid var(--border2);
    color: var(--text);
    padding: 11px 14px;
    border-radius: var(--radius);
    font-size: 14px;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;
    outline: none;
    transition: border-color 0.2s;
    resize: vertical;
  }
  .form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color: var(--accent); }
  .form-group select option { background: var(--bg2); }

  /* MOBILE */
  @media (max-width: 640px) {
    nav { padding: 0 1rem; }
    .nav-links { display: none; }
    .hero h1 { letter-spacing: -0.4px; }
    .hero-stats { gap: 2rem; }
    .form-row { grid-template-columns: 1fr; }
    .lookup-row { flex-direction: column; }
    .footer-inner { flex-direction: column; align-items: flex-start; }
  }

/* states.html */
:root {
    --bg:#0d0f12;--bg2:#141720;--bg3:#1c2030;--bg4:#222638;
    --accent:#4fc38a;--accent-dim:rgba(79,195,138,0.12);--accent-border:rgba(79,195,138,0.25);
    --text:#e8eaf0;--text2:#8b909e;--text3:#555b6e;
    --border:rgba(255,255,255,0.07);--border2:rgba(255,255,255,0.12);
    --red:#e05555;--red-dim:rgba(224,85,85,0.12);
    --amber:#d4943a;--amber-dim:rgba(212,148,58,0.12);
    --blue:#4a8fd4;--blue-dim:rgba(74,143,212,0.12);
    --purple:#9b72e8;--purple-dim:rgba(155,114,232,0.12);
    --radius:10px;--radius-lg:16px;
  }
  *{margin:0;padding:0;box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;background:var(--bg);color:var(--text);font-size:16px;line-height:1.7;overflow-x:hidden;}
  h1,h2,h3,h4,h5{font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;line-height:1.2;}
  nav{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(13,15,18,0.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:0 2rem;height:60px;display:flex;align-items:center;justify-content:space-between;}
  .nav-logo{font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;font-size:22px;font-weight:800;color:var(--text);text-decoration:none;letter-spacing:-0.2px;}
  .nav-logo span{color:var(--accent);}
  .nav-links{display:flex;gap:2rem;list-style:none;}
  .nav-links a{color:var(--text2);text-decoration:none;font-size:14px;font-weight:500;transition:color 0.2s;}
  .nav-links a:hover,.nav-links a.active{color:var(--accent);}
  .nav-cta{background:var(--accent);color:#0d1a12;padding:8px 18px;border-radius:var(--radius);font-size:14px;font-weight:700;text-decoration:none;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;}
  .page-header{padding:100px 2rem 40px;border-bottom:1px solid var(--border);background:var(--bg2);}
  .page-header .container{max-width:1200px;margin:0 auto;}
  .breadcrumb{font-size:13px;color:var(--text3);margin-bottom:1rem;display:flex;align-items:center;gap:8px;}
  .breadcrumb a{color:var(--accent);text-decoration:none;}
  .page-header h1{font-size:clamp(32px,5vw,52px);font-weight:800;letter-spacing:-0.6px;margin-bottom:0.75rem;}
  .page-header p{font-size:17px;color:var(--text2);font-weight:300;max-width:600px;}
  .disclaimer-banner{background:rgba(212,148,58,0.08);border:1px solid rgba(212,148,58,0.2);border-radius:var(--radius);padding:12px 18px;margin-top:1.5rem;font-size:13px;color:var(--amber);line-height:1.6;max-width:800px;}
  .main{max-width:1200px;margin:0 auto;padding:2.5rem 2rem;display:grid;grid-template-columns:240px 1fr;gap:2.5rem;}

  /* SIDEBAR */
  .sidebar{position:sticky;top:80px;align-self:start;max-height:calc(100vh - 100px);display:flex;flex-direction:column;}
  .sidebar-label{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--text3);font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;margin-bottom:0.75rem;padding:0 4px;}
  .state-search{position:relative;margin-bottom:0.75rem;flex-shrink:0;}
  .state-search input{width:100%;background:var(--bg3);border:1px solid var(--border2);color:var(--text);padding:9px 14px 9px 34px;border-radius:var(--radius);font-size:13px;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;outline:none;transition:border-color 0.2s;}
  .state-search input:focus{border-color:var(--accent);}
  .state-search input::placeholder{color:var(--text3);}
  .search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);font-size:12px;color:var(--text3);pointer-events:none;}
  .state-list{overflow-y:auto;flex:1;padding-right:4px;}
  .state-list::-webkit-scrollbar{width:3px;}
  .state-list::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px;}
  .state-tab{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius);cursor:pointer;transition:all 0.15s;border:1px solid transparent;margin-bottom:2px;}
  .state-tab:hover{background:var(--bg3);}
  .state-tab.active{background:var(--accent-dim);border-color:var(--accent-border);}
  .state-abbr{font-size:11px;font-weight:800;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;width:26px;text-align:center;color:var(--text3);flex-shrink:0;}
  .state-tab.active .state-abbr,.state-tab.live .state-abbr{color:var(--accent);}
  .state-tab-name{font-size:13px;font-weight:500;color:var(--text);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .state-tab.active .state-tab-name{color:var(--accent);}
  .status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;}
  .dot-live{background:var(--accent);}
  .dot-soon{background:var(--text3);}
  .contribute-box{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;margin-top:1rem;flex-shrink:0;}
  .contribute-box h4{font-size:13px;font-weight:700;margin-bottom:0.3rem;}
  .contribute-box p{font-size:12px;color:var(--text2);margin-bottom:0.75rem;line-height:1.5;}
  .contribute-btn{display:block;text-align:center;background:var(--accent-dim);border:1px solid var(--accent-border);color:var(--accent);padding:8px 14px;border-radius:var(--radius);font-size:12px;font-weight:700;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;text-decoration:none;transition:all 0.2s;}
  .contribute-btn:hover{background:var(--accent);color:#0a1a10;}

  /* CONTENT */
  .content{min-width:0;}
  .state-panel{display:none;}
  .state-panel.active{display:block;}

  /* STATE HEADER */
  .state-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border);flex-wrap:wrap;}
  .state-emblem{width:60px;height:60px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:900;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;flex-shrink:0;}
  .emblem-wa{background:#1a3a5c;color:#5bc4a0;}
  .emblem-nv{background:#1a2a1a;color:#7acc7a;}
  .state-header-text h2{font-size:28px;font-weight:800;letter-spacing:-0.2px;}
  .state-header-text p{font-size:13px;color:var(--text2);margin-top:4px;}
  .state-badges{display:flex;gap:8px;flex-wrap:wrap;margin-left:auto;}
  .badge{padding:5px 12px;border-radius:999px;font-size:12px;font-weight:700;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;}
  .badge-strict{background:var(--red-dim);color:var(--red);border:1px solid rgba(224,85,85,0.2);}
  .badge-tiered{background:var(--blue-dim);color:var(--blue);border:1px solid rgba(74,143,212,0.2);}
  .badge-moderate{background:var(--amber-dim);color:var(--amber);border:1px solid rgba(212,148,58,0.2);}

  /* PROGRESS */
  .progress-row{display:flex;align-items:center;gap:12px;margin-bottom:2rem;padding:1rem 1.25rem;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);}
  .progress-bar-wrap{flex:1;background:var(--bg4);border-radius:999px;height:6px;overflow:hidden;}
  .progress-bar-fill{height:100%;border-radius:999px;background:var(--accent);}
  .progress-label{font-size:12px;color:var(--text2);white-space:nowrap;}
  .progress-label span{color:var(--accent);font-weight:700;}

  /* CATEGORY BLOCKS */
  .cat-block{margin-bottom:1rem;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg2);}
  .cat-block-header{padding:1.1rem 1.5rem;display:flex;align-items:center;gap:1rem;cursor:pointer;transition:background 0.15s;user-select:none;}
  .cat-block-header:hover{background:var(--bg3);}
  .cat-block.open .cat-block-header{background:var(--bg3);border-bottom:1px solid var(--border);}
  .cat-number{width:30px;height:30px;border-radius:var(--radius);background:var(--bg4);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;color:var(--text3);flex-shrink:0;}
  .cat-block.open .cat-number{background:var(--accent-dim);border-color:var(--accent-border);color:var(--accent);}
  .cat-header-text{flex:1;}
  .cat-header-text h3{font-size:15px;font-weight:700;color:var(--text);margin-bottom:2px;}
  .cat-summary{font-size:12px;color:var(--text2);line-height:1.4;}
  .status-pill{padding:3px 10px;border-radius:999px;font-size:11px;font-weight:700;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;white-space:nowrap;flex-shrink:0;}
  .pill-strict{background:var(--red-dim);color:var(--red);}
  .pill-moderate{background:var(--amber-dim);color:var(--amber);}
  .pill-good{background:var(--accent-dim);color:var(--accent);}
  .pill-none{background:var(--bg4);color:var(--text3);border:1px solid var(--border2);}
  .pill-varies{background:var(--purple-dim);color:var(--purple);}
  .pill-note{background:var(--blue-dim);color:var(--blue);}
  .cat-toggle{font-size:11px;color:var(--text3);transition:transform 0.2s;flex-shrink:0;}
  .cat-block.open .cat-toggle{transform:rotate(180deg);}

  /* CAT BODY */
  .cat-body{display:none;padding:1.5rem;}
  .cat-block.open .cat-body{display:block;}
  .detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem;}
  .detail-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;}
  .detail-card.full{grid-column:1/-1;}
  .detail-label{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text3);font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;margin-bottom:6px;}
  .detail-card p{font-size:13px;color:var(--text2);line-height:1.6;}
  .detail-card ul{padding-left:1.1rem;}
  .detail-card ul li{font-size:13px;color:var(--text2);line-height:1.7;}
  .detail-value{font-size:22px;font-weight:800;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;color:var(--text);margin-bottom:4px;}
  .detail-value.red{color:var(--red);}
  .detail-value.amber{color:var(--amber);}
  .detail-value.green{color:var(--accent);}
  .detail-value.blue{color:var(--blue);}
  .community-note{background:var(--bg4);border-left:3px solid var(--accent);border-radius:0 var(--radius) var(--radius) 0;padding:0.875rem 1rem;margin-top:0.75rem;}
  .cn-label{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;margin-bottom:5px;}
  .community-note p{font-size:13px;color:var(--text2);line-height:1.6;}
  .cn-meta{font-size:12px;color:var(--text3);margin-top:5px;}
  .empty-note{background:var(--bg4);border:1px dashed var(--border2);border-radius:var(--radius);padding:0.875rem 1.25rem;margin-top:0.75rem;text-align:center;}
  .empty-note p{font-size:13px;color:var(--text3);}
  .empty-note a{color:var(--accent);text-decoration:none;}

  /* COMING SOON */
  .coming-soon-panel{text-align:center;padding:5rem 2rem;}
  .cs-icon{font-size:48px;margin-bottom:1.5rem;opacity:0.35;}
  .coming-soon-panel h2{font-size:28px;font-weight:800;letter-spacing:-0.2px;margin-bottom:0.75rem;}
  .coming-soon-panel p{font-size:16px;color:var(--text2);max-width:480px;margin:0 auto 2rem;font-weight:300;line-height:1.8;}
  .cs-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;}
  .btn-primary{background:var(--accent);color:#0a1a10;padding:13px 26px;border-radius:var(--radius);font-size:14px;font-weight:700;text-decoration:none;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;display:inline-block;}
  .btn-secondary{background:transparent;color:var(--text);padding:13px 26px;border-radius:var(--radius);font-size:14px;font-weight:500;text-decoration:none;border:1px solid var(--border2);display:inline-block;}
  .cs-note{display:inline-block;margin-top:2rem;font-size:13px;color:var(--text3);background:var(--bg2);border:1px solid var(--border);padding:10px 18px;border-radius:999px;}
  .last-updated{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text3);margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border);}
  .update-dot{width:6px;height:6px;background:var(--accent);border-radius:50%;flex-shrink:0;}

  @media(max-width:768px){
    .main{grid-template-columns:1fr;}
    .sidebar{position:static;max-height:none;}
    .state-list{max-height:260px;}
    nav{padding:0 1rem;}
    .nav-links{display:none;}
    .detail-grid{grid-template-columns:1fr;}
    .detail-card.full{grid-column:1;}
    .state-badges{margin-left:0;}
  }

/* news.html */
:root {
    --bg:#0d0f12;--bg2:#141720;--bg3:#1c2030;--bg4:#222638;
    --accent:#4fc38a;--accent-dim:rgba(79,195,138,0.12);--accent-border:rgba(79,195,138,0.25);
    --text:#e8eaf0;--text2:#8b909e;--text3:#555b6e;
    --border:rgba(255,255,255,0.07);--border2:rgba(255,255,255,0.12);
    --red:#e05555;--red-dim:rgba(224,85,85,0.12);
    --amber:#d4943a;--amber-dim:rgba(212,148,58,0.12);
    --blue:#4a8fd4;--blue-dim:rgba(74,143,212,0.12);
    --purple:#9b72e8;--purple-dim:rgba(155,114,232,0.12);
    --radius:10px;--radius-lg:16px;
  }
  *{margin:0;padding:0;box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;background:var(--bg);color:var(--text);font-size:16px;line-height:1.7;overflow-x:hidden;}
  h1,h2,h3,h4,h5{font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;line-height:1.2;}

  /* NAV */
  nav{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(13,15,18,0.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:0 2rem;height:60px;display:flex;align-items:center;justify-content:space-between;}
  .nav-logo{font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;font-size:22px;font-weight:800;color:var(--text);text-decoration:none;letter-spacing:-0.2px;}
  .nav-logo span{color:var(--accent);}
  .nav-links{display:flex;gap:2rem;list-style:none;}
  .nav-links a{color:var(--text2);text-decoration:none;font-size:14px;font-weight:500;transition:color 0.2s;}
  .nav-links a:hover,.nav-links a.active{color:var(--accent);}
  .nav-cta{background:var(--accent);color:#0d1a12;padding:8px 18px;border-radius:var(--radius);font-size:14px;font-weight:700;text-decoration:none;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;}

  /* PAGE HEADER */
  .page-header{padding:100px 2rem 50px;border-bottom:1px solid var(--border);background:var(--bg2);position:relative;overflow:hidden;}
  .page-header::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--blue),var(--purple));}
  .page-header .container{max-width:1100px;margin:0 auto;}
  .breadcrumb{font-size:13px;color:var(--text3);margin-bottom:1rem;display:flex;align-items:center;gap:8px;}
  .breadcrumb a{color:var(--accent);text-decoration:none;}
  .header-top{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:1.5rem;}
  .header-left h1{font-size:clamp(32px,5vw,52px);font-weight:800;letter-spacing:-0.6px;margin-bottom:0.75rem;}
  .header-left p{font-size:17px;color:var(--text2);font-weight:300;max-width:560px;}
  .live-badge{display:inline-flex;align-items:center;gap:8px;background:var(--red-dim);border:1px solid rgba(224,85,85,0.25);color:var(--red);padding:8px 16px;border-radius:999px;font-size:13px;font-weight:700;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;white-space:nowrap;}
  .live-dot{width:7px;height:7px;background:var(--red);border-radius:50%;animation:pulse 1.5s infinite;}
  @keyframes pulse{0%,100%{opacity:1;}50%{opacity:0.3;}}

  /* STATS BAR */
  .stats-bar{background:var(--bg3);border-bottom:1px solid var(--border);padding:1rem 2rem;}
  .stats-inner{max-width:1100px;margin:0 auto;display:flex;gap:2.5rem;flex-wrap:wrap;}
  .stat-item{display:flex;align-items:center;gap:10px;}
  .stat-num{font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;font-size:22px;font-weight:800;}
  .stat-num.green{color:var(--accent);}
  .stat-num.blue{color:var(--blue);}
  .stat-num.amber{color:var(--amber);}
  .stat-label{font-size:13px;color:var(--text2);}

  /* MAIN */
  .main{max-width:1100px;margin:0 auto;padding:3rem 2rem;display:grid;grid-template-columns:1fr 320px;gap:2.5rem;}

  /* WINS SECTION */
  .wins-section{margin-bottom:3rem;}
  .section-label{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;margin-bottom:1rem;}
  .label-green{color:var(--accent);}
  .label-blue{color:var(--blue);}
  .label-amber{color:var(--amber);}
  .label-purple{color:var(--purple);}
  .section-title{font-size:24px;font-weight:800;letter-spacing:-0.2px;margin-bottom:0.5rem;}
  .section-sub{font-size:15px;color:var(--text2);margin-bottom:1.5rem;font-weight:300;}

  /* WIN CARDS */
  .wins-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem;margin-bottom:1rem;}
  .win-card{background:var(--bg2);border:1px solid var(--accent-border);border-radius:var(--radius-lg);padding:1.5rem;position:relative;overflow:hidden;transition:transform 0.2s,border-color 0.2s;}
  .win-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),rgba(79,195,138,0.2));}
  .win-card:hover{transform:translateY(-2px);border-color:var(--accent);}
  .win-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:0.75rem;}
  .win-type{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;padding:4px 10px;border-radius:999px;}
  .type-federal{background:var(--accent-dim);color:var(--accent);}
  .type-state{background:var(--blue-dim);color:var(--blue);}
  .type-scotus{background:var(--purple-dim);color:var(--purple);}
  .win-date{font-size:12px;color:var(--text3);}
  .win-card h3{font-size:16px;font-weight:700;color:var(--text);margin-bottom:0.5rem;line-height:1.3;}
  .win-card p{font-size:13px;color:var(--text2);line-height:1.6;margin-bottom:1rem;}
  .win-impact{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--accent);font-weight:500;}
  .win-impact::before{content:'↑';font-weight:800;}
  .win-states{display:flex;gap:6px;flex-wrap:wrap;margin-top:0.75rem;}
  .state-chip{font-size:11px;background:var(--bg3);border:1px solid var(--border2);color:var(--text2);padding:3px 8px;border-radius:999px;}

  /* NEWS FEED */
  .news-feed{display:flex;flex-direction:column;gap:1px;background:var(--border);}
  .news-item{background:var(--bg);padding:1.5rem;transition:background 0.15s;cursor:pointer;position:relative;}
  .news-item:hover{background:var(--bg2);}
  .news-item:first-child{border-radius:var(--radius-lg) var(--radius-lg) 0 0;}
  .news-item:last-child{border-radius:0 0 var(--radius-lg) var(--radius-lg);}
  .news-meta{display:flex;align-items:center;gap:10px;margin-bottom:0.6rem;flex-wrap:wrap;}
  .news-tag{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;padding:3px 10px;border-radius:999px;}
  .tag-ruling{background:var(--accent-dim);color:var(--accent);}
  .tag-legislation{background:var(--blue-dim);color:var(--blue);}
  .tag-alert{background:var(--red-dim);color:var(--red);}
  .tag-community{background:var(--purple-dim);color:var(--purple);}
  .tag-policy{background:var(--amber-dim);color:var(--amber);}
  .news-date{font-size:12px;color:var(--text3);}
  .news-source{font-size:12px;color:var(--text3);}
  .news-item h3{font-size:16px;font-weight:600;color:var(--text);margin-bottom:0.4rem;line-height:1.4;}
  .news-item p{font-size:14px;color:var(--text2);line-height:1.6;}
  .news-expand{display:none;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border);}
  .news-expand.open{display:block;}
  .news-expand p{font-size:14px;color:var(--text2);line-height:1.7;margin-bottom:0.75rem;}
  .news-expand .community-tip{background:var(--bg3);border-left:3px solid var(--purple);border-radius:0 var(--radius) var(--radius) 0;padding:0.875rem 1rem;margin-top:0.75rem;}
  .community-tip-label{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--purple);font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;margin-bottom:5px;}
  .community-tip p{font-size:13px;color:var(--text2);line-height:1.6;}
  .community-tip .tip-meta{font-size:12px;color:var(--text3);margin-top:5px;}
  .read-more{font-size:13px;color:var(--accent);font-weight:500;display:flex;align-items:center;gap:4px;margin-top:0.5rem;background:none;border:none;cursor:pointer;padding:0;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;}
  .community-submitted{position:absolute;top:1.5rem;right:1.5rem;}
  .comm-badge{font-size:11px;color:var(--purple);background:var(--purple-dim);border:1px solid rgba(155,114,232,0.2);padding:3px 8px;border-radius:999px;font-weight:600;}

  /* FILTER BAR */
  .filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:1.5rem;}
  .filter-btn{background:var(--bg2);border:1px solid var(--border2);color:var(--text2);padding:7px 16px;border-radius:999px;font-size:13px;cursor:pointer;transition:all 0.15s;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;}
  .filter-btn:hover,.filter-btn.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent);}

  /* SIDEBAR */
  .sidebar{display:flex;flex-direction:column;gap:1.5rem;}
  .sidebar-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;}
  .sidebar-card h3{font-size:15px;font-weight:700;margin-bottom:1rem;}

  /* TRACKER */
  .tracker-items{display:flex;flex-direction:column;gap:0.75rem;}
  .tracker-item{display:flex;gap:12px;align-items:flex-start;}
  .tracker-status{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:7px;}
  .ts-active{background:var(--amber);}
  .ts-passed{background:var(--accent);}
  .ts-dead{background:var(--red);}
  .ts-watch{background:var(--blue);}
  .tracker-text{}
  .tracker-name{font-size:13px;font-weight:500;color:var(--text);line-height:1.4;}
  .tracker-detail{font-size:12px;color:var(--text3);margin-top:2px;}
  .tracker-badge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px;margin-top:4px;display:inline-block;}
  .tb-active{background:var(--amber-dim);color:var(--amber);}
  .tb-passed{background:var(--accent-dim);color:var(--accent);}
  .tb-dead{background:var(--red-dim);color:var(--red);}
  .tb-watch{background:var(--blue-dim);color:var(--blue);}

  /* SUBMIT TIP */
  .tip-form{display:flex;flex-direction:column;gap:0.75rem;}
  .tip-form input,.tip-form select,.tip-form textarea{background:var(--bg3);border:1px solid var(--border2);color:var(--text);padding:10px 12px;border-radius:var(--radius);font-size:13px;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;outline:none;transition:border-color 0.2s;resize:vertical;}
  .tip-form input:focus,.tip-form select:focus,.tip-form textarea:focus{border-color:var(--accent);}
  .tip-form select option{background:var(--bg2);}
  .tip-form input::placeholder,.tip-form textarea::placeholder{color:var(--text3);}
  .tip-submit{background:var(--accent);color:#0a1a10;border:none;padding:10px 16px;border-radius:var(--radius);font-size:13px;font-weight:700;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;cursor:pointer;transition:opacity 0.2s;}
  .tip-submit:hover{opacity:0.85;}
  .tip-note{font-size:11px;color:var(--text3);text-align:center;}

  /* ALERT BANNER */
  .alert-banner{background:rgba(224,85,85,0.08);border:1px solid rgba(224,85,85,0.2);border-radius:var(--radius);padding:1rem 1.25rem;display:flex;gap:12px;margin-bottom:1.5rem;}
  .alert-banner p{font-size:13px;color:var(--red);line-height:1.6;}

  /* LOAD MORE */
  .load-more{text-align:center;margin-top:1.5rem;}
  .btn-secondary{background:transparent;color:var(--text);padding:12px 24px;border-radius:var(--radius);font-size:14px;font-weight:500;border:1px solid var(--border2);cursor:pointer;transition:border-color 0.2s;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;}
  .btn-secondary:hover{border-color:var(--accent);}

  @media(max-width:768px){
    .main{grid-template-columns:1fr;}
    nav{padding:0 1rem;}
    .nav-links{display:none;}
    .wins-grid{grid-template-columns:1fr;}
  }

/* state-style.css */
:root {
  --bg:#0d0f12;--bg2:#141720;--bg3:#1c2030;--bg4:#222638;
  --accent:#4fc38a;--accent-dim:rgba(79,195,138,0.12);--accent-border:rgba(79,195,138,0.25);
  --text:#e8eaf0;--text2:#8b909e;--text3:#555b6e;
  --border:rgba(255,255,255,0.07);--border2:rgba(255,255,255,0.12);
  --red:#e05555;--red-dim:rgba(224,85,85,0.12);
  --amber:#d4943a;--amber-dim:rgba(212,148,58,0.12);
  --blue:#4a8fd4;--blue-dim:rgba(74,143,212,0.12);
  --purple:#9b72e8;--purple-dim:rgba(155,114,232,0.12);
  --radius:10px;--radius-lg:16px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;background:var(--bg);color:var(--text);font-size:16px;line-height:1.7;overflow-x:hidden;}
h1,h2,h3,h4,h5{font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;line-height:1.2;}
nav{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(13,15,18,0.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:0 2rem;height:60px;display:flex;align-items:center;justify-content:space-between;}
.nav-logo{font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;font-size:22px;font-weight:800;color:var(--text);text-decoration:none;letter-spacing:-0.2px;}
.nav-logo span{color:var(--accent);}
.nav-links{display:flex;gap:2rem;list-style:none;}
.nav-links a{color:var(--text2);text-decoration:none;font-size:14px;font-weight:500;transition:color 0.2s;}
.nav-links a:hover,.nav-links a.active{color:var(--accent);}
.nav-cta{background:var(--accent);color:#0d1a12;padding:8px 18px;border-radius:var(--radius);font-size:14px;font-weight:700;text-decoration:none;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;}
.back-bar{background:var(--bg2);border-top:60px solid transparent;border-bottom:1px solid var(--border);padding:0.75rem 2rem;margin-top:0;}
.back-bar .container{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;}
.back-link{font-size:13px;color:var(--text2);text-decoration:none;display:flex;align-items:center;gap:6px;transition:color 0.2s;}
.back-link:hover{color:var(--accent);}
.state-nav{display:flex;gap:1rem;}
.state-nav a{font-size:13px;color:var(--text2);text-decoration:none;padding:5px 12px;border:1px solid var(--border2);border-radius:999px;transition:all 0.2s;}
.state-nav a:hover{border-color:var(--accent);color:var(--accent);}
.page-header{padding:20px 2rem 40px;border-bottom:1px solid var(--border);background:var(--bg2);}
.page-header .container{max-width:1100px;margin:0 auto;}
.breadcrumb{font-size:13px;color:var(--text3);margin-bottom:1rem;display:flex;align-items:center;gap:8px;}
.breadcrumb a{color:var(--accent);text-decoration:none;}
.state-header{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;}
.state-emblem{width:64px;height:64px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:900;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;flex-shrink:0;}
.state-header-text h1{font-size:clamp(28px,5vw,46px);font-weight:800;letter-spacing:-0.6px;margin-bottom:4px;}
.state-header-text p{font-size:14px;color:var(--text2);font-weight:300;}
.state-badges{display:flex;gap:8px;flex-wrap:wrap;margin-left:auto;}
.badge{padding:5px 14px;border-radius:999px;font-size:12px;font-weight:700;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;}
.badge-strict{background:var(--red-dim);color:var(--red);border:1px solid rgba(224,85,85,0.2);}
.badge-moderate{background:var(--amber-dim);color:var(--amber);border:1px solid rgba(212,148,58,0.2);}
.badge-lenient{background:var(--accent-dim);color:var(--accent);border:1px solid var(--accent-border);}
.badge-tiered{background:var(--blue-dim);color:var(--blue);border:1px solid rgba(74,143,212,0.2);}
.disclaimer-banner{background:rgba(212,148,58,0.08);border:1px solid rgba(212,148,58,0.2);border-radius:var(--radius);padding:12px 18px;margin-top:1.5rem;font-size:13px;color:var(--amber);line-height:1.6;max-width:900px;}
.main{max-width:1100px;margin:0 auto;padding:2.5rem 2rem;display:grid;grid-template-columns:220px 1fr;gap:2.5rem;}
.sidebar{position:sticky;top:80px;align-self:start;}
.sidebar-label{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--text3);font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;margin-bottom:0.75rem;padding:0 4px;}
.cat-nav{display:flex;flex-direction:column;gap:2px;margin-bottom:1.5rem;}
.cat-link{padding:9px 12px;border-radius:var(--radius);font-size:13px;color:var(--text2);cursor:pointer;transition:all 0.15s;display:flex;align-items:center;gap:10px;text-decoration:none;}
.cat-link:hover{background:var(--bg3);color:var(--text);}
.cat-link.active{background:var(--bg3);color:var(--text);}
.progress-box{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1.5rem;}
.progress-box h4{font-size:13px;font-weight:700;margin-bottom:0.75rem;}
.progress-bar-wrap{background:var(--bg4);border-radius:999px;height:6px;margin-bottom:0.5rem;overflow:hidden;}
.progress-bar-fill{height:100%;border-radius:999px;background:var(--accent);}
.progress-label{font-size:12px;color:var(--text3);}
.contribute-box{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;}
.contribute-box h4{font-size:13px;font-weight:700;margin-bottom:0.3rem;}
.contribute-box p{font-size:12px;color:var(--text2);margin-bottom:0.75rem;line-height:1.5;}
.contribute-btn{display:block;text-align:center;background:var(--accent-dim);border:1px solid var(--accent-border);color:var(--accent);padding:8px 14px;border-radius:var(--radius);font-size:12px;font-weight:700;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;text-decoration:none;transition:all 0.2s;}
.contribute-btn:hover{background:var(--accent);color:#0a1a10;}
.content{min-width:0;}
.progress-row{display:flex;align-items:center;gap:12px;margin-bottom:2rem;padding:1rem 1.25rem;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);}
.progress-label span{color:var(--accent);font-weight:700;}
.cat-block{margin-bottom:1rem;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg2);}
.cat-block-header{padding:1.1rem 1.5rem;display:flex;align-items:center;gap:1rem;cursor:pointer;transition:background 0.15s;user-select:none;}
.cat-block-header:hover{background:var(--bg3);}
.cat-block.open .cat-block-header{background:var(--bg3);border-bottom:1px solid var(--border);}
.cat-number{width:30px;height:30px;border-radius:var(--radius);background:var(--bg4);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;color:var(--text3);flex-shrink:0;}
.cat-block.open .cat-number{background:var(--accent-dim);border-color:var(--accent-border);color:var(--accent);}
.cat-header-text{flex:1;}
.cat-header-text h3{font-size:15px;font-weight:700;color:var(--text);margin-bottom:2px;}
.cat-summary{font-size:12px;color:var(--text2);line-height:1.4;}
.status-pill{padding:3px 10px;border-radius:999px;font-size:11px;font-weight:700;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;white-space:nowrap;flex-shrink:0;}
.pill-strict{background:var(--red-dim);color:var(--red);}
.pill-moderate{background:var(--amber-dim);color:var(--amber);}
.pill-good{background:var(--accent-dim);color:var(--accent);}
.pill-none{background:var(--bg4);color:var(--text3);border:1px solid var(--border2);}
.pill-varies{background:var(--purple-dim);color:var(--purple);}
.pill-note{background:var(--blue-dim);color:var(--blue);}
.cat-toggle{font-size:11px;color:var(--text3);transition:transform 0.2s;flex-shrink:0;}
.cat-block.open .cat-toggle{transform:rotate(180deg);}
.cat-body{display:none;padding:1.5rem;}
.cat-block.open .cat-body{display:block;}
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem;}
.detail-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;}
.detail-card.full{grid-column:1/-1;}
.detail-label{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text3);font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;margin-bottom:6px;}
.detail-card p{font-size:13px;color:var(--text2);line-height:1.6;}
.detail-card ul{padding-left:1.1rem;}
.detail-card ul li{font-size:13px;color:var(--text2);line-height:1.7;}
.detail-value{font-size:22px;font-weight:800;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;color:var(--text);margin-bottom:4px;}
.detail-value.red{color:var(--red);}
.detail-value.amber{color:var(--amber);}
.detail-value.green{color:var(--accent);}
.detail-value.blue{color:var(--blue);}
.community-note{background:var(--bg4);border-left:3px solid var(--accent);border-radius:0 var(--radius) var(--radius) 0;padding:0.875rem 1rem;margin-top:0.75rem;}
.cn-label{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;margin-bottom:5px;}
.community-note p{font-size:13px;color:var(--text2);line-height:1.6;}
.cn-meta{font-size:12px;color:var(--text3);margin-top:5px;}
.empty-note{background:var(--bg4);border:1px dashed var(--border2);border-radius:var(--radius);padding:0.875rem 1.25rem;margin-top:0.75rem;text-align:center;}
.empty-note p{font-size:13px;color:var(--text3);}
.empty-note a{color:var(--accent);text-decoration:none;}
.last-updated{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text3);margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border);}
.update-dot{width:6px;height:6px;background:var(--accent);border-radius:50%;flex-shrink:0;}
@media(max-width:768px){
  .main{grid-template-columns:1fr;}
  .sidebar{position:static;}
  .detail-grid{grid-template-columns:1fr;}
  .detail-card.full{grid-column:1;}
  nav{padding:0 1rem;}
  .nav-links{display:none;}
  .state-badges{margin-left:0;}
  .back-bar{border-top:60px solid transparent;}
}



/* global fixes */
.nav-cta:hover{opacity:.9}
.site-nav{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(13,15,18,0.95);border-bottom:1px solid rgba(255,255,255,0.07);padding:0 2rem;height:60px;display:flex;align-items:center;justify-content:space-between;}
.site-nav .nav-links{display:flex;gap:2rem;list-style:none;}
.site-nav .nav-links a{color:var(--text2,#8b909e);text-decoration:none;font-size:14px;font-weight:500;transition:color .2s;}
.site-nav .nav-links a:hover,.site-nav .nav-links a.active{color:var(--accent,#4fc38a);}
.site-nav .nav-cta{background:var(--accent,#4fc38a);color:#0d1a12;padding:8px 18px;border-radius:10px;font-size:14px;font-weight:700;text-decoration:none;font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;}
.site-nav .nav-logo{font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;font-size:22px;font-weight:800;color:var(--text,#e8eaf0);text-decoration:none;letter-spacing:-.5px;}
.site-nav .nav-logo span{color:var(--accent,#4fc38a);}
@media(max-width:768px){.site-nav{padding:0 1rem;}.site-nav .nav-links{display:none;}}


/* ===== SOLAWS NONPROFIT + MOBILE PATCH 2026-04-23 ===== */
.mission-section{background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.mission-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem;}
.mission-card,.notice-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;}
.mission-card h3{font-size:16px;font-weight:700;margin-bottom:.5rem;}
.mission-card p,.notice-card{font-size:14px;color:var(--text2);line-height:1.65;}
.notice-card{border-left:3px solid var(--amber);margin-top:1.5rem;color:var(--text2);}
.notice-card strong{color:var(--amber);}
footer{margin-top:0;}
.footer-disclaimer{line-height:1.65;}

@media(max-width:900px){
  .mission-grid{grid-template-columns:1fr;}
  .main{grid-template-columns:1fr!important;gap:1.25rem!important;padding:1.5rem 1rem!important;}
  .sidebar{position:static!important;max-height:none!important;}
}

@media(max-width:640px){
  body{font-size:15px;line-height:1.6;}
  nav{height:56px;padding:0 .85rem!important;}
  .nav-logo{font-size:18px;white-space:nowrap;}
  .nav-cta{padding:7px 12px;font-size:12px;}
  .hero{min-height:auto;padding:88px 1rem 42px;}
  .hero-badge{font-size:11px;padding:5px 11px;margin-bottom:1.15rem;}
  .hero h1{font-size:clamp(34px,12vw,48px);letter-spacing:-1.25px;margin-bottom:1rem;}
  .hero p{font-size:15.5px;line-height:1.65;margin-bottom:1.5rem;max-width:100%;}
  .hero-actions{width:100%;gap:.7rem;}
  .hero-actions a,.btn-primary,.btn-secondary{width:100%;text-align:center;padding:12px 16px;font-size:14px;}
  .hero-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.5rem;width:100%;margin-top:2rem;}
  .stat{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:.85rem .5rem;}
  .stat-num{font-size:21px;}
  .stat-label{font-size:11px;line-height:1.25;display:block;}
  section{padding:46px 1rem;}
  .section-title{font-size:clamp(24px,8vw,32px);letter-spacing:-.6px;}
  .section-sub{font-size:15px;line-height:1.65;max-width:100%;}
  .features-grid{grid-template-columns:1fr;gap:.85rem;margin-top:1.75rem;}
  .feature-card{padding:1.15rem;}
  .feature-icon{width:38px;height:38px;margin-bottom:.85rem;}
  .lookup-box,.submit-form,.donate-box{padding:1.2rem;margin-top:1.5rem;border-radius:14px;}
  .lookup-row select,.lookup-row input,.lookup-btn{width:100%;min-width:0;}
  .topic-chips{overflow-x:auto;flex-wrap:nowrap;padding-bottom:.35rem;}
  .chip{white-space:nowrap;}
  .posts-grid{margin-top:1.5rem;}
  .post-card{padding:1rem;gap:.75rem;align-items:flex-start;}
  .post-vote{min-width:32px;}
  .vote-btn{width:28px;height:28px;}
  .post-card h4{font-size:15px;line-height:1.35;}
  .post-card p{font-size:13px;line-height:1.55;}
  .post-footer{flex-wrap:wrap;gap:.5rem;font-size:12px;}
  .form-row{grid-template-columns:1fr!important;gap:0;}
  .donate-amounts{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;}
  .amount-btn{padding:10px 12px;}
  .footer-inner{align-items:flex-start!important;}
  .footer-links{gap:.75rem 1rem;}
  footer{padding:2rem 1rem;}
  .page-header{padding:82px 1rem 28px!important;}
  .page-header h1,.header-left h1{font-size:clamp(28px,10vw,38px)!important;letter-spacing:-0.4px!important;}
  .page-header p,.header-left p{font-size:15px!important;line-height:1.55;}
  .breadcrumb{font-size:12px;overflow-x:auto;white-space:nowrap;}
  .disclaimer-banner,.alert-banner{font-size:12px;padding:.85rem;}
  .state-header{gap:.85rem!important;margin-bottom:1.25rem!important;padding-bottom:1rem!important;}
  .state-emblem{width:46px!important;height:46px!important;font-size:16px!important;border-radius:12px!important;}
  .state-header-text h2{font-size:22px!important;}
  .state-header-text p{font-size:12px!important;line-height:1.45;}
  .state-badges{width:100%;margin-left:0!important;}
  .badge{font-size:11px;padding:4px 10px;}
  .progress-row{display:none!important;}
  .state-list{max-height:210px!important;}
  .cat-block-header{padding:.9rem!important;gap:.65rem!important;align-items:flex-start!important;}
  .cat-number{width:26px!important;height:26px!important;}
  .cat-header-text h3{font-size:14px!important;}
  .cat-summary{font-size:11.5px!important;}
  .status-pill{display:none!important;}
  .cat-body{padding:1rem!important;}
  .detail-grid{grid-template-columns:1fr!important;gap:.75rem!important;}
  .detail-card{padding:.9rem!important;}
  .detail-card.full{grid-column:1!important;}
  .detail-value{font-size:19px!important;}
  .community-note{padding:.85rem!important;}
  .stats-inner{display:grid!important;grid-template-columns:1fr;gap:.75rem!important;}
  .wins-grid{grid-template-columns:1fr!important;}
  .win-card,.news-item,.sidebar-card{padding:1rem!important;}
  .filter-bar{overflow-x:auto;flex-wrap:nowrap;padding-bottom:.35rem;}
  .filter-btn{white-space:nowrap;}
  .community-submitted{position:static!important;margin-bottom:.5rem;}
  .back-bar{padding:.75rem 1rem!important;}
  .state-nav{overflow-x:auto;width:100%;padding-bottom:.25rem;}
  .state-nav a{white-space:nowrap;}
}

/* ===== VISIBLE NONPROFIT STRIP PATCH ===== */
.nonprofit-strip{background:rgba(79,195,138,0.08);border-top:1px solid var(--accent-border);border-bottom:1px solid var(--accent-border);padding:1rem 2rem;}
.nonprofit-strip .container{max-width:1100px;margin:0 auto;color:var(--text2);font-size:14px;line-height:1.6;}
.nonprofit-strip strong{color:var(--accent);font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;}
.hero p strong,.section-sub strong{color:var(--text);font-weight:700;}
@media(max-width:640px){.nonprofit-strip{padding:.9rem 1rem}.nonprofit-strip .container{font-size:13px}.hero-badge{margin-bottom:1.1rem}.nav-cta{padding:7px 12px;font-size:12px}.nav-logo{font-size:19px}}


/* SOLaws readability/font update — clean, easier-to-read typography */
body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;
  font-size: 15px;
  line-height: 1.65;
}

h1,h2,h3,h4,h5,
.nav-logo,.nav-cta,.btn-primary,.btn-secondary,.lookup-btn,.amount-btn,.submit-btn,.tip-submit,
.section-label,.badge,.status-pill,.post-tag,.news-tag,.win-type,.sidebar-label,.detail-label,.cn-label,.community-tip-label {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;
}

h1,h2,h3,h4,h5 {
  font-weight: 700;
  letter-spacing: -0.25px;
}

p,li,a,button,input,select,textarea {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;
}

@media (max-width:768px) {
  body { font-size:14px; line-height:1.6; }
  nav { height:56px; }
  .nav-logo { font-size:19px; }
  .nav-cta { padding:7px 12px; font-size:12px; }
  .hero { min-height:auto; padding:88px 1.15rem 42px; }
  .hero-badge { font-size:12px; margin-bottom:1.2rem; }
  .hero h1 { font-size:clamp(30px,10vw,38px)!important; line-height:1.18; letter-spacing:-0.4px; margin-bottom:1rem; }
  .hero p { font-size:15px; line-height:1.6; margin-bottom:1.5rem; }
  .hero-stats { margin-top:2rem; gap:1rem; }
  .stat-num { font-size:24px; }
  section { padding:48px 1.15rem; }
  .section-title { font-size:24px!important; line-height:1.25; }
  .section-sub { font-size:15px; line-height:1.6; }
  .features-grid,.wins-grid { gap:.9rem; margin-top:1.5rem; }
  .feature-card,.post-card,.win-card,.news-item,.sidebar-card,.lookup-box,.submit-form,.donate-box,.success-box { padding:1.1rem!important; }
  .post-card { gap:.75rem; }
  .post-card h4,.news-item h3,.win-card h3 { font-size:15px; line-height:1.35; }
  .post-card p,.news-item p,.win-card p,.detail-card p,.community-note p { font-size:13px; line-height:1.55; }
  .post-footer { flex-wrap:wrap; gap:.5rem; font-size:12px; }
  .page-header { padding:82px 1.15rem 30px; }
  .page-header h1,.header-left h1,.state-header-text h1 { font-size:30px!important; line-height:1.2; }
  .page-header p,.header-left p { font-size:15px; line-height:1.6; }
  .main { padding:1.25rem 1.15rem!important; gap:1.25rem!important; }
  .cat-block-header { padding:.9rem 1rem; gap:.75rem; align-items:flex-start; }
  .status-pill { display:none; }
  .cat-body { padding:1rem; }
  .detail-card { padding:.9rem; }
  .progress-row,.stats-inner { flex-direction:column; align-items:stretch; gap:.65rem; }
  .form-row,.lookup-row { grid-template-columns:1fr!important; flex-direction:column; }
  .btn-primary,.btn-secondary,.lookup-btn { width:100%; text-align:center; padding:12px 16px; }
}
