/*
 * Kombinovaný štýl pre skleniknapredaj.sk
 * Tento súbor spája všetky vlastné CSS úpravy do jedného súboru,
 * čím znižuje počet HTTP requestov. Obsahuje základný štýl,
 * vylepšenia (animované pozadie, fixný header), mobilné úpravy
 * a doplnkové prvky (toast notifikácia, bottom nav, dark mode, countdown).
 */

/* Import Google Fonts – vložené raz na začiatku */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;600;700&family=Open+Sans:wght@400;600&display=swap');

/* === Základné definície a štýly (z pôvodného sklenik_style.css) === */
:root {
  /* Základné farby webu – prispôsobte podľa vizuálnej identity */
  --primary-color: #77bb41;
  --secondary-color: #3b5e20;
  --accent-color: #f36722;
  --bg-light: #f7f9f4;
  --text-color: #2a2a2a;
  --heading-color: #1b3c10;
  --button-text: #ffffff;
  --button-bg: var(--primary-color);
  --button-bg-hover: #68a537;
  --border-radius: 8px;
  --transition: 0.3s ease;
}

/* Základné nastavenia */
body {
  font-family: 'Open Sans', Arial, sans-serif;
  color: var(--text-color);
  background-color: #ffffff;
  line-height: 1.6;
}

/* === HLAVIČKA A MENU === */
.header {
  background: #ffffff;
  border-bottom: 1px solid rgba(0,0,0,0.08);
  box-shadow: 0 4px 8px rgba(0,0,0,0.02);
}

.header .headerComponents {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 10px 0;
}

/* horizontálne menu */
#ce_menu ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 25px;
}

#ce_menu ul li a {
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  color: var(--heading-color);
  text-transform: uppercase;
  font-size: 0.9rem;
  letter-spacing: 0.5px;
  padding: 8px 12px;
  border-radius: var(--border-radius);
  transition: var(--transition);
  text-decoration: none;
}

#ce_menu ul li a:hover,
#ce_menu ul li a:focus {
  background-color: var(--primary-color);
  color: var(--button-text);
}

/* ikona košíka v hlavičke */
.shoppingCartIn {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  color: var(--heading-color);
  padding: 8px 12px;
  border-radius: var(--border-radius);
  transition: var(--transition);
}

.shoppingCartIn:hover {
  background-color: var(--primary-color);
  color: var(--button-text);
}

/* vyhľadávacie pole v hlavičke */
.txtbSearchProduct {
  border: 1px solid #ddd;
  border-radius: var(--border-radius);
  padding: 6px 12px;
  font-size: 0.9rem;
  width: 220px;
}

.txtbSearchButton {
  background-color: var(--primary-color);
  border: none;
  border-radius: var(--border-radius);
  padding: 8px 12px;
  color: var(--button-text);
  cursor: pointer;
  transition: var(--transition);
}

.txtbSearchButton:hover {
  background-color: var(--button-bg-hover);
}

/* bočný panel kategórií */
.pagePanel {
  background-color: var(--bg-light);
  padding: 20px;
  border-right: 1px solid rgba(0,0,0,0.05);
  font-size: 0.95rem;
}

.pagePanel .ce_category ul li a {
  display: block;
  padding: 8px 12px;
  color: var(--heading-color);
  font-weight: 500;
  transition: var(--transition);
  text-decoration: none;
}

.pagePanel .ce_category ul li a:hover {
  background-color: var(--primary-color);
  color: var(--button-text);
  border-radius: var(--border-radius);
}

/* === TYPOGRAFIA === */
h1, h2, h3, h4, h5 {
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  color: var(--heading-color);
  margin-top: 1.2em;
  margin-bottom: 0.5em;
  line-height: 1.2;
}

h1 { font-size: 2.5rem; }
h2 { font-size: 1.8rem; }
h3 { font-size: 1.4rem; }
h4 { font-size: 1.2rem; }
h5 { font-size: 1rem; }

p {
  font-size: 1rem;
  margin-bottom: 1em;
}

/* upravte farby textu v rôznych blokoch (napr. landing page) */
.landing-blok h1 {
  color: var(--secondary-color);
  font-weight: 700;
}

.landing-blok p {
  font-size: 1.1rem;
  color: var(--text-color);
}

/* === PRODUKTOVÉ KARTY NA HLAVNEJ STRÁNKE === */
.c-product {
  display: flex;
  flex-direction: column;
  background-color: #ffffff;
  border-radius: var(--border-radius);
  box-shadow: 0 4px 12px rgba(0,0,0,0.05);
  overflow: hidden;
  text-align: center;
  padding-bottom: 20px;
  transition: transform var(--transition), box-shadow var(--transition);
}

.c-product:hover {
  transform: translateY(-4px);
  box-shadow: 0 6px 16px rgba(0,0,0,0.07);
}

.c-product .p-img img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  display: block;
}

.c-product .p-subtitle {
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: 1.1rem;
  color: var(--heading-color);
  margin-top: 12px;
  min-height: 48px;
}

.c-product .p-tags {
  font-size: 0.75rem;
  display: flex;
  justify-content: center;
  gap: 6px;
  margin-top: 6px;
}

.c-product .p-tags span {
  padding: 2px 8px;
  border-radius: 4px;
  font-weight: 600;
}

.c-product .p-price {
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--secondary-color);
  margin-top: 8px;
}

.c-product .p-price .list-price {
  text-decoration: line-through;
  font-size: 0.9rem;
  color: #888;
  margin-left: 6px;
}

/* === VYLEPŠENÝ ŠTÝL Z advanced.css (bez vlastného menu) === */
/* Animované pozadie */
html {
  scroll-behavior: smooth;
}

body {
  font-family: 'Open Sans', Arial, sans-serif;
  color: var(--text-color);
  line-height: 1.6;
  margin: 0;
  padding: 0;
  background: linear-gradient(120deg, var(--bg-light), #ffffff, var(--bg-light));
  background-size: 200% 200%;
  animation: gradientMove 15s ease infinite;
  position: relative;
  overflow-x: hidden;
}

@keyframes gradientMove {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

/* Poletujúce lístky na pozadí */
body::before,
body::after {
  content: '';
  position: fixed;
  top: -10%;
  width: 64px;
  height: 64px;
  background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAJfUlEQVR4nO1aXYwkVRX+vnurumd6Z5dFnCWR6IOsf7NojEGDGNNoWpqVNTQ1pLVFeS2kArbA1mB8kWPd83V0dHSwC3BgYKbDNtQuCIQEQfrKqFuufO8vu/u8cvt4yRzJLnNzfefc7r7K0wMTExMTExMTExMTExMTExMQCk4hNUaGfpqida9N/p2loecMbISttUal0KaAFViT0pX4uSS+bhkhkU0oZxuL0RG7vSStJRksbl4KQ9p0KqTwNRZxC6qkOeUgrdTdtU91mz0ikZ2ei6DM1IMqMy0uWc6W0jdKukpWEkrOkKYSlLS16cHpclQkvZ8TrKJqmujQxxtY76sq/BIA3o2L3UJ4uE0dzjcQSbBRSZHlXFSyR3NafokpJvBJMam2VUZHfb4RE5OIZU0S5IFLPI5Msncwuwfo2AV7FLeSQ0HXHqzOvcR3htZfePeCM6y+8KyHWfx3MCl/G6K0H3lAxZ55Kskb0eYfBSVF7SgmkcV+DYkvZ8dxEkwjZ50pT4vjfpt9KfYQfd3C+pvtxI1EVFKdJGz5iNqsWS5AALz8Xk1zNsfs7IdR7cB6koVJOHXxRHSlYe21lY6iea0mpSOh1ZP52b0HiEAnxhw4L2PfF1zfk1LfnxTQK5XTBRoqhZIk2mOnMVlRRre+b0bi6gvR9ZVpRfyg43zTVnY5rpUR9tjsjnWkSoYRpq2XMkVp7UXSUsp9uYR+xZCvwxSUI7bja9M5J3kd2E6Z+gEmZeUpEJgHfwF/n+pxQPvHd6boRxy/Fiuw8mwHB3KknmmYIfHNBDKSGkWWnk8yJ5+pf8zv8e3zuPYHz1eZmPZtxVZWFpKT7uU/0CKRxaiGiWK6tHFevJizB6mmPZBvsekaxClVZpV681ElPU9M1iT/pxGeikvPIlUs9cSnsgedDv4gfZo0iW0pwXk/VnGsTmkyNDeTSX2W+z4uc1aRayipF3SlAkXFpXydv7cZJ0p7/hGgIoE4Ty5qBjEUKqsRB+skvZa6SMZG1TuirUQPqafW9EDaLGqUuasHlq+oyzHESvuMB9ZdhKORdxHxYkxsw0lbbpI/1YDDchwkgk9z3cUlabuBk/knFKZ8rZSEtnECK/WcuaxvLM5v73sy7KbORRZFasrT/FIfJtfGmwe0iX5ls68xeB73zKCNu0QppWkbpqmYE9XmdWGms4jf3nmILz4wm6vklDaUH5ew+Qkspn53K2+fmUxE2XPN8HZ8dNjWqYcFEc7GDt3H9DCDtkiXrDSUafc96e8A91QeqsE0lJpAeXcfW8KSwYG/fhHj5DY8fFFskjcGjv9XVPCk/Jnc3YWmlfeBTeCRnCKPJvJtPyjf33P1TpjUFS9Msa2WrL/IjHmV5Jy0c9PXGPlr8p3bdE/T1SI28DMwMTExMTExMTExMTExMTExN5pPfgD3UUyAO0mVEAAAAAElFTkSuQmCC');
  background-repeat: no-repeat;
  background-size: contain;
  opacity: 0.2;
  pointer-events: none;
  animation: leafFall 25s linear infinite;
}

body::after {
  left: 50%;
  animation-duration: 30s;
  animation-delay: 8s;
}

body::before {
  left: 20%;
  animation-duration: 35s;
  animation-delay: 2s;
}

@keyframes leafFall {
  0% { transform: translateX(-100vw) translateY(-10vh) rotate(0deg); }
  100% { transform: translateX(100vw) translateY(110vh) rotate(360deg); }
}

/* Fixný (plávajúci) header */
.header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: rgba(255,255,255,0.98);
  backdrop-filter: blur(4px);
  border-bottom: 1px solid rgba(0,0,0,0.08);
  box-shadow: 0 2px 6px rgba(0,0,0,0.05);
}

/* Štýl ikonky hamburgeru (bez vlastného menu) */
#responsive_menu_main_trg {
  width: 28px;
  height: 21px;
  cursor: pointer;
  position: relative;
  display: inline-block;
}

#responsive_menu_main_trg::before,
#responsive_menu_main_trg::after,
#responsive_menu_main_trg span {
  content: '';
  position: absolute;
  left: 0;
  width: 100%;
  height: 3px;
  background-color: var(--heading-color);
  transition: transform var(--transition), opacity var(--transition);
}

#responsive_menu_main_trg span { top: 9px; }
#responsive_menu_main_trg::before { top: 0; }
#responsive_menu_main_trg::after { bottom: 0; }

/* === PRO mobilné úpravy (z sklenik_style_pro.css) === */
@media (max-width: 768px) {
  /* bočný panel skryjeme, ale menu ponecháme viditeľné, aby sa zobrazovala
     pôvodná navigácia ClickEshopu aj v mobilnom zobrazení */
  /* .pagePanel { display: none; } */

  .header .headerComponents {
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 10px;
    padding-bottom: 8px;
  }

  /* Poradie elementov v hlavičke na mobiloch */
  #responsive_menu_main_trg { order: 1; }
  #shoppingCart { order: 2; }
  #loginUser { order: 3; }
  #productSearchOut { order: 4; flex: 1 1 100%; margin-top: 8px; }

  /* Full‑width vyhľadávacie pole na mobiloch */
  .txtbSearchProduct {
    width: 100%;
  }
}

@media (max-width: 768px) {
  .c-product {
    max-width: 100%;
  }
  .pageTitleSubFrame {
    flex-direction: column;
  }
}

/* Štýl pre tlačidlo Späť hore */
#backToTop {
  position: fixed;
  bottom: 30px;
  right: 30px;
  width: 44px;
  height: 44px;
  background-color: var(--primary-color);
  color: var(--button-text);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  cursor: pointer;
  box-shadow: 0 4px 8px rgba(0,0,0,0.2);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease;
  z-index: 999;
}

#backToTop.show {
  opacity: 1;
  visibility: visible;
}

@media (max-width: 768px) {
  #mainPanel {
    position: relative;
  }
  #responsive_menu_main_trg {
    position: absolute;
    top: 15px;
    right: 15px;
    z-index: 1001;
  }
}

/* === EXTRAS: toast, bottom nav, formuláre, dark mode, countdown === */
/* Toast notifikácia */
.toast-notification {
  position: fixed;
  bottom: 80px;
  right: 20px;
  background-color: var(--secondary-color);
  color: #fff;
  padding: 14px 20px;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  z-index: 1000;
  font-size: 0.9rem;
}

.toast-notification.show {
  opacity: 1;
  visibility: visible;
}

/* Spodná navigácia pre mobilné zariadenia */
.bottom-nav {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  background-color: #ffffff;
  border-top: 1px solid #e0e0e0;
  display: none;
  padding: 8px 0;
  z-index: 1000;
  box-shadow: 0 -2px 6px rgba(0,0,0,0.05);
}

.bottom-nav a {
  flex: 1;
  text-align: center;
  color: var(--heading-color);
  text-decoration: none;
  font-size: 0.9rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 6px 0;
  transition: color 0.2s ease;
}

.bottom-nav a span {
  font-size: 1.3rem;
  margin-bottom: 2px;
}

.bottom-nav a:hover {
  color: var(--primary-color);
}

@media (max-width: 768px) {
  .bottom-nav { display: flex; }
}

/* Vylepšené formuláre */
.form-label {
  display: block;
  font-weight: 600;
  margin-bottom: 4px;
  color: var(--heading-color);
  font-size: 0.95rem;
}

.form-control {
  display: block;
  width: 100%;
  padding: 12px 16px;
  border: 1px solid #ddd;
  border-radius: 6px;
  font-size: 1rem;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  color: var(--text-color);
  background-color: #fff;
}

.form-control:focus {
  border-color: var(--primary-color);
  box-shadow: 0 0 0 3px rgba(119,187,65,0.2);
  outline: none;
}

/* Tmavý režim */
.dark {
  --bg-light: #1a1a1a;
  --text-color: #e2e2e2;
  --heading-color: #f5f5f5;
  --primary-color: #77bb41;
  --secondary-color: #3b5e20;
  --accent-color: #ffae42;
}

.dark body {
  background-color: var(--bg-light);
  color: var(--text-color);
}

.dark .c-product {
  background-color: #2a2a2a;
  box-shadow: 0 4px 12px rgba(0,0,0,0.3);
}

.dark .pagePanel {
  background-color: #2a2a2a;
}

.dark .bottom-nav {
  background-color: #2a2a2a;
  border-top-color: #444;
}

.dark .bottom-nav a {
  color: var(--text-color);
}

.dark .bottom-nav a:hover {
  color: var(--primary-color);
}

/* Countdown timer – jednoduché zarovnanie */
.countdown-timer {
  font-family: 'Montserrat', sans-serif;
  display: inline-flex;
  gap: 4px;
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--accent-color);
}

.countdown-timer span {
  min-width: 20px;
  text-align: center;
}