*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--void:#020408;--accent:#4fc3f7;--warm:#ff6b35;--purple:#b388ff;--green:#69f0ae;--amber:#ffd54f;--muted:#3a4a6a;--text:#c8d8f0;--bright:#e8f4ff;--mono:"Space Mono", monospace;--display:"Syne", sans-serif}html,body{background:var(--void);color:var(--text);font-family:var(--mono);cursor:crosshair;-webkit-user-select:none;user-select:none;width:100vw;height:100vh;overflow:hidden}#root{width:100vw;height:100vh}.nav{z-index:20;pointer-events:all;justify-content:space-between;align-items:center;padding:1.2rem 3rem;display:flex;position:fixed;top:0;left:0;right:0}.nav-logo{font-family:var(--display);color:var(--accent);letter-spacing:.05em;cursor:pointer;font-size:1rem;font-weight:800}.nav-links{gap:2rem;list-style:none;display:flex}.nav-links button{color:var(--muted);font-family:var(--mono);letter-spacing:.15em;text-transform:uppercase;cursor:pointer;background:0 0;border:none;padding:0;font-size:.7rem;transition:color .2s}.nav-links button:hover,.nav-links button.active{color:var(--accent)}.location-badge{z-index:20;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);pointer-events:none;font-size:.62rem;position:fixed;top:5rem;left:3rem}.location-badge span{color:var(--accent)}.hero-text{z-index:20;transition:opacity .5s;position:fixed;top:50%;left:3rem;transform:translateY(-50%)}.ht-label{letter-spacing:.3em;text-transform:uppercase;color:var(--accent);align-items:center;gap:.75rem;margin-bottom:1rem;font-size:.65rem;display:flex}.ht-label:before{content:"";background:var(--accent);width:36px;height:1px;display:block}.hero-text h1{font-family:var(--display);color:var(--bright);letter-spacing:-.03em;margin-bottom:1.2rem;font-size:clamp(3rem,6vw,5.5rem);font-weight:800;line-height:.92}.hero-text h1 em{color:var(--accent);font-style:normal}.ht-sub{max-width:380px;color:var(--muted);font-size:.82rem;line-height:1.8}.planet-info{z-index:20;pointer-events:none;max-width:340px;transition:opacity .5s;position:fixed;top:50%;left:3rem;overflow:visible;transform:translateY(-50%)}.pi-tag{letter-spacing:.3em;text-transform:uppercase;color:var(--accent);align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:.6rem;display:flex}.pi-tag:before{content:"";background:var(--accent);width:24px;height:1px;display:block}.pi-name{font-family:var(--display);color:var(--bright);letter-spacing:-.03em;margin-bottom:.75rem;font-size:3.5rem;font-weight:800;line-height:.95}.pi-desc{color:var(--muted);margin-bottom:1.5rem;font-size:.8rem;line-height:1.7}.pi-cta{color:var(--accent);font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;cursor:pointer;pointer-events:all;background:0 0;border:1px solid #4fc3f74d;align-items:center;gap:.5rem;padding:.6rem 1.2rem;font-size:.7rem;transition:all .2s;display:inline-flex}.pi-cta:hover{border-color:var(--accent);background:#4fc3f714}.pi-cta-chevron{font-size:.85rem;line-height:1;transition:transform .4s cubic-bezier(.34,1.56,.64,1);display:inline-block}.pi-cta-chevron.open{transform:rotate(180deg)}.pi-moon-list{opacity:0;pointer-events:none;gap:.5rem;max-height:0;margin-top:.75rem;margin-right:-20px;padding-right:20px;transition:max-height .8s cubic-bezier(.22,1,.36,1),opacity .6s;display:grid;overflow:hidden}.pi-moon-list.open{opacity:1;pointer-events:all;max-height:600px}.pi-moon-card{cursor:pointer;text-align:left;pointer-events:all;opacity:0;background:#ffffff08;border:1px solid #4fc3f71f;border-radius:4px;flex-direction:column;gap:.15rem;padding:.6rem .8rem;transition:opacity .4s,transform .4s cubic-bezier(.22,1,.36,1),background .2s,border-color .2s;display:flex;transform:translateY(10px)translate(-6px)}.pi-moon-list.open .pi-moon-card{opacity:1;transform:translateY(0)translate(0)}.pi-moon-list.open .pi-moon-card:first-child{transition-delay:.1s}.pi-moon-list.open .pi-moon-card:nth-child(2){transition-delay:.22s}.pi-moon-list.open .pi-moon-card:nth-child(3){transition-delay:.34s}.pi-moon-list.open .pi-moon-card:nth-child(4){transition-delay:.46s}.pi-moon-list.open .pi-moon-card:nth-child(5){transition-delay:.58s}.pi-moon-list.open .pi-moon-card:nth-child(6){transition-delay:.7s}.pi-moon-list.open .pi-moon-card:hover{background:#4fc3f70f;border-color:#4fc3f74d;transform:translateY(0)translate(6px)}.pi-moon-num{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;opacity:.7;font-size:.55rem}.pi-moon-name{font-family:var(--display);color:var(--bright);font-size:.95rem;font-weight:700;line-height:1.1}.pi-moon-sub{color:var(--muted);font-size:.65rem;line-height:1.4}.moon-info{z-index:20;pointer-events:none;max-width:300px;transition:opacity .4s;position:fixed;top:50%;left:3rem;transform:translateY(-50%)}.mi-num{letter-spacing:.3em;color:var(--muted);margin-bottom:.5rem;font-size:.6rem}.mi-name{font-family:var(--display);color:var(--bright);margin-bottom:.5rem;font-size:2rem;font-weight:800;line-height:1}.mi-subtitle{color:var(--accent);letter-spacing:.1em;margin-bottom:.75rem;font-size:.72rem}.mi-desc{color:var(--muted);margin-bottom:1rem;font-size:.78rem;line-height:1.7}.mi-tags{flex-wrap:wrap;gap:.35rem;margin-bottom:1rem;display:flex}.mi-tag{color:var(--purple);letter-spacing:.07em;border:1px solid #b388ff40;padding:.2rem .55rem;font-size:.6rem}.mi-open{color:var(--accent);font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;cursor:pointer;pointer-events:all;background:0 0;border:1px solid #4fc3f74d;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.65rem;transition:all .2s;display:inline-flex}.mi-open:hover{border-color:var(--accent);background:#4fc3f714}.scroll-hint{letter-spacing:.25em;text-transform:uppercase;color:var(--muted);z-index:20;pointer-events:none;flex-direction:column;align-items:center;gap:.5rem;font-size:.6rem;transition:opacity .5s;display:flex;position:fixed;bottom:2rem;left:50%;transform:translate(-50%)}.scroll-arrow{background:var(--muted);width:1px;height:30px;position:relative;overflow:hidden}.scroll-arrow:after{content:"";background:var(--accent);width:100%;height:100%;animation:1.5s ease-in-out infinite scrollDrop;position:absolute;top:-100%;left:0}@keyframes scrollDrop{0%{top:-100%}to{top:100%}}.progress-ring{z-index:20;pointer-events:all;align-items:center;gap:.5rem;display:flex;position:fixed;bottom:2rem;left:50%;transform:translate(-50%)}.ring-dot{background:var(--muted);border-radius:50%;width:6px;height:6px;transition:all .3s}.ring-dot.active{background:var(--accent);box-shadow:0 0 8px #4fc3f799}.ring-dot.visited{background:#4fc3f74d}.side-panel{z-index:20;pointer-events:all;scrollbar-width:thin;scrollbar-color:#4fc3f733 transparent;background:linear-gradient(270deg,#020408f7,#020408e0);border-left:1px solid #4fc3f71a;width:420px;padding:6rem 2.5rem 3rem;transition:transform .6s cubic-bezier(.4,0,.2,1);position:fixed;top:0;bottom:0;right:0;overflow-y:auto;transform:translate(100%)}.side-panel.open{transform:translate(0)}.side-panel::-webkit-scrollbar{width:3px}.side-panel::-webkit-scrollbar-track{background:0 0}.side-panel::-webkit-scrollbar-thumb{background:#4fc3f733;border-radius:2px}.panel-close{color:var(--muted);font-family:var(--mono);cursor:pointer;letter-spacing:.1em;background:0 0;border:1px solid #4fc3f733;padding:.4rem .8rem;font-size:.7rem;transition:all .2s;position:absolute;top:1.5rem;right:1.5rem}.panel-close:hover{color:var(--accent);border-color:var(--accent)}.panel-section-tag{letter-spacing:.3em;text-transform:uppercase;color:var(--accent);background:#4fc3f712;border:1px solid #4fc3f726;margin-bottom:1.5rem;padding:.25rem .7rem;font-size:.6rem;display:inline-block}.panel-title{font-family:var(--display);color:var(--bright);letter-spacing:-.02em;margin-bottom:.5rem;font-size:1.6rem;font-weight:800}.panel-company{letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:.25rem;font-size:.7rem}.panel-period{color:var(--muted);letter-spacing:.1em;margin-bottom:1rem;font-size:.65rem}.panel-desc{color:var(--muted);margin-bottom:1.25rem;font-size:.82rem;line-height:1.8}.panel-bullets{margin-bottom:1.5rem;list-style:none}.panel-bullets li{color:var(--text);border-bottom:1px solid #4fc3f70f;padding:.4rem 0 .4rem 1rem;font-size:.78rem;position:relative}.panel-bullets li:before{content:"→";color:var(--accent);font-size:.7rem;position:absolute;left:0}.panel-tags{flex-wrap:wrap;gap:.4rem;margin-bottom:1.5rem;display:flex}.panel-tag{color:var(--purple);letter-spacing:.07em;background:#b388ff14;border:1px solid #b388ff33;padding:.22rem .6rem;font-size:.62rem}.panel-status{letter-spacing:.15em;text-transform:uppercase;margin-bottom:1rem;padding:.2rem .6rem;font-size:.58rem;display:inline-block}.status-live{color:var(--green);background:#69f0ae1a;border:1px solid #69f0ae40}.status-oss{color:var(--purple);background:#b388ff1a;border:1px solid #b388ff40}.status-wip{color:var(--warm);background:#ff6b351a;border:1px solid #ff6b3540}.panel-link{color:var(--accent);font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;cursor:pointer;background:#4fc3f714;border:1px solid #4fc3f740;align-items:center;gap:.5rem;margin-bottom:.5rem;margin-right:.5rem;padding:.6rem 1.2rem;font-size:.7rem;text-decoration:none;transition:all .2s;display:inline-flex}.panel-link:hover{border-color:var(--accent);background:#4fc3f726}.panel-divider{background:#4fc3f714;height:1px;margin:1.5rem 0}.panel-content{min-height:0}.skill-row{margin-bottom:1rem}.skill-head{color:var(--text);justify-content:space-between;margin-bottom:.35rem;font-size:.75rem;display:flex}.skill-pct{color:var(--muted)}.skill-track{background:#4fc3f71a;height:1.5px}.skill-fill{background:linear-gradient(90deg, var(--accent), var(--purple));width:0;height:100%}.about-para{color:var(--muted);margin-bottom:1rem;font-size:.82rem;line-height:1.9}.contact-row{border-bottom:1px solid #4fc3f712;align-items:center;gap:1rem;padding:.75rem 0;display:flex}.contact-key{letter-spacing:.1em;color:var(--muted);min-width:80px;font-size:.65rem}.contact-val{color:var(--text);font-size:.78rem}.contact-val a{color:var(--accent);text-decoration:none}@media (width<=768px){.side-panel{border-top:1px solid #4fc3f71a;border-left:none;width:100%}.hero-text h1{font-size:2.5rem}.pi-name{font-size:2.2rem}.nav{padding:1rem 1.5rem}.nav-links{gap:1rem}}
