/*
Theme Name: KTECH Fire & Safety
Theme URI: https://www.ktechfire.co.za
Description: Official WordPress theme for KTECH Fire and Safety Consultants (Pty) Ltd, trading as Aktech Fire & Safety Consultants. A modern, mobile-first theme built for professional safety consultants in KwaZulu-Natal.
Version: 1.0.0
Author: KTECH Fire & Safety Consultants
Author URI: https://www.ktechfire.co.za
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: ktech-fire-safety
Tags: fire-safety, consulting, professional, mobile-first, responsive
*/

/* ============================================================
   CSS CUSTOM PROPERTIES
   ============================================================ */
:root {
	--color-primary:     #1a1a1a;
	--color-secondary:   #404040;
	--color-accent:      #e63329;
	--color-accent-dark: #c0271d;
	--color-gray:        #808080;
	--color-light-gray:  #f5f5f5;
	--color-white:       #ffffff;
	--color-border:      #e0e0e0;
	--color-text:        #2d2d2d;
	--color-text-muted:  #666666;

	--font-body:    'Inter', system-ui, -apple-system, sans-serif;
	--font-heading: 'Montserrat', system-ui, -apple-system, sans-serif;

	--font-size-xs:   0.75rem;
	--font-size-sm:   0.875rem;
	--font-size-base: 1rem;
	--font-size-lg:   1.125rem;
	--font-size-xl:   1.25rem;
	--font-size-2xl:  1.5rem;
	--font-size-3xl:  1.875rem;
	--font-size-4xl:  2.25rem;
	--font-size-5xl:  3rem;
	--font-size-6xl:  3.75rem;

	--line-height-tight:  1.2;
	--line-height-snug:   1.4;
	--line-height-normal: 1.6;
	--line-height-loose:  1.8;

	--spacing-1:  0.25rem;
	--spacing-2:  0.5rem;
	--spacing-3:  0.75rem;
	--spacing-4:  1rem;
	--spacing-5:  1.25rem;
	--spacing-6:  1.5rem;
	--spacing-8:  2rem;
	--spacing-10: 2.5rem;
	--spacing-12: 3rem;
	--spacing-16: 4rem;
	--spacing-20: 5rem;
	--spacing-24: 6rem;

	--radius-sm:   4px;
	--radius-md:   8px;
	--radius-lg:   12px;
	--radius-xl:   16px;
	--radius-full: 9999px;

	--shadow-sm:  0 1px 3px rgba(0,0,0,.10), 0 1px 2px rgba(0,0,0,.06);
	--shadow-md:  0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.06);
	--shadow-lg:  0 10px 15px rgba(0,0,0,.10), 0 4px 6px rgba(0,0,0,.05);
	--shadow-xl:  0 20px 25px rgba(0,0,0,.10), 0 10px 10px rgba(0,0,0,.04);
	--shadow-accent: 0 4px 20px rgba(230,51,41,.30);

	--transition-fast:   150ms ease;
	--transition-normal: 250ms ease;
	--transition-slow:   350ms ease;

	--container-sm:  640px;
	--container-md:  768px;
	--container-lg:  1024px;
	--container-xl:  1280px;
	--container-2xl: 1400px;

	--header-height: 72px;
}

/* ============================================================
   CSS RESET & BASE
   ============================================================ */
*, *::before, *::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

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

body {
	font-family: var(--font-body);
	font-size: var(--font-size-base);
	line-height: var(--line-height-normal);
	color: var(--color-text);
	background-color: var(--color-white);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

img, svg, video {
	display: block;
	max-width: 100%;
	height: auto;
}

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

a:hover { color: var(--color-accent-dark); }
a:focus-visible {
	outline: 2px solid var(--color-accent);
	outline-offset: 2px;
	border-radius: 2px;
}

ul, ol { list-style: none; }

button, input, select, textarea {
	font-family: inherit;
	font-size: inherit;
}

button { cursor: pointer; }

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-heading);
	font-weight: 700;
	line-height: var(--line-height-tight);
	color: var(--color-primary);
}

h1 { font-size: clamp(var(--font-size-3xl), 5vw, var(--font-size-5xl)); }
h2 { font-size: clamp(var(--font-size-2xl), 4vw, var(--font-size-4xl)); }
h3 { font-size: clamp(var(--font-size-xl),  3vw, var(--font-size-3xl)); }
h4 { font-size: var(--font-size-xl); }
h5 { font-size: var(--font-size-lg); }
h6 { font-size: var(--font-size-base); }

p { margin-bottom: var(--spacing-4); }
p:last-child { margin-bottom: 0; }

strong { font-weight: 700; }
em { font-style: italic; }

hr {
	border: none;
	border-top: 1px solid var(--color-border);
	margin: var(--spacing-8) 0;
}

/* ============================================================
   SKIP LINK (Accessibility)
   ============================================================ */
.skip-link {
	position: absolute;
	top: -100%;
	left: 0;
	z-index: 9999;
	padding: var(--spacing-3) var(--spacing-6);
	background: var(--color-accent);
	color: var(--color-white);
	font-weight: 700;
	border-radius: 0 0 var(--radius-md) 0;
	transition: top var(--transition-fast);
}
.skip-link:focus { top: 0; color: var(--color-white); }

/* ============================================================
   LAYOUT UTILITIES
   ============================================================ */
.container {
	width: 100%;
	max-width: var(--container-xl);
	margin-inline: auto;
	padding-inline: var(--spacing-6);
}

.container--sm  { max-width: var(--container-sm); }
.container--md  { max-width: var(--container-md); }
.container--lg  { max-width: var(--container-lg); }
.container--2xl { max-width: var(--container-2xl); }

.section {
	padding-block: var(--spacing-20);
}
.section--sm  { padding-block: var(--spacing-12); }
.section--lg  { padding-block: var(--spacing-24); }
.section--dark {
	background-color: var(--color-primary);
	color: var(--color-white);
}
.section--dark h1,
.section--dark h2,
.section--dark h3,
.section--dark h4 { color: var(--color-white); }
.section--gray { background-color: var(--color-light-gray); }
.section--accent {
	background-color: var(--color-accent);
	color: var(--color-white);
}
.section--accent h1,
.section--accent h2,
.section--accent h3 { color: var(--color-white); }

.grid {
	display: grid;
	gap: var(--spacing-8);
}
.grid--2 { grid-template-columns: repeat(2, 1fr); }
.grid--3 { grid-template-columns: repeat(3, 1fr); }
.grid--4 { grid-template-columns: repeat(4, 1fr); }
.grid--auto { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }

.flex { display: flex; }
.flex--center { align-items: center; justify-content: center; }
.flex--between { align-items: center; justify-content: space-between; }
.flex--col { flex-direction: column; }
.flex--wrap { flex-wrap: wrap; }
.gap-2 { gap: var(--spacing-2); }
.gap-4 { gap: var(--spacing-4); }
.gap-6 { gap: var(--spacing-6); }
.gap-8 { gap: var(--spacing-8); }

.text-center { text-align: center; }
.text-left   { text-align: left; }
.text-right  { text-align: right; }

.section-header {
	text-align: center;
	margin-bottom: var(--spacing-12);
}
.section-header .section-label {
	display: inline-block;
	font-size: var(--font-size-sm);
	font-weight: 600;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--color-accent);
	margin-bottom: var(--spacing-3);
}
.section-header h2 {
	margin-bottom: var(--spacing-4);
}
.section-header p {
	font-size: var(--font-size-lg);
	color: var(--color-text-muted);
	max-width: 640px;
	margin-inline: auto;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
	display: inline-flex;
	align-items: center;
	gap: var(--spacing-2);
	padding: 0.75rem 1.75rem;
	font-family: var(--font-heading);
	font-size: var(--font-size-base);
	font-weight: 600;
	line-height: 1;
	border: 2px solid transparent;
	border-radius: var(--radius-md);
	cursor: pointer;
	text-decoration: none;
	transition: all var(--transition-normal);
	white-space: nowrap;
}
.btn:focus-visible {
	outline: 2px solid var(--color-accent);
	outline-offset: 3px;
}

.btn--primary {
	background-color: var(--color-accent);
	border-color: var(--color-accent);
	color: var(--color-white);
	box-shadow: var(--shadow-accent);
}
.btn--primary:hover {
	background-color: var(--color-accent-dark);
	border-color: var(--color-accent-dark);
	color: var(--color-white);
	transform: translateY(-2px);
	box-shadow: 0 6px 24px rgba(230,51,41,.40);
}

.btn--secondary {
	background-color: transparent;
	border-color: var(--color-white);
	color: var(--color-white);
}
.btn--secondary:hover {
	background-color: var(--color-white);
	color: var(--color-primary);
	transform: translateY(-2px);
}

.btn--outline {
	background-color: transparent;
	border-color: var(--color-accent);
	color: var(--color-accent);
}
.btn--outline:hover {
	background-color: var(--color-accent);
	color: var(--color-white);
	transform: translateY(-2px);
}

.btn--dark {
	background-color: var(--color-primary);
	border-color: var(--color-primary);
	color: var(--color-white);
}
.btn--dark:hover {
	background-color: var(--color-secondary);
	border-color: var(--color-secondary);
	color: var(--color-white);
	transform: translateY(-2px);
}

.btn--lg {
	padding: 1rem 2.25rem;
	font-size: var(--font-size-lg);
}
.btn--sm {
	padding: 0.5rem 1.25rem;
	font-size: var(--font-size-sm);
}

/* ============================================================
   SITE HEADER & NAVIGATION
   ============================================================ */
.site-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1000;
	height: var(--header-height);
	background-color: var(--color-primary);
	border-bottom: 2px solid rgba(255,255,255,.06);
	transition: all var(--transition-normal);
}
.site-header.scrolled {
	box-shadow: 0 2px 20px rgba(0,0,0,.4);
	background-color: rgba(26,26,26,.98);
	backdrop-filter: blur(10px);
}

.header-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: var(--header-height);
}

/* Logo */
.site-logo {
	display: flex;
	align-items: center;
	gap: var(--spacing-3);
	text-decoration: none;
	flex-shrink: 0;
}

/* WordPress custom_logo link — matches site-logo styling */
a.custom-logo-link {
	display: flex;
	align-items: center;
	flex-shrink: 0;
	text-decoration: none;
}

/* Uploaded PNG logo in header — auto-resize using Customizer CSS variable */
.custom-logo-link .custom-logo,
.site-logo img.custom-logo {
	display: block;
	height: var(--ktech-logo-height, 52px);
	width: auto;
	max-width: 280px;
	object-fit: contain;
}

/* SVG logo variant in header/footer */
.site-logo--svg,
.site-logo--footer {
	display: inline-block;
}
.site-logo--svg svg,
.site-logo--footer svg {
	display: block;
	height: var(--ktech-logo-height, 44px);
	width: auto;
	max-width: 260px;
}

/* Footer logo — always show at footer height */
.site-logo--footer img.footer-logo-img,
.site-logo--footer img.custom-logo {
	display: block;
	height: var(--ktech-footer-logo-height, 56px);
	width: auto;
	max-width: 280px;
	object-fit: contain;
	margin-bottom: var(--spacing-5);
}
.site-logo--footer svg {
	height: var(--ktech-footer-logo-height, 56px);
	max-width: 280px;
	margin-bottom: var(--spacing-5);
}

/* Mobile nav logo area */
.mobile-nav__logo {
	padding: var(--spacing-5) var(--spacing-5) var(--spacing-4);
	border-bottom: 1px solid rgba(255,255,255,.12);
	margin-bottom: var(--spacing-2);
}
.mobile-nav__logo .custom-logo-link,
.mobile-nav__logo .site-logo {
	display: inline-flex;
}
.mobile-nav__logo .custom-logo,
.mobile-nav__logo svg {
	height: 44px;
	width: auto;
	max-width: 200px;
	display: block;
}

/* Text fallback when SVG file is missing */
.logo-text-fallback {
	font-family: var(--font-heading);
	font-size: var(--font-size-xl);
	font-weight: 900;
	color: var(--color-white);
	letter-spacing: .02em;
}
.logo-text-fallback small {
	display: block;
	font-size: var(--font-size-xs);
	font-weight: 600;
	color: rgba(255,255,255,.6);
	letter-spacing: .08em;
	text-transform: uppercase;
}
/* Legacy text-based logo (kept for backwards compat) */
.logo-icon {
	width: 44px;
	height: 44px;
	background: var(--color-accent);
	border-radius: var(--radius-md);
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--font-heading);
	font-size: var(--font-size-xl);
	font-weight: 900;
	color: var(--color-white);
	letter-spacing: -1px;
	flex-shrink: 0;
}
.logo-text {
	display: flex;
	flex-direction: column;
}
.logo-text .logo-main {
	font-family: var(--font-heading);
	font-size: var(--font-size-lg);
	font-weight: 800;
	color: var(--color-white);
	line-height: 1;
	letter-spacing: .02em;
}
.logo-text .logo-sub {
	font-family: var(--font-body);
	font-size: var(--font-size-xs);
	color: rgba(255,255,255,.6);
	letter-spacing: .08em;
	text-transform: uppercase;
	line-height: 1.4;
}

/* Primary Navigation */
.primary-nav {
	display: flex;
	align-items: center;
}
.primary-nav ul {
	display: flex;
	align-items: center;
	gap: var(--spacing-1);
	list-style: none;
}
.primary-nav ul li { position: relative; }
.primary-nav ul li a {
	display: block;
	padding: var(--spacing-2) var(--spacing-3);
	font-family: var(--font-heading);
	font-size: var(--font-size-sm);
	font-weight: 600;
	color: rgba(255,255,255,.85);
	text-decoration: none;
	border-radius: var(--radius-sm);
	transition: all var(--transition-fast);
	white-space: nowrap;
}
.primary-nav ul li a:hover,
.primary-nav ul li.current-menu-item > a,
.primary-nav ul li.current_page_item > a {
	color: var(--color-white);
	background-color: rgba(255,255,255,.1);
}

/* Dropdown */
.primary-nav ul li.menu-item-has-children > a::after {
	content: '';
	display: inline-block;
	width: 8px;
	height: 8px;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: rotate(45deg) translateY(-2px);
	margin-left: var(--spacing-2);
	vertical-align: middle;
	transition: transform var(--transition-fast);
}
.primary-nav ul li.menu-item-has-children:hover > a::after {
	transform: rotate(-135deg) translateY(2px);
}
.primary-nav ul .sub-menu {
	position: absolute;
	top: calc(100% + var(--spacing-2));
	left: 0;
	min-width: 220px;
	background-color: var(--color-white);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-xl);
	opacity: 0;
	visibility: hidden;
	transform: translateY(-8px);
	transition: all var(--transition-normal);
	flex-direction: column;
	gap: 0;
	border-top: 3px solid var(--color-accent);
}
.primary-nav ul li:hover > .sub-menu,
.primary-nav ul li:focus-within > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}
.primary-nav ul .sub-menu li a {
	color: var(--color-text);
	border-radius: 0;
	padding: var(--spacing-3) var(--spacing-5);
	font-size: var(--font-size-sm);
}
.primary-nav ul .sub-menu li a:hover {
	background-color: var(--color-light-gray);
	color: var(--color-accent);
}
.primary-nav ul .sub-menu li:first-child a { border-radius: 0 0 0 0; }
.primary-nav ul .sub-menu li:last-child a {
	border-radius: 0 0 var(--radius-md) var(--radius-md);
}

.nav-cta {
	margin-left: var(--spacing-4);
}

/* Hamburger */
.hamburger-btn {
	display: none;
	flex-direction: column;
	gap: 5px;
	background: transparent;
	border: none;
	padding: var(--spacing-2);
	cursor: pointer;
	z-index: 1001;
	border-radius: var(--radius-sm);
	transition: background var(--transition-fast);
}
.hamburger-btn:hover { background: rgba(255,255,255,.1); }
.hamburger-btn span {
	display: block;
	width: 24px;
	height: 2px;
	background: var(--color-white);
	border-radius: 2px;
	transition: all var(--transition-normal);
	transform-origin: center;
}
.hamburger-btn[aria-expanded="true"] span:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}
.hamburger-btn[aria-expanded="true"] span:nth-child(2) {
	opacity: 0;
	transform: scaleX(0);
}
.hamburger-btn[aria-expanded="true"] span:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

/* Mobile Nav Overlay */
.mobile-nav {
	display: none;
	position: fixed;
	inset: 0;
	background: var(--color-primary);
	z-index: 999;
	overflow-y: auto;
	padding-top: var(--header-height);
}
.mobile-nav.is-open { display: flex; flex-direction: column; }
.mobile-nav__inner {
	padding: var(--spacing-8) var(--spacing-6);
	flex: 1;
}
.mobile-nav ul { list-style: none; }
.mobile-nav > .mobile-nav__inner > ul > li {
	border-bottom: 1px solid rgba(255,255,255,.08);
}
.mobile-nav ul li a {
	display: block;
	padding: var(--spacing-4) var(--spacing-2);
	font-family: var(--font-heading);
	font-size: var(--font-size-lg);
	font-weight: 600;
	color: rgba(255,255,255,.85);
	text-decoration: none;
	transition: color var(--transition-fast);
}
.mobile-nav ul li a:hover { color: var(--color-accent); }
.mobile-nav .sub-menu {
	padding-left: var(--spacing-4);
	padding-bottom: var(--spacing-2);
}
.mobile-nav .sub-menu li a {
	font-size: var(--font-size-base);
	font-weight: 500;
	padding: var(--spacing-2) var(--spacing-2);
	color: rgba(255,255,255,.65);
}
.mobile-nav__footer {
	padding: var(--spacing-6);
	border-top: 1px solid rgba(255,255,255,.08);
	display: flex;
	flex-direction: column;
	gap: var(--spacing-3);
}
.mobile-nav__footer a {
	color: rgba(255,255,255,.7);
	font-size: var(--font-size-sm);
	text-decoration: none;
}

/* ============================================================
   HERO SECTIONS
   ============================================================ */
.hero {
	position: relative;
	min-height: 90vh;
	display: flex;
	align-items: center;
	background-color: var(--color-primary);
	overflow: hidden;
	margin-top: var(--header-height);
}
.hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(26,26,26,.95) 0%, rgba(64,64,64,.85) 50%, rgba(230,51,41,.15) 100%);
	z-index: 1;
}
.hero-bg {
	position: absolute;
	inset: 0;
	background-image:
		radial-gradient(circle at 20% 50%, rgba(230,51,41,.15) 0%, transparent 50%),
		radial-gradient(circle at 80% 20%, rgba(230,51,41,.08) 0%, transparent 40%);
}
.hero-pattern {
	position: absolute;
	inset: 0;
	background-image:
		linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
	background-size: 60px 60px;
	z-index: 0;
}
.hero__content {
	position: relative;
	z-index: 2;
	max-width: 800px;
}
.hero__label {
	display: inline-flex;
	align-items: center;
	gap: var(--spacing-2);
	font-size: var(--font-size-sm);
	font-weight: 600;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--color-accent);
	margin-bottom: var(--spacing-5);
	padding: var(--spacing-2) var(--spacing-4);
	background: rgba(230,51,41,.12);
	border: 1px solid rgba(230,51,41,.25);
	border-radius: var(--radius-full);
}
.hero h1 {
	font-size: clamp(2rem, 5vw, 3.75rem);
	color: var(--color-white);
	margin-bottom: var(--spacing-6);
	line-height: 1.1;
}
.hero h1 span { color: var(--color-accent); }
.hero p {
	font-size: clamp(var(--font-size-lg), 2vw, var(--font-size-xl));
	color: rgba(255,255,255,.8);
	margin-bottom: var(--spacing-8);
	max-width: 600px;
	line-height: var(--line-height-loose);
}
.hero__actions {
	display: flex;
	gap: var(--spacing-4);
	flex-wrap: wrap;
}
.hero__stats {
	display: flex;
	gap: var(--spacing-8);
	margin-top: var(--spacing-12);
	padding-top: var(--spacing-8);
	border-top: 1px solid rgba(255,255,255,.1);
	flex-wrap: wrap;
}
.hero__stat { display: flex; flex-direction: column; }
.hero__stat .stat-number {
	font-family: var(--font-heading);
	font-size: var(--font-size-3xl);
	font-weight: 800;
	color: var(--color-accent);
	line-height: 1;
}
.hero__stat .stat-label {
	font-size: var(--font-size-sm);
	color: rgba(255,255,255,.6);
	margin-top: var(--spacing-1);
}

/* Page Hero (inner pages) */
.page-hero {
	background-color: var(--color-primary);
	padding: var(--spacing-20) 0 var(--spacing-16);
	margin-top: var(--header-height);
	position: relative;
	overflow: hidden;
}
.page-hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(230,51,41,.08) 0%, transparent 60%);
}
.page-hero::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: linear-gradient(90deg, var(--color-accent), var(--color-accent-dark));
}
.page-hero__content {
	position: relative;
	z-index: 1;
}
.page-hero .breadcrumb {
	display: flex;
	align-items: center;
	gap: var(--spacing-2);
	margin-bottom: var(--spacing-4);
	font-size: var(--font-size-sm);
}
.page-hero .breadcrumb a {
	color: rgba(255,255,255,.6);
	text-decoration: none;
	transition: color var(--transition-fast);
}
.page-hero .breadcrumb a:hover { color: var(--color-accent); }
.page-hero .breadcrumb span {
	color: rgba(255,255,255,.3);
}
.page-hero .breadcrumb .current {
	color: rgba(255,255,255,.9);
}
.page-hero h1 { color: var(--color-white); margin-bottom: var(--spacing-4); }
.page-hero p { color: rgba(255,255,255,.75); font-size: var(--font-size-lg); margin: 0; }

/* ============================================================
   CARDS
   ============================================================ */
.card {
	background: var(--color-white);
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow-md);
	transition: all var(--transition-normal);
	border: 1px solid var(--color-border);
}
.card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-xl);
	border-color: transparent;
}
.card__body { padding: var(--spacing-6); }
.card__header { padding: var(--spacing-6) var(--spacing-6) 0; }
.card__footer {
	padding: var(--spacing-4) var(--spacing-6) var(--spacing-6);
	border-top: 1px solid var(--color-border);
}

/* Service Cards */
.service-card {
	background: var(--color-white);
	border-radius: var(--radius-lg);
	padding: var(--spacing-8);
	box-shadow: var(--shadow-md);
	border: 1px solid var(--color-border);
	transition: all var(--transition-normal);
	position: relative;
	overflow: hidden;
}
.service-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: var(--color-accent);
	transform: scaleX(0);
	transition: transform var(--transition-normal);
	transform-origin: left;
}
.service-card:hover::before { transform: scaleX(1); }
.service-card:hover {
	transform: translateY(-6px);
	box-shadow: var(--shadow-xl);
}
.service-card__icon {
	width: 60px;
	height: 60px;
	background: linear-gradient(135deg, var(--color-accent), var(--color-accent-dark));
	border-radius: var(--radius-lg);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 28px;
	margin-bottom: var(--spacing-5);
	color: var(--color-white);
}
.service-card h3 {
	font-size: var(--font-size-xl);
	margin-bottom: var(--spacing-3);
	color: var(--color-primary);
}
.service-card p {
	color: var(--color-text-muted);
	font-size: var(--font-size-base);
	line-height: var(--line-height-loose);
	margin-bottom: var(--spacing-5);
}
.service-card .learn-more {
	display: inline-flex;
	align-items: center;
	gap: var(--spacing-2);
	color: var(--color-accent);
	font-weight: 600;
	font-size: var(--font-size-sm);
	text-decoration: none;
	transition: gap var(--transition-fast);
}
.service-card .learn-more:hover { gap: var(--spacing-3); }

/* Feature/Why Choose Us Cards */
.feature-card {
	background: var(--color-white);
	border-radius: var(--radius-lg);
	padding: var(--spacing-6);
	text-align: center;
	box-shadow: var(--shadow-sm);
	border: 1px solid var(--color-border);
	transition: all var(--transition-normal);
}
.feature-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-lg);
}
.feature-card__icon {
	font-size: 44px;
	margin-bottom: var(--spacing-4);
	display: block;
}
.feature-card h3 {
	font-size: var(--font-size-lg);
	margin-bottom: var(--spacing-2);
	color: var(--color-primary);
}
.feature-card p {
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	line-height: var(--line-height-loose);
	margin: 0;
}

/* Project Cards */
.project-card {
	background: var(--color-white);
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow-md);
	transition: all var(--transition-normal);
}
.project-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-xl);
}
.project-card__thumb {
	height: 180px;
	background: linear-gradient(135deg, var(--color-secondary), var(--color-primary));
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 48px;
	position: relative;
	overflow: hidden;
}
.project-card__thumb::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(to bottom, transparent 50%, rgba(0,0,0,.5));
}
.project-card__badge {
	position: absolute;
	top: var(--spacing-3);
	right: var(--spacing-3);
	background: var(--color-accent);
	color: var(--color-white);
	font-size: var(--font-size-xs);
	font-weight: 700;
	padding: var(--spacing-1) var(--spacing-3);
	border-radius: var(--radius-full);
	z-index: 1;
}
.project-card__body { padding: var(--spacing-5); }
.project-card h3 {
	font-size: var(--font-size-lg);
	margin-bottom: var(--spacing-2);
}
.project-card .project-value {
	font-size: var(--font-size-2xl);
	font-weight: 800;
	color: var(--color-accent);
	font-family: var(--font-heading);
}
.project-card .project-meta {
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	margin-top: var(--spacing-2);
}

/* Pricing Cards */
.pricing-table {
	background: var(--color-white);
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow-md);
	border: 1px solid var(--color-border);
}
.pricing-table__header {
	background: var(--color-primary);
	padding: var(--spacing-5) var(--spacing-6);
}
.pricing-table__header h3 {
	color: var(--color-white);
	font-size: var(--font-size-lg);
	margin: 0;
}
.pricing-table__body { padding: 0; }
.pricing-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: var(--spacing-4) var(--spacing-6);
	border-bottom: 1px solid var(--color-border);
	transition: background var(--transition-fast);
}
.pricing-row:last-child { border-bottom: none; }
.pricing-row:hover { background: var(--color-light-gray); }
.pricing-row .item-name {
	font-size: var(--font-size-sm);
	color: var(--color-text);
	flex: 1;
}
.pricing-row .item-price {
	font-family: var(--font-heading);
	font-weight: 700;
	color: var(--color-accent);
	font-size: var(--font-size-base);
	white-space: nowrap;
	margin-left: var(--spacing-4);
}

/* Training Cards */
.training-card {
	background: var(--color-white);
	border-radius: var(--radius-lg);
	padding: var(--spacing-6);
	box-shadow: var(--shadow-sm);
	border: 1px solid var(--color-border);
	transition: all var(--transition-normal);
	display: flex;
	flex-direction: column;
	gap: var(--spacing-3);
}
.training-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-lg);
	border-color: var(--color-accent);
}
.training-card__code {
	display: inline-block;
	background: rgba(230,51,41,.1);
	color: var(--color-accent);
	font-size: var(--font-size-xs);
	font-weight: 700;
	letter-spacing: .1em;
	text-transform: uppercase;
	padding: var(--spacing-1) var(--spacing-3);
	border-radius: var(--radius-full);
}
.training-card h3 {
	font-size: var(--font-size-base);
	margin: 0;
}
.training-card .training-price {
	font-family: var(--font-heading);
	font-size: var(--font-size-2xl);
	font-weight: 800;
	color: var(--color-accent);
	margin-top: auto;
}
.training-card .training-price span {
	font-size: var(--font-size-sm);
	font-weight: 500;
	color: var(--color-text-muted);
}

/* Accreditation Badges */
.accreditations-strip {
	background: var(--color-white);
	padding: var(--spacing-10) 0;
	border-top: 1px solid var(--color-border);
	border-bottom: 1px solid var(--color-border);
}
.accreditation-badge {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--spacing-2);
	padding: var(--spacing-4) var(--spacing-6);
	border-radius: var(--radius-md);
	transition: all var(--transition-normal);
}
.accreditation-badge:hover { background: var(--color-light-gray); }
.accreditation-badge .badge-icon {
	width: 56px;
	height: 56px;
	background: var(--color-light-gray);
	border-radius: var(--radius-full);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 24px;
	border: 2px solid var(--color-border);
}
.accreditation-badge .badge-name {
	font-family: var(--font-heading);
	font-size: var(--font-size-xs);
	font-weight: 700;
	color: var(--color-primary);
	text-transform: uppercase;
	letter-spacing: .05em;
}
.accreditation-badge .badge-desc {
	font-size: var(--font-size-xs);
	color: var(--color-text-muted);
	text-align: center;
}

/* ============================================================
   CTA BANNER
   ============================================================ */
.cta-banner {
	background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-secondary) 100%);
	padding: var(--spacing-16) 0;
	position: relative;
	overflow: hidden;
	text-align: center;
}
.cta-banner::before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(circle at 50% 50%, rgba(230,51,41,.15) 0%, transparent 60%);
}
.cta-banner__content { position: relative; z-index: 1; }
.cta-banner h2 {
	color: var(--color-white);
	font-size: clamp(var(--font-size-2xl), 4vw, var(--font-size-4xl));
	margin-bottom: var(--spacing-4);
}
.cta-banner p {
	color: rgba(255,255,255,.8);
	font-size: var(--font-size-lg);
	max-width: 600px;
	margin: 0 auto var(--spacing-8);
}
.cta-banner .btn-group {
	display: flex;
	gap: var(--spacing-4);
	justify-content: center;
	flex-wrap: wrap;
}

/* ============================================================
   CONTACT FORM
   ============================================================ */
.contact-section {
	display: grid;
	grid-template-columns: 1fr 1.5fr;
	gap: var(--spacing-12);
	align-items: start;
}
.contact-info { display: flex; flex-direction: column; }
.contact-info h2 {
	font-size: var(--font-size-2xl);
	margin-bottom: var(--spacing-6);
}
.contact-detail {
	display: flex;
	align-items: flex-start;
	gap: var(--spacing-4);
	margin-bottom: var(--spacing-6);
}
.contact-detail__icon {
	width: 44px;
	height: 44px;
	background: rgba(230,51,41,.1);
	border-radius: var(--radius-md);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 20px;
	flex-shrink: 0;
}
.contact-detail__text { display: flex; flex-direction: column; gap: 0.25rem; }
.contact-detail__text .label {
	font-size: var(--font-size-xs);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: var(--color-accent);
	margin-bottom: var(--spacing-1);
}
.contact-detail__text .value {
	font-size: var(--font-size-base);
	color: var(--color-text);
	font-weight: 500;
}
.contact-detail__text a {
	color: var(--color-text);
	text-decoration: none;
}
.contact-detail__text a:hover { color: var(--color-accent); }

.contact-form-wrap {
	background: var(--color-white);
	border-radius: var(--radius-xl);
	padding: var(--spacing-8);
	box-shadow: var(--shadow-xl);
	border: 1px solid var(--color-border);
}
.form-group {
	margin-bottom: var(--spacing-5);
}
.form-group label {
	display: block;
	font-size: var(--font-size-sm);
	font-weight: 600;
	color: var(--color-primary);
	margin-bottom: var(--spacing-2);
}
.form-group label .required { color: var(--color-accent); margin-left: 2px; }
.form-control {
	width: 100%;
	padding: 0.75rem 1rem;
	border: 2px solid var(--color-border);
	border-radius: var(--radius-md);
	background: var(--color-white);
	color: var(--color-text);
	font-size: var(--font-size-base);
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
	appearance: none;
}
.form-control:focus {
	outline: none;
	border-color: var(--color-accent);
	box-shadow: 0 0 0 3px rgba(230,51,41,.12);
}
.form-control::placeholder { color: var(--color-gray); }
textarea.form-control {
	resize: vertical;
	min-height: 120px;
}
.form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--spacing-4);
}
.form-notice {
	font-size: var(--font-size-xs);
	color: var(--color-text-muted);
	margin-top: var(--spacing-4);
}
.form-message {
	padding: var(--spacing-4);
	border-radius: var(--radius-md);
	margin-top: var(--spacing-4);
	font-size: var(--font-size-sm);
	font-weight: 500;
	display: none;
}
.form-message.success {
	background: #d1fae5;
	color: #065f46;
	border: 1px solid #6ee7b7;
	display: block;
}
.form-message.error {
	background: #fee2e2;
	color: #991b1b;
	border: 1px solid #fca5a5;
	display: block;
}

/* ============================================================
   SITE FOOTER
   ============================================================ */
.site-footer {
	background: var(--color-primary);
	color: rgba(255,255,255,.75);
}
.footer-top {
	padding: var(--spacing-16) 0 var(--spacing-12);
	border-bottom: 1px solid rgba(255,255,255,.08);
}
.footer-grid {
	display: grid;
	grid-template-columns: 1.5fr 1fr 1fr 1fr;
	gap: var(--spacing-8);
}
.footer-col { display: flex; flex-direction: column; }
.footer-col h4 {
	font-family: var(--font-heading);
	font-size: var(--font-size-sm);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .1em;
	color: var(--color-white);
	margin-bottom: var(--spacing-5);
	padding-bottom: var(--spacing-3);
	border-bottom: 2px solid var(--color-accent);
	display: inline-block;
}
.footer-col p {
	font-size: var(--font-size-sm);
	line-height: var(--line-height-loose);
	margin-bottom: var(--spacing-4);
	color: rgba(255,255,255,.65);
}
.footer-col ul { list-style: none; }
.footer-col ul li { margin-bottom: var(--spacing-2); }
.footer-col ul li a {
	color: rgba(255,255,255,.65);
	font-size: var(--font-size-sm);
	text-decoration: none;
	transition: color var(--transition-fast);
	display: inline-flex;
	align-items: center;
	gap: var(--spacing-2);
}
.footer-col ul li a::before {
	content: '→';
	color: var(--color-accent);
	font-size: var(--font-size-xs);
	transition: transform var(--transition-fast);
}
.footer-col ul li a:hover { color: var(--color-white); }
.footer-col ul li a:hover::before { transform: translateX(2px); }

.footer-contact-item {
	display: flex;
	align-items: flex-start;
	gap: var(--spacing-3);
	margin-bottom: var(--spacing-4);
}
.footer-contact-item .icon {
	font-size: 16px;
	margin-top: 2px;
	flex-shrink: 0;
	color: var(--color-accent);
}
.footer-contact-item .text {
	font-size: var(--font-size-sm);
	color: rgba(255,255,255,.65);
	line-height: var(--line-height-snug);
}
.footer-contact-item .text a {
	color: rgba(255,255,255,.65);
	text-decoration: none;
	transition: color var(--transition-fast);
}
.footer-contact-item .text a:hover { color: var(--color-accent); }

.footer-bottom {
	padding: var(--spacing-6) 0;
}
.footer-bottom-inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--spacing-4);
}
.footer-bottom-inner .copyright {
	font-size: var(--font-size-xs);
	color: rgba(255,255,255,.45);
}
.footer-bottom-inner .legal-links {
	display: flex;
	gap: var(--spacing-4);
}
.footer-bottom-inner .legal-links a {
	font-size: var(--font-size-xs);
	color: rgba(255,255,255,.45);
	text-decoration: none;
	transition: color var(--transition-fast);
}
.footer-bottom-inner .legal-links a:hover { color: rgba(255,255,255,.8); }
.footer-reg {
	font-size: var(--font-size-xs);
	color: rgba(255,255,255,.3);
	text-align: center;
	padding-top: var(--spacing-3);
	border-top: 1px solid rgba(255,255,255,.05);
}

/* ============================================================
   LISTS & CONTENT STYLES
   ============================================================ */
.check-list {
	list-style: none;
	padding: 0;
}
.check-list li {
	display: flex;
	align-items: flex-start;
	gap: var(--spacing-3);
	margin-bottom: var(--spacing-3);
	font-size: var(--font-size-base);
	color: var(--color-text);
}
.check-list li::before {
	content: '✓';
	display: flex;
	align-items: center;
	justify-content: center;
	width: 20px;
	height: 20px;
	background: rgba(230,51,41,.1);
	color: var(--color-accent);
	border-radius: 50%;
	font-size: 11px;
	font-weight: 700;
	flex-shrink: 0;
	margin-top: 2px;
}

.tag {
	display: inline-block;
	padding: var(--spacing-1) var(--spacing-3);
	background: var(--color-light-gray);
	border-radius: var(--radius-full);
	font-size: var(--font-size-xs);
	font-weight: 600;
	color: var(--color-secondary);
}
.tag--accent {
	background: rgba(230,51,41,.1);
	color: var(--color-accent);
}

/* ============================================================
   PAGE CONTENT AREA
   ============================================================ */
.main-content {
	margin-top: var(--header-height);
	min-height: 60vh;
}
.entry-content {
	max-width: var(--container-md);
	margin-inline: auto;
}
.entry-content h1, .entry-content h2, .entry-content h3 { margin-bottom: var(--spacing-4); }
.entry-content p { margin-bottom: var(--spacing-4); }
.entry-content ul, .entry-content ol {
	padding-left: var(--spacing-6);
	margin-bottom: var(--spacing-4);
}
.entry-content ul { list-style: disc; }
.entry-content ol { list-style: decimal; }
.entry-content li { margin-bottom: var(--spacing-2); }
.entry-content blockquote {
	border-left: 4px solid var(--color-accent);
	padding: var(--spacing-4) var(--spacing-6);
	background: var(--color-light-gray);
	border-radius: 0 var(--radius-md) var(--radius-md) 0;
	margin: var(--spacing-6) 0;
	font-style: italic;
}

/* ============================================================
   404 PAGE
   ============================================================ */
.error-page {
	min-height: 60vh;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: var(--spacing-20) var(--spacing-6);
}
.error-page .error-code {
	font-family: var(--font-heading);
	font-size: 120px;
	font-weight: 900;
	color: var(--color-accent);
	line-height: 1;
	opacity: .15;
	position: absolute;
}
.error-page__content { position: relative; z-index: 1; }
.error-page h1 { margin-bottom: var(--spacing-4); }
.error-page p { margin-bottom: var(--spacing-6); }

/* ============================================================
   UTILITY CLASSES
   ============================================================ */
.visually-hidden {
	position: absolute !important;
	width: 1px !important;
	height: 1px !important;
	padding: 0 !important;
	margin: -1px !important;
	overflow: hidden !important;
	clip: rect(0,0,0,0) !important;
	white-space: nowrap !important;
	border: 0 !important;
}
.mt-0  { margin-top: 0; }
.mt-4  { margin-top: var(--spacing-4); }
.mt-8  { margin-top: var(--spacing-8); }
.mt-12 { margin-top: var(--spacing-12); }
.mb-0  { margin-bottom: 0; }
.mb-4  { margin-bottom: var(--spacing-4); }
.mb-6  { margin-bottom: var(--spacing-6); }
.mb-8  { margin-bottom: var(--spacing-8); }
.text-accent  { color: var(--color-accent) !important; }
.text-muted   { color: var(--color-text-muted) !important; }
.text-white   { color: var(--color-white) !important; }
.bg-dark      { background-color: var(--color-primary); }
.bg-gray      { background-color: var(--color-light-gray); }
.font-bold    { font-weight: 700; }
.font-heading { font-family: var(--font-heading); }
.rounded      { border-radius: var(--radius-md); }
.shadow       { box-shadow: var(--shadow-md); }
.hidden       { display: none !important; }

/* Scroll animation classes */
.fade-in {
	opacity: 0;
	transform: translateY(24px);
	transition: opacity 0.6s ease, transform 0.6s ease;
}
.fade-in.visible {
	opacity: 1;
	transform: translateY(0);
}
.fade-in-delay-1 { transition-delay: 0.1s; }
.fade-in-delay-2 { transition-delay: 0.2s; }
.fade-in-delay-3 { transition-delay: 0.3s; }
.fade-in-delay-4 { transition-delay: 0.4s; }

/* ============================================================
   SERVICE ADVERTS — card grid (kept for price-guide page)
   ============================================================ */
.adverts-section { background: var(--color-light-gray); }

/* FooGallery section — centred shortcode output */
.foogallery-section .foogallery-section__content {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}
.foogallery-section .foogallery-section__content .foogallery-container,
.foogallery-section .foogallery-section__content > * {
	max-width: 100%;
	margin-left: auto;
	margin-right: auto;
}

.adverts-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: var(--spacing-6);
}

.advert-card {
	position: relative;
	background: var(--color-white);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-md);
	overflow: hidden;
	transition: transform var(--transition-normal), box-shadow var(--transition-normal);
}
.advert-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-xl);
}

.advert-card__badge {
	position: absolute;
	top: var(--spacing-3);
	left: var(--spacing-3);
	background: var(--color-accent);
	color: var(--color-white);
	font-size: var(--font-size-xs);
	font-weight: 700;
	font-family: var(--font-heading);
	text-transform: uppercase;
	letter-spacing: .06em;
	padding: .2rem .65rem;
	border-radius: var(--radius-full);
	z-index: 2;
	pointer-events: none;
}

.advert-card__image {
	position: relative;
	overflow: hidden;
	background: var(--color-light-gray);
	aspect-ratio: 1 / 1;
}
.advert-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform var(--transition-slow);
}
.advert-card:hover .advert-card__image img {
	transform: scale(1.04);
}
.advert-card__image a {
	display: block;
	width: 100%;
	height: 100%;
	position: relative;
}
.advert-card__zoom {
	position: absolute;
	bottom: var(--spacing-3);
	right: var(--spacing-3);
	background: rgba(0,0,0,.55);
	color: #fff;
	width: 36px;
	height: 36px;
	border-radius: var(--radius-full);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1rem;
	opacity: 0;
	transition: opacity var(--transition-fast);
}
.advert-card:hover .advert-card__zoom { opacity: 1; }

.advert-card__image--placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 3rem;
}

.advert-card__body {
	padding: var(--spacing-4) var(--spacing-5);
}
.advert-card__title {
	font-size: var(--font-size-base);
	font-weight: 700;
	line-height: var(--line-height-snug);
	margin-bottom: var(--spacing-2);
	color: var(--color-text);
}
.advert-card__desc {
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	line-height: var(--line-height-normal);
	margin-bottom: var(--spacing-3);
}
.advert-card__price {
	display: inline-block;
	background: var(--color-accent);
	color: var(--color-white);
	font-family: var(--font-heading);
	font-size: var(--font-size-sm);
	font-weight: 700;
	padding: .25rem .75rem;
	border-radius: var(--radius-full);
}

.advert-empty-hint {
	text-align: center;
	padding: var(--spacing-12) var(--spacing-8);
	color: var(--color-text-muted);
	font-size: var(--font-size-sm);
	border: 2px dashed var(--color-border);
	border-radius: var(--radius-lg);
}
.advert-empty-hint a { color: var(--color-accent); }

/* ============================================================
   GALLERY PAGE
   ============================================================ */
.ktech-gallery-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: var(--spacing-4);
}

.ktech-gallery-item {
	position: relative;
	overflow: hidden;
	border-radius: var(--radius-lg);
	background: var(--color-primary);
	aspect-ratio: 4 / 3;
	cursor: pointer;
	margin: 0;
}
.ktech-gallery-item a {
	display: block;
	width: 100%;
	height: 100%;
	position: relative;
}
.ktech-gallery-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform var(--transition-slow), filter var(--transition-normal);
}
.ktech-gallery-item:hover img {
	transform: scale(1.06);
	filter: brightness(.85);
}

.gallery-item__overlay {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: var(--spacing-2);
	background: rgba(0,0,0,.5);
	opacity: 0;
	transition: opacity var(--transition-normal);
	padding: var(--spacing-4);
}
.ktech-gallery-item:hover .gallery-item__overlay { opacity: 1; }

.gallery-item__icon {
	font-size: 2rem;
	display: block;
}
.gallery-item__caption {
	color: #fff;
	font-size: var(--font-size-sm);
	font-weight: 600;
	text-align: center;
	line-height: var(--line-height-snug);
}

.gallery-empty-hint {
	text-align: center;
	padding: var(--spacing-12) var(--spacing-8);
	color: var(--color-text-muted);
	font-size: var(--font-size-sm);
	border: 2px dashed var(--color-border);
	border-radius: var(--radius-lg);
}
.gallery-empty-hint a { color: var(--color-accent); }

.ktech-plugin-gallery-output { margin-top: var(--spacing-6); }

/* Admin hint bar (logged-in only) */
.admin-gallery-hint {
	background: #f0f6fc;
	border-bottom: 1px solid #c6d9ee;
	padding: var(--spacing-3) 0;
}
.admin-hint-inner {
	display: flex;
	align-items: flex-start;
	gap: var(--spacing-3);
	font-size: var(--font-size-sm);
	color: #1d4ed8;
}
.admin-hint-icon { font-size: 1.25rem; flex-shrink: 0; }
.admin-hint-inner a { color: #1d4ed8; font-weight: 600; }
.admin-hint-inner code { background: rgba(0,0,0,.06); padding: .1rem .35rem; border-radius: 3px; font-size: .8rem; }

/* ============================================================
   LIGHTBOX
   ============================================================ */
.ktech-lightbox {
	position: fixed;
	inset: 0;
	z-index: 9999;
	background: rgba(0,0,0,.92);
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	pointer-events: none;
	transition: opacity var(--transition-normal);
}
.ktech-lightbox.is-open {
	opacity: 1;
	pointer-events: all;
}
.ktech-lightbox__inner {
	position: relative;
	max-width: 92vw;
	max-height: 90vh;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--spacing-3);
}
.ktech-lightbox__image {
	max-width: 100%;
	max-height: 82vh;
	object-fit: contain;
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-xl);
	display: block;
}
.ktech-lightbox__caption {
	color: rgba(255,255,255,.8);
	font-size: var(--font-size-sm);
	text-align: center;
	max-width: 600px;
	margin: 0;
}
.ktech-lightbox__close {
	position: fixed;
	top: var(--spacing-5);
	right: var(--spacing-5);
	background: rgba(255,255,255,.15);
	border: none;
	color: #fff;
	font-size: 1.25rem;
	width: 44px;
	height: 44px;
	border-radius: var(--radius-full);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background var(--transition-fast);
	z-index: 10000;
}
.ktech-lightbox__close:hover { background: var(--color-accent); }
.ktech-lightbox__prev,
.ktech-lightbox__next {
	position: fixed;
	top: 50%;
	transform: translateY(-50%);
	background: rgba(255,255,255,.15);
	border: none;
	color: #fff;
	font-size: 1.5rem;
	width: 48px;
	height: 48px;
	border-radius: var(--radius-full);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background var(--transition-fast);
	z-index: 10000;
}
.ktech-lightbox__prev { left: var(--spacing-5); }
.ktech-lightbox__next { right: var(--spacing-5); }
.ktech-lightbox__prev:hover,
.ktech-lightbox__next:hover { background: var(--color-accent); }

/* ============================================================
   RESPONSIVE — TABLET (max-width: 1024px)
   ============================================================ */
@media (max-width: 1024px) {
	:root { --header-height: 64px; }

	.grid--4 { grid-template-columns: repeat(2, 1fr); }
	.footer-grid { grid-template-columns: 1fr 1fr; gap: var(--spacing-8); }
	.contact-section { grid-template-columns: 1fr; gap: var(--spacing-8); }

	.primary-nav { display: none; }
	.hamburger-btn { display: flex; }
	.nav-cta { display: none; }

	.hero { min-height: 75vh; }
	.hero__stats { gap: var(--spacing-6); }
}

/* ============================================================
   RESPONSIVE — MOBILE (max-width: 768px)
   ============================================================ */
@media (max-width: 768px) {
	:root {
		--header-height: 60px;
		--spacing-20: 3.5rem;
		--spacing-16: 3rem;
		--spacing-12: 2.5rem;
	}

	.container { padding-inline: var(--spacing-4); }

	.grid--2,
	.grid--3,
	.grid--4 { grid-template-columns: 1fr; }

	.grid--auto { grid-template-columns: 1fr; }

	.footer-grid { grid-template-columns: 1fr; gap: var(--spacing-6); }

	.footer-bottom-inner {
		flex-direction: column;
		text-align: center;
	}

	.hero { min-height: 100svh; }
	.hero h1 { font-size: clamp(1.75rem, 8vw, 2.25rem); }
	.hero p { font-size: var(--font-size-base); }
	.hero__actions { flex-direction: column; }
	.hero__actions .btn { width: 100%; justify-content: center; }
	.hero__stats { gap: var(--spacing-5); }
	.hero__stat .stat-number { font-size: var(--font-size-2xl); }

	.page-hero { padding: var(--spacing-16) 0 var(--spacing-12); }

	.form-row { grid-template-columns: 1fr; }
	.contact-form-wrap { padding: var(--spacing-6); }

	.cta-banner .btn-group { flex-direction: column; align-items: center; }
	.cta-banner .btn-group .btn { width: 100%; max-width: 320px; justify-content: center; }

	.logo-text .logo-sub { display: none; }

	.accreditations-strip .flex { flex-wrap: wrap; justify-content: center; }

	.pricing-row {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--spacing-1);
	}
	.pricing-row .item-price { margin-left: 0; }
}

@media (max-width: 480px) {
	h1 { font-size: clamp(1.5rem, 6vw, 2rem); }
	h2 { font-size: clamp(1.25rem, 5vw, 1.75rem); }

	.btn--lg { padding: 0.875rem 1.75rem; font-size: var(--font-size-base); }
	.section { padding-block: var(--spacing-12); }
}
