/* =====================================================================
   Programové období 28+  —  motiv nad Bootstrap 5.3
   Moderní vládní styl: modrá primární, národní červená jako „nyní“,
   Archivo (nadpisy) + IBM Plex Sans (text), přístupný focus.
   ===================================================================== */

:root{
  /* ---- barevné tokeny ---- */
  --p-ink:#1b2434;
  --p-ink-soft:#465063;
  --p-muted:#5c6678;
  --p-primary:#215fa5;
  --p-primary-600:#1c5292;
  --p-primary-700:#173e6b;
  --p-primary-900:#0f2a49;
  --p-primary-050:#eaf1f9;
  --p-primary-100:#d6e4f2;
  --p-red:#d7141a;
  --p-red-600:#b3111a;
  --p-red-050:#fbe6e7;
  --p-surface:#ffffff;
  --p-bg:#f4f7fa;
  --p-bg-2:#e9eff6;
  --p-border:#d9e1ec;
  --p-border-strong:#7d8ba6; /* okraj ovládacích prvků – kontrast ≥3:1 (WCAG 1.4.11) */
  --p-line:#e8edf4;
  --p-focus:#ffbf00;

  /* ---- přepis Bootstrap proměnných ---- */
  --bs-primary:#215fa5;
  --bs-primary-rgb:33,95,165;
  --bs-body-color:#1b2434;
  --bs-body-color-rgb:27,36,52;
  --bs-body-bg:#ffffff;
  --bs-secondary-color:rgba(27,36,52,.74);
  --bs-body-font-family:'IBM Plex Sans', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --bs-body-font-size:1.0625rem;
  --bs-body-font-weight:400;
  --bs-body-line-height:1.62;
  --bs-emphasis-color:#1b2434;
  --bs-heading-color:#1b2434;
  --bs-border-color:#d9e1ec;
  --bs-border-radius:.6rem;
  --bs-border-radius-sm:.4rem;
  --bs-border-radius-lg:.9rem;
  --bs-border-radius-xl:1.1rem;
  --bs-link-color-rgb:28,82,146;
  --bs-link-hover-color-rgb:15,42,73;
  --bs-link-decoration:none;
}

*{ text-underline-offset:.16em; }

body{
  background:var(--p-surface);
  color:var(--p-ink);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}

h1,h2,h3,h4,h5,h6,.display-1,.display-2,.display-3,.display-4,.display-5,.display-6{
  font-family:'Archivo','IBM Plex Sans',sans-serif;
  color:var(--p-ink);
  letter-spacing:-.015em;
  line-height:1.12;
  font-weight:800;
}
h4,h5,h6,.h4,.h5,.h6{ font-weight:700; letter-spacing:-.01em; }

a{ color:rgb(var(--bs-link-color-rgb)); }
a:hover{ color:rgb(var(--bs-link-hover-color-rgb)); }

strong,b{ font-weight:600; }

/* přístupnost – dobře viditelný focus */
a:focus-visible,button:focus-visible,.btn:focus-visible,
.nav-link:focus-visible,.form-control:focus-visible,
.rc-card:focus-visible,.tl-card:focus-visible,.ql:focus-visible,
[tabindex]:focus-visible{
  outline:3px solid var(--p-focus);
  outline-offset:2px;
  box-shadow:none;
  border-radius:.3rem;
}
.form-control:focus{ border-color:var(--p-primary); box-shadow:0 0 0 .2rem rgba(33,95,165,.18); }

/* přístupnost – přeskočení na obsah (WCAG 2.4.1) */
.skip-link{ position:absolute; left:1rem; top:.75rem; z-index:2000; transform:translateY(-160%);
  background:var(--p-primary-900); color:#fff; font-family:'Archivo',sans-serif; font-weight:600;
  padding:.6rem 1rem; border-radius:.5rem; text-decoration:none; box-shadow:0 6px 20px rgba(0,0,0,.35);
  transition:transform .15s ease; }
.skip-link:focus{ transform:translateY(0); color:#fff; outline:3px solid var(--p-focus); outline-offset:2px; }
main:focus{ outline:none; }

::selection{ background:var(--p-primary); color:#fff; }

/* ---------- pomocné třídy ---------- */
.section{ padding:clamp(3rem,6vw,5.5rem) 0; }
.section-sm{ padding:clamp(2.25rem,4vw,3.5rem) 0; }
.section-alt{ background:var(--p-bg); }
.bg-deep{ background:var(--p-primary-900); color:#e7eefb; }

.container-xl{ max-width:1240px; }

.eyebrow{
  font-family:'Archivo',sans-serif;
  font-weight:700; font-size:.8rem; text-transform:uppercase;
  letter-spacing:.16em; color:var(--p-primary);
  display:inline-flex; align-items:center; gap:.65rem; margin:0 0 .9rem;
}
.eyebrow::before{ content:""; width:26px; height:3px; border-radius:2px;
  background:linear-gradient(90deg,var(--p-primary) 50%,var(--p-red) 50%); }
.eyebrow-light{ color:#8fb4e0; }
.eyebrow-light::before{ background:linear-gradient(90deg,#8fb4e0 50%,#e8737a 50%); }

.section-title{ font-size:clamp(1.7rem,3.1vw,2.5rem); margin:0; }
.lead-lg{ color:var(--p-ink-soft); font-size:1.18rem; max-width:58ch; }
.text-accent{ color:var(--p-red-600); }
.text-primary-2{ color:var(--p-primary); }

.tricolor-rule{ height:4px; width:100%;
  background:linear-gradient(90deg,var(--p-primary) 0 40%,var(--p-red) 40% 70%,#ffffff 70% 100%); }

/* ---------- tlačítka ---------- */
.btn{ font-family:'Archivo',sans-serif; font-weight:600; letter-spacing:.005em;
  padding:.62rem 1.15rem; border-radius:.5rem; display:inline-flex; align-items:center;
  gap:.5rem; transition:transform .12s ease, background-color .15s, box-shadow .15s; }
.btn:active{ transform:translateY(1px); }
.btn-lg{ padding:.85rem 1.5rem; font-size:1.05rem; }
.btn i{ font-size:1.05em; }
.btn-primary{
  --bs-btn-bg:var(--p-primary); --bs-btn-border-color:var(--p-primary);
  --bs-btn-hover-bg:var(--p-primary-700); --bs-btn-hover-border-color:var(--p-primary-700);
  --bs-btn-active-bg:var(--p-primary-900); --bs-btn-active-border-color:var(--p-primary-900);
  --bs-btn-color:#fff; --bs-btn-hover-color:#fff; --bs-btn-active-color:#fff;
  box-shadow:0 10px 22px -12px rgba(33,95,165,.65);
}
.btn-outline-primary{
  --bs-btn-color:var(--p-primary-700); --bs-btn-border-color:var(--p-border-strong);
  --bs-btn-hover-bg:var(--p-primary); --bs-btn-hover-border-color:var(--p-primary);
  --bs-btn-hover-color:#fff; --bs-btn-active-bg:var(--p-primary-700);
}
.btn-outline-light{ --bs-btn-border-color:rgba(255,255,255,.5); --bs-btn-hover-bg:#fff; --bs-btn-hover-color:var(--p-primary-900); }
.btn-ghost{ background:transparent; color:var(--p-primary-700); border:0; }
.btn-ghost:hover{ background:var(--p-bg-2); color:var(--p-primary-900); }

/* ============================================================
   HLAVIČKA
   ============================================================ */
.site-topbar{ background:var(--p-primary-900); color:#c3d2e8; font-size:.82rem; }
.site-topbar .container-xl{ min-height:40px; padding-top:.35rem; padding-bottom:.35rem; }
.topbar-note{ opacity:.9; }
.site-topbar a{ color:#c3d2e8; display:inline-flex; align-items:center; min-height:24px; padding:.15rem .3rem; }
.site-topbar a:hover{ color:#fff; }
.topbar-div{ width:1px; height:14px; background:rgba(255,255,255,.22); display:inline-block; }
.lang{ display:inline-flex; align-items:center; gap:.15rem; font-family:'Archivo',sans-serif; font-weight:600; }
.lang a{ padding:.25rem .55rem; border-radius:.3rem; min-height:24px; display:inline-flex; align-items:center; }
.lang .lang-cur{ background:rgba(255,255,255,.14); color:#fff; }
.lang .lang-off{ opacity:.5; cursor:not-allowed; }
.lang .lang-off:hover{ opacity:.7; color:#c3d2e8; }

.navbar-main{ position:sticky; top:0; z-index:1030; background:#fff; box-shadow:0 1px 0 var(--p-line); }
.navbar-main .navbar{ padding-top:.55rem; padding-bottom:.55rem; }

.brandmark{ display:inline-flex; align-items:center; gap:.7rem; text-decoration:none; }
.brandmark .mark{ font-family:'Archivo',sans-serif; font-weight:800; font-size:1.5rem; line-height:1;
  letter-spacing:-.04em; background:var(--p-primary); color:#fff; padding:.28rem .5rem .3rem;
  border-radius:.5rem; }
.brandmark .mark .plus{ color:#ffd23a; }
.brandmark .wm{ display:flex; flex-direction:column; line-height:1.05; }
.brandmark .wm-1{ font-family:'Archivo',sans-serif; font-weight:800; font-size:1.02rem; color:var(--p-ink); letter-spacing:-.01em; }
.brandmark .wm-2{ font-size:.72rem; letter-spacing:.05em; text-transform:uppercase; color:var(--p-muted); }
.brandmark-light .wm-1{ color:#fff; }
.brandmark-light .wm-2{ color:#9fb4d2; }

.navbar-main .nav-link{ font-family:'Archivo',sans-serif; font-weight:600; color:var(--p-ink);
  padding:.5rem .85rem; border-radius:.45rem; position:relative; }
.navbar-main .nav-link:hover{ color:var(--p-primary); background:var(--p-bg); }
.navbar-main .nav-link.active{ color:var(--p-primary-700); }
.navbar-main .nav-link.active::after{ content:""; position:absolute; left:.85rem; right:.85rem; bottom:.2rem;
  height:3px; border-radius:2px; background:var(--p-red); }
.navbar-toggler{ border:1px solid var(--p-border-strong); border-radius:.5rem; font-size:1.35rem; color:var(--p-primary-700);
  padding:.25rem .55rem; line-height:1; }
.navbar-toggler:focus{ box-shadow:none; }

.header-search{ position:relative; }
.header-search .form-control{ border-radius:999px; padding:.45rem 2.4rem .45rem 1rem; border-color:var(--p-border-strong);
  background:var(--p-bg); min-width:210px; font-size:.95rem; }
.header-search .btn{ position:absolute; right:.15rem; top:50%; transform:translateY(-50%); background:transparent;
  color:var(--p-primary); padding:.3rem .5rem; border:0; }
.offcanvas{ max-width:88vw; }
.offcanvas-body .navbar-nav .nav-link{ padding:.7rem .25rem; border-bottom:1px solid var(--p-line); border-radius:0; }
@media (min-width:992px){ .offcanvas-body .navbar-nav .nav-link{ border-bottom:0; } }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; background:radial-gradient(1200px 520px at 82% -10%, #1c4f8a 0, transparent 60%),
  linear-gradient(160deg,#123a63 0%, var(--p-primary-900) 62%); color:#e9f0fb; overflow:hidden; }
.hero::after{ content:"28+"; position:absolute; right:-.06em; bottom:-.34em; font-family:'Archivo',sans-serif;
  font-weight:800; font-size:min(34rem,44vw); line-height:.8; color:rgba(255,255,255,.045);
  letter-spacing:-.04em; pointer-events:none; user-select:none; }
.hero .container-xl{ position:relative; z-index:1; }
.hero h1{ color:#fff; font-size:clamp(2.1rem,4.3vw,3.5rem); }
.hero-lead{ color:#c5d5ea; font-size:1.22rem; max-width:44ch; }
.phase-pill{ display:inline-flex; align-items:center; gap:.6rem; background:rgba(255,255,255,.09);
  border:1px solid rgba(255,255,255,.16); border-radius:999px; padding:.4rem .9rem .4rem .5rem;
  font-size:.92rem; color:#dbe6f6; }
.phase-pill .dot{ width:10px; height:10px; border-radius:50%; background:var(--p-red);
  box-shadow:0 0 0 4px rgba(215,20,26,.28); animation:pulse 2.4s infinite; }
@keyframes pulse{ 0%,100%{ box-shadow:0 0 0 4px rgba(215,20,26,.28);} 50%{ box-shadow:0 0 0 7px rgba(215,20,26,.12);} }

/* karta „aktuální fáze" v hero */
.status-card{ background:#fff; color:var(--p-ink); border-radius:1.1rem; padding:1.5rem 1.5rem 1.35rem;
  box-shadow:0 40px 80px -40px rgba(0,0,0,.6); }
.status-card .sc-year{ font-family:'Archivo',sans-serif; font-weight:800; font-size:2.6rem; line-height:1; color:var(--p-primary); }
.status-steps{ list-style:none; margin:1rem 0 0; padding:0; }
.status-steps li{ display:flex; gap:.75rem; align-items:flex-start; padding:.5rem 0; position:relative; }
.status-steps li + li{ border-top:1px solid var(--p-line); }
.status-steps .st-ico{ flex:0 0 auto; width:26px; height:26px; border-radius:50%; display:grid; place-items:center;
  font-size:.82rem; font-weight:700; }
.status-steps .done .st-ico{ background:var(--p-primary); color:#fff; }
.status-steps .now .st-ico{ background:var(--p-red); color:#fff; box-shadow:0 0 0 4px var(--p-red-050); }
.status-steps .todo .st-ico{ background:#fff; border:2px dashed var(--p-primary-100); color:var(--p-muted); }
.status-steps .st-txt{ font-size:.95rem; font-weight:500; }
.status-steps .now .st-txt{ font-weight:700; color:var(--p-red-600); }
.status-steps .todo .st-txt{ color:var(--p-muted); }

/* ============================================================
   ROZCESTNÍK (role) + rychlé odkazy (co hledáte)
   ============================================================ */
.rc-card{ display:flex; flex-direction:column; gap:.7rem; height:100%; background:#fff;
  border:1px solid var(--p-border); border-radius:.95rem; padding:1.5rem 1.4rem 1.3rem;
  text-decoration:none; color:inherit; position:relative; overflow:hidden;
  transition:transform .18s ease, box-shadow .18s, border-color .18s; }
.rc-card::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:4px;
  background:var(--p-red); transform:scaleY(0); transform-origin:top; transition:transform .2s ease; }
.rc-card:hover{ transform:translateY(-4px); border-color:var(--p-primary);
  box-shadow:0 24px 44px -26px rgba(20,50,90,.5); }
.rc-card:hover::before{ transform:scaleY(1); }
.rc-ico{ width:54px; height:54px; border-radius:.8rem; display:grid; place-items:center;
  background:var(--p-primary-050); color:var(--p-primary); font-size:1.55rem; }
.rc-title{ font-family:'Archivo',sans-serif; font-weight:700; font-size:1.18rem; margin:.15rem 0 0; }
.rc-desc{ font-size:.95rem; color:var(--p-ink-soft); margin:0; }
.rc-go{ margin-top:auto; padding-top:.35rem; color:var(--p-primary); font-family:'Archivo',sans-serif;
  font-weight:600; font-size:.95rem; display:inline-flex; align-items:center; gap:.45rem; }
.rc-card:hover .rc-go{ color:var(--p-red-600); gap:.7rem; }

.ql{ display:flex; align-items:center; gap:.85rem; padding:.95rem 1.05rem; border:1px solid var(--p-border);
  border-radius:.65rem; background:#fff; text-decoration:none; color:var(--p-ink); font-weight:600;
  font-family:'Archivo',sans-serif; transition:.15s; height:100%; }
.ql i{ color:var(--p-primary); font-size:1.25rem; flex:0 0 auto; }
.ql .ql-arrow{ margin-left:auto; color:var(--p-muted); transition:.15s; }
.ql:hover{ border-color:var(--p-primary); background:var(--p-primary-050); }
.ql:hover .ql-arrow{ color:var(--p-primary); transform:translateX(3px); }

/* ============================================================
   AKTUALITY
   ============================================================ */
.news-card{ display:flex; flex-direction:column; height:100%; background:#fff; border:1px solid var(--p-border);
  border-radius:.85rem; overflow:hidden; text-decoration:none; color:inherit; transition:.18s; }
.news-card:hover{ transform:translateY(-3px); box-shadow:0 22px 40px -26px rgba(20,50,90,.45); border-color:var(--p-primary); }
.news-top{ padding:1.25rem 1.3rem .4rem; display:flex; align-items:center; gap:.6rem; }
.news-tag{ font-family:'Archivo',sans-serif; font-weight:700; font-size:.7rem; text-transform:uppercase;
  letter-spacing:.08em; color:var(--p-primary); background:var(--p-primary-050); padding:.22rem .55rem; border-radius:.35rem; }
.news-date{ font-size:.82rem; color:var(--p-muted); }
.news-body{ padding:.35rem 1.3rem 1.3rem; }
.news-title{ font-family:'Archivo',sans-serif; font-weight:700; font-size:1.1rem; margin:.2rem 0 .4rem; line-height:1.25; }
.news-excerpt{ font-size:.92rem; color:var(--p-ink-soft); margin:0; }

/* ============================================================
   ČASOVÁ OSA
   ============================================================ */
.tl-legend{ display:flex; flex-wrap:wrap; gap:1.4rem; }
.tl-legend .li{ display:inline-flex; align-items:center; gap:.5rem; font-size:.92rem; font-weight:600; color:var(--p-ink-soft); }
.tl-legend .sw{ width:20px; height:20px; border-radius:6px; flex:0 0 auto; }
.tl-legend .sw-past{ background:var(--p-primary); }
.tl-legend .sw-now{ background:var(--p-red); }
.tl-legend .sw-fut{ background:#fff; border:2px dashed var(--p-primary); }

.tl-toolbar{ display:flex; align-items:center; gap:.6rem; }
.tl-scrollbtn{ width:46px; height:46px; border-radius:50%; border:1px solid var(--p-border-strong); background:#fff;
  color:var(--p-primary-700); font-size:1.25rem; display:grid; place-items:center; transition:.15s; flex:0 0 auto; }
.tl-scrollbtn:hover{ background:var(--p-primary); color:#fff; border-color:var(--p-primary); }
.tl-scrollbtn:disabled{ opacity:.4; cursor:not-allowed; }

.tl-wrap{ position:relative; }
.tl-scroller{ overflow-x:auto; overflow-y:hidden; padding:4px 2px 20px; cursor:grab;
  scroll-behavior:smooth; -webkit-overflow-scrolling:touch;
  scrollbar-color:var(--p-primary) var(--p-bg-2); scrollbar-width:thin; }
.tl-scroller.dragging{ cursor:grabbing; scroll-behavior:auto; }
.tl-scroller::-webkit-scrollbar{ height:12px; }
.tl-scroller::-webkit-scrollbar-track{ background:var(--p-bg-2); border-radius:999px; }
.tl-scroller::-webkit-scrollbar-thumb{ background:var(--p-primary); border-radius:999px; border:3px solid var(--p-bg-2); }
.tl-scroller::-webkit-scrollbar-thumb:hover{ background:var(--p-primary-700); }

.tl-track{ position:relative; display:flex; min-width:max-content; padding-bottom:6px; }
.tl-axis{ position:absolute; left:8px; right:8px; top:65px; height:3px; border-radius:2px;
  background:linear-gradient(90deg,var(--p-primary-100),var(--p-border)); z-index:0; }

.tl-col{ flex:0 0 268px; width:268px; padding:0 12px; position:relative; }
.tl-col.is-current{ background:linear-gradient(180deg,rgba(215,20,26,.07),rgba(215,20,26,0) 240px); border-radius:14px; }
.tl-head{ position:relative; height:82px; }
.tl-flag{ position:absolute; top:0; left:50%; transform:translateX(-50%);
  font-family:'Archivo',sans-serif; font-weight:800; font-size:.68rem; letter-spacing:.14em;
  color:#fff; background:var(--p-red); padding:.16rem .5rem; border-radius:999px; }
.tl-year{ position:absolute; top:26px; left:0; right:0; text-align:center;
  font-family:'Archivo',sans-serif; font-weight:800; font-size:1.45rem; color:var(--p-muted); }
.tl-col.is-past .tl-year{ color:var(--p-primary-700); }
.tl-col.is-current .tl-year{ color:var(--p-red-600); }
.tl-node{ position:absolute; top:59px; left:50%; transform:translateX(-50%); width:16px; height:16px;
  border-radius:50%; background:#fff; border:3px solid var(--p-primary-100); z-index:2; }
.tl-col.is-past .tl-node{ background:var(--p-primary); border-color:var(--p-primary); }
.tl-col.is-current .tl-node{ background:var(--p-red); border-color:var(--p-red); box-shadow:0 0 0 6px rgba(215,20,26,.2); }

.tl-body{ margin-top:6px; display:flex; flex-direction:column; gap:12px; }
.tl-card{ background:#fff; border:1px solid var(--p-border); border-left-width:4px; border-radius:.7rem;
  padding:.85rem .95rem .95rem; position:relative; transition:transform .16s ease, box-shadow .16s; }
.tl-card.is-past{ border-left-color:var(--p-primary); }
.tl-card.is-current{ border-left-color:var(--p-red); background:#fff7f7; }
.tl-card.is-future{ border-left-style:dashed; border-left-color:var(--p-primary-100); }
.tl-card:hover,.tl-card:focus-within{ transform:translateY(-3px); box-shadow:0 20px 40px -22px rgba(20,50,90,.55); z-index:5; }
.tl-chip{ display:inline-flex; align-items:center; gap:.3rem; font-family:'Archivo',sans-serif; font-weight:700;
  font-size:.66rem; text-transform:uppercase; letter-spacing:.06em; padding:.2rem .5rem; border-radius:999px; }
.is-past .tl-chip{ background:var(--p-primary-050); color:var(--p-primary-700); }
.is-current .tl-chip{ background:var(--p-red); color:#fff; }
.is-future .tl-chip{ background:#fff; color:var(--p-primary); border:1px dashed var(--p-primary-100); }
.tl-date{ font-size:.78rem; font-weight:600; color:var(--p-muted); margin-top:.45rem; display:flex; align-items:center; gap:.3rem; }
.tl-title{ font-family:'Archivo',sans-serif; font-weight:700; font-size:1.02rem; line-height:1.2; margin:.2rem 0 .35rem; }
.tl-desc{ font-size:.9rem; color:var(--p-ink-soft); margin:0; }
.tl-extra{ max-height:0; opacity:0; overflow:hidden; transition:max-height .3s ease, opacity .22s ease; }
.tl-card:hover .tl-extra,.tl-card:focus-within .tl-extra{ max-height:260px; opacity:1; margin-top:.6rem; }
.tl-extra-inner{ border-top:1px dashed var(--p-border); padding-top:.55rem; font-size:.86rem; color:var(--p-ink-soft); }
.tl-hint{ font-size:.78rem; color:var(--p-primary); font-weight:600; display:flex; align-items:center; gap:.3rem; margin-top:.55rem; }
.tl-card:hover .tl-hint,.tl-card:focus-within .tl-hint{ display:none; }

.tl-fade{ position:absolute; top:0; bottom:14px; width:46px; pointer-events:none; z-index:3; opacity:0; transition:opacity .2s; }
.tl-fade-l{ left:0; background:linear-gradient(90deg,var(--p-bg),transparent); }
.tl-fade-r{ right:0; background:linear-gradient(270deg,var(--p-bg),transparent); }
.tl-wrap.show-l .tl-fade-l{ opacity:1; }
.tl-wrap.show-r .tl-fade-r{ opacity:1; }

/* mini náhled osy na úvodu (bez ovládání) */
.tl-preview .tl-scroller{ cursor:auto; padding-bottom:8px; }
.tl-preview .tl-col{ flex-basis:240px; width:240px; }

/* ============================================================
   PATIČKA
   ============================================================ */
.site-footer{ background:var(--p-primary-900); color:#a9bcd6; font-size:.95rem; }
.site-footer a{ color:#c6d5ea; }
.site-footer a:hover{ color:#fff; text-decoration:underline; }
.footer-desc{ color:#9fb2cf; max-width:38ch; margin:1rem 0 1.2rem; font-size:.92rem; }
.footer-title{ font-family:'Archivo',sans-serif; font-weight:700; color:#fff; font-size:.82rem;
  text-transform:uppercase; letter-spacing:.1em; margin-bottom:1rem; }
.footer-links{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:.6rem; }
.footer-links a{ display:inline-flex; align-items:center; gap:.4rem; }
.logo-slots{ display:flex; gap:.75rem; flex-wrap:wrap; }
.logo-slot{ border:1px dashed rgba(255,255,255,.28); border-radius:.5rem; padding:.6rem .8rem;
  font-size:.72rem; line-height:1.3; color:#9fb2cf; text-align:center; min-width:96px; background:rgba(255,255,255,.03); }
.logo-slot strong{ color:#dce7f5; display:block; font-family:'Archivo',sans-serif; font-weight:700; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.12); font-size:.85rem; color:#8ea3c2; }
.footer-bottom a{ color:#8ea3c2; }
address{ font-style:normal; line-height:1.7; color:#b9c9e0; }

/* ---------- responsivita ---------- */
@media (max-width:991.98px){
  .hero::after{ font-size:40vw; opacity:.6; }
  .navbar-main .nav-link.active::after{ display:none; }
}
@media (max-width:575.98px){
  .brandmark .wm-1{ font-size:.92rem; }
  .tl-col{ flex-basis:230px; width:230px; }
}

/* přístupnost – respektování omezeného pohybu (WCAG 2.2.2 / 2.3.3) */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
    scroll-behavior:auto !important;
  }
}

/* ============================================================
   PŘEPÍNAČ + TMAVÝ REŽIM
   ============================================================ */
.theme-toggle{ background:transparent; border:0; color:#c3d2e8; display:inline-flex; align-items:center;
  justify-content:center; min-width:24px; min-height:24px; padding:.25rem .45rem; border-radius:.3rem;
  font-size:1rem; line-height:1; cursor:pointer; transition:background-color .15s, color .15s; }
.theme-toggle:hover{ color:#fff; background:rgba(255,255,255,.14); }

:root[data-theme="dark"]{
  --p-ink:#e8eef6;
  --p-ink-soft:#b7c2d4;
  --p-muted:#94a1b6;
  --p-primary:#6aa5e0;
  --p-primary-600:#5f9bd8;
  --p-primary-700:#8fbdea;
  --p-primary-900:#0c1826;
  --p-primary-050:#16212f;
  --p-primary-100:#2a3d54;
  --p-red-600:#ff7b80;
  --p-red-050:#2e1a1c;
  --p-surface:#10161f;
  --p-bg:#161f2b;
  --p-bg-2:#1e2938;
  --p-border:#2a3646;
  --p-border-strong:#5a6a80;
  --p-line:#212c3c;

  --bs-body-color:#e8eef6;
  --bs-body-color-rgb:232,238,246;
  --bs-body-bg:#10161f;
  --bs-secondary-color:rgba(232,238,246,.72);
  --bs-emphasis-color:#f2f6fb;
  --bs-heading-color:#f2f6fb;
  --bs-border-color:#2a3646;
  --bs-link-color-rgb:138,189,234;
  --bs-link-hover-color-rgb:180,210,240;
}
[data-theme="dark"] body{ background:var(--p-surface); color:var(--p-ink); }

/* povrchy, které měly napevno bílou barvu */
[data-theme="dark"] .navbar-main{ background:#10161f; box-shadow:0 1px 0 var(--p-line); }
[data-theme="dark"] .status-card,
[data-theme="dark"] .rc-card,
[data-theme="dark"] .ql,
[data-theme="dark"] .news-card,
[data-theme="dark"] .tl-card,
[data-theme="dark"] .tl-scrollbtn,
[data-theme="dark"] .tl-node,
[data-theme="dark"] .tl-legend .sw-fut,
[data-theme="dark"] .is-future .tl-chip,
[data-theme="dark"] .status-steps .todo .st-ico{ background:#18212e; }
[data-theme="dark"] .status-card{ color:var(--p-ink); box-shadow:0 40px 80px -40px rgba(0,0,0,.8); }
[data-theme="dark"] .tl-card.is-current{ background:#241a1c; }
[data-theme="dark"] .rc-ico{ background:var(--p-primary-050) !important; color:var(--p-primary); }

/* formulářová pole */
[data-theme="dark"] .form-control{ background:#18212e; color:var(--p-ink); }
[data-theme="dark"] .form-control::placeholder{ color:var(--p-muted); opacity:1; }

/* tlačítka – bílý text drží kontrast ≥4,5:1 i v tmavém režimu */
[data-theme="dark"] .btn-primary{
  --bs-btn-bg:#2d6fb8; --bs-btn-border-color:#2d6fb8;
  --bs-btn-hover-bg:#245c98; --bs-btn-hover-border-color:#245c98;
  --bs-btn-active-bg:#1d4c80; --bs-btn-active-border-color:#1d4c80;
}
[data-theme="dark"] .btn-outline-primary{
  --bs-btn-color:var(--p-primary-700); --bs-btn-border-color:var(--p-border-strong);
  --bs-btn-hover-bg:#2d6fb8; --bs-btn-hover-border-color:#2d6fb8; --bs-btn-hover-color:#fff;
  --bs-btn-active-bg:#245c98; --bs-btn-active-border-color:#245c98;
}
[data-theme="dark"] .brandmark .mark,
[data-theme="dark"] .status-steps .done .st-ico{ background:#2d6fb8; }

/* zavírací křížek offcanvas na tmavém pozadí */
[data-theme="dark"] .btn-close{ filter:invert(1) grayscale(1) brightness(2); }
