*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Noto Sans Thai',sans-serif;background:#0f172a;color:#e2e8f0;min-height:100vh}
.container{max-width:720px;margin:0 auto;padding:1rem}
h1{color:#f59e0b;font-size:1.4rem;text-align:center;margin-bottom:.5rem}
.subtitle{color:#94a3b8;text-align:center;font-size:.85rem;margin-bottom:1.2rem}
label{display:block;color:#94a3b8;font-size:.85rem;margin-bottom:.25rem;margin-top:.6rem}
input,select{width:100%;padding:.5rem;border:1px solid #334155;border-radius:6px;background:#1e293b;color:#e2e8f0;font-size:.95rem;outline:none}
input:focus,select:focus{border-color:#f59e0b}
.row{display:flex;gap:.5rem}
.row>*{flex:1}
.cb-row{display:flex;align-items:center;gap:.5rem;margin-top:.5rem}
.cb-row input[type=checkbox]{width:auto}
.cb-row label{margin:0;color:#94a3b8;font-size:.8rem}
.btn-main{display:block;width:100%;padding:.7rem;margin-top:1rem;border:none;border-radius:8px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#1e293b;font-size:1rem;font-weight:700;cursor:pointer;letter-spacing:.5px}
.btn-main:hover{opacity:.9}
.btn-main:disabled{opacity:.5;cursor:not-allowed}
.tab-bar{display:flex;justify-content:center;gap:.5rem;margin-top:.8rem;flex-wrap:wrap}
.tab-btn{padding:.4rem 1rem;border:none;border-radius:6px;background:#d4a373;color:#1e293b;font-size:.85rem;font-weight:600;cursor:pointer}
.tab-btn.active{background:#f59e0b;box-shadow:0 0 8px rgba(245,158,11,.4)}
.tab-btn:hover{opacity:.85}
#results{display:none;margin-top:1.5rem;text-align:center}
#results .birth-info{color:#f59e0b;font-size:1.05rem;margin-bottom:.25rem}
#results .lakkana-name{color:#38bdf8;font-size:1.15rem;font-weight:700;margin:.5rem 0}
.star-info{margin:.4rem 0;font-size:.95rem}
.star-info strong{color:#f59e0b}
.star-label{color:#94a3b8}
#binaryBtn{display:none;margin:1rem auto;padding:.5rem 1.5rem;border:none;border-radius:8px;background:#d4a373;color:#1e293b;font-weight:600;cursor:pointer;font-size:.9rem}
#binarySection{display:none;margin-top:1rem}
#binarySection table{width:100%;border-collapse:collapse;font-size:.82rem}
#binarySection th{background:#1e293b;color:#f59e0b;padding:.4rem;border:1px solid #334155;text-align:left}
#binarySection td{padding:.4rem;border:1px solid #334155}
.pair-type{color:#94a3b8;font-size:.75rem}
.loading{text-align:center;color:#f59e0b;padding:2rem;display:none}

/* ============================================================ */
/* Time Adjustment Slider                                        */
/* ============================================================ */
#timeSliderArea{margin-top:.6rem}
.time-slider-panel{background:#1e293b;border:1px solid #334155;border-radius:8px;padding:.6rem .8rem}
.time-slider-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.3rem}
.time-slider-icon{font-size:1.1rem}
.time-slider-title{color:#f59e0b;font-size:.85rem;font-weight:700;flex:1}
.time-slider-value{color:#22d3ee;font-size:1rem;font-weight:800;font-variant-numeric:tabular-nums;letter-spacing:1px}
.time-slider-ticks{position:relative;height:18px;margin:0 6px}
.ts-tick{position:absolute;display:flex;flex-direction:column;align-items:center;transform:translateX(-50%)}
.ts-tick-label{font-size:.55rem;color:#64748b;line-height:1;margin-bottom:1px;font-variant-numeric:tabular-nums}
.ts-tick-line{display:block;width:1px;height:6px;background:#334155}
.ts-tick-line.ts-tick-major{height:9px;background:#475569;width:1.5px}
.time-slider-row{display:flex;align-items:center;padding:0 4px}
.time-slider-row input[type=range]{flex:1;-webkit-appearance:none;height:8px;border-radius:4px;background:#1a2332;border:1px solid #334155;outline:none;cursor:pointer}
.time-slider-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,#f59e0b,#d97706);border:2px solid #0f172a;box-shadow:0 0 10px rgba(245,158,11,.4);cursor:grab}
.time-slider-row input[type=range]::-webkit-slider-thumb:active{cursor:grabbing;box-shadow:0 0 16px rgba(245,158,11,.6)}
.time-slider-row input[type=range]::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,#f59e0b,#d97706);border:2px solid #0f172a;cursor:grab}
.time-slider-row input[type=range]::-moz-range-track{height:8px;border-radius:4px;background:#1a2332;border:1px solid #334155}
.time-slider-display{text-align:center;font-size:.8rem;color:#94a3b8;margin-top:.4rem;font-variant-numeric:tabular-nums}
.time-slider-btns{display:flex;justify-content:center;gap:.3rem;margin-top:.5rem;flex-wrap:wrap}
.time-slider-btn{padding:.3rem .5rem;border:none;border-radius:5px;background:#334155;color:#e2e8f0;font-size:.7rem;font-weight:600;cursor:pointer;white-space:nowrap}
.time-slider-btn:hover{background:#475569}
.time-slider-btn.time-slider-reset{background:#f59e0b;color:#1e293b}
.time-slider-btn.time-slider-reset:hover{background:#d97706}

/* ============================================================ */
/* Square Chart Grid                                            */
/* ============================================================ */
#chartArea{display:none;margin-top:1.2rem}
.chart-grid{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  grid-template-rows:1fr 1fr 2fr 1fr 1fr;
  aspect-ratio:1/1;
  width:100%;
  max-width:580px;
  margin:0 auto;
  border:2px solid #64748b;
  background:#1e293b;
}
.cell{
  border:1px solid #475569;
  padding:4px 6px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  position:relative;
  overflow:hidden;
}
.cell.center-cell{background:#0f172a}

/* Grid placement */
.g-r1  {grid-row:1;grid-column:1}
.g-r2  {grid-row:2;grid-column:1}
.g-r0  {grid-row:1/3;grid-column:2}
.g-r11 {grid-row:1;grid-column:3}
.g-r10 {grid-row:2;grid-column:3}
.g-r3  {grid-row:3;grid-column:1}
.g-ctr {grid-row:3;grid-column:2}
.g-r9  {grid-row:3;grid-column:3}
.g-r4  {grid-row:4;grid-column:1}
.g-r5  {grid-row:5;grid-column:1}
.g-r6  {grid-row:4/6;grid-column:2}
.g-r8  {grid-row:4;grid-column:3}
.g-r7  {grid-row:5;grid-column:3}

/* Cell content */
.cell-label{font-size:.65rem;color:#94a3b8;position:absolute;top:2px;left:4px;line-height:1}
.cell-time{font-size:.6rem;color:#64748b;position:absolute;top:2px;right:3px;line-height:1}
.cell-planets{font-size:1.05rem;font-weight:700;color:#f8fafc;letter-spacing:2px;text-align:center;line-height:1.2}
.cell-lak{color:#ef4444;font-size:.75rem;font-weight:700}
.cell-transit{font-size:.85rem;font-weight:700;color:#22d3ee;letter-spacing:1px;text-align:center;line-height:1.2;margin-top:1px}
.cell-transit-from{font-size:.55rem;color:#67e8f9;text-align:center;line-height:1.15;margin-top:0;opacity:.85}
.cell-yok{font-size:.9rem;font-weight:700;color:#f8fafc;letter-spacing:2px;text-align:center;line-height:1.2;opacity:.25}
.cell-yok-label{font-size:.5rem;color:#94a3b8;opacity:.4;text-align:center;line-height:1}
.cell-deva{color:#ef4444;font-size:.7rem;font-weight:700;position:absolute;bottom:2px;right:4px}
.center-ongsa{font-size:1.5rem;font-weight:700;color:#e2e8f0}
.center-lakkana{font-size:.7rem;color:#38bdf8;margin-top:1px}
.center-transit-date{font-size:.6rem;color:#22d3ee;margin-top:2px}

/* ============================================================ */
/* View Switcher                                                 */
/* ============================================================ */
.view-switch{display:flex;justify-content:center;gap:6px;margin:8px 0}
.vs-btn{padding:5px 14px;border:1px solid #334155;border-radius:20px;background:#1e293b;color:#94a3b8;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .2s}
.vs-btn.active{background:linear-gradient(135deg,#0ea5e9,#6366f1);color:#fff;border-color:transparent;box-shadow:0 2px 12px rgba(99,102,241,.3)}
.vs-btn:hover:not(.active){border-color:#64748b;color:#e2e8f0}

/* ============================================================ */
/* Modern Circular Chart                                         */
/* ============================================================ */
.mc-wrap{position:relative;width:100%;max-width:620px;margin:0 auto;aspect-ratio:1;display:none}
.mc-wrap.active{display:block}

/* Concentric ring decorations */
.mc-ring-bg{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;border:1px solid rgba(71,85,105,.25)}
.mc-ring-bg.r1{width:92%;height:92%}
.mc-ring-bg.r2{width:64%;height:64%;border-style:dashed;border-color:rgba(71,85,105,.18)}
.mc-ring-bg.r3{width:36%;height:36%;border-color:rgba(71,85,105,.12)}

/* Tick marks - subtle lines from center outward */
.mc-tick{position:absolute;top:50%;left:50%;width:1px;height:46%;transform-origin:bottom center;background:linear-gradient(to top,transparent 30%,rgba(71,85,105,.15) 60%,transparent 95%)}

/* Center hub */
.mc-hub{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100px;height:100px;border-radius:50%;background:radial-gradient(circle at 40% 40%,#1e293b,#0f172a);border:2px solid #334155;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10;box-shadow:0 0 40px rgba(15,23,42,.9),inset 0 0 20px rgba(15,23,42,.5)}
.mc-hub-ongsa{font-size:1.2rem;font-weight:800;color:#e2e8f0;letter-spacing:1px}
.mc-hub-lak{font-size:.6rem;color:#38bdf8;margin-top:2px;font-weight:600}
.mc-hub-date{font-size:.5rem;color:#22d3ee;margin-top:2px}

/* Node cards */
.mc-node{position:absolute;transform:translate(-50%,-50%);width:76px;padding:5px 4px;background:rgba(30,41,59,.88);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid #334155;border-radius:10px;display:flex;flex-direction:column;align-items:center;transition:all .25s cubic-bezier(.4,0,.2,1);cursor:default;z-index:5}
.mc-node:hover{transform:translate(-50%,-50%) scale(1.15);border-color:#38bdf8;box-shadow:0 0 20px rgba(56,189,248,.25),0 8px 32px rgba(0,0,0,.4);z-index:20}
.mc-node.mc-lak-node{border-color:#f59e0b;box-shadow:0 0 14px rgba(245,158,11,.2)}
.mc-node.mc-lak-node:hover{border-color:#fbbf24;box-shadow:0 0 24px rgba(245,158,11,.35),0 8px 32px rgba(0,0,0,.4)}

/* Node content */
.mc-rasi{font-size:.58rem;color:#94a3b8;font-weight:700;letter-spacing:.5px;text-transform:uppercase}
.mc-bhava{font-size:.48rem;color:#64748b;margin-top:1px}
.mc-time{font-size:.42rem;color:#475569;margin-top:1px}
.mc-pl{font-size:1.05rem;font-weight:800;color:#f8fafc;letter-spacing:3px;margin:3px 0 1px;text-shadow:0 0 8px rgba(248,250,252,.15)}
.mc-pl-yok{font-size:.82rem;font-weight:700;color:#f8fafc;letter-spacing:2px;opacity:.22;margin:2px 0 0}
.mc-yok-src{font-size:.4rem;color:#94a3b8;opacity:.45}
.mc-tr{font-size:.78rem;font-weight:700;color:#22d3ee;letter-spacing:1px;margin-top:2px}
.mc-tr-from{font-size:.42rem;color:#67e8f9;opacity:.8;margin-top:0}
.mc-lak-badge{display:inline-block;background:#ef4444;color:#fff;font-size:.45rem;font-weight:800;padding:1px 4px;border-radius:3px;margin-bottom:2px;letter-spacing:.5px}
.mc-deva{color:#ef4444;font-size:.55rem;font-weight:700;margin-top:1px}
.mc-trend{font-size:.48rem;font-weight:600;color:#94a3b8;margin-top:2px;padding:1px 5px;border-radius:4px;background:rgba(148,163,184,.1)}

/* Person 2 node color */
.mc-pl-2{color:#c4b5fd}
.mc-hub-lak-2{color:#a78bfa}

/* ============================================================ */
/* Zodiac Wheel Chart                                            */
/* ============================================================ */
.zw-wrap{display:none;position:relative;width:100%;max-width:700px;margin:0 auto;aspect-ratio:1}
.zw-wrap.active{display:block}
.zw-svg{width:100%;height:100%}

/* Cosmic background */
.zw-bg-gradient{stop-color:#0f172a}
.zw-star{fill:#fff;opacity:.5}

/* Ring styles */
.zw-outer-ring{fill:none;stroke:rgba(100,116,139,.4);stroke-width:.8}
.zw-mid-ring{fill:none;stroke:rgba(100,116,139,.25);stroke-width:.5}
.zw-inner-ring{fill:none;stroke:rgba(100,116,139,.18);stroke-width:.5;stroke-dasharray:3 3}
.zw-rasi-divider{stroke:rgba(100,116,139,.2);stroke-width:.5}
.zw-rasi-arc{fill:rgba(30,41,59,.3);stroke:rgba(71,85,105,.3);stroke-width:.3;cursor:pointer;transition:fill .2s}
.zw-rasi-arc:hover{fill:rgba(56,189,248,.08)}
.zw-rasi-arc.zw-lak-arc{fill:rgba(245,158,11,.06);stroke:rgba(245,158,11,.3);stroke-width:.6}

/* Zodiac symbol on outer ring */
.zw-zodiac-sym{font-size:13px;fill:#64748b;text-anchor:middle;dominant-baseline:central;font-weight:700}
.zw-zodiac-sym.zw-lak-sym{fill:#f59e0b;font-size:15px}

/* Rasi name label */
.zw-rasi-label{font-size:7px;fill:#94a3b8;text-anchor:middle;dominant-baseline:central;font-weight:600;letter-spacing:.5px}

/* Planet dot */
.zw-planet-dot{cursor:default;transition:all .2s}
.zw-planet-dot:hover{filter:brightness(1.5)}
.zw-pl-circle{stroke-width:1.5}
.zw-pl-num{font-size:9px;font-weight:800;text-anchor:middle;dominant-baseline:central}
.zw-pl-name{font-size:5.5px;fill:#94a3b8;text-anchor:middle;dominant-baseline:central}

/* Transit planet */
.zw-tr-circle{fill:#0f172a;stroke:#22d3ee;stroke-width:1.2}
.zw-tr-num{font-size:8px;font-weight:700;fill:#22d3ee;text-anchor:middle;dominant-baseline:central}

/* Aspect lines */
.zw-aspect-line{stroke-width:.8;fill:none;opacity:.5}
.zw-asp-conj{stroke:#ef4444;stroke-dasharray:none}
.zw-asp-oppo{stroke:#a78bfa;stroke-dasharray:4 2}
.zw-asp-trine{stroke:#34d399;stroke-dasharray:none}
.zw-asp-square{stroke:#fbbf24;stroke-dasharray:2 2}

/* Center hub */
.zw-hub-bg{fill:url(#zwHubGrad);stroke:#334155;stroke-width:1.5}
.zw-hub-ongsa{font-size:18px;font-weight:800;fill:#e2e8f0;text-anchor:middle;dominant-baseline:central}
.zw-hub-lak{font-size:8px;fill:#38bdf8;text-anchor:middle;dominant-baseline:central;font-weight:600}
.zw-hub-date{font-size:6px;fill:#22d3ee;text-anchor:middle;dominant-baseline:central}

/* Yok planets (faded) */
.zw-yok-num{font-size:8px;font-weight:700;fill:#f8fafc;opacity:.2;text-anchor:middle;dominant-baseline:central}
.zw-yok-label{font-size:4.5px;fill:#94a3b8;opacity:.35;text-anchor:middle;dominant-baseline:central}

/* Lakkana indicator */
.zw-lak-marker{fill:#f59e0b;filter:drop-shadow(0 0 6px rgba(245,158,11,.8))}
.zw-lak-text{font-size:9px;fill:#f59e0b;font-weight:800;text-anchor:middle;dominant-baseline:central;filter:drop-shadow(0 0 4px rgba(245,158,11,.6))}
.zw-lak-arc{fill:rgba(245,158,11,.08);stroke:rgba(245,158,11,.5);stroke-width:1.2}

/* Glow effects */
.zw-planet-glow{filter:drop-shadow(0 0 3px rgba(248,250,252,.3))}
.zw-transit-glow{filter:drop-shadow(0 0 4px rgba(34,211,238,.4))}

/* Trend mode colors */
.trend-yellow{background:rgba(234,179,8,.18)!important}
.trend-green{background:rgba(34,197,94,.18)!important}
.trend-red{background:rgba(239,68,68,.18)!important}
.trend-neutral{background:rgba(148,163,184,.1)!important}
.trend-label{font-size:.6rem;font-weight:700;position:absolute;bottom:1px;left:50%;transform:translateX(-50%);white-space:nowrap}
.trend-label.t-yellow{color:#eab308}
.trend-label.t-green{color:#22c55e}
.trend-label.t-red{color:#ef4444}
.trend-label.t-neutral{color:#94a3b8}

/* ============================================================ */
/* Transit Timeline                                              */
/* ============================================================ */
#transitArea{display:none;margin-top:1rem}
.transit-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}
.transit-header h3{color:#22d3ee;font-size:.95rem}
.transit-toggle{padding:.3rem .8rem;border:none;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer}
.transit-toggle.on{background:#22d3ee;color:#0f172a}
.transit-toggle.off{background:#334155;color:#94a3b8}
.transit-controls{background:#1e293b;border:1px solid #334155;border-radius:8px;padding:.7rem;margin-bottom:.5rem}
.transit-date-row{display:flex;gap:.4rem;align-items:center;margin-bottom:.5rem}
.transit-date-row input[type=date]{flex:2;padding:.4rem;font-size:.85rem}
.transit-date-row select{flex:1;padding:.4rem;font-size:.85rem}
.transit-step-row{display:flex;gap:.3rem;justify-content:center;align-items:center;flex-wrap:wrap}
.step-btn{padding:.35rem .6rem;border:none;border-radius:5px;background:#334155;color:#e2e8f0;font-size:.75rem;font-weight:600;cursor:pointer;white-space:nowrap}
.step-btn:hover{background:#475569}
.step-btn.today{background:#f59e0b;color:#1e293b}
.step-btn.today:hover{background:#d97706}
.transit-info{text-align:center;font-size:.8rem;color:#22d3ee;margin-top:.4rem}
.transit-legend{display:flex;justify-content:center;gap:1rem;margin-top:.4rem;font-size:.75rem}
.legend-natal{color:#f8fafc}
.legend-natal::before{content:'●';margin-right:3px}
.legend-transit{color:#22d3ee}
.legend-transit::before{content:'●';margin-right:3px}

/* Slider */
.slider-wrap{margin-top:.6rem;padding:0 .2rem}
.slider-label-row{display:flex;justify-content:space-between;font-size:.7rem;color:#64748b;margin-bottom:2px}
.slider-date-display{text-align:center;font-size:.85rem;color:#22d3ee;font-weight:700;margin-top:4px}
#transitSlider{-webkit-appearance:none;width:100%;height:6px;border-radius:3px;background:linear-gradient(90deg,#334155 0%,#22d3ee 50%,#334155 100%);outline:none;cursor:pointer}
#transitSlider::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:#22d3ee;border:2px solid #0f172a;box-shadow:0 0 6px rgba(34,211,238,.5);cursor:grab}
#transitSlider::-webkit-slider-thumb:active{cursor:grabbing;background:#06b6d4;box-shadow:0 0 12px rgba(34,211,238,.7)}
#transitSlider::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:#22d3ee;border:2px solid #0f172a;cursor:grab}
#transitSlider::-moz-range-track{height:6px;border-radius:3px;background:linear-gradient(90deg,#334155 0%,#22d3ee 50%,#334155 100%)}

/* ============================================================ */
/* Calendar                                                      */
/* ============================================================ */
#calendarArea{display:none;margin-top:1rem;margin-left:-1rem;margin-right:-1rem}
.cal-panel{background:#1e293b;border:1px solid #334155;border-radius:8px;padding:.7rem}
.cal-header{display:flex;justify-content:center;align-items:center;gap:.6rem;margin-bottom:.6rem;flex-wrap:wrap}
.cal-nav-btn{padding:.3rem .7rem;border:none;border-radius:5px;background:#334155;color:#e2e8f0;font-size:.9rem;cursor:pointer;font-weight:700}
.cal-nav-btn:hover{background:#475569}
.cal-month-label{color:#38bdf8;font-size:.95rem;font-weight:700;min-width:140px;text-align:center}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:#334155;border-radius:4px;overflow:hidden}
.cal-dow{background:#0f172a;color:#64748b;text-align:center;padding:.45rem .15rem;font-size:.78rem;font-weight:600}
.cal-dow.weekend{color:#ef4444}
.cal-day{background:#1e293b;padding:5px 4px;min-height:90px;cursor:pointer;font-size:.72rem;transition:background .15s;position:relative;display:flex;flex-direction:column}
.cal-day:hover{background:#334155}
.cal-day.empty{background:#0f172a;cursor:default;min-height:20px}
.cal-day.is-today{box-shadow:inset 0 0 0 2px #22d3ee}
.cal-day.selected{box-shadow:inset 0 0 0 2px #f59e0b}
.cal-day-num{font-weight:700;color:#e2e8f0;font-size:.82rem;line-height:1}
.cal-day-moon{font-size:.7rem;line-height:1;margin-top:2px}
.cal-day-lunar{font-size:.55rem;color:#94a3b8;line-height:1.2}
.cal-day-events{margin-top:auto;display:flex;flex-wrap:wrap;gap:1px}
.cal-evt{font-size:.5rem;color:#22d3ee;line-height:1;background:rgba(34,211,238,.12);padding:1px 3px;border-radius:2px;white-space:nowrap}
.cal-asp{display:inline-block;width:6px;height:6px;border-radius:50%;margin:0 .5px}
.cal-asp.a-conj{background:#ef4444}
.cal-asp.a-oppo{background:#a78bfa}
.cal-asp.a-trine{background:#34d399}
.cal-asp.a-square{background:#fbbf24}
.cal-newmoon{background:rgba(148,163,184,.15)!important}
.cal-fullmoon{background:rgba(251,191,36,.1)!important}
/* Rerk badge in calendar cell */
.cal-rerk{margin-top:2px;font-size:.5rem;line-height:1;padding:1px 3px;border-radius:3px;white-space:nowrap;text-align:center}
.cal-rerk.rq-good{background:rgba(34,197,94,.18);color:#4ade80}
.cal-rerk.rq-bad{background:rgba(239,68,68,.18);color:#f87171}
.cal-rerk.rq-neutral{background:rgba(250,204,21,.12);color:#fbbf24}
/* Personal Tara badge */
.cal-tara{margin-top:1px;font-size:.48rem;line-height:1;padding:1px 3px;border-radius:3px;white-space:nowrap;text-align:center}
.cal-tara.tq-good{background:rgba(56,189,248,.15);color:#38bdf8}
.cal-tara.tq-bad{background:rgba(239,68,68,.12);color:#ef4444}
.cal-tara.tq-neutral{background:rgba(148,163,184,.12);color:#94a3b8}
/* Combined ฤกษ์ badge in calendar cell */
.cal-combined{margin-top:2px;font-size:.48rem;line-height:1;padding:2px 4px;border-radius:3px;white-space:nowrap;text-align:center;font-weight:700;letter-spacing:.5px}
.cal-combined.cb-excellent{background:linear-gradient(135deg,rgba(34,197,94,.25),rgba(56,189,248,.2));color:#4ade80;border:1px solid rgba(34,197,94,.3)}
.cal-combined.cb-good{background:rgba(34,197,94,.15);color:#4ade80}
.cal-combined.cb-fair{background:rgba(250,204,21,.12);color:#fbbf24}
.cal-combined.cb-mixed{background:rgba(249,115,22,.15);color:#f97316}
.cal-combined.cb-neutral{background:rgba(148,163,184,.1);color:#94a3b8}
.cal-combined.cb-poor{background:rgba(239,68,68,.12);color:#f87171}
.cal-combined.cb-avoid{background:rgba(239,68,68,.2);color:#ef4444;border:1px solid rgba(239,68,68,.3)}
/* ฤกษ์ล่าง detail panel */
.cal-detail-lower{margin-top:.5rem;padding:.6rem;background:#1e293b;border-radius:6px;border:1px solid #334155}
.cal-detail-lower-title{font-size:.82rem;font-weight:700;color:#f97316;margin-bottom:.4rem}
.cal-lower-items{display:flex;flex-direction:column;gap:4px}
.cal-lower-item{display:flex;align-items:center;gap:.5rem;padding:5px 8px;background:rgba(15,23,42,.4);border-radius:5px;border-left:3px solid #475569}
.cal-lower-item.li-good{border-left-color:#4ade80}
.cal-lower-item.li-bad{border-left-color:#f87171}
.cal-lower-item.li-neutral{border-left-color:#fbbf24}
.cal-lower-item .li-emoji{font-size:.9rem;min-width:22px;text-align:center}
.cal-lower-item .li-info{flex:1}
.cal-lower-item .li-label{font-size:.75rem;font-weight:700;color:#e2e8f0}
.cal-lower-item .li-desc{font-size:.62rem;color:#94a3b8}
.cal-lower-item .li-badge{padding:2px 8px;border-radius:4px;font-size:.65rem;font-weight:600}
.cal-lower-item .li-badge.lq-good{background:rgba(34,197,94,.15);color:#4ade80}
.cal-lower-item .li-badge.lq-bad{background:rgba(239,68,68,.15);color:#f87171}
.cal-lower-item .li-badge.lq-neutral{background:rgba(250,204,21,.12);color:#fbbf24}
/* Combined summary card */
.cal-detail-combined{margin-top:.5rem;padding:.6rem;background:linear-gradient(135deg,#1e293b,#0f172a);border-radius:8px;border:1px solid #334155}
.cal-combined-header{display:flex;align-items:center;gap:.6rem;margin-bottom:.4rem}
.cal-combined-emoji{font-size:1.5rem}
.cal-combined-info{flex:1}
.cal-combined-label{font-size:.95rem;font-weight:700}
.cal-combined-desc{font-size:.68rem;color:#94a3b8;margin-top:2px}
.cal-combined-meter{display:flex;gap:3px;margin-top:.4rem}
.cal-combined-dot{width:100%;height:8px;border-radius:4px;background:#334155}
.cal-combined-dot.cd-on-good{background:linear-gradient(90deg,#22c55e,#4ade80)}
.cal-combined-dot.cd-on-mid{background:linear-gradient(90deg,#eab308,#fbbf24)}
.cal-combined-dot.cd-on-bad{background:linear-gradient(90deg,#dc2626,#f87171)}
/* Combined summary card detail styles */
.cdc-title{font-size:.82rem;font-weight:700;color:#c084fc;margin-bottom:.4rem}
.cdc-verdict{display:flex;align-items:center;gap:.5rem}
.cdc-emoji{font-size:1.5rem;min-width:32px;text-align:center}
.cdc-info{flex:1}
.cdc-label{font-size:.9rem;font-weight:700}
.cdc-desc{font-size:.65rem;color:#94a3b8;margin-top:2px}
.cdc-meter{height:6px;background:#334155;border-radius:3px;margin-top:.4rem;overflow:hidden}
.cdc-meter-fill{height:100%;border-radius:3px;transition:width .3s}
.cdc-meter-fill.cb-excellent{background:linear-gradient(90deg,#22c55e,#86efac)}
.cdc-meter-fill.cb-good{background:linear-gradient(90deg,#22c55e,#4ade80)}
.cdc-meter-fill.cb-fair{background:linear-gradient(90deg,#38bdf8,#7dd3fc)}
.cdc-meter-fill.cb-mixed{background:linear-gradient(90deg,#eab308,#fbbf24)}
.cdc-meter-fill.cb-neutral{background:linear-gradient(90deg,#64748b,#94a3b8)}
.cdc-meter-fill.cb-poor{background:linear-gradient(90deg,#f97316,#fb923c)}
.cdc-meter-fill.cb-avoid{background:linear-gradient(90deg,#dc2626,#f87171)}
.cal-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem;margin-top:.5rem;font-size:.68rem;color:#94a3b8}
.cal-legend span::before{content:'';display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:3px;vertical-align:middle}
.cal-legend .l-conj::before{background:#ef4444}
.cal-legend .l-oppo::before{background:#a78bfa}
.cal-legend .l-trine::before{background:#34d399}
.cal-legend .l-square::before{background:#fbbf24}
.cal-legend .l-change::before{background:#22d3ee}
.cal-legend .l-rerk::before{background:#4ade80}
.cal-legend .l-tara::before{background:#38bdf8}
/* Goal selector bar */
.cal-goal-bar{margin-bottom:.6rem;text-align:center}
.cal-goal-label{font-size:.78rem;color:#94a3b8;margin-bottom:.4rem;font-weight:600}
.cal-goal-btns{display:flex;flex-wrap:wrap;justify-content:center;gap:4px}
.cal-goal-btn{padding:4px 10px;border:1px solid #334155;border-radius:6px;background:#1e293b;color:#cbd5e1;font-size:.72rem;cursor:pointer;transition:all .15s;white-space:nowrap}
.cal-goal-btn:hover{background:#334155;border-color:#475569}
.cal-goal-btn.active{background:linear-gradient(135deg,#0ea5e9,#8b5cf6);border-color:#8b5cf6;color:#fff;font-weight:700;box-shadow:0 0 8px rgba(139,92,246,.3)}
.cal-goal-btn .goal-emoji{margin-right:2px}
/* Goal score badge in calendar cell */
.cal-goal{margin-top:2px;font-size:.5rem;line-height:1;padding:2px 4px;border-radius:3px;white-space:nowrap;text-align:center;font-weight:600}
.cal-goal.gt-good{background:rgba(34,197,94,.2);color:#4ade80}
.cal-goal.gt-mid{background:rgba(250,204,21,.15);color:#fbbf24}
.cal-goal.gt-bad{background:rgba(239,68,68,.2);color:#f87171}
/* Goal detail panel */
.cal-detail-goal{margin-top:.5rem;padding:.6rem;background:#1e293b;border-radius:6px;border:1px solid #334155}
.cal-detail-goal-title{font-size:.85rem;font-weight:700;color:#a78bfa;margin-bottom:.4rem}
.cal-detail-goal-verdict{display:flex;align-items:center;gap:.6rem;padding:.5rem;background:rgba(15,23,42,.5);border-radius:6px;margin-bottom:.4rem}
.cal-detail-goal-verdict .goal-v-emoji{font-size:1.4rem}
.cal-detail-goal-verdict .goal-v-info{flex:1}
.cal-detail-goal-verdict .goal-v-label{font-size:.9rem;font-weight:700}
.cal-detail-goal-verdict .goal-v-interp{font-size:.72rem;color:#94a3b8;margin-top:2px}
.cal-detail-goal-verdict .goal-v-badge{padding:3px 10px;border-radius:5px;font-size:.75rem;font-weight:700}
.cal-detail-goal-verdict .goal-v-badge.gt-good{background:rgba(34,197,94,.2);color:#4ade80}
.cal-detail-goal-verdict .goal-v-badge.gt-mid{background:rgba(250,204,21,.15);color:#fbbf24}
.cal-detail-goal-verdict .goal-v-badge.gt-bad{background:rgba(239,68,68,.2);color:#f87171}
/* Score bar */
.goal-score-bar{height:6px;background:#334155;border-radius:3px;overflow:hidden;margin-top:4px}
.goal-score-fill{height:100%;border-radius:3px;transition:width .3s}
.goal-score-fill.gt-good{background:linear-gradient(90deg,#22c55e,#4ade80)}
.goal-score-fill.gt-mid{background:linear-gradient(90deg,#eab308,#fbbf24)}
.goal-score-fill.gt-bad{background:linear-gradient(90deg,#dc2626,#f87171)}
/* Planet detail cards */
.goal-planet-grid{display:grid;grid-template-columns:1fr;gap:4px;margin-top:.4rem}
.goal-planet-card{display:flex;align-items:center;gap:.5rem;padding:5px 8px;background:rgba(15,23,42,.4);border-radius:5px;border-left:3px solid #475569}
.goal-planet-card.gpc-good{border-left-color:#4ade80}
.goal-planet-card.gpc-mid{border-left-color:#fbbf24}
.goal-planet-card.gpc-bad{border-left-color:#f87171}
.goal-planet-card .gpc-name{font-size:.75rem;font-weight:700;color:#e2e8f0;min-width:60px}
.goal-planet-card .gpc-tara{font-size:.68rem;color:#94a3b8;flex:1}
.goal-planet-card .gpc-score{font-size:.72rem;font-weight:700}
.cal-detail{margin-top:.5rem;background:#0f172a;border:1px solid #334155;border-radius:6px;padding:.6rem;display:none}
.cal-detail-title{color:#f59e0b;font-size:.9rem;font-weight:700;margin-bottom:.5rem}
.cal-detail table{width:100%;border-collapse:collapse;font-size:.76rem}
.cal-detail th{background:#1e293b;color:#f59e0b;padding:4px 6px;border:1px solid #334155;text-align:left}
.cal-detail td{padding:4px 6px;border:1px solid #334155;color:#e2e8f0}
.cal-detail-rerk{margin-top:.5rem;padding:.5rem;background:#1e293b;border-radius:6px;border:1px solid #334155}
.cal-detail-rerk-title{font-size:.8rem;font-weight:700;color:#4ade80;margin-bottom:.3rem}
.cal-detail-rerk-hero{display:flex;align-items:center;gap:.5rem;padding:.4rem;background:rgba(15,23,42,.5);border-radius:5px;margin-bottom:.3rem}
.cal-detail-rerk-hero .rerk-e{font-size:1.3rem}
.cal-detail-rerk-hero .rerk-info{flex:1}
.cal-detail-rerk-hero .rerk-name{font-size:.82rem;font-weight:700}
.cal-detail-rerk-hero .rerk-nak{font-size:.65rem;color:#94a3b8}
/* Rerk Timeline */
.rerk-timeline{margin-top:.5rem;padding:.5rem;background:#1e293b;border-radius:6px;border:1px solid #334155}
.rerk-timeline-title{font-size:.82rem;font-weight:700;color:#f59e0b;margin-bottom:.4rem}
.rerk-tl-bar{display:flex;height:28px;border-radius:5px;overflow:hidden;background:#0f172a;margin-bottom:.3rem}
.rerk-tl-seg{display:flex;align-items:center;justify-content:center;font-size:.5rem;font-weight:600;color:#fff;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:0 2px;cursor:pointer;transition:opacity .15s;position:relative}
.rerk-tl-seg:hover{opacity:.85}
.rerk-tl-seg.rtq-good{background:linear-gradient(135deg,#166534,#22c55e)}
.rerk-tl-seg.rtq-bad{background:linear-gradient(135deg,#991b1b,#ef4444)}
.rerk-tl-seg.rtq-neutral{background:linear-gradient(135deg,#854d0e,#eab308)}
.rerk-tl-rows{display:flex;flex-direction:column;gap:3px}
.rerk-tl-row{display:flex;align-items:center;gap:6px;padding:3px 6px;background:rgba(15,23,42,.4);border-radius:4px;font-size:.7rem;color:#e2e8f0}
.rerk-tl-row .tl-time{font-weight:700;color:#38bdf8;min-width:90px;font-family:monospace;font-size:.72rem}
.rerk-tl-row .tl-emoji{font-size:.85rem}
.rerk-tl-row .tl-name{font-weight:600;min-width:70px}
.rerk-tl-row .tl-name.rq-good{color:#4ade80}
.rerk-tl-row .tl-name.rq-bad{color:#f87171}
.rerk-tl-row .tl-name.rq-neutral{color:#fbbf24}
.rerk-tl-row .tl-nak{color:#94a3b8;font-size:.62rem}
.rerk-tl-row .tl-dur{color:#64748b;font-size:.6rem;margin-left:auto}
.cal-detail-tara{margin-top:.4rem;padding:.5rem;background:#1e293b;border-radius:6px;border:1px solid #334155}
.cal-detail-tara-title{font-size:.8rem;font-weight:700;color:#38bdf8;margin-bottom:.3rem}
.cal-detail-tara-hero{display:flex;align-items:center;gap:.5rem;padding:.4rem;background:rgba(15,23,42,.5);border-radius:5px}
.cal-detail-tara-hero .tara-e{font-size:1.3rem}
.cal-detail-tara-hero .tara-info{flex:1}
.cal-detail-tara-hero .tara-name{font-size:.82rem;font-weight:700}
.cal-detail-tara-hero .tara-desc{font-size:.65rem;color:#94a3b8}
.cal-detail-tara-hero .tara-badge{padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:600}
.cal-detail-tara-hero .tara-badge.tq-good{background:rgba(56,189,248,.2);color:#38bdf8}
.cal-detail-tara-hero .tara-badge.tq-bad{background:rgba(239,68,68,.2);color:#ef4444}
.cal-detail-tara-hero .tara-badge.tq-neutral{background:rgba(148,163,184,.2);color:#94a3b8}
.cal-detail-asp{margin-top:.4rem}
.cal-detail-asp-item{font-size:.76rem;color:#e2e8f0;padding:2px 0}
.cal-set-transit{margin-top:.5rem;padding:.35rem .9rem;border:none;border-radius:5px;background:#22d3ee;color:#0f172a;font-size:.78rem;font-weight:600;cursor:pointer}
.cal-set-transit:hover{opacity:.85}
.cal-today-btn{padding:.3rem .7rem;border:none;border-radius:5px;background:#f59e0b;color:#1e293b;font-size:.75rem;font-weight:600;cursor:pointer}
.cal-today-btn:hover{opacity:.85}

@media(max-width:400px){
  .container{padding:.5rem}
  h1{font-size:1.1rem}
  .tab-btn{padding:.3rem .6rem;font-size:.75rem}
  .cell-planets{font-size:.9rem}
  .cell-transit{font-size:.75rem}
  .center-ongsa{font-size:1.2rem}
  .cell{padding:3px 4px}
  .step-btn{padding:.25rem .4rem;font-size:.7rem}
  .cal-day{min-height:70px;padding:3px}
  .cal-day-num{font-size:.7rem}
  .cal-day-moon{font-size:.6rem}
  .cal-day-lunar{font-size:.5rem}
  .cal-evt{font-size:.42rem}
  .cal-rerk{font-size:.42rem}
  .cal-tara{font-size:.4rem}
  /* Modern chart responsive */
  .mc-node{width:58px;padding:3px 2px;border-radius:7px;font-size:.6rem}
  .mc-pl{font-size:.82rem;letter-spacing:1.5px}
  .mc-rasi{font-size:.48rem}
  .mc-bhava{font-size:.4rem}
  .mc-time{font-size:.35rem}
  .mc-hub{width:76px;height:76px}
  .mc-hub-ongsa{font-size:.95rem}
  .mc-hub-lak{font-size:.5rem}
  .mc-tr{font-size:.62rem}
  .vs-btn{padding:4px 10px;font-size:.7rem}
  /* Zodiac wheel responsive */
  .zw-zodiac-sym{font-size:10px}
  .zw-rasi-label{font-size:5.5px}
  .zw-pl-num{font-size:7.5px}
  .zw-pl-name{font-size:4.5px}
  .zw-hub-ongsa{font-size:14px}
  .zw-hub-lak{font-size:6.5px}
  .zw-tr-num{font-size:7px}
}

/* ============================================================ */
/* Aspect Panel (Transit ↔ Natal)                                */
/* ============================================================ */
#aspectArea{display:none;margin-top:1rem}
.aspect-panel{background:#1e293b;border:1px solid #334155;border-radius:8px;padding:.7rem}
.aspect-panel-title{color:#f59e0b;font-size:.95rem;font-weight:700;text-align:center;margin-bottom:.6rem;cursor:pointer;user-select:none}
.aspect-panel-title:hover{opacity:.85}
.aspect-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
.aspect-group{background:#0f172a;border-radius:6px;padding:.5rem;border:1px solid #1e293b}
.aspect-title{font-size:.82rem;font-weight:700;padding:.25rem .4rem;border-radius:4px;margin-bottom:4px;display:flex;align-items:center;gap:.3rem}
.asp-conj .aspect-title{color:#ef4444;background:rgba(239,68,68,.12)}
.asp-oppo .aspect-title{color:#a78bfa;background:rgba(167,139,250,.12)}
.asp-trine .aspect-title{color:#34d399;background:rgba(52,211,153,.12)}
.asp-square .aspect-title{color:#fbbf24;background:rgba(251,191,36,.12)}
.aspect-count{font-weight:400;font-size:.7rem;opacity:.6;margin-left:auto}
.aspect-item{font-size:.78rem;color:#e2e8f0;padding:2px .4rem 2px .6rem;line-height:1.6;display:flex;align-items:center;gap:3px;flex-wrap:wrap}
.aspect-item .a-transit{color:#22d3ee;font-weight:600}
.aspect-item .a-natal{color:#f8fafc;font-weight:600}
.aspect-item .a-sym{opacity:.5;font-size:.7rem;margin:0 2px}
.aspect-item .a-rasi{color:#94a3b8;font-size:.68rem;margin-left:auto;white-space:nowrap}
.aspect-empty{font-size:.72rem;color:#475569;padding:2px .4rem;font-style:italic}
@media(max-width:400px){
  .aspect-grid{grid-template-columns:1fr}
  .aspect-item{font-size:.72rem}
}

/* ============================================================ */
/* Highlight Alerts                                              */
/* ============================================================ */
#highlightArea{display:none;margin-top:.8rem}
.highlight-list{display:flex;flex-direction:column;gap:4px}
.hl-alert{
  display:flex;align-items:center;gap:6px;
  padding:6px 10px;border-radius:6px;
  font-size:.82rem;font-weight:600;
  animation:hlPulse 2s ease-in-out infinite alternate;
}
.hl-alert .hl-icon{font-size:1rem;flex-shrink:0}
.hl-alert .hl-text{flex:1}
.hl-alert .hl-badge{font-size:.65rem;padding:1px 6px;border-radius:10px;font-weight:700;flex-shrink:0}
.hl-conj{background:rgba(239,68,68,.15);color:#fca5a5;border:1px solid rgba(239,68,68,.3)}
.hl-conj .hl-badge{background:#ef4444;color:#fff}
.hl-oppo{background:rgba(167,139,250,.15);color:#c4b5fd;border:1px solid rgba(167,139,250,.3)}
.hl-oppo .hl-badge{background:#a78bfa;color:#1e293b}
.hl-trine{background:rgba(52,211,153,.12);color:#6ee7b7;border:1px solid rgba(52,211,153,.25)}
.hl-trine .hl-badge{background:#34d399;color:#1e293b}
.hl-square{background:rgba(251,191,36,.15);color:#fde68a;border:1px solid rgba(251,191,36,.3)}
.hl-square .hl-badge{background:#fbbf24;color:#1e293b}
@keyframes hlPulse{from{opacity:.85}to{opacity:1}}

/* ============================================================ */
/* Event Detection Panel                                         */
/* ============================================================ */
#eventArea{display:none;margin-top:.8rem}
.event-panel{background:#1e293b;border:1px solid #334155;border-radius:8px;padding:.7rem}
.event-panel-title{color:#f59e0b;font-size:.9rem;font-weight:700;text-align:center;margin-bottom:.5rem}
.event-loading{text-align:center;color:#94a3b8;font-size:.8rem;padding:.5rem}
.event-list{display:flex;flex-direction:column;gap:3px}
.ev-item{
  display:flex;align-items:center;gap:6px;
  padding:5px 8px;border-radius:5px;
  font-size:.78rem;border:1px solid transparent;
}
.ev-item .ev-day{min-width:60px;font-weight:700;flex-shrink:0;text-align:right}
.ev-item .ev-desc{flex:1;color:#e2e8f0}
.ev-item .ev-arrow{color:#64748b;flex-shrink:0}
.ev-past{background:rgba(100,116,139,.08);border-color:#334155}
.ev-past .ev-day{color:#94a3b8}
.ev-today{background:rgba(245,158,11,.15);border-color:rgba(245,158,11,.4)}
.ev-today .ev-day{color:#f59e0b}
.ev-future{background:rgba(34,211,238,.08);border-color:rgba(34,211,238,.2)}
.ev-future .ev-day{color:#22d3ee}
.ev-empty{text-align:center;color:#475569;font-size:.78rem;font-style:italic;padding:.5rem}

/* ============================================================ */
/* Person 2 (Comparison)                                         */
/* ============================================================ */
.person-section{margin-top:1.5rem;border-top:2px dashed #475569;padding-top:1rem}
.person-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}
.person-header h2{color:#a78bfa;font-size:1rem}
.person-toggle{padding:.35rem .8rem;border:none;border-radius:6px;font-size:.82rem;font-weight:600;cursor:pointer;background:#a78bfa;color:#1e293b}
.person-toggle:hover{opacity:.85}
#person2Form{display:none}
#chartArea2{display:none;margin-top:.8rem}
.chart-label{text-align:center;font-weight:700;font-size:.9rem;margin-bottom:.3rem;padding:.3rem;border-radius:6px}
.chart-label-1{color:#f59e0b;background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.2)}
.chart-label-2{color:#a78bfa;background:rgba(167,139,250,.1);border:1px solid rgba(167,139,250,.2)}
#aspectArea2{display:none;margin-top:.8rem}
#highlightArea2{display:none;margin-top:.6rem}
#results2{display:none;margin-top:1rem;text-align:center}
.btn-main-2{display:block;width:100%;padding:.7rem;margin-top:1rem;border:none;border-radius:8px;background:linear-gradient(135deg,#a78bfa,#7c3aed);color:#fff;font-size:1rem;font-weight:700;cursor:pointer;letter-spacing:.5px}
.btn-main-2:hover{opacity:.9}
.btn-main-2:disabled{opacity:.5;cursor:not-allowed}
.cell-planets-2{font-size:1.05rem;font-weight:700;color:#c4b5fd;letter-spacing:2px;text-align:center;line-height:1.2}
.center-lakkana-2{font-size:.7rem;color:#a78bfa;margin-top:1px}

/* ============================================================ */
/* Synastry Panel (Natal1 ↔ Natal2)                              */
/* ============================================================ */
#synastryArea{display:none;margin-top:1rem}
.syn-panel{background:#1e293b;border:1px solid #334155;border-radius:8px;padding:.7rem}
.syn-panel-title{color:#e879f9;font-size:.95rem;font-weight:700;text-align:center;margin-bottom:.6rem}
.syn-summary{display:flex;justify-content:center;gap:.6rem;flex-wrap:wrap;margin-bottom:.6rem}
.syn-badge{padding:4px 10px;border-radius:12px;font-size:.78rem;font-weight:700}
.syn-badge-conj{background:rgba(239,68,68,.18);color:#fca5a5;border:1px solid rgba(239,68,68,.25)}
.syn-badge-oppo{background:rgba(167,139,250,.18);color:#c4b5fd;border:1px solid rgba(167,139,250,.25)}
.syn-badge-trine{background:rgba(52,211,153,.15);color:#6ee7b7;border:1px solid rgba(52,211,153,.2)}
.syn-badge-square{background:rgba(251,191,36,.15);color:#fde68a;border:1px solid rgba(251,191,36,.2)}
.syn-score{text-align:center;margin-bottom:.5rem}
.syn-score-bar{height:8px;border-radius:4px;background:#334155;overflow:hidden;margin:4px 0}
.syn-score-fill{height:100%;border-radius:4px;transition:width .5s ease}
.syn-score-label{font-size:.78rem;color:#94a3b8}
.syn-score-value{font-size:1.2rem;font-weight:700;margin-left:4px}
.syn-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
.syn-group{background:#0f172a;border-radius:6px;padding:.5rem;border:1px solid #1e293b}
.syn-item{font-size:.78rem;color:#e2e8f0;padding:2px .4rem 2px .6rem;line-height:1.6;display:flex;align-items:center;gap:3px;flex-wrap:wrap}
.syn-item .s-p1{color:#f59e0b;font-weight:600}
.syn-item .s-p2{color:#a78bfa;font-weight:600}
.syn-item .s-sym{opacity:.5;font-size:.7rem;margin:0 2px}
.syn-item .s-rasi{color:#94a3b8;font-size:.68rem;margin-left:auto;white-space:nowrap}
.syn-verdict{text-align:center;padding:.5rem;margin-top:.5rem;border-radius:6px;font-size:.88rem;font-weight:700}
.syn-verdict-good{background:rgba(52,211,153,.12);color:#6ee7b7;border:1px solid rgba(52,211,153,.2)}
.syn-verdict-neutral{background:rgba(251,191,36,.1);color:#fde68a;border:1px solid rgba(251,191,36,.2)}
.syn-verdict-caution{background:rgba(239,68,68,.1);color:#fca5a5;border:1px solid rgba(239,68,68,.2)}
@media(max-width:400px){
  .syn-grid{grid-template-columns:1fr}
  .syn-item{font-size:.72rem}
}

/* ============================================================ */
/* Bhava Reading Panel (ภพ 12 เรือน)                             */
/* ============================================================ */
#bhavaReadArea{display:none;margin-top:1rem}
#bhavaReadArea2{display:none;margin-top:1rem}
.bhr-panel{background:#1e293b;border:1px solid #334155;border-radius:8px;padding:.7rem}
.bhr-title{font-size:.95rem;font-weight:700;text-align:center;margin-bottom:.6rem}
.bhr-title-1{color:#f59e0b}
.bhr-title-2{color:#a78bfa}
.bhr-list{display:flex;flex-direction:column;gap:4px}
.bhr-row{background:#0f172a;border:1px solid #1e293b;border-radius:6px;overflow:hidden}
.bhr-row-header{display:flex;align-items:center;gap:6px;padding:6px 8px;cursor:pointer;user-select:none}
.bhr-row-header:hover{background:rgba(245,158,11,.06)}
.bhr-bhava-icon{font-size:1rem;flex-shrink:0}
.bhr-bhava-name{font-weight:700;font-size:.82rem;color:#f59e0b;min-width:52px}
.bhr-bhava-desc{font-size:.7rem;color:#94a3b8;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bhr-rasi-badge{font-size:.68rem;padding:1px 6px;border-radius:10px;background:rgba(56,189,248,.12);color:#38bdf8;border:1px solid rgba(56,189,248,.2);white-space:nowrap}
.bhr-planet-chips{display:flex;gap:3px;flex-wrap:wrap}
.bhr-chip{font-size:.68rem;padding:1px 5px;border-radius:8px;font-weight:600;white-space:nowrap}
.bhr-chip-planet{background:rgba(248,250,252,.1);color:#f8fafc;border:1px solid #475569}
.bhr-chip-empty{background:rgba(100,116,139,.1);color:#64748b;border:1px solid #334155;font-style:italic}
.bhr-chip-yok{background:rgba(251,191,36,.1);color:#fde68a;border:1px solid rgba(251,191,36,.25)}
.bhr-chip-leng{background:rgba(167,139,250,.1);color:#c4b5fd;border:1px solid rgba(167,139,250,.25)}
.bhr-detail{display:none;padding:6px 8px 8px;border-top:1px solid #1e293b;font-size:.72rem}
.bhr-detail.open{display:block}
.bhr-detail-row{display:flex;gap:6px;padding:2px 0;color:#e2e8f0}
.bhr-detail-label{color:#94a3b8;min-width:65px;flex-shrink:0}
.bhr-detail-val{flex:1}
.bhr-yok-chain{margin-top:4px;padding:4px 6px;background:rgba(251,191,36,.06);border-radius:4px;border:1px solid rgba(251,191,36,.12)}
.bhr-yok-title{color:#fbbf24;font-weight:700;font-size:.72rem;margin-bottom:2px}
.bhr-yok-step{font-size:.68rem;color:#fde68a;padding:1px 0}
.bhr-pairs{margin-top:4px;font-size:.68rem;color:#94a3b8}
.bhr-pairs span{color:#22d3ee;font-weight:600}
.bhr-planet-detail{margin-top:3px;padding:3px 6px;background:rgba(248,250,252,.03);border-radius:4px}
.bhr-pd-line{display:flex;gap:4px;padding:1px 0;font-size:.68rem;align-items:center}
.bhr-pd-num{color:#f59e0b;font-weight:700;min-width:14px}
.bhr-pd-name{font-weight:600;color:#e2e8f0;min-width:50px}
.bhr-pd-char{color:#22d3ee;font-size:.65rem}
.bhr-pd-meaning{color:#94a3b8;font-size:.62rem;flex:1}
.bhr-pd-time{color:#64748b;font-size:.6rem;white-space:nowrap}
@media(max-width:400px){
  .bhr-bhava-desc{display:none}
  .bhr-chip{font-size:.6rem}
}

/* ============================================================ */
/* Natal Aspect Panel (own chart aspects)                        */
/* ============================================================ */
#natalAspectArea{display:none;margin-top:.8rem}
#natalAspectArea2{display:none;margin-top:.8rem}
.natal-asp-panel{background:#1e293b;border:1px solid #334155;border-radius:8px;padding:.7rem}
.natal-asp-title{font-size:.9rem;font-weight:700;text-align:center;margin-bottom:.5rem}
.natal-asp-title-1{color:#f59e0b}
.natal-asp-title-2{color:#a78bfa}
.natal-asp-summary{display:flex;justify-content:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.5rem}
.natal-asp-item{font-size:.78rem;color:#e2e8f0;padding:2px .4rem 2px .6rem;line-height:1.6;display:flex;align-items:center;gap:3px;flex-wrap:wrap}
.natal-asp-item .na-p{font-weight:600}
.natal-asp-item .na-sym{opacity:.5;font-size:.7rem;margin:0 2px}
.natal-asp-item .na-rasi{color:#94a3b8;font-size:.68rem;margin-left:auto;white-space:nowrap}

/* ============================================================ */
/* Clickable Planet Numbers & Transit Popup                      */
/* ============================================================ */
.pl-click{cursor:pointer;transition:all .15s;border-radius:3px;padding:0 2px}
.pl-click:hover{color:#f59e0b;text-shadow:0 0 8px rgba(245,158,11,.5)}
.pl-click:active{transform:scale(1.2)}
.zw-pl-click{cursor:pointer}
.zw-pl-click:hover .zw-pl-circle{stroke-width:3;filter:drop-shadow(0 0 6px rgba(245,158,11,.6))}
.zw-pl-click:hover .zw-pl-num{fill:#f59e0b !important}

.pt-popup{display:none;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:92%;max-width:380px;max-height:70vh;background:#1e293b;border:1px solid #475569;border-radius:12px;box-shadow:0 8px 40px rgba(0,0,0,.7);z-index:1000;overflow:hidden;animation:ptSlideIn .2s ease}
@keyframes ptSlideIn{from{opacity:0;transform:translate(-50%,-55%)}to{opacity:1;transform:translate(-50%,-50%)}}
.pt-header{display:flex;align-items:center;justify-content:space-between;padding:.6rem .8rem;background:#0f172a;border-bottom:1px solid #334155}
.pt-title{color:#f59e0b;font-size:1rem;font-weight:700}
.pt-close{background:none;border:none;color:#94a3b8;font-size:1.4rem;cursor:pointer;padding:0 4px;line-height:1}
.pt-close:hover{color:#ef4444}
.pt-sub{text-align:center;font-size:.8rem;color:#94a3b8;padding:.3rem .8rem;border-bottom:1px solid #1e293b}
.pt-loading{text-align:center;color:#f59e0b;padding:1.5rem;font-size:.85rem}
.pt-empty{text-align:center;color:#64748b;padding:1.5rem;font-size:.85rem}
.pt-list{overflow-y:auto;max-height:50vh;padding:.4rem 0}
.pt-row{display:flex;align-items:center;gap:.4rem;padding:.35rem .8rem;font-size:.78rem;border-bottom:1px solid rgba(51,65,85,.3)}
.pt-row:last-child{border-bottom:none}
.pt-row.pt-past{opacity:.65}
.pt-row.pt-future{}
.pt-row.pt-current{background:rgba(245,158,11,.08);border-left:3px solid #f59e0b}
.pt-dir{color:#94a3b8;font-size:.72rem;min-width:55px;flex-shrink:0}
.pt-row.pt-future .pt-dir{color:#f59e0b}
.pt-row.pt-current .pt-dir{color:#f59e0b;font-weight:700}
.pt-rasi{color:#e2e8f0;flex:1;font-weight:600}
.pt-row.pt-past .pt-rasi{color:#94a3b8}
.pt-date{color:#64748b;font-size:.72rem;white-space:nowrap;font-variant-numeric:tabular-nums}
.pt-row.pt-future .pt-date{color:#22d3ee}

/* ============================================================ */
/* Planet Dignity Panel                                          */
/* ============================================================ */
#dignityArea{display:none;margin-top:.8rem}
#dignityArea2{display:none;margin-top:.8rem}
.dig-panel{background:#1e293b;border:1px solid #334155;border-radius:8px;padding:.7rem}
.dig-title{font-size:.9rem;font-weight:700;text-align:center;margin-bottom:.5rem}
.dig-title-1{color:#f59e0b}
.dig-title-2{color:#a78bfa}
.dig-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:4px}
.dig-card{background:#0f172a;border-radius:6px;padding:6px 8px;border:1px solid #1e293b;display:flex;align-items:center;gap:6px}
.dig-card .dig-num{font-size:1rem;font-weight:700;width:20px;text-align:center}
.dig-card .dig-info{flex:1;font-size:.75rem;line-height:1.35}
.dig-card .dig-name{font-weight:600;color:#e2e8f0}
.dig-card .dig-rasi{color:#94a3b8;font-size:.68rem}
.dig-card .dig-badge{font-size:.65rem;font-weight:700;padding:1px 6px;border-radius:8px;white-space:nowrap}
.dig-domicile{background:rgba(52,211,153,.18);color:#6ee7b7;border:1px solid rgba(52,211,153,.25)}
.dig-exalt{background:rgba(96,165,250,.18);color:#93c5fd;border:1px solid rgba(96,165,250,.25)}
.dig-detriment{background:rgba(251,191,36,.15);color:#fde68a;border:1px solid rgba(251,191,36,.25)}
.dig-fall{background:rgba(239,68,68,.15);color:#fca5a5;border:1px solid rgba(239,68,68,.25)}
.dig-neutral{background:rgba(100,116,139,.12);color:#94a3b8;border:1px solid #334155}
.dig-summary{display:flex;justify-content:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.5rem}

/* ============================================================ */
/* Lunar Phase Panel                                             */
/* ============================================================ */
#lunarArea{display:none;margin-top:.8rem}
#lunarArea2{display:none;margin-top:.8rem}
.lunar-panel{background:#1e293b;border:1px solid #334155;border-radius:8px;padding:.7rem;text-align:center}
.lunar-title{font-size:.9rem;font-weight:700;margin-bottom:.5rem}
.lunar-title-1{color:#f59e0b}
.lunar-title-2{color:#a78bfa}
.lunar-visual{display:flex;align-items:center;justify-content:center;gap:1.2rem;margin:.6rem 0}
.lunar-moon{font-size:5rem;line-height:1;filter:drop-shadow(0 0 12px rgba(251,191,36,.3))}
.lunar-moon-inner{display:none}
.lunar-info{text-align:left}
.lunar-phase-name{font-size:1rem;font-weight:700;color:#fbbf24}
.lunar-tithi{font-size:.82rem;color:#e2e8f0;margin-top:2px}
.lunar-detail{font-size:.72rem;color:#94a3b8;margin-top:1px}
.lunar-transit-row{margin-top:.5rem;padding-top:.5rem;border-top:1px solid #334155;font-size:.8rem;color:#22d3ee}

/* ============================================================ */
/* ฤกษ์ (Rerk) Panel                                             */
/* ============================================================ */
#rerkArea{display:none;margin-top:.8rem}
#rerkArea2{display:none;margin-top:.8rem}
.rerk-panel{background:#1e293b;border:1px solid #334155;border-radius:8px;padding:.7rem}
.rerk-title{font-size:.9rem;font-weight:700;margin-bottom:.5rem;text-align:center}
.rerk-title-1{color:#f59e0b}
.rerk-title-2{color:#a78bfa}

/* Hero card — main Moon rerk */
.rerk-hero{display:flex;align-items:center;gap:.7rem;padding:.6rem .8rem;border-radius:8px;margin-bottom:.6rem;background:rgba(15,23,42,.6);border:1px solid #334155}
.rerk-hero-emoji{font-size:2rem;line-height:1}
.rerk-hero-info{flex:1}
.rerk-hero-label{font-size:.65rem;color:#94a3b8;margin-bottom:2px}
.rerk-hero-name{font-size:1.1rem;font-weight:800;letter-spacing:.5px}
.rerk-hero-name.rq-good{color:#34d399}
.rerk-hero-name.rq-bad{color:#f87171}
.rerk-hero-name.rq-neutral{color:#fbbf24}
.rerk-hero-nak{font-size:.7rem;color:#94a3b8;margin-top:1px}
.rerk-hero-desc{font-size:.72rem;color:#cbd5e1;margin-top:3px;font-style:italic}
.rerk-hero-badge{padding:2px 8px;border-radius:12px;font-size:.65rem;font-weight:700;white-space:nowrap;align-self:flex-start;margin-top:2px}
.rerk-hero-badge.rq-good{background:rgba(52,211,153,.15);color:#34d399;border:1px solid rgba(52,211,153,.3)}
.rerk-hero-badge.rq-bad{background:rgba(248,113,113,.15);color:#f87171;border:1px solid rgba(248,113,113,.3)}
.rerk-hero-badge.rq-neutral{background:rgba(251,191,36,.12);color:#fbbf24;border:1px solid rgba(251,191,36,.25)}

/* Grid of planet rerks */
.rerk-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:5px}
.rerk-card{display:flex;align-items:center;gap:6px;padding:5px 8px;border-radius:6px;background:rgba(30,41,59,.5);border:1px solid #334155;transition:border-color .2s}
.rerk-card:hover{border-color:#475569}
.rerk-card-emoji{font-size:1rem}
.rerk-card-info{flex:1;min-width:0}
.rerk-card-planet{font-size:.65rem;color:#94a3b8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rerk-card-name{font-size:.78rem;font-weight:700}
.rerk-card-name.rq-good{color:#34d399}
.rerk-card-name.rq-bad{color:#f87171}
.rerk-card-name.rq-neutral{color:#fbbf24}
.rerk-card-nak{font-size:.55rem;color:#64748b}

/* ============================================================ */
/* Chart Structure Panel (โครงสร้างดวง)                          */
/* ============================================================ */
#strengthArea{display:none;margin-top:.8rem}
#strengthArea2{display:none;margin-top:.8rem}
.str-panel{background:#1e293b;border:1px solid #334155;border-radius:8px;padding:.7rem}
.str-title{font-size:.9rem;font-weight:700;margin-bottom:.5rem;text-align:center}
.str-title-1{color:#f59e0b}
.str-title-2{color:#a78bfa}
.str-table{width:100%;border-collapse:collapse;font-size:.75rem}
.str-table th{background:#0f172a;color:#94a3b8;padding:4px 6px;text-align:left;font-weight:600;border-bottom:1px solid #334155}
.str-table td{padding:4px 6px;border-bottom:1px solid #1e293b;color:#e2e8f0}
.str-table tr:hover{background:#334155}
.str-lak-row{margin-top:.5rem;padding:.5rem;background:#0f172a;border-radius:5px;font-size:.78rem;color:#e2e8f0}
.str-lak-label{color:#94a3b8;font-size:.7rem}

/* ============================================================ */
/* Mode Switcher (สุริยยาตร์ / โหรา 7 เสา)                      */
/* ============================================================ */
.mode-bar{display:flex;justify-content:center;gap:.5rem;margin-bottom:1rem}
.mode-btn{padding:.5rem 1.2rem;border:2px solid #475569;border-radius:8px;background:transparent;color:#94a3b8;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}
.mode-btn.active{border-color:#f59e0b;background:#f59e0b;color:#1e293b}
.mode-btn:hover{opacity:.85}
#suriyaSection{display:block}
#horaSection{display:none}

/* ============================================================ */
/* โหรา 7 เสา — Styles                                          */
/* ============================================================ */
.hora-container{max-width:960px;margin:0 auto}
.hora-grid{display:grid;grid-template-columns:240px 1fr;gap:1rem;margin-top:1rem}
@media(max-width:700px){.hora-grid{grid-template-columns:1fr}}

.hora-card{background:#1e293b;border:1px solid #334155;border-radius:8px;padding:1rem;margin-bottom:1rem}
.hora-card h3{color:#f59e0b;font-size:.95rem;margin-bottom:.6rem}

.hora-input-row{margin-bottom:.6rem}
.hora-input-row label{display:block;color:#94a3b8;font-size:.8rem;margin-bottom:.2rem}
.hora-input-row input,.hora-input-row select{width:100%;padding:.4rem .5rem;border:1px solid #334155;border-radius:6px;background:#0f172a;color:#e2e8f0;font-size:.9rem}
.hora-input-row input:focus,.hora-input-row select:focus{border-color:#f59e0b;outline:none}

.hora-info{display:grid;grid-template-columns:1fr 1fr;gap:.3rem;margin-top:.5rem;font-size:.8rem;color:#94a3b8}
.hora-info span{color:#e2e8f0;font-weight:600}

/* 7-pillar table */
.hora-table{width:100%;border-collapse:collapse;font-size:.78rem;text-align:center}
.hora-table th{background:#1e293b;color:#f59e0b;padding:.35rem .2rem;border:1px solid #475569;font-weight:600;white-space:nowrap}
.hora-table td{padding:.3rem .2rem;border:1px solid #475569;color:#e2e8f0}
.hora-table .row-label{color:#94a3b8;font-size:.72rem;text-align:left;padding-left:.4rem;white-space:nowrap}
.hora-table .row-sub{color:#64748b;font-size:.6rem}
.hora-table .val{font-weight:700;color:#f8fafc}
.hora-table .val-sum{color:#38bdf8;font-weight:700}
.hora-table .val-ego{color:#a78bfa;font-weight:700}
.hora-table .val-asc{color:#34d399;font-weight:700}
.hora-table .val-elem{color:#fbbf24;font-weight:600}
.hora-table tr.separator td{border-top:2px solid #f59e0b}

/* Triwai grid */
.triwai-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;margin-top:.5rem}
.triwai-cell{background:#0f172a;border:1px solid #475569;padding:.4rem;text-align:center;border-radius:4px}
.triwai-cell.header{background:#1e293b;color:#f59e0b;font-weight:600;font-size:.72rem}
.triwai-cell .tw-val{font-size:1rem;font-weight:700;color:#f8fafc}
.triwai-cell .tw-lbl{font-size:.65rem;color:#94a3b8}
.triwai-cell .tw-pwr{font-size:.75rem;color:#38bdf8}

/* Compatibility */
.compat-card{background:#0f172a;border:1px solid #475569;border-radius:8px;padding:1rem;margin-top:.5rem}
.compat-pair{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:.5rem}
.compat-badge{background:#1e293b;border:1px solid #475569;border-radius:8px;padding:.5rem .8rem;text-align:center}
.compat-badge .zname{color:#f59e0b;font-weight:700;font-size:.9rem}
.compat-badge .ename{color:#94a3b8;font-size:.72rem}
.compat-vs{color:#64748b;font-size:1.2rem;font-weight:700}
.compat-desc{color:#e2e8f0;font-size:.85rem;line-height:1.5;text-align:center;padding:.5rem;background:#1e293b;border-radius:6px}

/* Star power */
.star-pw-row{background:#0f172a;border:1px solid #475569;border-radius:6px;padding:.6rem;margin-top:.4rem}
.star-pw-head{display:flex;align-items:center;gap:.5rem;margin-bottom:.3rem}
.star-pw-head .sp-col{color:#f59e0b;font-weight:700;font-size:.85rem}
.star-pw-head .sp-pwr{color:#38bdf8;font-weight:600;font-size:.8rem}
.star-pw-desc{color:#e2e8f0;font-size:.78rem;line-height:1.4}
.star-pw-pairs{margin-top:.3rem;padding-top:.3rem;border-top:1px solid #334155}
.star-pw-pairs .sp-pair{color:#94a3b8;font-size:.72rem;margin-top:.15rem}
.star-pw-pairs .sp-pair b{color:#a78bfa}

/* Triwai Swaie */
.tw-swaie-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:.5rem}
.tw-swaie-cell{background:#0f172a;border:1px solid #475569;padding:.3rem;text-align:center;border-radius:4px}
.tw-swaie-cell .tw-val{font-size:.95rem;font-weight:700;color:#f8fafc}
.tw-swaie-cell .tw-lbl{font-size:.6rem;color:#94a3b8}

/* HOME (บ้าน) */
.home-diagram{max-width:360px;margin:0 auto}
.home-table{width:100%;border-collapse:collapse;text-align:center}
.home-table td{padding:.5rem .3rem;border:1px solid #334155;font-size:.78rem;color:#e2e8f0}
.home-cell{background:#0f172a;border-radius:4px}
.home-val{font-size:1.3rem;font-weight:700}
.home-ok .home-val{color:#22c55e}
.home-bad .home-val{color:#ef4444}
.home-ok{border-color:#22c55e !important}
.home-bad{border-color:#ef4444 !important}
.home-label{color:#94a3b8;font-weight:600;font-size:.8rem;background:transparent;border-color:transparent !important}
.home-table small{color:#64748b}

/* HUMAN (คน) */
.human-table{width:100%;border-collapse:collapse;text-align:center;max-width:420px;margin:0 auto}
.human-table td{padding:.3rem .2rem;font-size:.72rem;color:#e2e8f0;vertical-align:middle}
.human-cell{background:#0f172a;border:1px solid #475569;border-radius:4px;padding:.4rem .2rem}
.human-val{font-size:1rem;font-weight:700;color:#38bdf8}
.human-side{color:#64748b;font-size:.65rem}

/* Hora view switcher (HOME / HUMAN) */
.hv-switch{display:flex;justify-content:center;gap:.4rem;margin-bottom:.8rem;flex-wrap:wrap}
.hv-btn{padding:.35rem .8rem;border:none;border-radius:6px;background:#1e293b;color:#94a3b8;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}
.hv-btn:hover{background:#334155;color:#e2e8f0}
.hv-btn.active{background:#f59e0b;color:#1e293b;box-shadow:0 0 8px rgba(245,158,11,.35)}
