/* ============================================
   FlowTrader AI – App UI Mockups
   Täuschend echte CSS-Darstellungen der App
   ============================================ */

/* ── App Frame / Phone/Browser Container ── */
.app-frame {
  background: #0f1117;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.04);
  position: relative;
  font-size: 12px;
  line-height: 1.4;
}

.app-frame .titlebar {
  background: #1a1d23;
  padding: 10px 16px;
  display: flex;
  align-items: center;
  gap: 8px;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.app-frame .titlebar .dots { display: flex; gap: 5px; }
.app-frame .titlebar .dot {
  width: 10px; height: 10px; border-radius: 50%;
}
.app-frame .titlebar .dot-r { background: #ff5f57; }
.app-frame .titlebar .dot-y { background: #ffbd2e; }
.app-frame .titlebar .dot-g { background: #28c840; }
.app-frame .titlebar .url-bar {
  flex: 1; background: rgba(255,255,255,.06); border-radius: 6px;
  padding: 4px 12px; font-size: 11px; color: #94a3b8;
  text-align: center; margin: 0 8px;
}

/* ── App Sidebar ── */
.app-layout { display: flex; height: 100%; min-height: 380px; }
.app-sidebar {
  width: 48px; background: #12151b;
  border-right: 1px solid rgba(255,255,255,.06);
  display: flex; flex-direction: column; align-items: center;
  padding: 12px 0; gap: 4px; flex-shrink: 0;
}
.app-sidebar .logo-icon {
  width: 30px; height: 30px; border-radius: 8px;
  background: rgba(78,212,172,.15); display: flex; align-items: center;
  justify-content: center; font-size: 14px; margin-bottom: 8px;
}
.app-sidebar .nav-icon {
  width: 32px; height: 32px; border-radius: 8px; display: flex;
  align-items: center; justify-content: center; font-size: 14px;
  color: #64748b; cursor: pointer; transition: .2s;
}
.app-sidebar .nav-icon.active {
  background: rgba(78,212,172,.12); color: #4ed4ac;
}
.app-content { flex: 1; overflow: hidden; padding: 16px; }

/* ── Dashboard Mockup ── */
.mock-dashboard-header {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 14px;
}
.mock-dashboard-header h4 { font-size: 13px; font-weight: 700; color: #e2e8f0; }
.mock-dashboard-header span { font-size: 10px; color: #64748b; }

.mock-stats-row { display: grid; grid-template-columns: repeat(4,1fr); gap: 8px; margin-bottom: 14px; }
.mock-stat {
  background: #1a1d23; border: 1px solid rgba(255,255,255,.06);
  border-radius: 10px; padding: 10px;
}
.mock-stat .label { font-size: 9px; color: #64748b; margin-bottom: 4px; text-transform: uppercase; letter-spacing: .05em; }
.mock-stat .value { font-size: 15px; font-weight: 800; }
.mock-stat .value.green { color: #4ed4ac; }
.mock-stat .value.red { color: #ef4444; }
.mock-stat .value.white { color: #e2e8f0; }
.mock-stat .sub { font-size: 9px; color: #64748b; margin-top: 2px; }

.mock-chart-area {
  background: #1a1d23; border: 1px solid rgba(255,255,255,.06);
  border-radius: 10px; padding: 12px; margin-bottom: 10px;
}
.mock-chart-area .chart-label { font-size: 10px; color: #94a3b8; margin-bottom: 10px; font-weight: 600; }
.mock-bars { display: flex; align-items: flex-end; gap: 3px; height: 60px; }
.mock-bar {
  flex: 1; border-radius: 3px 3px 0 0; min-width: 4px;
  transition: height .3s;
}
.mock-bar.pos { background: rgba(78,212,172,.7); }
.mock-bar.neg { background: rgba(239,68,68,.6); }

.mock-emotion-row { display: flex; gap: 6px; flex-wrap: wrap; }
.mock-emotion-tag {
  padding: 3px 8px; border-radius: 5px; font-size: 9px; font-weight: 600;
}
.mock-emotion-tag.calm { background: rgba(78,212,172,.15); color: #4ed4ac; }
.mock-emotion-tag.gier { background: rgba(239,68,68,.15); color: #fca5a5; }
.mock-emotion-tag.fear { background: rgba(245,158,11,.15); color: #fcd34d; }
.mock-emotion-tag.neut { background: rgba(100,116,139,.15); color: #94a3b8; }

/* ── Journal Mockup ── */
.mock-journal-entry {
  background: #1a1d23; border: 1px solid rgba(255,255,255,.06);
  border-radius: 10px; padding: 12px; margin-bottom: 8px;
}
.mock-journal-header { display: flex; justify-content: space-between; margin-bottom: 8px; }
.mock-journal-header .market { font-size: 11px; font-weight: 700; color: #e2e8f0; }
.mock-journal-header .result { font-size: 11px; font-weight: 800; }
.mock-journal-header .result.win { color: #4ed4ac; }
.mock-journal-header .result.loss { color: #ef4444; }
.mock-journal-meta { display: flex; gap: 8px; margin-bottom: 8px; flex-wrap: wrap; }
.mock-tag {
  padding: 2px 7px; border-radius: 4px; font-size: 9px; font-weight: 600;
}
.mock-tag.emotion { background: rgba(239,68,68,.12); color: #fca5a5; }
.mock-tag.rule { background: rgba(78,212,172,.12); color: #4ed4ac; }
.mock-tag.date { background: rgba(100,116,139,.1); color: #94a3b8; }
.mock-stars { color: #f59e0b; font-size: 10px; }
.mock-ai-badge {
  display: inline-flex; align-items: center; gap: 4px;
  background: rgba(78,212,172,.08); border: 1px solid rgba(78,212,172,.15);
  border-radius: 5px; padding: 4px 8px; font-size: 9px; color: #4ed4ac;
  margin-top: 6px;
}

/* ── Coach Mockup ── */
.mock-chat { display: flex; flex-direction: column; gap: 8px; }
.mock-msg {
  max-width: 85%; border-radius: 10px; padding: 8px 12px;
  font-size: 10px; line-height: 1.5;
}
.mock-msg.ai {
  background: #1a1d23; border: 1px solid rgba(78,212,172,.12);
  color: #94a3b8; align-self: flex-start;
}
.mock-msg.ai .ai-name { font-size: 9px; color: #4ed4ac; font-weight: 700; margin-bottom: 3px; }
.mock-msg.user {
  background: rgba(78,212,172,.1); color: #e2e8f0;
  align-self: flex-end;
}
.mock-chat-input {
  background: #1a1d23; border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px; padding: 8px 12px; margin-top: 8px;
  display: flex; align-items: center; justify-content: space-between;
}
.mock-chat-input span { font-size: 10px; color: #64748b; }
.mock-chat-input .send-btn {
  width: 24px; height: 24px; border-radius: 6px;
  background: #4ed4ac; display: flex; align-items: center; justify-content: center;
  font-size: 11px;
}

/* ── Disziplin/Challenge Mockup ── */
.mock-level-badge {
  background: linear-gradient(135deg, rgba(78,212,172,.2), rgba(59,130,246,.1));
  border: 1px solid rgba(78,212,172,.25);
  border-radius: 10px; padding: 12px; margin-bottom: 10px;
  display: flex; align-items: center; gap: 10px;
}
.mock-level-icon {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(78,212,172,.15); display: flex; align-items: center;
  justify-content: center; font-size: 18px; flex-shrink: 0;
}
.mock-level-info .level-name { font-size: 12px; font-weight: 800; color: #4ed4ac; }
.mock-level-info .level-sub { font-size: 9px; color: #64748b; }
.mock-progress-bar {
  height: 4px; background: rgba(255,255,255,.06); border-radius: 2px;
  margin-top: 6px; overflow: hidden;
}
.mock-progress-bar .fill { height: 100%; background: #4ed4ac; border-radius: 2px; }

.mock-challenge {
  background: #1a1d23; border: 1px solid rgba(255,255,255,.06);
  border-radius: 10px; padding: 10px; margin-bottom: 6px;
  display: flex; align-items: center; gap: 10px;
}
.mock-challenge .check-circle {
  width: 20px; height: 20px; border-radius: 50%; flex-shrink: 0;
  border: 2px solid rgba(78,212,172,.3);
  display: flex; align-items: center; justify-content: center;
}
.mock-challenge .check-circle.done { background: #4ed4ac; border-color: #4ed4ac; }
.mock-challenge .check-circle.done::after { content: '✓'; font-size: 10px; color: #0a0c10; font-weight: 800; }
.mock-challenge .ch-text { font-size: 10px; color: #94a3b8; flex: 1; }
.mock-challenge .ch-pts { font-size: 9px; color: #4ed4ac; font-weight: 700; }

/* ── Mindset / Hypnose Mockup ── */
.mock-session-card {
  background: #1a1d23; border: 1px solid rgba(255,255,255,.06);
  border-radius: 10px; padding: 12px; margin-bottom: 6px;
  display: flex; align-items: center; gap: 10px;
}
.mock-session-thumb {
  width: 40px; height: 40px; border-radius: 8px;
  background: linear-gradient(135deg, rgba(78,212,172,.2), rgba(59,130,246,.15));
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; flex-shrink: 0;
}
.mock-session-info .title { font-size: 11px; font-weight: 700; color: #e2e8f0; }
.mock-session-info .sub { font-size: 9px; color: #64748b; }
.mock-play-btn {
  width: 28px; height: 28px; border-radius: 50%;
  background: rgba(78,212,172,.15); border: 1px solid rgba(78,212,172,.3);
  display: flex; align-items: center; justify-content: center;
  font-size: 10px; color: #4ed4ac; flex-shrink: 0;
}

/* ── Mini Player ── */
.mock-mini-player {
  position: absolute; bottom: 12px; right: 12px;
  background: #1a1d23; border: 1px solid rgba(78,212,172,.2);
  border-radius: 12px; padding: 8px 12px;
  display: flex; align-items: center; gap: 8px;
  box-shadow: 0 4px 20px rgba(0,0,0,.4);
  z-index: 10;
}
.mock-mini-player .track { font-size: 9px; color: #94a3b8; }
.mock-mini-player .track strong { display: block; color: #e2e8f0; font-size: 10px; }
.mock-mini-player .controls { display: flex; gap: 4px; }
.mock-mini-player .ctrl {
  width: 20px; height: 20px; border-radius: 50%;
  background: rgba(78,212,172,.1); display: flex; align-items: center;
  justify-content: center; font-size: 9px; color: #4ed4ac;
}
.mock-mini-player .ctrl.main { background: #4ed4ac; color: #0a0c10; }

/* ── Streak / Achievement ── */
.mock-streak-row { display: flex; gap: 6px; margin-bottom: 10px; }
.mock-streak-day {
  width: 28px; height: 28px; border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; flex-shrink: 0;
}
.mock-streak-day.done { background: rgba(78,212,172,.15); }
.mock-streak-day.miss { background: rgba(239,68,68,.1); }
.mock-streak-day.today {
  background: rgba(78,212,172,.25);
  border: 1px solid rgba(78,212,172,.4);
}

.mock-achievement {
  display: flex; gap: 8px; align-items: center;
  background: #1a1d23; border: 1px solid rgba(255,255,255,.06);
  border-radius: 8px; padding: 8px 10px; margin-bottom: 5px;
}
.mock-achievement .badge { font-size: 18px; flex-shrink: 0; }
.mock-achievement .ach-title { font-size: 10px; font-weight: 700; color: #e2e8f0; }
.mock-achievement .ach-sub { font-size: 9px; color: #64748b; }
.mock-achievement .unlocked { font-size: 9px; color: #4ed4ac; margin-left: auto; }

/* Responsive */
@media (max-width: 768px) {
  .mock-stats-row { grid-template-columns: repeat(2, 1fr); }
  .app-sidebar { display: none; }
}
