/* ===== Paleta Voynich =====
   Tema noche (oscuro cálido, tinta sepia sobre pergamino envejecido) por
   defecto, y tema día (pergamino claro) con [data-theme="light"].
   Acentos comunes: índigo desvaído, rojo óxido, verde salvia, ocre. */
:root{
  /* NOCHE (oscuro cálido) */
  --bg:#1a160f; --bg2:#241e15; --bg3:#2c2419;
  --ink:#ece3cf; --ink-dim:#a89a7c;
  --gold:#b08a4a; --gold-bright:#d8b777;
  --line:#473a28; --line-soft:#2f2719;
  --accent:#5f7a9b;        /* índigo Voynich desvaído */
  --danger:#a8503a;        /* rojo óxido */
  --ok:#7e9469;            /* verde salvia */
  --voynich-indigo:#5f7a9b;
  --voynich-rust:#a8503a;
  --voynich-sage:#7e9469;
  --voynich-ochre:#c2a878;
  --voynich-sepia:#7a6444;
  --mono:"SFMono-Regular",ui-monospace,Menlo,Consolas,monospace;
  --serif:"Iowan Old Style","Palatino",Georgia,serif;
}
:root[data-theme="light"]{
  /* DÍA (pergamino claro) */
  --bg:#ece3cd; --bg2:#e4d8bd; --bg3:#dccba9;
  --ink:#3a2f1d; --ink-dim:#7a6a4c;
  --gold:#9a6f33; --gold-bright:#7c571f;
  --line:#c4b292; --line-soft:#d6c6a4;
  --accent:#42597a;
  --danger:#9a4226;
  --ok:#5f7548;
  --voynich-indigo:#42597a;
  --voynich-rust:#9a4226;
  --voynich-sage:#5f7548;
  --voynich-ochre:#a07f3f;
  --voynich-sepia:#6b5538;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);
  font-family:var(--serif);-webkit-font-smoothing:antialiased;overscroll-behavior:none}
body{padding:env(safe-area-inset-top) 0 env(safe-area-inset-bottom)}

.view{display:none}
.view.on{display:block}

/* ---------- AUTH ---------- */
.auth-wrap{max-width:440px;margin:0 auto;min-height:100vh;display:flex;
  flex-direction:column;justify-content:center;padding:24px}
.brand{text-align:center;margin-bottom:24px}
.eyebrow{font-family:var(--mono);font-size:10px;letter-spacing:.42em;
  text-transform:uppercase;color:var(--gold);margin:0 0 8px}
.brand h1{font-size:46px;font-weight:500;letter-spacing:.04em;margin:0;
  color:var(--gold-bright);font-style:italic}
.sub{font-size:13px;color:var(--ink-dim);margin:8px 0 0}

.card{background:var(--bg2);border:1px solid var(--line);border-radius:14px;padding:6px}
.tabs{display:flex;gap:4px;padding:6px}
.tab{flex:1;background:transparent;border:none;color:var(--ink-dim);
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  padding:11px;border-radius:9px;cursor:pointer}
.tab.on{background:var(--bg3);color:var(--gold-bright)}
.auth-form{padding:14px}

.field{display:flex;flex-direction:column;gap:5px;margin-bottom:13px}
label{font-family:var(--mono);font-size:10px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--ink-dim)}
input,textarea,select{background:var(--bg);border:1px solid var(--line);border-radius:10px;
  color:var(--ink);font-family:var(--mono);font-size:16px;padding:12px 13px;width:100%;
  appearance:none;-webkit-appearance:none;transition:border-color .2s,box-shadow .2s}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(201,162,91,.12)}
input::placeholder,textarea::placeholder{color:#4a5170}
textarea{resize:vertical;line-height:1.5}
.row{display:flex;gap:12px}.row .field{flex:1}
.hint{font-size:11px;color:var(--ink-dim);font-family:var(--mono)}
.err{color:var(--danger);font-size:12px;font-family:var(--mono);min-height:16px;margin-top:6px}

.btn{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  border:none;border-radius:11px;padding:13px 16px;cursor:pointer;font-weight:600}
.btn.primary{background:linear-gradient(180deg,var(--gold-bright),var(--gold));color:#1a1408;
  width:100%;box-shadow:0 6px 18px rgba(201,162,91,.2)}
.btn.primary:active{transform:translateY(1px)}
.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--ink-dim)}
.btn.send{width:auto;padding:13px 16px;flex:0 0 auto}

/* ---------- SHELL ---------- */
.topbar{display:flex;align-items:center;justify-content:space-between;
  padding:10px 18px;border-bottom:1px solid var(--line-soft);position:sticky;top:0;
  background:var(--bg);z-index:10}
.tb-left{display:flex;flex-direction:column;gap:2px;min-width:0}
.logo{font-style:italic;font-size:20px;color:var(--gold-bright);letter-spacing:.03em;line-height:1.1}
.topbar-astrologer{display:flex;align-items:center;gap:7px;min-width:0}
.topbar-astrologer .avatar{width:20px;height:20px;border-radius:50%;object-fit:cover;
  background:var(--bg3);border:1px solid var(--line);flex:0 0 auto}
.topbar-astrologer .ta-name{font-family:var(--mono);font-size:10px;letter-spacing:.08em;
  color:var(--ink-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tb-right{display:flex;gap:6px;flex:0 0 auto}
.icon-btn{background:transparent;border:1px solid var(--line);color:var(--ink-dim);
  width:38px;height:38px;border-radius:10px;font-size:16px;cursor:pointer}
.icon-btn:active{background:var(--bg3)}

.charts-bar{display:flex;gap:8px;padding:12px 18px;align-items:center;
  border-bottom:1px solid var(--line-soft);overflow-x:auto}
.charts-scroll{display:flex;gap:8px}
.chip{flex:0 0 auto;background:var(--bg2);border:1px solid var(--line);color:var(--ink-dim);
  font-family:var(--mono);font-size:12px;padding:9px 14px;border-radius:20px;cursor:pointer;
  white-space:nowrap;display:flex;align-items:center;gap:7px}
.chip.on{background:var(--gold);border-color:var(--gold);color:#1a1408}
.chip.add{border-style:dashed;color:var(--gold)}
.chip .x{opacity:.5;font-size:14px}
.chip .rel{font-size:9px;letter-spacing:.1em;text-transform:uppercase;opacity:.6}

.viewtabs{display:flex;gap:6px;padding:12px 18px;justify-content:center}
.vt{background:transparent;border:1px solid var(--line);color:var(--ink-dim);
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  padding:9px 16px;border-radius:20px;cursor:pointer}
.vt.on{background:var(--gold);border-color:var(--gold);color:#1a1408}

.content{max-width:600px;margin:0 auto}
.pane{display:none}.pane.on{display:block}

.empty{text-align:center;padding:60px 24px;color:var(--ink-dim)}
.empty-glyph{font-size:40px;color:var(--gold);margin:0 0 12px}
.empty .btn{max-width:240px;margin:18px auto 0}

.chart-head{padding:14px 22px 4px;text-align:center}
.chart-head .nm{font-size:22px;letter-spacing:.02em}
.chart-head .meta{font-family:var(--mono);font-size:11px;color:var(--ink-dim);margin-top:4px}

/* sky (reusa estilo previo) */
#sky{width:100%;height:62vw;max-height:380px;display:block;touch-action:none;
  background:radial-gradient(120% 120% at 50% 30%,var(--bg3) 0%,var(--bg) 70%)}
.sky-frame{position:relative;margin:8px 0}
.sky-frame[hidden]{display:none}

/* selector de modo carta (2D / 3D) */
.chart-mode{display:flex;gap:8px;justify-content:center;padding:4px 18px 10px}
.mode-btn{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-dim);border:1px solid var(--line);border-radius:20px;padding:7px 14px;
  cursor:pointer;background:transparent}
.mode-btn.on{color:#1a1408;background:var(--gold);border-color:var(--gold)}

/* rueda 2D */
.wheel-frame{padding:6px 12px 4px}
.wheel-frame[hidden]{display:none}
#wheel{width:100%;height:auto;display:block;max-width:560px;margin:0 auto}

/* sección "Hoy" */
.today-head{text-align:center;padding:14px 18px 4px}
.today-title{font-family:var(--serif);font-size:24px;color:var(--ink)}
.today-head .meta{font-family:var(--mono);font-size:11px;color:var(--ink-dim);margin-top:4px}
#today-wheel{width:100%;height:auto;display:block;max-width:560px;margin:0 auto}
#today-horoscope{padding:4px 22px 30px}
.today-horo-h{display:flex;align-items:center;justify-content:space-between}
.refresh-btn{font-size:16px;line-height:1;color:var(--ink-dim);background:transparent;
  border:1px solid var(--line);border-radius:50%;width:30px;height:30px;cursor:pointer;
  flex:0 0 auto;transition:transform .4s ease,color .2s}
.refresh-btn:hover{color:var(--gold-bright)}
.refresh-btn.spinning{animation:refresh-spin .8s linear infinite}
@keyframes refresh-spin{to{transform:rotate(360deg)}}
.sky-hud{position:absolute;bottom:8px;left:0;right:0;text-align:center;
  font-family:var(--mono);font-size:9px;letter-spacing:.2em;color:var(--ink-dim);
  text-transform:uppercase;pointer-events:none}
.toggles{display:flex;gap:8px;justify-content:center;padding:4px 18px 12px;flex-wrap:wrap}
.tg{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-dim);border:1px solid var(--line);border-radius:20px;padding:7px 13px;
  cursor:pointer;background:transparent}
.tg.on{color:#1a1408;background:var(--gold);border-color:var(--gold)}
.section-h{font-family:var(--mono);font-size:10px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--gold);padding:16px 22px 8px;display:flex;align-items:center;gap:10px}
.section-h::after{content:"";flex:1;height:1px;background:var(--line-soft)}
table.planets{width:100%;border-collapse:collapse;font-family:var(--mono);font-size:13px}
table.planets td{padding:10px 8px;border-bottom:1px solid var(--line-soft)}
table.planets td:first-child{padding-left:22px}
table.planets td:last-child{padding-right:22px;text-align:right}
.glyph{font-size:16px;color:var(--gold-bright);width:22px;display:inline-block}
.sign{color:var(--accent)} .retro{color:var(--danger);font-size:10px}
.zg{font-family:"Times New Roman",serif;font-variant-emoji:text;text-rendering:optimizeLegibility;-webkit-text-fill-color:currentColor;color:var(--gold-bright)}
.angles{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line-soft);
  margin:0 22px;border:1px solid var(--line-soft);border-radius:10px;overflow:hidden}
.angles>div{background:var(--bg);padding:13px 15px}
.angles .k{font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim)}
.angles .v{font-family:var(--mono);font-size:13px;color:var(--gold-bright);margin-top:3px}

/* reading */
.reading{padding:8px 22px 16px;line-height:1.7;font-size:15px;white-space:pre-wrap}
.reading p{margin:0 0 14px}
.reading h3{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);margin:22px 0 10px;display:flex;align-items:center;gap:10px}
.reading h3::after{content:"";flex:1;height:1px;background:var(--line-soft)}
.reading h3:first-child{margin-top:4px}
.hint-inline{font-family:var(--mono);font-size:9px;letter-spacing:.05em;color:var(--ink-dim);text-transform:none}
.reading-actions{padding:0 22px 30px}
.reading-actions .btn{max-width:280px;margin:0 auto}
.loading{color:var(--ink-dim);font-family:var(--mono);font-size:12px;text-align:center;padding:30px}

/* chat */
#pane-chat{display:none;flex-direction:column;height:calc(100vh - 210px)}
#pane-chat.on{display:flex}
.chat-context{font-family:var(--mono);font-size:10px;color:var(--ink-dim);
  padding:8px 22px;border-bottom:1px solid var(--line-soft);letter-spacing:.05em}
.conv-bar{display:flex;gap:8px;padding:10px 18px;align-items:center;
  border-bottom:1px solid var(--line-soft);overflow-x:auto}
.conv-scroll{display:flex;gap:8px}
.chat-log{flex:1;overflow-y:auto;padding:16px 18px;display:flex;flex-direction:column;gap:12px}
.msg{max-width:85%;padding:11px 14px;border-radius:14px;font-size:15px;line-height:1.6;white-space:pre-wrap}
.msg.user{align-self:flex-end;background:var(--bg3);border:1px solid var(--line)}
.msg.assistant{align-self:flex-start;background:transparent;border:1px solid var(--line-soft);color:var(--ink)}
.chat-input{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--line-soft);align-items:flex-end}
.chat-input textarea{flex:1;max-height:120px;font-family:var(--serif);font-size:15px}

/* modals */
.modal{position:fixed;inset:0;background:rgba(3,5,12,.7);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;z-index:50;padding:18px}
.modal[hidden]{display:none}
.modal-card{background:var(--bg2);border:1px solid var(--line);border-radius:16px;
  padding:22px;width:100%;max-width:420px;max-height:90vh;overflow-y:auto}
.modal-card.wide{max-width:520px}
.modal-card h2{font-size:20px;margin:0 0 16px;font-weight:500;letter-spacing:.02em}
.modal-actions{display:flex;gap:10px;margin-top:16px}
.modal-actions .btn{flex:1}
.place-wrap{position:relative}
.suggest{position:absolute;top:100%;left:0;right:0;z-index:30;margin-top:4px;
  background:var(--bg3);border:1px solid var(--line);border-radius:10px;overflow:hidden;
  box-shadow:0 12px 30px rgba(0,0,0,.5);display:none}
.suggest.on{display:block}
.suggest div{padding:11px 14px;font-size:13px;border-bottom:1px solid var(--line-soft);cursor:pointer}
.suggest div:last-child{border-bottom:none}
.suggest .smeta{font-family:var(--mono);font-size:10px;color:var(--ink-dim);margin-top:2px}
.conv-charts{display:flex;flex-direction:column;gap:8px;margin:10px 0}
.conv-chart{display:flex;align-items:center;gap:10px;padding:11px 13px;border:1px solid var(--line);
  border-radius:10px;cursor:pointer;font-family:var(--mono);font-size:13px}
.conv-chart.on{border-color:var(--gold);background:rgba(201,162,91,.08)}
.conv-chart .box{width:18px;height:18px;border:1px solid var(--line);border-radius:5px;flex:0 0 auto}
.conv-chart.on .box{background:var(--gold);border-color:var(--gold)}
.credits{font-family:var(--mono);font-size:12px;color:var(--ok);padding:6px 0 2px}
.key-state{font-size:9px;color:var(--ok)}

/* personajes / astrólogos */
.section-label{font-family:var(--mono);font-size:10px;letter-spacing:.26em;
  text-transform:uppercase;color:var(--gold);margin:18px 0 8px;
  border-top:1px solid var(--line-soft);padding-top:16px}
.modal-card .section-label:first-of-type{border-top:none;padding-top:0;margin-top:4px}
.persona-list{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}
.persona-row{display:flex;align-items:center;gap:12px;padding:10px 12px;
  border:1px solid var(--line);border-radius:11px}
.persona-row.active{border-color:var(--gold);background:rgba(201,162,91,.07)}
.avatar{width:42px;height:42px;border-radius:50%;object-fit:cover;flex:0 0 auto;
  background:var(--bg3);border:1px solid var(--line)}
.avatar-lg{width:88px;height:88px;border-radius:50%;object-fit:cover;
  background:var(--bg3);border:1px solid var(--line);display:block}
.persona-row .pinfo{flex:1;min-width:0}
.persona-row .pname{font-size:15px}
.persona-row .pbadge{font-family:var(--mono);font-size:9px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--ok)}
.persona-row .pacts{display:flex;gap:6px;flex:0 0 auto}
.mini-btn{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;
  background:transparent;border:1px solid var(--line);color:var(--ink-dim);
  border-radius:8px;padding:6px 9px;cursor:pointer}
.mini-btn.gold{border-color:var(--gold);color:var(--gold-bright)}
.persona-edit{display:flex;gap:16px;align-items:flex-start;margin-bottom:12px}
.persona-avatar-edit{display:flex;flex-direction:column;gap:8px;align-items:center;flex:0 0 auto}
.upload-btn{font-size:9px;padding:7px 9px;text-align:center;cursor:pointer}
.persona-fields{flex:1}

/* barra de astrólogo en el chat */
.astrologer-bar{display:flex;align-items:center;gap:10px;padding:10px 18px;
  border-bottom:1px solid var(--line-soft)}
.astrologer-bar .avatar{width:34px;height:34px}
.astrologer-bar .aname{font-style:italic;font-size:16px;color:var(--gold-bright)}
.astrologer-bar .arole{font-family:var(--mono);font-size:9px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-dim)}

/* ---------- indicador de "trabajando" (orbe astral pulsante) ---------- */
.working{display:flex;flex-direction:column;align-items:center;gap:14px;padding:40px 24px;
  color:var(--ink-dim);font-family:var(--mono);font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;text-align:center}
.orb{position:relative;width:54px;height:54px}
.orb::before,.orb::after{content:"";position:absolute;inset:0;border-radius:50%}
.orb::before{background:radial-gradient(circle at 50% 45%,var(--gold-bright),var(--gold) 45%,transparent 70%);
  animation:orb-pulse 1.6s ease-in-out infinite}
.orb::after{border:1px solid var(--gold);opacity:.5;animation:orb-ring 1.6s ease-out infinite}
.orb .spark{position:absolute;top:50%;left:50%;width:6px;height:6px;margin:-3px 0 0 -3px;
  border-radius:50%;background:var(--gold-bright);
  box-shadow:0 0 8px var(--gold-bright);
  transform-origin:-16px center;animation:orb-orbit 2.2s linear infinite}
@keyframes orb-pulse{0%,100%{transform:scale(.82);opacity:.85}50%{transform:scale(1);opacity:1}}
@keyframes orb-ring{0%{transform:scale(.8);opacity:.6}100%{transform:scale(1.7);opacity:0}}
@keyframes orb-orbit{from{transform:rotate(0) translateX(20px)}to{transform:rotate(360deg) translateX(20px)}}
.working .wtext{max-width:240px;line-height:1.6}

/* cursor de escritura en el chat mientras llega el stream */
.msg.streaming::after{content:"";display:inline-block;width:7px;height:1.05em;
  margin-left:2px;vertical-align:-2px;background:var(--gold-bright);
  animation:caret 1s step-end infinite}
@keyframes caret{0%,100%{opacity:1}50%{opacity:0}}

/* selectores de fecha de nacimiento (Día / Mes / Año) */
.date-selects{display:flex;gap:8px}
.date-selects select{flex:1;min-width:0}
#c-day{flex:0 0 70px}
#c-month{flex:1.4}

/* selección de astrólogo (usuario) */
#topbar-astrologer{cursor:pointer;border-radius:20px;padding:3px 10px 3px 3px;
  transition:background .15s}
#topbar-astrologer:hover{background:var(--bg3)}
.choose-list{display:flex;flex-direction:column;gap:10px;margin-top:6px;
  max-height:60vh;overflow-y:auto}
.choose-card{display:flex;gap:12px;align-items:center;padding:12px;
  border:1px solid var(--line);border-radius:14px;cursor:pointer;
  background:var(--bg2);transition:border-color .15s,background .15s}
.choose-card:hover{border-color:var(--gold)}
.choose-card.on{border-color:var(--gold-bright);background:var(--bg3)}
.choose-card .avatar{width:52px;height:52px;flex:0 0 52px;border-radius:50%;
  object-fit:cover;background:var(--bg3)}
.choose-card .ci{flex:1;min-width:0}
.choose-card .cname{font-family:var(--serif);font-size:18px;color:var(--gold-bright)}
.choose-card .cdesc{font-size:13px;color:var(--ink-dim);line-height:1.45;margin-top:2px}
.choose-card .cmark{flex:0 0 auto;color:var(--gold-bright);font-size:18px;opacity:0}
.choose-card.on .cmark{opacity:1}

/* botones de orden de astrólogos (admin) */
.porder{display:flex;flex-direction:column;gap:2px;margin-right:6px}
.mini-btn.ord{padding:1px 7px;line-height:1.2;min-width:0}
.mini-btn.ord:disabled{opacity:.3;cursor:default}

/* signo solar ocupando la fila completa de la leyenda */
.angles>div.full{grid-column:1 / -1}

/* sección de planetas colapsable */
.planets-acc{margin-top:18px}
.planets-acc>summary{cursor:pointer;list-style:none;display:flex;align-items:center;
  justify-content:space-between;gap:10px;user-select:none}
.planets-acc>summary::-webkit-details-marker{display:none}
.planets-acc>summary::after{content:"›";flex:0 0 auto;width:16px;text-align:center;
  font-size:20px;color:var(--ink-dim);transition:transform .2s;
  transform-origin:center;display:inline-block}
.planets-acc[open]>summary::after{transform:rotate(90deg)}
