/* ═══════════════════════════════════════════════════════════════
   Nyovah — Main Stylesheet — Light Mode
   Full rewrite from dark cosmic → warm parchment
   All class names preserved — zero HTML/JS changes needed
   ═══════════════════════════════════════════════════════════════ */

/* Design tokens are in tokens.css — load that file first */

/* ── Google Fonts are loaded in celestia.html ── */
/* Cormorant Garamond · Cinzel · DM Sans · Tiro Devanagari Sanskrit · Noto Sans Bengali */

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

/* ── LANGUAGE FONTS ── */
:lang(hi){font-family:'Tiro Devanagari Sanskrit',serif!important}
:lang(bn),:lang(as){font-family:'Noto Sans Bengali',sans-serif!important}

/* ── BASE ── */
html{scroll-behavior:smooth;-webkit-tap-highlight-color:transparent;scroll-padding-top:calc(var(--nav-h) + 8px)}
body{background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;font-weight:400;min-height:100vh;overflow-x:hidden;padding-top:var(--nav-h);padding-bottom:var(--bottom-nav-h);overscroll-behavior-y:none}

/* ── MOBILE TOUCH OPTIMISATIONS ── */
/* Eliminates ~300ms tap delay; prevents text-selection loupe on UI chrome */
button,a,[role="button"],
.bnav-item,.ny-chip,.yoga-badge,
.chat-sug-btn,.ask-chip,.rqn-btn,
.profile-tool-btn,.today-col-hdr,
.timeline-col-hdr,.saved-item,
.more-tab,.inline-followup-chip,
.ny-ask-entry,.ny-share-btn,
.lang-toggle,.btn-login-nav,
.k-test-card,.dasha-tl-seg,.antar-seg{
  touch-action:manipulation;
  -webkit-user-select:none;
  user-select:none;
}
/* Keep text selectable in content areas */
.ai-body,.chat-bubble,.ask-bubble,
.inline-bubble,.plain-summary-text{
  -webkit-user-select:text;
  user-select:text;
}

/* ── FOCUS STYLES — keyboard navigation ── */
/* Global: any focusable element that was reached via keyboard gets a gold ring */
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:4px}
/* Inputs: already have a custom gold border+shadow focus style — suppress the outline */
input:focus-visible,select:focus-visible,textarea:focus-visible{outline:none}
/* Buttons with their own active background (bnav, chat back) — tighten the radius */
.bnav-item:focus-visible{outline-offset:0;border-radius:var(--r-sm)}
.chat-back-btn:focus-visible,.modal-close:focus-visible{border-radius:50%}

/* Starfield hidden in light mode */
#starfield{display:none}
.star,.orb,.orb-1,.orb-2{display:none}

/* ── APP CONTAINER ── */
.app{position:relative;z-index:1;max-width:600px;margin:0 auto;padding:0 16px}
@media(min-width:768px){.app{max-width:900px;padding:0 32px}}
@media(min-width:1100px){.app{max-width:1100px}}

/* ── TOP NAV ── */
nav:not(.bottom-nav){display:flex;justify-content:space-between;align-items:center;padding:0 16px;height:var(--nav-h);position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(var(--bg-rgb),0.97);backdrop-filter:blur(20px) saturate(160%);border-bottom:1px solid var(--border);overflow:visible;box-sizing:border-box}
.logo{font-family:'Cinzel',serif;font-size:var(--text-base);color:var(--text);letter-spacing:3px;line-height:1.2;flex-shrink:1;min-width:0;white-space:nowrap;display:flex;align-items:center;gap:7px;cursor:pointer;background:none;border:none;padding:0}
.logo>div{display:flex;flex-direction:column}
.logo span{display:none;font-size:var(--text-xs);letter-spacing:2px}
@media(min-width:380px){.logo{font-size:var(--text-base)}.logo span{display:block;font-size:var(--text-xs);color:var(--text-muted);letter-spacing:1.5px;margin-top:1px;text-transform:uppercase}}
.nav-right{display:flex;align-items:center;gap:6px;flex-shrink:0}

/* Language toggle */
.lang-toggle{position:relative;display:flex;align-items:center;gap:3px;background:var(--bg2);border:1px solid var(--border-md);border-radius:var(--r-chip);padding:5px 10px;cursor:pointer;font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:1px;color:var(--gold);flex-shrink:0;user-select:none}
.lang-toggle:hover{background:var(--gold-bg)}
.lang-menu{position:absolute;top:calc(100% + 6px);right:0;background:var(--surface);border:1px solid var(--border-md);border-radius:var(--r-inner);padding:6px;z-index:200;min-width:140px;box-shadow:0 8px 32px rgba(var(--ink-rgb),0.15)}
.lang-menu button{display:block;width:100%;background:none;border:none;color:var(--text-dim);font-family:'DM Sans',sans-serif;font-size:12px;padding:8px 12px;text-align:left;cursor:pointer;border-radius:var(--r-xs);transition:all var(--dur-fast)}
.lang-menu button:hover{background:var(--gold-bg);color:var(--gold)}
.lang-btn{padding:5px 11px;border-radius:var(--r-chip);border:none;cursor:pointer;font-size:var(--text-sm);font-weight:500;transition:all var(--dur-base);background:none;color:var(--text-muted);white-space:nowrap}
.lang-btn.active{background:var(--gold);color:#fff}

/* Login/user */
.btn-login-nav{background:var(--gold-bg);border:1px solid rgba(var(--gold-rgb),0.3);color:var(--gold);padding:6px 12px;font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:1px;cursor:pointer;transition:all var(--dur-base);white-space:nowrap;flex-shrink:0;border-radius:var(--r-pill);text-transform:uppercase}
.btn-login-nav:hover{background:var(--gold);color:#fff}
.user-bar{display:none;align-items:center;gap:8px}
.user-bar.active{display:flex}
.user-avatar{width:44px;height:44px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;font-size:var(--text-base);color:#fff;font-family:'Cinzel',serif;font-weight:600;flex-shrink:0;cursor:pointer}
.user-name{display:none}
.btn-signout{background:none;border:none;color:var(--text-muted);font-size:var(--text-sm);cursor:pointer;font-family:'Cinzel',serif}

/* ── BOTTOM NAV ── */
.bottom-nav{position:fixed!important;bottom:0!important;left:0;right:0;z-index:999;background:rgba(var(--bg-rgb),0.97)!important;backdrop-filter:blur(24px);border-top:1px solid var(--border)!important;display:flex!important;height:var(--bottom-nav-h);padding:0 8px;padding-bottom:env(safe-area-inset-bottom);margin:0!important}
.bottom-nav--hidden{display:none!important}
body.no-bottom-nav{padding-bottom:0}
.bnav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;border:none;background:none;color:var(--text-muted);transition:all var(--dur-base);border-radius:var(--r-sm)!important;margin:7px 1px!important;padding:4px 2px;position:relative;overflow:hidden}
.bnav-item.active{color:var(--gold);background:var(--gold-bg)!important;border:1px solid rgba(var(--gold-rgb),0.2)!important}
.bnav-icon{font-size:var(--text-lg);line-height:1;transition:transform 0.2s}
.bnav-icon--svg{display:flex;align-items:center;justify-content:center;line-height:0}
.bnav-item.active .bnav-icon{transform:scale(1.1)}
.bnav-label{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:0.8px;text-transform:uppercase}
/* 6-item nav: shrink labels so all fit on 375px */
@media(max-width:430px){
  .bnav-label{font-size:8px;letter-spacing:0.3px}
  .bnav-item{margin:7px 0!important;padding:4px 1px}
  .bnav-icon{font-size:18px}
}
/* Hide labels on the smallest phones — icons remain, aria-labels keep accessibility */
@media(max-width:359px){
  .bnav-label{display:none}
  .bnav-item{gap:0;justify-content:center}
  .bnav-icon{font-size:18px}
}

/* ── PANELS ── */
.panel{display:none;animation:panelIn var(--dur-slow) var(--ease-spring);padding-top:20px;padding-bottom:20px}
.panel.active{display:block}
@keyframes panelIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* ── HERO (landing) ── */
.hero{text-align:center;padding:24px 0 16px}
.hero-tag{font-family:'DM Sans',sans-serif;font-size:var(--text-sm);letter-spacing:4px;color:var(--text-muted);text-transform:uppercase;margin-bottom:14px;display:flex;align-items:center;gap:10px;justify-content:center}
.hero-tag::before,.hero-tag::after{content:'';width:24px;height:1px;background:var(--border-md)}
.hero h1{font-family:'Cormorant Garamond',serif;font-size:var(--text-hero);font-weight:300;line-height:1.1;color:var(--text);letter-spacing:-0.5px;margin-bottom:14px}
.hero h1 em{font-style:italic;color:var(--gold)}
.hero p{font-size:var(--text-base);color:var(--text-muted);max-width:280px;margin:0 auto;line-height:1.8}
.live-tag{font-size:var(--text-sm);color:var(--green);margin-left:8px;letter-spacing:0;font-weight:400;vertical-align:middle}
.live-dot{display:inline-block;width:6px;height:6px;background:var(--green);border-radius:50%;animation:pulseG 2s ease-in-out infinite;margin-right:4px;vertical-align:middle}
@keyframes pulseG{0%,100%{opacity:0.5;transform:scale(0.9)}50%{opacity:1;transform:scale(1.1)}}

/* ── CARDS ── */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-card);padding:20px;margin-bottom:12px;position:relative;overflow:hidden}
.card::before{display:none}
.card-title{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:2.5px;color:var(--gold);text-transform:uppercase;margin-bottom:16px;display:flex;align-items:center;gap:8px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.card-title::after{content:'';flex:1;height:1px;background:var(--border)}

/* ── FORM ── */
.sacred-form{background:var(--surface);border:1px solid var(--border);border-radius:24px;padding:24px 20px;position:relative;margin-bottom:16px}
.sacred-form::before{display:none}
.form-title{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:3px;color:var(--text-muted);text-transform:uppercase;text-align:center;margin-bottom:20px;display:flex;align-items:center;gap:10px}
.form-title::before,.form-title::after{content:'';flex:1;height:1px;background:var(--border)}
.field{margin-bottom:14px}
.field label{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:2px;color:var(--text-muted);text-transform:uppercase;display:block;margin-bottom:6px}
.field input,.field select{background:var(--bg2);border:1px solid var(--border-md);border-radius:var(--r-inner);padding:12px 14px;color:var(--text);font-size:16px;font-family:'DM Sans',sans-serif;outline:none;width:100%;transition:all var(--dur-base);-webkit-appearance:none}
@media(min-width:768px){.field input,.field select{font-size:var(--text-md)}}
.field input:focus,.field select:focus{border-color:var(--gold);background:var(--gold-bg);box-shadow:0 0 0 3px rgba(var(--gold-rgb),0.08)}
.field input::placeholder{color:var(--text-muted)}
.field select option{background:var(--surface)}
.field input[type="date"]::-webkit-calendar-picker-indicator,.field input[type="time"]::-webkit-calendar-picker-indicator{filter:opacity(0.5)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:0}

/* ── BUTTONS ──────────────────────────────────────────────
   Canonical system — 5 variants
   New names:   .btn--primary  .btn--secondary  .btn--positive  .btn--hero  .btn--icon
   Legacy names aliased below — existing HTML + JS unchanged
   ─────────────────────────────────────────────────────── */

/* PRIMARY — gold fill, full-width (new) | btn-gold, k-next-btn (legacy) */
.btn--primary,.btn-gold,.k-next-btn{width:100%;padding:14px;border:none;border-radius:var(--r-inner);background:var(--gold-dim);color:#fff;font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:2px;font-weight:500;cursor:pointer;transition:all var(--dur-base);box-shadow:0 3px 14px rgba(var(--gold-rgb),0.25);text-transform:uppercase}
.btn--primary:hover,.btn-gold:hover,.k-next-btn:hover{background:var(--gold-darker);box-shadow:0 5px 20px rgba(var(--gold-rgb),0.35)}
.btn--primary:disabled,.btn-gold:disabled,.k-next-btn:disabled{opacity:0.4;cursor:not-allowed}
.btn--primary::before,.btn-gold::before{display:none}

/* HERO — primary but larger, with arrow animation | btn-generate, k-generate-btn (legacy) */
.btn--hero,.btn-generate,.k-generate-btn{width:100%;padding:17px;border:none;border-radius:var(--r-sm);background:var(--gold-dim);color:#fff;font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:3px;font-weight:500;cursor:pointer;margin-top:8px;transition:all var(--dur-base);box-shadow:0 4px 20px rgba(var(--gold-rgb),0.3);text-transform:uppercase;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;gap:10px}
.btn--hero:hover,.btn-generate:hover,.k-generate-btn:hover{background:var(--gold-darker);box-shadow:0 6px 28px rgba(var(--gold-rgb),0.4);transform:translateY(-1px)}
.btn--hero:active,.btn-generate:active,.k-generate-btn:active{transform:scale(0.98)}
.btn-generate::before,.k-btn-shine{display:none}
.k-btn-text,.k-btn-arrow{position:relative;z-index:1}
.k-generate-btn:hover .k-btn-arrow{transform:translateX(4px)}
.k-form-footer{text-align:center;font-size:var(--text-sm);color:var(--text-muted);margin-top:12px;display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}

/* SECONDARY — gold outline | btn-outline, k-back-btn (legacy) */
.btn--secondary,.btn-outline{flex:1;padding:13px;background:transparent;border:1px solid rgba(var(--gold-rgb),0.3);color:var(--gold);border-radius:var(--r-inner);font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:1.5px;cursor:pointer;transition:all var(--dur-base);text-transform:uppercase}
.btn--secondary:hover,.btn-outline:hover{border-color:var(--gold);background:var(--gold-bg)}
/* k-back-btn: secondary but with subtle ink border (wizard back step) */
.k-back-btn{width:100%;padding:11px;background:transparent;border:1px solid var(--border);border-radius:13px;color:var(--ink4);font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:2px;cursor:pointer;text-transform:uppercase;margin-top:8px;transition:all var(--dur-fast)}
.k-back-btn:hover{background:var(--bg2);color:var(--ink2)}

/* POSITIVE — sage/green | btn-green (legacy) */
.btn--positive,.btn-green{flex:1;padding:13px;background:var(--sage-bg);border:1px solid rgba(var(--sage-rgb),0.25);color:var(--green);border-radius:var(--r-inner);font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:1.5px;cursor:pointer;transition:all var(--dur-base);text-transform:uppercase}
.btn--positive:hover,.btn-green:hover{background:rgba(var(--sage-rgb),0.2)}

.action-bar{display:flex;gap:10px;margin-top:14px}

/* ── LOADER ── */
.loader{display:none;flex-direction:column;align-items:center;gap:20px;padding:52px 16px;text-align:center}
.loader.active{display:flex}
.yantra-wrap{position:relative;width:80px;height:80px}
.yantra-ring{position:absolute;inset:0;border-radius:50%;border:1px solid transparent}
.yantra-ring-1{border-color:rgba(var(--gold-rgb),0.5);animation:spin 6s linear infinite}
.yantra-ring-2{inset:12px;border-color:rgba(var(--gold-rgb),0.25);animation:spin 4s linear infinite reverse}
.yantra-ring-3{inset:24px;border-color:rgba(var(--gold-rgb),0.15);animation:spin 3s linear infinite}
.yantra-center{position:absolute;inset:32px;background:radial-gradient(circle,rgba(var(--gold-rgb),0.3),transparent);border-radius:50%;animation:pulseG 2s ease-in-out infinite}
.yantra-sym{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--gold);animation:pulseG 2s ease-in-out infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loader-text{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:3px;color:var(--gold);text-transform:uppercase;animation:fadeFlick 2s ease-in-out infinite}
.loader-sub{font-size:12px;color:var(--text-muted);font-style:italic}
@keyframes fadeFlick{0%,100%{opacity:0.4}50%{opacity:1}}

/* Kundli loader mandala */
.k-loader-mandala{position:relative;width:80px;height:80px;margin:0 auto 18px;display:flex;align-items:center;justify-content:center}
.klm-ring{position:absolute;inset:0;border-radius:50%;border:1px solid transparent}
.klm-r1{border-color:rgba(var(--gold-rgb),0.5);animation:spin 5s linear infinite}
.klm-r2{inset:14px;border-color:rgba(var(--gold-rgb),0.25);animation:spin 3.5s linear infinite reverse}
.klm-r3{inset:26px;border-color:rgba(var(--gold-rgb),0.12);animation:spin 2.5s linear infinite}
.klm-center{position:relative;z-index:2;font-size:24px;color:var(--gold);animation:pulseG 2s ease-in-out infinite}
.k-loader-text{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:3px;color:var(--gold);text-transform:uppercase;animation:fadeFlick 2s ease-in-out infinite}
.k-loader-steps{margin-top:10px;display:flex;flex-direction:column;gap:5px;align-items:center}
.kls{font-size:var(--text-sm);color:var(--text-muted);opacity:0.4;transition:all 0.5s}
.kls.active{opacity:1;color:var(--gold);font-weight:500}

/* ── CHART HERO ── */
.chart-hero{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-card);padding:28px 16px 22px;text-align:center;position:relative;margin-bottom:12px;overflow:hidden}
.chart-hero::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.chart-hero::after{display:none}
.chart-hero-name{font-family:'Cormorant Garamond',serif;font-size:32px;font-weight:400;color:var(--text);margin-bottom:4px;animation:fadeUp 0.5s ease}
.chart-hero-meta{font-size:var(--text-sm);color:var(--text-muted);margin-bottom:14px;animation:fadeUp 0.5s 0.1s ease both}
.chart-badges{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;animation:fadeUp 0.5s 0.2s ease both}
.chart-badge-pill{background:var(--bg2);border:1px solid var(--border-md);border-radius:var(--r-pill);padding:5px 13px;font-size:var(--text-sm);color:var(--text-dim);font-family:'Cinzel',serif;letter-spacing:0.5px}
.chart-badge-pill.gold{background:var(--gold-bg);border-color:rgba(var(--gold-rgb),0.3);color:var(--gold)}

/* ── CHART GRID ── */
/* Chart wheel always on top, full width. Planet table below, full width. */
.chart-main-grid{display:grid;grid-template-columns:1fr;gap:16px;margin:16px 0}
@media(min-width:768px){.chart-wheel-card{max-width:520px;margin:0 auto}}
.chart-wheel-card,.chart-planets-card{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:0;position:relative;overflow:visible}
.chart-wheel-card::before,.chart-planets-card::before{display:none}
.chart-wheel-title{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:2px;color:var(--gold);text-transform:uppercase;margin-bottom:10px;text-align:center;padding-top:14px}

/* Planet table */
.planets-header{display:grid!important;grid-template-columns:28px 1fr 1fr 44px;gap:6px;padding:10px 14px;font-family:Cinzel,serif;font-size:var(--text-xs);letter-spacing:1.5px;color:var(--text-muted);text-transform:uppercase;border-bottom:1px solid var(--border)}
.planet-list{display:block!important;padding:4px 6px 12px}
.planet-row{display:grid!important;grid-template-columns:28px 1fr 1fr 44px;gap:6px;align-items:center;padding:9px 8px;border-radius:var(--r-tag);transition:background 0.15s}
/* On very narrow screens drop the dignity column */
@media(max-width:400px){
  .planets-header,.planet-row{grid-template-columns:26px 1fr 44px}
  .planet-dign{display:none}
}
.planet-row:hover{background:var(--bg2)}
.planet-sym{font-size:var(--text-lg);text-align:center;line-height:1}
.planet-nm{font-size:12px;color:var(--text);font-weight:500;letter-spacing:0.2px}
.planet-sign{font-size:var(--text-sm);color:var(--text-dim);font-weight:300}
.planet-house{font-size:var(--text-sm);font-family:Cinzel,serif;color:var(--gold);font-weight:500;line-height:1.4}
.planet-dign{font-size:var(--text-sm);color:var(--text-muted)}

/* ── AI SECTIONS ── */
.ai-section{border-radius:var(--r-card);overflow:hidden;margin:16px 0;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow)}
.ai-section::before{content:'';display:block;height:3px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.ai-header{display:flex;align-items:center;gap:12px;padding:18px 20px 14px;border-bottom:1px solid var(--border)}
.ai-avatar{width:42px;height:42px;background:var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.ai-title{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:2px;color:var(--gold);text-transform:uppercase}
.ai-subtitle{font-size:var(--text-sm);color:var(--text-muted);margin-top:2px;font-style:italic}
.ai-body{padding:18px 20px 22px;font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:500;line-height:1.9;color:var(--text)}
:lang(hi) .ai-body,:lang(bn) .ai-body,:lang(as) .ai-body{font-family:'Tiro Devanagari Sanskrit','Noto Sans Bengali','DM Sans',sans-serif;font-size:15px;line-height:2}
.ai-body p{margin-bottom:14px}
.ai-body strong{color:var(--gold);font-weight:500}
.ai-body h3{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:2.5px;color:var(--gold);text-transform:uppercase;margin:22px 0 10px;display:flex;align-items:center;gap:10px;opacity:0.85}
.ai-body h3::before{content:'✦';color:var(--gold)}
.ai-body h3::after{content:'';flex:1;height:1px;background:var(--border)}
.ai-typing{display:flex;align-items:center;gap:10px;padding:20px;color:var(--text-muted);font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:2px;text-transform:uppercase}
.ai-dots{display:flex;gap:4px}
.ai-dots span{width:6px;height:6px;background:var(--gold);border-radius:50%;animation:dotP 1.4s ease-in-out infinite;opacity:0.4}
.ai-dots span:nth-child(2){animation-delay:0.2s}.ai-dots span:nth-child(3){animation-delay:0.4s}
@keyframes dotP{0%,60%,100%{transform:translateY(0);opacity:0.3}30%{transform:translateY(-7px);opacity:1}}

/* ── SECTION DIVIDERS ── */
.section-divider{display:flex;align-items:center;gap:12px;margin:24px 0 16px;color:var(--text-muted);font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:3px;text-transform:uppercase}
.section-divider::before,.section-divider::after{content:'';flex:1;height:1px;background:var(--border)}

/* ── REPORT QUICKNAV ── */
.report-quicknav{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:18px}
@media(min-width:360px){.report-quicknav{grid-template-columns:1fr 1fr 1fr}}
.rqn-btn{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-chip);padding:18px 8px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:6px;transition:all var(--dur-base);position:relative}
.rqn-btn::before{display:none}
.rqn-btn:hover,.rqn-btn:active{border-color:rgba(var(--gold-rgb),0.3);background:var(--gold-bg);transform:translateY(-2px);box-shadow:0 6px 20px rgba(var(--gold-rgb),0.12)}
.rqn-icon{font-size:24px;transition:transform 0.2s}
.rqn-btn:hover .rqn-icon{transform:scale(1.1) translateY(-1px)}
.rqn-label{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:1.5px;color:var(--text-dim);text-transform:uppercase}
.rqn-status{font-size:var(--text-sm);color:var(--text-muted)}

/* ── EMPTY STATES ── */
.kundli-empty-state{text-align:center;padding:52px 20px 36px}
.empty-mandala{font-size:56px;opacity:0.12;margin-bottom:18px;display:block;animation:spin 30s linear infinite}
.empty-title{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:3px;color:var(--gold);text-transform:uppercase;margin-bottom:10px}
.empty-text{font-size:var(--text-base);color:var(--text-muted);line-height:1.85;max-width:240px;margin:0 auto}
.empty-text strong{color:var(--gold)}
.error-box{display:none;background:rgba(var(--rose-rgb),0.06);border:1px solid rgba(var(--rose-rgb),0.2);border-radius:var(--r-inner);padding:12px 14px;color:var(--rose);font-size:var(--text-base);margin:10px 0;font-style:italic}
.error-box.active{display:block}

/* ── CHART ACTIVE BAR ── */
.chart-active-bar{background:var(--gold-bg);border-bottom:1px solid rgba(var(--gold-rgb),0.15);padding:10px 20px;display:none;align-items:center;gap:10px;margin:0 -16px;cursor:pointer}
.chart-active-bar.show{display:flex}
.cab-dot{width:6px;height:6px;background:var(--green);border-radius:50%;flex-shrink:0}
.cab-name{font-family:'Cinzel',serif;font-size:var(--text-sm);color:var(--gold);letter-spacing:1px;flex:1}
.cab-detail{font-size:var(--text-sm);color:var(--text-muted)}
.cab-action{font-size:var(--text-sm);color:var(--gold);font-family:'Cinzel',serif}

/* ── SAVED CHARTS BAR ── */
.saved-bar{display:none;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:12px 14px;margin-bottom:12px}
.saved-bar.active{display:block}
.saved-bar-title{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:2px;color:var(--text-muted);text-transform:uppercase;margin-bottom:8px}
.saved-list{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none}
.saved-list::-webkit-scrollbar{display:none}
.saved-item{background:var(--bg2);border:1px solid var(--border-md);border-radius:var(--r-tag);padding:7px 12px;cursor:pointer;white-space:nowrap;font-size:12px;color:var(--text-dim);transition:all var(--dur-base);flex-shrink:0}
.saved-item:hover{border-color:rgba(var(--gold-rgb),0.3);color:var(--gold);background:var(--gold-bg)}
.back-to-chart{display:flex;align-items:center;gap:10px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-inner);padding:11px 14px;cursor:pointer;font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:1.5px;color:var(--text-muted);margin-bottom:14px;transition:all var(--dur-base);width:100%;text-transform:uppercase}
.back-to-chart:hover{background:var(--gold-bg);color:var(--gold)}

/* ── MORE TABS ── */
.more-tabs{display:flex;gap:6px;overflow-x:auto;margin-bottom:14px;scrollbar-width:none;padding:2px 0}
.more-tabs::-webkit-scrollbar{display:none}
.more-tab{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-pill);padding:7px 16px;cursor:pointer;white-space:nowrap;font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:1px;color:var(--text-muted);transition:all var(--dur-base);flex-shrink:0;text-transform:uppercase}
.more-tab.active,.more-tab:hover{border-color:rgba(var(--gold-rgb),0.3);color:var(--gold);background:var(--gold-bg)}
.more-content{display:none}
.more-content.active{display:block}

/* ── CHAT ── */
.chat-fab{position:fixed;bottom:calc(var(--bottom-nav-h) + 16px);right:16px;z-index:500;width:52px;height:52px;background:var(--gold);border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:0 4px 20px rgba(var(--gold-rgb),0.4);transition:transform 0.2s,box-shadow 0.2s}
.chat-fab:hover{transform:scale(1.05);box-shadow:0 6px 28px rgba(var(--gold-rgb),0.5)}
.chat-fab:active{transform:scale(0.92)}
.chat-badge{position:absolute;top:-2px;right:-2px;width:16px;height:16px;background:var(--rose);border-radius:50%;font-size:var(--text-sm);color:white;display:none;align-items:center;justify-content:center}
.chat-badge.active{display:flex}
/* FULL SCREEN CHAT — slides in from right like WhatsApp */
.chat-panel{
  position:fixed;inset:0;z-index:800;
  background:var(--bg);
  display:flex;flex-direction:column;
  transform:translateX(100%);
  transition:transform var(--dur-slow) var(--ease-slide);
  will-change:transform;
}
.chat-panel.open{transform:translateX(0)}
@media(min-width:540px){
  .chat-panel{left:50%;right:auto;width:480px;box-shadow:-4px 0 40px rgba(0,0,0,0.12);transform:translateX(100%)}
  .chat-panel.open{transform:translateX(0)}
}
.chat-header{
  display:flex;align-items:center;gap:0;
  padding:0 6px;height:56px;
  border-bottom:1px solid var(--border);
  flex-shrink:0;background:var(--surface);
  position:sticky;top:0;z-index:2;
}
.chat-back-btn{
  width:44px;height:44px;display:flex;align-items:center;justify-content:center;
  background:none;border:none;font-size:20px;color:var(--gold);cursor:pointer;
  flex-shrink:0;border-radius:50%;transition:background 0.15s;
}
.chat-back-btn:active{background:var(--gold-bg)}
.chat-header-center{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center}
.chat-header-name{font-family:'Cinzel',serif;font-size:12px;letter-spacing:2px;color:var(--ink);text-transform:uppercase}
.chat-header-status{font-size:var(--text-sm);color:var(--green);margin-top:1px;letter-spacing:0.3px}
.chat-header-avatar{display:none}
.chat-header-info{display:none}
.chat-close-btn{background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:4px 8px;line-height:1}
.chat-messages{flex:1;overflow-y:auto;padding:14px 16px 80px;display:flex;flex-direction:column;gap:10px;background:var(--bg);overscroll-behavior:contain}
.chat-msg{max-width:85%;animation:fadeIn 0.2s ease}
.chat-msg.user{align-self:flex-end}
.chat-msg.ai{align-self:flex-start}
.chat-bubble{padding:11px 15px;border-radius:var(--r-chip);font-size:var(--text-md);line-height:1.6}
.chat-msg.user .chat-bubble{background:var(--gold);color:#fff;border-radius:var(--r-chip) 16px 4px 16px;font-weight:400}
.chat-msg.ai .chat-bubble{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:var(--r-chip) 16px 16px 4px;font-family:'Cormorant Garamond',serif;font-size:var(--text-lg);font-weight:500;line-height:1.75}
:lang(hi) .chat-msg.ai .chat-bubble,:lang(bn) .chat-msg.ai .chat-bubble,:lang(as) .chat-msg.ai .chat-bubble{font-family:'Tiro Devanagari Sanskrit','Noto Sans Bengali','DM Sans',sans-serif;font-size:var(--text-md)}
.chat-msg.ai .chat-bubble strong{color:var(--gold)}
.chat-typing{display:none;align-self:flex-start;padding:11px 15px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-chip) 16px 16px 4px;gap:4px;align-items:center}
.chat-typing.active{display:flex}
.chat-dot{width:6px;height:6px;background:var(--gold);border-radius:50%;animation:chatDot 1.2s ease infinite;opacity:0.4}
.chat-dot:nth-child(2){animation-delay:0.2s}.chat-dot:nth-child(3){animation-delay:0.4s}
@keyframes chatDot{0%,60%,100%{transform:translateY(0);opacity:0.3}30%{transform:translateY(-5px);opacity:1}}
.chat-suggestions{display:flex;gap:8px;padding:0 14px 8px;overflow-x:auto;flex-shrink:0;scrollbar-width:none}
.chat-suggestions::-webkit-scrollbar{display:none}
.chat-sug-btn{background:var(--gold-bg);border:1px solid rgba(var(--gold-rgb),0.25);border-radius:var(--r-pill);padding:6px 13px;font-size:var(--text-sm);color:var(--gold);cursor:pointer;white-space:nowrap;font-family:'Cinzel',serif;letter-spacing:0.5px;flex-shrink:0}
.chat-sug-btn:active,.chat-sug-btn:hover{background:var(--gold);color:#fff}
.chat-input-row{
  display:flex;gap:10px;
  padding:10px 14px;
  padding-bottom:max(10px,env(safe-area-inset-bottom));
  border-top:1px solid var(--border);
  flex-shrink:0;
  background:var(--surface);
  position:sticky;bottom:0;z-index:2;
}
.chat-input{flex:1;background:var(--bg2);border:1px solid var(--border-md);border-radius:22px;padding:10px 15px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:16px;outline:none;resize:none;line-height:1.4;max-height:80px}
@media(min-width:768px){.chat-input{font-size:var(--text-md)}}
.chat-input:focus{border-color:var(--gold);background:var(--surface)}
/* ICON — round gold send button | chat-send-btn, ask-send-btn (legacy aliases) */
.btn--icon,.chat-send-btn,.ask-send-btn{width:44px;height:44px;background:var(--gold-dim);border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;align-self:flex-end;color:#fff;transition:transform 0.1s,box-shadow 0.15s;box-shadow:0 3px 10px rgba(var(--gold-rgb),0.3)}
.btn--icon:active,.chat-send-btn:active,.ask-send-btn:active{transform:scale(0.93)}

/* ── PROFILE PANEL ── */
.profile-panel{position:fixed;top:0;right:0;bottom:0;width:min(360px,100vw);background:var(--surface);z-index:700;transform:translateX(100%);transition:transform var(--dur-slow) var(--ease-slide);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;overscroll-behavior:contain}
.profile-panel.open{transform:translateX(0)}
.profile-header{background:var(--gold-bg);padding:44px 20px 18px;text-align:center;border-bottom:1px solid var(--border);position:relative}
.profile-avatar-big{width:68px;height:68px;background:var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--text-2xl);color:#fff;font-family:'Cinzel',serif;font-weight:600;margin:0 auto 10px}
.profile-name{font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--text);margin-bottom:3px}
.profile-email{font-size:var(--text-sm);color:var(--text-muted)}
.profile-close{position:absolute;top:14px;right:14px;background:none;border:none;color:var(--text-muted);font-size:20px;cursor:pointer}
.profile-tabs{display:flex;border-bottom:1px solid var(--border);padding:0 10px}
.profile-tab{flex:1;background:none;border:none;color:var(--text-muted);font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:1.5px;padding:12px 4px;cursor:pointer;border-bottom:2px solid transparent;transition:all var(--dur-base);text-transform:uppercase}
.profile-tab.active{color:var(--gold);border-bottom-color:var(--gold)}
.profile-tab-panel{overflow-y:auto;flex:1;display:none}
.profile-stats{display:flex;border:1px solid var(--border);border-radius:var(--r-inner);overflow:hidden;margin:12px 0}
.profile-stat{flex:1;text-align:center;padding:12px 4px;border-right:1px solid var(--border)}
.profile-stat:last-child{border-right:none}
.profile-stat span{display:block;font-family:'Cinzel',serif;font-size:20px;color:var(--gold)}
.profile-stat small{font-size:var(--text-xs);color:var(--text-muted);letter-spacing:1px;text-transform:uppercase}
.profile-section{padding:14px 18px}
.profile-section-title{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:2.5px;color:var(--gold);text-transform:uppercase;margin-bottom:10px}
.profile-new-chart-row{padding:14px 14px 6px}
.profile-new-chart-btn{width:100%;background:transparent;border:1.5px dashed rgba(var(--gold-rgb),0.45);border-radius:var(--r-inner);padding:12px 16px;color:var(--gold);font-family:'Cinzel',serif;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all var(--dur-base)}
.profile-new-chart-btn:hover,.profile-new-chart-btn:active{background:var(--gold-bg);border-color:var(--gold)}
.profile-new-chart-icon{font-size:14px;display:flex;align-items:center}
/* ── Nyovah logomark (SVG <use href="#ny-mark">) ── */
.ny-mark{display:block;width:100%;height:100%;color:inherit}
.ai-avatar .ny-mark{width:22px;height:22px;color:#fff}
.ask-avatar .ny-mark{width:20px;height:20px;color:#fff}
.ny-ask-entry-avatar .ny-mark{width:18px;height:18px;color:#fff}
.k-step-icon .ny-mark{width:28px;height:28px;color:var(--gold);margin:0 auto}
.profile-new-chart-icon .ny-mark{width:14px;height:14px;color:var(--gold)}
.profile-chart-item{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-inner);padding:11px 13px;margin-bottom:7px;display:flex;align-items:center;gap:10px;cursor:pointer;transition:all var(--dur-fast)}
.profile-chart-item:hover{background:var(--gold-bg);border-color:rgba(var(--gold-rgb),0.25)}
.profile-chart-icon{font-size:16px;flex-shrink:0}
.profile-chart-info{flex:1;min-width:0}
.profile-chart-name{font-size:var(--text-base);color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.profile-chart-meta{font-size:var(--text-sm);color:var(--text-muted);margin-top:2px}
.profile-chart-del{background:none;border:none;color:var(--text-muted);font-size:16px;cursor:pointer;padding:4px;flex-shrink:0}
.profile-btn{width:100%;padding:12px;border-radius:var(--r-inner);border:none;cursor:pointer;font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:1.5px;margin-bottom:7px;text-transform:uppercase;transition:all var(--dur-fast)}
.profile-btn-outline{background:transparent;border:1px solid rgba(var(--gold-rgb),0.25);color:var(--gold)}
.profile-btn-outline:hover{background:var(--gold-bg)}
.profile-btn-danger{background:transparent;border:1px solid rgba(var(--rose-rgb),0.2);color:var(--rose)}
.profile-footer{padding:12px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px}
.profile-empty{text-align:center;padding:28px 14px;color:var(--text-muted);font-size:12px}
.profile-empty-icon{font-size:28px;margin-bottom:8px}
/* ── MY LIFE facts list ── */
.fact-item{display:flex;align-items:flex-start;gap:9px;background:var(--bg2);border:1px solid var(--border);border-left:3px solid transparent;border-radius:11px;padding:10px 12px;margin-bottom:7px;transition:border-color var(--dur-fast) var(--ease-std)}
.fact-item:hover{border-color:rgba(var(--gold-rgb),0.25)}
/* Confirmed facts get a sage left border — subtle, not loud */
.fact-item--confirmed{border-left-color:var(--sage)}
.fact-year{font-size:var(--text-sm);color:var(--text-muted);flex-shrink:0;width:30px;text-align:right;margin-top:2px;letter-spacing:0.2px;opacity:0.65}
.fact-emoji{font-size:15px;flex-shrink:0;margin-top:1px}
.fact-text{flex:1;font-size:12px;color:var(--ink);line-height:1.5}
/* Actions cluster: confirm + delete sit together, right-aligned */
.fact-actions{display:flex;align-items:center;gap:4px;flex-shrink:0;margin-top:1px}
.fact-confirm{background:none;border:1px solid rgba(var(--sage-rgb),0.3);border-radius:var(--r-2xs);color:rgba(var(--sage-rgb),0.5);font-size:11px;font-weight:700;cursor:pointer;padding:1px 5px;line-height:1.4;transition:color var(--dur-fast) var(--ease-std),border-color var(--dur-fast) var(--ease-std),background var(--dur-fast) var(--ease-std)}
.fact-confirm:hover{color:var(--sage);border-color:var(--sage);background:rgba(var(--sage-rgb),0.08)}
.fact-confirm--done{color:var(--sage);border-color:var(--sage);background:rgba(var(--sage-rgb),0.1);cursor:default}
.fact-confirm--done:hover{color:var(--sage);border-color:var(--sage);background:rgba(var(--sage-rgb),0.1)}
.fact-del{background:none;border:none;color:var(--text-muted);font-size:16px;cursor:pointer;padding:0 2px;line-height:1;flex-shrink:0;opacity:0.5;transition:opacity var(--dur-fast) var(--ease-std)}
.fact-del:hover{opacity:1;color:var(--rose)}
@media(prefers-reduced-motion:reduce){.fact-item,.fact-confirm,.fact-del{transition:none}}
.profile-overlay{position:fixed;inset:0;background:rgba(var(--ink-rgb),0.4);z-index:690;opacity:0;pointer-events:none;transition:opacity 0.3s ease}
.profile-overlay.active{opacity:1;pointer-events:auto}

/* ── AUTH MODAL ── */
.auth-modal{position:fixed;inset:0;z-index:800;display:none;align-items:flex-end;justify-content:center}
.auth-modal.active{display:flex}
.auth-overlay{position:absolute;inset:0;background:rgba(var(--ink-rgb),0.6);backdrop-filter:blur(6px)}
.auth-sheet{position:relative;z-index:1;background:var(--surface);border-top:1px solid var(--border);border-radius:24px 24px 0 0;padding:18px 20px 26px;width:100%;max-width:480px;margin:0 auto}
.auth-sheet::before{content:'';display:block;width:36px;height:3px;background:var(--border-md);border-radius:2px;margin:0 auto 14px}
.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;color:var(--text-muted);font-size:16px;cursor:pointer;padding:4px 8px;line-height:1}
.modal-logo{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:3px;color:var(--gold);text-align:center;margin-bottom:5px;text-transform:uppercase;display:flex;align-items:center;justify-content:center;gap:8px}
.modal-title{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:400;color:var(--text);text-align:center;margin-bottom:12px}
.modal-title em{font-style:italic;color:var(--gold)}
.btn-google{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:11px 14px;background:var(--bg2);border:1px solid var(--border-md);border-radius:var(--r-inner);color:var(--text);font-family:'DM Sans',sans-serif;font-size:var(--text-base);cursor:pointer;transition:all var(--dur-base);margin-bottom:10px}
.btn-google:hover{background:var(--bg3);border-color:var(--border-md)}
.auth-divider{display:flex;align-items:center;gap:10px;font-size:var(--text-sm);color:var(--text-muted);margin-bottom:10px}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.auth-input{width:100%;background:var(--bg2);border:1px solid var(--border-md);border-radius:var(--r-tag);padding:10px 13px;color:var(--text);font-size:var(--text-base);font-family:'DM Sans',sans-serif;outline:none;transition:all var(--dur-base);margin-bottom:7px;display:block;box-sizing:border-box}
.auth-input:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(var(--gold-rgb),0.08)}
.auth-input::placeholder{color:var(--text-muted)}
.auth-error{color:var(--rose);font-size:var(--text-sm);margin-bottom:7px;font-style:italic;min-height:0}
.auth-error.active{margin-bottom:9px}
.auth-switch{text-align:center;font-size:var(--text-sm);color:var(--text-muted);margin-top:10px}
.auth-switch a{color:var(--gold);cursor:pointer;text-decoration:none}
#auth-submit-btn{padding:11px;font-size:var(--text-sm);letter-spacing:2px;margin-top:3px}

/* ── KUNDLI HERO SECTION ── */
.k-hero{padding:32px 0 24px;text-align:center;position:relative;overflow:hidden}
.k-hero-bg,.k-orb-1,.k-orb-2,.k-orb-3{display:none}
.k-hero-eyebrow{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:5px;color:var(--gold);text-transform:uppercase;margin-bottom:10px}
.k-hero-title{font-family:'Cormorant Garamond',serif;font-size:var(--text-hero);font-weight:300;line-height:1.15;color:var(--text);margin-bottom:12px;letter-spacing:-0.3px}
.k-hero-title em{font-style:italic;color:var(--gold);display:block}
.k-hero-sub{font-size:12px;color:var(--text-muted);letter-spacing:0.5px;margin-bottom:14px}
.k-hero-trust{display:flex;align-items:center;justify-content:center;gap:8px;font-size:var(--text-sm);color:var(--text-muted);flex-wrap:wrap}
.k-hero-cta{margin-top:22px;padding:14px 32px;background:var(--gold);color:#fff;border:none;border-radius:50px;font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:1px;cursor:pointer;transition:opacity 0.2s,transform 0.2s}
.k-hero-cta:hover{opacity:0.9;transform:translateY(-1px)}
.k-hero-cta:active{transform:translateY(0)}
.k-hero-auth{transition:all 0.3s}
.k-hero-auth.hidden{max-height:0;overflow:hidden;opacity:0}

/* ── KUNDLI FORM CARD ── */
.k-form-card{background:var(--surface);border:1px solid var(--border);border-radius:24px;padding:24px 20px;position:relative;overflow:hidden;margin-bottom:18px}
.k-form-card::before{display:none}
.k-form-header{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border)}
.k-form-header-icon{width:40px;height:40px;background:var(--gold-bg);border:1px solid rgba(var(--gold-rgb),0.25);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;color:var(--gold);flex-shrink:0}
.k-form-header-title{font-family:'Cinzel',serif;font-size:12px;letter-spacing:1px;color:var(--text);margin-bottom:3px}
.k-form-header-sub{font-size:var(--text-sm);color:var(--text-muted)}
.k-field-group{margin-bottom:0}
.k-field{margin-bottom:14px}
.k-field-full{width:100%}
.k-field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.k-field-slim .k-label{font-size:var(--text-xs)}
.k-label{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:2px;color:var(--text-muted);text-transform:uppercase;display:block;margin-bottom:7px}
.k-input{width:100%;background:var(--bg2);border:1px solid var(--border-md);border-radius:13px;padding:13px 15px;color:var(--text);font-size:16px;font-family:'DM Sans',sans-serif;outline:none;transition:all var(--dur-base);-webkit-appearance:none}
@media(min-width:768px){.k-input{font-size:var(--text-md)}}
.k-input:focus{border-color:var(--gold);background:var(--gold-bg);box-shadow:0 0 0 3px rgba(var(--gold-rgb),0.08)}
.k-input::placeholder{color:var(--text-muted)}
.k-input option{background:var(--surface)}
.k-input[type="date"]::-webkit-calendar-picker-indicator,.k-input[type="time"]::-webkit-calendar-picker-indicator{filter:opacity(0.5)}
.k-coords-pill{display:inline-flex;align-items:center;gap:5px;font-size:var(--text-sm);color:var(--gold);background:var(--gold-bg);border:1px solid rgba(var(--gold-rgb),0.2);border-radius:var(--r-pill);padding:4px 11px;margin-top:6px}

/* ── TESTIMONIALS ── */
.k-testimonials{padding:6px 0 20px}
.k-test-title{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:3px;color:var(--text-muted);text-transform:uppercase;text-align:center;margin-bottom:14px}
.k-test-scroll{display:flex;gap:12px;overflow-x:auto;padding:4px 2px 8px;scrollbar-width:none;overscroll-behavior:contain}
.k-test-scroll::-webkit-scrollbar{display:none}
.k-test-card{flex-shrink:0;width:220px;background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:15px;position:relative}
.k-test-card::before{display:none}
.k-test-stars{color:var(--gold);font-size:var(--text-sm);margin-bottom:8px;letter-spacing:2px}
.k-test-text{font-family:'Cormorant Garamond',serif;font-size:var(--text-md);color:var(--text-dim);line-height:1.6;margin-bottom:10px;font-style:italic}
.k-test-author{font-size:var(--text-sm);color:var(--text-muted)}

/* ── WHY NYOVAH ── */
.k-why-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px}
.k-why-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-chip);padding:16px}
.k-why-icon{font-size:22px;margin-bottom:8px}
.k-why-label{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:1.5px;color:var(--gold);text-transform:uppercase;margin-bottom:4px}
.k-why-text{font-size:var(--text-sm);color:var(--text-muted);line-height:1.6}

/* ── DASHA ── */
.dasha-timeline{margin:16px 0}
.dasha-item{display:flex;gap:14px;margin-bottom:12px;position:relative}
.dasha-item::before{content:'';position:absolute;left:6px;top:20px;bottom:-12px;width:1px;background:var(--border)}
.dasha-item:last-child::before{display:none}
.dasha-dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--gold);background:var(--surface);flex-shrink:0;margin-top:4px}
.dasha-item.current .dasha-dot{background:var(--gold)}
.dasha-content{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:14px 16px}
.dasha-item.current .dasha-content{background:var(--gold-bg);border-color:rgba(var(--gold-rgb),0.25)}
.dasha-planet{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:1px;color:var(--text);margin-bottom:3px}
.dasha-dates{font-size:var(--text-sm);color:var(--text-muted)}
.dasha-bar{height:3px;background:var(--bg3);border-radius:2px;margin-top:8px;overflow:hidden}
.dasha-fill{height:100%;background:var(--gold);border-radius:2px}

/* ── MATCHING ── */
.matching-score{text-align:center;padding:28px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-card);margin-bottom:14px}
.score-circle{width:100px;height:100px;border-radius:50%;border:3px solid var(--gold);display:flex;align-items:center;justify-content:center;flex-direction:column;margin:0 auto 14px;background:var(--gold-bg)}
.score-val{font-family:'Cormorant Garamond',serif;font-size:38px;color:var(--gold);font-weight:300;line-height:1}
.score-max{font-size:var(--text-sm);color:var(--text-muted)}
.score-label{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:2px;color:var(--text-muted);text-transform:uppercase}
.kuta-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:14px 0}
.kuta-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-inner);padding:12px}
.kuta-name{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:1px;color:var(--text-muted);text-transform:uppercase;margin-bottom:4px}
.kuta-score{display:flex;align-items:baseline;gap:4px}
.kuta-val{font-size:20px;font-weight:500;color:var(--text)}
.kuta-max{font-size:12px;color:var(--text-muted)}
.dosha-result{text-align:center;padding:22px;margin:10px 0;border-radius:18px}
.dosha-result.has{background:rgba(var(--rose-rgb),0.06);border:1px solid rgba(var(--rose-rgb),0.2)}
.dosha-result.no{background:var(--sage-bg);border:1px solid rgba(var(--sage-rgb),0.2)}
.dosha-icon{font-size:38px;margin-bottom:10px}
.dosha-title{font-family:'Cinzel',serif;font-size:12px;letter-spacing:2px;text-transform:uppercase;margin-bottom:8px;color:var(--text)}

/* ── NUMEROLOGY ── */
.num-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin:10px 0}
.num-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:14px 8px;text-align:center}
.num-val{font-family:'Cormorant Garamond',serif;font-size:38px;color:var(--gold);font-weight:300;line-height:1}
.num-name{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:1.5px;color:var(--text-muted);text-transform:uppercase;margin-top:5px}

/* ── GEMS ── */
.gem-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.gem-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-chip);padding:15px;text-align:center}
.gem-icon{font-size:var(--text-2xl);margin-bottom:7px}
.gem-name{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:1px;color:var(--gold);text-transform:uppercase;margin-bottom:3px}
.gem-planet{font-size:var(--text-sm);color:var(--text-dim)}

/* ── KUNDLI STATUS BAR ── */
.kundli-status-bar{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-inner);padding:10px 13px;margin-bottom:14px}
.ksb-dot{width:6px;height:6px;background:var(--green);border-radius:50%;flex-shrink:0}
.ksb-text{font-size:12px;color:var(--text-dim);flex:1;font-style:italic}
.ksb-change{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:1px;color:var(--gold);cursor:pointer;text-transform:uppercase}
.result-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:10px}

/* ── YOGA BADGES ── */
.yoga-badge{display:inline-flex;align-items:center;gap:6px;background:var(--gold-bg);border:1px solid rgba(var(--gold-rgb),0.2);border-radius:var(--r-pill);padding:5px 12px;font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:1px;color:var(--gold);cursor:pointer;margin:3px;position:relative;text-transform:uppercase;transition:all var(--dur-fast)}
.yoga-badge:hover{background:var(--gold);color:#fff}
.yoga-badge-tooltip{display:none;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:var(--text);color:var(--bg);padding:8px 12px;border-radius:var(--r-tag);font-size:var(--text-sm);white-space:nowrap;z-index:100;pointer-events:none;font-family:'DM Sans',sans-serif;letter-spacing:0;font-weight:300;text-transform:none}
.yoga-badge:hover .yoga-badge-tooltip,.yoga-badge:focus-visible .yoga-badge-tooltip{display:block}

/* ── PLAIN SUMMARY CARD — SCENARIO C ── */
.plain-summary-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-card);margin-bottom:14px;overflow:hidden}
.plain-summary-card::before{content:'';display:block;height:3px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.plain-summary-inner{padding:18px 18px 6px}
.plain-summary-label{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:3px;color:var(--gold);text-transform:uppercase;margin-bottom:12px}
.plain-summary-text p{font-family:'Cormorant Garamond',serif;font-size:var(--text-xl);font-weight:500;line-height:1.7;color:var(--text);margin-bottom:10px}
:lang(hi) .plain-summary-text p,:lang(bn) .plain-summary-text p,:lang(as) .plain-summary-text p{font-family:'Tiro Devanagari Sanskrit','Noto Sans Bengali','DM Sans',sans-serif;font-size:15px}
.plain-summary-loading{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:2px;color:var(--gold);animation:fadeFlick 2s ease-in-out infinite}
.plain-summary-cta{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:2px;color:var(--gold);padding:12px 18px 14px;cursor:pointer;text-transform:uppercase;transition:color 0.15s;border-top:1px solid var(--border)}
.plain-summary-cta:hover{color:var(--gold-dim)}
.sc-headline{margin-bottom:4px}
.sc-s1{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:500;line-height:1.65;color:var(--text);margin-bottom:8px}
.sc-s2{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:400;font-style:italic;line-height:1.65;color:var(--text-dim);margin-bottom:8px}
.sc-s3{font-family:'DM Sans',sans-serif;font-size:var(--text-base);font-weight:400;line-height:1.6;color:var(--gold);margin-bottom:0}
:lang(hi) .sc-s1,:lang(hi) .sc-s2,:lang(bn) .sc-s1,:lang(bn) .sc-s2,:lang(as) .sc-s1,:lang(as) .sc-s2{font-family:'Tiro Devanagari Sanskrit','Noto Sans Bengali','DM Sans',sans-serif;font-size:15px}
.sc-xray-toggle{display:flex;align-items:center;gap:8px;padding:11px 18px;cursor:pointer;border-top:1px solid var(--border);background:var(--surface2);transition:background 0.15s}
.sc-xray-toggle:hover{background:var(--bg2)}
.sc-xray-icon{font-size:var(--text-sm);color:var(--gold);flex-shrink:0}
.sc-xray-label{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:2px;color:var(--text-muted);text-transform:uppercase;flex:1}
.sc-xray-arrow{font-size:var(--text-base);color:var(--text-muted);transition:transform 0.2s;line-height:1}
.sc-xray-toggle.sc-xray-open .sc-xray-label{color:var(--gold)}
.sc-xray-body{padding:12px 18px 14px;background:var(--bg2);border-top:1px solid var(--border)}
.sc-xray-row{font-family:'DM Sans',sans-serif;font-size:var(--text-sm);color:var(--text-muted);line-height:1.6;padding:4px 0;border-bottom:1px solid var(--border)}
.sc-xray-row:last-child{border-bottom:none}

/* ── PANCHANG ── */
.panchang-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:12px 0}
.panchang-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:14px}
.panchang-label{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:1.5px;color:var(--text-muted);text-transform:uppercase;margin-bottom:4px}
.panchang-value{font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--text);font-weight:400}
.panchang-sub{font-size:var(--text-sm);color:var(--text-muted);margin-top:2px}

/* ── INLINE CHAT ── */
.inline-chat{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-card);margin-top:14px;overflow:hidden}
.inline-chat-header{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border)}
.inline-chat-title{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:1.5px;color:var(--text)}
.inline-chat-sub{font-size:var(--text-sm);color:var(--text-muted);margin-top:2px}
.inline-chat-messages{padding:12px 14px;display:flex;flex-direction:column;gap:10px;max-height:300px;overflow-y:auto;background:var(--bg)}
.inline-msg{max-width:88%}
.inline-msg.user{align-self:flex-end}
.inline-msg.ai{align-self:flex-start}
.inline-bubble{padding:10px 14px;border-radius:var(--r-chip);font-size:var(--text-md);line-height:1.6}
.inline-msg.user .inline-bubble{background:var(--gold);color:#fff;border-radius:var(--r-chip) 16px 4px 16px}
.inline-msg.ai .inline-bubble{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:var(--r-chip) 16px 16px 4px;font-family:'Cormorant Garamond',serif;font-size:var(--text-lg);font-weight:500;line-height:1.75}
:lang(hi) .inline-msg.ai .inline-bubble,:lang(bn) .inline-msg.ai .inline-bubble,:lang(as) .inline-msg.ai .inline-bubble{font-family:'Tiro Devanagari Sanskrit','Noto Sans Bengali','DM Sans',sans-serif;font-size:var(--text-md)}
.inline-msg.ai .inline-bubble strong{color:var(--gold)}
.inline-chat-input-row{display:flex;gap:8px;padding:10px 12px;border-top:1px solid var(--border);background:var(--surface)}
.inline-chat-input{flex:1;background:var(--bg2);border:1px solid var(--border-md);border-radius:var(--r-pill);padding:9px 14px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:var(--text-base);outline:none;resize:none;line-height:1.4;max-height:70px}
.inline-chat-input:focus{border-color:var(--gold);background:var(--surface)}
.inline-chat-send{width:40px;height:40px;background:var(--gold-dim);border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:var(--text-md);flex-shrink:0;align-self:flex-end;color:#fff}
.inline-typing-dots{display:flex;gap:4px;align-items:center;padding:4px 0}
.inline-typing-dots span{width:5px;height:5px;border-radius:50%;background:var(--gold);animation:dotP 1.4s ease-in-out infinite;opacity:0.4}
.inline-typing-dots span:nth-child(2){animation-delay:0.2s}
.inline-typing-dots span:nth-child(3){animation-delay:0.4s}
.inline-chat-cats{display:flex;gap:8px;padding:10px 14px;overflow-x:auto;border-top:1px solid var(--border);scrollbar-width:none}
.inline-chat-cats::-webkit-scrollbar{display:none}
.inline-cat-btn{flex-shrink:0;background:var(--bg2);border:1px solid var(--border-md);border-radius:var(--r-pill);padding:6px 14px;font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:1px;color:var(--gold);cursor:pointer;white-space:nowrap;text-transform:uppercase;transition:all var(--dur-fast)}
.inline-cat-btn:hover{background:var(--gold);color:#fff}

/* ── SHARE CARDS ── */
.share-btn{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-tag);padding:8px 14px;font-size:12px;color:var(--text-dim);cursor:pointer;display:flex;align-items:center;gap:6px;transition:all var(--dur-fast)}
.share-btn:hover{background:var(--gold-bg);color:var(--gold);border-color:rgba(var(--gold-rgb),0.25)}
.share-copied{font-size:var(--text-sm);color:var(--green);text-align:center;margin-top:5px;opacity:0;transition:opacity 0.3s}
.share-copied.show{opacity:1}

/* ── SIGNUP GATE ── */
.signup-gate{position:fixed;inset:0;z-index:900;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.3s}
.signup-gate.show{opacity:1;pointer-events:auto}
.signup-gate-overlay{position:absolute;inset:0;background:rgba(var(--ink-rgb),0.5);backdrop-filter:blur(4px)}
.signup-gate-sheet{position:relative;z-index:1;background:var(--surface);border-top:1px solid var(--border);border-radius:24px 24px 0 0;padding:20px 20px 36px;width:100%;max-width:480px;text-align:center}
.signup-gate-sheet::before{content:'';display:block;width:36px;height:3px;background:var(--border-md);border-radius:2px;margin:0 auto 16px}

/* ── DASHA MINI CARD ── */
.dasha-mini-wrap{background:var(--surface);border:1px solid var(--border);border-radius:18px;overflow:hidden;cursor:pointer;margin-bottom:12px;transition:all var(--dur-base)}
.dasha-mini-wrap:hover{border-color:rgba(var(--gold-rgb),0.25);box-shadow:0 4px 16px rgba(var(--gold-rgb),0.1)}
.dmi-header{display:flex;align-items:center;gap:14px;padding:16px}
.dmi-sym{font-size:28px;flex-shrink:0}
.dmi-info{flex:1;min-width:0}
.dmi-label-small{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:2px;color:var(--gold);text-transform:uppercase;margin-bottom:3px}
.dmi-title{font-family:'Cormorant Garamond',serif;font-size:var(--text-xl);color:var(--text);font-weight:400}
.dmi-sub{font-size:var(--text-sm);color:var(--text-muted);margin-top:2px}
.dmi-arrow{font-size:16px;color:var(--text-muted)}
.dasha-countdown{font-size:var(--text-sm);color:var(--gold);margin-top:4px;font-family:'Cinzel',serif;letter-spacing:0.5px}
.dmi-progress-track{height:3px;background:var(--bg3);margin:0 16px 14px;border-radius:2px;overflow:hidden}
.dmi-progress-fill{height:100%;background:var(--gold);border-radius:2px;transition:width 1s ease}

/* ── SADE SATI ── */
.ss-status-banner{border-radius:var(--r-chip);padding:16px;margin-bottom:14px;border:1px solid;text-align:center}
.ss-status-banner.active-ss{background:rgba(var(--rose-rgb),0.05);border-color:rgba(var(--rose-rgb),0.2)}
.ss-status-banner.active-dhaiya{background:rgba(var(--gold-rgb),0.05);border-color:rgba(var(--gold-rgb),0.2)}
.ss-status-banner.clear{background:var(--sage-bg);border-color:rgba(var(--sage-rgb),0.2)}
.ss-big-label{font-family:'Cinzel',serif;font-size:12px;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:5px}
.ss-phase-name{font-size:20px;font-weight:600;margin-bottom:3px;color:var(--text)}
.ss-dates-line{font-size:var(--text-sm);color:var(--text-muted)}
.ss-ends-in{font-size:var(--text-sm);margin-top:5px;color:var(--text-muted)}
.ss-timeline{position:relative;height:8px;background:var(--bg3);border-radius:var(--r-2xs);margin:18px 4px 24px}
.ss-tl-seg{position:absolute;top:0;height:100%;border-radius:3px}
.ss-tl-now{position:absolute;top:-5px;width:2px;height:18px;background:var(--gold);border-radius:2px}
.ss-tl-now::after{content:'Now';position:absolute;top:20px;left:50%;transform:translateX(-50%);font-size:var(--text-xs);color:var(--gold);font-family:'Cinzel',serif;white-space:nowrap}
.ss-group-row{border:1px solid var(--border);border-radius:var(--r-inner);margin-bottom:7px;overflow:hidden}
.ss-group-header{display:flex;align-items:center;gap:10px;padding:11px 13px;cursor:pointer;background:var(--surface)}
.ss-group-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.ss-group-title{font-size:var(--text-base);font-weight:500;flex:1;color:var(--text)}
.ss-group-dates{font-size:var(--text-sm);color:var(--text-muted)}
.ss-group-body{padding:0 13px 9px;display:none;background:var(--surface)}
.ss-group-body.open{display:block}
.ss-phase-row{display:flex;align-items:center;gap:8px;padding:5px 0;border-bottom:1px solid var(--border)}
.ss-phase-row:last-child{border-bottom:none}
.ss-phase-label{font-size:var(--text-sm);padding:2px 7px;border-radius:18px;font-family:'Cinzel',serif;letter-spacing:0.5px}
.ss-phase-rising{background:var(--gold-bg);color:var(--gold)}
.ss-phase-peak{background:rgba(var(--rose-rgb),0.1);color:var(--rose)}
.ss-phase-setting{background:var(--dusk-bg);color:var(--purple)}
.ss-phase-4th,.ss-phase-8th{background:var(--dusk-bg);color:var(--purple)}
.ss-phase-dates{font-size:var(--text-sm);color:var(--text-muted);flex:1;text-align:right}
.ss-remedy-box{background:var(--gold-bg);border:1px solid rgba(var(--gold-rgb),0.15);border-radius:var(--r-inner);padding:12px 14px;margin-top:14px}
.ss-remedy-title{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:1.2px;color:var(--gold);margin-bottom:7px;text-transform:uppercase}
.ss-remedy-item{font-size:12px;color:var(--text-dim);padding:3px 0;display:flex;gap:8px}

/* ── ADMIN AUDIT BUTTON ── */
.btn-debug{padding:13px 16px;background:var(--bg2);border:1px solid var(--border-md);color:var(--text-dim);border-radius:var(--r-inner);font-size:var(--text-sm);cursor:pointer;transition:all var(--dur-base)}
.btn-debug:hover{background:var(--gold-bg);color:var(--gold);border-color:rgba(var(--gold-rgb),0.25)}

/* ── PWA INSTALL BANNER ── */
.pwa-banner{position:fixed;bottom:calc(var(--bottom-nav-h) + 10px);left:12px;right:12px;z-index:500;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-chip);padding:14px 16px;display:flex;align-items:center;gap:12px;box-shadow:0 4px 20px rgba(var(--ink-rgb),0.12);transform:translateY(20px);opacity:0;transition:all 0.3s}
.pwa-banner.show{transform:translateY(0);opacity:1}
.pwa-icon{font-size:24px;flex-shrink:0}
.pwa-text{flex:1;font-size:12px;color:var(--text-dim)}
.pwa-text strong{color:var(--text);display:block;font-size:var(--text-base);margin-bottom:1px}
.pwa-install-btn{background:var(--gold-dim);color:#fff;border:none;border-radius:var(--r-pill);padding:7px 14px;font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:1px;cursor:pointer;white-space:nowrap;text-transform:uppercase}
.pwa-dismiss{background:none;border:none;color:var(--text-muted);font-size:16px;cursor:pointer;flex-shrink:0;padding:4px}

/* ── TRANSIT TODAY CARD ── */
.transit-today-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-chip);padding:14px;margin-top:12px}
.transit-today-title{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:1.5px;color:var(--text-muted);text-transform:uppercase;margin-bottom:8px;text-align:center}
.transit-mini-row{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:var(--text-sm);color:var(--text-dim)}
.transit-mini-row .sym{font-size:var(--text-md);width:22px;text-align:center}

/* ── MICRO-INTERACTIONS ── */
.panel.active{animation:panelFadeIn 0.3s ease both}
@keyframes panelFadeIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}
.btn--primary,.btn--hero,.btn-gold,.btn-generate,.k-generate-btn,.k-next-btn{transition:all var(--dur-base) var(--ease-std)}
.btn--primary:active,.btn--hero:active,.btn-gold:active,.btn-generate:active,.k-generate-btn:active,.k-next-btn:active{transform:scale(0.97)}
.rqn-btn:active{transform:scale(0.96)}
.bnav-item:active{transform:scale(0.93)}
.concern-chip{transition:all var(--dur-base) var(--ease-std)}
.concern-chip:active{transform:scale(0.96)}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border-md);border-radius:2px}
::-webkit-scrollbar-thumb:hover{background:var(--gold)}

/* ── CONCERN CHIPS (chat categories) ── */
.concern-chip{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-inner);padding:10px 14px;cursor:pointer;text-align:center;transition:all var(--dur-fast);font:inherit;-webkit-appearance:none;appearance:none;display:block;width:100%}
.concern-chip:hover,.concern-chip.selected{background:var(--gold-bg);border-color:rgba(var(--gold-rgb),0.3)}
.concern-chip-icon{font-size:20px;margin-bottom:4px}
.concern-chip-label{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:1px;color:var(--text-muted);text-transform:uppercase}

/* ── CHAT CATEGORIES ── */
#chat-categories{padding:12px 16px 6px}
.chat-cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}


/* ══════════════════════════════════════════════════════
   TATTVI-INSPIRED HOME SCREEN — Greeting + Cards
══════════════════════════════════════════════════════ */

/* Section label above insight card */
.ny-section-label{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:3px;color:var(--ink4);text-transform:uppercase;padding:0 0 10px;margin-top:4px}

/* Greeting */
.ny-greeting{padding:6px 0 20px}
.ny-date-line{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:2.5px;color:var(--gold);text-transform:uppercase;margin-bottom:14px}
.ny-hello{font-family:'Cormorant Garamond',serif;font-size:36px;font-weight:400;color:var(--ink);line-height:1.1}
.ny-name{font-family:'Cormorant Garamond',serif;font-size:36px;font-weight:400;font-style:italic;color:var(--gold);line-height:1.1;margin-bottom:0}

/* Today's Reading card */
.ny-reading-card{background:var(--gold);border-radius:var(--r-pill);padding:20px 22px;margin-bottom:22px;cursor:pointer;position:relative;overflow:hidden;transition:all var(--dur-base)}
.ny-reading-card::before{content:'';position:absolute;top:-30px;right:-30px;width:110px;height:110px;border-radius:50%;background:rgba(255,255,255,0.06)}
.ny-reading-card:active{transform:scale(0.98)}
.ny-reading-label{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:2.5px;color:rgba(255,255,255,0.65);text-transform:uppercase;margin-bottom:10px}
.ny-reading-text{font-family:'Cormorant Garamond',serif;font-size:21px;font-weight:500;font-style:italic;color:#fff;line-height:1.45;max-width:240px}
:lang(hi) .ny-reading-text,:lang(bn) .ny-reading-text,:lang(as) .ny-reading-text{font-family:'Tiro Devanagari Sanskrit','Noto Sans Bengali','DM Sans',sans-serif;font-size:16px}

/* Explore section */
.ny-explore-label{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:2.5px;color:var(--ink4);text-transform:uppercase;margin-bottom:10px}
.ny-explore-scroll{display:flex;gap:10px;overflow-x:auto;scrollbar-width:none;padding-bottom:2px;margin-bottom:20px}
.ny-explore-scroll::-webkit-scrollbar{display:none}
.ny-explore-card{flex-shrink:0;width:130px;height:110px;border-radius:18px;padding:14px;display:flex;flex-direction:column;justify-content:space-between;cursor:pointer;transition:transform 0.15s,box-shadow 0.15s;-webkit-tap-highlight-color:transparent}
.ny-explore-card:active{transform:scale(0.95)}
.ny-ec-dasha {background:var(--sage)}
.ny-ec-transit{background:#B8902A}
.ny-ec-match {background:var(--dusk)}
.ny-ec-remedy{background:var(--rose)}
.ny-ec-panchang{background:#5A8870}
.ny-ec-type{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:2px;color:rgba(255,255,255,0.65);text-transform:uppercase}
.ny-ec-title{font-family:'Cormorant Garamond',serif;font-size:var(--text-xl);font-weight:300;color:#fff;line-height:1.2}

/* ══════════════════════════════════════════════════════
   WIZARD / LANDING PAGE — classes from former inline style
══════════════════════════════════════════════════════ */

/* Free badge + strip */
.k-free-badge{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:2px;color:var(--gold);text-transform:uppercase;text-align:center;margin-bottom:12px}
.k-free-strip{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding-bottom:4px;margin-bottom:14px}
.k-free-item{display:flex;align-items:center;justify-content:center;gap:5px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-pill);padding:5px 12px;font-size:var(--text-sm);color:var(--ink2)}
.k-free-icon{font-size:var(--text-base)}
.k-free-text{font-size:var(--text-sm);font-family:'Cinzel',serif;letter-spacing:0.5px}

/* Feature chips strip */
.k-features-strip{margin-bottom:20px}
.k-features-title{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:2.5px;color:var(--gold);text-transform:uppercase;text-align:center;margin-bottom:10px}
.k-features-scroll{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;padding-bottom:2px}
.k-feat-chip{display:flex;align-items:center;gap:5px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-pill);padding:6px 13px;font-size:var(--text-sm);color:var(--ink2)}
.k-feat-chip-icon{font-size:var(--text-base)}
.k-feat-chip-text{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:0.5px}

/* 4-step wizard */
.k-wizard{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-pill);padding:22px 18px;margin-bottom:14px}
.k-progress-track{height:3px;background:var(--bg3);border-radius:2px;margin-bottom:6px;overflow:hidden}
.k-progress-fill{height:100%;background:var(--gold);border-radius:2px;transition:width 0.4s ease}
.k-step-ind{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:2px;color:var(--ink4);text-transform:uppercase;margin-bottom:20px;text-align:center}
.k-step{display:none}
.k-step.active{display:block}
.k-step-icon{font-size:28px;text-align:center;margin-bottom:12px}
.k-step-q{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:400;color:var(--ink);text-align:center;margin-bottom:6px;line-height:1.2}
.k-step-sub{font-size:var(--text-sm);color:var(--ink4);text-align:center;margin-bottom:20px;line-height:1.6}
.k-big-input{width:100%;background:var(--bg2);border:1px solid var(--border-md);border-radius:13px;padding:13px 15px;color:var(--ink);font-size:15px;font-family:'DM Sans',sans-serif;outline:none;transition:all var(--dur-base);-webkit-appearance:none;margin-bottom:12px;display:block;box-sizing:border-box}
.k-big-input:focus{border-color:var(--gold);background:var(--gold-bg);box-shadow:0 0 0 3px rgba(var(--gold-rgb),0.08)}
.k-big-input::placeholder{color:var(--ink4)}
.k-big-input option{background:var(--surface)}
.k-big-input[type="date"]::-webkit-calendar-picker-indicator,.k-big-input[type="time"]::-webkit-calendar-picker-indicator{filter:opacity(0.5)}
.k-gender-label{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:2px;color:var(--ink3);text-transform:uppercase;margin-bottom:8px;text-align:center}
.k-gender-row{display:flex;gap:8px;margin-bottom:16px;justify-content:center}
.k-gender-btn{flex:1;max-width:100px;padding:10px 6px;background:var(--bg2);border:1px solid var(--border-md);border-radius:var(--r-inner);color:var(--ink2);font-size:var(--text-base);cursor:pointer;transition:all var(--dur-fast);font-family:'DM Sans',sans-serif}
.k-gender-btn.active{background:var(--gold-bg);border-color:rgba(var(--gold-rgb),0.4);color:var(--gold)}
.k-next-btn{width:100%;padding:15px;background:var(--gold-dim);border:none;border-radius:13px;color:#fff;font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:3px;cursor:pointer;text-transform:uppercase;transition:all var(--dur-base);margin-top:4px}
.k-next-btn:hover{background:var(--gold-darker)}
/* .k-back-btn: deduplicated — see primary definition earlier in file */
.k-two-col{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.k-mini-field{display:flex;flex-direction:column}
.k-mini-label{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:1.5px;color:var(--ink3);text-transform:uppercase;margin-bottom:5px}
.k-city-chip{display:inline-flex;align-items:center;gap:5px;font-size:var(--text-sm);color:var(--gold);background:var(--gold-bg);border:1px solid rgba(var(--gold-rgb),0.2);border-radius:var(--r-pill);padding:4px 12px;margin-top:8px}
.k-confirm-summary{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-sm);padding:14px 16px;margin-bottom:14px;font-size:var(--text-base);color:var(--ink2);line-height:1.8}

/* Testimonials */
.k-testimonials{padding:4px 0 20px}
.k-test-title{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:2.5px;color:var(--ink4);text-transform:uppercase;text-align:center;margin-bottom:12px}
.k-test-scroll{display:flex;gap:12px;overflow-x:auto;padding:4px 2px 8px;scrollbar-width:none;overscroll-behavior:contain}
.k-test-scroll::-webkit-scrollbar{display:none}
.k-test-card{flex-shrink:0;width:220px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-chip);padding:14px}
.k-test-stars{color:var(--gold);font-size:var(--text-sm);margin-bottom:7px;letter-spacing:2px}
.k-test-text{font-family:'Cormorant Garamond',serif;font-size:var(--text-md);color:var(--ink2);line-height:1.6;margin-bottom:8px;font-style:italic}
.k-test-name{font-size:var(--text-sm);color:var(--ink4)}
.k-stat-row{display:flex;justify-content:center;gap:28px;margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}
.k-stat{display:flex;flex-direction:column;align-items:center;gap:3px}
.k-stat-num{font-family:'Cormorant Garamond',serif;font-size:var(--text-2xl);color:var(--gold);font-weight:300;line-height:1}
.k-stat-label{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:1.5px;color:var(--ink4);text-transform:uppercase}

/* Why Nyovah block */
.k-why-block{margin-bottom:20px}
.k-why-title{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:2.5px;color:var(--gold);text-transform:uppercase;text-align:center;margin-bottom:12px}
.k-why-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.k-why-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-chip);padding:14px;display:flex;flex-direction:column;gap:4px}
.k-why-emoji{font-size:20px}
.k-why-label{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:1px;color:var(--gold);text-transform:uppercase}
.k-why-desc{font-size:var(--text-sm);color:var(--ink3);line-height:1.5}

/* Chart style toggle */
.chart-style-toggle{display:flex;gap:6px;padding:12px 14px 6px;justify-content:center}
.chart-style-btn{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-pill);padding:5px 14px;font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:1px;color:var(--ink3);cursor:pointer;transition:all var(--dur-fast);text-transform:uppercase}
.chart-style-btn.active{background:var(--gold-bg);border-color:rgba(var(--gold-rgb),0.3);color:var(--gold)}

/* Scroll to top */
.scroll-top{position:fixed;bottom:calc(var(--bottom-nav-h) + 14px);right:14px;z-index:400;width:38px;height:38px;background:var(--surface);border:1px solid var(--border);border-radius:50%;color:var(--gold);font-size:var(--text-md);cursor:pointer;display:none;align-items:center;justify-content:center;box-shadow:0 2px 12px rgba(var(--ink-rgb),0.1);transition:all var(--dur-base)}
.scroll-top.show{display:flex}

/* Loader ring (older class name used in some panels) */
.loader-ring{width:48px;height:48px;border-radius:50%;border:2px solid var(--border);border-top-color:var(--gold);animation:spin 0.9s linear infinite;margin:0 auto}
.loader p{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:2.5px;color:var(--gold);margin-top:14px;animation:fadeFlick 2s ease-in-out infinite;text-align:center}

/* Signup gate sheet */
.signup-gate-sheet h2{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:400;color:var(--ink);margin-bottom:8px}
.signup-gate-sheet p{font-size:var(--text-base);color:var(--ink3);margin-bottom:18px;line-height:1.6}

/* City suggestions dropdown */
.city-suggestions{position:absolute;top:100%;left:0;right:0;background:var(--surface);border:1px solid var(--border-md);border-radius:var(--r-inner);box-shadow:0 8px 24px rgba(var(--ink-rgb),0.12);z-index:100;max-height:200px;overflow-y:auto;margin-top:4px;display:none}
.city-item{padding:10px 14px;cursor:pointer;font-size:var(--text-base);color:var(--ink2);border-bottom:1px solid var(--border);transition:background 0.1s}
.city-item:last-child{border-bottom:none}
.city-item:hover,.city-item:active{background:var(--gold-bg);color:var(--gold)}
.city-wrap{position:relative}

/* Rashi grid */
.rashi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}
.rashi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:14px 10px;text-align:center;cursor:pointer;transition:all var(--dur-fast)}
.rashi-card:hover{background:var(--gold-bg);border-color:rgba(var(--gold-rgb),0.25)}
.rashi-sym{font-size:22px;margin-bottom:5px}
.rashi-name{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:1px;color:var(--gold);text-transform:uppercase}
.rashi-en{font-size:var(--text-sm);color:var(--ink4);margin-top:2px}

/* More panel tabs (deep dive reports) */
.more-panel-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}
.more-panel-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-chip);padding:18px 14px;cursor:pointer;text-align:center;transition:all var(--dur-fast)}
.more-panel-card:hover{background:var(--gold-bg);border-color:rgba(var(--gold-rgb),0.25);transform:translateY(-2px);box-shadow:0 4px 16px rgba(var(--gold-rgb),0.1)}
.more-panel-icon{font-size:var(--text-2xl);margin-bottom:8px}
.more-panel-label{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:1.5px;color:var(--gold);text-transform:uppercase;margin-bottom:3px}
.more-panel-desc{font-size:var(--text-sm);color:var(--ink4);line-height:1.4}

/* ══════════════════════════════════════════════════════
   NAVIGATION REDESIGN — Today / Ask / Timeline / Profile
══════════════════════════════════════════════════════ */

/* Hide old feature strips after chart loads (landing only) */
.k-result-shown .k-landing-only { display: none !important; }

/* ── DECISION CHIPS ── */
.ny-decision-row{margin-bottom:18px}
.ny-decision-label{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:2.5px;color:var(--ink4);text-transform:uppercase;margin-bottom:10px}
.ny-chips-scroll{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;padding-bottom:2px}
.ny-chips-scroll::-webkit-scrollbar{display:none}
.ny-chip{flex-shrink:0;background:var(--surface);border:1px solid var(--border-md);border-radius:var(--r-pill);padding:8px 14px;font-size:12px;color:var(--ink2);cursor:pointer;white-space:nowrap;font-family:'DM Sans',sans-serif;transition:all var(--dur-fast);-webkit-tap-highlight-color:transparent}
.ny-chip:hover,.ny-chip:active{background:var(--gold);color:#fff;border-color:var(--gold)}

/* ── PROFILE TOOLS GRID ── */
.profile-tools-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.profile-tool-btn{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:14px 12px;cursor:pointer;display:flex;flex-direction:column;align-items:flex-start;gap:3px;transition:all var(--dur-fast);text-align:left;-webkit-tap-highlight-color:transparent}
.profile-tool-btn:hover,.profile-tool-btn:active{background:var(--gold-bg);border-color:rgba(var(--gold-rgb),0.25)}
.ptb-icon{font-size:20px}
.ptb-label{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:1px;color:var(--gold);text-transform:uppercase}
.ptb-sub{font-size:var(--text-sm);color:var(--ink4);line-height:1.3}

/* ── DASHA PANEL ── */
/* h1 already contains "Your <em>Timing</em>" — no ::before needed */

/* ══════════════════════════════════════════════
   TODAY TAB — DAILY BRIEFING COMPONENTS
   ══════════════════════════════════════════════ */

/* 1. CURRENT PHASE HERO */
.ny-phase-hero{background:var(--gold);border-radius:var(--r-pill);padding:22px 22px 20px;margin-bottom:16px;position:relative;overflow:hidden;min-height:90px;display:flex;flex-direction:column;justify-content:center}
.ny-phase-hero::before{content:'';position:absolute;top:-40px;right:-40px;width:130px;height:130px;border-radius:50%;background:rgba(255,255,255,0.07)}
.ny-phase-hero::after{content:'';position:absolute;bottom:-20px;left:-20px;width:80px;height:80px;border-radius:50%;background:rgba(255,255,255,0.04)}
.ny-phase-name{font-family:'Cormorant Garamond',serif;font-size:var(--text-2xl);font-weight:500;color:#fff;line-height:1.2;margin-bottom:8px;position:relative}
.ny-phase-desc{font-family:'DM Sans',sans-serif;font-size:var(--text-base);font-weight:400;color:rgba(255,255,255,0.85);line-height:1.55;margin-bottom:10px;position:relative}
.ny-phase-tag{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:1.5px;color:rgba(255,255,255,0.6);text-transform:uppercase;position:relative;margin-bottom:14px}
/* Share button — sits in its own row below the phase tag */
.ny-share-btn{position:relative;align-self:flex-start;background:rgba(255,255,255,0.18);border:1.5px solid rgba(255,255,255,0.45);color:#fff;font-family:'DM Sans',sans-serif;font-size:var(--text-sm);font-weight:600;letter-spacing:0.5px;border-radius:var(--r-pill);padding:7px 18px;cursor:pointer;display:flex;align-items:center;gap:6px;transition:background 0.2s,border-color 0.2s;z-index:2}
.ny-share-btn:hover{background:rgba(255,255,255,0.3);border-color:rgba(255,255,255,0.7)}
.ny-share-btn:disabled{opacity:0.55;cursor:not-allowed}

/* Phase shimmer (loading state) */
.ny-phase-shimmer{padding:4px 0}
.ny-shimmer-line{height:22px;border-radius:var(--r-xs);background:rgba(255,255,255,0.2);animation:shimmerPulse 1.6s ease-in-out infinite}
@keyframes shimmerPulse{0%,100%{opacity:0.4}50%{opacity:0.8}}

/* 2. WHAT TO DO TODAY */
.ny-actions-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-chip);padding:16px 18px;margin-bottom:14px}
.ny-actions-title{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:2px;color:var(--gold);text-transform:uppercase;margin-bottom:12px}
.ny-action-chip{display:block;width:100%;text-align:left;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-tag);font-family:'DM Sans',sans-serif;font-size:var(--text-base);color:var(--ink);line-height:1.5;padding:10px 14px;margin-bottom:8px;cursor:pointer;transition:border-color 0.15s,background 0.15s}
.ny-action-chip:last-child{margin-bottom:0}
.ny-action-chip:hover,.ny-action-chip:focus-visible{border-color:var(--gold);background:rgba(var(--gold-rgb),0.06);outline:none}

/* REFLECTION BANNER — pratyantara ended in last 3 days */
.ny-reflection-banner{margin-bottom:14px;background:rgba(var(--gold-rgb),0.07);border:1px solid rgba(var(--gold-rgb),0.22);border-radius:var(--r-md);padding:14px 16px}
.ny-reflection-content{display:flex;align-items:center;justify-content:space-between;gap:12px}
.ny-reflection-msg{font-family:'DM Sans',sans-serif;font-size:var(--text-sm);color:var(--ink);flex:1;line-height:1.4}
.ny-reflection-msg strong{color:var(--gold)}
.ny-reflection-btns{display:flex;align-items:center;gap:8px;flex-shrink:0}
.ny-reflection-cta{background:var(--gold);color:#fff;border:none;border-radius:var(--r-sm);padding:7px 14px;font-family:'DM Sans',sans-serif;font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:opacity var(--dur-fast) var(--ease-std)}
.ny-reflection-cta:hover{opacity:0.85}
.ny-reflection-close{background:none;border:1px solid rgba(var(--ink-rgb),0.18);border-radius:var(--r-xs);width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:12px;color:rgba(var(--ink-rgb),0.45);cursor:pointer;transition:color var(--dur-fast) var(--ease-std),border-color var(--dur-fast) var(--ease-std)}
.ny-reflection-close:hover{color:var(--ink);border-color:rgba(var(--ink-rgb),0.35)}
@media(prefers-reduced-motion:reduce){.ny-reflection-cta,.ny-reflection-close{transition:none}}

/* 3. NEXT SHIFT HOOK */
.ny-shift-hook{margin-bottom:14px}
.ny-shift-inner{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--sage);border-radius:var(--r-sm);padding:13px 16px}
.ny-shift-icon{font-size:18px;flex-shrink:0}
.ny-shift-days{font-family:'DM Sans',sans-serif;font-size:var(--text-base);color:var(--ink);line-height:1.3}
.ny-shift-days strong{color:var(--sage);font-weight:600}
.ny-shift-sub{font-size:var(--text-sm);color:var(--text-muted);margin-top:2px}

/* 5. TODAY'S INSIGHT */
.ny-insight-card{background:var(--surface2,var(--bg2));border:1px solid var(--border);border-radius:var(--r-chip);padding:16px 18px;margin-bottom:14px}
.ny-insight-label{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:2.5px;color:var(--gold);text-transform:uppercase;margin-bottom:10px}
.ny-insight-text{font-family:'Cormorant Garamond',serif;font-size:var(--text-xl);font-weight:500;font-style:italic;color:var(--ink);line-height:1.65}

/* 6. TODAY'S SKY — Transit card */
/* ── Ratna Vichara — Gemstone UI ─────────────────────────── */
.ny-gem-primary{background:linear-gradient(135deg,rgba(var(--gold-rgb),0.07),rgba(var(--gold-rgb),0.03));border:1.5px solid rgba(var(--gold-rgb),0.35);border-radius:var(--r-chip);padding:16px;margin-top:8px}
.ny-gem-badge{font-family:'Cinzel',serif;font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold-dim);margin-bottom:6px}
.ny-gem-name{font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:600;color:var(--gold);line-height:1.1}
.ny-gem-planet{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--text-muted);margin-top:3px;margin-bottom:2px}
.ny-gem-mantra{font-family:'Cormorant Garamond',serif;font-size:13px;color:var(--dusk);font-style:italic;margin-top:12px;padding:8px 12px;background:rgba(var(--dusk-rgb),0.08);border-radius:var(--r-xs);text-align:center;line-height:1.5}
.ny-gem-caution{font-family:'DM Sans',sans-serif;font-size:11px;color:var(--rose);margin-top:10px;padding:7px 10px;background:rgba(var(--rose-rgb),0.07);border-radius:var(--r-xs);line-height:1.4}
.ny-gem-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-inner);padding:12px 14px;margin-top:10px}
.ny-gem-card-name{font-family:'Cinzel',serif;font-size:13px;color:var(--ink);font-weight:600}
.ny-gem-card-planet{font-family:'DM Sans',sans-serif;font-size:11px;color:var(--text-muted);margin-top:2px}
.ny-gem-card-detail{font-family:'DM Sans',sans-serif;font-size:11px;color:var(--sage);margin-top:4px}
.ny-gem-card-alt{font-family:'DM Sans',sans-serif;font-size:11px;color:var(--dusk);margin-top:3px}
.ny-gem-avoid-section{margin-top:4px}
.ny-gem-avoid-item{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink);padding:8px 10px;background:rgba(var(--rose-rgb),0.06);border-left:3px solid var(--rose);border-radius:0 8px 8px 0;margin-top:8px;line-height:1.45}
.ny-gem-avoid-item strong{color:var(--rose)}
/* ─────────────────────────────────────────────────────────── */
.ny-transit-card{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--sage);border-radius:var(--r-chip);padding:14px 16px;margin-bottom:14px}
.ny-transit-title{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:2.5px;color:var(--sage);text-transform:uppercase;margin-bottom:10px}
.ny-transit-rows{display:flex;flex-direction:column;gap:7px}
.ny-tx-row{display:flex;align-items:center;justify-content:space-between;gap:8px}
.ny-tx-row--hl .ny-tx-label{color:var(--ink);font-weight:600}
.ny-tx-label{font-family:'DM Sans',sans-serif;font-size:var(--text-sm);color:var(--text-muted);flex-shrink:0;min-width:90px}
.ny-tx-val{font-family:'DM Sans',sans-serif;font-size:var(--text-sm);color:var(--ink);display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.ny-tx-dig{font-size:10px;font-family:'Cinzel',serif;letter-spacing:1px;text-transform:uppercase;padding:2px 7px;border-radius:var(--r-pill)}
.ny-tx-dig--exalted{background:rgba(var(--sage-rgb),0.15);color:var(--sage)}
.ny-tx-dig--debilitated{background:rgba(var(--rose-rgb),0.12);color:var(--rose)}
.ny-tx-dig--own-sign{background:rgba(var(--gold-rgb),0.12);color:var(--gold)}
/* Blueprint planet table — dignity badges */
.dig-badge{display:inline-block;font-family:'DM Sans',sans-serif;font-size:9px;font-weight:600;border-radius:var(--r-tag);padding:1px 5px;letter-spacing:0.3px;line-height:1.4}
.dig-exalted{background:rgba(var(--sage-rgb),0.15);color:var(--sage)}
.dig-debilitated{background:rgba(var(--rose-rgb),0.12);color:var(--rose)}
.dig-own{background:rgba(var(--sage-rgb),0.1);color:#4a8c68}
.dig-enemy{background:rgba(var(--rose-rgb),0.08);color:var(--rose)}
.ny-tx-double{display:flex;align-items:flex-start;gap:8px;margin-top:4px;padding-top:8px;border-top:1px solid var(--border)}
.ny-tx-double-icon{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--dusk);flex-shrink:0;margin-top:5px}
.ny-tx-double span:last-child{font-family:'DM Sans',sans-serif;font-size:var(--text-sm);color:var(--dusk);line-height:1.45}

/* 6b. TODAY'S SKY — summary line + house impact table */
.ny-tx-summary{font-family:'DM Sans',sans-serif;font-size:11px;color:var(--text-muted);margin-bottom:10px;line-height:1.45}
.ny-tx-expand-btn{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;border-top:1px solid var(--border);padding:8px 0 0;margin-top:10px;cursor:pointer;font-family:'Cinzel',serif;font-size:10px;letter-spacing:1.5px;color:var(--sage);text-transform:uppercase}
.ny-tx-expand-btn:focus-visible{outline:2px solid var(--sage);outline-offset:2px;border-radius:2px}
.ny-tx-expand-arrow{font-size:11px}
@media (prefers-reduced-motion:reduce){.ny-tx-expand-arrow{transition:none}}
.ny-hx-table{margin-top:8px}
.ny-hx-row{display:flex;align-items:center;gap:6px;padding:5px 0;border-bottom:1px solid rgba(var(--ink-rgb),0.06)}
.ny-hx-row:last-child{border-bottom:none}
.ny-hx-row--dasha{background:rgba(var(--gold-rgb),0.05);margin:0 -4px;padding:5px 4px;border-radius:4px}
.ny-hx-house{font-family:'Cinzel',serif;font-size:10px;color:var(--ink);min-width:52px;flex-shrink:0}
.ny-hx-sign{color:var(--text-muted);font-size:9px}
.ny-hx-chips{flex:1;display:flex;flex-wrap:wrap;gap:3px;align-items:center}
.ny-hx-chip{font-family:'DM Sans',sans-serif;font-size:10px;background:rgba(var(--sage-rgb),0.13);color:var(--sage);padding:1px 5px;border-radius:var(--r-tag)}
.ny-hx-empty{font-size:10px;color:var(--text-muted);opacity:0.5}
.ny-hx-impact{font-family:'Cinzel',serif;font-size:9px;letter-spacing:0.5px;font-weight:600;min-width:28px;text-align:right}
.ny-hx-impact--high{color:var(--rose)}
.ny-hx-impact--med{color:var(--gold)}
.ny-hx-impact--low{color:transparent}

/* 7. MINI CONTEXT PILLS */
.ny-ctx-row{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:18px}

/* 8. TODAY'S PANCHANG */
.ny-panchang-card{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--gold);border-radius:var(--r-chip);padding:14px 16px;margin-bottom:14px}
.ny-panchang-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.ny-panchang-title{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:2.5px;color:var(--gold);text-transform:uppercase}
.ny-panchang-vara{font-family:'DM Sans',sans-serif;font-size:11px;color:var(--text-muted)}
.ny-panchang-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 12px;margin-bottom:12px}
.ny-pan-item{}
.ny-pan-label{font-family:'Cinzel',serif;font-size:9px;letter-spacing:1.5px;color:var(--text-muted);text-transform:uppercase;margin-bottom:2px}
.ny-pan-val{font-family:'DM Sans',sans-serif;font-size:var(--text-sm);color:var(--ink);line-height:1.3}
.ny-panchang-sun{display:flex;align-items:center;gap:10px;font-family:'DM Sans',sans-serif;font-size:var(--text-sm);color:var(--text-muted);margin-bottom:12px}
.ny-pan-sun-item{display:flex;align-items:center;gap:4px}
.ny-pan-sun-icon{font-size:12px;color:var(--gold)}
.ny-pan-sun-sep{color:var(--border)}
.ny-panchang-periods{display:flex;flex-direction:column;gap:6px}
.ny-pan-period{display:flex;align-items:center;justify-content:space-between;padding:7px 10px;border-radius:var(--r-xs)}
.ny-pan-period--rahu{background:rgba(var(--rose-rgb),0.09)}
.ny-pan-period--abhijit{background:rgba(var(--gold-rgb),0.09)}
.ny-pan-period-label{font-family:'Cinzel',serif;font-size:10px;letter-spacing:1px;text-transform:uppercase}
.ny-pan-period--rahu .ny-pan-period-label{color:var(--rose)}
.ny-pan-period--abhijit .ny-pan-period-label{color:var(--gold)}
.ny-pan-period-time{font-family:'DM Sans',sans-serif;font-size:var(--text-sm);color:var(--ink)}
.ny-ctx-pill{font-family:'DM Sans',sans-serif;font-size:var(--text-sm);color:var(--text-muted);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-pill);padding:5px 11px;line-height:1.4}

/* ══════════════════════════════════════════════
   TODAY TAB — REDESIGNED LAYOUT (Sections 1–10)
   ══════════════════════════════════════════════ */

/* 1+2. PHASE BLOCK — Phase Name + Reality Line */
.ny-phase-block{background:var(--gold);border-radius:var(--r-pill);padding:22px 22px 18px;margin-bottom:16px;position:relative;overflow:hidden}
.ny-phase-block::before{content:'';position:absolute;top:-40px;right:-40px;width:130px;height:130px;border-radius:50%;background:rgba(255,255,255,0.07);pointer-events:none}
.ny-phase-block::after{content:'';position:absolute;bottom:-20px;left:-20px;width:80px;height:80px;border-radius:50%;background:rgba(255,255,255,0.04);pointer-events:none}
/* .ny-phase-name and .ny-phase-desc re-used from legacy — keep on gold bg */
.ny-phase-line{font-family:'DM Sans',sans-serif;font-size:var(--text-base);font-weight:400;color:rgba(255,255,255,0.88);line-height:1.55;margin-bottom:12px;position:relative}
.ny-phase-footer{display:flex;align-items:center;justify-content:space-between;gap:10px;position:relative}
/* Shimmer on dark gold background */
.ny-shimmer-dark{background:rgba(255,255,255,0.18);animation:shimmerPulse 1.6s ease-in-out infinite}

/* 3. COUNTDOWN BLOCK */
.ny-countdown-block{text-align:center;padding:24px 16px 20px;margin-bottom:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-pill)}
.ny-countdown-inner{display:flex;flex-direction:column;align-items:center;gap:0}
.ny-countdown-number{font-family:'Cormorant Garamond',serif;font-size:clamp(64px,18vw,96px);font-weight:600;color:var(--ink);line-height:1;letter-spacing:-2px}
.ny-countdown-label{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:3px;text-transform:uppercase;color:var(--sage);margin-top:2px}
.ny-countdown-sub{font-family:'DM Sans',sans-serif;font-size:var(--text-sm);color:var(--text-muted);margin-top:8px;line-height:1.4}
.ny-countdown-shimmer{width:60px;height:64px;border-radius:var(--r-xs);background:rgba(var(--ink-rgb),0.06);margin:0 auto;animation:shimmerPulse 1.6s ease-in-out infinite}
/* "Shifting Today" variant */
.ny-countdown--today .ny-countdown-today-label{font-family:'Cormorant Garamond',serif;font-size:clamp(32px,9vw,48px);font-weight:500;color:var(--sage);line-height:1.2;letter-spacing:-0.5px}
@media(prefers-reduced-motion:reduce){.ny-countdown-shimmer,.ny-shimmer-dark{animation:none;opacity:0.5}}

/* 4. SINGLE ACTION CTA */
.ny-today-cta{display:block;width:100%;background:var(--gold);color:#fff;border:none;border-radius:var(--r-pill);font-family:'DM Sans',sans-serif;font-size:var(--text-base);font-weight:600;letter-spacing:0.3px;padding:15px 20px;margin-bottom:10px;cursor:pointer;text-align:center;transition:opacity var(--dur-fast) var(--ease-std)}
.ny-today-cta:hover{opacity:0.88}
.ny-today-cta:active{opacity:0.78}
.ny-today-cta:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:var(--r-pill)}

/* 5. MICRO TRUST SIGNAL */
.ny-trust-signal{font-family:'Cinzel',serif;font-size:11px;letter-spacing:1px;color:rgba(var(--ink-rgb),0.42);text-align:center;margin-bottom:20px;min-height:16px}

/* 6. WHY YOU'RE FEELING THIS */
.ny-why-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-chip);padding:18px 18px 16px;margin-bottom:14px}

/* 7. WHAT'S COMING NEXT */
.ny-coming-card{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--sage);border-radius:var(--r-chip);padding:18px 18px 16px;margin-bottom:14px}

/* Shared section label + body (sections 6 & 7) */
.ny-section-label{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:2.5px;color:var(--gold);text-transform:uppercase;margin-bottom:10px}
.ny-section-body{font-family:'DM Sans',sans-serif;font-size:var(--text-base);color:var(--ink);line-height:1.65}

/* 9. TODAY'S SKY — compact preview */
.ny-sky-preview{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--sage);border-radius:var(--r-chip);padding:14px 16px;margin-bottom:14px;cursor:pointer;transition:background var(--dur-fast) var(--ease-std)}
.ny-sky-preview:hover,.ny-sky-preview:focus-visible{background:rgba(var(--sage-rgb),0.04);outline:none}
.ny-sky-preview:focus-visible{outline:2px solid var(--sage);outline-offset:2px;border-radius:var(--r-chip)}

/* 10. PANCHANG — compact preview */
.ny-panchang-preview{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--gold);border-radius:var(--r-chip);padding:14px 16px;margin-bottom:14px;cursor:pointer;transition:background var(--dur-fast) var(--ease-std)}
.ny-panchang-preview:hover,.ny-panchang-preview:focus-visible{background:rgba(var(--gold-rgb),0.04);outline:none}
.ny-panchang-preview:focus-visible{outline:2px solid var(--gold);outline-offset:2px;border-radius:var(--r-chip)}

/* Preview shared: header row + data rows */
.ny-preview-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.ny-preview-label{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:2.5px;text-transform:uppercase}
.ny-sky-preview .ny-preview-label{color:var(--sage)}
.ny-panchang-preview .ny-preview-label{color:var(--gold)}
.ny-preview-tap{font-family:'DM Sans',sans-serif;font-size:11px;color:rgba(var(--ink-rgb),0.38);letter-spacing:0.2px}
.ny-preview-rows{display:flex;flex-direction:column;gap:6px}
.ny-preview-row{display:flex;align-items:center;justify-content:space-between;gap:8px}
.ny-preview-row--hl .ny-preview-row-label{color:var(--ink);font-weight:600}
.ny-preview-row-label{font-family:'DM Sans',sans-serif;font-size:var(--text-sm);color:var(--text-muted);flex-shrink:0;min-width:80px}
.ny-preview-row-val{font-family:'DM Sans',sans-serif;font-size:var(--text-sm);color:var(--ink);display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:flex-end}

/* ── BOTTOM SHEETS ─────────────────────────────────────────────────────── */
.ny-bottom-sheet{position:fixed;inset:0;z-index:900;display:flex;flex-direction:column;justify-content:flex-end;pointer-events:none;visibility:hidden}
.ny-bottom-sheet.ny-bs-open{pointer-events:auto;visibility:visible}

/* Backdrop */
.ny-bs-backdrop{position:absolute;inset:0;background:rgba(var(--ink-rgb),0.45);opacity:0;transition:opacity var(--dur-slow) var(--ease-std)}
.ny-bs-open .ny-bs-backdrop{opacity:1}

/* Panel slides up */
.ny-bs-panel{position:relative;background:var(--surface);border-radius:20px 20px 0 0;padding:12px 20px 32px;max-height:82vh;overflow-y:auto;overscroll-behavior:contain;transform:translateY(100%);transition:transform var(--dur-slow) var(--ease-spring)}
.ny-bs-open .ny-bs-panel{transform:translateY(0)}

/* Drag handle */
.ny-bs-handle{width:36px;height:4px;border-radius:var(--r-pill);background:rgba(var(--ink-rgb),0.16);margin:0 auto 16px}

/* Header row: title + close button */
.ny-bs-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.ny-bs-title{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);margin-bottom:0}
.ny-bs-close{background:none;border:none;color:var(--text-muted);font-size:18px;line-height:1;cursor:pointer;padding:6px 4px;border-radius:var(--r-sm);transition:color var(--dur-base);flex-shrink:0}
.ny-bs-close:hover,.ny-bs-close:focus{color:var(--text);outline:2px solid var(--gold);outline-offset:2px}

/* Scrollable body */
.ny-bs-body{font-family:'DM Sans',sans-serif;font-size:var(--text-base);color:var(--ink)}
.ny-bs-panchang-vara{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:1.5px;color:var(--text-muted);text-transform:uppercase;margin-bottom:12px}
.ny-tx-expand-label{font-family:'Cinzel',serif;font-size:10px;letter-spacing:2px;color:var(--sage);text-transform:uppercase;margin:16px 0 8px;padding-top:14px;border-top:1px solid var(--border)}

@media(prefers-reduced-motion:reduce){
  .ny-bs-backdrop,.ny-bs-panel{transition:none}
}

/* ══════════════════════════════════════════════
   LIFE BLUEPRINT — Profile tab
   ══════════════════════════════════════════════ */

.blueprint-hero{padding:18px 16px 14px;border-bottom:1px solid var(--border);background:var(--surface);margin-bottom:14px}
.bp-name{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:400;color:var(--ink);line-height:1.2;margin-bottom:4px}
.bp-meta{font-size:var(--text-sm);color:var(--text-muted);margin-bottom:10px}
.bp-badges{display:flex;flex-wrap:wrap;gap:6px}
.bp-badge{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:1.2px;color:var(--gold);background:var(--gold-bg,rgba(var(--gold-rgb),0.08));border:1px solid rgba(var(--gold-rgb),0.2);border-radius:var(--r-pill);padding:4px 10px;text-transform:uppercase}

.blueprint-reading-title{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:3px;color:var(--text-muted);text-transform:uppercase;padding:16px 16px 8px;margin-top:6px}

/* Profile tab shrink so 5 tabs fit */
.profile-tabs{display:flex;overflow-x:auto;scrollbar-width:none;border-bottom:1px solid var(--border);background:var(--surface)}
.profile-tabs::-webkit-scrollbar{display:none}
.profile-tab{flex-shrink:0;padding:12px 14px;font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:1.2px;text-transform:uppercase;color:var(--text-muted);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;transition:color 0.15s,border-color 0.15s}
.profile-tab.active{color:var(--gold);border-bottom-color:var(--gold)}

/* ── INLINE CHAT: sticky input, never hidden behind bottom nav ── */
.inline-chat{display:flex;flex-direction:column;position:relative}
.inline-chat-input-row{
  position:sticky;
  bottom:calc(var(--bottom-nav-h) + 8px);
  background:var(--surface);
  border-top:1px solid var(--border);
  z-index:10;
  border-radius:0 0 var(--r-card,16px) var(--r-card,16px);
}
/* Extra scroll space so last inline chat message is never behind nav */
.inline-chat-messages{padding-bottom:8px}

/* ── BLUEPRINT: single-column chart grid inside narrow profile panel ── */
#profile-tab-blueprint .chart-main-grid{grid-template-columns:1fr}
#profile-tab-blueprint .chart-wheel-card,
#profile-tab-blueprint .chart-planets-card{border-radius:var(--r-sm)}
#profile-tab-blueprint .blueprint-reading-title{padding:14px 12px 6px}
#profile-tab-blueprint .ai-section,
#profile-tab-blueprint .deep-reading-wrap{padding:0 4px}

/* ══════════════════════════════════════════════
   DASHA TIMELINE BAR — Lifetime Map
   ══════════════════════════════════════════════ */
.dasha-tl-wrap{padding:16px 14px 12px}
.dasha-tl-header{margin-bottom:12px}
.dasha-tl-title{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:2px;color:var(--gold);text-transform:uppercase;margin-bottom:4px}
.dasha-tl-current-badge{font-family:'Cormorant Garamond',serif;font-size:var(--text-lg);color:var(--ink);font-weight:400}
/* The bar itself */
.dasha-tl-bar{display:flex;height:36px;border-radius:var(--r-tag);overflow:hidden;width:100%;margin-bottom:0}
.dasha-tl-seg{flex-shrink:0;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;padding:2px 4px;cursor:pointer;transition:opacity 0.15s;overflow:hidden;white-space:nowrap}
.dasha-tl-seg.active{opacity:1!important;box-shadow:inset 0 0 0 2px rgba(255,255,255,0.4)}
.dasha-tl-seg-sym{font-size:var(--text-sm);color:rgba(255,255,255,0.9);line-height:1}
.dasha-tl-seg-name{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:0.5px;color:rgba(255,255,255,0.75);overflow:hidden;text-overflow:ellipsis;max-width:100%}
/* NOW marker */
.dasha-tl-now{position:absolute;top:0;bottom:0;width:2px;background:#fff;opacity:0.9;pointer-events:none;box-shadow:0 0 4px rgba(255,255,255,0.6)}
/* Year labels — key fix: absolute inside relative container, non-overlapping */
.dasha-tl-labels{position:relative;height:18px;margin-top:4px;overflow:hidden}
.dasha-tl-label{position:absolute;font-family:'DM Sans',sans-serif;font-size:var(--text-sm);color:var(--text-muted);transform:translateX(-50%);white-space:nowrap;line-height:18px}
/* Antardasha sequence inside detail */
.antar-bar{display:flex;height:24px;border-radius:var(--r-xs);overflow:hidden;margin:10px 0 4px}
.antar-seg{flex-shrink:0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:opacity 0.15s;overflow:hidden}
.antar-seg.active{opacity:1!important;box-shadow:inset 0 0 0 2px rgba(255,255,255,0.4)}
.antar-seg-sym{font-size:var(--text-sm);color:rgba(255,255,255,0.85)}
.antar-labels{position:relative;height:16px;overflow:hidden;margin-bottom:8px}
.antar-label{position:absolute;font-size:var(--text-xs);color:var(--text-muted);transform:translateX(-50%);white-space:nowrap}

/* ══════════════════════════════════════════════
   DASHA DETAIL — Antardasha bar & list
   ══════════════════════════════════════════════ */
.dasha-detail{padding:0;overflow:hidden}
.dasha-detail-head{display:flex;align-items:center;gap:14px;padding:16px;margin-bottom:0}
.dasha-detail-sym{font-size:28px;line-height:1;flex-shrink:0}
.dasha-detail-title{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:400;color:var(--ink);line-height:1.2}
.dasha-detail-dates{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--text-muted);margin-top:3px}
.dasha-detail-years{font-family:'DM Sans',sans-serif;font-size:var(--text-sm);color:var(--text-muted);margin-top:2px}
.dasha-antar-title{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:2px;color:var(--text-muted);text-transform:uppercase;padding:14px 16px 8px}
/* THE KEY FIX: flex row so segments sit side-by-side proportionally */
.dasha-antar-bar{display:flex;flex-direction:row;height:32px;margin:0 16px 4px;border-radius:var(--r-tag);overflow:hidden}
.dasha-antar-seg{flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);color:rgba(255,255,255,0.85);cursor:pointer;transition:opacity 0.15s;overflow:hidden}
.dasha-antar-seg.active{opacity:1!important;box-shadow:inset 0 0 0 2px rgba(255,255,255,0.4)}
/* Antardasha list items */
.dasha-antar-list{padding:0 12px 12px}
.dasha-antar-item{display:flex;align-items:center;gap:10px;padding:9px 6px;border-bottom:1px solid var(--border)}
.dasha-antar-item:last-child{border-bottom:none}
.dasha-antar-item.current{background:var(--gold-bg);border-radius:var(--r-tag);border-color:transparent;padding:9px 10px;margin:0 -4px}
.dasha-antar-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.dasha-antar-name{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink);font-weight:400}
.dasha-antar-dur{font-size:var(--text-sm);color:var(--text-muted);margin-top:1px}
.dasha-antar-badge{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:1px;background:var(--gold);color:#fff;border-radius:var(--r-pill);padding:3px 8px;flex-shrink:0}
/* Duration label inside bar segment */
.dasha-tl-seg-dur{font-family:'DM Sans',sans-serif;font-size:9px;color:rgba(255,255,255,0.6);line-height:1;margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}
/* Mahadasha sequence list — compact row-per-period */
.dasha-seq-list{padding:10px 14px 4px;display:flex;flex-direction:column;gap:0}
.dasha-seq-item{display:flex;align-items:center;gap:8px;padding:6px 6px;border-bottom:1px solid rgba(0,0,0,0.05);cursor:pointer;border-radius:var(--r-xs);transition:background 0.12s}
.dasha-seq-item:last-child{border-bottom:none}
.dasha-seq-item:hover{background:rgba(0,0,0,0.03)}
.dasha-seq-item.active{background:rgba(var(--gold-rgb),0.06);border-bottom-color:transparent;border-radius:var(--r-xs)}
.dasha-seq-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dasha-seq-sym{font-size:15px;line-height:1;width:18px;text-align:center;flex-shrink:0}
.dasha-seq-name{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink);font-weight:500;min-width:60px}
.dasha-seq-yrs{font-family:'DM Sans',sans-serif;font-size:10px;color:var(--text-muted);flex:1}
.dasha-seq-badge{font-family:'DM Sans',sans-serif;font-size:10px;font-weight:600;border-radius:var(--r-inner);padding:2px 7px;flex-shrink:0;letter-spacing:0.3px}
.dasha-seq-now{font-family:'Cinzel',serif;font-size:8px;letter-spacing:1px;background:var(--gold);color:#fff;border-radius:var(--r-tag);padding:2px 6px;flex-shrink:0;text-transform:uppercase}

/* ══════════════════════════════════════════════
   TIMELINE — Session 24 rebuild
   Sections 1–7 new components
   ══════════════════════════════════════════════ */

/* ── Shared: section micro-label ── */
.ny-s-label{font-family:'Cinzel',serif;font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--text-muted)}

/* ── Section 1: YOUR TIMING block ── */
.ny-timing-block{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:16px 18px 14px;margin-top:14px}
.ny-timing-label{font-family:'Cinzel',serif;font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--text-muted);margin-bottom:14px}
.ny-timing-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}
.ny-timing-row:last-child{border-bottom:none;padding-bottom:2px}
.ny-timing-tier{font-family:'Cinzel',serif;font-size:10px;letter-spacing:0.8px;color:var(--text-muted);min-width:90px;flex-shrink:0}
.ny-timing-planet{display:flex;align-items:center;gap:8px;flex:1}
.ny-timing-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.ny-timing-name{font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--ink);font-weight:400}
.ny-timing-date{font-family:'DM Sans',sans-serif;font-size:11px;color:var(--text-muted);text-align:right;flex-shrink:0}
/* Active (Current Phase) row — gold highlight */
.ny-timing-active{background:var(--gold-bg);border-radius:10px;padding:10px 12px;margin:0 -12px;border-bottom:none!important}
.ny-timing-active .ny-timing-tier{color:var(--gold-dim)}
.ny-timing-active .ny-timing-name{color:var(--gold);font-weight:600}
.ny-timing-active .ny-timing-date{color:var(--gold-dim)}
/* Sub-Period (Pratyantara) row — indented, subtler */
.ny-timing-sub{padding-left:18px}
.ny-timing-sub .ny-timing-tier{font-size:9px;color:var(--text-muted);opacity:0.8}
.ny-timing-sub .ny-timing-dot{width:8px;height:8px}
.ny-timing-sub .ny-timing-name{font-size:15px;color:var(--ink3)}
/* Antardasha items that have pratyantara data — show pointer + hover */
.dasha-antar-item.has-prats{cursor:pointer;border-radius:8px;transition:background 0.15s}
.dasha-antar-item.has-prats:hover{background:var(--surface-hover,rgba(255,255,255,0.04))}

/* ── Section 3: Upcoming Phases ── */
.ny-upcoming-phases{padding:16px 16px 8px}
.ny-phase-list{display:flex;flex-direction:column;gap:2px}
.ny-phase-row{display:flex;align-items:center;gap:12px;padding:11px 8px;border-radius:10px;cursor:pointer;transition:background 0.15s;-webkit-tap-highlight-color:transparent}
.ny-phase-row:hover,.ny-phase-row:active{background:var(--bg2)}
.ny-phase-active{background:var(--gold-bg)!important;border:1px solid rgba(var(--gold-rgb),0.25)}
.ny-phase-dot{width:11px;height:11px;border-radius:50%;flex-shrink:0}
.ny-phase-info{flex:1;min-width:0}
.ny-phase-name{font-family:'Cormorant Garamond',serif;font-size:16px;color:var(--ink);font-weight:400;line-height:1.2}
.ny-phase-dates{font-size:11px;color:var(--text-muted);margin-top:1px}
.ny-phase-meaning{font-size:11px;color:var(--ink3);margin-top:2px;font-style:italic}
.ny-phase-chevron{font-size:18px;color:var(--text-muted);flex-shrink:0;padding-left:4px}
.ny-phase-empty{font-size:13px;color:var(--text-muted);padding:8px 4px}

/* ── Section 4: Saturn Watch ── */
.ny-saturn-watch{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px 16px}
.ny-saturn-watch.sw-clear{display:flex;align-items:center;gap:10px;padding:14px 16px}
.sw-tick{font-size:18px;color:var(--sage);flex-shrink:0}
.sw-clear-text{font-family:'DM Sans',sans-serif;font-size:14px;color:var(--sage)}
.ny-saturn-watch.sw-active{padding:14px 16px}
.sw-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.sw-badge{font-family:'Cinzel',serif;font-size:9px;letter-spacing:1.5px;text-transform:uppercase;border-radius:var(--r-pill);padding:4px 10px}
.sw-badge-active{background:rgba(var(--rose-rgb),0.1);color:var(--rose);border:1px solid rgba(var(--rose-rgb),0.25)}
.sw-badge-dhaiya{background:rgba(var(--dusk-rgb),0.1);color:var(--dusk);border:1px solid rgba(var(--dusk-rgb),0.25)}
.sw-phase-label{font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--ink)}
.sw-end-date{font-size:12px;color:var(--text-muted);margin-bottom:8px}
.sw-body-text{font-family:'DM Sans',sans-serif;font-size:13px;color:var(--ink2);line-height:1.6}
.sw-loading-text{font-size:13px;color:var(--text-muted);margin-top:6px}

/* ── Sections 5 & 6: tap-row previews ── */
.ny-section-tap-row{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px 16px;cursor:pointer;transition:background 0.15s;-webkit-tap-highlight-color:transparent;display:flex;align-items:center;gap:12px}
.ny-section-tap-row:hover,.ny-section-tap-row:active{background:var(--bg2)}
.ny-str-body{flex:1;min-width:0}
.ny-str-preview{font-family:'DM Sans',sans-serif;font-size:13px;color:var(--ink2);line-height:1.5;margin-top:6px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.ny-str-chevron{font-size:20px;color:var(--text-muted);flex-shrink:0}

/* ── Section 5: This Year — bottom sheet body ── */
.ny-bs-yearly-body{font-family:'DM Sans',sans-serif;font-size:14px;color:var(--ink);line-height:1.7}
.ny-bs-yearly-body p{margin-bottom:12px}
.ny-bs-yearly-body strong{color:var(--gold);font-weight:600}

/* ── Section 6: Year Ahead Chart — bottom sheet ── */
.ny-ya-header{text-align:center;padding:8px 0 20px;border-bottom:1px solid var(--border);margin-bottom:16px}
.ny-ya-year{font-family:'Cormorant Garamond',serif;font-size:48px;color:var(--gold);line-height:1}
.ny-ya-sub{font-size:12px;color:var(--text-muted);margin-top:4px}
.ny-ya-lord{margin-top:10px;font-family:'Cinzel',serif;font-size:10px;letter-spacing:1px;color:var(--gold-dim);background:var(--gold-bg);border:1px solid rgba(var(--gold-rgb),0.2);display:inline-block;border-radius:var(--r-pill);padding:4px 14px}
.ny-ya-lord strong{font-weight:600}
.ny-ya-srdate{font-size:11px;color:var(--text-muted);margin-top:6px}
.ny-ya-planet-list{display:flex;flex-direction:column;gap:4px}
.ny-ya-planet-row{display:flex;align-items:center;gap:10px;padding:8px 4px;border-bottom:1px solid var(--border)}
.ny-ya-planet-row:last-child{border-bottom:none}
.ny-ya-planet-name{font-family:'DM Sans',sans-serif;font-size:13px;flex:1;font-weight:500}
.ny-ya-sign{font-size:12px;color:var(--ink2);flex:1}
.ny-ya-house{font-size:11px;color:var(--text-muted);min-width:36px;text-align:right}

/* ── Section 7: Other Systems ── */
.ny-other-systems{background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden;margin-bottom:24px}
.ny-os-row{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;cursor:pointer;-webkit-tap-highlight-color:transparent}
.ny-os-row:hover,.ny-os-row:active{background:var(--bg2)}
.ny-os-label{font-family:'Cinzel',serif;font-size:11px;letter-spacing:1.5px;color:var(--text-muted);text-transform:uppercase}
.ny-os-chevron{font-size:18px;color:var(--text-muted);transition:transform 0.2s ease}
.ny-os-body{display:none;padding:0 16px 14px;border-top:1px solid var(--border)}
.ny-os-body.ny-os-open{display:block}
.ny-os-system{padding-top:12px}
.ny-os-sys-title{font-family:'Cinzel',serif;font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--gold-dim);margin-bottom:6px}
.ny-os-sys-content{font-family:'DM Sans',sans-serif;font-size:13px}
.ny-os-cur-row{display:flex;align-items:center;gap:12px}
.ny-os-cur-planet{font-family:'Cormorant Garamond',serif;font-size:17px;color:var(--ink);font-weight:400}
.ny-os-cur-dates{font-size:11px;color:var(--text-muted)}
.ny-os-loading{font-size:12px;color:var(--text-muted);font-style:italic}
.ny-os-none{font-size:12px;color:var(--text-muted)}

/* ── Pratyantara bottom sheet list ── */
.ny-prat-list{display:flex;flex-direction:column;gap:4px}
.ny-prat-row{display:flex;align-items:center;gap:12px;padding:10px 6px;border-bottom:1px solid var(--border)}
.ny-prat-row:last-child{border-bottom:none}
.ny-prat-active{background:var(--gold-bg);border-radius:8px;border-color:transparent;padding:10px 10px;margin:0 -4px}
.ny-prat-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.ny-prat-info{flex:1}
.ny-prat-name{font-family:'DM Sans',sans-serif;font-size:13px;color:var(--ink);font-weight:400}
.ny-prat-dates{font-size:11px;color:var(--text-muted);margin-top:1px}
.ny-prat-now{font-family:'Cinzel',serif;font-size:8px;letter-spacing:1px;background:var(--gold);color:#fff;border-radius:var(--r-pill);padding:2px 7px;flex-shrink:0;text-transform:uppercase}

/* ══════════════════════════════════════════════
   SADE SATI SECTION — Timeline tab
   ══════════════════════════════════════════════ */
.ss-timeline-card{background:var(--surface);border:1px solid var(--border);border-radius:18px;margin-top:14px;overflow:hidden}
.ss-tl-header{padding:16px 16px 12px;border-bottom:1px solid var(--border)}
.ss-tl-title{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:2px;color:var(--gold);text-transform:uppercase;margin-bottom:6px}
.ss-tl-status{font-family:'Cormorant Garamond',serif;font-size:20px;color:var(--ink);font-weight:400}
.ss-tl-sub{font-size:var(--text-sm);color:var(--text-muted);margin-top:3px}
.ss-phase-list{padding:12px 16px}
.ss-phase-item{display:flex;gap:12px;padding:8px 0;border-bottom:1px solid var(--border);align-items:flex-start}
.ss-phase-item:last-child{border-bottom:none}
.ss-phase-dot{width:10px;height:10px;border-radius:50%;background:var(--gold);flex-shrink:0;margin-top:4px}
.ss-phase-dot.active{background:var(--rose);box-shadow:0 0 0 3px rgba(var(--rose-rgb),0.15)}
.ss-phase-dot.clear{background:var(--sage)}
.ss-phase-name{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink);font-weight:500}
.ss-phase-dates{font-size:var(--text-sm);color:var(--text-muted);margin-top:2px}
.ss-phase-badge{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:1px;color:#fff;background:var(--rose);border-radius:var(--r-pill);padding:2px 8px;margin-top:3px;display:inline-block}

/* ══════════════════════════════════════════════
   INLINE CHAT — WhatsApp-inspired improvements
   ══════════════════════════════════════════════ */

/* Typing indicator with label */
.inline-typing-wrap{display:flex;align-items:center;gap:8px;padding:4px 2px}
.inline-typing-label{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:1.5px;color:var(--gold);opacity:0.7;animation:fadeFlick 1.8s ease-in-out infinite}

/* AI bubble — insight card style */
.inline-msg.ai .inline-bubble{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-chip) 16px 16px 4px;
  box-shadow:0 2px 12px rgba(var(--ink-rgb),0.06);
  padding:14px 16px;
  font-family:'Cormorant Garamond',serif;
  font-size:var(--text-lg);
  line-height:1.75;
  color:var(--ink);
}
.inline-p{margin:0 0 8px;padding:0}
.inline-p:last-of-type{margin-bottom:0}
.inline-li{padding:3px 0 3px 14px;position:relative;font-size:15px;color:var(--ink2)}
.inline-li::before{content:'•';position:absolute;left:0;color:var(--gold)}
.inline-msg.ai .inline-bubble strong{color:var(--gold);font-weight:600}

/* Trust signal line */
.inline-trust{
  font-family:'Cinzel',serif;
  font-size:var(--text-xs);
  letter-spacing:1.5px;
  color:var(--text-muted);
  text-transform:uppercase;
  margin-top:10px;
  padding-top:8px;
  border-top:1px solid var(--border);
}

/* Follow-up chips — subtle, secondary, after AI response */
.inline-followup-row{
  display:flex;
  flex-wrap:wrap;
  gap:7px;
  padding:8px 0 4px;
  align-self:flex-start;
  max-width:100%;
  animation:fadeSlideUp 0.3s ease;
}
@keyframes fadeSlideUp{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.inline-followup-chip{
  background:var(--surface);
  border:1px solid rgba(var(--gold-rgb),0.25);
  border-radius:var(--r-pill);
  padding:6px 13px;
  font-family:'DM Sans',sans-serif;
  font-size:12px;
  color:var(--gold);
  cursor:pointer;
  white-space:nowrap;
  transition:all var(--dur-fast);
  -webkit-tap-highlight-color:transparent;
}
.inline-followup-chip:active{background:var(--gold);color:#fff;transform:scale(0.97)}

/* Message fade-in handled via inline JS, but ensure transition works */
.inline-msg{transition:opacity 0.3s ease,transform 0.3s ease}

/* Input — cleaner focus ring */
.inline-chat-input:focus{
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(var(--gold-rgb),0.08);
  background:var(--surface);
}

/* ══════════════════════════════════════════════
   FULL-SCREEN CHAT — bubble & message polish
   ══════════════════════════════════════════════ */

/* AI bubble matches inline insight card style */
.chat-msg.ai .chat-bubble{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-chip) 16px 16px 4px;
  box-shadow:0 2px 12px rgba(var(--ink-rgb),0.06);
  font-family:'Cormorant Garamond',serif;
  font-size:var(--text-lg);
  line-height:1.75;
  color:var(--ink);
  padding:14px 16px;
}
.chat-msg.user .chat-bubble{
  background:var(--gold);
  color:#fff;
  border-radius:var(--r-chip) 16px 4px 16px;
  padding:11px 16px;
  font-family:'DM Sans',sans-serif;
  font-size:var(--text-md);
  line-height:1.5;
}
/* Typing dots in full-screen chat */
.chat-typing{display:flex;align-items:center;gap:8px;padding:10px 16px;flex-shrink:0}
.chat-typing.active{display:flex!important}
.chat-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);opacity:0.4;animation:dotP 1.4s ease-in-out infinite}
.chat-dot:nth-child(2){animation-delay:0.2s}
.chat-dot:nth-child(3){animation-delay:0.4s}
.chat-typing-label-full{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:1.5px;color:var(--gold);opacity:0.7;animation:fadeFlick 1.8s ease-in-out infinite}

/* chat-msg animation */
.chat-msg{max-width:85%;transition:opacity 0.3s ease,transform 0.3s ease}
.chat-msg.user{align-self:flex-end}
.chat-msg.ai{align-self:flex-start}

/* Suggestions hidden by default in full-screen — we use follow-up chips */
.chat-suggestions{display:none!important}
.chat-input-hint{display:none!important}

/* Overlay to dim Today/other content when chat is open */
.chat-overlay{
  position:fixed;inset:0;z-index:799;
  background:rgba(0,0,0,0.15);
  opacity:0;pointer-events:none;
  transition:opacity var(--dur-slow);
}
.chat-overlay.active{opacity:1;pointer-events:auto}

/* ══════════════════════════════════════════════
   PANEL-ASK — FULL SCREEN CHAT (WhatsApp style)
   ══════════════════════════════════════════════ */

/* Override panel defaults — no padding, fills viewport */
#panel-ask.panel {
  padding: 0;
  display: none;
  flex-direction: column;
  height: calc(100vh - var(--nav-h) - var(--bottom-nav-h));
  overflow: hidden;
  background: var(--bg);
  position: relative;
}
#panel-ask.panel.active {
  display: flex;
}

/* ── Header ── */
.ask-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px 11px;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  position: sticky;
  top: 0;
  z-index: 10;
}
.ask-header-left { display: flex; align-items: center; gap: 10px }
.ask-avatar {
  width: 38px; height: 38px; border-radius:50%;
  background: var(--gold); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; flex-shrink: 0;
}
.ask-name {
  font-family: 'Cinzel', serif;
  font-size: 12px; letter-spacing: 1.5px;
  color: var(--ink); text-transform: uppercase;
}
.ask-status {
  font-size:var(--text-sm); color: var(--sage); margin-top: 1px;
}
.ask-clear-btn {
  background: none; border: none;
  color: var(--text-muted); font-size: 18px;
  cursor: pointer; padding: 6px; border-radius:50%;
  transition: color 0.15s;
}
.ask-clear-btn:hover { color: var(--gold) }
.ask-history-btn {
  background: none; border: none;
  color: var(--text-muted); font-size: 18px;
  cursor: pointer; padding: 6px; border-radius:50%;
  transition: color 0.15s; margin-right: 2px;
}
.ask-history-btn:hover { color: var(--gold) }

/* ── Sessions history drawer ── */
.ask-sessions-drawer {
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background: var(--bg);
  z-index: 20;
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.25s ease;
  will-change: transform;
}
.ask-sessions-drawer.open {
  transform: translateX(0);
}
@media (prefers-reduced-motion: reduce) {
  .ask-sessions-drawer { transition: none; }
}
.ask-sessions-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px 13px;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.ask-sessions-title {
  font-family: 'Cinzel', serif;
  font-size: 11px; letter-spacing: 1.5px;
  color: var(--ink); text-transform: uppercase;
}
.ask-sessions-close {
  background: none; border: none;
  color: var(--text-muted); font-size: 16px;
  cursor: pointer; padding: 6px; border-radius:50%;
  transition: color 0.15s;
}
.ask-sessions-close:hover { color: var(--gold) }
.ask-sessions-list {
  flex: 1;
  overflow-y: auto;
  padding: 8px 0;
  scrollbar-width: none;
}
.ask-sessions-list::-webkit-scrollbar { display: none }
.ask-session-item {
  padding: 14px 16px;
  cursor: pointer;
  border-bottom: 1px solid var(--border);
  transition: background 0.12s;
}
.ask-session-item:hover,
.ask-session-item:active { background: var(--surface); }
.ask-session-item.active { background: var(--surface); }
.ask-session-item.active .ask-session-title { color: var(--gold); }
.ask-session-title {
  font-family: 'DM Sans', sans-serif;
  font-size: 14px; font-weight: 500;
  color: var(--ink);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.ask-session-date {
  font-family: 'DM Sans', sans-serif;
  font-size: 11px; color: var(--text-muted);
  margin-top: 3px;
}
.ask-sessions-empty {
  padding: 40px 16px;
  text-align: center;
  font-family: 'DM Sans', sans-serif;
  font-size: 13px; color: var(--text-muted);
}

/* ── Messages scroll area ── */
.ask-messages {
  flex: 1;
  overflow-y: auto;
  padding: 16px 12px 8px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
}
.ask-messages::-webkit-scrollbar { display: none }
.ask-messages { scrollbar-width: none; overscroll-behavior: contain }

/* Date pill */
.ask-date-pill {
  text-align: center;
  font-family: 'Cinzel', serif;
  font-size:var(--text-xs); letter-spacing: 2px;
  color: var(--text-muted); text-transform: uppercase;
  margin: 4px 0 8px;
}

/* ── Message bubbles ── */
.ask-msg {
  display: flex;
  max-width: 82%;
}
.ask-msg.ask-user {
  align-self: flex-end;
  flex-direction: row-reverse;
}
.ask-msg.ask-ai {
  align-self: flex-start;
}

/* User bubble — right, gold tinted */
.ask-msg.ask-user .ask-bubble {
  background: var(--gold);
  color: #fff;
  border-radius: 18px 18px 4px 18px;
  padding: 10px 14px;
  font-family: 'DM Sans', sans-serif;
  font-size:var(--text-md);
  line-height: 1.5;
}

/* AI bubble — left, parchment card with elevation */
.ask-msg.ask-ai .ask-bubble {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 4px 18px 18px 18px;
  padding: 13px 16px;
  font-family: 'Cormorant Garamond', serif;
  font-size:var(--text-lg);
  line-height: 1.75;
  color: var(--ink);
  box-shadow: 0 2px 10px rgba(var(--ink-rgb),0.07);
}
.ask-msg.ask-ai .ask-bubble strong { color: var(--gold); font-weight: 600 }
.ask-p { margin: 0 0 8px; padding: 0 }
.ask-p:last-of-type { margin-bottom: 0 }
.ask-li {
  padding: 2px 0 2px 14px;
  position: relative;
  font-size: 15px;
  color: var(--ink2, var(--ink));
}
.ask-li::before { content: '•'; position: absolute; left: 0; color: var(--gold) }

/* Trust signal */
.ask-trust {
  font-family: 'Cinzel', serif;
  font-size:var(--text-xs); letter-spacing: 1.5px;
  color: var(--text-muted); text-transform: uppercase;
  margin-top: 10px; padding-top: 8px;
  border-top: 1px solid var(--border);
}

/* Typing indicator */
.ask-typing-wrap {
  display: flex; align-items: center; gap: 8px; padding: 4px 0;
}
.ask-typing-dots {
  display: flex; gap: 4px; align-items: center;
}
.ask-typing-dots span {
  width: 6px; height: 6px; border-radius:50%;
  background: var(--gold); opacity: 0.4;
  animation: dotP 1.4s ease-in-out infinite;
}
.ask-typing-dots span:nth-child(2) { animation-delay: 0.2s }
.ask-typing-dots span:nth-child(3) { animation-delay: 0.4s }
.ask-typing-label {
  font-family: 'Cinzel', serif; font-size:var(--text-sm);
  letter-spacing: 1.5px; color: var(--gold); opacity: 0.7;
  animation: fadeFlick 1.8s ease-in-out infinite;
}

/* ── Follow-up chips ── */
.ask-chips-row {
  display: none; flex-wrap: nowrap; gap: 8px;
  padding: 8px 12px 4px;
  overflow-x: auto; scrollbar-width: none;
  flex-shrink: 0;
}
.ask-chips-row::-webkit-scrollbar { display: none }
.ask-chip {
  flex-shrink: 0;
  background: var(--surface);
  border: 1px solid rgba(var(--gold-rgb),0.3);
  border-radius:var(--r-pill);
  padding: 7px 14px;
  font-family: 'DM Sans', sans-serif;
  font-size: 12px; color: var(--gold);
  cursor: pointer; white-space: nowrap;
  transition: all 0.15s;
  -webkit-tap-highlight-color: transparent;
}
.ask-chip:active { background: var(--gold); color: #fff; transform: scale(0.97) }

/* ── Retry button (inline in error bubble) ── */
.ask-retry-btn {
  display: inline-block; margin-left: 6px;
  background: none; border: 1px solid rgba(var(--gold-rgb),0.5);
  color: var(--gold); font-family: 'DM Sans', sans-serif; font-size: 13px;
  padding: 2px 10px; border-radius: 12px; cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: background 0.15s, color 0.15s;
}
.ask-retry-btn:active { background: var(--gold); color: #fff; }

/* ── Quick tool links strip in Ask panel ── */
.ask-quick-tools {
  display: flex; gap: 8px; padding: 6px 12px 2px;
  flex-shrink: 0; overflow-x: auto; scrollbar-width: none;
}
.ask-quick-tools::-webkit-scrollbar { display: none }
.ask-quick-btn {
  flex-shrink: 0;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius:var(--r-pill);
  padding: 6px 14px;
  font-family: 'DM Sans', sans-serif;
  font-size: 12px; color: var(--ink);
  cursor: pointer; white-space: nowrap;
  transition: all 0.15s;
  -webkit-tap-highlight-color: transparent;
}
.ask-quick-btn:active { background: var(--gold); color: #fff; border-color: var(--gold); transform: scale(0.97) }

/* ── Conversation counter pill — shown at ≥80% usage ── */
.conv-counter {
  display: none;
  align-items: center;
  justify-content: center;
  font-family: 'DM Sans', sans-serif;
  font-size: 12px;
  color: var(--ink);
  background: #FFF8F0;
  border-top: 1px solid #EDE4D6;
  padding: 7px 16px;
  gap: 6px;
  cursor: pointer;
  flex-shrink: 0;
  transition: background 0.15s;
}
.conv-counter:hover, .conv-counter:focus { background: #F5ECD8; outline: none; }
.conv-counter::after {
  content: '→';
  color: var(--gold);
  font-size: 13px;
  font-weight: 500;
  margin-left: 2px;
}
@media (prefers-reduced-motion: reduce) { .conv-counter { transition: none; } }

/* ── Input row — sticky above bottom nav ── */
.ask-input-row {
  display: flex; gap: 8px;
  padding: 10px 12px;
  padding-bottom: max(10px, env(safe-area-inset-bottom));
  background: var(--surface);
  border-top: 1px solid var(--border);
  flex-shrink: 0;
  position: sticky;
  bottom: 0;
}
.ask-input {
  flex: 1;
  background: var(--bg2);
  border: 1px solid var(--border-md);
  border-radius: 24px;
  padding: 11px 16px;
  color: var(--ink);
  font-family: 'DM Sans', sans-serif;
  font-size: 16px; /* iOS zoom prevention */
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
}
@media(min-width:768px){.ask-input{font-size:var(--text-md)}}
.ask-input:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(var(--gold-rgb),0.08);
  background: var(--surface);
}
.ask-input::placeholder { color: var(--text-muted) }
/* ask-send-btn: merged into .btn--icon selector above */

/* ══════════════════════════════════════════════
   NY-ASK-ENTRY — minimal tap-to-chat strip on Today
   Replaces the old inline-chat widget
   ══════════════════════════════════════════════ */
.ny-ask-entry {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  background: var(--surface);
  border: 1px solid rgba(var(--gold-rgb),0.25);
  border-radius: 16px;
  padding: 14px 16px;
  margin-bottom: 16px;
  cursor: pointer;
  transition: all 0.15s;
  -webkit-tap-highlight-color: transparent;
}
.ny-ask-entry:active { transform: scale(0.99); border-color: var(--gold) }
.ny-ask-entry-left { display: flex; align-items: center; gap: 10px; flex: 1; min-width: 0 }
.ny-ask-entry-avatar {
  width: 34px; height: 34px; border-radius:50%;
  background: var(--gold); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size:var(--text-md); flex-shrink: 0;
}
.ny-ask-entry-placeholder {
  font-family: 'DM Sans', sans-serif;
  font-size:var(--text-md); color: var(--text-muted);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.ny-ask-entry-btn {
  flex-shrink: 0;
  background: var(--gold); color: #fff;
  border: none; border-radius:var(--r-pill);
  padding: 8px 16px;
  font-family: 'Cinzel', serif;
  font-size:var(--text-sm); letter-spacing: 1.5px;
  cursor: pointer; text-transform: uppercase;
  transition: opacity 0.15s;
}
.ny-ask-entry-btn:active { opacity: 0.85 }

/* Remove sticky from old inline-chat input — no longer used */
.inline-chat-input-row {
  position: static !important;
  bottom: auto !important;
}

/* ── Replaced inline styles ── */
.nav-logo-wrap{display:flex;align-items:center;gap:8px}
.nav-logo-svg{flex-shrink:0}
#nav-back-btn{display:none;background:none;border:none;color:var(--gold);font-size:18px;cursor:pointer;min-width:44px;min-height:44px;padding:0;line-height:1;align-items:center;justify-content:center;border-radius:50%;transition:background 0.15s}
#nav-back-btn:active{background:var(--gold-bg)}
#nav-home-btn{display:none;background:none;border:1px solid rgba(var(--gold-rgb),0.25);border-radius:var(--r-pill);color:var(--gold);font-size:var(--text-sm);font-family:Cinzel,serif;letter-spacing:1px;cursor:pointer;padding:5px 12px}
.lang-toggle-arrow{font-size:var(--text-xs);opacity:0.6;margin-left:2px}
.btn-signout-icon{background:none;border:none;cursor:pointer;color:var(--ink3);font-size:16px;padding:4px 6px;opacity:0.6;transition:opacity 0.2s}
.btn-signout-icon:hover{opacity:1}
#auth-name{display:none}
#auth-success{display:none;text-align:center;background:rgba(115,201,122,0.08);border:1px solid rgba(115,201,122,0.2);border-radius:var(--r-tag);padding:10px 14px;font-size:var(--text-sm);color:#7BC97A;margin-top:10px;line-height:1.5}
.auth-forgot{text-align:center;margin:8px 0 0}
.auth-forgot a{font-size:var(--text-sm);color:var(--gold-dim);cursor:pointer;text-decoration:none;letter-spacing:0.3px}
#signin-banner{display:flex;align-items:center;justify-content:space-between;padding:9px 16px;background:var(--gold-bg);border:1px solid rgba(var(--gold-rgb),0.2);border-radius:30px;margin-bottom:14px;gap:12px}
.signin-banner-title{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:1.5px;color:var(--gold);text-transform:uppercase;margin-bottom:2px}
.signin-banner-sub{font-size:var(--text-sm);color:var(--text-muted)}
.signin-banner-btn{padding:7px 14px;background:var(--gold-dim);border:1px solid var(--gold-dim);border-radius:var(--r-pill);color:#fff;font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:1.5px;cursor:pointer;text-transform:uppercase;white-space:nowrap;flex-shrink:0}
.sub-panel{display:none}
#blueprint-status-bar{display:none}
#more-back{display:none}
#yr-pdf-btn{display:none}
.profile-life-section{padding:16px 16px 8px}
.profile-life-label{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:2px;color:var(--text-muted);margin-bottom:4px}
.profile-life-sub{font-size:12px;color:var(--text-muted);line-height:1.5;margin-bottom:8px}
.profile-life-privacy{display:flex;align-items:flex-start;gap:8px;background:#f0ede6;border:1px solid rgba(var(--sage-rgb),0.25);border-radius:var(--r-tag);padding:9px 12px;margin:0 16px 14px}
.privacy-lock{font-size:var(--text-base);flex-shrink:0;line-height:1.5}
.privacy-text{font-size:var(--text-sm);line-height:1.55;color:var(--sage)}
.facts-clear-btn{width:100%;padding:10px;border:1px solid rgba(var(--rose-rgb),0.3);border-radius:var(--r-tag);background:none;color:var(--rose);font-size:12px;font-family:'DM Sans',sans-serif;cursor:pointer;letter-spacing:0.3px;transition:background 0.15s,border-color 0.15s}
.facts-clear-btn:hover{background:rgba(var(--rose-rgb),0.07);border-color:var(--rose)}
.profile-life-privacy{display:flex;align-items:flex-start;gap:8px;background:#f0ede6;border:1px solid rgba(var(--sage-rgb),0.25);border-radius:var(--r-tag);padding:9px 12px;margin:0 16px 14px;}
.privacy-lock{font-size:var(--text-base);flex-shrink:0;line-height:1.5}
.privacy-text{font-size:var(--text-sm);line-height:1.55;color:var(--sage)}
#profile-facts-list{padding:0 16px 80px}
.profile-settings-inner{padding:16px}
.settings-section-label{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:2px;color:var(--text-muted);margin-bottom:14px}
.settings-section-label-sm{margin-bottom:12px}
.blueprint-locked-note{margin-bottom:16px}
.settings-lang-row{display:flex;gap:8px}
.settings-lang-btn{flex:1;background:var(--bg2);border:1px solid var(--border-md);border-radius:var(--r-inner);padding:12px;cursor:pointer;color:var(--ink);font-size:var(--text-base)}
#settings-name{padding:11px 14px;font-size:var(--text-base)}
.settings-save-btn{margin-bottom:16px}
.field-mb-12{margin-bottom:12px}
.field-mb-6{margin-bottom:6px}
/* Profile gear icon */
.profile-gear{position:absolute;top:14px;right:42px;background:none;border:none;font-size:var(--text-lg);cursor:pointer;color:var(--ink);opacity:0.4;padding:4px 6px;border-radius:var(--r-2xs);transition:opacity .2s;line-height:1}
.profile-gear:hover{opacity:0.9}
/* Settings back button */
.settings-back-row{margin-bottom:16px}
.settings-back-btn{background:none;border:none;color:var(--gold);font-family:'DM Sans',sans-serif;font-size:var(--text-base);cursor:pointer;padding:0;letter-spacing:0.02em}
/* My Life divider before Recent Conversations */
.profile-life-divider{padding:20px 16px 8px;border-top:1px solid var(--border)}
/* Goals tab */
.goals-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 16px;margin-top:4px}
.goal-tile{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 10px;background:var(--surface);border:1.5px solid var(--border-md);border-radius:var(--r-sm);cursor:pointer;transition:all .18s;text-align:center;width:100%}
.goal-tile.active{border-color:var(--gold);background:#FDF8F0}
.goal-icon{font-size:22px;line-height:1}
.goal-label{font-size:var(--text-sm);font-family:'DM Sans',sans-serif;letter-spacing:0.02em;color:var(--ink);font-weight:500;line-height:1.35}
/* Goal timing window tag — shown under active tiles after analysis */
.goal-window-tag{display:flex;flex-direction:column;align-items:center;gap:4px;margin-top:4px;padding-top:6px;border-top:1px solid rgba(var(--gold-rgb),0.18);width:100%}
/* Active window: gold left border on the parent tile */
.goal-tile:has(.goal-window-tag--active){border-left:3px solid var(--gold)}
.goal-window-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:3px;width:100%}
.goal-window-range{font-family:'DM Sans',sans-serif;font-size:10px;color:var(--sage);font-weight:500;line-height:1.2}
.goal-window-dot{font-size:10px;color:var(--text-muted)}
.goal-window-dist{font-family:'Cinzel',serif;font-size:9px;color:rgba(var(--gold-rgb),0.75);text-transform:uppercase;letter-spacing:0.04em}
/* NOW pill — appears when the window is currently active */
.goal-window-now{font-family:'Cinzel',serif;font-size:8px;font-weight:700;color:#fff;background:var(--gold);border-radius:var(--r-pill);padding:1px 6px;letter-spacing:0.06em;text-transform:uppercase;line-height:1.5}
/* One-sentence reason — muted text, wraps naturally */
.goal-window-reason{font-family:'DM Sans',sans-serif;font-size:10px;color:var(--text-muted);line-height:1.4;text-align:center;padding:0 4px}
@media(prefers-reduced-motion:reduce){.goal-tile{transition:none}}
.goals-save-row{padding:18px 16px 6px}
.goals-save-btn{width:100%}
.goals-note{text-align:center;font-size:var(--text-sm);color:var(--text-muted);padding:4px 20px 24px;font-family:'DM Sans',sans-serif;line-height:1.5}
.sub-panel-desc{font-size:12px;color:var(--text-muted);margin-bottom:14px}
.sub-panel-desc-dim{font-size:12px;color:var(--text-dim);margin-bottom:16px;line-height:1.7}
.sub-panel-note{font-size:var(--text-sm);color:var(--text-muted);margin-bottom:10px;text-align:center}
.sub-panel-desc-lg{font-size:12px;color:var(--text-muted);margin:14px 0 10px;text-align:center}
.blueprint-hero-pad{padding:36px 0 28px}
.blueprint-hero-icon{position:relative;width:76px;height:76px;margin:0 auto 20px;display:flex;align-items:center;justify-content:center}
.blueprint-hero-svg{position:absolute;animation:mandala-spin 50s linear infinite;opacity:0.3}
.blueprint-hero-symbol{font-size:20px;position:relative;z-index:1;animation:pulse-soft 4s ease-in-out infinite;filter:drop-shadow(0 0 10px rgba(201,150,58,0.5))}
.hero-pb-20{padding-bottom:20px}
.d-coords{color:var(--text-muted);font-size:var(--text-sm);margin-top:4px}
#k-tz{margin-bottom:4px}
#k-ayanamsa{margin-bottom:12px;font-size:var(--text-base)}

/* ── Blueprint deep tool collapsible sections ───────────────────────────── */
.bp-tools-wrap{padding:4px 0 80px}
.bp-tools-heading{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:2px;color:var(--text-muted);text-align:center;padding:16px 16px 4px}
.bp-tools-sub{font-size:var(--text-sm);color:var(--text-muted);text-align:center;padding:0 16px 14px}
.bp-sec{margin:0 16px 8px;border:1px solid var(--border-md);border-radius:var(--r-sm);background:var(--surface);overflow:hidden}
.bp-sec-hdr{width:100%;display:flex;align-items:center;gap:12px;padding:14px 16px;background:none;border:none;cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent}
.bp-sec-hdr:active{background:var(--bg2)}
.bp-sec-icon{font-size:18px;flex-shrink:0;width:28px;text-align:center}
.bp-sec-text{flex:1;min-width:0}
.bp-sec-title{display:block;font-family:'Cinzel',serif;font-size:12px;letter-spacing:0.04em;color:var(--ink);font-weight:500}
.bp-sec-sub{display:block;font-size:var(--text-sm);color:var(--text-muted);margin-top:2px;line-height:1.4}
.bp-sec-arrow{font-size:20px;color:var(--gold);flex-shrink:0;transition:transform 0.2s;line-height:1;font-weight:300}
.bp-sec-body{display:none;padding:0 16px 16px;border-top:1px solid var(--border)}
.bp-sec-body.open{display:block}
.bp-sec-loader{margin:14px 0 4px}

/* ══════════════════════════════════════════════
   NUMEROLOGY — Blueprint deep-dive card
   ══════════════════════════════════════════════ */
.num-card{padding:4px 0 8px}
.num-card-header{padding:12px 2px 14px;border-bottom:1px solid var(--border)}
.num-card-title{font-family:'Cinzel',serif;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);display:block}
.num-card-sub{font-family:'DM Sans',sans-serif;font-size:11px;color:var(--text-muted);display:block;margin-top:3px}
.num-row{display:flex;align-items:flex-start;gap:12px;padding:12px 2px;border-bottom:1px solid rgba(0,0,0,0.05)}
.num-row:last-of-type{border-bottom:none}
.num-label{font-family:'Cinzel',serif;font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-muted);width:80px;flex-shrink:0;padding-top:3px;line-height:1.4}
.num-chip{font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:600;color:var(--gold);background:rgba(var(--gold-rgb),0.08);border:1px solid rgba(var(--gold-rgb),0.2);border-radius:var(--r-tag);width:44px;height:44px;display:flex;align-items:center;justify-content:center;flex-shrink:0;line-height:1}
.num-chip--master{background:rgba(var(--dusk-rgb),0.1);border-color:rgba(var(--dusk-rgb),0.3);color:var(--dusk)}
.num-keyword{font-family:'Cinzel',serif;font-size:11px;letter-spacing:0.5px;color:var(--ink);font-weight:500}
.num-desc{font-family:'DM Sans',sans-serif;font-size:11px;color:var(--text-muted);margin-top:3px;line-height:1.5}
.num-extra{font-family:'DM Sans',sans-serif;font-size:10px;color:var(--text-muted);margin-top:3px;font-style:italic;line-height:1.4}
.num-footer{font-family:'DM Sans',sans-serif;font-size:10px;color:var(--text-muted);padding:10px 2px 4px;line-height:1.5;border-top:1px solid var(--border);margin-top:6px}

/* ── Today tab collapsible sections ────────────────────────────────────── */
.today-cols-wrap{padding-bottom:4px}
.today-cols-heading{font-family:'Cinzel',serif;font-size:var(--text-sm);letter-spacing:2px;color:var(--text-muted);text-align:center;padding:12px 16px 10px}
.today-col-sec{margin:0 16px 8px;border:1px solid var(--border-md);border-radius:var(--r-sm);background:var(--surface);overflow:hidden}
.today-col-hdr{width:100%;display:flex;align-items:center;gap:12px;padding:13px 16px;background:none;border:none;cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent}
.today-col-hdr:active{background:var(--bg2)}
.tcs-icon{font-size:18px;flex-shrink:0;width:24px;text-align:center}
.tcs-text{flex:1;min-width:0}
.tcs-title{display:block;font-family:'Cinzel',serif;font-size:12px;letter-spacing:0.04em;color:var(--ink);font-weight:500}
.tcs-sub{display:block;font-size:var(--text-sm);color:var(--text-muted);margin-top:2px}
.tcs-arrow{font-size:20px;color:var(--gold);flex-shrink:0;transition:transform 0.2s;line-height:1;font-weight:300}
.today-col-body{display:none;padding:0 16px 16px;border-top:1px solid var(--border)}
.today-col-body.open{display:block}

/* ── Timeline collapsible sections ─────────────────────────────────────── */
.timeline-col-sec{margin:0 16px 8px;border:1px solid var(--border-md);border-radius:var(--r-sm);background:var(--surface);overflow:hidden}
.timeline-col-hdr{width:100%;display:flex;align-items:center;gap:12px;padding:14px 16px;background:none;border:none;cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent}
.timeline-col-hdr:active{background:var(--bg2)}
.tlcs-icon{font-size:18px;flex-shrink:0;width:24px;text-align:center}
.tlcs-text{flex:1;min-width:0}
.tlcs-title{display:block;font-family:'Cinzel',serif;font-size:12px;letter-spacing:0.04em;color:var(--ink);font-weight:500}
.tlcs-sub{display:block;font-size:var(--text-sm);color:var(--text-muted);margin-top:2px}
.tlcs-arrow{font-size:20px;color:var(--gold);flex-shrink:0;transition:transform 0.2s;line-height:1;font-weight:300}
.timeline-col-body{display:none;padding:0 16px 16px;border-top:1px solid var(--border)}
.timeline-col-body.open{display:block}

/* ── Ask prompt chips ───────────────────────────────────────────────────── */
.ask-prompt-chips{display:flex;gap:8px;padding:6px 16px 4px;flex-wrap:wrap}
.ask-prompt-chip{background:var(--surface);border:1px solid var(--border-md);border-radius:var(--r-pill);padding:7px 14px;font-size:12px;color:var(--ink2);cursor:pointer;font-family:'DM Sans',sans-serif;transition:border-color 0.15s,color 0.15s;white-space:nowrap;-webkit-tap-highlight-color:transparent}
.ask-prompt-chip:active{border-color:var(--gold);color:var(--gold)}

/* ── Placeholder panels (YOU, DIVE) ────────────────────────────────────── */
.panel-coming-soon{display:flex;align-items:center;justify-content:center;height:100%}
.panel-coming-soon-text{font-family:'Cinzel',serif;font-size:var(--text-sm);color:var(--text-muted);letter-spacing:1px}

/* ═══════════════════════════════════════════════════════════════════════════
   YOU TAB — panel-you
   7 sections: identity · phase-bridge · traits · shadows · arc · remedies · life
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Panel baseline ── */
#panel-you{padding-bottom:88px}

/* ── Loader ── */
.you-loader{
  display:none;
  flex-direction:column;align-items:center;justify-content:center;
  min-height:40vh;gap:16px;padding:40px 20px;
}
.you-loader-ring{
  width:36px;height:36px;
  border:2px solid var(--border);border-top-color:var(--gold);
  border-radius:50%;
  animation:spin 0.9s linear infinite;
}
.you-loader-text{
  font-family:'DM Sans',sans-serif;font-size:var(--text-sm);
  color:var(--text-muted);
}

/* ── Empty state ── */
.you-empty{
  display:none;
  flex-direction:column;align-items:center;justify-content:center;
  min-height:52vh;gap:16px;padding:32px 24px;text-align:center;
}
.you-empty-icon{font-size:38px;color:var(--gold);opacity:0.35;line-height:1}
.you-empty-title{
  font-family:'Cinzel',serif;font-size:var(--text-sm);
  color:var(--text-muted);letter-spacing:0.5px;
}
.you-empty-btn{margin-top:4px}

/* ── Sign-in gate ── */
.you-signin{
  display:none;
  flex-direction:column;align-items:center;justify-content:center;
  min-height:52vh;gap:14px;padding:32px 24px;text-align:center;
}
.you-signin-sub{
  font-size:var(--text-xs);color:var(--text-muted);
  max-width:260px;line-height:1.6;
}

/* ── Content wrapper ── */
.you-content{display:none;padding:0 16px 8px}

/* ── Section 1: Identity paragraph ── */
.you-identity{
  padding:22px 0 18px;
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(17px,4.8vw,21px);
  line-height:1.68;
  color:var(--text);
  font-weight:400;
  font-style:italic;
}

/* ── Section 2: Phase bridge card ── */
.you-phase-bridge{
  background:linear-gradient(135deg,rgba(var(--gold-rgb),0.09),rgba(var(--gold-rgb),0.04));
  border:1px solid rgba(var(--gold-rgb),0.22);
  border-radius:var(--r-card);
  padding:18px 20px;
  margin-bottom:30px;
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(15px,4.2vw,18px);
  line-height:1.65;
  color:var(--text);
}

/* ── Section wrapper ── */
.you-section{margin-bottom:30px}
.you-section-title{
  font-family:'Cinzel',serif;
  font-size:10px;font-weight:500;letter-spacing:1.6px;
  color:var(--text-muted);
  margin-bottom:14px;padding-bottom:8px;
  border-bottom:1px solid var(--border);
}

/* ── Trait / Shadow card grid ── */
.you-cards{display:flex;flex-direction:column;gap:12px}

.you-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-card);
  padding:18px 16px 14px;
  position:relative;
}

/* Share button — top-right; hidden until past fold */
.you-share-btn{
  position:absolute;top:14px;right:14px;
  font-family:'DM Sans',sans-serif;font-size:11px;
  color:var(--text-muted);
  background:none;border:1px solid var(--border);
  border-radius:var(--r-pill);padding:3px 10px;
  cursor:pointer;
  transition:border-color var(--dur-fast),color var(--dur-fast);
  -webkit-tap-highlight-color:transparent;
}
.you-share-btn:hover,.you-share-btn:focus-visible{border-color:var(--gold);color:var(--gold)}
.you-share--hidden{display:none}

.you-card-headline{
  font-family:'Cinzel',serif;
  font-size:12px;font-weight:500;letter-spacing:0.8px;
  color:var(--text);
  margin-bottom:8px;
  padding-right:64px; /* leave room for share btn */
}
.you-card-desc{
  font-family:'DM Sans',sans-serif;font-size:14px;line-height:1.62;
  color:var(--text-dim);margin-bottom:12px;
}
.you-card-timing{
  font-family:'DM Sans',sans-serif;font-size:13px;line-height:1.5;
  color:var(--text-muted);font-style:italic;margin-bottom:10px;
}

/* Activation state dot + label */
.you-act{
  display:inline-flex;align-items:center;gap:6px;
  font-family:'Cinzel',serif;font-size:10px;letter-spacing:0.4px;
  margin-bottom:12px;
}
.you-act-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.you-act--gold{color:var(--gold)} .you-act--gold .you-act-dot{background:var(--gold)}
.you-act--sage{color:var(--sage)} .you-act--sage .you-act-dot{background:var(--sage)}
.you-act--dusk{color:var(--dusk)} .you-act--dusk .you-act-dot{background:var(--dusk)}
.you-act--rose{color:var(--rose)} .you-act--rose .you-act-dot{background:var(--rose)}

/* Citation toggle row */
.you-card-footer{margin-top:2px}
.you-cite-btn{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;
  background:none;border:none;padding:6px 0;
  cursor:pointer;-webkit-tap-highlight-color:transparent;
  font-family:'Cinzel',serif;font-size:10px;letter-spacing:0.3px;
  color:var(--text-muted);
  transition:color var(--dur-fast);
  text-align:left;
}
.you-cite-btn:hover,.you-cite-btn:focus-visible{color:var(--gold)}
.you-cite-meta{flex:1;margin-right:8px}
.you-cite-arrow{
  font-size:9px;flex-shrink:0;
  transition:transform var(--dur-base) var(--ease-std);
}

/* Collapsed citation body */
.you-cite-body{padding:8px 0 4px}
.you-cite-text{
  font-family:'Cinzel',serif;font-size:10px;letter-spacing:0.3px;
  color:var(--text-muted);line-height:1.55;
  padding:8px 12px;
  background:var(--bg2);border-radius:var(--r-inner);
}

/* Depth toggle button */
.you-depth-btn{
  display:block;width:100%;text-align:left;
  background:none;border:none;padding:6px 0 2px;
  cursor:pointer;-webkit-tap-highlight-color:transparent;
  font-family:'DM Sans',sans-serif;font-size:12px;
  color:var(--text-muted);
  transition:color var(--dur-fast);
}
.you-depth-btn:hover,.you-depth-btn:focus-visible{color:var(--gold)}

/* ── Section 5: THE LONGER ARC ── */
.you-arc-para{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(16px,4.2vw,19px);line-height:1.72;
  color:var(--text);margin-bottom:18px;
}
.you-arc-line{
  font-family:'Cinzel',serif;font-size:11px;letter-spacing:0.8px;
  color:var(--text-muted);
  border-left:2px solid var(--gold);
  padding-left:14px;line-height:1.5;
}

/* ── Section 6: WHAT SUPPORTS YOU (remedies) ── */
.you-remedies{display:flex;flex-direction:column;gap:14px}

.you-rem-card{
  background:var(--surface2);
  border:1px solid var(--border);
  border-radius:var(--r-card);
  padding:16px 16px 14px;
}
.you-rem-header{
  display:flex;align-items:center;gap:8px;
  margin-bottom:10px;
}
.you-rem-planet{
  font-family:'Cinzel',serif;font-size:12px;font-weight:500;
  letter-spacing:0.8px;color:var(--gold);
}
.you-rem-badge{
  font-family:'Cinzel',serif;font-size:9px;letter-spacing:0.5px;
  background:rgba(var(--gold-rgb),0.1);color:var(--gold);
  border-radius:var(--r-tag);padding:2px 7px;
}
.you-rem-reason{
  font-family:'DM Sans',sans-serif;font-size:14px;line-height:1.62;
  color:var(--text-dim);margin-bottom:12px;
}
.you-rem-gem{
  font-family:'DM Sans',sans-serif;font-size:13px;line-height:1.55;
  color:var(--text-dim);
  background:rgba(var(--gold-rgb),0.06);
  border-radius:var(--r-inner);padding:10px 12px;
  margin-bottom:10px;
}
.you-rem-gem-name{font-weight:500;color:var(--gold)}
.you-rem-avoid{
  font-family:'DM Sans',sans-serif;font-size:13px;line-height:1.55;
  color:var(--rose);
  background:rgba(var(--rose-rgb),0.06);
  border-radius:var(--r-inner);padding:10px 12px;
  margin-bottom:10px;
}
.you-rem-support{
  font-family:'DM Sans',sans-serif;font-size:12px;line-height:1.5;
  color:var(--text-muted);font-style:italic;margin-bottom:8px;
}
.you-rem-instruction{
  font-family:'Cinzel',serif;font-size:10px;letter-spacing:0.5px;
  color:var(--text-muted);line-height:1.5;
  margin-top:6px;
}

/* ── Section 7: MY LIFE ── */
.you-life-facts{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.you-life-fact{
  display:flex;align-items:flex-start;gap:10px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  padding:12px 14px;
  font-family:'DM Sans',sans-serif;font-size:13px;line-height:1.55;
  color:var(--text-dim);
}
.you-life-dot{
  width:6px;height:6px;border-radius:50%;background:var(--sage);
  margin-top:5px;flex-shrink:0;
}

.you-life-cta{display:flex;flex-direction:column;align-items:center;gap:10px;padding:8px 0 4px}
.you-life-cta-text{
  font-family:'Cormorant Garamond',serif;font-size:15px;
  color:var(--text-muted);font-style:italic;
}

.you-life-empty{
  display:flex;flex-direction:column;align-items:center;
  gap:14px;padding:20px 0 8px;text-align:center;
}
.you-life-empty-text{
  font-family:'Cormorant Garamond',serif;font-size:16px;
  color:var(--text-muted);font-style:italic;line-height:1.5;
}

.you-life-ask-btn{
  font-family:'DM Sans',sans-serif;font-size:13px;
  background:none;
  border:1px solid var(--gold);color:var(--gold);
  border-radius:var(--r-pill);padding:8px 22px;
  cursor:pointer;
  transition:background var(--dur-fast);
  -webkit-tap-highlight-color:transparent;
}
.you-life-ask-btn:hover,.you-life-ask-btn:focus-visible{
  background:rgba(var(--gold-rgb),0.07);
}

/* ── MY LIFE dialogue cards (chart hypothesis × user fact × dasha verdict) ── */
.you-life-loading{
  display:flex;flex-direction:column;align-items:center;
  gap:12px;padding:24px 0;
}
.you-life-loading-text{
  font-family:'Cormorant Garamond',serif;font-size:14px;font-style:italic;
  color:var(--text-muted);text-align:center;
}

.you-life-cards{
  display:flex;flex-direction:column;gap:12px;margin-bottom:14px;
}
.you-life-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-card);
  padding:14px 16px 12px;
  display:flex;flex-direction:column;gap:10px;
}
.you-life-card-text{
  font-family:'Cormorant Garamond',serif;
  font-size:16px;line-height:1.45;
  color:var(--ink);
  margin:0;
}

.you-life-verdict{
  display:inline-flex;align-items:center;gap:6px;
  align-self:flex-start;
  font-family:'Cinzel',serif;
  font-size:10px;letter-spacing:0.08em;text-transform:uppercase;
  padding:4px 10px;
  border-radius:var(--r-pill);
  border:1px solid;
}
.you-life-verdict-dot{
  width:6px;height:6px;border-radius:50%;flex-shrink:0;
}
.you-life-verdict-label{line-height:1;}

.you-life-verdict--sage{
  background:rgba(var(--sage-rgb),0.10);
  border-color:rgba(var(--sage-rgb),0.45);
  color:var(--sage);
}
.you-life-verdict--sage .you-life-verdict-dot{ background:var(--sage); }

.you-life-verdict--gold{
  background:rgba(var(--gold-rgb),0.10);
  border-color:rgba(var(--gold-rgb),0.45);
  color:var(--gold-dim,var(--gold));
}
.you-life-verdict--gold .you-life-verdict-dot{ background:var(--gold); }

.you-life-verdict--rose{
  background:rgba(var(--rose-rgb),0.10);
  border-color:rgba(var(--rose-rgb),0.45);
  color:var(--rose);
}
.you-life-verdict--rose .you-life-verdict-dot{ background:var(--rose); }

.you-life-verdict--dusk{
  background:rgba(var(--dusk-rgb),0.10);
  border-color:rgba(var(--dusk-rgb),0.45);
  color:var(--dusk);
}
.you-life-verdict--dusk .you-life-verdict-dot{ background:var(--dusk); }

.you-life-card-lens{
  font-family:'DM Sans',sans-serif;
  font-size:13px;line-height:1.55;
  color:var(--text-dim);
  margin:0;
}

.you-life-card-ask{
  align-self:flex-start;
  font-family:'DM Sans',sans-serif;
  font-size:12px;
  background:none;border:none;
  color:var(--gold);
  padding:2px 0;margin-top:2px;
  cursor:pointer;
  -webkit-tap-highlight-color:transparent;
}
.you-life-card-ask:hover,.you-life-card-ask:focus-visible{
  text-decoration:underline;
  outline:none;
}

/* ── Reduced motion ─────────────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   DIVE TAB — panel-dive
   Cards show personal data before tap. No generic labels.
   ═══════════════════════════════════════════════════════════════ */

/* ── Tooltip ───────────────────────────────────────────────────────────── */
.dive-tooltip{display:none;align-items:center;gap:10px;background:var(--surface);border:1px solid rgba(var(--gold-rgb),0.3);border-radius:var(--r-chip);padding:12px 14px;margin:0 0 16px;font-family:'DM Sans',sans-serif;font-size:var(--text-base);color:var(--ink2);line-height:1.5;animation:panelIn var(--dur-slow) var(--ease-spring)}
.dive-tooltip-close{background:none;border:none;color:var(--ink4);font-size:16px;cursor:pointer;line-height:1;padding:2px 4px;flex-shrink:0;margin-left:auto}

/* ── Empty state ───────────────────────────────────────────────────────── */
.dive-empty{display:none;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;gap:12px;text-align:center;min-height:60vh}
.dive-empty-icon{font-size:40px;color:var(--ink4);margin-bottom:4px}
.dive-empty-title{font-family:'Cinzel',serif;font-size:var(--text-base);color:var(--ink);letter-spacing:1px}
.dive-empty-sub{font-family:'DM Sans',sans-serif;font-size:var(--text-base);color:var(--ink3);margin-bottom:8px}

/* ── Content wrapper ───────────────────────────────────────────────────── */
.dive-content{padding:0 16px 24px}

/* ── Sections ──────────────────────────────────────────────────────────── */
.dive-section{margin-bottom:28px}
.dive-section-hd{display:flex;align-items:baseline;gap:10px;margin-bottom:10px}
.dive-section-label{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:3px;color:var(--gold);text-transform:uppercase}
.dive-section-sub{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink4)}

/* ── Two-column grid ───────────────────────────────────────────────────── */
.dive-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* ── Base card ─────────────────────────────────────────────────────────── */
.dive-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-card);padding:16px;cursor:pointer;position:relative;display:flex;flex-direction:column;gap:8px;transition:background var(--dur-fast),transform var(--dur-fast),box-shadow var(--dur-fast);-webkit-tap-highlight-color:transparent;user-select:none;overflow:hidden;min-height:120px}
.dive-card:hover,.dive-card:focus-visible{background:var(--bg2);outline:none}
.dive-card:active{transform:scale(0.98);background:var(--bg2)}
.dive-card:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
.dive-card--half{min-height:140px}
.dive-card--hero{border:1px solid rgba(var(--gold-rgb),0.28);background:linear-gradient(135deg,var(--surface) 0%,rgba(var(--gold-rgb),0.04) 100%)}
.dive-card--coming{cursor:default;opacity:0.75;pointer-events:none}
.dive-card--coming:hover,.dive-card--coming:active{background:var(--surface);transform:none}

/* ── Card elements ─────────────────────────────────────────────────────── */
.dive-card-eyebrow{font-family:'Cinzel',serif;font-size:9px;letter-spacing:2.5px;color:var(--gold);text-transform:uppercase;line-height:1.2}
.dive-card-body-text{font-family:'DM Sans',sans-serif;font-size:13px;color:var(--ink2);line-height:1.5}
.dive-card-meta{font-family:'DM Sans',sans-serif;font-size:11px;color:var(--ink4);line-height:1.4}
.dive-card-prompt{font-family:'Cormorant Garamond',serif;font-size:16px;color:var(--ink2);line-height:1.45}
.dive-card-cta{font-family:'Cinzel',serif;font-size:10px;letter-spacing:1px;color:var(--gold);display:block;margin-top:auto}

/* ── Status loading placeholder ────────────────────────────────────────── */
.dive-status-loading{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink4);font-style:italic}

/* ── Status dots (Mars card) ───────────────────────────────────────────── */
.dive-status-row{display:flex;align-items:center;gap:8px}
.dive-status-dot{font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;line-height:1}
.dive-status-dot--lg{font-size:18px}
.dive-status--present{color:var(--rose)}
.dive-status--clear{color:var(--sage)}

/* ── Hero match avatars ────────────────────────────────────────────────── */
.dive-match-avatars{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.dive-avatar{width:44px;height:44px;border-radius:50%;border:1.5px solid var(--border-md);background:var(--bg2);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.dive-avatar--you{border-color:rgba(var(--gold-rgb),0.4);background:var(--gold-bg)}
.dive-avatar--them{border-style:dashed}
.dive-avatar-initial{font-family:'Cinzel',serif;font-size:16px;color:var(--gold);font-weight:600}
.dive-avatar-arc{display:flex;align-items:center}

/* ── Match result state ────────────────────────────────────────────────── */
.dive-match-result{display:flex;flex-direction:column;gap:4px}
.dive-match-result-name{font-family:'Cinzel',serif;font-size:var(--text-sm);color:var(--gold);letter-spacing:1px}
.dive-match-result-summary{font-family:'DM Sans',sans-serif;font-size:var(--text-base);color:var(--ink2)}

/* ── Mini chart wheel ──────────────────────────────────────────────────── */
.dive-mini-wheel{border-radius:var(--r-xs);overflow:hidden;margin:2px 0;max-height:130px;display:flex;align-items:center}
.dive-mini-wheel svg{width:100%!important;height:auto;display:block}

/* ── Planet preview rows (card) ────────────────────────────────────────── */
.dive-planets-preview{display:flex;flex-direction:column;gap:5px}
.dive-planet-row{display:flex;align-items:center;gap:6px}
.dive-planet-icon{font-size:13px;width:16px;flex-shrink:0;text-align:center}
.dive-planet-name{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink2);font-weight:500;min-width:40px}
.dive-planet-place{font-family:'DM Sans',sans-serif;font-size:11px;color:var(--ink4);margin-left:auto}

/* ── Yoga preview ──────────────────────────────────────────────────────── */
.dive-yogas-preview{display:flex;flex-direction:column;gap:6px}
.dive-yoga-top{display:flex;flex-direction:column;gap:3px}
.dive-yoga-name{font-family:'DM Sans',sans-serif;font-size:13px;color:var(--ink2);font-weight:500;line-height:1.3}
.dive-yoga-dot--active{font-family:'DM Sans',sans-serif;font-size:11px;color:var(--sage)}

/* ── Numerology preview ────────────────────────────────────────────────── */
.dive-num-preview-inner{display:flex;align-items:baseline;gap:6px;margin-bottom:2px}
.dive-num-number{font-family:'Cormorant Garamond',serif;font-size:32px;color:var(--gold);line-height:1}
.dive-num-label{font-family:'Cinzel',serif;font-size:9px;letter-spacing:2px;color:var(--ink4);text-transform:uppercase}

/* ── Ashtakvarga preview ───────────────────────────────────────────────── */
.dive-av-score-row{display:flex;align-items:baseline;gap:2px}
.dive-av-number{font-family:'Cormorant Garamond',serif;font-size:30px;color:var(--gold);line-height:1}
.dive-av-denom{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink4)}

/* ── Coming soon badge ─────────────────────────────────────────────────── */
.dive-coming-badge{display:inline-block;font-family:'Cinzel',serif;font-size:9px;letter-spacing:1.5px;color:var(--ink4);text-transform:uppercase;border:1px solid var(--border);border-radius:var(--r-xs);padding:3px 8px;margin-top:auto;align-self:flex-start}

/* ═══════════════════════════════════════════════════════════════
   DIVE — DETAIL OVERLAYS
   ═══════════════════════════════════════════════════════════════ */
.dive-detail{position:fixed;top:var(--nav-h);left:0;right:0;bottom:var(--bottom-nav-h);background:var(--bg);z-index:600;display:flex;flex-direction:column;transform:translateX(100%);transition:transform var(--dur-slow) var(--ease-slide);overflow:hidden;pointer-events:none}
.dive-detail--open{transform:translateX(0);pointer-events:all}

.dive-detail-header{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);background:rgba(var(--bg-rgb),0.97);backdrop-filter:blur(16px);flex-shrink:0;position:sticky;top:0;z-index:10}
.dive-detail-back{background:none;border:none;font-size:22px;cursor:pointer;color:var(--gold);padding:4px 8px 4px 0;line-height:1;display:flex;align-items:center}
.dive-detail-title{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:2.5px;color:var(--ink);text-transform:uppercase}
.dive-detail-body{flex:1;overflow-y:auto;padding:20px 16px 32px;overscroll-behavior:contain}

/* ── Detail content layout ─────────────────────────────────────────────── */
.dive-detail-section{display:flex;flex-direction:column;gap:16px}
.dive-detail-intro{font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--ink2);line-height:1.6}
.dive-detail-note{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink4);line-height:1.5}
.dive-detail-loading{font-family:'DM Sans',sans-serif;font-size:var(--text-base);color:var(--ink4);font-style:italic;padding:24px 0;text-align:center}
.dive-detail-sub-hd{font-family:'Cinzel',serif;font-size:10px;letter-spacing:2px;color:var(--ink3);text-transform:uppercase;padding-top:4px}

/* Detail box (card-within-detail) */
.dive-detail-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-inner);padding:14px 16px}
.dive-detail-box--sage{background:rgba(var(--sage-rgb),0.07);border-color:rgba(var(--sage-rgb),0.25)}
.dive-detail-box--premium{background:var(--gold-bg);border-color:rgba(var(--gold-rgb),0.25)}
.dive-detail-box-title{font-family:'Cinzel',serif;font-size:10px;letter-spacing:2px;color:var(--gold);text-transform:uppercase;margin-bottom:8px}
.dive-detail-box p{font-family:'DM Sans',sans-serif;font-size:var(--text-base);color:var(--ink2);line-height:1.6}

/* ── Match compatibility dims ──────────────────────────────────────────── */
.dive-verdict{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-inner);padding:14px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.dive-verdict--strong{border-color:rgba(var(--sage-rgb),0.4);background:rgba(var(--sage-rgb),0.06)}
.dive-verdict--moderate{border-color:rgba(var(--gold-rgb),0.3);background:rgba(var(--gold-rgb),0.05)}
.dive-verdict--weak{border-color:rgba(var(--rose-rgb),0.3);background:rgba(var(--rose-rgb),0.05)}
.dive-verdict-label{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:1px;color:var(--ink)}
.dive-verdict-score{font-family:'Cormorant Garamond',serif;font-size:20px;color:var(--gold)}
.dive-compat-dims{display:flex;flex-direction:column;gap:16px}
.dive-compat-dim{display:flex;flex-direction:column;gap:6px}
.dive-compat-dim-hd{display:flex;align-items:center;justify-content:space-between}
.dive-compat-dim-label{font-family:'DM Sans',sans-serif;font-size:13px;color:var(--ink2);font-weight:500}
.dive-compat-dim-score{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink4)}
.dive-compat-bar-track{height:3px;background:var(--bg3);border-radius:2px;overflow:hidden}
.dive-compat-bar-fill{height:100%;background:var(--gold);border-radius:2px;transition:width 0.6s var(--ease-slide)}
.dive-compat-dim-desc{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink3);line-height:1.5}
.dive-timing-note{background:var(--bg2);border-radius:var(--r-inner);padding:14px 16px;display:flex;gap:12px;align-items:flex-start}
.dive-timing-icon{font-size:16px;flex-shrink:0;margin-top:1px}
.dive-timing-note p{font-family:'DM Sans',sans-serif;font-size:var(--text-base);color:var(--ink2);line-height:1.6}
.dive-dosha-block{display:flex;flex-direction:column;gap:10px}
.dive-dosha-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xs);padding:12px 14px}
.dive-dosha-item--high{border-color:rgba(var(--rose-rgb),0.35)}
.dive-dosha-item--medium{border-color:rgba(var(--gold-rgb),0.3)}
.dive-dosha-name{font-family:'Cinzel',serif;font-size:10px;letter-spacing:1.5px;color:var(--ink);text-transform:uppercase;display:block;margin-bottom:6px}
.dive-dosha-desc{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink3);line-height:1.5}
.dive-share-btn{background:var(--gold-bg);border:1px solid rgba(var(--gold-rgb),0.35);border-radius:var(--r-pill);padding:12px 20px;font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:1px;color:var(--gold);cursor:pointer;width:100%;text-align:center;transition:background var(--dur-fast)}
.dive-share-btn:hover,.dive-share-btn:active{background:rgba(var(--gold-rgb),0.15)}

/* ── Match form ────────────────────────────────────────────────────────── */
.dive-form{display:flex;flex-direction:column;gap:14px}
.dive-form-group{display:flex;flex-direction:column;gap:5px;position:relative}
.dive-form-label{font-family:'Cinzel',serif;font-size:var(--text-xs);letter-spacing:1.5px;color:var(--ink3);text-transform:uppercase}
.dive-form-optional{font-family:'DM Sans',sans-serif;font-size:10px;color:var(--ink4);letter-spacing:0;text-transform:none}
.dive-form-input{background:var(--surface);border:1px solid var(--border-md);border-radius:var(--r-sm);padding:11px 14px;font-family:'DM Sans',sans-serif;font-size:var(--text-base);color:var(--ink);width:100%;transition:border-color var(--dur-fast)}
.dive-form-input:focus{outline:none;border-color:var(--gold)}
.dive-form-error{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--rose);padding:8px 12px;background:rgba(var(--rose-rgb),0.08);border-radius:var(--r-xs);border:1px solid rgba(var(--rose-rgb),0.2)}

/* ── Mars detail ───────────────────────────────────────────────────────── */
.dive-mars-status-block{display:flex;align-items:center;gap:12px;padding:4px 0}
.dive-mars-sev{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink4);text-transform:capitalize}
.dive-cancel-list{list-style:none;display:flex;flex-direction:column;gap:6px;margin:0;padding:0}
.dive-cancel-list li{font-family:'DM Sans',sans-serif;font-size:var(--text-base);color:var(--ink2);padding-left:16px;position:relative;line-height:1.5}
.dive-cancel-list li::before{content:'✓';position:absolute;left:0;color:var(--sage)}

/* ── Wheel detail ──────────────────────────────────────────────────────── */
.dive-detail-wheel{border-radius:var(--r-inner);overflow:hidden}
.dive-detail-wheel svg{width:100%!important;height:auto;display:block}
.dive-planet-list{display:flex;flex-direction:column;gap:0}
.dive-table{width:100%;border-collapse:collapse;font-size:13px;font-family:'DM Sans',sans-serif}
.dive-table th{text-align:left;padding:6px 8px;color:var(--ink3);font-size:11px;letter-spacing:.5px;border-bottom:1px solid var(--border);font-weight:600}
.dive-table td{padding:8px 8px;border-bottom:1px solid var(--border);color:var(--ink1)}
.dive-planet-row-detail{border-bottom:1px solid var(--border)}
.dive-planet-row-detail:last-child{border-bottom:none}
.dive-planet-row-sum{display:flex;align-items:center;gap:8px;padding:12px 4px;cursor:pointer;list-style:none;font-family:'DM Sans',sans-serif}
.dive-planet-row-sum::-webkit-details-marker{display:none}
.dive-planet-row-name{font-size:var(--text-base);color:var(--ink);font-weight:500;min-width:72px}
.dive-planet-row-place{font-size:13px;color:var(--ink3)}
.dive-planet-row-dig{font-size:12px;color:var(--ink4);margin-left:auto;text-transform:capitalize}
.dive-planet-row-body{padding:0 4px 12px;display:flex;flex-direction:column;gap:6px}
.dive-planet-row-body p{font-family:'DM Sans',sans-serif;font-size:var(--text-base);color:var(--ink2);line-height:1.6}
.dive-ptags{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.dive-ptag{font-family:'DM Sans',sans-serif;font-size:11px;color:var(--ink3);background:var(--bg2);border-radius:var(--r-xs);padding:2px 8px}
.dive-ptag--retro{color:var(--dusk);background:var(--dusk-bg)}
.dive-ptag--combust{color:var(--rose);background:rgba(var(--rose-rgb),0.08)}

/* ── Vargas (Deeper Charts) detail ─────────────────────────────────────── */
.dive-varga-block{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-inner);padding:14px 16px;display:flex;flex-direction:column;gap:8px}
.dive-varga-loading{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink4);font-style:italic;padding:8px 0}
.dive-varga-wheel{border-radius:var(--r-xs);overflow:hidden}
.dive-varga-wheel svg{width:100%!important;height:auto;display:block}
.dive-premium-list{list-style:none;margin:8px 0 12px;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:4px}
.dive-premium-list li{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink3);padding:2px 0}

/* ── Yoga list detail ──────────────────────────────────────────────────── */
.dive-yoga-list{display:flex;flex-direction:column;gap:12px}
.dive-yoga-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-inner);padding:14px 16px;display:flex;flex-direction:column;gap:6px}
.dive-yoga-item-hd{display:flex;align-items:center;justify-content:space-between;gap:8px}
.dive-yoga-item-name{font-family:'DM Sans',sans-serif;font-size:var(--text-base);color:var(--ink);font-weight:500}
.dive-yoga-str{font-family:'DM Sans',sans-serif;font-size:11px;padding:2px 8px;border-radius:var(--r-xs);text-transform:capitalize}
.dive-yoga-str--high{background:rgba(var(--sage-rgb),0.12);color:var(--sage)}
.dive-yoga-str--medium{background:rgba(var(--gold-rgb),0.1);color:var(--gold-dim)}
.dive-yoga-str--low{background:var(--bg2);color:var(--ink4)}

/* ── KP detail ─────────────────────────────────────────────────────────── */
.dive-kp-cusps{display:flex;flex-direction:column;gap:14px}
.dive-kp-cusp{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-inner);padding:14px 16px;display:flex;flex-direction:column;gap:8px}
.dive-kp-cusp-hd{display:flex;align-items:center;gap:8px}
.dive-kp-icon{font-size:16px}
.dive-kp-topic{font-family:'DM Sans',sans-serif;font-size:var(--text-base);color:var(--ink);font-weight:500}
.dive-kp-lords{display:flex;gap:16px;flex-wrap:wrap}
.dive-kp-lords span{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink3)}
.dive-kp-lords strong{color:var(--ink);font-weight:600}
.dive-kp-reading{font-family:'DM Sans',sans-serif;font-size:var(--text-base);color:var(--ink2);line-height:1.6}
.dive-kp-promise{font-family:'DM Sans',sans-serif;font-size:12px;padding:6px 10px;border-radius:var(--r-xs);color:var(--ink3)}
.dive-kp-promise--strong,.dive-kp-promise--positive{background:rgba(var(--sage-rgb),0.1);color:var(--sage)}
.dive-kp-promise--weak,.dive-kp-promise--negative{background:rgba(var(--rose-rgb),0.08);color:var(--rose)}
.dive-kp-promise--moderate,.dive-kp-promise--unknown{background:var(--bg2);color:var(--ink4)}

/* ── Ashtakvarga detail ────────────────────────────────────────────────── */
.dive-av-total-block{text-align:center;padding:8px 0 4px}
.dive-av-total-num{font-family:'Cormorant Garamond',serif;font-size:52px;color:var(--gold);display:block;line-height:1}
.dive-av-total-label{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink4);display:block;margin-top:4px}
.dive-av-planets{display:flex;flex-direction:column;gap:8px}
.dive-av-planet-row{display:grid;grid-template-columns:70px 1fr auto auto;gap:6px;align-items:center;padding:6px 0;border-bottom:1px solid var(--border)}
.dive-av-planet-row:last-child{border-bottom:none}
.dive-av-planet-name{font-family:'DM Sans',sans-serif;font-size:var(--text-base);color:var(--ink);font-weight:500}
.dive-av-planet-place{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink4)}
.dive-av-bindus{font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600}
.dive-av-quality{font-family:'DM Sans',sans-serif;font-size:11px}
.av-strong{color:var(--sage)}
.av-avg{color:var(--ink3)}
.av-weak{color:var(--rose)}
.dive-av-sign-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}
.dive-av-sign-cell{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 4px;border-radius:var(--r-xs);background:var(--bg2)}
.dive-av-sign-cell.av-strong{background:rgba(var(--sage-rgb),0.12)}
.dive-av-sign-cell.av-weak{background:rgba(var(--rose-rgb),0.08)}
.dive-av-sign-abbr{font-family:'DM Sans',sans-serif;font-size:10px;color:var(--ink3)}
.dive-av-sign-score{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;color:var(--ink)}
.dive-av-sign-cell.av-strong .dive-av-sign-score{color:var(--sage)}
.dive-av-sign-cell.av-weak .dive-av-sign-score{color:var(--rose)}

/* ── Lal Kitab detail ──────────────────────────────────────────────────── */
.dive-lk-list{display:flex;flex-direction:column;gap:10px}
.dive-lk-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xs);padding:12px 14px;display:flex;flex-wrap:wrap;align-items:center;gap:6px}
.dive-lk-item--rin{border-color:rgba(var(--dusk-rgb),0.3);background:rgba(var(--dusk-rgb),0.04)}
.dive-lk-planet{font-family:'DM Sans',sans-serif;font-size:var(--text-base);color:var(--ink);font-weight:600}
.dive-lk-house{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink4);margin-left:4px}
.dive-lk-item .dive-detail-note{width:100%;margin-top:4px}
.dive-lk-debt{font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;color:var(--dusk)}
.dive-lk-upayas{display:flex;flex-direction:column;gap:10px}
.dive-lk-upaya{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xs);padding:12px 14px}
.dive-lk-upaya-label{font-family:'DM Sans',sans-serif;font-size:11px;color:var(--ink4);display:block;margin-bottom:4px}

/* ═══════════════════════════════════════════════════════════════════════════
   MUHURTA — Find the Right Moment
   Card preview + detail overlay (event type selector + window list)
   ═══════════════════════════════════════════════════════════════════════════ */

/* Card preview */
.dive-muhurta-next-label{font-family:'DM Sans',sans-serif;font-size:11px;color:var(--ink4);letter-spacing:0.5px;text-transform:uppercase}
.dive-muhurta-next-date{font-family:'Cormorant Garamond',serif;font-size:20px;color:var(--ink);line-height:1.2;font-weight:600}
.dive-muhurta-next-time{font-family:'DM Sans',sans-serif;font-size:13px;color:var(--ink3);margin-top:1px}
.dive-muhurta-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}
.dive-muhurta-tag{font-family:'DM Sans',sans-serif;font-size:10px;color:var(--ink4);background:var(--bg2);border:1px solid var(--border);border-radius:20px;padding:2px 8px}
.dive-muhurta-score-pill{font-family:'DM Sans',sans-serif;font-size:10px;font-weight:600;letter-spacing:0.5px;border-radius:20px;padding:2px 10px;align-self:flex-start;margin-top:4px}
.dive-muhurta-score--strong{background:rgba(var(--sage-rgb),0.15);color:var(--sage)}
.dive-muhurta-score--good{background:rgba(var(--gold-rgb),0.12);color:var(--gold)}
.dive-muhurta-score--moderate{background:var(--bg2);color:var(--ink3)}
.dive-muhurta-score--weaker{background:rgba(var(--rose-rgb),0.08);color:var(--rose)}

/* Event type selector grid */
.muhurta-et-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:20px}
.muhurta-et-btn{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xs);cursor:pointer;font-family:'DM Sans',sans-serif;font-size:13px;color:var(--ink2);text-align:left;transition:background var(--dur-fast),border-color var(--dur-fast);-webkit-tap-highlight-color:transparent}
.muhurta-et-btn:hover{background:var(--bg2)}
.muhurta-et-btn:active{transform:scale(0.97)}
.muhurta-et-btn--active{border-color:rgba(var(--gold-rgb),0.5);background:rgba(var(--gold-rgb),0.06);color:var(--ink)}
.muhurta-et-icon{font-size:18px;flex-shrink:0}
.muhurta-et-label{font-size:13px;line-height:1.2}

/* Window list */
.muhurta-windows-list{display:flex;flex-direction:column;gap:12px;margin-top:4px}

.muhurta-window{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-card);overflow:hidden;transition:border-color var(--dur-fast)}
.muhurta-window[open]{border-color:rgba(var(--gold-rgb),0.35)}
.muhurta-window--locked{opacity:0.6;position:relative}

.muhurta-window-hd{list-style:none;padding:14px 16px;cursor:pointer;-webkit-tap-highlight-color:transparent}
.muhurta-window-hd::-webkit-details-marker{display:none}
.muhurta-window-hd:focus-visible{outline:2px solid var(--gold);outline-offset:-2px}
.muhurta-window-hd-inner{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:8px}
.muhurta-window-date-block{display:flex;flex-direction:column;gap:2px}
.muhurta-window-date{font-family:'Cormorant Garamond',serif;font-size:17px;color:var(--ink);font-weight:600;line-height:1.2}
.muhurta-window-time{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink4)}
.muhurta-window-tags{display:flex;flex-wrap:wrap;gap:5px}

.muhurta-score-badge{font-family:'DM Sans',sans-serif;font-size:10px;font-weight:600;letter-spacing:0.4px;border-radius:20px;padding:3px 10px;flex-shrink:0;white-space:nowrap}
.muhurta-score--strong{background:rgba(var(--sage-rgb),0.15);color:var(--sage)}
.muhurta-score--good{background:rgba(var(--gold-rgb),0.12);color:var(--gold)}
.muhurta-score--moderate{background:var(--bg2);color:var(--ink3)}
.muhurta-score--weaker{background:rgba(var(--rose-rgb),0.08);color:var(--rose)}

.muhurta-window-body{padding:0 16px 16px;border-top:1px solid var(--border)}
.muhurta-reason{font-family:'DM Sans',sans-serif;font-size:13px;color:var(--ink2);line-height:1.55;padding-top:12px;margin-bottom:10px}
.muhurta-avoid-row{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink3);background:var(--bg2);border-radius:var(--r-xs);padding:8px 12px;margin-bottom:10px;line-height:1.4}
.muhurta-avoid-label{font-weight:600;color:var(--ink2);margin-right:4px}
.muhurta-alternative{font-family:'DM Sans',sans-serif;font-size:11px;color:var(--ink4);font-style:italic;margin-top:8px;margin-bottom:10px;line-height:1.45}

/* Detail facts grid */
.muhurta-detail-facts{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:10px 0}

/* ═══════════════════════════════════════════════════════════════
   COLOUR ENHANCEMENTS — April 2026
   All within brand board palette. Purely additive — no class renames.
   ═══════════════════════════════════════════════════════════════ */

/* ── 1. AMBIENT PANEL BACKGROUNDS ──────────────────────────────
   Soft radial washes using gold / sage / dusk at 4–7% opacity.
   Barely-there on scroll but immediately warmer than flat parchment. */

#panel-kundli {
  background:
    radial-gradient(ellipse 70vw 40vh at 88% 6%,  rgba(var(--gold-rgb),0.07) 0%, transparent 65%),
    radial-gradient(ellipse 50vw 30vh at 12% 72%, rgba(var(--sage-rgb),0.05) 0%, transparent 65%),
    radial-gradient(ellipse 40vw 28vh at 55% 92%, rgba(var(--dusk-rgb),0.04) 0%, transparent 60%);
}

#panel-dasha {
  background:
    radial-gradient(ellipse 60vw 35vh at 82% 8%,  rgba(var(--sage-rgb),0.06) 0%, transparent 65%),
    radial-gradient(ellipse 45vw 28vh at 12% 75%, rgba(var(--gold-rgb),0.04) 0%, transparent 60%);
}

.k-hero {
  background:
    radial-gradient(ellipse 65vw 50vh at 72% 38%, rgba(var(--gold-rgb),0.08) 0%, transparent 65%),
    radial-gradient(ellipse 40vw 30vh at 18% 65%, rgba(var(--dusk-rgb),0.05) 0%, transparent 60%);
}

/* ── 2. PHASE HERO — warm gradient instead of flat gold ─────────
   Deep amber → saffron → light gold. Gives the flagship card
   real warmth and depth without leaving the brand palette. */

.ny-phase-hero,
.ny-phase-block {
  background: linear-gradient(135deg, #7B3C0A 0%, var(--gold) 52%, #D4884A 100%);
  box-shadow: 0 6px 28px rgba(var(--gold-rgb), 0.32);
}

/* ── 3. INSIGHT CARD — gold top accent + warm tint ─────────────
   The main AI insight card gets a vivid 3px gold top edge
   and a faint warm gradient wash so it reads as the hero card. */

.ny-insight-card {
  border-top: 3px solid var(--gold);
  background: linear-gradient(160deg, rgba(var(--gold-rgb),0.04) 0%, var(--surface2,var(--bg2)) 36%);
}

/* ── 4. TRANSIT CARD — sage gradient tint ───────────────────────
   Sage left-border already signals "positive transit". Amplify
   with a sage-to-transparent background so the card feels distinct. */

.ny-transit-card {
  background: linear-gradient(to right, rgba(var(--sage-rgb),0.07) 0%, var(--surface) 45%);
  border-left-width: 4px;
}

/* ── 5. CHART HERO — tricolour gradient bar + warm tint ─────────
   The 3px gold line becomes a 4px dusk→gold→sage sweep —
   representing past/present/future in one stroke. */

.chart-hero::before {
  height: 4px;
  background: linear-gradient(90deg, var(--dusk) 0%, var(--gold) 50%, var(--sage) 100%);
  opacity: 1;
}

.chart-hero {
  background: linear-gradient(160deg, rgba(var(--gold-rgb),0.04) 0%, var(--surface) 50%);
}

/* ── 6. TODAY COL SECTIONS — alternating coloured top caps ──────
   Odd sections get saffron, even get sage. Inset box-shadow
   keeps the existing border intact — zero DOM changes needed. */

.today-col-sec:nth-child(odd)  { box-shadow: inset 0 3px 0 rgba(var(--gold-rgb),0.55), var(--shadow-sm); }
.today-col-sec:nth-child(even) { box-shadow: inset 0 3px 0 rgba(var(--sage-rgb),0.55), var(--shadow-sm); }

/* ── 7. BOTTOM NAV — richer active state ────────────────────────
   Replace flat gold-bg with a warm gradient that has a stronger
   gold concentration at the top, evoking a lit indicator bar. */

.bnav-item.active {
  background: linear-gradient(to bottom,
    rgba(var(--gold-rgb),0.22) 0%,
    rgba(var(--gold-rgb),0.10) 100%
  ) !important;
  border: 1px solid rgba(var(--gold-rgb),0.25) !important;
  color: var(--gold) !important;
}

/* ── 8. MORE TILES — coloured icon area on hover ────────────────
   Give the tool tiles a subtle gold shimmer on interaction. */

.more-tile:hover,
.more-tile:active {
  background: linear-gradient(135deg, rgba(var(--gold-rgb),0.05) 0%, var(--surface) 60%);
  border-color: rgba(var(--gold-rgb),0.35);
}

/* ── 9. SECTION LABELS — use gold instead of muted ink4 ─────────
   .ny-section-label was var(--ink4) (pale grey). Gold makes
   section titles feel intentional and brand-consistent. */

.ny-section-label { color: var(--gold); }

/* ── 10. DASHA PHASE LIST — richer active row ───────────────────
   The active phase row gets a gold→transparent gradient so
   it reads as selected without being heavy-handed. */

.ny-phase-active {
  background: linear-gradient(to right,
    rgba(var(--gold-rgb),0.12) 0%,
    rgba(var(--gold-rgb),0.04) 100%
  ) !important;
  border-color: rgba(var(--gold-rgb),0.3) !important;
}

/* ── 11. DASHA PANEL — section label accent colour ──────────────
   Dasha section headers use sage to match their positive/timing
   connotation, giving each panel its own colour identity. */

#panel-dasha .ny-section-label  { color: var(--sage); }
#panel-dasha .ny-transit-title  { color: var(--sage); }

/* ── PREFERS REDUCED MOTION — no animation added, safe ─────────
   All enhancements above are static gradients / colours.
   No new keyframes or transitions introduced. */
.muhurta-fact-row{background:var(--bg2);border-radius:var(--r-xs);padding:8px 10px;display:flex;flex-direction:column;gap:2px}
.muhurta-fact-key{font-family:'DM Sans',sans-serif;font-size:10px;color:var(--ink4);text-transform:uppercase;letter-spacing:0.5px}
.muhurta-fact-val{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink2);font-weight:500}

/* Lock overlay */
.muhurta-lock-overlay{padding:12px 16px 14px;display:flex;align-items:center;gap:10px;background:var(--bg2)}
.muhurta-lock-icon{font-size:16px}
.muhurta-lock-text{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink3)}

/* Premium nudge */
.muhurta-premium-nudge{margin-top:16px;padding:14px 16px;background:rgba(var(--gold-rgb),0.05);border:1px solid rgba(var(--gold-rgb),0.2);border-radius:var(--r-card);text-align:center}
.muhurta-premium-nudge p{font-family:'DM Sans',sans-serif;font-size:13px;color:var(--ink2);line-height:1.4}
.muhurta-premium-nudge .dive-detail-note{margin-top:4px}

/* Share button */
.muhurta-share-btn{width:100%;margin-top:12px;padding:10px 16px;background:transparent;border:1px solid rgba(var(--gold-rgb),0.4);border-radius:var(--r-xs);font-family:'Cinzel',serif;font-size:10px;letter-spacing:1px;color:var(--gold);cursor:pointer;transition:background var(--dur-fast);-webkit-tap-highlight-color:transparent;text-transform:uppercase}
.muhurta-share-btn:hover{background:rgba(var(--gold-rgb),0.08)}
.muhurta-share-btn:active{transform:scale(0.97)}

/* ═══════════════════════════════════════════════════════════════
   NYOVAH ANIMATION SYSTEM
   Three tiers:
     1. Breathing  — invisible quality (cards, nav)
     2. Responsive — trust-building (forms, buttons)
     3. Rewarding  — earned moments (chart load, Phase Hero)
   All animations respect prefers-reduced-motion.
   No bounces. No loops outside the loader. Premium pacing only.
   ═══════════════════════════════════════════════════════════════ */

/* ── KEYFRAMES ─────────────────────────────────────────────── */

/* Tier 1 — card entrance: 6px lift, pure ease-out */
@keyframes nyCardEnter {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Tier 3 — Phase Hero: slightly taller rise, border brightens in */
@keyframes nyHeroEnter {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Tier 3 — staggered section reveal (used by JS .ny-reveal class) */
@keyframes nyReveal {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Tier 2 — focus underline grows from centre */
@keyframes nyUnderlineGrow {
  from { transform: scaleX(0); opacity: 0; }
  to   { transform: scaleX(1); opacity: 1; }
}

/* Tier 2 — input shake on error */
@keyframes nyShake {
  0%,100% { transform: translateX(0); }
  20%     { transform: translateX(-3px); }
  40%     { transform: translateX(3px); }
  60%     { transform: translateX(-2px); }
  80%     { transform: translateX(2px); }
}

/* Tier 2 — wizard step slide: incoming from right */
@keyframes nyStepIn {
  from { opacity: 0; transform: translateX(18px); }
  to   { opacity: 1; transform: translateX(0); }
}

/* Tier 2 — wizard step slide: outgoing to left */
@keyframes nyStepOut {
  from { opacity: 1; transform: translateX(0); }
  to   { opacity: 0; transform: translateX(-18px); }
}

/* Tier 3 — send button opacity dip on tap (not a ripple) */
@keyframes nySendTap {
  0%   { opacity: 1; }
  40%  { opacity: 0.65; }
  100% { opacity: 1; }
}

/* ── TIER 1: BREATHING — card & section enter ──────────────── */

/* Cards fade up on first paint — subtle, barely noticeable */
.card,
.k-form-card,
.ai-section,
.ny-actions-card,
.ny-insight-card,
.ny-shift-hook,
.ny-section-tap-row,
.sacred-form {
  animation: nyCardEnter 240ms cubic-bezier(0.16,1,0.3,1) both;
}

/* Hover lift — 1px only, premium restraint */
.card:hover,
.k-form-card:hover,
.ny-actions-card:hover,
.ny-insight-card:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow);
  transition: transform 200ms cubic-bezier(0.16,1,0.3,1),
              box-shadow 200ms cubic-bezier(0.16,1,0.3,1);
}

/* Bottom nav active tab — gold dot slides up into place */
.bnav-item::after {
  content: '';
  position: absolute;
  bottom: 2px;
  left: 50%;
  transform: translateX(-50%) scaleX(0);
  width: 16px;
  height: 2px;
  background: var(--gold);
  border-radius: 2px;
  transition: transform 200ms cubic-bezier(0.16,1,0.3,1),
              opacity 200ms ease;
  opacity: 0;
}
.bnav-item.active::after {
  transform: translateX(-50%) scaleX(1);
  opacity: 1;
}

/* ── TIER 2: RESPONSIVE — forms & buttons ──────────────────── */

/* Input focus: gold underline grows from centre beneath the field */
.field,
.k-input-wrap {
  position: relative;
}
.field input:focus ~ .ny-focus-line,
.field select:focus ~ .ny-focus-line {
  transform: scaleX(1);
  opacity: 1;
}
.ny-focus-line {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--gold);
  border-radius: 1px;
  transform: scaleX(0);
  transform-origin: center;
  opacity: 0;
  transition: transform 180ms cubic-bezier(0.16,1,0.3,1),
              opacity 180ms ease;
  pointer-events: none;
}

/* Continue button: muted until field has value — handled via JS .ny-btn-ready */
.btn--primary,
.btn-gold,
.k-next-btn {
  transition: background 200ms ease,
              box-shadow 200ms ease,
              opacity 200ms ease,
              transform var(--dur-fast) ease;
}
.btn--primary.ny-btn-muted,
.btn-gold.ny-btn-muted,
.k-next-btn.ny-btn-muted {
  opacity: 0.45;
}
.btn--primary.ny-btn-ready,
.btn-gold.ny-btn-ready,
.k-next-btn.ny-btn-ready {
  opacity: 1;
}

/* Wizard step transition */
.k-step.active {
  animation: nyStepIn 220ms cubic-bezier(0.4,0,0.2,1) both;
}
.k-step.ny-step-exit {
  animation: nyStepOut 180ms cubic-bezier(0.4,0,0.2,1) both;
}

/* Error shake — applied via JS: el.classList.add('ny-shake') */
.ny-shake {
  animation: nyShake 320ms cubic-bezier(0.36,0.07,0.19,0.97) both;
}

/* Send button tap — applied via JS on click */
.btn--icon.ny-tapped,
.chat-send-btn.ny-tapped,
.ask-send-btn.ny-tapped {
  animation: nySendTap 240ms ease both;
}

/* ── TIER 3: REWARDING — chart load & Phase Hero ───────────── */

/* Phase Hero entrance — single clean motion, no glow, no pulse */
.ny-phase-hero,
.ny-phase-block {
  animation: nyHeroEnter 320ms cubic-bezier(0.16,1,0.3,1) both;
}

/* Staggered section reveal — JS adds .ny-reveal to each section
   with an inline animation-delay (80ms apart) after chart loads */
.ny-reveal {
  animation: nyReveal 280ms cubic-bezier(0.16,1,0.3,1) both;
}

/* Stagger delays for Today tab sections (set in order) */
.ny-phase-hero.ny-reveal   { animation-delay: 0ms; }
.ny-actions-card.ny-reveal { animation-delay: 80ms; }
.ny-shift-hook.ny-reveal   { animation-delay: 160ms; }
.ny-insight-card.ny-reveal { animation-delay: 240ms; }

/* ── PREFERS-REDUCED-MOTION — all animation disabled ───────── */
@media (prefers-reduced-motion: reduce) {
  .card,
  .k-form-card,
  .ai-section,
  .ny-actions-card,
  .ny-insight-card,
  .ny-shift-hook,
  .ny-section-tap-row,
  .sacred-form,
  .ny-phase-hero,
  .ny-phase-block,
  .ny-reveal {
    animation: none !important;
  }
  .k-step.active {
    animation: none !important;
  }
  .bnav-item::after,
  .bnav-item.active::after {
    transition: none !important;
  }
  .ny-focus-line {
    transition: none !important;
  }
  .card:hover,
  .k-form-card:hover,
  .ny-actions-card:hover,
  .ny-insight-card:hover {
    transform: none !important;
    transition: none !important;
  }
}

/* reduced-motion: disable window expand animation */
@media(prefers-reduced-motion:reduce){.muhurta-window,.muhurta-et-btn,.muhurta-share-btn{transition:none}}

/* ═══════════════════════════════════════════════════════════════
   NYOVAH MOTION UPGRADE — Session 29
   Five additions that make the app feel genuinely alive:
     1. Phase Hero shimmer sweep (single-play, never loops)
     2. Countdown number roll-up (handled in JS)
     3. Bottom nav icon spring bounce on tap
     4. Scroll-triggered card reveals (IntersectionObserver in JS)
     5. Action chips stagger entrance
   All respect prefers-reduced-motion.
   ═══════════════════════════════════════════════════════════════ */

/* ── 1. PHASE HERO SHIMMER SWEEP ─────────────────────────────────
   A single light sweep plays on the gold hero card on entry.
   The ::before is already used for the decorative circle —
   we use ::after for the shimmer. Single play, never loops. */
@keyframes nyHeroShimmer {
  0%   { transform: translateX(-100%) skewX(-12deg); opacity: 0; }
  15%  { opacity: 1; }
  85%  { opacity: 1; }
  100% { transform: translateX(220%) skewX(-12deg); opacity: 0; }
}
.ny-phase-block.ny-reveal::after,
.ny-phase-hero.ny-reveal::after {
  content: '';
  position: absolute;
  inset: 0;
  width: 40%;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255,255,255,0.13) 50%,
    transparent 100%
  );
  pointer-events: none;
  animation: nyHeroShimmer 900ms cubic-bezier(0.16,1,0.3,1) 280ms both;
  z-index: 2;
}

/* ── 2. COUNTDOWN NUMBER — urgency glow when days < 30 ────────────
   The .ny-countdown--urgent class is toggled by JS when days ≤ 30.
   Number gets a warm amber glow breath. */
@keyframes nyCountdownGlow {
  0%, 100% { text-shadow: 0 0 0px rgba(var(--gold-rgb),0); }
  50%       { text-shadow: 0 0 28px rgba(var(--gold-rgb),0.45); }
}
.ny-countdown--urgent .ny-countdown-number {
  color: var(--gold-dim);
  animation: nyCountdownGlow 2.4s ease-in-out infinite;
}

/* ── 3. BOTTOM NAV ICON SPRING BOUNCE ─────────────────────────────
   .bnav-tap is added to the icon on switchPanel, removed on animationend. */
@keyframes nyNavIconBounce {
  0%   { transform: scale(1);    }
  30%  { transform: scale(1.28); }
  55%  { transform: scale(0.90); }
  75%  { transform: scale(1.08); }
  100% { transform: scale(1);    }
}
.bnav-icon.bnav-tap {
  animation: nyNavIconBounce 380ms cubic-bezier(0.34,1.56,0.64,1) both;
}

/* ── 4. SCROLL-TRIGGERED CARD REVEALS ────────────────────────────
   .ny-scroll-reveal starts invisible. IntersectionObserver in JS
   adds .ny-scroll-visible when element enters the viewport. */
.ny-scroll-reveal {
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 340ms cubic-bezier(0.16,1,0.3,1),
              transform 340ms cubic-bezier(0.16,1,0.3,1);
  will-change: opacity, transform;
}
.ny-scroll-reveal.ny-scroll-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ── 5. ACTION CHIPS STAGGER ─────────────────────────────────────
   .ny-chip-enter is added to each chip with an inline animation-delay.
   JS sets the delay (0ms, 50ms, 100ms…). */
@keyframes nyChipEnter {
  from { opacity: 0; transform: translateY(6px) scale(0.97); }
  to   { opacity: 1; transform: translateY(0)   scale(1);    }
}
.ny-action-chip.ny-chip-enter {
  animation: nyChipEnter 260ms cubic-bezier(0.16,1,0.3,1) both;
}

/* ── PREFERS-REDUCED-MOTION — all new additions disabled ─────── */
@media (prefers-reduced-motion: reduce) {
  .ny-phase-block.ny-reveal::after,
  .ny-phase-hero.ny-reveal::after {
    animation: none !important;
  }
  .ny-countdown--urgent .ny-countdown-number {
    animation: none !important;
    text-shadow: none !important;
  }
  .bnav-icon.bnav-tap {
    animation: none !important;
  }
  .ny-scroll-reveal {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
  .ny-action-chip.ny-chip-enter {
    animation: none !important;
  }
}
