/*
 * Democracy Defense - Mastodon Custom Theme
 * Style: A+C Hybrid (Professional/Institutional + Tech/Modern)
 *
 * Color Palette:
 * - Deep Navy: #0A1628 (background)
 * - Oxford Blue: #14304D (cards)
 * - Electric Blue: #3A76F0 (primary accent - Signal-inspired)
 * - Signal Red: #E11D48 (warnings/ethical constraints)
 * - Verified Green: #22C55E (success states)
 * - Silver: #E8ECF1 (text)
 * - Slate: #8B949E (secondary text)
 */

/* ===== CSS Variables ===== */
:root {
  --dd-deep-navy: #0A1628;
  --dd-oxford-blue: #14304D;
  --dd-electric-blue: #3A76F0;
  --dd-signal-red: #E11D48;
  --dd-verified-green: #22C55E;
  --dd-amber: #F59E0B;
  --dd-silver: #E8ECF1;
  --dd-slate: #8B949E;
  --dd-border: #30363D;
}

/* ===== Base Background ===== */
body,
.ui,
.column > .scrollable,
.drawer__inner,
.drawer__inner.darker {
  background: var(--dd-deep-navy) !important;
}

/* ===== Column Headers ===== */
.column-header,
.column-header__wrapper,
.column-header--slim {
  background: linear-gradient(180deg, var(--dd-oxford-blue) 0%, var(--dd-deep-navy) 100%) !important;
  border-bottom: 2px solid var(--dd-electric-blue) !important;
}

.column-header__title,
.column-header__back-button {
  color: var(--dd-silver) !important;
}

/* ===== Cards and Posts ===== */
.status,
.detailed-status,
.account-card,
.notification {
  background: var(--dd-oxford-blue) !important;
  border: 1px solid var(--dd-border) !important;
  border-radius: 8px !important;
  margin-bottom: 8px !important;
}

.status:hover,
.notification:hover {
  background: rgba(58, 118, 240, 0.05) !important;
  border-color: var(--dd-electric-blue) !important;
}

.status__content,
.status__display-name,
.detailed-status__display-name,
.account__display-name strong {
  color: var(--dd-silver) !important;
}

.status__relative-time,
.detailed-status__meta,
.account__relationship {
  color: var(--dd-slate) !important;
}

/* ===== Primary Buttons ===== */
.button,
.button:active,
.button:focus,
.button:hover {
  background: var(--dd-electric-blue) !important;
  color: white !important;
  border-radius: 8px !important;
  font-weight: 600 !important;
  transition: background 0.2s ease, transform 0.15s ease !important;
}

.button:hover {
  background: #2563EB !important;
  transform: scale(1.02) !important;
}

.button:focus {
  outline: 2px solid var(--dd-electric-blue) !important;
  outline-offset: 2px !important;
}

/* Secondary/Danger Buttons */
.button.button-secondary {
  background: transparent !important;
  border: 1px solid var(--dd-electric-blue) !important;
  color: var(--dd-electric-blue) !important;
}

.button.button--destructive {
  background: var(--dd-signal-red) !important;
}

/* ===== Links ===== */
a,
.status__content a,
.account__header__bio a {
  color: var(--dd-electric-blue) !important;
}

a:hover {
  color: #5B93F5 !important;
}

/* ===== Compose Area ===== */
.compose-form,
.compose-form .compose-form__publish {
  background: var(--dd-deep-navy) !important;
}

.compose-form .autosuggest-textarea__textarea,
.compose-form .spoiler-input__input {
  background: var(--dd-oxford-blue) !important;
  border: 1px solid var(--dd-border) !important;
  border-radius: 8px !important;
  color: var(--dd-silver) !important;
}

.compose-form .autosuggest-textarea__textarea:focus,
.compose-form .spoiler-input__input:focus {
  border-color: var(--dd-electric-blue) !important;
}

.compose-form .compose-form__buttons button {
  color: var(--dd-slate) !important;
}

.compose-form .compose-form__buttons button:hover {
  color: var(--dd-electric-blue) !important;
}

/* ===== Navigation and Tabs ===== */
.tabs-bar,
.getting-started,
.getting-started__wrapper {
  background: var(--dd-deep-navy) !important;
}

.tabs-bar__link,
.column-link {
  color: var(--dd-slate) !important;
}

.tabs-bar__link:hover,
.tabs-bar__link.active,
.column-link:hover,
.column-link--transparent.active {
  color: var(--dd-silver) !important;
  background: rgba(58, 118, 240, 0.1) !important;
}

.tabs-bar__link.active::before {
  background: var(--dd-electric-blue) !important;
}

/* ===== Custom Header Logo ===== */
.navigation-panel__logo {
  background-image: url('https://d2nkcz0d5kpg1u.cloudfront.net/site_uploads/files/000/000/003/original/30c7d40594618cbb.png') !important;
  background-size: 36px 36px !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  min-height: 44px !important;
}

.navigation-panel__logo svg {
  display: none !important;
}

.drawer__header .logo {
  background-image: url('https://d2nkcz0d5kpg1u.cloudfront.net/site_uploads/files/000/000/003/original/30c7d40594618cbb.png') !important;
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  width: 36px !important;
  height: 36px !important;
}

.drawer__header .logo svg {
  display: none !important;
}

/* ===== Drawers ===== */
.drawer__header,
.drawer__header a {
  background: var(--dd-oxford-blue) !important;
  color: var(--dd-silver) !important;
}

.drawer__pager,
.search {
  background: var(--dd-deep-navy) !important;
}

.search__input {
  background: var(--dd-oxford-blue) !important;
  border: 1px solid var(--dd-border) !important;
  color: var(--dd-silver) !important;
}

.search__input:focus {
  border-color: var(--dd-electric-blue) !important;
}

/* ===== Action Bar Icons ===== */
.status__action-bar button,
.detailed-status__action-bar button,
.icon-button {
  color: var(--dd-slate) !important;
}

.status__action-bar button:hover,
.detailed-status__action-bar button:hover,
.icon-button:hover {
  color: var(--dd-electric-blue) !important;
}

.icon-button.active.star-icon,
.status__action-bar button.star-icon.active {
  color: var(--dd-amber) !important;
}

.icon-button.active,
.status__action-bar button.active:not(.star-icon) {
  color: var(--dd-electric-blue) !important;
}

/* ===== Notifications ===== */
.notification__filter-bar button.active {
  color: var(--dd-electric-blue) !important;
  border-bottom-color: var(--dd-electric-blue) !important;
}

/* ===== Verified/Success States ===== */
.verified-badge,
.trends__item__current {
  color: var(--dd-verified-green) !important;
}

/* ===== Warning/Alert States ===== */
.status__content__spoiler-link,
.dismissable-banner {
  background: var(--dd-signal-red) !important;
  color: white !important;
}

/* ===== Modals ===== */
.modal-root__modal,
.confirmation-modal,
.mute-modal,
.report-modal,
.embed-modal,
.actions-modal {
  background: var(--dd-oxford-blue) !important;
  border: 1px solid var(--dd-border) !important;
}

.modal-root__modal .modal-header,
.confirmation-modal__action-bar,
.mute-modal__action-bar {
  background: var(--dd-deep-navy) !important;
}

/* ===== Dropdown Menus ===== */
.dropdown-menu {
  background: var(--dd-oxford-blue) !important;
  border: 1px solid var(--dd-border) !important;
  border-radius: 8px !important;
}

.dropdown-menu__item a,
.dropdown-menu__item button {
  color: var(--dd-silver) !important;
}

.dropdown-menu__item a:hover,
.dropdown-menu__item button:hover {
  background: rgba(58, 118, 240, 0.1) !important;
}

/* ===== Account Profiles ===== */
.account__header {
  background: var(--dd-oxford-blue) !important;
}

.account__header__bar {
  background: var(--dd-deep-navy) !important;
  border-bottom: 1px solid var(--dd-border) !important;
}

.account__header__bio {
  color: var(--dd-silver) !important;
}

.account__header__fields dt {
  color: var(--dd-slate) !important;
}

.account__header__fields dd {
  color: var(--dd-silver) !important;
}

.account__header__fields .verified dd {
  color: var(--dd-verified-green) !important;
  border-color: var(--dd-verified-green) !important;
}

/* ===== Scrollbars (Webkit) ===== */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-track {
  background: var(--dd-deep-navy);
}

::-webkit-scrollbar-thumb {
  background: var(--dd-oxford-blue);
  border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--dd-electric-blue);
}

/* ===== Forms and Inputs ===== */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
textarea,
select {
  background: var(--dd-oxford-blue) !important;
  border: 1px solid var(--dd-border) !important;
  color: var(--dd-silver) !important;
  border-radius: 8px !important;
}

input:focus,
textarea:focus,
select:focus {
  border-color: var(--dd-electric-blue) !important;
  outline: none !important;
}

/* ===== Admin Panel ===== */
.admin-wrapper .sidebar,
.admin-wrapper .sidebar-menu {
  background: var(--dd-deep-navy) !important;
}

.admin-wrapper .sidebar-menu__item a {
  color: var(--dd-silver) !important;
}

.admin-wrapper .sidebar-menu__item a:hover,
.admin-wrapper .sidebar-menu__item a.selected {
  background: rgba(58, 118, 240, 0.1) !important;
  color: var(--dd-electric-blue) !important;
}

.admin-wrapper .content-wrapper {
  background: var(--dd-deep-navy) !important;
}

/* ===== Tables ===== */
.table,
.batch-table__row,
.log-entry {
  background: var(--dd-oxford-blue) !important;
  border-color: var(--dd-border) !important;
}

.table thead th,
.batch-table__toolbar {
  background: var(--dd-deep-navy) !important;
  color: var(--dd-silver) !important;
}

/* ===== Landing Page / About ===== */
.landing-page,
.about-page,
.public-layout {
  background: var(--dd-deep-navy) !important;
}

.landing-page__information,
.landing-page__short-description,
.rich-formatting {
  color: var(--dd-silver) !important;
}

.landing-page h1,
.landing-page h2,
.landing-page h3,
.about-page h1,
.about-page h2 {
  color: var(--dd-silver) !important;
}

.hero-widget {
  background: var(--dd-oxford-blue) !important;
  border: 1px solid var(--dd-border) !important;
  border-radius: 8px !important;
}

/* ===== Server Rules Display ===== */
.rules-list li::before {
  background: var(--dd-electric-blue) !important;
}

/* ===== Hashtags and Trends ===== */
.trends__item,
.story {
  background: var(--dd-oxford-blue) !important;
  border-radius: 8px !important;
}

.trends__item:hover,
.story:hover {
  background: rgba(58, 118, 240, 0.1) !important;
}

.trends__item__name a {
  color: var(--dd-silver) !important;
}

/* ===== Privacy Badge for Democracy Defense ===== */
.status__wrapper::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: transparent;
  border-radius: 3px 0 0 3px;
}

/* ===== Focus States for Accessibility ===== */
*:focus-visible {
  outline: 2px solid var(--dd-electric-blue) !important;
  outline-offset: 2px !important;
}

/* ===== Print Styles ===== */
@media print {
  body {
    background: white !important;
    color: black !important;
  }

  .status__content {
    color: black !important;
  }
}

/* ===== Dark Mode Override (ensure consistency) ===== */
@media (prefers-color-scheme: dark) {
  :root {
    color-scheme: dark;
  }
}


