/* ============================================================
   site.css  -  Layout a komponenty verejneho webu Ekopron Metal
   Nacita se po bootstrap.min.css a content.css.
   ============================================================ */

html { scroll-behavior: smooth; }
body {
  font-family: var(--eko-font);
  color: #2b3035;
  background: #fff;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}
main { flex: 1 0 auto; }

a { color: var(--eko-red); }
a:hover { color: var(--eko-red-dark); }

.text-eko { color: var(--eko-red) !important; }
.bg-eko { background-color: var(--eko-red) !important; }
.bg-dark-eko { background-color: var(--eko-dark) !important; }

/* ---- Tlacitka ---- */
.btn-eko {
  --bs-btn-color: #fff;
  --bs-btn-bg: var(--eko-red);
  --bs-btn-border-color: var(--eko-red);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: var(--eko-red-dark);
  --bs-btn-hover-border-color: var(--eko-red-dark);
  --bs-btn-active-bg: var(--eko-red-dark);
  --bs-btn-active-border-color: var(--eko-red-dark);
  --bs-btn-focus-shadow-rgb: 209,31,38;
  font-weight: 600;
}
.btn-outline-eko {
  --bs-btn-color: var(--eko-red);
  --bs-btn-border-color: var(--eko-red);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: var(--eko-red);
  --bs-btn-hover-border-color: var(--eko-red);
  --bs-btn-active-bg: var(--eko-red);
  font-weight: 600;
}
.btn-light-eko {
  --bs-btn-color: var(--eko-dark);
  --bs-btn-bg: #fff;
  --bs-btn-hover-bg: #f1f1f1;
  font-weight: 600;
}

/* ---- Horni utility bar ---- */
.topbar {
  background: var(--eko-darker);
  color: #cfd4d8;
  font-size: .875rem;
}
.topbar a { color: #cfd4d8; text-decoration: none; }
.topbar a:hover { color: #fff; }
.topbar .sep { color: #4a5159; }

/* ---- Navbar ---- */
.site-header { position: sticky; top: 0; z-index: 1030; }
.navbar-eko {
  background: #fff;
  box-shadow: 0 2px 14px rgba(0,0,0,.08);
}
.navbar-eko .navbar-brand img { height: 46px; width: auto; }
.navbar-eko .nav-link {
  color: var(--eko-dark);
  font-weight: 600;
  padding: .6rem .9rem !important;
  position: relative;
}
.navbar-eko .nav-link:hover,
.navbar-eko .nav-link.active { color: var(--eko-red); }
.navbar-eko .nav-link.active::after {
  content: "";
  position: absolute;
  left: .9rem; right: .9rem; bottom: .25rem;
  height: 2px; background: var(--eko-red); border-radius: 2px;
}
.navbar-eko .dropdown-menu { border: 0; box-shadow: 0 8px 24px rgba(0,0,0,.12); }
.navbar-eko .submenu-toggle {
  background: transparent;
  border: 0;
  color: var(--eko-dark);
  line-height: 1;
  cursor: pointer;
}

/* Desktop: podmenu se otevira pri najeti, rodicovsky odkaz zustava klikaci */
@media (min-width: 992px) {
  .navbar-eko .nav-item.dropdown { position: relative; }
  .navbar-eko .nav-item.dropdown:hover > .dropdown-menu,
  .navbar-eko .nav-item.dropdown:focus-within > .dropdown-menu { display: block; }
  .navbar-eko .has-caret::after {
    content: "\F282";
    font-family: "bootstrap-icons";
    font-size: .65rem;
    margin-left: .35rem;
    vertical-align: middle;
    opacity: .7;
  }
}

/* Mobil: rodic = odkaz, caret vpravo rozbaluje podmenu inline */
@media (max-width: 991.98px) {
  .navbar-eko .nav-item.dropdown {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
  }
  .navbar-eko .nav-item.dropdown > .nav-link { flex: 1 1 auto; }
  .navbar-eko .submenu-toggle {
    flex: 0 0 auto;
    padding: .6rem .9rem;
    transition: transform .2s;
  }
  .navbar-eko .submenu-toggle.open { transform: rotate(180deg); }
  .navbar-eko .dropdown-menu {
    display: none;
    flex: 1 1 100%;
    box-shadow: none;
    padding: .25rem 0 .25rem 1rem;
    margin: 0;
  }
  .navbar-eko .dropdown-menu.show { display: block; }
}

/* ---- Oznameni banner ---- */
.announce-banner {
  background: var(--eko-red);
  color: #fff;
  text-align: center;
  padding: .55rem 1rem;
  font-weight: 600;
}
.announce-banner.warning { background: #b8860b; }
.announce-banner.info { background: var(--eko-dark); }
.announce-banner a { color: #fff; text-decoration: underline; }

/* ---- Hero ---- */
.hero {
  position: relative;
  background: var(--eko-dark) center/cover no-repeat;
  color: #fff;
  padding: 6rem 0;
  overflow: hidden;
}
.hero::before {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(120deg, rgba(21,25,29,.85) 0%, rgba(21,25,29,.55) 60%, rgba(21,25,29,.35) 100%);
}
.hero > .container { position: relative; z-index: 2; }
.hero h1 {
  font-size: clamp(2rem, 4vw, 3.2rem);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .5px;
  line-height: 1.1;
}
.hero .hero-kicker {
  display: inline-block;
  background: var(--eko-red);
  color: #fff;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  padding: .3rem .8rem;
  border-radius: 4px;
  font-size: .85rem;
  margin-bottom: 1rem;
}
.hero p.lead { font-size: 1.25rem; max-width: 640px; color: #e6e9ec; }

/* mensi hero pro podstranky */
.page-hero {
  background: var(--eko-dark) center/cover no-repeat;
  color: #fff;
  padding: 3.2rem 0;
  position: relative;
}
.page-hero::before {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(120deg, rgba(21,25,29,.9), rgba(21,25,29,.6));
}
.page-hero > .container { position: relative; z-index: 2; }
.page-hero h1 { font-weight: 800; text-transform: uppercase; margin: 0; }
.page-hero .breadcrumb { --bs-breadcrumb-divider-color: #9aa0a6; margin: .4rem 0 0; }
.page-hero .breadcrumb a { color: #cfd4d8; text-decoration: none; }
.page-hero .breadcrumb .active { color: #fff; }

/* ---- Sekce ---- */
.section { padding: 4rem 0; }
.section-light { background: var(--eko-light); }
.section-dark { background: var(--eko-dark); color: #fff; }
.section-title { margin-bottom: 2.5rem; }
.section-title .kicker {
  color: var(--eko-red);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  font-size: .85rem;
}
.section-title h2 {
  font-weight: 800;
  color: var(--eko-dark);
  margin: .35rem 0 0;
}
.section-dark .section-title h2 { color: #fff; }

/* ---- Karty sluzeb / feature ---- */
.feature-card {
  background: #fff;
  border: 1px solid var(--eko-border);
  border-radius: 12px;
  padding: 1.8rem;
  height: 100%;
  transition: transform .18s, box-shadow .18s, border-color .18s;
}
.feature-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 30px rgba(0,0,0,.10);
  border-color: transparent;
}
.feature-card .icon {
  width: 58px; height: 58px;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(209,31,38,.1);
  color: var(--eko-red);
  border-radius: 12px;
  font-size: 1.7rem;
  margin-bottom: 1rem;
}
.feature-card h3 { font-size: 1.2rem; font-weight: 700; color: var(--eko-dark); }
.feature-card p { color: var(--eko-gray); margin: 0; }

/* ---- Provozovny ---- */
.branch-card {
  border: 1px solid var(--eko-border);
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
  height: 100%;
  transition: box-shadow .18s, transform .18s;
}
.branch-card:hover { box-shadow: 0 12px 28px rgba(0,0,0,.10); transform: translateY(-3px); }
.branch-card .branch-head {
  background: var(--eko-dark);
  color: #fff;
  padding: 1rem 1.25rem;
  font-weight: 700;
  display: flex; align-items: center; gap: .5rem;
}
.branch-card .branch-head .badge-hq {
  background: var(--eko-red); color: #fff; font-size: .7rem;
  padding: .15rem .5rem; border-radius: 4px; text-transform: uppercase;
}
.branch-card .branch-body { padding: 1.25rem; }
.branch-card .branch-body i { color: var(--eko-red); width: 1.2rem; }

/* ---- Otevirací doba tabulka ---- */
.hours-table { width: 100%; font-size: .95rem; }
.hours-table td { padding: .3rem 0; border-bottom: 1px dashed var(--eko-border); }
.hours-table td:last-child { text-align: right; font-weight: 600; color: var(--eko-dark); }
.hours-table tr.today td { color: var(--eko-red); }
.hours-table .closed { color: var(--eko-gray); font-weight: 600; }

/* ---- Aktuality / clanky karty ---- */
.post-card {
  border: 1px solid var(--eko-border);
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
  height: 100%;
  display: flex; flex-direction: column;
  transition: box-shadow .18s, transform .18s;
}
.post-card:hover { box-shadow: 0 12px 28px rgba(0,0,0,.10); transform: translateY(-3px); }
.post-card .post-thumb { aspect-ratio: 16/10; background: var(--eko-light) center/cover no-repeat; }
.post-card .post-body { padding: 1.25rem; display: flex; flex-direction: column; flex: 1; }
.post-card .post-group {
  align-self: flex-start;
  background: rgba(209,31,38,.1); color: var(--eko-red);
  font-size: .72rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .5px; padding: .2rem .55rem; border-radius: 4px; margin-bottom: .6rem;
}
.post-card h3 { font-size: 1.15rem; font-weight: 700; color: var(--eko-dark); }
.post-card h3 a { color: inherit; }
.post-card h3 a:hover { color: var(--eko-red); }
.post-card .post-date { font-size: .85rem; color: var(--eko-gray); }
.post-card .post-excerpt { color: var(--eko-gray); flex: 1; }

/* ---- Bazar ---- */
.bazar-card { border: 1px solid var(--eko-border); border-radius: 12px; overflow: hidden; background: #fff; height: 100%; }
.bazar-card:hover { box-shadow: 0 12px 28px rgba(0,0,0,.10); }
.bazar-card .bazar-thumb { aspect-ratio: 4/3; background: var(--eko-light) center/cover no-repeat; }
.bazar-card .bazar-body { padding: 1.1rem; }
.bazar-card .price { color: var(--eko-red); font-weight: 800; font-size: 1.2rem; }
.bazar-card .badge-sold { background: var(--eko-gray); color:#fff; }

/* ---- Tym ---- */
.team-card { text-align: center; }
.team-card .photo {
  width: 120px; height: 120px; border-radius: 50%;
  background: var(--eko-light) center/cover no-repeat;
  margin: 0 auto 1rem; border: 3px solid #fff; box-shadow: 0 6px 18px rgba(0,0,0,.12);
  display:flex;align-items:center;justify-content:center;color:var(--eko-gray);font-size:2rem;
}
.team-card .name { font-weight: 700; color: var(--eko-dark); }
.team-card .role { color: var(--eko-gray); font-size: .9rem; }

/* ---- Kontaktni info dlazdice ---- */
.contact-tile { display:flex; gap:1rem; align-items:flex-start; }
.contact-tile .ic {
  flex: 0 0 auto; width:48px;height:48px;border-radius:10px;
  background: rgba(209,31,38,.1); color: var(--eko-red);
  display:flex;align-items:center;justify-content:center;font-size:1.3rem;
}

/* ---- CTA pruh ---- */
.cta-strip { background: var(--eko-red); color:#fff; padding: 2.6rem 0; }
.cta-strip h2 { font-weight: 800; margin: 0; }

/* ---- Footer ---- */
.site-footer { background: var(--eko-darker); color: #aeb4ba; padding-top: 3.2rem; }
.site-footer h5 { color: #fff; font-weight: 700; margin-bottom: 1.1rem; font-size: 1.05rem; }
.site-footer a { color: #aeb4ba; text-decoration: none; }
.site-footer a:hover { color: #fff; }
.site-footer .footer-logo { height: 48px; margin-bottom: 1rem; }
.site-footer ul { list-style: none; padding: 0; margin: 0; }
.site-footer ul li { margin-bottom: .5rem; }
.site-footer .footer-bottom {
  border-top: 1px solid #2a2f35;
  margin-top: 2.4rem; padding: 1.2rem 0;
  font-size: .85rem; color: #7c838a;
}
.site-footer .footer-bottom a { color: #9aa0a6; }

/* scroll-to-top */
.to-top {
  position: fixed; right: 1.2rem; bottom: 1.2rem; z-index: 1040;
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--eko-red); color:#fff; border: 0;
  display: none; align-items: center; justify-content: center;
  box-shadow: 0 6px 16px rgba(0,0,0,.25);
}
.to-top.show { display: inline-flex; }

/* ---- Tym na kontaktu ---- */
.team-group-title {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--eko-dark);
  margin: 1.6rem 0 1rem;
  padding-bottom: .4rem;
  border-bottom: 2px solid var(--eko-red);
  display: inline-block;
}
.contact-person {
  height: 100%;
  background: #fff;
  border: 1px solid var(--eko-border);
  border-radius: 10px;
  padding: 1.1rem 1.2rem;
  box-shadow: 0 4px 14px rgba(0,0,0,.04);
}
.contact-person .cp-name { font-weight: 700; color: var(--eko-dark); font-size: 1.05rem; }
.contact-person .cp-role { color: var(--eko-gray); font-size: .85rem; margin-bottom: .6rem; }
.contact-person .cp-line {
  display: flex;
  align-items: center;
  gap: .5rem;
  color: #41474d;
  text-decoration: none;
  font-size: .92rem;
  padding: .15rem 0;
  border-bottom: 0;
}
.contact-person .cp-line:hover { color: var(--eko-red); }
.contact-person .cp-line i { color: var(--eko-red); font-size: .9rem; }

/* ---- Certifikaty (documents blok) ---- */
.doc-card {
  display: flex;
  align-items: center;
  gap: .75rem;
  height: 100%;
  padding: 1rem 1.15rem;
  border: 1px solid var(--eko-border);
  border-radius: 10px;
  background: #fff;
  color: var(--eko-dark);
  font-weight: 600;
  text-decoration: none;
  box-shadow: 0 4px 14px rgba(0,0,0,.04);
  transition: border-color .15s, color .15s, transform .15s;
}
.doc-card:hover { border-color: var(--eko-red); color: var(--eko-red); transform: translateY(-2px); }
.doc-card > .bi-patch-check-fill { color: var(--eko-red); font-size: 1.6rem; }
.doc-card .bi-download { opacity: .55; }

/* ---- Kompaktni inline fotogalerie v textu (rte) ---- */
.rte-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(96px, 1fr));
  gap: .5rem;
  margin: 1.25rem 0 1.5rem;
}
.rte-gallery a { display: block; overflow: hidden; border-radius: 8px; line-height: 0; }
.rte-gallery img {
  width: 100%;
  height: 84px;
  object-fit: cover;
  border: 1px solid var(--eko-border);
  border-radius: 8px;
  transition: transform .25s, border-color .15s;
}
.rte-gallery a:hover img { transform: scale(1.06); border-color: var(--eko-red); }

@media (max-width: 991.98px) {
  .hero { padding: 4rem 0; }
  .navbar-eko .nav-link.active::after { display: none; }
}
