  :root{
  	--brand:#2f3c95; 
  	--brand-hover: #232f7f;
  	--bs-link-color-rgb: #2f3c95; 
  	--accent:#35c1a4; 
  	--ink:#0f172a; 
  	--muted:#64748b; 
  	--line:#e5e7eb; 
  	--ok:#35c1a4;
  	--no:#c04141;
  	--bg:#f7f7f8; 
  	--bs-primary: var(--brand);
  	--bs-primary-rgb: 47,60,149;

  	/* môžeš kľudne zväčšiť, ak chceš širší layout na veľkých monitoroch */
  	--container-max: 1280px;

  	/* bočný padding pre menšie šírky */
  	--page-offset: clamp(12px, 2.5vw, 24px);
}

/* hlavný kontajner – jednoduchšia logika */
.container-w{
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--page-offset);
}


/* sekcie – jednotné odsadenie zhora/zdola */
.sec{ padding-block: clamp(20px, 4vw, 40px); }

/* karty – jednotné vnútorné odsadenie */
.card.pad{ padding: clamp(14px, 2.2vw, 20px); }

/* typo “prose” pre textové bloky (O nás, blog) */
.prose{
  font-size: 1.06rem;
  line-height: 1.75;
  letter-spacing: .1px;
}
.prose p{ margin: 0 0 .9rem; }
.prose h2,.prose h3{ line-height: 1.25; margin: 1.2rem 0 .6rem; }
.prose ul{ padding-left: 1.1rem; margin: .6rem 0; }

.pl-0
{padding-left:0;}
.pr-0
{padding-right:0;}
.btn-primary {
    --bs-btn-color: #fff;
    --bs-btn-bg: var(--brand);
    --bs-btn-border-color: var(--brand);
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #0b5ed7;
    --bs-btn-hover-border-color: var(--brand);
    --bs-btn-focus-shadow-rgb: 49, 132, 253;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: var(--brand);
    --bs-btn-active-border-color: var(--brand);
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: #fff;
    --bs-btn-disabled-bg: var(--brand);
    --bs-btn-disabled-border-color: var(--brand);
}


 .page-link{
  --bs-btn-color: #fff;
  background-color:#fff;
  --bs-btn-bg: var(--brand);
  --bs-btn-border-color: var(--brand);
  --bs-btn-hover-bg: color-mix(in srgb, var(--brand) 90%, #000 10%);
  --bs-btn-hover-border-color: color-mix(in srgb, var(--brand) 90%, #000 12%);
  --bs-btn-active-bg: color-mix(in srgb, var(--brand) 80%, #000 20%);
  --bs-btn-active-border-color: color-mix(in srgb, var(--brand) 80%, #000 22%);
  --bs-btn-disabled-bg: var(--brand);
  --bs-btn-disabled-border-color: var(--brand);
}

.btn-outline-primary{
	color: var(--brand);
  --bs-btn-color: var(--brand);
  --bs-btn-border-color: var(--brand);
  --bs-btn-hover-bg: var(--brand);
  --bs-btn-hover-border-color: var(--brand);
  --bs-btn-hover-color:#fff;
}


.active>.page-link, .page-link.active
{
	background-color: var(--brand);
	border-color: var(--brand);
}
.pagination
{
	--bs-pagination-color: var(--brand);
}
/* Outline varianta (už ju máš, pre istotu nechávam tu zjednotenú) */
.btn-outline-primary,.page-link{
  --bs-btn-color: var(--brand);
  --bs-btn-border-color: var(--brand);
  background-color:#fff;
  --bs-btn-hover-bg: var(--brand);
  --bs-btn-hover-border-color: var(--brand);
  --bs-btn-hover-color:#fff;
}


/* Breadcrumbs */
.crumbs{font-size:.9rem; color:#6b7280; margin-bottom:5px;margin-top:5px;}
.crumbs a{color:inherit}

.short-desc
{line-height:1.6rem;}
.short-desc a
{color:var(--brand)}
.short-desc a:hover
{
	color:var(--brand-hover)
}
.delivery-text
{
	font-size:12px;margin-top:5px;
}

.brand-link
{
	font-weight:300;
	color:var(--brand)
}
/* Link tlačidlo nech má tiež firemnú farbu */
.btn-link{
  color: var(--brand);
}
.btn-link:hover{ filter: brightness(.9); }

.prod .thumb{ cursor:pointer; }
.prod .thumb:focus-visible{ outline:2px solid var(--brand); outline-offset:2px; border-radius:10px; }





    html,body{background:var(--bg); color:var(--ink); font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial}
    h1,h2,h3,h4{font-family:Poppins,Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial}
    a{text-decoration:none}
    
    .shadow-soft{box-shadow:0 12px 28px rgba(0,0,0,.06)}
.cat-card .title
{ color: var(--brand);}
    /* HEADER */
    .site-header{position:sticky; top:0; z-index:1040; background:#fff; box-shadow:0 2px 10px rgba(0,0,0,.06)}
    .logo-badge{background:var(--brand); padding:10px 14px;  display:inline-flex; align-items:center}
    .logo-badge img{height:50px; display:block}
    .main-nav{display:flex; align-items:center; gap:16px; margin:0; padding:0}
    .main-nav>li{list-style:none; position:relative}
    .main-nav>li>a{display:flex; align-items:center; gap:6px; padding:8px 10px; font-weight:600; color:#111827; border-radius:10px}
    .main-nav>li>a:hover{color:var(--brand)}
    .main-nav svg{width:16px;height:16px;vertical-align:-2px}

.crumbs a:hover {color:var(--brand);}

    /* Icon pills */
    .icon-btn{width:40px; height:40px; display:grid; place-items:center; border:0px solid var(--line); border-radius:12px; background:#fff; color:#334155}
    .icon-btn:hover{border-color:var(--brand); color:var(--brand)}
    .icon-btn:hover div {color:initial}
    .icon-btn svg{width:20px;height:20px}
    .icon-btn[data-count]::after{content:attr(data-count); position:absolute; top:-6px; right:-6px; min-width:18px; height:20px; display:grid; place-items:center; padding:0 4px; background:var(--accent); color:#fff; border-radius:999px; border:2px solid #fff; font-size:11px; font-weight:700}

    /* MEGA MENU (prevzaté a uhladené) */
    .about-visual {box-shadow:0 18px 40px rgba(0,0,0,.12);  border-radius:14px; overflow:hidden }
    .btn-light{color:#212529;background-color:#e4e4e4;border-color:#e4e4e4;}
.btn-light:hover{color:#212529;background-color:#d1d1d1;border-color:#cbcbcb;}
.btn-light:focus{box-shadow:0 0 0 .2rem rgba(199,199,200,.5);}
.btn-light:disabled{color:#212529;background-color:#e4e4e4;border-color:#e4e4e4;}
.btn-light:not(:disabled):not(.disabled):active{color:#212529;background-color:#cbcbcb;border-color:#c4c4c4;}
.btn-light:not(:disabled):not(.disabled):active:focus{box-shadow:0 0 0 .2rem rgba(199,199,200,.5);}

    .mega-trigger{position:relative}
    .mega-panel{position:absolute; top:100%; left:0; width:880px; background:#fff; border:1px solid var(--line); box-shadow:0 18px 40px rgba(0,0,0,.12); display:none; z-index:2000; border-radius:14px; overflow:hidden}
    @media (min-width: 992px){ .main-nav>li.mega-trigger:hover .mega-panel{display:block} }
    .mega-wrap{display:grid; grid-template-columns:300px 1fr; min-height:320px}
    .mega-left{border-right:1px solid var(--line); padding:12px}
    .mega-left a{display:flex; align-items:center; gap:10px; padding:10px 12px; border-radius:10px; color:#0f2435; font-weight:500}
    .mega-left a:hover, .mega-left a.active{background:#f7f7f8}
    .mega-left svg{width:20px;height:20px;color:var(--brand)}
    .mega-right{padding:16px 20px}
    .mega-right h6{font-size:.9rem; font-weight:700; color:#0f2435; margin:0 0 10px}
    .subgrid{display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:8px 18px}
    .subgrid a{color:#0f2435; padding:8px 10px; border:1px solid var(--line); border-radius:10px; font-weight:500}
    .subgrid a:hover{color:var(--brand); border-color:var(--brand); background:#f9fafb}
    @media (max-width:991.98px){ .mega-panel{position:static; width:100%} .mega-wrap{grid-template-columns:1fr} }

    /* HERO */
    .hero{position:relative; border-radius:20px; overflow:hidden}
    .hero::before{content:""; position:absolute; inset:0; background:linear-gradient(90deg, rgba(15,23,42,.65), rgba(15,23,42,.25) 45%, rgba(15,23,42,0) 70%)}
    .hero-img{position:absolute; inset:0; background:center/cover no-repeat}
    .hero-body{position:relative; z-index:2; padding:64px}
    .hero h1{color:#fff}
    .hero p{color:#e2e8f0}

    /* KARTY KATEGÓRIÍ */
    .cat-card{background:#fff; border:1px solid var(--line); border-radius:16px; overflow:hidden; display:flex; flex-direction:column}
    .cat-card .thumb{height:140px; background:#f3f4f6 center/cover no-repeat}
    .cat-card:hover{transform:translateY(-2px); box-shadow:0 12px 28px rgba(0,0,0,.08)}
    .cat-card .title{font-weight:700}
#searchModal 
{z-index:1065;}
    /* USP pás */
    .usp{background:#fff; border:1px solid var(--line); border-radius:16px}
    .usp .item{display:flex; gap:8px; align-items:center; padding:22px}
    .usp .ico{width:30px; height:30px; border-radius:12px; background:#eef2ff; color:var(--brand); display:grid; place-items:center; font-weight:600}

    /* BRANDS */
    .brands{background:#fff; border:1px solid var(--line); border-radius:16px}
    
    footer { background: var(--brand); color: #d2e2ef; }

    /* ===== Tokens & helpers ===== */
    :root{ --radius:16px; --r-lg:20px; --shadow:0 12px 28px rgba(0,0,0,.08); }
    .rounded-16{ border-radius: var(--radius) }
    .section{ margin-block: 3rem }
    .section-title{ font-weight: 800; letter-spacing:.2px; color:var(--brand); margin-bottom: .75rem }
    .small-muted{ color: var(--muted) }
    .clamp-2{ display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden }
    .clamp-3{ display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden }

    /* Header tighten + shrink on scroll */
    .site-header{ height:72px; transition:box-shadow .2s,height .2s }
    .site-header.shrink{ height:62px; box-shadow:0 6px 18px rgba(0,0,0,.08) }
    .logo-badge img{ height:44px; transition: transform .2s }
    .site-header.shrink .logo-badge img{ transform: scale(.94) }
 
 .cart-data
 {min-height:500px;}
    /* Buttons */
    .btn-cta{ background:var(--accent); color:#fff; border-radius:12px; padding:.6rem 1rem; font-weight:700; border:none; padding-top:10px; border:1px solid transparent; }
    .btn-cta:hover{background:var(--accent); border:1px solid var(--accent);color:var(--accent); }
    
    .btn-outline-arrow{ display:flex; justify-content:space-between; align-items:center; gap:12px;
      padding:.8rem 1rem; border:1px solid var(--line); border-radius:12px; background:#fff; font-weight:600; color:var(--ink) }
    .btn-outline-arrow:hover{ border-color:var(--brand); color:var(--brand) }
  
    .btn-outline{    border-radius: 12px;  padding: .6rem 1rem; border: 1px solid var(--line);align-items:center; text-align:center; gap:12px;      background:#fff; font-weight:600; color:var(--ink) }
    .btn-outline:hover{ border-color:var(--brand); color:var(--brand) }
   
.btn-dark {
	 
    border-radius: 12px!important;
    padding: .6rem 1rem; border: 1px solid transparent;     border-radius: var(--bs-btn-border-radius);
}

    /* News cards */
    .card.news{ border-radius:16px }
    .card.news .card-img{ height: clamp(220px, 24vw, 360px); object-fit:cover }
    .card.news .card-img-overlay{
      background:linear-gradient(180deg, rgba(0,0,0,0) 40%, rgba(0,0,0,.55) 100%);
      padding: 1rem 1rem 1.1rem
    }
    .card.news .badge{ background:#ffffffd6; color:#0b132b; font-weight:700 }

    /* Stats + chips */
    .stats{ background:#fff; border:1px solid var(--line); border-radius:16px }
    .stat-card{ background:#fff; border:1px dashed var(--line); border-radius:14px; padding:14px }
 
   /* Search modal header with logo */
.modal-fullscreen .modal-header{
  position: sticky; top: 0; z-index: 1060;
  background:#fff; border-bottom:1px solid var(--line);
  padding: 0; /* layout rieši vnútorný .container */
}
.search-header.container{ display:flex; align-items:center; gap:12px; padding:.75rem 1rem }
/* logo s modrým podkladom */
.search-brand{ display:inline-flex; align-items:center; background:var(--brand); padding:8px 12px; border-radius:12px }
.search-brand img{ height:40px; display:block }
/* krížik vždy vpravo a hore */
.modal-header .btn-close{ margin-left:auto; position:relative; z-index:1061 }
.modal-header .btn-close:focus{ box-shadow:0 0 0 .25rem rgba(47,60,149,.25) }

 .about-features{ display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); padding:10px; gap:10px; margin-top:10px }
    .about-features .chip{ display:block; background:#fff; border:1px solid var(--line); border-radius:12px; padding:10px 12px; color:#0f2435; font-weight:500 }
    .about-features .chip:hover{ color:var(--brand); border-color:var(--brand) }


    /* Responsive misc */
    @media (max-width: 991.98px){
      .main-nav{ display:none }
      .usp .item{ padding:14px }
      .cat-card .thumb{ height:120px }
    }
    @media (prefers-reduced-motion: reduce){
      *{ transition:none!important; animation:none!important }
    }
    /* Virtuálna prehliadka – full-width banner v container-i */
.tour-banner{
  position:relative; display:block; border-radius:16px; overflow:hidden;
}
.tour-banner .media{
  position:relative; width:100%; aspect-ratio: 24/9;  /* pekný široký pomer (mení sa podľa potreby) */
  background:#000 center/cover no-repeat;
}
.tour-banner img{
  width:100%; height:100%; object-fit:cover; display:block;
}
.tour-banner::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(15,23,42,.25), rgba(15,23,42,.55));
}
.tour-banner .content{
  position:absolute; inset:0; display:grid; place-items:center; text-align:center;
  z-index:9999;
  padding: clamp(16px, 4vw, 28px);
}
.tour-banner h3{ color:#fff; font-weight:800; letter-spacing:.2px; margin:0 0 8px }
.tour-banner p{ color:#e2e8f0; margin:0 0 14px }
.tour-banner .play{
  width:64px; height:64px; border-radius:999px; display:grid; place-items:center;
  background:rgba(255,255,255,.92); color:var(--brand); box-shadow:0 10px 30px rgba(0,0,0,.25);
  transition: transform .15s ease, filter .15s ease;
}
.tour-banner .play svg{ width:22px; height:22px; margin-left:2px }
.tour-banner:hover .play{ transform:scale(1.04); filter:drop-shadow(0 6px 16px rgba(0,0,0,.18)); }
.card-img-top {
    height: 280px;
    object-fit: cover;
}
/* čitateľnejší overlay v hero */
.overlay-strong{ background:linear-gradient(90deg, rgba(15,23,42,.72), rgba(15,23,42,.38) 48%, rgba(15,23,42,0) 74%) }

/* stat karty – rovnaká výška a vyrovnanie */
.cols .stat{ display:flex; flex-direction:column; gap:2px; min-height:110px; justify-content:center }
.stat .val{ font-size:2.1rem; font-weight:900; color:var(--brand); letter-spacing:-.5px }

/* USP karty */
.usp{ display:flex; gap:10px; align-items:flex-start }
.usp-ico{ font-size:22px; line-height:1; }
.usp-ttl{ font-weight:800; margin-bottom:2px }

/* koláž obrázkov (3 dlaždice, rovnaké okraje) */
.grid-collage{
  display:grid; gap:10px; grid-template-columns:repeat(3,1fr);
}
.grid-collage img{
  width:100%; aspect-ratio: 4/3; object-fit:cover; border:1px solid var(--line); border-radius:16px; display:block;
}

/* galéria – responsívna mriežka s rovnakou výškou riadkov */
.gallery{
  display:grid; gap:12px;
  grid-template-columns:repeat(4,minmax(0,1fr));
}
.gallery img{
  width:100%; aspect-ratio: 1/1; object-fit:cover;
  border:1px solid var(--line); border-radius:16px; display:block;
}
@media (max-width: 1199.98px){ .gallery{ grid-template-columns:repeat(3,1fr) } }
@media (max-width: 767.98px){ .gallery{ grid-template-columns:repeat(2,1fr) } }

/* timeline jemné vyrovnanie */
.timeline li{ align-items:baseline }
.timeline li > div:first-child{ font-weight:800; color:var(--brand) }
 
    @media (max-width: 991.98px){ .sec{ padding-block: var(--space-3); } }

    .section-title{ margin-bottom:.75rem; }
    .card{ background:#fff; border:1px solid var(--line); border-radius:16px; }
    .card.pad{ padding:16px; }

    /* hero */
    .hero{ position:relative; overflow:hidden; border-radius:16px; box-shadow:var(--shadow); }
    .hero .bg{ position:absolute; inset:0; background:center/cover no-repeat; }
    .hero .overlay{ position:absolute; inset:0;
      background:linear-gradient(90deg, rgba(15,23,42,.72), rgba(15,23,42,.35) 50%, rgba(15,23,42,0) 78%); }
    .hero .body{ position:relative; z-index:1; padding:48px; }
    @media (max-width: 767.98px){ .hero .body{ padding:28px; } }
    .btn-ghost{ border:1px solid #ffffff4a; color:#fff; border-radius:12px; padding:.6rem 1rem; font-weight:700; background:#ffffff22; }
    .btn-ghost:hover{ filter:brightness(.95); color:#fff; }

    /* mriežky */
    .cols{ display:grid; gap:16px; }
    .cols-2{ grid-template-columns:repeat(2,minmax(0,1fr)); }
    .cols-3{ grid-template-columns:repeat(3,minmax(0,1fr)); }
    .cols-4{ grid-template-columns:repeat(4,minmax(0,1fr)); }
    @media (max-width:1199.98px){ .cols-4{ grid-template-columns:repeat(3,1fr); } }
    @media (max-width:991.98px){ .cols-3{ grid-template-columns:repeat(2,1fr); } }
    @media (max-width:767.98px){ .cols-2,.cols-3,.cols-4{ grid-template-columns:1fr; } }

    /* stat karty */
    .stat{ padding:16px; }
    .stat .val{ font-weight:900; font-size:clamp(20px,3vw,28px); }
    .stat .text-muted{ font-weight:600; }

    /* USP */
    .usp{ display:flex; gap:10px; align-items:flex-start; padding:14px; }
    .usp-ico{ font-size:20px; line-height:1; margin-top:2px; }
    .usp-ttl{ font-weight:800; }

    /* koláž */
    .grid-collage{ display:grid; gap:12px; grid-template-columns:repeat(3,minmax(0,1fr)); }
    .grid-collage img{
      width:100%; aspect-ratio:4/3; object-fit:cover;
      border:1px solid var(--line); border-radius:16px; display:block;
    }

    /* galéria masonry */
    .gallery{ column-count:4; column-gap:16px; }
    .gallery>img{
      width:100%; display:block; margin:0 0 16px; break-inside:avoid;
      border-radius:16px; border:1px solid var(--line);
      transition:transform .2s ease, box-shadow .2s ease;
    }
    .gallery>img:hover{ transform:translateY(-2px); box-shadow:var(--shadow); }
    @media (max-width:1399.98px){ .gallery{ column-count:3; } }
    @media (max-width:991.98px){ .gallery{ column-count:2; } }
    @media (max-width:575.98px){ .gallery{ column-count:1; } }

    /* timeline */
    .timeline{ position:relative; padding-left:18px; list-style:none; margin:0; }
    .timeline::before{ content:""; position:absolute; left:4px; top:2px; bottom:2px; width:2px; background:var(--line); }
    .timeline li{ position:relative; padding-left:12px; display:grid; grid-template-columns:90px 1fr; gap:12px; }
    .timeline li::before{
      content:""; position:absolute; left:-3px; top:.55rem; width:8px; height:8px; border-radius:999px; background:var(--brand);
    }
    .timeline .year{ width:90px; color:var(--muted); font-weight:700; }

    /* utility obrázky */
    .img-fit{ width:100%; height:auto; display:block; border-radius:16px; }
    .ratio-16x10{ aspect-ratio:16/10; object-fit:cover; }
    
    /* ===== Refined look patch for "O nás" page ===== */

:root{
  --space-1: 10px;
  --space-2: 18px;
  --space-3: 30px;
  --space-4: 48px;
}
 

.card.pad {
  padding: 24px 28px;
}
.card p {
  line-height: 1.75;
  font-size: 1.05rem;
  font-weight: 400;
  letter-spacing: 0.1px;
  color: #2b2b2b;
}

/* Nadpisy */
h2.section-title, h3, h4 {
  font-family: "Poppins", sans-serif;
  font-weight: 700;
  letter-spacing: 0.2px;
}
h3.mb-2 { font-size: 1.35rem; }

/* Hero - menej kontrastný gradient a jemný blur */
.hero .overlay {
  background: linear-gradient(90deg, rgba(15,23,42,.68), rgba(15,23,42,.25) 50%, rgba(15,23,42,0) 80%);
  backdrop-filter: blur(1px);
}

/* Lepší spacing medzi sekciami */
.about .card:not(:last-child) {
  margin-bottom: var(--space-3);
}

/* Textové bloky v 2 stĺpcoch na širších viewportoch */
@media (min-width: 992px){
  .text-cols-2 {
    column-count: 2;
    column-gap: 40px;
  }
}

/* USP cards */
.card.usp {
  padding: 18px 22px;
  background: #f9fafc;
  border: 1px solid #eef0f3;
}
.usp-ttl {
  font-weight: 700;
  font-size: 1.05rem;
}
.usp .text-muted {
  font-size: 0.95rem;
}

/* Timeline vizuálne čistejšie */
.timeline li {
  padding-left: 16px;
}
.timeline li::before {
  top: 0.6rem;
  background: var(--brand);
  width: 10px;
  height: 10px;
}

/* Jemný efekt hover na obrázky */
.img-fit:hover {
  transform: scale(1.02);
  transition: transform .25s ease, box-shadow .25s ease;
  box-shadow: 0 4px 12px rgba(0,0,0,.08);
}
.gallery > img:hover {
  transform: scale(1.02);
}

/* Karty s obrázkami – viac zaoblené, mäkké tiene */
.grid-collage img {
  border-radius: 20px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.05);
}
/* ===== Spacing utilities ===== */
:root{
  --sp-0: 0;
  --sp-1: .25rem;   /* 4px  */
  --sp-2: .5rem;    /* 8px  */
  --sp-3: .75rem;   /* 12px */
  --sp-4: 1rem;     /* 16px */
  --sp-5: 1.5rem;   /* 24px */
  --sp-6: 2rem;     /* 32px */
  --sp-7: 3rem;     /* 48px */
  --sp-8: 4rem;     /* 64px */
}

/* helpers for x/y axes */
.mx-0 { margin-left: var(--sp-0); margin-right: var(--sp-0); }
.mx-1 { margin-left: var(--sp-1); margin-right: var(--sp-1); }
.mx-2 { margin-left: var(--sp-2); margin-right: var(--sp-2); }
.mx-3 { margin-left: var(--sp-3); margin-right: var(--sp-3); }
.mx-4 { margin-left: var(--sp-4); margin-right: var(--sp-4); }
.mx-5 { margin-left: var(--sp-5); margin-right: var(--sp-5); }
.mx-6 { margin-left: var(--sp-6); margin-right: var(--sp-6); }
.mx-7 { margin-left: var(--sp-7); margin-right: var(--sp-7); }
.mx-8 { margin-left: var(--sp-8); margin-right: var(--sp-8); }

.my-0 { margin-top: var(--sp-0); margin-bottom: var(--sp-0); }
.my-1 { margin-top: var(--sp-1); margin-bottom: var(--sp-1); }
.my-2 { margin-top: var(--sp-2); margin-bottom: var(--sp-2); }
.my-3 { margin-top: var(--sp-3); margin-bottom: var(--sp-3); }
.my-4 { margin-top: var(--sp-4); margin-bottom: var(--sp-4); }
.my-5 { margin-top: var(--sp-5); margin-bottom: var(--sp-5); }
.my-6 { margin-top: var(--sp-6); margin-bottom: var(--sp-6); }
.my-7 { margin-top: var(--sp-7); margin-bottom: var(--sp-7); }
.my-8 { margin-top: var(--sp-8); margin-bottom: var(--sp-8); }

/* margin – all sides */
.m-0 { margin: var(--sp-0); } .m-1 { margin: var(--sp-1); }
.m-2 { margin: var(--sp-2); } .m-3 { margin: var(--sp-3); }
.m-4 { margin: var(--sp-4); } .m-5 { margin: var(--sp-5); }
.m-6 { margin: var(--sp-6); } .m-7 { margin: var(--sp-7); }
.m-8 { margin: var(--sp-8); }

/* margin – single sides */
.mt-0 { margin-top: var(--sp-0); } .mt-1 { margin-top: var(--sp-1); }
.mt-2 { margin-top: var(--sp-2); } .mt-3 { margin-top: var(--sp-3); }
.mt-4 { margin-top: var(--sp-4); } .mt-5 { margin-top: var(--sp-5); }
.mt-6 { margin-top: var(--sp-6); } .mt-7 { margin-top: var(--sp-7); }
.mt-8 { margin-top: var(--sp-8); }

.mr-0 { margin-right: var(--sp-0); } .mr-1 { margin-right: var(--sp-1); }
.mr-2 { margin-right: var(--sp-2); } .mr-3 { margin-right: var(--sp-3); }
.mr-4 { margin-right: var(--sp-4); } .mr-5 { margin-right: var(--sp-5); }
.mr-6 { margin-right: var(--sp-6); } .mr-7 { margin-right: var(--sp-7); }
.mr-8 { margin-right: var(--sp-8); }

.mb-0 { margin-bottom: var(--sp-0); } .mb-1 { margin-bottom: var(--sp-1); }
.mb-2 { margin-bottom: var(--sp-2); } .mb-3 { margin-bottom: var(--sp-3); }
.mb-4 { margin-bottom: var(--sp-4); } .mb-5 { margin-bottom: var(--sp-5); }
.mb-6 { margin-bottom: var(--sp-6); } .mb-7 { margin-bottom: var(--sp-7); }
.mb-8 { margin-bottom: var(--sp-8); }

.ml-0 { margin-left: var(--sp-0); } .ml-1 { margin-left: var(--sp-1); }
.ml-2 { margin-left: var(--sp-2); } .ml-3 { margin-left: var(--sp-3); }
.ml-4 { margin-left: var(--sp-4); } .ml-5 { margin-left: var(--sp-5); }
.ml-6 { margin-left: var(--sp-6); } .ml-7 { margin-left: var(--sp-7); }
.ml-8 { margin-left: var(--sp-8); }

/* padding – axes */
.px-0 { padding-left: var(--sp-0); padding-right: var(--sp-0); }
.px-1 { padding-left: var(--sp-1); padding-right: var(--sp-1); }
.px-2 { padding-left: var(--sp-2); padding-right: var(--sp-2); }
.px-3 { padding-left: var(--sp-3); padding-right: var(--sp-3); }
.px-4 { padding-left: var(--sp-4); padding-right: var(--sp-4); }
.px-5 { padding-left: var(--sp-5); padding-right: var(--sp-5); }
.px-6 { padding-left: var(--sp-6); padding-right: var(--sp-6); }
.px-7 { padding-left: var(--sp-7); padding-right: var(--sp-7); }
.px-8 { padding-left: var(--sp-8); padding-right: var(--sp-8); }

.py-0 { padding-top: var(--sp-0); padding-bottom: var(--sp-0); }
.py-1 { padding-top: var(--sp-1); padding-bottom: var(--sp-1); }
.py-2 { padding-top: var(--sp-2); padding-bottom: var(--sp-2); }
.py-3 { padding-top: var(--sp-3); padding-bottom: var(--sp-3); }
.py-4 { padding-top: var(--sp-4); padding-bottom: var(--sp-4); }
.py-5 { padding-top: var(--sp-5); padding-bottom: var(--sp-5); }
.py-6 { padding-top: var(--sp-6); padding-bottom: var(--sp-6); }
.py-7 { padding-top: var(--sp-7); padding-bottom: var(--sp-7); }
.py-8 { padding-top: var(--sp-8); padding-bottom: var(--sp-8); }

/* padding – all sides */
.p-0 { padding: var(--sp-0); } .p-1 { padding: var(--sp-1); }
.p-2 { padding: var(--sp-2); } .p-3 { padding: var(--sp-3); }
.p-4 { padding: var(--sp-4); } .p-5 { padding: var(--sp-5); }
.p-6 { padding: var(--sp-6); } .p-7 { padding: var(--sp-7); }
.p-8 { padding: var(--sp-8); }

/* padding – single sides */
.pt-0 { padding-top: var(--sp-0); } .pt-1 { padding-top: var(--sp-1); }
.pt-2 { padding-top: var(--sp-2); } .pt-3 { padding-top: var(--sp-3); }
.pt-4 { padding-top: var(--sp-4); } .pt-5 { padding-top: var(--sp-5); }
.pt-6 { padding-top: var(--sp-6); } .pt-7 { padding-top: var(--sp-7); }
.pt-8 { padding-top: var(--sp-8); }

.pr-0 { padding-right: var(--sp-0); } .pr-1 { padding-right: var(--sp-1); }
.pr-2 { padding-right: var(--sp-2); } .pr-3 { padding-right: var(--sp-3); }
.pr-4 { padding-right: var(--sp-4); } .pr-5 { padding-right: var(--sp-5); }
.pr-6 { padding-right: var(--sp-6); } .pr-7 { padding-right: var(--sp-7); }
.pr-8 { padding-right: var(--sp-8); }

.pb-0 { padding-bottom: var(--sp-0); } .pb-1 { padding-bottom: var(--sp-1); }
.pb-2 { padding-bottom: var(--sp-2); } .pb-3 { padding-bottom: var(--sp-3); }
.pb-4 { padding-bottom: var(--sp-4); } .pb-5 { padding-bottom: var(--sp-5); }
.pb-6 { padding-bottom: var(--sp-6); } .pb-7 { padding-bottom: var(--sp-7); }
.pb-8 { padding-bottom: var(--sp-8); }

.pl-0 { padding-left: var(--sp-0); } .pl-1 { padding-left: var(--sp-1); }
.pl-2 { padding-left: var(--sp-2); } .pl-3 { padding-left: var(--sp-3); }
.pl-4 { padding-left: var(--sp-4); } .pl-5 { padding-left: var(--sp-5); }
.pl-6 { padding-left: var(--sp-6); } .pl-7 { padding-left: var(--sp-7); }
.pl-8 { padding-left: var(--sp-8); }.brands { position: relative; overflow: hidden; }

.brand-strip{
  display: flex;
  gap: 24px;
  overflow-x: auto;
  padding: 8px 4px;
  scroll-behavior: smooth;
  scrollbar-width: none;          /* Firefox */
}
.brand-strip::-webkit-scrollbar{  /* Chrome, Edge */
  display: none;
}

.brand-item{
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 6px 12px;
} 
.brand-item:hover img{
  filter: none;
  opacity: 1;
  transform: translateY(-2px);
}

.text-green
{color:green;}

.text-orange
{color:orange;}

/* šípky */
.brand-nav{
  width: 34px;
  height: 34px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: #fff;
  display: grid;
  place-items: center;
  font-size: 20px;
  line-height: 1;
  padding: 0;
  cursor: pointer;
}
.brand-nav:hover{
  border-color: var(--brand);
  color: var(--brand);
}

.brands-slider{
  overflow: hidden;
  position: relative;
}

.brands-track{
  display: inline-flex;
  align-items: center;
  gap: 42px;
  /* nekonečná animácia */
  animation: brands-marquee 30s linear infinite;
}

.brands-track:hover{
  animation-play-state: paused; /* pri hoveri sa zastaví */
}

.brand-item{
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 6px 21px;
}

.brand-item img{
             /* uprav podľa potreby */
    width: auto;
    max-width: 147px;
    max-height: 76px;
    height: auto;
  filter: grayscale(100%);
  opacity: 0.75;
  transition: filter .2s ease, opacity .2s ease, transform .2s ease;
}

.brand-item:hover img{
  filter: grayscale(0%);
  opacity: 1;
  transform: translateY(-2px);
}

/* nekonečná slučka – posun o polovicu šírky (2x sada log) */
@keyframes brands-marquee{
  0%{
    transform: translateX(0);
  }
  100%{
    transform: translateX(-50%);
  }
}



/* USP pás na úvodnej stránke */
.usp-strip{
  background:#fff;
  border:1px solid var(--line);
  border-radius:20px;
  padding:18px 24px;
}

.usp-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px 32px;
  align-items:flex-start;
}

@media (max-width: 991.98px){
  .usp-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
    row-gap:18px;
  }
}

@media (max-width: 575.98px){
  .usp-grid{
    grid-template-columns:1fr;
  }
}

.usp-item{
  display:flex;
  gap:12px;
  align-items:flex-start;
}

.usp-icon{
  width:25px;
  height:25px;
  border-radius:999px;
  display:grid;
  place-items:center;
  background:#eef2ff;
  color:var(--brand);
  font-size:14px;
  flex-shrink:0;
  margin-right:7px;
  margin-left:-17px;
}
.usp-icon img{
  width:35px;
  height:35px;
}

.usp-title{
  font-weight:700;
  margin-bottom:2px;
}

.usp-desc{
  font-size:.75rem;
  color:var(--muted);
}
.w-100
{width:100%}
/* Súvisiace produkty – 3 karty + stĺpec kontakt */
.rel-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media (max-width: 992px){ .rel-grid{grid-template-columns:1fr 1fr} }
.rel-card{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden}
.rel-card .thumb{aspect-ratio:4/3;background:#f3f4f6 center/cover no-repeat}
.rel-card .body{padding:10px}
.rel-contacts{display:flex;flex-direction:column;gap:10px;justify-content:stretch}
.rel-contacts a{display:flex;gap:10px;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:12px;padding:.65rem 1rem;background:#fff;font-weight:700}
.rel-contacts a:hover{border-color:var(--brand);color:var(--brand)}


.header-cart {
  display: inline-block;
  position: relative;
}
.header-carticon, .header-carticon-empty {
  display: inline-block;
  position: relative;
  text-align: center; 
  color: #1e1e1e;
  border-radius: 100%;
  font-size: 24px;
  font-weight: 700;
  height: 48px;
  width: 48px;
  margin-top:4px;
  line-height: 1;
  vertical-align: middle; 
}

.select-registration .login-button
{ white-space:nowrap;}
.header-carticon i,
.header-carticon-empty i {
  line-height: 48px;
}
.header-cart
{padding:0;
	}
.header-carticon span.count,
.header-carticon-empty span.count {
  position: absolute;
  top: -11px;
  right: -6px;
  display: block;
  overflow: hidden;
  width: 21px;
  height: 21px;
  line-height: 21px;
  font-weight: 400;
  font-size: 12px;
  font-family:monospace;
  color: #fff;
  background: var(--brand);
  text-align: center;
  border-radius: 100%;
}
.header-carticon:hover, .header-carticon.is-active,
.header-carticon-empty:hover, .header-carticon-empty.is-active {
  
}
.header-minicart {
  position: absolute;
  right: 0;
  top: 100%;
  z-index: 9;
  display: none;
}

/* ===== LIGHTBOX – ZÁKLAD ===== */

.gallery-lightbox-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.85);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  opacity: 0;
  pointer-events: none;
  transition: opacity .18s ease-out;
}

.gallery-lightbox-backdrop.is-open {
  opacity: 1;
  pointer-events: auto;
}

.gallery-lightbox-inner {
  max-width: min(1100px, 96vw);
  max-height: 92vh;
  padding: 16px 16px 20px;
  background: #0f172a;
  border-radius: 18px;
  box-shadow: 0 20px 60px rgba(15, 15, 35, 0.6);
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.gallery-lightbox-image-wrap {
  position: relative;
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

.gallery-lightbox-image-wrap img {
  max-width: 100%;
  max-height: 80vh;
  display: block;
  border-radius: 12px;
  box-shadow: 0 12px 35px rgba(0, 0, 0, 0.55);
}

/* Caption */
.gallery-lightbox-caption {
  color: #e5e7eb;
  font-size: .9rem;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: baseline;
}

.gallery-lightbox-caption-main {
  flex: 1;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.gallery-lightbox-counter {
  font-size: .8rem;
  opacity: .7;
}

/* Close + arrows */

.gallery-lightbox-close {
  position: absolute;
  top: 10px;
  right: 12px;
  border: 0;
  background: rgba(15, 23, 42, 0.8);
  color: #e5e7eb;
  width: 32px;
  height: 32px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 1.1rem;
}

.gallery-lightbox-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  border: 0;
  background: rgba(15, 23, 42, 0.8);
  color: #e5e7eb;
  width: 38px;
  height: 38px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 1.1rem;
}

.gallery-lightbox-nav.prev { left: 8px; }
.gallery-lightbox-nav.next { right: 8px; }

.gallery-lightbox-close:hover,
.gallery-lightbox-nav:hover {
  background: rgba(15, 23, 42, 0.95);
}

/* Na mobiloch natiahnuť trochu viac do výšky */
@media (max-width: 640px) {
  .gallery-lightbox-inner {
    width: 100%;
    height: 100%;
    border-radius: 0;
    max-height: 100vh;
  }

  .gallery-lightbox-image-wrap img {
    max-height: 82vh;
  }
}

.insp-hero .hero {
  position: relative;
  border-radius: 18px;
  overflow: hidden;
  min-height: 260px;
}

.insp-hero .hero .bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transform: scale(1.03);
  filter: brightness(0.85);
}

.insp-hero .hero .overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(5, 24, 72, 0.9) 0%, rgba(5, 24, 72, 0.05) 70%);
}

.insp-hero .hero .body {
  position: relative;
  padding: 40px 42px;
  max-width: 540px;
}

@media (max-width: 768px) {
  .insp-hero .hero .body {
    padding: 28px 20px 32px;
  }
}

/* =====================  MALÉ USP BLOKY POD HERO  ===================== */

.insp-mini-usp .card.pad {
  border-radius: 16px;
  border: 1px solid #edf0f5;
  box-shadow: 0 10px 25px rgba(15, 23, 42, 0.03);
}

/* =====================  FILTER BAR  ===================== */

.insp-filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-start;
}

.insp-filter {
  border: 1px solid #d6dce8;
  background-color: #fff;
  color: #111827;
  padding: 6px 14px;
  border-radius: 999px;
  font-size: 0.9rem;
  line-height: 1.4;
  cursor: pointer;
  transition: all .18s ease-out;
  white-space: nowrap;
}

.insp-filter:hover {
  border-color: #0f766e;
  color: #0f766e;
  background-color: #ecfdf5;
}

.insp-filter.active {
  background: #0f766e;
  border-color: #0f766e;
  color: #fff;
  box-shadow: 0 10px 20px rgba(15, 118, 110, 0.28);
}

/* =====================  GRID REALIZÁCIÍ  ===================== */

.insp-grid {
  gap: 18px;
}

.insp-card {
  border-radius: 18px;
  border: 1px solid #edf0f5;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  background-color: #fff;
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
  transition: transform .18s ease-out, box-shadow .18s ease-out;
}

.insp-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.12);
}

.insp-card-img {
  display: block;
  position: relative;
  overflow: hidden;
}

.insp-card-img img {
  display: block;
  width: 100%;
  height: auto;
  border-bottom: 1px solid #edf0f5;
  transition: transform .25s ease-out;
}

.insp-card:hover .insp-card-img img {
  transform: scale(1.03);
}

.insp-card .pad {
  padding: 14px 16px 16px;
}

.insp-card-meta .badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 0.78rem;
  line-height: 1.3;
}

.badge.bg-light {
  background-color: #f3f4ff;
  color: #4b5563;
}

.badge.bg-soft {
  background-color: #ecfdf5;
  color: #047857;
}

/* nadpis + popis v karte */
.insp-card h3 {
  font-size: 0.98rem;
  margin-bottom: 4px;
}

.insp-card .small {
  font-size: 0.8rem;
}

/* =====================  GALÉRIA DETAILOV  ===================== */

.sec .gallery {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 14px;
}

.sec .gallery img {
  border-radius: 18px;
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  aspect-ratio: 4 / 3;
}

@media (max-width: 992px) {
  .sec .gallery {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .sec .gallery {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* =====================  CTA PÁS  ===================== */

.insp-cta {
  border-radius: 18px;
  border: 1px solid #edf0f5;
  background: #f8fafc;
}

/* =====================  KONTAKTNÝ FORMULÁR  ===================== */

.contact-card {
  border-radius: 18px;
  border: 1px solid #edf0f5;
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.05);
}

.contact-form .form-label {
  font-size: 0.9rem;
  font-weight: 600;
  color: #111827;
}

.contact-form .form-control {
  border-radius: 10px;
  border: 1px solid #d6dce8;
  font-size: 0.92rem;
  padding: 0.55rem 0.8rem;
  transition: border-color .15s ease-out, box-shadow .15s ease-out, background-color .15s ease-out;
}

.contact-form .form-control:focus {
  border-color: #0f766e;
  box-shadow: 0 0 0 1px rgba(15, 118, 110, 0.3);
  outline: none;
  background-color: #fff;
}

.contact-form button.btn.btn-cta {
  margin-top: 4px;
  min-width: 190px;
}


/* ===== LIGHTBOX – ZÁKLAD ===== */

.gallery-lightbox-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.85);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  opacity: 0;
  pointer-events: none;
  transition: opacity .18s ease-out;
}

.gallery-lightbox-backdrop.is-open {
  opacity: 1;
  pointer-events: auto;
}

.gallery-lightbox-inner {
  max-width: min(1100px, 96vw);
  max-height: 92vh;
  padding: 16px 16px 20px;
  background: #0f172a;
  border-radius: 18px;
  box-shadow: 0 20px 60px rgba(15, 15, 35, 0.6);
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.gallery-lightbox-image-wrap {
  position: relative;
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

.gallery-lightbox-image-wrap img {
  max-width: 100%;
  max-height: 80vh;
  display: block;
  border-radius: 12px;
  box-shadow: 0 12px 35px rgba(0, 0, 0, 0.55);
}

/* Caption */
.gallery-lightbox-caption {
  color: #e5e7eb;
  font-size: .9rem;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: baseline;
}

.gallery-lightbox-caption-main {
  flex: 1;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.gallery-lightbox-counter {
  font-size: .8rem;
  opacity: .7;
}

/* Close + arrows */

.gallery-lightbox-close {
  position: absolute;
  top: 10px;
  right: 12px;
  border: 0;
  background: rgba(15, 23, 42, 0.8);
  color: #e5e7eb;
  width: 32px;
  height: 32px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 1.1rem;
}

.gallery-lightbox-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  border: 0;
  background: rgba(15, 23, 42, 0.8);
  color: #e5e7eb;
  width: 38px;
  height: 38px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 1.1rem;
}

.gallery-lightbox-nav.prev { left: 8px; }
.gallery-lightbox-nav.next { right: 8px; }

.gallery-lightbox-close:hover,
.gallery-lightbox-nav:hover {
  background: rgba(15, 23, 42, 0.95);
}

/* Na mobiloch natiahnuť trochu viac do výšky */
@media (max-width: 640px) {
  .gallery-lightbox-inner {
    width: 100%;
    height: 100%;
    border-radius: 0;
    max-height: 100vh;
  }

  .gallery-lightbox-image-wrap img {
    max-height: 82vh;
  }
}

 
/**
 * Minicart
 */
.minicart {
  border-bottom: 2px solid var(--brand);
  width: 350px;
  background: #ffffff;
  text-align: left;
  padding: 20px;
  padding-top: 20px;
  -webkit-box-shadow: -3px 5px 8px 5px rgba(0, 0, 0, 0.1);
          box-shadow: -3px 5px 8px 5px rgba(0, 0, 0, 0.1);
}
.minicart-header {
  max-height: 230px;
  overflow-y: auto;
}
.minicart-product {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 20px;
  position:relative;
}
.minicart-productcontent h6 {
  font-weight: 400;
  margin-bottom: 5px;
}
.minicart-productcontent h6 a {
  color: #1e1e1e;
}
.minicart-productcontent h6 a:hover {
  color: var(--brand);
}
.minicart-productcontent .minicart-productprice {
  color: var(--brand);
  font-size: 16px;
  font-weight: 700;
}
.minicart-productimage {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 70px;
          flex: 0 0 70px;
  max-width: 70px;
  margin-right: 20px;
  position: relative;
}
.minicart-productimage a {
  display: inline-block;
}
.minicart-productcontent h5
{margin-bottom:0;}
.minicart-productcontent a
{
	display: inline-block;
  font-size: 14px;
  color:#000;
}
.minicart-productcontent a:hover
{ 
  color:var(--brand);
}
#header-cart
{cursor:pointer;}
.minicart-productimage img {
  width: 100%;
}

.minicart-productcontent strong
{font-size:12px;}
.float-right
{float:right;}
.minicart-productimage .minicart-productquantity {
     position: absolute;
    left: 0;
    top: 0;
    background: var(--brand);
    height: 22px;
    width: 27px;
    line-height: 24px;
    text-align: center;
    border-bottom-right-radius: 6px;
    font-size: 12px;
    text-transform: uppercase;
    color: #ffffff;
    font-family: monospace;
}
.minicart-productimage .minicart-productquantity small
{font-size:10px;}
.minicart-productcontent {
  padding-right: 10px;
}
 del
 {font-weight:bolder;
 	opacity:.75;
 	color:#6b7280;}
.minicart-productclose {
  height: 30px;
  width: auto;
  padding: 0;
  line-height: 1;
  border: none;
  font-size: 18px;
  position:absolute;
    right: 7px;
    top: 15px;
    background-color:transparent;
}
.minicart-productclose:hover {
  color: var(--brand);
}
.minicart-pricing {
  padding-left: 0;
  padding-top: 20px;
  margin-bottom: 20px;
  list-style: none;
  border-top: 1px solid #e5e5e5;
}
.minicart-pricing li {
  list-style: none;
  display: block;
  color: #7e7e7e;
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 5px;
}
.minicart-pricing li::after {
  content: "";
  clear: both;
  display: table;
}
.minicart-pricing li span {
  color: var(--brand);
  float: right;
}
.minicart-footer .btn {
  margin-top: 10px;
}


.btn-fullwidth
{
	width:100%;
}
@media only screen and (max-width: 575px) {
  .minicart {
    width: 290px;
    padding: 15px;
  }
  .minicart-productimage {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 50px;
            flex: 0 0 50px;
    max-width: 50px;
    margin-right: 10px;
  }
  .minicart-productimage .minicart-productquantity {
    height: 22px;
    width: 22px;
    line-height: 24px;
    font-size: 10px;
  }
  .minicart-header {
    padding-top: 10px;
  }
}

 .btn-cta:hover{ border-color:var(--accent); background-color:#fff; color:var(--accent) }

.form-control{display:block;width:100%;height:calc(1.5em + .9rem + 7px);padding:.45rem .85rem;font-size:1rem;font-weight:400;line-height:1.5;color:#495057;background-color:#fff;background-clip:padding-box;border:1px solid #ced4da;border-radius:.37rem;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out;}
@media (prefers-reduced-motion:reduce){
.form-control{transition:none;}
}
.form-control:focus{color:#495057;background-color:#fff;border-color:#a5bdf6;outline:0;box-shadow:0 0 0 .2rem rgba(49,103,235,.25);}
.form-control::placeholder{color:#ced4da;opacity:1;}
.form-control:disabled{background-color:#e4e4e4;opacity:1;}
.btn:focus{outline:0;box-shadow:0 0 0 .2rem rgba(49,103,235,.25);}
.btn:disabled{opacity:.55;cursor:not-allowed;}
.input-group{position:relative;display:flex;flex-wrap:wrap;align-items:stretch;width:100%;}
.input-group>.form-control{position:relative;flex:1 1 auto;width:1%;margin-bottom:0;}
.input-group>.form-control:focus{z-index:3;}
.input-group>.form-control:not(:last-child){border-top-right-radius:0;border-bottom-right-radius:0;}
.input-group>.form-control:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0;}
.input-group-append,.input-group-prepend{display:flex;}
.input-group-append .btn,.input-group-prepend .btn{position:relative;z-index:2;}
.input-group-append .btn:focus,.input-group-prepend .btn:focus{z-index:3;}
.input-group-prepend{margin-right:-1px;}
.input-group-append{margin-left:-1px;}
.price-per-quantity{ width:150px}
.price-per-quantity .value{ width:150px; display:block; text-align:right;padding-right:10px}
.input-group>.input-group-prepend>.btn{border-top-right-radius:0;border-bottom-right-radius:0;}
.input-group>.input-group-append>.btn{border-top-left-radius:0;border-bottom-left-radius:0;}
.text-center{text-align:center!important;}
@media print{
*,::after,::before{text-shadow:none!important;box-shadow:none!important;}
}
.btn-light{background-color:#fff;border-color:#e4e4e4;}
.btn-light i{color:#969696;}
.btn-light:hover{background-color:#fff;border-color:#989898;}
.input-spinner{width:125px;flex-wrap:nowrap;display:inline-flex;vertical-align:middle;}
.input-spinner input.form-control{text-align:center;width:auto; max-width:53px;min-width:unset;font-weight:700; border-color:#e4e4e4; }
.input-spinner .btn{width:42px;text-align:center;padding-left:.5rem;padding-right:.5rem;line-height:22px;}
@media (max-width:768px){
.btn{font-size:.7rem;}
}
.fa{-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;display:inline-block;font-style:normal;font-variant:normal;text-rendering:auto;line-height:1;}
.fa-minus:before{content:"\f068";}
.fa-plus:before{content:"\f067";}
.fa{font-family:"Font Awesome 5 Free";}
.fa{font-weight:900;}

.shopping-cart .input-spinner input{padding:0 5px;}
@media (max-width:1024px){
.shopping-cart .input-spinner{width:70px;}
.shopping-cart .input-spinner .btn{width:28px;}
.shopping-cart .input-spinner{font-size:12px;}
}

@media (max-width:992px){
.shopping-cart .input-spinner{width:60px;}
.shopping-cart .input-spinner .btn{width:28px;}
.shopping-cart .input-spinner{font-size:12px;}
.pricebox .price{font-size:14px;}
}

@media (max-width:684px){
.shopping-cart .input-spinner{width:42px;}

}
@media (max-width: 360px){
.shopping-cart .input-spinner .btn{width:28px;}
}
.order-sum
{
	  border: 1px solid rgb(179 179 179 / 13%);
    border-radius: 0;
    background-color: #f8f8f8;
}
.shopping-cart .item .title
{color:#212529; font-weight:600;}

.shopping-cart .item {
    border-bottom: 1px solid #efefef;
    margin-bottom: 10px;
    padding-bottom: 10px;
}

.shopping-cart .card-lite
{
	padding:20px;

}

.shopping-cart .card-lite .last
{
	border-bottom:0;
    margin-bottom: 0px;
    padding-bottom: 0px;
}

.p-20 
{
	padding:20px;
	
}


.fs-16{font-size:16px;}
.fs-12{font-size:12px;}
.fs-11{font-size:11px; line-height:11px;}
.fs-14{font-size:14px;}
.fw-600{font-weight:600;}
.js-check{position:relative;cursor:pointer;}
.box{padding:5px;background:#fff;border-radius:0.37rem;border:1px solid rgba(0, 0, 0, .1);}
.js-check.box{width:100%;border-width:1px;}
.js-check.box h6{margin-top:5px;}
.shipbox .form-group,.payment-methods .form-group{margin:5px;}
.shipbox .js-check.box,.payment-methods .js-check.box{min-height:67px;}
.js-check input[type=radio]{width:20px;height:20px; margin-left:16px;
    display: block;
    height: 100%;}
    
    .error .form-control
    {border-color:var(--brand);}
    .error .form-check-label
    {color:var(--brand);}
.js-check.active{border-color:var(--brand);}
.page-checkout .card.box{border:1px solid rgba(0,0,0,.125); 
    background-color: #f6f6f6;}
    .page-checkout .nice-select
    {background-color:#fff;    height: 50px;
    line-height: 48px;
    border-radius: .375rem;
    border: 1px solid #ced4da;
    padding: 0 15px;}
    .page-checkout .nice-select::after
    {
    	line-height:48px;
    } 
.order-summary{padding:20px;}
.section-checkout .address-fields .form-group{margin-bottom:20px;}
.text-left{text-align:left;}
  
  
  .list-group-item.active
  {
  	background-color:var(--brand);
  	border-color:var(--brand);
  }
   
   
   .bb-1 {
   	    border-bottom: 1px solid #292929;
   }
 
 
 .step-navigation .btn-cta {
    float: right;
}
 
 
	.title-text h1
	{text-align:center;}
	/* Centering and layout */
.checkout-steps {
  text-align: center;
}

.nav-steps {
  display: inline-flex;
  list-style: none;
  padding: 0;
  gap: 10px;
}

.nav-steps .nav-item {
  position: relative;
  display: flex;
  align-items: center;
}
.nav-steps .nav-link:hover
{
	  color: var(--brand);
}
.nav-steps .nav-link {
  color: #333;
  text-decoration: none;
  font-weight: bold;
  padding: 8px 15px;
  border-radius: 4px;
  position: relative;
  transition: color 0.3s;
  cursor:pointer;
}
.ho-button
{
	cursor:pointer;
}
.nav-steps .nav-link.active {
  color: var(--brand);
}

.nav-steps .nav-link::after {
     content: '>';
    color: #ccc;
    position: absolute;
    right: -13px;
    font-size: 1.5em;
    top: 0;
    bottom: 0;
    margin: auto;
    line-height: 36px;
}
.step-navigation .btn-primary
{float:right;}
.nav-steps .nav-item:last-child .nav-link::after {
  content: ''; /* Remove the arrow from the last item */
}
@media (max-width: 434px) {

  /* Stack the list vertically instead of side-by-side */
  .nav-steps {
    display: flex;          /* keep flexbox */
    flex-direction: column; /* vertical */
    align-items: stretch;   /* each item takes full width */
    gap: 0;                 /* rely on borders instead of gap */
  }

  /* Each <li> fills the screen width */
  .nav-steps .nav-item {
    width: 100%;
  }

  /* Make the links look like full-width buttons */
  .nav-steps .nav-link {
    display: block;
    width: 100%;
    padding: 12px 16px;
    font-size: 0.95rem;      /* a little smaller so it fits */
    text-align: left;        /* keep text readable */
    border: 1px solid #e5e5e5;
    border-radius: 0;        /* square buttons feel more natural in a list */
  }

  /* Remove arrow between steps – it's pointless in a vertical list */
  .nav-steps .nav-link::after {
    content: none;
  }

  /* Optional: show a subtle divider instead of the > arrow */
  .nav-steps .nav-item + .nav-item .nav-link {
    border-top: 0;           /* collapse double borders */
  }

  /* Fatter tap target for the active step */
  .nav-steps .nav-link.active {
    border-left: 4px solid var(--brand);
    color: var(--brand);
    font-weight: 600;
  }
}
.float-left
{float:left;}

.cart-data{
	min-height:500px;
}

.mtb-75 {
    margin-top: 75px;
    margin-bottom: 75px;
}
.mtb-25 {
    margin-top: 25px;
    margin-bottom: 25px;
}

.mtb-50 {
    margin-top: 50px;
    margin-bottom: 50px;
}

textarea.form-control
{min-height:132px;}

/* Range Slider */
.is_clickable {
    cursor: hand;
    cursor: pointer
}

.range-slider {
    cursor: hand;
    cursor: pointer;
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
    border-radius: 10px;
    position: relative;
    width: 100%;
    height: 7px;
    background: #ababab;
    margin-top: 8px;
    margin-bottom: 8px;
}

.range-slider .range-slider-leftgrip.gripHighlighted,.range-slider .range-slider-rightgrip.gripHighlighted {
    background: #134
}

.range-slider .range-slider-leftgrip,.range-slider .range-slider-rightgrip {
    position: absolute;
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
    border-radius: 10px;
    width: 20px;
    height: 20px;
    background: #0B88EE;
    border: 5px solid #fff;
    top: 50%;
    margin-top: -10px;
    box-shadow: 0 0 10px rgba(0,0,0,.3)
}

.range-slider .bar {
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
    border-radius: 10px;
    position: absolute;
    background: #0B88EE;
    height: 8px;
    top: 0
}

.range-slider .highlightPanel {
    -webkit-transition: all .5s ease-in-out;
    -moz-transition: all .5s ease-in-out;
    -ms-transition: all .5s ease-in-out;
    -o-transition: all .5s ease-in-out;
    transition: all .5s ease-in-out;
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
    border-radius: 10px;
    position: absolute;
    background: #e87722;
    height: 20px;
    top: 0
}
.mt-30 {
    margin-top: 30px;
}



/**
 * Shop Widgets
 */
.shop-widgets .widget-title {
  font-size: 18px;
  font-weight: 700;
  color: #1e1e1e;
  position: relative;
  display: block;
  text-transform: uppercase;
}
.shop-widgets .single-widget ul {
  padding-left: 0;
  margin-bottom: 0;
}
.shop-widgets .single-widget ul li {
  list-style: none;
  display: block;
}
.shop-widgets .shop-widgetbox {
  
}
.shop-widgets .shop-widgetbox .single-widget {
  padding: 10px;
 
}
.shop-widgets .shop-widgetbox .single-widget:first-child {
  border-top: 0;
}
.shop-widgets .widget-categories {
  
  padding: 20px; 
}
.shop-widgets .widget-categories ul li {
  padding: 8px 0;
   
}
.shop-widgets .widget-categories ul li:first-child {
  border-top: none;
}
.shop-widgets .widget-categories ul li:last-child {
  padding-bottom: 0;
}
.shop-widgets .widget-categories ul li a {
  text-transform: uppercase;
  color: #7e7e7e;
  font-weight: 500;
  display: block;
  width:100%;height:100%;
}
.shop-widgets .widget-categories ul li a::after {
  content: "";
  clear: both;
  display: table;
}
.shop-widgets .widget-categories ul li a:hover {
  color: var(--brand);
}
.shop-widgets .widget-categories ul li a span {
 /* float: right;
  background: var(--brand);
  padding: 0 10px;
  border-radius: 5px;
  color: #fff;
  font-size: 12px;*/
  
      float: right;
    background: #777777;
    border-radius: 100%;
    color: #fff;
    font-size: 12px;
    width: 30px;
    height: 30px;
    line-height: 30px;
    text-align: center;
  
  
}
.shop-widgets .widget-color ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.shop-widgets .widget-color ul li {
  min-width: 50%;
}
.shop-widgets .widget-filters .single-widget-range-price {
  margin-top: 20px;
  font-weight: 600;
  color: #1e1e1e;
}
.shop-widgets .widget-filters .single-widget-range-price b {
  color: #7e7e7e;
}

.nice-select::after {
  display: none !important;
}

@media only screen and (min-width: 768px) and (max-width: 991px) {
  .shop-widgets {
    margin-top: 50px;
  }
}
@media only screen and (max-width: 767px) {
  .shop-widgets {
    margin-top: 20px;
  }
  .select-sortby
  {margin-left:0!important;}
}

body.news figure.image img
{
	max-width:100%;
	margin:0 auto;
}

.pt-50
{padding-top:50px;}


.table>:not(caption)>*>* {
    padding: .5rem .5rem;
    color: var(--bs-table-color-state, var(--bs-table-color-type, var(--bs-table-color)));
    background-color: transparent;
    border-bottom-width: 0;
    box-shadow: inset 0 0 0 9999px var(--bs-table-bg-state, var(--bs-table-bg-type, var(--bs-table-accent-bg)));
}
.table table
{width:100%;}

.news-3604 figcaption
{font-size:20px;text-align:center;margin-top:15px}

.properties
{font-size:12px; color:var(--muted)}

article.card,aside:not(.filter)
{
	margin-top:50px;
}

.price-tax
{font-size:12px;font-weight:400}
.in-price
{font-size: 23px;
    font-weight: 900;}
    
    .fs-19
  {font-size:19px;}
    .fs-20
  {font-size:20px;}
    .fs-21
  {font-size:21px;}
    .fs-22
  {font-size:22px;}
    .fs-23
  {font-size:23px;}
  
  .block-text
  {
  	line-height:1.6rem;
  	font-size:0.9rem;
  }
   
   
   #searchModal
   {z-index:9999;}