:root{--bg:#0b1020;--card:#121a33;--txt:#e9ecff;--muted:#aab0d6;--line:rgba(255,255,255,.08);--pri:#6ea8fe;--ok:#3ddc97;--bad:#ff6b6b;}
*{box-sizing:border-box}html,body{height:100%}body{margin:0;font:16px/1.5 system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Noto Sans",sans-serif;background:radial-gradient(1200px 600px at 20% -10%,rgba(110,168,254,.18),transparent 60%),radial-gradient(900px 500px at 100% 0%,rgba(61,220,151,.14),transparent 55%),var(--bg);color:var(--txt)}
a{color:inherit;text-decoration:none}a:hover{text-decoration:underline}
.container{max-width:980px;margin:0 auto;padding:18px}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0}
.brand{display:flex;gap:10px;align-items:center}
.logo{width:30px;height:30px;display:block}
.brand-title{font-weight:850;letter-spacing:0.2px}
.brand-badge{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,rgba(110,168,254,.9),rgba(61,220,151,.85));display:flex;align-items:center;justify-content:center;font-weight:800;color:#0b1020}
.brand-title{font-weight:800}
.lang{display:flex;gap:10px;align-items:center;color:var(--muted);font-size:13px}
.lang a{padding:6px 10px;border:1px solid var(--line);border-radius:999px}
.lang a.active{border-color:rgba(110,168,254,.6);color:var(--txt)}
.card{background:rgba(18,26,51,.86);border:1px solid var(--line);border-radius:18px;box-shadow:0 18px 42px rgba(0,0,0,.25);backdrop-filter: blur(8px)}
.card-pad{padding:18px}
.grid{display:grid;gap:14px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
@media (max-width:760px){.grid-2{grid-template-columns:1fr}}
.h1{font-size:28px;line-height:1.2;margin:0 0 10px;font-weight:850}
.sub{color:var(--muted);margin:0 0 16px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 14px;border-radius:14px;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--txt);cursor:pointer}
.btn.primary{background:rgba(110,168,254,.18);border-color:rgba(110,168,254,.4)}
.btn:disabled{opacity:.55;cursor:not-allowed}
.input{width:100%;padding:12px 12px;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.03);color:var(--txt);outline:none}
.label{font-size:13px;color:var(--muted);margin:0 0 6px}
.navbar{position:sticky;bottom:0;z-index:20;background:rgba(11,16,32,.78);backdrop-filter:blur(10px);border-top:1px solid var(--line)}
.navbar .inner{display:flex;justify-content:space-around;gap:8px;padding:10px 8px;max-width:980px;margin:0 auto}
.navitem{display:flex;flex-direction:column;align-items:center;gap:4px;font-size:12px;color:var(--muted)}
.navitem.active{color:var(--txt)}
.kv{display:flex;flex-wrap:wrap;gap:10px}
.kv .pill{padding:6px 10px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.03);font-size:12px;color:var(--muted)}
.hr{height:1px;background:var(--line);margin:16px 0}
.small{font-size:12px;color:var(--muted)}
.notice{padding:10px 12px;border-radius:12px;border:1px dashed rgba(110,168,254,.4);background:rgba(110,168,254,.10);color:var(--muted)}
.table{width:100%;border-collapse:separate;border-spacing:0}
.table th,.table td{padding:10px;border-bottom:1px solid var(--line);text-align:left;font-size:14px}
.table th{color:var(--muted);font-weight:600}

/* ===== v1.1 layout helpers ===== */
.topbar__row{display:flex;align-items:center;justify-content:space-between;gap:14px}
.nav{display:flex;gap:14px;flex-wrap:wrap;align-items:center;font-size:14px}
.nav a{color:var(--muted)}
.nav a:hover{color:var(--txt)}

.navbtn{display:none;padding:10px 12px;border-radius:14px;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--txt);cursor:pointer}

@media (max-width:860px){
  .nav{display:none;position:absolute;top:62px;left:18px;right:18px;flex-direction:column;gap:10px;padding:12px;border:1px solid var(--line);border-radius:18px;background:rgba(18,26,51,.96);box-shadow:0 18px 42px rgba(0,0,0,.35)}
  .nav a{padding:10px 12px;border-radius:12px;background:rgba(255,255,255,.02)}
  .navbtn{display:inline-flex}
  html.nav-open .nav{display:flex}
}

.error{color:var(--bad)}

.footer{margin-top:28px;border-top:1px solid var(--line);background:rgba(11,16,32,.35)}
.footer__row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:18px 0;color:var(--muted);font-size:13px}
.footer__links{display:flex;gap:14px}

.row{display:flex;align-items:center;flex-wrap:wrap}
.gap{gap:12px}

.form{display:grid;gap:12px}
.form label{display:grid;gap:6px}
.form input, .form select, .form textarea{width:100%;padding:12px 12px;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.03);color:var(--txt);outline:none}
.checkbox{display:flex !important;align-items:center;gap:8px;font-size:13px;color:var(--muted)}
.checkbox input{width:auto}

.muted{color:var(--muted)}

.grid2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}
@media (max-width:760px){.grid2{grid-template-columns:1fr}}

.result{margin-top:16px}
.result .svg-wrap{background:rgba(255,255,255,.02);border:1px solid var(--line);border-radius:18px;padding:12px;overflow:auto}
.result .svg-wrap svg{max-width:100%;height:auto}

/* ===== Astrology wheel (SVG) ===== */
.wheel-grid{display:grid;grid-template-columns:minmax(0,560px) minmax(0,1fr);gap:16px;align-items:start}
@media (max-width:860px){.wheel-grid{grid-template-columns:1fr}}
.wheel-box{background:rgba(255,255,255,.02);border:1px solid var(--line);border-radius:18px;padding:12px;position:relative;overflow:hidden}
.wheel-svg{width:100%;height:auto;display:block}
.wheel-legend{border:1px solid var(--line);border-radius:18px;padding:12px;background:rgba(255,255,255,.02)}
.wheel-legend h3{margin:0 0 10px;font-size:14px;color:var(--muted);font-weight:700}
.planet-list{display:grid;gap:8px}
.planet-item{display:flex;justify-content:space-between;gap:10px;padding:10px 12px;border-radius:14px;border:1px solid var(--line);background:rgba(255,255,255,.02);cursor:pointer}
.planet-item:hover{border-color:rgba(110,168,254,.45)}
.planet-item.active{border-color:rgba(61,220,151,.55);background:rgba(61,220,151,.08)}
.planet-item .name{font-weight:700}
.planet-item .meta{color:var(--muted);font-size:12px;text-align:right}
.tooltip{position:absolute;z-index:40;pointer-events:none;min-width:140px;max-width:240px;padding:10px 12px;border-radius:14px;border:1px solid var(--line);background:rgba(18,26,51,.96);color:var(--txt);box-shadow:0 18px 50px rgba(0,0,0,.45);font-size:12px;line-height:1.35;display:none}
.tooltip .tt-title{font-weight:800;margin-bottom:6px}
.tooltip .tt-muted{color:var(--muted)}

/* SVG pan/zoom controls */
.zoombar{display:flex;gap:8px;position:absolute;top:10px;right:10px;z-index:30}
.zoombar button{padding:8px 10px;border-radius:12px;border:1px solid var(--line);background:rgba(11,16,32,.45);color:var(--txt);cursor:pointer}
.zoombar button:hover{background:rgba(110,168,254,.12);border-color:rgba(110,168,254,.45)}

.geo-suggest{border:1px solid var(--line);background:rgba(18,26,51,.98);border-radius:12px;overflow:hidden}
.geo-suggest button{display:block;width:100%;text-align:left;padding:10px 12px;background:transparent;border:0;color:var(--txt);cursor:pointer}
.geo-suggest button:hover{background:rgba(110,168,254,.10)}

.bullets{margin:10px 0 0 18px;color:var(--muted)}

