/* ═══════════════════════════════════════════════════════════════════════
   COREFINITY — Universal Design System CSS
   Gunakan di setiap halaman:
     <link rel="stylesheet" href="assets/css/corefinity.css">
   Requires: Inter font + Tailwind CDN (untuk utility classes di HTML)
   ═══════════════════════════════════════════════════════════════════════ */

/* ─── 1. Design Tokens ──────────────────────────────────────────────── */
:root {
  /* Brand */
  --cf-blue: #0F488A;
  --cf-cyan: #009BDE;
  --cf-orange: #FF7102;

  /* Surface */
  --cf-bg: #F3F8FC;
  --cf-card: #FFFFFF;
  --cf-elevated: #E8F3FB;
  --cf-border: #CFE1F1;
  --cf-border-focus: #009BDE;

  /* Text */
  --cf-text-primary: #0B2540;
  --cf-text-secondary: #3B5978;
  --cf-text-muted: #6F8BA7;

  /* Gradient parts for body */
  --cf-grad-1: #F7FBFE;
  --cf-grad-2: #EEF6FC;

  /* Elevation */
  --cf-shadow-xs: 0 1px 4px rgba(15, 72, 138, .08);
  --cf-shadow-sm: 0 4px 16px -6px rgba(15, 72, 138, .14);
  --cf-shadow-md: 0 10px 30px -10px rgba(15, 72, 138, .22);
  --cf-shadow-lg: 0 20px 50px -15px rgba(15, 72, 138, .28);
  --cf-shadow-modal: 0 32px 80px -16px rgba(15, 72, 138, .32);

  /* Radius */
  --cf-radius-xs: 6px;
  --cf-radius-sm: 8px;
  --cf-radius-md: 12px;
  --cf-radius-lg: 16px;
  --cf-radius-xl: 20px;

  /* Motion */
  --cf-ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --cf-ease-in: cubic-bezier(0.4, 0, 1, 1);
  --cf-t-fast: 150ms;
  --cf-t-base: 250ms;
  --cf-t-slow: 350ms;

  /* Layout */
  --cf-header-h: 3.5rem;
  /* 56px */
  --cf-sidebar-w: 15rem;
  /* 240px */
}

/* ─── Dark Mode Overrides ─────────────────────────────────────────── */
.dark {
  /* Brand Adjustments for dark mode visibility */
  --cf-blue: #3B82F6;
  --cf-cyan: #34D399;
  /* Emerald/Cyan mix for contrast */
  /* --cf-orange remains same, it pops well */

  /* Surface */
  --cf-bg: #020617;
  /* Slate-950 */
  --cf-card: #0F172A;
  /* Slate-900 */
  --cf-elevated: #1E293B;
  /* Slate-800 */
  --cf-border: #334155;
  /* Slate-700 */

  /* Text */
  --cf-text-primary: #F8FAFC;
  /* Slate-50 */
  --cf-text-secondary: #CBD5E1;
  /* Slate-300 */
  --cf-text-muted: #64748B;
  /* Slate-500 */

  /* Gradient parts for body */
  --cf-grad-1: #020617;
  --cf-grad-2: #0F172A;

  /* Shadow - subtle light for depth in dark mode */
  --cf-shadow-xs: 0 1px 4px rgba(0, 0, 0, .3);
  --cf-shadow-sm: 0 4px 16px -6px rgba(0, 0, 0, .5);
  --cf-shadow-md: 0 10px 30px -10px rgba(0, 0, 0, .6);
  --cf-shadow-lg: 0 20px 50px -15px rgba(0, 0, 0, .7);
  --cf-shadow-modal: 0 0 0 1px rgba(255, 255, 255, 0.05), 0 32px 80px -16px rgba(0, 0, 0, .8);
}

/* ─── 2. Base & Reset ───────────────────────────────────────────────── */
*,
*::before,
*::after {
  box-sizing: border-box;
}

body {
  font-family: 'Inter', sans-serif;
  background:
    radial-gradient(circle at top right, rgba(255, 113, 2, .05), transparent 22rem),
    linear-gradient(180deg, var(--cf-grad-1) 0%, var(--cf-grad-2) 100%);
  background-attachment: fixed;
  color: var(--cf-text-primary);
}

/* ─── 3. Scrollbar ──────────────────────────────────────────────────── */
::-webkit-scrollbar {
  width: 4px;
  height: 4px;
}

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

::-webkit-scrollbar-thumb {
  background: rgba(156, 196, 225, .55);
  border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
  background: rgba(156, 196, 225, .85);
}

/* ─── 4. Focus Visible ──────────────────────────────────────────────── */
:focus-visible {
  outline: 2px solid var(--cf-cyan);
  outline-offset: 2px;
  border-radius: var(--cf-radius-xs);
}

/* ─── 5. Header ─────────────────────────────────────────────────────── */
.cf-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 50;
  height: var(--cf-header-h);
  background: var(--cf-card);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--cf-border);
  display: flex;
  align-items: center;
  padding: 0 1rem;
  gap: 0.625rem;
  box-shadow: 0 1px 0 var(--cf-border), var(--cf-shadow-xs);
}

/* ─── 6. Layout Wrapper ─────────────────────────────────────────────── */
.cf-layout {
  display: flex;
  margin-top: var(--cf-header-h);
  min-height: calc(100vh - var(--cf-header-h));
}

/* ─── 7. Sidebar ────────────────────────────────────────────────────── */
.cf-sidebar {
  /* Desktop: sticky, always visible by default */
  position: sticky;
  top: var(--cf-header-h);
  height: calc(100vh - var(--cf-header-h));
  width: var(--cf-sidebar-w);
  flex-shrink: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  padding-left: 16px;
  /* Space for accent border */
  background: var(--cf-card);
  transition:
    width var(--cf-t-base) var(--cf-ease-out),
    opacity var(--cf-t-base) var(--cf-ease-out),
    transform var(--cf-t-base) var(--cf-ease-out);
  will-change: width;
  z-index: 40;
}

.cf-sidebar::before {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 16px;
  background: linear-gradient(180deg, var(--cf-blue) 0%, var(--cf-cyan) 100%);
  z-index: 10;
}

.cf-sidebar nav {
  overflow-y: auto;
  overflow-x: hidden;
  flex: 1;
}

/* Desktop collapse state */
.cf-sidebar--collapsed {
  width: 5rem;
  /* ~80px: 16px blue bar + 64px icon area */
}

.cf-sidebar--collapsed .cf-nav-text,
.cf-sidebar--collapsed .cf-sidebar-hide {
  display: none !important;
}

.cf-sidebar--collapsed .cf-nav-item {
  justify-content: center;
  padding-left: 0;
  padding-right: 0;
}

/* Mobile: fixed, slides from left */
@media (max-width: 768px) {
  .cf-sidebar {
    position: fixed;
    left: 0;
    top: var(--cf-header-h);
    width: var(--cf-sidebar-w) !important;
    opacity: 1 !important;
    pointer-events: all !important;
    transform: translateX(-100%);
    box-shadow: none;
    transition: transform var(--cf-t-base) var(--cf-ease-out);
    z-index: 40;
  }

  .cf-sidebar--mobile-open {
    transform: translateX(0);
    box-shadow: var(--cf-shadow-lg);
  }
}

/* ─── 8. Mobile Overlay ─────────────────────────────────────────────── */
.cf-mobile-overlay {
  position: fixed;
  inset: 0;
  background: rgba(11, 37, 64, .45);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  z-index: 30;
}

/* ─── 9. Sidebar Toggle Button ──────────────────────────────────────── */
.cf-sidebar-toggle {
  /* Show only on desktop */
  display: none;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: var(--cf-radius-sm);
  background: transparent;
  border: none;
  cursor: pointer;
  color: var(--cf-text-muted);
  flex-shrink: 0;
  transition:
    background var(--cf-t-fast) ease,
    color var(--cf-t-fast) ease;
}

.cf-sidebar-toggle:hover {
  background: var(--cf-elevated);
  color: var(--cf-text-primary);
}

.cf-sidebar-toggle svg {
  width: 18px;
  height: 18px;
  transition: transform var(--cf-t-base) var(--cf-ease-out);
}

.cf-sidebar-toggle.is-collapsed svg {
  transform: scaleX(-1);
}

@media (min-width: 769px) {
  .cf-sidebar-toggle {
    display: flex;
  }
}

/* ─── 10. Main Content ──────────────────────────────────────────────── */
.cf-main {
  flex: 1;
  min-width: 0;
  transition: all var(--cf-t-base) var(--cf-ease-out);
}

/* ─── 11. Sidebar Nav Items ─────────────────────────────────────────── */
.cf-nav-label {
  font-size: 0.6875rem;
  font-weight: 600;
  color: var(--cf-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  padding: 1.25rem 1rem 0.625rem;
  display: block;
}

.cf-nav-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.5625rem 0.75rem;
  min-height: 44px;
  border-radius: 10px;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--cf-text-secondary);
  text-decoration: none;
  margin-bottom: 1px;
  transition:
    background var(--cf-t-fast) ease,
    color var(--cf-t-fast) ease,
    transform var(--cf-t-fast) ease;
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
  overflow: hidden;
  position: relative;
}

.cf-nav-item:hover {
  background: var(--cf-elevated);
  color: var(--cf-text-primary);
  transform: translateX(2px);
}

.cf-nav-item svg {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  transition: color var(--cf-t-fast) ease;
}

.cf-nav-item--active {
  background: linear-gradient(90deg, rgba(0, 155, 222, .13), rgba(15, 72, 138, .07));
  color: var(--cf-blue);
}

.cf-nav-item--active:hover {
  transform: none;
}

/* ─── 12. Section Cards ─────────────────────────────────────────────── */
.cf-card {
  background: var(--cf-card);
  border-radius: var(--cf-radius-xl);
  border: 1px solid var(--cf-border);
  box-shadow: var(--cf-shadow-sm);
  overflow: hidden;
  transition:
    box-shadow var(--cf-t-base) var(--cf-ease-out),
    transform var(--cf-t-base) var(--cf-ease-out);
}

.cf-card:hover {
  box-shadow: var(--cf-shadow-md);
  transform: translateY(-1px);
}

.cf-card-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 1.125rem 1.5rem;
  border-bottom: 1px solid var(--cf-border);
  background: linear-gradient(to right, rgba(248, 252, 255, .8), var(--cf-card));
}

.cf-card-icon {
  width: 40px;
  height: 40px;
  border-radius: var(--cf-radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: transform var(--cf-t-fast) ease;
}

.cf-card:hover .cf-card-icon {
  transform: scale(1.05);
}

.cf-card-icon--orange {
  background: rgba(255, 113, 2, .12);
  box-shadow: 0 0 0 4px rgba(255, 113, 2, .07);
}

.cf-card-icon--orange svg {
  color: var(--cf-orange);
}

.cf-card-icon--cyan {
  background: rgba(0, 155, 222, .12);
  box-shadow: 0 0 0 4px rgba(0, 155, 222, .07);
}

.cf-card-icon--cyan svg {
  color: var(--cf-cyan);
}

.cf-card-icon--blue {
  background: rgba(15, 72, 138, .10);
  box-shadow: 0 0 0 4px rgba(15, 72, 138, .05);
}

.cf-card-icon--blue svg {
  color: var(--cf-blue);
}

.cf-card-icon--red {
  background: rgba(239, 68, 68, .10);
  box-shadow: 0 0 0 4px rgba(239, 68, 68, .05);
}

.cf-card-icon--red svg {
  color: #ef4444;
}

.cf-card-body {
  padding: 1.5rem;
}

.cf-card-body--spaced {
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.cf-card-footer {
  padding: 0.875rem 1.5rem;
  background: linear-gradient(to right, rgba(243, 248, 252, .8), var(--cf-bg));
  border-top: 1px solid var(--cf-border);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.75rem;
}

/* ─── 13. Form Inputs ───────────────────────────────────────────────── */
.cf-input {
  width: 100%;
  background: var(--cf-bg);
  border: 1.5px solid var(--cf-border);
  border-radius: var(--cf-radius-md);
  padding: 0.625rem 1rem;
  font-size: 0.875rem;
  color: var(--cf-text-primary);
  font-family: 'Inter', sans-serif;
  outline: none;
  transition:
    border-color var(--cf-t-fast) ease,
    box-shadow var(--cf-t-fast) ease;
}

.cf-input::placeholder {
  color: var(--cf-text-muted);
}

.cf-input:hover:not(:focus, :read-only) {
  border-color: rgba(0, 155, 222, .4);
}

.cf-input:focus {
  border-color: var(--cf-cyan);
  box-shadow: 0 0 0 3px rgba(0, 155, 222, .18);
}

.cf-input:read-only {
  cursor: pointer;
}

/* Input with left icon */
.cf-input-group {
  position: relative;
}

.cf-input-group .cf-input {
  padding-left: 2.5rem;
}

.cf-input-group-icon {
  position: absolute;
  left: 0.875rem;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  color: var(--cf-text-muted);
  pointer-events: none;
  flex-shrink: 0;
}

/* Input with right slot (password toggle, kbd) */
.cf-input-group .cf-input--pr {
  padding-right: 2.75rem;
}

/* Password toggle */
.cf-pw-toggle {
  position: absolute;
  right: 0.625rem;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  cursor: pointer;
  color: var(--cf-text-muted);
  padding: 5px;
  border-radius: var(--cf-radius-xs);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color var(--cf-t-fast) ease, background var(--cf-t-fast) ease;
}

.cf-pw-toggle:hover {
  color: var(--cf-text-secondary);
  background: var(--cf-elevated);
}

/* Password strength */
.cf-strength-bars {
  display: flex;
  gap: 4px;
  margin-top: 8px;
}

.cf-strength-bar {
  height: 3px;
  flex: 1;
  border-radius: 9999px;
  background: var(--cf-border);
  transition: background-color var(--cf-t-base) ease;
}

/* Select */
.cf-select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background: var(--cf-bg);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M5 7.5L10 12.5L15 7.5' stroke='%2359708f' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  background-size: 0.875rem;
  border: 1.5px solid var(--cf-border);
  border-radius: var(--cf-radius-lg);
  padding: 0.625rem 2.5rem 0.625rem 0.875rem;
  font-size: 0.875rem;
  color: var(--cf-text-secondary);
  font-family: 'Inter', sans-serif;
  cursor: pointer;
  outline: none;
  transition: border-color var(--cf-t-fast) ease, box-shadow var(--cf-t-fast) ease, background-color var(--cf-t-fast) ease;
}

.cf-select:hover {
  border-color: #b6c5dc;
  background-color: #fbfdff;
}

.cf-select:focus {
  border-color: var(--cf-cyan);
  box-shadow: 0 0 0 3px rgba(0, 155, 222, .18);
}

.cf-select:disabled {
  cursor: not-allowed;
  opacity: 0.65;
  background-color: var(--cf-elevated);
}

select.cf-select::-ms-expand {
  display: none;
}

select.cf-select[multiple],
select.cf-select[size]:not([size="1"]) {
  background-image: none;
  padding-right: 0.875rem;
}

/* Connected Custom Select */
.cf-connected-select-wrapper {
  position: relative;
  width: 100%;
}

.cf-connected-select-btn {
  appearance: none;
  background: var(--cf-bg);
  border: 1.5px solid var(--cf-border);
  border-radius: var(--cf-radius-md);
  padding: 0.625rem 2.25rem 0.625rem 0.75rem;
  font-size: 0.875rem;
  color: var(--cf-text-secondary);
  font-family: 'Inter', sans-serif;
  cursor: pointer;
  outline: none;
  width: 100%;
  text-align: left;
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: border-color var(--cf-t-fast) ease, box-shadow var(--cf-t-fast) ease;
}

.cf-connected-select-btn:focus,
.cf-connected-select-btn[aria-expanded="true"] {
  border-color: var(--cf-cyan);
  box-shadow: 0 0 0 3px rgba(0, 155, 222, .18);
}

.cf-connected-select-btn[aria-expanded="true"] {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
  border-top-color: transparent;
  /* Seamless connection upwards */
}

.cf-connected-select-panel {
  position: absolute;
  bottom: 100%;
  left: 0;
  right: 0;
  background: var(--cf-bg);
  border: 1.5px solid var(--cf-cyan);
  border-bottom: 1px solid var(--cf-border);
  border-top-left-radius: var(--cf-radius-md);
  border-top-right-radius: var(--cf-radius-md);
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  box-shadow: 0 -8px 24px -8px rgba(0, 155, 222, .25);
  z-index: 50;
  overflow: hidden;
  max-height: 240px;
  overflow-y: auto;
  margin-bottom: -1.5px;
  /* Overlap button top border perfectly */
}

.cf-connected-select-item {
  display: flex;
  align-items: center;
  width: 100%;
  padding: 0.625rem 0.75rem;
  font-size: 0.875rem;
  color: var(--cf-text-secondary);
  background: transparent;
  border: none;
  cursor: pointer;
  text-align: left;
  font-family: 'Inter', sans-serif;
  transition: background var(--cf-t-fast) ease, color var(--cf-t-fast) ease;
}

.cf-connected-select-item:hover {
  background: rgba(0, 155, 222, .08);
  color: var(--cf-text-primary);
}

.cf-connected-select-item.is-selected {
  background: var(--cf-blue);
  color: #fff;
}

/* ─── 14. Buttons ───────────────────────────────────────────────────── */
.cf-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1.25rem;
  font-size: 0.875rem;
  font-weight: 600;
  border-radius: var(--cf-radius-md);
  border: 1px solid transparent;
  cursor: pointer;
  text-decoration: none;
  font-family: 'Inter', sans-serif;
  min-height: 40px;
  white-space: nowrap;
  transition:
    background var(--cf-t-fast) ease,
    box-shadow var(--cf-t-fast) ease,
    transform var(--cf-t-fast) ease,
    border-color var(--cf-t-fast) ease;
  user-select: none;
}

.cf-btn:active {
  transform: scale(0.96);
}

.cf-btn--orange {
  background: var(--cf-orange);
  color: #fff;
  box-shadow: 0 2px 8px rgba(255, 113, 2, .28);
}

.cf-btn--orange:hover {
  background: #e05e00;
  box-shadow: 0 4px 16px rgba(255, 113, 2, .35);
}

.cf-btn--blue {
  background: var(--cf-blue);
  color: #fff;
  box-shadow: 0 2px 8px rgba(15, 72, 138, .22);
}

.cf-btn--blue:hover {
  background: #0a3568;
  box-shadow: 0 4px 16px rgba(15, 72, 138, .3);
}

.cf-btn--cyan {
  background: var(--cf-cyan);
  color: #fff;
  box-shadow: 0 2px 8px rgba(0, 155, 222, .22);
}

.cf-btn--cyan:hover {
  background: #007db5;
  box-shadow: 0 4px 14px rgba(0, 155, 222, .3);
}

.cf-btn--ghost {
  background: transparent;
  color: var(--cf-text-secondary);
  border-color: transparent;
}

.cf-btn--ghost:hover {
  background: var(--cf-elevated);
  color: var(--cf-text-primary);
  border-color: var(--cf-border);
}

.cf-btn--danger {
  background: transparent;
  color: #dc2626;
  border-color: #fca5a5;
}

.cf-btn--danger:hover {
  background: #fef2f2;
  border-color: #f87171;
}

/* ─── 15. Dropdown Menu ─────────────────────────────────────────────── */
.cf-dropdown-wrapper {
  position: relative;
}

.cf-dropdown-panel {
  position: absolute;
  right: 0;
  top: calc(100% + 8px);
  background: var(--cf-card);
  border: 1px solid var(--cf-border);
  border-radius: var(--cf-radius-lg);
  box-shadow: var(--cf-shadow-lg);
  z-index: 60;
  overflow: hidden;
  animation: cf-dropdown-in var(--cf-t-fast) var(--cf-ease-out) both;
  transform-origin: top right;
}

.cf-dropdown-item {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  padding: 0.625rem 1rem;
  font-size: 0.875rem;
  color: var(--cf-text-secondary);
  text-decoration: none;
  transition: background var(--cf-t-fast) ease, color var(--cf-t-fast) ease;
  cursor: pointer;
  border: none;
  background: none;
  width: 100%;
  text-align: left;
  font-family: 'Inter', sans-serif;
}

.cf-dropdown-item:hover {
  background: var(--cf-bg);
  color: var(--cf-text-primary);
}

.cf-dropdown-item--primary {
  color: var(--cf-blue);
  font-weight: 500;
}

.cf-dropdown-item--danger {
  color: #ef4444;
}

.cf-dropdown-item--danger:hover {
  background: #fef2f2;
  color: #dc2626;
}

.cf-dropdown-divider {
  height: 1px;
  background: var(--cf-border);
  margin: 3px 0;
}

/* ─── 16. Search Bar (Header Trigger) ───────────────────────────────── */
.cf-search-trigger {
  position: relative;
  display: flex;
  align-items: center;
  cursor: pointer;
  border-radius: var(--cf-radius-md);
  transition: box-shadow var(--cf-t-fast) ease;
}

.cf-search-trigger:hover input {
  border-color: rgba(0, 155, 222, .45);
}

.cf-search-trigger:focus-within {
  box-shadow: none;
}

.cf-search-trigger input {
  cursor: pointer;
  caret-color: transparent;
}

/* ─── 17. Global Search Modal ───────────────────────────────────────── */
.cf-search-overlay {
  position: fixed;
  inset: 0;
  background: rgba(11, 37, 64, .52);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 200;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: max(8vh, 60px) 1rem 1rem;
}

.cf-search-modal {
  width: min(640px, 100%);
  background: var(--cf-card);
  border: 1px solid var(--cf-border);
  border-radius: var(--cf-radius-xl);
  box-shadow: var(--cf-shadow-modal);
  display: flex;
  flex-direction: column;
  max-height: min(75vh, 600px);
  overflow: hidden;
}

/* Search input row */
.cf-search-modal-head {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 1rem 1.125rem;
  border-bottom: 1px solid var(--cf-border);
  flex-shrink: 0;
}

.cf-search-modal-input {
  flex: 1;
  border: none;
  outline: none;
  font-size: 1rem;
  font-family: 'Inter', sans-serif;
  color: var(--cf-text-primary);
  background: transparent;
  caret-color: var(--cf-cyan);
  min-width: 0;
}

.cf-search-modal-input::placeholder {
  color: var(--cf-text-muted);
}

.cf-kbd {
  font-size: 0.6875rem;
  color: var(--cf-text-muted);
  background: var(--cf-bg);
  border: 1px solid var(--cf-border);
  border-radius: var(--cf-radius-xs);
  padding: 2px 7px;
  font-family: 'Inter', ui-monospace, monospace;
  white-space: nowrap;
  flex-shrink: 0;
  line-height: 1.6;
}

/* Category tabs */
.cf-search-tabs {
  display: flex;
  gap: 6px;
  padding: 0.75rem 1.125rem;
  border-bottom: 1px solid var(--cf-border);
  overflow-x: auto;
  scrollbar-width: none;
  flex-shrink: 0;
}

.cf-search-tabs::-webkit-scrollbar {
  display: none;
}

.cf-search-tab {
  padding: 4px 14px;
  border-radius: 9999px;
  font-size: 0.75rem;
  font-weight: 500;
  border: 1.5px solid var(--cf-border);
  background: transparent;
  color: var(--cf-text-secondary);
  cursor: pointer;
  white-space: nowrap;
  font-family: 'Inter', sans-serif;
  min-height: 28px;
  transition: all var(--cf-t-fast) ease;
}

.cf-search-tab:hover {
  background: var(--cf-elevated);
  color: var(--cf-text-primary);
}

.cf-search-tab.is-active {
  background: var(--cf-blue);
  color: #fff;
  border-color: var(--cf-blue);
  box-shadow: 0 2px 8px rgba(15, 72, 138, .22);
}

/* Results list */
.cf-search-results {
  overflow-y: auto;
  flex: 1;
  padding: 6px 8px;
}

.cf-search-result {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.5625rem 0.75rem;
  border-radius: var(--cf-radius-md);
  cursor: pointer;
  text-decoration: none;
  transition: background var(--cf-t-fast) ease;
  min-height: 52px;
}

.cf-search-result:hover,
.cf-search-result.is-selected {
  background: var(--cf-elevated);
}

.cf-search-result-icon {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.cf-search-result-title {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--cf-text-primary);
  line-height: 1.3;
}

.cf-search-result-breadcrumb {
  font-size: 0.6875rem;
  color: var(--cf-text-muted);
  margin-top: 2px;
}

/* Empty state */
.cf-search-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 3rem 1rem;
  color: var(--cf-text-muted);
  gap: 0.75rem;
  text-align: center;
}

.cf-search-empty svg {
  opacity: .35;
}

/* Footer hints */
.cf-search-footer {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.625rem 1.125rem;
  border-top: 1px solid var(--cf-border);
  background: var(--cf-bg);
  flex-shrink: 0;
  flex-wrap: wrap;
}

.cf-search-hint {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 0.6875rem;
  color: var(--cf-text-muted);
}

/* ─── 18. Toast ─────────────────────────────────────────────────────── */
.cf-toast {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  z-index: 9999;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  background: var(--cf-blue);
  color: #fff;
  font-size: 0.875rem;
  font-weight: 500;
  font-family: 'Inter', sans-serif;
  padding: 0.75rem 1.25rem;
  border-radius: 14px;
  box-shadow: var(--cf-shadow-lg), 0 0 0 1px rgba(255, 255, 255, .08) inset;
  pointer-events: none;
  user-select: none;
  opacity: 0;
  transform: translateY(14px) scale(0.97);
  transition:
    opacity var(--cf-t-base) var(--cf-ease-out),
    transform var(--cf-t-base) var(--cf-ease-out);
  min-width: 220px;
  max-width: 340px;
}

.cf-toast.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.cf-toast-check {
  width: 22px;
  height: 22px;
  background: rgba(0, 155, 222, .3);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.cf-toast-check svg {
  color: var(--cf-cyan);
  width: 12px;
  height: 12px;
}

/* ─── 19. Notification Badge ────────────────────────────────────────── */
.cf-notif-dot {
  position: absolute;
  top: 7px;
  right: 7px;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--cf-orange);
  border: 1.5px solid #fff;
  animation: cf-pulse 2s ease-in-out infinite;
}

/* ─── 20. Info Alert Box ────────────────────────────────────────────── */
.cf-alert {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  border-radius: var(--cf-radius-md);
  padding: 0.75rem 1rem;
  font-size: 0.8125rem;
  line-height: 1.55;
}

.cf-alert--warning {
  background: rgba(255, 113, 2, .08);
  border: 1px solid rgba(255, 113, 2, .20);
  color: var(--cf-text-secondary);
}

.cf-alert--warning>svg {
  color: var(--cf-orange);
  flex-shrink: 0;
  margin-top: 1px;
}

.cf-alert--info {
  background: rgba(0, 155, 222, .08);
  border: 1px solid rgba(0, 155, 222, .20);
  color: var(--cf-text-secondary);
}

/* ─── 21. Avatar ────────────────────────────────────────────────────── */
.cf-avatar {
  border-radius: var(--cf-radius-lg);
  background: var(--cf-blue);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-family: 'Inter', sans-serif;
  user-select: none;
  flex-shrink: 0;
  box-shadow: var(--cf-shadow-xs);
}

.cf-avatar--sm {
  width: 28px;
  height: 28px;
  font-size: 0.6875rem;
  border-radius: 8px;
}

.cf-avatar--md {
  width: 36px;
  height: 36px;
  font-size: 0.875rem;
  border-radius: 10px;
}

.cf-avatar--lg {
  width: 64px;
  height: 64px;
  font-size: 1.25rem;
}

/* ─── 22. Divider ───────────────────────────────────────────────────── */
.cf-divider {
  height: 1px;
  background: var(--cf-border);
}

/* ─── 23. Breadcrumb ────────────────────────────────────────────────── */
.cf-breadcrumb {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 0.75rem;
  color: var(--cf-text-muted);
}

.cf-breadcrumb a {
  color: inherit;
  text-decoration: none;
}

.cf-breadcrumb a:hover {
  color: var(--cf-blue);
}

.cf-breadcrumb svg {
  width: 12px;
  height: 12px;
}

/* ─── 24. Page Header ───────────────────────────────────────────────── */
.cf-page-title {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--cf-text-primary);
  letter-spacing: -0.025em;
  line-height: 1.2;
}

.cf-page-desc {
  font-size: 0.875rem;
  color: var(--cf-text-secondary);
  margin-top: 0.25rem;
  line-height: 1.55;
}

/* ─── 25. Animations ────────────────────────────────────────────────── */
@keyframes cf-dropdown-in {
  from {
    opacity: 0;
    transform: scale(0.95) translateY(-6px);
  }

  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

@keyframes cf-pulse {

  0%,
  100% {
    box-shadow: 0 0 0 0 rgba(255, 113, 2, .5);
  }

  50% {
    box-shadow: 0 0 0 5px rgba(255, 113, 2, 0);
  }
}

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

/* Alpine x-transition helpers (used with Tailwind) */
/* Search overlay */
.cf-overlay-enter {
  animation: cf-overlay-in 200ms var(--cf-ease-out) both;
}

.cf-overlay-leave {
  animation: cf-overlay-out 150ms var(--cf-ease-in) both;
}

@keyframes cf-overlay-in {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

@keyframes cf-overlay-out {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}

/* Search modal */
.cf-modal-enter {
  animation: cf-modal-in 220ms var(--cf-ease-out) both;
}

.cf-modal-leave {
  animation: cf-modal-out 150ms var(--cf-ease-in) both;
}

@keyframes cf-modal-in {
  from {
    opacity: 0;
    transform: scale(.95) translateY(-10px);
  }

  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

@keyframes cf-modal-out {
  from {
    opacity: 1;
    transform: scale(1) translateY(0);
  }

  to {
    opacity: 0;
    transform: scale(.96) translateY(-6px);
  }
}

/* ─── 26. Utility ───────────────────────────────────────────────────── */
.cf-truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.cf-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

/* Search modal */
.cf-modal-enter {
  animation: cf-modal-in 220ms var(--cf-ease-out) both;
}

.cf-modal-leave {
  animation: cf-modal-out 150ms var(--cf-ease-in) both;
}

@keyframes cf-modal-in {
  from {
    opacity: 0;
    transform: scale(.95) translateY(-10px);
  }

  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

@keyframes cf-modal-out {
  from {
    opacity: 1;
    transform: scale(1) translateY(0);
  }

  to {
    opacity: 0;
    transform: scale(.96) translateY(-6px);
  }
}

/* ─── 26. Utility ───────────────────────────────────────────────────── */
.cf-truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.cf-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}
