/* Action Text / Trix Editor - Dark Theme */

/* Editor Container */
trix-editor {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  color: var(--color-text);
  min-height: 200px;
  padding: 12px;
  outline: none;
}

trix-editor:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.15);
}

trix-editor [data-trix-mutable]:not(.attachment__caption-editor) {
  -webkit-user-select: none;
  user-select: none;
}

trix-editor [data-trix-mutable] {
  box-shadow: none !important;
}

trix-editor figure[data-trix-mutable] {
  box-shadow: none !important;
}

trix-editor figure[data-trix-mutable] img {
  box-shadow: 0 0 0 2px var(--color-primary) !important;
}

trix-editor .attachment {
  position: relative !important;
  display: inline-block !important;
  max-width: 100% !important;
}

trix-editor .attachment--preview {
  width: auto !important;
  text-align: left !important;
}

trix-editor .attachment__caption {
  display: none !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}

trix-editor .attachment__caption-editor {
  display: none !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}

trix-editor .attachment__toolbar {
  box-shadow: none !important;
}

trix-editor .attachment__toolbar * {
  box-shadow: none !important;
}

trix-editor .attachment[data-trix-mutable] img {
  box-shadow: 0 0 0 2px var(--color-primary) !important;
}

trix-editor img {
  max-width: 100%;
  height: auto;
}

/* Toolbar */
trix-toolbar {
  background: var(--color-bg-light);
  border: 1px solid var(--color-border);
  border-bottom: none;
  border-radius: var(--radius) var(--radius) 0 0;
  padding: 8px;
}

trix-toolbar + trix-editor {
  border-radius: 0 0 var(--radius) var(--radius);
}

trix-toolbar .trix-button-row {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  
}

trix-toolbar .trix-button-group {
  display: flex;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  overflow: hidden;
  margin-bottom: 4px;
}

trix-toolbar .trix-button-group:not(:first-child) {
  margin-left: 8px;
}

trix-toolbar .trix-button-group-spacer {
  flex-grow: 1;
}

trix-toolbar .trix-button {
  background: var(--color-bg);
  border: none;
  border-right: 1px solid var(--color-border);
  color: var(--color-text-muted);
  padding: 6px 10px;
  cursor: pointer;
  transition: all 0.2s;
  position: relative;
}

trix-toolbar .trix-button:last-child {
  border-right: none;
}

trix-toolbar .trix-button:hover {
  background: var(--color-bg-card);
  color: var(--color-text);
}

trix-toolbar .trix-button.trix-active {
  background: var(--color-primary);
  color: white;
}

trix-toolbar .trix-button:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

/* Icon Buttons */
trix-toolbar .trix-button--icon {
  width: 36px;
  height: 32px;
  padding: 0;
  text-indent: -9999px;
}

trix-toolbar .trix-button--icon::before {
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  opacity: 0.7;
  content: "";
  filter: invert(1);
}

trix-toolbar .trix-button--icon:hover::before {
  opacity: 1;
}

trix-toolbar .trix-button--icon.trix-active::before {
  opacity: 1;
  filter: invert(1);
}

/* Dialogs (Link input, etc.) */
trix-toolbar .trix-dialogs {
  position: relative;
}

trix-toolbar .trix-dialog {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 5;
  background: var(--color-bg-light);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: 12px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

trix-toolbar .trix-dialog__link-fields {
  display: flex;
  align-items: center;
  gap: 8px;
}

trix-toolbar .trix-input--dialog {
  flex: 1;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  color: var(--color-text);
  padding: 8px 12px;
  font-size: 14px;
  outline: none;
}

trix-toolbar .trix-input--dialog:focus {
  border-color: var(--color-primary);
}

trix-toolbar .trix-input--dialog::placeholder {
  color: var(--color-text-muted);
}

trix-toolbar .trix-button--dialog {
  background: var(--color-primary);
  color: white;
  border: none;
  border-radius: var(--radius);
  padding: 8px 16px;
  cursor: pointer;
  font-size: 14px;
  white-space: nowrap;
}

trix-toolbar .trix-button--dialog:hover {
  background: var(--color-primary-dark);
}

trix-toolbar .trix-button--dialog[data-trix-method="removeAttribute"] {
  background: transparent;
  color: var(--color-text-muted);
  border: 1px solid var(--color-border);
}

trix-toolbar .trix-button--dialog[data-trix-method="removeAttribute"]:hover {
  background: var(--color-bg-card);
  color: var(--color-text);
}

/* Attachment Toolbar (appears on images) */
trix-editor .attachment {
  position: relative;
  display: inline-block;
}

trix-editor .attachment__toolbar {
  position: absolute;
  top: 0px;
  right: 3.5px;
  left: auto;
  width: auto;
  transform: none;
  z-index: 10;
  text-align: right;
}

trix-editor .attachment__toolbar .trix-button-group {
  display: inline-flex;
  background: transparent;
  border: none;
  margin: 0;
}

trix-editor .trix-button-group {
  display: inline-flex;
  background: var(--color-bg-light);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  overflow: hidden;
}

trix-editor .trix-button {
  background: var(--color-bg);
  border: none;
  color: var(--color-text-muted);
  padding: 4px 8px;
  cursor: pointer;
  font-size: 12px;
}

trix-editor .trix-button:hover {
  background: var(--color-bg-card);
  color: var(--color-text);
}

trix-editor .trix-button--remove {
  background: rgba(0, 0, 0, 0.7) !important;
  border: none !important;
  border-radius: 50% !important;
  width: 28px !important;
  height: 28px !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  color: white !important;
  text-indent: -9999px !important;
  font-size: 0 !important;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3) !important;
  position: relative !important;
}

trix-editor .trix-button--remove::before {
  content: "×" !important;
  top: 4px;
  position: absolute !important;
  text-indent: 0 !important;
  font-size: 20px !important;
  line-height: 1 !important;
  color: white !important;
  background: none !important;
  opacity: 1 !important;
  filter: none !important;
}

trix-editor .trix-button--remove:hover {
  background: rgba(239, 68, 68, 0.9) !important;
}

/* Caption Editor - Hide it */
trix-editor .attachment__caption-editor {
  display: none !important;
}

trix-editor .attachment__caption {
  display: none !important;
}

/* Attachment Progress */
trix-editor .attachment__progress {
  position: absolute;
  top: 50%;
  left: 10%;
  right: 10%;
  transform: translateY(-50%);
  height: 8px;
  background: var(--color-bg-card);
  border-radius: 4px;
  overflow: hidden;
}

trix-editor .attachment__progress[value] {
  appearance: none;
}

trix-editor .attachment__progress[value]::-webkit-progress-bar {
  background: var(--color-bg-card);
}

trix-editor .attachment__progress[value]::-webkit-progress-value {
  background: var(--color-primary);
}

/* Attachment Metadata */
trix-editor .attachment__metadata {
  display: none;
}

/* Content Display Styles */
.trix-content,
.server-content {
  color: var(--color-text);
  line-height: 1.7;
  font-size: 15px;
}

.trix-content h1,
.server-content h1 {
  font-size: 1.5em;
  font-weight: 700;
  margin: 1em 0 0.5em;
}

.trix-content p,
.server-content p {
  margin: 0.5em 0;
}

.trix-content strong,
.server-content strong {
  font-weight: 700;
}

.trix-content em,
.server-content em {
  font-style: italic;
}

.trix-content a,
.server-content a {
  color: var(--color-primary);
  text-decoration: underline;
}

.trix-content a:hover,
.server-content a:hover {
  color: var(--color-primary-dark);
}

.trix-content blockquote,
.server-content blockquote {
  border-left: 3px solid var(--color-primary);
  margin: 1em 0;
  padding-left: 1em;
  color: var(--color-text-muted);
}

.trix-content pre,
.server-content pre {
  background: var(--color-bg-light) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius);
  padding: 12px;
  overflow-x: auto;
  font-family: monospace;
  font-size: 14px;
  color: var(--color-text) !important;
}

.trix-content pre code,
.server-content pre code {
  background: transparent !important;
  color: var(--color-text) !important;
}

.trix-content ul,
.trix-content ol,
.server-content ul,
.server-content ol {
  margin: 0.5em 0;
  padding-left: 1.5em;
}

.trix-content li,
.server-content li {
  margin: 0.25em 0;
  margin-left: 0;
}

trix-editor ul,
trix-editor ol {
  margin: 0.5em 0;
  padding-left: 2em;
}

trix-editor li {
  margin: 0.25em 0;
  margin-left: 0;
}

/* Code block in editor */
trix-editor pre {
  background: var(--color-bg-light) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius);
  padding: 12px;
  margin: 0.5em 0;
  font-family: monospace;
  font-size: 14px;
  color: var(--color-text) !important;
  overflow-x: auto;
}

/* Links in editor */
trix-editor a {
  color: var(--color-primary) !important;
  text-decoration: underline;
}

.trix-content img,
.server-content img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius);
}

.trix-content figure,
.server-content figure {
  margin: 1em 0;
  text-align: left;
}

.trix-content .attachment,
.server-content .attachment {
  display: inline-block;
  max-width: 100%;
  margin: 0.5em 0;
  text-align: left;
}

.trix-content .attachment--preview,
.server-content .attachment--preview {
  text-align: left;
  width: auto;
}

.trix-content action-text-attachment,
.server-content action-text-attachment {
  display: inline-block !important;
  width: auto !important;
  max-width: 100% !important;
  line-height: 0 !important;
}

.trix-content action-text-attachment figure,
.server-content action-text-attachment figure {
  display: inline-block !important;
  margin: 0 !important;
  width: auto !important;
  line-height: 0 !important;
}

.trix-content action-text-attachment .attachment,
.server-content action-text-attachment .attachment {
  display: inline-block !important;
  width: auto !important;
}

/* File attachments */
.trix-content .attachment--file,
.server-content .attachment--file {
  background: var(--color-bg-light);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: 8px 12px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--color-text);
}

/* Responsive */
@media (max-width: 768px) {
  trix-toolbar .trix-button-group:not(:first-child) {
    margin-left: 4px;
  }
  
  trix-toolbar .trix-button--icon {
    width: 32px;
  }
  
  trix-toolbar .trix-button-group-spacer {
    display: none;
  }
}
