/* Tamil temple-bronze theme — warm, classical, readable */

:root {
  --bg:           #fbf4e3;
  --bg-card:     #fffdf6;
  --bronze:      #7a4a14;
  --bronze-dk:   #5a3508;
  --bronze-lt:   #b88a4a;
  --gold:        #c39419;
  --red:         #b30000;
  --green:       #2f8540;
  --ink:         #2a1d0c;
  --muted:       #8a7a5c;
  --border:      #c9a36a;
  --shadow:      0 2px 8px rgba(90, 53, 8, 0.12);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: var(--bg); color: var(--ink); }
body {
  font-family: 'Noto Sans Tamil', 'Inter', system-ui, sans-serif;
  font-size: 15px;
  line-height: 1.6;
  min-height: 100vh;
}

/* --- Header --- */
.app-header {
  background: linear-gradient(135deg, #7a4a14 0%, #4f2c06 100%);
  color: #fff8e0;
  padding: 18px 28px 0;
  border-bottom: 4px solid var(--gold);
  box-shadow: var(--shadow);
  position: relative;
}
.header-actions {
  position: absolute; top: 16px; right: 24px;
  display: flex; gap: 10px; align-items: center;
}
.back-link {
  color: #fff8e0; text-decoration: none;
  font-size: 13px; font-weight: 600;
  border: 1px solid rgba(255,248,224,0.4); border-radius: 50px;
  padding: 6px 16px; transition: background .2s, border-color .2s;
  background: rgba(255,255,255,0.08);
}
.back-link:hover { background: var(--gold); color: var(--bronze-dk); border-color: var(--gold); }
.lang-toggle {
  background: var(--gold); color: var(--bronze-dk);
  border: none; border-radius: 50px; cursor: pointer;
  font-family: inherit; font-size: 13px; font-weight: 700;
  padding: 6px 16px; transition: background .2s, transform .15s;
  min-width: 44px;
}
.lang-toggle:hover { background: #f0d886; transform: translateY(-1px); }
.brand { display: flex; align-items: center; gap: 18px; margin-bottom: 14px; }
.brand .om {
  font-size: 56px; line-height: 1; color: var(--gold);
  font-family: 'Tiro Tamil', serif;
}
.brand h1 { margin: 0; font-size: 26px; font-weight: 700; letter-spacing: 0.5px; }
.brand p  { margin: 0; font-size: 12px; color: #d8b56a; letter-spacing: 1.5px; text-transform: uppercase; }

.tabs { display: flex; gap: 0; flex-wrap: wrap; }
.tab {
  background: transparent; border: 0; color: #d8b56a;
  padding: 12px 22px; font-size: 15px; cursor: pointer;
  font-family: inherit; font-weight: 500;
  border-bottom: 3px solid transparent; transition: all 0.15s;
}
.tab:hover { color: #fff8e0; }
.tab.active {
  color: #fff8e0; border-bottom-color: var(--gold);
  background: rgba(255, 248, 224, 0.05);
}

/* --- Main --- */
main { max-width: 1200px; margin: 0 auto; padding: 24px 20px 80px; }
.panel { display: none; }
.panel.active { display: block; animation: fadeIn 0.2s; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }

/* --- Cards --- */
.form-card, .card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 20px 24px;
  margin-bottom: 18px;
  box-shadow: var(--shadow);
  position: relative;
}
.form-card::before, .card::before {
  content: '';
  position: absolute; top: 0; left: 12px; right: 12px; height: 3px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  border-radius: 0 0 4px 4px;
}
h2, h3 { color: var(--bronze-dk); margin: 0 0 14px; font-weight: 600; }
h2 { font-size: 22px; }
h3 { font-size: 17px; }
h4 { color: var(--bronze); margin: 0 0 6px; font-size: 15px; }

/* --- Forms --- */
.form-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px 16px;
  margin-bottom: 16px;
}
.form-grid label, .couple-form label {
  display: flex; flex-direction: column; gap: 4px;
  font-size: 13px; color: var(--bronze);
  font-weight: 500;
}
.form-grid .span2 { grid-column: span 2; }
input, select {
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 5px;
  font-size: 14px;
  font-family: inherit;
  background: #fffefa;
  color: var(--ink);
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
}
input:focus, select:focus {
  border-color: var(--bronze);
  box-shadow: 0 0 0 3px rgba(122, 74, 20, 0.12);
}
.primary-btn {
  background: linear-gradient(180deg, var(--bronze-lt), var(--bronze));
  color: #fff8e0;
  border: 1px solid var(--bronze-dk);
  padding: 10px 28px;
  border-radius: 6px;
  font-size: 16px;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  box-shadow: var(--shadow);
  transition: transform 0.1s, box-shadow 0.15s;
}
.primary-btn:hover { transform: translateY(-1px); box-shadow: 0 4px 12px rgba(90,53,8,0.25); }
.primary-btn:active { transform: translateY(0); }

/* --- Autocomplete --- */
.form-grid label, .couple-form fieldset label { position: relative; }
.autocomplete {
  position: absolute; top: 100%; left: 0; right: 0;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 0 0 6px 6px; z-index: 10;
  max-height: 240px; overflow-y: auto;
  box-shadow: 0 4px 12px rgba(0,0,0,0.12);
  display: none;
}
.autocomplete-item {
  padding: 7px 10px; cursor: pointer; font-size: 13px;
  border-bottom: 1px solid #f0e6cc;
}
.autocomplete-item:hover { background: #f8efd6; }
.autocomplete-item:last-child { border-bottom: 0; }

/* --- Couple form --- */
.couple-form {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
}
.couple-form fieldset {
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 14px 16px;
  background: #fffaf0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.couple-form legend {
  padding: 0 8px; font-weight: 600; color: var(--bronze-dk); font-size: 15px;
}
.couple-form .span2 { grid-column: span 2; }

/* --- Meta lines --- */
.meta {
  display: flex; flex-wrap: wrap; gap: 8px 18px;
  margin-top: 8px;
  font-size: 14px; color: var(--bronze-dk);
}
.meta span { background: #f6ecd2; padding: 4px 10px; border-radius: 4px; }
.meta b { color: var(--bronze-dk); }
.muted { color: var(--muted); font-size: 13px; }

/* --- Charts row --- */
.charts-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: 18px;
  margin-bottom: 18px;
}
.chart-box {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 8px; padding: 16px; box-shadow: var(--shadow);
  text-align: center;
}
.chart-box h3 { text-align: center; margin-bottom: 12px; }
.rasi-chart { display: block; margin: 0 auto; max-width: 100%; height: auto; }

/* --- Educational chart row: chart LEFT, explanation RIGHT --- */
.chart-edu-row {
  display: grid; grid-template-columns: 380px 1fr; gap: 22px;
  align-items: start; margin-bottom: 22px;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 8px; padding: 18px; box-shadow: var(--shadow);
}
.chart-edu-chart { text-align: center; position: sticky; top: 12px; align-self: start; }
.chart-edu-chart h3 { margin-bottom: 12px; font-size: 16px; }
.chart-edu-explain h4 {
  margin: 2px 0 12px; font-size: 16px; color: var(--accent);
  border-bottom: 2px solid var(--border); padding-bottom: 6px;
}
.ce-intro {
  font-size: 14px; line-height: 1.85; margin-bottom: 14px;
  background: rgba(122,74,20,0.06); border-left: 3px solid var(--accent);
  padding: 10px 12px; border-radius: 0 6px 6px 0;
}
.ce-p { font-size: 13.5px; line-height: 1.8; margin: 6px 0 4px; }
/* section sub-heading */
.ce-sec {
  margin: 20px 0 10px; font-size: 14.5px; font-weight: 700; color: var(--accent);
  letter-spacing: .2px; border-bottom: 1px dashed var(--border); padding-bottom: 4px;
}
/* sign-occupancy grid */
.ce-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
.ce-cell {
  border: 1px solid var(--border); border-radius: 7px; padding: 9px 11px;
  background: rgba(0,0,0,0.015);
}
.ce-cell.empty { opacity: .6; }
.ce-cell.lagna { border-color: #b30000; background: rgba(179,0,0,0.05); }
.ce-cell-head { font-weight: 700; font-size: 13.5px; margin-bottom: 4px; }
.ce-cell-planets { font-size: 12.5px; color: #5a3a14; margin-bottom: 4px; }
.ce-none { font-size: 12px; font-style: italic; color: #999; }
.ce-tag {
  display: inline-block; font-size: 10.5px; font-weight: 700; padding: 1px 7px;
  border-radius: 10px; background: var(--accent); color: #fff; vertical-align: middle;
}
.ce-tag.good { background: #2e7d32; }
.ce-tag.bad  { background: var(--red); }
.ce-note { font-size: 12.5px; color: var(--muted); margin: 4px 0 10px; line-height: 1.6; }
.ce-pline { font-size: 13px; line-height: 1.65; padding: 5px 0; border-bottom: 1px dotted var(--border); }
.ce-pline:last-child { border-bottom: none; }
.ce-pline.good { color: #2a1d0c; }
.ce-pline.bad  { color: #7a1d10; }
.ce-house-area { font-size: 12.5px; color: var(--muted); margin-top: 2px; }
/* house & yoga blocks */
.ce-house {
  border-left: 3px solid var(--accent); padding: 7px 12px; margin-bottom: 9px;
  background: rgba(0,0,0,0.02); border-radius: 0 6px 6px 0;
}
.ce-house-head { font-weight: 700; font-size: 13.5px; margin-bottom: 3px; }
.ce-house-head .ce-sub { font-weight: 400; color: #777; font-size: 12.5px; }
/* bullet lists */
.ce-ul { margin: 2px 0 0; padding-left: 18px; }
.ce-ul li { font-size: 12.8px; line-height: 1.6; }
/* simple label/text row (D9 planet list) */
.ce-find {
  display: grid; grid-template-columns: 150px 1fr; gap: 12px;
  font-size: 13px; line-height: 1.65; padding: 6px 10px;
  border-radius: 6px; background: rgba(0,0,0,0.02); margin-bottom: 5px;
}
.ce-find .ce-label { font-weight: 700; color: var(--accent); }
@media (max-width: 760px) {
  .chart-edu-row { grid-template-columns: 1fr; }
  .chart-edu-chart { position: static; }
  .ce-grid { grid-template-columns: 1fr; }
  .ce-find { grid-template-columns: 1fr; gap: 2px; }
}

/* --- Inline detailed report (rendered in isolated iframe) --- */
#inline-report-wrap {
  margin: 18px 0; border: 1px solid var(--border);
  border-radius: 8px; overflow: hidden; box-shadow: var(--shadow);
  background: #f0e8d0;
}
.inline-report-bar {
  display: flex; justify-content: space-between; align-items: center;
  gap: 12px; flex-wrap: wrap;
  background: var(--bronze); color: #fff;
  padding: 10px 14px; font-size: 13.5px;
}
.inline-report-bar .primary-btn { padding: 6px 14px; font-size: 13px; margin-left: 8px; }
.report-inline-title { margin: 4px 0 0; color: var(--bronze-dk); }
#inline-report-frame {
  display: block; width: 100%; min-height: 400px; border: 0; background: #f0e8d0;
}
.print-row-bottom { margin: 14px 0 30px; text-align: center; }
.print-row-bottom .print-btn { font-size: 16px; padding: 12px 28px; }
@media print {
  /* When the main page prints, keep the inline report visible if open */
  #inline-report-wrap .inline-report-bar { display: none; }
}

/* --- Data tables --- */
.data-table {
  width: 100%; border-collapse: collapse; font-size: 14px;
  margin-top: 8px;
}
.data-table th, .data-table td {
  padding: 8px 10px;
  border-bottom: 1px solid #ead7a8;
  text-align: left;
}
.data-table thead th {
  background: #f1e2b6; color: var(--bronze-dk);
  font-weight: 600; font-size: 13px;
  border-bottom: 2px solid var(--border);
}
.data-table tbody tr:hover { background: #fdf6e3; }
.data-table tr.clickable { cursor: pointer; }
.data-table .retro { color: var(--red); font-weight: 600; }
.data-table .ok { color: var(--green); font-weight: 600; }
.data-table .fail { color: var(--red); font-weight: 600; }
.data-table tr.bad td { background: #fbe6e6; }
.sub-table { margin: 4px 0 8px; }
.sub-table thead th { background: #f6ecd2; }
.bhukti-row td { padding: 0 14px 8px !important; background: #fffaee; }

.current-dasha {
  background: linear-gradient(90deg, #f8e9b8, #fff3cc);
  border-left: 4px solid var(--gold);
  padding: 10px 14px;
  border-radius: 4px;
  margin-top: 12px;
  font-size: 15px;
}

/* --- Porutham --- */
.couple-meta { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 12px; }
.couple-meta > div { background: #f8efd6; padding: 10px 14px; border-radius: 6px; }
.score { font-size: 20px; color: var(--bronze-dk); }
.score b { color: var(--gold); font-size: 26px; }
.warning {
  background: #fde8c5; border-left: 4px solid #c87a00;
  padding: 8px 14px; border-radius: 4px;
}

/* --- Panchangam grid --- */
.tamil-date {
  font-size: 16px; color: var(--bronze-dk);
  background: #f6ecd2; padding: 10px 14px; border-radius: 6px;
  display: inline-block; margin-bottom: 14px;
}
.panch-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.panch-grid > div {
  background: #fffaf0; border: 1px solid #ead7a8;
  border-radius: 6px; padding: 10px 14px;
  display: flex; flex-direction: column;
}
.panch-grid span { font-size: 12px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.5px; }
.panch-grid b { font-size: 18px; color: var(--bronze-dk); margin: 2px 0; }
.panch-grid small { font-size: 11px; color: var(--muted); }

/* --- Saved cards --- */
.saved-card {
  display: flex; justify-content: space-between; align-items: center;
  background: #fffaf0; border: 1px solid var(--border); border-radius: 6px;
  padding: 12px 16px; margin-bottom: 8px;
}
.saved-card h4 { margin: 0; }
.saved-card p { margin: 2px 0 0; font-size: 13px; color: var(--muted); }
.saved-actions { display: flex; gap: 8px; }
.saved-actions button {
  padding: 6px 12px; border: 1px solid var(--border);
  background: #fff8e0; color: var(--bronze-dk);
  border-radius: 4px; cursor: pointer; font-family: inherit; font-size: 13px;
}
.saved-actions .btn-open { background: var(--bronze); color: #fff8e0; border-color: var(--bronze-dk); }
.saved-actions button:hover { transform: translateY(-1px); }

/* --- About --- */
.about p, .about li { color: var(--ink); font-size: 14px; }
.about ul { padding-left: 22px; }
.about h3 { margin-top: 18px; }

/* --- Footer --- */
footer {
  text-align: center; padding: 14px;
  color: var(--muted); font-size: 12px;
  border-top: 1px solid var(--border);
  background: #f4e9cb;
}

/* --- Responsive --- */
@media (max-width: 900px) {
  .form-grid { grid-template-columns: repeat(2, 1fr); }
  .couple-form, .charts-row, .couple-meta { grid-template-columns: 1fr; }
  .panch-grid { grid-template-columns: repeat(2, 1fr); }
  .brand h1 { font-size: 22px; }
}
@media (max-width: 600px) {
  .form-grid { grid-template-columns: 1fr; }
  .panch-grid { grid-template-columns: 1fr; }
  .tabs { overflow-x: auto; flex-wrap: nowrap; }
  .tab { padding: 10px 14px; font-size: 14px; white-space: nowrap; }
}

/* --- Dosha grid --- */
.dosha-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.dosha-item {
  border: 1px solid var(--border); border-radius: 6px;
  padding: 12px 14px; background: #fffaf0;
}
.dosha-item.good { border-left: 4px solid var(--green); background: #f0f7eb; }
.dosha-item.mild { border-left: 4px solid #c87a00; background: #fdf4dd; }
.dosha-item.bad  { border-left: 4px solid var(--red); background: #fde9e7; }
.dosha-item h4 { margin: 0 0 6px; color: var(--bronze-dk); }
.dosha-item small { display: block; color: var(--muted); margin-top: 6px; font-size: 12px; }
.dosha-item .cancel { color: var(--green); }

.dasha-effect {
  background: #f6ecd2; padding: 8px 12px;
  border-radius: 4px; margin-top: 8px; font-size: 14px;
}

.print-btn { display: block; margin: 20px auto; }
.print-row {
  display: flex; justify-content: center; gap: 12px;
  margin: 24px 0; flex-wrap: wrap;
}
.print-btn-detailed {
  background: linear-gradient(135deg, var(--bronze-dk), #6b4423) !important;
}

/* --- v4 Panchangam: daily flags, forecast, end times --- */
.karinaal-tag {
  display: inline-block; background: var(--red); color: white;
  padding: 3px 10px; border-radius: 12px; font-size: 14px;
  margin-left: 8px; vertical-align: middle;
}
.hijri-line {
  color: var(--muted); font-size: 13px; margin: 2px 0 8px;
  font-family: 'Inter', system-ui, sans-serif;
}
.special-yoga-banner {
  background: linear-gradient(90deg, #e6f5d0, #c8e6a0);
  border-left: 4px solid var(--green); padding: 10px 14px;
  margin: 12px 0; border-radius: 4px; color: #1a5d2e;
}
.end-time { color: var(--bronze-dk); font-style: italic; }

.flags-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 12px;
}
.flag-item {
  border: 1px solid var(--border); border-radius: 6px;
  padding: 12px 14px; background: #fffbf3;
}
.flag-item.bad { border-left: 4px solid var(--red); background: #fde9e7; }
.flag-item.mild { border-left: 4px solid #c87a00; background: #fdf4dd; }
.flag-item.neutral { border-left: 4px solid var(--border); }
.flag-item h4 { margin: 0 0 6px; color: var(--bronze-dk); }
.flag-item p { margin: 4px 0; font-size: 14px; }
.flag-item .parihar { background: #fff4cc; padding: 6px 10px; border-radius: 4px; margin-top: 6px; }

.rasi-forecast-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 8px;
}
.rasi-fc {
  border: 1px solid var(--border); border-radius: 6px;
  padding: 10px 12px; background: #fffbf3;
}
.rasi-fc.good { border-left: 4px solid var(--green); background: #f3f9ef; }
.rasi-fc.bad  { border-left: 4px solid var(--red); background: #fdf2f0; }
.rasi-fc.neutral { border-left: 4px solid var(--bronze); }
.rasi-fc-name { font-weight: 700; color: var(--bronze-dk); font-size: 15px; }
.rasi-fc-text { font-size: 13px; margin: 4px 0; }
.rasi-fc-house { font-size: 11px; color: var(--muted); }

.tara-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(125px, 1fr));
  gap: 6px;
}
.tara-item {
  border: 1px solid var(--border); border-radius: 4px;
  padding: 8px 10px; background: #fffbf3;
}
.tara-item.good { border-left: 3px solid var(--green); background: #f3f9ef; }
.tara-item.bad  { border-left: 3px solid var(--red); background: #fdf2f0; }
.tara-item.neutral { border-left: 3px solid var(--bronze); }
.tara-nak { font-weight: 600; color: var(--bronze-dk); font-size: 13px; }
.tara-name { font-size: 11px; color: var(--ink); }

.agni-flag {
  grid-column: 1 / -1;
  background: linear-gradient(90deg, #ffe0b3, #ffcc88);
  border-left: 4px solid var(--red);
  padding: 10px 14px;
  border-radius: 4px;
}
.agni-flag span { color: var(--red); font-weight: 600; }

/* --- Numerology --- */
.num-tabs {
  display: flex; gap: 6px; margin: 12px 0;
  border-bottom: 1px solid var(--border);
}
.num-tab {
  background: none; border: none; padding: 8px 16px;
  font-family: inherit; font-size: 14px; cursor: pointer;
  border-bottom: 2px solid transparent; color: var(--ink);
}
.num-tab.active {
  color: var(--bronze); border-bottom-color: var(--bronze);
  font-weight: 600;
}
.num-mode { margin-top: 8px; }

.num-card { padding-bottom: 20px; }
.num-summary {
  display: flex; align-items: center; gap: 20px;
  padding: 14px 18px; border-radius: 8px; margin: 14px 0;
}
.num-score-big { font-size: 48px; font-weight: 700; line-height: 1; }
.num-verdict { font-size: 18px; font-weight: 500; }
.num-summary.score-excellent { background: #d4eecc; color: #1a5d2e; }
.num-summary.score-good      { background: #e0f0d6; color: #2d6a3a; }
.num-summary.score-moderate  { background: #fdf4dd; color: #7a5400; }
.num-summary.score-poor      { background: #fde4dc; color: #8b2e16; }
.num-summary.score-avoid     { background: var(--red); color: white; }

.num-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px; margin: 12px 0;
}
.num-box {
  border: 1px solid var(--border); border-radius: 6px;
  padding: 14px; background: #fffbf3;
}
.num-box h4 { margin: 0 0 6px; color: var(--bronze-dk); }
.num-box .num-big {
  font-size: 38px; font-weight: 700; color: var(--bronze);
  line-height: 1; margin: 6px 0;
}
.num-box .num-medium {
  font-size: 22px; font-weight: 600; color: var(--bronze);
  margin: 6px 0;
}
.num-box.excellent { border-left: 4px solid #2d8a3e; background: #f3f9ef; }
.num-box.good      { border-left: 4px solid var(--green); background: #f6fbf2; }
.num-box.moderate  { border-left: 4px solid #c87a00; background: #fdf8e8; }
.num-box.avoid     { border-left: 4px solid var(--red); background: #fde9e7; }
.letter-breakdown {
  font-family: 'Inter', monospace; font-size: 14px;
  background: #f6ecd2; padding: 6px 10px; border-radius: 4px; margin-top: 8px;
}
.letter-breakdown sub { font-size: 11px; color: var(--red); }

.verdict-reasons {
  list-style: none; padding: 0; margin: 8px 0;
  background: #fffbf3; border-left: 3px solid var(--bronze);
  padding: 10px 14px; border-radius: 4px;
}
.verdict-reasons li { padding: 3px 0; font-size: 14px; }

.lucky-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 6px;
}
.lucky-grid > div {
  padding: 6px 0; font-size: 14px;
}

.name-idea { padding: 14px; }
.idea-head { display: flex; justify-content: space-between; align-items: center; }
.idea-head h3 { margin: 0; color: var(--bronze-dk); }
.idea-head h3 small { color: var(--muted); font-weight: normal; font-size: 13px; }

.alt-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 8px;
}
.alt-spell {
  border: 1px solid var(--border); border-radius: 6px;
  padding: 10px 12px; background: #fffbf3; position: relative;
}
.alt-spell b { display: block; color: var(--bronze-dk); font-size: 16px; }
.alt-spell span { display: block; font-size: 12px; color: var(--muted); }
.alt-spell .alt-score {
  position: absolute; top: 8px; right: 8px;
  background: var(--green); color: white;
  padding: 2px 8px; border-radius: 10px; font-size: 12px; font-weight: 700;
}

/* --- SL TZ warning banner --- */
.tz-warning-banner {
  background: #fde9b8; border-left: 4px solid #c87a00;
  padding: 12px 18px; border-radius: 6px;
  font-size: 14px; color: #7a5400; margin-bottom: 16px;
}

/* --- Gemstones --- */
.gem-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 14px; margin: 12px 0;
}
.gem-card {
  border: 1px solid var(--border); border-radius: 8px;
  padding: 14px 16px; background: #fffbf3; position: relative;
}
.gem-card.gem-primary    { border-left: 4px solid var(--green); background: #f6fbf2; }
.gem-card.gem-supportive { border-left: 4px solid var(--bronze); }
.gem-card.gem-avoid      { border-left: 4px solid var(--red); background: #fde9e7; }
.gem-tag {
  display: inline-block; padding: 3px 10px; border-radius: 10px;
  font-size: 11px; font-weight: 600; margin-bottom: 6px;
  background: var(--green); color: white;
}
.gem-tag.tag-supportive { background: var(--bronze); }
.gem-tag.tag-avoid { background: var(--red); }
.gem-card h4 { color: var(--bronze-dk); margin: 4px 0 6px; font-size: 16px; }
.gem-spec { padding-left: 18px; font-size: 13px; }
.gem-spec li { padding: 3px 0; }
.gem-notes {
  background: #faf3e0; border-left: 3px solid var(--bronze);
  padding: 10px 14px; border-radius: 4px; margin-top: 12px;
}
.gem-notes h4 { margin: 0 0 8px; color: var(--bronze-dk); }

/* --- Rasi Palan tab --- */
.rp-tabs {
  display: flex; flex-wrap: wrap; gap: 6px; margin: 12px 0;
  border-bottom: 1px solid var(--border);
}
.rp-tab {
  background: none; border: none; padding: 8px 14px;
  font-family: inherit; font-size: 14px; cursor: pointer;
  border-bottom: 2px solid transparent; color: var(--ink);
}
.rp-tab.active {
  color: var(--bronze); border-bottom-color: var(--bronze); font-weight: 600;
}
.rp-mode { margin-top: 10px; }

/* --- Porutham expandable rows --- */
.porutham-table .por-row:hover { background: rgba(122,74,20,0.05); }
.por-caret { color: var(--bronze); font-size: 12px; transition: transform .2s; display: inline-block; }
.por-caret.open { transform: rotate(180deg); }
.por-detail-box {
  background: rgba(122,74,20,0.05); border-left: 3px solid var(--border);
  padding: 10px 14px; border-radius: 0 6px 6px 0; margin: 2px 0;
}
.por-detail-box p { margin: 4px 0; font-size: 13.5px; line-height: 1.8; }
.por-detail-box .por-good { color: #2e7d32; font-weight: 500; }
.por-detail-box .por-bad  { color: #8a5a00; font-weight: 500; }

/* --- "More Predictions" sub-tabs (Dreams / Lizard) --- */
.op-tabs {
  display: flex; flex-wrap: wrap; gap: 6px; margin: 12px 0;
  border-bottom: 1px solid var(--border);
}
.op-tab {
  background: none; border: none; padding: 8px 16px;
  font-family: inherit; font-size: 14px; cursor: pointer;
  border-bottom: 2px solid transparent; color: var(--ink);
}
.op-tab.active { color: var(--bronze); border-bottom-color: var(--bronze); font-weight: 600; }
.op-mode { margin-top: 10px; }

/* --- Peyarchi (Transits) tab --- */
.py-rasi-select { display: flex; flex-wrap: wrap; gap: 6px; margin: 10px 0 14px; }
.py-rasi-btn {
  background: var(--bg-card); border: 1px solid var(--border);
  padding: 6px 12px; border-radius: 16px; cursor: pointer;
  font-family: inherit; font-size: 13px; color: var(--ink);
}
.py-rasi-btn:hover { border-color: var(--bronze); }
.py-rasi-btn.active { background: var(--bronze); color: #fff; border-color: var(--bronze); font-weight: 600; }
.py-subtabs {
  display: flex; flex-wrap: wrap; gap: 6px; margin: 6px 0 4px;
  border-bottom: 1px solid var(--border);
}
.py-tab {
  background: none; border: none; padding: 8px 16px;
  font-family: inherit; font-size: 14px; cursor: pointer;
  border-bottom: 2px solid transparent; color: var(--ink);
}
.py-tab.active { color: var(--bronze); border-bottom-color: var(--bronze); font-weight: 600; }

/* Deep honest report */
.py-report {
  background: var(--bg-card); border: 1px solid var(--border);
  border-left: 5px solid var(--bronze); border-radius: 8px;
  padding: 8px 22px 22px; margin-top: 14px; box-shadow: var(--shadow);
  max-width: 820px;
}
.py-report.rating-bad        { border-left-color: var(--red); }
.py-report.rating-excellent  { border-left-color: #2d8a3e; }
.py-report.rating-good       { border-left-color: var(--green); }
.py-report.rating-neutral    { border-left-color: #c87a00; }
.py-report-top { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 8px; }
.py-report-top h3 { margin: 14px 0 6px; color: var(--bronze-dk); }
.py-rsec { margin: 18px 0; padding-top: 6px; }
.py-rsec h4 {
  font-size: 16px; color: var(--bronze); margin: 0 0 8px;
  border-bottom: 1px dashed var(--border); padding-bottom: 6px;
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
.py-rsec p { font-size: 14.5px; line-height: 1.9; margin: 8px 0; text-align: justify; }
.py-rsec.lead { background: rgba(122,74,20,0.05); border-radius: 6px; padding: 12px 16px; }
.py-rsec.lead h4 { border-bottom: none; }
.py-rsec.muted-sec { opacity: .85; font-size: 13px; }
.py-rsec.muted-sec p { font-size: 13px; font-style: italic; color: var(--muted); }
.py-meta { font-size: 12.5px; color: var(--muted); margin: 2px 0 8px; font-style: italic; }
@media (max-width: 600px) { .py-report { padding: 8px 14px 16px; } }

.rasi-list {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px; margin-top: 12px;
}
.rasi-card {
  border: 1px solid var(--border); border-radius: 6px;
  padding: 12px 14px; background: #fffbf3;
}
.rasi-card.good     { border-left: 4px solid var(--green); background: #f6fbf2; }
.rasi-card.bad      { border-left: 4px solid var(--red); background: #fde9e7; }
.rasi-card.neutral  { border-left: 4px solid var(--bronze); }
.rasi-card h4 { margin: 0 0 4px; color: var(--bronze-dk); font-size: 17px; }
.rasi-card small { display: block; font-size: 12px; color: var(--muted); margin-top: 4px; }
.rasi-card small.bad { color: var(--red); font-weight: 600; }

/* 🎯 Chart-based personal Rasi Palan card */
.rp-personal {
  border: 2px solid var(--bronze);
  border-left: 6px solid var(--bronze-dk);
  background: linear-gradient(180deg, #fffaf0 0%, #fdf4e3 100%);
  margin-bottom: 16px; box-shadow: 0 2px 10px rgba(139,90,43,0.12);
}
.rp-personal.good { border-left-color: var(--green); }
.rp-personal.hint { border-style: dashed; background: #fffdf8; }
.rp-personal h3 { color: var(--bronze-dk); margin: 0 0 8px; }
.rp-personal .rp-period { font-size: 14px; color: var(--muted); font-weight: 600; }
.rp-personal .rp-dasha {
  background: #fff5e0; border-radius: 6px; padding: 10px 12px;
  margin: 8px 0; font-size: 14px; line-height: 1.7;
}
.rp-personal .rp-personal-summary { font-size: 15px; line-height: 1.8; }

.rasi-finder-result {
  display: flex; align-items: center; gap: 24px;
  padding: 14px; background: #faf3e0; border-radius: 6px; margin: 12px 0;
}
.rf-rasi {
  font-size: 38px; font-weight: 700; color: var(--bronze-dk);
}

.palli-result.good { border-left: 4px solid var(--green); background: #f6fbf2; }
.palli-result.bad  { border-left: 4px solid var(--red); background: #fde9e7; }
.palli-palan { font-size: 16px; margin: 8px 0; }
.palli-parihar {
  background: #fff4cc; padding: 10px 14px; border-radius: 4px;
  font-size: 13px; margin-top: 10px;
}

/* --- Deep Peyarchi accordion --- */
.peyarchi-header { margin-bottom: 14px; }
.peyarchi-header h3 { margin: 0 0 4px; color: var(--bronze-dk); }
.peyarchi-list { display: flex; flex-direction: column; gap: 8px; }
.peyarchi-item {
  border: 1px solid var(--border); border-radius: 6px; overflow: hidden;
  background: #fffbf3;
}
.peyarchi-item.rating-excellent { border-left: 4px solid #2d8a3e; }
.peyarchi-item.rating-good      { border-left: 4px solid var(--green); }
.peyarchi-item.rating-neutral   { border-left: 4px solid var(--bronze); }
.peyarchi-item.rating-bad       { border-left: 4px solid var(--red); }
.peyarchi-head {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 14px; cursor: pointer; user-select: none;
}
.peyarchi-head:hover { background: #f6ecd2; }
.peyarchi-title { flex: 1; }
.peyarchi-title b { color: var(--bronze-dk); font-size: 16px; }
.peyarchi-title small { display: block; color: var(--muted); font-size: 12px; }
.peyarchi-phase {
  display: inline-block; font-size: 11px; color: var(--red);
  margin-top: 2px;
}
.peyarchi-rating {
  padding: 3px 12px; border-radius: 12px; font-size: 12px; font-weight: 600;
  white-space: nowrap;
}
.peyarchi-rating.rating-excellent { background: #2d8a3e; color: #fff; }
.peyarchi-rating.rating-good      { background: var(--green); color: #fff; }
.peyarchi-rating.rating-neutral   { background: #c87a00; color: #fff; }
.peyarchi-rating.rating-bad       { background: var(--red); color: #fff; }
.peyarchi-arrow { transition: transform .2s; color: var(--muted); }
.peyarchi-item.open .peyarchi-arrow { transform: rotate(180deg); }
.peyarchi-body {
  display: none; padding: 0 14px 12px;
  border-top: 1px solid var(--border);
}
.peyarchi-item.open .peyarchi-body { display: block; }
.peyarchi-section { margin-top: 10px; }
.peyarchi-section h4 {
  margin: 0 0 3px; color: var(--bronze); font-size: 13px;
  border-bottom: 1px dotted var(--border-soft); padding-bottom: 2px;
}
.peyarchi-section p { margin: 0; font-size: 14px; line-height: 1.65; }

/* --- Kanavu Palan --- */
.kanavu-cats { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 12px; }
.kanavu-cat-chip {
  background: #fffbf3; border: 1px solid var(--border); border-radius: 50px;
  padding: 6px 14px; font-family: inherit; font-size: 13px; cursor: pointer;
  color: var(--ink); transition: background .2s, border-color .2s;
}
.kanavu-cat-chip:hover { background: #f6ecd2; }
.kanavu-cat-chip.active { background: var(--bronze); color: #fff; border-color: var(--bronze); }
.kanavu-list {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 12px;
}
.kanavu-item {
  border: 1px solid var(--border); border-radius: 6px; padding: 12px 14px;
  background: #fffbf3;
}
.kanavu-item.good    { border-left: 4px solid var(--green); background: #f6fbf2; }
.kanavu-item.bad     { border-left: 4px solid var(--red); background: #fdf2f0; }
.kanavu-item.neutral { border-left: 4px solid var(--bronze); }
.kanavu-item-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 6px; }
.kanavu-kw { font-weight: 700; color: var(--bronze-dk); font-size: 16px; }
.kanavu-omen { font-size: 11px; font-weight: 600; padding: 2px 8px; border-radius: 10px; }
.kanavu-omen.good { background: var(--green); color: #fff; }
.kanavu-omen.bad  { background: var(--red); color: #fff; }
.kanavu-omen.neutral { background: #c87a00; color: #fff; }
.kanavu-item p { margin: 4px 0; font-size: 14px; line-height: 1.6; }

/* --- Validation result --- */
.val-result {
  background: #fffbf3; border: 1px solid var(--border);
  border-radius: 6px; padding: 14px 18px; margin-top: 12px;
}
.val-result h4 { color: var(--bronze-dk); margin: 8px 0; }

/* --- Daily Thirukkural card --- */
.kural-card {
  background: linear-gradient(135deg, #faf3e0, #f3e6c8) !important;
  border-left: 4px solid var(--bronze) !important;
}
.kural-card h3 { color: var(--bronze-dk); }
.kural-verse {
  font-family: 'Tiro Tamil', 'Noto Sans Tamil', serif;
  font-size: 19px; line-height: 1.8;
  background: rgba(255,255,255,0.5);
  padding: 14px 18px; margin: 10px 0;
  border-radius: 6px; text-align: center;
}
.kural-line { font-weight: 500; color: var(--ink); }
.kural-meaning { margin: 8px 0; font-size: 15px; }
.kural-en { font-size: 13px; }

/* --- Ashtakavarga --- */
.av-sarva {
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 6px; margin: 10px 0;
}
@media (max-width: 720px) { .av-sarva { grid-template-columns: repeat(3, 1fr); } }
.av-cell {
  border: 1px solid var(--border); border-radius: 6px;
  padding: 8px 10px; text-align: center; background: #fffbf3;
}
.av-cell.excellent { border-left: 4px solid #2d8a3e; background: #f3f9ef; }
.av-cell.good      { border-left: 4px solid var(--green); background: #f6fbf2; }
.av-cell.neutral   { border-left: 4px solid var(--bronze); }
.av-cell.moderate  { border-left: 4px solid #c87a00; background: #fdf8e8; }
.av-cell.bad       { border-left: 4px solid var(--red); background: #fdf2f0; }
.av-rasi { font-size: 12px; color: var(--muted); }
.av-bindu { font-size: 24px; font-weight: 700; color: var(--bronze-dk); line-height: 1; margin: 4px 0; }
.av-strength { font-size: 11px; }
.av-bav { font-size: 12px; }
.av-bav th, .av-bav td { padding: 4px 8px; text-align: center; }
.av-bav td:first-child { text-align: left; }
.av-insights {
  background: #fffbf3; border-left: 3px solid var(--bronze);
  padding: 10px 14px; border-radius: 4px; margin-top: 10px;
}
.av-insights p { margin: 4px 0; font-size: 14px; }

/* --- Varga (divisional) mini-charts --- */
.varga-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
}
.varga-mini h4 {
  margin: 0 0 4px; color: var(--bronze-dk); font-size: 14px;
}
.varga-mini .muted { font-size: 11px; margin: 0 0 6px; }
.varga-chart {
  display: grid; grid-template-columns: repeat(4, 1fr);
  border: 2px solid var(--bronze); aspect-ratio: 1;
  font-size: 11px;
}
.varga-cell {
  border: 1px solid var(--border-soft); padding: 4px;
  display: flex; flex-direction: column;
  min-height: 0;
}
.varga-cell small { font-size: 9px; color: var(--muted); }
.varga-cell span { font-weight: 600; font-size: 11px; }
.varga-cell.empty { background: #faf3e0; }
.varga-cell.lagna { background: #fff4cc; }

/* --- Upagrahas --- */
/* uses default data-table styles */

/* --- Pariharam --- */
.pariharam-list { display: grid; gap: 12px; }
.pariharam-item {
  border: 1px solid var(--border); border-radius: 6px;
  padding: 14px 16px; background: #fffbf3;
}
.pariharam-item.bad { border-left: 4px solid var(--red); background: #fdf2f0; }
.pariharam-item.moderate { border-left: 4px solid #c87a00; background: #fdf8e8; }
.pariharam-item.good { border-left: 4px solid var(--green); background: #f6fbf2; }
.ph-head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 6px;
}
.ph-head h4 { margin: 0; color: var(--bronze-dk); }
.ph-severity {
  padding: 3px 10px; border-radius: 10px;
  font-size: 12px; font-weight: 600;
}
.ph-severity.bad { background: var(--red); color: white; }
.ph-severity.moderate { background: #c87a00; color: white; }
.ph-severity.good { background: var(--green); color: white; }
.ph-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 10px; font-size: 13px; margin-top: 8px;
}
.ph-grid > div {
  background: rgba(255,255,255,0.5); padding: 8px 10px; border-radius: 4px;
}
.ph-grid > div.span2 { grid-column: span 2; }
.ph-grid small { color: var(--muted); }

/* --- Yogas --- */
.yoga-list { display: grid; gap: 10px; }
.yoga-item {
  border: 1px solid var(--border); border-radius: 6px;
  padding: 12px 16px; background: #fffbf3;
}
.yoga-item.excellent { border-left: 4px solid #2d8a3e; background: #f3f9ef; }
.yoga-item.good      { border-left: 4px solid var(--green); background: #f6fbf2; }
.yoga-item.moderate  { border-left: 4px solid #c87a00; background: #fdf8e8; }
.yoga-item.bad       { border-left: 4px solid var(--red); background: #fde9e7; }
.yoga-head {
  display: flex; justify-content: space-between; align-items: center;
  gap: 10px; margin-bottom: 6px;
}
.yoga-head h4 {
  margin: 0; color: var(--bronze-dk); font-size: 17px;
}
.yoga-head h4 small {
  font-weight: 400; color: var(--muted); font-size: 13px; margin-left: 6px;
}
.yoga-quality-tag {
  padding: 3px 10px; border-radius: 10px;
  font-size: 12px; font-weight: 600; white-space: nowrap;
}
.yoga-quality-tag.excellent { background: #2d8a3e; color: white; }
.yoga-quality-tag.good      { background: var(--green); color: white; }
.yoga-quality-tag.moderate  { background: #c87a00; color: white; }
.yoga-quality-tag.bad       { background: var(--red); color: white; }
.yoga-planets {
  font-size: 13px; color: var(--ink); margin: 4px 0;
}

/* Hint text near card titles */
.card-hint { color: var(--muted); font-size: 12px; font-weight: 400; }

/* --- Tooltips (hover/tap explanations) --- */
.tip {
  position: relative;
  cursor: help;
  border-bottom: 1px dotted var(--bronze);
  display: inline-block;
}
.tip::after {
  content: attr(data-tip);
  position: absolute;
  bottom: calc(100% + 10px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--ink);
  color: white;
  padding: 10px 14px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 400;
  line-height: 1.6;
  width: 320px;
  max-width: 92vw;
  box-shadow: 0 6px 20px rgba(0,0,0,0.25);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s, transform 0.2s;
  z-index: 100;
  white-space: normal;
  text-align: left;
}
.tip::before {
  content: '';
  position: absolute;
  bottom: calc(100% + 4px);
  left: 50%;
  transform: translateX(-50%);
  border: 6px solid transparent;
  border-top-color: var(--ink);
  opacity: 0;
  transition: opacity 0.2s;
  z-index: 101;
}
.tip:hover::after, .tip:hover::before,
.tip.show::after, .tip.show::before {
  opacity: 1;
}
.tip:hover::after, .tip.show::after {
  transform: translateX(-50%) translateY(-2px);
}
/* When tooltip is near the right edge — flip to the left */
.tip.tip-left::after { left: auto; right: 0; transform: translateX(0); }
.tip.tip-left:hover::after { transform: translateX(0) translateY(-2px); }

/* Inline question-mark badge next to terms */
.tip-badge {
  display: inline-block;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--bronze);
  color: white;
  text-align: center;
  font-size: 10px;
  line-height: 14px;
  font-weight: 700;
  margin-left: 4px;
  cursor: help;
  vertical-align: super;
  position: relative;
  font-family: 'Inter', sans-serif;
}
.tip-badge::after { content: '?'; }

/* Visual hint banner shown on first visit */
.tooltip-hint {
  background: linear-gradient(90deg, #e0f0d6, #c8e6a0);
  border-left: 4px solid var(--green);
  padding: 8px 14px;
  margin: 8px 0;
  border-radius: 4px;
  font-size: 13px;
  color: #1a5d2e;
}

/* --- Panchangam enhancements --- */
.festival-banner {
  background: linear-gradient(90deg, #fff4cc, #fde9b8);
  border-left: 4px solid var(--bronze);
  padding: 10px 14px;
  margin: 12px 0;
  border-radius: 4px;
  color: var(--bronze-dk);
  font-weight: 500;
}
.panch-grid small.good { color: var(--green); }
.panch-grid small.bad  { color: var(--red); }
.panch-grid small.neutral { color: var(--muted); }
.aus-table tr.good td { background: #f0f7eb; }
.data-table tr.good td { background: #f6fbf2; }
.data-table tr.bad td  { background: #fdf2f0; }
.data-table tr.neutral td { background: #fafaf6; }

.chog-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.chog-grid h4 { margin: 0 0 8px; color: var(--bronze-dk); }
@media (max-width: 720px) { .chog-grid { grid-template-columns: 1fr; } }

.collapsible details summary {
  cursor: pointer; padding: 6px 0; color: var(--bronze-dk); font-weight: 500;
}

/* --- Muhurtham finder --- */
.muh-result { border-left: 4px solid var(--border); }
.muh-result.excellent { border-left-color: #2d8a3e; background: #f3f9ef; }
.muh-result.good      { border-left-color: var(--green); background: #f6fbf2; }
.muh-result.moderate  { border-left-color: #c87a00; background: #fdf8e8; }
.muh-result.poor      { border-left-color: var(--red); }
.muh-head {
  display: flex; justify-content: space-between; align-items: center; gap: 12px;
}
.muh-head h3 { margin: 0; color: var(--bronze-dk); }
.muh-head h3 small { font-weight: normal; color: var(--muted); font-size: 14px; }
.muh-score {
  display: flex; flex-direction: column; align-items: center;
  padding: 8px 14px; border-radius: 8px; min-width: 80px;
}
.score-num { font-size: 26px; font-weight: 700; line-height: 1; }
.score-label { font-size: 11px; letter-spacing: 1px; margin-top: 2px; }
.score-excellent { background: #2d8a3e; color: white; }
.score-good      { background: var(--green); color: white; }
.score-moderate  { background: #c87a00; color: white; }
.score-poor      { background: #999; color: white; }
.muh-summary { margin: 10px 0; color: var(--ink); }
.muh-reasons { list-style: none; padding: 0; margin: 8px 0; font-size: 13px; }
.muh-reasons li { padding: 3px 0; color: var(--ink); }
.muh-time {
  background: #fff8e0; padding: 8px 12px; border-radius: 4px;
  margin-top: 10px; font-size: 14px;
}

/* --- Print --- */
@media print {
  .app-header, .tabs, footer, .form-card, .print-btn { display: none; }
  body { background: white; font-size: 12px; }
  .card, .chart-box { box-shadow: none; border-color: #999; page-break-inside: avoid; }
  .charts-row { grid-template-columns: 1fr 1fr; }
  h2, h3 { color: #000 !important; }
  .data-table thead th { background: #eee !important; -webkit-print-color-adjust: exact; }
}

/* ====================== 👪 KUDUMBA JATHAGAM (Family) ====================== */
.btn-sm { padding: 6px 14px; border-radius: 6px; border: 1px solid var(--bronze-lt);
  background: var(--bronze); color: #fff; cursor: pointer; font-size: 13px; font-family: inherit; }
.btn-sm:hover { background: var(--bronze-dk); }
.btn-sm.ghost { background: #fff; color: var(--bronze); }
.btn-sm.danger { background: #fff; color: var(--red); border-color: var(--red); }
.fam-top { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; margin-top: 8px; }
.fam-top select { padding: 6px 10px; border-radius: 6px; border: 1px solid var(--bronze-lt); font-family: inherit; }
.fam-form { display: grid; grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); gap: 8px; align-items: center; }
.fam-form input, .fam-form select { padding: 7px 9px; border: 1px solid #d8c4a0; border-radius: 6px; font-family: inherit; font-size: 13px; }
.fam-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 12px; }
.fam-card { position: relative; border: 1px solid var(--border); border-left: 5px solid var(--bronze); border-radius: 8px;
  padding: 12px 14px; background: linear-gradient(180deg,#fffaf0,#fdf4e3); }
.fam-card-h { font-size: 16px; margin-bottom: 6px; }
.fam-card-h small { color: var(--muted); font-weight: 400; }
.fam-card-meta { display: flex; flex-direction: column; gap: 2px; font-size: 13px; }
.fam-today { margin-top: 8px; padding: 6px 8px; background: #fff5e0; border-radius: 5px; font-size: 13px; }
.fam-rm { position: absolute; top: 6px; right: 8px; border: 0; background: transparent; color: var(--red); font-size: 18px; cursor: pointer; line-height: 1; }
.fam-acc { display: flex; flex-direction: column; gap: 8px; }
.fam-item { border: 1px solid var(--border); border-radius: 8px; overflow: hidden; }
.fam-item-h { display: flex; align-items: center; gap: 8px; padding: 11px 14px; cursor: pointer; background: #fbf4e8; font-weight: 600; color: var(--bronze-dk); }
.fam-item-h:hover { background: #f6ead2; }
.fam-arrow { margin-left: auto; transition: transform .2s; }
.fam-item.open .fam-arrow { transform: rotate(180deg); }
.fam-item-b { display: none; padding: 12px 16px; }
.fam-item.open .fam-item-b { display: block; }
.fam-row { padding: 8px 0; border-top: 1px dashed #e4d4b4; }
.fam-row:first-child { border-top: 0; }
.fam-row-h { display: flex; align-items: center; gap: 8px; }
.fam-row p { margin: 4px 0; line-height: 1.7; }
.fam-verdict { font-weight: 600; color: var(--green); }
.fam-pct { display: inline-block; padding: 1px 9px; border-radius: 11px; font-size: 12px; font-weight: 700; color: #fff; }
.fam-pct.rating-excellent { background: #2d8a3e; }
.fam-pct.rating-good { background: var(--green); }
.fam-pct.rating-neutral { background: #c87a00; }
.fam-pct.rating-bad { background: var(--red); }
.fam-chip { display: inline-block; margin: 3px 4px 3px 0; padding: 2px 9px; border-radius: 11px; font-size: 12px; color: #fff; }
.fam-chip.rating-excellent { background: #2d8a3e; } .fam-chip.rating-good { background: var(--green); }
.fam-chip.rating-neutral { background: #c87a00; } .fam-chip.rating-bad { background: var(--red); }
.fam-fields { margin: 4px 0 4px 18px; } .fam-fields li { margin: 2px 0; }
.fam-bar { display: flex; align-items: center; gap: 8px; margin: 6px 0; font-size: 13px; }
.fam-bar span { width: 110px; } .fam-bar b { width: 42px; text-align: right; }
.fam-bar-t { flex: 1; height: 13px; background: #eee; border-radius: 7px; overflow: hidden; }
.fam-bar-t i { display: block; height: 13px; background: linear-gradient(90deg, var(--bronze-lt), var(--bronze)); }
.fam-actions { margin-top: 12px; }
.fam-ai .fam-chat { max-height: 320px; overflow-y: auto; display: flex; flex-direction: column; gap: 8px; padding: 8px 0; }
.fam-msg { max-width: 85%; padding: 8px 12px; border-radius: 12px; font-size: 14px; line-height: 1.6; white-space: normal; }
.fam-msg.user { align-self: flex-end; background: var(--bronze); color: #fff; border-bottom-right-radius: 3px; }
.fam-msg.ai { align-self: flex-start; background: #f3ead7; color: #2b2b2b; border-bottom-left-radius: 3px; }
.fam-ask { display: flex; gap: 8px; margin-top: 8px; }
.fam-ask input { flex: 1; padding: 9px 12px; border: 1px solid #d8c4a0; border-radius: 8px; font-family: inherit; }
.fam-suggest { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }
.fam-sg { padding: 5px 11px; border: 1px solid var(--bronze-lt); background: #fff; color: var(--bronze); border-radius: 14px; font-size: 12px; cursor: pointer; font-family: inherit; }
.fam-sg:hover { background: #fbf4e8; }
