/* ========================================
   ROOVIX COMPONENTS LIBRARY
   For Roovix Product Family (Knowledge Base, Social, Search, etc.)
   ======================================== */
/* ========================================
   1. BUTTON COMPONENTS - Roovix Exact
   ======================================== */

/* Base Button - Roovix's exact button styles */
.roovix-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-sans);
  font-weight: var(--font-medium);
  line-height: 20px; /* Roovix's exact line-height */
  border-radius: var(--radius-base);
  cursor: pointer;
  transition: all var(--transition-fast);
  border: 1px solid;
  text-decoration: none;
  white-space: nowrap;
  position: relative;
  padding: var(--space-1) var(--space-2);
}

/* Button Sizes - Roovix exact dimensions */
.roovix-btn-xs {
  height: 28px; /* Roovix's smallest */
  padding: 0 var(--space-2);
  font-size: 12px;
}

.roovix-btn-sm {
  height: 32px; /* Roovix's small */
  padding: 0 var(--space-3);
  font-size: 12px;
}

.roovix-btn-base {
  height: 40px; /* Roovix's default */
  padding: 0 var(--space-4);
  font-size: 14px;
}

.roovix-btn-md {
  height: 44px; /* Roovix's medium */
  padding: 0 var(--space-6);
  font-size: 14px;
}

.roovix-btn-lg {
  height: 48px; /* Roovix's large */
  padding: 0 var(--space-8);
  font-size: 16px;
}

.roovix-btn-xl {
  height: 56px; /* Roovix's extra large */
  padding: 0 var(--space-10);
  font-size: 18px;
}

/* Primary Button - Roovix exact */
.roovix-btn-primary {
  background-color: var(--roovix-btn-primary-bg);
  color: var(--roovix-btn-primary-text);
  border-color: rgba(255,255,255,0.1);
  box-shadow: var(--roovix-shadow-xs);
}

.roovix-btn-primary:hover:not(:disabled) {
  background-color: var(--roovix-btn-primary-bg-hover);
  border-color: rgba(255,255,255,0.2);
}

.roovix-btn-primary:active:not(:disabled) {
  background-color: var(--roovix-btn-primary-bg-active);
  box-shadow: inset 0 1px 0 rgba(0,0,0,0.1);
}

.roovix-btn-primary:disabled {
  background-color: var(--roovix-btn-primary-bg-disabled);
  color: var(--roovix-btn-primary-text-disabled);
  cursor: not-allowed;
  opacity: 0.7;
  border-color: transparent;
}

/* Secondary/Default Button - Roovix exact */
.roovix-btn-secondary {
  background-color: var(--roovix-btn-default-bg);
  color: var(--roovix-btn-default-text);
  border-color: var(--roovix-btn-default-border);
  box-shadow: var(--roovix-shadow-xs);
}

.roovix-btn-secondary:hover:not(:disabled) {
  background-color: var(--roovix-btn-default-bg-hover);
  border-color: var(--roovix-border-emphasis);
}

.roovix-btn-secondary:active:not(:disabled) {
  background-color: var(--roovix-btn-default-bg-active);
  box-shadow: inset 0 1px 0 rgba(0,0,0,0.1);
}

/* Danger Button - Roovix exact */
.roovix-btn-danger {
  background-color: var(--roovix-btn-danger-bg);
  color: var(--roovix-btn-danger-text);
  border-color: var(--roovix-border-danger);
  box-shadow: var(--roovix-shadow-xs);
}

.roovix-btn-danger:hover:not(:disabled) {
  background-color: var(--roovix-btn-danger-bg-hover);
  color: var(--roovix-btn-danger-text-hover);
  border-color: var(--roovix-btn-danger-bg-hover);
}

/* Outline Button - Roovix exact */
.roovix-btn-outline {
  background-color: transparent;
  color: var(--roovix-btn-outline-text);
  border-color: var(--roovix-btn-outline-text);
}

.roovix-btn-outline:hover:not(:disabled) {
  background-color: var(--roovix-btn-outline-bg-hover);
  color: var(--roovix-btn-outline-text-hover);
  border-color: transparent;
}

/* Ghost/Invisible Button - Roovix exact */
.roovix-btn-ghost {
  background-color: transparent;
  color: var(--roovix-text-primary);
  border-color: transparent;
}

.roovix-btn-ghost:hover:not(:disabled) {
  background-color: var(--roovix-btn-invisible-bg-hover);
}

/* Link Button - Roovix exact */
.roovix-btn-link {
  background-color: transparent;
  color: var(--roovix-text-link);
  padding: 0;
  height: auto;
  border: none;
  text-decoration: none;
}

.roovix-btn-link:hover:not(:disabled) {
  text-decoration: underline;
}

/* Icon Buttons - Roovix exact */
.roovix-btn-icon {
  width: 40px;
  padding: 0;
  justify-content: center;
}

.roovix-btn-icon.roovix-btn-xs {
  width: 28px;
}

.roovix-btn-icon.roovix-btn-sm {
  width: 32px;
}

.roovix-btn-icon.roovix-btn-md {
  width: 44px;
}

.roovix-btn-icon.roovix-btn-lg {
  width: 48px;
}

.roovix-btn-icon.roovix-btn-xl {
  width: 56px;
}

/* Button with Icon - Roovix exact spacing */
.roovix-btn-icon-left svg,
.roovix-btn-icon-left img {
  margin-right: var(--space-2);
}

.roovix-btn-icon-right svg,
.roovix-btn-icon-right img {
  margin-left: var(--space-2);
}

/* Button Group - Roovix exact */
.roovix-btn-group {
  display: inline-flex;
  border-radius: var(--radius-base);
  overflow: hidden;
  box-shadow: var(--roovix-shadow-xs);
}

.roovix-btn-group .roovix-btn {
  border-radius: 0;
  box-shadow: none;
  margin-left: -1px;
}

.roovix-btn-group .roovix-btn:first-child {
  margin-left: 0;
  border-top-left-radius: var(--radius-base);
  border-bottom-left-radius: var(--radius-base);
}

.roovix-btn-group .roovix-btn:last-child {
  border-top-right-radius: var(--radius-base);
  border-bottom-right-radius: var(--radius-base);
}

/* Button Loading State */
.roovix-btn-loading {
  pointer-events: none;
  opacity: 0.8;
}

.roovix-btn-loading .roovix-loader {
  margin-right: var(--space-2);
}

/* ========================================
   2. CARD COMPONENTS - Roovix Exact
   ======================================== */

.roovix-card {
  background-color: var(--roovix-bg-primary);
  border: 1px solid var(--roovix-border-default);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: all var(--transition-base);
}

/* Card Sizes */
.roovix-card-sm {
  border-radius: var(--radius-base);
}

.roovix-card-md {
  border-radius: var(--radius-md);
}

.roovix-card-lg {
  border-radius: var(--radius-lg);
}

.roovix-card-xl {
  border-radius: var(--radius-xl);
}

/* Card with shadow - Roovix exact */
.roovix-card-shadow-sm {
  box-shadow: var(--roovix-shadow-sm);
}

.roovix-card-shadow-md {
  box-shadow: var(--roovix-shadow-md);
}

.roovix-card-shadow-lg {
  box-shadow: var(--roovix-shadow-lg);
}

.roovix-card-shadow-floating {
  box-shadow: var(--roovix-shadow-floating-sm);
}

/* Card Interactive - Roovix exact hover effects */
.roovix-card-interactive {
  cursor: pointer;
}

.roovix-card-interactive:hover {
  box-shadow: var(--roovix-shadow-md);
  border-color: var(--roovix-border-emphasis);
}

/* Card Sections - Roovix exact padding */
.roovix-card-header {
  padding: var(--space-4);
  border-bottom: 1px solid var(--roovix-border-muted);
  font-weight: var(--font-semibold);
  display: flex;
  align-items: center;
  justify-content: space-between;
  background-color: var(--roovix-bg-secondary);
}

.roovix-card-header-sm {
  padding: var(--space-3);
}

.roovix-card-header-lg {
  padding: var(--space-6);
}

.roovix-card-body {
  padding: var(--space-4);
}

.roovix-card-body-sm {
  padding: var(--space-3);
}

.roovix-card-body-lg {
  padding: var(--space-6);
}

.roovix-card-footer {
  padding: var(--space-4);
  border-top: 1px solid var(--roovix-border-muted);
  background-color: var(--roovix-bg-muted);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-2);
}

.roovix-card-footer-sm {
  padding: var(--space-3);
}

.roovix-card-footer-lg {
  padding: var(--space-6);
}

/* Card Title - Roovix exact */
.roovix-card-title {
  margin-block-start: 0em;
  margin-block-end: 0em;
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  margin-bottom: var(--space-2);
  color: var(--roovix-text-primary);
}

.roovix-card-subtitle {
  font-size: var(--text-sm);
  color: var(--roovix-text-secondary);
  margin-bottom: var(--space-4);
}

/* Card with Image - Roovix exact */
.roovix-card-image-top {
  width: 100%;
  height: auto;
  aspect-ratio: 16/9;
  object-fit: cover;
  border-bottom: 1px solid var(--roovix-border-muted);
}

.roovix-card-image-left {
  display: flex;
}

.roovix-card-image-left .roovix-card-image {
  width: 200px;
  height: 100%;
  object-fit: cover;
  border-right: 1px solid var(--roovix-border-muted);
}

/* ========================================
   3. AVATAR COMPONENTS - Roovix Exact
   ======================================== */

.roovix-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-round);
  overflow: hidden;
  background-color: var(--roovix-avatar-bg);
  color: var(--roovix-text-primary);
  font-weight: var(--font-medium);
  flex-shrink: 0;
}

.roovix-avatar-border {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-round);
  overflow: hidden;
  background-color: var(--roovix-avatar-bg);
  border: 1px solid var(--roovix-avatar-border);
  color: var(--roovix-text-primary);
  font-weight: var(--font-medium);
  flex-shrink: 0;
}

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

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

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

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

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

.roovix-avatar-xl {
  width: 96px;
  height: 96px;
  font-size: 24px;
}

.roovix-avatar-2xl {
  width: 128px;
  height: 128px;
  font-size: 32px;
}

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

/* Avatar with Status - Roovix exact */
.roovix-avatar-container {
  position: relative;
  display: inline-block;
}

.roovix-avatar-status {
  position: absolute;
  bottom: 2px;
  right: 2px;
  width: 12px;
  height: 12px;
  border-radius: var(--radius-round);
  border: 2px solid var(--roovix-surface-card);
  box-shadow: 0 1px 2px rgba(0,0,0,0.1);
}

.roovix-avatar-status-online {
  background-color: var(--roovix-status-success-bg);
}

.roovix-avatar-status-offline {
  background-color: var(--roovix-text-tertiary);
}

.roovix-avatar-status-away {
  background-color: var(--roovix-status-warning-bg);
}

.roovix-avatar-status-busy {
  background-color: var(--roovix-status-danger-bg);
}

/* Avatar Group / Stack - Roovix exact */
.roovix-avatar-group {
  display: flex;
  align-items: center;
}

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

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

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

.roovix-avatar-group .roovix-avatar-count {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-round);
  background-color: var(--roovix-avatar-stack-fade);
  color: var(--roovix-text-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  margin-left: -8px;
  border: 2px solid var(--roovix-surface-card);
  cursor: pointer;
  transition: transform 0.1s ease;
}

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

/* ========================================
   4. BADGE COMPONENTS - Roovix Exact
   ======================================== */

.roovix-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 var(--space-2);
  font-size: 12px;
  font-weight: 500;
  line-height: 20px;
  border-radius: 2em;
  white-space: nowrap;
  border: 1px solid transparent;
  height: 20px;
}

/* Badge Sizes - Roovix exact */
.roovix-badge-sm {
  padding: 0 var(--space-1);
  font-size: 10px;
  height: 18px;
}

.roovix-badge-base {
  padding: 0 var(--space-2);
  font-size: 12px;
  height: 20px;
}

.roovix-badge-lg {
  padding: 0 var(--space-3);
  font-size: 14px;
  height: 24px;
}

/* Badge Variants - Roovix exact */
.roovix-badge-primary {
  background-color: var(--roovix-btn-primary-bg);
  color: var(--roovix-btn-primary-text);
}

.roovix-badge-secondary {
  background-color: var(--roovix-bg-secondary);
  color: var(--roovix-text-secondary);
  border: 1px solid var(--roovix-border-default);
}

.roovix-badge-success {
  background-color: var(--roovix-status-success-bg-muted);
  color: var(--roovix-text-success);
  border: 1px solid var(--roovix-status-success-border);
}

.roovix-badge-danger {
  background-color: var(--roovix-status-danger-bg-muted);
  color: var(--roovix-text-danger);
  border: 1px solid var(--roovix-status-danger-border);
}

.roovix-badge-warning {
  background-color: var(--roovix-status-warning-bg-muted);
  color: var(--roovix-text-warning);
  border: 1px solid var(--roovix-status-warning-border);
}

.roovix-badge-info {
  background-color: var(--roovix-status-info-bg-muted);
  color: var(--roovix-text-info);
  border: 1px solid var(--roovix-status-info-border);
}

.roovix-badge-done {
  background-color: var(--roovix-status-done-bg-muted);
  color: var(--roovix-text-done);
  border: 1px solid var(--roovix-status-done-border);
}

/* Badge with Icon */
.roovix-badge-icon-left svg,
.roovix-badge-icon-left img {
  margin-right: 4px;
  width: 12px;
  height: 12px;
}

.roovix-badge-icon-right svg,
.roovix-badge-icon-right img {
  margin-left: 4px;
  width: 12px;
  height: 12px;
}

/* ========================================
   5. FORM COMPONENTS - Roovix Exact
   ======================================== */

/* Input - Roovix exact */
.roovix-input {
  width: 100%;
  height: 32px;
  padding: 0 var(--space-3);
  font-family: var(--font-sans);
  font-size: 14px;
  line-height: 20px;
  background-color: var(--roovix-input-bg);
  border: 1px solid var(--roovix-input-border);
  border-radius: var(--radius-base);
  color: var(--roovix-input-text);
  transition: all var(--transition-fast);
  box-shadow: inset 0 1px 2px rgba(0,0,0,0.05);
}

.roovix-input:focus {
  outline: none;
  border-color: var(--roovix-input-border-focus);
  box-shadow: 0 0 0 3px var(--roovix-status-info-bg-muted);
}

.roovix-input:disabled {
  background-color: var(--roovix-input-bg-disabled);
  color: var(--roovix-text-disabled);
  cursor: not-allowed;
  opacity: 0.7;
}

.roovix-input-error {
  border-color: var(--roovix-input-border-error);
}

.roovix-input-error:focus {
  border-color: var(--roovix-input-border-error);
  box-shadow: 0 0 0 3px var(--roovix-status-danger-bg-muted);
}

.roovix-input-success {
  border-color: var(--roovix-input-border-success);
}

/* Input Sizes - Roovix exact */
.roovix-input-sm {
  height: 28px;
  font-size: 12px;
  padding: 0 var(--space-2);
}

.roovix-input-lg {
  height: 40px;
  font-size: 16px;
  padding: 0 var(--space-4);
}

/* Input with Icon */
.roovix-input-wrapper {
  position: relative;
  display: flex;
  align-items: center;
}

.roovix-input-icon-left {
  position: absolute;
  left: var(--space-3);
  color: var(--roovix-text-tertiary);
  pointer-events: none;
}

.roovix-input-icon-left ~ .roovix-input {
  padding-left: calc(var(--space-8) + 4px);
}

.roovix-input-icon-right {
  position: absolute;
  right: var(--space-3);
  color: var(--roovix-text-tertiary);
}

/* Textarea - Roovix exact */
.roovix-textarea {
  width: 100%;
  padding: var(--space-3);
  font-family: var(--font-sans);
  font-size: 14px;
  line-height: 20px;
  background-color: var(--roovix-input-bg);
  border: 1px solid var(--roovix-input-border);
  border-radius: var(--radius-base);
  color: var(--roovix-input-text);
  resize: vertical;
  min-height: 80px;
  box-shadow: inset 0 1px 2px rgba(0,0,0,0.05);
}

.roovix-textarea:focus {
  outline: none;
  border-color: var(--roovix-input-border-focus);
  box-shadow: 0 0 0 3px var(--roovix-status-info-bg-muted);
}

/* Select - Roovix exact */
.roovix-select {
  width: 100%;
  height: 32px;
  padding: 0 var(--space-8) 0 var(--space-3);
  font-family: var(--font-sans);
  font-size: 14px;
  line-height: 20px;
  background-color: var(--roovix-input-bg);
  border: 1px solid var(--roovix-input-border);
  border-radius: var(--radius-base);
  color: var(--roovix-input-text);
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16'%3E%3Cpath fill='%2359636e' d='M4.427 5.427l3.396 3.396a.25.25 0 00.354 0l3.396-3.396A.25.25 0 0111.604 5H4.396a.25.25 0 00-.177.427z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--space-2) center;
  background-size: 16px;
}

.roovix-select:focus {
  outline: none;
  border-color: var(--roovix-input-border-focus);
  box-shadow: 0 0 0 3px var(--roovix-status-info-bg-muted);
}

/* Checkbox - Roovix exact */
.roovix-checkbox {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  cursor: pointer;
}

.roovix-checkbox input[type="checkbox"] {
  width: 16px;
  height: 16px;
  margin: 0;
  accent-color: var(--roovix-input-checked-bg);
  border-radius: 3px;
}

.roovix-checkbox-label {
  font-size: 14px;
  color: var(--roovix-text-primary);
}

/* Radio - Roovix exact */
.roovix-radio {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  cursor: pointer;
}

.roovix-radio input[type="radio"] {
  width: 16px;
  height: 16px;
  margin: 0;
  accent-color: var(--roovix-input-checked-bg);
}

/* Toggle/Switch - Roovix exact */
.roovix-toggle {
  position: relative;
  display: inline-block;
  width: 48px;
  height: 24px;
}

.roovix-toggle input {
  opacity: 0;
  width: 0;
  height: 0;
}

.roovix-toggle-slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: var(--roovix-border-default);
  transition: var(--transition-base);
  border-radius: 24px;
}

.roovix-toggle-slider:before {
  position: absolute;
  content: "";
  height: 20px;
  width: 20px;
  left: 2px;
  bottom: 2px;
  background-color: var(--roovix-input-knob-bg);
  transition: var(--transition-base);
  border-radius: 50%;
  box-shadow: 0 1px 2px rgba(0,0,0,0.2);
}

input:checked + .roovix-toggle-slider {
  background-color: var(--roovix-input-checked-bg);
}

input:checked + .roovix-toggle-slider:before {
  transform: translateX(24px);
}

/* Form Group - Roovix exact */
.roovix-form-group {
  margin-bottom: var(--space-4);
}

.roovix-form-label {
  display: block;
  margin-bottom: var(--space-2);
  font-size: 14px;
  font-weight: 600;
  color: var(--roovix-text-primary);
}

.roovix-form-hint {
  display: block;
  margin-top: var(--space-1);
  font-size: 12px;
  color: var(--roovix-text-tertiary);
}

.roovix-form-error {
  display: block;
  margin-top: var(--space-1);
  font-size: 12px;
  color: var(--roovix-text-danger);
}

/* ========================================
   6. ALERT COMPONENTS - Roovix Exact
   ======================================== */

.roovix-alert {
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  margin-bottom: var(--space-4);
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  font-size: 14px;
  line-height: 20px;
}

.roovix-alert-sm {
  padding: var(--space-2) var(--space-3);
  font-size: 12px;
}

.roovix-alert-lg {
  padding: var(--space-4) var(--space-6);
  font-size: 16px;
}

/* Alert Variants - Roovix exact */
.roovix-alert-success {
  background-color: var(--roovix-status-success-bg-muted);
  border-color: var(--roovix-status-success-border);
  color: var(--roovix-text-success);
}

.roovix-alert-danger {
  background-color: var(--roovix-status-danger-bg-muted);
  border-color: var(--roovix-status-danger-border);
  color: var(--roovix-text-danger);
}

.roovix-alert-warning {
  background-color: var(--roovix-status-warning-bg-muted);
  border-color: var(--roovix-status-warning-border);
  color: var(--roovix-text-warning);
}

.roovix-alert-info {
  background-color: var(--roovix-status-info-bg-muted);
  border-color: var(--roovix-status-info-border);
  color: var(--roovix-text-info);
}

.roovix-alert-icon {
  flex-shrink: 0;
  font-size: 16px;
  line-height: 20px;
}

.roovix-alert-content {
  flex: 1;
}

.roovix-alert-title {
  font-weight: 600;
  margin-bottom: var(--space-1);
}

.roovix-alert-close {
  background: none;
  border: none;
  color: currentColor;
  opacity: 0.7;
  cursor: pointer;
  padding: 0;
  font-size: 18px;
  line-height: 1;
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.roovix-alert-close:hover {
  opacity: 1;
}

/* ========================================
   7. NAVIGATION COMPONENTS - Roovix Exact
   ======================================== */

/* Navbar - Roovix exact */
.roovix-navbar {
  display: flex;
  align-items: center;
  padding: 0 var(--space-4);
  background-color: var(--roovix-surface-header);
  color: var(--roovix-text-white);
  gap: var(--space-4);
  height: 64px;
  border-bottom: 1px solid var(--roovix-border-default);
  position: sticky;
  top: 0;
  z-index: var(--z-header);
}

.roovix-navbar-brand {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: 20px;
  font-weight: 600;
  color: var(--roovix-text-white);
  text-decoration: none;
}

.roovix-navbar-brand img {
  height: 32px;
  width: auto;
}

.roovix-navbar-nav {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  flex: 1;
  height: 100%;
}

.roovix-navbar-item {
  display: flex;
  align-items: center;
  height: 100%;
  padding: 0 var(--space-3);
  color: var(--roovix-text-white);
  text-decoration: none;
  font-size: 14px;
  font-weight: 500;
  transition: all var(--transition-fast);
  position: relative;
  opacity: 0.8;
}

.roovix-navbar-item:hover {
  opacity: 1;
}

.roovix-navbar-item.active {
  opacity: 1;
}

.roovix-navbar-item.active::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: var(--space-3);
  right: var(--space-3);
  height: 2px;
  background-color: var(--roovix-text-white);
}

/* Navbar Search */
.roovix-navbar-search {
  flex: 0 1 300px;
  margin: 0 var(--space-4);
}

.roovix-navbar-search .roovix-input {
  background-color: rgba(255,255,255,0.15);
  border-color: transparent;
  color: var(--roovix-text-white);
}

.roovix-navbar-search .roovix-input::placeholder {
  color: rgba(255,255,255,0.7);
}

/* Navbar Actions */
.roovix-navbar-actions {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

/* Side Navigation - Roovix exact */
.roovix-side-nav {
  width: 280px;
  background-color: var(--roovix-surface-sidebar);
  border-right: 1px solid var(--roovix-border-default);
  height: 100%;
  overflow-y: auto;
  position: sticky;
  top: 64px;
  align-self: flex-start;
}

.roovix-side-nav-header {
  padding: var(--space-3) var(--space-4);
  font-size: 12px;
  font-weight: 600;
  color: var(--roovix-text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.roovix-side-nav-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-4);
  color: var(--roovix-text-primary);
  text-decoration: none;
  font-size: 14px;
  font-weight: 400;
  transition: all var(--transition-fast);
  border-left: 2px solid transparent;
}

.roovix-side-nav-item:hover {
  background-color: var(--roovix-bg-muted);
  text-decoration: none;
}

.roovix-side-nav-item.active {
  background-color: var(--roovix-bg-muted);
  color: var(--roovix-text-primary);
  border-left-color: var(--roovix-text-accent);
  font-weight: 500;
}

.roovix-side-nav-icon {
  width: 16px;
  height: 16px;
  color: var(--roovix-text-secondary);
  flex-shrink: 0;
}

/* Tabs - Roovix exact */
.roovix-tabs {
  display: flex;
  border-bottom: 1px solid var(--roovix-border-muted);
  gap: var(--space-2);
  overflow-x: auto;
  padding: 0 var(--space-4);
}

.roovix-tab {
  padding: var(--space-3) var(--space-4);
  font-size: 14px;
  font-weight: 500;
  color: var(--roovix-text-secondary);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  transition: all var(--transition-fast);
  white-space: nowrap;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
}

.roovix-tab:hover {
  color: var(--roovix-text-primary);
  border-bottom-color: var(--roovix-border-muted);
}

.roovix-tab.active {
  color: var(--roovix-text-primary);
  border-bottom-color: var(--roovix-text-accent);
}

/* Breadcrumb - Roovix exact */
.roovix-breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  flex-wrap: wrap;
  font-size: 14px;
  background-color: var(--roovix-bg-muted);
  border-bottom: 1px solid var(--roovix-border-muted);
}

.roovix-breadcrumb-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--roovix-text-secondary);
}

.roovix-breadcrumb-item a {
  color: var(--roovix-text-link);
  text-decoration: none;
}

.roovix-breadcrumb-item a:hover {
  text-decoration: underline;
}

.roovix-breadcrumb-item.active {
  color: var(--roovix-text-primary);
  font-weight: 500;
}

.roovix-breadcrumb-separator {
  color: var(--roovix-text-tertiary);
}

/* Pagination - Roovix exact */
.roovix-pagination {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  justify-content: center;
  margin: var(--space-6) 0;
}

.roovix-page-item {
  list-style: none;
}

.roovix-page-link {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  height: 32px;
  padding: 0 var(--space-2);
  font-size: 14px;
  color: var(--roovix-text-primary);
  border: 1px solid var(--roovix-border-default);
  border-radius: var(--radius-base);
  text-decoration: none;
  transition: all var(--transition-fast);
  background-color: var(--roovix-surface-card);
}

.roovix-page-link:hover {
  background-color: var(--roovix-bg-muted);
  border-color: var(--roovix-border-emphasis);
  text-decoration: none;
}

.roovix-page-item.active .roovix-page-link {
  background-color: var(--roovix-btn-primary-bg);
  color: var(--roovix-btn-primary-text);
  border-color: var(--roovix-btn-primary-bg);
}

.roovix-page-item.disabled .roovix-page-link {
  opacity: 0.5;
  pointer-events: none;
  background-color: var(--roovix-bg-muted);
}

/* ========================================
   8. TABLE COMPONENTS - Roovix Exact
   ======================================== */

.roovix-table {
  width: 100%;
  border-collapse: collapse;
  background-color: var(--roovix-surface-card);
  border-radius: var(--radius-md);
  overflow: hidden;
  font-size: 14px;
  line-height: 20px;
}

.roovix-table th {
  text-align: left;
  padding: var(--space-3) var(--space-4);
  font-size: 12px;
  font-weight: 600;
  color: var(--roovix-text-secondary);
  border-bottom: 1px solid var(--roovix-border-muted);
  background-color: var(--roovix-bg-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.roovix-table td {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--roovix-border-muted);
  color: var(--roovix-text-primary);
}

.roovix-table tbody tr:hover td {
  background-color: var(--roovix-bg-muted);
}

.roovix-table-bordered {
  border: 1px solid var(--roovix-border-default);
}

.roovix-table-bordered th,
.roovix-table-bordered td {
  border: 1px solid var(--roovix-border-muted);
}

/* Table Sizes */
.roovix-table-sm th,
.roovix-table-sm td {
  padding: var(--space-2) var(--space-3);
  font-size: 12px;
}

.roovix-table-lg th,
.roovix-table-lg td {
  padding: var(--space-4) var(--space-6);
  font-size: 16px;
}

/* Table Striped */
.roovix-table-striped tbody tr:nth-child(odd) {
  background-color: var(--roovix-bg-muted);
}

/* Table with Actions */
.roovix-table-actions {
  display: flex;
  gap: var(--space-2);
  justify-content: flex-end;
}

/* ========================================
   9. MODAL COMPONENTS - Roovix Exact
   ======================================== */

.roovix-modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: var(--roovix-overlay-backdrop);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: var(--z-modal-backdrop);
  backdrop-filter: blur(4px);
  padding: var(--space-4);
}

.roovix-modal {
  background-color: var(--roovix-surface-modal);
  border-radius: var(--radius-lg);
  box-shadow: var(--roovix-shadow-floating-md);
  max-width: 90%;
  width: 500px;
  max-height: calc(100vh - var(--space-8));
  overflow-y: auto;
  z-index: var(--z-modal);
  animation: roovix-modal-slide-in 0.2s ease;
}

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

/* Modal Sizes - Roovix exact */
.roovix-modal-sm {
  width: 400px;
}

.roovix-modal-md {
  width: 500px;
}

.roovix-modal-lg {
  width: 800px;
}

.roovix-modal-xl {
  width: 1000px;
}

.roovix-modal-full {
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  border-radius: 0;
  margin: 0;
}

.roovix-modal-header {
  padding: var(--space-4) var(--space-6);
  border-bottom: 1px solid var(--roovix-border-muted);
  display: flex;
  align-items: center;
  justify-content: space-between;
  background-color: var(--roovix-bg-muted);
  position: sticky;
  top: 0;
  z-index: 1;
}

.roovix-modal-title {
  font-size: 16px;
  font-weight: 600;
  margin: 0;
  color: var(--roovix-text-primary);
}

.roovix-modal-close {
  background: none;
  border: none;
  font-size: 20px;
  cursor: pointer;
  color: var(--roovix-text-secondary);
  padding: var(--space-2);
  border-radius: var(--radius-sm);
  line-height: 1;
  transition: all var(--transition-fast);
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.roovix-modal-close:hover {
  background-color: var(--roovix-bg-muted);
  color: var(--roovix-text-primary);
}

.roovix-modal-body {
  padding: var(--space-6);
  color: var(--roovix-text-primary);
}

.roovix-modal-footer {
  padding: var(--space-4) var(--space-6);
  border-top: 1px solid var(--roovix-border-muted);
  display: flex;
  justify-content: flex-end;
  gap: var(--space-2);
  background-color: var(--roovix-bg-muted);
  position: sticky;
  bottom: 0;
}

/* ========================================
   10. DROPDOWN COMPONENTS - Roovix Exact
   ======================================== */

.roovix-dropdown {
  position: relative;
  display: inline-block;
}

.roovix-dropdown-menu {
  position: absolute;
  top: 100%;
  right: 0;
  min-width: 200px;
  background-color: var(--roovix-surface-dropdown);
  border-radius: var(--radius-md);
  box-shadow: var(--roovix-shadow-floating-sm);
  z-index: var(--z-dropdown);
  margin-top: var(--space-2);
  display: none;
  animation: roovix-dropdown-fade 0.2s ease;
  max-height: 400px;
  overflow: none;
  padding: var(--space-3) var(--space-2);
}

@keyframes roovix-dropdown-fade {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.roovix-dropdown-menu.show {
  display: block;
}

.roovix-dropdown-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-2);
  font-size: 14px;
  color: var(--roovix-text-primary);
  text-decoration: none;
  transition: all var(--transition-fast);
  cursor: pointer;
  border: none;
  border-radius: var(--radius-base);
  background: none;
  width: 200px;
  text-align: left;
  line-height: 20px;
}

.roovix-dropdown-item i {
  color: var(--roovix-text-secondary);
}

.roovix-dropdown-item:hover {
  background-color: var(--roovix-bg-muted);
  text-decoration: none;
}

.roovix-dropdown-item:active {
  background-color: var(--roovix-bg-tertiary);
}

.roovix-dropdown-divider {
  height: 1px;
  background-color: var(--roovix-border-muted);
  margin: var(--space-2) 0;
}

.roovix-dropdown-header {
  padding: var(--space-2) var(--space-3);
  font-size: 12px;
  font-weight: 600;
  color: var(--roovix-text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* Dropdown Positions */
.roovix-dropdown-menu-left {
  left: 0;
  right: auto;
}

.roovix-dropdown-menu-center {
  left: 50%;
  transform: translateX(-50%);
  right: auto;
}

/* ========================================
   11. TOOLTIP COMPONENTS - Universal Fix
   ======================================== */

.roovix-tooltip {
  position: relative;
  display: inline-block;
}

/* ===============================
   Base Tooltip
   =============================== */

.roovix-tooltip-content {
  position: absolute;
  display: inline-block; /* ensures padding & background render correctly */
  padding: var(--space-1) var(--space-2);
  background-color: var(--roovix-surface-tooltip);
  color: var(--roovix-text-white);
  font-size: 12px;
  line-height: 1.4;
  border-radius: var(--radius-base);
  white-space: nowrap;
  z-index: var(--z-tooltip);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  box-shadow: var(--roovix-shadow-sm);
  transition: opacity var(--transition-base),
              transform var(--transition-base);
}

/* Tooltip arrow */
.roovix-tooltip-content::after {
  content: "";
  position: absolute;
  border: 5px solid transparent;
}

/* Show tooltip */
.roovix-tooltip:hover .roovix-tooltip-content {
  opacity: 1;
  visibility: visible;
}

/* ===============================
   TOP (Default)
   =============================== */

.roovix-tooltip-top .roovix-tooltip-content {
  bottom: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
}

.roovix-tooltip-top .roovix-tooltip-content::after {
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border-top-color: var(--roovix-surface-tooltip);
}

/* ===============================
   BOTTOM
   =============================== */

.roovix-tooltip-bottom .roovix-tooltip-content {
  top: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
}

.roovix-tooltip-bottom .roovix-tooltip-content::after {
  bottom: 100%;
  left: 50%;
  transform: translateX(-50%);
  border-bottom-color: var(--roovix-surface-tooltip);
}

/* ===============================
   LEFT
   =============================== */

.roovix-tooltip-left .roovix-tooltip-content {
  right: calc(100% + 8px);
  top: 50%;
  transform: translateY(-50%);
}

.roovix-tooltip-left .roovix-tooltip-content::after {
  left: 100%;
  top: 50%;
  transform: translateY(-50%);
  border-left-color: var(--roovix-surface-tooltip);
}

/* ===============================
   RIGHT
   =============================== */

.roovix-tooltip-right .roovix-tooltip-content {
  left: calc(100% + 8px);
  top: 50%;
  transform: translateY(-50%);
}

.roovix-tooltip-right .roovix-tooltip-content::after {
  right: 100%;
  top: 50%;
  transform: translateY(-50%);
  border-right-color: var(--roovix-surface-tooltip);
}

/* ========================================
   12. PROGRESS COMPONENTS - Roovix Exact
   ======================================== */

.roovix-progress {
  height: 8px;
  background-color: var(--roovix-progress-track);
  border-radius: var(--radius-full);
  overflow: hidden;
  width: 100%;
}

.roovix-progress-bar {
  height: 100%;
  background-color: var(--roovix-progress-fill);
  border-radius: var(--radius-full);
  transition: width var(--transition-base);
}

/* Progress Sizes */
.roovix-progress-xs {
  height: 4px;
}

.roovix-progress-sm {
  height: 6px;
}

.roovix-progress-md {
  height: 8px;
}

.roovix-progress-lg {
  height: 12px;
}

.roovix-progress-xl {
  height: 16px;
}

/* Progress Variants */
.roovix-progress-success .roovix-progress-bar {
  background-color: var(--roovix-status-success-bg);
}

.roovix-progress-danger .roovix-progress-bar {
  background-color: var(--roovix-status-danger-bg);
}

.roovix-progress-warning .roovix-progress-bar {
  background-color: var(--roovix-status-warning-bg);
}

.roovix-progress-primary .roovix-progress-bar {
  background-color: var(--roovix-text-accent);
}

/* Progress with Label */
.roovix-progress-label {
  display: flex;
  justify-content: space-between;
  margin-bottom: var(--space-1);
  font-size: 12px;
  color: var(--roovix-text-secondary);
}

/* ========================================
   13. SKELETON LOADERS - Roovix Exact
   ======================================== */

.roovix-skeleton {
  background: linear-gradient(
    90deg,
    var(--roovix-skeleton-bg) 25%,
    var(--roovix-bg-muted) 50%,
    var(--roovix-skeleton-bg) 75%
  );
  background-size: 200% 100%;
  animation: roovix-skeleton-loading 1.5s ease-in-out infinite;
  border-radius: var(--radius-base);
}

@keyframes roovix-skeleton-loading {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

.roovix-skeleton-text {
  height: 16px;
  margin-bottom: var(--space-2);
  width: 100%;
}

.roovix-skeleton-text-sm {
  height: 12px;
}

.roovix-skeleton-text-lg {
  height: 20px;
}

.roovix-skeleton-title {
  height: 24px;
  width: 60%;
  margin-bottom: var(--space-4);
}

.roovix-skeleton-avatar {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-round);
}

.roovix-skeleton-avatar-sm {
  width: 32px;
  height: 32px;
}

.roovix-skeleton-avatar-lg {
  width: 64px;
  height: 64px;
}

.roovix-skeleton-button {
  height: 32px;
  width: 100px;
  border-radius: var(--radius-base);
}

.roovix-skeleton-card {
  height: 200px;
  width: 100%;
  border-radius: var(--radius-md);
}

/* ========================================
   14. LIST COMPONENTS - Roovix Exact
   ======================================== */

.roovix-list {
  list-style: none;
  padding: 0;
  margin: 0;
  background-color: var(--roovix-surface-card);
  border-radius: var(--radius-md);
  overflow: hidden;
  border: 1px solid var(--roovix-border-default);
}

.roovix-list-item {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--roovix-border-muted);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  color: var(--roovix-text-primary);
  font-size: 14px;
  line-height: 20px;
}

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

.roovix-list-item:hover {
  background-color: var(--roovix-bg-muted);
}

/* List Sizes */
.roovix-list-sm .roovix-list-item {
  padding: var(--space-2) var(--space-3);
  font-size: 12px;
}

.roovix-list-lg .roovix-list-item {
  padding: var(--space-4) var(--space-6);
  font-size: 16px;
}

/* List with Dividers */
.roovix-list-divided {
  border: 1px solid var(--roovix-border-default);
}

/* List with Icons */
.roovix-list-icon {
  width: 20px;
  height: 20px;
  color: var(--roovix-text-secondary);
  flex-shrink: 0;
}

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

.roovix-list-title {
  font-weight: 600;
  margin-bottom: 2px;
}

.roovix-list-subtitle {
  font-size: 12px;
  color: var(--roovix-text-secondary);
}

.roovix-list-action {
  flex-shrink: 0;
}

/* ========================================
   15. LOADER/SPINNER COMPONENTS - Roovix Exact
   ======================================== */

.roovix-loader {
  width: 32px;
  height: 32px;
  border: 2px solid var(--roovix-border-muted);
  border-top-color: var(--roovix-text-accent);
  border-radius: 50%;
  animation: roovix-spin 0.8s linear infinite;
  display: inline-block;
}

@keyframes roovix-spin {
  to { transform: rotate(360deg); }
}

/* Loader Sizes */
.roovix-loader-xs {
  width: 16px;
  height: 16px;
  border-width: 2px;
}

.roovix-loader-sm {
  width: 20px;
  height: 20px;
  border-width: 2px;
}

.roovix-loader-md {
  width: 32px;
  height: 32px;
  border-width: 2px;
}

.roovix-loader-lg {
  width: 48px;
  height: 48px;
  border-width: 3px;
}

.roovix-loader-xl {
  width: 64px;
  height: 64px;
  border-width: 4px;
}

/* Loader Variants */
.roovix-loader-primary {
  border-top-color: var(--roovix-text-accent);
}

.roovix-loader-secondary {
  border-top-color: var(--roovix-text-secondary);
}

.roovix-loader-success {
  border-top-color: var(--roovix-status-success-bg);
}

.roovix-loader-warning {
  border-top-color: var(--roovix-status-warning-bg);
}


.roovix-loader-danger {
  border-top-color: var(--roovix-status-danger-bg);
}

/* Loading Dots - Roovix exact */
.roovix-loader-dots {
  display: flex;
  gap: 4px;
  align-items: center;
}

.roovix-loader-dots span {
  width: 8px;
  height: 8px;
  background-color: var(--roovix-text-accent);
  border-radius: 50%;
  animation: roovix-dots 1.4s ease-in-out infinite;
}

.roovix-loader-dots span:nth-child(1) { animation-delay: -0.32s; }
.roovix-loader-dots span:nth-child(2) { animation-delay: -0.16s; }

@keyframes roovix-dots {
  0%, 80%, 100% { transform: scale(0); }
  40% { transform: scale(1); }
}

/* ========================================
   16. TAG/CHIP COMPONENTS - Roovix Exact
   ======================================== */

.roovix-tag {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: 0 var(--space-2);
  background-color: var(--roovix-bg-muted);
  border: 1px solid var(--roovix-border-default);
  border-radius: var(--radius-full);
  font-size: 12px;
  line-height: 20px;
  color: var(--roovix-text-primary);
  cursor: default;
  transition: all var(--transition-fast);
  height: 24px;
}

.roovix-tag-removable {
  padding-right: 4px;
  cursor: pointer;
}

.roovix-tag-removable:hover {
  background-color: var(--roovix-bg-tertiary);
  border-color: var(--roovix-border-emphasis);
}

.roovix-tag-remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  margin-left: 4px;
  border-radius: 50%;
  background: none;
  border: none;
  color: currentColor;
  cursor: pointer;
  font-size: 16px;
  padding: 0;
  line-height: 1;
}

.roovix-tag-remove:hover {
  background-color: var(--roovix-bg-emphasis);
  color: var(--roovix-text-white);
}

/* Tag Sizes */
.roovix-tag-sm {
  height: 20px;
  font-size: 10px;
  padding: 0 var(--space-1);
}

.roovix-tag-lg {
  height: 28px;
  font-size: 14px;
  padding: 0 var(--space-3);
}

/* Tag Variants */
.roovix-tag-primary {
  background-color: var(--roovix-btn-primary-bg);
  color: var(--roovix-btn-primary-text);
  border-color: var(--roovix-btn-primary-bg);
}

.roovix-tag-success {
  background-color: var(--roovix-status-success-bg-muted);
  color: var(--roovix-text-success);
  border-color: var(--roovix-status-success-border);
}

.roovix-tag-danger {
  background-color: var(--roovix-status-danger-bg-muted);
  color: var(--roovix-text-danger);
  border-color: var(--roovix-status-danger-border);
}

/* ========================================
   17. DIVIDER COMPONENTS - Roovix Exact
   ======================================== */

.roovix-divider {
  height: 1px;
  background-color: var(--roovix-border-muted);
  margin: var(--space-4) 0;
  width: 100%;
}

.roovix-divider-vertical {
  width: 1px;
  height: auto;
  min-height: 1em;
  background-color: var(--roovix-border-muted);
  margin: 0 var(--space-4);
  display: inline-block;
}

.roovix-divider-label {
  display: flex;
  align-items: center;
  color: var(--roovix-text-secondary);
  font-size: 12px;
  margin: var(--space-4) 0;
}

.roovix-divider-label::before,
.roovix-divider-label::after {
  content: "";
  flex: 1;
  height: 1px;
  background-color: var(--roovix-border-muted);
}

.roovix-divider-label::before {
  margin-right: var(--space-4);
}

.roovix-divider-label::after {
  margin-left: var(--space-4);
}

/* ========================================
   18. SOCIAL MEDIA COMPONENTS
   ======================================== */

/* Post Card - for social feeds */
.roovix-post-card {
  composes: roovix-card;
  padding: 0;
}

.roovix-post-header {
  padding: var(--space-4);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  border-bottom: 1px solid var(--roovix-border-muted);
}

.roovix-post-author {
  font-weight: 600;
  color: var(--roovix-text-primary);
}

.roovix-post-timestamp {
  font-size: 12px;
  color: var(--roovix-text-tertiary);
  margin-left: auto;
}

.roovix-post-content {
  padding: var(--space-4);
  font-size: 14px;
  line-height: 1.6;
}

.roovix-post-media {
  width: 100%;
  max-height: 400px;
  object-fit: cover;
  border-radius: var(--radius-md);
  margin: var(--space-2) 0;
}

.roovix-post-actions {
  padding: var(--space-3) var(--space-4);
  border-top: 1px solid var(--roovix-border-muted);
  display: flex;
  gap: var(--space-4);
}

.roovix-post-action {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  color: var(--roovix-text-secondary);
  font-size: 12px;
  cursor: pointer;
  transition: color var(--transition-fast);
}

.roovix-post-action:hover {
  color: var(--roovix-text-accent);
}

.roovix-post-action.liked {
  color: var(--roovix-text-danger);
}

/* Comment Component */
.roovix-comment {
  display: flex;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--roovix-border-muted);
}

.roovix-comment:last-child {
  border-bottom: none;
}

.roovix-comment-content {
  flex: 1;
}

.roovix-comment-header {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-1);
}

.roovix-comment-author {
  font-weight: 600;
  font-size: 14px;
  color: var(--roovix-text-primary);
}

.roovix-comment-time {
  font-size: 12px;
  color: var(--roovix-text-tertiary);
}

.roovix-comment-text {
  font-size: 14px;
  line-height: 1.5;
  margin-bottom: var(--space-2);
}

.roovix-comment-actions {
  display: flex;
  gap: var(--space-3);
  font-size: 12px;
}

.roovix-comment-action {
  color: var(--roovix-text-secondary);
  cursor: pointer;
  transition: color var(--transition-fast);
}

.roovix-comment-action:hover {
  color: var(--roovix-text-accent);
}

/* ========================================
   19. SEARCH ENGINE COMPONENTS
   ======================================== */

/* Search Bar - Google-like */
.roovix-search-bar {
  display: flex;
  align-items: center;
  width: 100%;
  max-width: 600px;
  margin: 0 auto;
  border: 1px solid var(--roovix-border-default);
  border-radius: 24px;
  background-color: var(--roovix-surface-card);
  transition: all var(--transition-base);
  box-shadow: var(--roovix-shadow-sm);
}

.roovix-search-bar:hover,
.roovix-search-bar:focus-within {
  box-shadow: var(--roovix-shadow-md);
  border-color: var(--roovix-border-emphasis);
}

.roovix-search-input {
  flex: 1;
  height: 44px;
  padding: 0 var(--space-4);
  border: none;
  background: transparent;
  font-size: 16px;
  color: var(--roovix-text-primary);
  outline: none;
}

.roovix-search-input::placeholder {
  color: var(--roovix-text-tertiary);
}

.roovix-search-button {
  width: 44px;
  height: 44px;
  border: none;
  background: transparent;
  color: var(--roovix-text-accent);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 0 24px 24px 0;
  transition: background-color var(--transition-fast);
}

.roovix-search-button:hover {
  background-color: var(--roovix-bg-muted);
}

/* Search Result Card */
.roovix-search-result {
  padding: var(--space-4);
  border-bottom: 1px solid var(--roovix-border-muted);
  transition: background-color var(--transition-fast);
}

.roovix-search-result:hover {
  background-color: var(--roovix-bg-muted);
}

.roovix-result-title {
  font-size: 18px;
  font-weight: 600;
  color: var(--roovix-text-link);
  margin-bottom: var(--space-1);
  cursor: pointer;
}

.roovix-result-title:hover {
  text-decoration: underline;
}

.roovix-result-url {
  font-size: 12px;
  color: var(--roovix-text-success);
  margin-bottom: var(--space-2);
}

.roovix-result-description {
  font-size: 14px;
  color: var(--roovix-text-primary);
  line-height: 1.5;
}

.roovix-result-meta {
  display: flex;
  gap: var(--space-4);
  margin-top: var(--space-2);
  font-size: 12px;
  color: var(--roovix-text-tertiary);
}

/* Search Filters */
.roovix-search-filters {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--roovix-border-muted);
}

.roovix-search-filter {
  padding: var(--space-1) var(--space-3);
  border: 1px solid var(--roovix-border-default);
  border-radius: var(--radius-full);
  font-size: 12px;
  color: var(--roovix-text-secondary);
  cursor: pointer;
  transition: all var(--transition-fast);
}

.roovix-search-filter:hover {
  background-color: var(--roovix-bg-muted);
  border-color: var(--roovix-border-emphasis);
}

.roovix-search-filter.active {
  background-color: var(--roovix-btn-primary-bg);
  color: var(--roovix-btn-primary-text);
  border-color: var(--roovix-btn-primary-bg);
}

/* ========================================
   20. KNOWLEDGE BASE SPECIFIC COMPONENTS
   ======================================== */

/* Article Card */
.roovix-article-card {
  composes: roovix-card;
  padding: var(--space-4);
}

.roovix-article-meta {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
  font-size: 12px;
  color: var(--roovix-text-tertiary);
}

.roovix-article-category {
  background-color: var(--roovix-bg-muted);
  padding: 2px var(--space-2);
  border-radius: var(--radius-full);
  color: var(--roovix-text-secondary);
}

.roovix-article-title {
  font-size: 18px;
  font-weight: 600;
  color: var(--roovix-text-primary);
  margin-bottom: var(--space-2);
  line-height: 1.4;
}

.roovix-article-title a {
  color: inherit;
  text-decoration: none;
}

.roovix-article-title a:hover {
  color: var(--roovix-text-link);
  text-decoration: underline;
}

.roovix-article-excerpt {
  font-size: 14px;
  color: var(--roovix-text-secondary);
  line-height: 1.6;
  margin-bottom: var(--space-3);
}

.roovix-article-stats {
  display: flex;
  gap: var(--space-4);
  font-size: 12px;
  color: var(--roovix-text-tertiary);
  border-top: 1px solid var(--roovix-border-muted);
  padding-top: var(--space-3);
}

.roovix-article-stat {
  display: flex;
  align-items: center;
  gap: 4px;
}

/* Table of Contents */
.roovix-toc {
  background-color: var(--roovix-bg-muted);
  border: 1px solid var(--roovix-border-default);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  margin-bottom: var(--space-6);
}

.roovix-toc-title {
  font-size: 16px;
  font-weight: 600;
  margin-bottom: var(--space-3);
  color: var(--roovix-text-primary);
}

.roovix-toc-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.roovix-toc-item {
  margin-bottom: var(--space-2);
  font-size: 14px;
}

.roovix-toc-link {
  color: var(--roovix-text-link);
  text-decoration: none;
  display: inline-block;
  padding: var(--space-1) 0;
}

.roovix-toc-link:hover {
  text-decoration: underline;
}

.roovix-toc-link.level-2 {
  padding-left: var(--space-4);
}

.roovix-toc-link.level-3 {
  padding-left: var(--space-8);
}

/* Code Block */
.roovix-code-block {
  background-color: var(--roovix-code-bg);
  border: 1px solid var(--roovix-border-default);
  border-radius: var(--radius-md);
  margin: var(--space-4) 0;
  overflow: hidden;
}

.roovix-code-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-2) var(--space-4);
  background-color: var(--roovix-bg-muted);
  border-bottom: 1px solid var(--roovix-border-muted);
  font-size: 12px;
  color: var(--roovix-text-secondary);
}

.roovix-code-language {
  font-weight: 600;
  text-transform: uppercase;
}

.roovix-code-copy {
  background: none;
  border: none;
  color: var(--roovix-text-secondary);
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  transition: all var(--transition-fast);
}

.roovix-code-copy:hover {
  background-color: var(--roovix-bg-tertiary);
  color: var(--roovix-text-primary);
}

.roovix-code-content {
  padding: var(--space-4);
  overflow-x: auto;
  font-family: var(--font-mono);
  font-size: 13px;
  line-height: 1.6;
  color: var(--roovix-code-text);
}

/* Version History */
.roovix-version-history {
  border: 1px solid var(--roovix-border-default);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.roovix-version-item {
  display: flex;
  align-items: center;
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--roovix-border-muted);
  transition: background-color var(--transition-fast);
}

.roovix-version-item:last-child {
  border-bottom: none;
}

.roovix-version-item:hover {
  background-color: var(--roovix-bg-muted);
}

.roovix-version-tag {
  background-color: var(--roovix-bg-tertiary);
  padding: 2px var(--space-2);
  border-radius: var(--radius-full);
  font-size: 11px;
  font-weight: 600;
  margin-right: var(--space-3);
  color: var(--roovix-text-secondary);
  min-width: 60px;
  text-align: center;
}

.roovix-version-date {
  font-size: 13px;
  color: var(--roovix-text-tertiary);
  margin-right: var(--space-4);
  min-width: 100px;
}

.roovix-version-author {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex: 1;
  font-size: 13px;
}

.roovix-version-message {
  color: var(--roovix-text-primary);
  font-weight: 500;
}

.roovix-version-compare {
  color: var(--roovix-text-link);
  font-size: 12px;
  text-decoration: none;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
}

.roovix-version-compare:hover {
  background-color: var(--roovix-bg-tertiary);
  text-decoration: underline;
}

/* ========================================
   21. DASHBOARD & ANALYTICS COMPONENTS
   ======================================== */

/* Stat Card */
.roovix-stat-card {
  composes: roovix-card;
  padding: var(--space-4);
  text-align: center;
  transition: transform var(--transition-fast);
}

.roovix-stat-card:hover {
  transform: translateY(-2px);
}

.roovix-stat-icon {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-full);
  background-color: var(--roovix-bg-muted);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto var(--space-3);
  color: var(--roovix-text-accent);
}

.roovix-stat-value {
  font-size: 32px;
  font-weight: 600;
  color: var(--roovix-text-primary);
  line-height: 1.2;
  margin-bottom: var(--space-1);
}

.roovix-stat-label {
  font-size: 14px;
  color: var(--roovix-text-secondary);
  margin-bottom: var(--space-2);
}

.roovix-stat-trend {
  font-size: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
}

.roovix-stat-trend.up {
  color: var(--roovix-text-success);
}

.roovix-stat-trend.down {
  color: var(--roovix-text-danger);
}

/* Activity Timeline */
.roovix-timeline {
  position: relative;
  padding-left: var(--space-6);
}

.roovix-timeline::before {
  content: '';
  position: absolute;
  left: 7px;
  top: 0;
  bottom: 0;
  width: 2px;
  background-color: var(--roovix-border-muted);
}

.roovix-timeline-item {
  position: relative;
  padding-bottom: var(--space-6);
}

.roovix-timeline-dot {
  position: absolute;
  left: calc(-1 * var(--space-6) + 1px);
  width: 12px;
  height: 12px;
  border-radius: var(--radius-round);
  background-color: var(--roovix-surface-card);
  border: 2px solid var(--roovix-text-accent);
  z-index: 1;
}

.roovix-timeline-dot.success {
  border-color: var(--roovix-text-success);
}

.roovix-timeline-dot.warning {
  border-color: var(--roovix-text-warning);
}

.roovix-timeline-dot.danger {
  border-color: var(--roovix-text-danger);
}

.roovix-timeline-content {
  background-color: var(--roovix-surface-card);
  border: 1px solid var(--roovix-border-default);
  border-radius: var(--radius-md);
  padding: var(--space-3);
}

.roovix-timeline-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-2);
  font-size: 13px;
}

.roovix-timeline-title {
  font-weight: 600;
  color: var(--roovix-text-primary);
}

.roovix-timeline-time {
  color: var(--roovix-text-tertiary);
  font-size: 11px;
}

.roovix-timeline-body {
  font-size: 13px;
  color: var(--roovix-text-secondary);
}

/* Metric Chart */
.roovix-metric-card {
  composes: roovix-card;
  padding: var(--space-4);
}

.roovix-metric-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-4);
}

.roovix-metric-title {
  font-size: 16px;
  font-weight: 600;
  color: var(--roovix-text-primary);
}

.roovix-metric-period {
  font-size: 12px;
  color: var(--roovix-text-tertiary);
  background-color: var(--roovix-bg-muted);
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-full);
}

.roovix-metric-value {
  font-size: 36px;
  font-weight: 600;
  color: var(--roovix-text-primary);
  line-height: 1;
  margin-bottom: var(--space-2);
}

.roovix-metric-change {
  font-size: 14px;
  display: flex;
  align-items: center;
  gap: 4px;
  margin-bottom: var(--space-4);
}

.roovix-metric-change.positive {
  color: var(--roovix-text-success);
}

.roovix-metric-change.negative {
  color: var(--roovix-text-danger);
}

.roovix-metric-chart {
  height: 100px;
  margin-top: var(--space-4);
}

/* ========================================
   22. USER PROFILE COMPONENTS
   ======================================== */

/* Profile Header */
.roovix-profile-header {
  background-color: var(--roovix-surface-card);
  border: 1px solid var(--roovix-border-default);
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: var(--space-6);
}

.roovix-profile-cover {
  height: 200px;
  background: linear-gradient(135deg, var(--roovix-bg-tertiary) 0%, var(--roovix-bg-emphasis) 100%);
  position: relative;
}

.roovix-profile-avatar {
  position: absolute;
  bottom: -40px;
  left: var(--space-6);
  border: 4px solid var(--roovix-surface-card);
  box-shadow: var(--roovix-shadow-md);
}

.roovix-profile-info {
  padding: var(--space-6) var(--space-6) var(--space-4);
  margin-top: 40px;
}

.roovix-profile-name {
  font-size: 24px;
  font-weight: 600;
  color: var(--roovix-text-primary);
  margin-bottom: 4px;
}

.roovix-profile-username {
  font-size: 16px;
  color: var(--roovix-text-secondary);
  margin-bottom: var(--space-3);
}

.roovix-profile-bio {
  font-size: 14px;
  color: var(--roovix-text-primary);
  line-height: 1.6;
  margin-bottom: var(--space-4);
  max-width: 600px;
}

.roovix-profile-meta {
  display: flex;
  gap: var(--space-6);
  padding-top: var(--space-4);
  border-top: 1px solid var(--roovix-border-muted);
}

.roovix-profile-stat {
  text-align: center;
}

.roovix-profile-stat-value {
  font-size: 20px;
  font-weight: 600;
  color: var(--roovix-text-primary);
  line-height: 1.2;
}

.roovix-profile-stat-label {
  font-size: 12px;
  color: var(--roovix-text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* Profile Navigation */
.roovix-profile-nav {
  display: flex;
  gap: var(--space-2);
  border-bottom: 1px solid var(--roovix-border-muted);
  padding: 0 var(--space-4);
  background-color: var(--roovix-surface-card);
}

.roovix-profile-nav-item {
  padding: var(--space-3) var(--space-4);
  font-size: 14px;
  font-weight: 500;
  color: var(--roovix-text-secondary);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  transition: all var(--transition-fast);
}

.roovix-profile-nav-item:hover {
  color: var(--roovix-text-primary);
  border-bottom-color: var(--roovix-border-muted);
}

.roovix-profile-nav-item.active {
  color: var(--roovix-text-primary);
  border-bottom-color: var(--roovix-text-accent);
}

/* Settings Form */
.roovix-settings-section {
  background-color: var(--roovix-surface-card);
  border: 1px solid var(--roovix-border-default);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  margin-bottom: var(--space-6);
}

.roovix-settings-title {
  font-size: 18px;
  font-weight: 600;
  color: var(--roovix-text-primary);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--roovix-border-muted);
}

.roovix-settings-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--roovix-border-muted);
}

.roovix-settings-row:last-child {
  border-bottom: none;
}

.roovix-settings-label {
  font-size: 14px;
  color: var(--roovix-text-primary);
  font-weight: 500;
}

.roovix-settings-description {
  font-size: 12px;
  color: var(--roovix-text-tertiary);
  margin-top: 2px;
}

.roovix-settings-control {
  min-width: 200px;
}

/* ========================================
   23. NOTIFICATION COMPONENTS
   ======================================== */

/* Notification Item */
.roovix-notification {
  display: flex;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--roovix-border-muted);
  transition: background-color var(--transition-fast);
  cursor: pointer;
}

.roovix-notification:hover {
  background-color: var(--roovix-bg-muted);
}

.roovix-notification.unread {
  background-color: var(--roovix-bg-muted);
  position: relative;
}

.roovix-notification.unread::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background-color: var(--roovix-text-accent);
}

.roovix-notification-icon {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-round);
  background-color: var(--roovix-bg-tertiary);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--roovix-text-secondary);
  flex-shrink: 0;
}

.roovix-notification-content {
  flex: 1;
}

.roovix-notification-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--roovix-text-primary);
  margin-bottom: 2px;
}

.roovix-notification-message {
  font-size: 13px;
  color: var(--roovix-text-secondary);
  line-height: 1.5;
  margin-bottom: 4px;
}

.roovix-notification-time {
  font-size: 11px;
  color: var(--roovix-text-tertiary);
}

.roovix-notification-actions {
  display: flex;
  gap: var(--space-2);
  margin-top: var(--space-2);
}

/* Notification Badge */
.roovix-notification-badge {
  position: relative;
  display: inline-block;
}

.roovix-notification-count {
  position: absolute;
  top: -4px;
  right: -4px;
  min-width: 18px;
  height: 18px;
  border-radius: var(--radius-full);
  background-color: var(--roovix-status-danger-bg);
  color: var(--roovix-text-white);
  font-size: 11px;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 4px;
  border: 2px solid var(--roovix-surface-card);
}

/* Notification Center */
.roovix-notification-center {
  width: 360px;
  max-height: 480px;
  overflow-y: auto;
  background-color: var(--roovix-surface-dropdown);
  border: 1px solid var(--roovix-border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--roovix-shadow-floating-md);
}

.roovix-notification-header {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--roovix-border-muted);
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: sticky;
  top: 0;
  background-color: inherit;
}

.roovix-notification-header h3 {
  font-size: 16px;
  font-weight: 600;
  color: var(--roovix-text-primary);
  margin: 0;
}

.roovix-notification-mark-read {
  font-size: 12px;
  color: var(--roovix-text-link);
  cursor: pointer;
  background: none;
  border: none;
}

.roovix-notification-mark-read:hover {
  text-decoration: underline;
}

.roovix-notification-footer {
  padding: var(--space-3) var(--space-4);
  border-top: 1px solid var(--roovix-border-muted);
  text-align: center;
  position: sticky;
  bottom: 0;
  background-color: inherit;
}

.roovix-notification-view-all {
  font-size: 13px;
  color: var(--roovix-text-link);
  text-decoration: none;
}

.roovix-notification-view-all:hover {
  text-decoration: underline;
}

/* ========================================
   24. ERROR & EMPTY STATES
   ======================================== */

/* Empty State */
.roovix-empty-state {
  text-align: center;
  padding: var(--space-12) var(--space-4);
  background-color: var(--roovix-surface-card);
  border: 1px solid var(--roovix-border-default);
  border-radius: var(--radius-lg);
}

.roovix-empty-icon {
  font-size: 48px;
  color: var(--roovix-text-tertiary);
  margin-bottom: var(--space-4);
  opacity: 0.5;
}

.roovix-empty-title {
  font-size: 20px;
  font-weight: 600;
  color: var(--roovix-text-primary);
  margin-bottom: var(--space-2);
}

.roovix-empty-message {
  font-size: 14px;
  color: var(--roovix-text-secondary);
  margin-bottom: var(--space-6);
  max-width: 400px;
  margin-left: auto;
  margin-right: auto;
}

.roovix-empty-action {
  margin-top: var(--space-4);
}

/* Error State */
.roovix-error-state {
  text-align: center;
  padding: var(--space-12) var(--space-4);
  background-color: var(--roovix-surface-card);
  border: 1px solid var(--roovix-border-danger);
  border-radius: var(--radius-lg);
}

.roovix-error-icon {
  font-size: 48px;
  color: var(--roovix-text-danger);
  margin-bottom: var(--space-4);
}

.roovix-error-code {
  font-size: 72px;
  font-weight: 700;
  color: var(--roovix-text-danger);
  line-height: 1;
  margin-bottom: var(--space-2);
  opacity: 0.5;
}

.roovix-error-title {
  font-size: 24px;
  font-weight: 600;
  color: var(--roovix-text-primary);
  margin-bottom: var(--space-2);
}

.roovix-error-message {
  font-size: 16px;
  color: var(--roovix-text-secondary);
  margin-bottom: var(--space-6);
  max-width: 500px;
  margin-left: auto;
  margin-right: auto;
}

/* Loading State */
.roovix-loading-state {
  text-align: center;
  padding: var(--space-12) var(--space-4);
}

.roovix-loading-spinner {
  margin-bottom: var(--space-4);
}

.roovix-loading-text {
  font-size: 14px;
  color: var(--roovix-text-secondary);
}

/* ========================================
   25. LAYOUT & GRID COMPONENTS
   ======================================== */

/* Container */
.roovix-container {
  width: 100%;
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--space-4);
  padding-right: var(--space-4);
}

.roovix-container-sm {
  max-width: 640px;
}

.roovix-container-md {
  max-width: 768px;
}

.roovix-container-lg {
  max-width: 1024px;
}

.roovix-container-xl {
  max-width: 1280px;
}

.roovix-container-fluid {
  max-width: 100%;
}

/* Grid */
.roovix-grid {
  display: grid;
  gap: var(--space-4);
}

.roovix-grid-cols-1 { grid-template-columns: repeat(1, 1fr); }
.roovix-grid-cols-2 { grid-template-columns: repeat(2, 1fr); }
.roovix-grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
.roovix-grid-cols-4 { grid-template-columns: repeat(4, 1fr); }
.roovix-grid-cols-5 { grid-template-columns: repeat(5, 1fr); }
.roovix-grid-cols-6 { grid-template-columns: repeat(6, 1fr); }
.roovix-grid-cols-12 { grid-template-columns: repeat(12, 1fr); }

.roovix-gap-0 { gap: 0; }
.roovix-gap-1 { gap: var(--space-1); }
.roovix-gap-2 { gap: var(--space-2); }
.roovix-gap-3 { gap: var(--space-3); }
.roovix-gap-4 { gap: var(--space-4); }
.roovix-gap-6 { gap: var(--space-6); }
.roovix-gap-8 { gap: var(--space-8); }

/* Responsive Grid */
@media (min-width: 640px) {
  .roovix-grid-sm-cols-1 { grid-template-columns: repeat(1, 1fr); }
  .roovix-grid-sm-cols-2 { grid-template-columns: repeat(2, 1fr); }
  .roovix-grid-sm-cols-3 { grid-template-columns: repeat(3, 1fr); }
  .roovix-grid-sm-cols-4 { grid-template-columns: repeat(4, 1fr); }
}

@media (min-width: 768px) {
  .roovix-grid-md-cols-1 { grid-template-columns: repeat(1, 1fr); }
  .roovix-grid-md-cols-2 { grid-template-columns: repeat(2, 1fr); }
  .roovix-grid-md-cols-3 { grid-template-columns: repeat(3, 1fr); }
  .roovix-grid-md-cols-4 { grid-template-columns: repeat(4, 1fr); }
}

@media (min-width: 1024px) {
  .roovix-grid-lg-cols-1 { grid-template-columns: repeat(1, 1fr); }
  .roovix-grid-lg-cols-2 { grid-template-columns: repeat(2, 1fr); }
  .roovix-grid-lg-cols-3 { grid-template-columns: repeat(3, 1fr); }
  .roovix-grid-lg-cols-4 { grid-template-columns: repeat(4, 1fr); }
}

/* Flexbox Utilities */
.roovix-flex {
  display: flex;
}

.roovix-flex-col {
  flex-direction: column;
}

.roovix-flex-wrap {
  flex-wrap: wrap;
}

.roovix-items-start {
  align-items: flex-start;
}

.roovix-items-center {
  align-items: center;
}

.roovix-items-end {
  align-items: flex-end;
}

.roovix-items-stretch {
  align-items: stretch;
}

.roovix-justify-start {
  justify-content: flex-start;
}

.roovix-justify-center {
  justify-content: center;
}

.roovix-justify-end {
  justify-content: flex-end;
}

.roovix-justify-between {
  justify-content: space-between;
}

.roovix-justify-around {
  justify-content: space-around;
}

.roovix-flex-1 {
  flex: 1;
}

.roovix-flex-auto {
  flex: auto;
}

.roovix-flex-none {
  flex: none;
}

/* ========================================
   26. ENTERPRISE PRODUCT COMPONENTS
   ======================================== */

/* Team Switcher */
.roovix-team-switcher {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  background-color: var(--roovix-bg-muted);
  border: 1px solid var(--roovix-border-default);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--transition-fast);
  min-width: 200px;
}

.roovix-team-switcher:hover {
  background-color: var(--roovix-bg-tertiary);
  border-color: var(--roovix-border-emphasis);
}

.roovix-team-avatar {
  width: 24px;
  height: 24px;
  border-radius: var(--radius-round);
  background-color: var(--roovix-avatar-bg);
}

.roovix-team-info {
  flex: 1;
}

.roovix-team-name {
  font-size: 14px;
  font-weight: 500;
  color: var(--roovix-text-primary);
  line-height: 1.2;
}

.roovix-team-plan {
  font-size: 11px;
  color: var(--roovix-text-tertiary);
}

.roovix-team-switcher-icon {
  color: var(--roovix-text-tertiary);
}

/* Organization Chart */
.roovix-org-tree {
  padding: var(--space-4);
}

.roovix-org-node {
  position: relative;
  margin-bottom: var(--space-2);
}

.roovix-org-node::before {
  content: '';
  position: absolute;
  left: -20px;
  top: 24px;
  bottom: 0;
  width: 1px;
  background-color: var(--roovix-border-muted);
}

.roovix-org-node:last-child::before {
  display: none;
}

.roovix-org-card {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3);
  background-color: var(--roovix-surface-card);
  border: 1px solid var(--roovix-border-default);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-2);
  transition: all var(--transition-fast);
}

.roovix-org-card:hover {
  border-color: var(--roovix-border-accent);
  box-shadow: var(--roovix-shadow-sm);
}

.roovix-org-avatar {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-round);
}

.roovix-org-details {
  flex: 1;
}

.roovix-org-name {
  font-size: 14px;
  font-weight: 600;
  color: var(--roovix-text-primary);
}

.roovix-org-role {
  font-size: 12px;
  color: var(--roovix-text-tertiary);
}

.roovix-org-children {
  margin-left: 30px;
  padding-left: var(--space-4);
  border-left: 1px solid var(--roovix-border-muted);
}

/* Project Card */
.roovix-project-card {
  composes: roovix-card;
  padding: var(--space-4);
  cursor: pointer;
  transition: all var(--transition-fast);
}

.roovix-project-card:hover {
  transform: translateY(-2px);
  border-color: var(--roovix-border-accent);
}

.roovix-project-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-3);
}

.roovix-project-icon {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-md);
  background: linear-gradient(135deg, var(--roovix-bg-tertiary) 0%, var(--roovix-bg-emphasis) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--roovix-text-white);
  font-weight: 600;
  font-size: 18px;
}

.roovix-project-name {
  font-size: 16px;
  font-weight: 600;
  color: var(--roovix-text-primary);
  margin-bottom: 4px;
}

.roovix-project-description {
  font-size: 13px;
  color: var(--roovix-text-secondary);
  line-height: 1.5;
  margin-bottom: var(--space-3);
}

.roovix-project-meta {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  font-size: 12px;
  color: var(--roovix-text-tertiary);
  padding-top: var(--space-3);
  border-top: 1px solid var(--roovix-border-muted);
}

.roovix-project-members {
  display: flex;
  align-items: center;
}

.roovix-project-member {
  width: 24px;
  height: 24px;
  border-radius: var(--radius-round);
  border: 2px solid var(--roovix-surface-card);
  margin-left: -8px;
}

.roovix-project-member:first-child {
  margin-left: 0;
}

/* ========================================
   27. MARKETING & LANDING PAGE COMPONENTS
   ======================================== */

/* Hero Section */
.roovix-hero {
  background: linear-gradient(135deg, var(--roovix-bg-primary) 0%, var(--roovix-bg-secondary) 100%);
  padding: var(--space-16) var(--space-4);
  text-align: center;
  border-bottom: 1px solid var(--roovix-border-muted);
}

.roovix-hero-title {
  font-size: 48px;
  font-weight: 700;
  color: var(--roovix-text-primary);
  margin-bottom: var(--space-4);
  line-height: 1.2;
}

.roovix-hero-subtitle {
  font-size: 20px;
  color: var(--roovix-text-secondary);
  margin-bottom: var(--space-8);
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

.roovix-hero-actions {
  display: flex;
  gap: var(--space-4);
  justify-content: center;
}

/* Feature Card */
.roovix-feature-card {
  composes: roovix-card;
  padding: var(--space-6);
  text-align: center;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.roovix-feature-icon {
  width: 64px;
  height: 64px;
  border-radius: var(--radius-full);
  background-color: var(--roovix-bg-muted);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto var(--space-4);
  color: var(--roovix-text-accent);
}

.roovix-feature-title {
  font-size: 20px;
  font-weight: 600;
  color: var(--roovix-text-primary);
  margin-bottom: var(--space-3);
}

.roovix-feature-description {
  font-size: 14px;
  color: var(--roovix-text-secondary);
  line-height: 1.6;
  margin-bottom: var(--space-4);
  flex: 1;
}

/* Pricing Card */
.roovix-pricing-card {
  composes: roovix-card;
  padding: var(--space-6);
  text-align: center;
  position: relative;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.roovix-pricing-card.popular {
  border-color: var(--roovix-border-accent);
  box-shadow: var(--roovix-shadow-md);
  transform: scale(1.05);
  z-index: 1;
}

.roovix-pricing-popular-badge {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background-color: var(--roovix-text-accent);
  color: var(--roovix-text-white);
  font-size: 12px;
  font-weight: 600;
  padding: 4px var(--space-3);
  border-radius: var(--radius-full);
  white-space: nowrap;
}

.roovix-pricing-name {
  font-size: 24px;
  font-weight: 600;
  color: var(--roovix-text-primary);
  margin-bottom: var(--space-2);
}

.roovix-pricing-price {
  font-size: 48px;
  font-weight: 700;
  color: var(--roovix-text-primary);
  margin-bottom: var(--space-2);
  line-height: 1;
}

.roovix-pricing-price span {
  font-size: 16px;
  font-weight: 400;
  color: var(--roovix-text-tertiary);
}

.roovix-pricing-period {
  font-size: 14px;
  color: var(--roovix-text-tertiary);
  margin-bottom: var(--space-6);
}

.roovix-pricing-features {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-6);
  flex: 1;
}

.roovix-pricing-feature {
  padding: var(--space-2) 0;
  font-size: 14px;
  color: var(--roovix-text-secondary);
  border-bottom: 1px solid var(--roovix-border-muted);
}

.roovix-pricing-feature:last-child {
  border-bottom: none;
}

.roovix-pricing-feature-icon {
  color: var(--roovix-text-success);
  margin-right: var(--space-2);
}

/* Testimonial Card */
.roovix-testimonial-card {
  composes: roovix-card;
  padding: var(--space-6);
  background-color: var(--roovix-surface-card);
  position: relative;
}

.roovix-testimonial-quote {
  font-size: 16px;
  color: var(--roovix-text-primary);
  line-height: 1.8;
  margin-bottom: var(--space-4);
  font-style: italic;
}

.roovix-testimonial-quote::before {
  content: '"';
  font-size: 48px;
  color: var(--roovix-text-tertiary);
  opacity: 0.3;
  position: absolute;
  top: 10px;
  left: 10px;
  font-family: serif;
}

.roovix-testimonial-author {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.roovix-testimonial-avatar {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-round);
}

.roovix-testimonial-info {
  flex: 1;
}

.roovix-testimonial-name {
  font-size: 16px;
  font-weight: 600;
  color: var(--roovix-text-primary);
  margin-bottom: 2px;
}

.roovix-testimonial-role {
  font-size: 12px;
  color: var(--roovix-text-tertiary);
}

/* ========================================
   28. UTILITY CLASSES
   ======================================== */

/* Text Utilities */
.roovix-text-primary { color: var(--roovix-text-primary); }
.roovix-text-secondary { color: var(--roovix-text-secondary); }
.roovix-text-tertiary { color: var(--roovix-text-tertiary); }
.roovix-text-success { color: var(--roovix-text-success); }
.roovix-text-danger { color: var(--roovix-text-danger); }
.roovix-text-warning { color: var(--roovix-text-warning); }
.roovix-text-info { color: var(--roovix-text-info); }
.roovix-text-link { color: var(--roovix-text-link); }
.roovix-text-white { color: var(--roovix-text-white); }
.roovix-text-black { color: var(--roovix-text-black); }

.roovix-text-xs { font-size: 12px; }
.roovix-text-sm { font-size: 14px; }
.roovix-text-base { font-size: 16px; }
.roovix-text-lg { font-size: 18px; }
.roovix-text-xl { font-size: 20px; }
.roovix-text-2xl { font-size: 24px; }
.roovix-text-3xl { font-size: 32px; }

.roovix-font-light { font-weight: 300; }
.roovix-font-normal { font-weight: 400; }
.roovix-font-medium { font-weight: 500; }
.roovix-font-semibold { font-weight: 600; }
.roovix-font-bold { font-weight: 700; }

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

/* Background Utilities */
.roovix-bg-primary { background-color: var(--roovix-bg-primary); }
.roovix-bg-secondary { background-color: var(--roovix-bg-secondary); }
.roovix-bg-tertiary { background-color: var(--roovix-bg-tertiary); }
.roovix-bg-success { background-color: var(--roovix-status-success-bg-muted); }
.roovix-bg-danger { background-color: var(--roovix-status-danger-bg-muted); }
.roovix-bg-warning { background-color: var(--roovix-status-warning-bg-muted); }
.roovix-bg-info { background-color: var(--roovix-status-info-bg-muted); }

/* Border Utilities */
.roovix-border { border: 1px solid var(--roovix-border-default); }
.roovix-border-top { border-top: 1px solid var(--roovix-border-default); }
.roovix-border-bottom { border-bottom: 1px solid var(--roovix-border-default); }
.roovix-border-left { border-left: 1px solid var(--roovix-border-default); }
.roovix-border-right { border-right: 1px solid var(--roovix-border-default); }
.roovix-border-success { border-color: var(--roovix-border-success); }
.roovix-border-danger { border-color: var(--roovix-border-danger); }
.roovix-border-warning { border-color: var(--roovix-border-warning); }
.roovix-border-info { border-color: var(--roovix-border-info); }

/* Shadow Utilities */
.roovix-shadow-none { box-shadow: none; }
.roovix-shadow-xs { box-shadow: var(--roovix-shadow-xs); }
.roovix-shadow-sm { box-shadow: var(--roovix-shadow-sm); }
.roovix-shadow-md { box-shadow: var(--roovix-shadow-md); }
.roovix-shadow-lg { box-shadow: var(--roovix-shadow-lg); }
.roovix-shadow-floating-sm { box-shadow: var(--roovix-shadow-floating-sm); }
.roovix-shadow-floating-md { box-shadow: var(--roovix-shadow-floating-md); }

/* Spacing Utilities */
.roovix-m-0 { margin: 0; }
.roovix-m-1 { margin: var(--space-1); }
.roovix-m-2 { margin: var(--space-2); }
.roovix-m-3 { margin: var(--space-3); }
.roovix-m-4 { margin: var(--space-4); }
.roovix-m-6 { margin: var(--space-6); }
.roovix-m-8 { margin: var(--space-8); }

.roovix-mt-1 { margin-top: var(--space-1); }
.roovix-mt-2 { margin-top: var(--space-2); }
.roovix-mt-3 { margin-top: var(--space-3); }
.roovix-mt-4 { margin-top: var(--space-4); }
.roovix-mt-6 { margin-top: var(--space-6); }
.roovix-mt-8 { margin-top: var(--space-8); }

.roovix-mb-1 { margin-bottom: var(--space-1); }
.roovix-mb-2 { margin-bottom: var(--space-2); }
.roovix-mb-3 { margin-bottom: var(--space-3); }
.roovix-mb-4 { margin-bottom: var(--space-4); }
.roovix-mb-6 { margin-bottom: var(--space-6); }
.roovix-mb-8 { margin-bottom: var(--space-8); }

.roovix-ml-1 { margin-left: var(--space-1); }
.roovix-ml-2 { margin-left: var(--space-2); }
.roovix-ml-3 { margin-left: var(--space-3); }
.roovix-ml-4 { margin-left: var(--space-4); }

.roovix-mr-1 { margin-right: var(--space-1); }
.roovix-mr-2 { margin-right: var(--space-2); }
.roovix-mr-3 { margin-right: var(--space-3); }
.roovix-mr-4 { margin-right: var(--space-4); }

.roovix-mx-auto { margin-left: auto; margin-right: auto; }
.roovix-my-auto { margin-top: auto; margin-bottom: auto; }

.roovix-p-0 { padding: 0; }
.roovix-p-1 { padding: var(--space-1); }
.roovix-p-2 { padding: var(--space-2); }
.roovix-p-3 { padding: var(--space-3); }
.roovix-p-4 { padding: var(--space-4); }
.roovix-p-6 { padding: var(--space-6); }
.roovix-p-8 { padding: var(--space-8); }

.roovix-pt-1 { padding-top: var(--space-1); }
.roovix-pt-2 { padding-top: var(--space-2); }
.roovix-pt-3 { padding-top: var(--space-3); }
.roovix-pt-4 { padding-top: var(--space-4); }

.roovix-pb-1 { padding-bottom: var(--space-1); }
.roovix-pb-2 { padding-bottom: var(--space-2); }
.roovix-pb-3 { padding-bottom: var(--space-3); }
.roovix-pb-4 { padding-bottom: var(--space-4); }

/* Display Utilities */
.roovix-hidden { display: none; }
.roovix-block { display: block; }
.roovix-inline-block { display: inline-block; }
.roovix-inline { display: inline; }

/* Position Utilities */
.roovix-relative { position: relative; }
.roovix-absolute { position: absolute; }
.roovix-fixed { position: fixed; }
.roovix-sticky { position: sticky; }

.roovix-top-0 { top: 0; }
.roovix-right-0 { right: 0; }
.roovix-bottom-0 { bottom: 0; }
.roovix-left-0 { left: 0; }

/* Width/Height Utilities */
.roovix-w-full { width: 100%; }
.roovix-w-auto { width: auto; }
.roovix-w-screen { width: 100vw; }

.roovix-h-full { height: 100%; }
.roovix-h-auto { height: auto; }
.roovix-h-screen { height: 100vh; }

/* Border Radius */
.roovix-rounded-none { border-radius: 0; }
.roovix-rounded-sm { border-radius: var(--radius-sm); }
.roovix-rounded { border-radius: var(--radius-base); }
.roovix-rounded-md { border-radius: var(--radius-md); }
.roovix-rounded-lg { border-radius: var(--radius-lg); }
.roovix-rounded-xl { border-radius: var(--radius-xl); }
.roovix-rounded-full { border-radius: var(--radius-full); }
.roovix-rounded-round { border-radius: var(--radius-round); }

/* ========================================
   29. RESPONSIVE UTILITIES
   ======================================== */

@media (min-width: 640px) {
  .roovix-sm\:hidden { display: none; }
  .roovix-sm\:block { display: block; }
  .roovix-sm\:flex { display: flex; }
  .roovix-sm\:grid { display: grid; }
  .roovix-sm\:w-auto { width: auto; }
  .roovix-sm\:text-left { text-align: left; }
  .roovix-sm\:text-center { text-align: center; }
  .roovix-sm\:text-right { text-align: right; }
}

@media (min-width: 768px) {
  .roovix-md\:hidden { display: none; }
  .roovix-md\:block { display: block; }
  .roovix-md\:flex { display: flex; }
  .roovix-md\:grid { display: grid; }
  .roovix-md\:w-auto { width: auto; }
  .roovix-md\:text-base { font-size: var(--text-base); }
}

@media (min-width: 1024px) {
  .roovix-lg\:hidden { display: none; }
  .roovix-lg\:block { display: block; }
  .roovix-lg\:flex { display: flex; }
  .roovix-lg\:grid { display: grid; }
  .roovix-lg\:text-lg { font-size: var(--text-lg); }
}

/* ========================================
   30. ANIMATIONS
   ======================================== */

.roovix-fade-in {
  animation: roovix-fade-in 0.3s ease;
}

.roovix-slide-up {
  animation: roovix-slide-up 0.3s ease;
}

.roovix-slide-down {
  animation: roovix-slide-down 0.3s ease;
}

.roovix-scale-in {
  animation: roovix-scale-in 0.2s ease;
}

@keyframes roovix-fade-in {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes roovix-slide-up {
  from {
    transform: translateY(20px);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes roovix-slide-down {
  from {
    transform: translateY(-20px);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

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

/* ========================================
   31. PRINT STYLES
   ======================================== */

@media print {
  .roovix-no-print {
    display: none !important;
  }
  
  .roovix-card {
    box-shadow: none;
    border: 1px solid #ddd;
    break-inside: avoid;
  }
  
  .roovix-btn {
    display: none !important;
  }
  
  a {
    text-decoration: underline;
    color: #000 !important;
  }
}

/* ========================================
   32. DARK MODE SUPPORT
   ======================================== */

@media (prefers-color-scheme: dark) {
  :root {
    color-scheme: dark;
  }
}

[data-theme="dark"] {
  color-scheme: dark;
}

[data-theme="light"] {
  color-scheme: light;
}

/* High Contrast Mode Support */
@media (prefers-contrast: high) {
  .roovix-btn,
  .roovix-card,
  .roovix-input {
    border-width: 2px;
  }
  
  .roovix-badge,
  .roovix-tag {
    border-width: 2px;
  }
}

/* Reduced Motion Support */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
