/* ============================================================
   KPortal — prezentační web www.kportal.cz
   Stylopis stránky. Barvy a geometrie přebírá z brand tokenů
   (css/tokens-base.css + css/tokens-light.css) — žádné hardcoded hex.
   ============================================================ */

/* ============ ZÁKLAD ============ */
* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--kwp-font-body);
  color: var(--kwp-text);
  background: var(--kwp-bg);
  line-height: var(--kwp-lh-normal);
  -webkit-font-smoothing: antialiased;
}

img, svg { display: block; max-width: 100%; }

a { color: var(--kwp-text-link); }

/* Společný vnitřní kontejner (zarovnání obsahu na střed) */
.kontejner {
  max-width: var(--kwp-max-width-content);
  margin: 0 auto;
  padding-left: var(--kwp-sp-10);
  padding-right: var(--kwp-sp-10);
}

/* Kotvy s odsazením kvůli pevné (sticky) hlavičce */
[id] { scroll-margin-top: 90px; }

/* Skok na obsah — přístupnost (viditelné jen při fokusu klávesnicí) */
.skok-na-obsah {
  position: absolute;
  left: var(--kwp-sp-3);
  top: -60px;
  background: var(--kwp-primary);
  color: var(--kwp-text-on-primary);
  padding: var(--kwp-sp-2) var(--kwp-sp-4);
  border-radius: var(--kwp-radius-md);
  z-index: var(--kwp-z-toast);
  transition: top var(--kwp-transition-base);
}
.skok-na-obsah:focus { top: var(--kwp-sp-3); }

/* ============ TLAČÍTKA ============ */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--kwp-sp-2);
  text-decoration: none;
  font-weight: var(--kwp-fw-semibold);
  font-size: var(--kwp-fs-small);
  border-radius: var(--kwp-radius-md);
  padding: var(--kwp-sp-3) var(--kwp-sp-6);
  border: 2px solid transparent;
  cursor: pointer;
  transition: background var(--kwp-transition-base), color var(--kwp-transition-base),
              border-color var(--kwp-transition-base), transform var(--kwp-transition-fast);
}
.btn:active { transform: translateY(1px); }
.btn:focus-visible { outline: 3px solid var(--kwp-focus-ring); outline-offset: 2px; }

/* Primární — modrá */
.btn-primarni {
  background: var(--kwp-primary);
  color: var(--kwp-text-on-primary);
}
.btn-primarni:hover { background: var(--kwp-primary-light); }

/* Accent — zelená (hlavní výzva k akci) */
.btn-accent {
  background: var(--kwp-accent);
  color: var(--kwp-text-on-accent);
}
.btn-accent:hover { background: var(--kwp-accent-light); }

/* Ghost — bez výplně */
.btn-ghost {
  background: transparent;
  color: var(--kwp-text);
}
.btn-ghost:hover { color: var(--kwp-accent-dark); }

/* Obrysové tlačítko na tmavém pozadí */
.btn-obrys-svetly {
  background: transparent;
  color: var(--kwp-text-on-primary);
  border-color: rgba(255, 255, 255, 0.4);
}
.btn-obrys-svetly:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.7);
}

/* ============ HLAVIČKA ============ */
.site-header {
  position: sticky;
  top: 0;
  z-index: var(--kwp-z-sticky);
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--kwp-border);
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--kwp-sp-6);
  padding-top: var(--kwp-sp-4);
  padding-bottom: var(--kwp-sp-4);
}
.brand {
  display: flex;
  align-items: center;
  gap: var(--kwp-sp-3);
  text-decoration: none;
  flex-shrink: 0;
}
.brand img { width: 42px; height: 42px; }
.brand-text {
  font-size: 26px;
  font-weight: var(--kwp-fw-extrabold);
  color: var(--kwp-primary);
  letter-spacing: var(--kwp-ls-tight);
}
.brand-text .lehky {
  color: var(--kwp-text-subtle);
  font-weight: var(--kwp-fw-semibold);
}
.nav {
  display: flex;
  gap: var(--kwp-sp-6);
  align-items: center;
}
.nav a {
  color: var(--kwp-text);
  text-decoration: none;
  font-size: var(--kwp-fs-small);
  font-weight: var(--kwp-fw-medium);
  transition: color var(--kwp-transition-fast);
}
.nav a:hover { color: var(--kwp-accent-dark); }
.nav .btn-cta {
  background: var(--kwp-accent);
  color: var(--kwp-text-on-accent);
  padding: var(--kwp-sp-2) var(--kwp-sp-5);
  border-radius: var(--kwp-radius-md);
  font-weight: var(--kwp-fw-semibold);
  display: inline-flex;
  align-items: center;
  gap: var(--kwp-sp-2);
}
.nav .btn-cta:hover { background: var(--kwp-accent-light); color: var(--kwp-text-on-accent); }

/* ============ HERO ============ */
.hero {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: var(--kwp-sp-12);
  align-items: center;
  padding-top: var(--kwp-sp-16);
  padding-bottom: var(--kwp-sp-16);
}
.hero-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--kwp-sp-2);
  background: var(--kwp-accent-50);
  color: var(--kwp-accent-dark);
  padding: var(--kwp-sp-1) var(--kwp-sp-3);
  border-radius: var(--kwp-radius-pill);
  font-size: var(--kwp-fs-caption);
  font-weight: var(--kwp-fw-semibold);
  letter-spacing: var(--kwp-ls-wide);
  text-transform: uppercase;
  margin-bottom: var(--kwp-sp-5);
}
.hero-title {
  font-size: var(--kwp-fs-display);
  font-weight: var(--kwp-fw-extrabold);
  line-height: var(--kwp-lh-tight);
  letter-spacing: var(--kwp-ls-tight);
  color: var(--kwp-primary);
  margin-bottom: var(--kwp-sp-5);
}
.hero-title .akcent { color: var(--kwp-accent-dark); }
.hero-text {
  font-size: 18px;
  color: var(--kwp-text-muted);
  margin-bottom: var(--kwp-sp-8);
  max-width: 540px;
}
.hero-cta {
  display: flex;
  gap: var(--kwp-sp-3);
  align-items: center;
  flex-wrap: wrap;
}

.hero-visual {
  background: linear-gradient(135deg, var(--kwp-primary) 0%, var(--kwp-primary-dark) 100%);
  border-radius: var(--kwp-radius-xl);
  padding: var(--kwp-sp-16) var(--kwp-sp-10);
  position: relative;
  overflow: hidden;
}
.hero-visual::before {
  content: '';
  position: absolute;
  top: -50px;
  right: -50px;
  width: 220px;
  height: 220px;
  background: var(--kwp-accent);
  opacity: 0.18;
  border-radius: 50%;
}
.hero-visual img {
  width: 70%;
  max-width: 280px;
  margin: 0 auto;
  position: relative;
}

/* ============ SEKCE — společné ============ */
.sekce { padding-top: var(--kwp-sp-16); padding-bottom: var(--kwp-sp-16); }
.sekce-seda { background: var(--kwp-surface-hover); }

.sekce-hlavicka {
  text-align: center;
  max-width: 660px;
  margin: 0 auto var(--kwp-sp-12);
}
.sekce-hlavicka h2 {
  font-size: var(--kwp-fs-h1);
  font-weight: var(--kwp-fw-bold);
  letter-spacing: var(--kwp-ls-tight);
  color: var(--kwp-primary);
  margin-bottom: var(--kwp-sp-3);
}
.sekce-hlavicka p {
  color: var(--kwp-text-muted);
  font-size: 18px;
}

/* ============ FUNKCE ============ */
.mrizka-funkci {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--kwp-sp-6);
}
.karta-funkce {
  background: var(--kwp-surface);
  border: 1px solid var(--kwp-border);
  border-radius: var(--kwp-radius-lg);
  padding: var(--kwp-sp-6);
  transition: border-color var(--kwp-transition-base), box-shadow var(--kwp-transition-base),
              transform var(--kwp-transition-base);
}
.karta-funkce:hover {
  border-color: var(--kwp-accent);
  box-shadow: var(--kwp-shadow-md);
  transform: translateY(-3px);
}
.ikona-funkce {
  width: 52px;
  height: 52px;
  background: var(--kwp-accent-50);
  color: var(--kwp-accent-dark);
  border-radius: var(--kwp-radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 26px;
  margin-bottom: var(--kwp-sp-4);
}
.karta-funkce h3 {
  font-size: var(--kwp-fs-h4);
  font-weight: var(--kwp-fw-semibold);
  color: var(--kwp-primary);
  margin-bottom: var(--kwp-sp-2);
}
.karta-funkce p {
  color: var(--kwp-text-muted);
  font-size: var(--kwp-fs-small);
  line-height: var(--kwp-lh-relaxed);
}

/* ============ PLATFORMY ============ */
.mrizka-platforem {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--kwp-sp-6);
}
.karta-platforma {
  background: var(--kwp-surface);
  border: 1px solid var(--kwp-border);
  border-radius: var(--kwp-radius-lg);
  padding: var(--kwp-sp-8) var(--kwp-sp-6);
  text-align: center;
}
.ikona-platforma {
  font-size: 44px;
  color: var(--kwp-primary);
  margin-bottom: var(--kwp-sp-4);
}
.karta-platforma h3 {
  font-size: var(--kwp-fs-h3);
  font-weight: var(--kwp-fw-semibold);
  color: var(--kwp-primary);
  margin-bottom: var(--kwp-sp-1);
}
.karta-platforma .stitek {
  display: inline-block;
  font-size: var(--kwp-fs-caption);
  font-weight: var(--kwp-fw-semibold);
  letter-spacing: var(--kwp-ls-wide);
  text-transform: uppercase;
  color: var(--kwp-accent-dark);
  background: var(--kwp-accent-50);
  padding: 2px var(--kwp-sp-2);
  border-radius: var(--kwp-radius-pill);
  margin-bottom: var(--kwp-sp-3);
}
.karta-platforma p {
  color: var(--kwp-text-muted);
  font-size: var(--kwp-fs-small);
  line-height: var(--kwp-lh-relaxed);
}

/* ============ CTA / KONTAKT ============ */
.cta {
  background: linear-gradient(135deg, var(--kwp-primary) 0%, var(--kwp-primary-dark) 100%);
  position: relative;
  overflow: hidden;
}
.cta::before {
  content: '';
  position: absolute;
  bottom: -90px;
  left: -60px;
  width: 280px;
  height: 280px;
  background: var(--kwp-accent);
  opacity: 0.14;
  border-radius: 50%;
}
.cta-obsah {
  text-align: center;
  max-width: 680px;
  margin: 0 auto;
  position: relative;
}
.cta-obsah h2 {
  font-size: var(--kwp-fs-h1);
  font-weight: var(--kwp-fw-bold);
  letter-spacing: var(--kwp-ls-tight);
  color: var(--kwp-text-on-primary);
  margin-bottom: var(--kwp-sp-4);
}
.cta-obsah p {
  color: rgba(255, 255, 255, 0.82);
  font-size: 18px;
  margin-bottom: var(--kwp-sp-8);
}
.cta-tlacitka {
  display: flex;
  gap: var(--kwp-sp-3);
  justify-content: center;
  flex-wrap: wrap;
}
.cta-poznamka {
  margin-top: var(--kwp-sp-6);
  font-size: var(--kwp-fs-small);
  color: rgba(255, 255, 255, 0.6);
}
.cta-poznamka a { color: var(--kwp-accent-light); }

/* ============ PATIČKA ============ */
.footer {
  background: var(--kwp-primary-dark);
  color: rgba(255, 255, 255, 0.7);
  padding-top: var(--kwp-sp-10);
  padding-bottom: var(--kwp-sp-10);
  font-size: var(--kwp-fs-small);
}
.footer-radek {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--kwp-sp-6);
  flex-wrap: wrap;
}
.footer-brand {
  display: flex;
  align-items: center;
  gap: var(--kwp-sp-2);
  font-weight: var(--kwp-fw-bold);
  color: var(--kwp-text-on-primary);
}
.footer-brand img { width: 30px; height: 30px; }
.footer-odkazy {
  display: flex;
  gap: var(--kwp-sp-5);
  flex-wrap: wrap;
}
.footer a { color: var(--kwp-accent-light); text-decoration: none; }
.footer a:hover { text-decoration: underline; }
.footer-spodek {
  margin-top: var(--kwp-sp-6);
  padding-top: var(--kwp-sp-5);
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--kwp-sp-3);
  flex-wrap: wrap;
  font-size: var(--kwp-fs-caption);
  color: rgba(255, 255, 255, 0.5);
}

/* ============ RESPONZIVITA ============ */

/* Tablet — hero do jednoho sloupce */
@media (max-width: 900px) {
  .hero {
    grid-template-columns: 1fr;
    gap: var(--kwp-sp-10);
    padding-top: var(--kwp-sp-12);
    padding-bottom: var(--kwp-sp-12);
  }
  .hero-visual { order: -1; padding: var(--kwp-sp-12); }
  .hero-visual img { max-width: 220px; }
  .hero-text { max-width: none; }
}

/* Mobil — kompaktnější rozestupy, zalamovaná hlavička */
@media (max-width: 640px) {
  .kontejner {
    padding-left: var(--kwp-sp-5);
    padding-right: var(--kwp-sp-5);
  }
  .header-inner {
    flex-wrap: wrap;
    justify-content: center;
  }
  .nav {
    width: 100%;
    justify-content: center;
    flex-wrap: wrap;
    gap: var(--kwp-sp-4);
  }
  :root { --kwp-fs-display: 38px; }
  .hero-title { font-size: 38px; }
  .sekce-hlavicka h2,
  .cta-obsah h2 { font-size: var(--kwp-fs-h2); }
  .sekce { padding-top: var(--kwp-sp-12); padding-bottom: var(--kwp-sp-12); }
  .btn { width: 100%; justify-content: center; }
  .nav .btn-cta { width: auto; }
}
