/* ==========================================
   Kamelie – style.css
   THEME: SOLID CHOCOLATE #634832 everywhere + darker gold accent
   - no background gradients / no decorative transitions
========================================== */

:root{
  --bg:#634832;                 /* solid background everywhere */
  --bg-rgb: 99,72,50;

  --surface:#ffffff;

  --text:#2b1e16;               /* text on light surfaces */
  --text-on-dark: rgba(255,255,255,.92);

  --muted:#6b5a4c;
  --muted-2:#8a7767;

  --ink-rgb: 43,30,22;

  /* darker / more vivid gold */
  --accent:#a77712;
  --accent-2:#7f5608;
  --accent-rgb: 167,119,18;
  --accent2-rgb: 127,86,8;

  --gold: var(--accent);

  --shadow:0 18px 55px rgba(10,10,10,.12);
  --shadowSoft:0 14px 26px rgba(10,10,10,.10);
  --radius:18px;
  --container:1120px;

  --focus:0 0 0 4px rgba(var(--accent-rgb),.26);
  --ease:cubic-bezier(.2,.8,.2,1);

  --font:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --font-header:"Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  --fs-base:1rem;
  --fs-sm:.95rem;
  --fs-lead:1.05rem;

  --header-pad-y:.95rem;
  --header-pad-y-scrolled:.55rem;

  /* topbar uses same solid bg */
  --header-hero-bg: var(--bg);
  --header-hero-border: rgba(var(--accent-rgb), .34);
  --header-light-bg: var(--bg);
  --header-light-border: rgba(var(--accent-rgb), .44);

  --dropdown-hero-bg: rgba(255,255,255,.98);
  --dropdown-light-bg: rgba(255,255,255,.98);

  --gold-filter:
    brightness(0) saturate(100%)
    invert(50%) sepia(65%) saturate(680%)
    hue-rotate(12deg) brightness(98%) contrast(96%);

  --black-filter:
    brightness(0) saturate(100%)
    invert(0%) sepia(0%) saturate(0%)
    contrast(100%);

  --anchor-offset: 140px;
}

/* -------------------------
   ANCHORS
------------------------- */
html{ scroll-behavior:auto; scroll-padding-top: var(--anchor-offset); }
[id]{ scroll-margin-top: var(--anchor-offset); }

/* -------------------------
   RESET & BASE
------------------------- */
*,
*::before,
*::after{ box-sizing:border-box; }

body{
  margin:0;
  font-family:var(--font);
  font-size:var(--fs-base);
  color:var(--text-on-dark);
  line-height:1.65;
  background: var(--bg); /* SOLID */
}

img{ max-width:100%; height:auto; display:block; }
a{ color:inherit; }
a:hover{ color: var(--accent); }
p{ margin:0 0 1rem; }
p:last-child{ margin-bottom:0; }

.topbar-inner,
.section-inner,
.footer-inner{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 1rem;
}

/* -------------------------
   A11Y
------------------------- */
.skip-link{
  position:absolute;
  left:-999px;
  top:10px;
  padding:.6rem .9rem;
  background: rgba(255,255,255,.98);
  border:1px solid rgba(var(--accent-rgb),.30);
  border-radius:999px;
  box-shadow:var(--shadow);
  z-index:999;
}
.skip-link:focus{
  left:12px;
  outline:none;
  box-shadow:var(--focus), var(--shadow);
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
summary:focus-visible{
  outline:none;
  box-shadow:var(--focus);
  border-radius:10px;
}

/* =========================================================
   HEADER
========================================================= */
.topbar{
  position:fixed;
  inset:0 0 auto 0;
  z-index:60;

  background: var(--bg); /* SOLID */
  backdrop-filter: none;
  -webkit-backdrop-filter: none;

  border-bottom: 1px solid rgba(var(--accent-rgb), .34);
  transition:
    box-shadow .25s var(--ease),
    border-color .25s var(--ease);
}
.topbar--scrolled{
  box-shadow: 0 18px 55px rgba(0,0,0,.26);
}
.topbar--light{
  background: var(--bg); /* still solid */
  border-bottom: 1px solid rgba(var(--accent-rgb), .44);
  box-shadow: 0 18px 55px rgba(0,0,0,.22);
}

.topbar-inner{
  padding: var(--header-pad-y) 1rem .75rem;
  transition: padding .25s var(--ease);
}
.topbar--scrolled .topbar-inner{
  padding: var(--header-pad-y-scrolled) 1rem .55rem;
}

.header-top{
  display:grid;
  grid-template-columns: auto 1fr;
  align-items:center;
  gap:1rem;
}

.logo{
  display:flex;
  align-items:center;
  gap:.75rem;
  text-decoration:none;
  white-space:nowrap;
}

.logo-mark{
  width:44px;
  height:44px;
  border-radius:14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;

  background: rgba(0,0,0,.12);
  border: 1px solid rgba(var(--accent-rgb),.34);
  box-shadow: 0 12px 28px rgba(0,0,0,.24);
  overflow:hidden;

  transition:
    width .25s var(--ease),
    height .25s var(--ease);
}
.logo-mark img{
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
}
.topbar--scrolled .logo-mark{ width:40px; height:40px; }

.logo-text{
  font-weight:900;
  letter-spacing:-.01em;
  font-size:1rem;
  line-height:1.1;
  color: rgba(255,255,255,.94);
}

.header-contacts{
  justify-self:end;
  display:flex;
  align-items:center;
  gap:.85rem;
  flex-wrap:nowrap;
}

.contact-chip{
  display:inline-flex;
  align-items:center;
  gap:.65rem;
  text-decoration:none;
  padding:.64rem .9rem;
  border-radius:999px;
  white-space:nowrap;

  background: rgba(0,0,0,.12);
  border: 1px solid rgba(var(--accent-rgb),.34);
  box-shadow: 0 10px 26px rgba(0,0,0,.22);

  transition:
    transform .18s var(--ease),
    box-shadow .18s var(--ease);
}
.contact-chip:hover{
  transform: translateY(-1px);
  box-shadow: 0 16px 40px rgba(0,0,0,.28);
}
.contact-chip span{
  font-size:.78rem;
  font-weight:900;
  letter-spacing:.03em;
  line-height:1;
  color: rgba(255,255,255,.78);
}
.contact-chip strong{
  font-size:.95rem;
  font-weight:900;
  letter-spacing:.01em;
  line-height:1;
  color: rgba(255,255,255,.94);
}
.contact-chip img{
  width:30px;
  height:30px;
  opacity:.98;
  filter: var(--gold-filter);
}

.header-nav{
  margin-top:.8rem;
  padding-top:.6rem;

  display:flex;
  align-items:center;
  justify-content:center;
  gap:1rem;

  position:relative;
  transition: margin-top .25s var(--ease), padding-top .25s var(--ease);
}
.topbar--scrolled .header-nav{
  margin-top:.55rem;
  padding-top:.5rem;
}
.topbar .header-nav{
  border-top: 1px solid rgba(var(--accent-rgb),.26);
}

.main-nav{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:1.55rem;
}
.main-nav a{
  text-decoration:none;
  font-weight:900;
  font-size:.95rem;
  padding:.2rem 0;
  position:relative;
  transition: color .18s var(--ease), transform .18s var(--ease);
  color: rgba(255,255,255,.86);
}
.main-nav a:hover{
  transform: translateY(-1px);
  color: rgba(var(--accent-rgb), .98);
}
.main-nav a::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-10px;
  width:100%;
  height:2px;
  border-radius:999px;
  background: rgba(var(--accent-rgb),1); /* no gradient */
  transform: scaleX(0);
  transform-origin:left;
  transition: transform .18s var(--ease);
}
.main-nav a:hover::after,
.main-nav a.is-active::after{ transform: scaleX(1); }

.nav-toggle{
  display:none;
  width:44px;
  height:44px;
  border-radius:14px;
  cursor:pointer;
  background: rgba(0,0,0,.12);
  border:1px solid rgba(var(--accent-rgb),.34);
  box-shadow: 0 12px 28px rgba(0,0,0,.22);
  position:relative;
  color: rgba(var(--accent-rgb), .98);
}
.nav-toggle::before{ content:"☰"; font-size:1.35rem; line-height:1; }
.nav-toggle.is-open::before{ content:"✕"; }

/* =========================
   HEADER FONT
========================= */
.topbar,
.topbar *{ font-family: var(--font-header) !important; }
.topbar .main-nav a{ letter-spacing: 0; }
.topbar .logo-text{ letter-spacing: -0.01em; }
.topbar .contact-chip span{ letter-spacing: 0.02em; }

/* =====================================================
   FAB
===================================================== */
.fab-group{
  position: fixed;
  right: 14px;
  bottom: 14px;
  z-index: 90;

  display:flex;
  flex-direction:column;
  gap:12px;

  opacity:0;
  transform: translateY(10px);
  pointer-events:none;
  transition: opacity .2s var(--ease), transform .2s var(--ease);
}
.fab-group.is-visible{
  opacity:1;
  transform: translateY(0);
  pointer-events:auto;
}

.fab{
  width:56px;
  height:56px;
  border-radius:999px;

  display:inline-flex;
  align-items:center;
  justify-content:center;

  text-decoration:none;
  background: rgba(255,255,255,.92);
  border:1px solid rgba(var(--accent-rgb),.34);
  box-shadow:0 18px 45px rgba(0,0,0,.22);
}
.fab img{
  width:26px;
  height:26px;
  filter: var(--gold-filter);
}
.fab-top{
  cursor:pointer;
  font-weight:900;
  font-size:18px;
  line-height:1;
  color: var(--accent);
  background: rgba(255,255,255,.92);
  border:1px solid rgba(var(--accent-rgb),.34);
  border-radius:999px;
  width:56px;
  height:56px;
  box-shadow:0 18px 45px rgba(0,0,0,.22);
}

/* =====================================================
   MOBILE HEADER
===================================================== */
@media (max-width: 980px){
  .header-top{
    grid-template-columns: 1fr auto;
    gap:.75rem;
  }

  .header-contacts{
    grid-column:1 / -1;
    width:100%;
    display:flex;
    flex-direction:column;
    align-items:stretch;
    gap:.35rem;
    justify-self:stretch;
  }

  .contact-chip{
    width:100%;
    justify-content:flex-start;
    padding:.5rem .75rem;
  }
  .contact-chip span{ display:none; }

  .header-nav{
    margin:0;
    padding:0;
    border:none;
    position:relative;
  }

  .topbar.topbar--compact .topbar-inner{ padding:.45rem 1rem; }
  .topbar.topbar--compact .header-contacts{ display:none !important; }

  .main-nav{
    position:absolute;
    top:100%;
    left:12px;
    right:12px;
    margin-top:10px;

    display:none;
    flex-direction:column;
    align-items:stretch;
    gap:.25rem;

    padding:.7rem;
    border-radius: 18px;
    box-shadow: 0 26px 80px rgba(0,0,0,.28);
  }
  .main-nav.is-open{ display:flex; }

  .topbar:not(.topbar--light) .main-nav,
  .topbar.topbar--light .main-nav{
    background: rgba(255,255,255,.98);
    border: 1px solid rgba(var(--accent-rgb),.30);
  }

  .main-nav a{
    padding: .95rem 1rem;
    border-radius: 14px;
    transform:none;
    color: rgba(var(--ink-rgb), .92);
  }
  .main-nav a:hover{ color: rgba(var(--accent-rgb), .98); }
  .main-nav a::after{ display:none; }
}

/* -------------------------
   HERO (index)
------------------------- */
.hero{
  position:relative;
  min-height:100vh;
  color: rgba(var(--ink-rgb),.96);
  background-image:url("hero.avif");
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  display:flex;
  align-items:center;
}
.hero-overlay{
  position:absolute;
  inset:0;
  /* keep only readability overlay for photo (not page background) */
  background: linear-gradient(to bottom, rgba(20,18,14,.18), rgba(20,18,14,.72));
  z-index:1;
}

.hero-inner{
  position:relative;
  z-index:2;
  padding: 7.2rem 1rem 3.25rem;
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  display:flex;
  align-items:center;
}
.hero-content{ max-width:650px; }
.hero-eyebrow{
  margin:0 0 .7rem;
  font-size:.92rem;
  opacity:.98;
  letter-spacing:.03em;
  text-transform:uppercase;
  color: rgba(var(--accent-rgb),.98);
}
.hero h1{
  margin:0 0 1rem;
  font-size:clamp(2.2rem, 4vw, 3.15rem);
  line-height:1.15;
  letter-spacing:-0.02em;
  color: rgba(233, 232, 229, 0.98);
  text-shadow:0 18px 40px rgba(0,0,0,.20);
}
.hero p{
  margin:0 0 1.55rem;
  font-size:var(--fs-lead);
  max-width:38rem;
  color: rgba(233, 232, 229, 0.98);
}
.hero-buttons{
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
  margin-bottom:1.25rem;
}
@media (max-width: 900px){
  .hero-inner{ padding-top: 8.2rem; }
  .hero-content{ text-align:center; margin:0 auto; }
  .hero p{ margin-left:auto; margin-right:auto; }
  .hero-buttons{ justify-content:center; }
}

/* -------------------------
   BUTTONS
------------------------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:.78rem 1.4rem;
  font-size:var(--fs-sm);
  border-radius:999px;
  border:1px solid transparent;
  cursor:pointer;
  text-decoration:none;
  font-weight: 900;
  transition:
    transform .16s var(--ease),
    background-color .16s var(--ease),
    color .16s var(--ease),
    border-color .16s var(--ease),
    box-shadow .16s var(--ease);
  user-select:none;
}
.btn:hover{ transform:translateY(-1px); }
.btn:active{ transform:translateY(0); }

.btn-primary{
  background: var(--accent); /* no gradient */
  color:#101010;
  border: 1px solid rgba(var(--accent-rgb),.40);
  box-shadow:0 14px 34px rgba(0,0,0,.22);
}
.hero .btn-primary{
  background: var(--accent);
  color:#000000;
  border-color:rgba(0,0,0,.12);
  box-shadow:0 14px 34px rgba(0,0,0,.26);
}

.btn-outline{
  background: rgba(0,0,0,.16);
  color: rgba(255,255,255,.94);
  border-color: rgba(var(--accent-rgb),.55);
}
.btn-wide{ width:100%; margin-top:.6rem; }
.small-muted{ color: rgba(0, 0, 0, 0.74); font-size:.92rem; }

/* -------------------------
   SECTIONS (SOLID BG)
------------------------- */
.section{
  padding:5rem 1rem;
  position:relative;
  color: rgba(255,255,255,.90);
  background: var(--bg); /* SOLID */
}
.section::before{
  content:"";
  position:absolute;
  left:0; right:0; top:0;
  height:1px;
  background: rgba(var(--accent-rgb),.45); /* no gradient */
  opacity:1;
}

.section-light,
.section-contact{
  background: var(--bg); /* SOLID */
}

.section h2{
  margin:0 0 .9rem;
  text-align:center;
  font-size:clamp(1.65rem, 2.1vw, 2.15rem);
  letter-spacing:-0.015em;
  line-height:1.15;
  color: rgba(255,255,255,.96);
}
.section-lead{
  margin:0 auto 2.4rem;
  text-align:center;
  color: rgba(255,255,255,.78);
  max-width:62ch;
  font-size:var(--fs-lead);
}

/* -------------------------
   SERVICES
------------------------- */
#sluzby.section{ background: var(--bg); }

.service-icons{
  display:grid;
  grid-template-columns:repeat(6, minmax(0,1fr));
  gap:2.6rem 1.6rem;
  margin-top:2.6rem;
  align-items:start;
}
@media (max-width: 1100px){
  .service-icons{ grid-template-columns:repeat(3, 1fr); }
}
@media (max-width: 640px){
  .service-icons{ grid-template-columns:repeat(2, 1fr); gap:2rem 1.2rem; }
}

.service-icon-link{
  text-decoration:none;
  color:inherit;
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:.75rem;
  transition:transform .18s var(--ease);
}
.service-icon-link:hover{ transform:translateY(-2px); }

.service-icon{
  width:130px;
  height:130px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(255,255,255,.62);
  border: 1px solid rgba(var(--accent-rgb),.30);
  box-shadow: 0 18px 36px rgba(0,0,0,.26);
}
.service-icon img{
  width:62px;
  height:62px;
  filter: var(--gold-filter);
  opacity:.98;
}
.service-label{
  font-size:var(--fs-sm);
  font-weight:900;
  line-height:1.3;
  letter-spacing:-0.01em;
  max-width:17ch;
  color: rgba(255,255,255,.92);
}

.service-icon-link.is-toggle{
  cursor:pointer;
  border:0;
  background:transparent;
  padding:0;
  font:inherit;
}

/* expander (light card => dark text!) */
.service-expander{
  grid-column:1 / -1;
  display:none;
  margin-top:-.6rem;
  padding:1.1rem 1.2rem;
  border-radius:18px;
  background: rgba(255,255,255,.92); /* SOLID */
  border:1px solid rgba(var(--accent-rgb),.28);
  box-shadow:0 18px 45px rgba(0,0,0,.26);
  color: rgba(var(--ink-rgb), .90);
}
.service-expander.is-open{ display:block; }
.service-expander ul{ list-style:none; margin:.7rem 0 0 0; padding:0; }
.service-expander li{
  position:relative;
  padding-left:1.6rem;
  margin:.35rem 0;
  color: rgba(var(--ink-rgb), .82);
}
.service-expander li::before{
  content:"✓";
  position:absolute;
  left:0;
  top:0;
  color: var(--accent);
  font-weight:900;
}
.service-expander a{
  color: rgba(var(--ink-rgb), .92);
  font-weight: 900;
  text-decoration:none;
}
.service-expander a:hover{
  color: var(--accent);
  text-decoration:underline;
}

.service-expander-actions{ margin-top:1rem; }
.service-cta-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:.7rem 1.4rem;
  border-radius:999px;
  background: var(--accent); /* no gradient */
  color:#101010;
  font-weight:900;
  font-size:var(--fs-sm);
  text-decoration:none;
  box-shadow: 0 14px 34px rgba(0,0,0,.24);
  border: 1px solid rgba(var(--accent-rgb),.40);
}

/* -------------------------
   CHECKLIST
------------------------- */
.checklist{
  list-style:none;
  padding:0;
  margin:0 0 1rem;
  display:grid;
  gap:.55rem;
}
.checklist li{
  position:relative;
  padding-left:1.55rem;
  color: rgba(255,255,255,.82);
  font-size:var(--fs-lead);
  line-height:1.55;
}
.checklist li::before{
  content:"✓";
  position:absolute;
  left:0;
  top:0;
  color:var(--accent);
  font-weight:900;
}

/* -------------------------
   PROCESS (Jak postupovat) – ONLY PHOTOS
------------------------- */
.process-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:2.5rem;
  align-items:center;
  margin-top:3rem;
}
.process-row.reverse{ direction:rtl; }
.process-row.reverse > *{ direction:ltr; }

.process-text h3{
  margin:0 0 .9rem;
  font-size:1.35rem;
  line-height:1.25;
  letter-spacing:-0.01em;
  color: rgba(255,255,255,.94);
}

/* Hard reset to kill any previous frame styles */
.process-image{
  position:relative;
  border:none !important;
  outline:none !important;
  padding:0 !important;
  margin:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  border-radius:var(--radius);
  overflow:hidden;
  height:260px;
}
.process-image::before,
.process-image::after{ content:none !important; display:none !important; }
.process-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
  border:none !important;
  background:transparent !important;
}

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

/* -------------------------
   INFO (FAQ)
------------------------- */
#informace{ background: var(--bg); }
.info-faq{
  max-width:980px;
  margin:0 auto;
  display:grid;
  gap:2.2rem;
}
.info-faq-item{ border:none; padding:0; }
.info-faq-item > summary{
  list-style:none;
  cursor:default;
  font-size:1.35rem;
  font-weight:900;
  letter-spacing:-0.015em;
  margin-bottom:1rem;
  color: rgba(255,255,255,.94);
}
.info-faq-item > summary::-webkit-details-marker{ display:none; }
.info-faq-item:not(:last-child){
  padding-bottom:2.1rem;
  border-bottom:1px solid rgba(var(--accent-rgb),.34);
}

/* -------------------------
   CONTACT
------------------------- */
.contact-layout--minimal{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:3rem;
  align-items:flex-start;
}
@media (max-width: 900px){
  .contact-layout--minimal{ grid-template-columns:1fr; gap:2.5rem; }
}
.contact-icons{ display:grid; gap:1.6rem; }

.contact-item{
  display:flex;
  align-items:center;
  gap:1.6rem;
  line-height:1.4;
  color: rgba(255,255,255,.84);
}
.contact-item img{
  width:60px;
  height:60px;
  flex:0 0 auto;
  filter: var(--gold-filter);
  opacity:.98;
}
.contact-item a{
  text-decoration:none;
  color: rgba(255,255,255,.96);
  font-weight:900;
}
.contact-item a:hover{
  text-decoration:underline;
  color: var(--accent);
}
.contact-item--urgent{ font-size:1.2rem; }

.contact-form--clean{
  display:grid;
  gap:1rem;
}
.contact-form--clean input,
.contact-form--clean textarea{
  width:100%;
  padding:1rem 1.1rem;
  border-radius:16px;
  border:1px solid rgba(var(--accent-rgb),.30);
  font:inherit;
  font-size:1rem;
  background: rgba(255,255,255,.92);
  color: rgba(var(--ink-rgb),.96);
  transition:border-color .15s var(--ease), box-shadow .15s var(--ease), background-color .15s var(--ease);
}
.contact-form--clean input:focus,
.contact-form--clean textarea:focus{
  border-color:rgba(var(--accent-rgb),.62);
  box-shadow:var(--focus);
  background: rgba(255,255,255,.98);
}
.form-note{
  margin-top:.4rem;
  font-size:.85rem;
  color: rgba(255,255,255,.74);
  text-align:center;
}

/* -------------------------
   LOCATIONS
------------------------- */
.locations{
  display:grid;
  grid-template-columns: minmax(0, 0.3fr) minmax(0, 1.6fr);
  gap:1.8rem;
  align-items:start;
}
.map-embed{
  width:100%;
  height:280px;
  border:1px solid rgba(var(--accent-rgb),.28);
  border-radius: var(--radius);
  box-shadow: var(--shadowSoft);
  background: rgba(255,255,255,.92);
}
@media (max-width: 980px){
  .locations{ grid-template-columns:1fr; }
}

/* -------------------------
   FOOTER (SOLID)
------------------------- */
.site-footer{
  border-top:1px solid rgba(var(--accent-rgb),.34);
  background: var(--bg); /* SOLID */
  padding:2.4rem 1rem 2.6rem;
  text-align:center;
  font-size:.92rem;
  color: rgba(255,255,255,.76);
}
.footer-cols{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:1rem;
  text-align:left;
  margin-bottom:1.25rem;
}
.footer-cols strong{ color: rgba(255,255,255,.92); }
.footer-cols a{
  color: rgba(var(--accent-rgb),.98);
  text-decoration:none;
  font-weight:900;
}
.footer-cols a:hover{ text-decoration:underline; }
.footer-meta{ margin:0; color: rgba(255,255,255,.72); }
@media (max-width: 900px){
  .footer-cols{ grid-template-columns:1fr; text-align:center; }
}

/* =====================================================
   SUBPAGES
===================================================== */
.page-hero{
  padding:.6rem 0 1.2rem;
  color: rgba(255,255,255,.90);
  background: var(--bg); /* SOLID */
}
.page-hero h1{ margin:0 0 .5rem 0; letter-spacing:-0.02em; color: rgba(255,255,255,.96); }
.page-hero p{ margin:0; max-width:78ch; color: rgba(255,255,255,.78); }

.page-back,
.parte-actions{
  margin-top: 1rem;
  display:flex;
  gap:.8rem;
  flex-wrap:wrap;
  align-items:center;
}

.parte-box{
  margin-top:1.6rem;
  padding:1.1rem 1.2rem;
  border-radius:18px;
  background: rgba(255,255,255,.92); /* SOLID */
  border:1px solid rgba(var(--accent-rgb),.26);
  box-shadow:0 18px 45px rgba(0,0,0,.26);
  color: rgba(var(--ink-rgb),.92);
}
.parte-box .parte-grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 1.2rem;
  align-items:start;
}
@media (max-width: 900px){
  .parte-box .parte-grid{ grid-template-columns:1fr; }
}

/* =========================================================
   MOBILE HEADER FIX
========================================================= */
@media (max-width: 980px){
  .header-contacts{ display: none !important; }

  .header-top{
    grid-template-columns: 1fr auto !important;
    align-items: center !important;
    gap: .75rem !important;
  }

  .logo{ min-width: 0; }
  .logo-text{
    display: inline !important;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 70vw;
  }

  .nav-toggle{
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
  }

  .header-nav{
    margin-top: .6rem !important;
    padding-top: .25rem !important;
    border-top: none !important;
    justify-content: flex-end;
  }

  .fab-group{
    opacity: 1 !important;
    transform: none !important;
    pointer-events: auto !important;
  }
}

/* =========================
   SUBPAGES: fixed header offset
========================= */
body.subpage main{
  padding-top: calc(var(--anchor-offset, 140px) + 16px);
}

/* ==========================================
   MOBILE HEADER: centrování + fullwidth menu
========================================== */
@media (max-width: 980px){
  .header-contacts{ display:none !important; }

  .header-top{
    grid-template-columns: 1fr !important;
    justify-items: center !important;
    gap: .65rem !important;
  }
  .logo{
    justify-content: center !important;
    text-align: center;
  }

  .header-nav{
    margin: .55rem 0 0 !important;
    padding: 0 !important;
    border: none !important;
    justify-content: center !important;
  }
  .nav-toggle{
    margin: 0 auto !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
  }

  .main-nav{
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    width: 100vw !important;

    top: calc(var(--anchor-offset, 140px) - 8px) !important;
    margin: 0 !important;

    display: none;
    flex-direction: column;
    align-items: stretch;
    gap: .25rem;

    padding: .75rem .75rem 1rem !important;
    border-radius: 0 0 18px 18px !important;
    z-index: 9999;

    max-height: calc(100vh - var(--anchor-offset, 140px));
    overflow: auto;

    background: rgba(255,255,255,.98);
    border: 1px solid rgba(var(--accent-rgb),.30);
    box-shadow: 0 26px 80px rgba(0,0,0,.30);
  }
  .main-nav.is-open{ display: flex !important; }

  .main-nav a{
    text-align: center;
    padding: .95rem 1rem !important;
    border-radius: 14px;
  }
}

/* =========================
   PARTE GALLERY
========================= */
.gallery{
  margin-top: 1.4rem;
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 1.1rem;
  align-items: start;
}
@media (max-width: 1100px){
  .gallery{ grid-template-columns: repeat(3, minmax(0,1fr)); }
}
@media (max-width: 900px){
  .gallery{ grid-template-columns: 1fr; }
}

.gallery-item{
  display:block;
  text-decoration:none;
  border-radius: var(--radius);
  overflow:hidden;
  background: rgba(255,255,255,.92); /* SOLID */
  border: 1px solid rgba(0,0,0,.10);
  box-shadow: var(--shadowSoft);
  transition: transform .18s var(--ease), border-color .18s var(--ease), background .18s var(--ease);
}
.gallery-item:hover{
  transform: translateY(-2px);
  border-color: rgba(var(--accent-rgb),.42);
  background: rgba(255,255,255,.98);
}

.gallery-item img{
  width: 100%;
  height: 240px;
  object-fit: cover;
  display:block;
}
@media (max-width: 720px){
  .gallery-item img{ height:190px; }
}

.gallery-meta{
  padding: .9rem .95rem;
  display:grid;
  gap:.25rem;
  color: rgba(var(--ink-rgb),.92);
}

.gallery-title{
  font-weight: 900;
  color: rgba(var(--ink-rgb),.96);
  line-height: 1.25;
}

.gallery-date{
  font-size: .9rem;
  color: rgba(var(--ink-rgb),.72);
}

/* PDF náhled (karta) */
.pdf-thumb{
  width: 100%;
  height: 240px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(255,255,255,.92); /* SOLID */
}

.pdf-badge{
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  padding:.55rem .85rem;
  border-radius: 999px;
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(var(--accent-rgb),.34);
  color: rgba(var(--accent-rgb), .98);
  font-weight: 900;
  letter-spacing: .02em;
  box-shadow: 0 10px 24px rgba(0,0,0,.14);
}
.pdf-badge span{
  color: rgba(var(--ink-rgb),.68);
  font-weight: 800;
}

/* Kontakt – varianta s více řádky */
.contact-item2{
  display:flex;
  align-items:flex-start;
  gap:1.6rem;
  line-height:1.4;
  color: rgba(255,255,255,.84);
}

.contact-item2 img{
  width:60px;
  height:60px;
  flex:0 0 auto;
  filter: var(--gold-filter);
  opacity:.98;
}

.contact-item2 span{ display:block; }

.contact-item2 a{
  display:block;
  margin-top:.15rem;
  text-decoration:none;
  color: rgba(255,255,255,.96);
  font-weight:900;
}
.contact-item2 a:hover{
  text-decoration:underline;
  color: var(--accent);
}
.contact-item2-body{ display:grid; gap:.25rem; }
/* =========================
   HERO: desktop centrování + H1 na 1 řádek
========================= */

/* Desktop: vše vycentrovat */
@media (min-width: 901px){
  .hero-inner{
    justify-content: center;      /* posune obsah doprostřed */
    text-align: center;
  }
  .hero-content{
    margin: 0 auto;
  }
  .hero-buttons{
    justify-content: center;
  }

  /* H1 na jeden řádek */
  .hero h1{
    white-space: nowrap;
    max-width: none;
  }
}

/* Mobile: menší odsazení od horní lišty */
@media (max-width: 900px){
  .hero-inner{
    padding-top: 6.2rem !important;   /* původně ~8.2rem */
    padding-bottom: 3rem;
  }
}
/* =========================
   HERO – přesné centrování (bez "hnutí")
========================= */

/* Desktop: hero obsah přesně do středu viewportu */
@media (min-width: 901px){
  .hero-inner{
    max-width: none !important;      /* zruší omezení na container */
    width: 100% !important;
    padding-left: 0 !important;       /* bez okrajů */
    padding-right: 0 !important;      /* bez okrajů */
    justify-content: center !important;
  }

  .hero-content{
    width: 100% !important;
    max-width: 1200px !important;     /* můžeš dát i 100% pokud chceš úplně bez omezení */
    margin: 0 auto !important;
    text-align: center !important;
  }

  .hero-eyebrow,
  .hero p{
    margin-left: auto !important;
    margin-right: auto !important;
    text-align: center !important;
  }

  .hero h1{
    margin-left: auto !important;
    margin-right: auto !important;
    text-align: center !important;

    /* 1 řádek na desktopu */
    white-space: nowrap !important;

    /* aby se vešlo lépe – jemně adaptivní */
    font-size: clamp(2.0rem, 3.6vw, 3.15rem) !important;
  }

  .hero-buttons{
    justify-content: center !important;
  }
}

/* Mobil: menší odsazení od horní lišty + text pořád na střed */
@media (max-width: 900px){
  .hero-inner{
    padding-top: 5.6rem !important;   /* menší než dřív */
    padding-left: 1rem !important;    /* na mobilu nechávám min. okraj kvůli čitelnosti */
    padding-right: 1rem !important;
  }

  .hero-content{
    text-align: center !important;
  }

  /* Na mobilu dovolíme zalomení (jinak by přetékal) */
  .hero h1{
    white-space: normal !important;
  }

  .hero-buttons{
    justify-content: center !important;
  }
}
.parte-gallery {
  text-align: center;
}

.parte-gallery .subtitle {
  margin-top: 0.5rem;   /* mezera pod nadpisem */
  font-size: 1.1rem;
}

/* =========================
   Kontakt formulář: consent + honeypot
========================= */
.contact-form .consent{
  display: flex;
  gap: .6rem;
  align-items: flex-start;
  font-size: .95rem;
  line-height: 1.35;
  margin: .85rem 0 .35rem;
}

.contact-form .consent input[type="checkbox"]{
  margin-top: .15rem;
}

.hp-field{
  position: absolute;
  left: -10000px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

/* =========================
   Cookie lišta
========================= */
.cookie-banner[hidden],
.cookie-modal[hidden]{
  display: none !important;
}

.cookie-banner{
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 9999;
  padding: 1rem;
  background: rgba(10,10,10,.86);
  backdrop-filter: blur(10px);
}

.cookie-banner__inner{
  max-width: 1150px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 1rem;
  align-items: center;
}

.cookie-banner__text{
  color: #fff;
  margin: 0;
  font-size: .95rem;
  line-height: 1.35;
}

.cookie-banner__text a{
  color: #fff;
  text-decoration: underline;
}

.cookie-banner__actions{
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  justify-content: flex-end;
}

@media (max-width: 720px){
  .cookie-banner__inner{
    grid-template-columns: 1fr;
  }
  .cookie-banner__actions{
    justify-content: flex-start;
  }
}

/* =========================
   Cookie modal
========================= */
.cookie-modal{
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: grid;
  place-items: center;
  padding: 1rem;
    color:#111;
}

.cookie-modal__overlay{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.6);
}

.cookie-modal__card{
  color:#111;
  position: relative;
  width: min(620px, 100%);
  background: #fff;
  border-radius: 18px;
  padding: 1.25rem 1.25rem 1.05rem;
  box-shadow: 0 20px 60px rgba(0,0,0,.35);
}

.cookie-modal__card h2{
  margin: 0 0 .5rem;
  
}

.cookie-setting{
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding: .85rem 0;
  border-bottom: 1px solid rgba(0,0,0,.08);
}

.cookie-setting:last-of-type{
  border-bottom: none;
}

.cookie-setting__fixed{
  font-weight: 700;
  white-space: nowrap;
}

.cookie-toggle{
  display: flex;
  gap: .6rem;
  align-items: center;
  font-weight: 600;
}

.cookie-modal__actions{
  display: flex;
  gap: .6rem;
  margin-top: 1rem;
  flex-wrap: wrap;
    color:#111;
}

body.is-modal-open{
  overflow: hidden;
}


/* Thank you page */
.thank-links{
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
  margin-top:1rem;
}
.thank-note{ margin-top:1rem; }
/* GDPR consent - user friendly */
.consent {
  margin-top: 14px;
  margin-bottom: 10px;
}

.consent__label {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  cursor: pointer;

  line-height: 1.45;
  font-size: 16px;
  color: #fff;

  /* jemný rámeček jako "box" */
  padding: 12px 14px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
}

.consent__label input[type="checkbox"] {
  width: 20px;
  height: 20px;
  margin-top: 2px; /* dorovnání na text */
  accent-color: #caa24a; /* sladění s buttonem */
  flex: 0 0 auto;
  cursor: pointer;
}

.consent__label a {
  color: #fff;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.consent__label a:hover {
  opacity: 0.85;
}
/* Aktualita popup */
.aktualita-overlay{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.55);
  display: grid;
  place-items: center;
  padding: 18px;
  z-index: 9999;
}

.aktualita-modal{
  width: min(560px, 100%);
  border-radius: 18px;
  padding: 18px 18px 16px;
  border: 1px solid rgba(200,168,91,.35);
  background: rgba(10,10,10,.92);
  box-shadow: 0 20px 70px rgba(0,0,0,.45);
}

.aktualita-title{
  margin: 0 0 10px;
  font-size: 20px;
}

.aktualita-body{
  white-space: pre-line;
  opacity: .95;
  line-height: 1.45;
  margin-bottom: 14px;
}

.aktualita-actions{
  display: flex;
  justify-content: flex-end;
}

