:root{
  --brand:#c26a3f;
  --footer-bg:#fff;
  --brand-hover:#b35d35;
  --bs-link-color-rgb:#c26a3f;
  --bs-link-hover-color-rgb:#b35d35;
  --bs-link-opacity:1;
  --accent:#2a2018;
  --ink:#2a2018;
  --muted:#7a6e63;
  --bs-pagination-hover-color:#000;
  --line:#e3ddd6;
  --ok:#35c1a4;
  --no:#c04141;
  --bg:#f9f7f5;
  --bs-primary:var(--brand);
  --bs-primary-rgb:194,106,63;
  --container-max:1400px;
  --page-offset:2rem;
  --font-sans:DM Sans,system-ui,-apple-system,sans-serif;
  --font-serif:DM Serif Display,Georgia,serif;
}

/* 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{
  background-color:hsl(30 20% 95%);
  border:1px solid var(--line)!important;
  color:var(--ink);
  height:40px;min-width:40px;
  display:inline-flex!important;align-items:center;justify-content:center;
  border-radius:999px!important;
  font-family:var(--font-sans);font-size:.875rem;font-weight:500;
  padding:0 .75rem!important;transition:all .2s;
  box-shadow:none!important;
}
.page-link:hover{background:hsl(30 30% 88%);color:var(--ink)}
.page-link:focus{box-shadow:none!important;outline:none}

/* Prev/Next — wider with text */
.page-item:first-child .page-link,
.page-item:last-child .page-link{
  padding:0 1rem!important;gap:.375rem;
}

/* Disabled */
.page-item.disabled .page-link,
.page-link.disabled{opacity:.4;pointer-events:none}

/* Active page */
.active>.page-link, .page-link.active{
  background-color:var(--brand)!important;
  border-color:var(--brand)!important;
  color:#fff!important;
  box-shadow:0 1px 3px rgba(0,0,0,.1)!important;
}

/* Pagination container */
.pagination{
  --bs-pagination-color:var(--ink);
  display:flex;align-items:center;justify-content:center;
  gap:6px;margin-top:3rem;padding:0;list-style:none;
  flex-wrap:wrap;
}
.page-item{list-style:none}
.page-item .page-link{text-decoration:none}

.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 */
.btn-outline-primary{
  --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-family:var(--font-sans);font-size:.875rem;color:var(--muted);margin:0;padding:.75rem 0;display:flex;align-items:center;gap:.375rem;flex-wrap:wrap}
.crumbs a{color:var(--muted);text-decoration:none;transition:color .2s}
.crumbs a:hover{color:var(--ink)}
.crumb-sep{color:var(--line);font-size:.75rem}
.crumb-current{color:var(--ink)}
.crumbs-wrap{
  background:hsl(30 20% 95%);padding:.25rem 0;
  width:100vw;position:relative;left:50%;transform:translateX(-50%);
  border-top:1px solid hsl(30 15% 90%);
}
.crumbs-container{max-width:1400px;margin:0 auto;padding:0 2rem}

.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-family:var(--font-sans);
	font-weight:600;
	font-size:.875rem;
	color:var(--brand);
	text-transform:uppercase;
	letter-spacing:.05em;
	text-decoration:none;
}
/* 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:#f9f7f5; color:var(--ink); font-family:var(--font-sans)}
    h1,h2,h3,h4,h5{font-family:var(--font-serif);font-weight:inherit}
    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:hsl(30 25% 97% / .95); backdrop-filter:blur(12px); border-bottom:1px solid transparent; transition: all .5s ease; box-shadow:0 1px 2px 0 rgb(0 0 0 / .05)}
    .site-header.scrolled-solid{background:hsl(30 25% 97% / .95); border-bottom-color:var(--line); box-shadow:0 1px 3px rgba(0,0,0,.04)}

    /* ===== Homepage transparent header ===== */
    .page-front .site-header{
      position:fixed; top:0; left:0; right:0; z-index:1050;
      background:transparent; border-bottom-color:transparent; box-shadow:none; backdrop-filter:none;
      transition: top .3s ease, background .5s ease, border-color .5s ease;
    }
    .page-front.has-notification .site-header{top:40px}
    .page-front .site-header .main-nav .nav-link,
    .page-front .site-header .nav-icon-btn,
    .page-front .site-header .mega-btn{color:rgba(255,255,255,.8)}
    .page-front .site-header .nav-icon-btn{background:transparent}
    .page-front .site-header .header-carticon,
    .page-front .site-header .header-carticon-empty{color:#fff}
    .page-front .site-header .header-carticon svg,
    .page-front .site-header .header-carticon-empty svg{color:#fff}
    .page-front .site-header .main-nav .nav-link:hover,
    .page-front .site-header .mega-btn:hover{color:#fff}
    .page-front .site-header .nav-icon-btn:hover{color:#fff}
    .page-front .site-header .logo-badge img{filter:brightness(0) invert(1)}
    .page-front .site-header .hamburger-line{background:#fff}
    .page-front .site-header .nav-hamburger:hover{background:rgba(255,255,255,.15)}

    .page-front .site-header.scrolled{
      top:0; background:hsl(30 25% 97% / .95); backdrop-filter:blur(12px);
      border-bottom-color:var(--line); box-shadow:0 1px 3px rgba(0,0,0,.04);
    }
    /* Mega menu open on homepage — force solid header */
    .page-front .site-header.mega-open{
      background:hsl(30 25% 97% / .95); backdrop-filter:blur(12px);
      border-bottom-color:var(--line);
    }
    .page-front .site-header.mega-open .main-nav .nav-link,
    .page-front .site-header.mega-open .nav-icon-btn,
    .page-front .site-header.mega-open .mega-btn{color:var(--muted)}
    .page-front .site-header.mega-open .main-nav .nav-link:hover,
    .page-front .site-header.mega-open .mega-btn:hover,
    .page-front .site-header.mega-open .nav-icon-btn:hover{color:var(--ink)}
    .page-front .site-header.mega-open .logo-badge img{filter:none}
    .page-front .site-header.mega-open .hamburger-line{background:var(--ink)}
    .page-front .site-header.mega-open .header-carticon,
    .page-front .site-header.mega-open .header-carticon-empty{color:var(--muted)}
    .page-front .site-header.mega-open .header-carticon svg,
    .page-front .site-header.mega-open .header-carticon-empty svg{color:var(--muted)}
    .page-front .site-header.mega-open .lang-code{color:var(--muted)}
    .page-front .site-header.scrolled .main-nav .nav-link,
    .page-front .site-header.scrolled .nav-icon-btn{color:var(--muted)}
    .page-front .site-header.scrolled .nav-icon-btn{background:transparent}
    .page-front .site-header.scrolled .header-carticon,
    .page-front .site-header.scrolled .header-carticon-empty{color:var(--muted)}
    .page-front .site-header.scrolled .header-carticon svg,
    .page-front .site-header.scrolled .header-carticon-empty svg{color:var(--muted)}
    .page-front .site-header.scrolled .mega-btn{color:var(--muted)}
    .page-front .site-header.scrolled .main-nav .nav-link:hover,
    .page-front .site-header.scrolled .mega-btn:hover{color:var(--ink)}
    .page-front .site-header.scrolled .nav-icon-btn:hover{color:var(--ink)}
    .page-front .site-header.scrolled .logo-badge img{filter:none}
    .page-front .site-header.scrolled .hamburger-line{background:var(--ink)}
    .page-front .site-header.scrolled .nav-hamburger:hover{background:hsl(30 20% 92%)}

    /* Notification bar — in flow above everything */
    .notification-bar{ position:relative; z-index:1051; }

    /* Homepage main.container-w — hero goes full-width */
    .page-front main.container-w{
      max-width:none; padding-inline:0; overflow-x:hidden;
    }

    /* Full-width hero on homepage */
    .page-front .hero-section{margin-top:0 !important; padding:0}
    .page-front .hero{border-radius:0; width:100%}
    .page-front .hero-slide{min-height:600px}
    .page-front .hero-body{padding-top:calc(72px + 3rem)}

    /* First big-reveal (hero) — full width, no container constraint */
    .page-front main.container-w > .big-reveal:first-of-type{
      max-width:none; padding-inline:0;
    }

    /* All other big-reveals — re-constrain to container */
    .page-front main.container-w > .big-reveal ~ .big-reveal,
    .page-front main.container-w > .row:not(:first-child),
    .page-front main.container-w > .container,
    .page-front main.container-w > .shop-page-area,
    .page-front main.container-w > section:not(.hero-section){
      max-width:var(--container-max);
      margin-inline:auto;
      padding-inline:var(--page-offset);
    }
    .nav-container{display:flex;align-items:stretch;justify-content:space-between;height:64px;max-width:1400px;margin:0 auto;padding:0 1rem}
    @media(min-width:768px){.nav-container{height:80px;padding:0 2rem}}
    .logo-badge{display:inline-flex;align-items:center;text-decoration:none}
    .logo-badge img{height:40px;display:block;transition:all .3s}
    @media(min-width:768px){.logo-badge img{height:48px}}
    .main-nav{display:flex;align-items:center;gap:1.75rem;height:100%;align-self:stretch}
    .main-nav .nav-item{position:relative;display:flex;align-items:center;height:100%}
    .main-nav .nav-link{font-family:var(--font-sans);font-size:.875rem;font-weight:500;color:hsl(20 10% 50%);text-decoration:none;display:inline-flex;align-items:center;gap:4px;transition:color .3s;letter-spacing:0;height:100%}
    .main-nav .nav-link:hover{color:hsl(20 20% 15%)}
    .nav-chevron{width:14px;height:14px;transition:transform .2s}
    .nav-actions{display:flex;align-items:center;gap:.25rem;align-self:center}
    @media(max-width:991.98px){.nav-actions{gap:.125rem}}
    .nav-icon-btn{padding:.5rem;color:hsl(20 10% 50%);background:transparent;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:color .3s;border-radius:8px}
    @media(max-width:767.98px){.nav-icon-btn{padding:.375rem}}
    .nav-icon-btn:hover{color:hsl(20 20% 15%)}
    .nav-icon-btn svg{width:20px;height:20px}
    .nav-actions .select-login,.nav-actions .select-registration{display:flex;align-items:center}
    .nav-actions .lang-switcher{display:flex;align-items:center}
    .nav-initials{font-size:.75rem;font-weight:600;margin-left:2px}

    /* Language switcher */
    .lang-switcher{position:relative}
    .lang-btn{gap:4px;padding:.5rem}
    .lang-code{font-family:var(--font-sans);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}
    .lang-dropdown{
      position:absolute;right:0;top:calc(100% + 4px);
      background:var(--bg);border:1px solid var(--line);border-radius:8px;
      box-shadow:0 8px 24px rgba(0,0,0,.08);overflow:hidden;
      display:none;z-index:50;min-width:130px;
    }
    .lang-switcher.is-open .lang-dropdown{display:block}
    .lang-option{display:block;padding:.5rem 1rem;font-size:.875rem;color:var(--ink);text-decoration:none;transition:background .15s}
    .lang-option:hover{background:var(--line)}
    .lang-option.active{font-weight:600;color:var(--brand)}

    /* Homepage lang switcher colors */
    .page-front .site-header:not(.scrolled) .lang-code{color:rgba(255,255,255,.8)}
    .page-front .site-header.scrolled .lang-code{color:var(--muted)}

.crumbs a:hover {color:var(--ink);}

    /* Icon buttons (legacy compat) */
    .icon-btn{padding:.5rem;color:var(--muted);background:transparent;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:color .5s;border-radius:8px}
    .icon-btn:hover{color:var(--ink)}
    .icon-btn svg{width:20px;height:20px}
    .icon-btn[data-count]::after{content:attr(data-count); position:absolute; top:-4px; right:-4px; min-width:16px; height:16px; display:grid; place-items:center; padding:0 3px; background:var(--brand); color:#fff; border-radius:999px; border:2px solid var(--bg); font-size:10px; font-weight:700}

    /* MEGA MENU — full width, hover managed by JS */
    .mega-trigger{position:static;display:flex;align-items:center;align-self:stretch}
    .mega-panel{position:absolute;top:100%;left:0;right:0;width:100%;background:var(--bg);border-bottom:1px solid var(--line);box-shadow:0 12px 32px rgba(0,0,0,.08);display:none;z-index:2000;border-radius:0}
    .mega-panel.is-open{display:block}
    .mega-inner{max-width:1400px;margin:0 auto;padding:1.5rem 2rem;display:flex;gap:0}
    .mega-left{width:260px;border-right:1px solid var(--line);padding-right:1.5rem;display:flex;flex-direction:column;gap:2px;flex-shrink:0}
    .mega-item{font-family:var(--font-sans);font-size:.875rem;padding:.5rem .75rem;color:var(--muted);text-decoration:none;display:flex;align-items:center;justify-content:space-between;border-radius:8px;transition:all .15s}
    .mega-item:hover,.mega-item.active{background:var(--line);color:var(--ink)}
    .mega-item-all{font-weight:600;color:var(--ink);margin-bottom:.25rem}
    .mega-chevron{opacity:.35;flex-shrink:0}
    .mega-right{flex:1;padding-left:2rem}
    .mega-right h6{font-size:.875rem;font-weight:700;color:var(--ink);margin:0 0 .75rem}
    .subgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
    .subgrid a{font-family:var(--font-sans);font-size:.875rem;color:var(--muted);padding:.625rem 1rem;border:1px solid var(--line);border-radius:8px;text-decoration:none;transition:all .15s}
    .subgrid a:hover{color:var(--ink);border-color:rgba(42,32,24,.2);background:rgba(42,32,24,.03)}
    @media(max-width:991.98px){.mega-panel{position:static;width:100%}.mega-inner{flex-direction:column;padding:1rem}.mega-left{width:100%;border-right:none;border-bottom:1px solid var(--line);padding-right:0;padding-bottom:1rem;margin-bottom:1rem}}
    .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 menu styles moved above) */

    /* 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;}
#searchModal .modal-dialog{max-width:100%;margin:0;align-items:flex-start}
#searchModal .modal-content{border-radius:0 0 16px 16px;box-shadow:0 20px 60px rgba(0,0,0,.15)}

/* ── Search Overlay — Lovable style ── */
.search-overlay-header{border-bottom:1px solid var(--line);background:var(--bg)}
.search-overlay-container{max-width:900px;margin:0 auto;padding:0 2rem}
.search-overlay-header .search-overlay-container{max-width:1400px;display:flex;align-items:center;justify-content:space-between;height:64px}
.search-overlay-brand img{height:36px;display:block}
.search-overlay-close{padding:.5rem;border-radius:999px;border:none;background:transparent;color:var(--muted);cursor:pointer;transition:all .2s}
.search-overlay-close:hover{background:hsl(30 20% 92%);color:var(--ink)}
.search-overlay-body{padding:2rem 2rem 3rem}
.search-overlay-title{font-family:var(--font-serif);font-size:clamp(1.75rem,4vw,2.5rem);color:var(--ink);margin-bottom:.5rem;font-weight:inherit}
.search-overlay-subtitle{font-family:var(--font-sans);font-size:.875rem;color:var(--muted);margin-bottom:0}
.search-overlay-intro{margin-bottom:1.5rem}

/* Input */
.search-overlay-input-wrap{position:relative;margin-bottom:1.5rem}
.search-overlay-input-icon{position:absolute;left:1.25rem;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}
.search-overlay-input{
  width:100%;height:56px;padding:0 3.5rem 0 3.5rem;
  border-radius:999px;border:2px solid var(--line);background:var(--bg);
  font-family:var(--font-sans);font-size:1rem;color:var(--ink);
  outline:none;transition:border-color .2s;
}
.search-overlay-input:focus{border-color:var(--brand)}
.search-overlay-input::placeholder{color:var(--muted);opacity:.7}
.search-overlay-input-clear{
  position:absolute;right:1.25rem;top:50%;transform:translateY(-50%);
  padding:.25rem;border-radius:999px;border:none;background:transparent;
  color:var(--muted);cursor:pointer;transition:all .15s;
}
.search-overlay-input-clear:hover{background:hsl(30 20% 92%);color:var(--ink)}

/* Popular tags */
.search-overlay-popular{margin-bottom:1rem}
.search-overlay-popular-label{font-family:var(--font-sans);font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:.75rem}
.search-overlay-popular-tags{display:flex;flex-wrap:wrap;gap:.5rem}
.search-popular-tag{
  padding:.5rem 1rem;border-radius:999px;border:none;
  background:hsl(30 20% 90%);color:var(--ink);
  font-family:var(--font-sans);font-size:.875rem;cursor:pointer;transition:background .15s;
}
.search-popular-tag:hover{background:hsl(30 20% 86%)}

/* Results */
.search-overlay-results{margin-top:.5rem}
.search-result-section{margin-bottom:2rem}
.search-result-heading{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}
.search-result-heading-text{font-family:var(--font-sans);font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600}
.search-result-heading-count{font-size:.7rem;color:var(--muted)}
.search-result-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
@media(max-width:767.98px){.search-result-grid{grid-template-columns:1fr}}

/* Result item */
.search-result-item{
  display:flex;align-items:center;gap:.75rem;padding:.75rem;
  border-radius:12px;text-decoration:none;color:inherit;transition:background .15s;
}
.search-result-item:hover{background:hsl(30 20% 92%)}
.search-result-item-img{width:56px;height:56px;border-radius:8px;overflow:hidden;background:hsl(30 20% 95%);flex-shrink:0}
.search-result-item-img img{width:100%;height:100%;object-fit:cover}
.search-result-item-info{flex:1;min-width:0}
.search-result-item-title{font-family:var(--font-sans);font-size:.875rem;font-weight:500;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.search-result-item:hover .search-result-item-title{color:var(--brand)}
.search-result-item-meta{font-family:var(--font-sans);font-size:.75rem;color:var(--muted)}
.search-result-item-arrow{color:var(--muted);flex-shrink:0;transition:all .15s}
.search-result-item:hover .search-result-item-arrow{color:var(--brand);transform:translateX(2px)}

/* Category result icon */
.search-result-cat-icon{width:40px;height:40px;border-radius:8px;background:hsl(15 60% 50% / .1);color:var(--brand);display:flex;align-items:center;justify-content:center;flex-shrink:0}

/* Empty state */
.search-overlay-empty{text-align:center;padding:3rem 0;color:var(--muted);font-family:var(--font-sans);font-size:.875rem}
    /* 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(--bg); color: var(--ink); border-top:1px solid var(--line); padding-left:var(--page-offset,1rem);padding-right:var(--page-offset,1rem) }
    footer h6{font-family:var(--font-serif);font-size:1.125rem;color:var(--ink);font-weight:inherit;margin-bottom:1rem}
    footer p,footer li,footer a{font-family:var(--font-sans);font-size:.875rem}
    footer .small,footer p.small{font-size:.875rem;color:var(--muted);line-height:1.6}
    footer a{color:var(--muted);text-decoration:none;transition:color .2s}
    footer a:hover{color:var(--ink)}
    footer .link-dark{color:var(--muted)}
    footer .link-dark:hover{color:var(--ink)}
    .footer-bottom{font-size:.875rem;color:var(--muted)}
    .footer-bottom a{color:var(--muted)}

    /* ===== 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: inherit; letter-spacing:.2px; color:var(--brand); margin-bottom: .75rem; font-family:var(--font-serif); font-size:2.25rem }
    .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 height */
    .site-header{ height:64px }
    @media(min-width:768px){.site-header{height:80px}}
    .logo-badge img{ transition: all .3s }
 
 .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; 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!important }
      .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, h5 {
  font-family: var(--font-serif);
  font-weight: inherit;
  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-flex;
  position: relative;
  align-items:center;
  padding:0 0 0 .5rem;
}
.header-carticon, .header-carticon-empty {
  display: inline-flex;
  align-items:center;
  justify-content:center;
  position: relative;
  color: inherit;
  height: auto;
  width: auto;
  margin:0;padding:0;
  line-height: 1;
}
.header-carticon svg, .header-carticon-empty svg{width:20px;height:20px}

.select-registration .login-button
{ white-space:nowrap;}
.header-carticon i,
.header-carticon-empty i {
  line-height: 48px;
}
.header-cart
{padding:0 0 0 8px;
	}
.header-carticon span.count,
.header-carticon-empty span.count {
  position: absolute;
  top: -4px;
  right: -4px;
  display: grid;
  place-items:center;
  width: 16px;
  height: 16px;
  line-height: 16px;
  font-weight: 700;
  font-size: 10px;
  font-family:var(--font-sans);
  color: #fff;
  background: var(--brand);
  text-align: center;
  border-radius: 999px;
}
.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, rgb(0 0 0 / 90%) 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 {}

.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;}
}

/* Cart responsive — mobile */
@media (max-width: 767.98px){
  .cart-data .col-md-9{padding-inline:0}
  .cart-data aside.col-md-3{margin-top:1rem}
  .shopping-cart .item .row{flex-wrap:wrap}
  .shopping-cart .item .col-3{flex:0 0 70px; max-width:70px}
  .shopping-cart .item .col-9{flex:1; max-width:calc(100% - 70px)}
  .shopping-cart .price-per-quantity{width:auto; min-width:80px}
  .shopping-cart .price-per-quantity .value{width:auto; text-align:right}
  .cart-product-title{font-size:.9rem}
}
.shopping-cart .remove{flex-shrink:0}
.cart-data aside .order-sum{position:sticky; top:90px}

/* Temperature groups in cart */
.temp-label{
  color:var(--brand);font-weight:700;font-size:.9rem;
  padding:8px 0 4px;margin-top:12px;
  border-bottom:1px solid var(--line);
}
.temp-label:first-child{margin-top:0}
.shopping-cart .item{
  border-bottom:1px solid #f0f0f0;padding:8px 0;
}
.shopping-cart .item:last-child{border-bottom:0}

.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-family: var(--font-serif);
  font-size: 1.25rem;
  font-weight: inherit;
  color: var(--ink);
  position: relative;
  display: block;
  text-transform: none;
  letter-spacing: normal;
}
.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;
}

/* Filter swatch images (property value thumbnails) */
.filter-swatch{
  width:auto;
  height:28px;
  max-width:60px;
  object-fit:contain;
  border-radius:4px;
  border:none;
  display:inline-block;
  vertical-align:middle;
  flex-shrink:0;
}
.has-swatch{
  display:flex;
  align-items:center;
  gap:6px;
  width:100%;
}
.has-swatch input[type="checkbox"]{
  flex-shrink:0;
}
.has-swatch .filter-swatch{
  flex:0 0 auto;
  max-width:60px;
}
.has-swatch label,
.has-swatch .form-check-label{
  flex:1;
}
/* Sidebar filter list — items in a row */
.filter-list li{
  display:flex;
  align-items:center;
  gap:6px;
  padding:4px 0;
}
.filter-list .has-swatch{
  gap:8px;
}
.filter-list .has-swatch .filter-swatch{
  height:24px;
  max-width:50px;
}

.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):not(.col-md-3):not(.lv-cart-summary)
{
	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;}


/* ===== Lovable utility classes ===== */
.text-foreground{color:hsl(var(--foreground, 20 20% 15%))}
.text-foreground,.text-foreground{color:var(--ink)}
.text-muted-foreground{color:var(--muted)}
.tracking-wider{letter-spacing:.05em}
.tracking-widest{letter-spacing:.1em}
.uppercase{text-transform:uppercase}
.font-bold{font-weight:700}
.font-semibold{font-weight:600}
.font-medium{font-weight:500}
.font-serif{font-family:var(--font-serif)}
.font-sans{font-family:var(--font-sans)}
.text-xs{font-size:.75rem;line-height:1rem}
.text-sm{font-size:.875rem;line-height:1.25rem}
.text-base{font-size:1rem;line-height:1.5rem}
.text-lg{font-size:1.125rem;line-height:1.75rem}
.text-xl{font-size:1.25rem;line-height:1.75rem}
.text-2xl{font-size:1.5rem;line-height:2rem}
.text-3xl{font-size:1.875rem;line-height:2.25rem}
.leading-relaxed{line-height:1.625}
.leading-snug{line-height:1.375}

/* ── Cart Drawer ── */
.cart-drawer-backdrop{
  position:fixed;inset:0;z-index:9990;
  background:rgba(42,32,24,.3);backdrop-filter:blur(2px);
  opacity:0;pointer-events:none;transition:opacity .3s;
}
.cart-drawer-backdrop.is-open{opacity:1;pointer-events:auto}

.cart-drawer{
  position:fixed;top:0;right:0;bottom:0;z-index:9995;
  width:100%;max-width:420px;background:var(--bg);
  border-left:1px solid var(--line);
  display:flex;flex-direction:column;
  transform:translateX(100%);transition:transform .3s ease;
  box-shadow:-8px 0 30px rgba(0,0,0,.1);
  visibility:hidden;display:none;
}
.cart-drawer.is-open{transform:translateX(0);visibility:visible;display:flex}

.cart-drawer-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:1.25rem 1.5rem;border-bottom:1px solid var(--line);flex-shrink:0;
}
.cart-drawer-title{
  font-family:var(--font-serif);font-size:1.375rem;color:var(--ink);
  display:flex;align-items:center;gap:.5rem;margin:0;font-weight:inherit;
}
.cart-drawer-title svg{width:20px;height:20px;flex-shrink:0}
.cart-drawer-count{font-family:var(--font-sans);font-size:1rem;font-weight:400;color:var(--muted)}
.cart-drawer-close{
  background:none;border:none;padding:.5rem;cursor:pointer;
  color:var(--muted);border-radius:999px;transition:all .15s;
}
.cart-drawer-close:hover{background:hsl(30 20% 92%);color:var(--ink)}

/* Items */
.cart-drawer-items{flex:1;overflow-y:auto;overflow-x:hidden;padding-top:1rem}
.cart-drawer-items ul{list-style:none;padding:0 1.5rem;margin:0}
.cart-drawer-items li{padding:1rem 0;border-bottom:1px solid var(--line)}
.cart-drawer-items li:last-child{border-bottom:none}

.cart-drawer-item{display:flex;gap:.75rem}
.cart-drawer-item-img{
  position:relative;width:72px;height:72px;border-radius:10px;
  overflow:hidden;background:hsl(30 20% 95%);flex-shrink:0;display:block;
}
.cart-drawer-item-img img{width:100%;height:100%;object-fit:cover}
.cart-drawer-item-qty-badge{
  position:absolute;top:4px;left:4px;
  background:var(--brand);color:#fff;font-size:10px;font-weight:600;
  padding:1px 5px;border-radius:4px;
}
.cart-drawer-item-info{flex:1;min-width:0}
.cart-drawer-item-top{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}
.cart-drawer-item-base-price{font-family:var(--font-sans);font-size:.8rem;color:var(--ink);font-weight:500;white-space:nowrap;flex-shrink:0;margin-left:auto}
.cart-drawer-item-name{
  font-family:var(--font-sans);font-size:.875rem;font-weight:500;
  color:var(--ink);text-decoration:none;display:-webkit-box;
  -webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  word-break:break-word;
}
.cart-drawer-item-name:hover{color:var(--brand)}
.cart-drawer-item-remove{
  background:none;border:none;padding:2px;cursor:pointer;
  color:var(--muted);flex-shrink:0;transition:color .15s;
}
.cart-drawer-item-remove:hover{color:#c04141}

/* Variants in drawer */
.cart-drawer-variants{
  list-style:none;padding:0 0 0 .5rem;margin:.375rem 0 0;
  border-left:2px solid hsl(15 60% 50% / .3);
}
.cart-drawer-variants li{
  font-family:var(--font-sans);font-size:.7rem;color:var(--muted);
  padding:.125rem 0;display:flex;justify-content:space-between;gap:.5rem;
}
.cart-drawer-variant-price{color:var(--ink);opacity:.6;flex-shrink:0}

.cart-drawer-item-bottom{display:flex;align-items:center;justify-content:flex-end;margin-top:.5rem}
.cart-drawer-item-price{font-family:var(--font-sans);font-size:.875rem;font-weight:600;color:var(--brand)}

/* Footer */
.cart-drawer-footer{
  border-top:1px solid var(--line);padding:1.25rem 1.5rem;
  background:hsl(30 20% 95%);flex-shrink:0;
}
.cart-drawer-total{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}
.cart-drawer-total span:first-child{font-family:var(--font-sans);font-size:.875rem;color:var(--muted)}
.cart-drawer-total-price{font-family:var(--font-serif);font-size:1.5rem;color:var(--ink)}
.cart-drawer-note{font-family:var(--font-sans);font-size:.75rem;color:var(--muted);margin:0 0 1rem}
.cart-drawer-btn-outline{
  display:block;text-align:center;height:44px;line-height:44px;
  border-radius:12px;border:1px solid var(--line);background:transparent;
  color:var(--ink);font-family:var(--font-sans);font-size:.875rem;font-weight:500;
  text-decoration:none;margin-bottom:.5rem;transition:all .15s;
}
.cart-drawer-btn-outline:hover{border-color:var(--ink);color:var(--ink)}
.cart-drawer-btn-primary{
  display:block;text-align:center;height:44px;line-height:44px;
  border-radius:12px;background:var(--ink);color:#fff;
  font-family:var(--font-sans);font-size:.875rem;font-weight:500;
  text-decoration:none;transition:background .15s;
}
.cart-drawer-btn-primary:hover{background:var(--accent);color:#fff}

/* Cart drawer empty state */
.cart-drawer-empty{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:2rem;text-align:center;
}
.cart-drawer-empty svg{margin-bottom:1rem}
.cart-drawer-empty h4{font-family:var(--font-serif);font-size:1.125rem;color:var(--ink);margin:0 0 .5rem;font-weight:inherit}
.cart-drawer-empty p{font-family:var(--font-sans);font-size:.875rem;color:var(--muted);margin:0 0 1.5rem}
.cart-drawer-empty .cart-drawer-btn-primary{width:auto;display:inline-block;padding:0 2rem}

/* ── Registration form — Lovable style ── */
#registerForm{max-width:720px;margin:0 auto}
#registerForm h1{font-family:var(--font-serif);font-size:clamp(2rem,5vw,2.75rem);color:var(--ink);text-align:center;margin-bottom:.5rem;font-weight:inherit}
#registerForm h4{font-family:var(--font-serif);font-size:1.25rem;color:var(--ink);font-weight:inherit;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--line)}
#registerForm .form-group{margin-bottom:1rem}
#registerForm .form-group label{font-family:var(--font-sans);font-size:.875rem;font-weight:500;color:var(--ink);margin-bottom:.375rem;display:block}
#registerForm .form-control{
  height:48px!important;border-radius:12px!important;
  border:1px solid var(--line)!important;background:var(--bg)!important;
  font-family:var(--font-sans)!important;font-size:.875rem!important;
  color:var(--ink)!important;padding:.5rem 1rem!important;width:100%!important;
}
#registerForm .form-control:focus{border-color:var(--brand)!important;box-shadow:0 0 0 3px hsl(15 60% 50% / .1)!important;outline:none!important}
#registerForm select.form-control{
  -webkit-appearance:none!important;appearance:none!important;
  background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="%237a6e63" stroke-width="2"><path d="m6 9 6 6 6-6"/></svg>')!important;
  background-repeat:no-repeat!important;background-position:right .75rem center!important;padding-right:2.5rem!important;
}

/* Type switcher — lovable card style */
.form-switch-container{display:grid!important;grid-template-columns:1fr 1fr!important;gap:1rem!important;margin-bottom:2rem!important}
.form-switch{margin:0!important;padding:0!important}
.form-switch label{
  display:flex!important;align-items:center!important;gap:.75rem!important;
  padding:1.25rem!important;margin:0!important;
  border:2px solid var(--line)!important;border-radius:12px!important;
  background:var(--bg)!important;cursor:pointer!important;
  font-weight:500!important;font-size:.875rem!important;color:var(--ink)!important;
  box-shadow:none!important;transition:all .15s!important;
  padding-left:1.25rem!important;
}
.form-switch label::before{display:none!important}
.form-switch input[type="radio"]:checked+label{
  border-color:var(--brand)!important;background:hsl(15 60% 50% / .05)!important;
}

/* Submit button */
#registerForm #submitForm{
  height:48px!important;border-radius:12px!important;
  background:var(--brand)!important;color:#fff!important;border:none!important;
  font-family:var(--font-sans)!important;font-size:1rem!important;font-weight:500!important;
  cursor:pointer!important;transition:background .2s!important;
}
#registerForm #submitForm:hover{background:var(--brand-hover)!important}

/* Checkboxes */
#registerForm input[type="checkbox"]{
  -webkit-appearance:none;appearance:none;
  width:18px;height:18px;min-width:18px;border-radius:4px;
  border:1.5px solid var(--line);background:var(--bg);
  cursor:pointer;vertical-align:middle;margin-right:.5rem;position:relative;
}
#registerForm input[type="checkbox"]:checked{
  background:var(--brand);border-color:var(--brand);
  background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16" fill="white"><path d="M12.207 4.793a1 1 0 010 1.414l-5 5a1 1 0 01-1.414 0l-2-2a1 1 0 011.414-1.414L6.5 9.086l4.293-4.293a1 1 0 011.414 0z"/></svg>');
  background-size:12px;background-position:center;background-repeat:no-repeat;
}

/* Error state */
#registerForm .border-danger{border-color:#c04141!important}
#registerForm .error-message{font-family:var(--font-sans);font-size:.75rem;color:#c04141;margin-top:.25rem}

/* reCAPTCHA */
#registerForm .g-recaptcha{margin-top:1.5rem}

/* Responsive */
@media(max-width:575.98px){
  .form-switch-container{grid-template-columns:1fr!important}
}

/* Cart drawer loader */
.cart-drawer-loader{
  position:absolute;inset:0;z-index:10;
  background:hsl(30 25% 97% / .8);backdrop-filter:blur(2px);
  display:flex;align-items:center;justify-content:center;
}
.cart-drawer-items{position:relative}
.cart-drawer-spinner{
  width:32px;height:32px;border:3px solid var(--line);
  border-top-color:var(--brand);border-radius:999px;
  animation:drawerSpin .6s linear infinite;
}
@keyframes drawerSpin{to{transform:rotate(360deg)}}

/* Cart drawer temperature groups */
.cart-drawer-temp-group{margin:0 0 .5rem;padding:0 1.5rem}
.cart-drawer-temp-header{display:flex;align-items:center;gap:.375rem;padding:.75rem 0 .5rem;border-bottom:1px solid var(--line);color:var(--brand)}
.cart-drawer-temp-header svg{flex-shrink:0;opacity:.7}
.cart-drawer-temp-label{font-family:var(--font-sans);font-size:.8rem;font-weight:600;color:var(--brand)}
.cart-drawer-temp-count{font-family:var(--font-sans);font-size:.7rem;color:var(--muted)}
.cart-drawer-temp-help{width:16px;height:16px;border-radius:50%;border:1px solid var(--line);font-family:var(--font-sans);font-size:.6rem;font-weight:600;color:var(--muted);display:inline-flex;align-items:center;justify-content:center;cursor:help;margin-left:auto;flex-shrink:0;transition:all .15s;position:relative}
.cart-drawer-temp-help:hover{border-color:var(--brand);color:var(--brand);background:hsl(15 60% 50% / .08)}
.cart-drawer-temp-help::after{content:attr(data-tip);position:absolute;top:calc(100% + 8px);right:-8px;width:220px;padding:.625rem .75rem;border-radius:10px;background:var(--ink);color:#fff;font-size:.7rem;font-weight:400;line-height:1.5;letter-spacing:0;pointer-events:none;opacity:0;transform:translateY(-4px);transition:all .2s;z-index:9999;text-align:left}
.cart-drawer-temp-help::before{content:'';position:absolute;top:calc(100% + 2px);right:2px;border:5px solid transparent;border-bottom-color:var(--ink);pointer-events:none;opacity:0;transition:opacity .2s;z-index:9999}
.cart-drawer-temp-help:hover::after,.cart-drawer-temp-help:hover::before{opacity:1;transform:translateY(0)}
.cart-drawer-group{list-style:none;padding:0;margin:0}
.cart-drawer-group>li{padding:1rem 0;border-bottom:1px solid var(--line)}
.cart-drawer-group>li:last-child{border-bottom:none}
.cart-drawer-group>li:last-child{border-bottom:none}
.cart-drawer-warning{display:flex;align-items:flex-start;gap:.5rem;padding:.75rem 1rem;margin:1rem 1.5rem 0;border-radius:10px;background:hsl(30 30% 92%);border:1px solid hsl(30 20% 86%);font-family:var(--font-sans);font-size:.75rem;color:var(--ink)}
.cart-drawer-warning svg{flex-shrink:0;margin-top:1px}
.cart-drawer-warning p{margin:0}

/* Prevent horizontal overflow from cart drawer */
html{overflow-x:hidden}
body{overflow-x:visible}

/* Full-width breakout from container */
.full-width{
  width:100vw;
  position:relative;
  left:50%;
  margin-left:-50vw;
}
.big-reveal:has(.full-width){max-width:none!important;overflow:visible!important}
.full-width>.sec-content,.full-width>.container-inner{max-width:960px;margin:0 auto;padding:0 var(--page-offset,1rem)}

/* ===== Lovable file download table (shared) ===== */
.lv-dl-table-wrap{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:hsl(30 20% 97%)}
.lv-dl-table{width:100%;border-collapse:collapse;font-family:var(--font-sans);font-size:.875rem}
.lv-dl-table th{text-align:left;padding:.875rem 1.5rem;font-weight:500;color:var(--muted);border-bottom:1px solid var(--line);font-size:.8rem}
.lv-dl-table td{padding:1rem 1.5rem;border-bottom:1px solid hsl(30 15% 92%);color:var(--ink);vertical-align:middle}
.lv-dl-table tr:last-child td{border-bottom:0}
.lv-dl-table tr:hover td{background:hsl(30 15% 94%)}
.lv-dl-name{display:flex;align-items:center;gap:.75rem;font-weight:500}
.lv-dl-icon{color:var(--muted);flex-shrink:0;opacity:.6}
.lv-dl-meta{color:var(--muted)}
.lv-dl-right{text-align:right!important}
.lv-dl-action{text-align:right;white-space:nowrap}
.lv-dl-btn{display:inline-flex;align-items:center;gap:.375rem;font-size:.8rem;font-weight:500;color:var(--muted);text-decoration:none;transition:color .2s}
.lv-dl-btn:hover{color:var(--brand)}
.lv-dl-btn svg{opacity:.7}


/* Inspiration detail: 2-column layout (section 3 + section 9) */
.inspd-layout{display:grid;grid-template-columns:1fr;gap:2.5rem;padding:clamp(2rem,4vw,3.5rem) 0}
@media(min-width:992px){.inspd-layout{grid-template-columns:2fr 1fr;gap:3.5rem}}
.inspd-layout-main{min-width:0}
.inspd-layout-main .inspd-section{margin-bottom:2.5rem}
.inspd-layout-main .inspd-section:last-child{margin-bottom:0}
.inspd-layout-main .inspd-section:empty{display:none;margin:0}
.inspd-layout-side{display:flex;flex-direction:column;gap:1.25rem}
@media(min-width:992px){.inspd-layout-side{position:sticky;top:7rem;align-self:start}}


/* ── Hamburger button ── */
.nav-hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;background:none;border:none;cursor:pointer;padding:6px;border-radius:8px;transition:background .15s;margin-left:.5rem}
@media(max-width:991.98px){.nav-hamburger{display:flex}}
.nav-hamburger:hover{background:hsl(30 20% 92%)}
.hamburger-line{display:block;width:100%;height:2px;background:var(--ink);border-radius:2px;transition:all .3s}
.nav-hamburger.is-open .hamburger-line:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-hamburger.is-open .hamburger-line:nth-child(2){opacity:0}
.nav-hamburger.is-open .hamburger-line:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── Mobile nav panel ── */
.mobile-nav{display:none;position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100%;z-index:1035;background:var(--bg,#faf8f5);overflow-y:auto;padding:5rem 1.5rem 2rem;-webkit-overflow-scrolling:touch}
.mobile-nav.is-open{display:block}
/* When mobile nav is open on homepage, force solid header */
.page-front .site-header.mobile-open{background:hsl(30 25% 97% / .95);backdrop-filter:blur(12px);border-bottom-color:var(--line)}
.page-front .site-header.mobile-open .hamburger-line{background:var(--ink)}
.page-front .site-header.mobile-open .nav-icon-btn{color:var(--muted)}
.page-front .site-header.mobile-open .logo-badge img{filter:none}
.page-front .site-header.mobile-open .header-carticon,
.page-front .site-header.mobile-open .header-carticon-empty{color:var(--muted)}
.page-front .site-header.mobile-open .header-carticon svg,
.page-front .site-header.mobile-open .header-carticon-empty svg{color:var(--muted)}
.page-front .site-header.mobile-open .lang-code{color:var(--muted)}
.mobile-nav-inner{max-width:480px;margin:0 auto}
.mobile-nav-link{display:block;padding:.75rem 0;font-family:var(--font-sans);font-size:1rem;color:var(--ink);text-decoration:none}
.mobile-nav-link:hover{color:var(--brand)}
.mobile-nav-highlight{font-weight:600;color:var(--brand)}
.mobile-nav-group{position:relative;display:flex;flex-wrap:wrap;align-items:center;border-bottom:1px solid var(--line)}
.mobile-nav-group .mobile-nav-link{flex:1;border-bottom:none;min-width:0}
.mobile-nav-group:not(:has(.mobile-nav-expand)) .mobile-nav-link{border-bottom:none}
.mobile-nav-link:not(.mobile-nav-highlight){border-bottom:1px solid var(--line)}
.mobile-nav-group .mobile-nav-link{border-bottom:none}
.mobile-nav-expand{width:44px;height:44px;background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:transform .2s;flex-shrink:0}
.mobile-nav-expand svg{width:16px;height:16px}
.mobile-nav-expand.is-open{transform:rotate(180deg)}
.mobile-nav-sub{display:none;width:100%;padding:0 0 .5rem 1rem}
.mobile-nav-sub.is-open{display:block}
.mobile-nav-sublink{display:block;padding:.5rem 0;font-size:.875rem;color:var(--muted);text-decoration:none}
.mobile-nav-sublink:hover{color:var(--brand)}
.mobile-nav-divider{height:0;margin:.5rem 0}


/* ── Mobile filter modal ── */
#mobileFilterModal{z-index:99999}
#mobileFilterModal .modal-dialog{z-index:99999;position:relative}
@media(max-width:767.98px){
  #mobileFilterModal .modal-dialog{margin:0;max-width:100%;min-height:100vh}
  #mobileFilterModal .modal-content{border:0;border-radius:0;min-height:100vh;background:var(--bg,#faf8f5)}
  #mobileFilterModal .modal-header{border-bottom:1px solid var(--line);padding:1rem 1.25rem}
  #mobileFilterModal .modal-title{font-family:var(--font-serif);font-size:1.25rem}
  #mobileFilterModal .modal-body{padding:1.25rem}
  #mobileFilterModal .modal-footer{border-top:1px solid var(--line);padding:1rem 1.25rem;position:sticky;bottom:0;background:var(--bg,#faf8f5)}
}
.mobile-filter-select{font-size:.85rem;border-radius:10px;border:1px solid var(--line);background:var(--bg,#faf8f5)}
.mobile-filter-btn{width:100%;height:44px;border-radius:9999px;border:1px solid var(--brand);background:transparent;color:var(--brand);font-family:var(--font-sans);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}
.mobile-filter-btn:hover{background:var(--brand);color:#fff}
.mobile-filter-btn svg{flex-shrink:0}


/* Mobile padding for builder components */
@media(max-width:767.98px){
  main.container-w > .big-reveal{padding-inline:0}
}


/* Checkout + Cart — remove double padding on mobile */
@media(max-width:767.98px){
  .page-checkout .container-w .container,
  .page-cart .container-w .container{padding-left:0;padding-right:0}
  .page-checkout .p-20{padding:12px}
  .page-checkout .section-content.p-20{padding:12px 0}
}


/* Pagination mobile */
@media(max-width:480px){
  .page-link{height:30px;min-width:30px;font-size:.7rem;padding:0 .375rem!important}
  .page-item:first-child .page-link,.page-item:last-child .page-link{padding:0 .5rem!important;font-size:0}
  .page-item:first-child .page-link svg,.page-item:last-child .page-link svg{width:14px;height:14px}
  .pagination{gap:3px;margin-top:2rem;flex-wrap:nowrap}
}


/* Footer single column on very small screens */
@media(max-width:365px){
  footer .row.g-4 > .col-6{width:100%;flex:0 0 100%}
}


/* Modal filter checkboxes — same style as sidebar */
.checkbox-modal{appearance:auto}
