@charset "UTF-8";

/* KIM Theme System: Light, Dark, High Contrast, Frosted */
/* Design goals: small, self-contained, CSS variables based, no dependencies */

/* Base tokens */
  :root {
	--kim-font-sans: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
	--kim-radius-xs: 2px;
	--kim-radius-sm: 4px;
	--kim-radius-md: 8px;
	--kim-radius-lg: 12px;
	--kim-gap-xs: 4px;
	--kim-gap-sm: 8px;
	--kim-gap-md: 12px;
	--kim-gap-lg: 16px;
	--kim-gap-xl: 24px;
	--kim-shadow-sm: 0 1px 2px rgba(0,0,0,.08);
	--kim-shadow-md: 0 4px 12px rgba(0,0,0,.12);
	--kim-shadow-lg: 0 12px 32px rgba(0,0,0,.16);
	--kim-header-height: 60px; /* Sticky header height */
	/* alias tokens */
	--kim-secondary: #6b7280;
	--kim-light: #f3f4f6;
	--kim-dark: #111827;

	/* THEME PARAMETERS (defaults = light) */
	--kim-bg-h: 0; --kim-bg-s: 0%; --kim-bg-l: 100%; --kim-bg-a: 1;
	--kim-bgsoft-h: 215; --kim-bgsoft-s: 14%; --kim-bgsoft-l: 97%; --kim-bgsoft-a: 1;
	--kim-surface-h: 0; --kim-surface-s: 0%; --kim-surface-l: 100%; --kim-surface-a: 1;
	--kim-surfacealt-h: 215; --kim-surfacealt-s: 12%; --kim-surfacealt-l: 96%; --kim-surfacealt-a: 1;
	--kim-text-h: 215; --kim-text-s: 28%; --kim-text-l: 24%;
	--kim-textmuted-h: 220; --kim-textmuted-s: 9%; --kim-textmuted-l: 46%;
	--kim-border-h: 215; --kim-border-s: 20%; --kim-border-l: 91%;
	--kim-primary-h: 221; --kim-primary-s: 83%; --kim-primary-l: 56%;
	--kim-primary-contrast: #ffffff;
	--kim-accent-h: 166; --kim-accent-s: 79%; --kim-accent-l: 42%;
	--kim-danger-h: 0; --kim-danger-s: 84%; --kim-danger-l: 63%;
	--kim-warning-h: 36; --kim-warning-s: 92%; --kim-warning-l: 52%;
	--kim-info-h: 199; --kim-info-s: 86%; --kim-info-l: 49%;

	/* DERIVED TOKENS */
	--kim-bg: hsl(var(--kim-bg-h) var(--kim-bg-s) var(--kim-bg-l) / var(--kim-bg-a, 1));
	--kim-bg-soft: hsl(var(--kim-bgsoft-h) var(--kim-bgsoft-s) var(--kim-bgsoft-l) / var(--kim-bgsoft-a, 1));
	--kim-surface: hsl(var(--kim-surface-h) var(--kim-surface-s) var(--kim-surface-l) / var(--kim-surface-a, 1));
	--kim-surface-rgb: var(--kim-surface-rgb-h, 255), var(--kim-surface-rgb-s, 255), var(--kim-surface-rgb-l, 255);
	--kim-surface-alt: hsl(var(--kim-surfacealt-h) var(--kim-surfacealt-s) var(--kim-surfacealt-l) / var(--kim-surfacealt-a, 1));
	--kim-text: hsl(var(--kim-text-h) var(--kim-text-s) var(--kim-text-l));
	--kim-textmuted: hsl(var(--kim-textmuted-h) var(--kim-textmuted-s) var(--kim-textmuted-l));
	--kim-border: hsl(var(--kim-border-h) var(--kim-border-s) var(--kim-border-l));
	--kim-primary: hsl(var(--kim-primary-h) var(--kim-primary-s) var(--kim-primary-l));
	--kim-accent: hsl(var(--kim-accent-h) var(--kim-accent-s) var(--kim-accent-l));
	--kim-danger: hsl(var(--kim-danger-h) var(--kim-danger-s) var(--kim-danger-l));
	--kim-warning: hsl(var(--kim-warning-h) var(--kim-warning-s) var(--kim-warning-l));
	--kim-info: hsl(var(--kim-info-h) var(--kim-info-s) var(--kim-info-l));
}

/* Theme overrides set only the PARAMETERS; derived tokens update automatically */

:root[data-theme="light"] {
	--kim-bg-h: 0; --kim-bg-s: 0%; --kim-bg-l: 100%;
	--kim-bgsoft-h: 0; --kim-bgsoft-s: 0%; --kim-bgsoft-l: 98%;
	--kim-surface-h: 0; --kim-surface-s: 0%; --kim-surface-l: 100%;
	--kim-surface-rgb-h: 255; --kim-surface-rgb-s: 255; --kim-surface-rgb-l: 255;
	--kim-surfacealt-h: 0; --kim-surfacealt-s: 0%; --kim-surfacealt-l: 98%;
	--kim-text-h: 0; --kim-text-s: 0%; --kim-text-l: 20%;
	--kim-textmuted-h: 0; --kim-textmuted-s: 0%; --kim-textmuted-l: 45%;
	--kim-border-h: 0; --kim-border-s: 0%; --kim-border-l: 90%;
	--kim-primary-h: 217; --kim-primary-s: 91%; --kim-primary-l: 60%;
	--kim-primary-contrast: #ffffff;
	--kim-accent-h: 158; --kim-accent-s: 64%; --kim-accent-l: 52%;
	--kim-danger-h: 0; --kim-danger-s: 90%; --kim-danger-l: 71%;
	--kim-warning-h: 45; --kim-warning-s: 97%; --kim-warning-l: 55%;
	--kim-info-h: 199; --kim-info-s: 93%; --kim-info-l: 61%;
}

:root[data-theme="dark"] {
	--kim-bg-h: 215; --kim-bg-s: 33%; --kim-bg-l: 6%;
	--kim-bgsoft-h: 210; --kim-bgsoft-s: 30%; --kim-bgsoft-l: 8%;
	--kim-surface-h: 215; --kim-surface-s: 33%; --kim-surface-l: 9%;
	--kim-surface-rgb-h: 23; --kim-surface-rgb-s: 23; --kim-surface-rgb-l: 23;
	--kim-surfacealt-h: 215; --kim-surfacealt-s: 31%; --kim-surfacealt-l: 12%;
	--kim-text-h: 220; --kim-text-s: 14%; --kim-text-l: 91%;
	--kim-textmuted-h: 220; --kim-textmuted-s: 9%; --kim-textmuted-l: 66%;
	--kim-border-h: 215; --kim-border-s: 28%; --kim-border-l: 18%;
	--kim-primary-h: 217; --kim-primary-s: 91%; --kim-primary-l: 60%;
	--kim-primary-contrast: #0b0f14;
	--kim-accent-h: 158; --kim-accent-s: 64%; --kim-accent-l: 52%;
	--kim-danger-h: 0; --kim-danger-s: 90%; --kim-danger-l: 71%;
	--kim-warning-h: 45; --kim-warning-s: 97%; --kim-warning-l: 55%;
	--kim-info-h: 199; --kim-info-s: 93%; --kim-info-l: 61%;
}

:root[data-theme="contrast"] {
	--kim-bg-h: 0; --kim-bg-s: 0%; --kim-bg-l: 0%;
	--kim-bgsoft-h: 0; --kim-bgsoft-s: 0%; --kim-bgsoft-l: 0%;
	--kim-surface-h: 0; --kim-surface-s: 0%; --kim-surface-l: 0%;
	--kim-surface-rgb-h: 0; --kim-surface-rgb-s: 0; --kim-surface-rgb-l: 0;
	--kim-surfacealt-h: 0; --kim-surfacealt-s: 0%; --kim-surfacealt-l: 0%;
	--kim-text-h: 0; --kim-text-s: 0%; --kim-text-l: 100%;
	--kim-textmuted-h: 210; --kim-textmuted-s: 20%; --kim-textmuted-l: 83%;
	--kim-border-h: 0; --kim-border-s: 0%; --kim-border-l: 100%;
	--kim-primary-h: 180; --kim-primary-s: 100%; --kim-primary-l: 50%;
	--kim-primary-contrast: #000000;
	--kim-accent-h: 60; --kim-accent-s: 100%; --kim-accent-l: 50%;
	--kim-danger-h: 0; --kim-danger-s: 100%; --kim-danger-l: 52%;
	--kim-warning-h: 30; --kim-warning-s: 100%; --kim-warning-l: 60%;
	--kim-info-h: 215; --kim-info-s: 100%; --kim-info-l: 70%;
}

/* High contrast specific card styling */
:root[data-theme="contrast"] .card {
	border: 2px solid #ffffff;
	border-radius: 8px;
	box-shadow: 0 0 0 1px #ffffff, 0 4px 12px rgba(255, 255, 255, 0.2);
	background: #000000;
}

:root[data-theme="contrast"] .card-header {
	border-bottom: 2px solid #ffffff;
	background: #333333;
	border-top-left-radius: 6px;
	border-top-right-radius: 6px;
}

:root[data-theme="contrast"] .card-body {
	background: #000000;
	padding: 20px;
}

/* Frosted builds on light but adjusts alpha */
:root[data-theme="frosted"] {
	--kim-bg-h: 216; --kim-bg-s: 46%; --kim-bg-l: 93%;
	--kim-bgsoft-a: .35; --kim-surface-a: .55; --kim-surfacealt-a: .35;
	--kim-surface-rgb-h: 255; --kim-surface-rgb-s: 255; --kim-surface-rgb-l: 255;
	--kim-text-h: 222; --kim-text-s: 52%; --kim-text-l: 16%;
	--kim-textmuted-h: 215; --kim-textmuted-s: 28%; --kim-textmuted-l: 32%;
	--kim-border-h: 215; --kim-border-s: 35%; --kim-border-l: 18%;
}

/* Frosted glass body background */
:root[data-theme="frosted"] body {
	background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
	background-attachment: fixed;
}

/* ======================================== */
/* THEME-SPECIFIC SCROLLBAR STYLES         */
/* ======================================== */

/* Light Theme Scrollbars */
:root[data-theme="light"] {
	/* Webkit browsers (Chrome, Safari, Edge) */
	--scrollbar-track: #f1f5f9;
	--scrollbar-thumb: #cbd5e1;
	--scrollbar-thumb-hover: #94a3b8;
	--scrollbar-thumb-active: #64748b;
	--scrollbar-width: 12px;
	--scrollbar-radius: 6px;
}

/* Dark Theme Scrollbars */
:root[data-theme="dark"] {
	--scrollbar-track: #1e293b;
	--scrollbar-thumb: #475569;
	--scrollbar-thumb-hover: #64748b;
	--scrollbar-thumb-active: #94a3b8;
	--scrollbar-width: 12px;
	--scrollbar-radius: 6px;
}

/* High Contrast Theme Scrollbars */
:root[data-theme="contrast"] {
	--scrollbar-track: #000000;
	--scrollbar-thumb: #ffffff;
	--scrollbar-thumb-hover: #cccccc;
	--scrollbar-thumb-active: #999999;
	--scrollbar-width: 16px;
	--scrollbar-radius: 8px;
}

/* Frosted Glass Theme Scrollbars */
:root[data-theme="frosted"] {
	--scrollbar-track: rgba(255, 255, 255, 0.1);
	--scrollbar-thumb: rgba(255, 255, 255, 0.3);
	--scrollbar-thumb-hover: rgba(255, 255, 255, 0.5);
	--scrollbar-thumb-active: rgba(255, 255, 255, 0.7);
	--scrollbar-width: 10px;
	--scrollbar-radius: 5px;
}

/* Global Scrollbar Styling */
::-webkit-scrollbar {
	width: var(--scrollbar-width);
	height: var(--scrollbar-width);
}

::-webkit-scrollbar-track {
	background: var(--scrollbar-track);
	border-radius: var(--scrollbar-radius);
}

::-webkit-scrollbar-thumb {
	background: var(--scrollbar-thumb);
	border-radius: var(--scrollbar-radius);
	border: 2px solid var(--scrollbar-track);
	transition: background 0.2s ease;
}

::-webkit-scrollbar-thumb:hover {
	background: var(--scrollbar-thumb-hover);
}

::-webkit-scrollbar-thumb:active {
	background: var(--scrollbar-thumb-active);
}

::-webkit-scrollbar-corner {
	background: var(--scrollbar-track);
}

/* Firefox Scrollbar Styling */
* {
	scrollbar-width: thin;
	scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
}

/* Custom scrollbar for specific elements */
.custom-scrollbar {
	scrollbar-width: thin;
	scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
}

.custom-scrollbar::-webkit-scrollbar {
	width: var(--scrollbar-width);
	height: var(--scrollbar-width);
}

.custom-scrollbar::-webkit-scrollbar-track {
	background: var(--scrollbar-track);
	border-radius: var(--scrollbar-radius);
}

.custom-scrollbar::-webkit-scrollbar-thumb {
	background: var(--scrollbar-thumb);
	border-radius: var(--scrollbar-radius);
	border: 2px solid var(--scrollbar-track);
	transition: background 0.2s ease;
}

.custom-scrollbar::-webkit-scrollbar-thumb:hover {
	background: var(--scrollbar-thumb-hover);
}

.custom-scrollbar::-webkit-scrollbar-thumb:active {
	background: var(--scrollbar-thumb-active);
}

/* Thin scrollbars for compact elements */
.thin-scrollbar {
	--scrollbar-width: 8px;
	--scrollbar-radius: 4px;
}

/* Thick scrollbars for prominent elements */
.thick-scrollbar {
	--scrollbar-width: 16px;
	--scrollbar-radius: 8px;
}

/* Rounded scrollbars for modern look */
.rounded-scrollbar {
	--scrollbar-radius: 999px;
}

/* Square scrollbars for minimal look */
.square-scrollbar {
	--scrollbar-radius: 0px;
}

/* Component-specific scrollbar overrides */
.sidebar {
	scrollbar-width: thin;
	scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
}

.sidebar::-webkit-scrollbar {
	width: 8px;
	height: 8px;
}

.sidebar::-webkit-scrollbar-track {
	background: transparent;
}

.sidebar::-webkit-scrollbar-thumb {
	background: var(--scrollbar-thumb);
	border-radius: 4px;
	border: 1px solid transparent;
}

.sidebar::-webkit-scrollbar-thumb:hover {
	background: var(--scrollbar-thumb-hover);
}

/* Code blocks and text areas */
pre, code, textarea {
	scrollbar-width: thin;
	scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
}

pre::-webkit-scrollbar, code::-webkit-scrollbar, textarea::-webkit-scrollbar {
	width: 8px;
	height: 8px;
}

pre::-webkit-scrollbar-track, code::-webkit-scrollbar-track, textarea::-webkit-scrollbar-track {
	background: var(--scrollbar-track);
	border-radius: 4px;
}

pre::-webkit-scrollbar-thumb, code::-webkit-scrollbar-thumb, textarea::-webkit-scrollbar-thumb {
	background: var(--scrollbar-thumb);
	border-radius: 4px;
	border: 1px solid var(--scrollbar-track);
}

pre::-webkit-scrollbar-thumb:hover, code::-webkit-scrollbar-thumb:hover, textarea::-webkit-scrollbar-thumb:hover {
	background: var(--scrollbar-thumb-hover);
}

/* Modal and overlay scrollbars */
.modal-body, .offcanvas-body {
	scrollbar-width: thin;
	scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
}

.modal-body::-webkit-scrollbar, .offcanvas-body::-webkit-scrollbar {
	width: 8px;
	height: 8px;
}

.modal-body::-webkit-scrollbar-track, .offcanvas-body::-webkit-scrollbar-track {
	background: var(--scrollbar-track);
	border-radius: 4px;
}

.modal-body::-webkit-scrollbar-thumb, .offcanvas-body::-webkit-scrollbar-thumb {
	background: var(--scrollbar-thumb);
	border-radius: 4px;
	border: 1px solid var(--scrollbar-track);
}

.modal-body::-webkit-scrollbar-thumb:hover, .offcanvas-body::-webkit-scrollbar-thumb:hover {
	background: var(--scrollbar-thumb-hover);
}

/* Table scrollbars */
.table-responsive {
	scrollbar-width: thin;
	scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
}

.table-responsive::-webkit-scrollbar {
	width: 8px;
	height: 8px;
}

.table-responsive::-webkit-scrollbar-track {
	background: var(--scrollbar-track);
	border-radius: 4px;
}

.table-responsive::-webkit-scrollbar-thumb {
	background: var(--scrollbar-thumb);
	border-radius: 4px;
	border: 1px solid var(--scrollbar-track);
}

.table-responsive::-webkit-scrollbar-thumb:hover {
	background: var(--scrollbar-thumb-hover);
}

/* Global base */
*, *::before, *::after { box-sizing: border-box; }
html { 
  -webkit-text-size-adjust: 100%; 
  height: 100%;
  overflow: hidden !important; /* Force prevent html scrolling */
}
body {
  margin: 0;
	font-family: var(--kim-font-sans);
  line-height: 1.5;
	color: var(--kim-text);
	background: var(--kim-bg);
  height: 100%;
  min-height: 100vh;
  overflow: hidden !important; /* Force prevent body scrolling */
  position: fixed; /* Lock body in place */
  width: 100%;
  top: 0;
  left: 0;
}

/* Allow scrolling only on main content */
.main-content,
.docs-main-content,
.full-height-content {
  overflow-y: auto !important;
  overflow-x: hidden !important;
  /* Ensure proper scrolling behavior */
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
  /* Debug: ensure content is visible */
  position: relative;
  z-index: 1;
  /* Make content stretch to fill available height */
  display: flex;
  flex-direction: column;
  min-height: 100%;
}

/* Ensure content inside main containers doesn't expand beyond bounds */
.main-content > *,
.docs-main-content > *,
.full-height-content > * {
  max-width: 100%;
  box-sizing: border-box;
}

/* Make the main content wrapper stretch to fill available height */
.main-content > .content-wrapper,
.docs-main-content > .content-wrapper,
.full-height-content > .content-wrapper {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0; /* Allow shrinking in flexbox */
}

/* Ensure the last content element stretches to fill remaining space */
.main-content > *:last-child,
.docs-main-content > *:last-child,
.full-height-content > *:last-child {
  flex: 1;
  min-height: 0; /* Allow shrinking in flexbox */
}

/* Force prevent scrolling on specific elements that shouldn't scroll */
html,
body,
.sidebar,
.docs-sidebar,
.sidebar-content,
.sidebar-content-icon-only,
.sidebar-content-with-sidebar,
.sidebar-content-full-width,
.main-layout,
.docs-layout,
.full-height-layout,
.full-height-sidebar {
  overflow: hidden !important;
}

/* Force prevent scrolling on all other elements */
.sidebar,
.docs-sidebar,
.sidebar-content,
.sidebar-content-icon-only,
.sidebar-content-with-sidebar,
.sidebar-content-full-width,
.main-layout,
.docs-layout,
.full-height-layout,
.full-height-sidebar {
  overflow: hidden !important;
}

/* Main layout container */
.main-layout {
  display: flex;
  height: 100vh;
  min-height: 100vh;
  overflow: hidden; /* Prevent container scrolling */
}

/* Main content area */
.main-content {
  flex: 1;
  height: calc(100vh - var(--kim-header-height)); /* Account for sticky header */
  max-height: calc(100vh - var(--kim-header-height)); /* Strict height constraint */
  overflow-y: auto !important;
  overflow-x: hidden !important;
  padding: 20px;
  /* This is the ONLY scrollable element */
  box-sizing: border-box; /* Include padding in height calculation */
  /* Stretch content to fill available height */
  display: flex;
  flex-direction: column;
}

/* Full height utility classes */
.h-100 { height: 100% !important; }
.h-100vh { height: 100vh !important; }
.min-h-100 { min-height: 100% !important; }
.min-h-100vh { min-height: 100vh !important; }

/* Full height layout utilities */
.full-height-layout {
  display: flex;
  height: 100vh;
  min-height: 100vh;
}

.full-height-content {
  flex: 1;
  height: calc(100vh - var(--kim-header-height)); /* Account for sticky header */
  max-height: calc(100vh - var(--kim-header-height)); /* Strict height constraint */
  overflow-y: auto !important; /* Only this scrolls */
  overflow-x: hidden !important;
  box-sizing: border-box; /* Include padding in height calculation */
  /* Stretch content to fill available height */
  display: flex;
  flex-direction: column;
}

.full-height-sidebar {
  height: 100vh;
  overflow: hidden; /* No scrolling */
}

/* Documentation layout specific styles */
.docs-layout {
  display: flex;
  height: 100vh;
  min-height: 100vh;
  overflow: hidden; /* Prevent container scrolling */
}

.docs-sidebar {
  width: 280px;
  height: 100vh;
  min-height: 100vh;
  overflow: hidden; /* No scrolling in sidebar */
  flex-shrink: 0;
  border-right: 1px solid var(--kim-border);
  background: var(--kim-surface);
}

.docs-main-content {
  flex: 1;
  height: calc(100vh - var(--kim-header-height)); /* Account for sticky header */
  max-height: calc(100vh - var(--kim-header-height)); /* Strict height constraint */
  overflow-y: auto !important;
  overflow-x: hidden !important;
  padding: 20px;
  background: var(--kim-bg);
  /* This is the ONLY scrollable element */
  box-sizing: border-box; /* Include padding in height calculation */
  /* Stretch content to fill available height */
  display: flex;
  flex-direction: column;
}

/* Ensure the main content area fills available space */
.docs-main-content .main-content {
  height: 100%;
  min-height: 100%;
  max-height: 100%;
  overflow: visible; /* Let parent handle scrolling */
}

/* Utilities */
.kim-container { width: 100%; margin-inline: auto; padding-inline: 16px; max-width: 1200px; }
.kim-row { display: flex; flex-wrap: wrap; gap: var(--kim-gap-md); }
.kim-col { flex: 1 1 0; min-width: 0; }
.kim-card {
	background: var(--kim-surface);
	border: 1px solid var(--kim-border);
	border-radius: var(--kim-radius-md);
	box-shadow: var(--kim-shadow-sm);
}
.kim-card-header { padding: 12px 16px; border-bottom: 1px solid var(--kim-border); font-weight: 600; }
.kim-card-body { padding: 16px; }

/* Buttons */
.kim-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 8px 14px;
	border-radius: var(--kim-radius-sm);
	border: 1px solid transparent;
	background: var(--kim-surface-alt);
	color: var(--kim-text);
  cursor: pointer;
	box-shadow: var(--kim-shadow-sm);
}
.kim-btn:hover { filter: brightness(0.98); }
.kim-btn:active { transform: translateY(1px); }
.kim-btn.primary { background: var(--kim-primary); color: var(--kim-primary-contrast); }
.kim-btn.outline { background: transparent; border-color: var(--kim-border); }

/* Form controls */
.kim-input, .kim-select, .kim-textarea {
  width: 100%;
	padding: 8px 10px;
	border-radius: var(--kim-radius-sm);
	border: 1px solid var(--kim-border);
	background: var(--kim-surface);
	color: var(--kim-text);
	box-shadow: var(--kim-shadow-sm) inset;
}
.kim-input:focus, .kim-select:focus, .kim-textarea:focus {
	outline: none;
	border-color: color-mix(in oklab, var(--kim-primary) 60%, var(--kim-border));
	box-shadow: 0 0 0 3px color-mix(in oklab, var(--kim-primary) 25%, transparent);
}
.kim-form-row { display: flex; gap: var(--kim-gap-md); flex-wrap: wrap; }
.kim-form-col { flex: 1 1 220px; min-width: 200px; }
.kim-label { display:block; margin-bottom: 6px; color: var(--kim-textmuted); font-weight: 600; }
.kim-help { margin-top: 6px; color: var(--kim-textmuted); font-size: .9em; }

/* Navbar */
.kim-navbar {
	display: flex; align-items: center; gap: var(--kim-gap-md);
	padding: 10px 16px;
	background: var(--kim-surface);
	border-bottom: 1px solid var(--kim-border);
	position: sticky; top: 0; z-index: 100;
}
.kim-navbar.brand-strong { font-weight: 700; }

/* Dropdown */
.kim-dropdown { position: relative; display: inline-block; }
.kim-dropdown-menu {
	position: absolute; min-width: 180px; margin-top: 6px;
	background: var(--kim-surface);
	border: 1px solid var(--kim-border);
	border-radius: var(--kim-radius-sm);
	box-shadow: var(--kim-shadow-md);
	padding: 6px; display: none;
}
.kim-dropdown.open > .kim-dropdown-menu { display: block; }
.kim-dropdown-item { padding: 8px 10px; border-radius: var(--kim-radius-sm); color: var(--kim-text); }
.kim-dropdown-item:hover { background: var(--kim-surface-alt); }

/* Modal */
.kim-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,.45); display: none; }
.kim-backdrop.show { display: block; }
.kim-modal {
	position: fixed; inset: 0; display: none; place-items: center; padding: 16px;
}
.kim-modal.show { display: grid; }
.kim-modal .kim-card { max-width: 560px; width: 100%; }

/* Offcanvas */
.kim-offcanvas {
	position: fixed; top: 0; bottom: 0; width: 320px; background: var(--kim-surface);
	border-left: 1px solid var(--kim-border);
	box-shadow: var(--kim-shadow-lg);
	transform: translateX(100%);
	transition: transform .3s ease;
}
.kim-offcanvas.start { left: 0; right: auto; border-left: 0; border-right: 1px solid var(--kim-border); transform: translateX(-100%); }
.kim-offcanvas.show { transform: translateX(0); }

/* Accordion */
.kim-accordion { border: 1px solid var(--kim-border); border-radius: var(--kim-radius-md); overflow: hidden; }
.kim-accordion-item + .kim-accordion-item { border-top: 1px solid var(--kim-border); }
.kim-accordion-header { padding: 12px 14px; background: var(--kim-surface-alt); cursor: pointer; }
.kim-accordion-body { padding: 14px; background: var(--kim-surface); }

/* Tabs */
.kim-tabs { display: flex; border-bottom: 1px solid var(--kim-border); gap: 8px; }
.kim-tab { padding: 8px 12px; border-radius: var(--kim-radius-sm) var(--kim-radius-sm) 0 0; background: var(--kim-surface-alt); cursor: pointer; }
.kim-tab.active { background: var(--kim-surface); border: 1px solid var(--kim-border); border-bottom: 1px solid var(--kim-surface); }
.kim-tabpanel { padding: 14px; border: 1px solid var(--kim-border); border-top: 0; border-radius: 0 0 var(--kim-radius-sm) var(--kim-radius-sm); }

/* Tooltip / Popover */
.kim-tooltip { position: absolute; background: var(--kim-text); color: var(--kim-bg); padding: 6px 8px; border-radius: var(--kim-radius-sm); box-shadow: var(--kim-shadow-md); font-size: 12px; }
.kim-popover { position: absolute; background: var(--kim-surface); color: var(--kim-text); border: 1px solid var(--kim-border); border-radius: var(--kim-radius-sm); box-shadow: var(--kim-shadow-md); padding: 8px 10px; max-width: 260px; }

/* BS-compatible utility aliases used by components */
.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; }
.d-block { display: block !important; }
.w-100 { width: 100% !important; }
.rounded-pill { border-radius: 999px !important; }
.text-bg-primary { background: var(--kim-primary); color: var(--kim-primary-contrast); }
.text-bg-secondary { background: var(--kim-secondary); color: #fff; }
.text-bg-success { background: var(--kim-accent); color: #000; }
.text-bg-danger { background: var(--kim-danger); color: #fff; }
.text-bg-warning { background: var(--kim-warning); color: #000; }
.text-bg-info { background: var(--kim-info); color: #000; }
.text-bg-light { background: var(--kim-light); color: var(--kim-text); }
.text-bg-dark { background: var(--kim-dark); color: #fff; }



/* Frosted specific backdrops */
:root[data-theme="frosted"] .card,
:root[data-theme="frosted"] .navbar,
:root[data-theme="frosted"] .dropdown-menu,
:root[data-theme="frosted"] .modal .modal-content,
:root[data-theme="frosted"] .popover,
:root[data-theme="frosted"] .modal-backdrop {
	backdrop-filter: blur(20px) saturate(140%);
	-webkit-backdrop-filter: blur(20px) saturate(140%);
	border-color: rgba(15,23,42,.18);
	/* Ensure proper stacking context for frosted elements */
	position: relative;
	z-index: 1;
}

/* Frosted glass nav tabs */
:root[data-theme="frosted"] .nav-tabs .nav-link {
	backdrop-filter: blur(16px) saturate(140%);
	-webkit-backdrop-filter: blur(16px) saturate(140%);
	background: rgba(255, 255, 255, 0.7);
	border-color: rgba(15, 23, 42, 0.15);
}

:root[data-theme="frosted"] .nav-tabs .nav-link.active {
	backdrop-filter: blur(16px) saturate(140%);
	-webkit-backdrop-filter: blur(16px) saturate(140%);
	background: rgba(255, 255, 255, 0.9);
	border-color: rgba(15, 23, 42, 0.2);
}

:root[data-theme="frosted"] .nav-tabs {
	border-bottom-color: rgba(15, 23, 42, 0.15);
}

/* Simple spacing utilities */
.m-0{margin:0}
.mt-1{margin-top:var(--kim-gap-sm)}
.mt-2{margin-top:var(--kim-gap-md)}
.mt-3{margin-top:var(--kim-gap-lg)}
.mb-1{margin-bottom:var(--kim-gap-sm)}
.mb-2{margin-bottom:var(--kim-gap-md)}
.mb-3{margin-bottom:var(--kim-gap-lg)}
.p-1{padding:var(--kim-gap-sm)}
.p-2{padding:var(--kim-gap-md)}
.p-3{padding:var(--kim-gap-lg)}

/* Utility layout aliases (grid/container/row) for existing KIMBS demos */
/* Layout */
.container, .container-fluid { width: 100%; margin-inline: auto; padding-inline: 16px; }
.container { max-width: 1200px; }
.row { display: flex; flex-wrap: wrap; gap: var(--kim-gap-md); }
.row > * { flex-shrink: 0; max-width: 100%; }
.col { flex: 1 0 0; }
/* Simple cols used in demo */
.col-md-4 { flex: 0 0 100%; }
.col-md-6 { flex: 0 0 100%; }
@media (min-width: 768px) {
	.col-md-4 { flex-basis: 33.3333%; max-width: 33.3333%; }
	.col-md-6 { flex-basis: 50%; max-width: 50%; }
}

/* Card */
.card { background: var(--kim-surface); border: 1px solid var(--kim-border); border-radius: var(--kim-radius-md); box-shadow: var(--kim-shadow-sm); }
.card > .list-group { border-top: 1px solid var(--kim-border); }
.card-img-top { width: 100%; display: block; border-top-left-radius: var(--kim-radius-md); border-top-right-radius: var(--kim-radius-md); }
.card-header { padding: 12px 16px; border-bottom: 1px solid var(--kim-border); font-weight: 600; background: var(--kim-surface-alt); }
.card-body { padding: 16px; }
.card-title { margin: 0 0 6px; font-weight: 700; }
.card-text { margin: 0; color: var(--kim-text); }

/* Buttons */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; border: 1px solid transparent; background: var(--kim-surface-alt); color: var(--kim-text); cursor: pointer; box-shadow: var(--kim-shadow-sm); text-decoration: none; }
.btn:hover { filter: brightness(.98); }
.btn:active { transform: translateY(1px); }
.btn-primary { background: var(--kim-primary); color: var(--kim-primary-contrast); }
.btn-secondary { background: var(--kim-secondary); color: #fff; border-color: var(--kim-secondary); }
.btn-success { background: var(--kim-accent); color: var(--kim-primary-contrast); }
.btn-danger { background: var(--kim-danger); color: #fff; }
.btn-warning { background: var(--kim-warning); color: #000; }
.btn-info { background: var(--kim-info); color: #000; }
.btn-light { background: var(--kim-bg-soft); color: var(--kim-text); }

/* Button Sizes */
.btn.btn-sm {
  padding: 4px 8px !important;
  font-size: 12px !important;
  border-radius: var(--kim-radius-xs) !important;
  min-height: 28px !important;
  min-width: 28px !important;
  line-height: 1.2 !important;
}

/* Default button size (medium) - smaller than current */
.btn {
  padding: 6px 12px !important;
  font-size: 14px !important;
  border-radius: var(--kim-radius-sm) !important;
  min-height: 36px !important;
  min-width: 36px !important;
  line-height: 1.2 !important;
}

.btn.btn-lg {
  padding: 10px 18px !important;
  font-size: 16px !important;
  border-radius: var(--kim-radius-md) !important;
  min-height: 44px !important;
  min-width: 44px !important;
  line-height: 1.2 !important;
}

.btn.btn-xl {
  padding: 14px 24px !important;
  font-size: 18px !important;
  border-radius: var(--kim-radius-lg) !important;
  min-height: 52px !important;
  min-width: 52px !important;
  line-height: 1.2 !important;
}

/* Outline Button Variants */
.btn-outline-primary {
  background: transparent;
  color: var(--kim-primary);
  border-color: var(--kim-primary);
}

.btn-outline-primary:hover {
  background: var(--kim-primary);
  color: var(--kim-primary-contrast);
}

.btn-outline-secondary {
  background: transparent;
  color: var(--kim-secondary);
  border-color: var(--kim-secondary);
}

.btn-outline-secondary:hover {
  background: var(--kim-secondary);
  color: #fff;
}

.btn-outline-success {
  background: transparent;
  color: var(--kim-accent);
  border-color: var(--kim-accent);
}

.btn-outline-success:hover {
  background: var(--kim-accent);
  color: var(--kim-primary-contrast);
}

.btn-outline-danger {
  background: transparent;
  color: var(--kim-danger);
  border-color: var(--kim-danger);
}

.btn-outline-danger:hover {
  background: var(--kim-danger);
  color: #fff;
}

.btn-outline-warning {
  background: transparent;
  color: var(--kim-warning);
  border-color: var(--kim-warning);
}

.btn-outline-warning:hover {
  background: var(--kim-warning);
  color: #000;
}

.btn-outline-info {
  background: transparent;
  color: var(--kim-info);
  border-color: var(--kim-info);
}

.btn-outline-info:hover {
  background: var(--kim-info);
  color: #000;
}

.btn-outline-light {
  background: transparent;
  color: var(--kim-bg-soft);
  border-color: var(--kim-bg-soft);
}

.btn-outline-light:hover {
  background: var(--kim-bg-soft);
  color: var(--kim-text);
}

/* Button Utilities */
.btn-block {
  display: block;
  width: 100%;
}

.btn-rounded {
  border-radius: 50px !important;
}

.btn-square {
  border-radius: 0 !important;
}

.btn-custom-rounded {
  border-radius: var(--kim-radius-md) !important;
}

.btn-custom-pill {
  border-radius: 50px !important;
}

.btn-custom-diagonal {
  border-radius: 8px 0 8px 0 !important;
}

/* Form Components Styling */
.submitted-data-card .data-item {
  margin-bottom: 1rem;
}

.submitted-data-card .data-label {
  font-size: 0.875rem;
  color: var(--kim-textmuted);
  margin-bottom: 0.25rem;
  font-weight: 500;
}

.submitted-data-card .data-value {
  font-size: 1rem;
  color: var(--kim-text);
}

.submitted-data-card .country-flag {
  font-size: 1.2rem;
  margin-right: 0.5rem;
}

/* Button with Icons */
.btn .icon {
  width: 16px;
  height: 16px;
}

.btn.btn-sm .icon {
  width: 14px;
  height: 14px;
}

.btn.btn-lg .icon {
  width: 18px;
  height: 18px;
}

.btn.btn-xl .icon {
  width: 20px;
  height: 20px;
}

/* Additional Button Size Utilities */
.btn.btn-sm.btn-block {
  min-height: 28px;
}

.btn.btn-lg.btn-block {
  min-height: 48px;
}

.btn.btn-xl.btn-block {
  min-height: 56px;
}

/* Dark theme button fixes */
.offcanvas-dark .btn-light { 
  background: #f8f9fa; 
  color: #212529; 
  border-color: #dee2e6;
}

.offcanvas-dark .btn-outline-light { 
  background: transparent; 
  color: #f8f9fa; 
  border-color: #f8f9fa;
}

.offcanvas-dark .btn-outline-light:hover { 
  background: #f8f9fa; 
  color: #212529;
}

/* Touch-friendly improvements */
.btn-touch-friendly, .btn-close, .nav-link, .dropdown-item, .page-link, .accordion-button {
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  user-select: none;
  touch-action: manipulation;
  min-height: 44px;
  min-width: 44px;
}

/* Legacy support for existing classes */
.btn, .btn-close, .nav-link, .dropdown-item, .page-link, .accordion-button {
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  user-select: none;
  touch-action: manipulation;
  min-height: 44px;
  min-width: 44px;
}

/* Additional touch-friendly classes */
.nav-link-touch-friendly {
  display: flex;
  align-items: center;
  justify-content: center;
}

.list-group-item-touch-friendly {
  min-height: 44px;
}

.btn-close-touch-friendly {
  min-height: 44px;
  min-width: 44px;
}

/* Enhanced touch feedback */
.btn:active, .nav-link:active, .dropdown-item:active, .page-link:active, .accordion-button:active {
  transform: scale(0.98);
  transition: transform 0.1s ease;
}

/* Table touch improvements */
.table th, .table td {
  padding: 12px 8px;
  vertical-align: middle;
}

.table tbody tr {
  min-height: 44px;
}

/* Modal and offcanvas touch improvements */
.modal-header, .offcanvas-header {
  touch-action: none;
  -webkit-tap-highlight-color: transparent;
}

/* Carousel touch improvements */
.carousel-control-prev, .carousel-control-next, .carousel-indicators button {
  min-height: 44px;
  min-width: 44px;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}

/* List group touch improvements */
.list-group-item {
  min-height: 44px;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}

/* Form controls touch improvements */
.form-control, .form-select, .form-check-input {
  min-height: 44px;
  touch-action: manipulation;
}

/* Prevent text selection on interactive elements */
.btn, .nav-link, .dropdown-item, .page-link, .accordion-button, .carousel-control-prev, .carousel-control-next {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

/* Improved focus states for touch devices */
@media (hover: none) and (pointer: coarse) {
  .btn:focus, .nav-link:focus, .dropdown-item:focus, .page-link:focus {
    outline: 2px solid var(--kim-primary);
    outline-offset: 2px;
  }
}
.btn-dark { background: #111827; color: #fff; }
.btn-link { background: transparent; color: var(--kim-primary); text-decoration: underline; box-shadow: none; }

/* Button variants (outline) */
.btn-outline-primary { background: transparent; color: var(--kim-primary); border-color: var(--kim-primary); }
.btn-outline-secondary { background: transparent; color: var(--kim-secondary); border-color: var(--kim-secondary); }
.btn-outline-success { background: transparent; color: var(--kim-accent); border-color: var(--kim-accent); }
.btn-outline-danger { background: transparent; color: var(--kim-danger); border-color: var(--kim-danger); }
.btn-outline-warning { background: transparent; color: var(--kim-warning); border-color: var(--kim-warning); }
.btn-outline-info { background: transparent; color: var(--kim-info); border-color: var(--kim-info); }
.btn-outline-light { background: transparent; color: var(--kim-text); border-color: var(--kim-border); }
.btn-outline-dark { background: transparent; color: var(--kim-dark); border-color: var(--kim-dark); }

/* Badges */
.badge { display: inline-block; padding: 4px 8px; border-radius: 999px; font-size: 12px; line-height: 1; color: #fff; background: var(--kim-primary); }
.badge.bg-primary, .badge-primary { background: var(--kim-primary); color: var(--kim-primary-contrast); }
.badge.bg-secondary, .badge-secondary { background: var(--kim-secondary); color: #fff; }
.badge.bg-success, .badge-success { background: var(--kim-accent); color: var(--kim-primary-contrast); }
.badge.bg-danger, .badge-danger { background: var(--kim-danger); color: #fff; }
.badge.bg-warning, .badge-warning { background: var(--kim-warning); color: #000; }
.badge.bg-info, .badge-info { background: var(--kim-info); color: #000; }
.badge.bg-light, .badge-light { background: var(--kim-bg-soft); color: var(--kim-text); }
.badge.bg-dark, .badge-dark { background: #111827; color: #fff; }

/* Alerts */
.alert { padding: 12px 14px; border-radius: var(--kim-radius-sm); border: 1px solid var(--kim-border); background: var(--kim-surface); }
.alert-primary { border-color: color-mix(in oklab, var(--kim-primary) 40%, var(--kim-border)); background: color-mix(in oklab, var(--kim-primary) 8%, var(--kim-surface)); }
.alert-secondary { border-color: color-mix(in oklab, var(--kim-secondary) 40%, var(--kim-border)); background: color-mix(in oklab, var(--kim-secondary) 8%, var(--kim-surface)); }
.alert-success { border-color: color-mix(in oklab, var(--kim-accent) 40%, var(--kim-border)); background: color-mix(in oklab, var(--kim-accent) 8%, var(--kim-surface)); }
.alert-danger { border-color: color-mix(in oklab, var(--kim-danger) 40%, var(--kim-border)); background: color-mix(in oklab, var(--kim-danger) 8%, var(--kim-surface)); }
.alert-warning { border-color: color-mix(in oklab, var(--kim-warning) 40%, var(--kim-border)); background: color-mix(in oklab, var(--kim-warning) 12%, var(--kim-surface)); }
.alert-info { border-color: color-mix(in oklab, var(--kim-info) 40%, var(--kim-border)); background: color-mix(in oklab, var(--kim-info) 8%, var(--kim-surface)); }
.alert-light { border-color: color-mix(in oklab, var(--kim-bg-soft) 40%, var(--kim-border)); background: color-mix(in oklab, var(--kim-bg-soft) 8%, var(--kim-surface)); }
.alert-dark { border-color: color-mix(in oklab, var(--kim-dark) 40%, var(--kim-border)); background: color-mix(in oklab, var(--kim-dark) 8%, var(--kim-surface)); color: #fff; }
.alert-dismissible { padding-right: 2.5rem; position: relative; }
.alert .btn-close { 
  position: absolute !important; 
  top: 0 !important; 
  bottom: 0 !important; 
  right: 10px !important; 
  margin: auto 0 !important; 
  color: var(--kim-text-muted) !important; 
  width: 1.25rem !important; 
  height: 1.25rem !important; 
  font-size: 0 !important; 
  line-height: 1 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  opacity: 0.6 !important;
}
.alert .btn-close:hover { 
  color: var(--kim-text) !important; 
  opacity: 0.8 !important; 
  transform: scale(1.05) !important; 
}

.alert .btn-close::before,
.alert .btn-close::after {
  content: '' !important;
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  width: 1rem !important;
  height: 0.125rem !important;
  background-color: currentColor !important;
  transform-origin: center !important;
}

.alert .btn-close::before {
  transform: translate(-50%, -50%) rotate(45deg) !important;
}

.alert .btn-close::after {
  transform: translate(-50%, -50%) rotate(-45deg) !important;
}

/* Navbar */
.navbar { display: flex; align-items: center; padding: 10px 16px; background: var(--kim-surface); border-bottom: 1px solid var(--kim-border); }
.navbar .navbar-brand { font-weight: 800; color: var(--kim-text); text-decoration: none; }

/* Nav */
.nav { display: flex; gap: 8px; border-bottom: 1px solid var(--kim-border); list-style: none; padding-left: 0; margin: 0; }
.nav .nav-item { list-style: none; }
.nav-tabs .nav-link { padding: 8px 12px; border-radius: var(--kim-radius-sm) var(--kim-radius-sm) 0 0; background: var(--kim-surface-alt); border: 1px solid var(--kim-border); border-bottom: none; color: var(--kim-text); text-decoration: none; position: relative; z-index: 0; }
.nav-tabs .nav-link.active { background: var(--kim-surface); border-bottom: 1px solid var(--kim-surface); margin-bottom: -1px; z-index: 1; }
.nav .nav-link.disabled { opacity: .5; pointer-events: none; }
.nav.nav-pills { border-bottom: 0; }
.nav-pills .nav-link { padding: 6px 10px; border-radius: 999px; text-decoration: none; color: var(--kim-text); }
.nav-pills .nav-link:hover { background: var(--kim-surface-alt); }
.nav-pills .nav-link.active { background: var(--kim-primary); color: var(--kim-primary-contrast); }

/* Enhanced Tab Variants */
.nav-underline {
  border-bottom: 2px solid var(--kim-border);
}

.nav-underline .nav-link {
  border: none;
  background: transparent;
  border-bottom: 2px solid transparent;
  border-radius: 0;
  margin-bottom: -2px;
}

.nav-underline .nav-link.active {
  border-bottom-color: var(--kim-primary);
  background: transparent;
  color: var(--kim-primary);
  font-weight: 600;
}

.nav-cards {
  border-bottom: none;
  gap: 8px;
  padding: 0;
  margin: 0;
}

.nav-cards .nav-link {
  border: 1px solid var(--kim-border);
  border-radius: var(--kim-radius-md);
  background: var(--kim-surface);
  margin-bottom: 0;
  padding: 12px 16px;
  min-width: 120px;
  text-align: center;
  transition: all 0.2s ease;
  box-shadow: var(--kim-shadow-sm);
  position: relative;
}

.nav-cards .nav-link:hover {
  background: var(--kim-surface-alt);
  border-color: var(--kim-primary);
  transform: translateY(-1px);
  box-shadow: var(--kim-shadow-md);
}

.nav-cards .nav-link.active {
  background: var(--kim-primary);
  border-color: var(--kim-primary);
  color: var(--kim-primary-contrast);
  box-shadow: var(--kim-shadow-md);
  transform: translateY(-1px);
}

.nav-cards .nav-link span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  margin-right: 8px;
  border-radius: var(--kim-radius-sm);
  background: rgba(255, 255, 255, 0.2);
  font-size: 14px;
}

.nav-cards .nav-link.active span {
  background: rgba(255, 255, 255, 0.3);
}

.nav-cards .nav-link {
  text-decoration: none;
}

.nav-cards .nav-link:hover {
  text-decoration: none;
}

/* Close button styling for closable tabs */
.nav-link .btn-close {
  opacity: 0.6;
  transition: opacity 0.2s ease;
}

.nav-link:hover .btn-close {
  opacity: 1;
}

.nav-link .btn-close:hover {
  opacity: 1;
  background-color: rgba(0, 0, 0, 0.1);
  border-radius: 50%;
}

/* Tab Sizes */
.nav-sm .nav-link {
  padding: 4px 8px;
  font-size: 0.875rem;
}

.nav-lg .nav-link {
  padding: 12px 16px;
  font-size: 1.125rem;
}

/* Vertical Tabs */
.nav-vertical {
  flex-direction: column !important;
  border-bottom: none !important;
  border-right: 1px solid var(--kim-border);
  gap: 0 !important;
  width: 200px;
  min-width: 200px;
  background: var(--kim-surface-alt);
  margin: 0;
  padding: 0;
  height: 100%;
  align-self: stretch;
}

.nav-vertical .nav-link {
  border-radius: 0 !important;
  border: none !important;
  border-bottom: 1px solid var(--kim-border) !important;
  text-align: left !important;
  padding: 12px 16px !important;
  position: relative;
  transition: all 0.2s ease;
  margin: 0;
  width: 100%;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  gap: 8px;
}

.nav-vertical .nav-link:hover {
  background: var(--kim-surface);
}

.nav-vertical .nav-link.active {
  border-right: 3px solid var(--kim-primary) !important;
  background: var(--kim-surface) !important;
  color: var(--kim-primary) !important;
  font-weight: 600;
}

.nav-vertical .nav-link.active::before {
  content: '';
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: var(--kim-primary);
}

.nav-vertical .nav-link:hover {
  background: var(--kim-surface);
  color: var(--kim-primary);
}

.tab-content-vertical {
  flex: 1;
  padding: 16px;
  background: var(--kim-surface);
  border-radius: var(--kim-radius-sm);
  min-height: 200px;
  margin-left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
}

/* Vertical Tabs Container */
.nav-vertical-container {
  display: flex !important;
  gap: 16px;
  align-items: flex-start;
  width: 100%;
  min-height: 300px;
}

/* Tab Pane Styles */
.tab-pane {
  display: none;
}

.tab-pane.show {
  display: block;
}

.tab-pane.active {
  display: block;
}

.tab-content-vertical .tab-pane {
  display: none;
  width: 100%;
  text-align: center;
}

.tab-content-vertical .tab-pane.show.active {
  display: block;
  width: 100%;
}

/* Breadcrumb */
.breadcrumb { display: flex; align-items: center; gap: 6px; list-style: none; padding: 6px 10px; margin: 0; color: var(--kim-text-muted); background: var(--kim-bg-soft); border: 1px solid var(--kim-border); border-radius: var(--kim-radius-sm); }
.breadcrumb .breadcrumb-item { list-style: none; display: inline-flex; align-items: center; }
.breadcrumb .breadcrumb-item + .breadcrumb-item::before { content: "›"; margin: 0 8px; color: var(--kim-text-muted); opacity: .8; }
.breadcrumb .breadcrumb-item a { color: var(--kim-text); text-decoration: none; }
.breadcrumb .breadcrumb-item a:hover { text-decoration: underline; }
.breadcrumb .breadcrumb-item.active { color: var(--kim-text); font-weight: 700; }

/* Breadcrumb Variants */
.breadcrumb-pills {
  background: transparent;
  border: none;
  padding: 0;
}

.breadcrumb-pills .breadcrumb-item {
  margin-right: 0.25rem;
}

.breadcrumb-pills .breadcrumb-item + .breadcrumb-item::before {
  content: none;
}

.breadcrumb-pill {
  background-color: var(--kim-surface);
  border: 1px solid var(--kim-border);
  border-radius: var(--kim-radius-pill);
  padding: 0.25rem 0.75rem;
  margin-right: 0.25rem;
}

.breadcrumb-pill.active {
  background-color: var(--kim-primary);
  border-color: var(--kim-primary);
  color: var(--kim-primary-contrast);
}

.breadcrumb-pill a {
  color: var(--kim-text);
}

.breadcrumb-pill.active a {
  color: var(--kim-primary-contrast);
}

.breadcrumb-arrows .breadcrumb-item + .breadcrumb-item::before {
  content: "›";
  font-weight: bold;
  color: var(--kim-text-muted);
}

/* Breadcrumb Sizes */
.breadcrumb-sm {
  padding: 0.5rem 0.75rem;
  font-size: 0.875rem;
}

.breadcrumb-sm .breadcrumb-item + .breadcrumb-item {
  padding-left: 0.375rem;
}

.breadcrumb-sm .breadcrumb-item + .breadcrumb-item::before {
  padding-right: 0.375rem;
}

.breadcrumb-lg {
  padding: 1rem 1.25rem;
  font-size: 1.125rem;
}

.breadcrumb-lg .breadcrumb-item + .breadcrumb-item {
  padding-left: 0.625rem;
}

.breadcrumb-lg .breadcrumb-item + .breadcrumb-item::before {
  padding-right: 0.625rem;
}

/* Pagination */
.pagination { display: flex; gap: 6px; list-style: none; padding-left: 0; margin: 0; }
.pagination .page-item { list-style: none; }
.page-link { display: inline-flex; align-items: center; justify-content: center; min-width: 36px; padding: 6px 10px; border: 1px solid var(--kim-border); border-radius: var(--kim-radius-sm); color: var(--kim-text); text-decoration: none; background: var(--kim-surface); }
.page-item.active .page-link { background: var(--kim-primary); color: var(--kim-primary-contrast); border-color: var(--kim-primary); }

/* List group */
.list-group { display: flex; flex-direction: column; border-radius: var(--kim-radius-md); overflow: hidden; border: 1px solid var(--kim-border); background: var(--kim-surface); box-shadow: var(--kim-shadow-sm); list-style: none; padding: 0; margin: 0; }
.list-group-item { 
  padding: 12px 16px; 
  border-bottom: 1px solid var(--kim-border); 
  background: var(--kim-surface); 
  transition: all 0.2s ease;
  position: relative;
  list-style: none;
}
.list-group-item:last-child { border-bottom: none; }
.list-group-item:first-child { border-top: none; }
.list-group-item.active { 
  background: linear-gradient(135deg, var(--kim-primary), color-mix(in oklab, var(--kim-primary) 80%, var(--kim-surface))); 
  color: var(--kim-primary-contrast); 
  font-weight: 600;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.1);
}
.list-group-item.disabled { 
  opacity: 0.6; 
  pointer-events: none;
  background: var(--kim-surface-alt); 
  color: var(--kim-text-muted);
}

/* flush variant */
.list-group.list-group-flush { 
  border: 0;
  border-radius: 0;
  box-shadow: none;
}
.list-group.list-group-flush .list-group-item { 
  border-right: 0;
  border-left: 0;
  border-radius: 0; 
  border-bottom: 1px solid var(--kim-border);
}

/* actionable items */
.list-group-item-action { 
  cursor: pointer; 
  user-select: none; 
  position: relative;
}
.list-group-item-action:hover {
  background: color-mix(in oklab, var(--kim-primary) 5%, var(--kim-surface)); 
  transform: translateX(2px);
  box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}
.list-group-item-action:active {
  filter: brightness(0.95); 
  transform: translateX(1px);
}
.list-group-item-action::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: var(--kim-primary);
  opacity: 0;
  transition: opacity 0.2s ease;
}
.list-group-item-action:hover::before {
    opacity: 1;
}

/* item variants */
.list-group-item-primary { background: color-mix(in oklab, var(--kim-primary) 10%, var(--kim-surface)); border-color: color-mix(in oklab, var(--kim-primary) 40%, var(--kim-border)); }
.list-group-item-secondary { background: color-mix(in oklab, var(--kim-secondary) 10%, var(--kim-surface)); border-color: color-mix(in oklab, var(--kim-secondary) 40%, var(--kim-border)); }
.list-group-item-success { background: color-mix(in oklab, var(--kim-accent) 10%, var(--kim-surface)); border-color: color-mix(in oklab, var(--kim-accent) 40%, var(--kim-border)); }
.list-group-item-danger { background: color-mix(in oklab, var(--kim-danger) 10%, var(--kim-surface)); border-color: color-mix(in oklab, var(--kim-danger) 40%, var(--kim-border)); }
.list-group-item-warning { background: color-mix(in oklab, var(--kim-warning) 14%, var(--kim-surface)); border-color: color-mix(in oklab, var(--kim-warning) 40%, var(--kim-border)); color: #000; }
.list-group-item-info { background: color-mix(in oklab, var(--kim-info) 12%, var(--kim-surface)); border-color: color-mix(in oklab, var(--kim-info) 40%, var(--kim-border)); }
.list-group-item-light { background: var(--kim-bg-soft); border-color: var(--kim-border); }
.list-group-item-dark { background: var(--kim-dark); color: #fff; border-color: var(--kim-dark); }

/* Forms */
.form-control { width: 100%; padding: 8px 10px; border-radius: var(--kim-radius-sm); border: 1px solid var(--kim-border); background: var(--kim-surface); color: var(--kim-text); }
.form-control:focus { outline: none; border-color: color-mix(in oklab, var(--kim-primary) 60%, var(--kim-border)); box-shadow: 0 0 0 3px color-mix(in oklab, var(--kim-primary) 25%, transparent); }
.form-select { width: 100%; padding: 8px 10px; border-radius: var(--kim-radius-sm); border: 1px solid var(--kim-border); background: var(--kim-surface); color: var(--kim-text); }

.form-range { width: 100%; }
.input-group { display: flex; align-items: stretch; width: 100%; }
.input-group-text { display: inline-flex; align-items: center; padding: 8px 10px; border: 1px solid var(--kim-border); border-right: 0; background: var(--kim-surface-alt); border-radius: var(--kim-radius-sm) 0 0 var(--kim-radius-sm); }
.input-group .form-control { border-radius: 0 var(--kim-radius-sm) var(--kim-radius-sm) 0; }
.form-floating { position: relative; }
.form-floating > label { position: absolute; left: 10px; top: 8px; color: var(--kim-text-muted); }
.form-floating > .form-control::placeholder { color: transparent; }
.form-floating > .form-control:focus + label,
.form-floating > .form-control:not(:placeholder-shown) + label { font-size: 12px; top: -8px; background: var(--kim-surface); padding: 0 4px; }
.form-control-color { width: 3rem; height: 2.25rem; padding: 4px; }
.form-range { accent-color: var(--kim-primary); }
.form-control-lg { padding: 12px 16px; font-size: 16px; border-radius: var(--kim-radius-md); }
.form-control-sm { padding: 6px 12px; font-size: 14px; border-radius: var(--kim-radius-sm); }
.form-control-plaintext { background-color: transparent; border: solid transparent; border-width: 1px 0; padding-left: 0; padding-right: 0; }
.form-label { margin-bottom: 0.5rem; font-weight: 500; color: var(--kim-text); }
.form-text { margin-top: 0.25rem; font-size: 0.875em; color: var(--kim-text-muted); }
.form-check { display: flex; min-height: 1.5rem; padding-left: 1.5em; margin-bottom: 0.125rem; }
.form-check-input { 
  width: 1em; 
  height: 1em; 
  margin-top: 0.25em; 
  margin-right: 0.5em; 
  margin-left: -1.5em; 
  background-color: var(--kim-surface, #ffffff); 
  background-repeat: no-repeat; 
  background-position: center; 
  background-size: contain; 
  border: 1px solid var(--kim-border, #dee2e6); 
  appearance: none;
  -webkit-appearance: none;
  display: inline-block;
  vertical-align: middle;
}
.form-check-input[type=checkbox] { 
  border-radius: 0.25em; 
  background-image: none;
  flex-shrink: 0;
  aspect-ratio: 1;
  min-width: 16px;
  min-height: 16px;
}
.form-check-input[type=radio] { 
  border-radius: 50%; 
  background-image: none;
  flex-shrink: 0;
  aspect-ratio: 1;
  min-width: 16px;
  min-height: 16px;
}
.form-check-input:checked { 
  background-color: var(--kim-primary, #0d6efd); 
  border-color: var(--kim-primary, #0d6efd); 
}
.form-check-input:checked[type=checkbox] { background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='m6 10 3 3 6-6'/%3e%3c/svg%3e"); }
.form-check-input:checked[type=radio] { 
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='2' fill='%23fff'/%3e%3c/svg%3e") !important; 
}
.form-check-input:focus { border-color: var(--kim-primary); outline: 0; box-shadow: 0 0 0 0.2rem rgba(var(--kim-primary-rgb), 0.25); }
.form-check-input:disabled { opacity: 0.5; }
.form-check-label { margin-bottom: 0; cursor: pointer; }
/* Modern Toggle Switch */
.form-check.form-switch { 
  padding-left: 0; 
  display: flex; 
  align-items: center; 
  gap: 0.75rem; 
  margin-bottom: 0;
}

.form-check.form-switch .form-check-input { 
  appearance: none;
  -webkit-appearance: none;
  width: 2.5em; 
  height: 1.25em; 
  margin: 0;
  background-color: #e9ecef; 
  border: 1px solid #dee2e6; 
  border-radius: 1.25em; 
  background-image: none !important; 
  position: relative; 
  transition: all 0.3s ease; 
  cursor: pointer; 
  flex-shrink: 0;
  display: inline-block;
  vertical-align: middle;
}

.form-check.form-switch .form-check-input::before { 
  content: ""; 
  position: absolute; 
  top: 2px; 
  left: 2px; 
  width: calc(1.25em - 4px); 
  height: calc(1.25em - 4px); 
  background-color: #fff; 
  border-radius: 50%; 
  transition: all 0.3s ease; 
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2); 
}

.form-check.form-switch .form-check-input:checked { 
  background-color: var(--kim-primary, #0d6efd); 
  border-color: var(--kim-primary, #0d6efd); 
  background-position: unset; 
  background-image: none; 
}

.form-check.form-switch .form-check-input:checked::before { 
  transform: translateX(1.25em); 
  background-color: #fff; 
}

.form-check.form-switch .form-check-input:focus { 
  box-shadow: 0 0 0 0.2rem rgba(var(--kim-primary-rgb), 0.25); 
  outline: none;
}

.form-check.form-switch .form-check-input:disabled { 
  opacity: 0.6; 
  cursor: not-allowed; 
}

.form-check.form-switch .form-check-input:disabled::before { 
  background-color: #f8f9fa; 
}

.form-check.form-switch .form-check-label {
  margin-left: 0.5rem;
  cursor: pointer;
}
.form-control.is-valid { border-color: var(--kim-accent); }
.form-control.is-invalid { border-color: var(--kim-danger); }
.valid-feedback { display: block; width: 100%; margin-top: 0.25rem; font-size: 0.875em; color: var(--kim-accent); }
.invalid-feedback { display: block; width: 100%; margin-top: 0.25rem; font-size: 0.875em; color: var(--kim-danger); }
.text-muted { color: var(--kim-text-muted) !important; }
.text-center { text-align: center !important; }
.text-warning { color: #ffc107 !important; }
.d-flex { display: flex !important; }
.align-items-center { align-items: center !important; }
.justify-content-between { justify-content: space-between !important; }
.gap-1 { gap: 0.25rem !important; }
.gap-2 { gap: 0.5rem !important; }
.gap-3 { gap: 1rem !important; }
.mt-1 { margin-top: 0.25rem !important; }
.mt-2 { margin-top: 0.5rem !important; }
.mb-3 { margin-bottom: 1rem !important; }
.mb-4 { margin-bottom: 1.5rem !important; }
.me-1 { margin-right: 0.25rem !important; }
.mx-2 { margin-left: 0.5rem !important; margin-right: 0.5rem !important; }
.p-2 { padding: 0.5rem !important; }
.position-relative { position: relative !important; }
.position-absolute { position: absolute !important; }
.w-100 { width: 100% !important; }
.fw-bold { font-weight: bold !important; }
.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; }

/* Dropdown */
.dropdown { position: relative; }
.dropdown-toggle::after { content: ""; display: inline-block; margin-left: 6px; vertical-align: middle; border-top: 4px solid currentColor; border-right: 4px solid transparent; border-left: 4px solid transparent; }
.dropdown-menu { position: absolute; z-index: 1000; min-width: 180px; margin-top: 6px; background: var(--kim-surface); border: 1px solid var(--kim-border); border-radius: var(--kim-radius-sm); box-shadow: var(--kim-shadow-md); padding: 6px; display: none; }
.dropdown-menu.show { display: block; }
.dropdown-item { padding: 8px 10px; border-radius: var(--kim-radius-sm); color: var(--kim-text); text-decoration: none; display: block; }
.dropdown-item:hover { background: var(--kim-surface-alt); }

/* Navbar theme modifiers */
.navbar-dark { background: var(--kim-dark); color: #fff; }
.navbar-dark .navbar-brand { color: #fff; }
.navbar-light { background: var(--kim-surface); color: var(--kim-text); }

/* Modal structure */
.code-editor-modal { position: fixed; inset: 0; display: none; z-index: 1060; }
.code-editor-modal.show { display: block; }
.code-editor-modal.show::before { content: ""; position: fixed; inset: 0; background: rgba(0,0,0,.5); }
.code-editor-modal.no-backdrop.show::before { content: none; }
.code-editor-modal-dialog { max-width: 600px; margin: 40px auto; position: relative; z-index: 1; }
.kim-modal-compact .code-editor-modal-dialog { width: 200px; max-width: 200px; }
.kim-modal-compact .code-editor-modal-content { border-radius: 10px; }
.kim-modal-compact .code-editor-modal-header, .kim-modal-compact .code-editor-modal-footer { padding: 8px 12px; }
.kim-modal-compact .code-editor-modal-title { font-size: 14px; }
.kim-modal-compact .code-editor-modal-body { padding: 10px 12px; }
.kim-modal-compact .code-editor-modal-form-control { padding: 6px 8px; font-size: 13px; }
.kim-modal-compact .btn { padding: 6px 10px; font-size: 13px; }
.code-editor-modal-dialog-centered { display: grid; place-items: center; min-height: 100%; }
.code-editor-modal-content { background: var(--kim-surface); color: var(--kim-text); border: 1px solid var(--kim-border); border-radius: var(--kim-radius-md); box-shadow: var(--kim-shadow-lg); }
.code-editor-modal-header, .code-editor-modal-footer { padding: 12px 16px; border-bottom: 1px solid var(--kim-border); }
.code-editor-modal-header { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.code-editor-modal-title { margin: 0; font-weight: 700; }
.code-editor-modal-footer { border-top: 1px solid var(--kim-border); border-bottom: 0; display: flex; gap: 8px; justify-content: flex-end; }
.code-editor-modal-body { padding: 16px; }

/* Modal (proper KIM.js component) */
.modal-backdrop { 
  position: fixed; 
  inset: 0; 
  background: rgba(0, 0, 0, 0.5); 
  z-index: 1055; 
  display: none; 
}

.modal-backdrop.show { 
  display: block; 
}

.modal { 
  position: fixed; 
  inset: 0; 
  z-index: 1060; 
  display: none; 
  align-items: center; 
  justify-content: center; 
}

.modal.show { 
  display: flex; 
}

.modal-dialog { 
  max-width: 500px; 
  width: 90%; 
  margin: 0; 
  position: relative; 
  z-index: 1; 
}

.modal-dialog.modal-sm { 
  max-width: 300px; 
}

.modal-dialog.modal-lg { 
  max-width: 800px; 
}

.modal-dialog.modal-xl { 
  max-width: 1140px; 
}

.modal-dialog.modal-dialog-centered { 
  display: grid; 
  place-items: center; 
  min-height: 100%; 
}

/* Draggable Modal */
.modal-dialog.modal-dialog-draggable {
  transition: transform 0.2s ease;
  user-select: none;
}

.modal-dialog.modal-dialog-draggable.dragging {
  transition: none;
}

.modal-dialog.modal-dialog-draggable .modal-header {
  cursor: move;
}

.modal-dialog.modal-dialog-draggable .modal-header:hover {
  background: rgba(0, 0, 0, 0.02);
}

.modal-dialog.modal-dialog-draggable.dragging .modal-header {
  cursor: grabbing;
}

.modal-content { 
  background: var(--kim-surface); 
  color: var(--kim-text); 
  border: 1px solid var(--kim-border); 
  border-radius: var(--kim-radius-md); 
  box-shadow: var(--kim-shadow-lg); 
  position: relative; 
}

.modal-header { 
  padding: 12px 16px; 
  border-bottom: 1px solid var(--kim-border); 
  display: flex; 
  align-items: center; 
  justify-content: space-between; 
  gap: 8px; 
}

.modal-title { 
  margin: 0; 
  font-weight: 700; 
}

.modal-body { 
  padding: 16px; 
}

.modal-footer { 
  padding: 12px 16px; 
  border-top: 1px solid var(--kim-border); 
  border-bottom: 0; 
  display: flex; 
  gap: 8px; 
  justify-content: flex-end; 
}
.btn-close { 
  width: 1em; 
  height: 1em; 
  opacity: .6; 
  background: none; 
  border: 0; 
  position: relative; 
  display: flex;
  align-items: center;
  justify-content: center;
}
.btn-close::before, .btn-close::after { 
  content: ""; 
  position: absolute; 
  width: 100%; 
  height: 2px; 
  background: currentColor; 
  transform-origin: center; 
}
.btn-close::before { transform: rotate(45deg); }
.btn-close::after { transform: rotate(-45deg); }



/* Progress & Spinner */
.progress { width: 100%; height: 12px; background: color-mix(in oklab, var(--kim-text) 6%, var(--kim-bg)); border: 1px solid var(--kim-border); border-radius: 999px; overflow: hidden; box-shadow: inset 0 1px 2px rgba(0,0,0,.06); }
.progress-xs { height: 6px; }
.progress-sm { height: 8px; }
.progress-md { height: 12px; }
.progress-lg { height: 16px; }
.progress-xl { height: 24px; }
.progress .progress-bar { height: 100%; background: var(--kim-accent); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 600; text-shadow: 0 1px 1px rgba(0,0,0,.25); transition: width .3s ease; }

/* Striped Progress Bar - Enhanced */
.progress .progress-bar.progress-bar-striped { 
  background-image: linear-gradient(
    45deg, 
    rgba(255,255,255,.5) 25%, 
    transparent 25%, 
    transparent 50%, 
    rgba(255,255,255,.5) 50%, 
    rgba(255,255,255,.5) 75%, 
    transparent 75%, 
    transparent
  ) !important; 
  background-size: 1rem 1rem !important; 
  background-repeat: repeat !important;
}

/* Ensure striped pattern works with all background colors */
.progress .progress-bar.bg-primary.progress-bar-striped,
.progress .progress-bar.bg-secondary.progress-bar-striped,
.progress .progress-bar.bg-success.progress-bar-striped,
.progress .progress-bar.bg-danger.progress-bar-striped,
.progress .progress-bar.bg-warning.progress-bar-striped,
.progress .progress-bar.bg-info.progress-bar-striped,
.progress .progress-bar.bg-light.progress-bar-striped,
.progress .progress-bar.bg-dark.progress-bar-striped {
  background-image: linear-gradient(
    45deg, 
    rgba(255,255,255,.5) 25%, 
    transparent 25%, 
    transparent 50%, 
    rgba(255,255,255,.5) 50%, 
    rgba(255,255,255,.5) 75%, 
    transparent 75%, 
    transparent
  ) !important; 
  background-size: 1rem 1rem !important; 
  background-repeat: repeat !important;
}

/* Animated Progress Bar - Enhanced */
@keyframes kim-progress-stripes { 
  0% { background-position: 0 0; } 
  100% { background-position: 1rem 0; } 
}

@keyframes kim-progress-stripes-transform { 
  0% { transform: translateX(0); } 
  100% { transform: translateX(-1rem); } 
}

@keyframes simple-pulse { 
  0% { opacity: 1; } 
  50% { opacity: 0.5; } 
  100% { opacity: 1; } 
}

/* Try a different animation approach */
@keyframes progress-animation {
  0% { 
    background-image: linear-gradient(45deg, rgba(255,255,255,.5) 25%, transparent 25%, transparent 50%, rgba(255,255,255,.5) 50%, rgba(255,255,255,.5) 75%, transparent 75%, transparent);
    background-position: 0 0;
  }
  100% { 
    background-image: linear-gradient(45deg, rgba(255,255,255,.5) 25%, transparent 25%, transparent 50%, rgba(255,255,255,.5) 50%, rgba(255,255,255,.5) 75%, transparent 75%, transparent);
    background-position: 1rem 0;
  }
}

/* Very simple animation test */
@keyframes blink {
  0%, 50% { opacity: 1; }
  51%, 100% { opacity: 0.3; }
}

/* Working moving stripes animation */
@keyframes moving-stripes {
  0% { background-position: 0 0; }
  100% { background-position: 1rem 0; }
}

.progress .progress-bar.progress-bar-animated { 
  animation: moving-stripes 1s linear infinite !important; 
  background-image: linear-gradient(
    45deg, 
    rgba(255,255,255,.5) 25%, 
    transparent 25%, 
    transparent 50%, 
    rgba(255,255,255,.5) 50%, 
    rgba(255,255,255,.5) 75%, 
    transparent 75%, 
    transparent
  ) !important; 
  background-size: 1rem 1rem !important; 
  background-repeat: repeat !important;
}

/* Ensure animation works with all background color variants */
.progress .progress-bar.bg-primary.progress-bar-animated,
.progress .progress-bar.bg-secondary.progress-bar-animated,
.progress .progress-bar.bg-success.progress-bar-animated,
.progress .progress-bar.bg-danger.progress-bar-animated,
.progress .progress-bar.bg-warning.progress-bar-animated,
.progress .progress-bar.bg-info.progress-bar-animated,
.progress .progress-bar.bg-light.progress-bar-animated,
.progress .progress-bar.bg-dark.progress-bar-animated {
  animation: moving-stripes 1s linear infinite !important; 
  background-image: linear-gradient(
    45deg, 
    rgba(255,255,255,.5) 25%, 
    transparent 25%, 
    transparent 50%, 
    rgba(255,255,255,.5) 50%, 
    rgba(255,255,255,.5) 75%, 
    transparent 75%, 
    transparent
  ) !important; 
  background-size: 1rem 1rem !important; 
  background-repeat: repeat !important;
}

/* Simple pulse animation test */
.progress .progress-bar.progress-bar-animated-simple { 
  animation: simple-pulse 1s ease-in-out infinite !important; 
}

/* Alternative animation using transform */
.progress .progress-bar.progress-bar-animated-alt { 
  animation: kim-progress-stripes-transform 1s linear infinite !important; 
  background-image: linear-gradient(
    45deg, 
    rgba(255,255,255,.5) 25%, 
    transparent 25%, 
    transparent 50%, 
    rgba(255,255,255,.5) 50%, 
    rgba(255,255,255,.5) 75%, 
    transparent 75%, 
    transparent
  ) !important; 
  background-size: 1rem 1rem !important; 
  background-repeat: repeat !important;
}

/* Enhanced Progress Variants */
.progress-gradient .progress-bar { background: linear-gradient(45deg, var(--kim-primary), var(--kim-accent)); }
.progress-rounded { border-radius: 12px; }
.progress-rounded .progress-bar { border-radius: 12px; }

/* Outlined Progress Bar - Fixed Size */
.progress-outlined { 
  background: transparent; 
  border: 2px solid var(--kim-border); 
  box-shadow: none;
  height: 20px !important; /* Increased height */
}
.progress-outlined .progress-bar { 
  background: var(--kim-primary); 
  border-radius: 8px; 
  margin: 2px; 
  height: calc(100% - 4px);
  max-width: calc(100% - 4px);
}

/* Multi-step Progress */
.progress-multi-step { display: flex; align-items: center; justify-content: space-between; margin: 20px 0; }
.progress-step { display: flex; flex-direction: column; align-items: center; flex: 1; position: relative; }
.progress-step:not(:last-child)::after { content: ''; position: absolute; top: 20px; left: 50%; width: 100%; height: 2px; background: var(--kim-border); z-index: 1; }
.progress-step.active:not(:last-child)::after { background: var(--kim-primary); }
.progress-step-circle { width: 40px; height: 40px; border-radius: 50%; background: var(--kim-border); color: var(--kim-text); display: flex; align-items: center; justify-content: center; font-weight: 600; font-size: 14px; position: relative; z-index: 2; transition: all 0.3s ease; }
.progress-step.active .progress-step-circle { background: var(--kim-primary); color: #fff; box-shadow: 0 2px 8px rgba(0,0,0,0.2); }
.progress-step-label { margin-top: 8px; font-size: 12px; color: var(--kim-text-muted); text-align: center; }
.progress-step.active .progress-step-label { color: var(--kim-primary); font-weight: 500; }



/* Spinner Variants */
@keyframes kim-spin { to { transform: rotate(360deg); } }
.spinner-border { width: 2rem; height: 2rem; border: 3px solid currentColor; border-right-color: transparent; border-radius: 50%; animation: kim-spin .8s linear infinite; }
@keyframes kim-grow { 0% { transform: scale(.25); opacity: .6; } 50% { transform: scale(1); opacity: 1; } 100% { transform: scale(.25); opacity: .6; } }
.spinner-grow { width: 2rem; height: 2rem; border-radius: 50%; background: currentColor; animation: kim-grow .8s ease-in-out infinite; }
.spinner-border-sm { width: 1rem; height: 1rem; border-width: 2px; }
.spinner-grow-sm { width: 1rem; height: 1rem; }
.spinner-border-lg { width: 3rem; height: 3rem; border-width: 4px; }
.spinner-grow-lg { width: 3rem; height: 3rem; }

/* Custom Spinners */
.spinner-dots { display: flex; align-items: center; justify-content: center; gap: 4px; }
.spinner-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--kim-primary); animation: spinner-dots 1.4s ease-in-out infinite both; }
.spinner-dot:nth-child(1) { animation-delay: -0.32s; }
.spinner-dot:nth-child(2) { animation-delay: -0.16s; }
@keyframes spinner-dots { 0%, 80%, 100% { transform: scale(0); } 40% { transform: scale(1); } }

.spinner-pulse { width: 2rem; height: 2rem; border-radius: 50%; background: var(--kim-primary); animation: spinner-pulse 1s ease-in-out infinite; }
@keyframes spinner-pulse { 0% { transform: scale(0.95); opacity: 0.7; } 50% { transform: scale(1.05); opacity: 1; } 100% { transform: scale(0.95); opacity: 0.7; } }

.spinner-wave { display: flex; align-items: center; justify-content: center; gap: 2px; }
.spinner-wave-bar { width: 3px; height: 20px; background: var(--kim-primary); border-radius: 2px; animation: spinner-wave 1.2s ease-in-out infinite; }
.spinner-wave-bar:nth-child(1) { animation-delay: -1.2s; }
.spinner-wave-bar:nth-child(2) { animation-delay: -1.1s; }
.spinner-wave-bar:nth-child(3) { animation-delay: -1.0s; }
.spinner-wave-bar:nth-child(4) { animation-delay: -0.9s; }
.spinner-wave-bar:nth-child(5) { animation-delay: -0.8s; }
@keyframes spinner-wave { 0%, 40%, 100% { transform: scaleY(0.4); } 20% { transform: scaleY(1); } }

/* Loading States */
.loading-card { background: var(--kim-surface); border: 1px solid var(--kim-border); border-radius: var(--kim-radius-md); padding: 16px; }
.loading-header { margin-bottom: 12px; }
.loading-title { height: 20px; background: var(--kim-border); border-radius: 4px; margin-bottom: 8px; animation: loading-pulse 1.5s ease-in-out infinite; }
.loading-subtitle { height: 14px; background: var(--kim-border); border-radius: 4px; width: 60%; animation: loading-pulse 1.5s ease-in-out infinite 0.2s; }
.loading-line { height: 12px; background: var(--kim-border); border-radius: 4px; margin-bottom: 8px; animation: loading-pulse 1.5s ease-in-out infinite; }
.loading-line:nth-child(2) { animation-delay: 0.1s; }
.loading-line:nth-child(3) { animation-delay: 0.2s; }
@keyframes loading-pulse { 0%, 100% { opacity: 0.6; } 50% { opacity: 1; } }

.loading-skeleton { display: flex; align-items: center; gap: 12px; }
.skeleton-avatar { width: 40px; height: 40px; border-radius: 50%; background: var(--kim-border); animation: loading-pulse 1.5s ease-in-out infinite; }
.skeleton-content { flex: 1; }
.skeleton-line { height: 14px; background: var(--kim-border); border-radius: 4px; margin-bottom: 6px; animation: loading-pulse 1.5s ease-in-out infinite; }
.skeleton-line-short { width: 70%; }

/* Additional Skeleton Variants */

/* Table Skeleton */
.skeleton-table {
  border: 1px solid var(--kim-border);
  border-radius: var(--kim-radius-md);
  overflow: hidden;
}

.skeleton-table-header {
  background: var(--kim-surface-alt);
  padding: 12px 16px;
  border-bottom: 1px solid var(--kim-border);
}

.skeleton-table-row {
  display: flex;
  padding: 12px 16px;
  border-bottom: 1px solid var(--kim-border);
  align-items: center;
}

.skeleton-table-row:last-child {
  border-bottom: none;
}

.skeleton-table-cell {
  flex: 1;
  height: 16px;
  background: var(--kim-border);
  border-radius: 4px;
  margin-right: 16px;
  animation: loading-pulse 1.5s ease-in-out infinite;
}

.skeleton-table-cell:last-child {
  margin-right: 0;
}

.skeleton-table-cell.small {
  flex: 0.5;
}

.skeleton-table-cell.medium {
  flex: 0.7;
}

/* Card Grid Skeleton */
.skeleton-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 16px;
}

.skeleton-card {
  background: var(--kim-surface);
  border: 1px solid var(--kim-border);
  border-radius: var(--kim-radius-md);
  padding: 16px;
  animation: loading-pulse 1.5s ease-in-out infinite;
}

.skeleton-card-image {
  width: 100%;
  height: 120px;
  background: var(--kim-border);
  border-radius: var(--kim-radius-sm);
  margin-bottom: 12px;
  animation: loading-pulse 1.5s ease-in-out infinite;
}

.skeleton-card-title {
  height: 20px;
  background: var(--kim-border);
  border-radius: 4px;
  margin-bottom: 8px;
  animation: loading-pulse 1.5s ease-in-out infinite;
}

.skeleton-card-text {
  height: 14px;
  background: var(--kim-border);
  border-radius: 4px;
  margin-bottom: 6px;
  animation: loading-pulse 1.5s ease-in-out infinite;
}

.skeleton-card-text:last-child {
  width: 60%;
}

/* List Skeleton */
.skeleton-list {
  background: var(--kim-surface);
  border: 1px solid var(--kim-border);
  border-radius: var(--kim-radius-md);
  overflow: hidden;
}

.skeleton-list-item {
  display: flex;
  align-items: center;
  padding: 12px 16px;
  border-bottom: 1px solid var(--kim-border);
  animation: loading-pulse 1.5s ease-in-out infinite;
}

.skeleton-list-item:last-child {
  border-bottom: none;
}

.skeleton-list-icon {
  width: 24px;
  height: 24px;
  background: var(--kim-border);
  border-radius: 4px;
  margin-right: 12px;
  animation: loading-pulse 1.5s ease-in-out infinite;
}

.skeleton-list-content {
  flex: 1;
}

.skeleton-list-title {
  height: 16px;
  background: var(--kim-border);
  border-radius: 4px;
  margin-bottom: 4px;
  animation: loading-pulse 1.5s ease-in-out infinite;
}

.skeleton-list-subtitle {
  height: 12px;
  background: var(--kim-border);
  border-radius: 4px;
  width: 70%;
  animation: loading-pulse 1.5s ease-in-out infinite;
}

/* Form Skeleton */
.skeleton-form {
  background: var(--kim-surface);
  border: 1px solid var(--kim-border);
  border-radius: var(--kim-radius-md);
  padding: 20px;
}

.skeleton-form-group {
  margin-bottom: 16px;
}

.skeleton-form-label {
  height: 16px;
  background: var(--kim-border);
  border-radius: 4px;
  margin-bottom: 8px;
  width: 40%;
  animation: loading-pulse 1.5s ease-in-out infinite;
}

.skeleton-form-input {
  height: 40px;
  background: var(--kim-border);
  border-radius: var(--kim-radius-sm);
  animation: loading-pulse 1.5s ease-in-out infinite;
}

.skeleton-form-textarea {
  height: 80px;
  background: var(--kim-border);
  border-radius: var(--kim-radius-sm);
  animation: loading-pulse 1.5s ease-in-out infinite;
}

.skeleton-form-buttons {
  display: flex;
  gap: 12px;
  margin-top: 20px;
}

.skeleton-form-button {
  height: 36px;
  background: var(--kim-border);
  border-radius: var(--kim-radius-sm);
  flex: 1;
  animation: loading-pulse 1.5s ease-in-out infinite;
}

.skeleton-form-button.secondary {
  flex: 0.5;
}

/* Shimmer Effect Skeleton */
.skeleton-shimmer {
  position: relative;
  overflow: hidden;
  background: var(--kim-border);
  border-radius: 4px;
}

.skeleton-shimmer::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 255, 255, 0.4),
    transparent
  );
  animation: shimmer 1.5s infinite;
}

@keyframes shimmer {
  0% {
    left: -100%;
  }
  100% {
    left: 100%;
  }
}

/* Wave Effect Skeleton */
.skeleton-wave {
  position: relative;
  overflow: hidden;
  background: var(--kim-border);
  border-radius: 4px;
}

.skeleton-wave::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255, 255, 255, 0.3) 50%,
    transparent 100%
  );
  animation: wave 2s infinite;
}

@keyframes wave {
  0% {
    transform: translateX(-100%);
  }
  100% {
    transform: translateX(100%);
  }
}

/* Size Variants */
.skeleton-sm {
  height: 12px;
}

.skeleton-md {
  height: 16px;
}

.skeleton-lg {
  height: 20px;
}

.skeleton-xl {
  height: 24px;
}

/* Rounded Variants */
.skeleton-rounded {
  border-radius: 50px;
}

.skeleton-circle {
  border-radius: 50%;
  width: 40px;
  height: 40px;
}

.skeleton-circle.small {
  width: 24px;
  height: 24px;
}

.skeleton-circle.large {
  width: 60px;
  height: 60px;
}

/* Avatar Component */
.avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--kim-primary);
  color: var(--kim-primary-contrast);
  font-weight: 600;
  border-radius: 50%;
  overflow: visible;
  position: relative;
  flex-shrink: 0;
}

.avatar .avatar-content {
  width: 100%;
  height: 100%;
  border-radius: inherit;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Avatar Sizes */
.avatar-xs {
  width: 24px;
  height: 24px;
  font-size: 10px;
}

.avatar-sm {
  width: 32px;
  height: 32px;
  font-size: 12px;
}

.avatar-md {
  width: 40px;
  height: 40px;
  font-size: 14px;
}

.avatar-lg {
  width: 48px;
  height: 48px;
  font-size: 16px;
}

.avatar-xl {
  width: 64px;
  height: 64px;
  font-size: 20px;
}

.avatar-xxl {
  width: 80px;
  height: 80px;
  font-size: 24px;
}

/* Avatar Shapes */
.avatar.avatar-square {
  border-radius: var(--kim-radius-sm);
}

.avatar.avatar-rounded {
  border-radius: var(--kim-radius-md);
}

.avatar.avatar-pill {
  border-radius: 50px;
}

/* Avatar Variants */
.avatar.avatar-primary {
  background: var(--kim-primary);
  color: var(--kim-primary-contrast);
}

.avatar.avatar-secondary {
  background: var(--kim-secondary);
  color: #fff;
}

.avatar.avatar-success {
  background: var(--kim-accent);
  color: var(--kim-primary-contrast);
}

.avatar.avatar-danger {
  background: var(--kim-danger);
  color: #fff;
}

.avatar.avatar-warning {
  background: var(--kim-warning);
  color: #000;
}

.avatar.avatar-info {
  background: var(--kim-info);
  color: #000;
}

.avatar.avatar-light {
  background: var(--kim-bg-soft);
  color: var(--kim-text);
  border: 1px solid var(--kim-border);
}

.avatar.avatar-dark {
  background: var(--kim-dark);
  color: #fff;
}

/* Avatar with Image */
.avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: inherit;
}

/* Avatar with Icon */
.avatar .avatar-icon {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: inherit;
}

/* Avatar Status Indicator */
.avatar .avatar-status {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  border: 2px solid var(--kim-surface);
  background: var(--kim-success);
}

.avatar-xs .avatar-status,
.avatar-sm .avatar-status {
  width: 6px;
  height: 6px;
  border-width: 1px;
}

.avatar-lg .avatar-status,
.avatar-xl .avatar-status,
.avatar-xxl .avatar-status {
  width: 12px;
  height: 12px;
  border-width: 3px;
}

.avatar-status.online {
  background: var(--kim-accent);
}

.avatar-status.offline {
  background: var(--kim-secondary);
}

.avatar-status.busy {
  background: var(--kim-danger);
}

.avatar-status.away {
  background: var(--kim-warning);
}

/* Avatar Group */
.avatar-group {
  display: inline-flex;
  align-items: center;
  position: relative;
}

.avatar-group .avatar {
  margin-left: -8px;
  border: 2px solid var(--kim-surface);
  transition: transform 0.2s ease;
}

.avatar-group .avatar:first-child {
  margin-left: 0;
}

.avatar-group .avatar:hover {
  transform: translateY(-2px);
  z-index: 1;
}

.avatar-group .avatar-xs,
.avatar-group .avatar-sm {
  margin-left: -4px;
  border-width: 1px;
}

.avatar-group .avatar-lg,
.avatar-group .avatar-xl,
.avatar-group .avatar-xxl {
  margin-left: -12px;
  border-width: 3px;
}

/* Avatar Overflow Button */
.avatar-overflow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--kim-primary);
  color: var(--kim-primary-contrast);
  font-weight: 600;
  border-radius: 50%;
  border: 2px solid var(--kim-surface);
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: 12px;
  min-width: 32px;
  height: 32px;
  margin-left: -8px;
}

.avatar-overflow:hover {
  transform: translateY(-2px);
  z-index: 1;
  background: var(--kim-primary-hover);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

.avatar-overflow.avatar-overflow-xs {
  min-width: 24px;
  height: 24px;
  font-size: 10px;
  margin-left: -4px;
  border-width: 1px;
}

.avatar-overflow.avatar-overflow-sm {
  min-width: 32px;
  height: 32px;
  font-size: 12px;
  margin-left: -4px;
  border-width: 1px;
}

.avatar-overflow.avatar-overflow-md {
  min-width: 40px;
  height: 40px;
  font-size: 14px;
  margin-left: -8px;
  border-width: 2px;
}

.avatar-overflow.avatar-overflow-lg {
  min-width: 48px;
  height: 48px;
  font-size: 16px;
  margin-left: -12px;
  border-width: 3px;
}

.avatar-overflow.avatar-overflow-xl {
  min-width: 64px;
  height: 64px;
  font-size: 20px;
  margin-left: -12px;
  border-width: 3px;
}

.avatar-overflow.avatar-overflow-xxl {
  min-width: 80px;
  height: 80px;
  font-size: 24px;
  margin-left: -12px;
  border-width: 3px;
}

/* Avatar Overflow Variants */
.avatar-overflow.avatar-overflow-primary {
  background: var(--kim-primary);
  color: var(--kim-primary-contrast);
}

.avatar-overflow.avatar-overflow-secondary {
  background: var(--kim-secondary);
  color: #fff;
}

.avatar-overflow.avatar-overflow-success {
  background: var(--kim-accent);
  color: var(--kim-primary-contrast);
}

.avatar-overflow.avatar-overflow-danger {
  background: var(--kim-danger);
  color: #fff;
}

.avatar-overflow.avatar-overflow-warning {
  background: var(--kim-warning);
  color: #000;
}

.avatar-overflow.avatar-overflow-info {
  background: var(--kim-info);
  color: #000;
}

.avatar-overflow.avatar-overflow-light {
  background: var(--kim-bg-soft);
  color: var(--kim-text);
  border: 1px solid var(--kim-border);
}

.avatar-overflow.avatar-overflow-dark {
  background: var(--kim-dark);
  color: #fff;
}

/* Avatar with Badge */
.avatar .avatar-badge {
  position: absolute;
  top: -6px;
  right: -6px;
  min-width: 18px;
  height: 18px;
  padding: 0 6px;
  border-radius: 9px;
  background: var(--kim-danger);
  color: #fff;
  font-size: 10px;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid var(--kim-surface);
  z-index: 10;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
  pointer-events: none;
}

.avatar-xs .avatar-badge,
.avatar-sm .avatar-badge {
  min-width: 14px;
  height: 14px;
  padding: 0 4px;
  font-size: 8px;
  border-width: 1px;
}

.avatar-lg .avatar-badge,
.avatar-xl .avatar-badge,
.avatar-xxl .avatar-badge {
  min-width: 24px;
  height: 24px;
  padding: 0 8px;
  font-size: 12px;
  border-width: 3px;
}

/* Avatar Stack */
.avatar-stack {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.avatar-stack .avatar {
  margin: 0;
  border: none;
}

/* Avatar with Border */
.avatar.avatar-bordered {
  border: 2px solid var(--kim-border);
}

.avatar.avatar-bordered.avatar-primary {
  border-color: var(--kim-primary);
}

.avatar.avatar-bordered.avatar-success {
  border-color: var(--kim-accent);
}

.avatar.avatar-bordered.avatar-danger {
  border-color: var(--kim-danger);
}

.avatar.avatar-bordered.avatar-warning {
  border-color: var(--kim-warning);
}

.avatar.avatar-bordered.avatar-info {
  border-color: var(--kim-info);
}

/* Avatar Loading State */
.avatar.avatar-loading {
  background: var(--kim-border);
  animation: loading-pulse 1.5s ease-in-out infinite;
}

.avatar.avatar-loading::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 255, 255, 0.4),
    transparent
  );
  animation: shimmer 1.5s infinite;
}

/* Responsive Avatars */
@media (max-width: 768px) {
  .avatar-xl {
    width: 56px;
    height: 56px;
    font-size: 18px;
  }
  
  .avatar-xxl {
    width: 72px;
    height: 72px;
    font-size: 22px;
  }
}

/* Theme Switch Component */
.theme-switch {
  position: relative;
  display: inline-block;
  width: 60px;
  height: 32px;
  background: var(--kim-border);
  border-radius: 16px;
  cursor: pointer;
  transition: all 0.3s ease;
  border: 2px solid transparent;
}

.theme-switch:hover {
  background: var(--kim-primary);
  transform: scale(1.05);
}

.theme-switch.active {
  background: var(--kim-primary);
}

.theme-switch .switch-slider {
  position: absolute;
  top: 2px;
  left: 2px;
  width: 24px;
  height: 24px;
  background: #fff;
  border-radius: 50%;
  transition: all 0.3s ease;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
}

.theme-switch.active .switch-slider {
  transform: translateX(28px);
}

.theme-switch .switch-slider::before {
  content: '☀️';
  opacity: 1;
  transition: opacity 0.3s ease;
}

.theme-switch.active .switch-slider::before {
  content: '🌙';
  opacity: 1;
}

/* Theme Switch Sizes */
.theme-switch.theme-switch-sm {
  width: 48px;
  height: 24px;
}

.theme-switch.theme-switch-sm .switch-slider {
  width: 18px;
  height: 18px;
  font-size: 10px;
}

.theme-switch.theme-switch-sm.active .switch-slider {
  transform: translateX(22px);
}

.theme-switch.theme-switch-lg {
  width: 72px;
  height: 40px;
}

.theme-switch.theme-switch-lg .switch-slider {
  width: 32px;
  height: 32px;
  font-size: 14px;
}

.theme-switch.theme-switch-lg.active .switch-slider {
  transform: translateX(32px);
}

/* Floating Action Button (FAB) */
.kimbs-fab-container {
  position: fixed;
  z-index: 1050;
  pointer-events: none;
}

/* Demo mode overrides */
.kimbs-fab-container.kimbs-fab-demo {
  position: absolute !important;
  z-index: 10 !important;
}

.kimbs-fab-backdrop {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: rgba(0, 0, 0, 0.3);
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: auto;
}

.kimbs-fab-backdrop.show {
  opacity: 1;
}

.kimbs-fab-trigger {
  position: relative;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  border: none;
  background: var(--kim-primary);
  color: var(--kim-primary-contrast);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  pointer-events: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  outline: none;
  padding: 0;
  margin: 0;
  /* Transparency control */
  opacity: var(--kimbs-fab-transparency, 1);
  /* Background color control */
  background: var(--kimbs-fab-background-color, var(--kim-primary));
}

.kimbs-fab-trigger:hover {
  transform: scale(1.05);
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.2);
  border-radius: 50%;
}

.kimbs-fab-trigger:active {
  transform: scale(0.95);
  border-radius: 50%;
}

.kimbs-fab-trigger:focus {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15), 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
  outline: none;
  border-radius: 50%;
}

.kimbs-fab-hamburger {
  width: 24px;
  height: 18px;
  position: relative;
  transition: transform 0.3s ease;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
}

.kimbs-fab-line {
  position: absolute;
  width: 100%;
  height: 2px;
  background: currentColor;
  border-radius: 1px;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  transform-origin: center;
  left: 0;
  right: 0;
}

.kimbs-fab-line-1 {
  top: 0;
}

.kimbs-fab-line-2 {
  top: 50%;
  transform: translateY(-50%);
}

.kimbs-fab-line-3 {
  bottom: 0;
}

.kimbs-fab-trigger-open .kimbs-fab-line-1 {
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
}

.kimbs-fab-trigger-open .kimbs-fab-line-2 {
  opacity: 0;
  transform: translateY(-50%) scaleX(0);
}

.kimbs-fab-trigger-open .kimbs-fab-line-3 {
  bottom: 50%;
  transform: translateY(50%) rotate(-45deg);
}

.kimbs-fab-trigger-open {
  border-radius: 50% !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
}

.kimbs-fab-buttons {
  position: absolute;
  display: flex;
  flex-direction: column;
  gap: 12px;
  pointer-events: none;
}

.kimbs-fab-buttons.kimbs-fab-horizontal {
  flex-direction: row;
}

.kimbs-fab-action {
  width: 48px;
  height: 48px;
  border-radius: 50% !important;
  background: var(--kim-surface);
  color: var(--kim-text);
  border: 1px solid var(--kim-border);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  pointer-events: auto;
  opacity: 0;
  transform: scale(0);
  visibility: hidden;
  font-size: 18px;
  font-weight: 500;
  padding: 0 !important;
  margin: 0 !important;
  text-decoration: none;
  /* Ensure circular shape is maintained */
  min-width: auto !important;
  min-height: auto !important;
  max-width: none !important;
  max-height: none !important;
  /* Override any inherited button styles */
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
}

/* Disable transitions when animations are active */
.kimbs-fab-buttons.kimbs-fab-open .kimbs-fab-action {
  transition: none !important;
}

/* Ensure consistent circular shape for all FAB action buttons */
.kimbs-fab-action,
.kimbs-fab-action:hover,
.kimbs-fab-action:focus,
.kimbs-fab-action:active {
  border-radius: 50% !important;
}

/* FAB action button variants */
.kimbs-fab-action.btn-primary {
  background: var(--kim-primary);
  color: var(--kim-primary-contrast);
  border-color: var(--kim-primary);
  border-radius: 50% !important;
}

.kimbs-fab-action.btn-secondary {
  background: var(--kim-secondary);
  color: #fff;
  border-color: var(--kim-secondary);
  border-radius: 50% !important;
}

.kimbs-fab-action.btn-success {
  background: var(--kim-accent);
  color: var(--kim-primary-contrast);
  border-color: var(--kim-accent);
  border-radius: 50% !important;
}

.kimbs-fab-action.btn-danger {
  background: #dc3545;
  color: #fff;
  border-color: #dc3545;
  border-radius: 50% !important;
}

.kimbs-fab-action.btn-warning {
  background: #ffc107;
  color: #000;
  border-color: #ffc107;
  border-radius: 50% !important;
}

.kimbs-fab-action.btn-info {
  background: #17a2b8;
  color: #fff;
  border-color: #17a2b8;
  border-radius: 50% !important;
}


.kimbs-fab-action:hover {
  transform: scale(1.1);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  background: var(--kim-primary);
  color: var(--kim-primary-contrast);
  border-radius: 50% !important;
}

/* Position variants */
.kimbs-fab-bottom-right {
  bottom: 24px;
  right: 24px;
}

.kimbs-fab-bottom-right .kimbs-fab-buttons {
  bottom: 68px;
  right: 0;
}

.kimbs-fab-bottom-right .kimbs-fab-buttons.kimbs-fab-horizontal {
  bottom: 0;
  right: 68px;
}

.kimbs-fab-bottom-left {
  bottom: 24px;
  left: 24px;
}

.kimbs-fab-bottom-left .kimbs-fab-buttons {
  bottom: 68px;
  left: 0;
}

.kimbs-fab-bottom-left .kimbs-fab-buttons.kimbs-fab-horizontal {
  bottom: 0;
  left: 68px;
}

.kimbs-fab-top-right {
  top: 24px;
  right: 24px;
}

.kimbs-fab-top-right .kimbs-fab-buttons {
  top: 68px;
  right: 0;
}

.kimbs-fab-top-right .kimbs-fab-buttons.kimbs-fab-horizontal {
  top: 0;
  right: 68px;
}

.kimbs-fab-top-left {
  top: 24px;
  left: 24px;
}

.kimbs-fab-top-left .kimbs-fab-buttons {
  top: 68px;
  left: 0;
}

.kimbs-fab-top-left .kimbs-fab-buttons.kimbs-fab-horizontal {
  top: 0;
  left: 68px;
}

/* Size variants */
.kimbs-fab-sm .kimbs-fab-trigger {
  width: 48px;
  height: 48px;
}

.kimbs-fab-sm .kimbs-fab-hamburger {
  width: 20px;
  height: 15px;
}

.kimbs-fab-sm .kimbs-fab-action {
  width: 40px;
  height: 40px;
  font-size: 16px;
  border-radius: 50% !important;
}

.kimbs-fab-lg .kimbs-fab-trigger {
  width: 64px;
  height: 64px;
}

.kimbs-fab-lg .kimbs-fab-hamburger {
  width: 28px;
  height: 21px;
}

.kimbs-fab-lg .kimbs-fab-action {
  width: 56px;
  height: 56px;
  font-size: 20px;
  border-radius: 50% !important;
}

/* Animation variants - Force animations to work */
.kimbs-fab-buttons.kimbs-fab-open .kimbs-fab-action {
  animation-delay: var(--kimbs-fab-delay, 0ms) !important;
  animation-fill-mode: forwards !important;
  animation-iteration-count: 1 !important;
  visibility: visible !important;
  border-radius: 50% !important;
}

/* Fade animation - Let animation handle the final state */
.kimbs-fab-buttons.kimbs-fab-fade.kimbs-fab-open .kimbs-fab-action {
  animation: kimbs-fab-fade-in 0.3s ease forwards !important;
}

/* Slide animation - Let animation handle the final state */
.kimbs-fab-buttons.kimbs-fab-slide.kimbs-fab-open .kimbs-fab-action {
  animation: kimbs-fab-slide-in 0.3s ease forwards !important;
}

/* Scale animation - Let animation handle the final state */
.kimbs-fab-buttons.kimbs-fab-scale.kimbs-fab-open .kimbs-fab-action {
  animation: kimbs-fab-scale-in 0.3s cubic-bezier(0.4, 0, 0.2, 1) forwards !important;
}

/* Bounce animation - Let animation handle the final state */
.kimbs-fab-buttons.kimbs-fab-bounce.kimbs-fab-open .kimbs-fab-action {
  animation: kimbs-fab-bounce-in 0.5s cubic-bezier(0.68, -0.55, 0.265, 1.55) forwards !important;
}

/* Closing animations - ensure they can play before hiding */
.kimbs-fab-buttons.kimbs-fab-fade:not(.kimbs-fab-open) .kimbs-fab-action {
  animation: kimbs-fab-fade-out 0.3s ease forwards !important;
  visibility: visible !important;
  border-radius: 50% !important;
}

.kimbs-fab-buttons.kimbs-fab-slide:not(.kimbs-fab-open) .kimbs-fab-action {
  animation: kimbs-fab-slide-out 0.3s ease forwards !important;
  visibility: visible !important;
  border-radius: 50% !important;
}

.kimbs-fab-buttons.kimbs-fab-scale:not(.kimbs-fab-open) .kimbs-fab-action {
  animation: kimbs-fab-scale-out 0.3s cubic-bezier(0.4, 0, 0.2, 1) forwards !important;
  visibility: visible !important;
  border-radius: 50% !important;
}

.kimbs-fab-buttons.kimbs-fab-bounce:not(.kimbs-fab-open) .kimbs-fab-action {
  animation: kimbs-fab-bounce-out 0.5s cubic-bezier(0.68, -0.55, 0.265, 1.55) forwards !important;
  visibility: visible !important;
  border-radius: 50% !important;
}

/* Animations */
@keyframes kimbs-fab-fade-in {
  from {
    opacity: 0;
    transform: scale(0);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes kimbs-fab-slide-in {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes kimbs-fab-scale-in {
  from {
    opacity: 0;
    transform: scale(0);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes kimbs-fab-bounce-in {
  0% {
    opacity: 0;
    transform: scale(0);
  }
  50% {
    opacity: 1;
    transform: scale(1.2);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

/* Closing animations */
@keyframes kimbs-fab-fade-out {
  from {
    opacity: 1;
    transform: scale(1);
  }
  to {
    opacity: 0;
    transform: scale(0);
  }
}

@keyframes kimbs-fab-slide-out {
  from {
    opacity: 1;
    transform: translateY(0);
  }
  to {
    opacity: 0;
    transform: translateY(20px);
  }
}

@keyframes kimbs-fab-scale-out {
  from {
    opacity: 1;
    transform: scale(1);
  }
  to {
    opacity: 0;
    transform: scale(0);
  }
}

@keyframes kimbs-fab-bounce-out {
  0% {
    opacity: 1;
    transform: scale(1);
  }
  50% {
    opacity: 1;
    transform: scale(1.1);
  }
  100% {
    opacity: 0;
    transform: scale(0);
  }
}

/* Prevent flash on page load - ensure FABs are completely hidden initially */
.kimbs-fab-container:not(.kimbs-fab-open) .kimbs-fab-buttons {
  opacity: 0 !important;
  visibility: hidden !important;
}

.kimbs-fab-container:not(.kimbs-fab-open) .kimbs-fab-action {
  opacity: 0 !important;
  visibility: hidden !important;
  transform: scale(0) !important;
  pointer-events: none !important;
}

/* Override when FAB is open */
.kimbs-fab-container.kimbs-fab-open .kimbs-fab-buttons {
  opacity: 1 !important;
  visibility: visible !important;
}

.kimbs-fab-container.kimbs-fab-open .kimbs-fab-action {
  pointer-events: auto !important;
}

/* Relative positioning - contained within a container */
.kimbs-fab-relative {
  position: absolute !important;
  z-index: 10;
}

.kimbs-fab-relative .kimbs-fab-backdrop {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: transparent !important;
}

/* Override fixed positioning for relative mode */
.kimbs-fab-relative.kimbs-fab-bottom-right {
  position: absolute !important;
  bottom: 16px;
  right: 16px;
}

.kimbs-fab-relative.kimbs-fab-bottom-left {
  position: absolute !important;
  bottom: 16px;
  left: 16px;
}

.kimbs-fab-relative.kimbs-fab-top-right {
  position: absolute !important;
  top: 16px;
  right: 16px;
}

.kimbs-fab-relative.kimbs-fab-top-left {
  position: absolute !important;
  top: 16px;
  left: 16px;
}

/* Image Component Styles */
.kimbs-image-container {
  position: relative;
  display: inline-block;
  overflow: hidden;
  box-shadow: 0 8px 28px rgba(0,0,0,0.12);
  transition: box-shadow 0.3s ease, transform 0.2s ease;
}
.kimbs-image-container:hover { box-shadow: 0 12px 36px rgba(0,0,0,0.18); }

.kimbs-image-thumb {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Shapes */
.kimbs-image-rectangle { border-radius: 0; }
.kimbs-image-rounded { border-radius: 12px; }
.kimbs-image-circle { border-radius: 50%; }
.kimbs-image-square { border-radius: 0; }

/* Hover animations */
.kimbs-image-fade .kimbs-image-thumb { transition: opacity 0.3s ease, transform 0.3s ease; }
.kimbs-image-fade:hover .kimbs-image-thumb { opacity: 0.95; transform: scale(1.02); }

.kimbs-image-slide .kimbs-image-thumb { transition: transform 0.3s ease; }
.kimbs-image-slide:hover .kimbs-image-thumb { transform: translateY(-4px); }

.kimbs-image-scale .kimbs-image-thumb { transition: transform 0.3s ease; }
.kimbs-image-scale:hover .kimbs-image-thumb { transform: scale(1.05); }

.kimbs-image-bounce .kimbs-image-thumb { transition: transform 0.3s cubic-bezier(0.68,-0.55,0.265,1.55); }
.kimbs-image-bounce:hover .kimbs-image-thumb { transform: scale(1.08); }

/* Overlay viewer */
.kimbs-image-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.9);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1200;
  animation: kimbs-image-overlay-in 180ms ease;
  backdrop-filter: blur(4px);
}
@keyframes kimbs-image-overlay-in { from { opacity: 0; } to { opacity: 1; } }

.kimbs-image-viewer {
  position: relative;
  max-width: calc(100vw - 40px);
  max-height: calc(100vh - 40px);
  width: 90vw;
  height: 90vh;
  overflow: hidden;
  border-radius: 12px;
  box-shadow: 0 30px 80px rgba(0,0,0,0.4);
  background: rgba(0,0,0,0.2);
  cursor: grab;
}
.kimbs-image-viewer:active { cursor: grabbing; }

.kimbs-image-full {
  display: block;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  transform-origin: center center;
  transition: transform 120ms ease;
  user-select: none;
  pointer-events: none;
}

.kimbs-image-close-btn {
  position: absolute;
  top: 15px;
  right: 15px;
  z-index: 1000;
  width: 40px;
  height: 40px;
  border: none;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.7);
  color: white;
  font-size: 18px;
  font-weight: bold;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
  backdrop-filter: blur(4px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.kimbs-image-close-btn:hover {
  background: rgba(220, 53, 69, 0.9);
  transform: scale(1.1);
  box-shadow: 0 6px 16px rgba(220, 53, 69, 0.4);
}

.kimbs-image-close-btn:active {
  transform: scale(0.95);
}

/* Theme Switch Variants */
.theme-switch.theme-switch-primary.active {
  background: var(--kim-primary);
}

.theme-switch.theme-switch-success.active {
  background: var(--kim-accent);
}

.theme-switch.theme-switch-danger.active {
  background: var(--kim-danger);
}

.theme-switch.theme-switch-warning.active {
  background: var(--kim-warning);
}

.theme-switch.theme-switch-info.active {
  background: var(--kim-info);
}

/* Theme Switch with Labels */
.theme-switch-container {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 500;
}

.theme-switch-container .theme-label {
  color: var(--kim-text);
  transition: color 0.3s ease;
}

.theme-switch-container .theme-label.active {
  color: var(--kim-primary);
}

/* Theme Switch Disabled State */
.theme-switch.theme-switch-disabled {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}

.theme-switch.theme-switch-disabled:hover {
  transform: none;
  background: var(--kim-border);
}

/* Background color utilities for components like progress bar */
.bg-primary { background: var(--kim-primary) !important; color: var(--kim-primary-contrast) !important; }
.bg-secondary { background: var(--kim-secondary) !important; color: #fff !important; }
.bg-success { background: var(--kim-accent) !important; color: #0b0f14 !important; }
.bg-danger { background: var(--kim-danger) !important; color: #fff !important; }
.bg-warning { background: var(--kim-warning) !important; color: #000 !important; }
.bg-info { background: var(--kim-info) !important; color: #000 !important; }
.bg-light { background: var(--kim-bg-soft) !important; color: var(--kim-text) !important; }
.bg-dark { background: var(--kim-dark) !important; color: #fff !important; }

/* Position and spacing helpers used in demo */
.position-relative { position: relative; }
.position-absolute { position: absolute; }
.top-0 { top: 0; }
.end-0 { right: 0; }
.p-3 { padding: 16px; }
.my-3 { margin-top: 16px; margin-bottom: 16px; }
.mt-2 { margin-top: 8px; }
.mb-2 { margin-bottom: 8px; }
.mx-2 { margin-left: 8px; margin-right: 8px; }
.d-flex { display: flex; }
.align-items-center { align-items: center; }
.gap-3 { gap: 12px; }
.me-auto { margin-right: auto; }
.g-2 { gap: 8px; }
.d-none { display: none !important; }
@media (min-width: 768px) { .d-md-block { display: block !important; } }

/* Accordion & Collapse */
.accordion { 
  border: none;
  border-radius: 0;
  overflow: hidden; 
  background: transparent;
  box-shadow: none;
}

/* Theme-specific accordion styles */
:root[data-theme="light"] .accordion {
  background: transparent;
}

:root[data-theme="light"] .accordion-button {
  background: var(--kim-surface-alt, #f8f9fa);
  border: 1px solid var(--kim-border, #e9ecef);
  color: var(--kim-text, #495057);
}

:root[data-theme="light"] .accordion-button:hover {
  background: var(--kim-surface-hover, #e9ecef);
  border-color: var(--kim-primary, #667eea);
}

:root[data-theme="light"] .accordion-button:not(.collapsed) {
  background: var(--kim-surface, #ffffff);
  border-color: var(--kim-primary, #667eea);
  color: var(--kim-text, #2c3e50);
}

:root[data-theme="light"] .accordion-body {
  background: var(--kim-surface, #ffffff);
  color: var(--kim-textmuted, #6c757d);
  border: 1px solid var(--kim-border, #e9ecef);
}

:root[data-theme="dark"] .accordion {
  background: transparent;
}

:root[data-theme="dark"] .accordion-button {
  background: var(--kim-surface-alt, #2d3748);
  border: 1px solid var(--kim-border, #4a5568);
  color: var(--kim-text, #e2e8f0);
}

:root[data-theme="dark"] .accordion-button:hover {
  background: var(--kim-surface-hover, #4a5568);
  border-color: var(--kim-primary, #667eea);
}

:root[data-theme="dark"] .accordion-button:not(.collapsed) {
  background: var(--kim-surface, #1a202c);
  border-color: var(--kim-primary, #667eea);
  color: var(--kim-text, #f7fafc);
}

:root[data-theme="dark"] .accordion-body {
  background: var(--kim-surface, #1a202c);
  color: var(--kim-textmuted, #a0aec0);
  border: 1px solid var(--kim-border, #4a5568);
}

:root[data-theme="contrast"] .accordion {
  background: transparent;
}

:root[data-theme="contrast"] .accordion-button {
  background: var(--kim-surface-alt, #000000);
  border: 2px solid var(--kim-border, #ffffff);
  color: var(--kim-text, #ffffff);
}

:root[data-theme="contrast"] .accordion-button:hover {
  background: var(--kim-surface-hover, #333333);
  border-color: var(--kim-primary, #ffff00);
}

:root[data-theme="contrast"] .accordion-button:not(.collapsed) {
  background: var(--kim-surface, #000000);
  border-color: var(--kim-primary, #ffff00);
  color: var(--kim-text, #ffffff);
}

:root[data-theme="contrast"] .accordion-body {
  background: var(--kim-surface, #000000);
  color: var(--kim-textmuted, #ffffff);
  border: 2px solid var(--kim-border, #ffffff);
}

:root[data-theme="frosted"] .accordion {
  background: transparent;
}

:root[data-theme="frosted"] .accordion-button {
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: var(--kim-text, #ffffff);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

:root[data-theme="frosted"] .accordion-button:hover {
  background: rgba(255, 255, 255, 0.15);
  border-color: var(--kim-primary, #667eea);
  backdrop-filter: blur(15px);
  -webkit-backdrop-filter: blur(15px);
}

:root[data-theme="frosted"] .accordion-button:not(.collapsed) {
  background: rgba(255, 255, 255, 0.2);
  border-color: var(--kim-primary, #667eea);
  color: var(--kim-text, #ffffff);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}

:root[data-theme="frosted"] .accordion-body {
  background: rgba(255, 255, 255, 0.1);
  color: var(--kim-textmuted, #e2e8f0);
  border: 1px solid rgba(255, 255, 255, 0.2);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.accordion-item + .accordion-item { 
  border-top: none;
  margin-top: 0;
}

.accordion-header { 
  background: transparent; 
}

.accordion-button {
  width: 100%; 
  text-align: left; 
  padding: 20px 24px 0 24px; 
  background: #f8f9fa;
  border: 1px solid #e9ecef;
  border-radius: 12px;
  cursor: pointer; 
  font-weight: 600;
  color: #495057;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 15px;
  position: relative;
  overflow: hidden;
  margin-bottom: 0;
}

/* Theme-specific base accordion button styles */
:root[data-theme="light"] .accordion-button {
  background: var(--kim-surface-alt, #f8f9fa);
  border: 1px solid var(--kim-border, #e9ecef);
  color: var(--kim-text, #495057);
}

:root[data-theme="dark"] .accordion-button {
  background: var(--kim-surface-alt, #2d3748);
  border: 1px solid var(--kim-border, #4a5568);
  color: var(--kim-text, #e2e8f0);
}

:root[data-theme="contrast"] .accordion-button {
  background: var(--kim-surface-alt, #000000);
  border: 2px solid var(--kim-border, #ffffff);
  color: var(--kim-text, #ffffff);
}

:root[data-theme="frosted"] .accordion-button {
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: var(--kim-text, #ffffff);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.accordion-button::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  opacity: 0;
  transition: opacity 0.3s ease;
  z-index: 0;
}

.accordion-button:hover {
  background: #e9ecef;
  border-color: #dee2e6;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

/* Theme-specific base accordion hover styles */
:root[data-theme="light"] .accordion-button:hover {
  background: var(--kim-border, #e9ecef);
  border-color: var(--kim-border, #dee2e6);
}

:root[data-theme="dark"] .accordion-button:hover {
  background: var(--kim-border, #4a5568);
  border-color: var(--kim-border, #4a5568);
}

:root[data-theme="contrast"] .accordion-button:hover {
  background: var(--kim-border, #ffffff);
  border-color: var(--kim-border, #ffffff);
}

:root[data-theme="frosted"] .accordion-button:hover {
  background: rgba(255, 255, 255, 0.2);
  border-color: rgba(255, 255, 255, 0.3);
}

.accordion-button:hover::before {
  opacity: 0.05;
}

.accordion-button.collapsed { 
  opacity: 1; 
}

.accordion-button:not(.collapsed) {
  background: #ffffff;
  border-color: #667eea;
  box-shadow: 0 4px 20px rgba(102, 126, 234, 0.15);
}

/* Theme-specific base accordion active styles */
:root[data-theme="light"] .accordion-button:not(.collapsed) {
  background: var(--kim-surface, #ffffff);
  border-color: var(--kim-primary, #667eea);
}

:root[data-theme="dark"] .accordion-button:not(.collapsed) {
  background: var(--kim-surface, #1a202c);
  border-color: var(--kim-primary, #667eea);
}

:root[data-theme="contrast"] .accordion-button:not(.collapsed) {
  background: var(--kim-surface, #000000);
  border-color: var(--kim-primary, #667eea);
}

:root[data-theme="frosted"] .accordion-button:not(.collapsed) {
  background: rgba(255, 255, 255, 0.15);
  border-color: var(--kim-primary, #667eea);
}

.accordion-body { 
  padding: 20px 24px;
  color: #6c757d;
  line-height: 1.6;
  font-size: 14px;
  background: #ffffff;
  border: 1px solid #e9ecef;
  border-top: none;
  border-radius: 0 0 12px 12px;
  margin-top: -1px;
}

/* Theme-specific base accordion body styles */
:root[data-theme="light"] .accordion-body {
  background: var(--kim-surface, #ffffff);
  color: var(--kim-textmuted, #6c757d);
  border: 1px solid var(--kim-border, #e9ecef);
}

:root[data-theme="dark"] .accordion-body {
  background: var(--kim-surface, #1a202c);
  color: var(--kim-textmuted, #a0aec0);
  border: 1px solid var(--kim-border, #4a5568);
}

:root[data-theme="contrast"] .accordion-body {
  background: var(--kim-surface, #000000);
  color: var(--kim-textmuted, #ffffff);
  border: 2px solid var(--kim-border, #ffffff);
}

:root[data-theme="frosted"] .accordion-body {
  background: rgba(255, 255, 255, 0.1);
  color: var(--kim-textmuted, #e2e8f0);
  border: 1px solid rgba(255, 255, 255, 0.2);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.collapse { display: none; }
.collapse.show { display: block; }

/* Accordion Variants */
.accordion.accordion-flush {
  border: none;
  border-radius: 0;
  background: transparent;
}

/* Theme-specific variant styles */
:root[data-theme="light"] .accordion.accordion-flush .accordion-button {
  background: var(--kim-surface-alt, #f8f9fa);
  border: 1px solid var(--kim-border, #e9ecef);
  color: var(--kim-text, #495057);
}

:root[data-theme="dark"] .accordion.accordion-flush .accordion-button {
  background: var(--kim-surface-alt, #2d3748);
  border: 1px solid var(--kim-border, #4a5568);
  color: var(--kim-text, #e2e8f0);
}

:root[data-theme="contrast"] .accordion.accordion-flush .accordion-button {
  background: var(--kim-surface-alt, #000000);
  border: 2px solid var(--kim-border, #ffffff);
  color: var(--kim-text, #ffffff);
}

:root[data-theme="frosted"] .accordion.accordion-flush .accordion-button {
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: var(--kim-text, #ffffff);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.accordion.accordion-flush .accordion-item {
  border: none;
  margin-bottom: 0;
  background: transparent;
}



.accordion.accordion-flush .accordion-header {
  background: transparent;
}

.accordion.accordion-flush .accordion-button {
  padding: 16px 20px 0 20px;
  font-weight: 600;
  color: #495057;
  transition: all 0.3s ease;
  font-size: 15px;
  background: #f8f9fa;
  border: 1px solid #e9ecef;
  border-radius: 8px;
  margin-bottom: 0;
}

.accordion.accordion-flush .accordion-button:hover {
  color: #667eea;
  background: #e9ecef;
  border-color: #667eea;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(102, 126, 234, 0.15);
}

/* Theme-specific flush hover styles */
:root[data-theme="light"] .accordion.accordion-flush .accordion-button:hover {
  color: var(--kim-primary, #667eea);
  background: var(--kim-border, #e9ecef);
  border-color: var(--kim-primary, #667eea);
}

:root[data-theme="dark"] .accordion.accordion-flush .accordion-button:hover {
  color: var(--kim-primary, #667eea);
  background: var(--kim-border, #4a5568);
  border-color: var(--kim-primary, #667eea);
}

:root[data-theme="contrast"] .accordion.accordion-flush .accordion-button:hover {
  color: var(--kim-primary, #667eea);
  background: var(--kim-border, #ffffff);
  border-color: var(--kim-primary, #667eea);
}

:root[data-theme="frosted"] .accordion.accordion-flush .accordion-button:hover {
  color: var(--kim-primary, #667eea);
  background: rgba(255, 255, 255, 0.2);
  border-color: var(--kim-primary, #667eea);
}

.accordion.accordion-flush .accordion-body {
  padding: 16px 20px;
  color: #6c757d;
  line-height: 1.6;
  font-size: 14px;
  background: #ffffff;
  border: 1px solid #e9ecef;
  border-top: none;
  border-radius: 0 0 8px 8px;
  margin-top: -1px;
}

/* Theme-specific flush body styles */
:root[data-theme="light"] .accordion.accordion-flush .accordion-body {
  background: var(--kim-surface, #ffffff);
  color: var(--kim-textmuted, #6c757d);
  border: 1px solid var(--kim-border, #e9ecef);
}

:root[data-theme="dark"] .accordion.accordion-flush .accordion-body {
  background: var(--kim-surface, #1a202c);
  color: var(--kim-textmuted, #a0aec0);
  border: 1px solid var(--kim-border, #4a5568);
}

:root[data-theme="contrast"] .accordion.accordion-flush .accordion-body {
  background: var(--kim-surface, #000000);
  color: var(--kim-textmuted, #ffffff);
  border: 2px solid var(--kim-border, #ffffff);
}

:root[data-theme="frosted"] .accordion.accordion-flush .accordion-body {
  background: rgba(255, 255, 255, 0.1);
  color: var(--kim-textmuted, #e2e8f0);
  border: 1px solid rgba(255, 255, 255, 0.2);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

/* Bordered Accordion */
.accordion.accordion-bordered {
  border: 2px solid #e9ecef;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
  background: #ffffff;
  padding: 4px;
}

/* Theme-specific bordered variant styles */
:root[data-theme="light"] .accordion.accordion-bordered {
  border: 2px solid var(--kim-border, #e9ecef);
  background: var(--kim-surface, #ffffff);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
}

:root[data-theme="dark"] .accordion.accordion-bordered {
  border: 2px solid var(--kim-border, #4a5568);
  background: var(--kim-surface, #1a202c);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
}

:root[data-theme="contrast"] .accordion.accordion-bordered {
  border: 3px solid var(--kim-border, #ffffff);
  background: var(--kim-surface, #000000);
  box-shadow: 0 8px 32px rgba(255, 255, 255, 0.2);
}

:root[data-theme="frosted"] .accordion.accordion-bordered {
  border: 2px solid rgba(255, 255, 255, 0.3);
  background: rgba(255, 255, 255, 0.1);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
  backdrop-filter: blur(15px);
  -webkit-backdrop-filter: blur(15px);
}

.accordion.accordion-bordered .accordion-item {
  border-top: 2px solid #f1f3f4;
  background: transparent;
  margin: 0;
}

.accordion.accordion-bordered .accordion-item:first-child {
  border-top: none;
  margin-top: 0;
  margin-bottom: 0;
}

.accordion.accordion-bordered .accordion-header {
  background: transparent;
}

.accordion.accordion-bordered .accordion-button {
  padding: 24px 32px 0 32px;
  font-weight: 700;
  color: #2c3e50;
  transition: all 0.3s ease;
  font-size: 16px;
  background: linear-gradient(135deg, #f8f9fa 0%, #ffffff 100%);
  border: 2px solid #e9ecef;
  border-radius: 16px;
  position: relative;
  margin-bottom: 0;
}

/* Theme-specific bordered button styles */
:root[data-theme="light"] .accordion.accordion-bordered .accordion-button {
  background: linear-gradient(135deg, var(--kim-surface-alt, #f8f9fa) 0%, var(--kim-surface, #ffffff) 100%);
  border: 2px solid var(--kim-border, #e9ecef);
  color: var(--kim-text, #2c3e50);
}

:root[data-theme="dark"] .accordion.accordion-bordered .accordion-button {
  background: linear-gradient(135deg, var(--kim-surface-alt, #2d3748) 0%, var(--kim-surface, #1a202c) 100%);
  border: 2px solid var(--kim-border, #4a5568);
  color: var(--kim-text, #e2e8f0);
}

:root[data-theme="contrast"] .accordion.accordion-bordered .accordion-button {
  background: linear-gradient(135deg, var(--kim-surface-alt, #000000) 0%, var(--kim-surface, #000000) 100%);
  border: 3px solid var(--kim-border, #ffffff);
  color: var(--kim-text, #ffffff);
}

:root[data-theme="frosted"] .accordion.accordion-bordered .accordion-button {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.1) 0%, rgba(255, 255, 255, 0.05) 100%);
  border: 2px solid rgba(255, 255, 255, 0.3);
  color: var(--kim-text, #ffffff);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.accordion.accordion-bordered .accordion-button:hover {
  background: linear-gradient(135deg, #e9ecef 0%, #f8f9fa 100%);
  border-color: #667eea;
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(102, 126, 234, 0.2);
}

.accordion.accordion-bordered .accordion-button:not(.collapsed) {
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  color: #ffffff;
  border-color: #667eea;
  box-shadow: 0 8px 25px rgba(102, 126, 234, 0.3);
}

.accordion.accordion-bordered .accordion-body {
  padding: 24px 32px;
  color: #6c757d;
  line-height: 1.7;
  font-size: 15px;
  background: #ffffff;
  border: 2px solid #e9ecef;
  border-top: none;
  border-radius: 0 0 16px 16px;
  margin: 0 4px;
  margin-top: -2px;
}

/* Theme-specific bordered body styles */
:root[data-theme="light"] .accordion.accordion-bordered .accordion-body {
  background: var(--kim-surface, #ffffff);
  color: var(--kim-textmuted, #6c757d);
  border: 2px solid var(--kim-border, #e9ecef);
}

:root[data-theme="dark"] .accordion.accordion-bordered .accordion-body {
  background: var(--kim-surface, #1a202c);
  color: var(--kim-textmuted, #a0aec0);
  border: 2px solid var(--kim-border, #4a5568);
}

:root[data-theme="contrast"] .accordion.accordion-bordered .accordion-body {
  background: var(--kim-surface, #000000);
  color: var(--kim-textmuted, #ffffff);
  border: 3px solid var(--kim-border, #ffffff);
}

:root[data-theme="frosted"] .accordion.accordion-bordered .accordion-body {
  background: rgba(255, 255, 255, 0.1);
  color: var(--kim-textmuted, #e2e8f0);
  border: 2px solid rgba(255, 255, 255, 0.3);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

/* Card-like Accordion */
.accordion.accordion-card {
  border: none;
  border-radius: 0;
  background: transparent;
}

/* Theme-specific card variant styles */
:root[data-theme="light"] .accordion.accordion-card .accordion-item {
  background: var(--kim-surface, #ffffff);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

:root[data-theme="dark"] .accordion.accordion-card .accordion-item {
  background: var(--kim-surface, #1a202c);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

:root[data-theme="contrast"] .accordion.accordion-card .accordion-item {
  background: var(--kim-surface, #000000);
  box-shadow: 0 2px 8px rgba(255, 255, 255, 0.2);
}

:root[data-theme="frosted"] .accordion.accordion-card .accordion-item {
  background: rgba(255, 255, 255, 0.1);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.accordion.accordion-card .accordion-item {
  border: none;
  border-radius: 24px;
  margin-bottom: 0;
  box-shadow: none;
  background: #ffffff;
  overflow: hidden;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
}



.accordion.accordion-card .accordion-item:hover {
  box-shadow: none;
  transform: none;
}





.accordion.accordion-card .accordion-header {
  background: #ffffff;
  border-radius: 24px 24px 0 0;
  margin-bottom: 0;
}

.accordion.accordion-card .accordion-button {
  padding: 32px 36px 0 36px;
  font-weight: 700;
  color: #2c3e50;
  border-radius: 24px 24px 0 0;
  transition: all 0.3s ease;
  font-size: 17px;
  background: #ffffff;
  border: none;
  position: relative;
  margin-bottom: 0;
}

/* Theme-specific card button styles */
:root[data-theme="light"] .accordion.accordion-card .accordion-button {
  background: var(--kim-surface, #ffffff);
  color: var(--kim-text, #2c3e50);
}

:root[data-theme="dark"] .accordion.accordion-card .accordion-button {
  background: var(--kim-surface, #1a202c);
  color: var(--kim-text, #e2e8f0);
}

:root[data-theme="contrast"] .accordion.accordion-card .accordion-button {
  background: var(--kim-surface, #000000);
  color: var(--kim-text, #ffffff);
}

:root[data-theme="frosted"] .accordion.accordion-card .accordion-button {
  background: rgba(255, 255, 255, 0.1);
  color: var(--kim-text, #ffffff);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.accordion.accordion-card .accordion-button:hover {
  background: #f8f9fa;
  color: #667eea;
}

.accordion.accordion-card .accordion-button:not(.collapsed) {
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  color: #ffffff;
}

.accordion.accordion-card .accordion-body {
  padding: 24px 36px 36px 36px;
  color: #6c757d;
  line-height: 1.7;
  font-size: 15px;
  background: #ffffff;
  border-radius: 0 0 24px 24px;
  margin-top: 0;
}

/* Theme-specific card body styles */
:root[data-theme="light"] .accordion.accordion-card .accordion-body {
  background: var(--kim-surface, #ffffff);
  color: var(--kim-textmuted, #6c757d);
}

:root[data-theme="dark"] .accordion.accordion-card .accordion-body {
  background: var(--kim-surface, #1a202c);
  color: var(--kim-textmuted, #a0aec0);
}

:root[data-theme="contrast"] .accordion.accordion-card .accordion-body {
  background: var(--kim-surface, #000000);
  color: var(--kim-textmuted, #ffffff);
}

:root[data-theme="frosted"] .accordion.accordion-card .accordion-body {
  background: rgba(255, 255, 255, 0.1);
  color: var(--kim-textmuted, #e2e8f0);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

/* Minimal Accordion */
.accordion.accordion-minimal {
  border: none;
  border-radius: 0;
  background: transparent;
}

/* Theme-specific minimal variant styles */
:root[data-theme="light"] .accordion.accordion-minimal .accordion-item::after {
  background: linear-gradient(90deg, transparent, var(--kim-border, #e9ecef), transparent);
}

:root[data-theme="dark"] .accordion.accordion-minimal .accordion-item::after {
  background: linear-gradient(90deg, transparent, var(--kim-border, #4a5568), transparent);
}

:root[data-theme="contrast"] .accordion.accordion-minimal .accordion-item::after {
  background: linear-gradient(90deg, transparent, var(--kim-border, #ffffff), transparent);
}

:root[data-theme="frosted"] .accordion.accordion-minimal .accordion-item::after {
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
}

.accordion.accordion-minimal .accordion-item {
  border: none;
  margin-bottom: 0;
  background: transparent;
  position: relative;
}



.accordion.accordion-minimal .accordion-item::after {
  content: '';
  position: absolute;
  bottom: -10px;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, #e9ecef, transparent);
}

.accordion.accordion-minimal .accordion-header {
  background: transparent;
}

.accordion.accordion-minimal .accordion-button {
  padding: 20px 0 0 0;
  font-weight: 600;
  color: #495057;
  transition: all 0.3s ease;
  font-size: 16px;
  background: transparent;
  border: none;
  position: relative;
  margin-bottom: 0;
}

/* Theme-specific minimal button styles */
:root[data-theme="light"] .accordion.accordion-minimal .accordion-button {
  color: var(--kim-text, #495057);
}

:root[data-theme="dark"] .accordion.accordion-minimal .accordion-button {
  color: var(--kim-text, #e2e8f0);
}

:root[data-theme="contrast"] .accordion.accordion-minimal .accordion-button {
  color: var(--kim-text, #ffffff);
}

:root[data-theme="frosted"] .accordion.accordion-minimal .accordion-button {
  color: var(--kim-text, #ffffff);
}

.accordion.accordion-minimal .accordion-button::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  width: 0;
  height: 2px;
  background: linear-gradient(90deg, #667eea, #764ba2);
  transition: width 0.3s ease;
  transform: translateY(-50%);
}

.accordion.accordion-minimal .accordion-button:hover {
  color: #667eea;
  background: transparent;
  padding-left: 20px;
}

.accordion.accordion-minimal .accordion-button:hover::before {
  width: 16px;
}

.accordion.accordion-minimal .accordion-button:not(.collapsed) {
  color: #667eea;
  padding-left: 20px;
}

.accordion.accordion-minimal .accordion-button:not(.collapsed)::before {
  width: 16px;
}

.accordion.accordion-minimal .accordion-body {
  padding: 0 0 24px 20px;
  color: #6c757d;
  line-height: 1.7;
  font-size: 15px;
  background: transparent;
  border-left: 2px solid #e9ecef;
  margin-left: 8px;
}

/* Theme-specific minimal body styles */
:root[data-theme="light"] .accordion.accordion-minimal .accordion-body {
  color: var(--kim-textmuted, #6c757d);
  border-left: 2px solid var(--kim-border, #e9ecef);
}

:root[data-theme="dark"] .accordion.accordion-minimal .accordion-body {
  color: var(--kim-textmuted, #a0aec0);
  border-left: 2px solid var(--kim-border, #4a5568);
}

:root[data-theme="contrast"] .accordion.accordion-minimal .accordion-body {
  color: var(--kim-textmuted, #ffffff);
  border-left: 3px solid var(--kim-border, #ffffff);
}

:root[data-theme="frosted"] .accordion.accordion-minimal .accordion-body {
  color: var(--kim-textmuted, #e2e8f0);
  border-left: 2px solid rgba(255, 255, 255, 0.3);
}

/* Rounded Accordion */
.accordion.accordion-rounded {
  border-radius: 32px;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
  border: none;
  background: linear-gradient(135deg, #f8f9fa 0%, #ffffff 100%);
  padding: 8px;
}

/* Theme-specific rounded variant styles */
:root[data-theme="light"] .accordion.accordion-rounded {
  background: linear-gradient(135deg, var(--kim-surface-alt, #f8f9fa) 0%, var(--kim-surface, #ffffff) 100%);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
}

:root[data-theme="dark"] .accordion.accordion-rounded {
  background: linear-gradient(135deg, var(--kim-surface-alt, #2d3748) 0%, var(--kim-surface, #1a202c) 100%);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
}

:root[data-theme="contrast"] .accordion.accordion-rounded {
  background: linear-gradient(135deg, var(--kim-surface-alt, #000000) 0%, var(--kim-surface, #000000) 100%);
  box-shadow: 0 8px 32px rgba(255, 255, 255, 0.2);
}

:root[data-theme="frosted"] .accordion.accordion-rounded {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.1) 0%, rgba(255, 255, 255, 0.05) 100%);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
  backdrop-filter: blur(15px);
  -webkit-backdrop-filter: blur(15px);
}

.accordion.accordion-rounded .accordion-item:first-child .accordion-header {
  border-top-left-radius: 24px;
  border-top-right-radius: 24px;
}

.accordion.accordion-rounded .accordion-item:last-child .accordion-body {
  border-bottom-left-radius: 24px;
  border-bottom-right-radius: 24px;
}

.accordion.accordion-rounded .accordion-header {
  background: transparent;
}

.accordion.accordion-rounded .accordion-button {
  padding: 28px 32px 0 32px;
  font-weight: 700;
  color: #2c3e50;
  transition: all 0.3s ease;
  font-size: 16px;
  background: #ffffff;
  border: 1px solid #e9ecef;
  border-radius: 24px;
  position: relative;
  overflow: hidden;
  margin-bottom: 0;
}

/* Theme-specific rounded button styles */
:root[data-theme="light"] .accordion.accordion-rounded .accordion-button {
  background: var(--kim-surface, #ffffff);
  color: var(--kim-text, #2c3e50);
  border: 1px solid var(--kim-border, #e9ecef);
}

:root[data-theme="dark"] .accordion.accordion-rounded .accordion-button {
  background: var(--kim-surface, #1a202c);
  color: var(--kim-text, #e2e8f0);
  border: 1px solid var(--kim-border, #4a5568);
}

:root[data-theme="contrast"] .accordion.accordion-rounded .accordion-button {
  background: var(--kim-surface, #000000);
  color: var(--kim-text, #ffffff);
  border: 2px solid var(--kim-border, #ffffff);
}

:root[data-theme="frosted"] .accordion.accordion-rounded .accordion-button {
  background: rgba(255, 255, 255, 0.1);
  color: var(--kim-text, #ffffff);
  border: 1px solid rgba(255, 255, 255, 0.3);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.accordion.accordion-rounded .accordion-button::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(102, 126, 234, 0.1), transparent);
  transition: left 0.5s ease;
}

.accordion.accordion-rounded .accordion-button:hover {
  background: #f8f9fa;
  border-color: #667eea;
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(102, 126, 234, 0.15);
}

.accordion.accordion-rounded .accordion-button:hover::before {
  left: 100%;
}

.accordion.accordion-rounded .accordion-button:not(.collapsed) {
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  color: #ffffff;
  border-color: #667eea;
  box-shadow: 0 8px 25px rgba(102, 126, 234, 0.25);
}

.accordion.accordion-rounded .accordion-body {
  padding: 24px 32px;
  color: #6c757d;
  line-height: 1.7;
  font-size: 15px;
  background: #ffffff;
  border: 1px solid #e9ecef;
  border-top: none;
  border-radius: 0 0 24px 24px;
  margin: 0 8px;
  margin-top: -1px;
}

/* Theme-specific rounded body styles */
:root[data-theme="light"] .accordion.accordion-rounded .accordion-body {
  background: var(--kim-surface, #ffffff);
  color: var(--kim-textmuted, #6c757d);
  border: 1px solid var(--kim-border, #e9ecef);
}

:root[data-theme="dark"] .accordion.accordion-rounded .accordion-body {
  background: var(--kim-surface, #1a202c);
  color: var(--kim-textmuted, #a0aec0);
  border: 1px solid var(--kim-border, #4a5568);
}

:root[data-theme="contrast"] .accordion.accordion-rounded .accordion-body {
  background: var(--kim-surface, #000000);
  color: var(--kim-textmuted, #ffffff);
  border: 2px solid var(--kim-border, #ffffff);
}

:root[data-theme="frosted"] .accordion.accordion-rounded .accordion-body {
  background: rgba(255, 255, 255, 0.1);
  color: var(--kim-textmuted, #e2e8f0);
  border: 1px solid rgba(255, 255, 255, 0.3);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

/* Accordion Sizes */
.accordion.accordion-sm .accordion-button {
  padding: 8px 12px;
  font-size: 14px;
}

.accordion.accordion-sm .accordion-body {
  padding: 8px 12px;
  font-size: 14px;
}

.accordion.accordion-lg .accordion-button {
  padding: 20px 24px;
  font-size: 18px;
  font-weight: 600;
}

.accordion.accordion-lg .accordion-body {
  padding: 24px;
  font-size: 16px;
}

/* Accordion with Icons */
.accordion-button .accordion-icon {
  font-size: 12px;
  color: var(--kim-text-muted);
  transition: all 0.3s ease;
  margin-left: 8px;
  opacity: 0.7;
}

.accordion-button:hover .accordion-icon {
  opacity: 1;
  color: var(--kim-primary);
}

.accordion-button.collapsed .accordion-icon {
  transform: rotate(-90deg);
}

.accordion-button:not(.collapsed) .accordion-icon {
  transform: rotate(0deg);
  color: var(--kim-primary);
  opacity: 1;
}

/* Accordion Color Variants */
.accordion.accordion-primary .accordion-button {
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  color: #ffffff;
  border-color: #667eea;
}

.accordion.accordion-primary .accordion-button:hover {
  background: linear-gradient(135deg, #5a6fd8 0%, #6a4190 100%);
  border-color: #5a6fd8;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(102, 126, 234, 0.2);
}

.accordion.accordion-primary .accordion-button:not(.collapsed) {
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  color: #ffffff;
  border-color: #667eea;
}

.accordion.accordion-primary .accordion-icon {
  color: #ffffff;
}

.accordion.accordion-success .accordion-button {
  background: linear-gradient(135deg, #28a745 0%, #20c997 100%);
  color: #ffffff;
  border-color: #28a745;
}

.accordion.accordion-success .accordion-button:hover {
  background: linear-gradient(135deg, #218838 0%, #1ea085 100%);
  border-color: #218838;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(40, 167, 69, 0.2);
}

.accordion.accordion-success .accordion-button:not(.collapsed) {
  background: linear-gradient(135deg, #28a745 0%, #20c997 100%);
  color: #ffffff;
  border-color: #28a745;
}

.accordion.accordion-success .accordion-icon {
  color: #ffffff;
}

.accordion.accordion-danger .accordion-button {
  background: linear-gradient(135deg, #dc3545 0%, #e83e8c 100%);
  color: #ffffff;
  border-color: #dc3545;
}

.accordion.accordion-danger .accordion-button:hover {
  background: linear-gradient(135deg, #c82333 0%, #d63384 100%);
  border-color: #c82333;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(220, 53, 69, 0.2);
}

.accordion.accordion-danger .accordion-button:not(.collapsed) {
  background: linear-gradient(135deg, #dc3545 0%, #e83e8c 100%);
  color: #ffffff;
  border-color: #dc3545;
}

.accordion.accordion-danger .accordion-icon {
  color: #ffffff;
}

.accordion.accordion-warning .accordion-button {
  background: linear-gradient(135deg, #ffc107 0%, #fd7e14 100%);
  color: #000000;
  border-color: #ffc107;
}

.accordion.accordion-warning .accordion-button:hover {
  background: linear-gradient(135deg, #e0a800 0%, #e8590c 100%);
  border-color: #e0a800;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(255, 193, 7, 0.2);
}

.accordion.accordion-warning .accordion-button:not(.collapsed) {
  background: linear-gradient(135deg, #ffc107 0%, #fd7e14 100%);
  color: #000000;
  border-color: #ffc107;
}

.accordion.accordion-warning .accordion-icon {
  color: #000000;
}

.accordion.accordion-info .accordion-button {
  background: linear-gradient(135deg, #17a2b8 0%, #6f42c1 100%);
  color: #ffffff;
  border-color: #17a2b8;
}

.accordion.accordion-info .accordion-button:hover {
  background: linear-gradient(135deg, #138496 0%, #5a32a3 100%);
  border-color: #138496;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(23, 162, 184, 0.2);
}

.accordion.accordion-info .accordion-button:not(.collapsed) {
  background: linear-gradient(135deg, #17a2b8 0%, #6f42c1 100%);
  color: #ffffff;
  border-color: #17a2b8;
}

.accordion.accordion-info .accordion-icon {
  color: #ffffff;
}

/* Tabs */
.tab-content { border: 1px solid var(--kim-border); border-top: 0; border-radius: 0 0 var(--kim-radius-sm) var(--kim-radius-sm); padding: 12px; position: relative; z-index: 0; background: var(--kim-surface); }
.tab-pane { display: none; }
.tab-pane.active.show { display: block; }
.fade { transition: opacity .15s linear; }
.fade:not(.show) { opacity: 0; }

/* Carousel */
.carousel { 
  position: relative; 
  width: 100%;
  max-width: 100%;
  overflow: hidden;
}

.carousel-inner { 
  position: relative; 
  width: 100%; 
  height: 100%;
  overflow: hidden; 
}

.carousel-item { 
  display: none; 
  width: 100%;
  height: 100%;
  position: relative;
}

.carousel-item.active { 
  display: block; 
}

.carousel-item img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  background: #f8f9fa;
  margin: 0 auto;
}

/* Carousel size variants */
.carousel.carousel-sm {
  max-width: 400px;
  height: 200px;
}

.carousel.carousel-md {
  max-width: 600px;
  height: 300px;
}

.carousel.carousel-lg {
  max-width: 800px;
  height: 400px;
}

.carousel.carousel-xl {
  max-width: 1000px;
  height: 500px;
}

/* Responsive carousel heights */
@media (max-width: 768px) {
  .carousel.carousel-lg,
  .carousel.carousel-xl {
    height: 300px;
  }
}

@media (max-width: 576px) {
  .carousel.carousel-md,
  .carousel.carousel-lg,
  .carousel.carousel-xl {
    height: 200px;
  }
}

/* Fixed height carousel */
.carousel.carousel-fixed-height {
  height: 300px;
}

/* All carousel images should use consistent sizing */
.carousel-item img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  background: #f8f9fa;
}
.carousel-control-prev, .carousel-control-next { position: absolute; top: 50%; transform: translateY(-50%); background: rgba(0,0,0,.35); color: #fff; border: 0; border-radius: 999px; width: 36px; height: 36px; display: grid; place-items: center; z-index: 2; }
.carousel-control-prev { left: 10px; }
.carousel-control-next { right: 10px; }
.carousel-control-prev-icon, .carousel-control-next-icon { width: 16px; height: 16px; display: inline-block; }
.carousel-control-prev-icon { border-left: 2px solid #fff; border-bottom: 2px solid #fff; transform: rotate(45deg); }
.carousel-control-next-icon { border-right: 2px solid #fff; border-bottom: 2px solid #fff; transform: rotate(-45deg); }
.carousel-caption { position: absolute; left: 0; right: 0; bottom: 10px; color: #fff; text-shadow: 0 1px 2px rgba(0,0,0,.5); }

/* Indicators */
.carousel-indicators { position: absolute; left: 0; right: 0; bottom: 8px; display: flex; justify-content: center; gap: 6px; margin: 0; padding: 0; list-style: none; z-index: 3; }
.carousel-indicators button { width: 10px; height: 10px; border-radius: 999px; border: 0; background: rgba(255,255,255,.5); cursor: pointer; }
.carousel-indicators .active, .carousel-indicators button.active { background: var(--kim-primary); }

/* Caption alignment & position */
.text-start { text-align: left !important; }
.text-center { text-align: center !important; }
.text-end { text-align: right !important; }
.caption-top { top: 10px; bottom: auto; }
.caption-bottom { bottom: 10px; top: auto; }

/* Dark variant */
.carousel.carousel-dark .carousel-caption { color: var(--kim-text); text-shadow: none; }
.carousel.carousel-dark .carousel-control-prev, .carousel.carousel-dark .carousel-control-next { background: rgba(0,0,0,.15); color: var(--kim-text); }

/* Fade variant: stack slides and fade between */
.carousel.carousel-fade .carousel-inner { position: relative; }
.carousel.carousel-fade .carousel-item { position: absolute; top: 0; left: 0; width: 100%; display: block; opacity: 0; transition: opacity .5s ease; }
.carousel.carousel-fade .carousel-item.active { position: relative; opacity: 1; z-index: 1; }

/* Button group / toolbar */
.btn-group { display: inline-flex; align-items: center; vertical-align: middle; }
.btn-group > .btn { position: relative; }
.btn-group > .btn + .btn { margin-left: -1px; }
.btn-group > .btn:not(:first-child) { border-top-left-radius: 0; border-bottom-left-radius: 0; }
.btn-group > .btn:not(:last-child) { border-top-right-radius: 0; border-bottom-right-radius: 0; }
.btn-group-vertical { display: inline-flex; flex-direction: column; align-items: stretch; }
.btn-group-vertical > .btn + .btn { margin-top: -1px; margin-left: 0; }
.btn-group-vertical > .btn:not(:first-child) { border-top-left-radius: 0; border-top-right-radius: 0; }
.btn-group-vertical > .btn:not(:last-child) { border-bottom-left-radius: 0; border-bottom-right-radius: 0; }

/* Button group sizes */
.btn-group-sm > .btn { padding: 4px 8px; font-size: 12px; border-radius: 3px; min-height: 28px; }
.btn-group-lg > .btn { padding: 12px 20px; font-size: 16px; border-radius: 6px; min-height: 48px; }
.btn-toolbar { display: flex; flex-wrap: wrap; gap: 8px; }

/* Offcanvas - Basic styles only, enhanced styles below */
.offcanvas-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,.5); z-index: 1040; }
.offcanvas { position: fixed; z-index: 1045; background: var(--kim-surface); color: var(--kim-text); border: 1px solid var(--kim-border); box-shadow: var(--kim-shadow-lg); }
.offcanvas-header { display: flex; align-items: center; padding: 12px 16px; border-bottom: 1px solid var(--kim-border); }
.offcanvas-body { padding: 16px; overflow-y: auto; }

/* Basic positioning for offcanvas sides - these are fallbacks */
.offcanvas-start { top: 0; bottom: 0; left: 0; width: 320px; }
.offcanvas-end { top: 0; bottom: 0; right: 0; width: 320px; }
.offcanvas-top { top: 0; left: 0; right: 0; height: 300px; }
.offcanvas-bottom { bottom: 0; left: 0; right: 0; height: 300px; }

/* Modal sizes */
.code-editor-modal-dialog.modal-lg { max-width: 800px; }
.code-editor-modal-dialog.modal-sm { max-width: 360px; }

/* Text color utilities for spinner variants and general use */
.text-primary { color: var(--kim-primary) !important; }
.text-secondary { color: var(--kim-secondary) !important; }
.text-success { color: var(--kim-accent) !important; }
.text-danger { color: var(--kim-danger) !important; }
.text-warning { color: var(--kim-warning) !important; }
.text-info { color: var(--kim-info) !important; }
.text-light { color: var(--kim-light) !important; }
.text-dark { color: var(--kim-dark) !important; }

/* Scrollspy nav container */
.kim-scrollspy-nav { position: sticky; top: 0; background: var(--kim-surface); padding: 6px; border: 1px solid var(--kim-border); border-radius: var(--kim-radius-sm); box-shadow: var(--kim-shadow-sm); z-index: 100; }

/* Tables */
.table-responsive { width: 100%; overflow-x: auto; }
.table { width: 100%; border-collapse: collapse; background: var(--kim-surface); color: var(--kim-text); }
.table th, .table td { padding: 10px 12px; border-top: 1px solid var(--kim-border); text-align: left; vertical-align: top; }
.table thead th { border-bottom: 2px solid var(--kim-border); font-weight: 700; }
.table-striped tbody tr:nth-of-type(odd) { background: color-mix(in oklab, var(--kim-text) 4%, var(--kim-surface)); }
.table-hover tbody tr:hover { background: var(--kim-surface-alt); }
.table-bordered { border: 1px solid var(--kim-border); }
.table-bordered th, .table-bordered td { border: 1px solid var(--kim-border); }
.table-sm th, .table-sm td { padding: 6px 8px; }
.table-dark { background: var(--kim-dark); color: #fff; }
.table-dark th, .table-dark td { border-color: color-mix(in oklab, #ffffff 20%, var(--kim-dark)); }
.table-dark thead th { border-bottom-color: color-mix(in oklab, #ffffff 35%, var(--kim-dark)); }

/* DataTable visuals */
.kim-datatable .kim-dt-controls .form-control { max-width: 320px; }
.kim-datatable .kim-dt-controls .form-select { width: 120px; }
.kim-datatable table thead th.sortable { cursor: pointer; position: relative; user-select: none; }
.kim-datatable table thead th.sortable[aria-sort="ascending"]::after { content: "▲"; position: absolute; right: 8px; opacity: .6; font-size: 11px; }
.kim-datatable table thead th.sortable[aria-sort="descending"]::after { content: "▼"; position: absolute; right: 8px; opacity: .6; font-size: 11px; }
.kim-datatable .summary { color: var(--kim-text-muted); }

/* Frosted tables */
:root[data-theme="frosted"] .table { backdrop-filter: blur(16px) saturate(140%); -webkit-backdrop-filter: blur(16px) saturate(140%); }

/* Frosted scrollspy nav container */
:root[data-theme="frosted"] .kim-scrollspy-nav { 
  backdrop-filter: blur(30px) saturate(180%) brightness(1.1);
  -webkit-backdrop-filter: blur(30px) saturate(180%) brightness(1.1);
  background: rgba(255, 255, 255, 0.15);
  border: 1px solid rgba(255, 255, 255, 0.3);
  box-shadow: 
    0 8px 32px rgba(0, 0, 0, 0.1),
    0 2px 8px rgba(0, 0, 0, 0.05),
    inset 0 1px 0 rgba(255, 255, 255, 0.2);
}

/* Frosted scrollspy nav links */
:root[data-theme="frosted"] .kim-scrollspy-nav .nav-link {
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.2);
  transition: all 0.3s ease;
}

:root[data-theme="frosted"] .kim-scrollspy-nav .nav-link:hover {
  backdrop-filter: blur(25px) saturate(170%);
  -webkit-backdrop-filter: blur(25px) saturate(170%);
  background: rgba(255, 255, 255, 0.2);
  border-color: rgba(255, 255, 255, 0.3);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

:root[data-theme="frosted"] .kim-scrollspy-nav .nav-link.active {
  backdrop-filter: blur(35px) saturate(200%) brightness(1.15);
  -webkit-backdrop-filter: blur(35px) saturate(200%) brightness(1.15);
  background: rgba(26, 115, 232, 0.25);
  border-color: rgba(26, 115, 232, 0.4);
  box-shadow: 
    0 6px 20px rgba(26, 115, 232, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.3);
  transform: translateY(-2px);
}

/* Code Pane */
.kim-codepane { border: 1px solid var(--kim-border); border-radius: var(--kim-radius-md); background: var(--kim-surface); box-shadow: var(--kim-shadow-sm); overflow: hidden; }
.kim-codepane-header { display: flex; align-items: center; justify-content: space-between; padding: 8px 10px; background: var(--kim-surface-alt); border-bottom: 1px solid var(--kim-border); }
.kim-codepane-lang { font-weight: 700; color: var(--kim-text); }
.kim-codepane-body { overflow: auto; }
.kim-codepane-table { width: 100%; border-collapse: collapse; table-layout: fixed; font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; font-size: 13px; line-height: 1.35; }
.kim-codepane-table td { vertical-align: top; padding: 0; }
.kim-codepane-table .ln { width: 48px; padding: 0 8px; text-align: right; color: var(--kim-text-muted); background: color-mix(in oklab, var(--kim-text) 4%, var(--kim-surface)); border-right: 1px solid var(--kim-border); user-select: none; }
.kim-codepane-table .code { padding: 0 10px; white-space: pre; }
.kim-codepane-table .code code { tab-size: 2; }
.kim-codepane.wrap .kim-codepane-table .code { white-space: pre-wrap; word-break: break-word; }

/* Code tokens */
.tok-comment { color: #6b7280; font-style: italic; }
.tok-string { color: #16a34a; }
.tok-number { color: #0ea5e9; }
.tok-keyword { color: #8b5cf6; font-weight: 600; }
.tok-boolean { color: #f59e0b; }
.tok-null { color: #ef4444; }
.tok-punc { color: var(--kim-text); }
.kim-codepane .code { color: var(--kim-text); }
.tok-tag { color: #2563eb; }
.tok-attr { color: #dc2626; }
.tok-attr-value { color: #16a34a; }
.tok-type { color: #0ea5e9; font-weight: 600; }
.tok-ident { color: var(--kim-text); }
.tok-ident-global { text-decoration: underline dotted; }
.tok-ident-local { opacity: 0.95; }
.tok-hl { background: color-mix(in oklab, var(--kim-primary) 20%, transparent); border-radius: 2px; }
.tok-hl-global { outline: 1px dashed color-mix(in oklab, var(--kim-primary) 40%, var(--kim-border)); }
.tok-hl-local { outline: 1px dashed color-mix(in oklab, var(--kim-accent) 40%, var(--kim-border)); }
/* Stronger brace highlight (used by CodeEditor) */
.tok-hl-brace {
  display: inline-block;
	background: rgba(255, 235, 59, 0.65); /* bright yellow */
	color: inherit;
	outline: 2px solid rgba(255, 152, 0, 0.95); /* orange ring */
	border-radius: 2px;
	box-shadow: 0 0 0 2px rgba(255, 235, 59, 0.65);
}

/* Code Editor */
.kim-codeeditor { position: relative; border: 1px solid var(--kim-border); border-radius: var(--kim-radius-md); background: var(--kim-surface); box-shadow: var(--kim-shadow-sm); overflow: hidden; }
.kim-codepane-header { position: relative; z-index: 3; }
.kim-codeeditor-body { position: relative; z-index: 1; }
.kim-codeeditor-overlay { position: absolute; top: 0; left: 0; right: 0; bottom: 0; overflow: hidden; pointer-events: none; z-index: 2; }
.kim-codeeditor-input { position: relative; z-index: 1; background: transparent; color: transparent; -webkit-text-fill-color: transparent; caret-color: var(--kim-text); border: 0; width: 100%; resize: vertical; font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; font-size: 13px; line-height: 1.35; padding: 0 10px 0 58px; white-space: pre; overflow: auto; tab-size: 2; }
.kim-codeeditor-input:focus { outline: none; }
.kim-codeeditor .kim-codepane-table .ln { background: color-mix(in oklab, var(--kim-text) 4%, var(--kim-surface)); }

/* Enhanced Form Styling */
.form-control:focus { border-color: var(--kim-primary); box-shadow: 0 0 0 0.2rem rgba(var(--kim-primary-rgb), 0.25); }
.form-control:hover { border-color: var(--kim-primary); }
.form-select:focus { border-color: var(--kim-primary); box-shadow: 0 0 0 0.2rem rgba(var(--kim-primary-rgb), 0.25); }
.form-select:hover { border-color: var(--kim-primary); }

/* Enhanced Input Groups */
.input-group-text { background-color: var(--kim-surface-alt); border-color: var(--kim-border); color: var(--kim-text-muted); font-weight: 500; }
.input-group:focus-within .input-group-text { border-color: var(--kim-primary); background-color: var(--kim-primary); color: white; }

/* Enhanced Range Slider */
.form-range::-webkit-slider-thumb { background: var(--kim-primary); }
.form-range::-moz-range-thumb { background: var(--kim-primary); }
.form-range::-ms-thumb { background: var(--kim-primary); }

/* Enhanced Color Picker */
.form-control-color { border-radius: var(--kim-radius-sm); cursor: pointer; }
.form-control-color:hover { transform: scale(1.05); transition: transform 0.2s ease; }

/* Ads Component */
.kim-ad { position: relative; border: 1px solid var(--kim-border); border-radius: var(--kim-radius-md); background: var(--kim-surface); box-shadow: var(--kim-shadow-sm); overflow: hidden; transition: all 0.3s ease; }
.kim-ad:hover { box-shadow: var(--kim-shadow-md); transform: translateY(-2px); }
.kim-ad-content { flex: 1; display: flex; align-items: center; justify-content: center; padding: 1.5rem; text-align: center; }
.kim-ad-content[style*="background-image"] { color: white; text-shadow: 0 1px 3px rgba(0,0,0,0.8); }
.kim-ad-content[style*="background-image"] .text-muted { color: rgba(255,255,255,0.9) !important; }
.kim-ad[style*="background-image"] { color: white; }
.kim-ad[style*="background-image"] .kim-ad-content { color: white; text-shadow: 0 1px 3px rgba(0,0,0,0.8); }
.kim-ad[style*="background-image"] .kim-ad-content .text-muted { color: rgba(255,255,255,0.9) !important; }

/* Fix text colors for different variants */
.kim-ad-primary .kim-ad-content { color: white; }
.kim-ad-primary .kim-ad-content .text-muted { color: rgba(255,255,255,0.9) !important; }
.kim-ad-primary .kim-ad-content .fw-bold { color: white; }

.kim-ad-success .kim-ad-content { color: white; }
.kim-ad-success .kim-ad-content .text-muted { color: rgba(255,255,255,0.9) !important; }
.kim-ad-success .kim-ad-content .fw-bold { color: white; }

.kim-ad-warning .kim-ad-content { color: white; }
.kim-ad-warning .kim-ad-content .text-muted { color: rgba(255,255,255,0.9) !important; }
.kim-ad-warning .kim-ad-content .fw-bold { color: white; }

.kim-ad-danger .kim-ad-content { color: white; }
.kim-ad-danger .kim-ad-content .text-muted { color: rgba(255,255,255,0.9) !important; }
.kim-ad-danger .kim-ad-content .fw-bold { color: white; }

.kim-ad-info .kim-ad-content { color: white; }
.kim-ad-info .kim-ad-content .text-muted { color: rgba(255,255,255,0.9) !important; }
.kim-ad-info .kim-ad-content .fw-bold { color: white; }

.kim-ad-gradient .kim-ad-content { color: white; }
.kim-ad-gradient .kim-ad-content .text-muted { color: rgba(255,255,255,0.9) !important; }
.kim-ad-gradient .kim-ad-content .fw-bold { color: white; }

/* Ensure proper contrast for outlined and light variants */
.kim-ad-outlined .kim-ad-content { color: var(--kim-text); }
.kim-ad-outlined .kim-ad-content .text-muted { color: var(--kim-text-muted) !important; }
.kim-ad-outlined .kim-ad-content .fw-bold { color: var(--kim-text); }

.kim-ad-light .kim-ad-content { color: var(--kim-text); }
.kim-ad-light .kim-ad-content .text-muted { color: var(--kim-text-muted) !important; }
.kim-ad-light .kim-ad-content .fw-bold { color: var(--kim-text); }
.kim-ad-popup .kim-ad-content { padding: 2rem; flex-direction: column; gap: 1rem; }
.kim-ad-title { font-weight: 600; margin-bottom: 0.25rem; }
.kim-ad-body { font-size: .95rem; color: var(--kim-text); }
.kim-ad .kim-ad-close { position: absolute; top: 8px; right: 8px; z-index: 10; }

/* Types */
.kim-ad-banner { width: 100%; min-height: 90px; display: flex; align-items: center; justify-content: center; padding: 1rem; }
.kim-ad-sidebar { width: 300px; min-height: 250px; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 1.5rem; }
.kim-ad-popup { position: fixed; z-index: 1060; min-width: 320px; max-width: 480px; box-shadow: var(--kim-shadow-lg); border-radius: var(--kim-radius-lg); }
.kim-ad-interstitial-holder { position: fixed; inset: 0; display: flex; align-items: center; justify-content: center; z-index: 1062; }
.kim-ad-interstitial-backdrop { position: fixed; inset: 0; z-index: 1061; background: rgba(0,0,0,0.35); opacity: 1; transition: opacity .25s ease; }

/* Popup placements */
.kim-ad-pos-top-left { top: 12px; left: 12px; }
.kim-ad-pos-top-right { top: 12px; right: 12px; }
.kim-ad-pos-bottom-left { bottom: 12px; left: 12px; }
.kim-ad-pos-bottom-right { bottom: 12px; right: 12px; }
.kim-ad-pos-center { top: 50%; left: 50%; transform: translate(-50%, -50%); }

/* Sizes */
.kim-ad-small { min-height: 60px; font-size: 0.875rem; }
.kim-ad-medium { min-height: 90px; font-size: 1rem; }
.kim-ad-large { min-height: 120px; font-size: 1.125rem; }
.kim-ad-xl { min-height: 150px; font-size: 1.25rem; }

/* Variants */
.kim-ad-default { background: var(--kim-surface); color: var(--kim-text); }
.kim-ad-primary { background: var(--kim-primary); color: var(--kim-primary-contrast); border-color: var(--kim-primary); }
.kim-ad-success { background: var(--kim-accent); color: #ffffff; border-color: var(--kim-accent); }
.kim-ad-warning { background: var(--kim-warning); color: #000000; border-color: var(--kim-warning); }
.kim-ad-danger { background: var(--kim-danger); color: #ffffff; border-color: var(--kim-danger); }
.kim-ad-info { background: var(--kim-info); color: #000000; border-color: var(--kim-info); }
.kim-ad-outlined { background: transparent; border: 2px solid var(--kim-primary); color: var(--kim-primary); }
.kim-ad-gradient { background: linear-gradient(135deg, var(--kim-primary), var(--kim-info)); color: #ffffff; border: none; }
.kim-ad-light { background: #ffffff; color: #333333; border-color: #e0e0e0; }
.kim-ad-dark { background: #333333; color: #ffffff; border-color: #555555; }
.kim-ad-frosted { backdrop-filter: blur(20px) saturate(140%); -webkit-backdrop-filter: blur(20px) saturate(140%); background: rgba(255, 255, 255, 0.1); border-color: rgba(255, 255, 255, 0.2); }

/* Ribbon label */
.kim-ad-label { position: absolute; top: 8px; left: 8px; font-size: 0.75rem; color: #ffffff; background: rgba(0, 0, 0, 0.55); padding: 3px 8px; border-radius: var(--kim-radius-sm); font-weight: 500; text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3); backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); }
.kim-ad-default .kim-ad-label, .kim-ad-outlined .kim-ad-label, .kim-ad-light .kim-ad-label { color: #333333; background: rgba(255, 255, 255, 0.9); text-shadow: none; border: 1px solid rgba(0, 0, 0, 0.08); }

/* Animations */
.kim-ad-animated { animation: kimAdFadeIn .35s ease-out; }
@keyframes kimAdFadeIn { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
.kim-ad-animated.kim-ad-popup { animation: kimAdPopupIn .3s ease-out; }
@keyframes kimAdPopupIn { from { opacity: 0; transform: translateY(12px) scale(0.98); } to { opacity: 1; transform: translateY(0) scale(1); } }
.kim-ad-interstitial-holder .kim-ad { animation: kimAdScaleIn .25s ease-out; }
@keyframes kimAdScaleIn { from { opacity: 0; transform: scale(0.96); } to { opacity: 1; transform: scale(1); } }

/* Responsive */
@media (max-width: 768px) {
  .kim-ad-sidebar { width: 100%; min-height: 200px; }
  .kim-ad-popup { min-width: 90vw; }
  .kim-ad-banner { min-height: 70px; }
}

/* Frosted theme enhancement */
:root[data-theme="frosted"] .kim-ad-frosted { backdrop-filter: blur(25px) saturate(180%); -webkit-backdrop-filter: blur(25px) saturate(180%); background: rgba(255, 255, 255, 0.15); border-color: rgba(255, 255, 255, 0.3); box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1), 0 2px 8px rgba(0, 0, 0, 0.05); }
/* Enhanced File Input */
.form-control[type="file"] { cursor: pointer; }
.form-control[type="file"]:hover { border-color: var(--kim-primary); }

/* Enhanced Textarea */
textarea.form-control { resize: vertical; min-height: 100px; }
textarea.form-control:focus { border-color: var(--kim-primary); box-shadow: 0 0 0 0.2rem rgba(var(--kim-primary-rgb), 0.25); }

/* Enhanced Search Input */
input[type="search"].form-control { background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath d='M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398h-.001c.03.04.062.078.098.115l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.85-3.85a1.007 1.007 0 0 0-.115-.1zM12 6.5a5.5 5.5 0 1 1-11 0 5.5 5.5 0 0 1 11 0z'/%3e%3c/svg%3e"); background-repeat: no-repeat; background-position: right 0.75rem center; background-size: 16px 12px; padding-right: 2.5rem; }

/* Enhanced Floating Labels */
.form-floating { position: relative; }
.form-floating > .form-control { height: calc(3.5rem + 2px); line-height: 1.25; }
.form-floating > .form-control:focus { border-color: var(--kim-primary); box-shadow: 0 0 0 0.2rem rgba(var(--kim-primary-rgb), 0.25); }
.form-floating > label { position: absolute; top: 0; left: 0; height: 100%; padding: 1rem 0.75rem; pointer-events: none; border: 1px solid transparent; transform-origin: 0 0; transition: opacity 0.1s ease-in-out, transform 0.1s ease-in-out; color: var(--kim-text-muted); }
.form-floating > .form-control:focus ~ label,
.form-floating > .form-control:not(:placeholder-shown) ~ label { opacity: 0.65; transform: scale(0.85) translateY(-0.5rem) translateX(0.15rem); color: var(--kim-primary); }



/* Enhanced Rating Stars */
.btn-outline-warning:hover { background-color: #ffc107; border-color: #ffc107; color: #000; }
.btn-outline-warning:focus { box-shadow: 0 0 0 0.2rem rgba(255, 193, 7, 0.25); }

/* Enhanced Autocomplete Dropdown */
.position-absolute.bg-white { box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15); border-radius: var(--kim-radius-md); }
.position-absolute.bg-white .p-2:hover { background-color: var(--kim-surface-alt); }

/* Enhanced Autocomplete Styling */
.autocomplete-dropdown { 
  box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15); 
  border-radius: var(--kim-radius-md); 
  border: 1px solid var(--kim-border);
  background: white;
  margin-top: 2px;
}

.autocomplete-item { 
  padding: 0.75rem 1rem !important; 
  border-bottom: 1px solid var(--kim-border) !important;
  transition: background-color 0.2s ease;
}

.autocomplete-item:last-child { 
  border-bottom: none !important; 
}

.autocomplete-item:hover { 
  background-color: var(--kim-surface-alt) !important; 
}

.autocomplete-title { 
  font-weight: 600; 
  color: var(--kim-text); 
  font-size: 0.95rem;
  line-height: 1.2;
  margin-bottom: 0.25rem;
}

.autocomplete-subtitle { 
  color: var(--kim-text-muted); 
  font-size: 0.8rem;
  line-height: 1.2;
  margin: 0;
}

/* Enhanced Tags */
.badge { font-size: 0.75em; font-weight: 500; padding: 0.35em 0.65em; }
.badge.bg-primary { background-color: var(--kim-primary) !important; }
.badge:hover { opacity: 0.8; cursor: pointer; }

/* Enhanced Form Sections */
.mb-4 { margin-bottom: 1.5rem !important; }
.text-muted { color: var(--kim-text-muted) !important; }
.h6 { font-size: 1rem; font-weight: 600; margin-bottom: 0.5rem; }

/* Toast Component */
.toast-container {
  position: fixed;
  z-index: 1055;
  pointer-events: none;
  padding: 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

/* Alignment based on placement */
.toast-container.top-left,
.toast-container.middle-left,
.toast-container.bottom-left {
  align-items: flex-start;
}

.toast-container.top-center,
.toast-container.middle-center,
.toast-container.bottom-center {
  align-items: center;
}

.toast-container.top-right,
.toast-container.middle-right,
.toast-container.bottom-right {
  align-items: flex-end;
}

/* Top placements */
.toast-container.top-left {
  top: 0;
  left: 0;
}

.toast-container.top-center {
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}

.toast-container.top-right {
  top: 0;
  right: 0;
}

/* Middle placements */
.toast-container.middle-left {
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}

.toast-container.middle-center {
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.toast-container.middle-right {
  top: 50%;
  right: 0;
  transform: translateY(-50%);
}

/* Bottom placements */
.toast-container.bottom-left {
  bottom: 0;
  left: 0;
}

.toast-container.bottom-center {
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}

.toast-container.bottom-right {
  bottom: 0;
  right: 0;
}

.toast {
  background: var(--kim-surface, #ffffff);
  border: 1px solid var(--kim-border, #dee2e6);
  border-radius: var(--kim-radius-md, 0.375rem);
  box-shadow: var(--kim-shadow-lg, 0 0.5rem 1rem rgba(0, 0, 0, 0.15));
  margin-bottom: 0.5rem;
  max-width: 350px;
  min-width: 250px;
  pointer-events: auto;
  position: relative;
  transition: all 0.3s ease-in-out;
  box-sizing: border-box;
}

/* Ensure each toast maintains its own size */
.toast[data-toast-id] {
  width: auto;
  height: auto;
  flex-shrink: 0;
}

/* Default animation (top-right) */
.toast {
  transform: translateX(100%);
}

.toast.show {
  transform: translateX(0);
}

/* Top-left animation */
.toast-container.top-left .toast {
  transform: translateX(-100%);
}

.toast-container.top-left .toast.show {
  transform: translateX(0);
}

/* Top-center animation */
.toast-container.top-center .toast {
  transform: translateY(-100%);
}

.toast-container.top-center .toast.show {
  transform: translateY(0);
}

/* Middle-left animation */
.toast-container.middle-left .toast {
  transform: translateX(-100%);
}

.toast-container.middle-left .toast.show {
  transform: translateX(0);
}

/* Middle-center animation */
.toast-container.middle-center .toast {
  transform: scale(0.8) translateY(-20px);
  opacity: 0;
}

.toast-container.middle-center .toast.show {
  transform: scale(1) translateY(0);
  opacity: 1;
}

/* Middle-right animation */
.toast-container.middle-right .toast {
  transform: translateX(100%);
}

.toast-container.middle-right .toast.show {
  transform: translateX(0);
}

/* Bottom-left animation */
.toast-container.bottom-left .toast {
  transform: translateX(-100%);
}

.toast-container.bottom-left .toast.show {
  transform: translateX(0);
}

/* Bottom-center animation */
.toast-container.bottom-center .toast {
  transform: translateY(100%);
}

.toast-container.bottom-center .toast.show {
  transform: translateY(0);
}

/* Bottom-right animation */
.toast-container.bottom-right .toast {
  transform: translateX(100%);
}

.toast-container.bottom-right .toast.show {
  transform: translateX(0);
}

.toast-header {
  align-items: center;
  background: var(--kim-surface-alt, #f8f9fa);
  border-bottom: 1px solid var(--kim-border, #dee2e6);
  border-top-left-radius: calc(var(--kim-radius-md, 0.375rem) - 1px);
  border-top-right-radius: calc(var(--kim-radius-md, 0.375rem) - 1px);
  color: var(--kim-text, #212529);
  display: flex;
  padding: 0.5rem 0.75rem;
}

.toast-header.bg-primary {
  background: var(--kim-primary, #0d6efd) !important;
  color: var(--kim-primary-contrast, #ffffff) !important;
}

.toast-header.bg-success {
  background: var(--kim-success, #198754) !important;
  color: #ffffff !important;
}

.toast-header.bg-danger {
  background: var(--kim-danger, #dc3545) !important;
  color: #ffffff !important;
}

.toast-header.bg-warning {
  background: var(--kim-warning, #ffc107) !important;
  color: #000000 !important;
}

.toast-header.bg-info {
  background: var(--kim-info, #0dcaf0) !important;
  color: #000000 !important;
}

.toast-body {
  color: var(--kim-text, #212529);
  padding: 0.75rem;
}

.btn-close {
  background: transparent;
  border: 0;
  cursor: pointer;
  padding: 0.25rem;
  margin: -0.25rem -0.25rem -0.25rem auto;
  opacity: 0.5;
  transition: opacity 0.15s ease;
}

.btn-close:hover {
  opacity: 0.75;
}

.btn-close-white {
  filter: invert(1) grayscale(100%) brightness(200%);
}

/* Enhanced Grid System */
.row { display: flex; flex-wrap: wrap; margin-right: -0.5rem; margin-left: -0.5rem; }
.col-md-3 { flex: 0 0 25%; max-width: 25%; padding-right: 0.5rem; padding-left: 0.5rem; }
.col-md-4 { flex: 0 0 33.333333%; max-width: 33.333333%; padding-right: 0.5rem; padding-left: 0.5rem; }
.col-md-6 { flex: 0 0 50%; max-width: 50%; padding-right: 0.5rem; padding-left: 0.5rem; }
.g-3 { gap: 1rem !important; }
.g-3 > * { margin: 0; }

/* Tag Input System */
.tags-container { position: relative; }
.tags-display { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.tag-badge { 
  display: inline-flex; 
  align-items: center; 
  background-color: var(--kim-primary); 
  color: white; 
  padding: 0.25rem 0.75rem; 
  border-radius: 1rem; 
  font-size: 0.875rem; 
  font-weight: 500; 
  cursor: pointer; 
  transition: all 0.2s ease;
  user-select: none;
}
.tag-badge:hover { 
  background-color: var(--kim-primary-dark, #0056b3); 
  transform: translateY(-1px);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}
.tag-text { margin-right: 0.25rem; }
.tag-remove { 
  font-size: 1.1rem; 
  font-weight: bold; 
  line-height: 1; 
  margin-left: 0.25rem;
  opacity: 0.8;
  transition: opacity 0.2s ease;
}
  .tag-remove:hover { opacity: 1; }

  /* Enhanced Offcanvas Styles */
  .offcanvas {
    position: fixed;
    z-index: 1045;
    display: flex;
    flex-direction: column;
    max-width: 100vw;
    max-height: 100vh;
    outline: 0;
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  }

  .offcanvas.show {
    transform: none !important;
  }

  .offcanvas-backdrop {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 1040;
    opacity: 0;
    transition: opacity 0.3s ease;
  }

  .offcanvas-backdrop.show {
    opacity: 1;
  }

  .offcanvas-backdrop.fade {
    transition: opacity 0.15s linear;
  }

  /* Offcanvas Variants */
  .offcanvas-elevated {
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
  }

  .offcanvas-outlined {
    border: 1px solid var(--kim-border, #dee2e6);
    box-shadow: 0 0 0 1px var(--kim-border, #dee2e6);
  }

  .offcanvas-rounded {
    border-radius: 12px;
  }

  .offcanvas-frosted {
    backdrop-filter: blur(20px);
    background: rgba(255, 255, 255, 0.8);
  }

  .offcanvas-dark {
    background: var(--kim-dark-surface, #212529);
    color: var(--kim-dark-text, #fff);
  }

  .offcanvas-dark .offcanvas-header {
    background-color: var(--kim-dark-surface-alt, #343a40);
    border-bottom: 1px solid var(--kim-dark-border, #495057);
  }

  .offcanvas-dark .offcanvas-footer {
    background-color: var(--kim-dark-surface-alt, #343a40);
    border-top: 1px solid var(--kim-dark-border, #495057);
  }

  .offcanvas-dark .btn-close {
    color: var(--kim-dark-text, #fff);
  }

  /* Offcanvas Sizes */
  .offcanvas-sm {
    width: 280px;
  }

  .offcanvas-lg {
    width: 480px;
  }

  .offcanvas-xl {
    width: 600px;
  }

  /* Offcanvas Header */
  .offcanvas-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem;
    border-bottom: 1px solid var(--kim-border, #dee2e6);
    flex-shrink: 0;
  }

  .offcanvas-title {
    margin: 0;
    font-size: 1.25rem;
    font-weight: 600;
    color: inherit;
  }

  .offcanvas-subtitle {
    margin: 0;
    font-size: 0.875rem;
    color: var(--kim-text-muted, #6c757d);
  }

  /* Offcanvas Body */
  .offcanvas-body {
    flex: 1 1 auto;
    padding: 1rem;
    overflow-y: auto;
    overflow-x: hidden;
  }

  /* Offcanvas Footer */
  .offcanvas-footer {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.5rem;
    padding: 1rem;
    border-top: 1px solid var(--kim-border, #dee2e6);
    flex-shrink: 0;
  }

  /* Offcanvas Animations */
  @keyframes offcanvas-ripple {
    0% {
      transform: scale(0);
      opacity: 1;
    }
    100% {
      transform: scale(4);
      opacity: 0;
    }
  }

  .offcanvas-backdrop-ripple {
    position: absolute;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.3);
    transform: scale(0);
    animation: offcanvas-ripple 0.6s linear;
    pointer-events: none;
  }

  /* Offcanvas Responsive */
  @media (max-width: 576px) {
    .offcanvas {
      width: 100vw !important;
    }
    
    .offcanvas-sm,
    .offcanvas-lg,
    .offcanvas-xl {
      width: 100vw !important;
    }
  }

  /* Offcanvas Drag Feedback */
  .offcanvas[data-dragging="true"] {
    transition: none;
    cursor: grabbing;
  }

  .offcanvas-draggable .offcanvas-body {
    cursor: grab;
  }

  .offcanvas-draggable .offcanvas-body:active {
    cursor: grabbing;
  }

  /* Visual feedback for draggable areas */
  .offcanvas-draggable .offcanvas-body::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, transparent, rgba(0,0,0,0.1), transparent);
    opacity: 0;
    transition: opacity 0.2s ease;
    pointer-events: none;
    z-index: 1;
  }

  .offcanvas-draggable .offcanvas-body:hover::before {
    opacity: 1;
  }

  /* Enhanced visual feedback during drag */
  .offcanvas[data-dragging="true"] {
    box-shadow: 0 8px 32px rgba(0,0,0,0.3) !important;
    opacity: 0.95;
  }

  .offcanvas[data-dragging="true"] .offcanvas-body::before {
    opacity: 1;
    background: linear-gradient(90deg, transparent, rgba(0,0,0,0.2), transparent);
  }

  /* Offcanvas Scrollbar Styling */
  .offcanvas-body::-webkit-scrollbar {
    width: 6px;
  }

  .offcanvas-body::-webkit-scrollbar-track {
    background: transparent;
  }

  .offcanvas-body::-webkit-scrollbar-thumb {
    background: rgba(0, 0, 0, 0.2);
    border-radius: 3px;
  }

  .offcanvas-body::-webkit-scrollbar-thumb:hover {
    background: rgba(0, 0, 0, 0.3);
  }

  .offcanvas-dark .offcanvas-body::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.2);
  }

  .offcanvas-dark .offcanvas-body::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.3);
  }

/* Circular Progress */
.progress-circular-simple { position: relative; display: inline-block; }
.progress-circular-ring { 
  width: 100%; 
  height: 100%; 
  border-radius: 50%; 
  background: conic-gradient(var(--kim-primary) 0deg, var(--kim-border) 0deg);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
.progress-circular-ring::before {
  content: '';
  position: absolute;
  width: 70%;
  height: 70%;
  border-radius: 50%;
  background: var(--kim-surface);
}
.progress-circular-fill { 
  position: absolute;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: conic-gradient(var(--kim-primary) 0deg, transparent 0deg);
  transition: transform 0.3s ease;
}
.progress-circular-fill.progress-circular-success { 
  background: conic-gradient(var(--kim-accent) 0deg, transparent 0deg);
}
.progress-circular-fill.progress-circular-warning { 
  background: conic-gradient(var(--kim-warning) 0deg, transparent 0deg);
}
.progress-circular-fill.progress-circular-danger { 
  background: conic-gradient(var(--kim-danger) 0deg, transparent 0deg);
}
.progress-circular-text { 
  position: absolute; 
  top: 50%; 
  left: 50%; 
  transform: translate(-50%, -50%); 
  font-size: 12px; 
  font-weight: 600; 
  color: var(--kim-text); 
  z-index: 2;
}

/* Even more specific rules to override any conflicting background styles */
.progress .progress-bar.progress-bar-striped.progress-bar-animated,
.progress .progress-bar.progress-bar-animated.progress-bar-striped {
  animation: moving-stripes 1s linear infinite !important; 
  background-image: linear-gradient(
    45deg, 
    rgba(255,255,255,.5) 25%, 
    transparent 25%, 
    transparent 50%, 
    rgba(255,255,255,.5) 50%, 
    rgba(255,255,255,.5) 75%, 
    transparent 75%, 
    transparent
  ) !important; 
  background-size: 1rem 1rem !important; 
  background-repeat: repeat !important;
}

/* ULTIMATE OVERRIDE: Most specific rules to override background colors with !important */
.progress .progress-bar.bg-primary.progress-bar-striped.progress-bar-animated,
.progress .progress-bar.bg-secondary.progress-bar-striped.progress-bar-animated,
.progress .progress-bar.bg-success.progress-bar-striped.progress-bar-animated,
.progress .progress-bar.bg-danger.progress-bar-striped.progress-bar-animated,
.progress .progress-bar.bg-warning.progress-bar-striped.progress-bar-animated,
.progress .progress-bar.bg-info.progress-bar-striped.progress-bar-animated,
.progress .progress-bar.bg-light.progress-bar-striped.progress-bar-animated,
.progress .progress-bar.bg-dark.progress-bar-striped.progress-bar-animated {
  animation: moving-stripes 1s linear infinite !important; 
  background-image: linear-gradient(
    45deg, 
    rgba(255,255,255,.5) 25%, 
    transparent 25%, 
    transparent 50%, 
    rgba(255,255,255,.5) 50%, 
    rgba(255,255,255,.5) 75%, 
    transparent 75%, 
    transparent
  ) !important; 
  background-size: 1rem 1rem !important; 
  background-repeat: repeat !important;
}

/* Close Button Variants */
.btn-close {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.25rem;
  height: 1.25rem;
  padding: 0;
  background: transparent;
  border: 0;
  border-radius: 0.375rem;
  opacity: 0.5;
  transition: all 0.15s ease-in-out;
  cursor: pointer;
  user-select: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  overflow: hidden;
}

.btn-close::before,
.btn-close::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 1rem;
  height: 0.125rem;
  background-color: currentColor;
  transition: all 0.15s ease-in-out;
  transform-origin: center;
}

.btn-close::before {
  transform: translate(-50%, -50%) rotate(45deg);
}

.btn-close::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

.btn-close:hover {
  opacity: 0.75;
  transform: scale(1.1);
}

.btn-close:focus {
  outline: 0;
  box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
  opacity: 0.75;
}

.btn-close:active {
  transform: scale(0.95);
}

/* Size Variants */
.btn-close-sm {
  width: 1rem;
  height: 1rem;
}

.btn-close-sm::before,
.btn-close-sm::after {
  width: 0.75rem;
  height: 0.1rem;
}

.btn-close-lg {
  width: 1.5rem;
  height: 1.5rem;
}

.btn-close-lg::before,
.btn-close-lg::after {
  width: 1.25rem;
  height: 0.15rem;
}

.btn-close-xl {
  width: 2rem;
  height: 2rem;
}

.btn-close-xl::before,
.btn-close-xl::after {
  width: 1.5rem;
  height: 0.2rem;
}

/* Color Variants */
.btn-close-white {
  color: #fff;
}

.btn-close-white:hover {
  color: #f8f9fa;
}

.btn-close-dark {
  color: #212529;
}

.btn-close-dark:hover {
  color: #000;
}

.btn-close-primary {
  color: var(--kim-primary);
}

.btn-close-primary:hover {
  color: var(--kim-primary-dark);
}

.btn-close-success {
  color: var(--kim-accent);
}

.btn-close-success:hover {
  color: #0b0f14;
}

.btn-close-warning {
  color: var(--kim-warning);
}

.btn-close-warning:hover {
  color: #856404;
}

.btn-close-danger {
  color: var(--kim-danger);
}

.btn-close-danger:hover {
  color: #721c24;
}

.btn-close-info {
  color: var(--kim-info);
}

.btn-close-info:hover {
  color: #0c5460;
}

.btn-close-light {
  color: #f8f9fa;
}

.btn-close-light:hover {
  color: #e2e6ea;
}

/* Style Variants */
.btn-close-outlined {
  border: 2px solid currentColor;
  background: transparent;
}

.btn-close-outlined:hover {
  background: currentColor;
  color: #fff;
}

.btn-close-rounded {
  border-radius: 50%;
}

.btn-close-circular {
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.1);
}

.btn-close-circular:hover {
  background: rgba(0, 0, 0, 0.2);
}

.btn-close-minimal {
  opacity: 0.3;
}

.btn-close-minimal:hover {
  opacity: 0.8;
}

.btn-close-elegant {
  border-radius: 0.5rem;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.05));
  backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.2);
}

.btn-close-elegant:hover {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0.1));
  border-color: rgba(255, 255, 255, 0.3);
}

.btn-close-modern {
  border-radius: 0.25rem;
  background: rgba(0, 0, 0, 0.05);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.btn-close-modern:hover {
  background: rgba(0, 0, 0, 0.1);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
  transform: translateY(-1px);
}

/* Animation Variants */
.btn-close-animated {
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.btn-close-animated:hover {
  transform: rotate(90deg) scale(1.1);
}

.btn-close-animated:active {
  transform: rotate(90deg) scale(0.9);
}

/* Special Effects */
.btn-close-animated.btn-close-elegant:hover {
  transform: rotate(90deg) scale(1.1);
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.2);
}

.btn-close-animated.btn-close-modern:hover {
  transform: rotate(90deg) translateY(-2px);
  box-shadow: 0 6px 12px rgba(0, 0, 0, 0.2);
}

/* Ensure X stays centered during animations */
.btn-close-animated::before,
.btn-close-animated::after {
  transform-origin: center;
}

.btn-close-animated:hover::before {
  transform: translate(-50%, -50%) rotate(45deg);
}

.btn-close-animated:hover::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

/* Dark Theme Support */
@media (prefers-color-scheme: dark) {
  .btn-close {
    color: #fff;
  }
  
  .btn-close-dark {
    color: #fff;
  }
  
  .btn-close-light {
    color: #212529;
  }
  
  .btn-close-circular {
    background: rgba(255, 255, 255, 0.1);
  }
  
  .btn-close-circular:hover {
    background: rgba(255, 255, 255, 0.2);
  }
  
  .btn-close-modern {
    background: rgba(255, 255, 255, 0.05);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
  }
  
  .btn-close-modern:hover {
    background: rgba(255, 255, 255, 0.1);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.4);
  }
}

/* Alert-specific close button styling */
.alert .btn-close {
  transition: all 0.2s ease-in-out;
}

.alert .btn-close:hover {
  opacity: 0.8;
  transform: scale(1.05);
}

.alert .btn-close:active {
  transform: scale(0.98);
}

/* Prevent aggressive animations in alerts */
.alert .btn-close-animated:hover {
  transform: scale(1.05);
}

.alert .btn-close-animated:active {
  transform: scale(0.98);
}

/* Subtle variant for alerts */
.btn-close-subtle {
  opacity: 0.4;
  transition: all 0.15s ease-in-out;
}

.btn-close-subtle:hover {
  opacity: 0.7;
  transform: scale(1.02);
}

.btn-close-subtle:active {
  transform: scale(0.99);
}

/* Alert-specific subtle close button styling */
.alert .btn-close.btn-close-subtle {
  transition: all 0.15s ease-in-out;
}

.alert .btn-close.btn-close-subtle:hover {
  opacity: 0.7;
  transform: translateY(-50%) scale(1.02);
}

.alert .btn-close.btn-close-subtle:active {
  transform: translateY(-50%) scale(0.99);
}

/* ==================== */
/* WINDOW CONTROL BTNS  */
/* ==================== */

.window-controls {
  display: flex;
  align-items: center;
  gap: 2px;
  user-select: none;
}

.window-control-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border: none;
  background: transparent;
  color: var(--kim-text, #212529);
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  border-radius: 4px;
  transition: all 0.15s ease-in-out;
  position: relative;
  overflow: hidden;
}

.window-control-btn:hover {
  background: rgba(0, 0, 0, 0.05);
  transform: scale(1.05);
}

.window-control-btn:active {
  transform: scale(0.95);
}

/* Minimize button */
.window-control-minimize {
  color: var(--kim-warning, #ffc107);
}

.window-control-minimize:hover {
  background: rgba(255, 193, 7, 0.1);
  color: var(--kim-warning, #ffc107);
}

/* Maximize button */
.window-control-maximize {
  color: var(--kim-success, #198754);
}

.window-control-maximize:hover {
  background: rgba(25, 135, 84, 0.1);
  color: var(--kim-success, #198754);
}

/* Restore button */
.window-control-restore {
  color: var(--kim-info, #0dcaf0);
}

.window-control-restore:hover {
  background: rgba(13, 202, 240, 0.1);
  color: var(--kim-info, #0dcaf0);
}

/* Close button */
.window-control-close {
  color: var(--kim-danger, #dc3545);
}

.window-control-close:hover {
  background: rgba(220, 53, 69, 0.1);
  color: var(--kim-danger, #dc3545);
}

/* Size variants */
.window-control-btn.btn-sm {
  width: 24px;
  height: 24px;
  font-size: 12px;
}

.window-control-btn.btn-lg {
  width: 40px;
  height: 40px;
  font-size: 16px;
}

/* Style variants */
.window-control-btn.btn-outline {
  border: 1px solid var(--kim-border, #dee2e6);
  background: var(--kim-surface, #ffffff);
}

.window-control-btn.btn-outline:hover {
  background: var(--kim-surface-alt, #f8f9fa);
  border-color: var(--kim-primary, #0d6efd);
}

.window-control-btn.btn-filled {
  background: var(--kim-surface-alt, #f8f9fa);
  border: 1px solid var(--kim-border, #dee2e6);
}

.window-control-btn.btn-filled:hover {
  background: var(--kim-primary, #0d6efd);
  color: var(--kim-primary-contrast, #ffffff);
  border-color: var(--kim-primary, #0d6efd);
}

.window-control-btn.btn-circular {
  border-radius: 50%;
}

/* Animated variants */
.window-control-btn.btn-animated {
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.window-control-btn.btn-animated:hover {
  transform: scale(1.1) rotate(5deg);
}

.window-control-btn.btn-animated:active {
  transform: scale(0.9) rotate(-5deg);
}

/* Animated variant without rotation */
.window-control-btn.btn-animated-no-rotate {
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.window-control-btn.btn-animated-no-rotate:hover {
  transform: scale(1.15);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.15);
}

.window-control-btn.btn-animated-no-rotate:active {
  transform: scale(0.95);
  transition: all 0.1s ease;
}

/* Modern variant */
.window-control-btn.btn-modern {
  background: rgba(0, 0, 0, 0.05);
  backdrop-filter: blur(10px);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.window-control-btn.btn-modern:hover {
  background: rgba(0, 0, 0, 0.1);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  transform: translateY(-1px);
}

/* Dark theme support */
@media (prefers-color-scheme: dark) {
  .window-control-btn {
    color: var(--kim-text-dark, #ffffff);
  }
  
  .window-control-btn:hover {
    background: rgba(255, 255, 255, 0.1);
  }
  
  .window-control-btn.btn-outline {
    border-color: var(--kim-border-dark, #495057);
    background: var(--kim-surface-dark, #212529);
  }
  
  .window-control-btn.btn-filled {
    background: var(--kim-surface-alt-dark, #343a40);
    border-color: var(--kim-border-dark, #495057);
  }
  
  .window-control-btn.btn-modern {
    background: rgba(255, 255, 255, 0.1);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
  }
  
  .window-control-btn.btn-modern:hover {
    background: rgba(255, 255, 255, 0.15);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
  }
  
  .window-control-btn.btn-animated-no-rotate:hover {
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.4);
  }
}

/* Frosted glass theme support */
.theme-frosted-glass .window-control-btn {
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.2);
}

.theme-frosted-glass .window-control-btn:hover {
  background: rgba(255, 255, 255, 0.2);
  border-color: rgba(255, 255, 255, 0.3);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.theme-frosted-glass .window-control-btn.btn-animated-no-rotate:hover {
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.15);
}

/* High contrast theme support */
.theme-high-contrast .window-control-btn {
  border: 2px solid var(--kim-text, #000000);
  background: var(--kim-surface, #ffffff);
  color: var(--kim-text, #000000);
}

.theme-high-contrast .window-control-btn:hover {
  background: var(--kim-text, #000000);
  color: var(--kim-surface, #ffffff);
}

/* ==================== */
/* SIDEBAR COMPONENT    */
/* ==================== */

/* Sidebar Container */
.sidebar-container {
  position: relative;
  display: flex;
  min-height: 100vh;
  width: 100%;
}

.sidebar-overlay-container {
  display: block;
}

/* Sidebar Overlay */
.sidebar-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.5);
  z-index: 999;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
  backdrop-filter: blur(4px);
}

.sidebar-overlay-active {
  opacity: 1;
  visibility: visible;
}

/* Base Sidebar */
.sidebar {
  position: relative;
  height: 100vh;
  background: var(--kim-surface, #ffffff);
  color: var(--kim-text, #495057);
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.15);
  z-index: 1;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  width: 280px;
}

/* Icon-only Sidebar */
.sidebar.sidebar-icon-only {
  width: 60px !important;
}

.sidebar.sidebar-icon-only .sidebar-header-content {
  display: none !important;
}

.sidebar.sidebar-icon-only .sidebar-header-buttons {
  justify-content: center !important;
}

.sidebar.sidebar-icon-only .sidebar-nav-text,
.sidebar.sidebar-icon-only .sidebar-section-title {
  display: none !important;
}

.sidebar.sidebar-icon-only .sidebar-nav-icon {
  margin-right: 0 !important;
  font-size: 18px !important;
}

.sidebar.sidebar-icon-only .sidebar-nav-link {
  justify-content: center !important;
  padding: 16px 8px !important;
  text-align: center !important;
}

.sidebar.sidebar-icon-only .sidebar-section-toggle {
  display: none !important;
}

.sidebar.sidebar-icon-only .sidebar-footer {
  padding: 12px 8px !important;
  text-align: center !important;
}

.sidebar.sidebar-icon-only .sidebar-footer * {
  display: none !important;
}

.sidebar.sidebar-icon-only .sidebar-footer::after {
  content: '⋯' !important;
  font-size: 20px !important;
  color: #6c757d !important;
}

/* Sidebar Positions */
.sidebar-left {
  left: 0;
  transform: translateX(-100%);
}

.sidebar-right {
  right: 0;
  transform: translateX(100%);
}

.sidebar-left.sidebar-open {
  transform: translateX(0);
}

.sidebar-right.sidebar-open {
  transform: translateX(0);
}

/* Sidebar Variants */
.sidebar-default {
  border-right: 1px solid #e9ecef;
}

.sidebar-dark {
  background: #2c3e50;
  color: #ffffff;
  border-right: 1px solid #34495e;
}

.sidebar-light {
  background: #f8f9fa;
  border-right: 1px solid #dee2e6;
}

.sidebar-primary {
  background: var(--kim-primary, linear-gradient(135deg, #667eea 0%, #764ba2 100%));
  color: var(--kim-primary-contrast, #ffffff);
}
.sidebar-primary .sidebar-nav-link { color: var(--kim-primary-contrast, rgba(255,255,255,0.9)); }
.sidebar-primary .sidebar-nav-link:hover { color: var(--kim-primary-contrast, #ffffff); background: rgba(255,255,255,0.12); }
.sidebar-primary .sidebar-section-title { color: var(--kim-primary-contrast, rgba(255,255,255,0.85)); }
.sidebar-primary .sidebar-nav-item-active .sidebar-nav-link { background: rgba(255,255,255,0.18); color: var(--kim-primary-contrast, #ffffff); }

.sidebar-success {
  background: linear-gradient(135deg, #28a745 0%, #20c997 100%);
  color: #ffffff;
}
.sidebar-success .sidebar-nav-link { color: rgba(255,255,255,0.9); }
.sidebar-success .sidebar-nav-link:hover { color: #ffffff; background: rgba(255,255,255,0.12); }
.sidebar-success .sidebar-section-title { color: rgba(255,255,255,0.85); }
.sidebar-success .sidebar-nav-item-active .sidebar-nav-link { background: rgba(255,255,255,0.18); color: #ffffff; }

.sidebar-danger {
  background: linear-gradient(135deg, #dc3545 0%, #e83e8c 100%);
  color: #ffffff;
}
.sidebar-danger .sidebar-nav-link { color: rgba(255,255,255,0.9); }
.sidebar-danger .sidebar-nav-link:hover { color: #ffffff; background: rgba(255,255,255,0.12); }
.sidebar-danger .sidebar-section-title { color: rgba(255,255,255,0.85); }
.sidebar-danger .sidebar-nav-item-active .sidebar-nav-link { background: rgba(255,255,255,0.18); color: #ffffff; }

.sidebar-warning {
  background: linear-gradient(135deg, #ffc107 0%, #fd7e14 100%);
  color: #000000;
}
.sidebar-warning .sidebar-nav-link { color: rgba(0,0,0,0.85); }
.sidebar-warning .sidebar-nav-link:hover { color: #000000; background: rgba(0,0,0,0.06); }
.sidebar-warning .sidebar-section-title { color: rgba(0,0,0,0.7); }
.sidebar-warning .sidebar-nav-item-active .sidebar-nav-link { background: rgba(0,0,0,0.08); color: #000000; }

.sidebar-info {
  background: linear-gradient(135deg, #17a2b8 0%, #6f42c1 100%);
  color: #ffffff;
}
.sidebar-info .sidebar-nav-link { color: rgba(255,255,255,0.9); }
.sidebar-info .sidebar-nav-link:hover { color: #ffffff; background: rgba(255,255,255,0.12); }
.sidebar-info .sidebar-section-title { color: rgba(255,255,255,0.85); }
.sidebar-info .sidebar-nav-item-active .sidebar-nav-link { background: rgba(255,255,255,0.18); color: #ffffff; }

/* Sidebar Animations */
.sidebar-slide {
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.sidebar-scale {
  transform: scale(0.8) translateX(-100%);
  opacity: 0;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.sidebar-scale.sidebar-open {
  transform: scale(1) translateX(0);
  opacity: 1;
}

.sidebar-fade {
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
}

.sidebar-fade.sidebar-open {
  opacity: 1;
  visibility: visible;
}

/* Sidebar Sizes */
.sidebar-sm {
  width: 240px !important;
}

.sidebar-lg {
  width: 320px !important;
}

.sidebar-xl {
  width: 400px !important;
}

/* Sidebar Header */
.sidebar-header {
  padding: 20px;
  border-bottom: 1px solid var(--kim-border, #e9ecef);
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--kim-surfacealt, rgba(0, 0, 0, 0.02));
  color: var(--kim-text, #495057);
  flex-shrink: 0;
}

.sidebar-header-content {
  flex: 1;
}

.sidebar-header-buttons {
  display: flex;
  align-items: center;
  gap: 8px;
}

.sidebar-close-btn,
.sidebar-icon-only-btn {
  width: 32px;
  height: 32px;
  border: none;
  background: transparent;
  color: var(--kim-textmuted, #6c757d);
  font-size: 16px;
  cursor: pointer;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
}

.sidebar-close-btn:hover,
.sidebar-icon-only-btn:hover {
  background: var(--kim-surfacealt, rgba(0, 0, 0, 0.1));
  color: var(--kim-text, #495057);
}

/* Sidebar Body */
.sidebar-body {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 10px 0;
}

/* Sidebar Footer */
.sidebar-footer {
  padding: 20px;
  border-top: 1px solid var(--kim-border, #e9ecef);
  background: var(--kim-surfacealt, rgba(0, 0, 0, 0.02));
  color: var(--kim-textmuted, #6c757d);
  flex-shrink: 0;
  margin-top: auto; /* Push footer to bottom */
}

/* Sidebar Navigation */
.sidebar-nav {
  list-style: none;
  padding: 0;
  margin: 0;
  width: 100%;
}

.sidebar-nav-item {
  margin-bottom: 4px;
}

.sidebar-nav-link {
  display: flex;
  align-items: center;
  padding: 12px 20px;
  color: var(--kim-text, #495057);
  text-decoration: none;
  border-radius: 8px;
  transition: all 0.2s ease;
  position: relative;
  overflow: hidden;
  width: 100%;
  box-sizing: border-box;
  margin: 2px 8px;
}

.sidebar-nav-link:hover {
  background: var(--kim-surfacealt, rgba(0, 0, 0, 0.05));
  color: var(--kim-text, #495057);
  text-decoration: none;
  transform: translateX(4px);
}

.sidebar-nav-item-active .sidebar-nav-link {
  background: var(--kim-primary, #0d6efd);
  color: var(--kim-primary-contrast, #ffffff);
  font-weight: 600;
}

.sidebar-nav-icon {
  margin-right: 12px;
  font-size: 16px;
  width: 20px;
  text-align: center;
}

.sidebar-nav-text {
  flex: 1;
  font-weight: 500;
}

/* Sidebar Section */
.sidebar-section {
  margin-bottom: 16px;
}

.sidebar-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
  padding: 0 20px;
}

.sidebar-section-title {
  margin: 0;
  font-size: 12px;
  font-weight: 600;
  color: var(--kim-textmuted, #6c757d);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.sidebar-section-toggle {
  background: none;
  border: none;
  color: var(--kim-textmuted, #6c757d);
  cursor: pointer;
  font-size: 10px;
  padding: 4px;
  border-radius: 4px;
  transition: all 0.2s ease;
}

.sidebar-section-toggle:hover {
  background: var(--kim-surfacealt, rgba(0, 0, 0, 0.05));
  color: var(--kim-text, #495057);
}

.sidebar-section-content {
  transition: all 0.3s ease;
  max-height: 1000px;
  overflow: hidden;
}

.sidebar-section-collapsed {
  max-height: 0;
}

/* Sidebar Content (for side-by-side layout) */
.sidebar-content {
  flex: 1;
  padding: 20px;
  transition: all 0.3s ease;
  margin-left: 0;
  width: auto;
  height: 100vh;
  overflow: hidden; /* No scrolling in sidebar content */
}

.sidebar-content-icon-only {
  margin-left: 0;
  height: 100vh;
  overflow: hidden; /* No scrolling */
}

.sidebar-content-with-sidebar {
  margin-left: 0;
  width: auto;
  height: 100vh;
  overflow: hidden; /* No scrolling */
}

.sidebar-content-full-width {
  margin-left: 0;
  width: 100%;
  height: 100vh;
  overflow: hidden; /* No scrolling */
}

/* Demo mode sidebars */
.sidebar-demo .sidebar {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  height: 100% !important;
  width: 100% !important;
  z-index: 1 !important;
}

/* Sidebar Toggle Button */
.sidebar-toggle {
  position: fixed;
  top: 16px;
  left: 16px;
  width: 40px;
  height: 40px;
  background: #ffffff;
  border: 1px solid #e9ecef;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 16px;
  color: #6c757d;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  transition: all 0.2s ease;
  z-index: 1001;
}

.sidebar-toggle:hover {
  background: #f8f9fa;
  transform: scale(1.05);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

/* Sidebar Icon-Only Toggle */
.sidebar-icon-only-toggle {
  position: fixed;
  top: 50%;
  left: 280px;
  transform: translateY(-50%);
  width: 24px;
  height: 60px;
  background: #ffffff;
  border: 1px solid #e9ecef;
  border-left: none;
  border-radius: 0 8px 8px 0;
  color: #6c757d;
  font-size: 12px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  z-index: 999;
  box-shadow: 2px 0 8px rgba(0, 0, 0, 0.1);
}

.sidebar-icon-only-toggle:hover {
  background: #f8f9fa;
  color: #495057;
  box-shadow: 2px 0 12px rgba(0, 0, 0, 0.15);
}

.sidebar-icon-only + .sidebar-icon-only-toggle {
  left: 60px;
}

/* Dark theme support */
@media (prefers-color-scheme: dark) {
  .sidebar {
    background: #2c3e50;
    color: #ffffff;
    border-right-color: #34495e;
  }
  
  .sidebar-header {
    border-bottom-color: #34495e;
    background: rgba(255, 255, 255, 0.05);
  }
  
  .sidebar-footer {
    border-top-color: #34495e;
    background: rgba(255, 255, 255, 0.05);
  }
  
  .sidebar-nav-link {
    color: #bdc3c7;
  }
  
  .sidebar-nav-link:hover {
    background: rgba(255, 255, 255, 0.1);
    color: #ffffff;
  }
  
  .sidebar-section-title {
    color: #95a5a6;
  }
  
  .sidebar-toggle {
    background: #2c3e50;
    color: #ffffff;
    border-color: #34495e;
  }
  
  .sidebar-toggle:hover {
    background: #34495e;
  }
  
  .sidebar-icon-only-toggle {
    background: #2c3e50;
    color: #ffffff;
    border-color: #34495e;
  }
  
  .sidebar-icon-only-toggle:hover {
    background: #34495e;
    color: #ffffff;
  }
  
  .sidebar.sidebar-icon-only .sidebar-footer::after {
    color: #bdc3c7;
  }
}

/* Sidebar Close Button Improvements */
.sidebar-close-btn {
  position: relative;
  z-index: 1001;
}

.sidebar-close-btn:hover {
  background: var(--kim-surfacealt, rgba(0, 0, 0, 0.1)) !important;
  transform: scale(1.1);
}

/* Ensure sidebar can be hidden in side-by-side mode */
.sidebar.sidebar-side-by-side:not(.sidebar-open):not(.sidebar-icon-only) {
  width: 0 !important;
  min-width: 0 !important;
  overflow: hidden;
  transition: width 0.3s ease, min-width 0.3s ease;
}

.sidebar.sidebar-side-by-side.sidebar-open:not(.sidebar-icon-only) {
  width: 280px !important;
  min-width: 280px !important;
  overflow: visible;
  transition: width 0.3s ease, min-width 0.3s ease;
}

/* Icon-only mode should always override side-by-side width */
.sidebar.sidebar-icon-only {
  width: 60px !important;
  min-width: 60px !important;
  overflow: visible;
}

/* Ensure icon-only mode works smoothly in side-by-side layout */
.sidebar.sidebar-side-by-side.sidebar-icon-only {
  transition: width 0.3s ease, min-width 0.3s ease;
}

/* Content area adjustments for icon-only mode */
.sidebar-content-icon-only {
  margin-left: 0;
  width: auto;
}



/* Ensure smooth transitions for sidebar width changes */
.sidebar.sidebar-side-by-side {
  transition: width 0.3s ease, min-width 0.3s ease;
}

/* Sidebar container layout */
.sidebar-container {
  display: flex;
  height: 100vh;
  overflow: hidden;
}

/* Ensure main content area expands properly */
.sidebar-container .sidebar-content {
  flex: 1;
  min-width: 0;
  overflow-x: hidden;
  overflow-y: auto;
}

/* Sidebar Toggle Button */
.sidebar-toggle-button {
  position: fixed;
  top: 20px;
  left: 20px;
  z-index: 1000;
  width: 48px;
  height: 48px;
  border: none;
  background: var(--kim-surface, #ffffff);
  color: var(--kim-text, #495057);
  border-radius: 50%;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  transition: all 0.3s ease;
}

.sidebar-toggle-button:hover {
  background: var(--kim-surfacealt, rgba(0, 0, 0, 0.05));
  transform: scale(1.1);
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.2);
}

/* Theme-specific toggle button styles */
:root[data-theme="dark"] .sidebar-toggle-button {
  background: var(--kim-surface, #2c3e50);
  color: var(--kim-text, #ffffff);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

:root[data-theme="dark"] .sidebar-toggle-button:hover {
  background: var(--kim-surfacealt, rgba(255, 255, 255, 0.1));
}

:root[data-theme="contrast"] .sidebar-toggle-button {
  background: var(--kim-surface, #000000);
  color: var(--kim-text, #ffffff);
  border: 2px solid var(--kim-text, #ffffff);
}

:root[data-theme="frosted"] .sidebar-toggle-button {
  background: rgba(255, 255, 255, 0.2);
  color: var(--kim-text, #2c3e50);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.3);
}

/* ==================== */
/* STICKY HEADER        */
/* ==================== */
.sticky-header {
  position: sticky;
  top: 0;
  background: var(--kim-surface, #ffffff);
  color: var(--kim-text, #495057);
  border-bottom: 1px solid var(--kim-border, #e9ecef);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  width: 100%;
  z-index: 1000;
  min-height: 60px;
  display: flex;
  align-items: center;
  padding: 0 20px;
  flex-shrink: 0; /* Prevent shrinking in flex container */
}

.sticky-header-active {
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.sticky-header-shadow {
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.sticky-header-active.sticky-header-shadow {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.sticky-header-blur {
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.sticky-header-active.sticky-header-blur {
  background: rgba(var(--kim-surface-rgb, 255, 255, 255), 0.95);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}

/* Sticky Header Navigation */
.sticky-header-nav {
  display: flex;
  gap: 20px;
}

.sticky-header-nav a {
  text-decoration: none;
  color: var(--kim-textmuted, #6c757d);
  font-weight: 500;
  transition: color 0.2s ease;
}

.sticky-header-nav a:hover {
  color: var(--kim-text, #495057);
}

/* Sticky Header Variants */
.sticky-header-primary {
  background: var(--kim-primary);
  color: white;
  border-bottom-color: var(--kim-primary-dark);
}

.sticky-header-primary.sticky-header-active {
  box-shadow: 0 2px 8px rgba(var(--kim-primary-rgb), 0.3);
}

.sticky-header-dark {
  background: var(--kim-dark);
  color: white;
  border-bottom-color: var(--kim-dark-dark);
}

.sticky-header-dark.sticky-header-active {
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

.sticky-header-light {
  background: var(--kim-surface, #ffffff);
  color: var(--kim-text, #495057);
  border-bottom-color: var(--kim-border, #e9ecef);
}

.sticky-header-light.sticky-header-active {
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.sticky-header-success {
  background: var(--kim-success);
  color: white;
  border-bottom-color: var(--kim-success-dark);
}

.sticky-header-success.sticky-header-active {
  box-shadow: 0 2px 8px rgba(var(--kim-success-rgb), 0.3);
}

.sticky-header-danger {
  background: var(--kim-danger);
  color: white;
  border-bottom-color: var(--kim-danger-dark);
}

.sticky-header-danger.sticky-header-active {
  box-shadow: 0 2px 8px rgba(var(--kim-danger-rgb), 0.3);
}

.sticky-header-warning {
  background: var(--kim-warning);
  color: var(--kim-dark);
  border-bottom-color: var(--kim-warning-dark);
}

.sticky-header-warning.sticky-header-active {
  box-shadow: 0 2px 8px rgba(var(--kim-warning-rgb), 0.3);
}

.sticky-header-info {
  background: var(--kim-info);
  color: white;
  border-bottom-color: var(--kim-info-dark);
}

.sticky-header-info.sticky-header-active {
  box-shadow: 0 2px 8px rgba(var(--kim-info-rgb), 0.3);
}

/* Sticky Header Sizes */
.sticky-header-sm {
  padding: 8px 20px;
  min-height: 48px;
}

.sticky-header-default {
  padding: 12px 24px;
  min-height: 60px;
}

.sticky-header-lg {
  padding: 16px 32px;
  min-height: 72px;
}

.sticky-header-xl {
  padding: 20px 40px;
  min-height: 84px;
}

/* Sticky Header Content */
.sticky-header-content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}

.sticky-header-left {
  display: flex;
  align-items: center;
  gap: 16px;
}

.sticky-header-center {
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 1;
}

.sticky-header-right {
  display: flex;
  align-items: center;
  gap: 16px;
}

/* Sticky Header Responsive */
@media (max-width: 768px) {
  .sticky-header-sm {
    padding: 6px 16px;
    min-height: 44px;
  }
  
  .sticky-header-default {
    padding: 10px 20px;
    min-height: 56px;
  }
  
  .sticky-header-lg {
    padding: 14px 28px;
    min-height: 68px;
  }
  
  .sticky-header-xl {
    padding: 18px 36px;
    min-height: 80px;
  }
  
  .sticky-header-content {
    flex-direction: column;
    gap: 12px;
  }
  
  .sticky-header-left,
  .sticky-header-center,
  .sticky-header-right {
    width: 100%;
    justify-content: center;
  }
}

/* ==================== */
/* LEGACY CLOSE BUTTON  */
/* ==================== */

/* Legacy close button variants that aren't covered by window controls */
.btn-close-white {
  color: #ffffff;
}

.btn-close-dark {
  color: #000000;
}

.btn-close-primary {
  color: var(--kim-primary, #0d6efd);
}

.btn-close-success {
  color: var(--kim-success, #198754);
}

.btn-close-warning {
  color: var(--kim-warning, #ffc107);
}

.btn-close-danger {
  color: var(--kim-danger, #dc3545);
}

.btn-close-info {
  color: var(--kim-info, #0dcaf0);
}

.btn-close-light {
  color: var(--kim-light, #f8f9fa);
}

.btn-close-rounded {
  border-radius: 50%;
}

.btn-close-minimal {
  opacity: 0.3;
  transition: opacity 0.15s ease-in-out;
}

.btn-close-minimal:hover {
  opacity: 0.7;
}

.btn-close-elegant {
  background: rgba(0, 0, 0, 0.05);
  border-radius: 50%;
  transition: all 0.2s ease-in-out;
}

.btn-close-elegant:hover {
  background: rgba(0, 0, 0, 0.1);
  transform: scale(1.1);
}

/* Size variants for close button (with higher specificity) */
.btn-close.btn-sm {
  width: 24px !important;
  height: 24px !important;
  font-size: 12px !important;
  min-width: 24px !important;
  min-height: 24px !important;
}

.btn-close.btn-lg {
  width: 40px !important;
  height: 40px !important;
  font-size: 16px !important;
  min-width: 40px !important;
  min-height: 40px !important;
}

.btn-close.btn-xl {
  width: 48px !important;
  height: 48px !important;
  font-size: 18px !important;
  min-width: 48px !important;
  min-height: 48px !important;
}

/* Touch-friendly close button */
.btn-close-touch-friendly {
  min-height: 44px;
  min-width: 44px;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  user-select: none;
}

/* ==================== */
/* WINDOW COMPONENT     */
/* ==================== */

/* Window Container */
.window-container {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  pointer-events: none;
  z-index: 1050;
  overflow: hidden;
}

/* Window Instance */
.window {
  position: absolute;
  background: var(--kim-surface, #ffffff);
  border: 1px solid var(--kim-border, #dee2e6);
  border-radius: var(--kim-radius-md, 8px);
  box-shadow: var(--kim-shadow-lg, 0 12px 32px rgba(0, 0, 0, 0.16));
  display: flex;
  flex-direction: column;
  min-width: 300px;
  min-height: 200px;
  max-width: calc(100vw - 40px);
  max-height: calc(100vh - 40px);
  pointer-events: auto;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  overflow: hidden;
  user-select: none;
}

/* Window Header */
.window-header {
  display: flex;
  align-items: center;
  padding: 8px 12px;
  background: var(--kim-surface-alt, #f8f9fa);
  border-bottom: 1px solid var(--kim-border, #dee2e6);
  border-top-left-radius: inherit;
  border-top-right-radius: inherit;
  cursor: move;
  flex-shrink: 0;
  min-height: 40px;
}

.window-header:active {
  cursor: grabbing;
}

.window-title {
  margin: 0;
  font-size: 14px;
  font-weight: 600;
  color: var(--kim-text, #212529);
  flex-shrink: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  padding-right: 8px;
  min-width: 0;
}

.window-subtitle {
  margin: 0;
  font-size: 12px;
  color: var(--kim-text-muted, #6c757d);
  font-weight: normal;
  display: block;
  margin-top: 2px;
}

/* Window Body */
.window-body {
  flex: 1;
  padding: 16px;
  overflow: auto;
  background: var(--kim-surface, #ffffff);
  color: var(--kim-text, #212529);
  position: relative;
}

/* Window Footer */
.window-footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  padding: 12px 16px;
  background: var(--kim-surface-alt, #f8f9fa);
  border-top: 1px solid var(--kim-border, #dee2e6);
  border-bottom-left-radius: inherit;
  border-bottom-right-radius: inherit;
  flex-shrink: 0;
}

/* Window Controls in Header */
.window-header .window-controls {
  flex-shrink: 0;
  margin-left: auto;
}

/* Resize Handles */
.window-resize-handle {
  position: absolute;
  background: transparent;
  z-index: 10;
}

.window-resize-handle.n {
  top: 0;
  left: 8px;
  right: 8px;
  height: 4px;
  cursor: n-resize;
}

.window-resize-handle.s {
  bottom: 0;
  left: 8px;
  right: 8px;
  height: 4px;
  cursor: s-resize;
}

.window-resize-handle.e {
  top: 8px;
  right: 0;
  bottom: 8px;
  width: 4px;
  cursor: e-resize;
}

.window-resize-handle.w {
  top: 8px;
  left: 0;
  bottom: 8px;
  width: 4px;
  cursor: w-resize;
}

.window-resize-handle.ne {
  top: 0;
  right: 0;
  width: 8px;
  height: 8px;
  cursor: ne-resize;
}

.window-resize-handle.nw {
  top: 0;
  left: 0;
  width: 8px;
  height: 8px;
  cursor: nw-resize;
}

.window-resize-handle.se {
  bottom: 0;
  right: 0;
  width: 8px;
  height: 8px;
  cursor: se-resize;
}

.window-resize-handle.sw {
  bottom: 0;
  left: 0;
  width: 8px;
  height: 8px;
  cursor: sw-resize;
}

/* Window States */
.window.minimized {
  transform: scale(0.1);
  opacity: 0;
  pointer-events: none;
}

.window.maximized {
  top: 0 !important;
  left: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  max-width: 100vw !important;
  max-height: 100vh !important;
  border-radius: 0;
}

.window.maximized .window-header {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}

.window.maximized .window-footer {
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}

.window.dragging {
  transition: none;
  z-index: 1060;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.3);
}

.window.resizing {
  transition: none;
  z-index: 1060;
}

/* Window Variants */
.window.window-outlined {
  border: 2px solid var(--kim-primary, #0d6efd);
  box-shadow: 0 8px 24px rgba(13, 110, 253, 0.15);
}

.window.window-elevated {
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.2);
}

.window.window-rounded {
  border-radius: 12px;
}

.window.window-frosted {
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  background: rgba(255, 255, 255, 0.8);
  border-color: rgba(255, 255, 255, 0.3);
}

.window.window-dark {
  background: var(--kim-dark-surface, #212529);
  color: var(--kim-dark-text, #ffffff);
  border-color: var(--kim-dark-border, #495057);
}

.window.window-dark .window-header {
  background: var(--kim-dark-surface-alt, #343a40);
  border-bottom-color: var(--kim-dark-border, #495057);
}

.window.window-dark .window-footer {
  background: var(--kim-dark-surface-alt, #343a40);
  border-top-color: var(--kim-dark-border, #495057);
}

.window.window-dark .window-title {
  color: var(--kim-dark-text, #ffffff);
}

.window.window-dark .window-subtitle {
  color: var(--kim-dark-text-muted, #adb5bd);
}

/* Window Sizes */
.window.window-sm {
  min-width: 250px;
  min-height: 150px;
}

.window.window-lg {
  min-width: 600px;
  min-height: 400px;
}

.window.window-xl {
  min-width: 800px;
  min-height: 600px;
}

/* Window Animations */
.window.window-animated {
  animation: windowFadeIn 0.3s ease-out;
}

@keyframes windowFadeIn {
  from {
    opacity: 0;
    transform: scale(0.9) translateY(20px);
  }
  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

.window.window-animated.minimized {
  animation: windowMinimize 0.2s ease-in;
}

@keyframes windowMinimize {
  from {
    opacity: 1;
    transform: scale(1);
  }
  to {
    opacity: 0;
    transform: scale(0.1);
  }
}

.window.window-animated.maximized {
  animation: windowMaximize 0.3s ease-out;
}

@keyframes windowMaximize {
  from {
    transform: scale(0.95);
  }
  to {
    transform: scale(1);
  }
}

/* Focus States */
.window:focus-within {
  box-shadow: 0 0 0 2px var(--kim-primary, #0d6efd), var(--kim-shadow-lg, 0 12px 32px rgba(0, 0, 0, 0.16));
}

.window.window-focused {
  box-shadow: 0 0 0 2px var(--kim-primary, #0d6efd), var(--kim-shadow-lg, 0 12px 32px rgba(0, 0, 0, 0.16));
}

/* Z-Index Management */
.window {
  z-index: 1050;
}

.window.window-focused {
  z-index: 1055;
}

.window.dragging,
.window.resizing {
  z-index: 1060;
}

/* Theme Integration */
/* Light Theme (default) - already covered above */

/* Dark Theme */
:root[data-theme="dark"] .window {
  background: var(--kim-surface, #1a1a1a);
  border-color: var(--kim-border, #333333);
  color: var(--kim-text, #ffffff);
}

:root[data-theme="dark"] .window .window-header {
  background: var(--kim-surface-alt, #2a2a2a);
  border-bottom-color: var(--kim-border, #333333);
}

:root[data-theme="dark"] .window .window-footer {
  background: var(--kim-surface-alt, #2a2a2a);
  border-top-color: var(--kim-border, #333333);
}

:root[data-theme="dark"] .window .window-title {
  color: var(--kim-text, #ffffff);
}

:root[data-theme="dark"] .window .window-subtitle {
  color: var(--kim-text-muted, #cccccc);
}

/* High Contrast Theme */
:root[data-theme="contrast"] .window {
  background: var(--kim-surface, #ffffff);
  border: 2px solid var(--kim-border, #000000);
  color: var(--kim-text, #000000);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
}

:root[data-theme="contrast"] .window .window-header {
  background: var(--kim-surface-alt, #f0f0f0);
  border-bottom: 2px solid var(--kim-border, #000000);
}

:root[data-theme="contrast"] .window .window-footer {
  background: var(--kim-surface-alt, #f0f0f0);
  border-top: 2px solid var(--kim-border, #000000);
}

:root[data-theme="contrast"] .window .window-title {
  color: var(--kim-text, #000000);
  font-weight: 700;
}

:root[data-theme="contrast"] .window .window-subtitle {
  color: var(--kim-text-muted, #333333);
}

/* Frosted Glass Theme */
:root[data-theme="frosted"] .window {
  backdrop-filter: blur(25px) saturate(180%);
  -webkit-backdrop-filter: blur(25px) saturate(180%);
  background: rgba(255, 255, 255, 0.15);
  border-color: rgba(255, 255, 255, 0.3);
  box-shadow: 
    0 8px 32px rgba(0, 0, 0, 0.1),
    0 2px 8px rgba(0, 0, 0, 0.05),
    inset 0 1px 0 rgba(255, 255, 255, 0.2);
}

:root[data-theme="frosted"] .window .window-header {
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  background: rgba(255, 255, 255, 0.1);
  border-bottom-color: rgba(255, 255, 255, 0.2);
}

:root[data-theme="frosted"] .window .window-footer {
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  background: rgba(255, 255, 255, 0.1);
  border-top-color: rgba(255, 255, 255, 0.2);
}

:root[data-theme="frosted"] .window .window-title {
  color: var(--kim-text, #1a1a1a);
  text-shadow: 0 1px 2px rgba(255, 255, 255, 0.5);
}

:root[data-theme="frosted"] .window .window-subtitle {
  color: var(--kim-text-muted, #4a4a4a);
  text-shadow: 0 1px 2px rgba(255, 255, 255, 0.3);
}

/* Responsive Design */
@media (max-width: 768px) {
  .window {
    min-width: calc(100vw - 20px);
    min-height: calc(100vh - 20px);
    max-width: calc(100vw - 20px);
    max-height: calc(100vh - 20px);
    margin: 10px;
  }
  
  .window.maximized {
    margin: 0;
    border-radius: 0;
  }
  
  .window-header {
    padding: 12px 16px;
    min-height: 48px;
  }
  
  .window-title {
    font-size: 16px;
  }
  
  .window-body {
    padding: 20px;
  }
  
  .window-footer {
    padding: 16px 20px;
  }
}

/* Touch Device Optimizations */
@media (hover: none) and (pointer: coarse) {
  .window-resize-handle {
    min-width: 44px;
    min-height: 44px;
  }
  
  .window-header {
    min-height: 48px;
    padding: 12px 16px;
  }
  
  .window-control-btn {
    min-width: 44px;
    min-height: 44px;
  }
}

/* Accessibility */
.window[role="dialog"] {
  outline: none;
}

.window[role="dialog"]:focus {
  outline: 2px solid var(--kim-primary, #0d6efd);
  outline-offset: 2px;
}

/* Print Styles */
@media print {
  .window {
    position: static !important;
    box-shadow: none !important;
    border: 1px solid #000 !important;
    page-break-inside: avoid;
  }
  
  .window-header,
  .window-footer {
    display: none !important;
  }
  
  .window-body {
    padding: 0 !important;
  }
}

/* ==================== */
/* WINDOW COMPONENT     */
/* ==================== */

/* Window Container */
.window-container {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  pointer-events: none;
  z-index: 1050;
  overflow: hidden;
}

/* Window Instance */
.window {
  position: absolute;
  background: var(--kim-surface, #ffffff);
  border: 1px solid var(--kim-border, #dee2e6);
  border-radius: var(--kim-radius-md, 8px);
  box-shadow: var(--kim-shadow-lg, 0 12px 32px rgba(0, 0, 0, 0.16));
  display: flex;
  flex-direction: column;
  min-width: 300px;
  min-height: 200px;
  max-width: calc(100vw - 40px);
  max-height: calc(100vh - 40px);
  pointer-events: auto;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  overflow: hidden;
  user-select: none;
}

/* Window Header */
.window-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px;
  background: var(--kim-surface-alt, #f8f9fa);
  border-bottom: 1px solid var(--kim-border, #dee2e6);
  border-top-left-radius: inherit;
  border-top-right-radius: inherit;
  cursor: move;
  flex-shrink: 0;
  min-height: 40px;
}

.window-header:active {
  cursor: grabbing;
}

.window-title {
  margin: 0;
  font-size: 14px;
  font-weight: 600;
  color: var(--kim-text, #212529);
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  padding-right: 8px;
}

.window-subtitle {
  margin: 0;
  font-size: 12px;
  color: var(--kim-text-muted, #6c757d);
  font-weight: normal;
  display: block;
  margin-top: 2px;
}

/* Window Body */
.window-body {
  flex: 1;
  padding: 16px;
  overflow: auto;
  background: var(--kim-surface, #ffffff);
  color: var(--kim-text, #212529);
  position: relative;
}

/* Window Footer */
.window-footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  padding: 12px 16px;
  background: var(--kim-surface-alt, #f8f9fa);
  border-top: 1px solid var(--kim-border, #dee2e6);
  border-bottom-left-radius: inherit;
  border-bottom-right-radius: inherit;
  flex-shrink: 0;
}

/* Window Controls in Header */
.window-header .window-controls {
  flex-shrink: 0;
  margin-left: auto;
}

/* Resize Handles */
.window-resize-handle {
  position: absolute;
  background: transparent;
  z-index: 10;
}

.window-resize-handle.n {
  top: 0;
  left: 8px;
  right: 8px;
  height: 4px;
  cursor: n-resize;
}

.window-resize-handle.s {
  bottom: 0;
  left: 8px;
  right: 8px;
  height: 4px;
  cursor: s-resize;
}

.window-resize-handle.e {
  top: 8px;
  right: 0;
  bottom: 8px;
  width: 4px;
  cursor: e-resize;
}

.window-resize-handle.w {
  top: 8px;
  left: 0;
  bottom: 8px;
  width: 4px;
  cursor: w-resize;
}

.window-resize-handle.ne {
  top: 0;
  right: 0;
  width: 8px;
  height: 8px;
  cursor: ne-resize;
}

.window-resize-handle.nw {
  top: 0;
  left: 0;
  width: 8px;
  height: 8px;
  cursor: nw-resize;
}

.window-resize-handle.se {
  bottom: 0;
  right: 0;
  width: 8px;
  height: 8px;
  cursor: se-resize;
}

.window-resize-handle.sw {
  bottom: 0;
  left: 0;
  width: 8px;
  height: 8px;
  cursor: sw-resize;
}

/* Window States */
.window.minimized {
  transform: scale(0.1);
  opacity: 0;
  pointer-events: none;
}

.window.maximized {
  top: 0 !important;
  left: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  max-width: 100vw !important;
  max-height: 100vh !important;
  border-radius: 0;
}

.window.maximized .window-header {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}

.window.maximized .window-footer {
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}

.window.dragging {
  transition: none;
  z-index: 1060;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.3);
}

.window.resizing {
  transition: none;
  z-index: 1060;
}

/* Window Variants */
.window.window-outlined {
  border: 2px solid var(--kim-primary, #0d6efd);
  box-shadow: 0 8px 24px rgba(13, 110, 253, 0.15);
}

.window.window-elevated {
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.2);
}

.window.window-rounded {
  border-radius: 12px;
}

.window.window-frosted {
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  background: rgba(255, 255, 255, 0.8);
  border-color: rgba(255, 255, 255, 0.3);
}

.window.window-dark {
  background: var(--kim-dark-surface, #212529);
  color: var(--kim-dark-text, #ffffff);
  border-color: var(--kim-dark-border, #495057);
}

.window.window-dark .window-header {
  background: var(--kim-dark-surface-alt, #343a40);
  border-bottom-color: var(--kim-dark-border, #495057);
}

.window.window-dark .window-footer {
  background: var(--kim-dark-surface-alt, #343a40);
  border-top-color: var(--kim-dark-border, #495057);
}

.window.window-dark .window-title {
  color: var(--kim-dark-text, #ffffff);
}

.window.window-dark .window-subtitle {
  color: var(--kim-dark-text-muted, #adb5bd);
}

/* Window Sizes */
.window.window-sm {
  min-width: 250px;
  min-height: 150px;
}

.window.window-lg {
  min-width: 600px;
  min-height: 400px;
}

.window.window-xl {
  min-width: 800px;
  min-height: 600px;
}

/* Window Animations */
.window.window-animated {
  animation: windowFadeIn 0.3s ease-out;
}

@keyframes windowFadeIn {
  from {
    opacity: 0;
    transform: scale(0.9) translateY(20px);
  }
  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

.window.window-animated.minimized {
  animation: windowMinimize 0.2s ease-in;
}

@keyframes windowMinimize {
  from {
    opacity: 1;
    transform: scale(1);
  }
  to {
    opacity: 0;
    transform: scale(0.1);
  }
}

.window.window-animated.maximized {
  animation: windowMaximize 0.3s ease-out;
}

@keyframes windowMaximize {
  from {
    transform: scale(0.95);
  }
  to {
    transform: scale(1);
  }
}

/* Focus States */
.window:focus-within {
  box-shadow: 0 0 0 2px var(--kim-primary, #0d6efd), var(--kim-shadow-lg, 0 12px 32px rgba(0, 0, 0, 0.16));
}

.window.window-focused {
  box-shadow: 0 0 0 2px var(--kim-primary, #0d6efd), var(--kim-shadow-lg, 0 12px 32px rgba(0, 0, 0, 0.16));
}

/* Z-Index Management */
.window {
  z-index: 1050;
}

.window.window-focused {
  z-index: 1055;
}

.window.dragging,
.window.resizing {
  z-index: 1060;
}

/* Theme Integration */
/* Light Theme (default) - already covered above */

/* Dark Theme */
:root[data-theme="dark"] .window {
  background: var(--kim-surface, #1a1a1a);
  border-color: var(--kim-border, #333333);
  color: var(--kim-text, #ffffff);
}

:root[data-theme="dark"] .window .window-header {
  background: var(--kim-surface-alt, #2a2a2a);
  border-bottom-color: var(--kim-border, #333333);
}

:root[data-theme="dark"] .window .window-footer {
  background: var(--kim-surface-alt, #2a2a2a);
  border-top-color: var(--kim-border, #333333);
}

:root[data-theme="dark"] .window .window-title {
  color: var(--kim-text, #ffffff);
}

:root[data-theme="dark"] .window .window-subtitle {
  color: var(--kim-text-muted, #cccccc);
}

/* High Contrast Theme */
:root[data-theme="contrast"] .window {
  background: var(--kim-surface, #ffffff);
  border: 2px solid var(--kim-border, #000000);
  color: var(--kim-text, #000000);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
}

:root[data-theme="contrast"] .window .window-header {
  background: var(--kim-surface-alt, #f0f0f0);
  border-bottom: 2px solid var(--kim-border, #000000);
}

:root[data-theme="contrast"] .window .window-footer {
  background: var(--kim-surface-alt, #f0f0f0);
  border-top: 2px solid var(--kim-border, #000000);
}

:root[data-theme="contrast"] .window .window-title {
  color: var(--kim-text, #000000);
  font-weight: 700;
}

:root[data-theme="contrast"] .window .window-subtitle {
  color: var(--kim-text-muted, #333333);
}

/* Frosted Glass Theme */
:root[data-theme="frosted"] .window {
  backdrop-filter: blur(25px) saturate(180%);
  -webkit-backdrop-filter: blur(25px) saturate(180%);
  background: rgba(255, 255, 255, 0.15);
  border-color: rgba(255, 255, 255, 0.3);
  box-shadow: 
    0 8px 32px rgba(0, 0, 0, 0.1),
    0 2px 8px rgba(0, 0, 0, 0.05),
    inset 0 1px 0 rgba(255, 255, 255, 0.2);
}

:root[data-theme="frosted"] .window .window-header {
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  background: rgba(255, 255, 255, 0.1);
  border-bottom-color: rgba(255, 255, 255, 0.2);
}

:root[data-theme="frosted"] .window .window-footer {
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  background: rgba(255, 255, 255, 0.1);
  border-top-color: rgba(255, 255, 255, 0.2);
}

:root[data-theme="frosted"] .window .window-title {
  color: var(--kim-text, #1a1a1a);
  text-shadow: 0 1px 2px rgba(255, 255, 255, 0.5);
}

:root[data-theme="frosted"] .window .window-subtitle {
  color: var(--kim-text-muted, #4a4a4a);
  text-shadow: 0 1px 2px rgba(255, 255, 255, 0.3);
}

/* Responsive Design */
@media (max-width: 768px) {
  .window {
    min-width: calc(100vw - 20px);
    min-height: calc(100vh - 20px);
    max-width: calc(100vw - 20px);
    max-height: calc(100vh - 20px);
    margin: 10px;
  }
  
  .window.maximized {
    margin: 0;
    border-radius: 0;
  }
  
  .window-header {
    padding: 12px 16px;
    min-height: 48px;
  }
  
  .window-title {
    font-size: 16px;
  }
  
  .window-body {
    padding: 20px;
  }
  
  .window-footer {
    padding: 16px 20px;
  }
}

/* Touch Device Optimizations */
@media (hover: none) and (pointer: coarse) {
  .window-resize-handle {
    min-width: 44px;
    min-height: 44px;
  }
  
  .window-header {
    min-height: 48px;
    padding: 12px 16px;
  }
  
  .window-control-btn {
    min-width: 44px;
    min-height: 44px;
  }
}

/* Accessibility */
.window[role="dialog"] {
  outline: none;
}

.window[role="dialog"]:focus {
  outline: 2px solid var(--kim-primary, #0d6efd);
  outline-offset: 2px;
}

/* Print Styles */
@media print {
  .window {
    position: static !important;
    box-shadow: none !important;
    border: 1px solid #000 !important;
    page-break-inside: avoid;
  }
  
  .window-header,
  .window-footer {
    display: none !important;
  }
  
  .window-body {
    padding: 0 !important;
  }
}

/* ==================== */
/* MENUBAR COMPONENT    */
/* ==================== */

/* Menubar Container */
.menubar {
  display: flex;
  align-items: center;
  background: var(--kim-surface-alt, #f8f9fa);
  border-bottom: 1px solid var(--kim-border, #dee2e6);
  padding: 0;
  margin: 0;
  list-style: none;
  font-size: 13px;
  font-weight: 500;
  color: var(--kim-text, #212529);
  user-select: none;
  flex-shrink: 0;
  min-height: 28px;
}

/* Menubar Item */
.menubar-item {
  position: relative;
  display: flex;
  align-items: center;
  padding: 4px 8px;
  cursor: pointer;
  border-radius: 4px;
  margin: 2px;
  transition: all 0.15s ease-in-out;
  white-space: nowrap;
}

.menubar-item:hover {
  background: var(--kim-primary, #0d6efd);
  color: var(--kim-primary-contrast, #ffffff);
}

.menubar-item.active {
  background: var(--kim-primary, #0d6efd);
  color: var(--kim-primary-contrast, #ffffff);
}

.menubar-item.disabled {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}

/* Menubar Item with Dropdown Arrow */
.menubar-item.has-dropdown::after {
  content: '▾';
  margin-left: 4px;
  font-size: 10px;
  opacity: 0.7;
}

.menubar-item:hover::after,
.menubar-item.active::after {
  opacity: 1;
}

/* Menubar Separator */
.menubar-separator {
  width: 1px;
  height: 16px;
  background: var(--kim-border, #dee2e6);
  margin: 0 4px;
  flex-shrink: 0;
}

/* Dropdown Menu */
.menubar-dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 200px;
  background: var(--kim-surface, #ffffff);
  border: 1px solid var(--kim-border, #dee2e6);
  border-radius: var(--kim-radius-sm, 4px);
  box-shadow: var(--kim-shadow-lg, 0 12px 32px rgba(0, 0, 0, 0.16));
  z-index: 1070;
  padding: 4px 0;
  margin-top: 2px;
  display: none;
  list-style: none;
  margin: 0;
}

.menubar-dropdown.show {
  display: block;
  animation: menubarDropdownFadeIn 0.15s ease-out;
}

@keyframes menubarDropdownFadeIn {
  from {
    opacity: 0;
    transform: translateY(-4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Dropdown Menu Item */
.menubar-dropdown-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 6px 12px;
  cursor: pointer;
  transition: all 0.15s ease-in-out;
  position: relative;
  font-size: 13px;
  color: var(--kim-text, #212529);
}

.menubar-dropdown-item:hover {
  background: var(--kim-primary, #0d6efd);
  color: var(--kim-primary-contrast, #ffffff);
}

.menubar-dropdown-item.disabled {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}

.menubar-dropdown-item.checked::before {
  content: '✓';
  position: absolute;
  left: 8px;
  font-weight: bold;
}

.menubar-dropdown-item.checked {
  padding-left: 24px;
}

/* Dropdown Item with Submenu */
.menubar-dropdown-item.has-submenu::after {
  content: '▸';
  margin-left: 8px;
  font-size: 10px;
  opacity: 0.7;
}

.menubar-dropdown-item:hover::after {
  opacity: 1;
}

/* Submenu */
.menubar-submenu {
  position: absolute;
  left: 100%;
  top: 0;
  min-width: 180px;
  background: var(--kim-surface, #ffffff);
  border: 1px solid var(--kim-border, #dee2e6);
  border-radius: var(--kim-radius-sm, 4px);
  box-shadow: var(--kim-shadow-lg, 0 12px 32px rgba(0, 0, 0, 0.16));
  z-index: 1071;
  padding: 4px 0;
  display: none;
  list-style: none;
  margin: 0;
}

.menubar-dropdown-item:hover .menubar-submenu {
  display: block;
  animation: menubarSubmenuFadeIn 0.15s ease-out;
}

@keyframes menubarSubmenuFadeIn {
  from {
    opacity: 0;
    transform: translateX(-4px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

/* Keyboard Shortcuts */
.menubar-shortcut {
  margin-left: 16px;
  font-size: 11px;
  opacity: 0.7;
  font-family: monospace;
}

.menubar-dropdown-item:hover .menubar-shortcut {
  opacity: 0.9;
}

/* Menubar Variants */
.menubar.menubar-compact {
  min-height: 24px;
  font-size: 12px;
}

.menubar.menubar-compact .menubar-item {
  padding: 2px 6px;
  margin: 1px;
}

.menubar.menubar-large {
  min-height: 36px;
  font-size: 14px;
}

.menubar.menubar-large .menubar-item {
  padding: 6px 12px;
  margin: 3px;
}

/* Menubar Styles */
.menubar.menubar-outlined {
  border: 1px solid var(--kim-border, #dee2e6);
  border-radius: var(--kim-radius-sm, 4px);
  margin: 4px;
}

.menubar.menubar-elevated {
  box-shadow: var(--kim-shadow-md, 0 4px 12px rgba(0, 0, 0, 0.12));
}

.menubar.menubar-flat {
  border-bottom: none;
  background: transparent;
}

/* Menubar in Window Header */
.window-header .menubar {
  flex: 1;
  margin: 0 8px;
  background: transparent;
  border: none;
  min-height: auto;
  display: flex;
  align-items: center;
}

/* Menubar Container (after header placement) */
.window-menubar-container {
  background: var(--kim-surface-alt, #f8f9fa);
  border-bottom: 1px solid var(--kim-border, #dee2e6);
  padding: 0;
  flex-shrink: 0;
}

.window-menubar-container .menubar {
  margin: 0;
  background: transparent;
  border: none;
  min-height: 32px;
  display: flex;
  align-items: center;
  padding: 0 8px;
}

.window-header .menubar .menubar-item {
  margin: 0 1px;
  padding: 2px 6px;
  font-size: 12px;
}

/* Theme Integration */
/* Light Theme (default) - already covered above */

/* Dark Theme */
:root[data-theme="dark"] .menubar {
  background: var(--kim-surface-alt, #2a2a2a);
  border-bottom-color: var(--kim-border, #333333);
  color: var(--kim-text, #ffffff);
}

:root[data-theme="dark"] .window-menubar-container {
  background: var(--kim-surface-alt, #2a2a2a);
  border-bottom-color: var(--kim-border, #333333);
}

:root[data-theme="dark"] .menubar-dropdown,
:root[data-theme="dark"] .menubar-submenu {
  background: var(--kim-surface, #1a1a1a);
  border-color: var(--kim-border, #333333);
  color: var(--kim-text, #ffffff);
}

:root[data-theme="dark"] .menubar-separator {
  background: var(--kim-border, #333333);
}

/* High Contrast Theme */
:root[data-theme="contrast"] .menubar {
  background: var(--kim-surface-alt, #f0f0f0);
  border-bottom: 2px solid var(--kim-border, #000000);
  color: var(--kim-text, #000000);
}

:root[data-theme="contrast"] .window-menubar-container {
  background: var(--kim-surface-alt, #f0f0f0);
  border-bottom: 2px solid var(--kim-border, #000000);
}

:root[data-theme="contrast"] .menubar-dropdown,
:root[data-theme="contrast"] .menubar-submenu {
  background: var(--kim-surface, #ffffff);
  border: 2px solid var(--kim-border, #000000);
  color: var(--kim-text, #000000);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

:root[data-theme="contrast"] .menubar-separator {
  background: var(--kim-border, #000000);
  width: 2px;
}

:root[data-theme="contrast"] .menubar-item:hover,
:root[data-theme="contrast"] .menubar-item.active,
:root[data-theme="contrast"] .menubar-dropdown-item:hover {
  background: var(--kim-primary, #000000);
  color: var(--kim-primary-contrast, #ffffff);
}

/* Frosted Glass Theme */
:root[data-theme="frosted"] .menubar {
  background: rgba(255, 255, 255, 0.7);
  border-bottom-color: rgba(255, 255, 255, 0.8);
  color: var(--kim-text, #1a1a1a);
  pointer-events: auto;
  /* Ensure menubar appears above other elements in frosted theme */
  position: relative;
  z-index: 9999;
}

:root[data-theme="frosted"] .window-menubar-container {
  background: rgba(255, 255, 255, 0.7);
  border-bottom-color: rgba(255, 255, 255, 0.8);
  pointer-events: auto;
}

:root[data-theme="frosted"] .menubar-dropdown,
:root[data-theme="frosted"] .menubar-submenu {
  background: rgba(255, 255, 255, 0.85);
  border-color: rgba(255, 255, 255, 0.9);
  box-shadow: 
    0 8px 32px rgba(0, 0, 0, 0.1),
    0 2px 8px rgba(0, 0, 0, 0.05),
    inset 0 1px 0 rgba(255, 255, 255, 0.8);
  pointer-events: auto;
  /* Fix z-index stacking for frosted glass theme */
  z-index: 10000;
  /* Ensure proper positioning and stacking */
  position: absolute;
  transform: translateZ(0);
}

:root[data-theme="frosted"] .menubar-submenu {
  z-index: 10001;
}

:root[data-theme="frosted"] .menubar-separator {
  background: rgba(255, 255, 255, 0.2);
}

/* Additional frosted glass menubar fixes */
:root[data-theme="frosted"] .menubar-item,
:root[data-theme="frosted"] .menubar-dropdown-item {
  pointer-events: auto;
  /* Ensure proper positioning for frosted theme */
  position: relative;
}

/* Fix standalone menubar container stacking in frosted theme */
:root[data-theme="frosted"] .standalone-menubar-wrapper {
  position: relative;
  z-index: 9998;
}

:root[data-theme="frosted"] .menubar-dropdown.show,
:root[data-theme="frosted"] .menubar-submenu.show {
  pointer-events: auto;
  /* Ensure visible dropdowns have highest z-index */
  z-index: 10002;
}

:root[data-theme="frosted"] .menubar-item:hover,
:root[data-theme="frosted"] .menubar-item.active,
:root[data-theme="frosted"] .menubar-dropdown-item:hover {
  background: rgba(26, 115, 232, 0.8);
  color: var(--kim-text, #1a1a1a);
  pointer-events: auto;
}

/* Responsive Design */
@media (max-width: 768px) {
  .menubar {
    flex-wrap: wrap;
    min-height: auto;
    padding: 4px;
  }
  
  .menubar-item {
    padding: 6px 8px;
    margin: 1px;
    font-size: 14px;
  }
  
  .menubar-dropdown {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    max-width: 90vw;
    max-height: 80vh;
    overflow-y: auto;
  }
  
  .menubar-submenu {
    position: static;
    box-shadow: none;
    border: none;
    border-top: 1px solid var(--kim-border, #dee2e6);
    margin-top: 4px;
    padding-top: 4px;
  }
}

/* Touch Device Optimizations */
@media (hover: none) and (pointer: coarse) {
  .menubar-item {
    min-height: 44px;
    padding: 8px 12px;
  }
  
  .menubar-dropdown-item {
    min-height: 44px;
    padding: 10px 16px;
  }
  
  .menubar-dropdown-item.checked {
    padding-left: 32px;
  }
}

/* Accessibility */
.menubar[role="menubar"] {
  outline: none;
}

.menubar-item[role="menuitem"]:focus {
  outline: 2px solid var(--kim-primary, #0d6efd);
  outline-offset: 2px;
}

.menubar-dropdown-item[role="menuitem"]:focus {
  outline: 2px solid var(--kim-primary, #0d6efd);
  outline-offset: -2px;
}

/* Print Styles */
@media print {
  .menubar {
    display: none !important;
  }
}

/* ==================== */
/* COLLAPSIBLE          */
/* ==================== */

.collapsible-container {
  margin-bottom: 1rem;
}

.collapsible-container .collapse {
  overflow: hidden;
}

.collapsible-container .collapse.show {
  animation: slideDown 0.3s ease-out;
}

.collapsible-container .collapse:not(.show) {
  animation: slideUp 0.3s ease-out;
}

@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes slideUp {
  from {
    opacity: 1;
    transform: translateY(0);
  }
  to {
    opacity: 0;
    transform: translateY(-10px);
  }
}

/* Toggle icon animations */
.toggle-icon {
  transition: transform 0.2s ease;
}

.collapsible-container .collapse.show ~ .collapsible-container .toggle-icon,
.collapsible-container .collapse.show + .toggle-icon {
  transform: rotate(180deg);
}

/* ==================== */
/* DIVIDER              */
/* ==================== */

.kimbs-divider {
  position: relative;
  background-color: var(--kim-border);
  transition: background-color 0.2s ease;
  user-select: none;
}

.kimbs-divider-resizable {
  cursor: ns-resize;
}

.kimbs-divider-resizable:hover {
  background-color: var(--kim-primary);
}

.kimbs-divider-vertical {
  cursor: ew-resize;
}

.kimbs-divider-vertical:hover {
  background-color: var(--kim-primary);
}

.kimbs-divider-handle {
  position: absolute;
  background-color: var(--kim-text-muted);
  border-radius: 1px;
  opacity: 0.6;
}

.kimbs-divider:not(.kimbs-divider-resizable) {
  cursor: default;
}

.kimbs-divider:not(.kimbs-divider-resizable):hover {
  background-color: var(--kim-border);
}

/* Divider in different themes */
:root[data-theme="light"] .kimbs-divider {
  background-color: #dee2e6;
  border: 1px solid #ced4da;
}

:root[data-theme="dark"] .kimbs-divider {
  background-color: #495057;
  border: 1px solid #6c757d;
}

:root[data-theme="contrast"] .kimbs-divider {
  background-color: #000000;
  border: 2px solid #ffffff;
}

:root[data-theme="frosted"] .kimbs-divider {
  background-color: rgba(255, 255, 255, 0.2);
  border: 1px solid rgba(255, 255, 255, 0.3);
  backdrop-filter: blur(10px);
}

/* Divider resize improvements */
.kimbs-divider-resizable {
  position: relative;
  z-index: 1000;
}

.kimbs-divider-resizable:hover {
  background-color: var(--kim-primary);
  transform: scale(1.02);
}

.kimbs-divider-resizable:active {
  background-color: var(--kim-accent);
  transform: scale(1.05);
}

/* Ensure smooth resizing */
.kimbs-divider-resizable * {
  transition: none !important;
}

/* Divider handle improvements */
.kimbs-divider-handle {
  pointer-events: none;
  transition: opacity 0.2s ease;
}

.kimbs-divider-resizable:hover .kimbs-divider-handle {
  opacity: 1 !important;
}

/* Force hardware acceleration for smooth resizing */
.kimbs-divider-resizable {
  transform: translateZ(0);
  will-change: transform;
}

/* Ensure divider works well with flexbox layouts */
.kimbs-divider {
  flex-shrink: 0;
  flex-grow: 0;
}

/* Improve resize performance */
.kimbs-divider-resizable * {
  pointer-events: none;
}

.kimbs-divider-resizable:hover * {
  pointer-events: auto;
}

/* Better visual feedback during resize */
.kimbs-divider-resizable:active {
  box-shadow: 0 0 0 2px var(--kim-primary);
}

/* Popover styles */
.kimbs-popover {
    font-size: 14px;
    line-height: 1.4;
    max-width: 300px;
    word-wrap: break-word;
    z-index: 1080 !important;
    position: fixed !important;
    display: none;
    background: #fff;
    border: 1px solid rgba(0,0,0,0.2);
    border-radius: 4px;
    box-shadow: 0 0.25rem 0.5rem rgba(0,0,0,0.1);
    padding: 0;
    margin: 0;
}

.kimbs-popover .popover-header {
    font-weight: 600;
    font-size: 16px;
    border-bottom: 1px solid rgba(0,0,0,0.1);
    margin: 0;
    padding: 8px 12px;
}

.kimbs-popover .popover-body {
    line-height: 1.5;
    padding: 8px 12px;
    margin: 0;
}

.kimbs-popover .popover-body br {
    line-height: 1.2;
}

.kimbs-popover .popover-body p {
    margin: 0 0 8px 0;
}

.kimbs-popover .popover-body p:last-child {
    margin-bottom: 0;
}

/* Interactive popover content styling */
.kimbs-popover .popover-body .form-control,
.kimbs-popover .popover-body .form-select {
    font-size: 12px;
    padding: 4px 8px;
    border-radius: 4px;
}

.kimbs-popover .popover-body .form-label {
    font-size: 11px;
    font-weight: 600;
    margin-bottom: 4px;
    color: #666;
}

.kimbs-popover .popover-body .form-check {
    margin-bottom: 6px;
}

.kimbs-popover .popover-body .form-check-input {
    margin-top: 0.15em;
}

.kimbs-popover .popover-body .form-check-label {
    font-size: 12px;
    margin-left: 4px;
}

.kimbs-popover .popover-body .btn {
    font-size: 11px;
    padding: 4px 8px;
    border-radius: 4px;
}

.kimbs-popover .popover-body .d-grid .btn {
    text-align: left;
    justify-content: flex-start;
}

.kimbs-popover .popover-body .gap-2 > * + * {
    margin-left: 8px;
}

/* ========================================
   RICH TEXT EDITOR STYLES
   ======================================== */

/* Base Rich Text Editor Container */
.kim-rich-text-editor {
    position: relative;
    border: 2px solid var(--kim-border);
    border-radius: var(--kim-radius-lg);
    background: var(--kim-bg);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    overflow: hidden;
    -webkit-border-radius: var(--kim-radius-lg);
    -moz-border-radius: var(--kim-radius-lg);
    -webkit-box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
    -moz-box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.kim-rich-text-editor:focus-within {
    border-color: var(--kim-primary);
    box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    transform: none;
}

/* Toolbar Styles */
.kim-rte-toolbar {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 12px 16px;
    background: linear-gradient(135deg, var(--kim-bg) 0%, var(--kim-bg-secondary) 100%);
    border-bottom: 1px solid var(--kim-border);
    flex-wrap: wrap;
    position: relative;
    overflow-x: auto;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.kim-rte-toolbar::-webkit-scrollbar {
    display: none;
}

.kim-rte-toolbar::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent 0%, var(--kim-border) 50%, transparent 100%);
}

/* Toolbar Buttons */
.kim-rte-toolbar button {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border: 1px solid var(--kim-border);
    border-radius: var(--kim-radius-md);
    background: var(--kim-bg);
    color: var(--kim-text-muted);
    cursor: pointer;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    overflow: hidden;
    font-weight: 500;
}

.kim-rte-toolbar button::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.1), transparent);
    transition: left 0.5s ease;
}

.kim-rte-toolbar button:hover {
    background: var(--kim-bg-hover);
    border-color: var(--kim-primary);
    color: var(--kim-text);
    transform: translateY(-1px);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.kim-rte-toolbar button:hover::before {
    left: 100%;
}

.kim-rte-toolbar button:active {
    transform: translateY(0);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
}

/* Active State - Enhanced Visual Differentiation */
.kim-rte-toolbar button.active {
    background: var(--kim-primary);
    color: var(--kim-primary-contrast);
    border-color: var(--kim-primary);
    box-shadow: 0 2px 12px rgba(var(--kim-primary-rgb), 0.4);
    font-weight: 600;
    transform: translateY(-1px);
}

.kim-rte-toolbar button.active::before {
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
}

.kim-rte-toolbar button.active::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 24px;
    height: 3px;
    background: var(--kim-primary-contrast);
    border-radius: 2px;
    animation: activeIndicator 0.3s ease-out;
    box-shadow: 0 0 8px rgba(var(--kim-primary-contrast-rgb), 0.5);
}

.kim-rte-toolbar button.active:hover {
    background: var(--kim-primary-dark, var(--kim-primary));
    box-shadow: 0 4px 16px rgba(var(--kim-primary-rgb), 0.5);
    transform: translateY(-2px);
}

/* Inactive State - More Subtle */
.kim-rte-toolbar button:not(.active) {
    opacity: 0.7;
}

.kim-rte-toolbar button:not(.active):hover {
    opacity: 1;
}

@keyframes activeIndicator {
    from {
        width: 0;
        opacity: 0;
    }
    to {
        width: 20px;
        opacity: 1;
    }
}

/* Toolbar Selects */
.kim-rte-toolbar select {
    height: 36px;
    padding: 0 12px;
    border: 1px solid var(--kim-border);
    border-radius: var(--kim-radius-md);
    background: var(--kim-bg);
    color: var(--kim-text);
    font-size: 13px;
    cursor: pointer;
    transition: all 0.2s ease;
    min-width: 120px;
}

.kim-rte-toolbar select:hover {
    border-color: var(--kim-primary);
    box-shadow: 0 0 0 2px rgba(var(--kim-primary-rgb), 0.1);
}

.kim-rte-toolbar select:focus {
    outline: none;
    border-color: var(--kim-primary);
    box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.2);
}

/* Color Pickers */
.kim-rte-toolbar input[type="color"] {
    width: 36px;
    height: 36px;
    border: 1px solid var(--kim-border);
    border-radius: var(--kim-radius-md);
    cursor: pointer;
    transition: all 0.2s ease;
    background: transparent;
    padding: 2px;
}

.kim-rte-toolbar input[type="color"]::-webkit-color-swatch-wrapper {
    padding: 0;
    border-radius: var(--kim-radius-sm);
    overflow: hidden;
}

.kim-rte-toolbar input[type="color"]::-webkit-color-swatch {
    border: none;
    border-radius: var(--kim-radius-sm);
}

.kim-rte-toolbar input[type="color"]:hover {
    border-color: var(--kim-primary);
    transform: scale(1.05);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

/* Separators */
.kim-rte-separator {
    width: 1px;
    height: 24px;
    background: linear-gradient(180deg, transparent 0%, var(--kim-border) 50%, transparent 100%);
    margin: 0 8px;
    position: relative;
}

.kim-rte-separator::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 1px;
    height: 16px;
    background: var(--kim-border);
    border-radius: 1px;
}

/* Editor Area */
.kim-rte-editor {
    min-height: 200px;
    padding: 20px;
    font-family: var(--kim-font-family);
    font-size: 14px;
    line-height: 1.6;
    color: var(--kim-text);
    background: var(--kim-bg);
    border: none;
    outline: none;
    resize: vertical;
    transition: all 0.2s ease;
    position: relative;
}

.kim-rte-editor:focus {
    background: var(--kim-bg);
}

.kim-rte-editor[contenteditable="false"] {
    background: var(--kim-bg-disabled);
    color: var(--kim-text-disabled);
    cursor: not-allowed;
}

/* Content Styling */
.kim-rte-editor h1, .kim-rte-editor h2, .kim-rte-editor h3,
.kim-rte-editor h4, .kim-rte-editor h5, .kim-rte-editor h6 {
    margin: 16px 0 8px 0;
    font-weight: 600;
    line-height: 1.3;
    color: var(--kim-text);
}

.kim-rte-editor h1 { font-size: 2em; }
.kim-rte-editor h2 { font-size: 1.75em; }
.kim-rte-editor h3 { font-size: 1.5em; }
.kim-rte-editor h4 { font-size: 1.25em; }
.kim-rte-editor h5 { font-size: 1.1em; }
.kim-rte-editor h6 { font-size: 1em; }

.kim-rte-editor p {
    margin: 8px 0;
    line-height: 1.6;
}

.kim-rte-editor blockquote {
    margin: 16px 0;
    padding: 12px 20px;
    border-left: 4px solid var(--kim-primary);
    background: var(--kim-bg-secondary);
    border-radius: 0 var(--kim-radius-md) var(--kim-radius-md) 0;
    font-style: italic;
    position: relative;
}

.kim-rte-editor blockquote::before {
    content: '"';
    position: absolute;
    top: -8px;
    left: 8px;
    font-size: 3em;
    color: var(--kim-primary);
    opacity: 0.3;
    font-family: serif;
}

.kim-rte-editor pre {
    background: var(--kim-bg-secondary);
    border: 1px solid var(--kim-border);
    border-radius: var(--kim-radius-md);
    padding: 16px;
    margin: 16px 0;
    overflow-x: auto;
    font-family: 'Monaco', 'Menlo', 'Ubuntu Mono', monospace;
    font-size: 13px;
    line-height: 1.4;
}

.kim-rte-editor code {
    background: var(--kim-bg-secondary);
    border: 1px solid var(--kim-border);
    border-radius: var(--kim-radius-sm);
    padding: 2px 6px;
    font-family: 'Monaco', 'Menlo', 'Ubuntu Mono', monospace;
    font-size: 0.9em;
    color: var(--kim-primary);
}

.kim-rte-editor ul, .kim-rte-editor ol {
    margin: 12px 0;
    padding-left: 24px;
}

.kim-rte-editor li {
    margin: 4px 0;
    line-height: 1.5;
}

.kim-rte-editor a {
    color: var(--kim-primary);
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: all 0.2s ease;
}

.kim-rte-editor a:hover {
    border-bottom-color: var(--kim-primary);
    text-shadow: 0 0 8px rgba(var(--kim-primary-rgb), 0.3);
}

.kim-rte-editor img {
    max-width: 100%;
    height: auto;
    border-radius: var(--kim-radius-md);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    transition: transform 0.2s ease;
}

.kim-rte-editor img:hover {
    transform: scale(1.02);
}

.kim-rte-editor table {
    width: 100%;
    border-collapse: collapse;
    margin: 16px 0;
    border-radius: var(--kim-radius-md);
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.kim-rte-editor th, .kim-rte-editor td {
    padding: 12px 16px;
    text-align: left;
    border-bottom: 1px solid var(--kim-border);
}

.kim-rte-editor th {
    background: var(--kim-bg-secondary);
    font-weight: 600;
    color: var(--kim-text);
}

.kim-rte-editor tr:hover {
    background: var(--kim-bg-hover);
}

.kim-rte-editor hr {
    border: none;
    height: 2px;
    background: linear-gradient(90deg, transparent 0%, var(--kim-border) 50%, transparent 100%);
    margin: 24px 0;
    position: relative;
}

.kim-rte-editor hr::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 40px;
    height: 2px;
    background: var(--kim-primary);
    border-radius: 1px;
}

/* Size Variants */
.kim-rich-text-editor.rte-sm {
    border: 2px solid var(--kim-border);
    border-radius: var(--kim-radius-md);
}

.kim-rich-text-editor.rte-sm:focus-within {
    box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
}

.kim-rich-text-editor.rte-sm .kim-rte-toolbar {
    padding: 8px 12px;
    gap: 2px;
}

.kim-rich-text-editor.rte-sm .kim-rte-toolbar button {
    width: 32px;
    height: 32px;
    font-size: 12px;
}

.kim-rich-text-editor.rte-sm .kim-rte-toolbar select {
    height: 32px;
    font-size: 12px;
    min-width: 100px;
}

.kim-rich-text-editor.rte-sm .kim-rte-toolbar input[type="color"] {
    width: 32px;
    height: 32px;
}

.kim-rich-text-editor.rte-sm .kim-rte-editor {
    min-height: 150px;
    padding: 16px;
    font-size: 13px;
}

.kim-rich-text-editor.rte-lg {
    border: 2px solid var(--kim-border);
    border-radius: var(--kim-radius-xl);
}

.kim-rich-text-editor.rte-lg:focus-within {
    box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.15);
    -moz-box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.15);
}

.kim-rich-text-editor.rte-lg .kim-rte-toolbar {
    padding: 16px 20px;
    gap: 6px;
}

.kim-rich-text-editor.rte-lg .kim-rte-toolbar button {
    width: 40px;
    height: 40px;
    font-size: 16px;
}

.kim-rich-text-editor.rte-lg .kim-rte-toolbar select {
    height: 40px;
    font-size: 14px;
    min-width: 140px;
}

.kim-rich-text-editor.rte-lg .kim-rte-toolbar input[type="color"] {
    width: 40px;
    height: 40px;
}

.kim-rich-text-editor.rte-lg .kim-rte-editor {
    min-height: 300px;
    padding: 24px;
    font-size: 16px;
}

/* Style Variants */
.kim-rich-text-editor.rte-outlined {
    border: 2px solid var(--kim-border);
    background: transparent;
    box-shadow: none;
}

.kim-rich-text-editor.rte-outlined:focus-within {
    border-color: var(--kim-primary);
    box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    transform: none;
}

.kim-rich-text-editor.rte-sm.rte-outlined:focus-within {
    box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
}

.kim-rich-text-editor.rte-lg.rte-outlined:focus-within {
    box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.15);
    -moz-box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.15);
}

.kim-rich-text-editor.rte-outlined .kim-rte-toolbar {
    background: transparent;
    border-bottom: 1px solid var(--kim-border);
}

.kim-rich-text-editor.rte-elevated {
    border: 2px solid var(--kim-border);
    border-radius: var(--kim-radius-lg);
    box-shadow: none;
    background: var(--kim-bg);
    transform: none;
}

.kim-rich-text-editor.rte-elevated:focus-within {
    border-color: var(--kim-primary);
    box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    transform: none;
}

.kim-rich-text-editor.rte-sm.rte-elevated:focus-within {
    box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
}

.kim-rich-text-editor.rte-lg.rte-elevated:focus-within {
    box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.15);
    -moz-box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.15);
}

.kim-rich-text-editor.rte-elevated .kim-rte-toolbar {
    background: linear-gradient(135deg, var(--kim-bg) 0%, var(--kim-bg-secondary) 100%);
    border-bottom: 1px solid var(--kim-border);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

.kim-rich-text-editor.rte-flat {
    border: 2px solid var(--kim-border);
    border-radius: var(--kim-radius-lg);
    box-shadow: none;
    background: var(--kim-bg-secondary);
}

.kim-rich-text-editor.rte-flat:focus-within {
    border-color: var(--kim-primary);
    box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    transform: none;
}

.kim-rich-text-editor.rte-sm.rte-flat:focus-within {
    box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
}

.kim-rich-text-editor.rte-lg.rte-flat:focus-within {
    box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.15);
    -moz-box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.15);
}

.kim-rich-text-editor.rte-flat .kim-rte-toolbar {
    background: var(--kim-bg-secondary);
    border-bottom: 1px solid var(--kim-border);
}

.kim-rich-text-editor.rte-flat .kim-rte-editor {
    background: var(--kim-bg-secondary);
}

.kim-rich-text-editor.rte-flat .kim-rte-editor:focus {
    background: var(--kim-bg);
}

/* Color Variants */
.kim-rich-text-editor.rte-primary {
    border: 2px solid var(--kim-border);
    border-radius: var(--kim-radius-lg);
}

.kim-rich-text-editor.rte-primary:focus-within {
    border-color: var(--kim-primary);
    box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    transform: none;
}

.kim-rich-text-editor.rte-sm.rte-primary:focus-within {
    box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
}

.kim-rich-text-editor.rte-lg.rte-primary:focus-within {
    box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.15);
    -moz-box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.15);
}

.kim-rich-text-editor.rte-primary .kim-rte-toolbar button.active {
    background: var(--kim-primary);
    color: var(--kim-primary-contrast);
    box-shadow: 0 2px 12px rgba(var(--kim-primary-rgb), 0.4);
}

.kim-rich-text-editor.rte-primary .kim-rte-toolbar button.active::after {
    background: var(--kim-primary-contrast);
    box-shadow: 0 0 8px rgba(var(--kim-primary-contrast-rgb), 0.5);
}

.kim-rich-text-editor.rte-success {
    border: 2px solid var(--kim-border);
    border-radius: var(--kim-radius-lg);
}

.kim-rich-text-editor.rte-success:focus-within {
    border-color: var(--kim-success);
    box-shadow: 0 0 0 3px rgba(var(--kim-success-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-success-rgb), 0.15);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-success-rgb), 0.15);
    transform: none;
}

.kim-rich-text-editor.rte-sm.rte-success:focus-within {
    box-shadow: 0 0 0 3px rgba(var(--kim-success-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-success-rgb), 0.15);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-success-rgb), 0.15);
}

.kim-rich-text-editor.rte-lg.rte-success:focus-within {
    box-shadow: 0 0 0 4px rgba(var(--kim-success-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 4px rgba(var(--kim-success-rgb), 0.15);
    -moz-box-shadow: 0 0 0 4px rgba(var(--kim-success-rgb), 0.15);
}

.kim-rich-text-editor.rte-success .kim-rte-toolbar button.active {
    background: var(--kim-success);
    color: var(--kim-success-contrast);
    box-shadow: 0 2px 12px rgba(var(--kim-success-rgb), 0.4);
}

.kim-rich-text-editor.rte-success .kim-rte-toolbar button.active::after {
    background: var(--kim-success-contrast);
    box-shadow: 0 0 8px rgba(var(--kim-success-contrast-rgb), 0.5);
}

.kim-rich-text-editor.rte-danger {
    border: 2px solid var(--kim-border);
    border-radius: var(--kim-radius-lg);
}

.kim-rich-text-editor.rte-danger:focus-within {
    border-color: var(--kim-danger);
    box-shadow: 0 0 0 3px rgba(var(--kim-danger-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-danger-rgb), 0.15);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-danger-rgb), 0.15);
    transform: none;
}

.kim-rich-text-editor.rte-sm.rte-danger:focus-within {
    box-shadow: 0 0 0 3px rgba(var(--kim-danger-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-danger-rgb), 0.15);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-danger-rgb), 0.15);
}

.kim-rich-text-editor.rte-lg.rte-danger:focus-within {
    box-shadow: 0 0 0 4px rgba(var(--kim-danger-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 4px rgba(var(--kim-danger-rgb), 0.15);
    -moz-box-shadow: 0 0 0 4px rgba(var(--kim-danger-rgb), 0.15);
}

.kim-rich-text-editor.rte-danger .kim-rte-toolbar button.active {
    background: var(--kim-danger);
    color: var(--kim-danger-contrast);
    box-shadow: 0 2px 12px rgba(var(--kim-danger-rgb), 0.4);
}

.kim-rich-text-editor.rte-danger .kim-rte-toolbar button.active::after {
    background: var(--kim-danger-contrast);
    box-shadow: 0 0 8px rgba(var(--kim-danger-contrast-rgb), 0.5);
}

/* Responsive Design */
@media (max-width: 768px) {
    .kim-rte-toolbar {
        padding: 8px 12px;
        gap: 2px;
    }
    
    .kim-rte-toolbar button {
        width: 32px;
        height: 32px;
        font-size: 12px;
    }
    
    .kim-rte-toolbar select {
        height: 32px;
        font-size: 12px;
        min-width: 100px;
    }
    
    .kim-rte-toolbar input[type="color"] {
        width: 32px;
        height: 32px;
    }
    
    .kim-rte-editor {
        padding: 16px;
        font-size: 16px; /* Prevent zoom on iOS */
    }
    
    .kim-rich-text-editor.rte-lg .kim-rte-editor {
        padding: 20px;
    }
}

/* ======================================== */
/* LIGHT THEME RTE STYLES                   */
/* ======================================== */
[data-theme="light"] .kim-rich-text-editor {
    background: var(--kim-bg);
    border: 2px solid var(--kim-border);
    border-radius: var(--kim-radius-lg);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    overflow: hidden;
}

[data-theme="light"] .kim-rich-text-editor:focus-within {
    border-color: var(--kim-primary);
    box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    transform: none;
}

[data-theme="light"] .kim-rte-toolbar {
    background: var(--kim-bg-soft);
    border-bottom: 1px solid var(--kim-border);
}

[data-theme="light"] .kim-rte-toolbar button {
    background: var(--kim-bg);
    border: 1px solid var(--kim-border);
    color: var(--kim-text-muted);
}

[data-theme="light"] .kim-rte-toolbar button:hover {
    background: var(--kim-bg-hover);
    border-color: var(--kim-primary);
    color: var(--kim-text);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

[data-theme="light"] .kim-rte-toolbar button.active {
    background: var(--kim-primary);
    color: var(--kim-primary-contrast);
    border-color: var(--kim-primary);
    box-shadow: 0 2px 12px rgba(var(--kim-primary-rgb), 0.3);
}

[data-theme="light"] .kim-rte-toolbar button.active::after {
    background: var(--kim-primary-contrast);
    box-shadow: 0 0 8px rgba(var(--kim-primary-contrast-rgb), 0.4);
}

[data-theme="light"] .kim-rte-editor {
    background: var(--kim-bg);
    color: var(--kim-text);
}

[data-theme="light"] .kim-rte-editor:focus {
    background: var(--kim-bg);
}

/* Light Theme Variants */
[data-theme="light"] .kim-rich-text-editor.rte-elevated {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
}

[data-theme="light"] .kim-rich-text-editor.rte-elevated:focus-within {
    border-color: var(--kim-primary);
    box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    transform: none;
}

[data-theme="light"] .kim-rich-text-editor.rte-outlined {
    border: 2px solid var(--kim-border);
    background: transparent;
}

[data-theme="light"] .kim-rich-text-editor.rte-outlined:focus-within {
    border-color: var(--kim-primary);
    box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    background: var(--kim-bg);
    transform: none;
}

[data-theme="light"] .kim-rich-text-editor.rte-flat {
    border: none;
    box-shadow: none;
    background: var(--kim-bg-soft);
}

[data-theme="light"] .kim-rich-text-editor.rte-flat:focus-within {
    background: var(--kim-bg);
    border-color: var(--kim-primary);
    box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    transform: none;
}

/* ======================================== */
/* DARK THEME RTE STYLES                    */
/* ======================================== */
[data-theme="dark"] .kim-rich-text-editor {
    background: var(--kim-bg);
    border: 2px solid var(--kim-border);
    border-radius: var(--kim-radius-lg);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
    overflow: hidden;
}

[data-theme="dark"] .kim-rich-text-editor:focus-within {
    border-color: var(--kim-primary);
    box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    transform: none;
}

[data-theme="dark"] .kim-rte-toolbar {
    background: var(--kim-bg-soft);
    border-bottom: 1px solid var(--kim-border);
}

[data-theme="dark"] .kim-rte-toolbar button {
    background: var(--kim-bg);
    border: 1px solid var(--kim-border);
    color: var(--kim-text-muted);
}

[data-theme="dark"] .kim-rte-toolbar button:hover {
    background: var(--kim-bg-hover);
    border-color: var(--kim-primary);
    color: var(--kim-text);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

[data-theme="dark"] .kim-rte-toolbar button.active {
    background: var(--kim-primary);
    color: var(--kim-primary-contrast);
    border-color: var(--kim-primary);
    box-shadow: 0 2px 12px rgba(var(--kim-primary-rgb), 0.4);
}

[data-theme="dark"] .kim-rte-toolbar button.active::after {
    background: var(--kim-primary-contrast);
    box-shadow: 0 0 8px rgba(var(--kim-primary-contrast-rgb), 0.5);
}

[data-theme="dark"] .kim-rte-editor {
    background: var(--kim-bg);
    color: var(--kim-text);
}

[data-theme="dark"] .kim-rte-editor:focus {
    background: var(--kim-bg);
}

/* Dark Theme Variants */
[data-theme="dark"] .kim-rich-text-editor.rte-elevated {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4);
}

[data-theme="dark"] .kim-rich-text-editor.rte-elevated:focus-within {
    border-color: var(--kim-primary);
    box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    transform: none;
}

[data-theme="dark"] .kim-rich-text-editor.rte-outlined {
    border: 2px solid var(--kim-border);
    background: transparent;
}

[data-theme="dark"] .kim-rich-text-editor.rte-outlined:focus-within {
    border-color: var(--kim-primary);
    box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    background: var(--kim-bg);
    transform: none;
}

[data-theme="dark"] .kim-rich-text-editor.rte-flat {
    border: none;
    box-shadow: none;
    background: var(--kim-bg-soft);
}

[data-theme="dark"] .kim-rich-text-editor.rte-flat:focus-within {
    background: var(--kim-bg);
    border-color: var(--kim-primary);
    box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    transform: none;
}

/* ======================================== */
/* HIGH CONTRAST THEME RTE STYLES           */
/* ======================================== */
[data-theme="contrast"] .kim-rich-text-editor {
    background: var(--kim-bg);
    border: 3px solid var(--kim-border);
    border-radius: var(--kim-radius-lg);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
    overflow: hidden;
}

[data-theme="contrast"] .kim-rich-text-editor:focus-within {
    border-color: var(--kim-primary);
    box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.5);
    -webkit-box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.5);
    -moz-box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.5);
    transform: none;
}

[data-theme="contrast"] .kim-rte-toolbar {
    background: var(--kim-bg-soft);
    border-bottom: 3px solid var(--kim-border);
}

[data-theme="contrast"] .kim-rte-toolbar button {
    background: var(--kim-bg);
    border: 2px solid var(--kim-border);
    color: var(--kim-text);
    font-weight: 600;
    min-width: 40px;
    height: 40px;
}

[data-theme="contrast"] .kim-rte-toolbar button:hover {
    background: var(--kim-bg-hover);
    border-color: var(--kim-primary);
    color: var(--kim-text);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
    transform: translateY(-2px);
}

[data-theme="contrast"] .kim-rte-toolbar button.active {
    background: var(--kim-primary);
    color: var(--kim-primary-contrast);
    border-color: var(--kim-primary);
    box-shadow: 0 4px 16px rgba(var(--kim-primary-rgb), 0.6);
    font-weight: 700;
}

[data-theme="contrast"] .kim-rte-toolbar button.active::after {
    background: var(--kim-primary-contrast);
    box-shadow: 0 0 12px rgba(var(--kim-primary-contrast-rgb), 0.8);
    height: 4px;
    width: 28px;
}

[data-theme="contrast"] .kim-rte-editor {
    background: var(--kim-bg);
    color: var(--kim-text);
    border: 2px solid transparent;
    font-weight: 500;
}

[data-theme="contrast"] .kim-rte-editor:focus {
    background: var(--kim-bg);
    border-color: var(--kim-primary);
}

/* High Contrast Theme Variants */
[data-theme="contrast"] .kim-rich-text-editor.rte-elevated {
    box-shadow: 0 6px 24px rgba(0, 0, 0, 0.4);
    border-width: 4px;
}

[data-theme="contrast"] .kim-rich-text-editor.rte-elevated:focus-within {
    border-color: var(--kim-primary);
    box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.5);
    transform: none;
}

[data-theme="contrast"] .kim-rich-text-editor.rte-outlined {
    border: 4px solid var(--kim-border);
    background: transparent;
}

[data-theme="contrast"] .kim-rich-text-editor.rte-outlined:focus-within {
    border-color: var(--kim-primary);
    box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.5);
    -webkit-box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.5);
    -moz-box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.5);
    background: var(--kim-bg);
    transform: none;
}

[data-theme="contrast"] .kim-rich-text-editor.rte-flat {
    border: 3px solid var(--kim-border);
    box-shadow: none;
    background: var(--kim-bg-soft);
}

[data-theme="contrast"] .kim-rich-text-editor.rte-flat:focus-within {
    background: var(--kim-bg);
    border-color: var(--kim-primary);
    box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.5);
    -webkit-box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.5);
    -moz-box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.5);
    transform: none;
}

/* ======================================== */
/* FROSTED GLASS THEME RTE STYLES           */
/* ======================================== */
[data-theme="frosted"] .kim-rich-text-editor {
    backdrop-filter: blur(15px) saturate(140%);
    -webkit-backdrop-filter: blur(15px) saturate(140%);
    background: rgba(var(--kim-bg-rgb), 0.7);
    border: 2px solid rgba(var(--kim-border-rgb), 0.3);
    border-radius: var(--kim-radius-lg);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
    overflow: hidden;
}

[data-theme="frosted"] .kim-rich-text-editor:focus-within {
    background: rgba(var(--kim-bg-rgb), 0.85);
    border-color: var(--kim-primary);
    box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    backdrop-filter: blur(20px) saturate(150%);
    -webkit-backdrop-filter: blur(20px) saturate(150%);
    transform: none;
}

[data-theme="frosted"] .kim-rte-toolbar {
    background: rgba(var(--kim-bg-secondary-rgb), 0.6);
    backdrop-filter: blur(10px) saturate(120%);
    -webkit-backdrop-filter: blur(10px) saturate(120%);
    border-bottom: 1px solid rgba(var(--kim-border-rgb), 0.2);
}

[data-theme="frosted"] .kim-rte-toolbar button {
    background: rgba(var(--kim-bg-rgb), 0.8);
    border: 1px solid rgba(var(--kim-border-rgb), 0.3);
    color: var(--kim-text-muted);
    backdrop-filter: blur(5px);
    -webkit-backdrop-filter: blur(5px);
}

[data-theme="frosted"] .kim-rte-toolbar button:hover {
    background: rgba(var(--kim-bg-hover-rgb), 0.9);
    border-color: var(--kim-primary);
    color: var(--kim-text);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
    backdrop-filter: blur(8px) saturate(130%);
    -webkit-backdrop-filter: blur(8px) saturate(130%);
}

[data-theme="frosted"] .kim-rte-toolbar button.active {
    background: rgba(var(--kim-primary-rgb), 0.9);
    color: var(--kim-primary-contrast);
    border-color: var(--kim-primary);
    box-shadow: 0 4px 20px rgba(var(--kim-primary-rgb), 0.4);
    backdrop-filter: blur(10px) saturate(140%);
    -webkit-backdrop-filter: blur(10px) saturate(140%);
}

[data-theme="frosted"] .kim-rte-toolbar button.active::after {
    background: var(--kim-primary-contrast);
    box-shadow: 0 0 12px rgba(var(--kim-primary-contrast-rgb), 0.6);
}

[data-theme="frosted"] .kim-rte-editor {
    background: rgba(var(--kim-bg-rgb), 0.8);
    color: var(--kim-text);
    backdrop-filter: blur(5px);
    -webkit-backdrop-filter: blur(5px);
}

[data-theme="frosted"] .kim-rte-editor:focus {
    background: rgba(var(--kim-bg-rgb), 0.9);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

/* Frosted Theme Variants */
[data-theme="frosted"] .kim-rich-text-editor.rte-elevated {
    box-shadow: 0 12px 48px rgba(0, 0, 0, 0.15);
    backdrop-filter: blur(20px) saturate(150%);
    -webkit-backdrop-filter: blur(20px) saturate(150%);
}

[data-theme="frosted"] .kim-rich-text-editor.rte-elevated:focus-within {
    border-color: var(--kim-primary);
    box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    transform: none;
    backdrop-filter: blur(25px) saturate(160%);
    -webkit-backdrop-filter: blur(25px) saturate(160%);
}

[data-theme="frosted"] .kim-rich-text-editor.rte-outlined {
    border: 2px solid rgba(var(--kim-border-rgb), 0.4);
    background: rgba(var(--kim-bg-rgb), 0.5);
    backdrop-filter: blur(12px) saturate(130%);
    -webkit-backdrop-filter: blur(12px) saturate(130%);
}

[data-theme="frosted"] .kim-rich-text-editor.rte-outlined:focus-within {
    border-color: var(--kim-primary);
    box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    background: rgba(var(--kim-bg-rgb), 0.8);
    backdrop-filter: blur(18px) saturate(140%);
    -webkit-backdrop-filter: blur(18px) saturate(140%);
    transform: none;
}

[data-theme="frosted"] .kim-rich-text-editor.rte-flat {
    border: 1px solid rgba(var(--kim-border-rgb), 0.2);
    box-shadow: none;
    background: rgba(var(--kim-bg-rgb), 0.6);
    backdrop-filter: blur(10px) saturate(120%);
    -webkit-backdrop-filter: blur(10px) saturate(120%);
}

[data-theme="frosted"] .kim-rich-text-editor.rte-flat:focus-within {
    background: rgba(var(--kim-bg-rgb), 0.8);
    border-color: var(--kim-primary);
    box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    transform: none;
    backdrop-filter: blur(15px) saturate(130%);
    -webkit-backdrop-filter: blur(15px) saturate(130%);
}

/* ======================================== */
/* THEME-SPECIFIC LOADING ANIMATIONS        */
/* ======================================== */
.kim-rich-text-editor.loading {
    position: relative;
    pointer-events: none;
}

.kim-rich-text-editor.loading::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(var(--kim-bg-rgb), 0.8);
    backdrop-filter: blur(2px);
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: center;
}

.kim-rich-text-editor.loading::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 32px;
    height: 32px;
    border: 3px solid var(--kim-border);
    border-top: 3px solid var(--kim-primary);
    border-radius: 50%;
    animation: spin 1s linear infinite;
    z-index: 11;
}

/* Theme-specific loading overlays */
[data-theme="dark"] .kim-rich-text-editor.loading::after {
    background: rgba(var(--kim-bg-rgb), 0.9);
    backdrop-filter: blur(3px);
}

[data-theme="contrast"] .kim-rich-text-editor.loading::after {
    background: rgba(var(--kim-bg-rgb), 0.95);
    backdrop-filter: blur(4px);
}

[data-theme="contrast"] .kim-rich-text-editor.loading::before {
    border-width: 4px;
    width: 36px;
    height: 36px;
}

[data-theme="frosted"] .kim-rich-text-editor.loading::after {
    background: rgba(var(--kim-bg-rgb), 0.7);
    backdrop-filter: blur(8px) saturate(120%);
    -webkit-backdrop-filter: blur(8px) saturate(120%);
}

[data-theme="frosted"] .kim-rich-text-editor.loading::before {
    border: 3px solid rgba(var(--kim-border-rgb), 0.5);
    border-top: 3px solid var(--kim-primary);
    backdrop-filter: blur(5px);
    -webkit-backdrop-filter: blur(5px);
}

@keyframes spin {
    0% { transform: translate(-50%, -50%) rotate(0deg); }
    100% { transform: translate(-50%, -50%) rotate(360deg); }
}

/* ======================================== */
/* THEME-SPECIFIC COLOR VARIANTS            */
/* ======================================== */

/* Light Theme Color Variants */
[data-theme="light"] .kim-rich-text-editor.rte-primary:focus-within {
    border-color: var(--kim-primary);
    box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.15);
    transform: none;
}

[data-theme="light"] .kim-rich-text-editor.rte-success:focus-within {
    border-color: var(--kim-success);
    box-shadow: 0 0 0 3px rgba(var(--kim-success-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-success-rgb), 0.15);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-success-rgb), 0.15);
    transform: none;
}

[data-theme="light"] .kim-rich-text-editor.rte-danger:focus-within {
    border-color: var(--kim-danger);
    box-shadow: 0 0 0 3px rgba(var(--kim-danger-rgb), 0.15);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-danger-rgb), 0.15);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-danger-rgb), 0.15);
    transform: none;
}

/* Dark Theme Color Variants */
[data-theme="dark"] .kim-rich-text-editor.rte-primary:focus-within {
    border-color: var(--kim-primary);
    box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    transform: none;
}

[data-theme="dark"] .kim-rich-text-editor.rte-success:focus-within {
    border-color: var(--kim-success);
    box-shadow: 0 0 0 3px rgba(var(--kim-success-rgb), 0.3);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-success-rgb), 0.3);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-success-rgb), 0.3);
    transform: none;
}

[data-theme="dark"] .kim-rich-text-editor.rte-danger:focus-within {
    border-color: var(--kim-danger);
    box-shadow: 0 0 0 3px rgba(var(--kim-danger-rgb), 0.3);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-danger-rgb), 0.3);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-danger-rgb), 0.3);
    transform: none;
}

/* High Contrast Theme Color Variants */
[data-theme="contrast"] .kim-rich-text-editor.rte-primary:focus-within {
    border-color: var(--kim-primary);
    box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.5);
    -webkit-box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.5);
    -moz-box-shadow: 0 0 0 4px rgba(var(--kim-primary-rgb), 0.5);
    transform: none;
}

[data-theme="contrast"] .kim-rich-text-editor.rte-success:focus-within {
    border-color: var(--kim-success);
    box-shadow: 0 0 0 4px rgba(var(--kim-success-rgb), 0.5);
    -webkit-box-shadow: 0 0 0 4px rgba(var(--kim-success-rgb), 0.5);
    -moz-box-shadow: 0 0 0 4px rgba(var(--kim-success-rgb), 0.5);
    transform: none;
}

[data-theme="contrast"] .kim-rich-text-editor.rte-danger:focus-within {
    border-color: var(--kim-danger);
    box-shadow: 0 0 0 4px rgba(var(--kim-danger-rgb), 0.5);
    -webkit-box-shadow: 0 0 0 4px rgba(var(--kim-danger-rgb), 0.5);
    -moz-box-shadow: 0 0 0 4px rgba(var(--kim-danger-rgb), 0.5);
    transform: none;
}

/* Frosted Theme Color Variants */
[data-theme="frosted"] .kim-rich-text-editor.rte-primary:focus-within {
    border-color: var(--kim-primary);
    box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-primary-rgb), 0.3);
    transform: none;
}

[data-theme="frosted"] .kim-rich-text-editor.rte-success:focus-within {
    border-color: var(--kim-success);
    box-shadow: 0 0 0 3px rgba(var(--kim-success-rgb), 0.3);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-success-rgb), 0.3);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-success-rgb), 0.3);
    transform: none;
}

[data-theme="frosted"] .kim-rich-text-editor.rte-danger:focus-within {
    border-color: var(--kim-danger);
    box-shadow: 0 0 0 3px rgba(var(--kim-danger-rgb), 0.3);
    -webkit-box-shadow: 0 0 0 3px rgba(var(--kim-danger-rgb), 0.3);
    -moz-box-shadow: 0 0 0 3px rgba(var(--kim-danger-rgb), 0.3);
    transform: none;
}