/* Hourkey — Dashboard /app v3 (Qi Men identity) */

.app-shell { padding: var(--gap-lg) 0 90px; }

.moment-row {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: var(--gap-md); flex-wrap: wrap; gap: var(--gap-md);
}
.moment-eyebrow { color: var(--text-dim); font-size: 11px; letter-spacing: 2px; text-transform: uppercase; margin-bottom: 4px; }
.moment-yam { display: flex; align-items: baseline; }

/* Action card v2 (3 columns: mode + palace + score) */
/* ★ 30-sec Tour */
.tour-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.75); backdrop-filter: blur(6px);
  z-index: 200;
  display: none; align-items: center; justify-content: center;
  padding: var(--gap-lg);
}
.tour-overlay.active { display: flex; }
.tour-tooltip {
  background: var(--navy-deep); border: 2px solid var(--gold-primary);
  border-radius: var(--r-lg); padding: var(--gap-lg);
  max-width: 420px; width: 100%;
  box-shadow: 0 12px 40px rgba(200,164,92,0.3);
  position: relative;
}
.tour-step { color: var(--gold-primary); font-size: 11px; letter-spacing: 2px; text-transform: uppercase; margin-bottom: var(--gap-sm); font-weight: 700; }
.tour-tooltip h3 { color: var(--text-primary); margin-bottom: var(--gap-sm); }
.tour-tooltip p { color: var(--text-muted); font-size: 14px; line-height: 1.6; margin-bottom: var(--gap-md); }
.tour-buttons { display: flex; gap: var(--gap-md); justify-content: flex-end; }

/* Expert Mode toggle */
.expert-toggle {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 12px; border-radius: var(--r-md);
  border: 1px solid var(--navy-border); cursor: pointer;
  background: var(--navy-medium); color: var(--text-muted);
  font-size: 12px; font-weight: 600; transition: all 0.15s;
}
.expert-toggle:has(input:checked), body.expert-mode .expert-toggle {
  background: var(--gold-bg); border-color: var(--gold-primary); color: var(--gold-primary);
}
.expert-toggle input { display: none; }

/* Expert mode reveals tech-details by default */
body.expert-mode .tech-details { display: block; }
body.expert-mode .tech-toggle { display: none; }
body.expert-mode .modal-qimen-line { font-size: 16px; padding: 8px 0; }

.personal-alert {
  margin-bottom: var(--gap-md);
  padding: var(--gap-md) var(--gap-lg);
  border-radius: var(--r-lg);
  border-left: 4px solid;
  background: rgba(15,23,41,0.7);
  backdrop-filter: blur(8px);
}
.personal-alert.severity-critical { border-left-color: var(--l5-avoid); background: rgba(239,68,68,0.1); }
.personal-alert.severity-caution  { border-left-color: var(--l2-cond); background: rgba(245,158,11,0.1); }
.personal-alert.severity-low      { border-left-color: var(--l3-observe); background: rgba(148,163,184,0.08); }
.personal-alert.severity-bonus    { border-left-color: var(--l1-strong); background: rgba(16,185,129,0.08); }
.personal-alert .pa-title { color: var(--gold-primary); font-size: 12px; letter-spacing: 1px; text-transform: uppercase; font-weight: 700; margin-bottom: 6px; }
.personal-alert .pa-line { color: var(--text-primary); font-size: 14px; line-height: 1.6; padding: 4px 0; }
.personal-alert .pa-line .cn { font-family: var(--font-cn); color: var(--gold-primary); font-weight: 600; padding: 0 4px; }
.personal-alert .pa-link { display: inline-block; margin-top: 6px; font-size: 12px; }

.qimen-verified-badge {
  display: inline-block;
  padding: 6px 14px;
  background: linear-gradient(135deg, rgba(200,164,92,0.15), rgba(200,164,92,0.05));
  border: 1px solid var(--gold-primary);
  border-radius: 999px;
  color: var(--gold-soft);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.5px;
  margin-bottom: var(--gap-md);
  font-family: var(--font-cn), var(--font-sans);
}
.action-card-v2 {
  border-width: 2px;
  background: linear-gradient(180deg, var(--navy-deep), var(--navy-medium));
  position: relative; overflow: hidden;
}
.action-card-v2::before {
  content: ''; position: absolute; inset: 0; opacity: 0.08;
  background: radial-gradient(circle at center, var(--gold-primary), transparent 60%);
  pointer-events: none;
}
.action-card-v2.level-1 { border-color: var(--l1-strong); }
.action-card-v2.level-2 { border-color: var(--l2-cond); }
.action-card-v2.level-3 { border-color: var(--l3-observe); }
.action-card-v2.level-4 { border-color: var(--l4-reduce); }
.action-card-v2.level-5 { border-color: var(--l5-avoid); }
.action-card-v2.level-6 { border-color: var(--l6-stand); }

.action-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: var(--gap-lg);
  align-items: start;
}
@media (max-width: 900px) { .action-grid { grid-template-columns: 1fr; } }

.action-mode-block .mode-level-num { color: var(--text-dim); font-family: var(--font-mono); font-size: 11px; letter-spacing: 2px; }
.action-mode-block .mode-label-th { font-size: 36px; font-weight: 800; margin: 6px 0; line-height: 1.1; }
.action-mode-block .mode-label-en { color: var(--text-muted); font-size: 14px; letter-spacing: 1px; }
.action-mode-block .mode-summary { color: var(--text-muted); margin-top: var(--gap-md); line-height: 1.6; font-size: 14px; }

.palace-block { display: flex; flex-direction: column; align-items: flex-start; gap: var(--gap-sm); }
.palace-grid svg { display: block; }
.palace-values { margin-top: var(--gap-sm); width: 100%; }

.score-block { text-align: left; }
.score-big { font-family: var(--font-mono); font-size: 64px; font-weight: 700; color: var(--gold-primary); line-height: 1; margin-top: 6px; }
.score-bar { width: 100%; height: 4px; background: var(--navy-medium); border-radius: 2px; margin-top: var(--gap-md); overflow: hidden; }
.score-fill { height: 100%; background: var(--gold-primary); transition: width 0.4s ease; }
.score-meta { font-size: 12px; margin-top: var(--gap-sm); }

@media (max-width: 600px) {
  .action-mode-block .mode-label-th { font-size: 28px; }
  .score-big { font-size: 48px; }
}

/* Clock grid (countdown + 12 yam clock + day outlook) */
.clock-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: var(--gap-lg);
}
@media (max-width: 900px) { .clock-grid { grid-template-columns: 1fr; } }

.countdown-card-v2 .countdown-num { font-family: var(--font-mono); font-size: 36px; font-weight: 700; color: var(--text-primary); margin-top: 6px; }
.countdown-card-v2 .progress-bar { width: 100%; height: 4px; background: var(--navy-border); border-radius: 2px; margin-top: var(--gap-md); overflow: hidden; }
.countdown-card-v2 .progress-fill { height: 100%; background: var(--gold-primary); transition: width 1s linear; }
.countdown-card-v2 .next-yam { padding-top: var(--gap-md); border-top: 1px solid var(--line-soft); }
.countdown-card-v2 .next-yam-line { display: flex; align-items: center; gap: var(--gap-sm); margin-top: 6px; flex-wrap: wrap; }

.clock-card { text-align: center; }
.yam-clock-wrap { display: flex; justify-content: center; align-items: center; padding: var(--gap-md) 0; }

.day-outlook .outlook-list { display: flex; flex-direction: column; gap: var(--gap-sm); margin-top: 6px; }
.outlook-row { display: grid; grid-template-columns: 14px 1fr auto; gap: var(--gap-sm); align-items: center; color: var(--text-muted); font-size: 14px; }
.outlook-row .dot { width: 10px; height: 10px; border-radius: 50%; background: var(--text-dim); }
.outlook-row .dot.l1 { background: var(--l1-strong); }
.outlook-row .dot.l3 { background: var(--l3-observe); }
.outlook-row .dot.l4 { background: var(--l4-reduce); }
.outlook-row .dot.l6 { background: var(--l6-stand); }
.outlook-row .cnt { color: var(--text-primary); }

.best-window { padding-top: var(--gap-md); border-top: 1px solid var(--line-soft); }
.best-line { display: flex; align-items: center; gap: var(--gap-sm); margin-top: 6px; flex-wrap: wrap; }

/* Banner pills */
.banner-row { display: flex; flex-wrap: wrap; gap: var(--gap-sm); margin-top: var(--gap-md); }
.banner-pill {
  padding: 6px 12px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  border: 1px solid;
}
.banner-pill.volatility_caution { color: var(--l2-cond); border-color: var(--l2-cond); background: rgba(245,158,11,0.1); }
.banner-pill.void_caution { color: var(--l3-observe); border-color: var(--l3-observe); background: rgba(148,163,184,0.1); }
.banner-pill.stand_aside { color: var(--l5-avoid); border-color: var(--l5-avoid); background: rgba(239,68,68,0.1); }

/* Guidance + risk */
.guidance-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--gap-lg); }
@media (max-width: 768px) { .guidance-grid { grid-template-columns: 1fr; } }

.guidance-card .primary-text { font-size: 16px; color: var(--text-primary); margin-bottom: var(--gap-md); line-height: 1.5; }
.guidance-card .checklist-back { color: var(--text-muted); padding-left: 0; list-style: none; }
.guidance-card .checklist-back li { padding: 4px 0; }
.guidance-card .if-invalid {
  margin-top: var(--gap-md);
  padding: var(--gap-md);
  background: var(--gold-bg);
  border-left: 3px solid var(--gold-primary);
  border-radius: var(--r-sm);
  color: var(--text-primary);
  font-size: 14px;
}

.risk-list { color: var(--text-muted); padding-left: 0; list-style: none; }
.risk-list li { padding: 6px 0; padding-left: 24px; position: relative; }
.risk-list li::before { content: '⚠'; position: absolute; left: 0; color: var(--l2-cond); }

/* Pre-trade Checklist */
.checklist-item { display: flex; align-items: flex-start; gap: var(--gap-sm); padding: var(--gap-sm) 0; cursor: pointer; }
.checklist-item input[type="checkbox"] { width: 18px; height: 18px; accent-color: var(--gold-primary); margin-top: 2px; flex-shrink: 0; }
.checklist-item label { color: var(--text-primary); cursor: pointer; line-height: 1.4; }
.checklist-item.checked label { color: var(--text-dim); text-decoration: line-through; }

.checklist-status {
  margin-top: var(--gap-md);
  padding: var(--gap-md);
  border-radius: var(--r-sm);
  font-size: 14px;
}
.checklist-status.incomplete { background: rgba(245,158,11,0.1); border-left: 3px solid var(--l2-cond); }
.checklist-status.complete { background: rgba(16,185,129,0.1); border-left: 3px solid var(--l1-strong); }
.checklist-status.stand-aside { background: rgba(239,68,68,0.08); border-left: 3px solid var(--l5-avoid); }

/* Timeline */
.timeline-toolbar { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--gap-md); flex-wrap: wrap; gap: var(--gap-sm); }
.timeline-meta { color: var(--text-dim); font-size: 13px; }

.timeline-bars { display: grid; grid-template-columns: repeat(12, 1fr); gap: 6px; padding-bottom: 28px; }
.bar {
  height: 100px;
  background: var(--navy-medium);
  border-radius: 6px;
  position: relative;
  cursor: pointer;
  transition: transform 0.15s, box-shadow 0.15s;
  display: flex; flex-direction: column;
  justify-content: flex-end;
  padding: 6px 4px;
  border: 1px solid transparent;
}
.bar:hover { transform: translateY(-3px); }
.bar.current { box-shadow: 0 0 0 2px var(--gold-primary); border-color: var(--gold-primary); }
.bar.l1 { background: linear-gradient(180deg, transparent 30%, var(--l1-strong)); }
.bar.l2 { background: linear-gradient(180deg, transparent 30%, var(--l2-cond)); }
.bar.l3 { background: linear-gradient(180deg, transparent 30%, var(--l3-observe)); }
.bar.l4 { background: linear-gradient(180deg, transparent 30%, var(--l4-reduce)); }
.bar.l5 { background: linear-gradient(180deg, transparent 30%, var(--l5-avoid)); }
.bar.l6 { background: linear-gradient(180deg, transparent 30%, var(--l6-stand)); }
.bar .bar-score { color: white; font-family: var(--font-mono); font-size: 11px; text-shadow: 0 1px 2px rgba(0,0,0,0.5); text-align: center; font-weight: 600; }
.bar .yam-tag {
  position: absolute; bottom: -22px; left: 0; right: 0; text-align: center;
  font-family: var(--font-cn); font-size: 13px; color: var(--gold-primary); font-weight: 600;
}

@media (max-width: 768px) {
  .timeline-bars { grid-template-columns: 1fr; gap: var(--gap-sm); padding-bottom: 0; }
  .bar { height: auto; min-height: 56px; flex-direction: row; align-items: center; padding: 12px var(--gap-md); gap: var(--gap-md); border-radius: var(--r-sm); }
  .bar.l1, .bar.l2, .bar.l3, .bar.l4, .bar.l5, .bar.l6 { background: var(--navy-medium); border-left: 5px solid; }
  .bar.l1 { border-left-color: var(--l1-strong); }
  .bar.l2 { border-left-color: var(--l2-cond); }
  .bar.l3 { border-left-color: var(--l3-observe); }
  .bar.l4 { border-left-color: var(--l4-reduce); }
  .bar.l5 { border-left-color: var(--l5-avoid); }
  .bar.l6 { border-left-color: var(--l6-stand); }
  .bar .bar-mobile-row { display: flex; flex: 1; justify-content: space-between; align-items: center; }
  .bar .yam-tag { position: static; text-align: left; font-size: 12px; }
  .bar .bar-score { color: var(--gold-primary); font-size: 14px; }
}

/* Why Modal */
.modal-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.75);
  display: none; align-items: center; justify-content: center;
  z-index: 100;
  backdrop-filter: blur(6px);
  padding: var(--gap-lg);
}
.modal-overlay.active { display: flex; animation: fade-in 0.15s ease-out; }
@keyframes fade-in { from { opacity: 0 } to { opacity: 1 } }

.modal {
  background: var(--navy-deep);
  border: 1px solid var(--navy-border);
  border-radius: var(--r-lg);
  max-width: 680px; width: 100%;
  max-height: 88vh; overflow-y: auto;
  padding: var(--gap-lg);
  position: relative;
}
.modal .close-btn { position: absolute; top: 12px; right: 16px; cursor: pointer; color: var(--text-dim); font-size: 28px; line-height: 1; background: transparent; border: 0; padding: 4px 8px; }
.modal .close-btn:hover { color: var(--gold-primary); }
.modal .modal-eyebrow { color: var(--gold-primary); font-size: 11px; letter-spacing: 2px; text-transform: uppercase; margin-bottom: var(--gap-sm); font-family: var(--font-cn), var(--font-sans); }
.modal h2 { margin-bottom: var(--gap-sm); font-size: 28px; font-family: var(--font-cn); }
.modal .modal-yam-range { color: var(--text-muted); font-family: var(--font-mono); font-size: 13px; margin-bottom: var(--gap-md); }
.modal .modal-mode-label { display: inline-block; padding: 4px 12px; border-radius: 999px; font-weight: 600; font-size: 13px; margin-bottom: var(--gap-md); }
.modal .modal-summary { font-size: 16px; color: var(--text-primary); line-height: 1.6; padding: var(--gap-md); background: var(--navy-medium); border-radius: var(--r-sm); }
.modal .modal-qimen-line {
  font-family: var(--font-cn);
  color: var(--gold-primary);
  font-size: 14px;
  margin-top: var(--gap-md);
  padding: var(--gap-sm) var(--gap-md);
  background: var(--gold-bg);
  border-radius: var(--r-sm);
  letter-spacing: 1px;
}

.section-title { color: var(--gold-primary); font-size: 11px; letter-spacing: 2px; text-transform: uppercase; margin: var(--gap-lg) 0 var(--gap-sm); }
.modal .reason { padding: var(--gap-sm) var(--gap-md); border-left: 3px solid var(--navy-border); margin: var(--gap-sm) 0; background: rgba(255,255,255,0.02); }
.modal .reason.positive { border-left-color: var(--l1-strong); }
.modal .reason.neutral { border-left-color: var(--l3-observe); }
.modal .reason.caution { border-left-color: var(--l2-cond); }
.modal .reason.critical { border-left-color: var(--l5-avoid); }
.modal .reason .text { color: var(--text-primary); margin-bottom: 4px; font-size: 14px; }
.modal .reason .why { color: var(--text-muted); font-size: 12px; }

.modal .modal-checklist { color: var(--text-muted); padding-left: 20px; }
.modal .modal-checklist li { padding: 4px 0; }
.modal .modal-if-invalid { padding: var(--gap-sm); background: var(--gold-bg); border-left: 3px solid var(--gold-primary); border-radius: var(--r-sm); margin-top: var(--gap-sm); font-size: 14px; }

.modal .context-card { padding: var(--gap-md); background: var(--navy-medium); border-radius: var(--r-sm); margin-bottom: var(--gap-sm); font-size: 14px; }
.modal .context-card .ctx-title { color: var(--text-dim); font-size: 11px; letter-spacing: 1px; text-transform: uppercase; }
.modal .context-card .ctx-text { color: var(--text-primary); margin-top: 4px; }

.tech-toggle { background: transparent; color: var(--gold-primary); border: 1px solid var(--navy-border); margin-top: var(--gap-md); width: 100%; text-align: left; padding: var(--gap-sm) var(--gap-md); font-family: var(--font-cn), var(--font-sans); }
.tech-details { display: none; padding: var(--gap-md); background: var(--navy-medium); border-radius: var(--r-sm); margin-top: var(--gap-sm); font-size: 12px; color: var(--text-muted); }
.tech-details.open { display: block; }
.tech-details .row { display: flex; justify-content: space-between; padding: 4px 0; border-bottom: 1px dashed var(--navy-border); }
.tech-details .row:last-child { border-bottom: 0; }
.tech-details .row span:first-child { font-family: var(--font-cn), var(--font-sans); color: var(--gold-primary); }

.modal-disclaimer { margin-top: var(--gap-lg); padding-top: var(--gap-md); border-top: 1px solid var(--navy-border); color: var(--text-dim); font-size: 12px; line-height: 1.5; }

@media (max-width: 600px) {
  .modal-overlay { padding: 0; align-items: flex-end; }
  .modal { max-height: 92vh; border-radius: var(--r-lg) var(--r-lg) 0 0; padding: var(--gap-md); }
  .modal h2 { font-size: 22px; }
}

/* ============ Stat Cards (★ NEW panels) ============ */
.stat-card { padding: var(--gap-lg); }
.stat-card .block-eyebrow {
  color: var(--gold-primary);
  letter-spacing: 2.5px;
  font-weight: 700;
  margin-bottom: 6px;
}
.stat-title {
  font-size: 18px;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: var(--gap-md);
  font-family: var(--font-cn), var(--font-sans);
}
.stat-footnote {
  margin-top: var(--gap-md);
  padding-top: var(--gap-md);
  border-top: 1px solid var(--line-soft);
  color: var(--text-dim);
  font-size: 12px;
}

/* 4-column grid for Today's Profile */
.stat-grid-4 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--gap-md);
}
@media (max-width: 768px) { .stat-grid-4 { grid-template-columns: repeat(2, 1fr); } }
.stat-grid-2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--gap-md);
}
.stat-item {
  text-align: center;
  padding: var(--gap-md);
  background: var(--navy-medium);
  border-radius: var(--r-sm);
  border: 1px solid var(--line-soft);
}
.stat-v {
  font-family: var(--font-mono);
  font-size: 28px;
  color: var(--gold-primary);
  font-weight: 700;
  line-height: 1;
  margin-bottom: 6px;
}
.stat-v.cn-emph { font-family: var(--font-cn); }
.stat-k {
  color: var(--text-muted);
  font-size: 11px;
  letter-spacing: 1px;
  text-transform: uppercase;
}

/* 2 cards row (Session + Credibility) */
.stat-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--gap-lg); }
@media (max-width: 900px) { .stat-row-2 { grid-template-columns: 1fr; } }

/* Distribution bars (Time Distribution) */
.dist-bars { display: flex; flex-direction: column; gap: 10px; }
.dist-row { display: grid; grid-template-columns: 30px 1fr 50px; gap: 12px; align-items: center; }
.dist-row .lvl { font-family: var(--font-mono); color: var(--text-muted); font-size: 13px; font-weight: 600; }
.dist-bar-track { height: 18px; background: var(--navy-medium); border-radius: 9px; overflow: hidden; }
.dist-bar { height: 100%; transition: width 0.6s ease; border-radius: 9px; }
.dist-bar.l1 { background: var(--l1-strong); }
.dist-bar.l2 { background: var(--l2-cond); }
.dist-bar.l3 { background: var(--l3-observe); }
.dist-bar.l4 { background: var(--l4-reduce); }
.dist-bar.l5 { background: var(--l5-avoid); }
.dist-bar.l6 { background: var(--l6-stand); }
.dist-pct { font-family: var(--font-mono); color: var(--text-primary); font-size: 13px; text-align: right; font-weight: 600; }
.insight-line { color: var(--gold-primary); font-size: 13px; }
.insight-tag { color: var(--text-primary); font-size: 13px; font-weight: 600; }

/* Distribution Insight (3 column with emoji) */
.insight-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--gap-md); }
@media (max-width: 600px) { .insight-grid { grid-template-columns: 1fr; } }
.insight-item {
  text-align: center;
  padding: var(--gap-lg) var(--gap-md);
  background: var(--navy-medium);
  border-radius: var(--r-sm);
  border: 1px solid var(--line-soft);
}
.insight-emoji { font-size: 28px; margin-bottom: var(--gap-sm); }
.insight-pct { font-family: var(--font-mono); font-size: 32px; font-weight: 800; color: var(--gold-primary); line-height: 1; margin-bottom: 4px; }
.insight-label { color: var(--text-muted); font-size: 13px; }

/* What to do next */
.next-actions-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--gap-md); }
@media (max-width: 600px) { .next-actions-grid { grid-template-columns: 1fr; } }
.next-action {
  display: block;
  padding: var(--gap-lg);
  background: var(--navy-medium);
  border-radius: var(--r-md);
  border: 1px solid var(--line-soft);
  text-align: center;
  text-decoration: none;
  transition: transform 0.15s, border-color 0.15s;
}
.next-action:hover { transform: translateY(-3px); border-color: var(--gold-primary); }
.next-action .na-icon { font-size: 32px; margin-bottom: 8px; }
.next-action .na-title { color: var(--text-primary); font-size: 16px; font-weight: 600; }
.next-action .na-sub { color: var(--gold-primary); font-size: 13px; font-family: var(--font-cn), var(--font-sans); margin-top: 4px; }

/* Section heading utility */
.section-heading {
  color: var(--gold-primary);
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-bottom: var(--gap-md);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

/* Loading / error */
.loading-text { color: var(--text-muted); text-align: center; padding: var(--gap-lg); font-size: 14px; }
.error-card { padding: var(--gap-lg); text-align: center; color: var(--text-muted); }
.error-card .err-msg { color: var(--l5-avoid); margin-bottom: var(--gap-md); }

/* Offline banner */
.offline-banner {
  position: fixed; top: 60px; left: 0; right: 0;
  background: var(--l5-avoid);
  color: white;
  padding: 8px var(--gap-md);
  text-align: center;
  font-size: 14px;
  z-index: 60;
  display: none;
}
.offline-banner.show { display: block; }
