/* ============================================================
 * Джйотиш-калькулятор SJC — тёмная индиго-золотая тема
 * ============================================================ */
:root {
  --bg: #0d0b1e;
  --bg2: #14112b;
  --panel: #1a1633;
  --panel2: #221d42;
  --line: #322a5e;
  --text: #e8e4f5;
  --muted: #9b93c0;
  --gold: #e8b955;
  --gold2: #f5d488;
  --accent: #8d7bff;
  --good: #4ecf8a;
  --warn: #ff8a65;
  --hl: #3a2f73;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font: 16px/1.55 "Segoe UI", system-ui, -apple-system, sans-serif;
}

a { color: var(--gold); }
.muted { color: var(--muted); }
.small { font-size: .85em; }
.hidden { display: none; }
.accent { color: var(--gold); }

/* --- Hero --- */
.hero {
  background:
    radial-gradient(ellipse 70% 100% at 50% -10%, #2c2461 0%, transparent 65%),
    radial-gradient(ellipse 40% 60% at 80% 0%, #3c2a14 0%, transparent 60%),
    var(--bg);
  border-bottom: 1px solid var(--line);
  text-align: center;
  padding: 56px 16px 40px;
}
.hero-om {
  font-size: 52px;
  color: var(--gold);
  text-shadow: 0 0 30px rgba(232, 185, 85, .45);
}
.hero h1 { margin: 8px 0 12px; font-size: 2rem; letter-spacing: .02em; }
.hero-sub { color: var(--muted); max-width: 640px; margin: 0 auto; }
.hero-note { color: var(--gold2); font-size: .85em; margin-top: 14px; opacity: .85; }

/* --- Layout --- */
main { max-width: 1080px; margin: 0 auto; padding: 24px 16px 64px; }
.panel {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 22px 24px;
  margin-bottom: 22px;
}
.panel h2 {
  margin: 0 0 16px;
  font-size: 1.25rem;
  color: var(--gold2);
  border-bottom: 1px solid var(--line);
  padding-bottom: 10px;
}
.panel h3 { color: var(--gold2); font-size: 1.02rem; margin: 18px 0 8px; }

/* --- Форма --- */
.form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px 16px;
}
.form-grid label { display: flex; flex-direction: column; font-size: .85em; color: var(--muted); gap: 4px; }
.form-grid input, .form-grid select {
  background: var(--bg2);
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--text);
  padding: 9px 10px;
  font-size: 1rem;
  color-scheme: dark;
}
.form-grid input:focus, .form-grid select:focus { outline: 1px solid var(--accent); }
.form-actions { margin-top: 18px; display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.btn-main {
  background: linear-gradient(135deg, var(--gold), #c99a3a);
  color: #1c1505;
  font-weight: 700;
  font-size: 1.05rem;
  border: none;
  border-radius: 10px;
  padding: 12px 28px;
  cursor: pointer;
}
.btn-main:hover { filter: brightness(1.1); }
.btn-ghost {
  background: transparent;
  color: var(--muted);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 12px 20px;
  cursor: pointer;
}
.btn-ghost:hover { color: var(--gold2); border-color: var(--gold); }
.form-error { color: var(--warn); }

/* --- Сводка --- */
.summary { line-height: 1.9; }

/* --- Вкладки варг --- */
.tabs { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; }
.tab {
  background: var(--bg2);
  border: 1px solid var(--line);
  color: var(--muted);
  border-radius: 20px;
  padding: 7px 14px;
  cursor: pointer;
  font-size: .88em;
}
.tab:hover { color: var(--gold2); }
.tab-active { background: var(--hl); color: var(--gold2); border-color: var(--gold); }

/* --- Южноиндийская карта --- */
.chart-wrap { max-width: 620px; margin: 0 auto; }
.chart-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: repeat(4, minmax(92px, auto));
  gap: 3px;
  background: var(--line);
  border: 2px solid var(--line);
  border-radius: 10px;
  overflow: hidden;
}
.chart-cell {
  background: var(--bg2);
  padding: 6px 7px;
  position: relative;
  cursor: pointer;
  transition: background .15s;
  min-height: 92px;
}
.chart-cell:hover { background: #1d1840; }
.cell-hl { background: var(--hl) !important; box-shadow: inset 0 0 0 1.5px var(--gold); }
.cell-lagna { box-shadow: inset 0 0 0 1.5px var(--accent); }
.cell-lagna.cell-hl { box-shadow: inset 0 0 0 1.5px var(--gold); }
.cell-sign { font-size: .68em; color: var(--muted); display: block; }
.cell-asc {
  position: absolute; top: 5px; right: 7px;
  color: var(--accent); font-size: .7em; font-weight: 700;
}
.cell-badges {
  display: block;
  font-size: .62em;
  color: var(--gold);
  margin-top: 1px;
}
.cell-planets { display: block; margin-top: 4px; line-height: 1.7; }
.pl {
  display: inline-block;
  font-size: .82em;
  padding: 0 4px;
  border-radius: 5px;
  background: #2a2350;
  margin: 1px 1px 0 0;
  cursor: pointer;
}
.pl i { font-style: normal; font-size: .75em; color: var(--warn); }
.pl-sel { outline: 1.5px solid var(--gold); }
.pl-Sun { color: #ffb74d; } .pl-Moon { color: #e3f2fd; } .pl-Mars { color: #ff7043; }
.pl-Mercury { color: #81c784; } .pl-Jupiter { color: #ffd54f; } .pl-Venus { color: #f48fb1; }
.pl-Saturn { color: #90a4ae; } .pl-Rahu { color: #b39ddb; } .pl-Ketu { color: #bcaaa4; }
.chart-center {
  background: var(--panel2);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; padding: 10px;
}
.chart-title { color: var(--gold2); font-weight: 700; font-size: 1.05em; }
.chart-sub { color: var(--muted); font-size: .72em; margin-top: 6px; max-width: 200px; }

/* --- Дома --- */
.houses-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.houses-list { display: flex; flex-direction: column; gap: 6px; }
.house-item {
  display: grid;
  grid-template-columns: 28px 92px 1fr auto;
  gap: 8px;
  align-items: center;
  background: var(--bg2);
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--text);
  padding: 7px 10px;
  cursor: pointer;
  text-align: left;
  font-size: .88em;
}
.house-item:hover { border-color: var(--gold); }
.house-active { background: var(--hl); border-color: var(--gold); }
.house-no { color: var(--gold); font-weight: 700; }
.house-sign { color: var(--muted); }
.house-occ { color: var(--gold2); font-size: .85em; }
.house-card {
  background: var(--panel2);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 16px 18px;
  align-self: start;
  position: sticky;
  top: 12px;
}
.house-card h3 { margin-top: 0; }
.facts { list-style: none; padding: 0; margin: 10px 0 0; }
.facts li { padding: 5px 0; border-bottom: 1px dashed var(--line); font-size: .92em; }
.alert-line { color: var(--gold2); }

/* --- Таблицы --- */
.tbl-wrap { overflow-x: auto; }
.tbl { border-collapse: collapse; width: 100%; font-size: .88em; }
.tbl th, .tbl td { padding: 6px 10px; text-align: left; border-bottom: 1px solid var(--line); }
.tbl th { color: var(--muted); font-weight: 600; font-size: .92em; }
.row-active { background: var(--hl); }
.row-active td:first-child { border-left: 3px solid var(--gold); }
.retro { color: var(--warn); font-style: normal; font-size: .8em; }
.dasha-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; }

/* --- Транзиты --- */
.transit-head { margin-bottom: 14px; }
.alert {
  border-radius: 10px;
  padding: 12px 14px;
  margin-bottom: 10px;
  font-size: .92em;
  border: 1px solid var(--line);
  background: var(--bg2);
}
.alert.warn { border-left: 4px solid var(--warn); }
.alert.good { border-left: 4px solid var(--good); }
.alert.neutral { border-left: 4px solid var(--muted); color: var(--muted); }

/* --- Деваты --- */
.spirit-head { margin-bottom: 14px; }
.dev-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 14px; }
.dev-card {
  background: var(--panel2);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 16px;
  text-align: center;
}
.dev-card h4 { margin: 0 0 8px; color: var(--gold2); }
.dev-planet { font-size: 1.25em; font-weight: 700; }
.dev-form { color: var(--gold); margin: 4px 0; }
.dev-mantra { margin-top: 8px; font-size: .92em; }
.dev-note { font-size: .78em; margin-top: 8px; }

/* --- SJC-разбор --- */
.sjc-card {
  background: var(--bg2);
  border: 1px solid var(--line);
  border-radius: 10px;
  margin-bottom: 10px;
  overflow: hidden;
}
.sjc-card summary {
  cursor: pointer;
  padding: 13px 16px;
  font-weight: 600;
  color: var(--gold2);
  list-style: none;
}
.sjc-card summary::before { content: '☉ '; color: var(--gold); }
.sjc-card[open] summary { border-bottom: 1px solid var(--line); }
.sjc-body { padding: 6px 16px 14px; }
.fact-block { padding: 10px 0; border-bottom: 1px dashed var(--line); font-size: .92em; }
.fact-block:last-child { border-bottom: none; }
.fact { color: var(--muted); }
.concl { margin-top: 5px; }
.tag {
  display: inline-block;
  font-size: .68em;
  font-weight: 700;
  letter-spacing: .06em;
  color: var(--accent);
  border: 1px solid var(--accent);
  border-radius: 4px;
  padding: 0 5px;
  margin-right: 6px;
  vertical-align: 1px;
}
.tag-c { color: var(--gold); border-color: var(--gold); }

/* --- Footer --- */
footer {
  border-top: 1px solid var(--line);
  text-align: center;
  padding: 26px 16px 40px;
  color: var(--muted);
  font-size: .85em;
}

/* --- Mobile --- */
@media (max-width: 760px) {
  .houses-grid, .dasha-grid { grid-template-columns: 1fr; }
  .house-card { position: static; }
  .hero h1 { font-size: 1.5rem; }
  .chart-grid { grid-template-rows: repeat(4, minmax(74px, auto)); }
  .chart-cell { min-height: 74px; padding: 4px 5px; }
}
