:root{
  --bg: #08110b;
  --panel: #0e1b12;
  --panel-2: #102117;
  --line: #234831;
  --text: #b7ffbf;
  --muted: #79c980;
  --strong: #e3ffe7;
  --accent: #48ff72;
  --accent-2: #b6ff00;
  --danger: #ff7a7a;
  --shadow: 0 0 20px rgba(72, 255, 114, 0.08);
  --radius: 10px;
  --font: "Courier New", Courier, monospace;
}

*{
  box-sizing: border-box;
}

html, body{
  margin: 0;
  padding: 0;
  min-height: 100%;
  background: radial-gradient(circle at top, #102015 0%, #08110b 50%, #050805 100%);
  color: var(--text);
  font-family: var(--font);
}

body{
  position: relative;
  overflow-x: hidden;
}

.scanlines{
  pointer-events: none;
  position: fixed;
  inset: 0;
  background:
    repeating-linear-gradient(
      to bottom,
      rgba(255,255,255,0.02) 0px,
      rgba(255,255,255,0.02) 1px,
      transparent 2px,
      transparent 4px
    );
  opacity: 0.15;
  z-index: 20;
}

.crt-flicker{
  pointer-events: none;
  position: fixed;
  inset: 0;
  z-index: 21;
  opacity: 0.06;
  background: rgba(255,255,255,0.04);
  animation: flicker 0.14s infinite;
}

.app{
  position: relative;
  z-index: 3;
  width: min(1200px, 94%);
  margin: 0 auto;
  padding: 28px 0 60px;
}

/* HERO */

.hero{
  position: relative;
  margin-bottom: 20px;
  overflow: hidden;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  background:
    linear-gradient(180deg, rgba(8,17,11,0.96), rgba(10,18,12,0.98));
}

.hero-media{
  position: relative;
  width: 100%;
  height: 320px;
  overflow: hidden;
  background:
    linear-gradient(135deg, #050805 0%, #0c1810 100%);
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
}

.hero-media img{
  position: relative;
  z-index: 1;
  width: auto;
  max-width: min(100%, 980px);
  height: 100%;
  object-fit: contain;
  object-position: top left;
  image-rendering: pixelated;
  image-rendering: crisp-edges;
  filter:
    contrast(1.15)
    saturate(1.08)
    brightness(0.92);
  transform: translate(0, 0);
  animation: heroIdle 5s ease-in-out infinite;
}

.hero-overlay{
  position: absolute;
  inset: 0;
  z-index: 4;
  background:
    linear-gradient(to bottom, rgba(0,0,0,0.08), rgba(0,0,0,0.78)),
    linear-gradient(to right, rgba(0,0,0,0.08), rgba(0,0,0,0.28)),
    repeating-linear-gradient(
      to bottom,
      rgba(255,255,255,0.02) 0px,
      rgba(255,255,255,0.02) 1px,
      transparent 2px,
      transparent 4px
    );
}

.hero-glitch{
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  opacity: 0;
  background-image: url("./pedro.png");
  background-repeat: no-repeat;
  background-position: top left;
  background-size: auto 100%;
  mix-blend-mode: screen;
}

.hero-glitch-1{
  filter: contrast(1.2) saturate(1.2);
}

.hero-glitch-2{
  filter: contrast(1.3) saturate(1.3) hue-rotate(-18deg);
}

.glitch-on-load .hero-glitch-1{
  opacity: 0.22;
  animation: glitchShift1 0.18s steps(2, end) infinite;
}

.glitch-on-load .hero-glitch-2{
  opacity: 0.18;
  animation: glitchShift2 0.13s steps(2, end) infinite;
}

.glitch-on-load #heroImage{
  animation:
    bootFlash 0.16s steps(2, end) 8,
    heroIdle 5s ease-in-out infinite 1.6s;
}

.hero-box{
  position: relative;
  z-index: 5;
  margin-top: -54px;
  margin-left: 18px;
  margin-right: 18px;
  border: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(16,33,23,0.92), rgba(9,17,12,0.97));
  border-radius: var(--radius);
  box-shadow: 0 0 25px rgba(72, 255, 114, 0.08);
  backdrop-filter: blur(4px);
  padding: 22px;
}

.kicker{
  margin: 0 0 8px;
  color: var(--accent-2);
  font-size: 0.85rem;
  letter-spacing: 1px;
}

h1{
  margin: 0 0 8px;
  font-size: clamp(2rem, 5vw, 4rem);
  color: var(--strong);
  text-transform: uppercase;
  line-height: 1;
  text-shadow: 0 0 10px rgba(72,255,114,0.15);
}

.tagline{
  margin: 0 0 10px;
  color: var(--accent);
  font-size: 0.83rem;
  letter-spacing: 1px;
}

.subtitle{
  margin: 0;
  max-width: 850px;
  color: var(--muted);
  line-height: 1.55;
}

/* CONTROLS */

.controls{
  display: grid;
  grid-template-columns: repeat(3, minmax(180px, 220px)) 1fr;
  gap: 14px;
  align-items: end;
  margin-bottom: 20px;
}

.control-group{
  display: flex;
  flex-direction: column;
  gap: 8px;
  border: 1px solid var(--line);
  background: var(--panel);
  border-radius: var(--radius);
  padding: 14px;
}

label{
  color: var(--accent-2);
  font-size: 0.9rem;
}

select,
textarea,
button{
  font-family: var(--font);
}

select{
  background: #09120c;
  color: var(--text);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 10px;
  font-size: 1rem;
}

.buttons{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  border: 1px solid var(--line);
  background: var(--panel);
  border-radius: var(--radius);
  padding: 14px;
}

button{
  background: var(--accent);
  color: #051008;
  border: 1px solid #7dff9b;
  border-radius: 6px;
  padding: 12px 16px;
  cursor: pointer;
  font-weight: bold;
  letter-spacing: 0.5px;
  transition: transform 0.08s ease, opacity 0.2s ease, box-shadow 0.2s ease;
}

button:hover{
  transform: translateY(-1px);
  box-shadow: 0 0 12px rgba(72,255,114,0.18);
}

button.secondary{
  background: transparent;
  color: var(--text);
  border-color: var(--line);
}

button.active-mode{
  background: var(--accent-2);
  color: #071008;
  border-color: var(--accent-2);
}

/* WORKSPACE */

.workspace{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-bottom: 18px;
}

.panel{
  border: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(14,27,18,0.98), rgba(10,18,12,0.98));
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow: hidden;
}

.panel-title{
  padding: 12px 14px;
  border-bottom: 1px solid var(--line);
  color: var(--accent-2);
  background: rgba(255,255,255,0.03);
  font-size: 0.95rem;
  letter-spacing: 1px;
}

textarea{
  width: 100%;
  min-height: 420px;
  resize: vertical;
  border: none;
  outline: none;
  padding: 16px;
  background: transparent;
  color: var(--text);
  font-size: 1rem;
  line-height: 1.6;
}

.output{
  min-height: 420px;
  padding: 16px;
  white-space: pre-wrap;
  line-height: 1.65;
  color: var(--strong);
}

.output-placeholder{
  color: var(--muted);
}

.output .block{
  margin-bottom: 10px;
}

.output .legend{
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px dashed rgba(121, 201, 128, 0.2);
  color: var(--muted);
  font-size: 0.92rem;
}

.mark{
  padding: 0 2px;
  border-radius: 3px;
  background: rgba(72, 255, 114, 0.14);
  color: var(--strong);
}

.mark-original{
  color: #ff9d9d;
}

.mark-new{
  color: #8dffab;
  font-weight: bold;
}

/* STATS */

.stats{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
  margin-bottom: 18px;
}

.stat-box{
  border: 1px solid var(--line);
  background: var(--panel-2);
  border-radius: var(--radius);
  padding: 16px;
}

.stat-label{
  display: block;
  color: var(--muted);
  margin-bottom: 8px;
}

.stat-value{
  display: block;
  color: var(--strong);
  font-size: 1.6rem;
  font-weight: bold;
}

/* LOG */

.log-section{
  border: 1px solid var(--line);
  background: var(--panel);
  border-radius: var(--radius);
  overflow: hidden;
}

.changes-log{
  padding: 16px;
  line-height: 1.6;
  color: var(--muted);
}

.change-item{
  padding: 8px 0;
  border-bottom: 1px dashed rgba(121, 201, 128, 0.2);
}

.change-item:last-child{
  border-bottom: none;
}

.original{
  color: var(--danger);
}

.new{
  color: var(--accent);
}

/* FOOTER */

.footer{
  margin-top: 18px;
  color: var(--muted);
  font-size: 0.92rem;
  line-height: 1.5;
}

/* ANIMACIONES */

@keyframes flicker{
  0%{ opacity: 0.05; }
  20%{ opacity: 0.08; }
  40%{ opacity: 0.04; }
  60%{ opacity: 0.09; }
  80%{ opacity: 0.03; }
  100%{ opacity: 0.06; }
}

@keyframes bootFlash{
  0%{
    transform: translate(0, 0);
    filter: contrast(1.35) brightness(1.1) saturate(1.25);
  }
  20%{
    transform: translate(-4px, 1px);
    filter: contrast(1.5) brightness(1.22) saturate(1.35);
  }
  40%{
    transform: translate(5px, -1px);
    filter: contrast(1.15) brightness(0.82) saturate(1.15);
  }
  60%{
    transform: translate(-3px, 2px);
    filter: contrast(1.45) brightness(1.15) saturate(1.3);
  }
  80%{
    transform: translate(2px, -2px);
    filter: contrast(1.2) brightness(0.88) saturate(1.1);
  }
  100%{
    transform: translate(0, 0);
    filter: contrast(1.15) brightness(0.92) saturate(1.08);
  }
}

@keyframes glitchShift1{
  0%{
    transform: translate(0, 0);
    clip-path: inset(0 0 0 0);
  }
  20%{
    transform: translate(-8px, 0);
    clip-path: inset(8% 0 60% 0);
  }
  40%{
    transform: translate(6px, 0);
    clip-path: inset(48% 0 22% 0);
  }
  60%{
    transform: translate(-3px, 0);
    clip-path: inset(72% 0 8% 0);
  }
  80%{
    transform: translate(4px, 0);
    clip-path: inset(18% 0 38% 0);
  }
  100%{
    transform: translate(0, 0);
    clip-path: inset(0 0 0 0);
  }
}

@keyframes glitchShift2{
  0%{
    transform: translate(0, 0);
    clip-path: inset(0 0 0 0);
  }
  25%{
    transform: translate(10px, 0);
    clip-path: inset(6% 0 70% 0);
  }
  50%{
    transform: translate(-6px, 0);
    clip-path: inset(40% 0 30% 0);
  }
  75%{
    transform: translate(5px, 0);
    clip-path: inset(78% 0 6% 0);
  }
  100%{
    transform: translate(0, 0);
    clip-path: inset(0 0 0 0);
  }
}

@keyframes heroIdle{
  0%{ transform: translate(0, 0); }
  50%{ transform: translate(2px, -1px); }
  100%{ transform: translate(0, 0); }
}

/* RESPONSIVE */

@media (max-width: 920px){
  .controls{
    grid-template-columns: 1fr;
  }

  .workspace{
    grid-template-columns: 1fr;
  }

  textarea,
  .output{
    min-height: 280px;
  }

  .stats{
    grid-template-columns: 1fr;
  }

  .hero-media{
    height: 250px;
  }

  .hero-media img{
    width: 100%;
    max-width: none;
    height: auto;
    max-height: 100%;
    object-fit: contain;
    object-position: top left;
  }

  .hero-glitch{
    background-size: contain;
    background-position: top left;
  }

  .hero-box{
    margin-top: -24px;
    margin-left: 10px;
    margin-right: 10px;
    padding: 18px;
  }
}

@media (max-width: 560px){
  .app{
    width: min(96%, 96%);
    padding-top: 18px;
  }

  .hero-media{
    height: 210px;
  }

  h1{
    font-size: clamp(1.7rem, 9vw, 2.6rem);
  }

  .kicker,
  .tagline{
    font-size: 0.75rem;
    line-height: 1.4;
  }

  .subtitle{
    font-size: 0.95rem;
  }

  .buttons{
    gap: 8px;
  }

  button{
    width: 100%;
  }
}
.rss-monitor{
  margin-bottom: 20px;
}

.rss-toolbar{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  padding: 14px;
  border-bottom: 1px solid var(--line);
  background: rgba(255,255,255,0.02);
}

.rss-feed-grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  padding: 14px;
}

.rss-card{
  border: 1px solid rgba(121, 201, 128, 0.18);
  border-radius: 8px;
  background: linear-gradient(180deg, rgba(16,33,23,0.75), rgba(9,17,12,0.92));
  padding: 14px;
}

.rss-meta{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 10px;
  color: var(--accent-2);
  font-size: 0.85rem;
}

.rss-source{
  font-weight: bold;
}

.rss-makeup{
  color: var(--accent);
}

.rss-title{
  margin: 0 0 10px;
  color: var(--strong);
  font-size: 1.05rem;
  line-height: 1.4;
}

.rss-desc{
  margin: 0 0 12px;
  color: var(--muted);
  line-height: 1.55;
}

.rss-translated{
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px dashed rgba(121, 201, 128, 0.2);
}

.rss-translated-title{
  margin: 0 0 8px;
  color: var(--accent);
  font-weight: bold;
}

.rss-link{
  display: inline-block;
  margin-top: 8px;
  color: var(--accent-2);
  text-decoration: none;
  border-bottom: 1px dotted var(--accent-2);
}

.rss-link:hover{
  opacity: 0.85;
}

.rss-empty{
  color: var(--muted);
}
