:root {
    --orika-red: #ed1c24;
    --orika-red-dark: #d71920;
    --orika-yellow: #ffce60;
    --orika-yellow-dark: #eeb638;
    --orika-ink: #2e2821;
    --orika-text: #626262;
    --orika-muted: #747474;
    --orika-footer: #014059;
    --orika-blue: #005f83;
    --orika-line: rgba(46, 40, 33, .14);
}

.site-error-page {
    align-items: stretch;
    background:
        linear-gradient(135deg, rgba(0, 77, 99, .93), rgba(2, 92, 117, .86)),
        url("../img/site/territorio-habitamos.webp") center / cover;
    color: #fff;
    display: grid;
    gap: 28px;
    grid-template-columns: minmax(0, 1fr) minmax(260px, 360px);
    min-height: calc(100vh - 170px);
    padding: clamp(42px, 8vw, 92px) clamp(18px, 7vw, 96px);
}

.site-error-page__content {
    align-self: center;
    max-width: 760px;
}

.site-error-page__kicker {
    color: #ffc845;
    display: inline-flex;
    font-size: .82rem;
    font-weight: 900;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.site-error-page__code {
    color: rgba(255, 255, 255, .22);
    font-family: "Arial Black", Impact, sans-serif;
    font-size: clamp(5rem, 14vw, 10rem);
    line-height: .85;
    margin: 18px 0 0;
}

.site-error-page h1 {
    color: #fff;
    font-family: "Arial Black", Impact, sans-serif;
    font-size: clamp(2.4rem, 6vw, 5rem);
    line-height: .95;
    margin: 0 0 20px;
    max-width: 820px;
}

.site-error-page p {
    color: rgba(255, 255, 255, .9);
    font-size: clamp(1rem, 2vw, 1.25rem);
    line-height: 1.55;
    margin: 0;
    max-width: 680px;
}

.site-error-page__actions {
    display: flex;
    margin-top: 30px;
}

.site-error-page__button {
    align-items: center;
    background: #ffc845;
    border-radius: 8px;
    color: #161616;
    display: inline-flex;
    font-weight: 900;
    min-height: 52px;
    padding: 0 24px;
    text-decoration: none;
}

.site-error-page__button:hover {
    background: #ffd86b;
    color: #161616;
}

.site-error-page__panel {
    align-self: end;
    background: rgba(255, 255, 255, .94);
    border-left: 4px solid #ffc845;
    border-radius: 8px;
    box-shadow: 0 22px 50px rgba(0, 0, 0, .22);
    color: #24313a;
    display: grid;
    gap: 8px;
    padding: 22px;
}

.site-error-page__panel strong {
    color: #ed1c24;
    font-family: "Arial Black", Impact, sans-serif;
    font-size: 1.05rem;
    text-transform: uppercase;
}

.site-error-page__panel span,
.site-error-page__panel small {
    color: #425261;
}

.maritorio-hero .home-hero__content {
    max-width: 860px;
}

.maritorio-hero {
    min-height: clamp(560px, 76vh, 760px);
}

.maritorio-hero::after {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0), #f6f9f8);
}

.maritorio-water-sequence {
    background:
        linear-gradient(180deg, rgba(0, 95, 131, .82), rgba(1, 64, 89, .9)),
        url("../img/site/maritorio-background.webp") center top / cover;
}

.maritorio-overview {
    color: #ffffff;
    padding: clamp(38px, 5vw, 62px) clamp(18px, 7vw, 86px) clamp(30px, 4vw, 52px);
}

.maritorio-overview__inner {
    margin: 0 auto;
    max-width: 1120px;
}

.maritorio-overview h2 {
    color: #ffffff;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(2.4rem, 4.6vw, 4rem);
    font-weight: 700;
    line-height: 1;
    margin: 0 0 12px;
    text-align: center;
}

.maritorio-overview p {
    color: rgba(255, 255, 255, .96);
    font-size: clamp(.98rem, 1.4vw, 1.08rem);
    font-weight: 600;
    line-height: 1.24;
    margin: 0 auto 28px;
    max-width: 1040px;
    text-align: justify;
}

.maritorio-overview__map {
    background: #d9eef4;
    border: 6px solid rgba(255, 255, 255, .9);
    box-shadow: 0 22px 48px rgba(1, 34, 50, .32);
    height: clamp(300px, 38vw, 420px);
    margin: 0 auto;
    max-width: 1040px;
    overflow: hidden;
    position: relative;
    width: 100%;
}

.maritorio-overview__fullscreen {
    background: transparent;
    border: 0;
    color: var(--orika-yellow);
    cursor: pointer;
    display: inline-flex;
    font-size: .95rem;
    font-weight: 800;
    margin-top: 15px;
    padding: 0;
    text-decoration: none;
}

.maritorio-overview__fullscreen:hover,
.maritorio-overview__fullscreen:focus {
    color: #ffffff;
    text-decoration: underline;
}

.maritorio-docs {
    color: #161616;
    padding: clamp(34px, 5vw, 58px) clamp(18px, 7vw, 86px) clamp(46px, 6vw, 78px);
}

.maritorio-docs__inner {
    margin: 0 auto;
    max-width: 1120px;
}

.maritorio-docs__copy {
    background: rgba(255, 255, 255, .7);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255, 255, 255, .48);
    border-radius: 8px;
    box-shadow: 0 18px 42px rgba(1, 34, 50, .18);
    margin: 0 auto 24px;
    max-width: 900px;
    padding: clamp(24px, 4vw, 38px);
    text-align: center;
}

.maritorio-docs__copy > span {
    color: var(--orika-red);
    display: inline-flex;
    font-size: .82rem;
    font-weight: 900;
    letter-spacing: .03em;
    margin-bottom: 10px;
    text-transform: uppercase;
}

.maritorio-docs h2 {
    color: #161616;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(2.1rem, 4vw, 3.5rem);
    font-weight: 700;
    line-height: 1;
    margin: 0 0 16px;
}

.maritorio-docs__copy p {
    color: #26343b;
    font-size: clamp(.98rem, 1.35vw, 1.08rem);
    font-weight: 600;
    line-height: 1.48;
    margin: 0;
}

.maritorio-docs__timeline {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin: 0 auto 24px;
    max-width: 900px;
}

.maritorio-docs__timeline span {
    background: rgba(1, 64, 89, .88);
    border-left: 4px solid var(--orika-yellow);
    border-radius: 8px;
    box-shadow: 0 14px 28px rgba(1, 34, 50, .18);
    color: rgba(255, 255, 255, .92);
    font-weight: 800;
    min-height: 72px;
    padding: 14px 16px;
}

.maritorio-docs__timeline strong {
    color: var(--orika-yellow);
    display: block;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: 1.55rem;
    line-height: 1;
}

.maritorio-docs__grid {
    display: grid;
    gap: 22px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.maritorio-doc-card {
    background: rgba(255, 255, 255, .92);
    border: 1px solid rgba(255, 255, 255, .58);
    border-radius: 8px;
    box-shadow: 0 22px 52px rgba(1, 34, 50, .24);
    overflow: hidden;
}

.maritorio-doc-card img {
    aspect-ratio: 16 / 8.5;
    background: #ffffff;
    display: block;
    object-fit: contain;
    object-position: center;
    padding: 10px;
    width: 100%;
}

.maritorio-doc-card div {
    padding: 20px;
}

.maritorio-doc-card span {
    color: var(--orika-red);
    display: block;
    font-size: .78rem;
    font-weight: 900;
    letter-spacing: .03em;
    margin-bottom: 8px;
    text-transform: uppercase;
}

.maritorio-doc-card h3 {
    color: #161616;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(1.55rem, 2.4vw, 2.1rem);
    font-weight: 700;
    line-height: 1;
    margin: 0 0 10px;
}

.maritorio-doc-card p {
    color: #4a5b66;
    font-size: .98rem;
    font-weight: 600;
    line-height: 1.42;
    margin: 0 0 16px;
}

.maritorio-doc-card a {
    align-items: center;
    background: var(--orika-yellow);
    border-radius: 6px;
    color: #161616;
    display: inline-flex;
    font-weight: 900;
    min-height: 42px;
    padding: 0 18px;
    text-decoration: none;
}

.maritorio-doc-card a:hover,
.maritorio-doc-card a:focus {
    background: var(--orika-red);
    color: #ffffff;
}

.org-hero {
    align-items: center;
    background: #014059;
    color: #ffffff;
    display: flex;
    min-height: clamp(500px, 70vh, 700px);
    overflow: hidden;
    padding: 118px clamp(24px, 7vw, 108px) 92px;
    position: relative;
}

.org-hero::after {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0), #f6f8f7);
    bottom: 0;
    content: "";
    height: 92px;
    left: 0;
    position: absolute;
    right: 0;
}

.org-hero__content {
    max-width: 820px;
    position: relative;
    z-index: 1;
}

.org-hero h1 {
    color: #ffffff;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(2.45rem, 6vw, 5.4rem);
    font-weight: 700;
    line-height: 1.02;
    margin: 24px 0 18px;
}

.org-hero p {
    color: rgba(255, 255, 255, .94);
    font-size: clamp(1.05rem, 2vw, 1.25rem);
    font-weight: 600;
    line-height: 1.5;
    margin: 0;
    max-width: 680px;
}

.org-section-label {
    align-items: center;
    color: var(--orika-yellow);
    display: inline-flex;
    font-size: .82rem;
    font-weight: 900;
    gap: 12px;
    letter-spacing: .03em;
    text-transform: uppercase;
}

.org-section-label::before {
    background: currentColor;
    content: "";
    height: 2px;
    width: 34px;
}

.org-intro {
    background: #f6f8f7;
    display: grid;
    gap: 28px;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
    padding: clamp(44px, 7vw, 88px) clamp(18px, 7vw, 96px);
}

.org-intro__copy {
    max-width: 820px;
}

.org-intro h2,
.org-chart-section h2,
.org-docs h2 {
    color: var(--orika-footer);
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(2.25rem, 4.8vw, 4.2rem);
    font-weight: 700;
    line-height: .98;
    margin: 18px 0 20px;
}

.org-intro p,
.org-chart-section p {
    color: #3d4e58;
    font-size: clamp(1rem, 1.35vw, 1.08rem);
    font-weight: 600;
    line-height: 1.55;
    margin: 0 0 16px;
}

.org-intro__facts {
    align-self: center;
    display: grid;
    gap: 12px;
}

.org-intro__facts span {
    background: #ffffff;
    border-left: 4px solid var(--orika-red);
    border-radius: 8px;
    box-shadow: 0 18px 42px rgba(1, 64, 89, .08);
    color: #3d4e58;
    font-weight: 800;
    padding: 18px;
}

.org-intro__facts strong {
    color: var(--orika-red);
    display: block;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: 2rem;
    line-height: 1;
}

.org-chart-section {
    background: #ffffff;
    display: grid;
    gap: 28px;
    grid-template-columns: minmax(320px, .82fr) minmax(0, 1fr);
    padding: clamp(42px, 6vw, 78px) clamp(18px, 7vw, 96px);
}

.org-chart-section__header {
    align-self: center;
}

.org-chart-section__figure {
    background: #ffffff;
    border-radius: 8px;
    box-shadow: 0 22px 52px rgba(1, 64, 89, .12);
    margin: 0;
    overflow: hidden;
    padding: clamp(16px, 3vw, 28px);
}

.org-chart-section__figure img {
    display: block;
    height: auto;
    width: 100%;
}

.org-docs {
    background:
        linear-gradient(135deg, rgba(0, 95, 131, .94), rgba(1, 64, 89, .96)),
        url("../img/site/maritorio-background.webp") center / cover;
    padding: clamp(44px, 7vw, 84px) clamp(18px, 7vw, 96px);
}

.org-docs__header {
    margin: 0 auto 28px;
    max-width: 980px;
    text-align: center;
}

.org-docs h2 {
    color: #ffffff;
}

.org-docs__grid {
    display: grid;
    gap: 22px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin: 0 auto;
    max-width: 980px;
}

.org-doc-card {
    background: rgba(255, 255, 255, .94);
    border-radius: 8px;
    box-shadow: 0 22px 52px rgba(1, 34, 50, .24);
    overflow: hidden;
}

.org-doc-card img {
    aspect-ratio: 16 / 9;
    display: block;
    object-fit: cover;
    width: 100%;
}

.org-doc-card div {
    padding: 20px;
}

.org-doc-card span {
    color: var(--orika-red);
    display: block;
    font-size: .78rem;
    font-weight: 900;
    letter-spacing: .03em;
    margin-bottom: 8px;
    text-transform: uppercase;
}

.org-doc-card h3 {
    color: #161616;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(1.55rem, 2.4vw, 2.1rem);
    font-weight: 700;
    line-height: 1;
    margin: 0 0 10px;
}

.org-doc-card p {
    color: #4a5b66;
    font-size: .98rem;
    font-weight: 600;
    line-height: 1.42;
    margin: 0 0 16px;
}

.org-doc-card a {
    align-items: center;
    background: var(--orika-yellow);
    border-radius: 6px;
    color: #161616;
    display: inline-flex;
    font-weight: 900;
    min-height: 42px;
    padding: 0 18px;
    text-decoration: none;
}

.org-doc-card a:hover,
.org-doc-card a:focus {
    background: var(--orika-red);
    color: #ffffff;
}

.tourism-hero {
    align-items: flex-start;
    background: linear-gradient(135deg, #014059, #00647f);
    color: #ffffff;
    display: flex;
    min-height: clamp(560px, 78vh, 720px);
    overflow: hidden;
    padding: 0;
    position: relative;
}

.tourism-hero::after {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0), #f6f8f7);
    bottom: 0;
    content: "";
    height: 58px;
    left: 0;
    position: absolute;
    right: 0;
    z-index: 1;
}

.tourism-hero .home-hero__slides {
    background: #014059;
    display: flex;
}

.tourism-hero .home-hero__slide {
    align-items: flex-start;
    background-image: none;
    background-size: auto;
    box-sizing: border-box;
    display: flex;
    justify-content: center;
    padding: 28px clamp(22px, 5vw, 72px) 54px clamp(260px, 33vw, 500px);
    transform: none;
}

.tourism-hero .home-hero__slide::before {
    background:
        linear-gradient(90deg, rgba(1, 64, 89, .78), rgba(1, 64, 89, .24), rgba(1, 64, 89, .68)),
        var(--slide-bg) center / cover no-repeat;
    content: "";
    filter: blur(22px) saturate(1.1);
    inset: -28px;
    opacity: .9;
    position: absolute;
    transform: scale(1.04);
    z-index: 0;
}

.tourism-hero__poster {
    align-items: center;
    background: rgba(255, 255, 255, .08);
    border: 1px solid rgba(255, 255, 255, .16);
    border-radius: 8px;
    box-shadow: 0 28px 78px rgba(0, 0, 0, .28);
    display: flex;
    justify-content: center;
    max-width: min(1040px, 72vw);
    overflow: hidden;
    padding: 10px;
    position: relative;
    width: 100%;
    z-index: 1;
}

.tourism-hero__poster img {
    border-radius: 8px;
    display: block;
    height: auto;
    max-height: clamp(430px, 66vh, 620px);
    object-fit: contain;
    position: relative;
    width: 100%;
}

.tourism-hero__content {
    background: linear-gradient(135deg, rgba(1, 64, 89, .96), rgba(0, 95, 131, .74));
    border-left: 4px solid var(--orika-yellow);
    box-shadow: 18px 0 48px rgba(1, 34, 50, .22);
    left: clamp(18px, 4vw, 56px);
    max-width: min(470px, 34vw);
    padding: clamp(20px, 3vw, 34px);
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 3;
}

.tourism-hero h1 {
    color: #ffffff;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(2.15rem, 4vw, 3.8rem);
    font-weight: 700;
    line-height: 1.02;
    margin: 16px 0 12px;
}

.tourism-hero p {
    color: rgba(255, 255, 255, .94);
    font-size: clamp(.98rem, 1.35vw, 1.08rem);
    font-weight: 600;
    line-height: 1.45;
    margin: 0 0 22px;
    max-width: 680px;
}

.tourism-intro {
    background: #f6f8f7;
    display: grid;
    gap: 28px;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
    padding: clamp(44px, 7vw, 88px) clamp(18px, 7vw, 96px);
}

.tourism-intro__copy {
    align-self: center;
    max-width: 820px;
}

.tourism-intro h2 {
    color: var(--orika-footer);
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(2.25rem, 4.8vw, 4.2rem);
    font-weight: 700;
    line-height: .98;
    margin: 18px 0 20px;
}

.tourism-intro p {
    color: #3d4e58;
    font-size: clamp(1rem, 1.35vw, 1.08rem);
    font-weight: 600;
    line-height: 1.55;
    margin: 0 0 26px;
}

.tourism-intro__media {
    align-self: center;
    background: #ffffff;
    border-radius: 8px;
    box-shadow: 0 22px 52px rgba(1, 64, 89, .12);
    margin: 0;
    overflow: hidden;
    padding: 14px;
}

.tourism-intro__media img {
    border-radius: 6px;
    display: block;
    height: auto;
    width: 100%;
}

.tourism-values {
    background: linear-gradient(135deg, rgba(0, 95, 131, .94), rgba(1, 64, 89, .96)), url("../img/site/maritorio-background.webp") center / cover;
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    padding: clamp(42px, 6vw, 76px) clamp(18px, 7vw, 96px);
}

.tourism-values article {
    background: rgba(255, 255, 255, .94);
    border-bottom: 4px solid var(--orika-red);
    border-radius: 8px;
    box-shadow: 0 18px 42px rgba(1, 34, 50, .18);
    padding: 24px;
}

.tourism-values span {
    color: var(--orika-red);
    display: block;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: 2rem;
    font-weight: 700;
    line-height: 1;
    margin-bottom: 12px;
}

.tourism-values strong {
    color: var(--orika-footer);
    display: block;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: 1.65rem;
    line-height: 1;
    margin-bottom: 10px;
}

.tourism-values p {
    color: #4a5b66;
    font-weight: 600;
    line-height: 1.42;
    margin: 0;
}

.tourism-map-section {
    background: #ffffff;
    padding: clamp(42px, 6vw, 76px) clamp(18px, 7vw, 96px);
}

.tourism-map-section__header {
    margin: 0 auto 28px;
    max-width: 980px;
    text-align: center;
}

.tourism-map-section__header .org-section-label {
    justify-content: center;
}

.tourism-map-section h2 {
    color: var(--orika-footer);
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(2.25rem, 4.8vw, 4.2rem);
    font-weight: 700;
    line-height: .98;
    margin: 18px 0 14px;
}

.tourism-map-section p {
    color: #3d4e58;
    font-size: clamp(1rem, 1.35vw, 1.08rem);
    font-weight: 600;
    line-height: 1.5;
    margin: 0 auto;
    max-width: 760px;
}

.tourism-map-section__frame {
    border: 6px solid #ffffff;
    border-radius: 8px;
    box-shadow: 0 24px 58px rgba(1, 64, 89, .18);
    height: clamp(420px, 58vw, 680px);
    margin: 0 auto;
    max-width: 1180px;
    overflow: hidden;
    position: relative;
}

.tourism-map-section__map {
    height: 100%;
}

.tourism-gallery {
    background: #f6f8f7;
    padding: clamp(42px, 6vw, 76px) clamp(18px, 7vw, 96px);
}

.tourism-gallery__header {
    margin: 0 auto 28px;
    max-width: 980px;
    text-align: center;
}

.tourism-gallery__header .org-section-label {
    justify-content: center;
}

.tourism-gallery h2 {
    color: var(--orika-footer);
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(2.25rem, 4.8vw, 4.2rem);
    font-weight: 700;
    line-height: .98;
    margin: 18px 0 14px;
}

.tourism-gallery p {
    color: #3d4e58;
    font-size: clamp(1rem, 1.35vw, 1.08rem);
    font-weight: 600;
    line-height: 1.5;
    margin: 0 auto;
    max-width: 760px;
}

.tourism-gallery__grid {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin: 0 auto;
    max-width: 1180px;
}

.tourism-gallery__item {
    background: #014059;
    border-radius: 8px;
    box-shadow: 0 18px 42px rgba(1, 34, 50, .16);
    margin: 0;
    min-height: 240px;
    overflow: hidden;
    position: relative;
}

.tourism-gallery__item--featured {
    grid-column: span 2;
    grid-row: span 2;
    min-height: 496px;
}

.tourism-gallery__item img {
    display: block;
    height: 100%;
    object-fit: cover;
    transform: scale(1.01);
    transition: transform .35s ease;
    width: 100%;
}

.tourism-gallery__item:hover img,
.tourism-gallery__item:focus-within img {
    transform: scale(1.045);
}

.tourism-gallery__item::after {
    background: linear-gradient(180deg, rgba(1, 64, 89, 0), rgba(1, 64, 89, .84));
    bottom: 0;
    content: "";
    height: 52%;
    left: 0;
    position: absolute;
    right: 0;
}

.tourism-gallery__item figcaption {
    bottom: 0;
    color: #ffffff;
    left: 0;
    padding: 18px;
    position: absolute;
    right: 0;
    z-index: 1;
}

.tourism-gallery__item figcaption span {
    color: var(--orika-yellow);
    display: block;
    font-size: .78rem;
    font-weight: 900;
    letter-spacing: .03em;
    margin-bottom: 5px;
    text-transform: uppercase;
}

.tourism-gallery__item figcaption strong {
    display: block;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(1.35rem, 2vw, 2rem);
    font-weight: 700;
    line-height: 1;
}

.tourism-map-float {
    align-items: center;
    background: var(--orika-yellow);
    border: 0;
    border-radius: 999px;
    bottom: 24px;
    box-shadow: 0 16px 38px rgba(1, 34, 50, .26);
    color: var(--orika-ink);
    display: inline-flex;
    font-weight: 900;
    gap: 10px;
    min-height: 54px;
    padding: 0 22px;
    position: fixed;
    right: 24px;
    z-index: 950;
}

.tourism-map-float::before {
    background: var(--orika-red);
    border: 2px solid #ffffff;
    border-radius: 50% 50% 50% 0;
    content: "";
    height: 18px;
    transform: rotate(-45deg);
    width: 18px;
}

.tourism-map-float:hover,
.tourism-map-float:focus {
    background: #ffffff;
    color: var(--orika-red);
}

.relatos-hero {
    align-items: center;
    background:
        linear-gradient(90deg, rgba(1, 64, 89, .94), rgba(1, 64, 89, .54)),
        var(--relatos-hero-image) center / cover;
    color: #ffffff;
    display: grid;
    gap: clamp(22px, 5vw, 72px);
    grid-template-columns: minmax(0, .95fr) minmax(320px, .72fr);
    min-height: clamp(560px, 76vh, 720px);
    overflow: hidden;
    padding: 112px clamp(18px, 7vw, 96px) 118px;
    position: relative;
}

.relatos-scroll-cue {
    animation: relatosScrollCue 1.8s ease-in-out infinite;
    background: rgba(255, 255, 255, .94);
    border-color: rgba(255, 206, 96, .94);
    bottom: 82px;
    box-shadow: 0 16px 36px rgba(1, 34, 50, .24);
    color: var(--orika-footer);
    left: 50%;
    min-height: 44px;
    padding: 10px 18px 10px 20px;
    position: absolute;
    transform: translateX(-50%);
    z-index: 3;
}

.relatos-scroll-cue:hover,
.relatos-scroll-cue:focus {
    background: var(--orika-yellow);
    border-color: var(--orika-yellow);
    box-shadow: 0 20px 42px rgba(1, 34, 50, .34);
    color: var(--orika-ink);
}

@keyframes relatosScrollCue {
    0%,
    100% {
        transform: translateX(-50%) translateY(0);
    }

    50% {
        transform: translateX(-50%) translateY(7px);
    }
}

.relatos-hero::before {
    background:
        radial-gradient(circle at 88% 18%, rgba(255, 200, 69, .14), transparent 28%),
        linear-gradient(180deg, rgba(1, 64, 89, .12), rgba(1, 64, 89, .88));
    content: "";
    inset: 0;
    position: absolute;
}

.relatos-hero::after {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0), #f6f8f7);
    bottom: 0;
    content: "";
    height: 70px;
    left: 0;
    position: absolute;
    right: 0;
}

.relatos-hero__content,
.relatos-hero__preview {
    position: relative;
    z-index: 1;
}

.relatos-hero__content {
    border-left: 4px solid var(--orika-yellow);
    max-width: 760px;
    padding-left: 24px;
}

.relatos-hero h1 {
    color: #ffffff;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(2.8rem, 7vw, 6rem);
    font-weight: 700;
    line-height: .95;
    margin: 22px 0 18px;
}

.relatos-hero p {
    color: rgba(255, 255, 255, .94);
    font-size: clamp(1.05rem, 1.8vw, 1.25rem);
    font-weight: 600;
    line-height: 1.5;
    margin: 0 0 28px;
    max-width: 650px;
}

.relatos-hero__preview {
    align-self: end;
    background: rgba(255, 255, 255, .09);
    border: 1px solid rgba(255, 255, 255, .18);
    border-radius: 8px;
    box-shadow: 0 28px 78px rgba(1, 34, 50, .36);
    overflow: hidden;
}

.relatos-hero__preview img {
    aspect-ratio: 16 / 9;
    display: block;
    object-fit: cover;
    width: 100%;
}

.relatos-hero__preview div {
    align-items: center;
    background: rgba(1, 64, 89, .94);
    border-top: 3px solid var(--orika-yellow);
    display: flex;
    gap: 14px;
    padding: 18px;
}

.relatos-hero__preview span {
    color: var(--orika-yellow);
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: 2rem;
    font-weight: 700;
    line-height: 1;
}

.relatos-hero__preview strong {
    color: #ffffff;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: 1.55rem;
    line-height: 1;
}

.relatos-intro {
    align-items: end;
    background: #f6f8f7;
    display: grid;
    gap: 26px;
    grid-template-columns: minmax(280px, .78fr) minmax(0, 1fr);
    padding: clamp(42px, 7vw, 82px) clamp(18px, 7vw, 96px);
}

.relatos-intro h2 {
    color: var(--orika-footer);
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(2.35rem, 5vw, 4.4rem);
    font-weight: 700;
    line-height: .98;
    margin: 18px 0 0;
}

.relatos-intro p {
    color: #3d4e58;
    font-size: clamp(1rem, 1.35vw, 1.1rem);
    font-weight: 600;
    line-height: 1.58;
    margin: 0;
}

.relatos-grid {
    background:
        linear-gradient(135deg, rgba(0, 95, 131, .96), rgba(1, 64, 89, .98)),
        url("../img/site/maritorio-background.webp") center / cover;
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    padding: clamp(42px, 7vw, 84px) clamp(18px, 7vw, 96px);
}

.relato-card {
    background: rgba(255, 255, 255, .95);
    border-radius: 8px;
    box-shadow: 0 20px 44px rgba(1, 34, 50, .18);
    display: flex;
    flex-direction: column;
    min-height: 100%;
    overflow: hidden;
}

.relato-card figure {
    background: #014059;
    margin: 0;
    position: relative;
}

.relato-card img {
    aspect-ratio: 16 / 9;
    display: block;
    object-fit: cover;
    width: 100%;
}

.relato-card figcaption {
    background: var(--orika-red);
    color: #ffffff;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: 1.65rem;
    font-weight: 700;
    left: 14px;
    line-height: 1;
    padding: 8px 10px;
    position: absolute;
    top: 14px;
}

.relato-card__body {
    display: flex;
    flex: 1;
    flex-direction: column;
    padding: 22px;
}

.relato-card h2 {
    color: var(--orika-footer);
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(1.65rem, 2.3vw, 2.15rem);
    font-weight: 700;
    line-height: 1;
    margin: 0 0 12px;
}

.relato-card p {
    color: #4a5b66;
    font-size: .98rem;
    font-weight: 600;
    line-height: 1.42;
    margin: 0 0 18px;
}

.relato-card__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: auto;
}

.relato-card__actions button {
    align-items: center;
    background: var(--orika-yellow);
    border: 0;
    border-radius: 6px;
    color: #161616;
    display: inline-flex;
    font-size: .92rem;
    font-weight: 900;
    gap: 8px;
    min-height: 40px;
    padding: 0 14px;
    text-decoration: none;
}

.relato-card__button-icon {
    align-items: center;
    background: #ffffff;
    border-radius: 999px;
    display: inline-flex;
    height: 24px;
    justify-content: center;
    width: 24px;
}

.relato-card__button-icon img {
    display: block;
    height: 14px;
    width: 14px;
}

.relato-card__actions button:nth-child(2) {
    background: #014059;
    color: #ffffff;
}

.relato-card__actions button:hover,
.relato-card__actions button:focus {
    background: var(--orika-red);
    color: #ffffff;
}

.relato-media-modal .modal-content {
    border: 0;
    border-radius: 8px;
    box-shadow: 0 28px 70px rgba(1, 64, 89, .28);
    overflow: hidden;
}

.relato-media-modal .modal-header {
    align-items: flex-start;
    background:
        radial-gradient(circle at 90% 12%, rgba(255, 206, 96, .18), transparent 26%),
        linear-gradient(135deg, #005f83 0%, #014059 100%);
    border: 0;
    color: #ffffff;
    gap: 18px;
    padding: 20px 24px;
}

.relato-media-modal .modal-header span {
    color: var(--orika-yellow);
    display: block;
    font-size: .78rem;
    font-weight: 900;
    letter-spacing: .03em;
    margin-bottom: 6px;
    text-transform: uppercase;
}

.relato-media-modal .modal-title {
    color: #ffffff;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(1.8rem, 3vw, 2.65rem);
    font-weight: 700;
    line-height: 1;
    margin: 0;
}

.relato-media-modal .btn-close {
    filter: invert(1);
    opacity: .9;
}

.relato-media-modal .modal-body {
    background: #014059;
    padding: 0;
}

.relato-media-modal iframe {
    aspect-ratio: 16 / 9;
    border: 0;
    display: block;
    width: 100%;
}

.relato-media-modal--audio .modal-body {
    background: #f6f8f7;
    padding: 18px;
}

.relato-media-modal--audio iframe {
    aspect-ratio: auto;
    border-radius: 8px;
    height: 352px;
}

.solar-hero {
    align-items: center;
    background:
        linear-gradient(90deg, rgba(1, 64, 89, .92), rgba(1, 64, 89, .42), rgba(1, 64, 89, .76)),
        var(--solar-hero-image) center / cover;
    color: #ffffff;
    display: flex;
    min-height: clamp(560px, 76vh, 720px);
    overflow: hidden;
    padding: 112px clamp(18px, 7vw, 96px) 76px;
    position: relative;
}

.solar-hero::after {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0), #f6f8f7);
    bottom: 0;
    content: "";
    height: 72px;
    left: 0;
    position: absolute;
    right: 0;
}

.solar-hero__content {
    border-left: 4px solid var(--orika-yellow);
    max-width: 760px;
    padding-left: 24px;
    position: relative;
    z-index: 1;
}

.solar-hero h1,
.solar-intro h2,
.solar-system h2,
.solar-consumption h2,
.solar-gallery h2,
.solar-location h2 {
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-weight: 700;
    line-height: .98;
}

.solar-hero h1 {
    color: #ffffff;
    font-size: clamp(2.9rem, 7vw, 6.2rem);
    margin: 22px 0 18px;
    max-width: 780px;
}

.solar-hero p {
    color: rgba(255, 255, 255, .94);
    font-size: clamp(1.05rem, 1.8vw, 1.25rem);
    font-weight: 700;
    line-height: 1.5;
    margin: 0 0 28px;
    max-width: 650px;
}

.solar-tabs {
    align-items: center;
    backdrop-filter: blur(14px);
    background:
        linear-gradient(90deg, rgba(1, 64, 89, .94), rgba(35, 142, 156, .88)),
        rgba(1, 64, 89, .84);
    border-top: 3px solid var(--orika-red);
    box-shadow: 0 18px 38px rgba(1, 34, 50, .18);
    display: grid;
    gap: 10px;
    grid-template-columns: minmax(240px, 1.22fr) repeat(5, minmax(170px, 1fr));
    padding: 13px clamp(14px, 3vw, 30px);
    position: sticky;
    top: 0;
    z-index: 8;
}

.solar-tabs__item {
    align-items: center;
    background: rgba(255, 255, 255, .08);
    border: 1px solid rgba(255, 255, 255, .16);
    border-radius: 999px;
    color: rgba(255, 255, 255, .9);
    cursor: pointer;
    display: inline-flex;
    font-size: clamp(.8rem, .9vw, .9rem);
    font-weight: 900;
    gap: 9px;
    justify-content: center;
    line-height: 1.1;
    min-height: 44px;
    max-width: none;
    min-width: 0;
    padding: 0 14px;
    text-align: center;
    text-decoration: none;
    transition: background .18s ease, border-color .18s ease, box-shadow .18s ease, color .18s ease, transform .18s ease;
    white-space: nowrap;
    width: 100%;
}

.solar-tabs__item:first-child {
    max-width: none;
}

.solar-tab-panels {
    background: #f6f8f7;
}

.solar-tab-panel {
    animation: solarTabFade .22s ease both;
}

.solar-tab-panel[hidden] {
    display: none !important;
}

@keyframes solarTabFade {
    from {
        opacity: 0;
        transform: translateY(8px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.solar-tabs__icon {
    align-items: center;
    background: rgba(255, 255, 255, .14);
    border-radius: 999px;
    display: inline-flex;
    flex: 0 0 auto;
    height: 26px;
    justify-content: center;
    width: 26px;
}

.solar-tabs__icon img {
    display: block;
    filter: brightness(0) invert(1);
    height: 15px;
    opacity: .94;
    width: 15px;
}

.solar-tabs__item:hover,
.solar-tabs__item:focus,
.solar-tabs__item--active {
    background: #ffc845;
    border-color: rgba(255, 255, 255, .45);
    box-shadow: 0 12px 28px rgba(0, 0, 0, .16);
    color: #062d36;
    transform: translateY(-1px);
}

.solar-tabs__item:hover .solar-tabs__icon,
.solar-tabs__item:focus .solar-tabs__icon,
.solar-tabs__item--active .solar-tabs__icon {
    background: rgba(1, 64, 89, .12);
}

.solar-tabs__item:hover .solar-tabs__icon img,
.solar-tabs__item:focus .solar-tabs__icon img,
.solar-tabs__item--active .solar-tabs__icon img {
    filter: none;
    opacity: 1;
}

.solar-intro {
    align-items: center;
    background: #f6f8f7;
    display: grid;
    gap: clamp(24px, 5vw, 56px);
    grid-template-columns: minmax(0, .9fr) minmax(320px, .75fr);
    padding: clamp(44px, 7vw, 88px) clamp(18px, 7vw, 96px);
    scroll-margin-top: 84px;
}

.solar-intro__copy {
    max-width: 760px;
}

.solar-intro h2,
.solar-system h2,
.solar-consumption h2,
.solar-gallery h2,
.solar-location h2 {
    color: var(--orika-footer);
    font-size: clamp(2.35rem, 5vw, 4.4rem);
    margin: 18px 0 20px;
}

.solar-intro p,
.solar-system__header p,
.solar-consumption__copy p {
    color: #3d4e58;
    font-size: clamp(1rem, 1.35vw, 1.08rem);
    font-weight: 600;
    line-height: 1.55;
    margin: 0;
}

.solar-intro__figure,
.solar-system__diagram,
.solar-consumption__cards figure,
.solar-gallery__item {
    background: #ffffff;
    border-radius: 8px;
    box-shadow: 0 22px 52px rgba(1, 64, 89, .14);
    margin: 0;
    overflow: hidden;
}

.solar-intro__figure img,
.solar-gallery__item img {
    aspect-ratio: 16 / 10;
    display: block;
    object-fit: cover;
    width: 100%;
}

.solar-intro__figure figcaption,
.solar-consumption__cards figcaption,
.solar-gallery__item figcaption {
    background: var(--orika-footer);
    border-top: 3px solid var(--orika-yellow);
    color: #ffffff;
    font-weight: 900;
    padding: 14px 16px;
}

.solar-values {
    background:
        linear-gradient(135deg, rgba(0, 95, 131, .96), rgba(1, 64, 89, .98)),
        url("../img/site/parque-solar/panoramica.webp") center / cover;
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    padding: clamp(42px, 7vw, 76px) clamp(18px, 7vw, 96px);
}

.solar-value-card {
    background: rgba(255, 255, 255, .94);
    border-bottom: 4px solid var(--orika-red);
    border-radius: 8px;
    box-shadow: 0 20px 44px rgba(1, 34, 50, .2);
    min-height: 210px;
    padding: clamp(22px, 3vw, 30px);
}

.solar-value-card span {
    color: var(--orika-red);
    display: block;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: 2rem;
    font-weight: 700;
    line-height: 1;
    margin-bottom: 14px;
}

.solar-value-card h2 {
    color: var(--orika-footer);
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(1.7rem, 2.4vw, 2.25rem);
    font-weight: 700;
    line-height: 1;
    margin: 0 0 12px;
}

.solar-value-card p {
    color: #3d4e58;
    font-size: 1rem;
    font-weight: 650;
    line-height: 1.45;
    margin: 0;
}

.solar-system {
    background: #ffffff;
    padding: clamp(44px, 7vw, 84px) clamp(18px, 7vw, 96px);
    scroll-margin-top: 84px;
}

.solar-system__header,
.solar-gallery__header {
    margin: 0 auto 28px;
    max-width: 960px;
    text-align: center;
}

.solar-system__header .org-section-label,
.solar-gallery__header .org-section-label {
    justify-content: center;
}

.solar-system__copy {
    display: grid;
    gap: 14px;
    margin: 0 auto;
    max-width: 980px;
}

.solar-system__copy p {
    color: #3d4e58;
    font-size: clamp(1rem, 1.25vw, 1.08rem);
    font-weight: 600;
    line-height: 1.52;
    margin: 0;
}

.solar-system__stats {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin: 0 auto 24px;
    max-width: 1180px;
}

.solar-system__stats span {
    background: #ffffff;
    border-left: 4px solid var(--orika-yellow);
    border-radius: 8px;
    box-shadow: 0 16px 36px rgba(1, 64, 89, .1);
    color: #3d4e58;
    display: block;
    font-weight: 800;
    min-height: 96px;
    padding: 18px;
}

.solar-system__stats strong {
    color: var(--orika-red);
    display: block;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(1.9rem, 3vw, 2.5rem);
    line-height: .95;
    margin-bottom: 8px;
}

.solar-system__grid {
    align-items: start;
    display: grid;
    gap: 24px;
    grid-template-columns: minmax(0, .85fr) minmax(320px, .72fr);
    margin: 0 auto;
    max-width: 1180px;
}

.solar-system__diagram {
    padding: clamp(12px, 2vw, 20px);
}

.solar-system__diagram img {
    display: block;
    height: auto;
    object-fit: contain;
    width: 100%;
}

.solar-system__diagram--wide {
    align-self: stretch;
    display: flex;
}

.solar-system__diagram--wide img {
    margin: auto;
}

.solar-generation {
    background:
        linear-gradient(135deg, rgba(255, 255, 255, .96), rgba(246, 248, 247, .94)),
        url("../img/site/parque-solar/panoramica.webp") center / cover;
}

.solar-generation__hero {
    align-items: stretch;
    display: grid;
    gap: 24px;
    grid-template-columns: minmax(0, 1fr) minmax(260px, 340px);
    margin: 0 auto 28px;
    max-width: 1180px;
}

.solar-generation__hero h2 {
    color: #238e9c;
    margin-bottom: 16px;
}

.solar-generation__hero p {
    color: #3d4e58;
    font-size: clamp(1rem, 1.3vw, 1.12rem);
    font-weight: 600;
    line-height: 1.5;
    margin: 0;
}

.solar-generation__impact {
    background: linear-gradient(135deg, #238e9c, #014059);
    border-bottom: 4px solid var(--orika-yellow);
    border-radius: 8px;
    box-shadow: 0 18px 42px rgba(1, 64, 89, .18);
    color: #ffffff;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 180px;
    padding: 24px;
}

.solar-generation__impact span {
    color: rgba(255, 255, 255, .86);
    font-size: .9rem;
    font-weight: 900;
    letter-spacing: .03em;
    text-transform: uppercase;
}

.solar-generation__impact strong {
    color: #ffffff;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(2.3rem, 4vw, 3.6rem);
    line-height: .95;
    margin-top: 10px;
}

.solar-generation__grid {
    align-items: start;
    display: grid;
    gap: 24px;
    grid-template-columns: minmax(360px, .92fr) minmax(360px, 1fr);
    margin: 0 auto;
    max-width: 1180px;
}

.solar-generation__diagram {
    align-self: stretch;
    display: flex;
    min-height: 520px;
}

.solar-generation__diagram img {
    margin: auto;
}

.solar-generation__components {
    display: grid;
    gap: 10px;
}

.solar-generation__components article {
    background: rgba(1, 64, 89, .9);
    border-left: 4px solid var(--orika-yellow);
    border-radius: 8px;
    box-shadow: 0 14px 30px rgba(1, 64, 89, .12);
    color: #ffffff;
    padding: 14px 16px;
}

.solar-generation__components h3 {
    color: #ffffff;
    font-size: clamp(1rem, 1.5vw, 1.18rem);
    font-weight: 900;
    line-height: 1.1;
    margin: 0 0 6px;
}

.solar-generation__components p {
    color: rgba(255, 255, 255, .9);
    font-size: .94rem;
    font-weight: 600;
    line-height: 1.35;
    margin: 0;
}

.solar-consumption {
    background:
        linear-gradient(135deg, rgba(1, 64, 89, .94), rgba(0, 95, 131, .9)),
        url("../img/site/maritorio-background.webp") center / cover;
    color: #ffffff;
    display: grid;
    gap: 28px;
    grid-template-columns: minmax(280px, .6fr) minmax(0, 1fr);
    padding: clamp(44px, 7vw, 84px) clamp(18px, 7vw, 96px);
    scroll-margin-top: 84px;
}

.solar-consumption h2,
.solar-consumption__copy p {
    color: #ffffff;
}

.solar-consumption__cards {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.solar-consumption__cards--two {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.solar-consumption__cards--single {
    grid-template-columns: minmax(280px, 560px);
    justify-content: center;
}

.solar-consumption__cards img {
    aspect-ratio: 4 / 3;
    display: block;
    object-fit: contain;
    padding: 12px;
    width: 100%;
}

.solar-measurement {
    background: #ffffff;
    padding: clamp(44px, 7vw, 84px) clamp(18px, 7vw, 96px);
    scroll-margin-top: 84px;
}

.solar-measurement__header {
    margin: 0 auto 26px;
    max-width: 1180px;
}

.solar-measurement__header h2 {
    color: #238e9c;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(2.35rem, 5vw, 4.4rem);
    font-weight: 700;
    line-height: .98;
    margin: 18px 0 0;
}

.solar-measurement__grid {
    align-items: start;
    display: grid;
    gap: 28px;
    grid-template-columns: minmax(420px, .78fr) minmax(320px, .52fr);
    margin: 0 auto;
    max-width: 1180px;
}

.solar-measurement__table,
.solar-measurement__scale figure {
    background: #ffffff;
    border-radius: 8px;
    box-shadow: 0 22px 52px rgba(1, 64, 89, .12);
    margin: 0;
    overflow: hidden;
}

.solar-measurement__table img,
.solar-measurement__scale img {
    display: block;
    height: auto;
    object-fit: contain;
    width: 100%;
}

.solar-measurement__tips {
    display: grid;
    gap: 16px;
}

.solar-measurement__tips article {
    background: #f6f8f7;
    border-left: 4px solid var(--orika-yellow);
    border-radius: 8px;
    box-shadow: 0 16px 36px rgba(1, 64, 89, .08);
    padding: 18px 20px;
}

.solar-measurement__tips h3 {
    color: #014059;
    font-size: 1.08rem;
    font-weight: 900;
    margin: 0 0 8px;
}

.solar-measurement__tips ul {
    color: #004478;
    font-size: .96rem;
    font-weight: 650;
    line-height: 1.36;
    margin: 0;
    padding-left: 18px;
}

.solar-measurement__tips p {
    color: #004478;
    font-size: .88rem;
    font-weight: 600;
    line-height: 1.38;
    margin: 12px 0 0;
}

.solar-measurement__scale {
    margin: 34px auto 0;
    max-width: 1060px;
}

.solar-measurement__scale p {
    color: #014059;
    font-size: clamp(1rem, 1.4vw, 1.12rem);
    font-weight: 900;
    line-height: 1.35;
    margin: 0 0 18px;
    text-align: center;
}

.solar-measurement__scale figure {
    padding: clamp(12px, 2vw, 20px);
}

.solar-payment {
    background: #ffffff;
    padding: clamp(44px, 7vw, 84px) clamp(18px, 7vw, 96px);
    scroll-margin-top: 84px;
}

.solar-payment__header {
    margin: 0 auto 34px;
    max-width: 1180px;
}

.solar-payment__header h2 {
    color: #238e9c;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(2.35rem, 5vw, 4.4rem);
    font-weight: 700;
    line-height: .98;
    margin: 18px 0 28px;
}

.solar-payment__header p {
    color: #003f54;
    font-size: clamp(1rem, 1.3vw, 1.1rem);
    font-weight: 500;
    line-height: 1.48;
    margin: 0;
}

.solar-payment__steps {
    background: #ffffff;
    border-radius: 8px;
    box-shadow: 0 24px 58px rgba(1, 64, 89, .1);
    margin: 0 auto;
    max-width: 760px;
    overflow: hidden;
    padding: clamp(10px, 2vw, 18px);
}

.solar-payment__steps img {
    display: block;
    height: auto;
    object-fit: contain;
    width: 100%;
}

.solar-interest {
    background: #ffffff;
    scroll-margin-top: 84px;
}

.solar-interest__links {
    padding: clamp(44px, 7vw, 82px) clamp(18px, 7vw, 96px);
}

.solar-interest__links h2,
.solar-interest__entities h2 {
    color: #238e9c;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(2.35rem, 5vw, 4.2rem);
    font-weight: 700;
    line-height: .98;
    margin: 0 0 34px;
    text-align: center;
}

.solar-interest__grid {
    display: grid;
    gap: 28px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin: 0 auto;
    max-width: 1180px;
}

.solar-interest-card {
    background: #ffffff;
    border-radius: 8px;
    box-shadow: 0 20px 48px rgba(1, 64, 89, .16);
    color: #014059;
    display: grid;
    grid-template-rows: clamp(220px, 18vw, 255px) minmax(112px, auto) 58px;
    justify-items: center;
    overflow: hidden;
    padding: 0 0 24px;
    text-align: center;
    text-decoration: none;
}

.solar-interest-card figure {
    background: #d9f5f0;
    height: 100%;
    margin: 0;
    overflow: hidden;
}

.solar-interest-card img {
    display: block;
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.solar-interest-card span {
    align-items: center;
    align-self: center;
    background: var(--orika-yellow);
    border-radius: 999px;
    color: #014059;
    display: inline-flex;
    font-size: .8rem;
    font-weight: 900;
    grid-row: 3;
    justify-content: center;
    height: 36px;
    line-height: 1;
    margin: 0;
    min-width: 112px;
    padding: 0 18px;
    text-transform: uppercase;
}

.solar-interest-card strong {
    align-self: start;
    color: #238e9c;
    display: block;
    font-size: clamp(1.2rem, 2vw, 1.55rem);
    font-weight: 900;
    grid-row: 2;
    line-height: 1.12;
    min-height: 0;
    padding: 28px 18px 0;
    width: 100%;
}

.solar-interest-card:hover,
.solar-interest-card:focus {
    color: #014059;
    transform: translateY(-2px);
}

.solar-interest__entities {
    background: #014059;
    padding: clamp(38px, 6vw, 70px) clamp(18px, 7vw, 96px);
}

.solar-interest__entities h2 {
    color: #ffffff;
}

.solar-entities__grid {
    display: grid;
    gap: 28px;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    margin: 0 auto;
    max-width: 1120px;
}

.solar-entity-card {
    align-items: center;
    background:
        radial-gradient(circle at 12% 12%, rgba(255, 206, 96, .22), transparent 30%),
        linear-gradient(145deg, #ffffff 0%, #f7fbfb 58%, #eef7f5 100%);
    border: 1px solid rgba(255, 255, 255, .78);
    border-radius: 8px;
    box-shadow: 0 22px 48px rgba(0, 0, 0, .22);
    color: #014059;
    display: flex;
    grid-column: span 3;
    justify-content: center;
    min-height: 170px;
    overflow: hidden;
    padding: 24px;
    position: relative;
    text-align: center;
    text-decoration: none;
    transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}

.solar-entity-card::after {
    background: linear-gradient(90deg, var(--orika-yellow), var(--orika-red));
    bottom: 0;
    content: "";
    height: 4px;
    left: 0;
    opacity: .9;
    position: absolute;
    right: 0;
}

.solar-entity-card img {
    display: block;
    height: 112px;
    max-width: 210px;
    object-fit: contain;
    width: 100%;
}

.solar-entity-card:nth-child(5) {
    grid-column: 2 / span 3;
}

.solar-entity-card:nth-child(6) {
    grid-column: 5 / span 3;
}

.solar-entity-card:nth-child(7) {
    grid-column: 8 / span 3;
}

.solar-entity-card:hover,
.solar-entity-card:focus {
    border-color: var(--orika-yellow);
    color: #014059;
    box-shadow: 0 28px 58px rgba(0, 0, 0, .28);
    transform: translateY(-3px);
}

.solar-entity-card--static {
    cursor: default;
}

.solar-entity-card--static:hover,
.solar-entity-card--static:focus {
    border-color: rgba(1, 64, 89, .1);
    transform: none;
}

.solar-gallery {
    background: #f6f8f7;
    padding: clamp(44px, 7vw, 84px) clamp(18px, 7vw, 96px);
    scroll-margin-top: 84px;
}

#solar-generation,
#solar-payment {
    scroll-margin-top: 84px;
}

.solar-gallery__grid {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.solar-gallery__item--wide {
    grid-column: 1 / -1;
}

.solar-gallery__item--wide img {
    aspect-ratio: 21 / 9;
}

.solar-location {
    background: #ffffff;
    padding: clamp(44px, 7vw, 84px) clamp(18px, 7vw, 96px);
    scroll-margin-top: 84px;
}

.solar-location__header {
    margin: 0 auto 28px;
    max-width: 1200px;
}

.solar-location__header h2 {
    color: #238e9c;
    font-size: clamp(2.35rem, 4.6vw, 4.3rem);
    margin: 0 0 18px;
}

.solar-location__header h2 span {
    color: #238e9c;
    display: inline-block;
    font-family: "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(1.35rem, 2vw, 2rem);
    font-weight: 500;
    line-height: 1.15;
    margin-left: 8px;
    vertical-align: middle;
}

.solar-location__header p {
    color: #003f54;
    font-size: clamp(1rem, 1.3vw, 1.12rem);
    font-weight: 500;
    line-height: 1.45;
    margin: 0;
    max-width: 1120px;
}

.solar-location__grid {
    display: grid;
    gap: 10px;
    grid-template-columns: minmax(340px, 1fr) minmax(340px, 1fr);
    margin: 32px auto 0;
    max-width: 1220px;
}

.solar-location__map-card,
.solar-location__photo {
    border: 6px solid #014059;
    box-shadow: 0 18px 42px rgba(1, 64, 89, .16);
    margin: 0;
    min-height: 360px;
    overflow: hidden;
}

.solar-location__map-card {
    background: #e8f5f3;
    display: flex;
    flex-direction: column;
}

.solar-location__map-card header {
    align-items: center;
    background: #003f46;
    color: #ffffff;
    display: flex;
    gap: 12px;
    min-height: 42px;
    padding: 7px 14px;
}

.solar-location__map-card h3 {
    color: #ffffff;
    font-size: clamp(1rem, 1.8vw, 1.45rem);
    font-weight: 500;
    line-height: 1.1;
    margin: 0;
}

.solar-location__flag {
    background: linear-gradient(180deg, #ffd600 0 33%, #005bbb 33% 66%, #ef3340 66% 100%);
    box-shadow: 0 0 0 1px rgba(255, 255, 255, .18);
    display: inline-block;
    flex: 0 0 auto;
    height: 16px;
    width: 26px;
}

.solar-location-map {
    flex: 1 1 auto;
    min-height: 340px;
    width: 100%;
}

.solar-location-map .leaflet-control-attribution {
    font-size: .68rem;
}

.solar-location-map__marker {
    align-items: center;
    background: rgba(237, 28, 36, .18);
    border-radius: 999px;
    display: flex;
    justify-content: center;
}

.solar-location-map__marker span {
    background: var(--orika-red);
    border: 3px solid #ffffff;
    border-radius: 999px;
    box-shadow: 0 8px 18px rgba(1, 34, 50, .32);
    display: block;
    height: 18px;
    position: relative;
    width: 18px;
}

.solar-location-map__marker span::after {
    background: var(--orika-red);
    bottom: -8px;
    content: "";
    height: 10px;
    left: 50%;
    position: absolute;
    transform: translateX(-50%) rotate(45deg);
    width: 10px;
    z-index: -1;
}

.solar-location__photo {
    background: #014059;
    position: relative;
}

.solar-location__photo img {
    display: block;
    height: 100%;
    min-height: 390px;
    object-fit: cover;
    width: 100%;
}

.solar-location-slider {
    isolation: isolate;
}

.solar-location-slider__slide {
    animation: solarLocationSlide 24s infinite;
    inset: 0;
    margin: 0;
    opacity: 0;
    position: absolute;
    transform: scale(1.025);
}

.solar-location-slider__slide:first-child {
    opacity: 1;
    position: relative;
}

.solar-location-slider__slide:nth-child(2) {
    animation-delay: -18s;
}

.solar-location-slider__slide:nth-child(3) {
    animation-delay: -12s;
}

.solar-location-slider__slide:nth-child(4) {
    animation-delay: -6s;
}

.solar-location-slider__slide img {
    height: 100%;
    min-height: 390px;
    object-fit: cover;
    width: 100%;
}

.solar-location-slider__slide figcaption {
    background: rgba(1, 64, 89, .9);
    border-left: 4px solid var(--orika-yellow);
    bottom: 18px;
    color: #ffffff;
    font-size: .9rem;
    font-weight: 900;
    left: 18px;
    min-height: 36px;
    padding: 9px 14px;
    position: absolute;
    z-index: 2;
}

@keyframes solarLocationSlide {
    0%,
    20% {
        opacity: 1;
        transform: scale(1);
    }

    25%,
    95% {
        opacity: 0;
        transform: scale(1.035);
    }

    100% {
        opacity: 1;
        transform: scale(1);
    }
}

.maritorio-feature {
    background: #f6f9f8;
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(0, 1.04fr) minmax(360px, .96fr);
    padding: 18px 18px 0;
}

.maritorio-feature__map,
.maritorio-feature__copy {
    min-height: 520px;
}

.maritorio-feature__map {
    background: linear-gradient(135deg, #036781, #014059);
    border-radius: 8px;
    overflow: hidden;
    position: relative;
}

.maritorio-feature__sea {
    background:
        linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px),
        radial-gradient(circle at 80% 32%, rgba(255, 200, 69, .16), transparent 18%),
        linear-gradient(135deg, #045f78, #047b96);
    background-size: 56px 56px, 56px 56px, auto, auto;
    height: 100%;
    overflow: hidden;
    position: relative;
}

.maritorio-feature__sea strong {
    bottom: 36px;
    color: rgba(255, 255, 255, .18);
    font-family: "Arial Black", Impact, sans-serif;
    font-size: clamp(4rem, 10vw, 7rem);
    left: 24px;
    line-height: .85;
    position: absolute;
    text-transform: uppercase;
}

.maritorio-feature__land {
    background: linear-gradient(135deg, #e1aa62, #c88a42);
    border-radius: 42% 58% 51% 49%;
    display: block;
    filter: drop-shadow(0 18px 40px rgba(0, 0, 0, .18));
    position: absolute;
}

.maritorio-feature__land--cartagena {
    height: 260px;
    left: -80px;
    top: 82px;
    width: 260px;
}

.maritorio-feature__route {
    border-top: 2px dashed rgba(255, 255, 255, .5);
    left: 150px;
    position: absolute;
    top: 248px;
    transform: rotate(-8deg);
    transform-origin: left center;
    width: 360px;
}

.maritorio-feature__island {
    background: #ffc845;
    border-radius: 999px;
    display: block;
    position: absolute;
}

.maritorio-feature__island--one {
    height: 18px;
    right: 170px;
    top: 242px;
    width: 18px;
}

.maritorio-feature__island--two {
    box-shadow: 32px 21px 0 rgba(255, 200, 69, .76), -42px 10px 0 rgba(255, 200, 69, .82), 54px -28px 0 rgba(255, 200, 69, .68);
    height: 22px;
    right: 118px;
    top: 268px;
    width: 22px;
}

.maritorio-feature__pin {
    align-items: center;
    color: #fff;
    display: inline-flex;
    font-family: "Arial Black", Impact, sans-serif;
    font-size: .8rem;
    gap: 8px;
    position: absolute;
    text-transform: uppercase;
    white-space: nowrap;
}

.maritorio-feature__pin::before {
    background: #ed1c24;
    border: 5px solid rgba(255, 255, 255, .88);
    border-radius: 999px;
    box-shadow: 0 0 0 10px rgba(237, 28, 36, .24);
    content: "";
    height: 24px;
    width: 24px;
}

.maritorio-feature__pin--cartagena {
    left: 118px;
    top: 222px;
}

.maritorio-feature__pin--rosario {
    right: 58px;
    top: 254px;
}

.maritorio-feature__pin--rosario::before {
    background: #ffc845;
    box-shadow: 0 0 0 16px rgba(255, 200, 69, .18);
}

.maritorio-feature__copy {
    align-items: flex-start;
    background: #014059;
    border-radius: 8px;
    color: #fff;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: clamp(34px, 5vw, 68px);
}

.maritorio-feature__kicker,
.maritorio-split__copy span {
    align-items: center;
    color: #ffc845;
    display: inline-flex;
    font-family: "Arial Black", Impact, sans-serif;
    font-size: .78rem;
    gap: 12px;
    letter-spacing: .02em;
    text-transform: uppercase;
}

.maritorio-feature__kicker::before,
.maritorio-split__copy span::before {
    background: #ffc845;
    content: "";
    height: 2px;
    width: 34px;
}

.maritorio-feature__copy h2,
.maritorio-principles h2,
.maritorio-split h2 {
    color: #fff;
    font-family: "Arial Black", Impact, sans-serif;
    font-size: clamp(2.4rem, 4.8vw, 4.7rem);
    line-height: .95;
    margin: 22px 0;
}

.maritorio-feature__copy p,
.maritorio-split p {
    color: rgba(255, 255, 255, .94);
    font-size: clamp(1rem, 1.55vw, 1.2rem);
    font-weight: 700;
    line-height: 1.48;
    margin: 0;
}

.maritorio-feature__facts {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin: 30px 0;
    width: 100%;
}

.maritorio-feature__facts span {
    background: rgba(255, 255, 255, .09);
    border-left: 3px solid #ffc845;
    border-radius: 6px;
    color: #fff;
    font-weight: 900;
    padding: 16px;
}

.maritorio-split {
    background: #fff;
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
    padding: 18px;
}

.maritorio-split__copy,
.maritorio-split__panel,
.maritorio-principles {
    border-radius: 8px;
}

.maritorio-split__copy {
    background: linear-gradient(135deg, #005f83, #014059);
    padding: clamp(34px, 5vw, 72px);
}

.maritorio-split__panel {
    align-content: center;
    background: #ffc845;
    color: #161616;
    display: grid;
    gap: 18px;
    padding: clamp(28px, 4vw, 48px);
}

.maritorio-split__panel strong {
    font-family: "Arial Black", Impact, sans-serif;
    font-size: clamp(2rem, 4vw, 3.6rem);
    line-height: .94;
}

.maritorio-split__panel span {
    font-weight: 900;
    line-height: 1.4;
}

.maritorio-principles {
    background: #f4f8f7;
    display: grid;
    gap: 26px;
    padding: clamp(38px, 6vw, 76px) clamp(18px, 7vw, 96px);
}

.maritorio-principles h2 {
    color: #014059;
    max-width: 760px;
}

.maritorio-principles__grid {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.maritorio-principles article {
    background: #fff;
    border-bottom: 4px solid #ed1c24;
    border-radius: 8px;
    box-shadow: 0 18px 48px rgba(1, 64, 89, .08);
    padding: 24px;
}

.maritorio-principles article strong {
    color: #014059;
    display: block;
    font-family: "Arial Black", Impact, sans-serif;
    font-size: 1.25rem;
    margin-bottom: 10px;
}

.maritorio-principles article p {
    color: #4a5b66;
    font-weight: 700;
    line-height: 1.48;
    margin: 0;
}

@media (max-width: 860px) {
    .maritorio-feature,
    .maritorio-split,
    .maritorio-principles__grid {
        grid-template-columns: 1fr;
    }

    .maritorio-feature {
        padding: 14px;
    }

    .maritorio-overview {
        padding: 34px 14px 28px;
    }

    .maritorio-overview h2 {
        text-align: left;
    }

    .maritorio-overview p {
        line-height: 1.35;
        text-align: left;
    }

    .maritorio-overview__map {
        border-width: 4px;
        height: 360px;
    }

    .maritorio-docs {
        padding: 28px 14px 42px;
    }

    .maritorio-docs__copy {
        text-align: left;
    }

    .maritorio-docs__timeline,
    .maritorio-docs__grid,
    .org-intro,
    .org-chart-section,
    .org-docs__grid,
    .tourism-intro,
    .tourism-values {
        grid-template-columns: 1fr;
    }

    .org-hero,
    .tourism-hero {
        min-height: 480px;
    }

    .org-hero {
        padding: 112px 18px 74px;
    }

    .tourism-hero {
        min-height: auto;
    }

    .tourism-hero .home-hero__slide {
        align-items: stretch;
        flex-direction: column;
        justify-content: flex-start;
        padding: 96px 12px 36px;
    }

    .tourism-hero__poster {
        max-width: 100%;
        order: 2;
        padding: 7px;
    }

    .tourism-hero__poster img {
        max-height: none;
    }

    .tourism-hero__content {
        left: auto;
        margin-bottom: 14px;
        max-width: 100%;
        order: 1;
        padding: 18px;
        position: relative;
        top: auto;
        transform: none;
    }

    .tourism-hero h1 {
        font-size: 2.25rem;
    }

    .tourism-hero p {
        font-size: .94rem;
    }

    .org-intro,
    .org-chart-section,
    .org-docs,
    .tourism-intro,
    .tourism-values,
    .tourism-map-section,
    .tourism-gallery {
        padding-left: 14px;
        padding-right: 14px;
    }

    .tourism-map-section__header {
        text-align: left;
    }

    .tourism-map-section__header .org-section-label {
        justify-content: flex-start;
    }

    .tourism-map-section__frame {
        border-width: 4px;
        height: 460px;
    }

    .tourism-gallery__header {
        text-align: left;
    }

    .tourism-gallery__header .org-section-label {
        justify-content: flex-start;
    }

    .tourism-gallery__grid {
        grid-template-columns: 1fr;
    }

    .relatos-hero,
    .relatos-intro,
    .relatos-grid,
    .solar-intro,
    .solar-values,
    .solar-system__grid,
    .solar-consumption,
    .solar-consumption__cards,
    .solar-gallery__grid,
    .solar-location__grid {
        grid-template-columns: 1fr;
        padding-left: 14px;
        padding-right: 14px;
    }

    .solar-generation__hero,
    .solar-generation__grid,
    .solar-measurement__grid {
        grid-template-columns: 1fr;
    }

    .solar-generation__diagram {
        min-height: auto;
    }

    .relatos-hero {
        min-height: auto;
        padding-bottom: 96px;
        padding-top: 108px;
    }

    .relatos-hero__content {
        order: 1;
        padding-left: 18px;
    }

    .relatos-hero__preview {
        align-self: stretch;
        order: 3;
    }

    .relatos-scroll-cue {
        animation-name: relatosScrollCueMobile;
        bottom: auto;
        justify-content: center;
        justify-self: start;
        left: auto;
        max-width: calc(100% - 28px);
        order: 2;
        position: relative;
        text-align: center;
        transform: none;
        white-space: normal;
        width: max-content;
    }

    .relatos-intro {
        align-items: start;
    }

    .solar-hero {
        min-height: 500px;
        padding: 108px 14px 72px;
    }

    .solar-hero__content {
        padding-left: 18px;
    }

    .solar-intro,
    .solar-system,
    .solar-consumption,
    .solar-gallery,
    .solar-measurement,
    .solar-payment,
    .solar-interest__links,
    .solar-interest__entities,
    .solar-location {
        padding-left: 14px;
        padding-right: 14px;
    }

    .solar-interest__grid,
    .solar-entities__grid {
        grid-template-columns: 1fr;
    }

    .solar-entity-card,
    .solar-entity-card:nth-child(5),
    .solar-entity-card:nth-child(6),
    .solar-entity-card:nth-child(7) {
        grid-column: auto;
    }

    .solar-system__header,
    .solar-gallery__header,
    .solar-location__header {
        text-align: left;
    }

    .solar-system__header .org-section-label,
    .solar-gallery__header .org-section-label {
        justify-content: flex-start;
    }

    .solar-system__stats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .solar-gallery__item--wide {
        grid-column: auto;
    }

    .solar-gallery__item--wide img {
        aspect-ratio: 16 / 10;
    }

    .solar-location__header h2 span {
        display: block;
        margin: 8px 0 0;
    }

    .solar-location__map-card,
    .solar-location__photo {
        border-width: 4px;
        min-height: 320px;
    }

    .solar-location-map,
    .solar-location__photo img {
        min-height: 320px;
    }

    .solar-location-slider__slide img {
        min-height: 320px;
    }

    .solar-location-slider__slide figcaption {
        bottom: 12px;
        left: 12px;
    }

    .solar-system__stats {
        grid-template-columns: 1fr;
    }

    .solar-tabs {
        display: flex;
        gap: 8px;
        grid-template-columns: none;
        overflow-x: auto;
        padding: 10px 12px;
        top: 0;
        scrollbar-width: thin;
    }

    .solar-tabs__item {
        flex: 0 0 auto;
        min-height: 40px;
        max-width: none;
        width: auto;
        padding: 0 14px;
    }

    .solar-tabs__item:first-child {
        flex-basis: auto;
        max-width: none;
    }

    .solar-tabs__icon {
        height: 24px;
        width: 24px;
    }

    .tourism-gallery__item,
    .tourism-gallery__item--featured {
        grid-column: auto;
        grid-row: auto;
        min-height: 260px;
    }

    .tourism-map-float {
        bottom: 14px;
        justify-content: center;
        left: 14px;
        min-height: 50px;
        right: 14px;
    }

    .org-docs__header {
        text-align: left;
    }

    .maritorio-feature__map,
    .maritorio-feature__copy {
        min-height: 420px;
    }

    .maritorio-feature__facts {
        grid-template-columns: 1fr;
    }

    .site-error-page {
        grid-template-columns: 1fr;
    }

    .site-error-page__panel {
        align-self: stretch;
    }
}

@keyframes relatosScrollCueMobile {
    0%,
    100% {
        transform: translateY(0);
    }

    50% {
        transform: translateY(7px);
    }
}

html {
    scroll-behavior: smooth;
}

.site-shell {
    background: #ffffff;
    color: var(--orika-ink);
    font-family: "Barlow", "Segoe UI", Arial, sans-serif;
}

.public-navbar {
    background: linear-gradient(90deg, var(--orika-red), var(--orika-red-dark));
    border-bottom: 3px solid rgba(255, 206, 96, .92);
    box-shadow: 0 10px 24px rgba(46, 40, 33, .16);
    min-height: 76px;
    position: relative;
    z-index: 10;
}

.public-navbar .container {
    max-width: 1160px;
    padding-left: 22px;
    padding-right: 22px;
}

.public-navbar .navbar-collapse {
    min-width: 0;
}

.public-navbar .navbar-nav {
    align-items: center;
    flex-wrap: nowrap;
    gap: 3px;
    justify-content: flex-end;
    min-width: 0;
    width: 100%;
}

.public-navbar .navbar-brand,
.public-navbar .nav-link {
    color: #ffffff;
}

.public-navbar__brand {
    align-items: center;
    display: flex;
    min-height: 54px;
    padding: 0;
}

.public-navbar__logo {
    display: block;
    max-height: 58px;
    width: auto;
}

.public-navbar .nav-link {
    border-radius: 999px;
    font-size: .88rem;
    font-weight: 700;
    line-height: 1.1;
    margin: 0;
    padding: 10px 11px;
    position: relative;
    transition: background-color .18s ease, color .18s ease, transform .18s ease;
    white-space: nowrap;
}

.public-navbar .nav-link.active,
.public-navbar .nav-link:hover,
.public-navbar .nav-link:focus {
    background: rgba(255, 206, 96, .16);
    color: var(--orika-yellow);
}

.public-navbar .nav-link:hover,
.public-navbar .nav-link:focus {
    transform: translateY(-1px);
}

.public-navbar .nav-link.active {
    background: rgba(255, 206, 96, .22);
    box-shadow: inset 0 0 0 1px rgba(255, 206, 96, .16);
}

.public-navbar .navbar-toggler {
    border-color: rgba(255, 255, 255, .65);
    border-radius: 8px;
    padding: 7px 9px;
}

.public-navbar .navbar-toggler-icon {
    filter: invert(1);
}

.public-admin-link {
    background: var(--orika-yellow);
    border: 1px solid var(--orika-yellow);
    border-radius: 0;
    color: var(--orika-ink);
    font-weight: 600;
    padding: 8px 16px;
    text-decoration: none;
}

.public-admin-link:hover,
.public-admin-link:focus {
    background: var(--orika-yellow-dark);
    border-color: var(--orika-yellow-dark);
    color: var(--orika-ink);
}

.public-main {
    padding-top: 0;
}

.public-container {
    width: 100%;
}

.home-hero {
    align-items: center;
    background:
        linear-gradient(90deg, rgba(46, 40, 33, .76), rgba(237, 28, 36, .18)),
        url("https://images.unsplash.com/photo-1507525428034-b723cf961d3e?auto=format&fit=crop&w=1800&q=80");
    color: #ffffff;
    display: flex;
    min-height: calc(100vh - 82px);
    overflow: hidden;
    padding: 72px max(24px, 7vw);
    position: relative;
}

.home-hero::after {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0), #ffffff);
    bottom: 0;
    content: "";
    height: 96px;
    left: 0;
    pointer-events: none;
    position: absolute;
    right: 0;
}

.home-hero__content {
    max-width: 820px;
    position: relative;
    z-index: 2;
}

.home-hero__slides {
    inset: 0;
    position: absolute;
    z-index: 0;
}

.home-hero__slide {
    animation: heroSlideFade var(--carousel-duration) infinite;
    animation-delay: var(--slide-delay);
    background-position: center;
    background-size: cover;
    inset: 0;
    opacity: 0;
    position: absolute;
    transform: scale(1.03);
}

.home-hero__slide:first-child {
    opacity: 1;
}

.home-hero:not(.home-hero--carousel) .home-hero__slide {
    animation: none;
}

@keyframes heroSlideFade {
    0% {
        opacity: 1;
        transform: scale(1);
    }

    8% {
        opacity: 1;
    }

    14% {
        opacity: 0;
        transform: scale(1.04);
    }

    94% {
        opacity: 0;
        transform: scale(1.04);
    }

    100% {
        opacity: 1;
        transform: scale(1);
    }
}

.home-hero__eyebrow {
    background: var(--orika-yellow);
    border-radius: 15px;
    color: var(--orika-ink);
    display: inline-block;
    font-size: .86rem;
    font-weight: 800;
    letter-spacing: .08em;
    margin-bottom: 14px;
    padding: 2px 15px;
    text-transform: uppercase;
}

.home-hero h1 {
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(2.45rem, 6vw, 5.4rem);
    font-weight: 700;
    line-height: 1.02;
    margin: 0;
}

.home-hero p {
    color: rgba(255, 255, 255, .92);
    font-size: 1.2rem;
    line-height: 1.7;
    margin: 22px 0 0;
    max-width: 650px;
}

.home-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-top: 28px;
}

.home-scroll-cue {
    align-items: center;
    background: rgba(46, 40, 33, .32);
    border: 1px solid rgba(255, 255, 255, .52);
    border-radius: 999px;
    color: #ffffff;
    display: inline-flex;
    font-size: .9rem;
    font-weight: 600;
    gap: 10px;
    padding: 9px 15px 9px 18px;
    text-decoration: none;
}

.home-scroll-cue::after {
    border-bottom: 2px solid currentColor;
    border-right: 2px solid currentColor;
    content: "";
    height: 8px;
    margin-top: -4px;
    transform: rotate(45deg);
    width: 8px;
}

.home-scroll-cue:hover,
.home-scroll-cue:focus {
    background: var(--orika-yellow);
    border-color: var(--orika-yellow);
    color: var(--orika-ink);
}

.relatos-scroll-cue:hover,
.relatos-scroll-cue:focus {
    background: var(--orika-yellow);
    border-color: var(--orika-yellow);
    box-shadow: 0 20px 42px rgba(1, 34, 50, .34);
    color: var(--orika-ink);
}

.home-button {
    border-radius: 0;
    display: inline-flex;
    font-weight: 600;
    padding: 12px 22px;
    text-decoration: none;
}

.home-button--primary {
    background: var(--orika-yellow);
    color: var(--orika-ink);
}

.home-button--primary:hover,
.home-button--primary:focus {
    background: var(--orika-yellow-dark);
    color: var(--orika-ink);
}

.home-button--ghost {
    background: rgba(255, 255, 255, .08);
    border: 1px solid rgba(255, 255, 255, .62);
    color: #ffffff;
}

.territory-intro {
    background:
        linear-gradient(180deg, #ffffff 0%, #f6f8f7 100%);
    color: #ffffff;
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(0, 1.05fr) minmax(390px, .95fr);
    min-height: 540px;
    padding: 28px clamp(18px, 3.6vw, 48px);
    position: relative;
}

.territory-intro__media {
    background: #014059;
    border-radius: 8px;
    box-shadow: 0 18px 40px rgba(1, 64, 89, .16);
    min-height: 484px;
    overflow: hidden;
    position: relative;
}

.territory-intro__media::after {
    background:
        linear-gradient(90deg, rgba(1, 64, 89, 0) 58%, rgba(1, 64, 89, .22)),
        linear-gradient(180deg, rgba(1, 64, 89, 0), rgba(1, 64, 89, .28));
    content: "";
    inset: 0;
    pointer-events: none;
    position: absolute;
}

.territory-intro__media img {
    display: block;
    height: 100%;
    object-fit: cover;
    object-position: center;
    transform: scale(1.01);
    width: 100%;
}

.territory-intro__media-label {
    align-items: center;
    backdrop-filter: blur(10px);
    background: rgba(1, 64, 89, .72);
    border: 1px solid rgba(255, 255, 255, .2);
    border-left: 4px solid var(--orika-yellow);
    border-radius: 6px;
    bottom: 24px;
    color: #ffffff;
    display: inline-flex;
    font-size: .84rem;
    font-weight: 700;
    left: 24px;
    padding: 10px 14px;
    position: absolute;
    text-transform: uppercase;
    z-index: 1;
}

.territory-intro__copy {
    align-items: flex-start;
    background:
        radial-gradient(circle at 92% 8%, rgba(255, 206, 96, .17), transparent 25%),
        linear-gradient(135deg, #005f83 0%, #014059 100%);
    border-radius: 8px;
    box-shadow: 0 18px 40px rgba(1, 64, 89, .16);
    display: flex;
    flex-direction: column;
    justify-content: center;
    overflow: hidden;
    padding: 64px clamp(36px, 5vw, 78px);
    position: relative;
    text-align: left;
}

.territory-intro__copy::before {
    background:
        linear-gradient(135deg, rgba(255, 255, 255, .18), rgba(255, 255, 255, 0));
    content: "";
    height: 180px;
    position: absolute;
    right: -46px;
    top: -72px;
    transform: rotate(18deg);
    width: 180px;
}

.territory-intro__copy > * {
    position: relative;
    z-index: 1;
}

.territory-intro__copy::after {
    background: rgba(255, 255, 255, .08);
    bottom: 24px;
    content: "";
    height: 1px;
    left: 36px;
    position: absolute;
    right: 36px;
}

.territory-intro__kicker {
    align-items: center;
    color: var(--orika-yellow);
    display: inline-flex;
    font-size: .78rem;
    font-weight: 800;
    gap: 10px;
    margin-bottom: 12px;
    text-transform: uppercase;
}

.territory-intro__kicker::before {
    background: currentColor;
    content: "";
    height: 2px;
    width: 34px;
}

.territory-intro__copy h2 {
    color: #ffffff;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(2.35rem, 4vw, 3.35rem);
    font-weight: 700;
    line-height: 1.05;
    margin: 0 0 24px;
    max-width: 560px;
}

.territory-intro__copy p {
    color: #ffffff;
    font-size: 1.08rem;
    font-weight: 500;
    line-height: 1.45;
    margin: 0;
    max-width: 610px;
    text-align: left;
}

.territory-intro__facts {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-top: 28px;
    max-width: 600px;
    width: 100%;
}

.territory-intro__facts span {
    background: rgba(255, 255, 255, .1);
    border-left: 3px solid var(--orika-yellow);
    border-radius: 6px;
    color: rgba(255, 255, 255, .88);
    font-size: .88rem;
    line-height: 1.25;
    min-height: 76px;
    padding: 13px 14px 12px;
    text-align: left;
}

.territory-intro__facts strong {
    color: #ffffff;
    display: block;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: 1.35rem;
    line-height: 1;
}

.territory-intro__link {
    align-items: center;
    background: var(--orika-yellow);
    border: 0;
    border-radius: 6px;
    color: var(--orika-ink);
    cursor: pointer;
    display: inline-flex;
    font-size: .9rem;
    gap: 12px;
    font-weight: 800;
    margin-top: 32px;
    padding: 11px 18px;
    text-decoration: none;
}

.territory-intro__link::after {
    border-right: 2px solid currentColor;
    border-top: 2px solid currentColor;
    content: "";
    height: 8px;
    transform: rotate(45deg);
    width: 8px;
}

.territory-intro__link:hover,
.territory-intro__link:focus {
    background: #ffffff;
    color: var(--orika-red);
}

.community-section {
    background: #ffffff;
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(390px, .95fr) minmax(0, 1.05fr);
    padding: 0 clamp(18px, 3.6vw, 48px) 28px;
}

.community-section__copy {
    align-items: flex-start;
    background:
        radial-gradient(circle at 14% 14%, rgba(255, 206, 96, .16), transparent 26%),
        linear-gradient(135deg, #005f83 0%, #014059 100%);
    border-radius: 8px;
    box-shadow: 0 18px 40px rgba(1, 64, 89, .14);
    color: #ffffff;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 390px;
    overflow: hidden;
    padding: 56px clamp(34px, 5vw, 72px);
    position: relative;
}

.community-section__kicker {
    align-items: center;
    color: var(--orika-yellow);
    display: inline-flex;
    font-size: .78rem;
    font-weight: 800;
    gap: 10px;
    margin-bottom: 14px;
    text-transform: uppercase;
}

.community-section__kicker::before {
    background: currentColor;
    content: "";
    height: 2px;
    width: 34px;
}

.community-section__copy h2 {
    color: #ffffff;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(2rem, 3.4vw, 2.9rem);
    font-weight: 700;
    line-height: 1.08;
    margin: 0 0 24px;
}

.community-section__copy p {
    color: rgba(255, 255, 255, .95);
    font-size: 1.08rem;
    font-weight: 500;
    line-height: 1.48;
    margin: 0;
    max-width: 620px;
}

.community-section__media {
    background: #014059;
    border-radius: 8px;
    box-shadow: 0 18px 40px rgba(1, 64, 89, .14);
    margin: 0;
    min-height: 390px;
    overflow: hidden;
    position: relative;
}

.community-section__media::after {
    background: linear-gradient(180deg, rgba(1, 64, 89, 0) 48%, rgba(1, 64, 89, .8));
    content: "";
    inset: 0;
    pointer-events: none;
    position: absolute;
}

.community-section__slides {
    inset: 0;
    position: absolute;
}

.community-section__slide {
    animation: communitySlideFade var(--community-carousel-duration) infinite;
    animation-delay: var(--community-slide-delay);
    display: block;
    height: 100%;
    inset: 0;
    object-fit: cover;
    object-position: center;
    opacity: 0;
    position: absolute;
    transform: scale(1.02);
    width: 100%;
}

.community-section__slide--contain {
    background: linear-gradient(180deg, #fff5c9, #e0efe4);
    object-fit: contain;
    padding: 12px 12px 48px;
}

.community-section__slide:first-child {
    opacity: 1;
}

.community-section__media figcaption {
    background: rgba(1, 64, 89, .88);
    border-left: 4px solid var(--orika-yellow);
    bottom: 0;
    color: #ffffff;
    font-size: .92rem;
    font-weight: 800;
    left: 0;
    margin: 0;
    padding: 13px 18px;
    position: absolute;
    right: 0;
    text-align: center;
    text-transform: capitalize;
    z-index: 1;
}

.community-section__view-button {
    align-items: center;
    background: var(--orika-yellow);
    border: 0;
    border-radius: 6px;
    bottom: 58px;
    box-shadow: 0 12px 24px rgba(1, 64, 89, .24);
    color: #13251f;
    display: inline-flex;
    font-size: .86rem;
    font-weight: 800;
    justify-content: center;
    line-height: 1;
    min-height: 38px;
    padding: 0 18px;
    position: absolute;
    right: 18px;
    text-transform: uppercase;
    transition: background .2s ease, color .2s ease, transform .2s ease;
    z-index: 2;
}

.community-section__view-button:hover,
.community-section__view-button:focus {
    background: #ffffff;
    color: var(--orika-red);
    transform: translateY(-1px);
}

.community-section__dots {
    align-items: center;
    display: flex;
    gap: 7px;
    position: absolute;
    right: 18px;
    top: 18px;
    z-index: 1;
}

.community-section__dots span {
    animation: communityDotPulse var(--community-carousel-duration) infinite;
    animation-delay: var(--community-dot-delay);
    background: rgba(255, 255, 255, .56);
    border-radius: 999px;
    display: block;
    height: 7px;
    width: 7px;
}

@keyframes communitySlideFade {
    0% {
        opacity: 1;
        transform: scale(1);
    }

    13% {
        opacity: 1;
    }

    16.6% {
        opacity: 0;
        transform: scale(1.035);
    }

    94% {
        opacity: 0;
        transform: scale(1.035);
    }

    100% {
        opacity: 1;
        transform: scale(1);
    }
}

@keyframes communityDotPulse {
    0%,
    16% {
        background: var(--orika-yellow);
        transform: scale(1.45);
    }

    17%,
    100% {
        background: rgba(255, 255, 255, .56);
        transform: scale(1);
    }
}

.organization-section {
    background: #ffffff;
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(0, 1.05fr) minmax(390px, .95fr);
    padding: 0 clamp(18px, 3.6vw, 48px) 28px;
}

.organization-section__media {
    background: #014059;
    border-radius: 8px;
    box-shadow: 0 18px 40px rgba(1, 64, 89, .14);
    margin: 0;
    min-height: 390px;
    overflow: hidden;
    position: relative;
}

.organization-section__media::after {
    background: linear-gradient(180deg, rgba(1, 64, 89, 0), rgba(1, 64, 89, .2));
    content: "";
    inset: 0;
    pointer-events: none;
    position: absolute;
}

.organization-section__media img {
    display: block;
    height: 100%;
    object-fit: cover;
    object-position: center;
    width: 100%;
}

.organization-section__copy {
    align-items: flex-start;
    background:
        radial-gradient(circle at 88% 12%, rgba(255, 206, 96, .16), transparent 26%),
        linear-gradient(135deg, #005f83 0%, #014059 100%);
    border-radius: 8px;
    box-shadow: 0 18px 40px rgba(1, 64, 89, .14);
    color: #ffffff;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 390px;
    overflow: hidden;
    padding: 56px clamp(34px, 5vw, 72px);
    position: relative;
}

.organization-section__kicker {
    align-items: center;
    color: var(--orika-yellow);
    display: inline-flex;
    font-size: .78rem;
    font-weight: 800;
    gap: 10px;
    margin-bottom: 14px;
    text-transform: uppercase;
}

.organization-section__kicker::before {
    background: currentColor;
    content: "";
    height: 2px;
    width: 34px;
}

.organization-section__copy h2 {
    color: #ffffff;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(2rem, 3.4vw, 2.9rem);
    font-weight: 700;
    line-height: 1.08;
    margin: 0 0 24px;
}

.organization-section__copy p {
    color: rgba(255, 255, 255, .95);
    font-size: 1.08rem;
    font-weight: 500;
    line-height: 1.48;
    margin: 0;
    max-width: 650px;
}

.organization-section__button {
    align-items: center;
    background: var(--orika-yellow);
    border: 0;
    border-radius: 6px;
    color: var(--orika-ink);
    display: inline-flex;
    font-size: .9rem;
    font-weight: 800;
    gap: 12px;
    margin-top: 28px;
    padding: 11px 18px;
}

.organization-section__button::after {
    border-right: 2px solid currentColor;
    border-top: 2px solid currentColor;
    content: "";
    height: 8px;
    transform: rotate(45deg);
    width: 8px;
}

.organization-section__button:hover,
.organization-section__button:focus {
    background: #ffffff;
    color: var(--orika-red);
}

.timeline-modal .modal-content {
    border: 0;
    border-radius: 8px;
    overflow: hidden;
}

.timeline-modal .modal-header {
    background: #014059;
    border: 0;
    color: #ffffff;
}

.timeline-modal .modal-title {
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: 1.55rem;
    font-weight: 700;
}

.timeline-modal .btn-close {
    filter: invert(1);
    opacity: .9;
}

.timeline-modal .modal-body {
    background: #f6f8f7;
    padding: 0;
}

.timeline-modal .modal-body img {
    display: block;
    height: auto;
    width: 100%;
}

.enterprise-section {
    background: #ffffff;
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(390px, .95fr) minmax(0, 1.05fr);
    padding: 0 clamp(18px, 3.6vw, 48px) 28px;
}

.enterprise-section__copy {
    align-items: flex-start;
    background:
        radial-gradient(circle at 18% 20%, rgba(255, 206, 96, .14), transparent 26%),
        linear-gradient(135deg, #005f83 0%, #014059 100%);
    border-radius: 8px;
    box-shadow: 0 18px 40px rgba(1, 64, 89, .14);
    color: #ffffff;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 390px;
    overflow: hidden;
    padding: 56px clamp(34px, 5vw, 72px);
    position: relative;
}

.enterprise-section__kicker {
    align-items: center;
    color: var(--orika-yellow);
    display: inline-flex;
    font-size: .78rem;
    font-weight: 800;
    gap: 10px;
    margin-bottom: 14px;
    text-transform: uppercase;
}

.enterprise-section__kicker::before {
    background: currentColor;
    content: "";
    height: 2px;
    width: 34px;
}

.enterprise-section__copy h2 {
    color: #ffffff;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(2rem, 3.4vw, 2.9rem);
    font-weight: 700;
    line-height: 1.08;
    margin: 0 0 24px;
    max-width: 520px;
}

.enterprise-section__copy p {
    color: rgba(255, 255, 255, .95);
    font-size: 1.08rem;
    font-weight: 500;
    line-height: 1.48;
    margin: 0;
    max-width: 650px;
}

.enterprise-section__link {
    align-items: center;
    background: var(--orika-yellow);
    border: 0;
    border-radius: 6px;
    color: var(--orika-ink);
    cursor: pointer;
    display: inline-flex;
    font-size: .9rem;
    font-weight: 800;
    gap: 12px;
    margin-top: 28px;
    padding: 11px 18px;
}

.enterprise-section__link::after {
    border-right: 2px solid currentColor;
    border-top: 2px solid currentColor;
    content: "";
    height: 8px;
    transform: rotate(45deg);
    width: 8px;
}

.enterprise-section__link:hover,
.enterprise-section__link:focus {
    background: #ffffff;
    color: var(--orika-red);
}

.enterprise-section__media {
    background: #014059;
    border-radius: 8px;
    box-shadow: 0 18px 40px rgba(1, 64, 89, .14);
    margin: 0;
    min-height: 390px;
    overflow: hidden;
    position: relative;
}

.enterprise-section__slides {
    inset: 0;
    position: absolute;
}

.enterprise-section__slide {
    animation: communitySlideFade var(--enterprise-carousel-duration) infinite;
    animation-delay: var(--enterprise-slide-delay);
    inset: 0;
    opacity: 0;
    position: absolute;
    transform: scale(1.02);
}

.enterprise-section__slide:first-child {
    opacity: 1;
}

.enterprise-section__slide img {
    display: block;
    height: 100%;
    object-fit: cover;
    object-position: center;
    width: 100%;
}

.enterprise-section__slide::after {
    background: linear-gradient(180deg, rgba(1, 64, 89, 0) 52%, rgba(1, 64, 89, .78));
    content: "";
    inset: 0;
    pointer-events: none;
    position: absolute;
}

.enterprise-section__slide figcaption {
    background: rgba(1, 64, 89, .9);
    border-left: 4px solid var(--orika-yellow);
    bottom: 0;
    color: #ffffff;
    font-size: .92rem;
    font-weight: 800;
    left: 0;
    margin: 0;
    min-width: min(340px, 72%);
    padding: 13px 18px;
    position: absolute;
    text-align: center;
    text-transform: capitalize;
    z-index: 1;
}

.enterprise-section__dots {
    align-items: center;
    display: flex;
    gap: 7px;
    position: absolute;
    right: 18px;
    top: 18px;
    z-index: 2;
}

.enterprise-section__dots span {
    animation: enterpriseDotPulse var(--enterprise-carousel-duration) infinite;
    animation-delay: var(--enterprise-dot-delay);
    background: rgba(255, 255, 255, .58);
    border-radius: 999px;
    display: block;
    height: 7px;
    width: 7px;
}

@keyframes enterpriseDotPulse {
    0%,
    12.5% {
        background: var(--orika-yellow);
        transform: scale(1.45);
    }

    13%,
    100% {
        background: rgba(255, 255, 255, .58);
        transform: scale(1);
    }
}

.social-section {
    background:
        linear-gradient(90deg, rgba(1, 64, 89, .92), rgba(0, 95, 131, .76)),
        url("../img/site/territorio-habitamos.webp") center / cover;
    color: #ffffff;
    padding: 34px clamp(18px, 3.6vw, 48px) 42px;
}

.social-section__inner {
    align-items: center;
    border: 1px solid rgba(255, 255, 255, .18);
    border-radius: 8px;
    display: flex;
    flex-direction: column;
    margin: 0 auto;
    max-width: 1080px;
    padding: clamp(38px, 6vw, 68px) clamp(24px, 5vw, 64px);
    position: relative;
    text-align: center;
}

.social-section__inner::before {
    background: var(--orika-yellow);
    content: "";
    height: 3px;
    left: 50%;
    position: absolute;
    top: 0;
    transform: translateX(-50%);
    width: min(180px, 42%);
}

.social-section__kicker {
    color: var(--orika-yellow);
    font-size: .78rem;
    font-weight: 800;
    letter-spacing: 0;
    margin-bottom: 12px;
    text-transform: uppercase;
}

.social-section h2 {
    color: #ffffff;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(2.2rem, 5vw, 3.6rem);
    font-weight: 700;
    line-height: 1.03;
    margin: 0 0 18px;
}

.social-section p {
    color: rgba(255, 255, 255, .92);
    font-size: 1.04rem;
    font-weight: 500;
    line-height: 1.5;
    margin: 0;
    max-width: 690px;
}

.social-section__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: center;
    margin-top: 30px;
}

.social-section__button {
    align-items: center;
    background: #ffffff;
    border-radius: 8px;
    box-shadow: 0 16px 34px rgba(1, 64, 89, .22);
    color: var(--orika-ink);
    display: inline-flex;
    gap: 14px;
    min-width: 230px;
    padding: 15px 18px;
    text-align: left;
    text-decoration: none;
    transition: color .2s ease, transform .2s ease, box-shadow .2s ease;
}

.social-section__icon {
    align-items: center;
    border-radius: 8px;
    color: #ffffff;
    display: inline-flex;
    flex: 0 0 auto;
    height: 38px;
    justify-content: center;
    line-height: 1;
    width: 38px;
}

.social-section__icon svg {
    display: block;
    fill: currentColor;
    height: 20px;
    width: 20px;
}

.social-section__icon img {
    display: block;
    height: 20px;
    width: 20px;
}

.social-section__icon--facebook {
    background: #1877f2;
}

.social-section__icon--instagram {
    background:
        radial-gradient(circle at 30% 107%, #fdf497 0 18%, #fd5949 42%, #d6249f 62%, #285aeb 100%);
}

.social-section__icon--mail {
    background: #ffffff;
    box-shadow: inset 0 0 0 1px rgba(1, 64, 89, .10);
}

.social-section__button-copy {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
}

.social-section__button-copy strong {
    color: var(--orika-red);
    font-size: .95rem;
    font-weight: 800;
    text-transform: uppercase;
}

.social-section__button-copy small {
    color: var(--orika-muted);
    font-size: .86rem;
    font-weight: 700;
    overflow-wrap: anywhere;
}

.social-section__external {
    align-items: center;
    color: rgba(1, 64, 89, .56);
    display: inline-flex;
    margin-left: auto;
}

.social-section__external svg {
    display: block;
    fill: none;
    height: 18px;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 2;
    width: 18px;
}

.social-section__button:hover,
.social-section__button:focus {
    color: var(--orika-red);
    box-shadow: 0 18px 38px rgba(1, 64, 89, .28);
    transform: translateY(-2px);
}

.social-section__button:hover .social-section__external,
.social-section__button:focus .social-section__external {
    color: var(--orika-red);
}

.home-content {
    display: grid;
    gap: 32px;
    grid-template-columns: minmax(0, 1fr) 320px;
    margin: 0 auto;
    max-width: 1080px;
    padding: 46px 24px 78px;
}

.home-content__main {
    color: var(--orika-text);
    font-size: 1rem;
    line-height: 1.875;
}

.home-content__main h2,
.home-content__main h3 {
    color: var(--orika-ink);
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-weight: 600;
    margin-top: 0;
}

.home-content__main h2 {
    font-size: clamp(2rem, 4vw, 3.1rem);
    line-height: 1.2;
}

.home-content__main p {
    color: var(--orika-text);
}

.home-content__aside {
    align-self: start;
    background: #ffffff;
    border: 1px solid var(--orika-line);
    border-radius: 14px;
    box-shadow: 0 18px 45px rgba(46, 40, 33, .08);
    padding: 24px;
}

.home-content__aside strong,
.home-content__aside span {
    display: block;
}

.home-content__aside strong {
    color: var(--orika-ink);
    font-size: 1.2rem;
}

.home-content__aside span {
    color: var(--orika-red);
    font-weight: 800;
    margin-top: 4px;
}

.home-content__aside p {
    color: var(--orika-text);
    line-height: 1.6;
    margin: 16px 0;
}

.public-footer {
    background:
        linear-gradient(90deg, rgba(1, 64, 89, .98), rgba(0, 95, 131, .96));
    border-top: 3px solid var(--orika-yellow);
    color: rgba(255, 255, 255, .82);
    font-size: .92rem;
    padding: 28px 24px 30px;
}

.public-footer__inner {
    align-items: center;
    display: flex;
    gap: 28px;
    justify-content: space-between;
    margin: 0 auto;
    max-width: 1160px;
}

.public-footer__brand {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.public-footer__brand strong {
    color: #ffffff;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: 1.28rem;
    font-weight: 700;
    line-height: 1.05;
}

.public-footer__brand span {
    color: rgba(255, 255, 255, .84);
    font-size: .94rem;
    font-weight: 500;
}

.public-footer__brand small {
    color: rgba(255, 255, 255, .62);
    font-size: .8rem;
    font-weight: 500;
}

.public-footer p {
    margin: 0;
}

.public-footer__credit {
    align-items: center;
    background: rgba(255, 255, 255, .08);
    border: 1px solid rgba(255, 255, 255, .12);
    border-radius: 8px;
    display: flex;
    gap: 10px;
    padding: 10px 12px;
    white-space: nowrap;
}

.public-footer__credit span {
    color: rgba(255, 255, 255, .72);
    font-size: .82rem;
    font-weight: 700;
}

.sim-main-footer__logo {
    display: block;
    height: 20px;
    width: auto;
}

.maritorio-map-modal .modal-content {
    border: 0;
    border-radius: 8px;
    box-shadow: 0 28px 70px rgba(1, 64, 89, .28);
    height: 92vh;
    max-height: 860px;
    overflow: hidden;
}

.maritorio-map-modal .modal-header {
    align-items: flex-start;
    background:
        radial-gradient(circle at 92% 12%, rgba(255, 206, 96, .16), transparent 26%),
        linear-gradient(135deg, #005f83 0%, #014059 100%);
    border: 0;
    color: #ffffff;
    gap: 18px;
    padding: 22px 26px 20px;
}

.maritorio-map-modal__kicker {
    color: var(--orika-yellow);
    display: block;
    font-size: .78rem;
    font-weight: 800;
    margin-bottom: 6px;
    text-transform: uppercase;
}

.maritorio-map-modal .modal-title {
    color: #ffffff;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 700;
    line-height: 1;
    margin: 0;
}

.maritorio-map-modal .modal-header p {
    color: rgba(255, 255, 255, .88);
    font-size: .98rem;
    font-weight: 500;
    line-height: 1.4;
    margin: 10px 0 0;
    max-width: 760px;
}

.maritorio-map-modal .btn-close {
    filter: invert(1);
    margin-top: 4px;
    opacity: .9;
}

.maritorio-map-modal .modal-body {
    background: #e8f0ef;
    min-height: 0;
    overflow: hidden;
    padding: 0;
    position: relative;
}

.maritorio-map-modal__map {
    display: block;
    height: 100%;
    min-height: 0;
    width: 100%;
}

.maritorio-map-modal__layers {
    background: #ffffff;
    border-right: 1px solid rgba(1, 64, 89, .12);
    bottom: 0;
    box-shadow: 14px 0 28px rgba(1, 64, 89, .16);
    left: 0;
    max-height: none;
    overflow: auto;
    padding: 18px 16px;
    position: absolute;
    top: 0;
    transform: translateX(-102%);
    transition: transform .22s ease;
    width: min(320px, 86vw);
    z-index: 500;
}

.maritorio-map-modal--layers-open .maritorio-map-modal__layers {
    transform: translateX(0);
}

.maritorio-map-modal__toggle {
    background: var(--orika-yellow);
    border: 0;
    border-radius: 6px;
    box-shadow: 0 12px 24px rgba(1, 64, 89, .18);
    color: var(--orika-ink);
    font-size: .84rem;
    font-weight: 900;
    left: 14px;
    padding: 10px 13px;
    position: absolute;
    text-transform: uppercase;
    top: 76px;
    z-index: 650;
}

.maritorio-map-modal--layers-open .maritorio-map-modal__toggle {
    background: var(--orika-red);
    color: #ffffff;
}

.maritorio-map-modal__layers strong {
    color: var(--orika-ink);
    display: block;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: 1.22rem;
    line-height: 1;
    margin-bottom: 12px;
}

.maritorio-map-modal__layers label {
    align-items: flex-start;
    border-bottom: 1px solid rgba(46, 40, 33, .08);
    color: var(--orika-text);
    cursor: pointer;
    display: grid;
    font-size: .82rem;
    font-weight: 700;
    gap: 8px;
    grid-template-columns: auto auto 1fr;
    line-height: 1.24;
    padding: 10px 0;
}

.maritorio-map-modal__layers input {
    margin-top: 2px;
}

.maritorio-map-modal__swatch {
    border: 1px solid rgba(46, 40, 33, .18);
    border-radius: 999px;
    display: inline-block;
    height: 12px;
    margin-top: 3px;
    width: 12px;
}

.maritorio-map-popup strong,
.maritorio-map-popup span {
    display: block;
}

.maritorio-map-popup strong {
    color: var(--orika-ink);
    font-size: .98rem;
    line-height: 1.2;
}

.maritorio-map-popup span {
    color: var(--orika-red);
    font-size: .76rem;
    font-weight: 800;
    margin-top: 4px;
}

.maritorio-map-popup p {
    color: var(--orika-text);
    font-size: .82rem;
    line-height: 1.35;
    margin: 8px 0 0;
}

.maritorio-map-pin {
    background: transparent;
    border: 0;
}

.maritorio-map-pin span {
    background: var(--orika-red);
    border: 2px solid #ffffff;
    border-radius: 50% 50% 50% 0;
    box-shadow: 0 8px 18px rgba(46, 40, 33, .28);
    display: block;
    height: 24px;
    position: relative;
    transform: rotate(-45deg);
    width: 24px;
}

.maritorio-map-pin span::after {
    background: #ffffff;
    border-radius: 999px;
    content: "";
    height: 7px;
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 7px;
}

.maritorio-own-map--error {
    align-items: center;
    color: var(--orika-muted);
    display: flex;
    font-weight: 800;
    justify-content: center;
    text-align: center;
}

.turistico-map-modal .modal-content {
    border: 0;
    border-radius: 8px;
    box-shadow: 0 28px 70px rgba(1, 64, 89, .28);
    height: 92vh;
    max-height: 860px;
    overflow: hidden;
}

.turistico-map-modal .modal-header {
    align-items: flex-start;
    background:
        radial-gradient(circle at 90% 12%, rgba(255, 206, 96, .18), transparent 26%),
        linear-gradient(135deg, #005f83 0%, #014059 100%);
    border: 0;
    color: #ffffff;
    gap: 18px;
    padding: 22px 26px 20px;
}

.turistico-map-modal__kicker {
    color: var(--orika-yellow);
    display: block;
    font-size: .78rem;
    font-weight: 800;
    margin-bottom: 6px;
    text-transform: uppercase;
}

.turistico-map-modal .modal-title {
    color: #ffffff;
    font-family: "Barlow Condensed", "Barlow", "Segoe UI", Arial, sans-serif;
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 700;
    line-height: 1;
    margin: 0;
}

.turistico-map-modal .modal-header p {
    color: rgba(255, 255, 255, .9);
    font-size: .98rem;
    font-weight: 500;
    line-height: 1.4;
    margin: 10px 0 0;
}

.turistico-map-modal .btn-close {
    filter: invert(1);
    opacity: .9;
}

.turistico-map-modal .modal-body {
    background: #e8f0ef;
    overflow: hidden;
    padding: 0;
    position: relative;
}

.turistico-map-modal__map {
    height: 100%;
    width: 100%;
}

.turistico-map-modal__legend {
    background: #ffffff;
    border-radius: 8px;
    box-shadow: 0 14px 28px rgba(1, 64, 89, .16);
    display: flex;
    flex-direction: column;
    gap: 8px;
    left: 14px;
    padding: 12px;
    position: absolute;
    top: 14px;
    width: min(250px, 82vw);
    z-index: 650;
}

.turistico-map-modal__legend button {
    align-items: center;
    background: #f6f8f7;
    border: 1px solid rgba(1, 64, 89, .1);
    border-radius: 6px;
    color: var(--orika-ink);
    display: flex;
    font-size: .84rem;
    font-weight: 800;
    gap: 8px;
    padding: 8px;
    text-align: left;
}

.turistico-map-modal__legend button.is-active {
    background: #e7f6f5;
    border-color: var(--orika-blue);
}

.turistico-map-modal__legend button span {
    border: 2px solid #ffffff;
    border-radius: 999px;
    display: inline-block;
    height: 18px;
    width: 18px;
}

.turistico-map-icon {
    background: transparent;
    border: 0;
}

.turistico-map-icon span {
    align-items: center;
    border: 2px solid #ffffff;
    border-radius: 999px;
    box-shadow: 0 8px 18px rgba(46, 40, 33, .28);
    color: #ffffff;
    display: flex;
    font-size: .78rem;
    font-weight: 900;
    height: 30px;
    justify-content: center;
    position: relative;
    width: 30px;
}

.turistico-map-icon span::after {
    background: inherit;
    border-bottom: 2px solid #ffffff;
    border-right: 2px solid #ffffff;
    bottom: -3px;
    content: "";
    height: 10px;
    position: absolute;
    transform: rotate(45deg);
    width: 10px;
    z-index: -1;
}

.turistico-map-route-label span {
    background: rgba(1, 64, 89, .82);
    border-radius: 999px;
    color: #ffffff;
    display: inline-block;
    font-size: .68rem;
    font-weight: 800;
    line-height: 1.1;
    max-width: 120px;
    padding: 3px 7px;
    text-align: center;
    white-space: normal;
}

.turistico-map-route-tooltip {
    background: rgba(1, 64, 89, .92);
    border: 0;
    border-radius: 999px;
    box-shadow: 0 8px 18px rgba(1, 64, 89, .18);
    color: #ffffff;
    font-size: .72rem;
    font-weight: 800;
    padding: 4px 8px;
    pointer-events: none;
}

.turistico-map-route-tooltip::before {
    display: none;
}

.turistico-map-popup strong,
.turistico-map-popup span {
    display: block;
}

.turistico-map-popup .leaflet-popup-content {
    max-height: min(230px, 48vh);
    overflow-y: auto;
}

.turistico-map-popup strong {
    color: var(--orika-ink);
}

.turistico-map-popup span {
    color: var(--orika-red);
    font-size: .78rem;
    font-weight: 800;
    margin-top: 4px;
}

.turistico-map-popup p {
    color: var(--orika-text);
    font-size: .84rem;
    line-height: 1.35;
    margin: 8px 0 0;
}

.turistico-map-popup img {
    border-radius: 6px;
    display: block;
    margin-top: 8px;
    max-height: 86px;
    object-fit: cover;
    width: 100%;
}

.turistico-map-popup a {
    background: var(--orika-yellow);
    border-radius: 6px;
    color: var(--orika-ink);
    display: block;
    font-size: .82rem;
    font-weight: 800;
    margin-top: 8px;
    padding: 7px 10px;
    text-align: center;
    text-decoration: none;
}

.not-set {
    color: #c55;
    font-style: italic;
}

a.asc:after,
a.desc:after {
    content: '';
    left: 3px;
    display: inline-block;
    width: 0;
    height: 0;
    border: solid 5px transparent;
    margin: 4px 4px 2px 4px;
    background: transparent;
}

a.asc:after {
    border-bottom: solid 7px #212529;
    border-top-width: 0;
}

a.desc:after {
    border-top: solid 7px #212529;
    border-bottom-width: 0;
}

.grid-view th,
.grid-view td:last-child {
    white-space: nowrap;
}

.grid-view .filters input,
.grid-view .filters select {
    min-width: 50px;
}

.hint-block {
    display: block;
    margin-top: 5px;
    color: #999;
}

.error-summary {
    color: #a94442;
    background: #fdf7f7;
    border-left: 3px solid #eed3d7;
    padding: 10px 20px;
    margin: 0 0 15px 0;
}

.navbar form > button.logout {
    padding-top: 7px;
    color: rgba(255, 255, 255, 0.5);
}

.navbar form > button.logout:focus,
.navbar form > button.logout:hover {
    text-decoration: none;
    color: rgba(255, 255, 255, 0.75);
}

.navbar form > button.logout:focus {
    outline: none;
}

.breadcrumb {
    display: none;
}

.breadcrumb-item > a {
    text-decoration: none;
}

@media(max-width: 767px) {
    .navbar form > button.logout {
        display: block;
        padding: 10px 0;
        text-align: left;
        width: 100%;
    }
}

@media (max-width: 860px) {
    .public-navbar {
        min-height: 72px;
    }

    .public-navbar .container {
        padding-left: 16px;
        padding-right: 16px;
    }

    .public-navbar .navbar-collapse {
        background: rgba(185, 17, 23, .34);
        border-radius: 8px;
        margin-top: 10px;
        padding: 8px;
    }

    .public-navbar .navbar-nav {
        align-items: stretch;
        gap: 4px;
    }

    .public-navbar .nav-link {
        padding: 11px 12px;
    }

    .public-main {
        padding-top: 0;
    }

    .public-navbar__logo {
        max-height: 48px;
    }

    .home-content {
        grid-template-columns: 1fr;
    }

    .territory-intro {
        gap: 12px;
        grid-template-columns: 1fr;
        padding: 18px 14px;
    }

    .territory-intro__media {
        min-height: 280px;
    }

    .territory-intro__media-label {
        bottom: 16px;
        font-size: .74rem;
        left: 16px;
        padding: 8px 10px;
    }

    .territory-intro__copy {
        align-items: center;
        padding: 38px 24px 42px;
        text-align: center;
    }

    .territory-intro__copy::after {
        display: none;
    }

    .territory-intro__copy::before {
        height: 120px;
        right: -56px;
        top: -58px;
        width: 120px;
    }

    .territory-intro__copy h2 {
        font-size: 2rem;
        margin-bottom: 18px;
    }

    .territory-intro__copy p {
        font-size: 1rem;
        line-height: 1.38;
        text-align: center;
    }

    .territory-intro__facts {
        grid-template-columns: 1fr;
    }

    .territory-intro__facts span {
        text-align: left;
    }

    .territory-intro__kicker::before {
        width: 24px;
    }

    .community-section {
        gap: 12px;
        grid-template-columns: 1fr;
        padding: 0 14px 18px;
    }

    .community-section__copy {
        align-items: center;
        min-height: auto;
        padding: 38px 24px 42px;
        text-align: center;
    }

    .community-section__copy p {
        font-size: 1rem;
        line-height: 1.38;
    }

    .community-section__media {
        min-height: 280px;
        order: -1;
    }

    .community-section__view-button {
        bottom: 54px;
        min-height: 34px;
        padding: 0 14px;
        right: 14px;
    }

    .community-section__kicker::before {
        width: 24px;
    }

    .organization-section {
        gap: 12px;
        grid-template-columns: 1fr;
        padding: 0 14px 18px;
    }

    .organization-section__media {
        min-height: 280px;
    }

    .organization-section__copy {
        align-items: center;
        min-height: auto;
        padding: 38px 24px 42px;
        text-align: center;
    }

    .organization-section__copy p {
        font-size: 1rem;
        line-height: 1.38;
    }

    .organization-section__kicker::before {
        width: 24px;
    }

    .enterprise-section {
        gap: 12px;
        grid-template-columns: 1fr;
        padding: 0 14px 18px;
    }

    .enterprise-section__media {
        min-height: 280px;
        order: -1;
    }

    .enterprise-section__copy {
        align-items: center;
        min-height: auto;
        padding: 38px 24px 42px;
        text-align: center;
    }

    .enterprise-section__copy p {
        font-size: 1rem;
        line-height: 1.38;
    }

    .enterprise-section__kicker::before {
        width: 24px;
    }

    .enterprise-section__slide figcaption {
        min-width: 0;
        right: 0;
    }

    .social-section {
        padding: 18px 14px 24px;
    }

    .social-section__inner {
        padding: 36px 22px 38px;
    }

    .social-section p {
        font-size: 1rem;
        line-height: 1.42;
    }

    .social-section__actions {
        width: 100%;
    }

    .social-section__button {
        min-width: 0;
        width: 100%;
    }

    .public-footer__inner {
        align-items: center;
        flex-direction: column;
        gap: 16px;
        text-align: center;
    }

    .public-footer__brand {
        align-items: center;
    }

    .public-footer__credit {
        justify-content: center;
    }

    .maritorio-map-modal .modal-content {
        border-radius: 0;
        height: 100vh;
    }

    .maritorio-map-modal .modal-header {
        padding: 18px 18px 16px;
    }

    .maritorio-map-modal .modal-body {
        min-height: 0;
    }

    .maritorio-map-modal__map {
        height: 100%;
        min-height: 62vh;
    }

    .maritorio-map-modal__layers {
        border-right: 1px solid rgba(1, 64, 89, .12);
        width: min(310px, 88vw);
    }

    .turistico-map-modal .modal-content {
        border-radius: 0;
        height: 100vh;
    }

    .turistico-map-modal .modal-header {
        padding: 18px 18px 16px;
    }

    .turistico-map-modal__legend {
        bottom: 12px;
        flex-direction: row;
        left: 12px;
        overflow-x: auto;
        top: auto;
        width: calc(100% - 24px);
    }

    .turistico-map-modal__legend button {
        flex: 0 0 auto;
        white-space: nowrap;
    }

}
