
    :root{
      --accent:#2D6CDF;
      --bg:#fff;
      --card:#ffffff;
      --muted:#828282;
      --shadow: 0 6px 18px rgba(16,24,40,0.08);
    }
    *{box-sizing:border-box}

    /* Contenedor principal */
    .card{
      width:920px; max-width:95vw; background:var(--card); border-radius:12px; box-shadow:var(--shadow); position:relative; padding-top:36px; overflow:hidden;
    }

    /* Pestañas: las hacemos "sobre-salientes" situadas parcialmente fuera del borde superior */
    .tabs{
      display:flex; gap:8px; padding:0 16px; position:relative; z-index:20; justify-content:flex-start; align-items:flex-end;
      margin-bottom:6px; transform:translateY(-18px);
    }
    .tab{
      --h:44px;
      height:var(--h); min-width:56px; padding:0 12px; display:inline-flex; align-items:center; justify-content:center;
      border-radius:10px 10px 0 0; background:linear-gradient(180deg,#ffffff,#fbfdff); border:1px solid rgba(15,23,42,0.06);
      box-shadow:0 4px 10px rgba(2,6,23,0.04); cursor:pointer; font-weight:600; color:var(--muted);
      transform:translateY(6px); transition:all 220ms cubic-bezier(.2,.9,.2,1);
      user-select:none; position:relative;
    }
    .tab:hover{ transform:translateY(0); }
    .tab[aria-selected="true"]{
      background: linear-gradient(180deg,var(--accent), #437be2); color:white; transform:translateY(-6px); box-shadow:0 10px 30px rgba(45,108,223,0.18);
    }

    /* Área de contenido dentro de la tarjeta */
    .content{
      padding:22px 22px 28px 22px; background:linear-gradient(180deg,#ffffff,#fbfdff); border-top-left-radius:6px; border-top-right-radius:6px;
      min-height:260px; position:relative; overflow:hidden;
    }

    /* Paneles (cada tab muestra un panel). Usamos transición de opacidad para desaparecer/entrar con suavidad */
    .panel{
      position:absolute; inset:22px 22px 28px 22px; padding:8px 12px; border-radius:8px; background:transparent; transition:opacity 260ms ease, transform 260ms ease; opacity:0; pointer-events:none; transform:translateY(8px);
    }
    .panel[aria-hidden="false"]{ opacity:1; pointer-events:auto; transform:translateY(0); }

    /* Tabla simple y responsiva */
    table{ width:100%; border-collapse:collapse; background:rgba(255,255,255,0.9); border-radius:8px; overflow:hidden; box-shadow:0 4px 14px rgba(2,6,23,0.03); }
    th, td{ padding:10px 12px; text-align:left; font-size:14px; border-bottom:1px solid rgba(15,23,42,0.06); }
    th{ background:linear-gradient(180deg,#fbfdff,#f7f9ff); font-weight:700; color:#05204a }
    tr:last-child td{ border-bottom:0 }

    /* Indicador responsivo para pantallas pequeñas: convertir pestañas en scroll horizontal */
    @media (max-width:600px){
      .tabs{ overflow:auto; padding-bottom:6px }
      .tab{ min-width:48px }
      .card{ padding-top:28px }
      .panel{ inset:18px }
    }

    /* Pequeño estilo de numeración roman en cada celda para ejemplo */
    .muted{ color:var(--muted); font-weight:600 }

    .optativas {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 20px;
  align-items: start;
}

.optativas h4 {
  grid-column: 1 / -1;
  margin-bottom: 10px;
}

.optativas .columna-1,
.optativas .columna-2,
.optativas .columna-3 {
  list-style: disc inside;
  padding-left: 12px;
  margin: 0;
  align-self: start;
}

@media (max-width: 768px) {
  .optativas {
    grid-template-columns: 1fr;
  }
}
