/* ── 3ORG.ORG — SIGNAL DIAGNOSTIC SYSTEM ── */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Space+Mono:wght@400;700&display=swap');

:root{
  --bg:#050505;--fg:#efefeb;--dim:#555555;--ghost:#1a1a1a;--rule:#1e1e1e;
  --pad:clamp(20px,5vw,72px);--nav-h:48px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:auto}
body{
  background:var(--bg);color:var(--fg);
  font-family:'Space Mono',monospace;font-size:11px;line-height:1.6;
  letter-spacing:.05em;-webkit-font-smoothing:antialiased;
  cursor:crosshair;overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{display:block}
button{font-family:'Space Mono',monospace;cursor:crosshair}

/* ── SCAN LINES ── */
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:9999;
  background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.06) 2px,rgba(0,0,0,.06) 4px);
}

/* ── NAV ── */
#nav{
  position:fixed;top:0;left:0;right:0;height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 var(--pad);background:var(--bg);border-bottom:1px solid var(--rule);z-index:100;
}
.nav-logo{
  font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:10px;color:var(--fg);position:relative;
}
.nav-logo::before,.nav-logo::after{
  content:attr(data-text);position:absolute;top:0;left:0;
  font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:10px;
}
.nav-logo::before{color:var(--fg);clip-path:polygon(0 30%,100% 30%,100% 50%,0 50%);transform:translateX(-2px);animation:glitch-a 8s infinite;opacity:.7}
.nav-logo::after{color:var(--fg);clip-path:polygon(0 60%,100% 60%,100% 75%,0 75%);transform:translateX(2px);animation:glitch-b 8s infinite;opacity:.5}
@keyframes glitch-a{0%,89%,100%{transform:translateX(-2px);opacity:0}90%{transform:translateX(-6px);opacity:.7}91%{transform:translateX(3px);opacity:.5}92%{transform:translateX(-2px);opacity:0}94%{transform:translateX(-4px);opacity:.6}95%{transform:translateX(2px);opacity:0}}
@keyframes glitch-b{0%,89%,100%{transform:translateX(2px);opacity:0}90%{transform:translateX(6px);opacity:.5}91.5%{transform:translateX(-3px);opacity:.4}93%{transform:translateX(2px);opacity:0}94.5%{transform:translateX(4px);opacity:.4}95.5%{transform:translateX(-2px);opacity:0}}

.nav-links{display:flex;align-items:center;gap:clamp(12px,2vw,36px)}
.nav-links a,.nav-merch{font-size:10px;letter-spacing:3px;color:var(--dim);transition:color .05s;background:none;border:none}
.nav-links a:hover,.nav-links a.active,.nav-merch:hover{color:var(--fg)}
.nav-burger{display:none;background:none;border:none;color:var(--fg);font-size:16px;padding:8px;cursor:crosshair}

/* ── TXTMOSH HOVER FX — char glitch on interactive elements ── */
.btn,.nav-links a,.nav-merch,.release-row,.disc-item,.social-cell,
.tool-cell,.entity-row,.press-row,.stream-btn{
  position:relative;overflow:hidden;
}
/* Scan-line wipe on hover */
.btn::after,.stream-btn::after{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(255,255,255,.03) 3px,rgba(255,255,255,.03) 4px);
  opacity:0;transition:opacity .1s;pointer-events:none;
}
.btn:hover::after,.stream-btn:hover::after{opacity:1}
/* Glitch shift on button text */
.btn:hover,.stream-btn:hover{
  animation:btn-glitch .15s steps(2) 1;
}
@keyframes btn-glitch{
  0%{transform:translateX(0)}
  25%{transform:translateX(-2px)}
  50%{transform:translateX(2px)}
  75%{transform:translateX(-1px)}
  100%{transform:translateX(0)}
}
/* Release row hover — horizontal glitch stripe */
.release-row::before{
  content:'';position:absolute;left:0;right:0;height:1px;
  background:var(--fg);opacity:0;top:50%;transition:opacity .05s;pointer-events:none;
}
.release-row:hover::before{animation:stripe-flick .2s steps(3) 1}
@keyframes stripe-flick{0%{opacity:0;top:30%}33%{opacity:.4;top:50%}66%{opacity:.2;top:70%}100%{opacity:0;top:50%}}
/* Disc item — image desaturate lift with glitch flash */
.disc-item img{transition:filter .15s}
.disc-item:hover img{filter:grayscale(0%)}
.disc-item::after{
  content:'';position:absolute;inset:0;background:rgba(239,239,235,.04);
  opacity:0;pointer-events:none;
}
.disc-item:hover::after{animation:flash-in .12s steps(2) 1}
@keyframes flash-in{0%{opacity:0}50%{opacity:1}100%{opacity:0}}
/* Nav links — char flicker */
.nav-links a:hover,.nav-merch:hover{animation:char-flick .1s steps(3) 1}
@keyframes char-flick{0%{opacity:1}33%{opacity:.4}66%{opacity:.8}100%{opacity:1}}
/* Page load — body wipes in */
body{animation:page-in .2s steps(4) 1}
@keyframes page-in{0%{opacity:0}50%{opacity:.6}75%{opacity:.85}100%{opacity:1}}

/* ── MOBILE MENU ── */
#mobileMenu{display:none;position:fixed;inset:0;top:var(--nav-h);background:var(--bg);z-index:99;flex-direction:column;padding:clamp(32px,6vw,60px) var(--pad)}
#mobileMenu.open{display:flex}
#mobileMenu a,#mobileMenu button{
  font-family:'Bebas Neue',sans-serif;font-size:clamp(36px,9vw,64px);letter-spacing:8px;
  color:var(--dim);padding:10px 0;border-bottom:1px solid var(--rule);
  transition:color .05s;background:none;text-align:left;width:100%;
}
#mobileMenu a:hover,#mobileMenu button:hover{color:var(--fg)}

/* ── PAGE WRAP ── */
.page-wrap{padding-top:var(--nav-h)}

/* ── SECTION PRIMITIVES ── */
.sec{border-bottom:1px solid var(--rule)}
.sec-inner{padding:clamp(48px,7vw,100px) var(--pad)}
.label{font-size:9px;letter-spacing:4px;color:var(--dim);display:block;margin-bottom:8px}
.h1{font-family:'Bebas Neue',sans-serif;font-size:clamp(48px,10vw,160px);letter-spacing:clamp(3px,1.5vw,20px);line-height:.88;color:var(--fg)}
.h2{font-family:'Bebas Neue',sans-serif;font-size:clamp(32px,5vw,64px);letter-spacing:clamp(3px,1vw,12px);line-height:.9;color:var(--fg)}
.h3{font-family:'Bebas Neue',sans-serif;font-size:clamp(20px,3vw,36px);letter-spacing:6px;color:var(--fg)}
.body{font-size:clamp(10px,1.1vw,11px);letter-spacing:2px;color:var(--dim);line-height:2;max-width:540px}
.rule{border:none;border-top:1px solid var(--rule);margin:0}

/* ── DATA ROW ── */
.data-row{display:flex;align-items:baseline;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--rule);gap:20px}
.data-row:last-child{border-bottom:none}
.data-key{font-size:9px;letter-spacing:3px;color:var(--dim);flex-shrink:0}
.data-val{font-size:11px;letter-spacing:2px;color:var(--fg);text-align:right}

/* ── TERMINAL BUTTON ── */
.btn{
  display:inline-block;font-size:10px;letter-spacing:4px;
  color:var(--dim);border:1px solid var(--rule);padding:10px 20px;
  background:none;transition:color .05s,border-color .05s;cursor:crosshair;text-decoration:none;
  -webkit-tap-highlight-color:transparent;min-height:44px;display:inline-flex;align-items:center;
}
.btn:hover{color:var(--fg);border-color:var(--dim)}
.btn.inv{background:var(--fg);color:var(--bg);border-color:var(--fg)}
.btn.inv:hover{background:transparent;color:var(--fg)}
.stream-btn{
  font-family:'Space Mono',monospace;font-size:9px;letter-spacing:2px;
  padding:8px 14px;border:1px solid var(--rule);color:var(--smoke);
  text-decoration:none;transition:color .05s,border-color .05s;
  -webkit-tap-highlight-color:transparent;min-height:36px;display:inline-flex;align-items:center;
}
.stream-btn:hover{color:var(--fg);border-color:var(--dim)}

/* ── FOOTER ── */
#footer{padding:clamp(40px,5vw,64px) var(--pad) clamp(24px,3vw,40px);border-top:1px solid var(--rule)}
.footer-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer-col-label{font-size:8px;letter-spacing:4px;color:var(--dim);margin-bottom:16px;display:block}
.footer-col a,.footer-col span{display:block;font-size:10px;letter-spacing:2px;color:var(--dim);margin-bottom:10px;transition:color .05s}
.footer-col a:hover{color:var(--fg)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;padding-top:24px;border-top:1px solid var(--rule)}
.footer-bottom span{font-size:8px;letter-spacing:2px;color:var(--rule)}
.footer-logo{font-family:'Bebas Neue',sans-serif;font-size:14px;letter-spacing:8px;color:var(--rule)}

/* ── MERCH MODAL ── */
#merchModal{display:none;position:fixed;inset:0;z-index:200;background:var(--bg);align-items:center;justify-content:center;flex-direction:column;gap:0;cursor:crosshair}
#merchModal.open{display:flex}
.merch-label{font-size:9px;letter-spacing:6px;color:var(--dim);margin-bottom:24px}
.merch-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(48px,12vw,140px);letter-spacing:clamp(4px,2vw,24px);color:var(--fg);line-height:.88;text-align:center}
.merch-status{font-size:9px;letter-spacing:6px;color:var(--dim);margin-top:32px}
.merch-close{position:absolute;top:clamp(16px,3vw,28px);right:var(--pad);font-size:9px;letter-spacing:3px;color:var(--dim);background:none;border:none;transition:color .05s;min-height:44px;display:flex;align-items:center}
.merch-close:hover{color:var(--fg)}

/* ── MOBILE RESPONSIVE ── */
@media(max-width:768px){
  .nav-links,.nav-cta{display:none}
  .nav-burger{display:block}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:8px}
  /* Increase tap targets on mobile */
  .btn{min-height:48px;padding:12px 20px}
  .stream-btn{min-height:44px;padding:10px 14px}
  /* Reduce motion on small screens */
  body::before{opacity:.4}
}
@media(max-width:480px){
  :root{--pad:20px}
  .h1{font-size:clamp(40px,14vw,80px)}
  body::before{display:none} /* remove scan lines on very small screens for perf */
}
/* Respect reduced motion preference */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .nav-logo::before,.nav-logo::after{display:none}
}
