@import url('https://fonts.googleapis.com/css2?family=Bangers&family=Patrick+Hand&display=swap');

:root {
  --paper: #e8e4dc;
  --paper-dark: #d4cfc4;
  --ink: #1a1a1a;
  --ink-light: #3a3a3a;
  --ink-faded: #666;
  --white: #f5f5f0;
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: 'Patrick Hand', cursive, sans-serif;
  background: var(--ink);
  color: var(--ink);
  line-height: 1.7;
  font-size: 19px;
}

/* Textura de ruido */
body::after {
  content: '';
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  opacity: 0.12;
  z-index: 10000;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ==================== PÁGINA PRINCIPAL ==================== */
.page {
  background: var(--paper);
  max-width: 800px;
  margin: 40px auto;
  padding: 60px 50px;
  position: relative;
  box-shadow: 
    0 0 0 3px var(--ink),
    8px 8px 0 var(--ink),
    0 20px 60px rgba(0,0,0,0.4);
}

@media (max-width: 860px) {
  .page {
    margin: 20px;
    padding: 40px 30px;
  }
}

/* Manchas de página */
.page::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  pointer-events: none;
  background: 
    radial-gradient(ellipse at 10% 5%, rgba(0,0,0,0.06) 0%, transparent 40%),
    radial-gradient(ellipse at 90% 95%, rgba(0,0,0,0.08) 0%, transparent 50%),
    radial-gradient(ellipse at 50% 50%, rgba(0,0,0,0.03) 0%, transparent 60%);
}

/* ==================== TÍTULO PRINCIPAL ==================== */
.title {
  font-family: 'Bangers', cursive;
  font-size: clamp(2.5rem, 8vw, 4rem);
  text-align: center;
  letter-spacing: 3px;
  margin-bottom: 10px;
  color: var(--ink);
  text-shadow: 
    3px 3px 0 var(--paper-dark),
    -1px -1px 0 var(--ink-light);
  transform: rotate(-1deg);
}

.subtitle {
  text-align: center;
  font-size: 1.3rem;
  color: var(--ink-faded);
  margin-bottom: 40px;
  font-style: italic;
}

/* ==================== VIÑETAS / PANELES ==================== */
.panel {
  border: 3px solid var(--ink);
  padding: 24px;
  margin: 30px 0;
  position: relative;
  background: var(--white);
  box-shadow: 4px 4px 0 var(--ink);
}

.panel--highlight {
  background: #fff;
  border-width: 4px;
}

.panel--dark {
  background: var(--ink);
  color: var(--paper);
}

.panel__title {
  font-family: 'Bangers', cursive;
  font-size: 1.6rem;
  margin-bottom: 16px;
  letter-spacing: 2px;
  color: var(--ink);
}

.panel--dark .panel__title {
  color: var(--paper);
}

/* ==================== TEXTO ==================== */
p {
  margin-bottom: 20px;
}

strong {
  font-weight: bold;
  color: var(--ink);
}

em {
  font-style: italic;
  background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,0.1) 60%);
  padding: 0 4px;
}

/* ==================== IMAGEN ==================== */
.comic-image {
  width: 100%;
  border: 3px solid var(--ink);
  box-shadow: 5px 5px 0 var(--ink);
  margin: 20px 0;
}

.comic-image--float {
  float: right;
  width: 45%;
  margin: 0 0 20px 30px;
}

@media (max-width: 600px) {
  .comic-image--float {
    float: none;
    width: 100%;
    margin: 20px 0;
  }
}

/* ==================== LISTA DE REGLAS ==================== */
.rules {
  list-style: none;
  margin: 24px 0;
  padding: 0;
}

.rules li {
  padding: 12px 0 12px 35px;
  border-bottom: 2px dashed var(--ink-light);
  position: relative;
  font-size: 1.1rem;
}

.rules li::before {
  content: '✦';
  position: absolute;
  left: 8px;
  top: 12px;
  font-size: 1rem;
}

.rules li:last-child {
  border-bottom: none;
}

/* ==================== CAJA GANADORA ==================== */
.winner {
  background: var(--ink);
  color: var(--paper);
  border: 4px solid var(--ink);
  padding: 40px;
  margin: 40px 0;
  text-align: center;
  position: relative;
  box-shadow: 6px 6px 0 var(--ink-light);
}

.winner::before {
  content: '★ GANADORA ★';
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--paper);
  color: var(--ink);
  padding: 4px 20px;
  font-family: 'Bangers', cursive;
  font-size: 1rem;
  letter-spacing: 3px;
  border: 2px solid var(--ink);
}

.winner__name {
  font-family: 'Bangers', cursive;
  font-size: 2.5rem;
  letter-spacing: 2px;
  margin-bottom: 8px;
}

.winner__email {
  font-size: 1rem;
  opacity: 0.7;
}

/* ==================== SEPARADOR ==================== */
.divider {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 40px 0;
  gap: 20px;
  color: var(--ink-faded);
}

.divider::before,
.divider::after {
  content: '';
  flex: 1;
  height: 2px;
  background: 
    repeating-linear-gradient(
      90deg,
      var(--ink) 0px,
      var(--ink) 8px,
      transparent 8px,
      transparent 16px
    );
}

/* ==================== BOTÓN ==================== */
.btn {
  display: inline-block;
  font-family: 'Bangers', cursive;
  font-size: 1.3rem;
  letter-spacing: 2px;
  background: var(--ink);
  color: var(--paper);
  padding: 16px 40px;
  text-decoration: none;
  border: 3px solid var(--ink);
  box-shadow: 4px 4px 0 var(--ink-light);
  transition: all 0.15s;
  position: relative;
}

.btn:hover {
  transform: translate(2px, 2px);
  box-shadow: 2px 2px 0 var(--ink-light);
}

.btn:active {
  transform: translate(4px, 4px);
  box-shadow: none;
}

/* ==================== HEADER FECHA ==================== */
.date {
  font-size: 0.9rem;
  color: var(--ink-faded);
  text-transform: uppercase;
  letter-spacing: 3px;
  margin-bottom: 8px;
  text-align: center;
}

/* ==================== NOTA FINAL ==================== */
.note {
  background: var(--paper-dark);
  border-left: 4px solid var(--ink);
  padding: 20px 24px;
  margin: 30px 0;
  font-style: italic;
}

.note a {
  color: var(--ink);
  font-weight: bold;
}

/* ==================== FOOTER ==================== */
.footer {
  text-align: center;
  padding: 40px 20px;
  color: var(--paper-dark);
  font-size: 0.9rem;
}

.footer a {
  color: var(--paper);
  text-decoration: none;
  border-bottom: 1px solid var(--paper-dark);
}

/* ==================== NAV SIMPLE ==================== */
.nav-simple {
  text-align: center;
  padding: 20px;
  background: var(--ink);
}

.nav-simple a {
  color: var(--paper);
  text-decoration: none;
  margin: 0 15px;
  font-family: 'Bangers', cursive;
  letter-spacing: 2px;
  font-size: 1.1rem;
  opacity: 0.8;
  transition: opacity 0.2s;
}

.nav-simple a:hover {
  opacity: 1;
}

/* ==================== CENTRAR ==================== */
.text-center {
  text-align: center;
}

.mt-40 {
  margin-top: 40px;
}

/* ==================== RESPONSIVE ==================== */

/* Tablet */
@media (max-width: 768px) {
  body {
    font-size: 17px;
  }
  
  .page {
    margin: 15px;
    padding: 30px 25px;
    box-shadow: 
      0 0 0 2px var(--ink),
      5px 5px 0 var(--ink),
      0 15px 40px rgba(0,0,0,0.4);
  }
  
  .title {
    font-size: 2.2rem;
    letter-spacing: 2px;
  }
  
  .subtitle {
    font-size: 1.1rem;
    margin-bottom: 30px;
  }
  
  .panel {
    padding: 20px;
    margin: 25px 0;
    box-shadow: 3px 3px 0 var(--ink);
  }
  
  .panel__title {
    font-size: 1.4rem;
  }
  
  .winner {
    padding: 35px 20px;
    margin: 30px 0;
  }
  
  .winner__name {
    font-size: 2rem;
  }
  
  .winner::before {
    font-size: 0.85rem;
    padding: 4px 15px;
  }
  
  .rules li {
    padding: 10px 0 10px 30px;
    font-size: 1rem;
  }
  
  .btn {
    padding: 14px 30px;
    font-size: 1.1rem;
  }
  
  .comic-image {
    box-shadow: 3px 3px 0 var(--ink);
  }
  
  .divider {
    margin: 30px 0;
  }
  
  .note {
    padding: 16px 20px;
  }
}

/* Móvil */
@media (max-width: 480px) {
  body {
    font-size: 16px;
  }
  
  .page {
    margin: 10px;
    padding: 25px 18px;
    box-shadow: 
      0 0 0 2px var(--ink),
      4px 4px 0 var(--ink),
      0 10px 30px rgba(0,0,0,0.4);
  }
  
  .title {
    font-size: 1.8rem;
    letter-spacing: 1px;
    transform: none;
  }
  
  .subtitle {
    font-size: 1rem;
    margin-bottom: 25px;
  }
  
  .panel {
    padding: 16px;
    margin: 20px 0;
    border-width: 2px;
    box-shadow: 2px 2px 0 var(--ink);
  }
  
  .panel__title {
    font-size: 1.2rem;
    margin-bottom: 12px;
  }
  
  .winner {
    padding: 30px 15px;
    margin: 25px 0;
    border-width: 3px;
    box-shadow: 4px 4px 0 var(--ink-light);
  }
  
  .winner__name {
    font-size: 1.6rem;
    letter-spacing: 1px;
  }
  
  .winner__email {
    font-size: 0.9rem;
    word-break: break-all;
  }
  
  .winner::before {
    font-size: 0.75rem;
    padding: 3px 12px;
    letter-spacing: 2px;
    top: -12px;
  }
  
  .rules li {
    padding: 10px 0 10px 28px;
    font-size: 0.95rem;
  }
  
  .rules li::before {
    left: 5px;
    font-size: 0.9rem;
  }
  
  .btn {
    padding: 12px 24px;
    font-size: 1rem;
    width: 100%;
    text-align: center;
    box-shadow: 3px 3px 0 var(--ink-light);
  }
  
  .comic-image {
    border-width: 2px;
    box-shadow: 3px 3px 0 var(--ink);
    margin: 15px 0;
  }
  
  .divider {
    margin: 25px 0;
    gap: 15px;
  }
  
  .note {
    padding: 14px 16px;
    margin: 20px 0;
    font-size: 0.95rem;
  }
  
  .nav-simple {
    padding: 15px;
  }
  
  .nav-simple a {
    font-size: 1rem;
    margin: 0 10px;
  }
  
  .footer {
    padding: 30px 15px;
    font-size: 0.85rem;
  }
  
  .date {
    font-size: 0.8rem;
    letter-spacing: 2px;
  }
  
  p {
    margin-bottom: 16px;
  }
  
  .mt-40 {
    margin-top: 30px;
  }
}
