/* Pro features styles */
.pro-header { padding: var(--gap-lg) 0; }
.pro-tabs {
  display: flex; gap: 6px; flex-wrap: wrap;
  border-bottom: 1px solid var(--line-soft);
  padding-bottom: var(--gap-md);
  margin-bottom: var(--gap-lg);
}
.pro-tab {
  background: var(--navy-medium);
  border: 1px solid var(--line-soft);
  color: var(--text-muted);
  padding: 10px 16px;
  border-radius: var(--r-md);
  font-size: 13px;
  cursor: pointer;
  transition: all 0.15s;
}
.pro-tab:hover { color: var(--gold-soft); border-color: var(--gold-primary); }
.pro-tab.active { background: var(--gold-bg); border-color: var(--gold-primary); color: var(--gold-primary); font-weight: 600; }

.pro-section { display: none; }
.pro-section.active { display: block; }

.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--gap-md); margin-bottom: var(--gap-md); align-items: end; }
@media (max-width: 600px) { .form-row { grid-template-columns: 1fr; } }

textarea.lb-input { resize: vertical; font-family: inherit; }

/* Journal */
.journal-form { padding: var(--gap-md); background: var(--navy-medium); border-radius: var(--r-sm); margin-bottom: var(--gap-md); }
.journal-item { padding: var(--gap-md); border-bottom: 1px solid var(--line-soft); display: grid; grid-template-columns: auto 1fr auto; gap: var(--gap-md); align-items: start; }
.journal-item:last-child { border-bottom: 0; }
.j-mode { padding: 6px 12px; border-radius: 999px; font-size: 12px; font-weight: 700; flex-shrink: 0; }
.j-meta { color: var(--text-muted); font-size: 12px; }
.j-meta .mono { font-family: var(--font-mono); }
.j-notes { color: var(--text-primary); margin-top: 6px; font-size: 14px; }
.j-del { color: var(--text-dim); cursor: pointer; font-size: 18px; padding: 0 8px; background: transparent; border: 0; }
.j-del:hover { color: var(--l5-avoid); }

/* Risk Cap */
.risk-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--gap-md); }
@media (max-width: 600px) { .risk-grid { grid-template-columns: 1fr; } }
.risk-alert { margin-top: var(--gap-md); padding: var(--gap-md); border-radius: var(--r-sm); border-left: 3px solid; font-size: 14px; }
.risk-alert.warn { background: rgba(245,158,11,0.1); border-left-color: var(--l2-cond); color: var(--text-primary); }
.risk-alert.crit { background: rgba(239,68,68,0.1); border-left-color: var(--l5-avoid); color: var(--text-primary); }
.risk-alert.ok { background: rgba(16,185,129,0.08); border-left-color: var(--l1-strong); color: var(--text-primary); }

/* Watchlist */
.wl-item { display: grid; grid-template-columns: auto 1fr auto auto; gap: var(--gap-md); padding: var(--gap-sm) var(--gap-md); align-items: center; border-bottom: 1px solid var(--line-soft); }
.wl-item:last-child { border-bottom: 0; }
.wl-type-tag { padding: 4px 10px; background: var(--navy-medium); border-radius: 999px; font-size: 11px; color: var(--text-muted); border: 1px solid var(--line-soft); }
.wl-label { color: var(--text-primary); font-weight: 600; }

/* Lookback analytics */
.lba-summary {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--gap-md);
  padding: var(--gap-md); background: var(--navy-medium); border-radius: var(--r-sm);
}
@media (max-width: 600px) { .lba-summary { grid-template-columns: repeat(2, 1fr); } }
.lba-stat { text-align: center; }
.lba-stat .v { font-family: var(--font-mono); color: var(--gold-primary); font-size: 22px; font-weight: 700; }
.lba-stat .k { color: var(--text-muted); font-size: 11px; letter-spacing: 1px; text-transform: uppercase; margin-top: 4px; }
.lba-item { padding: 10px var(--gap-md); border-bottom: 1px solid var(--line-soft); display: grid; grid-template-columns: auto 1fr auto; gap: var(--gap-md); align-items: center; }
.lba-item:last-child { border-bottom: 0; }

/* Planner */
.planner-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: var(--gap-sm); }
@media (max-width: 768px) { .planner-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .planner-grid { grid-template-columns: 1fr; } }
.planner-day {
  padding: var(--gap-md); background: var(--navy-medium); border-radius: var(--r-md);
  border: 1px solid var(--line-soft);
  cursor: pointer; transition: transform 0.15s, border-color 0.15s;
}
.planner-day:hover { transform: translateY(-2px); border-color: var(--gold-primary); }
.planner-day .day-date { color: var(--gold-primary); font-weight: 600; font-size: 13px; }
.planner-day .day-pillar { color: var(--text-muted); font-family: var(--font-cn); font-size: 12px; margin-top: 2px; }
.planner-day .day-bar { display: flex; height: 6px; margin: var(--gap-md) 0; border-radius: 3px; overflow: hidden; background: var(--navy-deepest); }
.planner-day .day-bar > div { height: 100%; }
.planner-day .day-summary { color: var(--text-muted); font-size: 12px; }
.planner-day .day-best { color: var(--gold-primary); font-family: var(--font-cn); font-size: 14px; margin-top: 4px; }

/* BaZi */
.bazi-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--gap-md); }
@media (max-width: 600px) { .bazi-grid { grid-template-columns: 1fr; } }
.bazi-result { margin-top: var(--gap-lg); padding: var(--gap-lg); background: var(--gold-bg); border-radius: var(--r-md); border: 1px solid var(--gold-primary); }
.bazi-result .bz-pillar-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--gap-md); margin: var(--gap-md) 0; }
.bazi-result .bz-pillar { text-align: center; padding: var(--gap-sm); background: var(--navy-medium); border-radius: var(--r-sm); }
.bazi-result .bz-pillar .v { font-family: var(--font-cn); color: var(--gold-primary); font-size: 22px; font-weight: 600; }
.bazi-result .bz-pillar .k { color: var(--text-muted); font-size: 10px; letter-spacing: 1px; text-transform: uppercase; }
.bazi-result .bz-elements { display: flex; gap: var(--gap-sm); margin-top: var(--gap-md); flex-wrap: wrap; }
.bazi-result .bz-pill { padding: 6px 12px; border-radius: 999px; font-size: 12px; }
.bazi-result .bz-pill.fav { background: rgba(16,185,129,0.15); color: var(--l1-strong); }
.bazi-result .bz-pill.unfav { background: rgba(239,68,68,0.12); color: var(--l5-avoid); }

/* Session Overlay (used in app.html timeline) */
.session-overlay { display: grid; grid-template-columns: repeat(12, 1fr); gap: 6px; margin-top: 4px; }
.session-band { height: 4px; border-radius: 2px; opacity: 0.5; }
.session-asia { background: #f59e0b; }
.session-eu { background: #60a5fa; }
.session-us { background: #c084fc; }
.session-legend { display: flex; gap: var(--gap-md); margin-top: var(--gap-sm); flex-wrap: wrap; font-size: 11px; color: var(--text-dim); }
.session-legend .ll { display: flex; align-items: center; gap: 4px; }
.session-legend .lc { width: 12px; height: 4px; border-radius: 2px; }

/* Smart Checklist enhancement */
.checklist-item.smart-add { background: rgba(245,158,11,0.06); border-left: 3px solid var(--l2-cond); padding-left: var(--gap-sm); border-radius: var(--r-sm); }
.checklist-item.smart-add label::after { content: ' (เพิ่มตามโหมด)'; color: var(--l2-cond); font-size: 11px; }

/* Empty state */
.empty-state { padding: var(--gap-xl) var(--gap-lg); text-align: center; color: var(--text-dim); }
