@import url('./fonts.css');

:root{
  --bg: oklch(0.08 0.03 260);
  --deep: oklch(0.05 0.02 260);
  --fg: oklch(0.95 0.02 220);
  --muted: oklch(0.65 0.04 230);
  --primary: oklch(0.78 0.15 215);
  --cyan: oklch(0.85 0.16 200);
  --accent: oklch(0.72 0.21 50);
  --uv: oklch(0.55 0.28 295);
  --border: oklch(0.78 0.15 215 / 0.18);
  --card: oklch(0.11 0.04 265 / 0.6);
  --glow-cyan: 0 0 40px oklch(0.78 0.15 215 / 0.4), 0 0 80px oklch(0.78 0.15 215 / 0.15);
  --grad-nebula: radial-gradient(ellipse at 30% 40%, oklch(0.35 0.18 280 / 0.45), transparent 50%), radial-gradient(ellipse at 70% 60%, oklch(0.45 0.18 200 / 0.35), transparent 55%), radial-gradient(ellipse at 50% 80%, oklch(0.40 0.20 50 / 0.20), transparent 50%);
  --grad-hud: linear-gradient(135deg, oklch(0.78 0.15 215 / 0.08), oklch(0.55 0.28 295 / 0.04));
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;border-color:var(--border)}
html,body{background:var(--bg);color:var(--fg);font-family:'Space Grotesk',sans-serif;line-height:1.5;-webkit-font-smoothing:antialiased}
body{background-image:var(--grad-nebula);background-attachment:fixed;min-height:100vh}
h1,h2,h3,h4{font-family:'Orbitron',sans-serif;letter-spacing:.02em;line-height:1.05;font-weight:700}
a{color:inherit;text-decoration:none}
button,select,input{font:inherit;color:inherit}
img{max-width:100%;display:block}

.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}
.mono{font-family:'JetBrains Mono',monospace;letter-spacing:.08em;text-transform:uppercase;font-size:.7rem}
.text-primary{color:var(--primary)}
.text-accent{color:var(--accent)}
.text-muted{color:var(--muted)}
.text-glow{text-shadow:0 0 20px oklch(0.78 0.15 215 / .6),0 0 40px oklch(0.78 0.15 215 / .3)}
.text-glow-ember{text-shadow:0 0 20px oklch(0.72 0.21 50 / .7)}

/* HUD panel with corner brackets */
.hud{background:var(--grad-hud);border:1px solid var(--border);backdrop-filter:blur(12px);position:relative}
.hud::before,.hud::after{content:'';position:absolute;width:12px;height:12px;border:1px solid var(--cyan)}
.hud::before{top:-1px;left:-1px;border-right:0;border-bottom:0}
.hud::after{bottom:-1px;right:-1px;border-left:0;border-top:0}

/* Star field */
.starfield{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.starfield::before,.starfield::after{content:'';position:absolute;inset:0;background-image:
  radial-gradient(1px 1px at 20% 30%,#fff,transparent),
  radial-gradient(1px 1px at 60% 70%,#fff,transparent),
  radial-gradient(2px 2px at 80% 10%,#fff,transparent),
  radial-gradient(1px 1px at 40% 80%,#fff,transparent),
  radial-gradient(1px 1px at 10% 60%,var(--cyan),transparent),
  radial-gradient(1.5px 1.5px at 90% 40%,#fff,transparent),
  radial-gradient(1px 1px at 30% 10%,var(--accent),transparent),
  radial-gradient(1px 1px at 70% 90%,#fff,transparent),
  radial-gradient(1px 1px at 50% 50%,#fff,transparent);
  background-size:400px 400px;background-repeat:repeat;opacity:.7}
.starfield::after{background-size:700px 700px;opacity:.4;animation:drift 240s linear infinite}
@keyframes drift{from{transform:translateY(0)}to{transform:translateY(-2000px)}}

.grid-overlay{position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(oklch(0.78 0.15 215 / .06) 1px,transparent 1px),linear-gradient(90deg,oklch(0.78 0.15 215 / .06) 1px,transparent 1px);
  background-size:60px 60px;opacity:.5}

/* Scan line */
.scan{position:fixed;inset:0;z-index:40;pointer-events:none;overflow:hidden}
.scan::after{content:'';position:absolute;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,oklch(0.85 0.16 200 / .7),transparent);box-shadow:0 0 20px oklch(0.85 0.16 200 / .6);animation:scan 6s linear infinite}
@keyframes scan{0%{transform:translateY(-100%);opacity:0}50%{opacity:1}100%{transform:translateY(100vh);opacity:0}}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:50}
.nav-inner{max-width:1280px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem}
.brand{display:flex;align-items:center;gap:.75rem}
.brand-orb{position:relative;width:32px;height:32px}
.brand-orb .ring{position:absolute;inset:0;border-radius:50%;border:1px solid var(--primary);animation:orbit 30s linear infinite}
.brand-orb .core{position:absolute;inset:6px;border-radius:50%;background:var(--primary);box-shadow:var(--glow-cyan);animation:pulse 4s ease-in-out infinite}
.brand-name{font-family:'Orbitron',sans-serif;font-weight:900;letter-spacing:.3em;font-size:.85rem}
.nav-menu{display:flex;align-items:center;gap:.25rem;padding:.5rem .75rem}
.nav-menu a{padding:.5rem .75rem;color:var(--muted);transition:color .2s}
.nav-menu a:hover,.nav-menu a.active{color:var(--primary);background:oklch(0.78 0.15 215 / .1)}
.nav-burger{display:none;padding:.5rem .75rem;color:var(--primary);background:transparent;border:0;cursor:pointer}
.nav-mobile{display:none;margin:0 1.5rem}
.nav-mobile.open{display:block}
.nav-mobile a{display:block;padding:.85rem 1rem;color:var(--muted);border-bottom:1px solid oklch(0.78 0.15 215 / .1)}
.nav-mobile a:last-child{border-bottom:0}
@media (max-width:880px){.nav-menu{display:none}.nav-burger{display:block}}

main{padding-top:5rem}

/* Hero */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;margin-top:-5rem;padding-top:5rem}
.hero-content{position:relative;z-index:10;text-align:center;max-width:1100px;padding:0 1.5rem}
.hero h1{font-size:clamp(2.6rem,7vw,5.5rem);font-weight:900;letter-spacing:-.02em}
.hero h1 .grad{background:linear-gradient(90deg,var(--cyan),var(--fg),var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent;display:block}
.hero p{margin-top:2rem;font-size:1.15rem;color:var(--muted);max-width:600px;margin-left:auto;margin-right:auto}
.hero-badge{display:inline-block;border:1px solid oklch(0.78 0.15 215 / .4);padding:.4rem .85rem;color:var(--primary);margin-bottom:2rem}
.hero-actions{margin-top:2.5rem;display:flex;flex-wrap:wrap;justify-content:center;gap:1rem}
.btn{display:inline-block;padding:1rem 2rem;background:var(--primary);color:var(--deep);box-shadow:var(--glow-cyan);transition:transform .3s}
.btn:hover{transform:translateY(-2px)}
.btn-ghost{background:transparent;border:1px solid oklch(0.78 0.15 215 / .5);color:var(--primary)}
.btn-ghost:hover{background:oklch(0.78 0.15 215 / .1)}
.hero-corner{position:absolute;padding:.5rem 1rem;color:var(--primary)}
.hero-corner.tl{top:6rem;left:1.5rem}
.hero-corner.tr{top:6rem;right:1.5rem}
.hero-bottom{position:absolute;bottom:2.5rem;left:1.5rem;right:1.5rem;display:flex;justify-content:space-between;color:var(--muted)}
@media (max-width:768px){.hero-corner,.hero-bottom{display:none}}

/* Black hole */
.bh-wrap{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:.85}
.blackhole{position:relative}
.bh-disk{position:absolute;inset:0;border-radius:50%;
  background:conic-gradient(from 0deg,oklch(0.72 0.21 50 / 0),oklch(0.85 0.16 200 / .7),oklch(0.55 0.28 295 / .6),oklch(0.72 0.21 50 / .8),oklch(0.95 0.02 220 / .4),oklch(0.72 0.21 50 / 0));
  -webkit-mask:radial-gradient(circle,transparent 28%,#000 32%,#000 48%,transparent 60%);
  mask:radial-gradient(circle,transparent 28%,#000 32%,#000 48%,transparent 60%);
  animation:orbit 40s linear infinite}
.bh-inner{position:absolute;inset:0;border-radius:50%;
  background:conic-gradient(from 180deg,oklch(0.95 0.02 220 / 0),oklch(0.85 0.16 200 / .9),oklch(0.95 0.02 220 / .7),oklch(0.85 0.16 200 / 0));
  -webkit-mask:radial-gradient(circle,transparent 24%,#000 26%,#000 30%,transparent 34%);
  mask:radial-gradient(circle,transparent 24%,#000 26%,#000 30%,transparent 34%);
  filter:blur(2px);animation:orbit-rev 18s linear infinite}
.bh-event{position:absolute;inset:0;border-radius:50%;background:radial-gradient(circle,#000 22%,oklch(0.05 0.02 260 / .8) 28%,transparent 60%);box-shadow:inset 0 0 80px oklch(0.85 0.16 200 / .6),0 0 120px oklch(0.55 0.28 295 / .4)}
.bh-photon{position:absolute;inset:0;border-radius:50%;background:radial-gradient(circle,transparent 26%,oklch(0.95 0.02 220 / .8) 27%,transparent 28.5%);filter:blur(.5px)}
.bh-orbit{position:absolute;inset:0;border-radius:50%;border:1px solid oklch(0.78 0.15 215 / .25)}
.bh-orbit .sat{position:absolute;top:0;left:50%;width:6px;height:6px;border-radius:50%;background:var(--cyan);box-shadow:0 0 12px var(--cyan);transform:translate(-50%,-50%)}

@keyframes orbit{to{transform:rotate(360deg)}}
@keyframes orbit-rev{to{transform:rotate(-360deg)}}
@keyframes pulse{0%,100%{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}

.fade-in{opacity:0;transform:translateY(20px);transition:opacity .8s ease,transform .8s ease}
.fade-in.in{opacity:1;transform:none}

/* Sections */
section.pad{padding:4rem 0}
section.pad-lg{padding:6rem 0}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:3rem;gap:1rem;flex-wrap:wrap}
.section-head h2{font-size:clamp(2rem,4vw,3rem)}
.kicker{color:var(--primary);margin-bottom:.5rem}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border)}
.stats > div{background:var(--bg);padding:1.5rem}
.stats .v{font-family:'Orbitron',sans-serif;font-size:1.75rem;color:var(--primary);margin-top:.4rem}
@media (max-width:768px){.stats{grid-template-columns:repeat(2,1fr)}}

/* Zodiac grid */
.zgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
@media (max-width:900px){.zgrid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.zgrid{grid-template-columns:1fr}}
.zcard{padding:1.25rem;display:block;color:inherit;transition:transform .4s,background .4s;position:relative;overflow:hidden}
.zcard:hover{transform:translateY(-4px);background:oklch(0.78 0.15 215 / .05)}
.zcard .glow{position:absolute;top:-3rem;right:-3rem;width:8rem;height:8rem;border-radius:50%;background:radial-gradient(circle,oklch(0.78 0.15 215 / .6),transparent 70%);filter:blur(20px);opacity:.3;transition:opacity .4s}
.zcard:hover .glow{opacity:.7}
.zcard .head{display:flex;justify-content:space-between}
.zcard .body{display:flex;align-items:center;gap:1rem;margin-top:1rem}
.zcard .sym{font-size:3rem;color:var(--primary);font-family:'Orbitron',sans-serif;animation:orbit 90s linear infinite}
.zcard h3{font-size:1.5rem;letter-spacing:.05em}
.zcard .pred{margin-top:1.25rem;font-size:.9rem;color:oklch(0.95 0.02 220 / .7);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.zcard .meter{margin-top:1.25rem}
.bar{height:1px;background:var(--border);position:relative;overflow:hidden;margin-top:.4rem}
.bar > i{position:absolute;inset:0 auto 0 0;background:var(--primary);box-shadow:0 0 8px var(--cyan);width:0;transition:width 1.2s ease}
.bar.in > i{width:var(--w)}
.zcard .foot{margin-top:1.5rem;display:flex;justify-content:space-between}

/* Sign page */
.sign-hero{display:grid;grid-template-columns:1fr auto;gap:3rem;align-items:center;padding:3rem 0 4rem}
.sign-hero h1{font-size:clamp(3rem,8vw,6rem);font-weight:900;margin-top:.75rem}
.sign-hero .meta{display:flex;flex-wrap:wrap;gap:.5rem 1.5rem;margin-top:1rem;color:var(--muted)}
.sign-hero .pred{margin-top:2rem;font-size:1.15rem;max-width:600px;color:oklch(0.95 0.02 220 / .85)}
.sign-symbol{font-size:clamp(8rem,15vw,15rem);color:var(--primary);font-family:'Orbitron',sans-serif;line-height:1;animation:orbit 60s linear infinite}
@media (max-width:768px){.sign-hero{grid-template-columns:1fr}.sign-symbol{order:-1;text-align:center}}

.widgets{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border)}
.widgets > div{background:var(--bg);padding:1.25rem}
.widgets .v{font-family:'Orbitron',sans-serif;font-size:1.4rem;color:var(--primary);margin-top:.4rem}
@media (max-width:768px){.widgets{grid-template-columns:repeat(2,1fr)}}

.sectors{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}
@media (max-width:768px){.sectors{grid-template-columns:1fr}}
.sector{padding:1.5rem}
.sector .top{display:flex;justify-content:space-between;color:var(--muted)}
.sector h3{margin-top:.75rem;font-size:1.4rem}
.sector p{margin-top:.75rem;color:oklch(0.95 0.02 220 / .8)}

.cta-strip{padding:2rem;text-align:center}
.cta-strip p{font-size:1.5rem;font-family:'Orbitron',sans-serif;margin:.75rem 0 1.5rem}

/* Compatibility */
.compat-pickers{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:3rem}
@media (max-width:680px){.compat-pickers{grid-template-columns:1fr}}
.picker{padding:1.5rem}
.picker select{margin-top:.75rem;width:100%;background:oklch(0 0 0 / .4);border:1px solid var(--border);font-family:'Orbitron',sans-serif;font-size:1.4rem;padding:.75rem;color:var(--primary)}
.picker select:focus{outline:0;border-color:var(--primary)}
.picker .row{margin-top:1rem;display:flex;justify-content:space-between;color:var(--muted)}

.orbital{margin-top:3rem;padding:2.5rem;position:relative;overflow:hidden}
.orbital .header{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.orbital-stage{position:relative;height:20rem;display:flex;align-items:center;justify-content:center;margin:2rem 0}
.ring1{position:absolute;width:18rem;height:18rem;border-radius:50%;border:1px solid oklch(0.78 0.15 215 / .3);animation:orbit 30s linear infinite}
.ring1 .lbl{position:absolute;top:-1.5rem;left:50%;transform:translateX(-50%);font-size:2rem;color:var(--primary)}
.ring2{position:absolute;width:12rem;height:12rem;border-radius:50%;border:1px solid oklch(0.72 0.21 50 / .4);animation:orbit-rev 20s linear infinite}
.ring2 .lbl{position:absolute;top:-1.25rem;left:50%;transform:translateX(-50%);font-size:1.6rem;color:var(--accent)}
.core{width:4rem;height:4rem;border-radius:50%;background:oklch(0.78 0.15 215 / .3);box-shadow:var(--glow-cyan);animation:pulse 4s ease-in-out infinite}
.radar{position:absolute;width:18rem;height:18rem;border-radius:50%;overflow:hidden;animation:orbit 4s linear infinite}
.radar > i{display:block;width:100%;height:100%;background:conic-gradient(from 0deg,oklch(0.85 0.16 200 / .25),transparent 25%)}

.metrics{display:grid;gap:1rem;margin-top:2rem}
.metric .lbl{display:flex;justify-content:space-between}
.summary{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem}
@media (max-width:680px){.summary{grid-template-columns:1fr}}
.summary > div{padding:1rem;border:1px solid var(--border)}
.summary .v{font-family:'Orbitron',sans-serif;font-size:1.6rem;color:var(--primary)}

/* Archive */
.arch{display:grid;gap:1px;background:var(--border)}
.arch article{background:var(--bg);padding:2rem;display:grid;grid-template-columns:200px 1fr auto;gap:1.5rem;align-items:center;transition:background .3s}
.arch article:hover{background:oklch(0.78 0.15 215 / .05)}
.arch article h2{font-size:1.5rem;font-weight:600}
.arch article p{margin-top:.5rem;color:var(--muted)}
.arch .meta{font-family:'JetBrains Mono',monospace;font-size:.7rem;line-height:1.8}
.arch .meta .c{color:var(--primary);text-transform:uppercase}
.arch .meta .a{color:var(--accent)}
@media (max-width:768px){.arch article{grid-template-columns:1fr}}

/* Astro data */
.astro{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem;margin-top:2rem}
@media (max-width:900px){.astro{grid-template-columns:1fr}}
.astro .panel{padding:1.5rem}
.astro .planets > div{display:grid;grid-template-columns:40px 1fr 1fr 100px 90px;gap:1rem;align-items:center;padding:.75rem 0;border-top:1px solid oklch(0.78 0.15 215 / .1)}
.astro .planets > div:first-child{border-top:0}
.astro .planets .sym{font-size:1.5rem;color:var(--primary)}
.live3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2.5rem}
@media (max-width:768px){.live3{grid-template-columns:1fr}}
.live3 .panel{padding:1.5rem}
.live3 .v{font-family:'Orbitron',sans-serif;font-size:1.8rem;color:var(--primary);margin-top:.4rem}

/* Footer */
footer{margin-top:8rem;border-top:1px solid var(--border);position:relative}
.foot-grid{max-width:1200px;margin:0 auto;padding:3rem 1.5rem;display:grid;grid-template-columns:2fr 1fr 1fr;gap:2.5rem}
@media (max-width:768px){.foot-grid{grid-template-columns:1fr}}
.foot-grid h4{color:var(--primary);font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:1rem}
.foot-grid ul{list-style:none}
.foot-grid li{margin-bottom:.5rem;color:var(--muted)}
.foot-grid li a:hover{color:var(--primary)}
.foot-bottom{border-top:1px solid oklch(0.78 0.15 215 / .1);padding:1.25rem;text-align:center;color:var(--muted);font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase}

.back-link{color:var(--muted);font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase}
.back-link:hover{color:var(--primary)}
