/* ==========================================================================
   BS Autoservis — doplnkový CSS (responzívne úpravy + 2026 polish)
   Additívne pravidlá. Nemení farby, fonty ani animácie šablóny.
   Načítava sa AŽ ZA style.css, takže má prednosť pri responzívnych opravách.
   ========================================================================== */

/* --- Globálne istoty proti horizontálnemu pretekaniu na mobile --- */
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body { overflow-x: hidden; }
*, *::before, *::after { box-sizing: border-box; }
img, svg, video { max-width: 100%; height: auto; }
img[src=""], img:not([src]) { visibility: hidden; }

/* Plynulejší fokus pre prístupnosť (klávesnica) */
a:focus-visible, button:focus-visible, input:focus-visible,
textarea:focus-visible, select:focus-visible {
  outline: 2px solid var(--primary-color, #ff5e14);
  outline-offset: 2px;
}

/* Obrázky pokrývajúce pozadie nech sa nikdy nedeformujú */
.object-cover { object-fit: cover; }

/* ==========================================================================
   TABLET (<= 1199px)
   ========================================================================== */
@media screen and (max-width: 1199px) {
  .container { padding-left: 24px; padding-right: 24px; }

  .hero-main-title,
  .hero-main-title-1 { font-size: clamp(34px, 6vw, 64px) !important; line-height: 1.08 !important; }

  .section-title, .ak-section-heading h2,
  h2.title, .title h2 { font-size: clamp(26px, 4vw, 44px) !important; line-height: 1.15 !important; }
}

/* ==========================================================================
   TABLET / MENU BREAK (<= 991px)
   ========================================================================== */
@media screen and (max-width: 991px) {
  .container { padding-left: 20px; padding-right: 20px; }

  /* Sekcie majú obrovské vertikálne medzery — zmenšíme ich rozumne */
  [class*="ak-height-150"] { height: 70px !important; }
  [class*="ak-height-140"] { height: 64px !important; }
  [class*="ak-height-130"] { height: 60px !important; }
  [class*="ak-height-125"] { height: 56px !important; }
  [class*="ak-height-120"] { height: 54px !important; }
  [class*="ak-height-115"] { height: 52px !important; }
  [class*="ak-height-110"] { height: 50px !important; }
  [class*="ak-height-100"] { height: 46px !important; }
  [class*="ak-height-90"]  { height: 42px !important; }
  [class*="ak-height-85"]  { height: 40px !important; }
  [class*="ak-height-80"]  { height: 38px !important; }
  [class*="ak-height-75"]  { height: 36px !important; }
  [class*="ak-height-70"]  { height: 34px !important; }

  /* Hero ako kompaktnejší na tablete */
  .ak-hero { min-height: 78vh; }
  .hero-slider-info { padding-top: 40px; padding-bottom: 40px; }

  /* Mriežky kariet -> 2 stĺpce / stack */
  .services-wrapper, .blog-wrapper, .team-wrapper, .pricing-wrapper,
  .gallery-wrapper { gap: 24px; }

  /* Dvojstĺpcové sekcie (text + obrázok) stackujeme */
  .row > [class*="col-lg-6"] { margin-bottom: 24px; }
}

/* ==========================================================================
   MOBILE (<= 767px)
   ========================================================================== */
@media screen and (max-width: 767px) {
  .container { padding-left: 18px; padding-right: 18px; }

  .hero-main-title,
  .hero-main-title-1 { font-size: clamp(28px, 9vw, 40px) !important; }
  .mini-title { font-size: 15px !important; line-height: 1.6 !important; }

  .section-title, .ak-section-heading h2,
  h2.title, .title h2 { font-size: clamp(24px, 7vw, 32px) !important; }

  p, .desp, .menu-item, li { font-size: 15px; line-height: 1.65; }

  /* Tlačidlá na celú šírku, pohodlný dotyk */
  .common-btn,
  .ak-btn,
  a.common-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
  }

  /* Hero CTA na celú šírku */
  .slider-info .common-btn { width: 100%; max-width: 320px; }

  /* Footer — všetko pekne pod sebou a vycentrované */
  .footer-content {
    display: flex !important;
    flex-direction: column;
    gap: 30px;
    text-align: left;
  }
  .footer-content > div { width: 100% !important; }
  .copy-right {
    flex-direction: column;
    gap: 16px;
    text-align: center;
  }
  .copy-right .social-icon { justify-content: center; display: flex; gap: 14px; }

  /* Hlavičkové kontaktné číslo nech sa nezalamuje cez logo */
  .ak-main-header-right h6 { font-size: 14px !important; white-space: nowrap !important; }

  /* Tabuľky / cenníky scroll na mobile */
  .table-responsive, .pricing-table { overflow-x: auto; -webkit-overflow-scrolling: touch; }

  /* Akordeón / FAQ pohodlnejší dotyk */
  .accordion-button, .faq-question { padding-top: 16px; padding-bottom: 16px; }

  /* Galéria -> 1 stĺpec */
  .gallery-wrapper, .ak-gallery { grid-template-columns: 1fr !important; }

  /* Veľké čísla štatistík */
  .counter-number, .funfact-number { font-size: clamp(32px, 12vw, 48px) !important; }
}

/* ==========================================================================
   MALÝ MOBIL (<= 480px)
   ========================================================================== */
@media screen and (max-width: 480px) {
  .container { padding-left: 16px; padding-right: 16px; }
  /* Telefón menší a vždy na jednom riadku (veľké logo mu uberá miesto) */
  .ak-main-header-right h6 { font-size: 12px !important; white-space: nowrap !important; }
  .ak-main-header-right .d-flex { gap: 8px !important; }
  .ak-main-header-right .heartbeat-icon { transform: scale(.8); }
  .ak-site_branding img { height: 60px !important; } /* aby ostalo miesto na číslo */
  .hero-main-title, .hero-main-title-1 { font-size: clamp(26px, 10vw, 34px) !important; }
}

/* ==========================================================================
   2026 polish — jemné, nemení identitu značky
   ========================================================================== */
@media (prefers-reduced-motion: no-preference) {
  .common-btn, .ak-btn, .service-card, .blog-card, .team-card, .pricing-card {
    transition: transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease;
  }
  .service-card:hover, .blog-card:hover, .team-card:hover, .pricing-card:hover {
    transform: translateY(-6px);
  }
}

::selection { background: var(--primary-color, #ff5e14); color: #fff; }

/* Lepšie zobrazenie máp / iframe */
iframe { max-width: 100%; border: 0; }
.map-wrapper iframe, .contact-map iframe { width: 100%; min-height: 360px; display: block; }

/* ==========================================================================
   DYNAMICKÝ CENNÍK (z MongoDB) — 3 divízie, záložky a tabuľky
   Ladí s tmavou témou šablóny (bg #101010, primary #ff3d24, font Oxanium)
   ========================================================================== */
.bs-pricelist { width: 100%; }
.bs-pricelist-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
  margin-bottom: 40px;
}
.bs-tab {
  font-family: var(--heading-font-family, "Oxanium");
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  font-size: 15px;
  color: #fff;
  background: rgba(255, 255, 255, .06);
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: 50px;
  padding: 12px 28px;
  cursor: pointer;
  transition: all .25s ease;
}
.bs-tab:hover { border-color: var(--primary-color, #ff3d24); }
.bs-tab.active {
  background: var(--primary-color, #ff3d24);
  border-color: var(--primary-color, #ff3d24);
  color: #fff;
}
.bs-panel { display: none; animation: bsFade .4s ease; }
.bs-panel.active { display: block; }
@keyframes bsFade { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }

.bs-division-lead {
  text-align: center;
  font-size: 17px;
  color: var(--body-color, #d3d3d3);
  max-width: 760px;
  margin: 0 auto 40px;
}
.bs-cat-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 26px 40px;
}
.bs-cat {
  background: rgba(255, 255, 255, .03);
  border: 1px solid rgba(255, 255, 255, .08);
  border-radius: 16px;
  padding: 26px 28px;
}
.bs-cat-title {
  font-family: var(--heading-font-family, "Oxanium");
  color: #fff;
  font-size: 21px;
  margin: 0 0 14px;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--primary-color, #ff3d24);
  display: inline-block;
}
.bs-price-table { width: 100%; border-collapse: collapse; }
.bs-price-table td {
  padding: 11px 0;
  border-bottom: 1px dashed rgba(255, 255, 255, .1);
  vertical-align: top;
  font-size: 15.5px;
}
.bs-price-table tr:last-child td { border-bottom: 0; }
.bs-item { color: var(--body-color, #d3d3d3); padding-right: 18px; }
.bs-item-note { color: #8c8c8c; font-size: 13px; }
.bs-price {
  text-align: right;
  white-space: nowrap;
  font-family: var(--heading-font-family, "Oxanium");
  font-weight: 700;
  color: #fff;
}
.bs-price-note { color: var(--primary-color, #ff3d24); font-weight: 600; font-size: 14px; }
.bs-popular .bs-item { color: #fff; font-weight: 600; }
.bs-popular .bs-price { color: var(--primary-color, #ff3d24); }
.bs-pricelist-disclaimer {
  margin-top: 40px;
  font-size: 14px;
  color: #9a9a9a;
  text-align: center;
  max-width: 860px;
  margin-left: auto;
  margin-right: auto;
}

@media screen and (max-width: 991px) {
  .bs-cat-grid { grid-template-columns: 1fr; gap: 20px; }
}
@media screen and (max-width: 767px) {
  .bs-tab { padding: 10px 18px; font-size: 13px; }
  .bs-cat { padding: 20px 18px; }
  .bs-price-table td { font-size: 14.5px; }
}

/* ==========================================================================
   LOGO BS Autoservis — farebné logo na bielom badge (čitateľné na tmavej hlavičke)
   ========================================================================== */
.ak-site_branding img,
.footer-logo img {
  background: #fff;
  padding: 8px 12px;
  border-radius: 10px;
  box-shadow: 0 4px 18px rgba(0,0,0,.25);
}
.ak-site_branding img { height: 208px; width: auto; }
.footer-logo img { height: 96px; width: auto; }
@media screen and (max-width: 767px) {
  .ak-site_branding img { height: 132px; padding: 6px 9px; }
}

/* Telefónne číslo v hlavičke vždy na jednom riadku */
.ak-main-header-right h6,
.ak-main-header-right a { white-space: nowrap; }
.ak-main-header-right { flex: 0 0 auto; }

/* Tlačidlá "OBJEDNAŤ SA" — vždy na jednom riadku (šablóna má v nich <br>) */
.get-started-btn, .common-btn, .ak-btn { white-space: nowrap; }
.get-started-btn br, .common-btn br, .ak-btn br { display: none; }
.get-started-btn > span, .common-btn > span { display: inline-flex; align-items: center; gap: 8px; white-space: nowrap; }
.get-started-btn span span, .common-btn span span { display: inline-flex; align-items: center; }

/* Cenníkové karty (balíčky) — každá položka na jednom riadku, bez zalamovania */
.opation { align-items: center; }
.opation .title,
.opation p {
  white-space: nowrap;
  font-size: 14px;
  line-height: 1.4;
  margin-bottom: 0;
}
.opation .icon { flex: 0 0 auto; }
@media screen and (max-width: 1199px) {
  .opation .title, .opation p { font-size: 13px; }
}
@media screen and (max-width: 575px) {
  .opation .title, .opation p { white-space: normal; font-size: 14px; }
}

/* ==========================================================================
   CENNÍK — interaktívny akordeón po kategóriách (rozbaľovanie)
   ========================================================================== */
.bs-accordion { max-width: 940px; margin: 0 auto; display: flex; flex-direction: column; gap: 14px; }
.bs-acc-item {
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 14px;
  overflow: hidden;
  transition: border-color .25s ease, background .25s ease;
}
.bs-acc-item.open { border-color: rgba(255,61,36,.55); background: rgba(255,255,255,.05); }
.bs-acc-head {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  background: transparent;
  border: 0;
  cursor: pointer;
  padding: 18px 24px;
  text-align: left;
}
.bs-acc-title {
  font-family: var(--heading-font-family, "Oxanium");
  font-weight: 700;
  font-size: 18px;
  color: #fff;
  transition: color .2s ease;
}
.bs-acc-head:hover .bs-acc-title { color: var(--primary-color, #ff3d24); }
.bs-acc-meta { display: flex; align-items: center; gap: 16px; flex: 0 0 auto; }
.bs-acc-count { font-size: 13px; color: #9a9a9a; white-space: nowrap; }
.bs-acc-from {
  font-family: var(--heading-font-family, "Oxanium");
  font-weight: 700;
  font-size: 14px;
  color: var(--primary-color, #ff3d24);
  white-space: nowrap;
}
.bs-acc-chevron { display: inline-flex; color: #fff; transition: transform .3s ease, color .2s ease; }
.bs-acc-item.open .bs-acc-chevron { transform: rotate(180deg); color: var(--primary-color, #ff3d24); }
.bs-acc-item.open .bs-acc-head { border-bottom: 1px solid rgba(255,255,255,.09); }
.bs-acc-body { max-height: 0; overflow: hidden; transition: max-height .35s cubic-bezier(.4,0,.2,1); }
.bs-acc-body .bs-price-table { width: calc(100% - 48px); margin: 6px 24px 16px; }

@media screen and (max-width: 575px) {
  .bs-acc-head { padding: 14px 16px; }
  .bs-acc-title { font-size: 16px; }
  .bs-acc-count { display: none; }
  .bs-acc-body .bs-price-table { width: calc(100% - 32px); margin: 4px 16px 12px; }
}

/* ==========================================================================
   OFFLINE CHATBOT — plávajúci asistent (tmavá téma, primárna #ff3d24)
   ========================================================================== */
.bs-bot-launch {
  position: fixed; right: 22px; bottom: 22px; z-index: 9999;
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--primary-color, #ff3d24); color: #fff;
  border: 0; border-radius: 50px; padding: 14px 20px; cursor: pointer;
  font-family: var(--heading-font-family, "Oxanium"); font-weight: 700; font-size: 15px;
  box-shadow: 0 10px 30px rgba(255,61,36,.45); transition: transform .25s ease, box-shadow .25s ease;
}
.bs-bot-launch:hover { transform: translateY(-3px); box-shadow: 0 14px 36px rgba(255,61,36,.55); }
.bs-bot-launch.hidden { display: none; }

.bs-bot-panel {
  position: fixed; right: 22px; bottom: 22px; z-index: 10000;
  width: 380px; max-width: calc(100vw - 28px); height: 560px; max-height: calc(100vh - 40px);
  background: #15161a; border: 1px solid rgba(255,255,255,.1); border-radius: 18px;
  display: none; flex-direction: column; overflow: hidden;
  box-shadow: 0 24px 60px rgba(0,0,0,.55);
  transform: translateY(16px) scale(.98); opacity: 0; transition: transform .25s ease, opacity .25s ease;
}
.bs-bot-panel.open { display: flex; transform: none; opacity: 1; }

.bs-bot-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 18px; background: linear-gradient(135deg, #ff3d24, #c41f0d); color: #fff;
}
.bs-bot-head-t { font-family: var(--heading-font-family, "Oxanium"); font-weight: 700; font-size: 16px; display: flex; align-items: center; gap: 8px; }
.bs-bot-dot { width: 9px; height: 9px; border-radius: 50%; background: #6dff8a; box-shadow: 0 0 0 0 rgba(109,255,138,.7); animation: bsPulse 2s infinite; }
@keyframes bsPulse { 0%{box-shadow:0 0 0 0 rgba(109,255,138,.6)} 70%{box-shadow:0 0 0 7px rgba(109,255,138,0)} 100%{box-shadow:0 0 0 0 rgba(109,255,138,0)} }
.bs-bot-close { background: transparent; border: 0; color: #fff; font-size: 26px; line-height: 1; cursor: pointer; opacity: .9; }
.bs-bot-close:hover { opacity: 1; }

.bs-bot-body { flex: 1; overflow-y: auto; padding: 18px; display: flex; flex-direction: column; gap: 12px; background: #15161a; }
.bs-bot-msg { max-width: 86%; padding: 11px 14px; border-radius: 14px; font-size: 14.5px; line-height: 1.5; word-wrap: break-word; }
.bs-bot-bot { background: rgba(255,255,255,.07); color: #e9e9e9; border-bottom-left-radius: 4px; align-self: flex-start; }
.bs-bot-user { background: var(--primary-color, #ff3d24); color: #fff; border-bottom-right-radius: 4px; align-self: flex-end; }
.bs-bot-msg a { color: var(--primary-color, #ff3d24); font-weight: 600; text-decoration: underline; }
.bs-bot-user a { color: #fff; }
.bs-bot-list { margin: 8px 0 4px; padding-left: 18px; }
.bs-bot-list li { margin-bottom: 4px; }

.bs-bot-chips { display: flex; flex-wrap: wrap; gap: 8px; align-self: flex-start; max-width: 100%; }
.bs-bot-chip {
  background: transparent; border: 1px solid rgba(255,61,36,.5); color: #fff;
  border-radius: 50px; padding: 8px 14px; font-size: 13px; cursor: pointer; transition: background .2s ease, border-color .2s ease;
}
.bs-bot-chip:hover { background: rgba(255,61,36,.18); border-color: var(--primary-color, #ff3d24); }

.bs-bot-foot { display: flex; gap: 8px; padding: 12px; border-top: 1px solid rgba(255,255,255,.08); background: #15161a; }
.bs-bot-input {
  flex: 1; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12);
  border-radius: 50px; padding: 12px 16px; color: #fff; font-size: 14.5px; outline: none;
}
.bs-bot-input::placeholder { color: #8a8a8a; }
.bs-bot-input:focus { border-color: var(--primary-color, #ff3d24); }
.bs-bot-send {
  width: 46px; flex: 0 0 46px; border: 0; border-radius: 50%; background: var(--primary-color, #ff3d24);
  color: #fff; font-size: 24px; line-height: 1; cursor: pointer; transition: transform .2s ease;
}
.bs-bot-send:hover { transform: scale(1.07); }

.bs-bot-dots { display: inline-flex; gap: 4px; }
.bs-bot-dots i { width: 7px; height: 7px; border-radius: 50%; background: #8a8a8a; display: inline-block; animation: bsBlink 1.2s infinite; }
.bs-bot-dots i:nth-child(2){ animation-delay:.2s } .bs-bot-dots i:nth-child(3){ animation-delay:.4s }
@keyframes bsBlink { 0%,80%,100%{opacity:.3} 40%{opacity:1} }

@media screen and (max-width: 480px) {
  .bs-bot-panel { right: 8px; bottom: 8px; height: calc(100vh - 16px); max-height: none; width: calc(100vw - 16px); }
  .bs-bot-launch { right: 14px; bottom: 14px; padding: 12px 16px; }
  .bs-bot-launch span { display: none; }
}

/* Tlačidlo "späť hore" presunúť doľava dole (vpravo dole je chatbot) */
.ak-scrollup { right: auto !important; left: 24px !important; }
@media screen and (max-width: 480px) {
  .ak-scrollup { left: 14px !important; }
}

/* ==========================================================================
   FEATURE STRÁNKY — formuláre, kalkulačka, stav opravy, pneuhotel, balíčky
   ========================================================================== */
.bs-feature { max-width: 820px; margin: 0 auto; }
.bs-feature-wide { max-width: 1100px; margin: 0 auto; }
.bs-card2 { background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.09); border-radius: 16px; padding: 28px; }
.bs-form { display: grid; gap: 16px; }
.bs-form .row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.bs-field label { display: block; font-size: 13px; color: #b9b9b9; margin-bottom: 6px; font-family: var(--heading-font-family,"Oxanium"); }
.bs-input, .bs-select, .bs-textarea {
  width: 100%; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.14);
  border-radius: 10px; padding: 13px 15px; color: #fff; font-size: 15px; outline: none;
}
.bs-input:focus, .bs-select:focus, .bs-textarea:focus { border-color: var(--primary-color,#ff3d24); }
.bs-input::placeholder, .bs-textarea::placeholder { color: #8a8a8a; }
.bs-textarea { min-height: 110px; resize: vertical; }
.bs-select option { background: #15161a; }
.bs-submit {
  background: var(--primary-color,#ff3d24); color: #fff; border: 0; border-radius: 50px;
  padding: 15px 34px; font-family: var(--heading-font-family,"Oxanium"); font-weight: 700;
  text-transform: uppercase; letter-spacing: .5px; cursor: pointer; font-size: 15px; transition: transform .2s ease;
}
.bs-submit:hover { transform: translateY(-2px); }
.bs-submit:disabled { opacity: .6; cursor: not-allowed; transform: none; }
.bs-note { font-size: 13px; color: #9a9a9a; }

/* Sloty rezervácie */
.bs-slots { display: flex; flex-wrap: wrap; gap: 10px; }
.bs-slot { border: 1px solid rgba(255,255,255,.16); background: rgba(255,255,255,.05); color: #fff;
  border-radius: 10px; padding: 11px 16px; cursor: pointer; font-weight: 600; transition: all .2s ease; }
.bs-slot:hover { border-color: var(--primary-color,#ff3d24); }
.bs-slot.sel { background: var(--primary-color,#ff3d24); border-color: var(--primary-color,#ff3d24); }
.bs-slot:disabled { opacity: .35; text-decoration: line-through; cursor: not-allowed; }

/* Stav opravy — timeline */
.bs-steps { display: flex; flex-wrap: wrap; gap: 0; margin: 10px 0 24px; counter-reset: s; }
.bs-step { flex: 1; min-width: 90px; text-align: center; position: relative; padding-top: 34px; color: #8a8a8a; font-size: 12.5px; }
.bs-step::before { counter-increment: s; content: counter(s); position: absolute; top: 0; left: 50%; transform: translateX(-50%);
  width: 26px; height: 26px; border-radius: 50%; background: rgba(255,255,255,.1); color: #fff; display: grid; place-items: center; font-weight: 700; }
.bs-step::after { content: ""; position: absolute; top: 13px; left: -50%; width: 100%; height: 2px; background: rgba(255,255,255,.1); z-index: -1; }
.bs-step:first-child::after { display: none; }
.bs-step.done { color: #fff; }
.bs-step.done::before { background: var(--primary-color,#ff3d24); }
.bs-step.done::after { background: var(--primary-color,#ff3d24); }

.bs-timeline { list-style: none; padding: 0; margin: 0; }
.bs-timeline li { padding: 0 0 16px 22px; position: relative; border-left: 2px solid rgba(255,255,255,.12); }
.bs-timeline li::before { content: ""; position: absolute; left: -7px; top: 2px; width: 12px; height: 12px; border-radius: 50%; background: var(--primary-color,#ff3d24); }
.bs-timeline li:last-child { border-left-color: transparent; }

.bs-result { margin-top: 22px; }
.bs-kv { display: flex; justify-content: space-between; gap: 14px; padding: 9px 0; border-bottom: 1px dashed rgba(255,255,255,.1); font-size: 15px; }
.bs-kv span:first-child { color: #b9b9b9; }
.bs-kv span:last-child { color: #fff; font-weight: 600; text-align: right; }
.bs-badge { display: inline-block; padding: 4px 12px; border-radius: 50px; font-size: 12px; font-weight: 700; }
.bs-badge-ok { background: rgba(109,255,138,.15); color: #6dff8a; }
.bs-badge-wait { background: rgba(255,193,7,.15); color: #ffc107; }
.bs-badge-no { background: rgba(255,61,36,.15); color: #ff6a55; }

/* Kalkulačka */
.bs-calc-total { font-family: var(--heading-font-family,"Oxanium"); font-weight: 800; font-size: 30px; color: var(--primary-color,#ff3d24); }
.bs-checklist { display: grid; gap: 10px; max-height: 360px; overflow-y: auto; padding-right: 6px; }
.bs-checkitem { display: flex; align-items: center; gap: 12px; padding: 12px 14px; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08); border-radius: 10px; cursor: pointer; }
.bs-checkitem input { width: 18px; height: 18px; accent-color: var(--primary-color,#ff3d24); }
.bs-checkitem .nm { flex: 1; font-size: 14.5px; }
.bs-checkitem .pr { font-family: var(--heading-font-family,"Oxanium"); font-weight: 700; white-space: nowrap; }

/* Balíčky / vernosť */
.bs-pkg-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.bs-pkg { background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.1); border-radius: 16px; padding: 28px; display: flex; flex-direction: column; }
.bs-pkg.pop { border-color: var(--primary-color,#ff3d24); box-shadow: 0 14px 40px rgba(255,61,36,.18); }
.bs-pkg h3 { font-family: var(--heading-font-family,"Oxanium"); color: #fff; margin: 0 0 6px; }
.bs-pkg .price { font-family: var(--heading-font-family,"Oxanium"); font-size: 26px; font-weight: 800; color: var(--primary-color,#ff3d24); margin: 8px 0 14px; }
.bs-pkg ul { list-style: none; padding: 0; margin: 0 0 20px; flex: 1; }
.bs-pkg ul li { padding: 7px 0 7px 26px; position: relative; color: #d3d3d3; font-size: 14.5px; }
.bs-pkg ul li::before { content: "✓"; position: absolute; left: 0; color: var(--primary-color,#ff3d24); font-weight: 700; }

/* Hub / zákaznícka zóna dlaždice */
.bs-hub { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
.bs-hub a { display: block; background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.1); border-radius: 16px; padding: 28px; color: #fff; text-decoration: none; transition: transform .25s ease, border-color .25s ease; }
.bs-hub a:hover { transform: translateY(-5px); border-color: var(--primary-color,#ff3d24); }
.bs-hub h4 { font-family: var(--heading-font-family,"Oxanium"); margin: 10px 0 6px; }
.bs-hub p { color: #9a9a9a; font-size: 14px; margin: 0; }

/* Toast */
.bs-toast { position: fixed; left: 50%; bottom: 30px; transform: translate(-50%, 20px); opacity: 0;
  padding: 14px 22px; border-radius: 12px; color: #fff; font-weight: 600; z-index: 10001; transition: all .35s ease; max-width: 90vw; }
.bs-toast.show { opacity: 1; transform: translate(-50%, 0); }
.bs-toast-ok { background: #1f8a3b; }
.bs-toast-err { background: #c41f0d; }

@media screen and (max-width: 991px) {
  .bs-pkg-grid, .bs-hub { grid-template-columns: 1fr 1fr; }
}
@media screen and (max-width: 767px) {
  .bs-form .row2 { grid-template-columns: 1fr; }
  .bs-pkg-grid, .bs-hub { grid-template-columns: 1fr; }
  .bs-card2 { padding: 20px; }
  /* Kroky stavu opravy v jednom rade aj na mobile */
  .bs-steps { flex-wrap: nowrap; }
  .bs-step { font-size: 0; padding-top: 28px; min-width: 0; }
  .bs-step::before { width: 22px; height: 22px; font-size: 11px; }
  .bs-step::after { top: 11px; }
}

/* ==========================================================================
   MACBOOK AIR / NOTEBOOKY — kompaktnejšie rozloženie, aby sa stránka zmestila
   (šablóna je dimenzovaná pre veľké monitory — na ~1440×900 zmenšíme medzery)
   ========================================================================== */
@media screen and (min-width: 992px) and (max-width: 1600px) {
  [class*="ak-height-150"] { height: 96px !important; }
  [class*="ak-height-140"] { height: 90px !important; }
  [class*="ak-height-130"] { height: 84px !important; }
  [class*="ak-height-125"] { height: 80px !important; }
  [class*="ak-height-120"] { height: 76px !important; }
  [class*="ak-height-115"] { height: 72px !important; }
  [class*="ak-height-110"] { height: 68px !important; }
  [class*="ak-height-105"] { height: 64px !important; }
  [class*="ak-height-100"] { height: 60px !important; }
  [class*="ak-height-95"]  { height: 58px !important; }
  [class*="ak-height-90"]  { height: 54px !important; }
}
/* Nízke obrazovky (MacBook Air ~900 px výška) — hero aj nadpisy nech sa zmestia */
@media screen and (min-width: 992px) and (max-height: 950px) {
  .hero-main-title, .hero-main-title-1 { font-size: clamp(38px, 4.6vw, 60px) !important; line-height: 1.06 !important; }
  .mini-title { font-size: 16px !important; }
  .common-page-title .page-title { font-size: clamp(30px, 4vw, 52px) !important; }
}

/* ==========================================================================
   CENNÍK — neuromarketingové prvky (dôvera, hodnota, CTA)
   ========================================================================== */
.bs-trust { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 14px 28px; text-align: center; }
.bs-trust-rating { font-size: 16px; color: #fff; }
.bs-trust-rating strong { font-family: var(--heading-font-family,"Oxanium"); font-size: 20px; }
.bs-stars { color: #ffc107; letter-spacing: 2px; }
.bs-trust-sub { color: #9a9a9a; font-size: 14px; }
.bs-trust-badges { display: flex; flex-wrap: wrap; gap: 10px 18px; justify-content: center; }
.bs-trust-badge { color: #d3d3d3; font-size: 14px; font-weight: 600; }

.bs-value-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; max-width: 1040px; margin: 0 auto; }
.bs-value-card { background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.09); border-left: 3px solid var(--primary-color,#ff3d24); border-radius: 12px; padding: 20px 22px; }
.bs-value-card h4 { font-family: var(--heading-font-family,"Oxanium"); color: #fff; font-size: 17px; margin: 0 0 8px; }
.bs-value-card p { color: #c2c2c2; font-size: 14.5px; line-height: 1.6; margin: 0; }
.bs-value-card strong { color: #fff; }

.bs-cennik-cta {
  max-width: 960px; margin: 0 auto; background: linear-gradient(135deg, rgba(255,61,36,.12), rgba(255,255,255,.03));
  border: 1px solid rgba(255,61,36,.35); border-radius: 18px; padding: 30px;
  display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 24px;
}
.bs-cta-quote { margin: 0; flex: 1 1 360px; color: #e9e9e9; font-size: 16px; line-height: 1.6; font-style: italic; border: 0; }
.bs-cta-quote cite { display: block; margin-top: 10px; color: var(--primary-color,#ff3d24); font-style: normal; font-weight: 700; font-size: 14px; }
.bs-cta-action { display: flex; flex-direction: column; align-items: center; gap: 10px; text-align: center; }
.bs-cta-urgency { color: #6dff8a; font-weight: 700; font-size: 14px; }
.bs-cta-btn { text-decoration: none; }
.bs-cta-note { color: #9a9a9a; font-size: 12.5px; }

@media screen and (max-width: 991px) {
  .bs-value-grid { grid-template-columns: 1fr; max-width: 560px; }
  .bs-cennik-cta { flex-direction: column; text-align: center; }
  .bs-cta-quote { flex-basis: auto; }
}
