/* Impostazioni generali pagina */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
html, body {
  height: 100%;
}
body {
  background-color: #000;          /* Sfondo nero pieno */
  color: #fff;                    /* Testo bianco di default */
  font-family: 'Orbitron', sans-serif;
  font-weight: 400;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  overflow: hidden;               /* Evita scroll dovuto a glitch fuori area */
}

/* Titolo "North Frame" con effetto glitch */
.glitch-text {
  position: relative;
  font-weight: 800;               /* Usa peso forte per il titolo */
  font-size: clamp(2.5rem, 10vw, 6rem);  /* Dimensione adattiva (min 2.5rem, max 6rem) */
  letter-spacing: 2px;
  text-transform: none;           /* Mantiene maiuscole/minuscole come da testo */
  /* Animazione leggera di tremolio (skew) del testo principale */
  animation: text-glitch 1.5s linear infinite alternate-reverse;
}

/* Slogan/tagline sotto il titolo */
.tagline {
  font-weight: 400;
  font-size: clamp(1rem, 3vw, 1.5rem);   /* Testo adattivo anche per tagline */
  margin-top: 1.5rem;
}

/* Pseudo-elementi per l'effetto glitch (uno rosso e uno blu) */
.glitch-text::before,
.glitch-text::after {
  content: attr(data-text);    /* Duplica il testo del titolo */
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #000;            /* Sfondo nero per coprire testo sottostante */
  overflow: hidden;
}
.glitch-text::before {
  left: -2px;
  text-shadow: -2px 0 red;     /* Ombra di testo rossa spostata a sinistra */
  animation: glitch-anim-1 1.5s linear infinite alternate-reverse;
}
.glitch-text::after {
  left: 2px;
  text-shadow: -2px 0 blue;    /* Ombra di testo blu spostata a sinistra */
  animation: glitch-anim-2 1.5s linear infinite alternate-reverse;
}

/* Keyframes per animazione glitch del testo principale (leggera distorsione) */
@keyframes text-glitch {
  0%   { transform: skew(-2deg); }
  40%  { transform: skew(2deg);  }
  45%  { transform: skew(-2deg); }
  50%  { transform: skew(2deg);  }
  100% { transform: skew(-2deg); }
}

/* Keyframes per gli effetti glitch sui pseudo-elementi colorati */
@keyframes glitch-anim-1 {
  0%  { clip: rect(80px, 9999px, 85px, 0); }
  5%  { clip: rect(84px, 9999px, 118px, 0); }
  10% { clip: rect(22px, 9999px, 83px, 0); }
  15% { clip: rect(15px, 9999px, 15px, 0); }
  20% { clip: rect(116px, 9999px, 89px, 0); }
  25% { clip: rect(95px, 9999px, 122px, 0); }
  30% { clip: rect(108px, 9999px, 10px, 0); }
  35% { clip: rect(118px, 9999px, 76px, 0); }
  40% { clip: rect(53px, 9999px, 46px, 0); }
  45% { clip: rect(131px, 9999px, 121px, 0); }
  50% { clip: rect(79px, 9999px, 68px, 0); }
  55% { clip: rect(40px, 9999px, 108px, 0); }
  60% { clip: rect(25px, 9999px, 94px, 0); }
  65% { clip: rect(125px, 9999px, 119px, 0); }
  70% { clip: rect(59px, 9999px, 87px, 0); }
  75% { clip: rect(70px, 9999px, 69px, 0); }
  80% { clip: rect(109px, 9999px, 67px, 0); }
  85% { clip: rect(29px, 9999px, 96px, 0); }
  90% { clip: rect(41px, 9999px, 53px, 0); }
  95% { clip: rect(110px, 9999px, 37px, 0); }
  100%{ clip: rect(90px, 9999px, 92px, 0); }
}
@keyframes glitch-anim-2 {
  0%  { clip: rect(73px, 9999px, 132px, 0); }
  5%  { clip: rect(126px, 9999px, 60px, 0); }
  10% { clip: rect(119px, 9999px, 28px, 0); }
  15% { clip: rect(154px, 9999px, 40px, 0); }
  20% { clip: rect(87px, 9999px, 64px, 0); }
  25% { clip: rect(55px, 9999px, 19px, 0); }
  30% { clip: rect(105px, 9999px, 115px, 0); }
  35% { clip: rect(28px, 9999px, 95px, 0); }
  40% { clip: rect(99px, 9999px, 27px, 0); }
  45% { clip: rect(160px, 9999px, 30px, 0); }
  50% { clip: rect(46px, 9999px, 102px, 0); }
  55% { clip: rect(26px, 9999px, 106px, 0); }
  60% { clip: rect(123px, 9999px, 8px, 0); }
  65% { clip: rect(155px, 9999px, 123px, 0); }
  70% { clip: rect(29px, 9999px, 118px, 0); }
  75% { clip: rect(43px, 9999px, 24px, 0); }
  80% { clip: rect(129px, 9999px, 67px, 0); }
  85% { clip: rect(101px, 9999px, 127px, 0); }
  90% { clip: rect(121px, 9999px, 0px, 0); }
  95% { clip: rect(110px, 9999px, 84px, 0); }
  100%{ clip: rect(19px, 9999px, 112px, 0); }
}