/* =============================================================================
   FOXX BOARD STYLES â€“ WEBSITE GOLD/BLACK FINAL PRO
   DATEI: Ghost_Integrations\web\static\styles.css
   =============================================================================
   ZIEL:
   - Premium Finance Look Schwarz / Gold
   - Light Mode wirklich hell/weiß
   - Sidebar + Topbar stabil/fix
   - Board, Admin, Chat, Daily Brief, Signale, Marktanalyse professioneller
   - bessere Lesbarkeit, größere Schrift, klare Gliederung
   - Live-Daten-UI ohne Dummy-Optik
   ============================================================================= */

:root {
  --fox-bg: #050505;
  --fox-bg-2: #0b0b0b;
  --fox-bg-3: #111111;

  --fox-panel: #121212;
  --fox-panel-2: #171717;
  --fox-panel-3: #1d1d1d;
  --fox-panel-4: #232323;

  --fox-text: #f5f5f5;
  --fox-text-soft: #c9c9c9;
  --fox-text-dim: #8d8d8d;
  --fox-text-muted: #6f6f6f;

  --fox-gold: #d4a017;
  --fox-gold-light: #f0c94c;
  --fox-gold-dark: #8c6b10;
  --fox-gold-soft: rgba(212, 160, 23, 0.16);

  --fox-green: #25d366;
  --fox-green-soft: rgba(37, 211, 102, 0.14);

  --fox-red: #ff5f5f;
  --fox-red-soft: rgba(255, 95, 95, 0.14);

  --fox-blue: #4f8cff;
  --fox-blue-soft: rgba(79, 140, 255, 0.13);

  --fox-orange: #ffb347;
  --fox-orange-soft: rgba(255, 179, 71, 0.14);

  --fox-border: rgba(212, 160, 23, 0.26);
  --fox-border-strong: rgba(212, 160, 23, 0.62);
  --fox-border-soft: rgba(255, 255, 255, 0.07);
  --fox-border-white: rgba(255, 255, 255, 0.11);

  --fox-shadow-lg: 0 24px 60px rgba(0, 0, 0, 0.55);
  --fox-shadow-md: 0 14px 34px rgba(0, 0, 0, 0.34);
  --fox-shadow-sm: 0 8px 18px rgba(0, 0, 0, 0.24);

  --fox-glow: 0 0 0 1px rgba(212,160,23,0.20), 0 0 28px rgba(212,160,23,0.16);
  --fox-glow-strong: 0 0 0 1px rgba(212,160,23,0.34), 0 0 38px rgba(212,160,23,0.24);

  --fox-radius-xxl: 34px;
  --fox-radius-xl: 28px;
  --fox-radius-lg: 22px;
  --fox-radius-md: 16px;
  --fox-radius-sm: 12px;

  --sidebar-width: 282px;
  --topbar-height: 88px;
  --content-max: 1640px;

  --font-main: Inter, "Segoe UI", Arial, sans-serif;
}

html[data-theme="light"] {
  --fox-bg: #ffffff;
  --fox-bg-2: #f7f7f7;
  --fox-bg-3: #ffffff;

  --fox-panel: #ffffff;
  --fox-panel-2: #ffffff;
  --fox-panel-3: #f8f8f8;
  --fox-panel-4: #f1f1f1;

  --fox-text: #111111;
  --fox-text-soft: #444444;
  --fox-text-dim: #777777;
  --fox-text-muted: #999999;

  --fox-border: rgba(0, 0, 0, 0.08);
  --fox-border-strong: rgba(212, 160, 23, 0.65);
  --fox-border-soft: rgba(0, 0, 0, 0.06);
  --fox-border-white: rgba(0, 0, 0, 0.08);

  --fox-shadow-lg: 0 24px 60px rgba(0, 0, 0, 0.10);
  --fox-shadow-md: 0 14px 34px rgba(0, 0, 0, 0.08);
  --fox-shadow-sm: 0 8px 18px rgba(0, 0, 0, 0.06);
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
  min-height: 100%;
  color: var(--fox-text);
  font-family: var(--font-main);
  background:
    radial-gradient(circle at 8% 8%, rgba(212,160,23,0.12), transparent 28%),
    radial-gradient(circle at 92% 4%, rgba(212,160,23,0.08), transparent 26%),
    linear-gradient(180deg, var(--fox-bg-2) 0%, var(--fox-bg) 58%, #020202 100%);
  -webkit-font-smoothing: antialiased;
  text-rendering: geometricPrecision;
}

html[data-theme="light"],
html[data-theme="light"] body {
  background: #ffffff;
  color: #111111;
}

body {
  overflow-x: hidden;
}

img {
  max-width: 100%;
  display: block;
}

button,
input,
textarea,
select {
  font: inherit;
}

button {
  cursor: pointer;
}

a {
  color: inherit;
  text-decoration: none;
}

/* =============================================================================
   GLOBAL ELEMENTS
   ============================================================================= */

.panel-glow {
  background:
    linear-gradient(180deg, rgba(212,160,23,0.035), transparent 28%),
    linear-gradient(180deg, var(--fox-panel-2), var(--fox-panel));
  border: 1px solid var(--fox-border);
  border-radius: var(--fox-radius-lg);
  box-shadow: var(--fox-shadow-md);
  position: relative;
  overflow: hidden;
}

.panel-glow::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 0% 0%, rgba(212,160,23,0.10), transparent 32%),
    radial-gradient(circle at 100% 100%, rgba(212,160,23,0.05), transparent 26%);
}

.primary-btn,
.secondary-btn,
.card-open-btn,
.sidebar-support-btn,
.logout-btn,
.auth-submit-btn,
.auth-tab,
.auth-link-btn,
.topbar-icon-btn,
.sidebar-nav-btn,
.tf-chip,
.admin-tab,
.admin-btn,
.admin-action-btn,
.admin-save-btn,
.admin-small-btn {
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease,
    border-color 0.18s ease,
    background 0.18s ease,
    color 0.18s ease;
}

.primary-btn,
.auth-submit-btn,
.sidebar-support-btn {
  border: 1px solid var(--fox-border-strong);
  color: #090909;
  background: linear-gradient(180deg, var(--fox-gold-light), var(--fox-gold));
  border-radius: 14px;
  padding: 13px 18px;
  font-weight: 950;
  box-shadow: 0 12px 26px rgba(212,160,23,0.18);
}

.primary-btn:hover,
.auth-submit-btn:hover,
.sidebar-support-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 16px 32px rgba(212,160,23,0.24);
}

.secondary-btn,
.card-open-btn,
.logout-btn,
.topbar-icon-btn {
  border: 1px solid var(--fox-border);
  color: var(--fox-text);
  background: linear-gradient(180deg, var(--fox-panel-3), var(--fox-panel));
  border-radius: 14px;
}

.secondary-btn:hover,
.card-open-btn:hover,
.logout-btn:hover,
.topbar-icon-btn:hover {
  transform: translateY(-1px);
  border-color: var(--fox-border-strong);
  box-shadow: var(--fox-glow);
}

.global-status-box,
.auth-status-box {
  margin-top: 12px;
  padding: 13px 15px;
  border-radius: 14px;
  font-size: 15px;
  font-weight: 800;
  border: 1px solid var(--fox-border);
  background: var(--fox-panel-3);
}

.auth-status-box[data-type="error"],
.global-status-box[data-type="error"] {
  border-color: rgba(255, 95, 95, 0.45);
  color: #ffd7d7;
  background: rgba(70, 10, 10, 0.75);
}

html[data-theme="light"] .auth-status-box[data-type="error"],
html[data-theme="light"] .global-status-box[data-type="error"] {
  color: #8b0000;
  background: #fff0f0;
}

.auth-status-box[data-type="success"],
.global-status-box[data-type="success"] {
  border-color: rgba(37, 211, 102, 0.42);
  color: #d9ffea;
  background: rgba(8, 48, 24, 0.78);
}

html[data-theme="light"] .auth-status-box[data-type="success"],
html[data-theme="light"] .global-status-box[data-type="success"] {
  color: #075c2b;
  background: #eefff5;
}

/* =============================================================================
   AUTH LOGIN / REGISTER
   ============================================================================= */

.auth-shell {
  position: relative;
  min-height: 100vh;
  padding: 34px;
  display: grid;
  align-items: center;
  overflow: hidden;
}

.auth-bg-glow {
  position: absolute;
  width: 520px;
  height: 520px;
  border-radius: 999px;
  filter: blur(110px);
  opacity: 0.42;
  pointer-events: none;
}

.auth-bg-glow-left {
  top: -150px;
  left: -140px;
  background: rgba(212,160,23,0.20);
}

.auth-bg-glow-right {
  right: -180px;
  bottom: -160px;
  background: rgba(212,160,23,0.12);
}

.auth-wrap {
  position: relative;
  z-index: 2;
  width: min(1180px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(320px, 500px) minmax(340px, 520px);
  gap: 30px;
  align-items: stretch;
}

.auth-brand-card,
.auth-form-card {
  min-height: 620px;
  padding: 36px;
}

.auth-brand-card {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.auth-brand-top {
  display: flex;
  align-items: center;
  gap: 18px;
}

.auth-logo-wrap {
  width: 86px;
  height: 86px;
  border-radius: 24px;
  display: grid;
  place-items: center;
  background: linear-gradient(180deg, var(--fox-panel-3), var(--fox-panel));
  border: 1px solid var(--fox-border);
  box-shadow: var(--fox-glow);
}

.auth-logo-img {
  width: 58px;
  height: 58px;
  object-fit: contain;
}

.auth-brand-main {
  font-size: 40px;
  line-height: 1;
  font-weight: 950;
  letter-spacing: 0.06em;
}

.auth-brand-sub {
  margin-top: 6px;
  font-size: 16px;
  color: var(--fox-text-soft);
  letter-spacing: 0.30em;
  font-weight: 850;
}

.auth-brand-headline {
  margin-top: 36px;
  font-size: 30px;
  font-weight: 950;
  line-height: 1.14;
  max-width: 520px;
}

.auth-brand-copy {
  margin-top: 18px;
  color: var(--fox-text-soft);
  font-size: 17px;
  line-height: 1.75;
  max-width: 520px;
}

.auth-feature-list {
  margin-top: 30px;
  display: grid;
  gap: 14px;
}

.auth-feature-row {
  display: flex;
  align-items: center;
  gap: 11px;
  color: var(--fox-text);
  font-size: 16px;
  line-height: 1.45;
}

.dot {
  width: 9px;
  height: 9px;
  border-radius: 999px;
  display: inline-block;
  flex: 0 0 auto;
}

.dot.green {
  background: var(--fox-green);
  box-shadow: 0 0 12px rgba(37,211,102,0.65);
}

.dot.red {
  background: var(--fox-red);
  box-shadow: 0 0 12px rgba(255,95,95,0.60);
}

.dot.gold {
  background: var(--fox-gold-light);
  box-shadow: 0 0 12px rgba(240,201,76,0.60);
}

.auth-form-card {
  display: flex;
  flex-direction: column;
}

.auth-mode-tabs {
  display: inline-grid;
  grid-auto-flow: column;
  gap: 8px;
  align-self: flex-start;
  padding: 6px;
  border-radius: 16px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--fox-border-soft);
}

.auth-tab {
  min-width: 138px;
  padding: 12px 18px;
  border-radius: 12px;
  border: 1px solid transparent;
  background: transparent;
  color: var(--fox-text-soft);
  font-weight: 850;
}

.auth-tab.active {
  color: #0a0a0a;
  background: linear-gradient(180deg, var(--fox-gold-light), var(--fox-gold));
  border-color: var(--fox-border-strong);
  box-shadow: var(--fox-glow);
}

.auth-form-body {
  margin-top: 30px;
  display: flex;
  flex-direction: column;
  gap: 17px;
}

.auth-title {
  margin: 0;
  font-size: 36px;
  line-height: 1.1;
  font-weight: 950;
}

.auth-subtitle {
  margin: 0 0 8px;
  color: var(--fox-text-soft);
  font-size: 17px;
  line-height: 1.62;
}

.auth-label {
  display: grid;
  gap: 9px;
}

.auth-label > span {
  font-size: 15px;
  color: var(--fox-text-soft);
  font-weight: 850;
}

.auth-input,
.foxx-chat-input {
  width: 100%;
  min-height: 58px;
  padding: 0 17px;
  border-radius: 16px;
  border: 1px solid var(--fox-border);
  background: var(--fox-panel-3);
  color: var(--fox-text);
  outline: none;
}

.auth-input::placeholder,
.foxx-chat-input::placeholder {
  color: var(--fox-text-dim);
}

.auth-input:focus,
.foxx-chat-input:focus {
  border-color: var(--fox-border-strong);
  box-shadow: var(--fox-glow);
}

.auth-submit-btn {
  margin-top: 10px;
  width: 100%;
  min-height: 56px;
}

.auth-footer-note {
  margin-top: 8px;
  color: var(--fox-text-soft);
  font-size: 15px;
}

.auth-link-btn {
  border: 0;
  padding: 0;
  background: transparent;
  color: var(--fox-gold-light);
  font-weight: 950;
}

/* =============================================================================
   APP SHELL / SIDEBAR / TOPBAR
   ============================================================================= */

.app-shell {
  display: grid;
  grid-template-columns: var(--sidebar-width) minmax(0, 1fr);
  min-height: 100vh;
}

.sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  padding: 18px 14px;
  border-right: 1px solid var(--fox-border-soft);
  background:
    linear-gradient(180deg, rgba(212,160,23,0.045), transparent 20%),
    linear-gradient(180deg, #070707, #030303);
  overflow-y: auto;
  overscroll-behavior: contain;
  z-index: 30;
}

html[data-theme="light"] .sidebar {
  background: #ffffff;
  border-right: 1px solid rgba(0,0,0,0.06);
}

.sidebar::-webkit-scrollbar {
  width: 8px;
}

.sidebar::-webkit-scrollbar-thumb {
  background: rgba(212,160,23,0.25);
  border-radius: 999px;
}

.sidebar-brand,
.sidebar-card {
  background: linear-gradient(180deg, var(--fox-panel-2), var(--fox-panel));
  border: 1px solid var(--fox-border);
  border-radius: 22px;
  box-shadow: var(--fox-shadow-sm);
  margin-bottom: 14px;
  overflow: hidden;
}

.sidebar-brand {
  padding: 15px 15px 13px;
}

.sidebar-brand-top {
  display: flex;
  align-items: center;
  gap: 11px;
}

.sidebar-brand-logo {
  width: 56px;
  height: 56px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  background: linear-gradient(180deg, var(--fox-panel-3), var(--fox-panel));
  border: 1px solid var(--fox-border);
}

.brand-logo-img {
  width: 38px;
  height: 38px;
  object-fit: contain;
}

.sidebar-brand-text {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.brand-main {
  font-size: 23px;
  font-weight: 950;
  letter-spacing: 0.04em;
  line-height: 1;
}

.brand-sub {
  margin-top: 4px;
  font-size: 11px;
  color: var(--fox-text-soft);
  letter-spacing: 0.30em;
  font-weight: 850;
}

.sidebar-mini-toggle {
  margin-left: auto;
  width: 38px;
  height: 38px;
  border-radius: 12px;
  border: 1px solid var(--fox-border);
  background: var(--fox-panel-3);
  color: var(--fox-text);
}

.sidebar-brand-tagline {
  margin-top: 11px;
  color: var(--fox-text-soft);
  font-size: 13px;
  line-height: 1.6;
}

.sidebar-card {
  padding: 15px;
}

.sidebar-user-top {
  display: flex;
  align-items: center;
  gap: 12px;
}

.sidebar-user-avatar,
.topbar-user-avatar {
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid var(--fox-border);
  background: var(--fox-panel-3);
}

.sidebar-user-avatar {
  width: 50px;
  height: 50px;
}

.sidebar-user-avatar-img,
.topbar-user-avatar-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sidebar-user-name {
  font-size: 19px;
  font-weight: 950;
}

.sidebar-user-plan {
  margin-top: 3px;
  color: var(--fox-text-soft);
  font-size: 14px;
}

.sidebar-mini-stats,
.plan-benefits {
  margin-top: 15px;
  display: grid;
  gap: 9px;
}

.sidebar-mini-row,
.plan-row,
.hero-side-row,
.data-line {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}

.sidebar-mini-row span,
.plan-row span,
.hero-side-row span,
.data-line span {
  color: var(--fox-text-soft);
  font-size: 15px;
}

.sidebar-mini-row strong,
.plan-row strong,
.hero-side-row strong,
.data-line strong {
  color: var(--fox-text);
  font-size: 15px;
  font-weight: 950;
  text-align: right;
}

.sidebar-card-title {
  font-size: 14px;
  color: var(--fox-text-soft);
  letter-spacing: 0.09em;
  font-weight: 950;
  margin-bottom: 12px;
}

.sidebar-nav {
  margin-bottom: 14px;
}

.sidebar-section {
  margin-bottom: 15px;
}

.sidebar-section-title {
  font-size: 13px;
  color: var(--fox-text-dim);
  font-weight: 950;
  letter-spacing: 0.09em;
  margin: 0 8px 8px;
}

.sidebar-section-items {
  display: grid;
  gap: 8px;
}

.sidebar-nav-btn {
  width: 100%;
  min-height: 50px;
  padding: 12px 14px;
  display: flex;
  align-items: center;
  border-radius: 16px;
  border: 1px solid var(--fox-border-soft);
  background: var(--fox-panel);
  color: var(--fox-text);
  text-align: left;
}

.sidebar-nav-btn:hover {
  border-color: var(--fox-border);
  box-shadow: var(--fox-glow);
  transform: translateY(-1px);
}

.sidebar-nav-btn.active {
  border-color: var(--fox-border-strong);
  background:
    linear-gradient(180deg, rgba(212,160,23,0.16), rgba(212,160,23,0.05)),
    var(--fox-panel);
  box-shadow: var(--fox-glow);
}

.sidebar-nav-text {
  font-size: 16px;
  font-weight: 900;
}

.plan-top-line {
  display: flex;
  align-items: center;
  gap: 10px;
}

.plan-badge-wrap {
  width: 38px;
  height: 38px;
  border-radius: 13px;
  display: grid;
  place-items: center;
  border: 1px solid var(--fox-border);
  background: var(--fox-panel-3);
}

.plan-crown-icon {
  width: 22px;
  height: 22px;
  object-fit: contain;
}

.plan-main-text {
  font-size: 19px;
  font-weight: 950;
}

.plan-status {
  margin-left: auto;
  color: var(--fox-green);
  font-size: 14px;
  font-weight: 950;
}

.sidebar-support-btn {
  width: 100%;
  margin-top: 16px;
  min-height: 48px;
}

.app-content {
  min-width: 0;
  display: flex;
  flex-direction: column;
}

.topbar {
  min-height: var(--topbar-height);
  padding: 18px 24px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 18px;
  border-bottom: 1px solid var(--fox-border-soft);
  background: rgba(5,5,5,0.92);
  position: sticky;
  top: 0;
  z-index: 20;
  backdrop-filter: blur(14px);
}

html[data-theme="light"] .topbar {
  background: rgba(255,255,255,0.96);
}

.welcome-line {
  font-size: 27px;
  font-weight: 950;
  line-height: 1.1;
}

.topbar-status-line {
  margin-top: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  color: var(--fox-text-soft);
  font-size: 14px;
}

.status-dot-line {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.topbar-pill {
  padding: 12px 18px;
  min-width: 165px;
  border-radius: 18px;
  border: 1px solid var(--fox-border);
  background: var(--fox-panel);
  box-shadow: var(--fox-shadow-sm);
}

.topbar-pill-title {
  font-size: 13px;
  color: var(--fox-text-soft);
}

.topbar-pill-value {
  margin-top: 4px;
  font-size: 19px;
  font-weight: 950;
}

.topbar-pill-value.live {
  color: var(--fox-green);
}

.topbar-center {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

.foxx-voice-main-btn {
  min-width: 260px;
  min-height: 58px;
  padding: 11px 22px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  border-radius: 18px;
  border: 1px solid rgba(212,160,23,0.58);
  background:
    linear-gradient(180deg, rgba(245,194,45,0.96), rgba(208,151,14,0.96));
  color: #090909;
  box-shadow: 0 14px 34px rgba(212,160,23,0.22);
  cursor: pointer;
}

.foxx-voice-main-btn.active {
  border-color: rgba(34,197,94,0.72);
  background:
    linear-gradient(180deg, rgba(41,228,113,0.96), rgba(19,142,68,0.96));
  box-shadow: 0 14px 34px rgba(34,197,94,0.22);
}

.foxx-voice-main-title {
  font-size: 18px;
  font-weight: 950;
  line-height: 1.1;
}

.foxx-voice-main-sub {
  font-size: 12px;
  font-weight: 900;
  opacity: 0.78;
}

.foxx-voice-test-btn {
  min-height: 58px;
  padding: 0 18px;
  border-radius: 18px;
  border: 1px solid var(--fox-border);
  background: var(--fox-panel);
  color: var(--fox-text);
  font-weight: 950;
  cursor: pointer;
}

.asset-universe-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}

.asset-group-card {
  padding: 14px;
  border-radius: 18px;
}

.asset-pill-grid {
  margin-top: 10px;
  display: grid;
  gap: 8px;
}

.asset-pill {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 9px 10px;
  border-radius: 12px;
  border: 1px solid var(--fox-border-soft);
  background: var(--fox-panel-3);
  font-weight: 900;
}

.asset-pill small {
  color: var(--fox-text-dim);
  font-size: 11px;
  white-space: nowrap;
}

.asset-pill.unlocked {
  border-color: rgba(34,197,94,0.36);
}

.asset-pill.unlocked small {
  color: var(--fox-green);
}

.asset-pill.locked {
  opacity: 0.72;
}

.topbar-right {
  display: flex;
  align-items: center;
  gap: 10px;
}

.topbar-icon-btn {
    width: 43px;
    height: 43px;
    display: grid;
    place-items: center;
    font-weight: 950;
  }

  .topbar-text-btn {
    width: auto;
    min-width: 52px;
    padding: 0 12px;
    font-size: 11px;
    line-height: 1;
  }

.topbar-user-badge {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 16px;
  border: 1px solid var(--fox-border);
  background: var(--fox-panel);
}

.topbar-user-avatar {
  width: 39px;
  height: 39px;
}

.topbar-user-name {
  font-size: 15px;
  font-weight: 950;
}

.topbar-user-role {
  font-size: 12px;
  color: var(--fox-text-soft);
}

.logout-btn {
  min-height: 43px;
  padding: 0 16px;
  font-weight: 900;
}

/* =============================================================================
   MAIN / HERO / DASHBOARD CARDS
   ============================================================================= */

.app-main {
  width: 100%;
  max-width: var(--content-max);
  margin: 0 auto;
  padding: 28px 24px 42px;
}

.hero-section {
  margin-bottom: 20px;
}

.hero-main-card {
  display: grid;
  grid-template-columns: 178px minmax(0, 1fr) 245px;
  gap: 24px;
  align-items: center;
  padding: 28px;
  min-height: 282px;
}

.hero-logo-col {
  display: flex;
  justify-content: center;
}

.hero-logo-ring {
  width: 164px;
  height: 164px;
  border-radius: 999px;
  padding: 12px;
  background: linear-gradient(180deg, var(--fox-panel-3), var(--fox-panel));
  border: 1px solid var(--fox-border);
  box-shadow: var(--fox-glow);
  display: grid;
  place-items: center;
}

.hero-logo-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  border-radius: 999px;
}

.hero-main-headline {
  font-size: clamp(34px, 2.8vw, 56px);
  font-weight: 950;
  line-height: 1.02;
  letter-spacing: 0.01em;
}

.hero-main-headline-accent {
  color: var(--fox-gold);
}

.hero-status-strip {
  margin-top: 18px;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
}

.hero-status-chip {
  min-height: 76px;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid var(--fox-border-soft);
  background: var(--fox-panel-3);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.hero-status-chip span {
  color: var(--fox-text-soft);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.06em;
}

.hero-status-chip strong {
  margin-top: 6px;
  font-size: 25px;
  color: var(--fox-green);
  font-weight: 950;
}

.hero-summary-text {
  margin-top: 17px;
  color: var(--fox-text-soft);
  font-size: 17px;
  line-height: 1.72;
  max-width: 850px;
}

.hero-actions {
  margin-top: 24px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.hero-btn {
  min-height: 50px;
  padding: 0 20px;
  font-weight: 950;
}

.hero-side-card {
  border-radius: 20px;
  border: 1px solid var(--fox-border);
  background: var(--fox-panel-3);
  padding: 19px;
  min-height: 205px;
}

.hero-side-title {
  font-size: 14px;
  color: var(--fox-text-soft);
  letter-spacing: 0.09em;
  font-weight: 950;
  margin-bottom: 15px;
}

.hero-side-list {
  display: grid;
  gap: 13px;
}

.dashboard-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 17px;
}

.dashboard-card,
.news-card,
.admin-card {
  display: flex;
  flex-direction: column;
  min-height: 300px;
  padding: 19px;
  position: relative;
  overflow: hidden;
  background: linear-gradient(180deg, var(--fox-panel-2), var(--fox-panel));
  border: 1px solid var(--fox-border);
  border-radius: 22px;
  box-shadow: var(--fox-shadow-sm);
}

.dashboard-card::after,
.news-card::after,
.admin-card::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-radius: inherit;
  background:
    radial-gradient(circle at 0% 0%, rgba(212,160,23,0.07), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,0.025), transparent 50%);
}

.card-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 16px;
  position: relative;
  z-index: 1;
}

.card-title-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.card-title {
  font-size: 24px;
  font-weight: 950;
  line-height: 1.1;
}

.card-badge {
  min-height: 31px;
  padding: 0 10px;
  border-radius: 999px;
  display: inline-grid;
  place-items: center;
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0.06em;
  border: 1px solid var(--fox-border-soft);
  white-space: nowrap;
}

.card-badge.live {
  color: #dffff0;
  background: rgba(37,211,102,0.16);
  border-color: rgba(37,211,102,0.34);
}

.card-badge.warn {
  color: #fff0c9;
  background: rgba(255,179,71,0.16);
  border-color: rgba(255,179,71,0.34);
}

.card-badge.stop {
  color: #ffd9d9;
  background: rgba(255,95,95,0.16);
  border-color: rgba(255,95,95,0.34);
}

html[data-theme="light"] .card-badge.live {
  color: #075c2b;
  background: #eefff5;
}

.card-subtle {
  color: var(--fox-text-soft);
  font-size: 14px;
  font-weight: 850;
}

.card-description,
.news-card-text {
  color: var(--fox-text-soft);
  font-size: 17px;
  line-height: 1.72;
  position: relative;
  z-index: 1;
}

.card-description strong,
.news-card-text strong {
  color: var(--fox-text);
}

.card-ai-body {
  display: grid;
  grid-template-columns: 92px minmax(0, 1fr);
  gap: 15px;
  align-items: start;
  position: relative;
  z-index: 1;
}

.card-avatar-wrap {
  width: 92px;
  height: 92px;
  border-radius: 999px;
  padding: 6px;
  border: 1px solid var(--fox-border);
  background: var(--fox-panel-3);
  display: grid;
  place-items: center;
  box-shadow: var(--fox-glow);
}

.card-avatar-img {
  width: 100%;
  height: 100%;
  border-radius: 999px;
  object-fit: contain;
}

.big-bias {
  margin-top: 5px;
  font-size: 34px;
  line-height: 1;
  font-weight: 950;
}

.big-bias.bullish {
  color: var(--fox-green);
}

.big-bias.bearish {
  color: #ff7777;
}

.big-bias.neutral {
  color: var(--fox-gold-light);
}

.card-open-btn {
  width: 100%;
  min-height: 46px;
  margin-top: auto;
  padding: 0 16px;
  font-weight: 950;
  position: relative;
  z-index: 2;
}

/* =============================================================================
   DAILY MARKET BRIEF â€“ PROFESSIONAL CARDS
   ============================================================================= */

.daily-brief-home-section {
  margin: 18px 0;
}

.daily-brief-overview {
  margin-bottom: 20px;
}

.daily-brief-card {
  min-height: 360px;
}

.daily-brief-card .card-title {
  font-size: 22px;
}

.daily-brief-macro {
  position: relative;
  z-index: 1;
  padding: 14px 15px;
  border-radius: 16px;
  color: var(--fox-text-soft);
  font-size: 16px;
  line-height: 1.72;
  background:
    linear-gradient(180deg, rgba(212,160,23,0.075), rgba(255,255,255,0.018)),
    var(--fox-panel-3);
  border: 1px solid var(--fox-border-soft);
}

.daily-brief-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-top: 14px;
}

.daily-brief-mini {
  min-height: 76px;
  padding: 12px 10px;
  border-radius: 16px;
  background: var(--fox-panel-3);
  border: 1px solid var(--fox-border-soft);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.daily-brief-mini span {
  display: block;
  color: var(--fox-text-dim);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.daily-brief-mini strong {
  margin-top: 7px;
  display: block;
  color: var(--fox-text);
  font-size: 17px;
  font-weight: 950;
  word-break: break-word;
}

.daily-brief-levels {
  position: relative;
  z-index: 1;
  margin-top: 14px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.daily-brief-levels > div {
  padding: 14px 15px;
  border-radius: 16px;
  background: var(--fox-panel-3);
  border: 1px solid var(--fox-border-soft);
  color: var(--fox-text-soft);
  font-size: 15px;
  line-height: 1.65;
}

.daily-brief-levels strong {
  color: var(--fox-gold-light);
  font-size: 13px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.daily-brief-scenarios {
  position: relative;
  z-index: 1;
  margin-top: 14px;
  padding: 15px;
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.012)),
    var(--fox-panel-3);
  border: 1px solid var(--fox-border-soft);
  display: grid;
  gap: 10px;
  color: var(--fox-text-soft);
  font-size: 15px;
  line-height: 1.65;
}

.daily-brief-scenarios div:nth-child(1) strong {
  color: var(--fox-green);
}

.daily-brief-scenarios div:nth-child(2) strong {
  color: var(--fox-red);
}

.daily-brief-scenarios div:nth-child(3) strong {
  color: var(--fox-orange);
}

.daily-brief-risk {
  position: relative;
  z-index: 1;
  margin-top: 14px;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(255,179,71,0.22);
  color: #ffe1ad;
  background: rgba(255,179,71,0.075);
  font-size: 14px;
  line-height: 1.6;
}

html[data-theme="light"] .daily-brief-risk {
  color: #6b4700;
  background: #fff7e6;
}

/* =============================================================================
   CONTENT ROOMS / FILTERS / NEWS
   ============================================================================= */

.content-section {
  padding: 24px;
  margin-bottom: 17px;
}

.content-section h2,
.content-section h3 {
  margin: 0 0 11px;
  font-size: 31px;
  font-weight: 950;
}

.content-section p {
  margin: 0;
  color: var(--fox-text-soft);
  line-height: 1.72;
  font-size: 17px;
}

.news-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 17px;
}

.news-card {
  min-height: 220px;
}

.news-relevance-high {
  border-color: rgba(230, 67, 67, 0.85);
  box-shadow: 0 0 0 1px rgba(230, 67, 67, 0.18), var(--fox-shadow-sm);
}

.news-relevance-medium {
  border-color: rgba(245, 159, 11, 0.86);
  box-shadow: 0 0 0 1px rgba(245, 159, 11, 0.18), var(--fox-shadow-sm);
}

.news-relevance-low {
  border-color: rgba(34, 197, 94, 0.82);
  box-shadow: 0 0 0 1px rgba(34, 197, 94, 0.16), var(--fox-shadow-sm);
}

.news-relevance-pill {
  position: relative;
  z-index: 1;
  align-self: flex-start;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 950;
  background: rgba(255,255,255,.06);
  border: 1px solid var(--fox-border);
  margin-bottom: 10px;
}

.news-card-title {
  position: relative;
  z-index: 1;
  font-size: 23px;
  font-weight: 950;
  line-height: 1.22;
}

.news-card-meta {
  position: relative;
  z-index: 1;
  margin-top: 9px;
  color: var(--fox-text-dim);
  font-size: 14px;
  font-weight: 850;
}

.news-card-text {
  margin-top: 13px;
}

.news-card-foot {
  position: relative;
  z-index: 1;
  margin-top: auto;
  padding-top: 14px;
  color: var(--fox-gold-light);
  font-size: 15px;
  font-weight: 850;
  line-height: 1.55;
}

.news-card-foot strong {
  color: var(--fox-gold-light);
}

.tf-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  margin: 12px 0 0;
}

.tf-chip {
  min-height: 34px;
  padding: 0 13px;
  border-radius: 999px;
  display: inline-grid;
  place-items: center;
  border: 1px solid var(--fox-border);
  background: var(--fox-panel-3);
  color: var(--fox-text);
  font-size: 14px;
  font-weight: 900;
}

.tf-chip.active {
  background: linear-gradient(180deg, var(--fox-gold-light), var(--fox-gold));
  border-color: var(--fox-border-strong);
  color: #090909;
}

.quote-section {
  margin-top: 19px;
  min-height: 112px;
  padding: 25px;
}

.quote-mark {
  font-size: 34px;
  color: var(--fox-gold);
  font-weight: 950;
}

.quote-main {
  margin-top: 4px;
  font-size: 24px;
  font-weight: 950;
}

.quote-sub {
  margin-top: 9px;
  font-size: 15px;
  color: var(--fox-gold-light);
  font-weight: 850;
}

/* =============================================================================
   MARKTANALYSE â€“ DETAIL VIEW
   ============================================================================= */

.analysis-detail-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(320px, 0.65fr);
  gap: 17px;
  margin-bottom: 17px;
}

.analysis-main-card,
.analysis-level-card {
  padding: 24px;
}

.analysis-main-card h3,
.analysis-level-card h3 {
  margin: 0 0 16px;
  font-size: 27px;
  font-weight: 950;
}

.analysis-explain-box {
  padding: 16px 17px;
  border-radius: 18px;
  margin-bottom: 16px;
  color: var(--fox-text-soft);
  line-height: 1.72;
  font-size: 16px;
  background:
    linear-gradient(180deg, rgba(212,160,23,0.10), rgba(255,255,255,0.015)),
    var(--fox-panel-3);
  border: 1px solid var(--fox-border);
}

.analysis-explain-box strong {
  color: var(--fox-gold-light);
  font-size: 18px;
}

.analysis-metric-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 11px;
  margin-bottom: 16px;
}
.analysis-metric {
  min-height: 84px;
  padding: 13px 12px;
  border-radius: 18px;
  background: var(--fox-panel-3);
  border: 1px solid var(--fox-border-soft);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.analysis-metric span {
  color: var(--fox-text-dim);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.analysis-metric strong {
  margin-top: 7px;
  color: var(--fox-text);
  font-size: 18px;
  font-weight: 950;
}

.analysis-long-text {
  margin-top: 13px;
  padding: 15px 16px;
  border-radius: 18px;
  border: 1px solid var(--fox-border-soft);
  background: var(--fox-panel-3);
  color: var(--fox-text-soft);
  font-size: 15px;
  line-height: 1.72;
}

.analysis-long-text strong {
  color: var(--fox-gold-light);
}

/* =============================================================================
   SIGNAL SYSTEM â€“ PROFESSIONAL BOARD CARDS
   ============================================================================= */

.signal-card-grid {
  align-items: stretch;
}

.signal-board-card {
  min-height: 360px;
  padding: 20px;
  border-color: rgba(212,160,23,0.34);
}

.signal-board-card .news-card-title {
  font-size: 22px;
}

.signal-board-card .news-card-meta {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 7px;
  align-items: center;
}

.signal-quality-line {
  position: relative;
  z-index: 1;
  margin-top: 12px;
  padding: 10px 13px;
  border-radius: 15px;
  color: var(--fox-text);
  background:
    linear-gradient(180deg, rgba(37,211,102,0.08), rgba(212,160,23,0.04)),
    var(--fox-panel-3);
  border: 1px solid var(--fox-border-soft);
  font-size: 15px;
  line-height: 1.55;
}

.signal-quality-line strong {
  color: var(--fox-gold-light);
}

.signal-level-grid {
  position: relative;
  z-index: 1;
  margin-top: 13px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.signal-level-grid > div {
  min-height: 74px;
  padding: 11px 10px;
  border-radius: 16px;
  background: var(--fox-panel-3);
  border: 1px solid var(--fox-border-soft);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.signal-level-grid span {
  display: block;
  color: var(--fox-text-dim);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.signal-level-grid strong {
  margin-top: 7px;
  color: var(--fox-text);
  font-size: 17px;
  font-weight: 950;
}

/* =============================================================================
   FOXX CHAT â€“ LONG CHAT AREA
   ============================================================================= */

.foxx-chat-shell {
  padding: 19px;
  min-height: 650px;
  display: flex;
  flex-direction: column;
}

.foxx-voice-chat-panel {
  margin-bottom: 16px;
  padding: 20px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 18px;
}

.foxx-voice-chat-kicker {
  color: var(--fox-gold);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0.08em;
}

.foxx-voice-chat-panel h3 {
  margin: 4px 0 6px;
  font-size: 30px;
  line-height: 1.08;
}

.foxx-voice-chat-panel p {
  margin: 0;
  color: var(--fox-text-soft);
  line-height: 1.55;
}

.foxx-voice-chat-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.foxx-chat-history {
  height: min(62vh, 560px);
  min-height: 430px;
  overflow-y: auto;
  padding: 14px;
  border-radius: 20px;
  border: 1px solid var(--fox-border-soft);
  background:
    radial-gradient(circle at 0% 0%, rgba(212,160,23,0.06), transparent 34%),
    var(--fox-panel-3);
}

.foxx-chat-history::-webkit-scrollbar {
  width: 8px;
}

.foxx-chat-history::-webkit-scrollbar-thumb {
  background: rgba(212,160,23,0.28);
  border-radius: 999px;
}

.foxx-chat-empty {
  color: var(--fox-text-soft);
  padding: 16px;
  font-size: 16px;
}

.foxx-chat-msg {
  max-width: 82%;
  margin-bottom: 14px;
  padding: 15px 17px;
  border-radius: 18px;
  border: 1px solid var(--fox-border-soft);
  background: var(--fox-panel);
}

.foxx-chat-msg.user {
  margin-left: auto;
  border-color: var(--fox-border-strong);
  background:
    linear-gradient(180deg, rgba(212,160,23,0.16), rgba(212,160,23,0.06)),
    var(--fox-panel);
}

.foxx-chat-msg.assistant {
  margin-right: auto;
}

.foxx-chat-msg-role {
  font-size: 12px;
  color: var(--fox-text-dim);
  font-weight: 950;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.foxx-chat-msg-content {
  margin-top: 7px;
  line-height: 1.75;
  color: var(--fox-text);
  font-size: 16px;
  white-space: pre-wrap;
}

.foxx-chat-msg-time {
  margin-top: 9px;
  font-size: 12px;
  color: var(--fox-text-dim);
}

.foxx-chat-input-row {
  margin-top: 16px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 150px;
  gap: 12px;
  align-items: stretch;
}

.foxx-chat-input {
  min-height: 96px;
  resize: vertical;
  padding: 15px 17px;
  line-height: 1.55;
}

.foxx-chat-input-row .primary-btn {
  min-height: 96px;
}

/* =============================================================================
   ADMIN â€“ PROFESSIONAL CONTROL CENTER
   ============================================================================= */

#admin-view-root {
  min-height: 420px;
}

.admin-shell,
.admin-page,
.admin-panel {
  color: var(--fox-text);
}

.admin-shell {
  display: grid;
  gap: 18px;
}

.admin-header,
.admin-hero,
.admin-topbar {
  position: sticky;
  top: calc(var(--topbar-height) + 8px);
  z-index: 12;
  padding: 18px 20px;
  border-radius: 22px;
  border: 1px solid var(--fox-border);
  background:
    linear-gradient(180deg, rgba(212,160,23,0.10), rgba(255,255,255,0.015)),
    var(--fox-panel);
  box-shadow: var(--fox-shadow-sm);
  backdrop-filter: blur(12px);
}

.admin-header h1,
.admin-hero h1,
.admin-topbar h1 {
  margin: 0;
  font-size: 32px;
  font-weight: 950;
  line-height: 1.12;
}

.admin-header p,
.admin-hero p,
.admin-topbar p {
  margin: 8px 0 0;
  color: var(--fox-text-soft);
  font-size: 16px;
  line-height: 1.65;
}

.admin-grid,
.admin-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 17px;
}

.admin-card,
.admin-box,
.admin-section,
.admin-table-wrap {
  background: linear-gradient(180deg, var(--fox-panel-2), var(--fox-panel));
  border: 1px solid var(--fox-border);
  border-radius: 22px;
  box-shadow: var(--fox-shadow-sm);
  padding: 20px;
  position: relative;
  overflow: hidden;
}

.admin-card::before,
.admin-box::before,
.admin-section::before,
.admin-table-wrap::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 0% 0%, rgba(212,160,23,0.08), transparent 35%),
    linear-gradient(180deg, rgba(255,255,255,0.022), transparent 60%);
}

.admin-card > *,
.admin-box > *,
.admin-section > *,
.admin-table-wrap > * {
  position: relative;
  z-index: 1;
}

.admin-card h2,
.admin-card h3,
.admin-box h2,
.admin-box h3,
.admin-section h2,
.admin-section h3 {
  margin: 0 0 12px;
  font-size: 25px;
  font-weight: 950;
}

.admin-card p,
.admin-box p,
.admin-section p {
  color: var(--fox-text-soft);
  font-size: 16px;
  line-height: 1.7;
}

.admin-tabs,
.admin-tab-row,
.admin-actions,
.admin-filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 14px 0;
}

.admin-tab,
.admin-btn,
.admin-action-btn,
.admin-save-btn,
.admin-small-btn {
  min-height: 42px;
  padding: 0 15px;
  border-radius: 14px;
  border: 1px solid var(--fox-border);
  background: var(--fox-panel-3);
  color: var(--fox-text);
  font-weight: 900;
}

.admin-tab:hover,
.admin-btn:hover,
.admin-action-btn:hover,
.admin-small-btn:hover {
  border-color: var(--fox-border-strong);
  box-shadow: var(--fox-glow);
  transform: translateY(-1px);
}

.admin-tab.active,
.admin-btn.primary,
.admin-save-btn {
  background: linear-gradient(180deg, var(--fox-gold-light), var(--fox-gold));
  color: #090909;
  border-color: var(--fox-border-strong);
  box-shadow: var(--fox-glow);
}

.admin-input,
.admin-select,
.admin-textarea {
  width: 100%;
  min-height: 44px;
  border-radius: 14px;
  border: 1px solid var(--fox-border);
  background: var(--fox-panel-3);
  color: var(--fox-text);
  padding: 0 14px;
  outline: none;
}

.admin-textarea {
  min-height: 110px;
  padding: 13px 14px;
  resize: vertical;
  line-height: 1.55;
}

.admin-input:focus,
.admin-select:focus,
.admin-textarea:focus {
  border-color: var(--fox-border-strong);
  box-shadow: var(--fox-glow);
}

.admin-label,
.admin-field,
.admin-form-row label {
  display: grid;
  gap: 8px;
  color: var(--fox-text-soft);
  font-size: 14px;
  font-weight: 850;
}

.admin-form-grid,
.admin-settings-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.admin-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 15px;
}

.admin-table th,
.admin-table td {
  padding: 12px;
  border-bottom: 1px solid var(--fox-border-soft);
  text-align: left;
}

.admin-table th {
  color: var(--fox-gold-light);
  font-weight: 950;
  letter-spacing: 0.04em;
}

.admin-table td {
  color: var(--fox-text-soft);
}

.admin-status-ok,
.status-ok {
  color: var(--fox-green);
  font-weight: 950;
}

.admin-status-warn,
.status-warn {
  color: var(--fox-gold-light);
  font-weight: 950;
}

.admin-status-error,
.status-error {
  color: var(--fox-red);
  font-weight: 950;
}

.admin-toggle-row,
.admin-setting-row,
.admin-control-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 12px 0;
  border-bottom: 1px solid var(--fox-border-soft);
}

.admin-toggle-row:last-child,
.admin-setting-row:last-child,
.admin-control-row:last-child {
  border-bottom: 0;
}

.admin-toggle-row span,
.admin-setting-row span,
.admin-control-row span {
  color: var(--fox-text-soft);
  line-height: 1.45;
}

.admin-toggle-row strong,
.admin-setting-row strong,
.admin-control-row strong {
  color: var(--fox-text);
}

.admin-pill {
  display: inline-grid;
  place-items: center;
  min-height: 30px;
  padding: 0 11px;
  border-radius: 999px;
  border: 1px solid var(--fox-border);
  background: var(--fox-panel-3);
  color: var(--fox-text-soft);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0.05em;
}

.admin-pill.live,
.admin-pill.ok {
  color: #dffff0;
  background: rgba(37,211,102,0.14);
  border-color: rgba(37,211,102,0.34);
}

.admin-pill.warn {
  color: #fff0c9;
  background: rgba(255,179,71,0.14);
  border-color: rgba(255,179,71,0.34);
}

.admin-pill.error {
  color: #ffd9d9;
  background: rgba(255,95,95,0.14);
  border-color: rgba(255,95,95,0.34);
}

/* =============================================================================
   USER SETTINGS / HOMEPAGE CONFIG
   ============================================================================= */

.user-settings-card,
.home-settings-card,
.preference-card {
  background: linear-gradient(180deg, var(--fox-panel-2), var(--fox-panel));
  border: 1px solid var(--fox-border);
  border-radius: 22px;
  box-shadow: var(--fox-shadow-sm);
  padding: 20px;
}

.settings-toggle-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.settings-toggle-item {
  min-height: 72px;
  padding: 13px 14px;
  border-radius: 18px;
  border: 1px solid var(--fox-border-soft);
  background: var(--fox-panel-3);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.settings-toggle-item span {
  color: var(--fox-text-soft);
  font-size: 15px;
  line-height: 1.45;
}

.settings-toggle-item strong {
  color: var(--fox-text);
  font-size: 16px;
  font-weight: 950;
}

.settings-switch {
  width: 48px;
  height: 26px;
  border-radius: 999px;
  border: 1px solid var(--fox-border);
  background: var(--fox-panel);
  position: relative;
  flex: 0 0 auto;
}

.settings-switch::after {
  content: "";
  position: absolute;
  top: 3px;
  left: 3px;
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: var(--fox-text-dim);
  transition: left 0.18s ease, background 0.18s ease;
}

.settings-switch.active {
  background: rgba(37,211,102,0.18);
  border-color: rgba(37,211,102,0.42);
}

.settings-switch.active::after {
  left: 25px;
  background: var(--fox-green);
}

/* =============================================================================
   COMMUNITY / MEMBERS / DM
   ============================================================================= */

.member-card,
.dm-card,
.community-room-card {
  min-height: 210px;
}

.member-avatar-row {
  display: flex;
  align-items: center;
  gap: 13px;
}

.member-avatar {
  width: 52px;
  height: 52px;
  border-radius: 18px;
  border: 1px solid var(--fox-border);
  background: var(--fox-panel-3);
  overflow: hidden;
  display: grid;
  place-items: center;
}
.member-name {
  font-size: 20px;
  font-weight: 950;
}

.member-meta {
  margin-top: 4px;
  color: var(--fox-text-soft);
  font-size: 14px;
}

.member-online {
  color: var(--fox-green);
  font-weight: 950;
}

.member-offline {
  color: var(--fox-text-dim);
  font-weight: 850;
}

.dm-thread {
  display: flex;
  flex-direction: column;
  min-height: 520px;
  border-radius: 22px;
  border: 1px solid var(--fox-border);
  background: var(--fox-panel);
  overflow: hidden;
}

.dm-thread-header {
  padding: 16px 18px;
  border-bottom: 1px solid var(--fox-border-soft);
  background: var(--fox-panel-2);
}

.dm-thread-body {
  flex: 1;
  padding: 16px;
  overflow-y: auto;
  min-height: 360px;
}

.dm-thread-input {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 140px;
  gap: 10px;
  padding: 14px;
  border-top: 1px solid var(--fox-border-soft);
  background: var(--fox-panel-2);
}

/* =============================================================================
   CAMPUS / KNOWLEDGE
   ============================================================================= */

.knowledge-card,
.campus-card,
.lesson-card {
  min-height: 245px;
}

.lesson-level,
.knowledge-tag {
  display: inline-grid;
  place-items: center;
  min-height: 29px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid var(--fox-border);
  background: var(--fox-panel-3);
  color: var(--fox-gold-light);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0.05em;
}

.lesson-text,
.knowledge-text {
  margin-top: 12px;
  color: var(--fox-text-soft);
  line-height: 1.7;
  font-size: 16px;
}

/* =============================================================================
   LIGHT MODE OVERRIDES
   ============================================================================= */

html[data-theme="light"] .panel-glow,
html[data-theme="light"] .dashboard-card,
html[data-theme="light"] .news-card,
html[data-theme="light"] .admin-card,
html[data-theme="light"] .admin-box,
html[data-theme="light"] .admin-section,
html[data-theme="light"] .admin-table-wrap,
html[data-theme="light"] .sidebar-brand,
html[data-theme="light"] .sidebar-card,
html[data-theme="light"] .topbar-pill,
html[data-theme="light"] .topbar-user-badge,
html[data-theme="light"] .hero-side-card,
html[data-theme="light"] .hero-status-chip,
html[data-theme="light"] .foxx-chat-history,
html[data-theme="light"] .foxx-chat-msg,
html[data-theme="light"] .auth-brand-card,
html[data-theme="light"] .auth-form-card,
html[data-theme="light"] .daily-brief-mini,
html[data-theme="light"] .daily-brief-levels > div,
html[data-theme="light"] .daily-brief-scenarios,
html[data-theme="light"] .analysis-metric,
html[data-theme="light"] .analysis-long-text,
html[data-theme="light"] .analysis-explain-box,
html[data-theme="light"] .signal-level-grid > div,
html[data-theme="light"] .signal-quality-line,
html[data-theme="light"] .admin-header,
html[data-theme="light"] .admin-hero,
html[data-theme="light"] .admin-topbar,
html[data-theme="light"] .user-settings-card,
html[data-theme="light"] .home-settings-card,
html[data-theme="light"] .preference-card,
html[data-theme="light"] .settings-toggle-item,
html[data-theme="light"] .dm-thread,
html[data-theme="light"] .dm-thread-header,
html[data-theme="light"] .dm-thread-input {
  background: #ffffff;
  color: #111111;
  border-color: rgba(0,0,0,0.08);
  box-shadow: 0 8px 18px rgba(0,0,0,0.06);
}

html[data-theme="light"] .secondary-btn,
html[data-theme="light"] .card-open-btn,
html[data-theme="light"] .logout-btn,
html[data-theme="light"] .topbar-icon-btn,
html[data-theme="light"] .sidebar-nav-btn,
html[data-theme="light"] .tf-chip,
html[data-theme="light"] .admin-tab,
html[data-theme="light"] .admin-btn,
html[data-theme="light"] .admin-action-btn,
html[data-theme="light"] .admin-small-btn,
html[data-theme="light"] .admin-pill {
  background: #ffffff;
  color: #111111;
  border-color: rgba(0,0,0,0.10);
}

html[data-theme="light"] .auth-input,
html[data-theme="light"] .foxx-chat-input,
html[data-theme="light"] .admin-input,
html[data-theme="light"] .admin-select,
html[data-theme="light"] .admin-textarea {
  background: #ffffff;
  color: #111111;
  border-color: rgba(0,0,0,0.12);
}

html[data-theme="light"] .card-description,
html[data-theme="light"] .news-card-text,
html[data-theme="light"] .content-section p,
html[data-theme="light"] .daily-brief-macro,
html[data-theme="light"] .analysis-long-text,
html[data-theme="light"] .lesson-text,
html[data-theme="light"] .knowledge-text {
  color: #444444;
}

html[data-theme="light"] .card-description strong,
html[data-theme="light"] .news-card-text strong,
html[data-theme="light"] .analysis-metric strong,
html[data-theme="light"] .daily-brief-mini strong,
html[data-theme="light"] .signal-level-grid strong {
  color: #111111;
}

html[data-theme="light"] .sidebar-nav-btn.active,
html[data-theme="light"] .tf-chip.active,
html[data-theme="light"] .admin-tab.active,
html[data-theme="light"] .admin-btn.primary,
html[data-theme="light"] .admin-save-btn {
  background: linear-gradient(180deg, var(--fox-gold-light), var(--fox-gold));
  color: #090909;
  border-color: var(--fox-border-strong);
}

html[data-theme="light"] .admin-pill.live,
html[data-theme="light"] .admin-pill.ok {
  color: #075c2b;
  background: #eefff5;
}

html[data-theme="light"] .admin-pill.warn {
  color: #6b4700;
  background: #fff7e6;
}

html[data-theme="light"] .admin-pill.error {
  color: #8b0000;
  background: #fff0f0;
}

/* =============================================================================
   RESPONSIVE / IFRAME SAFE
   ============================================================================= */

@media (max-width: 1500px) {
  .dashboard-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .hero-status-strip {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .admin-grid,
  .admin-cards-grid,
  .news-cards-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .analysis-detail-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 1280px) {
  .app-shell {
    grid-template-columns: 1fr;
  }

  .sidebar {
    position: relative;
    height: auto;
    border-right: 0;
    border-bottom: 1px solid var(--fox-border-soft);
  }

  .topbar {
    grid-template-columns: 1fr;
    justify-items: start;
  }

  .topbar-center {
    width: 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  .topbar-right {
    flex-wrap: wrap;
  }

  .asset-universe-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .hero-main-card {
    grid-template-columns: 1fr;
  }

  .hero-logo-col {
    justify-content: start;
  }

  .auth-wrap {
    grid-template-columns: 1fr;
  }

  .auth-brand-card,
  .auth-form-card {
    min-height: auto;
  }

  .admin-header,
  .admin-hero,
  .admin-topbar {
    position: relative;
    top: auto;
  }
}

@media (max-width: 900px) {
  .daily-brief-grid,
  .analysis-metric-grid,
  .signal-level-grid,
  .settings-toggle-grid,
  .admin-form-grid,
  .admin-settings-grid {
    grid-template-columns: 1fr;
  }

  .daily-brief-levels {
    grid-template-columns: 1fr;
  }

  .dm-thread-input {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .auth-shell {
    padding: 16px;
  }

  .app-main {
    padding: 16px;
  }

  .welcome-line {
    font-size: 23px;
  }

  .hero-main-headline {
    font-size: 36px;
  }

  .hero-status-strip,
  .dashboard-grid,
  .news-cards-grid,
  .admin-grid,
  .admin-cards-grid {
    grid-template-columns: 1fr;
  }

  .foxx-chat-input-row {
    grid-template-columns: 1fr;
  }

  .asset-universe-grid {
    grid-template-columns: 1fr;
  }

  .foxx-voice-chat-panel {
    grid-template-columns: 1fr;
  }

  .foxx-voice-chat-actions {
    justify-content: stretch;
  }

  .foxx-voice-main-btn,
  .foxx-voice-test-btn,
  .foxx-voice-chat-actions .secondary-btn {
    width: 100%;
    min-width: 0;
  }

  .foxx-chat-input-row .primary-btn {
    min-height: 52px;
  }

  .hero-main-card {
    padding: 20px;
  }

  .content-section {
    padding: 18px;
  }

  .content-section h2,
  .content-section h3 {
    font-size: 25px;
  }

  .card-title,
  .news-card-title {
    font-size: 21px;
  }

  .card-description,
  .news-card-text {
    font-size: 15px;
  }
}

/* =============================================================================
   FOXX BOARD HOME â€“ REFERENZBILD LAYOUT FINAL
   =============================================================================
   Ziel:
   - Startseite wie Referenzbild
   - Schwarz/Gold Premium Look
   - großer Hero
   - Foxx AI im Zentrum
   - Halbkreis / Gauge Status
   - kurze Startkarten
   - Details erst nach Öffnen
   - Abstände sauber:
     Desktop Content: 28px
     Karten Gap: 18px
     Hero Padding: 30px
     Mobile: 16px
   ============================================================================= */

.foxx-home-final {
  width: 100%;
  display: grid;
  gap: 18px;
  padding: 0;
}

/* =============================================================================
   HERO
   ============================================================================= */

.foxx-reference-hero {
  min-height: 360px;
  padding: 30px;
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) 310px;
  gap: 28px;
  align-items: center;
  border-radius: 34px;
  overflow: hidden;
  position: relative;
  background:
    radial-gradient(circle at 18% 18%, rgba(212, 160, 23, 0.18), transparent 32%),
    radial-gradient(circle at 86% 24%, rgba(212, 160, 23, 0.10), transparent 30%),
    linear-gradient(135deg, rgba(23, 23, 23, 0.98), rgba(5, 5, 5, 0.98));
}

.foxx-reference-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(212,160,23,0.10), transparent 30%, rgba(212,160,23,0.07)),
    radial-gradient(circle at 50% 100%, rgba(212,160,23,0.12), transparent 36%);
}

.foxx-reference-hero > * {
  position: relative;
  z-index: 1;
}

.foxx-reference-hero-left {
  display: grid;
  gap: 18px;
  justify-items: center;
}

.foxx-reference-logo-ring {
  width: 178px;
  height: 178px;
  border-radius: 999px;
  padding: 14px;
  display: grid;
  place-items: center;
  background:
    radial-gradient(circle at 50% 45%, rgba(212,160,23,0.20), transparent 58%),
    linear-gradient(180deg, var(--fox-panel-3), var(--fox-panel));
  border: 1px solid var(--fox-border-strong);
  box-shadow:
    0 0 0 8px rgba(212,160,23,0.045),
    0 0 0 18px rgba(212,160,23,0.025),
    0 24px 58px rgba(0,0,0,0.45),
    var(--fox-glow-strong);
}

.foxx-reference-logo-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  border-radius: 999px;
}

.foxx-reference-plan-pill {
  width: 100%;
  max-width: 190px;
  min-height: 72px;
  border-radius: 22px;
  padding: 13px 15px;
  display: grid;
  align-content: center;
  text-align: center;
  background:
    linear-gradient(180deg, rgba(212,160,23,0.16), rgba(212,160,23,0.04)),
    var(--fox-panel-3);
  border: 1px solid var(--fox-border);
  box-shadow: var(--fox-shadow-sm);
}

.foxx-reference-plan-pill span {
  color: var(--fox-text-dim);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0.08em;
}

.foxx-reference-plan-pill strong {
  margin-top: 5px;
  color: var(--fox-gold-light);
  font-size: 22px;
  font-weight: 950;
}

.foxx-reference-hero-center {
  min-width: 0;
}

.foxx-reference-kicker {
  color: var(--fox-gold-light);
  font-size: 13px;
  font-weight: 950;
  letter-spacing: 0.14em;
  margin-bottom: 12px;
}

.foxx-reference-title {
  margin: 0;
  font-size: clamp(40px, 3.6vw, 68px);
  line-height: 0.98;
  font-weight: 950;
  letter-spacing: -0.045em;
  color: var(--fox-text);
}

.foxx-reference-title span {
  color: var(--fox-gold);
}

.foxx-reference-short {
  max-width: 850px;
  margin: 20px 0 0;
  color: var(--fox-text-soft);
  font-size: 18px;
  line-height: 1.72;
}

.foxx-reference-action-row {
  margin-top: 24px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.foxx-reference-action-row .hero-btn {
  min-height: 52px;
  padding: 0 22px;
}
/* =============================================================================
   RIGHT HERO / GAUGE
   ============================================================================= */

.foxx-reference-hero-right {
  display: grid;
  gap: 16px;
}

.foxx-reference-gauge-wrap {
  display: grid;
  justify-items: center;
  gap: 12px;
}

.foxx-reference-gauge {
  --gauge-value: 50;
  width: 220px;
  height: 132px;
  position: relative;
  overflow: hidden;
  display: grid;
  place-items: end center;
}

.foxx-reference-gauge::before {
  content: "";
  position: absolute;
  width: 220px;
  height: 220px;
  left: 0;
  top: 0;
  border-radius: 999px;
  background:
    conic-gradient(
      from 270deg,
      var(--fox-gold-light) 0deg,
      var(--fox-gold) calc(var(--gauge-value) * 1.8deg),
      rgba(255,255,255,0.08) calc(var(--gauge-value) * 1.8deg),
      rgba(255,255,255,0.08) 180deg,
      transparent 180deg,
      transparent 360deg
    );
  box-shadow: var(--fox-glow);
}

.foxx-reference-gauge.bullish::before {
  background:
    conic-gradient(
      from 270deg,
      var(--fox-green) 0deg,
      var(--fox-green) calc(var(--gauge-value) * 1.8deg),
      rgba(255,255,255,0.08) calc(var(--gauge-value) * 1.8deg),
      rgba(255,255,255,0.08) 180deg,
      transparent 180deg,
      transparent 360deg
    );
}

.foxx-reference-gauge.bearish::before {
  background:
    conic-gradient(
      from 270deg,
      var(--fox-red) 0deg,
      var(--fox-red) calc(var(--gauge-value) * 1.8deg),
      rgba(255,255,255,0.08) calc(var(--gauge-value) * 1.8deg),
      rgba(255,255,255,0.08) 180deg,
      transparent 180deg,
      transparent 360deg
    );
}

.foxx-reference-gauge::after {
  content: "";
  position: absolute;
  width: 156px;
  height: 156px;
  left: 32px;
  top: 32px;
  border-radius: 999px;
  background:
    radial-gradient(circle at 50% 45%, rgba(212,160,23,0.08), transparent 56%),
    var(--fox-panel);
  border: 1px solid var(--fox-border-soft);
}

.foxx-reference-gauge-inner {
  position: relative;
  z-index: 2;
  width: 146px;
  height: 92px;
  display: grid;
  place-items: center;
  align-content: center;
  padding-top: 24px;
}

.foxx-reference-gauge-inner span {
  color: var(--fox-text-dim);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0.10em;
}

.foxx-reference-gauge-inner strong {
  margin-top: 5px;
  color: var(--fox-text);
  font-size: 24px;
  line-height: 1;
  font-weight: 950;
}

.foxx-reference-gauge-caption {
  max-width: 240px;
  color: var(--fox-text-dim);
  text-align: center;
  font-size: 13px;
  line-height: 1.5;
}

.foxx-reference-side-metrics {
  display: grid;
  gap: 10px;
}

.foxx-reference-side-row {
  min-height: 58px;
  padding: 11px 13px;
  border-radius: 18px;
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.012)),
    var(--fox-panel-3);
  border: 1px solid var(--fox-border-soft);
}

.foxx-reference-side-row span {
  color: var(--fox-text-dim);
  font-size: 13px;
  font-weight: 950;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.foxx-reference-side-row strong {
  color: var(--fox-text);
  font-size: 18px;
  font-weight: 950;
  text-align: right;
}

/* =============================================================================
   QUICK STRIP
   ============================================================================= */

.foxx-reference-quick-strip {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 18px;
}

.foxx-reference-quick-item {
  min-height: 96px;
  padding: 16px 18px;
  border-radius: 24px;
  display: grid;
  align-content: center;
  background:
    linear-gradient(180deg, rgba(212,160,23,0.075), rgba(255,255,255,0.015)),
    var(--fox-panel);
  border: 1px solid var(--fox-border);
  box-shadow: var(--fox-shadow-sm);
}

.foxx-reference-quick-item span {
  color: var(--fox-text-dim);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0.08em;
}

.foxx-reference-quick-item strong {
  margin-top: 8px;
  color: var(--fox-gold-light);
  font-size: 26px;
  line-height: 1;
  font-weight: 950;
}

/* =============================================================================
   PREVIEW CARDS
   ============================================================================= */

.foxx-reference-card-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.foxx-reference-preview-card {
  min-height: 315px;
  padding: 22px;
  border-radius: 28px;
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.025), transparent 56%),
    linear-gradient(180deg, var(--fox-panel-2), var(--fox-panel));
  border: 1px solid var(--fox-border);
  box-shadow: var(--fox-shadow-sm);
}

.foxx-reference-preview-card::before {
  content: "";
  position: absolute;
  width: 180px;
  height: 180px;
  right: -70px;
  top: -72px;
  border-radius: 999px;
  pointer-events: none;
  background: rgba(212,160,23,0.12);
  filter: blur(2px);
}

.foxx-reference-preview-card.bullish::before,
.foxx-reference-preview-card.green::before {
  background: rgba(37,211,102,0.13);
}

.foxx-reference-preview-card.bearish::before {
  background: rgba(255,95,95,0.13);
}

.foxx-reference-preview-card.blue::before {
  background: rgba(79,140,255,0.13);
}

.foxx-reference-card-top {
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
}

.foxx-reference-card-kicker {
  color: var(--fox-gold-light);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0.10em;
  margin-bottom: 8px;
}

.foxx-reference-card-top h3 {
  margin: 0;
  color: var(--fox-text);
  font-size: 26px;
  line-height: 1.08;
  font-weight: 950;
}

.foxx-reference-card-orb {
  width: 44px;
  height: 44px;
  border-radius: 999px;
  flex: 0 0 auto;
  background:
    radial-gradient(circle at 50% 50%, var(--fox-gold-light), var(--fox-gold));
  box-shadow: 0 0 26px rgba(212,160,23,0.30);
}

.foxx-reference-preview-card.green .foxx-reference-card-orb,
.foxx-reference-preview-card.bullish .foxx-reference-card-orb {
  background:
    radial-gradient(circle at 50% 50%, #82ffb2, var(--fox-green));
  box-shadow: 0 0 26px rgba(37,211,102,0.26);
}

.foxx-reference-preview-card.bearish .foxx-reference-card-orb {
  background:
    radial-gradient(circle at 50% 50%, #ff9b9b, var(--fox-red));
  box-shadow: 0 0 26px rgba(255,95,95,0.26);
}

.foxx-reference-preview-card.blue .foxx-reference-card-orb {
  background:
    radial-gradient(circle at 50% 50%, #9fc1ff, var(--fox-blue));
  box-shadow: 0 0 26px rgba(79,140,255,0.24);
}

.foxx-reference-card-headline {
  position: relative;
  z-index: 1;
  margin-top: 22px;
  color: var(--fox-text);
  font-size: 25px;
  line-height: 1.12;
  font-weight: 950;
  letter-spacing: -0.02em;
}

.foxx-reference-card-text {
  position: relative;
  z-index: 1;
  margin: 13px 0 0;
  color: var(--fox-text-soft);
  font-size: 16px;
  line-height: 1.66;
}

.foxx-reference-preview-card .card-open-btn {
  margin-top: auto;
}

/* =============================================================================
   DAILY PREVIEW
   ============================================================================= */

.foxx-reference-wide-row {
  display: grid;
  gap: 18px;
}

.foxx-reference-daily-card {
  padding: 26px;
  border-radius: 30px;
  min-height: 245px;
  background:
    radial-gradient(circle at 0% 0%, rgba(212,160,23,0.12), transparent 34%),
    linear-gradient(180deg, var(--fox-panel-2), var(--fox-panel));
}

.foxx-reference-section-head {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-start;
  margin-bottom: 18px;
}

.foxx-reference-section-kicker {
  color: var(--fox-gold-light);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0.10em;
  margin-bottom: 7px;
}

.foxx-reference-section-head h2 {
  margin: 0;
  color: var(--fox-text);
  font-size: 31px;
  line-height: 1.12;
  font-weight: 950;
}

.foxx-reference-daily-preview {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(360px, 0.85fr);
  gap: 18px;
}

.foxx-reference-daily-main {
  padding: 18px 20px;
  border-radius: 22px;
  color: var(--fox-text-soft);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.012)),
    var(--fox-panel-3);
  border: 1px solid var(--fox-border-soft);
  font-size: 17px;
  line-height: 1.75;
}

.foxx-reference-daily-mini-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.foxx-reference-daily-mini-grid > div {
  min-height: 88px;
  padding: 13px 14px;
  border-radius: 20px;
  display: grid;
  align-content: center;
  background: var(--fox-panel-3);
  border: 1px solid var(--fox-border-soft);
}

.foxx-reference-daily-mini-grid span {
  color: var(--fox-text-dim);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0.07em;
  text-transform: uppercase;
}

.foxx-reference-daily-mini-grid strong {
  margin-top: 7px;
  color: var(--fox-text);
  font-size: 17px;
  font-weight: 950;
}

/* =============================================================================
   LIGHT MODE
   ============================================================================= */

html[data-theme="light"] .foxx-reference-hero,
html[data-theme="light"] .foxx-reference-preview-card,
html[data-theme="light"] .foxx-reference-daily-card,
html[data-theme="light"] .foxx-reference-quick-item {
  background: #ffffff;
  border-color: rgba(0,0,0,0.08);
  box-shadow: 0 12px 28px rgba(0,0,0,0.06);
}

html[data-theme="light"] .foxx-reference-gauge::after {
  background: #ffffff;
  border-color: rgba(0,0,0,0.08);
}

html[data-theme="light"] .foxx-reference-side-row,
html[data-theme="light"] .foxx-reference-daily-main,
html[data-theme="light"] .foxx-reference-daily-mini-grid > div,
html[data-theme="light"] .foxx-reference-plan-pill {
  background: #ffffff;
  border-color: rgba(0,0,0,0.08);
}

/* =============================================================================
   RESPONSIVE
   ============================================================================= */

@media (max-width: 1500px) {
  .foxx-reference-hero {
    grid-template-columns: 190px minmax(0, 1fr) 280px;
  }

  .foxx-reference-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .foxx-reference-quick-strip {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }
}

@media (max-width: 1150px) {
  .foxx-reference-hero {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .foxx-reference-action-row {
    justify-content: center;
  }

  .foxx-reference-hero-right {
    justify-items: center;
  }

  .foxx-reference-side-metrics {
    width: min(520px, 100%);
  }

  .foxx-reference-daily-preview {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  .foxx-reference-quick-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .foxx-reference-card-grid {
    grid-template-columns: 1fr;
  }

  .foxx-reference-daily-mini-grid {
    grid-template-columns: 1fr;
  }

  .foxx-reference-section-head {
    flex-direction: column;
  }
}

@media (max-width: 760px) {
  .foxx-home-final {
    gap: 16px;
  }

  .foxx-reference-hero {
    padding: 22px 16px;
    border-radius: 24px;
  }

  .foxx-reference-title {
    font-size: 36px;
  }

  .foxx-reference-short {
    font-size: 15px;
  }

  .foxx-reference-logo-ring {
    width: 138px;
    height: 138px;
  }

  .foxx-reference-gauge {
    width: 190px;
    height: 118px;
  }

  .foxx-reference-gauge::before {
    width: 190px;
    height: 190px;
  }

  .foxx-reference-gauge::after {
    width: 134px;
    height: 134px;
    left: 28px;
    top: 28px;
  }

  .foxx-reference-preview-card,
  .foxx-reference-daily-card {
    padding: 18px;
    border-radius: 22px;
  }

  .foxx-reference-card-top h3 {
    font-size: 23px;
  }

  .foxx-reference-card-headline {
    font-size: 22px;
  }
}

/* =============================================================================
   FOXX BOARD ANALYSIS â€“ REFERENZBILD LAYOUT FINAL
   ============================================================================= */

.foxx-analysis-final {
  display: grid;
  gap: 18px;
}

.foxx-analysis-hero {
  min-height: 260px;
  padding: 28px;
  border-radius: 30px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 310px;
  gap: 24px;
  align-items: center;
  background:
    radial-gradient(circle at 0% 0%, rgba(212,160,23,0.14), transparent 34%),
    linear-gradient(180deg, var(--fox-panel-2), var(--fox-panel));
}

.foxx-analysis-kicker,
.foxx-analysis-section-kicker,
.foxx-analysis-info-kicker {
  color: var(--fox-gold-light);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0.10em;
  text-transform: uppercase;
}

.foxx-analysis-hero h2 {
  margin: 8px 0 0;
  color: var(--fox-text);
  font-size: clamp(32px, 3vw, 54px);
  line-height: 1.02;
  font-weight: 950;
}

.foxx-analysis-hero p {
  max-width: 860px;
  margin: 16px 0 0;
  color: var(--fox-text-soft);
  font-size: 17px;
  line-height: 1.68;
}

.foxx-analysis-actions {
  margin-top: 22px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.foxx-analysis-hero-right {
  display: grid;
  justify-items: center;
  gap: 14px;
}

.foxx-analysis-gauge-wrap {
  display: grid;
  justify-items: center;
}

.foxx-analysis-gauge {
  --gauge-value: 50;
  width: 220px;
  height: 132px;
  position: relative;
  overflow: hidden;
  display: grid;
  place-items: end center;
}

.foxx-analysis-gauge::before {
  content: "";
  position: absolute;
  width: 220px;
  height: 220px;
  left: 0;
  top: 0;
  border-radius: 999px;
  background:
    conic-gradient(
      from 270deg,
      var(--fox-gold-light) 0deg,
      var(--fox-gold) calc(var(--gauge-value) * 1.8deg),
      rgba(255,255,255,0.08) calc(var(--gauge-value) * 1.8deg),
      rgba(255,255,255,0.08) 180deg,
      transparent 180deg,
      transparent 360deg
    );
}

.foxx-analysis-gauge.bullish::before {
  background:
    conic-gradient(
      from 270deg,
      var(--fox-green) 0deg,
      var(--fox-green) calc(var(--gauge-value) * 1.8deg),
      rgba(255,255,255,0.08) calc(var(--gauge-value) * 1.8deg),
      rgba(255,255,255,0.08) 180deg,
      transparent 180deg,
      transparent 360deg
    );
}

.foxx-analysis-gauge.bearish::before {
  background:
    conic-gradient(
      from 270deg,
      var(--fox-red) 0deg,
      var(--fox-red) calc(var(--gauge-value) * 1.8deg),
      rgba(255,255,255,0.08) calc(var(--gauge-value) * 1.8deg),
      rgba(255,255,255,0.08) 180deg,
      transparent 180deg,
      transparent 360deg
    );
}

.foxx-analysis-gauge::after {
  content: "";
  position: absolute;
  width: 156px;
  height: 156px;
  left: 32px;
  top: 32px;
  border-radius: 999px;
  background: var(--fox-panel);
  border: 1px solid var(--fox-border-soft);
}

.foxx-analysis-gauge-inner {
  position: relative;
  z-index: 2;
  width: 146px;
  height: 92px;
  display: grid;
  place-items: center;
  align-content: center;
  padding-top: 24px;
}

.foxx-analysis-gauge-inner span {
  color: var(--fox-text-dim);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0.08em;
}

.foxx-analysis-gauge-inner strong {
  margin-top: 5px;
  color: var(--fox-text);
  font-size: 24px;
  font-weight: 950;
}

.foxx-analysis-mini-stack {
  width: 100%;
  display: grid;
  gap: 10px;
}

.foxx-analysis-mini-row {
  min-height: 54px;
  padding: 10px 13px;
  border-radius: 18px;
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
  background: var(--fox-panel-3);
  border: 1px solid var(--fox-border-soft);
}

.foxx-analysis-mini-row span {
  color: var(--fox-text-dim);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.foxx-analysis-mini-row strong {
  color: var(--fox-text);
  font-size: 16px;
  font-weight: 950;
  text-align: right;
}

.foxx-analysis-main-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(340px, 0.55fr);
  gap: 18px;
}

.foxx-analysis-core-card,
.foxx-analysis-level-card {
  padding: 24px;
  border-radius: 28px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.025), transparent 58%),
    var(--fox-panel);
}

.foxx-analysis-section-head {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 16px;
}

.foxx-analysis-section-head h3 {
  margin: 6px 0 0;
  color: var(--fox-text);
  font-size: 28px;
  font-weight: 950;
}

.foxx-analysis-decision-box {
  padding: 18px 20px;
  border-radius: 22px;
  color: var(--fox-text);
  font-size: 17px;
  line-height: 1.68;
  background:
    linear-gradient(180deg, rgba(212,160,23,0.12), rgba(255,255,255,0.012)),
    var(--fox-panel-3);
  border: 1px solid var(--fox-border);
}

.foxx-analysis-metric-grid {
  margin-top: 16px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.foxx-analysis-metric {
  min-height: 82px;
  padding: 13px 14px;
  border-radius: 18px;
  display: grid;
  align-content: center;
  background: var(--fox-panel-3);
  border: 1px solid var(--fox-border-soft);
}

.foxx-analysis-metric span {
  color: var(--fox-text-dim);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0.07em;
  text-transform: uppercase;
}

.foxx-analysis-metric strong {
  margin-top: 8px;
  color: var(--fox-text);
  font-size: 18px;
  font-weight: 950;
}

.foxx-analysis-note-card {
  margin-top: 14px;
  padding: 16px 18px;
  border-radius: 20px;
  background: var(--fox-panel-3);
  border: 1px solid var(--fox-border-soft);
}

.foxx-analysis-note-card strong {
  color: var(--fox-gold-light);
  font-weight: 950;
}

.foxx-analysis-note-card p {
  margin: 8px 0 0;
  color: var(--fox-text-soft);
  line-height: 1.65;
}

.foxx-analysis-note-card.warning {
  border-color: rgba(255, 187, 64, 0.28);
}

.foxx-analysis-level-grid {
  display: grid;
  gap: 12px;
}

.foxx-analysis-level-grid > div {
  min-height: 78px;
  padding: 13px 14px;
  border-radius: 18px;
  background: var(--fox-panel-3);
  border: 1px solid var(--fox-border-soft);
  display: grid;
  align-content: center;
}

.foxx-analysis-level-grid span {
  color: var(--fox-gold-light);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
}

.foxx-analysis-level-grid strong {
  margin-top: 7px;
  color: var(--fox-text);
  font-size: 15px;
  line-height: 1.5;
}

.foxx-analysis-scenario-grid,
.foxx-analysis-detail-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.foxx-analysis-scenario-card,
.foxx-analysis-info-card {
  padding: 21px;
  border-radius: 26px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.025), transparent 55%),
    var(--fox-panel);
  border: 1px solid var(--fox-border);
}

.foxx-analysis-scenario-card.bullish {
  border-color: rgba(37,211,102,0.28);
}

.foxx-analysis-scenario-card.bearish {
  border-color: rgba(255,95,95,0.28);
}

.foxx-analysis-scenario-top {
  display: grid;
  gap: 5px;
  margin-bottom: 12px;
}

.foxx-analysis-scenario-top span {
  color: var(--fox-text-dim);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
}

.foxx-analysis-scenario-top strong,
.foxx-analysis-info-card h3 {
  color: var(--fox-text);
  font-size: 22px;
  font-weight: 950;
}

.foxx-analysis-scenario-card p,
.foxx-analysis-info-card p {
  color: var(--fox-text-soft);
  line-height: 1.68;
}

.foxx-analysis-trigger {
  margin-top: 12px;
  padding: 11px 13px;
  border-radius: 16px;
  background: var(--fox-panel-3);
  border: 1px solid var(--fox-border-soft);
  display: flex;
  justify-content: space-between;
  gap: 12px;
}

.foxx-analysis-trigger span {
  color: var(--fox-text-dim);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
}

.foxx-analysis-trigger strong {
  color: var(--fox-text);
  text-align: right;
}

.foxx-analysis-info-card.locked {
  opacity: 0.82;
}

.foxx-analysis-info-card.locked h3::after {
  content: "  ðŸ”’";
  color: var(--fox-gold-light);
}

@media (max-width: 1250px) {
  .foxx-analysis-hero,
  .foxx-analysis-main-grid {
    grid-template-columns: 1fr;
  }

  .foxx-analysis-hero-right {
    justify-items: stretch;
  }

  .foxx-analysis-mini-stack {
    max-width: 560px;
    justify-self: center;
  }

  .foxx-analysis-scenario-grid,
  .foxx-analysis-detail-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .foxx-analysis-hero,
  .foxx-analysis-core-card,
  .foxx-analysis-level-card,
  .foxx-analysis-scenario-card,
  .foxx-analysis-info-card {
    padding: 18px;
    border-radius: 22px;
  }

  .foxx-analysis-metric-grid {
    grid-template-columns: 1fr;
  }
}

.foxx-daily-final {
  padding: 25px;
  border-radius: 20px;
  background: var(--fox-panel);
  margin-top: 20px;
  border: 1px solid var(--fox-border);
  box-shadow: var(--fox-shadow-sm);
}

.daily-main {
  margin-bottom: 15px;
  color: var(--fox-text-soft);
  line-height: 1.7;
}

.daily-impulse-box {
  background: var(--fox-panel-3);
  padding: 15px;
  border-radius: 12px;
  border: 1px solid var(--fox-gold);
}

.daily-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-top: 15px;
}

.daily-grid > div {
  background: var(--fox-panel-3);
  border: 1px solid var(--fox-border-soft);
  border-radius: 14px;
  padding: 14px;
  color: var(--fox-text-soft);
  line-height: 1.55;
}

.daily-grid b {
  color: var(--fox-gold-light);
}

.daily-risk {
  margin-top: 15px;
  color: #ffb84d;
}

html[data-theme="light"] .foxx-daily-final,
html[data-theme="light"] .daily-impulse-box,
html[data-theme="light"] .daily-grid > div {
  background: #ffffff;
  color: #111111;
  border-color: rgba(0,0,0,0.08);
}

html[data-theme="light"] .daily-main,
html[data-theme="light"] .daily-grid > div {
  color: #444444;
}

@media (max-width: 900px) {
  .daily-grid {
    grid-template-columns: 1fr;
  }
}
/* =============================================================================
   FOXX BOARD â€“ WEBSITE FONT / READABILITY FINAL
============================================================================= */

:root {
  --foxx-font-main: "Inter", "Montserrat", "Segoe UI", Arial, sans-serif;
  --foxx-font-head: "Montserrat", "Inter", "Segoe UI", Arial, sans-serif;
}

html,
body,
button,
input,
select,
textarea {
  font-family: var(--foxx-font-main);
  font-size: 16px;
}

body {
  line-height: 1.55;
}

h1, h2, h3,
.brand-main,
.welcome-line,
.foxx-reference-title,
.foxx-analysis-hero h2,
.news-card-title {
  font-family: var(--foxx-font-head);
  font-weight: 800;
  letter-spacing: -0.02em;
}

.app-main {
  font-size: 16px;
}

.content-section p,
.news-card-text,
.analysis-long-text,
.foxx-analysis-note-card,
.daily-main,
.daily-impulse-box,
.daily-grid,
.daily-risk {
  font-size: 15.5px;
  line-height: 1.6;
}

.analysis-metric span,
.foxx-analysis-metric span,
.signal-level-grid span,
.daily-brief-mini span {
  font-size: 12px;
  letter-spacing: 0.05em;
}

.analysis-metric strong,
.foxx-analysis-metric strong,
.signal-level-grid strong,
.daily-brief-mini strong {
  font-size: 17px;
  line-height: 1.35;
}

.sidebar-nav-btn,
.logout-btn,
.primary-btn,
.secondary-btn,
.card-open-btn {
  font-size: 15px;
  font-weight: 800;
}

.sidebar {
  font-size: 14px;
}

.foxx-analysis-hero h2,
.content-section h2 {
  font-size: clamp(28px, 2.4vw, 44px);
}

.content-section h3,
.news-card-title {
  font-size: 22px;
}

/* =============================================================================
   FOXX BOARD â€“ READABILITY FINAL
============================================================================= */

html,
body,
button,
input,
select,
textarea {
  font-family: "Inter", "Montserrat", "Segoe UI", Arial, sans-serif;
  font-size: 16px;
}

body {
  line-height: 1.55;
}

h1, h2, h3,
.brand-main,
.welcome-line,
.news-card-title,
.content-section h2,
.content-section h3 {
  font-family: "Montserrat", "Inter", "Segoe UI", Arial, sans-serif;
  font-weight: 800;
  letter-spacing: -0.02em;
}

.app-main,
.content-section,
.analysis-long-text,
.daily-main,
.daily-impulse-box,
.daily-grid,
.daily-risk,
.news-card-text {
  font-size: 15.5px;
  line-height: 1.6;
}

.analysis-metric span,
.daily-brief-mini span {
  font-size: 12px;
  letter-spacing: 0.05em;
}

.analysis-metric strong,
.daily-brief-mini strong {
  font-size: 17px;
  line-height: 1.35;
}

.primary-btn,
.secondary-btn,
.card-open-btn,
.sidebar-nav-btn,
.logout-btn {
  font-size: 15px;
  font-weight: 800;
}

.content-section h2 {
  font-size: clamp(28px, 2.2vw, 42px);
}

.content-section h3 {
  font-size: 22px;
}
/* =========================================================
   FOXX SIGNAL DETAIL â€“ EXPLAINED BLOCKS
   ========================================================= */

.foxx-explained-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin-top: 18px;
}

.foxx-explained-card {
  min-height: 170px;
}

.foxx-explained-card h3 {
  margin-bottom: 12px;
}

.foxx-detail-lines {
  background: rgba(255, 248, 225, 0.55);
  border: 1px solid rgba(218, 165, 32, 0.22);
  border-radius: 14px;
  padding: 12px 14px;
  line-height: 1.65;
  font-weight: 600;
}

.foxx-ai-explain {
  margin-top: 12px;
  background: rgba(255, 255, 255, 0.72);
  border-left: 4px solid #d6a313;
  border-radius: 12px;
  padding: 12px 14px;
  line-height: 1.6;
}

.foxx-ai-explain strong {
  color: #d6a313;
}

@media (max-width: 1100px) {
  .foxx-explained-grid {
    grid-template-columns: 1fr;
  }
}
/* =============================================================================
   FOXX BOARD â€“ FINAL SIGNAL / CHAT / NOTIFICATION PATCH
   Ergänzt: Signalgruppen nebeneinander, Glocke, Community-Räume, Detail-Blöcke
   ============================================================================= */

.signal-asset-sections {
  display: grid;
  gap: 24px;
}

.signal-asset-section {
  display: grid;
  gap: 14px;
}

.signal-asset-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 16px;
  padding: 8px 4px 0;
}

.signal-asset-head h3 {
  margin: 0;
  font-size: 28px;
  font-weight: 950;
  color: var(--fox-text);
}

.signal-asset-head span {
  color: var(--fox-gold-light);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.signal-asset-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--fox-border-strong), transparent);
}

.signal-asset-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  align-items: stretch;
}

.signal-board-card {
  min-height: 440px;
}

.signal-empty-card {
  opacity: 0.78;
}

.signal-time-row {
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: space-between;
  gap: 10px;
  margin-top: 10px;
  color: var(--fox-text-soft);
  font-size: 12px;
  line-height: 1.45;
}

.signal-short-message {
  max-height: 120px;
  overflow: hidden;
}

.topbar-bell-btn {
  position: relative;
}

.topbar-bell-badge {
  position: absolute;
  top: -7px;
  right: -7px;
  min-width: 21px;
  height: 21px;
  padding: 0 6px;
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  color: #090909;
  background: linear-gradient(180deg, var(--fox-gold-light), var(--fox-gold));
  border: 1px solid var(--fox-border-strong);
  font-size: 11px;
  font-weight: 950;
  box-shadow: var(--fox-glow);
}

.notification-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.notification-card {
  padding: 20px;
  border-radius: 22px;
  min-height: 210px;
}

.notification-title {
  font-size: 22px;
  font-weight: 950;
}

.notification-meta {
  margin-top: 8px;
  color: var(--fox-text-dim);
  font-size: 13px;
  font-weight: 850;
}

.notification-text {
  margin-top: 13px;
  color: var(--fox-text-soft);
  font-size: 15px;
  line-height: 1.65;
}

.community-room-grid .community-room-card {
  min-height: 230px;
}

.community-chat-shell {
  min-height: 720px;
}

.foxx-chat-msg.foxx-ai-msg {
  border-color: var(--fox-border-strong);
  background:
    linear-gradient(180deg, rgba(212,160,23,0.12), rgba(212,160,23,0.04)),
    var(--fox-panel);
}

.foxx-detail-lines {
  color: var(--fox-text);
  background: rgba(212,160,23,0.075);
  border: 1px solid var(--fox-border-soft);
}

.foxx-ai-explain {
  color: var(--fox-text-soft);
  background: var(--fox-panel-3);
  border-left: 4px solid var(--fox-gold);
}

html[data-theme="light"] .foxx-detail-lines,
html[data-theme="light"] .foxx-ai-explain,
html[data-theme="light"] .notification-card,
html[data-theme="light"] .foxx-chat-msg.foxx-ai-msg {
  background: #ffffff;
  color: #111111;
  border-color: rgba(0,0,0,0.08);
}

@media (max-width: 1280px) {
  .signal-asset-grid,
  .notification-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .signal-asset-grid,
  .notification-grid {
    grid-template-columns: 1fr;
  }

  .signal-asset-head {
    align-items: flex-start;
    flex-direction: column;
  }

  .signal-time-row {
    flex-direction: column;
  }
}


/* =========================================================
   FOXX BOARD DATA ROUTER REPAIR â€“ SIGNALS / NEWS / GLOSSARY
   ========================================================= */
.signal-asset-sections{display:flex;flex-direction:column;gap:26px;margin-top:18px;}
.signal-asset-section{width:100%;}
.signal-asset-head{display:flex;align-items:flex-end;justify-content:space-between;margin:6px 0 8px;}
.signal-asset-head h3{font-size:22px;margin:0;font-weight:900;}
.signal-asset-head span{font-size:12px;opacity:.7;font-weight:800;}
.signal-asset-divider{height:2px;background:linear-gradient(90deg,#d6a313,rgba(214,163,19,.08));border-radius:999px;margin-bottom:14px;}
.signal-asset-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;align-items:stretch;}
.signal-empty-card{opacity:.75;}
.signal-time-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;font-size:11px;margin:10px 0;}
.signal-short-message{font-size:12px;line-height:1.55;}
.knowledge-card .news-card-text{line-height:1.65;}

.knowledge-toolbar{
  display:grid;
  grid-template-columns:minmax(220px,1fr) minmax(180px,260px);
  gap:10px;
  margin-top:16px;
}

.knowledge-az-bar{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-top:14px;
}

.knowledge-letter{
  min-width:34px;
  min-height:32px;
  border:1px solid var(--border);
  border-radius:8px;
  background:var(--surface);
  color:var(--text);
  font-weight:800;
  cursor:pointer;
}

.knowledge-letter.active,
.knowledge-letter:hover{
  background:var(--accent);
  color:#111;
  border-color:var(--accent);
}

.knowledge-card{
  cursor:pointer;
}

.knowledge-card:hover{
  transform:translateY(-2px);
  border-color:var(--accent);
}

.campus-hero{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(280px,360px);
  gap:22px;
  align-items:stretch;
}

.campus-hero-copy h2{
  margin:4px 0 10px;
  font-size:clamp(32px,3vw,52px);
  line-height:1.02;
}

.campus-hero-copy p{
  max-width:820px;
  line-height:1.72;
  color:var(--text-muted);
}

.campus-hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}

.campus-progress-panel{
  border:1px solid var(--border);
  border-radius:18px;
  background:var(--surface);
  padding:18px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.campus-progress-number{
  font-size:58px;
  line-height:1;
  font-weight:950;
  color:var(--accent);
}

.campus-progress-label{
  margin-top:6px;
  font-weight:900;
  color:var(--text-muted);
}

.campus-progress-bar{
  height:10px;
  border-radius:999px;
  background:rgba(128,128,128,.18);
  overflow:hidden;
  margin:16px 0;
}

.campus-progress-bar span{
  display:block;
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,var(--accent),#22c55e);
}

.campus-stat-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:8px;
}

.campus-stat-grid div,
.campus-classroom-grid div,
.campus-access-list div{
  border:1px solid var(--border);
  border-radius:12px;
  background:var(--surface-2);
  padding:10px;
}

.campus-stat-grid strong,
.campus-classroom-grid strong,
.campus-access-list strong{
  display:block;
  font-size:18px;
  font-weight:950;
}

.campus-stat-grid span,
.campus-classroom-grid span,
.campus-access-list span{
  display:block;
  margin-top:4px;
  color:var(--text-muted);
  font-size:12px;
  line-height:1.45;
}

.campus-tabs-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:14px 0 18px;
}

.campus-tab{
  min-height:38px;
  padding:0 14px;
  border-radius:999px;
  border:1px solid var(--border);
  background:var(--surface);
  color:var(--text);
  font-weight:900;
}

.campus-tab.active{
  background:var(--accent);
  color:#111;
  border-color:var(--accent);
}

.campus-path-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
  margin-bottom:20px;
}

.campus-course-card{
  padding:18px;
  border-radius:18px;
  min-height:100%;
}

.campus-course-card.locked{
  opacity:.72;
}

.campus-course-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}

.campus-course-top h3{
  margin:6px 0 0;
  font-size:22px;
  line-height:1.12;
}

.campus-course-step{
  width:46px;
  height:46px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:var(--accent);
  color:#111;
  font-weight:950;
}

.campus-course-card p,
.campus-outcome{
  color:var(--text-muted);
  line-height:1.6;
}

.campus-outcome{
  margin-top:12px;
  padding:10px;
  border-radius:12px;
  background:var(--surface-2);
}

.campus-module-list{
  display:grid;
  gap:9px;
  margin:14px 0;
}

.campus-module-row{
  display:grid;
  grid-template-columns:32px minmax(0,1fr);
  gap:10px;
  align-items:start;
  padding:10px;
  border-radius:12px;
  border:1px solid var(--border);
  background:var(--surface-2);
}

.campus-module-index{
  width:28px;
  height:28px;
  border-radius:9px;
  display:grid;
  place-items:center;
  background:rgba(214,163,19,.18);
  color:var(--accent);
  font-weight:950;
}

.campus-module-index.done{
  background:#22c55e;
  color:#07140b;
  font-size:10px;
}

.campus-module-row strong,
.campus-module-row span,
.campus-module-row em{
  display:block;
}

.campus-module-row span{
  margin-top:4px;
  color:var(--text-muted);
  font-size:12px;
}

.campus-module-row em{
  margin-top:6px;
  font-style:normal;
  color:var(--text);
  line-height:1.45;
}

.campus-lesson-visual,
.mt5-guide-visual{
  position:relative;
  min-height:220px;
  border:1px solid var(--border);
  border-radius:18px;
  overflow:hidden;
  background:
    linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px),
    linear-gradient(180deg, rgba(255,255,255,.045) 1px, transparent 1px),
    linear-gradient(135deg, rgba(214,163,19,.18), rgba(34,197,94,.08), transparent);
  background-size:42px 42px, 42px 42px, auto;
  padding:18px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  gap:8px;
}

.campus-lesson-visual span,
.mt5-guide-visual span{
  position:relative;
  z-index:2;
  color:var(--text-muted);
  font-weight:850;
  line-height:1.5;
}

.campus-lesson-visual strong,
.mt5-guide-visual strong{
  position:relative;
  z-index:2;
  font-size:22px;
  font-weight:950;
}

.campus-lesson-candle{
  position:absolute;
  left:20%;
  bottom:38%;
  width:42px;
  height:96px;
  border-radius:8px;
  background:#22c55e;
  box-shadow:70px -34px 0 #ef4444, 140px -6px 0 #22c55e, 210px -62px 0 #22c55e;
}

.campus-lesson-line,
.mt5-guide-arrow{
  position:absolute;
  left:8%;
  right:8%;
  height:3px;
  background:var(--accent);
  box-shadow:0 0 14px rgba(214,163,19,.45);
}

.campus-lesson-line.line-one{top:35%;}
.campus-lesson-line.line-two{top:58%; opacity:.65;}

.mt5-guide-stage{
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(220px,.8fr);
  gap:16px;
  margin:16px 0;
}

.mt5-guide-brand{
  position:absolute;
  top:18px;
  left:18px;
  z-index:3;
  display:flex;
  align-items:center;
  gap:10px;
  padding:9px 12px;
  border:1px solid rgba(214,163,19,.35);
  border-radius:14px;
  background:rgba(255,255,255,.88);
  color:#111;
  font-weight:950;
  box-shadow:0 12px 28px rgba(0,0,0,.14);
}

.mt5-guide-brand img{
  width:34px;
  height:34px;
  object-fit:contain;
}

.mt5-guide-step-pill{
  position:absolute;
  top:18px;
  right:18px;
  z-index:3;
  padding:8px 12px;
  border-radius:999px;
  background:var(--accent);
  color:#111;
  font-size:12px;
  font-weight:950;
  box-shadow:0 12px 24px rgba(214,163,19,.22);
}

.mt5-guide-window{
  position:absolute;
  inset:74px 34px 82px;
  border:2px solid rgba(214,163,19,.3);
  border-radius:16px;
  background:
    linear-gradient(90deg, rgba(34,197,94,.16) 0 18%, transparent 18% 42%, rgba(239,68,68,.13) 42% 58%, transparent 58% 100%),
    linear-gradient(180deg, rgba(255,255,255,.65), rgba(255,255,255,.18));
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.28);
}

.mt5-guide-arrow{
  top:48%;
  transform:rotate(-4deg);
}

.mt5-guide-controls{
  display:flex;
  flex-direction:column;
  gap:10px;
  align-self:stretch;
  justify-content:center;
}

.mt5-step-dots{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:10px 0 18px;
}

.mt5-step-dots button{
  width:42px;
  height:34px;
  border-radius:999px;
  border:1px solid var(--border);
  background:var(--panel);
  color:var(--text);
  font-weight:950;
  cursor:pointer;
}

.mt5-step-dots button.active{
  background:var(--accent);
  color:#111;
  border-color:var(--accent);
  box-shadow:0 10px 24px rgba(214,163,19,.24);
}

.active-guide-step{
  border-color:var(--accent);
  box-shadow:0 0 0 1px rgba(214,163,19,.35), var(--fox-shadow-sm);
}

.foxx-chat-inline-status{
  margin:8px auto;
  padding:9px 12px;
  border-radius:12px;
  border:1px solid var(--border);
  color:var(--text-muted);
  font-weight:850;
  text-align:center;
  background:var(--panel);
}

.foxx-chat-inline-status.success{
  border-color:rgba(34,197,94,.35);
  color:#16a34a;
}

.foxx-chat-inline-status.error{
  border-color:rgba(239,68,68,.35);
  color:#dc2626;
}

.foxx-generated-chart{
  position:relative;
  min-height:260px;
  border:1px solid var(--border);
  border-radius:18px;
  overflow:hidden;
  background:
    linear-gradient(90deg, rgba(0,0,0,.06) 1px, transparent 1px),
    linear-gradient(180deg, rgba(0,0,0,.06) 1px, transparent 1px),
    linear-gradient(135deg, rgba(214,163,19,.12), rgba(34,197,94,.08), rgba(59,130,246,.08));
  background-size:44px 44px, 44px 44px, auto;
  padding:18px;
}

.foxx-chart-brand{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  font-weight:950;
  color:var(--text);
}

.foxx-chart-brand img{
  width:28px;
  height:28px;
  object-fit:contain;
}

.foxx-chart-title{
  margin-top:14px;
  font-size:18px;
  font-weight:950;
}

.foxx-chart-candles{
  position:absolute;
  left:18%;
  right:12%;
  top:42%;
  height:72px;
  background:
    linear-gradient(90deg, transparent 0 6%, #22c55e 6% 10%, transparent 10% 20%, #ef4444 20% 24%, transparent 24% 38%, #22c55e 38% 42%, transparent 42% 58%, #22c55e 58% 62%, transparent 62% 76%, #ef4444 76% 80%, transparent 80% 100%);
  filter:drop-shadow(0 8px 16px rgba(0,0,0,.18));
}

.foxx-chart-zone{
  position:absolute;
  left:10%;
  right:10%;
  height:3px;
  background:var(--accent);
  box-shadow:0 0 16px rgba(214,163,19,.35);
}

.foxx-chart-zone.top{top:34%;}
.foxx-chart-zone.bottom{top:70%; opacity:.72;}

.foxx-chart-callout{
  position:absolute;
  right:16px;
  bottom:16px;
  max-width:260px;
  padding:10px 12px;
  border:1px solid rgba(214,163,19,.32);
  border-radius:14px;
  background:rgba(255,255,255,.86);
  color:#111;
  font-weight:850;
}

.campus-checkpoints{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin:12px 0;
}

.campus-checkpoints span{
  border:1px solid var(--border);
  border-radius:999px;
  padding:6px 9px;
  font-size:11px;
  font-weight:900;
  color:var(--text-muted);
}

.campus-classroom-grid,
.campus-access-list{
  display:grid;
  gap:10px;
}

.campus-classroom-grid{
  grid-template-columns:repeat(2,minmax(0,1fr));
}

@media (max-width: 720px){
  .knowledge-toolbar{grid-template-columns:1fr;}
  .campus-hero,
  .campus-path-grid,
  .campus-classroom-grid,
  .mt5-guide-stage{grid-template-columns:1fr;}
}

@media (max-width: 1180px){
  .campus-path-grid{grid-template-columns:1fr;}
}
@media(max-width:1200px){.signal-asset-grid{grid-template-columns:1fr;}.signal-time-row{grid-template-columns:1fr;}}

/* =========================================================
   FOXX SIGNAL COCKPIT
   ========================================================= */
.signal-cockpit-hero{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(240px,360px);
  gap:22px;
  align-items:center;
}

.signal-cockpit-stats{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
}

.signal-cockpit-stats div,
.signal-performance-card{
  border:1px solid var(--border);
  border-radius:12px;
  background:var(--surface);
}

.signal-cockpit-stats div{
  padding:14px;
}

.signal-cockpit-stats span,
.signal-mini-levels span,
.signal-performance-toggle span{
  display:block;
  color:var(--muted);
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
}

.signal-cockpit-stats strong{
  display:block;
  margin-top:5px;
  color:var(--accent);
  font-size:28px;
  font-weight:950;
}

.signal-cockpit-toolbar{
  display:flex;
  flex-direction:column;
  gap:14px;
}

.signal-tab-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.signal-tab{
  min-height:38px;
  padding:0 14px;
  border:1px solid var(--border);
  border-radius:10px;
  background:var(--surface);
  color:var(--text);
  font-weight:900;
  cursor:pointer;
}

.signal-tab span{
  margin-left:8px;
  color:var(--accent);
}

.signal-tab.active,
.signal-tab:hover{
  background:var(--accent);
  border-color:var(--accent);
  color:#111;
}

.signal-tab.active span,
.signal-tab:hover span{
  color:#111;
}

.signal-filter-grid{
  display:grid;
  grid-template-columns:minmax(220px,1fr) minmax(180px,260px);
  gap:10px;
}

.signal-performance-strip{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
  margin:18px 0;
}

.signal-performance-toggle{
  width:100%;
  min-height:58px;
  padding:11px 13px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  border:0;
  background:transparent;
  color:var(--text);
  cursor:pointer;
  text-align:left;
  font-weight:900;
}

.signal-performance-toggle strong{
  color:var(--accent);
}

.signal-performance-body{
  padding:0 12px 12px;
}

.signal-cockpit-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}

.signal-market-groups{
  display:flex;
  flex-direction:column;
  gap:22px;
  margin-top:18px;
}

.signal-market-group{
  padding:18px;
  border:1px solid var(--border);
  border-radius:16px;
  background:linear-gradient(180deg, rgba(214,163,19,.05), transparent), var(--surface);
}

.signal-market-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:16px;
  padding-bottom:14px;
  border-bottom:1px solid var(--border);
}

.signal-market-head h3{
  margin:2px 0 0;
  font-size:24px;
  font-weight:950;
}

.signal-market-head > span{
  color:var(--accent);
  font-size:12px;
  font-weight:950;
  text-transform:uppercase;
}

.signal-market-assets{
  display:flex;
  flex-direction:column;
  gap:16px;
  margin-top:16px;
}

.signal-asset-cockpit-section{
  padding:14px;
  border:1px solid var(--border);
  border-radius:14px;
  background:rgba(0,0,0,.03);
}

.signal-asset-cockpit-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
  margin-bottom:12px;
}

.signal-asset-cockpit-head span{
  color:var(--muted);
  font-size:11px;
  font-weight:950;
  text-transform:uppercase;
}

.signal-asset-cockpit-head h4{
  margin:3px 0 0;
  font-size:20px;
  font-weight:950;
}

.signal-asset-counts{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.signal-asset-counts span{
  padding:6px 8px;
  border:1px solid var(--border);
  border-radius:999px;
  background:var(--surface);
  color:var(--text);
}

.signal-asset-signal-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}

.signal-asset-performance-row{
  margin-top:12px;
}

.signal-asset-performance-row .signal-performance-card{
  background:rgba(214,163,19,.06);
}

.signal-mini-card{
  min-height:260px;
  padding:18px;
  border-radius:14px;
  border:1px solid var(--border);
  background:var(--surface);
}

.signal-mini-card.active.buy{
  border-color:rgba(25,196,105,.45);
}

.signal-mini-card.active.sell{
  border-color:rgba(255,91,91,.45);
}

.signal-mini-card.wait{
  opacity:.86;
  border-style:dashed;
}

.signal-mini-top,
.signal-mini-footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}

.signal-mini-top span,
.signal-mini-footer span{
  color:var(--muted);
  font-size:12px;
  font-weight:900;
}

.signal-mini-top strong{
  color:var(--accent);
  font-size:13px;
  font-weight:950;
}

.signal-mini-card h3{
  margin:12px 0;
  font-size:21px;
  font-weight:950;
}

.signal-mini-card p{
  color:var(--text);
  line-height:1.55;
}

.signal-mini-levels{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
  margin:12px 0;
}

.signal-mini-levels div{
  padding:9px;
  border:1px solid var(--border);
  border-radius:10px;
  background:rgba(0,0,0,.04);
}

.signal-mini-levels strong{
  display:block;
  margin-top:3px;
  font-size:13px;
}

.signal-mini-note{
  margin-top:16px;
  padding:10px;
  border-left:3px solid var(--accent);
  background:rgba(214,163,19,.08);
  color:var(--text);
  line-height:1.5;
}

@media(max-width:1280px){
  .signal-performance-strip{grid-template-columns:repeat(2,minmax(0,1fr));}
  .signal-cockpit-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .signal-asset-signal-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}

@media(max-width:760px){
  .signal-cockpit-hero,
  .signal-filter-grid,
  .signal-performance-strip,
  .signal-cockpit-grid{grid-template-columns:1fr;}
  .signal-cockpit-stats{grid-template-columns:repeat(3,minmax(0,1fr));}
  .signal-asset-signal-grid{grid-template-columns:1fr;}
  .signal-market-head,
  .signal-asset-cockpit-head{align-items:flex-start;flex-direction:column;}
}

/* =========================================================
   FOXX AGENT CONTROL
   ========================================================= */
.agent-control-kpis{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  margin:18px 0;
}

.agent-control-kpis article{
  padding:18px;
  border:1px solid var(--border);
  border-radius:14px;
  background:var(--surface);
}

.agent-control-kpis span{
  display:block;
  color:var(--muted);
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
}

.agent-control-kpis strong{
  display:block;
  margin-top:6px;
  color:var(--accent);
  font-size:28px;
  font-weight:950;
}

.agent-control-card{
  min-height:300px;
}

@media(max-width:900px){
  .agent-control-kpis{grid-template-columns:repeat(2,minmax(0,1fr));}
}

@media(max-width:560px){
  .agent-control-kpis{grid-template-columns:1fr;}
}

/* =========================================================
   FOXX MOBILE INSTALL / PHONE UX
   ========================================================= */
.mobile-install-hero{
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(260px,.8fr);
  gap:22px;
  align-items:center;
}

.mobile-install-copy h2{
  margin:8px 0 12px;
  font-size:clamp(30px, 4vw, 54px);
  line-height:1.02;
}

.mobile-install-copy p{
  color:var(--fox-text-soft);
  line-height:1.7;
  max-width:760px;
}

.mobile-qr-card{
  border:1px solid var(--fox-border);
  border-radius:22px;
  background:var(--fox-panel-2);
  padding:18px;
  display:grid;
  place-items:center;
  gap:10px;
  text-align:center;
  box-shadow:var(--fox-shadow-sm);
}

.mobile-qr-img{
  width:min(260px, 72vw);
  aspect-ratio:1;
  border-radius:16px;
  padding:10px;
  background:#fff;
}

.mobile-qr-card strong{
  font-size:18px;
  font-weight:950;
}

.mobile-qr-card span{
  max-width:100%;
  overflow-wrap:anywhere;
  color:var(--fox-text-dim);
  font-size:12px;
  line-height:1.45;
}

.foxx-voice-player-slot{
    width:min(360px, 100%);
    border:1px solid var(--fox-border-soft);
    border-radius:12px;
    background:var(--fox-panel-2);
  padding:8px 10px;
  display:grid;
  gap:5px;
}

.foxx-voice-player-label{
  font-size:10px;
  font-weight:900;
  color:var(--fox-text-dim);
  text-transform:uppercase;
}

.foxx-voice-player-slot audio{
    width:100%;
    height:32px;
  }

  .foxx-voice-player-inline{
    width:min(760px, calc(100% - 48px));
    margin:8px auto 0;
    box-shadow:var(--fox-shadow-soft);
    border-color:var(--fox-gold);
    background:linear-gradient(135deg, rgba(238,185,35,.16), var(--fox-panel));
  }

  .foxx-voice-player-inline audio{
    height:42px;
    margin-top:6px;
  }

  .foxx-voice-open-link{
    display:inline-flex;
    margin-top:6px;
    color:var(--fox-gold);
    font-size:12px;
    font-weight:900;
    text-decoration:none;
  }

.visual-practice-card{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.mini-trading-chart{
  position:relative;
  min-height:180px;
  border:1px solid rgba(214,163,19,.25);
  border-radius:10px;
  overflow:hidden;
  background:#0c0f12;
  color:#f7f2df;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.03);
}

.mini-chart-head{
  position:absolute;
  left:10px;
  right:10px;
  top:8px;
  z-index:4;
  display:flex;
  justify-content:space-between;
  gap:10px;
  font-size:11px;
}

.mini-chart-head strong{font-size:13px;font-weight:950;}
.mini-chart-head span{color:var(--accent);font-weight:900;}

.mini-chart-grid{
  position:absolute;
  inset:0;
  background:
    linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px) 0 0 / 100% 25%,
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px) 0 0 / 14.28% 100%;
}

.mini-bb{
  position:absolute;
  left:8%;
  right:8%;
  height:1px;
  border-top:1px dashed rgba(87,160,255,.85);
  z-index:2;
}
.mini-bb.upper{top:28%;border-radius:50%;transform:skewY(-4deg);}
.mini-bb.middle{top:48%;border-color:rgba(255,255,255,.45);}
.mini-bb.lower{top:68%;transform:skewY(4deg);}

.mini-zone{
  position:absolute;
  left:7%;
  right:7%;
  height:22px;
  z-index:1;
  border-radius:6px;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  padding-right:8px;
  font-size:9px;
  font-weight:900;
}
.mini-zone.resistance{top:31%;background:rgba(255,84,84,.13);border-top:1px solid rgba(255,84,84,.7);}
.mini-zone.support{bottom:19%;background:rgba(20,190,112,.13);border-bottom:1px solid rgba(20,190,112,.75);}

.mini-fibo{
  position:absolute;
  left:15%;
  right:25%;
  top:54%;
  height:18px;
  border:1px solid rgba(214,163,19,.7);
  background:rgba(214,163,19,.12);
  border-radius:5px;
  z-index:2;
  font-size:9px;
  font-weight:900;
  padding:2px 6px;
}

.mini-candles{
  position:absolute;
  left:8%;
  right:8%;
  bottom:32px;
  top:34px;
  z-index:3;
}

.mini-candles i{
  position:absolute;
  bottom:calc((var(--i) * 7px) + 8px);
  left:calc(var(--i) * 12.5%);
  width:9px;
  height:calc(var(--h) * 1px);
  border-radius:3px;
}
.mini-candles i::before{
  content:"";
  position:absolute;
  left:4px;
  top:-12px;
  bottom:-10px;
  border-left:1px solid currentColor;
  opacity:.9;
}
.mini-candles i.g{background:#19c37d;color:#19c37d;}
.mini-candles i.r{background:#ff5a5f;color:#ff5a5f;}

.mini-chart-note{
  position:absolute;
  left:10px;
  bottom:8px;
  z-index:4;
  font-size:10px;
  color:rgba(247,242,223,.78);
}

@media (max-width: 820px){
  :root{
    --sidebar-width:100%;
    --topbar-height:auto;
  }

  .app-shell,
  #foxx-root{
    display:block;
  }

  .sidebar{
    position:relative;
    width:100%;
    height:auto;
    max-height:none;
    border-right:0;
    border-bottom:1px solid var(--fox-border-soft);
  }

  .sidebar-nav{
    max-height:none;
  }

  .sidebar-section-items{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:8px;
  }

  .main-wrap,
  .main-content,
  #app-main{
    width:100%;
    margin-left:0;
    padding-left:12px;
    padding-right:12px;
  }

  .topbar{
    position:sticky;
    top:0;
    z-index:20;
    min-height:auto;
    display:grid;
    grid-template-columns:1fr;
    gap:10px;
    padding:12px;
  }

  .topbar-center,
  .topbar-right{
    justify-content:flex-start;
    flex-wrap:wrap;
  }

  .dashboard-grid,
  .news-cards-grid,
  .foxx-reference-card-grid,
  .analysis-detail-grid,
  .foxx-explained-grid,
  .mobile-install-hero{
    grid-template-columns:1fr;
  }

  .content-section,
  .dashboard-card,
  .news-card,
  .campus-course-card{
    border-radius:16px;
  }

  .foxx-voice-main-btn,
  .primary-btn,
  .secondary-btn,
  .card-open-btn{
    min-height:44px;
  }
}

/* FOXX Campus step-by-step learning */
.campus-stepper{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
  padding:12px;
  margin:14px 0 18px;
}

.campus-step{
  min-height:58px;
  border:1px solid var(--border);
  border-radius:12px;
  background:var(--surface);
  color:var(--text);
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px;
  cursor:pointer;
  text-align:left;
}

.campus-step span{
  width:28px;
  height:28px;
  border-radius:999px;
  display:grid;
  place-items:center;
  background:var(--surface-2);
  color:var(--accent);
  font-weight:950;
  flex:0 0 auto;
}

.campus-step strong{
  font-size:13px;
  line-height:1.2;
}

.campus-step.active{
  border-color:var(--accent);
  background:linear-gradient(135deg,rgba(212,160,23,.24),var(--surface));
  box-shadow:0 12px 28px rgba(212,160,23,.16);
}

.campus-answer-list{
  display:grid;
  gap:8px;
  margin:12px 0;
}

.campus-answer{
  min-height:44px;
  border:1px solid var(--border);
  border-radius:10px;
  background:var(--surface-2);
  color:var(--text);
  padding:10px 12px;
  text-align:left;
  font-weight:800;
  cursor:pointer;
}

.campus-answer.selected{
  border-color:var(--accent);
  background:rgba(212,160,23,.14);
}

.campus-answer.correct{
  border-color:#22c55e;
  background:rgba(34,197,94,.12);
}

.campus-answer-feedback{
  margin-top:10px;
  border-radius:10px;
  padding:10px 12px;
  font-weight:800;
  line-height:1.5;
}

.campus-answer-feedback.correct{
  border:1px solid rgba(34,197,94,.45);
  background:rgba(34,197,94,.10);
}

.campus-answer-feedback.wrong{
  border:1px solid rgba(245,158,11,.45);
  background:rgba(245,158,11,.10);
}

.campus-lesson-actions{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:8px;
  margin-top:12px;
}

@media (max-width: 760px){
  .campus-stepper,
  .campus-lesson-actions{
    grid-template-columns:1fr;
  }
}
