.sulice-v11-wrap,.sulice-v11-card{box-sizing:border-box;font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:#18211d}.sulice-v11-hero{border:1px solid #d6ddd7;border-radius:24px;padding:34px 40px;margin:0 0 28px;background:#fff}.sulice-v11-hero h1{font-size:clamp(34px,4.5vw,64px);line-height:1.08;margin:0 0 18px;letter-spacing:-.035em}.sulice-v11-hero p{font-size:clamp(18px,2vw,26px);line-height:1.35;color:#5d6a62;margin:0;max-width:980px}.sulice-v11-grid{display:grid;grid-template-columns:minmax(280px,420px) 1fr;gap:28px}.sulice-v11-card{border:1px solid #d6ddd7;border-radius:24px;padding:28px;background:#fff;margin-bottom:24px}.sulice-v11-card label{display:block;font-weight:700;margin:16px 0 8px}.sulice-v11-card select,.sulice-v11-card input,.sulice-v11-card textarea{width:100%;font-size:18px;border:1px solid #cdd6cf;border-radius:10px;padding:10px 12px;background:#fff}.sulice-v11-card button{margin-top:16px;border:0;border-radius:999px;padding:12px 18px;background:#196f43;color:#fff;font-weight:800;cursor:pointer}.sulice-v11-card button+button{background:#5f6b64}.sulice-check{font-weight:500!important;font-size:14px;color:#5d6a62}.sulice-check input{width:auto}.muted{color:#6b756e;font-weight:500}.warn{color:#a14a00;font-weight:800}.success{margin-top:20px;padding:15px;background:#e7f8ec;border-radius:12px;font-weight:700}.result-card{background:linear-gradient(145deg,#fff,#f8fbf8)}.main-number{text-align:center;font-size:clamp(70px,8vw,132px);line-height:.9;font-weight:900;color:#197447;margin:10px 0}.main-label{text-align:center;text-transform:uppercase;letter-spacing:.13em;font-weight:900;color:#67736c;margin-bottom:24px}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px}.kpi-grid div{border:1px solid #d6ddd7;border-radius:18px;padding:18px;min-height:118px;background:#fff}.kpi-grid strong{display:block;font-size:clamp(26px,3vw,40px);line-height:1.05}.kpi-grid span{display:block;margin-top:6px;color:#5f6b64;font-size:17px}.note{font-size:18px;color:#4e5c54;margin:22px 0 0}.sulice-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}#sulice_share_text{margin-top:14px;min-height:84px}.sulice-leaflet-wrap{width:100%!important;max-width:100%!important}.sulice-leaflet-map{width:100%!important;height:620px!important;min-height:620px!important;border:1px solid #cbd5cf;border-radius:22px;overflow:hidden;background:#e7eee7;position:relative;z-index:1}.sulice-leaflet-pin{width:26px!important;height:26px!important;border-radius:50%;box-shadow:0 3px 10px rgba(0,0,0,.35)}.sulice-leaflet-pin.red{background:rgba(183,37,31,.72);border:4px solid #a6201c}.sulice-leaflet-pin.orange{background:rgba(218,127,18,.75);border:4px solid #b96f13}.sulice-map-popup h3{margin:0 0 8px;font-size:20px}.sulice-map-popup p{margin:0 0 10px;line-height:1.35}.map-popup-kpis{display:grid;gap:6px;margin:8px 0}.map-popup-kpis span{display:block;background:#f5f8f6;border-radius:8px;padding:6px 8px}.map-popup-kpis strong{color:#197447}.leaflet-popup-content{min-width:260px}.parcel-hit{position:relative;border:1px solid #d6ddd7;border-radius:18px;padding:18px 18px 18px 22px;margin:14px 0;background:#fff}.parcel-hit h4{margin:0 0 8px;font-size:22px}.parcel-hit p{margin:8px 0}.parcel-hit small{color:#65716a}.risk-badge{position:absolute;right:14px;top:14px;border-radius:999px;padding:4px 10px;background:#eef2ef;font-size:12px;font-weight:900;text-transform:uppercase}.risk-vysoky{border-left:8px solid #a6201c}.risk-vysoky .risk-badge{background:#fee2e2;color:#8b1a1a}.risk-stredni{border-left:8px solid #b96f13}.risk-stredni .risk-badge{background:#fff4dc;color:#81520f}.parcel-no{border:1px dashed #b8c4bc;border-radius:18px;padding:18px;margin-top:14px;background:#fafcfb}.sulice-db-table-wrap{overflow:auto;margin-top:18px}.sulice-db-table{width:100%;border-collapse:collapse;background:#fff}.sulice-db-table th,.sulice-db-table td{border-bottom:1px solid #d6ddd7;padding:10px;text-align:left;vertical-align:top}.sulice-db-table th{font-weight:900;background:#f7faf8}.heatmap-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin:20px 0}.heatmap-summary div,.heatmap-type-card{border:1px solid #d6ddd7;border-radius:18px;padding:18px;background:#fff}.heatmap-summary strong,.heatmap-type-card strong{display:block;font-size:34px;line-height:1;color:#197447}.heatmap-summary span,.heatmap-type-card span{display:block;margin-top:8px;color:#5f6b64;font-weight:700}.heatmap-bars{display:grid;gap:12px;margin:20px 0}.heatmap-row{display:grid;grid-template-columns:130px 1fr 50px;gap:12px;align-items:center}.heatmap-name{font-weight:800}.heatmap-bar-bg{height:28px;background:#eef3ef;border-radius:999px;overflow:hidden;border:1px solid #d6ddd7}.heatmap-bar{height:100%;background:#196f43;border-radius:999px}.heatmap-count{text-align:right;font-weight:900;font-size:20px}.heatmap-type-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px}@media(max-width:900px){.sulice-v11-grid{grid-template-columns:1fr}.sulice-v11-hero{padding:24px}.kpi-grid{grid-template-columns:repeat(2,1fr)}.sulice-leaflet-map{height:460px!important;min-height:460px!important}}@media print{.sulice-v11-card:first-child,.sulice-actions,#sulice_share_text{display:none}.sulice-v11-grid{display:block}.sulice-v11-hero{border:0;padding:0}.result-card{border:0}}
/* V11.3: headline sizing and result explanation */
.sulice-v11-hero h1{
  font-size:clamp(32px,3.4vw,54px) !important;
  line-height:1.12 !important;
}
.main-label::after{
  content:"Vyjadřuje orientační počet nových domů nebo bytových jednotek, které mohou vzniknout v dané části obce podle zvoleného scénáře.";
  display:block;
  max-width:680px;
  margin:12px auto 0;
  text-transform:none;
  letter-spacing:0;
  font-size:17px;
  line-height:1.4;
  font-weight:600;
  color:#5f6b64;
}
.sulice-db-row{
  cursor:pointer;
}
.sulice-db-row:hover{
  background:#f3faf5;
}
.sulice-row-map-btn{
  border:0;
  border-radius:999px;
  background:#196f43;
  color:#fff;
  padding:7px 12px;
  font-weight:800;
  cursor:pointer;
}
.sulice-map-modal{
  display:none;
  position:fixed;
  inset:0;
  z-index:99999;
  background:rgba(0,0,0,.55);
  padding:30px;
}
.sulice-map-modal.is-open{
  display:flex;
  align-items:center;
  justify-content:center;
}
.sulice-map-modal-inner{
  position:relative;
  width:min(1100px,96vw);
  background:#fff;
  border-radius:24px;
  padding:26px;
  box-shadow:0 18px 60px rgba(0,0,0,.35);
}
.sulice-map-modal-close{
  position:absolute;
  right:18px;
  top:14px;
  border:0;
  background:transparent;
  font-size:34px;
  line-height:1;
  cursor:pointer;
  color:#5f6b64;
}
.sulice-parcel-leaflet-map{
  width:100%;
  height:520px;
  min-height:520px;
  border:1px solid #cbd5cf;
  border-radius:18px;
  overflow:hidden;
}
@media(max-width:900px){
  .sulice-parcel-leaflet-map{
    height:420px;
    min-height:420px;
  }
  .sulice-map-modal{
    padding:12px;
  }
}

/* V11.5 cadastral map detail */
.sulice-parcel-leaflet-map .leaflet-control-layers{
  font-size:14px;
  border-radius:12px;
  box-shadow:0 5px 18px rgba(0,0,0,.18);
}
.sulice-parcel-leaflet-map .leaflet-control-layers-expanded{
  padding:10px 12px;
}
.sulice-map-modal-inner::after{
  content:"Mapa obsahuje orientační bod a volitelnou katastrální vrstvu ČÚZK. Přesné právní údaje vždy ověřte v Nahlížení do KN.";
  display:block;
  margin-top:10px;
  color:#5f6b64;
  font-size:14px;
}

/* V13 Moje ulice */
.sulice-street-tool h2{
  font-size:clamp(30px,3vw,46px);
}
.sulice-street-map{
  display:none;
  width:100%;
  height:520px;
  min-height:520px;
  margin-top:18px;
  border:1px solid #cbd5cf;
  border-radius:22px;
  overflow:hidden;
}
.street-result-card{
  position:relative;
  margin-top:20px;
  border:1px solid #d6ddd7;
  border-radius:22px;
  padding:24px;
  background:#fff;
}
.street-result-card h3{
  margin:0 80px 12px 0;
  font-size:34px;
}
.street-citizen{
  font-size:20px;
  line-height:1.45;
  font-weight:700;
  color:#24322a;
}
.street-kpis{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
  gap:14px;
  margin:18px 0;
}
.street-kpis div{
  background:#f7faf8;
  border:1px solid #d6ddd7;
  border-radius:16px;
  padding:16px;
}
.street-kpis strong{
  display:block;
  font-size:34px;
  line-height:1;
  color:#197447;
}
.street-kpis span{
  display:block;
  margin-top:6px;
  color:#5f6b64;
  font-weight:700;
}
.sulice-street-copy{
  margin-top:12px;
  border:0;
  border-radius:999px;
  padding:12px 18px;
  background:#196f43;
  color:#fff;
  font-weight:800;
  cursor:pointer;
}
@media(max-width:900px){
  .sulice-street-map{height:420px;min-height:420px}
}

/* V14 conversion layer */
.sulice-change-card h2{
 font-size:clamp(32px,3vw,48px);
}
.sulice-action-grid{
 display:grid;
 grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
 gap:18px;
 margin:24px 0;
}
.action-box{
 background:#f7faf8;
 border:1px solid #d6ddd7;
 border-radius:22px;
 padding:22px;
}
.action-box.highlight{
 background:#196f43;
 color:white;
}
.sulice-change-form{
 display:grid;
 gap:12px;
 max-width:700px;
}
.sulice-change-form input{
 padding:14px;
 border-radius:14px;
 border:1px solid #ccd7cf;
}
.sulice-change-form button{
 border:0;
 background:#196f43;
 color:white;
 font-weight:800;
 padding:14px;
 border-radius:999px;
 cursor:pointer;
}

.sulice-scroll-box{
    cursor:pointer;
    transition:all .25s ease;
}
.sulice-scroll-box:hover{
    transform:translateY(-6px);
    box-shadow:0 12px 30px rgba(0,0,0,.12);
}

/* V19 impact visual */
.sulice-impact-visual h2{
  font-size:clamp(32px,3.4vw,52px);
  margin-bottom:10px;
}
.sulice-impact-visual select{
  max-width:420px;
  margin-bottom:22px;
}
.impact-hero-metric{
  display:grid;
  grid-template-columns:minmax(180px,260px) 1fr;
  gap:22px;
  align-items:center;
  background:linear-gradient(135deg,#f4faf6,#fff);
  border:1px solid #d6ddd7;
  border-radius:24px;
  padding:24px;
  margin:20px 0 26px;
}
.impact-hero-metric strong{
  display:block;
  font-size:72px;
  line-height:.9;
  color:#197447;
}
.impact-hero-metric span{
  display:block;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:#5f6b64;
}
.impact-hero-metric p{
  font-size:20px;
  line-height:1.45;
  margin:0;
  color:#27342d;
}
.impact-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
  gap:18px;
}
.impact-card{
  border:1px solid #d6ddd7;
  border-radius:22px;
  padding:22px;
  background:#fff;
  box-shadow:0 8px 22px rgba(0,0,0,.04);
}
.impact-icon{
  font-size:34px;
  margin-bottom:8px;
}
.impact-card h3{
  margin:0 0 12px;
  font-size:24px;
}
.impact-number{
  font-size:46px;
  font-weight:900;
  line-height:1;
  color:#197447;
  margin:12px 0 6px;
}
.impact-card p{
  margin:0 0 12px;
  font-weight:700;
  color:#4b5a51;
}
.impact-card small{
  display:block;
  margin-top:12px;
  color:#69766e;
  line-height:1.35;
}
.impact-bar{
  width:100%;
  height:14px;
  background:#edf3ef;
  border-radius:999px;
  overflow:hidden;
}
.impact-bar span{
  display:block;
  height:100%;
  width:10%;
  background:#196f43;
  border-radius:999px;
  transition:width .35s ease;
}
.impact-explain{
  margin-top:24px;
  border:1px dashed #b8c4bc;
  border-radius:22px;
  padding:22px;
  background:#fafcfb;
}
.impact-explain h3{
  margin-top:0;
}
@media(max-width:760px){
  .impact-hero-metric{
    grid-template-columns:1fr;
  }
}


/* V20.1 */
.sulice-home-risk h2{
    font-size:clamp(32px,3.5vw,54px);
}

.risk-result-box{
    display:grid;
    grid-template-columns:320px 1fr;
    gap:20px;
    margin:24px 0;
}

.risk-distance{
    background:#197447;
    color:white;
    padding:24px;
    border-radius:20px;
    text-align:center;
}

.risk-number{
    font-size:72px;
    font-weight:900;
}

.risk-alert{
    background:#fff8e8;
    padding:24px;
    border-radius:20px;
}

.risk-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
    gap:16px;
}

.risk-card{
    background:white;
    border:1px solid #ddd;
    padding:20px;
    border-radius:18px;
}

@media(max-width:760px){
    .risk-result-box{
        grid-template-columns:1fr;
    }
}

/* V21 text clarity and UX fixes */
.field-help{
  margin:-2px 0 10px;
  color:#5f6b64;
  font-size:15px;
  line-height:1.4;
}
.result-explain-box{
  max-width:720px;
  margin:12px auto 24px;
  padding:14px 18px;
  background:#f6faf7;
  border:1px solid #d6ddd7;
  border-radius:16px;
  text-align:left;
}
.result-explain-box strong{
  display:block;
  color:#18211d;
  margin-bottom:4px;
}
.result-explain-box span{
  display:block;
  color:#5f6b64;
  line-height:1.45;
}
.risk-number{
  font-size:48px !important;
  line-height:1 !important;
}
.risk-label{
  font-size:16px !important;
  line-height:1.3 !important;
  margin-top:10px !important;
  opacity:.95;
}
.risk-distance{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
}
.risk-alert{
  font-size:20px;
  line-height:1.45;
}
.sulice-home-risk .risk-result-box{
  align-items:stretch;
}

/* V22 interactive lower boxes */
.risk-action-card{
  cursor:pointer;
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease, background .22s ease;
  position:relative;
}
.risk-action-card:hover,
.risk-action-card:focus{
  transform:translateY(-6px);
  box-shadow:0 14px 34px rgba(0,0,0,.12);
  border-color:#197447;
  background:#fbfffc;
  outline:none;
}


.risk-action-hint{
  margin-top:18px;
  padding:14px 18px;
  border-radius:16px;
  background:#f6faf7;
  border:1px solid #d6ddd7;
  color:#435147;
  font-weight:700;
  min-height:24px;
}
.sulice-highlight-section{
  animation:sulicePulseHighlight 1.8s ease;
}
@keyframes sulicePulseHighlight{
  0%{box-shadow:0 0 0 0 rgba(25,111,67,.45);}
  45%{box-shadow:0 0 0 10px rgba(25,111,67,.18);}
  100%{box-shadow:0 0 0 0 rgba(25,111,67,0);}
}

/* V22.1 fix: hover hint no longer overlaps card text */
.risk-action-card::after,
.risk-action-card:hover::after,
.risk-action-card:focus::after{
  content:none !important;
  display:none !important;
}
.risk-action-card{
  min-height:unset;
}
.risk-action-hint{
  margin-top:18px;
  padding:14px 18px;
  border-radius:16px;
  background:#f6faf7;
  border:1px solid #d6ddd7;
  color:#435147;
  font-weight:700;
  min-height:24px;
}
