/* Server card theme studio + themed card surfaces */

.sct-studio {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  margin-top: var(--space-5);
  padding: var(--space-4);
  border-radius: var(--radius-xl);
  border: 1px solid rgba(255, 255, 255, 0.08);
  background:
    linear-gradient(180deg, rgba(0, 212, 238, 0.04) 0%, transparent 40%),
    rgba(255, 255, 255, 0.02);
}
.sct-studio__header h2 {
  margin: 0 0 6px;
  font-size: 17px;
  font-weight: 700;
}
.sct-studio__header p {
  margin: 0;
  font-size: 13px;
  color: var(--muted);
  line-height: 1.45;
}

.sct-presets {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.sct-preset {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  padding: 10px 12px;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(0, 0, 0, 0.25);
  color: var(--text-secondary);
  cursor: pointer;
  text-align: left;
  transition: border-color var(--motion), background var(--motion), color var(--motion);
}
.sct-preset strong {
  font-size: 12px;
  color: var(--text);
}
.sct-preset span {
  font-size: 10px;
  opacity: 0.75;
}
.sct-preset:hover,
.sct-preset.selected {
  border-color: rgba(0, 212, 238, 0.45);
  background: rgba(0, 212, 238, 0.1);
  color: var(--text);
}

.sct-groups {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.sct-group h3 {
  margin: 0 0 10px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
}

.sct-slot {
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: var(--radius-lg);
  background: rgba(0, 0, 0, 0.18);
  margin-bottom: 8px;
}
.sct-slot__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  cursor: pointer;
  list-style: none;
}
.sct-slot__head::-webkit-details-marker { display: none; }
.sct-slot__label {
  font-size: 13px;
  font-weight: 600;
}
.sct-slot__preview {
  min-width: 28px;
  text-align: center;
}
.sct-slot__body {
  padding: 0 12px 12px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.sct-font-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 6px;
}
.sct-font-chip {
  padding: 8px 6px;
  border-radius: var(--radius-md);
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.03);
  color: var(--text-secondary);
  font-size: 10px;
  cursor: pointer;
  transition: border-color var(--motion), background var(--motion);
}
.sct-font-chip span {
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sct-font-chip:hover,
.sct-font-chip.selected {
  border-color: rgba(0, 212, 238, 0.45);
  background: rgba(0, 212, 238, 0.12);
  color: var(--text);
}

.sct-slot__row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.sct-slot__field {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 11px;
  color: var(--muted);
}
.sct-select {
  width: 100%;
  padding: 6px 8px;
  border-radius: var(--radius-md);
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(0, 0, 0, 0.35);
  color: var(--text);
  font-size: 12px;
}

.sct-slot__colors,
.sct-surface {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}
.sct-slot__colors-label,
.sct-surface__label {
  font-size: 11px;
  color: var(--muted);
  min-width: 48px;
}
.sct-swatches {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.sct-swatch {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, 0.15);
  background: var(--swatch);
  cursor: pointer;
  padding: 0;
  transition: transform var(--motion), border-color var(--motion);
}
.sct-swatch:hover { transform: scale(1.08); }
.sct-swatch.selected {
  border-color: #fff;
  box-shadow: 0 0 0 2px rgba(0, 212, 238, 0.5);
}
.sct-color-input {
  width: 32px;
  height: 26px;
  padding: 0;
  border: none;
  background: transparent;
  cursor: pointer;
}

/* Themed server card (owner preview) */
.server-card__shell.server-card--themed {
  background: var(--sct-panel-bg, var(--surface));
  border-color: var(--sct-panel-border, rgba(255, 255, 255, 0.1));
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--sct-accent, #00d4ee) 12%, transparent),
    0 12px 48px rgba(0, 0, 0, 0.35);
}
.server-card__shell.server-card--themed .server-card__input--name {
  font-family: var(--sct-title-font, var(--font-brutal));
  font-size: var(--sct-title-size, 20px);
  color: var(--sct-title-color, #fff);
  font-weight: var(--sct-title-weight, 900);
}
.server-card__shell.server-card--themed .server-card__input--tagline {
  font-family: var(--sct-tagline-font, var(--font-body));
  font-size: var(--sct-tagline-size, 12px);
  color: var(--sct-tagline-color, rgba(255, 255, 255, 0.55));
  font-weight: var(--sct-tagline-weight, 400);
}
.server-card__shell.server-card--themed .server-card__game-badge {
  font-family: var(--sct-badge-font, var(--font-body));
  font-size: var(--sct-badge-size, 11px);
  color: var(--sct-badge-color, rgba(255, 255, 255, 0.72));
  font-weight: var(--sct-badge-weight, 600);
}
.server-card__shell.server-card--themed .server-card__status-pill {
  font-family: var(--sct-status-font, var(--font-body));
  font-size: var(--sct-status-size, 11px);
  color: var(--sct-status-color, #86efac);
  font-weight: var(--sct-status-weight, 700);
}
.server-card__shell.server-card--themed .server-card__input--bio {
  font-family: var(--sct-description-font, var(--font-body));
  font-size: var(--sct-description-size, 14px);
  color: var(--sct-description-color, rgba(255, 255, 255, 0.88));
  font-weight: var(--sct-description-weight, 400);
}
.server-card__shell.server-card--themed .server-card__label {
  font-family: var(--sct-labels-font, var(--font-body));
  font-size: var(--sct-labels-size, 11px);
  color: var(--sct-labels-color, rgba(255, 255, 255, 0.45));
  font-weight: var(--sct-labels-weight, 600);
}
.server-card__shell.server-card--themed .server-card__input:not(.server-card__input--name):not(.server-card__input--bio):not(.server-card__input--tagline) {
  font-family: var(--sct-links-font, var(--font-body));
  font-size: var(--sct-links-size, 12px);
  color: var(--sct-links-color, rgba(255, 255, 255, 0.78));
  font-weight: var(--sct-links-weight, 400);
}
.server-card__shell.server-card--themed .server-card__tag {
  font-family: var(--sct-tags-font, var(--font-body));
  font-size: var(--sct-tags-size, 11px);
  color: var(--sct-tags-color, var(--accent-bright));
  font-weight: var(--sct-tags-weight, 600);
  background: var(--sct-tag-bg, rgba(255, 255, 255, 0.06));
  border-color: var(--sct-tag-border, rgba(255, 255, 255, 0.12));
}
.server-card--themed-caption.server-card__caption {
  font-family: var(--sct-caption-font, var(--font-body));
  font-size: var(--sct-caption-size, 11px);
  color: var(--sct-caption-color, rgba(255, 255, 255, 0.4));
  font-weight: var(--sct-caption-weight, 400);
}

.server-card__input--tagline {
  width: 100%;
  margin-top: 4px;
  padding: 0;
  border: none;
  background: transparent;
  text-align: center;
  outline: none;
}
.server-card__input--tagline::placeholder {
  color: rgba(255, 255, 255, 0.35);
}

/* Themed dock cards (Main tab) */
.dock-server-card__frame.server-card--themed {
  background: var(--sct-panel-bg, rgba(12, 16, 24, 0.96));
  border-color: var(--sct-panel-border, rgba(255, 255, 255, 0.1));
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--sct-accent, #00d4ee) 14%, transparent),
    0 8px 28px rgba(0, 0, 0, 0.35);
}
.dock-server-card__frame.server-card--themed .dock-server-card__banner-scrim {
  background: linear-gradient(180deg, transparent 0%, var(--sct-banner-scrim, rgba(7, 7, 13, 0.55)) 100%);
}
.dock-server-card__frame.server-card--themed .dock-server-card__name {
  font-family: var(--sct-title-font, var(--font-body));
  font-size: var(--sct-title-size, 15px);
  color: var(--sct-title-color, #fff);
  font-weight: var(--sct-title-weight, 800);
}
.dock-server-card__frame.server-card--themed .dock-server-card__meta {
  font-family: var(--sct-tagline-font, var(--font-body));
  font-size: var(--sct-tagline-size, 11px);
  color: var(--sct-tagline-color, rgba(255, 255, 255, 0.5));
  font-weight: var(--sct-tagline-weight, 400);
}
.dock-server-card__frame.server-card--themed .dock-server-card__tag {
  font-family: var(--sct-tags-font, var(--font-body));
  font-size: var(--sct-tags-size, 10px);
  color: var(--sct-tags-color, var(--accent-bright));
  font-weight: var(--sct-tags-weight, 600);
  background: var(--sct-tag-bg, rgba(255, 255, 255, 0.06));
  border-color: var(--sct-tag-border, rgba(255, 255, 255, 0.12));
}
.dock-server-card__frame.server-card--themed .dock-server-card__status {
  font-family: var(--sct-status-font, var(--font-body));
  font-size: var(--sct-status-size, 10px);
  color: var(--sct-status-color, #86efac);
  font-weight: var(--sct-status-weight, 700);
}
.dock-server-card__frame.server-card--themed .dock-server-card__players {
  font-family: var(--sct-players-font, var(--font-body));
  font-size: var(--sct-players-size, 12px);
  color: var(--sct-players-color, var(--accent-bright));
  font-weight: var(--sct-players-weight, 700);
}
.dock-server-card__frame.server-card--themed .dock-server-card__players strong {
  color: inherit;
}
.dock-server-card__frame.server-card--themed .dock-server-card__pop-bar span {
  background: var(--sct-accent, var(--accent));
}

@media (max-width: 480px) {
  .sct-presets {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .sct-font-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
