utn-cli 2.1.53 → 2.1.55

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (40) hide show
  1. package/package.json +1 -1
  2. package/templates/backend/package.json +3 -3
  3. package/templates/backend/rutas/DatosMiscelaneos.js +50 -0
  4. package/templates/backend/rutas/misc.js +177 -5
  5. package/templates/backend/rutas/rutas.js +2 -0
  6. package/templates/backend/servicios/Nucleo/DatosMiscelaneos.js +36 -0
  7. package/templates/backend/servicios/Nucleo/Miscelaneas.js +192 -25
  8. package/templates/frontend/Dockerfile +1 -0
  9. package/templates/frontend/src/app/Componentes/Nucleo/boton-ayuda/boton-ayuda.component.css +7 -0
  10. package/templates/frontend/src/app/Componentes/Nucleo/boton-ayuda/boton-ayuda.component.html +28 -0
  11. package/templates/frontend/src/app/Componentes/Nucleo/boton-ayuda/boton-ayuda.component.ts +78 -0
  12. package/templates/frontend/src/app/Componentes/Nucleo/estadisticas-del-modulo/estadisticas-del-modulo.component.html +43 -8
  13. package/templates/frontend/src/app/Componentes/Nucleo/estadisticas-del-modulo/estadisticas-del-modulo.component.ts +5 -4
  14. package/templates/frontend/src/app/Componentes/Nucleo/gestion-actividad/gestion-actividad.component.ts +1 -0
  15. package/templates/frontend/src/app/Componentes/Nucleo/mensaje-confirmacion/mensaje-confirmacion.component.css +4 -2
  16. package/templates/frontend/src/app/Componentes/Nucleo/mensaje-institucional/mensaje-institucional.component.html +3 -3
  17. package/templates/frontend/src/app/Componentes/Nucleo/mensaje-institucional/mensaje-institucional.component.ts +1 -1
  18. package/templates/frontend/src/app/Componentes/Nucleo/subir-archivo/subir-archivo.component.ts +1 -1
  19. package/templates/frontend/src/app/Paginas/Nucleo/accesibilidad/accesibilidad.component.css +25 -0
  20. package/templates/frontend/src/app/Paginas/Nucleo/accesibilidad/accesibilidad.component.html +2 -0
  21. package/templates/frontend/src/app/Paginas/Nucleo/accesibilidad/accesibilidad.component.ts +31 -2
  22. package/templates/frontend/src/app/Paginas/Nucleo/acercade/acercade.component.css +67 -18
  23. package/templates/frontend/src/app/Paginas/Nucleo/acercade/acercade.component.html +56 -46
  24. package/templates/frontend/src/app/Paginas/Nucleo/acercade/acercade.component.ts +21 -1
  25. package/templates/frontend/src/app/Paginas/Nucleo/conozcanos/conozcanos.component.css +190 -375
  26. package/templates/frontend/src/app/Paginas/Nucleo/conozcanos/conozcanos.component.html +92 -91
  27. package/templates/frontend/src/app/Paginas/Nucleo/conozcanos/conozcanos.component.ts +19 -2
  28. package/templates/frontend/src/app/Paginas/Nucleo/contenedor-componentes/contenedor-componentes.component.ts +26 -1
  29. package/templates/frontend/src/app/Paginas/Nucleo/declaracion-ia/declaracion-ia.component.css +25 -0
  30. package/templates/frontend/src/app/Paginas/Nucleo/declaracion-ia/declaracion-ia.component.html +2 -0
  31. package/templates/frontend/src/app/Paginas/Nucleo/declaracion-ia/declaracion-ia.component.ts +33 -3
  32. package/templates/frontend/src/app/Paginas/Nucleo/politicas/politicas.component.css +69 -15
  33. package/templates/frontend/src/app/Paginas/Nucleo/politicas/politicas.component.html +129 -107
  34. package/templates/frontend/src/app/Paginas/Nucleo/politicas/politicas.component.ts +51 -9
  35. package/templates/frontend/src/app/Paginas/Nucleo/preguntasFrecuentes/preguntasFrecuentes.component.css +68 -15
  36. package/templates/frontend/src/app/Paginas/Nucleo/preguntasFrecuentes/preguntasFrecuentes.component.html +161 -88
  37. package/templates/frontend/src/app/Paginas/Nucleo/preguntasFrecuentes/preguntasFrecuentes.component.ts +63 -10
  38. package/templates/frontend/src/app/Paginas/Nucleo/sabiasque/sabiasque.component.css +100 -24
  39. package/templates/frontend/src/app/Paginas/Nucleo/sabiasque/sabiasque.component.html +269 -339
  40. package/templates/frontend/src/app/Paginas/Nucleo/sabiasque/sabiasque.component.ts +94 -6
@@ -1,120 +1,142 @@
1
+ <div class="ia-layout">
2
+ <main class="ia-main">
1
3
 
2
- <div class="subtitle">
3
- <p>Acuerdo de seguridad, privacidad y condiciones de uso</p>
4
- </div>
5
- <div class="politicas-container">
4
+ <header class="ia-encabezado">
5
+ <mat-icon class="ia-icono-header">gavel</mat-icon>
6
+ <div>
7
+ <h1>Acuerdo de seguridad, privacidad y condiciones de uso</h1>
8
+ </div>
9
+ </header>
6
10
 
7
- <div class="description">
8
- <p>La Universidad Técnica Nacional (UTN), institución pública de educación superior dedicada a la docencia, la
9
- investigación y la acción social, pone a disposición de la comunidad universitaria la plataforma digital SIGU
10
- (Sistema Integrado de Gestión Universitaria).
11
- </p>
12
- <p>El presente acuerdo establece los términos y condiciones de seguridad, privacidad y acceso aplicables a todos los
13
- usuarios del sistema.</p>
14
- </div>
11
+ <section class="ia-seccion">
12
+ <div class="description">
13
+ <p>La Universidad Técnica Nacional (UTN), institución pública de educación superior dedicada a la docencia, la
14
+ investigación y la acción social, pone a disposición de la comunidad universitaria la plataforma digital SIGU
15
+ (Sistema Integrado de Gestión Universitaria).
16
+ </p>
17
+ <p>El presente acuerdo establece los términos y condiciones de seguridad, privacidad y acceso aplicables a todos los
18
+ usuarios del sistema.</p>
19
+ </div>
20
+ </section>
15
21
 
16
- <!-- Árbol-->
17
- <div class="tree-container">
22
+ <section class="ia-seccion">
23
+ <div class="tree-container">
18
24
 
19
- <!-- Item 1 -->
20
- <div class="tree-item" [class.expanded-item]="expandedItems['item1']">
21
- <div class="tree-header" (click)="toggleItem('item1')">
22
- <span class="tree-icon">{{ expandedItems['item1'] ? '▼' : '▶' }}</span>
23
- <span class="tree-title">1. Usuario</span>
24
- </div>
25
- <div class="tree-content" [class.expanded]="expandedItems['item1']">
26
- <p>1.1. Este Acuerdo regula la relación entre la Universidad Técnica Nacional y los usuarios que hacen uso de la
27
- plataforma SIGU, incluyendo estudiantes, docentes, personal administrativo, aspirantes, clientes y público en
28
- general que utilicen los servicios disponibles dentro del sistema.</p>
25
+ <div class="tree-item" *ngFor="let pregunta of preguntas" [class.expanded-item]="expandedItems[pregunta.id]">
29
26
 
30
- <p>1.2. El acceso a los módulos del SIGU está estrictamente limitado según el perfil del usuario autenticado,
31
- garantizando que visualice y utilice únicamente la información y servicios correspondientes a su gestión o
32
- autorización dentro de la plataforma. </p>
27
+ <div class="tree-header" (click)="toggleItem(pregunta.id)">
28
+ <span class="tree-icon">
29
+ {{ expandedItems[pregunta.id] ? '▼' : '▶' }}
30
+ </span>
31
+ <span class="tree-title">
32
+ {{ obtenerNumeroItem(pregunta.id) }}. {{ pregunta.titulo }}
33
+ </span>
34
+ </div>
33
35
 
34
- <p>1.3. Los usuarios deberán hacer un uso responsable, ético y seguro de la plataforma SIGU, conforme al
35
- Reglamento de Seguridad de la Información de TI de la UTN y demás políticas aplicables en materia de seguridad
36
- informática y uso de recursos tecnológicos.
37
- </p>
36
+ <!-- ITEM 1 -->
37
+ <div *ngIf="pregunta.id === 'item1'" class="tree-content" [class.expanded]="expandedItems['item1']">
38
+ <p>
39
+ {{ obtenerNumeroItem('item1') }}.1.
40
+ Este acuerdo regula la relación entre la Universidad Técnica Nacional y los usuarios que hacen uso de la
41
+ plataforma SIGU, incluyendo estudiantes, docentes, personal administrativo, aspirantes, clientes y público en
42
+ general que utilicen los servicios disponibles dentro del sistema.
43
+ </p>
44
+ <p>
45
+ {{ obtenerNumeroItem('item1') }}.2.
46
+ El acceso a los módulos del SIGU está estrictamente limitado según el perfil del usuario autenticado,
47
+ garantizando que visualice y utilice únicamente la información y servicios correspondientes a su gestión o
48
+ autorización dentro de la plataforma.
49
+ </p>
50
+ <p>
51
+ {{ obtenerNumeroItem('item1') }}.3.
52
+ Los usuarios deberán hacer un uso responsable, ético y seguro de la plataforma SIGU, conforme al
53
+ Reglamento de Seguridad de la Información de TI de la UTN y demás políticas aplicables en materia de seguridad
54
+ informática y uso de recursos tecnológicos.
55
+ </p>
56
+ <p>
57
+ {{ obtenerNumeroItem('item1') }}.4.
58
+ Asimismo, cada usuario será responsable de resguardar la confidencialidad de sus credenciales de acceso
59
+ y de utilizar la información disponible en el sistema únicamente para fines académicos y administrativos
60
+ autorizados.
61
+ </p>
62
+ </div>
38
63
 
39
- <p>1.4. Asimismo, cada usuario será responsable de resguardar la confidencialidad de sus credenciales de acceso
40
- y de utilizar la información disponible en el sistema únicamente para fines académicos y administrativos
41
- autorizados. </p>
42
- </div>
43
- <div class="line"></div>
44
- </div>
64
+ <!-- ITEM 2 -->
65
+ <div *ngIf="pregunta.id === 'item2'" class="tree-content" [class.expanded]="expandedItems['item2']">
66
+ <p>
67
+ {{ obtenerNumeroItem('item2') }}.1
68
+ El cumplimiento de la ley de protección de la persona frente al tratamiento de sus datos personales (N °
69
+ 8968) y su reglamento, la UTN declara que:
70
+ </p>
71
+ <ul>
72
+ <li>La información recolectada a través de formularios en el SIGU (admisión, solicitud de becas, planes de
73
+ estudio, etc.) será utilizada exclusivamente para la finalidad establecida en cada formulario y para la
74
+ gestión interna universitaria.</li>
75
+ <li>Al completar los formularios, el usuario otorga su consentimiento para que los datos sean suministrados y
76
+ procesados por la UTN.</li>
77
+ <li>En ningún caso la información personal será distribuida, vendida o cedida a terceros.</li>
78
+ </ul>
79
+ </div>
45
80
 
46
- <!-- Item 2-->
47
- <div class="tree-item" [class.expanded-item]="expandedItems['item2']">
48
- <div class="tree-header" (click)="toggleItem('item2')">
49
- <span class="tree-icon">{{ expandedItems['item2'] ? '▼' : '▶' }}</span>
50
- <span class="tree-title">2. Protección de datos</span>
51
- </div>
52
- <div class="tree-content" [class.expanded]="expandedItems['item2']">
53
- <p>2.1 El cumplimiento de la ley de protección de la persona frente al tratamiento de sus datos personales (N °
54
- 8968) y su reglamento, la UTN declara que:</p>
55
- <ul>
56
- <li>La información recolectada a través de formularios en el SIGU (admisión, solicitud de becas, planes de
57
- estudio, etc.) será utilizada exclusivamente para la finalidad establecida en cada formulario y para la
58
- gestión interna universitaria.</li>
59
- <li>Al completar los formularios, el usuario otorga su consentimiento para que los datos sean suministrados y
60
- procesados por la UTN.</li>
61
- <li>En ningún caso la información personal será distribuida, vendida o cedida a terceros.</li>
62
- </ul>
63
- </div>
64
- <div class="line"></div>
65
- </div>
81
+ <!-- ITEM 3 -->
82
+ <div *ngIf="pregunta.id === 'item3'" class="tree-content" [class.expanded]="expandedItems['item3']">
83
+ <p>
84
+ {{ obtenerNumeroItem('item3') }}.1
85
+ Las solicitudes de información sensible a través del sitio web son completamente privadas y solo visibles
86
+ para el usuario titular y el personal administrativo autorizado para la gestión de trámites. Cualquier otro
87
+ dato que el usuario proporcione será utilizado en apego a lo establecido por la legislación costarricense en
88
+ materia de protección de datos personales, y no será divulgado sin el consentimiento del titular.
89
+ </p>
90
+ <p>
91
+ {{ obtenerNumeroItem('item3') }}.2
92
+ Asimismo, el sitio web SIGU utiliza cookies para almacenar información de sesión y preferencias de
93
+ accesibilidad del usuario. Estos datos se utilizan únicamente con el fin de mejorar la experiencia del usuario
94
+ mientras navega por el sitio web institucional.
95
+ </p>
96
+ <p>
97
+ {{ obtenerNumeroItem('item3') }}.3
98
+ El contenido almacenado en las cookies no almacena datos sensibles y no se distribuyen a terceros.
99
+ </p>
100
+ </div>
66
101
 
67
- <!-- Item 3-->
68
- <div class="tree-item" [class.expanded-item]="expandedItems['item3']">
69
- <div class="tree-header" (click)="toggleItem('item3')">
70
- <span class="tree-icon">{{ expandedItems['item3'] ? '▼' : '▶' }}</span>
71
- <span class="tree-title">3. Privacidad</span>
72
- </div>
73
- <div class="tree-content" [class.expanded]="expandedItems['item3']">
74
- <p>3.1 Las solicitudes de información sensible a través del sitio web son completamente privadas y solo visibles
75
- para el usuario titular y el personal administrativo autorizado para la gestión de trámites. Cualquier otro
76
- dato que el usuario proporcione será utilizado en apego a lo establecido por la legislación costarricense en
77
- materia de protección de datos personales, y no será divulgado sin el consentimiento del titular.
78
- </p>
79
- <p>3.2 Asimismo, el sitio web SIGU utiliza cookies para almacenar información de sesión y preferencias de
80
- accesibilidad del usuario. Estos datos se utilizan únicamente con el fin de mejorar la experiencia del usuario
81
- mientras navega por el sitio web institucional.
82
- </p>
83
- <p>3.3 El contenido almacenado en las cookies no almacena datos sensibles y no se distribuyen a terceros.
84
- </p>
85
- </div>
86
- <div class="line"></div>
87
- </div>
102
+ <!-- ITEM 4 -->
103
+ <div *ngIf="pregunta.id === 'item4'" class="tree-content" [class.expanded]="expandedItems['item4']">
104
+ <p>
105
+ {{ obtenerNumeroItem('item4') }}.1
106
+ La UTN se reserva el derecho de actualizar y mejorar la plataforma SIGU, su estructura, funcionalidades,
107
+ contenidos y el presente Acuerdo de Seguridad, cuando lo considere necesario para fortalecer la seguridad, la
108
+ accesibilidad y el correcto funcionamiento del sistema. Las modificaciones entrarán en vigencia a partir de su
109
+ publicación dentro de la plataforma, sin necesidad de previo aviso individual, aunque se recomienda al usuario
110
+ revisar la última actualización.
111
+ </p>
112
+ <p>
113
+ {{ obtenerNumeroItem('item4') }}.2
114
+ La dirección de gestión de tecnologías de información de la UTN trabaja para garantizar la accesibilidad
115
+ universal del SIGU, como:
116
+ </p>
117
+ <ul>
118
+ <li>Se utilizan herramientas automáticas y pruebas de intervención humana para evaluar el desempeño en
119
+ términos de accesibilidad visual y de navegación.</li>
120
+ <li>Durante las actualizaciones o pruebas de funcionalidades, los datos personales de los usuarios no serán
121
+ utilizados en entornos de prueba. Se utilizan datos ficticios para salvaguardar la privacidad.
122
+ </li>
123
+ </ul>
124
+ <p>
125
+ {{ obtenerNumeroItem('item4') }}.3
126
+ En caso de que los usuarios presenten alguna dificultad de accesibilidad al sitio web y requieran
127
+ asistencia, pueden contactarse con el Departamento de Soporte Técnico de la UTN, por medio del correo
128
+ electrónico soporte@utn.ac.cr
129
+ </p>
130
+ </div>
131
+
132
+ <div class="line"></div>
133
+
134
+ </div>
88
135
 
89
- <!-- Item 4-->
90
- <div class="tree-item" [class.expanded-item]="expandedItems['item4']">
91
- <div class="tree-header" (click)="toggleItem('item4')">
92
- <span class="tree-icon">{{ expandedItems['item4'] ? '▼' : '▶' }}</span>
93
- <span class="tree-title">4. Accesibilidad y modificaciones</span>
94
- </div>
95
- <div class="tree-content" [class.expanded]="expandedItems['item4']">
96
- <p>4.1 La UTN se reserva el derecho de actualizar y mejorar la plataforma SIGU, su estructura, funcionalidades,
97
- contenidos y el presente Acuerdo de Seguridad, cuando lo considere necesario para fortalecer la seguridad, la
98
- accesibilidad y el correcto funcionamiento del sistema. Las modificaciones entrarán en vigencia a partir de su
99
- publicación dentro de la plataforma, sin necesidad de previo aviso individual, aunque se recomienda al usuario
100
- revisar la última actualización.</p>
101
- <p>4.2 La dirección de gestión de tecnologías de información de la UTN trabaja para garantizar la accesibilidad
102
- universal del SIGU, como:
103
- </p>
104
- <ul>
105
- <li>Se utilizan herramientas automáticas y pruebas de intervención humana para evaluar el desempeño en
106
- términos de accesibilidad visual y de navegación.</li>
107
- <li>Durante las actualizaciones o pruebas de funcionalidades, los datos personales de los usuarios no serán
108
- utilizados en entornos de prueba. Se utilizan datos ficticios para salvaguardar la privacidad.
109
- </li>
110
- </ul>
111
- <p>4.3 En caso de que los usuarios presenten alguna dificultad de accesibilidad al sitio web y requieran
112
- asistencia, pueden contactarse con el Departamento de Soporte Técnico de la UTN, por medio del correo
113
- electrónico soporte@utn.ac.cr</p>
114
136
  </div>
115
- <div class="line"></div>
116
- </div>
137
+ </section>
117
138
 
118
- </div>
139
+ <button *ngIf="mostrarBotonInicio" class="btn-volver-arriba" (click)="irAlInicio()" title="Volver arriba">↑ Volver arriba</button>
119
140
 
120
- </div>
141
+ </main>
142
+ </div>
@@ -1,5 +1,6 @@
1
1
  import { Component, OnInit } from '@angular/core';
2
2
  import { MatIconModule } from '@angular/material/icon';
3
+ import { CommonModule } from '@angular/common';
3
4
  import { DatosGlobalesService } from '../../../datos-globales.service';
4
5
  import { HttpClient } from '@angular/common/http';
5
6
  import { takeUntil } from 'rxjs/operators';
@@ -7,17 +8,41 @@ import { Subject } from 'rxjs';
7
8
  @Component({
8
9
  selector: 'app-politicas',
9
10
  standalone: true,
10
- imports: [MatIconModule],
11
+ imports: [CommonModule, MatIconModule],
11
12
  templateUrl: './politicas.component.html',
12
13
  styleUrl: './politicas.component.css'
13
14
  })
14
15
  export class PoliticasComponent implements OnInit {
15
-
16
+
16
17
  private _destroy$ = new Subject<void>();
18
+ mostrarBotonInicio = false;
19
+ private _scrollListener?: EventListener;
20
+
17
21
  constructor(private http: HttpClient, private datosGlobalesService: DatosGlobalesService) { }
18
- ngOnInit(): void {
19
- this.http.get(`${this.datosGlobalesService.ObtenerURL()}misc/VistaDePoliticas`).pipe(takeUntil(this._destroy$)).subscribe({ error: () => { } });
20
- }
22
+ ngOnInit(): void {
23
+ this.http.get(`${this.datosGlobalesService.ObtenerURL()}misc/VistaDePoliticas`).pipe(takeUntil(this._destroy$)).subscribe({ error: () => { } });
24
+
25
+ this.http.get<any>(`${this.datosGlobalesService.ObtenerURL()}misc/obtenerRankingDeItemsDePoliticas`).pipe(takeUntil(this._destroy$)).subscribe({
26
+ next: (respuesta) => {
27
+ const ranking = respuesta.body ?? {};
28
+ this.preguntas.sort(
29
+ (a, b) =>
30
+ (ranking[b.id] ?? 0) - (ranking[a.id] ?? 0));
31
+ }
32
+ });
33
+ setTimeout(() => {
34
+ const c = document.querySelector('.zona-scrollable');
35
+ if (c) {
36
+ this._scrollListener = () => { this.mostrarBotonInicio = (c as HTMLElement).scrollTop > 200; };
37
+ c.addEventListener('scroll', this._scrollListener);
38
+ }
39
+ }, 0);
40
+ }
41
+
42
+ ngOnDestroy(): void {
43
+ this._destroy$.next(); this._destroy$.complete();
44
+ if (this._scrollListener) { document.querySelector('.zona-scrollable')?.removeEventListener('scroll', this._scrollListener); }
45
+ }
21
46
  // items expandidos
22
47
  expandedItems: { [key: string]: boolean } = {
23
48
  item1: false,
@@ -25,9 +50,26 @@ export class PoliticasComponent implements OnInit {
25
50
  item3: false,
26
51
  item4: false,
27
52
  };
28
-
53
+
29
54
  toggleItem(itemId: string) {
30
- this.expandedItems[itemId] = !this.expandedItems[itemId];
55
+ const estabaAbierto = this.expandedItems[itemId];
56
+ this.expandedItems[itemId] = !estabaAbierto;
57
+ if (!estabaAbierto) { this.http.post(`${this.datosGlobalesService.ObtenerURL()}misc/registrarVistaDeItemsDePoliticas`, { itemId }).subscribe({ error: (error) => console.error(error) }); }
58
+ }
59
+
60
+ preguntas = [
61
+ { id: 'item1', titulo: 'Usuario' },
62
+ { id: 'item2', titulo: 'Protección de datos' },
63
+ { id: 'item3', titulo: 'Privacidad' },
64
+ { id: 'item4', titulo: 'Accesibilidad y modificaciones' }
65
+ ];
66
+
67
+ obtenerNumeroItem(itemId: string): number {
68
+ return this.preguntas.findIndex(x => x.id === itemId) + 1;
69
+ }
70
+ irAlInicio(): void {
71
+ const contenedor = document.querySelector('.zona-scrollable');
72
+ if (contenedor) { contenedor.scrollTo({ top: 0, behavior: 'smooth' }); this.mostrarBotonInicio = false; }
73
+ else { window.scrollTo({ top: 0, behavior: 'smooth' }); }
31
74
  }
32
-
33
- }
75
+ }
@@ -1,24 +1,53 @@
1
- .politicas-container {
2
- max-width: 1000px;
3
- padding-bottom: 20px;
4
- font-family: 'Roboto', sans-serif;
5
- background-color: white;
6
- text-align: left;
1
+ .ia-layout {
2
+ max-width: 820px;
7
3
  margin: 0 auto;
4
+ padding: 24px 16px;
5
+ font-family: 'Roboto', sans-serif;
6
+ }
7
+
8
+ .ia-main {
9
+ display: flex;
10
+ flex-direction: column;
11
+ gap: 28px;
8
12
  }
9
13
 
10
- .subtitle {
11
- background-color: #0b4794;
12
- font-size: 25px;
14
+ .ia-encabezado {
15
+ display: flex;
16
+ align-items: center;
17
+ gap: 14px;
18
+ padding: 20px 24px;
19
+ background: linear-gradient(90deg, rgba(1, 33, 105, 1) 0%, rgba(63, 97, 171, 1) 100%);
13
20
  color: white;
14
- padding: 18px;
15
- margin: 20px 0;
16
- text-align: center;
21
+ border-radius: 12px;
22
+ }
23
+
24
+ .ia-icono-header {
25
+ font-size: 40px !important;
26
+ width: 40px !important;
27
+ height: 40px !important;
28
+ flex-shrink: 0;
29
+ opacity: 0.9;
30
+ }
31
+
32
+ .ia-encabezado h1 {
33
+ margin: 0;
34
+ font-size: 22px;
35
+ font-weight: 700;
36
+ line-height: 1.2;
17
37
  }
18
- .subtitle p {
19
- margin: 5px 0;
38
+
39
+ .ia-seccion {
40
+ background: white;
41
+ border: 1px solid #d0daea;
42
+ border-radius: 10px;
43
+ padding: 20px 24px;
20
44
  }
21
45
 
46
+ .ia-seccion .tree-container {
47
+ padding-left: 0;
48
+ padding-right: 0;
49
+ margin-top: 0;
50
+ }
22
51
 
23
52
  @media (max-width: 768px) {
24
53
  .description {
@@ -159,4 +188,28 @@
159
188
  .tree-content li{
160
189
  font-size: 14px;
161
190
  }
162
- }
191
+ }
192
+
193
+ /* Botón volver arriba */
194
+ .btn-volver-arriba {
195
+ display: none;
196
+ }
197
+
198
+ @media (max-width: 768px) {
199
+ .btn-volver-arriba {
200
+ display: flex;
201
+ align-items: center;
202
+ justify-content: center;
203
+ margin: 2rem auto 1rem;
204
+ padding: 0.6rem 1.4rem;
205
+ background: linear-gradient(90deg, rgba(1, 33, 105, 1) 0%, rgba(63, 97, 171, 1) 100%);
206
+ color: white;
207
+ border: none;
208
+ border-radius: 24px;
209
+ font-family: 'Roboto', sans-serif;
210
+ font-size: 0.9rem;
211
+ font-weight: 500;
212
+ cursor: pointer;
213
+ box-shadow: 0 2px 8px rgba(0, 0, 0, 0.18);
214
+ }
215
+ }