/* -------------------------------------------------------------------------- */
/* Tailwind Extensions                                                        */
/* Centralized overrides extending Tailwind’s theme, utility, and component   */
/* layers with project-specific design tokens and helper classes.             */
/* -------------------------------------------------------------------------- */

/* -------------------------------------------------------------------------- */
/* Theme tokens                                                               */
/* Define additional CSS custom properties that Tailwind utilities can use.   */
/* -------------------------------------------------------------------------- */
@layer theme {
  :root,
  :host {
    --color-fuchsia-50: oklch(97.7% 0.017 320.058);
    --color-fuchsia-100: oklch(94.8% 0.043 319.998);
    --color-fuchsia-200: oklch(89.8% 0.089 319.892);
    --color-fuchsia-300: oklch(83% 0.145 321.021);
    --color-fuchsia-800: oklch(41.3% 0.199 322.123);
    --color-fuchsia-900: oklch(34.7% 0.19 323.563);
    --color-fuchsia-950: oklch(24.8% 0.144 324.369);

    --color-sky-50: oklch(97.7% 0.013 236.62);
    --color-sky-100: oklch(95.1% 0.026 236.824);
    --color-sky-200: oklch(90.1% 0.058 230.902);
    --color-sky-300: oklch(82.8% 0.111 230.318);
    --color-sky-400: oklch(74.6% 0.16 232.661);
    --color-sky-600: oklch(58.8% 0.158 241.966);
    --color-sky-700: oklch(50% 0.134 242.749);
    --color-sky-800: oklch(44.3% 0.11 240.79);
    --color-sky-950: oklch(29.3% 0.066 243.157);

    --color-rose-700: oklch(51.4% 0.222 16.935);

    --success: var(--color-green-600);
    --success-foreground: var(--color-white);
    --warning: var(--color-amber-500);
    --warning-foreground: var(--color-zinc-950);
    --info: var(--color-violet-500);
    --info-foreground: var(--color-white);

    --color-success: var(--success);
    --color-warning: var(--warning);
    --color-info: var(--info);
  }

  .dark {
    --success: var(--color-green-500);
    --success-foreground: var(--color-zinc-950);
    --warning: var(--color-amber-400);
    --warning-foreground: var(--color-zinc-950);
    --info: var(--color-sky-400);
    --info-foreground: var(--color-white);
  }
}

/* -------------------------------------------------------------------------- */
/* Utility extensions                                                         */
/* Hand-crafted utility classes that Tailwind’s generator does not emit by    */
/* default (custom colors, border widths, etc.).                              */
/* -------------------------------------------------------------------------- */
@layer utilities {
  /* --- Fuchsia palette helpers ------------------------------------------ */
  .bg-fuchsia-50 { background-color: var(--color-fuchsia-50); }
  .bg-fuchsia-100 { background-color: var(--color-fuchsia-100); }
  .bg-fuchsia-200 { background-color: var(--color-fuchsia-200); }
  .bg-fuchsia-300 { background-color: var(--color-fuchsia-300); }
  .bg-fuchsia-800 { background-color: var(--color-fuchsia-800); }
  .bg-fuchsia-900 { background-color: var(--color-fuchsia-900); }
  .bg-fuchsia-950 { background-color: var(--color-fuchsia-950); }

  .text-fuchsia-50 { color: var(--color-fuchsia-50); }
  .text-fuchsia-100 { color: var(--color-fuchsia-100); }
  .text-fuchsia-200 { color: var(--color-fuchsia-200); }
  .text-fuchsia-300 { color: var(--color-fuchsia-300); }
  .text-fuchsia-800 { color: var(--color-fuchsia-800); }
  .text-fuchsia-900 { color: var(--color-fuchsia-900); }
  .text-fuchsia-950 { color: var(--color-fuchsia-950); }

  .border-fuchsia-50 { border-color: var(--color-fuchsia-50); }
  .border-fuchsia-100 { border-color: var(--color-fuchsia-100); }
  .border-fuchsia-200 { border-color: var(--color-fuchsia-200); }
  .border-fuchsia-300 { border-color: var(--color-fuchsia-300); }
  .border-fuchsia-800 { border-color: var(--color-fuchsia-800); }
  .border-fuchsia-900 { border-color: var(--color-fuchsia-900); }
  .border-fuchsia-950 { border-color: var(--color-fuchsia-950); }

  /* --- Sky palette helpers ---------------------------------------------- */
  .border-sky-50 { border-color: var(--color-sky-50); }
  .border-sky-100 { border-color: var(--color-sky-100); }
  .border-sky-200 { border-color: var(--color-sky-200); }
  .border-sky-300 { border-color: var(--color-sky-300); }
  .border-sky-400 { border-color: var(--color-sky-400); }
  .border-sky-500 { border-color: var(--color-sky-500); }
  .border-sky-600 { border-color: var(--color-sky-600); }
  .border-sky-700 { border-color: var(--color-sky-700); }
  .border-sky-800 { border-color: var(--color-sky-800); }
  .border-sky-900 { border-color: var(--color-sky-900); }
  .border-sky-950 { border-color: var(--color-sky-950); }

  /* --- Single-color helpers -------------------------------------------- */
  .border-violet-500 { border-color: var(--color-violet-500); }
  .border-green-600 { border-color: var(--color-green-600); }
  .border-cyan-500 { border-color: var(--color-cyan-500); }
  .border-amber-400 { border-color: var(--color-amber-400); }
  .border-blue-500 { border-color: var(--color-blue-500); }
  .border-red-500 { border-color: var(--color-red-500); }
  .border-slate-500 { border-color: var(--color-slate-500); }

  /* --- Dimensional helpers --------------------------------------------- */
  .size-20 {
    width: calc(var(--spacing) * 20);
    height: calc(var(--spacing) * 20);
  }

  .border-3 {
    border-style: var(--tw-border-style);
    border-width: 3px;
  }

  .border-4 {
    border-style: var(--tw-border-style);
    border-width: 4px;
  }

  /* --- Semantic text colors -------------------------------------------- */
  .text-warning { color: var(--warning); }
  .text-success { color: var(--success); }
  .text-destructive { color: var(--destructive); }
  .text-info { color: var(--info); }
  .text-mono { color: var(--mono); }

  /* --- Semantic backgrounds with opacity guards ------------------------ */
  .bg-warning\/10 {
    background-color: var(--warning);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--warning) 10%, transparent);
    }
  }

  .bg-success\/10 {
    background-color: var(--success);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--success) 10%, transparent);
    }
  }

  .bg-destructive\/10 {
    background-color: var(--destructive);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--destructive) 10%, transparent);
    }
  }

  .bg-info\/10 {
    background-color: var(--info);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--info) 10%, transparent);
    }
  }

  .bg-mono\/10 {
    background-color: var(--mono);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--mono) 10%, transparent);
    }
  }

  /* --- Badge helpers ---------------------------------------------------- */
  .kt-badge-rose {
    background-color: var(--color-rose-700);
    color: var(--color-white);
  }
}

/* -------------------------------------------------------------------------- */
/* Component extensions                                                       */
/* Higher-level styling for widgets/components that rely on multiple rules.   */
/* Currently focused on Action Text rich text presentation.                   */
/* -------------------------------------------------------------------------- */
@layer components {
  /* --- Action Text (Trix) content --------------------------------------- */
  .trix-content {
    line-height: 1.625;
    font-size: 1rem;
  }

  .trix-content ul,
  .trix-content ol {
    margin: 0.75rem 0 0.75rem 1.5rem;
    padding-left: 1.25rem;
    list-style-position: outside;
  }

  .trix-content ul { list-style-type: disc; }
  .trix-content ol { list-style-type: decimal; }

  .trix-content ul ul,
  .trix-content ul ol,
  .trix-content ol ul,
  .trix-content ol ol {
    margin: 0.5rem 0;
  }

  .trix-content li { margin: 0.25rem 0; }

  .trix-content h1 {
    font-size: 1.75rem;
    font-weight: 600;
    margin: 1.5rem 0 0.75rem;
  }

  .trix-content h2 {
    font-size: 1.5rem;
    font-weight: 600;
    margin: 1.25rem 0 0.75rem;
  }

  .trix-content h3 {
    font-size: 1.25rem;
    font-weight: 600;
    margin: 1rem 0 0.5rem;
  }

  .trix-content h4 {
    font-size: 1.1rem;
    font-weight: 600;
    margin: 0.75rem 0 0.5rem;
  }

  .trix-content h5 {
    font-size: 1rem;
    font-weight: 600;
    margin: 0.75rem 0 0.5rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
  }

  .trix-content h6 {
    font-size: 0.875rem;
    font-weight: 600;
    margin: 0.5rem 0;
    letter-spacing: 0.08em;
    text-transform: uppercase;
  }

  .trix-content blockquote {
    border-left: 4px solid rgba(107, 114, 128, 0.4);
    padding-left: 1rem;
    font-style: italic;
    color: rgba(75, 85, 99, 1);
    background-color: rgba(107, 114, 128, 0.08);
    margin: 1rem 0;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
  }

  .dark .trix-content blockquote {
    border-left-color: rgba(156, 163, 175, 0.5);
    background-color: rgba(107, 114, 128, 0.15);
    color: rgba(209, 213, 219, 1);
  }
}
