/* ═══════════════════════════════════
   BAZILAR — bazilar.css v3.1
   No bold. Monospace inputs. Dark/light.
═══════════════════════════════════ */

:root,[data-theme="dark"]{
  --bg:#0b0a0a;--surface:#131211;--panel:#1c1a18;--panel2:#242120;
  --text:#e8e5e0;--muted:#918c86;--dim:#6d6862;
  --input-bg:#1c1a18;--input-bd:rgba(201,168,76,.12);
  --shadow:rgba(0,0,0,.50);
}
[data-theme="light"]{
  --bg:#f5f2ea;--surface:#faf8f2;--panel:#ffffff;--panel2:#f0ede4;
  --text:#1a1814;--muted:#6b6458;--dim:#9a9488;
  --input-bg:#faf8f2;--input-bd:rgba(201,168,76,.12);
  --shadow:rgba(0,0,0,.06);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --gold:#c9a84c;--gold2:#e8c97a;--gold-dim:#a08830;--gold-bg:rgba(201,168,76,.12);
  /* Element colors — ONLY for result cards/pillars, never UI nav */
  --wood:#7dba82;--fire:#e05c4a;--earth:#c9a84c;--metal:#b0bec5;--water:#5b9fc9;
  --bg-gold:rgba(201,168,76,.10);
  --r:8px;--r-lg:12px;
  /* Spacing scale — base 4px */
  --sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;
  --sp-6:24px;--sp-8:32px;--sp-12:48px;--sp-16:64px;
}
:focus-visible{outline:2px solid var(--gold);outline-offset:2px;border-radius:3px}
html{font-size:15px;scroll-behavior:smooth}
body{
  font-family:'Noto Sans',sans-serif;font-weight:300;
  background:var(--bg);color:var(--text);
  min-height:100vh;line-height:1.65;
  transition:background .3s,color .3s;
}
body::after{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:9999;
  opacity:.035;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-repeat:repeat;background-size:256px 256px;
}
/* Global no-bold */
strong,b,h1,h2,h3,h4,h5,h6{font-weight:400}

/* Skip link */
.skip-link{position:absolute;top:-40px;left:0;background:var(--gold);color:var(--bg);padding:8px 16px;font-family:'JetBrains Mono',monospace;font-size:.7rem;text-decoration:none;z-index:9999;border-radius:0 0 var(--r) 0;transition:top .2s}
.skip-link:focus{top:0}

/* ═══════ TOPBAR ═══════ */
.topbar{
  background:rgba(19,18,17,.88);border-bottom:1px solid var(--bg-gold);
  padding:0 22px;display:flex;align-items:center;
  justify-content:space-between;height:54px;
  position:sticky;top:0;z-index:100;
  box-shadow:0 2px 16px var(--shadow);transition:background .3s;
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
}
[data-theme="light"] .topbar{background:rgba(250,248,242,.90)}
.topbar-brand{display:flex;align-items:center;gap:10px;color:var(--gold);text-decoration:none;flex-shrink:0}
.topbar-sym{
  width:32px;height:32px;border:1.5px solid var(--gold);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:.9rem;font-family:'Noto Sans SC',sans-serif;
}
.topbar-name{font-family:'PT Serif',serif;font-size:1.05rem;color:var(--gold);letter-spacing:.12em;text-transform:uppercase}
.topbar-right{display:flex;align-items:center;gap:9px}
.topbar-badge{
  background:rgba(201,168,76,.08);border:1px solid rgba(201,168,76,.25);
  border-radius:20px;padding:2px 9px;font-size:.54rem;
  color:var(--gold-dim);letter-spacing:.12em;text-transform:uppercase;
  font-family:'JetBrains Mono',monospace;
}

/* Lang dropdown */
.lang-wrap{position:relative}
.lang-btn{
  display:flex;align-items:center;gap:5px;
  background:var(--panel);border:1px solid var(--bg-gold);
  border-radius:var(--r);padding:6px 10px;
  cursor:pointer;color:var(--text);font-size:.79rem;
  font-family:'Noto Sans',sans-serif;transition:border-color .2s;
}
.lang-btn:hover,.lang-btn:focus-visible{border-color:var(--gold);outline:none}
.lang-arrow{font-size:.5rem;color:var(--muted);transition:transform .2s}
.lang-wrap.open .lang-arrow{transform:rotate(180deg)}
.lang-menu{
  display:none;position:absolute;top:calc(100% + 5px);right:0;
  background:var(--panel);border:1px solid var(--bg-gold);
  border-radius:var(--r);min-width:155px;
  box-shadow:0 8px 28px var(--shadow);z-index:200;overflow:hidden;
}
.lang-wrap.open .lang-menu{display:block}
.lang-opt{
  display:flex;align-items:center;gap:8px;
  padding:8px 12px;font-size:.82rem;color:var(--text);
  cursor:pointer;transition:background .15s;border:none;
  background:transparent;width:100%;text-align:left;font-family:'Noto Sans',sans-serif;
}
.lang-opt:hover,.lang-opt:focus-visible{background:rgba(201,168,76,.1);color:var(--gold2);outline:none}
.lang-opt.active{color:var(--gold)}

/* Theme */
.theme-btn{
  display:flex;align-items:center;justify-content:center;
  width:36px;height:36px;background:var(--panel);
  border:1px solid var(--bg-gold);border-radius:var(--r);
  cursor:pointer;font-size:1rem;transition:border-color .2s;
}
.theme-btn:hover,.theme-btn:focus-visible{border-color:var(--gold);outline:none}

/* ═══════ LAYOUT ═══════ */
.page{
  max-width:1120px;margin:0 auto;padding:28px 22px 60px;
  display:grid;grid-template-columns:340px 1fr;gap:24px;align-items:start;
}

/* ═══════ INPUT PANEL ═══════ */
.input-panel{
  background:var(--panel);border:1px solid var(--bg-gold);
  border-radius:var(--r-lg);padding:22px;
  position:sticky;top:70px;
  box-shadow:0 4px 20px var(--shadow);transition:background .3s,border-color .3s;
}
.panel-title{
  font-family:'PT Serif',serif;font-size:1.15rem;
  color:var(--gold);margin-bottom:17px;
  padding-bottom:11px;border-bottom:1px solid var(--bg-gold);
  display:flex;align-items:center;gap:8px;
}
.panel-title-zh{font-size:1rem;opacity:.55}
.field-group{margin-bottom:13px}
.field-label{
  font-size:.62rem;color:var(--muted);letter-spacing:.09em;text-transform:uppercase;
  margin-bottom:4px;display:block;font-family:'JetBrains Mono',monospace;
}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:7px}
.field-row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:7px}

/* All inputs monospace */
/* Estilo base para Inputs Mono (conforme o print) */
.input-mono {
  width: 100%;
  background: var(--panel);
  border: 1px solid rgba(201,168,76,.12);
  border-radius: 8px;
  padding: 12px 14px;
  color: var(--text);
  font-family: 'JetBrains Mono', monospace; /* Fonte do print */
  font-size: .80rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  transition: border-color 200ms ease;
}

.input-mono::placeholder {
  color: var(--dim);
  opacity: 0.6;
}

.input-mono:focus {
  border-color: var(--gold);
  outline: none;
}

/* Grid para os campos DD / MM / AAAA */
.date-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1.5fr; /* O ano é levemente mais largo */
  gap: var(--sp-2);
}

.date-subgroup {
  display: flex;
  vertical-align: top;
  flex-direction: column;
  gap: var(--sp-1);
}

.sub-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: .55rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--muted);
}

/* Ajuste nos labels principais para alinhar com o print */
.field-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: .62rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: var(--sp-2);
  display: block;
}
input:focus,select:focus{border-color:var(--gold)}
input::placeholder{color:var(--dim);font-family:'JetBrains Mono',monospace}
select option{background:var(--input-bg);color:var(--text)}

/* Gender buttons — independent, nothing pre-selected */
.gender-row{display:flex;gap:7px}
.gender-btn{
  flex:1;padding:9px 8px;
  border:1px solid var(--input-bd);border-radius:var(--r);
  background:var(--input-bg);color:var(--muted);
  font-family:'JetBrains Mono',monospace;font-size:.82rem;
  cursor:pointer;text-align:center;transition:all .2s;
}
.gender-btn:hover{border-color:var(--gold);color:var(--text)}
.gender-btn.active{border-color:var(--gold);color:var(--gold2);background:rgba(201,168,76,.1)}

/* Checkbox */
.chk-row{display:flex;align-items:center;gap:7px;margin-top:5px}
.chk-row input[type=checkbox]{width:15px;height:15px;accent-color:var(--gold);cursor:pointer;flex-shrink:0}
.chk-row label{font-size:.79rem;color:var(--muted);cursor:pointer}

.calc-btn{
  width:100%;margin-top:17px;padding:13px;
  border-radius:var(--r);background:var(--gold);
  border:none;color:#1a1814;
  font-family:'JetBrains Mono',monospace;font-size:.60rem;font-weight:400;
  cursor:pointer;transition:background .2s,transform .1s;letter-spacing:.12em;text-transform:uppercase;
}
.calc-btn:hover{background:var(--gold2)}
.calc-btn:active{transform:scale(.98)}

/* RST box */
.rst-box{
  background:rgba(201,168,76,.06);border:1px solid rgba(201,168,76,.22);
  border-radius:var(--r);padding:10px 13px;margin-top:12px;
}
.rst-lbl{font-size:.58rem;color:var(--gold-dim);letter-spacing:.1em;text-transform:uppercase;font-family:'JetBrains Mono',monospace}
.rst-val{font-size:1.25rem;color:var(--gold2);margin:3px 0;font-family:'JetBrains Mono',monospace}
.rst-det{font-size:.68rem;color:var(--muted);line-height:1.65;font-family:'JetBrains Mono',monospace}

/* ═══════ ZI SELECTOR — matches screenshot exactly ═══════ */
.zi-selector{margin-top:12px;border:1px solid var(--bg-gold);border-radius:var(--r);overflow:hidden}
.zi-toggle-hd{
  display:flex;align-items:center;gap:6px;
  padding:8px 12px;cursor:pointer;
  font-size:.76rem;color:var(--muted);transition:color .2s;user-select:none;
}
.zi-toggle-hd:hover{color:var(--text)}
.zi-toggle-arrow{font-size:.55rem;transition:transform .2s}
.zi-selector.open .zi-toggle-arrow{transform:rotate(180deg)}
.zi-opts{display:none;padding:0 6px 6px}
.zi-selector.open .zi-opts{display:block}
.zi-opt{
  display:flex;align-items:flex-start;gap:10px;
  padding:10px 12px;margin:4px 0;
  border:1px solid var(--input-bd);border-radius:var(--r);
  cursor:pointer;transition:all .2s;background:transparent;
}
.zi-opt:hover{border-color:var(--gold)}
.zi-opt.active{border-color:var(--gold);background:rgba(201,168,76,.06)}
.zi-radio{
  width:16px;height:16px;border-radius:50%;
  border:2px solid var(--dim);flex-shrink:0;margin-top:2px;
  transition:border-color .2s;position:relative;
}
.zi-opt.active .zi-radio{border-color:var(--gold)}
.zi-opt.active .zi-radio::after{
  content:'';position:absolute;top:3px;left:3px;
  width:6px;height:6px;border-radius:50%;background:var(--gold);
}
.zi-label{flex:1}
.zi-name{font-size:.84rem;color:var(--text);display:flex;align-items:center;gap:8px}
.zi-name-zh{font-family:'Noto Sans SC',sans-serif;font-size:.88rem}
.zi-name-en{font-family:'JetBrains Mono',monospace;font-size:.82rem}
.zi-badge{
  font-size:.55rem;color:var(--gold);
  background:rgba(201,168,76,.12);border:1px solid rgba(201,168,76,.25);
  border-radius:10px;padding:1px 7px;
  font-family:'JetBrains Mono',monospace;letter-spacing:.06em;
}
.zi-desc{font-size:.7rem;color:var(--dim);margin-top:3px;line-height:1.55}

/* Location preview */
.loc-prev{font-size:.68rem;color:var(--muted);margin-top:4px;font-family:'JetBrains Mono',monospace;min-height:.9rem}
.geo-wrap{position:relative}
.geo-spin{
  position:absolute;right:10px;top:50%;transform:translateY(-50%);
  width:14px;height:14px;border:2px solid rgba(201,168,76,.25);
  border-top-color:var(--gold);border-radius:50%;
  animation:spin .7s linear infinite;opacity:0;transition:opacity .2s;pointer-events:none;
}
@keyframes spin{to{transform:translateY(-50%) rotate(360deg)}}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}

/* Suggestions */
.sug-box{
  display:none;position:absolute;top:calc(100% + 4px);left:0;right:0;
  background:var(--panel);border:1px solid var(--bg-gold);
  border-radius:var(--r);overflow:hidden;
  box-shadow:0 8px 28px var(--shadow);z-index:300;max-height:240px;overflow-y:auto;
}
.sug-item{
  display:flex;flex-direction:column;gap:2px;
  width:100%;padding:9px 12px;border:none;background:transparent;cursor:pointer;
  text-align:left;font-family:'JetBrains Mono',monospace;
  transition:background .15s;border-bottom:1px solid rgba(201,168,76,.06);
}
.sug-item:last-child{border-bottom:none}
.sug-item:hover,.sug-item:focus{background:rgba(201,168,76,.1);outline:none}
.sug-name{font-size:.8rem;color:var(--text);line-height:1.3}
.sug-coords{font-size:.64rem;color:var(--muted)}
.sug-none{padding:10px 12px;font-size:.8rem;color:var(--muted);font-style:italic}
.sug-attr{padding:5px 10px;font-size:.6rem;color:var(--dim);border-top:1px solid rgba(201,168,76,.06);text-align:right}
.sug-attr a{color:var(--dim);text-decoration:none}
.sug-attr a:hover{color:var(--muted)}

/* ═══════ RESULTS ═══════ */
.name-greet{
  font-family:'PT Serif',serif;font-size:1.1rem;color:var(--gold);
  margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--bg-gold);
}
.name-label{color:var(--muted);font-size:.85rem}
.name-val{color:var(--gold2)}

.sec-label{
  font-size:.6rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;
  margin-bottom:10px;font-family:'JetBrains Mono',monospace;
  padding-bottom:6px;border-bottom:1px solid var(--bg-gold);
}

/* Pillars */
.pillars-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;margin-bottom:22px}
.pillar-card{
  background:var(--panel);border:1px solid var(--bg-gold);
  border-radius:var(--r-lg);overflow:hidden;
  transition:transform .25s,border-color .25s,box-shadow .25s;
}
.pillar-card:hover{transform:translateY(-3px);border-color:var(--gold);box-shadow:0 8px 24px var(--shadow)}
.pillar-hd{
  padding:8px 5px;text-align:center;font-size:.58rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--bg-gold);
  font-family:'JetBrains Mono',monospace;
}
.pillar-hd.active{color:var(--gold);background:rgba(201,168,76,.06)}
.p-stem,.p-branch{padding:14px 7px;text-align:center;border-bottom:1px solid rgba(201,168,76,.06)}
.p-branch{border-bottom:none}
.p-char{font-family:'Noto Sans SC',sans-serif;font-size:2.5rem;line-height:1;display:block;margin-bottom:5px}
.p-py{font-size:.6rem;color:var(--muted);display:block;margin-bottom:3px;font-style:italic}
.p-elem{display:inline-flex;padding:2px 8px;border-radius:10px;font-size:.58rem;letter-spacing:.04em;font-family:'JetBrains Mono',monospace}
.p-god{font-size:.58rem;color:var(--muted);margin-top:4px;display:block;font-family:'JetBrains Mono',monospace}
.p-hidden{
  margin-top:6px;padding-top:6px;border-top:1px dashed rgba(201,168,76,.15);
  font-size:.55rem;color:var(--dim);font-family:'JetBrains Mono',monospace;
  text-align:center;line-height:1.8;
}
.p-hidden span{display:inline-block;padding:1px 5px;border-radius:4px;margin:1px 2px;font-size:.58rem}

/* Info cards */
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:22px}
.info-card{background:var(--panel);border:1px solid var(--bg-gold);border-radius:10px;padding:13px 15px;transition:background .3s}
.ic-title{font-size:.56rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px;font-family:'JetBrains Mono',monospace}
.ic-val{font-size:.89rem;color:var(--text)}
.ic-sub{font-size:.68rem;color:var(--muted);margin-top:3px}

/* Elements balance */
.elem-bar{background:var(--panel);border:1px solid var(--bg-gold);border-radius:10px;padding:14px 16px;margin-bottom:22px}
.elem-title{font-size:.56rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-bottom:10px;font-family:'JetBrains Mono',monospace}
.elem-row{display:flex;gap:6px;margin-bottom:6px;align-items:center}
.elem-name{width:50px;font-size:.7rem;color:var(--muted);text-align:right;font-family:'JetBrains Mono',monospace}
.elem-track{flex:1;height:18px;background:rgba(201,168,76,.04);border-radius:4px;overflow:hidden}
.elem-fill{height:100%;border-radius:4px;transition:width .5s ease;min-width:2px}
.elem-count{width:24px;font-size:.68rem;color:var(--dim);text-align:center;font-family:'JetBrains Mono',monospace}

/* Terms */
.term-bar{background:var(--panel);border:1px solid var(--bg-gold);border-radius:10px;padding:13px 15px;margin-bottom:22px}
.term-ttl{font-size:.56rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px;font-family:'JetBrains Mono',monospace}
.term-track{display:flex;gap:3px;flex-wrap:wrap}
.term-dot{padding:3px 7px;border-radius:4px;font-size:.6rem;color:var(--dim);background:rgba(201,168,76,.04);cursor:default;white-space:nowrap;transition:background .2s}
.term-dot.past{background:rgba(201,168,76,.1);color:var(--gold)}
.term-dot.cur{background:var(--gold);color:#1a1814}

/* Luck Pillars */
.luck-section{margin-bottom:22px}
.luck-grid{display:flex;gap:6px;overflow-x:auto;padding-bottom:6px}
.luck-card{
  min-width:80px;flex-shrink:0;background:var(--panel);border:1px solid var(--bg-gold);
  border-radius:10px;padding:10px 8px;text-align:center;transition:border-color .2s;
}
.luck-card:hover{border-color:var(--gold)}
.luck-card.current{border-color:var(--gold);background:rgba(201,168,76,.06)}
.luck-age{font-size:.55rem;color:var(--muted);font-family:'JetBrains Mono',monospace;margin-bottom:4px}
.luck-chars{font-family:'Noto Sans SC',sans-serif;font-size:1.3rem;color:var(--text);line-height:1.2}
.luck-py{font-size:.55rem;color:var(--dim);font-style:italic;margin-top:2px}
.luck-elem{margin-top:4px}
.luck-years{font-size:.52rem;color:var(--dim);margin-top:3px;font-family:'JetBrains Mono',monospace}

/* Stars */
.stars-section{margin-bottom:22px}
.stars-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px}
.star-card{background:var(--panel);border:1px solid var(--bg-gold);border-radius:8px;padding:10px 12px}
.star-name{font-size:.7rem;color:var(--gold);font-family:'JetBrains Mono',monospace;margin-bottom:3px}
.star-val{font-size:.82rem;color:var(--text)}
.star-desc{font-size:.62rem;color:var(--dim);margin-top:2px}

/* Interactions */
.interact-section{margin-bottom:22px}
.interact-list{display:flex;flex-direction:column;gap:6px}
.interact-item{
  background:var(--panel);border:1px solid var(--bg-gold);border-radius:8px;
  padding:9px 13px;display:flex;align-items:center;gap:10px;font-size:.8rem;
}
.interact-type{font-size:.55rem;color:var(--gold);font-family:'JetBrains Mono',monospace;letter-spacing:.06em;text-transform:uppercase;min-width:60px}
.interact-pair{color:var(--text)}
.interact-result{font-size:.7rem;color:var(--muted);margin-left:auto}

/* Zi notice */
.zi-notice{
  background:rgba(192,105,43,.08);border:1px solid rgba(192,105,43,.3);
  border-radius:var(--r);padding:10px 13px;margin-bottom:16px;
  font-size:.78rem;color:var(--muted);line-height:1.7;
}

/* Log */
.log-card{
  background:var(--panel2);border:1px solid var(--bg-gold);border-radius:10px;
  padding:16px;margin-bottom:9px;font-family:'JetBrains Mono',monospace;
  font-size:.7rem;color:var(--muted);
}
.fl{margin-bottom:5px;line-height:1.75}.fl:last-child{margin-bottom:0}
.hg{color:var(--gold2)} .hv{color:var(--gold-dim)} .hc{color:var(--dim)}

/* Accuracy */
.acc{
  background:rgba(201,168,76,.04);border:1px solid rgba(201,168,76,.12);
  border-radius:8px;padding:10px 13px;font-size:.72rem;color:var(--muted);
  line-height:1.7;margin-top:8px;
}

/* Empty / error */
.empty{background:var(--panel);border:1px dashed var(--bg-gold);border-radius:var(--r-lg);padding:50px 22px;text-align:center}
.empty-ico{font-size:2.5rem;margin-bottom:14px;opacity:.3;font-family:'Noto Sans SC',sans-serif}
.empty-ttl{font-family:'PT Serif',serif;font-size:1.05rem;color:var(--muted);margin-bottom:8px}
.empty-sub{font-size:.8rem;color:var(--dim);max-width:280px;margin:0 auto;line-height:1.75}
.err{background:rgba(192,105,43,.1);border:1px solid rgba(192,105,43,.4);border-radius:8px;padding:10px 13px;font-size:.81rem;color:#e07a3a;margin-bottom:13px}

/* Toggle */
.toggle-hd{display:flex;align-items:center;gap:8px;cursor:pointer;padding:8px 0;user-select:none}
.toggle-hd:hover .sec-label{color:var(--gold)}
.toggle-arrow{font-size:.5rem;color:var(--muted);transition:transform .2s}
.toggle-hd[aria-expanded="true"] .toggle-arrow{transform:rotate(90deg)}
.toggle-body{display:none}
.toggle-body.open{display:block}

/* ═══════ FOOTER — SOLLUN unified ═══════ */
.app-footer{
  background:var(--surface);border-top:1px solid var(--bg-gold);
  padding:36px 24px;transition:background .3s;
}
.footer-inner{
  max-width:1080px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  font-family:'JetBrains Mono',monospace;font-size:.52rem;
  color:var(--dim);letter-spacing:.08em;
}
.footer-brand{
  font-family:'PT Serif',serif;font-size:.52rem;color:var(--gold);
  letter-spacing:.12em;text-transform:uppercase;text-decoration:none;
}
.footer-brand:hover{color:var(--gold2)}
.footer-links{display:flex;gap:16px}
.footer-links a{
  color:var(--dim);text-decoration:none;font-family:'JetBrains Mono',monospace;
  font-size:.52rem;letter-spacing:.08em;text-transform:uppercase;transition:color .2s;
}
.footer-links a:hover{color:var(--gold)}
.footer-tagline{font-size:.52rem;letter-spacing:.08em;color:var(--dim)}
@media(max-width:540px){
  .footer-inner{flex-direction:column;gap:12px;text-align:center}
}

/* ═══════ RESPONSIVE ═══════ */
@media(max-width:800px){
  .page{grid-template-columns:1fr;padding:16px 14px 50px}
  .input-panel{position:static}
  .pillars-grid{grid-template-columns:repeat(2,1fr)}
  .topbar-badge{display:none}
}
@media(max-width:480px){
  .info-grid{grid-template-columns:1fr}
  .stars-grid{grid-template-columns:1fr}
}

/* ═══════════════════════════════════════════════════════
   JYOTISH — Extended CSS
   Vedic Astrology additions on top of SOLLUN base
═══════════════════════════════════════════════════════ */

/* ── Empty state features grid ── */
.empty-features {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 7px; margin-top: 24px; max-width: 400px; margin-inline: auto;
}
.ef-item {
  background: var(--panel2); border: 1px solid var(--bg-gold);
  border-radius: var(--r); padding: 7px 8px;
  font-size: .65rem; color: var(--muted); text-align: center;
  font-family: 'JetBrains Mono', monospace;
}

/* ── Result header ── */
.result-header {
  background: var(--panel); border: 1px solid var(--bg-gold);
  border-radius: var(--r-lg); padding: 20px 24px;
  margin-bottom: 16px;
}
.result-name {
  font-family: 'PT Serif', serif; font-size: 1.25rem;
  color: var(--gold2); margin-bottom: 12px;
}
.result-meta-row {
  display: flex; gap: 24px; flex-wrap: wrap;
}
.result-meta-item { min-width: 120px; }
.meta-label {
  font-size: .58rem; color: var(--dim);
  text-transform: uppercase; letter-spacing: .09em;
  font-family: 'JetBrains Mono', monospace; margin-bottom: 2px;
}
.meta-val {
  font-size: .85rem; color: var(--text);
  font-family: 'JetBrains Mono', monospace;
}

/* ── Tab bar ── */
.tab-bar {
  display: flex; gap: 4px; flex-wrap: wrap;
  background: var(--surface); border: 1px solid var(--bg-gold);
  border-radius: var(--r-lg); padding: 5px;
  margin-bottom: 16px;
}
.tab-btn {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 13px; border-radius: var(--r);
  background: transparent; border: none; cursor: pointer;
  color: var(--muted); font-family: 'JetBrains Mono', monospace;
  font-size: .65rem; text-transform: uppercase; letter-spacing: .08em;
  transition: all .2s; white-space: nowrap;
}
.tab-btn:hover { background: var(--panel); color: var(--text); }
.tab-btn.active {
  background: var(--panel); color: var(--gold);
  border: 1px solid var(--bg-gold);
}
.tab-icon { font-size: .9rem; }

/* ── Tab content ── */
.tab-content { position: relative; }
.tab-pane {
  display: none;
  background: var(--panel); border: 1px solid var(--bg-gold);
  border-radius: var(--r-lg); padding: 22px;
  animation: fadeIn .25s ease;
}
.tab-pane.active { display: block; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(4px); } to { opacity:1; transform:none; } }

.sec-title {
  font-family: 'PT Serif', serif; font-size: 1.1rem;
  color: var(--gold); margin-bottom: 18px;
  padding-bottom: 10px; border-bottom: 1px solid var(--bg-gold);
}

/* ── Vedic Table ── */
.table-wrap {
  overflow-x: auto; border-radius: var(--r);
  border: 1px solid var(--bg-gold);
}
.vedic-table {
  width: 100%; border-collapse: collapse;
  font-size: .78rem; font-family: 'Noto Sans', sans-serif;
}
.vedic-table th {
  background: var(--panel2); padding: 9px 12px;
  text-align: left; color: var(--muted);
  font-size: .58rem; letter-spacing: .08em;
  text-transform: uppercase; font-family: 'JetBrains Mono', monospace;
  border-bottom: 1px solid var(--bg-gold); font-weight: 400;
}
.vedic-table td {
  padding: 9px 12px; border-bottom: 1px solid rgba(201,168,76,.06);
  vertical-align: middle; color: var(--text);
}
.vedic-table tr:last-child td { border-bottom: none; }
.vedic-table tr:hover td { background: rgba(201,168,76,.04); }
.planet-row-lagna td { color: var(--gold2); }

.mono { font-family: 'JetBrains Mono', monospace; font-size: .75rem; }
.muted { color: var(--muted); font-size: .76rem; }
small.muted { font-size: .66rem; }

/* Planet symbol */
.pl-sym {
  display: inline-block; font-size: 1rem;
  margin-right: 4px; line-height: 1;
  vertical-align: middle;
}

/* ── Dignity badges ── */
.dig-badge {
  display: inline-block; padding: 2px 7px; border-radius: 20px;
  font-size: .6rem; letter-spacing: .07em;
  font-family: 'JetBrains Mono', monospace; text-transform: uppercase;
}
.dig-exalted     { background: rgba(125,186,130,.15); color: #7dba82; border: 1px solid rgba(125,186,130,.3); }
.dig-debilitated { background: rgba(224,92,74,.12);   color: #e05c4a; border: 1px solid rgba(224,92,74,.3); }
.dig-moolatrikona{ background: rgba(201,168,76,.15);   color: var(--gold2); border: 1px solid rgba(201,168,76,.3); }
.dig-own         { background: rgba(91,159,201,.12);   color: #5b9fc9; border: 1px solid rgba(91,159,201,.3); }
.dig-friend      { background: rgba(125,186,130,.08);  color: #7dba82; border: 1px solid rgba(125,186,130,.2); }
.dig-enemy       { background: rgba(224,92,74,.08);    color: #e05c4a; border: 1px solid rgba(224,92,74,.2); }
.dig-neutral     { background: rgba(145,140,134,.1);   color: var(--muted); border: 1px solid rgba(145,140,134,.2); }

/* Retro/Combust tags */
.tag-retro  { color: #5b9fc9; font-size: .8rem; }
.tag-combust{ color: #e05c4a; font-size: .8rem; }

/* Strength */
.strength-strong { color: #7dba82; font-size: .75rem; }
.strength-medium { color: var(--gold); font-size: .75rem; }
.strength-weak   { color: #e05c4a; font-size: .75rem; }

/* House type badges */
.house-num { font-family: 'JetBrains Mono', monospace; color: var(--gold); }
.house-type-badge {
  display: inline-block; padding: 2px 7px; border-radius: 20px;
  font-size: .58rem; font-family: 'JetBrains Mono', monospace;
  text-transform: uppercase; letter-spacing: .07em;
}
.kendra    { background: rgba(201,168,76,.15);   color: var(--gold2); border: 1px solid rgba(201,168,76,.3); }
.trikona   { background: rgba(125,186,130,.12);  color: #7dba82;      border: 1px solid rgba(125,186,130,.3); }
.dusthana  { background: rgba(224,92,74,.1);     color: #e05c4a;      border: 1px solid rgba(224,92,74,.25); }
.upachaya  { background: rgba(91,159,201,.1);    color: #5b9fc9;      border: 1px solid rgba(91,159,201,.25); }
.neutral   { background: rgba(145,140,134,.08);  color: var(--dim);   border: 1px solid rgba(145,140,134,.18); }

/* ── Two-chart layout (D-1 + D-9) ── */
.two-chart-row {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 20px; margin-bottom: 20px;
}
.chart-half { text-align: center; }
.chart-label {
  font-family: 'PT Serif', serif; font-size: .85rem;
  color: var(--gold); margin-bottom: 10px; text-align: center;
}

/* Vargottama */
.vargottama-box {
  background: rgba(232,201,122,.06); border: 1px solid rgba(232,201,122,.2);
  border-radius: var(--r); padding: 12px 16px; margin-top: 12px;
}
.vg-label {
  font-size: .62rem; color: var(--gold-dim); letter-spacing: .08em;
  text-transform: uppercase; font-family: 'JetBrains Mono', monospace;
  margin-bottom: 8px;
}
.pl-chip {
  display: inline-block; padding: 3px 9px; margin: 3px;
  background: var(--panel2); border: 1px solid var(--bg-gold);
  border-radius: 20px; font-size: .7rem; color: var(--text);
  font-family: 'JetBrains Mono', monospace;
}
.pl-chip.vargottama { border-color: var(--gold); color: var(--gold2); }

/* ── Yoga cards ── */
.yoga-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px,1fr)); gap: 12px; }
.yoga-card {
  background: var(--panel2); border: 1px solid var(--bg-gold);
  border-radius: var(--r); padding: 14px 16px; transition: border-color .2s;
}
.yoga-card:hover { border-color: var(--gold); }
.yoga-card.yoga-gold    { border-left: 3px solid var(--gold); }
.yoga-card.yoga-green   { border-left: 3px solid #7dba82; }
.yoga-card.yoga-blue    { border-left: 3px solid #5b9fc9; }
.yoga-card.yoga-red     { border-left: 3px solid #e05c4a; }
.yoga-card.yoga-neutral { border-left: 3px solid var(--dim); }
.yoga-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 8px; gap: 8px; }
.yoga-name { font-family: 'PT Serif', serif; font-size: .95rem; color: var(--gold2); }
.yoga-type {
  font-size: .55rem; color: var(--muted);
  font-family: 'JetBrains Mono', monospace; text-transform: uppercase;
  letter-spacing: .08em; flex-shrink: 0; padding-top: 3px;
}
.yoga-planets { margin-bottom: 8px; }
.yoga-desc { font-size: .78rem; color: var(--muted); line-height: 1.65; }

/* ── Dasha table ── */
.current-dasha-box {
  background: rgba(201,168,76,.08); border: 1px solid rgba(201,168,76,.3);
  border-radius: var(--r); padding: 14px 18px; margin-bottom: 16px;
}
.cd-label { font-size: .58rem; color: var(--gold-dim); text-transform: uppercase; letter-spacing: .09em; font-family: 'JetBrains Mono', monospace; }
.cd-main  { font-family: 'PT Serif', serif; font-size: 1.1rem; color: var(--gold2); margin: 4px 0; }
.cd-sub   { font-size: .82rem; color: var(--gold); margin-bottom: 4px; }
.cd-dates { font-size: .72rem; color: var(--muted); font-family: 'JetBrains Mono', monospace; }

.maha-row td { color: var(--text); }
.maha-active td { background: rgba(201,168,76,.06) !important; color: var(--gold2); }
.ad-row td { color: var(--dim); font-size: .77rem; padding: 6px 12px; }
.ad-indent { padding-left: 28px !important; }
.ad-active td { color: var(--gold) !important; }
.now-badge {
  display: inline-block; padding: 2px 8px;
  background: rgba(201,168,76,.2); color: var(--gold2);
  border-radius: 20px; font-size: .58rem;
  font-family: 'JetBrains Mono', monospace; letter-spacing: .08em; text-transform: uppercase;
}
.progress-bar {
  height: 6px; background: var(--panel2); border-radius: 3px;
  min-width: 80px; position: relative; overflow: hidden;
}
.progress-fill {
  height: 100%; background: linear-gradient(90deg, var(--gold), var(--gold2));
  border-radius: 3px; transition: width .5s ease;
}

/* ── Shadbala chart ── */
.sb-legend { margin-bottom: 12px; }
.sb-ref-label { font-size: .62rem; color: var(--dim); font-family: 'JetBrains Mono', monospace; }
.sb-chart { display: flex; flex-direction: column; gap: 6px; }
.sb-row {
  display: grid; grid-template-columns: 90px 1fr 60px 70px;
  align-items: center; gap: 10px;
}
.sb-label { font-size: .78rem; color: var(--text); }
.sb-bar-wrap {
  height: 10px; background: var(--panel2); border-radius: 5px;
  position: relative; overflow: visible;
}
.sb-bar {
  height: 100%; border-radius: 5px;
  transition: width .5s ease;
}
.bar-strong { background: linear-gradient(90deg, #7dba82, #5b9fc9); }
.bar-medium { background: linear-gradient(90deg, var(--gold), var(--gold2)); }
.bar-weak   { background: linear-gradient(90deg, #e05c4a, #c9604a); }
.sb-ref-390 {
  position: absolute; top: -3px; width: 2px; height: 16px;
  background: rgba(201,168,76,.6); border-radius: 1px;
}
.sb-val { font-family: 'JetBrains Mono', monospace; font-size: .75rem; color: var(--text); text-align: right; }
.sb-breakdown {
  display: flex; gap: 8px; padding: 2px 0 6px 90px; flex-wrap: wrap;
}
.sb-breakdown span { font-size: .6rem; color: var(--dim); font-family: 'JetBrains Mono', monospace; }

/* ── Aspects panel ── */
.asp-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px,1fr)); gap: 10px; }
.asp-card {
  background: var(--panel2); border: 1px solid var(--bg-gold);
  border-radius: var(--r); padding: 12px 14px;
}
.asp-source { font-family: 'PT Serif', serif; font-size: .9rem; color: var(--gold2); margin-bottom: 8px; }
.asp-list { display: flex; flex-direction: column; gap: 4px; }
.asp-target { font-size: .7rem; color: var(--muted); font-family: 'JetBrains Mono', monospace; }

/* ── Quick reference ── */
.quick-ref {
  margin-top: 18px; padding: 12px 14px;
  background: var(--panel2); border: 1px solid var(--bg-gold);
  border-radius: var(--r);
}
.qr-title {
  font-size: .58rem; color: var(--dim); text-transform: uppercase;
  letter-spacing: .09em; font-family: 'JetBrains Mono', monospace;
  margin-bottom: 8px;
}
.qr-row {
  display: flex; justify-content: space-between;
  font-size: .72rem; color: var(--muted); margin-bottom: 4px;
  font-family: 'JetBrains Mono', monospace;
}
.qr-note { font-size: .62rem; color: var(--dim); margin-top: 6px; font-family: 'JetBrains Mono', monospace; }

/* ── Calc button with spinner ── */
.calc-btn {
  display: flex; align-items: center; justify-content: center; gap: 8px;
}
.calc-spin {
  width: 14px; height: 14px; border: 2px solid rgba(26,24,20,.3);
  border-top-color: #1a1814; border-radius: 50%;
  animation: spin 1s linear infinite; flex-shrink: 0;
}

/* ── Error ── */
.field-error {
  font-size: .68rem; color: #e05c4a; margin-top: 4px;
  font-family: 'JetBrains Mono', monospace;
}
.error-box {
  background: rgba(224,92,74,.1); border: 1px solid rgba(224,92,74,.3);
  border-radius: var(--r); padding: 16px 20px;
  color: #e05c4a; font-size: .82rem; font-family: 'JetBrains Mono', monospace;
}
.muted-msg { color: var(--muted); font-size: .82rem; padding: 20px 0; }

/* ── Responsive ── */
@media (max-width: 900px) {
  .two-chart-row { grid-template-columns: 1fr; }
  .sb-row { grid-template-columns: 70px 1fr 50px; }
  .sb-strength { display: none; }
  .tab-btn .tab-label { display: none; }
  .tab-btn { padding: 8px 10px; }
}
@media (max-width: 800px) {
  .page { grid-template-columns: 1fr; padding: 16px 14px 50px; }
  .input-panel { position: static; }
  .empty-features { grid-template-columns: repeat(2, 1fr); }
  .result-meta-row { gap: 12px; }
  .yoga-grid { grid-template-columns: 1fr; }
  .asp-grid { grid-template-columns: 1fr; }
}

