@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700;800&display=swap");

/* ===============================
   VARIABLES
   =============================== */
:root {
  --blue: #1b5e20;        /* tmavě zelená – primární */
  --blue-soft: #2e7d32;   /* světlejší zelená */
  --orange: #66bb6a;      /* zelený akcent místo oranžové */
  --bg-light: #edf6ed;    /* světle zelené pozadí formulářů */
}

/* ===============================
   BASE
   =============================== */
* {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: "Inter", Arial, sans-serif;
  background: #fff;
  color: #111;
}

/* ===============================
   HEADER + HERO
   =============================== */
.site-header {
  background: linear-gradient(135deg, var(--blue), var(--blue-soft));
  border-bottom: 4px solid var(--orange);
  text-align: center;
  padding: 2.4rem 0 1.2rem;
}

.big-logo {
  font-size: 4rem;
  font-weight: 800;
  letter-spacing: 6px;
  color: #fff;
}

.big-logo .tagline {
  display: block;
  margin-top: 0.4rem;
  font-size: 0.95rem;
  letter-spacing: 2px;
  color: #f3e5cf;
}

/* NAV */
.main-nav ul {
  list-style: none;
  padding: 0;
  margin: 1.4rem 0 1.6rem;
  display: flex;
  justify-content: center;
  gap: 0.6rem;
}

.main-nav a {
  background: var(--orange);
  color: #000;
  padding: 0.45rem 1.1rem;
  border-radius: 6px;
  font-weight: 600;
  font-size: 0.9rem;
  text-decoration: none;
  transition: 0.2s;
}

.main-nav a:hover {
  background: var(--blue);
  color: #fff;
}

/* HERO TEXT */
.hero h1 {
  font-size: 1.8rem;
  font-weight: 700;
  color: #fff;
  margin: 0 0 0.4rem;
}

.hero p {
  margin: 0;
  font-size: 1rem;
  color: var(--orange);
  font-weight: 600;
}

/* ===============================
   CARDS
   =============================== */
.cards {
  max-width: 1100px;
  margin: 2rem auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.4rem;
  padding: 0 1rem;
}

.card {
  background: #fff;
  border: 1px solid #d6dbff;
  border-radius: 10px;
  overflow: hidden;
}

/* IMAGE – +30px */
.card > img {
  width: 100%;
  height: 175px;
  object-fit: cover;
  display: block;
}

/* BODY */
.card-body {
  padding: 1rem;
}

.card h2 {
  margin: 0 0 0.3rem;
  font-size: 1.2rem;
  color: var(--blue);
}

.card p {
  margin: 0 0 0.8rem;
  font-size: 0.95rem;
  color: #444;
}

/* BUTTON */
.card .btn {
  display: inline-block;
  background: var(--orange);
  color: #000;
  padding: 0.45rem 0.9rem;
  border-radius: 6px;
  font-size: 0.85rem;
  font-weight: 700;
  text-decoration: none;
  margin-bottom: 0.8rem;
}

.card .btn:hover {
  background: var(--blue);
  color: #fff;
}

/* ===============================
   FORM IN CARD (COMPACT)
   =============================== */
.card form {
  background: var(--bg-light);
  padding: 0.7rem;
  border-radius: 8px;
  display: grid;
  gap: 0.45rem;
}

.card form .form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.4rem;
}

.card form input,
.card form textarea {
  width: 100%;
  height: 26px;
  padding: 0.2rem 0.45rem;
  font-size: 0.8rem;
  border-radius: 5px;
  border: 1px solid #ccd1ff;
  font-family: inherit;
}

.card form textarea {
  height: 48px;
  resize: none;
}

.card form button {
  background: var(--orange);
  border: none;
  border-radius: 6px;
  padding: 0.45rem;
  font-size: 0.85rem;
  font-weight: 700;
  cursor: pointer;
}

.card form button:hover {
  background: var(--blue);
  color: #fff;
}

/* ===============================
   FOOTER
   =============================== */
.site-footer {
  background: var(--blue);
  border-top: 4px solid var(--orange);
  color: #fff;
  text-align: center;
  padding: 2rem 1rem;
  margin-top: 3rem;
}

/* ===============================
   RESPONSIVE
   =============================== */
@media (max-width: 900px) {
  .cards {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 600px) {
  .cards {
    grid-template-columns: 1fr;
  }

  .card form .form-row {
    grid-template-columns: 1fr;
  }
}

/* === SVĚTLONCE MODRÉ TLAČÍTKO – FINÁLNÍ === */
.card form button {
  background: #E9EEFF !important;      /* světle modrá */
  border: 1px solid #CCD5FF !important;/* jemná modrá linka */
  color: #081444 !important;           /* tmavě modrá firemní */
  font-weight: 700;
  padding: 0.55rem;
  border-radius: 6px;
  font-size: 0.85rem;
  cursor: pointer;
  transition: 0.25s ease;
}

.card form button:hover {
  background: #081444 !important;      /* firemní modrá */
  border-color: #081444 !important;
  color: #fff !important;              /* bílé písmo */
}
.big-logo {
  text-shadow:
    0 2px 4px rgba(0,0,0,0.45),     /* jemný spodek */
    0 4px 14px rgba(0,0,0,0.35),    /* širší ambientní */
    0 0 22px rgba(255,255,255,0.08) /* jemný světelný halo */
    ;
}
.hero h1 {
  font-size: 1.45rem !important;     /* menší a profesionálnější */
  font-weight: 700;
  letter-spacing: .3px;              /* jemnější rytmus */
  margin-bottom: .3rem;
}

.hero {
  padding-top: 0.8rem;
  padding-bottom: 1.2rem;
}
body {
  background: #f2f4fb;
}

.card {
  box-shadow: 0 6px 18px rgba(8, 20, 68, 0.08);
}

/* ==============================
   MODERNÍ OHRANIČENÍ + SHADOW + HOVER
   ============================== */

.card {
  background: #ffffff;
  border-radius: 12px;
  border: 1px solid rgba(8, 20, 68, 0.12); /* jemná modrá linka */
  box-shadow: 0 2px 6px rgba(8, 20, 68, 0.06); /* základní malý stín */
  
  transition: transform 0.25s ease, 
              box-shadow 0.25s ease,
              border-color 0.25s ease;
}

/* HOVER efekt – elegantní odlepení */
.card:hover {
  transform: translateY(-8px); /* plynulý pohyb nahoru */
  box-shadow: 0 10px 24px rgba(8, 20, 68, 0.15); /* výraznější stín */
  border-color: var(--orange); /* oranžové zvýraznění */
}
/* ===========================
   HEADER CONTACT (SVG ICONS)
   =========================== */

.header-contact {
  position: absolute;
  top: 1rem;
  right: 1.5rem;
  display: flex;
  gap: 1.6rem;
}

.contact-item {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  color: #ffffff;
  text-decoration: none;
  font-size: 0.95rem;
  font-weight: 600;
  opacity: 0.9;
  transition: 0.2s ease;
}

.contact-item:hover {
  color: var(--orange);
  opacity: 1;
}

/* SVG ikony */
.contact-item .icon {
  width: 18px;
  height: 18px;
  fill: currentColor; /* barva se bere z textu */
  display: block;
}

/* ZVĚTŠENÍ OBRÁZKU PRO DERATIZACI (A OSTATNÍ KARTY) */
.card > img {
  width: 100%;
  height: 260px;   /* bylo 175px */
  object-fit: cover;
  display: block;
}

/* VOLITELNĚ: mírné zvětšení horní části karty */
.card {
  padding-bottom: 0.5rem; /* jemný prostor navíc pod obrázkem */
}

/* ======================================
   SUBPAGE HEADER
   ====================================== */
.sub-header {
  background: linear-gradient(135deg, var(--blue), var(--blue-soft));
  padding: 2.6rem 1rem 2rem;
  color: #fff;
  text-align: center;
  border-bottom: 4px solid var(--orange);
}

.sub-header-inner {
  max-width: 1200px;
  margin: 0 auto;
}

.sub-header-title h1 {
  font-size: 2.8rem;
  font-weight: 800;
  margin: 0 0 .4rem;
  letter-spacing: .5px;
}

.sub-header-title p {
  font-size: 1.1rem;
  opacity: .9;
  margin: 0 0 1.6rem;
  font-weight: 500;
}

.sub-header-nav ul {
  list-style: none;
  margin: 0 auto 1.6rem;
  padding: 0;
  display: flex;
  gap: 0.6rem;
  justify-content: center;
  flex-wrap: wrap;
}

.sub-header-nav a {
  background: #ffffff;
  color: var(--blue);
  padding: 0.45rem 1rem;
  border-radius: 6px;
  font-weight: 600;
  text-decoration: none;
  transition: 0.2s;
}

.sub-header-nav a:hover {
  background: var(--orange);
  color: #fff;
}

.sub-header-contact {
  display: flex;
  justify-content: center;
  gap: 1.6rem;
  font-weight: 600;
  opacity: .95;
}

.sub-header-contact a {
  color: #fff;
  text-decoration: none;
}

.sub-header-contact a:hover {
  color: var(--orange);
}

.subpage-content {
    max-width: 1100px;
    margin: 2rem auto;
    padding: 0 1rem 3rem;
}

.subpage-content h2 {
    font-size: 1.9rem;
    margin-bottom: 1rem;
    color: var(--blue);
}

.subpage-content h3 {
    font-size: 1.35rem;
    margin-top: 1.6rem;
    margin-bottom: .6rem;
    color: var(--blue-soft);
}
.mapa iframe {
    border-radius: 10px;
    box-shadow: 0 4px 16px rgba(0,0,0,0.15);
    margin-top: 1rem;
}

.cards {
    max-width: 1300px !important; /* místo 1100px */
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 2rem !important; /* větší mezery – opticky širší */
}

.card {
    border-radius: 0 !important;
}

.card img {
    border-radius: 0 !important;
}

body {
    background: #c3c3c3 !important; /* jemná světle šedá */
}

/* ===============================
   EKO LUX COLOR PATCH
   (bez změny layoutu / hranaté karty zachovány)
   =============================== */

/* 1) Tmavší, přírodní zelená (méně křiklavá) */
:root{
  --eco-green-main: #1f5f2e;   /* hlavní tmavší zelená */
  --eco-green-dark: #154421;   /* header / hover */
  --eco-green-soft: #e6f1ea;   /* eko pozadí formulářů */
  --eco-green-line: #8fb89a;   /* jemná linka / akcent */
}

/* 2) Header – hlubší zelená, luxusnější */
.site-header,
.sub-header{
  background: linear-gradient(
    135deg,
    var(--eco-green-dark),
    var(--eco-green-main)
  );
}

/* 3) Texty v headeru – čistší kontrast */
.site-header h1,
.sub-header h1{
  color: #ffffff;
}

.site-header p,
.sub-header p{
  color: rgba(255,255,255,0.9);
}

/* 4) Pozadí stránky – klidnější, eko */
body{
  background: #e9e9e9;
}

/* 5) KARTY – stále HRANATÉ, jen jemnější barvy */
.card{
  background: #ffffff;
  border-color: rgba(0,0,0,0.08);
}

/* 6) Nadpisy v kartách – tmavší zelená */
.card h2{
  color: var(--eco-green-dark);
}

/* 7) Text v kartách – méně šedý, „čistší papír“ */
.card p{
  color: #2a2a2a;
}

/* 8) CTA tlačítka – hezčí, eko, ale jednoduchá */
.card .btn{
  background: linear-gradient(
    135deg,
    var(--eco-green-main),
    #2f7a44
  );
  color: #ffffff;
  border: 1px solid var(--eco-green-dark);
}

.card .btn:hover{
  background: linear-gradient(
    135deg,
    var(--eco-green-dark),
    var(--eco-green-main)
  );
}

/* 9) Formulář v kartách – víc eko */
.card form{
  background: var(--eco-green-soft);
  border: 1px solid var(--eco-green-line);
}

/* 10) Inputy – čistší, méně „plastové“ */
.card form input,
.card form textarea{
  background: #ffffff;
  border-color: rgba(0,0,0,0.18);
}

/* 11) Odesílací tlačítko ve formuláři – lux eko */
.card form button{
  background: #ffffff;
  color: var(--eco-green-dark);
  border: 2px solid var(--eco-green-main);
  font-weight: 700;
}

.card form button:hover{
  background: var(--eco-green-main);
  color: #ffffff;
}
/* ===============================
   SUB HEADER – FOTO + OVERLAY
   =============================== */

.sub-header{
  position: relative;
  min-height: 220px;          /* ← DŮLEŽITÉ */
  overflow: hidden;
  display: flex;
  align-items: center;
}

/* wrapper s fotkou */
.sub-header .header-bg{
  position: absolute;
  inset: 0;
  z-index: 0;
}

/* samotná fotka */
.sub-header .header-bg img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

/* zelený overlay */
.sub-header::after{
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(20,60,30,0.60);
  z-index: 1;
}

/* obsah nad fotkou */
.sub-header-inner{
  position: relative;
  z-index: 2;
  width: 100%;
  text-align: center;
}

/* tmavá zelená oddělovací linka pod headerem */

.sub-header{
  border-bottom: 4px solid rgba(31,95,46,0.45); /* tmavá zelená, ale průhledná */
}

/* ===============================
   FOOTER – EKO, KORESPONDUJE S HEADEREM
   =============================== */

.site-footer{
  border-top: 4px solid rgba(255,255,255,0.18);
}

/* text ve footeru */
.site-footer p,
.site-footer span{
  color: rgba(255,255,255,0.9);
  font-size: 0.95rem;
}

/* odkazy */
.site-footer a{
  color: #ffffff;
  text-decoration: none;
  font-weight: 600;
}

.site-footer a:hover{
  color: #a6d3b0; /* jemný eko akcent */
}

/* ikony (telefon, mail) */
.site-footer svg,
.site-footer i{
  color: #a6d3b0;
}


/* ===============================
   FOOTER – FOTO + OVERLAY (STEJNĚ JAKO SUB-HEADER)
   =============================== */

.site-footer{
  position: relative;
  min-height: 260px;        /* výška footeru s fotkou – uprav dle chuti */
  overflow: hidden;
  display: flex;
  align-items: center;
}

/* wrapper s fotkou */
.site-footer .header-bg{
  position: absolute;
  inset: 0;
  z-index: 0;
}

/* samotná fotka */
.site-footer .header-bg img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center bottom; /* bere SPODNÍ část fotky */
  display: block;
}

/* zelený overlay */
.site-footer::after{
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(20,60,30,0.60); /* stejné ladění jako header */
  z-index: 1;
}

/* obsah nad fotkou */
.site-footer .footer-inner{
  position: relative;
  z-index: 2;
  width: 100%;
  text-align: center;
}

.card{
  border: 3px solid #1D5A2C; /* tmavě zelený, ale jemný */
  background: #fff;
}

/* ===============================
   KONTAKT NAD MAPOU – SAMOSTATNÁ TŘÍDA
   =============================== */

.sub-header-contact-kontakt{
  display: flex;
  gap: 2rem;                 /* vzdálenost Tel / Email */
  align-items: center;
  justify-content: flex-start;
  color: #000;
}

/* odkazy */
.sub-header-contact-kontakt .contact-item{
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  color: #000;               /* ČERNÁ */
  text-decoration: none;
  font-weight: 600;
}

/* ikony */
.sub-header-contact-kontakt .icon{
  fill: #000;                /* ČERNÉ IKONY */
}

/* hover jemný */
.sub-header-contact-kontakt .contact-item:hover{
  text-decoration: underline;
}

.about-wide{
  width: 68%;
  margin: 0 auto;            /* ✅ VYCENTROVÁNÍ */
  background: #C3C3C3;
  padding: 50px 0;
}

/* bílý blok přes CELÝ obsah */
.about-company{
  width: 100%;
  background: #f2f2f2;
  padding: 30px 60px;      /* odsazení od krajů */
  border-left: 6px solid #2f6b3c;

  color: #222;
  font-size: 16px;
  line-height: 1.8;
}

/* typografie */
.about-company p{
  margin: 0 0 18px;
}

.about-company .signature{
  margin-top: 26px;
  font-style: italic;
  color: #444;
}

.about-company .signature strong{
  display: block;
  margin-top: 6px;
  font-style: normal;
  color: #1f4f2f;
}

.cookie-bar{
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  background: #1f5f2e;
  color: #fff;
  z-index: 9999;
  padding: 14px 18px;
  display: none;
}

.cookie-inner{
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  gap: 1rem;
  align-items: center;
  justify-content: space-between;
}

.cookie-bar p{
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.4;
}

.cookie-bar a{
  color: #a6d3b0;
  text-decoration: underline;
}

#cookie-accept{
  background: #ffffff;
  color: #1f5f2e;
  border: none;
  padding: 8px 14px;
  font-weight: 700;
  cursor: pointer;
  border-radius: 4px;
}

#cookie-accept:hover{
  background: #a6d3b0;
}
/* GDPR souhlas ve formuláři – KOMPAKTNÍ verze do karet */
.card form .gdpr-consent{
  margin: 6px 0 4px;
  font-size: 0.78rem;     /* menší text */
  line-height: 1.15;
  color: #222;
}

.card form .gdpr-consent label{
  display: flex;
  align-items: center;    /* checkbox + text na jednu linku */
  gap: 6px;
}

.card form .gdpr-consent input[type="checkbox"]{
  width: 16px;
  height: 16px;
  margin: 0;
}

.card form .gdpr-consent a{
  color: #1f5f2e;
  text-decoration: underline;
}

/* ======================================
   PDF PREVIEW SEKCE (5 náhledů vedle sebe)
   ====================================== */

.pdf-preview-block{
  width: 90vw;              /* široké, jako zbytek */
  max-width: 1600px;
  margin: 2.5rem auto 2rem; /* nad poptávkou */
  padding: 1.2rem 1.2rem 1rem;
  background: #e5e5e5;      /* sedí k tvému šedému stylu */
  border: 1px solid rgba(0,0,0,0.12);
}

.pdf-preview-block h2{
  margin: 0 0 1rem;
  font-size: 1.6rem;
  font-weight: 800;
  color: #143c1e;
  text-align: left;         /* vypadá líp než center */
}

/* Grid 5 kusů */
.pdf-preview-grid{
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1rem;
  align-items: stretch;
}

/* Klikací dlaždice */
.pdf-preview-grid a{
  display: block;
  text-decoration: none;
}

/* Obrázky (náhledy) */
.pdf-preview-grid img{
  width: 100%;
  height: 140px;           /* jednotná výška */
  object-fit: cover;
  display: block;
  border: 1px solid rgba(0,0,0,0.18);
  background: #f7f7f7;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

/* Hover efekt */
.pdf-preview-grid a:hover img{
  transform: translateY(-3px);
  box-shadow: 0 10px 22px rgba(0,0,0,0.18);
  border-color: rgba(20,60,30,0.35);
}

/* Pokud chceš pod každým obrázkem i popisek (když ho dáš do HTML jako <span>) */
.pdf-preview-grid a span{
  display: block;
  margin-top: .5rem;
  font-size: .9rem;
  font-weight: 600;
  color: #143c1e;
  text-align: center;
}

/* Link pod obrázky */
.pdf-preview-link{
  margin-top: 1rem;
  padding-top: .8rem;
  border-top: 1px solid rgba(0,0,0,0.12);
  text-align: left;
}

.pdf-preview-link a{
  font-weight: 700;
  color: #143c1e;
  text-decoration: none;
}

.pdf-preview-link a:hover{
  text-decoration: underline;
}

/* RESPONSIVE */
@media (max-width: 1100px){
  .pdf-preview-grid{ grid-template-columns: repeat(3, 1fr); }
  .pdf-preview-grid img{ height: 150px; }
}


/* ======================================
   PDF PREVIEW – TLAČÍTKO „STÁHNOUT PDF“
   ====================================== */

.pdf-item .pdf-btn{
  display: block;
  margin-top: 0.6rem;
  padding: 0.45rem 0.6rem;
  text-align: center;

  font-size: 0.8rem;
  font-weight: 700;
  color: #1f5f2e;            /* eko zelená */
  background: #ffffff;

  border: 1px solid #1f5f2e;
  text-decoration: none;
  transition: background 0.2s ease, color 0.2s ease;
}

.pdf-item .pdf-btn:hover{
  background: #1f5f2e;
  color: #ffffff;
}

/* ======================================
   PDF PREVIEW – ZELENÉ NADPISY (H5)
   ====================================== */

.pdf-item h5{
  margin: 0 0 0.5rem;
  font-size: 0.85rem;      /* menší, jak jsi chtěl */
  font-weight: 700;
  color: #1f5f2e;          /* eko zelená */
  text-align: left;
}


/* =========================================================
   RESPONSIVE OVERRIDE – TABLET + MOBIL
   Priorita: TEXT + FOTKA (C)
   ========================================================= */


/* =========================
   TABLET (≤1024px)
   ========================= */
@media (max-width: 1024px){

  /* zmenšení headeru */
  .sub-header{
    min-height: 160px;
    padding: 1.6rem 1rem;
  }

  .sub-header h1{
    font-size: 2rem;
  }

  /* PDF sekce – 5 → 3 */
  .pdf-preview-grid{
    grid-template-columns: repeat(3, 1fr);
  }

  /* formulář – víc prostoru */
  .poptavka-wrapper{
    padding: 2rem 1.5rem;
  }
}


/* =========================
   MOBIL (≤768px)
   ========================= */
@media (max-width: 768px){

  /* ====== POŘADÍ BLOKŮ (C) ====== */
  /* text + fotka */
  .subpage-hero,
  .subpage-hero-reverse{
    order: 1;
  }

  /* PDF dokumentace */
  .pdf-preview-block{
    order: 2;
  }

  /* poptávka až nakonec */
  .poptavka-wrapper{
    order: 3;
  }

  /* ====== HERO – sloupce pod sebe ====== */
  .subpage-hero,
  .subpage-hero-reverse{
    grid-template-columns: 1fr !important;
  }

  .subpage-hero img,
  .subpage-hero-reverse img{
    height: 220px !important;
  }

  .subpage-hero .hero-text,
  .subpage-hero-reverse .hero-text{
    padding: 1.2rem 1.2rem;
  }

  .subpage-hero h1{
    font-size: 1.6rem;
  }

  /* ====== PDF sekce – 3 → 2 ====== */
  .pdf-preview-grid{
    grid-template-columns: repeat(2, 1fr);
  }

  /* ====== FORM ====== */
  .poptavka-wrapper .form-row{
    grid-template-columns: 1fr;
  }

  .poptavka-title{
    font-size: 1.6rem;
  }

  /* ====== FOOTER ====== */
  .site-footer .footer-inner{
    text-align: center;
  }
}


/* =========================
   MALÝ MOBIL (≤480px)
   ========================= */
@media (max-width: 480px){

  /* PDF sekce – 2 → 1 */
  .pdf-preview-grid{
    grid-template-columns: 1fr;
  }

  .pdf-preview-grid img{
    height: 160px;
  }

  /* tlačítka větší pro prsty */
  .pdf-item .pdf-btn{
    padding: 0.6rem;
    font-size: 0.9rem;
  }

  /* header text menší */
  .sub-header h1{
    font-size: 1.4rem;
  }
}

/* =========================================================
   MOBIL – MENU + BLOKY + FOOTER KONTAKT
   ========================================================= */
@media (max-width: 768px){

  /* ---------- MENU: pod sebe, plná šířka ---------- */
  .main-nav ul{
    flex-direction: column;
    align-items: stretch;
    gap: .4rem;
    padding: 0 12px;
  }

  .main-nav li{
    width: 100%;
  }

  .main-nav a{
    display: block;
    width: 100%;
    text-align: center;
    padding: .65rem 1rem;
    border-radius: 8px;
  }

  /* ---------- BLOKY / KARTY: pod sebe ---------- */
  .cards{
    grid-template-columns: 1fr !important;
    gap: 1rem !important;
    padding: 0 12px !important;
  }

  /* pokud používáš PDF mřížku */
  .pdf-preview-grid{
    grid-template-columns: 1fr !important; /* vše pod sebe */
    gap: 1rem !important;
  }

  /* ---------- SPLIT BLOKY (50/50): pod sebe ---------- */
  .subpage-hero,
  .subpage-hero-reverse{
    grid-template-columns: 1fr !important;
  }

  /* ---------- FOOTER: telefon + email pod sebe ---------- */
  .site-footer .sub-header-contact,
  .sub-header-contact{
    flex-direction: column;
    align-items: center;
    gap: .45rem;
  }

  /* aby se v mobilu nelepilo těsně k okraji */
  .site-footer .footer-inner{
    padding: 0 12px;
  }
}

/* =========================================================
   MALÝ MOBIL – ještě větší klikací prvky
   ========================================================= */
@media (max-width: 480px){
  .main-nav a{
    padding: .75rem 1rem;
    font-size: .95rem;
  }

  /* tlačítka u PDF (pokud máš .pdf-btn) */
  .pdf-item .pdf-btn{
    padding: .65rem .8rem;
    font-size: .9rem;
  }
}

/* =========================================================
   MOBILNÍ MENU – SAMOSTATNÉ (DETAILS) + ŽÁDNÉ PŘEKRYVY
   ========================================================= */

/* výchozí: mobilní menu skryté na desktopu */
.mobile-menu{ display:none; }

/* MOBIL */
@media (max-width: 768px){

  /* desktop nav schovat */
  .desktop-nav{ display:none !important; }

  /* mobilní menu zapnout */
  .mobile-menu{
    display:block;
    margin: .8rem 0 .6rem;
    padding: 0 12px;
  }

  /* tlačítko "Menu" */
  .mobile-menu > summary{
    list-style: none;
    cursor: pointer;
    user-select: none;

    display:block;
    width: 100%;
    text-align:center;

    background: #ffffff;
    color: var(--blue);
    font-weight: 800;
    padding: .7rem 1rem;
    border-radius: 8px;
    border: 1px solid rgba(0,0,0,0.15);
  }

  /* odstranit defaultní šipku v některých prohlížečích */
  .mobile-menu > summary::-webkit-details-marker{ display:none; }

  /* rozbalený panel */
  .mobile-menu[open] > summary{
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
  }

  .mobile-nav{
    display: grid;
    gap: .45rem;
    padding: .6rem 0 0;
    background: rgba(255,255,255,0.0);
  }

  .mobile-nav a{
    display:block;
    width: 100%;
    text-align:center;
    padding: .65rem 1rem;
    border-radius: 8px;

    background: rgba(255,255,255,0.14);
    border: 1px solid rgba(255,255,255,0.18);
    color: #fff;
    text-decoration:none;
    font-weight: 700;
  }

  /* kontakt vždy POD menu – už žádné překrytí */
  .sub-header-contact{
    display:flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: .35rem !important;
    margin-top: .8rem !important;
  }
}