/* Lal Kitab Varshphal preview pages — shared style. */
:root {
  --bg: #fdf6e3;
  --surface: #fffef8;
  --border: #e8d8a8;
  --gold: #8b6e2e;
  --gold-dim: #b89a4a;
  --gold-soft: #fff5cf;
  --ink: #1a132e;
  --ink-2: #4a3f5e;
  --ink-3: #7a6e8e;
  --debilitated: #a83232;
}
* { box-sizing: border-box; }
html, body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font: 14px/1.55 -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
}
header {
  padding: 14px 22px;
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  background: var(--surface);
}
header .title { font-weight: 700; color: var(--gold); font-size: 18px; }
header nav a {
  color: var(--ink-2); text-decoration: none; margin-left: 16px;
  padding: 6px 10px; border-radius: 6px; font-weight: 600;
}
header nav a.active { background: var(--gold-soft); color: var(--gold); }
header nav a:hover { background: var(--gold-soft); }

.layout { display: grid; grid-template-columns: 340px 1fr; min-height: calc(100vh - 56px); }
.sidebar {
  padding: 20px;
  border-right: 1px solid var(--border);
  background: var(--surface);
  position: sticky; top: 0; align-self: start; max-height: 100vh; overflow-y: auto;
}
.panel { padding: 24px 28px; max-width: 880px; }

label { display: block; font-size: 12px; color: var(--ink-2); margin: 10px 0 4px; font-weight: 600; }
input, select {
  width: 100%; padding: 8px 10px; border: 1px solid var(--border); border-radius: 6px;
  background: #fff; color: var(--ink); font: inherit;
}
.row { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
button {
  background: var(--gold); color: #fff8e0; border: none; cursor: pointer;
  padding: 10px 14px; border-radius: 6px; font: inherit; font-weight: 600;
}
button:hover:not(:disabled) { background: #6f5723; }
button:disabled { opacity: 0.55; cursor: not-allowed; }
button.ghost {
  background: transparent; color: var(--gold); border: 1px solid var(--gold-dim);
}
button.ghost:hover:not(:disabled) { background: var(--gold-soft); color: var(--gold); }

.heading { margin: 0 0 6px; font-size: 24px; color: var(--ink); }
.subtle { color: var(--ink-2); margin: 0 0 14px; }
.muted { color: var(--ink-3); font-style: italic; }
.err { color: var(--debilitated); font-weight: 600; }

.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 16px 18px;
  margin-bottom: 14px;
  position: relative;
}
.card-head {
  display: flex; justify-content: space-between; align-items: baseline;
  border-bottom: 1px solid var(--border);
  padding-bottom: 8px; margin-bottom: 10px;
}
.planet { font-weight: 700; color: var(--gold); font-size: 17px; }
.house { color: var(--ink-3); font-size: 12px; font-weight: 600; }
.headline { font-weight: 700; font-size: 15px; color: var(--ink); margin: 0 0 8px; }
.body { white-space: pre-wrap; line-height: 1.65; color: var(--ink); }

.card-tools { margin-top: 12px; display: flex; justify-content: flex-end; }
.card-tools button { padding: 6px 12px; font-size: 12px; }

.summary-bar {
  display: flex; gap: 14px; align-items: center; flex-wrap: wrap;
  margin-bottom: 16px; padding: 12px 16px;
  background: var(--gold-soft); border: 1px solid var(--gold-dim); border-radius: 10px;
}
.summary-bar b { color: var(--gold); }

.chart-wrap { display: flex; justify-content: center; margin: 6px 0 18px; }

.geocode {
  background: var(--surface); border: 1px solid var(--border); border-radius: 6px;
  max-height: 200px; overflow: auto; margin-top: 4px;
}
.geocode div { padding: 8px 10px; cursor: pointer; border-bottom: 1px solid var(--border); }
.geocode div:last-child { border-bottom: none; }
.geocode div:hover { background: var(--gold-soft); }

.spinner {
  border: 3px solid var(--border); border-top-color: var(--gold);
  border-radius: 50%; width: 22px; height: 22px;
  animation: spin 0.7s linear infinite;
}
.center-stack { display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 24px 0; }
@keyframes spin { to { transform: rotate(360deg); } }

.toolbar { display: flex; gap: 8px; align-items: center; margin-bottom: 14px; flex-wrap: wrap; }
