/* ============================================================
   PANELS — Header bar, function keys, panel chrome, tables
   ============================================================ */

/* ---------- Top header bar ---------- */
.header-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: linear-gradient(180deg, var(--header-blue) 0%, var(--header-blue-2) 100%);
  border-bottom: 1px solid var(--border);
  padding: 4px 10px;
  height: 30px;
  font-size: var(--fs-sm);
}
.header-left, .header-center, .header-right {
  display: flex;
  align-items: center;
  gap: 8px;
}
.header-logo {
  background: var(--amber);
  color: var(--bg-black);
  font-weight: 700;
  padding: 1px 6px;
  border-radius: var(--radius);
  letter-spacing: 1px;
}
.header-title { color: var(--white-warm); font-weight: 600; letter-spacing: 1px; }
.header-name { color: var(--amber); font-weight: 700; letter-spacing: 1px; }
.header-role { color: var(--white-warm); letter-spacing: 0.5px; }
.header-separator { color: var(--blue-accent); opacity: 0.6; }
.header-clock {
  color: var(--green-up);
  font-weight: 600;
  min-width: 70px;
  text-align: right;
}

.lang-toggle { display: flex; align-items: center; gap: 3px; }
.lang-btn {
  background: transparent;
  border: none;
  color: var(--white-warm);
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  cursor: pointer;
  padding: 1px 4px;
  border-radius: var(--radius);
  opacity: 0.6;
}
.lang-btn.active {
  color: var(--amber);
  opacity: 1;
  font-weight: 700;
  background: rgba(0, 0, 0, 0.3);
}
.lang-btn:hover { opacity: 1; color: var(--amber); }
.lang-separator { color: var(--white-warm); opacity: 0.4; }

/* ---------- Function key bar ---------- */
.fkey-bar {
  display: flex;
  background: var(--bg-near-black);
  border-bottom: 1px solid var(--border);
  height: 32px;
}
.fkey-btn {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  background: transparent;
  border: none;
  border-right: 1px solid var(--border);
  color: var(--white-warm);
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  cursor: pointer;
  transition: background 0.12s, color 0.12s;
  letter-spacing: 0.5px;
}
.fkey-btn:last-child { border-right: none; }
.fkey-label {
  color: var(--blue-accent);
  font-weight: 700;
  font-size: var(--fs-xs);
}
.fkey-text { font-weight: 600; }
.fkey-btn:hover { background: var(--bg-panel); color: var(--amber); }
.fkey-btn:hover .fkey-label { color: var(--amber); }
.fkey-btn.active {
  background: var(--amber);
  color: var(--bg-black);
}
.fkey-btn.active .fkey-label,
.fkey-btn.active .fkey-text { color: var(--bg-black); }
.fkey-home .fkey-label { color: var(--green-up); }

/* ---------- Panel chrome ---------- */
.panel {
  background: var(--bg-panel);
  border: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
}
.panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: linear-gradient(180deg, var(--panel-head) 0%, var(--panel-head-2) 100%);
  border-bottom: 1px solid var(--border);
  padding: 3px 8px;
  min-height: 22px;
}
.panel-title {
  color: var(--amber);
  font-weight: 700;
  font-size: var(--fs-sm);
  letter-spacing: 1px;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 6px;
}
.panel-title::before {
  content: "▌";
  color: var(--amber);
}
.panel-meta {
  color: var(--grey-text);
  font-size: var(--fs-xs);
  font-weight: 600;
}
.panel-body {
  padding: var(--pad);
  overflow-y: auto;
  flex: 1;
}

/* ---------- Data tables ---------- */
.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-sm);
}
.data-table th {
  text-align: left;
  color: var(--grey-text);
  text-transform: uppercase;
  font-size: var(--fs-xs);
  letter-spacing: 0.5px;
  padding: 4px 8px;
  border-bottom: 1px solid var(--border);
  font-weight: 600;
  background: linear-gradient(180deg, #1d1d1d 0%, #141414 100%);
}
.data-table td {
  padding: 4px 8px;
  border-bottom: 1px solid #222;
  vertical-align: top;
}
.data-table tr:hover td { background: rgba(255, 153, 0, 0.05); }

/* Key/value description rows (DES style) */
.kv-row {
  display: flex;
  border-bottom: 1px solid #222;
  padding: 4px 0;
  gap: 10px;
}
.kv-key {
  color: var(--label);
  text-transform: uppercase;
  font-size: var(--fs-xs);
  letter-spacing: 0.5px;
  min-width: 110px;
  font-weight: 600;
  padding-top: 1px;
}
.kv-val { color: var(--white-warm); flex: 1; }
.kv-val a { word-break: break-all; }

/* Section heading inside panels */
.section-label {
  color: var(--amber);
  text-transform: uppercase;
  font-size: var(--fs-xs);
  letter-spacing: 1px;
  font-weight: 700;
  margin: 12px 0 6px;
  border-bottom: 1px dashed var(--border);
  padding-bottom: 3px;
}
.section-label:first-child { margin-top: 0; }

/* Bullet lists */
.term-list { list-style: none; }
.term-list li {
  position: relative;
  padding-left: 16px;
  margin-bottom: 4px;
  color: var(--white-warm);
}
.term-list li::before {
  content: "›";
  position: absolute;
  left: 0;
  color: var(--amber);
  font-weight: 700;
}

/* Tags / chips */
.tag {
  display: inline-block;
  background: var(--bg-near-black);
  border: 1px solid var(--border-light);
  color: var(--amber);
  font-size: var(--fs-xs);
  padding: 1px 6px;
  border-radius: var(--radius);
  margin: 2px 3px 2px 0;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* Stat boxes */
.stat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
  gap: var(--gap);
}
.stat-box {
  background: var(--bg-near-black);
  border: 1px solid var(--border);
  padding: 8px;
}
.stat-label {
  color: var(--grey-text);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.stat-value {
  color: var(--amber);
  font-size: var(--fs-lg);
  font-weight: 700;
  display: flex;
  align-items: baseline;
  gap: 5px;
}
.trend-up   { color: var(--green-up); font-size: var(--fs-sm); }
.trend-down { color: var(--red-down); font-size: var(--fs-sm); }
.trend-flat { color: var(--blue-accent); font-size: var(--fs-sm); }

/* Buttons (Bloomberg action) */
.btn {
  background: var(--bg-near-black);
  border: 1px solid var(--amber);
  color: var(--amber);
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 6px 14px;
  cursor: pointer;
  border-radius: var(--radius);
  transition: background 0.12s, color 0.12s;
}
.btn:hover { background: var(--amber); color: var(--bg-black); }
.btn-green { border-color: var(--green-up); color: var(--green-up); }
.btn-green:hover { background: var(--green-up); color: var(--bg-black); }
.btn-blue { border-color: var(--blue-accent); color: var(--blue-accent); }
.btn-blue:hover { background: var(--blue-accent); color: var(--bg-black); }
/* Solid amber action button (orange bg, black font) */
.btn-amber { background: var(--amber); border-color: var(--amber); color: #000; }
.btn-amber:hover { background: var(--amber-bright); border-color: var(--amber-bright); color: #000; }

/* Message composer (MSG / chat-style) */
.msg-form { max-width: 640px; }
.msg-field { margin-bottom: 10px; }
.msg-label {
  display: block;
  color: var(--label);
  text-transform: uppercase;
  font-size: var(--fs-xs);
  letter-spacing: 0.5px;
  margin-bottom: 3px;
}
.msg-input, .msg-textarea {
  width: 100%;
  background: var(--bg-near-black);
  border: 1px solid var(--border-light);
  color: var(--white-warm);
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  padding: 6px 8px;
  outline: none;
}
.msg-input:focus, .msg-textarea:focus { border-color: var(--amber); }
.msg-input[readonly] { color: var(--amber); opacity: 0.85; cursor: default; }
.msg-textarea { resize: vertical; min-height: 120px; line-height: 1.5; }

/* Profile photo */
.profile-photo {
  width: 96px;
  height: 96px;
  border: 1px solid var(--amber);
  background: var(--bg-near-black);
  object-fit: cover;
  display: block;
}
.profile-photo-fallback {
  width: 96px;
  height: 96px;
  border: 1px solid var(--amber);
  background: var(--bg-near-black);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--amber);
  font-size: var(--fs-xl);
  font-weight: 700;
  letter-spacing: 1px;
}

/* Skill bars */
.skill-row {
  display: grid;
  grid-template-columns: 140px 1fr 36px;
  align-items: center;
  gap: 8px;
  margin-bottom: 5px;
  font-size: var(--fs-sm);
}
.skill-name { color: var(--white-warm); }
.skill-bar-track {
  background: var(--bg-near-black);
  border: 1px solid var(--border);
  height: 12px;
  position: relative;
  overflow: hidden;
}
.skill-bar-fill {
  background: linear-gradient(90deg, var(--amber-dim), var(--amber));
  height: 100%;
  width: 0;
  transition: width 0.6s ease-out;
}
.skill-pct { color: var(--amber); text-align: right; font-weight: 600; }

/* Project card */
.project-card {
  background: var(--bg-panel);
  border: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  transition: border-color 0.12s;
}
.project-card:hover {
  border-color: var(--border-light);
}
.project-thumb {
  height: 90px;
  background: var(--bg-near-black);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--amber);
  font-size: var(--fs-xl);
  font-weight: 700;
  letter-spacing: 2px;
}
.project-body { padding: var(--pad); flex: 1; display: flex; flex-direction: column; }
.project-name { color: var(--amber); font-weight: 700; font-size: var(--fs-md); margin-bottom: 2px; }
.project-org { color: var(--grey-text); font-size: var(--fs-xs); margin-bottom: 6px; text-transform: uppercase; letter-spacing: 0.5px; }
.project-desc { color: var(--white-warm); font-size: var(--fs-sm); flex: 1; margin-bottom: 8px; }

/* Timeline (experience) */
.timeline-entry {
  border-left: 2px solid var(--border);
  padding: 0 0 14px 14px;
  position: relative;
}
.timeline-entry::before {
  content: "";
  position: absolute;
  left: -5px;
  top: 3px;
  width: 8px;
  height: 8px;
  background: var(--amber);
  border-radius: 50%;
}
.timeline-entry:last-child { padding-bottom: 0; }
.entry-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 6px;
}
.entry-company { color: var(--amber); font-weight: 700; font-size: var(--fs-md); }
.entry-period { color: var(--green-up); font-size: var(--fs-sm); font-weight: 600; }
.entry-role { color: var(--amber-bright); font-size: var(--fs-sm); font-weight: 600; margin: 1px 0 4px; }
.entry-meta { color: var(--grey-text); font-size: var(--fs-xs); }

/* Help screen */
.intro-text {
  color: var(--white-warm);
  margin-bottom: 10px;
  font-size: var(--fs-sm);
}
.tip-text {
  margin-top: 12px;
  color: var(--green-up);
  font-size: var(--fs-xs);
  border-top: 1px dashed var(--border);
  padding-top: 8px;
}

/* PDF embed */
.pdf-frame {
  width: 100%;
  height: 65vh;
  border: 1px solid var(--border);
  background: var(--bg-near-black);
}

/* Placeholder marker */
.placeholder {
  color: var(--red-down);
  font-style: italic;
  opacity: 0.8;
}

/* Button rows */
.btn-row { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 10px; }

/* Canvas chart container */
.chart-wrap { width: 100%; }
.chart-wrap canvas { width: 100%; display: block; }
