@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Playfair+Display:ital,wght@0,400..900;1,400..900&display=swap');
:root {
	--site-color: #e5201f;
	--site-color1: #000;
	--site-color2: #333;
    --colorSecondary: #333;
	--site-color3: #ccc;
	--currentColor: #e5201f;
	--font: "Inter", sans-serif;
}

body {
	font-family: "Inter", sans-serif;
	font-size: 16px;
	line-height: 28px;
	background: #fff;
	color: #111;
}
h1, h2, h3, h4, h5{font-family: "Playfair Display", serif;}
.d-flex {display: flex;}
.d-grid {display: grid;}
.flex-wrap {flex-wrap: wrap;}
.align_ic {align-items: center;}
.justify_sb {justify-content: space-between;}
.justify_sc {justify-content: center;}
.text-center{text-align: center;}
.flex-grow1 {flex-grow: 1;}
.flex-grow2 {flex-grow: 2;}
.flex-grow3 {flex-grow: 3;}

.gap-5{gap: 5px;}
.gap-10{gap: 10px;}
.gap-15{gap: 15px;}
.gap-20{gap: 20px;}
.gap-30{gap: 30px;}
.gap-40{gap: 40px;}

.grid2 {grid-template-columns: repeat(2, 1fr);}
.grid3 {grid-template-columns: repeat(3, 1fr);}
.grid4 {grid-template-columns: repeat(4, 1fr);}

.pt-1{padding-top:1rem}
.pt-2{padding-top:2rem}
.pt-3{padding-top:3rem}

.pb-1{padding-bottom:1rem}
.pb-2{padding-bottom:2rem}
.pb-3{padding-bottom:3rem}

.mt-1{padding-top:1rem}
.mt-2{padding-top:2rem}
.mt-3{padding-top:3rem}

.mb-15{margin-bottom: 15px;}

 .relative { position: relative;}
 .absolute { position: absolute;}

 .d-none {display: none;}

.container {
	max-width: 1270px;
	padding: 0 15px;
	margin: 0 auto;
	
}
img {display: inline-block; vertical-align: bottom;}

a{outline: none !important;}

h2{font-size:46px; font-weight: 400; line-height: 60px;}

header#masthead {
    position: fixed;
    top: 0;
    z-index: 9999;
    width: 100%;
    padding: 20px 0;
    transition: padding 0.3s ease;
    color: #fff;
    background: #000000;
background: linear-gradient(0deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.78) 30%, rgba(0, 0, 0, 1) 100%);
}
header#masthead.active {
    background: #000;
    transition: padding 0.3s ease;
    padding: 10px 0 0;
}
.right-head {
    flex-basis: 180px;
    display: flex;
    gap: 30px;
    justify-content: end;
    align-items: center;
}
a.my-account-icon:visited{color: #fff}
.right-head a.my-account-icon:hover{color: #70c7f4}
.right-head a:hover{color: #e5211f}
.top-header{background: #e5211f; color: #fff; text-align: center; font-size: 14px; padding: 4px; margin-top: -20px;}
.page-top-padding{padding-top: 1.5rem; padding-bottom: 1rem;}

.woocommerce:where(body:not(.woocommerce-uses-block-theme)) div.product p.price, .woocommerce:where(body:not(.woocommerce-uses-block-theme)) div.product span.price{color: #000; font-size: 1.2rem}

.btn-hero{ background:#0076a9; border:1px solid #0076a9; border-radius:0; color:#fff!important; font-size:18px; font-weight: 400; display: inline-flex; align-items: center;
    gap: 8px; padding: 12px 30px; text-transform:uppercase; text-decoration:none !important; justify-content:center; font-family:Inter; margin-top: 30px;}
.btn-hero:hover{background: #e5211f; border-color:#e5211f; color: #fff;}
.btn-primary, a.btn-primary:visited, .single_add_to_cart_button, 
.add_to_cart_button.ajax_add_to_cart{ background:#fff !important; border:1px solid #0076a9 !important; border-radius:0 !important; color:#0076a9 !important; font-size:16px !important; font-weight: 400 !important; display: inline-flex; align-items: center;
    gap: 8px; padding: 10px 30px !important; text-transform:uppercase; text-decoration:none; justify-content:center; font-family:Inter !important; }

.btn-primary.added, a.btn-primary.added:visited{padding: 10px 8px !important; font-size: 16px !important}
.woocommerce a.added_to_cart, .search-list a.added_to_cart{padding:6px 8px 5px !important; font-size: 14px !important; border: 1px solid #ccc;}
.search-list .cart-button-inner{display: inline-flex; align-items: center; gap: 5px;}
.btn-primary:hover, a.btn-primary:hover, .single_add_to_cart_button:hover{background:#0076a9 !important; color: #fff !important; text-decoration:none;}

.wc-block-components-button.contained{background:#0076a9; color: #fff !important;}
.wc-block-components-button.contained:hover{background: #e5211f;}

.woocommerce header .entry-meta{display: none;}
.woocommerce a.remove{line-height: 0.7rem;}
.wp-block-button__link{height: auto;}
.woocommerce-product-details__short-description{padding: 0 0 15px}
.woocommerce table.my_account_orders .button{margin-right:1px; margin-left:1px }
.custom-social-share{padding-top: 15px; display: flex; gap: 8px; align-items: center;}
.custom-social-share a {
    display: inline-block;
    padding: 7px 12px 6px;
    background-color: #fff;
    color: #333;
    font-size: 14px;
    line-height: 14px;
    text-decoration: none;
    border:1px solid #ccc;
}
.custom-social-share a:hover { background-color: #fefefe; border-color: #000; }

#site-navigation{justify-content: center;}
#mega-menu-wrap-menu-1{background: transparent;}
.main-navigation{margin: 0; padding: 0; flex-grow: 1}
.main-navigation .main-menu > li{font-size: 18px; color: #000; padding-left: 10px; padding-right: 10px;}
.main-navigation .main-menu > li > a{color: #000;}
.main-navigation .main-menu > li > a:hover{ color: #e5201f; text-decoration: none;}
.main-navigation .sub-menu {column-count: 3; background: #fff; color: #333; padding: 10px; border-radius: 6px; 
box-shadow:0px 2px 15px 0px rgba(32, 35, 35, 0.09)}
.main-navigation .sub-menu > li{text-align: left;}
.main-navigation .sub-menu > li > a{ color: #000}
.main-navigation .sub-menu > li a:hover{ background:#efefef; border-radius:4px; }
.main-navigation .sub-menu > li > a:hover, 
.main-navigation .sub-menu > li > a:focus, 
.main-navigation .sub-menu > li > .menu-item-link-return:hover, 
.main-navigation .sub-menu > li > .menu-item-link-return:focus{	text-decoration: none; background:#e5201f; color:#fff; }
.main-navigation .main-menu-more .main-menu > li{padding: 0}

#mega-menu-wrap-menu-1 #mega-menu-menu-1 > li.mega-menu-item.mega-current-menu-item#mega-menu-item-1051 > a.mega-menu-link{ color:#fff; font-weight:500 }
#mega-menu-wrap-menu-1 #mega-menu-menu-1 > li.mega-menu-item.mega-current-menu-item#mega-menu-item-1051 > a.mega-menu-link:hover{ color:#70c7f4; font-weight:500 !important }

.wpfFilterWrapper[data-filter-type="wpfPrice"] .wpfFilterContent .wfpDescription{margin-left: -10px;}

.my-account-icon{ display: inline-block; text-align: center; color: #fff; }
.my-account-icon:hover{ color:#e5201f }

.user-account .login-dropdown-section {
    top: calc(100% + 10px);
        width: 270px;
        right: 0;
        z-index:100;
}
.login-content {
    padding: 16px;
    font-size: 16px;
    box-shadow: 0px 2px 15px 0px rgba(32, 35, 35, 0.09);
    background: #fff;
    border-radius: 6px;
}
.login-dropdown-section nav a {
    color: var(--colorSecondary);
    text-decoration: none;
    display: flex;
    gap: 7px;
    align-items: center;
    padding: 8px;
    opacity: 70%;
}
.login-dropdown-section nav a:hover { background-color: #eff4f6; border-radius: 5px; }
.dropdownMenu.active .dropdownMenuWrapper.d-none { display: block; }

.header-cart{padding: 5px; position: relative;}
.header-cart a{color: #fff}
.header-cart a:hover{color: #70c7f4; text-decoration: none;}
.cart-count{ position:absolute; background:#e5211f; color:#fff; font-size:12px; line-height: 12px; right: -3px; top: -3px; display:inline-block; border-radius:6px; padding:2px 4px; }

.search-container { position: relative; display: inline-block;}
.headerSearch{ background: none; border: none; cursor: pointer; font-size:16px; }
.headerSearch:hover{ color:#70c7f4; }
.search-form-wrapper {
    position: absolute;
    top: 100%;
    right: 0;
    display: none;
    background: white;
    box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.1);
    z-index: 10;
    padding: 10px;
}

#woocommerce-product-search{display: flex;}
#woocommerce-search-field{padding: 0.36rem 0.2rem 0.36rem 0.5rem; max-width: 145px;}
#woocommerce-product-search #search-submit{ background:#e4211e; border:1px solid #e4211e; white-space: nowrap; color:#fff; font-size:14px; margin:0; padding: 8px 15px; border-radius:0; font-weight:500; }
#woocommerce-product-search #search-submit:hover{background:#111;border:1px solid #000; }
.search-sidebar{padding-bottom: 20px;}
.search-lable{ font-size: 14px; padding-bottom: 5px;}
.product-sidebar #woocommerce-search-field{max-width: 100%; width: 100%;}

.careliahelmi-hero {
    position: relative;
    width: 100%;
    height: 800px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.carliahelmi-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1; 
}

.hero-content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 2;
    color: white;
    text-align: center;
    min-width: 900px;
}

h1.widget-title { font-family: "Playfair Display", serif; font-size: 3rem; line-height: 3rem; font-weight: 400; margin: 0; padding: 20px 0; text-shadow: 0 0 2px #000}
.hero-content p{ font-size:22px; line-height:30px; padding:0 60px;text-shadow: 0 0 2px #000; font-weight:600 }

.price{color: #000; font-weight: 600!important; font-size: 18px; font-family:Inter; margin: 0 !important; padding: 10px 0;}
.product-title, .woocommerce-loop-product__title, 
.wc-block-components-product-name, .wc-block-grid__product-title{
    font-weight: 400; font-size: 20px !important;font-family:"Playfair Display"; margin: 0 !important; margin-bottom: 0 !important; line-height: 28px; color: #000 !important;
display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis; min-height: 35px; padding-top:10px !important;
}
.woocommerce ul.products li.product .woocommerce-loop-category__title, .woocommerce ul.products li.product .woocommerce-loop-product__title, .woocommerce ul.products li.product h3{padding: 0 5px}
.product-title a{color: #000;}
.product_thumb{position: relative;}
.quick-view-modal-content h3{padding: 5px 0 !important}
.quick-view-modal-content p{padding-bottom: 15px !important}
.quick-view-button{position: absolute; right: 10px; top: 10px; opacity: 0; padding: 10px 12px; background-color: #e4201e; border-radius: 4px;}
.yith-add-to-wishlist-button-block{position: absolute;right: 10px; top: 55px; margin: 0; opacity: 0; }

.yith-wcwl-add-to-wishlist-button:is(button):not(.yith-wcwl-theme-button-style){ border:0; border-radius:4px;padding: 9px; }
.yith-wcwl-add-to-wishlist-button:is(button):not(.yith-wcwl-theme-button-style):hover{border: 0; background: #eee;}

.product:hover .yith-add-to-wishlist-button-block,
.product:hover .quick-view-button{opacity:1;}

.yith-wcwl-add-to-wishlist-button.yith-wcwl-add-to-wishlist-button--anchor{flex-direction:row-reverse !important;}
.yith-wcwl-add-to-wishlist-button__label{ display:none; }

.single-product .entry-summary .yith-add-to-wishlist-button-block{position: static; opacity: 1}
.single-product .entry-summary .yith-wcwl-add-to-wishlist-button--single{box-shadow: 0 0 1px #000;}
.single-product .entry-summary .yith-wcwl-add-to-wishlist-button__label{display: block; font-size: 16px; color: #333; font-weight: 400;}


.latest-products .product-title{ font-weight:400; padding-left:5px; padding-right:5px; }
.product_thumb .btn-primary{position: absolute; bottom: 15px; margin: auto; left: 15px; right: 15px; opacity: 0}
.product_thumb:hover .btn-primary{opacity: 1}

.category-name{font-weight: 700; font-size: 20px;font-family:Inter; margin: 0; padding: 15px 0; line-height: 28px;color: #000}

.related.products h2 {margin-bottom: 30px; font-size: 38px; text-transform: capitalize;}
.product-category a:hover h3{color: #e4211e}

.product-categories, .latest-products{ padding: 2.5rem 0 0 ;}
.product-categories h2, .section-events h2, .latest-products h2, .shop-title{margin-bottom: 0; font-family: "Playfair Display", serif;}
.latest-products .product:hover{background: #fff; box-shadow: 0px 10px 10px #eee }


.section-offer{ background:url(../images/offer-background.png); background-size: cover; padding: 2rem 0 ; margin-top:3rem;  position: relative; display: flex; align-items: stretch;}
.offer-tag{background: #e4211e; display: inline-flex; gap: 8px; border-radius: 6px; font-size: 22px; font-family:"Inter"; padding: 7px 10px; color: #fff; border: 1px solid #fff; box-shadow: -4px 2px 8px #ccc;}

.section-offer .container {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    box-sizing: border-box;
	width:100%;
   
}

.section-offer .container > div:first-child {
    width: 100%; /* Text container takes up 50% of the container width */
    padding: 20px;
    box-sizing: border-box;
    align-items: center; 
}
.section-offer h2{color: #0f75bc;font-family: "Playfair Display", serif;}
.section-offer p{ font-size: 18px; line-height: 26px; max-width: 80%; padding-bottom: 1rem}




/* Each slide */
.wc-sale-slider .swiper-slide {
    display: flex;
    align-items: center;
    justify-content: center;
}

.sale-slide-inner {
    display: flex;
    gap: 20px;
    align-items: center;
    width: 100%;
    padding: 20px;
    box-shadow: 0 6px 18px rgba(25,25,25,0.06);
    border-radius: 12px;
    background: #fff;
}

/* Text column */
.sale-text {
    flex: 1 1 45%;
}


/* Image column */
.sale-image {
    flex: 0 0 48%;
    display: flex;
    align-items: center;
    justify-content: center;
}
.sale-product-image {
    max-width: 100%;
    height: auto;
    border-radius: 8px;
    object-fit: cover;
}


/* Responsive: stack on small screens */
@media (max-width: 768px) {
    .sale-slide-inner {
        flex-direction: column-reverse;
        text-align: center;
    }
    .sale-image {
        width: 70%;
        margin: 0 auto 12px;
    }
    .sale-text { width: 100%; }
}




.slick-slider { box-shadow: 0 0 20px #ccc; max-height: 350px; overflow: hidden;}
.slick-slider .element{ 
  background-color:#fff;
  color:#000;
  border-radius:5px;
  margin:0px;
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  -webkit-box-pack:center;
      -ms-flex-pack:center;
          justify-content:space-between;
  -webkit-box-align:center;
      -ms-flex-align:center;
          align-items:center;
  font-size:20px;
   
}
.slick-slider .slick-disabled { background-color: #ccc; pointer-events:none; color: #000;}
.slick-prev, .slick-next{position: absolute; bottom:20px; left: 20px; background: #e5211f; color: #fff; border-radius: 50%;}
.slick-next{ left: 75px;}
.slick-slider .event{ padding:10px 10px 60px 20px; }
.event-column{flex: 1 1 60%;}
.event-title{margin: 0; font-size:60px; font-weight: 400; color: #000; line-height: 75px;}
.dates{display: inline-block; background: #e4211e; color: #fff; font-size: 24px; font-weight: 700; border-radius: 6px; padding:5px 10px; margin:10px 0  }
.slick-slider .event .dates p{margin:0; padding: 0;}
.slick-slider .event p{ margin: 0; padding:10px 0; font-size:18px; }
.section-events{padding: 2.5rem 0 0 ;}

.mec-month-side{max-height: 400px; overflow: auto;}
.mec-calendar .mec-month-side .mec-event-article{flex-direction: column; padding: 6px 15px; margin: 15px;}
.mec-calendar .mec-event-article .mec-event-time{font-size: 16px;}
.mec-event-image{width: 100%; padding: 0; margin: 0}
.mec-event-image img{width: 100%; height: auto}
.mec-monthly-contents{gap: 6px;}
.mec-event-loc-place{width: 100%; line-height: 20px;}


.email-newsletter{background:url(../images/newsletter-bg.png); background-size:cover; margin: 2rem 0;
    text-align:center; min-height:500px; display: flex; flex-direction: column; justify-content: center; }
.email-newsletter h3{font-family: "Playfair Display"; font-size: 44px; line-height: 60px; font-weight: 400; max-width:70%; margin-left: auto; margin-right: auto;}
.email-newsletter h3 span{ color:#e4211e; }
.newsletter-signup {position: relative; max-width: 700px; margin: auto }
.newsletter-signup input[type="email"]{ width: 100%; height: 70px; }
.newsletter-signup button[type="submit"]{position: absolute; right:10px; top: 10px; text-transform: uppercase; font-family:"Inter"; font-size: 18px; font-weight: 400; border-radius: 0; background: #0f75bc; color: #fff; padding: 0; width: 170px; height: 50px; border: 1px solid #0f75bc; }
.newsletter-signup button[type="submit"]:hover{ color:#fff; background:#e4211e; border-color:#e4211e }

/**/
.woocommerce-account .woocommerce-MyAccount-navigation{ width: 25%;}
.woocommerce-account .woocommerce-MyAccount-content{ width: 73%;}
.woocommerce .woocommerce-ordering select, #pa_color, #pa_size, .variations #logo{padding: 6px;}
.woocommerce ul.products li.product, .woocommerce-page ul.products li.product{text-align: center; padding: 0; margin: 0 0 30px; position: relative;}
.woocommerce ul.products li.product:hover, .woocommerce-page ul.products li.product:hover {background: #fff; box-shadow: 0px 10px 10px #eee;}
.woocommerce ul.products li.product .button{margin-top: 0}
.woocommerce nav.woocommerce-pagination ul{ border:none; }
.woocommerce nav.woocommerce-pagination ul li{border: none; margin: 4px}
.woocommerce nav.woocommerce-pagination ul li a{background: #111; color: #fff; border-radius: 50%; width: 40px; height: 40px; line-height: 23px}
.woocommerce nav.woocommerce-pagination ul li span{background: #ccc; color: #000; border-radius: 50%; width: 40px; height: 40px;line-height: 23px}
.woocommerce:where(body:not(.woocommerce-uses-block-theme)) ul.products li.product .price{color: #000; font-weight: 600; font-size: 18px;}

.prev.page-numbers,
.next.page-numbers{ background: #e5211f !important; color: #fff !important; border-radius: 50%; width: 40px; height: 40px;line-height: 20px !important}

.quantity {display: flex; align-items: center; padding-right: 20px}

/* For most modern browsers */
input[type="number"]::-webkit-inner-spin-button, 
input[type="number"]::-webkit-outer-spin-button {
    -webkit-appearance: none; margin: 0;
}
input[type="number"] { -moz-appearance: textfield;}

.quantity input.qty { width: 60px !important;text-align: center; border: 0; font-size: 20px; font-weight: 600; text-align: center;}
.quantity button { background: #e5211f; color: #fff; border: 1px solid #e5211f; padding: 10px; cursor: pointer;border-radius: 50%; width:40px; height:40px }
.quantity button:hover { background: #111;border: 1px solid #000;}

.woocommerce table.shop_attributes td p{padding: 8px;}
.woocommerce-MyAccount-navigation ul{ list-style:none; margin:0; padding:20px 0 }
.woocommerce-MyAccount-navigation ul li a{ background:#f7f7f7; border-radius:6px; padding:8px 15px; display:block; margin-bottom:5px; font-weight:600; }
.woocommerce-MyAccount-navigation ul li a:hover{ background:#eee;}
.woocommerce-MyAccount-navigation ul li.is-active a{ background:#e5211f; color: #fff; border-radius:6px; padding:8px 15px; display:block; margin-bottom:5px; }

.select2-container .select2-selection--single, .select2-container--default .select2-selection--single .select2-selection__arrow{height: 36px;}
.select2-container--default .select2-selection--single .select2-selection__rendered{line-height: 36px;}

.woocommerce-info::before{color: #71c8f4;}
.woocommerce-info{border-top-color: #71c8f4;}
.product_meta{padding: 10px 0}
.woocommerce span.onsale {
    background-color:#e5211f;
    padding: 0;
    border-radius: 4px;
    min-height: auto;
    min-width: auto;
    height: 20px;
    line-height: 20px;
    font-size: 13px;
    font-weight: normal;
    width:50px;
    top: 5px;
    left: 5px;
}

.woocommerce ul.products li.product .onsale{ margin:5px 5px 0 0 }
.product .product-content { padding-bottom: 15px;}
.product-content .cart-button-inner{display: inline-flex; gap: 10px; align-items: center;}

.wc-block-components-form .wc-block-components-checkout-step{margin: 0 0 1rem !important;}
.wc-block-components-order-summary .wc-block-components-order-summary-item__individual-prices{padding-top: 0 !important}

.is-large .wc-block-checkout__sidebar{top: 100px !important;}

.woocommerce-thankyou-order-received{color: green; border: 1px solid; padding: 5px 10px;}
table td, table th{border-color: #ccc}
.login-woo{max-width: 450px; margin: auto;}
.forgot-password-woo{max-width: 450px; margin: auto; border-radius: 6px; border: 1px solid #eee; padding: 15px;}
.forgot-password-woo input[type="text"]{ width: 100%;}
.entry-header .entry-title {margin:0; line-height:normal;font-family: "Playfair Display", serif;}

.search-results .search-result-count {
    border-bottom: solid 1px #ddd;
    padding-bottom: 15px;
    text-align: left;
    padding-top: 10px;
}
.search .page-header .page-description{display: inline-block;}

.contact-address {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); /* Three equal columns */
    justify-content: space-between;
    align-items: stretch;
    gap: 30px;
    margin-top: 2rem;
    margin-bottom: 2rem;
}

.call {
    display: flex;
    gap: 30px;
    align-items: center; 
    background-color: #fff; 
    color: #333; 
    padding: 20px; 
    border-radius: 5px;
    border: 1px solid #eee;
    border-bottom: 3px solid #e4211e;
    box-shadow: 0 0 15px #efefef;
}
.call i{font-size: 1.5rem; color: #ccc}
.contact-form input{width: 100%;}

.kiertuemyynti-page h2 span{display: block; font-size:20px; line-height:20px; margin-top: 40px;}
.kiertuemyynti-bx{
    background-color: #fff;
    color: #333;
    padding: 20px 30px;
    border-radius: 5px;
    border: 1px solid #eee;
    border-bottom: 3px solid #e4211e;
    box-shadow: 0 0 15px #efefef;
}

/**/

#site-footer{background:#f6f6f6; padding-top: 40px; padding-bottom: 20px; color: #000}
.social-navigation ul.social-links-menu{display: flex; gap: 30px; margin-left: -3px;}
.social-links-menu .svg-icon{color: #000;}
.social-navigation ul.social-links-menu li a svg{ width:25px; height:25px; }

#site-footer h3{ font-size:24px; font-weight:400; padding-bottom:5px; font-family: "Playfair Display", serif;}
ul#menu-footer-menu {display: grid;grid-template-columns: 1fr 1fr 1fr;}
ul#menu-footer-menu li a{white-space: nowrap; color: #000; font-size: 15px;}
ul#menu-footer-menu li a:hover, .quick-contact a:hover, .company-menu a:hover{color: #e5201f;}
.company-menu a{font-size: 15px;}
.quick-contact a, .company-menu a{color: #000;}
.quick-contact .textwidget div{display: flex; gap: 20px; align-items: center; padding-bottom: 15px;}

.footer-navigation .footer-menu li{padding-bottom: 3px;}
.footer-bottom{font-size: 12px; border-top: 1px solid #e3e3e3; margin-top: 20px; padding-top: 10px; padding-bottom: 10px;}
.footer-bottom a{color: #e5201f;}

#show-filters{display: none;}

.wpfMainWrapper{display: flex; flex-direction: column; gap: 10px;}
.wpfFilterWrapper{ margin-top:0 !important; padding-top:0 !important }
.wpfFilterWrapper select{
box-sizing: border-box;
    width: 100%;
    margin: 0;
    outline: 0;
    line-height: normal;
    border-radius: 5px;
    background: #fff;
    border: solid 1px #ccc;
    padding: 0.36rem 0.66rem;
}
.la-spinner, .wpfIconPreview .spinner, .wpfLoaderIconTemplate .spinner, .woobewoo-filter-loader.spinner{ background-image:url(../images/filter-loading.gif) !important;  }
.filters-widget .wpfFilterDelimeter { margin-left: 30px; margin-right: 30px; }
.filters-widget .ui-slider.ui-widget-content .ui-slider-handle{border-radius: 50%;}

.product .product_thumb, .woocommerce ul.products li.product .product-img { height: auto; background: #f9f9f9; }
.product .product_thumb img, .woocommerce ul.products li.product .product-img img { height: 100%; object-fit: cover; }

  .custom-page-header {
    background: #242323 url(../images/inner-header.jpg);
    background-size: cover;
    background-position: center;
    text-align: center;
    padding-top: 7rem;
    padding-bottom: 2rem;
    color: #fff;
  }
  .aioseo-breadcrumbs { font-size: 14px; }
  .aioseo-breadcrumbs a:hover{color:red }

  .woocommerce .woocommerce-ordering select { vertical-align: top; border: 1px solid #fff; background: none; }
  .single-product .product_meta{display: none;}
  .single-product div.product .product_title {
    margin-top: 10px;
    padding: 0;
    font-weight: 400;
    line-height: 1.2;
  }

  .single-product .variations tr td{display: block;}
  .woocommerce div.product form.cart .variations label {
    font-weight: 600;
    text-align: left;
  }
  .woocommerce div.product form.cart .variations td.label{padding-top:0; padding-bottom:0;}
  .woocommerce div.product form.cart .variations select {
    border: 1px solid #242121;
    padding: 10px 15px !important;
    border-radius: 50px;
    min-width:290px;
  }
  .single-product .variations_form.cart{ display:flex;}
  .single-product .variations_form.cart { display: grid; grid-template-columns: 1fr; align-items: end; gap: 20px; }
  .single-product .variations_form.cart:before, .single-product .variations_form.cart:after{display:none !important;}
  .woocommerce div.product form.cart table td { padding-bottom: 0; }
  .single-product  .woocommerce .single_add_to_cart_button{ margin-bottom:0 !important; }
  .woocommerce div.product form.cart .variations{margin-bottom:0;}
  .woocommerce div.product form.cart div.quantity { border: 1px solid #242121; padding: 0; margin-right: 10px; }
  .woocommerce div.product form.cart div.quantity button {
    background: none;
    border: none;
    color: #242121;
    border-radius: 0;
    padding: 0;
    margin-top: -3px;
    height: 40px;
    font-size: 18px;
  }
  .woocommerce div.product form.cart div.quantity input.qty { width: 80px !important; padding: 0; font-weight: 400; }
  body .woocommerce div.product form.cart { margin-bottom: 1.3em; }
  body button:focus, button:focus,  body input[type="button"]:focus,  body input[type="reset"]:focus,  body input[type="submit"]:focus {
    background: #111;
    outline: none;
    outline-offset: -4px;
  }
  .woocommerce-Tabs-panel h3{display:none;}
  .woocommerce div.product div.images .flex-control-thumbs li {
    padding: 10px;
    height:120px;
    overflow:hidden;
	min-width: 120px;
	max-width: 120px;
  }
  .woocommerce div.product div.images .flex-control-thumbs li img{height:100%; object-fit: cover;}
  .woocommerce div.product div.images .flex-control-thumbs li:first-child{ padding-left:0;  }
  .woocommerce-message { border-top-color: #e4211e; display: flex; justify-content: space-between; flex-wrap: wrap; }
  .woocommerce-message a.button { height: fit-content; display: block; min-width: max-content; }
.woocommerce-message::before{ color: #e4211e;}
.woocommerce-message:focus-visible{ outline:none;}
.woocommerce div.product .woocommerce-tabs ul.tabs li{border-radius:0;}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active { border-top: 4px solid #e4211e; }
.woocommerce div.product .woocommerce-tabs ul.tabs li { background-color: #fbfbfb; }
.woocommerce div.product .woocommerce-tabs ul.tabs{margin-bottom:15px;}
.woocommerce-Tabs-panel p:nth-child(2){margin-top:0;}
.woocommerce-cart .wc-block-components-product-name {
    padding-top: 0 !important;
    min-height: inherit !important;
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    margin-bottom:0 !important;
   }
.woocommerce-cart .wc-block-cart-item__wrap { display: flex; flex-wrap: wrap; gap:5px; align-items:center; }
.woocommerce-cart  .wc-block-cart-item__quantity { display: flex; align-items: center; gap: 10px; }
.woocommerce-cart .wc-block-components-product-metadata__description{display:none;}
.woocommerce-cart .wc-block-components-product-price{padding:5px 0 0 0;}
.woocommerce-cart .wc-block-cart-item__quantity .wc-block-components-quantity-selector { margin-bottom: 0 !important; }
.wc-block-components-sidebar.wc-block-cart__sidebar.wp-block-woocommerce-cart-totals-block {
    padding: 15px !important;
    border-radius: 5px;
    border:1px solid hsla(0,0%,7%,.11);
}
.wc-block-components-product-metadata__description { display: none; }
.wc-block-components-checkout-order-summary__content > .wc-block-components-totals-wrapper:nth-child(4){
    background:#e4211e;
    color:#fff;
    border-radius:0 0 5px 5px;
}

.wc-block-components-order-summary__content .wc-block-components-order-summary-item{border-bottom:1px solid hsla(0,0%,7%,.11);}
.wp-block-woocommerce-checkout { padding-top: 0; }
.wc-block-components-title.wc-block-components-title{font-weight:600;}
.wc-block-components-checkout-order-summary__title-text{ font-family: "Playfair Display"; font-weight:600 !important; font-size:1.25em;}

.woocommerce-order {
    border: 1px solid hsla(0, 0%, 7%, .11);
    padding: 15px;
    max-width: 700px;
    margin: 0 auto;
    border-radius: 15px;
    background: #fff;
    box-shadow: 0 0 35px #e5e5e5;
}

.woocommerce-order .woocommerce-thankyou-order-received {
    border: none;
    text-align: center;
    font-weight: 700;
    font-family: "Playfair Display";
    font-size: 1.5rem;
    margin: 5px 0 25px 0;
	line-height: 40px;
}

.woocommerce-order ul.order_details { background: #f2f2f2; padding: 10px; border-radius: 5px; margin-bottom: 1rem;}
.woocommerce-order h2.woocommerce-order-details__title { text-align: center; font-size: 36px; font-weight: 600; }
.woocommerce-order table.woocommerce-table.woocommerce-table--order-details.shop_table.order_details {
    border: 1px solid hsla(0, 0%, 7%, .11);
    border-radius: 0;
    border-collapse: collapse;
}
.woocommerce-order ul.wc-item-meta { margin: 0; padding: 0; }
.woocommerce-order p{text-align:center;}
.woocommerce-order table p{text-align:left;}
.login-woo h2, .wishlist-title-container{display:none;}
button.woocommerce-button.button.woocommerce-form-login__submit { width: 100%; margin-top:5px; }
table.shop_table.cart.wishlist_table.wishlist_view.traditional.responsive {
  border-collapse: collapse;
  margin: 0;
  width: 99.99%;
}

.wishlist_table .product-add-to-cart a {
    display: inline-block !important;
    margin: 0 auto 5px !important;
    text-align: center;
}

.wp-block-woocommerce-checkout .wc-block-components-sidebar { padding: 0; background: #f9f9f9}
ul.sub-menu.hidden-links {padding: 40px 0;}
.newsletter form p { display: block; margin-bottom: 0;}
.newsletter form .wpcf7-response-output {margin-top: 0;}

.d-grid.latest-products {grid-template-columns: repeat(auto-fit, minmax(268px, 1fr));}
.product-categories-container .product-category img { width: 100%;}
.product-categories .product-category{ position:relative; font-weight:400;  }
.product-categories .product-category:hover a.btn-catshop{padding:3px 20px; font-weight: 600}
.product-categories .product-category h3{ position:absolute;font-family: "Playfair Display", serif; z-index:1; font-size:30px; font-weight:400; max-width:80%; text-align:left; line-height:40px; }
.product-categories .product-category a.btn-catshop{transition: all 0.3s ease; position:absolute; font-family:"Inter"; z-index:1; border-radius:3px; font-size:16px; text-transform:uppercase;padding:3px 15px; }
.product-categories .product-category a.btn-catshop:hover{ background:transparent; box-shadow:0 0 2px #ccc }

.mineraalit-ja-kristallit h3.category-name{ color:#c95629; top:20px; left:30px; }
.mineraalit-ja-kristallit a.btn-catshop{color:#c95629; border: 1px solid #c95629;top:135px; left:30px; background: #fef8f1}

.lahjatavarat h3.category-name{ color:#5c160b; top:20px; left:30px; }
.lahjatavarat a.btn-catshop{color:#5c160b; border: 1px solid #5c160b;top:90px; left:30px; background: #dcdbd6}

.kiteet h3.category-name{ color:#000; top:20px; left:30px; }
.kiteet a.btn-catshop{color:#cad3d9; border: 1px solid #cad3d9;top:90px; left:30px; background: #404143}

.fossillit-fo h3.category-name{ color:#000; top:20px; left:30px; }
.fossillit-fo a.btn-catshop{color:#828282; border: 1px solid #828282;top:90px; left:30px; background: #f4f4f4}

.raakapalat h3.category-name{ color:#70300b; top:20px; left:30px; }
.raakapalat a.btn-catshop{color:#70300b; border: 1px solid #70300b;top:90px; left:30px; background: #eac2b2}

.lohkopalat h3.category-name{ color:#000; top:20px; left:30px; }
.lohkopalat a.btn-catshop{color:#a07957; border: 1px solid #a07957;top:90px; left:30px; background: #fffcf4}

.salt-products h3.category-name{ color:#c95629; top:20px; left:30px; }
.salt-products a.btn-catshop{color:#c95629; border: 1px solid #c95629;top:90px; left:30px; background: #fef8f1}

.geodit h3.category-name{ color:#000; top:20px; left:30px; }
.geodit a.btn-catshop{color:#5257b1; border: 1px solid #5257b1;top:90px; left:30px; background: #d4e7f9}

.korut h3.category-name{ color:#421106; top:20px; left:30px; }
.korut a.btn-catshop{color:#421106; border: 1px solid #421106;top:90px; left:30px; background: #f9f9f6}

.angels h3.category-name{ color:#fbffe0; bottom:90px; left:30px; }
.angels a.btn-catshop{color:#111; border: 1px solid #111; bottom:35px; left:30px; background: #eeefef}

.rumpuhiotut h3.category-name{ color:#000; top:20px; left:30px; }
.rumpuhiotut a.btn-catshop{color:#52614d; border: 1px solid #52614d;top:90px; left:30px; background: #cde0c7}

.muotoillut-kivet h3.category-name{ color:#111; top:20px; left:30px; }
.muotoillut-kivet a.btn-catshop{color:#9cc87a; border: 1px solid #9cc87a;left:30px; top:90px; background: #366a5c}

.sisustus-kivet-sk h3.category-name{ color:#ffeedb; top:20px; left:30px; }
.sisustus-kivet-sk a.btn-catshop{color:#5c160b; border: 1px solid #5c160b;left:30px; top:90px; background: #f6e0c8}

.kammen-kivet h3.category-name{ color:#121400; top:20px; left:30px; }
.kammen-kivet a.btn-catshop{color:#6e771b; border: 1px solid #6e771b;top:90px; left:30px; background: #f0f4c9}

.other-stone h3.category-name{ color:#fff; top:20px; left:30px; }
.other-stone a.btn-catshop{color:#fff; border: 1px solid #fff;top:90px; left:30px; background: #715a78}


/* Event section */
.events-grid { display:grid; grid-template-columns: repeat(auto-fill,minmax(600px,1fr)); gap:1rem; }
.event-card {
  background:#fff;
  padding:1rem;
  border-radius:10px;
  box-shadow:0 8px 20px rgba(0,0,0,0.06);
  border-left: 5px solid #e4211e;
  cursor:pointer;
  transition:transform .12s ease, box-shadow .12s ease;
}
.event-card.previous{background: #eee;}
.event-card.previous span{font-size: 13px; color: #666;}
.event-card:hover { transform:translateY(-4px); box-shadow:0 14px 30px rgba(0,0,0,0.08); }
.event-card h2 { margin:0; font-size:1.3rem; }
.note-cta {
    background: #2c76be;
    padding: 25px;
    border-radius: 15px;
    margin-top: 2rem;
    color: #fff;
    font-size: 1.1rem;
    line-height: 1.7;
}

.woocommerce ul.products::before { position: absolute;}
li.entry.product.type-product { width: 100% !important;}
.gallery-item{ margin:0; min-width:250px; }
.gallery {gap: 10px;}
.woocommerce ul.order_details li { border-right: none;float: none; margin-bottom: 10px; break-inside: avoid; padding-right:0; margin-right: 0;}
.woocommerce ul.order_details { column-count: 2;}
.woocommerce-columns--addresses h2.woocommerce-column__title { font-size: 30px; font-weight: 600; margin: 0px 0 10px;}
section.woocommerce-columns.addresses .woocommerce-column > * > * { text-align: left;}
.woocommerce table.shop_attributes td{padding :10px;}
.wishlist_view.responsive .product-name h3 { margin: 0 !important; font-size: 18px;}
.wishlist_table.mobile .additional-info-wrapper { display: flex; border-top: 1px solid #efefef; padding-top: 10px; gap: 10px;}
.wishlist_table.mobile .product-add-to-cart { min-width: 140px;}
.wishlist_table.mobile li { padding: 20px; box-shadow: 1px 1px 10px 0 #ececec; border-radius: 20px; margin-bottom: 20px;}
.woocommerce div.product div.images .flex-control-thumbs{
	display: flex;
	 overflow: hidden; /* Hides the scrollbars */
  overflow-y: scroll; /* Allows vertical scrolling */
  -ms-overflow-style: none; /* Hides scrollbar in Internet Explorer */
  scrollbar-width: none;
}
.woocommerce div.product form.cart .variations td.value { display: flex; flex-wrap: nowrap;}
.u-columns.woocommerce-Addresses > div {
    background: #fff;
    padding: 15px;
    border-radius: 20px;
    box-shadow: 0 0 20px 0 #f5f5f5;
    margin-bottom: 20px;
}
form.edit-account .woocommerce-Button {
    box-shadow: none !important;
    border-radius: 6px !important;
    padding: .618em 1em !important;
    font-size: 100% !important;
}

.woocommerce form .form-row em { font-size: 12px; color: #969696;}
.woocommerce form .form-row input { border-radius: 5px;}
.woocommerce form .form-row label { font-weight: 500; color: #737373; font-size: 15px;}
tr.woocommerce-orders-table__row { margin-top: 40px; }
tr.woocommerce-orders-table__row:first-child { margin-top: 0px; }
li.mega-mobile-parent-nav-menu-item { display: none;}
ul.mega-sub-menu { overflow: auto !important; max-height: 335px !important; padding: 5px !important; }
#mega-menu-wrap-menu-1 #mega-menu-menu-1 > li.mega-menu-item > a.mega-menu-link{ color:#fff; font-family:"Inter";  font-weight:500 }
#mega-menu-wrap-menu-1 #mega-menu-menu-1 > li.mega-menu-item.mega-current-menu-item > a.mega-menu-link, #mega-menu-wrap-menu-1 #mega-menu-menu-1 > li.mega-menu-item.mega-current-menu-ancestor > a.mega-menu-link, #mega-menu-wrap-menu-1 #mega-menu-menu-1 > li.mega-menu-item.mega-current-page-ancestor > a.mega-menu-link{font-weight: 500}
form.cart .price { display: none; }
.wishlist_table.mobile li table { width: fit-content !important; margin-right: auto; }
.wishlist_table.mobile { padding: 0;}
.woocommerce-message a.button.wc-forward { margin-left: auto;}
.product .product_thumb img { height:auto; width:100%; }
.single-post .post-thumbnail  {
    width: 100% !important;
    height: 100%;
    max-width: 1200px !important;
    border-radius: 30px;
    max-height: 620px;
    overflow: hidden;
    margin-top: 20px;
    margin-bottom: 20px;
    text-align: center;
}
.post-thumbnail .wp-post-image {
    max-width: 100% !important;
    margin: 0;
    height: 100% !important;
    object-fit: cover;
}
.woocommerce table.my_account_orders{ border-collapse: collapse; border: 0;}
.woocommerce table.my_account_orders {
	td, th{ border: 0; padding-top:15px; padding-bottom: 15px;}
	th{ background:#efefef;}
	td{ border-bottom: 1px solid #efefef;}	
}
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) #respond input#submit, .woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) a.button, .woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) button.button, .woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) input.button, :where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce #respond input#submit, :where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce a.button, :where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce button.button, :where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce input.button{background: #e5201f; color: #fff}
.wc-block-components-order-summary .wc-block-components-order-summary-item__individual-prices { display: none !important;}
.wc-block-checkout__sidebar .wc-block-components-product-name {padding-right: 20px;}
.entry-content p{margin-bottom: 20px}
.search-list article h2.entry-title {
    font-size: 18px;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1;
    overflow: hidden;
    margin: 15px 0;
}
.search-list article footer.entry-footer{display: none}
.search-list .product {text-align: center; padding-bottom: 15px}
.search-list .product:hover{background: #fff; box-shadow: 0px 10px 10px #eee;}
.search-list article .entry-content:after, .search-list article .entry-content:before {width: 100% !important;}
.search .pagination .nav-links { margin: 0 !important; justify-content: center;	align-items: center;}
.search a.page-numbers {
    width: fit-content;
    border-radius: 20px;
    padding: 10px 20x;
    display: flex;
    justify-content: center;
    align-items: center;
}
.search a.page-numbers.next { padding: 10px 20px 10px 35px; }
.search a.page-numbers.prev { padding: 10px 35px 10px 20px; }
span.wpcf7-not-valid-tip {
    background: #f00000;
    color: #fff;
    margin: 10px;
    padding: 10px;
    width: 90%;
    border-radius: 5px;
}
.wpcf7-response-output {
    background: #fff6cf;
    border: 0 !important;
    color: #991717;
    width: 90%;
    margin: -15px auto 10px !important;
    border-radius: 5px;
}
.wpcf7 form.sent .wpcf7-response-output{ background:none; color:#46b450; font-weight:600 }
.email-newsletter .wpcf7-response-output{max-width: 700px;}
p.woocommerce-notice.woocommerce-notice--success.woocommerce-thankyou-order-received:before {
    content: "✔";
    position: relative;
    margin: auto;
    display: flex;
    width: 60px;
    height: 60px;
    background: green;
    color: #fff;
    align-items: center;
    justify-content: center;
    border-radius: 50px;
    margin-bottom: 20px;
}
table.woocommerce-table.woocommerce-table--order-details.shop_table.order_details {
	td,th{border: 0; padding-top:15px; padding-bottom:15px}
	th {background: #efefef;}
	tr {border-bottom: 1px solid #efefef}
	tfoot tr {background : #efefef; border-bottom: 5px solid #fff;}
	tfoot th {border-right: 1px solid #b8b8b8;}
}
table.woocommerce-table.woocommerce-table--order-details.shop_table.order_details {border: none !important; }
ul.products.columns-3 {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
	gap:0 40px;
}
ul.products.columns-4 {
     display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr;
    gap:0 30px;
}


/* 27-10-25 */
/* single product two-column (if using content-single-product.php above) */
.product-single-wrap { display: flex; gap: 30px; align-items: flex-start;}
.product-sidebar { width: 300px; flex: 0 0 300px;}
.product-main { flex: 1 1 auto;}

/* wrapper uses flex: sidebar left, content right */
.dev-shop-left-sidebar, .shop-archive-inner { display: flex; gap: 30px; align-items: flex-start;}

/* sidebar (left column) */
.dev-shop-left-sidebar .product-sidebar { width: 300px; flex: 0 0 300px;}
.dev-shop-left-sidebar .shop-main { flex: 1 1 auto;}
.dev-shop-left-sidebar .woocommerce { width: 100%;}

/* Products grid: enforce 3 columns */
.dev-shop-left-sidebar ul.products {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.dev-shop-left-sidebar ul.products li.product { display: flex; flex-direction: column;}
.dev-shop-left-sidebar .woocommerce.columns-3 ul.products { grid-template-columns: repeat(3, 1fr); }
.product_title.entry-title + h1.product_title.entry-title{display: none;}
.top-breadcrumb { display: flex; justify-content: space-between; padding: 20px 0; align-items: center;}
.blog-listing { display: grid; grid-template-columns: 1fr 1fr; gap: 25px;}
.blog-listing article {display: flex; flex-direction: column; overflow: hidden; position: relative; background-color: #fff; width: 100%;
    min-height: 100%; border-radius: 3px; border: 0 solid #69727d; transition: all .25s; box-shadow: 0 0 10px 0 rgba(0, 0, 0, .15);
}
.blog-thumb { position: relative; display: block; width: 100%; height: 300px; overflow: hidden;}
.blog-thumb img{width: -webkit-fill-available;}
.post-date {
    position: relative;
    display: inline-block;
    color: #fff;
    padding: 10px 15px 0px;
    text-align: center;
    font-size: 14px;
}
.post-date span { display: inline-block; font-weight: 700; padding-right: 3px; }
.category-name {
    position: absolute;
    top: 0;
    right: 0;
    z-index: 1;
    padding: 8px 0px;
    font-weight: 700;
    font-size: 16px;
}
.category-name a{color: #fff;}
.category-name a:hover{color: #e5201f;}
.blog-post-txt { padding: 20px 30px; color: #666; line-height: 28px; }
.author-name { padding:0 0 8px 15px; color: #fff;}
.top-featured{position: relative;}
.over-blurr{position: absolute; bottom: 0; width: 100%; z-index: 1; background-color: rgba(0, 0, 0, 0.61); backdrop-filter: blur(5px); }
.single-post .entry-header .entry-title { font-size: 50px;  font-weight: normal; color: #000;}

.bloginner{max-width: 900px; margin: auto;}
.sub-heading.h2-head{ margin:0; padding:0; font-family: "Playfair Display", serif; }
.over-blurr .category-name {padding: 8px 15px;}

/* -- ============== --  */
/* Stone Search page  */
/* -- ============== --  */
    .search-header { text-align: center; padding: 40px 20px ; background: #ffffff; margin-bottom: 40px; box-shadow: 0 1px 20px rgba(0,0,0,0.03); position: relative; overflow: hidden; }
    .search-header::before {
            content: '';
            position: absolute;
            top: -50%;
            left: -50%;
            width: 200%;
            height: 200%;
            /* Hardcoded Gradient */
            background: radial-gradient(circle, rgba(142, 158, 171, 0.1) 0%, rgba(255,255,255,0) 70%);
            z-index: 0;
            pointer-events: none;
        }
    .search-header h2 { font-weight: 600; font-size: 2.3rem;}
    .search-sec { max-width: 600px; margin: 10px auto; position: relative; z-index: 1;}
    #searchBox {
            width: 100%;
            padding: 15px 25px;
            border-radius: 50px;
            border:2px solid #db1c14;
            background: #f1f3f5;
            font-size: 1rem;
            transition: all 0.3s ease;
            outline: none;
            box-shadow: inset 0 2px 5px rgba(0,0,0,0.02);
        }
    #searchBox:focus { background: #ffffff; border-color: #8e9eab; box-shadow: 0 5px 20px rgba(142, 158, 171, 0.3);}
    #stoneGrid{display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 25px; margin-bottom: 50px;}
    .kivetcard {
            background: #ffffff;
            border-radius: 15px;
            padding: 20px;
            /* Hardcoded Soft Shadow */
            box-shadow: 0 10px 30px -10px rgba(0, 0, 0, 0.08); 
            transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
            position: relative;
            overflow: hidden;
            border-top: 4px solid transparent;
            animation: fadeInUp 0.6s ease-out forwards;
            opacity: 0; /* Hidden initially for animation */
            cursor: pointer;
            display: flex;
            gap: 15px;
        }
        .stone-icon{max-width: 90px; height: 90px; border-radius: 5px; overflow: hidden;margin-top: 2px;}
        .stone-icon img{width: 100%; height: 100%; object-fit: cover;}
        .stone-bx-txt { flex-grow: 1; width: min-content;}

        /* Random decorative gradient top borders */
        .kivetcard:nth-child(4n+1) { border-top-color: #a8c0ff; }
        .kivetcard:nth-child(4n+2) { border-top-color: #fbc2eb; }
        .kivetcard:nth-child(4n+3) { border-top-color: #e0c3fc; }
        .kivetcard:nth-child(4n+4) { border-top-color: #8ec5fc; }
        .kivetcard:hover { transform: translateY(-10px); box-shadow: 0 20px 40px -10px rgba(0, 0, 0, 0.15); }
        .kivetcard h2 { font-size: 1.2rem; margin:0; color: #2c3e50; line-height: normal; padding-bottom: 5px;}
        .kivetcard p { color: #666666; font-size: 0.8rem;}
        .kivetcard::after {
            content: '✦';
            position: absolute;
            top: 20px;
            right: 20px;
            font-size: 1.5rem;
            color: rgba(0,0,0,0.05);
            transition: 0.3s;
        }
        .kivetcard:hover::after { color: rgba(0,0,0,0.1); transform: rotate(45deg);}

        @keyframes fadeInUp {
            from { opacity: 0; transform: translateY(30px);}
            to { opacity: 1; transform: translateY(0);}
        }
        .hidden { display: none;}

/* -- ============== --  */
/* -- About us page --  */
/* -- ============== --  */
    .values {display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 20px; margin-top: 40px;}
    .value-card {
            background: #fff;
            padding: 1rem;
            text-align: center;
            box-shadow: 0 4px 15px rgba(0,0,0,0.1);
            border-radius: 8px;
            border-top: 4px solid #e4211e;
        }
    .value-card h3 { margin-bottom: 10px; font-size: 1.2rem;}
    .value-card p { color: #666; font-size: 0.85rem; margin-bottom: 0.5rem}
    .about-content { display: flex; flex-wrap: wrap;  gap: 40px; align-items: center; padding: 1.5rem 0 0rem 0; }
    .about-text-col { flex: 1 1 500px; }
    .about-image-col {flex: 1 1 400px; display: flex; justify-content: center; flex-direction: column; gap: 30px;}
    .about-image-col img { max-width: 1000%; width: 100%; height: auto; border-radius: 12px; box-shadow: 15px 15px 0px #e4211e; }
    .about-text-col h2 { font-size: 2rem; margin-bottom: 1.5rem; position: relative;}
    .about-text-col h2::after { content: ''; display: block; width: 60px; height: 3px; background: #e4211e; margin-top: 10px;}
    .about-text-col blockquote {
        border-left: 4px solid #e4211e;
        padding-left: 1rem;
        font-style: italic;
        font-weight: 600;
        color: #555;
        background: #fff;
        padding: 1rem;
        margin: 1.2rem 0;
        box-shadow: 0 2px 5px rgba(0,0,0,0.05);
    }
    .about-content p {margin-bottom: 1rem; color: #444;}
    .info-box { background-color: #eef2f5; padding: 2rem; border-radius: 8px; margin-top: 2rem;}
    .info-box h3, .info-box p { margin-bottom: 1rem;}
    
    .about-tags { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 1rem; margin-bottom: 2rem;}
    .tag-bx {
            background-color: #fff;
            border: 1px solid #a3a3a3;
            color: #4f4f4f;
            padding: 5px 15px;
            border-radius: 20px;
            font-size:15px;
            font-weight: bold;
        }

/* == Horoscope page == */

.horoscope-hero {
   height: 60vh;
   max-height: 700px;
    display: flex;
    flex-direction: column;
    color: #fff;
    align-items: center;
    justify-content: center;
    text-align: center;
    background: url(../images/bg5-1.jpg) bottom center no-repeat;
    background-size: cover;
    position: relative;
    overflow: hidden;
}
.horoscope-hero .sub-heading.h2-head{ margin-top: -4rem; }
.zodiac-bg-icon {
    position: absolute;
    color: rgba(255, 255, 255, 0.03);
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    pointer-events: none;
    animation: rotate 8s linear infinite;
    margin-top: -30px;
}

@keyframes rotate {
    from { transform: translate(-50%, -50%) rotate(0deg); }
    to { transform: translate(-50%, -50%) rotate(360deg); }
}
 /* Zodiac Grid */
        .zodiac-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 15px;
            padding: 60px 0;
            max-width: 800px;
            margin: 0 auto;
        }

@media (min-width: 768px) {
    .zodiac-grid {grid-template-columns: repeat(6, 1fr);}
}

        .zodiac-icon {
            background: white;
            border: 2px solid #e0e0e0;
            border-radius: 15px;
            padding: 25px 15px;
            text-align: center;
            cursor: pointer;
            transition: all 0.3s ease;
            box-shadow: 0 2px 8px rgba(0,0,0,0.05);
        }

        .zodiac-icon:hover { transform: translateY(-5px); box-shadow: 0 8px 20px rgba(90, 103, 216, 0.2); border-color: #5a67d8; }
        .zodiac-icon.active { border-color: #5a67d8; background: #f0f4ff;}
        .zodiac-icon .symbol { font-size: 40px; margin-bottom: 8px; transition: transform 0.3s ease;}
        .zodiac-icon:hover .symbol { transform: scale(1.2); }
        .zodiac-icon .name { font-size: 16px; color: #666; font-weight: 600; }

        /* Sign Section */
        .sign-section { margin-bottom: 40px; scroll-margin-top: 20px;}
        .sign-card { background: white; border-radius: 20px; padding:25px; box-shadow: 0 4px 20px rgba(0,0,0,0.08); border: 2px solid #f0f0f0; }
        .sign-header {
            display: flex;
            align-items: center;
            gap: 20px;
            margin-bottom: 15px;
            padding-bottom: 10px;
            border-bottom: 2px solid #f5f5f5;
        }
        .sign-header .symbol {font-size: 70px;}
        .sign-header h2 { font-size: 38px; color: #333; margin: 0px;}
        .sign-header .dates { font-size: 18px; color: #666; background: #eeefef; margin-top: 0;}
        .description { font-size: 18px; color: #555; margin-bottom: 35px; line-height: 1.8; }
        .stones-title { font-size: 24px; color: #333; margin-bottom: 25px; display: flex; align-items: center; gap: 10px; }
        .stones-grid { display: grid; grid-template-columns: 1fr; gap: 20px; margin-bottom: 30px; }

    @media (min-width: 768px) {
        .stones-grid { grid-template-columns: repeat(3, 1fr); }
    }

        .stone-card {
            background: #fafafa;
            border: 2px solid #e0e0e0;
            border-radius: 15px;
            padding: 15px;
            display: flex;
            gap: 15px;
            transition: all 0.3s ease;
        }
        .stone-card:hover {transform: translateY(-5px); box-shadow: 0 8px 20px rgba(0,0,0,0.1); border-color: #5a67d8;}
        .stone-card .stone-image { font-size: 50px; margin-bottom: 15px;}
        .stone-card h4 { font-size: 20px; color: #333; margin-top: 0; margin-bottom: 10px;}
        .stone-card .keywords { font-size: 14px; color: #666; font-style: italic; margin-bottom:15px;}

    /* Color Themes */
        .aries { border-left: 5px solid #ef4444; }
        .taurus { border-left: 5px solid #10b981; }
        .gemini { border-left: 5px solid #f59e0b; }
        .cancer { border-left: 5px solid #3b82f6; }
        .leo { border-left: 5px solid #f97316; }
        .virgo { border-left: 5px solid #14b8a6; }
        .libra { border-left: 5px solid #ec4899; }
        .scorpio { border-left: 5px solid #a855f7; }
        .sagittarius { border-left: 5px solid #6366f1; }
        .capricorn { border-left: 5px solid #64748b; }
        .aquarius { border-left: 5px solid #06b6d4; }
        .pisces { border-left: 5px solid #14b8a6; }

    .cta-section{ text-align: center; padding: 40px 20px;}
    .cta-card {
        background: #f9f9f9;
        border: 2px solid #e0e0e0;
        border-radius: 20px;
        padding: 40px 30px;
        max-width: 700px;
        margin: 0 auto;
    }
    .cta-card .icon { font-size: 50px; margin-bottom: 20px; }
    .cta-card h3 { font-size: 32px; color: #333; margin-bottom: 15px;}
    .cta-card p{ margin-bottom: 1rem;}

/* ======= ============= */
/* == Responsive CSS  == */
/* ======= ============= */
@media(max-width:1180px){
	.main-navigation .sub-menu{ column-count: auto;;background: #e5201f; color: #fff; padding: 0; box-shadow: none;}
	.main-navigation .sub-menu > li > a{color: #fff}
    .sub-heading.h2-head{ font-size:44px; margin:0; padding:0; font-family: "Playfair Display", serif; }
}
@media(max-width:1024px){
	.social-navigation ul.social-links-menu{ gap:20px; }
	.wc-block-components-product-name {font-size: 16px !important;line-height: 20px;}
	#site-footer .d-flex.gap-30{flex-wrap: wrap;}
    .dev-shop-left-sidebar .product-sidebar { width: 220px; flex: 0 0 220px;}
	ul.products.columns-3 { grid-template-columns: repeat(2, 1fr);	gap:0 20px; }
    ul.products.columns-4 { grid-template-columns: repeat(2, 1fr);; gap:0 40px; }
    .product-categories .product-category h3{ font-size: 24px; line-height: 30px;}
}
@media(max-width:992px){ 
    #site-navigation{justify-content: end; flex-grow: initial;} 
    .right-head{flex-basis: 130px; gap: 20px; padding-right: 10px;}
    .header-right {flex-direction: row-reverse;}
    .user-account .login-dropdown-section{ width:200px }
    .search-form-wrapper{width: 270px;transform: translateX(-50%);left: 50%;}
}

@media(max-width:915px){
	.grid4 {grid-template-columns: repeat(2, 1fr); gap: 20px;}	
	.slick-slider .element{flex-direction: column-reverse;}
	.slick-slider{max-height:none}
	.event-column{flex: 100%;width:100%;}
	.event-column img {width: 100%;}
	.slick-prev, .slick-next{bottom: 20px}
	.woocommerce-account .woocommerce-MyAccount-navigation, 
	.woocommerce-account .woocommerce-MyAccount-content{ width: 100%;}
	.contact-address{grid-template-columns: 1fr;}
	.woocommerce-MyAccount-navigation ul {display: flex; overflow: auto;}
	.woocommerce-MyAccount-navigation ul li a {min-width: max-content; margin-bottom: 0; border-radius: 0;}
	h3.event-title{font-size:30px; font-weight:600; line-height: 40px;}
	.dates {font-size: 15px; padding: 3px 20px;}
	.slick-slider .event > p {font-size: 15px;}
	.slick-slider button.slick-next, .slick-slider button.slick-prev {padding: 10px 14px;}

    .hero-content{min-width: 600px}
    h1.widget-title{ font-size: 2rem; line-height: 2rem;}
    .hero-content p{ font-size: 16px; line-height: 26px; padding: 0 20px;}

    .product-categories .product-category h3{top: 15px; left:0; right: 0; bottom: auto; max-width: 92%;width: 100%; 
        border-radius: 4px; padding: 10px 15px; margin: auto;}
    .product-categories .product-category a.btn-catshop{ left:15px; right:auto; bottom:15px; top:auto }
    .tumbled-stones a.btn-catshop, .hand-polished-stones a.btn-catshop{top: 100px !important;  bottom: auto!important;}
    .stone-geodes a.btn-catshop{left: auto !important; right: 15px !important;}

    .dev-shop-left-sidebar .product-sidebar { width: 200px; flex: 0 0 200px;}
    ul.products.columns-3 { grid-template-columns: repeat(2, 1fr);  gap:0 20px; }

    .blog-thumb{height: 250px;}
}

@media (max-width: 768px){
	.contact-sec{grid-template-columns: 1fr;}
	.contact-map.pt-2 { padding: 0;}
	.woocommerce-checkout .container.page-top-padding { padding-top: 0;}
    .newsletter-signup{max-width: 460px;}
    .section-offer .container{flex-direction: column; gap: 20px;}
    .section-offer .container > div:first-child, .section-offer .container .rt-img{width: 98%; padding: 5px;}
    .btn-primary, a.btn-primary:visited, .single_add_to_cart_button, 
    .add_to_cart_button.ajax_add_to_cart{ font-size:16px !important; }
    .section-offer h2{    font-size: 34px; line-height: 44px}
    .section-offer p{ max-width:100% }
    .dev-shop-left-sidebar, .shop-archive-inner{flex-direction: column;}
    .dev-shop-left-sidebar .product-sidebar { width: 100%;   flex: auto;    }
    #filters-pop { display: none; overflow: hidden; transition: all 0.4s ease; }
    #show-filters{display: block; border: 1px solid #ccc; font-size: 14px; color: #333; padding: 10px 15px; text-align: center; margin-bottom: 15px;}
    #mega-menu-wrap-menu-1 .mega-menu-toggle .mega-toggle-block-0 .mega-toggle-animated{ transform: scale(0.6);}
    #mega-menu-wrap-menu-1 .mega-menu-toggle{line-height: 36px; height: 36px;}
    .about-content { flex-direction: column-reverse; }
    .about-image-col img { max-width: 100%; box-shadow: 10px 10px 0px var(--accent); }
    .values { margin-top: 20px; }
}

@media screen and (min-width: 1280px) and (max-width: 1440px) and (min-height: 640px) and (max-height: 800px) {
    .product-categories .product-category h3{ font-size:28px; line-height:32px; }
}

@media (max-width:730px) { 
	.wc-block-cart-item__prices {display:none;}
	.wc-block-components-product-metadata { width: 100%; margin-bottom: 0 !important; min-height: 0;}
	tr.wc-block-cart-items__row { margin: 20px 0; box-shadow: 0 0 15px 0 #efefef; padding: 10px !important; border-radius: 10px;}
	.wc-block-components-radio-control .wc-block-components-radio-control__input { left: 2px !important; }
	.is-medium .wc-block-components-shipping-rates-control .wc-block-components-radio-control__option { padding-left: 2.5em !important; }
    .wp-block-woocommerce-checkout .wc-block-components-sidebar{background: #fff} 
    .blog-listing{ grid-template-columns: 1fr;}
    .single-post .entry-header .entry-title { font-size: 30px; text-align: left;}
    .sub-heading.h2-head{ font-size:38px; margin:0; padding:0 }
    .blog-post-txt{ padding: 15px;}
    .blog-post-txt h3{ margin: 5px 0 15px;}
    .events-grid{ grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));}
    .note-cta{ flex-direction: column; text-align: center; font-size: 0.8rem; gap: 10px;}
    .section-offer h2 { font-size: 30px; line-height: 34px;}
}

@media (max-width: 640px){
	.search-bar {display: none;}
    .email-newsletter h3{ font-size:34px; line-height:44px; }
}

@media(max-width:586px){
	.page-top-padding{padding-top: 1.5rem}
	.grid4, .grid3, .contact-address, .contact-sec, .kiertuemyynti-page .grid2 {grid-template-columns: 1fr; gap: 15px;}
	.aioseo-breadcrumbs{display: none;}
	.careliahelmi-hero{background: none; padding: 0;}
	.hero-content p {font-size: 18px; line-height: normal;}
	.product-categories,.section-events, .latest-products{ padding:1.5rem 0 }
	.product-categories-container{ padding-top:1rem; }
	.product-categories h2, .section-events h2, .latest-products h2, .related.products h2{ margin: 0; padding: 0; font-size: 34px; line-height: normal;}
	.slick-slider{margin-top: 1rem;}
	ul#menu-footer-menu{grid-template-columns: 1fr 1fr;}
	.social-navigation, .footer-bottom p{margin-top: 0;}
	.woocommerce ul.products[class*=columns-] li.product, .woocommerce-page ul.products[class*=columns-] li.product {
        width: 100%; float: left; clear: both; margin: 0 0 2.992em;
    }
    .entry-header .entry-title {text-align: center;}
    .woocommerce .woocommerce-result-count {text-align: center; width: 100%;}
    .woocommerce .woocommerce-ordering, body .woocommerce .woocommerce-ordering select{ width: 100%; }
    .gallery-columns-4 .gallery-item { max-width: calc((100% - 16px* 2) / 2);}
    .contact-map{padding-top: 0}
	.careliahelmi-hero .hero-content {max-width: 100%;}
	.wc-block-cart-item__product .wc-block-components-product-name {padding-right: 30px;}
	p.woocommerce-form-row.woocommerce-form-row--last.form-row.form-row-last { width: 100%;}
	p.woocommerce-form-row.woocommerce-form-row--first.form-row.form-row-first {width: 100%;}
	.woocommerce-MyAccount-content .woocommerce-info { height: 120px;}
	.woocommerce-MyAccount-content .woocommerce-info a.button { position: absolute;  top: 55px;}
	.d-grid .product {margin-bottom: 30px;}

    .hero-content{min-width: 380px}
    #masthead .logo{max-width: 130px;}
    .btn-primary, a.btn-primary:visited, .single_add_to_cart_button, 
    .add_to_cart_button.ajax_add_to_cart{font-size: 14px !important; padding: 12px 20px !important; line-height: normal;}
    .wishlist_table .product-add-to-cart a.button{padding: 6px !important;}
    .latest-products { padding-bottom:0; }
    .section-events h2, .related.products h2{padding-bottom: 20px;}
    .event-card h2{font-size: 1.1rem;}
    .wc-block-components-totals-wrapper { padding: 16px 10px;}
    .btn-hero{padding: 8px 20px;font-size: 16px;}
}
@media (max-width:570px){
	.d-grid .product .product-title { min-height: 0;}
    .newsletter-signup{max-width: 90%; padding-left: 15px;}
    .wpfMainWrapper{flex-direction: column; gap: 0;}  
    .section-offer{ margin-top:1rem } 
}

@media (max-width:480px){
    .email-newsletter{min-height: 400px;}
    .newsletter-signup input[type="email"]{height: 50px;}
    .newsletter-signup button[type="submit"]{position: relative; width: 98%; margin-left: 14px;}
    .email-newsletter h3 { font-size: 24px; line-height: 34px;}   
    .top-header{ font-size:12px;
        display: -webkit-box;
        -webkit-line-clamp: 1;
        -webkit-box-orient: vertical;
        overflow: hidden;
        text-overflow: ellipsis;
        text-align: left;
        overflow: scroll;
        padding-right: 100px; 
    }
    ul.products.columns-3, ul.products.columns-4 { grid-template-columns: repeat(1, 1fr);  gap:0 5px; }
    .blog-post-txt h3{font-size: 1rem;}
    .top-breadcrumb{ padding:10px 0 }
}

@media (max-width:380px){
	.header-right.d-flex.align_ic.gap-10{gap:1px;}
    .newsletter-signup button[type="submit"]{position: relative; width: 99%; margin-left: 11px;}
    .hero-content{min-width: 350px}
    .blog-thumb {height: 220px;}
}
