/* GCT GATMU client additions: president message, useful links, OSM map and static council pages. */

.gct-navbar {
    gap: 14px;
}

.gct-brand {
    flex: 0 0 auto;
}

.gct-desktop-nav ul {
    gap: 4px;
}

.gct-desktop-nav a {
    min-height: 42px;
}

.gct-header-actions {
    gap: 8px;
}

.gct-mobile-nav > a {
    width: 100%;
}

.gct-president-section {
    padding-top: 72px;
}

.gct-director-home-section {
    padding: 82px 0;
    background:
        linear-gradient(90deg, rgba(248,251,255,.96), rgba(255,255,255,.94)),
        url("../images/city-initiatives-image-prime.jpg") center/cover;
}

.gct-director-home {
    display: grid;
    grid-template-columns: minmax(280px, .78fr) minmax(0, 1.22fr);
    align-items: stretch;
    overflow: hidden;
    border: 1px solid var(--gct-border);
    border-radius: 8px;
    background: #fff;
    box-shadow: var(--gct-shadow-sm);
}

.gct-director-visual {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    min-height: 430px;
    padding: 30px;
    color: #fff;
    background:
        linear-gradient(180deg, rgba(6,31,72,.10), rgba(6,31,72,.96)),
        url("../images/president.jpeg") center/cover;
}

.gct-director-visual::before {
    content: "";
    position: absolute;
    inset: 18px;
    border: 1px solid rgba(255,255,255,.18);
    border-radius: 8px;
    pointer-events: none;
}

.gct-director-portrait {
    width: 86px;
    height: 86px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: relative;
    z-index: 1;
    margin-bottom: 18px;
    border-radius: 8px;
    background: var(--accent-secondary-color);
    color: var(--primary-color);
    font-size: 34px;
    box-shadow: 0 18px 38px rgba(0,0,0,.22);
}

.gct-director-identity {
    position: relative;
    z-index: 1;
}

.gct-director-identity strong,
.gct-director-identity span {
    display: block;
}

.gct-director-identity strong {
    color: #fff;
    font-size: 28px;
    line-height: 1.05;
}

.gct-director-identity span {
    margin-top: 8px;
    color: rgba(255,255,255,.78);
    font-weight: 800;
}

.gct-director-copy {
    padding: 44px;
}

.gct-director-copy h2 {
    margin: 10px 0 20px;
    color: var(--primary-color);
    font-size: clamp(34px, 4.2vw, 54px);
    line-height: 1;
}

.gct-director-copy blockquote {
    position: relative;
    margin: 0 0 20px;
    padding-left: 26px;
    border-left: 4px solid var(--accent-secondary-color);
    color: #17365f;
    font-size: 23px;
    line-height: 1.45;
    font-weight: 850;
}

.gct-director-copy p {
    max-width: 760px;
    color: #52667d;
    line-height: 1.75;
    margin-bottom: 22px;
}

.gct-director-pill-row {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin: 6px 0 26px;
}

.gct-director-pill-row span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 38px;
    padding: 0 13px;
    border: 1px solid var(--gct-border);
    border-radius: 999px;
    background: #f8fbff;
    color: #254061;
    font-size: 13px;
    font-weight: 900;
}

.gct-director-pill-row i {
    color: var(--accent-color);
}

.gct-president-panel {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(320px, .95fr);
    gap: 34px;
    align-items: stretch;
    padding: 34px;
    border: 1px solid var(--gct-border);
    border-radius: 28px;
    background: linear-gradient(135deg, #ffffff, #f6fbff);
    box-shadow: var(--gct-shadow-sm);
}

.gct-president-panel--video-only {
    display: block;
    padding: 18px;
}

.gct-president-panel--video-only .gct-president-media,
.gct-president-panel--video-only .gct-video-placeholder {
    min-height: 520px;
}

.gct-video-placeholder--empty {
    background: transparent;
}

.gct-president-copy h2 {
    margin: 10px 0 18px;
    color: var(--primary-color);
}

.gct-president-copy p {
    color: #52667d;
    line-height: 1.75;
}

.gct-president-meta {
    display: flex;
    gap: 14px;
    align-items: center;
    margin-bottom: 18px;
}

.gct-president-avatar {
    width: 64px;
    height: 64px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 18px;
    color: #fff;
    background: linear-gradient(135deg, var(--accent-color), #19a6d2);
    font-size: 26px;
    flex: 0 0 auto;
}

.gct-president-meta strong,
.gct-president-meta span {
    display: block;
}

.gct-president-meta strong {
    color: var(--primary-color);
    font-size: 18px;
}

.gct-president-meta span {
    color: #6a7b90;
    font-weight: 750;
}

.gct-president-actions {
    display: flex;
    gap: 16px;
    align-items: center;
    flex-wrap: wrap;
    margin-top: 22px;
}

.gct-president-media,
.gct-video-placeholder {
    min-height: 315px;
}

.gct-president-media {
    border-radius: 24px;
    overflow: hidden;
    background: linear-gradient(135deg, rgba(6, 31, 72, .92), rgba(11, 78, 162, .88)), url("../images/city-initiatives-image-prime.jpg") center/cover;
}

.gct-video-placeholder {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 12px;
    padding: 28px;
    text-align: center;
    color: #fff;
}

.gct-video-placeholder i {
    width: 74px;
    height: 74px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: var(--accent-secondary-color);
    color: var(--primary-color);
    font-size: 24px;
}

.gct-video-placeholder strong {
    color: #fff;
    font-size: 24px;
}

.gct-video-placeholder span {
    color: rgba(255,255,255,.78);
    max-width: 360px;
}

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

.gct-useful-links-grid--full {
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.gct-useful-link-card {
    padding: 26px;
    min-height: 235px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.gct-useful-link-card h3 {
    margin: 4px 0 0;
    color: var(--primary-color);
    font-size: 21px;
}

.gct-useful-link-card p {
    color: #63748a;
    line-height: 1.62;
    margin: 0;
}

.gct-useful-link-card a {
    margin-top: auto;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--accent-color);
    font-weight: 850;
    text-decoration: none;
}

.gct-org-section {
    background:
        linear-gradient(180deg, #ffffff, #f7fbff);
}

.gct-org-section .section-title p {
    max-width: 760px;
    margin: 12px auto 0;
}

.gct-org-chart {
    position: relative;
    max-width: 1180px;
    margin: 34px auto 0;
    padding: 12px 0 0;
}

.gct-org-row {
    position: relative;
    display: grid;
    justify-items: center;
    gap: 20px;
}

.gct-org-row + .gct-org-row {
    margin-top: 34px;
}

.gct-org-row--assist {
    grid-template-columns: repeat(2, minmax(220px, 280px));
    justify-content: center;
    gap: 260px;
}

.gct-org-row--services {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    align-items: stretch;
}

.gct-org-card {
    position: relative;
    z-index: 1;
    width: 100%;
    min-height: 128px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 22px 18px;
    border: 1px solid rgba(8,43,97,.14);
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 14px 34px rgba(8,43,97,.08);
    text-align: center;
}

.gct-org-card--primary,
.gct-org-card--director {
    max-width: 360px;
}

.gct-org-card--primary {
    background: linear-gradient(135deg, #082b61, #0b4ea2);
    color: #fff;
    box-shadow: 0 22px 48px rgba(8,43,97,.22);
}

.gct-org-card--director {
    background: linear-gradient(180deg, #ffffff, #eef6ff);
    border-color: rgba(11,78,162,.22);
}

.gct-org-icon {
    width: 44px;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    border-radius: 8px;
    background: #eaf3ff;
    color: var(--accent-color);
    font-size: 18px;
}

.gct-org-card--primary .gct-org-icon {
    background: var(--accent-secondary-color);
    color: var(--primary-color);
}

.gct-org-card small {
    color: var(--accent-color);
    font-size: 12px;
    font-weight: 900;
    line-height: 1;
    text-transform: uppercase;
}

.gct-org-card strong {
    color: var(--primary-color);
    font-size: 16px;
    line-height: 1.28;
}

.gct-org-card--primary strong,
.gct-org-card--primary small {
    color: #fff;
}

.gct-org-row--top::after,
.gct-org-row--director::before,
.gct-org-row--director::after,
.gct-org-row--office::after {
    content: "";
    position: absolute;
    left: 50%;
    width: 2px;
    background: rgba(11,78,162,.32);
    transform: translateX(-50%);
}

.gct-org-row--top::after {
    bottom: -34px;
    height: 34px;
}

.gct-org-row--director::before {
    top: -34px;
    height: 34px;
}

.gct-org-row--director::after {
    bottom: -34px;
    height: 34px;
}

.gct-org-row--office::after {
    bottom: -34px;
    height: 34px;
}

.gct-org-row--assist::before,
.gct-org-row--services::before {
    content: "";
    position: absolute;
    left: 50%;
    right: auto;
    top: -18px;
    width: min(72%, 760px);
    height: 2px;
    background: rgba(11,78,162,.26);
    transform: translateX(-50%);
}

.gct-org-row--assist .gct-org-card::before,
.gct-org-row--services .gct-org-card::before {
    content: "";
    position: absolute;
    left: 50%;
    top: -18px;
    width: 2px;
    height: 18px;
    background: rgba(11,78,162,.26);
    transform: translateX(-50%);
}

.gct-map-shell {
    padding: 14px;
    border: 1px solid var(--gct-border);
    border-radius: 28px;
    background: #fff;
    box-shadow: var(--gct-shadow-sm);
}

.gct-google-map {
    display: block;
    width: 100%;
    border: 0;
    min-height: 520px;
    border-radius: 20px;
    overflow: hidden;
    background: #eaf3ff;
}

.gct-speech-section {
    background: linear-gradient(180deg, #f7fbff, #ffffff);
}

.gct-director-video-section {
    padding-bottom: 40px;
}

.gct-director-video-section + .gct-speech-section {
    padding-top: 40px;
}

.gct-director-video-only {
    max-width: 920px;
    min-height: 430px;
    margin: 0 auto;
    border-radius: 8px;
    overflow: hidden;
    background: linear-gradient(135deg, rgba(6, 31, 72, .94), rgba(11, 78, 162, .9)), url("../images/city-initiatives-image-prime.jpg") center/cover;
    box-shadow: var(--gct-shadow-sm);
}

.gct-speech-card {
    max-width: 980px;
    margin: 0 auto;
    padding: 38px;
    border: 1px solid var(--gct-border);
    border-radius: 28px;
    background: #fff;
    box-shadow: var(--gct-shadow-sm);
}

.gct-speech-meta {
    display: flex;
    align-items: center;
    gap: 18px;
    padding-bottom: 26px;
    margin-bottom: 28px;
    border-bottom: 1px solid var(--gct-border);
}

.gct-speech-meta h2 {
    margin: 8px 0 6px;
    color: var(--primary-color);
    font-size: clamp(28px, 4vw, 42px);
    line-height: 1.08;
}

.gct-speech-meta p,
.gct-speech-body p {
    color: #52667d;
    line-height: 1.78;
}

.gct-speech-body h3 {
    margin: 32px 0 14px;
    color: var(--primary-color);
    font-size: 24px;
}

.gct-speech-list {
    display: grid;
    gap: 14px;
    padding: 0;
    margin: 18px 0 0;
    list-style: none;
}

.gct-speech-list li {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    padding: 18px;
    border: 1px solid var(--gct-border);
    border-radius: 18px;
    background: #f8fbff;
    color: #254061;
    font-weight: 750;
    line-height: 1.62;
}

.gct-speech-list i {
    width: 42px;
    height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    border-radius: 14px;
    background: #eaf3ff;
    color: var(--accent-color);
}

.gct-speech-signature {
    margin-top: 28px;
    padding-top: 22px;
    border-top: 1px solid var(--gct-border);
}

/* Unified Morocco map: custom SVG avoids provider disputed-border rendering.
   The simplified outline can be replaced later by a more precise official GeoJSON. */
.gct-map-note {
    margin-top: 12px;
    color: #617287;
    font-weight: 750;
    font-size: 14px;
}

.gct-login-wrap {
    max-width: 1060px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: .9fr 1.1fr;
    gap: 28px;
    align-items: stretch;
}

.gct-login-intro,
.gct-login-card,
.gct-dashboard-panel {
    border: 1px solid var(--gct-border);
    border-radius: 28px;
    background: #fff;
    box-shadow: var(--gct-shadow-sm);
}

.gct-login-intro {
    padding: 34px;
    background: linear-gradient(135deg, #061f48, #0b4ea2);
    color: #fff;
}

.gct-login-intro h2,
.gct-login-intro h3 {
    color: #fff;
}

.gct-login-intro p,
.gct-login-intro li {
    color: rgba(255,255,255,.78);
}

.gct-login-intro ul {
    display: grid;
    gap: 11px;
    padding: 0;
    margin: 24px 0 0;
    list-style: none;
}

.gct-login-intro i {
    color: var(--accent-secondary-color);
    margin-right: 9px;
}

.gct-login-card {
    padding: 34px;
}

.gct-login-card label {
    display: block;
    margin-bottom: 8px;
    color: var(--primary-color);
    font-weight: 850;
}

.gct-login-card input {
    width: 100%;
    min-height: 54px;
    border: 1px solid var(--gct-border);
    border-radius: 16px;
    padding: 0 16px;
    margin-bottom: 18px;
}

.gct-login-card .btn-default {
    width: 100%;
    border: 0;
}

.gct-form-hint,
.gct-auth-error {
    font-size: 14px;
    color: #66778c;
    margin-top: 14px;
}

.gct-auth-error {
    display: none;
    color: #b42318;
    font-weight: 850;
}

.gct-auth-error.is-visible {
    display: block;
}

body[data-protected-council] main {
    visibility: hidden;
}

body.gct-council-ready main {
    visibility: visible;
}

.gct-dashboard-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 18px;
}

.gct-dashboard-panel {
    padding: 24px;
    min-height: 190px;
}

.gct-dashboard-panel i {
    color: var(--accent-color);
    font-size: 28px;
    margin-bottom: 18px;
}

.gct-dashboard-panel h3 {
    color: var(--primary-color);
    font-size: 20px;
}

.gct-dashboard-panel p {
    color: #63748a;
    line-height: 1.6;
}

.gct-dashboard-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    flex-wrap: wrap;
    margin-bottom: 28px;
}

.gct-logout-btn {
    border: 0;
}

@media (max-width: 1199px) {
    .gct-useful-links-grid--full,
    .gct-dashboard-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .gct-org-row--assist {
        gap: 120px;
    }
    .gct-org-row--services {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .gct-org-row--services::before,
    .gct-org-row--services .gct-org-card::before {
        display: none;
    }
}

@media (max-width: 991px) {
    .gct-director-home {
        grid-template-columns: 1fr;
    }
    .gct-director-visual {
        min-height: 330px;
    }
    .gct-president-panel,
    .gct-login-wrap {
        grid-template-columns: 1fr;
    }
    .gct-useful-links-grid,
    .gct-useful-links-grid--full {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .gct-org-row--assist {
        gap: 50px;
    }
    .gct-org-card--primary,
    .gct-org-card--director {
        max-width: 100%;
    }
}

@media (max-width: 767px) {
    .gct-director-home-section {
        padding: 60px 0;
    }
    .gct-director-visual {
        min-height: 285px;
        padding: 24px;
    }
    .gct-director-copy {
        padding: 26px;
    }
    .gct-director-copy blockquote {
        font-size: 19px;
        padding-left: 18px;
    }
    .gct-director-pill-row span {
        width: 100%;
        justify-content: center;
    }
    .gct-president-section {
        padding-top: 54px;
    }
    .gct-president-panel,
    .gct-login-intro,
    .gct-login-card {
        padding: 24px;
        border-radius: 22px;
    }
    .gct-president-media,
    .gct-video-placeholder {
        min-height: 260px;
    }
    .gct-president-panel--video-only .gct-president-media,
    .gct-president-panel--video-only .gct-video-placeholder {
        min-height: 300px;
    }
    .gct-useful-links-grid,
    .gct-useful-links-grid--full,
    .gct-dashboard-grid {
        grid-template-columns: 1fr;
    }
    .gct-org-chart {
        margin-top: 24px;
    }
    .gct-org-row,
    .gct-org-row--assist,
    .gct-org-row--services {
        grid-template-columns: 1fr;
        gap: 14px;
    }
    .gct-org-row + .gct-org-row {
        margin-top: 18px;
    }
    .gct-org-card {
        min-height: auto;
        align-items: flex-start;
        text-align: left;
        padding: 18px;
    }
    .gct-org-card strong {
        font-size: 15px;
    }
    .gct-org-row--top::after,
    .gct-org-row--director::before,
    .gct-org-row--director::after,
    .gct-org-row--office::after,
    .gct-org-row--assist::before,
    .gct-org-row--services::before,
    .gct-org-row--assist .gct-org-card::before,
    .gct-org-row--services .gct-org-card::before {
        display: none;
    }
    .gct-google-map {
        min-height: 360px;
    }
    .gct-speech-card {
        padding: 24px;
        border-radius: 22px;
    }
    .gct-speech-meta {
        align-items: flex-start;
    }
    .gct-speech-list li {
        padding: 15px;
    }
}

html[dir="rtl"] .gct-breadcrumb,
html[dir="rtl"] .gct-top-strip .container,
html[dir="rtl"] .gct-navbar,
html[dir="rtl"] .gct-desktop-nav ul { direction: rtl; }

.gct-content-layout { display: grid; grid-template-columns: minmax(220px, 280px) minmax(0, 1fr); gap: 28px; align-items: start; }
.gct-content-toc { position: sticky; top: 110px; display: grid; gap: 8px; padding: 20px; border: 1px solid rgba(20, 50, 44, 0.12); border-radius: 8px; background: #fff; }
.gct-content-toc strong { color: var(--accent-color); font-weight: 800; margin-bottom: 8px; }
.gct-content-toc a { color: var(--text-color); font-size: 15px; line-height: 1.35; padding: 9px 10px; border-radius: 6px; }
.gct-content-toc a:hover, .gct-content-toc a.is-active { color: #fff; background: var(--accent-color); }
.gct-content-sections { display: grid; gap: 22px; }
.gct-rich-section { padding: 28px; }
.gct-rich-section h2 { font-size: 28px; line-height: 1.2; margin-bottom: 12px; }
.gct-rich-section p { font-size: 17px; line-height: 1.75; }
.gct-image-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; margin-top: 22px; }
.gct-figure { margin: 22px 0 0; }
.gct-figure img { display: block; width: 100%; height: auto; border-radius: 8px; border: 1px solid rgba(20, 50, 44, 0.12); background: #fff; }
.gct-figure figcaption { margin-top: 8px; color: var(--text-color); font-size: 14px; line-height: 1.45; }
.gct-member-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 18px; }
.gct-member-card { min-height: 128px; padding: 22px; }
.gct-member-card i { color: var(--accent-color); font-size: 28px; margin-bottom: 16px; }
.gct-member-card h3 { font-size: 18px; line-height: 1.25; margin: 0; }
.gct-kpi-grid--wide { grid-template-columns: repeat(5, minmax(0, 1fr)); }

@media (max-width: 991px) {
    .gct-content-layout { grid-template-columns: 1fr; }
    .gct-content-toc { position: static; }
    .gct-member-grid, .gct-kpi-grid--wide { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 575px) {
    .gct-rich-section { padding: 20px; }
    .gct-rich-section h2 { font-size: 23px; }
    .gct-image-grid, .gct-member-grid, .gct-kpi-grid--wide { grid-template-columns: 1fr; }
}

/* Content pages: desktop sticky side navigation, mobile compact summary. */
.gct-content-section {
    padding-top: 72px;
}

.gct-content-shell {
    display: grid;
    grid-template-columns: minmax(240px, 300px) minmax(0, 1fr);
    gap: 28px;
    align-items: start;
}

.gct-content-sidebar {
    position: sticky;
    top: 104px;
    align-self: start;
}

.gct-content-nav {
    padding: 24px;
    border-radius: 8px;
    background: #fff;
    box-shadow: var(--gct-shadow-sm);
}

.gct-content-nav h2 {
    margin: 8px 0 18px;
    color: var(--primary-color);
    font-size: 26px;
    line-height: 1.1;
}

.gct-content-nav nav {
    display: grid;
    gap: 8px;
}

.gct-content-nav a {
    display: grid;
    grid-template-columns: 20px minmax(0, 1fr);
    gap: 10px;
    align-items: center;
    min-height: 44px;
    padding: 10px 12px;
    border: 1px solid var(--gct-border);
    border-radius: 8px;
    background: #f8fbff;
    color: #254061;
    font-weight: 850;
    line-height: 1.25;
}

.gct-content-nav a i {
    color: var(--accent-color);
    font-size: 13px;
    transition: transform .2s ease;
}

.gct-content-nav a:hover,
.gct-content-nav a:focus-visible {
    border-color: rgba(0, 85, 180, .22);
    background: var(--primary-color);
    color: #fff;
}

.gct-content-nav a:hover i,
.gct-content-nav a:focus-visible i {
    color: var(--accent-secondary-color);
    transform: translateX(3px);
}

.gct-content-main {
    display: grid;
    gap: 28px;
    min-width: 0;
}

.gct-rich-section {
    scroll-margin-top: 112px;
}

.gct-rich-section--soft {
    background: linear-gradient(135deg, #ffffff, #f7fbff);
}

html[dir="rtl"] .gct-content-nav a:hover i,
html[dir="rtl"] .gct-content-nav a:focus-visible i {
    transform: translateX(-3px);
}

@media (max-width: 991px) {
    .gct-content-section {
        padding-top: 48px;
    }

    .gct-content-shell {
        display: block;
    }

    .gct-content-sidebar {
        position: static;
        margin-bottom: 22px;
    }

    .gct-content-nav {
        padding: 18px;
    }

    .gct-content-nav h2 {
        font-size: 23px;
    }

    .gct-content-nav nav {
        display: flex;
        gap: 10px;
        overflow-x: auto;
        padding-bottom: 4px;
        scroll-snap-type: x proximity;
    }

    .gct-content-nav a {
        flex: 0 0 min(82vw, 330px);
        scroll-snap-align: start;
    }
}
.gct-partners-intro {
    margin: 0 0 18px;
    color: #52667d;
    line-height: 1.7;
    font-weight: 700;
}

.gct-partner-page-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
}

.gct-partner-page-card {
    display: flex;
    flex-direction: column;
    min-height: 320px;
    overflow: hidden;
    border-radius: 8px;
}

.gct-partner-logo-frame {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 190px;
    padding: 28px;
    background: linear-gradient(180deg, #ffffff, #f6fbff);
    border-bottom: 1px solid var(--gct-border);
}

.gct-partner-logo-frame img {
    display: block;
    width: 100%;
    max-width: 190px;
    max-height: 112px;
    object-fit: contain;
}

.gct-partner-logo-frame .gct-partner-logo--dre {
    max-width: 160px;
    max-height: 130px;
}

.gct-partner-logo-frame .gct-partner-logo--alsa {
    max-width: 178px;
}

.gct-partner-logo-frame .gct-partner-logo--sdl {
    max-width: 205px;
}

.gct-partner-logo-frame .gct-partner-logo--giz {
    max-width: 150px;
}

.gct-partner-page-body {
    display: flex;
    flex: 1;
    flex-direction: column;
    justify-content: flex-end;
    padding: 24px;
}

.gct-partner-page-body span {
    color: var(--accent-color);
    font-size: 13px;
    font-weight: 900;
    line-height: 1.35;
    text-transform: uppercase;
}

.gct-partner-page-body h3 {
    margin: 9px 0 0;
    color: var(--primary-color);
    font-size: 22px;
    line-height: 1.2;
}

@media (max-width: 1199px) {
    .gct-partner-page-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575px) {
    .gct-partner-page-grid {
        grid-template-columns: 1fr;
    }

    .gct-partner-page-card {
        min-height: 280px;
    }

    .gct-partner-logo-frame {
        min-height: 160px;
        padding: 24px;
    }
}
