:root{
    --bg:#080a0f;
    --bg-2:#0d1118;
    --panel:rgba(255,255,255,.05);
    --panel-2:rgba(255,255,255,.07);
    --text:#f4f7fb;
    --muted:#98a2b3;
    --line:rgba(255,255,255,.08);
    --green:#29f0b4;
    --green-2:#7dffd7;
    --red:#ff4b57;
    --red-2:#ff6b75;
    --shadow:0 24px 80px rgba(0,0,0,.38);
    --radius:24px;
    --container:1220px;
    --header-h:78px;
    --mobile-bottom-h:88px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
    margin:0;
    font-family:'Inter',sans-serif;
    color:var(--text);
    background:linear-gradient(180deg,#06080d 0%,#0a0d14 100%);
    overflow-x:hidden;
}
body.menu-open{overflow:hidden}
a{text-decoration:none;color:inherit}
button{font:inherit}
input,textarea,select,button{font-family:inherit}
.container{
    width:min(calc(100% - 32px), var(--container));
    margin:0 auto;
}
.site-bg{
    position:fixed;
    inset:0;
    z-index:0;
    pointer-events:none;
    background:
        radial-gradient(circle at 12% 10%, rgba(41,240,180,.10), transparent 24%),
        radial-gradient(circle at 88% 14%, rgba(255,75,87,.10), transparent 22%),
        radial-gradient(circle at 50% 60%, rgba(255,255,255,.03), transparent 35%);
}
.site-noise{
    position:fixed;
    inset:0;
    z-index:1;
    pointer-events:none;
    opacity:.045;
    background-image:
        radial-gradient(circle at 20% 20%, #fff 0 1px, transparent 1px),
        radial-gradient(circle at 80% 50%, #fff 0 1px, transparent 1px),
        radial-gradient(circle at 40% 80%, #fff 0 1px, transparent 1px);
    background-size:160px 160px;
}
.site-header{
    position:sticky;
    top:0;
    z-index:1000;
    height:var(--header-h);
    backdrop-filter:blur(16px);
    background:rgba(6,8,13,.72);
    border-bottom:1px solid rgba(255,255,255,.05);
}
.header-inner{
    min-height:var(--header-h);
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:18px;
}
.brand{
    display:flex;
    align-items:center;
    gap:12px;
    min-width:0;
}
.brand-logo{
    width:46px;
    height:46px;
    border-radius:15px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:linear-gradient(135deg,var(--green),#13d89f);
    color:#04110d;
    font-weight:900;
    letter-spacing:.08em;
    box-shadow:0 10px 30px rgba(41,240,180,.22);
    flex:0 0 auto;
}
.brand-logo.small{
    width:40px;
    height:40px;
    border-radius:13px;
    font-size:13px;
}
.brand-copy{
    display:flex;
    flex-direction:column;
    min-width:0;
}
.brand-copy strong{
    font-size:14px;
    letter-spacing:.08em;
    white-space:nowrap;
}
.brand-copy span{
    font-size:12px;
    color:var(--muted);
    white-space:nowrap;
}
.desktop-nav{
    display:flex;
    align-items:center;
    gap:26px;
}
.desktop-nav a{
    color:var(--muted);
    font-size:14px;
    font-weight:700;
    transition:.2s ease;
}
.desktop-nav a:hover{color:#fff}
.header-actions{
    display:flex;
    align-items:center;
    gap:12px;
}
.btn{
    min-height:54px;
    border:none;
    border-radius:18px;
    padding:0 22px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    font-weight:800;
    transition:transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease, opacity .18s ease;
    cursor:pointer;
}
.btn:hover{transform:translateY(-1px)}
.btn:disabled{
    opacity:.7;
    cursor:not-allowed;
    transform:none;
}
.btn-primary{
    background:linear-gradient(135deg,var(--green),var(--green-2));
    color:#05120d;
    box-shadow:0 14px 34px rgba(41,240,180,.22);
}
.btn-ghost{
    background:rgba(255,255,255,.05);
    color:#fff;
    border:1px solid rgba(255,255,255,.08);
}
.btn-full{width:100%}
.btn-header{
    min-height:46px;
    padding:0 18px;
    border-radius:14px;
}
.mobile-menu-toggle{
    width:46px;
    height:46px;
    border-radius:14px;
    border:1px solid rgba(255,255,255,.08);
    background:rgba(255,255,255,.04);
    display:none;
    align-items:center;
    justify-content:center;
    flex-direction:column;
    gap:5px;
    padding:0;
}
.mobile-menu-toggle span{
    width:18px;
    height:2px;
    background:#fff;
    border-radius:999px;
    display:block;
}
.hero{
    position:relative;
    z-index:2;
    padding:58px 0 84px;
}
.hero-grid{
    display:grid;
    grid-template-columns:minmax(0,1.03fr) minmax(420px,.97fr);
    gap:34px;
    align-items:center;
}
.hero-badge,
.section-kicker{
    display:inline-flex;
    align-items:center;
    min-height:38px;
    padding:0 14px;
    border-radius:999px;
    background:rgba(255,255,255,.05);
    border:1px solid rgba(255,255,255,.07);
    color:#fff;
    font-size:12px;
    font-weight:800;
    letter-spacing:.08em;
    text-transform:uppercase;
}
.hero-copy h1{
    margin:18px 0 16px;
    font-family:'Sora',sans-serif;
    font-size:clamp(40px,6vw,72px);
    line-height:1.02;
    letter-spacing:-.03em;
}
.hero-copy h1 span{color:var(--green)}
.hero-text{
    max-width:700px;
    margin:0 0 28px;
    color:var(--muted);
    font-size:18px;
    line-height:1.75;
}
.hero-actions{
    display:flex;
    align-items:center;
    gap:14px;
    flex-wrap:wrap;
    margin-bottom:28px;
}
.hero-stats{
    display:flex;
    gap:14px;
    flex-wrap:wrap;
}
.hero-stat{
    min-width:160px;
    padding:18px 18px;
    border-radius:20px;
    background:rgba(255,255,255,.045);
    border:1px solid rgba(255,255,255,.07);
    box-shadow:var(--shadow);
}
.hero-stat span{
    display:block;
    margin-bottom:10px;
    color:var(--muted);
    font-size:13px;
    font-weight:700;
}
.hero-stat strong{
    font-size:30px;
    line-height:1;
}
.hero-visual{position:relative}

.pill{
    min-height:34px;
    padding:0 12px;
    border-radius:999px;
    display:inline-flex;
    align-items:center;
    font-size:11px;
    font-weight:900;
    letter-spacing:.08em;
    text-transform:uppercase;
}
.pill-red{
    background:rgba(255,75,87,.14);
    color:#fff;
    border:1px solid rgba(255,75,87,.35);
}
.pill-dark{
    background:rgba(255,255,255,.06);
    color:#fff;
    border:1px solid rgba(255,255,255,.08);
}


.map-ring{
    position:absolute;
    border-radius:50%;
    border:1px solid rgba(41,240,180,.22);
    left:50%;
    top:50%;
    transform:translate(-50%,-50%);
}
.ring-1{width:140px;height:140px}
.ring-2{width:230px;height:230px}
.ring-3{width:330px;height:330px}
.map-point{
    position:absolute;
    width:14px;
    height:14px;
    border-radius:50%;
    background:var(--red);
    box-shadow:0 0 0 6px rgba(255,75,87,.12), 0 0 22px rgba(255,75,87,.55);
}
.point-1{top:17%;left:54%}
.point-2{top:24%;left:72%}
.point-3{top:35%;left:30%}
.point-4{top:46%;left:66%}
.point-5{top:54%;left:42%}
.point-6{top:63%;left:22%}
.point-7{top:70%;left:58%}
.point-8{top:78%;left:76%}

.map-center-label{
    display:inline-flex;
    min-height:28px;
    align-items:center;
    padding:0 10px;
    border-radius:999px;
    background:rgba(41,240,180,.12);
    color:var(--green-2);
    font-size:11px;
    font-weight:900;
    letter-spacing:.08em;
    text-transform:uppercase;
}
.map-center-card strong{
    display:block;
    margin-top:14px;
    font-size:32px;
    line-height:1;
    letter-spacing:.02em;
}
.map-center-card p{
    margin:12px 0 0;
    color:var(--muted);
    font-size:14px;
    line-height:1.7;
}


.hero-visual{
    position:relative;
}

.hero-card{
    position:relative;
    min-height:560px;
    padding:22px;
    border-radius:30px;
    background:
        linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.025)),
        linear-gradient(135deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
    border:1px solid rgba(255,255,255,.08);
    box-shadow:var(--shadow);
    overflow:hidden;
}

.hero-card::before{
    content:"";
    position:absolute;
    inset:-2px;
    border-radius:inherit;
    pointer-events:none;
    background:linear-gradient(135deg, rgba(41,240,180,.12), transparent 28%, rgba(255,75,87,.12) 76%, transparent 100%);
    opacity:.85;
}

.hero-card-map{
    background:
        radial-gradient(circle at 15% 15%, rgba(255,75,87,.10), transparent 25%),
        radial-gradient(circle at 85% 85%, rgba(41,240,180,.08), transparent 25%),
        linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.025));
}

.hero-card-top{
    position:relative;
    z-index:5;
    display:flex;
    justify-content:space-between;
    gap:10px;
    flex-wrap:wrap;
}

.city-map-art{
    position:relative;
    margin-top:18px;
    min-height:440px;
    border-radius:24px;
    background:
        linear-gradient(180deg, rgba(8,12,18,.96), rgba(10,15,23,.86));
    border:1px solid rgba(255,255,255,.06);
    overflow:hidden;
}

.map-grid{
    position:absolute;
    inset:0;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:24px;
}

.map-image{
    width:600px;

    object-fit:contain;
    opacity:.90;
    filter:brightness(1.05) contrast(1.05);
}

.map-overlay-gradient{
    position:absolute;
    inset:0;
    background:
        radial-gradient(circle at 20% 30%, rgba(255,75,87,.18), transparent 22%),
        radial-gradient(circle at 72% 38%, rgba(255,75,87,.12), transparent 18%),
        radial-gradient(circle at 55% 72%, rgba(41,240,180,.10), transparent 24%),
        linear-gradient(180deg, rgba(6,8,13,.10), rgba(6,8,13,.35));
    z-index:1;
    pointer-events:none;
}

.map-hot-badge{
    position:absolute;
    z-index:4;
    padding:14px 16px;
    border-radius:18px;
    background:rgba(7,11,17,.88);
    border:1px solid rgba(255,255,255,.08);
    box-shadow:0 16px 40px rgba(0,0,0,.30);
    backdrop-filter:blur(10px);
}

.map-hot-badge strong{
    display:block;
    font-size:28px;
    line-height:1;
    color:#fff;
    margin-bottom:6px;
    font-family:'Sora',sans-serif;
    letter-spacing:-.03em;
}

.map-hot-badge span{
    display:block;
    font-size:12px;
    font-weight:700;
    color:var(--muted);
    text-transform:uppercase;
    letter-spacing:.08em;
}

.badge-1{
    top:22px;
    left:22px;
}

.badge-2{
    top:22px;
    right:22px;
}

.badge-3{
    bottom:118px;
    left:22px;
}

.map-radar{
    position:absolute;
    border-radius:50%;
    border:1px solid rgba(255,75,87,.22);
    z-index:2;
    pointer-events:none;
}

.radar-1{
    width:180px;
    height:180px;
    right:42px;
    bottom:46px;
    box-shadow:0 0 0 14px rgba(255,75,87,.05), 0 0 0 30px rgba(255,75,87,.03);
}

.radar-2{
    width:120px;
    height:120px;
    left:70px;
    top:92px;
    box-shadow:0 0 0 12px rgba(41,240,180,.04), 0 0 0 24px rgba(41,240,180,.02);
}

.map-center-card{
    position:absolute;
    left:50%;
    top:54%;
    transform:translate(-50%,-50%);
    width:min(84%, 370px);
    padding:24px 22px;
    border-radius:24px;
    background:rgba(7,11,17,.92);
    border:1px solid rgba(255,255,255,.08);
    box-shadow:0 18px 50px rgba(0,0,0,.35);
    text-align:left;
    z-index:4;
}

.map-center-card-strong{
    background:
        linear-gradient(180deg, rgba(10,14,22,.96), rgba(8,11,18,.94));
}

.map-center-label{
    display:inline-flex;
    min-height:28px;
    align-items:center;
    padding:0 10px;
    border-radius:999px;
    background:rgba(255,75,87,.12);
    color:#ffb4ba;
    font-size:11px;
    font-weight:900;
    letter-spacing:.08em;
    text-transform:uppercase;
}

.map-center-card strong{
    display:block;
    margin-top:14px;
    font-size:34px;
    line-height:1.02;
    letter-spacing:-.04em;
    font-family:'Sora',sans-serif;
}

.map-center-card p{
    margin:12px 0 0;
    color:var(--muted);
    font-size:14px;
    line-height:1.75;
}

.hero-card-bottom{
    position:relative;
    z-index:5;
    margin-top:16px;
    display:grid;
    gap:14px;
}

.hero-card-bottom-3{
    grid-template-columns:repeat(3, 1fr);
}

.hero-mini-stat{
    padding:16px 18px;
    border-radius:18px;
    background:rgba(255,255,255,.045);
    border:1px solid rgba(255,255,255,.07);
    backdrop-filter:blur(8px);
}

.hero-mini-stat span{
    display:block;
    margin-bottom:8px;
    color:var(--muted);
    font-size:12px;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:.06em;
}

.hero-mini-stat strong{
    font-size:18px;
    line-height:1.2;
    color:#fff;
}

@media (max-width: 768px){
    .hero-card{
        min-height:500px;
        padding:16px;
        border-radius:24px;
    }

    .city-map-art{
        min-height:380px;
        border-radius:20px;
    }

    .map-hot-badge{
        padding:12px 14px;
        border-radius:16px;
    }

    .map-hot-badge strong{
        font-size:22px;
    }

    .badge-1{
        top:14px;
        left:14px;
    }

    .badge-2{
        top:14px;
        right:14px;
    }

    .badge-3{
        left:14px;
        bottom:108px;
    }

    .map-center-card{
        width:min(88%, 310px);
        padding:18px 16px;
        border-radius:20px;
    }

    .map-center-card strong{
        font-size:26px;
    }

    .hero-card-bottom-3{
        grid-template-columns:1fr;
    }
}



.hero-mini-stat span{
    display:block;
    margin-bottom:8px;
    color:var(--muted);
    font-size:12px;
    font-weight:700;
}
.hero-mini-stat strong{font-size:18px}
.section{
    position:relative;
    z-index:2;
    padding:40px 0;
}
.section-dark{
    background:linear-gradient(180deg, rgba(255,255,255,.018), rgba(255,255,255,.01));
    border-top:1px solid rgba(255,255,255,.04);
    border-bottom:1px solid rgba(255,255,255,.04);
}
.section-head{
    max-width:860px;
    margin-bottom:36px;
}
.section-head.center{
    margin-left:auto;
    margin-right:auto;
    text-align:center;
}
.section-head h2{
    margin:18px 0 14px;
    font-family:'Sora',sans-serif;
    font-size:clamp(30px,5vw,54px);
    line-height:1.08;
    letter-spacing:-.03em;
}
.section-head p{
    margin:0;
    color:var(--muted);
    font-size:17px;
    line-height:1.8;
}
.impact-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:22px;
}
.impact-box{
    padding:28px;
    border-radius:26px;
    border:1px solid rgba(255,255,255,.07);
    box-shadow:var(--shadow);
}
.impact-red{
    background:linear-gradient(180deg, rgba(255,75,87,.11), rgba(255,255,255,.03));
}
.impact-dark{
    background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.03));
}
.impact-green{
    background:linear-gradient(180deg, rgba(41,240,180,.10), rgba(255,255,255,.03));
}
.impact-index{
    display:inline-block;
    margin-bottom:16px;
    font-family:'Sora',sans-serif;
    font-size:44px;
    font-weight:800;
    color:rgba(255,255,255,.18);
}
.impact-box h3{
    margin:0 0 10px;
    font-size:24px;
}
.impact-box p{
    margin:0;
    color:var(--muted);
    line-height:1.75;
}
.petition-grid{
    display:grid;
    grid-template-columns:minmax(0,1fr) minmax(0,520px);
    gap:32px;
    align-items:start;
}
.petition-copy h2{
    margin:18px 0 16px;
    font-family:'Sora',sans-serif;
    font-size:clamp(30px,4vw,52px);
    line-height:1.08;
    letter-spacing:-.03em;
}
.petition-copy p{
    margin:0;
    color:var(--muted);
    font-size:17px;
    line-height:1.8;
}
.petition-points{
    margin-top:24px;
    display:grid;
    gap:14px;
}
.petition-point{
    display:flex;
    align-items:flex-start;
    gap:14px;
}
.petition-point span{
    width:12px;
    height:12px;
    margin-top:8px;
    border-radius:50%;
    flex:0 0 auto;
    background:var(--green);
    box-shadow:0 0 18px rgba(41,240,180,.4);
}
.petition-point p{
    margin:0;
    color:#eef3f8;
}
.petition-card{
    padding:28px;
    border-radius:28px;
    background:rgba(255,255,255,.055);
    border:1px solid rgba(255,255,255,.08);
    box-shadow:var(--shadow);
}
.form-group{margin-bottom:16px}
.form-row{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:14px;
}
label{
    display:block;
    margin-bottom:8px;
    font-size:14px;
    font-weight:700;
    color:#fff;
}
input,textarea,select{
    width:100%;
    min-height:56px;
    padding:16px;
    border-radius:18px;
    background:rgba(7,11,17,.85);
    border:1px solid rgba(255,255,255,.08);
    color:#fff;
    outline:none;
    transition:border-color .18s ease, box-shadow .18s ease, background .18s ease;
}
textarea{
    min-height:132px;
    resize:vertical;
}
input:focus,textarea:focus,select:focus{
    border-color:rgba(41,240,180,.5);
    box-shadow:0 0 0 4px rgba(41,240,180,.10);
}
.is-invalid{
    border-color:rgba(255,75,87,.65) !important;
    box-shadow:0 0 0 4px rgba(255,75,87,.10) !important;
}
.field-error{
    min-height:18px;
    margin-top:8px;
    font-size:13px;
    font-weight:600;
    color:#ff9aa1;
}
.form-note{
    margin:14px 0 0;
    color:var(--muted);
    font-size:13px;
    line-height:1.6;
}
.quote-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:20px;
}
.quote-card{
    padding:24px;
    border-radius:24px;
    background:rgba(255,255,255,.045);
    border:1px solid rgba(255,255,255,.07);
    box-shadow:var(--shadow);
}
.quote-card p{
    margin:0;
    font-size:20px;
    line-height:1.65;
}
.action-banner{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:20px;
    padding:30px;
    border-radius:28px;
    background:
        radial-gradient(circle at 0% 50%, rgba(255,75,87,.12), transparent 24%),
        radial-gradient(circle at 100% 50%, rgba(41,240,180,.12), transparent 24%),
        rgba(255,255,255,.05);
    border:1px solid rgba(255,255,255,.08);
    box-shadow:var(--shadow);
}
.action-copy h2{
    margin:18px 0 12px;
    font-family:'Sora',sans-serif;
    font-size:clamp(28px,4vw,44px);
    line-height:1.08;
    letter-spacing:-.03em;
}
.action-copy p{
    margin:0;
    color:var(--muted);
    line-height:1.8;
}
.site-footer{
    position:relative;
    z-index:2;
    padding:28px 0 120px;
    border-top:1px solid rgba(255,255,255,.05);
}
.footer-inner{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:20px;
    flex-wrap:wrap;
}
.footer-inner p{
    margin:6px 0 0;
    color:var(--muted);
}
.mobile-menu-backdrop,
.modal-backdrop{
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.58);
    backdrop-filter:blur(6px);
    z-index:1090;
    opacity:0;
    visibility:hidden;
    transition:.22s ease;
}
.mobile-menu{
    position:fixed;
    top:0;
    right:0;
    width:min(88vw, 360px);
    height:100vh;
    background:linear-gradient(180deg, #0b1018 0%, #0a0d14 100%);
    border-left:1px solid rgba(255,255,255,.08);
    z-index:1100;
    transform:translateX(100%);
    transition:.24s ease;
    display:flex;
    flex-direction:column;
    padding:20px;
}
.mobile-menu.active{
    transform:translateX(0);
}
.mobile-menu-backdrop.active,
.modal-backdrop.active{
    opacity:1;
    visibility:visible;
}
.mobile-menu-head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:14px;
    margin-bottom:22px;
}
.mobile-menu-brand{
    display:flex;
    align-items:center;
    gap:10px;
}
.mobile-menu-close,
.response-modal-close{
    width:42px;
    height:42px;
    border-radius:14px;
    border:1px solid rgba(255,255,255,.08);
    background:rgba(255,255,255,.05);
    color:#fff;
    font-size:28px;
    line-height:1;
    padding:0;
    cursor:pointer;
}
.mobile-nav{
    display:grid;
    gap:10px;
}
.mobile-nav-link{
    min-height:56px;
    display:flex;
    align-items:center;
    padding:0 16px;
    border-radius:18px;
    background:rgba(255,255,255,.04);
    border:1px solid rgba(255,255,255,.07);
    font-weight:800;
}
.mobile-menu-bottom{
    margin-top:auto;
    padding-top:18px;
}
.mobile-bottom-bar{
    display:none;
    position:fixed;
    left:0;
    right:0;
    bottom:0;
    z-index:1005;
    padding:12px 14px calc(12px + env(safe-area-inset-bottom));
    background:linear-gradient(180deg, rgba(10,13,20,.1), rgba(10,13,20,.92));
    backdrop-filter:blur(16px);
    border-top:1px solid rgba(255,255,255,.06);
}
.response-modal{
    position:fixed;
    left:50%;
    top:50%;
    z-index:1200;
    width:min(calc(100% - 24px), 520px);
    transform:translate(-50%, -50%) scale(.94);
    opacity:0;
    visibility:hidden;
    transition:.22s ease;
    background:linear-gradient(180deg, rgba(14,20,29,.98), rgba(9,13,20,.98));
    border:1px solid rgba(255,255,255,.08);
    border-radius:28px;
    box-shadow:0 30px 100px rgba(0,0,0,.45);
    padding:28px;
}
.response-modal.active{
    opacity:1;
    visibility:visible;
    transform:translate(-50%, -50%) scale(1);
}
.response-modal-close{
    position:absolute;
    top:16px;
    right:16px;
}
.response-modal-icon{
    width:74px;
    height:74px;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:34px;
    font-weight:900;
    margin:0 auto 18px;
}
.response-modal-icon.success{
    background:rgba(41,240,180,.12);
    color:var(--green);
    box-shadow:0 0 0 8px rgba(41,240,180,.06);
}
.response-modal-icon.error{
    background:rgba(255,75,87,.12);
    color:var(--red);
    box-shadow:0 0 0 8px rgba(255,75,87,.06);
}
.response-modal h3{
    margin:0 0 12px;
    text-align:center;
    font-family:'Sora',sans-serif;
    font-size:30px;
    line-height:1.1;
}
.response-modal p{
    margin:0 0 22px;
    text-align:center;
    color:var(--muted);
    font-size:16px;
    line-height:1.8;
}
.honeypot{
    position:absolute !important;
    left:-9999px !important;
    opacity:0 !important;
    pointer-events:none !important;
    width:0 !important;
    height:0 !important;
}
@media (max-width: 1120px){
    .hero-grid{grid-template-columns:1fr}
    .hero-card{min-height:520px}
}
@media (max-width: 920px){
    .desktop-nav,
    .desktop-cta{display:none}
    .mobile-menu-toggle{display:flex}
    .impact-grid,
    .quote-grid,
    .petition-grid{grid-template-columns:1fr}
    .action-banner{
        flex-direction:column;
        align-items:flex-start;
    }
}
@media (max-width: 768px){
    :root{--header-h:72px}
    .container{width:min(calc(100% - 24px), var(--container))}
    .hero{padding:34px 0 72px}
    .hero-copy h1{font-size:clamp(34px, 10vw, 52px)}
    .hero-text,
    .section-head p,
    .petition-copy p,
    .action-copy p{font-size:16px}
    .hero-card{
        min-height:460px;
        padding:16px;
        border-radius:24px;
    }
    .city-map-art{
        min-height:350px;
        border-radius:20px;
    }
    .map-center-card{
        width:min(86%, 280px);
        padding:18px 16px;
        border-radius:20px;
    }
    .map-center-card strong{font-size:26px}
    .hero-card-bottom{grid-template-columns:1fr}
    .hero-stats{
        display:grid;
        grid-template-columns:1fr 1fr;
    }
    .hero-stat{min-width:0}
    .form-row{grid-template-columns:1fr}
    .site-footer{
        padding-bottom:calc(110px + env(safe-area-inset-bottom));
    }
    .mobile-bottom-bar{display:block}
    .response-modal{
        padding:24px 18px 18px;
        border-radius:24px;
    }
    .response-modal h3{font-size:26px}
}
@media (max-width: 520px){
    .hero-stats{grid-template-columns:1fr}
    .quote-card p{font-size:18px}
    .impact-box,
    .petition-card,
    .quote-card,
    .action-banner{border-radius:22px}
}

[hidden]{
    display:none !important;
}

.response-modal,
.modal-backdrop{
    display:block;
}