/* Zakladni nastaveni a sdilene prvky */
.body {margin: 0; padding: 0; color: black; background-color: white; font-family: 'Poppins', sans-serif;}
.odkaz_text:link, a:active, a:visited {color: black; text-decoration: none;}
.odkaz_text:hover {color: coral;}
.nadpis {text-align: center; font-size: 2.2em; color: #0d1f3f; font-weight: 800; text-transform: uppercase; letter-spacing: 1.2px; margin: 40px 0; padding: 10px 0; background: linear-gradient(to right, rgba(0, 0, 0, 0.05), rgba(0, 0, 0, 0.1)); box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);}
.pruh {width: 100%; height: auto; background-color: #ffefd5; margin: 100px auto; display: flex; justify-content: center; align-items: center; flex-wrap: wrap; box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);}
.pruh a {text-decoration: none; color: inherit; background-color: white; padding: 15px 25px; margin: 10px 20px; border-radius: 5px; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); cursor: pointer; text-align: center; font-size: 1.0em; transition: background-color 1.0s;}
.pruh a:hover {background-color: #ffcc80; transition: background-color 0.0s; box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);}
.prazdny_pruh {width: 100%; height: 500px;}
.homepage-oznameni {display: none; width: min(1100px, calc(100% - 32px)); margin: 24px auto 10px; padding: 16px 20px; box-sizing: border-box; text-align: center; color: #7a3e00; background: linear-gradient(135deg, #fff2d8 0%, #ffe4b3 100%); border: 1px solid #f0ba67; border-radius: 12px; box-shadow: 0 10px 24px rgba(122, 62, 0, 0.12); font-size: 1.05em; font-weight: 600; line-height: 1.5;}
.homepage-oznameni.is-visible {display: block;}

/* Homepage */
.home-page {padding-bottom: 20px;}
.home-hero {width: min(1180px, calc(100% - 40px)); margin: 30px auto 0; display: grid; grid-template-columns: minmax(0, 1.12fr) minmax(320px, 0.82fr); gap: 28px; align-items: stretch;}
.home-hero-copy {position: relative; padding: 42px 42px 34px; color: #132038; background: radial-gradient(circle at top left, rgba(255, 221, 155, 0.92) 0%, rgba(255, 244, 225, 0.96) 38%, #ffffff 100%); border: 1px solid rgba(240, 186, 103, 0.45); border-radius: 26px; box-shadow: 0 22px 48px rgba(83, 54, 10, 0.12); overflow: hidden;}
.home-hero-copy::after {content: ""; position: absolute; width: 240px; height: 240px; top: -120px; right: -80px; background: rgba(255, 184, 79, 0.18); border-radius: 50%;}
.home-eyebrow {position: relative; z-index: 1; margin: 0 0 14px; color: #b35b00; font-size: 0.88em; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase;}
.home-hero h1 {position: relative; z-index: 1; margin: 0; font-size: clamp(2.3rem, 4vw, 4.4rem); line-height: 1.02; color: #0d1f3f;}
.home-lead {position: relative; z-index: 1; max-width: 620px; margin: 18px 0 0; color: #3d4656; font-size: 1.08em; line-height: 1.75;}
.home-hero-actions {position: relative; z-index: 1; display: flex; flex-wrap: wrap; gap: 12px; margin-top: 26px;}
.home-hero-actions a {display: inline-flex; align-items: center; justify-content: center; min-height: 50px; padding: 0 20px; border-radius: 999px; text-decoration: none; font-weight: 800; transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;}
.home-action-primary {color: #111; background: linear-gradient(135deg, #ffb84f 0%, #ffc970 100%); box-shadow: 0 14px 30px rgba(179, 91, 0, 0.18);}
.home-action-secondary {color: #152033; background: rgba(255, 255, 255, 0.88); border: 1px solid rgba(20, 32, 51, 0.1); box-shadow: 0 8px 20px rgba(13, 31, 63, 0.08);}
.home-hero-actions a:hover {transform: translateY(-2px);}
.home-hero-points {position: relative; z-index: 1; display: flex; flex-wrap: wrap; gap: 10px; margin-top: 22px;}
.home-hero-points span {padding: 10px 14px; color: #5a4a2a; background: rgba(255, 255, 255, 0.78); border: 1px solid rgba(240, 186, 103, 0.35); border-radius: 999px; font-size: 0.92em; font-weight: 700;}
.home-hero-stats {position: relative; z-index: 1; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; margin-top: 28px;}
.home-hero-stats article {padding: 18px 16px; background: rgba(13, 31, 63, 0.92); border-radius: 18px; color: #f8fafc; box-shadow: 0 12px 24px rgba(13, 31, 63, 0.12);}
.home-hero-stats strong {display: block; color: #ffcf8a; font-size: 2em; line-height: 1; font-weight: 900;}
.home-hero-stats span {display: block; margin-top: 8px; font-size: 0.92em; font-weight: 600; line-height: 1.45;}
.home-hero-stage {position: relative; min-height: 560px; padding: 14px; background: radial-gradient(circle at top left, rgba(255, 221, 155, 0.92) 0%, rgba(255, 244, 225, 0.96) 38%, #ffffff 100%); border: 1px solid rgba(240, 186, 103, 0.45); border-radius: 26px; box-shadow: 0 22px 48px rgba(83, 54, 10, 0.12); overflow: hidden;}
.home-hero-stage::before {content: ""; position: absolute; inset: auto -70px -90px auto; width: 280px; height: 280px; background: rgba(255, 184, 79, 0.14); border-radius: 50%;}
.home-hero-slider {position: relative; height: 100%; min-height: 640px; background: linear-gradient(180deg, rgba(255, 248, 237, 0.98) 0%, #ffffff 100%); border: 1px solid rgba(240, 186, 103, 0.35); border-radius: 22px; overflow: hidden; box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);}
.home-hero-slide {position: absolute; inset: 0; display: flex; align-items: flex-end; justify-content: flex-start; opacity: 0; pointer-events: none; transition: opacity 0.7s ease, transform 0.7s ease; transform: scale(1.02);}
.home-hero-slide.is-active {opacity: 1; pointer-events: auto; transform: scale(1);}
.home-hero-slide img {position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center; background: linear-gradient(180deg, rgba(255, 248, 237, 0.98) 0%, #ffffff 100%);}
.home-hero-slide::after {content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(255, 255, 255, 0.04) 0%, rgba(19, 32, 56, 0.12) 56%, rgba(19, 32, 56, 0.56) 100%);}
.home-hero-slide-poster img {object-position: center top;}
.home-hero-slide-showroom img {object-position: center center;}
.home-hero-slide-promo img {object-position: 34% center;}
.home-hero-caption {position: relative; z-index: 1; display: inline-flex; align-items: center; max-width: min(88%, 360px); margin: 0 0 28px 20px; padding: 12px 16px; color: #152033; background: rgba(255, 255, 255, 0.9); border: 1px solid rgba(240, 186, 103, 0.42); border-radius: 18px; font-size: 1em; font-weight: 800; line-height: 1.45; box-shadow: 0 12px 26px rgba(19, 32, 56, 0.12);}
.home-hero-dots {position: absolute; left: 28px; bottom: 28px; z-index: 2; display: flex; gap: 10px;}
.home-hero-dots button {width: 12px; height: 12px; padding: 0; border: 0; border-radius: 50%; background: rgba(255, 255, 255, 0.35); cursor: pointer; transition: transform 0.2s ease, background-color 0.2s ease;}
.home-hero-dots button.is-active {background: #ffcf8a; transform: scale(1.15);}
.home-hero-panel {position: absolute; right: 22px; bottom: 22px; z-index: 3; display: grid; gap: 12px; width: min(290px, calc(100% - 44px)); padding: 18px; background: rgba(255, 255, 255, 0.94); border: 1px solid rgba(240, 186, 103, 0.42); border-radius: 20px; box-shadow: 0 18px 36px rgba(83, 54, 10, 0.16);}
.home-hero-panel div {display: grid; gap: 4px;}
.home-hero-panel p {margin: 0; color: #b35b00; font-size: 0.82em; font-weight: 800; text-transform: uppercase; letter-spacing: 0.05em;}
.home-hero-panel strong {color: #152033; font-size: 1em; line-height: 1.5;}
.home-hero-panel a {display: inline-flex; align-items: center; justify-content: center; min-height: 44px; margin-top: 4px; color: #111; text-decoration: none; font-weight: 800; background: #ffb84f; border-radius: 999px;}
.home-section {width: min(1180px, calc(100% - 40px)); margin: 28px auto 0;}
.home-section-head {display: flex; align-items: flex-end; justify-content: space-between; gap: 18px; margin-bottom: 18px;}
.home-section-head p {margin: 0 0 6px; color: #b35b00; font-size: 0.82em; font-weight: 800; text-transform: uppercase; letter-spacing: 0.08em;}
.home-section-head h2 {margin: 0; color: #0d1f3f; font-size: 2.2em;}
.home-category-grid {display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 18px;}
.home-category-card {position: relative; display: block; padding: 24px 22px 22px; color: #152033; text-decoration: none; background: linear-gradient(180deg, rgba(255, 238, 211, 0.82) 0%, #ffffff 100%); border: 1px solid #f1d4a1; border-radius: 20px; box-shadow: 0 12px 28px rgba(13, 31, 63, 0.08); overflow: hidden; transition: transform 0.2s ease, box-shadow 0.2s ease;}
.home-category-card::before {content: ""; position: absolute; inset: 0 auto 0 0; width: 5px; background: linear-gradient(180deg, #ffb84f 0%, #f08c00 100%);}
.home-category-card:hover {transform: translateY(-4px); box-shadow: 0 18px 34px rgba(13, 31, 63, 0.12);}
.home-category-count, .home-category-label {display: inline-flex; align-items: center; min-height: 30px; margin-bottom: 16px; padding: 0 12px; color: #ffffff; background: #0d1f3f; border-radius: 999px; font-size: 0.92em; font-weight: 800;}
.home-category-card h3 {margin: 0; font-size: 1.45em; color: #152033;}
.home-category-card p {margin: 12px 0 0; color: #516076; line-height: 1.6;}
.home-story-grid {display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(320px, 0.9fr); gap: 24px;}
.home-story-card, .home-service-card, .home-news-card, .home-contact-card {border: 1px solid #e6e8ec; border-radius: 22px; box-shadow: 0 16px 34px rgba(13, 31, 63, 0.08);}
.home-story-card {padding: 30px; background: linear-gradient(145deg, #ffffff 0%, #fff7eb 100%);}
.home-label {margin: 0 0 10px; color: #b35b00; font-size: 0.82em; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase;}
.home-story-card h2, .home-service-card h2, .home-contact-card h2 {margin: 0; color: #0d1f3f; font-size: 2em; line-height: 1.18;}
.home-story-card p:not(.home-label) {margin: 16px 0 0; color: #3d4656; line-height: 1.8;}
.home-brand-strip {display: flex; flex-wrap: wrap; gap: 10px; margin-top: 22px;}
.home-brand-strip span {padding: 10px 14px; color: #0d1f3f; background: #fff; border: 1px solid #ead3aa; border-radius: 999px; font-weight: 700;}
.home-service-card {padding: 30px; background: linear-gradient(165deg, #152033 0%, #213454 100%); color: #f8fafc;}
.home-service-card h2 {color: #ffffff;}
.home-checklist {display: grid; gap: 12px; margin: 22px 0 0; padding: 0; list-style: none;}
.home-checklist li {position: relative; padding-left: 24px; color: #d8dee8; line-height: 1.65;}
.home-checklist li::before {content: ""; position: absolute; left: 0; top: 11px; width: 10px; height: 10px; background: #ffb84f; border-radius: 50%;}
.home-service-actions {display: flex; flex-wrap: wrap; gap: 12px; margin-top: 24px;}
.home-service-actions a {display: inline-flex; align-items: center; justify-content: center; min-height: 46px; padding: 0 18px; color: #111; text-decoration: none; font-weight: 800; background: #ffcf8a; border-radius: 999px;}
.home-news-grid {display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 20px;}
.home-news-card {display: grid; grid-template-rows: auto 1fr; overflow: hidden; background: #ffffff; transition: transform 0.2s ease, box-shadow 0.2s ease;}
.home-news-card:hover {transform: translateY(-4px); box-shadow: 0 22px 40px rgba(13, 31, 63, 0.12);}
.home-news-card img {width: 100%; height: 220px; object-fit: cover;}
.home-news-card > div {display: flex; flex-direction: column; gap: 12px; padding: 22px;}
.home-news-tag {margin: 0; color: #b35b00; font-size: 0.8em; font-weight: 800; text-transform: uppercase; letter-spacing: 0.06em;}
.home-news-card h3 {margin: 0; color: #152033; font-size: 1.4em; line-height: 1.25;}
.home-news-card p {margin: 0; color: #506073; line-height: 1.7;}
.home-news-price {color: #d80000 !important; font-size: 1.25em; font-weight: 900;}
.home-news-card a {display: inline-flex; align-items: center; margin-top: auto; color: #b35b00; font-weight: 800; text-decoration: none;}
.home-contact-grid {display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 20px;}
.home-contact-card {display: flex; flex-direction: column; gap: 14px; padding: 28px; color: #152033; text-decoration: none; background: linear-gradient(145deg, #ffffff 0%, #f8fafc 100%);}
.home-contact-card p {margin: 0; color: #3d4656; line-height: 1.75;}
.home-contact-card strong {color: #152033; font-size: 1.1em; line-height: 1.5;}
.home-contact-card[href] {transition: transform 0.2s ease, box-shadow 0.2s ease;}
.home-contact-card[href]:hover {transform: translateY(-4px); box-shadow: 0 22px 40px rgba(13, 31, 63, 0.12);}
.home-contact-card.is-map {background: linear-gradient(145deg, #fff6e8 0%, #ffffff 100%);}
.home-contact-actions {background: linear-gradient(145deg, #fff4dc 0%, #ffffff 100%);}
.home-action-stack {display: grid; gap: 10px; margin-top: 6px;}
.home-action-stack a {display: inline-flex; align-items: center; justify-content: center; min-height: 46px; color: #111; text-decoration: none; font-weight: 800; background: #ffb84f; border-radius: 999px;}
.home-contact-note {display: inline-flex; align-items: center; width: max-content; padding: 8px 12px; color: #0d1f3f; background: #eef3fa; border-radius: 999px; font-size: 0.9em; font-weight: 700;}
.home-hero-panel a:hover, .home-service-actions a:hover, .home-action-stack a:hover {filter: brightness(0.98);}

/* Horni navigace */
.horni_lista {width: 100%; min-height: 68px; overflow-x: hidden; position: sticky; top: 0; background: linear-gradient(135deg, #f2a43b 0%, #ffc46b 58%, #f6ae45 100%); font-family: 'Poppins', sans-serif; z-index: 1000; display: flex; align-items: center; justify-content: space-between; gap: 18px; padding: 0 22px; box-sizing: border-box; border-bottom: 1px solid rgba(126, 72, 8, 0.22); box-shadow: 0 10px 24px rgba(69, 43, 13, 0.14);}
.horni_lista img {height: 54px; max-width: min(42vw, 420px); object-fit: contain; cursor: pointer; display: block;}
.horni_lista .mezera {flex-grow: 1;}
.horni_lista .menu_buttons {display: flex; align-items: center; justify-content: flex-end; gap: 6px; min-width: 0;}
.horni_lista .menu_button {height: 42px; padding: 0 16px; transform: none; transition: background-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease; cursor: pointer; display: flex; align-items: center; justify-content: center; border: 1px solid transparent; border-radius: 999px; color: #17120b; font-size: 0.96em; font-weight: 700; white-space: nowrap;}
.horni_lista .menu_button:hover {background-color: rgba(255, 255, 255, 0.36); border-color: rgba(255, 255, 255, 0.42); transform: translateY(-1px);}
.horni_lista .menu_button.active, .horni_lista .menu_button.active:hover {background-color: #ffffff; border-color: rgba(255, 255, 255, 0.8); box-shadow: 0 8px 20px rgba(91, 52, 5, 0.16); color: #111827;}

/* Spodni lista */
.spodni_lista {margin-top: 80px; color: #f8fafc; background: #171d27; border-top: 4px solid #ffb84f;}
.footer-inner {width: min(1180px, calc(100% - 40px)); margin: 0 auto; padding: 34px 0 24px; display: grid; grid-template-columns: minmax(220px, 1.2fr) minmax(220px, 1fr) minmax(160px, 0.8fr) minmax(260px, 1.1fr); gap: 24px; align-items: start;}
.footer-brand img {width: 190px; height: auto; display: block; margin-bottom: 14px; padding: 6px; background: white; border-radius: 6px;}
.footer-brand p {margin: 0; color: #d8dee8; line-height: 1.6;}
.footer-contact {display: flex; flex-direction: column; gap: 12px;}
.footer-contact a {display: inline-flex; align-items: center; gap: 10px; color: #f8fafc; text-decoration: none; font-weight: 700;}
.footer-contact img {width: 28px; height: 28px; object-fit: contain;}
.footer-links {display: grid; gap: 10px;}
.footer-links a {color: #f8fafc; text-decoration: none; font-weight: 700; padding: 10px 12px; border: 1px solid rgba(255, 255, 255, 0.12); border-radius: 6px; background: rgba(255, 255, 255, 0.05);}
.footer-links a:hover, .footer-contact a:hover {color: #ffcf8a;}
.footer-counts {display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px;}
.footer-counts a {min-height: 112px; color: #f8fafc; text-decoration: none; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 6px; padding: 12px 8px; border-radius: 8px; background: rgba(255, 255, 255, 0.07); border: 1px solid rgba(255, 255, 255, 0.12);}
.footer-counts a:hover {background: rgba(255, 184, 79, 0.16); border-color: rgba(255, 184, 79, 0.45);}
.footer-counts img {width: 34px; height: 34px; object-fit: contain;}
.footer-counts span {color: #ffb84f; font-size: 1.8em; line-height: 1; font-weight: 900;}
.footer-counts strong {font-size: 0.82em; text-align: center;}
.footer-note {grid-column: 1 / -1; margin: 8px 0 0; padding-top: 18px; color: #aeb8c6; border-top: 1px solid rgba(255, 255, 255, 0.12); font-size: 0.9em;}

/* Uvodni stranka */
.slider {position: relative; width: 100%; overflow: hidden; height: 520px;}
.slider-images {display: flex; transition: transform 1s ease-in-out; width: 100%; height: auto;}
.slider img {width: 100%; height: auto;}
.slider-images a {width: 100%; height: 100%; flex-shrink: 0;}
.slider-images > img {width: 100%; flex-shrink: 0;}
.uvod {display: flex; width: 90%; margin: 0 auto;}
.uvod_left {flex: 1; padding: 20px;}
.uvod_right {flex: 1; padding: 20px; text-align: center;}
.uvod_right img {width: 60%; height: auto;}
.uvod .odstavec {font-size: 1.4em; text-align: justify; text-indent: 50px;}
.cedule {margin: 100px auto; display: flex; justify-content: center; gap: 20px;}
.cedule div {background-color: #f7f7f7; border-radius: 15px; box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2); padding: 20px 30px; text-align: center; font-family: 'Poiret One', cursive; font-size: 1.5em; display: flex; align-items: center; justify-content: center;}
.cedule span {color: #0032a5; font-size: 2em; padding-right: 20px;}
.aktualita {width: 90%; display: flex; align-items: center; margin: 50px auto; padding: 30px; background: linear-gradient(to right, rgba(255, 204, 102, 0.5) 30%, rgba(255, 255, 255, 0.5) 70%); box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2), 0 6px 20px rgba(0, 0, 0, 0.19); border-radius: 10px;}
.aktualita img {width: 250px; height: auto; margin-right: 20px;}
.aktualita-content {flex-grow: 1;}
.aktualita h1 {margin: 0 0 10px 0;}
.aktualita .cena {font-size: 1.5em; font-weight: bold; color: #ff0000;}
.aktualita_big {width: 90%; display: flex; align-items: center; margin: 50px auto; padding: 30px; background: linear-gradient(to right, rgba(255, 204, 102, 0.5) 30%, rgba(255, 255, 255, 0.5) 70%); box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2), 0 6px 20px rgba(0, 0, 0, 0.19); border-radius: 10px;}
.aktualita_big img {width: 90%; height: auto; margin: 5px auto;}
.aktuality {display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; width: 90%; margin: 50px auto;}
.prouzky {margin: 70px auto; width: 80%;}
.prouzky div {padding: 15px 20px; margin: 15px 0; background: linear-gradient(to right, #ffb84f 20%, #EEEEEE 50%); box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); border-radius: 8px; font-size: 1.1em; line-height: 1.6; color: #333;}
.oteviracka {margin: 30px auto; padding: 50px 0; display: flex; justify-content: center; width: 100%; text-align: center; background-color: rgb(250,253,242); border-bottom: 1px solid rgb(221, 221, 221); border-top: 1px solid rgb(221, 221, 221);}

/* Stare tabulkove menu */
.menu_linka {width: 100%; border-collapse: collapse; table-layout: fixed;}
.menu_linka td {border-bottom: 3px solid #ccc; text-align: center; padding: 10px; transition: border-color 0.3s;}
.menu_linka td.left, .menu_linka td.right {width: 120px; text-align: center;}
.menu_linka td.middle {font-size: 2em; width: 1px; white-space: nowrap; font-weight: bolder;}
.menu_linka td.spacer {width: 100%;}
.menu_linka td.left:hover, .menu_linka td.right:hover {border-bottom: 3px solid orange; cursor: pointer;}
.menu_linka a {text-decoration: none; color: inherit;}
.menu_linka td.aktivni {border-bottom: 3px solid orange;}

/* Sluzby a doplnky */
.sluzby-container {display: flex; flex-wrap: wrap; justify-content: center; margin: 20px auto; width: 100%;}
.sluzby-card {display: flex; width: min(100%, 980px); min-height: 350px; height: auto; background-color: #fff; border-radius: 12px; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1); overflow: hidden; margin: 25px auto;}
.sluzby-container .klikaci {cursor: pointer; transition: background-color 0.3s ease, transform 0.2s ease;}
.sluzby-container .klikaci:hover {background-color: #f0f0f0; transform: scale(1.05);}
.sluzby-card-left {flex: 0 0 35%; min-width: 260px; background-color: #f5f5f5; display: flex; align-items: center; justify-content: center; padding: 24px;}
.sluzby-card-left img {width: 90%; height: auto; max-width: 330px; object-fit: contain;}
.sluzby-card-right {flex: 1 1 auto; min-width: 0; padding: 28px 32px; display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-start;}
.sluzby-card-right img {width: auto; height: 64px; max-width: 100%; object-fit: contain; margin: 4px 8px 4px 0;}
.sluzby-card-right .repliky img {cursor: pointer;}
.sluzby-card-right h2 {font-size: 1.5em; font-weight: bold; color: #333; margin: 0 0 10px; align-self: center; text-align: center;}
.sluzby-card-right p {margin: 0; margin-bottom: 1em; text-align: justify; line-height: 1.55;}
.sluzby-card-right .cenovka {font-weight: bold; color: #d80000; font-size: 1.2em;}
.sluzby-card-right .zvyrazneni {font-weight: bold; color: #540505; align-self: center;}
.sluzby-card-right ul {list-style-type: none; padding: 0; margin: 10px 0;}
.sluzby-card-right ul li {padding: 2px 0; color: #0d1f3f;}
.sluzby-card-right ul li::before {content: '•'; color: #ff4500; font-size: 1.3em; font-weight: bold; display: inline-block; margin-right: 0.5em;}
#modal {display: none; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.8); align-items: center; justify-content: center; cursor: pointer; z-index: 1000;}
#modal img {max-width: 80%; max-height: 80%; border-radius: 10px;}
.sluzby_clanek {margin: 50px 0; padding: 50px 10px; background-color: whitesmoke; text-align: center;}
.sluzby_clanek p {text-align: justify; padding: 10px 20%;}
.sluzby_kontakt {margin: 50px auto; display: flex; width: 90%; gap: 20px;}
.sluzby_kontakt a {width: 400px; display: flex; text-align: center; align-items: center; padding: 15px; border-radius: 10px; background-color: cornsilk; box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1); text-decoration: none; color: black; transition: background-color 0.3s ease;}
.sluzby_kontakt a:hover {background-color: #ffe4ad;}
.sluzby_kontakt .icon {font-size: 3em; margin-right: 25px;}

/* Kontakty */
.kontakty-container {display: flex; flex-wrap: wrap; justify-content: center; margin: 20px auto; width: 95%;}
.kontakty-card {display: flex; width: 550px; height: 200px; background-color: #fff; border-radius: 12px; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1); overflow: hidden; margin: 25px;}
.kontakty-container .klikaci {cursor: pointer; transition: background-color 0.3s ease, transform 0.2s ease;}
.kontakty-container .klikaci:hover {background-color: #f0f0f0; transform: scale(1.05);}
.kontakty-card-left {flex: 1; background-color: #f5f5f5; display: flex; align-items: center; justify-content: center; padding: 20px;}
.kontakty-card-left img {width: 80%; height: auto; max-width: 150px; object-fit: contain;}
.kontakty-card-right {flex: 2; padding: 20px; display: flex; flex-direction: column; justify-content: center;}
.kontakty-card-right img {width: auto; height: 72px;}
.kontakty-card-right h2 {font-size: 1.3em; margin: 0 0 10px; font-weight: bold; color: #333;}
.kontakty-card-right p {margin: 0; font-size: 1em; color: #555; line-height: 1.6; text-align: center;}

/* Katalog a porovnani modelu */
.catalog-page {width: min(1180px, calc(100% - 40px)); margin: 42px auto 80px;}
.catalog-head {display: grid; grid-template-columns: 1fr auto; gap: 6px 24px; align-items: end; margin-bottom: 22px;}
.catalog-head p {grid-column: 1 / -1; margin: 0; color: #b35b00; font-weight: 700; text-transform: uppercase; font-size: 0.85em;}
.catalog-head h1 {margin: 0; color: #0d1f3f; font-size: 2.4em;}
.catalog-head span {color: #555; font-weight: 600;}
.filter-bar {display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; padding: 12px; margin-bottom: 28px; background: #f6f7f9; border: 1px solid #e6e8ec; border-radius: 8px;}
.filter-buttons {display: flex; flex-wrap: wrap; gap: 10px;}
.filter-button {border: 1px solid #d7dce3; background: white; color: #1d2735; padding: 10px 18px; border-radius: 6px; cursor: pointer; font: inherit; font-weight: 700; transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;}
.filter-button:hover, .filter-button.active {background: #ffb84f; border-color: #ffb84f; color: #111;}
.compare-link, .compare-back {display: inline-flex; align-items: center; min-height: 40px; color: #111; background: #ffb84f; border-radius: 6px; padding: 0 16px; text-decoration: none; font-weight: 800;}
.compare-link:hover, .compare-back:hover {background: #ffcc80;}
.model-grid {display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 320px)); justify-content: center; gap: 24px;}
.model-card {background: white; border: 1px solid #e6e8ec; border-radius: 8px; overflow: hidden; box-shadow: 0 10px 26px rgba(13, 31, 63, 0.08); transition: transform 0.2s ease, box-shadow 0.2s ease;}
.model-card:hover {transform: translateY(-4px); box-shadow: 0 16px 34px rgba(13, 31, 63, 0.14);}
.model-card a {display: block; color: inherit; text-decoration: none;}
.model-card-image {height: 220px; background: #f4f5f7; display: flex; align-items: center; justify-content: center; padding: 18px;}
.model-card-image img {max-width: 100%; max-height: 100%; object-fit: contain;}
.model-card-content {padding: 18px;}
.model-brand {margin: 0 0 4px; color: #b35b00; font-size: 0.82em; font-weight: 800; text-transform: uppercase;}
.model-card h2 {margin: 0 0 12px; color: #152033; font-size: 1.35em;}
.model-price {display: flex; gap: 10px; align-items: baseline; margin-bottom: 14px; color: #d80000; font-size: 1.35em; font-weight: 800;}
.model-price-old {color: #8b95a5; text-decoration: line-through; font-size: 0.76em; font-weight: 600;}
.model-spec {display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-bottom: 14px;}
.model-spec span {background: #f6f7f9; border-radius: 6px; padding: 8px 6px; color: #455165; font-size: 0.84em; text-align: center; font-weight: 700;}
.model-statuses {display: flex; flex-wrap: wrap; gap: 8px;}
.model-status {border-radius: 999px; color: white; font-size: 0.72em; font-weight: 800; padding: 5px 10px; text-transform: uppercase;}
.model-status.skladem {background: #2f9e44;}
.model-status.vystaveno {background: #1c7ed6;}
.model-status.sleva {background: #e8590c;}
.model-status.novinka {background: #f08c00;}
.model-empty {grid-column: 1 / -1; padding: 42px; text-align: center; background: #f6f7f9; border: 1px dashed #cbd2dc; border-radius: 8px; color: #596579;}
.compare-intro {margin: 0 0 22px; color: #3c4656; line-height: 1.65;}
.compare-table-wrap {overflow-x: auto; border: 1px solid #e6e8ec; border-radius: 8px; background: white; box-shadow: 0 10px 26px rgba(13, 31, 63, 0.06);}
.porovnavaci_tabulka {width: 100%; min-width: 980px; border-collapse: collapse; background-color: #fff;}
.porovnavaci_tabulka th {background-color: #f0f2f5; font-weight: 800; padding: 12px 10px; text-align: left; color: #263246; font-size: 0.9em; user-select: none;}
.porovnavaci_tabulka th:hover {cursor: pointer; color: #b35b00;}
.porovnavaci_tabulka th.asc::after {content: " ↑";}
.porovnavaci_tabulka th.desc::after {content: " ↓";}
.porovnavaci_tabulka td {padding: 12px 10px; text-align: left; border-bottom: 1px solid #e6e8ec; color: #455165;}
.porovnavaci_tabulka tbody tr:nth-child(even) {background-color: #f8f9fb;}
.porovnavaci_tabulka tbody tr:hover {background-color: #fff4df; cursor: pointer;}
.porovnavaci_tabulka .porovnani_model {font-weight: 800; color: #152033;}
.porovnavaci_tabulka .porovnani_cena {font-weight: 900; color: #d80000;}

/* Detail modelu */
.detail-page {width: min(1180px, calc(100% - 40px)); margin: 34px auto 80px;}
.detail-toolbar {display: flex; justify-content: space-between; align-items: center; gap: 20px; min-height: 70px; padding: 10px 24px; background-color: rgba(255, 255, 255, 0.86); border: 1px solid rgba(0, 0, 0, 0.08); border-radius: 8px; box-shadow: 0 8px 24px rgba(13, 31, 63, 0.08);}
.detail-toolbar-actions {display: flex; flex-wrap: wrap; gap: 10px;}
.detail-toolbar-actions a {text-decoration: none; color: inherit; background-color: rgba(255, 255, 255, 0.92); border: 1px solid rgba(0, 0, 0, 0.1); padding: 10px 20px; border-radius: 5px; box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1); font-size: 1em; cursor: pointer; transition: background-color 0.2s ease;}
.detail-toolbar-actions a:hover {background-color: rgb(255, 204, 102); box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);}
.detail-toolbar-price {display: flex; align-items: center; justify-content: flex-end; flex-wrap: wrap; gap: 14px;}
.detail-toolbar-price .detail-price {margin: 0;}
.detail-title-strip {margin: 30px auto; min-height: 300px; display: grid; grid-template-columns: minmax(260px, 420px) 1fr; align-items: center; gap: 28px; padding: 0 40px; text-align: center; background: linear-gradient(to left, #e8e8e8 0%, #ffffff 50%); box-shadow: 0 4px 8px 0 rgb(0, 0, 0), 0 6px 20px 0 rgb(0, 0, 0);}
.detail-title-image {height: 300px; display: flex; align-items: center; justify-content: center;}
.detail-main-photo {width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; border: 0; background: transparent; padding: 0; cursor: pointer;}
.detail-main-photo:hover img {transform: scale(1.03);}
.detail-main-photo:focus-visible {outline: 3px solid #ffb84f; outline-offset: 4px; border-radius: 8px;}
.detail-title-image img {width: auto; max-width: 100%; height: 300px; object-fit: contain; transition: transform 0.2s ease;}
.detail-title-strip h1 {margin: 0; color: #111; font-family: 'Codystar', 'Poppins', sans-serif; font-size: 3em; font-weight: 900; line-height: 1.18;}
.detail-title-strip h1 span {color: #111;}
.detail-title-strip h1 strong {color: red; font-weight: 900;}
.detail-price {display: flex; gap: 14px; align-items: baseline; margin-bottom: 18px; color: #d80000; font-size: 2em; font-weight: 900;}
.detail-price-old {color: #8b95a5; text-decoration: line-through; font-size: 0.62em; font-weight: 700;}
.detail-actions {display: flex; flex-wrap: wrap; gap: 10px; margin-top: 22px;}
.detail-actions a, .model-not-found a {background: #ffb84f; border-radius: 6px; color: #111; font-weight: 800; padding: 12px 16px; text-decoration: none;}
.model-section {margin-top: 28px; padding: 28px; background: white; border: 1px solid #e6e8ec; border-radius: 8px; box-shadow: 0 10px 26px rgba(13, 31, 63, 0.06);}
.model-section h2 {margin: 0 0 18px; color: #0d1f3f;}
.detail-params {display: grid; grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)); gap: 12px;}
.detail-params div {background: #f6f7f9; border-radius: 6px; padding: 14px;}
.detail-params span {display: block; color: #6b7484; font-size: 0.82em; margin-bottom: 4px;}
.detail-params strong {color: #152033;}
.detail-grid {display: grid; grid-template-columns: 1fr 1fr; gap: 28px;}
.detail-list {margin: 0; padding-left: 20px; color: #263246; line-height: 1.7;}
.detail-colors {display: flex; flex-wrap: wrap; gap: 10px;}
.detail-colors span {border: 1px solid #d7dce3; border-radius: 6px; min-width: 92px; padding: 12px; text-align: center; font-weight: 800;}
.detail-description {margin: 0; color: #263246; line-height: 1.75;}
.detail-description h3 {margin: 0 0 12px; color: #152033; font-size: 1.3em;}
.detail-description p {margin: 0 0 14px;}
.detail-description p:last-child {margin-bottom: 0;}
.detail-accessories {display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 14px;}
.detail-accessories a, .detail-accessories div {display: flex; flex-direction: column; align-items: center; justify-content: flex-start; gap: 12px; min-height: 190px; padding: 14px; color: #152033; text-align: center; text-decoration: none; background: #f6f7f9; border: 1px solid #e6e8ec; border-radius: 8px; transition: transform 0.2s ease, box-shadow 0.2s ease;}
.detail-accessories a:hover {transform: translateY(-2px); box-shadow: 0 10px 22px rgba(13, 31, 63, 0.12);}
.detail-accessories span {display: flex; align-items: center; justify-content: center; width: 100%; height: 108px; background: white; border-radius: 6px;}
.detail-accessories img {max-width: 100%; max-height: 100%; object-fit: contain;}
.detail-accessories strong {font-size: 0.95em; line-height: 1.35;}
.model-not-found {padding: 60px 20px; text-align: center;}
.detail-brand-section {overflow: hidden;}
.detail-brand-layout {display: grid; grid-template-columns: minmax(180px, 250px) minmax(0, 1fr); gap: 24px; align-items: center;}
.detail-brand-media {display: flex; align-items: center; justify-content: center; min-height: 180px; padding: 18px; background: #f6f7f9; border: 1px solid #e6e8ec; border-radius: 8px; box-sizing: border-box;}
.detail-brand-media img {max-width: 100%; max-height: 180px; object-fit: contain;}
.detail-brand-copy {margin: 0;}
.detail-brand-copy p {text-align: left;}
.detail-brand-accent {color: #ff5a2f;}

/* Galerie detailu modelu */
.detail-gallery {display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 14px;}
.detail-gallery button {display: flex; align-items: center; justify-content: center; height: 150px; background: #f6f7f9; border: 0; border-radius: 8px; overflow: hidden; cursor: pointer; padding: 0;}
.detail-gallery img {width: 100%; height: 100%; object-fit: contain; transition: transform 0.2s ease;}
.detail-gallery button:hover img {transform: scale(1.04);}
.gallery-open {overflow: hidden;}
.gallery-lightbox {display: none; position: fixed; inset: 0; z-index: 2000; background: rgba(0, 0, 0, 0.88); align-items: center; justify-content: center; padding: 70px 96px;}
.gallery-lightbox.open {display: flex;}
.gallery-lightbox img {max-width: 100%; max-height: 100%; object-fit: contain; border-radius: 8px; box-shadow: 0 16px 45px rgba(0, 0, 0, 0.4);}
.gallery-close, .gallery-nav {position: fixed; border: 0; border-radius: 6px; background: rgba(255, 255, 255, 0.92); color: #111; cursor: pointer; font: inherit; font-weight: 800; padding: 12px 16px;}
.gallery-close {top: 22px; right: 24px;}
.gallery-prev {left: 24px; top: 50%; transform: translateY(-50%);}
.gallery-next {right: 24px; top: 50%; transform: translateY(-50%);}
.gallery-close:hover, .gallery-nav:hover {background: #ffb84f;}

@media (max-width: 980px) {
.home-hero {grid-template-columns: 1fr;}
.home-hero-stage {display: flex; flex-direction: column; min-height: 0;}
.home-hero-slider {min-height: 500px;}
.home-hero-panel {position: static; width: auto; margin-top: 16px;}
.home-category-grid {grid-template-columns: repeat(2, minmax(0, 1fr));}
.home-story-grid {grid-template-columns: 1fr;}
.home-news-grid {grid-template-columns: repeat(2, minmax(0, 1fr));}
.home-contact-grid {grid-template-columns: 1fr;}
}

/* Mobilni zobrazeni */
@media (max-width: 760px) {
.home-hero {width: min(1180px, calc(100% - 24px)); margin-top: 18px;}
.home-section {width: min(1180px, calc(100% - 24px));}
.home-hero-copy {padding: 30px 22px 24px; border-radius: 22px;}
.home-hero h1 {font-size: 2.15em;}
.home-lead {font-size: 1em;}
.home-hero-stats {grid-template-columns: 1fr;}
.home-hero-stage {padding: 12px; border-radius: 22px;}
.home-hero-slider {min-height: 420px;}
.home-hero-caption {max-width: calc(100% - 32px); margin: 0 0 18px 16px; font-size: 0.92em;}
.home-hero-dots {left: 18px; bottom: 18px;}
.home-hero-panel {padding: 16px;}
.home-section-head {flex-direction: column; align-items: flex-start;}
.home-section-head h2 {font-size: 1.8em;}
.home-category-grid {grid-template-columns: 1fr;}
.home-hero-actions, .home-service-actions {flex-direction: column;}
.home-story-card, .home-service-card, .home-contact-card {padding: 22px;}
.home-story-card h2, .home-service-card h2, .home-contact-card h2 {font-size: 1.6em;}
.home-news-grid {grid-template-columns: 1fr;}
.home-news-card img {height: 190px;}
.home-hero-actions a, .home-service-actions a, .home-action-stack a {width: 100%;}
.catalog-head {grid-template-columns: 1fr;}
.sluzby-card {flex-direction: column; width: 100%; margin: 18px auto;}
.sluzby-card-left {min-width: 0; min-height: 220px; flex-basis: auto;}
.sluzby-card-right {padding: 22px;}
.sluzby-card-right h2 {font-size: 1.25em;}
.detail-toolbar {align-items: flex-start; flex-direction: column;}
.detail-toolbar-price {justify-content: flex-start;}
.detail-title-strip {grid-template-columns: 1fr; padding: 20px; gap: 12px;}
.detail-title-image {height: 240px;}
.detail-title-image img {height: 240px;}
.detail-title-strip h1 {font-size: 2em;}
.detail-grid {grid-template-columns: 1fr;}
.detail-brand-layout {grid-template-columns: 1fr;}
.detail-brand-media {min-height: 0; padding: 16px;}
.detail-brand-media img {max-height: 160px;}
.horni_lista {height: auto; align-items: center; flex-wrap: wrap; gap: 10px; padding: 10px 14px;}
.horni_lista img {height: 46px; max-width: min(78vw, 360px);}
.horni_lista .mezera {display: none;}
.horni_lista .menu_buttons {width: 100%; flex-wrap: wrap; justify-content: center; gap: 6px;}
.horni_lista .menu_button {height: 38px; padding: 0 12px; transform: none; font-size: 0.9em;}
.footer-inner {grid-template-columns: 1fr; padding: 28px 0 22px;}
.footer-brand img {width: 170px;}
.footer-counts {grid-template-columns: repeat(3, minmax(0, 1fr));}
.footer-counts a {min-height: 96px;}
}
