/*
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.0.0
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: #2563eb;
	--k-accent: #1d4ed8;
	--k-text: #0f172a;
	--k-muted: #64748b;
	--k-bg: #f8fafc;
	--k-white: #ffffff;
	--k-border: #e2e8f0;
	--k-radius: 12px;
	--k-font: system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

	--e-global-color-primary: var(--k-primary);
	--e-global-color-accent: var(--k-accent);
	--e-global-color-text: var(--k-text);
	--e-global-color-secondary: var(--k-muted);
}

*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
	margin: 0;
	color: var(--k-text);
	background: var(--k-bg);
	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 rgba(37,99,235,.4);
	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: rgba(255,255,255,.82);
	border-bottom: 1px solid rgba(226,232,240,.6);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	transition: box-shadow .25s ease, background .25s ease;
}

.kimsoft-header.is-scrolled {
	background: var(--k-white);
	box-shadow: 0 4px 30px rgba(15,23,42,.07);
	border-bottom-color: var(--k-border);
}

.kimsoft-header__inner {
	max-width: 1140px;
	margin: 0 auto;
	padding: 0 20px;
	height: 64px;
	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: 18px;
	letter-spacing: -.02em;
	color: var(--k-text);
}

.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: 6px;
}

.kimsoft-menu--desktop li { position: relative; }

.kimsoft-menu--desktop a {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 14px;
	border-radius: 10px;
	color: var(--k-text);
	font-weight: 600;
	font-size: 14px;
	text-decoration: none;
	transition: background .15s ease, color .15s ease;
}

.kimsoft-menu--desktop a:hover {
	background: rgba(37,99,235,.06);
	color: var(--k-primary);
}

.kimsoft-menu--desktop > li.menu-item-has-children > a::after {
	content: '';
	width: 7px;
	height: 7px;
	border-right: 1.5px solid currentColor;
	border-bottom: 1.5px solid currentColor;
	transform: rotate(45deg);
	margin-top: -2px;
	opacity: .5;
	transition: transform .2s ease;
}

.kimsoft-menu--desktop > li.menu-item-has-children:hover > a::after {
	transform: rotate(225deg);
}

/* Desktop dropdown */
.kimsoft-menu--desktop .sub-menu {
	position: absolute;
	left: 0;
	top: calc(100% + 4px);
	min-width: 220px;
	list-style: none;
	margin: 0;
	padding: 8px;
	background: var(--k-white);
	border: 1px solid var(--k-border);
	border-radius: 14px;
	box-shadow: 0 12px 40px rgba(15,23,42,.1);
	z-index: 50;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transform: translateY(6px);
	transition: opacity .18s ease, transform .18s ease, visibility .18s ease;
}

.kimsoft-menu--desktop li:hover > .sub-menu {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transform: translateY(0);
}

.kimsoft-menu--desktop .sub-menu a {
	padding: 10px 14px;
	border-radius: 8px;
	width: 100%;
}

/* Desktop submenu toggle hidden */
.kimsoft-submenu-toggle { display: none; }

/* === HAMBURGER BUTTON === */

.kimsoft-nav-toggle {
	display: none;
	align-items: center;
	gap: 10px;
	padding: 8px 14px;
	background: transparent;
	border: 1px solid var(--k-border);
	border-radius: 10px;
	color: var(--k-text);
	font-weight: 700;
	font-size: 14px;
	cursor: pointer;
	transition: background .15s ease;
}

.kimsoft-nav-toggle:hover {
	background: rgba(37,99,235,.04);
}

.kimsoft-hamburger {
	width: 20px;
	height: 14px;
	display: inline-flex;
	flex-direction: column;
	justify-content: space-between;
	flex-shrink: 0;
}

.kimsoft-hamburger__line {
	height: 2px;
	background: currentColor;
	border-radius: 2px;
	transform-origin: center;
	transition: transform .3s cubic-bezier(.4,0,.2,1), opacity .2s ease;
}

.kimsoft-nav-toggle.is-open .kimsoft-hamburger__line:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.kimsoft-nav-toggle.is-open .kimsoft-hamburger__line:nth-child(2) { opacity: 0; }
.kimsoft-nav-toggle.is-open .kimsoft-hamburger__line:nth-child(3) { transform: translateY(-6px) 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: rgba(15,23,42,.4);
	opacity: 0;
	transition: opacity .3s ease;
}

.kimsoft-mobile-drawer.is-open .kimsoft-mobile-drawer__backdrop {
	opacity: 1;
}

.kimsoft-mobile-drawer__panel {
	position: absolute;
	inset: 0;
	background: var(--k-white);
	padding: 20px;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	transform: translateY(-100%);
	transition: transform .35s cubic-bezier(.4,0,.2,1);
}

.kimsoft-mobile-drawer.is-open .kimsoft-mobile-drawer__panel {
	transform: translateY(0);
}

.kimsoft-mobile-drawer__top {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding-bottom: 16px;
	border-bottom: 1px solid var(--k-border);
	margin-bottom: 8px;
}

.kimsoft-mobile-drawer__close {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	background: transparent;
	border: 1px solid var(--k-border);
	border-radius: 10px;
	cursor: pointer;
	font-size: 18px;
	color: var(--k-text);
	transition: background .15s ease;
}

.kimsoft-mobile-drawer__close:hover {
	background: rgba(37,99,235,.04);
}

/* === MOBILE MENU === */

.kimsoft-menu--mobile {
	list-style: none;
	margin: 0;
	padding: 0;
}

.kimsoft-menu--mobile > li {
	display: grid;
	grid-template-columns: 1fr auto;
	align-items: center;
	border-bottom: 1px solid var(--k-border);
}

.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 a {
	display: flex;
	align-items: center;
	padding: 16px 4px;
	font-weight: 700;
	font-size: 16px;
	color: var(--k-text);
	text-decoration: none;
}

.kimsoft-menu--mobile .sub-menu {
	display: none;
	list-style: none;
	margin: 0;
	padding: 0 0 8px;
}

.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: 600;
	padding: 12px 4px 12px 20px;
	font-size: 15px;
	color: var(--k-muted);
}

.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: 40px;
	height: 40px;
	border-radius: 10px;
	border: 1px solid var(--k-border);
	background: var(--k-white);
	cursor: pointer;
	flex-shrink: 0;
	transition: background .15s ease;
}

.kimsoft-menu--mobile .kimsoft-submenu-toggle:hover {
	background: rgba(37,99,235,.04);
}

.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 .25s cubic-bezier(.4,0,.2,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;
}

/* === ELEMENTOR FULL WIDTH === */

body.elementor-page .kimsoft-main {
	max-width: none;
	padding: 0;
}

/* === CONTENT CONTAINERS === */

.kimsoft-post,
.kimsoft-page,
.kimsoft-single {
	background: var(--k-white);
	border: 1px solid var(--k-border);
	border-radius: var(--k-radius);
	padding: 28px;
}

.kimsoft-post__title,
.kimsoft-page__title,
.kimsoft-single__title {
	margin: 0 0 16px;
	font-size: 28px;
	line-height: 1.2;
	letter-spacing: -.02em;
}

/* === ELEMENTOR OVERRIDES === */

.elementor-widget-container { word-break: break-word; }
.elementor-heading-title { letter-spacing: -.015em; }

.elementor-button {
	border-radius: 10px !important;
	font-weight: 700 !important;
}

.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 rgba(37,99,235,.12);
	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 rgba(37,99,235,.12);
}

.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 ul.products {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
}

.woocommerce ul.products li.product {
	margin: 0;
	padding: 16px;
	border: 1px solid var(--k-border);
	border-radius: var(--k-radius);
	background: var(--k-white);
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-size: 15px;
	margin-top: 10px;
}

.woocommerce ul.products li.product .price {
	color: var(--k-muted);
	margin: 8px 0 0;
}

.woocommerce div.product {
	background: var(--k-white);
	border: 1px solid var(--k-border);
	border-radius: var(--k-radius);
	padding: 24px;
}

.woocommerce table.shop_table {
	width: 100%;
	border: 1px solid var(--k-border);
	border-collapse: collapse;
	border-radius: var(--k-radius);
	overflow: hidden;
}

.woocommerce table.shop_table thead th {
	background: var(--k-bg);
	font-weight: 700;
	text-align: left;
	padding: 12px 14px;
	border-bottom: 1px solid var(--k-border);
}

.woocommerce table.shop_table td,
.woocommerce table.shop_table th {
	padding: 12px 14px;
	border-bottom: 1px solid var(--k-border);
	vertical-align: middle;
}

.woocommerce form.checkout {
	background: var(--k-white);
	border: 1px solid var(--k-border);
	border-radius: var(--k-radius);
	padding: 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: 16px 18px;
}

.woocommerce nav.woocommerce-pagination ul {
	list-style: none;
	padding: 0;
	margin: 24px 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;
}

.woocommerce nav.woocommerce-pagination .current {
	background: rgba(37,99,235,.08);
	border-color: var(--k-primary);
	color: var(--k-primary);
}

.woocommerce .quantity .qty { width: 80px; text-align: center; }

/* === RESPONSIVE === */

@media (max-width: 900px) {
	.woocommerce ul.products { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 860px) {
	.kimsoft-nav--desktop { display: none; }
	.kimsoft-nav-toggle { display: inline-flex; }
	.kimsoft-main { padding: 24px 16px; }
}

@media (max-width: 560px) {
	.woocommerce ul.products { grid-template-columns: 1fr; }
}

@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; }
}
