/* KPD – čisté, robustní, bez inline stylů */

.kpd-wrap { font: 16px/1.5 system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; color: #111; }
.kpd-container { max-width: 1100px; margin: 0 auto; padding: 0 16px; }

.kpd-section { padding: 56px 0; }
.kpd-section--alt { background: #f6f7f9; }
.kpd-section--cta { background: #0f172a; color: #fff; }
.kpd-section--staff { background: #fff7ed; }

.kpd-eyebrow { letter-spacing: .08em; text-transform: uppercase; font-weight: 700; font-size: 12px; opacity: .8; }
.kpd-h1 { font-size: 40px; line-height: 1.1; margin: 10px 0 14px; }
.kpd-h2 { font-size: 28px; line-height: 1.2; margin: 0 0 12px; }
.kpd-h3 { font-size: 18px; margin: 0 0 10px; }
.kpd-h4 { font-size: 15px; margin: 0 0 8px; }
.kpd-lead { font-size: 18px; color: #222; max-width: 62ch; }
.kpd-muted { color: #5b6472; }
.kpd-small { font-size: 13px; }

.kpd-hero { padding: 56px 0 18px; background: linear-gradient(180deg, #0b1220 0%, #0f172a 100%); color: #fff; }
.kpd-hero__grid { display: grid; grid-template-columns: 1.2fr .8fr; gap: 18px; align-items: start; }
.kpd-hero__copy .kpd-lead { color: rgba(255,255,255,.86); }

.kpd-card { background: #fff; color: #111; border-radius: 18px; padding: 18px; box-shadow: 0 10px 30px rgba(0,0,0,.08); }
.kpd-hero__card .kpd-card { border: 1px solid rgba(255,255,255,.08); }

.kpd-miniCard { background: #fff; border: 1px solid #e6e8ee; border-radius: 16px; padding: 16px; box-shadow: 0 6px 18px rgba(0,0,0,.04); }
.kpd-section--cta .kpd-miniCard { background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.12); box-shadow: none; }

.kpd-ctaRow { display: flex; gap: 10px; margin: 18px 0 12px; flex-wrap: wrap; }
.kpd-btn { display: inline-flex; align-items: center; justify-content: center; padding: 12px 14px; border-radius: 12px; text-decoration: none; font-weight: 700; border: 1px solid transparent; cursor: pointer; }
.kpd-btn--primary { background: #2563eb; color: #fff; }
.kpd-btn--ghost { background: rgba(255,255,255,.08); color: #fff; border-color: rgba(255,255,255,.14); }
.kpd-btn--full { width: 100%; }

.kpd-pillRow { list-style: none; display: flex; gap: 10px; padding: 0; margin: 14px 0 0; flex-wrap: wrap; }
.kpd-pillRow li { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.14); padding: 8px 10px; border-radius: 999px; font-weight: 600; font-size: 13px; }

.kpd-list { margin: 10px 0 0; padding-left: 18px; }
.kpd-list li { margin: 6px 0; }

.kpd-split { display: grid; grid-template-columns: 1fr; gap: 18px; }
.kpd-grid3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }

.kpd-callout { border-radius: 14px; padding: 12px 14px; border: 1px solid #e6e8ee; background: #fff; }
.kpd-callout--info { border-color: #c7ddff; background: #eef6ff; }
.kpd-callout--warn { border-color: #fde68a; background: #fffbeb; }
.kpd-callout--dark { border-color: rgba(255,255,255,.18); background: rgba(255,255,255,.06); }

.kpd-steps { margin: 16px 0 0; padding-left: 18px; }
.kpd-steps li { margin: 10px 0; }
.kpd-steps h3 { margin: 0 0 4px; font-size: 16px; }

.kpd-zones { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; margin-top: 16px; }
.kpd-zone { background: #fff; border: 1px solid #e6e8ee; border-radius: 16px; padding: 16px; box-shadow: 0 6px 18px rgba(0,0,0,.03); }
.kpd-goal { margin-top: 10px; }

.kpd-pricingGrid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 14px; }
.kpd-headerRow { display: flex; justify-content: space-between; align-items: end; gap: 10px; flex-wrap: wrap; }

.kpd-field { margin-top: 12px; }
.kpd-field label, .kpd-field legend { font-weight: 800; display: block; margin-bottom: 6px; }
.kpd-select, .kpd-form input, .kpd-form textarea {
  width: 100%;
  border-radius: 12px;
  border: 1px solid #d7dbe5;
  padding: 10px 12px;
  font: inherit;
}
.kpd-help { margin: 6px 0 0; font-size: 13px; color: #5b6472; }

.kpd-checkGrid { display: grid; grid-template-columns: 1fr; gap: 8px; }
.kpd-check { display: flex; gap: 10px; align-items: flex-start; background: #f8fafc; border: 1px solid #e6e8ee; border-radius: 12px; padding: 10px 12px; cursor: pointer; }
.kpd-check em { font-style: normal; color: #334155; font-weight: 700; }

.kpd-result { margin-top: 6px; }
.kpd-result__line { display: flex; justify-content: space-between; align-items: baseline; padding: 6px 0; }
.kpd-result__line strong { font-size: 20px; }
.kpd-divider { height: 1px; background: #e6e8ee; margin: 12px 0; }

.kpd-badges { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 10px; }
.kpd-badge { background: #eff6ff; border: 1px solid #c7ddff; padding: 6px 10px; border-radius: 999px; font-weight: 800; font-size: 12px; }

.kpd-summaryBox { background: #f8fafc; border: 1px solid #e6e8ee; border-radius: 14px; padding: 12px 12px; margin-top: 10px; }

.kpd-faqGrid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 16px; align-items: start; }
.kpd-accordion { border: 1px solid #e6e8ee; border-radius: 16px; overflow: hidden; background: #fff; }
.kpd-accItem { width: 100%; display: flex; justify-content: space-between; align-items: center; padding: 14px 14px; border: 0; background: #fff; font: inherit; font-weight: 900; cursor: pointer; text-align: left; }
.kpd-accItem + .kpd-accPanel { border-top: 1px solid #e6e8ee; }
.kpd-accPanel { padding: 0 14px 14px; }
.kpd-accIcon { font-weight: 900; opacity: .6; }

.kpd-ctaGrid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; align-items: start; }
.kpd-card--cta { background: #fff; color: #111; }
.kpd-section--cta .kpd-muted { color: rgba(255,255,255,.78); }

.kpd-formRow { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }

/* Consent checkbox – mobilní fix */
.kpd-consent{
  display: grid;
  grid-template-columns: 20px 1fr;
  gap: 10px;
  align-items: start;
  margin: 12px 0;
  font-size: 13px;
  line-height: 1.35;
}

.kpd-consent input[type="checkbox"]{
  width: 18px;
  height: 18px;
  margin: 2px 0 0; /* lehce doladí zarovnání k prvnímu řádku textu */
  flex: none;
}

.kpd-consent span{
  display: block;
}

.kpd-formStatus { margin-top: 10px; font-weight: 800; }
.kpd-formStatus.is-ok { color: #16a34a; }
.kpd-formStatus.is-err { color: #dc2626; }

.kpd-staffGrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-top: 12px; }

/* Responsivní */
@media (max-width: 980px) {
  .kpd-hero__grid, .kpd-pricingGrid, .kpd-faqGrid, .kpd-ctaGrid { grid-template-columns: 1fr; }
  .kpd-grid3 { grid-template-columns: 1fr; }
  .kpd-zones { grid-template-columns: 1fr; }
  .kpd-staffGrid { grid-template-columns: 1fr; }
  .kpd-h1 { font-size: 34px; }
  .kpd-formRow { grid-template-columns: 1fr; }
}


.kpd-section--afterform .kpd-card--info {
  padding: 24px;
}

.kpd-infoGrid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-top: 16px;
}

@media (max-width: 860px) {
  .kpd-infoGrid { grid-template-columns: 1fr; }
}

.kpd-card--info .kpd-lead {
  margin-top: 8px;
}

.kpd-card--info .kpd-divider {
  margin: 18px 0;
}

.kpd-publicChecklist{
  margin: 14px 0 18px;
}

.kpd-checklist{
  list-style: none;
  padding: 0;
  margin: 0 0 8px;
}

.kpd-checklist li{
  padding-left: 1.4em;
  position: relative;
  margin-bottom: 6px;
}

.kpd-checklist li::before{
  content: "•";
  position: absolute;
  left: 0;
}

/* volitelné: větší "tap target" na mobilu */
@media (max-width: 980px){
  .kpd-consent{
    padding: 10px 12px;
    border: 1px solid #e6e8ee;
    border-radius: 12px;
    background: #f8fafc;
  }
}

.kpd-consent a{
  color: #2563eb;
  font-weight: 700;
  text-decoration: underline;
}

.kpd-consent a:hover{
  text-decoration: none;
}


@media (max-width: 980px){
  .kpd-consent a{
    display: inline-block;
    padding: 2px 0;
  }
}

