@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700&family=Roboto:wght@400;500;700&family=Open+Sans:wght@400;600;700&family=Lato:wght@400;700&family=Montserrat:wght@400;600;700&family=Poppins:wght@400;600;700&family=Space+Grotesk:wght@500;700&family=Merriweather:wght@400;700&family=Playfair+Display:wght@500;700&family=JetBrains+Mono:wght@400;600&family=IBM+Plex+Mono:wght@400;600&family=Source+Code+Pro:wght@400;600&display=swap");

@font-face {
  font-family: "Pokemon Solid";
  src: url("/pokemon/Pokemon%20Solid.ttf") format("truetype");
  font-style: normal;
  font-weight: 400;
  font-display: swap;
}

@font-face {
  font-family: "Pokemon Hollow";
  src: url("/pokemon/Pokemon%20Hollow.ttf") format("truetype");
  font-style: normal;
  font-weight: 400;
  font-display: swap;
}

:root {
  overflow-x: hidden;
  overflow-y: auto;
  color-scheme: dark;
  --brand-background-image: none;
  --pro-overlay-color: rgba(255, 255, 255, 0.92);
  --ui-font-sans: ui-sans-serif, "Inter", "Segoe UI", sans-serif;
  --ui-font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  --brand-font-primary: ui-sans-serif, "Inter", "Segoe UI", sans-serif;
  --brand-font-secondary: ui-sans-serif, "Inter", "Segoe UI", sans-serif;
  --brand-font-heading: var(--brand-font-primary);
  --brand-font-mono: "JetBrains Mono", "IBM Plex Mono", "Share Tech Mono", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  --brand-text-scale-primary: 1;
  --brand-text-scale-secondary: 1;
  font-family: var(--ui-font-sans);
  font-size: 16px;
  --brand-background: #000000;
  --brand-surface: #0b0b0b;
  --brand-surface-alt: #0f1116;
  --brand-border: #171717;
  --brand-border-strong: #1a1a1a;
  --brand-text-primary: #f5f7fa;
  --brand-text-secondary: #9aa29b;
  --brand-text-muted: #7f7f7f;
  --brand-accent: #03ff0a;
  --brand-accent-soft: #6dff81;
  --brand-accent-contrast: #052b1a;
  --brand-danger: #ff4f6f;
  --brand-danger-soft: #ff8f92;
  --brand-warning: #f7b955;
  --brand-warning-soft: #facc15;
  --shell-background: #060910;
  --shell-surface: #0d111d;
  --shell-surface-alt: #13182a;
  --shell-border: #1e2436;
  --shell-border-strong: #272f47;
  --shell-text-primary: #f5f7fb;
  --shell-text-secondary: #c2c9dd;
  --shell-text-muted: #8a94b6;
  --shell-accent: #4f8cff;
  --grid-item-selected-outline: color-mix(in srgb, var(--brand-accent) 65%, transparent);
  --grid-item-selected-glow: color-mix(in srgb, var(--brand-accent) 35%, transparent);
  --ghost-button-border: color-mix(in srgb, var(--shell-text-muted) 45%, transparent);
  --ghost-button-border-hover: color-mix(in srgb, var(--shell-text-muted) 75%, transparent);
  --brand-radius-lg: 26px;
  --brand-radius: 18px;
  --brand-radius-md: 16px;
  --brand-radius-sm: 14px;
  --brand-radius-xs: 8px;
}

body {
  background-color: var(--brand-background);
  background-image: var(--brand-background-image);
  background-size: cover;
  background-repeat: no-repeat;
  background-attachment: fixed;
}

* {
  box-sizing: border-box;
}

.icon {
  width: 1.2em;
  height: 1.2em;
  display: inline-block;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

body {
  margin: 0;
  min-height: 100vh;
  background-color: var(--brand-background);
  background-image: var(--brand-background-image);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  color: var(--shell-text-primary);
  display: flex;
  justify-content: center;
  overflow-x: hidden;
  overflow-y: auto;
}

body.admin-page {
  display: block;
  justify-content: initial;
  align-items: initial;
  padding: 0 16px 32px;
  width: 100%;
  max-width: 100%;
}

.invite-page {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  background: #0d1117;
  color: #f2f4f8;
}

.invite-container {
  max-width: 480px;
  width: 100%;
  padding: 24px;
}

.invite-card {
  background: #111827;
  border: 1px solid #1f2937;
  border-radius: 12px;
  padding: 24px;
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.35);
}

.invite-card h1 {
  margin: 0 0 12px;
  font-family: var(--brand-font-primary);
  font-size: calc(1.25rem * var(--brand-text-scale-primary));
}

.invite-details {
  margin-bottom: 16px;
  color: #cdd5e0;
}

.invite-form label {
  display: block;
  margin-bottom: 12px;
}

.invite-form input {
  width: 100%;
  padding: 10px 12px;
  border-radius: 8px;
  border: 1px solid #1f2937;
  background: #0b1220;
  color: #e5e7eb;
}

.invite-form button {
  width: 100%;
  padding: 12px;
  border: none;
  border-radius: 8px;
  background: #10b981;
  color: #0b1220;
  font-weight: 700;
  cursor: pointer;
}

.invite-form button:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

body[data-template="professional"] {
  color-scheme: light;
  background-color: var(--brand-background, #f8fafc);
  background-image: var(--brand-background-image, linear-gradient(135deg, #e2e8f0, #f8fafc));
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  color: var(--brand-text-primary, #0f172a);
  --pro-panel-background: var(--pro-overlay-color, rgba(255, 255, 255, 0.92));
  --pro-panel-border: color-mix(in srgb, var(--brand-border, rgba(15, 23, 42, 0.35)) 80%, transparent);
  --pro-panel-shadow: 0 35px 80px color-mix(in srgb, var(--brand-border, rgba(15, 23, 42, 0.18)) 40%, transparent);
  --pro-text-primary: var(--brand-text-primary, #0f172a);
  --pro-text-secondary: var(--brand-text-secondary, #475569);
  --pro-text-muted: var(--brand-text-muted, #94a3b8);
  --pro-accent: var(--brand-accent, #2563eb);
  --pro-accent-soft: var(--brand-accent-soft, #93c5fd);
  --pro-accent-contrast: var(--brand-accent-contrast, #052b1a);
  --pro-danger: var(--brand-danger, #b91c1c);
  --pro-danger-soft: var(--brand-danger-soft, #fecdd3);
  --pro-warning: var(--brand-warning, #facc15);
  --pro-warning-soft: var(--brand-warning-soft, #fde68a);
  --pro-border-strong: color-mix(in srgb, var(--brand-border-strong, #1a1a1a) 35%, transparent);
  --pro-border-soft: color-mix(in srgb, var(--brand-border, #0f172a) 12%, transparent);
  --pro-surface: color-mix(in srgb, var(--brand-surface, #f8fafc) 85%, transparent);
  --pro-surface-alt: color-mix(in srgb, var(--brand-surface-alt, #e2e8f0) 80%, transparent);
}

body[data-template="professional"] .app {
  background: transparent;
  padding: clamp(24px, 4vw, 48px);
  max-width: 1560px;
}

body[data-template="professional"] .app.overlay-disabled {
  --pro-panel-background: transparent;
  --pro-panel-border: color-mix(in srgb, var(--brand-text-primary, #f5f7fa) 25%, transparent);
  --pro-panel-shadow: none;
  backdrop-filter: none;
}

#root {
  flex: 1;
  display: flex;
}

.app {
  --simple-shell-padding: clamp(20px, 4vw, 36px);
  width: 100%;
  min-height: 100vh;
  margin: 0 auto;
  padding: var(--simple-shell-padding);
  display: flex;
  flex-direction: column;
  gap: clamp(14px, 2.4vw, 22px);
  background: var(--brand-background);
}

.app.has-background-image {
  background: transparent;
  backdrop-filter: none;
}

.has-background-image .app {
  background: transparent;
  backdrop-filter: none;
}

.app.has-background-image.overlay-disabled {
  background: transparent;
  backdrop-filter: none;
}

body[data-template="professional"] .app.has-background-image {
  background: transparent;
  backdrop-filter: none;
}

.template-simple .header {
  position: relative;
  /* padding-top: clamp(90px, 12vw, 160px); */
}

.template-simple .brand-logo-wrapper {
  position: absolute;
  top: calc(-0.6 * var(--simple-shell-padding, 24px));
  left: 50%;
  transform: translate(-50%, 0);
  width: min(780px, calc(100% - 2 * var(--simple-shell-padding, 24px)));
  display: inline-flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  z-index: 2;
}

.template-simple .brand-logo-wrapper img.brand-logo {
  display: block;
  max-width: min(640px, 60vw);
  height: auto;
}

.template-simple .header-top {
  margin-top: clamp(40px, 6vw, 60px);
}

.template-simple.app.is-livestream .status-pill {
  position: absolute;
  top: calc(0px - 0.3 * var(--simple-shell-padding, 24px));
  right: clamp(18px, 4vw, 48px);
  z-index: 3;
}

@media (max-width: 1100px) {
  body[data-template="simple"] {
    padding: clamp(10px, 4vw, 20px);
  }

  body[data-template="simple"] .app,
  .app.template-simple {
    padding: clamp(16px, 4vw, 22px);
    border-radius: 20px;
    box-shadow: 0 15px 40px rgba(0, 0, 0, 0.45);
  }

  body[data-template="simple"] .brand-logo,
  .app.template-simple .brand-logo {
    height: clamp(56px, 24vw, 96px) !important;
    max-width: 90%;
  }
}

.template-professional.pro-app {
  gap: clamp(20px, 2vw, 32px);
}

.pro-hero {
  display: flex;
  flex-direction: column;
  gap: clamp(18px, 2vw, 28px);
  background: var(--pro-panel-background);
  border-radius: 0;
  padding: clamp(24px, 3vw, 36px);
  border: 1px solid var(--pro-panel-border);
  box-shadow: var(--pro-panel-shadow);
}

.pro-hero__brand {
  display: flex;
  gap: clamp(18px, 2vw, 28px);
  align-items: flex-start;
}

.pro-hero__logo {
  width: clamp(90px, 12vw, 140px);
  height: auto;
  object-fit: contain;
}

.pro-hero__eyebrow {
  margin: 0 0 4px;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  font-family: var(--brand-font-heading);
  font-size: calc(0.7rem * var(--brand-text-scale-primary));
  color: var(--pro-text-muted, #94a3b8);
}

.pro-hero__mint {
  margin: 8px 0 0;
  color: var(--pro-text-secondary, #475569);
  font-size: 0.9rem;
}

.pro-hero__mint a {
  color: var(--pro-accent, var(--brand-accent, #2563eb));
  text-decoration: none;
  margin-left: 6px;
}

.pro-hero__links {
  margin-top: 16px;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.pro-hero__brand h1 {
  margin: 0;
  font-size: calc(clamp(1.6rem, 5vw, 2.4rem) * var(--brand-text-scale-primary));
  color: var(--pro-text-primary, #0f172a);
}

.pro-status-chip {
  align-self: flex-start;
  padding: 6px 18px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--pro-text-primary, #0f172a) 80%, transparent);
  border: 1px solid var(--pro-border-strong);
  font-weight: 600;
  letter-spacing: 0.18em;
  color: var(--pro-surface, #f8fafc);
}

.pro-status-chip.is-live {
  background: var(--pro-accent, #22c55e);
  border-color: transparent;
  color: var(--pro-accent-contrast, #052e16);
}

.pro-status-caption {
  font-size: 0.85rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--pro-text-muted, #94a3b8);
}

.pro-hero__meta {
  margin-top: 18px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

.pro-hero__status-pill {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.pro-hero__next {
  display: flex;
  flex-direction: column;
  gap: 2px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.72rem;
  color: var(--pro-text-secondary, #475569);
}

.pro-hero__next strong {
  font-size: clamp(1.4rem, 4vw, 2rem);
  letter-spacing: 0.18em;
  color: var(--pro-text-primary, #0f172a);
}

.pro-control {
  border: 1px solid transparent;
  border-radius: 16px;
  padding: 12px 18px;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  cursor: pointer;
  background: var(--pro-accent, #2563eb);
  color: var(--pro-accent-contrast, #052b1a);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.pro-control[data-state="stop"] {
  background: transparent;
  color: var(--pro-text-primary, #0f172a);
  border: 1px solid color-mix(in srgb, var(--pro-text-muted, #94a3b8) 30%, transparent);
}

.pro-control:hover {
  transform: translateY(-1px);
  box-shadow: 0 20px 40px color-mix(in srgb, var(--pro-accent, #2563eb) 25%, transparent);
}

.pro-link {
  border-radius: 0;
  border: 1px solid var(--pro-border-strong);
  padding: 10px 18px;
  font-size: 0.78rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--pro-text-primary, #0f172a);
  background: color-mix(in srgb, var(--pro-surface-alt, rgba(148, 163, 184, 0.15)) 60%, transparent);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
}

.pro-link--accent {
  background: linear-gradient(120deg, var(--pro-accent-soft, #22d3ee), var(--pro-accent, #2563eb));
  color: var(--pro-accent-contrast, #052b1a);
  border: none;
}

.pro-link--ghost {
  background: transparent;
  border-color: var(--pro-border-soft);
}

.pro-snapshot {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: clamp(14px, 2vw, 20px);
}

.pro-card {
  background: var(--pro-panel-background);
  border-radius: 0;
  padding: 20px;
  border: 1px solid var(--pro-panel-border);
  display: grid;
  gap: 12px;
  box-shadow: var(--pro-panel-shadow);
}

.pro-card header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.pro-card__label {
  font-size: 0.8rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--pro-text-muted, #94a3b8);
}

.pro-card__meta {
  font-size: 0.85rem;
  color: var(--pro-text-secondary, #475569);
}

.pro-card__content {
  display: flex;
  gap: 12px;
  align-items: center;
}

.holder-eligibility {
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  width: 100%;
}

.holder-eligibility__stat {
  flex: 1 1 200px;
  min-width: 160px;
}

.holder-eligibility__stat--holders {
  text-align: right;
}

@media (max-width: 1100px) {
  .holder-eligibility__stat--holders {
    text-align: left;
  }
}

.pro-card__logo {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  object-fit: cover;
  border: 1px solid var(--pro-border-strong);
}

.pro-card__value {
  margin: 0;
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--pro-text-primary, #0f172a);
}

.pro-card__sub {
  margin: 4px 0;
  font-size: 0.85rem;
  color: var(--pro-text-secondary, #475569);
}

.pro-card__link {
  font-size: 0.78rem;
  color: var(--pro-accent, #2563eb);
  text-decoration: none;
}

.pro-card__link.is-disabled {
  color: var(--pro-text-muted, #94a3b8);
  cursor: default;
}

.pro-card--countdown {
  text-align: center;
}

.pro-countdown {
  margin: 8px 0 0;
  font-size: clamp(2rem, 4vw, 2.8rem);
  font-weight: 600;
  letter-spacing: 0.2em;
}

.pro-card--metrics {
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}

.pro-main-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: clamp(16px, 2vw, 24px);
}

.pro-panel {
  background: var(--pro-panel-background);
  border-radius: 0;
  border: 1px solid var(--pro-panel-border);
  box-shadow: var(--pro-panel-shadow);
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.pro-panel__header {
  padding: 20px 24px 0;
  display: flex;
  justify-content: space-between;
  gap: 12px;
}

.pro-panel__header h2 {
  margin: 0;
  font-size: calc(1.1rem * var(--brand-text-scale-primary));
  color: var(--pro-text-primary, #0f172a);
}

.pro-panel__header p {
  margin: 4px 0 0;
  color: var(--pro-text-secondary, #475569);
  font-size: 0.9rem;
}

.pro-panel__actions {
  display: flex;
  align-items: flex-start;
}

.pro-panel__body {
  padding: 16px 24px 24px;
  min-height: 0;
}

.pro-activity-log {
  max-height: 420px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.pro-activity-item {
  padding: 14px 16px;
  border-radius: 0;
  border: 1px solid var(--pro-border-soft);
  background: var(--pro-surface-alt);
}

.pro-activity-meta {
  display: flex;
  justify-content: space-between;
  font-size: 0.82rem;
  color: var(--pro-text-secondary, #475569);
  margin-bottom: 6px;
  gap: 10px;
  flex-wrap: wrap;
}

.pro-activity-headline {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--pro-text-primary, #0f172a);
}

.pro-activity-detail {
  margin: 4px 0 0;
  font-size: 0.88rem;
  color: var(--pro-text-secondary, #475569);
}

.pro-tag {
  text-transform: uppercase;
  letter-spacing: 0.2em;
  font-size: 0.68rem;
  border: 1px solid var(--pro-border-soft);
  border-radius: 0;
  padding: 2px 10px;
  color: var(--pro-text-secondary, #475569);
}

.pro-tag--error {
  border-color: color-mix(in srgb, var(--pro-danger, #b91c1c) 50%, transparent);
  color: var(--pro-danger, #b91c1c);
  background: color-mix(in srgb, var(--pro-danger-soft, #fecdd3) 40%, transparent);
}

.pro-tag--success {
  border-color: color-mix(in srgb, var(--pro-accent, #22c55e) 50%, transparent);
  color: var(--pro-accent, #22c55e);
  background: color-mix(in srgb, var(--pro-accent-soft, #bbf7d0) 35%, transparent);
}

.pro-tag--warn,
.pro-tag--warning {
  border-color: color-mix(in srgb, var(--pro-warning, #facc15) 50%, transparent);
  color: var(--pro-warning, #facc15);
  background: color-mix(in srgb, var(--pro-warning-soft, #fde68a) 35%, transparent);
}

.pro-tag--info {
  border-color: color-mix(in srgb, var(--pro-text-muted, #94a3b8) 40%, transparent);
  color: var(--pro-text-muted, #94a3b8);
}

.pro-empty {
  margin: 0;
  color: var(--pro-text-muted, #94a3b8);
}

.pro-donation-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.pro-donation-item {
  padding: 12px 0;
  border-bottom: 1px solid var(--pro-border-soft);
  display: flex;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.pro-donation-name {
  margin: 0;
  font-weight: 600;
}

.pro-donation-amount {
  color: var(--pro-accent, #2563eb);
  font-weight: 600;
}

.pro-donation-meta {
  font-size: 0.82rem;
  color: var(--pro-text-secondary, #475569);
  display: flex;
  gap: 12px;
}

.pro-donation-meta a {
  color: var(--pro-accent, #2563eb);
  text-decoration: none;
}

.pro-error {
  color: var(--pro-danger, #b91c1c);
}

.pro-muted {
  color: var(--pro-text-muted, #94a3b8);
}

.pro-table-wrapper {
  overflow-x: auto;
}

.pro-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}

.pro-table th {
  text-align: left;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.72rem;
  color: var(--pro-text-muted, #94a3b8);
  padding-bottom: 8px;
}

.pro-table td {
  padding: 10px 0;
  border-bottom: 1px solid var(--pro-border-soft);
}

.pro-vote-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
  padding: 0 24px 24px;
}

.pro-vote-card {
  border: 1px solid var(--pro-border-soft);
  border-radius: 18px;
  padding: 14px 16px;
  background: var(--pro-surface);
  display: grid;
  gap: 12px;
}

.pro-vote-card.is-active {
  border-color: var(--pro-accent, #2563eb);
  box-shadow: 0 18px 36px color-mix(in srgb, var(--pro-accent, #2563eb) 35%, transparent);
}

.pro-vote-card__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
}

.pro-vote-card__head p {
  margin: 0;
  font-weight: 600;
  color: var(--pro-text-primary, #0f172a);
}

.pro-vote-card__head span {
  font-size: 0.78rem;
  color: var(--pro-text-muted, #94a3b8);
  text-transform: uppercase;
  letter-spacing: 0.14em;
}

.pro-progress {
  background: color-mix(in srgb, var(--pro-text-muted, #94a3b8) 20%, transparent);
  border-radius: 0;
  height: 8px;
  overflow: hidden;
}

.pro-progress span {
  display: block;
  height: 100%;
  background: linear-gradient(120deg, var(--pro-accent-soft, #22d3ee), var(--pro-accent, #2563eb));
}

.pro-footer {
  background: var(--pro-panel-background);
  color: var(--pro-text-primary, #e2e8f0);
  border-radius: 0;
  padding: clamp(24px, 3vw, 36px);
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  border: 1px solid var(--pro-panel-border);
  box-shadow: var(--pro-panel-shadow);
}

.pro-footer h3 {
  margin: 0 0 8px;
}

.pro-footer p {
  margin: 0 0 16px;
  color: var(--pro-text-secondary, #475569);
}

.pro-footer__links {
  display: flex;
  gap: 12px;
}

.pro-footer__art {
  max-width: 340px;
  border-radius: 0;
  width: 100%;
  border: 1px solid var(--pro-border-soft);
}

.pro-footer__placeholder {
  font-size: 0.85rem;
  color: var(--pro-text-secondary, #475569);
  border: 1px dashed color-mix(in srgb, var(--pro-text-muted, #94a3b8) 40%, transparent);
  border-radius: 0;
  padding: 18px;
}

body[data-template="terminal"] {
  --brand-font-heading: var(--brand-font-mono);
  background-color: var(--brand-background, #010a05);
  background-image: var(--brand-background-image, none);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  color: var(--brand-text-primary, #57ff9c);
  font-family: var(--brand-font-mono);
  align-items: stretch;
}

.project-console-shell__header,
.project-console-shell__sidebar,
.project-console__header,
.project-console__tabs,
.project-console__tabstack {
  --brand-font-primary: var(--ui-font-sans);
  --brand-font-secondary: var(--ui-font-sans);
  --brand-font-heading: var(--ui-font-sans);
  --brand-font-mono: var(--ui-font-mono);
  --brand-text-scale-primary: 1;
  --brand-text-scale-secondary: 1;
}

body[data-template="terminal"] #root {
  width: 100%;
}

body[data-template="terminal"] .app {
  max-width: none;
  width: min(1880px, calc(100vw - clamp(24px, 8vw, 160px)));
  background: color-mix(in srgb, var(--brand-background, #000000) 85%, #000000 15%);
  padding: clamp(20px, 3vw, 40px);
  margin: 0 auto;
}

.terminal-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: clamp(16px, 2vw, 32px);
  align-items: stretch;
  width: 100%;
}

.terminal-layout--with-aside {
  grid-template-columns: minmax(200px, 0.4fr) minmax(0, 1.6fr);
}

.terminal-aside {
  border: 1px solid color-mix(in srgb, var(--brand-accent, #57ff9c) 25%, transparent);
  padding: 6px;
  background: rgba(0, 0, 0, 0.4);
  display: flex;
  align-items: flex-start;
  justify-content: center;
}

.terminal-aside img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.terminal-app a {
  color: var(--brand-accent, #57ff9c);
}

.terminal-window {
  position: relative;
  background: radial-gradient(
      circle at top left,
      color-mix(in srgb, var(--brand-accent, #57ff9c) 10%, transparent),
      transparent 55%
    ),
    color-mix(in srgb, var(--brand-background, #010a05) 85%, #020403 15%);
  border: 1px solid color-mix(in srgb, var(--brand-accent, #57ff9c) 40%, transparent);
  box-shadow: 0 0 60px color-mix(in srgb, var(--brand-accent, #57ff9c) 24%, transparent);
  width: 100%;
  min-height: calc(100vh - clamp(120px, 12vh, 200px));
  overflow: hidden;
}

.terminal-window::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    120deg,
    color-mix(in srgb, var(--brand-accent, #57ff9c) 25%, transparent),
    transparent 45%,
    transparent 55%,
    color-mix(in srgb, var(--brand-accent, #57ff9c) 12%, transparent)
  );
  opacity: 0.06;
  pointer-events: none;
}

.terminal-window::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(transparent 60%, rgba(0, 0, 0, 0.6));
  mix-blend-mode: screen;
  opacity: 0.3;
  pointer-events: none;
}

.terminal-bar {
  display: flex;
  justify-content: space-between;
  padding: 12px 18px;
  border-bottom: 1px solid color-mix(in srgb, var(--brand-accent, #57ff9c) 30%, transparent);
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--brand-accent, #57ff9c) 20%, transparent),
    transparent
  );
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.2em;
}

.terminal-bar__status {
  display: flex;
  gap: 12px;
  align-items: center;
  font-size: 0.75rem;
}

.terminal-chip {
  padding: 2px 10px;
  border: 1px solid color-mix(in srgb, var(--brand-accent, #57ff9c) 40%, transparent);
  text-transform: uppercase;
  font-size: 0.72rem;
}

.terminal-chip.is-live {
  background: color-mix(in srgb, var(--brand-accent, #57ff9c) 35%, transparent);
}

.terminal-body {
  position: relative;
  padding: clamp(20px, 4vw, 40px);
  display: flex;
  flex-direction: column;
  gap: clamp(20px, 2.6vw, 36px);
}

.terminal-columns {
  display: flex;
  flex-direction: column;
  gap: clamp(18px, 2vw, 32px);
}

.terminal-column {
  display: flex;
  flex-direction: column;
  gap: clamp(14px, 1.5vw, 24px);
}

@media (min-width: 1100px) {
  .terminal-columns {
    flex-direction: row;
    align-items: flex-start;
  }

  .terminal-column--primary {
    flex: 1.1 1 0;
  }

  .terminal-column--secondary {
    flex: 0.9 1 0;
  }
}

.terminal-header {
  display: flex;
  gap: 16px;
  align-items: center;
  border: 1px solid color-mix(in srgb, var(--brand-accent, #57ff9c) 20%, transparent);
  padding: 12px 14px;
}

.terminal-header-meta {
  margin-top: 10px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.terminal-badge {
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--brand-accent, #57ff9c) 35%, transparent);
  text-transform: uppercase;
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  color: var(--brand-accent, #57ff9c);
  background: rgba(5, 15, 10, 0.6);
  animation: terminalPulse 4s ease-in-out infinite;
}

.terminal-badge.is-accent {
  border-color: color-mix(in srgb, var(--brand-warning, #f7b955) 55%, transparent);
  color: var(--brand-warning, #f7b955);
}

.terminal-logo {
  max-height: 72px;
  width: auto;
  object-fit: contain;
}

.terminal-app-name {
  margin: 0;
  font-size: 1rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.terminal-app-mint {
  margin: 4px 0 0;
  font-size: 0.85rem;
  color: var(--brand-textSecondary, #94ffce);
}

.terminal-type-line {
  margin: 0;
  font-size: 0.82rem;
  letter-spacing: 0.2em;
  color: var(--brand-textSecondary, #94ffce);
  white-space: nowrap;
  overflow: hidden;
  border-right: 2px solid var(--brand-accent, #57ff9c);
  padding-right: 6px;
  animation: terminalType 6s steps(45) infinite;
}

.terminal-highlight {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
  border: 1px solid color-mix(in srgb, var(--brand-accent, #57ff9c) 35%, transparent);
  padding: 16px;
  background: color-mix(in srgb, var(--brand-background, #010a05) 70%, #000000 30%);
}

.terminal-highlight-label {
  margin: 0 0 6px;
  text-transform: uppercase;
  letter-spacing: 0.3em;
  font-size: 0.72rem;
  color: var(--brand-textSecondary, #94ffce);
}

.terminal-highlight-value {
  margin: 0;
  font-size: clamp(2rem, 5vw, 3rem);
  letter-spacing: 0.18em;
  color: var(--brand-textPrimary, #57ff9c);
  text-shadow: 0 0 25px color-mix(in srgb, var(--brand-accent, #57ff9c) 30%, transparent);
}

.terminal-section {
  border: 1px solid color-mix(in srgb, var(--brand-accent, #57ff9c) 20%, transparent);
  padding: 16px;
  background: rgba(0, 0, 0, 0.35);
  backdrop-filter: blur(4px);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.35);
}

.terminal-section h2 {
  margin: 0 0 10px;
  font-size: calc(0.9rem * var(--brand-text-scale-primary));
  color: var(--brand-accent, #57ff9c);
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.terminal-label {
  color: var(--brand-accent, #57ff9c);
  margin-right: 12px;
}

.terminal-list,
.terminal-log {
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: 0.88rem;
}

.terminal-log li,
.terminal-list li {
  padding: 4px 0;
  border-bottom: 1px dashed color-mix(in srgb, var(--brand-textMuted, #94ffce) 30%, transparent);
  animation: terminalLineGlow 6s ease-in-out infinite;
}

.terminal-time {
  color: var(--brand-textSecondary, #22ef9f);
  margin-right: 10px;
}

.terminal-level {
  color: var(--brand-accentSoft, #94ffce);
  margin-right: 8px;
}

.terminal-footer-art {
  margin-top: 12px;
  border: 1px solid color-mix(in srgb, var(--brand-accent, #57ff9c) 20%, transparent);
  padding: 6px;
}

.terminal-footer-art img {
  width: 100%;
  height: auto;
  display: block;
}

@media (max-width: 960px) {
  .pro-hero__meta {
    flex-direction: column;
    align-items: flex-start;
  }
}

.header {
  display: flex;
  flex-direction: column;
  gap: clamp(16px, 2vw, 24px);
}

.header-top {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-between;
  gap: clamp(14px, 2vw, 20px);
}

.primary-nav-wrap {
  display: flex;
  align-items: center;
  gap: clamp(12px, 1.8vw, 20px);
  flex-wrap: nowrap;
  margin-left: auto;
}

.primary-nav {
  display: flex;
  align-items: center;
  gap: clamp(10px, 1.4vw, 18px);
  flex-wrap: nowrap;
  min-width: 0;
}

.nav-link,
.nav-cta {
  font-size: 0.85rem;
}

.nav-link {
  color: var(--shell-text-primary);
  text-decoration: none;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  transition: color 0.2s ease;
}

.nav-link:hover,
.nav-link:focus-visible {
  color: var(--shell-accent);
}

.nav-link-social {
  font-size: 1rem;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.nav-link svg {
  width: 20px;
  height: 20px;
}

.nav-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  margin-left: clamp(12px, 2vw, 20px);
  padding: 10px 24px;
  background: var(--brand-accent-contrast);
  color: var(--shell-text-primary);
  border: 1px solid color-mix(in srgb, var(--brand-accent) 30%, transparent);
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  text-decoration: none;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}

.nav-cta:hover,
.nav-cta:focus-visible {
  transform: translateY(-2px);
  box-shadow: 0 14px 28px color-mix(in srgb, var(--brand-accent) 22%, transparent);
  border-color: color-mix(in srgb, var(--brand-accent) 45%, transparent);
}


.brand {
  display: flex;
  align-items: center;
  gap: clamp(14px, 2.4vw, 20px);
  flex: 0 0 auto;
}

.logo {
  height: clamp(60px, 10vw, 90px);
  width: auto;
  object-fit: contain;
  align-self: center;
}

.brand-logo {
  height: var(--brand-logo-height, clamp(44px, 8vw, 90px));
  width: auto;
  object-fit: contain;
}

.app.is-livestream .brand-logo {
  height: var(--brand-logo-height, clamp(28px, 5vw, 80px));
}

.app.is-livestream .header-top,
.app.is-livestream .header {
  align-items: center;
  gap: 16px;
}

.app.is-livestream .status-pill {
  align-self: center;
}

.vote-sections.is-livestream {
  gap: clamp(10px, 2vw, 16px);
}

.charity-card {
  display: flex;
  align-items: center;
  gap: clamp(12px, 2vw, 18px);
  background: var(--brand-surface);
  border: 1px solid var(--brand-border);
  border-radius: 18px;
  padding: 14px 18px;
  box-shadow: 0 16px 28px rgba(0, 0, 0, 0.45);
  min-width: clamp(220px, 22vw, 320px);
  min-height: clamp(120px, 18vw, 160px);
  align-self: stretch;
}

.charity-label {
  font-family: var(--brand-font-heading);
  font-size: calc(0.75rem * var(--brand-text-scale-primary));
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--shell-text-muted);
}

.charity-details {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.charity-name {
  font-family: var(--brand-font-heading);
  font-size: calc(clamp(1.25rem, 2.8vw, 1.625rem) * var(--brand-text-scale-primary));
  font-weight: 600;
  color: var(--brand-text-primary);
}

.charity-meta {
  display: flex;
  align-items: center;
  gap: 14px;
}

.charity-mark {
  width: clamp(68px, 8vw, 96px);
  height: clamp(68px, 8vw, 96px);
  border-radius: 12px;
  object-fit: contain;
  border: 1px solid var(--brand-border-strong);
  background: var(--brand-surface-alt);
}

.charity-address {
  font-family: var(--brand-font-mono);
  font-size: 0.75rem;
  letter-spacing: 0.08em;
  color: var(--shell-text-secondary);
}

.metric-grid {
  flex: 1 1 auto;
  display: grid;
  grid-template-columns: repeat(3, minmax(140px, 1fr));
  gap: clamp(12px, 2vw, 18px);
  justify-items: stretch;
  align-items: stretch;
  grid-auto-rows: 1fr;
}

.metric-card {
  min-width: 0;
  background: var(--brand-surface);
  border: 1px solid var(--brand-border-strong);
  border-radius: 22px;
  padding: clamp(14px, 2.4vw, 22px);
  display: flex;
  flex-direction: column;
  gap: 8px;
  justify-content: center;
  height: 100%;
  box-shadow: 0 24px 48px rgba(0, 0, 0, 0.55);
}

.metric-label {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.8125rem * var(--brand-text-scale-secondary));
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--shell-text-muted);
}

.metric-value {
  font-family: var(--brand-font-primary);
  font-size: calc(clamp(1.875rem, 5vw, 3.25rem) * var(--brand-text-scale-primary));
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--brand-text-primary);
}

.metric-value.metric-small {
  font-size: calc(clamp(1.25rem, 3.2vw, 1.875rem) * var(--brand-text-scale-primary));
  line-height: 1.1;
  letter-spacing: -0.01em;
}

.metric-value.status-live {
  color: var(--shell-accent);
}

.metric-value.status-paused {
  color: var(--brand-danger);
}

.metric-caption {
  font-size: calc(0.875rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-secondary);
}

.header-grid {
  display: grid;
  width: 100%;
  --header-grid-template: repeat(auto-fit, minmax(220px, 1fr));
  grid-template-columns: var(--header-grid-template);
  gap: clamp(12px, 1.6vw, 18px);
  align-items: stretch;
}

.header-grid--count-1 {
  --header-grid-template: minmax(0, 1fr);
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
}

.header-grid--count-2 {
  --header-grid-template: repeat(2, minmax(260px, 1fr));
}

.header-grid--count-3 {
  --header-grid-template: minmax(340px, 2fr) repeat(2, minmax(220px, 1fr));
}

 
.header-grid,
.header-grid .header-card,
.header-grid .header-card * {
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.project-grid {
  --grid-columns: 24;
  --grid-rows: 96;
  --grid-row-height: 24px;
  --grid-gap: 0px;
  position: relative;
  display: grid;
  grid-template-columns: repeat(var(--grid-columns), minmax(0, 1fr));
  grid-template-rows: repeat(var(--grid-rows), var(--grid-row-height));
  gap: var(--grid-gap);
  padding: 0;
  border-radius: 0;
  border: 1px solid var(--brand-border);
  background-color: var(--brand-background);
  background-image: var(--brand-background-image);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  overflow: hidden;
  width: 100%;
  min-height: max(
    100vh,
    calc(var(--grid-rows) * var(--grid-row-height) + (var(--grid-rows) - 1) * var(--grid-gap))
  );
}

.project-grid.is-fullscreen {
  height: calc(100vh - 2 * var(--simple-shell-padding, 0px));
  height: calc(100dvh - 2 * var(--simple-shell-padding, 0px));
  min-height: calc(100vh - 2 * var(--simple-shell-padding, 0px));
  min-height: calc(100dvh - 2 * var(--simple-shell-padding, 0px));
  max-height: calc(100vh - 2 * var(--simple-shell-padding, 0px));
  max-height: calc(100dvh - 2 * var(--simple-shell-padding, 0px));
  grid-template-rows: repeat(var(--grid-rows), minmax(0, 1fr));
}

.project-grid__item {
  position: relative;
  display: flex;
  flex-direction: column;
  z-index: 1;
  min-width: 0;
  min-height: 0;
}

.project-grid__drop-preview {
  pointer-events: none;
  z-index: 8;
  border-radius: var(--brand-radius);
  border: 2px dashed color-mix(in srgb, var(--shell-accent) 65%, transparent 35%);
  background: color-mix(in srgb, var(--shell-accent) 14%, transparent 86%);
  box-shadow:
    0 20px 50px rgba(0, 0, 0, 0.38),
    0 0 0 1px color-mix(in srgb, var(--shell-accent) 25%, transparent 75%);
  backdrop-filter: blur(6px);
}

.project-grid__drop-preview.is-invalid {
  border-color: color-mix(in srgb, #ef4444 75%, transparent 25%);
  background: color-mix(in srgb, #ef4444 12%, transparent 88%);
  box-shadow:
    0 20px 50px rgba(0, 0, 0, 0.38),
    0 0 0 1px color-mix(in srgb, #ef4444 35%, transparent 65%);
}

.project-grid__item.is-selected {
  z-index: 6;
}

.project-grid__item.is-selected > :not(.project-grid__handle):not(.project-grid__resize) {
  box-shadow:
    0 0 0 2px var(--grid-item-selected-outline),
    0 0 20px var(--grid-item-selected-glow);
}

.project-grid__item > :not(.project-grid__handle):not(.project-grid__resize) {
  flex: 1 1 auto;
  min-height: 0;
}

.project-grid__stack {
  display: flex;
  flex-direction: column;
  gap: clamp(16px, 2.6vw, 24px);
}

.app.app-grid {
  padding: 0;
  background: transparent;
}

.project-grid__item.is-dragging {
  z-index: 5;
}

.project-grid__item.is-selected.is-dragging {
  z-index: 7;
}

.project-grid__handle,
.project-grid__resize {
  position: absolute;
  border: 1px solid var(--brand-border);
  background: var(--brand-surface-alt);
  border-radius: var(--brand-radius-xs);
  opacity: 0.75;
  transition: opacity 0.2s ease, transform 0.2s ease;
  z-index: 2;
}

.project-grid__handle {
  top: 10px;
  right: 10px;
  width: 26px;
  height: 26px;
  cursor: grab;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  touch-action: none;
}

.project-grid__handle::before {
  content: "";
  width: 12px;
  height: 12px;
  background-image: radial-gradient(circle, var(--shell-text-muted) 2px, transparent 2px);
  background-size: 6px 6px;
}

.project-grid__resize {
  right: 8px;
  bottom: 8px;
  width: 22px;
  height: 22px;
  cursor: se-resize;
  touch-action: none;
}

.project-grid__resize::before {
  content: "";
  position: absolute;
  inset: 6px;
  border-right: 2px solid var(--shell-text-muted);
  border-bottom: 2px solid var(--shell-text-muted);
}

.project-grid__item:hover .project-grid__handle,
.project-grid__item:hover .project-grid__resize {
  opacity: 1;
  transform: translateY(-1px);
}

.project-grid__action {
  height: 100%;
  display: grid;
  place-items: center;
}

.project-grid__action.actions {
  align-items: center;
  justify-content: center;
}

.project-grid__logo-card {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  padding: clamp(12px, 2vw, 22px);
  background: color-mix(in srgb, var(--brand-surface) 68%, transparent);
  border: 1px solid var(--brand-border);
  border-radius: var(--brand-radius);
  overflow: hidden;
}

.project-grid__logo-image {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.project-grid__logo-video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
  border: 0;
  background: #000;
}

.project-grid__logo-video-viewport {
  width: 100%;
  height: 100%;
  overflow: hidden;
  background: #000;
}

.project-grid .log-panel {
  height: 100%;
}

.project-grid__item .header-card {
  height: 100%;
}

.project-grid__item .header-card,
.project-grid__item .log-panel {
  min-height: 0;
}

.component-wrapper {
  position: relative;
  height: 100%;
  border-radius: var(--brand-radius);
  font-family: var(--brand-font-secondary);
}

.component-controls {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 3;
  display: inline-flex;
  gap: 8px;
}

.component-delete,
.component-gear {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.component-image-card {
  padding: 0;
  overflow: hidden;
}

.sum-tally-card__value.is-positive {
  color: var(--brand-success);
}

.sum-tally-card__value.is-negative {
  color: var(--brand-danger);
}

.component-image-placeholder {
  height: 100%;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  color: var(--brand-text-secondary);
  padding: 20px;
  text-align: center;
  font-size: calc(1rem * var(--brand-text-scale-secondary));
}

.component-image-placeholder span {
  color: var(--brand-text-primary);
  font-weight: 700;
  font-family: var(--brand-font-primary);
  font-size: calc(1rem * var(--brand-text-scale-primary));
}

.component-image-placeholder small {
  color: var(--brand-text-muted);
}

.component-nft-drop-card {
  position: relative;
  min-height: 0;
  height: 100%;
}

.component-nft-drop-shell {
  --nft-gallery-columns: 3;
  --nft-gallery-width-percent: 32%;
  --nft-agent-log-width-percent: 34%;
  height: 100%;
  min-height: 0;
  display: grid;
  grid-template-columns: minmax(220px, var(--nft-gallery-width-percent, 32%)) minmax(0, 1fr);
  gap: 0;
  container-type: inline-size;
}

.component-nft-drop-shell--with-log {
  grid-template-columns:
    minmax(220px, var(--nft-agent-log-width-percent, 34%))
    minmax(220px, var(--nft-gallery-width-percent, 32%))
    minmax(0, 1fr);
}

.component-nft-drop-shell--no-gallery {
  grid-template-columns: minmax(0, 1fr);
}

.component-nft-drop-agent-log,
.component-nft-drop-gallery {
  min-height: 0;
  height: 100%;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  background: color-mix(in srgb, var(--brand-background) 88%, transparent);
  border: 1px solid color-mix(in srgb, var(--brand-border) 74%, transparent);
  border-radius: var(--brand-radius-lg);
  padding: 10px;
  gap: 10px;
  overflow: hidden;
}

.component-nft-drop-agent-log {
  border-radius: var(--brand-radius-lg);
}

.component-nft-drop-shell--with-log .component-nft-drop-agent-log {
  border-right: 0;
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}

.component-nft-drop-shell--with-log .component-nft-drop-gallery {
  border-left: 0;
  border-radius: 0;
}

.component-nft-drop-agent-log__list {
  min-height: 0;
  overflow: auto;
  display: grid;
  gap: 8px;
  align-content: start;
  padding-right: 2px;
}

.component-nft-drop-agent-log__entry {
  display: grid;
  gap: 8px;
  border: 1px solid color-mix(in srgb, var(--brand-border) 64%, transparent);
  border-radius: 10px;
  padding: 8px;
  background: color-mix(in srgb, var(--brand-background) 92%, transparent);
}

.component-nft-drop-agent-log__message {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.74rem * var(--brand-text-scale-secondary));
  line-height: 1.4;
  color: var(--shell-text-secondary);
  white-space: pre-wrap;
}

.component-nft-drop-agent-log__cursor {
  display: inline-block;
  margin-left: 0.05em;
  animation: nft-agent-log-cursor-blink 1s step-end infinite;
}

@keyframes nft-agent-log-cursor-blink {
  0%,
  49% {
    opacity: 1;
  }
  50%,
  100% {
    opacity: 0;
  }
}

.component-nft-drop-agent-log__image-wrap {
  display: flex;
  justify-content: center;
}

.component-nft-drop-agent-log__image {
  width: var(--nft-agent-log-image-size-percent, 100%);
  max-width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 8px;
  border: 1px solid color-mix(in srgb, var(--brand-border) 70%, transparent);
  background: color-mix(in srgb, var(--brand-background) 92%, transparent);
}

.component-nft-drop-gallery__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.component-nft-drop-gallery__title {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.78rem * var(--brand-text-scale-secondary));
  letter-spacing: 0.11em;
  text-transform: uppercase;
  color: var(--shell-text-muted);
}

.component-nft-drop-gallery__count {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.72rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-secondary);
  border: 1px solid color-mix(in srgb, var(--brand-border) 70%, transparent);
  border-radius: 999px;
  padding: 2px 8px;
}

.component-nft-drop-gallery__grid {
  min-height: 0;
  overflow: auto;
  display: grid;
  grid-template-columns: repeat(var(--nft-gallery-columns, 3), minmax(0, 1fr));
  gap: 8px;
  align-content: start;
  padding-right: 2px;
}

.component-nft-drop-gallery__tile {
  display: grid;
  gap: 6px;
}

.component-nft-drop-gallery__tile-image {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 10px;
  border: 1px solid color-mix(in srgb, var(--brand-border) 70%, transparent);
  background: color-mix(in srgb, var(--brand-background) 92%, transparent);
}

.component-nft-drop-gallery__tile-name {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.68rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-secondary);
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.component-nft-drop-gallery__empty {
  min-height: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-family: var(--brand-font-secondary);
  font-size: calc(0.82rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-muted);
}

.component-nft-drop-card__name-badge {
  position: absolute;
  top: 14px;
  left: 16px;
  z-index: 1;
  font-family: var(--brand-font-secondary);
  font-size: calc(0.85rem * var(--brand-text-scale-primary));
  letter-spacing: 0.01em;
  color: var(--brand-text-primary);
  background: color-mix(in srgb, var(--brand-background) 75%, transparent);
  border: 1px solid color-mix(in srgb, var(--brand-border) 70%, transparent);
  border-radius: 999px;
  padding: 6px 10px;
  max-width: min(72%, 420px);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.component-nft-drop-card__devmode {
  position: absolute;
  top: 14px;
  right: 16px;
  z-index: 1;
  font-family: var(--brand-font-secondary);
  font-size: calc(0.75rem * var(--brand-text-scale-secondary));
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brand-danger-soft);
  background: color-mix(in srgb, var(--brand-danger) 18%, var(--brand-background) 82%);
  border: 1px solid color-mix(in srgb, var(--brand-danger) 45%, transparent);
  border-radius: 999px;
  padding: 6px 10px;
}

.component-nft-drop-card__image {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.component-nft-drop-card__actions {
  position: absolute;
  right: 12px;
  bottom: 12px;
  z-index: 1;
}

.component-nft-drop-card__meta {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  padding: 14px 16px 16px;
  background: linear-gradient(
    to top,
    color-mix(in srgb, var(--brand-background) 88%, transparent),
    color-mix(in srgb, var(--brand-background) 30%, transparent),
    transparent
  );
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.component-nft-drop-card__meta-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}

.component-nft-drop-card__meta-title {
  font-weight: 800;
  color: var(--brand-text-primary);
  letter-spacing: -0.01em;
  font-family: var(--brand-font-primary);
  font-size: calc(1rem * var(--brand-text-scale-primary));
}

.component-nft-drop-card__meta-kpi {
  font-weight: 800;
  color: var(--brand-text-primary);
  font-family: var(--brand-font-primary);
  font-size: calc(1rem * var(--brand-text-scale-primary));
}

.component-nft-drop-card__meta-sub {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.88rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-secondary);
}

.component-nft-drop-card__meta-collection {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.8rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-muted);
}

@container (max-width: 720px) {
  .component-nft-drop-shell {
    grid-template-columns: minmax(0, 1fr);
  }

  .component-nft-drop-agent-log,
  .component-nft-drop-gallery {
    max-height: 44%;
  }
}

.component-text-card {
  align-items: stretch;
  justify-content: flex-start;
  gap: clamp(8px, 1.1vw, 14px);
}

.component-text-card__body {
  font-family: var(--brand-font-secondary);
  font-size: calc(1rem * var(--brand-text-scale-secondary));
  white-space: pre-wrap;
  line-height: 1.2;
  letter-spacing: 0.01em;
  color: inherit;
  width: 100%;
}

.component-text-card__placeholder {
  white-space: pre-wrap;
  color: var(--shell-text-secondary);
  font-family: var(--brand-font-secondary);
  font-size: calc(0.92rem * var(--brand-text-scale-secondary));
  line-height: 1.4;
  width: 100%;
}

.component-text-card--horizontal .component-text-card__body {
  white-space: normal;
  overflow-wrap: anywhere;
}

.component-text-card--horizontal {
  min-height: clamp(72px, 9vw, 96px);
  padding: clamp(8px, 1vw, 12px) clamp(10px, 1.2vw, 14px);
}

.status-feed-card {
  justify-content: flex-start;
  gap: 12px;
  container-type: inline-size;
  background:
    radial-gradient(circle at 6% 6%, color-mix(in srgb, var(--brand-accent) 18%, transparent), transparent 42%),
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--component-background, var(--brand-surface)) 92%, #05070c 8%),
      color-mix(in srgb, var(--component-background, var(--brand-surface)) 72%, #060912 28%)
    );
}

.status-feed-card__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
}

.status-feed-card__title {
  font-family: var(--brand-font-primary);
  font-size: calc(0.85rem * var(--brand-text-scale-primary));
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: var(--shell-text-muted);
}

.status-feed-card__source {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.72rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.status-feed-card__message {
  flex: 1 1 auto;
  width: 100%;
  min-height: clamp(84px, 30cqh, 180px);
  border-radius: 12px;
  border: 1px solid color-mix(in srgb, var(--brand-border) 80%, transparent);
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--component-background, var(--brand-surface)) 76%, var(--brand-surface-alt) 24%),
    color-mix(in srgb, var(--component-background, var(--brand-background)) 70%, #04060a 30%)
  );
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, #ffffff 12%, transparent),
    0 12px 28px rgba(0, 0, 0, 0.35);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: clamp(12px, 1.8cqw, 18px);
  font-family: var(--brand-font-primary);
  font-size: clamp(1.32rem, 6.4cqw, 3.1rem);
  font-weight: 900;
  letter-spacing: 0.06em;
  line-height: 1.05;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--brand-text-primary) 88%, #f9e7be 12%);
  text-shadow: 0 2px 7px rgba(0, 0, 0, 0.62);
}

.status-feed-card__message--pending {
  border-color: color-mix(in srgb, var(--brand-border-strong) 74%, #7f8ca9 26%);
  color: var(--brand-text-primary);
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--component-background, var(--brand-surface-alt)) 72%, #213050 28%) 0%,
    color-mix(in srgb, var(--component-background, var(--brand-background)) 78%, #101a31 22%) 100%
  );
}

.status-feed-card__message--red {
  border-color: color-mix(in srgb, var(--brand-danger) 82%, #ff4d6d 18%);
  color: color-mix(in srgb, var(--brand-danger-soft) 58%, #fff4f7 42%);
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--component-background, var(--brand-surface-alt)) 70%, var(--brand-danger) 30%) 0%,
    color-mix(in srgb, var(--component-background, var(--brand-background)) 78%, #620a1d 22%) 100%
  );
}

.status-feed-card__message--black {
  border-color: color-mix(in srgb, var(--brand-border-strong) 86%, #8e8e8e 14%);
  color: var(--brand-text-primary);
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--component-background, var(--brand-surface-alt)) 70%, #2a2a2a 30%) 0%,
    color-mix(in srgb, var(--component-background, var(--brand-background)) 80%, #0b0b0b 20%) 100%
  );
}

.status-feed-card__message--green {
  border-color: color-mix(in srgb, var(--brand-accent) 84%, #49eb8f 16%);
  color: color-mix(in srgb, var(--brand-accent-contrast) 38%, #effff6 62%);
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--component-background, var(--brand-surface-alt)) 72%, var(--brand-accent) 28%) 0%,
    color-mix(in srgb, var(--component-background, var(--brand-background)) 80%, #0a5d31 20%) 100%
  );
}

.roulette-card {
  gap: 10px;
  justify-content: flex-start;
  overflow: hidden;
  padding: 12px;
  position: relative;
  container-type: size;
  background: var(
    --component-background,
    radial-gradient(circle at 20% 0%, color-mix(in srgb, var(--brand-accent) 18%, transparent), transparent 48%),
    radial-gradient(circle at 100% 100%, color-mix(in srgb, #f4c542 18%, transparent), transparent 54%),
    color-mix(in srgb, var(--brand-surface-alt) 88%, #07090f 12%)
  );
}

.roulette-card__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}

.roulette-card__title {
  font-family: var(--brand-font-primary);
  font-size: calc(0.95rem * var(--brand-text-scale-primary));
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--brand-text-primary);
}

.roulette-card__status {
  font-family: var(--brand-font-mono);
  font-size: calc(0.76rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-secondary);
  border: 1px solid color-mix(in srgb, var(--brand-border) 72%, transparent);
  background: color-mix(in srgb, var(--brand-background) 62%, transparent);
  border-radius: 999px;
  padding: 4px 10px;
}

.roulette-card__status--floating {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 2;
}

.roulette-stage {
  display: grid;
  place-items: center;
  width: 100%;
  flex: 1 1 auto;
  min-height: 0;
}

.roulette-wheel-shell {
  position: relative;
  --roulette-wheel-size: min(100%, 520px);
  width: var(--roulette-wheel-size);
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  --roulette-slot-radius: calc(var(--roulette-wheel-size) * 0.443);
  --roulette-ball-radius: calc(var(--roulette-wheel-size) * 0.314);
}

.roulette-card.roulette-card--status-hidden .roulette-wheel-shell {
  --roulette-wheel-size: min(100%, 620px);
}

@supports (width: 1cqw) {
  .roulette-wheel-shell {
    --roulette-wheel-size: min(96cqw, max(260px, calc(100cqh - 134px)));
  }

  .roulette-card.roulette-card--status-hidden .roulette-wheel-shell {
    --roulette-wheel-size: min(98cqw, max(300px, calc(100cqh - 74px)));
  }
}

.roulette-wheel-shell.is-spinning {
  filter: drop-shadow(0 0 14px color-mix(in srgb, var(--brand-warning) 34%, transparent));
}

.roulette-wheel {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  isolation: isolate;
  transition: transform var(--roulette-wheel-transition-ms, 4200ms) var(--roulette-wheel-easing, linear);
  border: 3px solid color-mix(in srgb, #ffdf95 80%, #9e6e2c 20%);
  background:
    radial-gradient(circle at 30% 24%, color-mix(in srgb, #a26a2d 38%, transparent), transparent 54%),
    repeating-conic-gradient(
      from 0deg,
      #603013 0deg 24deg,
      #6f3616 24deg 48deg
    );
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, #ffe3a6 35%, transparent),
    inset 0 24px 34px color-mix(in srgb, #000000 28%, transparent),
    0 14px 26px color-mix(in srgb, #000000 32%, transparent);
}

.roulette-wheel::before,
.roulette-wheel::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
}

.roulette-wheel::before {
  z-index: 1;
  background:
    var(--roulette-pocket-gradient),
    radial-gradient(
      circle,
      transparent 0 56.8%,
      color-mix(in srgb, #ffd88b 90%, #9d6d29 10%) 56.9% 57.9%,
      transparent 58% 80.4%,
      color-mix(in srgb, #ffd88b 90%, #9d6d29 10%) 80.5% 81.2%,
      transparent 81.3%
    );
  -webkit-mask: radial-gradient(circle, transparent 0 56.5%, #000 56.6% 81.3%, transparent 81.4%);
  mask: radial-gradient(circle, transparent 0 56.5%, #000 56.6% 81.3%, transparent 81.4%);
}

.roulette-wheel::after {
  z-index: 2;
  background:
    repeating-conic-gradient(
      from 0deg,
      #159146 0deg 8.7deg,
      #26b65a 8.7deg 9.73deg
    ),
    radial-gradient(
      circle,
      transparent 0 40%,
      color-mix(in srgb, #ffd88b 90%, #9d6d29 10%) 40.1% 41%,
      transparent 41.1% 56%,
      color-mix(in srgb, #ffd88b 90%, #9d6d29 10%) 56.1% 56.9%,
      transparent 57%
    );
  -webkit-mask: radial-gradient(circle, transparent 0 40%, #000 40.1% 56.9%, transparent 57%);
  mask: radial-gradient(circle, transparent 0 40%, #000 40.1% 56.9%, transparent 57%);
}

.roulette-wheel__slots {
  position: absolute;
  inset: 0;
  z-index: 6;
  pointer-events: none;
}

.roulette-slot {
  position: absolute;
  z-index: 7;
  left: 50%;
  top: 50%;
  transform:
    translate(-50%, -50%)
    rotate(var(--roulette-slot-angle))
    translateY(calc(var(--roulette-slot-radius) * -1))
    rotate(calc((var(--roulette-slot-angle) * -1) - var(--roulette-wheel-angle, 0deg)));
  font-family: "Montserrat", var(--brand-font-primary), sans-serif;
  font-size: clamp(0.86rem, calc(var(--roulette-wheel-size) * 0.034), 1.55rem);
  font-weight: 900;
  width: 2.1ch;
  height: 1em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  text-align: center;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.01em;
  -webkit-text-stroke: 0.35px rgba(35, 20, 5, 0.45);
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.9), 0 0 3px rgba(0, 0, 0, 0.72);
  color: #f7dfab;
}

.roulette-slot--red {
  color: #f7dfab;
}

.roulette-slot--black {
  color: #f7dfab;
}

.roulette-slot--green {
  color: #f7dfab;
}

.roulette-spinner {
  position: absolute;
  z-index: 3;
  left: 50%;
  top: 50%;
  width: 32%;
  height: 32%;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background:
    radial-gradient(circle at 28% 24%, color-mix(in srgb, #a86d31 45%, transparent), transparent 50%),
    radial-gradient(circle, #5e2f14 0 70%, #4c250f 71% 100%);
  border: 2px solid color-mix(in srgb, #ffd88b 85%, #8e5d22 15%);
  box-shadow: inset 0 3px 9px rgba(0, 0, 0, 0.35);
}

.roulette-spinner__arm {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 44%;
  height: 8%;
  border-radius: 999px;
  transform-origin: 0 50%;
  background: linear-gradient(90deg, #f6cf7b 0%, #b8792f 70%, #7d4f1c 100%);
  box-shadow: inset 0 1px 2px rgba(255, 233, 166, 0.45), 0 1px 2px rgba(0, 0, 0, 0.4);
}

.roulette-spinner__arm::after {
  content: "";
  position: absolute;
  right: -6px;
  top: 50%;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  transform: translateY(-50%);
  background: radial-gradient(circle at 30% 30%, #ffe6ae 0 35%, #d79d49 70%, #915d22 100%);
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
}

.roulette-spinner__arm--a {
  transform: translate(0, -50%) rotate(18deg);
}

.roulette-spinner__arm--b {
  transform: translate(0, -50%) rotate(108deg);
}

.roulette-spinner__arm--c {
  transform: translate(0, -50%) rotate(198deg);
}

.roulette-spinner__arm--d {
  transform: translate(0, -50%) rotate(288deg);
}

.roulette-wheel__hub {
  position: absolute;
  z-index: 8;
  left: 50%;
  top: 50%;
  width: 9%;
  height: 9%;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  border: 2px solid color-mix(in srgb, #ffd27f 65%, var(--brand-border));
  background:
    radial-gradient(circle at 30% 30%, #ffe4a4 0 32%, #d69943 70%, #8c5a20 100%);
  box-shadow: inset 0 2px 8px rgba(0, 0, 0, 0.4);
}

.roulette-ball-track {
  position: absolute;
  inset: 0;
  transition: transform var(--roulette-ball-transition-ms, 4300ms) var(--roulette-ball-easing, linear);
}

.roulette-ball {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  transform: translate(-50%, -50%) translateY(calc(var(--roulette-ball-radius) * -1));
  background: radial-gradient(circle at 30% 30%, #ffffff 0 25%, #cfd6dd 65%, #8f969d 100%);
  box-shadow: 0 2px 7px rgba(0, 0, 0, 0.5);
}

.roulette-board {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 6px;
}

.roulette-board--floating {
  position: absolute;
  top: 10px;
  right: 54px;
  width: min(170px, 42%);
  z-index: 2;
}

.roulette-board__cell {
  border: 1px solid color-mix(in srgb, var(--brand-border) 70%, transparent);
  border-radius: 10px;
  padding: 6px 8px;
  display: grid;
  gap: 2px;
  text-align: center;
  background: color-mix(in srgb, var(--brand-background) 62%, transparent);
}

.roulette-board__cell span {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.68rem * var(--brand-text-scale-secondary));
  letter-spacing: 0.09em;
  color: var(--shell-text-muted);
}

.roulette-board__cell strong {
  font-family: var(--brand-font-primary);
  font-size: calc(0.98rem * var(--brand-text-scale-primary));
}

.roulette-board__wallets {
  margin-top: 2px;
  display: grid;
  gap: 1px;
}

.roulette-board__wallet {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.58rem * var(--brand-text-scale-secondary));
  line-height: 1.15;
  color: var(--shell-text-muted);
}

.roulette-board__cell--red strong {
  color: #ff7f97;
}

.roulette-board__cell--black strong {
  color: #f2f6ff;
}

.roulette-board__cell--green strong {
  color: #7af5ac;
}

.roulette-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  font-family: var(--brand-font-secondary);
  font-size: calc(0.74rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-secondary);
}

.roulette-result {
  border-radius: 10px;
  padding: 14px 16px;
  border: 1px solid color-mix(in srgb, var(--brand-border) 78%, transparent);
  background: color-mix(in srgb, var(--brand-background) 74%, transparent);
  font-family: "Montserrat", var(--brand-font-primary), sans-serif;
  font-size: clamp(1.1rem, calc(var(--roulette-wheel-size) * 0.037), 1.95rem);
  font-weight: 900;
  line-height: 1.1;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-align: center;
  color: #f9e7be;
  min-height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, #f7d289 24%, transparent),
    0 10px 22px rgba(0, 0, 0, 0.35);
  text-shadow: 0 2px 6px rgba(0, 0, 0, 0.6);
}

.roulette-result--spinning {
  animation: rouletteResultSpinText 560ms ease-in-out infinite;
}

.roulette-result--revealed {
  border-color: #ffffff;
  animation: rouletteResultAuraPulse 780ms ease-in-out infinite;
}

@keyframes rouletteResultSpinText {
  0% {
    font-size: clamp(1.1rem, calc(var(--roulette-wheel-size) * 0.037), 1.95rem);
  }
  50% {
    font-size: clamp(1.24rem, calc(var(--roulette-wheel-size) * 0.043), 2.14rem);
  }
  100% {
    font-size: clamp(1.1rem, calc(var(--roulette-wheel-size) * 0.037), 1.95rem);
  }
}

@keyframes rouletteResultAuraPulse {
  0% {
    box-shadow:
      inset 0 0 0 1px rgba(255, 255, 255, 0.2),
      0 0 0 1px rgba(255, 255, 255, 0.35),
      0 0 14px rgba(255, 255, 255, 0.28),
      0 0 26px rgba(255, 255, 255, 0.16);
  }
  50% {
    box-shadow:
      inset 0 0 0 1px rgba(255, 255, 255, 0.35),
      0 0 0 1px rgba(255, 255, 255, 0.7),
      0 0 24px rgba(255, 255, 255, 0.46),
      0 0 42px rgba(255, 255, 255, 0.28);
  }
  100% {
    box-shadow:
      inset 0 0 0 1px rgba(255, 255, 255, 0.2),
      0 0 0 1px rgba(255, 255, 255, 0.35),
      0 0 14px rgba(255, 255, 255, 0.28),
      0 0 26px rgba(255, 255, 255, 0.16);
  }
}

@keyframes headsTailsResultBreath {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.045);
  }
  100% {
    transform: scale(1);
  }
}

.roulette-result--pending {
  border-color: #7f8ca9;
  color: #e7efff;
  background: linear-gradient(180deg, #1d2640 0%, #131a2e 100%);
}

.roulette-result--red {
  border-color: #ff4d6d;
  color: #ffe6eb;
  background: linear-gradient(180deg, #8f0f2a 0%, #620a1d 100%);
  box-shadow:
    inset 0 0 0 1px rgba(255, 171, 186, 0.25),
    0 12px 26px rgba(143, 15, 42, 0.45);
}

.roulette-result--black {
  border-color: #8e8e8e;
  color: #f7f7f7;
  background: linear-gradient(180deg, #232323 0%, #0b0b0b 100%);
  box-shadow:
    inset 0 0 0 1px rgba(245, 245, 245, 0.14),
    0 12px 26px rgba(0, 0, 0, 0.58);
}

.roulette-result--green {
  border-color: #49eb8f;
  color: #e5fff0;
  background: linear-gradient(180deg, #0f7f44 0%, #0a5d31 100%);
  box-shadow:
    inset 0 0 0 1px rgba(171, 255, 204, 0.22),
    0 12px 26px rgba(10, 93, 49, 0.42);
}

.roulette-round-modal {
  position: absolute;
  inset: 0;
  z-index: 8;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(2, 6, 16, 0.72);
  padding: 14px;
}

.roulette-round-modal__panel {
  width: min(92%, 560px);
  border-radius: 12px;
  border: 1px solid color-mix(in srgb, var(--brand-border) 72%, transparent);
  background: linear-gradient(180deg, #141f36 0%, #0e1527 100%);
  box-shadow: 0 20px 48px rgba(0, 0, 0, 0.55);
  padding: 16px 18px;
  position: relative;
}

.roulette-round-modal__panel--sending {
  border-color: rgba(67, 242, 126, 0.62);
  box-shadow:
    inset 0 0 0 1px rgba(67, 242, 126, 0.2),
    0 20px 48px rgba(0, 0, 0, 0.55);
}

.roulette-round-modal__panel--no-winner {
  border-color: rgba(255, 86, 120, 0.58);
  box-shadow:
    inset 0 0 0 1px rgba(255, 86, 120, 0.18),
    0 20px 48px rgba(0, 0, 0, 0.55);
}

.roulette-round-modal__title {
  font-family: var(--brand-font-primary);
  font-size: calc(0.9rem * var(--brand-text-scale-primary));
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--shell-text-muted);
  margin-bottom: 8px;
}

.roulette-round-modal__message {
  font-family: "Montserrat", var(--brand-font-primary), sans-serif;
  font-size: calc(1.08rem * var(--brand-text-scale-primary));
  font-weight: 800;
  line-height: 1.3;
  color: #f4f8ff;
}

.roulette-round-modal__close {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--brand-border) 75%, transparent);
  background: color-mix(in srgb, var(--brand-background) 86%, transparent);
  color: var(--shell-text-primary);
  font-size: 1.15rem;
  line-height: 1;
  cursor: pointer;
}

.slot-machine-card {
  display: flex;
  flex-direction: column;
  gap: 0.58rem;
  min-height: 100%;
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(255, 236, 94, 0.2), transparent 45%),
    linear-gradient(180deg, rgba(63, 23, 3, 0.95), rgba(29, 8, 2, 0.96));
  border: 1px solid rgba(255, 170, 28, 0.35);
  box-shadow: inset 0 0 0 1px rgba(255, 232, 120, 0.2), 0 8px 28px rgba(0, 0, 0, 0.28);
  overflow: hidden;
}

.slot-machine-card--status-hidden {
  gap: 0.42rem;
}

.slot-machine-marquee {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.4rem 0.6rem;
  border-radius: 10px;
  border: 1px solid rgba(255, 232, 127, 0.34);
  background: linear-gradient(180deg, rgba(255, 201, 55, 0.3), rgba(117, 47, 0, 0.28));
}

.slot-machine-marquee__left {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
  min-width: 0;
}

.slot-machine-marquee__entries {
  font-weight: 900;
  letter-spacing: 0.08em;
  font-size: clamp(1.55rem, 4.8vw, 2.7rem);
  line-height: 1;
  color: #fff3a8;
  text-shadow:
    0 0 14px rgba(255, 214, 90, 0.45),
    0 1px 0 rgba(88, 31, 0, 0.75);
}

.slot-machine-marquee__entries--right {
  margin-left: auto;
  text-align: right;
  white-space: nowrap;
}

.slot-machine-marquee__title {
  font-weight: 800;
  letter-spacing: 0.16em;
  font-size: 0.72rem;
  color: rgba(255, 233, 145, 0.92);
  text-shadow: 0 0 8px rgba(255, 199, 69, 0.35);
}

.slot-machine-marquee__blink {
  font-weight: 800;
  font-size: 0.69rem;
  letter-spacing: 0.14em;
  color: #ff4545;
  animation: slotMachineBlink 860ms steps(2, end) infinite;
}

.slot-machine-top {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.45rem;
}

.slot-machine-metric {
  background: linear-gradient(180deg, rgba(8, 15, 32, 0.85), rgba(2, 6, 14, 0.9));
  border: 1px solid rgba(255, 191, 54, 0.4);
  border-radius: 8px;
  padding: 0.42rem 0.56rem;
  display: flex;
  flex-direction: column;
  gap: 0.14rem;
}

.slot-machine-metric > span {
  font-size: 0.65rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.7);
}

.slot-machine-metric > strong {
  font-size: 0.78rem;
  letter-spacing: 0.02em;
}

.slot-machine-stage {
  display: grid;
  grid-template-columns: 22px minmax(0, 1fr) 22px;
  align-items: stretch;
  gap: 0.5rem;
  background: linear-gradient(180deg, rgba(255, 183, 35, 0.55), rgba(109, 45, 0, 0.45));
  border: 1px solid rgba(255, 215, 122, 0.42);
  border-radius: 12px;
  padding: 0.65rem 0.58rem;
  min-height: 210px;
  flex: 1 1 auto;
}

.slot-machine-stage.is-spinning {
  box-shadow: 0 0 0 1px rgba(255, 210, 90, 0.38), 0 0 26px rgba(255, 78, 39, 0.24);
}

.slot-machine-stage__rail {
  border-radius: 999px;
  border: 1px solid rgba(255, 240, 160, 0.35);
  background:
    radial-gradient(circle at 50% 10%, rgba(255, 250, 170, 0.72), rgba(255, 157, 39, 0.5) 40%, transparent 75%),
    repeating-linear-gradient(
      180deg,
      rgba(255, 227, 145, 0.28) 0 9px,
      rgba(205, 76, 10, 0.2) 9px 18px
    );
  box-shadow: inset 0 0 16px rgba(0, 0, 0, 0.25);
  animation: slotMachineRailPulse 1.1s ease-in-out infinite;
}

.slot-machine-stage__rail--right {
  animation-delay: 0.5s;
}

.slot-machine-stage__center {
  display: flex;
  align-items: stretch;
  border-radius: 12px;
  border: 1px solid rgba(255, 220, 125, 0.46);
  background:
    linear-gradient(180deg, rgba(3, 8, 20, 0.95), rgba(1, 3, 11, 0.96));
  box-shadow: inset 0 0 0 1px rgba(255, 170, 37, 0.2), inset 0 8px 24px rgba(0, 0, 0, 0.34);
  padding: 0.6rem;
  min-height: 0;
}

.slot-machine-webgl {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 0;
  flex: 1 1 auto;
  border-radius: 10px;
  overflow: hidden;
  display: flex;
  align-items: stretch;
  justify-content: stretch;
  background:
    linear-gradient(180deg, rgba(255, 230, 160, 0.06), rgba(255, 230, 160, 0) 30%),
    radial-gradient(130% 75% at 50% -10%, rgba(255, 220, 136, 0.2), transparent 44%),
    rgba(0, 0, 0, 0.2);
}

.slot-machine-webgl::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(
      180deg,
      rgba(0, 0, 0, 0.52) 0%,
      rgba(0, 0, 0, 0.2) 24%,
      rgba(0, 0, 0, 0) 36%,
      rgba(0, 0, 0, 0) 64%,
      rgba(0, 0, 0, 0.22) 76%,
      rgba(0, 0, 0, 0.55) 100%
    );
}

.slot-machine-webgl::after {
  content: "";
  position: absolute;
  left: 0.8%;
  right: 0.8%;
  top: 50%;
  height: 34%;
  transform: translateY(-50%);
  pointer-events: none;
  border: 8px solid rgba(255, 194, 90, 0.8);
  box-shadow:
    inset 0 0 28px rgba(255, 82, 56, 0.2),
    0 0 22px rgba(255, 142, 35, 0.2);
}

.slot-machine-stage.is-payline-flash .slot-machine-webgl::after {
  border-width: 14px;
  border-style: solid;
  border-color: var(--slot-payline-flash-a, #ffd84d);
  box-shadow:
    inset 0 0 34px color-mix(in srgb, var(--slot-payline-flash-a, #ffd84d) 58%, transparent),
    0 0 34px color-mix(in srgb, var(--slot-payline-flash-b, #ff2d55) 62%, transparent);
  animation: slotPaylineFlash 120ms linear 8;
}

.slot-machine-webgl__canvas {
  width: 100%;
  height: 100%;
  display: block;
}

.slot-machine-webgl--fallback {
  min-height: 170px;
  padding: 0.4rem;
}

.slot-machine-webgl-fallback-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.5rem;
  width: 100%;
}

.slot-machine-webgl-fallback-tile {
  min-height: 108px;
  border-radius: 10px;
  border: 1px solid rgba(255, 201, 86, 0.45);
  background: linear-gradient(180deg, rgba(8, 15, 32, 0.88), rgba(2, 6, 14, 0.95));
  display: flex;
  align-items: center;
  justify-content: center;
}

.slot-machine-webgl-fallback-tile > span {
  font-size: clamp(2.05rem, 5vw, 3rem);
  line-height: 1;
  font-weight: 900;
  letter-spacing: 0.06em;
  color: #ff3030;
  text-shadow: 0 0 20px rgba(255, 51, 51, 0.35);
}

.slot-machine-webgl-fallback-tile > img {
  max-width: 82%;
  max-height: 82%;
  object-fit: contain;
}

.slot-machine-result {
  border: 1px solid rgba(255, 206, 79, 0.35);
  border-radius: 8px;
  background: rgba(2, 9, 22, 0.72);
  padding: 0.4rem 0.55rem;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.04em;
}

.slot-machine-result--pending {
  color: #ffd591;
}

.slot-machine-result--success {
  color: #6bf7a3;
}

.slot-machine-result--muted {
  color: rgba(235, 242, 255, 0.9);
}

.slot-machine-payout-guide {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.35rem;
}

.slot-machine-payout-guide > span {
  border: 1px dashed rgba(255, 204, 82, 0.38);
  border-radius: 6px;
  padding: 0.26rem 0.34rem;
  text-align: center;
  font-size: 0.66rem;
  letter-spacing: 0.03em;
  background: rgba(2, 8, 18, 0.48);
}

.slot-machine-entry-list {
  border: 1px solid rgba(255, 207, 90, 0.32);
  border-radius: 8px;
  background: rgba(2, 8, 18, 0.52);
  max-height: 132px;
  overflow: auto;
}

.slot-machine-entry {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.55rem;
  padding: 0.28rem 0.5rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  font-size: 0.74rem;
}

.slot-machine-entry:last-child {
  border-bottom: none;
}

.slot-machine-entry__wallet {
  color: rgba(245, 250, 255, 0.86);
}

.slot-machine-entry__digits {
  color: #ff7e45;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.slot-machine-entry--empty {
  justify-content: center;
  color: rgba(236, 240, 255, 0.75);
}

.slot-machine-card--stpat {
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(163, 230, 53, 0.22), transparent 45%),
    linear-gradient(180deg, rgba(18, 58, 27, 0.96), rgba(6, 31, 15, 0.97));
  border: 1px solid rgba(133, 218, 109, 0.4);
  box-shadow: inset 0 0 0 1px rgba(235, 217, 125, 0.2), 0 8px 28px rgba(0, 0, 0, 0.3);
}

.slot-machine-card--stpat .slot-machine-marquee {
  border-color: rgba(236, 220, 140, 0.44);
  background: linear-gradient(180deg, rgba(234, 204, 104, 0.28), rgba(24, 87, 38, 0.34));
}

.slot-machine-card--stpat .slot-machine-marquee__entries {
  color: #f8ecb0;
  text-shadow:
    0 0 14px rgba(255, 229, 137, 0.45),
    0 1px 0 rgba(9, 44, 20, 0.75);
}

.slot-machine-card--stpat .slot-machine-marquee__title {
  color: rgba(226, 252, 184, 0.94);
  text-shadow: 0 0 8px rgba(120, 222, 129, 0.38);
}

.slot-machine-card--stpat .slot-machine-stage {
  background: linear-gradient(180deg, rgba(209, 184, 90, 0.5), rgba(18, 80, 35, 0.48));
  border-color: rgba(239, 225, 149, 0.46);
}

.slot-machine-card--stpat .slot-machine-stage.is-spinning {
  box-shadow: 0 0 0 1px rgba(229, 224, 155, 0.42), 0 0 28px rgba(62, 213, 112, 0.27);
}

.slot-machine-card--stpat .slot-machine-stage__rail {
  border-color: rgba(227, 241, 174, 0.44);
  background:
    radial-gradient(circle at 50% 10%, rgba(240, 246, 176, 0.66), rgba(144, 210, 96, 0.48) 40%, transparent 75%),
    repeating-linear-gradient(
      180deg,
      rgba(228, 246, 176, 0.28) 0 9px,
      rgba(26, 122, 52, 0.24) 9px 18px
    );
}

.slot-machine-card--stpat .slot-machine-stage__center {
  border-color: rgba(238, 230, 163, 0.5);
  background: linear-gradient(180deg, rgba(4, 21, 10, 0.95), rgba(2, 13, 7, 0.96));
  box-shadow: inset 0 0 0 1px rgba(171, 219, 109, 0.2), inset 0 8px 24px rgba(0, 0, 0, 0.36);
}

.slot-machine-webgl--stpat {
  background:
    linear-gradient(180deg, rgba(227, 246, 180, 0.08), rgba(227, 246, 180, 0) 30%),
    radial-gradient(130% 75% at 50% -10%, rgba(192, 236, 114, 0.2), transparent 44%),
    rgba(0, 0, 0, 0.2);
}

.slot-machine-webgl--stpat::after {
  border-color: rgba(233, 224, 148, 0.85);
  box-shadow:
    inset 0 0 28px rgba(117, 209, 103, 0.24),
    0 0 22px rgba(149, 231, 133, 0.2);
}

.slot-machine-card--stpat .slot-machine-result {
  border-color: rgba(198, 228, 148, 0.4);
  background: rgba(4, 23, 10, 0.62);
}

.slot-machine-card--stpat .slot-machine-result--pending {
  color: #dff7b0;
}

.slot-machine-card--stpat .slot-machine-result--success {
  color: #b9ffd3;
}

.slot-machine-card--stpat .slot-machine-result--muted {
  color: rgba(225, 248, 208, 0.9);
}

.slot-machine-card--stpat .slot-machine-entry-list {
  border-color: rgba(186, 225, 130, 0.38);
  background: rgba(4, 20, 9, 0.54);
}

.slot-machine-card--stpat .slot-machine-entry__digits {
  color: #f8e98b;
}

@media (max-width: 720px) {
  .slot-machine-top,
  .slot-machine-payout-guide {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .slot-machine-stage {
    min-height: 188px;
    grid-template-columns: 16px minmax(0, 1fr) 16px;
  }

  .slot-machine-webgl,
  .slot-machine-webgl--fallback {
    min-height: 150px;
  }
}

@keyframes slotMachineBlink {
  0%, 49% {
    opacity: 1;
    text-shadow: 0 0 12px rgba(255, 99, 69, 0.5);
  }
  50%, 100% {
    opacity: 0.45;
    text-shadow: none;
  }
}

@keyframes slotMachineRailPulse {
  0%, 100% {
    filter: brightness(1);
  }
  50% {
    filter: brightness(1.25);
  }
}

@keyframes slotPaylineFlash {
  0%, 100% {
    opacity: 1;
    border-color: var(--slot-payline-flash-a, #ffd84d);
  }
  50% {
    opacity: 0.42;
    border-color: var(--slot-payline-flash-b, #ff2d55);
  }
}

.tweet-card {
  justify-content: flex-start;
}

.tweet-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.tweet-header-left {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.tweet-x-logo {
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
  color: var(--brand-text-primary);
  opacity: 0.9;
}

.tweet-header-title {
  font-family: var(--brand-font-primary);
  font-size: calc(0.95rem * var(--brand-text-scale-primary));
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--shell-text-muted);
}

.tweet-body {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  min-height: 0;
}

.tweet-avatar {
  flex: 0 0 auto;
  width: 48px;
  height: 48px;
}

.tweet-avatar img,
.tweet-avatar-fallback {
  width: 48px;
  height: 48px;
  border-radius: 999px;
  display: block;
}

.tweet-avatar-fallback {
  display: flex;
  align-items: center;
  justify-content: center;
}

.tweet-avatar-logo {
  width: 20px;
  height: 20px;
  color: rgba(255, 255, 255, 0.78);
}

.tweet-avatar img {
  object-fit: cover;
  border: 1px solid var(--brand-border-strong);
  background: var(--brand-surface-alt);
}

.tweet-avatar-fallback {
  border: 1px solid var(--brand-border-strong);
  background: radial-gradient(circle at 30% 30%, rgba(3, 255, 10, 0.25), rgba(0, 0, 0, 0.55));
}

.tweet-content {
  flex: 1 1 auto;
  min-width: 0;
}

.tweet-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 8px;
  min-width: 0;
}

.tweet-name {
  font-weight: 700;
  color: var(--brand-text-primary);
  font-family: var(--brand-font-secondary);
  font-size: calc(1rem * var(--brand-text-scale-secondary));
}

.tweet-handle,
.tweet-time {
  color: var(--brand-text-muted);
  font-family: var(--brand-font-secondary);
  font-size: calc(0.85rem * var(--brand-text-scale-secondary));
  white-space: nowrap;
}

.tweet-text {
  margin-top: 8px;
  color: var(--brand-text-primary);
  font-family: var(--brand-font-secondary);
  font-size: calc(1.05rem * var(--brand-text-scale-secondary));
  line-height: 1.35;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
}

.component-live-mints-card {
  align-items: stretch;
  gap: 12px;
  justify-content: flex-start;
}

.live-mints-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}

.live-mints-title {
  font-family: var(--brand-font-primary);
  font-size: calc(0.95rem * var(--brand-text-scale-primary));
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--shell-text-muted);
}

.live-mints-subtitle {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.8rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-muted);
  white-space: nowrap;
}

.live-mints-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  padding-right: 4px;
}

.live-mints-list--horizontal {
  flex-direction: row;
  align-items: stretch;
  overflow-x: auto;
  overflow-y: hidden;
  padding-right: 0;
  padding-bottom: 4px;
}

.live-mints-list--horizontal .live-mints-item {
  flex: 0 0 min(340px, 78%);
  width: min(340px, 78%);
}

.live-mints-item {
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  min-height: 110px;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid var(--brand-border-strong);
  background: var(--brand-surface-alt);
  text-decoration: none;
  color: inherit;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.live-mints-item--glow {
  position: relative;
  overflow: hidden;
}

.live-mints-item--skipped {
  border-color: var(--brand-danger);
  background: color-mix(in srgb, var(--brand-danger-soft) 35%, var(--brand-surface-alt));
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--brand-danger) 55%, transparent);
}

.live-mints-item--skipped .live-mints-item__name,
.live-mints-item--skipped .live-mints-item__cap {
  color: var(--brand-danger);
}

.live-mints-item__glow {
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(64, 255, 156, 0.8) 45%,
    rgba(140, 255, 210, 0.9) 50%,
    rgba(64, 255, 156, 0.8) 55%,
    transparent 100%
  );
  background-size: 200% 100%;
  animation: liveMintsGlow 0.9s ease forwards;
  animation-delay: var(--glow-delay, 0s);
  opacity: 0;
  pointer-events: none;
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
}

@keyframes liveMintsGlow {
  0% {
    opacity: 0;
    background-position: 0% 0;
  }
  20% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    background-position: 100% 0;
  }
}

.live-mints-item:hover {
  border-color: var(--brand-accent);
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.35);
  transform: translateY(-1px);
}

.live-mints-item__image {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  overflow: hidden;
  background: var(--brand-surface);
  border: 1px solid var(--brand-border-strong);
  display: flex;
  align-items: center;
  justify-content: center;
}

.live-mints-item__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.live-mints-item__fallback {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.68rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-muted);
  text-align: center;
  padding: 0 4px;
}

.live-mints-item__meta {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.live-mints-item__title {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
}

.live-mints-item__name {
  font-family: var(--brand-font-primary);
  font-size: calc(0.95rem * var(--brand-text-scale-primary));
  font-weight: 700;
  color: var(--brand-text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.live-mints-item__time {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.72rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-muted);
  white-space: nowrap;
}

.live-mints-item__details {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
}

.live-mints-item__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.live-mints-item__skip {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.75rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  flex: 1 1 auto;
  min-width: 0;
}

.live-mints-item__symbol {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.8rem * var(--brand-text-scale-secondary));
  color: var(--brand-text-muted);
}

.live-mints-item__cap {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.85rem * var(--brand-text-scale-secondary));
  color: var(--brand-text-primary);
}

.live-mints-item__hold {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.8rem * var(--brand-text-scale-secondary));
  color: var(--brand-danger);
  font-weight: 700;
}

.live-mints-item__buy {
  padding: 4px 10px;
  font-size: calc(0.7rem * var(--brand-text-scale-secondary));
  text-transform: uppercase;
  letter-spacing: 0.12em;
}

.live-mints-item__buy:disabled {
  cursor: not-allowed;
  opacity: 0.6;
}

.live-mints-item--skipped .live-mints-item__skip {
  color: var(--brand-danger);
}

.live-mints-empty {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.9rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-muted);
  padding: 10px 12px;
  border-radius: 12px;
  background: color-mix(in srgb, var(--brand-surface-alt) 90%, transparent);
}

.live-mints-empty.is-error {
  color: var(--brand-danger);
  background: color-mix(in srgb, var(--brand-danger-soft) 35%, transparent);
  border: 1px solid color-mix(in srgb, var(--brand-danger) 45%, transparent);
}

.wallet-component-card {
  align-items: stretch;
  gap: 12px;
  justify-content: flex-start;
}

.wallet-component-card--pnl {
  justify-content: flex-start;
  height: 100%;
  min-height: 0;
}

.wallet-component__layout--pnl {
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex: 1 1 auto;
  min-height: 0;
}

.wallet-component__layout--pnl-horizontal {
  --wallet-horizontal-item-width: min(340px, 78%);
}

.wallet-component__layout--pnl-horizontal .wallet-holdings-strip--horizontal,
.wallet-component__layout--pnl-horizontal .wallet-trades--horizontal {
  flex: 1 1 0;
  min-height: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
  padding: 0;
}

.wallet-holdings-strip {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 12px;
  border-radius: 16px;
  border: 1px solid var(--brand-border-strong);
  background: color-mix(in srgb, var(--brand-surface-alt) 80%, transparent);
}

.wallet-holdings-strip__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.wallet-holdings-strip__title {
  font-family: var(--brand-font-primary);
  font-size: calc(0.95rem * var(--brand-text-scale-primary));
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--shell-text-muted);
}

.wallet-holdings-strip__count {
  font-family: var(--brand-font-primary);
  font-size: calc(1.6rem * var(--brand-text-scale-primary));
  font-weight: 700;
  color: var(--brand-text-primary);
}

.wallet-holdings-strip__pnl {
  align-self: flex-start;
  font-family: var(--brand-font-secondary);
  font-size: calc(0.9rem * var(--brand-text-scale-secondary));
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--shell-text-muted);
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid var(--brand-border-strong);
  background: color-mix(in srgb, var(--brand-surface-alt) 85%, transparent);
}

.wallet-holdings-strip__pnl.is-positive {
  color: #36ff6b;
  border-color: color-mix(in srgb, #36ff6b 45%, transparent);
  background: color-mix(in srgb, #36ff6b 14%, transparent);
}

.wallet-holdings-strip__pnl.is-negative {
  color: var(--brand-danger);
  border-color: color-mix(in srgb, var(--brand-danger) 45%, transparent);
  background: color-mix(in srgb, var(--brand-danger-soft) 32%, transparent);
}

.wallet-holdings-strip__list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-height: 220px;
  overflow-y: auto;
  overflow-x: hidden;
  padding-right: 4px;
  flex: 1 1 auto;
  min-height: 0;
}

.wallet-holdings-strip__list--horizontal {
  flex-direction: row;
  align-items: stretch;
  max-height: none;
  overflow-x: auto;
  overflow-y: hidden;
  padding-right: 0;
  padding-bottom: 4px;
}

.wallet-holdings-strip__list--horizontal .wallet-live-mint-card,
.wallet-trades__list--horizontal .wallet-live-mint-card {
  flex: 0 0 var(--wallet-horizontal-item-width, min(340px, 78%));
  width: var(--wallet-horizontal-item-width, min(340px, 78%));
}

.wallet-holdings-item__row {
  display: flex;
  align-items: center;
  gap: 10px;
}

.wallet-holdings-strip__list--horizontal .wallet-holdings-item__row {
  flex: 0 0 var(--wallet-horizontal-item-width, clamp(260px, 30vw, 380px));
  flex-direction: column;
  align-items: stretch;
  gap: 8px;
}

.wallet-holdings-item__link {
  flex: 1 1 auto;
  min-width: 0;
}

.wallet-holdings-strip__list--horizontal .wallet-holdings-item__link {
  width: 100%;
}

.wallet-holdings-item__sell {
  white-space: nowrap;
}

.wallet-holdings-strip__list--horizontal .wallet-holdings-item__sell {
  align-self: flex-end;
}

.wallet-holdings-strip__item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--brand-border-strong);
  background: color-mix(in srgb, var(--brand-surface) 70%, transparent);
  font-family: var(--brand-font-secondary);
  font-size: calc(0.78rem * var(--brand-text-scale-secondary));
  color: var(--brand-text-primary);
}

.wallet-holdings-strip__image {
  width: 24px;
  height: 24px;
  border-radius: 999px;
  overflow: hidden;
  border: 1px solid var(--brand-border-strong);
  background: var(--brand-surface);
  display: flex;
  align-items: center;
  justify-content: center;
}

.wallet-holdings-strip__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.wallet-holdings-strip__fallback {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.6rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-muted);
}

.wallet-holdings-strip__label {
  max-width: 140px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.wallet-holdings-item__amount {
  font-family: var(--brand-font-primary);
  font-size: calc(1.05rem * var(--brand-text-scale-primary));
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--brand-text-primary);
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid var(--brand-border-strong);
  background: color-mix(in srgb, var(--brand-surface) 70%, transparent);
  white-space: nowrap;
}

.wallet-holdings-item__cap {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.75rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-muted);
}

.wallet-holdings-strip__empty {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.82rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-muted);
  padding: 6px 2px;
}

.wallet-buy-button--compact {
  padding: 6px 16px;
  font-size: 0.78rem;
}

.wallet-component__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.wallet-component__pnl-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 8px;
}

.wallet-component__pnl-header--no-label {
  justify-content: flex-end;
  margin-bottom: 0;
}

.wallet-component__header-main {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.wallet-component__toggle {
  margin-top: 6px;
  font-size: 0.78rem;
}

.wallet-component__toggle--no-label {
  margin-top: 0;
}

.wallet-component__title {
  font-family: var(--brand-font-primary);
  font-size: calc(0.95rem * var(--brand-text-scale-primary));
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--shell-text-muted);
}

.wallet-component__subtitle {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.8rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-muted);
}

.wallet-component__address {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--shell-text-muted);
}

.wallet-component__address code {
  font-family: var(--brand-font-mono);
  font-size: calc(0.78rem * var(--brand-text-scale-secondary));
  padding: 2px 6px;
  border-radius: 999px;
  border: 1px solid var(--brand-border-strong);
  color: var(--brand-text-primary);
  background: color-mix(in srgb, var(--brand-surface-alt) 85%, transparent);
}

.wallet-component__copy {
  margin-top: 4px;
  align-self: flex-end;
  background: transparent;
  border: 1px solid var(--brand-border-strong);
  border-radius: 999px;
  padding: 4px 8px;
  font-size: 0.85rem;
  line-height: 1;
  color: inherit;
  cursor: pointer;
}

.wallet-component__copy:hover {
  border-color: var(--brand-accent);
  color: var(--brand-accent);
}

.wallet-component__copy-note {
  margin-top: 4px;
  font-size: 0.75rem;
  color: var(--brand-accent);
}

.wallet-component__balance {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  font-family: var(--brand-font-primary);
  font-weight: 700;
  font-size: calc(1.6rem * var(--brand-text-scale-primary));
  color: var(--brand-text-primary);
}

.wallet-component__balance span {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.75rem * var(--brand-text-scale-secondary));
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--shell-text-muted);
}

.wallet-component__balance strong {
  font-weight: 700;
}

.wallet-component__pnl {
  text-align: center;
  font-family: var(--brand-font-secondary);
  font-size: calc(0.85rem * var(--brand-text-scale-secondary));
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--shell-text-muted);
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid var(--brand-border-strong);
  background: color-mix(in srgb, var(--brand-surface-alt) 85%, transparent);
}

.wallet-component__pnl.is-positive {
  color: #36ff6b;
  border-color: color-mix(in srgb, #36ff6b 45%, transparent);
  background: color-mix(in srgb, #36ff6b 12%, transparent);
}

.wallet-component__pnl.is-negative {
  color: var(--brand-danger);
  border-color: color-mix(in srgb, var(--brand-danger) 45%, transparent);
  background: color-mix(in srgb, var(--brand-danger-soft) 35%, transparent);
}

.wallet-component__actions {
  display: flex;
  justify-content: center;
}

.wallet-buy-button {
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--brand-accent) 60%, transparent);
  background: linear-gradient(135deg, color-mix(in srgb, var(--brand-accent) 70%, #2cff8b), var(--brand-accent));
  color: #041d10;
  padding: 8px 20px;
  font-weight: 700;
  letter-spacing: 0.08em;
  cursor: pointer;
}

.wallet-buy-button:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.wallet-component__list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  padding-right: 4px;
}

.wallet-trades {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 12px;
  border-radius: 16px;
  border: 1px solid var(--brand-border-strong);
  background: color-mix(in srgb, var(--brand-surface-alt) 75%, transparent);
  flex: 1 1 auto;
  min-height: 0;
}

.wallet-trades__header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}

.wallet-trades__title {
  font-family: var(--brand-font-primary);
  font-size: calc(1rem * var(--brand-text-scale-primary));
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--shell-text-muted);
}

.wallet-trades__subtitle {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.82rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-muted);
  white-space: nowrap;
}

.wallet-trades__list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-height: 360px;
  overflow-y: auto;
  overflow-x: hidden;
  padding-right: 4px;
  flex: 1 1 auto;
  min-height: 0;
}

.wallet-trades__list--horizontal {
  flex-direction: row;
  align-items: stretch;
  max-height: none;
  overflow-x: auto;
  overflow-y: hidden;
  padding-right: 0;
  padding-bottom: 4px;
}

.wallet-trades__list--horizontal .wallet-trades__item {
  flex: 0 0 var(--wallet-horizontal-item-width, clamp(260px, 30vw, 380px));
}

.wallet-live-mint-card__pnl {
  font-family: var(--brand-font-primary);
  font-size: calc(0.95rem * var(--brand-text-scale-primary));
  font-weight: 700;
  letter-spacing: 0.04em;
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid var(--brand-border-strong);
  background: color-mix(in srgb, var(--brand-surface) 70%, transparent);
  white-space: nowrap;
}

.wallet-live-mint-card__pnl.is-positive {
  color: #36ff6b;
  border-color: color-mix(in srgb, #36ff6b 50%, transparent);
  background: color-mix(in srgb, #36ff6b 18%, transparent);
}

.wallet-live-mint-card__pnl.is-negative {
  color: var(--brand-danger);
  border-color: color-mix(in srgb, var(--brand-danger) 50%, transparent);
  background: color-mix(in srgb, var(--brand-danger-soft) 35%, transparent);
}

.wallet-live-mint-card__pnl.is-entry {
  color: var(--brand-accent);
  border-color: color-mix(in srgb, var(--brand-accent) 45%, transparent);
  background: color-mix(in srgb, var(--brand-accent) 12%, transparent);
}

.wallet-component-card--pnl .wallet-trades__list {
  max-height: none;
}

.wallet-trades__item {
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid var(--brand-border-strong);
  background: var(--brand-surface-alt);
  text-decoration: none;
  color: inherit;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.wallet-trades__item:hover {
  border-color: var(--brand-accent);
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.35);
  transform: translateY(-1px);
}

.wallet-trades__image {
  width: 64px;
  height: 64px;
  border-radius: 14px;
  overflow: hidden;
  background: var(--brand-surface);
  border: 1px solid var(--brand-border-strong);
  display: flex;
  align-items: center;
  justify-content: center;
}

.wallet-trades__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.wallet-trades__fallback {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.7rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-muted);
  text-align: center;
  padding: 0 4px;
}

.wallet-trades__meta {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.wallet-trades__title-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
}

.wallet-trades__name {
  font-family: var(--brand-font-primary);
  font-size: calc(1.05rem * var(--brand-text-scale-primary));
  font-weight: 700;
  color: var(--brand-text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.wallet-trades__time {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.75rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-muted);
  white-space: nowrap;
}

.wallet-trades__details {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  font-family: var(--brand-font-secondary);
  font-size: calc(0.8rem * var(--brand-text-scale-secondary));
  color: var(--brand-text-muted);
}

.wallet-trades__symbol {
  font-family: var(--brand-font-mono);
  font-size: calc(0.75rem * var(--brand-text-scale-secondary));
  letter-spacing: 0.06em;
  color: var(--shell-text-muted);
}

.wallet-trades__side {
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 999px;
  border: 1px solid var(--brand-border-strong);
}

.wallet-trades__side.is-buy {
  color: var(--brand-accent);
  border-color: color-mix(in srgb, var(--brand-accent) 45%, transparent);
  background: color-mix(in srgb, var(--brand-accent) 16%, transparent);
}

.wallet-trades__side.is-sell {
  color: #36ff6b;
  border-color: color-mix(in srgb, #36ff6b 45%, transparent);
  background: color-mix(in srgb, #36ff6b 16%, transparent);
}

.wallet-trades__pnl {
  font-family: var(--brand-font-primary);
  font-size: calc(1.05rem * var(--brand-text-scale-primary));
  font-weight: 700;
  letter-spacing: 0.04em;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid var(--brand-border-strong);
  background: color-mix(in srgb, var(--brand-surface) 70%, transparent);
  white-space: nowrap;
}

.wallet-trades__pnl.is-positive {
  color: #36ff6b;
  border-color: color-mix(in srgb, #36ff6b 50%, transparent);
  background: color-mix(in srgb, #36ff6b 18%, transparent);
}

.wallet-trades__pnl.is-negative {
  color: var(--brand-danger);
  border-color: color-mix(in srgb, var(--brand-danger) 50%, transparent);
  background: color-mix(in srgb, var(--brand-danger-soft) 35%, transparent);
}

.wallet-trades__pnl.is-entry {
  color: var(--brand-accent);
  border-color: color-mix(in srgb, var(--brand-accent) 45%, transparent);
  background: color-mix(in srgb, var(--brand-accent) 12%, transparent);
}

.wallet-trades__empty {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.85rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-secondary);
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px dashed color-mix(in srgb, var(--brand-border) 60%, transparent);
  background: color-mix(in srgb, var(--brand-surface-alt) 75%, transparent);
}

.wallet-component__row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid var(--brand-border-strong);
  background: var(--brand-surface-alt);
}

.wallet-component__token {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.wallet-component__token-link {
  text-decoration: none;
  color: inherit;
  cursor: pointer;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.wallet-component__token-link:hover {
  transform: translateY(-1px);
}

.wallet-component__token-image {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  overflow: hidden;
  background: var(--brand-surface);
  border: 1px solid var(--brand-border-strong);
  display: flex;
  align-items: center;
  justify-content: center;
}

.wallet-component__token-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.wallet-component__token-fallback {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.68rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-muted);
  text-align: center;
  padding: 0 4px;
}

.wallet-component__token-meta {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.wallet-component__token-name {
  font-family: var(--brand-font-primary);
  font-size: calc(0.95rem * var(--brand-text-scale-primary));
  font-weight: 700;
  color: var(--brand-text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.wallet-component__token-sub {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 8px;
  font-family: var(--brand-font-secondary);
  font-size: calc(0.78rem * var(--brand-text-scale-secondary));
  color: var(--brand-text-muted);
}

.wallet-component__token-sub code {
  font-family: var(--brand-font-mono);
  font-size: calc(0.7rem * var(--brand-text-scale-secondary));
  letter-spacing: 0.04em;
  color: var(--shell-text-muted);
}

.wallet-component__token-cap {
  font-size: calc(0.76rem * var(--brand-text-scale-secondary));
  color: color-mix(in srgb, var(--brand-positive) 80%, transparent);
}

.wallet-component__sell {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.wallet-sell-button {
  border-radius: 999px;
  border: 1px solid var(--ghost-button-border);
  background: color-mix(in srgb, var(--brand-surface) 70%, transparent);
  color: var(--brand-text-primary);
  font-size: 0.75rem;
  padding: 6px 12px;
  cursor: pointer;
}

.wallet-sell-button:hover:not(:disabled) {
  border-color: var(--ghost-button-border-hover);
  background: color-mix(in srgb, var(--ghost-button-border-hover) 18%, transparent);
}

.wallet-sell-button:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.wallet-component__notice {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.85rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-secondary);
  padding: 8px 12px;
  border-radius: 12px;
  border: 1px solid color-mix(in srgb, var(--brand-border) 60%, transparent);
  background: color-mix(in srgb, var(--brand-surface-alt) 80%, transparent);
}

.wallet-component__notice.is-error {
  color: var(--brand-danger);
  background: color-mix(in srgb, var(--brand-danger-soft) 35%, transparent);
  border: 1px solid color-mix(in srgb, var(--brand-danger) 45%, transparent);
}

.wallet-buy-modal .project-settings-form {
  gap: 16px;
}

.wallet-buy-preview {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  border-radius: 14px;
  border: 1px solid var(--brand-border-strong);
  background: var(--brand-surface-alt);
}

.wallet-buy-preview__image {
  width: 64px;
  height: 64px;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid var(--brand-border-strong);
  background: var(--brand-surface);
  display: flex;
  align-items: center;
  justify-content: center;
}

.wallet-buy-preview__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.wallet-buy-preview__placeholder {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.72rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-muted);
  text-align: center;
  padding: 0 6px;
}

.wallet-buy-preview__meta {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}

.wallet-buy-preview__name {
  font-family: var(--brand-font-primary);
  font-size: calc(1.05rem * var(--brand-text-scale-primary));
  font-weight: 700;
  color: var(--brand-text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.wallet-buy-preview__symbol {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.85rem * var(--brand-text-scale-secondary));
  color: var(--brand-text-muted);
}

.wallet-buy-preview__mint {
  font-family: var(--brand-font-mono);
  font-size: calc(0.72rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-muted);
  letter-spacing: 0.04em;
}

.component-challenge-stack {
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 12px;
  overflow: auto;
}

.header-card {
  position: relative;
  min-height: clamp(110px, 14vw, 160px);
  background: var(--component-background, var(--brand-surface));
  border: 1px solid var(--brand-border);
  border-radius: var(--brand-radius);
  padding: clamp(12px, 1.6vw, 20px);
  display: flex;
  flex-direction: column;
  gap: 10px;
  justify-content: center;
  box-shadow: 0 18px 32px rgba(0, 0, 0, 0.4);
  width: 100%;
}

.header-card-support {
  flex-direction: column;
  gap: clamp(12px, 1.8vw, 18px);
}

.header-card-support--expanded {
  display: grid;
  grid-template-columns: minmax(0, 1.8fr) minmax(0, 1fr);
  gap: 0;
  align-items: stretch;
}

.header-card-support--expanded.header-card-support--triple {
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr) minmax(0, 1fr);
}

.burnair-header-card.header-card-support--expanded {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.burnair-header-card--pair.header-card-support--expanded {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.header-card-support--expanded > * {
  align-self: stretch;
}

.header-card-support--expanded > :first-child {
  padding-right: clamp(14px, 2vw, 20px);
}

.header-card-support--expanded > :not(:first-child) {
  border-left: 1px solid var(--brand-border);
  padding-left: clamp(14px, 2vw, 20px);
}

.header-card-support--expanded > :not(:first-child):not(:last-child) {
  padding-right: clamp(14px, 2vw, 20px);
}

.header-card-support--stack {
  display: grid;
  grid-auto-flow: row;
  grid-auto-rows: minmax(0, 1fr);
  gap: 0;
  align-items: stretch;
  justify-items: stretch;
  align-content: stretch;
  justify-content: stretch;
  min-height: 0;
}

.header-card-support--stack > * {
  align-self: stretch;
  min-height: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.header-card-support--stack > :not(:first-child) {
  border-top: 1px solid var(--brand-border);
  margin-top: 0;
  padding-top: clamp(6px, 0.9vw, 10px);
}

.support-primary {
  display: flex;
  align-items: flex-start;
  gap: clamp(14px, 2vw, 20px);
}

.header-card-charity-mark {
  height: clamp(48px, 7vw, 84px);
  width: clamp(48px, 7vw, 84px);
  border-radius: var(--brand-radius-sm);
  border: 1px solid var(--brand-border-strong);
  object-fit: contain;
  background: var(--brand-surface-alt);
}

.header-card-details {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.header-card-label,
.support-meta-label {
  font-family: var(--brand-font-secondary);
  font-size: calc(clamp(0.9rem, 1.4vw, 1.125rem) * var(--brand-text-scale-primary));
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--shell-text-muted);
}

.header-card-name {
  font-family: var(--brand-font-primary);
  font-size: calc(clamp(1.1rem, 2.6vw, 1.65rem) * var(--brand-text-scale-primary));
  font-weight: 600;
  color: var(--brand-text-primary);
}

.header-card-address {
  font-family: var(--brand-font-mono);
  font-size: calc(clamp(0.72rem, 1.5vw, 0.85rem) * var(--brand-text-scale-secondary));
  letter-spacing: 0.06em;
  color: var(--shell-text-secondary);
  overflow-wrap: anywhere;
}

.header-card-address-link {
  color: inherit;
  text-decoration: none;
}

.header-card-address-link:hover {
  text-decoration: underline;
}

.support-meta {
  display: flex;
  flex-direction: column;
  gap: 10px;
  justify-content: flex-start;
}

.support-meta-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  align-items: start;
}

.support-meta-grid > :first-child {
  padding-right: 12px;
}

.support-meta-grid > :not(:first-child) {
  border-left: 1px solid var(--brand-border);
  padding-left: 12px;
}

.support-meta-grid--donation {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}

.support-meta-col {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-width: 0;
}

.support-meta-row {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.support-meta-value {
  font-family: var(--brand-font-primary);
  font-size: calc(clamp(1.05rem, 2vw, 1.4rem) * var(--brand-text-scale-primary));
  font-weight: 600;
  color: var(--brand-accent-soft);
}

.support-meta-link {
  font-family: var(--brand-font-mono);
  font-size: calc(0.75rem * var(--brand-text-scale-secondary));
  letter-spacing: 0.08em;
  color: var(--brand-accent-soft);
  text-decoration: none;
}

.support-meta-link:hover {
  text-decoration: underline;
}

.support-meta-muted {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.75rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-secondary);
  opacity: 0.7;
}

.header-card-compact {
  padding: clamp(10px, 1.2vw, 14px) clamp(12px, 1.4vw, 16px);
  gap: 10px;
}

.header-card--metric-horizontal {
  min-height: clamp(72px, 9vw, 96px);
  padding: clamp(8px, 1vw, 12px) clamp(10px, 1.2vw, 14px);
  gap: 6px;
}

.header-card-wide {
  grid-column: span 2;
}

.metric-inline {
  display: grid;
  gap: 8px;
  min-width: 0;
}

.metric-inline-label {
  font-family: var(--brand-font-primary);
  font-size: calc(clamp(1rem, 1.6vw, 1.2rem) * var(--brand-text-scale-primary));
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--shell-text-muted);
  line-height: 1.08;
  min-width: 0;
  overflow-wrap: anywhere;
}

.metric-inline-value {
  font-family: var(--brand-font-secondary);
  font-size: calc(clamp(1.5rem, 3vw, 2.4rem) * var(--brand-text-scale-secondary));
  font-weight: 600;
  color: var(--brand-accent-soft);
  line-height: 1.02;
  min-width: 0;
  overflow-wrap: anywhere;
}

.market-cap-value {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
  color: var(--brand-text-primary);
}

.market-cap-value.is-up {
  color: var(--brand-accent);
}

.market-cap-value.is-down {
  color: var(--brand-danger);
}

.market-cap-arrow {
  width: 0;
  height: 0;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-bottom: 16px solid currentColor;
}

.market-cap-value.is-down .market-cap-arrow {
  border-bottom: 0;
  border-top: 16px solid currentColor;
}

.metric-inline-caption {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.78rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-secondary);
  min-width: 0;
  overflow-wrap: anywhere;
}

.metric-inline--horizontal {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.4fr);
  column-gap: clamp(12px, 1.6vw, 18px);
  row-gap: clamp(4px, 0.6vw, 8px);
  align-items: center;
}

.metric-inline--horizontal .metric-inline-label {
  align-self: center;
  text-align: left;
  margin: 0;
}

.metric-inline--horizontal .metric-inline-value {
  justify-self: end;
  text-align: right;
  margin: 0;
}

.metric-inline--horizontal .metric-inline-caption {
  grid-column: 1 / -1;
  text-align: left;
}

.metric-inline--horizontal.metric-inline--horizontal-no-label {
  grid-template-columns: minmax(0, 1fr);
}

.metric-inline--horizontal.metric-inline--horizontal-no-label .metric-inline-value,
.metric-inline--horizontal.metric-inline--horizontal-no-label .metric-inline-caption {
  justify-self: start;
  text-align: left;
}

.header-card-support--stack .metric-inline {
  gap: 4px;
}

.header-card-support--stack .metric-inline-label {
  font-size: calc(clamp(0.78rem, 1.05vw, 0.95rem) * var(--brand-text-scale-primary));
}

.header-card-support--stack .metric-inline-value {
  font-size: calc(clamp(1.15rem, 1.9vw, 1.85rem) * var(--brand-text-scale-secondary));
  line-height: 1.05;
}

.header-card-support--stack .metric-inline-caption {
  font-size: calc(0.68rem * var(--brand-text-scale-secondary));
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.header-card-support--stack .support-primary {
  align-items: center;
  gap: 10px;
  min-height: 0;
}

.header-card-support--stack .header-card-charity-mark {
  width: clamp(34px, 4.2vw, 48px);
  height: clamp(34px, 4.2vw, 48px);
}

.header-card-support--stack .header-card-details {
  min-width: 0;
  gap: 4px;
}

.header-card-support--stack .header-card-name {
  font-size: calc(clamp(0.92rem, 1.55vw, 1.25rem) * var(--brand-text-scale-primary));
  line-height: 1.1;
}

.header-card-support--stack .header-card-address {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.longest-holders-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  overflow: auto;
  padding-top: 6px;
}

.longest-holders-row {
  display: grid;
  grid-template-columns: 3.5ch minmax(0, 1fr) 7ch minmax(0, 10ch);
  gap: 10px;
  align-items: center;
  font-family: var(--brand-font-secondary);
  font-size: calc(0.85rem * var(--brand-text-scale-secondary));
  color: var(--brand-text-primary);
}

.longest-holders-rank {
  color: var(--shell-text-secondary);
  opacity: 0.9;
}

.longest-holders-wallet {
  font-family: var(--brand-font-mono);
  font-size: calc(0.82rem * var(--brand-text-scale-secondary));
  letter-spacing: 0.06em;
  background: transparent;
  border: 0;
  padding: 0;
  color: var(--brand-accent-soft);
}

.longest-holders-age {
  justify-self: end;
  color: var(--shell-text-muted);
}

.longest-holders-balance {
  justify-self: end;
  color: var(--shell-text-secondary);
  opacity: 0.8;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.metric-stack {
  display: grid;
  gap: 12px;
}

.metric-stack-item {
  display: grid;
  gap: 6px;
}

.metric-stack-label {
  font-family: var(--brand-font-primary);
  font-size: calc(clamp(1rem, 1.6vw, 1.2rem) * var(--brand-text-scale-primary));
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--brand-text-muted);
}

.metric-stack-value {
  font-family: var(--brand-font-secondary);
  font-size: calc(clamp(1.4rem, 2.6vw, 2.1rem) * var(--brand-text-scale-secondary));
  font-weight: 600;
  color: var(--brand-text-primary);
}

.metric-stack-caption {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.75rem * var(--brand-text-scale-secondary));
  color: var(--brand-accent-soft);
}

.status-pill {
  align-self: flex-end;
  display: inline-flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
  border: 1px solid var(--brand-border);
  border-radius: 14px;
  padding: 10px 14px;
  background: var(--brand-accent-contrast);
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.35);
  color: var(--brand-text-primary);
}

.status-pill-label {
  font-size: 0.65rem;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--brand-text-primary);
}

.status-pill-value {
  font-size: clamp(1rem, 2vw, 1.4rem);
  font-weight: 700;
  letter-spacing: 0.18em;
  color: var(--brand-text-primary);;
}

.status-pill.is-live {
  border-color: color-mix(in srgb, var(--brand-accent) 55%, var(--brand-border) 45%);
  background: linear-gradient(
    140deg,
    color-mix(in srgb, var(--brand-accent-contrast) 84%, #000 16%),
    color-mix(in srgb, var(--brand-accent) 26%, var(--brand-accent-contrast) 74%)
  );
}

.status-pill.is-live .status-pill-value {
  color: var(--brand-accent-soft);
}

.status-pill.is-live .status-pill-caption {
  color: color-mix(in srgb, var(--brand-accent-soft) 70%, var(--brand-text-secondary) 30%);
  opacity: 1;
}

.status-pill.is-paused .status-pill-value {
  color: var(--brand-danger-soft);
}

.status-pill-caption {
  font-size: 0.7rem;
  color: var(--shell-text-secondary);
  opacity: 0.8;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.vote-sections {
  display: flex;
  flex-direction: column;
  gap: clamp(10px, 1.6vw, 16px);
}

.how-it-works {
  display: flex;
}

.how-it-works-card {
  flex: 1 1 auto;
  background: var(--brand-surface);
  border: 1px solid var(--brand-border);
  border-radius: 18px;
  padding: clamp(14px, 1.8vw, 20px);
  display: grid;
  gap: 10px;
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.45);
  color: var(--shell-text-secondary);
}

.how-it-works-card h2 {
  margin: 0;
  color: var(--brand-text-primary);
  font-family: var(--brand-font-primary);
  font-size: calc(clamp(1.05rem, 2vw, 1.3rem) * var(--brand-text-scale-primary));
}

.charity-vote-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: clamp(12px, 1.6vw, 18px);
  align-items: stretch;
}

.charity-vote-card {
  background: var(--brand-surface-alt);
  border: 1px solid var(--brand-border);
  border-radius: 18px;
  padding: clamp(16px, 1.8vw, 20px);
  display: flex;
  align-items: stretch;
  min-height: clamp(150px, 22vw, 200px);
  box-shadow: 0 18px 30px rgba(0, 0, 0, 0.28);
  transition: transform 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease;
}

.charity-vote-body {
  display: grid;
  grid-template-columns: minmax(0, 1fr) clamp(120px, 22vw, 180px);
  align-items: center;
  gap: clamp(12px, 1.8vw, 20px);
  width: 100%;
}

.charity-vote-card.countdown {
  align-items: center;
  justify-content: center;
  text-align: center;
}

.charity-vote-card:hover {
  transform: translateY(-1px);
  border-color: var(--shell-accent);
  box-shadow: 0 14px 24px color-mix(in srgb, var(--brand-accent) 30%, transparent);
}

.charity-vote-card.is-active {
  border-color: var(--shell-accent);
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--brand-accent) 40%, transparent),
    0 18px 28px color-mix(in srgb, var(--brand-accent) 18%, transparent);
}

 .charity-vote-details {
   display: flex;
   flex-direction: column;
   align-items: flex-start;
   gap: clamp(10px, 1.4vw, 14px);
   text-align: left;
 }

.charity-vote-count {
  font-size: calc(clamp(1.75rem, 3.6vw, 2.5rem) * var(--brand-text-scale-primary));
  font-weight: 700;
  color: var(--brand-text-primary);
  font-family: var(--brand-font-mono);
}

.charity-vote-logo {
  width: 100%;
  object-fit: contain;
  border-radius: 12px;
  border: 1px solid var(--brand-border-strong);
  background: var(--brand-surface);
}

.charity-vote-name {
  font-size: clamp(1.05rem, 2.2vw, 1.5rem);
  font-weight: 600;
  color: var(--brand-text-primary);
  line-height: 1.3;
}

.charity-vote-command {
  font-size: clamp(1.2rem, 2.6vw, 1.6rem);
  text-transform: uppercase;
  letter-spacing: 0.28em;
  color: var(--brand-accent-soft);
  white-space: nowrap;
}

.charity-countdown-label {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--brand-text-muted);
}

.charity-countdown-value {
  font-size: calc(clamp(1.625rem, 3.6vw, 2.25rem) * var(--brand-text-scale-primary));
  font-weight: 650;
  color: var(--brand-text-primary);
  font-family: var(--brand-font-mono);
}

.charity-countdown-caption {
  font-size: 0.82rem;
  color: var(--brand-accent-soft);
  letter-spacing: 0.1em;
}

.actions {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(12px, 2vw, 18px);
  justify-content: flex-start;
}

.actions .toggle {
  flex: 0 0 auto;
  border: none;
  border-radius: 14px;
  padding: 10px 24px;
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  border: 1px solid var(--brand-border-strong);
  background: var(--brand-accent);
  color: var(--brand-accent-contrast);
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease, color 0.2s ease;
  box-shadow: 0 14px 26px color-mix(in srgb, var(--brand-accent) 25%, transparent);
}

.actions .toggle:hover {
  transform: translateY(-2px);
}

.actions .toggle:active {
  transform: translateY(0);
  box-shadow: 0 8px 18px color-mix(in srgb, var(--brand-accent) 25%, transparent);
}

.actions .toggle[data-state="stop"] {
  background: transparent;
  color: var(--brand-text-primary);
  border-color: var(--brand-border-strong);
  box-shadow: none;
}

.actions .toggle[data-state="stop"]:hover {
  box-shadow: 0 12px 20px color-mix(in srgb, var(--brand-accent) 18%, transparent);
}

.log-region {
  flex: 1 1 auto;
  display: flex;
  flex-wrap: wrap;
  gap: clamp(12px, 2vw, 18px);
  margin-top: clamp(8px, 1.2vw, 14px);
}

.donations-section,
.donations-page {
  margin-top: clamp(24px, 4vw, 36px);
  background: var(--brand-surface);
  border: 1px solid var(--brand-border);
  border-radius: 18px;
  padding: clamp(18px, 2.4vw, 28px);
  display: flex;
  flex-direction: column;
  gap: clamp(14px, 2vw, 20px);
  box-shadow: 0 18px 38px rgba(0, 0, 0, 0.45);
}

.section-heading {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: clamp(10px, 1.4vw, 18px);
  align-items: flex-start;
}

.section-heading h2 {
  margin: 0;
  font-size: clamp(1.1rem, 2.6vw, 1.6rem);
  font-weight: 600;
  color: var(--brand-text-primary);
}

.section-heading p {
  margin: 0;
  color: var(--shell-text-secondary);
  opacity: 0.85;
  max-width: 640px;
  line-height: 1.5;
}

.about-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 22px;
  border-radius: 999px;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.75rem;
  font-weight: 600;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease, color 0.2s ease;
  border: 1px solid var(--brand-accent-soft);
  color: var(--brand-accent-soft);
  background: transparent;
}

.about-link.about-link-accent {
  border-color: var(--brand-accent-soft);
  color: var(--brand-accent-soft);
}

.about-link:hover,
.about-link:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 12px 24px color-mix(in srgb, var(--brand-accent-soft) 18%, transparent);
  background: color-mix(in srgb, var(--brand-accent-soft) 12%, transparent);
}

.icon-inline {
  width: 18px;
  height: 18px;
}

.link-button {
  border: 1px solid var(--brand-border-strong);
  border-radius: 999px;
  background: transparent;
  color: var(--brand-text-primary);
  padding: 8px 18px;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-weight: 600;
  cursor: pointer;
  transition: color 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}

.link-button:hover,
.link-button:focus-visible {
  color: var(--shell-accent);
  border-color: var(--shell-accent);
  transform: translateY(-1px);
}

.link-button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
  border-color: var(--brand-border-strong);
}

.section-message {
  border-radius: 12px;
  padding: 12px 14px;
  background: var(--brand-surface-alt);
  border: 1px solid var(--brand-border);
  color: var(--shell-text-secondary);
  font-size: 0.85rem;
}

.section-message--error {
  background: color-mix(in srgb, var(--brand-danger) 12%, transparent);
  border-color: color-mix(in srgb, var(--brand-danger) 32%, transparent);
  color: var(--brand-danger-soft);
}

.donation-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: clamp(10px, 1.6vw, 16px);
}

.donation-item {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  border: 1px solid var(--brand-border);
  border-radius: 14px;
  background: var(--brand-surface-alt);
  padding: clamp(12px, 1.6vw, 18px);
}

.donation-primary {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.donation-charity {
  font-weight: 600;
  color: var(--brand-text-primary);
  font-size: 1rem;
}

.donation-amount {
  font-family: var(--brand-font-mono);
  font-weight: 600;
  color: var(--shell-accent);
}

.donation-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  font-size: 0.82rem;
  color: var(--shell-text-secondary);
}

.donation-time {
  color: var(--brand-text-muted);
}

.donation-link {
  color: var(--shell-accent);
  text-decoration: none;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.72rem;
}

.donation-link:hover,
.donation-link:focus-visible {
  text-decoration: underline;
}

.donation-link.disabled {
  color: var(--brand-text-muted);
  pointer-events: none;
  text-decoration: none;
}

.donations-table-wrapper {
  width: 100%;
  overflow-x: auto;
}

.donations-table {
  width: 100%;
  min-width: 480px;
  border-collapse: collapse;
}

.donations-table th,
.donations-table td {
  text-align: left;
  padding: 12px 14px;
  border-bottom: 1px solid var(--brand-border);
  font-size: 0.84rem;
  color: var(--shell-text-secondary);
}

.donations-table th {
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.72rem;
  color: var(--brand-text-muted);
}

.donations-table tbody tr:hover {
  background: color-mix(in srgb, var(--brand-surface-alt) 90%, transparent);
}

.donations-table a {
  color: var(--shell-accent);
  text-decoration: none;
}

.donations-table a:hover,
.donations-table a:focus-visible {
  text-decoration: underline;
}

.global-footer {
  margin-top: clamp(32px, 5vw, 48px);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: clamp(18px, 3vw, 32px);
  background: var(--brand-surface);
  border: 1px solid var(--brand-border);
  border-radius: 18px;
  padding: clamp(18px, 2.8vw, 32px);
  box-shadow: 0 18px 38px rgba(0, 0, 0, 0.45);
}

.global-footer-content {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-width: 560px;
}

.global-footer-content h3 {
  margin: 0;
  font-size: clamp(1.1rem, 2.4vw, 1.5rem);
  font-weight: 600;
  color: var(--brand-text-primary);
}

.global-footer-content p {
  margin: 0;
  color: var(--shell-text-secondary);
  opacity: 0.85;
  line-height: 1.6;
}

.global-footer-links {
  display: inline-flex;
  align-items: center;
  gap: 12px;
}

.global-footer-links .nav-link-social {
  font-size: 1.1rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.global-footer-links .nav-cta {
  font-size: 0.72rem;
  padding: 10px 20px;
}

.global-footer-art {
  flex: 0 0 clamp(420px, 45%, 560px);
  max-width: clamp(420px, 45%, 560px);
  overflow: hidden;
  border-radius: 16px;
  border: 1px solid var(--brand-border);
  background: var(--brand-surface-alt);
  box-shadow: 0 16px 30px rgba(0, 0, 0, 0.35);
  padding: clamp(8px, 1vw, 12px);
}

.global-footer-art img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 12px;
}

.nokids-proof {
  margin-top: clamp(24px, 4vw, 42px);
  background: var(--brand-surface);
  border: 1px solid var(--brand-border);
  border-radius: 22px;
  padding: clamp(18px, 2.6vw, 30px);
  box-shadow: 0 24px 48px rgba(0, 0, 0, 0.35);
}

.nokids-proof-card {
  display: flex;
  gap: clamp(16px, 3vw, 32px);
  align-items: center;
}

.nokids-proof-text {
  flex: 1 1 55%;
}

.nokids-proof-eyebrow {
  margin: 0 0 6px;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  font-family: var(--brand-font-heading);
  font-size: calc(0.7rem * var(--brand-text-scale-primary));
  color: var(--brand-text-muted);
}

.nokids-proof-text h3 {
  margin: 0 0 10px;
  font-size: calc(clamp(1.2rem, 2.6vw, 1.8rem) * var(--brand-text-scale-primary));
  color: var(--brand-text-primary);
}

.nokids-proof-text p {
  margin: 0 0 10px;
  color: var(--shell-text-secondary);
  line-height: 1.6;
}

.nokids-proof-media {
  flex: 0 0 min(320px, 38%);
  max-width: min(320px, 38%);
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(0, 0, 0, 0.2);
  overflow: hidden;
  min-width: 220px;
}

.nokids-proof-media img {
  width: 100%;
  display: block;
  object-fit: cover;
}

@media (max-width: 1100px) {
  .nokids-proof-card {
    flex-direction: column;
    align-items: flex-start;
  }

  .nokids-proof-media {
    width: 100%;
  }
}

.log-panel {
  flex: 1 1 320px;
  min-width: min(320px, 100%);
  min-height: 0;
  height: clamp(260px, 42vh, 420px);
  display: grid;
  grid-template-rows: auto 1fr;
  background: var(--brand-surface);
  border: 1px solid var(--brand-border);
  border-radius: var(--brand-radius-lg);
  box-shadow: 0 30px 60px rgba(0, 0, 0, 0.55);
  overflow: visible;
}

.log-panel--no-header {
  grid-template-rows: 1fr;
}

.log-panel--no-header .log-header {
  display: none;
}

.log-panel--compact .log-stream {
  padding: 0;
}

.log-panel--compact .log-entry {
  margin-top: 0;
  border-radius: 0;
  box-shadow: none;
  gap: 6px;
  padding: 10px 12px;
  border-left-width: 4px;
}

.log-panel--compact .log-entry + .log-entry {
  border-top: none;
}

.log-panel--fullscreen {
  height: 100%;
}

.log-panel--powershell {
  background: var(--component-background, var(--brand-surface));
  border: 1px solid var(--brand-border-strong, var(--brand-border));
  box-shadow: 0 28px 54px rgba(0, 0, 0, 0.65);
}

.log-panel--powershell .log-header {
  background: color-mix(in srgb, var(--component-background, var(--brand-surface)) 70%, #2d2d30 30%);
  border-bottom-color: var(--brand-border, #3f3f46);
  color: var(--brand-text-primary, #f3f3f3);
  font-family: var(--brand-font-primary, var(--brand-font-secondary)), "Cascadia Mono", "Consolas",
    "Lucida Console", Monaco, monospace;
  font-size: calc(0.95rem * var(--brand-text-scale-primary));
  font-weight: 600;
  letter-spacing: 0.02em;
  padding: 10px 14px;
}

.log-panel--powershell .log-stream {
  background: color-mix(in srgb, var(--component-background, var(--brand-surface)) 88%, #070707 12%);
  color: var(--brand-text-primary, #f3f3f3);
  font-family: var(--brand-font-primary, var(--brand-font-secondary)), "Cascadia Mono", "Consolas",
    "Lucida Console", Monaco, monospace;
  font-size: calc(1rem * var(--brand-text-scale-secondary));
  gap: 4px;
  padding: 10px 12px;
}

.log-panel--powershell .log-stream::-webkit-scrollbar-track {
  background: color-mix(in srgb, var(--component-background, var(--brand-surface-alt)) 82%, #101012 18%);
  border-left-color: var(--brand-border-strong, #2a2a2a);
}

.log-panel--powershell .log-stream::-webkit-scrollbar-thumb {
  background: color-mix(in srgb, var(--brand-accent-soft, #4c4c52) 55%, #4c4c52 45%);
  border-color: color-mix(in srgb, var(--component-background, var(--brand-surface-alt)) 82%, #101012 18%);
}

.log-panel--powershell .log-stream::-webkit-scrollbar-thumb:hover {
  background: color-mix(in srgb, var(--brand-accent, #67676e) 60%, #67676e 40%);
}

.log-panel--with-secondary {
  grid-template-rows: auto auto 1fr;
}

.log-panel.agent-panel--with-metrics {
  grid-template-rows: auto auto 1fr;
}

.log-panel.agent-panel--with-metrics.log-panel--no-header {
  grid-template-rows: auto 1fr;
}

.log-panel.agent-panel {
  background: var(--component-background, var(--brand-surface));
}

.log-panel.agent-panel .log-header {
  background: color-mix(in srgb, var(--component-background, var(--brand-surface)) 82%, transparent);
}

.agent-airdrop-strip {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(0, 1fr);
  border-bottom: 1px solid var(--brand-border);
  background: color-mix(
    in srgb,
    var(--component-background, var(--brand-surface-alt)) 82%,
    transparent
  );
}

.agent-airdrop-strip__item {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 8px;
  min-width: 0;
  min-height: clamp(110px, 14vw, 160px);
  padding: clamp(12px, 1.6vw, 20px);
}

.agent-airdrop-strip__item + .agent-airdrop-strip__item {
  border-left: 1px solid var(--brand-border);
}

.agent-airdrop-strip__label {
  font-family: var(--brand-font-primary);
  font-size: calc(clamp(1rem, 1.6vw, 1.2rem) * var(--brand-text-scale-primary));
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--shell-text-muted);
}

.agent-airdrop-strip__value {
  font-family: var(--brand-font-secondary);
  font-size: calc(clamp(1.5rem, 3vw, 2.4rem) * var(--brand-text-scale-secondary));
  font-weight: 600;
  color: var(--brand-accent-soft);
  line-height: 1.1;
  white-space: normal;
  overflow-wrap: anywhere;
}

.vote-panel__options {
  padding: clamp(12px, 1.8vw, 18px);
  border-bottom: 1px solid var(--brand-border);
  max-height: clamp(150px, 18vh, 220px);
  overflow-y: auto;
}

.vote-panel__empty {
  color: var(--shell-text-secondary);
  font-size: calc(0.9rem * var(--brand-text-scale-secondary));
}

.vote-panel .charity-vote-row {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
}

.vote-panel .charity-vote-card {
  min-height: 96px;
  padding: 12px;
  border-radius: 16px;
}

.vote-panel .charity-vote-body {
  grid-template-columns: minmax(0, 1fr) 92px;
  gap: 12px;
}

.vote-panel .charity-vote-count {
  font-size: calc(clamp(1.375rem, 3vw, 1.875rem) * var(--brand-text-scale-primary));
}

.vote-panel .charity-vote-name {
  font-size: calc(1rem * var(--brand-text-scale-secondary));
}

.vote-panel .charity-vote-command {
  font-size: calc(1.05rem * var(--brand-text-scale-secondary));
}

.vote-panel__log {
  padding-top: 12px;
}

.log-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: clamp(14px, 2.4vw, 22px);
  border-bottom: 1px solid var(--brand-border);
  color: var(--brand-text-primary);
  font-family: var(--brand-font-heading);
  font-size: calc(clamp(1.25rem, 3vw, 1.625rem) * var(--brand-text-scale-primary));
  font-weight: 600;
}

.log-subtitle {
  font-size: calc(0.875rem * var(--brand-text-scale-secondary));
  color: var(--brand-text-muted);
}

.log-stream {
  min-height: 0;
  height: 100%;
  overflow-y: scroll;
  padding: clamp(14px, 2.2vw, 20px);
  flex-direction: column;
  justify-content: flex-end;
  gap: clamp(10px, 1.4vw, 14px);
  scrollbar-gutter: stable both-edges;
  scrollbar-width: auto;
  scrollbar-color: var(--brand-accent-soft) var(--brand-surface-alt);
}

.agent-log-stream {
  justify-content: flex-start;
}

.agent-log-entry {
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: color-mix(in srgb, var(--component-background, var(--brand-surface-alt)) 32%, transparent);
  padding: 12px;
  display: grid;
  gap: 8px;
}

.agent-log-media {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: color-mix(in srgb, var(--component-background, var(--brand-surface)) 50%, transparent);
}

.agent-log-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.agent-log-headline {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  color: var(--brand-text-muted);
  font-size: calc(0.8rem * var(--brand-text-scale-secondary));
}

.agent-log-action {
  color: var(--brand-text-primary);
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size: calc(0.75rem * var(--brand-text-scale-secondary));
  text-transform: uppercase;
  letter-spacing: 0.08em;
  opacity: 0.9;
}

.agent-log-thought {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  color: var(--brand-text-secondary);
  font-size: calc(0.9rem * var(--brand-text-scale-secondary));
  line-height: 1.35;
  white-space: pre-wrap;
  border-left: 3px solid rgba(3, 255, 10, 0.55);
  padding-left: 10px;
  font-style: italic;
}

.agent-log-entry--skip .agent-log-thought {
  border-left-color: rgba(255, 79, 111, 0.75);
}

.agent-log-entry--skip .agent-log-action {
  color: rgba(255, 143, 146, 0.95);
}

.agent-log-entry--replying-template {
  border: 0;
  background: transparent;
  border-radius: 0;
  padding: 0;
  gap: 6px;
  box-shadow: none;
}

.agent-log-entry--replying-template .agent-log-thought {
  border-left: 0;
  padding-left: 0;
  font-style: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.agent-log-entry--replying-template .agent-log-decision {
  overflow-wrap: anywhere;
  word-break: break-word;
}

.agent-log-stream--terminal-template {
  gap: 6px;
  padding: clamp(10px, 1.4vw, 14px);
}

.agent-log-entry--terminal-template {
  border-radius: 10px;
  padding: 8px 10px;
  gap: 4px;
  background: color-mix(in srgb, var(--component-background, var(--brand-surface-alt)) 22%, transparent);
}

.agent-log-entry--terminal-template .agent-log-headline {
  font-size: calc(0.72rem * var(--brand-text-scale-secondary));
}

.agent-log-terminal-lines {
  display: grid;
  gap: 4px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size: calc(0.84rem * var(--brand-text-scale-secondary));
  line-height: 1.3;
  color: var(--brand-text-primary);
}

.agent-log-terminal-line {
  white-space: pre-wrap;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.agent-log-terminal-key {
  color: var(--brand-text-muted);
  margin-right: 0.45rem;
}

.agent-log-terminal-link {
  text-decoration: none;
}

.agent-log-terminal-link:hover {
  text-decoration: underline;
}

.agent-log-decision {
  color: var(--brand-text-primary);
  font-size: calc(1.05rem * var(--brand-text-scale-secondary));
  line-height: 1.35;
  white-space: pre-wrap;
}

.agent-log-link {
  color: inherit;
  text-decoration: none;
  cursor: pointer;
}

.agent-log-link:hover {
  text-decoration: underline;
}

.log-stream::-webkit-scrollbar {
  width: 12px;
}

.log-stream::-webkit-scrollbar-track {
  background: var(--brand-surface-alt);
  border-left: 1px solid var(--brand-border-strong);
}

.log-stream::-webkit-scrollbar-thumb {
  background: var(--brand-accent-soft);
  border-radius: 8px;
  border: 2px solid var(--brand-surface-alt);
}

.log-stream::-webkit-scrollbar-thumb:hover {
  background: var(--brand-accent);
}

.log-entry {
  background: var(--brand-surface-alt);
  border-radius: 16px;
  border: 1px solid var(--brand-border);
  padding: clamp(12px, 1.6vw, 16px);
  display: flex;
  flex-direction: column;
  gap: 8px;
  box-shadow: 0 18px 34px rgba(0, 0, 0, 0.45);
  margin-top: 16px;
}

.log-entry--powershell {
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  margin-top: 0;
  padding: 2px 0;
  gap: 3px;
}

.log-entry.info {
  border-left: 4px solid var(--brand-accent);
}

.log-entry.success {
  border-left: 4px solid var(--brand-accent);
}

.log-entry.warn {
  border-left: 4px solid var(--brand-warning);
}

.log-entry.error {
  border-left: 4px solid var(--brand-danger);
}

.log-entry.fees {
  border-left: 4px solid #c084fc;
}

.log-entry--powershell.info,
.log-entry--powershell.success,
.log-entry--powershell.warn,
.log-entry--powershell.error,
.log-entry--powershell.fees {
  border-left: 0;
}

@keyframes scrollTextTicker {
  from {
    transform: translate3d(0, 0, 0);
  }
  to {
    transform: translate3d(calc(-1 * var(--scroll-text-distance, 0px)), 0, 0);
  }
}

.log-headline {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: baseline;
  font-family: var(--brand-font-mono);
}

.timestamp {
  color: var(--brand-accent-soft);
  font-size: calc(0.8125rem * var(--brand-text-scale-secondary));
  letter-spacing: 0.08em;
}

.level-tag {
  font-size: calc(0.75rem * var(--brand-text-scale-secondary));
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--shell-text-secondary);
}

.message {
  font-size: calc(clamp(0.9375rem, 2.4vw, 1.125rem) * var(--brand-text-scale-secondary));
  line-height: 1.6;
  color: var(--brand-text-primary);
  font-family: var(--brand-font-secondary);
}

.log-terminal-line {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.35rem;
  font-family: var(--brand-font-primary, var(--brand-font-secondary)), "Cascadia Mono", "Consolas",
    "Lucida Console", Monaco, monospace;
  font-size: 1em;
  line-height: 1.45;
  color: var(--brand-text-primary, #f3f3f3);
  white-space: pre-wrap;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.log-terminal-user {
  color: var(--brand-accent-soft, #22c55e);
  font-weight: 700;
}

.log-terminal-path {
  color: var(--brand-accent, #22c55e);
  font-weight: 700;
}

.log-terminal-command {
  color: var(--brand-text-primary, #e5e7eb);
}

.log-terminal-output {
  font-family: var(--brand-font-primary, var(--brand-font-secondary)), "Cascadia Mono", "Consolas",
    "Lucida Console", Monaco, monospace;
  font-size: 0.94em;
  line-height: 1.35;
  color: var(--brand-text-secondary, #d4d4d8);
  padding-left: 0.2rem;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.log-entry--powershell .log-headline {
  gap: 8px;
  font-family: var(--brand-font-primary, var(--brand-font-secondary)), "Cascadia Mono", "Consolas",
    "Lucida Console", Monaco, monospace;
}

.log-entry--powershell .timestamp {
  color: var(--brand-text-muted, #9ca3af);
  font-size: 0.85em;
  letter-spacing: 0.04em;
}

.log-entry--powershell .level-tag {
  color: var(--brand-warning, #fbbf24);
  font-size: 0.84em;
  letter-spacing: 0.08em;
}

.log-detail {
  font-family: var(--brand-font-secondary);
  font-size: calc(0.85rem * var(--brand-text-scale-secondary));
  color: var(--brand-text-muted);
  line-height: 1.5;
}

.burnair-log-entry {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.8rem;
  align-items: start;
}

.burnair-log-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 110px;
  padding: 0.36rem 0.7rem;
  border-radius: 999px;
  border: 1px solid var(--brand-border);
  font-family: var(--brand-font-heading);
  font-size: calc(clamp(0.9rem, 1.5vw, 1.05rem) * var(--brand-text-scale-primary));
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1;
  text-transform: uppercase;
  white-space: nowrap;
}

.burnair-log-pill--airdrop {
  color: var(--brand-text-primary);
  border-color: color-mix(in srgb, var(--brand-text-primary) 45%, var(--brand-border));
  background: color-mix(in srgb, var(--brand-text-primary) 14%, transparent);
}

.burnair-log-pill--burn {
  color: var(--brand-text-secondary);
  border-color: color-mix(in srgb, var(--brand-text-secondary) 55%, var(--brand-border));
  background: color-mix(in srgb, var(--brand-text-secondary) 20%, transparent);
}

.burnair-log-main {
  min-width: 0;
  display: grid;
  gap: 0.28rem;
}

.burnair-log-line {
  font-family: var(--brand-font-secondary);
  font-size: calc(clamp(0.95rem, 1.8vw, 1.1rem) * var(--brand-text-scale-secondary));
  line-height: 1.45;
  color: var(--brand-text-primary);
  overflow-wrap: anywhere;
}

.burnair-log-timestamp {
  color: var(--brand-accent-soft);
  font-size: calc(0.82rem * var(--brand-text-scale-secondary));
  letter-spacing: 0.08em;
  margin-right: 0.4rem;
  white-space: nowrap;
}

.vote-log-entry {
  background: var(--brand-surface-alt);
  border-radius: 14px;
  border: 1px solid var(--brand-border);
  padding: clamp(10px, 2vw, 16px);
  display: flex;
  flex-direction: column;
  gap: 6px;
  box-shadow: 0 18px 32px rgba(0, 0, 0, 0.4);
}

.vote-log-headline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  font-size: calc(0.78rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-secondary);
}

.vote-log-name {
  font-weight: 600;
  color: var(--brand-text-primary);
}

.vote-log-timestamp {
  font-size: calc(0.72rem * var(--brand-text-scale-secondary));
  color: var(--brand-text-muted);
  font-family: var(--brand-font-mono);
}

.vote-log-body {
  font-size: calc(0.9rem * var(--brand-text-scale-secondary));
  color: var(--shell-text-secondary);
}

.vote-log-wallet {
  font-family: var(--brand-font-mono);
  font-size: calc(0.72rem * var(--brand-text-scale-secondary));
  color: var(--brand-accent-soft);
  letter-spacing: 0.1em;
}

.meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.meta span {
  border: 1px solid var(--brand-border);
  border-radius: 999px;
  padding: 6px 12px;
  font-size: 0.75rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--shell-text-secondary);
  background: color-mix(in srgb, var(--brand-surface-alt) 90%, transparent);
  font-family: var(--brand-font-mono);
}


/* @media (max-width: 720px) {
  .donations-table {
    min-width: 0;
  }

  .donations-table thead {
    display: none;
  }

  .donations-table tbody tr {
    display: grid;
    grid-template-columns: 1fr;
    gap: 6px;
    padding: 12px 0;
  }

  .donations-table tbody tr:not(:last-of-type) {
    border-bottom: 1px solid var(--brand-border);
  }

  .donations-table td {
    border: none;
    padding: 6px 0;
  }

  .donations-table td::before {
    content: attr(data-label) ": ";
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--brand-text-muted);
    margin-right: 6px;
  }

  .primary-nav-wrap {
    align-items: center;
    gap: 6px;
    flex-wrap: nowrap;
    flex: 0 0 auto;
    margin-left: auto;
    justify-content: flex-start;
  }

  .primary-nav {
    gap: 8px;
    flex: 1 1 auto;
    min-width: 0;
    flex-wrap: nowrap;
  }

  .nav-link,
  .nav-cta {
    letter-spacing: 0.08em;
    white-space: nowrap;
  }

  .nav-cta {
    width: auto;
    justify-content: center;
    padding: 8px 16px;
  }

  .global-footer-content {
    max-width: 100%;
  }
}

@media (max-width: 1100px) {
  .header-grid {
    --header-grid-template: 1fr;
    gap: 12px;
  }

  .header-card {
    width: 100%;
  }

  .header-card-support--expanded {
    display: grid;
    grid-template-columns: 1fr;
  }

  .header-card-support--expanded > :not(:first-child) {
    border-left: 0;
    padding-left: 0;
    border-top: 1px solid var(--brand-border);
    padding-top: 12px;
  }

  .header-card-support--expanded > :first-child {
    padding-right: 0;
  }

  .support-primary {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }

  .support-meta {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }

  .support-meta-grid {
    grid-template-columns: 1fr;
  }

  .support-meta-grid > :first-child {
    padding-right: 0;
  }

  .support-meta-grid > :not(:first-child) {
    border-left: 0;
    padding-left: 0;
    border-top: 1px solid var(--brand-border);
    padding-top: 12px;
  }

  .how-it-works {
    flex-direction: column;
  }

  .global-footer-art {
    flex: 1 1 100%;
    max-width: 100%;
    padding: 6px;
  }

  .about-link {
    width: auto;
    justify-content: center;
  }

  .section-heading p {
    max-width: 100%;
  }

  .primary-nav {
    width: auto;
    justify-content: flex-end;
    gap: 8px;
    flex: 0 0 auto;
    min-width: 0;
    flex-wrap: nowrap;
  }

  .primary-nav-wrap {
    align-items: center;
    gap: 6px;
    flex-wrap: nowrap;
    width: 100%;
  }

  .nav-cta {
    flex: 0 0 auto;
  }
} */





body::-webkit-scrollbar { width: 0; height: 0; }

.admin-page {
  margin: 0;
  min-height: 100vh;
  background: var(--brand-background);
  color: var(--brand-text-primary);
  display: flex;
  justify-content: center;
  align-items: stretch;
  padding: clamp(24px, 5vw, 40px);
  font-family: var(--brand-font-secondary);
}

.admin-login-wrapper,
.admin-loading {
  width: min(420px, 100%);
  margin: auto;
  display: flex;
  justify-content: center;
  align-items: center;
}

.admin-loading {
  font-size: 1rem;
  color: var(--shell-text-secondary);
  opacity: 0.8;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.admin-shell {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: clamp(18px, 2vw, 24px);
}

.admin-shell__header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  background: var(--brand-surface);
  border: 1px solid var(--brand-border);
  border-radius: 18px;
  padding: clamp(14px, 2vw, 20px);
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.45);
}

.admin-shell__brand {
  display: flex;
  align-items: center;
  gap: 14px;
  font-weight: 600;
  font-size: clamp(1.1rem, 2vw, 1.4rem);
}

.admin-shell__brand-copy {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.admin-shell__brand-subtitle {
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--brand-text-muted);
  margin: 0;
}

body.projects {
  display: block;
}

.project-console-shell {
  width: 100%;
  max-width: 100%;
  margin: 0;
  /* background: var(--shell-background); */
  background: #060910;
  /* border: 1px solid var(--shell-border); */
  border: 1px solid #1e2436;;
  border-radius: 0;
  box-shadow: 0 30px 70px rgba(0, 0, 0, 0.6);
  color: var(--shell-text-primary);
  display: flex;
  flex-direction: column;
  gap: 18px;
  min-height: 100vh;
  height: 100vh;
}

.project-console-shell.projects-hub-shell {
  gap: 12px;
}

.project-console-shell__content {
  overflow: hidden;
  box-shadow: 0 25px 60px rgba(0, 0, 0, 0.5);
  min-width: 0;
  min-height: 0;
  height: 100%;
}

.project-console-shell.live-public {
  border: none;
  box-shadow: none;
  background: transparent;
  padding: 0;
}

.project-console-shell.live-public .project-console-shell__content {
  box-shadow: none;
  overflow: visible;
}

.project-console__body {
  display: grid;
  grid-template-columns: 380px minmax(0, 1fr);
  align-items: stretch;
  flex: 1;
  min-height: 0;
}

.projects-hub-shell {
  max-width: 100%;
  width: 100%;
  margin: 0 auto;
}

.projects-hub {
  width: 100%;
  background: var(--shell-background);
  border: 1px solid var(--shell-border);
  border-radius: 12px;
  padding: 16px;
  box-shadow: 0 30px 70px rgba(0, 0, 0, 0.6);
  color: var(--shell-text-primary);
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.projects-hub__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.projects-hub__header h2 {
  margin: 0;
  font-size: 1.7rem;
  line-height: 1.15;
}

.projects-hub__actions {
  display: flex;
  gap: 8px;
}

.projects-hub__templates {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px;
}

.projects-hub__template-tile {
  width: 100%;
  border: 1px dashed var(--shell-border-strong);
  background: color-mix(in srgb, var(--shell-surface) 72%, var(--shell-border) 28%);
  border-radius: 12px;
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  text-align: left;
  cursor: pointer;
  color: inherit;
  font: inherit;
  appearance: none;
}

.projects-hub__template-tile:hover:not(:disabled) {
  border-color: var(--shell-border);
  background: color-mix(in srgb, var(--shell-surface) 82%, var(--shell-border) 18%);
}

.projects-hub__template-tile:focus-visible {
  outline: 2px solid var(--shell-accent);
  outline-offset: 3px;
}

.projects-hub__template-tile.is-active {
  border-style: solid;
  border-color: color-mix(in srgb, var(--shell-accent) 60%, var(--shell-border-strong));
  background: color-mix(in srgb, var(--shell-surface) 80%, var(--shell-accent) 20%);
}

.projects-hub__template-new {
  border-style: solid;
  border-color: color-mix(in srgb, var(--shell-accent) 35%, var(--shell-border-strong));
}

.projects-hub__template-title h3 {
  margin: 0;
  font-size: 1.02rem;
}

.projects-hub__template-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.projects-hub__template-hint {
  margin: 0;
  color: var(--shell-text-muted);
  font-size: 0.78rem;
}

.projects-hub__create-backdrop {
  background: color-mix(in srgb, #020617 78%, transparent);
  backdrop-filter: blur(10px);
}

.projects-hub__create-modal {
  width: min(680px, 92vw);
  border-radius: 18px;
  border: 1px solid color-mix(in srgb, var(--shell-border-strong) 75%, transparent);
  background:
    radial-gradient(140% 120% at 0% 0%, rgba(56, 189, 248, 0.12) 0%, transparent 55%),
    radial-gradient(120% 120% at 100% 0%, rgba(14, 165, 233, 0.1) 0%, transparent 50%),
    var(--shell-surface);
  box-shadow:
    0 30px 90px rgba(2, 6, 23, 0.6),
    0 8px 20px rgba(2, 6, 23, 0.45);
  padding: 24px;
}

.projects-hub__create-modal .admin-modal__header {
  position: relative;
  align-items: flex-start;
  gap: 16px;
  padding-right: 48px;
  padding-bottom: 12px;
  border-bottom: 1px solid color-mix(in srgb, var(--shell-border) 60%, transparent);
  margin-bottom: 4px;
}

.projects-hub__create-modal .admin-modal__eyebrow {
  letter-spacing: 0.32em;
  text-transform: uppercase;
  font-size: 0.65rem;
  color: color-mix(in srgb, var(--shell-text-muted) 80%, white);
}

.projects-hub__create-modal h3 {
  font-size: 1.3rem;
  margin: 0;
}

.projects-hub__create-modal p {
  margin: 0;
}

.projects-hub__create-modal .projects-hub__create-meta {
  margin-top: 6px;
  gap: 8px;
}

.projects-hub__create-modal .projects-hub__form {
  margin-top: 16px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 14px;
  padding: 16px;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--shell-border) 65%, transparent);
  background: color-mix(in srgb, var(--shell-surface-alt) 70%, transparent);
}

.projects-hub__create-modal .projects-hub__form label {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.projects-hub__create-modal .projects-hub__form label span {
  font-size: 0.88rem;
  color: var(--shell-text-muted);
}

.projects-hub__create-modal .projects-hub__form input {
  background: color-mix(in srgb, var(--shell-surface) 75%, #020617 25%);
  border: 1px solid color-mix(in srgb, var(--shell-border) 70%, transparent);
  border-radius: 12px;
  padding: 10px 12px;
  transition: border-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.projects-hub__create-modal .projects-hub__form input:focus {
  outline: none;
  border-color: color-mix(in srgb, var(--shell-accent) 75%, white);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--shell-accent) 30%, transparent);
  transform: translateY(-1px);
}

.projects-hub__create-modal .projects-hub__formactions {
  grid-column: 1 / -1;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 10px;
  margin-top: 6px;
}

.projects-hub__create-modal .projects-hub__formactions button {
  padding: 9px 18px;
  border-radius: 999px;
  letter-spacing: 0.04em;
}

.projects-hub__create-modal .projects-hub__formactions button[type="submit"] {
  border-color: transparent;
  background: linear-gradient(135deg, color-mix(in srgb, var(--shell-accent) 70%, #38bdf8), #0ea5e9);
  color: #0b1220;
  font-weight: 700;
}

.projects-hub__create-modal .projects-hub__formactions button[type="submit"]:hover {
  filter: brightness(1.05);
}

.projects-hub__create-modal .admin-modal__header .link {
  color: var(--shell-text-muted);
}

.projects-hub__create-modal .admin-modal__close {
  border: 1px solid color-mix(in srgb, var(--shell-border) 70%, transparent);
  background: color-mix(in srgb, var(--shell-surface) 75%, transparent);
  color: var(--shell-text-muted);
  border-radius: 999px;
  width: 34px;
  height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 0;
  right: 0;
  cursor: pointer;
  transition: border-color 160ms ease, color 160ms ease, transform 160ms ease, background 160ms ease;
}

.projects-hub__create-modal .admin-modal__close svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
}

.projects-hub__create-modal .admin-modal__close:hover {
  color: var(--shell-text-primary);
  border-color: color-mix(in srgb, var(--shell-accent) 60%, var(--shell-border));
  background: color-mix(in srgb, var(--shell-accent) 18%, transparent);
  transform: translateY(-1px);
}

.projects-hub__list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 12px;
  align-items: stretch;
}

.projects-hub__card {
  width: 100%;
  border: 1px solid var(--shell-border-strong);
  background: var(--shell-surface);
  border-radius: 12px;
  padding: 12px 14px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.projects-hub__card--project {
  flex-direction: column;
  align-items: stretch;
  min-height: 280px;
}

.projects-hub__card--project .projects-hub__buttons {
  justify-content: flex-start;
  margin-top: auto;
}

.projects-hub__card--new {
  border-style: dashed;
  background: color-mix(in srgb, var(--shell-surface) 70%, var(--shell-border) 30%);
  cursor: pointer;
}

.projects-hub__card--new:focus-visible {
  outline: 2px solid var(--shell-accent);
  outline-offset: 3px;
}

.projects-hub__card--loading,
.projects-hub__empty {
  justify-content: flex-start;
  color: var(--shell-text-muted);
}

.projects-hub__info {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}

.projects-hub__title {
  display: flex;
  align-items: center;
  gap: 10px;
}

.projects-hub__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  color: var(--shell-text-muted);
}

.projects-hub__pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 3px 9px;
  border-radius: 999px;
  border: 1px solid var(--shell-border);
  background: var(--shell-surface-alt);
  font-size: 0.76rem;
}

.projects-hub__pill--component {
  border-color: color-mix(in srgb, var(--brand-accent) 45%, var(--shell-border));
  color: color-mix(in srgb, var(--brand-accent) 80%, var(--shell-text-primary));
  background: color-mix(in srgb, var(--brand-accent) 12%, var(--shell-surface-alt) 88%);
}

.projects-hub__pill--muted {
  color: var(--shell-text-muted);
}

.projects-hub__pill--running {
  border-color: color-mix(in srgb, var(--brand-accent) 55%, var(--shell-border));
  color: var(--brand-accent);
  background: color-mix(in srgb, var(--brand-accent) 18%, var(--shell-surface-alt) 82%);
}

.projects-hub__pill--paused {
  border-color: color-mix(in srgb, var(--brand-warning) 55%, var(--shell-border));
  color: var(--brand-warning);
  background: color-mix(in srgb, var(--brand-warning) 18%, var(--shell-surface-alt) 82%);
}

.projects-hub__pill--stopped {
  border-color: color-mix(in srgb, var(--brand-danger) 55%, var(--shell-border));
  color: var(--brand-danger);
  background: color-mix(in srgb, var(--brand-danger) 18%, var(--shell-surface-alt) 82%);
}

.projects-hub__buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  justify-content: flex-end;
}

.projects-hub__cycle-start {
  border-color: color-mix(in srgb, var(--brand-accent) 55%, var(--shell-border));
  color: var(--brand-accent);
}

.projects-hub__cycle-start:hover {
  background: color-mix(in srgb, var(--brand-accent) 12%, transparent);
}

.projects-hub__cycle-stop {
  border-color: color-mix(in srgb, var(--brand-danger) 55%, var(--shell-border));
  color: var(--brand-danger);
}

.projects-hub__cycle-stop:hover {
  background: color-mix(in srgb, var(--brand-danger) 12%, transparent);
}

.projects-hub__hint {
  margin: 6px 0 0;
  color: var(--shell-text-muted);
}

.projects-hub__create-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

.projects-hub__create-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.projects-hub__form {
  display: grid;
  gap: 8px;
  margin-top: 8px;
}

.projects-hub__form label {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.projects-hub__form input {
  background: var(--shell-surface);
  border: 1px solid var(--shell-border);
  border-radius: 10px;
  padding: 9px 10px;
  color: var(--shell-text-primary);
}

.projects-hub__formactions {
  display: flex;
  gap: 8px;
  align-items: center;
}

.projects-hub__danger {
  color: var(--brand-danger);
  border-color: var(--brand-danger);
}

.projects-hub__danger:hover {
  color: var(--brand-danger);
  border-color: var(--brand-danger);
  background: color-mix(in srgb, var(--brand-danger) 10%, transparent);
}

.projects-hub__cardbody {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.project-console {
  display: flex;
  flex-direction: column;
  gap: 16px;
  width: 100%;
  flex: 1;
  min-height: 0;
}

.project-console-main {
  display: block;
}

.project-console__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 0;
  margin: 0 25px;
}

.project-console__headercontrols {
  display: grid;
  grid-auto-flow: column;
  align-items: center;
  gap: 12px;
}

.project-console__headercluster {
  display: flex;
  align-items: center;
  gap: 10px;
}

.project-console__headerselect select {
  min-width: 180px;
}

.project-console__eyebrow {
  margin: 0;
  font-family: var(--brand-font-heading);
  font-size: calc(0.75rem * var(--brand-text-scale-primary));
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--shell-text-muted);
}

.project-console__name {
  font-family: var(--brand-font-heading);
  font-size: calc(1.375rem * var(--brand-text-scale-primary));
}

.project-console__badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 0.75rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: color-mix(in srgb, var(--shell-accent) 30%, transparent);
  color: var(--shell-text-primary);
  margin-left: 6px;
}

.project-console__actions {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-left: auto;
  flex-wrap: nowrap;
  justify-content: flex-end;
}

.project-console__layout-indicator {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  border-radius: 999px;
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  background: color-mix(in srgb, var(--shell-accent) 30%, transparent);
  border: 1px solid color-mix(in srgb, var(--shell-accent) 55%, transparent);
  color: var(--shell-text-primary);
}

.charity-info {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 12px;
}

.charity-info__logo {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  background: color-mix(in srgb, var(--shell-surface-alt) 80%, var(--shell-background) 20%);
  border: 1px solid var(--shell-border);
  display: grid;
  place-items: center;
  overflow: hidden;
}

.charity-info__logo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.charity-info__placeholder {
  font-weight: 700;
  color: var(--shell-text-secondary);
  font-size: 1rem;
}

.charity-info__meta {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.charity-info__name {
  font-size: 1rem;
  color: var(--shell-text-primary);
}

.charity-info__address {
  font-size: 0.85rem;
  color: var(--shell-text-secondary);
}

.charity-info__vote {
  font-size: 0.85rem;
  color: var(--shell-text-muted);
}

.charity-edit {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.charity-edit__fields {
  display: grid;
  gap: 12px;
}

.charity-edit__fields input {
  width: 100%;
  word-break: break-all;
}

.charity-edit__preview {
  width: 84px;
  height: 84px;
  border-radius: 16px;
  background: color-mix(in srgb, var(--shell-surface-alt) 80%, var(--shell-background) 20%);
  border: 1px solid var(--shell-border);
  display: grid;
  place-items: center;
  overflow: hidden;
}

.charity-edit__preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.project-console__actions select {
  border-radius: 10px;
  border: 1px solid var(--shell-border-strong);
  background: var(--shell-surface-alt);
  color: var(--shell-text-primary);
  padding: 8px 12px;
}

.project-console__account {
  border-color: var(--shell-border-strong);
  color: var(--shell-text-primary);
}

.project-console__account:hover {
  border-color: var(--shell-accent);
  color: var(--shell-accent);
}

.project-console__logout {
  border-color: var(--shell-border-strong);
  color: var(--shell-text-primary);
}

.project-console__logout:hover {
  border-color: var(--brand-danger);
  color: var(--brand-danger);
}

.project-console__stream-key {
  min-width: 180px;
  padding: 8px 12px;
  border-radius: 10px;
  border: 1px solid var(--shell-border-strong);
  background: var(--shell-surface-alt);
  color: var(--shell-text-primary);
}

.project-console__stream-key:disabled {
  opacity: 0.75;
}

.project-console__stream-toggle {
  min-width: 96px;
}

.project-console__livestream-banner {
  margin-top: 8px;
}

.project-livestream-row {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

.project-livestream-row input {
  flex: 1 1 260px;
}

.project-livestream-status {
  font-size: 0.9rem;
  color: var(--shell-text-primary);
  margin-bottom: 12px;
}

.project-moderation {
  display: flex;
  flex-direction: column;
  gap: 8px;
  height: 100%;
  min-height: 0;
  justify-content: flex-start;
  padding: 8px;
  font-family: var(--brand-font-primary);
  font-size: calc(0.9rem * var(--brand-text-scale-primary));
  color: var(--brand-text-primary);
}

.project-moderation.header-card {
  min-height: 0;
  padding: 8px;
  justify-content: flex-start;
  gap: 8px;
}

.project-moderation-status {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--brand-border);
  border-radius: 12px;
  background: var(--brand-surface-alt);
}

.project-moderation-status[data-state="connected"] {
  border-color: var(--brand-accent);
}

.project-moderation-status[data-state="error"] {
  border-color: #ff6b6b;
}

.project-moderation-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.project-moderation-messages {
  border: 1px solid var(--brand-border);
  border-radius: 12px;
  background: var(--component-background, var(--brand-surface));
  padding: 6px;
  flex: 1 1 auto;
  min-height: 0;
  overflow: auto;
  display: flex;
  flex-direction: column;
  gap: 4px;
  align-items: stretch;
  justify-content: flex-start;
  font-family: var(--brand-font-secondary);
  font-size: calc(0.9rem * var(--brand-text-scale-secondary));
}

.project-moderation-message {
  border: 1px solid var(--brand-border);
  border-radius: 6px;
  padding: 4px 6px;
  background: var(--brand-surface-alt);
  color: var(--brand-text-primary);
}

.project-moderation-message.is-flagged {
  border-color: #ff6b6b;
}

.project-moderation-message__head {
  display: flex;
  gap: 6px;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: nowrap;
  font-family: var(--brand-font-secondary);
  font-size: calc(0.76rem * var(--brand-text-scale-secondary));
  line-height: 1.2;
  color: var(--brand-text-muted);
}

.project-moderation-message__head strong {
  font-family: var(--brand-font-primary);
  font-size: calc(0.84rem * var(--brand-text-scale-primary));
  color: var(--brand-text-primary);
  font-weight: 600;
  max-width: 40%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.project-moderation-message__wallet {
  font-family: var(--brand-font-primary);
  font-size: calc(0.8rem * var(--brand-text-scale-primary));
  color: var(--brand-text-primary);
  max-width: 45%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.project-moderation-message__head time {
  margin-left: auto;
  white-space: nowrap;
  font-size: calc(0.72rem * var(--brand-text-scale-secondary));
  color: var(--brand-text-muted);
}

.project-moderation-message__body {
  margin-top: 2px;
  font-family: var(--brand-font-secondary);
  font-size: calc(0.92rem * var(--brand-text-scale-secondary));
  line-height: 1.25;
  white-space: pre-wrap;
  word-break: break-word;
  color: var(--brand-text-primary);
}

.project-moderation-message__actions {
  display: flex;
  gap: 8px;
  margin-top: 8px;
  flex-wrap: wrap;
}

.project-moderation-send {
  display: grid;
  gap: 8px;
}

.project-moderation-send textarea {
  min-height: 72px;
}

.project-moderation-log ul {
  list-style: none;
  padding: 0;
  margin: 8px 0 0;
  display: grid;
  gap: 8px;
}

.project-moderation-log li {
  border: 1px solid var(--shell-border);
  border-radius: 10px;
  padding: 8px;
  background: var(--shell-surface);
}

.project-moderation-log pre {
  background: var(--shell-surface-alt);
  border-radius: 8px;
  padding: 8px;
  overflow: auto;
}

.project-moderation-empty {
  color: var(--brand-text-muted);
  font-family: var(--brand-font-secondary);
  font-size: calc(0.82rem * var(--brand-text-scale-secondary));
}

.project-console__error {
  border: 1px solid var(--shell-border-strong);
  border-radius: 12px;
  padding: 10px 12px;
  background: color-mix(in srgb, var(--shell-border) 60%, transparent);
  color: var(--shell-text-primary);
  font-size: 0.85rem;
}

.project-console__notice {
  border: 1px solid var(--shell-border);
  border-radius: 12px;
  padding: 10px 12px;
  background: color-mix(in srgb, var(--shell-accent) 12%, transparent);
  color: var(--shell-text-primary);
  font-size: 0.85rem;
}

.project-console__empty {
  border: 1px dashed var(--shell-border);
  border-radius: 12px;
  padding: 12px;
  color: var(--shell-text-muted);
  font-size: 0.9rem;
}

.project-console__tabs {
  display: inline-flex;
  gap: 8px;
  border: 1px solid var(--shell-border);
  border-radius: 12px;
  padding: 6px;
  margin-bottom: 12px;
  background: var(--shell-surface);
}

.project-console__tab {
  position: relative;
  border: none;
  border-radius: 10px;
  padding: 8px 16px;
  background: transparent;
  color: var(--shell-text-secondary);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.2s ease, color 0.2s ease;
}

input[disabled],
select[disabled],
textarea[disabled] {
  background: color-mix(in srgb, var(--shell-surface) 50%, var(--shell-background) 50%);
  color: var(--shell-text-muted);
  cursor: not-allowed;
  border-color: var(--shell-border-strong);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--shell-border-strong) 60%, transparent);
  opacity: 0.65;
}

.project-console__tab::after {
  content: attr(data-label);
  position: absolute;
  left: 50%;
  top: calc(100% + 10px);
  transform: translate(-50%, -4px);
  background: color-mix(in srgb, var(--shell-surface-alt) 90%, var(--shell-background) 10%);
  color: var(--shell-text-primary);
  padding: 6px 10px;
  border-radius: 10px;
  border: 1px solid var(--shell-border);
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.32);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.15s ease, transform 0.15s ease;
  z-index: 5;
}

.project-console__tab:hover::after,
.project-console__tab:focus-visible::after {
  opacity: 1;
  transform: translate(-50%, 0);
}

.project-console__tab.is-active {
  background: color-mix(in srgb, var(--shell-accent) 25%, transparent);
  color: var(--shell-accent);
}

.project-console__tabs--vertical {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  align-items: stretch;
  position: sticky;
  top: 16px;
  width: 100%;
  height: 100%;
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-gutter: stable;
  padding: 16px 18px;
  background: transparent;
  border: none;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.45);
  border-radius: 0;
}

.project-console__tabcard {
  border: 1px solid var(--shell-border);
  border-radius: 12px;
  padding: 10px 12px;
  margin-bottom: 10px;
  background: color-mix(in srgb, var(--shell-surface-alt) 90%, var(--shell-background) 10%);
  display: grid;
  gap: 8px;
  width: 100%;
}

.project-console__tabstack {
  display: flex;
  gap: 8px;
  flex-wrap: nowrap;
}

.project-console__tabs--vertical .project-console__tab {
  text-align: center;
  width: auto;
}

.project-console__panelstack {
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-height: 0;
  overflow: visible;
}

.project-console__header {
  position: relative;
}

.project-console__header .project-console__actions {
  position: absolute;
  top: 16px;
  right: 0;
}

.project-console__select {
  width: 100%;
  border-radius: 10px;
  border: 1px solid var(--shell-border-strong);
  background: color-mix(in srgb, var(--shell-surface-alt) 90%, var(--shell-background) 10%);
  color: var(--shell-text-primary);
  padding: 10px 12px;
  box-sizing: border-box;
}

.project-console__sideactions {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

.project-console__sidecontent {
  margin-top: 12px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  width: 100%;
  max-height: calc(100vh - 140px);
  padding-right: 4px;
}

.project-console-shell.is-livestream .project-console__header,
.project-console-shell.is-livestream .project-console__tabs--vertical {
  display: none;
}

.project-console-shell.is-livestream .project-console__body {
  grid-template-columns: 1fr;
}

.project-console-shell.is-livestream {
  border: none;
  box-shadow: none;
  background: transparent;
}

.project-console-shell.is-livestream .project-console-shell__content {
  box-shadow: none;
  overflow: visible;
}

.project-console-shell.is-livestream .project-grid {
  width: var(--livestream-grid-base-width, 100%);
  transform: scale(var(--livestream-grid-scale, 1));
  transform-origin: top left;
}

@media (max-width: 960px) {
  .project-console__body {
    grid-template-columns: 1fr;
    flex: initial;
    min-height: 0;
  }
  .project-console__tabs--vertical {
    position: relative;
    top: auto;
    max-width: 100%;
    max-height: none;
    height: auto;
    grid-template-rows: auto;
    padding: 12px;
    margin: 0 0 16px;
  }
  .project-console__panelstack {
    overflow: visible;
  }
}

.project-coin-card {
  border: 1px solid var(--shell-border);
  border-radius: 16px;
  padding: 16px;
  background: var(--shell-surface-alt);
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 16px;
}

.project-name-card h3 {
  font-size: 1.1rem;
}

.project-coin-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.project-coin-card__header > div:first-child {
  flex: 1 1 auto;
}

.project-coin-card__actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.project-coin-grid {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.project-coin-eyebrow {
  margin: 0;
  font-family: var(--brand-font-primary);
  font-size: calc(0.75rem * var(--brand-text-scale-primary));
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--brand-text-muted);
}

.project-coin-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 0.9rem;
}

.project-coin-field > div {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.project-coin-field > div code {
  flex: 1 1 220px;
  min-width: min(220px, 100%);
}

.project-coin-feature-toggles {
  gap: 8px;
}

.project-coin-toggle-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 8px;
}

.toggle-row {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: none;
}

.project-coin-field span {
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brand-text-muted);
}

.project-coin-field code,
.project-coin-field strong {
  font-family: var(--brand-font-mono);
  color: var(--brand-text-primary);
  word-break: break-all;
}

.sniper-wallet-list,
.sniper-results {
  list-style: none;
  padding: 0;
  margin: 8px 0 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.sniper-wallet,
.sniper-result {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border: 1px solid var(--shell-border);
  border-radius: 12px;
  background: color-mix(in srgb, var(--shell-surface) 85%, var(--shell-background) 15%);
}

.sniper-wallet__actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

.sniper-result.is-success {
  border-color: color-mix(in srgb, var(--shell-accent) 60%, var(--shell-border) 40%);
}

.sniper-result.is-failure {
  border-color: color-mix(in srgb, #f87171 80%, var(--shell-border) 20%);
}

.sniper-result__meta {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 0.9rem;
  color: var(--shell-text-muted);
}

.sniper-result__meta strong {
  color: var(--shell-text-primary);
}

.sniper-result__status {
  font-weight: 700;
  color: var(--shell-text-primary);
}

.wallets-shell {
  padding: 24px;
  max-width: 1600px;
  margin: 0 auto;
  width: 100%;
}

.wallets-shell--full {
  max-width: none;
  margin: 0;
  padding: clamp(14px, 2vw, 28px);
}

.wallets-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 380px;
  gap: 18px;
  align-items: start;
}

.wallets-layout--single {
  grid-template-columns: minmax(0, 1fr);
}

.wallets-main,
.wallets-sidebar {
  min-width: 0;
}

.wallets-sidebar__sticky {
  position: sticky;
  top: 18px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding-top: 14px;
}

@media (max-width: 1100px) {
  .wallets-layout {
    grid-template-columns: 1fr;
  }

  .wallets-sidebar__sticky {
    position: static;
    padding-top: 0;
  }
}

.wallets-header {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 10px;
  position: sticky;
  top: 0;
  z-index: 20;
  padding: 14px 0 10px;
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--shell-background) 92%, transparent 8%) 0%,
    transparent 100%
  );
  backdrop-filter: blur(10px);
}

.wallets-eyebrow {
  text-transform: uppercase;
  letter-spacing: 0.16em;
  margin: 0;
  color: var(--brand-text-muted);
  font-family: var(--brand-font-primary);
  font-size: calc(0.8rem * var(--brand-text-scale-primary));
}

.wallets-subtitle {
  margin: 4px 0 0;
  color: var(--shell-text-muted);
}

.wallets-header__right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 10px;
}

.wallets-metrics {
  border: 1px solid color-mix(in srgb, var(--shell-border) 80%, transparent 20%);
  border-radius: 16px;
  padding: 10px 12px;
  background: color-mix(in srgb, var(--shell-surface) 70%, transparent 30%);
  text-align: right;
  min-width: 220px;
}

.wallets-metrics--sidebar {
  width: 100%;
  min-width: 0;
  text-align: left;
  border-radius: 18px;
  padding: 14px 14px;
}

.wallets-metrics--sidebar .wallets-metrics__value {
  font-size: 2.1rem;
}

.wallets-metrics__meta {
  margin-top: 6px;
  color: var(--shell-text-muted);
  font-size: 0.82rem;
}

.wallets-coin-card {
  border: 1px solid color-mix(in srgb, var(--shell-border) 80%, transparent 20%);
  border-radius: 18px;
  padding: 14px;
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--shell-surface-alt) 92%, var(--shell-background) 8%) 0%,
    color-mix(in srgb, var(--shell-surface) 92%, var(--shell-background) 8%) 100%
  );
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.35);
}

.wallets-coin-card__header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}

.wallets-coin-card__marketcap {
  border: 1px solid color-mix(in srgb, var(--shell-border) 70%, transparent 30%);
  border-radius: 16px;
  padding: 12px;
  background: color-mix(in srgb, var(--shell-surface) 70%, transparent 30%);
  margin-bottom: 12px;
}

.wallets-coin-card__marketcap-label {
  font-family: var(--brand-font-primary);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 0.72rem;
  color: var(--shell-text-muted);
}

.wallets-coin-card__marketcap-value {
  margin-top: 6px;
  font-size: 2rem;
  font-weight: 900;
  letter-spacing: -0.02em;
  color: var(--shell-text-primary);
}

.wallets-coin-card__marketcap-meta {
  margin-top: 6px;
  color: var(--shell-text-muted);
  font-size: 0.82rem;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.wallets-coin-card__marketcap-sol {
  font-size: 0.76rem;
  color: var(--shell-text-muted);
}

.wallets-coin-card__marketcap-updated {
  font-size: 0.82rem;
  color: var(--shell-text-muted);
}

.wallets-coin-avatar {
  width: 58px;
  height: 58px;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--shell-border-strong) 75%, transparent 25%);
  background: color-mix(in srgb, var(--shell-surface) 70%, transparent 30%);
  flex: 0 0 auto;
}

.wallets-coin-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.wallets-coin-avatar__placeholder {
  width: 100%;
  height: 100%;
  background: radial-gradient(
      circle at 30% 30%,
      color-mix(in srgb, var(--shell-accent) 40%, transparent 60%) 0%,
      transparent 55%
    ),
    linear-gradient(
      135deg,
      color-mix(in srgb, var(--shell-border) 70%, transparent 30%),
      color-mix(in srgb, var(--shell-surface-alt) 80%, transparent 20%)
    );
}

.wallets-coin-card__name {
  font-size: 1.15rem;
  font-weight: 900;
  letter-spacing: -0.02em;
}

.wallets-coin-card__symbol {
  margin-top: 2px;
  color: var(--shell-text-muted);
  font-family: var(--brand-font-mono);
  font-size: 0.9rem;
}

.wallets-coin-card__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.wallets-coin-card__key {
  color: var(--shell-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 0.72rem;
  font-weight: 700;
}

.wallets-coin-card__copy {
  width: 36px;
  height: 34px;
  border-radius: 12px;
  border: 1px solid color-mix(in srgb, var(--shell-border) 70%, transparent 30%);
  background: color-mix(in srgb, var(--shell-surface) 65%, transparent 35%);
  color: var(--shell-text-primary);
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: transform 140ms ease, box-shadow 140ms ease, border-color 140ms ease;
}

.wallets-coin-card__copy:hover:not(:disabled) {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--shell-accent) 45%, var(--shell-border) 55%);
  box-shadow: 0 14px 26px color-mix(in srgb, var(--shell-accent) 20%, transparent 80%);
}

.wallets-coin-card__copy:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.wallets-coin-card__mint {
  margin-top: 8px;
  font-family: var(--brand-font-mono);
  color: var(--shell-text-secondary);
  word-break: break-all;
}

.wallets-coin-card__description {
  margin: 12px 0 0;
  color: var(--shell-text-secondary);
  font-size: 0.92rem;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 9;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.wallets-metrics__label {
  font-family: var(--brand-font-primary);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 0.72rem;
  color: var(--shell-text-muted);
}

.wallets-metrics__value {
  margin-top: 4px;
  font-size: 1.6rem;
  font-weight: 900;
  letter-spacing: -0.02em;
  color: var(--shell-text-primary);
}

.wallets-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  justify-content: flex-end;
  padding: 8px 10px;
  border: 1px solid color-mix(in srgb, var(--shell-border) 80%, transparent 20%);
  border-radius: 18px;
  background: color-mix(in srgb, var(--shell-surface) 60%, transparent 40%);
}

.wallets-actions button {
  border-radius: 999px;
}

.wallets-actions select {
  padding: 0.3rem 0.65rem;
  border-radius: 999px;
  border: 1px solid var(--ghost-button-border);
  background: transparent;
  color: var(--brand-text-primary);
  font-size: 0.78rem;
  cursor: pointer;
}

.wallets-actions select:hover:not(:disabled) {
  border-color: var(--ghost-button-border-hover);
  background: color-mix(in srgb, var(--ghost-button-border-hover) 18%, transparent);
}

.wallets-actions select:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.wallets-notice-slot {
  margin: 8px 0 12px;
}

.wallets-pnl {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
  margin: 8px 0 16px;
}

.wallets-pnl__card {
  border: 1px solid var(--shell-border);
  border-radius: 14px;
  padding: 14px;
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--shell-surface) 88%, var(--shell-background) 12%) 0%,
    color-mix(in srgb, var(--shell-surface-alt) 88%, var(--shell-background) 12%) 100%
  );
  display: flex;
  flex-direction: column;
  gap: 6px;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.3);
}

.wallets-pnl__card--secondary {
  background: color-mix(in srgb, var(--shell-surface-alt) 88%, var(--shell-background) 12%);
}

.wallets-pnl__label {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--shell-text-muted);
}

.wallets-pnl__value {
  font-size: 1.35rem;
  font-weight: 800;
  color: var(--shell-text-primary);
}

.wallets-pnl__value.is-positive {
  color: #22c55e;
}

.wallets-pnl__value.is-negative {
  color: #ef4444;
}

.wallets-pnl__meta {
  font-size: 0.82rem;
  color: var(--shell-text-muted);
}

.wallets-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 14px;
  justify-content: stretch;
  width: 100%;
  align-items: start;
}

.wallets-bulk {
  border: 1px solid color-mix(in srgb, var(--shell-border) 80%, transparent 20%);
  border-radius: 18px;
  padding: 12px 12px 10px;
  background: color-mix(in srgb, var(--shell-surface) 60%, transparent 40%);
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.32);
  width: min(760px, 100%);
  margin: 6px 0 10px;
}

.wallets-bulk__header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.wallets-bulk__title {
  font-weight: 900;
  letter-spacing: -0.02em;
  color: var(--shell-text-primary);
}

.wallets-bulk__hint {
  color: var(--shell-text-muted);
  font-size: 0.9rem;
}

.wallets-bulk__rows {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.wallets-bulk__row {
  display: grid;
  grid-template-columns: 46px 1fr;
  align-items: center;
  gap: 10px;
}

.wallets-bulk__label {
  font-family: var(--brand-font-primary);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 0.72rem;
  color: var(--shell-text-muted);
  font-weight: 800;
}

.wallets-bulk__buttons {
  width: 100%;
}

.wallets-warmup-panel {
  border: 1px solid color-mix(in srgb, var(--shell-border) 80%, transparent 20%);
  border-radius: 18px;
  padding: 12px;
  background: color-mix(in srgb, var(--shell-surface) 62%, transparent 38%);
  box-shadow: 0 16px 36px rgba(0, 0, 0, 0.34);
  width: min(960px, 100%);
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.wallets-warmup-panel__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.wallets-warmup-panel__title {
  font-size: 1rem;
  font-weight: 900;
  color: var(--shell-text-primary);
}

.wallets-warmup-panel__subtitle {
  font-size: 0.82rem;
  color: var(--shell-text-muted);
}

.wallets-warmup-panel__stats {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  font-size: 0.78rem;
  color: var(--shell-text-secondary);
}

.wallets-warmup-panel__stats span {
  border: 1px solid color-mix(in srgb, var(--shell-border) 72%, transparent 28%);
  border-radius: 999px;
  padding: 4px 8px;
  background: color-mix(in srgb, var(--shell-surface-alt) 86%, transparent 14%);
}

.wallets-warmup-live-mints .live-mints-list {
  max-height: 220px;
  overflow-y: auto;
}

.wallets-warmup-wallets {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 10px;
}

.wallets-warmup-wallet {
  border: 1px solid color-mix(in srgb, var(--shell-border) 76%, transparent 24%);
  border-radius: 12px;
  padding: 10px;
  background: color-mix(in srgb, var(--shell-surface-alt) 84%, transparent 16%);
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.wallets-warmup-wallet.is-buying,
.wallets-warmup-wallet.is-selling {
  border-color: color-mix(in srgb, var(--shell-accent) 60%, var(--shell-border) 40%);
}

.wallets-warmup-wallet.is-error {
  border-color: color-mix(in srgb, #ef4444 60%, var(--shell-border) 40%);
}

.wallets-warmup-wallet__name {
  font-weight: 800;
  color: var(--shell-text-primary);
  font-size: 0.88rem;
}

.wallets-warmup-wallet__message {
  color: var(--shell-text-secondary);
  font-size: 0.8rem;
  line-height: 1.35;
}

.wallets-warmup-modal {
  max-width: 680px;
}

.wallets-warmup-modal__wallets {
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-height: 230px;
  overflow-y: auto;
  border: 1px solid color-mix(in srgb, var(--shell-border) 75%, transparent 25%);
  border-radius: 10px;
  padding: 8px;
  background: color-mix(in srgb, var(--shell-surface-alt) 84%, transparent 16%);
}

.wallets-warmup-modal__wallet {
  margin: 0;
  align-items: flex-start;
}

@media (max-width: 720px) {
  .wallets-bulk__header {
    flex-direction: column;
    align-items: flex-start;
  }
  .wallets-bulk__row {
    grid-template-columns: 1fr;
  }
  .wallets-warmup-panel__header {
    flex-direction: column;
    align-items: flex-start;
  }
}

.wallets-secret {
  border: 1px solid color-mix(in srgb, var(--shell-border) 70%, #22c55e 30%);
  border-radius: 14px;
  padding: 14px;
  background: color-mix(in srgb, #22c55e 12%, var(--shell-surface) 88%);
  margin-bottom: 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.wallets-secret__title {
  font-weight: 800;
  color: var(--shell-text-primary);
}

.wallets-secret__row {
  display: grid;
  grid-template-columns: 60px 1fr auto;
  gap: 10px;
  align-items: center;
}

.wallets-secret__label {
  color: var(--shell-text-muted);
  font-weight: 700;
  font-size: 0.85rem;
}

.wallets-secret__code {
  font-family: var(--brand-font-mono);
  word-break: break-all;
  color: var(--shell-text-primary);
}

.wallets-secret__input {
  width: 100%;
  font-family: var(--brand-font-mono);
  color: var(--shell-text-primary);
}

.wallets-secret__hint {
  color: var(--shell-text-muted);
  font-size: 0.85rem;
}

.wallets-import__textarea {
  width: 100%;
  resize: vertical;
  min-height: 96px;
}

.wallet-card {
  border: 1px solid var(--shell-border);
  border-radius: 14px;
  padding: 14px;
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--shell-surface-alt) 92%, var(--shell-background) 8%) 0%,
    color-mix(in srgb, var(--shell-surface) 92%, var(--shell-background) 8%) 100%
  );
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-width: 0;
  transition: border-color 140ms ease, box-shadow 140ms ease;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.35);
}

.wallet-card:hover {
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.42);
}

.wallet-card--success {
  border-color: color-mix(in srgb, #22c55e 70%, var(--shell-border) 30%);
  box-shadow: 0 0 0 1px color-mix(in srgb, #22c55e 40%, transparent 60%);
}

.wallet-card--error {
  border-color: color-mix(in srgb, #ef4444 75%, var(--shell-border) 25%);
  box-shadow: 0 0 0 1px color-mix(in srgb, #ef4444 45%, transparent 55%);
}

@keyframes wallet-shake {
  0% { transform: translateX(0); }
  20% { transform: translateX(-6px); }
  40% { transform: translateX(6px); }
  60% { transform: translateX(-4px); }
  80% { transform: translateX(4px); }
  100% { transform: translateX(0); }
}

.wallet-card--shake {
  animation: wallet-shake 0.35s ease-in-out 0s 1;
}

.wallet-card__header {
  display: flex;
  align-items: center;
  gap: 8px;
}

.wallet-pill {
  padding: 4px 8px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--shell-accent) 20%, transparent);
  color: var(--shell-accent);
  font-weight: 700;
  font-size: 0.8rem;
}

.wallet-label {
  color: var(--shell-text-primary);
  font-weight: 700;
  flex: 1 1 auto;
  min-width: 0;
}

.wallet-label--editable {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: none;
  background: transparent;
  padding: 3px 6px;
  border-radius: 10px;
  cursor: pointer;
  text-align: left;
}

.wallet-label--editable:hover {
  background: color-mix(in srgb, var(--shell-surface) 70%, transparent 30%);
}

.wallet-label__icon {
  font-size: 0.85rem;
  color: var(--shell-text-muted);
}

.wallet-label-input {
  flex: 1 1 auto;
  min-width: 0;
  padding: 6px 8px;
  border-radius: 10px;
  border: 1px solid color-mix(in srgb, var(--shell-border) 70%, transparent 30%);
  background: color-mix(in srgb, var(--shell-surface) 86%, transparent 14%);
  font-weight: 800;
}

.wallet-card__body {
  display: flex;
  flex-direction: column;
  gap: 4px;
  color: var(--shell-text-muted);
}

.wallet-status {
  min-height: 18px;
  line-height: 18px;
  font-size: 0.85rem;
  font-weight: 800;
  visibility: hidden;
  color: var(--shell-text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.wallet-status--visible {
  visibility: visible;
}

.wallet-status--success {
  color: #22c55e;
}

.wallet-status--error {
  color: #ef4444;
}

.wallet-status--pending {
  color: var(--shell-text-muted);
}

.wallet-status--info {
  color: var(--shell-text-muted);
}

.wallet-balance {
  margin: 0;
  font-size: 1.1rem;
  color: var(--shell-text-primary);
}

.wallet-token {
  margin: 0;
}

.wallet-pnl {
  margin: 0;
  font-weight: 800;
  color: var(--shell-text-muted);
}

.wallet-pnl.is-positive {
  color: #22c55e;
}

.wallet-pnl.is-negative {
  color: #ef4444;
}

.wallet-pubkey {
  margin: 0;
  font-family: var(--brand-font-mono);
  font-size: 0.85rem;
  display: flex;
  align-items: center;
  gap: 8px;
}

.wallet-pubkey-copy {
  border: none;
  background: transparent;
  padding: 0;
  cursor: pointer;
  font-size: 0.95rem;
  line-height: 1;
  opacity: 0.85;
}

.wallet-pubkey-copy:hover {
  opacity: 1;
}

.wallet-card__trade {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.wallet-trade-row {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 6px;
}

.wallet-trade-button {
  padding: 6px 0;
  border-radius: 10px;
  font-weight: 800;
  font-size: 0.8rem;
  line-height: 1;
  border: 1px solid transparent;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

.wallet-trade-button--buy {
  background: linear-gradient(180deg, color-mix(in srgb, #22c55e 90%, #000 10%), #22c55e);
  border-color: color-mix(in srgb, #22c55e 70%, var(--shell-border) 30%);
  color: #0a0a0a;
}

.wallet-trade-button--sell {
  background: linear-gradient(180deg, color-mix(in srgb, #ef4444 90%, #000 10%), #ef4444);
  border-color: color-mix(in srgb, #ef4444 70%, var(--shell-border) 30%);
  color: #0a0a0a;
}

.wallet-trade-button--send {
  background: linear-gradient(180deg, color-mix(in srgb, #38bdf8 85%, #000 15%), #38bdf8);
  border-color: color-mix(in srgb, #38bdf8 65%, var(--shell-border) 35%);
  color: #081018;
}

.wallet-card__trade--send {
  display: flex;
  justify-content: center;
}

.wallet-card__trade--send .wallet-trade-button {
  min-width: 120px;
}

.wallet-trade-button:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.wallet-results {
  margin-top: 16px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.saved-wallets-list {
  display: grid;
  gap: 10px;
}

.saved-wallet-option {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid var(--shell-border);
  background: color-mix(in srgb, var(--shell-surface) 88%, var(--shell-background) 12%);
  text-align: left;
  font-weight: 600;
}

.saved-wallet-option:hover:not(:disabled) {
  border-color: color-mix(in srgb, var(--shell-border) 60%, #38bdf8 40%);
  box-shadow: 0 0 0 1px rgba(56, 189, 248, 0.15);
}

.saved-wallet-option__label {
  font-size: 0.95rem;
}

.saved-wallet-option__meta {
  font-size: 0.78rem;
  color: var(--shell-muted);
}

.saved-wallet-option__balance {
  font-size: 0.9rem;
  color: #d1fae5;
}

.wallet-result {
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid var(--shell-border);
  background: color-mix(in srgb, var(--shell-surface) 80%, var(--shell-background) 20%);
  display: flex;
  gap: 10px;
  align-items: center;
}

.danger-button {
  background: color-mix(in srgb, var(--shell-danger, #f87171) 85%, #ff4f6f 15%);
  color: #0a0a0a;
  border: 1px solid color-mix(in srgb, var(--shell-danger, #f87171) 70%, #ffccd5 30%);
}

.danger-button:hover {
  filter: brightness(0.95);
}

.feature-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.feature-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 10px;
}

.components-palette-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.components-palette {
  display: grid;
  gap: 14px;
}

.components-palette-header {
  color: var(--shell-text-secondary);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin: 2px 0 8px;
}

.components-palette-grid .ghost-button {
  display: block;
  width: 100%;
  min-width: 0;
  min-height: 38px;
  padding: 0.48rem 0.7rem;
  font-size: 0.75rem;
  line-height: 1.1;
  text-align: left;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

@media (max-width: 420px) {
  .components-palette-grid {
    grid-template-columns: 1fr;
  }
}

.components-on-grid-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.components-on-grid-item {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  justify-content: space-between;
  padding: 12px;
  border-radius: 16px;
  border: 1px solid var(--shell-border);
  background: color-mix(in srgb, var(--shell-surface) 72%, var(--shell-background) 28%);
  min-width: 0;
}

.components-on-grid-item.is-disabled {
  opacity: 0.75;
}

.components-on-grid-item__main {
  min-width: 0;
  flex: 1 1 auto;
}

.components-on-grid-item__title {
  color: var(--shell-text-primary);
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.2;
}

.components-on-grid-item__meta {
  margin-top: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.components-chip {
  display: inline-flex;
  align-items: center;
  padding: 2px 10px;
  border-radius: 999px;
  border: 1px solid var(--shell-border);
  background: color-mix(in srgb, var(--shell-surface-alt) 70%, transparent);
  font-size: 0.72rem;
  color: var(--shell-text-secondary);
  white-space: nowrap;
}

.components-chip.is-enabled {
  border-color: color-mix(in srgb, var(--brand-accent) 55%, var(--shell-border) 45%);
  color: var(--brand-accent);
  background: color-mix(in srgb, var(--brand-accent) 14%, transparent);
}

.components-chip.is-disabled {
  border-color: color-mix(in srgb, var(--shell-text-muted) 40%, var(--shell-border) 60%);
  color: var(--shell-text-muted);
}

.components-chip.is-muted {
  color: var(--shell-text-muted);
}

.components-on-grid-item__actions {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.components-on-grid-item__actions .ghost-button {
  padding: 0.25rem 0.55rem;
}

.feature-toggle {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
  align-items: flex-start;
  padding: 10px;
  border: 1px solid var(--shell-border);
  border-radius: 10px;
  background: color-mix(in srgb, var(--shell-surface-alt) 85%, var(--shell-background) 15%);
}

.feature-toggle input[type="checkbox"] {
  margin-top: 4px;
}

.feature-toggle strong {
  display: block;
  margin-bottom: 2px;
}

.feature-toggle p {
  margin: 0;
  color: var(--brand-text-muted);
  font-size: 0.9rem;
}

.feature-toggle__conditional {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
  color: var(--brand-text-muted);
  font-size: 0.85rem;
}

.feature-toggle__conditional select {
  background: var(--shell-surface);
  color: var(--shell-text-primary);
  border: 1px solid var(--shell-border);
  border-radius: 8px;
  padding: 4px 8px;
  font-size: 0.85rem;
}

.project-coin-split {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 12px;
}

.project-coin-split div {
  border: 1px solid var(--shell-border);
  border-radius: 12px;
  padding: 10px;
  text-align: center;
  background: var(--shell-surface);
  color: var(--shell-text-primary);
}

.project-settings-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.project-settings-form label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-weight: 600;
}

.project-settings-form input,
.project-settings-form select,
.project-settings-form textarea {
  border-radius: 10px;
  border: 1px solid var(--shell-border-strong);
  background: var(--shell-surface);
  color: var(--shell-text-primary);
  padding: 8px 12px;
}

.project-settings-form textarea {
  min-height: 80px;
  resize: vertical;
}

.project-settings-hidden {
  border: 1px dashed var(--shell-border-strong);
  border-radius: 12px;
  padding: 12px;
  background: var(--shell-surface);
  color: var(--shell-text-secondary);
  display: grid;
  gap: 8px;
}

.project-settings-row {
  border: 1px solid color-mix(in srgb, var(--shell-border) 75%, transparent);
  border-radius: 12px;
  padding: 10px;
  display: grid;
  gap: 8px;
  background: color-mix(in srgb, var(--shell-surface) 85%, var(--shell-background) 15%);
}

.inline-checkbox {
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
}

.project-settings-form label.inline-checkbox {
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid color-mix(in srgb, var(--shell-border) 70%, transparent);
  background: color-mix(in srgb, var(--shell-surface-alt) 78%, var(--shell-background) 22%);
  color: var(--shell-text-primary);
  cursor: pointer;
  transition: border-color 0.2s ease, background 0.2s ease, transform 0.2s ease;
}

.project-settings-form label.inline-checkbox:hover {
  border-color: color-mix(in srgb, var(--shell-accent) 45%, var(--shell-border) 55%);
  background: color-mix(in srgb, var(--shell-surface-alt) 68%, var(--shell-background) 32%);
}

.project-settings-form label.inline-checkbox:focus-within {
  border-color: var(--shell-accent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--shell-accent) 25%, transparent);
}

.project-settings-form label.inline-checkbox input[type="checkbox"] {
  width: 16px;
  height: 16px;
  margin: 0;
  accent-color: var(--brand-accent);
  flex: 0 0 auto;
}

.project-settings-form label.inline-checkbox span {
  flex: 1 1 auto;
  text-align: left;
}

.inline-radio {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
}

.branding-palette-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 8px;
}

.branding-color-field {
  display: grid;
  gap: 6px;
}

.color-input-row {
  display: flex;
  align-items: center;
  gap: 8px;
}

.color-input-row input[type="text"] {
  flex: 1 1 auto;
  min-width: 0;
}

.branding-color-swatch {
  width: 26px;
  height: 26px;
  border-radius: 8px;
  border: 1px solid var(--shell-border);
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.15);
  position: relative;
  overflow: hidden;
}

.branding-color-swatch input[type="color"] {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
}

.branding-color-swatch span {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 8px;
}
.branding-input-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  align-items: center;
}

.branding-input-row.has-action {
  grid-template-columns: 1fr auto auto;
}

.branding-clear-button {
  padding: 8px 10px;
  border-radius: 8px;
  border: 1px solid var(--shell-border);
  background: transparent;
  color: var(--shell-text-secondary);
  cursor: pointer;
}

.branding-clear-button:hover {
  border-color: var(--shell-text-primary);
  color: var(--shell-text-primary);
}

.branding-preview {
  margin-top: 6px;
  border: 1px solid var(--shell-border);
  border-radius: 10px;
  padding: 6px;
  background: var(--shell-surface-alt);
}

.branding-preview img {
  max-width: 100%;
  height: 80px;
  object-fit: contain;
  display: block;
}

.branding-media-card {
  display: grid;
  gap: 8px;
  background: var(--shell-surface);
  border: 1px solid var(--shell-border);
  border-radius: 12px;
  padding: 10px;
}

.branding-media__preview {
  position: relative;
  border: 1px dashed var(--shell-border);
  border-radius: 10px;
  background: var(--shell-surface-alt);
  min-height: 120px;
  display: grid;
  place-items: center;
  overflow: hidden;
}

.branding-media__preview.is-background {
  min-height: 160px;
}

.branding-media__preview img {
  max-width: 100%;
  max-height: 180px;
  width: 100%;
  object-fit: cover;
  display: block;
}

.branding-media__placeholder {
  color: var(--shell-text-muted);
  font-size: 0.9rem;
}

.branding-media__actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
}

.branding-upload-button {
  position: relative;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--shell-border);
  background: var(--shell-surface-alt);
  cursor: pointer;
  color: var(--shell-text-primary);
}

.branding-upload-button input[type="file"] {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
}

.branding-media__actions .ghost-button {
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--shell-border);
  background: transparent;
  color: var(--shell-text-secondary);
}

.branding-media__actions .ghost-button:not(:disabled):hover {
  color: var(--shell-text-primary);
  border-color: var(--shell-text-primary);
}

.branding-media__url {
  width: 100%;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--shell-border);
  background: var(--shell-surface-alt);
  color: var(--shell-text-primary);
  font-size: 0.95rem;
  min-width: 0;
}

.branding-media__url::placeholder {
  color: var(--shell-text-muted);
}

.branding-upload-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 8px;
}
.project-settings-message {
  border-radius: 10px;
  padding: 8px 12px;
  background: color-mix(in srgb, var(--shell-accent) 20%, transparent);
  color: var(--shell-text-primary);
  font-size: 0.85rem;
}

.project-settings-message.is-error {
  background: color-mix(in srgb, var(--brand-danger) 25%, transparent);
}

.project-settings-message.is-warning {
  border: 1px solid color-mix(in srgb, var(--brand-warning) 45%, transparent);
  color: var(--brand-warning, #f7b955);
  background: color-mix(in srgb, var(--brand-warning) 18%, transparent);
}

.custom-mint-address {
  font-family: "Space Mono", "SFMono-Regular", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas,
    "Liberation Mono", "Courier New", monospace;
  letter-spacing: 0.02em;
}

.project-settings-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
}

.project-settings-actions button {
  border-radius: 10px;
  border: 1px solid var(--shell-border-strong);
  background: var(--shell-accent);
  color: var(--shell-text-primary);
  padding: 8px 18px;
  font-weight: 600;
  letter-spacing: 0.08em;
  cursor: pointer;
}

.project-settings-actions button:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.project-settings-actions .button-success {
  background: linear-gradient(135deg, var(--brand-accent), #36ff6b);
  color: #01240f;
  border-color: color-mix(in srgb, var(--brand-accent) 60%, var(--shell-border-strong));
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--brand-accent) 30%, transparent);
}

.admin-shell__brand-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: clamp(96px, 10vw, 120px);
  height: clamp(36px, 6vw, 44px);
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--brand-accent) 45%, transparent);
  background: radial-gradient(circle at 30% 30%, color-mix(in srgb, var(--brand-accent) 55%, transparent), var(--brand-accent-contrast));
  color: var(--brand-text-primary);
  font-family: var(--brand-font-mono);
  letter-spacing: 0.18em;
  font-size: 0.8rem;
}

.admin-shell__actions {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.admin-shell__account {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.admin-shell__actions .secondary {
  border: 1px solid var(--brand-border-strong);
  background: transparent;
  color: var(--brand-text-primary);
  border-radius: 12px;
  padding: 10px 16px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.72rem;
  cursor: pointer;
}

.admin-shell__actions .secondary:hover {
  border-color: var(--shell-accent);
  color: var(--shell-accent);
}

.admin-shell__project-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 220px;
}

.admin-project-chip {
  border: 1px solid var(--brand-border);
  border-radius: 999px;
  padding: 10px 18px;
  background: color-mix(in srgb, var(--brand-surface) 85%, transparent);
  color: var(--brand-text-primary);
  display: inline-flex;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  transition: border 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.admin-project-chip:disabled {
  opacity: 0.6;
  cursor: default;
}

.admin-project-chip:not(:disabled):hover {
  border-color: var(--shell-accent);
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.35);
  transform: translateY(-1px);
}

.admin-project-chip__label {
  font-weight: 600;
  letter-spacing: 0.04em;
}

.admin-project-count {
  font-size: 0.78rem;
  color: var(--brand-text-muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.admin-shell__nav {
  display: inline-flex;
  gap: 12px;
  background: color-mix(in srgb, var(--brand-surface) 95%, transparent);
  border: 1px solid var(--brand-border);
  border-radius: 14px;
  padding: 8px;
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.4);
  align-self: flex-start;
  flex-wrap: wrap;
}

.admin-shell__nav-link {
  border: none;
  border-radius: 10px;
  padding: 10px 18px;
  background: transparent;
  color: var(--shell-text-secondary);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: color 0.2s ease, background 0.2s ease, transform 0.2s ease;
}

.admin-shell__nav-link:hover {
  color: var(--shell-accent);
}

.admin-shell__nav-link.is-active {
  background: color-mix(in srgb, var(--brand-accent) 18%, transparent);
  color: var(--shell-accent);
  box-shadow: 0 10px 18px color-mix(in srgb, var(--brand-accent) 18%, transparent);
  transform: translateY(-1px);
}

.moderation-page {
  background: var(--shell-background);
  color: var(--shell-text-primary);
}

.moderation-page .admin-panel {
  width: 100% !important;
}

.moderation-page .admin-shell,
.moderation-page .admin-shell__content,
.moderation-page .admin-panel {
  background: var(--shell-background);
  color: var(--shell-text-primary);
}

.moderation-page .admin-panel__section,
.moderation-page .admin-panel__log-entry,
.moderation-page .admin-panel__message,
.moderation-page .admin-panel__form,
.moderation-page .admin-panel__log-stream,
.moderation-page .admin-panel__messages {
  background: var(--shell-surface);
  border-color: var(--shell-border);
}

.moderation-page .admin-panel__status,
.moderation-page .admin-panel__message,
.moderation-page .admin-panel__log-entry {
  border-color: var(--shell-border);
}

.moderation-page input,
.moderation-page textarea,
.moderation-page select {
  background: var(--shell-surface-alt);
  color: var(--shell-text-primary);
  border-color: var(--shell-border);
}

.moderation-page button.secondary,
.moderation-page button {
  background: var(--shell-surface-alt);
  color: var(--shell-text-primary);
  border-color: var(--shell-border);
}

.moderation-page .admin-panel__muted,
.moderation-page .admin-panel__message-head span,
.moderation-page .admin-panel__message-head time {
  color: var(--shell-text-muted);
}

.admin-shell__content {
  flex: 1 1 auto;
  width: 100%;
}

.admin-inline-error {
  border-radius: 14px;
  padding: 12px 16px;
  background: color-mix(in srgb, var(--brand-danger) 20%, transparent);
  border: 1px solid var(--shell-border-strong);
  color: var(--brand-text-primary);
  font-size: 0.92rem;
}

.admin-dashboard-tabs {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 6px;
  border-radius: 12px;
  border: 1px solid var(--brand-border);
  background: color-mix(in srgb, var(--brand-surface) 85%, transparent);
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.35);
}

.admin-dashboard-tab {
  border: none;
  border-radius: 10px;
  padding: 10px 18px;
  background: transparent;
  color: var(--shell-text-secondary);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: color 0.2s ease, background 0.2s ease, transform 0.2s ease;
}

.admin-dashboard-tab.is-active {
  background: color-mix(in srgb, var(--brand-accent) 18%, transparent);
  color: var(--shell-accent);
  transform: translateY(-1px);
  box-shadow: 0 10px 18px color-mix(in srgb, var(--brand-accent) 18%, transparent);
}

.admin-dashboard-panel {
  display: flex;
  flex-direction: column;
  gap: clamp(18px, 2vw, 24px);
  width: 100%;
}

.project-summary-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: clamp(14px, 2vw, 24px);
  margin-bottom: clamp(14px, 2vw, 20px);
}

.project-summary-card {
  border: 1px solid var(--brand-border);
  border-radius: 18px;
  padding: clamp(14px, 2vw, 20px);
  background: color-mix(in srgb, var(--brand-surface) 90%, transparent);
  display: flex;
  flex-direction: column;
  gap: 12px;
  box-shadow: 0 18px 30px rgba(0, 0, 0, 0.35);
}

.project-summary-card header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.project-summary-eyebrow {
  font-family: var(--brand-font-heading);
  font-size: calc(0.72rem * var(--brand-text-scale-primary));
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--brand-text-muted);
  margin: 0 0 4px 0;
}

.project-summary-card dl {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 12px;
  margin: 0;
}

.project-summary-card dt {
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brand-text-muted);
}

.project-summary-card dd {
  margin: 0;
  font-weight: 600;
  color: var(--brand-text-primary);
}

.project-status-badge {
  border-radius: 999px;
  padding: 4px 12px;
  font-size: 0.75rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: color-mix(in srgb, var(--shell-accent) 30%, transparent);
  color: var(--shell-text-primary);
}

.project-status-badge.is-active {
  background: color-mix(in srgb, var(--brand-accent) 35%, transparent);
  color: color-mix(in srgb, var(--brand-accent-contrast) 70%, white 10%);
}

.project-status-badge.is-paused {
  background: color-mix(in srgb, var(--brand-warning) 35%, transparent);
  color: #1f1407;
}

.project-status-badge.is-neutral {
  background: color-mix(in srgb, var(--brand-border) 70%, transparent);
}

.project-status-badge.is-unassigned {
  background: color-mix(in srgb, var(--brand-border) 85%, transparent);
}

.project-settings-card {
  border: 1px solid var(--brand-border);
  border-radius: 18px;
  padding: clamp(16px, 2vw, 24px);
  background: color-mix(in srgb, var(--brand-surface) 88%, transparent);
  box-shadow: 0 18px 30px rgba(0, 0, 0, 0.35);
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.project-settings-card header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.project-settings-eyebrow {
  font-family: var(--brand-font-heading);
  font-size: calc(0.72rem * var(--brand-text-scale-primary));
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--brand-text-muted);
  margin: 0 0 4px 0;
}

.project-settings-card form {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.project-settings-card label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-weight: 600;
}

.project-settings-card input,
.project-settings-card select {
  border-radius: 12px;
  border: 1px solid var(--shell-border-strong);
  background: var(--shell-surface-alt);
  color: var(--shell-text-primary);
  padding: 10px 12px;
}

.project-settings-notice {
  border-radius: 12px;
  padding: 10px 12px;
  border: 1px solid var(--brand-border);
  background: color-mix(in srgb, var(--brand-accent) 12%, transparent);
  color: var(--brand-text-primary);
  font-size: 0.85rem;
}

.project-settings-empty {
  color: var(--brand-text-muted);
  margin: 0;
}

.dracula-ideas {
  display: grid;
  gap: 12px;
}

.dracula-idea-card {
  border: 1px solid var(--brand-border);
  border-radius: 16px;
  padding: 12px 14px;
  background: color-mix(in srgb, var(--shell-surface-alt) 92%, transparent);
  display: grid;
  gap: 8px;
}

.dracula-idea-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.dracula-idea-card p {
  margin: 0;
}

.dracula-idea-meta {
  color: var(--shell-text-muted);
  font-size: 0.9rem;
}

.dracula-idea-mono {
  font-family: var(--brand-font-mono);
}

.dracula-activity-log {
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-height: 360px;
  overflow-y: auto;
}

.dracula-activity-item {
  border: 1px solid var(--brand-border);
  border-radius: 14px;
  padding: 10px 12px;
  background: color-mix(in srgb, var(--shell-surface-alt) 92%, transparent);
  display: grid;
  gap: 6px;
}

.dracula-activity-item.error {
  border-color: color-mix(in srgb, var(--brand-danger) 35%, var(--brand-border));
}

.dracula-activity-meta {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  font-family: var(--brand-font-mono);
  font-size: 0.72rem;
  color: var(--shell-text-muted);
}

.dracula-activity-message {
  margin: 0;
  font-size: 0.95rem;
}

.dracula-activity-item.thinking .dracula-activity-message {
  color: var(--shell-text-muted);
}

.dracula-activity-item.final .dracula-activity-message {
  color: var(--shell-text-primary);
}

.dracula-activity-detail {
  margin: 0;
  color: var(--shell-text-muted);
  font-size: 0.85rem;
}

.admin-page label {
  color: var(--shell-text-secondary);
}

.admin-page label span {
  color: var(--brand-text-muted);
}

.admin-page input[type="text"],
.admin-page input[type="url"],
.admin-page input[type="number"],
.admin-page input[type="password"],
.admin-page textarea {
  border-radius: 12px;
  border: 1px solid var(--brand-border-strong);
  background: var(--brand-surface-alt);
  color: var(--brand-text-primary);
  padding: 10px 12px;
}

.admin-main-stack {
  display: flex;
  flex-direction: column;
  gap: clamp(18px, 2vw, 24px);
  width: 100%;
}

.admin-main-stack--charities {
  flex: 1 1 auto;
}

.project-list-card,
.project-members-card {
  background: linear-gradient(145deg, color-mix(in srgb, var(--shell-surface) 94%, transparent), color-mix(in srgb, var(--shell-surface-alt) 90%, transparent));
  border: 1px solid var(--shell-border);
  border-radius: 18px;
  padding: clamp(16px, 2vw, 22px);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.35);
}

.project-list-card__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid color-mix(in srgb, var(--shell-border) 85%, transparent);
}

.project-list-card__header h3 {
  margin: 0 0 4px;
  font-size: clamp(1.05rem, 2vw, 1.2rem);
  font-weight: 650;
}

.project-list-card__header small {
  display: block;
  color: var(--shell-text-muted, var(--brand-text-muted));
}

.project-list-card .project-summary-eyebrow,
.project-members-card .project-summary-eyebrow {
  margin: 0;
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--brand-text-muted);
}

.project-list-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.project-list {
  list-style: none;
  padding: 0;
  margin: 16px 0 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 12px;
}

.project-list__item {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  background: color-mix(in srgb, var(--shell-surface-alt) 94%, transparent);
  border: 1px solid color-mix(in srgb, var(--shell-border) 90%, transparent);
  border-radius: 14px;
  padding: 14px 16px;
  box-shadow: 0 16px 36px rgba(0, 0, 0, 0.28);
  transition: transform 120ms ease, box-shadow 120ms ease, border-color 120ms ease;
}

.project-list__item:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.35);
  border-color: color-mix(in srgb, var(--brand-accent) 35%, var(--shell-border));
}

.project-list__meta {
  display: grid;
  grid-template-columns: auto auto;
  column-gap: 10px;
  row-gap: 6px;
  flex: 1 1 auto;
  min-width: 0;
}

.project-list__meta strong {
  font-size: 1.02rem;
  font-weight: 650;
  color: var(--shell-text-primary);
  grid-column: 1;
}

.project-list__meta .project-status-badge {
  grid-column: 2;
  justify-self: start;
  align-self: start;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 6px 12px;
}

.project-list__meta small {
  grid-column: 1 / -1;
  color: var(--shell-text-muted, var(--brand-text-muted));
  opacity: 0.9;
}

.project-list__actions {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
}

.project-list__actions button,
.project-list-card__actions button {
  border-radius: 12px;
  padding: 10px 14px;
  font-weight: 600;
}

.project-table-wrapper {
  width: 100%;
  overflow-x: auto;
  margin-top: 12px;
}

.project-table-hint {
  margin: 6px 0 0;
  color: var(--shell-text-muted, var(--brand-text-muted));
  font-size: 0.9rem;
}

.project-table {
  width: 100%;
  border-collapse: collapse;
  background: color-mix(in srgb, var(--shell-surface) 96%, transparent);
  border: 1px solid var(--shell-border);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.32);
}

.project-table th,
.project-table td {
  padding: 12px 14px;
  text-align: left;
  border-bottom: 1px solid color-mix(in srgb, var(--shell-border) 85%, transparent);
  font-size: 0.95rem;
}

.project-table thead {
  background: color-mix(in srgb, var(--shell-surface-alt) 94%, transparent);
}

.project-table th {
  font-weight: 650;
  letter-spacing: 0.04em;
  color: var(--shell-text-secondary);
}

.project-table__row:last-child td {
  border-bottom: none;
}

.project-table__row {
  transition: background 120ms ease, border-color 120ms ease;
}

.project-table__row:hover {
  background: color-mix(in srgb, var(--shell-surface-alt) 90%, transparent);
}

.project-table__row.is-active {
  border-left: 3px solid var(--brand-accent);
  background: color-mix(in srgb, var(--brand-accent) 6%, var(--shell-surface) 94%);
}

.project-table__name {
  font-weight: 650;
  color: var(--shell-text-primary);
  margin-bottom: 4px;
}

.project-table__meta {
  color: var(--brand-text-muted);
  font-size: 0.85rem;
}

.project-table__mono {
  font-family: var(--brand-font-mono);
  word-break: break-all;
}

.project-table__actions {
  text-align: right;
  min-width: 120px;
}

.project-table__actions button {
  width: 100%;
  justify-content: center;
}

.pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 0.78rem;
  letter-spacing: 0.05em;
  font-weight: 650;
}

.pill--current {
  background: color-mix(in srgb, var(--brand-accent) 35%, transparent);
  color: var(--brand-accent-contrast);
  border: 1px solid color-mix(in srgb, var(--brand-accent) 60%, transparent);
}

.pill--ghost {
  background: color-mix(in srgb, var(--shell-border) 70%, transparent);
  color: var(--shell-text-primary);
  border: 1px solid color-mix(in srgb, var(--shell-border) 85%, transparent);
}

.nftdrop-tree-stack {
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.nftdrop-tree-row {
  padding: 10px 12px;
  border: 1px solid var(--shell-border);
  border-radius: 14px;
  background: color-mix(in srgb, var(--shell-surface-alt) 92%, transparent);
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.nftdrop-tree-row__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.nftdrop-tree-row__addr {
  font-family: var(--brand-font-mono);
  color: var(--shell-text-primary);
}

.nftdrop-tree-row__stats {
  color: var(--shell-text-secondary);
  font-size: 0.9rem;
}

.project-members-card header h3 {
  margin: 0 0 4px;
  font-family: var(--brand-font-primary);
  font-size: calc(clamp(1.02rem, 2vw, 1.15rem) * var(--brand-text-scale-primary));
}

.project-members-card .project-list-card__header {
  margin-bottom: 10px;
}

.project-member-form {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
  padding: 14px;
  border: 1px solid var(--shell-border);
  border-radius: 14px;
  background: color-mix(in srgb, var(--shell-surface-alt) 92%, transparent);
}

.project-member-form label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 0.88rem;
  color: var(--shell-text-secondary);
}

.project-member-form input,
.project-member-form select {
  width: 100%;
  border-radius: 12px;
  border: 1px solid var(--shell-border-strong);
  background: var(--brand-surface);
  color: var(--brand-text-primary);
  padding: 10px 12px;
}

.project-member-form .project-list-card__actions {
  padding-top: 4px;
  justify-content: flex-start;
}

.project-members-card .account-roster-list {
  list-style: none;
  margin: 14px 0 0;
  padding: 0;
  display: grid;
  gap: 10px;
}

.project-members-card .account-roster-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  border: 1px solid color-mix(in srgb, var(--shell-border) 90%, transparent);
  border-radius: 14px;
  background: color-mix(in srgb, var(--shell-surface-alt) 92%, transparent);
}

.project-members-card .account-roster-primary strong {
  font-size: 1rem;
}

.project-members-card .account-roster-meta {
  color: var(--brand-text-muted);
  font-size: 0.85rem;
}

.project-members-card .account-roster-role {
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: flex-end;
}

.project-members-card .account-roster-role select {
  border-radius: 12px;
  border: 1px solid var(--shell-border-strong);
  background: var(--brand-surface);
  color: var(--brand-text-primary);
  padding: 8px 10px;
}

.project-members-card .account-roster-role button {
  border-radius: 12px;
}

.project-members-card .account-roster-empty {
  padding: 10px 2px 0;
}

.global-settings-card {
  background: var(--brand-surface);
  border: 1px solid var(--brand-border);
  border-radius: 18px;
  padding: clamp(18px, 2.4vw, 24px);
  display: grid;
  gap: 14px;
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.45);
}

.global-settings-card header h2 {
  margin: 0 0 6px;
  font-size: clamp(1.04rem, 2vw, 1.25rem);
  font-weight: 600;
}

.global-settings-card header p {
  margin: 0;
  color: var(--shell-text-secondary);
  opacity: 0.8;
  font-size: 0.9rem;
}

.global-settings-card label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 0.82rem;
  color: var(--shell-text-secondary);
}

.global-settings-card label span {
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.7rem;
  color: var(--brand-text-muted);
}

.global-settings-card input {
  border-radius: 12px;
  border: 1px solid var(--brand-border-strong);
  background: var(--brand-surface-alt);
  color: var(--brand-text-primary);
  padding: 10px 12px;
  font-size: 0.92rem;
}

.field-hint {
  display: block;
  font-size: 0.85rem;
  color: var(--brand-text-muted);
  margin-top: 0.15rem;
}

.account-invite-token {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
  margin-top: 0.75rem;
}

.account-invite-token code {
  font-family: var(--brand-font-mono);
  font-size: 0.9rem;
  padding: 0.35rem 0.55rem;
  border-radius: 8px;
  background: rgba(148, 163, 184, 0.12);
  color: var(--brand-text-primary);
  word-break: break-all;
}

.account-roster-section {
  margin-top: 1.25rem;
  border-top: 1px solid rgba(148, 163, 184, 0.2);
  padding-top: 1rem;
}

.account-roster-section h3 {
  margin: 0 0 0.5rem;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--brand-text-primary);
}

.account-roster-heading {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.5rem;
}
.admin-create-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}
.admin-create-actions {
  display: flex;
  align-items: flex-end;
  justify-content: flex-start;
}

.account-roster-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.account-roster-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0.35rem 0;
  border-bottom: 1px solid rgba(148, 163, 184, 0.12);
}

.account-roster-row:last-child {
  border-bottom: none;
}

.account-roster-primary {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}

.account-roster-primary strong {
  font-size: 0.95rem;
  color: var(--brand-text-primary);
}

.account-roster-primary span {
  font-size: 0.8rem;
  color: var(--brand-text-muted);
}

.account-roster-meta {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  font-size: 0.8rem;
  color: var(--brand-text-muted);
  align-items: flex-end;
}

.account-roster-empty {
  margin: 0.5rem 0 0;
  color: var(--brand-text-muted);
  font-size: 0.85rem;
}

.account-invite-row .account-roster-meta {
  align-items: flex-start;
}

.account-roster-role {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  min-width: 180px;
}

.account-roster-role label {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  font-size: 0.78rem;
  color: var(--shell-text-secondary);
}

.account-roster-role select {
  border-radius: 10px;
  border: 1px solid var(--shell-border-strong);
  background: var(--shell-surface-alt);
  color: var(--shell-text-primary);
  padding: 6px 10px;
}

.account-roster-role__status {
  font-size: 0.75rem;
  color: var(--brand-text-muted);
}

.ghost-button {
  padding: 0.3rem 0.65rem;
  border-radius: 999px;
  border: 1px solid var(--ghost-button-border);
  background: transparent;
  color: var(--brand-text-primary);
  font-size: 0.78rem;
  cursor: pointer;
}

.ghost-button:hover:not(:disabled) {
  border-color: var(--ghost-button-border-hover);
  background: color-mix(in srgb, var(--ghost-button-border-hover) 18%, transparent);
}

.ghost-button:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.global-settings-card input[type="checkbox"] {
  width: 22px;
  height: 22px;
  padding: 0;
  border-radius: 6px;
}

.feature-flags-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.feature-flags-toggle {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid var(--brand-border);
  background: var(--brand-surface-alt);
  cursor: pointer;
  transition: border-color 0.2s ease, background 0.2s ease;
}

.feature-flags-toggle:hover {
  border-color: var(--brand-border-strong);
  background: rgba(255, 255, 255, 0.03);
}

.feature-flags-toggle input[type="checkbox"] {
  margin: 2px 0 0;
  flex-shrink: 0;
  accent-color: var(--shell-accent);
}

.feature-flags-toggle__content {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.feature-flags-toggle__content strong {
  font-size: 0.95rem;
  color: var(--brand-text-primary);
}

.feature-flags-toggle__content p {
  margin: 0;
  font-size: 0.82rem;
  color: var(--shell-text-secondary);
}

.feature-flags-message {
  border-radius: 12px;
  padding: 10px 14px;
  font-size: 0.82rem;
  border: 1px solid var(--brand-border);
  background: var(--brand-surface-alt);
}

.feature-flags-message--error {
  border-color: var(--brand-danger);
  color: var(--brand-danger);
}

.feature-flags-message--success {
  border-color: var(--shell-accent);
  color: var(--shell-accent);
}

.challenge-manager-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  flex-wrap: wrap;
}

.challenge-manager-actions {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.challenge-manager-item__prompt {
  font-size: 1rem;
  font-weight: 600;
  margin: 0 0 0.35rem;
}

.challenge-manager-item__status {
  margin: 0;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--shell-text-secondary);
}

.challenge-manager-item__window {
  margin: 0.2rem 0 0;
  font-size: 0.85rem;
  color: var(--brand-text-muted);
}

.challenge-manager-item__answers {
  list-style: none;
  margin: 0.75rem 0 0;
  padding: 0;
  display: grid;
  gap: 0.35rem;
}

.challenge-manager-item__answers li {
  padding: 0.25rem 0.4rem;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.04);
}

.challenge-manager-item__actions {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-top: 0.75rem;
}

.donation-settings-burn {
  font-size: 0.8rem;
  color: var(--shell-text-secondary);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-top: -4px;
  margin-bottom: 8px;
}

.donation-settings-burn strong {
  color: var(--shell-accent);
}

.donation-settings-retained-note {
  font-size: 0.72rem;
  color: var(--brand-text-muted);
}

.donation-settings-hint {
  margin: 0;
  font-size: 0.75rem;
  color: var(--brand-text-muted);
}

.donation-settings-mode {
  border: 1px solid color-mix(in srgb, var(--brand-border) 65%, transparent);
  border-radius: 14px;
  padding: 14px 16px;
  margin: 18px 0;
}

.donation-settings-mode legend {
  font-weight: 600;
  font-size: 0.9rem;
  margin-bottom: 8px;
  color: var(--brand-text-primary);
}

.donation-settings-radio {
  display: flex;
  gap: 10px;
  align-items: center;
  font-size: 0.9rem;
  color: var(--shell-text-secondary);
  margin-bottom: 6px;
}

.donation-settings-radio:last-of-type {
  margin-bottom: 0;
}

.donation-settings-radio input {
  width: auto;
}

.donation-settings-metrics {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
  margin-top: 12px;
  margin-bottom: 8px;
}

.donation-settings-metric {
  border: 1px solid var(--brand-border);
  border-radius: 12px;
  padding: 10px 12px;
  background: color-mix(in srgb, var(--brand-surface) 80%, transparent);
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.donation-settings-metric span {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--brand-text-muted);
}

.donation-settings-metric strong {
  font-size: 0.92rem;
  color: var(--brand-text-primary);
}

.donation-settings-feedback {
  margin-top: 8px;
  border-radius: 12px;
  padding: 10px 12px;
  font-size: 0.85rem;
}

.donation-settings-feedback--error {
  background: color-mix(in srgb, var(--brand-danger) 14%, transparent);
  border: 1px solid color-mix(in srgb, var(--brand-danger) 35%, transparent);
  color: var(--brand-danger-soft);
}

.donation-settings-feedback--success {
  background: color-mix(in srgb, var(--brand-accent) 14%, transparent);
  border: 1px solid color-mix(in srgb, var(--brand-accent) 35%, transparent);
  color: var(--shell-accent);
}

.donation-settings-reset {
  border: 1px solid color-mix(in srgb, var(--brand-danger) 45%, transparent);
  background: transparent;
  color: var(--brand-danger-soft);
  border-radius: 12px;
  padding: 10px 16px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.72rem;
  cursor: pointer;
  transition: border-color 0.2s ease, color 0.2s ease;
}

.donation-settings-reset:hover:not([disabled]) {
  border-color: color-mix(in srgb, var(--brand-danger) 70%, transparent);
  color: var(--brand-danger);
}

.donation-settings-reset[disabled] {
  opacity: 0.6;
  cursor: not-allowed;
}

.account-security-card {
  position: relative;
}

.account-security-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: baseline;
  font-size: 0.85rem;
  color: var(--shell-text-secondary);
}

.account-security-meta strong {
  color: var(--brand-text-primary);
  font-weight: 600;
}

.account-security-loading {
  font-size: 0.78rem;
  color: var(--brand-text-muted);
}

.account-security-hint {
  margin: 0;
  font-size: 0.78rem;
  color: var(--brand-text-muted);
  line-height: 1.4;
}

.account-security-feedback {
  border-radius: 12px;
  padding: 10px 12px;
  font-size: 0.85rem;
  margin: 4px 0 0;
}

.account-security-feedback--error {
  background: color-mix(in srgb, var(--brand-danger) 16%, transparent);
  border: 1px solid color-mix(in srgb, var(--brand-danger) 40%, transparent);
  color: var(--brand-danger-soft);
}

.account-security-feedback--success {
  background: color-mix(in srgb, var(--brand-accent) 14%, transparent);
  border: 1px solid color-mix(in srgb, var(--brand-accent) 40%, transparent);
  color: var(--shell-accent);
}

.account-security-actions {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
}

.global-settings-section {
  display: grid;
  gap: 12px;
}

.global-settings-section h3 {
  margin: 0;
  font-size: 1rem;
  font-weight: 600;
  color: var(--brand-text-primary);
}

.global-settings-description {
  margin: 0;
  font-size: 0.85rem;
  color: var(--shell-text-secondary);
}

.global-settings-divider {
  height: 1px;
  background: var(--brand-border);
  border-radius: 1px;
}

.global-settings-note {
  margin-top: 6px;
  font-size: 0.82rem;
  color: var(--shell-text-secondary);
  word-break: break-all;
}

.global-settings-note code {
  font-family: var(--brand-font-mono);
  color: var(--brand-accent-soft);
}

.global-settings-actions {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
}

.global-settings-actions button {
  border: none;
  border-radius: 12px;
  padding: 10px 18px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  background: var(--brand-accent);
  color: var(--brand-accent-contrast);
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.global-settings-actions button:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.global-settings-actions button:not(:disabled):hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 24px color-mix(in srgb, var(--brand-accent) 28%, transparent);
}

.global-settings-error {
  background: color-mix(in srgb, var(--brand-danger) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--brand-danger) 30%, transparent);
  color: var(--brand-danger-soft);
  padding: 8px 12px;
  border-radius: 12px;
  font-size: 0.85rem;
}

.launchpad-platform-wallet {
  display: grid;
  gap: 8px;
}

.launchpad-platform-wallet code {
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid var(--brand-border);
  background: color-mix(in srgb, var(--brand-panel) 82%, black);
  color: var(--shell-text-primary);
  word-break: break-all;
}

.launchpad-platform-wallet button {
  width: fit-content;
}

.launchpad-options-manager {
  display: grid;
  gap: 10px;
  padding: 12px;
  border-radius: 12px;
  border: 1px solid var(--brand-border);
  background: color-mix(in srgb, var(--brand-panel) 88%, black);
}

.launchpad-options-manager__actions {
  display: flex;
  justify-content: flex-start;
}

.launchpad-airdrop-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 12px;
}

.launchpad-airdrop-card {
  border: 1px solid var(--brand-border);
  border-radius: 14px;
  padding: 14px;
  background: color-mix(in srgb, var(--brand-panel) 90%, black);
  display: grid;
  gap: 10px;
}

.launchpad-airdrop-card__header {
  display: flex;
  align-items: center;
  gap: 12px;
}

.launchpad-airdrop-card__media {
  width: 52px;
  height: 52px;
  border-radius: 10px;
  border: 1px solid var(--brand-border);
  background: color-mix(in srgb, var(--brand-panel-strong) 85%, black);
  overflow: hidden;
  display: grid;
  place-items: center;
}

.launchpad-airdrop-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.launchpad-airdrop-card__fallback {
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--shell-text-primary);
}

.launchpad-airdrop-card__meta {
  display: grid;
  gap: 4px;
}

.launchpad-airdrop-card__meta strong {
  font-size: 0.95rem;
}

.launchpad-airdrop-card__meta span {
  font-size: 0.8rem;
  color: var(--shell-text-secondary);
}

.launchpad-airdrop-card__actions {
  display: flex;
  justify-content: flex-end;
}

.launchpad-registered-panel {
  border: 1px solid var(--brand-border);
  border-radius: 14px;
  padding: 14px;
  background: color-mix(in srgb, var(--brand-panel) 90%, black);
  display: grid;
  gap: 10px;
}

.launchpad-registered-panel__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
}

.launchpad-registered-panel__header h3 {
  margin: 0;
  font-size: 0.95rem;
}

.launchpad-registered-panel__header small {
  color: var(--shell-text-secondary);
  font-size: 0.78rem;
}

.launchpad-registered-list {
  display: grid;
  gap: 8px;
  max-height: 280px;
  overflow: auto;
  padding-right: 4px;
}

.launchpad-registered-row {
  border: 1px solid var(--brand-border);
  border-radius: 10px;
  padding: 10px;
  background: color-mix(in srgb, var(--brand-panel-strong) 90%, black);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.launchpad-registered-row__meta {
  display: grid;
  gap: 5px;
  min-width: 0;
}

.launchpad-registered-row__meta strong {
  font-size: 0.86rem;
}

.launchpad-registered-row__meta code {
  border: 1px solid var(--brand-border);
  border-radius: 8px;
  padding: 6px 8px;
  background: color-mix(in srgb, var(--brand-panel) 82%, black);
  color: var(--shell-text-primary);
  font-size: 0.72rem;
  word-break: break-all;
}

.launchpad-activity-panel {
  border: 1px solid var(--brand-border);
  border-radius: 14px;
  padding: 14px;
  background: color-mix(in srgb, var(--brand-panel) 90%, black);
  display: grid;
  gap: 10px;
}

.launchpad-activity-panel__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
}

.launchpad-activity-panel__controls {
  display: flex;
  align-items: flex-end;
  gap: 8px;
}

.launchpad-activity-filter {
  display: grid;
  gap: 4px;
}

.launchpad-activity-filter span {
  font-size: 0.72rem;
  color: var(--shell-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.launchpad-activity-filter select {
  min-width: 210px;
  border-radius: 8px;
}

.launchpad-activity-panel__header h3 {
  margin: 0;
  font-size: 0.95rem;
}

.launchpad-activity-panel__header small {
  color: var(--shell-text-secondary);
  font-size: 0.78rem;
}

.launchpad-activity-list {
  display: grid;
  gap: 8px;
  max-height: 280px;
  overflow: auto;
  padding-right: 4px;
}

.launchpad-activity-row {
  border: 1px solid var(--brand-border);
  border-radius: 10px;
  padding: 9px 10px;
  background: color-mix(in srgb, var(--brand-panel-strong) 90%, black);
  display: grid;
  gap: 6px;
}

.launchpad-activity-row__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
}

.launchpad-activity-row__head strong {
  font-size: 0.85rem;
}

.launchpad-activity-row__head span {
  font-size: 0.75rem;
  color: var(--shell-text-secondary);
}

.launchpad-activity-row p {
  margin: 0;
  font-size: 0.78rem;
  color: var(--shell-text-secondary);
  line-height: 1.4;
  word-break: break-word;
}

.launchpad-activity-row.level-success {
  border-color: color-mix(in srgb, var(--brand-success) 60%, var(--brand-border));
}

.launchpad-activity-row.level-warn {
  border-color: color-mix(in srgb, var(--brand-warning) 60%, var(--brand-border));
}

.launchpad-activity-row.level-error {
  border-color: color-mix(in srgb, var(--brand-danger) 60%, var(--brand-border));
}

@media (max-width: 900px) {
  .launchpad-registered-row {
    flex-direction: column;
    align-items: stretch;
  }

  .launchpad-activity-panel__header {
    flex-direction: column;
    align-items: stretch;
  }

  .launchpad-activity-panel__controls {
    width: 100%;
    justify-content: space-between;
  }

  .launchpad-activity-filter select {
    min-width: 0;
    width: 100%;
  }
}

.branding-settings-card {
  background: var(--brand-surface);
  border: 1px solid var(--brand-border);
  border-radius: 18px;
  padding: clamp(18px, 2.6vw, 28px);
  display: flex;
  flex-direction: column;
  gap: clamp(18px, 2vw, 24px);
  box-shadow: 0 18px 38px rgba(0, 0, 0, 0.45);
}

.branding-font-advanced {
  margin-top: 10px;
}

.branding-font-advanced summary {
  cursor: pointer;
  user-select: none;
  color: var(--shell-text-secondary);
  font-size: 0.85rem;
}

.branding-font-advanced input {
  margin-top: 8px;
}

.branding-settings-card header h2 {
  margin: 0 0 6px;
  font-size: clamp(1.04rem, 2vw, 1.3rem);
  font-weight: 600;
}

.branding-settings-card header p {
  margin: 0;
  color: var(--shell-text-secondary);
  opacity: 0.8;
  font-size: 0.94rem;
}

.branding-settings-section {
  display: flex;
  flex-direction: column;
  gap: clamp(12px, 1.6vw, 18px);
}

.branding-settings-section__header {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.branding-settings-section__header h3 {
  margin: 0;
  font-size: clamp(1rem, 1.8vw, 1.2rem);
  font-weight: 600;
  color: var(--brand-text-primary);
}

.branding-settings-section__header p {
  margin: 0;
  color: var(--shell-text-secondary);
  opacity: 0.85;
  font-size: 0.88rem;
}

.branding-template-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: clamp(12px, 1.6vw, 18px);
}

.branding-template-card {
  position: relative;
  border: 1px solid var(--brand-border);
  border-radius: 18px;
  padding: 0;
  cursor: pointer;
  background: var(--brand-surface);
  transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.branding-template-card input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.branding-template-card__body {
  display: grid;
  gap: 12px;
  padding: 16px;
}

.branding-template-card__preview {
  border-radius: 12px;
  height: 120px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--brand-text-primary);
  border: 1px solid var(--brand-border-strong);
}

.branding-template-card__preview--simple {
  background: linear-gradient(135deg, #040404, #121822);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.branding-template-card__preview--professional {
  background: linear-gradient(135deg, #f8fafc, #e2e8f0);
  color: #0f172a;
  box-shadow: inset 0 0 0 1px rgba(15, 23, 42, 0.08);
}

.branding-template-card__preview--terminal {
  background: linear-gradient(135deg, #021005, #062c16);
  color: #57ff9c;
  box-shadow: inset 0 0 0 1px rgba(87, 255, 156, 0.2);
}

.branding-template-card__details {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.branding-template-card__name {
  font-size: 1rem;
  font-weight: 600;
  color: var(--brand-text-primary);
}

.branding-template-card__tagline {
  font-size: 0.85rem;
  color: var(--shell-text-secondary);
}

.branding-template-card__badges {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.branding-template-card__badge {
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border: 1px solid var(--brand-border);
  border-radius: 999px;
  padding: 4px 10px;
  color: var(--brand-text-muted);
}

.branding-template-card.is-selected {
  border-color: var(--shell-accent);
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--brand-accent) 40%, transparent),
    0 18px 32px rgba(0, 0, 0, 0.45);
  transform: translateY(-2px);
}

.branding-template-card.is-selected .branding-template-card__badge {
  border-color: var(--shell-accent);
  color: var(--brand-accent-soft);
}

.branding-settings-hint {
  margin: 0;
  color: var(--brand-text-muted);
  font-size: 0.82rem;
}

.branding-settings-media {
  display: grid;
  gap: clamp(12px, 1.8vw, 18px);
  grid-template-columns: minmax(0, 280px) minmax(0, 1fr);
  align-items: start;
}

.branding-settings-media__preview {
  background: var(--brand-surface-alt);
  border: 1px solid var(--brand-border);
  border-radius: 16px;
  min-height: 180px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
}

.branding-settings-media__preview img {
  max-width: 100%;
  max-height: 240px;
  object-fit: contain;
  border-radius: 12px;
}

.branding-settings-media__placeholder {
  font-size: 0.9rem;
  color: var(--brand-text-muted);
  text-align: center;
  opacity: 0.8;
}

.branding-settings-media__controls {
  display: grid;
  gap: 12px;
}

.branding-settings-media__controls label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 0.84rem;
  color: var(--shell-text-secondary);
}

.branding-settings-media__controls span {
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.7rem;
  color: var(--brand-text-muted);
}

.branding-settings-media__controls input[type="file"] {
  border: 1px dashed var(--brand-border-strong);
  border-radius: 10px;
  padding: 10px;
  background: var(--brand-surface-alt);
  color: var(--shell-text-secondary);
  cursor: pointer;
}

.branding-settings-media__controls input[type="url"],
.branding-settings-media__controls input[type="text"] {
  border-radius: 12px;
  border: 1px solid var(--brand-border-strong);
  background: var(--brand-surface-alt);
  color: var(--brand-text-primary);
  padding: 10px 12px;
  font-size: 0.92rem;
}

.branding-settings-media__filename {
  font-size: 0.75rem;
  color: var(--brand-text-muted);
  letter-spacing: 0.08em;
}

.branding-settings-media__actions {
  display: flex;
  gap: 10px;
}

.branding-settings-media__actions .secondary {
  border: 1px solid var(--brand-border-strong);
  background: transparent;
  color: var(--shell-text-secondary);
  border-radius: 10px;
  padding: 8px 14px;
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
}

.branding-settings-media__actions .secondary:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.branding-settings-media__actions .secondary:not(:disabled):hover {
  color: var(--shell-accent);
  border-color: var(--shell-accent);
}

.branding-settings-toggle {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.9rem;
  color: var(--shell-text-secondary);
  margin: 4px 0;
}

.branding-settings-toggle input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--shell-accent);
}

.branding-overlay-color {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: flex-end;
}

.branding-overlay-color label {
  flex: 1 1 220px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.branding-overlay-color input[type="color"] {
  width: 64px;
  height: 40px;
  padding: 0;
  border: none;
  background: transparent;
  cursor: pointer;
}

.branding-overlay-alpha__controls {
  display: flex;
  align-items: center;
  gap: 12px;
}

.branding-overlay-alpha input[type="range"] {
  flex: 1 1 auto;
  accent-color: var(--shell-accent);
}

.branding-overlay-alpha output {
  min-width: 3ch;
  text-align: right;
  font-variant-numeric: tabular-nums;
  color: var(--shell-text-secondary);
}

.branding-custom-css {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.branding-custom-css span {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  font-weight: 600;
  color: var(--shell-text-secondary);
}

.branding-custom-css small {
  font-weight: 400;
  font-size: 0.8rem;
  color: var(--brand-text-muted);
}

.branding-custom-css textarea {
  width: 100%;
  min-height: 200px;
  border-radius: 12px;
  border: 1px solid var(--brand-border);
  background: rgba(15, 17, 24, 0.35);
  color: var(--brand-text-primary);
  font-family: var(--brand-font-mono);
  font-size: 0.95rem;
  line-height: 1.5;
  padding: 12px;
  resize: vertical;
}

.branding-custom-css textarea::placeholder {
  color: var(--brand-text-muted);
}

.branding-settings-media--background .branding-settings-media__preview {
  min-height: 220px;
}

.branding-settings-background-card {
  width: 100%;
  height: 220px;
  border-radius: 18px;
  border: 1px solid var(--brand-border);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.2);
}

.branding-settings-colors {
  display: grid;
  gap: clamp(12px, 1.6vw, 18px);
}

.branding-settings-colors__group {
  border: 1px solid var(--brand-border);
  border-radius: 14px;
  padding: clamp(12px, 1.6vw, 18px);
  background: var(--brand-surface-alt);
}

.branding-settings-colors__group legend {
  padding: 0 6px;
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--brand-text-muted);
}

.branding-settings-colors__group legend small {
  display: block;
  font-size: 0.68rem;
  letter-spacing: 0.08em;
  color: var(--shell-text-secondary);
  opacity: 0.75;
  text-transform: none;
  margin-top: 4px;
}

.branding-settings-colors__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
  margin-top: 12px;
}

.branding-settings-colors__grid label {
  display: grid;
  gap: 6px;
  font-size: 0.8rem;
  color: var(--shell-text-secondary);
}

.branding-settings-colors__grid label span {
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.68rem;
  color: var(--brand-text-muted);
}

.branding-settings-colors__grid input[type="color"] {
  width: 100%;
  height: 42px;
  border: 1px solid var(--brand-border-strong);
  border-radius: 10px;
  background: transparent;
  padding: 0;
  cursor: pointer;
}

.branding-settings-color-value {
  border-radius: 10px;
  border: 1px solid var(--brand-border-strong);
  background: var(--brand-surface);
  color: var(--brand-text-primary);
  padding: 8px 10px;
  font-size: 0.8rem;
  font-family: var(--brand-font-mono);
}

.branding-settings-message {
  border-radius: 12px;
  padding: 10px 14px;
  font-size: 0.85rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.branding-settings-message--error {
  background: color-mix(in srgb, var(--brand-danger) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--brand-danger) 28%, transparent);
  color: var(--brand-danger-soft);
}

.branding-settings-message--success {
  background: color-mix(in srgb, var(--brand-accent) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--brand-accent) 28%, transparent);
  color: var(--brand-accent-soft);
}

.branding-settings-message__dismiss {
  border: none;
  background: transparent;
  color: inherit;
  cursor: pointer;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
}

.branding-settings-actions {
  display: flex;
  justify-content: flex-end;
}

.branding-settings-actions button {
  border-radius: 12px;
  border: none;
  padding: 12px 20px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  background: var(--brand-accent);
  color: var(--brand-accent-contrast);
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.branding-settings-actions button:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  box-shadow: none;
  transform: none;
}

.branding-settings-actions button:not(:disabled):hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 26px color-mix(in srgb, var(--brand-accent) 26%, transparent);
}

.charity-manager {
  background: var(--brand-surface);
  border: 1px solid var(--brand-border);
  border-radius: 18px;
  padding: clamp(18px, 2.4vw, 24px);
  display: flex;
  flex-direction: column;
  gap: clamp(16px, 2vw, 20px);
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.45);
}

.charity-manager__header h2 {
  margin: 0 0 6px;
  font-size: clamp(1.04rem, 2vw, 1.25rem);
  font-weight: 600;
}

.charity-manager__header p {
  margin: 0;
  color: var(--shell-text-secondary);
  opacity: 0.7;
  font-size: 0.9rem;
}

.charity-manager__grid {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) minmax(320px, 1fr);
  gap: clamp(18px, 2vw, 24px);
  align-items: flex-start;
}

.charity-manager__form {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.charity-manager__form label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 0.82rem;
  color: var(--shell-text-secondary);
}

.charity-manager__form label span {
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.7rem;
  color: var(--brand-text-muted);
}

.charity-manager__form input {
  border-radius: 12px;
  border: 1px solid var(--brand-border-strong);
  background: var(--brand-surface-alt);
  color: var(--brand-text-primary);
  padding: 10px 12px;
  font-size: 0.92rem;
}

.charity-manager__file input[type="file"] {
  border: 1px dashed var(--brand-border-strong);
  border-radius: 12px;
  background: color-mix(in srgb, var(--brand-surface-alt) 70%, transparent);
  padding: 12px;
  color: var(--shell-text-secondary);
  cursor: pointer;
  font-size: 0.85rem;
}

.charity-manager__file input[type="file"]::file-selector-button {
  border: none;
  border-radius: 8px;
  background: color-mix(in srgb, var(--brand-accent) 18%, transparent);
  color: var(--shell-accent);
  padding: 6px 12px;
  margin-right: 12px;
  cursor: pointer;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.charity-manager__file input[type="file"]:hover::file-selector-button {
  background: color-mix(in srgb, var(--brand-accent) 28%, transparent);
}

.charity-manager__file-name,
.charity-manager__file-hint {
  font-size: 0.75rem;
  color: rgba(154, 164, 160, 0.78);
}

.charity-manager__form-actions {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  align-items: center;
}

.charity-manager__cancel {
  border-radius: 12px;
  padding: 9px 16px;
  border: 1px solid var(--brand-border);
  background: transparent;
  color: var(--shell-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.7rem;
  cursor: pointer;
  transition: color 0.2s ease, border-color 0.2s ease;
}

.charity-manager__cancel:hover {
  border-color: var(--shell-accent);
  color: var(--shell-accent);
}

.charity-manager__cancel[disabled] {
  opacity: 0.6;
  cursor: not-allowed;
}

.charity-manager__preview {
  margin-top: 4px;
  border: 1px solid var(--brand-border);
  border-radius: 12px;
  padding: 10px;
  background: rgba(5, 5, 5, 0.9);
  max-width: 180px;
}

.charity-manager__preview img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 8px;
  object-fit: contain;
}

.charity-manager__status {
  margin-top: 2px;
  border-radius: 12px;
  padding: 8px 12px;
  font-size: 0.78rem;
  background: rgba(24, 24, 24, 0.85);
  border: 1px solid rgba(38, 38, 38, 0.8);
  color: var(--shell-text-secondary);
}

.charity-manager__status--error {
  background: color-mix(in srgb, var(--brand-danger) 12%, transparent);
  border-color: color-mix(in srgb, var(--brand-danger) 28%, transparent);
  color: var(--brand-danger-soft);
}

.charity-manager__status--success {
  background: color-mix(in srgb, var(--brand-accent) 12%, transparent);
  border-color: color-mix(in srgb, var(--brand-accent) 35%, transparent);
  color: var(--brand-accent-soft);
}

.charity-manager__hint--info {
  color: var(--brand-accent-soft);
}

.charity-manager__hint {
  font-size: 0.78rem;
  color: rgba(154, 164, 160, 0.85);
  margin-bottom: 4px;
}

.charity-manager__list {
  background: rgba(5, 5, 5, 0.82);
  border: 1px solid var(--brand-border-strong);
  border-radius: 16px;
  padding: 16px;
  max-height: 420px;
  overflow: auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.charity-manager__list ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.charity-manager__empty {
  text-align: center;
  font-size: 0.85rem;
  padding: 24px 12px;
  color: rgba(154, 164, 160, 0.74);
}

.charity-manager__item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(27, 27, 27, 0.9);
  background: rgba(12, 12, 12, 0.9);
  transition: border-color 0.2s ease, transform 0.2s ease;
}
.charity-manager__item.is-editing {
  border-color: color-mix(in srgb, var(--brand-accent) 55%, transparent);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--brand-accent) 35%, transparent),
    0 12px 24px rgba(18, 82, 54, 0.35);
}

.charity-manager__item:hover {
  border-color: color-mix(in srgb, var(--brand-accent) 30%, transparent);
  transform: translateY(-1px);
}

.charity-manager__item.is-active {
  border-color: color-mix(in srgb, var(--brand-accent) 55%, transparent);
  box-shadow: 0 12px 28px color-mix(in srgb, var(--brand-accent) 24%, transparent);
}

.charity-manager__logo,
.charity-manager__avatar {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  border: 1px solid rgba(29, 29, 29, 0.9);
  object-fit: cover;
  flex: 0 0 auto;
}

.charity-manager__avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, color-mix(in srgb, var(--brand-accent) 20%, transparent), color-mix(in srgb, var(--brand-accent-contrast) 90%, transparent));
  color: var(--brand-accent-soft);
  font-weight: 600;
  font-size: 1.1rem;
}

.charity-manager__details {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.charity-manager__details strong {
  font-size: 0.95rem;
  color: var(--brand-text-primary);
}

.charity-manager__address {
  font-family: var(--brand-font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.04em;
  color: rgba(186, 198, 191, 0.8);
  word-break: break-all;
}

.charity-manager__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  font-size: 0.74rem;
}

.charity-manager__vote {
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(63, 145, 104, 0.16);
  color: var(--brand-accent-soft);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.charity-manager__badge {
  padding: 4px 10px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--brand-accent) 18%, transparent);
  color: var(--shell-accent);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.charity-manager__actions {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 8px;
}

.charity-manager__edit {
  border: 1px solid var(--brand-border);
  background: rgba(20, 20, 20, 0.85);
  color: var(--shell-text-secondary);
  padding: 6px 14px;
  border-radius: 999px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.68rem;
  cursor: pointer;
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.charity-manager__edit:hover:not([disabled]) {
  border-color: color-mix(in srgb, var(--brand-accent) 65%, transparent);
  color: var(--shell-accent);
  background: rgba(28, 28, 28, 0.95);
}

.charity-manager__edit[disabled] {
  opacity: 0.6;
  cursor: default;
}

.charity-manager__activate {
  border: 1px solid color-mix(in srgb, var(--brand-accent) 45%, transparent);
  background: rgba(12, 48, 30, 0.6);
  color: var(--brand-accent-soft);
  padding: 6px 14px;
  border-radius: 999px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.68rem;
  transition: background 0.15s ease, border-color 0.15s ease;
}

.charity-manager__activate:hover:not([disabled]) {
  border-color: color-mix(in srgb, var(--brand-accent) 70%, transparent);
  background: rgba(20, 72, 44, 0.85);
}

.charity-manager__activate[disabled] {
  opacity: 0.6;
  cursor: wait;
}

@media (max-width: 980px) {
  .charity-manager__grid {
    grid-template-columns: 1fr;
  }

  .charity-manager__list {
    max-height: none;
  }
}

.admin-panel__heading {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: clamp(12px, 1.8vw, 16px);
}

.admin-panel__heading h2 {
  margin: 0;
  font-size: clamp(1.05rem, 1.9vw, 1.3rem);
  font-weight: 600;
}

.admin-panel__heading p {
  margin: 4px 0 0;
}

.admin-panel--moderation {
  gap: clamp(12px, 1.8vw, 18px);
}

.admin-access {
  margin-top: 6px;
  display: flex;
  justify-content: flex-start;
}

.admin-login-card {
  background: var(--brand-surface);
  border: 1px solid var(--brand-border);
  border-radius: 18px;
  padding: clamp(16px, 3vw, 24px);
  max-width: 320px;
  display: grid;
  gap: 14px;
  box-shadow: 0 16px 28px rgba(0, 0, 0, 0.45);
}

.admin-login-card h3 {
  margin: 0;
  font-size: 1.1rem;
  font-weight: 600;
}

.admin-login-subtext {
  margin: 0;
  color: var(--shell-text-secondary); opacity: 0.7;
  font-size: 0.9rem;
}

.admin-login-card label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 0.85rem;
  color: var(--shell-text-secondary);
}

.admin-login-card label span {
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.7rem;
  color: var(--brand-text-muted);
}

.admin-login-card input {
  border-radius: 12px;
  border: 1px solid var(--brand-border-strong);
  background: var(--brand-surface-alt);
  color: var(--brand-text-primary);
  padding: 10px 12px;
}

.admin-login-card button {
  border: none;
  border-radius: 12px;
  padding: 10px 18px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  background: var(--brand-accent);
  color: var(--brand-accent-contrast);
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.admin-login-card button:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.admin-login-card button:not(:disabled):hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 24px color-mix(in srgb, var(--brand-accent) 28%, transparent);
}

.admin-login-error {
  background: color-mix(in srgb, var(--brand-danger) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--brand-danger) 30%, transparent);
  color: var(--brand-danger-soft);
  padding: 8px 12px;
  border-radius: 12px;
  font-size: 0.85rem;
}

.admin-session-chip {
  background: var(--brand-surface);
  border: 1px solid var(--brand-border);
  border-radius: 18px;
  padding: 14px 16px;
  display: flex;
  align-items: center;
  gap: 18px;
  box-shadow: 0 16px 28px rgba(0, 0, 0, 0.45);
}

.admin-session-label {
  display: block;
  text-transform: uppercase;
  font-size: 0.68rem;
  letter-spacing: 0.16em;
  color: var(--brand-text-muted);
  margin-bottom: 4px;
}

.admin-session-chip strong {
  font-size: 1rem;
  color: var(--brand-accent-soft);
}

.admin-session-actions {
  display: flex;
  gap: 10px;
}

.admin-session-actions .secondary {
  border: 1px solid var(--brand-border-strong);
  background: transparent;
  color: var(--shell-text-secondary);
  border-radius: 12px;
  padding: 8px 14px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-size: 0.72rem;
  cursor: pointer;
}

.admin-session-actions .secondary:hover {
  border-color: var(--shell-accent);
  color: var(--shell-accent);
}

.admin-overlay {
  position: fixed;
  inset: 0;
  background: rgba(6, 8, 10, 0.86);
  backdrop-filter: blur(12px);
  display: flex;
  justify-content: center;
  align-items: flex-start;
  padding: clamp(18px, 5vw, 36px);
  z-index: 999;
  overflow-y: auto;
}

.admin-panel {
  width: min(1280px, 100%);
  background: var(--brand-surface-alt);
  border: 1px solid var(--brand-border-strong);
  border-radius: 22px;
  box-shadow: 0 34px 80px rgba(0, 0, 0, 0.55);
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding: clamp(18px, 2.4vw, 28px);
  color: var(--brand-text-primary);
}

.admin-panel__topbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.admin-panel__brand {
  display: flex;
  align-items: center;
  gap: 14px;
  font-weight: 600;
  font-size: clamp(1.1rem, 2vw, 1.4rem);
  letter-spacing: 0.02em;
}

.admin-panel__brand-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: clamp(96px, 10vw, 120px);
  height: clamp(34px, 6vw, 44px);
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--brand-accent) 45%, transparent);
  background: radial-gradient(circle at 30% 30%, color-mix(in srgb, var(--brand-accent) 55%, transparent), color-mix(in srgb, var(--brand-accent-contrast) 95%, transparent));
  color: var(--brand-accent-soft);
  font-family: var(--brand-font-mono);
  letter-spacing: 0.16em;
  font-size: 0.8rem;
}

.admin-panel__status {
  padding: 8px 16px;
  border-radius: 999px;
  background: var(--brand-surface-alt);
  border: 1px solid var(--brand-border-strong);
  color: var(--brand-text-primary);
  font-size: 0.82rem;
  display: inline-flex;
  gap: 10px;
  align-items: center;
}

.admin-panel__status[data-state="connected"] {
  border-color: var(--shell-accent);
  color: var(--shell-accent);
}

.admin-panel__status small {
  font-size: 0.72rem;
  color: rgba(211, 243, 226, 0.8);
}

.admin-panel__close {
  border: 1px solid var(--brand-border-strong);
  background: transparent;
  color: var(--brand-text-primary);
  border-radius: 14px;
  padding: 10px 18px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
}

.admin-panel__layout {
  display: grid;
  grid-template-columns: minmax(240px, 320px) minmax(0, 1.75fr) minmax(240px, 1fr);
  gap: clamp(16px, 2vw, 20px);
}

.admin-panel__section {
  background: var(--brand-surface-alt);
  border: 1px solid var(--brand-border);
  border-radius: 18px;
  padding: clamp(14px, 2vw, 18px);
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-height: 0;
  box-shadow: 0 16px 30px rgba(0, 0, 0, 0.26);
}

.admin-panel__muted {
  margin: 0;
  color: rgba(172, 191, 230, 0.75);
  font-size: 0.85rem;
}

@keyframes terminalPulse {
  0%,
  100% {
    box-shadow: 0 0 6px rgba(3, 255, 10, 0.2);
    opacity: 0.9;
  }
  50% {
    box-shadow: 0 0 18px rgba(3, 255, 10, 0.45);
    opacity: 1;
  }
}

@keyframes terminalMarquee {
  0% {
    transform: translateX(5%);
  }
  100% {
    transform: translateX(-105%);
  }
}

@keyframes terminalType {
  0% {
    width: 0;
  }
  60% {
    width: 100%;
  }
  100% {
    width: 0;
  }
}

@keyframes terminalLineGlow {
  0%,
  100% {
    border-color: color-mix(in srgb, var(--brand-textMuted, #94ffce) 30%, transparent);
  }
  50% {
    border-color: color-mix(in srgb, var(--brand-accent, #57ff9c) 35%, transparent);
  }
}

@media (prefers-reduced-motion: reduce) {
  .terminal-badge,
  .terminal-marquee-text,
  .terminal-type-line,
  .terminal-log li {
    animation: none;
  }
}

.admin-panel__form {
  display: flex;
  flex-direction: column;
  gap: 14px;
  overflow-y: auto;
  padding-right: 4px;
}

.admin-panel__form label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 0.82rem;
  color: rgba(255, 255, 255, 0.78);
}

.admin-panel__form label span {
  text-transform: uppercase;
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  color: rgba(255, 255, 255, 0.55);
}

.admin-panel__form input,
.admin-panel__form textarea {
  border-radius: 12px;
  border: 1px solid var(--brand-border-strong);
  background: #0f1116;
  color: var(--brand-text-primary);
  padding: 10px 12px;
  font-family: inherit;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.admin-panel__form textarea {
  min-height: 96px;
  resize: vertical;
}

.admin-panel__form input:focus,
.admin-panel__form textarea:focus {
  outline: none;
  border-color: var(--shell-accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--brand-accent) 25%, transparent);
}

.admin-panel__checkbox {
  flex-direction: row !important;
  align-items: center;
  justify-content: space-between;
}

.admin-panel__checkbox input[type="checkbox"] {
  width: 20px;
  height: 20px;
  margin: 0;
  accent-color: var(--shell-accent);
}

.admin-panel__button-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.admin-panel__button-row button {
  border: none;
  border-radius: 12px;
  padding: 10px 16px;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  cursor: pointer;
  background: var(--brand-accent);
  color: var(--brand-accent-contrast);
}

.admin-panel__button-row button.secondary {
  background: transparent;
  border: 1px solid var(--brand-border);
  color: var(--brand-text-primary);
}

.admin-panel__button-row button.secondary:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.admin-panel__art {
  display: flex;
  justify-content: center;
  padding-top: 10px;
}

.admin-panel__art img {
  max-width: 240px;
  width: 100%;
  border-radius: 16px;
  border: 1px solid var(--brand-border);
}

.admin-panel__chat {
  grid-column: 2;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 14px;
}

.admin-panel__messages {
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 12px;
  background: var(--brand-surface-alt);
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--brand-accent) 25%, transparent);
  box-shadow: inset 0 14px 28px rgba(0, 0, 0, 0.45);
  font-family: var(--brand-font-mono);
}

.admin-panel__message {
  background: color-mix(in srgb, var(--brand-accent-contrast) 85%, transparent);
  border-radius: 12px;
  padding: 12px;
  box-shadow: inset 0 0 18px rgba(85, 210, 146, 0.06), 0 18px 40px rgba(8, 11, 10, 0.55);
}

.admin-panel__message.is-flagged {
  border: 1px solid color-mix(in srgb, var(--brand-danger) 55%, transparent);
}

.admin-panel__message-head {
  display: flex;
  gap: 8px;
  font-size: 0.75rem;
  color: rgba(124, 231, 177, 0.8);
  margin-bottom: 6px;
  align-items: center;
}

.admin-panel__message-head time {
  margin-left: auto;
  opacity: 0.7;
}

.admin-panel__message-body {
  font-size: 0.85rem;
  margin: 0 0 10px;
  color: var(--brand-accent-soft);
}

.admin-panel__message-actions {
  display: inline-flex;
  gap: 8px;
}

.admin-panel__message-actions button {
  border-radius: 8px;
  padding: 6px 10px;
  font-size: 0.7rem;
  letter-spacing: 0.02em;
  background: transparent;
  cursor: pointer;
}

.admin-panel__message-actions .danger {
  border: 1px solid var(--brand-danger-soft);
  color: var(--brand-danger-soft);
}

.admin-panel__message-actions .warning {
  border: 1px solid var(--brand-warning);
  color: var(--brand-warning);
}

.admin-panel__send {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
}

.admin-panel__send textarea {
  min-height: 60px;
  border-radius: 12px;
  border: 1px solid var(--brand-border-strong);
  background: #0f1116;
  color: var(--brand-text-primary);
  padding: 10px 12px;
}

.admin-panel__send button {
  border-radius: 12px;
  border: none;
  background: var(--brand-accent);
  color: var(--brand-accent-contrast);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight: 600;
  padding: 10px 18px;
  cursor: pointer;
}

.admin-panel__log {
  grid-column: 3;
}

.admin-panel__log-stream {
  flex: 1 1 auto;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.admin-panel__log-entry {
  background: #0f1116;
  border-radius: 12px;
  border: 1px solid var(--brand-border-strong);
  padding: 12px;
  display: grid;
  gap: 8px;
  font-family: var(--brand-font-mono);
}

.admin-panel__log-entry header {
  display: flex;
  justify-content: space-between;
  font-size: 0.78rem;
  color: rgba(221, 231, 235, 0.8);
}

.admin-panel__log-entry pre {
  margin: 0;
  font-size: 0.72rem;
  background: var(--brand-surface-alt);
  padding: 8px;
  border-radius: 10px;
  border: 1px solid var(--brand-border-strong);
  color: var(--brand-accent-soft);
  overflow-x: auto;
}

.admin-panel__empty {
  background: #0f1116;
  border-radius: 12px;
  border: 1px dashed var(--brand-border-strong);
  padding: 16px;
  text-align: center;
  color: rgba(207, 216, 219, 0.6);
  font-size: 0.85rem;
}

@media (max-width: 1200px) {
  .admin-panel__layout {
    grid-template-columns: minmax(0, 1fr);
  }
  .admin-panel__chat {
    grid-column: 1;
  }
  .admin-panel__log {
    grid-column: 1;
  }
  .admin-panel__send {
    grid-template-columns: 1fr;
  }
}
.terminal-hero-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: clamp(16px, 2vw, 24px);
}

.terminal-hero-card {
  border: 1px solid color-mix(in srgb, var(--brand-accent, #57ff9c) 18%, transparent);
  background: linear-gradient(135deg, rgba(5, 15, 10, 0.85), rgba(3, 9, 6, 0.5));
  padding: 16px;
  border-radius: 14px;
  position: relative;
  overflow: hidden;
}

.terminal-hero-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, color-mix(in srgb, var(--brand-accent, #57ff9c) 25%, transparent), transparent 60%);
  opacity: 0.12;
  pointer-events: none;
}

.terminal-hero-label {
  margin: 0;
  font-size: 0.72rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--brand-textSecondary, #94ffce);
}

.terminal-hero-value {
  margin: 6px 0;
  font-size: clamp(2rem, 6vw, 3.4rem);
  letter-spacing: 0.15em;
  color: var(--brand-accent, #57ff9c);
  text-shadow: 0 0 20px color-mix(in srgb, var(--brand-accent, #57ff9c) 45%, transparent);
}

.terminal-hero-caption {
  margin: 0;
  font-size: 0.75rem;
  color: var(--brand-text-muted, #94ffce);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.terminal-hero-card--eligibility {
  border-color: color-mix(in srgb, var(--brand-warning, #f7b955) 25%, transparent);
}

.terminal-hero-chip {
  display: inline-block;
  margin-top: 10px;
  padding: 4px 12px;
  border-radius: 999px;
  border: 1px dashed color-mix(in srgb, var(--brand-warning, #f7b955) 40%, transparent);
  text-transform: uppercase;
  font-size: 0.6rem;
  letter-spacing: 0.3em;
  color: var(--brand-warning, #f7b955);
}

.terminal-marquee {
  margin-top: 4px;
  border: 1px solid color-mix(in srgb, var(--brand-accent, #57ff9c) 20%, transparent);
  border-radius: 14px;
  background: linear-gradient(90deg, rgba(2, 9, 6, 0.85), rgba(2, 5, 4, 0.65));
  padding: 14px 18px;
  display: flex;
  gap: 12px;
  align-items: center;
  overflow: hidden;
  position: relative;
}

.terminal-marquee-label {
  font-size: 0.72rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--brand-warning, #f7b955);
}

.terminal-marquee-text {
  font-size: 0.88rem;
  color: var(--brand-text-primary, #57ff9c);
  white-space: nowrap;
  animation: terminalMarquee 18s linear infinite;
}

.terminal-marquee::after {
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  width: 60px;
  background: linear-gradient(90deg, transparent, rgba(0, 0, 0, 0.8));
}
.challenge-card-wrapper {
  margin: 2rem auto;
}

.challenge-card {
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(8, 11, 20, 0.92);
  padding: 1.5rem;
  box-shadow: 0 25px 60px rgba(0, 0, 0, 0.35);
  color: var(--brand-text-primary, #f5f7fa);
}

.challenge-card--professional {
  background: var(--brand-surface, rgba(8, 11, 20, 0.92));
}

.challenge-card--terminal {
  border-color: rgba(0, 255, 247, 0.25);
  background: rgba(3, 10, 18, 0.95);
}

.challenge-card__head h3 {
  margin: 0.4rem 0 0;
  font-size: calc(1.5rem * var(--brand-text-scale-primary));
}

.challenge-card__eyebrow {
  text-transform: uppercase;
  font-family: var(--brand-font-heading);
  font-size: calc(0.75rem * var(--brand-text-scale-primary));
  letter-spacing: 0.1em;
  color: var(--brand-text-secondary, #9aa29b);
}

.challenge-card__countdown {
  margin: 0.25rem 0 0;
  font-size: 0.9rem;
  color: var(--brand-text-secondary, #9aa29b);
}

.challenge-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1rem;
  font-size: 0.85rem;
  color: var(--brand-text-secondary, #9aa29b);
}

.challenge-card__reward {
  padding: 0.15rem 0.9rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
}

.challenge-card--terminal .challenge-card__reward {
  background: rgba(0, 255, 247, 0.1);
}

.challenge-card__answers {
  margin: 1.25rem 0 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 0.9rem;
}

.challenge-card__answer {
  padding: 0.85rem 1rem;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.02);
}

.challenge-card--terminal .challenge-card__answer {
  border-color: rgba(0, 255, 247, 0.2);
  background: rgba(0, 0, 0, 0.5);
}

.challenge-card__answer-label {
  margin: 0 0 0.35rem;
  font-weight: 600;
}

.challenge-card__answer-command {
  font-family: var(--brand-font-mono);
  font-size: 0.85rem;
  color: var(--brand-accent, #03ff0a);
}

.challenge-card--terminal .challenge-card__answer-command {
  color: #00f5ff;
}

.challenge-card__footer {
  margin-top: 1rem;
  font-size: 0.85rem;
  color: var(--brand-text-secondary, #9aa29b);
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 1rem;
}

.challenge-card__footer-right {
  margin: 0;
  font-size: 0.78rem;
  color: rgba(255, 255, 255, 0.65);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.pro-challenge {
  margin: 2rem 0 1rem;
}

.terminal-challenge-wrapper {
  margin: 1.5rem 0 2rem;
}

.challenge-card--terminal .challenge-card__eyebrow {
  color: #00f5ff;
}

@media (max-width: 1100px) {
  .challenge-card-wrapper {
    margin: 1.5rem 1rem;
  }

  .challenge-card {
    padding: 1.25rem;
  }
}

.challenge-result-card {
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(12, 15, 24, 0.95);
  padding: 1.15rem 1.35rem;
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.35);
}

.challenge-result-eyebrow {
  margin: 0 0 0.35rem;
  font-family: var(--brand-font-heading);
  font-size: calc(0.7rem * var(--brand-text-scale-primary));
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--brand-text-secondary, #9aa29b);
}

.challenge-result-card h4 {
  margin: 0;
  font-size: calc(1.2rem * var(--brand-text-scale-primary));
  color: var(--brand-text-primary, #f5f7fa);
}

.challenge-result-body {
  margin: 0.35rem 0 0;
  font-size: 0.92rem;
  color: var(--brand-text-secondary, #9aa29b);
}

.terminal-challenge-wrapper .challenge-result-card {
  border-color: rgba(0, 255, 247, 0.25);
  background: rgba(0, 0, 0, 0.55);
}

.challenge-payout-card {
  border-radius: 16px;
  border: 1px solid rgba(16, 196, 255, 0.2);
  background: rgba(5, 11, 22, 0.95);
  padding: 1rem 1.25rem;
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.3);
}

.challenge-payout-eyebrow {
  margin: 0 0 0.3rem;
  font-family: var(--brand-font-heading);
  font-size: calc(0.68rem * var(--brand-text-scale-primary));
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(16, 196, 255, 0.9);
}

.challenge-payout-card h4 {
  margin: 0;
  font-size: calc(1.1rem * var(--brand-text-scale-primary));
  color: var(--brand-text-primary, #f5f7fa);
}

.challenge-payout-body {
  margin: 0.25rem 0;
  font-size: 0.9rem;
  color: var(--brand-text-secondary, #9aa29b);
}

.challenge-payout-footer {
  margin: 0.25rem 0 0;
  font-size: 0.75rem;
  color: var(--brand-text-secondary, #9aa29b);
}

.challenge-payout-footer a {
  color: var(--brand-accent, #4cc9ff);
}

#challenge-overlay {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  z-index: 9999;
  max-width: 320px;
  width: calc(100vw - 2rem);
}

#challenge-overlay.hidden {
  display: none;
}

.challenge-overlay-card {
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(7, 9, 15, 0.95);
  color: #f5f7fa;
  box-shadow: 0 20px 45px rgba(0, 0, 0, 0.4);
  padding: 1rem 1.1rem;
  font-family: var(--brand-font-secondary);
}

.challenge-overlay-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.5rem;
}

.challenge-overlay-eyebrow {
  text-transform: uppercase;
  font-family: var(--brand-font-heading);
  font-size: calc(0.68rem * var(--brand-text-scale-primary));
  letter-spacing: 0.2em;
  color: #9aa29b;
}

.challenge-overlay-dismiss {
  background: transparent;
  border: none;
  color: #9aa29b;
  font-size: 1.1rem;
  cursor: pointer;
  padding: 0.1rem 0.35rem;
}

.challenge-overlay-body {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.challenge-overlay-muted {
  color: #9aa29b;
  margin: 0;
  font-size: 0.85rem;
}

.challenge-overlay-answers {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.challenge-overlay-answer {
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  padding: 0.65rem 0.75rem;
  background: rgba(255, 255, 255, 0.02);
}

.challenge-overlay-answer p {
  margin: 0;
  font-weight: 600;
}

.challenge-overlay-command {
  font-family: var(--brand-font-mono);
  font-size: 0.85rem;
  color: #03ff0a;
}

.challenge-overlay-result {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  padding-top: 0.65rem;
}
@media (max-width: 1100px) {
  body[data-template="simple"] .header-top {
    flex-direction: column;
    align-items: stretch;
    text-align: center;
    gap: 16px;
  }

  body[data-template="simple"] .brand-logo {
    align-self: center;
  }

  body[data-template="simple"] .primary-nav-wrap {
    width: 100%;
    flex-direction: column;
    align-items: stretch;
    justify-content: center;
    gap: 12px;
    margin-left: 0;
  }

  body[data-template="simple"] .primary-nav {
    width: 100%;
    justify-content: center;
    gap: 12px;
    flex-wrap: wrap;
  }

  body[data-template="simple"] .nav-link {
    flex: 1 1 calc(50% - 12px);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 12px;
    text-align: center;
  }

  body[data-template="simple"] .nav-link.nav-link-social {
    flex: 0 0 auto;
    padding: 10px;
  }

  body[data-template="simple"] .nav-cta {
    width: 100%;
    margin-left: 0;
    justify-content: center;
    padding: 12px;
  }
}

@media (max-width: 1100px) {
  body[data-template="simple"] #root {
    padding: 0 clamp(14px, 5vw, 24px);
  }

  body[data-template="simple"] .app,
  .app[data-template="simple"] {
    gap: 16px;
    padding: clamp(18px, 4vw, 26px);
    border-radius: 18px;
    box-shadow: 0 22px 60px rgba(0, 0, 0, 0.35);
    background: color-mix(in srgb, var(--brand-surface, #0b0b0b) 90%, #050505 10%);
  }

  body[data-template="simple"] .header-grid,
  .app[data-template="simple"] .header-grid {
    --header-grid-template: 1fr;
    grid-template-columns: 1fr;
    gap: 16px;
  }

  body[data-template="simple"] .header-card,
  .app[data-template="simple"] .header-card {
    min-height: auto;
  }

  body[data-template="simple"] .header-card-support--expanded,
  .app[data-template="simple"] .header-card-support--expanded {
    grid-template-columns: 1fr;
  }

  body[data-template="simple"] .support-meta,
  .app[data-template="simple"] .support-meta {
    flex-direction: row;
    gap: 12px;
    width: 100%;
  }

  body[data-template="simple"] .support-meta-row,
  .app[data-template="simple"] .support-meta-row {
    flex: 1 1 50%;
  }

  body[data-template="simple"] .metric-grid,
  .app[data-template="simple"] .metric-grid {
    grid-template-columns: 1fr;
    width: 100%;
  }

  body[data-template="simple"] .vote-sections,
  .app[data-template="simple"] .vote-sections {
    flex-direction: column;
  }

  body[data-template="simple"] .how-it-works,
  .app[data-template="simple"] .how-it-works {
    flex-direction: column;
    width: 100%;
  }

  body[data-template="simple"] .charity-vote-row,
  .app[data-template="simple"] .charity-vote-row {
    grid-template-columns: 1fr;
  }

  body[data-template="simple"] .log-region,
  .app[data-template="simple"] .log-region {
    flex-direction: column;
  }

  body[data-template="simple"] .log-panel,
  .app[data-template="simple"] .log-panel {
    width: 100%;
  }

  body[data-template="simple"] .donations-section,
  .app[data-template="simple"] .donations-section {
    margin-top: 16px;
  }
}

@media (max-width: 1100px) {
  body[data-template="simple"] .charity-vote-card,
  .app[data-template="simple"] .charity-vote-card {
    min-height: auto;
    padding: 14px;
  }

  body[data-template="simple"] .charity-vote-body,
  .app[data-template="simple"] .charity-vote-body {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  body[data-template="simple"] .charity-vote-logo,
  .app[data-template="simple"] .charity-vote-logo {
    max-width: 160px;
    width: 70%;
    justify-self: flex-start;
  }

  body[data-template="simple"] .charity-vote-command,
  .app[data-template="simple"] .charity-vote-command {
    letter-spacing: 0.16em;
    font-size: 1rem;
    white-space: normal;
  }
}

@media (max-width: 1100px) {
  body[data-template="simple"] .primary-nav {
    flex-direction: column;
  }

  body[data-template="simple"] .nav-link {
    flex: 1 1 100%;
  }

  body[data-template="simple"] .nav-cta {
    padding: 12px 16px;
  }
}
.admin-modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(5, 5, 5, 0.72);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(12px, 4vw, 32px);
  z-index: 999;
}

.admin-modal {
  width: min(520px, 100%);
  max-height: 90vh;
  overflow-y: auto;
  background: var(--brand-surface);
  border: 1px solid var(--brand-border);
  border-radius: 20px;
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.6);
  padding: clamp(16px, 3vw, 28px);
}

.admin-modal--project-picker {
  width: min(640px, 100%);
}

.admin-modal__header {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
}

.admin-modal__eyebrow {
  font-family: var(--brand-font-primary);
  font-size: calc(0.72rem * var(--brand-text-scale-primary));
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--brand-text-muted);
  margin: 0 0 4px 0;
}

.admin-modal__muted {
  color: var(--brand-text-muted);
  margin: 4px 0 0;
  line-height: 1.4;
}

.admin-modal__header .link {
  border: none;
  background: none;
  color: var(--shell-text-secondary);
  text-decoration: underline;
  cursor: pointer;
  padding: 0;
}

.pump-modal {
  width: min(860px, 100%);
}

.pump-modal-form textarea {
  width: 100%;
  min-height: 90px;
  resize: vertical;
}

.pump-modal-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 12px;
}

.pump-modal-drop {
  border: 1px dashed var(--shell-border);
  border-radius: 14px;
  padding: 16px;
  text-align: center;
  background: color-mix(in srgb, var(--brand-surface) 70%, transparent);
  color: var(--brand-text-secondary);
  cursor: pointer;
  position: relative;
  overflow: hidden;
}

.pump-modal-drop input[type="file"] {
  opacity: 0;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  cursor: pointer;
}

.pump-modal-drop small {
  display: block;
  margin-top: 6px;
  color: var(--brand-text-muted);
}

.pump-modal-preview {
  margin: 10px 0 4px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.pump-modal-preview__frame {
  width: 100%;
  height: 180px;
  border: 1px solid var(--shell-border);
  border-radius: 12px;
  overflow: hidden;
  background: var(--shell-surface-alt);
  display: flex;
  align-items: center;
  justify-content: center;
}

.pump-modal-preview__frame img {
  max-height: 100%;
  max-width: 100%;
  object-fit: contain;
  display: block;
}

.pump-modal__help {
  display: block;
  color: var(--brand-text-muted);
  margin-top: 6px;
}

.pump-modal-actions {
  justify-content: space-between;
}

.project-picker-search {
  display: flex;
  gap: 8px;
  margin-bottom: 12px;
}

.project-picker-search input {
  flex: 1;
  border-radius: 12px;
  border: 1px solid var(--shell-border-strong);
  background: var(--shell-surface-alt);
  color: var(--shell-text-primary);
  padding: 10px 14px;
}

.project-picker-search button {
  border-radius: 12px;
  border: 1px solid var(--brand-border);
  background: transparent;
  color: var(--brand-text-primary);
  padding: 10px 16px;
  cursor: pointer;
}

.project-picker-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-height: 60vh;
  overflow-y: auto;
}

.project-picker-item {
  border: 1px solid var(--brand-border);
  border-radius: 14px;
  padding: 12px 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  background: color-mix(in srgb, var(--brand-surface) 90%, transparent);
  cursor: pointer;
  transition: border 0.2s ease, transform 0.2s ease;
}

.project-picker-item.is-active {
  border-color: var(--shell-accent);
  background: color-mix(in srgb, var(--shell-accent) 25%, transparent);
  cursor: default;
}

.project-picker-item:disabled {
  opacity: 0.7;
  cursor: default;
}

.project-picker-item:not(.is-active):hover {
  border-color: var(--shell-accent);
  transform: translateY(-1px);
}

.project-picker-item__meta {
  display: flex;
  flex-direction: column;
  gap: 4px;
  text-align: left;
}

.project-picker-item__slug {
  font-size: 0.8rem;
  color: var(--brand-text-muted);
}

.project-picker-empty {
  border: 1px dashed var(--shell-border);
  border-radius: 14px;
  padding: 40px 16px;
  text-align: center;
  color: var(--brand-text-muted);
}

.project-create-form label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 12px;
  font-weight: 600;
}

.project-create-form input {
  border-radius: 12px;
  border: 1px solid var(--shell-border-strong);
  background: var(--shell-surface-alt);
  color: var(--shell-text-primary);
  padding: 10px 12px;
}

.project-create-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 12px;
}

.form-hint {
  font-size: 0.8rem;
  color: var(--brand-text-muted);
}

.form-hint--error {
  color: var(--brand-danger);
}

.form-error {
  border-radius: 12px;
  border: 1px solid var(--shell-border-strong);
  background: color-mix(in srgb, var(--shell-border) 60%, transparent);
  color: var(--brand-text-primary);
  padding: 10px 12px;
  font-size: 0.85rem;
}

.admin-log-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-height: 520px;
  overflow-y: auto;
}

.admin-log {
  border: 1px solid var(--shell-border);
  border-radius: 12px;
  padding: 10px 12px;
  background: var(--brand-surface-alt);
  color: var(--shell-text-primary);
}

.admin-log__meta {
  display: flex;
  gap: 8px;
  font-size: 0.82rem;
  color: var(--shell-text-muted);
}

.admin-log__level {
  font-weight: 700;
  letter-spacing: 0.08em;
}

.admin-log__message {
  margin-top: 4px;
  font-weight: 600;
}

.admin-log__detail {
  margin: 6px 0 0;
  padding: 8px;
  background: var(--brand-surface);
  border-radius: 8px;
  border: 1px solid var(--shell-border);
  color: var(--shell-text-secondary);
  font-size: 0.85rem;
  white-space: pre-wrap;
  word-break: break-word;
}

/* NFT Manager */
.nft-shell .project-console {
  max-width: 1180px;
  margin: 0 auto;
  padding: 20px;
  background: #10121d;
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.35);
}

.nft-shell .project-console__header {
  padding: 0;
  margin-bottom: 16px;
  border: none;
}

.nft-shell .project-console__headercontrols {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.nft-actions {
  display: flex;
  gap: 8px;
  align-items: center;
}

.nft-grid {
  display: grid;
  gap: 16px;
  grid-template-columns: 1fr;
}

.nft-card {
  background: #121526;
  border: 1px solid rgba(255, 255, 255, 0.04);
  border-radius: 14px;
  padding: 16px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.25);
}

.nft-card header h3 {
  margin: 0 0 4px;
}

.nft-card header p {
  margin: 0 0 12px;
}

.nft-card__title {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.nft-form {
  display: grid;
  gap: 12px;
}

.nft-form.two-col {
  grid-template-columns: 1fr;
}

@media (min-width: 980px) {
  .nft-form.two-col {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: start;
  }

  .nft-form.two-col .inline-checkbox,
  .nft-form.two-col .nft-cnft-quick,
  .nft-form.two-col .nft-cnft-presets,
  .nft-form.two-col .nft-cnft-advanced,
  .nft-form.two-col .nft-row-actions,
  .nft-form.two-col .nft-cnft-last {
    grid-column: 1 / -1;
  }
}

.nft-cnft-presets {
  display: grid;
  gap: 8px;
  padding: 12px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.02);
}

.nft-cnft-quick {
  display: grid;
  gap: 12px;
}

@media (min-width: 720px) {
  .nft-cnft-quick {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: start;
  }
}

.nft-cnft-quick strong {
  display: block;
  margin-top: 2px;
  font-weight: 800;
  letter-spacing: 0.04em;
}

.nft-cnft-advanced {
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.02);
  padding: 10px 12px;
}

.nft-cnft-advanced > summary {
  cursor: pointer;
  font-weight: 700;
  color: var(--shell-text-primary);
  user-select: none;
}

.nft-cnft-advanced[open] > summary {
  margin-bottom: 12px;
}

.nft-cnft-advanced .nft-row-actions,
.nft-cnft-advanced__meta {
  grid-column: 1 / -1;
}

.nft-cnft-advanced__meta {
  display: grid;
  gap: 8px;
}

.nft-cnft-last {
  font-size: 0.9rem;
}

.nft-inline-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.mono-link {
  font-family: var(--brand-font-mono);
  font-size: 0.85rem;
  color: color-mix(in srgb, var(--brand-accent) 65%, white);
  text-decoration: none;
}

.mono-link:hover {
  text-decoration: underline;
}

.nft-cnft-presets__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

.nft-cnft-presets__head > span {
  font-weight: 650;
}

.nft-cnft-presets__buttons {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.nft-cnft-preset-button {
  appearance: none;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.06);
  color: var(--shell-text-primary);
  padding: 6px 12px;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 650;
  letter-spacing: 0.02em;
  cursor: pointer;
  white-space: nowrap;
}

.nft-cnft-preset-button.is-active {
  background: color-mix(in srgb, var(--brand-accent) 35%, transparent);
  color: var(--brand-accent-contrast);
  border-color: color-mix(in srgb, var(--brand-accent) 60%, transparent);
}

.nft-cnft-preset-button:hover {
  border-color: rgba(255, 255, 255, 0.2);
}

.nft-form label,
.nft-fields label {
  display: grid;
  gap: 6px;
}

.nft-form input,
.nft-form textarea,
.nft-fields input,
.nft-fields textarea {
  width: 100%;
  background: #0c0e18;
  border: 1px solid rgba(255, 255, 255, 0.08);
  color: var(--shell-text-primary);
  border-radius: 10px;
  padding: 10px;
}

.nft-inline-alert {
  margin-bottom: 12px;
}

.nft-form-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  align-items: center;
}

.nft-form-actions.justify-end {
  justify-content: flex-end;
}

.nft-mode-toggle {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.nft-mode-option {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.03);
  cursor: pointer;
}

.nft-mode-option input {
  width: auto;
  margin: 0;
}

.nft-mode-option span {
  font-weight: 650;
}

.nft-variant-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.nft-variant-card {
  display: grid;
  grid-template-columns: 90px 1fr;
  gap: 12px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 12px;
  padding: 12px;
}

.project-settings-list {
  display: grid;
  gap: 12px;
}

.nft-row {
  align-items: flex-start;
}

.nft-row-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  background: rgba(255, 255, 255, 0.08);
  color: var(--shell-text-primary);
  border-radius: 999px;
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.02em;
}

.nft-mini-actions {
  display: flex;
  gap: 6px;
}

.nft-thumb {
  width: 72px;
  height: 72px;
  border-radius: 10px;
  overflow: hidden;
  background: var(--shell-surface-alt);
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--shell-border);
}

.nft-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.nft-thumb__placeholder {
  font-size: 0.625rem;
  color: var(--shell-text-secondary);
  text-align: center;
  padding: 4px;
}

.nft-fields {
  display: grid;
  gap: 8px;
  flex: 1;
}

.nft-field-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 8px;
}

.nft-row-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.nft-ai-history-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.nft-ai-history-card {
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.02);
}

.nft-ai-history-card__thumb {
  height: 160px;
  background: rgba(255, 255, 255, 0.03);
}

.nft-ai-history-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.nft-ai-history-card__body {
  display: grid;
  gap: 6px;
  padding: 10px;
}

.nft-ai-history-card__body p {
  margin: 0;
  color: var(--shell-text-secondary);
  font-size: 0.9rem;
}

.nft-ai-fallback-card {
  margin-top: 12px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  padding: 12px;
  background: rgba(255, 255, 255, 0.02);
  display: grid;
  gap: 10px;
}

.nft-ai-fallback-card header h4 {
  margin: 0;
}

.nft-ai-fallback-grid {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.nft-style-ref-block {
  display: grid;
  gap: 10px;
}

.nft-style-ref-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}

.nft-style-ref-card {
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 10px;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.02);
}

.nft-style-ref-card__thumb {
  height: 110px;
  background: rgba(255, 255, 255, 0.03);
}

.nft-style-ref-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.nft-style-ref-card__body {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 8px 10px;
}

.nft-style-ref-card__body strong {
  font-size: 0.85rem;
  word-break: break-word;
}

.nft-upload-inline {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border: 1px dashed rgba(255, 255, 255, 0.2);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.03);
  cursor: pointer;
}

.nft-upload-inline input {
  display: none;
}

.nft-upload-inline span {
  font-size: 0.9rem;
  color: var(--shell-text-secondary);
}

.ghost-link {
  color: var(--accent);
  font-weight: 600;
  text-decoration: none;
}

.ghost-link:hover {
  text-decoration: underline;
}

.nft-pool-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-top: 8px;
}

.nft-key-summary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 8px;
  margin-bottom: 8px;
}

.nft-key-chip {
  padding: 8px 10px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.02);
  display: grid;
  gap: 6px;
  align-items: center;
}

.nft-key-chip code {
  word-break: break-all;
  font-size: 0.85rem;
  color: var(--shell-text-primary);
}

.nft-key-chip input {
  width: 100%;
  background: #0c0e18;
  border: 1px solid rgba(255, 255, 255, 0.08);
  color: var(--shell-text-primary);
  border-radius: 8px;
  padding: 8px;
}

.info-dot {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 16px;
  height: 16px;
  margin-left: 6px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.1);
  color: var(--shell-text-secondary);
  font-size: 0.6875rem;
  font-weight: 700;
  cursor: help;
  vertical-align: middle;
}

.info-dot:hover {
  background: rgba(255, 255, 255, 0.2);
  color: var(--shell-text-primary);
}
