:root{
  --blue:#0f5bea;
  --blue-dark:#0b2b6f;
  --blue-soft:#eaf2ff;
  --ink:#101b3d;
  --muted:#61708f;
  --line:#e6ecf5;
  --bg:#f7faff;
  --card:#ffffff;
  --shadow:0 18px 45px rgba(15,43,111,.12);
  --radius:22px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;color:var(--ink);background:var(--bg);line-height:1.55}
a{text-decoration:none;color:inherit}.site-header{height:78px;background:rgba(255,255,255,.94);backdrop-filter:blur(18px);display:flex;align-items:center;justify-content:space-between;padding:0 56px;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}.brand{display:flex;align-items:center;gap:12px}.brand-icon{width:42px;height:42px;border-radius:13px;background:linear-gradient(135deg,#0f5bea,#3b82f6);display:grid;place-items:center;color:#fff;font-weight:900;box-shadow:0 10px 25px rgba(15,91,234,.25)}.brand strong{display:block;font-size:23px;letter-spacing:-.05em}.brand small{display:block;color:var(--muted);font-weight:600;font-size:12px;margin-top:-4px}.brand.small strong{font-size:18px}.main-nav{display:flex;gap:34px;font-size:14px;font-weight:800;color:#1d2c55}.main-nav a{opacity:.9}.main-nav a:hover{color:var(--blue)}.header-actions,.hero-actions{display:flex;gap:14px;align-items:center}.btn{border:1px solid transparent;border-radius:9px;padding:12px 18px;font-weight:800;font-size:14px;display:inline-flex;align-items:center;justify-content:center;gap:10px;cursor:pointer;transition:.2s ease}.btn-primary{background:var(--blue);color:#fff;box-shadow:0 10px 24px rgba(15,91,234,.22)}.btn-primary:hover{background:#0b4ed3;transform:translateY(-1px)}.btn-ghost{border-color:#c8d8f5;color:var(--blue);background:#fff}.btn-soft{border-color:#c8d8f5;color:var(--blue);background:#fff}.btn-large{padding:16px 28px;border-radius:11px}.hero{min-height:540px;display:grid;grid-template-columns:1fr 1.25fr;align-items:center;position:relative;overflow:hidden;background:linear-gradient(90deg,#fff 0%,#fff 36%,rgba(255,255,255,.88) 49%,rgba(255,255,255,.15) 70%),radial-gradient(circle at 70% 30%,#dbeafe 0,#eff6ff 25%,#fff 70%)}.hero-content{padding-left:96px;max-width:690px;position:relative;z-index:3}.eyebrow{display:inline-flex;padding:7px 12px;border-radius:999px;background:#eaf2ff;color:#0f5bea;font-weight:900;font-size:13px;margin-bottom:24px}.hero h1{font-size:56px;line-height:1.04;letter-spacing:-.065em;margin:0 0 22px}.hero h1 span{color:var(--blue)}.hero p{font-size:18px;color:#314061;margin:0 0 28px;max-width:560px}.trust-line{font-size:14px!important;font-weight:800;color:#314061!important;margin-top:24px!important}.trust-line:before{content:"◇";color:var(--blue);margin-right:10px}.hero-image{height:100%;min-height:540px;position:relative;overflow:hidden;background:linear-gradient(180deg,#cfe8ff 0%,#eff7ff 42%,#d8e9ff 43%,#a5c4f0 100%)}.sky:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 68% 22%,rgba(255,255,255,.95) 0 9%,transparent 18%),linear-gradient(180deg,rgba(255,255,255,.2),transparent)}.town{position:absolute;left:7%;right:0;bottom:0;height:72%;background:linear-gradient(160deg,transparent 0 36%,#abc4e8 36% 37%,transparent 38%),linear-gradient(15deg,transparent 0 24%,#9fb9de 25% 26%,transparent 27%)}.tower{position:absolute;width:82px;height:270px;right:34%;bottom:110px;background:#f8fbff;border:1px solid #9ab1cf;box-shadow:0 18px 30px rgba(11,43,111,.18)}.tower:before{content:"";position:absolute;left:21px;top:-116px;border-left:20px solid transparent;border-right:20px solid transparent;border-bottom:116px solid #172a4d}.tower:after{content:"";position:absolute;left:22px;top:62px;width:38px;height:58px;border-radius:20px 20px 0 0;background:#1e3a70}.house{position:absolute;bottom:80px;width:150px;height:88px;background:#fff;border:1px solid #b7c6dc;box-shadow:0 14px 20px rgba(15,43,111,.12)}.house:before{content:"";position:absolute;left:-8px;right:-8px;top:-38px;height:44px;background:#b85c43;clip-path:polygon(0 100%,50% 0,100% 100%)}.h1{left:3%;bottom:105px}.h2{left:19%;bottom:86px;transform:scale(.9)}.h3{right:10%;bottom:95px;transform:scale(1.05)}.h4{right:48%;bottom:62px;transform:scale(.75)}.trees{position:absolute;left:-8%;right:-8%;bottom:0;height:130px;background:radial-gradient(circle at 8% 44%,#4a7b35 0 35px,transparent 37px),radial-gradient(circle at 16% 60%,#37672c 0 50px,transparent 52px),radial-gradient(circle at 30% 50%,#5b8b3b 0 55px,transparent 57px),radial-gradient(circle at 45% 60%,#33642b 0 52px,transparent 54px),radial-gradient(circle at 60% 48%,#5f963f 0 60px,transparent 62px),radial-gradient(circle at 78% 58%,#3f7330 0 64px,transparent 66px),radial-gradient(circle at 95% 50%,#588e38 0 58px,transparent 60px),linear-gradient(180deg,transparent 0 35%,#5b7b30 36% 100%)}.feature-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;background:#fff;padding:30px 96px;border-bottom:1px solid var(--line);box-shadow:0 10px 30px rgba(15,43,111,.04)}.feature-strip article{display:flex;gap:18px;align-items:flex-start}.icon,.step-icon{width:46px;height:46px;border-radius:16px;background:var(--blue-soft);display:grid;place-items:center;color:var(--blue);font-size:22px}.feature-strip h3,.vote-card h3,.steps h3{font-size:15px;margin:0 0 6px;font-weight:900}.feature-strip p,.vote-card p,.steps p{font-size:14px;color:var(--muted);margin:0}.section{padding:34px 96px 54px}.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}.section h2,.process-section h2,.admin-panel h2,.trust-section h2{font-size:24px;letter-spacing:-.04em;margin:0}.section-head a{color:var(--blue);font-weight:900;font-size:14px}.vote-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}.vote-card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;display:grid;grid-template-columns:42% 58%;min-height:190px;box-shadow:0 16px 35px rgba(15,43,111,.08)}.vote-visual{min-height:190px}.playground{background:linear-gradient(135deg,#c6d9ff,#f7fbff),radial-gradient(circle at 30% 50%,#e88b5e 0 8px,transparent 9px)}.bike{background:linear-gradient(135deg,#b9d3f8,#f5f8ff)}.building{background:linear-gradient(135deg,#94c6ff,#f8fbff)}.vote-body{padding:18px}.badge{display:inline-flex;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:900;margin-bottom:8px}.badge-blue{background:#eaf2ff;color:var(--blue)}.badge-orange{background:#fff1dc;color:#c56b00}.vote-meta{display:flex;justify-content:space-between;gap:8px;font-size:12px;color:#30405e;margin:16px 0 8px}.vote-meta span:before{content:"👥 ";color:var(--blue)}.progress{height:8px;background:#e6eefb;border-radius:20px;overflow:hidden}.progress span{display:block;height:100%;background:var(--blue);border-radius:20px}.percent{text-align:right;font-size:12px;font-weight:900;margin-top:4px}.process-section{padding:42px 96px 58px;display:grid;grid-template-columns:1.2fr 1fr;gap:56px;background:#fff;border-top:1px solid var(--line)}.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:34px;position:relative}.steps:before{content:"";position:absolute;top:17px;left:8%;right:8%;height:1px;background:#cbd9ee}.steps article{text-align:center;position:relative}.steps article>span{display:inline-grid;place-items:center;width:27px;height:27px;background:var(--blue);color:#fff;border-radius:50%;font-weight:900;font-size:12px;margin-bottom:22px;position:relative;z-index:2}.step-icon{margin:0 auto 14px;width:56px;height:56px}.benefits-card{border-left:1px solid #dbe5f2;padding-left:44px}.benefits-card ul{padding:0;margin:26px 0 0;list-style:none}.benefits-card li{padding:10px 0;color:#263653;font-weight:700}.benefits-card li:before{content:"✓";color:var(--blue);background:#eaf2ff;border-radius:50%;padding:1px 5px;margin-right:12px}.admin-panel{margin:42px 96px;padding:38px;border-radius:26px;background:linear-gradient(135deg,#fff,#eef5ff);border:1px solid #d7e4f7;box-shadow:var(--shadow);display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}.admin-panel p{color:var(--muted);font-size:16px}.api-form{display:grid;gap:14px;background:#fff;border:1px solid var(--line);padding:22px;border-radius:20px}.api-form label{display:grid;gap:7px;font-size:13px;font-weight:900;color:#1c2c55}.api-form input,.api-form select{height:46px;border:1px solid #ccd9ee;border-radius:11px;padding:0 13px;font:inherit;color:var(--ink);background:#fff}.trust-section{text-align:center;padding:62px 22px 78px;background:#f8fbff}.trust-section p{max-width:760px;margin:14px auto 26px;color:var(--muted);font-size:17px}.site-footer{display:flex;align-items:center;justify-content:space-between;padding:26px 96px;background:#fff;border-top:1px solid var(--line);color:var(--muted);font-size:14px}
@media(max-width:1100px){.site-header{padding:0 24px}.main-nav{display:none}.hero{grid-template-columns:1fr}.hero-content{padding:70px 28px}.hero-image{min-height:330px}.feature-strip,.vote-grid,.process-section,.admin-panel{grid-template-columns:1fr}.feature-strip,.section,.process-section{padding-left:28px;padding-right:28px}.steps{grid-template-columns:1fr 1fr}.vote-card{grid-template-columns:1fr}.vote-visual{min-height:150px}.admin-panel{margin-left:28px;margin-right:28px}.site-footer{padding:24px;flex-direction:column;gap:16px}.header-actions{display:none}.hero h1{font-size:42px}.benefits-card{border-left:0;padding-left:0}.feature-strip{gap:18px}}
@media(max-width:640px){.steps{grid-template-columns:1fr}.steps:before{display:none}.hero-actions{flex-direction:column;align-items:stretch}.btn-large{width:100%}.feature-strip{grid-template-columns:1fr}.hero h1{font-size:36px}}

/* Korrektur: reale kommunale Bildwelt statt Illustration/Grün */
.hero{
  grid-template-columns: 1fr 1.4fr;
  background: linear-gradient(90deg,#ffffff 0%,#ffffff 38%,rgba(255,255,255,.92) 52%,rgba(255,255,255,.08) 74%);
}
.hero-image{
  min-height:540px;
  height:100%;
  background:
    linear-gradient(90deg,rgba(255,255,255,.72) 0%,rgba(255,255,255,.28) 28%,rgba(255,255,255,0) 52%),
    url('assets/city-hero.jpg') center center / cover no-repeat;
  filter:saturate(1.04) contrast(1.02);
}
.hero-image .sky,
.hero-image .town,
.hero-image .tower,
.hero-image .house,
.hero-image .trees{display:none!important;}
.vote-visual{background-size:cover!important;background-position:center!important;min-height:190px;}
.playground{background-image:url('assets/park.jpg')!important;}
.bike{background-image:url('assets/radweg.jpg')!important;}
.building{background-image:url('assets/jugendzentrum.jpg')!important;}
.admin-panel{display:none;}
@media(max-width:900px){
  .hero{grid-template-columns:1fr;background:#fff;}
  .hero-image{min-height:320px;order:-1;}
}

/* Bürger-Hinweis auf der Startseite */
.citizen-info{
  margin:34px 96px 34px;
  position:relative;
  z-index:5;
  display:grid;
  grid-template-columns:1.45fr 1fr 1fr 1fr;
  gap:18px;
  align-items:stretch;
}
.citizen-card{
  background:rgba(255,255,255,.96);
  border:1px solid #dbe6f7;
  border-radius:20px;
  box-shadow:0 18px 42px rgba(15,43,111,.10);
}
.citizen-main{
  padding:26px 30px;
  background:linear-gradient(135deg,#ffffff 0%,#eef5ff 100%);
}
.citizen-main .eyebrow{margin-bottom:14px;}
.citizen-main h2{
  margin:0 0 12px;
  font-size:26px;
  line-height:1.18;
  letter-spacing:-.045em;
  color:var(--ink);
}
.citizen-main p{
  margin:0;
  color:#52617f;
  font-size:15px;
}
.citizen-card.mini{
  padding:24px 22px;
}
.mini-icon{
  width:42px;
  height:42px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:var(--blue-soft);
  color:var(--blue);
  margin-bottom:16px;
  font-size:20px;
}
.citizen-card h3{
  margin:0 0 8px;
  font-size:16px;
  font-weight:900;
  letter-spacing:-.025em;
}
.citizen-card.mini p{
  margin:0;
  color:var(--muted);
  font-size:14px;
}
@media(max-width:1100px){
  .citizen-info{margin:24px 28px;grid-template-columns:1fr 1fr;}
  .citizen-main{grid-column:1/-1;}
}
@media(max-width:640px){
  .citizen-info{grid-template-columns:1fr;}
}



/* Update: Bürger-Vorteile sauber unter dem Hero, keine Überlagerung */
.citizen-info{
  margin:38px 96px 34px!important;
  z-index:1;
}
.hero{
  overflow:hidden;
}
@media(max-width:1100px){
  .citizen-info{margin:28px 28px 34px!important;}
}


/* Update: Abstimmungskarten klickbar + Detailseite */
.vote-card{
  color:inherit;
  text-decoration:none;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.vote-card:hover{
  transform:translateY(-4px);
  border-color:#b8cdf0;
  box-shadow:0 22px 46px rgba(15,43,111,.14);
}
.vote-card:focus-visible{
  outline:3px solid rgba(15,91,234,.35);
  outline-offset:4px;
}
.detail-hero{
  padding:54px 96px 34px;
  background:linear-gradient(135deg,#ffffff 0%,#eef5ff 100%);
  border-bottom:1px solid var(--line);
}
.detail-wrap{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:34px;
  align-items:start;
  padding:38px 96px 70px;
}
.detail-card,.vote-box{
  background:#fff;
  border:1px solid var(--line);
  border-radius:22px;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.detail-image{
  min-height:310px;
  background-size:cover;
  background-position:center;
}
.detail-content{padding:28px;}
.detail-content h1,.detail-hero h1{
  margin:0 0 14px;
  font-size:42px;
  line-height:1.08;
  letter-spacing:-.055em;
}
.detail-content p,.detail-hero p{
  color:var(--muted);
  font-size:17px;
  line-height:1.65;
}
.info-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin-top:22px;
}
.info-pill{
  background:#f4f8ff;
  border:1px solid #dbe6f7;
  border-radius:15px;
  padding:14px;
}
.info-pill small{display:block;color:var(--muted);font-weight:800;margin-bottom:4px;}
.info-pill strong{font-size:15px;}
.vote-box{padding:26px;position:sticky;top:104px;}
.vote-box h2{margin:0 0 10px;font-size:24px;letter-spacing:-.04em;}
.vote-option{
  display:flex;
  align-items:center;
  gap:12px;
  border:1px solid #dbe6f7;
  border-radius:14px;
  padding:14px;
  margin:12px 0;
  font-weight:800;
  cursor:pointer;
}
.vote-option input{accent-color:#0f5bea;}
.permission-note{
  background:#eef5ff;
  border:1px solid #cfe0fb;
  border-radius:16px;
  padding:15px;
  color:#314061;
  font-weight:700;
  margin:18px 0;
}
.detail-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px;}
@media(max-width:900px){
  .detail-hero,.detail-wrap{padding-left:28px;padding-right:28px;}
  .detail-wrap{grid-template-columns:1fr;}
  .vote-box{position:static;}
  .info-grid{grid-template-columns:1fr;}
  .detail-content h1,.detail-hero h1{font-size:32px;}
}


/* Rechtliche Must-Haves: DSGVO, BITV, Sicherheit */
.compliance-section{
  padding:42px 96px 58px;
  background:#f8fbff;
  border-top:1px solid var(--line);
}
.compliance-head{
  margin-bottom:22px;
}
.compliance-head .eyebrow{
  margin-bottom:10px;
}
.compliance-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:22px;
}
.compliance-card{
  background:#fff;
  border:1px solid #dbe6f7;
  border-radius:20px;
  padding:24px 22px;
  box-shadow:0 16px 34px rgba(15,43,111,.07);
}
.compliance-card h3{
  margin:0 0 8px;
  font-size:16px;
  font-weight:900;
  letter-spacing:-.025em;
  color:var(--ink);
}
.compliance-card p{
  margin:0;
  color:var(--muted);
  font-size:14px;
  line-height:1.55;
}
@media(max-width:1100px){
  .compliance-section{padding-left:28px;padding-right:28px;}
  .compliance-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:640px){
  .compliance-grid{grid-template-columns:1fr;}
}


/* Rechtliche Unterseiten und Footer-Links: optisch passend, ohne das bestehende Layout zu verändern */
.footer-links{display:flex;gap:18px;flex-wrap:wrap;align-items:center;justify-content:center;font-weight:800;color:#1d2c55}
.footer-links a{color:#1d2c55}
.footer-links a:hover{color:var(--blue)}
.legal-page{padding:54px 96px 76px;background:#f8fbff}
.legal-wrap{max-width:1040px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);padding:42px}
.legal-wrap h1{font-size:42px;line-height:1.08;letter-spacing:-.055em;margin:0 0 14px;color:var(--ink)}
.legal-wrap h2{font-size:22px;letter-spacing:-.035em;margin:34px 0 10px;color:var(--ink)}
.legal-wrap p,.legal-wrap li{color:#52617f;font-size:16px}
.legal-wrap ul{padding-left:22px}
.legal-note{border:1px solid #dbe6f7;background:#eef5ff;border-radius:18px;padding:18px 20px;margin:22px 0;color:#314061;font-weight:700}
.legal-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:22px}
.legal-box{border:1px solid #dbe6f7;border-radius:18px;padding:20px;background:#fbfdff}
.legal-box h3{margin:0 0 8px;font-size:17px;color:var(--ink)}
.legal-box p{margin:0;font-size:15px}
.skip-link{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:16px;top:16px;width:auto;height:auto;z-index:999;background:#fff;color:var(--blue);padding:12px 16px;border-radius:10px;box-shadow:var(--shadow);font-weight:900}
@media(max-width:900px){.legal-page{padding:28px}.legal-wrap{padding:26px}.legal-grid{grid-template-columns:1fr}.legal-wrap h1{font-size:34px}}

/* Stadtentscheid Update: Legacy-Seiten optisch an Hauptdesign angleichen */
.wrap{
  width:min(1180px,calc(100% - 48px));
  margin:0 auto;
}
.topbar{
  min-height:78px;
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line);
  position:sticky;
  top:0;
  z-index:50;
}
.nav{
  min-height:78px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:26px;
}
.logo{
  width:42px;
  height:42px;
  border-radius:13px;
  background:linear-gradient(135deg,#0f5bea,#3b82f6);
  display:grid;
  place-items:center;
  color:#fff;
  font-weight:900;
  box-shadow:0 10px 25px rgba(15,91,234,.25);
  flex:0 0 auto;
}
.brand span span,
.brand > span > span{
  display:block;
  font-size:23px;
  font-weight:900;
  letter-spacing:-.05em;
  color:var(--ink);
  line-height:1.05;
}
.claim{
  color:var(--muted);
  font-weight:700;
  font-size:12px;
  margin-top:2px;
  letter-spacing:0;
}
.links{
  display:flex;
  align-items:center;
  gap:30px;
  font-size:14px;
  font-weight:900;
  color:#1d2c55;
  white-space:nowrap;
}
.links a:hover{color:var(--blue)}
.actions{
  display:flex;
  align-items:center;
  gap:12px;
  white-space:nowrap;
}
.btn.primary,
button.btn.primary{
  background:var(--blue);
  color:#fff;
  box-shadow:0 10px 24px rgba(15,91,234,.22);
  border-color:var(--blue);
}
.btn.light{
  background:#fff;
  color:var(--blue);
  border-color:#c8d8f5;
}
.btn.primary:hover,
button.btn.primary:hover{background:#0b4ed3;transform:translateY(-1px)}
.btn.light:hover{border-color:#9dbcf2;transform:translateY(-1px)}
.page-hero{
  padding:70px 0 36px;
  background:linear-gradient(135deg,#ffffff 0%,#eef5ff 100%);
  border-bottom:1px solid var(--line);
}
.page-hero h1{
  max-width:820px;
  margin:0 0 16px;
  font-size:52px;
  line-height:1.05;
  letter-spacing:-.06em;
  color:var(--ink);
}
.page-hero p{
  max-width:760px;
  margin:0;
  color:#314061;
  font-size:19px;
  line-height:1.65;
}
.center{
  display:flex;
  justify-content:center;
}
.card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  box-shadow:var(--shadow);
}
.formgrid{
  width:min(760px,100%);
  padding:36px;
  display:grid;
  gap:18px;
}
.formgrid h2{
  margin:0 0 6px;
  font-size:30px;
  line-height:1.1;
  letter-spacing:-.045em;
  color:var(--ink);
}
.split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}
.field{
  display:grid;
  gap:7px;
}
.field label{
  font-size:13px;
  font-weight:900;
  color:#1c2c55;
}
.input,
.field input,
.field textarea,
.field select{
  width:100%;
  min-height:48px;
  border:1px solid #ccd9ee;
  border-radius:12px;
  padding:0 14px;
  font:inherit;
  color:var(--ink);
  background:#fff;
  outline:none;
}
.field textarea{
  min-height:118px;
  resize:vertical;
  padding:14px;
}
.input:focus,
.field input:focus,
.field textarea:focus,
.field select:focus{
  border-color:#8bb2f4;
  box-shadow:0 0 0 4px rgba(15,91,234,.10);
}
.notice{
  border:1px solid #dbe6f7;
  background:#eef5ff;
  border-radius:16px;
  padding:15px 16px;
  color:#314061;
  font-weight:700;
  line-height:1.55;
}
.footer{
  background:#fff;
  border-top:1px solid var(--line);
  padding:26px 0;
  color:var(--muted);
  font-size:14px;
}
.footer .wrap{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}
.footer a{
  margin-left:18px;
  font-weight:800;
  color:#1d2c55;
}
.footer a:hover{color:var(--blue)}
@media(max-width:980px){
  .wrap{width:min(100% - 32px,1180px)}
  .nav{align-items:flex-start;flex-direction:column;padding:18px 0;gap:16px}
  .links{width:100%;gap:16px;flex-wrap:wrap;white-space:normal}
  .actions{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .actions .btn{width:100%}
  .page-hero{padding:46px 0 28px}
  .page-hero h1{font-size:38px}
  .page-hero p{font-size:17px}
  .section{padding-left:0!important;padding-right:0!important}
  .formgrid{padding:24px;border-radius:20px}
  .split{grid-template-columns:1fr}
  .footer .wrap{align-items:flex-start;flex-direction:column}
  .footer a{margin-left:0;margin-right:16px;display:inline-block;margin-top:8px}
}
@media(max-width:560px){
  .wrap{width:min(100% - 28px,1180px)}
  .brand span span,.brand > span > span{font-size:20px}
  .claim{font-size:11px}
  .links{font-size:14px;gap:12px}
  .actions{grid-template-columns:1fr}
  .page-hero h1{font-size:34px}
  .formgrid h2{font-size:26px}
  .btn{width:100%;min-height:48px}
}

.checkline{display:flex;gap:10px;align-items:flex-start;margin:12px 0;color:#1d2c55;font-weight:700}.checkline input{width:auto;margin-top:5px}
