html,body{background:var(--k-bg);color:var(--ink);}
/* SVG oktagramma uz tumša fona: tumšajā tēmā invertē VISU SVG sakni.
   (filtrs uz <g id="mat"> Chromium/Safari NERENDERĒJAS — uz saknes <svg> jā.)
   .dark-center (dzeltenā komforta zona + e1/e2) tiek PRETINVERTĒTA, lai paliek
   savās krāsās. Tā mazie melnie cipari/uzraksti kļūst gaiši un redzami. */
.matrix-svg { filter: invert(1) hue-rotate(180deg); }
.matrix-svg .dark-center { filter: invert(1) hue-rotate(180deg); }
:root[data-theme="light"] .matrix-svg,
:root[data-theme="light"] .matrix-svg .dark-center { filter: none; }


/* =====================================================================
   Likteņa matricas kalkulators — dizains 1:1 pēc paraugs.png
   Gaišā tēma (krēms/balts/indigo), kā blmatrica.lv references.
   ===================================================================== */

* { box-sizing: border-box; margin: 0; padding: 0; }

/* GIF kā caurspīdīgs fons VIRSŪ hero tekstam (maģijas efekts) */
.hero-gif-bg {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
  object-fit: cover;        /* aizpilda hero joslu pilnā platumā */
  opacity: 0.4;             /* caurspīdīgs (mobilais) */
  pointer-events: none;
  z-index: 2;               /* virs teksta */
}
@media (min-width: 769px) {
  .hero-gif-bg { opacity: 0.22; }   /* desktopā maigāks */
}

:root {
  --accent: #7c6cf0;       /* indigo akcents */
  --ink: #e6e8f0;
  --muted: #9aa0b0;
  --hero-bg: #1a1d27;      /* krēmkrāsas augšdaļa */
  --line: #2c3040;
  --cta-bg: #232733;
  --k-bg: #0f1117;
  --k-num: #2c3040;
}

/* ==== GAIŠĀ TĒMA (sinhronizēta ar vietnes data-theme) ==== */
:root[data-theme="light"] {
  --accent: #4841df;
  --ink: #1a1a1a;
  --muted: #555;
  --hero-bg: #eae6e0;
  --line: #000;
  --cta-bg: #e3e0db;
  --k-bg: #fff;
  --k-num: #000;
}


body {
  font-family: "Montserrat", -apple-system, Arial, sans-serif;
  background: var(--hero-bg);
  color: var(--ink);
  line-height: 1.5;
}

/* ---- Augšējā navigācija ---- */
.calc-topnav {
  background: var(--hero-bg);
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.8rem 2rem;
}
.calc-topnav .brand {
  width: 42px; height: 42px; border-radius: 50%;
  border: 1px solid var(--line); display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; color: var(--muted);
}
.calc-topnav .nav-right { display: flex; gap: 1.5rem; font-size: 0.9rem; }
.calc-topnav .nav-right a { color: var(--ink); text-decoration: none; }
.calc-topnav .nav-right a:hover { color: var(--accent); }

/* ---- Hero (virsraksts) — centrēts, fons 100% platuma, GIF virsū ---- */
.calc-hero {
  position: relative;
  overflow: hidden;
  background: var(--hero-bg);
  text-align: center;
  padding: 2rem 1.5rem 1rem;
}
.hero-text {
  position: relative;
  z-index: 1;              /* aiz GIF (GIF caurspīdīgs virsū) */
}
.calc-hero h1 {
  font-family: "Montserrat", -apple-system, Arial, sans-serif;
  font-size: 3.2rem;
  font-weight: 700;
  color: var(--accent);
  letter-spacing: 0.01em;
}
.calc-hero p { font-size: 1.05rem; color: var(--muted); margin-top: 0.6rem; }

/* ---- Galvenais konteiners (2 kolonnas) ---- */
.calc-main {
  max-width: 1180px;
  margin: 0 auto;
  padding: 1.2rem 1.5rem 2rem;
  display: flex;
  gap: 2.5rem;
  align-items: flex-start;
  justify-content: center;
}
.calc-left { flex: 0 0 auto; }
.calc-right { flex: 1; max-width: 480px; min-width: 340px; }

/* ---- Ievades lauki ---- */
.calc-inputs { margin-bottom: 1rem; }

/* Rāmīti ievades lauki (kā paraugā) */
.ci-box {
  width: 100%;
  border: 1.5px solid var(--line);
  border-radius: 8px;
  background: transparent;
  color: var(--ink);
  font-family: inherit;
  font-size: 1rem;
  font-weight: 600;
  padding: 0.7rem 0.9rem;
  outline: none;
  transition: border-color 0.15s;
}
.ci-box::placeholder { color: var(--muted); font-weight: 400; }
.ci-box:focus { border-color: var(--accent); }

.ci-field { margin-bottom: 0.7rem; }
.ci-row { display: flex; align-items: stretch; gap: 0.7rem; margin-bottom: 0.7rem; }
.ci-date { flex: 1; min-width: 0; }

/* Dzimuma pārslēgs S / V */
.gender-toggle {
  display: flex; flex-shrink: 0;
  border: 1.5px solid var(--accent);
  border-radius: 8px; overflow: hidden;
}
.gender-opt {
  border: none; background: transparent; color: var(--ink);
  font-family: inherit; font-size: 1rem; font-weight: 700;
  padding: 0 1.1rem; min-width: 50px; cursor: pointer;
  transition: background 0.15s, color 0.15s;
}
.gender-opt + .gender-opt { border-left: 1.5px solid var(--accent); }
.gender-opt.active { background: var(--accent); color: #fff; }

.k7-age-row { display: flex; justify-content: center; align-items: baseline; gap: 0.6rem; margin-bottom: 1.6rem; }
.ci-age-lbl { color: var(--accent); font-weight: 700; font-size: 0.95rem; }
.age-box { font-weight: 700; color: var(--ink); border-bottom: 2px solid var(--accent); min-width: 50px; padding: 2px 4px; }

/* ---- SVG matrica ---- */
.matrix-svg { width: 560px; max-width: 100%; height: auto; display: block; }
.matrix-svg text.val { font-family: Arial, sans-serif; font-weight: 700; text-anchor: middle; dominant-baseline: central; fill: var(--k-num); }
.matrix-svg text.age { font-family: Arial, sans-serif; fill: var(--ink); }

/* ---- Apakšējie skaitļi (dzimtas spēks, kods, mērķi) ---- */
.calc-bottom { margin-top: 1.5rem; }
.calc-bottom-row { display: flex; gap: 2.5rem; align-items: baseline; margin-bottom: 1.2rem; flex-wrap: wrap; }
.calc-bottom-row .lbl { font-weight: 700; }
.calc-bottom-row .val { border-bottom: 1.5px solid var(--line); min-width: 60px; text-align: center; font-weight: 700; padding: 0 6px; }

.goals { display: flex; gap: 2.5rem; flex-wrap: wrap; }
.goal-col { font-size: 0.85rem; }
.goal-col .goal-title { color: var(--accent); font-weight: 700; margin-bottom: 0.6rem; line-height: 1.3; }
.goal-pair { display: flex; align-items: center; gap: 0.5rem; margin-bottom: 0.4rem; }
.goal-pair .pair-lbl { font-weight: 700; min-width: 46px; }
.circle-num {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; border-radius: 50%; border: 1.5px solid var(--line);
  font-weight: 700; font-size: 0.95rem;
}
.goal-pair-brace { display: flex; align-items: center; gap: 0.4rem; }
.goal-result { margin-left: 0.3rem; }

/* ---- Veselības karte (tabula, gaišā tēma 1:1 pēc references) ---- */
.health-title { color: var(--accent); font-weight: 700; font-size: 1.7rem; text-align: center; margin-bottom: 1.2rem; letter-spacing: 0.02em; }
.health-table {
  width: 100%; border-collapse: collapse;
  background: var(--hero-bg); border-radius: 6px;
  box-shadow: 0 1px 4px rgba(0,0,0,0.45);
  font-family: inherit;
}
/* Noapaļotie stūri bez overflow:hidden (lai tooltip var izkļūt ārpus tabulas) */
.health-table thead th:first-child { border-top-left-radius: 6px; }
.health-table thead th:last-child  { border-top-right-radius: 6px; }
.health-table tr.total td:first-child { border-bottom-left-radius: 6px; }
.health-table tr.total td:last-child  { border-bottom-right-radius: 6px; }

/* Galvene */
.health-table thead th {
  background: var(--cta-bg); color: var(--ink); font-weight: 600;
  font-size: 0.95rem; text-align: left; padding: 1rem 0.9rem;
  border-bottom: 1px solid var(--line);
}
.health-table thead th.hc-num { text-align: center; }
.health-table thead th.hc-bar { width: 6px; padding: 0; }

/* Krāsainā kreisās malas josla ar numuru */
.hc-bar {
  width: 34px; padding: 0; text-align: center; vertical-align: middle;
  color: var(--hero-bg); font-weight: 700; font-size: 1rem;
}

/* Čakras nosaukums + apraksts */
.hc-name { padding: 0.85rem 0.9rem; vertical-align: middle; }
.ch-title { display: block; font-weight: 700; font-size: 1.02rem; color: var(--ink); }
.ch-help {
  position: relative;
  display: inline-block; margin-left: 0.35rem; width: 1.05em; height: 1.05em;
  line-height: 1.05em; text-align: center; border-radius: 50%;
  border: 1.5px solid currentColor; font-size: 0.72rem; font-weight: 700;
  vertical-align: middle; cursor: help;
}

/* Tooltip — balta kaste ar ēnu un bultiņu (kā references) */
.ch-tip {
  position: absolute;
  bottom: calc(100% + 12px);
  left: 50%;
  transform: translateX(-50%) translateY(4px);
  width: 240px;
  background: var(--hero-bg); color: var(--ink);
  font-size: 0.92rem; font-weight: 400; line-height: 1.4; text-align: left;
  padding: 0.85rem 1rem; border-radius: 8px;
  box-shadow: 0 6px 24px rgba(0,0,0,0.55);
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity 0.15s ease, transform 0.15s ease;
  z-index: 50;
}
/* Bultiņa apakšā, kas norāda uz ikonu */
.ch-tip::after {
  content: ""; position: absolute; top: 100%; left: 50%;
  transform: translateX(-50%);
  border: 8px solid transparent; border-top-color: var(--hero-bg);
  filter: drop-shadow(0 3px 2px rgba(0,0,0,0.40));
}
/* Rādīšana: hover (desktops) vai .open klase (pieskāriens, JS pārvaldīts) */
.ch-help:hover .ch-tip,
.ch-help.open .ch-tip {
  opacity: 1; visibility: visible;
  transform: translateX(-50%) translateY(0);
}
.ch-sub { display: block; font-size: 0.84rem; color: var(--muted); margin-top: 0.15rem; }

/* Skaitļu kolonnas */
.hc-num {
  text-align: center; vertical-align: middle; font-size: 1.25rem;
  color: var(--ink); padding: 0.85rem 0.6rem;
}

/* Rindas + zebra */
.health-table tbody tr { border-bottom: 1px solid var(--cta-bg); }
.health-table tbody tr:nth-child(even) { background: var(--cta-bg); }
.health-table tbody tr:nth-child(odd)  { background: var(--hero-bg); }

/* KOPĀ (Result) rinda */
.health-table tr.total { background: var(--cta-bg); border-top: 2px solid var(--line); }
.health-table tr.total .hc-bar { background: var(--muted); }
.health-table tr.total .hc-num { font-weight: 700; }

/* ---- CTA bloks ---- */
.calc-cta {
  max-width: 760px; margin: 1rem auto 4rem; background: var(--cta-bg);
  text-align: center; padding: 3rem 2rem; border-radius: 2px;
}
.calc-cta p { font-size: 1.05rem; color: var(--ink); margin: 0.3rem 0; }
.calc-cta .cta-btn {
  display: inline-block; margin-top: 1.5rem; padding: 0.9rem 2rem;
  border: 1px solid var(--muted); border-radius: 30px; color: var(--ink); text-decoration: none;
  font-size: 0.85rem; letter-spacing: 0.1em; text-transform: uppercase; background: var(--cta-bg);
  transition: background 0.15s;
}
.calc-cta .cta-btn:hover { background: var(--hero-bg); }

/* ---- PDF poga ---- */
.pdf-row { text-align: center; margin: 1.5rem 0; }
.pdf-btn {
  background: var(--accent); color: var(--hero-bg); border: 1px solid var(--accent);
  padding: 0.8rem 2rem; font-size: 0.95rem; font-family: inherit; cursor: pointer;
  border-radius: 2px; transition: 0.2s;
}
.pdf-btn:hover { background: transparent; color: var(--accent); }

/* ---- Atvērto jautājumu piezīme ---- */
.calc-note { max-width: 1180px; margin: 0 auto 2rem; padding: 0 1.5rem; font-size: 0.8rem; color: var(--muted); }

/* =====================================================================
   PAPILDU FUNKCIJAS — paaudžu līnijas + mērķu kartītes
   Skaitļi nāk no matrica-core.js (verificēti); UI nosaukumi no MATRIX_TASK.md.
   ===================================================================== */
.extra { max-width: 1180px; margin: 0 auto 3rem; padding: 0 1.5rem; }
.extra-title {
  color: var(--accent); font-weight: 700; font-size: 1.5rem;
  text-align: center; margin-bottom: 2rem; letter-spacing: 0.01em;
}

/* Kopīgs aplis (energy circle) */
.ec {
  display: inline-flex; align-items: center; justify-content: center;
  width: 44px; height: 44px; border-radius: 50%;
  border: 1.5px solid var(--accent); color: var(--ink);
  font-weight: 700; font-size: 1.05rem; flex: 0 0 auto;
}
.ec-result {
  width: 52px; height: 52px; font-size: 1.2rem;
  border-width: 2px; background: var(--cta-bg);
}

/* Paaudžu līnijas */
.gen-lines {
  display: flex; flex-direction: column; gap: 1rem;
  align-items: center; margin-bottom: 2.5rem;
}
.gen-row { display: flex; align-items: center; gap: 1.2rem; }
.gen-label { font-weight: 700; min-width: 130px; text-align: right; color: var(--muted); }
.gen-circles { display: flex; gap: 0.8rem; }

/* Mērķu kartītes — atsaucīgs grid */
.goal-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1.5rem;
}
.goal-card {
  background: var(--hero-bg); border: 1px solid var(--cta-bg); border-radius: 10px;
  padding: 1.3rem 1.2rem; box-shadow: 0 1px 4px rgba(0,0,0,0.35);
  display: flex; flex-direction: column;
}
.gc-head { font-size: 0.8rem; color: var(--accent); font-weight: 700; letter-spacing: 0.03em; }
.gc-name { font-size: 1.15rem; font-weight: 700; margin: 0.2rem 0 1rem; color: var(--ink); }

.gc-pair { display: flex; align-items: center; gap: 0.8rem; margin-bottom: 0.4rem; }
.gc-pair-center { justify-content: center; padding: 0.4rem 0; }
.gc-inputs { display: flex; flex-direction: column; gap: 0.5rem; }
.gc-in { display: flex; align-items: center; gap: 0.6rem; }
.gc-in-lbl { font-weight: 700; font-size: 0.85rem; min-width: 56px; color: var(--muted); }
.gc-arrow { font-size: 1.4rem; color: var(--accent); }

.code-row { display: flex; gap: 0.6rem; justify-content: center; margin: 0.6rem 0; }

.gc-desc { font-size: 0.82rem; color: var(--muted); line-height: 1.4; margin-top: auto; padding-top: 0.8rem; }

/* =====================================================================
   INTERPRETĀCIJAS — kodu nozīmes ar mandalu un tekstu
   ===================================================================== */
.interp { max-width: 1180px; margin: 0 auto 3rem; padding: 0 1.5rem; }
.interp-title {
  color: var(--accent); font-weight: 700; font-size: 1.5rem;
  text-align: center; margin-bottom: 0.4rem;
}
.interp-sub { text-align: center; color: var(--muted); font-size: 0.92rem; margin-bottom: 2rem; }

.interp-cards { display: flex; flex-direction: column; gap: 1.5rem; }

.icard {
  display: grid;
  grid-template-columns: 150px 1fr;
  gap: 1.5rem;
  background: var(--hero-bg);
  border: 1px solid var(--cta-bg);
  border-radius: 14px;
  padding: 1.4rem 1.5rem;
  box-shadow: 0 1px 4px rgba(0,0,0,0.35);
  align-items: start;
}
.icard-mandala { text-align: center; }
.icard-mandala img {
  width: 130px; height: auto; display: block; margin: 0 auto 0.6rem;
}
.icard-codebadge {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 40px; height: 40px; padding: 0 0.5rem;
  border-radius: 999px; background: var(--accent); color: var(--hero-bg);
  font-weight: 700; font-size: 1.1rem;
}
.icard-role { font-size: 0.78rem; color: var(--muted); margin-top: 0.4rem; }

.icard-body { min-width: 0; }
.icard-head { font-size: 0.78rem; font-weight: 700; letter-spacing: 0.05em;
  text-transform: uppercase; color: var(--accent); }
.icard-name { font-size: 1.25rem; font-weight: 700; color: var(--ink); margin: 0.15rem 0 0.8rem; }
.icard-general { font-size: 0.92rem; line-height: 1.55; color: var(--ink); margin-bottom: 1rem; }

.icard-block { margin-bottom: 0.8rem; }
.icard-block h4 {
  font-size: 0.82rem; font-weight: 700; margin-bottom: 0.3rem;
  display: flex; align-items: center; gap: 0.4rem;
}
.icard-block.plus  h4 { color: #3ddc84; }
.icard-block.minus h4 { color: #ff6b6b; }
.icard-block.adv   h4 { color: #7c6cf0; }
.icard-block p, .icard-block ul { font-size: 0.86rem; line-height: 1.5; color: var(--muted); }
.icard-block ul { padding-left: 1.1rem; }
.icard-block li { margin-bottom: 0.2rem; }

.interp-disclaimer {
  margin-top: 2rem; font-size: 0.78rem; color: var(--muted); text-align: center;
  line-height: 1.5; max-width: 720px; margin-left: auto; margin-right: auto;
}

/* ===== LIELĀ ATSKAITE ===== */
.report { max-width: 920px; margin: 0 auto 3rem; padding: 0 1.5rem; }
.report-title {
  text-align: center; color: var(--accent); font-weight: 700;
  font-size: 1.7rem; letter-spacing: 0.02em; margin-bottom: 0.4rem;
}
.report-sub { text-align: center; color: var(--muted); font-size: 0.92rem; margin-bottom: 2rem; }

/* ===== SADAĻU ACCORDION (vienots saraksts) ===== */
.rsec {
  background: var(--hero-bg); border: 1px solid var(--line);
  border-radius: 10px; margin-bottom: 0.6rem;
  box-shadow: 0 1px 6px rgba(124,108,240,0.18);
  overflow: hidden;
}
/* Galva = klikšķināma rinda */
.rsec-head {
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  padding: 1.05rem 1.4rem; cursor: pointer; user-select: none;
  transition: background 0.15s;
}
.rsec-head:hover { background: var(--cta-bg); }
.rsec-head h3 { font-size: 1.08rem; font-weight: 700; color: var(--ink); margin: 0; flex: 1; }
/* Ikona labajā malā (▼ izvēršamai / 🔒 maksas) */
.rsec-ico {
  font-size: 0.95rem; color: var(--muted); flex-shrink: 0;
  transition: transform 0.2s;
}
.rsec.open .rsec-ico { transform: rotate(180deg); }
/* Saturs — sākotnēji aizvērts, izveras klikšķinot */
.rsec-body {
  padding: 0 1.4rem; max-height: 0; overflow: hidden;
  transition: max-height 0.3s ease, padding 0.3s ease;
}
.rsec.open .rsec-body { max-height: 8000px; padding: 0.4rem 1.4rem 1.4rem; }

/* Maksas (atslēgtā) rinda — nav klikšķināma */
.rsec.locked .rsec-head { cursor: default; opacity: 0.78; }
.rsec.locked .rsec-head:hover { background: none; }
.rsec.locked .rsec-ico { color: #c98fd6; }

.rsec-badge {
  font-size: 0.7rem; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase;
  padding: 0.25rem 0.6rem; border-radius: 999px; white-space: nowrap; flex-shrink: 0;
}
.rsec-badge.free { background: #16271d; color: #3ddc84; }
:root[data-theme="light"] .rsec-badge.free { color: #fff; }

.rsec-lead {
  font-size: 1rem; color: var(--ink); margin: 1.1rem 0 0.6rem;
  padding-bottom: 0.35rem; border-bottom: 1px solid var(--cta-bg);
}
.rsec-lead:first-child { margin-top: 0; }
.rsec-lead b { color: var(--accent); }
.rsec-foot { margin-top: 1rem; font-size: 0.95rem; color: var(--muted); }
.rsec-foot b { color: var(--accent); }

.rsec-codes b {
  display: inline-block; min-width: 1.9em; text-align: center;
  background: var(--accent); color: var(--hero-bg); border-radius: 6px;
  padding: 0.1em 0.4em; font-size: 0.95rem;
}
.rsec-codes i { color: var(--muted); font-style: normal; margin: 0 0.3em; }

/* Maksas sadaļu priekšskatījums — vienā kolonnā kā pārējais accordion */
.rsec-locked-grid { margin-top: 1rem; }

/* ===== PIRKŠANAS POGA (zem sadaļām) ===== */
.paywall {
  margin: 1.6rem auto 0; max-width: 640px; text-align: center;
}
.buy-btn {
  background: linear-gradient(135deg, #e0b352, #e0b352);
  color: var(--hero-bg); border: none; border-radius: 999px;
  padding: 0.85rem 2rem; font-size: 1.02rem; font-weight: 700;
  font-family: inherit; cursor: pointer; transition: transform 0.12s, box-shadow 0.12s;
  box-shadow: 0 4px 14px rgba(224,179,82,0.35);
}
.buy-btn:hover:not(:disabled) { transform: translateY(-1px); box-shadow: 0 6px 18px rgba(224,179,82,0.45); }
.buy-btn:disabled { opacity: 0.7; cursor: default; }
.paywall-msg { color: #ff6b6b; font-size: 0.88rem; min-height: 1em; margin: 0.7rem 0 0; }
.paywall-note { font-size: 0.78rem; color: var(--muted); margin: 0.8rem 0 0; }

.rsec-paid { margin-top: 1.4rem; }
.rsec-badge.paid { background: #2a2417; color: #c89a3a; }

/* AI interpretācija */
.rsec-ai { margin-top: 1.4rem; padding-top: 1.2rem; border-top: 1px dashed var(--line); }
.ai-btn {
  background: linear-gradient(135deg, var(--accent), #9389f5);
  color: var(--hero-bg); border: none; border-radius: 999px;
  padding: 0.7rem 1.4rem; font-size: 0.92rem; font-weight: 700;
  font-family: inherit; cursor: pointer; transition: transform 0.12s, box-shadow 0.12s;
  box-shadow: 0 3px 12px rgba(124,108,240,0.30);
}
.ai-btn:hover:not(:disabled) { transform: translateY(-1px); box-shadow: 0 5px 16px rgba(124,108,240,0.40); }
.ai-btn:disabled { opacity: 0.7; cursor: default; }

.ai-out { margin-top: 1.1rem; }
.ai-out.ai-loading { color: var(--muted); font-style: italic; font-size: 0.92rem; }
.ai-out.ai-error { color: #ff6b6b; font-size: 0.92rem; }
.ai-out h3, .ai-out h4 { color: var(--accent); margin: 1rem 0 0.4rem; font-size: 1.02rem; }
.ai-out h4 { font-size: 0.95rem; color: #6a5ae0; }
.ai-out p { font-size: 0.92rem; line-height: 1.6; color: var(--ink); margin-bottom: 0.7rem; }
.ai-out ul { padding-left: 1.2rem; margin-bottom: 0.7rem; }
.ai-out li { font-size: 0.92rem; line-height: 1.5; color: var(--ink); margin-bottom: 0.25rem; }
.ai-out strong { color: var(--ink); }

/* ---- Responsīvs ---- */
@media (max-width: 1000px) {
  .calc-main { flex-direction: column; align-items: center; }
  .calc-left { width: 100%; max-width: 560px; }
  .calc-right { max-width: 560px; width: 100%; }
}
@media (max-width: 640px) {
  .calc-hero h1 { font-size: 1.9rem; }
  .matrix-svg { width: 100%; }
  .calc-topnav { padding: 0.8rem 1rem; }
  .calc-topnav .nav-right { gap: 0.8rem; font-size: 0.78rem; }
  .goals { gap: 1.5rem; }

  /* ---- Veselības karte: sašaurināt, lai tabula ietilpst ekrānā ---- */
  /* Mazākas malas konteinerim → vairāk vietas tabulai, centrēta */
  .calc-main { padding: 0.8rem 0.75rem 2rem; }
  .calc-right {
    min-width: 0;       /* atļaut tabulai sašaurināties (bija 340px) */
    width: 100%;
    max-width: 100%;
  }

  /* Tabula fiksēta izkārtojuma, lai kolonnas dalās proporcionāli */
  .health-table { table-layout: fixed; }

  /* Saspiest visas šūnas */
  .health-table thead th {
    font-size: 0.7rem;
    padding: 0.6rem 0.25rem;
    text-align: center;       /* skaitļu galvenes centrā */
  }
  .health-table thead th.hc-name { text-align: left; }

  .hc-bar { width: 20px; font-size: 0.8rem; }
  .health-table thead th.hc-bar { width: 20px; }

  .hc-name { padding: 0.6rem 0.4rem; }
  .ch-title { font-size: 0.82rem; }
  .ch-sub   { font-size: 0.66rem; }

  .hc-num {
    font-size: 0.95rem;
    padding: 0.6rem 0.15rem;
  }

  /* Tooltip mobilajā šaurāks, lai neizsprāgst ārpus ekrāna */
  .ch-tip { width: 180px; font-size: 0.82rem; }

  /* Papildu funkcijas — mobilajā */
  .extra { padding: 0 0.9rem; }
  .gen-row { flex-direction: column; gap: 0.5rem; }
  .gen-label { min-width: 0; text-align: center; }
  .ec { width: 40px; height: 40px; font-size: 0.95rem; }
  .ec-result { width: 46px; height: 46px; font-size: 1.05rem; }

  /* Interpretācijas — mobilajā: mandala virs teksta */
  .interp { padding: 0 0.9rem; }
  .icard { grid-template-columns: 1fr; gap: 0.8rem; padding: 1.2rem; }
  .icard-mandala img { width: 110px; }

  /* Lielā atskaite — mobilajā */
  .report { padding: 0 0.9rem; }
  .rsec-head { padding: 0.95rem 1.1rem; }
  .rsec.open .rsec-body { padding: 0.4rem 1.1rem 1.2rem; }
}

/* ===== kalkulators7 — rezultātu akordeons (Ārējā / Iekšējā / Dzīves mācība) ===== */
.rsec-headtext { flex: 1; }
.rsec-headtext h3 { margin: 0; }
.rsec-subhead { display: block; font-size: 0.82rem; color: var(--muted); font-weight: 400; margin-top: 0.25rem; line-height: 1.45; }
.md-content h4 { font-size: 0.98rem; color: var(--accent); margin: 1.1rem 0 0.35rem; }
.md-content h4:first-child { margin-top: 0; }
.md-content p { font-size: 0.9rem; line-height: 1.6; color: var(--ink); margin: 0 0 0.7rem; }
.md-content p:last-child { margin-bottom: 0; }
.md-content .md-empty { color: var(--muted); font-style: italic; }
.md-content .ex-note { color: var(--muted); font-size: 0.8rem; font-style: italic; margin-top: 0.3rem; }

/* Papildu informatīvie bloki — režģis 3×2 (kartītes ar uzreiz redzamu saturu) */
.ex-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.8rem; margin-bottom: 1.8rem; }
.ex-card {
  background: var(--hero-bg); border: 1px solid var(--line); border-radius: 10px;
  padding: 1rem 1.2rem; box-shadow: 0 1px 6px rgba(124,108,240,0.18);
}
.ex-card h3 { font-size: 1.05rem; font-weight: 700; color: var(--ink); margin: 0 0 0.2rem; }
.ex-card .ex-sub { display: block; font-size: 0.82rem; color: var(--muted); margin-bottom: 0.7rem; line-height: 1.4; }
.ex-card .md-content p { font-size: 0.86rem; }
@media (max-width: 900px) { .ex-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .ex-grid { grid-template-columns: 1fr; } }
.report-sub.k7 { margin-bottom: 1.4rem; }

/* =====================================================================
   ĢENERĒT ATBILDI — poga + mistiskā "atbildes būvēšanas" animācija
   ===================================================================== */

/* --- Poga --- */
.k7-gen { max-width: 920px; margin: 0.5rem auto 2.6rem; padding: 0 1.5rem; text-align: center; }

.k7-gen-btn {
  position: relative;
  display: inline-flex; align-items: center; justify-content: center;
  padding: 0.95rem 2.6rem;
  font-family: inherit; font-size: 1.02rem; font-weight: 700; letter-spacing: 0.04em;
  color: #fff; cursor: pointer;
  border: 1px solid rgba(233, 196, 106, 0.55);
  border-radius: 999px;
  background: linear-gradient(135deg, #4a3ea8 0%, #7c6cf0 50%, #5a3ea0 100%);
  box-shadow: 0 10px 30px rgba(124, 108, 240, 0.35), inset 0 0 0 1px rgba(255,255,255,0.06);
  overflow: hidden;
  transition: transform 0.18s ease, box-shadow 0.25s ease, opacity 0.2s ease, filter 0.25s ease;
}
.k7-gen-btn:disabled { opacity: 0.5; cursor: not-allowed; filter: grayscale(0.4); box-shadow: none; }
.k7-gen-btn.ready { animation: k7-btn-breathe 2.8s ease-in-out infinite; }
.k7-gen-btn.ready:hover { transform: translateY(-2px); box-shadow: 0 16px 40px rgba(124, 108, 240, 0.5), 0 0 22px rgba(233,196,106,0.35); }
.k7-gen-btn.ready:active { transform: translateY(0); }
.k7-gen-btn-label { position: relative; z-index: 2; }

/* Mirdzošs sweep pāri pogai */
.k7-gen-btn-shine {
  position: absolute; top: 0; left: -60%; width: 50%; height: 100%; z-index: 1;
  background: linear-gradient(100deg, transparent, rgba(255,255,255,0.45), transparent);
  transform: skewX(-18deg);
}
.k7-gen-btn.ready .k7-gen-btn-shine { animation: k7-btn-shine 3.4s ease-in-out infinite; }

.k7-gen-btn.shake { animation: k7-shake 0.45s ease both; }

.k7-gen-hint { margin: 0.9rem 0 0; font-size: 0.9rem; color: var(--muted); }

@keyframes k7-btn-breathe {
  0%, 100% { box-shadow: 0 10px 30px rgba(124,108,240,0.35), 0 0 0 rgba(233,196,106,0); }
  50%      { box-shadow: 0 12px 34px rgba(124,108,240,0.5), 0 0 20px rgba(233,196,106,0.4); }
}
@keyframes k7-btn-shine { 0% { left: -60%; } 55%, 100% { left: 130%; } }
@keyframes k7-shake {
  0%,100% { transform: translateX(0); } 20% { transform: translateX(-7px); }
  40% { transform: translateX(6px); } 60% { transform: translateX(-4px); } 80% { transform: translateX(3px); }
}

/* --- PILNEKRĀNA mistiskais ielādes pārklājums --- */
.k7-overlay {
  position: fixed; inset: 0; z-index: 9999;
  display: flex; align-items: center; justify-content: center;
  padding: 1.5rem; text-align: center;
  background:
    radial-gradient(60% 60% at 50% 42%, rgba(124,108,240,0.22), transparent 70%),
    radial-gradient(40% 40% at 80% 80%, rgba(233,196,106,0.12), transparent 70%),
    radial-gradient(1px 1px at 20% 30%, rgba(255,255,255,0.85), transparent),
    radial-gradient(1px 1px at 70% 22%, rgba(255,255,255,0.6), transparent),
    radial-gradient(1px 1px at 38% 72%, rgba(255,255,255,0.7), transparent),
    radial-gradient(1.5px 1.5px at 85% 55%, rgba(255,255,255,0.55), transparent),
    radial-gradient(1px 1px at 12% 80%, rgba(255,255,255,0.5), transparent),
    radial-gradient(1px 1px at 60% 88%, rgba(255,255,255,0.5), transparent),
    linear-gradient(160deg, #141233 0%, #0a081c 55%, #16112e 100%);
  opacity: 0; transition: opacity 0.55s ease;
  -webkit-backdrop-filter: blur(2px); backdrop-filter: blur(2px);
}
.k7-overlay.on { opacity: 1; }
.k7-overlay-inner {
  transform: translateY(14px) scale(0.97); opacity: 0;
  transition: opacity 0.6s ease 0.1s, transform 0.6s ease 0.1s;
}
.k7-overlay.on .k7-overlay-inner { transform: none; opacity: 1; }
/* `hidden` atribūtam jāuzvar pār display:flex (citādi pārklājums bloķē klikšķus). */
.k7-overlay[hidden], .k7-status[hidden] { display: none !important; }
body.k7-locked { overflow: hidden; }

.k7-loader-stage { position: relative; width: 200px; height: 200px; margin: 0 auto 1.4rem; }
.k7-glyph { width: 100%; height: 100%; overflow: visible; }

.k7-glyph .k7-ring {
  fill: none; stroke-linecap: round;
  transform-box: fill-box; transform-origin: center;
}
.k7-glyph .k7-ring-1 {
  stroke: rgba(124,108,240,0.55); stroke-width: 1.4; stroke-dasharray: 6 14;
  animation: k7-spin 9s linear infinite;
}
.k7-glyph .k7-ring-2 {
  stroke: rgba(233,196,106,0.45); stroke-width: 1; stroke-dasharray: 3 10;
  animation: k7-spin-rev 6s linear infinite;
}

.k7-glyph .k7-star {
  fill: none; stroke-width: 1.6; stroke-linejoin: round;
  transform-box: fill-box; transform-origin: center;
  stroke-dasharray: 528; stroke-dashoffset: 528;
  filter: drop-shadow(0 0 4px rgba(124,108,240,0.7));
}
.k7-glyph .k7-star-a {
  stroke: #8b7cf6;
  animation: k7-draw 2.2s ease forwards, k7-spin 18s linear infinite;
}
.k7-glyph .k7-star-b {
  stroke: rgba(233,196,106,0.85);
  transform: rotate(45deg);
  animation: k7-draw 2.2s ease 0.25s forwards, k7-spin-rev 22s linear infinite;
}

.k7-glyph .k7-node { fill: #e9c46a; filter: drop-shadow(0 0 4px rgba(233,196,106,0.9)); animation: k7-node-blink 2.4s ease-in-out infinite; }
.k7-glyph .k7-node:nth-of-type(2) { animation-delay: 0.6s; }
.k7-glyph .k7-node:nth-of-type(3) { animation-delay: 1.2s; }
.k7-glyph .k7-node:nth-of-type(4) { animation-delay: 1.8s; }

.k7-glyph .k7-core {
  fill: radial-gradient(circle, #fff, #b9a8ff);
  fill: #c9bdff;
  filter: drop-shadow(0 0 10px rgba(180,160,255,0.9));
  animation: k7-core-glow 2.6s ease-in-out infinite;
  transform-box: fill-box; transform-origin: center;
}
.k7-glyph .k7-core-pulse {
  fill: none; stroke: rgba(201,189,255,0.6); stroke-width: 1.2;
  transform-box: fill-box; transform-origin: center;
  animation: k7-core-ping 2.6s ease-out infinite;
}

/* Orbītā lidojošas dzirksteles */
.k7-spark { position: absolute; top: 50%; left: 50%; border-radius: 50%; pointer-events: none; }
.k7-spark::before {
  content: ""; position: absolute; top: -3px; left: 50%; width: 7px; height: 7px; margin-left: -3.5px;
  border-radius: 50%; background: #fff;
  box-shadow: 0 0 8px 2px rgba(233,196,106,0.9), 0 0 14px 4px rgba(124,108,240,0.6);
}
.k7-spark-1 { width: 150px; height: 150px; margin: -75px 0 0 -75px; animation: k7-spin 4.5s linear infinite; }
.k7-spark-2 { width: 200px; height: 200px; margin: -100px 0 0 -100px; animation: k7-spin-rev 7s linear infinite; }
.k7-spark-2::before { background: #e9c46a; box-shadow: 0 0 8px 2px rgba(124,108,240,0.9); }
.k7-spark-3 { width: 116px; height: 116px; margin: -58px 0 0 -58px; animation: k7-spin 3.4s linear infinite; }
.k7-spark-3::before { width: 5px; height: 5px; margin-left: -2.5px; background: #b9a8ff; }

.k7-loader-text {
  min-height: 2.6em; color: #efeaff; font-size: 1.04rem; font-weight: 600; line-height: 1.45;
  letter-spacing: 0.01em; max-width: 24em; margin: 0 auto;
  opacity: 0; transform: translateY(8px); transition: opacity 0.5s ease, transform 0.5s ease;
  text-shadow: 0 0 18px rgba(124,108,240,0.45);
}
.k7-loader-text.show { opacity: 1; transform: none; }

.k7-loader-prog {
  width: 220px; max-width: 80%; height: 3px; margin: 1.3rem auto 0;
  border-radius: 999px; background: rgba(255,255,255,0.1); overflow: hidden;
}
.k7-loader-bar {
  display: block; width: 0; height: 100%; border-radius: 999px;
  background: linear-gradient(90deg, #7c6cf0, #e9c46a);
  box-shadow: 0 0 10px rgba(233,196,106,0.6);
}

@keyframes k7-spin { to { transform: rotate(360deg); } }
@keyframes k7-spin-rev { to { transform: rotate(-360deg); } }
@keyframes k7-draw { to { stroke-dashoffset: 0; } }
@keyframes k7-node-blink { 0%,100% { opacity: 0.25; } 50% { opacity: 1; } }
@keyframes k7-core-glow {
  0%,100% { transform: scale(0.9); opacity: 0.85; }
  50%     { transform: scale(1.12); opacity: 1; }
}
@keyframes k7-core-ping {
  0%   { transform: scale(0.9); opacity: 0.8; }
  80%, 100% { transform: scale(3.2); opacity: 0; }
}

/* --- Atskaite: paslēpta līdz ģenerēšanai, parādās ar slide-up --- */
.report.k7-gated { display: none; }
.report.k7-gated.revealed {
  display: block;
  animation: k7-rise 0.9s cubic-bezier(0.2, 0.7, 0.2, 1) both;
}
@keyframes k7-rise {
  from { opacity: 0; transform: translateY(30px) scale(0.985); }
  to   { opacity: 1; transform: none; }
}

@media (max-width: 600px) {
  .k7-gen-btn { width: 100%; max-width: 360px; padding: 0.95rem 1.4rem; }
  .k7-loader-stage { width: 168px; height: 168px; }
  .k7-spark-1 { width: 126px; height: 126px; margin: -63px 0 0 -63px; }
  .k7-spark-2 { width: 168px; height: 168px; margin: -84px 0 0 -84px; }
  .k7-spark-3 { width: 98px; height: 98px; margin: -49px 0 0 -49px; }
  .k7-loader-text { font-size: 0.98rem; }
}

/* Cieņa pret reduced-motion: bez griešanās, bet atbilde tāpat parādās */
@media (prefers-reduced-motion: reduce) {
  .k7-glyph .k7-ring, .k7-glyph .k7-star, .k7-spark,
  .k7-glyph .k7-core, .k7-glyph .k7-core-pulse, .k7-glyph .k7-node,
  .k7-gen-btn.ready, .k7-gen-btn.ready .k7-gen-btn-shine { animation: none; }
  .k7-glyph .k7-star { stroke-dashoffset: 0; }
}

/* =====================================================================
   PIRMS-ĢENERĒŠANAS redzamība (admin "Kalkulators 7" cilne)
   ---------------------------------------------------------------------
   Pirms ģenerēšanas (body.k7-pregen) rāda tikai ievades laukus + pogu.
   Bloki ar .k7-prehide (matrica, veselības karte, paaudžu līnijas) ir
   paslēpti, līdz admin tos ieslēdz VAI līdz lietotājs nospiež "Ģenerēt".
   Pēc ģenerēšanas (body.k7-generated) visi bloki vienmēr parādās.
   ===================================================================== */
body.k7-pregen .k7-prehide { display: none !important; }
/* Pēc ģenerēšanas atklāšanu pārvalda kinematogrāfiskā secība (k7-cin*),
   tāpēc šeit k7-prehide vairs neko neanimē. */
/* Kad matrica paslēpta, ievades kolonna saglabā ērtu platumu (nesarūk). */
body.k7-pregen .calc-left { width: min(480px, 100%); }

/* =====================================================================
   KINEMATOGRĀFISKĀ pakāpeniskā atklāšana (k7-generate.js)
   ===================================================================== */

/* Secības bloks, kas vēl nav atklāts — pilnībā paslēpts (bez atstarpes). */
.k7-cin { display: none !important; }

/* Standarta bloka atklāšana — fade-in + slide-up. */
.k7-cin-in {
  animation: k7-rise 0.9s cubic-bezier(0.2, 0.7, 0.2, 1) both;
}

/* Matricas īpašā atklāšana — iezoomējas + izgaismojas. */
.k7-cin-matrix {
  animation: k7-matrix-in 1.5s cubic-bezier(0.18, 0.7, 0.2, 1) both;
}
@keyframes k7-matrix-in {
  0%   { opacity: 0; transform: scale(0.82) translateY(10px); filter: brightness(2.1) drop-shadow(0 0 26px rgba(124,108,240,0.9)); }
  55%  { opacity: 1; filter: brightness(1.35) drop-shadow(0 0 20px rgba(124,108,240,0.7)); }
  100% { opacity: 1; transform: none; filter: none; }
}

/* Īslaicīgs "tikko ģenerēts" izcēlums — maigs glow pulss. */
.k7-cin-glow {
  animation: k7-glow-pulse 2.4s ease-in-out;
  border-radius: 16px;
}
@keyframes k7-glow-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(124,108,240,0); }
  18%  { box-shadow: 0 0 34px 4px rgba(124,108,240,0.55), 0 0 16px 2px rgba(233,196,106,0.35); }
  100% { box-shadow: 0 0 0 0 rgba(124,108,240,0); }
}

/* --- Per-bloka statusa indikators (apakšā, fiksēts; mobilajām draudzīgs) --- */
.k7-status {
  position: fixed; left: 50%; bottom: 22px; z-index: 9998;
  transform: translate(-50%, 16px); opacity: 0; pointer-events: none;
  display: flex; align-items: center; gap: 0.7rem;
  max-width: calc(100vw - 32px);
  padding: 0.7rem 1.15rem; border-radius: 999px;
  border: 1px solid rgba(124,108,240,0.4);
  background: linear-gradient(135deg, rgba(20,18,51,0.96), rgba(12,10,34,0.96));
  box-shadow: 0 14px 40px rgba(8,6,24,0.5), inset 0 0 0 1px rgba(255,255,255,0.04);
  color: #efeaff; font-size: 0.92rem; font-weight: 600; line-height: 1.3;
  transition: opacity 0.4s ease, transform 0.4s ease;
}
.k7-status.on { opacity: 1; transform: translate(-50%, 0); }
.k7-status-text { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.k7-status-orb {
  flex: 0 0 auto; width: 16px; height: 16px; border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, #fff, #b9a8ff 55%, #7c6cf0);
  box-shadow: 0 0 10px 2px rgba(124,108,240,0.8);
  animation: k7-orb-pulse 1.1s ease-in-out infinite;
}
@keyframes k7-orb-pulse {
  0%,100% { transform: scale(0.82); box-shadow: 0 0 8px 1px rgba(124,108,240,0.7); }
  50%     { transform: scale(1.1);  box-shadow: 0 0 16px 4px rgba(233,196,106,0.6); }
}

@media (max-width: 600px) {
  .k7-status { bottom: 14px; font-size: 0.86rem; padding: 0.62rem 0.95rem; }
  .k7-status-text { white-space: normal; }
}

/* Reduced-motion: bez statusa pulsa / zoom — bloki tāpat parādās. */
@media (prefers-reduced-motion: reduce) {
  .k7-cin-in, .k7-cin-matrix, .k7-cin-glow, .k7-status-orb { animation: none !important; }
  .k7-cin-matrix { filter: none; transform: none; opacity: 1; }
}
