/* Editor wrapper — ring colour set here to avoid cross-panel Tailwind cascade issues */
.fi-tiptap-wrapper {
    --tw-ring-color: color-mix(in oklab, oklch(0.141 0.005 285.823) 10%, transparent);
}

.dark .fi-tiptap-wrapper {
    --tw-ring-color: color-mix(in oklab, white 20%, transparent);
}

/* TipTap form field — prose typography matching Filament fi-prose (fi-size-sm) */
.fi-tiptap-container .ProseMirror {
    outline: none;
    padding: 1.5rem 2rem;
    font-size: 14px;
    line-height: 1.5;
    color: oklch(0.37 0.013 285.805);
}

.fi-tiptap-container .ProseMirror h1 {
    font-size: 1.4285714em;
    font-weight: 700;
    line-height: 1.5556;
    margin-top: 0;
    margin-bottom: 0.8em;
    color: oklch(0.141 0.005 285.823);
}

.fi-tiptap-container .ProseMirror h2 {
    font-size: 1.2857143em;
    font-weight: 600;
    line-height: 1.5556;
    margin-top: 1.7777778em;
    margin-bottom: 0;
    color: oklch(0.141 0.005 285.823);
}

.fi-tiptap-container .ProseMirror h3 {
    font-size: 1.1428571em;
    font-weight: 600;
    line-height: 1.5;
    margin-top: 1.5555556em;
    margin-bottom: 0;
    color: oklch(0.141 0.005 285.823);
}

.fi-tiptap-container .ProseMirror p {
    margin-top: 1.1428571em;
    margin-bottom: 0;
}

.fi-tiptap-container .ProseMirror p:first-child {
    margin-top: 0;
}

.fi-tiptap-container .ProseMirror strong {
    font-weight: 600;
    color: oklch(0.141 0.005 285.823);
}

.fi-tiptap-container .ProseMirror hr {
    margin-top: 2.2857143em;
    margin-bottom: 2.2857143em;
    border-top: 1px solid oklch(0.871 0.006 286.029);
}

.fi-tiptap-container .ProseMirror ul,
.fi-tiptap-container .ProseMirror ol {
    margin-top: 1.1428571em;
    margin-bottom: 1.1428571em;
    padding-left: 1.5714286em;
}

.fi-tiptap-container .ProseMirror ul {
    list-style-type: disc;
}

.fi-tiptap-container .ProseMirror ol {
    list-style-type: decimal;
}

.fi-tiptap-container .ProseMirror li {
    margin-top: 0.2857143em;
    margin-bottom: 0.2857143em;
}

.fi-tiptap-container .ProseMirror li > ul,
.fi-tiptap-container .ProseMirror li > ol {
    margin-top: 0.2857143em;
    margin-bottom: 0.2857143em;
}

.fi-tiptap-container .ProseMirror s {
    text-decoration: line-through;
}

.fi-tiptap-container .ProseMirror blockquote {
    margin-top: 1.3333333em;
    margin-bottom: 1.3333333em;
    padding-left: 1.1111111em;
    border-left: 0.25em solid oklch(0.871 0.006 286.029);
    font-style: italic;
    color: oklch(0.37 0.013 285.805);
}

.fi-tiptap-container .ProseMirror code {
    font-size: 0.8571429em;
    font-weight: 600;
    color: oklch(0.141 0.005 285.823);
}

.fi-tiptap-container .ProseMirror table {
    width: 100%;
    table-layout: auto;
    text-align: left;
    margin-top: 1.7142857em;
    margin-bottom: 1.7142857em;
    font-size: 0.8571429em;
    line-height: 1.5;
}

.fi-tiptap-container .ProseMirror table th,
.fi-tiptap-container .ProseMirror table td {
    padding: 0.5714286em 0.8571429em;
    border-bottom: 1px solid oklch(0.871 0.006 286.029);
}

.fi-tiptap-container .ProseMirror table th {
    font-weight: 600;
    color: oklch(0.141 0.005 285.823);
}

/* Dark mode */
.dark .fi-tiptap-container .ProseMirror {
    color: oklch(0.871 0.006 286.029);
}

.dark .fi-tiptap-container .ProseMirror h1,
.dark .fi-tiptap-container .ProseMirror h2,
.dark .fi-tiptap-container .ProseMirror h3,
.dark .fi-tiptap-container .ProseMirror strong,
.dark .fi-tiptap-container .ProseMirror code,
.dark .fi-tiptap-container .ProseMirror table th {
    color: oklch(0.985 0 0);
}

.dark .fi-tiptap-container .ProseMirror hr,
.dark .fi-tiptap-container .ProseMirror table th,
.dark .fi-tiptap-container .ProseMirror table td {
    border-color: oklch(0.37 0.013 285.805);
}

.dark .fi-tiptap-container .ProseMirror blockquote {
    border-left-color: oklch(0.37 0.013 285.805);
    color: oklch(0.871 0.006 286.029);
}

/* Toolbar buttons */
.fi-tiptap-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 28px;
    height: 28px;
    padding: 0 4px;
    border-radius: 6px;
    color: rgb(107 114 128);
    transition: all 0.15s ease;
    cursor: pointer;
    border: none;
    background: transparent;
}

.fi-tiptap-btn:hover {
    background-color: rgb(229 231 235);
    color: rgb(17 24 39);
}

.fi-tiptap-btn-active {
    background-color: rgb(219 234 254) !important;
    color: rgb(37 99 235) !important;
}

.dark .fi-tiptap-btn {
    color: rgb(156 163 175);
}

.dark .fi-tiptap-btn:hover {
    background-color: rgb(55 65 81);
    color: rgb(243 244 246);
}

.dark .fi-tiptap-btn-active {
    background-color: rgb(30 58 138) !important;
    color: rgb(147 197 253) !important;
}

/* Table size picker popover */
.fi-tiptap-table-picker {
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 50;
    margin-top: 0.25rem;
    padding: 0.5rem;
    border-radius: 0.5rem;
    background: white;
    box-shadow:
        0 10px 15px -3px rgb(0 0 0 / 0.1),
        0 4px 6px -4px rgb(0 0 0 / 0.1),
        0 0 0 1px rgb(3 7 18 / 0.08);
}

.dark .fi-tiptap-table-picker {
    background: var(--gray-900);
    box-shadow:
        0 10px 15px -3px rgb(0 0 0 / 0.3),
        0 4px 6px -4px rgb(0 0 0 / 0.3),
        0 0 0 1px rgb(255 255 255 / 0.1);
}

.fi-tiptap-table-picker-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 2px;
}

.fi-tiptap-table-picker-cell {
    width: 18px;
    height: 18px;
    border: 1px solid rgb(209 213 219); /* gray-300 */
    border-radius: 2px;
    background: rgb(249 250 251); /* gray-50 */
    cursor: pointer;
    transition: background-color 75ms ease, border-color 75ms ease;
    padding: 0;
}

.dark .fi-tiptap-table-picker-cell {
    border-color: rgb(75 85 99); /* gray-600 */
    background: rgb(31 41 55); /* gray-800 */
}

.fi-tiptap-table-picker-cell-active {
    background: var(--primary-200);
    border-color: var(--primary-500);
}

.dark .fi-tiptap-table-picker-cell-active {
    background: oklch(from var(--primary-500) l c h / 0.35);
    border-color: var(--primary-400);
}

.fi-tiptap-table-picker-label {
    margin-top: 0.375rem;
    font-size: 0.6875rem;
    text-align: center;
    color: rgb(107 114 128); /* gray-500 */
    font-variant-numeric: tabular-nums;
}

.dark .fi-tiptap-table-picker-label {
    color: rgb(156 163 175); /* gray-400 */
}

/* Link picker popover */
.fi-tiptap-link-picker {
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 50;
    margin-top: 0.25rem;
    padding: 0.75rem;
    width: 260px;
    border-radius: 0.5rem;
    background: white;
    box-shadow:
        0 10px 15px -3px rgb(0 0 0 / 0.1),
        0 4px 6px -4px rgb(0 0 0 / 0.1),
        0 0 0 1px rgb(3 7 18 / 0.08);
}

.dark .fi-tiptap-link-picker {
    background: var(--gray-900);
    box-shadow:
        0 10px 15px -3px rgb(0 0 0 / 0.3),
        0 4px 6px -4px rgb(0 0 0 / 0.3),
        0 0 0 1px rgb(255 255 255 / 0.1);
}

.fi-tiptap-link-picker-label {
    display: block;
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: rgb(107 114 128);
    margin-bottom: 0.25rem;
}

.dark .fi-tiptap-link-picker-label {
    color: rgb(156 163 175);
}

.fi-tiptap-link-picker-input {
    width: 100%;
    padding: 0.375rem 0.5rem;
    font-size: 0.8125rem;
    color: rgb(17 24 39);
    background: white;
    border: 1px solid rgb(209 213 219);
    border-radius: 0.375rem;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.fi-tiptap-link-picker-input:focus {
    outline: none;
    border-color: var(--primary-500);
    box-shadow: 0 0 0 2px color-mix(in oklab, var(--primary-500) 20%, transparent);
}

.dark .fi-tiptap-link-picker-input {
    color: rgb(243 244 246);
    background: rgb(17 24 39);
    border-color: rgb(75 85 99);
}

.fi-tiptap-link-picker-group {
    margin-top: 0.5rem;
}

.fi-tiptap-link-picker-actions {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 0.375rem;
    margin-top: 0.75rem;
}

.fi-tiptap-link-picker-btn {
    padding: 0.3125rem 0.625rem;
    font-size: 0.75rem;
    font-weight: 500;
    color: rgb(75 85 99);
    background: transparent;
    border: 1px solid transparent;
    border-radius: 0.375rem;
    cursor: pointer;
    transition: all 0.15s ease;
}

.fi-tiptap-link-picker-btn:hover {
    background: rgb(243 244 246);
    color: rgb(17 24 39);
}

.dark .fi-tiptap-link-picker-btn {
    color: rgb(209 213 219);
}

.dark .fi-tiptap-link-picker-btn:hover {
    background: rgb(55 65 81);
    color: rgb(243 244 246);
}

.fi-tiptap-link-picker-btn-primary {
    color: white;
    background: var(--primary-600);
}

.fi-tiptap-link-picker-btn-primary:hover {
    background: var(--primary-700);
    color: white;
}

.fi-tiptap-link-picker-btn-danger {
    color: rgb(185 28 28);
}

.fi-tiptap-link-picker-btn-danger:hover {
    background: rgb(254 226 226);
    color: rgb(153 27 27);
}

.dark .fi-tiptap-link-picker-btn-danger {
    color: rgb(248 113 113);
}

.dark .fi-tiptap-link-picker-btn-danger:hover {
    background: rgb(127 29 29 / 0.3);
    color: rgb(252 165 165);
}

/* Placeholder chips — visual only via ProseMirror decorations */
.fi-placeholder-chip {
    display: inline;
    padding: 1px 6px;
    border-radius: 4px;
    background: var(--primary-50);
    color: var(--primary-700);
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
    font-size: 0.8125rem;
    font-weight: 500;
    border: 1px solid var(--primary-200);
}

.dark .fi-placeholder-chip {
    background: oklch(from var(--primary-500) l c h / 0.15);
    color: var(--primary-300);
    border-color: oklch(from var(--primary-500) l c h / 0.3);
}

/* Autocomplete dropdown */
.fi-placeholder-dropdown {
    position: absolute;
    z-index: 100;
    max-height: 300px;
    overflow-y: auto;
    min-width: 280px;
    border-radius: 0.5rem;
    padding: 0.25rem;
    background: white;
    box-shadow:
        0 10px 15px -3px rgb(0 0 0 / 0.1),
        0 4px 6px -4px rgb(0 0 0 / 0.1),
        0 0 0 1px rgb(3 7 18 / 0.05);
}

.dark .fi-placeholder-dropdown {
    background: var(--gray-900);
    box-shadow:
        0 10px 15px -3px rgb(0 0 0 / 0.1),
        0 4px 6px -4px rgb(0 0 0 / 0.1),
        0 0 0 1px rgb(255 255 255 / 0.1);
}

.fi-placeholder-dropdown-item {
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
    padding: 0.5rem;
    cursor: pointer;
    border-radius: 0.375rem;
    margin: 0.125rem 0;
    transition: background-color 75ms ease-in-out;
}

.fi-placeholder-dropdown-item:hover,
.fi-placeholder-dropdown-item-active {
    background: var(--gray-100);
}

.dark .fi-placeholder-dropdown-item:hover,
.dark .fi-placeholder-dropdown-item-active {
    background: rgb(255 255 255 / 0.1);
}

/* Dropdown item text styles (self-contained — no dependency on autocomplete-textarea.css) */
.fi-placeholder-dropdown .fi-autocomplete-value {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--primary-600);
}

.dark .fi-placeholder-dropdown .fi-autocomplete-value {
    color: var(--primary-400);
}

.fi-placeholder-dropdown .fi-autocomplete-description {
    font-size: 0.75rem;
    color: var(--gray-500);
    line-height: 1.25;
}

.dark .fi-placeholder-dropdown .fi-autocomplete-description {
    color: var(--gray-400);
}

.fi-placeholder-dropdown .fi-autocomplete-highlight {
    background: var(--primary-100);
    color: inherit;
    padding: 0 0.125rem;
    border-radius: 0.125rem;
}

.dark .fi-placeholder-dropdown .fi-autocomplete-highlight {
    background: oklch(from var(--primary-500) l c h / 0.2);
}
