/* ═══════════════════════════════════════════════
   EXPO SOFTWARES — raw internet energy
   tables. borders. marquees. personality.
   ═══════════════════════════════════════════════ */

:root{
  --bg:#050508;--bg2:#0a0a12;--accent:#00e5ff;--accent2:#ff003c;
  --glow:rgba(0,229,255,.3);--text:#8ab4c8;--dim:#2a4a5a;
  --bright:#e0f0ff;--border:#00e5ff;--font:'JetBrains Mono',monospace;
  --pixel:'VT323',monospace;--display:'Orbitron',sans-serif;
  --jp:'Noto Sans JP',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
body{
  font-family:var(--font);font-size:12px;color:var(--text);
  background:var(--bg);background-image:url('img/bg-stars.gif');
  background-repeat:repeat;background-attachment:fixed;
  cursor:crosshair;line-height:1.5;
}
a{color:var(--accent);text-decoration:none}
a:hover{color:var(--bright);text-shadow:0 0 8px var(--glow);text-decoration:underline}
button{font-family:var(--font);cursor:pointer}
img{max-width:100%;display:block}
::selection{background:var(--accent);color:var(--bg)}

/* ═══ GATE ═══ */
#gate{
  position:fixed;inset:0;z-index:9999;background:var(--bg);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.g-scanlines{
  position:absolute;inset:0;
  background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,255,255,.02) 2px,rgba(0,255,255,.02) 4px);
  pointer-events:none;z-index:1;
}
.g-content{position:relative;z-index:2;width:90%;max-width:400px}
.g-logo{text-align:center;margin-bottom:2rem}
.g-logo-text{font-family:var(--display);font-size:clamp(1rem,5vw,1.8rem);color:var(--accent);letter-spacing:.12em;text-shadow:0 0 20px var(--glow),0 0 40px var(--glow)}
.g-logo-jp{font-family:var(--jp);font-size:.7rem;color:var(--dim);letter-spacing:.3em;margin-top:.3rem}
.g-terminal{
  border:1px solid var(--accent);background:rgba(0,10,15,.9);
  border-radius:2px;overflow:hidden;margin-bottom:1rem;
  box-shadow:0 0 20px var(--glow),inset 0 0 30px rgba(0,229,255,.05);
}
.g-term-header{
  padding:4px 8px;background:rgba(0,229,255,.1);
  border-bottom:1px solid var(--dim);font-size:.65rem;
  color:var(--accent);display:flex;justify-content:space-between;
}
.g-blink{animation:blink 1s step-end infinite}
@keyframes blink{50%{opacity:0}}
.g-term-body{padding:8px;min-height:60px;font-family:var(--pixel);font-size:1rem;color:var(--accent)}
.g-line{margin-bottom:2px;opacity:.7}
.g-line.g-cracking{color:var(--accent2);animation:flicker .1s infinite}
.g-line.g-found{color:#33ff66;font-weight:bold}
@keyframes flicker{0%{opacity:1}50%{opacity:.3}100%{opacity:.8}}
.g-input-row{display:flex;align-items:center;padding:4px 8px;border-top:1px solid var(--dim);background:rgba(0,0,0,.3)}
.g-prompt{color:var(--accent);margin-right:6px;font-family:var(--pixel);font-size:1rem}
.g-input{
  flex:1;background:none;border:none;outline:none;
  font-family:var(--pixel);font-size:1rem;color:var(--bright);
  caret-color:var(--accent);
}
.g-input::placeholder{color:var(--dim)}
.g-buttons{display:flex;gap:.5rem;margin-bottom:.8rem}
.g-btn{
  flex:1;padding:.6rem;font-size:.7rem;letter-spacing:.1em;
  border:1px solid var(--dim);background:rgba(0,10,15,.8);
  color:var(--text);border-radius:2px;transition:all .2s;
}
.g-btn:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 0 10px var(--glow)}
.g-btn-crack{border-color:var(--accent);color:var(--accent)}
.g-btn-crack:hover{background:var(--accent);color:var(--bg)}
.g-btn-crack.cracking{animation:crackPulse .5s infinite;pointer-events:none}
@keyframes crackPulse{0%,100%{box-shadow:0 0 10px var(--glow)}50%{box-shadow:0 0 25px var(--glow)}}
.g-hint{font-size:.55rem;color:var(--dim);text-align:center;font-style:italic}
.g-legal{font-size:.5rem;color:var(--dim);text-align:center;margin-top:.8rem}
.g-legal a{color:var(--accent);opacity:.7}
.g-legal a:hover{opacity:1}

/* ═══ MARQUEE ═══ */
.marquee-bar{
  padding:3px 0;font-family:var(--pixel);font-size:.85rem;
  letter-spacing:.08em;border-top:1px solid var(--accent);
  border-bottom:1px solid var(--accent);overflow:hidden;
  white-space:nowrap;
}
.marquee-top{color:var(--accent);background:rgba(0,229,255,.05)}
.marquee-bottom{color:var(--dim);background:rgba(0,229,255,.02)}
.marquee-track{display:inline-block;white-space:nowrap;animation:scrollLeft 30s linear infinite}
.marquee-reverse .marquee-text{animation-direction:reverse}
.marquee-reverse{animation:scrollRight 25s linear infinite}
.marquee-text{display:inline-block;white-space:nowrap}
@keyframes scrollLeft{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes scrollRight{0%{transform:translateX(-50%)}100%{transform:translateX(0)}}
.mini-marquee{font-size:.65rem;color:var(--dim);margin-bottom:.5rem;padding:2px 0;border:none}

/* ═══ AUDIO BUTTON ═══ */
#audio-btn{
  position:fixed;bottom:1rem;right:1rem;z-index:100;
  width:50px;height:50px;border-radius:50%;
  border:2px solid var(--accent);background:var(--bg);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .2s;
  box-shadow:0 0 15px var(--glow);
  animation:audioPulse 2s ease infinite;
}
#audio-btn:hover{transform:scale(1.1);box-shadow:0 0 25px var(--glow)}
#audio-btn.playing{background:var(--accent);animation:none}
#audio-btn.playing #audio-icon{color:var(--bg)}
#audio-icon{font-size:1.2rem;color:var(--accent)}
@keyframes audioPulse{0%,100%{box-shadow:0 0 10px var(--glow)}50%{box-shadow:0 0 20px var(--glow)}}

/* ═══ HEADER TABLE ═══ */
.header-table{
  width:100%;border-collapse:collapse;
  border:2px solid var(--accent);background:var(--bg2);
  box-shadow:0 0 15px var(--glow);
}
.ht-avatar{width:80px;padding:8px;vertical-align:top;border-right:1px solid var(--dim)}
.avatar{
  width:70px;height:70px;border:2px solid var(--accent);
  border-radius:2px;object-fit:cover;
  box-shadow:0 0 10px var(--glow);
  image-rendering:auto;
}
.ht-info{padding:8px 12px;vertical-align:middle}
.site-name{
  font-family:var(--display);font-size:clamp(.9rem,4vw,1.4rem);
  color:var(--bright);letter-spacing:.08em;
  text-shadow:0 0 15px var(--glow);
}
.site-sub{font-size:.65rem;color:var(--dim);margin-top:2px}
.site-handle{font-size:.7rem;margin-top:4px}

/* ═══ VISITOR COUNTER ═══ */
.visitor-counter{
  text-align:center;padding:4px;font-family:var(--pixel);
  font-size:.8rem;color:var(--dim);
  border-bottom:1px solid var(--dim);background:rgba(0,0,0,.3);
  letter-spacing:.15em;
}
.vc-num{
  color:var(--accent);font-size:1rem;
  text-shadow:0 0 6px var(--glow);
  display:inline-block;min-width:60px;
}

/* ═══ TOUCH SPARKLES ═══ */
.sparkle{
  position:fixed;pointer-events:none;z-index:9998;
  font-size:1.2rem;color:var(--accent);
  animation:sparklePop .6s ease forwards;
  text-shadow:0 0 10px var(--glow);
}
@keyframes sparklePop{
  0%{transform:scale(0) rotate(0deg);opacity:1}
  50%{transform:scale(1.2) rotate(180deg);opacity:.8}
  100%{transform:scale(0) rotate(360deg) translateY(-40px);opacity:0}
}
.sparkle-ring{
  position:fixed;pointer-events:none;z-index:9997;
  width:30px;height:30px;border-radius:50%;
  border:2px solid var(--accent);
  animation:ringPop .5s ease forwards;
}
@keyframes ringPop{
  0%{transform:translate(-50%,-50%) scale(0);opacity:.8}
  100%{transform:translate(-50%,-50%) scale(2.5);opacity:0}
}

/* ═══ SCROLL EFFECTS ═══ */
/* ═══ SCROLL EFFECTS ═══ */

/* panels reveal on scroll */
.panel{
  border:2px solid var(--accent);margin:6px 4px;
  background:var(--bg2);box-shadow:0 0 8px var(--glow);
  opacity:0;transform:translateY(20px);
  transition:opacity .6s ease,transform .6s ease;
}
.panel.visible{opacity:1;transform:translateY(0)}
.panel-header{
  padding:6px 10px;font-family:var(--display);font-size:.7rem;
  letter-spacing:.12em;color:var(--bg);
  background:var(--accent);font-weight:600;
}
.panel-body{padding:10px}
.panel-desc{font-size:.75rem;color:var(--dim);margin-bottom:.8rem}

/* ═══ ATLAS GRID ═══ */
.atlas-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:4px;margin-bottom:.8rem;
}
.atlas-thumb{
  aspect-ratio:3/4;overflow:hidden;cursor:pointer;
  border:1px solid var(--dim);transition:all .2s;
  position:relative;background:var(--bg);
}
.atlas-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.atlas-thumb:hover{border-color:var(--accent);box-shadow:0 0 10px var(--glow)}
.atlas-thumb:hover img{transform:scale(1.1)}
.atlas-num{
  position:absolute;bottom:0;left:0;right:0;
  padding:1px 3px;font-family:var(--pixel);font-size:.6rem;
  background:rgba(0,0,0,.85);color:var(--accent);text-align:center;
  letter-spacing:.05em;
}

/* Volume tags */
.vol-row{display:flex;flex-wrap:wrap;gap:3px}
.vol-tag{font-family:var(--pixel);font-size:.65rem;padding:2px 6px;border:1px solid var(--dim);color:var(--dim)}
.vol-active{border-color:var(--accent);color:var(--accent);animation:volPulse 1.5s ease infinite;text-shadow:0 0 8px var(--accent)}
@keyframes volPulse{0%,100%{box-shadow:0 0 8px var(--glow);border-color:var(--accent)}50%{box-shadow:0 0 25px var(--accent),0 0 50px var(--glow);border-color:var(--accent)}}
.vol-soon{border-style:dashed;opacity:.5}
.vol-soon:hover{opacity:.8}

/* ═══ COMING SOON ═══ */
.coming-soon{
  font-family:var(--pixel);font-size:1rem;
  color:var(--dim);text-align:center;padding:1.5rem;
  opacity:.5;letter-spacing:.1em;
}
.cs-icon{margin-right:.3rem}

/* ═══ TERMINAL / ARCHIVE ═══ */
.terminal{
  font-family:var(--pixel);font-size:.85rem;
  color:var(--text);white-space:pre-wrap;
  line-height:1.6;padding:4px 0;
}
.t-dim{color:var(--dim)}
.t-accent{color:var(--accent)}
.t-sys{color:var(--dim);font-style:italic}

/* ═══ SKIN BUTTONS ═══ */
.skin-btns{display:flex;flex-wrap:wrap;gap:4px}
.skin-btn{
  padding:5px 10px;font-size:.65rem;letter-spacing:.05em;
  border:1px solid var(--dim);background:var(--bg);
  color:var(--text);transition:all .2s;font-family:var(--pixel);
  font-size:.75rem;
}
.skin-btn:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 0 6px var(--glow)}
.skin-btn.active{border-color:var(--accent);color:var(--accent);background:rgba(0,229,255,.08)}
.skin-btn-gen{border-color:var(--accent2);color:var(--accent2)}
.skin-btn-gen:hover{background:var(--accent2);color:var(--bg)}

/* ═══ DISCLAIMER ═══ */
.disclaimer-bar{
  text-align:center;padding:6px;font-size:.6rem;
  color:var(--dim);border-top:1px solid var(--dim);
  border-bottom:1px solid var(--dim);
}

/* ═══ FOOTER ═══ */
.raw-footer{text-align:center;padding:1.5rem .5rem;font-size:.7rem}
.footer-tiny{font-size:.6rem;color:var(--dim);display:block;margin-top:.3rem}
.footer-tiny a{color:var(--accent);opacity:.7}
.footer-tiny a:hover{opacity:1}

/* ═══ ATLAS VIEWER ═══ */
#atlas-view{
  position:fixed;inset:0;z-index:200;background:var(--bg);
  overflow-y:auto;display:flex;flex-direction:column;
}
.av-bar{
  display:flex;align-items:center;justify-content:space-between;
  padding:4px 6px;background:var(--accent);gap:4px;flex-wrap:wrap;
  position:sticky;top:0;z-index:10;
}
.av-bar button{
  font-family:var(--pixel);font-size:.8rem;
  color:var(--bg);background:none;border:1px solid var(--bg);
  padding:3px 8px;cursor:pointer;transition:all .2s;
}
.av-bar button:hover{background:var(--bg);color:var(--accent)}
.av-bar button:disabled{opacity:.3}
#av-count{font-family:var(--pixel);font-size:.75rem;color:var(--bg)}
.av-ad{
  padding:6px;text-align:center;background:rgba(0,0,0,.5);
  border-bottom:1px solid var(--dim);min-height:70px;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--pixel);font-size:.7rem;color:var(--dim);
  border:1px dashed var(--dim);margin:4px;
}
.av-body{flex:1;padding:4px}
.av-body img{width:100%;border:2px solid var(--accent);box-shadow:0 0 15px var(--glow)}
.av-title-block{text-align:center;margin:.8rem 0;border:1px solid var(--dim);padding:6px;background:var(--bg2)}
.av-title-block h3{font-family:var(--display);font-size:1rem;color:var(--bright);letter-spacing:.06em}
.av-title-block span{font-family:var(--pixel);font-size:.8rem;color:var(--accent)}
.av-sections{display:flex;flex-direction:column;gap:6px;margin-top:6px;padding-bottom:2rem}
.av-sec{
  padding:8px;border:1px solid var(--dim);background:var(--bg2);
  opacity:0;transform:translateY(15px);transition:all .5s;
}
.av-sec.vis{opacity:1;transform:translateY(0)}
.av-sec-label{font-family:var(--pixel);font-size:.7rem;color:var(--accent);margin-bottom:4px;letter-spacing:.12em}
.av-sec p,.av-sec li{font-size:.7rem}
.av-sec ul{padding-left:1rem}
.av-palette{display:flex;gap:6px;flex-wrap:wrap}
.av-chip-wrap{display:flex;flex-direction:column;align-items:center;gap:2px}
.av-chip{width:32px;height:32px;border:1px solid rgba(255,255,255,.15);cursor:pointer;transition:all .2s}
.av-chip:hover{transform:scale(1.5);box-shadow:0 0 12px var(--glow);z-index:1}
.av-hex{font-family:var(--pixel);font-size:.55rem;color:var(--accent);letter-spacing:.03em;opacity:.7}
.av-chip:hover+.av-hex{opacity:1}
.av-rating{margin-bottom:3px}
.av-rating-label{font-family:var(--pixel);font-size:.7rem;color:var(--dim);display:flex;justify-content:space-between}
.av-rating-bar{height:5px;background:rgba(255,255,255,.05);overflow:hidden;margin-top:2px}
.av-rating-fill{height:100%;background:var(--accent);width:0;transition:width 1s ease}
.av-tags{display:flex;flex-wrap:wrap;gap:3px}
.av-tag{
  font-family:var(--pixel);padding:2px 5px;font-size:.65rem;
  border:1px solid var(--dim);color:var(--accent);transition:all .2s;
}
.av-tag:hover{background:var(--accent);color:var(--bg)}
/* ═══ ATLAS OS-WINDOW BLOCKERS ═══ */
.os-window{
  position:absolute;z-index:10;
  background:var(--bg2);border:2px solid var(--accent);
  box-shadow:0 0 15px var(--glow),4px 4px 0 rgba(0,0,0,.5);
  min-width:180px;max-width:70%;
  animation:osWindowPop .3s ease;
  cursor:default;
  user-select:none;
}
@keyframes osWindowPop{
  0%{transform:scale(0);opacity:0}
  70%{transform:scale(1.05)}
  100%{transform:scale(1);opacity:1}
}
.os-win-bar{
  display:flex;justify-content:space-between;align-items:center;
  padding:3px 6px;background:var(--accent);
  cursor:grab;
}
.os-win-title{font-family:var(--pixel);font-size:.6rem;color:var(--bg);font-weight:bold;letter-spacing:.05em}
.os-win-close{
  width:16px;height:16px;display:flex;align-items:center;justify-content:center;
  font-size:.6rem;color:var(--bg);background:rgba(0,0,0,.2);
  cursor:pointer;border:1px solid rgba(0,0,0,.3);
  font-family:var(--pixel);
}
.os-win-close:hover{background:var(--accent2);color:#fff}
.os-win-body{
  padding:8px 10px;font-family:var(--pixel);font-size:.75rem;
  color:var(--accent);text-align:center;line-height:1.5;
}
.os-win-body .os-emoji{font-size:1.5rem;display:block;margin-bottom:4px}
.av-share-msg{text-align:center;font-family:var(--pixel);font-size:.7rem;color:var(--dim);padding:1rem;font-style:italic}

/* ═══ SCREENSHOT POPUP ═══ */
#ss-popup{position:fixed;inset:0;z-index:9000;background:rgba(0,0,0,.95);display:flex;align-items:center;justify-content:center;padding:1rem}
.ss-box{text-align:center;padding:1.5rem;border:2px solid var(--accent);background:var(--bg);box-shadow:0 0 30px var(--glow);max-width:360px;width:100%}
.ss-box pre{font-family:var(--pixel);font-size:.85rem;color:var(--accent);margin-bottom:1.2rem;white-space:pre-wrap;line-height:1.6;text-align:left}
.ss-box button{font-family:var(--pixel);font-size:.9rem;padding:8px 24px;border:1px solid var(--accent);background:none;color:var(--accent);cursor:pointer;width:100%}
.ss-box button:hover{background:var(--accent);color:var(--bg)}

/* ═══ TV MODAL ═══ */
#tv-modal{position:fixed;inset:0;z-index:8000;display:flex;align-items:center;justify-content:center}
.tv-bg{position:absolute;inset:0;background:rgba(0,0,0,.9)}
.tv-box{position:relative;width:min(340px,92vw);border:2px solid var(--accent);background:var(--bg);box-shadow:0 0 20px var(--glow)}
.tv-screen{font-family:var(--pixel);font-size:.85rem;color:var(--accent);padding:1.5rem;white-space:pre-wrap;text-align:center;min-height:150px}
.tv-screen button{font-family:var(--pixel);font-size:.85rem;padding:6px 16px;border:1px solid var(--accent);background:none;color:var(--accent);cursor:pointer;margin-top:.5rem}
.tv-screen button:hover{background:var(--accent);color:var(--bg)}
.tv-x{position:absolute;top:-10px;right:-10px;width:20px;height:20px;border:1px solid var(--accent);background:var(--bg);color:var(--accent);font-size:.6rem;cursor:pointer;display:flex;align-items:center;justify-content:center}

/* ═══ COOKIE CONSENT ═══ */
#cookie-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:9999;
  background:var(--bg2);border-top:2px solid var(--accent);
  padding:10px;
  box-shadow:0 -4px 20px rgba(0,0,0,.5);
}
.cookie-inner{display:flex;align-items:center;justify-content:space-between;gap:10px;max-width:700px;margin:0 auto;flex-wrap:wrap}
.cookie-text{font-family:var(--pixel);font-size:.7rem;color:var(--text);flex:1;line-height:1.5}
.cookie-text a{color:var(--accent)}
.cookie-btn{
  font-family:var(--pixel);font-size:.75rem;padding:6px 16px;
  border:1px solid var(--accent);background:var(--accent);
  color:var(--bg);cursor:pointer;white-space:nowrap;
}
.cookie-btn:hover{box-shadow:0 0 10px var(--glow)}

/* ═══ SCROLLBAR ═══ */
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--accent)}

/* ═══ RESPONSIVE ═══ */
@media(min-width:500px){.atlas-grid{grid-template-columns:repeat(4,1fr)}}
@media(min-width:700px){.atlas-grid{grid-template-columns:repeat(5,1fr)}}
