:root {
  --bg: #212121;
  --bg-elevated: #171717;
  --surface: #2f2f2f;
  --surface-2: #3a3a3a;
  --surface-soft: #2a2a2a;
  --border: rgba(255, 255, 255, 0.09);
  --divider: rgba(255, 255, 255, 0.06);
  --text: #ececec;
  --text-muted: #a3a3b3;
  --text-faint: #7a7a8a;
  --accent: #fff;
  --accent-strong: #e6e6e6;
  --accent-fg: #000;
  --green: #fff;
  --error: #ef4444;
  --error-bg: rgba(239, 68, 68, 0.09);
  --shadow-soft: 0 10px 30px rgba(0, 0, 0, 0.24);
  color-scheme: dark;
}

[data-theme="light"] {
  --bg: #ffffff;
  --bg-elevated: #ffffff;
  --surface: #f2f2f3;
  --surface-2: #ebebed;
  --surface-soft: #f7f7f8;
  --border: rgba(15, 23, 42, 0.08);
  --divider: rgba(15, 23, 42, 0.05);
  --text: #1f1f1f;
  --text-muted: #5b6070;
  --text-faint: #8c909d;
  --accent: #000;
  --accent-strong: #1a1a1a;
  --accent-fg: #fff;
  --green: #000;
  --error: #dc2626;
  --error-bg: rgba(220, 38, 38, 0.08);
  --shadow-soft: 0 10px 24px rgba(31, 41, 55, 0.08);
  color-scheme: light;
}

[data-theme="dark"] .theme-icon-moon,
[data-theme="light"] .theme-icon-sun {
  display: block;
}

[data-theme="dark"] .theme-icon-sun,
[data-theme="light"] .theme-icon-moon {
  display: none;
}

* {
  box-sizing: border-box;
}

html,
body {
  width: 100%;
  height: 100%;
  margin: 0;
}

body {
  overflow: hidden;
  background: var(--bg);
  color: var(--text);
  font-family: "Söhne", "Sohne", -apple-system, BlinkMacSystemFont, "Segoe UI",
    Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji";
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

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

.layout {
  --sidebar-width: 256px;
  --sidebar-rail-width: 56px;
  --splitter-width: 8px;
  width: 100%;
  height: 100vh;
  display: grid;
  grid-template-columns: var(--sidebar-width) var(--splitter-width) minmax(
      0,
      1fr
    );
  overflow: hidden;
  background: var(--bg);
  position: relative;
}

/* Sidebar */
.sidebar {
  grid-column: 1;
  background: var(--bg-elevated);
  border-right: 1px solid var(--divider);
  position: relative;
  padding: 0;
  overflow: visible;
}

.sidebar-expanded {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 10px 10px 12px;
  overflow-y: auto;
  overflow-x: visible;
  height: 100%;
}

.sidebar-expanded::-webkit-scrollbar {
  width: 6px;
}

.sidebar-expanded::-webkit-scrollbar-track {
  background: transparent;
}

.sidebar-expanded::-webkit-scrollbar-thumb {
  background: var(--surface-2);
  border-radius: 999px;
}

.sidebar-rail {
  display: none;
  height: 100%;
  padding: 7px 6px 10px;
  flex-direction: column;
  align-items: center;
  gap: 7px;
}

.sidebar-rail-btn {
  width: 32px;
  height: 32px;
  border: 0;
  border-radius: 9px;
  background: transparent;
  color: var(--text-muted);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.16s ease, color 0.16s ease, transform 0.16s ease;
}

.sidebar-rail-btn:hover {
  background: var(--surface-soft);
  color: var(--text);
  transform: translateY(-1px);
}

.sidebar-rail-btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 1px;
}

.sidebar-rail-btn-primary {
  background: color-mix(in srgb, var(--surface-soft) 80%, transparent);
  border: 1px solid var(--border);
}

.sidebar-brand-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 8px 6px;
}

.sidebar-logo-wrap {
  display: flex;
  align-items: center;
  gap: 11px;
  min-width: 0;
}

.sidebar-logo {
  width: 34px;
  height: 34px;
  border-radius: 11px;
  display: grid;
  place-items: center;
  color: var(--text-muted);
  background: var(--surface);
  border: 1px solid var(--border);
  flex-shrink: 0;
}

.sidebar-product {
  margin: 0;
  font-size: 0.9375rem;
  font-weight: 600;
  line-height: 1.2;
}

.sidebar-caption {
  margin: 2px 0 0;
  font-size: 0.73rem;
  color: var(--text-faint);
  line-height: 1.2;
}

.sidebar-close-btn {
  display: inline-flex;
}

.sidebar-nav {
  margin: 4px 0 2px;
  padding-bottom: 8px;
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.sidebar-item {
  width: 100%;
  min-height: 40px;
  border: 0;
  border-radius: 11px;
  padding: 9px 12px;
  background: transparent;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 11px;
  text-align: left;
  cursor: pointer;
  font-size: 0.9375rem;
  font-weight: 400;
  line-height: 1.35;
  transition: background 0.16s ease, color 0.16s ease;
}

.sidebar-item:hover {
  background: var(--surface);
}

.sidebar-item:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 1px;
}

.sidebar-item-strong {
  background: var(--surface-soft);
  border: 1px solid var(--border);
}

.sidebar-item-strong:hover {
  background: var(--surface);
}

.sidebar-icon {
  width: 17px;
  height: 17px;
  flex-shrink: 0;
  color: var(--text-muted);
}

.sidebar-section {
  margin-top: 6px;
  padding-top: 7px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.sidebar-section-toggle {
  width: 100%;
  border: 0;
  border-radius: 11px;
  background: transparent;
  color: var(--text);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  text-align: left;
  padding: 9px 12px;
  cursor: pointer;
  font-size: 0.9375rem;
  font-weight: 400;
  transition: background 0.16s ease;
}

.sidebar-section-toggle:hover {
  background: var(--surface);
}

.sidebar-section-toggle .sidebar-label {
  margin: 0;
  padding: 0;
  font-size: 0.9375rem;
  font-weight: 400;
  color: var(--text);
}

.sidebar-section-toggle-left {
  display: flex;
  align-items: center;
  gap: 11px;
}

.section-chevron {
  color: var(--text-faint);
  transition: transform 0.18s ease;
}

.quick-prompts-body {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.quick-prompts-section.quick-prompts-collapsed .quick-prompts-body {
  display: none;
}

.quick-prompts-section.quick-prompts-collapsed .section-chevron {
  transform: rotate(-90deg);
}

.history-body {
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.history-section.history-collapsed .history-body {
  display: none;
}

.history-section.history-collapsed .section-chevron {
  transform: rotate(-90deg);
}

.sidebar-label {
  margin: 5px 0 2px;
  padding: 0 11px;
  color: var(--text-faint);
  font-size: 0.75rem;
  font-weight: 400;
}

.history-section {
  gap: 1px;
}

.history-item {
  gap: 0;
  min-height: 35px;
  font-size: 0.875rem;
  font-weight: 400;
  color: var(--text-muted);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.history-item-title {
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.history-pin-icon {
  flex-shrink: 0;
  color: var(--text-faint);
  opacity: 0.6;
  margin-left: 6px;
}

.history-item:hover {
  color: var(--text);
}

.history-item.active {
  color: var(--text);
  background: var(--surface);
}

.history-item.active .history-pin-icon {
  opacity: 1;
  color: var(--text-muted);
}

.history-empty {
  margin: 3px 9px 5px;
  color: var(--text-faint);
  font-size: 0.78rem;
}

.prompt-chip {
  font-size: 0.875rem;
  color: var(--text-muted);
  min-height: 36px;
}

.prompt-chip:hover {
  color: var(--text);
}

.birth-panel {
  margin-top: 6px;
  padding-top: 6px;
}

.birth-panel summary {
  list-style: none;
  user-select: none;
}

.birth-panel summary::-webkit-details-marker {
  display: none;
}

.birth-panel summary::after {
  content: "›";
  margin-left: auto;
  color: var(--text-faint);
  font-size: 1rem;
  transition: transform 0.22s ease;
}

.birth-panel[open] summary::after {
  transform: rotate(90deg);
}

.summary-hint {
  font-size: 0.72rem;
  color: var(--text-faint);
}

.profile-add-hint {
  margin-left: auto;
  margin-right: 6px;
  font-size: 0.74rem;
  letter-spacing: 0.01em;
  text-transform: none;
}

.birth-card {
  padding: 8px 10px 4px 41px;
}

.birth-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

.birth-grid label {
  display: flex;
  flex-direction: column;
  gap: 5px;
  color: var(--text-faint);
  font-size: 0.67rem;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  font-weight: 700;
}

.birth-grid input,
.birth-grid select {
  border: 1px solid var(--border);
  border-radius: 9px;
  min-height: 34px;
  padding: 6px 10px;
  color: var(--text);
  background: var(--surface-soft);
  font-size: 0.84rem;
}

.birth-grid input:focus,
.birth-grid select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(0, 0, 0, 0.14);
}

.birth-grid select option {
  color: var(--text);
  background: var(--bg-elevated);
}

.geo-status {
  min-height: 17px;
  margin: 9px 0 0;
  color: var(--text-faint);
  font-size: 0.73rem;
  font-weight: 500;
}

.geo-status.success {
  color: var(--text-muted);
}

.geo-status.error {
  color: var(--error);
}

.geo-status.loading {
  color: var(--text-faint);
}

.geo-inline-status {
  display: block;
  margin-top: 6px;
  font-size: 0.8rem;
  color: var(--text-muted);
  background: var(--surface-soft);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 8px 10px;
  font-family: inherit;
}

.sidebar-footer-wrap {
  margin-top: auto;
  position: relative;
  padding: 11px 9px 4px;
}

.sidebar-footer {
  width: 100%;
  border: 0;
  background: transparent;
  border-radius: 12px;
  color: inherit;
  text-align: left;
  cursor: pointer;
  padding: 0;
  padding: 11px 9px 4px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.sidebar-footer:hover {
  background: var(--surface-soft);
}

.sidebar-footer:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 1px;
}

.user-avatar {
  width: 31px;
  height: 31px;
  border-radius: 50%;
  background: #1c1c1c;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.73rem;
  font-weight: 700;
  flex-shrink: 0;
}

.user-info {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.user-name {
  font-size: 0.84rem;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.user-plan {
  font-size: 0.72rem;
  color: var(--text-faint);
}

.sidebar-profile-caret {
  margin-left: auto;
  color: var(--text-faint);
  flex-shrink: 0;
  transition: transform 0.18s ease;
}

.sidebar-profile-trigger.open .sidebar-profile-caret {
  transform: rotate(180deg);
}

.sidebar-profile-dropdown {
  position: fixed !important;
  bottom: 72px !important;
  top: auto !important;
  left: 8px !important;
  right: auto !important;
  width: 256px !important;
  max-height: calc(100vh - 100px) !important;
  overflow-y: auto;
  overflow-x: hidden;
  z-index: 120 !important;
  padding: 6px !important;
}

/* Stack form rows vertically inside the narrow popup */
.sidebar-profile-dropdown .profile-form-row {
  grid-template-columns: 1fr;
}

.sidebar-profile-dropdown .profile-form {
  padding: 6px 4px;
}

/* Profile manager popup menu items */
.pm-menu-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 2px 0;
}

.pm-menu-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  border: 0;
  background: transparent;
  color: var(--text);
  padding: 9px 10px;
  border-radius: 10px;
  cursor: pointer;
  text-align: left;
  font-size: 0.875rem;
  font-weight: 500;
  transition: background 0.12s ease;
}

.pm-menu-item:hover {
  background: var(--surface-soft);
}

.pm-menu-item-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  flex-shrink: 0;
}

.pm-menu-item-label {
  flex: 1;
}

.pm-menu-item-arrow {
  color: var(--text-faint);
  flex-shrink: 0;
}

/* Profile manager sub-panel header (back button) */
.pm-sub-header {
  display: flex;
  align-items: center;
  gap: 7px;
  width: 100%;
  border: 0;
  background: transparent;
  color: var(--text-muted);
  padding: 6px 4px 8px;
  cursor: pointer;
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  transition: color 0.12s ease;
}

.pm-sub-header:hover {
  color: var(--text);
}

/* Resize handle */
.resize-handle {
  grid-column: 2;
  width: 100%;
  border: 0;
  padding: 0;
  margin: 0;
  background: transparent;
  cursor: col-resize;
  position: relative;
  touch-action: none;
}

.resize-handle::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: calc(50% - 1.5px);
  width: 3px;
  background: transparent;
  border-radius: 2px;
  transition: background 0.15s ease;
}

.resize-handle:hover::before,
body.is-resizing .resize-handle::before {
  background: var(--surface-2);
}

body.is-resizing,
body.is-resizing * {
  cursor: col-resize !important;
  user-select: none !important;
}

/* Main area */
.main-panel {
  grid-column: 3;
  min-width: 0;
  height: 100vh;
  display: grid;
  grid-template-rows: auto 1fr auto;
  overflow: hidden;
  position: relative;
  transition: padding-right 0.24s ease;
  background: var(--bg);
}

body.trace-open .main-panel {
  padding-right: 370px;
}

.topbar {
  height: 56px;
  border-bottom: 0;
  background: var(--bg);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 0 16px;
}

.topbar-left,
.topbar-right {
  display: flex;
  align-items: center;
  gap: 4px;
}

.brand-wrap {
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
}

/* Tier menu */
.tier-menu-wrap {
  position: relative;
}

.tier-dropdown {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  min-width: 180px;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 10px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
  z-index: 200;
  overflow: hidden;
  padding: 4px;
}

.tier-option {
  width: 100%;
  border: 0;
  border-radius: 7px;
  background: transparent;
  text-align: left;
  padding: 8px 10px;
  cursor: pointer;
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 8px;
  transition: background 0.14s;
}

.tier-option:hover {
  background: var(--surface-soft);
}

.tier-option.active {
  background: var(--surface);
}

.tier-option.active .tier-option-label {
  font-weight: 600;
  color: var(--text);
}

.tier-option-label {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text);
  flex: 0 0 auto;
}

.tier-option > svg {
  margin-left: 10px;
  flex: 0 0 auto;
}

.topbar-brand-block {
  display: flex;
  align-items: center;
  gap: 5px;
  border: 0;
  background: transparent;
  cursor: pointer;
  border-radius: 9px;
  padding: 5px 7px;
  margin: 0 -7px;
  color: var(--text);
  transition: background 0.15s ease;
}

.topbar-brand-block:hover {
  background: var(--surface);
}

/* Profile switcher */
.profile-switcher-wrap {
  position: relative;
}

.topbar-profile-btn {
  display: flex;
  align-items: center;
  gap: 4px;
}

.profile-sw-caret {
  color: var(--text-faint);
  transition: transform 0.18s ease;
  flex-shrink: 0;
}

.profile-sw-open .profile-sw-caret {
  transform: rotate(180deg);
}

.profile-switcher-dropdown {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  min-width: 200px;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
  z-index: 200;
  padding: 4px;
  display: flex;
  flex-direction: column;
}

.profile-sw-item {
  width: 100%;
  border-radius: 8px;
  background: transparent;
  display: flex;
  align-items: center;
  transition: background 0.13s;
}

.profile-sw-item:hover {
  background: var(--surface-soft);
}

.profile-sw-item.active {
  background: var(--surface);
}

.profile-sw-item.active .profile-sw-name {
  font-weight: 600;
  color: var(--text);
}

.profile-sw-item-btn {
  flex: 1;
  border: 0;
  background: transparent;
  text-align: left;
  padding: 8px 10px;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.profile-sw-delete-btn {
  opacity: 0;
  flex-shrink: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  padding: 5px 6px;
  margin-right: 4px;
  border-radius: 6px;
  color: var(--text-muted);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.15s, color 0.15s, background 0.15s;
}

.profile-sw-item:hover .profile-sw-delete-btn {
  opacity: 1;
}

.profile-sw-delete-btn:hover {
  color: #ef4444;
  background: color-mix(in srgb, #ef4444 10%, transparent);
}

.profile-sw-name {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text);
}

.profile-sw-meta {
  font-size: 0.72rem;
  color: var(--text-faint);
}

.profile-sw-empty {
  font-size: 0.82rem;
  color: var(--text-faint);
  padding: 8px 10px;
  display: block;
}

.topbar-title {
  font-size: 1.13rem;
  font-weight: 500;
  letter-spacing: 0.01em;
}

.topbar-title-caret {
  color: var(--text-faint);
  transition: transform 0.18s ease;
}

.brand-wrap.brand-open .topbar-title-caret {
  transform: rotate(180deg);
}

.model-select-wrap.model-open .topbar-title-caret {
  transform: rotate(180deg);
}

/* Tier Selection Refined */
.model-select-wrap {
  position: relative;
  display: flex;
  align-items: center;
  margin-left: 8px;
}

.model-label {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-faint);
  margin-right: 1px;
  user-select: none;
}

.tier-menu {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.tier-menu-item {
  width: 100%;
  border: 0;
  border-radius: 9px;
  background: transparent;
  color: var(--text);
  text-align: left;
  padding: 10px 16px;
  cursor: pointer;
  font-size: 0.875rem;
  font-weight: 400;
  display: flex;
  align-items: center;
  gap: 8px;
  transition: all 0.15s ease;
}

.tier-menu-item:hover {
  background: var(--surface-soft);
}

.tier-menu-item.active {
  color: var(--text);
  background: transparent;
  font-weight: 600;
}

/* Brand dropdown */
.brand-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  width: min(360px, calc(100vw - 24px));
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 18px;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.12);
  padding: 12px;
  z-index: 30;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

#modelTierDropdown {
  width: auto;
  min-width: 140px;
}

.brand-dropdown.hidden {
  display: none;
}

.brand-dropdown-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 4px 4px 8px;
}

.brand-dd-avatar {
  width: 38px;
  height: 38px;
  border-radius: 999px;
  background: #1c1c1c;
  color: #fff;
  display: grid;
  place-items: center;
  font-size: 0.8rem;
  font-weight: 600;
  flex-shrink: 0;
  letter-spacing: 0.03em;
}

.brand-dd-info {
  min-width: 0;
  flex: 1;
}

.brand-dd-name {
  margin: 0;
  font-size: 0.9375rem;
  font-weight: 600;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.brand-dd-sub {
  margin: 3px 0 0;
  font-size: 0.72rem;
  color: var(--text-faint);
  line-height: 1.3;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.brand-dd-divider {
  height: 1px;
  background: var(--border);
  margin: 4px 0;
}

.brand-dd-section {
  padding: 4px 0 2px;
}

.brand-dd-label {
  margin: 0 0 6px;
  padding: 0 4px;
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--text-faint);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.profile-manager {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.profile-manager-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.profile-manager-header-btn {
  width: 100%;
  border: 0;
  border-radius: 10px;
  background: transparent;
  color: inherit;
  text-align: left;
  padding: 4px 6px;
  cursor: pointer;
}

.profile-manager-header-btn:hover {
  background: var(--surface-soft);
}

.profile-manager-header-btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 1px;
}

.profile-manager-header .brand-dd-label {
  margin-bottom: 0;
}

.profile-manager-caret {
  color: var(--text-faint);
  transition: transform 0.18s ease;
}

.profile-manager-header-btn[aria-expanded="true"] .profile-manager-caret {
  transform: rotate(180deg);
}

.profile-toggle-btn {
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--surface-soft);
  color: var(--text-muted);
  font-size: 0.75rem;
  font-weight: 600;
  padding: 4px 10px;
  cursor: pointer;
}

.profile-toggle-btn:hover {
  background: var(--surface);
  color: var(--text);
}

.profile-form {
  display: flex;
  flex-direction: column;
  gap: 8px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--surface-soft);
  padding: 10px;
}

.profile-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.profile-form label {
  display: flex;
  flex-direction: column;
  gap: 5px;
  color: var(--text-faint);
  font-size: 0.66rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-weight: 700;
}

.profile-form input,
.profile-form select {
  border: 1px solid var(--border);
  border-radius: 9px;
  min-height: 34px;
  padding: 6px 10px;
  color: var(--text);
  background: var(--bg-elevated);
  font-size: 0.82rem;
}

.profile-form input:focus,
.profile-form select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.13);
}

.profile-save-btn {
  margin-top: 2px;
  border: 1px solid var(--accent);
  border-radius: 10px;
  min-height: 34px;
  padding: 0 11px;
  background: var(--accent);
  color: var(--accent-fg);
  font-size: 0.83rem;
  font-weight: 600;
  cursor: pointer;
  width: 100%;
  transition: background 0.15s, border-color 0.15s;
}

.profile-save-btn:hover {
  background: var(--accent-strong);
  border-color: var(--accent-strong);
}

.profiles-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  max-height: 180px;
  overflow-y: auto;
  padding-right: 2px;
}

.profiles-list::-webkit-scrollbar {
  width: 6px;
}

.profiles-list::-webkit-scrollbar-thumb {
  background: var(--surface-2);
  border-radius: 999px;
}

.profile-card {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 11px;
  background: var(--surface-soft);
  color: var(--text);
  display: flex;
  flex-direction: column;
  gap: 3px;
  text-align: left;
  padding: 9px 10px;
  cursor: pointer;
}

.profile-card:hover {
  background: var(--surface);
}

.profile-card.active {
  border-color: var(--text-muted);
  background: var(--surface);
}

.profile-card-name {
  font-size: 0.84rem;
  font-weight: 600;
  color: var(--text);
}

.profile-card-meta {
  font-size: 0.74rem;
  color: var(--text-muted);
  line-height: 1.3;
}

.astro-settings-toggle {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 11px;
  background: var(--surface-soft);
  color: var(--text);
  min-height: 36px;
  padding: 8px 10px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
}

.astro-settings-toggle:hover {
  background: var(--surface);
}

.astro-settings-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
}

.astro-settings-label {
  font-size: 0.84rem;
  font-weight: 500;
  color: var(--text-muted);
}

.astro-settings-caret {
  margin-left: auto;
  color: var(--text-faint);
  transition: transform 0.18s ease;
}

.astro-settings-toggle[aria-expanded="true"] .astro-settings-caret {
  transform: rotate(180deg);
}

.panchang-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
}

.panchang-cell {
  background: var(--surface-soft);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 8px 10px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.panchang-k {
  font-size: 0.68rem;
  font-weight: 600;
  color: var(--text-faint);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.panchang-v {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text);
}

.brand-dd-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 4px;
  border-radius: 10px;
}

.brand-dd-row-icon {
  color: var(--text-faint);
  display: inline-flex;
  align-items: center;
}

.brand-dd-row-label {
  font-size: 0.875rem;
  color: var(--text-muted);
  flex: 1;
}

.brand-dd-row-val {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--accent);
}

.brand-chips {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
}

.brand-chip {
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 5px 13px;
  background: transparent;
  color: var(--text-muted);
  font-size: 0.8125rem;
  font-weight: 400;
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.brand-chip:hover {
  background: var(--surface);
  color: var(--text);
}

.brand-chip.brand-chip-active {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--accent-fg);
  font-weight: 500;
}

.header-actions {
  gap: 4px;
}

.header-share-btn {
  min-height: 32px;
  border: 0;
  border-radius: 9px;
  background: transparent;
  color: var(--text);
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 0 8px;
  cursor: pointer;
  font-size: 0.94rem;
  font-weight: 500;
}

.header-share-btn:hover {
  background: var(--surface-soft);
}

.chat-menu-wrap {
  position: relative;
}

.topbar-icon-btn,
.header-more-btn,
.tier-menu-btn {
  width: 42px;
  height: 42px;
  min-width: 42px;
  border: 0;
  border-radius: 10px;
  background: transparent;
  color: var(--text);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0;
  flex-shrink: 0;
  transition: background 0.15s, color 0.15s;
}

.todays-sky-btn {
  color: color-mix(in srgb, var(--text) 78%, var(--text-muted) 22%);
}

/* Tier button inner layout */
.tier-btn-inner {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 4px;
  width: auto;
}

.tier-menu-btn {
  width: auto;
  min-width: 52px;
  padding: 0 8px;
}

.tier-btn-inner > svg {
  width: 20px;
  height: 20px;
  flex: 0 0 20px;
}

/* Pip indicator row beside brain icon */
.tier-pip-row {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  flex: 0 0 auto;
}

.tier-pip {
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: #6ee7b7;
  transition: background 0.2s;
}

.tier-pip.tier-pip-1 {
  background: #6ee7b7;
}

.tier-pip.tier-pip-2 {
  background: #34d399;
}

.tier-pip.tier-pip-3 {
  background: #10b981;
}

.tier-pip.tier-pip-4 {
  background: #059669;
}

.tier-pip.tier-pip-5 {
  background: #065f46;
}

/* Pips inside the dropdown options */
.tier-option-left {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-right: auto;
}

.tier-option-pips {
  display: flex;
  align-items: center;
  gap: 2px;
}

.tier-opt-pip {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #6ee7b7;
  transition: background 0.15s ease;
}

.tier-option[data-tier="standard"] .tier-opt-pip {
  background: #6ee7b7;
}

.tier-option[data-tier="expert"] .tier-opt-pip:nth-child(1) {
  background: #6ee7b7;
}

.tier-option[data-tier="expert"] .tier-opt-pip:nth-child(2) {
  background: #34d399;
}

.tier-option[data-tier="expert"] .tier-opt-pip:nth-child(3) {
  background: #10b981;
}

.tier-option[data-tier="advanced"] .tier-opt-pip:nth-child(1) {
  background: #6ee7b7;
}

.tier-option[data-tier="advanced"] .tier-opt-pip:nth-child(2) {
  background: #34d399;
}

.tier-option[data-tier="advanced"] .tier-opt-pip:nth-child(3) {
  background: #10b981;
}

.tier-option[data-tier="advanced"] .tier-opt-pip:nth-child(4) {
  background: #059669;
}

.tier-option[data-tier="advanced"] .tier-opt-pip:nth-child(5) {
  background: #065f46;
}

.topbar-icon-btn:hover,
.header-more-btn:hover,
.tier-menu-btn:hover,
.tier-open .tier-menu-btn {
  background: var(--surface-soft);
  color: var(--text);
}

/* Icon tooltip on hover */
.topbar-icon-btn[data-tooltip] {
  position: relative;
}

.topbar-icon-btn[data-tooltip]::after {
  content: attr(data-tooltip);
  position: absolute;
  top: calc(100% + 7px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--surface-2, #2a2a2a);
  color: var(--text);
  font-size: 0.7rem;
  font-weight: 500;
  padding: 4px 8px;
  border-radius: 6px;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.15s;
  z-index: 200;
}

.topbar-icon-btn[data-tooltip]:hover::after {
  opacity: 1;
}

.chat-menu {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 210px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--bg-elevated);
  box-shadow: var(--shadow-soft);
  padding: 6px;
  z-index: 24;
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.chat-menu-item {
  width: 100%;
  border: 0;
  border-radius: 10px;
  background: transparent;
  color: var(--text);
  text-align: left;
  padding: 9px 10px;
  cursor: pointer;
  font-size: 0.875rem;
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  transition: background 0.12s ease;
}

.chat-menu-item:hover {
  background: var(--surface-soft);
}

.chat-menu-item-icon {
  width: 16px;
  height: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  flex-shrink: 0;
}

.chat-menu-divider {
  height: 1px;
  background: var(--divider);
  margin: 4px 0;
}

/* ── Report / generic modal ─────────────────────────────────────────────── */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(4px);
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

.modal-card {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 18px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4);
  width: 100%;
  max-width: 420px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.modal-title {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--text);
  margin: 0;
}

.modal-close-btn {
  width: 32px;
  height: 32px;
  border: 0;
  border-radius: 8px;
  background: transparent;
  color: var(--text-muted);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.13s, color 0.13s;
}

.modal-close-btn:hover {
  background: var(--surface);
  color: var(--text);
}

.modal-subtitle {
  font-size: 0.9rem;
  color: var(--text-muted);
  margin: 0;
}

.report-reasons {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.report-reason-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 11px 12px;
  border-radius: 10px;
  cursor: pointer;
  font-size: 0.9375rem;
  color: var(--text);
  transition: background 0.13s;
}

.report-reason-item:hover {
  background: var(--surface-soft);
}

.report-reason-item.selected {
  background: var(--surface);
}

.report-reason-item input[type="radio"] {
  width: 18px;
  height: 18px;
  accent-color: var(--accent);
  cursor: pointer;
  flex-shrink: 0;
}

.modal-footer {
  display: flex;
  justify-content: flex-end;
  padding-top: 4px;
}

.modal-submit-btn {
  padding: 9px 22px;
  border: 0;
  border-radius: 10px;
  background: var(--surface);
  color: var(--text);
  font-size: 0.9rem;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.13s;
}

.modal-submit-btn:hover:not(:disabled) {
  background: var(--surface-2);
}

.modal-submit-btn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.modal-selected-reason {
  font-size: 1rem;
  font-weight: 500;
  color: var(--text);
  margin: 0;
}

.report-details-input {
  width: 100%;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  color: var(--text);
  font-size: 0.9rem;
  padding: 12px 14px;
  resize: vertical;
  min-height: 100px;
  outline: none;
  font-family: inherit;
  line-height: 1.5;
  box-sizing: border-box;
  transition: border-color 0.15s;
}

.report-details-input::placeholder {
  color: var(--text-faint);
}

.report-details-input:focus {
  border-color: var(--text-muted);
}

.modal-footer-two {
  gap: 8px;
}

.modal-back-btn {
  padding: 9px 22px;
  border: 0;
  border-radius: 10px;
  background: var(--surface);
  color: var(--text-muted);
  font-size: 0.9rem;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.13s, color 0.13s;
}

.modal-back-btn:hover {
  background: var(--surface-2);
  color: var(--text);
}

.modal-submit-primary {
  background: var(--text);
  color: var(--bg);
}

.modal-submit-primary:hover:not(:disabled) {
  opacity: 0.88;
}

.chat-menu-item.danger {
  color: #ef4444;
}

.chat-menu-item.danger .chat-menu-item-icon {
  color: #ef4444;
}

.icon-btn {
  width: 34px;
  height: 34px;
  border: 0;
  border-radius: 9px;
  background: transparent;
  color: var(--text-muted);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.16s ease, color 0.16s ease;
}

.icon-btn:hover {
  color: var(--text);
  background: var(--surface);
}

.sidebar-toggle-btn {
  display: none;
}

.sidebar-toggle-btn.is-open {
  color: var(--text);
  background: var(--surface-soft);
}

.sidebar-toggle-btn.is-hidden {
  display: none;
}

/* Chat pane */
.chat-main {
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  display: flex;
  flex-direction: column;
}

.chat-main::-webkit-scrollbar {
  width: 7px;
}

.chat-main::-webkit-scrollbar-track {
  background: transparent;
}

.chat-main::-webkit-scrollbar-thumb {
  background: var(--surface-2);
  border-radius: 999px;
}

.empty-state {
  width: min(860px, calc(100% - 54px));
  margin: auto;
  text-align: center;
  padding: 48px 0 54px;
}

.empty-kicker {
  margin: 0;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.67rem;
  font-weight: 700;
  color: var(--text-faint);
}

.empty-title {
  margin: 12px 0 0;
  font-size: clamp(1.8rem, 5vw, 2.25rem);
  line-height: 1.2;
  font-weight: 600;
}

.empty-subtitle {
  margin: 12px auto 30px;
  max-width: 58ch;
  color: var(--text-muted);
  font-size: 0.99rem;
}

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

.prompt-card {
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--surface-soft);
  color: var(--text);
  cursor: pointer;
  padding: 15px 16px;
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: 4px;
  transition: transform 0.16s ease, border-color 0.16s ease,
    background 0.16s ease;
}

.prompt-card:hover {
  transform: translateY(-1px);
  background: var(--surface);
  border-color: color-mix(in srgb, var(--border) 50%, var(--accent));
}

.prompt-card-title {
  font-size: 0.88rem;
  font-weight: 600;
  line-height: 1.35;
}

.prompt-card-sub {
  font-size: 0.8rem;
  color: var(--text-muted);
  line-height: 1.35;
}

.messages {
  width: min(840px, calc(100% - 52px));
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 28px;
  padding: 26px 0 20px;
}

.message-row {
  width: 100%;
}

.message-shell {
  width: 100%;
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.message-avatar {
  width: 28px;
  height: 28px;
  border-radius: 7px;
  flex-shrink: 0;
  display: grid;
  place-items: center;
  font-size: 0.68rem;
  font-weight: 700;
  color: #fff;
  background: #1c1c1c;
  margin-top: 1px;
  letter-spacing: 0.02em;
}

.message-body {
  min-width: 0;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.message-content {
  color: var(--text);
  line-height: 1.55;
  word-break: break-word;
  font-size: 1rem;
}

.message-mode-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 0 0 6px;
}

.message-mode-pill {
  border: 1px solid color-mix(in srgb, var(--border) 68%, var(--accent));
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  color: var(--text-muted);
  border-radius: 999px;
  padding: 2px 8px;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.01em;
}

.message-meta {
  margin: 7px 0 0;
  font-size: 0.79rem;
  color: var(--text-faint);
  font-weight: 500;
}

.message-row.assistant .message-content {
  font-size: 1rem;
}

.message-row.user .message-shell {
  justify-content: flex-end;
}

.message-row.user .message-avatar {
  display: none;
}

.message-row.user .message-body {
  flex: 0 1 auto;
  max-width: min(720px, 84%);
  align-items: flex-end;
}

.message-row.user .message-content {
  font-size: 1rem;
  border: 1px solid var(--border);
  border-radius: 18px;
  border-bottom-right-radius: 6px;
  background: var(--surface-soft);
  padding: 10px 14px;
}

.message-row.user .message-mode-row {
  justify-content: flex-end;
}

.message-row.user .message-meta {
  display: none;
}

/* Chart containers in messages */
.message-chart-container {
  margin: 14px 0 4px;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--surface-soft);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8px;
}

.message-chart-container svg {
  max-width: 100%;
  height: auto;
  display: block;
}

.message-chart-container img {
  max-width: 100%;
  border-radius: 8px;
  display: block;
}

/* Markdown typography */
.message-content h1,
.message-content h2,
.message-content h3,
.message-content h4,
.message-content h5,
.message-content h6 {
  margin: 1.12em 0 0.45em;
  line-height: 1.35;
  font-weight: 600;
}

.message-content > h1:first-child,
.message-content > h2:first-child,
.message-content > h3:first-child,
.message-content > h4:first-child {
  margin-top: 0;
}

.message-content h1 {
  font-size: 1.32rem;
}

.message-content h2 {
  font-size: 1.15rem;
  border-bottom: 1px solid var(--border);
  padding-bottom: 5px;
}

.message-content h3 {
  font-size: 1.04rem;
}

.message-content h4,
.message-content h5,
.message-content h6 {
  font-size: 0.96rem;
  color: var(--text-muted);
}

.message-content p {
  margin: 0 0 0.82em;
}

.message-content p:last-child {
  margin-bottom: 0;
}

.message-content ul,
.message-content ol {
  margin: 0.44em 0 0.82em;
  padding-left: 1.55em;
}

.message-content li {
  margin: 0.32em 0;
}

.message-content code {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 0.85em;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--surface-soft);
  padding: 0.17em 0.4em;
}

.message-content pre {
  margin: 0.82em 0;
  border: 1px solid var(--border);
  border-radius: 11px;
  padding: 12px 15px;
  background: var(--bg-elevated);
  font-size: 0.88rem;
  line-height: 1.65;
  overflow-x: auto;
}

.message-content pre code {
  border: 0;
  border-radius: 0;
  padding: 0;
  background: transparent;
  font-size: inherit;
}

.message-content blockquote {
  margin: 0.82em 0;
  padding: 10px 14px;
  border-left: 3px solid var(--accent);
  border-radius: 0 9px 9px 0;
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  color: var(--text-muted);
}

.message-content a {
  color: var(--accent);
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
}

.message-content strong {
  font-weight: 700;
}

.message-content hr {
  border: 0;
  border-top: 1px solid var(--border);
  margin: 1.15em 0;
}

.message-content table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  margin: 0.82em 0;
  font-size: 0.9rem;
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  display: block;
  overflow-x: auto;
}

.message-content th,
.message-content td {
  border-right: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 9px 13px;
  text-align: left;
  min-width: 110px;
}

.message-content th {
  background: var(--surface);
  color: var(--text-muted);
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-weight: 600;
}

.message-content td:last-child,
.message-content th:last-child {
  border-right: 0;
}

.message-content tr:last-child td {
  border-bottom: 0;
}

.message-content tbody tr:hover td {
  background: var(--surface-soft);
}

/* Composer */
.composer-dock {
  border-top: 0;
  background: var(--bg);
  padding: 12px 20px 14px;
}

.main-panel.solar-open .composer-dock {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 60;
  background: transparent;
  border-top: 0;
}

.main-panel.solar-open .composer-container {
  background: rgba(8, 10, 24, 0.72);
  border-color: rgba(0, 188, 255, 0.28);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.42);
  backdrop-filter: blur(10px);
}

.main-panel.solar-open .composer-disclaimer {
  color: rgba(255, 255, 255, 0.55);
}

.suggestion-panel {
  width: min(840px, 100%);
  margin: 0 auto 9px;
  padding: 0 4px;
}

.suggestion-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 8px;
}

.suggestion-title {
  margin: 0;
  font-size: 0.76rem;
  color: var(--text-muted);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.suggestion-clear-btn {
  border: 0;
  background: transparent;
  color: var(--text-faint);
  font-size: 0.76rem;
  font-weight: 600;
  cursor: pointer;
  padding: 2px 4px;
  border-radius: 6px;
}

.suggestion-clear-btn:hover {
  color: var(--text);
  background: var(--surface-soft);
}

.suggestion-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.suggestion-chip {
  border: 1px solid var(--border);
  background: var(--bg-elevated);
  color: var(--text-muted);
  border-radius: 999px;
  min-height: 30px;
  padding: 6px 12px;
  display: inline-flex;
  align-items: center;
  font-size: 0.82rem;
  line-height: 1.35;
  cursor: pointer;
  transition: background 0.16s ease, color 0.16s ease, border-color 0.16s ease;
}

.suggestion-chip:hover {
  color: var(--text);
  background: var(--surface-soft);
  border-color: var(--text-muted);
}

.suggestion-chip.ask-original {
  border-color: var(--text-muted);
  color: var(--text);
}

.suggestion-chip.ask-original:hover {
  color: #fff;
  background: #1c1c1c;
  border-color: #1c1c1c;
}

.composer-container {
  width: min(840px, calc(100% - 44px));
  margin: 0 auto;
  border: 1px solid var(--border);
  border-radius: 28px;
  background: var(--bg-elevated);
  box-shadow: none;
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 8px 10px;
  transition: border-color 0.18s ease, box-shadow 0.18s ease;
}

.composer-container:focus-within {
  border-color: var(--text-muted);
  box-shadow: none;
}

.composer-input-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
}

.composer-menu-wrap {
  position: relative;
  align-self: center;
}

.composer-icon-btn {
  width: 40px;
  height: 40px;
  min-width: 40px;
  border: 0;
  border-radius: 50%;
  color: var(--text-muted);
  background: transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.16s ease, color 0.16s ease;
}

.composer-icon-btn:hover {
  color: var(--text);
  background: var(--surface);
}

.composer-plus-btn {
  border: 1px solid color-mix(in srgb, var(--border) 75%, var(--divider));
  background: color-mix(in srgb, var(--surface-soft) 82%, transparent);
}

.composer-menu {
  position: absolute;
  left: 0;
  bottom: calc(100% + 10px);
  min-width: 210px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--bg-elevated);
  box-shadow: var(--shadow-soft);
  padding: 6px;
  z-index: 12;
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.composer-menu-item {
  width: 100%;
  border: 0;
  border-radius: 10px;
  background: transparent;
  color: var(--text);
  text-align: left;
  padding: 9px 10px;
  cursor: pointer;
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.3;
  transition: background 0.12s ease;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.composer-menu-item:hover {
  background: var(--surface-soft);
}

.composer-menu-item.is-active {
  color: var(--accent);
  background: color-mix(in srgb, var(--accent) 11%, transparent);
}

.composer-menu-divider {
  height: 1px;
  margin: 4px 0;
  background: var(--divider);
}

.composer-menu-item-icon {
  width: 16px;
  height: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  flex-shrink: 0;
}

.composer-menu-item.has-chevron .composer-menu-item-end {
  margin-left: auto;
  color: var(--text-faint);
}

/* Attached files preview row */
.composer-attachments {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 8px 12px 4px;
  border-bottom: 1px solid var(--border);
}

.composer-file-chip {
  display: flex;
  align-items: center;
  gap: 6px;
  background: var(--surface-soft);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 4px 6px 4px 4px;
  max-width: 180px;
  min-width: 0;
}

.composer-file-thumb {
  width: 36px;
  height: 36px;
  border-radius: 5px;
  object-fit: cover;
  flex-shrink: 0;
}

.composer-file-icon {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--surface-2);
  border-radius: 5px;
  color: var(--text-muted);
  flex-shrink: 0;
}

.composer-file-name {
  font-size: 0.72rem;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  flex: 1;
  min-width: 0;
}

.composer-file-remove {
  flex-shrink: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  color: var(--text-muted);
  padding: 2px;
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color 0.15s;
}

.composer-file-remove:hover {
  color: var(--text);
}

.composer-meta-row {
  display: flex;
  align-items: center;
  min-height: 28px;
  padding: 0 4px 2px 4px;
}

.composer-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.composer-tag {
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 0.74rem;
  color: var(--text-muted);
  background: var(--surface-soft);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.composer-tag button {
  border: 0;
  background: transparent;
  color: var(--text-faint);
  cursor: pointer;
  font-size: 0.74rem;
  padding: 0;
}

.composer-tag button:hover {
  color: var(--text);
}

#queryInput {
  min-height: 38px;
  max-height: 180px;
  width: 100%;
  flex: 1;
  border: 0;
  background: transparent;
  color: var(--text);
  padding: 8px 0;
  resize: none;
  outline: none;
  line-height: 1.45;
  font-size: 1rem;
  font-weight: 400;
  overflow-y: hidden;
  scrollbar-width: none;
}

#queryInput::-webkit-scrollbar {
  display: none;
}

#queryInput::placeholder {
  color: color-mix(in srgb, var(--text-faint) 88%, var(--text-muted));
  font-size: 1rem;
}

#sendBtn {
  width: 40px;
  height: 40px;
  min-width: 40px;
  border: 0;
  border-radius: 50%;
  background: var(--accent);
  color: var(--accent-fg);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: transform 0.15s ease, opacity 0.15s ease, background 0.15s ease;
}

#sendBtn:hover:not([disabled]) {
  opacity: 0.95;
  background: var(--accent-strong);
}

#sendBtn:active:not([disabled]) {
  transform: scale(0.93);
}

#sendBtn[disabled] {
  opacity: 0.44;
  cursor: wait;
}

#sendBtn.is-stop {
  background: #1c1c1c;
  cursor: pointer;
  opacity: 1;
}

#sendBtn.is-stop:hover {
  background: #333;
  opacity: 1;
}

.composer-disclaimer {
  width: min(840px, 100%);
  margin: 8px auto 0;
  text-align: center;
  color: var(--text-faint);
  font-size: 0.7rem;
}

.error-banner {
  width: min(840px, 100%);
  margin: 8px auto 0;
  border: 1px solid color-mix(in srgb, var(--error) 55%, transparent);
  border-radius: 10px;
  background: var(--error-bg);
  color: var(--error);
  font-size: 0.84rem;
  font-weight: 500;
  padding: 10px 13px;
}

.hidden {
  display: none;
}

/* Sidebar chat search (keep global to avoid accidental nested-scope regressions) */
.sidebar-search-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 10px;
  background: var(--surface-soft);
  border: 1px solid var(--border);
  border-radius: 11px;
  margin: 2px 0;
  transition: border-color 0.2s, box-shadow 0.2s;
}

.sidebar-search-wrap:focus-within {
  border-color: #000;
  box-shadow: none;
  background: var(--surface);
}

.sidebar-search-icon {
  color: var(--text-faint);
  flex-shrink: 0;
}

.sidebar-search-input {
  flex: 1;
  min-width: 0;
  padding: 9px 0;
  border: none !important;
  outline: none !important;
  background: none;
  color: var(--text);
  font-size: 0.875rem;
}

.sidebar-search-input::placeholder {
  color: var(--text-faint);
}

.sidebar-search-clear {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  cursor: pointer;
  color: var(--text-faint);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 5px;
  margin-right: -4px;
  border-radius: 6px;
  flex-shrink: 0;
  transition: color 0.12s, background 0.12s;
}

.sidebar-search-clear:hover {
  color: var(--text);
  background: var(--surface-2) !important;
}

.sidebar-search-results {
  flex: 1;
  overflow-y: auto;
  padding: 4px 0;
  min-height: 0;
}

.sidebar-search-empty {
  padding: 20px 16px;
  font-size: 0.82rem;
  color: var(--text-faint);
  text-align: center;
  line-height: 1.5;
}

/* Thinking Widget styling */
.thinking-widget {
  margin-top: 4px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.thinking-main {
  display: flex;
  align-items: center;
  gap: 8px;
}

.thinking-star {
  color: var(--text-muted);
  font-size: 1rem;
  animation: pulse 2s infinite;
}

.thinking-label {
  font-size: 0.88rem;
  color: var(--text-muted);
  font-weight: 500;
}

.thinking-pipeline {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.thinking-stage {
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0;
  padding: 2px 8px;
  border-radius: 6px;
  border: 1px solid var(--border);
  color: var(--text-faint);
  transition: all 0.2s ease;
}

.thinking-stage.active {
  color: var(--text);
  border-color: var(--text-muted);
  background: transparent;
}

.thinking-stage.success {
  color: var(--text-muted);
  background: var(--surface);
  border-color: var(--border);
}

@keyframes pulse {
  0% {
    opacity: 0.5;
    transform: scale(0.95);
  }

  50% {
    opacity: 1;
    transform: scale(1.05);
  }

  100% {
    opacity: 0.5;
    transform: scale(0.95);
  }
}

/* Trace panel */
.trace-panel {
  position: absolute;
  top: 0;
  right: 0;
  width: 370px;
  height: 100%;
  border-left: 1px solid var(--border);
  background: color-mix(in srgb, var(--bg-elevated) 96%, transparent);
  transform: translateX(105%);
  transition: transform 0.24s ease;
  z-index: 16;
  display: flex;
  flex-direction: column;
}

body.trace-open .trace-panel,
.layout.trace-open .trace-panel,
.trace-panel.is-open {
  transform: translateX(0);
}

.trace-panel-header {
  min-height: 58px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 0 12px 0 14px;
}

.trace-panel-header h3 {
  margin: 0;
  font-size: 0.92rem;
  font-weight: 600;
}

.trace-panel-body {
  min-height: 0;
  flex: 1;
  overflow-y: auto;
  padding: 12px 12px 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.trace-panel-body::-webkit-scrollbar {
  width: 6px;
}

.trace-panel-body::-webkit-scrollbar-track {
  background: transparent;
}

.trace-panel-body::-webkit-scrollbar-thumb {
  background: var(--surface-2);
  border-radius: 999px;
}

.trace-empty {
  margin: 6px 0 0;
  font-size: 0.86rem;
  color: var(--text-faint);
  line-height: 1.45;
}

.trace-section {
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--surface-soft);
  padding: 10px 11px;
}

.trace-section-title {
  margin: 0 0 8px;
  color: var(--text-muted);
  font-size: 0.71rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.trace-stage-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 6px;
}

.trace-stage-item {
  font-size: 0.82rem;
  color: var(--text-muted);
  padding: 6px 9px;
  border-radius: 8px;
  border: 1px solid var(--border);
}

.trace-stage-item.success {
  color: var(--text-muted);
  border-color: var(--border);
  background: transparent;
}

.trace-stage-item.failed {
  color: var(--error);
  border-color: color-mix(in srgb, var(--error) 45%, var(--border));
  background: color-mix(in srgb, var(--error) 7%, transparent);
}

.trace-stage-item.active {
  color: var(--text);
  border-color: var(--text-muted);
  background: transparent;
  animation: trace-pulse 1.8s ease-in-out infinite;
}

@keyframes trace-pulse {
  0%,
  100% {
    opacity: 0.85;
  }

  50% {
    opacity: 1;
  }
}

/* Execution event log */
.trace-event-log {
  display: flex;
  flex-direction: column;
  gap: 6px;
  max-height: 300px;
  overflow-y: auto;
}

.trace-event-entry {
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 6px 8px;
  background: var(--bg-elevated);
}

.trace-event-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
  margin-bottom: 2px;
}

.trace-event-stage {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-muted);
}

.trace-event-message {
  margin: 0;
  font-size: 0.72rem;
  color: var(--text-faint);
  line-height: 1.35;
}

.trace-kv {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.trace-kv + .trace-kv {
  margin-top: 10px;
}

.trace-kv dt {
  color: var(--text-faint);
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.trace-kv dd {
  margin: 0;
  color: var(--text);
  font-size: 0.81rem;
  line-height: 1.45;
}

.trace-tool-card {
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--bg-elevated);
  padding: 8px 9px;
}

.trace-tool-card + .trace-tool-card {
  margin-top: 8px;
}

.trace-tool-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 7px;
}

.trace-tool-name {
  margin: 0;
  font-size: 0.83rem;
  font-weight: 600;
}

.trace-pill {
  border-radius: 999px;
  border: 1px solid var(--border);
  padding: 2px 8px;
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-faint);
}

.trace-pill.ok {
  color: var(--text-muted);
  border-color: var(--border);
  background: transparent;
}

.trace-pill.fail {
  color: var(--error);
  border-color: color-mix(in srgb, var(--error) 45%, var(--border));
  background: color-mix(in srgb, var(--error) 8%, transparent);
}

.trace-pill.active-tool {
  color: var(--text);
  border-color: var(--text-muted);
  background: transparent;
  animation: trace-pulse 1.8s ease-in-out infinite;
}

.trace-tool-card.is-active {
  border-color: color-mix(in srgb, var(--accent) 50%, var(--border));
  background: color-mix(in srgb, var(--accent) 5%, var(--bg-elevated));
}

.trace-tool-meta {
  margin: 0 0 7px;
  color: var(--text-faint);
  font-size: 0.73rem;
}

.trace-pre {
  margin: 0;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface-soft);
  padding: 8px 9px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 0.74rem;
  line-height: 1.42;
  color: var(--text-muted);
  white-space: pre-wrap;
  word-break: break-word;
  max-height: 180px;
  overflow: auto;
}

.trace-overlay {
  display: none;
  position: fixed;
  inset: 0;
  border: 0;
  padding: 0;
  margin: 0;
  background: rgba(0, 0, 0, 0.42);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
  z-index: 14;
}

/* ── TracePanel — vertical timeline ───────────────────────── */

/* Trace header */
.tp-header-left {
  display: flex;
  align-items: center;
  gap: 7px;
}

.tp-header-left h3 {
  margin: 0;
}

/* Empty state */
.tp-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  flex: 1;
  padding: 40px 24px;
  color: var(--text-faint);
  font-size: 0.83rem;
  text-align: center;
  line-height: 1.6;
}

.tp-empty p {
  margin: 0;
}

/* Scrollable content wrapper */
.tp-scroll {
  flex: 1;
  overflow-y: auto;
  padding: 14px 14px 48px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* Query chip at the top */
.tp-qchip {
  background: var(--surface-soft);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px 14px;
}

.tp-stage {
  font-size: 0.74rem;
  font-weight: 500;
  color: var(--text-faint);
}

.tp-stage.done {
  color: var(--text-muted);
}

.tp-stage.done::before {
  content: "✓ ";
}

.tp-stage.active {
  color: var(--text);
}

.tp-stage.active::before {
  content: "⟳ ";
}

.tp-stage:not(:last-child)::after {
  content: " · ";
  color: var(--text-faint);
}

/* Trace section block */
.tp-block {
  background: var(--surface-soft);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 12px 14px;
}

.tp-qchip-label {
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-faint);
  display: block;
  margin-bottom: 4px;
}

.tp-qchip-text {
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--text);
  line-height: 1.45;
  margin: 0;
}

/* Timeline node list */
.tp-nodes {
  display: flex;
  flex-direction: column;
}

/* Single pipeline node */
.tp-node {
  display: flex;
  gap: 0;
  min-height: 40px;
}

.tp-node-pending {
  opacity: 0.38;
}

/* Left rail: dot + vertical stem */
.tp-node-rail {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 28px;
  flex-shrink: 0;
  padding-top: 7px;
  position: relative;
}

.tp-node-dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--text-faint);
  flex-shrink: 0;
  position: relative;
  z-index: 2;
  transition: all 0.25s ease;
}

.tp-node-stem {
  position: absolute;
  top: 16px;
  bottom: -7px;
  width: 1px;
  background: var(--divider);
  z-index: 1;
}

.tp-node:last-child .tp-node-stem {
  display: none;
}

.tp-node-done .tp-node-dot {
  background: var(--text-muted);
}

.tp-node-active .tp-node-dot {
  background: var(--text);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--text) 10%, transparent);
}

.tp-value.tp-err {
  color: #e57373;
}

.tp-value.tp-muted {
  color: var(--text-faint);
  font-size: 0.8rem;
}

/* Node body */
.tp-node-body {
  flex: 1;
  padding: 0 0 16px 10px;
  min-width: 0;
}

.tp-node-head {
  display: flex;
  align-items: center;
  gap: 6px;
  min-height: 22px;
}

.tp-node-label {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--text-muted);
  flex: 1;
}

.tp-node-pending .tp-node-label {
  color: var(--text-faint);
  font-weight: 500;
}

.tp-node-dur {
  font-size: 0.7rem;
  color: var(--text-faint);
  font-variant-numeric: tabular-nums;
  margin-left: auto;
  flex-shrink: 0;
}

/* Active stage visual hint on text instead of border */
.tp-node-active .tp-node-label {
  color: var(--text);
}

/* Active stage: animated left accent line on body */
.tp-node-active .tp-node-body {
  border-left: 2px solid var(--border);
  padding-left: 8px;
  margin-left: -2px;
  animation: tpBodyPulse 1.6s ease-in-out infinite;
}

@keyframes tpBodyPulse {
  0%,
  100% {
    border-left-color: var(--border);
  }

  50% {
    border-left-color: var(--text-muted);
  }
}

/* Spinner for active stage */
@keyframes tpSpin {
  to {
    transform: rotate(360deg);
  }
}

.tp-node-spinner {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: 1.5px solid var(--border);
  border-top-color: var(--text-muted);
  animation: tpSpin 0.75s linear infinite;
  flex-shrink: 0;
}

/* Checkmark for done */
.tp-check {
  margin-left: auto;
  flex-shrink: 0;
  color: var(--text-faint);
}

/* Node inner content */
.tp-node-content {
  margin-top: 7px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.tp-node-text {
  font-size: 0.83rem;
  color: var(--text-muted);
  line-height: 1.55;
  margin: 0;
}

.tp-node-text.tp-bold {
  font-weight: 600;
  color: var(--text);
}

.tp-node-muted {
  font-size: 0.78rem;
  color: var(--text-faint);
  margin: 0;
}

.tp-node-tag {
  display: inline-flex;
  align-items: center;
  font-size: 0.7rem;
  color: var(--text-faint);
  background: var(--surface-soft);
  border: 1px solid var(--border);
  border-radius: 5px;
  padding: 2px 7px;
  width: fit-content;
  margin: 0;
}

.tp-node-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.tp-list li {
  font-size: 0.81rem;
  color: var(--text-muted);
  line-height: 1.5;
  padding-left: 12px;
  position: relative;
}

.tp-list li::before {
  content: "–";
  position: absolute;
  left: 2px;
  color: var(--text-faint);
}

/* Confidence bar */
.tp-confidence {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 2px 0;
}

.tp-confidence-label {
  font-size: 0.72rem;
  color: var(--text-faint);
  flex-shrink: 0;
}

.tp-confidence-bar {
  flex: 1;
  height: 4px;
  border-radius: 2px;
  background: var(--border);
  overflow: hidden;
  max-width: 80px;
}

.tp-confidence-fill {
  height: 100%;
  border-radius: 2px;
  background: #000;
  transition: width 0.5s ease;
}

.tp-confidence-val {
  font-size: 0.72rem;
  color: var(--text-faint);
  flex-shrink: 0;
}

/* Error text */
.tp-err-text {
  font-size: 0.82rem;
  color: #e57373;
  line-height: 1.5;
  margin: 4px 0 0;
}

/* Footer chips */
.tp-footer-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 4px;
}

.tp-chip {
  font-size: 0.7rem;
  color: var(--text-faint);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 3px 9px;
  background: var(--surface-soft);
}

/* Tool list within executing node */
.tp-tool-list {
  display: flex;
  flex-direction: column;
  gap: 1px;
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
  background: var(--surface-soft);
}

.tp-tool {
  border-bottom: 1px solid var(--border);
}

.tp-tool:last-child {
  border-bottom: none;
}

.tp-tool-btn {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  background: none;
  border: none;
  text-align: left;
  transition: background 0.1s;
}

.tp-tool-btn:hover {
  background: var(--surface-soft);
}

.tp-tool-pip {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}

.tp-dot.ok {
  background: var(--text-faint);
}

.tp-dot.err {
  background: #e57373;
}

.tp-tool-name {
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--text-muted);
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-transform: capitalize;
}

.tp-tool-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.73rem;
  color: var(--text-faint);
  flex-shrink: 0;
  font-variant-numeric: tabular-nums;
}

.tp-tool-detail {
  padding: 4px 10px 10px 24px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.tp-sub-label {
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-faint);
  margin: 0 0 2px;
}

.tp-pre {
  font-size: 0.7rem;
  line-height: 1.5;
  color: var(--text-muted);
  background: var(--surface);
  border-radius: 6px;
  padding: 7px 9px;
  overflow: auto;
  white-space: pre;
  max-height: 160px;
  margin: 0;
  border: 1px solid var(--border);
}

.tp-pre.tp-pre-err {
  color: #e57373;
}

/* Thinking */
.thinking-widget {
  display: flex;
  flex-direction: column;
  gap: 13px;
}

.thinking-main {
  display: flex;
  align-items: center;
  gap: 10px;
}

.thinking-star {
  font-size: 1.12rem;
  color: var(--accent);
  animation: t-star-pulse 2.2s ease-in-out infinite;
}

@keyframes t-star-pulse {
  0%,
  100% {
    transform: scale(1) rotate(0deg);
    opacity: 0.58;
  }

  50% {
    transform: scale(1.26) rotate(38deg);
    opacity: 1;
  }
}

.thinking-label {
  color: var(--text-muted);
  font-size: 0.96rem;
  font-weight: 400;
  transition: opacity 0.35s ease;
}

.thinking-label.fading {
  opacity: 0;
}

.thinking-pipeline {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.tp-step {
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 0.67rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--text-faint);
}

.tp-step.active {
  color: var(--text);
  border-color: var(--text-muted);
  background: transparent;
}

.tp-step.done {
  color: var(--text-muted);
  border-color: var(--border);
  background: transparent;
}

.tp-sep {
  color: var(--text-faint);
  font-size: 0.63rem;
}

.message-content span {
  transition: opacity 0.06s ease;
}

/* Charts */
.charts-container {
  margin-top: 1.3rem;
  display: flex;
  flex-direction: column;
  gap: 0.95rem;
}

.chart-wrapper {
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  background: var(--bg-elevated);
}

.chart-label {
  padding: 8px 14px;
  border-bottom: 1px solid var(--border);
  background: var(--surface);
  font-size: 0.67rem;
  font-weight: 700;
  color: var(--text-muted);
  letter-spacing: 0.09em;
  text-transform: uppercase;
}

.chart-svg,
.chart-img {
  padding: 14px;
}

.chart-svg {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.chart-svg svg,
.chart-img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
}

/* Mobile sidebar overlay */
.sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  border: 0;
  padding: 0;
  margin: 0;
  background: rgba(0, 0, 0, 0.45);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
  z-index: 15;
}

/* Responsive */
@media (max-width: 1280px) {
  .layout {
    --sidebar-width: 256px;
  }

  .messages,
  .suggestion-panel,
  .composer-container,
  .composer-disclaimer,
  .error-banner,
  .empty-state {
    width: min(820px, calc(100% - 46px));
  }
}

@media (min-width: 1081px) {
  body.sidebar-collapsed .layout {
    grid-template-columns: var(--sidebar-rail-width) 0 minmax(0, 1fr);
  }

  body.sidebar-collapsed .resize-handle {
    display: none;
  }

  body.sidebar-collapsed .sidebar {
    border-right: 1px solid var(--divider);
  }

  body.sidebar-collapsed .sidebar-rail {
    display: flex;
  }

  body.sidebar-collapsed .sidebar-expanded {
    display: none;
  }
}

@media (max-width: 1080px) {
  .layout {
    grid-template-columns: 1fr;
  }

  .main-panel {
    grid-column: 1;
  }

  .sidebar {
    position: fixed;
    top: 0;
    left: 0;
    width: min(320px, 88vw);
    height: 100vh;
    z-index: 20;
    transform: translateX(-104%);
    transition: transform 0.24s ease;
    box-shadow: 18px 0 28px rgba(0, 0, 0, 0.28);
    overflow: visible;
  }

  body.sidebar-open .sidebar {
    transform: translateX(0);
  }

  .sidebar-expanded {
    display: flex;
    overflow-x: visible;
  }

  .sidebar-profile-dropdown {
    position: fixed !important;
    bottom: 72px !important;
    top: auto !important;
    left: 12px !important;
    right: 12px !important;
    width: auto !important;
    max-height: calc(100vh - 100px) !important;
  }

  .sidebar-rail {
    display: none !important;
  }

  .resize-handle {
    display: none;
  }

  .sidebar-toggle-btn {
    display: inline-flex;
  }

  .sidebar-close-btn {
    display: inline-flex;
  }

  .sidebar-overlay {
    display: block;
  }

  body.sidebar-open .sidebar-overlay {
    opacity: 1;
    pointer-events: auto;
  }

  .messages,
  .suggestion-panel,
  .composer-container,
  .composer-disclaimer,
  .error-banner,
  .empty-state {
    width: calc(100% - 36px);
  }

  body.trace-open .main-panel {
    padding-right: 0;
  }

  .trace-panel {
    position: fixed;
    top: 0;
    right: 0;
    width: min(390px, 92vw);
    height: 100vh;
    z-index: 22;
    transform: translateX(105%);
    box-shadow: -18px 0 26px rgba(0, 0, 0, 0.28);
  }

  .trace-overlay {
    display: block;
  }

  body.trace-open .trace-overlay {
    opacity: 1;
    pointer-events: auto;
  }
}

@media (max-width: 760px) {
  body {
    font-size: 15px;
  }

  .topbar {
    height: 54px;
    padding: 0 12px;
  }

  .topbar-title {
    font-size: 0.9rem;
  }

  .header-share-btn span {
    display: none;
  }

  .header-share-btn {
    width: 34px;
    height: 34px;
    min-width: 34px;
    border-radius: 9px;
    justify-content: center;
    padding: 0;
  }

  .empty-state {
    padding: 34px 0 32px;
  }

  .empty-title {
    font-size: 1.63rem;
  }

  .empty-subtitle {
    font-size: 0.9rem;
    margin-bottom: 22px;
  }

  .prompt-grid {
    grid-template-columns: 1fr;
  }

  .messages {
    gap: 20px;
    padding: 17px 0 12px;
    width: calc(100% - 24px);
  }

  .message-shell {
    gap: 9px;
  }

  .message-avatar {
    width: 26px;
    height: 26px;
    border-radius: 7px;
    font-size: 0.66rem;
    margin-top: 1px;
  }

  .message-row.user .message-body {
    max-width: 92%;
  }

  .composer-dock {
    padding: 10px 12px 12px;
  }

  .composer-container,
  .suggestion-panel,
  .composer-disclaimer,
  .error-banner {
    width: 100%;
  }

  .composer-container {
    border-radius: 21px;
    gap: 6px;
    padding: 7px 8px 7px 9px;
  }

  .composer-icon-btn,
  #sendBtn {
    width: 34px;
    height: 34px;
    min-width: 34px;
  }

  #queryInput {
    min-height: 30px;
    font-size: 0.96rem;
  }
}

@media (max-width: 520px) {
  .sidebar {
    width: 92vw;
  }

  .topbar-right {
    gap: 6px;
  }

  .icon-btn {
    width: 32px;
    height: 32px;
  }

  .empty-kicker {
    letter-spacing: 0.11em;
  }
}

/* ============================================================
   Classifier split card
   ============================================================ */

.classifier-choice {
  max-width: 680px;
  margin: 16px auto 0;
  padding: 0 4px;
}

.classifier-choice-intro {
  font-size: 0.9rem;
  color: var(--text-muted);
  margin: 0 0 12px;
}

.choice-cards {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}

.choice-card {
  flex: 1;
  min-width: 200px;
  border-radius: 14px;
  padding: 20px;
  background: var(--surface);
  border: 1.5px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.choice-card.precise {
  border-color: var(--border);
}

.choice-card-icon {
  font-size: 1.4rem;
  line-height: 1;
}

.choice-card-title {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text);
  margin: 0;
}

.choice-card-sub {
  font-size: 0.85rem;
  color: var(--text-muted);
  margin: 0;
}

.choice-card-assumptions {
  font-size: 0.8rem;
  color: var(--text-faint);
  margin: 4px 0 0;
  padding-left: 16px;
  list-style: disc;
  flex: 1;
}

.choice-card-assumptions li {
  margin-bottom: 3px;
}

.choice-card-btn {
  margin-top: auto;
  width: 100%;
  padding: 9px 14px;
  border-radius: 8px;
  border: 1.5px solid var(--border);
  background: transparent;
  color: var(--text);
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}

.choice-card-btn:hover {
  background: var(--surface-2);
}

.choice-card-btn.accent {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--accent-fg);
}

.choice-card-btn.accent:hover {
  background: var(--accent-strong);
  border-color: var(--accent-strong);
}

/* ============================================================
   Clarification form
   ============================================================ */

.clarification-form {
  max-width: 680px;
  margin: 16px auto 0;
  padding: 0 4px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.clarification-intro {
  font-size: 0.9rem;
  color: var(--text-muted);
  margin: 0;
}

.clarification-q {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.clarification-q label {
  font-size: 0.875rem;
  color: var(--text);
  font-weight: 500;
}

.clarification-q textarea {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: 8px;
  padding: 10px 12px;
  color: var(--text);
  font-size: 0.875rem;
  resize: vertical;
  min-height: 56px;
  outline: none;
  transition: border-color 0.15s;
}

.clarification-q textarea:focus {
  border-color: var(--accent);
}

.clarification-skip {
  background: none;
  border: none;
  padding: 0;
  font-size: 0.8rem;
  color: var(--text-faint);
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 3px;
  align-self: flex-start;
}

.clarification-skip:hover {
  color: var(--text-muted);
}

@media (max-width: 480px) {
  .choice-cards {
    flex-direction: column;
  }

  .choice-card {
    min-width: unset;
  }
}

/* =====================================================
   KUNDLI SECTION ONE  –  Infinite Scroll, No Cards
   ===================================================== */

.ks1-scroll {
  width: 100%;
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  background: var(--bg);
}

.ks1-scroll > .ks1-split-view + section,
.ks1-scroll > section + section {
  margin-top: 28px;
}

/* ── Header Bar ────────────────────────────────────────── */
.ks1-header-bar {
  width: 100%;
  background: color-mix(in srgb, var(--surface) 40%, transparent);
  backdrop-filter: blur(8px);
  border-bottom: 2px solid var(--border-soft);
  display: flex;
  flex-wrap: wrap;
  gap: 28px;
  padding: 14px 24px;
  justify-content: flex-start;
  align-items: center;
}

.ks1-profile-icon {
  width: 44px;
  height: 44px;
  background: var(--accent);
  /* Solid color icon */
  color: white;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 1.4rem;
  font-weight: 700;
  text-transform: uppercase;
  flex-shrink: 0;
}

.ks1-header-item {
  display: flex;
  gap: 6px;
  white-space: nowrap;
  font-size: 0.88rem;
  color: var(--text);
}

.ks1-header-item strong {
  font-weight: 700;
  color: var(--text-faint);
}

/* ── Split Layout ──────────────────────────────────── */
.ks1-split-view {
  width: 1024px;
  max-width: 100%;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  padding: 56px 24px 64px;
  align-items: flex-start;
}

.ks1-left-panel {
  display: flex;
  flex-direction: column;
  gap: 28px;
}

.ks1-right-panel {
  display: flex;
  justify-content: center;
  align-items: center;
}

.ks1-panel-title {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--text);
}

.ks1-astro-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background: color-mix(in srgb, var(--surface) 30%, transparent);
  backdrop-filter: blur(4px);
  border-radius: 12px;
  overflow: hidden;
  border: 1.5px solid rgba(0, 0, 0, 0.5);
  /* Light green border */
}

.ks1-astro-table tr {
  border-bottom: 1px solid var(--divider-soft);
}

.ks1-astro-table tr:nth-child(even) {
  /* Light green row highlight */
  background: rgba(0, 0, 0, 0.08) !important;
}

.ks1-astro-table tr:last-child {
  border-bottom: none;
}

.ks1-astro-table td {
  padding: 14px 20px;
  font-size: 0.95rem;
  border-right: 1px solid var(--divider-soft);
}

.ks1-astro-table td:first-child {
  font-weight: 600;
  color: var(--text-faint);
  width: 42%;
}

.ks1-astro-table td:last-child {
  color: var(--text);
  font-weight: 550;
  text-align: left;
  border-right: none;
}

.ks1-hero {
  display: none;
  /* Hide the old hero as we use header bar */
}

/* ── Name ──────────────────────────────────────────── */
.ks1-name {
  margin: 0;
  font-size: clamp(2.4rem, 5.5vw, 3.8rem);
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 1.08;
  color: var(--text);
}

.ks1-caret {
  display: inline-block;
  width: 3px;
  height: 0.82em;
  margin-left: 3px;
  background: var(--accent);
  vertical-align: baseline;
  border-radius: 1px;
  animation: ks1-blink 0.72s ease-in-out infinite;
}

.ks1-caret.done {
  animation: none;
}

@keyframes ks1-blink {
  0%,
  100% {
    opacity: 1;
  }

  50% {
    opacity: 0;
  }
}

/* ── Birth details (minimal centered lines) ────────── */
.ks1-details {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
}

.ks1-detail-primary {
  margin: 0;
  font-size: 1rem;
  font-weight: 500;
  color: var(--text-muted);
  letter-spacing: 0.02em;
}

.ks1-detail-secondary {
  margin: 0;
  font-size: 0.88rem;
  color: var(--text-faint);
  letter-spacing: 0.01em;
}

/* ── Chart section removed in favor of split-view ── */
.ks1-chart-section {
  display: none;
}

.ks1-chart-canvas {
  display: grid;
  place-items: center;
  min-width: 380px;
  min-height: 380px;
  background: radial-gradient(
    circle at center,
    color-mix(in srgb, var(--surface) 20%, transparent),
    transparent 75%
  );
  border-radius: 50%;
  padding: 30px;
}

/* ── Responsive ────────────────────────────────────── */
@media (max-width: 700px) {
  .ks1-hero {
    padding: 60px 16px 16px;
    gap: 16px;
  }

  .ks1-name {
    font-size: 2.2rem;
  }

  .ks1-detail-primary {
    font-size: 0.9rem;
  }

  .ks1-detail-secondary {
    font-size: 0.8rem;
  }

  .ks1-chart-section {
    padding: 0 14px 48px;
  }

  .ks1-chart-canvas {
    min-width: 290px;
    min-height: 290px;
    transform: scale(0.88);
  }
}

/* =====================================================
   KUNDLI SECTION TWO – PLANETARY PLACEMENTS (VERTICAL TABLE)
   ===================================================== */

.ks2-section {
  width: 100%;
  max-width: 1024px;
  margin: 0 auto;
  padding: 32px 24px 80px;
  display: flex;
  flex-direction: column;
  gap: 32px;
}

/* ── Planet-centric Table Redesign ──────────────────── */
.ks2-vtable {
  width: 100%;
  display: flex;
  flex-direction: column;
  background: color-mix(in srgb, var(--surface) 20%, transparent);
  border: 1.5px solid var(--border);
  /* Slightly stronger than 'very light' but still clean */
  border-radius: 12px;
  overflow: hidden;
  backdrop-filter: blur(8px);
}

.ks2-vt-head {
  display: grid;
  grid-template-columns: 80px 1fr 1fr 1fr 1.2fr 1.1fr 1fr;
  background: color-mix(in srgb, var(--surface) 60%, transparent);
  border-bottom: 2px solid var(--border);
  padding: 16px 20px;
  gap: 12px;
  font-weight: 700;
  font-size: 0.75rem;
  color: var(--text-faint);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  align-items: center;
}

.ks2-vt-body {
  display: flex;
  flex-direction: column;
}

.ks2-vt-row {
  display: grid;
  grid-template-columns: 80px 1fr 1fr 1fr 1.2fr 1.1fr 1fr;
  padding: 14px 20px;
  gap: 12px;
  border-bottom: 1px solid var(--divider-faint);
  align-items: center;
  transition: all 0.24s cubic-bezier(0.16, 1, 0.3, 1);
}

.ks2-vt-row:last-child {
  border-bottom: none;
}

/* Filled Houses - Premium Highlight (Green) */
.ks2-vt-row--filled {
  background: color-mix(in srgb, #27ae60 10%, transparent);
  border-left: none;
  /* Removed left border */
}

/* Empty Houses - Transparent & Subtle */
.ks2-vt-row--empty {
  background: transparent;
  border-left: none;
  /* Removed left border */
}

.ks2-vt-row:hover {
  background: color-mix(in srgb, var(--accent) 8%, transparent);
}

.ks2-vt-dim {
  color: var(--text-faint) !important;
  opacity: 0.5;
}

.ks2-vt-hnum {
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--accent);
  opacity: 0.95;
}

.ks2-vt-pname {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text);
}

.ks2-vt-sign {
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--text-muted);
}

.ks2-vt-deg {
  font-size: 0.88rem;
  font-variant-numeric: tabular-nums;
  color: var(--text-muted);
  font-family: inherit;
}

.ks2-vt-nak {
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--text-muted);
}

.ks2-vt-avastha {
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--accent);
  padding: 4px 10px;
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  border-radius: 6px;
  width: fit-content;
}

.ks2-vt-status {
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--text-muted);
}

@media (max-width: 850px) {
  .ks2-vt-hide-sm {
    display: none;
  }

  .ks2-vt-head,
  .ks2-vt-row {
    grid-template-columns: 60px 1fr 1fr 1fr 1fr;
  }
}

@media (max-width: 600px) {
  .ks2-vt-head,
  .ks2-vt-row {
    grid-template-columns: 50px 1fr 1fr 1fr;
    padding: 12px 14px;
    font-size: 0.85rem;
  }

  .ks2-vt-avastha {
    padding: 2px 6px;
    font-size: 0.75rem;
  }
}

/* =====================================================
   KUNDLI SECTION TWO – RASHI (D1) PLACEMENT ATLAS
   ===================================================== */

.ks2-section {
  width: 1024px;
  max-width: 100%;
  margin: 0 auto;
  padding: 18px 24px 96px;
  display: flex;
  flex-direction: column;
  gap: 24px;
  align-items: stretch;
}

.ks2-header {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.ks2-kicker {
  margin: 0;
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-faint);
  font-weight: 600;
}

.ks2-title {
  margin: 0;
  font-size: clamp(1.5rem, 2.2vw, 2rem);
  line-height: 1.18;
  letter-spacing: -0.02em;
  font-weight: 650;
  color: var(--text);
  text-align: left;
}

.ks2-subtitle {
  margin: 0;
  max-width: 720px;
  color: var(--text-muted);
  font-size: 0.94rem;
  text-align: left;
}

.ks2-filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.ks2-filter-chip {
  border: 1px solid var(--border);
  background: var(--surface-soft);
  color: var(--text-muted);
  border-radius: 999px;
  height: 34px;
  padding: 0 12px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  transition: border-color 0.16s ease, color 0.16s ease, background 0.16s ease;
}

.ks2-filter-chip:hover {
  color: var(--text);
  border-color: color-mix(in srgb, var(--accent) 34%, var(--border));
}

.ks2-filter-chip:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--accent) 66%, transparent);
  outline-offset: 1px;
}

.ks2-filter-chip-active {
  color: var(--text);
  background: color-mix(in srgb, var(--accent) 14%, var(--surface-soft));
  border-color: color-mix(in srgb, var(--accent) 52%, var(--border));
}

.ks2-filter-count {
  min-width: 18px;
  height: 18px;
  border-radius: 999px;
  background: var(--surface-2);
  color: var(--text-faint);
  font-size: 0.72rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 5px;
}

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

.ks2-house-card {
  border: 1px solid var(--border);
  border-radius: 14px;
  background: color-mix(in srgb, var(--bg-elevated) 88%, transparent);
  min-height: 148px;
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  cursor: pointer;
  transition: border-color 0.16s ease, background 0.16s ease, opacity 0.16s ease;
}

.ks2-house-card:hover {
  border-color: color-mix(in srgb, var(--accent) 30%, var(--border));
}

.ks2-house-card:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--accent) 66%, transparent);
  outline-offset: 1px;
}

.ks2-house-card-active {
  border-color: color-mix(in srgb, var(--accent) 58%, var(--border));
  background: color-mix(in srgb, var(--accent) 7%, var(--bg-elevated));
}

.ks2-house-card-muted {
  opacity: 0.4;
}

.ks2-house-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}

.ks2-house-id {
  margin: 0;
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-faint);
}

.ks2-sign-name {
  margin: 3px 0 0;
  font-size: 1.03rem;
  line-height: 1.2;
  color: var(--text);
}

.ks2-occupant-count {
  min-width: 50px;
  height: 24px;
  border-radius: 999px;
  border: 1px solid var(--border);
  color: var(--text-muted);
  background: var(--surface-soft);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.76rem;
}

.ks2-chip-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.ks2-planet-chip {
  height: 28px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--surface-soft);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 0 9px;
  font-size: 0.73rem;
  color: var(--text-muted);
}

.ks2-planet-short {
  color: var(--text);
  font-weight: 600;
}

.ks2-planet-degree {
  color: var(--text-faint);
}

.ks2-state-chip {
  padding: 0 5px;
  height: 16px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 18%, var(--surface-2));
  color: var(--text);
  font-size: 0.64rem;
  display: inline-flex;
  align-items: center;
}

.ks2-empty-note {
  margin: 2px 0 0;
  color: var(--text-faint);
  font-size: 0.82rem;
}

.ks2-detail-panel {
  border-top: 1px solid var(--divider);
  padding-top: 10px;
  overflow: hidden;
}

.ks2-detail-list {
  display: flex;
  flex-direction: column;
  gap: 9px;
}

.ks2-detail-item {
  border: 1px solid var(--border);
  border-radius: 10px;
  background: color-mix(in srgb, var(--surface-soft) 86%, transparent);
  padding: 8px 10px;
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.ks2-detail-top {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  align-items: baseline;
}

.ks2-detail-name,
.ks2-detail-degree,
.ks2-detail-meta,
.ks2-detail-aspects,
.ks2-detail-empty {
  margin: 0;
}

.ks2-detail-name {
  font-size: 0.87rem;
  color: var(--text);
  font-weight: 600;
}

.ks2-detail-degree {
  font-size: 0.77rem;
  color: var(--text-faint);
}

.ks2-detail-meta {
  font-size: 0.76rem;
  color: var(--text-muted);
}

.ks2-detail-aspects {
  font-size: 0.74rem;
  color: var(--text-faint);
}

.ks2-detail-empty {
  font-size: 0.82rem;
  color: var(--text-faint);
}

@media (max-width: 980px) {
  .ks2-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 700px) {
  .ks2-section {
    padding: 8px 16px 78px;
    gap: 18px;
  }

  .ks2-filter-chip {
    height: 32px;
    font-size: 0.82rem;
  }

  .ks2-grid {
    grid-template-columns: 1fr;
    gap: 11px;
  }

  .ks2-house-card {
    border-radius: 12px;
    min-height: 132px;
    padding: 12px;
  }
}

/* =====================================================
   KUNDLI SECTION EIGHT – DASHA TIMELINE SERIES GRAPH
   ===================================================== */

.ks8-section {
  width: 100%;
  max-width: 1024px;
  /* 5xl */
  margin: 0 auto;
  padding: 32px 40px 80px;
  display: flex;
  flex-direction: column;
  gap: 32px;
}

.ks8-header {
  text-align: left;
}

.ks8-title {
  margin: 0;
  font-size: clamp(1.4rem, 2.4vw, 1.9rem);
  font-weight: 650;
  letter-spacing: -0.02em;
  color: var(--text);
}

.ks8-subtitle {
  margin: 4px 0 0;
  font-size: 0.9rem;
  color: var(--text-muted);
}

.ks8-level-tabs {
  display: flex;
  justify-content: flex-start;
  gap: 0;
  border: 1.5px solid var(--border);
  border-radius: 8px;
  /* Rounded corners */
  width: fit-content;
  overflow: hidden;
  margin-bottom: 24px;
}

.ks8-tab {
  border: none;
  border-right: 1px solid var(--border);
  background: transparent;
  color: var(--text-muted);
  height: 38px;
  padding: 0 20px;
  font-size: 0.86rem;
  font-weight: 650;
  cursor: pointer;
  transition: all 0.2s ease;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  display: flex;
  align-items: center;
  justify-content: center;
}

.ks8-tab:last-child {
  border-right: none;
}

.ks8-tab:hover {
  background: color-mix(in srgb, var(--accent) 5%, transparent);
  color: var(--text);
}

.ks8-tab.active {
  color: white;
  background: var(--accent);
}

/* ── Cycle Wrap (Wrapped, Border-focused Implementation) ── */
.ks8-cycle-wrap {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  /* No horizontal scroll */
  gap: 24px 32px;
  padding: 16px 0 32px;
  align-items: flex-start;
  margin-bottom: 12px;
  /* Reduced gap */
}

.ks8-flow-item {
  display: flex;
  align-items: center;
  gap: 20px;
}

.ks8-node {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 0;
  min-width: 180px;
}

.ks8-node-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 38px;
  height: 38px;
  border: 1.5px solid var(--border);
  border-radius: 8px;
  color: var(--text);
  background: color-mix(in srgb, var(--surface) 50%, transparent);
}

.ks8-node-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.ks8-node-header {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ks8-node-lvl {
  font-size: 0.62rem;
  font-weight: 800;
  color: var(--accent);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  border: 1px solid var(--accent);
  padding: 2px 8px;
  border-radius: 4px;
  width: fit-content;
}

.ks8-node-pname {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--text);
  line-height: 1.2;
}

.ks8-node-dates {
  font-size: 0.72rem;
  color: var(--text-faint);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.ks8-node-arrow {
  color: var(--divider-soft);
  opacity: 0.5;
  display: flex;
  align-items: center;
  height: 100%;
}

.ks8-picon {
  opacity: 0.9;
}

.ks8-picon.su {
  color: #f59e0b;
}

.ks8-picon.mo {
  color: #94a3b8;
}

.ks8-picon.ma {
  color: #ef4444;
}

.ks8-picon.me {
  color: #000;
}

.ks8-picon.ju {
  color: #8b5cf6;
}

.ks8-picon.ve {
  color: #ec4899;
}

.ks8-picon.sa {
  color: #475569;
}

.ks8-picon.ra {
  color: #6366f1;
}

.ks8-picon.ke {
  color: #64748b;
}

.ks8-level-tabs-container {
  width: 100%;
  margin-bottom: 24px;
}

/* ── Timeline Series Graph ─────────────────────────── */
.ks8-series-container {
  width: 100%;
  max-width: 1024px;
  overflow-x: auto;
  padding: 24px 40px;
  scroll-behavior: smooth;
  scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
  /* subtle mask to fade edges if overflowing */
  -webkit-mask-image: linear-gradient(
    90deg,
    transparent,
    #000 5%,
    #000 95%,
    transparent
  );
  mask-image: linear-gradient(
    90deg,
    transparent,
    #000 5%,
    #000 95%,
    transparent
  );
}

.ks8-series-container::-webkit-scrollbar {
  height: 6px;
}

.ks8-series-container::-webkit-scrollbar-thumb {
  background: var(--border);
  border-radius: 3px;
}

.ks8-series-track {
  display: flex;
  align-items: flex-end;
  gap: 6px;
  position: relative;
  min-height: 56px;
  padding-bottom: 0;
}

.ks8-series-block {
  position: relative;
  height: 56px;
  /* More compact height */
  border: none;
  background: transparent;
  padding: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  cursor: pointer;
  outline: none;
}

/* Base styling for the block background */
.ks8-block-bg {
  position: absolute;
  inset: 0;
  background: color-mix(in srgb, var(--surface-soft) 60%, transparent);
  border: 1.5px solid var(--border);
  /* Thinner border */
  border-radius: 6px 6px 0 0;
  transition: all 0.2s ease;
  z-index: 1;
}

.ks8-series-block:hover .ks8-block-bg {
  background: color-mix(in srgb, var(--surface-soft) 80%, transparent);
  border-color: color-mix(in srgb, var(--accent) 30%, var(--border));
}

.ks8-series-block.current .ks8-block-bg {
  background: color-mix(in srgb, var(--accent) 15%, var(--surface-soft));
  border: 1.5px solid var(--accent);
}

.ks8-series-block.selected .ks8-block-bg {
  background: color-mix(in srgb, var(--accent) 25%, var(--surface-soft));
  border: 2px solid var(--accent);
  box-shadow: 0 0 12px color-mix(in srgb, var(--accent) 25%, transparent);
}

.ks8-series-block.upcoming .ks8-block-bg {
  border-style: dashed;
  opacity: 0.8;
}

.ks8-series-block.past .ks8-block-bg {
  opacity: 0.5;
}

/* Progress fill within the block */
.ks8-block-progress {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  background: color-mix(in srgb, var(--accent) 25%, transparent);
  border-right: 1.5px solid color-mix(in srgb, var(--accent) 40%, transparent);
  z-index: 2;
  pointer-events: none;
  border-radius: inherit;
  transition: width 0.3s ease;
}

.ks8-block-content {
  position: relative;
  z-index: 3;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-bottom: 6px;
  gap: 2px;
  pointer-events: none;
}

.ks8-block-planet {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--text-muted);
}

.ks8-series-block.selected .ks8-block-planet,
.ks8-series-block.current .ks8-block-planet {
  color: var(--text);
}

.ks8-block-year {
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--text);
  letter-spacing: 0.02em;
}

.ks8-series-block.selected .ks8-block-year,
.ks8-series-block.current .ks8-block-year {
  color: var(--text);
}

/* ── Time Axis ─────────────────────────────────────── */
.ks8-series-axis {
  display: flex;
  gap: 6px;
  /* Slightly tighter gap */
  border-top: 1px solid var(--border);
  padding-top: 6px;
}

.ks8-axis-segment {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.ks8-axis-tick {
  position: absolute;
  top: -6px;
  left: 0;
  width: 1px;
  height: 4px;
  background: var(--border);
}

.ks8-axis-date {
  font-size: 0.6rem;
  color: var(--text-faint);
  white-space: nowrap;
  transform: translateX(-4px);
}

/* ── Detail Card ───────────────────────────────────── */
.ks8-detail-card {
  display: none;
  /* Removed as requested */
}

.ks8-card-top {
  display: flex;
  align-items: center;
  gap: 16px;
}

.ks8-card-badge {
  width: 48px;
  height: 48px;
  border-radius: 10px;
  border: 1px solid color-mix(in srgb, var(--accent) 40%, var(--border));
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  display: grid;
  place-items: center;
  font-size: 1rem;
  font-weight: 700;
  color: var(--text);
}

.ks8-card-info {
  flex: 1;
  display: flex;
  flex-direction: column;
}

.ks8-card-level {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-faint);
}

.ks8-card-planet {
  font-size: 1.25rem;
  font-weight: 650;
  color: var(--text);
  margin-top: 2px;
}

.ks8-card-status {
  padding: 4px 10px;
  border-radius: 6px;
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.ks8-card-status.live {
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  color: color-mix(in srgb, var(--accent) 80%, white);
}

.ks8-card-status.next {
  background: color-mix(in srgb, #67c5ff 14%, transparent);
  color: #67c5ff;
}

.ks8-card-status.past {
  background: color-mix(in srgb, var(--text-faint) 15%, transparent);
  color: var(--text-muted);
}

.ks8-card-meta {
  display: flex;
  flex-direction: column;
  gap: 12px;
  border-top: 1px solid var(--divider);
  padding-top: 16px;
}

.ks8-meta-item {
  display: flex;
  align-items: baseline;
  gap: 8px;
}

.ks8-meta-label {
  flex: 0 0 110px;
  font-size: 0.75rem;
  color: var(--text-faint);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.ks8-meta-val {
  font-size: 0.94rem;
  color: var(--text);
  font-weight: 500;
}

.ks8-meta-sub {
  font-size: 0.88rem;
  color: var(--text-muted);
}

.ks8-card-progress {
  display: flex;
  align-items: center;
  gap: 12px;
  border-top: 1px solid var(--divider);
  padding-top: 16px;
}

.ks8-progress-bar {
  flex: 1;
  height: 6px;
  border-radius: 3px;
  background: color-mix(in srgb, var(--surface-soft) 80%, transparent);
  overflow: hidden;
}

.ks8-progress-fill {
  height: 100%;
  background: var(--accent);
  border-radius: inherit;
}

.ks8-progress-text {
  font-size: 0.82rem;
  color: var(--text-faint);
  min-width: 32px;
  text-align: right;
}

/* ── Responsive ────────────────────────────────────── */
@media (max-width: 700px) {
  .ks8-section {
    padding: 60px 16px;
    gap: 24px;
    border-radius: 20px;
  }

  .ks8-series-container {
    padding: 16px 20px;
  }

  .ks8-meta-item {
    flex-direction: column;
    gap: 4px;
    align-items: flex-start;
  }

  .ks8-meta-label {
    flex: none;
  }
}

/* =====================================================
   SECTION 9 – DIVISIONAL CHARTS
   ===================================================== */

.ks9-section {
  width: 100%;
  max-width: 1024px;
  margin: 0 auto;
  padding: 60px 24px;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 24px;
}

.ks9-header {
  text-align: left;
  max-width: 600px;
}

.ks9-title {
  margin: 0;
  font-size: clamp(1.4rem, 2.4vw, 1.9rem);
  font-weight: 650;
  letter-spacing: -0.02em;
  color: var(--text);
}

.ks9-subtitle {
  margin: 4px 0 0;
  color: var(--text-muted);
  font-size: 0.9rem;
}

.ks9-stack {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  width: 100%;
  max-width: 1024px;
  margin: 0;
}

.ks9-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  min-width: 0;
}

.ks9-label {
  margin: 0;
  font-size: 1rem;
  font-weight: 650;
  color: var(--text);
  text-align: center;
}

.ks9-chart-select {
  color: var(--text);
  padding: 10px 16px;
  width: 90%;
  max-width: 260px;
  border: 2px solid rgba(0, 0, 0, 0.35);
  border-radius: 12px;
  background: color-mix(in srgb, var(--surface) 60%, transparent);
  backdrop-filter: blur(8px);
  font-size: 0.88rem;
  font-weight: 600;
  cursor: pointer;
  outline: none;
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  margin-bottom: 8px;
  text-align: center;
  text-align-last: center;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23a3a3b3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 16px;
  box-shadow: none;
}

.ks9-chart-select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(0, 0, 0, 0.15);
  background-color: var(--surface);
}

.ks9-chart-select:hover {
  background-color: var(--surface-2);
  border-color: var(--text-faint);
  transform: translateY(-1px);
  box-shadow: none;
}

.ks9-chart-canvas {
  width: 100%;
  max-width: 320px;
  aspect-ratio: 1 / 1;
  display: flex;
  justify-content: center;
  align-items: center;
  background: transparent;
  border-radius: 12px;
  padding: 10px;
}

.ks9-chart-canvas svg {
  max-width: 100%;
  max-height: 100%;
}

@media (max-width: 900px) {
  .ks9-stack {
    grid-template-columns: 1fr;
    max-width: 400px;
    gap: 40px;
  }
}

/* =====================================================
   INLINE HEADER — SectionShell inline variant
   (used by Insight Summary section)
   ===================================================== */

.ks1-inline-header {
  display: flex;
  align-items: baseline;
  gap: 14px;
  margin-bottom: 16px;
  flex-wrap: wrap;
  opacity: 0;
  transform: translateY(-8px);
  transition: opacity 0.55s ease, transform 0.55s ease;
}

.ks1-inline-header.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.ks1-inline-kicker {
  color: var(--text-faint);
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  white-space: nowrap;
}

.ks1-inline-sep {
  color: var(--text-faint);
  font-size: 1rem;
  opacity: 0.4;
  font-weight: 300;
}

.ks1-inline-title {
  margin: 0;
  font-size: clamp(1.8rem, 3.2vw, 2.6rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.05;
  color: var(--text);
}

/* =====================================================
   SECTION 11 – FINAL INSIGHT SUMMARY
   ===================================================== */

.ks11-section {
  width: 100%;
  max-width: 1024px;
  margin: 0 auto;
  padding: 40px 24px 120px;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 32px;
}

.ks11-header {
  text-align: left;
}

.ks11-title {
  margin: 0;
  font-size: clamp(1.4rem, 2.4vw, 1.9rem);
  font-weight: 650;
  letter-spacing: -0.02em;
  color: var(--text);
}

.ks11-subtitle {
  margin: 6px 0 0;
  font-size: 0.9rem;
  color: var(--text-muted);
}

/* ── Content Body ──────────────────────────────────── */
.ks11-body {
  display: flex;
  flex-direction: column;
  gap: 32px;
}

.ks11-grid-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  align-items: stretch;
}

@media (max-width: 768px) {
  .ks11-grid-row {
    grid-template-columns: 1fr;
    gap: 32px;
  }
}

/* ── Block Container ───────────────────────────────── */

.ks11-block-label {
  margin: 0;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--text-faint);
  font-weight: 600;
}

/* =====================================================
   Strengths — Horizontal Bar Visualization
   ===================================================== */

.ks11-strength-rows {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.ks11-str-row {
  display: grid;
  grid-template-columns: 28px 72px 1fr;
  grid-template-rows: auto auto;
  column-gap: 10px;
  row-gap: 4px;
  align-items: center;
}

.ks11-str-rank {
  grid-row: 1 / 3;
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--accent);
  text-align: center;
  letter-spacing: -0.02em;
}

.ks11-str-planet {
  font-size: 0.96rem;
  font-weight: 600;
  color: var(--text);
  grid-column: 2;
  grid-row: 1 / 3;
}

.ks11-str-bar-track {
  grid-column: 3;
  grid-row: 1;
  height: 8px;
  border-radius: 4px;
  background: color-mix(in srgb, var(--surface-soft) 70%, transparent);
  overflow: hidden;
}

.ks11-str-bar-fill {
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--accent) 60%, transparent),
    var(--accent)
  );
}

.ks11-str-meta {
  grid-column: 3;
  grid-row: 2;
  display: flex;
  align-items: baseline;
  gap: 8px;
}

.ks11-str-dignity {
  font-size: 0.74rem;
  font-weight: 600;
  color: var(--accent);
  padding: 1px 6px;
  border-radius: 4px;
  background: color-mix(in srgb, var(--accent) 10%, transparent);
}

.ks11-str-house {
  font-size: 0.76rem;
  color: var(--text-muted);
}

/* =====================================================
   Challenges — Vertical Timeline
   ===================================================== */

.ks11-challenge-timeline {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ks11-ch-row {
  display: flex;
  gap: 14px;
  align-items: flex-start;
}

.ks11-ch-dot-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 14px;
  flex-shrink: 0;
  padding-top: 5px;
}

.ks11-ch-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: 2px solid color-mix(in srgb, var(--error) 60%, var(--border));
  background: color-mix(in srgb, var(--error) 18%, transparent);
  flex-shrink: 0;
}

.ks11-ch-line {
  flex: 1;
  width: 1.5px;
  min-height: 24px;
  background: color-mix(in srgb, var(--error) 20%, var(--border));
  margin-top: 4px;
}

.ks11-ch-content {
  flex: 1;
  padding-bottom: 18px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.ks11-ch-row:last-child .ks11-ch-content {
  padding-bottom: 0;
}

.ks11-ch-head {
  display: flex;
  align-items: baseline;
  gap: 10px;
}

.ks11-ch-planet {
  font-size: 0.96rem;
  font-weight: 600;
  color: var(--text);
}

.ks11-ch-domain {
  font-size: 0.78rem;
  color: var(--text-muted);
}

.ks11-ch-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.ks11-ch-tag {
  font-size: 0.68rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 2px 8px;
  border-radius: 4px;
  background: color-mix(in srgb, var(--error) 10%, transparent);
  color: color-mix(in srgb, var(--error) 75%, var(--text));
  border: 1px solid color-mix(in srgb, var(--error) 18%, var(--border));
}

/* =====================================================
   Dual Column: Donut Chart + Guna Bars
   ===================================================== */

/* ── Donut Chart ───────────────────────────────────── */
.ks11-donut-layout {
  display: flex;
  align-items: center;
  justify-content: space-around;
  gap: 24px;
  width: 100%;
}

@media (max-width: 1024px) {
  .ks11-donut-layout {
    flex-direction: column;
    gap: 16px;
  }
}

.ks11-donut-svg {
  display: block;
}

.ks11-donut-arc {
  transition: opacity 0.3s ease;
}

.ks11-donut-label {
  fill: var(--text);
  font-size: 13px;
  font-weight: 650;
  letter-spacing: -0.02em;
}

.ks11-donut-sublabel {
  fill: var(--text-faint);
  font-size: 9px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

/* ── Donut Legend ──────────────────────────────────── */
.ks11-donut-legend {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-width: 140px;
}

.ks11-legend-row {
  display: flex;
  align-items: center;
  gap: 10px;
}

.ks11-legend-row.dominant .ks11-legend-name {
  color: var(--text);
  font-weight: 700;
}

.ks11-legend-swatch {
  width: 12px;
  height: 12px;
  border-radius: 4px;
  flex-shrink: 0;
  box-shadow: 0 0 8px color-mix(in srgb, currentColor 20%, transparent);
}

.ks11-legend-swatch[data-element="fire"] {
  background: #ef4444;
}

.ks11-legend-swatch[data-element="earth"] {
  background: #10b981;
}

.ks11-legend-swatch[data-element="air"] {
  background: #3b82f6;
}

.ks11-legend-swatch[data-element="water"] {
  background: #6366f1;
}

.ks11-legend-name {
  font-size: 0.78rem;
  color: var(--text-muted);
  flex: 1;
}

.ks11-legend-count {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--text);
  min-width: 14px;
  text-align: right;
}

.ks11-block {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 24px;
  background: var(--bg-secondary);
  border: 1.5px solid var(--border-soft);
  border-radius: 16px;
  transition: transform 0.2s ease;
}

.ks11-block:hover {
  border-color: var(--accent);
}

/* ── New Panel layout (no card) ──────────────────── */
.ks11-insight-root {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 48px;
}

.ks11-top-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}

.ks11-bottom-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
  padding-top: 8px;
  border-top: 1px solid var(--border);
}

@media (max-width: 768px) {
  .ks11-top-grid,
  .ks11-bottom-grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }
}

.ks11-panel {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.ks11-panel-head {
  display: flex;
  align-items: center;
  gap: 10px;
}

.ks11-panel-num {
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  font-variant-numeric: tabular-nums;
  opacity: 0.85;
  flex-shrink: 0;
}

.ks11-panel-rule {
  flex: 1;
  height: 1px;
  border-radius: 1px;
}

/* Guna callout badge */
.ks11-guna-callout {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 4px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}

.ks11-guna-callout-label {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-faint);
}

.ks11-guna-callout-value {
  font-size: 0.88rem;
  font-weight: 700;
  color: #8b5cf6;
}

.ks11-block-label {
  margin: 0;
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--text-faint);
  font-weight: 700;
  margin-bottom: 4px;
}

/* ── Guna Bars ─────────────────────────────────────── */
.ks11-guna-stack {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 10px 0;
}

.ks11-guna-row {
  display: flex;
  align-items: center;
  gap: 16px;
}

.ks11-guna-name {
  flex: 0 0 80px;
  font-size: 0.9rem;
  color: var(--text-muted);
  font-weight: 600;
}

.ks11-guna-row.dominant .ks11-guna-name {
  color: var(--text);
  font-weight: 800;
}

.ks11-guna-bar-track {
  flex: 1;
  height: 8px;
  border-radius: 4px;
  background: var(--bg-tertiary);
  overflow: hidden;
}

.ks11-guna-bar-fill {
  height: 100%;
  border-radius: inherit;
  background: var(--border-soft);
  transition: width 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}

.ks11-guna-row.dominant .ks11-guna-bar-fill {
  background: var(--accent);
  box-shadow: 0 0 12px color-mix(in srgb, var(--accent) 25%, transparent);
}

.ks11-guna-count {
  font-size: 0.9rem;
  font-weight: 800;
  color: var(--text-faint);
  min-width: 24px;
  text-align: right;
  font-variant-numeric: tabular-nums;
}

.ks11-guna-row.dominant .ks11-guna-count {
  color: var(--accent);
}

/* ── Life Theme Pull-Quote ─────────────────────────── */
.ks11-block--theme {
  padding: 28px 24px;
  border-top: 1px solid var(--divider);
  border-bottom: 1px solid var(--divider);
}

.ks11-theme-text {
  margin: 0;
  font-size: 1.12rem;
  line-height: 1.6;
  color: var(--text);
  font-weight: 450;
  letter-spacing: -0.005em;
}

/* ── Current Period Card ───────────────────────────── */
.ks11-period-card {
  border: 1px solid color-mix(in srgb, var(--accent) 25%, var(--border));
  border-radius: 12px;
  background: color-mix(in srgb, var(--accent) 4%, transparent);
  padding: 16px 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.ks11-period-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}

.ks11-period-label {
  font-size: 1.1rem;
  font-weight: 650;
  color: var(--text);
}

.ks11-period-range {
  font-size: 0.82rem;
  color: var(--text-muted);
}

.ks11-period-detail {
  display: flex;
  align-items: baseline;
  gap: 10px;
  border-top: 1px solid var(--divider);
  padding-top: 10px;
}

.ks11-period-houses {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--text);
  padding: 3px 8px;
  border-radius: 5px;
  background: color-mix(in srgb, var(--accent) 12%, transparent);
}

.ks11-period-themes {
  font-size: 0.86rem;
  color: var(--text-muted);
}

/* ── Footer ────────────────────────────────────────── */
.ks11-footer {
  margin-top: 16px;
}

.ks11-footer-rule {
  border: none;
  margin: 0 0 12px;
}

.ks11-footer-text {
  margin: 0;
  font-size: 0.68rem;
  color: var(--text-faint);
  text-align: left;
  letter-spacing: 0.02em;
}

/* ── Responsive ────────────────────────────────────── */
@media (max-width: 700px) {
  .ks11-section {
    padding: 60px 16px 80px;
    gap: 24px;
  }

  .ks11-str-row {
    grid-template-columns: 24px 60px 1fr;
    column-gap: 8px;
  }

  .ks11-str-planet {
    font-size: 0.88rem;
  }

  .ks11-block--dual {
    flex-direction: column;
    gap: 24px;
    padding: 16px;
  }

  .ks11-dual-divider {
    width: 100%;
    height: 1px;
  }

  .ks11-donut-legend {
    max-width: 100%;
  }

  .ks11-period-head {
    flex-direction: column;
    gap: 4px;
  }

  .ks11-theme-text {
    font-size: 1rem;
  }
}

/* =====================================================
   KUNDLI SECTION TEN – YOGINI DASHA (INTERACTIVE)
   ===================================================== */

.ks10-section {
  width: 100%;
  max-width: 1024px;
  margin: 0 auto !important;
  padding: 40px 24px;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 24px;
}

.ks10-header {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.ks10-title {
  margin: 0;
  font-size: clamp(1.4rem, 2.4vw, 1.9rem);
  font-weight: 650;
  letter-spacing: -0.02em;
  color: var(--text);
}

.ks10-subtitle {
  margin: 0;
  font-size: 0.9rem;
  color: var(--text-muted);
}

.ks10-simple-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
  width: 100%;
}

.ks10-simple-row {
  display: flex;
  align-items: center;
  gap: 24px;
  padding: 20px 24px;
  background: var(--bg-secondary);
  border: 1.5px solid var(--border);
  border-radius: 12px;
  transition: transform 0.2s ease, border-color 0.2s ease;
}

.ks10-simple-row:hover {
  transform: translateY(-2px);
  border-color: var(--ks10-col);
  background: var(--bg-tertiary);
}

.ks10-s-info {
  width: 160px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.ks10-s-lvl {
  font-size: 0.65rem;
  font-weight: 800;
  color: var(--ks10-col);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.ks10-s-main {
  display: flex;
  align-items: baseline;
  gap: 6px;
}

.ks10-s-name {
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--text);
}

.ks10-s-planet {
  font-size: 0.85rem;
  color: var(--text-muted);
  font-weight: 500;
}

.ks10-s-graph {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.ks10-s-track {
  height: 8px;
  background: var(--divider-soft);
  border-radius: 4px;
  overflow: hidden;
  position: relative;
}

.ks10-s-fill {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  background: var(--ks10-col);
  border-radius: 4px;
}

.ks10-s-dates {
  display: flex;
  justify-content: space-between;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
}

.ks10-s-perc {
  color: var(--ks10-col);
  font-weight: 700;
}

.ks10-s-meta {
  width: 80px;
  text-align: right;
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--text);
}

/* Cards View */
.ks10-cards-view {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 20px;
}

.ks10-dasha-card {
  background: var(--bg-secondary);
  border-radius: 16px;
  padding: 24px;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  transition: all 0.3s ease;
  border: 1px solid transparent;
}

.ks10-dasha-card:hover {
  transform: translateY(-4px);
  border-color: var(--card-col, var(--accent));
}

.ks10-dasha-card.selected {
  border-color: var(--card-col, var(--accent));
  box-shadow: 0 8px 32px
    color-mix(in srgb, var(--card-col, var(--accent)) 20%, transparent);
}

.ks10-dasha-card .ks10-card-glow {
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: radial-gradient(
    circle,
    var(--card-col, var(--accent)) 0%,
    transparent 70%
  );
  opacity: 0.05;
  pointer-events: none;
}

.ks10-card-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}

.ks10-card-type {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--card-col, var(--accent));
  font-weight: 600;
}

.ks10-card-parent {
  font-size: 0.7rem;
  color: var(--text-faint);
}

.ks10-card-name {
  margin: 0 0 16px;
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--text);
}

.ks10-card-bar {
  height: 6px;
  background: var(--divider);
  border-radius: 3px;
  overflow: hidden;
  margin-bottom: 12px;
}

.ks10-card-bar-fill {
  height: 100%;
  background: var(--card-col, var(--accent));
  border-radius: 3px;
}

.ks10-card-meta {
  display: flex;
  justify-content: space-between;
  font-size: 0.8rem;
  color: var(--text-muted);
}

/* Responsive */
@media (max-width: 700px) {
  .ks10-section {
    padding: 60px 16px 80px;
    gap: 24px;
  }

  .ks10-timeline-track {
    flex-direction: column;
    align-items: flex-start;
    gap: 24px;
    padding: 0;
  }

  .ks10-timeline-node {
    flex-direction: row;
    width: 100%;
  }

  .ks10-node-info {
    align-items: flex-start;
    text-align: left;
  }

  .ks10-timeline-connector {
    display: none;
  }

  .ks10-detail-panel {
    flex-direction: column;
    align-items: flex-start;
  }

  .ks10-progress-ring-container {
    align-self: center;
  }
}

/* =====================================================
   KUNDALI UI ENHANCEMENTS — visual polish pass
   ===================================================== */

/* ── KS1: Hero + Chart ─────────────────────────────── */
.ks1-hero {
  position: relative;
}

.ks1-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(
    ellipse 65% 55% at 50% 25%,
    color-mix(in srgb, var(--accent) 9%, transparent),
    transparent 68%
  );
  pointer-events: none;
  z-index: 0;
}

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

.ks1-name {
  background: linear-gradient(
    145deg,
    var(--text) 30%,
    color-mix(in srgb, var(--accent) 80%, var(--text)) 100%
  );
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.ks1-detail-primary {
  font-size: 0.95rem;
  color: var(--text-muted);
  letter-spacing: 0.03em;
}

.ks1-chart-canvas {
  border-radius: 14px;
  background: color-mix(in srgb, var(--surface-soft) 45%, transparent);
  border: 1px solid color-mix(in srgb, var(--border) 80%, transparent);
  padding: 18px;
  box-shadow: inset 0 1px 0 color-mix(in srgb, white 5%, transparent),
    0 8px 32px color-mix(in srgb, var(--accent) 6%, transparent);
}

.ks2-row {
  border-radius: 8px;
  transition: background 0.15s ease;
  padding: 11px 8px;
  margin: 0 -8px;
}

.ks2-row:hover {
  background: color-mix(in srgb, var(--surface-soft) 55%, transparent);
}

.ks2-row:last-child {
  border-bottom: none;
}

.ks2-row-house {
  font-size: 0.72rem;
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--accent);
  padding: 2px 6px;
  border-radius: 4px;
  flex: 0 0 auto;
}

.ks2-row-sign {
  font-size: 0.86rem;
  font-weight: 600;
  color: var(--text);
}

.ks2-tag {
  border: 1px solid color-mix(in srgb, var(--accent) 20%, transparent);
  font-size: 0.65rem;
  vertical-align: middle;
  margin-left: 5px;
  letter-spacing: 0.02em;
}

/* Dignity-specific tag colors */
.ks2-tag[data-kind="exalted"] {
  background: color-mix(in srgb, #f4b400 15%, transparent);
  color: #c9870c;
  border-color: color-mix(in srgb, #f4b400 25%, transparent);
}

.ks2-tag[data-kind="debilitated"] {
  background: color-mix(in srgb, #ef4444 12%, transparent);
  color: #ef4444;
  border-color: color-mix(in srgb, #ef4444 22%, transparent);
}

.ks2-tag[data-kind="own-sign"] {
  background: color-mix(in srgb, #000 12%, transparent);
  color: #000;
  border-color: color-mix(in srgb, #000 22%, transparent);
}

.ks2-tag[data-kind="mooltrikona"] {
  background: color-mix(in srgb, #8b5cf6 12%, transparent);
  color: #8b5cf6;
  border-color: color-mix(in srgb, #8b5cf6 22%, transparent);
}

.ks2-tag[data-kind="retro"] {
  background: color-mix(in srgb, #3b82f6 12%, transparent);
  color: #3b82f6;
  border-color: color-mix(in srgb, #3b82f6 22%, transparent);
}

.ks2-tag[data-kind="combust"] {
  background: color-mix(in srgb, #f97316 12%, transparent);
  color: #f97316;
  border-color: color-mix(in srgb, #f97316 22%, transparent);
}

/* ── KS8: Dasha Timeline ───────────────────────────── */
.ks8-section {
  padding: 60px 24px;
}

.ks8-tab.active {
  background: var(--surface-soft);
  color: var(--accent);
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.18);
}

.ks8-series-block.current .ks8-block-bg {
  background: color-mix(in srgb, var(--accent) 18%, var(--surface-soft));
  border: 1.5px solid color-mix(in srgb, var(--accent) 45%, transparent);
}

.ks8-series-block.selected .ks8-block-bg {
  background: color-mix(in srgb, var(--accent) 24%, var(--surface-soft));
  border: 2px solid var(--accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 12%, transparent);
}

.ks8-series-block.current .ks8-block-planet,
.ks8-series-block.selected .ks8-block-planet {
  font-weight: 700;
  color: var(--accent);
}

.ks8-block-progress {
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--accent) 50%, transparent),
    var(--accent) 100%
  );
}

.ks8-detail-card {
  border: 1px solid color-mix(in srgb, var(--accent) 22%, var(--border));
  background: color-mix(in srgb, var(--accent) 4%, var(--bg-elevated));
  box-shadow: 0 4px 24px color-mix(in srgb, var(--accent) 7%, transparent);
}

.ks8-card-badge {
  background: linear-gradient(135deg, var(--accent), var(--accent-strong));
  color: #fff;
  box-shadow: 0 4px 14px color-mix(in srgb, var(--accent) 32%, transparent);
  border: none;
}

.ks8-card-status.live {
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  color: var(--accent);
  border: 1px solid color-mix(in srgb, var(--accent) 24%, transparent);
}

.ks8-progress-fill {
  background: linear-gradient(90deg, var(--accent-strong), var(--accent));
  box-shadow: 0 0 6px color-mix(in srgb, var(--accent) 28%, transparent);
}

/* ── KS9: Divisional Charts ────────────────────────── */
.ks9-section {
  padding: 60px 24px;
}

.ks9-stack {
  gap: 16px;
}

.ks9-item {
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 20px 16px;
  background: color-mix(in srgb, var(--surface-soft) 40%, transparent);
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
  overflow: hidden;
}

.ks9-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 32px color-mix(in srgb, black 22%, transparent);
}

/* Per-chart accent colors */
.ks9-item[data-chart="d9"] {
  --ks9-c: #7c3aed;
}

.ks9-item[data-chart="d10"] {
  --ks9-c: #2563eb;
}

.ks9-item[data-chart="d7"] {
  --ks9-c: #d97706;
}

.ks9-item[data-chart="d12"] {
  --ks9-c: #db2777;
}

.ks9-item[data-chart="d60"] {
  --ks9-c: #0891b2;
}

.ks9-item:hover {
  border-color: color-mix(
    in srgb,
    var(--ks9-c, var(--accent)) 35%,
    var(--border)
  );
}

.ks9-label {
  color: var(--ks9-c, var(--accent));
  font-weight: 700;
  letter-spacing: -0.01em;
}

.ks9-focus {
  font-size: 0.8rem;
  color: var(--text-muted);
  margin: 0 0 10px;
}

.ks9-chart-canvas {
  border-radius: 10px;
  overflow: hidden;
  background: color-mix(in srgb, var(--ks9-c, var(--accent)) 5%, transparent);
}

.ks9-title {
  font-size: clamp(1.4rem, 2.4vw, 1.9rem);
  font-weight: 650;
  letter-spacing: -0.02em;
  margin: 0;
}

.ks9-subtitle {
  margin: 6px 0 0;
  font-size: 0.9rem;
  color: var(--text-muted);
  text-align: center;
}

/* ── KS11: Insight Summary ─────────────────────────── */
.ks11-section {
  max-width: 760px;
  padding: 80px 24px 100px;
}

.ks11-block {
  padding: 20px;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--border) 80%, transparent);
  background: color-mix(in srgb, var(--surface-soft) 28%, transparent);
}

.ks11-block-label {
  font-size: 0.68rem;
  letter-spacing: 0.13em;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--divider);
  margin-bottom: 4px;
  color: var(--text-faint);
}

.ks11-block--dual {
  border: 1px solid color-mix(in srgb, var(--border) 80%, transparent);
  background: color-mix(in srgb, var(--surface-soft) 28%, transparent);
  padding: 20px;
}

.ks11-str-bar-track {
  border-radius: 999px;
  overflow: hidden;
  background: color-mix(in srgb, var(--border) 60%, transparent);
}

.ks11-str-bar-fill {
  border-radius: 999px;
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--accent) 55%, transparent),
    var(--accent)
  );
  box-shadow: 0 0 8px color-mix(in srgb, var(--accent) 28%, transparent);
}

.ks11-str-planet {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text);
}

.ks11-ch-dot {
  box-shadow: 0 0 6px color-mix(in srgb, var(--error) 28%, transparent);
}

.ks11-ch-planet {
  font-size: 0.94rem;
  font-weight: 600;
}

.ks11-ch-tag {
  border-radius: 6px;
  font-size: 0.66rem;
}

.ks11-period-card {
  border: 1px solid color-mix(in srgb, var(--accent) 28%, var(--border));
  background: color-mix(in srgb, var(--accent) 5%, var(--surface-soft));
  box-shadow: 0 2px 14px color-mix(in srgb, var(--accent) 8%, transparent);
}

.ks11-period-label {
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent);
}

.ks11-guna-bar-track {
  border-radius: 999px;
  overflow: hidden;
}

.ks11-guna-row.dominant .ks11-guna-bar-fill {
  background: linear-gradient(90deg, var(--accent-strong), var(--accent));
  box-shadow: 0 0 6px color-mix(in srgb, var(--accent) 24%, transparent);
}

.ks11-footer-text {
  font-size: 0.74rem;
  text-align: center;
  color: var(--text-faint);
  letter-spacing: 0.02em;
}

.ks11-title {
  letter-spacing: -0.025em;
}

/* ── KS11 Insight Summary V3 (vertical flow / no cards) ─────── */
.ks11-insight-section .ks1-section-content {
  margin-top: 34px !important;
}

.ks11-insight-root {
  width: min(100%, 980px);
  margin: 0 auto 0 0;
}

.ks11-flow {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 46px;
  margin-left: clamp(10px, 1.2vw, 18px);
}

.ks11-chapter {
  --ks11-accent: var(--accent);
  position: relative;
  padding-left: 50px;
}

.ks11-chapter::before {
  content: "";
  position: absolute;
  left: 16px;
  top: 28px;
  bottom: -30px;
  width: 1px;
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--ks11-accent) 52%, transparent) 0%,
    color-mix(in srgb, var(--ks11-accent) 24%, transparent) 100%
  );
}

.ks11-chapter::after {
  content: "";
  position: absolute;
  left: 10px;
  top: 8px;
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: var(--bg);
  border: 2px solid color-mix(in srgb, var(--ks11-accent) 75%, var(--border));
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--ks11-accent) 12%, transparent);
}

.ks11-chapter:last-child::before {
  display: none;
}

.ks11-chapter-head {
  display: grid;
  grid-template-columns: auto auto 1fr;
  align-items: center;
  gap: 12px;
}

.ks11-chapter-index {
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  color: color-mix(in srgb, var(--ks11-accent) 78%, var(--text));
  font-variant-numeric: tabular-nums;
}

.ks11-chapter-title {
  margin: 0;
  font-size: 0.86rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--text-faint);
}

.ks11-chapter-line {
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--ks11-accent) 60%, transparent) 0%,
    color-mix(in srgb, var(--ks11-accent) 30%, transparent) 55%,
    transparent 100%
  );
}

.ks11-chapter-body {
  margin-top: 16px;
}

.ks11-chapter .ks11-strength-rows {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.ks11-chapter .ks11-str-row {
  display: grid;
  grid-template-columns: 30px 110px 1fr;
  grid-template-rows: auto auto;
  column-gap: 10px;
  row-gap: 5px;
  align-items: center;
}

.ks11-chapter .ks11-str-rank {
  grid-row: 1 / 3;
  font-size: 0.78rem;
  font-weight: 800;
  color: color-mix(in srgb, var(--ks11-accent) 90%, var(--text));
}

.ks11-chapter .ks11-str-planet {
  font-size: 0.98rem;
  font-weight: 650;
  letter-spacing: -0.01em;
  color: var(--text);
}

.ks11-chapter .ks11-str-bar-track {
  height: 8px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--border) 58%, transparent);
  overflow: hidden;
}

.ks11-chapter .ks11-str-bar-fill {
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--ks11-accent) 36%, transparent) 0%,
    color-mix(in srgb, var(--ks11-accent) 88%, var(--text)) 100%
  );
}

.ks11-chapter .ks11-str-meta {
  display: flex;
  align-items: baseline;
  gap: 8px;
}

.ks11-chapter .ks11-str-dignity {
  font-size: 0.76rem;
  font-weight: 700;
  color: color-mix(in srgb, var(--ks11-accent) 85%, var(--text));
  background: color-mix(in srgb, var(--ks11-accent) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--ks11-accent) 24%, transparent);
  border-radius: 8px;
  padding: 2px 8px;
}

.ks11-chapter .ks11-str-house {
  font-size: 0.82rem;
  color: var(--text-muted);
}

.ks11-chapter .ks11-challenge-timeline {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.ks11-chapter .ks11-ch-row {
  display: flex;
  gap: 14px;
  align-items: flex-start;
}

.ks11-chapter .ks11-ch-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: 2px solid color-mix(in srgb, var(--ks11-accent) 68%, var(--border));
  background: color-mix(in srgb, var(--ks11-accent) 14%, transparent);
}

.ks11-chapter .ks11-ch-line {
  width: 1.5px;
  min-height: 24px;
  margin-top: 4px;
  background: color-mix(in srgb, var(--ks11-accent) 26%, var(--border));
}

.ks11-chapter .ks11-ch-content {
  padding-bottom: 14px;
}

.ks11-chapter .ks11-ch-row:last-child .ks11-ch-content {
  padding-bottom: 0;
}

.ks11-chapter .ks11-ch-planet {
  font-size: 0.98rem;
  font-weight: 650;
  color: var(--text);
}

.ks11-chapter .ks11-ch-domain {
  font-size: 0.86rem;
  color: var(--text-muted);
}

.ks11-chapter .ks11-ch-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 6px;
}

.ks11-chapter .ks11-ch-tag {
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--ks11-accent) 86%, var(--text));
  background: color-mix(in srgb, var(--ks11-accent) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--ks11-accent) 26%, var(--border));
  border-radius: 8px;
  padding: 3px 9px;
}

.ks11-chapter .ks11-donut-layout {
  display: flex;
  align-items: center;
  gap: 28px;
}

.ks11-chapter .ks11-donut-container {
  flex-shrink: 0;
}

.ks11-chapter .ks11-donut-legend {
  min-width: 180px;
}

.ks11-chapter .ks11-legend-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 4px 0;
}

.ks11-chapter .ks11-legend-row.dominant .ks11-legend-name,
.ks11-chapter .ks11-legend-row.dominant .ks11-legend-count {
  color: color-mix(in srgb, var(--ks11-accent) 85%, var(--text));
  font-weight: 800;
}

.ks11-chapter .ks11-guna-stack {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.ks11-chapter .ks11-guna-row {
  display: flex;
  align-items: center;
  gap: 12px;
}

.ks11-chapter .ks11-guna-name {
  min-width: 82px;
  font-size: 0.95rem;
  font-weight: 650;
  color: var(--text);
}

.ks11-chapter .ks11-guna-bar-track {
  flex: 1;
  height: 10px;
  border-radius: 999px;
  overflow: hidden;
  background: color-mix(in srgb, var(--border) 58%, transparent);
}

.ks11-chapter .ks11-guna-bar-fill {
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--ks11-accent) 36%, transparent) 0%,
    color-mix(in srgb, var(--ks11-accent) 88%, var(--text)) 100%
  );
}

.ks11-chapter .ks11-guna-count {
  min-width: 24px;
  text-align: right;
  font-size: 1.05rem;
  font-weight: 800;
  color: color-mix(in srgb, var(--ks11-accent) 85%, var(--text));
  font-variant-numeric: tabular-nums;
}

.ks11-guna-callout {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 12px;
  padding-top: 14px;
  border-top: 1px dashed
    color-mix(in srgb, var(--ks11-accent) 32%, var(--border));
}

.ks11-guna-callout-label {
  font-size: 0.74rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--text-faint);
}

.ks11-guna-callout-value {
  font-size: 0.96rem;
  font-weight: 800;
  color: color-mix(in srgb, var(--ks11-accent) 88%, var(--text));
}

@media (max-width: 900px) {
  .ks11-chapter {
    padding-left: 42px;
  }

  .ks11-chapter .ks11-str-row {
    grid-template-columns: 24px 84px 1fr;
    column-gap: 8px;
  }
}

@media (max-width: 760px) {
  .ks11-flow {
    gap: 36px;
    margin-left: 0;
  }

  .ks11-chapter {
    padding-left: 30px;
  }

  .ks11-chapter::before {
    left: 10px;
  }

  .ks11-chapter::after {
    left: 4px;
  }

  .ks11-chapter-head {
    grid-template-columns: auto 1fr;
  }

  .ks11-chapter-line {
    grid-column: 1 / -1;
  }

  .ks11-chapter .ks11-donut-layout {
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
  }
}

/* ── Light theme overrides for Kundali ─────────────── */
[data-theme="light"] .ks1-chart-canvas {
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8),
    0 8px 32px color-mix(in srgb, var(--accent) 8%, transparent);
}

[data-theme="light"] .ks9-item:hover {
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
}

[data-theme="light"] .ks8-detail-card {
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
}

@media (max-width: 700px) {
  .ks9-stack {
    gap: 12px;
  }

  .ks11-block {
    padding: 16px;
  }

  .ks8-section {
    padding: 48px 16px;
  }

  .ks9-section {
    padding: 48px 16px;
  }

  .ks11-section {
    padding: 60px 16px 80px;
  }
}

/* ═══════════════════════════════════════════════════════════════
   Today's Sky — Saturn Planet with Flowing Rings
   ═══════════════════════════════════════════════════════════════ */

@keyframes ringTilt {
  from {
    transform: rotate(-22deg);
  }

  to {
    transform: rotate(-22deg);
  }
}

@keyframes ringFlow {
  from {
    stroke-dashoffset: 0;
  }

  to {
    stroke-dashoffset: -60;
  }
}

@keyframes skyCorePulse {
  0%,
  100% {
    transform: scale(0.95);
    opacity: 0.9;
  }

  50% {
    transform: scale(1.08);
    opacity: 1;
  }
}

@keyframes skyStarTwinkle {
  0%,
  100% {
    opacity: 0.82;
    transform: scale(0.9);
  }

  50% {
    opacity: 0.25;
    transform: scale(1.16);
  }
}

.icon-todays-sky {
  display: block;
  opacity: 0.88;
}

@keyframes skyOrbitSpinA {
  from {
    transform: rotate(0deg);
  }

  to {
    transform: rotate(360deg);
  }
}

@keyframes skyOrbitSpinB {
  from {
    transform: rotate(60deg);
  }

  to {
    transform: rotate(420deg);
  }
}

.icon-todays-sky .sky-orbit-wrap {
  transform-box: view-box;
  transform-origin: 50% 50%;
}

.icon-todays-sky .sky-orbit-wrap-a {
  animation: skyOrbitSpinA 7.8s linear infinite;
}

.icon-todays-sky .sky-orbit-wrap-b {
  animation: skyOrbitSpinB 9.8s linear infinite;
}

.icon-todays-sky .sky-orbit-ring {
  stroke: currentColor;
  stroke-width: 1.6;
  fill: none;
  stroke-linecap: round;
  opacity: 0.82;
}

.icon-todays-sky .sky-core {
  fill: currentColor;
  opacity: 0.84;
  transform-box: fill-box;
  transform-origin: center;
  animation: skyCorePulse 2.4s ease-in-out infinite;
}

.icon-todays-sky .sky-star {
  opacity: 0.7;
  transform-box: fill-box;
  transform-origin: center;
}

.icon-todays-sky .sky-star-1 {
  animation: skyStarTwinkle 2.2s ease-in-out infinite;
}

.icon-todays-sky .sky-star-2 {
  animation: skyStarTwinkle 2.2s ease-in-out infinite 0.66s;
}

.icon-todays-sky .sky-star-3 {
  animation: skyStarTwinkle 2.2s ease-in-out infinite 1.32s;
}

/* ═══════════════════════════════════════════════════════════════
   Kundali View — Zodiac Wheel (Outer rotates CW, Inner CCW)
   ═══════════════════════════════════════════════════════════════ */

@keyframes rotateCW {
  from {
    transform: rotate(0deg);
  }

  to {
    transform: rotate(360deg);
  }
}

@keyframes rotateCCW {
  from {
    transform: rotate(0deg);
  }

  to {
    transform: rotate(-360deg);
  }
}

@keyframes kundaliGemPulse {
  0%,
  100% {
    opacity: 0.95;
    transform: scale(1);
  }

  50% {
    opacity: 0.4;
    transform: scale(1.5);
  }
}

.icon-kundali {
  display: block;
}

/* Entire chart pulses gently on hover / when active */
.icon-kundali .kundali-chart {
  transform-box: view-box;
  transform-origin: 50% 50%;
  transition: opacity 0.2s;
}

.header-layout-btn:hover .kundali-chart,
.header-layout-btn.active .kundali-chart {
  opacity: 0.85;
}

.icon-kundali .kundali-center-gem {
  transform-box: fill-box;
  transform-origin: center;
  animation: kundaliGemPulse 2.5s ease-in-out infinite;
}

.header-layout-btn.active {
  background: var(--surface);
}

.solar-overlay {
  position: absolute;
  inset: 0;
  z-index: 40;
  background: #030308;
  display: flex;
  flex-direction: column;
  opacity: 0;
  transition: opacity 0.4s ease;
}

.solar-overlay.hidden {
  display: none;
  opacity: 0;
}

.solar-overlay.visible {
  opacity: 1;
}

.solar-overlay canvas {
  width: 100% !important;
  height: 100% !important;
  display: block;
  position: absolute;
  inset: 0;
}

.solar-ref-box {
  position: absolute;
  right: 24px;
  bottom: 110px;
  /* Lowered slightly to give more room to the grid card */
  z-index: 70;
}

.solar-ref-btn {
  min-width: 240px;
  width: 240px;
  min-height: 56px;
  border: none;
  border-radius: 0;
  background: transparent;
  color: #fff;
  padding: 12px 14px;
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: 2px;
  cursor: pointer;
  backdrop-filter: blur(20px);
}

.solar-ref-label {
  font-size: 0.72rem;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.45);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.solar-ref-value {
  font-size: 1.05rem;
  font-weight: 600;
  color: #fff;
  letter-spacing: 0.02em;
}

.solar-ref-btn:hover {
  border-color: rgba(0, 242, 255, 0.45);
}

.solar-ref-label {
  font-size: 0.62rem;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.62);
  font-weight: 700;
}

.solar-ref-value {
  font-size: 1.05rem;
  letter-spacing: 0.03em;
  font-weight: 800;
  color: #ffd24a;
}

.solar-ref-location {
  color: rgba(255, 255, 255, 0.85);
  font-size: 0.75rem;
  text-align: right;
}

/* HUD — glassmorphic topbar */
.solar-hud {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 30px;
  background: linear-gradient(to bottom, rgba(5, 5, 12, 0.7), transparent);
  pointer-events: none;
}

.solar-hud > * {
  pointer-events: auto;
}

.solar-hud-left {
  display: flex;
  align-items: center;
}

.solar-hud-title {
  color: #fff;
  font-size: 1.1rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.5);
}

.solar-hud-date {
  font-size: 0.9rem;
  color: #ffffff;
  font-weight: 600;
  letter-spacing: 0.03em;
}

.solar-hud-center {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
}

.solar-hud-location {
  font-size: 1.1rem;
  color: #ffffff;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.solar-hud-right {
  display: flex;
  gap: 12px;
}

.solar-hud-btn {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.12);
  color: #fff;
  width: 38px;
  height: 38px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.2s ease;
  backdrop-filter: blur(15px);
}

.solar-hud-btn:hover {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.3);
  transform: translateY(-1px);
}

.solar-close-btn:hover {
  background: rgba(239, 68, 68, 0.2);
  border-color: rgba(239, 68, 68, 0.4);
}

/* Planet Labels */
.solar-labels-container {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 5;
  overflow: hidden;
}

.planet-label {
  position: absolute;
  color: #fff;
  font-size: 0.75rem;
  font-weight: 600;
  pointer-events: none;
  background: rgba(0, 0, 0, 1);
  /* Black background as requested */
  padding: 4px 8px;
  border-radius: 6px;
  border: 1px solid rgba(255, 255, 255, 0.15);
  display: flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.5);
  transition: opacity 0.2s, transform 0.2s;
  z-index: 1000;
  /* Anchor from bottom-center so JS top can target exact planet top edge */
  transform: translate(-50%, -100%);
}

.label-name {
  color: #f7fbff;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.label-degree {
  font-size: 9px;
  color: #fff;
  /* Pure white as requested */
  font-weight: 600;
  letter-spacing: 0.02em;
}

.planet-label.focused {
  opacity: 1;
  background: rgba(0, 0, 0, 0.92);
  border-color: rgba(255, 255, 255, 0.5);
  transform: translate(-50%, -100%) scale(1.05);
  z-index: 50;
  box-shadow: 0 0 20px rgba(255, 255, 255, 0.2), 0 4px 12px rgba(0, 0, 0, 0.5);
}

.planet-label.focused .label-name {
  color: #fff;
}

.planet-label.focused .label-degree {
  color: #fff;
}

.solar-zodiac-label {
  position: absolute;
  transform: translate(-50%, -50%);
  color: #72e8ff;
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-shadow: 0 0 8px rgba(0, 0, 0, 0.9), 0 0 6px rgba(80, 220, 255, 0.35);
  white-space: nowrap;
  pointer-events: none;
}

/* Info panel — right side above frame-of-reference */
.solar-info-panel {
  position: absolute;
  right: 24px;
  bottom: 220px;
  left: auto;
  z-index: 75;
  width: 320px;
  padding: 20px;
  background: rgba(5, 5, 20, 0.55);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 16px;
  color: #f0f0f5;
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s ease;
  pointer-events: none;
}

.solar-info-panel.visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

.solar-info-title {
  font-size: 1.1rem;
  font-weight: 700;
  margin: 0 0 4px;
  letter-spacing: 0.01em;
}

.solar-info-subtitle {
  font-size: 0.75rem;
  color: rgba(255, 255, 255, 0.4);
  margin: 0 0 12px;
}

.solar-info-grid {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 10px;
}

.solar-info-cell {
  display: flex;
  flex-direction: column;
  gap: 3px;
  padding: 8px 12px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
}

.solar-info-key {
  font-size: 0.58rem;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.35);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.solar-info-val {
  font-size: 0.85rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 1);
  font-variant-numeric: tabular-nums;
  word-break: break-all;
}

.solar-info-val.retro-yes {
  color: #072716;
  background: linear-gradient(
    120deg,
    rgba(100, 255, 178, 0.95),
    rgba(50, 231, 255, 0.92)
  );
  border-radius: 999px;
  padding: 2px 8px;
  font-weight: 800;
  letter-spacing: 0.04em;
  display: inline-flex;
  width: fit-content;
  box-shadow: 0 0 14px rgba(66, 255, 180, 0.45);
  animation: retroPulse 1.9s ease-in-out infinite;
}

.solar-info-val.retro-no {
  color: rgba(255, 255, 255, 0.88);
  background: rgba(255, 255, 255, 0.08);
  border-radius: 999px;
  padding: 2px 8px;
  display: inline-flex;
  width: fit-content;
}

.solar-info-val.retro-unknown {
  color: rgba(255, 255, 255, 0.7);
}

@keyframes retroPulse {
  0% {
    box-shadow: 0 0 6px rgba(66, 255, 180, 0.25);
    transform: translateZ(0);
  }

  50% {
    box-shadow: 0 0 18px rgba(66, 255, 180, 0.6);
    transform: translateY(-1px);
  }

  100% {
    box-shadow: 0 0 6px rgba(66, 255, 180, 0.25);
    transform: translateZ(0);
  }
}

.solar-info-hint {
  margin-top: 12px;
  font-size: 0.65rem;
  color: rgba(255, 255, 255, 0.25);
  letter-spacing: 0.04em;
}

/* ─── Compact Astro-Sidebar (Refinement) ─── */
.solar-planet-sidebar {
  position: absolute;
  right: 24px;
  bottom: 210px;
  /* Increased distance from ref box */
  z-index: 100;
  width: 140px;
  background: rgba(2, 5, 14, 0.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 12px;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.6);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.solar-sidebar-content {
  flex-grow: 1;
  overflow-y: auto;
  padding: 12px;
}

.solar-sidebar-content::-webkit-scrollbar {
  width: 4px;
}

.solar-sidebar-content::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.1);
  border-radius: 10px;
}

.solar-planet-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  margin-bottom: 20px;
}

.solar-planet-grid::-webkit-scrollbar {
  width: 3px;
}

.solar-planet-grid::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.15);
  border-radius: 4px;
}

.solar-planet-item {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 12px;
  transition: all 0.3s;
}

.solar-planet-btn {
  width: 100%;
  display: flex;
  align-items: center;
  padding: 10px 14px;
  gap: 12px;
  background: none;
  border: none;
  cursor: pointer;
  color: #fff;
  transition: all 0.3s;
}

.solar-planet-btn:hover {
  background: rgba(255, 255, 255, 0.05);
}

.solar-planet-btn.active .solar-planet-btn-icon {
  transform: scale(1.3);
  color: #00f2ff;
}

.solar-planet-btn-icon {
  font-size: 1.4rem;
  transition: transform 0.4s;
}

.solar-planet-btn-name {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.solar-astro-details-panel {
  padding: 12px;
  background: rgba(2, 5, 14, 0.92);
  border-radius: 12px;
  border: 1px solid rgba(114, 152, 224, 0.34);
  box-shadow: inset 0 0 0 1px rgba(33, 58, 106, 0.35);
}

.solar-sidebar-actions {
  padding: 10px 12px;
}

.solar-unfocus-btn {
  width: 100%;
  min-height: 36px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.6);
  padding: 6px 10px;
  border-radius: 8px;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  cursor: pointer;
  transition: all 0.2s;
}

.solar-unfocus-btn:hover {
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
}

/* Floating Info Panel (Refined Transparency) */
.solar-floating-info-panel {
  position: absolute;
  z-index: 1000;
  min-width: 140px;
  background: none;
  /* Container itself is fully transparent */
  border: none;
  color: #fff;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease;
  pointer-events: none;
}

.solar-floating-info-panel .solar-info-box {
  background: rgba(2, 5, 14, 0.94);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  width: 270px;
  padding: 12px 16px;
  border: 1px solid rgba(255, 255, 255, 0.15);
  display: block;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.6);
  border-radius: 12px;
}

.solar-floating-info-panel .solar-info-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
  margin-top: 0;
}

.solar-floating-info-panel .solar-info-cell {
  padding: 6px 8px;
  border-radius: 9px;
}

.solar-details-section {
  margin-top: 15px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding-top: 10px;
}

.solar-details-heading {
  font-size: 0.65rem;
  font-weight: 800;
  color: rgba(255, 255, 255, 0.5);
  letter-spacing: 0.1em;
  margin-bottom: 8px;
  text-transform: uppercase;
}

.solar-planet-item.active {
  background: rgba(255, 255, 255, 0.2);
  border-color: rgba(255, 255, 255, 0.9);
  box-shadow: 0 0 15px rgba(255, 255, 255, 0.3);
  transform: scale(1.05);
}

.solar-planet-btn.active {
  color: #fff;
  text-shadow: 0 0 10px rgba(255, 255, 255, 0.5);
}

.solar-floating-info-panel .solar-info-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  font-size: 0.75rem;
}

.solar-floating-info-panel .solar-info-key {
  color: rgba(255, 255, 255, 0.7);
  font-weight: 500;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  font-size: 0.65rem;
}

.solar-floating-info-panel .solar-info-val {
  color: #fff;
  font-weight: 700;
}

.solar-floating-info-panel.visible {
  opacity: 1;
  visibility: visible;
}

.solar-change-loc-btn {
  background: none;
  border: none;
  color: rgba(255, 255, 255, 0.4);
  cursor: pointer;
  padding: 4px;
  margin-left: 4px;
  transition: color 0.2s;
  display: inline-flex;
  align-items: center;
}

.solar-change-loc-btn:hover {
  color: #ffd24a;
}

.solar-planet-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  /* Reduced gap */
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 12px;
  padding: 8px 2px;
  /* Reduced padding */
  cursor: pointer;
  color: #fff;
  transition: all 0.3s cubic-bezier(0.23, 1, 0.32, 1);
}

.solar-planet-btn:hover {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(0, 242, 255, 0.5);
  transform: translateY(-2px);
  /* Subtle lift */
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3);
}

.solar-planet-btn-icon {
  font-size: 1.3rem;
  /* Reduced from 1.6rem */
  line-height: 1;
  opacity: 0.9;
}

.solar-planet-btn-name {
  font-size: 0.55rem;
  /* Reduced from 0.6rem */
  font-weight: 700;
  letter-spacing: 0.05em;
  color: rgba(255, 255, 255, 0.7);
  text-transform: uppercase;
}

/* Scrollable planet cards: 4 visible slots + in-card details */
.solar-planet-scroll {
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-height: none;
  overflow: visible;
  padding-right: 0;
}

.solar-grid-title {
  margin-bottom: 16px;
  font-size: 0.7rem;
  font-weight: 800;
  color: rgba(255, 255, 255, 0.4);
  letter-spacing: 0.08em;
  padding-left: 2px;
}

.solar-planet-scroll::-webkit-scrollbar {
  width: 4px;
}

.solar-planet-scroll::-webkit-scrollbar-thumb {
  background: rgba(170, 197, 255, 0.35);
  border-radius: 999px;
}

.solar-planet-card {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 6px;
  padding: 5px 10px;
  min-height: 26px;
  cursor: pointer;
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

.solar-planet-card:hover {
  background: rgba(255, 255, 255, 0.1);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.7);
  border-color: rgba(255, 255, 255, 0.25);
  transform: translateX(-2px);
}

.solar-planet-card.active {
  background: transparent;
  border: none;
  box-shadow: none;
}

.solar-sidebar-divider {
  width: 100%;
  height: 1px;
  background: rgba(255, 255, 255, 0.15);
  margin: 12px 0;
}

.solar-planet-card-head {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 12px;
  padding: 0 2px;
}

.solar-planet-card-icon {
  font-size: 1.25rem;
  line-height: 1;
  color: #ffffff;
  transition: all 0.2s ease;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.8));
}

.solar-planet-card-icon.active {
  font-size: 1.4rem;
  color: #00f2ff;
  transform: scale(1.1);
  filter: drop-shadow(0 0 8px rgba(0, 242, 255, 0.6));
}

.solar-planet-card-name {
  font-size: 0.68rem;
  font-weight: 700;
  color: #ffffff;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.9);
}

.solar-planet-card.active .solar-planet-card-name {
  color: #fff;
}

.solar-planet-card-body {
  display: none;
}

.solar-planet-meta-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
}

.solar-planet-meta-cell {
  display: flex;
  flex-direction: column;
  gap: 3px;
  background: rgba(1, 3, 9, 0.96);
  border: 1px solid rgba(112, 142, 210, 0.32);
  border-radius: 8px;
  padding: 6px;
}

.solar-planet-meta-key {
  font-size: 0.46rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(176, 196, 235, 0.68);
  font-weight: 700;
}

.solar-planet-meta-val {
  font-size: 0.6rem;
  color: rgba(239, 246, 255, 0.96);
  font-weight: 600;
}

/* Mobile adjustments */
@media (max-width: 640px) {
  .solar-planet-sidebar {
    left: 12px;
    right: 12px;
    bottom: 160px;
    width: auto;
    padding: 12px;
  }

  .solar-planet-scroll {
    max-height: 170px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
  }

  .solar-planet-meta-grid {
    grid-template-columns: 1fr;
  }

  .solar-hud {
    padding: 10px 14px;
  }

  .solar-hud-title {
    font-size: 0.9rem;
  }

  .solar-hud-date {
    display: none;
  }

  .solar-hud-location {
    display: none;
  }
}

/* ── Settings Panel ─────────────────────────────────────────── */
.settings-panel {
  padding: 4px 0 6px;
}

.settings-row-btn {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  background: none;
  border: none;
  cursor: pointer;
  padding: 8px 14px;
  border-radius: 8px;
  color: var(--text);
  font-size: 0.875rem;
  transition: background 0.15s;
}

.settings-row-btn:hover {
  background: var(--surface);
}

.settings-row-icon {
  color: var(--text-muted);
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

.settings-row-label {
  flex: 1;
  text-align: left;
}

.settings-row-arrow {
  color: var(--text-faint);
  flex-shrink: 0;
}

.settings-hint {
  font-size: 0.78rem;
  color: var(--text-muted);
  line-height: 1.5;
  margin: 4px 0 0;
  padding: 0 14px;
}

/* ── Help Panel (old sub-panel, kept for safety) ────────────── */
.help-panel {
  padding: 6px 0 8px;
}

/* ── Help Flyout ────────────────────────────────────────────── */
.help-flyout {
  position: fixed;
  bottom: 72px;
  left: calc(8px + 256px + 10px);
  /* right of sidebar-profile-dropdown */
  width: 210px;
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 6px;
  z-index: 130;
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.32);
  display: flex;
  flex-direction: column;
  gap: 1px;
  animation: flyout-in 0.14s ease;
}

@keyframes flyout-in {
  from {
    opacity: 0;
    transform: translateX(-6px);
  }

  to {
    opacity: 1;
    transform: translateX(0);
  }
}

.help-flyout-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  background: none;
  border: none;
  cursor: pointer;
  padding: 9px 11px;
  border-radius: 8px;
  color: var(--text);
  font-size: 0.875rem;
  text-align: left;
  transition: background 0.12s;
}

.help-flyout-item:hover {
  background: var(--surface);
}

.help-flyout-icon {
  color: var(--text-muted);
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

/* active state on Help button when flyout is open */
.pm-menu-item-active {
  background: var(--surface-soft);
}

.help-topic-list {
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.help-topic-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  background: none;
  border: none;
  cursor: pointer;
  padding: 8px 14px;
  border-radius: 8px;
  color: var(--text);
  font-size: 0.875rem;
  text-align: left;
  transition: background 0.15s;
}

.help-topic-item:hover {
  background: var(--surface);
}

.help-topic-icon {
  color: var(--text-muted);
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

/* ── Plan Panel ─────────────────────────────────────────────── */
.plan-panel {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 6px 10px 10px;
}

.plan-card {
  border-radius: 10px;
  padding: 12px 14px;
  background: var(--surface-soft);
  border: 1px solid var(--border);
}

.plan-card-pro {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 8%, var(--surface-soft));
}

.plan-card-elite {
  border-color: rgba(168, 85, 247, 0.45);
  background: color-mix(in srgb, #a855f7 8%, var(--surface-soft));
}

.plan-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 4px;
}

.plan-name {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--text);
}

.plan-badge {
  font-size: 0.68rem;
  font-weight: 600;
  padding: 2px 7px;
  border-radius: 20px;
  letter-spacing: 0.03em;
}

.plan-badge-current {
  background: var(--surface-2);
  color: var(--text-muted);
}

.plan-badge-popular {
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  color: var(--accent);
}

.plan-price {
  font-size: 1rem;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 8px;
}

.plan-period {
  font-size: 0.78rem;
  font-weight: 400;
  color: var(--text-muted);
}

.plan-features {
  list-style: none;
  margin: 0 0 10px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.plan-features li {
  font-size: 0.8rem;
  color: var(--text-muted);
  padding-left: 14px;
  position: relative;
}

.plan-features li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--accent);
  font-size: 0.75rem;
}

.plan-card-elite .plan-features li::before {
  color: #a855f7;
}

.plan-upgrade-btn {
  width: 100%;
  padding: 7px 12px;
  border-radius: 7px;
  border: none;
  background: var(--accent);
  color: #fff;
  font-size: 0.8rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s, opacity 0.15s;
}

.plan-upgrade-btn:hover {
  background: var(--accent-strong);
}

.plan-upgrade-btn-elite {
  background: #a855f7;
}

.plan-upgrade-btn-elite:hover {
  background: #9333ea;
}

/* Upgrade plan — no accent color */
.pm-menu-item-upgrade .pm-menu-item-label {
  color: var(--text);
}

.pm-menu-item-upgrade .pm-menu-item-icon svg {
  stroke: currentColor;
}

/* ── Sidebar search ─────────────────────────────────────────── */
.sidebar-search-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 10px;
  background: var(--surface-soft);
  border: 1px solid var(--border);
  border-radius: 11px;
  margin: 2px 0;
  transition: border-color 0.2s, box-shadow 0.2s;
}

.sidebar-search-wrap:focus-within {
  border-color: #000;
  box-shadow: none;
  background: var(--surface);
}

.sidebar-search-icon {
  color: var(--text-faint);
  flex-shrink: 0;
}

.sidebar-search-input {
  flex: 1;
  background: none;
  border: none !important;
  outline: none !important;
  color: var(--text);
  font-size: 0.875rem;
  padding: 9px 0;
  min-width: 0;
}

.sidebar-search-input::placeholder {
  color: var(--text-faint);
}

.sidebar-search-clear {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  cursor: pointer;
  color: var(--text-faint);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 5px;
  margin-right: -4px;
  border-radius: 6px;
  flex-shrink: 0;
  transition: color 0.12s, background 0.12s;
}

.sidebar-search-clear:hover {
  color: var(--text);
  background: var(--surface-2) !important;
}

.sidebar-search-results {
  flex: 1;
  overflow-y: auto;
  padding: 4px 0;
  min-height: 0;
}

.sidebar-search-empty {
  padding: 20px 16px;
  font-size: 0.82rem;
  color: var(--text-faint);
  text-align: center;
  line-height: 1.5;
}

/* ── Help kbd ───────────────────────────────────────────────── */
.help-kbd {
  margin-left: auto;
  font-size: 0.7rem;
  color: var(--text-faint);
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 1px 5px;
  font-family: ui-monospace, monospace;
  flex-shrink: 0;
}

/* ── Plan Modal ─────────────────────────────────────────────── */
.plan-modal {
  max-width: 680px;
  width: 95vw;
}

.plan-modal-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-top: 16px;
}

@media (max-width: 600px) {
  .plan-modal-grid {
    grid-template-columns: 1fr;
  }
}

.plan-modal-card {
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 16px;
  background: var(--surface-soft);
  display: flex;
  flex-direction: column;
}

.plan-modal-card-featured {
  border-color: var(--border);
  background: var(--surface-soft);
}

.plan-modal-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 6px;
}

.plan-modal-name {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text);
}

.plan-modal-badge {
  font-size: 0.66rem;
  font-weight: 600;
  padding: 2px 7px;
  border-radius: 20px;
  letter-spacing: 0.03em;
}

.plan-modal-badge-current {
  background: var(--surface-2);
  color: var(--text-muted);
}

.plan-modal-badge-popular {
  background: var(--surface-2);
  color: var(--text-muted);
}

.plan-modal-price {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 12px;
}

.plan-modal-period {
  font-size: 0.78rem;
  font-weight: 400;
  color: var(--text-muted);
}

.plan-modal-features {
  list-style: none;
  margin: 0 0 14px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 5px;
  flex: 1;
}

.plan-modal-features li {
  font-size: 0.81rem;
  color: var(--text-muted);
  padding-left: 16px;
  position: relative;
  line-height: 1.4;
}

.plan-modal-features li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--text-muted);
  font-size: 0.75rem;
}

.plan-modal-btn {
  width: 100%;
  padding: 8px 12px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: var(--surface-2);
  color: var(--text);
  font-size: 0.82rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s;
  margin-top: auto;
}

.plan-modal-btn:hover {
  background: var(--surface);
}

.plan-modal-btn-primary {
  background: var(--surface-2);
  border-color: var(--border);
  color: var(--text);
}

.plan-modal-btn-primary:hover {
  background: var(--surface);
}

.sm-backdrop {
  position: fixed;
  inset: 0;
  z-index: 900;
  background: rgba(0, 0, 0, 0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  animation: fadeIn 0.15s ease;
}

.sm-dialog {
  display: flex;
  width: min(800px, 100%);
  height: min(580px, 90vh);
  border-radius: 16px;
  overflow: visible;
  background: var(--bg);
  border: 1px solid var(--border);
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.4);
  animation: slideUp 0.18s ease;
}

/* ── Left nav ── */
.sm-nav {
  width: 195px;
  flex-shrink: 0;
  background: var(--surface-soft);
  border-right: 1px solid var(--border);
  padding: 20px 10px 16px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  overflow-y: auto;
  border-radius: 16px 0 0 16px;
}

.sm-nav-heading {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--text-faint);
  padding: 0 12px 10px;
  margin: 0;
}

.sm-nav-item {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 9px 12px;
  border-radius: 8px;
  border: none;
  background: none;
  cursor: pointer;
  color: var(--text-muted);
  font-size: 0.875rem;
  font-weight: 500;
  width: 100%;
  text-align: left;
  transition: background 0.12s, color 0.12s;
}

.sm-nav-item:hover {
  background: var(--surface);
  color: var(--text);
}

.sm-nav-item.active {
  background: var(--surface);
  color: var(--text);
}

.sm-nav-icon {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  opacity: 0.65;
}

.sm-nav-item.active .sm-nav-icon {
  opacity: 1;
}

/* ── Right panel ── */
.sm-panel {
  flex: 1;
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: visible;
  border-radius: 0 16px 16px 0;
  background: var(--bg);
}

.sm-close {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 7px;
  border: none;
  background: none;
  cursor: pointer;
  color: var(--text-muted);
  transition: background 0.12s, color 0.12s;
}

.sm-close:hover {
  background: var(--surface-soft);
  color: var(--text);
}

.sm-panel-inner {
  flex: 1;
  overflow-y: auto;
  overflow-x: visible;
  padding: 28px 32px 32px;
}

.sm-panel {
  overflow: visible !important;
}

/* ── Section headers ── */
.sm-section {
  display: flex;
  flex-direction: column;
}

.sm-section-title {
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--text);
  margin: 0 0 4px;
}

.sm-section-desc {
  font-size: 0.84rem;
  color: var(--text-muted);
  margin: 0 0 20px;
  line-height: 1.5;
}

.sm-section-subtitle {
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-faint);
  margin: 24px 0 4px;
}

/* ── Row layout (ChatGPT-style) ── */
.sm-rows {
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: visible;
}

.sm-rows > .sm-row:first-child {
  border-radius: 10px 10px 0 0;
}

.sm-rows > .sm-row:last-child {
  border-radius: 0 0 10px 10px;
}

.sm-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
  background: var(--surface-soft);
  transition: background 0.1s;
}

.sm-row:last-child {
  border-bottom: none;
}

.sm-row-col {
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
}

.sm-row-profile {
  cursor: pointer;
}

.sm-row-profile:hover {
  background: var(--surface);
}

.sm-row-profile.active {
  background: var(--surface);
  color: var(--accent, #7c6ff7);
}

.sm-row-left {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.sm-row-label {
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--text);
  margin: 0;
}

.sm-row-meta {
  font-size: 0.8rem;
  color: var(--text-muted);
  margin: 0;
}

.sm-row-value {
  font-size: 0.875rem;
  color: var(--text-muted);
  white-space: nowrap;
}

/* Row controls */
.sm-row-select {
  appearance: auto;
  background: var(--surface-soft);
  border: 1px solid var(--border);
  color: var(--text);
  padding: 5px 8px;
  border-radius: 7px;
  font-size: 0.84rem;
  cursor: pointer;
  min-width: 110px;
  flex-shrink: 0;
}

.sm-row-select:focus {
  outline: 2px solid var(--accent, #7c6ff7);
  outline-offset: 1px;
}

/* Compact inline field (no heavy box look) */
.sm-field {
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--border);
  color: var(--text);
  padding: 4px 2px;
  font-size: 0.875rem;
  min-width: 160px;
  flex-shrink: 0;
  text-align: right;
  transition: border-color 0.15s;
}

.sm-field:focus {
  outline: none;
  border-bottom-color: var(--accent, #7c6ff7);
}

.sm-field::placeholder {
  color: var(--text-faint);
}

.sm-field-date {
  min-width: 130px;
  color-scheme: dark;
}

.sm-field-xs {
  min-width: 60px;
  max-width: 80px;
  text-align: right;
}

.sm-field-hint {
  font-size: 0.75rem;
  color: var(--text-faint);
  margin: 2px 0 0;
}

.sm-field-hint-ok {
  color: var(--accent, #7c6ff7);
}

.sm-field-hint-err {
  color: #e05566;
}

/* Legacy row-input kept for non-birth tabs */
.sm-row-input {
  background: var(--surface-soft);
  border: 1px solid var(--border);
  color: var(--text);
  padding: 6px 10px;
  border-radius: 7px;
  font-size: 0.875rem;
  min-width: 160px;
  flex-shrink: 0;
}

.sm-row-input:focus {
  outline: 2px solid var(--accent, #7c6ff7);
  outline-offset: 1px;
}

.sm-row-btn {
  flex-shrink: 0;
  padding: 6px 13px;
  border-radius: 7px;
  border: 1px solid var(--border);
  background: var(--surface-soft);
  color: var(--text);
  font-size: 0.83rem;
  font-weight: 500;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.12s;
}

.sm-row-btn:hover {
  background: var(--surface);
}

.sm-row-label-sm {
  font-size: 0.85rem;
  color: var(--text-muted);
}

/* Today's Sky location row */
.sm-sky-loc-typehead-wrap {
  width: 100%;
  position: relative;
  z-index: 9999;
}

.sm-sky-loc-typehead-wrap .place-selection-wrapper {
  width: 100%;
}

.sm-sky-loc-typehead-wrap .rbt-menu,
.sm-sky-loc-typehead-wrap .dropdown-menu {
  z-index: 9999 !important;
  position: absolute !important;
}

/* Badge (e.g. "Free" plan label) */
.sm-badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 20px;
  border: 1px solid var(--border);
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--text-muted);
  background: var(--bg);
  white-space: nowrap;
}

/* Save button */
.sm-save-btn {
  margin-top: 4px;
  padding: 8px 18px;
  border-radius: 8px;
  border: none;
  background: var(--accent, #7c6ff7);
  color: #fff;
  font-size: 0.84rem;
  font-weight: 600;
  cursor: pointer;
  align-self: flex-start;
  transition: opacity 0.12s;
}

.sm-save-btn:hover {
  opacity: 0.85;
}

/* ── Birth Profile form ── */
.bp-form {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-bottom: 4px;
}

.bp-row-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.bp-field {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.bp-label {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--text-muted);
  letter-spacing: 0.01em;
}

.bp-input {
  background: var(--surface-soft);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--text);
  padding: 8px 10px;
  font-size: 0.875rem;
  width: 100%;
  box-sizing: border-box;
  transition: border-color 0.15s;
  color-scheme: dark;
}

.bp-input:focus {
  outline: none;
  border-color: var(--accent, #7c6ff7);
}

.bp-input::placeholder {
  color: var(--text-faint);
}

.bp-select {
  cursor: pointer;
  appearance: auto;
}

.bp-geo {
  font-size: 0.75rem;
  color: var(--text-faint);
  margin-top: 2px;
}

.bp-geo-ok {
  color: var(--accent, #7c6ff7);
}

.bp-geo-err {
  color: #e05566;
}

/* Profile delete button */
.sm-profile-del {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 6px;
  border: none;
  background: none;
  color: var(--text-faint);
  cursor: pointer;
  transition: background 0.12s, color 0.12s;
  flex-shrink: 0;
}

.sm-profile-del:hover {
  background: rgba(220, 50, 50, 0.12);
  color: #e05566;
}

/* Profile avatar */
.sm-profile-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--surface);
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text);
  flex-shrink: 0;
}

/* Hint text */
.sm-hint {
  margin: 12px 0 0;
  font-size: 0.8rem;
  color: var(--text-faint);
  line-height: 1.5;
}

/* ── Upgrade plan cards ── */
.sm-plan-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 4px;
}

.sm-plan-card {
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 16px;
  background: var(--surface-soft);
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.sm-plan-card.featured {
  border-color: var(--accent, #7c6ff7);
  background: var(--surface);
}

.sm-plan-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
}

.sm-plan-badge {
  display: inline-block;
  font-size: 0.68rem;
  font-weight: 700;
  color: var(--accent, #7c6ff7);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 0 0 2px;
}

.sm-plan-name {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text);
  margin: 0;
}

.sm-plan-price {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--text);
  margin: 0;
  white-space: nowrap;
}

.sm-plan-price span {
  font-size: 0.78rem;
  font-weight: 400;
  color: var(--text-muted);
}

.sm-plan-features {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 5px;
  flex: 1;
}

.sm-plan-features li {
  font-size: 0.82rem;
  color: var(--text-muted);
  padding-left: 14px;
  position: relative;
}

.sm-plan-features li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--text-faint);
  font-size: 0.75rem;
}

.sm-plan-current {
  font-size: 0.78rem;
  color: var(--text-faint);
  font-style: italic;
}

.sm-plan-btn {
  padding: 8px 14px;
  border-radius: 8px;
  border: none;
  background: var(--text);
  color: var(--bg);
  font-size: 0.84rem;
  font-weight: 600;
  cursor: pointer;
  transition: opacity 0.12s;
}

.sm-plan-btn:hover {
  opacity: 0.85;
}

@keyframes slideUp {
  from {
    opacity: 0;
    transform: translateY(12px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ============================================================
   AUTH PAGES (Login / Signup)
   ============================================================ */
.auth-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #212121;
  padding: 24px;
}

.auth-card {
  width: 100%;
  max-width: 400px;
  background: transparent;
  border-radius: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
}

.auth-logo {
  margin-bottom: 20px;
}

.auth-logo-mark {
  width: 48px;
  height: 48px;
  background: var(--accent, #c8a96e);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
}

.auth-title {
  font-size: 1.9rem;
  font-weight: 600;
  color: #fff;
  margin: 0 0 8px;
  text-align: center;
}

.auth-subtitle {
  font-size: 0.9rem;
  color: #9e9e9e;
  text-align: center;
  margin: 0 0 28px;
  line-height: 1.5;
}

/* Social button */
.auth-social-btn {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 12px 16px;
  background: #3f3f3f;
  border: 1px solid #555;
  border-radius: 100px;
  color: #fff;
  font-size: 0.9rem;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.15s;
  margin-bottom: 4px;
}

.auth-social-btn:hover {
  background: #4a4a4a;
}

/* Divider */
.auth-divider {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  margin: 16px 0;
  color: #666;
  font-size: 0.8rem;
}

.auth-divider::before,
.auth-divider::after {
  content: "";
  flex: 1;
  height: 1px;
  background: #444;
}

/* Form */
.auth-form {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.auth-field {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.auth-label {
  font-size: 0.8rem;
  color: #bbb;
  font-weight: 500;
}

.auth-input {
  width: 100%;
  padding: 13px 16px;
  background: #2a2a2a;
  border: 1.5px solid #3f3f3f;
  border-radius: 10px;
  color: #fff;
  font-size: 0.95rem;
  outline: none;
  box-sizing: border-box;
  transition: border-color 0.15s;
}

.auth-input:focus {
  border-color: var(--accent, #c8a96e);
}

.auth-input::placeholder {
  color: #666;
}

.auth-error {
  background: rgba(239, 68, 68, 0.15);
  border: 1px solid rgba(239, 68, 68, 0.3);
  color: #f87171;
  border-radius: 8px;
  padding: 10px 12px;
  font-size: 0.85rem;
}

.auth-submit-btn {
  width: 100%;
  padding: 12px;
  background: #fff;
  color: #111;
  border: none;
  border-radius: 100px;
  font-size: 0.95rem;
  font-weight: 600;
  cursor: pointer;
  margin-top: 4px;
  transition: opacity 0.15s;
}

.auth-submit-btn:hover {
  opacity: 0.9;
}

.auth-submit-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

/* Toggle mode */
.auth-toggle {
  font-size: 0.875rem;
  color: #9e9e9e;
  text-align: center;
  margin: 20px 0 0;
}

.auth-toggle-btn {
  background: none;
  border: none;
  color: #ececec;
  cursor: pointer;
  font-size: inherit;
  font-weight: 600;
  padding: 0;
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color 0.15s;
}

.auth-toggle-btn:hover {
  color: #fff;
}

.auth-footer-links {
  display: flex;
  gap: 12px;
  align-items: center;
  margin-top: 20px;
  font-size: 0.75rem;
  color: #666;
}

.auth-footer-links a {
  color: #888;
  text-decoration: underline;
}

.auth-footer-links a:hover {
  color: #bbb;
}

/* ============================================================
   SIDEBAR USER SECTION
   ============================================================ */
.sidebar-user-section {
  position: relative;
  padding: 8px 8px 4px;
  border-top: 1px solid var(--border-color, rgba(255, 255, 255, 0.08));
}

/* Logged-in trigger button */
.sidebar-user-btn {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 9px 10px;
  background: transparent;
  border: none;
  border-radius: 10px;
  cursor: pointer;
  color: var(--text-primary, #e8e0d5);
  transition: background 0.15s;
  text-align: left;
}

.sidebar-user-btn:hover {
  background: var(--sidebar-item-hover, rgba(255, 255, 255, 0.06));
}

.sidebar-user-avatar {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: #1a1a1a;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  font-weight: 700;
  color: #fff;
  flex-shrink: 0;
  overflow: hidden;
}

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

.sidebar-user-info {
  flex: 1;
  overflow: hidden;
  min-width: 0;
}

.sidebar-user-name {
  display: block;
  font-size: 0.85rem;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sidebar-user-email {
  display: block;
  font-size: 0.72rem;
  color: #888;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sidebar-user-caret {
  opacity: 0.5;
  flex-shrink: 0;
}

/* User dropdown menu */
.user-menu-dropdown {
  position: absolute;
  bottom: calc(100% + 4px);
  left: 8px;
  right: 8px;
  background: var(--surface-elevated, #2a2a2a);
  border: 1px solid var(--border-color, rgba(255, 255, 255, 0.1));
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4);
  z-index: 200;
  animation: slideUp 0.15s ease;
}

.user-menu-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 14px 12px;
}

.user-menu-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: #1a1a1a;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  font-weight: 700;
  color: #fff;
  flex-shrink: 0;
  overflow: hidden;
}

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

.user-menu-info {
  overflow: hidden;
}

.user-menu-name {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--text-primary, #e8e0d5);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.user-menu-email {
  font-size: 0.75rem;
  color: #888;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.user-menu-divider {
  height: 1px;
  background: var(--border-color, rgba(255, 255, 255, 0.08));
}

.user-menu-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 11px 14px;
  background: none;
  border: none;
  color: var(--text-primary, #e8e0d5);
  font-size: 0.875rem;
  cursor: pointer;
  text-align: left;
  transition: background 0.12s;
}

.user-menu-item:hover {
  background: rgba(255, 255, 255, 0.06);
}

.user-menu-logout {
  color: var(--text);
}

.user-menu-logout:hover {
  background: rgba(0, 0, 0, 0.06);
}

[data-theme="dark"] .user-menu-logout:hover,
.dark .user-menu-logout:hover {
  background: rgba(255, 255, 255, 0.06);
}

.user-menu-footer-links {
  display: flex;
  gap: 8px;
  align-items: center;
  padding: 10px 14px;
  font-size: 0.72rem;
  color: #666;
}

.user-menu-footer-links a {
  color: #777;
  text-decoration: none;
}

.user-menu-footer-links a:hover {
  color: #aaa;
  text-decoration: underline;
}

/* Logged-out auth prompt */
.sidebar-auth-prompt {
  padding: 8px 4px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.sidebar-auth-desc {
  font-size: 0.78rem;
  color: #888;
  margin: 0 0 2px;
  line-height: 1.4;
}

.sidebar-login-btn,
.sidebar-signup-btn {
  display: block;
  text-align: center;
  padding: 9px 14px;
  border-radius: 100px;
  font-size: 0.85rem;
  font-weight: 600;
  text-decoration: none;
  transition: opacity 0.15s;
}

.sidebar-login-btn {
  background: #fff;
  color: #111;
}

.sidebar-login-btn:hover {
  opacity: 0.9;
}

.sidebar-signup-btn {
  background: transparent;
  color: var(--text-primary, #e8e0d5);
  border: 1px solid rgba(255, 255, 255, 0.2);
}

.sidebar-signup-btn:hover {
  background: rgba(255, 255, 255, 0.06);
}

/* ============================================================
   LOGOUT CONFIRMATION MODAL
   ============================================================ */
.logout-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  z-index: 9000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.logout-modal {
  background: #fff;
  color: #111;
  border-radius: 16px;
  padding: 32px 28px;
  max-width: 380px;
  width: 100%;
  text-align: center;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
}

.logout-modal h3 {
  font-size: 1.15rem;
  font-weight: 700;
  margin: 0 0 10px;
}

.logout-modal p {
  font-size: 0.875rem;
  color: #555;
  margin: 0 0 24px;
  line-height: 1.5;
}

.logout-modal-confirm {
  display: block;
  width: 100%;
  padding: 12px;
  background: #111;
  color: #fff;
  border: none;
  border-radius: 100px;
  font-size: 0.95rem;
  font-weight: 600;
  cursor: pointer;
  margin-bottom: 10px;
  transition: opacity 0.15s;
}

.logout-modal-confirm:hover {
  opacity: 0.85;
}

.logout-modal-cancel {
  display: block;
  width: 100%;
  padding: 12px;
  background: transparent;
  color: #111;
  border: 1px solid #ddd;
  border-radius: 100px;
  font-size: 0.95rem;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.15s;
}

.logout-modal-cancel:hover {
  background: #f5f5f5;
}

/* ============================================================
   TOPBAR AUTH BUTTONS (Log in / Sign up)
   ============================================================ */
.topbar-auth-btn {
  display: inline-flex;
  align-items: center;
  padding: 7px 16px;
  border-radius: 100px;
  font-size: 0.85rem;
  font-weight: 600;
  text-decoration: none;
  transition: opacity 0.15s;
  white-space: nowrap;
}

.topbar-login-btn {
  background: var(--text-primary, #1a1a1a);
  color: var(--bg-primary, #fff);
  border: 1px solid transparent;
}

[data-theme="dark"] .topbar-login-btn,
.dark .topbar-login-btn {
  background: #fff;
  color: #111;
}

.topbar-login-btn:hover {
  opacity: 0.85;
}

.topbar-signup-btn {
  background: transparent;
  color: var(--text-primary, #1a1a1a);
  border: 1px solid rgba(0, 0, 0, 0.2);
}

[data-theme="dark"] .topbar-signup-btn,
.dark .topbar-signup-btn {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.2);
}

.topbar-signup-btn:hover {
  opacity: 0.75;
}

/* ============================================================
   PROFILE MANAGER LOGOUT ITEM
   ============================================================ */
.pm-menu-logout .pm-menu-item-label {
  color: var(--text);
}

.pm-menu-logout svg {
  stroke: var(--text);
}

.pm-menu-logout:hover {
  background: rgba(0, 0, 0, 0.06) !important;
}

[data-theme="dark"] .pm-menu-logout:hover,
.dark .pm-menu-logout:hover {
  background: rgba(255, 255, 255, 0.06) !important;
}

/* Add an account link in Profile Manager */
.pm-add-account {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  color: var(--text-primary, inherit);
  text-decoration: none;
  font-size: 0.875rem;
  border-radius: 8px;
  transition: background 0.12s;
  cursor: pointer;
  width: 100%;
}

.pm-add-account:hover {
  background: var(--surface-soft, rgba(0, 0, 0, 0.05));
}

/* ── Auth: password eye toggle + forgot password ── */
.auth-input-wrapper {
  position: relative;
  display: flex;
  align-items: center;
}

.auth-input-wrapper .auth-input {
  padding-right: 44px;
  width: 100%;
}

.auth-eye-btn {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
  color: #9e9e9e;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  transition: color 0.15s;
}

.auth-eye-btn:hover {
  color: #ececec;
}

.auth-forgot-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0;
}

.auth-forgot-link {
  font-size: 0.8rem;
  color: #9e9e9e;
  text-decoration: none;
  transition: color 0.15s;
}

.auth-forgot-link:hover {
  color: #ececec;
  text-decoration: underline;
}

/* ═══════════════════════════════════════════════════════
   Auth Flow Pages (ChatGPT-style: forgot/reset password)
   ═══════════════════════════════════════════════════════ */

.auth-flow-page {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: #212121;
  padding: 24px;
}

.auth-flow-content {
  width: 100%;
  max-width: 400px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.auth-flow-title {
  font-size: 1.9rem;
  font-weight: 600;
  color: #ececec;
  margin: 0 0 14px;
  line-height: 1.2;
}

.auth-flow-subtitle {
  font-size: 0.92rem;
  color: #9e9e9e;
  margin: 0 0 28px;
  line-height: 1.6;
}

.auth-flow-field {
  width: 100%;
  text-align: left;
  margin-bottom: 14px;
}

.auth-flow-label {
  display: block;
  font-size: 0.8rem;
  color: #9e9e9e;
  margin-bottom: 6px;
}

.auth-flow-label--blue {
  color: #6b7ef7;
}

.auth-flow-input {
  width: 100%;
  padding: 14px 16px;
  background: transparent;
  border: 1.5px solid #3f3f3f;
  border-radius: 10px;
  color: #ececec;
  font-size: 0.95rem;
  outline: none;
  transition: border-color 0.15s;
  box-sizing: border-box;
}

.auth-flow-input:focus {
  border-color: #6b7ef7;
}

.auth-flow-input--code {
  font-size: 1.2rem;
  letter-spacing: 0.15em;
  text-align: center;
}

/* Big white primary pill button */
.auth-btn-primary {
  width: 100%;
  padding: 14px 28px;
  background: var(--accent);
  color: var(--accent-fg);
  border: none;
  border-radius: 100px;
  font-size: 0.95rem;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.15s, opacity 0.15s;
  margin-bottom: 10px;
  display: block;
  text-align: center;
  text-decoration: none;
}

.auth-btn-primary:hover:not(:disabled) {
  background: var(--accent-strong);
}

.auth-btn-primary:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

/* Dark secondary pill button */
.auth-btn-secondary {
  width: 100%;
  padding: 14px 28px;
  background: #2a2a2a;
  color: #ececec;
  border: 1px solid #3f3f3f;
  border-radius: 100px;
  font-size: 0.95rem;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.15s;
  margin-bottom: 10px;
  display: block;
  text-align: center;
  text-decoration: none;
  box-sizing: border-box;
}

.auth-btn-secondary:hover {
  background: #363636;
}

/* Subtle text link button */
.auth-btn-text {
  background: none;
  border: none;
  color: #9e9e9e;
  font-size: 0.9rem;
  cursor: pointer;
  padding: 8px 12px;
  transition: color 0.15s;
  text-decoration: none;
  display: inline-block;
  margin-bottom: 4px;
}

.auth-btn-text:hover {
  color: #ececec;
}

/* OR divider */
.auth-flow-or {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  margin: 12px 0 16px;
  color: #555;
  font-size: 0.82rem;
}

.auth-flow-or::before,
.auth-flow-or::after {
  content: "";
  flex: 1;
  height: 1px;
  background: #3a3a3a;
}

/* Footer links (Terms / Privacy) */
.auth-flow-footer {
  margin-top: 48px;
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 0.78rem;
  color: #555;
}

.auth-flow-footer a {
  color: #555;
  text-decoration: underline;
  transition: color 0.15s;
}

.auth-flow-footer a:hover {
  color: #9e9e9e;
}

.auth-flow-footer span {
  color: #3a3a3a;
}

/* Reuse eye-btn on auth-flow-input */
.auth-flow-field .auth-input-wrapper .auth-flow-input {
  padding-right: 44px;
}

/* Eye toggle works inside auth-flow-field too */
.auth-flow-field .auth-input-wrapper {
  position: relative;
  display: flex;
  align-items: center;
}

.auth-flow-field .auth-input-wrapper .auth-flow-input {
  padding-right: 44px;
  width: 100%;
}
/* ── Solar Location Overlay ── */
.solar-loc-overlay {
  position: absolute;
  top: 120px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 200;
  animation: slideUp 0.3s ease-out;
}

.solar-loc-overlay-inner {
  background: rgba(0, 0, 0, 0.45);
  backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 16px;
  padding: 24px;
  width: 320px;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.5);
  text-align: center;
}

.solar-loc-overlay-head {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  margin-bottom: 20px;
  position: relative;
}

.solar-loc-overlay-title {
  font-size: 0.95rem;
  font-weight: 600;
  color: #fff;
  letter-spacing: 0.02em;
}

.solar-loc-overlay-close {
  position: absolute;
  top: -10px;
  right: -10px;
  background: rgba(255, 255, 255, 0.05);
  border-radius: 50%;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  color: rgba(255, 255, 255, 0.5);
  cursor: pointer;
  font-size: 0.9rem;
  transition: color 0.2s;
}

.solar-loc-overlay-close:hover {
  color: #fff;
}

.solar-loc-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 20px;
}

.solar-loc-label {
  font-size: 0.7rem;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.4);
  letter-spacing: 0.1em;
}

.solar-loc-input {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 8px;
  color: #fff;
  padding: 10px 12px;
  font-size: 0.9rem;
  width: 100%;
  box-sizing: border-box;
  outline: none;
  transition: border-color 0.2s;
  text-align: center;
}

.solar-loc-input:focus {
  border-color: rgba(255, 255, 255, 0.3);
}

.solar-loc-submit-btn {
  width: 100%;
  padding: 10px;
  border-radius: 8px;
  border: none;
  background: rgba(255, 255, 255, 0.9);
  color: #000;
  font-size: 0.85rem;
  font-weight: 700;
  cursor: pointer;
  transition: opacity 0.2s;
}

.solar-loc-submit-btn:hover {
  opacity: 0.9;
}
