/* Cozmo — "brass astrolabe in a dark observatory" facelift.
   Shared by the chart app + auth pages. */
:root{
  --ink:#0a0c10; --ink2:#12151d; --panel:#14171f; --panel2:#101319;
  --brass:#c9a227; --brass-dim:#8a7330; --line:#2c3340;
  --parch:#e9e2d0; --muted:#9aa0ad;
  --fire:#c65d3b; --earth:#8a9a5b; --air:#d4a843; --water:#5b8aa6;
  --retro:#d4683f;
  --sym:"Noto Sans Symbols 2","Segoe UI Symbol",serif;
}
*{box-sizing:border-box}
html,body{margin:0;min-height:100%}
body{
  background:
    radial-gradient(120% 90% at 50% 32%, #1a1f2b 0%, var(--ink2) 40%, var(--ink) 80%),
    var(--ink);
  color:var(--parch); font-family:"EB Garamond",Georgia,serif; min-height:100vh;
  overflow-x:hidden;
}
body::after{content:"";position:fixed;inset:0;pointer-events:none;opacity:.035;z-index:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");}
a{color:var(--brass)}
.brand-logo{width:26px;height:26px;display:block;flex:0 0 auto}
/* print a reading to PDF: isolate the reading panel, black-on-white */
@media print{
  body.printing-reading *{visibility:hidden!important}
  body.printing-reading #readingBack,body.printing-reading #readingBack *{visibility:visible!important}
  body.printing-reading #readingBack{position:absolute;inset:0;background:#fff;display:block;overflow:visible}
  body.printing-reading .reading{box-shadow:none;border:none;max-width:100%;background:#fff}
  body.printing-reading .rbody,body.printing-reading .rbody *{color:#16181d!important}
  body.printing-reading h2 #readingTitle{color:#16181d!important}
  body.printing-reading .rfoot,body.printing-reading #readingClose,
  body.printing-reading .rdg-fb,body.printing-reading .rdg-cal,body.printing-reading #readingOverlay{display:none!important}
}
/* landing / billboard */
.lp-top{position:relative;z-index:1;display:flex;align-items:center;gap:12px;padding:16px 22px;border-bottom:1px solid var(--line)}
.lp-top .mark{font-family:"Cinzel",serif;font-weight:600;letter-spacing:.34em;font-size:12px;color:var(--brass)}
.lp-hero{position:relative;z-index:1;text-align:center;max-width:680px;margin:0 auto;padding:54px 20px 30px}
.lp-mark{width:84px;height:84px;margin:0 auto 14px;filter:drop-shadow(0 6px 18px #0008)}
.lp-hero h1{font-family:"Cinzel",serif;font-weight:500;font-size:34px;line-height:1.15;margin:.1em 0 .3em}
.lp-sub{color:var(--muted);font-size:16px;line-height:1.6}
.lp-cta{font-size:16px;padding:11px 26px;margin-top:18px;display:inline-block;text-decoration:none}
.lp-fine{color:var(--muted);font-size:12px;margin-top:12px}
.lp-feats{position:relative;z-index:1;display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));
  gap:16px;max-width:900px;margin:24px auto;padding:0 20px}
.lp-feat{background:#0e1117aa;border:1px solid var(--line);border-radius:12px;padding:18px}
.lp-feat h3{font-family:"Cinzel",serif;color:var(--brass);font-size:14px;margin:0 0 6px}
.lp-feat p{color:var(--parch);font-size:14px;line-height:1.55;margin:0}
.lp-pricing{position:relative;z-index:1;max-width:960px;margin:28px auto 70px;padding:0 20px}
.lp-pricing h2{font-family:"Cinzel",serif;font-weight:500;text-align:center;color:var(--brass);font-size:20px}
.lp-tiers{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:16px;margin-top:18px}
.lp-tier{position:relative;background:#0e1117cc;border:1px solid var(--line);border-radius:14px;padding:22px 20px;display:flex;flex-direction:column}
.lp-tier.hot{border-color:var(--brass);box-shadow:0 12px 40px -20px #c9a22788}
.lp-badge{position:absolute;top:-10px;left:50%;transform:translateX(-50%);background:var(--brass);color:#1a140a;
  font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:2px 10px;border-radius:10px;font-family:"Cinzel",serif}
.lp-tname{font-family:"Cinzel",serif;color:var(--parch);font-size:16px;letter-spacing:.06em}
.lp-price{color:var(--brass);font-size:22px;font-family:"Spline Sans Mono",monospace;margin:6px 0 12px}
.lp-tier ul{list-style:none;padding:0;margin:0 0 16px;flex:1}
.lp-tier li{color:var(--parch);font-size:13.5px;line-height:1.5;padding-left:18px;position:relative;margin:7px 0}
.lp-tier li:before{content:"✦";position:absolute;left:0;color:var(--brass-dim);font-size:11px}
.lp-tier .btn{text-align:center;text-decoration:none}
.shared-body{line-height:1.62}.shared-body h3{font-family:"Cinzel",serif;color:var(--brass);font-size:15px;margin:18px 0 4px}
@media(max-width:560px){.lp-hero h1{font-size:27px}}
/* focus chips (chart CTA + onboarding) — narrow the reading to chosen life areas */
.focus-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center;margin:8px auto 0;max-width:580px}
.focus-lab{font-family:"Cinzel",serif;font-size:10px;letter-spacing:.18em;color:var(--brass-dim);text-transform:uppercase}
.focus-chips,.ob-chips{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}
.ob-chips{justify-content:flex-start;margin-top:7px}
.focus-chip,.ob-chip{background:none;border:1px solid var(--line);color:var(--muted);border-radius:14px;
  padding:3px 11px;font-size:12px;cursor:pointer;font-family:"EB Garamond",Georgia,serif}
.focus-chip:hover,.ob-chip:hover{border-color:var(--brass-dim);color:var(--parch)}
.focus-chip.on,.ob-chip.on{border-color:var(--brass);color:var(--brass);background:#c9a2271a}
/* animated starfield + Milky Way: behind all content, above the body gradient */
#starfield{position:fixed;inset:0;width:100%;height:100%;z-index:0;pointer-events:none}

/* ---- legal pages (terms / privacy) ---------------------------------- */
.legal{position:relative;z-index:1;max-width:820px;margin:0 auto;padding:32px 20px 80px}
.legal-card{background:#0e1117cc;border:1px solid var(--line);border-radius:14px;
  padding:30px 30px 34px;box-shadow:0 18px 50px -24px #000}
.legal .mark{font-family:"Cinzel",serif;font-weight:600;letter-spacing:.4em;font-size:11px;
  color:var(--brass);text-indent:.4em}
.legal .mark span{opacity:.5;margin:0 .15em}
.legal h1{font-family:"Cinzel",serif;font-weight:500;font-size:26px;margin:.3em 0 .1em}
.legal h2{font-family:"Cinzel",serif;font-weight:500;font-size:15px;color:var(--brass);
  letter-spacing:.04em;margin:26px 0 6px}
.legal p,.legal li{color:var(--parch);line-height:1.62;font-size:15px}
.legal ul{padding-left:20px;margin:6px 0}
.legal li{margin:4px 0}
.legal .eff{color:var(--muted);font-style:italic;font-size:13px;margin-top:2px}
.legal .note{background:#1a1f2b80;border:1px solid var(--line);border-left:3px solid var(--brass);
  border-radius:6px;padding:10px 14px;color:var(--muted);font-size:13.5px;font-style:italic}
.legal .legal-foot{margin-top:30px;padding-top:16px;border-top:1px solid var(--line);
  color:var(--muted);font-size:14px}
/* signup agreement checkbox */
.agree{display:flex;align-items:flex-start;gap:9px;margin:12px 0 4px;font-size:13.5px;
  line-height:1.45;color:var(--muted);text-transform:none;letter-spacing:0}
.agree input{width:auto;margin-top:3px;flex:0 0 auto;accent-color:var(--brass)}
/* astrologer apply page */
.ob-h2{font-family:"Cinzel",serif;font-weight:500;font-size:14px;color:var(--brass);
  letter-spacing:.04em;margin:18px 0 6px}
.reqs{margin:4px 0 18px;padding-left:20px}
.reqs li{margin:6px 0;line-height:1.55;color:var(--parch);font-size:14px}
.agree-err{color:var(--retro);font-size:13px;margin-top:8px}
/* point-of-sale legal microcopy under Upgrade CTAs */
.legal-mini{margin:10px 0 0;font-size:11.5px;line-height:1.5;color:var(--muted)}
.legal-mini a{color:var(--brass)}
/* footer legal links */
.site-foot{position:relative;z-index:1;text-align:center;padding:22px 16px 30px;
  color:var(--muted);font-size:12.5px}
.site-foot a{color:var(--muted)}.site-foot a:hover{color:var(--brass)}
.site-foot .dot{opacity:.5;margin:0 8px}

/* ---- top bar ---------------------------------------------------------- */
.topbar{position:relative;z-index:1;display:flex;align-items:center;gap:16px;
  flex-wrap:wrap;padding:14px 22px;border-bottom:1px solid var(--line);background:#0c0f15cc}
.mark{font-family:"Cinzel",serif;font-weight:600;letter-spacing:.40em;font-size:13px;
  color:var(--brass);text-indent:.40em}
.mark span{color:var(--parch)}
.topbar .grow{flex:1}
.who{color:var(--muted);font-size:13px}
.who b{color:var(--parch);font-weight:500}

/* ---- generic controls ------------------------------------------------- */
select,input,button,.btn{font-family:inherit;font-size:14px;color:var(--parch);
  background:var(--panel);border:1px solid var(--line);border-radius:5px;padding:8px 11px}
input::placeholder{color:#6a7180}
select:focus,input:focus{outline:none;border-color:var(--brass)}
button,.btn{cursor:pointer;letter-spacing:.02em}
button:hover,.btn:hover{border-color:var(--brass);color:#fff}
button.primary,.btn.primary{background:linear-gradient(180deg,#caa531,#9c7d22);
  border-color:#b8941f;color:#1a140a;font-weight:600}
button.primary:hover{filter:brightness(1.08);color:#1a140a}
button.ghost{background:transparent}
label.fld{display:flex;flex-direction:column;gap:4px;font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted)}
label.fld input,label.fld select{font-size:14px;text-transform:none;letter-spacing:0;color:var(--parch)}

/* ---- screen tabs ------------------------------------------------------ */
.tabs{position:relative;z-index:1;display:flex;gap:2px;padding:10px 22px 0;border-bottom:1px solid var(--line)}
.tab{font-family:"Cinzel",serif;font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);background:transparent;border:1px solid transparent;border-bottom:none;
  border-radius:6px 6px 0 0;padding:9px 16px}
.tab:hover{color:var(--parch)}
.tab.active{color:var(--brass);border-color:var(--line);background:var(--panel);
  position:relative;top:1px}

/* ---- stage: wheel + side panel --------------------------------------- */
.stage{position:relative;z-index:1;display:grid;
  grid-template-columns:minmax(300px,1fr) 366px;gap:26px;
  padding:20px 22px 50px;align-items:start;max-width:1200px;margin:0 auto}
@media(max-width:900px){.stage{grid-template-columns:1fr}}
/* wheel sized by the smaller of viewport width AND height so it fits any screen */
.wheel-wrap{position:relative;width:min(90vw,74vh,560px);max-width:100%;margin:0 auto;
  animation:rise 1s cubic-bezier(.2,.7,.2,1) both}
@keyframes rise{from{opacity:0;transform:scale(.97)}to{opacity:1;transform:none}}
@media(max-width:600px){
  .topbar{padding:11px 14px;gap:10px}
  .tabs{padding:8px 14px 0}
  .stage{padding:14px 12px 40px;gap:16px}
  .wheel-wrap{width:min(92vw,66vh,430px)}
}
svg#wheel{width:100%;height:auto;display:block;overflow:visible}
.wheel-cap{text-align:center;color:var(--muted);font-style:italic;font-size:12.5px;margin-top:10px}

.panel{background:linear-gradient(180deg,var(--panel),var(--panel2));
  border:1px solid var(--line);border-radius:5px;
  box-shadow:0 1px 0 rgba(255,255,255,.03) inset,0 18px 40px -24px #000;
  overflow:hidden;margin-bottom:18px}
.panel h2{font-family:"Cinzel",serif;font-size:11px;letter-spacing:.26em;color:var(--brass);
  margin:0;padding:12px 15px 10px;border-bottom:1px solid var(--line);background:#0e1118;
  text-transform:uppercase}
.panel .body{padding:13px 15px}
.big3{padding:12px 15px;border-bottom:1px solid var(--line);font-size:15px;line-height:1.7}
.big3 b{font-family:"Cinzel",serif;font-weight:500;color:var(--parch)}
.sym{font-family:var(--sym)}

table.bodies{width:100%;border-collapse:collapse;font-size:12.5px;table-layout:fixed}
table.bodies td,table.bodies th{padding:5px 8px;text-align:left;border-bottom:1px solid #1c212b;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
table.bodies th{font-family:"Cinzel",serif;font-size:9px;letter-spacing:.1em;color:var(--muted);
  text-transform:uppercase;font-weight:500;background:#0e1118}
table.bodies td.sub{color:var(--muted);font-size:11px;font-family:"Spline Sans Mono",monospace}
table.bodies td.num,table.bodies th.num{text-align:right;font-family:"Spline Sans Mono",monospace;color:var(--muted);width:30px}
table.bodies tr:last-child td{border-bottom:none}
.gl{font-family:var(--sym);font-size:15px;margin-right:5px;vertical-align:-1px}
.rx{color:var(--retro);font-size:11px;margin-left:3px;font-family:var(--sym)}
/* aspects table */
table.aspects td.asp{text-align:center;font-family:var(--sym);font-size:15px;width:26px;padding:5px 2px}
table.aspects td.asp.hard{color:var(--retro)}
table.aspects td.asp.soft{color:var(--water)}
table.aspects td.asp.neutral{color:var(--muted)}
table.aspects td.num{width:44px}

/* control rows inside panels */
.ctl{display:flex;flex-wrap:wrap;gap:10px;align-items:end}
.ctl .narrow{width:74px}
.ctl-row{display:flex;gap:8px;margin-top:10px}
.seg{display:inline-flex;border:1px solid var(--line);border-radius:5px;overflow:hidden}
.seg button{border:none;border-radius:0;background:var(--panel);padding:8px 12px}
.seg button.on{background:var(--brass);color:#1a140a;font-weight:600}
.quick{display:flex;flex-wrap:wrap;gap:8px}
.quick button{font-size:12.5px;padding:7px 10px}
.hint{color:var(--muted);font-size:12px;margin:2px 0 0}
.err{color:var(--fire);font-size:12.5px;margin-top:8px;min-height:1em}

/* predictive readout */
table.readout{width:100%;border-collapse:collapse;font-size:12.5px}
table.readout td{padding:5px 15px;border-bottom:1px solid #1c212b}
table.readout td:first-child{color:var(--muted);font-family:"Cinzel",serif;font-size:10px;
  letter-spacing:.12em;text-transform:uppercase}
table.readout td:last-child{text-align:right;font-family:"Spline Sans Mono",monospace;color:var(--parch)}
table.readout tr.grp td{background:#0e1118;color:var(--brass);font-family:"Cinzel",serif;
  letter-spacing:.16em;font-size:9.5px}

/* ---- modal (add chart) ----------------------------------------------- */
.modal-back{position:fixed;inset:0;z-index:20;background:#05070bcc;display:none;
  align-items:flex-start;justify-content:center;padding:6vh 16px;overflow:auto}
.modal-back.open{display:flex}
.modal{width:min(520px,100%);background:linear-gradient(180deg,var(--panel),var(--panel2));
  border:1px solid var(--line);border-radius:8px;box-shadow:0 30px 80px -30px #000}
.modal h2{font-family:"Cinzel",serif;font-size:13px;letter-spacing:.2em;color:var(--brass);
  margin:0;padding:16px 20px;border-bottom:1px solid var(--line);text-transform:uppercase}
.modal .grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:20px}
.modal .grid .full{grid-column:1/-1}
.modal .foot{display:flex;justify-content:flex-end;gap:10px;padding:0 20px 20px}
/* city autocomplete dropdown */
.city-results{position:absolute;top:100%;left:0;right:0;z-index:5;display:none;max-height:210px;
  overflow-y:auto;background:#0c0f15;border:1px solid var(--line);border-top:none;border-radius:0 0 6px 6px;
  box-shadow:0 16px 30px -16px #000}
.city-item{padding:8px 11px;font-size:13px;color:var(--parch);cursor:pointer;border-bottom:1px solid #161b22;
  text-transform:none;letter-spacing:0}
.city-item:hover{background:var(--brass);color:#1a140a}
.city-item:last-child{border-bottom:none}

/* ---- settings page ---------------------------------------------------- */
.settings-wrap{position:relative;z-index:1;max-width:620px;margin:24px auto;padding:0 16px}
.settings-wrap .panel{margin-bottom:18px}
.settings-wrap .btn{text-decoration:none;display:inline-block}

/* ---- reading modal ---------------------------------------------------- */
.reading-back{position:fixed;inset:0;z-index:25;background:#05070bdd;display:none;
  align-items:flex-start;justify-content:center;padding:5vh 16px;overflow:auto}
.reading-back.open{display:flex}
.reading{width:min(680px,100%);background:linear-gradient(180deg,var(--panel),var(--panel2));
  border:1px solid var(--line);border-radius:8px;box-shadow:0 30px 80px -30px #000}
.reading h2{font-family:"Cinzel",serif;font-size:14px;letter-spacing:.18em;color:var(--brass);
  margin:0;padding:15px 20px;border-bottom:1px solid var(--line);text-transform:uppercase;
  display:flex;align-items:center;gap:10px}
.reading .rbody{padding:18px 22px;font-size:16px;line-height:1.62;max-height:64vh;overflow:auto}
.reading .rbody h3{font-family:"Cinzel",serif;font-size:15px;color:var(--brass);margin:18px 0 6px}
.reading .rbody h3:first-child{margin-top:0}
.reading .rbody p{margin:0 0 12px}
.reading .rnote{color:var(--air);font-style:italic;font-size:13px;border-left:2px solid var(--brass-dim);
  padding-left:10px;margin:0 0 14px}
.reading .rfoot{display:flex;justify-content:flex-end;gap:10px;padding:0 22px 18px}
.reading .spin{color:var(--muted);font-style:italic}
.read-accuracy{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}
.read-accuracy label{display:flex;align-items:center;gap:5px;font-size:12px;text-transform:none;
  letter-spacing:0;color:var(--parch);background:var(--panel);border:1px solid var(--line);
  border-radius:6px;padding:6px 10px;cursor:pointer}
.read-accuracy input{width:auto}
.ev-list{list-style:none;padding:0;margin:8px 0;font-size:13px}
.ev-list li{display:flex;align-items:center;gap:8px;padding:5px 2px;border-bottom:1px solid #1b212b}
.ev-list .evd{font-family:"Spline Sans Mono",monospace;color:var(--muted);flex:0 0 86px}
.ev-list .evl{flex:1}
.ev-list .evx{color:var(--fire);cursor:pointer;font-weight:600}
.cand-list{margin:6px 0 0}
.cand-list .cand{display:flex;align-items:center;gap:10px;padding:6px 0;border-bottom:1px solid #1b212b}
.cand-list .ct{font-family:"Spline Sans Mono",monospace;font-size:15px;color:var(--parch);flex:0 0 56px}
.cand-list .cbar{height:8px;border-radius:4px;background:linear-gradient(90deg,var(--brass-dim),var(--brass))}
.cand-list .best .ct{color:var(--brass);font-weight:700}

/* ---- auth pages ------------------------------------------------------- */
.auth-wrap{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column;
  align-items:center;justify-content:center;padding:40px 18px;gap:6px}
.auth-card{width:min(380px,100%);background:linear-gradient(180deg,var(--panel),var(--panel2));
  border:1px solid var(--line);border-radius:8px;padding:26px 26px 22px;
  box-shadow:0 30px 80px -30px #000}
.auth-card h1{font-family:"Cinzel",serif;font-weight:500;font-size:22px;margin:0 0 2px;text-align:center}
.auth-card .mark{display:block;text-align:center;margin-bottom:14px}
.auth-card form{display:flex;flex-direction:column;gap:12px;margin-top:14px}
.auth-card input{width:100%}
.auth-card label{font-size:12px;color:var(--muted)}
.auth-card .helptext,.auth-card ul{color:var(--muted);font-size:11.5px;margin:2px 0 0;padding-left:16px}
.auth-card .errornote,.auth-card .errorlist{color:var(--fire);font-size:12.5px;list-style:none;padding:0;margin:0}
.auth-alt{color:var(--muted);font-size:13px}

/* ---------- Forecast + calendar push ---------- */
.cal-row{display:flex;flex-wrap:wrap;gap:8px}
.cal-row .btn{font-size:13px;text-decoration:none}
.cal-btn.connected{border-color:var(--brass);color:var(--brass)}
.cal-btn:disabled{opacity:.5;cursor:not-allowed}
.cal-btn:disabled:hover{border-color:var(--line);color:var(--parch)}
.cal-disc{font-size:11px}
#calStatus{line-height:1.6}
.fc-list{display:flex;flex-direction:column}
.fc-item{display:grid;grid-template-columns:84px 1fr auto;gap:10px;align-items:start;
  padding:10px 15px;border-bottom:1px solid var(--line);border-left:3px solid var(--line)}
.fc-item.s-prominent{border-left-color:var(--retro)}
.fc-item.s-notable{border-left-color:var(--air)}
.fc-item.s-quiet{border-left-color:var(--water)}
.fc-d{font-family:"Spline Sans Mono",monospace;font-size:11.5px;color:var(--muted);padding-top:2px}
.fc-main{font-size:14px;line-height:1.45}
.fc-main b{font-weight:600}
.fc-g{font-family:var(--sym);font-size:17px;color:var(--parch);margin-right:5px}
.fc-area{color:var(--brass);font-style:italic;margin-left:6px}
.fc-watch{color:var(--muted);font-size:12px;margin-top:2px}
.fc-st{font-family:"Cinzel",serif;font-size:8.5px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--muted);padding-top:3px}
.fc-item.s-prominent .fc-st{color:var(--retro)}
/* tone badge + the "why" reveal */
.fc-tone{font-size:9px;letter-spacing:.04em;border-radius:4px;padding:0 5px;margin-left:6px;
  border:1px solid var(--line);text-transform:uppercase;vertical-align:middle}
.fc-tone.t-caution{color:var(--retro);border-color:var(--retro)}
.fc-tone.t-ease{color:var(--earth);border-color:var(--earth)}
.fc-tone.t-neutral{color:var(--muted)}
.fc-why{margin-top:4px;font-size:11.5px;color:var(--muted);font-style:italic;
  border-left:2px solid var(--line);padding-left:8px}
.fc-why b{color:var(--parch);font-style:normal;text-transform:capitalize}
/* per-motion feedback logger (power-user) */
.fc-log{margin-top:5px}
.fc-logbtn{background:none;border:none;color:var(--brass-dim);font-size:11px;cursor:pointer;padding:0}
.fc-logbtn:hover{color:var(--brass)}
.fc-logform{display:flex;gap:6px;align-items:center;flex-wrap:wrap;margin-top:5px}
.fc-rate button{background:none;border:1px solid var(--line);color:var(--muted);border-radius:4px;
  font-size:11px;padding:2px 6px;cursor:pointer}
.fc-rate button.on{border-color:var(--brass);color:var(--brass)}
.fc-lognote{flex:1;min-width:120px;background:var(--ink2,#12151d);color:var(--parch);
  border:1px solid var(--line);border-radius:4px;padding:4px 6px;font-size:12px}
.fc-logwhen{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:4px}
.fc-logdate{background:var(--ink2,#12151d);color:var(--parch);border:1px solid var(--line);
  border-radius:4px;padding:2px 5px;font-size:11px}
.fc-logsave{font-size:11px;padding:3px 9px}
.fc-logdone{color:var(--earth);font-size:11.5px}
/* progression-system badge (P2/P3/P4) on a motion */
.fc-sys{font-family:"Spline Sans Mono",monospace;font-size:9px;letter-spacing:.04em;
  border:1px solid var(--brass-dim);border-radius:4px;padding:0 4px;margin-left:6px;
  color:var(--brass-dim);vertical-align:middle}
.fc-sys.s-P2{color:var(--brass);border-color:var(--brass)}
.fc-sys.s-P3{color:var(--air);border-color:var(--air)}
.fc-sys.s-P4{color:var(--water);border-color:var(--water)}

/* forecast/transit timing + reading calendar */
.fc-when{font-family:"Spline Sans Mono",monospace;font-size:11px;color:var(--brass)}
.fc-sub{color:var(--muted);font-size:12px}
.rdg-ul{margin:6px 0 10px;padding-left:20px}
.rdg-ul li{margin:4px 0;line-height:1.55}
.rbody strong{color:var(--parch);font-weight:600}
.rbody em{color:var(--brass);font-style:italic}
/* feedback capture under a reading */
.rdg-fb{margin-top:18px;padding-top:14px;border-top:1px dashed var(--line)}
.rdg-fb .fb-head{font-size:13px;color:var(--muted);margin-bottom:8px}
.rdg-fb .fb-rate{display:flex;gap:8px;margin-bottom:8px;flex-wrap:wrap}
.rdg-fb .fb-rate button.on{border-color:var(--brass);color:var(--brass)}
.rdg-fb .fb-note{width:100%;background:var(--panel,#12151d);color:var(--parch);
  border:1px solid var(--line);border-radius:6px;padding:8px;margin-bottom:8px}
.rdg-fb .fb-done{color:var(--earth);font-size:13px}
.fb-pill{font-size:11px;padding:1px 8px;border-radius:10px;border:1px solid var(--line)}
.fb-pill.fb-hit{color:var(--earth);border-color:var(--earth)}
.fb-pill.fb-partial{color:var(--air);border-color:var(--air)}
.fb-pill.fb-miss{color:var(--retro);border-color:var(--retro)}
.rdg-cal{margin-top:18px;padding-top:12px;border-top:1px solid var(--line);
  color:var(--muted);font-size:13px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.rdg-cal .btn{font-size:12px;text-decoration:none}

/* ---------- Admin dashboard (/manage) ---------- */
.manage-wrap{max-width:1000px;margin:0 auto;padding:22px}
.manage-nav{display:flex;gap:4px;flex-wrap:wrap;border-bottom:1px solid var(--line);margin-bottom:20px}
.manage-nav a{padding:9px 16px;font-family:"Cinzel",serif;font-size:12px;letter-spacing:.12em;
  color:var(--muted);text-decoration:none;border:1px solid transparent;border-bottom:none;border-radius:6px 6px 0 0}
.manage-nav a:hover{color:var(--parch)}
.manage-nav a.active{color:var(--brass);border-color:var(--line);background:var(--panel)}
.manage-nav a.dim{color:#5a626f;cursor:default}
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:18px 16px;text-align:center}
.stat .n{font-family:"Cinzel",serif;font-size:30px;color:var(--brass);line-height:1}
.stat .l{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:8px}
.user-tbl select{padding:5px 8px;font-size:13px}
.user-tbl td{vertical-align:middle}
.tag{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:#1a140a;background:var(--brass);
  padding:2px 6px;border-radius:4px;vertical-align:middle}

/* ---------- Saved readings + premium upsell ---------- */
.rfoot{display:flex;gap:8px;align-items:center}
.upsell{text-align:center;padding:24px 16px}
.upsell h3{font-family:"Cinzel",serif;color:var(--brass);font-size:16px;letter-spacing:.1em;margin:0 0 8px}
.upsell p{color:var(--muted);max-width:380px;margin:0 auto}
.saved-list{list-style:none;margin:0;padding:0}
.saved-list li{display:flex;align-items:center;gap:10px;padding:11px 6px;border-bottom:1px solid var(--line);cursor:pointer}
.saved-list li:hover{background:#0e1118}
.saved-list .sv-t{flex:1;color:var(--parch)}
.saved-list .sv-d{color:var(--muted);font-size:12px;font-family:"Spline Sans Mono",monospace}
.saved-list .sv-x{color:var(--muted);font-size:13px;padding:2px 6px}
.saved-list .sv-x:hover{color:var(--retro)}

/* ---------- Onboarding wizard ---------- */
.ob-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.ob-card{width:100%;max-width:480px;background:var(--panel);border:1px solid var(--line);
  border-radius:14px;padding:26px 26px 22px;box-shadow:0 18px 60px #0008}
.ob-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.ob-prog{display:flex;gap:6px}
.ob-prog span{width:26px;height:4px;border-radius:2px;background:var(--line)}
.ob-prog span.on{background:var(--brass)}
.ob-step h1{font-family:"Cinzel",serif;color:var(--parch);font-size:24px;font-weight:500;margin:0 0 4px}
.ob-sub{color:var(--muted);margin:0 0 18px}
.ob-card .fld{width:100%}
.ob-card .fld input,.ob-card .fld select{width:100%;font-size:16px;padding:11px 12px}
.ob-q{font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.ob-seg{display:flex;margin-top:8px;width:100%}
.ob-seg button{flex:1}
.muted{color:var(--muted);text-transform:none;letter-spacing:0;font-size:12px}
.ob-nav{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:24px}
.ob-nav .primary{padding:11px 22px;font-size:15px}
.ob-err{color:var(--retro);font-size:13px;margin-top:10px;min-height:16px}
.ob-verify{margin-top:10px;min-height:20px;font-size:13px}
.ob-ok{color:var(--air)}
.btn.primary{text-decoration:none;display:inline-block}

/* life-stage toggle matrix */
.ls-matrix{margin-top:10px;border:1px solid var(--line);border-radius:6px;background:#0e1118}
.ls-matrix summary{cursor:pointer;padding:9px 12px;font-family:"Cinzel",serif;font-size:12px;
  letter-spacing:.1em;color:var(--brass)}
.ls-grid{width:100%;border-collapse:collapse;font-size:12.5px}
.ls-grid th{font-family:"Cinzel",serif;font-size:9px;letter-spacing:.06em;color:var(--muted);
  text-transform:capitalize;padding:4px 8px;text-align:center;font-weight:500}
.ls-grid td{padding:5px 8px;text-align:center;border-top:1px solid var(--line)}
.ls-grid td.ls-p{text-align:left;color:var(--parch)}
.ls-grid input{width:auto}

/* tiers / plans editor */
.ls-q{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.tier-kinds,.tier-flags{display:flex;flex-wrap:wrap;gap:14px;margin-top:6px}
.tier-kinds label,.tier-flags label{display:flex;align-items:center;gap:6px;font-size:13.5px;
  text-transform:none;letter-spacing:0;color:var(--parch);text-transform:capitalize}
.tier-kinds input,.tier-flags input{width:auto}

/* astrologer directory */
.astro-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.astro-card{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:18px;display:flex;flex-direction:column}
.astro-card h3{font-family:"Cinzel",serif;color:var(--parch);margin:0 0 4px;font-size:17px;font-weight:500}
.astro-head{color:var(--brass);font-size:13px;font-style:italic;margin-bottom:6px}
.astro-spec{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}
.astro-bio{font-size:14px;line-height:1.5;flex:1;margin:0 0 14px}
.astro-foot{display:flex;align-items:center;justify-content:space-between;gap:10px}
.astro-rate{color:var(--brass);font-family:"Spline Sans Mono",monospace;font-size:13px}
.astro-share{font-size:13px;text-decoration:none}

/* ---------- Reading loading overlay ---------- */
.ro{position:fixed;inset:0;z-index:40;display:none;flex-direction:column;align-items:center;
  justify-content:center;gap:16px;background:#05070bf5;backdrop-filter:blur(3px);padding:20px;text-align:center}
.ro.on{display:flex}
.ro-stage{position:relative;width:220px;height:220px}
.ro-ring{position:absolute;inset:0;border-radius:50%;border:1px solid var(--brass-dim);
  animation:ro-spin 26s linear infinite}
.ro-ring::before{content:"";position:absolute;inset:22px;border-radius:50%;border:1px solid var(--line)}
.ro-ring .g{position:absolute;left:50%;top:50%;font-family:var(--sym);font-size:18px;color:var(--brass)}
.ro-sweep{position:absolute;left:50%;top:6px;bottom:50%;width:2px;margin-left:-1px;
  background:linear-gradient(var(--brass),transparent);transform-origin:bottom center;
  animation:ro-spin 2.6s linear infinite}
.ro-hub{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-size:34px;
  animation:ro-pulse 2s ease-in-out infinite}
.ro-status{font-family:"Cinzel",serif;color:var(--parch);font-size:16px;letter-spacing:.05em;min-height:22px}
.ro-sub{color:var(--muted);font-size:13px;margin:0;max-width:340px}
.ro #roCancel{margin-top:4px}
@keyframes ro-spin{to{transform:rotate(360deg)}}
@keyframes ro-pulse{0%,100%{transform:translate(-50%,-50%) scale(1);opacity:.8}
  50%{transform:translate(-50%,-50%) scale(1.16);opacity:1}}
@media (prefers-reduced-motion:reduce){.ro-ring,.ro-sweep,.ro-hub{animation:none}}

/* ---------- Mobile IA: viewport fit, menu, chartbar, data tabs ---------- */
html,body{max-width:100%;overflow-x:hidden}
.topbar{flex-wrap:wrap}
.tabs{flex-wrap:wrap}                 /* stack tabs instead of horizontal scroll */
.tabs .tab{flex:1 1 auto;text-align:center;white-space:nowrap}

/* hamburger menu */
.menu{position:relative}
#menuBtn{font-size:18px;line-height:1;padding:6px 12px}
.menu-pop{position:absolute;right:0;top:calc(100% + 6px);min-width:190px;z-index:30;
  background:var(--panel);border:1px solid var(--line);border-radius:8px;display:none;
  flex-direction:column;overflow:hidden;box-shadow:0 14px 44px #000a}
.menu-pop.on{display:flex}
.menu-pop a,.menu-pop button{background:transparent;border:0;border-bottom:1px solid var(--line);
  border-radius:0;text-align:left;width:100%;padding:12px 15px;color:var(--parch);
  text-decoration:none;font-size:14px;letter-spacing:0;text-transform:none;cursor:pointer}
.menu-pop a:hover,.menu-pop button:hover{background:#0e1118;color:var(--brass)}
.menu-pop form{margin:0}
.menu-pop > :last-child{border-bottom:0}

/* chart control bar above the wheel */
.chartbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:12px}
.chartbar #chartSel{flex:1 1 150px;min-width:0}
.chartbar .cb-fld{display:flex;align-items:center;gap:6px;font-size:10px;color:var(--muted);
  text-transform:uppercase;letter-spacing:.05em}
.chartbar .cb-fld select{font-size:13px;text-transform:none;letter-spacing:0}

/* luminaries block under the wheel */
.panel.lum{margin-top:12px}
.panel.lum .big3{border-bottom:0}

/* segmented data tabs (Bodies / Aspects / Data) */
.seg.datatabs{display:flex;width:100%;border-radius:0;border:0;border-bottom:1px solid var(--line)}
.seg.datatabs button{flex:1;border-radius:0;background:transparent;border:0;
  border-bottom:2px solid transparent;padding:11px 8px;color:var(--muted);
  font-family:"Cinzel",serif;font-size:11px;letter-spacing:.14em}
.seg.datatabs button.on{color:var(--brass);border-bottom-color:var(--brass);background:#0e1118}
.data-view table{width:100%}

/* collapsible predictive readout */
.readout-wrap{border-top:1px solid var(--line)}
.readout-wrap summary{cursor:pointer;padding:12px 15px;font-family:"Cinzel",serif;font-size:11px;
  letter-spacing:.2em;color:var(--brass);text-transform:uppercase}

/* ---------- Mobile screenshot fixes (2026-06-12) ---------- */
.topbar{z-index:10}                          /* paint topbar (and its menu) above the tabs */
.menu-pop{background:#161a23}                 /* fully opaque — no tab bleed-through */
/* House / Orb column was crushed to "1…" / "0…" — give it room, no ellipsis */
table.bodies td.num,table.bodies th.num{width:46px;min-width:46px;padding-left:2px;
  overflow:visible;text-overflow:clip}
/* prominent reading CTA under the wheel */
.gen-reading{display:block;width:100%;margin:12px 0 0;font-size:15px;padding:13px}
/* extended "Data" table scrolls sideways instead of cropping the 6 columns */
.data-view[data-d="data"]{overflow-x:auto;-webkit-overflow-scrolling:touch}
#bodiesExtTbl{table-layout:auto;width:auto;min-width:100%}
#bodiesExtTbl td,#bodiesExtTbl th{overflow:visible;text-overflow:clip;white-space:nowrap}
