:root {
    /* Firemní barvy KZ Valašské Meziříčí */
    --navy: #c3112f;       /* hlavní – červená KZ (tlačítka, akce) */
    --navy-dark: #9c0e26;  /* tmavší červená (hover) */
    --accent: #31276b;     /* doplňková – fialová KZ (odkazy, akcenty) */
    --bg: #f5f5f7;
    --card: #ffffff;
    --line: #e3e8ee;
    --text: #1f2933;
    --muted: #6b7785;
    --green: #1f9d55;
    --green-bg: #e6f6ec;
    --orange: #b9770e;
    --orange-bg: #fdf3e0;
    --red: #c0392b;
    --red-bg: #fbe9e7;
    --radius: 10px;
}

* { box-sizing: border-box; }

body {
    margin: 0;
    font-family: -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    color: var(--text);
    background: var(--bg);
    line-height: 1.5;
}

a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

.wrap { max-width: 920px; margin: 0 auto; padding: 0 18px; }

/* ---- Topbar (bílá hlavička s logem a barevným akcentem KZ) ---- */
.topbar { background: #fff; border-top: 4px solid var(--navy); border-bottom: 1px solid var(--line); }
.topbar.admin { border-top-color: var(--accent); } /* správa = fialový proužek KZ */
.topbar .bar { display: flex; align-items: center; justify-content: space-between; min-height: 64px; gap: 12px; }
.topbar .brand { display: flex; align-items: center; gap: 12px; color: #20222e; font-weight: 700; font-size: 16px; }
.topbar .brand:hover { text-decoration: none; }
.topbar .brand img { height: 42px; width: auto; display: block; }
.topbar .brand .brand-text { line-height: 1.15; }
.topbar .brand .brand-text small { display: block; font-weight: 400; font-size: 12px; color: var(--muted); }
.topbar nav { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.topbar nav a { color: #44454f; font-size: 15px; }
.topbar nav a:hover { color: var(--navy); text-decoration: none; }

main.wrap { padding-top: 26px; padding-bottom: 60px; }

h1 { font-size: 26px; margin: 0 0 14px; }
h2 { font-size: 19px; margin: 0 0 10px; }
.lead { color: var(--muted); max-width: 640px; margin-top: -4px; }
.muted { color: var(--muted); }
.small { font-size: 13px; }
.center { text-align: center; }
.empty { color: var(--muted); padding: 30px; text-align: center; background: var(--card); border-radius: var(--radius); border: 1px dashed var(--line); }

/* ---- Cards ---- */
.card {
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 20px;
    margin-bottom: 18px;
    box-shadow: 0 1px 2px rgba(16, 36, 56, .04);
}
.card-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.card-actions { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 12px; align-items: center; }
.meta { color: var(--muted); margin: 2px 0 12px; }
.popis { white-space: normal; }
.prose h2 { margin-top: 18px; }

/* Vstupné – nenápadný řádek */
.cena { margin: 6px 0 0; font-size: 14px; color: var(--muted); }
.cena strong { color: var(--text); font-weight: 600; }

/* Plakát / obrázek pořadu */
.porad-top { display: flex; gap: 18px; align-items: flex-start; }
.porad-text { flex: 1; min-width: 0; }
.porad-foto { width: 96px; aspect-ratio: 2 / 3; object-fit: cover; object-position: center top; border-radius: 8px; flex: none; border: 1px solid var(--line); background: #f0f0f3; }
@media (max-width: 560px) { .porad-foto { width: 72px; } }

/* ---- Tags / pills / badges ---- */
.tag { display: inline-block; background: #ece9f5; color: var(--accent); font-size: 12px; padding: 2px 9px; border-radius: 20px; margin-left: 6px; vertical-align: middle; }
.tag-muted { background: #f0e6e6; color: var(--red); }

.badge { display: inline-block; font-size: 13px; font-weight: 600; padding: 4px 11px; border-radius: 20px; }
.badge-volno, .badge-volno  { background: var(--green-bg); color: var(--green); }
.badge-malo { background: var(--orange-bg); color: var(--orange); }
.badge-plno, .badge-uzavreno { background: var(--red-bg); color: var(--red); }

.pill { display: inline-block; font-size: 12px; padding: 2px 9px; border-radius: 6px; text-transform: capitalize; }
.pill-otevreny { background: var(--green-bg); color: var(--green); }
.pill-uzavreny { background: var(--orange-bg); color: var(--orange); }
.pill-zruseny  { background: var(--red-bg); color: var(--red); }

/* ---- Termíny (veřejné) – seskupené po dnech, zarovnané sloupce ---- */
.den + .den { margin-top: 2px; }
.den-datum { display: flex; align-items: center; gap: 8px; font-weight: 700; font-size: 14px; color: #20222e; margin: 16px 0 4px; }
.den-datum::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--accent); flex: none; }
.den-sal { font-weight: 400; color: var(--muted); }
.terminy { list-style: none; padding: 0; margin: 0; }
.termin-row { display: grid; grid-template-columns: 140px auto 1fr; align-items: center; gap: 4px 16px; padding: 7px 10px; border-radius: 8px; }
.termin-row + .termin-row { border-top: 1px solid #f2f2f5; }
.termin-row:hover { background: #faf9fb; }
.t-cas { font-weight: 600; color: #20222e; font-size: 15px; }
.t-cas .t-sal { font-weight: 400; color: var(--muted); font-size: 13px; }
.t-badge { justify-self: start; }
.t-akce { justify-self: end; } /* tlačítko k pravému okraji */

@media (max-width: 560px) {
    .termin-row { grid-template-columns: 1fr auto; gap: 2px 10px; }
    .termin-row .t-cas { grid-column: 1 / -1; }
}

/* ---- Přepínač pohledů ---- */
.viewswitch { display: inline-flex; border: 1px solid var(--line); border-radius: 8px; overflow: hidden; margin-bottom: 22px; }
.viewswitch a { padding: 7px 15px; font-size: 14px; color: #44454f; background: #fff; }
.viewswitch a:hover { text-decoration: none; background: #f5f5f7; }
.viewswitch a.active { background: var(--navy); color: #fff; }
.viewswitch a + a { border-left: 1px solid var(--line); }

/* ---- Filtr-bar (Verze B) ---- */
.filterbar { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; background: #fff; border: 1px solid var(--line); border-radius: 10px; padding: 12px 14px; }
.chips { display: flex; gap: 6px; flex-wrap: wrap; }
.chip { border: 1px solid var(--line); background: #f5f5f7; color: #2c2d36; padding: 6px 14px; border-radius: 20px; font-size: 14px; cursor: pointer; font-family: inherit; text-decoration: none; }
.chip:hover { background: #ececf0; text-decoration: none; }
.chip.active { background: var(--navy); color: #fff; border-color: var(--navy); }
.chip.active:hover { background: var(--navy-dark); }
.filterbar .hledat { flex: 1; min-width: 170px; padding: 9px 12px; border: 1px solid #cdd6df; border-radius: 8px; font-size: 15px; font-family: inherit; }
.filterbar .hledat:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px rgba(49, 39, 107, .15); }
.filterbar .chk { display: flex; align-items: center; gap: 6px; font-size: 14px; color: #44454f; white-space: nowrap; }
.vysledek { color: var(--muted); font-size: 13px; margin: 8px 2px 18px; }
.filterbar .adm-select { padding: 8px 10px; border: 1px solid #cdd6df; border-radius: 8px; font-size: 14px; font-family: inherit; background: #fff; color: #2c2d36; }
.adm-souhrn { margin: -2px 0 16px; font-size: 14px; }
.adm-souhrn b { color: #20222e; }

/* ---- Katalogová mřížka (Verze B) ---- */
.katalog { display: grid; grid-template-columns: repeat(auto-fill, minmax(330px, 1fr)); gap: 16px; align-items: start; }
.kkarta { background: var(--card); border: 1px solid var(--line); border-radius: 10px; padding: 16px; box-shadow: 0 1px 2px rgba(16, 36, 56, .04); }
.kkarta-top { display: flex; gap: 14px; align-items: flex-start; }
.kfoto { width: 74px; aspect-ratio: 2 / 3; object-fit: cover; object-position: center top; border-radius: 6px; flex: none; border: 1px solid var(--line); background: #f0f0f3; }
.kfoto--placeholder { display: flex; align-items: center; justify-content: center; font-size: 30px; }
.kkarta-info { flex: 1; min-width: 0; }
.kkarta-info h2 { font-size: 17px; margin: 0 0 6px; }
.popis-zkr { color: var(--muted); font-size: 13px; margin: 6px 0; }
.popis-plny { color: var(--text); font-size: 14px; margin: 0 0 10px; }
.souhrn { font-size: 13px; color: var(--accent); font-weight: 600; margin: 8px 0 0; }
.kterminy { margin-top: 12px; border-top: 1px solid var(--line); padding-top: 6px; }
.kterminy > summary { cursor: pointer; color: var(--accent); font-weight: 600; font-size: 14px; list-style: none; padding: 5px 0; }
.kterminy > summary::-webkit-details-marker { display: none; }
.kterminy > summary::before { content: "▾ "; font-size: 11px; }
.kterminy[open] > summary::before { content: "▴ "; }

/* ---- Kalendář (Verze C) ---- */
.kal-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin: 22px 0 10px; }
.kal-head h2 { margin: 0; font-size: 20px; }
.kal-legenda { display: flex; gap: 16px; font-size: 13px; color: var(--muted); margin: 4px 0 16px; flex-wrap: wrap; }
.kal-legenda i { display: inline-block; width: 10px; height: 10px; border-radius: 50%; margin-right: 5px; vertical-align: middle; }
.kal-grid { display: grid; grid-template-columns: repeat(7, minmax(0, 1fr)); gap: 6px; }
.kal-dow { text-align: center; font-weight: 600; font-size: 12px; color: var(--muted); padding: 4px 0; text-transform: uppercase; letter-spacing: .03em; }
.kal-cell { min-width: 0; min-height: 82px; border: 1px solid var(--line); border-radius: 8px; padding: 5px; background: #fff; display: flex; flex-direction: column; gap: 3px; }
.kal-cell--out { background: #fafafb; opacity: .5; }
.kal-cell--today { border-color: var(--navy); box-shadow: 0 0 0 2px rgba(195, 17, 47, .15); }
.kal-den { font-size: 12px; font-weight: 700; color: #6b7280; }
.kal-cell--today .kal-den { color: var(--navy); }
.kal-ud { display: block; font-size: 11.5px; line-height: 1.3; padding: 2px 6px; border-radius: 5px; border-left: 3px solid var(--green); background: var(--green-bg); color: #1f3d2a; text-decoration: none; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.kal-ud:hover { text-decoration: none; filter: brightness(.96); }
.kal-ud b { font-weight: 700; }
.kal-ud.s-malo { border-left-color: var(--orange); background: var(--orange-bg); color: #7a4f0a; }
.kal-ud.s-plno, .kal-ud.s-uzavreno { border-left-color: var(--red); background: var(--red-bg); color: #7a1f17; }
.kal-agenda { display: none; }
@media (max-width: 700px) {
    .kal-grid { display: none; }
    .kal-agenda { display: block; }
}

/* Rozbalení dalších termínů */
details.vice-terminu { margin-top: 2px; }
details.vice-terminu > summary { cursor: pointer; color: var(--accent); font-weight: 600; font-size: 14px; padding: 10px 0; list-style: none; display: inline-flex; align-items: center; gap: 6px; }
details.vice-terminu > summary::-webkit-details-marker { display: none; }
details.vice-terminu > summary::before { content: "▾"; font-size: 11px; }
details.vice-terminu[open] > summary::before { content: "▴"; }

/* ---- Buttons ---- */
.btn { display: inline-block; background: #f0f0f3; color: #2c2d36; border: 1px solid var(--line); padding: 8px 14px; border-radius: 8px; font-size: 14px; cursor: pointer; line-height: 1.2; }
.btn:hover { background: #e3e9ef; text-decoration: none; }
.btn-primary { background: var(--navy); color: #fff; border-color: var(--navy); }
.btn-primary:hover { background: var(--navy-dark); }
.btn-danger { background: #fff; color: var(--red); border-color: #e7c3bd; }
.btn-danger:hover { background: var(--red-bg); }
.btn-sm { padding: 5px 10px; font-size: 13px; }
.linkbtn { background: none; border: none; color: var(--accent); cursor: pointer; font-size: 13px; padding: 0; }
.inline { display: inline; }

/* ---- Forms ---- */
.form .field { margin-bottom: 14px; }
.field label { display: block; font-weight: 600; font-size: 14px; margin-bottom: 5px; }
.field input, .field select, .field textarea {
    width: 100%; padding: 9px 11px; border: 1px solid #cdd6df; border-radius: 8px; font-size: 15px; font-family: inherit; background: #fff;
}
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px rgba(29, 122, 140, .15); }
.field.check label { font-weight: 400; display: flex; align-items: center; gap: 8px; }
.field.check input { width: auto; }
.row { display: flex; gap: 14px; flex-wrap: wrap; }
.row .field { flex: 1; min-width: 160px; }
.err { color: var(--red); font-size: 13px; display: block; margin-top: 4px; }
.hp { position: absolute; left: -9999px; height: 0; overflow: hidden; }

/* ---- Flash ---- */
.flash { padding: 12px 16px; border-radius: 8px; margin-bottom: 16px; font-size: 15px; }
.flash-success { background: var(--green-bg); color: #176c3b; }
.flash-error { background: var(--red-bg); color: var(--red); }

/* ---- Tables (admin) ---- */
.tbl { width: 100%; border-collapse: collapse; margin-top: 6px; font-size: 14px; }
.tbl th, .tbl td { text-align: left; padding: 9px 10px; border-bottom: 1px solid var(--line); vertical-align: top; }
.tbl th { color: var(--muted); font-weight: 600; font-size: 12px; text-transform: uppercase; letter-spacing: .02em; }
.tbl td.actions { white-space: nowrap; display: flex; gap: 6px; flex-wrap: wrap; }
.row-cancelled td { opacity: .5; }

.bar-mini { display: inline-block; width: 90px; height: 7px; background: var(--line); border-radius: 4px; overflow: hidden; vertical-align: middle; margin-left: 6px; }
.bar-mini span { display: block; height: 100%; background: var(--accent); }

/* ---- Admin layout helpers ---- */
.bar { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.login-wrap { max-width: 380px; margin: 40px auto; }

/* ---- Dropdown (přesun) ---- */
details.dd { display: inline-block; position: relative; }
details.dd summary { list-style: none; }
details.dd summary::-webkit-details-marker { display: none; }
details.dd .dd-body { position: absolute; z-index: 10; top: 110%; left: 0; width: 260px; background: #fff; border: 1px solid var(--line); border-radius: 8px; padding: 12px; box-shadow: 0 6px 20px rgba(16, 36, 56, .12); display: flex; flex-direction: column; gap: 8px; }
details.dd .dd-body select { padding: 7px; border: 1px solid #cdd6df; border-radius: 6px; }

/* ---- Footer ---- */
.footer { border-top: 1px solid var(--line); padding: 18px 0; color: var(--muted); font-size: 14px; background: #fff; }
.footer-inner { display: flex; justify-content: space-between; gap: 10px 18px; flex-wrap: wrap; }

@media (max-width: 560px) {
    .topbar .bar { flex-direction: column; align-items: flex-start; gap: 6px; padding: 10px 0; }
    h1 { font-size: 22px; }
}
