/* Make the filename text match the theme */
.onyx-attach input[type="file"].fileupload{
  font: inherit;
  color: var(--text-light, #b0b0b0);   /* "No file chosen" text */
  background: transparent;
  border: 0;
  max-width: 100%;
}

/* Modern browsers */
.onyx-attach input[type="file"].fileupload::file-selector-button{
  background: var(--button-bg, var(--accent));
  color: var(--button-text, #fff);
  border: 1px solid var(--button-bg, var(--accent));
  border-radius: 10px;
  padding: 8px 12px;
  margin-right: 10px;
  cursor: pointer;
  transition: background-color .18s ease, transform .06s ease, box-shadow .18s ease;
  box-shadow: 0 4px 14px color-mix(in oklab, var(--accent) 25%, transparent);
}
.onyx-attach input[type="file"].fileupload:hover::file-selector-button{
  background: var(--button-hover-bg, var(--accent-soft));
}
.onyx-attach input[type="file"].fileupload:active::file-selector-button{
  transform: translateY(1px);
}
.onyx-attach input[type="file"].fileupload:focus-visible::file-selector-button{
  outline: 2px solid var(--accent-soft);
  outline-offset: 2px;
}

/* Safari / older WebKit */
.onyx-attach input[type="file"].fileupload::-webkit-file-upload-button{
  background: var(--button-bg, var(--accent));
  color: var(--button-text, #fff);
  border: 1px solid var(--button-bg, var(--accent));
  border-radius: 10px;
  padding: 8px 12px;
  margin-right: 10px;
  cursor: pointer;
  transition: background-color .18s ease, transform .06s ease, box-shadow .18s ease;
  box-shadow: 0 4px 14px color-mix(in oklab, var(--accent) 25%, transparent);
}
.onyx-attach input[type="file"].fileupload:hover::-webkit-file-upload-button{
  background: var(--button-hover-bg, var(--accent-soft));
}
.onyx-attach input[type="file"].fileupload:active::-webkit-file-upload-button{
  transform: translateY(1px);
}
.onyx-attach input[type="file"].fileupload:focus-visible::-webkit-file-upload-button{
  outline: 2px solid var(--accent-soft);
  outline-offset: 2px;
}

/* Fix the inline typo and set the card shell */
.onyx-attach {
  display: block; /* fixes `dosplay:block` typo in HTML */
  --bg: var(--secondary-bg, #1f1f1f);
  --card: var(--card-bg, #2a2a2a);
  --border: var(--border-color, #4a4a4a);

  background: var(--bg);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 14px;
  box-shadow: 0 6px 20px var(--shadow);
  padding: 0;
  overflow: hidden;
}


/* Header */
.onyx-attach__head {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  background: var(--card);
  border-bottom: 1px solid var(--border);
}
.onyx-attach__icon { color: var(--accent); display: inline-flex; }
.onyx-attach__title { margin: 0; font-weight: 700; font-size: 1rem; }
.onyx-attach__quota { font-size: .85rem; color: var(--muted); }
.onyx-attach__quota a { color: var(--link-color, #ff5e98); text-decoration: none; }

/* Body layout: line with paperclip, file input, and button */
.onyx-attach img[src*="paperclip"] {
  width: 18px; height: 18px; vertical-align: middle; margin: 14px 10px 0 16px;
  filter: brightness(0) invert(1);
}
.onyx-attach > strong {
  display: inline-block;
  margin-top: 12px;
  font-weight: 600;
}
.onyx-attach .fileupload {
  margin-left: 10px;
  background: var(--input-bg, #2d2d2d);
  color: var(--input-text, #e0e0e0);
  border: 1px solid var(--input-border, #444);
  border-radius: 10px;
  padding: 8px;
}
.onyx-attach .button[name="newattachment"] {
  margin-left: 12px;
  background: var(--button-bg, var(--accent));
  color: var(--button-text, #fff);
  border: 1px solid var(--button-bg, var(--accent));
  border-radius: 10px;
  padding: 8px 12px;
  font-weight: 600;
  cursor: pointer;
  transition: background-color .18s ease, transform .06s ease, box-shadow .18s ease;
  box-shadow: 0 4px 14px color-mix(in oklab, var(--accent) 25%, transparent);
}
.onyx-attach .button[name="newattachment"]:hover {
  background: var(--button-hover-bg, var(--accent-soft));
}
.onyx-attach .button[name="newattachment"]:active { transform: translateY(1px); }

/* Progress bar (override inline style sizes only, keep width value dynamic) */
#upload_bar {
  background: var(--accent) !important;
  height: 6px !important;
  border-radius: 999px;
  margin: 12px 16px 0;
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 20%, transparent);
}

/* Dropzone (override inline with !important) */
#dropzone {
  padding: 18px !important;
  margin: 12px 16px 16px !important;
  border: 1.5px dashed var(--border) !important;
  background: var(--highlight-bg, #2b2b2b) !important;
  text-align: left !important;
  border-radius: 12px !important;
  color: var(--muted) !important;
  display: grid !important;
  grid-template-columns: auto 1fr !important;
  gap: 12px !important;
  align-items: center !important;
  position: relative;
  transition: border-color .18s ease, box-shadow .18s ease, background-color .18s ease;
  cursor: pointer !important;
}

/* Add a decorative upload icon via pseudo */
#dropzone::before {
  content: "";
  width: 28px; height: 28px;
  margin-left: 2px;
  mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M21 15v4a2 2 0 01-2 2H5a2 2 0 01-2-2v-4'/%3E%3Cpath d='M7 10l5-5 5 5M12 15V5'/%3E%3C/svg%3E") center / contain no-repeat;
  background: var(--accent);
  display: inline-block;
}

#dropzone:hover {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 25%, transparent);
  color: var(--text-main) !important;
}

/* Helpful inline text inside dropzone */
#dropzone > div[style*="pointer-events"] {
  pointer-events: none !important;
  color: inherit !important;
  font-size: .95rem !important;
}
#dropzone > div[style*="pointer-events"]::before {
  content: "Drag & drop files here";
  display: block;
  font-weight: 600;
  margin-bottom: 4px;
}
#dropzone > div[style*="pointer-events"]::after {
  content: "or click to browse";
  display: block;
  font-size: .85rem;
  color: var(--muted);
}

/* Mobile tweaks */
@media (max-width: 560px) {
  .onyx-attach__head { grid-template-columns: auto 1fr; }
  .onyx-attach__quota { grid-column: 1 / -1; }
  .onyx-attach img[src*="paperclip"] { margin: 12px 8px 0 16px; }
}




.onyx-newthread {
  --bg: var(--secondary-bg, #1f1f1f);
  --card: var(--card-bg, #2a2a2a);
  --text: var(--text-main, #e0e0e0);
  --muted: var(--text-muted, #828282);
  --accent: #7f56d9; 
  --accent-soft: #9a7fe0; 
  --link-color: #ff5e98;
  
  --border: var(--border-color, #4a4a4a);
  --shadow: var(--shadow-color, rgba(0,0,0,.4));

  background: var(--bg);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 18px;
  box-shadow: 0 6px 20px var(--shadow);
}

.onyx-newthread * { box-sizing: border-box; }

.onyx-newthread__header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 16px;
  margin-bottom: 14px;
  border-bottom: 1px solid var(--border);
  padding-bottom: 10px;
}

.onyx-newthread__title {
  font-size: 1.1rem;
  font-weight: 700;
  letter-spacing: .3px;
}

.onyx-newthread__user {
  margin-left: auto;
  font-size: .9rem;
  color: var(--muted);
}
.onyx-newthread__user a { color: var(--link-color, #ff5e98); text-decoration: none; }

.onyx-newthread__row { margin-bottom: 14px; }
.onyx-newthread__label {
  display: block;
  font-size: .9rem;
  color: var(--muted);
  margin-bottom: 6px;
}

.onyx-newthread__subject-wrap {
  display: grid;
  grid-template-columns: minmax(140px, 220px) 1fr;
  gap: 10px;
}

.onyx-newthread__prefix,
.onyx-newthread__subject,
.onyx-newthread__input,
.onyx-newthread__editor textarea {
  background: var(--input-bg, #2d2d2d);
  color: var(--input-text, #e0e0e0);
  border: 1px solid var(--input-border, #444);
  border-radius: 12px;
  padding: 10px 12px;
  outline: none;
  width: 100%;
}

.onyx-newthread__prefix { cursor: pointer; }
.onyx-newthread__subject::placeholder { color: var(--text-light, #b0b0b0); }

.onyx-newthread__editor {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 8px;
}

/* Options Grid */
.onyx-newthread__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

@media (max-width: 1100px) {
  .onyx-newthread__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .onyx-newthread__subject-wrap { grid-template-columns: 1fr; }
  .onyx-newthread__grid { grid-template-columns: 1fr; }
}

.onyx-newthread__card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 12px;
}

.onyx-newthread__card-head {
  font-weight: 600;
  font-size: .95rem;
  margin-bottom: 8px;
}

/* Switches (pure CSS) */
.onyx-newthread__switch {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 8px;
  padding: 8px 0;
  border-top: 1px dashed var(--border);
}
.onyx-newthread__switch:first-of-type { border-top: 0; }

.onyx-newthread__switch-input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.onyx-newthread__switch-label {
  display: grid;
  gap: 2px;
}
.onyx-newthread__switch-title { font-size: .95rem; }
.onyx-newthread__switch-hint { font-size: .8rem; color: var(--muted); }

/* slider look */
.onyx-newthread__switch-label::after {
  content: "";
  width: 44px; height: 26px;
  background: var(--input-bg, #2d2d2d);
  border: 1px solid var(--input-border, #444);
  border-radius: 999px;
  display: block;
  grid-column: 2;
  justify-self: end;
  position: relative;
}
.onyx-newthread__switch-input:checked + .onyx-newthread__switch-label::after {
  background: var(--accent);
  border-color: var(--accent);
}
.onyx-newthread__switch-label::before {
  content: "";
  position: relative;
  left: 16px; top: 0;
  width: 18px; height: 18px;
  background: var(--text-bright, #fff);
  border-radius: 50%;
  box-shadow: 0 1px 3px var(--shadow);
  display: block;
  transform: translateY(4px);
  transition: transform .15s linear;
}
.onyx-newthread__switch-input:checked + .onyx-newthread__switch-label::before {
  transform: translate(26px, 4px);
}

/* Radios */
.onyx-newthread__radio {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 0;
  border-top: 1px dashed var(--border);
}
.onyx-newthread__radio:first-of-type { border-top: 0; }
.onyx-newthread__radio input[type="radio"] {
  accent-color: var(--accent);
}

/* Inline input row */
.onyx-newthread__inline {
  display: grid;
  grid-template-columns: 1fr 120px;
  gap: 10px;
  margin-top: 10px;
}
.onyx-newthread__inline-label {
  align-self: center;
  color: var(--muted);
}

/* CKEditor dark tweaks to match */
textarea.cke_source { background-color: #222 !important; color: #eee !important; }
.cke_wysiwyg_frame { background-color: #222 !important; }
	</style>
