/*
Theme Name: Kimsoft Lite
Theme URI: https://kimsoft.se/
Author: Kimsoft
Author URI: https://kimsoft.se/
Description: Lightweight Elementor-ready theme with modern header, WooCommerce support, and plugin recommendations.
Version: 1.6.6
Requires at least: 6.0
Requires PHP: 8.0
Text Domain: kimsoft-lite
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Tags: elementor, custom-logo, one-column, full-width-template
*/

/* === RESET & BASE === */

:root {
	--k-primary-base: #c9a84c;
	--k-accent-base: #b8943f;
	--k-text-base: #e5e5e5;
	--k-muted-base: #888888;
	--k-bg: #0f0f0f;
	--k-white: #1a1a1a;
	--k-border: #2a2a2a;
	--k-radius: 12px;
	--k-font: system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

	--k-primary: var(--k-primary-base);
	--k-accent: var(--k-accent-base);
	--k-text: var(--k-text-base);
	--k-muted: var(--k-muted-base);
}

body {
	--k-primary: var(--e-global-color-primary, var(--k-primary-base));
	--k-accent: var(--e-global-color-accent, var(--k-accent-base));
	--k-text: var(--e-global-color-text, var(--k-text-base));
	--k-muted: var(--e-global-color-secondary, var(--k-muted-base));
}

*, *::before, *::after { box-sizing: border-box; }

html:focus-within { scroll-behavior: smooth; }

body {
	margin: 0;
	color: var(--k-text);
	background: var(--k-bg);
	font-family: var(--e-global-typography-text-font-family, var(--k-font));
	font-size: 16px;
	line-height: 1.65;
	-webkit-font-smoothing: antialiased;
}

img { max-width: 100%; height: auto; display: block; }

a { color: var(--k-primary); text-decoration-thickness: 1.5px; text-underline-offset: 3px; }
a:hover { color: var(--k-accent); }

a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible {
	outline: 3px solid color-mix(in srgb, var(--k-primary) 40%, transparent);
	outline-offset: 2px;
}

/* === LAYOUT === */

.kimsoft-site {
	min-height: 100vh;
	display: flex;
	flex-direction: column;
}

.kimsoft-main {
	width: 100%;
	flex: 1 0 auto;
	max-width: 1140px;
	margin: 0 auto;
	padding: 32px 20px;
}

/* === HEADER === */

.kimsoft-header {
	position: sticky;
	top: 0;
	z-index: 1000;
	background: color-mix(in srgb, var(--k-bg) 92%, transparent);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
	transition: background .3s ease, box-shadow .3s ease;
}

.kimsoft-header.is-scrolled {
	background: color-mix(in srgb, var(--k-bg) 96%, transparent);
	box-shadow: 0 1px 0 color-mix(in srgb, var(--k-border) 50%, transparent);
}

.kimsoft-header__inner {
	max-width: 1140px;
	margin: 0 auto;
	padding: 0 24px;
	height: 72px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
}

/* Logo */
.kimsoft-logo,
.custom-logo-link {
	display: inline-flex;
	align-items: center;
	text-decoration: none;
	flex-shrink: 0;
}

.kimsoft-logo {
	font-weight: 800;
	font-size: 20px;
	letter-spacing: -.03em;
	color: var(--k-text);
	transition: opacity .2s ease;
}

.kimsoft-logo:hover { opacity: .7; }

.custom-logo { max-height: 40px; width: auto; }

/* === DESKTOP NAV === */

.kimsoft-nav--desktop { display: flex; }

.kimsoft-menu--desktop {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	align-items: center;
	gap: 2px;
}

.kimsoft-menu--desktop li { position: relative; }

.kimsoft-menu--desktop > li > a {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 16px;
	color: var(--k-muted);
	font-weight: 500;
	font-size: 14px;
	text-decoration: none;
	letter-spacing: .01em;
	position: relative;
	transition: color .25s ease;
}

.kimsoft-menu--desktop > li > a::after {
	content: '';
	position: absolute;
	bottom: 2px;
	left: 16px;
	right: 16px;
	height: 1.5px;
	background: var(--k-primary);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform .3s cubic-bezier(.4,0,.2,1);
}

.kimsoft-menu--desktop > li > a:hover,
.kimsoft-menu--desktop > li.current-menu-item > a,
.kimsoft-menu--desktop > li.current-menu-ancestor > a {
	color: var(--k-text);
}

.kimsoft-menu--desktop > li > a:hover::after,
.kimsoft-menu--desktop > li.current-menu-item > a::after,
.kimsoft-menu--desktop > li.current-menu-ancestor > a::after {
	transform: scaleX(1);
}

/* Desktop dropdown */
.kimsoft-menu--desktop .sub-menu {
	position: absolute;
	left: 0;
	top: 100%;
	min-width: 220px;
	list-style: none;
	margin: 0;
	padding: 8px;
	padding-top: 16px;
	background: var(--k-white);
	border: 1px solid var(--k-border);
	border-radius: 14px;
	box-shadow: 0 16px 48px color-mix(in srgb, var(--k-bg) 50%, transparent);
	z-index: 50;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transform: translateY(8px);
	background-clip: padding-box;
}

.kimsoft-menu--desktop .sub-menu::before {
	content: '';
	position: absolute;
	top: -10px;
	left: 0;
	right: 0;
	height: 10px;
}

.kimsoft-menu--desktop li:hover > .sub-menu {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transform: translateY(0);
	transition: opacity .2s ease, transform .25s ease;
}

.kimsoft-menu--desktop .sub-menu a {
	display: flex;
	align-items: center;
	padding: 10px 14px;
	border-radius: 8px;
	width: 100%;
	font-size: 13px;
	font-weight: 500;
	color: var(--k-muted);
	transition: color .15s ease, background .15s ease;
}

.kimsoft-menu--desktop .sub-menu a:hover {
	color: var(--k-text);
	background: color-mix(in srgb, var(--k-text) 5%, transparent);
}

/* Desktop submenu toggle hidden */
.kimsoft-submenu-toggle { display: none; }

/* === HAMBURGER BUTTON === */

.kimsoft-nav-toggle {
	display: none;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	padding: 0;
	background: transparent;
	border: none;
	color: var(--k-text);
	cursor: pointer;
	-webkit-tap-highlight-color: transparent;
}

.kimsoft-hamburger {
	width: 24px;
	height: 16px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	pointer-events: none;
}

.kimsoft-hamburger span {
	display: block;
	height: 2px;
	background: currentColor;
	border-radius: 2px;
	transform-origin: center;
	transition: transform .4s cubic-bezier(.77,0,.18,1), opacity .25s ease, width .3s ease;
}

.kimsoft-hamburger span:nth-child(2) {
	width: 60%;
	margin-left: auto;
}

.kimsoft-nav-toggle.is-open .kimsoft-hamburger span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.kimsoft-nav-toggle.is-open .kimsoft-hamburger span:nth-child(2) { opacity: 0; width: 0; }
.kimsoft-nav-toggle.is-open .kimsoft-hamburger span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* === MOBILE DRAWER (fullscreen) === */

.kimsoft-mobile-drawer {
	position: fixed;
	inset: 0;
	z-index: 2000;
	pointer-events: none;
	visibility: hidden;
}

.kimsoft-mobile-drawer.is-open {
	pointer-events: auto;
	visibility: visible;
}

.kimsoft-mobile-drawer__backdrop {
	position: absolute;
	inset: 0;
	background: var(--k-bg);
	opacity: 0;
}

.kimsoft-mobile-drawer__panel {
	position: absolute;
	inset: 0;
	background: var(--k-bg);
	display: flex;
	flex-direction: column;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	opacity: 0;
}

.kimsoft-mobile-drawer__top {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 14px 24px;
	flex-shrink: 0;
}

.kimsoft-mobile-drawer__close {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	background: transparent;
	border: 1px solid var(--k-border);
	border-radius: 50%;
	cursor: pointer;
	color: var(--k-muted);
	transition: color .2s ease, border-color .2s ease;
}

.kimsoft-mobile-drawer__close:hover {
	color: var(--k-text);
	border-color: var(--k-text);
}

/* === MOBILE MENU === */

.kimsoft-nav--mobile {
	flex: 1;
	display: flex;
	align-items: flex-start;
	padding: 16px 24px 40px;
}

.kimsoft-menu--mobile {
	list-style: none;
	margin: 0;
	padding: 0;
	width: 100%;
}

.kimsoft-menu--mobile > li {
	display: grid;
	grid-template-columns: 1fr auto;
	align-items: center;
	border-bottom: 1px solid color-mix(in srgb, var(--k-border) 50%, transparent);
}

.kimsoft-menu--mobile > li > a { grid-column: 1; }
.kimsoft-menu--mobile > li > .kimsoft-submenu-toggle { grid-column: 2; }
.kimsoft-menu--mobile > li > ul.sub-menu { grid-column: 1 / -1; }

.kimsoft-menu--mobile > li > a {
	display: flex;
	align-items: center;
	padding: 20px 0;
	font-weight: 600;
	font-size: clamp(18px, 4vw, 24px);
	color: var(--k-text);
	text-decoration: none;
	letter-spacing: -.01em;
	transition: color .2s ease;
}

.kimsoft-menu--mobile > li > a:hover {
	color: var(--k-primary);
}

.kimsoft-menu--mobile .sub-menu {
	display: none;
	list-style: none;
	margin: 0;
	padding: 0 0 12px;
}

.kimsoft-menu--mobile .sub-menu li {
	display: grid;
	grid-template-columns: 1fr auto;
	align-items: center;
}

.kimsoft-menu--mobile .sub-menu > li > a { grid-column: 1; }
.kimsoft-menu--mobile .sub-menu > li > .kimsoft-submenu-toggle { grid-column: 2; }
.kimsoft-menu--mobile .sub-menu > li > ul.sub-menu { grid-column: 1 / -1; }

.kimsoft-menu--mobile .sub-menu a {
	font-weight: 500;
	padding: 12px 0 12px 16px;
	font-size: 16px;
	color: var(--k-muted);
	text-decoration: none;
	transition: color .2s ease;
}

.kimsoft-menu--mobile .sub-menu a:hover {
	color: var(--k-primary);
}

/* Mobile submenu toggle (chevron button) */
.kimsoft-menu--mobile .kimsoft-submenu-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	border: 1px solid var(--k-border);
	background: transparent;
	cursor: pointer;
	flex-shrink: 0;
	transition: border-color .2s ease;
}

.kimsoft-menu--mobile .kimsoft-submenu-toggle:hover {
	border-color: var(--k-text);
}

.kimsoft-submenu-toggle__icon {
	width: 8px;
	height: 8px;
	border-right: 2px solid var(--k-muted);
	border-bottom: 2px solid var(--k-muted);
	transform: rotate(45deg);
	transition: transform .35s cubic-bezier(.77,0,.18,1);
}

.kimsoft-submenu-toggle.is-open .kimsoft-submenu-toggle__icon {
	transform: rotate(225deg);
}

.kimsoft-lock-scroll { overflow: hidden !important; }

/* === FOOTER === */

.kimsoft-footer {
	background: var(--k-white);
	border-top: 1px solid var(--k-border);
	margin-top: auto;
}

.kimsoft-footer__inner {
	max-width: 1140px;
	margin: 0 auto;
	padding: 32px 20px;
}

.kimsoft-footer__row {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 20px;
	flex-wrap: wrap;
}

.kimsoft-footer__brand {
	font-weight: 800;
	font-size: 16px;
	color: var(--k-text);
}

.kimsoft-footer-menu {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
}

.kimsoft-footer-menu a {
	text-decoration: none;
	color: var(--k-muted);
	font-weight: 600;
	font-size: 14px;
	transition: color .15s ease;
}

.kimsoft-footer-menu a:hover { color: var(--k-primary); }

.kimsoft-footer__meta {
	margin-top: 20px;
	padding-top: 16px;
	border-top: 1px solid var(--k-border);
	color: var(--k-muted);
	font-size: 13px;
}

/* === SKIP LINK === */

.kimsoft-skip-link {
	position: absolute;
	left: -9999px;
	top: auto;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

.kimsoft-skip-link:focus {
	left: 16px;
	top: 16px;
	width: auto;
	height: auto;
	padding: 12px 16px;
	background: var(--k-white);
	border: 1px solid var(--k-border);
	border-radius: var(--k-radius);
	z-index: 99999;
	font-weight: 700;
}

/* === PAGE HERO === */

.kimsoft-hero {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 48px 20px 32px;
	text-align: center;
	width: 100vw;
	margin-left: calc(-50vw + 50%);
	margin-top: -32px;
}

.kimsoft-hero__title {
	margin: 0;
	font-size: clamp(28px, 4vw, 42px);
	font-weight: 800;
	color: var(--k-text);
	letter-spacing: -.02em;
	line-height: 1.2;
}

/* === ELEMENTOR FULL WIDTH === */

body.elementor-page .kimsoft-main,
body.elementor-template-full-width .kimsoft-main,
body.elementor-template-canvas .kimsoft-main,
body.elementor-editor-active .kimsoft-main,
body.elementor-editor-preview .kimsoft-main {
	max-width: none;
	padding: 0;
}

body.elementor-page .kimsoft-hero,
body.elementor-editor-active .kimsoft-hero,
body.elementor-editor-preview .kimsoft-hero {
	display: none;
}

body.elementor-page .kimsoft-woocommerce,
body.elementor-template-full-width .kimsoft-woocommerce {
	max-width: none;
	padding: 0;
	margin: 0;
}

/* === CONTENT CONTAINERS === */

.kimsoft-post,
.kimsoft-page,
.kimsoft-single {
	padding: 0;
}

.kimsoft-page__content,
.kimsoft-single__content,
.kimsoft-post__content {
	line-height: 1.7;
	color: var(--k-text);
}

/* === ELEMENTOR OVERRIDES === */

.elementor-widget-container { word-break: break-word; }
.elementor-heading-title { letter-spacing: -.015em; }

.elementor-button {
	border-radius: 10px;
	font-weight: 700;
}

.elementor-form input[type="text"],
.elementor-form input[type="email"],
.elementor-form input[type="url"],
.elementor-form input[type="tel"],
.elementor-form input[type="number"],
.elementor-form input[type="search"],
.elementor-form input[type="password"],
.elementor-form textarea {
	border-radius: 10px;
	border: 1px solid var(--k-border);
	padding: 12px 14px;
}

.elementor-form input:focus,
.elementor-form textarea:focus {
	border-color: var(--k-primary);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--k-primary) 15%, transparent);
	outline: none;
}

.elementor-section.elementor-section-boxed > .elementor-container {
	max-width: 1140px;
}

/* === WOOCOMMERCE === */

.woocommerce { color: var(--k-text); }

.woocommerce .woocommerce-breadcrumb {
	color: var(--k-muted);
	font-size: 14px;
	margin: 0 0 18px;
}

.woocommerce .woocommerce-breadcrumb a { color: var(--k-primary); }

.woocommerce a.button,
.woocommerce a.button.alt,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce button.button.alt,
.woocommerce input.button.alt {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	background: var(--k-primary);
	color: #fff;
	border: none;
	border-radius: 10px;
	padding: 12px 20px;
	font-weight: 700;
	text-decoration: none;
	line-height: 1;
	transition: background .15s ease;
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover {
	background: var(--k-accent);
	color: #fff;
}

.woocommerce input[type="text"],
.woocommerce input[type="email"],
.woocommerce input[type="url"],
.woocommerce input[type="tel"],
.woocommerce input[type="number"],
.woocommerce input[type="search"],
.woocommerce input[type="password"],
.woocommerce textarea,
.woocommerce select {
	border: 1px solid var(--k-border);
	border-radius: 10px;
	padding: 12px 14px;
	background: var(--k-white);
}

.woocommerce input:focus,
.woocommerce textarea:focus,
.woocommerce select:focus {
	border-color: var(--k-primary);
	outline: none;
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--k-primary) 15%, transparent);
}

.woocommerce .woocommerce-message,
.woocommerce .woocommerce-error,
.woocommerce .woocommerce-info {
	border-radius: var(--k-radius);
	border: 1px solid var(--k-border);
	background: var(--k-white);
	padding: 14px 18px;
}

.woocommerce .woocommerce-error { border-color: #dc2626; }
.woocommerce .woocommerce-info { border-color: var(--k-primary); }

/* WooCommerce single product */
.woocommerce div.product {
	background: var(--k-white);
	border: 1px solid var(--k-border);
	border-radius: var(--k-radius);
	padding: 32px;
}

.woocommerce div.product .product_title {
	color: var(--k-text);
	font-weight: 800;
	font-size: 28px;
	letter-spacing: -.02em;
	margin-bottom: 10px;
}

.woocommerce div.product .price {
	color: var(--k-primary);
	font-size: 24px;
	font-weight: 800;
	margin-bottom: 16px;
}

.woocommerce div.product .price del {
	opacity: .45;
	font-size: 18px;
}

.woocommerce div.product .price ins {
	text-decoration: none;
}

.woocommerce div.product .woocommerce-product-details__short-description {
	color: var(--k-muted);
	line-height: 1.7;
	margin-bottom: 20px;
}

.woocommerce div.product .stock {
	font-size: 13px;
	font-weight: 700;
}

.woocommerce div.product .stock.in-stock {
	color: #22c55e;
}

.woocommerce div.product .stock.out-of-stock {
	color: #ef4444;
}

.woocommerce div.product form.cart {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-top: 16px;
	margin-bottom: 24px;
}

.woocommerce div.product form.cart .quantity input[type="number"] {
	width: 70px;
	text-align: center;
	border: 1px solid var(--k-border);
	border-radius: 10px;
	padding: 10px;
	background: var(--k-bg);
	color: var(--k-text);
	font-size: 15px;
	-moz-appearance: textfield;
}

.woocommerce div.product form.cart .quantity input[type="number"]::-webkit-inner-spin-button,
.woocommerce div.product form.cart .quantity input[type="number"]::-webkit-outer-spin-button {
	opacity: 1;
}

.woocommerce div.product form.cart .single_add_to_cart_button {
	flex: 1;
}

.woocommerce span.onsale {
	background: var(--k-primary);
	color: var(--k-bg);
	font-weight: 800;
	font-size: 13px;
	border-radius: 6px;
	padding: 4px 12px;
	line-height: 1.4;
	min-width: auto;
	min-height: auto;
}

.woocommerce div.product .woocommerce-tabs ul.tabs {
	list-style: none;
	padding: 0;
	margin: 0 0 20px;
	display: flex;
	gap: 4px;
	border-bottom: 1px solid var(--k-border);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	display: block;
	padding: 12px 18px;
	font-weight: 700;
	font-size: 14px;
	color: var(--k-muted);
	text-decoration: none;
	border-bottom: 2px solid transparent;
	transition: color .15s ease;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
	color: var(--k-primary);
	border-bottom-color: var(--k-primary);
}

.woocommerce div.product .woocommerce-tabs .panel {
	color: var(--k-muted);
	line-height: 1.7;
}

.woocommerce div.product .woocommerce-tabs .panel h2 {
	color: var(--k-text);
	font-size: 18px;
	font-weight: 800;
}

/* WooCommerce product image gallery */
.woocommerce div.product div.images img {
	border-radius: 10px;
}

.woocommerce div.product div.images .flex-control-thumbs li img {
	border-radius: 6px;
	opacity: .6;
	transition: opacity .15s ease;
}

.woocommerce div.product div.images .flex-control-thumbs li img.flex-active,
.woocommerce div.product div.images .flex-control-thumbs li img:hover {
	opacity: 1;
}

/* WooCommerce product meta */
.woocommerce div.product .product_meta {
	color: var(--k-muted);
	font-size: 14px;
}

.woocommerce div.product .product_meta a {
	color: var(--k-primary);
}

/* WooCommerce product loops (related, up-sells, cross-sells) */
.woocommerce ul.products {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 20px;
}

.woocommerce ul.products li.product {
	list-style: none;
	margin: 0;
	padding: 0;
}

.related.products > h2,
.up-sells > h2,
.cross-sells > h2 {
	color: var(--k-text);
	font-weight: 800;
	font-size: 22px;
	margin: 40px 0 20px;
	letter-spacing: -.01em;
}

@media (max-width: 900px) {
	.woocommerce ul.products { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 560px) {
	.woocommerce ul.products { grid-template-columns: 1fr; }
}

/* WooCommerce tables */
.woocommerce table.shop_table {
	width: 100%;
	border: 1px solid var(--k-border);
	border-collapse: collapse;
	border-radius: var(--k-radius);
	overflow: hidden;
	color: var(--k-text);
}

.woocommerce table.shop_table thead th {
	background: color-mix(in srgb, var(--k-text) 3%, transparent);
	font-weight: 700;
	text-align: left;
	padding: 14px 16px;
	border-bottom: 1px solid var(--k-border);
	color: var(--k-muted);
	font-size: 13px;
	text-transform: uppercase;
	letter-spacing: .04em;
}

.woocommerce table.shop_table td,
.woocommerce table.shop_table th {
	padding: 14px 16px;
	border-bottom: 1px solid var(--k-border);
	vertical-align: middle;
}

.woocommerce table.shop_table .product-thumbnail img {
	border-radius: 8px;
	width: 64px;
	height: 64px;
	object-fit: cover;
}

.woocommerce table.shop_table .product-name a {
	color: var(--k-text);
	font-weight: 700;
	text-decoration: none;
}

.woocommerce table.shop_table .product-price,
.woocommerce table.shop_table .product-subtotal {
	color: var(--k-primary);
	font-weight: 700;
}

.woocommerce table.shop_table .product-remove a {
	color: var(--k-muted);
	font-size: 18px;
	text-decoration: none;
	transition: color .15s ease;
}

.woocommerce table.shop_table .product-remove a:hover {
	color: #ef4444;
}

/* WooCommerce cart totals */
.woocommerce .cart_totals {
	background: var(--k-white);
	border: 1px solid var(--k-border);
	border-radius: var(--k-radius);
	padding: 24px;
}

.woocommerce .cart_totals h2 {
	color: var(--k-text);
	font-weight: 800;
	margin: 0 0 16px;
	font-size: 18px;
}

/* WooCommerce checkout */
.woocommerce form.checkout {
	color: var(--k-text);
}

.woocommerce form.checkout h3 {
	color: var(--k-text);
	font-weight: 800;
	margin-bottom: 16px;
}

.woocommerce form.checkout label {
	color: var(--k-muted);
	font-weight: 600;
	font-size: 14px;
}

.woocommerce .woocommerce-billing-fields,
.woocommerce .woocommerce-shipping-fields,
.woocommerce .woocommerce-additional-fields {
	background: var(--k-white);
	border: 1px solid var(--k-border);
	border-radius: var(--k-radius);
	padding: 24px;
	margin-bottom: 20px;
}

.woocommerce-checkout #order_review,
.woocommerce-checkout .woocommerce-checkout-review-order,
.woocommerce-checkout .woocommerce-checkout-payment {
	background: var(--k-white);
	border: 1px solid var(--k-border);
	border-radius: var(--k-radius);
	padding: 24px;
}

/* WooCommerce pagination */
.woocommerce nav.woocommerce-pagination ul {
	list-style: none;
	padding: 0;
	margin: 32px 0 0;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.woocommerce nav.woocommerce-pagination a,
.woocommerce nav.woocommerce-pagination span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 14px;
	border-radius: 10px;
	border: 1px solid var(--k-border);
	background: var(--k-white);
	font-weight: 700;
	text-decoration: none;
	color: var(--k-text);
	transition: border-color .15s ease, color .15s ease;
}

.woocommerce nav.woocommerce-pagination a:hover {
	border-color: var(--k-primary);
	color: var(--k-primary);
}

.woocommerce nav.woocommerce-pagination .current {
	background: color-mix(in srgb, var(--k-primary) 10%, transparent);
	border-color: var(--k-primary);
	color: var(--k-primary);
}

.woocommerce .quantity .qty {
	width: 80px;
	text-align: center;
	background: var(--k-white);
	color: var(--k-text);
}

/* WooCommerce result count + ordering (hidden; replaced by kpg-filters) */
.woocommerce .woocommerce-result-count { color: var(--k-muted); font-size: 14px; }
.woocommerce .woocommerce-ordering select {
	background: var(--k-white);
	color: var(--k-text);
	border: 1px solid var(--k-border);
	border-radius: 10px;
	padding: 10px 14px;
	font-size: 14px;
}

/* === SCROLL REVEAL (initial states — only when JS animations are active) === */

html.k-anim .k-reveal {
	opacity: 0;
	transform: translateY(40px);
	will-change: opacity, transform;
}

html.k-anim .k-reveal--left {
	opacity: 0;
	transform: translateX(-60px);
	will-change: opacity, transform;
}

html.k-anim .k-reveal--right {
	opacity: 0;
	transform: translateX(60px);
	will-change: opacity, transform;
}

html.k-anim .k-reveal--scale {
	opacity: 0;
	transform: scale(0.88);
	will-change: opacity, transform;
}

html.k-anim .k-reveal--stagger > * {
	opacity: 0;
	transform: translateY(30px);
}

/* === HOVER EFFECTS (Elementor CSS Classes) === */

.k-hover-lift {
	transition: transform .25s cubic-bezier(.4,0,.2,1), box-shadow .25s ease;
}

.k-hover-lift:hover {
	transform: translateY(-6px);
	box-shadow: 0 16px 40px rgba(15,23,42,.1);
}

.k-hover-zoom {
	overflow: hidden;
}

.k-hover-zoom img,
.k-hover-zoom .elementor-image img,
.k-hover-zoom > * {
	transition: transform .4s cubic-bezier(.4,0,.2,1);
}

.k-hover-zoom:hover img,
.k-hover-zoom:hover .elementor-image img,
.k-hover-zoom:hover > * {
	transform: scale(1.06);
}

.k-hover-glow {
	transition: box-shadow .3s ease;
}

.k-hover-glow:hover {
	box-shadow: 0 0 30px color-mix(in srgb, var(--k-primary) 18%, transparent), 0 0 60px color-mix(in srgb, var(--k-primary) 6%, transparent);
}

/* === RIPPLE EFFECT === */

.k-ripple {
	position: relative;
	overflow: hidden;
}

.k-ripple__wave {
	position: absolute;
	border-radius: 50%;
	background: rgba(255,255,255,.35);
	pointer-events: none;
	z-index: 1;
}

/* === PARALLAX === */

.k-parallax {
	background-attachment: fixed;
	background-size: cover;
	background-position: center;
}

@supports (-webkit-touch-callout: none) {
	.k-parallax { background-attachment: scroll; }
}

/* === COUNTER === */

.k-counter {
	font-variant-numeric: tabular-nums;
}

/* === CART (native + widget) === */

.kc-layout {
	display: flex;
	gap: 32px;
	align-items: flex-start;
}

.kc-continue {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	text-decoration: none;
	color: var(--k-muted);
	font-size: 13px;
	font-weight: 600;
	margin-bottom: 12px;
	transition: opacity .15s ease;
}

.kc-continue:hover { opacity: .7; }

.kc-page-title {
	color: var(--k-text);
	font-weight: 800;
	margin: 0 0 24px;
	line-height: 1.2;
	letter-spacing: -.02em;
}

.kc-items {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
}

.kc-item {
	display: flex;
	align-items: center;
	gap: 16px;
	padding: 16px 0;
	border-bottom: 1px solid var(--k-border);
}

.kc-thumb-link { flex-shrink: 0; }

.kc-thumb {
	width: 80px;
	height: 80px;
	border-radius: 8px;
	object-fit: cover;
	display: block;
}

.kc-item-info {
	flex: 1;
	min-width: 0;
}

.kc-name {
	display: block;
	font-weight: 700;
	text-decoration: none;
	color: var(--k-text);
	margin-bottom: 2px;
}

.kc-sku {
	display: block;
	font-weight: 600;
	letter-spacing: .04em;
	text-transform: uppercase;
	color: var(--k-muted);
	font-size: 11px;
	margin-bottom: 6px;
}

.kc-qty-wrap { margin-top: 8px; }

.kc-item-end {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 6px;
}

.kc-price {
	color: var(--k-primary);
	font-weight: 800;
	font-size: 16px;
}

.kc-remove {
	color: var(--k-muted);
	font-size: 18px;
	text-decoration: none;
	transition: color .15s ease;
}

.kc-remove:hover { color: var(--k-text); }

.kc-update { margin-top: 16px; }

.kc-summary {
	width: 340px;
	flex-shrink: 0;
	background: var(--k-white);
	border: 1px solid var(--k-border);
	border-radius: var(--k-radius);
	padding: 24px;
	position: sticky;
	top: 80px;
}

.kc-sum-title {
	color: var(--k-text);
	font-weight: 800;
	margin: 0 0 16px;
	font-size: 18px;
}

.kc-sum-row {
	display: flex;
	justify-content: space-between;
	padding: 10px 0;
	border-bottom: 1px solid var(--k-border);
}

.kc-sum-label {
	color: var(--k-muted);
	font-size: 14px;
}

.kc-sum-value {
	color: var(--k-text);
	font-weight: 700;
}

.kc-sum-total {
	border-bottom: none;
	padding-top: 14px;
}

.kc-sum-total .kc-sum-label {
	color: var(--k-text);
	font-size: 16px;
	font-weight: 800;
}

.kc-sum-total .kc-sum-value {
	color: var(--k-primary);
	font-size: 18px;
	font-weight: 800;
}

.kc-qty-wrap {
	display: inline-flex;
	align-items: center;
	border: 1px solid color-mix(in srgb, var(--k-text) 12%, transparent);
	overflow: hidden;
}

.kc-qty-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border: none;
	cursor: pointer;
	font-size: 16px;
	font-weight: 700;
	line-height: 1;
	transition: background .15s ease;
}

.kc-qty-btn:hover { opacity: .8; }

.kc-qty-val {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 32px;
	height: 32px;
	font-weight: 700;
	font-size: 14px;
}

.kc-item-end {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 8px;
	flex-shrink: 0;
}

.kc-remove {
	display: inline-flex;
	transition: color .15s ease;
	text-decoration: none;
}

.kc-price {
	font-weight: 800;
	white-space: nowrap;
}

.kc-summary {
	border: 1px solid transparent;
	flex-shrink: 0;
	width: 320px;
	align-self: flex-start;
	position: sticky;
	top: 80px;
}

.kc-sum-title {
	font-weight: 800;
	margin: 0 0 16px;
	font-size: 18px;
}

.kc-sum-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 10px 0;
	border-bottom: 1px solid color-mix(in srgb, var(--k-text) 6%, transparent);
}

.kc-sum-label {
	font-weight: 600;
	font-size: 14px;
}

.kc-sum-value {
	font-weight: 700;
	font-size: 14px;
}

.kc-sum-total {
	border-bottom: none;
	padding-top: 14px;
}

.kc-sum-total .kc-sum-label {
	font-size: 16px;
	font-weight: 800;
}

.kc-sum-total .kc-sum-value {
	font-size: 18px;
	font-weight: 800;
}

.kc-checkout-btn {
	display: block;
	width: 100%;
	text-align: center;
	padding: 14px 20px;
	font-weight: 700;
	text-decoration: none;
	border: none;
	cursor: pointer;
	margin-top: 16px;
	transition: background .15s ease, opacity .15s ease;
}

.kc-checkout-btn:hover { opacity: .9; }

.kc-empty {
	text-align: center;
	padding: 40px 20px;
	font-size: 15px;
}

@media (max-width: 768px) {
	.kc-layout { flex-direction: column !important; }
	.kc-summary { width: 100%; position: static; }
}

/* === CHECKOUT (native + widget) === */

.kco-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 28px;
	align-items: start;
}

.kco-wrap {
	overflow: hidden;
	border: 1px solid transparent;
}

.kco-wrap input:not([type="submit"]):not([type="checkbox"]):not([type="radio"]),
.kco-wrap textarea,
.kco-wrap select {
	width: 100%;
	padding: 12px 14px;
	border: 1px solid var(--k-border);
	background: var(--k-white);
	color: var(--k-text);
	border-radius: 10px;
}

.kco-wrap input:focus,
.kco-wrap textarea:focus,
.kco-wrap select:focus {
	outline: none;
	border-color: var(--k-primary);
}

.kco-wrap h3 {
	color: var(--k-text);
	font-weight: 800;
	margin: 0 0 16px;
	letter-spacing: -.01em;
}

.kco-wrap label {
	display: block;
	color: var(--k-muted);
	font-weight: 600;
	margin-bottom: 4px;
}

.kco-order {
	background: var(--k-white);
	border: 1px solid var(--k-border);
	border-radius: var(--k-radius);
	padding: 24px;
	position: sticky;
	top: 80px;
}

.kco-order-title {
	color: var(--k-text);
	font-weight: 800;
	margin: 0 0 16px;
}

.kco-wrap #place_order {
	display: block;
	width: 100%;
	padding: 14px 20px;
	background: var(--k-primary);
	color: var(--k-bg);
	font-weight: 700;
	border: none;
	border-radius: 10px;
	cursor: pointer;
	transition: opacity .15s ease;
	margin-top: 16px;
}

.kco-wrap #place_order:hover { opacity: .9; }

@media (max-width: 768px) {
	.kco-grid { grid-template-columns: 1fr; }
}

/* === HOVER CARD WIDGET === */

.kimsoft-hover-card {
	display: block;
	text-decoration: none;
	color: inherit;
	border: 1px solid var(--k-border);
	overflow: hidden;
}

/* === PRODUCT GRID (native + widget) === */

.kpg-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 20px;
}

.kpg-card {
	background: var(--k-white);
	border: 1px solid var(--k-border);
	border-radius: 12px;
	padding: 16px;
	display: flex;
	flex-direction: column;
	transition: transform .25s cubic-bezier(.4,0,.2,1), box-shadow .25s ease;
	overflow: hidden;
}

.kpg-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 40px rgba(0,0,0,.35);
}

.kpg-card:hover .kpg-img {
	transform: scale(1.05);
}

.kpg-card:hover .kpg-cart-btn {
	background: color-mix(in srgb, var(--k-text) 18%, transparent);
	color: var(--k-text);
}

.kpg-img-link {
	display: block;
	overflow: hidden;
	border-radius: 8px;
}

.kpg-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	aspect-ratio: 1/1;
	border-radius: 8px;
	transition: transform .4s cubic-bezier(.4,0,.2,1);
}

.kpg-body {
	flex: 1;
	display: flex;
	flex-direction: column;
	padding-top: 12px;
}

.kpg-sku {
	color: var(--k-muted);
	font-size: 11px;
	font-weight: 600;
	letter-spacing: .04em;
	text-transform: uppercase;
	margin-bottom: 4px;
}

.kpg-title {
	color: var(--k-text);
	font-size: 16px;
	margin: 0 0 4px;
	font-weight: 700;
	line-height: 1.3;
}

.kpg-title-link {
	text-decoration: none;
	color: inherit;
}

.kpg-desc {
	color: var(--k-muted);
	font-size: 13px;
	margin: 0 0 8px;
	line-height: 1.5;
	overflow: hidden;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
}

.kpg-footer {
	margin-top: auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 8px;
	padding-top: 8px;
}

.kpg-price-wrap {
	display: flex;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
}

.kpg-price {
	color: var(--k-primary);
	font-size: 18px;
	font-weight: 800;
	line-height: 1;
}

.kpg-badge {
	display: inline-block;
	padding: 3px 10px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: .02em;
	white-space: nowrap;
	border-radius: 6px;
}

.kpg-badge--instock {
	background: rgba(34,197,94,.15);
	color: #22c55e;
}

.kpg-badge--onbackorder {
	background: rgba(234,88,12,.15);
	color: #ea580c;
}

.kpg-badge--outofstock {
	background: rgba(239,68,68,.15);
	color: #ef4444;
}

.kpg-cart-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: 8px;
	border: none;
	cursor: pointer;
	background: color-mix(in srgb, var(--k-text) 8%, transparent);
	color: var(--k-muted);
	transition: background .2s ease, color .2s ease;
	text-decoration: none;
	flex-shrink: 0;
}

.kpg-cart-btn svg {
	width: 18px;
	height: 18px;
	fill: currentColor;
}

.kpg-cart-btn:hover {
	background: color-mix(in srgb, var(--k-text) 18%, transparent);
	color: var(--k-text);
}

/* === SHOP PAGE LAYOUT === */

.kimsoft-shop {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 20px;
}

.kimsoft-shop__title {
	color: var(--k-text);
	font-weight: 800;
	font-size: 28px;
	margin: 0 0 24px;
	letter-spacing: -.02em;
}

.kimsoft-shop__toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	flex-wrap: wrap;
	margin-bottom: 28px;
}

.kimsoft-shop__meta {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 12px;
	margin-bottom: 20px;
	clear: both;
}

.kimsoft-shop__meta::after {
	content: '';
	display: table;
	clear: both;
}

.kimsoft-shop__meta .woocommerce-result-count {
	margin: 0;
	color: var(--k-muted);
	font-size: 14px;
	float: none;
}

.kimsoft-shop__meta .woocommerce-ordering {
	float: none;
}

.kimsoft-shop__meta .woocommerce-ordering select {
	background: var(--k-white);
	color: var(--k-text);
	border: 1px solid var(--k-border);
	border-radius: 10px;
	padding: 10px 14px;
	font-size: 14px;
}

.kpg-filters {
	display: flex;
	align-items: center;
	gap: 6px;
	flex-wrap: wrap;
}

.kpg-filter {
	display: inline-flex;
	align-items: center;
	padding: 8px 16px;
	border: 1px solid var(--k-border);
	border-radius: 10px;
	background: transparent;
	color: var(--k-muted);
	font-size: 14px;
	font-weight: 600;
	text-decoration: none;
	cursor: pointer;
	transition: border-color .15s ease, color .15s ease, background .15s ease;
	white-space: nowrap;
}

.kpg-filter:hover {
	border-color: var(--k-primary);
	color: var(--k-primary);
}

.kpg-filter--active {
	border-color: var(--k-primary);
	color: var(--k-primary);
	background: color-mix(in srgb, var(--k-primary) 8%, transparent);
}

.kpg-search {
	display: flex;
	align-items: center;
	gap: 8px;
	background: var(--k-white);
	border: 1px solid var(--k-border);
	border-radius: 10px;
	padding: 0 14px;
	min-width: 240px;
	transition: border-color .15s ease;
}

.kpg-search:focus-within {
	border-color: var(--k-primary);
}

.kpg-search svg {
	flex-shrink: 0;
	color: var(--k-muted);
}

.kpg-search input[type="search"] {
	background: transparent;
	border: none;
	color: var(--k-text);
	font-size: 14px;
	padding: 10px 0;
	width: 100%;
	outline: none;
	box-shadow: none;
}

.kpg-search input[type="search"]::placeholder {
	color: var(--k-muted);
}

@media (max-width: 900px) {
	.kpg-grid { grid-template-columns: repeat(2, 1fr) !important; }
	.kimsoft-shop__toolbar { flex-direction: column; align-items: stretch; }
	.kpg-search { min-width: 0; }
	.kimsoft-shop--checkout .checkout > div { grid-template-columns: 1fr !important; }
	.kimsoft-shop--cart .kc-layout { flex-direction: column !important; }
	.kimsoft-shop--cart .kc-summary { width: 100% !important; position: static !important; }
}

@media (max-width: 560px) {
	.kpg-grid { grid-template-columns: 1fr !important; }
}

/* === RESPONSIVE === */

@media (max-width: 860px) {
	.kimsoft-nav--desktop { display: none; }
	.kimsoft-nav-toggle { display: inline-flex; }
	.kimsoft-main { padding: 24px 16px; }
}

@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
	.kimsoft-mobile-drawer__panel { transition: none; }
	.kimsoft-mobile-drawer__backdrop { transition: none; }
	.kimsoft-menu--desktop .sub-menu { transition: none; }
	.kimsoft-hamburger__line { transition: none; }

	html.k-anim .k-reveal,
	html.k-anim .k-reveal--left,
	html.k-anim .k-reveal--right,
	html.k-anim .k-reveal--scale { opacity: 1; transform: none; }
	html.k-anim .k-reveal--stagger > * { opacity: 1; transform: none; }
	.k-hover-lift:hover { transform: none; }
	.k-hover-zoom:hover img,
	.k-hover-zoom:hover > * { transform: none; }
}
