.dp-root{
  --dp-text:#111827;
  --dp-muted:#6b7280;
  --dp-border:#e5e7eb;
  --dp-border-strong:#d1d5db;
  --dp-panel:#ffffff;

  --dp-accent:#0d6efd;
  --dp-accent-dark: #003b93;
  --dp-btn-green:#16a34a;
  --dp-btn-green-hover:#15803d;

  --dp-radius:2px;

  /* Single source of truth – velikosti */
  --ctrl-font: .95rem;  /* cca 15px */
  --ctrl-py: .5rem;
  --ctrl-px: .65rem;
  --ctrl-lh: 1.2;

  --card-font: .92rem;
  --card-py: .45rem;
  --card-px: .55rem;
  --card-minh: 40px;
  --choice-card-minh: 38px;

    /* nové společné labely */
  --label-font-size:1rem;
  --label-font-weight:500;
  --label-line-height:1.15;
  --label-color-dark:#374151;
  --label-color-light:#ffffff;

  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 16px;
  line-height: 1.45;
  color: var(--dp-text);
}

.dp-root, .dp-root *{ box-sizing:border-box; }

#diplomkaForm{
  max-width: 980px;
  margin: 0 auto;
}

/* sekce */
#diplomkaForm .dp-section{
  background: var(--dp-panel);
  border: 1px solid var(--dp-border);
  border-radius: var(--dp-radius);
  padding: 16px;
}

#diplomkaForm .dp-section + .dp-section{
  margin-top: 40px;
}

#diplomkaForm .dp-production-layout{
  display: grid;
  grid-template-columns: 1fr;
  gap: 40px;
  margin-top: 40px;
  margin-bottom: 40px;
}

#diplomkaForm .dp-prod-hardcover,
#diplomkaForm .dp-prod-bindings{
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-width: 0;
}

#diplomkaForm .dp-prod-hardcover > *,
#diplomkaForm .dp-prod-bindings > *{
  margin-top: 0 !important;
}

#diplomkaForm .dp-prod-hardcover > #dp_cover_print_section{
  margin-top: -14px !important;
}

#diplomkaForm .dp-prod-print{
  min-width: 0;
}

#diplomkaForm .dp-prod-extras{
  min-width: 0;
}

#diplomkaForm .dp-production-layout > .dp-section + .dp-section{
  margin-top: 0;
}

@media (min-width: 861px){
    #diplomkaForm.mode-full .dp-production-layout,
  #diplomkaForm.mode-covers-only .dp-production-layout,
  #diplomkaForm.mode-binding-only .dp-production-layout{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-areas:
      "hardcover bindings"
      "print extras";
    gap: 32px;
    align-items: start;
  }

  #diplomkaForm.mode-full .dp-prod-hardcover,
  #diplomkaForm.mode-covers-only .dp-prod-hardcover,
  #diplomkaForm.mode-binding-only .dp-prod-hardcover{ grid-area: hardcover; }

  #diplomkaForm.mode-full .dp-prod-bindings,
  #diplomkaForm.mode-covers-only .dp-prod-bindings,
  #diplomkaForm.mode-binding-only .dp-prod-bindings{ grid-area: bindings; }

  #diplomkaForm.mode-full .dp-prod-print,
  #diplomkaForm.mode-covers-only .dp-prod-print,
  #diplomkaForm.mode-binding-only .dp-prod-print{ grid-area: print; }

  #diplomkaForm.mode-full .dp-prod-extras,
  #diplomkaForm.mode-covers-only .dp-prod-extras,
  #diplomkaForm.mode-binding-only .dp-prod-extras{ grid-area: extras; }

  #diplomkaForm .dp-prod-print .dp-print-grid{
    grid-template-columns: 1fr;
    gap: 18px;
  }

  #diplomkaForm .dp-prod-print .dp-print-controls{
    padding-left: 0;
    padding-top: 0;
  }

  #diplomkaForm.mode-no-hardcover .dp-production-layout{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-areas:
      "bindings print"
      "extras extras";
    gap: 32px;
    align-items: start;
  }

  #diplomkaForm.mode-no-hardcover .dp-prod-bindings{ grid-area: bindings; }
  #diplomkaForm.mode-no-hardcover .dp-prod-print{ grid-area: print; }
  #diplomkaForm.mode-no-hardcover .dp-prod-extras{ grid-area: extras; }
  
}

/* nadpisy */
#diplomkaForm h3{
  margin: 14px 0 6px;
  font-size: 1rem;
  font-weight: 700;
}

/* inputy – jen přes dp-input */
#diplomkaForm .dp-input{
  width: 100%;
  padding: var(--ctrl-py) var(--ctrl-px);
  border: 1px solid var(--dp-border-strong);
  border-radius: var(--dp-radius);
  background: #fff;
  color: var(--dp-text);
  font-size: var(--ctrl-font);
  line-height: var(--ctrl-lh);
  outline: none;
}

#diplomkaForm .dp-input:focus{
  border-color: var(--dp-accent);
  box-shadow: 0 0 0 2px rgba(13,110,253,.10);
}

/* info */
#diplomkaForm .dp-info{
  margin-top: 12px;
  padding: 10px 12px;
  background: #f8fafc;
  border: 1px solid var(--dp-border);
  border-radius: var(--dp-radius);
  color: var(--dp-muted);
  font-size: .9rem;
}

#diplomkaForm .dp-capacity-msg{
  display: none;
  margin-top: 12px;
  padding: 10px 12px;
  border: 1px solid #fecaca;
  background: #fef2f2;
  color: #991b1b;
  border-radius: var(--dp-radius);
  font-size: .92rem;
  line-height: 1.4;
}

#diplomkaForm .dp-capacity-msg.is-visible{
  display: block;
}

#diplomkaForm .dp-swatch.is-hidden-by-capacity{
  display: none !important;
}

/* karty */
#diplomkaForm .dp-cards{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 8px;
}


/* speed layout */
#diplomkaForm .dp-cards.dp-cards-speed{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
@media (min-width: 861px){
  #diplomkaForm .dp-cards.dp-cards-speed{ grid-template-columns: repeat(6, minmax(0, 1fr)); }
}

/* samotná karta = button */
#diplomkaForm .dp-card{
  appearance: none;
  border: 1px solid var(--dp-border);
  border-radius: var(--dp-radius);
  background: #fff;
  color: var(--dp-text);

  min-height: var(--card-minh);
  padding: var(--card-py) var(--card-px);

  font-weight: 700;
  font-size: var(--card-font);
  line-height: 1.15;
  text-align: center;

  cursor: pointer;
  user-select: none;

  transition: border-color .12s ease, background-color .12s ease, color .12s ease;
}

#diplomkaForm .dp-card:hover{ border-color:#cbd5e1; }

#diplomkaForm .dp-card.is-active{
  background: var(--dp-accent);
  color: #fff;
  border-color: var(--dp-accent);
}

/* schovej radio inputy, ale ponech v DOM kvůli odeslání */
#diplomkaForm .dp-radio{
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

/* checkboxes */
#diplomkaForm .dp-check{
  display:flex;
  gap:.6rem;
  align-items:flex-start;
  margin-top: 10px;
  font-size: var(--ctrl-font);
}
#diplomkaForm .dp-check input[type="checkbox"]{
  width: 18px;
  height: 18px;
  margin-top: 2px;
  accent-color: var(--dp-accent);
}

/* total */

#diplomkaForm #dp_total_price{
  font-size: 1.35rem;
  font-weight: 900;
}

/* buttons */
.dp-root .dp-btn{
  border: 1px solid transparent;
  border-radius: var(--dp-radius);
  padding: .75rem .9rem;
  font-weight: 800;
  cursor: pointer;
  width: 100%;
}

.dp-root .dp-btn-green{
  margin-top: 12px;
  background: var(--dp-btn-green);
  color: #fff;
  border-color: var(--dp-btn-green);
}
.dp-root .dp-btn-green:hover{
  background: var(--dp-btn-green-hover);
  border-color: var(--dp-btn-green-hover);
}

#diplomkaForm #dp_zasilkovna_wrap .dp-btn-green{
  margin-top: 0;
}


/* responsive */
@media (max-width: 520px){
  #diplomkaForm .dp-cards{ grid-template-columns: 1fr; }
}

#diplomkaForm ::placeholder{ color:#9ca3af; }

/* --- řádek: label + input vedle sebe (všude) --- */
#diplomkaForm .dp-line{
  display:flex;
  align-items:center;
  gap:12px;
  margin-top: 0px;
}

#diplomkaForm .dp-inline{
  display:flex;
  align-items:center;
  gap:12px;
}

/* Sjednocené labely ve formuláři */
#diplomkaForm .dp-label,
#diplomkaForm .dp-inline-label{
  color: var(--label-color-dark);
  font-size: var(--label-font-size);
  font-weight: var(--label-font-weight);
  line-height: var(--label-line-height);
}

/* klasické labely vlevo od inputů */
#diplomkaForm .dp-label{
  flex: 0 0 220px;
}

/* inline labely vlevo od karet / souborů / swatchů */
#diplomkaForm .dp-inline-label{
  margin: 0;
  white-space: nowrap;
}


/* na menších displejích nech label užší */
@media (max-width: 520px){
  #diplomkaForm .dp-label{ flex-basis: 170px; font-size: .95rem; }
}


/* Doprava/platba: na mobilu 3 sloupce (override proti globálnímu 1 sloupci) */
@media (max-width: 520px){
  #diplomkaForm .dp-cards.dp-cards-3mobile{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  /* ať se text vejde */
  #diplomkaForm .dp-cards.dp-cards-3mobile .dp-card{
    font-size: .86rem;
    padding: .40rem .45rem;
    min-height: var(--choice-card-minh);
  }
}


/* ===================================================
   Jednotný vertikální rytmus mezi bloky formuláře
   =================================================== */

#diplomkaForm .dp-section > * + *{
  margin-top: 18px;
}



/* === Barva desek: swatche vedle labelu === */
#diplomkaForm .dp-row-inline{
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:nowrap;
  justify-content: space-between;
}

#diplomkaForm .dp-cards.dp-cards-inline{
  margin-left: auto;
}


/* swatche vždy v jedné řadě */
#diplomkaForm .dp-swatches{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:nowrap;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  padding-bottom:2px;
}

/* samotný čtvereček */
#diplomkaForm .dp-swatch{
  width: 26px;
  height: 26px;
  border-radius: 4px;
  border: 1px solid var(--dp-border);
  background: var(--swatch, #fff);
  cursor:pointer;
  padding:0;
  flex: 0 0 auto;
}

#diplomkaForm .dp-swatch:hover{
  border-color:#94a3b8;
}

/* aktivní swatch */
#diplomkaForm .dp-swatch.is-active{
  border-color: var(--dp-accent);
  box-shadow: 0 0 0 2px rgba(13,110,253,.18);
}

/* bílá: ať je vidět okraj */
#diplomkaForm .dp-swatch[data-value="bila"]{
  border-color:#cbd5e1;
}


/* Barva písma – vždy v jednom řádku */
/* Inline karty – Tisk / Papír / Barva písma */
#diplomkaForm .dp-cards.dp-cards-inline{
  display: flex;
  gap: 10px;
  margin-top: 0;
  flex-wrap: nowrap;
  align-items: stretch;
}

#diplomkaForm .dp-cards.dp-cards-inline .dp-card{
  min-width: 110px;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: var(--choice-card-minh);
  padding: .45rem .7rem;
}

/* Delší texty v inline kartách */
#diplomkaForm .dp-cards.dp-cards-inline .dp-card[data-value="premium"]{
  min-width: 140px;
}


/* Dokončit objednávku – neaktivní stav */
.dp-root .dp-btn.is-disabled{
  background: #e5e7eb !important;
  border-color: #e5e7eb !important;
  color: #9ca3af !important;
  cursor: not-allowed !important;
  opacity: 1 !important;
}


/* ==============================
   Kontaktní údaje – layout skupin
   ============================== */

#diplomkaForm .dp-fields{
  display: grid;
  gap: 10px;
}

#diplomkaForm .dp-fields-hrbet{
  grid-template-columns: 1fr;
}

@media (min-width: 861px){
  #diplomkaForm .dp-fields-hrbet{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/* Jméno + příjmení: vždy 2 sloupce (všechna zařízení) */
#diplomkaForm .dp-fields-name{
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

/* Telefon + email:
   - mobil: 1 sloupec (2 řádky)
   - PC: 2 sloupce (1 řádek) */
#diplomkaForm .dp-fields-contact{
  grid-template-columns: 1fr;
}
@media (min-width: 861px){
  #diplomkaForm .dp-fields-contact{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* Adresa:
   - mobil: ulice na celý řádek, město + PSČ vedle sebe
   - PC: 3 sloupce v jednom řádku */
#diplomkaForm .dp-fields-address{
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
#diplomkaForm .dp-fields-address .dp-field-ulice{
  grid-column: 1 / -1; /* na mobilu celá šířka */
}

@media (min-width: 861px){
  #diplomkaForm .dp-fields-address{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  #diplomkaForm .dp-fields-address .dp-field-ulice{
    grid-column: auto; /* na PC už normálně 1/3 */
  }
}


#diplomkaForm .dp-sum-row{
  display:flex;
  align-items:flex-start;
  justify-content: space-between;
  gap: 14px;
}

#diplomkaForm .dp-sum-left{
  flex: 1 1 auto;
}

#diplomkaForm .dp-sum-right{
  flex: 0 0 auto;
  text-align:right;
  white-space: nowrap;
  font-weight: 800;
}

#diplomkaForm .dp-sum-sub{
  margin-top: 6px;
  color: var(--dp-muted);
  font-weight: 600;
  font-size: .92rem;
  line-height: 1.25;
}

#diplomkaForm .dp-sum-hr{
  height:1px;
  background: var(--dp-border);
  margin: 12px 0;
}

#diplomkaForm .dp-sum-total .dp-sum-right{
  font-size: 1.15rem;
  font-weight: 900;
}

/* =========================================================
   REKAPITULACE (dp-summary) – tmavý inverzní vzhled
   ========================================================= */

#diplomkaForm .dp-summary{
  background: #1f2937;                 /* tmavě šedá */
  color: #f9fafb;                      /* bílý text */
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--dp-radius);
  padding: 14px 14px;
}

/* Nadpis */
#diplomkaForm .dp-summary .dp-sum-title{
  margin: 0 0 10px;
  font-size: 1.02rem;
  font-weight: 800;
  color: #ffffff;
  padding-bottom: 10px;
}

/* Řádek položky */
#diplomkaForm .dp-summary .dp-sum-row{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 12px;
  padding: 2px 0;
}

/* Levý sloupec – žádná tučnost */
#diplomkaForm .dp-summary .dp-sum-left{
  font-weight: 400;
  color: #f9fafb;
  min-width: 0;
}

/* Pravý sloupec (cena) – žádná tučnost */
#diplomkaForm .dp-summary .dp-sum-right{
  font-weight: 400;
  color: #f9fafb;
  white-space: nowrap;
  text-align: right;
}

/* Vynuceně zruš tučnost u strong uvnitř řádků (kromě total níže) */
#diplomkaForm .dp-summary .dp-sum-row strong{
  font-weight: 400;
}

/* Doplňující šedé texty – světlejší šedá, bez odsazení navíc */
#diplomkaForm .dp-summary .dp-sum-sub{
  margin: 0;                           /* zruší extra vertikální odsazení */
  padding: 0;
  font-weight: 400;
  color: rgba(255,255,255,.72);
  font-size: .92rem;
  line-height: 1.25;
}

/* Oddělovač před celkovou cenou */
#diplomkaForm .dp-summary .dp-sum-hr{
  height: 1px;
  background: rgba(255,255,255,.18);
  margin: 10px 0;
}

/* Celková cena – jediná věc, co je výrazná */
#diplomkaForm .dp-summary .dp-sum-row.dp-sum-total{
  margin-top: 0;
  padding-top: 0;
}

/* vrátit tučnost jen v total */
#diplomkaForm .dp-summary .dp-sum-row.dp-sum-total strong{
  font-weight: 900;
  color: #ffffff;
}

/* pokud by někde probleskovalo staré zvýraznění */
#diplomkaForm .dp-summary .dp-sum-row.dp-sum-total .dp-sum-left,
#diplomkaForm .dp-summary .dp-sum-row.dp-sum-total .dp-sum-right{
  color: #ffffff;
}

/* Mobile drobnosti */
@media (max-width: 520px){
  #diplomkaForm .dp-summary{
    padding: 12px 12px;
  }
  #diplomkaForm .dp-summary .dp-sum-row{
    gap: 10px;
  }
}


/* Kombinovaný tisk – pole čísel barevných stran */
#diplomkaForm .dp-mixed-pages{
  align-items:center;
  gap:12px;
}

#diplomkaForm .dp-mixed-input{
  flex: 1 1 auto;
  min-width:0;
  max-width: 420px;
}

/* mobil pod sebe */
@media (max-width: 640px){
  #diplomkaForm .dp-mixed-pages{
    flex-direction:column;
    align-items:stretch;
    gap:8px;
  }

  #diplomkaForm .dp-mixed-input{
    max-width:none;
    width:100%;
  }
}

/* Kombinovaný tisk – label se může zalamovat */
#diplomkaForm .dp-mixed-pages .dp-inline-label{
  white-space: normal;
  word-break: break-word;
}

/* Rekapitulace – hlavička (klikací) */
#diplomkaForm .dp-summary-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  cursor:pointer;
}

/* pravá strana: Rozbalit + šipka */
#diplomkaForm .dp-summary-toggle{
  display:flex;
  align-items:center;
  gap:6px;
  font-size:.75rem;
  color: rgba(255,255,255,.65);
  user-select:none;
}

#diplomkaForm .dp-summary-arrow{
  transition: transform .2s ease;
}

/* otevřený stav */
#diplomkaForm .dp-summary.dp-summary-open .dp-summary-arrow{
  transform: rotate(180deg);
}

/* Poděkování po odeslání */
#diplomkaForm + .dp-thanks,
.dp-thanks{
  background: #ffffff;
  border: 1px solid var(--dp-border);
  border-radius: var(--dp-radius);
  border-left: 4px solid var(--dp-btn-green);
  padding: 20px;
  margin: 0 0 14px;
}

.dp-thanks h3{
  margin: 0 0 10px;
  font-size: 1.1rem;
  font-weight: 800;
}

.dp-thanks p{
  margin: 0 0 16px;
  color: var(--dp-muted);
  font-size: .95rem;
  line-height: 1.4;
}

.dp-thanks .dp-btn{
  width: auto;          /* ať není přes celou šířku */
  min-width: 260px;
}


/* =========================================
   DESKY – nová UX karta s barvami uvnitř
   ========================================= */

#diplomkaForm .dp-desky-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

#diplomkaForm .dp-desky-card{
  border: 1px solid var(--dp-border);
  border-radius: var(--dp-radius);
  background:#fff;
  overflow:hidden;
}

#diplomkaForm .dp-desky-main{
  padding: 14px;
  cursor: pointer;
  transition: border-color .12s ease, background-color .12s ease, color .12s ease;
}

#diplomkaForm .dp-desky-card.is-active .dp-desky-main{
  background: var(--dp-accent);
  color:#fff;
}

#diplomkaForm .dp-desky-title{
  font-weight: 800;
  font-size: 15px;
  line-height: 1.2;
}

#diplomkaForm .dp-desky-divider{
  height:1px;
  margin:10px 0 10px;
  background: var(--dp-border);
}

#diplomkaForm .dp-desky-card.is-active .dp-desky-divider{
  background: rgba(255,255,255,.35);
}


#diplomkaForm .dp-desky-price-row{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap: 12px;
}

#diplomkaForm .dp-desky-price-label{
  font-size: 13px;
  line-height: 1.15;
  opacity: .9;
}

#diplomkaForm .dp-desky-price{
  font-size: 20px;
  font-weight: 900;
  letter-spacing: .2px;
}

#diplomkaForm .dp-desky-swatches-wrap{
  padding: 10px 14px 14px;
  background:#fff;
}

#diplomkaForm .dp-desky-swatches-wrap .dp-swatches{
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  overflow: visible;
}


@media (max-width: 720px){
  #diplomkaForm .dp-desky-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }

  #diplomkaForm .dp-desky-main{
    padding: 12px;
  }

  #diplomkaForm .dp-desky-title{
    font-size: 14px;
  }

  #diplomkaForm .dp-desky-price-row{
    display: block;
  }

  #diplomkaForm .dp-desky-price-label{
    display: block;
    font-size: 12px;
    margin-bottom: 4px;
  }

  #diplomkaForm .dp-desky-price{
    display: block;
    font-size: 18px;
    line-height: 1.1;
  }

  #diplomkaForm .dp-desky-swatches-wrap{
    padding: 10px 12px 12px;
  }
}

/* Aktivní karta desek = modrá i ve swatch části */
#diplomkaForm .dp-desky-card.is-active .dp-desky-swatches-wrap{
  background: var(--dp-accent);
  color: #fff;
  border-top: 0;
}


/* Swatche v aktivní kartě – jemně světlejší okraje */
#diplomkaForm .dp-desky-card.is-active .dp-swatch{
  border-color: rgba(255,255,255,.35);
}

/* Vybraná barva v aktivní kartě – bílý zvýrazňovací okraj */
#diplomkaForm .dp-desky-card.is-active .dp-swatch.is-active{
  border-color: #fff;
  box-shadow: 0 0 0 2px rgba(255,255,255,.45);
}

/* Bílý swatch v aktivní kartě ať nezmizí */
#diplomkaForm .dp-desky-card.is-active .dp-swatch[data-value="bila"]{
  border-color: #fff;
}

/* Mini nadpisy uvnitř karet desek */
#diplomkaForm .dp-desky-mini-label{
  font-size: 13px;
  line-height: 1.12;
  opacity: .9;
  margin: 0 0 6px;
  font-weight: 700;
}

/* Druhý mini nadpis "Potisk" */
#diplomkaForm .dp-desky-swatches-wrap .dp-desky-mini-label + .dp-swatches + .dp-desky-mini-label{
  margin-top: 12px;
}

/* Swatche pro potisk */
#diplomkaForm .dp-pismo-swatches{
  gap: 8px;
  flex-wrap: wrap;
  overflow: visible;
}

#diplomkaForm .dp-pismo-swatches .dp-swatch[data-value="bila"]{
  border-color:#cbd5e1;
}

/* Aktivní karta = mini nadpisy bílé */
#diplomkaForm .dp-desky-card.is-active .dp-desky-mini-label{
  color: #fff;
}

/* Zlatá a stříbrná ať mají trochu jemnější border */
#diplomkaForm .dp-swatch-metal{
  border-color: rgba(0,0,0,.12);
}

/* V aktivní kartě pro kovové swatche */
#diplomkaForm .dp-desky-card.is-active .dp-swatch-metal{
  border-color: rgba(255,255,255,.35);
}

.dp-desky-mini-label.is-placeholder{
  opacity: .6;
  font-weight: 600;
}

/* =========================================
   Stepper řádky – kompaktnější karta
   ========================================= */

#diplomkaForm .dp-line.dp-line-stepper{
  background: var(--dp-accent-dark);
  border-radius: var(--dp-radius);
  padding: 10px 16px;
  gap: 14px;
  min-height: 60px;
}

#diplomkaForm .dp-line.dp-line-stepper .dp-label{
  color: var(--label-color-light);
  font-size: var(--label-font-size);
  font-weight: var(--label-font-weight);
  line-height: var(--label-line-height);
  flex: 1 1 auto;
  min-width: 0;
  margin: 0;
}

/* pravá část */
#diplomkaForm .dp-stepper{
  display: flex;
  align-items: center;
  gap: 8px;
  width: auto;
  margin-left: auto;
  flex: 0 0 auto;
}

/* tlačítka minus / plus */
#diplomkaForm .dp-stepper-btn{
  appearance: none;
  border: 0;
  border-radius: var(--dp-radius);
  width: 38px;
  height: 38px;
  background: rgba(255,255,255,.16);
  color: #fff;
  font-size: 1.5rem;
  line-height: 1;
  font-weight: 400;
  cursor: pointer;
  flex: 0 0 38px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
}

#diplomkaForm .dp-stepper-btn:hover{
  background: rgba(255,255,255,.24);
  filter: none;
}

/* bílé číselné pole */
#diplomkaForm .dp-stepper-input{
  text-align: center;
  width: 88px;
  min-width: 88px;
  max-width: 88px !important;
  height: 38px;
  font-size: 1.05rem;
  padding: 0 .35rem;
  border: 0;
  border-radius: var(--dp-radius);
  background: #fff;
  color: var(--dp-text);
  box-shadow: none;
}

#diplomkaForm .dp-stepper-input:focus{
  border: 0;
  box-shadow: 0 0 0 2px rgba(255,255,255,.25);
}

#diplomkaForm .dp-stepper-input::-webkit-outer-spin-button,
#diplomkaForm .dp-stepper-input::-webkit-inner-spin-button{
  -webkit-appearance: none;
  margin: 0;
}

#diplomkaForm .dp-stepper-input[type=number]{
  -moz-appearance: textfield;
}

@media (max-width: 720px){
  #diplomkaForm .dp-line.dp-line-stepper{
    padding: 8px 16px;
    min-height: 54px;
    gap: 10px;
  }

  #diplomkaForm .dp-line.dp-line-stepper .dp-label{
    font-size: .9rem;
    line-height: 1.1;
  }

  #diplomkaForm .dp-stepper{
    gap: 6px;
  }

  #diplomkaForm .dp-stepper-btn{
    width: 34px;
    height: 34px;
    flex-basis: 34px;
    font-size: 1.35rem;
  }

  #diplomkaForm .dp-stepper-input{
    width: 72px;
    min-width: 72px;
    max-width: 72px !important;
    height: 34px;
    font-size: 1rem;
  }
}

/* První sekce s druhy vazeb bez rámečku a bez bočních odsazení */
#diplomkaForm .dp-section.dp-section-flat{
  background: transparent;
  border: 0;
  padding: 0;
}

/* Režim bez pevných desek – schované sekce */
#diplomkaForm.mode-no-hardcover .dp-prod-hardcover,
#diplomkaForm.mode-no-hardcover #dp_covers_section,
#diplomkaForm.mode-no-hardcover #dp_cover_assets_section{
  display: none !important;
}

/* Horní odsazení upload sekce */
#diplomkaForm #dp_print_upload_section{
  margin-top: 40px;
}

/* Mezisoučet pro režim bez pevných desek */
#diplomkaForm .dp-mode-subtotal{
  margin-top: 40px;
  background: var(--dp-accent);
  color: #ffffff;
  border: 1px solid var(--dp-accent);
  border-radius: var(--dp-radius);
  padding: 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

#diplomkaForm .dp-mode-subtotal-label{
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.15;
  color: #ffffff;
  white-space: nowrap;
}

#diplomkaForm .dp-mode-subtotal-price{
  margin-top: 0;
  font-size: 1.6rem;
  font-weight: 900;
  line-height: 1;
  color: #ffffff;
  white-space: nowrap;
}

@media (max-width: 860px){
  #diplomkaForm .dp-mode-subtotal{
    margin-top: 32px;
    padding: 14px;
  }

  #diplomkaForm .dp-mode-subtotal-price{
    font-size: 1.4rem;
  }
}

/* =========================================
   TISK – nová dvousloupcová sekce
   ========================================= */

#diplomkaForm .dp-section-print{
  background: #f8fafc;
}

#diplomkaForm .dp-print-grid{
  display: grid;
  grid-template-columns: minmax(260px, .95fr) minmax(0, 1.05fr);
  gap: 36px;
  align-items: start;
}

#diplomkaForm .dp-print-info{
  padding-top: 2px;
}

#diplomkaForm .dp-print-title{
  margin: 0 0 8px;
  font-size: 1.1rem;
  font-weight: 800;
}

#diplomkaForm .dp-print-text{
  font-size: .92rem;
  line-height: 1.45;
  color: var(--dp-muted);
}

#diplomkaForm .dp-print-controls > * + *{
  margin-top: 14px;
}

/* v tiskové sekci klidnější steppery */
#diplomkaForm .dp-section-print .dp-stepper-btn{
  background: #e5e7eb;
  color: var(--dp-text);
}

#diplomkaForm .dp-section-print .dp-stepper-btn:hover{
  background: #d1d5db;
}

#diplomkaForm .dp-section-print .dp-stepper-input{
  background: #fff;
  border: 1px solid var(--dp-border-strong);
}

#diplomkaForm .dp-section-print .dp-label{
  flex: 0 0 120px;
}

#diplomkaForm .dp-section-print .dp-row-inline{
  display: grid;
  grid-template-columns: 90px minmax(0, 1fr);
  align-items: center;
  gap: 10px;
}


#diplomkaForm .dp-section-print .dp-row-inline .dp-cards.dp-cards-inline{
  margin-left: 0;
}


/* mobil */
@media (max-width: 720px){
  #diplomkaForm .dp-print-grid{
    grid-template-columns: 1fr;
    gap: 16px;
  }

  #diplomkaForm .dp-print-title{
    font-size: 1rem;
  }

  #diplomkaForm .dp-print-text{
    font-size: .9rem;
  }

  #diplomkaForm .dp-section-print .dp-label{
    flex: 0 0 110px;
  }



  #diplomkaForm .dp-section-print .dp-cards.dp-cards-inline .dp-card{
    min-height: var(--choice-card-minh);
    padding: .4rem .45rem;
    font-size: .86rem;
  }
}

@media (min-width: 721px){
  #diplomkaForm .dp-section-print .dp-print-controls{
    padding-top: 6px;
    padding-left: 0;
  }

  #diplomkaForm .dp-section-print .dp-label{
    flex: 0 0 150px;
  }

  #diplomkaForm .dp-section-print .dp-row-inline{
    grid-template-columns: 75px minmax(0, 1fr);
    gap: 10px;
  }
}

/* =========================================
   Vlastní upload souborů
   ========================================= */

#diplomkaForm .dp-file-native{
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

#diplomkaForm .dp-upload-stack{
  display: flex;
  flex-direction: column;
  gap: 10px;
}

#diplomkaForm .dp-upload-block{
  display: flex;
  flex-direction: column;
  gap: 10px;
}

#diplomkaForm .dp-btn-upload{
  margin-top: 0;
  width: 100%;
  min-height: var(--choice-card-minh);
  padding: 0 var(--card-px);
  align-self: stretch;
  background: var(--dp-accent-dark);
  color: var(--label-color-light);
  border-color: var(--dp-accent-dark);
  font-size: var(--card-font);
  line-height: 1.15;
}

#diplomkaForm .dp-btn-upload:hover{
  background: var(--dp-accent);
  border-color: var(--dp-accent);
  filter: none;
}

#diplomkaForm .dp-file-picked{
  display: flex;
  align-items: stretch;
  gap: 10px;
  min-width: 0;
}

#diplomkaForm .dp-file-picked-name{
  flex: 1 1 auto;
  min-width: 0;
  min-height: var(--choice-card-minh);
  padding: 0 .8rem;
  border: 1px solid var(--dp-border);
  border-radius: var(--dp-radius);
  background: #fff;
  color: var(--dp-text);
  font-size: var(--card-font);
  line-height: 1.2;
  display: flex;
  align-items: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

#diplomkaForm .dp-file-remove{
  appearance: none;
  border: 1px solid #dc2626;
  background: #dc2626;
  color: #fff;
  border-radius: var(--dp-radius);
  width: var(--choice-card-minh);
  height: var(--choice-card-minh);
  flex: 0 0 var(--choice-card-minh);
  font-size: 1.35rem;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
}

#diplomkaForm .dp-file-remove:hover{
  background: #b91c1c;
  border-color: #b91c1c;
}

@media (min-width: 721px){
  #diplomkaForm .dp-upload-block{
    flex-direction: row;
    align-items: stretch;
  }

  #diplomkaForm .dp-btn-upload{
    width: auto;
    flex: 0 0 auto;
    align-self: auto;
  }

  #diplomkaForm .dp-file-picked{
    flex: 1 1 auto;
  }
}

@media (min-width: 721px){
  #diplomkaForm #dp_zasilkovna_wrap{
    justify-content: space-between;
  }

  #diplomkaForm #dp_zasilkovna_pick{
    width: auto;
    flex: 0 0 auto;
    margin-top: 0;
  }

  #diplomkaForm #dp_zasilkovna_selected{
    flex: 1 1 auto;
    margin-top: 0;
  }
}

@media (max-width: 720px){
  #diplomkaForm #dp_zasilkovna_wrap{
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }

  #diplomkaForm #dp_zasilkovna_pick{
    width: 100%;
    margin-top: 0;
  }

  #diplomkaForm #dp_zasilkovna_selected{
    margin-top: 0;
  }
}



/* =========================================
   TISK – papír a tisk v jednom řádku
   ========================================= */


#diplomkaForm .dp-section-print .dp-cards.dp-cards-inline{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 0;
  width: 100%;
  min-width: 0;
}

#diplomkaForm .dp-section-print .dp-cards.dp-cards-inline .dp-card{
  width: 100%;
  min-width: 0;
  min-height: var(--choice-card-minh);
  padding: .45rem .55rem;
  white-space: nowrap;
  text-align: center;
}

#diplomkaForm .dp-section-print .dp-cards.dp-cards-inline .dp-card[data-value="premium"]{
  min-width: 0;
}

/* =========================================
   POTISK PEVNÝCH DESEK
   ========================================= */

#diplomkaForm .dp-section-coverprint{
  background: #eef6ff;
}


#diplomkaForm .dp-coverprint-text{
  font-size: .92rem;
  line-height: 1.45;
  color: var(--dp-muted);
}

#diplomkaForm .dp-coverprint-controls > * + *{
  margin-top: 14px;
}

#diplomkaForm .dp-section-coverprint .dp-coverprint-controls{
  padding: 0;
}

#diplomkaForm .dp-section-coverprint .dp-coverprint-text{
  margin: 0 0 14px;
}

/* klidnější stepper jako u tisku */
#diplomkaForm .dp-section-coverprint .dp-stepper-btn{
  background: #dbeafe;
  color: var(--dp-text);
}

#diplomkaForm .dp-section-coverprint .dp-stepper-btn:hover{
  background: #bfdbfe;
}

#diplomkaForm .dp-section-coverprint .dp-stepper-input{
  background: #fff;
  border: 1px solid var(--dp-border-strong);
}

#diplomkaForm .dp-section-coverprint .dp-label{
  flex: 0 0 140px;
}

#diplomkaForm .dp-section-coverprint .dp-row-inline{
  display: grid;
  grid-template-columns: 140px minmax(0, 1fr);
  align-items: center;
  gap: 10px;
}


#diplomkaForm .dp-section-coverprint .dp-row-inline .dp-cards.dp-cards-inline{
  margin-left: 0;
}

#diplomkaForm .dp-section-coverprint .dp-cards.dp-cards-inline{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 0;
  width: 100%;
  min-width: 0;
}

#diplomkaForm .dp-section-coverprint .dp-cards.dp-cards-inline .dp-card{
  width: 100%;
  min-width: 0;
  min-height: var(--choice-card-minh);
  padding: .45rem .55rem;
  white-space: nowrap;
  text-align: center;
}

/* mobil */
@media (max-width: 720px){

  #diplomkaForm .dp-coverprint-text{
    font-size: .9rem;
  }

  #diplomkaForm .dp-section-coverprint .dp-label{
    flex: 0 0 110px;
  }

  #diplomkaForm .dp-section-coverprint .dp-row-inline{
    grid-template-columns: 110px minmax(0, 1fr);
    gap: 10px;
  }

  #diplomkaForm .dp-section-coverprint .dp-cards.dp-cards-inline .dp-card{
    min-height: var(--choice-card-minh);
    padding: .4rem .45rem;
    font-size: .86rem;
  }
}

#diplomkaForm .dp-cards.dp-cards-speed .dp-card,
#diplomkaForm .dp-cards.dp-cards-3mobile .dp-card{
  min-height: var(--choice-card-minh);
}

/* =========================================
   DOPLŇKY VAZBY – toggle řádek Ano/Ne
   ========================================= */

#diplomkaForm #dp_binding_extra_toggle_row{
  display: grid;
  gap: 14px;
  align-items: center;
  grid-template-columns: 1fr;
}

#diplomkaForm #dp_binding_extra_toggle_row .dp-inline-label{
  margin: 0;
  min-width: 0;
  white-space: normal;
}

#diplomkaForm #dp_binding_extra_toggle_row .dp-cards.dp-cards-inline{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  width: 100%;
  min-width: 0;
  margin: 0;
}

#diplomkaForm #dp_binding_extra_toggle_row .dp-cards.dp-cards-inline .dp-card{
  width: 100%;
  min-width: 0;
}

@media (min-width: 721px){
  #diplomkaForm #dp_binding_extra_toggle_row{
    grid-template-columns: 1fr;
    gap: 14px;
  }

  #diplomkaForm #dp_binding_extra_toggle_row .dp-cards.dp-cards-inline{
    width: 100%;
    max-width: none;
  }
}

@media (max-width: 720px){
  #diplomkaForm #dp_binding_extra_toggle_row{
    grid-template-columns: 1fr;
  }
}

/* =========================================
   RYCHLOST – kompaktní zelený layout
   ========================================= */

#diplomkaForm .dp-speed-section{
  margin-top: -20px;
  margin-bottom: 40px;
}

#diplomkaForm .dp-speed-layout{
  display: grid;
  grid-template-columns: minmax(0, 1fr) 185px;
  gap: 16px;
  align-items: start;
}

#diplomkaForm .dp-speed-main{
  min-width: 0;
  padding-top: 37px;
}

#diplomkaForm .dp-speed-main-inner{
  background: #38A95B;
  border-radius: var(--dp-radius);
  padding: 16px;
}

#diplomkaForm .dp-speed-main .dp-cards.dp-cards-speed{
  margin-top: 0;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 10px;
}

#diplomkaForm .dp-speed-main .dp-cards.dp-cards-speed .dp-card{
  min-height: var(--choice-card-minh);
  background: #BFECC8;
  border: 1px solid rgba(255,255,255,.5);
  color: #111827;
  font-weight: 700;
}

#diplomkaForm .dp-speed-main .dp-cards.dp-cards-speed .dp-card:hover{
  border-color: rgba(255,255,255,.8);
}

#diplomkaForm .dp-speed-main .dp-cards.dp-cards-speed .dp-card.is-active{
  background: #14532D;
  border-color: rgba(255,255,255,.75);
  color: #ffffff;
}

#diplomkaForm .dp-speed-warning{
  margin-top: 12px;
  color: #ffffff;
  font-size: 0.92rem;
  line-height: 1.35;
}

#diplomkaForm .dp-speed-warning strong{
  color: #ffffff;
  font-weight: 800;
}

#diplomkaForm .dp-speed-deadline{
  display: flex;
  flex-direction: column;
  border-radius: var(--dp-radius);
  overflow: hidden;
  background: #14532D;
  color: #ffffff;
  min-height: 156px;
}

#diplomkaForm .dp-speed-deadline-top{
  background: #38A95B;
  color: #ffffff;
  font-size: .92rem;
  font-weight: 700;
  line-height: 1.2;
  text-align: center;
  padding: 10px 12px 9px;
}

#diplomkaForm .dp-speed-deadline-body{
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 16px 14px;
  text-align: center;
}

#diplomkaForm .dp-speed-deadline-day{
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 6px;
}

#diplomkaForm .dp-speed-deadline-date{
  font-size: 2.05rem;
  font-weight: 900;
  line-height: 1;
  letter-spacing: -0.02em;
  margin-bottom: 6px;
}

#diplomkaForm .dp-speed-deadline-time{
  font-size: 0.95rem;
  font-weight: 800;
  line-height: 1.15;
}

/* mobil */
@media (max-width: 860px){
  #diplomkaForm .dp-speed-layout{
    grid-template-columns: minmax(0, 1fr) 108px;
    gap: 10px;
    align-items: start;
  }

  #diplomkaForm .dp-speed-main{
    order: 1;
    min-width: 0;
    align-self: start;
    padding-top: 0;
  }

  #diplomkaForm .dp-speed-main-inner{
    padding: 10px;
  }

  #diplomkaForm .dp-speed-main .dp-cards.dp-cards-speed{
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    margin-top: 0;
  }

  #diplomkaForm .dp-speed-deadline{
    order: 2;
    width: 108px;
    min-width: 108px;
    margin-left: 0;
    align-self: start;
  }
}


#diplomkaForm .dp-textarea{
  min-height: 110px;
  resize: vertical;
}

/* =========================================
   REŽIM OBJEDNÁVKY – výběrové karty
   ========================================= */

.dp-root .dp-section-mode{
  background: transparent;
  border: 0;
  border-radius: 0;
  padding: clamp(25px, 3vw, 45px);
  margin: 0 0 14px;
}

.dp-root .dp-cards-mode{
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin-top: 0;
}

.dp-root .dp-cards-mode .dp-card{
  appearance: none;
  border: 1px solid var(--dp-border);
  border-radius: var(--dp-radius);
  background: #f3f4f6;
  color: #111827;

  min-height: var(--choice-card-minh);
  padding: .45rem .7rem;

  font-weight: 700;
  font-size: var(--card-font);
  line-height: 1.15;
  text-align: center;

  cursor: pointer;
  user-select: none;
  transition: border-color .12s ease, background-color .12s ease, color .12s ease;
}

.dp-root .dp-cards-mode .dp-card:hover{
  border-color: #9ca3af;
}

.dp-root .dp-cards-mode .dp-card.is-active{
  background: #374151;
  color: #ffffff;
  border-color: #374151;
}

.dp-root .dp-cards-mode .dp-radio{
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

/* =========================================
   DOPRAVA NAHOŘE – tmavě šedo žluté karty
   ========================================= */

#diplomkaForm .dp-shipping-top{
  margin: 18px 0 4px;
  padding: 0 16px;
}

#diplomkaForm .dp-cards.dp-cards-shipping-top{
  display: grid;
  grid-template-columns: max-content max-content max-content;
  justify-content: start;
  gap: 0;
  margin-top: 0;
}

#diplomkaForm .dp-cards.dp-cards-shipping-top .dp-card{
  min-height: var(--choice-card-minh);
  padding: var(--card-py) 1.1rem;
  border-radius: 0;
  border: 1px solid rgba(255,255,255,.35);
  background: #f2c200;
  color: #111827;
  font-size: var(--card-font);
  font-weight: 700;
  line-height: 1.15;
  white-space: nowrap;
  display: flex;
  align-items: center;
  justify-content: center;
}

#diplomkaForm .dp-cards.dp-cards-shipping-top .dp-card:hover{
  border-color: rgba(255,255,255,.55);
}

#diplomkaForm .dp-cards.dp-cards-shipping-top .dp-card.is-active{
  background: #2f2f2f;
  color: #ffffff;
  border-color: rgba(255,255,255,.18);
}

#diplomkaForm .dp-cards.dp-cards-shipping-top .dp-card + .dp-card{
  border-left: 0;
}

#diplomkaForm .dp-ship-text-mobile{
  display: none;
}

#diplomkaForm .dp-ship-text-desktop{
  display: inline;
}

#diplomkaForm .dp-shipping-top-hint{
  display: none;
  margin-top: 8px;
  font-size: .9rem;
  line-height: 1.35;
  color: var(--dp-muted);
}

@media (max-width: 860px){
  #diplomkaForm .dp-shipping-top{
    margin: 0 0 34px;
    padding: 0 16px;
  }

  #diplomkaForm .dp-cards.dp-cards-shipping-top{
    grid-template-columns: repeat(3, minmax(0, 1fr));
    justify-content: stretch;
    gap: 0;
  }

  #diplomkaForm .dp-cards.dp-cards-shipping-top .dp-card{
    min-width: 0;
    width: 100%;
    padding: .4rem .35rem;
    min-height: var(--choice-card-minh);
    font-size: .86rem;
    white-space: nowrap;
  }

  #diplomkaForm .dp-cards.dp-cards-shipping-top .dp-card + .dp-card{
    border-left: 0;
  }

  #diplomkaForm .dp-ship-text-desktop{
    display: none;
  }

  #diplomkaForm .dp-ship-text-mobile{
    display: inline;
  }

  #diplomkaForm .dp-shipping-top-hint{
    display: block;
    text-align: center;
  }
}

/* =========================================
   PLATBA – label a karty v jednom řádku
   ========================================= */

#diplomkaForm .dp-section:has(.dp-payment-row){
  background: #f8fafc;
}

#diplomkaForm .dp-payment-row{
  display: grid;
  grid-template-columns: 90px minmax(0, 1fr);
  align-items: center;
  gap: 10px;
}

#diplomkaForm .dp-payment-row .dp-cards.dp-cards-inline{
  margin-left: 0;
  width: 100%;
}

#diplomkaForm .dp-payment-info-box{
  grid-column: 1 / -1;
  margin-top: 10px;
}

@media (min-width: 861px){
  #diplomkaForm .dp-payment-row{
    grid-template-columns: 90px max-content 1fr;
    justify-content: start;
    align-items: center;
    column-gap: 18px;
    row-gap: 0;
  }

  #diplomkaForm .dp-payment-row .dp-cards.dp-cards-inline{
    width: auto;
  }

  #diplomkaForm .dp-payment-info-box{
    grid-column: auto;
    margin-top: 0;
    align-self: center;
    width: 100%;
  }
}

@media (max-width: 720px){
  #diplomkaForm .dp-payment-row{
    grid-template-columns: 90px minmax(0, 1fr);
    gap: 10px;
  }

  #diplomkaForm .dp-payment-row .dp-cards.dp-cards-inline .dp-card{
    min-height: var(--choice-card-minh);
    padding: .4rem .45rem;
    font-size: .86rem;
  }
}
