:root{
  --gap: 12px;
  --maxw: 980px;

  /* === souřadnice pinů (snadné ladění) === */
  --pin-kvk-left: 10%;
  --pin-kvk-top: 33%;
  --pin-uk-left: 24%;
  --pin-uk-top: 22%;
  --pin-sck-left: 35%;
  --pin-sck-top: 37%;
}

*{ box-sizing: border-box; }

body{
  font-family: system-ui, Arial, sans-serif;
  margin: 0; padding: 0;
  line-height: 1.6;
  background:#e8ebef;
  color:#222;
}

.container{ max-width: var(--maxw); margin: 0 auto; padding: 0 16px; }

/* ===== HLAVIČKA ===== */
.site-header{
  position: sticky; top: 0; z-index: 1000;
  background: linear-gradient(140deg, #003b9e 0%, #0060e0 100%);
  color:#fff; padding:20px 0; border-bottom:0;
  transition: box-shadow .2s ease;
  box-shadow: 0 2px 10px rgba(0,0,0,.06);
  backdrop-filter: blur(3px); -webkit-backdrop-filter: blur(3px);
}
.site-header.stuck{ box-shadow: 0 6px 18px rgba(0,0,0,.08); }
.site-header .container{ position: relative; z-index: 2; }

.site-header::before{
  content:""; position:absolute; z-index:1; top:0; left:0; right:0; height:4px;
  background:rgba(255,255,255,.25); pointer-events:none;
}
.site-header::after{
  content:""; position:absolute; inset:0; z-index:1;
  background: rgba(255,255,255,.02); pointer-events:none;
}

/* (původní mobilní blok s .header-cta { order:99 } byl odstraněn) */
.brand{ order:1; display:flex; align-items:center; gap:10px; color:#fff; }
.logo{
  display:inline-grid; place-items:center;
  width:38px; height:38px; border-radius:10px;
  border:1px solid rgba(255,255,255,.35); color:#fff;
}
.brand-txt{ font-size:1.4rem; font-weight:700; line-height:1.2; text-shadow:0 1px 2px rgba(0,0,0,.35); }
.brand-txt small{ opacity:.85; font-size:.80rem; }

.header-cta{
  order:2; margin-left:auto; display:flex; align-items:flex-start; gap:12px; color:#fff; flex-shrink:0;
  border-left:0; padding-left:0;
}
@media (min-width: 900px){
  .header-cta{ border-left:1px solid rgba(255,255,255,.25); padding-left:20px; }
}

.header-bar{ display:flex; align-items:flex-start; gap:16px; flex-wrap:wrap; }
.phone-ico{
  display:flex; align-items:center; justify-content:center;
  width:34px; height:34px; border-radius:8px; border:1px solid rgba(255,255,255,.45);
}
.phone{ display:flex; flex-direction:column; line-height:1.25; }
.phone-title{ font-size:.9rem; font-weight:600; margin-bottom:2px; }
.phone a{ color:#fff; font-weight:700; text-decoration:none; }
.phone a:hover{ text-decoration:underline; }

/* ===== NAV ===== */
.site-nav{
  order:3; flex-basis:100%; margin-top:12px; overflow:visible; white-space:normal; padding-bottom:0;
}
.site-nav ul{
  list-style:none; display:flex; flex-wrap:wrap; justify-content:center;
  gap:10px 12px; margin:0; padding:0;
}
.site-nav li{ flex:0 1 auto; }
.site-nav a{
  color:#fff; text-decoration:none; font-size:.95rem;
  padding:8px 12px; border-radius:12px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.22);
}
.site-nav a:hover{ background:rgba(255,255,255,.18); }
.site-nav a.active{ background:#fff; color:#0d47a1; border-color:transparent; }

/* ===== OBSAH ===== */
.site-main{ padding:20px 0; }

.hero{
  padding:22px; margin-bottom:16px;
  border:1px solid #e5e5e5; border-radius:12px; background:#fff;
}
.hero .btn{ display:inline-block; margin-top:8px; }
.note{ color:#666; font-size:.9rem; }

/* KARTY SLUŽEB */
.cards{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:12px; margin:16px 0;
}
.card{
  background:#fff; border:1px solid #e5e5e5; border-radius:12px; padding:14px;
  transition: border-color .2s ease, transform .15s ease;
}
.card:hover{ border-color:#c7daf8; transform: translateY(-2px); }
.card h3{ margin:0 0 8px; text-align:center; }
.card h3 a{ color:#0d47a1; text-decoration:none; }
.card h3 a:hover{ text-decoration:underline; }

/* PATIČKA */
.site-footer{
  padding:16px; background:#f5f5f5; border-top:1px solid #e0e0e0;
  margin-top:24px; clear: both;
}

.btn{
  background:#111; color:#fff; border:none; border-radius:8px;
  padding:10px 14px; text-decoration:none; cursor:pointer; display:inline-block;
}
.btn:hover{ opacity:.92; }

.form{ display:grid; gap:10px; max-width:620px; }
input[type=text], input[type=email], textarea{
  width:100%; padding:10px; border:1px solid #ccc; border-radius:8px; background:#fff;
}
.success{ background:#e9f9ef; border:1px solid #bfe8ca; padding:10px; border-radius:8px; }
.error{ background:#fdecea; border:1px solid #f5c2c0; padding:10px; border-radius:8px; }

/* full-bleed */
.fullbleed{
  position:relative; left:50%; right:50%;
  margin-left:-50vw; margin-right:-50vw; width:100vw;
}

/* === IMAGE-CARD (pro případ jiných sekcí; bez mapy) === */
.image-card{
  position:relative; margin:28px 0 32px;
  border-radius:14px; padding:32px; min-height:260px;
  overflow:hidden; border:1px solid #e5e5e5; border-top:3px solid #0d47a1;
  width:100%; box-sizing:border-box; grid-column:1 / -1 !important;
  display:flex; flex-direction:column; justify-content:center; align-items:center;
  padding-top:60px; padding-bottom:40px;
}
.image-card::before{
  content:""; position:absolute; inset:0;
  background:linear-gradient(to bottom, rgba(255,255,255,.70) 0%, rgba(255,255,255,.30) 50%, rgba(255,255,255,.02) 100%);
  pointer-events:none;
}
.image-card > *{ position:relative; z-index:1; }
.image-card h2{
  margin-top:0; text-align:center; font-weight:800; font-size:1.9rem; color:#0d47a1;
  text-shadow:0 1px 3px rgba(255,255,255,.85);
}
.image-card p{
  text-align:center; font-weight:700; font-size:1.3rem; color:#000; line-height:1.6;
  text-shadow:0 1px 3px rgba(255,255,255,.85);
}
@media(max-width:600px){
  .image-card{ padding:24px; min-height:220px; padding-top:50px; }
  .image-card p{ font-size:18px; }
}

/* ikonky v kartach */
.card-ico{ margin-bottom:10px; display:flex; align-items:center; justify-content:center; color:#0d47a1; }

/* responsive drobnosti */
@media (max-width: 600px){
  .hero{ padding:18px; }
  .image-card{ padding:22px; min-height:220px; }
  .image-card .biggertext{ font-size:18px; }
  .phone-title{ display:none; }
  .site-nav a{ padding:7px 10px; font-size:.9rem; }
}

.cert-images{ display:flex; gap:20px; flex-wrap:wrap; margin:20px 0 40px; }
.cert-images img{ width:45%; border-radius:8px; border:1px solid #ddd; }
.hero h2{ text-align:center; }
.site-main h1{ text-align:center; }

/* FAQ */
.faq{
  background:#fff; border:1px solid #e5e5e5; border-radius:12px;
  padding:18px; margin:24px 0;
}
.faq h2{ margin:0 0 8px; text-align:center; font-size:1.6rem; }
.faq details{ border-top:1px solid #eee; padding:10px 0; }
.faq details:first-of-type{ border-top:0; }
.faq summary{
  cursor:pointer; font-weight:600; list-style:none; position:relative; padding-right:22px;
}
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{
  content:""; position:absolute; right:2px; top:.6em; width:10px; height:10px;
  border-right:2px solid #0d47a1; border-bottom:2px solid #0d47a1;
  transform: rotate(-45deg); transition: transform .15s ease;
}
.faq details[open] summary::after{ transform: rotate(45deg); }
.faq p{ margin:.4rem 0 .2rem; color:#333; }

/* ===== HERO GRID 50/50 ===== */
.hero-grid{ display:grid; grid-template-columns: 1fr 1fr; gap: var(--gap); align-items: stretch; }
@media (max-width: 900px){ .hero-grid{ grid-template-columns: 1fr; } }

/* ===== FAQ MINI ===== */
.faq-mini .faq-title{ margin: 0 0 8px; text-align: left; font-size: 1.25rem; }
.faq-mini details{ border-top: 1px solid #eee; padding: 8px 0; }
.faq-mini details:first-of-type{ border-top: 0; }
.faq-mini summary{ position: relative; padding-right: 40px; }
.faq-mini summary::-webkit-details-marker{ display:none; }
.faq-mini summary::after{ content: "›"; position: absolute; right: 10px; top: .5em; font-size: 1rem; color: #0d47a1; }
.faq-mini details.info    summary::before{ content:"🛈";  position:absolute; right:26px; top:.30em; font-size:1.35rem; line-height:1; color:#0d47a1; }
.faq-mini details.time    summary::before{ content:"🕒";  position:absolute; right:26px; top:.30em; font-size:1.25rem; line-height:1; color:#0d47a1; }
.faq-mini details.ev      summary::before{ content:"🔋⚡"; position:absolute; right:26px; top:.35em; font-size:1.32rem; line-height:1; color:#0d47a1; }
.faq-mini details.person  summary::before{ content:"🧍‍♂️";position:absolute; right:26px; top:.30em; font-size:1.25rem; line-height:1; color:#0d47a1; }
.faq-mini details.czk     summary::before{ content:"💰";  position:absolute; right:26px; top:.30em; font-size:1.25rem; line-height:1; color:#0d47a1; }
.faq-mini details.stamp   summary::before{ content:"📄✓"; position:absolute; right:26px; top:.30em; font-size:1.18rem; line-height:1; color:#0d47a1; }
.faq-mini details.calendar summary::before{ content:"📅"; position:absolute; right:26px; top:.30em; font-size:1.25rem; line-height:1; color:#0d47a1; }

/* Kontakt – pravý sloupec box */
.contact-box{ background:#fff; border:1px solid #e5e5e5; border-radius:12px; padding:16px; }
.kv{ display:grid; grid-template-columns: 1fr 1.6fr; gap:8px 14px; margin:0; }
.kv dt{ margin:0; color:#555; font-weight:600; }
.kv dd{ margin:0; }

/* drobná poznámka + odkaz */
.mini-note{ margin-top:12px; color:#666; font-size:.9rem; }
.mini-links .btn-lite{
  display:inline-block; margin-top:8px; background:#f5f5f5; color:#111;
  border:1px solid #e0e0e0; border-radius:8px; padding:8px 12px; text-decoration:none;
}
.mini-links .btn-lite:hover{ background:#eee; }

/* Kontakt – 2 sloupce na desktopu */
.contact-grid{
  display: grid; grid-template-columns: 1fr minmax(320px, 420px);
  gap: 16px; align-items: start;
}
.contact-main, .contact-aside{ min-width: 0; }
.contact-main .form{ max-width: 100%; }
.contact-box h3{ margin: 0 0 10px; font-size: 1.1rem; }
@media (min-width: 701px){ .contact-aside{ position: sticky; top: 20px; } }
@media (max-width: 700px){ .contact-grid{ grid-template-columns: 1fr; } }

/* Když je image-card uvnitř .cards gridu, ať zabere celou řadu */
.cards > .image-card{ grid-column: 1 / -1; margin-top: 8px; }

/* ==== Failsafe ==== */
.image-card{ display:block; width:100%; box-sizing:border-box; margin-top: 8px; margin-bottom:32px; grid-column: 1 / -1 !important; }
.cards .image-card{ grid-column: 1 / -1 !important; }
.cards{ grid-column: 1 / -1 !important; width: 100%; }
.hero-grid .cards{ grid-column: 1 / -1 !important; }

/* Kontakt – řádky s ikonami (silnější selektory kvůli globálním stylům UL/LI) */
.contact-box .contact-info{ margin:0 0 12px; }
.contact-box .contact-info h3{ margin:0 0 8px; font-size:1.1rem; color:#0d47a1; }

.contact-box .contact-list{
  list-style:none; margin:0; padding:0;
  display:grid; gap:8px;
}
.contact-box .contact-item{
  display:grid; grid-template-columns:28px 1fr; align-items:center; gap:10px;
  padding:8px 10px;
  background:#f7f9fc; border:1px solid #e8eef7; border-radius:10px;
}
.contact-box .contact-icon,
.contact-box .contact-icon svg{
  display:inline-block; width:22px; height:22px; color:#0d47a1; fill:currentColor;
  vertical-align:middle;
}
.contact-box .contact-link{
  color:#111; text-decoration:none; font-weight:600; overflow-wrap:anywhere;
}
.contact-box .contact-link:hover{ text-decoration:underline; }
@media (max-width:600px){
  .contact-box .contact-item{ grid-template-columns:26px 1fr; padding:8px; }
  .contact-box .contact-link{ font-weight:700; }
}

/* === Kompaktní hlavička na mobilu – FIX kontaktu === */
@media (max-width:700px){
  .site-header{ padding:8px 0; }

  /* kontakt nahoře – plná šířka, hezké zalomení */
  .header-cta{
    order:0; width:100%; margin:4px 0 6px;
    text-align:left; display:block;
    border-left:0; padding-left:0;
  }

  /* telefony jako pilulky, vedle sebe; e-mail zvlášť */
  .header-cta .phone{
    display:flex; flex-direction:row; flex-wrap:wrap;
    align-items:center; gap:6px 8px;
    line-height:1.2; white-space:normal;
  }

  .header-cta .phone a{
    color:#fff; text-decoration:none;
  }

  .header-cta .phone a[href^="tel:"]{
    display:inline-flex; align-items:center;
    padding:6px 10px;
    border-radius:999px;
    border:1px solid rgba(255,255,255,.25);
    background:rgba(255,255,255,.10);
    font-size:.95rem;
  }

  /* e-mail vždy pod telefony, menší text */
  .header-cta .phone a[href^="mailto:"]{
    display:block; width:100%; margin-top:4px;
    padding:0; border:0; background:transparent;
    font-size:.85rem; opacity:.95;
    overflow-wrap:anywhere; white-space:normal;
  }

  /* žádná tečka mezi čísly; jen ikonka telefonu */
  .header-cta .phone a[href^="tel:"]::before{ content:"📞 "; }
  .header-cta .phone a[href^="tel:"] + a[href^="tel:"]::before{ content:"📞 "; }

  .brand{ order:1; }
  .phone-ico{ display:none; }
  .brand-txt{ font-size:1.15rem; }
  .brand-txt small{ display:none; }
  .site-nav{ margin-top:8px; }
  .site-nav ul{ gap:6px; }
  .site-nav a{ padding:6px 9px; font-size:.9rem; border-radius:10px; }
}

/* ===================== MAPA ===================== */
/* Karta pro mapu – 2 sloupce: mapa | legenda */
.map-card{
  margin:28px 0 32px; background:#fff; border:1px solid #e5e5e5;
  border-radius:14px; border-top:3px solid #0d47a1; padding:16px;
  display:grid; grid-template-columns: 2fr 1fr; gap:16px; align-items:center;
}
@media (max-width: 900px){ .map-card{ grid-template-columns: 1fr; } }

/* Obrázek mapy + overlay s piny */
.map-figure{ position:relative; border-radius:12px; overflow:hidden; }
.map-figure img{ display:block; width:100%; height:auto; }
.map-figure .cz-overlay{ position:absolute; inset:0; pointer-events:none; }

/* Tečky – střed tečky = referenční bod */
.map-figure .pin{
  position:absolute; width:14px; height:14px; border-radius:50%;
  background:rgba(220,0,0,.90);
  box-shadow:0 0 0 6px rgba(220,0,0,.15), 0 0 18px rgba(220,0,0,.35);
  transform: translate(-50%, -50%);
  /* jen puls stínu, aby se nepřepisoval transform */
  animation: pinPulse 2.2s ease-out infinite;
}
@media (max-width: 600px){ .map-figure .pin{ width:12px; height:12px; } }

@keyframes pinPulse{
  0%{ box-shadow:0 0 0 4px rgba(220,0,0,.12), 0 0 14px rgba(220,0,0,.30); }
  50%{ box-shadow:0 0 0 7px rgba(220,0,0,.18), 0 0 20px rgba(220,0,0,.45); }
  100%{ box-shadow:0 0 0 4px rgba(220,0,0,.12), 0 0 14px rgba(220,0,0,.30); }
}

/* Pozice pinů – uprav jen proměnné nahoře */
.map-figure .pin-kvk{ left: var(--pin-kvk-left); top: var(--pin-kvk-top); }
.map-figure .pin-uk { left: var(--pin-uk-left);  top: var(--pin-uk-top);  }
.map-figure .pin-sck{ left: var(--pin-sck-left); top: var(--pin-sck-top); }

/* Legenda vpravo */
.map-legend{ padding:8px 4px; }
.map-legend h3{ margin:0 0 10px; font-size:1.05rem; color:#0d47a1; }
.map-legend ul{ list-style:none; margin:0; padding:0; display:grid; gap:10px; }
.map-legend li{
  display:flex; align-items:center; gap:10px;
  background:#f7f9fc; border:1px solid #e8eef7; border-radius:10px; padding:8px 10px;
}
.map-legend .bullet{
  width:12px; height:12px; border-radius:50%;
  background:rgba(220,0,0,.9);
  box-shadow:0 0 0 4px rgba(220,0,0,.12);
  flex:0 0 12px;
}

/* === ČEZ PARTNER PANEL === */
.cez-panel{
  position: fixed;
  top: 50%;
  right: -280px;              /* schovaný mimo obraz */
  transform: translateY(-50%);
  z-index: 1200;
  width: 260px;
  background: linear-gradient(145deg, #fff 0%, #f8f9fb 100%);
  border: 1px solid #e0e0e0;
  border-right: 4px solid #f15a22;
  border-radius: 12px 0 0 12px;
  box-shadow: 0 4px 20px rgba(0,0,0,.15);
  padding: 12px 16px;
  color: #111;
  font-family: system-ui, Arial, sans-serif;
  transition: right 0.6s ease;
}
.cez-panel.show{ right: 0; }           /* vyjede */
.cez-panel.minimized{ right: -210px; } /* zmenšený stav, jen trochu vidět */

/* text uvnitř */
.cez-inner{ text-align:left; line-height:1.4; }
.cez-top{ margin:0; font-size:.95rem; color:#0d47a1; }
.cez-bottom{
  margin:2px 0 0;
  font-weight:800;
  color:#f15a22;
  font-size:1.05rem;
  letter-spacing:.3px;
}

/* Minimalistická ikonka */
.cez-icon-btn{
  position: fixed;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
  z-index: 1210;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: none;
  background: #f15a22;
  color: #fff;
  font-size: 22px;
  cursor: pointer;
  box-shadow: 0 4px 10px rgba(0,0,0,.2);
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s ease;
}
.cez-icon-btn.visible{
  opacity: 1;
  pointer-events: auto;
}

/* Mobilní verze */
@media (max-width:600px){
  .cez-panel{
    right: -240px;
    width: 220px;
    padding:10px 14px;
    font-size:.9rem;
    top:45%;
  }
  .cez-icon-btn{ right:8px; width:38px; height:38px; font-size:20px; }
}

/* FAQ – tlačítko na reference */
.faq-ref{
  margin-top: 14px;
  text-align: right;
}

.btn-ref{
  background:#0d47a1;
  color:#fff;
  padding:8px 14px;
  border-radius:8px;
  text-decoration:none;
  font-size:.9rem;
  font-weight:600;
  display:inline-block;
  transition:.2s;
}

.btn-ref:hover{
  background:#0b3a8b;
}

/* =========================================
   ELEKTROREVIZE – layout & termokamera
   ========================================= */

/* hlavní dvousloupcový layout: vlevo text, vpravo reference */
.revize-wrap{
  max-width: var(--maxw);
  margin: 0 auto 32px;
  padding: 0 16px;
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 28px;
  align-items: flex-start;
}

@media (max-width: 900px){
  .revize-wrap{
    grid-template-columns: 1fr;
  }
}

/* pravý box s referencemi */
.revize-box{
  background:#ffffff;
  border:1px solid #e5e5e5;
  border-radius:12px;
  padding:18px 20px;
}

.revize-box h3{
  margin:0 0 10px;
  font-size:1.1rem;
  color:#0d47a1;
}

.revize-box p{
  margin:0 0 10px;
  font-size:.95rem;
  color:#444;
}

.revize-box ul{
  list-style:disc;
  margin:0;
  padding-left:18px;
  display:grid;
  gap:6px;
  font-size:.95rem;
}

/* termokamera blok – obrázek vlevo, text vpravo */
.thermo-row{
  max-width: var(--maxw);
  margin:26px auto;
  padding:0 16px;
  display:grid;
  grid-template-columns: 42% 1fr;
  gap:22px;
  align-items:center;
}

@media (max-width: 700px){
  .thermo-row{
    grid-template-columns: 1fr;
  }
}

.thermo-img{
  border-radius:12px;
  border:1px solid #e5e5e5;
  width:100%;
  height:auto;
  display:block;
}

.thermo-box h3{
  margin:0 0 6px;
}

.thermo-list{
  margin:8px 0 0;
  padding:0;
  list-style:none;
}

.thermo-list li{
  display:flex;
  align-items:flex-start;
  gap:10px;
  margin:8px 0;
}

.thermo-ico{
  font-size:1.2rem;
  line-height:1;
  color:#0d47a1;
}
