/* ==========================================================================
   HANSA BRNO — base.css
   Reset, design tokeny (proměnné), typografie, kontejner. Načítá se na každé stránce.
   ========================================================================== */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  /* Industrial LIGHT */
  --barva-bila:            #ffffff;
  --barva-svetle-seda:   #f8fafc;
  --barva-seda:    #f1f5f9;
  --barva-bila:       #ffffff;
  --barva-textu:          #0f172a;
  --barva-textu-tlumena:    #475569;
  --barva-textu-jemna:   #94a3b8;
  --barva-borderu-jemny:        rgba(15,23,42,0.10);
  --barva-borderu-svetly: rgba(15,23,42,0.20);

  --primarni-barva:        #DA2B14;
  --primarni-barva-hover:  #b82210;
  --barva-na-akcentu:     #ffffff;
  --primarni-barva-jemna:   #fef2f1;

  --barva-uspech: #16a34a;
  --barva-varovani: #f59e0b;

  --font-nadpis: 'Inter', system-ui, sans-serif;
  --font-text:    'Inter', system-ui, sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, monospace;
}

html { scroll-behavior: smooth; }
body {
  font-family: var(--font-text);
  background: var(--barva-bila);
  color: var(--barva-textu);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

.container { max-width: 1600px; margin: 0 auto; padding: 0 48px; }

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button { font-family: inherit; cursor: pointer; }

section { padding: 120px 0; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { transition: none !important; animation: none !important; }
}


/* ==========================================================================
   HANSA BRNO — hlavicka-paticka.css
   Ramec webu: horni lista + navigace (header) a paticka (footer).
   Slouceno z header + footer.
   ========================================================================== */

/* ==========================================================================
   HANSA BRNO — header.css
   Globální horní lišta (horni-lista) + hlavní navigace. Stejné na všech stránkách.
   ========================================================================== */

/* TOP BAR */
.horni-lista { background: var(--barva-seda); border-bottom: 1px solid var(--barva-borderu-jemny); font-size: 13px; color: var(--barva-textu-tlumena); padding: 10px 0; }
.horni-lista-obsah { display: flex; justify-content: space-between; align-items: center; }
.horni-lista-vlevo { display: flex; gap: 28px; align-items: center; }
.horni-lista-polozka { display: inline-flex; align-items: center; gap: 8px; }
.horni-lista-ikona { color: var(--primarni-barva); flex-shrink: 0; }
.horni-lista-mono { font-family: var(--font-mono); font-size: 12.5px; color: var(--barva-textu); font-weight: 600; }

.prepinac-jazyka { font-family: var(--font-mono); font-size: 12px; display: flex; gap: 4px; align-items: center; }
.prepinac-jazyka a { padding: 0 6px; color: var(--barva-textu-jemna); }
.prepinac-jazyka a.aktivni { color: var(--primarni-barva); font-weight: 700; }
.prepinac-jazyka a:hover { color: var(--barva-textu); }
.jazyk-oddelovac { color: var(--barva-textu-jemna); }

/* NAV */
.hlavicka { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,0.92); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border-bottom: 1px solid var(--barva-borderu-jemny); }
.hlavicka-obsah { display: flex; align-items: center; gap: 32px; height: 84px; }
.logo { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
.logo-svg { height: 44px; width: auto; display: block; }
.logo-znak { width: 38px; height: 38px; background: var(--primarni-barva); border-radius: 6px; display: grid; place-items: center; color: #fff; font-family: var(--font-nadpis); font-weight: 800; font-size: 22px; letter-spacing: -0.04em; }
.logo-text { font-family: var(--font-nadpis); font-weight: 700; font-size: 18px; letter-spacing: -0.02em; color: var(--barva-textu); }
.logo-text .logo-svetle { font-weight: 500; color: var(--barva-textu-tlumena); margin-left: 4px; }

nav.menu { flex: 1; display: flex; justify-content: center; gap: 4px; }
.menu-odkaz { padding: 9px 16px; font-size: 14.5px; font-weight: 500; color: var(--barva-textu-tlumena); border-radius: 6px; transition: color .2s, background .2s; white-space: nowrap; }
.menu-odkaz:hover { color: var(--barva-textu); background: var(--barva-seda); }
.menu-odkaz.aktivni { color: var(--barva-textu); background: var(--barva-seda); }
/* CTA Poptávka uvnitř mobilního menu — na desktopu skryté (je v .hlavicka-akce) */
.menu-cta-mobil { display: none; }

.hlavicka-akce { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }

/* Hamburger (mobil) — na desktopu skryté, zobrazí se v responsive.css */
.menu-prepinac { display: none; width: 44px; height: 44px; border: 1px solid var(--barva-borderu-svetly); border-radius: 8px; background: var(--barva-bila); color: var(--barva-textu); align-items: center; justify-content: center; flex-shrink: 0; }
.menu-prepinac:hover { border-color: var(--primarni-barva); color: var(--primarni-barva); }
.menu-prepinac svg { display: block; }
.menu-prepinac .ikona-zavrit { display: none; }
.menu-prepinac.je-otevreno .ikona-menu { display: none; }
.menu-prepinac.je-otevreno .ikona-zavrit { display: block; }
/* ==========================================================================
   HANSA BRNO — footer.css
   Globální patička. Stejná na všech stránkách.
   ========================================================================== */

footer { background: #0a1220; color: #94a3b8; padding: 96px 0 32px; }
.paticka-mrizka { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr 1.2fr; gap: 64px; margin-bottom: 64px; }
.paticka-znacka { display: flex; gap: 12px; align-items: center; margin-bottom: 20px; }
.paticka-logo-svg { height: 40px; width: auto; display: block; }
.paticka-logo-znak { width: 38px; height: 38px; background: var(--primarni-barva); border-radius: 6px; display: grid; place-items: center; color: #fff; font-weight: 800; font-size: 22px; letter-spacing: -0.04em; }
.paticka-logo-text { font-family: var(--font-nadpis); font-weight: 700; font-size: 18px; letter-spacing: -0.02em; color: #fff; }
.paticka-logo-text .logo-svetle { font-weight: 500; color: #94a3b8; margin-left: 4px; }
.paticka-popis { font-size: 13.5px; color: #94a3b8; line-height: 1.65; max-width: 300px; }

.paticka-nadpis { font-family: var(--font-mono); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .14em; color: #fff; margin-bottom: 18px; }
.paticka-odkazy { display: flex; flex-direction: column; gap: 10px; }
.paticka-odkazy a { font-size: 13.5px; color: #94a3b8; transition: color .2s; }
.paticka-odkazy a:hover { color: var(--primarni-barva); }
.paticka-kontakt-silny { font-family: var(--font-mono); color: #fff; font-weight: 600; }
.paticka-adresa { margin-top: 16px; font-size: 12.5px; color: #94a3b8; line-height: 1.6; }

.paticka-pdf { display: flex; flex-direction: column; gap: 10px; }
.pdf-odkaz { display: flex; align-items: center; gap: 12px; padding: 12px 14px; border: 1px solid rgba(255,255,255,0.12); border-radius: 8px; color: #fff; font-size: 13px; transition: border-color .2s, background .2s; background: rgba(255,255,255,.02); }
.pdf-odkaz:hover { border-color: var(--primarni-barva); background: rgba(218,43,20,.08); }
.pdf-odkaz svg { color: var(--primarni-barva); flex-shrink: 0; }
.pdf-nazev { font-weight: 600; font-size: 13px; }
.pdf-meta { font-family: var(--font-mono); font-size: 10.5px; color: #64748b; margin-top: 3px; display: block; }

.paticka-spodek { padding-top: 32px; border-top: 1px solid rgba(255,255,255,.1); display: flex; justify-content: space-between; align-items: center; font-size: 12.5px; color: #64748b; flex-wrap: wrap; gap: 16px; }
.paticka-meta { font-family: var(--font-mono); font-size: 11.5px; }
.paticka-meta a { color: var(--barva-textu-jemna); transition: color .2s; }
.paticka-meta a:hover { color: var(--primarni-barva); }
