
/*
Theme Name: Knjizara VUK Pro
Theme URI: https://example.com/
Author: OpenAI
Description: Custom WooCommerce WordPress theme for Knjižara VUK, Borča.
Version: 2.5.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
Text Domain: knjizara-vuk
License: GPLv2 or later
*/

:root{
  --vuk-bg:#ffffff;
  --vuk-soft:#f7f4ef;
  --vuk-soft-2:#fbfaf8;
  --vuk-border:#ece6dc;
  --vuk-text:#171717;
  --vuk-muted:#666;
  --vuk-accent:#a9784f;
  --vuk-accent-dark:#805638;
  --vuk-danger:#b3382c;
  --vuk-shadow:0 18px 45px rgba(0,0,0,.08);
  --vuk-radius:18px;
  --vuk-serif: Georgia, "Times New Roman", serif;
  --vuk-sans: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--vuk-bg);
  color:var(--vuk-text);
  font-family:var(--vuk-sans);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
button,input,select,textarea{font:inherit}
.screen-reader-text{position:absolute;left:-9999px}

/* Layout */
.vuk-container{width:min(1180px, calc(100% - 40px));margin-inline:auto}
.vuk-section{padding:70px 0}
.vuk-section-title{
  font-family:var(--vuk-serif);
  font-size:clamp(30px,4vw,48px);
  line-height:1.1;
  margin:0 0 28px;
  letter-spacing:-.02em;
}
.vuk-kicker{
  text-transform:uppercase;
  letter-spacing:.13em;
  font-size:12px;
  font-weight:700;
  color:var(--vuk-accent);
  margin:0 0 14px;
}

/* Header */
.vuk-topbar{
  background:var(--vuk-text);
  color:#fff;
  font-size:13px;
}
.vuk-topbar-inner{
  display:flex;
  justify-content:space-between;
  gap:16px;
  padding:8px 0;
}
.vuk-site-header{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--vuk-border);
}
.admin-bar .vuk-site-header{top:32px}
.vuk-header-inner{
  display:grid;
  grid-template-columns:150px 1fr auto;
  align-items:center;
  gap:22px;
  min-height:92px;
}
.vuk-logo-wrap{display:flex;align-items:center;gap:12px}
.vuk-logo{width:78px;height:auto}
.vuk-brand-small{display:none;font-weight:800}
.vuk-search-form{
  max-width:520px;
  margin-inline:auto;
  width:100%;
  display:flex;
  border:1px solid var(--vuk-border);
  border-radius:999px;
  background:#fff;
  overflow:hidden;
}
.vuk-search-form input{
  border:0;
  outline:0;
  flex:1;
  padding:14px 18px;
  min-width:0;
}
.vuk-search-form button{
  border:0;
  background:#fff;
  padding:0 18px;
  cursor:pointer;
}
.vuk-actions{display:flex;align-items:center;gap:12px}
.vuk-icon-link{
  position:relative;
  width:42px;height:42px;
  display:grid;place-items:center;
  border:1px solid var(--vuk-border);
  border-radius:50%;
  background:#fff;
}
.vuk-cart-count{
  position:absolute;
  top:-6px;right:-6px;
  background:var(--vuk-text);
  color:#fff;
  border-radius:999px;
  font-size:11px;
  min-width:20px;
  height:20px;
  display:grid;
  place-items:center;
  padding:0 5px;
}
.vuk-menu-row{
  border-top:1px solid var(--vuk-border);
}
.vuk-menu-row .menu{
  list-style:none;
  display:flex;
  justify-content:center;
  gap:30px;
  margin:0;
  padding:14px 0;
  font-size:13px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.03em;
}
.vuk-menu-row .menu a{padding:8px 0}
.vuk-menu-row .menu a:hover{color:var(--vuk-accent)}
.vuk-mobile-toggle{display:none;border:0;background:#fff;font-size:26px}

/* Hero */
.vuk-hero{
  background:
    radial-gradient(circle at 80% 30%, rgba(169,120,79,.10), transparent 30%),
    linear-gradient(180deg,#fff 0%,#fbfaf8 100%);
  padding:74px 0 52px;
}
.vuk-hero-grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  align-items:center;
  gap:54px;
}
.vuk-hero h1{
  font-family:var(--vuk-serif);
  font-size:clamp(48px,6vw,82px);
  line-height:1.02;
  letter-spacing:-.045em;
  margin:0 0 22px;
}
.vuk-hero p{
  max-width:560px;
  font-size:18px;
  color:var(--vuk-muted);
  margin:0 0 30px;
}
.vuk-hero-buttons{display:flex;gap:14px;flex-wrap:wrap}
.vuk-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  border-radius:8px;
  padding:15px 24px;
  font-weight:800;
  border:1px solid transparent;
  cursor:pointer;
  transition:.2s ease;
}
.vuk-btn-primary{background:var(--vuk-text);color:#fff}
.vuk-btn-primary:hover{background:var(--vuk-accent)}
.vuk-btn-secondary{background:#fff;border-color:var(--vuk-border)}
.vuk-btn-secondary:hover{border-color:var(--vuk-accent);color:var(--vuk-accent)}
.vuk-hero-visual{
  min-height:430px;
  border-radius:28px;
  background:
    linear-gradient(120deg,rgba(255,255,255,.2),rgba(255,255,255,.85)),
    url('assets/img/hero-placeholder.svg');
  background-size:cover;
  background-position:center;
  box-shadow:var(--vuk-shadow);
  position:relative;
  overflow:hidden;
}
.vuk-hero-card{
  position:absolute;
  left:24px;
  bottom:24px;
  right:24px;
  background:rgba(255,255,255,.88);
  border:1px solid rgba(255,255,255,.5);
  backdrop-filter:blur(12px);
  border-radius:18px;
  padding:20px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}

/* Category cards */
.vuk-categories-grid{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:16px;
  margin-top:-20px;
  position:relative;
  z-index:5;
}
.vuk-category-card{
  background:#fff;
  border:1px solid var(--vuk-border);
  border-radius:16px;
  padding:24px 16px;
  min-height:138px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap:12px;
  text-align:center;
  box-shadow:0 12px 30px rgba(0,0,0,.055);
  transition:.2s ease;
}
.vuk-category-card:hover{transform:translateY(-4px);box-shadow:var(--vuk-shadow)}
.vuk-category-icon{font-size:34px}
.vuk-category-card strong{text-transform:uppercase;font-size:13px}
.vuk-category-card small{color:var(--vuk-muted)}

/* Products */
.vuk-products-head{
  display:flex;
  justify-content:space-between;
  align-items:end;
  gap:20px;
  margin-bottom:28px;
}
.vuk-products-grid,
ul.products{
  display:grid!important;
  grid-template-columns:repeat(4,1fr);
  gap:26px;
  padding:0!important;
  margin:0!important;
}
ul.products li.product,
.vuk-product-card{
  list-style:none!important;
  background:#fff;
  border:1px solid var(--vuk-border);
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 8px 22px rgba(0,0,0,.045);
  transition:.2s ease;
  position:relative;
}
ul.products li.product:hover,.vuk-product-card:hover{transform:translateY(-4px);box-shadow:var(--vuk-shadow)}
.woocommerce ul.products li.product a img,
.vuk-product-image{
  width:100%;
  aspect-ratio:3/4;
  object-fit:cover;
  background:var(--vuk-soft);
  margin:0!important;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.vuk-product-card h3{
  font-size:16px!important;
  line-height:1.35;
  margin:16px 16px 4px!important;
  padding:0!important;
  color:var(--vuk-text);
}
.woocommerce ul.products li.product .price,
.vuk-price{
  display:block!important;
  margin:8px 16px 16px!important;
  color:var(--vuk-danger)!important;
  font-weight:900!important;
  font-size:18px!important;
}
.woocommerce ul.products li.product .button,
.vuk-add-btn,
.single_add_to_cart_button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button{
  display:flex!important;
  justify-content:center;
  margin:0 16px 18px!important;
  background:var(--vuk-accent)!important;
  color:#fff!important;
  border-radius:8px!important;
  padding:13px 18px!important;
  font-weight:800!important;
  border:0!important;
}
.woocommerce ul.products li.product .onsale,
.onsale{
  background:var(--vuk-danger)!important;
  color:#fff!important;
  border-radius:6px!important;
  min-height:auto!important;
  line-height:1!important;
  padding:7px 9px!important;
  font-size:12px!important;
  font-weight:800!important;
  right:12px!important;
  top:12px!important;
  left:auto!important;
}

/* Trust bar */
.vuk-trust-grid{
  border-top:1px solid var(--vuk-border);
  border-bottom:1px solid var(--vuk-border);
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
}
.vuk-trust-item{
  padding:24px;
  display:flex;
  gap:14px;
  align-items:flex-start;
  border-right:1px solid var(--vuk-border);
}
.vuk-trust-item:last-child{border-right:0}
.vuk-trust-item span{font-size:26px}
.vuk-trust-item strong{display:block}
.vuk-trust-item small{color:var(--vuk-muted)}

/* Info / services */
.vuk-info-band{background:var(--vuk-soft-2)}
.vuk-info-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
}
.vuk-info-card{
  background:#fff;
  border:1px solid var(--vuk-border);
  border-radius:18px;
  padding:28px;
  box-shadow:0 8px 22px rgba(0,0,0,.04);
}
.vuk-info-card h3{margin:0 0 8px;font-size:18px}
.vuk-info-card .big{
  font-size:24px;
  font-weight:900;
  letter-spacing:.02em;
}
.vuk-story{
  display:grid;
  grid-template-columns:.85fr 1.15fr;
  gap:42px;
  align-items:start;
}
.vuk-story-box{
  background:var(--vuk-soft);
  border-radius:24px;
  padding:36px;
}
.vuk-story p{color:var(--vuk-muted);font-size:17px}

/* Footer */
.vuk-footer{
  background:#101010;
  color:#fff;
  padding:56px 0 26px;
}
.vuk-footer-grid{
  display:grid;
  grid-template-columns:1.3fr repeat(3,1fr);
  gap:34px;
}
.vuk-footer a{color:#ddd}
.vuk-footer ul{list-style:none;margin:0;padding:0}
.vuk-footer li{margin:8px 0}
.vuk-footer-bottom{
  border-top:1px solid rgba(255,255,255,.12);
  margin-top:36px;
  padding-top:20px;
  color:#bbb;
  font-size:13px;
}

/* WooCommerce pages */
.woocommerce .woocommerce-breadcrumb{margin:24px 0;color:var(--vuk-muted)}
.woocommerce div.product{padding:44px 0}
.woocommerce div.product div.images img{border-radius:18px;border:1px solid var(--vuk-border)}
.woocommerce div.product .product_title{font-family:var(--vuk-serif);font-size:44px}
.woocommerce div.product p.price{color:var(--vuk-danger);font-size:30px;font-weight:900}
.woocommerce table.shop_table{border-radius:16px;overflow:hidden;border-color:var(--vuk-border)}
.woocommerce form .form-row input.input-text,.woocommerce form .form-row textarea,.woocommerce form .form-row select{
  border:1px solid var(--vuk-border);
  border-radius:10px;
  padding:13px;
}
.woocommerce-checkout #payment{background:var(--vuk-soft);border-radius:16px}

/* Mobile */
@media(max-width:980px){
  .vuk-header-inner{grid-template-columns:auto 1fr auto;min-height:76px}
  .vuk-search-form{display:none}
  .vuk-mobile-toggle{display:block}
  .vuk-menu-row{display:none}
  .vuk-menu-row.is-open{display:block}
  .vuk-menu-row .menu{flex-direction:column;align-items:flex-start;padding:20px;gap:8px}
  .vuk-hero-grid,.vuk-story{grid-template-columns:1fr}
  .vuk-categories-grid{grid-template-columns:repeat(3,1fr)}
  .vuk-products-grid,ul.products{grid-template-columns:repeat(2,1fr)}
  .vuk-trust-grid,.vuk-info-grid,.vuk-footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .vuk-container{width:min(100% - 26px, 1180px)}
  .admin-bar .vuk-site-header{top:0}
  .vuk-topbar-inner{flex-direction:column;gap:4px}
  .vuk-logo{width:60px}
  .vuk-brand-small{display:block}
  .vuk-hero{padding:42px 0 34px}
  .vuk-hero h1{font-size:43px}
  .vuk-hero-visual{min-height:280px}
  .vuk-hero-card{position:static;margin:16px;border:1px solid var(--vuk-border)}
  .vuk-categories-grid,.vuk-products-grid,ul.products,.vuk-trust-grid,.vuk-info-grid,.vuk-footer-grid{grid-template-columns:1fr}
  .vuk-section{padding:46px 0}
  .vuk-products-head{display:block}
}



/* =========================================================
   VUK v2.2 - Product / WooCommerce polish
   ========================================================= */

.vuk-home-section-head{margin-top:34px}

.vuk-home-widget-area .widget,
.vuk-home-widget-area .wp-block-group{
  margin:0;
}

.vuk-home-widget-area .wc-block-product-categories-list,
.vuk-home-widget-area .product-categories{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:16px;
}

.vuk-home-widget-area .wc-block-product-categories-list li,
.vuk-home-widget-area .product-categories li{
  background:#fff;
  border:1px solid var(--vuk-border);
  border-radius:18px;
  min-height:128px;
  padding:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  box-shadow:0 10px 24px rgba(0,0,0,.045);
  transition:.18s ease;
}

.vuk-home-widget-area .wc-block-product-categories-list li:hover,
.vuk-home-widget-area .product-categories li:hover{
  transform:translateY(-4px);
  box-shadow:var(--vuk-shadow);
}

.vuk-home-widget-area .wc-block-product-categories-list a,
.vuk-home-widget-area .product-categories a{
  font-weight:850;
  font-size:14px;
  text-transform:uppercase;
}

.vuk-category-thumb{
  width:58px;
  height:58px;
  background-size:cover;
  background-position:center;
  border-radius:16px;
  border:1px solid var(--vuk-border);
  background-color:var(--vuk-soft);
}

/* Better product cards, both classic WooCommerce and block widgets */
.woocommerce ul.products li.product,
.wc-block-grid__product,
.wp-block-woocommerce-product-template li,
.vuk-product-card{
  background:#fff!important;
  border:1px solid var(--vuk-border)!important;
  border-radius:22px!important;
  overflow:hidden!important;
  box-shadow:0 8px 22px rgba(0,0,0,.045)!important;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease!important;
}

.woocommerce ul.products li.product:hover,
.wc-block-grid__product:hover,
.wp-block-woocommerce-product-template li:hover,
.vuk-product-card:hover{
  transform:translateY(-5px)!important;
  box-shadow:0 20px 48px rgba(0,0,0,.09)!important;
  border-color:#dccdbb!important;
}

.woocommerce ul.products li.product a.woocommerce-LoopProduct-link{
  display:block;
}

.woocommerce ul.products li.product a img,
.wc-block-grid__product-image img,
.wp-block-woocommerce-product-template img{
  width:100%!important;
  aspect-ratio:1/1!important;
  object-fit:contain!important;
  background:linear-gradient(180deg,#fbfaf8,#f4eee6)!important;
  padding:22px!important;
  margin:0!important;
  border-bottom:1px solid var(--vuk-border)!important;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title,
.wc-block-grid__product-title,
.wp-block-woocommerce-product-template .wp-block-post-title,
.vuk-product-card h3{
  min-height:44px;
  font-size:15.5px!important;
  font-weight:850!important;
  line-height:1.35!important;
  color:var(--vuk-text)!important;
  margin:16px 18px 6px!important;
  padding:0!important;
}

.woocommerce ul.products li.product .price,
.wc-block-grid__product-price,
.wp-block-woocommerce-product-template .wc-block-components-product-price,
.vuk-price{
  margin:8px 18px 12px!important;
  color:var(--vuk-danger)!important;
  font-weight:950!important;
  font-size:18px!important;
}

.woocommerce ul.products li.product .price del,
.wc-block-grid__product-price del{
  color:#999!important;
  font-size:13px!important;
  margin-right:6px;
}

.woocommerce ul.products li.product .star-rating{
  margin:8px 18px 0!important;
}

.woocommerce ul.products li.product .button,
.wc-block-grid__product-add-to-cart a,
.wp-block-button.wc-block-components-product-button .wp-block-button__link,
.vuk-add-btn{
  width:calc(100% - 36px)!important;
  margin:0 18px 18px!important;
  min-height:44px!important;
  border-radius:12px!important;
  background:var(--vuk-text)!important;
  color:#fff!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  text-align:center!important;
  font-size:14px!important;
  font-weight:900!important;
  letter-spacing:.01em!important;
  transition:.18s ease!important;
}

.woocommerce ul.products li.product .button:hover,
.wc-block-grid__product-add-to-cart a:hover,
.wp-block-button.wc-block-components-product-button .wp-block-button__link:hover,
.vuk-add-btn:hover{
  background:var(--vuk-accent)!important;
}

.woocommerce span.onsale,
.woocommerce ul.products li.product .onsale,
.wc-block-grid__product-onsale{
  background:var(--vuk-danger)!important;
  color:#fff!important;
  border:0!important;
  border-radius:999px!important;
  padding:7px 11px!important;
  min-height:auto!important;
  line-height:1!important;
  font-size:12px!important;
  font-weight:950!important;
  box-shadow:0 8px 20px rgba(179,56,44,.25)!important;
  top:14px!important;
  right:14px!important;
  left:auto!important;
}

/* Shop page header and notices */
.woocommerce-result-count{
  color:var(--vuk-muted);
  margin-top:0!important;
}

.woocommerce-ordering select{
  border:1px solid var(--vuk-border);
  border-radius:12px;
  padding:12px 14px;
  background:#fff;
}

.woocommerce nav.woocommerce-pagination ul{
  border:0!important;
  display:flex!important;
  gap:8px;
  justify-content:center;
}

.woocommerce nav.woocommerce-pagination ul li{
  border:0!important;
}

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span{
  border:1px solid var(--vuk-border)!important;
  border-radius:10px!important;
  min-width:40px;
  min-height:40px;
  display:grid!important;
  place-items:center;
}

.woocommerce nav.woocommerce-pagination ul li span.current{
  background:var(--vuk-text)!important;
  color:#fff!important;
}

.woocommerce-message,
.woocommerce-info,
.woocommerce-error{
  border-top:0!important;
  border-radius:16px!important;
  background:var(--vuk-soft)!important;
  box-shadow:0 8px 20px rgba(0,0,0,.04)!important;
}

.woocommerce-message::before,
.woocommerce-info::before{
  color:var(--vuk-accent)!important;
}

/* Single product */
.woocommerce div.product{
  background:#fff;
}

.woocommerce div.product div.images .woocommerce-product-gallery__wrapper{
  border-radius:24px;
  overflow:hidden;
  border:1px solid var(--vuk-border);
  background:var(--vuk-soft-2);
}

.woocommerce div.product div.summary{
  background:#fff;
  border:1px solid var(--vuk-border);
  border-radius:24px;
  padding:30px;
  box-shadow:0 12px 32px rgba(0,0,0,.045);
}

.woocommerce div.product .product_title{
  font-size:clamp(32px,4vw,52px)!important;
  line-height:1.05!important;
  letter-spacing:-.03em!important;
}

.woocommerce div.product form.cart{
  display:flex;
  gap:12px;
  align-items:center;
  flex-wrap:wrap;
}

.woocommerce .quantity .qty{
  width:82px!important;
  height:48px!important;
  border:1px solid var(--vuk-border)!important;
  border-radius:12px!important;
}

.single_add_to_cart_button{
  min-height:48px!important;
  margin:0!important;
  border-radius:12px!important;
  padding-inline:28px!important;
}

.woocommerce-tabs{
  margin-top:42px;
}

.woocommerce div.product .woocommerce-tabs ul.tabs{
  padding:0!important;
  margin:0 0 20px!important;
  border-bottom:1px solid var(--vuk-border);
}

.woocommerce div.product .woocommerce-tabs ul.tabs::before{
  display:none!important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li{
  border:1px solid var(--vuk-border)!important;
  border-radius:12px 12px 0 0!important;
  background:#fff!important;
  margin:0 6px 0 0!important;
}

.woocommerce div.product .woocommerce-tabs .panel{
  background:#fff;
  border:1px solid var(--vuk-border);
  border-radius:18px;
  padding:24px;
}

/* Cart and checkout */
.woocommerce-cart-form,
.woocommerce-checkout-review-order,
.woocommerce form.checkout{
  background:#fff;
  border:1px solid var(--vuk-border);
  border-radius:22px;
  padding:22px;
  box-shadow:0 8px 22px rgba(0,0,0,.035);
}

.woocommerce table.shop_table{
  border:1px solid var(--vuk-border)!important;
  border-radius:18px!important;
  overflow:hidden;
}

.woocommerce table.shop_table th{
  background:var(--vuk-soft);
}

.woocommerce a.remove{
  color:var(--vuk-danger)!important;
}

.woocommerce a.remove:hover{
  background:var(--vuk-danger)!important;
  color:#fff!important;
}

@media(max-width:980px){
  .vuk-home-widget-area .wc-block-product-categories-list,
  .vuk-home-widget-area .product-categories{
    grid-template-columns:repeat(3,1fr);
  }
}

@media(max-width:640px){
  .vuk-home-widget-area .wc-block-product-categories-list,
  .vuk-home-widget-area .product-categories{
    grid-template-columns:1fr 1fr;
  }

  .woocommerce ul.products li.product a img,
  .wc-block-grid__product-image img,
  .wp-block-woocommerce-product-template img{
    padding:16px!important;
  }

  .woocommerce div.product div.summary{
    padding:20px;
  }
}



/* =========================================================
   VUK v2.3 - HARD FIX WooCommerce product grid
   Problem: default WooCommerce float + width:22.05% ruins layout.
   This fully disables WooCommerce float layout and uses CSS grid.
   ========================================================= */

.woocommerce ul.products,
.woocommerce-page ul.products,
.woocommerce .products ul,
.woocommerce-page .products ul{
  display:grid !important;
  grid-template-columns:repeat(4, minmax(0, 1fr)) !important;
  gap:28px !important;
  margin:0 !important;
  padding:0 !important;
  clear:both !important;
}

.woocommerce ul.products::before,
.woocommerce ul.products::after,
.woocommerce-page ul.products::before,
.woocommerce-page ul.products::after{
  content:none !important;
  display:none !important;
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product{
  float:none !important;
  clear:none !important;
  width:auto !important;
  max-width:none !important;
  min-width:0 !important;
  margin:0 !important;
  padding:0 !important;
  position:relative !important;
  display:flex !important;
  flex-direction:column !important;
  height:100% !important;
  background:#fff !important;
  border:1px solid var(--vuk-border) !important;
  border-radius:22px !important;
  overflow:hidden !important;
  box-shadow:0 8px 24px rgba(0,0,0,.055) !important;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease !important;
}

.woocommerce ul.products li.product:hover,
.woocommerce-page ul.products li.product:hover{
  transform:translateY(-5px) !important;
  box-shadow:0 22px 50px rgba(0,0,0,.10) !important;
  border-color:#d9c7b2 !important;
}

/* Product image area */
.woocommerce ul.products li.product a.woocommerce-LoopProduct-link,
.woocommerce-page ul.products li.product a.woocommerce-LoopProduct-link{
  display:flex !important;
  flex-direction:column !important;
  flex:1 1 auto !important;
}

.woocommerce ul.products li.product a img,
.woocommerce-page ul.products li.product a img{
  width:100% !important;
  height:auto !important;
  aspect-ratio:1 / 1 !important;
  object-fit:contain !important;
  background:linear-gradient(180deg,#fbfaf8 0%,#f3eee6 100%) !important;
  padding:24px !important;
  margin:0 !important;
  border-bottom:1px solid var(--vuk-border) !important;
}

/* Product title */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce-page ul.products li.product .woocommerce-loop-product__title{
  display:block !important;
  min-height:48px !important;
  margin:18px 18px 8px !important;
  padding:0 !important;
  font-size:15.5px !important;
  font-weight:850 !important;
  line-height:1.35 !important;
  color:var(--vuk-text) !important;
  letter-spacing:-.01em !important;
}

/* Price */
.woocommerce ul.products li.product .price,
.woocommerce-page ul.products li.product .price{
  display:block !important;
  margin:0 18px 14px !important;
  color:var(--vuk-danger) !important;
  font-size:18px !important;
  font-weight:950 !important;
  line-height:1.2 !important;
}

.woocommerce ul.products li.product .price del,
.woocommerce-page ul.products li.product .price del{
  color:#9b9b9b !important;
  font-size:13px !important;
  font-weight:600 !important;
  margin-right:6px !important;
}

.woocommerce ul.products li.product .price ins,
.woocommerce-page ul.products li.product .price ins{
  text-decoration:none !important;
}

/* Buttons */
.woocommerce ul.products li.product .button,
.woocommerce-page ul.products li.product .button{
  width:calc(100% - 36px) !important;
  min-height:46px !important;
  margin:auto 18px 18px !important;
  padding:13px 16px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  border-radius:12px !important;
  background:var(--vuk-text) !important;
  color:#fff !important;
  border:0 !important;
  font-size:14px !important;
  font-weight:900 !important;
  line-height:1.2 !important;
  text-align:center !important;
}

.woocommerce ul.products li.product .button:hover,
.woocommerce-page ul.products li.product .button:hover{
  background:var(--vuk-accent) !important;
  color:#fff !important;
}

/* Sale badge */
.woocommerce ul.products li.product .onsale,
.woocommerce-page ul.products li.product .onsale{
  position:absolute !important;
  top:14px !important;
  right:14px !important;
  left:auto !important;
  margin:0 !important;
  min-width:auto !important;
  min-height:auto !important;
  line-height:1 !important;
  padding:8px 11px !important;
  border-radius:999px !important;
  background:var(--vuk-danger) !important;
  color:#fff !important;
  font-size:12px !important;
  font-weight:950 !important;
  box-shadow:0 8px 20px rgba(179,56,44,.25) !important;
  z-index:2 !important;
}

/* Shop title / toolbar */
.woocommerce .woocommerce-result-count,
.woocommerce-page .woocommerce-result-count{
  float:none !important;
  margin:0 0 18px !important;
  color:var(--vuk-muted) !important;
}

.woocommerce .woocommerce-ordering,
.woocommerce-page .woocommerce-ordering{
  float:none !important;
  margin:0 0 24px !important;
}

.woocommerce .woocommerce-ordering select,
.woocommerce-page .woocommerce-ordering select{
  min-height:44px !important;
  border:1px solid var(--vuk-border) !important;
  border-radius:12px !important;
  padding:10px 14px !important;
  background:#fff !important;
}

/* Make product grid work better on Gutenberg product blocks too */
.wc-block-grid__products,
.wp-block-woocommerce-product-template{
  display:grid !important;
  grid-template-columns:repeat(4, minmax(0,1fr)) !important;
  gap:28px !important;
}

.wc-block-grid__product,
.wp-block-woocommerce-product-template li{
  max-width:none !important;
  flex:none !important;
  margin:0 !important;
}

/* Tablet */
@media(max-width:1100px){
  .woocommerce ul.products,
  .woocommerce-page ul.products,
  .woocommerce .products ul,
  .woocommerce-page .products ul,
  .wc-block-grid__products,
  .wp-block-woocommerce-product-template{
    grid-template-columns:repeat(3, minmax(0,1fr)) !important;
    gap:22px !important;
  }
}

/* Mobile */
@media(max-width:760px){
  .woocommerce ul.products,
  .woocommerce-page ul.products,
  .woocommerce .products ul,
  .woocommerce-page .products ul,
  .wc-block-grid__products,
  .wp-block-woocommerce-product-template{
    grid-template-columns:repeat(2, minmax(0,1fr)) !important;
    gap:16px !important;
  }

  .woocommerce ul.products li.product a img,
  .woocommerce-page ul.products li.product a img{
    padding:16px !important;
  }

  .woocommerce ul.products li.product .woocommerce-loop-product__title,
  .woocommerce-page ul.products li.product .woocommerce-loop-product__title{
    min-height:42px !important;
    margin:14px 14px 6px !important;
    font-size:14px !important;
  }

  .woocommerce ul.products li.product .price,
  .woocommerce-page ul.products li.product .price{
    margin:0 14px 12px !important;
    font-size:16px !important;
  }

  .woocommerce ul.products li.product .button,
  .woocommerce-page ul.products li.product .button{
    width:calc(100% - 28px) !important;
    margin:auto 14px 14px !important;
    font-size:13px !important;
    min-height:42px !important;
  }
}

/* Very small */
@media(max-width:430px){
  .woocommerce ul.products,
  .woocommerce-page ul.products,
  .woocommerce .products ul,
  .woocommerce-page .products ul,
  .wc-block-grid__products,
  .wp-block-woocommerce-product-template{
    grid-template-columns:1fr !important;
  }
}



/* VUK v2.5 - homepage widget corrections */
.vuk-home-news-widget-section .vuk-container > .vuk-hw-section{
  width:100%;
  padding-top:0;
  padding-bottom:0;
}
.vuk-home-widget-area:empty{display:none;}
