/**
 * Kajinga Theme - Combined Stylesheet
 *
 * @package Kajinga_Theme
 */

/* ===================================================================
   1. BASE - Variables, Reset, Typography
   =================================================================== */

/* === Default CSS Variables === */
:root {
	--kt-primary: #2563eb;
	--kt-secondary: #1d4ed8;
	--kt-text: #1e293b;
	--kt-text-secondary: #64748b;
	--kt-bg: #ffffff;
	--kt-surface: #f1f5f9;
	--kt-link: #2563eb;
	--kt-link-hover: #1d4ed8;
	--kt-h1-color: #1e293b;
	--kt-h2-color: #1e293b;
	--kt-h3-color: #1e293b;
	--kt-h4-color: #1e293b;
	--kt-h5-color: #1e293b;
	--kt-h6-color: #1e293b;
	--kt-nav-link: #ffffff;
	--kt-nav-link-hover: #dd9933;
	--kt-border: #e2e8f0;
	--kt-container: 1200px;
	--kt-font: Helvetica, Arial, sans-serif;
	--kt-heading-font: "Prompt", sans-serif;
	--kt-header-font: "Prompt", sans-serif;
	--kt-font-size: 16px;
	--kt-line-height: 1.4;
	--kt-heading-weight: 700;
	--kt-h1-size: 2.25rem;
	--kt-h2-size: 1.875rem;
	--kt-h3-size: 1.5rem;
	--kt-h4-size: 1.25rem;
	--kt-h5-size: 1.125rem;
	--kt-h6-size: 1rem;
	--kt-radius: 8px;
	--kt-shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.08), 0 1px 2px rgba(0, 0, 0, 0.06);
	--kt-shadow-md: 0 4px 6px rgba(0, 0, 0, 0.07), 0 2px 4px rgba(0, 0, 0, 0.05);
	--kt-transition: 0.2s ease;
	--kt-header-bg: #1e293b;
	--kt-header-text: #ffffff;
	--kt-logo-height: 50px;
	--kt-sidebar-bg: #f8fafc;
	--kt-footer-bg: #374151;
	--kt-footer-text: #e5e7eb;
	--kt-footer-font-size: 14px;
	--kt-footer-padding-top: 40px;
	--kt-footer-padding-bottom: 40px;
	--kt-topbar-bg: #111827;
	--kt-topbar-text: #d1d5db;
	--kt-nav-font: var(--kt-header-font);
	--kt-cta-font: var(--kt-header-font);
	--kt-subnav-link: #1e293b;
	--kt-subnav-link-hover: #2563eb;
	--kt-subnav-bg: #ffffff;
	--kt-subnav-bg-hover: #f1f5f9;
	--kt-subnav-spacing: 8px;
}

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

html {
	-webkit-text-size-adjust: 100%;
	-moz-text-size-adjust: 100%;
	text-size-adjust: 100%;
	scroll-behavior: smooth;
}

body {
	margin: 0;
	font-family: var(--kt-font);
	font-size: var(--kt-font-size);
	font-weight: var(--kt-body-weight, 400);
	font-style: var(--kt-body-style, normal);
	line-height: var(--kt-line-height);
	color: var(--kt-text);
	background: var(--kt-bg);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/* === Typography (scoped to .kajinga-layout for Elementor isolation) === */
.kajinga-layout h1,
.kajinga-layout h2,
.kajinga-layout h3,
.kajinga-layout h4,
.kajinga-layout h5,
.kajinga-layout h6 {
	margin: 0 0 0.5em;
	font-family: var(--kt-heading-font);
	font-weight: var(--kt-heading-weight);
	line-height: 1.25;
	letter-spacing: -0.01em;
}

.kajinga-layout h1 {
	font-size: var(--kt-h1-size);
	color: var(--kt-h1-color);
	font-family: var(--kt-h1-font, var(--kt-heading-font));
	font-weight: var(--kt-h1-weight, var(--kt-heading-weight));
	font-style: var(--kt-h1-style, normal);
	letter-spacing: -0.025em;
}
.kajinga-layout h2 {
	font-size: var(--kt-h2-size);
	color: var(--kt-h2-color);
	font-family: var(--kt-h2-font, var(--kt-heading-font));
	font-weight: var(--kt-h2-weight, var(--kt-heading-weight));
	font-style: var(--kt-h2-style, normal);
	letter-spacing: -0.02em;
}
.kajinga-layout h3 {
	font-size: var(--kt-h3-size);
	color: var(--kt-h3-color);
	font-family: var(--kt-h3-font, var(--kt-heading-font));
	font-weight: var(--kt-h3-weight, var(--kt-heading-weight));
	font-style: var(--kt-h3-style, normal);
}
.kajinga-layout h4 {
	font-size: var(--kt-h4-size);
	color: var(--kt-h4-color);
	font-family: var(--kt-h4-font, var(--kt-heading-font));
	font-weight: var(--kt-h4-weight, var(--kt-heading-weight));
	font-style: var(--kt-h4-style, normal);
}
.kajinga-layout h5 {
	font-size: var(--kt-h5-size);
	color: var(--kt-h5-color);
	font-family: var(--kt-h5-font, var(--kt-heading-font));
	font-weight: var(--kt-h5-weight, var(--kt-heading-weight));
	font-style: var(--kt-h5-style, normal);
}
.kajinga-layout h6 {
	font-size: var(--kt-h6-size);
	color: var(--kt-h6-color);
	font-family: var(--kt-h6-font, var(--kt-heading-font));
	font-weight: var(--kt-h6-weight, var(--kt-heading-weight));
	font-style: var(--kt-h6-style, normal);
}

.kajinga-layout h1 a, .kajinga-layout h2 a, .kajinga-layout h3 a, .kajinga-layout h4 a, .kajinga-layout h5 a, .kajinga-layout h6 a { color: inherit; }
.kajinga-layout h1 a:hover, .kajinga-layout h2 a:hover, .kajinga-layout h3 a:hover, .kajinga-layout h4 a:hover, .kajinga-layout h5 a:hover, .kajinga-layout h6 a:hover { color: var(--kt-link-hover); }

.kajinga-layout p {
	margin: 0 0 1.5em;
}

a {
	text-decoration: none;
	transition: color var(--kt-transition);
}

.kajinga-layout a {
	color: var(--kt-link);
}

.kajinga-layout a:hover,
.kajinga-layout a:focus {
	color: var(--kt-link-hover);
}

/* === Lists === */
.kajinga-layout ul,
.kajinga-layout ol {
	margin: 0 0 1.5em;
	padding-left: 1.5em;
}

/* === Media === */
.kajinga-layout img {
	max-width: 100%;
	height: auto;
	display: block;
}

.kajinga-layout figure {
	margin: 0 0 1.5em;
}

/* === Tables === */
.kajinga-layout table {
	width: 100%;
	border-collapse: collapse;
	margin-bottom: 1.5em;
}

.kajinga-layout th,
.kajinga-layout td {
	padding: 0.5em 0.75em;
	text-align: left;
	border-bottom: 1px solid var(--kt-border);
}

.kajinga-layout th {
	font-weight: var(--kt-heading-weight);
}

/* === Code === */
.kajinga-layout pre,
.kajinga-layout code {
	font-family: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;
	font-size: 0.875em;
}

.kajinga-layout pre {
	overflow-x: auto;
	padding: 1em;
	background: var(--kt-surface);
	border-radius: var(--kt-radius);
	margin-bottom: 1.5em;
}

.kajinga-layout code {
	padding: 0.125em 0.375em;
	background: var(--kt-surface);
	border-radius: 2px;
}

.kajinga-layout pre code {
	padding: 0;
	background: none;
}

/* === Blockquote === */
.kajinga-layout blockquote {
	margin: 0 0 1.5em;
	padding: 1.25em 1.5em;
	border-left: 4px solid var(--kt-primary);
	background: var(--kt-surface);
	border-radius: 0 var(--kt-radius) var(--kt-radius) 0;
	font-style: italic;
}

.kajinga-layout blockquote p:last-child {
	margin-bottom: 0;
}

/* === HR === */
.kajinga-layout hr {
	border: 0;
	border-top: 1px solid var(--kt-border);
	margin: 2em 0;
}

/* === Accessibility === */
.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
	word-wrap: normal !important;
}

.screen-reader-text:focus {
	background-color: #f1f1f1;
	border-radius: 3px;
	box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
	clip: auto !important;
	clip-path: none;
	color: #21759b;
	display: block;
	font-size: 0.875rem;
	font-weight: 700;
	height: auto;
	left: 5px;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	top: 5px;
	width: auto;
	z-index: 100000;
}

.skip-link:focus {
	z-index: 100001;
}

/* === WordPress Generated Classes === */
.alignleft {
	float: left;
	margin-right: 1.5em;
	margin-bottom: 1em;
}

.alignright {
	float: right;
	margin-left: 1.5em;
	margin-bottom: 1em;
}

.aligncenter {
	display: block;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 1em;
}

.alignwide {
	margin-left: -5%;
	margin-right: -5%;
	max-width: 110%;
}

.alignfull {
	margin-left: calc(-50vw + 50%);
	margin-right: calc(-50vw + 50%);
	max-width: 100vw;
	width: 100vw;
}

.wp-caption {
	max-width: 100%;
}

.wp-caption-text {
	font-size: 0.875em;
	color: var(--kt-text-secondary);
	padding-top: 0.5em;
}

.gallery {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5em;
}

.gallery-item {
	flex: 1 0 calc(33.333% - 0.5em);
}

.gallery-caption {
	font-size: 0.8125em;
}

/* === Sticky === */
.sticky {
	position: relative;
}

/* === Page Links === */
.page-links {
	clear: both;
	margin: 1.5em 0;
}

/* ===================================================================
   2. LAYOUT - Container, Grid, Sidebar
   =================================================================== */

/* === Container === */
.kajinga-container {
	width: 100%;
	max-width: var(--kt-container);
	margin: 0 auto;
	padding: 0 1.5em;
}

/* === Content Area === */
.kajinga-content-area {
	padding: 2em 0;
}

/* === Layout Grid === */
.kajinga-layout {
	display: grid;
	gap: 2em;
}

.kajinga-layout--sidebar-right {
	grid-template-columns: 1fr var(--kt-sidebar-width, 25%);
}

.kajinga-layout--sidebar-left {
	grid-template-columns: var(--kt-sidebar-width, 25%) 1fr;
}

.kajinga-layout--sidebar-left .kajinga-sidebar {
	order: -1;
}

.kajinga-layout--no-sidebar {
	grid-template-columns: 1fr;
}

/* === Blog Layouts === */
.kajinga-blog--list .kajinga-post {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1em;
	margin-bottom: 2em;
	padding-bottom: 2em;
	border-bottom: 1px solid var(--kt-border);
}

.kajinga-blog--list .kajinga-post:last-child {
	border-bottom: 0;
}

.kajinga-blog--list .kajinga-post .post-thumbnail {
	margin-bottom: 0;
}

/* Blog layout columns (shared by grid/cards/cover) */
.kajinga-blog--cols-2 {
	grid-template-columns: repeat(2, 1fr);
}

.kajinga-blog--cols-3 {
	grid-template-columns: repeat(3, 1fr);
}

/* Layout-specific styles loaded conditionally via blog-{layout}.css */

/* === Sidebar Styling === */

/* -- Default: Background fill -- */
.kajinga-sidebar--default {
	background: var(--kt-sidebar-bg);
	padding: 1.5em;
	border-radius: var(--kt-radius);
}

/* -- Bordered: Line between content and sidebar -- */
.kajinga-sidebar--bordered {
	padding: 0 0 0 1.5em;
	border-left: 1px solid var(--kt-border);
}

.kajinga-layout--sidebar-left .kajinga-sidebar--bordered {
	padding: 0 1.5em 0 0;
	border-left: none;
	border-right: 1px solid var(--kt-border);
}

/* -- Card: Elevated card with shadow -- */
.kajinga-sidebar--card {
	background: var(--kt-sidebar-bg);
	padding: 1.5em;
	border-radius: var(--kt-radius);
	border: 1px solid var(--kt-border);
	box-shadow: var(--kt-shadow-md);
}

/* -- Minimal: Only a subtle separator, no bg -- */
.kajinga-sidebar--minimal {
	padding: 0 0 0 2em;
	position: relative;
}

.kajinga-sidebar--minimal::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 1px;
	background: linear-gradient(to bottom, transparent, var(--kt-border) 15%, var(--kt-border) 85%, transparent);
}

.kajinga-layout--sidebar-left .kajinga-sidebar--minimal {
	padding: 0 2em 0 0;
}

.kajinga-layout--sidebar-left .kajinga-sidebar--minimal::before {
	left: auto;
	right: 0;
}

/* -- Boxed Widgets: Each widget as its own card -- */
.kajinga-sidebar--boxed-widgets {
	padding: 0;
	background: none;
}

.kajinga-sidebar--boxed-widgets .widget {
	background: var(--kt-sidebar-bg);
	padding: 1.25em;
	border-radius: var(--kt-radius);
	border: 1px solid var(--kt-border);
	box-shadow: var(--kt-shadow-sm);
}

/* === Sticky Sidebar (Desktop) === */
@media (min-width: 1025px) {
	.kajinga-sidebar {
		position: sticky;
		top: 2em;
		align-self: start;
	}

	.kajinga-header-sticky .kajinga-sidebar {
		top: calc(70px + 2em);
		transition: top 0.3s ease;
	}

	body.is-header-scrolled .kajinga-sidebar {
		top: calc(56px + 2em);
	}
}

/* === Site layout === */
.kajinga-site {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}

.kajinga-content-area {
	flex: 1;
}

/* === Page/Post Content === */
.entry-content {
	margin-bottom: 1.5em;
}

.entry-content > *:last-child {
	margin-bottom: 0;
}

/* === Post Thumbnail === */
.post-thumbnail {
	margin-bottom: 1.5em;
}

.post-thumbnail img {
	border-radius: var(--kt-radius);
	width: 100%;
	height: auto;
	box-shadow: var(--kt-shadow-sm);
}

/* === Elementor Full Width === */
.kajinga-elementor-page .kajinga-content-area {
	padding: 0;
}

.kajinga-elementor-page .kajinga-content-area .kajinga-container {
	max-width: none;
	padding: 0;
}

/* === Elementor Full Width === */
.elementor-template-full-width .entry-content {
	padding: 0;
	margin: 0;
}

.elementor-template-full-width .kajinga-content-area {
	padding: 0;
}

/* ===================================================================
   3. HEADER
   =================================================================== */

.kajinga-header {
	background-color: var(--kt-header-bg);
	color: var(--kt-header-text);
	font-family: var(--kt-header-font);
	font-size: var(--kt-header-font-size, 14px);
	box-shadow: var(--kt-shadow-sm);
	z-index: 999;
	transition: box-shadow 0.3s ease;
}

/* === Header Shrink on Scroll (sticky only) === */
.kajinga-header-sticky .kajinga-header.is-scrolled {
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

.kajinga-header-sticky .kajinga-header.is-scrolled .kajinga-header__inner {
	min-height: 56px;
	transition: min-height 0.3s ease;
}

.kajinga-header-sticky .kajinga-header.is-scrolled .custom-logo {
	max-height: 36px;
}

/* Buttons-top: hide CTA row on scroll for slimmer header */
.kajinga-header-sticky .kajinga-header--buttons-top.is-scrolled .kajinga-header__right-top {
	max-height: 0;
	opacity: 0;
	overflow: hidden;
	margin: 0;
	padding: 0;
	transition: max-height 0.3s ease, opacity 0.2s ease;
}

.kajinga-header--buttons-top .kajinga-header__right-top {
	max-height: 60px;
	opacity: 1;
	transition: max-height 0.3s ease, opacity 0.2s ease 0.1s;
}

/* === Default Layout: Logo left, Nav right === */
.kajinga-header--default .kajinga-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	min-height: 70px;
}

.kajinga-header--default .kajinga-header__branding {
	flex-shrink: 0;
}

/* === Minimal Layout: Centered === */
.kajinga-header--minimal .kajinga-header__inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 1em 0;
	gap: 0.75em;
}

/* === Site Title / Logo === */
.site-title {
	margin: 0;
	font-size: 1.5rem;
	font-family: var(--kt-header-font);
	font-weight: 700;
	line-height: 1;
}

.site-title a {
	color: var(--kt-header-text);
	text-decoration: none;
}

.site-description {
	margin: 0;
	font-size: 0.875em;
	opacity: 0.6;
}

.custom-logo-link {
	display: inline-block;
}

.custom-logo {
	max-height: var(--kt-logo-height, 50px);
	width: auto;
	transition: max-height 0.3s ease;
}

/* === Primary Navigation === */
.kajinga-nav {
	display: flex;
	align-items: center;
}

.kajinga-nav__menu {
	display: flex;
	list-style: none;
	margin: 0;
	padding: 0;
	gap: 0.25em;
	font-family: var(--kt-nav-font);
}

.kajinga-nav__menu li {
	position: relative;
}

.kajinga-nav__menu a {
	display: block;
	padding: 0.5em 0.75em;
	color: var(--kt-nav-link);
	font-size: var(--kt-nav-font-size, 15px);
	font-weight: 500;
	white-space: nowrap;
	opacity: 0.85;
	transition: color var(--kt-transition), opacity var(--kt-transition);
}

.kajinga-nav__menu a:hover {
	color: var(--kt-nav-link-hover);
	opacity: 1;
}

.kajinga-nav__menu .current-menu-item > a,
.kajinga-nav__menu .current_page_item > a {
	color: var(--kt-nav-link-active, var(--kt-nav-link-hover));
	opacity: 1;
}

/* === Sub-Menu (animated) === */
.kajinga-nav__menu .sub-menu {
	position: absolute;
	top: 100%;
	left: 0;
	min-width: 220px;
	background: var(--kt-subnav-bg);
	border: 1px solid var(--kt-border);
	border-radius: var(--kt-radius);
	box-shadow: var(--kt-shadow-md);
	padding: 0.375em 0;
	list-style: none;
	z-index: 1000;
	visibility: hidden;
	opacity: 0;
	transform: translateY(8px);
	transition: visibility 0.2s, opacity 0.2s, transform 0.2s;
	pointer-events: none;
}

.kajinga-nav__menu li:hover > .sub-menu,
.kajinga-nav__menu li:focus-within > .sub-menu {
	visibility: visible;
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
}

.kajinga-nav__menu .sub-menu a {
	padding: var(--kt-subnav-spacing) 1em;
	color: var(--kt-subnav-link);
	font-size: var(--kt-subnav-font-size, 13px);
}

.kajinga-nav__menu .sub-menu a:hover {
	background: var(--kt-subnav-bg-hover);
	color: var(--kt-subnav-link-hover);
}

/* Nested sub-menu: slide from right */
.kajinga-nav__menu .sub-menu .sub-menu {
	top: 0;
	left: 100%;
	transform: translateX(8px);
}

.kajinga-nav__menu .sub-menu li:hover > .sub-menu,
.kajinga-nav__menu .sub-menu li:focus-within > .sub-menu {
	transform: translateX(0);
}

/* === Submenu Indicator (Desktop) === */
.kajinga-nav__menu > .menu-item-has-children > a::after {
	content: "";
	display: inline-block;
	width: 4px;
	height: 4px;
	border-right: 1.5px solid currentColor;
	border-bottom: 1.5px solid currentColor;
	transform: rotate(45deg);
	margin-left: 0.35em;
	vertical-align: 0.15em;
	opacity: 0.5;
}

.kajinga-nav__menu .sub-menu .menu-item-has-children > a::after {
	content: "";
	display: inline-block;
	width: 4px;
	height: 4px;
	border-right: 1.5px solid currentColor;
	border-bottom: 1.5px solid currentColor;
	transform: rotate(-45deg);
	margin-left: auto;
	padding-left: 0.75em;
	opacity: 0.5;
}

/* === Mobile Toggle === */
.kajinga-menu-toggle {
	display: none;
	background: none;
	border: none;
	padding: 10px;
	cursor: pointer;
	color: var(--kt-header-text);
}

.kajinga-menu-toggle svg {
	width: 24px;
	height: 24px;
	fill: currentColor;
}

/* Touch target: 24px icon + 2*10px padding = 44px */

.kajinga-menu-toggle:hover {
	color: #fff;
	background: none;
	border-color: transparent;
}

.kajinga-menu-toggle:focus-visible {
	outline: 2px solid currentColor;
	outline-offset: 2px;
}

/* === Mobile-only elements (hidden on desktop) === */
.kajinga-nav__close,
.kajinga-nav-backdrop,
.kajinga-submenu-toggle {
	display: none;
}

/* === Header CTA Buttons === */
.kajinga-header-cta {
	display: flex;
	align-items: center;
	gap: 0.5em;
	margin-left: 1em;
}

.kajinga-header-cta__btn {
	display: inline-block;
	padding: 0.5em 1.25em;
	font-family: var(--kt-cta-font);
	font-size: 0.875rem;
	font-weight: 600;
	line-height: 1.5;
	border-radius: var(--kt-radius);
	text-decoration: none;
	white-space: nowrap;
	transition: all var(--kt-transition);
	cursor: pointer;
}

.kajinga-header-cta__btn--filled {
	background-color: var(--kt-primary);
	border: 2px solid var(--kt-primary);
	color: #fff;
}

.kajinga-header-cta__btn--filled:hover {
	filter: brightness(0.85);
	color: #fff;
	transform: translateY(-1px);
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
}

.kajinga-header-cta__btn--outline {
	background: transparent;
	border: 1px solid var(--kt-header-text);
	color: var(--kt-header-text);
}

.kajinga-header-cta__btn--outline:hover {
	background: var(--kt-header-text);
	color: var(--kt-header-bg);
	transform: translateY(-1px);
}

.kajinga-header-cta__btn--ghost {
	background: transparent;
	border: 2px solid transparent;
	color: var(--kt-header-text);
}

.kajinga-header-cta__btn--ghost:hover {
	background: rgba(0, 0, 0, 0.06);
	transform: translateY(-1px);
}

.kajinga-header-cta__btn--soft {
	background-color: color-mix(in srgb, var(--kt-primary) 12%, transparent);
	border: 2px solid transparent;
	color: var(--kt-primary);
}

.kajinga-header-cta__btn--soft:hover {
	background-color: color-mix(in srgb, var(--kt-primary) 20%, transparent);
	transform: translateY(-1px);
}

.kajinga-header-cta__btn--pill {
	background-color: var(--kt-primary);
	border: 2px solid var(--kt-primary);
	color: #fff;
	border-radius: 999px;
}

.kajinga-header-cta__btn--pill:hover {
	filter: brightness(0.85);
	color: #fff;
	transform: translateY(-1px);
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
}

.kajinga-header-cta__btn--pill-outline {
	background: transparent;
	border: 1px solid var(--kt-header-text);
	color: var(--kt-header-text);
	border-radius: 999px;
}

.kajinga-header-cta__btn--pill-outline:hover {
	background: var(--kt-header-text);
	color: var(--kt-header-bg);
	transform: translateY(-1px);
}

.kajinga-header-cta__btn:focus-visible {
	outline: 2px solid currentColor;
	outline-offset: 2px;
}

/* ===================================================================
   4. COMPONENTS - Buttons, Forms, Navigation, Widgets
   =================================================================== */

/* === Buttons (scoped to .kajinga-layout for Elementor isolation) === */
.kajinga-layout .button,
.kajinga-layout button,
.kajinga-layout input[type="submit"],
.kajinga-layout input[type="button"],
.kajinga-layout input[type="reset"] {
	display: inline-block;
	padding: 0.625em 1.5em;
	font-size: 0.9375rem;
	font-weight: 600;
	line-height: 1.5;
	color: #fff;
	background-color: var(--kt-primary);
	border: 2px solid var(--kt-primary);
	border-radius: var(--kt-radius);
	cursor: pointer;
	text-align: center;
	text-decoration: none;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
	transition: all var(--kt-transition);
	-webkit-appearance: none;
	appearance: none;
}

.kajinga-layout .button:hover,
.kajinga-layout button:hover,
.kajinga-layout input[type="submit"]:hover,
.kajinga-layout input[type="button"]:hover,
.kajinga-layout input[type="reset"]:hover {
	background-color: var(--kt-secondary);
	border-color: var(--kt-secondary);
	color: #fff;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.12);
	transform: translateY(-1px);
}

.kajinga-layout .button--outline {
	background: transparent;
	color: var(--kt-primary);
}

.kajinga-layout .button--outline:hover {
	background: var(--kt-primary);
	color: #fff;
}

/* === Forms (scoped to .kajinga-layout for Elementor isolation) === */
.kajinga-layout input[type="text"],
.kajinga-layout input[type="email"],
.kajinga-layout input[type="url"],
.kajinga-layout input[type="password"],
.kajinga-layout input[type="search"],
.kajinga-layout input[type="number"],
.kajinga-layout input[type="tel"],
.kajinga-layout textarea,
.kajinga-layout select {
	display: block;
	width: 100%;
	padding: 0.6em 0.75em;
	font-size: 1rem;
	font-family: inherit;
	line-height: 1.5;
	color: var(--kt-text);
	background: var(--kt-bg);
	border: 1px solid var(--kt-border);
	border-radius: var(--kt-radius);
	transition: border-color var(--kt-transition);
	-webkit-appearance: none;
	appearance: none;
}

.kajinga-layout input:focus,
.kajinga-layout textarea:focus,
.kajinga-layout select:focus {
	outline: none;
	border-color: var(--kt-primary);
	box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
}

.kajinga-layout textarea {
	resize: vertical;
	min-height: 120px;
}

.kajinga-layout label {
	display: block;
	margin-bottom: 0.25em;
	font-weight: 500;
}

/* === Entry Meta === */
.entry-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75em;
	color: var(--kt-text-secondary);
	font-size: 0.875em;
	margin-bottom: 1em;
}

.entry-meta a {
	color: var(--kt-text-secondary);
}

.entry-meta a:hover {
	color: var(--kt-link-hover);
}

/* === Entry Footer === */
.entry-footer {
	margin-top: 1.5em;
	padding-top: 1em;
	border-top: 1px solid var(--kt-border);
	font-size: 0.875em;
	color: var(--kt-text-secondary);
}

.entry-footer span {
	margin-right: 1em;
}

.entry-footer a {
	color: var(--kt-text-secondary);
}

.entry-footer a:hover {
	color: var(--kt-link-hover);
}

/* === Read More === */
.entry-summary {
	margin-bottom: 0;
}

.read-more {
	display: inline-block;
	margin-top: 0.25em;
	font-weight: 600;
	color: var(--kt-primary);
}

.read-more:hover {
	color: var(--kt-secondary);
}

/* === Pagination === */
.pagination,
.nav-links {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5em;
	margin-top: 2em;
	justify-content: center;
}

.page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.75em;
	height: 2.75em;
	padding: 0 0.5em;
	border: 1px solid var(--kt-border);
	border-radius: var(--kt-radius);
	text-decoration: none;
	color: var(--kt-text);
	font-weight: 500;
	transition: all var(--kt-transition);
}

.page-numbers:hover {
	background: var(--kt-surface);
	border-color: var(--kt-primary);
	color: var(--kt-primary);
}

.page-numbers:focus-visible {
	outline: 2px solid var(--kt-primary);
	outline-offset: 2px;
}

.page-numbers.current {
	background: var(--kt-primary);
	border-color: var(--kt-primary);
	color: #fff;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

/* === Post Navigation === */
.post-navigation {
	margin-top: 2em;
	padding-top: 1.5em;
	border-top: 1px solid var(--kt-border);
}

.post-navigation .nav-links {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1em;
}

.nav-subtitle {
	display: block;
	font-size: 0.75em;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--kt-text-secondary);
}

.nav-title {
	font-weight: 600;
}

/* === Search Form === */
.search-form {
	display: flex;
	gap: 0.5em;
}

.search-form .search-field {
	flex: 1;
}

.search-form .search-submit {
	flex-shrink: 0;
}

/* === Post Type Badge (Search) === */
.post-type-badge {
	display: inline-block;
	padding: 0.125em 0.5em;
	font-size: 0.75em;
	font-weight: 600;
	text-transform: uppercase;
	background: var(--kt-surface);
	border-radius: var(--kt-radius);
}

/* === Widget === */
.widget {
	margin-bottom: 1.75em;
}

.widget:last-child {
	margin-bottom: 0;
}

.widget-title {
	font-size: 0.8125rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--kt-text-secondary);
	margin-bottom: 0.75em;
	padding-bottom: 0.5em;
	border-bottom: 2px solid var(--kt-primary);
}

.widget ul {
	list-style: none;
	padding: 0;
}

.widget li {
	padding: 0.25em 0;
}

.widget li a {
	color: var(--kt-text);
}

.widget li a:hover {
	color: var(--kt-link-hover);
}

/* === Comments === */
.comments-area {
	margin-top: 2em;
}

.comment-list {
	list-style: none;
	padding: 0;
}

.comment-body {
	padding: 1.5em;
	margin-bottom: 1em;
	background: var(--kt-surface);
	border-radius: var(--kt-radius);
	box-shadow: var(--kt-shadow-sm);
}

.comment-meta {
	display: flex;
	align-items: center;
	gap: 0.75em;
	margin-bottom: 0.75em;
}

.comment-author .avatar {
	border-radius: 50%;
}

.comment-author .fn {
	font-weight: 600;
}

.comment-metadata {
	font-size: 0.8125em;
	color: var(--kt-text-secondary);
}

.children {
	list-style: none;
	padding-left: 2em;
}

.comment-respond {
	margin-top: 2em;
}

/* === Scroll-to-Top === */
.kajinga-scroll-top {
	position: fixed;
	bottom: 2em;
	right: 2em;
	z-index: 99;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	padding: 0;
	color: #fff;
	background: var(--kt-primary);
	border: none;
	border-radius: 50%;
	cursor: pointer;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
	opacity: 0;
	visibility: hidden;
	transform: translateY(12px);
	transition: opacity 0.3s, visibility 0.3s, transform 0.3s, background-color var(--kt-transition);
}

.kajinga-scroll-top.is-visible {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.kajinga-scroll-top:hover {
	background: var(--kt-secondary);
}

.kajinga-scroll-top:focus-visible {
	outline: 2px solid #fff;
	outline-offset: 2px;
}

/* === Breadcrumbs === */
.kajinga-breadcrumbs {
	margin-bottom: 1.5em;
	font-size: 0.875em;
	color: var(--kt-text-secondary);
}

.kajinga-breadcrumbs__list {
	display: flex;
	flex-wrap: wrap;
	list-style: none;
	margin: 0;
	padding: 0;
	gap: 0.25em;
}

.kajinga-breadcrumbs__item:not(:last-child)::after {
	content: "/";
	margin-left: 0.25em;
	color: var(--kt-border);
}

.kajinga-breadcrumbs__item a {
	color: var(--kt-text-secondary);
	text-decoration: none;
}

.kajinga-breadcrumbs__item a:hover {
	color: var(--kt-link-hover);
}

/* === Related Posts === */
.kajinga-related-posts {
	margin-top: 2.5em;
	padding-top: 2em;
	border-top: 1px solid var(--kt-border);
}

.kajinga-related-posts__title {
	font-size: 1.25rem;
	margin-bottom: 1.25em;
}

.kajinga-related-posts__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.5em;
}

.kajinga-related-posts__thumb {
	overflow: hidden;
	border-radius: var(--kt-radius);
	display: block;
}

.kajinga-related-posts__thumb img {
	width: 100%;
	aspect-ratio: 4/3;
	object-fit: cover;
	border-radius: var(--kt-radius);
	transition: transform var(--kt-transition);
}

.kajinga-related-posts__thumb:hover img {
	transform: scale(1.03);
}

.kajinga-related-posts__item-title {
	font-size: 1rem;
	margin: 0.5em 0 0.25em;
	line-height: 1.4;
}

.kajinga-related-posts__item-title a {
	color: var(--kt-text);
	text-decoration: none;
}

.kajinga-related-posts__item-title a:hover {
	color: var(--kt-link-hover);
}

.kajinga-related-posts__item .entry-meta {
	margin-bottom: 0;
}

/* === Top Bar === */
.kajinga-topbar {
	background-color: var(--kt-topbar-bg, #111827);
	color: var(--kt-topbar-text, #d1d5db);
	font-size: 0.875rem;
	line-height: 1;
}

.kajinga-topbar__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 36px;
	gap: 1em;
}

.kajinga-topbar__right {
	display: flex;
	align-items: center;
	gap: 1em;
}

.kajinga-topbar a {
	color: var(--kt-topbar-text, #d1d5db);
	transition: color var(--kt-transition);
}

.kajinga-topbar a:hover {
	color: #fff;
}

.kajinga-topbar__menu {
	display: flex;
	align-items: center;
	gap: 1.25em;
	list-style: none;
	margin: 0;
	padding: 0;
}

.kajinga-topbar__menu li {
	margin: 0;
	padding: 0;
}

.kajinga-topbar__menu a {
	color: var(--kt-topbar-text, #d1d5db);
	text-decoration: none;
	font-size: inherit;
	transition: color var(--kt-transition);
}

.kajinga-topbar__menu a:hover {
	color: #fff;
}

/* Topbar centered layout */
.kajinga-topbar__inner--center {
	justify-content: center;
}

/* Topbar Icons (Bookmark-bar style) */
.kajinga-topbar__menu a {
	display: inline-flex;
	align-items: center;
	height: 36px;
}

.kajinga-topbar__icon {
	width: 18px;
	height: 18px;
	object-fit: contain;
	vertical-align: middle;
	margin-right: 0.35em;
	flex-shrink: 0;
}

.kajinga-topbar__icon--fallback {
	width: 18px;
	height: 18px;
	vertical-align: middle;
	margin-right: 0.35em;
	flex-shrink: 0;
	opacity: 0.6;
}

/* === Search Toggle === */
.kajinga-search-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: none;
	border: none;
	color: var(--kt-header-text);
	cursor: pointer;
	padding: 10px;
	opacity: 0.85;
	transition: opacity var(--kt-transition);
}

.kajinga-search-toggle:hover {
	opacity: 1;
}

.kajinga-search-toggle:focus-visible {
	outline: 2px solid currentColor;
	outline-offset: 2px;
}

/* === Search Overlay === */
.kajinga-search-overlay {
	background: var(--kt-header-bg);
	overflow: hidden;
	max-height: 0;
	opacity: 0;
	transition: max-height 0.3s ease, opacity 0.3s ease;
}

.kajinga-search-overlay.is-open {
	max-height: 80px;
	opacity: 1;
}

.kajinga-search-overlay__form {
	display: flex;
	align-items: center;
	padding: 0.75em 0;
	gap: 0.5em;
}

.kajinga-search-overlay__input {
	flex: 1;
	background: rgba(255, 255, 255, 0.1);
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: var(--kt-radius);
	color: var(--kt-header-text);
	padding: 0.5em 0.75em;
	font-size: 1rem;
	font-family: inherit;
}

.kajinga-search-overlay__input::placeholder {
	color: rgba(255, 255, 255, 0.5);
}

.kajinga-search-overlay__input:focus {
	outline: none;
	border-color: rgba(255, 255, 255, 0.5);
	box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.1);
}

.kajinga-search-overlay__submit,
.kajinga-search-overlay__close {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: none;
	border: none;
	color: var(--kt-header-text);
	cursor: pointer;
	padding: 10px;
	opacity: 0.7;
	transition: opacity var(--kt-transition);
}

.kajinga-search-overlay__submit:hover,
.kajinga-search-overlay__close:hover {
	opacity: 1;
}

.kajinga-search-overlay__submit:focus-visible,
.kajinga-search-overlay__close:focus-visible {
	outline: 2px solid currentColor;
	outline-offset: 2px;
}

/* === Stacked Layout === */
.kajinga-header--stacked .kajinga-header__inner {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1em 0 0;
	position: relative;
}

.kajinga-header--stacked .kajinga-header__inner .kajinga-menu-toggle {
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
}

.kajinga-header--stacked .kajinga-header__nav-row {
	display: flex;
	justify-content: center;
	padding-bottom: 0.5em;
}

.kajinga-header--stacked .kajinga-header__nav-row .kajinga-nav {
	justify-content: center;
}

.kajinga-header--stacked .kajinga-header__nav-row .kajinga-nav__menu {
	justify-content: center;
}

/* === Buttons Top Layout === */
.kajinga-header-cta--mobile {
	display: none;
}

.kajinga-header--buttons-top .kajinga-header__inner {
	display: grid;
	grid-template-columns: max-content 1fr;
	align-items: center;
	min-height: auto;
}

.kajinga-header--buttons-top .kajinga-header__branding {
	grid-row: 1 / 3;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	align-content: center;
	align-self: stretch;
	padding: 0.5em 2em 0.5em 0;
}

.kajinga-header--buttons-top .kajinga-header__branding .site-description {
	width: 100%;
}

.kajinga-header--buttons-top .kajinga-header__branding .custom-logo,
.kajinga-header--buttons-top .kajinga-header__branding .custom-logo-link {
	flex-shrink: 0;
}

.kajinga-header--buttons-top .kajinga-header__right {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 0.25em;
	padding: 0.75em 0;
}

.kajinga-header--buttons-top .kajinga-header__right-top {
	display: flex;
	justify-content: flex-end;
}

.kajinga-header--buttons-top .kajinga-header__right-top .kajinga-header-cta {
	margin-left: 0;
}

.kajinga-header--buttons-top .kajinga-nav {
	display: flex;
	align-items: center;
}

.kajinga-header--buttons-top .kajinga-nav__menu {
	gap: 0;
}

/* ===================================================================
   5. FOOTER
   =================================================================== */

.kajinga-footer {
	background-color: var(--kt-footer-bg);
	color: var(--kt-footer-text);
	font-size: var(--kt-footer-font-size);
	padding-top: var(--kt-footer-padding-top);
	padding-bottom: var(--kt-footer-padding-bottom);
}

.kajinga-footer a {
	color: var(--kt-footer-text);
	transition: color var(--kt-transition);
}

.kajinga-footer a:hover {
	color: #fff;
}

/* === Footer Widgets === */
.kajinga-footer__widgets {
	display: grid;
	gap: 2em;
	padding: 3em 0;
}

.kajinga-footer__widgets--cols-1 {
	grid-template-columns: 1fr;
}

.kajinga-footer__widgets--cols-2 {
	grid-template-columns: repeat(2, 1fr);
}

.kajinga-footer__widgets--cols-3 {
	grid-template-columns: repeat(3, 1fr);
}

.kajinga-footer__widgets--cols-4 {
	grid-template-columns: repeat(4, 1fr);
}

.kajinga-footer .widget-title {
	color: #fff;
	border-bottom-color: rgba(255, 255, 255, 0.2);
}

.kajinga-footer .widget li a {
	color: var(--kt-footer-text);
}

.kajinga-footer .widget li a:hover {
	color: #fff;
}

/* === Copyright Bar === */
.kajinga-footer__copyright {
	padding: 1.5em 0;
	font-size: 0.875em;
	text-align: center;
}

/* === Footer Navigation === */
.kajinga-footer__nav {
	padding: 1.5em 0;
}

.kajinga-footer__nav ul {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 1em;
	list-style: none;
	margin: 0;
	padding: 0;
}

.kajinga-footer__nav a {
	font-size: 0.875em;
}

/* ===================================================================
   6. RESPONSIVE - Media Queries
   =================================================================== */

/* === Tablet (max 1024px) === */
@media (max-width: 1024px) {
	.kajinga-layout--sidebar-right,
	.kajinga-layout--sidebar-left {
		grid-template-columns: 1fr;
	}

	.kajinga-layout--sidebar-left .kajinga-sidebar {
		order: 0;
	}

	/* Reset sidebar design borders on stacked layout */
	.kajinga-sidebar--bordered {
		padding: 1.5em 0 0;
		border-left: none;
		border-top: 1px solid var(--kt-border);
	}

	.kajinga-layout--sidebar-left .kajinga-sidebar--bordered {
		padding: 1.5em 0 0;
		border-right: none;
		border-top: 1px solid var(--kt-border);
	}

	.kajinga-sidebar--minimal {
		padding: 1.5em 0 0;
	}

	.kajinga-sidebar--minimal::before {
		left: 0;
		right: 0;
		top: 0;
		bottom: auto;
		width: auto;
		height: 1px;
		background: linear-gradient(to right, transparent, var(--kt-border) 15%, var(--kt-border) 85%, transparent);
	}

	.kajinga-layout--sidebar-left .kajinga-sidebar--minimal {
		padding: 1.5em 0 0;
	}

	.kajinga-layout--sidebar-left .kajinga-sidebar--minimal::before {
		left: 0;
		right: 0;
	}

	.kajinga-blog--cols-3 {
		grid-template-columns: repeat(2, 1fr);
	}

	.kajinga-footer__widgets--cols-4 {
		grid-template-columns: repeat(2, 1fr);
	}

	.kajinga-related-posts__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* === Mobile (max 768px) === */
@media (max-width: 768px) {
	/* Typography */
	.kajinga-layout h1 { font-size: 1.75rem; }
	.kajinga-layout h2 { font-size: 1.5rem; }
	.kajinga-layout h3 { font-size: 1.25rem; }

	/* Container */
	.kajinga-container {
		padding: 0 1em;
	}

	/* Header - Mobile Toggle */
	.kajinga-menu-toggle {
		display: block;
	}

	/* Slide-in Navigation Panel */
	.kajinga-nav {
		position: fixed;
		top: 0;
		right: 0;
		bottom: 0;
		width: 280px;
		max-width: 85vw;
		background: var(--kt-header-bg);
		z-index: 10000;
		transform: translateX(100%);
		transition: transform 0.3s ease;
		overflow-y: auto;
		-webkit-overflow-scrolling: touch;
		display: flex;
		flex-direction: column;
	}

	.kajinga-nav.is-open {
		transform: translateX(0);
	}

	/* Close button */
	.kajinga-nav__close {
		display: flex;
		align-items: center;
		justify-content: flex-end;
		padding: 1em;
		background: none;
		border: none;
		color: var(--kt-header-text);
		cursor: pointer;
		flex-shrink: 0;
	}

	.kajinga-nav__close:hover {
		opacity: 0.7;
	}

	.kajinga-nav__close:focus-visible {
		outline: 2px solid currentColor;
		outline-offset: 2px;
	}

	/* Backdrop overlay */
	.kajinga-nav-backdrop {
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		background: rgba(0, 0, 0, 0.5);
		z-index: 9999;
		opacity: 0;
		visibility: hidden;
		transition: opacity 0.3s ease, visibility 0.3s ease;
	}

	.kajinga-nav-backdrop.is-visible {
		opacity: 1;
		visibility: visible;
	}

	/* Menu items */
	.kajinga-nav__menu {
		flex-direction: column;
		padding: 0 1em 1em;
	}

	.kajinga-nav__menu > li {
		border-bottom: 1px solid rgba(255, 255, 255, 0.1);
	}

	.kajinga-nav__menu > li:last-child {
		border-bottom: none;
	}

	/* Hide desktop chevron indicators on mobile */
	.kajinga-nav__menu .menu-item-has-children > a::after {
		display: none;
	}

	.kajinga-nav__menu a {
		padding: 0.875em 0;
		opacity: 1;
	}

	/* Submenu items with accordion parent */
	.menu-item-has-children {
		position: relative;
	}

	.kajinga-submenu-toggle {
		position: absolute;
		top: 0;
		right: 0;
		display: flex;
		align-items: center;
		justify-content: center;
		width: 44px;
		height: 44px;
		background: none;
		border: none;
		color: var(--kt-header-text);
		cursor: pointer;
		opacity: 0.6;
		transition: transform 0.2s ease, opacity 0.2s ease;
	}

	.kajinga-submenu-toggle:hover {
		opacity: 1;
	}

	.kajinga-submenu-toggle:focus-visible {
		outline: 2px solid currentColor;
		outline-offset: 2px;
	}

	.is-expanded > .kajinga-submenu-toggle {
		transform: rotate(180deg);
		opacity: 1;
	}

	/* Submenu accordion - reset desktop dropdown animation */
	.kajinga-nav__menu .sub-menu {
		position: static;
		border: none;
		box-shadow: none;
		background: none;
		padding: 0 0 0 1em;
		max-height: 0;
		overflow: hidden;
		transition: max-height 0.3s ease;
		min-width: 0;
		visibility: visible;
		opacity: 1;
		transform: none;
		pointer-events: auto;
	}

	.kajinga-nav__menu .sub-menu a {
		font-size: 0.9375em;
		padding: 0.625em 0;
		opacity: 0.8;
	}

	.kajinga-nav__menu .sub-menu a:hover {
		opacity: 1;
		color: var(--kt-header-text);
		background: none;
	}

	.kajinga-nav__menu .sub-menu .sub-menu {
		top: auto;
		left: auto;
	}

	/* CTA Buttons in slide-in panel */
	.kajinga-header-cta {
		flex-direction: column;
		margin: 1em 1em 0;
		padding-top: 1em;
		border-top: 1px solid rgba(255, 255, 255, 0.1);
	}

	.kajinga-header-cta__btn {
		width: 100%;
		text-align: center;
		padding: 0.75em 1.25em;
	}

	/* Top Bar hide on mobile */
	.kajinga-topbar--hide-mobile {
		display: none;
	}

	/* Search toggle in mobile nav */
	.kajinga-search-toggle {
		margin-left: 0;
	}

	/* Stacked layout: hide nav-row, show hamburger */
	.kajinga-header--stacked .kajinga-header__nav-row {
		display: none;
	}

	.kajinga-header--stacked .kajinga-header__inner .kajinga-menu-toggle {
		display: block;
	}

	/* Buttons-top layout: collapse to single row with hamburger */
	.kajinga-header--buttons-top .kajinga-header__inner {
		display: flex;
		min-height: 70px;
	}

	.kajinga-header--buttons-top .kajinga-header__branding {
		grid-row: auto;
	}

	.kajinga-header--buttons-top .kajinga-header__right {
		display: contents;
	}

	.kajinga-header--buttons-top .kajinga-header__right-top {
		display: none;
	}

	/* Cloned CTA buttons visible in mobile slide-in */
	.kajinga-header-cta--mobile {
		display: flex;
		flex-direction: column;
		margin: 1em 1em 0;
		padding-top: 1em;
		border-top: 1px solid rgba(255, 255, 255, 0.1);
	}

	.kajinga-header-cta--mobile .kajinga-header-cta__btn {
		width: 100%;
		text-align: center;
		padding: 0.75em 1.25em;
	}

	/* Blog Grid + Cards */
	.kajinga-blog--cols-2,
	.kajinga-blog--cols-3 {
		grid-template-columns: 1fr;
	}

	/* Blog List with thumbnail */
	.kajinga-blog--list .kajinga-post {
		grid-template-columns: 1fr;
	}

	/* Footer Widgets */
	.kajinga-footer__widgets--cols-2,
	.kajinga-footer__widgets--cols-3,
	.kajinga-footer__widgets--cols-4 {
		grid-template-columns: 1fr;
	}

	/* Post Navigation */
	.post-navigation .nav-links {
		grid-template-columns: 1fr;
	}

	/* Alignwide */
	.alignwide {
		margin-left: 0;
		margin-right: 0;
		max-width: 100%;
	}

	/* Related Posts */
	.kajinga-related-posts__grid {
		grid-template-columns: 1fr;
	}

	/* Scroll-to-Top */
	.kajinga-scroll-top {
		width: 44px;
		height: 44px;
		bottom: 1em;
		right: 1em;
	}

	/* Touch targets - min 44px */
	.widget li {
		padding: 0.5em 0;
	}

	.widget li a {
		display: block;
		padding: 0.25em 0;
	}

	.kajinga-footer__nav a {
		display: inline-block;
		padding: 0.5em 0;
	}

	.entry-footer a {
		display: inline-block;
		padding: 0.25em 0;
	}
}

/* === Small Mobile (max 480px) === */
@media (max-width: 480px) {
	.kajinga-content-area {
		padding: 1em 0;
	}

	.search-form {
		flex-direction: column;
	}

	.entry-meta {
		flex-direction: column;
		gap: 0.25em;
	}
}
