/* Zimní deník – base styles */

:root, [data-theme="light"] {
    --zd-primary: #1a365d;
    --zd-accent: #e67e22;
    --zd-bg: #f0f2f5;
    --zd-card: #ffffff;
    --zd-card-border: #dee2e6;
    --zd-text: #212529;
    --zd-text-muted: #6c757d;
    --zd-input-bg: #ffffff;
    --zd-input-border: #ced4da;
    --zd-table-stripe: #f8f9fa;
    --zd-workdesk-bg: #fff3e0;
    --zd-workdesk-border: #ffe0b2;
}
[data-theme="dark"] {
    --zd-primary: #2d4a7a;
    --zd-accent: #e67e22;
    --zd-bg: #1a1d23;
    --zd-card: #2d3139;
    --zd-card-border: #3d434b;
    --zd-text: #e0e0e0;
    --zd-text-muted: #9ca3af;
    --zd-input-bg: #363b44;
    --zd-input-border: #4d535c;
    --zd-table-stripe: #252830;
    --zd-workdesk-bg: #3a2e1a;
    --zd-workdesk-border: #5a4520;
}
[data-theme="dark"] .card,
[data-theme="dark"] .alert,
[data-theme="dark"] .notif-card { background: var(--zd-card) !important; color: var(--zd-text); border-color: var(--zd-card-border); }
[data-theme="dark"] .card-header { background: var(--zd-input-bg) !important; color: var(--zd-text); border-color: var(--zd-card-border); }
[data-theme="dark"] .notif-card .card-header { background: #4a3a1a !important; }
[data-theme="dark"] .form-control,
[data-theme="dark"] .form-select { background: var(--zd-input-bg); color: var(--zd-text); border-color: var(--zd-input-border); color-scheme: dark; }
[data-theme="dark"] .form-control::placeholder { color: var(--zd-text-muted); }
[data-theme="dark"] input[type="time"]::-webkit-calendar-picker-indicator,
[data-theme="dark"] input[type="date"]::-webkit-calendar-picker-indicator { filter: invert(0.8); cursor: pointer; }
[data-theme="dark"] .table { color: var(--zd-text); --bs-table-bg: transparent; }
[data-theme="dark"] .table th { background: var(--zd-input-bg); color: var(--zd-text-muted); }
[data-theme="dark"] .table td { border-color: var(--zd-card-border); }
[data-theme="dark"] .table-hover tbody tr:hover { background: var(--zd-table-stripe); }
[data-theme="dark"] .table > :not(caption) > * > * { color: var(--zd-text); }
[data-theme="dark"] .table thead th { color: var(--zd-text-muted); background: var(--zd-input-bg); }
[data-theme="dark"] .dropdown-menu { background: var(--zd-card); border-color: var(--zd-card-border); }
[data-theme="dark"] .dropdown-item { color: var(--zd-text); }
[data-theme="dark"] .dropdown-item:hover { background: var(--zd-input-bg); }
[data-theme="dark"] .text-muted { color: var(--zd-text-muted) !important; }
[data-theme="dark"] .badge.bg-secondary { background: #4d535c !important; }
[data-theme="dark"] .selectable-event { background: var(--zd-card); }
[data-theme="dark"] label { color: var(--zd-text); }

body { background: var(--zd-bg); color: var(--zd-text); font-family: 'Segoe UI', system-ui, sans-serif; transition: background 0.3s, color 0.3s; }
.navbar-zd { background: var(--zd-primary); }
.btn-accent { background: var(--zd-accent); color: #fff; border: none; }
.btn-accent:hover { background: #cf6d17; color: #fff; }
.event-card { border-left: 3px solid var(--zd-primary); background: var(--zd-card); color: var(--zd-text); position: relative; overflow: visible; }
.event-card .dropdown-menu { z-index: 1050; }
.event-card:has(.dropdown-menu.show),
.card:has(.dropdown-menu.show) { z-index: 1040; position: relative; }
.event-card.active-event { border-left-color: var(--zd-accent); }
.event-card.closed-duration { opacity: 0.75; }
.event-card.draft-event { opacity: 0.7; border-left-style: dashed !important; }
.event-time { font-family: 'Consolas', 'Courier New', monospace; font-size: 1.1rem; font-weight: 600; color: var(--zd-accent); min-width: 60px; }
.sec { font-size: 0.7em; opacity: 0.5; font-weight: 400; }
/* Family tree connectors */
.family-tree { margin-bottom: 0.5rem; }
.family-parent .event-card { border-left-width: 4px; }
.family-children { margin-left: 20px; padding-left: 20px; border-left: 2px solid var(--tree-color, var(--zd-card-border)); }
.family-child { position: relative; margin-bottom: 4px; }
.family-child::before {
    content: '';
    position: absolute;
    left: -20px; top: 50%;
    width: 18px; height: 0;
    border-top: 2px solid var(--tree-color, var(--zd-card-border));
}
.family-child--last { /* last child: cut vertical line at connector height */ }
.family-child .event-card { border-left-width: 2px; }
.event-type-badge { font-size: 0.75rem; padding: 2px 8px; border-radius: 3px; background: var(--zd-primary); color: #fff; }
.event-type-badge.active { background: var(--zd-accent); }
.notification-line { font-size: 0.85rem; color: var(--zd-text-muted); padding-left: 1rem; border-left: 2px solid var(--zd-card-border); }
.shift-header { background: var(--zd-primary); color: #fff; border-radius: 6px; }
.workdesk-panel { background: var(--zd-workdesk-bg); border: 1px solid var(--zd-workdesk-border); border-radius: 6px; }
.carried-badge { font-size: 0.7rem; background: transparent; color: #7c3aed; padding: 1px 6px; border-radius: 3px; border: 1px solid #7c3aed; }
.duration-label { display: inline-block; font-size: 0.7rem; padding: 1px 6px; border-radius: 3px; font-weight: 600; }
.duration-label--active { color: var(--zd-accent); border: 1px solid var(--zd-accent); background: transparent; }
.duration-label--closed { color: #059669; border: 1px solid #059669; background: transparent; }
.event-meta-line { font-size: 0.8rem; color: var(--zd-text-muted); display: flex; flex-wrap: wrap; gap: 4px 12px; align-items: center; margin-top: 4px; }
.event-meta-line .meta-item { display: inline-flex; align-items: center; gap: 3px; }
.event-meta-line a { color: var(--zd-text-muted); text-decoration: none; }
.event-meta-line a:hover { text-decoration: underline; }
.theme-toggle { cursor: pointer; font-size: 1.1rem; opacity: 0.8; transition: opacity 0.2s; }
.theme-toggle:hover { opacity: 1; }

/* Form validation errors — prominent styling */
.sf-errors-banner {
    background: #fff5f5; border: 2px solid #dc3545; border-radius: 8px;
    padding: 12px 16px; margin-bottom: 16px;
    animation: sf-shake 0.4s ease-in-out;
}
[data-theme="dark"] .sf-errors-banner { background: #3a1a1a; border-color: #ff4d4d; }
.sf-errors-banner .sf-errors-title {
    font-weight: 700; color: #dc3545; font-size: 0.95rem; margin-bottom: 6px;
    display: flex; align-items: center; gap: 6px;
}
.sf-errors-banner .sf-error-item {
    font-size: 0.88rem; color: #842029; padding: 2px 0 2px 20px;
    position: relative;
}
[data-theme="dark"] .sf-errors-banner .sf-error-item { color: #ffa0a0; }
.sf-errors-banner .sf-error-item::before {
    content: "•"; position: absolute; left: 8px; color: #dc3545; font-weight: bold;
}
@keyframes sf-shake {
    0%, 100% { transform: translateX(0); }
    20% { transform: translateX(-6px); }
    40% { transform: translateX(6px); }
    60% { transform: translateX(-4px); }
    80% { transform: translateX(4px); }
}
.sf-field-error { border-color: #dc3545 !important; box-shadow: 0 0 0 2px rgba(220,53,69,0.25) !important; }
.sf-required::after { content: " *"; color: #dc3545; font-weight: 700; }

/* Scheduled task cards */
.scheduled-task-card { transition: border-color 0.3s; border-width: 2px; }
.scheduled-task-card.border-danger { animation: pulse-border 2s infinite; }
@keyframes pulse-border {
    0%, 100% { border-color: var(--bs-danger) !important; }
    50% { border-color: transparent !important; }
}

/* Dispatch clock - segment display */
.dispatch-clock {
    background: #0a0a0a;
    border: 2px solid #333;
    border-radius: 6px;
    padding: 4px 16px;
    line-height: 1;
    box-shadow: inset 0 2px 8px rgba(0,0,0,0.6), 0 1px 3px rgba(0,0,0,0.3);
}
.dispatch-clock .clock-main {
    font-family: 'Consolas', 'Courier New', monospace;
    font-size: 2.2rem;
    font-weight: 700;
    color: #ff2222;
    letter-spacing: 3px;
    text-shadow: 0 0 12px rgba(255, 34, 34, 0.6), 0 0 30px rgba(255, 34, 34, 0.2);
}
.dispatch-clock .clock-seconds {
    font-family: 'Consolas', 'Courier New', monospace;
    font-size: 1.2rem;
    font-weight: 700;
    color: #ff2222;
    opacity: 0.75;
    text-shadow: 0 0 8px rgba(255, 34, 34, 0.4);
}
.dispatch-clock .clock-date {
    font-family: 'Segoe UI', system-ui, sans-serif;
    font-size: 0.65rem;
    font-weight: 400;
    color: #ff6666;
    opacity: 0.7;
    letter-spacing: 0;
    text-align: center;
}

/* Weather forecast styles */
.weather-forecast { border: 1px solid var(--zd-card-border); border-radius: 6px; padding: 12px; margin-top: 8px; background: var(--zd-card); }
.weather-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; flex-wrap: wrap; gap: 4px; }
.weather-badge { background: #1e40af; color: #fff; padding: 2px 8px; border-radius: 3px; font-size: 0.75rem; font-weight: 600; }
.weather-badge-medium { background: #7c3aed; }
.weather-meta { font-size: 0.75rem; color: var(--zd-text-muted); }
.weather-valid { font-size: 0.8rem; color: var(--zd-text-muted); margin-bottom: 8px; }
.weather-day { margin-bottom: 12px; padding-bottom: 8px; border-bottom: 1px dashed var(--zd-card-border); }
.weather-day:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
.weather-day-label { font-weight: 600; font-size: 0.85rem; margin-bottom: 4px; }
.weather-summary { font-size: 0.85rem; margin-bottom: 6px; font-style: italic; }
.weather-table { width: 100%; border-collapse: collapse; font-size: 0.8rem; margin: 6px 0; }
.weather-table th { background: var(--zd-input-bg); padding: 3px 6px; text-align: left; font-size: 0.7rem; color: var(--zd-text-muted); border-bottom: 1px solid var(--zd-card-border); }
.weather-table td { padding: 4px 6px; border-bottom: 1px solid var(--zd-card-border); }
.weather-period { font-family: 'Consolas', monospace; font-weight: 600; }
.weather-temp { font-weight: 600; }
.weather-comment { font-size: 0.8rem; margin-top: 6px; padding: 4px 8px; background: #fef3c7; border-radius: 3px; color: #92400e; }
[data-theme="dark"] .weather-comment { background: #4a3a1a; color: #fbbf24; }
.weather-reliability { font-size: 0.75rem; color: var(--zd-text-muted); margin-top: 4px; }
.weather-author { font-size: 0.7rem; color: var(--zd-text-muted); margin-top: 6px; text-align: right; }
.weather-situation { font-size: 0.85rem; margin-bottom: 10px; padding: 6px 8px; background: var(--zd-table-stripe); border-radius: 4px; }
.weather-medium-day { margin-bottom: 8px; }
.weather-medium-label { font-weight: 600; font-size: 0.8rem; color: var(--zd-accent); }
.weather-medium-text { font-size: 0.85rem; }
.weather-outlook { font-size: 0.85rem; margin-top: 8px; padding: 6px 8px; background: var(--zd-table-stripe); border-radius: 4px; }

/* ─── Compact duty timeline (dashboard) ─── */
.duty-compact { background: var(--zd-card); border: 1px solid var(--zd-card-border); border-radius: 8px; padding: 10px 14px; margin-bottom: 12px; }
.duty-compact-header { margin-bottom: 8px; }
.duty-compact-title { text-decoration: none; font-size: 0.78rem; font-weight: 700; color: var(--zd-text-muted); display: inline-flex; align-items: center; gap: 4px; }
.duty-compact-title:hover { color: var(--zd-accent); }

.duty-compact-grid { display: grid; grid-template-columns: 48px 1fr 1fr 1fr; gap: 3px; margin-bottom: 2px; align-items: center; }
.duty-compact-label { font-size: 0.68rem; font-weight: 600; color: var(--zd-text-muted); text-align: right; padding-right: 6px; white-space: nowrap; }

.duty-compact-shift-header { text-align: center; font-size: 0.62rem; color: var(--zd-text-muted); padding: 2px 0; border-radius: 4px; }
.duty-compact-shift-header.current { background: rgba(230, 126, 34, 0.1); font-weight: 700; }
.duty-compact-shift-name { display: block; font-weight: 600; font-size: 0.7rem; }
.duty-compact-shift-date { display: block; font-size: 0.6rem; opacity: 0.7; }

.duty-compact-section-label { font-size: 0.58rem; font-weight: 700; text-transform: uppercase; letter-spacing: 1.2px; color: var(--zd-text-muted); margin: 4px 0 2px; padding-left: 52px; }
.duty-compact-section-label.mk { color: #2563eb; }
.duty-compact-section-label.nmk { color: #059669; }

.duty-compact-cell { padding: 1px; }
.duty-compact-cell.current { position: relative; }

.duty-compact-bar { height: 24px; border-radius: 3px; display: flex; align-items: center; justify-content: center; font-size: 0.68rem; font-weight: 600; color: #fff; position: relative; overflow: hidden; transition: filter 0.15s; }
.duty-compact-bar:hover { filter: brightness(1.12); }
.duty-compact-bar.neurceno { background: var(--zd-table-stripe); color: var(--zd-text-muted); border: 1px dashed var(--zd-card-border); }
.duty-compact-bar.pracovni_pohotovost { background: #2563eb; }
.duty-compact-bar.domaci_pohotovost { background: #6b7280; }
.duty-compact-bar.cisteni { background: #059669; }
.duty-compact-bar.pohotovost_programy { background: #d97706; }

.duty-compact-bar-multi { display: flex; height: 24px; border-radius: 3px; overflow: hidden; position: relative; }
.duty-compact-bar-multi .duty-compact-bar { border-radius: 0; height: 100%; }
.duty-compact-bar-multi .duty-compact-bar:first-child { border-radius: 3px 0 0 3px; }
.duty-compact-bar-multi .duty-compact-bar:last-child { border-radius: 0 3px 3px 0; }

.duty-compact-bar-text { position: relative; z-index: 1; }

.duty-compact-now { position: absolute; top: -1px; bottom: -1px; width: 2px; background: #dc2626; z-index: 2; }
.duty-compact-now::after { content: ''; position: absolute; top: -2px; left: -2px; width: 6px; height: 6px; background: #dc2626; border-radius: 50%; }

.duty-compact-legend { display: flex; gap: 10px; margin-top: 6px; padding-left: 52px; }
.dcl-item { font-size: 0.6rem; color: var(--zd-text-muted); display: flex; align-items: center; gap: 3px; }
.dcl-dot { width: 8px; height: 8px; border-radius: 2px; display: inline-block; }

@media (max-width: 576px) {
    .duty-compact-grid { grid-template-columns: 36px 1fr 1fr 1fr; }
    .duty-compact-label { font-size: 0.6rem; padding-right: 3px; }
    .duty-compact-section-label { padding-left: 40px; }
    .duty-compact-legend { padding-left: 40px; }
    .duty-compact-bar { height: 20px; font-size: 0.6rem; }
}

/* Weather warning bars */
.weather-warning-bar { font-size: 0.85rem; border-radius: 4px; margin-bottom: 4px; }

@media print {
    .no-print { display: none !important; }
    body { background: #fff; color: #000; }
    .event-card { border: 1px solid #999; break-inside: avoid; background: #fff; color: #000; }
    .duty-compact { display: none; }
}

/* ═══ Beta feedback widget ═══════════════════════════════════════ */
.feedback-fab {
    position: fixed;
    right: 20px;
    bottom: 20px;
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: var(--zd-accent);
    color: #fff;
    border: none;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.25);
    font-size: 1.4rem;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1030;
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.feedback-fab:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.3);
    color: #fff;
}
.feedback-category-option {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.4rem 0.75rem;
    border: 1px solid var(--zd-card-border);
    border-radius: 6px;
    cursor: pointer;
    background: var(--zd-card);
    transition: background 0.15s, border-color 0.15s;
}
.feedback-category-option:hover {
    border-color: var(--zd-accent);
}
.feedback-category-option input[type="radio"] {
    margin: 0;
}
.feedback-category-option:has(input:checked) {
    background: var(--zd-accent);
    border-color: var(--zd-accent);
    color: #fff;
}
