/* =========================================
   REPOSE ETERNAL - LUXURY STYLE SHEET
   ========================================= */

/* 1. RESET A ZÁKLADNÍ NASTAVENÍ */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box; /* Klíčové pro správné počítání šířky */
}

body {
  font-family: 'Proza Libre', sans-serif;
  color: #e0e0e0;
  background-color: #0a0a0a;

  /* 1. Nastavíme minimální výšku okna */
  min-height: 100vh;

  /* 2. Flexbox pro centrování */
  display: flex;
  flex-direction: column; /* Důležité pro margin: auto */

  /* 3. TOTO JE TA ZMĚNA: */
  /* Místo align-items/justify-content použijeme padding */
  /* To zajistí, že nahoře a dole bude VŽDY minimálně 80px místa */
  padding: 10vh 0;

  /* Posuvníky */
  overflow-y: scroll;
  overflow-x: hidden;
  position: relative;

  overscroll-behavior-y: none;
}

body::before {
  content: '';
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;

  /* TOTO JE TA OPRAVA: */
  height: 100vh; /* Záloha pro staré mobily */
  height: 100svh; /* "Smallest Viewport Height" - Ignoruje mizející lištu */

  background-image: url('background.jpg');
  background-size: cover;
  background-position: center;
  z-index: -1;

  /* Hardwarová akcelerace - pomůže proti "škubání" */
  will-change: transform;
  transform: translateZ(0);
}

/* 2. POZADÍ (FIXED) 
   Odděleno od body, aby se "nepřibližovalo" při změně velikosti okna */
body::before {
  content: '';
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url('background.webp');
  background-size: cover;
  background-position: center;
  z-index: -1;
}

/* 3. OVERLAY (GRADIENT)
   Ztmavuje spodek stránky pro lepší čitelnost textu */
.overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  /* Nahoře průhledné (vidět urna), dole tmavé (čtivý text) */
  background: linear-gradient(
    to bottom,
    rgba(0, 0, 0, 0.1) 0%,
    rgba(0, 0, 0, 0.4) 40%,
    rgba(0, 0, 0, 0.95) 100%
  );
  z-index: 0;
}

/* 4. HLAVNÍ OBSAHOVÝ BOX (RÁMEČEK) */
.content {
  position: relative;
  z-index: 1;
  max-width: 900px;
  width: 90%;
  padding: 60px 40px;
  text-align: center;

  /* TOTO JE TA ZMĚNA: */
  /* margin: auto zajistí vertikální centrování ve zbylém prostoru */
  margin: auto;

  background: rgba(0, 0, 0, 0.2);
  border: 1px solid rgba(212, 175, 55, 0.4);
  text-shadow: 0 4px 30px rgba(0, 0, 0, 1);
  transition: all 0.6s cubic-bezier(0.25, 1, 0.5, 1);
}

/* =========================================
   TYPOGRAFIE
   ========================================= */

h1.brand-name {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 300;
  font-size: 4rem;
  letter-spacing: 2px;
  color: #d4af37;
  text-transform: uppercase;
  margin-bottom: 15px;
  line-height: 1.1;
}

.tagline {
  font-size: 0.9rem;
  color: #ccc;
  text-transform: uppercase;
  letter-spacing: 3px;
  margin-bottom: 40px;
  opacity: 0.8;
}

.divider {
  width: 60px;
  height: 1px;
  background: #d4af37;
  margin: 0 auto 40px auto;
  opacity: 0.5;
}

.text-block {
  margin-bottom: 40px;
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
}

h2 {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 300;
  font-size: 2rem;
  line-height: 1.4;
  color: #eee;
  margin-bottom: 30px;
}

.main-desc {
  font-size: 1.1rem;
  line-height: 1.8;
  color: #bbb;
  font-weight: 300;
}

/* Styl pro zalomené telefonní číslo */
.phone-block {
  display: block;
  margin-top: 5px;

  /* ZMĚNA: Zlatá barva natrvalo */
  color: #d4af37;

  text-decoration: none;

  /* ZMĚNA: Menší písmo (bylo 1rem) */
  font-size: 0.9rem;

  letter-spacing: 1px;
}

/* Pojistka: Aby barva zůstala zlatá i po kliknutí, při najetí, nebo když už byl odkaz navštíven */
.phone-block:hover,
.phone-block:visited,
.phone-block:active,
.phone-block:focus {
  color: #d4af37;
  text-decoration: none;
  cursor: default; /* Volitelné: Pokud chceš, aby to ani nevypadalo jako klikací (kurzor se nezmění na ručičku), dej sem 'default'. Jinak tento řádek smaž. */
}

/* =========================================
   CTA KONTEJNER A ANIMACE
   ========================================= */

.cta-container {
  min-height: 60px; /* Drží výšku, aby box neposkočil */
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  transition: all 0.5s ease;
}

/* Wrapper pro TLAČÍTKO */
.btn-wrapper {
  width: 100%;
  display: flex;
  justify-content: center;

  /* Animace */
  max-height: 100px;
  opacity: 1;
  overflow: hidden;
  transition: max-height 0.4s ease, opacity 0.3s ease;
}

.btn-wrapper.hidden {
  max-height: 0;
  opacity: 0;
}

/* Wrapper pro FORMULÁŘ */
.form-wrapper {
  width: 100%;

  /* Animace */
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height 0.8s cubic-bezier(0.25, 1, 0.5, 1), opacity 0.5s ease;
}

.form-wrapper.open {
  max-height: 700px; /* Dostatek místa pro formulář i chybové hlášky */
  opacity: 1;
  margin-top: 20px;
}

/* =========================================
   TLAČÍTKA A FORMULÁŘ (SJEDNOCENÉ ŠÍŘKY)
   ========================================= */

/* Společný styl pro tlačítka */
.btn-gold,
.btn-submit {
  display: block; /* Aby fungovala šířka */
  width: 100%;
  max-width: 360px; /* Pevná šířka sloupce */

  padding: 15px 0; /* Padding jen nahoře/dole, šířka je dána width */
  border: 1px solid #d4af37;
  background: transparent;
  color: #d4af37;
  text-transform: uppercase;
  letter-spacing: 2px;
  font-size: 0.9rem;
  font-family: 'Proza Libre', sans-serif;
  transition: all 0.4s ease;
  cursor: pointer;
  text-align: center;
}

.btn-gold:hover,
.btn-submit:hover {
  background: rgba(212, 175, 55, 0.15);
  color: #fff;
  border-color: #fff;
}

/* Styl formuláře */
#contactForm {
  position: relative;
  width: 100%;
  max-width: 360px; /* Stejná šířka jako tlačítko */
  margin: 0 auto; /* Centrování */
  text-align: center;
  padding-top: 20px;
}

.form-group {
  margin-bottom: 15px;
  width: 100%;
}

/* Inputy */
input,
textarea {
  width: 100%;
  padding: 12px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(212, 175, 55, 0.3);
  color: #fff;
  font-family: 'Proza Libre', sans-serif;
  font-size: 0.9rem;
  box-sizing: border-box; /* Padding nerozhodí šířku */
}

textarea {
  resize: vertical; /* Povolí tahat jen dolů, ne do stran */
  min-height: 80px; /* (Volitelné) Aby to nešlo smrsknout na úplnou nudli */
  max-height: 300px; /* (Volitelné) Aby to neroztáhli přes celou obrazovku */
}

input:focus,
textarea:focus {
  outline: none;
  border-color: #d4af37;
  background: rgba(255, 255, 255, 0.1);
}

/* Křížek pro zavření */
.close-btn {
  position: absolute;
  top: -15px;
  right: 0;
  font-size: 2rem;
  color: #d4af37;
  cursor: pointer;
  line-height: 1;
  transition: color 0.3s ease;
  z-index: 10;
}

.close-btn:hover {
  color: #fff;
}

.status-msg {
  margin-top: 15px;
  font-size: 0.9rem;
  min-height: 1.2em; /* Rezervace místa pro zprávu */
}

/* =========================================
   PATIČKA A RESPONSIVITA
   ========================================= */

footer {
  margin-top: 60px;
  font-size: 0.8rem;
  color: #666;
  letter-spacing: 1px;
}

footer p {
  margin-bottom: 10px;
}

@media (max-width: 600px) {
  body {
    padding: 3vh 0;
  }

  .content {
    width: 85%;
    padding: 40px 20px;
    margin: 20px auto;
  }

  h1.brand-name {
    font-size: 2.5rem;
  }

  h2 {
    font-size: 1.2rem;
  }

  /* Na mobilu zvětšíme inputy pro pohodlné psaní */
  input,
  textarea {
    font-size: 16px; /* Zabraňuje zoomování na iPhonech */
    padding: 15px;
  }
}

/* --- Validace formuláře (OPRAVENO) --- */

.form-group {
  margin-bottom: 20px; /* Zvětšíme mezeru mezi poli, aby se tam chyba vešla */
  text-align: left; /* Zarovnáme obsah (chyby) doleva */
  position: relative;
}

/* Třída pro pole s chybou */
.input-error {
  border-color: #e08e51 !important;
  background: rgba(255, 77, 77, 0.05) !important;
}

/* Text chybové hlášky pod polem */
.field-error-msg {
  display: none;
  color: #e08e51;
  font-size: 0.75rem;

  /* OPRAVA ZAROVNÁNÍ */
  margin-top: 6px; /* Dáme mezeru OD rámečku dolů (žádné mínusy) */
  margin-bottom: 0;
  padding-left: 14px; /* Odstup zleva stejný jako padding v inputu (aby to lícovalo s textem) */

  letter-spacing: 0.5px;
  font-weight: 600; /* Trochu tučnější, aby byla čitelná */
}

.field-error-msg.active {
  display: block;
  animation: fadeIn 0.3s ease; /* Jemná animace objevení */
}

/* Bonus: Animace pro hezčí zobrazení chyby */
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(-5px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* =========================================
   LUXUSNÍ POSUVNÍK (SCROLLBAR)
   ========================================= */

/* 1. Pro Firefox (Nový standard) */
html {
  scrollbar-width: thin; /* Tenký posuvník */
  scrollbar-color: #d4af37 #0a0a0a; /* Zlatý jezdec, černé pozadí */
}

/* 2. Pro Chrome, Edge, Safari (Webkit) */

/* Celková šířka posuvníku */
::-webkit-scrollbar {
  width: 10px; /* Decentní šířka */
}

/* "Koleje" (Pozadí posuvníku) */
::-webkit-scrollbar-track {
  background: #0a0a0a; /* Splyne s pozadím stránky */
}

/* "Jezdec" (To, čím posouváš) */
::-webkit-scrollbar-thumb {
  background-color: #d4af37; /* Zlatá barva */
  border-radius: 10px; /* Zaoblené rohy */
  border: 3px solid #0a0a0a; /* Trik: Černý rámeček kolem zlaté ji opticky ztenčí */
}

/* Jezdec při najetí myší */
::-webkit-scrollbar-thumb:hover {
  background-color: #fff; /* Při aktivním používání se rozsvítí (volitelné) */
}

/* =========================================
   FIX: ODSTRANĚNÍ ŠEDÉHO POZADÍ PŘI AUTOCOMPLETE
   ========================================= */

/* Cílíme na stav, kdy Chrome vyplnil data */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
textarea:-webkit-autofill,
textarea:-webkit-autofill:hover,
textarea:-webkit-autofill:focus {
  /* 1. Barva textu */
  /* Musíme použít tento speciální prefix, color: #fff často nefunguje */
  -webkit-text-fill-color: #fff;

  /* 2. Barva pozadí (Trik s přechodem) */
  /* Nastavíme přechod (transition) na background-color s obrovským zpožděním.
       Prohlížeč čeká 99999 sekund, než tam tu šedou barvu vloží. */
  transition: background-color 5000s ease-in-out 0s;

  /* Ujistíme se, že i ohraničení zůstane naše */
  border: 1px solid rgba(212, 175, 55, 0.3);

  /* Zachování fontu (někdy ho Chrome resetuje) */
  font-family: 'Proza Libre', sans-serif;
  font-size: 0.9rem;
}
