/* ===================================================
   Estilos específicos de terminos.html
   Los estilos globales (nav, footer, animaciones, etc.)
   están en stylesheet.css
   =================================================== */

/* ===== VARIABLES Y ESTILOS BASE ===== */
    :root {
      --primary-color: rgb(255, 153, 0);
      --primary-dark: rgb(255, 136, 0);
      --nav-bg: rgba(17, 17, 17, 0.95);
      --nav-border: rgb(255, 153, 0);
      --nav-text: #ffffff;
      --nav-accent: rgb(255, 153, 0);
      --nav-hover: rgb(255, 170, 51);
      --nav-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
      --nav-transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
      --bg-dark: #111111;
      --bg-darker: #0a0a0a;
      --text-light: #ffffff;
      --text-gray: #cccccc;
      --border-color: #333;
      --transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
      --shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
      --shadow-hover: 0 8px 30px rgba(255, 153, 0, 0.15);
    }

/* ===== ESTILOS ESPECÍFICOS PARA TÉRMINOS Y CONDICIONES ===== */
    .terminos-header {
      position: relative;
      width: 100%;
      height: 500px;
      overflow: hidden;
      display: flex;
      align-items: center;
      padding-left: 0;
      margin-bottom: 40px;
      animation: fadeIn 1s ease-out;
    }

.terminos-titulo {
      position: relative;
      z-index: 2;
      background-color: rgba(0, 0, 0, 0.85);
      color: white;
      padding: 100px 50px 40px 50px;
      font-size: 15mm;
      font-family: "Bebas Neue", sans-serif;
      height: 100%; 
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: flex-start; 
      animation: slideInFromLeft 1s ease-out 0.3s both;
    }

.terminos-titulo .naranja {
      color: var(--primary-color);
    }

.contenido-terminos {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 20px 60px 20px;
    }

/* Cajas principales */
    .seccion-terminos {
      background-color: var(--bg-dark);
      padding: 40px;
      margin-bottom: 30px;
      border-radius: 10px;
      border: 1px solid var(--border-color);
      transition: var(--transition);
      animation: fadeIn 0.8s ease-out;
      position: relative;
      overflow: hidden;
    }

.seccion-terminos:hover {
      box-shadow: var(--shadow-hover);
      transform: translateY(-5px);
    }

.seccion-terminos h2 {
      color: var(--primary-color);
      font-size: 2rem;
      margin-bottom: 25px;
      font-weight: bold;
      text-align: center;
      position: relative;
      padding-bottom: 10px;
    }

.seccion-terminos h2::after {
      content: '';
      position: absolute;
      bottom: 0;
      left: 50%;
      transform: translateX(-50%);
      width: 60px;
      height: 3px;
      background: var(--primary-color);
      border-radius: 2px;
    }

.seccion-terminos h3 {
    color: var(--text-light);
    font-size: 1.4rem;
    /* margin: 25px 0 15px 0; */
    font-weight: 600;
    text-align: center;
}

.seccion-terminos h4 {
      color: var(--primary-color);
      font-size: 1.3rem;
      margin-bottom: 15px;
      font-weight: 600;
      text-align: center;
    }

.seccion-terminos p {
      color: var(--text-light);
      font-size: 1.1rem;
      line-height: 1.6;
      margin-bottom: 15px;
      text-align: center;
    }

.seccion-terminos ul, .seccion-terminos ol {
      color: var(--text-light);
      padding-left: 20px;
      margin-bottom: 20px;
    }

.seccion-terminos li {
      margin-bottom: 10px;
      line-height: 1.5;
      position: relative;
      padding-left: 10px;
    }

.seccion-terminos li::before {
      content: '•';
      color: var(--primary-color);
      font-weight: bold;
      position: absolute;
      left: -18.5px;
    }

/* Destacado */
    .destacado {
      background-color: rgba(255, 153, 0, 0.08);
      padding: 25px;
      margin: 25px 0;
      border-radius: 8px;
      text-align: center;
      border: 1px solid rgba(255, 153, 0, 0.2);
      transition: var(--transition);
      position: relative;
      overflow: hidden;
    }

.destacado:hover {
      box-shadow: 0 0 15px rgba(255, 153, 0, 0.2);
      transform: scale(1.01);
    }

.destacado p {
      margin: 0;
      color: var(--text-light);
      font-weight: 500;
    }

/* Grid de categorías */
    .grid-categorias {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
      gap: 25px;
      margin: 25px 0;
    }

.categoria-item {
      background: linear-gradient(145deg, #1a1a1a, #151515);
      border-radius: 12px;
      padding: 30px 25px;
      transition: var(--transition);
      display: flex;
      flex-direction: column;
      align-items: center;
      text-align: center;
      gap: 15px;
      border: 1px solid var(--border-color);
      position: relative;
      overflow: hidden;
    }

.categoria-item:hover {
      transform: translateY(-8px);
      box-shadow: var(--shadow-hover);
    }

.categoria-icono {
      font-size: 3rem;
      margin-bottom: 10px;
      transition: var(--transition);
      animation: float 3s ease-in-out infinite;
    }

.categoria-item:hover .categoria-icono {
      transform: scale(1.1);
      animation: pulse 1s infinite;
    }

.categoria-contenido {
      display: flex;
      flex-direction: column;
      align-items: center;
      text-align: center;
      width: 100%;
    }

.categoria-contenido h4 {
      color: var(--text-light);
      font-size: 1.3rem;
      margin-bottom: 15px;
      font-weight: 600;
      text-align: center;
    }

.categoria-contenido p {
      color: var(--text-gray);
      font-size: 0.95rem;
      line-height: 1.5;
      margin-bottom: 20px;
      text-align: center;
      max-width: 300px;
    }

.categoria-info {
      display: flex;
      gap: 10px;
      margin-bottom: 25px;
      flex-wrap: wrap;
      justify-content: center;
    }

.cat-tipo, .cat-duracion {
      background-color: #333;
      color: var(--text-light);
      padding: 4px 8px;
      border-radius: 4px;
      font-size: 0.8rem;
      font-weight: 500;
      transition: var(--transition);
    }

.categoria-item:hover .cat-tipo,
    .categoria-item:hover .cat-duracion {
      background-color: #444;
    }

.cat-obligatorio {
      background-color: var(--primary-color);
      color: black;
      padding: 4px 8px;
      border-radius: 4px;
      font-size: 0.8rem;
      font-weight: bold;
      transition: var(--transition);
    }

.categoria-item:hover .cat-obligatorio {
      background-color: var(--primary-dark);
      transform: scale(1.05);
    }

.premisa-destacada {
      background: rgba(255, 153, 0, 0.1);
      border-radius: 8px;
      padding: 15px;
      text-align: center;
      margin-top: 10px;
      border: 1px solid rgba(255, 153, 0, 0.2);
      transition: var(--transition);
    }

.premisa-destacada:hover {
      box-shadow: 0 0 10px rgba(255, 153, 0, 0.15);
      transform: translateY(-3px);
    }

.premisa-destacada p {
      color: var(--primary-color);
      font-size: 0.9rem;
      margin: 0;
      font-weight: 500;
      line-height: 1.4;
    }

/* Botón volver */
    .btn-volver {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      background: linear-gradient(135deg, var(--primary-color), var(--primary-dark));
      color: black;
      text-decoration: none;
      padding: 12px 25px;
      border-radius: 8px;
      font-weight: bold;
      transition: var(--transition);
      margin: 30px auto;
      justify-content: center;
      border: none;
      position: relative;
      overflow: hidden;
    }

.btn-volver:hover {
      transform: translateY(-3px);
      box-shadow: 0 0 20px rgba(255, 153, 0, 0.3);
      color: white;
    }

/* ESTILOS PARA SOLAPAS SIMPLIFICADAS */
    .solapas-container {
      display: flex;
      flex-direction: column;
      gap: 20px;
      margin: 40px 0;
    }

.solapa-item {
      background: linear-gradient(145deg, #1a1a1a, #151515);
      border: 1px solid var(--border-color);
      border-radius: 16px;
      overflow: hidden;
      transition: var(--transition);
      box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
    }

.solapa-item:hover {
      border-color: var(--primary-color);
      box-shadow: var(--shadow-hover);
    }

.solapa-checkbox {
      display: none;
    }

.solapa-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px;
    cursor: pointer;
    transition: var(--transition);
    background: linear-gradient(135deg, rgba(255, 153, 0, 0.05), rgba(255, 136, 0, 0.02));
    border-bottom: 1px solid transparent;
}

.solapa-header:hover {
      background: linear-gradient(135deg, rgba(255, 153, 0, 0.08), rgba(255, 136, 0, 0.05));
    }

.solapa-checkbox:checked + .solapa-header {
      background: linear-gradient(135deg, rgba(255, 153, 0, 0.1), rgba(255, 136, 0, 0.07));
      border-bottom-color: rgba(255, 153, 0, 0.3);
    }

.solapa-icono-titulo {
      display: flex;
      align-items: flex-start;
      gap: 20px;
      flex: 1;
    }

.solapa-icono {
      font-size: 2.5rem;
      flex-shrink: 0;
      margin-top: 5px;
      transition: var(--transition);
      animation: float 3s ease-in-out infinite;
    }

.solapa-checkbox:checked + .solapa-header .solapa-icono {
      animation: pulse 1s infinite;
    }

.solapa-titulo h3 {
      color: var(--text-light);
      font-size: 1.8rem;
      margin-bottom: 8px;
      font-weight: 700;
      transition: var(--transition);
    }

.solapa-header:hover .solapa-titulo h3 {
      color: var(--primary-color);
    }

.solapa-meta {
      display: flex;
      flex-direction: column;
      gap: 6px;
    }

.solapa-autor {
      color: #888;
      font-size: 0.95rem;
      font-style: italic;
    }

.solapa-categoria {
      background: rgba(255, 153, 0, 0.2);
      color: var(--primary-color);
      padding: 4px 10px;
      border-radius: 10px;
      font-size: 0.85rem;
      font-weight: 600;
      align-self: flex-start;
    }

.solapa-indicador {
      display: flex;
      align-items: center;
      justify-content: center;
      width: 40px;
      height: 40px;
      background: rgba(255, 153, 0, 0.1);
      border-radius: 50%;
      transition: var(--transition);
      position: relative;
    }

.solapa-header:hover .solapa-indicador {
      background: rgba(255, 153, 0, 0.2);
      transform: scale(1.1);
    }

.solapa-mas,
    .solapa-menos {
      position: absolute;
      font-size: 1.5rem;
      font-weight: bold;
      color: var(--primary-color);
      transition: all 0.3s ease;
    }

.solapa-mas {
      opacity: 1;
      transform: scale(1);
    }

.solapa-menos {
      opacity: 0;
      transform: scale(0);
    }

.solapa-checkbox:checked + .solapa-header .solapa-mas {
      opacity: 0;
      transform: scale(0);
    }

.solapa-checkbox:checked + .solapa-header .solapa-menos {
      opacity: 1;
      transform: scale(1);
    }

.solapa-contenido {
      max-height: 0;
      overflow: hidden;
      transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1);
      opacity: 0;
      transform: translateY(-10px);
    }

.solapa-checkbox:checked ~ .solapa-contenido {
      max-height: 5000px;
      opacity: 1;
      transform: translateY(0);
      padding: 0 30px 30px 30px;
    }

/* ESTILOS PARA TEXTO CONTINUO SIMPLIFICADO */
    .texto-continuo {
      margin: 30px 0;
      line-height: 1.8;
      font-size: 1.1rem;
      color: var(--text-light);
    }

.texto-continuo p {
      margin-bottom: 20px;
      text-align: left;
      font-size: 1.1rem;
      line-height: 1.7;
    }

.texto-continuo p:last-child {
      margin-bottom: 0;
    }

.texto-continuo strong {
      color: var(--primary-color);
      font-weight: 600;
    }

.texto-continuo p:first-child {
      font-size: 1.3rem;
      font-weight: 600;
      color: var(--primary-color);
      margin-bottom: 25px;
      padding-bottom: 10px;
      border-bottom: 2px solid rgba(255, 153, 0, 0.3);
    }

/* ACCESO A CUENTO DIGITAL */
    .acceso-cuento-digital {
      margin: 40px 0;
    }

.acceso-presentacion {
      display: flex;
      align-items: center;
      gap: 25px;
      margin-bottom: 30px;
      padding: 30px;
      background: rgba(255, 153, 0, 0.1);
      border-radius: 12px;
    }

.acceso-icono-grande {
      font-size: 3rem;
      flex-shrink: 0;
    }

.acceso-informacion h4 {
      color: var(--primary-color);
      font-size: 1.5rem;
      margin-bottom: 10px;
    }

.acceso-informacion p {
      color: var(--text-light);
      font-size: 1.1rem;
      line-height: 1.6;
      margin: 0;
    }

.especificaciones-cuento {
      display: flex;
      justify-content: center;
      gap: 30px;
      margin-bottom: 35px;
      flex-wrap: wrap;
    }

.espec-item {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 8px;
      padding: 15px 20px;
      background: rgba(255, 255, 255, 0.05);
      border-radius: 8px;
      min-width: 140px;
    }

.espec-etiqueta {
      color: var(--text-gray);
      font-size: 0.9rem;
      font-weight: 500;
    }

.espec-valor {
      color: var(--primary-color);
      font-size: 1rem;
      font-weight: 600;
    }

.acciones-cuento {
      text-align: center;
    }

.btn-lectura {
      display: inline-flex;
      align-items: center;
      gap: 12px;
      background: linear-gradient(135deg, var(--primary-color), var(--primary-dark));
      color: black;
      text-decoration: none;
      padding: 18px 35px;
      border-radius: 10px;
      font-weight: bold;
      transition: var(--transition);
      margin-bottom: 15px;
    }

.btn-lectura:hover {
      transform: translateY(-3px);
      box-shadow: 0 8px 25px rgba(255, 153, 0, 0.4);
      color: white;
    }

.info-descarga {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      color: var(--text-gray);
      font-size: 0.9rem;
    }

@media screen and (max-width: 480px) {
      .solapa-icono-titulo {
        flex-direction: column;
        text-align: center;
        gap: 15px;
      }
      
      .solapa-icono {
        margin-top: 0;
      }
      
      .solapa-meta {
        align-items: center;
      }
      
      .solapa-categoria {
        align-self: center;
      }
    }