@charset "UTF-8";
:root {
  --main-color:       #bed600;
  --main-color-rgb:   190,214,0; }

/*!
 * Ruta formativa Duoc UC
 * Autor: Bloom User Experience <basilio@bloom-ux.com>
 * http://www.bloom-ux.com
 *
 * Bootstrap 4.1, Sass, Gulp, jQuery
 *
*/
:root {
  --blue: #005d9c;
  --indigo: #6610f2;
  --purple: #6f42c1;
  --pink: #e83e8c;
  --red: #dc3545;
  --orange: #fd7e14;
  --yellow: #ffc107;
  --green: #28a745;
  --teal: #20c997;
  --cyan: #17a2b8;
  --white: #fff;
  --gray: #6c757d;
  --gray-dark: #343a40;
  --primary: #2b2b2b;
  --secondary: #6c757d;
  --success: #28a745;
  --info: #17a2b8;
  --warning: #ffc107;
  --danger: #dc3545;
  --light: #fafafa;
  --dark: #343a40;
  --breakpoint-xs: 0;
  --breakpoint-sm: 576px;
  --breakpoint-md: 768px;
  --breakpoint-lg: 992px;
  --breakpoint-xl: 1200px;
  --font-family-sans-serif: "Lato", sans-serif;
  --font-family-monospace: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; }

*,
*::before,
*::after {
  box-sizing: border-box; }

html {
  font-family: sans-serif;
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0); }

article, aside, figcaption, figure, footer, header, hgroup, main, nav, section {
  display: block; }

body {
  margin: 0;
  font-family: "Lato", sans-serif;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: #000;
  text-align: left;
  background-color: #fff; }

[tabindex="-1"]:focus:not(:focus-visible) {
  outline: 0 !important; }

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible; }

h1, h2, h3, h4, h5, h6 {
  margin-top: 0;
  margin-bottom: 0.5rem; }

p {
  margin-top: 0;
  margin-bottom: 1rem; }

abbr[title],
abbr[data-original-title] {
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
  cursor: help;
  border-bottom: 0;
  text-decoration-skip-ink: none; }

address {
  margin-bottom: 1rem;
  font-style: normal;
  line-height: inherit; }

ol,
ul,
dl {
  margin-top: 0;
  margin-bottom: 1rem; }

ol ol,
ul ul,
ol ul,
ul ol {
  margin-bottom: 0; }

dt {
  font-weight: 700; }

dd {
  margin-bottom: .5rem;
  margin-left: 0; }

blockquote {
  margin: 0 0 1rem; }

b,
strong {
  font-weight: bolder; }

small {
  font-size: 80%; }

sub,
sup {
  position: relative;
  font-size: 75%;
  line-height: 0;
  vertical-align: baseline; }

sub {
  bottom: -.25em; }

sup {
  top: -.5em; }

a {
  color: #2b2b2b;
  text-decoration: none;
  background-color: transparent; }
  a:hover {
    color: #050505;
    text-decoration: underline; }

a:not([href]):not([class]) {
  color: inherit;
  text-decoration: none; }
  a:not([href]):not([class]):hover {
    color: inherit;
    text-decoration: none; }

pre,
code,
kbd,
samp {
  font-family: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size: 1em; }

pre {
  margin-top: 0;
  margin-bottom: 1rem;
  overflow: auto;
  -ms-overflow-style: scrollbar; }

figure {
  margin: 0 0 1rem; }

img {
  vertical-align: middle;
  border-style: none; }

svg {
  overflow: hidden;
  vertical-align: middle; }

table {
  border-collapse: collapse; }

caption {
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
  color: #6c757d;
  text-align: left;
  caption-side: bottom; }

th {
  text-align: inherit;
  text-align: -webkit-match-parent; }

label {
  display: inline-block;
  margin-bottom: 0.5rem; }

button {
  border-radius: 0; }

button:focus {
  outline: 1px dotted;
  outline: 5px auto -webkit-focus-ring-color; }

input,
button,
select,
optgroup,
textarea {
  margin: 0;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit; }

button,
input {
  overflow: visible; }

button,
select {
  text-transform: none; }

[role="button"] {
  cursor: pointer; }

select {
  word-wrap: normal; }

button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button; }

button:not(:disabled),
[type="button"]:not(:disabled),
[type="reset"]:not(:disabled),
[type="submit"]:not(:disabled) {
  cursor: pointer; }

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  padding: 0;
  border-style: none; }

input[type="radio"],
input[type="checkbox"] {
  box-sizing: border-box;
  padding: 0; }

textarea {
  overflow: auto;
  resize: vertical; }

fieldset {
  min-width: 0;
  padding: 0;
  margin: 0;
  border: 0; }

legend {
  display: block;
  width: 100%;
  max-width: 100%;
  padding: 0;
  margin-bottom: .5rem;
  font-size: 1.5rem;
  line-height: inherit;
  color: inherit;
  white-space: normal; }

progress {
  vertical-align: baseline; }

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto; }

[type="search"] {
  outline-offset: -2px;
  -webkit-appearance: none; }

[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; }

::-webkit-file-upload-button {
  font: inherit;
  -webkit-appearance: button; }

output {
  display: inline-block; }

summary {
  display: list-item;
  cursor: pointer; }

template {
  display: none; }

[hidden] {
  display: none !important; }

h1, h2, h3, h4, h5, h6,
.h1,
.subject-single__name, .h2, .h3, .h4, .h5, .h6 {
  margin-bottom: 0.5rem;
  font-family: "Lato", sans-serif;
  font-weight: 900;
  line-height: 1.2; }

h1,
.h1,
.subject-single__name {
  font-size: 2.5rem; }

h2, .h2 {
  font-size: 2rem; }

h3, .h3 {
  font-size: 1.75rem; }

h4, .h4 {
  font-size: 1.5rem; }

h5, .h5 {
  font-size: 1.25rem; }

h6, .h6 {
  font-size: 1rem; }

.lead {
  font-size: 1.25rem;
  font-weight: 300; }

.display-1 {
  font-size: 6rem;
  font-weight: 300;
  line-height: 1.2; }

.display-2 {
  font-size: 5.5rem;
  font-weight: 300;
  line-height: 1.2; }

.display-3 {
  font-size: 4.5rem;
  font-weight: 300;
  line-height: 1.2; }

.display-4 {
  font-size: 3.5rem;
  font-weight: 300;
  line-height: 1.2; }

hr {
  margin-top: 1rem;
  margin-bottom: 1rem;
  border: 0;
  border-top: 1px solid rgba(0, 0, 0, 0.1); }

small,
.small {
  font-size: 80%;
  font-weight: 400; }

mark,
.mark {
  padding: 0.2em;
  background-color: #fcf8e3; }

.list-unstyled, .list-summary, .list-numbers, .list-certificates, .list-skills, ul.list-skills-all, .list-subjects, .list-bullets, ul.list-pedagogical-strategies, .modal--rutas .modal-previous-version, .list-training-line, .program-section--single .program-section__anexos, .progress-indicator {
  padding-left: 0;
  list-style: none; }

.list-inline {
  padding-left: 0;
  list-style: none; }

.list-inline-item {
  display: inline-block; }
  .list-inline-item:not(:last-child) {
    margin-right: 0.5rem; }

.initialism {
  font-size: 90%;
  text-transform: uppercase; }

.blockquote {
  margin-bottom: 1rem;
  font-size: 1.25rem; }

.blockquote-footer {
  display: block;
  font-size: 80%;
  color: #6c757d; }
  .blockquote-footer::before {
    content: "\2014\00A0"; }

.table {
  width: 100%;
  margin-bottom: 1rem;
  color: #000; }
  .table th,
  .table td {
    padding: 0.75rem;
    vertical-align: top;
    border-top: 1px solid #d0d0d0; }
  .table thead th {
    vertical-align: bottom;
    border-bottom: 2px solid #d0d0d0; }
  .table tbody + tbody {
    border-top: 2px solid #d0d0d0; }

.table-sm th,
.table-sm td {
  padding: 0.3rem; }

.table-bordered {
  border: 1px solid #d0d0d0; }
  .table-bordered th,
  .table-bordered td {
    border: 1px solid #d0d0d0; }
  .table-bordered thead th,
  .table-bordered thead td {
    border-bottom-width: 2px; }

.table-borderless th,
.table-borderless td,
.table-borderless thead th,
.table-borderless tbody + tbody {
  border: 0; }

.table-striped tbody tr:nth-of-type(odd) {
  background-color: rgba(0, 0, 0, 0.05); }

.table-hover tbody tr:hover {
  color: #000;
  background-color: rgba(0, 0, 0, 0.075); }

.table-primary,
.table-primary > th,
.table-primary > td {
  background-color: #c4c4c4; }

.table-primary th,
.table-primary td,
.table-primary thead th,
.table-primary tbody + tbody {
  border-color: #919191; }

.table-hover .table-primary:hover {
  background-color: #b7b7b7; }
  .table-hover .table-primary:hover > td,
  .table-hover .table-primary:hover > th {
    background-color: #b7b7b7; }

.table-secondary,
.table-secondary > th,
.table-secondary > td {
  background-color: #d6d8db; }

.table-secondary th,
.table-secondary td,
.table-secondary thead th,
.table-secondary tbody + tbody {
  border-color: #b3b7bb; }

.table-hover .table-secondary:hover {
  background-color: #c8cbcf; }
  .table-hover .table-secondary:hover > td,
  .table-hover .table-secondary:hover > th {
    background-color: #c8cbcf; }

.table-success,
.table-success > th,
.table-success > td {
  background-color: #c3e6cb; }

.table-success th,
.table-success td,
.table-success thead th,
.table-success tbody + tbody {
  border-color: #8fd19e; }

.table-hover .table-success:hover {
  background-color: #b1dfbb; }
  .table-hover .table-success:hover > td,
  .table-hover .table-success:hover > th {
    background-color: #b1dfbb; }

.table-info,
.table-info > th,
.table-info > td {
  background-color: #bee5eb; }

.table-info th,
.table-info td,
.table-info thead th,
.table-info tbody + tbody {
  border-color: #86cfda; }

.table-hover .table-info:hover {
  background-color: #abdde5; }
  .table-hover .table-info:hover > td,
  .table-hover .table-info:hover > th {
    background-color: #abdde5; }

.table-warning,
.table-warning > th,
.table-warning > td {
  background-color: #ffeeba; }

.table-warning th,
.table-warning td,
.table-warning thead th,
.table-warning tbody + tbody {
  border-color: #ffdf7e; }

.table-hover .table-warning:hover {
  background-color: #ffe8a1; }
  .table-hover .table-warning:hover > td,
  .table-hover .table-warning:hover > th {
    background-color: #ffe8a1; }

.table-danger,
.table-danger > th,
.table-danger > td {
  background-color: #f5c6cb; }

.table-danger th,
.table-danger td,
.table-danger thead th,
.table-danger tbody + tbody {
  border-color: #ed969e; }

.table-hover .table-danger:hover {
  background-color: #f1b0b7; }
  .table-hover .table-danger:hover > td,
  .table-hover .table-danger:hover > th {
    background-color: #f1b0b7; }

.table-light,
.table-light > th,
.table-light > td {
  background-color: #fefefe; }

.table-light th,
.table-light td,
.table-light thead th,
.table-light tbody + tbody {
  border-color: #fcfcfc; }

.table-hover .table-light:hover {
  background-color: #f1f1f1; }
  .table-hover .table-light:hover > td,
  .table-hover .table-light:hover > th {
    background-color: #f1f1f1; }

.table-dark,
.table-dark > th,
.table-dark > td {
  background-color: #c6c8ca; }

.table-dark th,
.table-dark td,
.table-dark thead th,
.table-dark tbody + tbody {
  border-color: #95999c; }

.table-hover .table-dark:hover {
  background-color: #b9bbbe; }
  .table-hover .table-dark:hover > td,
  .table-hover .table-dark:hover > th {
    background-color: #b9bbbe; }

.table-active,
.table-active > th,
.table-active > td {
  background-color: rgba(0, 0, 0, 0.075); }

.table-hover .table-active:hover {
  background-color: rgba(0, 0, 0, 0.075); }
  .table-hover .table-active:hover > td,
  .table-hover .table-active:hover > th {
    background-color: rgba(0, 0, 0, 0.075); }

.table .thead-dark th {
  color: #fff;
  background-color: #343a40;
  border-color: #454d55; }

.table .thead-light th {
  color: #495057;
  background-color: #efefef;
  border-color: #d0d0d0; }

.table-dark {
  color: #fff;
  background-color: #343a40; }
  .table-dark th,
  .table-dark td,
  .table-dark thead th {
    border-color: #454d55; }
  .table-dark.table-bordered {
    border: 0; }
  .table-dark.table-striped tbody tr:nth-of-type(odd) {
    background-color: rgba(255, 255, 255, 0.05); }
  .table-dark.table-hover tbody tr:hover {
    color: #fff;
    background-color: rgba(255, 255, 255, 0.075); }

@media (max-width: 575.98px) {
  .table-responsive-sm {
    display: block;
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch; }
    .table-responsive-sm > .table-bordered {
      border: 0; } }

@media (max-width: 767.98px) {
  .table-responsive-md {
    display: block;
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch; }
    .table-responsive-md > .table-bordered {
      border: 0; } }

@media (max-width: 991.98px) {
  .table-responsive-lg {
    display: block;
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch; }
    .table-responsive-lg > .table-bordered {
      border: 0; } }

@media (max-width: 1199.98px) {
  .table-responsive-xl {
    display: block;
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch; }
    .table-responsive-xl > .table-bordered {
      border: 0; } }

.table-responsive {
  display: block;
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch; }
  .table-responsive > .table-bordered {
    border: 0; }

.btn {
  display: inline-block;
  font-weight: 400;
  color: #000;
  text-align: center;
  vertical-align: middle;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  background-color: transparent;
  border: 1px solid transparent;
  padding: 0.375rem 0.75rem;
  font-size: 1rem;
  line-height: 1.5;
  border-radius: 0;
  transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out; }
  @media (prefers-reduced-motion: reduce) {
    .btn {
      transition: none; } }
  .btn:hover {
    color: #000;
    text-decoration: none; }
  .btn:focus, .btn.focus {
    outline: 0;
    box-shadow: 0 0 0 0.2rem rgba(43, 43, 43, 0.25); }
  .btn.disabled, .btn:disabled {
    opacity: 0.65; }
  .btn:not(:disabled):not(.disabled) {
    cursor: pointer; }

a.btn.disabled,
fieldset:disabled a.btn {
  pointer-events: none; }

.btn-primary {
  color: #fff;
  background-color: #2b2b2b;
  border-color: #2b2b2b; }
  .btn-primary:hover {
    color: #fff;
    background-color: #181818;
    border-color: #121212; }
  .btn-primary:focus, .btn-primary.focus {
    color: #fff;
    background-color: #181818;
    border-color: #121212;
    box-shadow: 0 0 0 0.2rem rgba(75, 75, 75, 0.5); }
  .btn-primary.disabled, .btn-primary:disabled {
    color: #fff;
    background-color: #2b2b2b;
    border-color: #2b2b2b; }
  .btn-primary:not(:disabled):not(.disabled):active, .btn-primary:not(:disabled):not(.disabled).active,
  .show > .btn-primary.dropdown-toggle {
    color: #fff;
    background-color: #121212;
    border-color: #0b0b0b; }
    .btn-primary:not(:disabled):not(.disabled):active:focus, .btn-primary:not(:disabled):not(.disabled).active:focus,
    .show > .btn-primary.dropdown-toggle:focus {
      box-shadow: 0 0 0 0.2rem rgba(75, 75, 75, 0.5); }

.btn-secondary {
  color: #fff;
  background-color: #6c757d;
  border-color: #6c757d; }
  .btn-secondary:hover {
    color: #fff;
    background-color: #5a6268;
    border-color: #545b62; }
  .btn-secondary:focus, .btn-secondary.focus {
    color: #fff;
    background-color: #5a6268;
    border-color: #545b62;
    box-shadow: 0 0 0 0.2rem rgba(130, 138, 145, 0.5); }
  .btn-secondary.disabled, .btn-secondary:disabled {
    color: #fff;
    background-color: #6c757d;
    border-color: #6c757d; }
  .btn-secondary:not(:disabled):not(.disabled):active, .btn-secondary:not(:disabled):not(.disabled).active,
  .show > .btn-secondary.dropdown-toggle {
    color: #fff;
    background-color: #545b62;
    border-color: #4e555b; }
    .btn-secondary:not(:disabled):not(.disabled):active:focus, .btn-secondary:not(:disabled):not(.disabled).active:focus,
    .show > .btn-secondary.dropdown-toggle:focus {
      box-shadow: 0 0 0 0.2rem rgba(130, 138, 145, 0.5); }

.btn-success {
  color: #fff;
  background-color: #28a745;
  border-color: #28a745; }
  .btn-success:hover {
    color: #fff;
    background-color: #218838;
    border-color: #1e7e34; }
  .btn-success:focus, .btn-success.focus {
    color: #fff;
    background-color: #218838;
    border-color: #1e7e34;
    box-shadow: 0 0 0 0.2rem rgba(72, 180, 97, 0.5); }
  .btn-success.disabled, .btn-success:disabled {
    color: #fff;
    background-color: #28a745;
    border-color: #28a745; }
  .btn-success:not(:disabled):not(.disabled):active, .btn-success:not(:disabled):not(.disabled).active,
  .show > .btn-success.dropdown-toggle {
    color: #fff;
    background-color: #1e7e34;
    border-color: #1c7430; }
    .btn-success:not(:disabled):not(.disabled):active:focus, .btn-success:not(:disabled):not(.disabled).active:focus,
    .show > .btn-success.dropdown-toggle:focus {
      box-shadow: 0 0 0 0.2rem rgba(72, 180, 97, 0.5); }

.btn-info {
  color: #fff;
  background-color: #17a2b8;
  border-color: #17a2b8; }
  .btn-info:hover {
    color: #fff;
    background-color: #138496;
    border-color: #117a8b; }
  .btn-info:focus, .btn-info.focus {
    color: #fff;
    background-color: #138496;
    border-color: #117a8b;
    box-shadow: 0 0 0 0.2rem rgba(58, 176, 195, 0.5); }
  .btn-info.disabled, .btn-info:disabled {
    color: #fff;
    background-color: #17a2b8;
    border-color: #17a2b8; }
  .btn-info:not(:disabled):not(.disabled):active, .btn-info:not(:disabled):not(.disabled).active,
  .show > .btn-info.dropdown-toggle {
    color: #fff;
    background-color: #117a8b;
    border-color: #10707f; }
    .btn-info:not(:disabled):not(.disabled):active:focus, .btn-info:not(:disabled):not(.disabled).active:focus,
    .show > .btn-info.dropdown-toggle:focus {
      box-shadow: 0 0 0 0.2rem rgba(58, 176, 195, 0.5); }

.btn-warning {
  color: #2b2b2b;
  background-color: #ffc107;
  border-color: #ffc107; }
  .btn-warning:hover {
    color: #2b2b2b;
    background-color: #e0a800;
    border-color: #d39e00; }
  .btn-warning:focus, .btn-warning.focus {
    color: #2b2b2b;
    background-color: #e0a800;
    border-color: #d39e00;
    box-shadow: 0 0 0 0.2rem rgba(223, 171, 12, 0.5); }
  .btn-warning.disabled, .btn-warning:disabled {
    color: #2b2b2b;
    background-color: #ffc107;
    border-color: #ffc107; }
  .btn-warning:not(:disabled):not(.disabled):active, .btn-warning:not(:disabled):not(.disabled).active,
  .show > .btn-warning.dropdown-toggle {
    color: #2b2b2b;
    background-color: #d39e00;
    border-color: #c69500; }
    .btn-warning:not(:disabled):not(.disabled):active:focus, .btn-warning:not(:disabled):not(.disabled).active:focus,
    .show > .btn-warning.dropdown-toggle:focus {
      box-shadow: 0 0 0 0.2rem rgba(223, 171, 12, 0.5); }

.btn-danger {
  color: #fff;
  background-color: #dc3545;
  border-color: #dc3545; }
  .btn-danger:hover {
    color: #fff;
    background-color: #c82333;
    border-color: #bd2130; }
  .btn-danger:focus, .btn-danger.focus {
    color: #fff;
    background-color: #c82333;
    border-color: #bd2130;
    box-shadow: 0 0 0 0.2rem rgba(225, 83, 97, 0.5); }
  .btn-danger.disabled, .btn-danger:disabled {
    color: #fff;
    background-color: #dc3545;
    border-color: #dc3545; }
  .btn-danger:not(:disabled):not(.disabled):active, .btn-danger:not(:disabled):not(.disabled).active,
  .show > .btn-danger.dropdown-toggle {
    color: #fff;
    background-color: #bd2130;
    border-color: #b21f2d; }
    .btn-danger:not(:disabled):not(.disabled):active:focus, .btn-danger:not(:disabled):not(.disabled).active:focus,
    .show > .btn-danger.dropdown-toggle:focus {
      box-shadow: 0 0 0 0.2rem rgba(225, 83, 97, 0.5); }

.btn-light {
  color: #2b2b2b;
  background-color: #fafafa;
  border-color: #fafafa; }
  .btn-light:hover {
    color: #2b2b2b;
    background-color: #e7e7e7;
    border-color: #e1e1e1; }
  .btn-light:focus, .btn-light.focus {
    color: #2b2b2b;
    background-color: #e7e7e7;
    border-color: #e1e1e1;
    box-shadow: 0 0 0 0.2rem rgba(219, 219, 219, 0.5); }
  .btn-light.disabled, .btn-light:disabled {
    color: #2b2b2b;
    background-color: #fafafa;
    border-color: #fafafa; }
  .btn-light:not(:disabled):not(.disabled):active, .btn-light:not(:disabled):not(.disabled).active,
  .show > .btn-light.dropdown-toggle {
    color: #2b2b2b;
    background-color: #e1e1e1;
    border-color: #dadada; }
    .btn-light:not(:disabled):not(.disabled):active:focus, .btn-light:not(:disabled):not(.disabled).active:focus,
    .show > .btn-light.dropdown-toggle:focus {
      box-shadow: 0 0 0 0.2rem rgba(219, 219, 219, 0.5); }

.btn-dark {
  color: #fff;
  background-color: #343a40;
  border-color: #343a40; }
  .btn-dark:hover {
    color: #fff;
    background-color: #23272b;
    border-color: #1d2124; }
  .btn-dark:focus, .btn-dark.focus {
    color: #fff;
    background-color: #23272b;
    border-color: #1d2124;
    box-shadow: 0 0 0 0.2rem rgba(82, 88, 93, 0.5); }
  .btn-dark.disabled, .btn-dark:disabled {
    color: #fff;
    background-color: #343a40;
    border-color: #343a40; }
  .btn-dark:not(:disabled):not(.disabled):active, .btn-dark:not(:disabled):not(.disabled).active,
  .show > .btn-dark.dropdown-toggle {
    color: #fff;
    background-color: #1d2124;
    border-color: #171a1d; }
    .btn-dark:not(:disabled):not(.disabled):active:focus, .btn-dark:not(:disabled):not(.disabled).active:focus,
    .show > .btn-dark.dropdown-toggle:focus {
      box-shadow: 0 0 0 0.2rem rgba(82, 88, 93, 0.5); }

.btn-outline-primary {
  color: #2b2b2b;
  border-color: #2b2b2b; }
  .btn-outline-primary:hover {
    color: #fff;
    background-color: #2b2b2b;
    border-color: #2b2b2b; }
  .btn-outline-primary:focus, .btn-outline-primary.focus {
    box-shadow: 0 0 0 0.2rem rgba(43, 43, 43, 0.5); }
  .btn-outline-primary.disabled, .btn-outline-primary:disabled {
    color: #2b2b2b;
    background-color: transparent; }
  .btn-outline-primary:not(:disabled):not(.disabled):active, .btn-outline-primary:not(:disabled):not(.disabled).active,
  .show > .btn-outline-primary.dropdown-toggle {
    color: #fff;
    background-color: #2b2b2b;
    border-color: #2b2b2b; }
    .btn-outline-primary:not(:disabled):not(.disabled):active:focus, .btn-outline-primary:not(:disabled):not(.disabled).active:focus,
    .show > .btn-outline-primary.dropdown-toggle:focus {
      box-shadow: 0 0 0 0.2rem rgba(43, 43, 43, 0.5); }

.btn-outline-secondary {
  color: #6c757d;
  border-color: #6c757d; }
  .btn-outline-secondary:hover {
    color: #fff;
    background-color: #6c757d;
    border-color: #6c757d; }
  .btn-outline-secondary:focus, .btn-outline-secondary.focus {
    box-shadow: 0 0 0 0.2rem rgba(108, 117, 125, 0.5); }
  .btn-outline-secondary.disabled, .btn-outline-secondary:disabled {
    color: #6c757d;
    background-color: transparent; }
  .btn-outline-secondary:not(:disabled):not(.disabled):active, .btn-outline-secondary:not(:disabled):not(.disabled).active,
  .show > .btn-outline-secondary.dropdown-toggle {
    color: #fff;
    background-color: #6c757d;
    border-color: #6c757d; }
    .btn-outline-secondary:not(:disabled):not(.disabled):active:focus, .btn-outline-secondary:not(:disabled):not(.disabled).active:focus,
    .show > .btn-outline-secondary.dropdown-toggle:focus {
      box-shadow: 0 0 0 0.2rem rgba(108, 117, 125, 0.5); }

.btn-outline-success {
  color: #28a745;
  border-color: #28a745; }
  .btn-outline-success:hover {
    color: #fff;
    background-color: #28a745;
    border-color: #28a745; }
  .btn-outline-success:focus, .btn-outline-success.focus {
    box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.5); }
  .btn-outline-success.disabled, .btn-outline-success:disabled {
    color: #28a745;
    background-color: transparent; }
  .btn-outline-success:not(:disabled):not(.disabled):active, .btn-outline-success:not(:disabled):not(.disabled).active,
  .show > .btn-outline-success.dropdown-toggle {
    color: #fff;
    background-color: #28a745;
    border-color: #28a745; }
    .btn-outline-success:not(:disabled):not(.disabled):active:focus, .btn-outline-success:not(:disabled):not(.disabled).active:focus,
    .show > .btn-outline-success.dropdown-toggle:focus {
      box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.5); }

.btn-outline-info {
  color: #17a2b8;
  border-color: #17a2b8; }
  .btn-outline-info:hover {
    color: #fff;
    background-color: #17a2b8;
    border-color: #17a2b8; }
  .btn-outline-info:focus, .btn-outline-info.focus {
    box-shadow: 0 0 0 0.2rem rgba(23, 162, 184, 0.5); }
  .btn-outline-info.disabled, .btn-outline-info:disabled {
    color: #17a2b8;
    background-color: transparent; }
  .btn-outline-info:not(:disabled):not(.disabled):active, .btn-outline-info:not(:disabled):not(.disabled).active,
  .show > .btn-outline-info.dropdown-toggle {
    color: #fff;
    background-color: #17a2b8;
    border-color: #17a2b8; }
    .btn-outline-info:not(:disabled):not(.disabled):active:focus, .btn-outline-info:not(:disabled):not(.disabled).active:focus,
    .show > .btn-outline-info.dropdown-toggle:focus {
      box-shadow: 0 0 0 0.2rem rgba(23, 162, 184, 0.5); }

.btn-outline-warning {
  color: #ffc107;
  border-color: #ffc107; }
  .btn-outline-warning:hover {
    color: #2b2b2b;
    background-color: #ffc107;
    border-color: #ffc107; }
  .btn-outline-warning:focus, .btn-outline-warning.focus {
    box-shadow: 0 0 0 0.2rem rgba(255, 193, 7, 0.5); }
  .btn-outline-warning.disabled, .btn-outline-warning:disabled {
    color: #ffc107;
    background-color: transparent; }
  .btn-outline-warning:not(:disabled):not(.disabled):active, .btn-outline-warning:not(:disabled):not(.disabled).active,
  .show > .btn-outline-warning.dropdown-toggle {
    color: #2b2b2b;
    background-color: #ffc107;
    border-color: #ffc107; }
    .btn-outline-warning:not(:disabled):not(.disabled):active:focus, .btn-outline-warning:not(:disabled):not(.disabled).active:focus,
    .show > .btn-outline-warning.dropdown-toggle:focus {
      box-shadow: 0 0 0 0.2rem rgba(255, 193, 7, 0.5); }

.btn-outline-danger {
  color: #dc3545;
  border-color: #dc3545; }
  .btn-outline-danger:hover {
    color: #fff;
    background-color: #dc3545;
    border-color: #dc3545; }
  .btn-outline-danger:focus, .btn-outline-danger.focus {
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.5); }
  .btn-outline-danger.disabled, .btn-outline-danger:disabled {
    color: #dc3545;
    background-color: transparent; }
  .btn-outline-danger:not(:disabled):not(.disabled):active, .btn-outline-danger:not(:disabled):not(.disabled).active,
  .show > .btn-outline-danger.dropdown-toggle {
    color: #fff;
    background-color: #dc3545;
    border-color: #dc3545; }
    .btn-outline-danger:not(:disabled):not(.disabled):active:focus, .btn-outline-danger:not(:disabled):not(.disabled).active:focus,
    .show > .btn-outline-danger.dropdown-toggle:focus {
      box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.5); }

.btn-outline-light {
  color: #fafafa;
  border-color: #fafafa; }
  .btn-outline-light:hover {
    color: #2b2b2b;
    background-color: #fafafa;
    border-color: #fafafa; }
  .btn-outline-light:focus, .btn-outline-light.focus {
    box-shadow: 0 0 0 0.2rem rgba(250, 250, 250, 0.5); }
  .btn-outline-light.disabled, .btn-outline-light:disabled {
    color: #fafafa;
    background-color: transparent; }
  .btn-outline-light:not(:disabled):not(.disabled):active, .btn-outline-light:not(:disabled):not(.disabled).active,
  .show > .btn-outline-light.dropdown-toggle {
    color: #2b2b2b;
    background-color: #fafafa;
    border-color: #fafafa; }
    .btn-outline-light:not(:disabled):not(.disabled):active:focus, .btn-outline-light:not(:disabled):not(.disabled).active:focus,
    .show > .btn-outline-light.dropdown-toggle:focus {
      box-shadow: 0 0 0 0.2rem rgba(250, 250, 250, 0.5); }

.btn-outline-dark {
  color: #343a40;
  border-color: #343a40; }
  .btn-outline-dark:hover {
    color: #fff;
    background-color: #343a40;
    border-color: #343a40; }
  .btn-outline-dark:focus, .btn-outline-dark.focus {
    box-shadow: 0 0 0 0.2rem rgba(52, 58, 64, 0.5); }
  .btn-outline-dark.disabled, .btn-outline-dark:disabled {
    color: #343a40;
    background-color: transparent; }
  .btn-outline-dark:not(:disabled):not(.disabled):active, .btn-outline-dark:not(:disabled):not(.disabled).active,
  .show > .btn-outline-dark.dropdown-toggle {
    color: #fff;
    background-color: #343a40;
    border-color: #343a40; }
    .btn-outline-dark:not(:disabled):not(.disabled):active:focus, .btn-outline-dark:not(:disabled):not(.disabled).active:focus,
    .show > .btn-outline-dark.dropdown-toggle:focus {
      box-shadow: 0 0 0 0.2rem rgba(52, 58, 64, 0.5); }

.btn-link {
  font-weight: 400;
  color: #2b2b2b;
  text-decoration: none; }
  .btn-link:hover {
    color: #050505;
    text-decoration: underline; }
  .btn-link:focus, .btn-link.focus {
    text-decoration: underline; }
  .btn-link:disabled, .btn-link.disabled {
    color: #6c757d;
    pointer-events: none; }

.btn-lg {
  padding: 0.5rem 1rem;
  font-size: 1.25rem;
  line-height: 1.5;
  border-radius: 0; }

.btn-sm {
  padding: 0.25rem 0.5rem;
  font-size: 0.875rem;
  line-height: 1.5;
  border-radius: 0; }

.btn-block {
  display: block;
  width: 100%; }
  .btn-block + .btn-block {
    margin-top: 0.5rem; }

input[type="submit"].btn-block,
input[type="reset"].btn-block,
input[type="button"].btn-block {
  width: 100%; }

.fade {
  transition: opacity 0.15s linear; }
  @media (prefers-reduced-motion: reduce) {
    .fade {
      transition: none; } }
  .fade:not(.show) {
    opacity: 0; }

.collapse:not(.show) {
  display: none; }

.collapsing {
  position: relative;
  height: 0;
  overflow: hidden;
  transition: height 0.35s ease; }
  @media (prefers-reduced-motion: reduce) {
    .collapsing {
      transition: none; } }

.dropup,
.dropright,
.dropdown,
.dropleft {
  position: relative; }

.dropdown-toggle {
  white-space: nowrap; }
  .dropdown-toggle::after {
    display: inline-block;
    margin-left: 0.255em;
    vertical-align: 0.255em;
    content: "";
    border-top: 0.3em solid;
    border-right: 0.3em solid transparent;
    border-bottom: 0;
    border-left: 0.3em solid transparent; }
  .dropdown-toggle:empty::after {
    margin-left: 0; }

.dropdown-menu {
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 1000;
  display: none;
  float: left;
  min-width: 10rem;
  padding: 0.5rem 0;
  margin: 0.125rem 0 0;
  font-size: 1rem;
  color: #000;
  text-align: left;
  list-style: none;
  background-color: #fff;
  background-clip: padding-box;
  border: 1px solid rgba(0, 0, 0, 0.15); }

.dropdown-menu-left {
  right: auto;
  left: 0; }

.dropdown-menu-right {
  right: 0;
  left: auto; }

@media (min-width: 576px) {
  .dropdown-menu-sm-left {
    right: auto;
    left: 0; }
  .dropdown-menu-sm-right {
    right: 0;
    left: auto; } }

@media (min-width: 768px) {
  .dropdown-menu-md-left {
    right: auto;
    left: 0; }
  .dropdown-menu-md-right {
    right: 0;
    left: auto; } }

@media (min-width: 992px) {
  .dropdown-menu-lg-left {
    right: auto;
    left: 0; }
  .dropdown-menu-lg-right {
    right: 0;
    left: auto; } }

@media (min-width: 1200px) {
  .dropdown-menu-xl-left {
    right: auto;
    left: 0; }
  .dropdown-menu-xl-right {
    right: 0;
    left: auto; } }

.dropup .dropdown-menu {
  top: auto;
  bottom: 100%;
  margin-top: 0;
  margin-bottom: 0.125rem; }

.dropup .dropdown-toggle::after {
  display: inline-block;
  margin-left: 0.255em;
  vertical-align: 0.255em;
  content: "";
  border-top: 0;
  border-right: 0.3em solid transparent;
  border-bottom: 0.3em solid;
  border-left: 0.3em solid transparent; }

.dropup .dropdown-toggle:empty::after {
  margin-left: 0; }

.dropright .dropdown-menu {
  top: 0;
  right: auto;
  left: 100%;
  margin-top: 0;
  margin-left: 0.125rem; }

.dropright .dropdown-toggle::after {
  display: inline-block;
  margin-left: 0.255em;
  vertical-align: 0.255em;
  content: "";
  border-top: 0.3em solid transparent;
  border-right: 0;
  border-bottom: 0.3em solid transparent;
  border-left: 0.3em solid; }

.dropright .dropdown-toggle:empty::after {
  margin-left: 0; }

.dropright .dropdown-toggle::after {
  vertical-align: 0; }

.dropleft .dropdown-menu {
  top: 0;
  right: 100%;
  left: auto;
  margin-top: 0;
  margin-right: 0.125rem; }

.dropleft .dropdown-toggle::after {
  display: inline-block;
  margin-left: 0.255em;
  vertical-align: 0.255em;
  content: ""; }

.dropleft .dropdown-toggle::after {
  display: none; }

.dropleft .dropdown-toggle::before {
  display: inline-block;
  margin-right: 0.255em;
  vertical-align: 0.255em;
  content: "";
  border-top: 0.3em solid transparent;
  border-right: 0.3em solid;
  border-bottom: 0.3em solid transparent; }

.dropleft .dropdown-toggle:empty::after {
  margin-left: 0; }

.dropleft .dropdown-toggle::before {
  vertical-align: 0; }

.dropdown-menu[x-placement^="top"], .dropdown-menu[x-placement^="right"], .dropdown-menu[x-placement^="bottom"], .dropdown-menu[x-placement^="left"] {
  right: auto;
  bottom: auto; }

.dropdown-divider {
  height: 0;
  margin: 0.5rem 0;
  overflow: hidden;
  border-top: 1px solid #efefef; }

.dropdown-item {
  display: block;
  width: 100%;
  padding: 0.25rem 1.5rem;
  clear: both;
  font-weight: 400;
  color: #2b2b2b;
  text-align: inherit;
  white-space: nowrap;
  background-color: transparent;
  border: 0; }
  .dropdown-item:hover, .dropdown-item:focus {
    color: #1e1e1e;
    text-decoration: none;
    background-color: #fafafa; }
  .dropdown-item.active, .dropdown-item:active {
    color: #fff;
    text-decoration: none;
    background-color: #2b2b2b; }
  .dropdown-item.disabled, .dropdown-item:disabled {
    color: #6c757d;
    pointer-events: none;
    background-color: transparent; }

.dropdown-menu.show {
  display: block; }

.dropdown-header {
  display: block;
  padding: 0.5rem 1.5rem;
  margin-bottom: 0;
  font-size: 0.875rem;
  color: #6c757d;
  white-space: nowrap; }

.dropdown-item-text {
  display: block;
  padding: 0.25rem 1.5rem;
  color: #2b2b2b; }

.navbar {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  padding: 0.5rem 1rem; }
  .navbar .container,
  .navbar .container-fluid, .navbar > .container-sm, .navbar > .container-md, .navbar > .container-lg, .navbar > .container-xl {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between; }

.navbar-brand {
  display: inline-block;
  padding-top: 0.3125rem;
  padding-bottom: 0.3125rem;
  margin-right: 1rem;
  font-size: 1.25rem;
  line-height: inherit;
  white-space: nowrap; }
  .navbar-brand:hover, .navbar-brand:focus {
    text-decoration: none; }

.navbar-nav {
  display: flex;
  flex-direction: column;
  padding-left: 0;
  margin-bottom: 0;
  list-style: none; }
  .navbar-nav .nav-link {
    padding-right: 0;
    padding-left: 0; }
  .navbar-nav .dropdown-menu {
    position: static;
    float: none; }

.navbar-text {
  display: inline-block;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem; }

.navbar-collapse {
  flex-basis: 100%;
  flex-grow: 1;
  align-items: center; }

.navbar-toggler {
  padding: 0.25rem 0.75rem;
  font-size: 1.25rem;
  line-height: 1;
  background-color: transparent;
  border: 1px solid transparent; }
  .navbar-toggler:hover, .navbar-toggler:focus {
    text-decoration: none; }

.navbar-toggler-icon {
  display: inline-block;
  width: 1.5em;
  height: 1.5em;
  vertical-align: middle;
  content: "";
  background: no-repeat center center;
  background-size: 100% 100%; }

@media (max-width: 575.98px) {
  .navbar-expand-sm > .container,
  .navbar-expand-sm > .container-fluid, .navbar-expand-sm > .container-sm, .navbar-expand-sm > .container-md, .navbar-expand-sm > .container-lg, .navbar-expand-sm > .container-xl {
    padding-right: 0;
    padding-left: 0; } }

@media (min-width: 576px) {
  .navbar-expand-sm {
    flex-flow: row nowrap;
    justify-content: flex-start; }
    .navbar-expand-sm .navbar-nav {
      flex-direction: row; }
      .navbar-expand-sm .navbar-nav .dropdown-menu {
        position: absolute; }
      .navbar-expand-sm .navbar-nav .nav-link {
        padding-right: 0.5rem;
        padding-left: 0.5rem; }
    .navbar-expand-sm > .container,
    .navbar-expand-sm > .container-fluid, .navbar-expand-sm > .container-sm, .navbar-expand-sm > .container-md, .navbar-expand-sm > .container-lg, .navbar-expand-sm > .container-xl {
      flex-wrap: nowrap; }
    .navbar-expand-sm .navbar-collapse {
      display: flex !important;
      flex-basis: auto; }
    .navbar-expand-sm .navbar-toggler {
      display: none; } }

@media (max-width: 767.98px) {
  .navbar-expand-md > .container,
  .navbar-expand-md > .container-fluid, .navbar-expand-md > .container-sm, .navbar-expand-md > .container-md, .navbar-expand-md > .container-lg, .navbar-expand-md > .container-xl {
    padding-right: 0;
    padding-left: 0; } }

@media (min-width: 768px) {
  .navbar-expand-md {
    flex-flow: row nowrap;
    justify-content: flex-start; }
    .navbar-expand-md .navbar-nav {
      flex-direction: row; }
      .navbar-expand-md .navbar-nav .dropdown-menu {
        position: absolute; }
      .navbar-expand-md .navbar-nav .nav-link {
        padding-right: 0.5rem;
        padding-left: 0.5rem; }
    .navbar-expand-md > .container,
    .navbar-expand-md > .container-fluid, .navbar-expand-md > .container-sm, .navbar-expand-md > .container-md, .navbar-expand-md > .container-lg, .navbar-expand-md > .container-xl {
      flex-wrap: nowrap; }
    .navbar-expand-md .navbar-collapse {
      display: flex !important;
      flex-basis: auto; }
    .navbar-expand-md .navbar-toggler {
      display: none; } }

@media (max-width: 991.98px) {
  .navbar-expand-lg > .container,
  .navbar-expand-lg > .container-fluid, .navbar-expand-lg > .container-sm, .navbar-expand-lg > .container-md, .navbar-expand-lg > .container-lg, .navbar-expand-lg > .container-xl {
    padding-right: 0;
    padding-left: 0; } }

@media (min-width: 992px) {
  .navbar-expand-lg {
    flex-flow: row nowrap;
    justify-content: flex-start; }
    .navbar-expand-lg .navbar-nav {
      flex-direction: row; }
      .navbar-expand-lg .navbar-nav .dropdown-menu {
        position: absolute; }
      .navbar-expand-lg .navbar-nav .nav-link {
        padding-right: 0.5rem;
        padding-left: 0.5rem; }
    .navbar-expand-lg > .container,
    .navbar-expand-lg > .container-fluid, .navbar-expand-lg > .container-sm, .navbar-expand-lg > .container-md, .navbar-expand-lg > .container-lg, .navbar-expand-lg > .container-xl {
      flex-wrap: nowrap; }
    .navbar-expand-lg .navbar-collapse {
      display: flex !important;
      flex-basis: auto; }
    .navbar-expand-lg .navbar-toggler {
      display: none; } }

@media (max-width: 1199.98px) {
  .navbar-expand-xl > .container,
  .navbar-expand-xl > .container-fluid, .navbar-expand-xl > .container-sm, .navbar-expand-xl > .container-md, .navbar-expand-xl > .container-lg, .navbar-expand-xl > .container-xl {
    padding-right: 0;
    padding-left: 0; } }

@media (min-width: 1200px) {
  .navbar-expand-xl {
    flex-flow: row nowrap;
    justify-content: flex-start; }
    .navbar-expand-xl .navbar-nav {
      flex-direction: row; }
      .navbar-expand-xl .navbar-nav .dropdown-menu {
        position: absolute; }
      .navbar-expand-xl .navbar-nav .nav-link {
        padding-right: 0.5rem;
        padding-left: 0.5rem; }
    .navbar-expand-xl > .container,
    .navbar-expand-xl > .container-fluid, .navbar-expand-xl > .container-sm, .navbar-expand-xl > .container-md, .navbar-expand-xl > .container-lg, .navbar-expand-xl > .container-xl {
      flex-wrap: nowrap; }
    .navbar-expand-xl .navbar-collapse {
      display: flex !important;
      flex-basis: auto; }
    .navbar-expand-xl .navbar-toggler {
      display: none; } }

.navbar-expand {
  flex-flow: row nowrap;
  justify-content: flex-start; }
  .navbar-expand > .container,
  .navbar-expand > .container-fluid, .navbar-expand > .container-sm, .navbar-expand > .container-md, .navbar-expand > .container-lg, .navbar-expand > .container-xl {
    padding-right: 0;
    padding-left: 0; }
  .navbar-expand .navbar-nav {
    flex-direction: row; }
    .navbar-expand .navbar-nav .dropdown-menu {
      position: absolute; }
    .navbar-expand .navbar-nav .nav-link {
      padding-right: 0.5rem;
      padding-left: 0.5rem; }
  .navbar-expand > .container,
  .navbar-expand > .container-fluid, .navbar-expand > .container-sm, .navbar-expand > .container-md, .navbar-expand > .container-lg, .navbar-expand > .container-xl {
    flex-wrap: nowrap; }
  .navbar-expand .navbar-collapse {
    display: flex !important;
    flex-basis: auto; }
  .navbar-expand .navbar-toggler {
    display: none; }

.navbar-light .navbar-brand {
  color: rgba(0, 0, 0, 0.9); }
  .navbar-light .navbar-brand:hover, .navbar-light .navbar-brand:focus {
    color: rgba(0, 0, 0, 0.9); }

.navbar-light .navbar-nav .nav-link {
  color: rgba(0, 0, 0, 0.5); }
  .navbar-light .navbar-nav .nav-link:hover, .navbar-light .navbar-nav .nav-link:focus {
    color: rgba(0, 0, 0, 0.7); }
  .navbar-light .navbar-nav .nav-link.disabled {
    color: rgba(0, 0, 0, 0.3); }

.navbar-light .navbar-nav .show > .nav-link,
.navbar-light .navbar-nav .active > .nav-link,
.navbar-light .navbar-nav .nav-link.show,
.navbar-light .navbar-nav .nav-link.active {
  color: rgba(0, 0, 0, 0.9); }

.navbar-light .navbar-toggler {
  color: rgba(0, 0, 0, 0.5);
  border-color: rgba(0, 0, 0, 0.1); }

.navbar-light .navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='30' height='30' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%280, 0, 0, 0.5%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e"); }

.navbar-light .navbar-text {
  color: rgba(0, 0, 0, 0.5); }
  .navbar-light .navbar-text a {
    color: rgba(0, 0, 0, 0.9); }
    .navbar-light .navbar-text a:hover, .navbar-light .navbar-text a:focus {
      color: rgba(0, 0, 0, 0.9); }

.navbar-dark .navbar-brand {
  color: #fff; }
  .navbar-dark .navbar-brand:hover, .navbar-dark .navbar-brand:focus {
    color: #fff; }

.navbar-dark .navbar-nav .nav-link {
  color: rgba(255, 255, 255, 0.5); }
  .navbar-dark .navbar-nav .nav-link:hover, .navbar-dark .navbar-nav .nav-link:focus {
    color: rgba(255, 255, 255, 0.75); }
  .navbar-dark .navbar-nav .nav-link.disabled {
    color: rgba(255, 255, 255, 0.25); }

.navbar-dark .navbar-nav .show > .nav-link,
.navbar-dark .navbar-nav .active > .nav-link,
.navbar-dark .navbar-nav .nav-link.show,
.navbar-dark .navbar-nav .nav-link.active {
  color: #fff; }

.navbar-dark .navbar-toggler {
  color: rgba(255, 255, 255, 0.5);
  border-color: rgba(255, 255, 255, 0.1); }

.navbar-dark .navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='30' height='30' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 0.5%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e"); }

.navbar-dark .navbar-text {
  color: rgba(255, 255, 255, 0.5); }
  .navbar-dark .navbar-text a {
    color: #fff; }
    .navbar-dark .navbar-text a:hover, .navbar-dark .navbar-text a:focus {
      color: #fff; }

.modal-open {
  overflow: hidden; }
  .modal-open .modal {
    overflow-x: hidden;
    overflow-y: auto; }

.modal {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1050;
  display: none;
  width: 100%;
  height: 100%;
  overflow: hidden;
  outline: 0; }

.modal-dialog {
  position: relative;
  width: auto;
  margin: 0.5rem;
  pointer-events: none; }
  .modal.fade .modal-dialog {
    transition: -webkit-transform 0.3s ease-out;
    transition: transform 0.3s ease-out;
    transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
    -webkit-transform: translate(0, -50px);
            transform: translate(0, -50px); }
    @media (prefers-reduced-motion: reduce) {
      .modal.fade .modal-dialog {
        transition: none; } }
  .modal.show .modal-dialog {
    -webkit-transform: none;
            transform: none; }
  .modal.modal-static .modal-dialog {
    -webkit-transform: scale(1.02);
            transform: scale(1.02); }

.modal-dialog-scrollable {
  display: flex;
  max-height: calc(100% - 1rem); }
  .modal-dialog-scrollable .modal-content {
    max-height: calc(100vh - 1rem);
    overflow: hidden; }
  .modal-dialog-scrollable .modal-header,
  .modal-dialog-scrollable .modal-footer {
    flex-shrink: 0; }
  .modal-dialog-scrollable .modal-body {
    overflow-y: auto; }

.modal-dialog-centered {
  display: flex;
  align-items: center;
  min-height: calc(100% - 1rem); }
  .modal-dialog-centered::before {
    display: block;
    height: calc(100vh - 1rem);
    height: -webkit-min-content;
    height: -moz-min-content;
    height: min-content;
    content: ""; }
  .modal-dialog-centered.modal-dialog-scrollable {
    flex-direction: column;
    justify-content: center;
    height: 100%; }
    .modal-dialog-centered.modal-dialog-scrollable .modal-content {
      max-height: none; }
    .modal-dialog-centered.modal-dialog-scrollable::before {
      content: none; }

.modal-content {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  pointer-events: auto;
  background-color: #fff;
  background-clip: padding-box;
  border: 1px solid rgba(0, 0, 0, 0.2);
  outline: 0; }

.modal-backdrop {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1040;
  width: 100vw;
  height: 100vh;
  background-color: #000; }
  .modal-backdrop.fade {
    opacity: 0; }
  .modal-backdrop.show {
    opacity: 0.5; }

.modal-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: 1rem 1rem;
  border-bottom: 1px solid #d0d0d0; }
  .modal-header .close {
    padding: 1rem 1rem;
    margin: -1rem -1rem -1rem auto; }

.modal-title {
  margin-bottom: 0;
  line-height: 1.5; }

.modal-body {
  position: relative;
  flex: 1 1 auto;
  padding: 5rem; }

.modal-footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  padding: 4.75rem;
  border-top: 1px solid #d0d0d0; }
  .modal-footer > * {
    margin: 0.25rem; }

.modal-scrollbar-measure {
  position: absolute;
  top: -9999px;
  width: 50px;
  height: 50px;
  overflow: scroll; }

@media (min-width: 576px) {
  .modal-dialog {
    max-width: 500px;
    margin: 1.75rem auto; }
  .modal-dialog-scrollable {
    max-height: calc(100% - 3.5rem); }
    .modal-dialog-scrollable .modal-content {
      max-height: calc(100vh - 3.5rem); }
  .modal-dialog-centered {
    min-height: calc(100% - 3.5rem); }
    .modal-dialog-centered::before {
      height: calc(100vh - 3.5rem);
      height: -webkit-min-content;
      height: -moz-min-content;
      height: min-content; }
  .modal-sm {
    max-width: 300px; } }

@media (min-width: 992px) {
  .modal-lg,
  .modal-xl {
    max-width: 800px; } }

@media (min-width: 1200px) {
  .modal-xl {
    max-width: 995px; } }

.d-none {
  display: none !important; }

.d-inline {
  display: inline !important; }

.d-inline-block {
  display: inline-block !important; }

.d-block {
  display: block !important; }

.d-table {
  display: table !important; }

.d-table-row {
  display: table-row !important; }

.d-table-cell {
  display: table-cell !important; }

.d-flex {
  display: flex !important; }

.d-inline-flex {
  display: inline-flex !important; }

@media (min-width: 576px) {
  .d-sm-none {
    display: none !important; }
  .d-sm-inline {
    display: inline !important; }
  .d-sm-inline-block {
    display: inline-block !important; }
  .d-sm-block {
    display: block !important; }
  .d-sm-table {
    display: table !important; }
  .d-sm-table-row {
    display: table-row !important; }
  .d-sm-table-cell {
    display: table-cell !important; }
  .d-sm-flex {
    display: flex !important; }
  .d-sm-inline-flex {
    display: inline-flex !important; } }

@media (min-width: 768px) {
  .d-md-none {
    display: none !important; }
  .d-md-inline {
    display: inline !important; }
  .d-md-inline-block {
    display: inline-block !important; }
  .d-md-block {
    display: block !important; }
  .d-md-table {
    display: table !important; }
  .d-md-table-row {
    display: table-row !important; }
  .d-md-table-cell {
    display: table-cell !important; }
  .d-md-flex {
    display: flex !important; }
  .d-md-inline-flex {
    display: inline-flex !important; } }

@media (min-width: 992px) {
  .d-lg-none {
    display: none !important; }
  .d-lg-inline {
    display: inline !important; }
  .d-lg-inline-block {
    display: inline-block !important; }
  .d-lg-block {
    display: block !important; }
  .d-lg-table {
    display: table !important; }
  .d-lg-table-row {
    display: table-row !important; }
  .d-lg-table-cell {
    display: table-cell !important; }
  .d-lg-flex {
    display: flex !important; }
  .d-lg-inline-flex {
    display: inline-flex !important; } }

@media (min-width: 1200px) {
  .d-xl-none {
    display: none !important; }
  .d-xl-inline {
    display: inline !important; }
  .d-xl-inline-block {
    display: inline-block !important; }
  .d-xl-block {
    display: block !important; }
  .d-xl-table {
    display: table !important; }
  .d-xl-table-row {
    display: table-row !important; }
  .d-xl-table-cell {
    display: table-cell !important; }
  .d-xl-flex {
    display: flex !important; }
  .d-xl-inline-flex {
    display: inline-flex !important; } }

@media print {
  .d-print-none {
    display: none !important; }
  .d-print-inline {
    display: inline !important; }
  .d-print-inline-block {
    display: inline-block !important; }
  .d-print-block {
    display: block !important; }
  .d-print-table {
    display: table !important; }
  .d-print-table-row {
    display: table-row !important; }
  .d-print-table-cell {
    display: table-cell !important; }
  .d-print-flex {
    display: flex !important; }
  .d-print-inline-flex {
    display: inline-flex !important; } }

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0; }

.sr-only-focusable:active, .sr-only-focusable:focus {
  position: static;
  width: auto;
  height: auto;
  overflow: visible;
  clip: auto;
  white-space: normal; }

@media print {
  *,
  *::before,
  *::after {
    text-shadow: none !important;
    box-shadow: none !important; }
  a:not(.btn) {
    text-decoration: underline; }
  abbr[title]::after {
    content: " (" attr(title) ")"; }
  pre {
    white-space: pre-wrap !important; }
  pre,
  blockquote {
    border: 1px solid #9f9f9f;
    page-break-inside: avoid; }
  thead {
    display: table-header-group; }
  tr,
  img {
    page-break-inside: avoid; }
  p,
  h2,
  h3 {
    orphans: 3;
    widows: 3; }
  h2,
  h3 {
    page-break-after: avoid; }
  @page {
    size: a3; }
  body {
    min-width: 992px !important; }
  .container {
    min-width: 992px !important; }
  .navbar {
    display: none; }
  .badge {
    border: 1px solid #000; }
  .table {
    border-collapse: collapse !important; }
    .table td,
    .table th {
      background-color: #fff !important; }
  .table-bordered th,
  .table-bordered td {
    border: 1px solid #d0d0d0 !important; }
  .table-dark {
    color: inherit; }
    .table-dark th,
    .table-dark td,
    .table-dark thead th,
    .table-dark tbody + tbody {
      border-color: #d0d0d0; }
  .table .thead-dark th {
    color: inherit;
    border-color: #d0d0d0; } }

.logo-duoc {
  display: inline-block;
  width: 100px;
  height: 22px;
  background: transparent url(../images/logo-duoc.svg) no-repeat 0 0;
  background-size: cover;
  transition: all 0.2s ease-in-out;
  -webkit-filter: grayscale(1);
          filter: grayscale(1); }
  .logo-duoc:hover {
    -webkit-filter: unset;
            filter: unset; }
  @media (min-width: 768px) {
    .logo-duoc {
      width: 170px;
      height: 38px; } }

.logo-duoc-light {
  display: inline-block;
  width: 100px;
  height: 22px;
  background: transparent url(../images/logo-duoc-light.svg) no-repeat 0 0;
  background-size: cover; }
  @media (min-width: 768px) {
    .logo-duoc-light {
      width: 170px;
      height: 38px; } }

.logo-duoc-rutas-formativas {
  display: inline-block;
  width: 180px;
  height: 35px;
  background: transparent url(../images/logo-duoc-rutas-formativas-bg-negro.png) no-repeat 0 0;
  background-size: cover;
  background-blend-mode: multiply; }
  @media (min-width: 576px) {
    .logo-duoc-rutas-formativas {
      width: 220px;
      height: 43px; } }
  @media (min-width: 768px) {
    .logo-duoc-rutas-formativas {
      width: 250px;
      height: 38px; } }
  @media (min-width: 992px) {
    .logo-duoc-rutas-formativas {
      width: 300px;
      height: 45px; } }

.logo-duoc-rutas-formativas-black {
  position: relative;
  display: inline-block;
  width: 180px;
  height: 35px;
  background: transparent url(../images/logo-duoc-rutas-formativas-bg-transparente.png) no-repeat 0 0;
  background-size: cover; }
  @media (min-width: 576px) {
    .logo-duoc-rutas-formativas-black {
      width: 220px;
      height: 43px; } }
  @media (min-width: 768px) {
    .logo-duoc-rutas-formativas-black {
      width: 250px;
      height: 38px; } }
  @media (min-width: 992px) {
    .logo-duoc-rutas-formativas-black {
      width: 300px;
      height: 45px; } }

.logo-duoc-rutas-formativas-color {
  display: inline-block;
  width: 250px;
  height: 46px;
  background: transparent url(../images/logo-duoc-rutas-formativas-color.png) no-repeat 0 0;
  background-size: cover; }

.list-summary__label, .list-subjects .list-subject__metadata, .program-link-to-content, .program-section__duration, .btn-download, .subject__credits, .subject__subtitle, .program-option__label {
  font-size: 1rem;
  font-family: "Lato", sans-serif;
  text-transform: uppercase; }
  @media (min-width: 768px) {
    .list-summary__label, .list-subjects .list-subject__metadata, .program-link-to-content, .program-section__duration, .btn-download, .subject__credits, .subject__subtitle, .program-option__label {
      font-size: 0.85714rem; } }
  @media (min-width: 768px) {
    .list-summary__label, .list-subjects .list-subject__metadata, .program-link-to-content, .program-section__duration, .btn-download, .subject__credits, .subject__subtitle, .program-option__label {
      font-size: 1.16667rem; } }
  @media (min-width: 768px) and (min-width: 768px) {
    .list-summary__label, .list-subjects .list-subject__metadata, .program-link-to-content, .program-section__duration, .btn-download, .subject__credits, .subject__subtitle, .program-option__label {
      font-size: 1rem; } }

h1,
.h1, .subject-single__name, .site-title {
  font-size: 1.83333rem;
  font-family: "Lato", sans-serif;
  font-weight: 900;
  text-transform: uppercase; }
  @media (min-width: 768px) {
    h1,
    .h1, .subject-single__name, .site-title {
      font-size: 1.57143rem; } }
  @media (min-width: 768px) {
    h1,
    .h1, .subject-single__name, .site-title {
      font-size: 2rem; } }
  @media (min-width: 768px) and (min-width: 768px) {
    h1,
    .h1, .subject-single__name, .site-title {
      font-size: 1.71429rem; } }

h2,
.h2, .list-summary__description, .program-summary__footer-title, .program-section--featured .program-section__title,
.program-section--single .program-section__title, .subject__name {
  font-size: 1.66667rem;
  font-family: "Lato", sans-serif;
  font-weight: 900; }
  @media (min-width: 768px) {
    h2,
    .h2, .list-summary__description, .program-summary__footer-title, .program-section--featured .program-section__title,
    .program-section--single .program-section__title, .subject__name {
      font-size: 1.42857rem; } }
  @media (min-width: 768px) {
    h2,
    .h2, .list-summary__description, .program-summary__footer-title, .program-section--featured .program-section__title,
    .program-section--single .program-section__title, .subject__name {
      font-size: 1.75rem; } }
  @media (min-width: 768px) and (min-width: 768px) {
    h2,
    .h2, .list-summary__description, .program-summary__footer-title, .program-section--featured .program-section__title,
    .program-section--single .program-section__title, .subject__name {
      font-size: 1.5rem; } }

.program-section__title, .semester__title, .program-option__title, .program-option--exit {
  font-size: 1.33333rem;
  font-family: "Lato", sans-serif;
  font-weight: 900;
  line-height: 1.33;
  text-transform: uppercase; }
  @media (min-width: 768px) {
    .program-section__title, .semester__title, .program-option__title, .program-option--exit {
      font-size: 1.14286rem; } }
  @media (min-width: 768px) {
    .program-section__title, .semester__title, .program-option__title, .program-option--exit {
      font-size: 1.5rem; } }
  @media (min-width: 768px) and (min-width: 768px) {
    .program-section__title, .semester__title, .program-option__title, .program-option--exit {
      font-size: 1.28571rem; } }

h3,
.h3 {
  font-size: 1rem;
  font-family: "Lato", sans-serif;
  font-weight: 900;
  text-transform: uppercase; }
  @media (min-width: 768px) {
    h3,
    .h3 {
      font-size: 0.85714rem; } }
  @media (min-width: 768px) {
    h3,
    .h3 {
      font-size: 1.16667rem; } }
  @media (min-width: 768px) and (min-width: 768px) {
    h3,
    .h3 {
      font-size: 1rem; } }

.text-light, .subject__subtitle {
  font-weight: 400; }

h1,
.h1,
.subject-single__name {
  text-transform: none; }

h4, .h4 {
  font-size: 1rem;
  font-family: "Lato", sans-serif;
  font-weight: 900; }
  @media (min-width: 768px) {
    h4, .h4 {
      font-size: 0.85714rem; } }
  @media (min-width: 768px) {
    h4, .h4 {
      font-size: 1.16667rem; } }
  @media (min-width: 768px) and (min-width: 768px) {
    h4, .h4 {
      font-size: 1rem; } }

.text-content > h1,
.text-content > h2,
.text-content > h3,
.text-content > h4 {
  margin-top: 1.25rem;
  margin-bottom: 1rem; }

.text-content > p,
.text-content > ul,
.text-content > ol {
  margin-bottom: 1.5rem; }

.text-content > p + ul {
  margin-top: -.5rem; }

.text-content > ul,
.text-content > ol {
  padding-left: 1.5rem; }

.text-content > ol > li,
.text-content > ul > li {
  margin-bottom: 0.5rem; }

.text-content > ul + h3 {
  margin-top: 3rem; }

.text-content iframe {
  margin-top: 1rem;
  margin-bottom: 3rem; }

.text-content > *:last-child {
  margin-bottom: 0; }

.text-content > p:not([class]) a[href],
.text-content > ul:not([class]) a[href] {
  text-decoration: underline; }

.text-content-sm > h1,
.text-content-sm > h2,
.text-content-sm > h3,
.text-content-sm > h4 {
  margin-top: 1rem;
  margin-bottom: 0.66667rem; }

.text-content-sm > p,
.text-content-sm > ul,
.text-content-sm > ol {
  margin-bottom: 2.5rem; }

.text-content-sm > p + ul {
  margin-top: -1.5rem; }

.btn-bracket {
  font-size: 1rem;
  position: relative;
  display: block;
  margin-left: 5px;
  padding: 11px 17px;
  font-family: "Lato", sans-serif;
  font-weight: 900;
  letter-spacing: .25px;
  line-height: 1.3;
  color: #005d9c;
  background-color: rgba(var(--main-color-rgb), 0.25);
  transition: all 0.2s ease-in-out; }
  .btn-bracket::before, .btn-bracket::after {
    --border-width: 3px;
    position: absolute;
    width: calc( var(--border-width) * 2);
    top: calc( var(--border-width) / -2);
    bottom: calc( var(--border-width) / -2);
    border-top: var(--border-width) solid #2b2b2b;
    border-bottom: var(--border-width) solid #2b2b2b;
    content: ''; }
    @media (min-width: 768px) {
      .btn-bracket::before, .btn-bracket::after {
        --border-width: 5px; } }
  .btn-bracket::before {
    left: calc( var(--border-width) / -2);
    border-left: var(--border-width) solid #2b2b2b; }
  .btn-bracket::after {
    right: calc( var(--border-width) / -2);
    border-right: var(--border-width) solid #2b2b2b; }
  @media (min-width: 768px) {
    .btn-bracket {
      font-size: 0.85714rem; } }
  .btn-bracket:hover {
    text-decoration: none;
    color: #2b2b2b;
    background-color: rgba(var(--main-color-rgb), 0.5); }
  .btn-bracket.btn-bracket--aprendizaje-colaborativo-basado-desafios {
    padding-left: calc(17px + 15px + 6px);
    background-image: url(../images/icon-acbd.svg);
    background-repeat: no-repeat;
    background-position: 14px center; }
  @media (min-width: 768px) {
    .btn-bracket {
      font-size: 1.16667rem;
      display: inline-block; } }
  @media (min-width: 768px) and (min-width: 768px) {
    .btn-bracket {
      font-size: 1rem; } }

.underline, .program-section__title > a {
  position: relative;
  display: block;
  padding-bottom: 1rem;
  text-decoration: none;
  transition: all 0.2s ease-in-out; }
  .underline::after, .program-section__title > a::after {
    position: absolute;
    width: 60px;
    height: 7px;
    bottom: 0;
    left: 0;
    transition: width .35s ease;
    background-color: var(--main-color);
    content: ''; }
  .underline:hover::after, .program-section__title > a:hover::after {
    width: 150px; }

.list-summary {
  margin-bottom: 1rem; }
  @media (min-width: 768px) {
    .list-summary {
      display: flex; } }
  .subject-single .list-summary {
    margin-bottom: 3rem; }
    .subject-single .list-summary .list-skills {
      margin-top: 0.33333rem; }

.list-summary > li {
  display: flex;
  flex-direction: column; }
  @media (max-width: 767.98px) {
    .list-summary > li {
      margin-bottom: 1rem; } }
  @media (min-width: 768px) {
    .list-summary > li {
      margin-right: 50px; } }
  .list-summary > li:last-child {
    margin-right: 0; }

.list-summary__label {
  margin-bottom: .25rem; }
  .list-summary--sm .list-summary__label {
    font-size: 1rem; }
    @media (min-width: 768px) {
      .list-summary--sm .list-summary__label {
        font-size: 0.85714rem; } }

.list-summary__description {
  text-transform: uppercase; }
  .list-summary--sm .list-summary__description {
    font-size: 1.16667rem;
    display: flex;
    min-height: 40px;
    align-items: center; }
    @media (min-width: 768px) {
      .list-summary--sm .list-summary__description {
        font-size: 1rem; } }

.list-numbers {
  margin-bottom: 2.25rem; }
  .list-numbers > li {
    font-size: 1.16667rem;
    display: grid;
    grid-template-columns: minmax(2ch, auto) 1fr;
    -webkit-column-gap: 0.5rem;
       -moz-column-gap: 0.5rem;
            column-gap: 0.5rem;
    align-items: center;
    margin-bottom: 0.33333rem;
    line-height: 1.33; }
    @media (min-width: 768px) {
      .list-numbers > li {
        font-size: 1rem; } }
  .list-numbers .number {
    grid-column: 1/2;
    font-family: "Lato", sans-serif;
    font-weight: 900;
    text-align: right; }
  .list-numbers .number-description {
    grid-column: 2/3; }

.list-certificates {
  margin-bottom: 2.25rem; }
  .list-certificates > li {
    position: relative;
    margin-bottom: 0.5rem;
    margin-left: 0;
    padding-left: 1.125rem;
    font-weight: bold;
    line-height: 1.33; }
    .list-certificates > li a {
      color: #005d9c;
      font-weight: 900; }
    .list-certificates > li::before {
      content: '';
      position: absolute;
      display: block;
      width: 5px;
      height: 5px;
      top: 50%;
      left: 2px;
      margin-top: -3px;
      background-color: var(--main-color);
      border-radius: 5px; }
    .list-certificates > li .svg-check-dims {
      display: none; }
    @media (min-width: 768px) {
      .list-certificates > li .svg-check-dims {
        width: 20px;
        height: 20px;
        margin-top: -10px;
        left: 0; } }
  @media (min-width: 768px) {
    .program-section__col .list-certificates {
      display: flex;
      flex-wrap: wrap;
      justify-content: space-between;
      align-items: center; }
      .program-section__col .list-certificates > li {
        flex-basis: 45%;
        max-width: 45%;
        margin-bottom: 0.5rem; }
        .program-section__col .list-certificates > li .svg-check-dims {
          margin-top: -8px; } }

.list-skills > li {
  margin-bottom: 1rem;
  display: grid;
  grid-template-columns: 30px auto;
  gap: 0.5rem;
  align-items: center;
  line-height: 1.33;
  color: #2b2b2b; }

.list-skills [class^="svg-"],
.list-skills img {
  width: 30px;
  height: auto; }

.list-summary--inline .list-skills, .list-skills.list-skills--inline {
  display: flex; }
  .list-summary--inline .list-skills > li, .list-skills.list-skills--inline > li {
    margin-right: 1rem; }

symbol[id^="duoc-"] path:first-child {
  fill: var(--main-color); }

ul.list-skills-all {
  --icon-width: 60px;
  padding-top: 2rem;
  padding-left: 0; }
  ul.list-skills-all > li {
    position: relative;
    display: grid;
    grid-template-columns: var(--icon-width) 1fr;
    grid-template-rows: auto auto;
    -webkit-column-gap: 1.5rem;
       -moz-column-gap: 1.5rem;
            column-gap: 1.5rem;
    margin-bottom: 2rem; }
    @media (min-width: 768px) {
      ul.list-skills-all > li {
        -webkit-column-gap: 2.5rem;
           -moz-column-gap: 2.5rem;
                column-gap: 2.5rem;
        margin-bottom: 3.5rem; } }
  ul.list-skills-all .list-skills-all__title {
    font-size: 1.33333rem;
    grid-column: 2/3;
    grid-row: 1/2;
    align-self: flex-end; }
    @media (min-width: 768px) {
      ul.list-skills-all .list-skills-all__title {
        font-size: 1.14286rem; } }
    ul.list-skills-all .list-skills-all__title + p {
      grid-column: 2/3;
      grid-row: 2/3;
      margin-bottom: 0; }
  ul.list-skills-all [class^="svg-"],
  ul.list-skills-all img {
    grid-column: 1/2;
    grid-row: 1/3;
    width: var(--icon-width);
    height: auto;
    fill: rgba(43, 43, 43, 0.75); }
  @media (min-width: 768px) {
    ul.list-skills-all {
      --icon-width: 60px; } }

.list-subjects {
  margin-top: 1rem;
  margin-bottom: 2.25rem; }
  .list-subjects > li {
    margin-bottom: 0.5rem;
    background-color: #fafafa;
    border-left: 8px solid var(--main-color); }
    @media (min-width: 576px) {
      .list-subjects > li {
        display: grid;
        grid-template-columns: 1fr -webkit-max-content;
        grid-template-columns: 1fr max-content;
        display: flex;
        justify-content: space-between;
        align-items: stretch; } }
  .list-subjects .list-subject__name {
    font-size: 1.16667rem;
    grid-column: 1/2;
    padding: 1rem;
    font-weight: bold;
    line-height: 1.33; }
    @media (min-width: 768px) {
      .list-subjects .list-subject__name {
        font-size: 1rem; } }
    @media (max-width: 575.98px) {
      .list-subjects .list-subject__name {
        padding-top: 0.5rem;
        padding-bottom: 0.5rem; } }
  .list-subjects .list-subject__metadata {
    font-size: 1rem;
    grid-column: 2/3;
    display: flex;
    align-items: center;
    padding: 0.5rem 1rem;
    line-height: 1.33;
    letter-spacing: 0;
    background-color: #efefef; }
    @media (min-width: 768px) {
      .list-subjects .list-subject__metadata {
        font-size: 0.85714rem; } }
    .list-subjects .list-subject__metadata strong,
    .list-subjects .list-subject__metadata span {
      padding-left: 5px;
      padding-right: 5px; }
    .list-subjects .list-subject__metadata strong:first-child {
      padding-left: 0; }
    @media (min-width: 576px) {
      .list-subjects .list-subject__metadata {
        justify-content: space-between;
        min-height: 100%; } }

.list-subjects--courses {
  padding-left: 0 !important; }
  .list-subjects--courses .list-subject__metadata {
    min-width: 120px;
    justify-content: center; }

.list-bullets {
  margin-top: 1rem; }
  .list-bullets > li {
    position: relative;
    margin-top: 2rem;
    margin-bottom: 1rem;
    padding-left: 25px; }
  .list-bullets ol {
    margin-top: 1rem;
    margin-bottom: 1.5rem; }
  .list-bullets .svg-chevron-right-dims {
    position: absolute;
    width: 10px;
    height: 16px;
    top: 5px;
    left: 3px;
    fill: var(--main-color); }

ul.list-pedagogical-strategies {
  margin-left: 0;
  padding-left: 0; }
  ul.list-pedagogical-strategies > li {
    margin-bottom: 1rem;
    margin-left: 0; }

.js-owl-carousel.owl-carousel {
  position: relative;
  margin-bottom: 100px; }

.js-owl-carousel.owl-carousel .owl-nav {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 33.33333px; }
  @media (max-width: 991.98px) {
    .js-owl-carousel.owl-carousel .owl-nav {
      display: none; } }

.js-owl-carousel.owl-carousel .owl-prev {
  left: 45%; }
  .js-owl-carousel.owl-carousel .owl-prev:focus {
    -webkit-transform: translateX(-3px);
            transform: translateX(-3px); }

.js-owl-carousel.owl-carousel .owl-next {
  right: 45%; }
  .js-owl-carousel.owl-carousel .owl-next:focus {
    -webkit-transform: translateX(3px);
            transform: translateX(3px); }

.js-owl-carousel.owl-carousel .owl-nav button {
  background-color: transparent;
  border: none;
  z-index: 100;
  padding: 1rem !important;
  cursor: pointer;
  margin-left: 25px;
  margin-right: 25px;
  transition: all 0.2s ease-in-out; }
  .js-owl-carousel.owl-carousel .owl-nav button:focus {
    outline: none;
    transition: all 0.2s ease-in-out; }

.js-owl-carousel.owl-carousel [class^="svg-long-arrow-"] {
  width: 40px;
  height: 16px;
  vertical-align: initial;
  fill: #2b2b2b; }

.formative-route__testimony {
  position: relative; }

.slider-counter {
  font-size: 1.16667rem;
  font-weight: 700;
  color: #2b2b2b;
  letter-spacing: .3px;
  text-align: center;
  position: absolute;
  bottom: 16px;
  right: 0;
  left: 0; }
  @media (min-width: 768px) {
    .slider-counter {
      font-size: 1rem; } }
  @media (max-width: 991.98px) {
    .slider-counter {
      display: none; } }

.return-link {
  font-size: 1.16667rem;
  display: flex;
  align-items: center;
  font-family: "Lato", sans-serif;
  font-weight: bold;
  line-height: 1.16; }
  @media (min-width: 768px) {
    .return-link {
      font-size: 1rem; } }
  .return-link .svg-arrow-left-dims {
    width: 20px;
    height: 20px;
    margin-right: 0.5rem;
    fill: var(--main-color); }
  .return-link .svg-chevron-left-dims {
    width: 11px;
    height: 11px;
    margin-right: 0.4rem;
    fill: #000; }

@media (max-width: 991.98px) {
  .modal-dialog {
    max-width: 650px; } }

@media (max-width: 767.98px) {
  .modal-dialog {
    margin-top: 5rem;
    max-width: 550px; } }

.modal-title {
  margin-bottom: 2rem; }

.modal-body {
  position: relative;
  overflow: hidden; }
  .modal-body::before {
    position: absolute;
    width: 120%;
    top: -10px;
    left: -20px;
    right: 0;
    height: 300px;
    background-color: var(--main-color);
    -webkit-transform: rotate(0.85deg);
            transform: rotate(0.85deg);
    content: ''; }
  @media (max-width: 767.98px) {
    .modal-body {
      padding: 2rem; } }
  @media (max-width: 575.98px) {
    .modal-body {
      padding: 1rem; } }

.modal-body-wrapper {
  position: relative;
  padding: 50px;
  background-color: #fff;
  z-index: 10; }
  @media (max-width: 767.98px) {
    .modal-body-wrapper {
      padding: 2rem; } }
  .modal-body-wrapper > h2 {
    margin-top: 0; }
  .modal-body-wrapper .text-content > p > img:only-child {
    display: block;
    max-width: 640px;
    height: auto;
    margin: 2rem auto;
    width: 100%; }
  .modal-body-wrapper .external-link {
    font-size: 1rem;
    color: #005d9c;
    font-weight: 900; }
    @media (min-width: 768px) {
      .modal-body-wrapper .external-link {
        font-size: 0.85714rem; } }
    .modal-body-wrapper .external-link:hover {
      color: #005d9c; }
    @media (min-width: 768px) {
      .modal-body-wrapper .external-link {
        font-size: 1.16667rem;
        color: #005d9c; } }
  @media (min-width: 768px) and (min-width: 768px) {
    .modal-body-wrapper .external-link {
      font-size: 1rem; } }

.modal .close {
  position: absolute;
  top: 25px;
  right: 25px;
  background-color: transparent;
  border: none;
  z-index: 100000;
  cursor: pointer; }
  @media (max-width: 767.98px) {
    .modal .close {
      top: -3rem;
      right: 0; } }
  .modal .close .svg-close-dims {
    display: block;
    width: 20px;
    height: 20px;
    fill: #fff; }
    .modal .close .svg-close-dims use {
      fill: #fff; }
      @media (min-width: 768px) {
        .modal .close .svg-close-dims use {
          fill: #2b2b2b; } }
    @media (min-width: 768px) {
      .modal .close .svg-close-dims {
        display: inline-block;
        width: 16px;
        height: 16px;
        fill: #2b2b2b; } }
  .modal .close .modal-text-close {
    font-size: 1.16667rem;
    padding-right: 0.33333rem; }
    @media (min-width: 768px) {
      .modal .close .modal-text-close {
        font-size: 1rem; } }
    @media (max-width: 767.98px) {
      .modal .close .modal-text-close {
        display: none; } }

@media (max-width: 767.98px) {
  .modal--rutas .modal-body-wrapper {
    padding-bottom: 6rem; } }

@media (max-width: 575.98px) {
  .modal--rutas .modal-body-wrapper {
    padding-bottom: 2rem; } }

.modal--rutas .modal-title {
  text-transform: uppercase;
  margin-bottom: 0.5rem; }

.modal--rutas h4 {
  text-transform: uppercase;
  margin-bottom: 0.5rem; }

.modal--rutas .modal-formative-route {
  border-bottom: 1px solid #efefef;
  padding-bottom: 1rem;
  position: relative; }

.modal--rutas .modal-previous-version li {
  position: relative;
  padding-left: 1rem;
  margin-bottom: 0.33333rem; }
  .modal--rutas .modal-previous-version li::before {
    content: '';
    position: absolute;
    display: block;
    width: 5px;
    height: 5px;
    top: 50%;
    left: 0;
    margin-top: -3px;
    background-color: #000;
    border-radius: 50%; }
    @media (max-width: 767.98px) {
      .modal--rutas .modal-previous-version li::before {
        top: 6px;
        margin-top: 0; } }
  .modal--rutas .modal-previous-version li:only-child {
    padding-left: 0; }
    .modal--rutas .modal-previous-version li:only-child::before {
      content: none; }

.modal--rutas .modal-formative-route__current {
  background-color: #005d9c;
  font-weight: bold;
  color: #fff;
  padding: 0.33333rem 0.66667rem 0.5rem;
  display: block;
  text-align: center;
  max-width: 140px;
  margin-top: 1rem; }
  @media (min-width: 576px) {
    .modal--rutas .modal-formative-route__current {
      padding: 0.33333rem 0.66667rem 0.5rem;
      position: absolute;
      right: 0;
      bottom: 1rem;
      display: inline-block;
      margin-top: 0; } }

.modal--rutas .modal-formative-route__buttons {
  display: flex;
  gap: .25rem;
  margin-top: 1rem; }
  .modal--rutas .modal-formative-route__buttons .modal-formative-route__current {
    position: relative;
    right: unset;
    bottom: unset;
    margin-top: 0; }
  @media (min-width: 576px) {
    .modal--rutas .modal-formative-route__buttons {
      position: absolute;
      right: 0;
      bottom: 1rem; } }
  @media (min-width: 768px) and (max-width: 991.98px) {
    .modal--rutas .modal-formative-route__buttons {
      flex-direction: column; } }

.modal--rutas .modal-previous-version__link {
  color: #005d9c;
  font-weight: bold;
  text-align: left;
  padding: 0.33333rem 0;
  display: block; }
  @media (min-width: 576px) {
    .modal--rutas .modal-previous-version__link {
      position: absolute;
      right: 0;
      text-align: right;
      padding: 0 0.66667rem;
      display: inline-block; } }

.list-training-line {
  margin-bottom: 2.25rem; }
  .list-training-line > li {
    position: relative;
    margin-bottom: 0.5rem;
    margin-left: 0;
    padding-left: 1.125rem;
    font-weight: bold;
    line-height: 1.33; }
    .list-training-line > li a {
      color: #005d9c;
      font-weight: 900; }
    .list-training-line > li::before {
      content: '';
      position: absolute;
      display: block;
      width: 5px;
      height: 5px;
      top: 50%;
      left: 2px;
      margin-top: -3px;
      background-color: var(--main-color);
      border-radius: 5px; }
    .list-training-line > li .svg-check-dims {
      display: none; }
    @media (min-width: 768px) {
      .list-training-line > li .svg-check-dims {
        width: 20px;
        height: 20px;
        margin-top: -10px;
        left: 0; } }

html {
  font-size: 12px; }
  @media (min-width: 768px) {
    html {
      font-size: 14px; } }

html,
body {
  scroll-behavior: smooth; }

.container {
  width: 100%;
  padding-right: 25px;
  padding-left: 25px;
  margin-right: auto;
  margin-left: auto;
  max-width: 1300px; }

.site-header {
  position: relative;
  z-index: 10;
  overflow: hidden;
  background-color: var(--main-color); }
  .site-header .container {
    padding-top: 1rem;
    padding-bottom: 2rem; }
  .site-header::after {
    position: absolute;
    width: 120%;
    padding-top: 100%;
    bottom: 0;
    left: 0;
    background-color: #fff;
    -webkit-transform: rotate(0.85deg);
            transform: rotate(0.85deg);
    content: ''; }
  .site-header .site-title {
    display: flex;
    align-items: baseline; }
    @media (max-width: 1199.98px) {
      .site-header .site-title {
        flex-direction: column; } }
    .site-header .site-title .return-link {
      font-size: 1.41667rem;
      display: block;
      height: 100%;
      padding-left: 1rem;
      letter-spacing: 0;
      text-transform: none; }
      @media (min-width: 768px) {
        .site-header .site-title .return-link {
          font-size: 1.21429rem; } }
      @media (max-width: 1199.98px) {
        .site-header .site-title .return-link {
          font-size: 1.33333rem;
          padding: .3rem 0 0 0; } }
  @media (max-width: 1199.98px) and (min-width: 768px) {
    .site-header .site-title .return-link {
      font-size: 1.14286rem; } }
      @media (max-width: 767.98px) {
        .site-header .site-title .return-link {
          font-size: 1.16667rem; } }
  @media (max-width: 767.98px) and (min-width: 768px) {
    .site-header .site-title .return-link {
      font-size: 1rem; } }

.site-header__wrapper {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
  z-index: 1; }

.site-title {
  margin-bottom: 0;
  margin-right: 1rem; }
  @media (max-width: 575.98px) {
    .site-title {
      font-size: 1.16667rem;
      line-height: 1.25; } }
  @media (max-width: 575.98px) and (min-width: 768px) {
    .site-title {
      font-size: 1rem; } }

.site-header--corporative {
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  z-index: 1030; }
  .site-header--corporative .nav-primary .logo-nav:has(:not(.logo-primary)) {
    display: block; }
    .site-header--corporative .nav-primary .logo-nav:has(:not(.logo-primary)) .logo-scroll {
      height: 67px;
      width: auto; }

.site-header--routes .nav-primary .logo-nav .logo-primary-hero[src*="logo-duoc-footer.svg"] {
  width: 238px; }

/* NAV */
.navbar {
  position: fixed;
  width: 100%;
  z-index: 99999;
  padding: 0; }
  .navbar .logo-nav-mobile {
    display: none; }
  .navbar .d-none {
    display: none; }

.navbar-collapse {
  justify-content: flex-end;
  flex-direction: column; }

.nav-secondary {
  background-color: #E1E0DD;
  width: 100%; }
  .nav-secondary .navbar-nav {
    gap: .5rem;
    padding: .25rem;
    margin: 0;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap; }
    .nav-secondary .navbar-nav .nav-link {
      color: #000;
      font-size: 0.8rem;
      padding: .2rem .5rem;
      position: relative;
      display: flex;
      align-items: center;
      text-transform: uppercase;
      font-family: 'Lato';
      text-decoration: none; }

.btn-nav-icon1 a::before,
.btn-nav-icon2 a::before {
  content: "";
  display: inline-block;
  position: absolute;
  width: 1em;
  height: 1em;
  left: -7px; }

.btn-nav-icon1 a::before {
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='currentColor' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='M21 10c0 6-9 13-9 13S3 16 3 10a9 9 0 0 1 18 0Z'/%3E%3Ccircle cx='12' cy='10' r='3'/%3E%3C/svg%3E") no-repeat center; }

.btn-nav-icon2 a::before {
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='currentColor' stroke-width='2' viewBox='0 0 24 24'%3E%3Crect x='1' y='4' width='22' height='16' rx='2' ry='2'/%3E%3Cline x1='1' y1='10' x2='23' y2='10'/%3E%3C/svg%3E") no-repeat center; }

.btn-nav-border a {
  border: solid 1px rgba(0, 0, 0, 0.7);
  color: rgba(0, 0, 0, 0.7) !important;
  border-radius: 100px;
  font-weight: 600;
  padding: 6px 40px 6px 12px !important;
  transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out; }
  .btn-nav-border a::after {
    content: "";
    display: inline-block;
    position: absolute;
    width: 1em;
    height: 1em;
    right: 9px;
    font-size: 1.4rem;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='currentColor' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpolyline points='9 18 15 12 9 6'/%3E%3C/svg%3E") no-repeat center;
    color: rgba(0, 0, 0, 0.3); }
  .btn-nav-border a:hover {
    color: #000 !important;
    text-decoration: none; }
    .btn-nav-border a:hover::after {
      color: #000; }
  .btn-nav-border a:focus {
    color: #fff !important;
    background-color: #000; }
    .btn-nav-border a:focus::after {
      background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='%23ffffff' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpolyline points='9 18 15 12 9 6'/%3E%3C/svg%3E") no-repeat center; }

.btn-nav-bg a {
  background-color: #81db21;
  border: #61bb01;
  color: #000;
  border-radius: 100px;
  padding: 0.5rem .5rem !important;
  font-weight: 600; }
  .btn-nav-bg a:hover {
    box-shadow: 0px 0px 6px 2px rgba(97, 187, 1, 0.5); }

/* Nav primary */
.nav-primary {
  justify-content: space-between;
  width: 100%;
  display: flex; }
  .nav-primary .logo-nav {
    margin: 0 3.5rem 0 1rem !important;
    display: flex;
    align-items: center; }
    .nav-primary .logo-nav img {
      width: 100%; }
    .nav-primary .logo-nav .logo-primary,
    .nav-primary .logo-nav .logo-primary-hero {
      width: 280px;
      padding: .5rem 0; }
  .nav-primary .navbar-nav {
    background-color: #000;
    position: relative;
    gap: 2rem;
    margin-bottom: .5rem; }
    @media (min-width: 992px) {
      .nav-primary .navbar-nav {
        margin-bottom: 0; } }
    .nav-primary .navbar-nav::before {
      content: '';
      width: 0;
      height: 0;
      border-top: 67px solid #000;
      border-left: 60px solid transparent;
      position: absolute;
      left: -60px;
      top: 0px; }
    .nav-primary .navbar-nav .dropdown {
      display: flex;
      align-items: center; }
    .nav-primary .navbar-nav .nav-link {
      color: #fff;
      text-transform: uppercase;
      font-family: 'Lato';
      font-size: 1.2rem;
      font-weight: 400;
      padding: 0;
      text-decoration: none;
      background: 0 0;
      border: 0;
      transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out; }
      .nav-primary .navbar-nav .nav-link:hover {
        color: #919191 !important; }
    .nav-primary .navbar-nav .nav-link.show {
      color: #919191; }
    .nav-primary .navbar-nav .dropdown-menu {
      border-radius: 0px;
      background-color: #000; }
      .nav-primary .navbar-nav .dropdown-menu .dropdown-item {
        color: #fff;
        font-family: 'Lato';
        font-size: 1.2rem;
        text-decoration: none; }
        .nav-primary .navbar-nav .dropdown-menu .dropdown-item:hover {
          color: #000; }
        .nav-primary .navbar-nav .dropdown-menu .dropdown-item:focus {
          background-color: #fff;
          color: #000; }
      .nav-primary .navbar-nav .dropdown-menu .co-destacado {
        color: #FFB800; }
    .nav-primary .navbar-nav .nav-destacado {
      background-color: #FFB800;
      margin-left: 50px;
      padding-right: 1.5rem;
      position: relative; }
      .nav-primary .navbar-nav .nav-destacado::before {
        content: '';
        width: 0;
        height: 0;
        border-top: 67px solid #FFB800;
        border-left: 60px solid transparent;
        position: absolute;
        left: -60px;
        top: 0px; }
      .nav-primary .navbar-nav .nav-destacado .nav-link {
        color: #000;
        font-weight: 600; }
        .nav-primary .navbar-nav .nav-destacado .nav-link:hover {
          color: #000 !important; }
      .nav-primary .navbar-nav .nav-destacado .nav-link.show {
        color: #000; }
      .nav-primary .navbar-nav .nav-destacado .dropdown-menu {
        left: auto;
        right: 0; }
        .nav-primary .navbar-nav .nav-destacado .dropdown-menu .dropdown-item {
          padding-right: 3rem;
          font-family: 'Lato'; }
          .nav-primary .navbar-nav .nav-destacado .dropdown-menu .dropdown-item::before {
            display: none; }
      .nav-primary .navbar-nav .nav-destacado .dropdown-menu .destacado {
        background-color: #FFB800; }
        .nav-primary .navbar-nav .nav-destacado .dropdown-menu .destacado .dropdown-item {
          color: #000;
          font-weight: 700; }

.dropdown-menu[data-bs-popper] {
  top: 59px; }

.dropdown-item::before {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  vertical-align: -2px;
  margin-right: 0.5em;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='%23ffffff' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpolyline points='13 17 18 12 13 7'/%3E%3Cpolyline points='6 17 11 12 6 7'/%3E%3C/svg%3E") no-repeat center; }

.drop-submenu::after {
  display: inline-block;
  margin-left: .255em;
  vertical-align: 1px;
  content: "";
  border-top: .3em solid transparent;
  border-right: 0;
  border-bottom: .3em solid transparent;
  border-left: .3em solid; }

.sub-menu {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column; }
  .sub-menu .dropdown-item::before {
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='%23ffffff' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='M15 10l5 5-5 5'/%3E%3Cpath d='M4 4v7a4 4 0 0 0 4 4h12'/%3E%3C/svg%3E") no-repeat center; }

.navbar-toggler {
  border: none; }
  .navbar-toggler:focus {
    box-shadow: 1 1 1 #FFB800; }
  .navbar-toggler .navbar-icon {
    background: none;
    align-items: center;
    justify-content: center;
    display: flex;
    flex-direction: column; }
  .navbar-toggler .navbar-icon span {
    width: 30px;
    height: 2px;
    margin: 4px 0;
    background-color: white;
    transition: all .4s ease-in-out; }

.navbar-toggler[aria-expanded='true'] .navbar-icon .a {
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  -webkit-transform-origin: 1px;
          transform-origin: 1px;
  transition: all .4s ease-in-out; }

.navbar-toggler[aria-expanded='true'] .navbar-icon .b {
  -webkit-transform: scale(0);
          transform: scale(0);
  transition: all .4s ease-in-out; }

.navbar-toggler[aria-expanded='true'] .navbar-icon .c {
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
  -webkit-transform-origin: 1px;
          transform-origin: 1px;
  transition: all .4s ease-in-out; }

/* Nav primary */
/* SECCIÓN HERO */
#header-hero {
  background-image: url("../images/hero-duoc.jpg");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  background-attachment: fixed; }
  #header-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, black 20%, rgba(255, 255, 255, 0) 100%);
    z-index: 0; }

/* SECCIÓN HERO */
/* NAV */
@media (max-width: 1200px) {
  .navbar-brand-container {
    background-color: #1A1A1A;
    width: 100%;
    display: flex;
    justify-content: space-between; }
    .navbar-brand-container .logo-nav-mobile {
      display: block;
      max-width: 23rem; }
      .navbar-brand-container .logo-nav-mobile img {
        max-width: 100%;
        height: auto; }
  .logo-nav {
    display: none !important; }
  .navbar-collapse {
    height: 100vh;
    overflow-y: auto;
    padding-bottom: 3.2rem; }
    .navbar-collapse .nav-secondary {
      padding: 1rem; }
    .navbar-collapse .nav-secondary .navbar-nav .nav-item {
      width: 100%;
      display: flex; }
    .navbar-collapse .btn-nav-icon1,
    .navbar-collapse .btn-nav-icon2 {
      padding-left: 1rem; }
    .navbar-collapse .nav-primary {
      height: auto; }
    .navbar-collapse .nav-primary .navbar-nav {
      width: 100%;
      padding: 1rem;
      margin: 0 !important;
      gap: .5rem; }
      .navbar-collapse .nav-primary .navbar-nav .dropdown {
        flex-direction: column; }
        .navbar-collapse .nav-primary .navbar-nav .dropdown .nav-link {
          width: 100%;
          display: flex;
          justify-content: start;
          align-items: center; }
        .navbar-collapse .nav-primary .navbar-nav .dropdown .dropdown-menu {
          border: none;
          width: 100%;
          flex-direction: column; }
      .navbar-collapse .nav-primary .navbar-nav .nav-destacado {
        padding: 0;
        margin: 0; }
        .navbar-collapse .nav-primary .navbar-nav .nav-destacado .nav-link {
          padding-left: 1rem; }
        .navbar-collapse .nav-primary .navbar-nav .nav-destacado::before {
          display: none; }
  .section-hero {
    padding: 0; }
    .section-hero .row-hero {
      margin: 0 1.25rem;
      height: 69vh; }
      .section-hero .row-hero h1 {
        margin-right: 0; } }

@media (max-width: 768px) {
  .logo-nav-mobile {
    padding: 1.5rem !important; } }

@media (max-width: 576px) {
  .box-botton-header {
    flex-direction: column; }
    .box-botton-header .btn.btn-primary {
      width: -webkit-max-content;
      width: -moz-max-content;
      width: max-content; } }

.site-footer {
  position: relative;
  background-color: #fff; }
  .semesters + .site-footer,
  .courses + .site-footer {
    border-top: 5px solid #efefef; }
  .site-footer > .container {
    position: relative;
    padding-top: 2rem;
    padding-bottom: 2rem;
    z-index: 10; }
  @media (min-width: 768px) {
    .site-footer .logo-duoc {
      height: 51px;
      width: 206px;
      background-size: contain; } }
  .site-footer .logo-duoc-rutas-formativas-black {
    background: transparent url(../images/logo-duoc-rutas-formativas-bg-transparente-footer.png) no-repeat 0 0;
    background-size: cover; }
  .subject-single + .site-footer {
    margin-top: 50px; }
    .subject-single + .site-footer::after {
      background-image: linear-gradient(to bottom, #efefef 50%, #fff 100%);
      background-repeat: repeat-x;
      background-color: transparent; }

.site-footer__wrapper {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
  z-index: 1; }

/* FOOTER */
.footer-diseno {
  background-color: #1A1A1A;
  padding: 20px 40px;
  position: relative;
  z-index: 1; }
  .footer-diseno .container-fluid {
    width: 100%;
    padding-right: calc(var(1.5rem) * .5);
    padding-left: calc(var(1.5rem) * .5);
    margin-right: auto;
    margin-left: auto; }
  .footer-diseno .col {
    padding: 20px 20px; }
  .footer-diseno .box-title {
    border-bottom: 1px solid #FFB800;
    margin-bottom: 1rem; }
  .footer-diseno .title-footer {
    color: #FFB800;
    border-bottom: 7px solid #FFB800;
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    margin: 0;
    padding-bottom: .4rem;
    font-weight: 300;
    font-family: 'Merriweather';
    font-size: 1.9rem;
    text-transform: none; }
  .footer-diseno .list-footer {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    list-style: none;
    padding: 0; }
    .footer-diseno .list-footer.mt-5 {
      margin-top: 3rem; }
    .footer-diseno .list-footer a {
      color: #fff;
      transition: opacity 200ms ease;
      text-transform: uppercase;
      font-size: 1rem;
      text-decoration: none;
      font-family: 'Lato', sans-serif; }
    .footer-diseno .list-footer a:hover {
      text-decoration: underline; }
  .footer-diseno .contain-img-footer {
    border-top: solid 1px #fff;
    padding-top: 20px; }
    .footer-diseno .contain-img-footer .row {
      display: flex;
      justify-content: space-between;
      flex-wrap: wrap; }
      .footer-diseno .contain-img-footer .row .col {
        flex: 1 0 0; }
        .footer-diseno .contain-img-footer .row .col.justify-content-end {
          display: flex;
          justify-content: flex-end; }
    .footer-diseno .contain-img-footer .img-footer-1 {
      width: 40%;
      -o-object-fit: cover;
         object-fit: cover; }
    .footer-diseno .contain-img-footer .img-footer-2 {
      width: 65%;
      -o-object-fit: contain;
         object-fit: contain; }
  .footer-diseno .icon-footer {
    padding-right: .5rem; }
  .footer-diseno .d-none {
    display: none; }
  @media (min-width: 1200px) {
    .footer-diseno .d-xl-none {
      display: none; }
    .footer-diseno .d-xl-block {
      display: block; } }

@media (min-width: 1200px) {
  .footer-diseno__container {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr; } }

.footer-diseno .column-1 {
  color: #fff; }
  .footer-diseno .column-1 .btn.btn-primary.btn-footer {
    border-radius: 100px;
    padding: 0.5rem 1.5rem;
    border-color: rgba(255, 255, 255, 0.8);
    color: rgba(255, 255, 255, 0.8);
    background: transparent;
    margin: 2rem 0;
    transition: all .3s ease;
    font-size: 1.2rem; }
    .footer-diseno .column-1 .btn.btn-primary.btn-footer:hover {
      border-color: white;
      color: white;
      opacity: 1;
      background: rgba(0, 0, 0, 0.2);
      box-shadow: 0px 10px 7px black;
      -webkit-transform: translateY(-10px);
              transform: translateY(-10px);
      background-color: rgba(0, 0, 0, 0.2); }
  .footer-diseno .column-1 .section-column-1 {
    border-bottom: 1px solid #fff;
    margin: 0 5rem 0 0;
    padding-top: 1rem;
    padding-bottom: 1rem; }
    .footer-diseno .column-1 .section-column-1 h4 {
      font-family: "Merriweather", serif;
      font-weight: 500;
      font-size: 1.4rem; }
    .footer-diseno .column-1 .section-column-1 h5 {
      font-family: "lato", sans-serif;
      font-weight: 600;
      font-size: 1.3rem; }
    .footer-diseno .column-1 .section-column-1 p {
      margin: 0;
      font-size: 1.2rem;
      font-weight: 400; }
    .footer-diseno .column-1 .section-column-1 .number-footer {
      text-decoration: underline;
      color: #fff;
      font-weight: 600;
      font-size: 1.2rem; }
    .footer-diseno .column-1 .section-column-1 .list-column-1 {
      gap: 0; }
  .footer-diseno .column-1 .box-rrss {
    border: none;
    padding-bottom: 20px;
    padding-top: 3rem;
    margin: 0 5rem 0 0; }
    .footer-diseno .column-1 .box-rrss .dc-icon-footer {
      color: #fff; }
    .footer-diseno .column-1 .box-rrss .dc-rrss {
      gap: 3rem;
      justify-content: flex-start;
      display: flex; }
    .footer-diseno .column-1 .box-rrss .dc-icon-footer:hover {
      opacity: .3;
      transition: background-color .25s ease-in; }

.footer-toggle {
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
  background-color: transparent;
  border: none;
  border-bottom: solid 1px #FFB800;
  padding: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  text-align: left; }
  .footer-toggle.mb-5 {
    margin-bottom: 3rem; }
  .footer-toggle .chevron-icon {
    stroke: #FFB800; }
  .footer-toggle:focus:not(:focus-visible) {
    outline: 0; }

.footer-toggle.active-toggle {
  -webkit-transform: translateY(-10px);
          transform: translateY(-10px); }

.chevron-icon {
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease; }

.footer-toggle.active-toggle .chevron-icon {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg); }

.footer-toggle.active-toggle svg {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg); }

.footer-toggle svg, .footer-toggle.collapsed svg {
  -webkit-transform: rotate(0deg);
          transform: rotate(0deg); }

.accordion-footer {
  margin-bottom: 3rem; }

/* FOOTER */
@media ((min-width: 1400px)) {
  .footer-diseno .container {
    max-width: 100%;
    padding: 0 15px; } }

@media (max-width: 1200px) {
  .footer-diseno .column-1 .section-column-1 {
    margin: 0; }
  .footer-toggle,
  .footer-toggle:hover {
    border-bottom-color: #FFB800; } }

@media (max-width: 768px) {
  .footer-diseno .contain-img-footer .img-footer-1 {
    width: 95%;
    -o-object-fit: cover;
       object-fit: cover; }
  .footer-diseno .contain-img-footer .img-footer-2 {
    width: 100%;
    -o-object-fit: contain;
       object-fit: contain; } }

@media (max-width: 576px) {
  .box-rrss .dc-rrss {
    justify-content: space-between;
    gap: 0; } }

.site-header--routes {
  background-image: url("../../dist/images/hero-duoc.jpg");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  background-attachment: fixed;
  z-index: initial; }
  .site-header--routes::after {
    content: none; }
  .site-header--routes::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, black 20%, rgba(255, 255, 255, 0) 100%);
    z-index: 0; }
  .site-header--routes .container {
    padding-top: 25px;
    padding-bottom: 25px; }
  .site-header--routes .site-header__link {
    color: #fff;
    font-weight: 900;
    margin-left: 1rem; }
    @media (min-width: 768px) {
      .site-header--routes .site-header__link {
        font-size: 1.5rem; } }
  @media (min-width: 768px) and (min-width: 768px) {
    .site-header--routes .site-header__link {
      font-size: 1.28571rem; } }

.formative-route {
  position: relative;
  color: #fff;
  padding-top: 40px;
  background-color: #fff; }
  .formative-route .container {
    position: relative;
    z-index: 1;
    max-width: 1380px;
    padding-bottom: 5rem; }
    @media (max-width: 1199.98px) {
      .formative-route .container {
        padding-left: 0;
        padding-right: 0; } }

.formative-route__title {
  font-size: 1.75rem;
  font-family: "Merriweather", serif;
  font-weight: 700;
  text-transform: none;
  margin-bottom: 0.5rem;
  color: #000;
  margin-top: 0;
  padding: 0 1.25rem; }
  @media (min-width: 768px) {
    .formative-route__title {
      font-size: 1.5rem; } }
  @media (min-width: 1200px) {
    .formative-route__title {
      padding: 0; } }
  @media (min-width: 768px) {
    .formative-route__title {
      font-size: 3.5rem;
      margin-top: 25px; } }
  @media (min-width: 768px) and (min-width: 768px) {
    .formative-route__title {
      font-size: 3rem; } }

.formative-route__paragraph {
  font-size: 1rem;
  font-family: "Merriweather", serif;
  font-weight: 400;
  color: #000;
  line-height: 1.4;
  margin-bottom: 2rem;
  padding: 0 1.25rem; }
  @media (min-width: 768px) {
    .formative-route__paragraph {
      font-size: 0.85714rem; } }
  @media (min-width: 1200px) {
    .formative-route__paragraph {
      padding: 0; } }
  @media (min-width: 768px) {
    .formative-route__paragraph {
      font-size: 1.5rem;
      line-height: 1.5; } }
  @media (min-width: 768px) and (min-width: 768px) {
    .formative-route__paragraph {
      font-size: 1.28571rem; } }

.hero {
  position: relative;
  overflow: hidden;
  height: 223px; }
  @media (min-width: 768px) {
    .hero {
      height: 350px; } }

.hero img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: 50%;
     object-position: 50%;
  position: absolute;
  bottom: 0;
  height: 360px;
  -webkit-filter: blur(2px);
          filter: blur(2px);
  -webkit-transform: scale(1.04);
  transform: scale(1.04); }

.hero::before {
  content: '';
  background-color: #2b2b2b;
  opacity: .3;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 2; }

.hero::after {
  content: '';
  background-color: #fff;
  position: absolute;
  right: 0;
  height: 23px;
  bottom: -12px;
  left: 0;
  z-index: 2;
  -webkit-transform: rotate(0.7deg);
  transform: rotate(0.7deg); }

.hero .container {
  max-width: 730px;
  position: relative;
  padding: 1rem;
  z-index: 4;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%; }

.hero__title {
  font-size: 1.75rem;
  text-transform: uppercase;
  text-align: center;
  color: #fff;
  font-weight: 800;
  line-height: 1.2;
  text-shadow: 0px 0px 4px rgba(0, 0, 0, 0.25); }
  @media (min-width: 768px) {
    .hero__title {
      font-size: 1.5rem; } }
  @media (min-width: 768px) {
    .hero__title {
      font-size: 2.83333rem; } }
  @media (min-width: 768px) and (min-width: 768px) {
    .hero__title {
      font-size: 2.42857rem; } }

.image-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  z-index: -1;
  position: fixed; }

.section-hero {
  max-width: 1380px;
  display: flex;
  align-items: center;
  overflow: hidden;
  position: relative;
  padding-right: 25px;
  padding-left: 25px;
  padding-bottom: 25px; }
  .section-hero.container {
    padding-top: 150px;
    padding-bottom: 60px; }
    @media (min-width: 992px) {
      .section-hero.container {
        min-height: 700px; } }
    @media (min-width: 1199px) {
      .section-hero.container {
        padding-top: 100px;
        padding-bottom: 25px;
        min-height: 780px; } }
  .section-hero__content {
    max-width: 43.5rem;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    color: #ffffff; }
  .section-hero__logo {
    max-width: 200px;
    width: 100%;
    height: auto;
    margin-bottom: 3.2rem; }
    @media (min-width: 768px) {
      .section-hero__logo {
        max-width: 250px; } }
    @media (min-width: 992px) {
      .section-hero__logo {
        max-width: 300px; } }
  .section-hero__title-home {
    font-size: 2.33333rem;
    font-family: "Merriweather", serif;
    text-shadow: 1px 1px 4px rgba(0, 0, 0, 0.5);
    font-weight: 400;
    margin-bottom: 0; }
    @media (min-width: 768px) {
      .section-hero__title-home {
        font-size: 2rem; } }
    @media (min-width: 768px) {
      .section-hero__title-home {
        font-size: 2.83333rem; } }
  @media (min-width: 768px) and (min-width: 768px) {
    .section-hero__title-home {
      font-size: 2.42857rem; } }
    @media (min-width: 992px) {
      .section-hero__title-home {
        font-size: 3.5rem; } }
  @media (min-width: 992px) and (min-width: 768px) {
    .section-hero__title-home {
      font-size: 3rem; } }
  .section-hero__buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
    margin-top: 3.1rem; }
  .section-hero .btn.btn-primary {
    border: solid 3px #fff;
    border-radius: 100px;
    position: relative;
    padding: 12px 30px !important;
    text-align: left;
    transition: all .3s ease;
    display: flex;
    align-items: center;
    font-size: 1.3rem;
    font-weight: 800; }
    .section-hero .btn.btn-primary:hover {
      box-shadow: 0px 10px 7px rgba(0, 0, 0, 0.1);
      -webkit-transform: translateY(-10px);
              transform: translateY(-10px); }
    .section-hero .btn.btn-primary:focus {
      -webkit-transform: translateY(-10px);
              transform: translateY(-10px);
      box-shadow: 0 0 0 0.3rem #9f9f9f; }
    .section-hero .btn.btn-primary .svg-chevron-right-dims {
      width: 6px;
      height: 12px;
      fill: #000000;
      margin-left: 1.2rem; }
  .section-hero .btn.btn-primary.btn-header-1 {
    background-color: #fff;
    color: #000; }
  .section-hero .btn.btn-primary.btn-header-2 {
    background-color: transparent;
    color: #fff; }
    .section-hero .btn.btn-primary.btn-header-2 .svg-chevron-right-dims {
      fill: #ffffff; }

.hero-home {
  position: relative;
  overflow: hidden;
  height: 100vh !important;
  min-height: 700px; }
  .hero-home > img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: 50%;
       object-position: 50%;
    position: absolute; }
  .hero-home::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, black 20%, rgba(255, 255, 255, 0) 100%);
    z-index: 0; }
  .hero-home .container {
    position: relative;
    padding: 1rem;
    z-index: 4;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    flex-direction: column;
    height: 100%; }
  .hero-home .hero-home__logo {
    margin-bottom: 3.2rem;
    max-width: 25rem; }
  .hero-home h1 {
    font-size: 1.75rem;
    font-family: 'Merriweather';
    text-shadow: 1px 1px 4px rgba(0, 0, 0, 0.5);
    color: #fff;
    font-weight: 400;
    line-height: 1.2; }
    @media (min-width: 768px) {
      .hero-home h1 {
        font-size: 1.5rem; } }
    @media (min-width: 768px) {
      .hero-home h1 {
        font-size: 2.83333rem; } }
  @media (min-width: 768px) and (min-width: 768px) {
    .hero-home h1 {
      font-size: 2.42857rem; } }
  .hero-home .hero-home__buttons {
    display: flex; }
  .hero-home .btn.btn-primary {
    border: solid 3px #fff;
    border-radius: 100px;
    position: relative;
    padding: 12px 30px !important;
    text-align: left;
    transition: all .3s ease;
    display: flex;
    align-items: center;
    font-size: 1.3rem;
    font-weight: 800; }
    .hero-home .btn.btn-primary:hover {
      box-shadow: 0px 10px 7px rgba(0, 0, 0, 0.1);
      -webkit-transform: translateY(-10px);
              transform: translateY(-10px); }
    .hero-home .btn.btn-primary:focus {
      -webkit-transform: translateY(-10px);
              transform: translateY(-10px);
      box-shadow: 0 0 0 0.3rem #9f9f9f; }
    .hero-home .btn.btn-primary svg {
      margin-left: 1.2rem; }
  .hero-home .btn.btn-primary.btn-header-1 {
    background-color: #fff;
    color: #000; }
  .hero-home .btn.btn-primary.btn-header-2 {
    background-color: transparent;
    color: #fff; }

.featured-message__image {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-size: cover;
  background-position: 0 0;
  background-repeat: no-repeat;
  background-image: url(../images/ruta-formativa.jpg);
  -webkit-filter: blur(2px);
          filter: blur(2px);
  -webkit-transform: scale(1.04);
  transform: scale(1.04); }
  @media (min-width: 992px) {
    .featured-message__image {
      background-position: 0 -119px; } }
  .featured-message__image::after {
    content: '';
    background-color: rgba(0, 0, 0, 0.7);
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0; }

.suggested-routes {
  display: grid;
  gap: 5px;
  grid-template-columns: 1fr; }
  @media (min-width: 992px) {
    .suggested-routes {
      grid-template-columns: minmax(0, 50%) 1fr;
      grid-template-rows: repeat(auto-fill, minmax(40px, auto));
      gap: 10px; } }
  @media (min-width: 1200px) {
    .suggested-routes {
      grid-template-columns: minmax(0, 630px) 1fr; } }

.suggested-routes__title {
  font-size: 1rem;
  text-transform: uppercase;
  color: #2b2b2b;
  font-weight: 700;
  letter-spacing: 0.48px;
  padding: 10px 20px;
  margin-bottom: 0;
  grid-column: 1/2; }
  @media (min-width: 768px) {
    .suggested-routes__title {
      font-size: 0.85714rem; } }
  @media (min-width: 992px) {
    .suggested-routes__title {
      font-size: 1.33333rem; } }
  @media (min-width: 992px) and (min-width: 768px) {
    .suggested-routes__title {
      font-size: 1.14286rem; } }

.careers__wrapper {
  background-color: var(--career-color, #b5b5a5);
  color: #fff;
  position: relative;
  padding: 25px 20px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: .5rem;
  grid-column: 1/2;
  transition: all 0.2s ease-in-out;
  padding-top: 1rem;
  padding-bottom: 1rem; }
  .careers__wrapper:hover {
    cursor: pointer;
    text-decoration: none !important;
    background-color: var(--career-color, #b5b5a5);
    color: #fff; }
    .careers__wrapper:hover .formative-route-link {
      color: #2b2b2b; }
    .careers__wrapper:hover .svg-chevron-right-dims {
      fill: #fff; }
  @media (min-width: 992px) {
    .careers__wrapper {
      padding-left: 85px;
      height: 100px; }
      .careers__wrapper::before {
        content: '';
        background-color: var(--career-color, #b5b5a5);
        position: absolute;
        left: 0;
        top: -1px;
        bottom: 0;
        width: 50px;
        -webkit-clip-path: polygon(60% 0, 100% 50%, 60% 100%, 0 100%, 0 0);
                clip-path: polygon(60% 0, 100% 50%, 60% 100%, 0 100%, 0 0);
        z-index: 1; }
      .careers__wrapper::after {
        content: '';
        background-color: #fff;
        position: absolute;
        left: 0;
        top: -1px;
        bottom: 0;
        width: 60px;
        -webkit-clip-path: polygon(67% 0, 100% 50%, 67% 100%, 0 100%, 0 0);
                clip-path: polygon(67% 0, 100% 50%, 67% 100%, 0 100%, 0 0);
        z-index: 0;
        min-height: 81px;
        height: 100%; } }
    @media (min-width: 992px) and (min-width: 992px) {
      .careers__wrapper::after {
        height: 101px; } }

.careers-title {
  font-size: 1.16667rem;
  text-transform: none;
  font-weight: 700;
  margin-bottom: 0; }
  @media (min-width: 768px) {
    .careers-title {
      font-size: 1rem; } }
  @media (min-width: 992px) {
    .careers-title {
      font-size: 1.75rem; } }
  @media (min-width: 992px) and (min-width: 768px) {
    .careers-title {
      font-size: 1.5rem; } }

.formative-route-link {
  font-size: 1rem;
  color: var(--main-color);
  font-family: "Merriweather", serif;
  font-weight: 400;
  margin-bottom: 0;
  padding: 0.5rem 0;
  white-space: nowrap; }
  @media (min-width: 768px) {
    .formative-route-link {
      font-size: 0.85714rem; } }
  .formative-route-link:hover {
    text-decoration: underline;
    color: var(--main-color); }
  @media (min-width: 992px) {
    .formative-route-link {
      font-size: 1.33333rem; } }
  @media (min-width: 992px) and (min-width: 768px) {
    .formative-route-link {
      font-size: 1.14286rem; } }
  .formative-route-link::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 2; }

.formative-route-link .svg-chevron-right-dims {
  width: 6px;
  height: 10px;
  fill: var(--career-color, #b5b5a5);
  margin-left: 3px; }
  .careers__wrapper.active .formative-route-link .svg-chevron-right-dims {
    fill: #fff; }
    @media (max-width: 1199.98px) {
      .careers__wrapper.active .formative-route-link .svg-chevron-right-dims {
        -webkit-transform: rotate(90deg);
                transform: rotate(90deg); } }

.career__specializations {
  margin: 5px; }
  @media (min-width: 992px) {
    .career__specializations {
      display: none; } }

.suggested-routes__options {
  display: none; }
  @media (min-width: 992px) {
    .suggested-routes__options {
      display: grid;
      grid-template-columns: 1fr;
      grid-template-rows: auto 1fr;
      grid-column: 2/3;
      grid-row: 1 / 8;
      -webkit-column-gap: 10px;
         -moz-column-gap: 10px;
              column-gap: 10px;
      grid-template-columns: 1fr;
      grid-template-rows: -webkit-max-content;
      grid-template-rows: max-content; } }

@media (min-width: 992px) {
  .suggested-routes__options .suggested-routes__title:first-child {
    grid-column: 1/2;
    grid-row: 1/2;
    margin-bottom: 10px; } }

@media (min-width: 992px) {
  .suggested-routes__options .suggested-routes__title:nth-child(3) {
    grid-column: 2/3;
    grid-row: 1/2;
    margin-bottom: 10px; } }

.suggested-routes__specialization {
  display: grid;
  grid-template-columns: 1fr;
  row-gap: 5px; }
  @media (min-width: 992px) {
    .suggested-routes__specialization {
      grid-template-rows: repeat(auto-fit, minmax(55px, auto));
      row-gap: 10px; } }

.suggested-tag {
  font-size: 0.91667rem;
  color: #2b2b2b;
  letter-spacing: .3px;
  text-transform: uppercase;
  font-weight: 700;
  text-align: center;
  display: block;
  background-color: var(--main-color);
  border-radius: 5px;
  padding: 4px 7px;
  width: 150px;
  margin-bottom: 5px;
  opacity: 0;
  -webkit-animation: fadeIn 1s forwards;
          animation: fadeIn 1s forwards; }
  @media (min-width: 768px) {
    .suggested-tag {
      font-size: 0.78571rem; } }
  @media (min-width: 992px) {
    .suggested-tag {
      margin-bottom: 10px; } }

@-webkit-keyframes fadeIn {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }

@keyframes fadeIn {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }

@media (min-width: 992px) {
  .has-selected {
    background-color: var(--main-color);
    border-radius: 10px 10px 0 0; } }

.suggested-routes__options .has-selected {
  background-color: var(--main-color);
  text-align: center; }
  @media (min-width: 992px) {
    .suggested-routes__options .has-selected {
      background-color: transparent;
      text-align: left; } }

.suggested-routes__mention {
  display: grid;
  grid-template-rows: repeat(auto-fill, minmax(1fr, 1fr));
  row-gap: 5px;
  margin-bottom: 5px; }
  @media (min-width: 992px) {
    .suggested-routes__mention {
      row-gap: 10px;
      grid-template-rows: repeat(auto-fill, minmax(320px, 1fr));
      margin-bottom: 0; } }

.mention__wrapper {
  position: relative;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding: 1rem 20px;
  grid-column: 1 / 3;
  background-color: #2b2b2b;
  color: #fff;
  transition: all 0.2s ease-in-out; }
  .mention__wrapper:hover {
    color: #2b2b2b;
    background-color: var(--main-color) !important; }
    .mention__wrapper:hover .svg-chevron-right-dims {
      fill: #2b2b2b; }
  @media (min-width: 992px) {
    .mention__wrapper {
      gap: .5rem;
      padding-top: .5rem;
      padding-bottom: .5rem; } }

.mention-title {
  font-size: 1.16667rem;
  text-transform: none;
  font-weight: 700;
  margin-bottom: 0;
  line-height: 1.4; }
  @media (min-width: 768px) {
    .mention-title {
      font-size: 1rem; } }
  @media (min-width: 992px) {
    .mention-title {
      font-size: 1.5rem; } }
  @media (min-width: 992px) and (min-width: 768px) {
    .mention-title {
      font-size: 1.28571rem; } }

.suggested-routes__diplomat {
  display: grid;
  grid-template-rows: repeat(auto-fill, minmax(1fr, 1fr));
  row-gap: 5px; }
  @media (min-width: 992px) {
    .suggested-routes__diplomat {
      row-gap: 10px; } }

.diplomat__wrapper {
  background-color: #2b2b2b;
  color: #fff;
  position: relative;
  padding: 25px 25px 1.5rem;
  display: flex;
  justify-content: center;
  flex-direction: column;
  transition: all 0.2s ease-in-out; }
  @media (min-width: 992px) {
    .diplomat__wrapper {
      padding: 25px; } }

.diplomat-title {
  font-size: 1.33333rem;
  text-transform: none;
  font-weight: 700;
  margin-bottom: 0;
  line-height: 1.4; }
  @media (min-width: 768px) {
    .diplomat-title {
      font-size: 1.14286rem; } }
  @media (min-width: 992px) {
    .diplomat-title {
      font-size: 1.5rem; } }
  @media (min-width: 992px) and (min-width: 768px) {
    .diplomat-title {
      font-size: 1.28571rem; } }

.inactive,
.careers__wrapper--ddwebfol {
  background-color: #D9D9D9;
  color: #2b2b2b; }
  .inactive::before,
  .careers__wrapper--ddwebfol::before {
    background-color: #D9D9D9; }
  .inactive.careers__wrapper:hover,
  .careers__wrapper--ddwebfol.careers__wrapper:hover {
    background-color: #2b2b2b;
    color: #fff; }
    .inactive.careers__wrapper:hover::before,
    .careers__wrapper--ddwebfol.careers__wrapper:hover::before {
      background-color: #2b2b2b; }
  .inactive .formative-route-link,
  .careers__wrapper--ddwebfol .formative-route-link {
    color: #fff; }
  .inactive .svg-chevron-right-dims,
  .careers__wrapper--ddwebfol .svg-chevron-right-dims {
    fill: #2b2b2b; }

.careers__wrapper.active,
.careers__wrapper.careers__wrapper--ddwebfol:hover {
  background-color: var(--career-color, #b5b5a5);
  color: #fff; }
  .careers__wrapper.active::before,
  .careers__wrapper.careers__wrapper--ddwebfol:hover::before {
    background-color: var(--career-color, #b5b5a5); }
  .careers__wrapper.active .formative-route-link,
  .careers__wrapper.careers__wrapper--ddwebfol:hover .formative-route-link {
    color: var(--career-color, #b5b5a5); }
  .careers__wrapper.active .svg-chevron-right-dims,
  .careers__wrapper.careers__wrapper--ddwebfol:hover .svg-chevron-right-dims {
    fill: #fff; }

.mention__wrapper.active {
  background-color: #2b2b2b;
  color: #fff; }
  .mention__wrapper.active::before {
    background-color: #2b2b2b; }
  .mention__wrapper.active .formative-route-link {
    color: #2b2b2b; }
  .mention__wrapper.active .svg-chevron-right-dims {
    fill: var(--main-color); }

.formative-route__testimony {
  margin-top: 33.33333px; }

.testimony {
  position: relative; }
  @media (min-width: 992px) {
    .testimony {
      display: flex;
      align-items: flex-start;
      justify-content: space-between; } }

.testimony__wrapper {
  position: relative;
  z-index: 1;
  height: 166px;
  width: 100%;
  overflow: hidden; }
  .testimony__wrapper img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: 50%;
       object-position: 50%; }
  @media (min-width: 576px) {
    .testimony__wrapper {
      height: 300px; } }
  @media (min-width: 992px) {
    .testimony__wrapper {
      height: 450px;
      width: 865px; } }

.testimony__card {
  background-color: #2b2b2b;
  color: #fff;
  position: relative;
  margin: -2.1rem 1.25rem 1.25rem;
  padding: 1.25rem;
  z-index: 2; }
  @media (min-width: 992px) {
    .testimony__card {
      padding: 3.75rem 3.333rem;
      width: 640px;
      margin: 0;
      margin-top: 45px;
      margin-left: -175px; } }

.testimony__content {
  position: relative;
  padding-left: 2.5rem;
  max-width: 700px; }
  .testimony__content::before {
    content: '';
    width: 15px;
    background-color: var(--main-color);
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0; }
    @media (min-width: 1200px) {
      .testimony__content::before {
        width: 30px; } }
  @media (min-width: 1200px) {
    .testimony__content {
      padding-left: 3.333rem;
      max-width: 456px; } }

.testimony__text {
  font-size: 1.16667rem;
  font-family: "Merriweather", serif;
  color: #fff;
  font-weight: 400;
  margin-bottom: 0;
  line-height: 1.6; }
  @media (min-width: 768px) {
    .testimony__text {
      font-size: 1rem; } }
  @media (min-width: 992px) {
    .testimony__text {
      font-size: 1.75rem; } }
  @media (min-width: 992px) and (min-width: 768px) {
    .testimony__text {
      font-size: 1.5rem; } }

.testimony__info {
  margin-top: 1.667rem; }
  .testimony__info .formative-route-link {
    text-decoration: underline; }

.testimony-name {
  font-size: 1.33333rem;
  color: #fff;
  font-weight: 700;
  display: block; }
  @media (min-width: 768px) {
    .testimony-name {
      font-size: 1.14286rem; } }
  @media (min-width: 992px) {
    .testimony-name {
      font-size: 1.75rem; } }
  @media (min-width: 992px) and (min-width: 768px) {
    .testimony-name {
      font-size: 1.5rem; } }

.testimony-studies {
  font-size: 1rem;
  font-family: "Merriweather", serif;
  color: #fff;
  font-weight: 400;
  display: block; }
  @media (min-width: 768px) {
    .testimony-studies {
      font-size: 0.85714rem; } }
  @media (min-width: 992px) {
    .testimony-studies {
      font-size: 1.33333rem; } }
  @media (min-width: 992px) and (min-width: 768px) {
    .testimony-studies {
      font-size: 1.14286rem; } }

.featured-message .container {
  max-width: 795px;
  position: relative;
  padding: 75px 1rem;
  z-index: 4;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%; }

.featured-message {
  position: relative;
  overflow: hidden;
  min-height: 308px; }
  @media (min-width: 768px) {
    .featured-message {
      height: 476px; } }

.featured-message img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  position: absolute;
  bottom: 0; }

.featured-message::before {
  content: '';
  background-color: #2b2b2b;
  opacity: .8;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 2; }

.featured-message__text {
  font-size: 1rem;
  text-transform: uppercase;
  text-align: center;
  font-weight: 600;
  line-height: 1.9;
  color: #fff;
  text-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25); }
  @media (min-width: 768px) {
    .featured-message__text {
      font-size: 0.85714rem; } }
  @media (min-width: 768px) {
    .featured-message__text {
      font-size: 1.5rem; } }
  @media (min-width: 768px) and (min-width: 768px) {
    .featured-message__text {
      font-size: 1.28571rem; } }

.site-footer--routes {
  position: relative; }
  .site-footer--routes::after {
    top: 0;
    bottom: 0;
    padding-top: 0;
    right: -1px;
    width: calc(100% + 2px);
    left: 0; }
  .site-footer--routes .container {
    max-width: 1380px; }
  .site-footer--routes .logo-duoc {
    -webkit-filter: none;
            filter: none; }
  .site-footer--routes .site-footer__wrapper {
    flex-direction: column-reverse; }
    @media (min-width: 768px) {
      .site-footer--routes .site-footer__wrapper {
        flex-direction: row; } }
  @media (max-width: 991.98px) {
    .site-footer--routes {
      display: none; } }

.site-footer__rrss {
  list-style: none;
  padding-left: 0;
  text-align: center;
  margin-bottom: 50px; }
  @media (min-width: 768px) {
    .site-footer__rrss {
      margin-bottom: 0; } }

.site-footer__rrss-label {
  font-size: 1.16667rem;
  font-weight: 900;
  text-transform: uppercase;
  padding-right: 0;
  display: block;
  padding-bottom: 1rem; }
  @media (min-width: 768px) {
    .site-footer__rrss-label {
      font-size: 1rem; } }
  @media (min-width: 768px) {
    .site-footer__rrss-label {
      padding-right: 25px;
      display: inline-block;
      vertical-align: middle;
      padding-bottom: 0; } }

.site-footer__rrss-icon {
  display: inline-block;
  vertical-align: middle; }
  .site-footer__rrss-icon [class^="svg-"] {
    width: 30px;
    height: 30px;
    fill: #000; }
    @media (min-width: 768px) {
      .site-footer__rrss-icon [class^="svg-"] {
        width: 40px;
        height: 40px; } }
  .site-footer__rrss-icon + .site-footer__rrss-icon {
    padding-left: 1rem; }

.footer-two {
  position: relative; }

.program-summary {
  position: relative;
  padding-top: 4.5rem;
  padding-bottom: 4.5rem;
  background-color: #fafafa;
  overflow-x: hidden; }
  @media (min-width: 1200px) {
    .program-summary {
      padding-top: 10rem; } }
  .program-summary .container {
    position: relative;
    z-index: 10; }
  .program-summary::before {
    position: absolute;
    width: 120%;
    top: 0;
    left: -20px;
    right: 0;
    height: 80%;
    background-color: var(--main-color);
    -webkit-transform: rotate(0.85deg);
            transform: rotate(0.85deg);
    content: ''; }
  @media (min-width: 768px) {
    .program-summary .list-summary {
      display: flex; } }

.site-header--corporative + .program-summary {
  padding-top: 8.5rem; }
  @media (min-width: 1200px) {
    .site-header--corporative + .program-summary {
      padding-top: 10rem; } }

@media (min-width: 768px) {
  .program-summary__parts {
    display: grid;
    grid-template-columns: 1.5fr 1fr;
    gap: 22px; } }

.program-summary__parts__base {
  width: 100%; }

.program-summary__parts__next {
  width: 100%;
  margin-top: 2.5rem; }

.program-link-to-content {
  position: relative;
  display: block;
  max-width: 300px;
  margin: 2.5rem auto;
  padding-bottom: 1rem;
  text-align: center; }
  .program-link-to-content .svg-arrow-down-dims {
    position: absolute;
    width: 14px;
    height: 14px;
    bottom: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    fill: var(--main-color); }

@media (max-width: 767.98px) {
  .program-summary__footer {
    display: none; } }

.program-summary__footer-title {
  margin-top: 2.5rem; }

.program-summary__breadcrumb {
  list-style: none;
  padding-left: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 1.5rem; }
  .program-summary__breadcrumb li {
    letter-spacing: .3px; }
  .program-summary__breadcrumb a {
    text-decoration: underline;
    text-underline-offset: .2rem; }
  .program-summary__breadcrumb li + li::before {
    content: "/";
    margin: .5rem;
    opacity: .9; }

.program-section {
  background-color: #fff;
  margin-bottom: 8px;
  padding: 1.5rem 25px 2rem 25px;
  box-shadow: 0 5px 10px 0 rgba(0, 0, 0, 0.03); }
  @media (min-width: 768px) {
    .program-section {
      padding-left: 2.5rem;
      padding-right: 2.5rem; } }
  .program-section *:last-child {
    margin-bottom: 0; }

.program-section--featured {
  position: relative;
  padding: 25px;
  margin-bottom: 2rem; }
  .program-section--featured::before, .program-section--featured::after {
    --border-width: 8px;
    position: absolute;
    width: calc( var(--border-width) * 2);
    top: calc( var(--border-width) / -2);
    bottom: calc( var(--border-width) / -2);
    border-top: var(--border-width) solid #2b2b2b;
    border-bottom: var(--border-width) solid #2b2b2b;
    content: ''; }
    @media (min-width: 768px) {
      .program-section--featured::before, .program-section--featured::after {
        --border-width: 12px; } }
  .program-section--featured::before {
    left: calc( var(--border-width) / -2);
    border-left: var(--border-width) solid #2b2b2b; }
  .program-section--featured::after {
    right: calc( var(--border-width) / -2);
    border-right: var(--border-width) solid #2b2b2b; }
  @media (min-width: 768px) {
    .program-section--featured {
      padding: 50px;
      margin-bottom: 0; }
      .program-section--featured .program-section__header p {
        max-width: 90ch; } }
  .program-section--featured .program-section__description:last-child {
    font-weight: 900; }
  .program-section--featured + .program-section {
    margin-top: 8px; }

@media (max-width: 991.98px) {
  .program-section__row .program-section__col {
    padding-bottom: 2rem; } }

@media (min-width: 992px) {
  .program-section__row {
    display: flex;
    flex-wrap: wrap;
    margin-right: -25px;
    margin-left: -25px;
    padding-bottom: 2rem; }
    .program-section__row .program-section__col {
      position: relative;
      width: 100%;
      padding-right: 25px;
      padding-left: 25px;
      flex: 0 0 100%;
      max-width: 100%; }
      .program-section__row .program-section__col + .program-section__col {
        flex: 0 0 54.16667%;
        max-width: 54.16667%; } }

.program-section--single {
  position: relative;
  display: flex;
  flex-direction: column;
  margin-top: 2rem;
  padding: 25px; }
  .program-section--single::before, .program-section--single::after {
    --border-width: 8px;
    position: absolute;
    width: calc( var(--border-width) * 2);
    top: calc( var(--border-width) / -2);
    bottom: calc( var(--border-width) / -2);
    border-top: var(--border-width) solid #2b2b2b;
    border-bottom: var(--border-width) solid #2b2b2b;
    content: ''; }
    @media (min-width: 768px) {
      .program-section--single::before, .program-section--single::after {
        --border-width: 12px; } }
  .program-section--single::before {
    left: calc( var(--border-width) / -2);
    border-left: var(--border-width) solid #2b2b2b; }
  .program-section--single::after {
    right: calc( var(--border-width) / -2);
    border-right: var(--border-width) solid #2b2b2b; }
  .program-section--single .btn-download {
    display: flex;
    align-self: flex-start;
    margin-top: 2rem; }
  @media (min-width: 768px) {
    .program-section--single {
      flex-direction: row;
      padding: 50px; } }
  .program-section--single .program-section__header {
    margin-right: 50px; }
    @media (min-width: 992px) {
      .program-section--single .program-section__header {
        width: 65%; } }
    .program-section--single .program-section__header a {
      color: #9f9f9f;
      font-weight: 900; }
  .program-section--single ul {
    padding-left: 1rem; }

.program-section__title-anexos {
  margin-top: 2rem; }

.program-section--single .program-section__anexos {
  padding-left: 0; }
  .program-section--single .program-section__anexos > li {
    position: relative;
    margin-bottom: 0.5rem;
    margin-left: 0;
    padding-left: 1.125rem;
    font-weight: bold;
    line-height: 1.33; }
    .program-section--single .program-section__anexos > li a {
      color: #9f9f9f; }
      .program-section--single .program-section__anexos > li a:hover {
        color: var(--main-color);
        text-decoration: none; }
    .program-section--single .program-section__anexos > li::before {
      content: '';
      position: absolute;
      display: block;
      width: 5px;
      height: 5px;
      top: 50%;
      left: 2px;
      margin-top: -3px;
      background-color: var(--main-color);
      border-radius: 5px; }

.program-section__duration {
  display: block;
  padding-bottom: 0.5rem; }

.program-section__title {
  margin-bottom: 1rem; }
  .program-section--featured .program-section__title,
  .program-section--single .program-section__title {
    margin-bottom: 1.5rem; }

.program-section__readarea {
  max-width: 100ch; }

.program-section__description {
  margin-bottom: 1.5rem; }
  .program-section__description a {
    color: #005d9c; }

.program-section__parent {
  font-size: 1.16667rem;
  font-weight: 400;
  text-transform: uppercase; }
  @media (min-width: 768px) {
    .program-section__parent {
      font-size: 1rem; } }

.program-section .list-certificates {
  margin-left: 0; }
  .program-section .list-certificates > li a {
    color: #343a40;
    font-weight: 400;
    text-decoration: underline; }
    .program-section .list-certificates > li a:hover {
      text-decoration: underline; }

.btn-download {
  display: flex;
  align-items: center;
  padding: 1rem 1.5rem;
  white-space: nowrap;
  background-color: #fafafa;
  border: 2px solid #efefef;
  color: #005d9c;
  max-width: 270px;
  width: 100%;
  justify-content: space-between; }
  .btn-download .svg-arrow-down-dims {
    width: 25px;
    height: 25px;
    fill: var(--main-color);
    margin-left: 10px; }
    @media (min-width: 768px) {
      .btn-download .svg-arrow-down-dims {
        width: 30px;
        height: 30px; } }

@media (min-width: 768px) {
  .program-section--articulation {
    display: flex;
    justify-content: space-between; } }

.program-section--articulation .program-section__download .btn-download {
  min-width: 200px;
  margin: 1.5rem 1.5rem 0 0; }
  @media (min-width: 768px) {
    .program-section--articulation .program-section__download .btn-download {
      min-width: 270px;
      margin: 1rem 1.5rem 0 1.5rem; } }

.program-section--articulation .program-section__aside .list-certificates {
  flex-direction: column;
  align-items: flex-start; }
  .program-section--articulation .program-section__aside .list-certificates li {
    flex-basis: 100%;
    max-width: 100%; }

@media (min-width: 992px) {
  .program-section--step-middle {
    display: flex;
    justify-content: space-between; } }

.program-section--step-middle .program-section__download .btn-download {
  min-width: 200px;
  margin: 1.5rem 1.5rem 0 0; }
  @media (min-width: 992px) {
    .program-section--step-middle .program-section__download .btn-download {
      min-width: 270px;
      margin: 1rem 1.5rem 0 1.5rem; } }

.progress-indicator-wrapper {
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  padding-top: 0.5rem;
  padding-bottom: 2rem;
  background-color: #fafafa;
  box-shadow: 0 5px 5px rgba(43, 43, 43, 0.25);
  transition: all 0.2s ease-in-out;
  z-index: 1040; }
  @media (max-width: 767.98px) {
    .progress-indicator-wrapper {
      display: none; } }
  .progress-indicator-wrapper.progress-indicator-wrapper--active {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem; }
  .progress-indicator-wrapper .container {
    height: 7rem; }
  .site-header + .progress-indicator-wrapper {
    background-image: linear-gradient(to bottom, #efefef 50%, #fff 100%);
    background-repeat: repeat-x;
    position: relative;
    padding-top: 5rem;
    padding-bottom: 1rem;
    z-index: 1; }

.progress-indicator {
  display: flex; }
  .progress-indicator.progress-indicator--salida-intermedia:not(.progress-indicator--menciones) {
    padding-bottom: 2rem; }

.progress-step {
  --progress: 0;
  position: relative;
  display: flex;
  flex-direction: column;
  flex-basis: 15%;
  justify-content: center;
  padding-top: 2rem; }
  .progress-step.progress-step--labels {
    flex-basis: 40%; }
    @media (max-width: 991.98px) {
      .progress-step.progress-step--labels {
        padding-right: 0; } }

.progress-step--middle {
  flex-basis: 100px; }
  .progress-indicator--menciones .progress-step--middle .progress-road__line--mencion {
    top: 0px;
    -webkit-transform: rotate(-17deg);
            transform: rotate(-17deg); }
  .progress-indicator--2026 .progress-step--middle .progress-road__line--especialidad {
    top: 23px;
    -webkit-transform: rotate(24deg);
            transform: rotate(24deg); }
  .progress-indicator--menciones .progress-step--middle .progress-road__line + .progress-road__line--mencion {
    top: 100%;
    -webkit-transform: rotate(17deg);
            transform: rotate(17deg); }
  .progress-indicator--salida-intermedia:not(.progress-indicator--menciones) .progress-step--middle .progress-road__line--salida-intermedia {
    top: calc(100% + 5px);
    -webkit-transform: rotate(24deg);
            transform: rotate(24deg); }
  .progress-indicator--salida-intermedia.progress-indicator--articulation .progress-step--middle .progress-road__line--salida-intermedia {
    top: calc(100% + 4px);
    -webkit-transform: rotate(18deg);
            transform: rotate(18deg); }

.progress-step--extra .progress-step__semester + .progress-road {
  margin-bottom: 20px; }

.progress-step--middle + .progress-step--extra .progress-step__semester + .progress-road {
  margin-bottom: 0; }

.progress-step__semester {
  font-size: 1rem;
  position: absolute;
  width: 100%;
  top: 0;
  left: calc(( 50% - 6px) * -1);
  font-family: "Lato", sans-serif;
  font-weight: 900;
  text-align: center;
  color: #9f9f9f;
  transition: all 0.2s ease-in-out; }
  @media (min-width: 768px) {
    .progress-step__semester {
      font-size: 0.85714rem; } }
  .progress-step--active .progress-step__semester {
    font-weight: 900;
    color: #000; }
    .progress-step--active .progress-step__semester:after {
      content: ' Semestre';
      text-transform: uppercase; }

.progress-indicator--bimestre .progress-step--active .progress-step__semester:after {
  content: ' Bimestre'; }

.progress-road {
  position: relative;
  display: flex;
  height: 20px;
  cursor: pointer; }
  body:not(.body--tiene-menciones) .progress-step--middle ~ .progress-step .progress-road {
    top: 10px; }
    body:not(.body--tiene-menciones) .progress-step--middle ~ .progress-step .progress-road ~ .progress-road {
      top: 20px; }
  .progress-road .progress-step--active + .progress-road__program-label {
    color: #000; }

.progress-step--middle + .progress-step--extra .progress-road--active.progress-road--last .progress-road__program-label, .progress-step--middle + .progress-step--extra .progress-step__semester + .progress-road + .progress-road--active.progress-road .progress-road__program-label {
  color: #000; }

.progress-step--middle + .progress-step--extra .progress-road--active.progress-road--last .progress-road__marker, .progress-step--middle + .progress-step--extra .progress-step__semester + .progress-road + .progress-road--active.progress-road .progress-road__marker {
  background-color: var(--main-color);
  border-color: var(--main-color);
  box-shadow: 0 0 0 3px var(--main-color); }

.progress-road__marker {
  position: absolute;
  display: block;
  width: 12px;
  height: 12px;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background-color: #fafafa;
  border: 1px solid #2b2b2b;
  border-radius: 100%;
  transition: all 0.2s ease-in-out;
  z-index: 1; }
  .progress-road__marker:hover, .progress-road__marker.active,
  .progress-step--active .progress-road--active .progress-road__marker,
  .progress-step--previous .progress-road--active .progress-road__marker,
  .progress-indicator--salida-intermedia:not(.progress-indicator--menciones) .progress-step--previous + .progress-step--middle .progress-road__marker,
  .progress-road__marker .progress-indicator--salida-intermedia:not(.progress-indicator--menciones) .progress-step--active,
  body.body--front-page .progress-indicator--salida-intermedia .progress-step.progress-step--previous .progress-road:not(.progress-road--last) .progress-road__marker {
    background-color: var(--main-color);
    border-color: var(--main-color);
    box-shadow: 0 0 0 3px var(--main-color); }
  .progress-step--middle .progress-road__marker {
    width: 6px;
    height: 6px;
    background-color: #2b2b2b; }
    .progress-step--middle .progress-road__marker:hover {
      background-color: var(--main-color); }
  body:not(.body--tiene-menciones) .progress-step--active .progress-step--active .progress-road__marker {
    background-color: var(--main-color);
    border-color: var(--main-color);
    box-shadow: 0 0 0 3px var(--main-color); }

.progress-road--active:before,
body:not(.body--tiene-menciones) .progress-road:before {
  content: '';
  position: absolute;
  width: 55px;
  height: 75px;
  left: -20px;
  bottom: -10px; }

.progress-step--extra .progress-road:before,
body:not(.body--tiene-menciones) .progress-step--middle + .progress-step .progress-road:before {
  content: '';
  position: absolute;
  width: 50px;
  height: 19px;
  left: -20px;
  top: 0; }

.progress-step--middle .progress-step--active .progress-road__marker {
  box-shadow: 0 0 0 1px var(--main-color); }

.progress-road__line {
  position: absolute;
  display: block;
  width: 100%;
  height: 1.1px;
  top: 10px;
  left: 2px;
  background-color: #d0d0d0; }
  .progress-road--last .progress-road__line, .progress-step--middle + .progress-step--extra .progress-step__semester + .progress-road + .progress-road .progress-road__line {
    display: none; }
  .progress-road__line::before {
    position: absolute;
    display: none;
    width: var(--progress);
    height: 5px;
    top: -2px;
    left: 0;
    background-color: var(--main-color);
    content: ''; }
  .progress-indicator--menciones .progress-step--middle .progress-road__line.progress-road__line--active::before,
  .progress-step--active:not(.progress-step--middle) .progress-road--active .progress-road__line::before,
  .body--front-page:not(.body--tiene-menciones) .progress-road--active .progress-road__line.progress-road__line--active::before,
  .progress-step--previous:not(.progress-step--middle) .progress-road--active .progress-road__line::before,
  body:not(.body--tiene-menciones) .progress-step--active:not(.progress-step--middle) .progress-step--active .progress-road__line::before,
  .body--front-page:not(.body--tiene-menciones) .progress-step--previous + .progress-step--middle .progress-road__line:not(.progress-road__line--salida-intermedia)::before {
    display: block; }
  .progress-step--previous:not(.progress-step--middle) .progress-road--active .progress-road__line::before,
  .body--tiene-menciones .progress-step--middle .progress-road__line.progress-road__line--active::before,
  .body--front-page:not(.body--tiene-menciones) .progress-step--previous .progress-road__line.progress-road__line--active::before,
  body:not(.body--tiene-menciones) .progress-step.progress-step--previous .progress-road .progress-road__line::before,
  .body--front-page:not(.body--tiene-menciones) .progress-step--previous + .progress-step--middle .progress-road__line:not(.progress-road__line--salida-intermedia)::before {
    --progress: 100%; }

.progress-road__program-label {
  font-size: 0.83333rem;
  display: flex;
  margin-left: 1.5rem;
  align-items: center;
  font-family: "Lato", sans-serif;
  font-weight: 900;
  line-height: 1.16;
  text-transform: uppercase;
  color: #9f9f9f;
  transition: all 0.2s ease-in-out; }
  @media (min-width: 768px) {
    .progress-road__program-label {
      font-size: 0.71429rem; } }

body.body--front-page .progress-step.progress-step--previous:not(.progress-step--middle) .progress-road .progress-road__line::before,
body.body--front-page .progress-step--middle.progress-step--previous .progress-road--active .progress-road__line:not(.progress-road__line--salida-intermedia)::before,
body.body--certificate .progress-indicator--salida-intermedia .progress-step .progress-road--active .progress-road__line.progress-road__line--salida-intermedia::before,
body.body--certificate .progress-indicator--salida-intermedia .progress-step:not(.progress-step--middle) .progress-road--active .progress-road__line::before {
  --progress: 100%;
  display: block; }

body.body--front-page .progress-step--active.progress-step--middle .progress-road__line:not(.progress-road__line--salida-intermedia)::before {
  display: block; }

body.body--certificate .progress-indicator--salida-intermedia .progress-step .progress-road--active .progress-road__marker {
  background-color: var(--main-color);
  border-color: var(--main-color);
  box-shadow: 0 0 0 3px var(--main-color); }

body:not(.body--tiene-menciones) .progress-indicator--articulation .progress-step--labels .progress-road--last + .progress-road--last .progress-road__marker, body:not(.body--tiene-menciones) .progress-indicator--articulation .progress-step--labels .progress-step--middle + .progress-step--extra .progress-step__semester + .progress-road + .progress-road + .progress-road--last .progress-road__marker, .progress-step--middle + .progress-step--extra body:not(.body--tiene-menciones) .progress-indicator--articulation .progress-step--labels .progress-step__semester + .progress-road + .progress-road + .progress-road--last .progress-road__marker, body:not(.body--tiene-menciones) .progress-indicator--articulation .progress-step--labels .progress-step--middle + .progress-step--extra .progress-step__semester + .progress-road.progress-road--last + .progress-road .progress-road__marker, .progress-step--middle + .progress-step--extra body:not(.body--tiene-menciones) .progress-indicator--articulation .progress-step--labels .progress-step__semester + .progress-road.progress-road--last + .progress-road .progress-road__marker, body:not(.body--tiene-menciones) .progress-indicator--articulation .progress-step--labels .progress-step--middle + .progress-step--extra .progress-step__semester + .progress-step__semester.progress-road + .progress-road + .progress-road .progress-road__marker, .progress-step--middle + .progress-step--extra body:not(.body--tiene-menciones) .progress-indicator--articulation .progress-step--labels .progress-step__semester + .progress-step__semester.progress-road + .progress-road + .progress-road .progress-road__marker {
  background-color: transparent;
  border: 1px solid #2b2b2b;
  box-shadow: none; }
  body:not(.body--tiene-menciones) .progress-indicator--articulation .progress-step--labels .progress-road--last + .progress-road--last .progress-road__marker:hover, body:not(.body--tiene-menciones) .progress-indicator--articulation .progress-step--labels .progress-step--middle + .progress-step--extra .progress-step__semester + .progress-road + .progress-road + .progress-road--last .progress-road__marker:hover, .progress-step--middle + .progress-step--extra body:not(.body--tiene-menciones) .progress-indicator--articulation .progress-step--labels .progress-step__semester + .progress-road + .progress-road + .progress-road--last .progress-road__marker:hover, body:not(.body--tiene-menciones) .progress-indicator--articulation .progress-step--labels .progress-step--middle + .progress-step--extra .progress-step__semester + .progress-road.progress-road--last + .progress-road .progress-road__marker:hover, .progress-step--middle + .progress-step--extra body:not(.body--tiene-menciones) .progress-indicator--articulation .progress-step--labels .progress-step__semester + .progress-road.progress-road--last + .progress-road .progress-road__marker:hover, body:not(.body--tiene-menciones) .progress-indicator--articulation .progress-step--labels .progress-step--middle + .progress-step--extra .progress-step__semester + .progress-step__semester.progress-road + .progress-road + .progress-road .progress-road__marker:hover, .progress-step--middle + .progress-step--extra body:not(.body--tiene-menciones) .progress-indicator--articulation .progress-step--labels .progress-step__semester + .progress-step__semester.progress-road + .progress-road + .progress-road .progress-road__marker:hover {
    background-color: var(--main-color);
    border-color: var(--main-color);
    box-shadow: 0 0 0 3px var(--main-color); }

.semester {
  position: relative; }
  .semesters > .semester:nth-child(1) {
    z-index: 10; }
  .semesters > .semester:nth-child(2) {
    z-index: 9; }
  .semesters > .semester:nth-child(3) {
    z-index: 8; }
  .semesters > .semester:nth-child(4) {
    z-index: 7; }
  .semesters > .semester:nth-child(5) {
    z-index: 6; }
  .semesters > .semester:nth-child(6) {
    z-index: 5; }
  .semesters > .semester:nth-child(7) {
    z-index: 4; }
  .semesters > .semester:nth-child(8) {
    z-index: 3; }
  .semesters > .semester:nth-child(9) {
    z-index: 2; }
  .semesters > .semester:nth-child(10) {
    z-index: 1; }
  .semester::before {
    position: relative;
    display: block;
    visibility: hidden;
    margin-top: -130px;
    height: 130px;
    content: ''; }

.semester__header {
  padding-top: 2rem;
  padding-bottom: 1.75rem;
  background-color: #e6f2a6;
  border-top: 5px solid #fff;
  border-bottom: 5px solid #fff; }
  .semester__header:first-child {
    border-top: none; }
  @media (max-width: 767.98px) {
    .semester__header {
      position: -webkit-sticky;
      position: sticky;
      top: 0;
      box-shadow: 0 4px 4px rgba(43, 43, 43, 0.25);
      z-index: 100;
      border-top: none;
      border-bottom: none; } }

.semester__title {
  margin-bottom: 0; }

.subject {
  border-bottom: 5px solid #efefef;
  transition: all 0.2s ease-in-out; }
  .subject:last-child {
    border-bottom-color: #fff; }
  .semesters .semester:last-child .subject:last-child {
    padding-bottom: 0.5rem; }
  .subject:focus-within {
    background-color: rgba(239, 239, 239, 0.5); }
  .subject--expanded {
    background-color: rgba(239, 239, 239, 0.5); }
    @media (max-width: 767.98px) {
      .subject--expanded .subject__name {
        padding-right: 4rem; } }
    .subject--expanded .subject__close {
      display: block; }
  .subject--fadeout {
    opacity: 0;
    height: 0;
    border: none;
    overflow: hidden; }

.subject--acbd {
  position: relative;
  padding-top: 6rem;
  padding-bottom: 6rem;
  background-color: #fafafa;
  border-bottom-color: #fff; }
  .subject--acbd::before {
    position: absolute;
    width: .75vw;
    height: 100%;
    top: 0;
    left: 0;
    background-image: linear-gradient(to bottom, #1F3492 25%, #F18B00 25%, #F18B00 50%, #EAC92D 50%, #EAC92D 75%, #16A681 75%);
    content: ''; }

.subject__header {
  position: relative;
  display: block;
  padding-top: 2rem;
  padding-bottom: 1.5rem;
  padding-left: 2.25rem; }

.subject__body {
  display: none;
  padding-left: 2.25rem;
  max-height: 0;
  overflow: hidden;
  transition: all 1s ease-out;
  pointer-events: none; }
  .subject--expanded .subject__body {
    display: block;
    max-height: none;
    overflow: unset;
    pointer-events: auto; }
    @media (min-width: 768px) {
      .subject--expanded .subject__body {
        display: flex;
        flex-wrap: wrap;
        margin-right: -25px;
        margin-left: -25px; } }

.subject__content {
  padding-bottom: 3.5rem; }
  @media (min-width: 768px) {
    .subject__content {
      position: relative;
      width: 100%;
      padding-right: 25px;
      padding-left: 25px;
      flex: 0 0 58.33333%;
      max-width: 58.33333%; } }
  @media (min-width: 992px) {
    .subject__content {
      flex: 0 0 66.66667%;
      max-width: 66.66667%; } }
  .subject__content ul {
    padding-left: 1rem; }

.subject__aside {
  padding-bottom: 3.5rem; }
  @media (min-width: 768px) {
    .subject__aside {
      position: relative;
      width: 100%;
      padding-right: 25px;
      padding-left: 25px;
      flex: 0 0 41.66667%;
      max-width: 41.66667%; } }
  @media (min-width: 992px) {
    .subject__aside {
      flex: 0 0 33.33333%;
      max-width: 33.33333%; } }

.subject__name {
  transition: color .3s ease-out; }
  .subject__name > a {
    transition: color .15s ease-out; }
    .subject__name > a:hover {
      text-decoration: none;
      color: var(--main-color); }
  @media (min-width: 768px) {
    .subject__name {
      display: inline-block;
      margin-right: 1rem; }
      .subject--no-description .subject__name {
        margin-bottom: 0; } }

.subject__link {
  font-size: 1rem;
  color: #005d9c;
  font-weight: 900; }
  @media (min-width: 768px) {
    .subject__link {
      font-size: 0.85714rem; } }
  .subject__link:hover {
    color: #005d9c; }
  @media (min-width: 768px) {
    .subject__link {
      font-size: 1.16667rem;
      color: #005d9c; } }
  @media (min-width: 768px) and (min-width: 768px) {
    .subject__link {
      font-size: 1rem; } }

.subject__chevron {
  position: absolute;
  display: flex;
  width: 20px;
  height: 20px;
  top: 2.125rem;
  left: 0;
  fill: var(--main-color); }
  @media (min-width: 768px) {
    .subject__chevron {
      top: 50%;
      margin-top: -9.5px; } }

.subject__close {
  font-size: 1.16667rem;
  color: #005d9c;
  margin-left: auto;
  position: absolute;
  right: 0;
  top: 2rem;
  display: none; }
  @media (min-width: 768px) {
    .subject__close {
      font-size: 1rem; } }

.subject__subtitle {
  margin-bottom: 0.65rem; }

.subject__description {
  font-size: 1.25rem; }
  @media (min-width: 768px) {
    .subject__description {
      font-size: 1.07143rem; } }
  @media (max-width: 767.98px) {
    .subject__description {
      margin-bottom: 2rem; } }
  @media (min-width: 768px) {
    .subject__description {
      position: relative;
      width: 100%;
      padding-right: 25px;
      padding-left: 25px;
      flex: 0 0 45.83333%;
      max-width: 45.83333%; } }
  .subject__description p {
    margin-bottom: 2rem; }
  .subject__description *:last-child {
    margin-bottom: 0; }
  .subject__description > ul {
    padding-left: 1.5rem; }
    .subject__description > ul > li {
      margin-bottom: 0.33333rem;
      line-height: 1.45; }

.subject__skills {
  justify-self: flex-start;
  margin-right: auto; }
  @media (max-width: 767.98px) {
    .subject__skills {
      margin-bottom: 2rem; } }
  @media (min-width: 768px) {
    .subject__skills {
      position: relative;
      width: 100%;
      padding-right: 25px;
      padding-left: 25px;
      flex: 0 0 20.83333%;
      max-width: 20.83333%; } }
  .subject__skills .subject__subtitle {
    font-size: 1rem;
    display: block;
    font-weight: bold;
    line-height: 1.33;
    letter-spacing: .5px;
    text-transform: none; }
    @media (min-width: 768px) {
      .subject__skills .subject__subtitle {
        font-size: 0.85714rem; } }

.subject__aside h3 a {
  font-size: 1.16667rem;
  color: #005d9c;
  font-weight: 400;
  text-transform: none;
  margin-left: 1rem;
  font-weight: bold; }
  @media (min-width: 768px) {
    .subject__aside h3 a {
      font-size: 1rem; } }

.subject__aside .list-skills {
  padding-left: 0; }
  .subject__aside .list-skills [class^="svg-"] {
    width: 25px;
    height: 25px; }
  .subject__aside .list-skills li {
    grid-template-columns: 2.2rem auto; }

.subject__aside .list-certificates,
.subject__aside .list-training-line {
  padding-left: 0; }
  .subject__aside .list-certificates li,
  .subject__aside .list-training-line li {
    padding-left: 2rem; }
    .subject__aside .list-certificates li:before,
    .subject__aside .list-training-line li:before {
      content: none; }
    .subject__aside .list-certificates li .svg-check-dims,
    .subject__aside .list-training-line li .svg-check-dims {
      display: block;
      width: 20px;
      height: 20px;
      fill: var(--main-color);
      position: absolute;
      left: 0;
      margin-top: 0; }

.subject__certificates .list-certificates + .subject__subtitle {
  margin-top: 2rem; }

@media (max-width: 767.98px) {
  .subject__certificates,
  .subject__type-skills {
    margin-bottom: 2rem; } }

@media (min-width: 768px) {
  .subject__certificates,
  .subject__type-skills {
    position: relative;
    width: 100%;
    padding-right: 25px;
    padding-left: 25px;
    flex: 0 0 33.33333%;
    max-width: 33.33333%; } }

.subject__certificates ul,
.subject__type-skills ul {
  margin-bottom: 0; }

.subject__behance {
  display: grid;
  max-width: 280px;
  grid-template-columns: 3rem 1fr;
  gap: .75rem;
  font-weight: bold; }
  .subject__behance:not(:first-child) {
    margin-top: 3rem; }
  .subject__behance svg {
    grid-column: 1/2;
    width: 3rem;
    height: 3rem;
    margin-right: .5rem; }

.next-step {
  position: relative;
  color: #fff; }
  .next-step::before {
    display: block;
    visibility: hidden;
    margin-top: -130px;
    height: 130px;
    content: ''; }
  .next-step .container {
    position: relative;
    padding-top: 4rem;
    padding-bottom: 100px;
    z-index: 1; }
    @media (min-width: 768px) {
      .next-step .container .program-options:only-child {
        margin-top: 2rem;
        margin-bottom: 0; } }
  .next-step:not(.next-step--subject) .container > h3 {
    font-size: 1.75rem;
    font-weight: 400;
    text-transform: none;
    text-align: center;
    margin-bottom: 2.5rem; }
    @media (min-width: 768px) {
      .next-step:not(.next-step--subject) .container > h3 {
        font-size: 1.5rem; } }
    @media (min-width: 768px) {
      .next-step:not(.next-step--subject) .container > h3 {
        margin-bottom: 50px; } }
  .next-step:not(.next-step--subject) .container > p {
    margin-bottom: 2rem; }
    @media (min-width: 768px) {
      .next-step:not(.next-step--subject) .container > p {
        width: 60%;
        margin-bottom: 2.5rem; } }
  .semesters .next-step .container {
    padding-top: 150px; }
  .next-step.next-step--subject .container {
    padding-top: 150px;
    padding-bottom: 200px;
    text-align: right; }

.next-step__media {
  position: absolute;
  width: 100%;
  height: calc(100% - 130px);
  overflow: hidden; }

.next-step__image {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background-color: #2b2b2b;
  background-image: var(--main-image);
  background-blend-mode: overlay;
  background-size: cover;
  -webkit-filter: blur(2px);
          filter: blur(2px);
  content: '';
  -webkit-transform: scale(1.05);
  transform: scale(1.05); }

.next-step__image::after {
  background-image: linear-gradient(to bottom, transparent 0%, #2b2b2b 100%);
  background-repeat: repeat-x;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  content: ''; }

.next-step--download {
  overflow: hidden;
  background-color: #efefef;
  padding: 50px 0; }

.program-options {
  margin-bottom: 2rem; }
  @media (min-width: 992px) {
    .program-options {
      margin-bottom: 3.5rem;
      display: flex;
      flex-wrap: wrap;
      margin-right: -25px;
      margin-left: -25px;
      justify-content: center; } }

.program-option-wrapper {
  margin-bottom: 5px; }
  @media (min-width: 992px) {
    .program-option-wrapper {
      position: relative;
      width: 100%;
      padding-right: 25px;
      padding-left: 25px;
      flex: 0 0 50%;
      max-width: 50%; } }

.program-option {
  display: flex;
  flex-direction: column;
  width: 100%;
  min-height: 100%;
  padding: 1.5rem;
  text-align: left;
  background-color: rgba(255, 255, 255, 0.9);
  transition: all 0.2s ease-in-out; }
  .program-option:hover {
    text-decoration: none;
    background-color: #fff; }
    .program-option:hover .program-option__title {
      text-decoration: underline; }
  @media (min-width: 768px) {
    .program-option {
      padding: 50px; } }

.program-option__label {
  display: block;
  margin-bottom: 0.5rem; }

.program-option__title {
  position: relative;
  padding-right: 4rem; }
  .program-option__title [class^="svg-arrow-"] {
    position: absolute;
    width: 30px;
    height: 30px;
    top: 50%;
    right: 0;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    fill: var(--main-color); }
    @media (min-width: 768px) {
      .program-option__title [class^="svg-arrow-"] {
        width: 45px;
        height: 45px; } }

.program-option--exit {
  width: 100%;
  padding: 0;
  color: #fff;
  background-color: transparent; }
  .program-option--exit .program-option__title {
    display: inline-block;
    padding-left: 2.5rem;
    padding-right: 0; }
    @media (min-width: 768px) {
      .program-option--exit .program-option__title {
        padding-right: 1rem;
        padding-left: 3rem; } }
  .program-option--exit:hover {
    text-decoration: none;
    color: inherit;
    background-color: transparent; }
  @media (min-width: 768px) {
    .program-option--exit {
      width: -webkit-max-content;
      width: -moz-max-content;
      width: max-content;
      margin: 0 auto;
      display: block; } }
  .next-step--subject .program-option--exit {
    align-items: flex-end;
    margin-right: 0; }
  .program-option--exit .svg-arrow-right-dims {
    width: 20px;
    height: 20px;
    right: initial;
    left: 0;
    top: 0;
    -webkit-transform: none;
            transform: none; }
    @media (min-width: 768px) {
      .program-option--exit .svg-arrow-right-dims {
        width: 30px;
        height: 30px; } }
  .program-option--exit .program-option__tag {
    font-size: 0.83333rem;
    font-weight: 900;
    color: #2b2b2b;
    background-color: var(--main-color);
    vertical-align: middle;
    padding: 0.66667rem 0.66667rem;
    margin-left: 3rem;
    text-align: center;
    display: inline-block;
    max-width: 140px; }
    @media (min-width: 768px) {
      .program-option--exit .program-option__tag {
        font-size: 0.71429rem; } }
    .program-option--exit .program-option__tag:hover {
      text-decoration: none; }
    @media (min-width: 768px) {
      .program-option--exit .program-option__tag {
        margin-left: 0; } }

.program-options-download .program-options-download__access {
  display: block;
  padding: 1rem 0 1rem 50px;
  position: relative; }
  @media (min-width: 768px) {
    .program-options-download .program-options-download__access {
      padding: 1rem 0 1rem 75px; } }

.program-options-download .svg-arrow-down-dims {
  position: absolute;
  width: 30px;
  height: 30px;
  fill: var(--main-color);
  left: 0;
  top: 1rem;
  -webkit-transform: none;
          transform: none; }
  @media (min-width: 768px) {
    .program-options-download .svg-arrow-down-dims {
      width: 55px;
      height: 55px; } }

.program-options-download .program-options-download__label {
  font-size: 1.16667rem;
  display: block;
  padding-bottom: 0.5rem; }
  @media (min-width: 768px) {
    .program-options-download .program-options-download__label {
      font-size: 1rem; } }

.program-options-download .program-options-download__title {
  font-size: 1.5rem;
  font-weight: 900; }
  @media (min-width: 768px) {
    .program-options-download .program-options-download__title {
      font-size: 1.28571rem; } }

.subject-single {
  position: relative;
  z-index: 10;
  overflow-x: hidden; }
  .subject-single .container {
    position: relative; }
  @media (max-width: 767.98px) {
    .subject-single .return-link {
      margin-bottom: 3rem; } }
  @media (min-width: 768px) {
    .subject-single .return-link {
      position: absolute;
      top: 0;
      left: 25px; } }

.subject-single__header {
  position: relative;
  margin-bottom: 50px;
  padding-top: 2.5rem;
  padding-bottom: 2.5rem;
  border-bottom: 3px solid #fafafa; }
  .subject-single__header .container {
    display: flex;
    justify-content: space-between; }
    .subject-single__header .container .btn-bracket {
      margin-left: 2rem; }
  .site-header + .subject-single .subject-single__header {
    padding-top: 3.5rem;
    background-image: linear-gradient(to bottom, #efefef 50%, #fff 100%);
    background-repeat: repeat-x; }
    .site-header + .subject-single .subject-single__header::before {
      position: absolute;
      width: 120%;
      bottom: 80%;
      left: -20px;
      right: 0;
      height: 50px;
      background-color: #fff;
      -webkit-transform: rotate(0.85deg);
              transform: rotate(0.85deg);
      content: ''; }
  .subject-single--acbd .subject-single__header::before {
    position: absolute;
    width: 100%;
    height: 3px;
    bottom: 0;
    left: 0;
    background-image: linear-gradient(to right, #1F3492 25%, #F18B00 25%, #F18B00 50%, #EAC92D 50%, #EAC92D 75%, #16A681 75%);
    content: ''; }

.subject-single__name {
  margin-bottom: 0; }

.subject-single__body-wrapper {
  position: unset !important; }
  @media (min-width: 768px) {
    .subject-single__body-wrapper {
      position: relative;
      width: 100%;
      padding-right: 25px;
      padding-left: 25px;
      flex: 0 0 75%;
      max-width: 75%;
      margin-left: 25%; } }
  @media (min-width: 992px) {
    .subject-single__body-wrapper {
      flex: 0 0 58.33333%;
      max-width: 58.33333%; } }

.subject-single__prerrequisites {
  margin-bottom: 4rem;
  padding-top: 25px;
  padding-bottom: 25px;
  border: 3px solid #fafafa; }
  .subject-single__prerrequisites > ul {
    margin-bottom: 0; }
  .subject-single__prerrequisites > p {
    padding-left: 25px;
    padding-right: 25px; }
    .subject-single__prerrequisites > p + p {
      margin-top: 25px;
      padding-top: 25px;
      border-top: 3px solid #fafafa; }

.subject-single__acbd {
  background-image: linear-gradient(to bottom, #efefef 0%, #fff 100%);
  background-repeat: repeat-x;
  position: relative;
  padding-top: 50px;
  padding-bottom: 50px; }
  .subject-single__body-wrapper > .subject-single__acbd {
    margin-top: 100px; }
  .owl-carousel + .subject-single__acbd {
    margin-top: -50px;
    padding-top: 75px; }
  .subject-single__acbd .list-summary__label {
    display: inline-block;
    padding-bottom: 0.5rem; }
  .subject-single__acbd .list-skills {
    display: flex; }
    .subject-single__acbd .list-skills > li {
      margin-right: 1rem; }

@media (min-width: 768px) {
  .subject-single__acbd-wrapper {
    position: relative;
    width: 100%;
    padding-right: 25px;
    padding-left: 25px;
    flex: 0 0 75%;
    max-width: 75%;
    margin-left: 25%; } }

.subject-single__acbd-wrapper .subject-single__acbd__title {
  margin-bottom: 3rem; }

.subject-single__acbd-wrapper .list-summary {
  margin-bottom: 1.5rem; }

.subject-single__content {
  background-image: linear-gradient(to bottom, #efefef 0%, #fff 100%);
  background-repeat: repeat-x;
  position: relative;
  padding-top: 50px;
  padding-bottom: 50px; }

.optative-subjects {
  display: grid;
  width: 100%;
  gap: 1.5rem;
  margin-bottom: 50px; }
  @media (min-width: 768px) {
    .optative-subjects {
      margin-left: 25px;
      margin-right: 25px; } }
  .optative-subjects__header {
    position: -webkit-sticky;
    position: sticky;
    top: 0;
    background-color: #fafafa;
    border-bottom: 5px solid #efefef;
    z-index: 100; }
  .optative-subjects__header .container {
    display: grid;
    gap: 1rem;
    padding: 1rem;
    justify-content: flex-end;
    text-align: right; }
    @media (min-width: 768px) {
      .optative-subjects__header .container {
        grid-template-columns: auto auto;
        align-items: center;
        gap: 3rem;
        padding-bottom: 2rem; } }
  .optative-subjects__label-available {
    font-weight: 900;
    text-transform: uppercase; }
  .optative-subjects__title {
    margin-bottom: 0; }
  .optative-subjects__filter {
    position: relative; }
    .optative-subjects__filter label {
      padding-right: 1.5rem;
      font-weight: 700; }
    .optative-subjects__filter select {
      min-width: 200px; }
  .optative-subjects__items {
    display: grid;
    gap: 5px;
    max-height: 400px;
    overflow-y: auto; }
  .optative-subjects__empty {
    padding: 3.5rem 2rem;
    text-align: center;
    background-color: #fff; }
    .optative-subjects__empty p {
      margin-bottom: 0; }

.optative-subject {
  display: grid;
  gap: .5rem 1rem;
  align-items: center;
  padding-top: 1rem;
  padding-bottom: 1rem;
  background-color: #fff;
  border-left: 9px solid var(--main-color); }
  @media (max-width: 991.98px) {
    .optative-subject {
      padding-left: 1.5rem;
      padding-right: 1.5rem; } }
  @media (min-width: 768px) {
    .optative-subject {
      grid-template-columns: 1.5fr 1.25fr 1fr .75fr; }
      .optative-subject > div:first-child {
        padding-left: 1.5rem;
        padding-right: 2rem; }
      .optative-subject > div:last-child {
        padding-right: 2rem;
        text-align: right; }
      .optative-subject > div > a {
        font-weight: 700;
        color: #005d9c; } }
  .optative-subject__name {
    margin-bottom: 0; }

.optative-single {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 2.5rem; }
  @media (min-width: 768px) {
    .optative-single {
      grid-template-columns: 2.5fr 1fr; } }

.external-media {
  position: relative;
  padding-top: 75px;
  padding-bottom: 100px;
  text-align: center;
  background-color: #000; }
  .external-media .container {
    display: grid;
    gap: 25px; }
    @media (min-width: 576px) {
      .external-media .container {
        grid-template-columns: 1.5fr 1fr; } }
  .external-media--centered .container {
    max-width: 768px; }
  .external-media__title {
    font-size: 1.83333rem;
    margin-bottom: 1rem;
    color: #fff; }
    @media (min-width: 768px) {
      .external-media__title {
        font-size: 1.57143rem; } }
    @media (min-width: 576px) {
      .external-media__title {
        grid-column: 1/3; } }
  .external-media__youtube {
    width: 100%;
    height: 100%;
    min-height: 250px; }
    @media (min-width: 576px) {
      .external-media__youtube {
        grid-column: 1/2;
        min-height: unset; } }
    @media (min-width: 576px) {
      .external-media--centered .external-media__youtube {
        grid-column: 1/3;
        min-height: 350px; } }
  .external-media__behance {
    display: block;
    width: 100%;
    height: 100%;
    background-color: #000;
    transition: all 0.2s ease-in-out;
    font-family: "Lato", sans-serif;
    text-align: center;
    text-decoration: underline;
    text-underline-offset: .25rem;
    -webkit-text-decoration-color: var(--main-color);
            text-decoration-color: var(--main-color);
    color: #fff; }
    @media (min-width: 768px) {
      .external-media__behance {
        grid-column: 2/3; } }
    .external-media__behance:hover {
      background-color: rgba(0, 0, 0, 0.95); }
    .external-media__behance img {
      width: 100%;
      height: 100%;
      -o-object-fit: cover;
         object-fit: cover;
      -o-object-position: center left;
         object-position: center left; }
    .external-media__behance p {
      font-size: 1.75rem; }
      @media (min-width: 768px) {
        .external-media__behance p {
          font-size: 1.5rem; } }
      .external-media__behance p strong {
        font-weight: 700; }

/*# sourceMappingURL=maps/style.css.map */
