/* ==========================================================
   DATERANGEPICKER – minimální styly (BS5 + design system)
   Pouze to, co nelze řešit BS5 třídami (JS generuje DOM)
   ========================================================== */

/* Wrapper – JS ho vkládá do body, nelze přidat BS5 třídy */
.date-picker-wrapper {
  position: absolute;
  z-index: 1050;
  background-color: var(--c-black);
  border: 1px solid var(--c-secondary-20);
  border-radius: var(--bs-border-radius-lg, .5rem);
  padding: 1rem;
  font-family: var(--ff-body);
  font-size: var(--bs-body-font-size, .875rem);
  color: var(--c-secondary);
  box-shadow: var(--bs-box-shadow-lg, 0 1rem 3rem rgba(0,0,0,.175));
}
.date-picker-wrapper.inline-wrapper { position: relative; box-shadow: none; display: inline-block; }
.date-picker-wrapper.no-shortcuts { padding-bottom: 1rem; }
.date-picker-wrapper.no-topbar { padding-top: 1rem; }
.dp-clearfix { clear: both; height: 0; font-size: 0; }

/* Top bar */
.date-picker-wrapper .drp_top-bar {
  position: relative;
  padding: .5rem 2.5rem .5rem 0;
  border-bottom: 1px solid var(--c-secondary-20);
  margin-bottom: .75rem;
}
.date-picker-wrapper .drp_top-bar .error-top,
.date-picker-wrapper .drp_top-bar .normal-top { display: none; }
.date-picker-wrapper .drp_top-bar .default-top { color: var(--color-text-muted); }
.date-picker-wrapper .drp_top-bar.error .default-top { display: none; }
.date-picker-wrapper .drp_top-bar.error .error-top { display: block; color: var(--c-primary); }
.date-picker-wrapper .drp_top-bar.normal .default-top { display: none; }
.date-picker-wrapper .drp_top-bar.normal .normal-top { display: block; }
.date-picker-wrapper .drp_top-bar b { color: var(--c-secondary); }
.date-picker-wrapper .selected-days { display: none; }

/* Close button (X) */
.date-picker-wrapper .drp_top-bar .apply-btn {
  position: absolute; right: 0; top: .375rem;
  padding: .2rem .5rem; margin: 0; cursor: pointer;
  background: transparent; border: 1px solid var(--c-secondary-20);
  color: var(--c-secondary); border-radius: var(--bs-border-radius-sm, .25rem);
}
.date-picker-wrapper .drp_top-bar .apply-btn:hover {
  background: var(--c-primary); border-color: var(--c-primary); color: var(--on-primary);
}
.date-picker-wrapper .drp_top-bar .apply-btn.disabled { opacity: .35; cursor: default; }
.date-picker-wrapper .drp_top-bar .apply-btn.hide { display: none; }

/* Month tables */
.date-picker-wrapper .month-wrapper { background: transparent; border: none; padding: 0; position: relative; }
.date-picker-wrapper .month-wrapper table { width: 210px; float: left; }
.date-picker-wrapper .month-wrapper table th,
.date-picker-wrapper .month-wrapper table td { vertical-align: middle; text-align: center; padding: 0; }

/* Caption (měsíc + šipky) */
.date-picker-wrapper table .caption { height: 40px; }
.date-picker-wrapper .month-name { text-transform: uppercase; font-weight: 600; letter-spacing: .04em; }
.date-picker-wrapper table .caption .next,
.date-picker-wrapper table .caption .prev {
  padding: .2rem .4rem; cursor: pointer; border-radius: var(--bs-border-radius-sm, .25rem);
  color: var(--c-secondary); font-weight: 700;
}
.date-picker-wrapper table .caption .next:hover,
.date-picker-wrapper table .caption .prev:hover { background: var(--c-primary); color: var(--on-primary); }

/* Week header */
.date-picker-wrapper .week-name {
  height: 28px; line-height: 28px; font-weight: 600;
  font-size: .7rem; text-transform: uppercase; color: var(--color-text-muted);
}

/* Day cells */
.date-picker-wrapper .day {
  padding: .35rem 0; font-size: .8rem;
  color: var(--color-text-muted); cursor: default;
  border-radius: var(--bs-border-radius-sm, .25rem);
}
.date-picker-wrapper .day.lastMonth,
.date-picker-wrapper .day.nextMonth { display: none; }
.date-picker-wrapper .day.toMonth.valid { color: var(--c-secondary); cursor: pointer; }
.date-picker-wrapper .day.toMonth.valid:hover,
.date-picker-wrapper .day.toMonth.hovering { background: var(--c-secondary-20); }
.date-picker-wrapper .day.checked { background: var(--c-primary-20); color: var(--c-secondary); }
.date-picker-wrapper .first-date-selected,
.date-picker-wrapper .last-date-selected { background: var(--c-primary) !important; color: var(--on-primary) !important; }
.date-picker-wrapper .day.real-today { font-weight: 700; box-shadow: inset 0 0 0 1px var(--c-primary); }
.date-picker-wrapper .day.real-today.checked,
.date-picker-wrapper .day.real-today.hovering { background: var(--c-primary); color: var(--on-primary); }
.date-picker-wrapper .day.invalid { color: var(--c-secondary-20); cursor: not-allowed; }
.date-picker-wrapper .day.has-tooltip { cursor: help !important; }

/* Gap */
.date-picker-wrapper .gap { width: 1px; background: var(--c-secondary-20); float: left; margin: 0 .75rem; height: 0; visibility: hidden; position: relative; }
.date-picker-wrapper .gap .gap-lines, .date-picker-wrapper .gap .gap-line,
.date-picker-wrapper .gap .gap-1, .date-picker-wrapper .gap .gap-2, .date-picker-wrapper .gap .gap-3,
.date-picker-wrapper .gap .gap-top-mask, .date-picker-wrapper .gap .gap-bottom-mask { display: none; }

/* Tooltip (počet dní) */
.date-picker-wrapper .date-range-length-tip {
  position: absolute; display: none;
  background: var(--c-primary); color: var(--on-primary);
  padding: .1rem .4rem; border-radius: var(--bs-border-radius-sm, .25rem);
  font-size: .7rem; margin-top: -4px; margin-left: -8px;
}
.date-picker-wrapper .date-range-length-tip:after {
  content: ''; position: absolute;
  border-left: 4px solid transparent; border-right: 4px solid transparent;
  border-top: 4px solid var(--c-primary);
  left: 50%; margin-left: -4px; bottom: -4px;
}

/* Two months layout */
.date-picker-wrapper.two-months.no-gap .month1 .next,
.date-picker-wrapper.two-months.no-gap .month2 .prev { display: none; }

/* Select wrappers (month/year dropdowns) */
.date-picker-wrapper .select-wrapper { display: inline-block; vertical-align: middle; position: relative; overflow: hidden; }
.date-picker-wrapper .select-wrapper select {
  position: absolute; left: 0; top: -1px; cursor: pointer;
  -webkit-appearance: none; appearance: none;
  background: transparent; border: 0; outline: 0; opacity: 0.01;
  font: inherit; text-transform: inherit; color: inherit;
}
.date-picker-wrapper .month-element { display: inline-block; vertical-align: middle; }

/* Links */
.date-picker-wrapper a { color: var(--c-primary); }

/* Time (pokud se používá) */
.date-picker-wrapper .time { position: relative; }
.date-picker-wrapper .time1, .date-picker-wrapper .time2 { width: 200px; padding: 0 .5rem; text-align: center; }
.date-picker-wrapper .time1 { float: left; }
.date-picker-wrapper .time2 { float: right; }
.date-picker-wrapper .time input[type=range] { width: 130px; }
.date-picker-wrapper .time label { white-space: nowrap; }

/* Week numbers */
.date-picker-wrapper .week-number { padding: .35rem 0; font-size: .7rem; color: var(--color-text-muted); cursor: pointer; }
.date-picker-wrapper .week-number.week-number-selected { color: var(--c-primary); font-weight: 700; }

/* Utility */
.date-picker-wrapper .hide { display: none; }

/* Responsive – single column na mobilu */
@media (max-width: 480px) {
  .date-picker-wrapper .month-wrapper table,
  .date-picker-wrapper .month-wrapper table.month2 { width: 100%; float: none; }
  .date-picker-wrapper .gap { display: none; }
}
