/* ====== Sjednocené nadpisy sekcí napříč webem ======
   Match style sekce kontaktního formuláře (eyebrow + 32px h3 bold).
   Cílí jen na .ul-section-header h3 (= section-level nadpisy),
   neovlivňuje article hero h1 ani article body h2/h3. */
.ul-section-header h3,
.ul-section-header.second h3 {
  font-size: 32px !important;
  line-height: 1.2 !important;
  letter-spacing: -0.01em !important;
  font-weight: 800 !important;
}
@media (max-width: 991px) {
  .ul-section-header h3,
  .ul-section-header.second h3 { font-size: 28px !important; line-height: 1.2 !important; }
}
@media (max-width: 575px) {
  .ul-section-header h3,
  .ul-section-header.second h3 { font-size: 24px !important; }
}

/* ====== Sjednocený footer pro celý web ======
   Načítáno z <head> každé stránky.
   Mění barvy automaticky podle dark mode (body.dark). */
.article-footer { background: var(--background-color); border-top: 1px solid rgba(3,22,36,0.08); padding: 50px 40px 0; margin: 0; color: var(--font-color); }
body.dark .article-footer { background: var(--background-color2); border-top-color: rgba(255,255,255,0.1); color: #fff; }
.article-footer .article-footer-inner { max-width: 1600px; margin: 0 auto; display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 50px; padding-bottom: 50px; }
.article-footer .af-col h4 { font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: 2px; margin: 0 0 20px; color: var(--color-primary); }
.article-footer .af-col h4.mt-30 { margin-top: 36px; }
.article-footer .af-logo { display: inline-block; margin-bottom: 18px; }
.article-footer .af-logo img { height: 50px; width: auto; display: block; }
.article-footer .af-col-brand p { font-size: 15px; line-height: 1.6; opacity: 0.75; margin: 0 0 24px; max-width: 400px; }
.article-footer .af-social { display: flex; gap: 18px; align-items: center; }
.article-footer .af-social-link { display: inline-flex; align-items: center; justify-content: center; color: var(--font-color); text-decoration: none; opacity: 0.85; transition: opacity .2s, transform .2s, color .2s; }
.article-footer .af-social-link i { font-size: 19px; }
.article-footer .af-social-link:hover { opacity: 1; color: var(--color-primary); transform: translateY(-2px); }
body.dark .article-footer .af-social-link { color: #fff; }
.article-footer .af-list { list-style: none; padding: 0; margin: 0; }
.article-footer .af-col-contact .af-list li { display: flex; gap: 12px; align-items: flex-start; margin-bottom: 14px; font-size: 15px; line-height: 1.55; }
.article-footer .af-col-contact .af-list i { color: var(--color-primary); font-size: 15px; margin-top: 4px; flex-shrink: 0; width: 17px; text-align: center; }
.article-footer .af-col-contact .af-list li > span,
.article-footer .af-col-contact .af-list li > a { flex: 1; min-width: 0; color: var(--font-color); text-decoration: none; transition: color .2s; font-size: 15px; line-height: 1.55; }
.article-footer .af-col-contact .af-list li > a:hover { color: var(--color-primary); }
body.dark .article-footer .af-col-contact .af-list li > span,
body.dark .article-footer .af-col-contact .af-list li > a { color: #fff; }
.article-footer .af-list-links li { margin-bottom: 10px; font-size: 15px; line-height: 1.5; }
.article-footer .af-list-links a { color: var(--font-color); text-decoration: none; opacity: 0.8; transition: opacity .2s, color .2s; }
.article-footer .af-list-links a:hover { color: var(--color-primary); opacity: 1; }
body.dark .article-footer .af-list-links a { color: #fff; }
.article-footer-bottom { max-width: 1600px; margin: 0 auto; padding: 24px 0; border-top: 1px solid rgba(3,22,36,0.08); text-align: center; font-size: 12px; opacity: 0.6; }
body.dark .article-footer-bottom { border-top-color: rgba(255,255,255,0.1); }
@media (max-width: 1100px) {
  .article-footer { padding: 40px 30px 0; }
  .article-footer .article-footer-inner { grid-template-columns: repeat(3, 1fr); gap: 40px; }
  .article-footer .af-col-brand { grid-column: 1 / -1; }
}
@media (max-width: 700px) {
  .article-footer .article-footer-inner { grid-template-columns: 1fr 1fr; gap: 36px; }
}
@media (max-width: 480px) {
  .article-footer { padding: 40px 20px 0; }
  .article-footer .article-footer-inner { grid-template-columns: 1fr; gap: 32px; }
  .article-footer .af-col-brand p { max-width: 100%; }
}
/* ===== Mobile (≤700px): vše vystředit + větší tap targets ===== */
@media (max-width: 700px) {
  .article-footer .af-col { text-align: center; }
  .article-footer .af-logo { display: block; margin-left: auto; margin-right: auto; }
  .article-footer .af-logo img { margin-left: auto; margin-right: auto; }
  .article-footer .af-col-brand p { margin-left: auto; margin-right: auto; max-width: 420px; }
  .article-footer .af-social { justify-content: center; gap: 12px; }
  .article-footer .af-social-link { width: 44px; height: 44px; border-radius: 50%; background: rgba(3,22,36,0.05); }
  body.dark .article-footer .af-social-link { background: rgba(255,255,255,0.06); }
  .article-footer .af-social-link i { font-size: 22px; }
  .article-footer .af-col-contact .af-list li { justify-content: center; gap: 10px; }
  .article-footer .af-col-contact .af-list li > span,
  .article-footer .af-col-contact .af-list li > a { flex: 0 1 auto; text-align: center; }
}
