/*
Theme Name:        Kamano
Theme URI:         https://www.kamano.ch
Author:            Kamano GmbH
Author URI:        https://www.kamano.ch
Description:       Premium B2B WordPress Block Theme for kamano | master of digital. Full Site Editing, Gutenberg-native, mobile-first. No external dependencies.
Version:           2.0.0
Requires at least: 6.4
Tested up to:      6.9
Requires PHP:      8.0
License:           GNU General Public License v2 or later
License URI:       https://www.gnu.org/licenses/gpl-2.0.html
Text Domain:       kamano
Tags:              block-themes, full-site-editing, wide-blocks, responsive-layout, custom-colors, custom-menu, custom-logo, editor-style, featured-images, blog
*/

/* =============================================================================
   KAMANO DESIGN SYSTEM — Global CSS
   All values derived from theme.json tokens. No external dependencies.
   ============================================================================= */

*,
*::before,
*::after { box-sizing: border-box; }

html {
	font-size: 16px;
	scroll-behavior: smooth;
	-webkit-text-size-adjust: 100%;
}

body {
	margin: 0;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

img, picture, video, canvas, svg {
	display: block;
	max-width: 100%;
}

/* ---- Custom Properties ---- */
:root {
	--k-primary-50:  #E8F6F8;
	--k-primary-100: #C3E8EE;
	--k-primary-200: #8FCFDB;
	--k-primary-300: #5BAFC0;
	--k-primary:     #3A96AD;
	--k-primary-500: #2E7D93;
	--k-primary-600: #22616F;
	--k-primary-700: #17454F;
	--k-primary-800: #0D2E36;
	--k-primary-900: #061A1F;
	--k-slate-50:  #F0F2F5;
	--k-slate-100: #D8DDE6;
	--k-slate-200: #B4BDC9;
	--k-slate-300: #8896A8;
	--k-slate-400: #60718A;
	--k-slate-500: #445569;
	--k-slate-600: #2D3F52;
	--k-slate:     #1E2D3D;
	--k-slate-800: #121E2A;
	--k-slate-900: #080E14;
	--k-gold-50:  #FBF6E9;
	--k-gold-100: #F5E5B8;
	--k-gold-200: #EBD07A;
	--k-gold:     #D4B045;
	--k-gold-400: #B88F1E;
	--k-gold-500: #9A7210;
	--k-gold-600: #7A5A08;
	--k-white:    #FFFFFF;
	--k-gray-50:  #F8F9FA;
	--k-gray-100: #F1F3F5;
	--k-gray-200: #E9ECEF;
	--k-gray-300: #DEE2E6;
	--k-gray-400: #CED4DA;
	--k-gray-500: #ADB5BD;
	--k-gray-600: #6C757D;
	--k-gray-700: #495057;
	--k-gray-800: #343A40;
	--k-gray-900: #212529;
	--k-success: #1D9E75;
	--k-warning: #D4B045;
	--k-error:   #D85A30;
	--k-radius-sm:   4px;
	--k-radius-md:   8px;
	--k-radius-lg:   12px;
	--k-radius-xl:   16px;
	--k-radius-2xl:  24px;
	--k-radius-full: 9999px;
	--k-shadow-xs: 0 1px 2px rgba(8,14,20,0.04);
	--k-shadow-sm: 0 2px 8px rgba(8,14,20,0.06), 0 1px 2px rgba(8,14,20,0.04);
	--k-shadow-md: 0 4px 16px rgba(8,14,20,0.08), 0 2px 4px rgba(8,14,20,0.04);
	--k-shadow-lg: 0 8px 32px rgba(8,14,20,0.10), 0 4px 8px rgba(8,14,20,0.06);
	--k-shadow-xl: 0 16px 48px rgba(8,14,20,0.12), 0 8px 16px rgba(8,14,20,0.08);
	--k-ease:          cubic-bezier(0.16, 1, 0.3, 1);
	--k-duration-fast: 150ms;
	--k-duration:      250ms;
	--k-duration-slow: 400ms;
}

/* ---- Skip Link ---- */
.skip-link {
	clip: rect(1px, 1px, 1px, 1px);
	height: 1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
}
.skip-link:focus {
	background-color: var(--k-primary);
	border-radius: var(--k-radius-md);
	clip: auto !important;
	color: var(--k-white);
	display: block;
	font-size: 14px;
	font-weight: 500;
	height: auto;
	left: 8px;
	padding: 12px 20px;
	text-decoration: none;
	top: 8px;
	width: auto;
	z-index: 10000;
}

/* ---- Accessibility ---- */
:focus-visible {
	outline: 3px solid var(--k-primary);
	outline-offset: 2px;
	border-radius: var(--k-radius-sm);
}

::selection {
	background-color: var(--k-primary-100);
	color: var(--k-primary-800);
}

/* =============================================================================
   HEADER & NAVIGATION
   ============================================================================= */

.site-header {
	position: sticky;
	top: 0;
	z-index: 1000;
	background: rgba(255, 255, 255, 0.96);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	border-bottom: 1px solid var(--k-gray-200);
	transition: box-shadow var(--k-duration) var(--k-ease);
}

.wp-block-navigation .wp-block-navigation-item__content {
	font-size: 14px;
	font-weight: 400;
	color: var(--k-gray-600);
	padding: 8px 12px;
	border-radius: var(--k-radius-md);
	transition: all var(--k-duration-fast) var(--k-ease);
	text-decoration: none;
}

.wp-block-navigation .wp-block-navigation-item__content:hover {
	color: var(--k-gray-900);
	background: var(--k-gray-50);
}

.wp-block-navigation .current-menu-item > .wp-block-navigation-item__content {
	color: var(--k-primary-500);
	background: var(--k-primary-50);
	font-weight: 500;
}

.wp-block-site-title a {
	text-decoration: none;
	color: inherit;
}

.wp-block-navigation__submenu-container .wp-block-navigation-item__label {
  overflow-wrap: normal !important;
  white-space: nowrap !important;
}

/* =============================================================================
   BUTTONS
   ============================================================================= */

.wp-block-button__link {
	transition: all var(--k-duration) var(--k-ease);
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	text-decoration: none !important;
	font-weight: 500 !important;
	letter-spacing: -0.01em;
	white-space: nowrap;
}

/* Primary */
.wp-block-button:not([class*="is-style"]) .wp-block-button__link,
.wp-block-button.is-style-primary .wp-block-button__link {
	background-color: var(--k-primary) !important;
	color: var(--k-white) !important;
	border: none !important;
	box-shadow: 0 2px 8px rgba(58,150,173,0.30);
}
.wp-block-button:not([class*="is-style"]) .wp-block-button__link:hover,
.wp-block-button.is-style-primary .wp-block-button__link:hover {
	background-color: var(--k-primary-500) !important;
	transform: translateY(-1px);
	box-shadow: 0 4px 16px rgba(58,150,173,0.40);
}

/* Secondary */
.wp-block-button.is-style-secondary .wp-block-button__link {
	background-color: transparent !important;
	color: var(--k-primary-500) !important;
	border: 1.5px solid var(--k-primary) !important;
}
.wp-block-button.is-style-secondary .wp-block-button__link:hover {
	background-color: var(--k-primary-50) !important;
	transform: translateY(-1px);
}

/* Ghost */
.wp-block-button.is-style-ghost .wp-block-button__link {
	background-color: transparent !important;
	color: var(--k-slate-600) !important;
	border: 1px solid var(--k-gray-300) !important;
}
.wp-block-button.is-style-ghost .wp-block-button__link:hover {
	background-color: var(--k-gray-50) !important;
	border-color: var(--k-gray-400) !important;
}

/* Dark */
.wp-block-button.is-style-dark .wp-block-button__link {
	background-color: var(--k-slate-800) !important;
	color: var(--k-white) !important;
	border: none !important;
}
.wp-block-button.is-style-dark .wp-block-button__link:hover {
	background-color: var(--k-slate) !important;
	transform: translateY(-1px);
	box-shadow: var(--k-shadow-md);
}

/* Secondary on dark backgrounds */
.has-slate-800-background-color .wp-block-button.is-style-secondary .wp-block-button__link,
.has-slate-dark-background-color .wp-block-button.is-style-secondary .wp-block-button__link {
	color: var(--k-white) !important;
	border-color: rgba(255,255,255,0.40) !important;
}
.has-slate-800-background-color .wp-block-button.is-style-secondary .wp-block-button__link:hover,
.has-slate-dark-background-color .wp-block-button.is-style-secondary .wp-block-button__link:hover {
	background-color: rgba(255,255,255,0.08) !important;
}

/* =============================================================================
   CARD STYLES
   ============================================================================= */

.wp-block-group.is-style-card {
	background: var(--k-white);
	border: 1px solid var(--k-gray-200);
	border-radius: var(--k-radius-xl);
	box-shadow: var(--k-shadow-sm);
	padding: 24px;
	transition: all var(--k-duration) var(--k-ease);
}

.wp-block-group.is-style-stat-card {
	background: var(--k-white);
	border: 1px solid var(--k-gray-200);
	border-radius: var(--k-radius-xl);
	box-shadow: var(--k-shadow-sm);
	padding: 24px;
	position: relative;
	overflow: hidden;
	transition: all var(--k-duration) var(--k-ease);
}
.wp-block-group.is-style-stat-card::before {
	content: '';
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 3px;
	background: var(--k-primary);
	opacity: 0;
	transition: opacity var(--k-duration) var(--k-ease);
}
.wp-block-group.is-style-stat-card:hover {
	box-shadow: var(--k-shadow-md);
	transform: translateY(-2px);
}
.wp-block-group.is-style-stat-card:hover::before { opacity: 1; }

.wp-block-group.is-style-service-card {
	background: var(--k-white);
	border: 1px solid var(--k-gray-200);
	border-radius: var(--k-radius-xl);
	box-shadow: var(--k-shadow-sm);
	padding: 32px;
	transition: all var(--k-duration) var(--k-ease);
}
.wp-block-group.is-style-service-card:hover {
	border-color: var(--k-primary-200);
	box-shadow: var(--k-shadow-md);
	transform: translateY(-3px);
}

.wp-block-group.is-style-testimonial-card {
	background: var(--k-white);
	border: 1px solid var(--k-gray-200);
	border-radius: var(--k-radius-xl);
	box-shadow: var(--k-shadow-sm);
	padding: 32px;
}

/* =============================================================================
   TYPOGRAPHY VARIANTS
   ============================================================================= */

.is-style-eyebrow {
	font-size: 11px !important;
	font-weight: 600 !important;
	letter-spacing: 0.12em !important;
	text-transform: uppercase !important;
	color: var(--k-primary) !important;
	line-height: 1.5;
}

.is-style-eyebrow.has-text-align-center {
	text-align: center !important;
}

.is-style-eyebrow-pill {
	display: inline-block !important;
	font-size: 11px !important;
	font-weight: 600 !important;
	letter-spacing: 0.08em !important;
	text-transform: uppercase !important;
	color: var(--k-primary-600) !important;
	background-color: var(--k-primary-50) !important;
	border: 1px solid var(--k-primary-200) !important;
	border-radius: 9999px !important;
	padding: 3px 10px !important;
	line-height: 1.5;
}
p.has-border-color[style*="border-radius:9999px"],
p.has-border-color[style*="border-radius: 9999px"] {
	display: inline-block !important;
}
.has-slate-800-background-color .is-style-eyebrow,
.has-slate-dark-background-color .is-style-eyebrow {
	color: var(--k-primary-300) !important;
}


.is-style-stat-value {
	font-family: var(--wp--preset--font-family--display) !important;
	font-size: 40px !important;
	font-weight: 400 !important;
	letter-spacing: -0.02em !important;
	line-height: 1 !important;
}

.is-style-testimonial-quote {
	font-size: var(--wp--preset--font-size--medium) !important;
	line-height: 1.5 !important;
	position: relative;
	padding-left: 20px;
}
.is-style-testimonial-quote::before {
	content: '\201C';
	position: absolute;
	left: 0;
	top: -4px;
	font-size: 52px;
	color: var(--k-primary-200);
	font-family: var(--wp--preset--font-family--display);
	line-height: 1;
}

/* =============================================================================
   FORMS
   ============================================================================= */

.wp-block-search__input,
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
	width: 100%;
	font-size: 15px;
	color: var(--k-slate-800);
	background: var(--k-white);
	border: 1.5px solid var(--k-gray-300);
	border-radius: var(--k-radius-md);
	padding: 12px 16px;
	outline: none;
	transition: border-color var(--k-duration-fast) var(--k-ease), box-shadow var(--k-duration-fast) var(--k-ease);
	appearance: none;
}
.wp-block-search__input:hover { border-color: var(--k-gray-400); }
.wp-block-search__input:focus,
.comment-form input:focus,
.comment-form textarea:focus {
	border-color: var(--k-primary);
	box-shadow: 0 0 0 3px rgba(58,150,173,0.12);
	outline: none;
}

/* =============================================================================
   QUOTE BLOCK
   ============================================================================= */

.wp-block-quote {
	border-left: 3px solid var(--k-primary) !important;
	padding-left: 24px;
	margin-left: 0;
}

/* =============================================================================
   SEPARATOR
   ============================================================================= */

.wp-block-separator { border-color: var(--k-gray-200) !important; }

/* =============================================================================
   FOOTER
   ============================================================================= */

.site-footer a {
	color: rgba(255,255,255,0.55);
	text-decoration: none;
	transition: color var(--k-duration-fast) var(--k-ease);
}
.site-footer a:hover { color: var(--k-white); }

/* =============================================================================
   RESPONSIVE UTILITIES
   ============================================================================= */

@media (max-width: 767px) {
	.hidden-mobile { display: none !important; }
}
@media (min-width: 768px) {
	.hidden-desktop { display: none !important; }
}

/* =============================================================================
   PRINT
   ============================================================================= */

@media print {
	.site-header, .site-footer, .wp-block-button { display: none !important; }
}

/* FAQ ACCORDION */
details.wp-block-details.k-faq {
	border-bottom: 1px solid var(--k-gray-200);
	margin: 0;
}
details.wp-block-details.k-faq > summary {
	display: flex !important;
	justify-content: space-between !important;
	align-items: center !important;
	gap: 16px;
	padding: 20px 0;
	cursor: pointer;
	list-style: none;
	font-family: var(--wp--preset--font-family--sans) !important;
	font-size: 16px !important;
	font-weight: 500 !important;
	color: var(--k-slate-800) !important;
	transition: color var(--k-duration-fast) var(--k-ease);
}
details.wp-block-details.k-faq > summary::-webkit-details-marker { display: none; }
details.wp-block-details.k-faq > summary::marker { display: none; content: ''; }
details.wp-block-details.k-faq > summary:hover { color: var(--k-primary) !important; }
details.wp-block-details.k-faq > summary .k-faq-icon {
	width: 26px;
	height: 26px;
	min-width: 26px;
	border-radius: var(--k-radius-full);
	border: 1px solid var(--k-gray-300);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 16px;
	font-weight: 400;
	color: var(--k-gray-500);
	transition: all var(--k-duration) var(--k-ease);
	flex-shrink: 0;
	line-height: 1;
}
details.wp-block-details.k-faq[open] > summary .k-faq-icon {
	background: var(--k-primary);
	border-color: var(--k-primary);
	color: var(--k-white);
	transform: rotate(45deg);
}
details.wp-block-details.k-faq > p {
	font-size: 15px;
	line-height: 1.75;
	color: var(--k-gray-600);
	padding-bottom: 18px;
	margin: 0;
}
