@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700;800&display=swap");

* {
  /* ==========================================================================
     HUE JADRO - Odvodené z tvojho nočného pozadia rgb(15, 23, 42) = slate-900
     ========================================================================== */
  --app-width: 1500px;   
  --base-hue: 222;        
  --brand-saturation: 47%; 

  --neutral-100-light: hsl(0 0 95%);
  --neutral-100-dark: hsl(0 0 5%);

  /* --- SVETLÝ MÓD (Light) - Inšpirované Tailwind Slate --- */
  --accent:       hsl(25 95% 53%);       /* Oranžová rgb(249, 115, 22) */
  /* --accent-hover-light: hsl(25 95% 43%);   */
  --accent-hover: hsl(21, 90%, 48%);     
  
  /* TAILWIND slate-900 (Presne tvoja milovaná rgb(15, 23, 42)) */ 
  --text-main-light:   hsl(var(--base-hue) var(--brand-saturation) 11%); 
  
  /* TAILWIND slate-500 (Perfektne čitateľná šedá na bielom podklade) */
  --text-muted-light:  hsl(var(--base-hue) 16% 46%); 
  
  --bg-page-light:     hsl(var(--base-hue) 25% 98%);  /* slate-50 alternatíva pre dno */
  --bg-card-light:     hsl(0 0% 100%);                 /* Čistá biela */
  --border-light:      hsl(var(--base-hue) 20% 92%);  /* slate-200 alternatíva */
  
  /* TAILWIND slate-50 (Jemný, prémiový odtieň bielej došiva: #f8fafc) */
  --text-main-dark:    hsl(var(--base-hue) 30% 98%);  
  
  /* TAILWIND slate-300 (Presne tvoja zvolená farba #cbd5e1) */
  --text-muted-dark:   hsl(var(--base-hue) 32% 85%);  

  --hero-bg: var(--text-main-light);
  --blue-blob: #2563eb;
  --hero-paragraph: #cbd5e1;

  --btn-text-light: #475569;
  --btn-text-dark: #94a3b8;
  --links-text: var(--text-muted);

  /* Tvoje nočné pozadie rgb(15, 23, 42) = slate-900 */
  --bg-page-dark:      hsl(var(--base-hue) var(--brand-saturation) 11%); 
  --bg-card-dark:      hsl(var(--base-hue) var(--brand-saturation) 16%); /* slate-800 alternatíva */
  --border-dark:       hsl(var(--base-hue) var(--brand-saturation) 22%); /* slate-700 alternatíva */

  --space-2xs: clamp(0.5rem, 0.4831rem + 0.0847vw, 0.5625rem);
  --space-xs: clamp(0.75rem, 0.7161rem + 0.1695vw, 0.875rem);
  --space-s: clamp(1rem, 0.9661rem + 0.1695vw, 1.125rem);
  --space-m: clamp(1.5rem, 1.4492rem + 0.2542vw, 1.6875rem);
  --space-l: clamp(2rem, 1.9322rem + 0.339vw, 2.25rem);
  --space-xl: clamp(3rem, 2.8983rem + 0.5085vw, 3.375rem);
  --space-m-xl: clamp(1.5rem, 0.9915rem + 2.5424vw, 3.375rem);
  --space-mega: clamp(6rem, 4.5763rem + 7.1186vw, 11.25rem);

  --size-step-2: clamp(1.2656rem, 1.0692rem + 0.9822vw, 1.99rem);

}

:root {
  /* PREDVOLENÉ NASTAVENIE (Svetlý mód) */
  color-scheme: light;
  
  --text:        var(--text-main-light);
  --btn-text:    var(--btn-text-light);
  --text-muted:  var(--text-muted-light);
  --bg-page:     var(--bg-page-light);
  --bg-card:     var(--bg-card-light);
  --border:      var(--border-light);
  --neutral:     var(--neutral-100-light);

  /* FIXNÉ SYSTÉMOVÉ FARBY (Nemenia sa pri zmene témy ani Hue) */
  --color-discount: #ef4444; /* Agresívna červená pre percentá a ceny v akcii */
  --color-success:  #22c55e; /* Zelená pre skladovosť / overené obchody */
  --color-sucess-light: #dcfce7;
  --accent-border: #fdba74;
  --color-sucess-dark: #166534;

  /* GLOBÁLNE UTILITY */
  --radius-button:  0.75rem; /* 12px */
  --radius-card:    1.25rem; /* 20px */
  --transition:     all 0.2s ease;
  
  font-size: 14px;
}

/* RESPONSIVE SCALING - Zväčšenie textu a mierky na desktopoch */
@media (min-width: 768px)  { :root { font-size: 15px; } }
@media (min-width: 1280px) { :root { font-size: 16px; } }

/* AUTOMATICKÝ DARK MODE (Podľa nastavenia v telefóne/PC) */
@media (prefers-color-scheme: dark) {
  :root {
    color-scheme: dark;
    --text:       var(--text-main-dark);
    --btn-text:   var(--btn-text-dark);
    --text-muted: var(--text-muted-dark);
    --bg-page:    var(--bg-page-dark);
    --bg-card:    var(--bg-card-dark);
    --border:     var(--border-dark);
    --neutral:    var(--neutral-100-dark);
  }
}

/* MANUÁLNY DARK MODE (Keď na body pridáš .dark triedu cez JS prepínač) */
body.dark {
    color-scheme: dark;
    --text:       var(--text-main-dark);
    --btn-text:   var(--btn-text-dark);
    --text-muted: var(--text-muted-dark);
    --bg-page:    var(--bg-page-dark);
    --bg-card:    var(--bg-card-dark);
    --border:     var(--border-dark);
    --neutral:    var(--neutral-100-dark);
}

body.light {
    color-scheme: light;
    --text:        var(--text-main-light);
    --btn-text:    var(--btn-text-light);
    --text-muted:  var(--text-muted-light);
    --bg-page:     var(--bg-page-light);
    --bg-card:     var(--bg-card-light);
    --border:      var(--border-light);
    --neutral:    var(--neutral-100-light);
}

/* GLOBÁLNY RESET */
* { font-family: "Inter", sans-serif; }

body {
  font-family: "Inter", sans-serif;
  background-color: var(--bg-page, white);
  color: var(--text);
  margin: 0;
  transition: background-color var(--transition), color var(--transition);
}

/*******************/
/* utils section */
/*******************/
* { box-sizing: border-box; margin: 0; padding: 0;}

*:focus-visible {
  outline: 2px solid #4d90fe;
  outline-offset: 2px;
}

@view-transition { navigation: auto; }

.text-6xl { font-size: 3rem;}
.text-2xl { font-size: 1.5rem; font-weight: 900; line-height: 2rem; }


.blured { backdrop-filter: blur(12px); }
.backdrop-blur-md { background-color: rgba(from var(--bg-page) r g b / 0.8); backdrop-filter: blur(12px); }
.z-50 { z-index: 50; position: sticky; top: 0; }
.hwrap { padding-inline: var(--base-padding, 0.5rem); }
.btn { display: flex; color: var(--text); background: transparent; border: 1px solid transparent; cursor: pointer; border-radius: .75rem;
  &:hover { color: var(--accent-hover); border-color: var(--accent-border); }
  &:disabled { opacity: 0.6; }
}
.icon-btn:hover:not(:disabled) {
    border-color: var(--accent);
}
.icon-btn {display: inline-flex;align-items: center; justify-content: center; gap: 8px; padding: 0.5rem 0.75rem; border-radius: 0.25rem; 
  border: 1px solid var(--border); background-color: var(--bg-card-light); color: var(--text);font-size: 0.875rem;font-weight: 500; text-transform: uppercase; 
  letter-spacing: 0.5px; cursor: pointer; transition: all 0.2s ease; position: relative; overflow: hidden;
}
h2 { font-size: var(--size-step-2); }

.btn.primary { padding: var(--space-2xs) var(--space-xs); border: 1px solid var(--border); padding: var(--space-2xs) var(--space-xs); background-color: var(--text); color: contrast-color(var(--text));
 &:hover { border-color: var(--accent-hover); background-color: color-mix(in srgb, var(--text), var(--neutral) 20%); }
}
.btn.primary.inverted { background-color: contrast-color(var(--text)); color: var(--text); 
  background-color: color-mix(in srgb, contrast-color(var(--text)), var(--neutral) 20%);
}
.shadow-sm { box-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);  }

svg {stroke-width: 0px; }
.icon { width: 1.5rem; height: 1.5rem; }
.text-brand-500 { color: var(--accent); }
.tight { letter-spacing: -0.025rem; }
.extra-bold { font-weight: 800; }
.left { left: -1.5rem;}
.right { right: -1.5rem;}
.rounded { border-radius: 9999px; }
img { max-width: 100%; height: auto; display: block; object-fit: contain; }
.trim { display: -webkit-box; -webkit-line-clamp: var(--trim-lines, 2); -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis;}
.tighter { letter-spacing: -0.05em; }
/* .text-2xl { line-height: 2rem; } */

ol, ul { list-style-type: none;}

.icon-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 0.5rem 0.75rem; border-radius: 0.25rem;
  border: 1px solid var(--border); background-color: var(--bg-card); color: var(--text);
  font-size: 0.875rem; font-weight: 500; text-transform: uppercase; letter-spacing: 0.5px; cursor: pointer; transition: all 0.2s ease; position: relative; overflow: hidden; }
.btnc { cursor: pointer; border: none; background: transparent; transition: transform var(--speed) var(--anim); color: inherit; }

.close-btn { position: relative; background: var(--accent); border: none; color: var(--text); width: 32px; height: 32px; top: auto; right: auto; aspect-ratio: 1 / 1; border-radius: 50%; cursor: pointer; transition: transform 0.3s ease;
  &::after, &::before { content: ""; position: absolute; top: 50%; left: 50%; width: 20px; height: 2px; background: currentColor; width: 14px; }
  &::after { transform: translate(-50%, -50%) rotate(-45deg); }
  &::before { transform: translate(-50%, -50%) rotate(45deg); }
}
.close-btn:hover { background-color: var(--accent-hover); transform: rotate(90deg); }
/*******************/
/* header section */
/*******************/
.maxw { max-width: var(--app-width); margin-inline: auto; }
.maxw-wider { max-width: calc(var(--app-width) + 15rem); margin-inline: auto; }
header { background-color: var(--bg-page); }
.header-wrapper { border-bottom: 1px solid var(--border); }
.header { display: grid; grid-template-areas: "logo buttons" " search search "; grid-template-columns: auto 1fr; grid-gap: var(--space-xs); 
 padding-block: var(--space-xs, 0.5rem);}
.search-wrapper { grid-area: search; }
.profile-wrapper {grid-area: buttons; align-content: center; align-items: center; justify-content: flex-end;
  .title { display: none; }
  .btn { padding: var(--space-xs); }
}
.menu-wrapper { grid-area: logo; }


.menu-row, .logo, .search {display: flex; }
.logo { margin-inline-start: 1rem; }
.menu-btn .icon { width: 2.5rem; height: 2.5rem; }
.menu-btn:hover { border: 1px solid transparent; }
.logo svg {width: 17rem; margin-bottom: 8px; }
.menu { display: flex; align-items: center; }

.menu-header h2 svg { width: 90%; }

.search-wrapper {
    display: flex;
    flex-direction: column;
    width: 100%;
    min-width: 100px;
    order: 3;
    justify-content: center;
}

/* Pomocná animácia */
@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.search-results {
  position: absolute;
    top: 0;
    left: 0;
    right: 0;
    background-color: var(--bg-card);
    border-top: none;
    border-radius: 0 0 16px 16px;
    box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1);
    overflow: hidden;
    max-height: 400px;
    overflow-y: auto;
    animation: slideDown 0.2s ease-out;
        width: 70%;
    display: flex;
    flex-direction: column;
    margin-inline: auto;
    padding-inline: 4px;
}
.has-results .search-results {
  border: 1px solid var(--accent);
  border-top: 0px;
}

.search-wrapper {
  &.has-results .search {
    border-radius: 16px 16px 0px 0px;
    border: 1px solid var(--accent);
  }
}
.result-wrapper {
  position: relative;
    width: 100%;
    z-index: var(--menu-idx);
}
.suggest {
    text-decoration: none;
    background-color: var(--bg-card);
    padding: 1rem 1rem;
    color: var(--text);
    transition: all 0.2s ease;
    /* border-bottom: 1px solid var(--accent); */
    &:hover {
      background-color: rgb(var(--border) / 1);
      color: var(--accent-hover);
      padding-left: 1.5rem;
    }
    mark {
      font-weight: bold;
      background-color: transparent;
      color: var(--accent);
    }
  }
  
.search {position: relative; display: flex; align-items: center; width: 100%; margin-inline: auto; background-color: var(--border); border: 1px solid transparent; border-radius: 16px; padding: .25rem; transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); 
  &:focus-within { border-color: var(--accent); }
}
.inputbox, .search-wrapper input { flex: 1; border: none; padding: 0.5rem 0.75rem; font-size: 1rem; background-color: transparent; color: var(--text); outline: none; font-weight: 500;}
.search .btn { background: var(--border); border-radius: .75rem; width: 3.5rem; height: 100%; margin-right: .25rem;
  display: flex; align-items: center; justify-content: center; color: var(--text);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); 
  &:hover { background-color: var(--accent-hover); color: white; }
  .icon { width: 1.5rem; height: 1.5rem; }
}

.has-results .search-results { width: 100%; }

@media (min-width: 768px)  {
 .header { grid-template-areas: "logo search buttons"; grid-template-columns: auto 1fr auto;}
 .search { width: 70%; }
 .has-results .search-results { width: 70%; }
}


/*******************/
/* hero section */
/*******************/
.hero-section { position: relative; color: contrast-color(var(--text-main-light)); background-color: var(--text-main-light); padding: 4rem 1rem; text-align: center; overflow: hidden;
 h1 { font-size: 3.75rem; letter-spacing: -0.025em; line-height: 1.2; margin-bottom: 1.5rem; font-weight: 800;}
 p { font-size: 1.25rem; color: var(--hero-paragraph); max-width: 42rem; margin: 0 auto;}
}
.sun {position: absolute; border-radius: 9999px; filter: blur(80px); opacity: 0.2; z-index: 1;}
.sun.top-right { top: -5rem; right: -5rem; width: 24rem; height: 24rem; background-color: var(--accent);  animation: pulse 4s infinite ease-in-out; }
.sun.bottom-left.blue { bottom: -5rem; left: -5rem; width: 20rem; height: 20rem; background-color: var(--blue-blob); }
.hero-section { padding: 6rem 1rem; }

/* intex tags scrollable */
.main-sections { padding-inline: var(--space-l);  border-bottom: 1px solid var(--border); border-top: 1px solid var(--border);
  .scroll-container { margin-inline-end: var(--space-2xs); padding-bottom: 0rem;}
}
.scroll-container { overflow-x: auto; scrollbar-width: thin; scrollbar-color: var(--text) var(--bg-page); }
.rollable-container { position: relative; }
.section-categories { display: inline-flex; padding: var(--space-2xs); gap: var(--space-m); font-size: 0.875rem; font-weight: 600; color: #475569;
  .btn { display: inline-flex; align-items: center; flex-shrink: 0; border-color: var(--border); color: var(--btn-text); padding: var(--space-2xs) var(--space-s); display: flex; gap: var(--space-2xs); 
    &:hover {border-color: var(--accent-border); color: var(--accent-hover); } 
    &:last-child {margin-inline-end: 1rem; }
  }
  svg { width: var(--space-m); height: var(--space-m); stroke: currentColor; }
}


/* .scroll-btn { position: absolute; top: 50%; transform: translateY(-50%); width: 3rem; height: 3rem; border-radius: 50%; background-color: contrast-color( var(--bg-page) );
  border: 1px solid var(--border); color: contrast-color( var(--text) ); z-index: 30; cursor: pointer; box-shadow: 0 4px 12px rgba(var(--surface-shadow), 0.2); transition: all 0.2s;
  svg { width: 1.5rem; height: 1.5rem; stroke: currentColor; }
} */

/* main sections */
.main-content { padding-inline: var(--space-l); padding-block-start: var(--space-xs); }
.wrapped {  max-width: var(--app-width, 1200px); margin-inline: auto; }
.wrapped-wider {  max-width: calc(var(--app-width, 1200px) + var(--space-mega)); margin-inline: auto; }

.section-title { display: flex; margin-block-end: 1.5rem; }
.title-symbol { display: flex; align-items: center; gap: var(--space-s);
  .section-icon { display: flex; padding: var(--space-xs); background-color: rgb(255 237 213); border-radius: .75rem; color: var(--accent-hover); }
  .icon { width: var(--size-step-2); height: var(--size-step-2);}
}

.show-all { margin-left: auto; font-weight: 600; font-size: 0.875rem; line-height: 1.25rem; color: var(--accent); display: flex; gap: 0.5rem; align-items: center;
}

/* horizontal scroll index */
.similar-grid { display: grid; grid-auto-flow: column; grid-auto-columns: 16rem; gap: 1.5rem; }

/* grid items */
.item {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  background-color: var(--bg-card);
  color: var(--text);

  &:hover { color: var(--accent); }

  .img-wrapper { position: relative;}
  .discount-badge { position: absolute; top: 0.5rem; left: 0.5rem; font-size: 0.75rem; padding: 0.25rem 0.75rem; border-radius: .5rem;
    font-weight: 800;  background-color: var(--color-discount); color: white; box-shadow: 0 4px 10px rgba(220, 38, 38, 0.3); 
    &:after {content: '%'; }
  }
  .placeholder { position: absolute; bottom: 0.5rem; right: 0.5rem; font-size: 0.7rem; padding: 0.25rem 0.5rem; 
    background-color: var(--bg-card); color: var(--text); border-radius: 1rem;}

  .content-wrapper { padding: 1.25rem; flex-grow: 1
    ; display: flex; flex-direction: column; gap: 0.5rem;}

  .brand-line { display: flex; justify-content: space-between; align-items: center; }
  .brand, .eshop { font-size: 0.75rem; color: var(--accent); font-weight: 800; text-transform: uppercase; letter-spacing: 0.1em;}
  .eshop { font-weight: 600; padding: 0.125rem 0.5rem; background-color: var(--bg-page); color: var(--text-muted);}
  .item-title { color: inherit; }

  .item-price { display: flex; justify-content: space-between; align-items: flex-end; }
  .prices { display: flex; flex-direction: column; }
  .old { color: var(--text-muted); text-decoration: line-through; font-size: 0.875rem; font-weight: 500;} 
  .btn-view-details {  background-color: var(--text); color: contrast-color(var(--text)); border: none; padding: 0.5rem .75rem; border-radius: 10px; font-weight: 700;
    display: flex; align-items: center; gap: 0.5rem; transition: background-color 0.2s;
    &:hover { color: inherit; }
  }
  .current { color: var(--color-discount); font-size: 1.2rem; font-weight: 800;}

  .discount-info { background-color: #dcfce7; color: var(--color-success); display: flex; align-items: center; padding: var(--space-xs) var(--space-s); }
   .discount-info {
  background-color: var(--bg-card);
  color: var(--text-muted);
  border-top: 1px solid var(--border);
  font-weight: 600;
}
 .discount-info .icon { margin-inline-end: .5rem; stroke: var(--text-muted); }
 .loader { position: absolute; top: 50%; left: 50%; color: var(--accent); 
    .icon { width: 2rem; height: 2rem; }
  }
}


.item .img-wrapper,
.similar-item .img-wrapper{ aspect-ratio: 1 / 1; display: flex; align-items: center; justify-content: center; overflow: hidden; padding-inline: var(--space-s);}

.grid .caption { display: none; }


/* main grid panels */
.main-wrapper { max-width: var(--app-width); margin-inline: auto; }
.main {
  display: grid; grid-template-areas: "info info" "items items"; grid-template-rows: auto 1fr; grid-template-columns: 20rem 1fr;
  .info-panel {grid-area: info; }
  .info-panel .category-seo-text { margin-inline-start: 0rem; }
  .side-panel .close-btn {display: none; }
  .side-panel { display: none; }
  .items-wrapper { grid-area: items;}
}

@media screen and (min-width: 770px) {
  .main { grid-template-areas: "info info" "sidepanel items"; grid-column-gap: .5rem;}
  .main .side-panel { grid-area: sidepanel; display: block; z-index: 20; }
  .filter-btn { display: none; }
  .main .info-panel .category-seo-text { margin-inline-start: 20rem; }
}

.main-detail .breadcrumb { padding-block: var(--space-m);}
section.breadcrumb { padding-block: var(--space-2xs); }
.breadcrumb { --links-text: var(--text-muted); border-top: 1px solid var(--border);
   overflow-x: auto; scrollbar-width: thin; 
  a { text-decoration: none; color: var(--links-text); 
    &:hover { color: var(--accent); } }
  ol {display: inline-flex; flex-wrap: nowrap; list-style: none; align-items: center;
    li { display: inline-flex; flex-shrink: 0; align-items: center; font-size: var(--font-size-sm, 0.875rem); color: var(--text); 
      &:not(:last-child)::after { content: '\00203A'; margin-inline: var(--spacing-sm, 0.5rem); color: var(--color-text-tertiary); font-weight: 400;  }
    }
  }
}

/******************************************************************************/
/* SEO TEXT SECTION (.category-seo-text)                                      */
/******************************************************************************/

.category-seo-text {
  margin-block: var(--space-s) var(--space-xl);
  max-width: var(--app-width, 1200px);
  

  h2 {
    /* Použije tvoju hlavnú tmavú/svetlú farbu (slate-900 / slate-50) */
    color: var(--text); 
    font-size: 1rem; /* Zodpovedá text-sm z tvojho HTML */
    font-weight: 700;
    line-height: 1.4;
    margin-block: .5rem;
    letter-spacing: -0.01em;
    padding-block: var(--space-2xs);
  }

  /* ODSTAVEC TEXTU (p) */
  p {
    /* Použije tlmenú šedú (slate-500 / slate-300), aby text nebil do očí a plnil SEO účel */
    color: var(--text-muted); 
    font-size: 0.825rem; /* Zodpovedá text-xs */
    line-height: 1.6; /* Vyšší line-height pre príjemné čítanie blokov textu */
    font-weight: 400;
    margin-block-end: var(--space-2xs);
  }

  /* DÔLEŽITÝ TEXT (strong) */
  strong {
    /* Zvýraznené kľúčové slová urobíme o chlp tmavšie/svetlejšie s jemným akcentom */
    color: var(--text);
    font-weight: 600;
  }
}


.category-heading { position: relative; padding-bottom: 0.75rem; border-bottom: 1px solid var(--border); margin-block-end: var(--hwrap); 
  display: flex; justify-content: space-between; flex-wrap: wrap;
  &::after { content: ""; position: absolute; bottom: -1px; left: 0; width: 60px; height: 3px; background: var(--accent); border-radius: 2px;}
  .showing-count { margin-block: .5rem; }
}
.group { display: flex; gap: .5rem; justify-content: end; flex-grow: 1;}
.active-filters-wrapper:has(.btn) { margin-block: var(--space-s);}
.active-filters-wrapper:not(:has(.btn)) { margin-block-end: .5rem;}
.filter-tag { display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px; border-radius: 20px;
  border: 1px solid var(--border);
  background: var(--bg-card);
  color: var(--text); font-size: 0.75rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.3px; cursor: default; transition: all 0.2s; max-width: 300px;
 &:hover { color: inherit; border-color: var(--border);}

}
.simple-close {display: flex; align-items: center; justify-content: center; padding: 0.125rem; margin-left: 4px; cursor: pointer; border-radius: 50%; transition: all 0.2s;
  border: 1px solid var(--border, #94a3b8); color: var(--border-x, #94a3b8); background-color: var(--border);
  &:hover { color: var(--accent-hover); border-color: var(--accent-hover); }
}

/* 1. DEFINUJEME KONTAJNER - Hovoríme prehliadaču, aby sledoval šírku (inline-size) celej tejto sekcie*/
.items-wrapper { container-type: inline-size; width: 100%; }
/* 2. ZÁKLADNÝ GRID PRODUKTOV (Predvolený pre užšie priestory / mobily) */
.items.grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(15rem, 1fr)); gap: .25rem; }
.items.list { 
  .item {
    display: grid; grid-template-areas: "img text" "price price"; grid-template-rows: 200px 1rem; grid-template-columns: 1fr 1fr;

    .img-wrapper .image { grid-area: img; width: 100%; height: 100%; }
  }
  
  .item .content-wrapper {grid-area: text;}
  .item .discount-info {grid-area: price;}

}

/* 4. CONTAINER QUERY - Čo sa má stať, ak má .items-wrapper dosť miesta? */
/* Napríklad na desktope, kde má hlavná sekcia šírku viac ako 700px */
@container (max-width: 340px) {
  /* Môžeš zmeniť správanie samotného gridu,  aby stĺpce boli širšie a priestornejšie */
  .items.grid {
    grid-template-columns: 1fr;
    gap: .5rem;
  }
}
@container (min-width: 770px) {
  /* Môžeš zmeniť správanie samotného gridu,  aby stĺpce boli širšie a priestornejšie */
  .items.grid {
    grid-template-columns: repeat(auto-fit, minmax(calc(100% / 5), 1fr) );
    
    gap: .5rem;

    .caption { display: block; }
  }
}

.items.grid .item { container-type: inline-size; width: 100%; }

@container(min-width: 230px){
  .item {
    .caption { display: block; }
  }
}


/* ************************ */
/* filter panel */
/* ************************ */
.hc { justify-content: center; }

.submit-panel {margin-block-start: var(--space-m);}

.btnc-wrapped { align-content: center; color: inherit; } 
.expandable {
  --expanded: 1fr;
  --speed: 0.25s;
  --anim: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  display: grid; grid-template-rows: 2rem var(--expanded); grid-template-rows: 3.5rem var(--expanded); transition: grid-template-rows var(--speed) var(--anim);

  &.closed { --expanded: 0fr; }
  &:not(.closed) .btnc { transform: rotate(90deg); }

  .expand { overflow: hidden; }

  .arrow-right {  display: flex; align-items: center; justify-content: center; }
}

.filter-options .btn {
  appearance: none; background: var(--surface, #ffffff); border: 1px solid var(--border, #e2e8f0); padding: 0.5rem 1rem; border-radius: 2rem; 
  font-size: 0.85rem; font-weight: 600; color: var(--text-main, #0f172a); cursor: pointer; transition: all 0.2s ease-in-out; white-space: nowrap;
  &:hover:not(:disabled) { border-color: var(--primary, #f97316); color: var(--primary, #f97316); background-color: rgba(249, 115, 22, 0.05); transform: translateY(-1px); }
  &:hover:disabled { cursor: not-allowed; }
  &.active { background-color: var(--primary, #f97316); border-color: var(--primary, #f97316); color: #ffffff; box-shadow: 0 4px 12px rgba(249, 115, 22, 0.25); }
  &:disabled { background: var(--surface, #ffffff); cursor: auto; }
}

.common-panel .active { color: var(--accent); }

.side-panel{
  
  .close { display: none; }
  .filter-options { display: flex; flex-wrap: wrap; padding-block: .75rem; }
  .filter-panel { /* background-color: var(--bg-page); */ border-bottom: 1px solid var(--border); } 
  
}

.panel-inner-content { }
.slidein-content > .common-title-panel { padding: 1rem 0.75rem; border-bottom: 1px solid var(--border); 
  .icon {color: var(--accent-hover); width: 2rem; height: 2rem; }
}
.common-title-panel h3 { line-height: var(--close-btn-width); text-transform: capitalize; display: flex; align-items: center; gap: 0.5rem; }
.filter-section {
  &:not(:last-child) {border-bottom: 1px solid var(--border, rgb(226 232 240)); }
  .common-title-panel { display: flex; justify-content: space-between; 
    &:hover { background-color: color-mix(in srgb, var(--border), var(--neutral)); color: var(--accent-hover); }  
  }
}

.filter-panel.common-title-wrapper .icon { color: var(--accent); width: 2rem; height: 2rem;} 

.filter-options .btn { }
.range { display: flex; justify-content: space-between; align-items: center; margin-block: 0.75rem;
  .divider { color: var(--border); font-weight: 300;}
}
.range input {border: 2px solid var(--border); border-radius: 6px; font-size: 16px; padding: 12px; transition: all 0.3s ease; 
    width: calc(100% / 3); background-color: var(--bg-page); color: var(--text);
}

.loading-wrapper { margin-top: var(--space-m); }
.load-more-wrapper { display: flex; justify-content: center; }
.loader-btn {display: flex; align-items: center; gap: var(--space-xs); }
.btn.primary.load-more { padding: 0.75rem 2rem; border-radius: 9999px; background-color: var(--text); color: contrast-color(var(--text));
  font-size: 0.875rem; font-weight: 600; letter-spacing: 0.5px; 
  &:disabled { opacity: 0.6; }
}
.loader-btn.no-loading svg, .loader-btn.disabled svg{ display: none; }


.glass { --btn-text-glass: rgb(71 85 105);
   background-color: transparent; color: var(--btn-text-glass); border-radius: 0.25rem;}

.btn.glass {padding: 0.5rem 0.75rem;}

.paging-wrapper { display: flex; }
.paging { align-items: center; gap: 0.25rem; margin-inline: 0.5rem; }

.paging-wrapper { display: flex; align-items: center; justify-content: center; margin: 2rem 0;
  gap: 0.5rem; /* Medzera medzi šípkami a číslami */
}

ul.paging { display: flex; list-style: none; padding: 0; margin: 0; gap: 0.375rem; /* Jemná medzera medzi jednotlivými číslami strán */
}

.paging-wrapper .btn.glass,
ul.paging .num .btn.glass { display: inline-flex; align-items: center; justify-content: center;
  /* Rozmery - dokonalý štvorec príjemný na klikanie prstom na mobile */
  width: 2.5rem; height: 2.5rem; padding: 0;
  /* Reset natívnych štýlov buttonu */
  border: 1px solid var(--border); background-color: var(--bg-card); color: var(--text); border-radius: var(--radius-button);
  cursor: pointer; transition: var(--transition);
  &:hover:not(:disabled) { background-color: var(--accent-hover); color: contrast-color( var(--text) ); border-color: transparent; }
  &.active { background-color: var(--accent-hover); color: contrast-color( var(--text) );}
}

.paging-wrapper .btn.glass {
  &:disabled { opacity: 0.3; cursor: auto;}
  
}

/* IKONY VO VNÚTRI ŠÍPOK */
.paging-wrapper .btn.glass .icon {
  /* Zabezpečíme, aby šípka chytila správnu farbu textu */
  stroke: var(--text);  fill: none; width: 1.25rem; height: 1.25rem; transition: var(--transition);
}



/* panels menu */
.menu-header, .common-title-panel { padding: 1rem 1.5rem; line-height: 2.5rem; display: flex; align-items: center; justify-content: space-between; 
  h2 { color: var(--text); font-size: 1.875rem; font-weight: 800; letter-spacing: -0.025em; margin: 0; }
}
.panel-content .back { border-bottom: 1px solid var(--border1, red); padding: 1rem 1.5rem; width: 100%; display: grid; border: none; align-items: center;
  justify-items: self-start; cursor: pointer; color: var(--text); font-weight: 600; transition: background-color 0.2s ease; grid-template-columns: 1fr; 
   &:has(span:nth-child(2)) { grid-template-columns: 1fr 2fr; }

   .go-back { font-weight: 400; color: var(--text); display: flex; gap: .15rem; align-items: center;}
}

.inner-menu, .panel-inner-content { overflow-y: auto; 
  li { margin: 0; padding: 0.125rem 0.0625rem; display: flex; border-bottom: 1px solid var(--color-bg-surface-border / 0.5); transition: all 0.2s ease; 
    line-height: 1.5rem; font-size: 1rem; justify-content: space-between;

    /* &:hover { background-color: rgba(from var(--accent-hover) r g b / 0.1); } */

    button { display: flex; align-items: center; justify-content: space-between; background: transparent; border: none; text-decoration: none; 
      color: var(--text); font-size: 1rem; font-weight: 500; cursor: pointer; text-align: left;}
  }
  ul.step li .mlink { display: flex; flex-grow: 1; justify-content: space-between; 
    span {all: unset; 
      
    }
  }
}

/******************************************************************************/
/* PRODUCT DETAIL SECTION (.main-detail)                                      */
/******************************************************************************/
.price { color: var(--text); }
.price-vat {color: var(--accent); }

.main-detail {
  /* padding-block: var(--space-m); */
}

/* Hlavná mriežka pre rozloženie detailu */
.product-layout {
  display: grid;
  grid-template-columns: 1fr; /* Na mobile jeden stĺpec */
  gap: var(--space-l);
  margin-block-end: var(--space-xl);
}

@media (min-width: 992px) {
  .product-layout {
    grid-template-columns: 1.1fr 0.9fr; /* Na desktope 2 vyvážené stĺpce */
    align-items: start;
  }
}

@media (max-width: 280px) {
  .product-layout { display: block; 
    .description { padding: var(--space-xs); }
    .p-img-wrapper { aspect-ratio: 1 / 1; }
  }
  .search { padding: .25rem 0px; }
  .product-specs { grid-template-columns: repeat(1, 1fr); }
}

/* === L'AVÝ PANEL: GALÉRIA & POPIS === */
.left-panel {
  display: flex;
  flex-direction: column;
  gap: var(--space-l);
}

/* Galéria obrázkov */
.gallery {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.main-image-container {
  background-color: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-card);
  overflow: hidden;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05);
}

.p-img-wrapper {
  position: relative;
  aspect-ratio: 4 / 3; /* Pekný obdĺžnikový formát pre oblečenie/obuv */
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-s);
  background-color: #ffffff; /* Vždy biele pozadie pre fotky tovaru */
}

.main-image {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}

/* Navigačné šípky v galérii */
.nav-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background-color: rgba(255, 255, 255, 0.8);
  border: 1px solid var(--border-light);
  color: var(--text-main-light);
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 1.25rem;
  transition: var(--transition);
  z-index: 10;
  
  &:hover {
    background-color: var(--accent);
    color: white;
    border-color: var(--accent);
  }
  &.prev-btn { left: var(--space-xs); }
  &.next-btn { right: var(--space-xs); }
}

/* Náhľady (Thumbnails) */
.thumbnails {
  display: flex;
  gap: var(--space-xs);
  flex-wrap: wrap;
}

.thumbnail {
  width: 4.5rem;
  height: 4.5rem;
  object-fit: contain;
  padding: 0.25rem;
  background-color: #ffffff;
  border: 2px solid var(--border);
  border-radius: var(--radius-button);
  cursor: pointer;
  transition: var(--transition);

  &.active, &:hover {
    border-color: var(--accent);
  }
}

/* Sekcia popisu produktu */
.description {
  background-color: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-card);
  padding: var(--space-m);

  h3 {
    font-size: 1.15rem;
    font-weight: 700;
    margin-bottom: var(--space-xs);
    color: var(--text);
  }
  
  p {
    line-height: 1.6;
    color: var(--text-muted);
  }
}

/* === PRAVÝ PANEL: CENY & MARKETINGOVÉ INFORMÁCIE === */
.product-price-info {
  background-color: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-card);
  padding: var(--space-m);
  position: sticky;
  top: 6.5rem; /* Zasekne sa pod fixným headerom pri scrollovaní */
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.02);
}

.product-header {
  margin-bottom: var(--space-m);
}

/* .product-main { padding-inline: 2rem; } */

.product-title {
  font-size: 1.5rem;
  font-weight: 800;
  line-height: 1.3;
  letter-spacing: -0.02em;
  color: var(--text);
  margin-bottom: var(--space-xs);
}

.product-meta {
  display: flex;
  gap: var(--space-s);
  flex-wrap: wrap;
  align-items: center;
}

.product-brand.info {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--text-muted);
  letter-spacing: 0.05em;

  .icon {
    width: 1.1rem;
    height: 1.1rem;
    stroke: var(--text-muted);
    fill: none;
  }
}

/* Blok s cenami (Aktuálna vs Bežná) */
.details-section-2 {
  display: flex;
  align-items: center;
  background-color: var(--bg-page);
  border-radius: var(--radius-card);
  padding: var(--space-s);
  margin-bottom: var(--space-m);
  border: 1px solid var(--border);

  background: var(--surface);
  border: .25rem solid var(--border);
  padding: var(--space-m);
  border-radius: var(--radius-lg, 1.25rem);
  box-shadow: var(--shadow);
  display: flex;
  gap: var(--space-m);;
  margin-bottom: var(--space-m);;
  /* width: 100%; */
  justify-content: space-around;
}

@media screen and (max-width: 440px) {
  .details-section-2 {
    flex-direction: column;
    .price-divider { width: 100%; height: .25rem; }
  }

  .header { grid-row-gap: var(--space-xs); grid-column-gap: .125rem; }
  .logo { max-width: 17rem; flex-grow: 1; flex-shrink: 1;
    svg { width: 90%; margin-bottom: 0px; margin-inline: auto;}
  }
  .menu-row .icon { width: 1.5rem; height: 1.5rem; }
  .menu-btn {align-items: center;  .icon { width: 2rem; height: 2rem; } }
}
.profile.btn:not(.theme-switch) { display: none; }
@media screen and (max-width: 250px) {
  .header { grid-row-gap: var(--space-xs); grid-column-gap: .125rem; }
  .menu-row .icon { width: 1rem; height: 1rem; }
  .menu-btn .icon { width: 1.5rem; height: 1.5rem; } 
  .profile-wrapper .btn, .profile.btn {padding: .125rem;}
  .menu-row .btn { border-color: transparent; }
  .text-sm { font-size: 11px; }
  .search .btn { position: absolute; right: 0;}
}

.section-block {
  display: flex;
  flex-direction: column;
}

.price-text {
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
  margin-bottom: 0.25rem;
}

.price-section-new {
  flex: 1;
  
  .current-price {
    display: flex;
    align-items: baseline;
    color: var(--color-discount); /* Ceny v zľave svietia červeno */
    font-weight: 800;
    
    .price { line-height: 1; }
    /* .price-vat { font-weight: 600; margin-left: 2px; } */
  }
}

.price-divider {
  width: 1px;
  align-self: stretch;
  background-color: var(--border);
  margin-horizontal: var(--space-s);
}

.price-section-old {
  flex: 1;
  
  .price {
    color: var(--text-muted);
    text-decoration: line-through;
    font-weight: 600;
    margin-bottom: 2px;
  }
}

/* Zľavový badge s informáciou koľko ušetria */
.price-saved {
  display: inline-flex;
  align-self: flex-start;
  font-size: 0.75rem;
  font-weight: 700;
  background-color: color-mix(in srgb, var(--color-success) 12%, var(--bg-card));
  color: var(--color-success-dark);
  padding: 0.25rem 0.6rem;
  border-radius: var(--radius-button);

  span {    background: #dcfce7;
    color: #166534;
    padding: 0.2rem 0.5rem;
    border-radius: 0.5rem;
    font-weight: 800;
    font-size: 0.85rem;
    text-wrap: nowrap;}
}

/* Výber variantov (Veľkosti, farby) */
.product-variants {
  margin-bottom: var(--space-m);

  strong { color: var(--text); }
}

.variant-tags {
  display: flex;
  gap: var(--space-2xs);
  flex-wrap: wrap;
  margin-top: 0.5rem;
}

.trim-1 { white-space: nowrap; overflow: hidden; text-overflow: ellipsis;}

.variant-tag {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  background-color: var(--bg-page);
  border: 1px solid var(--border);
  padding: 0.5rem 0.85rem;
  border-radius: var(--radius-button);
  color: var(--text);
  font-size: 0.85rem;
  font-weight: 600;
  cursor: pointer;
  transition: var(--transition);

  .check-icon {
    color: var(--color-success);
  }

  .quantity-badge {
    font-size: 0.75rem;
    background-color: var(--border);
    color: var(--text-muted);
    padding-inline: 0.35rem;
    border-radius: 4px;
  }

  &:hover {
    border-color: var(--accent);
    background-color: color-mix(in srgb, var(--accent) 4%, var(--bg-card));
  }
}

/* Technické parametre (Specs) */
.product-specs {
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding-block: var(--space-m);
  margin-bottom: var(--space-m);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-s);

  .spec-text {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-muted);
    text-transform: uppercase;
    margin-bottom: 2px;
  }

  .desc {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--text);
  }
}

/* Hlavná redirect sekcia a veľké akčné tlačidlo "UCHMATNI" */
.redirect-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--space-2xs);

  .redirect-btn {
    border-color: transparent;
    cursor: pointer;
  }

  .btn-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-xs);
    /* width: 100%; */
    background-color: var(--accent); /* Kráľovská oranžová */
    color: #ffffff !important;
    text-transform: uppercase;
    font-weight: 800;
    letter-spacing: 0.05em;
    padding: var(--space-s) var(--space-m);
    border-radius: var(--radius-card);
    text-decoration: none;
    box-shadow: 0 10px 15px -3px rgba(249, 115, 22, 0.3);
    transition: var(--transition);

    .icon {
      stroke: #ffffff;
      fill: none;
      width: 1.75rem;
      height: 1.75rem;
    }

    &:hover {
      background-color: var(--accent-hover);
      transform: translateY(-2px);
      box-shadow: 0 12px 20px -3px rgba(213, 85, 11, 0.4);
    }
  }

  p {
    font-size: 0.75rem;
    color: var(--text-muted);
    text-align: center;
    letter-spacing: 0.05em;
    font-weight: 600;
    color: var(--text-muted);
    margin-top: 0.75rem;
  }
}

/* === SPODNÝ PANEL: PODOBNÉ PRODUKTY SCROLLER === */
.similar-products {
  /* margin-top: var(--space-xl);
  border-top: 1px solid var(--border); */
  padding-top: var(--space-m);

  .section-title.now {
    font-size: 1.35rem;
    font-weight: 800;
    letter-spacing: -0.02em;
    color: var(--text);
    margin-block: var(--space-l) var(--space-m);
  }
}

.full-width-section .rollable-container {
  position: relative;
  margin-inline: 1rem;
}

.scroll-container {
  overflow-x: auto;
  scrollbar-width: none; /* Skryje natívny scrollbar */
  &::-webkit-scrollbar { display: none; }
  padding-bottom: var(--space-xs);
}

/* Šípky pre scrollovanie zoznamu */
.scroll-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 2.75rem;
  height: 2.75rem;
  background-color: var(--text);
  border: 1px solid var(--text);
  color: var(--bg-card);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 20;
  box-shadow: 0 4px 10px rgba(0,0,0,0.06);
  transition: var(--transition);

  &:hover {
    border-color: var(--accent);
    color: var(--accent);
  }

  &.left { left: -1.25rem; }
  &.right { right: -1.25rem; }

  svg { stroke-width: 2px; }
}

/* Grid pre podobné produkty vo vnútri scrolleru */
.similar-grid {
  display: inline-grid; /* Zmena na flex pre plynulý overflow-x scrollovanie */
  gap: var(--space-s);
  padding-block: 1rem;
}

.similar-item {
  flex-shrink: 0;
  width: 14rem; /* Fixná šírka pre karty v horizontálnom rade */
  display: flex;
  flex-direction: column;
  background-color: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-card);
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: var(--transition);

  .img-wrapper {
    width: 100%;
    aspect-ratio: 1 / 1;
    background-color: #ffffff;
    padding: var(--space-xs);
    display: flex;
    align-items: center;
    justify-content: center;

    img {
      max-width: 100%;
      max-height: 100%;
      object-fit: contain;
    }
  }

  .item-info {
    padding: var(--space-xs) var(--space-s) var(--space-s) var(--space-s);
    display: flex;
    flex-direction: column;
    flex-grow: 1;

    .brand {
      font-size: 0.7rem;
      font-weight: 800;
      text-transform: uppercase;
      color: var(--accent);
      letter-spacing: 0.05em;
      margin-bottom: 2px;
    }

    .name {
      font-size: 0.85rem;
      font-weight: 600;
      color: var(--text);
      line-height: 1.4;
      display: -webkit-box;
      -webkit-line-clamp: 2;
      -webkit-box-orient: vertical;
      overflow: hidden;
      margin-bottom: var(--space-xs);
      height: 2.4rem; /* Drží rovnakú výšku boxu pre text bez ohľadu na dĺžku názvu */
    }

    .prices {
      display: flex;
      align-items: baseline;
      gap: var(--space-2xs);
      margin-top: auto; /* Tlačí ceny na absolútny spodok karty */

      .price {
        font-size: 1.1rem;
        font-weight: 800;
        color: var(--color-discount);
      }

      .old {
        font-size: 0.75rem;
        color: var(--text-muted);
        text-decoration: line-through;
        font-weight: 500;
      }
    }
  }

  &:hover {
    border-color: var(--accent);
    transform: translateY(-3px);
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.05);
  }
}






.box { width: 300px; height: 300px;}
.b1 {background-color: var(--accent); color: contrast-color(var(--accent));}
.b2 {background-color: var(--accent-hover); color: contrast-color(var(--accent-hover));}
.b3 {background-color: var(--text); color: contrast-color(var(--text)); }
.b4 {background-color: var(--text-muted); color: contrast-color(var(--text-muted));}
.b5 {background-color: var(--bg-card); color: contrast-color(var(--bg-card));}
.b6 {background-color: var(--bg-page); color: contrast-color(var(--bg-page));}
.b7 {background-color: var(--border); color: contrast-color(var(--border));}


/* design sidepanel categories */
/******************************************************************************/
/* SIDE PANEL MENU (.slidein-content)                                         */
/******************************************************************************/

/* HLAVIČKA PANELU (Uchmatni + Close tlačidlo) */
.menu-header {
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  background-color: var(--bg-card);

  h2 {
    color: var(--accent); /* Logo "Uchmatni" v menu zažiari tvojou oranžovou */
    font-size: 1.5rem;
    font-weight: 800;
    letter-spacing: -0.025em;
  }

  /* Prepojenie na tvoje už existujúce štýly pre close-btn */
  .close-btn {
    /* Ak máš v HTML text "X", skryjeme ho a necháme pracovať tvoje CSS s ::after/::before pseudoprvkami */
    font-size: 0; 
  }
}

/* TLAČIDLO SPÄŤ / AKTÍVNA ÚROVEŇ ("Všetky kategórie") */
.panel-content .back {
  width: 100%;
  padding: 1rem 1.5rem;
  background-color: var(--bg-page); /* Jemne odlíšené pozadie */
  border: none;
  border-bottom: 1px solid var(--border);
  color: var(--text);
  font-weight: 700;
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  text-align: left;
  transition: var(--transition);

  /* Stav, kedy je tlačidlo vypnuté (sme na hlavnej úrovni kategórií) */
  &:disabled {
    color: var(--text-muted);
    opacity: 1; /* Prebijeme globálny opacity reset, aby text zostal dobre čitateľný */
    cursor: default;
  }

  /* Keď bude v budúcnosti aktívne (klikateľné pre návrat späť) */
  &:not(:disabled):hover {
    background-color: color-mix(in srgb, var(--accent) 5%, var(--bg-page));
    color: var(--accent-hover);
    cursor: pointer;
  }
}

/* VNÚTORNÉ MENU - ROLOVATEĽNÁ ČASŤ */
.inner-menu {
  flex-grow: 1;
  overflow-y: auto; /* Ak je kategórií veľa, panel sa dá plynule scrollovať */
  scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
}

/* Zoznam položiek (ul) */
ul.step {
  list-style: none;
  padding: 0;
  margin: 0;
}

/* Jednotlivé riadky kategórií (li) */
ul.step li {
  display: flex;
  align-items: stretch; /* Zabezpečí, že klikateľná zóna šípky bude na celú výšku riadku */
  border-bottom: 1px solid color-mix(in srgb, var(--border) 50%, transparent);
  transition: var(--transition);

  /* HOVER EFEKT: Využitie tvojho sémantického color-mix */
  &:hover {
    background-color: rgb(from var(--accent) r g b / 0.1);
    
    /* Text kategórie pri hoveri jemne zoranžovie (pre button aj pre priamy odkaz a) */
    button span, a span {
      color: var(--accent-hover);
    }

    /* Šípka vpravo sa jemne posunie a zoranžovie */
    .arrow-right .icon {
      /* stroke: var(--accent-hover); */
      transform: translateX(2px);
    }
  }
}

/* HLAVNÉ TLAČIDLO KATEGÓRIE AJ PRIAMY ODKAZ (Zjednotenie štýlu a paddingov) */
ul.step li > button:not(.arrow-right),
ul.step li > a {
  flex-grow: 1;
  background: transparent;
  border: none;
  text-align: left;
  cursor: pointer;
  display: flex;
  align-items: center;
  text-decoration: none; /* Pre a: zrušíme predvolené podčiarknutie textu linku */
  color: inherit;        /* Pre a: prevezme farbu textu z li */

  span {
    color: var(--text);
    font-size: 0.95rem;
    font-weight: 600;
    transition: var(--transition);
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
  }
}

/* Špecifický padding pre button (má vedľa seba šípku, takže pravý padding zmenšíme, nech to dýcha) */
ul.step li > button:not(.arrow-right) {
  padding: 1rem 0.5rem 1rem 1.5rem;
}

/* Špecifický padding pre priamy odkaz a (nemá vedľa seba šípku, potiahneme padding až na kraj) */
ul.step li > a {
  padding: 1rem 1.5rem 1rem 1.5rem;
}

/* POČET PRODUKTOV V ZÁVORKE: Pre <i> na buttonoch aj pre čistý text na odkazoch */
/* Pomocou CSS selektorov naformátujeme text tak, aby oba vyzerali ako identické oválne badgíky */
ul.step li i,
ul.step li a span::after {
  font-style: normal;
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--text-muted); /* Šedé, tlmené číslo */
  background-color: var(--bg-page);
  padding: 0.15rem 0.5rem;
  border-radius: 20px;
  border: 1px solid var(--border);
  transition: var(--transition);
}

/* Špecifické dotiahnutie detailu pre odkaz a, ak je číslo natvrdo súčasťou stringu */
ul.step li a span {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
}

/* PRAVÉ TLAČIDLO SO ŠÍPKOU (Prechod do podkategórie) */
.arrow-right {
  background: transparent;
  border: none;
  padding-inline: 1.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  border-left: 1px solid color-mix(in srgb, var(--border) 30%, transparent);
  transition: var(--transition);

  /* Reset hover efektu, ktorý máš na globálnej triede .btn */
  &:hover {
    border-color: transparent !important;
    /* background-color: color-mix(in srgb, var(--accent) 8%, var(--bg-card)); */
  }

  .icon {
    width: 1.15rem;
    height: 1.15rem;
    fill: none;
    transition: var(--transition);
  }
}

/* Jednotlivé riadky kategórií (li) */
ul.step li {
  display: flex;
  align-items: stretch;
  border-bottom: 1px solid color-mix(in srgb, var(--border) 50%, transparent);
  transition: var(--transition);
}

/* ==========================================================================
   1. SCENÁR: RIADOK JE PRIAMY LINK <a> (Nemá šípku)
   ========================================================================== */
ul.step li:has(> a):hover {
  /* Podfarbíme celý riadok */
  background-color: rgb(from var(--accent) r g b / 0.1);
  color: var(--accent);
  
  /* Text linku zoranžovie */
  a span {
    color: var(--accent-hover);
  }
}

/* ==========================================================================
   2. SCENÁR: RIADOK MÁ PODKATEGÓRIU (Má button + šípku .arrow-right)
   ========================================================================== */
/* Keď používateľ prejde myšou po samotnom texte podkategórie (mimo šípky) */
ul.step li > button:not(.arrow-right):hover {
  /* background-color: color-mix(in srgb, var(--text) 12%, transparent); Jemný šedý podmaz pre text */
  /* Farba textu (span) sa tu NEMENÍ na oranžovú, zostáva pôvodná */
}
ul.step li > button:hover ~ .arrow-right, .arrow-right:hover {
 color: var(--accent);
  /* Farba textu (span) sa tu NEMENÍ na oranžovú, zostáva pôvodná */
}



/* search box */
.search-wrapper {

}

.panel-inner-content li.active {  
    color: var(--accent);
    font-weight: 700;
}
    
.slideinbothfullv {
  .panel-inner-content ul:not(.filter-options) li {
      --orange-bg-100: rgb(255 237 213);
        padding: 1.125rem 1.5rem;
        color: var(--slate-700-300);
        font-size: 1.125rem;
        font-weight: 500;
        cursor: pointer;
        display: flex;
        align-items: center;
        justify-content: center;
        transition: all 0.2s ease;
        &:not(:last-child) {
            border-bottom: 1px solid var(--border);
        }
        
        &:hover { background-color: rgb(from var(--accent) r g b / 0.9); }
    }

    .filter-options li { display: inline-flex; }
  
.panel-inner-content ul {
    padding: 1rem 0 2rem;
}

.common-title-panel svg {
  width: 2.5rem;
  height: 2.5rem;
  /* color: var(--accent); */
}
.arrow-right svg {
  width: 1.5rem;
  height: 1.5rem;
}
}
/* slidin panels */
.slideinbothfull {
      position: fixed; top: 0; left: 0; right: 0; bottom: 0; z-index: 1000; visibility: hidden;
      transition:  visibility 0s 0.5s; display: grid; grid-template-columns: 1fr min(50vw, 80vw); grid-template-areas: "shadow content"; pointer-events: none; /* Initially not interactive */
      &.opened {
        transition:  visibility 0s 0s; visibility: visible; pointer-events: all; /* Interactive when open */
      }
      .overlay {
        background-color: rgba(192, 192, 192, 0.7); /* Semi-transparent silver */
        cursor: pointer; transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94); display: none;
      }

      &.right {
        grid-template-columns: min(50vw, 80vw) 1fr; grid-template-areas: "content shadow";
        .overlay.for-right-bottom { display: block; }
        /* Right slidein panel - Overlay slides from left, content from right */
        .overlay { grid-column: 1; transform: translateX(-100%); } /* Start off-screen to the left */
        &.opened .overlay { transform: translateX(0); } /* Slide in from left */

        .slidein-content { grid-column: 2; transform: translateX(100%); } /* Start off-screen to the right */
        &.opened .slidein-content { transform: translateX(0); } /* Slide in from right */

        .close { float: left; }
      }

      &.left {
        grid-template-columns: min(30rem, 80vw) 1fr; grid-template-areas: "content shadow";
        .overlay.for-left-top { display: block; }
        /* Left slidein panel - Overlay slides from right, content from left */
        .overlay { grid-column: 2; transform: translateX(100%); } /* Start off-screen to the right */
        &.opened .overlay { transform: translateX(0); } /* Slide in from right */
        .slidein-content { grid-column: 1; transform: translateX(-100%); } /* Start off-screen to the left */
        &.opened .slidein-content { transform: translateX(0%); } /* Slide in from left */

        .close { float: right; }
      }
    }

/* Slidein content styling */
      .slidein-content {
        transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
        /* box-shadow: 0 -5px 25px rgba(0, 0, 0, 0.15); */
        background: var(--bg-card);
        pointer-events: all;
        position: relative;
        /* width: min(20rem, 80vw); */
        /* height: 100%; */
        overflow-y: auto;
      }

.slideinbothfullv {
      position: fixed; top: 0; left: 0; right: 0; bottom: 0; z-index: 1000; visibility: hidden;
      transition:  visibility 0s 0.5s; display: grid; grid-template-rows: 1fr min(50vw, 80vw); grid-template-areas: "shadow content"; pointer-events: none; /* Initially not interactive */
      &.opened {
        transition:  visibility 0s 0s; visibility: visible; pointer-events: all; /* Interactive when open */
      }
      .overlay {
        background-color: rgba(192, 192, 192, 0.7); /* Semi-transparent silver */
        cursor: pointer; transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94); display: none;
      }

      &.bottom {
        grid-template-rows: min(30vh, 80vh) 1fr; grid-template-areas: "content" "shadow";
        .overlay.for-left-top { display: block; }
        /* Right slidein panel - Overlay slides from left, content from right */
        .overlay { grid-row: 1; transform: translateY(-100%); } /* Start off-screen to the left */
        &.opened .overlay { transform: translateX(0); } /* Slide in from left */

        .slidein-content { grid-row: 2; transform: translateY(100%); } /* Start off-screen to the right */
        &.opened .slidein-content { transform: translateY(0); } /* Slide in from right */

        .close { float: left; }
      }

      &.top {
        grid-template-rows: min(50vw, 80vw) 1fr; grid-template-areas: "content" "shadow";
        .overlay.for-right-bottom { display: block; }
        /* Left slidein panel - Overlay slides from right, content from left */
        .overlay { grid-row: 2; transform: translateY(100%); } /* Start off-screen to the right */
        &.opened .overlay { transform: translateY(0); } /* Slide in from right */
        .slidein-content { grid-row: 1; transform: translateY(-100%); } /* Start off-screen to the left */
        &.opened .slidein-content { transform: translateY(0%); } /* Slide in from left */

        .close { float: right; }
      }

      /* Slidein content styling */
      .slidein-content {
        transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
        box-shadow: 0 -5px 25px rgba(0, 0, 0, 0.15);
        background: var(--bg-card);
        pointer-events: all;
        position: relative;
        /* width: min(20rem, 80vw); */
        /* height: 100%; */
        overflow-y: auto;
      }
    }


/* ============================================
   FOOTER (nezmenené)
============================================ */
.seo-content { max-width: var(--app-width); margin-inline: auto;}
.leading-relaxed { margin-inline: .25rem; }
.footer {
  background: var(--bg-color);
  color: var(--text-primary);
  /* padding: 2rem; */
  /* margin-top: 3rem; */
}

.footer a {
  color: var(--text-primary);
  text-decoration: none;
}

.footer a:hover {
  color: var(--text-primary);
}

.py-16 { padding-top: 4rem; padding-bottom: 4rem; }

@media (min-width: 768px) {
    .md\:grid-cols-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}
.grid { display: grid; }

.flex {
    display: flex;
}
.items-start {
    align-items: flex-start;
}
.flex-col {
    flex-direction: column;
}
.h-8 {
    height: 2rem;
}
.w-8 {
    width: 2rem;
}
.text-orange-500 {
    color: #f97316;
}
.footer svg {stroke-width: 2px; }

.mb-4 {
    margin-bottom: 1rem;
}
.text-slate-400 {
    color: var(--slate-400, rgb(148 163 184));
}

.font-bold {
    font-weight: 700;
}
.mb-2 {
    margin-bottom: 0.5rem;
}

.seo-info {
  border-top: 1px solid var(--border);
}
.utility-footer {
  border-top: 1px solid var(--border);
  padding-block: 2rem;
  font-size: .75rem;
}

/* ============================================
   4. ANIMATIONS
   ============================================ */
@keyframes pulse {

  0%,
  100% {
    opacity: 0.25;
    transform: scale(1);
  }

  50% {
    opacity: 0.35;
    transform: scale(1.05);
  }
}