/* ==============================
   1. TOKENS
   ============================== */
/* =====================================================
   COLOR PALETTE — Single source of truth
   =====================================================
   All colors in the app MUST use these variables.
   Never use raw rgba/hex values outside this block.
   ===================================================== */
:root {
  /* ── Accent ─────────────────────────────────────── */
  --accent:                rgba(247, 26, 152, 1);
  --accent-light:          rgba(248, 124, 248, 1);
  --accent-secondary:      rgba(32, 10, 61, 1);
  --accent-secondary-light: rgba(186, 7, 252, 1);
  --accent-50:             rgba(247, 26, 152, 0.5);
  --accent-secondary-50:   rgba(32, 10, 61, 0.5);

  /* ── White ──────────────────────────────────────── */
  --white:    rgba(255, 255, 255, 1);
  --white-10: rgba(255, 255, 255, 0.1);
  --white-50: rgba(255, 255, 255, 0.5);

  /* ── Black ──────────────────────────────────────── */
  --black:    rgba(0, 0, 0, 1);
  --black-10: rgba(0, 0, 0, 0.1);
  --black-50: rgba(0, 0, 0, 0.5);

  /* ── Success (green) ───────────────────────────── */
  --success:    rgba(40, 167, 69, 1);
  --success-50: rgba(40, 167, 69, 0.5);

  /* ── Danger (red) ──────────────────────────────── */
  --danger:    rgba(239, 68, 68, 1);
  --danger-50: rgba(239, 68, 68, 0.5);

  /* ── Info ───────────────────────────────────────── */
  --info:    rgba(126, 244, 245, 1);
  --info-50: rgba(126, 244, 245, 0.5);

  /* ── Warning ────────────────────────────────────── */
  --warning:    rgba(255, 193, 7, 1);
  --warning-50: rgba(255, 193, 7, 0.5);

  /* ── Neutral / Gray ────────────────────────────── */
  --neutral:    rgba(173, 181, 189, 1);

  /* ── Gradients ──────────────────────────────────── */
  --secondary-gradient: linear-gradient(135deg, var(--accent) 0%, var(--accent-secondary-light) 100%);

  /* ── Aliases ───────────────────────────────────── */
  --glass-border: var(--accent-50);
  --focus-ring:   var(--accent-50);

  /* ── Typography ─────────────────────────────────── */
  --font-family-sans: 'Nunito Sans', 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  --font-family-mono: 'Consolas', 'Monaco', monospace;

  /* ── Font sizes ─────────────────────────────────── */
  --font-size-xs:   0.75rem;
  --font-size-sm:   0.85rem;
  --font-size-base: 1rem;
  --font-size-lg:   1.25rem;
  --font-size-2xl:  1.75rem;
  --font-size-3xl:  2rem;
  --font-size-4xl:  2.5rem;

  /* ── Font weights ───────────────────────────────── */
  --font-weight-normal:    400;
  --font-weight-medium:    500;
  --font-weight-semibold:  600;
  --font-weight-bold:      700;
  --font-weight-extrabold: 800;

  /* ── Line heights ───────────────────────────────── */
  --line-height-tight:   1.2;
  --line-height-base:    1.5;

  /* ── Interactive state tokens ──────────────────── */
  --focus-ring-width: var(--border-width-thick);
  --disabled-opacity: 0.5;
  --active-scale:     0.97;
  --transition-fast:   0.15s ease;
  --transition-medium: 0.2s ease;
  --transition-normal: 0.25s ease;
  --transition-slow:   0.3s ease;
  --transition-instant: 0.05s ease;

  /* ── Blur ────────────────────────────────────────── */
  --blur-heavy: blur(20px);
  --blur-light: blur(6px);

  /* ── Spacing ────────────────────────────────────── */
  --space-1:  4px;
  --space-2:  6px;
  --space-3:  8px;
  --space-4:  10px;
  --space-5:  12px;
  --space-6:  14px;
  --space-7:  16px;
  --space-8:  20px;
  --space-9:  24px;
  --space-10: 32px;
  --space-11: 36px;

  /* ── Borders ────────────────────────────────────── */
  --border-width-thin:   1px;
  --border-width-base:   1.5px;
  --border-width-thick:  2px;
  --border-width-xl:     3px;
  --radius-sm:     4px;
  --radius-md:     8px;
  --radius-pill:   22px;
  --radius-circle: 50%;

  /* ── Z-index ─────────────────────────────────────── */
  --z-overlay:  100;
  --z-dropdown: 1000;
  --z-modal:    9999;
  --z-loading:  10000;
}


/* ==============================
   2. RESET / BASE
   ============================== */
* {
  box-sizing: border-box;
  scrollbar-width: thin;
  scrollbar-color: var(--accent) var(--white-10);
}

/* Normalize form elements: inherit font from body, zero border-radius */
button,
select,
input,
textarea {
  font: inherit;
}

button,
select,
input,
textarea,
.form-control,
.form-select,
.form-check-input,
.modal-content,
.toast,
.nav-link {
  border-radius: 0;
}

/* Custom Scrollbar Styles */
::-webkit-scrollbar {
  width: var(--space-3);
  height: var(--space-3);
}

::-webkit-scrollbar-track {
  background: var(--white-10);
}

::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, var(--accent) 0%, var(--accent-secondary) 100%);
  border: var(--border-width-thick) solid transparent;
  background-clip: padding-box;
}

::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, var(--accent-light) 0%, var(--accent-secondary-light) 100%);
  border: var(--border-width-thick) solid transparent;
  background-clip: padding-box;
}

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

body {
  background: url('../background.png') no-repeat center center fixed;
  background-size: cover;
  min-height: 100vh;
  font-family: var(--font-family-sans);
  color: var(--white);
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(var(--fade-from, 10px));
  }

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

@keyframes bounce {
  0%,
  80%,
  100% {
    transform: scale(0);
  }

  40% {
    transform: scale(1);
  }
}

@keyframes pulse {
  0%,
  100% {
    opacity: 1;
  }

  50% {
    opacity: 0.5;
  }
}

@keyframes spin {
  from {
    transform: rotate(0deg);
  }

  to {
    transform: rotate(360deg);
  }
}



/* ==============================
   3. COMPONENT STRUCTURE
   (Layout rules for modal, tab, collapse, form, toast, alert.
    Visual overrides live in the Molecules/Organisms layers.)
   ============================== */

/* ─── Modal ─── */
.modal { display: none; position: fixed; inset: 0; z-index: var(--z-modal); overflow-y: auto; }
.modal.show { display: block; }
.modal-backdrop { position: fixed; inset: 0; z-index: calc(var(--z-modal) - 1); background: var(--black-50); }
.modal-dialog { position: relative; margin: 1.75rem auto; max-width: 500px; }
.modal-lg { max-width: 800px; }
.modal-fullscreen { max-width: 100%; margin: 0; height: 100%; }
.modal-fullscreen .modal-content { height: 100%; border: 0; overflow: hidden; }
.modal-fullscreen .modal-body { overflow-y: auto; }
.modal-dialog-scrollable .modal-content { max-height: calc(100vh - 3.5rem); overflow: hidden; }
.modal-dialog-scrollable .modal-body { overflow-y: auto; }
.modal-dialog-centered { display: flex; align-items: center; min-height: 100%; }
.modal-content { position: relative; display: flex; flex-direction: column; width: 100%; }
.modal-header { display: flex; align-items: center; justify-content: space-between; padding: var(--space-4) var(--space-7); }
.modal-body { flex: 1 1 auto; padding: var(--space-4) var(--space-7) var(--space-7); }
.modal-footer { display: flex; align-items: center; justify-content: flex-end; padding: var(--space-5) var(--space-7); gap: var(--space-3); }

/* ─── Nav / Tabs ─── */
.nav { display: flex; flex-wrap: wrap; padding-left: 0; margin: 0; list-style: none; }
.nav-item { list-style: none; }
.tab-content > .tab-pane { display: none; }
.tab-content > .tab-pane.show.active { display: block; }

/* ─── hr ─── */
hr { margin: var(--space-7) 0; border: 0; border-top: var(--border-width-thin) solid var(--accent-secondary-50); opacity: 0.5; }

/* ─── Collapse ─── */
.collapse:not(.show) { display: none; }

/* ─── Forms ─── */
.form-label { display: inline-block; margin-bottom: var(--space-2); }
.form-check { display: flex; align-items: center; gap: var(--space-3); }
.form-check-input { width: 1em; height: 1em; margin: 0; cursor: pointer; appearance: none; -webkit-appearance: none; }
.form-switch { position: relative; }
.form-switch .form-check-input {
  width: 2em; height: 1.1em;
  background: var(--white-10); border: var(--border-width-thin) solid var(--glass-border);
  border-radius: 1em; cursor: pointer; transition: background var(--transition-fast);
}
.form-switch .form-check-input::before {
  content: ''; position: absolute; top: 2px; left: 2px;
  width: calc(1.1em - 6px); height: calc(1.1em - 6px);
  background: var(--white); border-radius: var(--radius-circle); transition: transform var(--transition-fast);
}
.form-switch .form-check-input:checked { background: var(--accent); border-color: var(--accent); }
.form-switch .form-check-input:checked::before { transform: translateX(0.9em); }
.form-check-label { cursor: pointer; }
.input-group { display: flex; width: 100%; }
.input-group > .form-control { flex: 1 1 auto; min-width: 0; }

/* ─── btn-close ─── */
.btn-close {
  display: inline-flex; align-items: center; justify-content: center;
  width: 1em; height: 1em; padding: 0.25em; border: 0; cursor: pointer; opacity: 0.5;
  background: transparent url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath d='M.293.293a1 1 0 0 1 1.414 0L8 6.586 14.293.293a1 1 0 1 1 1.414 1.414L9.414 8l6.293 6.293a1 1 0 0 1-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 0 1-1.414-1.414L6.586 8 .293 1.707a1 1 0 0 1 0-1.414z'/%3e%3c/svg%3e") center/1em auto no-repeat;
  filter: invert(1);
}
.btn-close:hover { opacity: 0.75; }
.btn-close-white { filter: invert(1) grayscale(100%) brightness(200%); }

/* ─── Toast ─── */
.toast { display: flex; align-items: center; padding: var(--space-5) var(--space-7); max-width: 350px; }
.toast-body { flex: 1; }

/* ─── Alert ─── */
.alert { padding: var(--space-5) var(--space-7); margin-bottom: var(--space-7); border: var(--border-width-thin) solid transparent; }
.alert-info { background: rgba(126, 244, 245, 0.1); color: var(--info); border-color: var(--info-50); }
.alert-warning { background: rgba(255, 193, 7, 0.1); color: var(--warning); border-color: var(--warning-50); }


/* ==============================
   4. ATOMS
   ============================== */
/* ─── DEFAULT BUTTON ─── */
button:not(.btn-close):not(.emoji-picker-button):not(.toggle-btn):not(.uploaded-media-section-header):not(.image-fullview-close):not(.circle-btn):not(.nav-link),
input[type='button'],
input[type='submit'] {
  --ch: 14px;
  background: transparent;
  border: none !important;
  color: var(--white);
  padding: var(--space-3) var(--space-7);
  width: fit-content;
  white-space: nowrap;
  position: relative;
}

button:not(.btn-close):not(.emoji-picker-button):not(.toggle-btn):not(.uploaded-media-section-header):not(.image-fullview-close):not(.circle-btn):not(.nav-link)::before,
input[type='button']::before,
input[type='submit']::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  --bw: var(--border-width-base);
  --ch: 14px;
  --c: var(--accent-50);
  transition: all var(--transition-fast);
  background:
    linear-gradient(var(--c), var(--c)) top / 100% var(--bw) no-repeat,
    linear-gradient(var(--c), var(--c)) right / var(--bw) 100% no-repeat,
    linear-gradient(var(--c), var(--c)) right bottom / calc(100% - var(--ch)) var(--bw) no-repeat,
    linear-gradient(var(--c), var(--c)) left top / var(--bw) calc(100% - var(--ch)) no-repeat,
    linear-gradient(45deg, transparent calc(50% - var(--bw) * 0.707), var(--c) calc(50% - var(--bw) * 0.707), var(--c) calc(50% + var(--bw) * 0.707), transparent calc(50% + var(--bw) * 0.707)) left bottom / var(--ch) var(--ch) no-repeat;
}

/* Default button hover: border brightens */
button:not(.btn-close):not(.emoji-picker-button):not(.toggle-btn):not(.uploaded-media-section-header):not(.image-fullview-close):not(.circle-btn):not(.nav-link):hover::before {
  --c: var(--accent);
}


/* ─── DEFAULT BUTTON: FILLED VARIANTS ─── */
/* Shared structure for btn-light, btn-save, btn-reset, and .selected.
   Each variant only sets --btn-bg, --btn-bg-hover, --btn-color, --btn-color-hover. */
.btn-light,
.btn-save,
.btn-reset,
button.selected:not(.btn-close):not(.circle-btn):not(.nav-link):not(.btn-light) {
  --ch: 14px;
  background: var(--btn-bg) !important;
  color: var(--btn-color) !important;
  clip-path: polygon(0 0, 100% 0, 100% 100%, var(--ch) 100%, 0 calc(100% - var(--ch)));
}

.btn-light:hover,
.btn-save:hover,
.btn-reset:hover,
button.selected:not(.btn-close):not(.circle-btn):not(.nav-link):not(.btn-light):hover {
  background: var(--btn-bg-hover) !important;
  color: var(--btn-color-hover) !important;
}

.btn-light::before,
.btn-save::before,
.btn-reset::before,
button.selected:not(.btn-close):not(.circle-btn):not(.nav-link):not(.btn-light)::before {
  background: none;
}

/* Light: semi-transparent accent, dark text → solid accent on hover */
.btn-light,
button.selected:not(.btn-close):not(.circle-btn):not(.nav-link):not(.btn-light) {
  --btn-bg: var(--accent-50);
  --btn-bg-hover: var(--accent);
  --btn-color: var(--black);
  --btn-color-hover: var(--white);
}

/* Save: solid accent, white text → lighter accent on hover */
.btn-save {
  --btn-bg: var(--accent);
  --btn-bg-hover: var(--accent-light);
  --btn-color: var(--white);
  --btn-color-hover: var(--white);
}

/* Reset: semi-transparent danger, white text → solid danger on hover */
.btn-reset {
  --btn-bg: var(--danger-50);
  --btn-bg-hover: var(--danger);
  --btn-color: var(--white);
  --btn-color-hover: var(--white);
}


/* ─── CIRCLE BUTTON (.circle-btn) ─── */
.circle-btn {
  background: var(--accent-50) !important;
  border: var(--border-width-base) solid var(--accent) !important;
  border-radius: var(--radius-circle) !important;
  color: var(--accent-secondary) !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--space-11);
  height: var(--space-11);
  min-width: var(--space-11);
  min-height: var(--space-11);
  padding: 0 !important;
  font-size: var(--font-size-sm);
  transition: background var(--transition-fast), box-shadow var(--transition-fast), color var(--transition-fast);
}

.circle-btn::before {
  display: none !important;
}

.circle-btn:hover {
  background: var(--accent) !important;
  box-shadow: 0 0 14px var(--accent-50);
  color: var(--white) !important;
}

.circle-btn i {
  transition: transform var(--transition-fast);
}

.circle-btn:hover i {
  transform: scale(1.25);
}

/* ─── CIRCLE BUTTON: EXPANDED (.circle-btn.circle-expanded) ─── */
/* Circle button that stretches to a pill/rectangle. Inherits all circle-btn
   appearance (bg, border, color, hover, icon grow). Adds width + text support. */
.circle-btn.circle-expanded {
  width: auto !important;
  min-width: 0 !important;
  flex: 1 !important;
  border-radius: var(--radius-pill) !important;
  padding: 0 var(--space-7) !important;
  gap: var(--space-3);
  font-size: var(--font-size-sm);
  white-space: nowrap;
  display: flex !important;
}

/* ─── TAB ─── */
/* Base tab pattern — shared by all tab-like elements */
.nav-tabs .nav-link,
.cc-collapsible-toggle {
  background: transparent;
  border: none;
  color: var(--white-50);
  font-size: var(--font-size-sm);
  padding: var(--space-3) var(--space-7);
  cursor: pointer;
  transition: all var(--transition-medium);
}

.nav-tabs .nav-link:hover,
.cc-collapsible-toggle:hover {
  color: var(--white);
  background: var(--accent-secondary-50);
}

.nav-tabs .nav-link.active {
  color: var(--white);
  background: var(--accent-secondary-50);
  border: none;
  border-bottom: var(--border-width-thick) solid var(--accent);
}

.cc-collapsible-toggle:active {
  color: var(--accent);
}

.nav-tabs {
  border-bottom: var(--border-width-thin) solid var(--accent-secondary-50);
}

/* ─── FORM SELECT ─── */
.form-select {
  display: block;
  width: 100%;
  background: var(--accent-secondary-50);
  border: var(--border-width-thin) solid var(--accent-50);
  color: var(--white);
  font-size: var(--font-size-base);
  line-height: var(--line-height-base);
  cursor: pointer;
  padding: var(--space-3) var(--space-5);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.form-select:hover {
  border-color: var(--accent);
}

.form-select:focus {
  background: var(--white);
  border-color: var(--accent);
  box-shadow: 0 0 10px var(--accent-50);
  color: var(--black);
  outline: none;
}

.form-select option {
  background: var(--accent-secondary);
  color: var(--white);
}

.form-select:disabled {
  opacity: var(--disabled-opacity);
  cursor: not-allowed;
}

/* ----- SHARED STATES (all categories) ----- */
/* Remove focus styles for mouse/touch, keep them for keyboard (focus-visible) */
button:focus:not(:focus-visible) {
  box-shadow: none !important;
  outline: none !important;
}

button:disabled {
  opacity: var(--disabled-opacity);
  filter: none;
  cursor: not-allowed;
}

button:active:not(:disabled) {
  transform: scale(var(--active-scale)) !important;
  filter: brightness(1.1) !important;
  transition: transform var(--transition-instant), filter var(--transition-instant);
}

/* Utility-button sizing: all modal body/header buttons are compact,
   except primary action buttons (generate, refine) and navigation controls */


/* Keyboard focus ring — visible only for keyboard users */
button:focus-visible,
a:focus-visible,
select:focus-visible,
textarea:focus-visible,
input:focus-visible {
  outline: var(--focus-ring-width) solid var(--focus-ring) !important;
  outline-offset: 2px !important;
  box-shadow: none !important;
}

/* form-select: inherits TAB. */
/* form-control: base styles for text inputs/textareas */
.form-control {
  display: block;
  width: 100%;
  background: var(--accent-secondary-50);
  border: var(--border-width-thin) solid var(--accent-50);
  color: var(--white);
  font-size: var(--font-size-base);
  line-height: var(--line-height-base);
  padding: var(--space-4) var(--space-7);
}

/* Collapsible toggle: sizing only (appearance from TAB) */
.cc-collapsible-toggle {
  font-size: var(--font-size-sm);
  padding: var(--space-1) 0;
}

/* btn-emulator: circle-btn, inherits CIRCLE BUTTON */
.btn-emulator {
  font-size: var(--font-size-base);
}

/* uploaded-media-tabs: inherits TAB. Sizing only. */
.uploaded-media-tabs .nav-link {
  font-size: var(--font-size-xs);
  padding: var(--space-3) var(--space-5);
}

/* auth tabs: inherits from TAB. Sizing only. */
.auth-tabs .nav-link {
  flex: 1;
  padding: var(--space-5);
  text-align: center;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
}

/* analytics-subtabs: inherits TAB. Sizing only. */
.analytics-subtabs .nav-link {
  font-size: var(--font-size-xs);
  padding: var(--space-2) var(--space-7);
}

.form-control:focus {
  background: var(--white);
  border-color: var(--accent);
  box-shadow: 0 0 0 0.2rem var(--accent-secondary-50);
  color: var(--black);
  caret-color: var(--black);
}

.form-control::placeholder {
  color: var(--white-50) !important;
}

.form-control:read-only,
.cc-textarea:read-only {
  opacity: 0.6;
  cursor: not-allowed;
  background: var(--black-10);
  border-color: var(--accent-secondary-50);
}

.form-control:read-only:focus,
.cc-textarea:read-only:focus {
  box-shadow: none;
  border-color: var(--accent-secondary-50);
}

/* Step flow system */
.cc-step-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: var(--radius-circle);
  background: var(--accent-secondary-50);
  color: var(--white);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  margin-right: var(--space-3);
  transition: background var(--transition-normal), box-shadow var(--transition-normal);
}

.cc-step-active .cc-step-badge {
  background: var(--accent);
  box-shadow: 0 0 12px var(--accent-50);
}

.cc-step-active,
.cc-step-done {
  padding-left: var(--space-5);
  transition: border-color var(--transition-normal),
              opacity var(--transition-normal),
              filter var(--transition-normal);
}

.cc-step-active {
  border-left: var(--border-width-xl) solid var(--accent) !important;
}

.cc-step-locked {
  opacity: 0.35;
  pointer-events: none;
  filter: grayscale(30%);
  transition: opacity var(--transition-normal), filter var(--transition-normal);
}

.cc-step-locked .cc-section-header {
  color: var(--white-50);
}

.cc-step-done .cc-step-badge {
  background: var(--success);
}

.cc-step-done {
  border-left: var(--border-width-xl) solid var(--success) !important;
}

/* Status indicator */
.status-indicator {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--black-50);
  font-size: var(--font-size-xs);
  margin-top: 0;
  white-space: nowrap;
}

.status-dot {
  width: var(--space-3);
  height: var(--space-3);
  border-radius: var(--radius-circle);
  background: var(--success);
}

.status-dot.offline {
  background: var(--danger);
}

.status-dot.connecting {
  background: var(--info);
  animation: pulse 1s infinite;
}

/* Indicator dots (positioned on parent containers) */
.indicator-dot {
  position: absolute;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: var(--radius-circle);
}

.config-changed-dot {
  top: -3px;
  right: -3px;
  background: var(--warning);
}

.draft-delta-dot {
  top: -3px;
  left: -3px;
  background: var(--accent);
}

.indicator-dot.inline {
  position: static;
  display: inline-block;
  vertical-align: middle;
  margin-left: var(--space-2);
}

/* Hidden elements based on role */
.role-hidden {
  display: none !important;
}

.pulse {
  animation: pulse 1s ease-in-out infinite;
}


/* ==============================
   5. MOLECULES
   ============================== */
.header-controls-col .controls-row-status {
  max-width: 100%;
  flex-direction: column;
  align-items: flex-end;
  gap: clamp(2px, 0.5%, 6px);
}

.controls-row {
  display: flex;
  gap: var(--space-7);
  flex-wrap: wrap;
  align-items: center;
}

.controls-row-status {
  flex-wrap: nowrap;
  gap: var(--space-4);
}


/* Section blocks */
.cc-section {
  margin-bottom: 2rem;
  padding-bottom: 1.5rem;
  border-bottom: var(--border-width-thin) solid var(--accent-secondary-50);
}

.cc-section:last-child {
  border-bottom: none;
}

.cc-section-header {
  color: var(--white);
  margin-bottom: 1rem;
  padding-bottom: 0.5rem;
  border-bottom: var(--border-width-thin) solid var(--accent-secondary-50);
}

.cc-sub-header {
  color: var(--white-50);
  margin-bottom: 0.75rem;
  padding-bottom: 0.4rem;
  border-bottom: var(--border-width-thin) solid var(--accent-secondary-50);
}

.cc-collapse-icon {
  transition: transform var(--transition-medium);
  font-size: var(--font-size-xs);
  margin-right: var(--space-1);
}

.cc-collapsible-toggle[aria-expanded='true'] .cc-collapse-icon {
  transform: rotate(90deg);
}


/* Output areas */
.cc-output-area {
  border: var(--border-width-thin) solid var(--accent-secondary-50);
  border-radius: var(--radius-sm);
  padding: 1rem;
}


/* Validate button: green hint on hover, green glow when validated */
.cc-validate-btn {
  transition: color var(--transition-fast), border-color var(--transition-fast);
}

.cc-validate-btn:hover:not(.cc-validated) {
  color: var(--success-50);
  border-color: var(--success-50);
}

/* Media outputs */
.cc-output-img {
  max-width: 100%;
  max-height: 300px;
  border: var(--border-width-thin) solid var(--accent-secondary-50);
}

/* Create content: validated state — green text with subtle glow */
.cc-validate-btn.cc-validated,
.cc-validate-btn.cc-validated:hover {
  color: var(--success) !important;
  border-color: var(--success) !important;
}

/* Style gallery in Create Content */

/* Generated images library in Create Content */
.cc-generated-library {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: var(--space-3);
}

.cc-library-item {
  position: relative;
  overflow: hidden;
  cursor: pointer;
  border: var(--border-width-thick) solid transparent;
  transition: all var(--transition-medium);
  aspect-ratio: 9 / 16;
  border-radius: var(--radius-sm);
}

.cc-library-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.cc-library-audio-preview {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  background: var(--bg-surface);
  color: var(--text-secondary);
}

.cc-library-audio-preview i {
  font-size: 1.5rem;
  opacity: 0.7;
}

.cc-library-audio-preview audio {
  width: 90%;
  max-width: 100%;
  height: 28px;
}

.cc-library-item:hover {
  border-color: var(--accent-50);
}

.cc-library-item.selected,
.cc-library-item.in-use {
  border-color: var(--accent);
  box-shadow: 0 0 0 var(--focus-ring-width) var(--focus-ring);
}

.cc-library-item:active {
  transform: scale(var(--active-scale));
}

.cc-library-item-actions {
  position: absolute;
  top: 0;
  right: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: var(--space-1);
  opacity: 0;
  transition: opacity var(--transition-medium);
}

.cc-library-item:hover .cc-library-item-actions {
  opacity: 1;
}

/* On selected items: show actions but only the select button visible */
.cc-library-item.selected .cc-library-item-actions,
.cc-library-item.in-use .cc-library-item-actions {
  opacity: 1;
}

.cc-library-item.selected .cc-library-item-actions button:not(.cc-library-select-btn),
.cc-library-item.in-use .cc-library-item-actions button:not(.cc-library-select-btn) {
  opacity: 0;
  pointer-events: none;
}

/* On hover of selected item, show all buttons again */
.cc-library-item.selected:hover .cc-library-item-actions button,
.cc-library-item.in-use:hover .cc-library-item-actions button {
  opacity: 1;
  pointer-events: auto;
}


/* List display mode for renderMediaGallery (voices, etc.) */
.cc-library-list-mode {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.cc-library-list-item {
  aspect-ratio: unset;
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
}

.cc-library-list-item .cc-library-item-info {
  flex: 1;
  display: flex;
  align-items: center;
  gap: var(--space-2);
  overflow: hidden;
  color: var(--neutral);
  font-size: var(--font-size-sm);
}

.cc-library-list-item .cc-library-item-name {
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
}

.cc-library-list-item .cc-library-item-actions {
  position: static;
  opacity: 1;
  flex-direction: row;
  padding: 0;
}

/* Archived items */
.cc-library-item.archived {
  opacity: 0.4;
}

.mobile-emulator .message-bubble {
  padding: var(--space-3) var(--space-5);
  font-size: var(--font-size-sm);
  line-height: var(--line-height-base);
}

.mobile-emulator .message-avatar {
  width: 28px;
  height: 28px;
  min-width: 28px;
  margin-right: var(--space-2);
  font-size: var(--font-size-xs);
}

.mobile-emulator .message-avatar-spacer {
  width: 28px;
  min-width: 28px;
  margin-right: var(--space-2);
}

.mobile-emulator .message-timestamp {
  font-size: var(--font-size-xs);
}

/* Message labels (shared base) */
.message-topic-label,
.message-thinking-label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  background: var(--accent-secondary-50);
  color: var(--accent-secondary);
  padding: 2px var(--space-3);
  font-size: var(--font-size-xs);
  margin-top: var(--space-2);
}

.message-topic-label i,
.message-thinking-label i {
  font-size: var(--font-size-xs);
}

.message-thinking-label {
  color: var(--info);
  margin-left: var(--space-2);
}

.message {
  display: flex;
  margin-bottom: var(--space-3);
  animation: fadeIn var(--transition-slow);
  align-items: flex-start;
}

.message.user {
  justify-content: flex-end;
}

.message.ai {
  justify-content: flex-start;
}

/* Content wrapper holds timestamp + bubble */
.message-content-wrapper {
  display: flex;
  flex-direction: column;
  max-width: 70%;
  position: relative;
}

.message.user .message-content-wrapper {
  align-items: flex-end;
}

.message.ai .message-content-wrapper {
  align-items: flex-start;
}

/* Timestamp */
.message-timestamp {
  font-size: var(--font-size-xs);
  color: var(--black);
  margin-bottom: 3px;
  padding: 0 var(--space-1);
  user-select: none;
}

.message.user .message-timestamp {
  text-align: right;
}

.message-bubble {
  padding: 12px 18px;
  border-radius: var(--radius-md);
  word-wrap: break-word;
  line-height: var(--line-height-base);
  background: var(--white);
  color: var(--black);
}

.message.user .message-bubble {
  border-bottom-right-radius: 0;
}

.message.ai .message-bubble {
  border-top-left-radius: 0;
}

/* Avatar: only shown on first AI message of a response */
.message-avatar {
  width: 36px;
  height: 36px;
  min-width: 36px;
  border-radius: var(--radius-circle);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: var(--space-3);
  font-size: var(--font-size-base);
  background: var(--secondary-gradient);
  color: var(--white);
  overflow: hidden;
}

.message-avatar-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Spacer keeps alignment when avatar is not shown */
.message-avatar-spacer {
  width: 36px;
  min-width: 36px;
  margin-right: var(--space-3);
}

.typing-indicator {
  display: flex;
  align-items: center;
  gap: 5px;
}

.typing-indicator span {
  width: 8px;
  height: 8px;
  background: var(--accent);
  border-radius: var(--radius-circle);
  animation: bounce 1.4s infinite ease-in-out both;
}

.typing-indicator span:nth-child(1) {
  animation-delay: -0.32s;
}

.typing-indicator span:nth-child(2) {
  animation-delay: -0.16s;
}

.typing-indicator span:nth-child(3) {
  animation-delay: 0;
}

/* System message styles */
.message.system-message {
  justify-content: center;
  margin: var(--space-8) 0;
}

.system-message-content {
  background: var(--accent-secondary-50);
  border: var(--border-width-thin) solid var(--accent-secondary-50);
  padding: var(--space-5) var(--space-9);
  display: flex;
  align-items: center;
  gap: var(--space-4);
  color: var(--black);
  font-size: var(--font-size-base);
  text-align: center;
}

.system-message-content i {
  color: var(--accent);
  font-size: var(--font-size-lg);
}

.uploaded-media-message .message-bubble {
  padding: var(--space-3);
}

/* Voice Message in Chat */
.message.voice-message .message-bubble {
  position: relative;
}

.message-bubble.voice-streaming {
  background: var(--accent-secondary-50);
  border: var(--border-width-thin) solid var(--accent-50);
}

.message-bubble.voice-final {
  background: var(--accent-secondary-50);
}

/* Responsive table */
@media (max-width: 768px) {
  .btn-emulator {
    display: none !important;
  }

  .chat-container {
    padding: var(--space-4);
  }

  .chat-header {
    padding: var(--space-7);
  }

  .chat-title {
    font-size: var(--font-size-lg);
  }


  .message-content-wrapper {
    max-width: 85%;
  }

  .chat-body-wrapper {
    padding: 6px;
  }

  .message-avatar {
    width: 30px;
    height: 30px;
    min-width: 30px;
    font-size: var(--font-size-sm);
  }

  .message-avatar-spacer {
    width: 30px;
    min-width: 30px;
  }

  .analytics-table-container {
    overflow-x: auto;
  }

  .analytics-table {
    min-width: 700px;
  }

  .analytics-table th,
  .analytics-table td {
    padding: 8px 6px;
    font-size: var(--font-size-xs);
  }
}

.chat-list-body {
  flex: 1;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

/* Chat messages scrollbar */
.chat-messages::-webkit-scrollbar { width: var(--space-3); }
.chat-messages::-webkit-scrollbar-track { background: var(--white-10); }
.chat-messages::-webkit-scrollbar-thumb { background: var(--white-10); }
.chat-messages::-webkit-scrollbar-thumb:hover { background: var(--white-50); }

/* ── Publish preview panel ────────────────────── */
.publish-preview-panel {
  border: var(--border-width-thin) solid var(--accent-50);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-5);
  overflow: hidden;
}

.publish-preview-header {
  background: var(--accent-secondary-50);
  padding: var(--space-4) var(--space-5);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  color: var(--white);
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-sm);
}

.publish-preview-close {
  margin-left: auto;
  background: transparent;
  border: none;
  color: var(--white-50);
  cursor: pointer;
  padding: var(--space-1);
}

.publish-preview-close:hover {
  color: var(--white);
}

.publish-preview-body {
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  max-height: 400px;
  overflow-y: auto;
}

.publish-preview-section-title {
  color: var(--info);
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-sm);
  margin-bottom: var(--space-3);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.publish-preview-section-title--warning {
  color: var(--warning);
}

.publish-preview-change-item {
  background: var(--accent-secondary-50);
  border-radius: var(--radius-sm);
  padding: var(--space-2) var(--space-4);
  margin-bottom: var(--space-2);
  font-size: var(--font-size-xs);
  color: var(--white);
}

.publish-preview-no-changes {
  text-align: center;
  padding: var(--space-5);
  color: var(--success);
  font-size: var(--font-size-sm);
}

.publish-preview-footer {
  padding: var(--space-4) var(--space-5);
  display: flex;
  justify-content: flex-end;
  gap: var(--space-3);
  border-top: var(--border-width-thin) solid var(--white-10);
}

.publish-conflict-item .conflict-choice-group {
  display: flex;
  gap: var(--space-5);
  margin-top: var(--space-3);
}

.publish-conflict-item .conflict-choice-group label {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-xs);
  color: var(--white-50);
  cursor: pointer;
}

.publish-conflict-item .conflict-choice-group input[type="radio"] {
  accent-color: var(--accent);
}

/* ── Sync conflict banner ─────────────────────── */
.sync-conflict-banner {
  border: var(--border-width-thin) solid var(--warning-50);
  border-left: var(--border-width-xl) solid var(--warning);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  margin-bottom: var(--space-5);
}

.sync-conflict-header {
  color: var(--warning);
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-sm);
  margin-bottom: var(--space-4);
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.sync-conflict-item {
  background: var(--accent-secondary-50);
  border-radius: var(--radius-sm);
  padding: var(--space-4);
  margin-bottom: var(--space-3);
}

.sync-conflict-item:last-child {
  margin-bottom: 0;
}

.sync-conflict-field-name {
  color: var(--white);
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-sm);
  margin-bottom: var(--space-3);
}

.sync-conflict-values {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
}

.sync-conflict-value-label {
  font-size: var(--font-size-xs);
  color: var(--white-50);
  text-transform: uppercase;
  margin-bottom: var(--space-1);
}

.sync-conflict-value-preview {
  background: var(--black-10);
  padding: var(--space-3);
  border-radius: var(--radius-sm);
  max-height: 200px;
  overflow-y: auto;
  font-family: var(--font-family-mono);
  font-size: var(--font-size-xs);
  color: var(--white);
  white-space: pre-wrap;
  word-break: break-word;
}

.sync-conflict-actions {
  display: flex;
  gap: var(--space-3);
  justify-content: flex-end;
}

/* Merge preview thumbnails (publish/sync conflict image display) */
.merge-preview-thumb {
  width: 40px;
  height: 40px;
  object-fit: cover;
  border-radius: var(--radius-sm);
  margin: 2px;
}

.merge-preview-images {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 2px;
}

.merge-preview-topic {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.merge-preview-more {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
  margin-left: var(--space-2);
}


.sync-conflict-actions .conflict-btn-mine {
  color: var(--info);
}

.sync-conflict-actions .conflict-btn-mine:hover {
  color: var(--white);
}

.sync-conflict-actions .conflict-btn-theirs {
  color: var(--warning);
}

.sync-conflict-actions .conflict-btn-theirs:hover {
  color: var(--white);
}

/* ==============================
   6. ORGANISMS
   ============================== */
/* Row 1: Title left, Auth right */
.header-top-row {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: clamp(4px, 1%, 8px);
}

/* Rows 2 and 3: same 50/50 grid */
.header-bottom-row,
.header-actions-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(6px, 2%, 12px);
  margin-top: clamp(4px, 1%, 8px);
  align-items: center;
}

/* Row 2, Col 1: character image */
.header-char-col {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

#character-panel {
  display: block;
}

#character-display {
  display: block;
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  object-position: top center;
  border: var(--border-width-xl) solid var(--accent);
  box-shadow:
    0 25px 50px -12px var(--black-50),
    0 0 30px var(--accent-secondary-50);
}

/* Blocking overlay for tab panes during async operations */
.tab-blocking-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: var(--black-50);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: var(--z-overlay);
  border-radius: inherit;
}

.tab-blocking-overlay-content {
  color: var(--white-50);
  font-size: var(--font-size-base);
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

/* Row 2, Col 2: status controls */
.header-controls-col {
  display: flex;
  flex-direction: column;
  gap: 0;
  align-items: flex-end;
  min-width: 0;
}

/* Row 3: button groups capped at image width, container-query scaling */
.header-actions-left,
.header-actions-right {
  display: flex;
  align-items: center;
  justify-content: center;
  justify-self: end;
  min-width: 0;
  max-width: 100%;
  width: 100%;
  container-type: inline-size;
  gap: 2cqw;
}

.header-actions-right .circle-btn {
  flex-shrink: 0;
}

.header-actions-left .form-select {
  flex: 1;
  min-width: 0;
}

.header-actions-right .btn-clear-chat {
  flex: 1;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.header-actions-left {
  justify-self: start;
}

.chat-header {
  background: transparent;
  padding: var(--space-4) var(--space-7);
  margin-bottom: var(--space-7);
  border: var(--border-width-xl) solid var(--accent);
  backdrop-filter: var(--blur-heavy);
  box-shadow:
    0 25px 50px -12px var(--black-50),
    0 0 30px var(--accent-secondary-50);
  position: relative;
  overflow: visible;
}

/* Circle buttons in chat-header — sizing only (appearance from Category 2) */
.chat-header .circle-btn {
  flex-shrink: 0;
}

.chat-title {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  text-align: left;
  margin: 0;
  color: var(--black);
  -webkit-text-fill-color: var(--black);
}


.chat-title .collapse-icon {
  font-size: 0.8em;
  transition: transform var(--transition-slow);
}

.chat-title .collapse-icon.collapsed {
  transform: rotate(-90deg);
}

/* btn-settings: circle-btn, inherits Category 2 */
.btn-settings {
  font-size: var(--font-size-sm);
}

/* Clear Chat & Create Content — default buttons (layout only) */
.btn-clear-chat,
.btn-create-content {
  min-width: 0;
  max-width: 100%;
}

.mobile-emulator .chat-header {
  padding: 6px 10px;
  margin-bottom: var(--space-3);
}

.mobile-emulator .header-controls-col .header-actions-left {
  flex-direction: row-reverse;
  container-type: normal;
  gap: var(--space-2);
}

.mobile-emulator .header-controls-col .header-actions-right {
  max-width: none;
  width: auto;
  justify-content: flex-end;
  container-type: normal;
  gap: var(--space-2);
}

/* circle-btn sizing in mobile emulator — see OVERRIDES section */


.mobile-emulator .header-controls-col .btn-clear-chat {
  flex: 0 1 auto;
}

/* Create Content Modal - fullscreen */
#createContentModal .modal-content {
  height: 100vh;
}

/* Video preview — constrain size (9:16 content) */
#ccVideoPreview video {
  max-width: 200px;
  max-height: 350px;
  display: block;
  margin: 0 auto;
}

.chat-container {
  max-width: 800px;
  margin: 0 auto;
  height: 100vh;
  display: none;
  flex-direction: column;
  padding: var(--space-8);
  position: relative;
}

/* Chat body wrapper - chatbot-border.png as background frame */
.chat-body-wrapper {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  background: transparent;
  border: var(--border-width-xl) solid var(--accent);
  backdrop-filter: var(--blur-heavy);
  box-shadow:
    0 25px 50px -12px var(--black-50),
    0 0 30px var(--accent-secondary-50);
  position: relative;
  overflow: hidden;
  margin-bottom: var(--space-7);
  padding: var(--space-4);
}

/* Mobile Emulator Mode - applied via JS toggle in landscape */
.chat-container.mobile-emulator {
  max-width: calc((100vh - 20px) * 9 / 19.5);
  padding: 5px;
  font-size: var(--font-size-sm);
}

.mobile-emulator .chat-body-wrapper {
  margin-bottom: var(--space-3);
  padding: 6px;
}

.mobile-emulator .chat-messages {
  padding: var(--space-4);
}

.mobile-emulator .chat-placeholder-icon {
  font-size: var(--font-size-4xl);
}

.mobile-emulator .chat-placeholder-title {
  font-size: var(--font-size-lg);
}

.chat-messages {
  flex: 1;
  min-height: 0;
  background: transparent;
  padding: var(--space-8);
  overflow-y: auto;
  margin-bottom: 0;
  border: none;
}

.chat-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
  text-align: center;
  color: var(--white-50);
  animation: fadeIn 0.5s ease;
}

.chat-placeholder-icon {
  font-size: 4rem;
  margin-bottom: 1rem;
  color: var(--black-50);
}

.chat-placeholder-title {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  margin-bottom: 0.5rem;
  color: var(--black-50);
}

.mobile-emulator .chat-input-area {
  padding: 6px 10px;
  gap: var(--space-1);
}

.mobile-emulator #messageInput {
  font-size: var(--font-size-sm);
  padding: 8px 12px;
  min-height: 36px;
}

/* chat-input circle-btn sizing in mobile emulator — see OVERRIDES section */

.chat-input-area {
  background: transparent;
  padding: var(--space-4) var(--space-7) var(--space-7);
  border: none;
  border-top: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.chat-input-area.chat-disabled {
  pointer-events: none;
}

.chat-input-area.chat-disabled #messageInput {
  cursor: not-allowed;
  width: 100%;
  height: 4rem;
  background-color: transparent;
  border: 0;
}

.chat-input-area .chat-disabled-hidden {
  display: none !important;
}

/* Row 1: Main input row */
.input-row-main {
  display: flex;
  align-items: flex-end;
  gap: var(--space-3);
  position: relative;
}

/* Row 2: Secondary controls */
.input-row-secondary {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: 0.5rem;
}

.input-group-custom {
  flex: 1;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* #messageInput: inherits .form-control atom. Sizing only. */
#messageInput {
  width: 100%;
  font-size: var(--font-size-sm);
  resize: none;
  min-height: 40px;
  max-height: 150px;
}

/* Circle buttons in chat input area - override default button border */
/* Chat input area circle buttons — sizing only (appearance from Category 2) */
.chat-input-area > .input-row-main > button,
.chat-input-area > .input-row-secondary > .mic-settings-wrapper > button {
  width: 44px;
  height: 44px;
  min-width: 44px;
  min-height: 44px;
  font-size: var(--font-size-lg);
}

/* Emoji & Send — circle-btn, inherit Category 2. Sizing only here. */
.btn-emoji-circle {
  font-size: var(--font-size-lg);
}

.btn-send {
  font-size: var(--font-size-base);
}

.emoji-picker-container {
  position: absolute;
  bottom: 55px;
  left: 0;
  z-index: var(--z-dropdown);
  display: none;
}

.emoji-picker-container.show {
  display: block;
}

.chat-input-disabled {
  opacity: 0.4;
  pointer-events: none;
}

/* Modal Styles */
.modal-content {
  background: var(--accent-secondary);
  backdrop-filter: var(--blur-heavy);
  border: var(--border-width-thick) solid var(--accent-50);
}

.modal-header {
  border-bottom: var(--border-width-thin) solid var(--accent-secondary-50);
}

.modal-title {
  color: var(--white);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  margin: 0;
}

.modal-body textarea {
  min-height: 200px;
}

.modal-body textarea.textarea-sm {
  min-height: 100px;
}


/* Fix strong text color in publish tab */
#publishPane strong {
  color: var(--white-50);
}

/* Login Modal Styles */
.login-modal .modal-content {
  background: var(--accent-secondary);
  border: var(--border-width-thick) solid var(--accent);
}

.login-modal .modal-header {
  border-bottom: var(--border-width-thin) solid var(--accent-secondary-50);
}

.login-modal .modal-title {
  background: var(--secondary-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.modal-footer {
  border-top: var(--border-width-thin) solid var(--accent-secondary-50);
}

/* Topic Media Styles */
.uploaded-media-section {
  margin-top: var(--space-7);
  padding: var(--space-7);
  background: var(--accent-secondary-50);
  border: var(--border-width-thin) solid var(--accent-secondary-50);
}

.uploaded-media-section-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
}

.uploaded-media-section-header:hover {
  color: var(--accent);
}

.uploaded-media-section-title {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: var(--accent-light);
}

.uploaded-media-section-title i {
  margin-right: var(--space-1);
}

.uploaded-media-content {
  display: none;
}

.uploaded-media-content.show {
  display: block;
}

/* Topic Media Tabs */
.uploaded-media-tabs {
  border-bottom: var(--border-width-thin) solid var(--white-10);
  margin-bottom: 0;
}

.uploaded-media-tabs .nav-link i {
  margin-right: var(--space-1);
}

.uploaded-media-tab-content {
  background: var(--black-10);
  border: var(--border-width-thin) solid var(--white-10);
  border-top: none;
  padding: var(--space-7);
}

.uploaded-media-generate-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: var(--white-10);
  padding: 30px 20px;
  text-align: center;
}

.uploaded-media-generate-placeholder i {
  opacity: 0.5;
}

.uploaded-media-generate-placeholder p {
  margin: 0;
  font-size: var(--font-size-sm);
}

.uploaded-media-upload-area {
  background: transparent;
  border: 1px dashed var(--white-10);
  padding: var(--space-7);
}

.uploaded-media-preview {
  margin-bottom: var(--space-4);
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 60px;
}

.uploaded-media-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
  color: var(--white-10);
  padding: var(--space-8);
}

.uploaded-media-empty i {
  font-size: var(--font-size-3xl);
}

.uploaded-media-empty span {
  font-size: var(--font-size-sm);
}

.uploaded-media-img,
.uploaded-media-video {
  max-width: 100%;
  max-height: 200px;
  object-fit: contain;
}

.uploaded-media-img.collapsed,
.uploaded-media-video.collapsed {
  max-height: 80px;
  max-width: 120px;
}

.uploaded-media-audio {
  width: 100%;
  max-width: 300px;
}

.uploaded-media-audio.collapsed {
  max-width: 200px;
  height: 32px;
}

.uploaded-media-controls {
  display: flex;
  gap: var(--space-4);
  justify-content: center;
  margin-top: var(--space-4);
}


.uploaded-media-info {
  margin-top: var(--space-4);
  text-align: center;
}

.uploaded-media-info small {
  font-size: var(--font-size-xs);
}

/* Collapsed media preview in topic list */
.uploaded-media-preview-collapsed {
  flex-shrink: 0;
  width: 80px;
  height: 80px;
  padding: 4px;
  background: var(--black-10);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.uploaded-media-preview-collapsed video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Topic media as separate message bubble */
.uploaded-media-message {
  margin-top: 5px;
}

.uploaded-media-chat-img,
.uploaded-media-chat-video {
  max-width: 100%;
  max-height: 250px;
  object-fit: contain;
}

.uploaded-media-chat-audio {
  width: 100%;
  min-width: 250px;
  max-width: 300px;
  height: 40px;
  margin-top: 5px;
}

/* Topic Media Library */
.uploaded-media-library-section {
  margin-top: var(--space-8);
  padding-top: 15px;
  border-top: var(--border-width-thin) solid var(--white-10);
}

.uploaded-media-library-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-5);
}

.uploaded-media-library-title {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--white-50);
}

.uploaded-media-library-title i {
  margin-right: var(--space-3);
  color: var(--white-50);
}

.uploaded-media-library {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: var(--space-4);
  min-height: 80px;
}

/* Chat message uploaded media */
.message-uploaded-media {
  min-width: 250px;
}

.message-media-only {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 250px;
}

.imagegen-container {
  padding: 10px 0;
}

.imagegen-section,
.voicegen-section {
  margin-bottom: var(--space-7);
}

.imagegen-section-header,
.voicegen-section-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-4);
  gap: var(--space-4);
}

.imagegen-section-actions {
  display: flex;
  gap: 5px;
}

.imagegen-section-title,
.voicegen-section-title {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--accent-light);
}

.imagegen-section-title i,
.voicegen-section-title i {
  margin-right: var(--space-2);
}

/* Collapsible Style Prompt Section */
.imagegen-section-collapsible .imagegen-section-toggle {
  cursor: pointer;
  user-select: none;
  padding: var(--space-3) var(--space-5);
  background: var(--white-10);
  margin-bottom: 0;
  transition: background var(--transition-medium);
}

.imagegen-toggle-icon {
  margin-left: var(--space-3);
  font-size: var(--font-size-xs);
  transition: transform var(--transition-medium);
}

.imagegen-toggle-icon.expanded {
  transform: rotate(180deg);
}

.imagegen-section-content {
  padding: 12px 0;
}

.imagegen-section-content .imagegen-section-actions {
  margin-top: var(--space-4);
}

.generated-library-empty,
.media-library-empty {
  grid-column: 1 / -1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.style-selection-info {
  margin-top: var(--space-4);
  font-size: var(--font-size-xs);
  color: var(--white-50);
}

.style-selection-info .selection-count {
  font-weight: var(--font-weight-bold);
  color: var(--accent-light);
}

/* Style & User Prompt Inputs */
.style-prompt-input,
.user-prompt-input {
  font-size: var(--font-size-sm);
  resize: vertical;
}

/* Generate Actions */
.imagegen-actions,
.voicegen-actions {
  display: flex;
  gap: var(--space-4);
  margin-top: var(--space-7);
  flex-wrap: wrap;
}


.generate-image-btn .spinner,
.generate-voice-btn .spinner {
  margin-left: var(--space-3);
  animation: spin 1s linear infinite;
}

/* Generated Image Result */
.imagegen-result {
  margin-top: var(--space-7);
  padding: var(--space-7);
  background: var(--black-10);
  text-align: center;
}

/* Image Generation Options Row */
.imagegen-options-row {
  display: flex;
  gap: var(--space-7);
  flex-wrap: wrap;
}

.imagegen-options-row .imagegen-option {
  flex: 1;
  min-width: 150px;
}

.imagegen-options-row label {
  display: block;
  font-size: var(--font-size-sm);
  color: var(--white-50);
  margin-bottom: 5px;
}

.imagegen-options-row select {
  width: 100%;
  padding: 8px 12px;
  background: var(--white-10);
  border: var(--border-width-thin) solid var(--white-10);
  color: var(--white);
  font-size: var(--font-size-sm);
}

.imagegen-options-row select:focus {
  outline: none;
  border-color: var(--accent);
}

/* Image Generation Result Gallery */
.imagegen-result-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: var(--space-4);
  margin-bottom: var(--space-7);
}

/* Generated Images Library */
.generated-images-library {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: var(--space-4);
  min-height: 80px;
}

.generated-library-empty {
  padding: 30px;
  color: var(--white-50);
  gap: var(--space-4);
}

/* generated-library-item: now uses .cc-library-item */

/* Disabled Notice */
.imagegen-disabled-notice,
.voicegen-disabled-notice {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-10) var(--space-8);
  color: var(--white-50);
  text-align: center;
}

.imagegen-disabled-notice i,
.voicegen-disabled-notice i {
  font-size: var(--font-size-3xl);
  margin-bottom: var(--space-4);
  color: var(--info);
}

.imagegen-disabled-notice p,
.voicegen-disabled-notice p {
  margin: 0;
  font-size: var(--font-size-sm);
}

.media-library-empty {
  padding: 25px;
  color: var(--white-50);
  gap: var(--space-3);
  font-size: var(--font-size-sm);
}

.cc-library-item video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* ========================
   Fullview Modal (image / video / audio)
   ======================== */
.image-fullview-modal {
  position: fixed;
  inset: 0;
  z-index: var(--z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition:
    opacity 0.2s,
    visibility 0.2s;
}

.image-fullview-modal.show {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.image-fullview-backdrop {
  position: absolute;
  inset: 0;
  background: var(--black-50);
  backdrop-filter: var(--blur-light);
}

/* Card that wraps around the media — sizes to content */
.image-fullview-content {
  position: relative;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  background: var(--accent-secondary);
  padding: 16px;
  box-shadow:
    0 20px 60px var(--black-50),
    0 0 0 1px var(--white-10);
}

/* Fullview media — shared size constraints for all media types */
.image-fullview-img,
.media-fullview-video {
  display: block;
  max-width: calc(85vw - 80px);
  max-height: calc(85vh - 100px);
  width: auto;
  height: auto;
  object-fit: contain;
}

.media-fullview-audio {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 40px;
  background: var(--white-10);
  color: var(--white-50);
}

.media-fullview-audio audio {
  margin-top: var(--space-8);
  width: 300px;
}

.image-fullview-close {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 32px;
  height: 32px;
  background: var(--white-10);
  border: none;
  color: var(--white);
  font-size: var(--font-size-base);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s;
  z-index: 1;
}

.image-fullview-filename {
  margin-top: var(--space-4);
  color: var(--white-50);
  font-size: var(--font-size-xs);
  text-align: center;
  word-break: break-all;
}

.voicegen-container {
  padding: 10px 0;
}

.voicegen-char-count-label {
  font-size: var(--font-size-xs);
  color: var(--white-50);
}

.voicegen-char-count {
  color: var(--accent-light);
}

/* Voice Generation Options Row */
.voicegen-options-row {
  display: flex;
  gap: var(--space-7);
  flex-wrap: wrap;
}

.voicegen-option {
  flex: 1;
  min-width: 100px;
}

.voicegen-option.voicegen-option-wide {
  flex: 2;
  min-width: 200px;
}

.voicegen-option label {
  display: block;
  font-size: var(--font-size-xs);
  color: var(--white-50);
  margin-bottom: 5px;
}

.voicegen-option select {
  width: 100%;
  padding: 8px 12px;
  background: var(--accent-secondary);
  border: var(--border-width-thin) solid var(--white-10);
  color: var(--white);
  font-size: var(--font-size-sm);
}

.voicegen-option select:focus {
  outline: none;
  border-color: var(--accent);
}

.voicegen-option select optgroup {
  background: var(--accent-secondary);
  font-weight: var(--font-weight-semibold);
  color: var(--accent-light);
  padding: 8px 0;
}

/* Text Input */
.voicegen-text-input {
  background: var(--black-10);
  border: var(--border-width-thin) solid var(--white-10);
  color: var(--white);
  font-size: var(--font-size-sm);
  resize: vertical;
  min-height: 80px;
}

.voicegen-text-input:focus {
  background: var(--black-10);
  border-color: var(--accent);
  box-shadow: 0 0 0 2px var(--accent-secondary-50);
}

.voicegen-text-input::placeholder {
  color: var(--white-10);
}

/* Voice Preview */
.voicegen-preview {
  margin-top: var(--space-7);
  padding: var(--space-7);
  background: var(--black-10);
}

.voicegen-preview-header {
  font-size: var(--font-size-xs);
  color: var(--white-50);
  margin-bottom: var(--space-4);
}

.voicegen-preview-header i {
  margin-right: var(--space-2);
}

.voicegen-audio-player {
  width: 100%;
  height: 40px;
}

/* Generated Voices Library */
.generated-voices-library {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  min-height: 80px;
}

.topic-details {
  margin-top: var(--space-4);
  padding-top: 10px;
  border-top: var(--border-width-thin) solid var(--white-10);
}

/* Topic details single-row layout for name + trigger + affinity */
.topic-details-row {
  display: flex;
  gap: var(--space-4);
  align-items: flex-end;
  flex-wrap: wrap;
}

.topic-details-field {
  margin-bottom: 0;
}

.topic-details-field-name {
  flex: 2;
  min-width: 140px;
}

.topic-details-field-trigger {
  flex: 1.5;
  min-width: 120px;
}

.topic-details-field-affinity {
  flex: 1;
  min-width: 80px;
}

/* Topic test panel styles */
.topic-test-panel {
  margin-top: var(--space-7);
  padding: var(--space-7);
  background: var(--accent-secondary-50);
  border: var(--border-width-thin) solid var(--accent-secondary-50);
}

.topic-test-panel-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-4);
  cursor: pointer;
}

.topic-test-panel-header:hover {
  color: var(--accent);
}

.topic-test-panel-title {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: var(--accent-light);
}

.topic-test-panel-title i {
  margin-right: var(--space-1);
}

.topic-test-content {
  display: none;
}

.topic-test-content.show {
  display: block;
}

.topic-test-input-wrapper {
  display: flex;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
}

.topic-test-input {
  flex: 1;
  background: var(--white-10);
  border: var(--border-width-thin) solid var(--white-10);
  color: var(--white);
  padding: 8px 12px;
  font-size: var(--font-size-sm);
}

.topic-test-input:focus {
  outline: none;
  border-color: var(--accent-50);
}

.topic-test-btn {
  font-size: var(--font-size-sm);
  display: flex;
  align-items: center;
  gap: 5px;
}

.topic-test-btn .spinner {
  display: none;
}

.topic-test-btn.loading .spinner {
  display: inline-block;
}

.topic-test-btn.loading .send-icon {
  display: none;
}

.topic-test-response {
  background: var(--black-10);
  padding: 12px;
  min-height: 60px;
  max-height: 200px;
  overflow-y: auto;
  font-size: var(--font-size-sm);
  color: var(--white-50);
  white-space: pre-wrap;
}

.topic-test-response.empty {
  color: var(--white-10);
  font-style: italic;
}

.topic-test-response.error {
  color: var(--accent);
}

.topic-test-info {
  font-size: var(--font-size-xs);
  color: var(--white-50);
  margin-top: var(--space-3);
}

.topic-test-detect-toggle {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
  padding: 8px 12px;
  background: var(--black-10);
}

.topic-test-detect-toggle label {
  font-size: var(--font-size-sm);
  color: var(--white-50);
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.topic-test-detect-toggle input[type='checkbox'] {
  width: 18px;
  height: 18px;
  cursor: pointer;
}

.topic-test-topic-label {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--accent-secondary-50);
  color: var(--accent-light);
  padding: 4px 10px;
  font-size: var(--font-size-xs);
  margin-top: var(--space-3);
}

.topic-test-topic-label i {
  font-size: var(--font-size-xs);
}

.topic-test-warning {
  display: flex;
  align-items: center;
  gap: 5px;
  background: var(--accent-secondary-50);
  color: var(--accent);
  padding: 8px 12px;
  font-size: var(--font-size-xs);
  margin-top: var(--space-3);
}

.topic-test-warning i {
  font-size: var(--font-size-sm);
}

/* Topic test media */
.topic-test-media {
  margin-top: var(--space-4);
  padding: var(--space-4);
  background: var(--black-10);
  display: flex;
  justify-content: center;
}

.topic-test-media-video {
  max-width: 100%;
  max-height: 150px;
  object-fit: contain;
}

.topic-test-media-audio {
  width: 100%;
  max-width: 250px;
}

.login-modal .form-label {
  color: var(--white);
  font-size: var(--font-size-sm);
}

.login-modal .btn-save {
  padding: 12px 24px;
  font-weight: var(--font-weight-semibold);
  width: 100%;
}

.login-modal .login-error {
  background: var(--danger-50);
  border: var(--border-width-thin) solid var(--danger-50);
  color: var(--danger);
  padding: 10px 15px;
  font-size: var(--font-size-sm);
  margin-bottom: var(--space-7);
}

/* Debug Log Panel */
.log-panel {
  display: none;
  background: var(--black-50);
  border: var(--border-width-thin) solid var(--white-10);
  margin-top: var(--space-4);
  max-height: 200px;
  overflow: hidden;
  flex-direction: column;
}

.log-panel.show {
  display: flex;
}

.log-panel-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 12px;
  background: var(--white-10);
  border-bottom: var(--border-width-thin) solid var(--white-10);
  color: var(--white-50);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
}

.log-panel-header i {
  margin-right: var(--space-2);
}

.log-panel-actions {
  display: flex;
  gap: var(--space-1);
}

.log-panel-content {
  flex: 1;
  overflow-y: auto;
  padding: var(--space-4);
  font-family: var(--font-family-mono);
  font-size: var(--font-size-xs);
  line-height: var(--line-height-base);
  color: var(--success);
}

.log-entry {
  margin-bottom: var(--space-3);
  padding: 6px 8px;
  background: var(--white-10);
  border-left: var(--border-width-xl) solid var(--accent);
}

.log-entry-time {
  color: var(--neutral);
  font-size: var(--font-size-xs);
  margin-bottom: var(--space-1);
}

.log-entry-content {
  white-space: pre-wrap;
  word-break: break-all;
}

/* Auth Screen Styles */
.auth-screen,
.app-loading-screen {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url('../background.png') no-repeat center center fixed;
  background-size: cover;
  justify-content: center;
  align-items: center;
}

.auth-screen {
  display: flex;
  z-index: var(--z-modal);
}

/* App Loading Screen */
.app-loading-screen {
  display: none;
  z-index: var(--z-loading);
  transition: opacity 0.4s ease;
}

.app-loading-screen.fade-out {
  opacity: 0;
  pointer-events: none;
}

.app-loading-content {
  text-align: center;
  color: var(--white);
}

.app-loading-content h1 {
  font-size: var(--font-size-4xl);
  margin-bottom: var(--space-8);
  color: var(--accent);
}

.app-loading-content h1 i {
  color: var(--accent);
}

.app-loading-spinner {
  font-size: var(--font-size-3xl);
  color: var(--accent);
  margin-bottom: var(--space-7);
}

.app-loading-content p {
  font-size: var(--font-size-base);
  color: var(--neutral);
}

.auth-screen.hidden {
  display: none;
}

/* Chat List Screen */
.chat-list-screen {
  max-width: 800px;
  margin: 0 auto;
  height: 100vh;
  display: flex;
  flex-direction: column;
  padding: var(--space-8);
}

.chat-list-screen.hidden {
  display: none;
}

.chat-list-header .circle-btn {
  flex-shrink: 0;
}

.chat-list-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-4) var(--space-7);
  margin-bottom: var(--space-7);
  border: var(--border-width-base) solid var(--accent);
  backdrop-filter: var(--blur-heavy);
}

.chat-list-item {
  display: flex;
  align-items: center;
  gap: var(--space-5);
  padding: var(--space-5) var(--space-7);
  border: var(--border-width-base) solid var(--accent);
  background: var(--accent-secondary-50);
  backdrop-filter: var(--blur-heavy);
  cursor: pointer;
  transition: all var(--transition-medium);
}

.chat-list-item:hover {
  background: var(--accent-secondary-50);
  border-color: var(--accent-50);
  box-shadow: 0 0 12px var(--accent-secondary-50);
}

.chat-list-avatar {
  width: 50px;
  height: 50px;
  border-radius: var(--radius-md);
  border: var(--border-width-base) solid var(--accent);
  object-fit: cover;
  object-position: top center;
  flex-shrink: 0;
}

.chat-list-info {
  flex: 1;
  min-width: 0;
}

.chat-list-name {
  font-weight: var(--font-weight-bold);
  color: var(--white);
  font-size: var(--font-size-base);
  margin-bottom: 2px;
}

.chat-list-preview {
  color: var(--white-50);
  font-size: var(--font-size-sm);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.chat-list-item-archived {
  opacity: 0.6;
}

.chat-list-time {
  color: var(--white-10);
  font-size: var(--font-size-xs);
  flex-shrink: 0;
}

/* Back button in chat header */
/* btn-back: circle-btn, inherits Category 2. Layout only. */
.btn-back {
  width: clamp(24px, 2.5vw, 40px);
  height: clamp(24px, 2.5vw, 40px);
  margin-right: var(--space-3);
}

.auth-card {
  background: var(--black-10);
  backdrop-filter: var(--blur-heavy);
  border: var(--border-width-xl) solid var(--accent);
  padding: 40px;
  width: 100%;
  max-width: 420px;
  box-shadow:
    0 25px 50px -12px var(--black-50),
    0 0 30px var(--accent-secondary-50);
}

.auth-card-logo {
  text-align: center;
  margin-bottom: 30px;
}

.auth-card-logo h1 {
  background: var(--secondary-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-size: var(--font-size-4xl);
  font-weight: var(--font-weight-bold);
  margin: 0;
}

.auth-card-logo h1 i {
  -webkit-text-fill-color: var(--accent);
}

.auth-card-logo p {
  color: var(--white-50);
  margin-top: var(--space-3);
  font-size: var(--font-size-base);
}

.auth-tabs {
  margin-bottom: var(--space-9);
}

.auth-form {
  display: none;
}

.auth-form.active {
  display: block;
}

.auth-form .form-label {
  color: var(--white);
  font-size: var(--font-size-sm);
  margin-bottom: var(--space-3);
}

.auth-form .btn-submit {
  padding: 14px 24px;
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-base);
  width: 100%;
}

.auth-error,
.auth-success {
  padding: 12px 16px;
  font-size: var(--font-size-sm);
  margin-bottom: var(--space-8);
  display: none;
}

.auth-error.show,
.auth-success.show {
  display: block;
}

.auth-error {
  background: var(--danger-50);
  border: var(--border-width-thin) solid var(--danger-50);
  color: var(--danger);
}

.auth-success {
  background: var(--success-50);
  border: var(--border-width-thin) solid var(--success-50);
  color: var(--success);
}

.password-requirements {
  font-size: var(--font-size-xs);
  color: var(--white-50);
  margin-top: var(--space-2);
}

/* User Manager Styles */
.user-manager-modal .modal-dialog {
  max-width: 900px;
}

.user-manager-table {
  background: var(--white-10);
  overflow: hidden;
}

.user-manager-table table {
  width: 100%;
  border-collapse: collapse;
  color: var(--white);
}

.user-manager-table th {
  background: var(--white-10);
  padding: 14px 16px;
  text-align: left;
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-sm);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-bottom: var(--border-width-thin) solid var(--white-10);
}

.user-manager-table td {
  padding: 14px 16px;
  border-bottom: var(--border-width-thin) solid var(--white-10);
  vertical-align: middle;
}

.user-manager-table tr:hover {
  background: var(--white-10);
}

.user-manager-table .user-email {
  font-size: var(--font-size-sm);
}

.user-manager-table .role-select {
  background: var(--white-10);
  border: var(--border-width-thin) solid var(--white-10);
  color: var(--white);
  padding: 6px 12px;
  font-size: var(--font-size-sm);
  min-width: 100px;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23ffffff' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  padding-right: 30px;
}

.user-manager-table .role-select option {
  background: var(--accent-secondary);
  color: var(--white);
  padding: 8px 12px;
}

.user-manager-table .role-select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px var(--accent-secondary-50);
  outline: none;
}

.user-manager-table .role-select:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
}

.user-manager-table .status-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 4px 12px;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
}

.user-manager-table .status-badge.active {
  background: var(--success-50);
  color: var(--success);
}

.user-manager-table .status-badge.inactive {
  background: var(--white-10);
  color: var(--neutral);
}

.user-manager-table .btn-delete,
.user-manager-table .btn-toggle-status {
  width: 32px;
  height: 32px;
  padding: 0;
  margin-right: var(--space-1);
}

.user-manager-table .btn-delete:hover {
  color: var(--danger);
}

.user-manager-table .btn-toggle-status:hover {
  color: var(--info);
}

/* btn-add-user: default button, sizing only */
.btn-add-user {
  padding: 10px 20px;
  font-weight: var(--font-weight-medium);
}

/* btn-user-manager: default button. No sizing overrides. */

.user-loading,
.no-users-message {
  text-align: center;
  padding: 40px;
  color: var(--white-50);
}

.user-loading i {
  font-size: var(--font-size-3xl);
  margin-bottom: var(--space-4);
  animation: spin 1s linear infinite;
}

/* Voice Button */
/* btn-voice: circle-btn, inherits CIRCLE BUTTON. Sizing + states only. */
.btn-voice {
  width: 44px;
  height: 44px;
  min-width: 44px;
  min-height: 44px;
  font-size: var(--font-size-lg);
  user-select: none;
  -webkit-user-select: none;
  touch-action: manipulation;
}

/* Voice recording: uses circle-expanded + red color override */
@keyframes pulse-recording {
  0%, 100% { box-shadow: 0 0 0 0 var(--danger-50); }
  50%      { box-shadow: 0 0 0 10px transparent; }
}

.btn-voice.recording {
  background: var(--danger) !important;
  border-color: var(--danger) !important;
  color: var(--white) !important;
  animation: pulse-recording 1.5s ease-in-out infinite;
}

.btn-voice.recording:hover {
  background: var(--danger) !important;
}

/* Mic Settings Button */
.mic-settings-wrapper {
  position: relative;
}

/* btn-mic-settings: circle-btn, inherits Category 2. Sizing only. */
.btn-mic-settings {
  width: 32px;
  height: 32px;
  min-width: 32px;
  min-height: 32px;
  font-size: var(--font-size-xs);
}

/* Mic Selector Popup */
.mic-selector-popup {
  position: absolute;
  bottom: calc(100% + 10px);
  right: 0;
  width: 280px;
  background: var(--accent-secondary);
  border: var(--border-width-thick) solid var(--accent);
  box-shadow:
    0 10px 40px var(--black-50),
    0 0 15px var(--accent-secondary-50);
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition: all var(--transition-slow);
  z-index: var(--z-dropdown);
}

.mic-selector-popup.show {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.mic-popup-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 15px;
  border-bottom: var(--border-width-thin) solid var(--white-10);
}

.mic-popup-header h6 {
  margin: 0;
  font-size: var(--font-size-sm);
  color: var(--white-50);
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.mic-popup-refresh {
  background: none;
  border: none;
  color: var(--white-50);
  padding: 5px 8px;
  cursor: pointer;
  transition: all var(--transition-medium);
}

.mic-popup-refresh:hover {
  background: var(--white-10);
  color: var(--white-50);
}

.mic-popup-content {
  padding: var(--space-7);
}

.mic-popup-content label {
  display: block;
  font-size: var(--font-size-xs);
  color: var(--white-50);
  margin-bottom: var(--space-2);
}

.mic-select {
  width: 100%;
  background: var(--white-10);
  border: var(--border-width-thin) solid var(--white-10);
  color: var(--white);
  padding: 8px 12px;
  font-size: var(--font-size-sm);
  margin-bottom: var(--space-7);
}

.mic-select:focus {
  outline: none;
  border-color: var(--accent);
}

.mic-select option {
  background: var(--accent-secondary);
  color: var(--white);
}

.mic-audio-settings {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  padding-top: 10px;
  border-top: var(--border-width-thin) solid var(--white-10);
}

.mic-setting-toggle {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  cursor: pointer;
  padding: 6px 8px;
  transition: background var(--transition-medium);
}

.mic-setting-toggle:hover {
  background: var(--white-10);
}

.mic-setting-toggle input[type='checkbox'] {
  width: 16px;
  height: 16px;
  accent-color: var(--accent);
  cursor: pointer;
}

.mic-setting-toggle span {
  font-size: var(--font-size-sm);
  color: var(--white-50);
}

.voice-indicator {
  display: inline-flex;
  align-items: center;
  margin-right: var(--space-3);
  color: var(--danger);
}

.voice-text {
  color: var(--white-50);
}

/* Voice Settings Styles */
.voice-instructions {
  background: var(--white-10);
  padding: var(--space-7);
}

.voice-instructions ol li {
  margin-bottom: var(--space-3);
}

.voice-instructions ol li:last-child {
  margin-bottom: 0;
}

#refreshMicrophonesBtn {
  font-size: var(--font-size-xs);
}

/* Voice status in settings */
#voiceNotConfigured {
  border-color: var(--info);
  background: var(--accent-secondary-50);
}

/* Analytics Chart */
.analytics-chart-container {
  background: var(--black-10);
  padding: var(--space-8);
  height: 250px;
}

/* Analytics Table */
.analytics-table-container {
  max-height: 500px;
  overflow-y: auto;
  background: var(--black-10);
}

.analytics-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--font-size-sm);
}

.analytics-table thead {
  position: sticky;
  top: 0;
  z-index: 10;
  background: var(--accent-secondary);
}

.analytics-table th {
  padding: 12px 10px;
  text-align: left;
  font-weight: var(--font-weight-semibold);
  color: var(--white-50);
  border-bottom: var(--border-width-thick) solid var(--accent-secondary-50);
  white-space: nowrap;
}

.analytics-table th.sortable {
  cursor: pointer;
  user-select: none;
  transition: all var(--transition-medium);
}

.analytics-table th.sortable:hover {
  background: var(--accent-secondary-50);
  color: var(--accent-light);
}

.analytics-table th.sortable i {
  margin-left: 6px;
  font-size: var(--font-size-xs);
  opacity: 0.6;
  transition: opacity 0.2s;
}

.analytics-table th.sortable:hover i {
  opacity: 1;
}

.analytics-table td {
  padding: var(--space-4);
  border-bottom: var(--border-width-thin) solid var(--white-10);
  color: var(--white-50);
  vertical-align: middle;
}

.analytics-row {
  cursor: pointer;
  transition: all var(--transition-medium);
}

.analytics-row:hover {
  background: var(--accent-secondary-50);
}

.analytics-row.expanded {
  background: var(--accent-secondary-50);
}

.analytics-row.expanded td {
  border-bottom-color: transparent;
}

/* Analytics Details Row */
.analytics-details-row {
  background: var(--black-10);
}

.analytics-details-row td {
  padding: 0;
  border-bottom: var(--border-width-thick) solid var(--accent-secondary-50);
}

.analytics-details-content {
  padding: 15px 20px;
  --fade-from: -10px;
  animation: fadeIn 0.2s ease-out;
}

.analytics-details-grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.analytics-detail-section {
  background: var(--white-10);
  padding: 10px 12px;
}

.analytics-detail-label {
  font-size: var(--font-size-xs);
  color: var(--white-50);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: var(--space-2);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.analytics-detail-label i {
  font-size: var(--font-size-xs);
}

.analytics-detail-text {
  font-size: var(--font-size-sm);
  color: var(--white-50);
  white-space: pre-wrap;
  word-break: break-word;
  max-height: 200px;
  overflow-y: auto;
  padding: 8px 10px;
  background: var(--black-10);
  border-left: var(--border-width-xl) solid var(--accent-50);
}

.analytics-detail-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-7);
  font-size: var(--font-size-xs);
  color: var(--white-50);
  padding: 8px 12px;
}

.analytics-detail-meta span {
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.analytics-detail-meta i {
  font-size: var(--font-size-xs);
  opacity: 0.7;
}

.analytics-detail-user {
  background: var(--accent-secondary-50);
  border-left: var(--border-width-xl) solid var(--accent-50);
}

.analytics-detail-user .analytics-detail-label {
  color: var(--accent-50);
}

.analytics-detail-media {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin-top: var(--space-3);
}

.analytics-media-thumb {
  width: 60px;
  height: 60px;
  object-fit: cover;
  cursor: pointer;
  transition: all var(--transition-medium);
  border: var(--border-width-thick) solid transparent;
}

.analytics-media-thumb:hover {
  transform: scale(1.05);
  border-color: var(--accent);
  box-shadow: 0 2px 10px var(--accent-secondary-50);
}

.analytics-media-generated {
  border-color: var(--accent-secondary-50);
}

.analytics-media-generated:hover {
  border-color: var(--accent);
  box-shadow: 0 2px 10px var(--accent-secondary-50);
}

.analytics-media-style-ref {
  border-color: var(--accent-secondary-50);
  opacity: 0.8;
}

.analytics-media-style-ref:hover {
  border-color: var(--accent);
  opacity: 1;
}

.analytics-audio {
  height: 32px;
  max-width: 250px;
}

.analytics-audio::-webkit-media-controls-panel {
  background: var(--accent-secondary-50);
}

/* Analytics Pagination */
#analyticsPagination .pagination {
  --bs-pagination-bg: var(--white-10);
  --bs-pagination-border-color: var(--white-10);
  --bs-pagination-color: var(--white-50);
  --bs-pagination-hover-bg: var(--white-10);
  --bs-pagination-hover-color: var(--white);
  --bs-pagination-focus-bg: var(--white-10);
  --bs-pagination-active-bg: var(--accent);
  --bs-pagination-active-border-color: var(--accent);
  --bs-pagination-disabled-bg: var(--white-10);
  --bs-pagination-disabled-color: var(--white-10);
}

#analyticsPagination .page-link {
  margin: 0 2px;
}

/* Analytics Empty State */
#analyticsEmpty {
  color: var(--white-50);
}

#analyticsEmpty i {
  opacity: 0.5;
}

/* Analytics Filter Inputs */
.analytics-filters {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
}

.analytics-filters .form-select {
  padding-right: 1.5rem;
}

.analytics-filters .analytics-text-filter {
  min-width: 130px;
  flex: 1;
}

/* Date input icon color fix */
#analyticsPane input[type='date']::-webkit-calendar-picker-indicator {
  filter: invert(0.7);
}

.analytics-subtabs {
  border-bottom: var(--border-width-thin) solid var(--white-10);
  gap: var(--space-1);
}

.cohort-controls {
  padding: 8px 0;
}

.cohort-card-users,
.cohort-card-sessions {
  border-left: var(--border-width-xl) solid var(--info);
}

.cohort-card-active {
  border-left: var(--border-width-xl) solid var(--success);
}

.cohort-card-returning {
  border-left: var(--border-width-xl) solid var(--accent);
}

/* Cohort Heatmap */
.cohort-heatmap-container {
  background: var(--black-10);
  border: var(--border-width-thin) solid var(--white-10);
  overflow: hidden;
}

.cohort-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--font-size-xs);
}

.cohort-table td {
  padding: 6px 8px;
  text-align: center;
  border: var(--border-width-thin) solid var(--white-10);
}

.cohort-table thead {
  background: var(--white-10);
}

.cohort-table th {
  color: var(--white-50);
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

.cohort-heatmap-label {
  text-align: left !important;
  color: var(--white-50);
  font-weight: var(--font-weight-medium);
  white-space: nowrap;
  min-width: 80px;
}

.cohort-heatmap-period {
  min-width: 46px;
  font-size: var(--font-size-xs);
}

.cohort-heatmap-cell {
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-xs);
  transition: all 0.15s;
  cursor: default;
  min-width: 46px;
}

.cohort-heatmap-cell:hover {
  outline: 1px solid var(--white-10);
  outline-offset: -1px;
}

.cohort-heatmap-empty {
  background: var(--white-10);
}

/* Cohort Detail Table */
#cohortDetailTable {
  font-size: var(--font-size-xs);
}

#cohortDetailTable th {
  padding: 8px 10px;
}

.character-image-uploads {
  display: flex;
  gap: var(--space-4);
}

.character-image-field {
  flex: 1;
}

.character-image-preview {
  width: 110px;
  height: 110px;
  border: 2px dashed var(--white-10);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: var(--black-10);
}

.character-image-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.character-bg-preview {
  width: 110px;
  height: auto;
  aspect-ratio: 9 / 19.5;
}

.character-image-placeholder {
  font-size: var(--font-size-lg);
  color: var(--white-10);
}

/* Gallery-select slot buttons */
.char-image-slot {
  cursor: pointer;
  transition: border-color var(--transition-fast);
}

.char-image-slot-active .character-image-preview {
  border-color: var(--accent);
  border-style: solid;
}

.char-image-select-btn,
.char-image-clear-btn {
  font-size: var(--font-size-xs);
  padding: var(--space-1) var(--space-3);
  cursor: pointer;
  text-align: center;
  background: var(--white-10);
  border: var(--border-width-thin) solid var(--glass-border);
  color: var(--white);
  transition: background var(--transition-fast);
}

.char-image-select-btn:hover,
.char-image-clear-btn:hover {
  background: var(--white-20);
}

.char-image-slot-active .char-image-select-btn {
  background: var(--accent);
  color: var(--bg-dark);
}

.char-image-gallery-section {
  border-top: var(--border-width-thin) solid var(--glass-border);
  padding-top: var(--space-4);
}

.char-image-gallery-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-3);
}

.char-image-gallery-title {
  font-size: var(--font-size-sm);
  color: var(--text-muted);
}

.char-image-assigning-label {
  color: var(--accent);
  font-size: var(--font-size-xs);
}

.char-image-upload-btn {
  font-size: var(--font-size-xs);
  padding: var(--space-1) var(--space-3);
  cursor: pointer;
  background: var(--white-10);
  border: var(--border-width-thin) solid var(--glass-border);
  color: var(--white);
  transition: background var(--transition-fast);
}

.char-image-upload-btn:hover {
  background: var(--white-20);
}

.char-image-refresh-btn {
  font-size: var(--font-size-xs);
  padding: var(--space-1) var(--space-2);
  cursor: pointer;
  background: var(--white-10);
  border: var(--border-width-thin) solid var(--glass-border);
  color: var(--white);
  transition: background var(--transition-fast);
}

.char-image-refresh-btn:hover {
  background: var(--white-20);
}

.character-emotion-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
}

.character-emotion-grid .character-image-preview {
  width: 100%;
  aspect-ratio: 1;
  height: auto;
}


/* login-modal form-control: inherits base, sizing only */
.login-modal .form-control {
  padding: 12px 15px;
}

/* auth-form form-control: inherits base, sizing only */
.auth-form .form-control {
  padding: 14px 18px;
  font-size: var(--font-size-base);
}

.analytics-filters .form-control {
  width: auto;
  min-width: 0;
  font-size: var(--font-size-xs);
  padding: 0.2rem 0.5rem;
  height: 28px;
}

#commonPromptsReadonlyNotice {
  background: var(--white-10);
  border: var(--border-width-thin) solid var(--neutral);
  color: var(--white-50);
  padding: var(--space-4) var(--space-7);
}

#commonPromptsReadonlyNotice i {
  color: var(--info);
}

/* Editable list items — shared base */
.affinity-rule-item,
.topic-item,
.config-item {
  background: var(--black-10);
  border: var(--border-width-thin) solid var(--glass-border);
  padding: var(--space-7);
  margin-bottom: var(--space-4);
}

.affinity-rule-item:hover,
.topic-item:hover,
.trigger-pattern-item:hover,
.config-item:hover {
  border-color: var(--accent-50);
}

.affinity-rule-item.editing,
.topic-item.editing,
.trigger-pattern-item.editing {
  background: var(--accent-secondary-50);
  box-shadow: 0 0 0 1px var(--accent-secondary-50);
}

.affinity-rule-item.editing { border-color: var(--accent); }

.affinity-rule-header,
.topic-header,
.trigger-pattern-header,
.config-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-4);
}

.affinity-rule-label {
  font-weight: var(--font-weight-bold);
  color: var(--accent);
}

.affinity-rule-range {
  color: var(--white-50);
  font-size: var(--font-size-sm);
}

.style-field {
  margin-bottom: var(--space-3);
}

.style-field label {
  font-size: var(--font-size-xs);
  color: var(--white-50);
  margin-bottom: 3px;
}

.style-field textarea {
  background: var(--white-10);
  border: var(--border-width-thin) solid var(--white-10);
  color: var(--white);
  padding: 5px 10px;
  font-size: var(--font-size-sm);
  min-height: auto;
}

.topic-item.editing { border-color: var(--accent); }

.topic-item.disabled {
  opacity: 0.5;
}

.topic-id {
  font-weight: var(--font-weight-bold);
  color: var(--accent);
}

.topic-trigger {
  display: inline-block;
  background: var(--accent-secondary-50);
  color: var(--accent);
  padding: 2px 8px;
  font-size: var(--font-size-xs);
  margin-left: var(--space-3);
}

/* Collapsed body: horizontal layout with media left, info right */
.topic-collapsed-body {
  display: flex;
  gap: var(--space-5);
  align-items: flex-start;
  margin-top: var(--space-1);
}

.topic-collapsed-info {
  flex: 1;
  min-width: 0;
}

.topic-affinity-range {
  color: var(--white-50);
  font-size: var(--font-size-sm);
}

.topic-summary {
  color: var(--white-50);
  font-size: var(--font-size-sm);
  margin-top: var(--space-2);
  padding: 8px 10px;
  background: var(--black-10);
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  line-clamp: 3;
  -webkit-box-orient: vertical;
}

.trigger-pattern-item {
  background: var(--white-10);
  border: var(--border-width-thin) solid var(--white-10);
  padding: var(--space-7);
  margin-bottom: var(--space-4);
}

.trigger-pattern-item.editing { border-color: var(--success); }

.trigger-pattern-name {
  font-weight: var(--font-weight-bold);
  color: var(--accent);
  text-transform: capitalize;
}

.trigger-pattern-keywords {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: var(--space-3);
}

.trigger-keyword {
  background: var(--accent-secondary-50);
  color: var(--accent-light);
  padding: 2px 8px;
  font-size: var(--font-size-xs);
}

.trigger-keyword.duplicate {
  background: var(--danger-50);
  color: var(--danger);
  border: var(--border-width-thin) solid var(--danger-50);
}

.trigger-pattern-name.has-duplicate-keywords {
  color: var(--danger) !important;
}

.trigger-pattern-item.has-duplicate-keywords {
  border-color: var(--danger-50);
}

.trigger-duplicate-warning {
  color: var(--danger);
  font-size: var(--font-size-xs);
  margin-top: var(--space-3);
  padding: 6px 10px;
  background: var(--danger-50);
  border-left: var(--border-width-xl) solid var(--danger);
}

.trigger-duplicate-warning i {
  margin-right: var(--space-2);
  color: var(--danger);
}

.trigger-pattern-input {
  background: var(--white-10);
  border: var(--border-width-thin) solid var(--white-10);
  color: var(--white);
  padding: 8px 10px;
  font-size: var(--font-size-sm);
  width: 100%;
}

/* Trigger Test Section Styles */
.trigger-test-section {
  background: var(--black-10);
  padding: var(--space-7);
}

.trigger-test-section .trigger-test-muted {
  color: var(--white-50);
}

.trigger-test-section .trigger-test-input {
  background: var(--white-10);
  border: var(--border-width-thin) solid var(--white-10);
  color: var(--white);
}

.trigger-test-section .trigger-test-input::placeholder {
  color: var(--white-50);
}

.trigger-test-result {
  padding: 12px 15px;
  font-size: var(--font-size-sm);
}

.trigger-test-result.success {
  background: var(--success-50);
  border: var(--border-width-thin) solid var(--success-50);
  color: var(--success);
}

.trigger-test-result.no-match {
  background: var(--white-10);
  border: var(--border-width-thin) solid var(--neutral);
  color: var(--neutral);
}

.trigger-test-result .matched-trigger {
  font-weight: var(--font-weight-bold);
  color: var(--success);
}

.trigger-test-result .matched-keyword {
  background: var(--success-50);
  padding: 2px 6px;
  font-family: var(--font-family-mono);
}

.config-item.enabled {
  border-color: var(--success-50);
  background: var(--success-50);
}

.config-name {
  font-family: var(--font-family-mono);
  font-size: var(--font-size-sm);
  color: var(--accent);
  background: var(--accent-secondary-50);
  padding: 2px 8px;
}

.config-status {
  display: inline-block;
  padding: 2px 8px;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
}

.config-status.enabled {
  background: var(--success-50);
  color: var(--success);
}

.config-status.disabled {
  background: var(--white-10);
  color: var(--neutral);
}

.config-meta {
  color: var(--white-50);
  font-size: var(--font-size-xs);
  margin-top: var(--space-3);
}

.config-meta i {
  margin-right: var(--space-1);
  width: 16px;
  text-align: center;
}

.config-notes {
  color: var(--white-50);
  font-size: var(--font-size-sm);
  margin-top: var(--space-3);
  padding: var(--space-4);
  background: var(--black-10);
}

.config-notes.empty {
  color: var(--white-10);
  font-style: italic;
}

.config-actions {
  display: flex;
  gap: 5px;
}

.config-edit-form {
  margin-top: var(--space-4);
  padding-top: 10px;
  border-top: var(--border-width-thin) solid var(--white-10);
}

.config-edit-form textarea {
  background: var(--white-10);
  border: var(--border-width-thin) solid var(--white-10);
  color: var(--white);
  resize: vertical;
}

.config-name-input {
  background: var(--white-10);
  border: var(--border-width-thin) solid var(--white-10);
  color: var(--white);
  padding: 4px 8px;
  font-size: var(--font-size-sm);
}

/* Session Mode Toggle Styles */
.session-mode-toggle {
  display: flex;
  align-items: center;
  background: var(--accent-secondary-50);
  padding: 3px;
  gap: 2px;
  position: fixed;
  bottom: var(--space-5);
  right: var(--space-5);
  z-index: var(--z-toast);
}

.status-indicator {
  position: fixed;
  bottom: calc(var(--space-5) + 36px);
  right: var(--space-5);
  z-index: var(--z-toast);
}

.btn-emulator {
  position: fixed;
  bottom: calc(var(--space-5) + 72px);
  right: var(--space-5);
  z-index: var(--z-toast);
}


.session-mode-toggle .toggle-btn {
  border: none;
  background: transparent;
  color: var(--white-50);
  padding: 6px 12px;
  cursor: pointer;
  transition: all var(--transition-medium);
  font-size: var(--font-size-sm);
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

.session-mode-toggle .toggle-btn:hover {
  color: var(--white);
  background: var(--accent-secondary-50);
}

.session-mode-toggle .toggle-btn.play.active {
  background: var(--accent-50);
  color: var(--white);
}

.session-mode-toggle .toggle-btn.draft.active {
  background: var(--accent-secondary-50);
  color: var(--info);
}

.mobile-emulator .user-role {
  display: none !important;
}

.mobile-emulator .user-info #userDisplayName {
  max-width: 70px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Login/Auth Styles */
.auth-container {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-left: auto;
}

.user-info {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: 5px 12px;
  background: transparent;
  font-size: var(--font-size-sm);
  color: var(--black-50);
}

.user-info .user-role {
  font-size: var(--font-size-xs);
  padding: 2px 6px;
  text-transform: uppercase;
  font-weight: var(--font-weight-bold);
}

.user-role.admin,
.user-role.pm,
.user-role.editor,
.user-role.user {
  background: transparent;
}

.user-role.admin  { color: var(--danger); }
.user-role.pm     { color: var(--info); }
.user-role.editor { color: var(--success); }
.user-role.user   { color: var(--neutral); }

/* Pending config notification badge */
.pending-config-wrapper {
  position: relative;
  cursor: pointer;
  font-size: var(--font-size-base);
  color: var(--white-50);
  transition: color var(--transition-fast);
}

.pending-config-wrapper:hover {
  color: var(--white);
}

.pending-config-wrapper.has-pending {
  color: var(--warning);
}

.pending-config-count {
  position: absolute;
  top: -6px;
  right: -8px;
  background: var(--danger);
  color: var(--white);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  min-width: 16px;
  height: 16px;
  display: none;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-circle);
  line-height: 1;
}

.pending-config-wrapper.has-pending .pending-config-count {
  display: flex;
}

/* Affinity slider in chat */
.affinity-slider-container {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex: 1;
  padding: var(--space-1) var(--space-3);
  background: transparent;
}

.affinity-slider-container label {
  color: var(--black);
  font-size: var(--font-size-sm);
  white-space: nowrap;
}

.affinity-slider {
  flex: 1;
  -webkit-appearance: none;
  appearance: none;
  height: var(--space-3);
  background: linear-gradient(to right, var(--accent), var(--danger));
}

.affinity-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 20px;
  height: 20px;
  background: var(--affinity-thumb-color, var(--accent));
  border: var(--border-width-thick) solid var(--affinity-thumb-color, var(--accent));
  cursor: pointer;
}

.affinity-slider::-moz-range-thumb {
  width: 20px;
  height: 20px;
  background: var(--affinity-thumb-color, var(--accent));
  border: var(--border-width-thick) solid var(--affinity-thumb-color, var(--accent));
  cursor: pointer;
}

.affinity-value-display {
  min-width: 45px;
  text-align: center;
  color: var(--accent);
  font-weight: var(--font-weight-bold);
}

/* Analytics Summary Cards */
.analytics-card {
  display: flex;
  align-items: center;
  padding: var(--space-7);
  background: var(--black-10);
  border: var(--border-width-thin) solid var(--glass-border);
  transition: all var(--transition-slow);
}

.analytics-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 15px var(--black-10);
}

.analytics-card-chat,
.analytics-card-imagegen {
  border-left: 4px solid var(--accent);
}

.analytics-card-tts {
  border-left: 4px solid var(--info);
}

.analytics-card-icon {
  font-size: var(--font-size-3xl);
  margin-right: var(--space-7);
  opacity: 0.8;
}

.analytics-card-chat .analytics-card-icon,
.analytics-card-imagegen .analytics-card-icon {
  color: var(--accent);
}

.analytics-card-tts .analytics-card-icon {
  color: var(--info);
}

.analytics-card-content {
  flex: 1;
}

.analytics-card-title {
  font-size: var(--font-size-sm);
  color: var(--white-50);
  margin-bottom: var(--space-1);
}

.analytics-card-value {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-semibold);
  color: var(--white);
  line-height: var(--line-height-tight);
}

.analytics-card-detail {
  font-size: var(--font-size-xs);
  color: var(--white-50);
  margin-top: 2px;
}

.analytics-type-badge,
.analytics-mode-badge {
  font-weight: var(--font-weight-semibold);
  text-transform: uppercase;
  color: var(--white);
}

.analytics-type-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px;
  font-size: var(--font-size-xs);
}

.analytics-type-badge i {
  font-size: var(--font-size-xs);
}

.analytics-mode-badge {
  display: inline-block;
  padding: 2px 6px;
  font-size: var(--font-size-xs);
}

/* Cohort summary card variants */
.cohort-card-users .analytics-card-icon {
  color: var(--info);
}

.cohort-card-active .analytics-card-icon {
  color: var(--success);
}

.cohort-card-returning .analytics-card-icon {
  color: var(--accent);
}

.cohort-card-sessions .analytics-card-icon {
  color: var(--info);
}

/* ==============================
   7. UTILITIES
   ============================== */

/* Display */
.d-none { display: none !important; }
.d-block { display: block !important; }
.d-flex { display: flex !important; }

/* Flexbox */
.flex-wrap { flex-wrap: wrap !important; }
.flex-grow-1 { flex-grow: 1 !important; }
.align-items-center { align-items: center !important; }
.align-items-start { align-items: flex-start !important; }
.justify-content-between { justify-content: space-between !important; }
.justify-content-center { justify-content: center !important; }

/* Gap */
.gap-1 { gap: var(--space-1) !important; }
.gap-2 { gap: var(--space-3) !important; }
.gap-3 { gap: var(--space-7) !important; }

/* Margin */
.mt-1 { margin-top: var(--space-1) !important; }
.mt-2 { margin-top: var(--space-3) !important; }
.mt-3 { margin-top: var(--space-7) !important; }
.mt-4 { margin-top: var(--space-9) !important; }
.mb-0 { margin-bottom: 0 !important; }
.mb-2 { margin-bottom: var(--space-3) !important; }
.mb-3 { margin-bottom: var(--space-7) !important; }
.mb-4 { margin-bottom: var(--space-9) !important; }
.me-1 { margin-inline-end: var(--space-1) !important; }
.me-2 { margin-inline-end: var(--space-3) !important; }
.ms-auto { margin-inline-start: auto !important; }
.m-auto { margin: auto !important; }

/* Padding */
.p-3 { padding: var(--space-7) !important; }
.pt-3 { padding-top: var(--space-7) !important; }
.pb-0 { padding-bottom: 0 !important; }
.ps-3 { padding-inline-start: var(--space-7) !important; }
.py-2 { padding-block: var(--space-3) !important; }
.py-4 { padding-block: var(--space-9) !important; }

/* Text */
.text-muted { color: var(--white-50) !important; }
.text-light { color: var(--white) !important; }
.text-light-emphasis { color: rgba(255, 255, 255, 0.75) !important; }
.text-white { color: var(--white) !important; }
.text-dark { color: var(--black) !important; }
.text-danger { color: var(--danger) !important; }
.text-success { color: var(--success) !important; }
.text-info { color: var(--info) !important; }
.text-center { text-align: center !important; }
.text-end { text-align: end !important; }
.text-nowrap { white-space: nowrap !important; }
.text-truncate { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.fst-italic { font-style: italic !important; }
.small { font-size: var(--font-size-sm) !important; }

/* Background */
.bg-dark { background-color: var(--black) !important; }
.bg-success { background-color: var(--success) !important; }
.bg-danger { background-color: var(--danger) !important; }
.bg-warning { background-color: var(--warning) !important; }
.bg-info { background-color: var(--info) !important; }

/* Sizing */
.w-100 { width: 100% !important; }
.h-100 { height: 100% !important; }

/* Position */
.position-fixed { position: fixed !important; }
.bottom-0 { bottom: 0 !important; }
.end-0 { right: 0 !important; }

/* Border */
.border-0 { border: 0 !important; }
.border-secondary { border-color: var(--accent-secondary-50) !important; }

/* Opacity */
.opacity-75 { opacity: 0.75 !important; }

/* Grid */
.row { display: grid; grid-template-columns: repeat(12, 1fr); gap: var(--space-7); }
.g-3 { gap: var(--space-7); }
.col-6 { grid-column: span 6; }
.col-md-3 { grid-column: span 6; }
.col-md-4 { grid-column: span 12; }
.col-md-6 { grid-column: span 12; }

@media (min-width: 768px) {
  .col-md-3 { grid-column: span 3; }
  .col-md-4 { grid-column: span 4; }
  .col-md-6 { grid-column: span 6; }
}


/* ==============================
   8. OVERRIDES / RESPONSIVE
   ============================== */

/* Landscape blocker — hidden by default, shown on mobile landscape */
.landscape-blocker {
  display: none;
  position: fixed;
  inset: 0;
  z-index: var(--z-loading);
  background: url('../background.png') no-repeat center center fixed;
  background-size: cover;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-7);
  color: var(--white);
  font-size: var(--font-size-lg);
}

.landscape-blocker i {
  font-size: var(--font-size-4xl);
  color: var(--accent);
  animation: pulse 1.5s ease-in-out infinite;
}

@media (orientation: landscape) and (max-height: 500px) and (hover: none) and (pointer: coarse) {
  .landscape-blocker {
    display: flex;
  }
}

/* Mobile emulator: all circle buttons use consistent smaller size */
/* High specificity to override header-actions, chat-input, and chat-header rules */
.mobile-emulator .circle-btn {
  width: var(--space-10);
  height: var(--space-10);
  min-width: var(--space-10);
  min-height: var(--space-10);
  font-size: var(--font-size-xs);
}

.mobile-emulator .header-top-row {
  flex-wrap: wrap;
  gap: var(--space-1);
}

.mobile-emulator .turn-countdown {
  right: calc(50% - calc((100vh - 20px) * 9 / 19.5 / 2) - 10px);
  font-size: var(--font-size-xs);
}

/* Chat list in mobile emulator mode */
.chat-list-screen.mobile-emulator {
  max-width: calc((100vh - 20px) * 9 / 19.5);
  padding: 5px;
  font-size: var(--font-size-sm);
}

.chat-list-screen.mobile-emulator .chat-list-header {
  padding: 6px 10px;
  margin-bottom: var(--space-3);
}

.chat-list-screen.mobile-emulator .chat-list-avatar {
  width: 40px;
  height: 40px;
}

.chat-list-screen.mobile-emulator .chat-list-item {
  padding: 8px 10px;
  gap: var(--space-3);
}

/* Turn countdown label */
.turn-countdown {
  position: fixed;
  right: calc(50% - 430px);
  bottom: 80px;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  font-size: var(--font-size-xs);
  color: var(--black);
  font-weight: var(--font-weight-extrabold);
  letter-spacing: 1px;
  user-select: none;
  pointer-events: none;
  z-index: 10;
}


