/* ============================================================================
   kundali.css  ·  Full Kundali workspace styling
   ========================================================================== */
.ku-ws { display: grid; grid-template-columns: 204px 1fr; gap: 22px; align-items: start; }
.ku-sidenav { position: sticky; top: 0; display: flex; flex-direction: column; gap: 14px; }
.ku-nativity { background: var(--glass-fill); border: 1px solid var(--glass-border); border-radius: var(--r-md); padding: 14px;
  display: flex; flex-direction: column; gap: 2px; }
.kn-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; }
.kn-actions { display: flex; gap: 6px; flex: 0 0 auto; }
.kn-edit { flex: 0 0 auto; width: 24px; height: 24px; border-radius: 6px; background: transparent; border: 1px solid var(--glass-border);
  color: var(--ink-soft); cursor: pointer; font-size: 0.8rem; line-height: 1; }
.kn-edit:hover { border-color: var(--gold); color: var(--gold); }
.nat-form { display: flex; flex-direction: column; gap: 4px; }
.nat-l { margin-top: 6px; }
.nat-l:first-child { margin-top: 0; }
.nat-i { background: rgba(255,255,255,0.04); border: 1px solid var(--glass-border); color: var(--ink); border-radius: 7px;
  padding: 7px 9px; font-family: var(--font-data); font-size: 0.8rem; color-scheme: dark; }
.nat-i:focus { outline: none; border-color: var(--gold); }
.nat-save { margin-top: 10px; padding: 8px; border-radius: 8px; background: var(--gold); color: #1a1407; border: 0;
  font-family: var(--font-data); font-size: 0.78rem; font-weight: 700; cursor: pointer; }
.nat-save:hover { background: var(--gold-bright); }
.kn-name { color: var(--gold); font-size: 0.92rem; font-weight: 600; line-height: 1.15; white-space: nowrap; }
.kn-head .kn-name { max-width: none; }
.kn-birth { font-size: 0.66rem; color: var(--ink-faint); margin-top: 2px; }
.kn-asc { font-size: 0.72rem; color: var(--ink-soft); margin-top: 7px; }
.kn-aya { margin-top: 7px; color: var(--ink-faint); }
.ku-subnav { display: flex; flex-direction: column; gap: 3px; }
.kusub { display: flex; align-items: center; gap: 10px; padding: 9px 12px; border-radius: 8px; background: transparent;
  border: 1px solid transparent; color: var(--ink-soft); cursor: pointer; font-family: var(--font-data);
  font-size: 0.82rem; font-weight: 600; text-align: left; transition: all var(--dur-fast); }
.kusub-g { width: 18px; text-align: center; color: var(--ink-faint); font-size: 0.95rem; }
.kusub:hover { background: rgba(212,168,67,0.08); color: var(--ink); }
.kusub.on { background: rgba(212,168,67,0.14); border-color: var(--glass-border); color: var(--gold); }
.kusub.on .kusub-g { color: var(--gold); }
.ku-content { min-width: 0; }

/* chart */
.kchart-controls { display: flex; justify-content: space-between; align-items: center; margin-bottom: 18px; gap: 12px; flex-wrap: wrap; }
.varga-tabs { display: flex; gap: 6px; flex-wrap: wrap; }
.varga-tabs button { padding: 6px 12px; border-radius: 8px; background: transparent; border: 1px solid var(--glass-border);
  color: var(--ink-soft); cursor: pointer; font-family: var(--font-ephem); font-size: 0.72rem; }
.varga-tabs button.on { background: var(--gold); color: #1a1407; border-color: var(--gold); }
.varga-tabs button:hover:not(.on) { border-color: var(--gold); color: var(--ink); }
.kchart-stage { display: grid; grid-template-columns: minmax(0, 420px) 1fr; gap: 24px; align-items: start; }
.kchart-box { background: var(--glass-fill); border: 1px solid var(--glass-border); border-radius: var(--r-lg); padding: 16px; }
.kchart-svg { width: 100%; height: auto; }
.kchart-meta { display: flex; flex-direction: column; gap: 8px; }
.kc-vlabel { font-size: 1.4rem; color: var(--gold); font-weight: 600; }
.kc-asc { font-size: 0.8rem; color: var(--ink-soft); }
.kc-legend { display: grid; grid-template-columns: 1fr 1fr; gap: 4px 14px; margin-top: 8px; font-size: 0.72rem; color: var(--ink-soft); }
.kcl i { font-style: normal; font-weight: 700; margin-right: 6px; }

/* tables */
.ktbl { display: flex; flex-direction: column; gap: 1px; }
.ktbl-head, .ktbl-row { display: grid; grid-template-columns: 1.3fr 1fr 1fr 1.3fr 0.6fr 0.9fr; gap: 10px; align-items: center; padding: 9px 10px; }
.ktbl.up .ktbl-head, .ktbl.up .ktbl-row { grid-template-columns: 1.2fr 1fr 1fr 1.3fr; }
.ktbl-head { color: var(--ink-faint); border-bottom: 1px solid var(--glass-border); }
.ktbl-row { border-radius: 6px; font-size: 0.8rem; }
.ktbl-row:hover { background: rgba(255,255,255,0.03); }
.ktbl-row.dim { opacity: 0.6; }
.ktc-g { display: flex; align-items: center; gap: 7px; font-weight: 600; }
.ktc-g i { font-size: 1rem; font-style: normal; }
.kt-r { color: var(--retro-purple); font-style: normal; filter: brightness(1.7); }
.kt-dig { color: var(--gold); }
.ktbl-sub { margin: 12px 0 4px; color: var(--ink-faint); border-top: 1px solid var(--glass-border); padding-top: 10px; }

/* yoga */
.yoga-sec { margin: 4px 0 12px; color: var(--ink-faint); }
.yoga-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 12px; margin-bottom: 18px; }
.yoga-card { background: var(--glass-fill); border: 1px solid var(--glass-border); border-radius: var(--r-md);
  padding: 14px; border-left: 3px solid var(--glass-border); display: flex; flex-direction: column; gap: 7px; }
.yoga-card.off { opacity: 0.5; }
.yoga-card.auspicious.on { border-left-color: var(--m-green); }
.yoga-card.inauspicious.on { border-left-color: var(--m-red); }
.yc-top { display: flex; justify-content: space-between; align-items: flex-start; gap: 10px; margin-bottom: 0; }
.yc-name { font-size: 1rem; color: var(--ink); font-weight: 600; line-height: 1.14; }
.yc-tag { flex: 0 0 auto; font-size: 0.5rem; padding: 2px 7px; border-radius: 6px; text-transform: uppercase; letter-spacing: 0.06em; }
.yc-tag.auspicious { color: #93e2b3; background: rgba(46,139,87,0.16); }
.yc-tag.inauspicious { color: #ed9aa6; background: rgba(196,30,58,0.16); }
.yc-note { font-size: 0.76rem; color: var(--ink-soft); line-height: 1.4; margin: 0; }
.yoga-card { cursor: pointer; transition: transform var(--dur-fast), box-shadow var(--dur-fast); }
.yoga-card.on:hover { transform: translateY(-2px); box-shadow: 0 16px 36px -22px rgba(0,0,0,0.9); }
.yoga-hint { text-transform: none; letter-spacing: 0; color: var(--ink-faint); font-size: 0.82em; margin-left: 8px; }
.yc-form { margin-top: 9px; padding-top: 10px; border-top: 1px solid var(--glass-border); }
.ycf-lbl { color: var(--gold); margin-bottom: 9px; }
.ycf-chain { display: flex; align-items: center; flex-wrap: wrap; gap: 4px; }
.ycf-node { display: inline-flex; flex-direction: column; align-items: center; gap: 2px; padding: 7px 11px; border-radius: 10px;
  background: color-mix(in srgb, var(--pc) 12%, transparent); border: 1px solid color-mix(in srgb, var(--pc) 40%, transparent); }
.ycf-glyph { font-family: var(--font-glyph, serif); font-size: 1.3rem; line-height: 1; color: var(--pc); }
.ycf-nm { font-size: 0.56rem; color: var(--ink-soft); letter-spacing: 0.04em; }
.ycf-link { width: 22px; height: 2px; border-radius: 2px; background: linear-gradient(90deg, var(--gold), var(--gold-bright)); }
.ycf-solo { font-size: 0.66rem; color: var(--ink-faint); margin-left: 6px; }
@media (prefers-reduced-motion: no-preference) {
  .ycf-node { animation: ycf-pop 0.45s var(--ease-celestial, cubic-bezier(.2,.7,.2,1)) both; }
  .ycf-link { animation: ycf-draw 0.4s ease both; transform-origin: left center; }
}
@keyframes ycf-pop { from { transform: scale(0.6); } to { transform: scale(1); } }
@keyframes ycf-draw { from { transform: scaleX(0); } to { transform: scaleX(1); } }

/* birth panchang */
.kp-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; align-items: start; }

/* vimshottari 5-level drill */
.dasha5 { display: grid; grid-template-columns: repeat(5, 1fr); gap: 10px; }
.dcol { background: var(--glass-fill); border: 1px solid var(--glass-border); border-radius: var(--r-md); overflow: hidden; display: flex; flex-direction: column; }
.dcol-head { padding: 10px 12px; background: rgba(212,168,67,0.08); color: var(--gold); border-bottom: 1px solid var(--glass-border); }
.dcol-list { display: flex; flex-direction: column; max-height: 580px; overflow-y: auto; }
.drow { position: relative; display: flex; flex-direction: column; gap: 2px; padding: 9px 12px; background: transparent;
  border: 0; border-bottom: 1px solid rgba(255,255,255,0.04); cursor: pointer; text-align: left; color: var(--ink-soft); }
.drow:hover { background: rgba(255,255,255,0.03); }
.drow.sel { background: rgba(212,168,67,0.12); }
.dr-lord { font-size: 0.85rem; font-weight: 600; color: var(--ink); }
.drow.sel .dr-lord { color: var(--gold); }
.dr-span { font-size: 0.6rem; color: var(--gold); }
.dr-dates { font-size: 0.6rem; color: var(--ink-faint); }
.dr-now { position: absolute; top: 9px; right: 9px; color: var(--m-green); font-size: 0.6rem; }

/* ===== Graha Drishti engine (interactive aspect rays) ===== */
.kchart-svg.interactive .kn-graha { transition: filter var(--dur-fast, 0.18s); }
.kchart-svg.interactive .kn-graha:hover { filter: drop-shadow(0 0 5px currentColor); }
.drishti-ray { stroke-linecap: round; filter: drop-shadow(0 0 3px currentColor); }
/* whole-Bhava illumination — the entire house glows, not a point */
.dh-fill { fill-opacity: 0.17; filter: drop-shadow(0 0 7px var(--tc, currentColor)); }
.dh-stroke { filter: drop-shadow(0 0 4px currentColor); }
.dh-tag { letter-spacing: 0.04em; }
@media (prefers-reduced-motion: no-preference) {
  .drishti-ray { stroke-dashoffset: 60; animation: drishti-flow 1.1s linear infinite, drishti-in 0.45s ease-out both; }
  .dh-fill { animation: dh-breathe 2.8s ease-in-out infinite; }
  .drishti-src { animation: drishti-srcpulse 1.8s ease-in-out infinite; }
  /* per-graha energy signatures */
  .th-guru .dh-fill   { animation: dh-bloom 2.6s ease-in-out infinite; }   /* golden bloom */
  .th-mangala .dh-fill{ animation: dh-ignite 1.4s ease-in-out infinite; } /* fiery pulse */
  .th-shani .dh-fill  { animation: dh-heavy 4.2s ease-in-out infinite; }  /* slow, structured */
  .th-ketu .dh-fill, .th-rahu .dh-fill { animation: dh-mystic 3.2s ease-in-out infinite; }
}
@keyframes drishti-flow { to { stroke-dashoffset: 0; } }
@keyframes drishti-in { from { opacity: 0; } to { opacity: 0.95; } }
@keyframes dh-breathe { 0%,100% { fill-opacity: 0.15; } 50% { fill-opacity: 0.26; } }
@keyframes dh-bloom   { 0%,100% { fill-opacity: 0.18; filter: drop-shadow(0 0 6px currentColor); } 50% { fill-opacity: 0.32; filter: drop-shadow(0 0 14px currentColor); } }
@keyframes dh-ignite  { 0%,100% { fill-opacity: 0.16; } 45% { fill-opacity: 0.34; } 55% { fill-opacity: 0.22; } }
@keyframes dh-heavy   { 0%,100% { fill-opacity: 0.24; } 50% { fill-opacity: 0.30; } }
@keyframes dh-mystic  { 0%,100% { fill-opacity: 0.10; } 50% { fill-opacity: 0.20; } }
.th-shani .dh-stroke { stroke-dasharray: 6 3; }
.th-ketu .dh-stroke, .th-rahu .dh-stroke { stroke-dasharray: 2 4; }
.drishti-hint { color: var(--ink-faint); margin: 12px 0 4px; font-size: 0.62rem; }

/* ===== Planetary Comfort & Consciousness Engine ===== */
.gc-wrap { margin-bottom: 22px; }
.gc-intro { display: flex; flex-direction: column; gap: 3px; margin-bottom: 14px; }
.gc-sub { font-size: 0.66rem; color: var(--ink-faint); }
.gc-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(230px, 1fr)); gap: 14px; }
.gc-card { position: relative; overflow: hidden; cursor: pointer; padding: 16px 16px 14px; border-radius: var(--r-md);
  background: var(--glass-fill); border: 1px solid var(--glass-border); border-top: 2px solid color-mix(in srgb, var(--pc) 55%, transparent);
  display: flex; flex-direction: column; align-items: center; text-align: center; transition: transform var(--dur-fast), box-shadow var(--dur-fast); }
.gc-card:hover { transform: translateY(-3px); box-shadow: 0 18px 40px -22px rgba(0,0,0,0.9); }
.gc-aura { position: absolute; top: -30%; left: 50%; transform: translateX(-50%); width: 150px; height: 150px; border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--pc) 50%, transparent), transparent 70%); filter: blur(26px); opacity: 0.4; pointer-events: none; }
.gc-glyph { position: relative; font-family: var(--font-glyph, serif); font-size: 2.4rem; line-height: 1; color: var(--pc); z-index: 1; }
.gc-name { font-size: 1.04rem; color: var(--ink); font-weight: 600; margin-top: 5px; z-index: 1; }
.gc-place { font-size: 0.64rem; color: var(--ink-soft); margin-top: 1px; }
.gc-kingdom { font-size: 0.52rem; color: var(--ink-faint); margin-top: 3px; }
.gc-badge { margin-top: 9px; font-size: 0.58rem; letter-spacing: 0.05em; text-transform: uppercase; padding: 3px 10px; border-radius: 999px; white-space: nowrap;
  color: var(--pc); background: color-mix(in srgb, var(--pc) 14%, transparent); border: 1px solid color-mix(in srgb, var(--pc) 34%, transparent); }
.gc-meter { width: 100%; height: 5px; border-radius: 4px; background: rgba(255,255,255,0.07); margin-top: 11px; overflow: hidden; }
.gc-meter i { display: block; height: 100%; border-radius: 4px; transition: width 700ms var(--ease-celestial, ease); }
.gc-comfort { font-size: 0.78rem; color: var(--ink); margin-top: 6px; }
.gc-comfort span { font-size: 0.56rem; color: var(--ink-faint); margin-left: 2px; }
.gc-rel { max-height: 0; opacity: 0; overflow: hidden; font-size: 0.72rem; color: var(--ink-soft); line-height: 1.42; text-align: left;
  transition: max-height var(--dur-med), opacity var(--dur-med), margin-top var(--dur-med); }
.gc-card.open .gc-rel { max-height: 640px; opacity: 1; margin-top: 11px; }
.gc-badge.s-exalted { color: #F0C84A; } .gc-badge.s-debilitated { color: #ed9aa6; }
/* per-state energy signatures */
@media (prefers-reduced-motion: no-preference) {
  .gc-card.s-exalted .gc-glyph { animation: gc-radiate 2.4s ease-in-out infinite; }
  .gc-card.s-exalted .gc-aura, .gc-card.s-moolatrikona .gc-aura { animation: gc-bloom 2.8s ease-in-out infinite; }
  .gc-card.s-own .gc-glyph { animation: gc-throne 3.6s ease-in-out infinite; }
  .gc-card.s-friend .gc-aura { animation: gc-warm 3.2s ease-in-out infinite; }
  .gc-card.s-enemy .gc-glyph { animation: gc-tense 0.5s ease-in-out infinite; }
  .gc-card.s-debilitated .gc-glyph { animation: gc-fragment 1.7s steps(8, end) infinite; }
  .gc-card.s-shadow .gc-glyph { animation: gc-drift 4s ease-in-out infinite; }
}
.gc-card.s-debilitated .gc-glyph { opacity: 0.5; }
.gc-card.s-debilitated .gc-aura { opacity: 0.16; }
.gc-card.s-neutral .gc-aura { opacity: 0.22; }
@keyframes gc-radiate { 0%,100% { filter: drop-shadow(0 0 3px var(--pc)); transform: scale(1); } 50% { filter: drop-shadow(0 0 16px var(--pc)); transform: scale(1.08); } }
@keyframes gc-bloom { 0%,100% { opacity: 0.32; transform: translateX(-50%) scale(1); } 50% { opacity: 0.6; transform: translateX(-50%) scale(1.14); } }
@keyframes gc-throne { 0%,100% { filter: drop-shadow(0 0 4px var(--pc)); } 50% { filter: drop-shadow(0 0 9px var(--pc)); } }
@keyframes gc-warm { 0%,100% { opacity: 0.3; } 50% { opacity: 0.5; } }
@keyframes gc-tense { 0%,100% { transform: translateX(0); } 25% { transform: translateX(-1.5px) rotate(-2deg); } 75% { transform: translateX(1.5px) rotate(2deg); } }
@keyframes gc-fragment { 0%,100% { opacity: 0.5; } 30% { opacity: 0.22; } 45% { opacity: 0.62; } 70% { opacity: 0.3; } }
@keyframes gc-drift { 0%,100% { transform: translateY(0); filter: blur(0); } 50% { transform: translateY(-3px); filter: blur(0.6px); } }

/* ===== Karma Chain Engine ===== */
.karma-wrap { max-width: 760px; }
.karma-houses { display: grid; grid-template-columns: repeat(12, 1fr); gap: 6px; margin: 16px 0 22px; }
.khouse { display: flex; flex-direction: column; align-items: center; gap: 1px; padding: 7px 2px; border-radius: 9px; cursor: pointer;
  background: var(--glass-fill); border: 1px solid var(--glass-border); transition: all var(--dur-fast); }
.khouse:hover { border-color: color-mix(in srgb, var(--gold) 40%, transparent); }
.khouse.on { background: rgba(212,168,67,0.14); border-color: var(--gold); box-shadow: 0 0 16px -8px var(--gold); }
.kh-num { font-size: 0.82rem; font-weight: 700; color: var(--ink); }
.kh-sign { font-size: 0.5rem; color: var(--ink-faint); text-transform: uppercase; }
.kh-lord { font-family: var(--font-glyph, serif); font-size: 0.8rem; line-height: 1; }
.karma-chain { position: relative; padding-left: 6px; }
.kchain-node { position: relative; display: flex; gap: 14px; padding: 0 0 16px 0; }
@media (prefers-reduced-motion: no-preference) { .kchain-node { animation: kchain-in 0.5s var(--ease-celestial, ease) both; } }
@keyframes kchain-in { from { transform: translateY(10px); } to { transform: none; } }
.kchain-node:not(:last-child)::before { content: ""; position: absolute; left: 13px; top: 26px; bottom: -2px; width: 2px;
  background: linear-gradient(var(--gold), color-mix(in srgb, var(--gold) 20%, transparent)); opacity: 0.5; }
.kchain-dot { flex: 0 0 auto; width: 28px; height: 28px; border-radius: 50%; display: grid; place-items: center; z-index: 1;
  background: radial-gradient(circle at 38% 32%, rgba(212,168,67,0.3), transparent), var(--void, #0a0a12); border: 1px solid var(--gold); }
.kchain-dot i { font-style: normal; font-family: var(--font-ephem); font-size: 0.68rem; color: var(--gold); font-weight: 700; }
.kchain-body { flex: 1; padding-top: 2px; }
.kchain-tag { display: block; color: var(--gold); margin-bottom: 4px; font-size: 0.58rem; }
.kchain-p { font-size: 0.82rem; color: var(--ink-soft); line-height: 1.5; margin: 0; }
.kchain-p b { color: var(--ink); }
.kchain-lord { display: flex; gap: 12px; align-items: center; }
.kchain-glyph { font-family: var(--font-glyph, serif); font-size: 1.8rem; line-height: 1; filter: drop-shadow(0 0 8px currentColor); }
.kchain-lord .gc-badge { display: inline-block; margin-top: 5px; }
.kchain-chips { display: flex; flex-wrap: wrap; gap: 7px; }
.kchain-chip { display: inline-flex; align-items: center; gap: 5px; font-size: 0.72rem; color: var(--ink-soft);
  background: rgba(255,255,255,0.04); border: 1px solid var(--glass-border); border-radius: 7px; padding: 4px 9px; }
.kchain-chip i { font-family: var(--font-glyph, serif); font-size: 0.85rem; }
.kchain-verdict { font-size: 0.86rem; line-height: 1.55; margin: 0; padding: 11px 14px; border-radius: var(--r-md); border-left: 3px solid; }
.kchain-verdict.tone-good { background: rgba(46,139,87,0.09); border-color: var(--m-green); color: #b9e6cb; }
.kchain-verdict.tone-bad { background: rgba(196,30,58,0.09); border-color: var(--m-red); color: #f0b6c0; }
.kchain-verdict.tone-mixed { background: rgba(255,140,0,0.09); border-color: var(--m-amber); color: #f3d3a0; }

/* D1↔D9 Soul Mirror (inside comfort cards) */
.gc-mirror { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 6px; margin-top: 9px; width: 100%;
  padding-top: 9px; border-top: 1px solid var(--glass-border); }
.gcm-cell { font-size: 0.6rem; color: var(--ink-faint); }
.gcm-cell b { color: var(--ink-soft); font-weight: 600; }
.gcm-arrow { color: var(--pc); font-size: 0.7rem; }
.gcm-verdict { flex-basis: 100%; text-align: center; font-size: 0.6rem; margin-top: 3px; letter-spacing: 0.03em; }
.gcm-verdict.v-genuine { color: #93e2b3; } .gcm-verdict.v-rising { color: #9fd0f0; }
.gcm-verdict.v-superficial { color: #f5c98a; } .gcm-verdict.v-frail { color: #ed9aa6; } .gcm-verdict.v-steady { color: var(--ink-soft); }
/* Ṣoḍaśavarga divisional sync strip */
.gc-vargas { margin-top: 11px; padding-top: 10px; border-top: 1px solid var(--glass-border); }
.gcv-head { color: var(--gold); margin-bottom: 8px; font-size: 0.54rem; }
.gcv-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(58px, 1fr)); gap: 5px; }
.gcv-cell { display: flex; flex-direction: column; align-items: center; gap: 1px; padding: 5px 3px; border-radius: 7px;
  background: rgba(255,255,255,0.03); border: 1px solid var(--glass-border); }
.gcv-cell b { font-size: 0.6rem; color: var(--ink); font-family: var(--font-ephem); }
.gcv-sign { font-size: 0.5rem; color: var(--ink-faint); text-transform: uppercase; }
.gcv-dig { font-size: 0.52rem; font-weight: 600; }
.gcv-cell.s-exalted, .gcv-cell.s-moolatrikona { border-color: color-mix(in srgb, var(--m-green) 50%, transparent); }
.gcv-cell.s-exalted .gcv-dig, .gcv-cell.s-moolatrikona .gcv-dig, .gcv-cell.s-own .gcv-dig { color: #93e2b3; }
.gcv-cell.s-friend .gcv-dig { color: #bfe6cd; }
.gcv-cell.s-neutral .gcv-dig, .gcv-cell.s-shadow .gcv-dig { color: var(--ink-soft); }
.gcv-cell.s-enemy .gcv-dig { color: #f5c98a; }
.gcv-cell.s-debilitated .gcv-dig { color: #ed9aa6; }
.gcv-cell.s-debilitated { border-color: color-mix(in srgb, var(--m-red) 45%, transparent); }
.gcv-avg { margin-top: 9px; font-size: 0.66rem; color: var(--ink-faint); }

/* ===== Gochar transit activation ===== */
.gochar-act { margin-top: 24px; }
.gochar-head { display: flex; flex-direction: column; gap: 3px; margin-bottom: 14px; }
.gochar-flag { display: flex; align-items: center; gap: 9px; flex-wrap: wrap; padding: 12px 15px; border-radius: var(--r-md); margin-bottom: 16px;
  background: rgba(123,93,166,0.12); border: 1px solid rgba(123,93,166,0.32); font-size: 0.8rem; color: var(--ink-soft); line-height: 1.5; }
.gochar-flag b { color: var(--retro-purple, #b79be0); }
.gf-icon { font-family: var(--font-glyph, serif); font-size: 1.1rem; color: var(--g-shani); }
.gochar-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 12px; }
.gochar-card { padding: 13px 15px; border-radius: var(--r-md); background: var(--glass-fill); border: 1px solid var(--glass-border);
  border-left: 3px solid var(--glass-border); }
.goc-top { display: flex; align-items: center; gap: 8px; margin-bottom: 7px; }
.goc-glyph { font-family: var(--font-glyph, serif); font-size: 1.25rem; color: var(--pc); line-height: 1; filter: drop-shadow(0 0 6px var(--pc)); }
.goc-name { font-size: 0.92rem; font-weight: 600; color: var(--ink); }
.goc-retro { color: var(--retro-purple, #b79be0); font-size: 0.7rem; }
.goc-key { margin-left: auto; font-size: 0.5rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gold);
  background: rgba(212,168,67,0.14); border-radius: 20px; padding: 2px 8px; }
.goc-house { font-size: 0.8rem; color: var(--pc); font-weight: 600; }
.goc-house b { color: var(--ink); }
.goc-sig { font-size: 0.62rem; color: var(--ink-faint); margin-top: 3px; line-height: 1.4; }
.goc-moon { font-size: 0.58rem; color: var(--ink-soft); margin-top: 6px; padding-top: 6px; border-top: 1px solid var(--glass-border); }

/* ===== Living chart — idle "breathing" layer (Animation Bible §1.1) ===== */
.kn-dust circle { opacity: 0.1; }
@media (prefers-reduced-motion: no-preference) {
  .kn-frame { animation: kn-breathe 8s ease-in-out infinite; }
  .kn-float { animation: kn-float 6s ease-in-out infinite; }
  .kn-dust circle { animation: kn-drift 9s ease-in-out infinite; }
}
@keyframes kn-breathe { 0%,100% { opacity: 0.55; } 50% { opacity: 0.85; } }
@keyframes kn-float { 0%,100% { transform: translateY(0.6px); } 50% { transform: translateY(-1.2px); } }
@keyframes kn-drift { 0% { opacity: 0.05; transform: translate(0,0); } 50% { opacity: 0.2; transform: translate(2px,-4px); } 100% { opacity: 0.05; transform: translate(0,0); } }

/* Daśā Activation card */
.dact { margin-top: 4px; padding: 13px 14px; border-radius: var(--r-md); background: color-mix(in srgb, var(--ac) 8%, var(--glass-fill));
  border: 1px solid color-mix(in srgb, var(--ac) 30%, transparent); border-left: 3px solid var(--ac); }
.dact-head { color: var(--ac); margin-bottom: 9px; }
.dact-row { display: flex; justify-content: space-between; gap: 10px; font-size: 0.74rem; color: var(--ink-soft); padding: 3px 0; }
.dact-k { color: var(--ink-faint); text-transform: uppercase; font-size: 0.56rem; letter-spacing: 0.08em; align-self: center; }
.dact-dig { color: var(--ac); }
.drishti-card { margin: 12px 0 6px; padding: 12px 14px; border-radius: var(--r-md); background: color-mix(in srgb, var(--dc) 9%, var(--glass-fill));
  border: 1px solid color-mix(in srgb, var(--dc) 34%, transparent); border-left: 3px solid var(--dc); }
.dr-card-top { display: flex; justify-content: space-between; align-items: center; }
.dr-card-name { font-size: 0.92rem; font-weight: 600; color: var(--dc); }
.dr-clear { background: none; border: 0; color: var(--ink-faint); font-size: 1.1rem; cursor: pointer; line-height: 1; padding: 0 2px; }
.dr-clear:hover { color: var(--ink); }
.dr-card-houses { display: flex; flex-wrap: wrap; gap: 6px; margin: 9px 0 7px; }
.dr-hchip { font-size: 0.68rem; color: var(--ink-soft); background: rgba(255,255,255,0.04); border: 1px solid var(--glass-border);
  border-radius: 6px; padding: 3px 8px; }
.dr-hchip i { font-style: normal; color: var(--dc); font-weight: 600; margin-right: 4px; }
.dr-card-mean { font-size: 0.66rem; color: var(--ink-faint); text-transform: capitalize; }
.kcl.on { color: var(--gold); }
.kcl.on i { filter: drop-shadow(0 0 4px currentColor); }

/* ===== Vimshottari Chakra (orbital view) ===== */
.dview-toggle { display: inline-flex; gap: 4px; padding: 4px; border-radius: 999px; background: var(--glass-fill);
  border: 1px solid var(--glass-border); margin-bottom: 18px; }
.dview-toggle button { border: 0; background: transparent; color: var(--ink-faint); font-size: 0.72rem; letter-spacing: 0.06em;
  padding: 7px 16px; border-radius: 999px; cursor: pointer; transition: all var(--dur-fast, 0.18s); }
.dview-toggle button.on { background: rgba(212,168,67,0.16); color: var(--gold); }
.dchakra-wrap { display: grid; grid-template-columns: minmax(0, 1fr) 318px; gap: 30px; align-items: start; }
.dchakra-stage { display: flex; flex-direction: column; gap: 20px; }
.dchakra-board { position: relative; width: 100%; max-width: 480px; aspect-ratio: 1; margin: 0 auto;
  background: radial-gradient(circle at 50% 42%, var(--nebula-violet, rgba(60,40,90,0.22)), transparent 62%); border-radius: 50%; }
.dchakra-svg { width: 100%; height: 100%; overflow: visible; }
@media (prefers-reduced-motion: no-preference) { .dchakra-svg { animation: dch-in 0.9s var(--ease-celestial, cubic-bezier(.2,.7,.2,1)); } }
@keyframes dch-in { from { transform: scale(0.88) rotate(-9deg); } to { transform: none; } }
.dch-guide { fill: none; stroke: rgba(212,168,67,0.16); stroke-width: 1; }
.dch-guide.faint { stroke: rgba(255,255,255,0.04); }
.darc { opacity: 1; }
.darc.clk { cursor: pointer; }
.darc.clk:hover path { fill-opacity: 0.4; }
@media (prefers-reduced-motion: no-preference) { .darc.on { animation: darc-pulse 3.2s ease-in-out infinite; } }
@keyframes darc-pulse { 0%,100% { filter: drop-shadow(0 0 2px rgba(212,168,67,0.35)); } 50% { filter: drop-shadow(0 0 8px rgba(212,168,67,0.85)); } }
.darc-g { font-family: var(--font-glyph, serif); pointer-events: none; font-weight: 600; }
.dnow-dot { fill: #fff; stroke: var(--gold-bright); stroke-width: 1.2; animation: dnow 1.6s ease-in-out infinite; }
@keyframes dnow { 0%,100% { opacity: 0.55; r: 2.6px; } 50% { opacity: 1; r: 4px; } }
.dchakra-hub { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 2px; pointer-events: none; }
.dch-hub-glyph { font-size: 2rem; line-height: 1; filter: drop-shadow(0 0 10px currentColor); }
.dch-hub-eye { font-size: 0.52rem; color: var(--ink-faint); margin-top: 4px; }
.dch-hub-date { font-size: 0.62rem; color: var(--gold); }
/* lifetime ribbon */
.dlife { width: 100%; max-width: 520px; margin: 0 auto; }
.dlife-bar { position: relative; display: flex; height: 30px; border-radius: 8px; overflow: hidden; border: 1px solid var(--glass-border); }
.dlife-seg { border: 0; padding: 0; cursor: pointer; display: grid; place-items: center; transition: opacity var(--dur-fast, 0.18s);
  border-right: 1px solid rgba(0,0,0,0.25); }
.dlife-seg.on { box-shadow: inset 0 0 0 1.5px var(--gold-bright); }
.dlife-g { font-family: var(--font-glyph, serif); font-size: 0.8rem; color: rgba(0,0,0,0.62); }
.dlife-now { position: absolute; top: -3px; bottom: -3px; width: 2px; background: var(--gold-bright); box-shadow: 0 0 8px var(--gold-bright); }
.dlife-now::after { content: "▾"; position: absolute; top: -13px; left: 50%; transform: translateX(-50%); color: var(--gold-bright); font-size: 0.7rem; }
.dlife-axis { display: flex; justify-content: space-between; margin-top: 6px; font-size: 0.6rem; color: var(--ink-faint); }
/* side panel */
.dchakra-side { display: flex; flex-direction: column; gap: 16px; }
.dpath { background: var(--glass-fill); border: 1px solid var(--glass-border); border-radius: var(--r-md); padding: 14px; }
.dpath-head { color: var(--gold); margin-bottom: 12px; }
.dpath-row { display: flex; gap: 11px; align-items: flex-start; padding: 9px 8px; border-radius: 9px; border-left: 2px solid transparent; }
.dpath-row.run { background: rgba(212,168,67,0.07); border-left-color: var(--pc); }
.dpath-glyph { font-family: var(--font-glyph, serif); font-size: 1.25rem; line-height: 1; width: 22px; text-align: center; }
.dpath-main { flex: 1; min-width: 0; }
.dpath-top { display: flex; justify-content: space-between; align-items: baseline; gap: 8px; }
.dpath-lord { font-size: 0.9rem; font-weight: 600; color: var(--ink); }
.dpath-lvl { font-size: 0.56rem; color: var(--ink-faint); text-transform: uppercase; letter-spacing: 0.08em; }
.dpath-dates { font-size: 0.62rem; color: var(--ink-soft); margin-top: 2px; }
.dpath-prog { height: 3px; border-radius: 3px; background: rgba(255,255,255,0.08); margin-top: 6px; overflow: hidden; }
.dpath-prog i { display: block; height: 100%; border-radius: 3px; }
.dlegend { display: flex; flex-wrap: wrap; gap: 5px 12px; padding: 0 4px; }
.dleg { display: inline-flex; align-items: center; gap: 5px; font-size: 0.62rem; color: var(--ink-soft); }
.dleg i { width: 8px; height: 8px; border-radius: 50%; background: var(--pc); }
@media (max-width: 880px) {
  .dchakra-wrap { grid-template-columns: 1fr; }
}

/* ashtakavarga */
.av-wrap { overflow-x: auto; }
/* sarva heat-map chart */
.avh-block { margin-bottom: 28px; }
.avh-stage { display: flex; gap: 24px; align-items: center; flex-wrap: wrap; }
.avh-svg { width: 340px; max-width: 100%; flex: 0 0 auto; }
.avh-num { font-family: var(--font-ephem); font-size: 14px; font-weight: 700; }
.avh-sgn { font-family: var(--font-ephem); font-size: 7px; fill: var(--ink-faint); text-transform: uppercase; }
.avh-house polygon { transition: fill-opacity var(--dur-med); }
.avh-legend { flex: 1; min-width: 200px; display: flex; flex-direction: column; gap: 8px; }
.avh-leg { display: flex; align-items: center; gap: 9px; font-size: 0.74rem; color: var(--ink-soft); }
.avh-leg i { width: 12px; height: 12px; border-radius: 3px; flex: 0 0 auto; }
.avh-note { font-size: 0.68rem; color: var(--ink-faint); line-height: 1.45; margin-top: 6px; }

/* ===== Graha Deep-Dive drawer (Animation Bible §1.5) ===== */
.ktbl-click { cursor: pointer; transition: background var(--dur-fast); }
.ktbl-click:hover { background: rgba(212,168,67,0.07); }
.dd-backdrop { position: fixed; inset: 0; background: rgba(5,4,12,0.6); backdrop-filter: blur(3px); z-index: 90; display: flex; justify-content: flex-end; }
@media (prefers-reduced-motion: no-preference) { .dd-backdrop { animation: dd-fade 0.25s ease both; } }
@keyframes dd-fade { from { opacity: 0; } to { opacity: 1; } }
.dd-drawer { width: 400px; max-width: 92vw; height: 100%; overflow-y: auto; background: linear-gradient(180deg, var(--void2, #150D28), var(--void, #0D0618));
  border-left: 1px solid color-mix(in srgb, var(--pc) 40%, var(--glass-border)); padding: 26px 24px 40px; position: relative;
  box-shadow: -30px 0 80px -30px #000; }
@media (prefers-reduced-motion: no-preference) { .dd-drawer { animation: dd-slide 0.4s var(--ease-celestial, cubic-bezier(.2,.7,.2,1)) both; } }
@keyframes dd-slide { from { transform: translateY(18px); } to { transform: none; } }
.dd-close { position: absolute; top: 16px; right: 18px; background: none; border: 0; color: var(--ink-faint); font-size: 1.5rem; cursor: pointer; line-height: 1; }
.dd-close:hover { color: var(--ink); }
.dd-head { display: flex; align-items: center; gap: 14px; margin-bottom: 22px; }
.dd-glyph { font-family: var(--font-glyph, serif); font-size: 2.6rem; line-height: 1; color: var(--pc); filter: drop-shadow(0 0 14px var(--pc)); }
.dd-name { font-size: 1.5rem; color: var(--ink); font-weight: 600; }
.dd-en { font-size: 0.68rem; color: var(--ink-soft); margin-top: 2px; }
.dd-sec { margin-bottom: 20px; }
.dd-lbl { display: block; color: var(--pc); margin-bottom: 9px; }
.dd-ok { color: var(--m-green); text-transform: none; letter-spacing: 0; margin-left: 6px; }
.dd-no { color: var(--m-red); text-transform: none; letter-spacing: 0; margin-left: 6px; }
.dd-rows { display: flex; flex-direction: column; gap: 1px; }
.dd-r { display: flex; justify-content: space-between; gap: 14px; padding: 7px 0; border-bottom: 1px solid var(--glass-border); font-size: 0.82rem; }
.dd-r > span:first-child { color: var(--ink-faint); font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.08em; align-self: center; }
.dd-r > span:last-child { color: var(--ink-soft); text-align: right; }
.dd-bars { display: flex; flex-direction: column; gap: 7px; }
.dd-bar { display: grid; grid-template-columns: 70px 1fr 34px; gap: 9px; align-items: center; }
.dd-bk { font-size: 0.66rem; color: var(--ink-soft); }
.dd-bt { height: 6px; border-radius: 4px; background: rgba(255,255,255,0.07); overflow: hidden; }
.dd-bt i { display: block; height: 100%; border-radius: 4px; transition: width 600ms var(--ease-celestial, ease); }
.dd-bv { font-size: 0.66rem; color: var(--ink-faint); text-align: right; }
.dd-varga { display: grid; grid-template-columns: repeat(auto-fill, minmax(52px, 1fr)); gap: 5px; }
.dd-vc { display: flex; flex-direction: column; align-items: center; gap: 1px; padding: 5px 2px; border-radius: 6px; background: rgba(255,255,255,0.03); border: 1px solid var(--glass-border); }
.dd-vc b { font-size: 0.6rem; color: var(--ink); font-family: var(--font-ephem); }
.dd-vc span { font-size: 0.52rem; color: var(--ink-faint); text-transform: uppercase; }
.dd-vc.s-exalted, .dd-vc.s-moolatrikona, .dd-vc.s-own { border-color: color-mix(in srgb, var(--m-green) 45%, transparent); }
.dd-vc.s-debilitated { border-color: color-mix(in srgb, var(--m-red) 45%, transparent); }
.av-cap { margin: 0 0 12px; color: var(--ink-faint); }
.av-sarva { margin-bottom: 26px; }
.av-bars { display: grid; grid-template-columns: repeat(12, 1fr); gap: 6px; align-items: end; height: 170px; min-width: 600px; }
.avb { display: flex; flex-direction: column; align-items: center; gap: 4px; height: 100%; justify-content: flex-end; }
.avb-track { width: 100%; flex: 1; display: flex; align-items: flex-end; background: rgba(255,255,255,0.03); border-radius: 4px; }
.avb-track span { width: 100%; background: linear-gradient(var(--gold-bright), var(--gold-dim)); border-radius: 4px; min-height: 3px; }
.avb-val { font-size: 0.7rem; color: var(--gold); }
.avb-sign { font-size: 0.55rem; color: var(--ink-faint); }
.av-grid { display: grid; gap: 2px; min-width: 720px; }
.avg-h { font-size: 0.55rem; text-align: center; padding: 4px 0; color: var(--ink-faint); }
.avg-rl { font-size: 0.7rem; padding: 6px 8px; color: var(--ink-soft); display: flex; align-items: center; }
.avg-rl.gold { color: var(--gold); font-weight: 700; }
.avg-c { text-align: center; padding: 6px 0; font-size: 0.72rem; border-radius: 4px; color: var(--ink); }
.avg-c.gold { background: rgba(212,168,67,0.18) !important; color: var(--gold); font-weight: 700; }

/* shadbala */
.sb-wrap { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 14px; }
.sb-card { background: var(--glass-fill); border: 1px solid var(--glass-border); border-radius: var(--r-md); padding: 14px; }
.sb-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 10px; }
.sb-name { font-size: 1.1rem; color: var(--gold); font-weight: 600; }
.sb-rank { color: var(--ink-faint); }
.sb-bar { position: relative; height: 8px; background: rgba(255,255,255,0.06); border-radius: 8px; margin-bottom: 8px; }
.sb-bar span { display: block; height: 100%; border-radius: 8px; }
.sb-min { position: absolute; top: -3px; width: 2px; height: 14px; background: var(--ink); opacity: 0.7; }
.sb-figs { font-size: 0.72rem; color: var(--ink-soft); margin-bottom: 10px; }
.sb-figs b { color: var(--gold); }
.sb-comps { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 10px; }
.sbc { display: flex; flex-direction: column; gap: 1px; background: rgba(255,255,255,0.03); border-radius: 6px; padding: 5px 8px; font-size: 0.75rem; color: var(--ink); }
.sbc i { font-size: 0.5rem; color: var(--ink-faint); }
.sb-ik { display: flex; gap: 8px; }
.ik { font-size: 0.62rem; padding: 4px 8px; border-radius: 6px; }
.ik.good { color: #93e2b3; background: rgba(46,139,87,0.16); }
.ik.bad { color: #ed9aa6; background: rgba(196,30,58,0.16); }

/* bhavabala */
.bb-wrap { display: flex; flex-direction: column; gap: 6px; max-width: 700px; }
.bb-row { display: grid; grid-template-columns: 42px 42px 1fr 58px; gap: 12px; align-items: center; }
.bb-h { color: var(--gold); font-size: 1rem; font-weight: 600; }
.bb-rank { color: var(--ink-faint); font-size: 0.6rem; }
.bb-bar { height: 10px; background: rgba(255,255,255,0.05); border-radius: 8px; overflow: hidden; }
.bb-bar span { display: block; height: 100%; background: linear-gradient(90deg, var(--gold-dim), var(--gold)); border-radius: 8px; }
.bb-val { font-size: 0.78rem; color: var(--ink-soft); text-align: right; }

/* dosha */
.dosha-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 14px; }
.dosha-card { background: var(--glass-fill); border: 1px solid var(--glass-border); border-radius: var(--r-md);
  padding: 16px; border-left: 4px solid var(--glass-border); display: flex; flex-direction: column; gap: 7px; }
.dosha-card.good { border-left-color: var(--m-green); }
.dosha-card.mid { border-left-color: var(--m-amber); }
.dosha-card.bad { border-left-color: var(--m-red); }
.dc-top { display: flex; justify-content: space-between; align-items: flex-start; gap: 10px; }
.dc-medallion { flex: 0 0 auto; width: 34px; height: 34px; display: grid; place-items: center; border-radius: 50%;
  font-size: 0.95rem; border: 1px solid var(--glass-border); }
.dosha-card.good .dc-medallion { color: #93e2b3; background: radial-gradient(circle at 38% 32%, rgba(46,139,87,0.28), transparent); box-shadow: 0 0 14px -6px var(--m-green); }
.dosha-card.mid .dc-medallion { color: #f5c98a; background: radial-gradient(circle at 38% 32%, rgba(255,140,0,0.26), transparent); box-shadow: 0 0 14px -6px var(--m-amber); }
.dosha-card.bad .dc-medallion { color: #ed9aa6; background: radial-gradient(circle at 38% 32%, rgba(196,30,58,0.28), transparent); box-shadow: 0 0 14px -6px var(--m-red); }
.dc-name { flex: 1; }
.pc-medallion { flex: 0 0 auto; width: 34px; height: 34px; display: grid; place-items: center; border-radius: 50%;
  font-size: 0.95rem; border: 1px solid var(--glass-border); background: rgba(255,255,255,0.03); }
.pc-top .pc-name { flex: 1; }
.dc-name { font-size: 1.05rem; color: var(--ink); font-weight: 600; line-height: 1.14; }
.dc-status { flex: 0 0 auto; font-size: 0.56rem; padding: 3px 9px; border-radius: 6px; text-transform: uppercase; letter-spacing: 0.06em; white-space: nowrap; }
.dc-status.good { color: #93e2b3; background: rgba(46,139,87,0.16); }
.dc-status.mid { color: #f5c98a; background: rgba(255,140,0,0.16); }
.dc-status.bad { color: #ed9aa6; background: rgba(196,30,58,0.16); }
.dc-from { color: var(--gold); }
.dc-note { font-size: 0.76rem; color: var(--ink-soft); line-height: 1.4; margin: 0; }

/* shodhya pinda */
.shodhya { display: flex; flex-direction: column; gap: 2px; min-width: 560px; }
.sh-row { display: grid; grid-template-columns: 90px repeat(8, 1fr); gap: 4px; align-items: center; }
.sh-row span { text-align: center; font-size: 0.72rem; padding: 5px 0; }
.sh-row.sh-head span { color: var(--ink-faint); }
.sh-l { text-align: left !important; color: var(--ink-soft); font-size: 0.7rem !important; }
.sh-row.gold span { color: var(--gold); font-weight: 700; }

/* varshaphal */
.varsha { display: flex; flex-direction: column; gap: 18px; }
.vp-note { font-size: 0.82rem; color: var(--ink-soft); line-height: 1.45; margin: 12px 0 0; }
.mudda { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 10px; }
.mudda-seg { display: flex; flex-direction: column; gap: 2px; padding: 12px 14px; border-radius: var(--r-md);
  background: rgba(255,255,255,0.03); border: 1px solid var(--glass-border); }
.mudda-seg.cur { border-color: var(--gold); box-shadow: 0 0 22px -10px var(--gold); }
.md-lord { font-size: 1.05rem; color: var(--gold); }
.md-span { font-size: 0.72rem; color: var(--ink); }
.md-from { font-size: 0.62rem; color: var(--ink-faint); }

/* phala — classical rules */
.phala-bar { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 16px; flex-wrap: wrap; }
.phala-toggle { display: flex; align-items: center; gap: 7px; font-size: 0.74rem; color: var(--ink-soft); cursor: pointer; white-space: nowrap; }
.phala-toggle input { accent-color: var(--gold); }
.phala-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 14px; }
.phala-card { background: var(--glass-fill); border: 1px solid var(--glass-border); border-radius: var(--r-md);
  padding: 16px; display: flex; flex-direction: column; gap: 9px; }
.phala-card.applies { border-color: var(--gold); box-shadow: 0 0 32px -16px var(--gold); }
.phala-card.unverified { opacity: 0.6; }
.ph-top { display: flex; align-items: baseline; gap: 8px; }
.ph-id { font-size: 0.6rem; color: var(--ink-faint); }
.ph-name { font-size: 1.05rem; color: var(--gold); font-weight: 600; line-height: 1.1; flex: 1; }
.ph-status { font-size: 0.48rem; padding: 2px 7px; border-radius: 5px; text-transform: uppercase; letter-spacing: 0.06em; white-space: nowrap; }
.ph-status.verified { color: #93e2b3; background: rgba(46,139,87,0.16); }
.ph-status.corrected { color: #f5c98a; background: rgba(255,140,0,0.16); }
.ph-status.unverified { color: #ed9aa6; background: rgba(196,30,58,0.18); }
.ph-meta { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.ph-src { font-size: 0.62rem; color: var(--ink-faint); font-family: var(--font-ephem); }
.ph-badge { font-size: 0.56rem; padding: 2px 8px; border-radius: 999px; }
.ph-badge.good { color: #93e2b3; background: rgba(46,139,87,0.16); }
.ph-badge.bad { color: #ed9aa6; background: rgba(196,30,58,0.16); }
.ph-planet { font-size: 0.56rem; color: var(--gold); padding: 2px 8px; border-radius: 999px; background: rgba(212,168,67,0.1); }
.ph-trigger { font-size: 0.76rem; color: var(--ink-soft); line-height: 1.4; }
.ph-trigger b, .ph-foot b { display: block; color: var(--ink-faint); margin-bottom: 2px; }
.ph-block .ph-h { display: block; margin-bottom: 4px; }
.good-h { color: #93e2b3; } .bad-h { color: #ed9aa6; }
.ph-block ul { margin: 0; padding-left: 16px; display: flex; flex-direction: column; gap: 2px; }
.ph-block li { font-size: 0.72rem; color: var(--ink-soft); line-height: 1.35; }
.ph-foot { display: flex; flex-direction: column; gap: 6px; padding-top: 8px; border-top: 1px solid var(--glass-border); }
.ph-foot span { font-size: 0.7rem; color: var(--ink-soft); line-height: 1.35; }
.ph-warn { font-size: 0.68rem; color: #ed9aa6; background: rgba(196,30,58,0.1); border: 1px solid rgba(196,30,58,0.25);
  border-radius: 7px; padding: 8px 10px; }

/* pitra dosha */
.pitra-hero { display: grid; grid-template-columns: 150px 1fr; gap: 24px; align-items: center; margin-bottom: 22px;
  background: var(--glass-fill); border: 1px solid var(--glass-border); border-radius: var(--r-lg); padding: 20px 24px; }
.pitra-gauge svg { width: 140px; height: 140px; }
.ps-cat { font-size: 1.5rem; font-weight: 600; }
.ps-urgency { color: var(--ink-faint); margin: 3px 0 10px; }
.ps-stats { display: flex; flex-wrap: wrap; gap: 16px; font-size: 0.78rem; color: var(--ink-soft); }
.ps-stats b { color: var(--gold); margin-right: 4px; }
.ps-warn { margin-top: 12px; font-size: 0.72rem; color: #ed9aa6; background: rgba(196,30,58,0.1);
  border: 1px solid rgba(196,30,58,0.25); border-radius: 8px; padding: 9px 12px; }
.pitra-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 14px; }
.pitra-card { background: var(--glass-fill); border: 1px solid var(--glass-border); border-left: 4px solid var(--glass-border);
  border-radius: var(--r-md); padding: 16px; display: flex; flex-direction: column; gap: 9px; }
.pitra-card.off { opacity: 0.5; }
.pc-top { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; }
.pc-name { font-size: 1.05rem; color: var(--gold); font-weight: 600; line-height: 1.12; }
.pc-sev { font-size: 0.56rem; font-weight: 700; letter-spacing: 0.06em; }
.pc-meta { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.pc-type { font-size: 0.58rem; color: var(--ink-faint); font-family: var(--font-ephem); }
.pc-conf { font-size: 0.62rem; color: var(--silver); padding: 1px 7px; border-radius: 999px; background: rgba(255,255,255,0.05); }
.pc-coll { font-size: 0.54rem; color: #f5c98a; background: rgba(255,140,0,0.16); padding: 2px 7px; border-radius: 999px; }
.pc-active { font-size: 0.54rem; color: #93e2b3; background: rgba(46,139,87,0.16); padding: 2px 7px; border-radius: 999px; }
.pc-cause { font-size: 0.74rem; color: var(--ink-soft); line-height: 1.4; }
.pc-cause b, .pitra-card .eyebrow { display: block; color: var(--ink-faint); margin-bottom: 2px; }
.pc-block ul { margin: 0; padding-left: 16px; display: flex; flex-direction: column; gap: 2px; }
.pc-block li { font-size: 0.72rem; color: var(--ink-soft); line-height: 1.35; }
.pc-src { font-size: 0.6rem; color: var(--ink-faint); padding-top: 6px; border-top: 1px solid var(--glass-border); }
@media (max-width: 700px) { .pitra-hero { grid-template-columns: 1fr; justify-items: center; text-align: center; } }

@media (max-width: 1100px) {
  .ku-ws { grid-template-columns: 1fr; }
  .ku-sidenav { position: static; }
  .ku-subnav { flex-direction: row; flex-wrap: wrap; }
  .kusub { flex: 0 0 auto; }
  .kchart-stage { grid-template-columns: 1fr; }
  .kp-grid { grid-template-columns: 1fr; }
  .dasha5 { grid-template-columns: repeat(2, 1fr); }
  .sb-wrap { grid-template-columns: 1fr; }
}
