.gi-public-page {
    --gi-red: #b40000;
    --gi-dark-red: #820000;
    --gi-dark: #1f2933;
    --gi-text: #3f4650;
    --gi-muted: #6b7280;
    --gi-soft: #f4f6f8;
    --gi-border: #e5e7eb;
    --gi-white: #ffffff;

    font-family: Arial, Helvetica, sans-serif;
    color: var(--gi-text);
    background: linear-gradient(180deg, #ffffff 0%, #f6f7f9 100%);
    min-height: 100vh;
}

/* PORTADA */

.gi-home-modern {
    max-width: 1180px;
    margin: 0 auto;
    padding: 28px;
}

.gi-header,
.gi-inner-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid var(--gi-border);
    border-radius: 22px;
    padding: 18px 32px;
    box-shadow: 0 14px 40px rgba(31, 41, 51, 0.08);
}

.gi-header-brand,
.gi-inner-brand {
    display: flex;
    align-items: center;
    gap: 14px;
}

.gi-header-brand strong,
.gi-inner-brand strong {
    display: block;
    color: var(--gi-dark);
    font-size: 17px;
}

.gi-header-brand span,
.gi-inner-brand span {
    display: block;
    color: var(--gi-muted);
    font-size: 13px;
    margin-top: 2px;
}

.gi-usal-mark,
.gi-mini-logo {
    width: 54px;
    height: 54px;
    border-radius: 16px;
    background: linear-gradient(135deg, var(--gi-red), var(--gi-dark-red));
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    letter-spacing: 0.5px;
}

.gi-header-nav,
.gi-inner-nav {
    display: flex;
    align-items: center;
    gap: 18px;
}

.gi-header-nav a,
.gi-inner-nav a {
    color: var(--gi-text);
    text-decoration: none;
    font-weight: 600;
    font-size: 14px;
}

.gi-header-nav a:hover,
.gi-inner-nav a:hover {
    color: var(--gi-red);
}

.gi-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(320px, 0.65fr);
    gap: 34px;
    align-items: center;
    padding: 80px 0 50px;
}

.gi-hero-content {
    padding: 20px 0;
}

.gi-kicker {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--gi-red);
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 13px;
    margin-bottom: 16px;
}

.gi-hero h1 {
    color: var(--gi-dark);
    font-size: clamp(48px, 7vw, 86px);
    line-height: 0.95;
    margin: 0 0 22px;
    letter-spacing: -0.06em;
}

.gi-hero h1 span {
    color: var(--gi-red);
}

.gi-hero p {
    max-width: 680px;
    font-size: 20px;
    line-height: 1.65;
    color: var(--gi-text);
    margin: 0 0 34px;
}

.gi-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
}

.gi-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 14px 22px;
    font-weight: 800;
    text-decoration: none;
    border: 1px solid transparent;
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.gi-btn:hover {
    transform: translateY(-2px);
}

.gi-btn-primary {
    background: linear-gradient(135deg, var(--gi-red), var(--gi-dark-red));
    color: white;
    box-shadow: 0 16px 32px rgba(180, 0, 0, 0.22);
}

.gi-btn-secondary {
    background: white;
    color: var(--gi-dark);
    border-color: var(--gi-border);
}

.gi-hero-card {
    background:
        radial-gradient(circle at top right, rgba(180, 0, 0, 0.18), transparent 36%),
        white;
    border: 1px solid var(--gi-border);
    border-radius: 32px;
    min-height: 390px;
    padding: 36px;
    box-shadow: 0 24px 70px rgba(31, 41, 51, 0.12);
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: center;
}

.gi-mida-logo-modern {
    width: 190px;
    height: 170px;
    margin: 0 auto 28px;
    background: linear-gradient(135deg, var(--gi-red), #d32f2f);
    clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
    display: flex;
    align-items: end;
    justify-content: center;
    padding-bottom: 42px;
    color: white;
    font-size: 42px;
    font-weight: 900;
}

.gi-hero-card h2 {
    color: var(--gi-dark);
    font-size: 24px;
    margin: 0 0 8px;
}

.gi-hero-card p {
    color: var(--gi-muted);
    margin: 0;
}

.gi-home-summary {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
    padding-bottom: 40px;
}

.gi-home-summary article {
    background: white;
    border: 1px solid var(--gi-border);
    border-radius: 24px;
    padding: 24px;
    box-shadow: 0 12px 34px rgba(31, 41, 51, 0.07);
}

.gi-home-summary strong {
    display: block;
    color: var(--gi-dark);
    font-size: 20px;
    margin-bottom: 8px;
}

.gi-home-summary span {
    color: var(--gi-muted);
    line-height: 1.4;
}

/* INTERIOR */

.gi-site-modern {
    padding: 24px;
}

.gi-inner-header {
    position: sticky;
    top: 16px;
    z-index: 10;
    max-width: 1320px;
    margin: 0 auto 34px;
}

.gi-inner-main {
    max-width: 1320px;
    margin: 0 auto;
}

.gi-welcome-section {
    display: grid;
    grid-template-columns: 1.4fr 0.6fr;
    gap: 28px;
    align-items: center;
    background: white;
    border: 1px solid var(--gi-border);
    border-radius: 32px;
    padding: 44px;
    box-shadow: 0 18px 50px rgba(31, 41, 51, 0.08);
    margin-bottom: 28px;
}

.gi-welcome-section h1 {
    color: var(--gi-dark);
    font-size: clamp(34px, 4vw, 58px);
    letter-spacing: -0.04em;
    margin: 0 0 16px;
}

.gi-welcome-section p {
    color: var(--gi-text);
    font-size: 18px;
    line-height: 1.7;
    margin: 0;
    max-width: 760px;
}

.gi-highlight-box {
    min-height: 220px;
    border-radius: 28px;
    background: linear-gradient(135deg, var(--gi-red), var(--gi-dark-red));
    color: white;
    padding: 28px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
}

.gi-highlight-box strong {
    display: block;
    font-size: 34px;
    line-height: 1;
    margin-bottom: 8px;
}

.gi-highlight-box span {
    opacity: 0.86;
}

.gi-dashboard-grid {
    display: grid;
    grid-template-columns: repeat(
        auto-fit,
        minmax(230px, 1fr)
    );
    gap: 18px;
    margin-bottom: 32px;
}

.gi-content-card {
    background: white;
    border: 1px solid var(--gi-border);
    border-radius: 26px;
    padding: 24px;
    box-shadow: 0 14px 36px rgba(31, 41, 51, 0.07);
    min-height: 280px;
}

.gi-card-label {
    display: inline-block;
    background: #fff1f1;
    color: var(--gi-red);
    font-size: 13px;
    font-weight: 800;
    padding: 7px 10px;
    border-radius: 999px;
    margin-bottom: 18px;
}

.gi-content-card h2 {
    color: var(--gi-dark);
    font-size: 23px;
    line-height: 1.15;
    margin: 0 0 14px;
}

.gi-content-card p {
    color: var(--gi-muted);
    line-height: 1.55;
}

.gi-content-card a {
    color: var(--gi-red);
    font-weight: 800;
    text-decoration: none;
}

.gi-section-block {
    background: white;
    border: 1px solid var(--gi-border);
    border-radius: 32px;
    padding: 36px;
    box-shadow: 0 14px 36px rgba(31, 41, 51, 0.06);
}

.gi-section-heading h2 {
    color: var(--gi-dark);
    font-size: 36px;
    margin: 0 0 24px;
}

.gi-lineas-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}

.gi-lineas-grid article {
    background: var(--gi-soft);
    border-radius: 22px;
    padding: 24px;
}

.gi-lineas-grid h3 {
    color: var(--gi-dark);
    margin-top: 0;
}

.gi-lineas-grid p {
    color: var(--gi-muted);
    line-height: 1.5;
}

/* Responsive */

@media (max-width: 980px) {
    .gi-hero,
    .gi-welcome-section {
        grid-template-columns: 1fr;
    }

    .gi-home-summary,
    .gi-dashboard-grid,
    .gi-lineas-grid {
        grid-template-columns: 1fr 1fr;
    }

    .gi-inner-header {
        position: static;
        flex-direction: column;
        align-items: flex-start;
    }

    .gi-inner-nav {
        flex-wrap: wrap;
    }
}

@media (max-width: 640px) {
    .gi-home-modern,
    .gi-site-modern {
        padding: 14px;
    }

    .gi-header,
    .gi-inner-header {
        border-radius: 18px;
        padding: 16px;
        flex-direction: column;
        align-items: flex-start;
    }

    .gi-hero {
        padding-top: 42px;
    }

    .gi-hero-card {
        min-height: auto;
    }

    .gi-home-summary,
    .gi-dashboard-grid,
    .gi-lineas-grid {
        grid-template-columns: 1fr;
    }

    .gi-welcome-section {
        padding: 26px;
    }
}

/* Ajuste del recuadro superior de navegación interna */

.gi-site-modern .gi-inner-header {
    position: sticky;
    top: 16px;
    left: 20%;
    transform: translateX(-20%);

    width: 1100px;
    max-width: calc(100vw - 80px);

    margin: 0 0 34px 0;
    padding: 22px 36px;
    box-sizing: border-box;

    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;

    background: rgba(255, 255, 255, 0.92);
    border: 1px solid var(--gi-border);
    border-radius: 22px;
    box-shadow: 0 14px 40px rgba(31, 41, 51, 0.08);

    z-index: 10;
}

.gi-site-modern .gi-inner-nav {
    flex: 1;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 22px;
    flex-wrap: nowrap;
}

.gi-site-modern .gi-inner-nav a {
    white-space: nowrap;
}

.gi-site-modern .gi-inner-nav a {
    white-space: nowrap;
}

/* Página pública de miembros */

.gi-members-page {
    max-width: 1180px;
    margin: 0 auto;
    padding: 40px 24px 70px;
}

.gi-section-hero {
    background:
        radial-gradient(circle at top right, rgba(180, 0, 0, 0.12), transparent 34%),
        #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 32px;
    padding: 48px;
    box-shadow: 0 18px 50px rgba(31, 41, 51, 0.08);
    margin-bottom: 26px;
}

.gi-section-hero h1 {
    color: var(--gi-dark);
    font-size: clamp(38px, 5vw, 62px);
    margin: 0 0 16px;
    letter-spacing: -0.05em;
}

.gi-section-hero p {
    color: var(--gi-muted);
    font-size: 18px;
    line-height: 1.7;
    max-width: 760px;
    margin: 0;
}

.gi-members-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    background: #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 24px;
    padding: 16px;
    box-shadow: 0 12px 34px rgba(31, 41, 51, 0.06);
    margin-bottom: 34px;
}

.gi-members-filters a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--gi-dark);
    background: var(--gi-soft);
    border-radius: 999px;
    padding: 10px 16px;
    font-weight: 800;
    text-decoration: none;
    transition: all 0.15s ease;
}

.gi-members-filters a:hover {
    color: #ffffff;
    background: var(--gi-red);
    transform: translateY(-2px);
}

.gi-members-section {
    margin-top: 42px;
}

.gi-section-title {
    margin-bottom: 18px;
}

.gi-section-title h2 {
    color: var(--gi-dark);
    font-size: 32px;
    margin: 0 0 6px;
}

.gi-section-title p {
    color: var(--gi-muted);
    margin: 0;
}

.gi-members-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.gi-member-card {
    display: grid;
    grid-template-columns: 96px 1fr;
    gap: 20px;
    align-items: start;
    background: #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 28px;
    padding: 22px;
    box-shadow: 0 14px 36px rgba(31, 41, 51, 0.07);
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.gi-member-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 20px 48px rgba(31, 41, 51, 0.12);
}

.gi-member-photo {
    width: 88px;
    height: 88px;
    border-radius: 24px;
    background: linear-gradient(135deg, var(--gi-red), var(--gi-dark-red));
    color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    font-weight: 900;
    overflow: hidden;
}

.gi-member-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.gi-member-role {
    display: inline-flex;
    color: var(--gi-red);
    background: #fff1f1;
    border-radius: 999px;
    padding: 6px 10px;
    font-size: 12px;
    font-weight: 900;
    margin-bottom: 10px;
}

.gi-member-info h3 {
    color: var(--gi-dark);
    font-size: 22px;
    line-height: 1.2;
    margin: 0 0 12px;
}

.gi-member-info ul {
    list-style: none;
    padding: 0;
    margin: 0 0 16px;
}

.gi-member-info li {
    color: var(--gi-muted);
    line-height: 1.45;
    margin-bottom: 4px;
}

.gi-member-info strong {
    color: var(--gi-dark);
}

.gi-member-link {
    color: var(--gi-red);
    font-weight: 900;
    text-decoration: none;
}

.gi-member-link:hover {
    text-decoration: underline;
}

@media (max-width: 800px) {
    .gi-members-grid {
        grid-template-columns: 1fr;
    }

    .gi-member-card {
        grid-template-columns: 72px 1fr;
    }

    .gi-member-photo {
        width: 72px;
        height: 72px;
        border-radius: 20px;
        font-size: 20px;
    }
}

@media (max-width: 560px) {
    .gi-section-hero {
        padding: 30px;
    }

    .gi-member-card {
        grid-template-columns: 1fr;
    }
}

/* Página pública de publicaciones */

.gi-publications-page {
    max-width: 1180px;
    margin: 0 auto;
    padding: 40px 24px 70px;
}

.gi-publications-hero {
    margin-bottom: 26px;
}

.gi-publications-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 24px;
    background: #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 26px;
    padding: 18px 20px;
    box-shadow: 0 12px 34px rgba(31, 41, 51, 0.06);
    margin-bottom: 34px;
}

.gi-year-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.gi-year-filters a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--gi-dark);
    background: var(--gi-soft);
    border-radius: 999px;
    padding: 9px 14px;
    font-size: 14px;
    font-weight: 800;
    text-decoration: none;
    transition: all 0.15s ease;
}

.gi-year-filters a:hover,
.gi-year-filters a.active {
    background: var(--gi-red);
    color: #ffffff;
    transform: translateY(-2px);
}

.gi-publication-search {
    display: flex;
    align-items: center;
    gap: 10px;
}

.gi-publication-search label {
    color: var(--gi-muted);
    font-weight: 700;
    font-size: 14px;
}

.gi-publication-search input {
    min-width: 240px;
    border: 1px solid var(--gi-border);
    border-radius: 999px;
    padding: 10px 14px;
    font-size: 14px;
    outline: none;
}

.gi-publication-search input:focus {
    border-color: var(--gi-red);
    box-shadow: 0 0 0 3px rgba(180, 0, 0, 0.12);
}

.gi-publication-category {
    background: #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 32px;
    padding: 28px;
    box-shadow: 0 18px 50px rgba(31, 41, 51, 0.08);
}

.gi-category-heading {
    display: flex;
    align-items: center;
    gap: 18px;
    margin-bottom: 24px;
}

.gi-category-icon {
    width: 54px;
    height: 54px;
    border-radius: 18px;
    background: #fff1f1;
    color: var(--gi-red);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 26px;
}

.gi-category-heading h2 {
    color: var(--gi-dark);
    font-size: 34px;
    margin: 0 0 4px;
}

.gi-category-heading p {
    color: var(--gi-muted);
    margin: 0;
}

.gi-publications-list {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.gi-publication-card {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 22px;
    background: var(--gi-soft);
    border: 1px solid var(--gi-border);
    border-radius: 24px;
    padding: 22px;
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.gi-publication-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 16px 38px rgba(31, 41, 51, 0.1);
}

.gi-publication-year {
    display: inline-flex;
    background: #ffffff;
    color: var(--gi-red);
    border: 1px solid #ffd8d8;
    border-radius: 999px;
    padding: 5px 10px;
    font-size: 13px;
    font-weight: 900;
    margin-bottom: 12px;
}

.gi-publication-main h3 {
    color: var(--gi-dark);
    font-size: 22px;
    line-height: 1.25;
    margin: 0 0 10px;
}

.gi-publication-authors {
    color: var(--gi-text);
    margin: 0 0 6px;
    line-height: 1.5;
}

.gi-publication-authors strong {
    color: var(--gi-red);
}

.gi-publication-source {
    color: var(--gi-muted);
    margin: 0;
    line-height: 1.5;
}

.gi-publication-actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
    align-items: flex-end;
    justify-content: center;
}

.gi-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 48px;
    border-radius: 999px;
    padding: 7px 10px;
    color: #ffffff;
    font-size: 12px;
    font-weight: 900;
    text-decoration: none;
    text-transform: uppercase;
}

.gi-pill-blue {
    background: #3b82f6;
}

.gi-pill-orange {
    background: #f59e0b;
}

.gi-pill-green {
    background: #65a30d;
}

@media (max-width: 850px) {
    .gi-publications-toolbar {
        align-items: flex-start;
        flex-direction: column;
    }

    .gi-publication-search {
        width: 100%;
        align-items: flex-start;
        flex-direction: column;
    }

    .gi-publication-search input {
        width: 100%;
        min-width: 0;
    }

    .gi-publication-card {
        grid-template-columns: 1fr;
    }

    .gi-publication-actions {
        flex-direction: row;
        justify-content: flex-start;
        align-items: center;
    }
}

/* Página pública de eventos */

.gi-events-page {
    max-width: 1180px;
    margin: 0 auto;
    padding: 40px 24px 70px;
}

.gi-events-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
}

.gi-event-card {
    display: grid;
    grid-template-columns: 120px 1fr;
    gap: 24px;
    background: #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 30px;
    padding: 26px;
    box-shadow: 0 18px 50px rgba(31, 41, 51, 0.08);
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.gi-event-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 24px 60px rgba(31, 41, 51, 0.12);
}

.gi-event-date {
    width: 110px;
    height: 120px;
    border-radius: 26px;
    background: linear-gradient(135deg, var(--gi-red), var(--gi-dark-red));
    color: #ffffff;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    box-shadow: 0 16px 32px rgba(180, 0, 0, 0.22);
}

.gi-event-date span {
    font-size: 42px;
    font-weight: 900;
    line-height: 1;
}

.gi-event-date strong {
    font-size: 17px;
    letter-spacing: 0.08em;
    margin-top: 6px;
}

.gi-event-date small {
    opacity: 0.86;
    margin-top: 4px;
}

.gi-event-type {
    display: inline-flex;
    color: var(--gi-red);
    background: #fff1f1;
    border-radius: 999px;
    padding: 6px 10px;
    font-size: 12px;
    font-weight: 900;
    margin-bottom: 12px;
}

.gi-event-content h2 {
    color: var(--gi-dark);
    font-size: 28px;
    line-height: 1.15;
    margin: 0 0 12px;
}

.gi-event-content p {
    color: var(--gi-muted);
    line-height: 1.6;
    margin: 0 0 16px;
}

.gi-event-content ul {
    list-style: none;
    padding: 0;
    margin: 0 0 18px;
}

.gi-event-content li {
    color: var(--gi-muted);
    margin-bottom: 5px;
}

.gi-event-content strong {
    color: var(--gi-dark);
}

.gi-event-link {
    color: var(--gi-red);
    font-weight: 900;
    text-decoration: none;
}

.gi-event-link:hover {
    text-decoration: underline;
}

@media (max-width: 700px) {
    .gi-event-card {
        grid-template-columns: 1fr;
    }

    .gi-event-date {
        width: 100%;
        height: auto;
        padding: 20px;
    }
}

/* Página pública de investigación */

.gi-research-page {
    max-width: 1180px;
    margin: 0 auto;
    padding: 40px 24px 80px;
}

.gi-research-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    background: #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 24px;
    padding: 16px;
    box-shadow: 0 12px 34px rgba(31, 41, 51, 0.06);
    margin-bottom: 36px;
}

.gi-research-tabs a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--gi-dark);
    background: var(--gi-soft);
    border-radius: 999px;
    padding: 10px 16px;
    font-weight: 800;
    text-decoration: none;
    transition: all 0.15s ease;
}

.gi-research-tabs a:hover {
    color: #ffffff;
    background: var(--gi-red);
    transform: translateY(-2px);
}

.gi-research-block {
    margin-top: 48px;
}

.gi-research-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px;
}

.gi-research-card {
    background: #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 28px;
    padding: 28px;
    box-shadow: 0 16px 42px rgba(31, 41, 51, 0.07);
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.gi-research-card:hover,
.gi-project-card:hover,
.gi-line-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 22px 54px rgba(31, 41, 51, 0.12);
}

.gi-research-card-featured {
    background:
        radial-gradient(circle at top right, rgba(180, 0, 0, 0.12), transparent 34%),
        #ffffff;
}

.gi-research-label,
.gi-project-status {
    display: inline-flex;
    color: var(--gi-red);
    background: #fff1f1;
    border-radius: 999px;
    padding: 7px 11px;
    font-size: 12px;
    font-weight: 900;
    margin-bottom: 14px;
}

.gi-research-card h3,
.gi-line-card h3,
.gi-project-card h3 {
    color: var(--gi-dark);
    font-size: 25px;
    line-height: 1.18;
    margin: 0 0 12px;
}

.gi-research-card p,
.gi-line-card p,
.gi-project-card p {
    color: var(--gi-muted);
    line-height: 1.65;
    margin: 0;
}

.gi-research-meta {
    margin-top: 20px;
}

.gi-research-meta strong {
    display: block;
    color: var(--gi-dark);
    margin-bottom: 8px;
}

.gi-research-meta span {
    display: inline-flex;
    margin: 0 6px 8px 0;
    background: var(--gi-soft);
    color: var(--gi-text);
    border-radius: 999px;
    padding: 7px 10px;
    font-size: 13px;
    font-weight: 700;
}

.gi-research-links {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 18px;
}

.gi-research-links a,
.gi-project-card a {
    color: var(--gi-red);
    font-weight: 900;
    text-decoration: none;
}

.gi-research-links a:hover,
.gi-project-card a:hover {
    text-decoration: underline;
}

.gi-lines-list {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.gi-line-card {
    display: grid;
    grid-template-columns: 88px 1fr;
    gap: 22px;
    align-items: center;
    background: #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 28px;
    padding: 24px;
    box-shadow: 0 14px 36px rgba(31, 41, 51, 0.07);
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.gi-line-icon {
    width: 76px;
    height: 76px;
    border-radius: 22px;
    background: linear-gradient(135deg, var(--gi-red), var(--gi-dark-red));
    color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 900;
    font-size: 20px;
    box-shadow: 0 16px 32px rgba(180, 0, 0, 0.18);
}

.gi-projects-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px;
}

.gi-project-card {
    background: #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 28px;
    padding: 28px;
    box-shadow: 0 16px 42px rgba(31, 41, 51, 0.07);
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.gi-project-card p {
    margin-bottom: 18px;
}

@media (max-width: 850px) {
    .gi-research-grid,
    .gi-projects-grid {
        grid-template-columns: 1fr;
    }

    .gi-line-card {
        grid-template-columns: 1fr;
    }

    .gi-line-icon {
        width: 64px;
        height: 64px;
    }
}

/* Página pública de recursos */

.gi-resources-page {
    max-width: 1180px;
    margin: 0 auto;
    padding: 40px 24px 80px;
}

.gi-resources-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    background: #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 24px;
    padding: 16px;
    box-shadow: 0 12px 34px rgba(31, 41, 51, 0.06);
    margin-bottom: 36px;
}

.gi-resources-tabs a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--gi-dark);
    background: var(--gi-soft);
    border-radius: 999px;
    padding: 10px 18px;
    font-weight: 800;
    text-decoration: none;
    transition: all 0.15s ease;
}

.gi-resources-tabs a:hover {
    color: #ffffff;
    background: var(--gi-red);
    transform: translateY(-2px);
}

.gi-resource-section {
    margin-top: 48px;
}

.gi-resource-list {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.gi-resource-item {
    display: grid;
    grid-template-columns: 88px 1fr auto;
    gap: 24px;
    align-items: center;
    background: #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 28px;
    padding: 24px;
    box-shadow: 0 16px 42px rgba(31, 41, 51, 0.07);
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.gi-resource-item:hover {
    transform: translateY(-3px);
    box-shadow: 0 22px 54px rgba(31, 41, 51, 0.12);
}

.gi-resource-badge {
    width: 76px;
    height: 76px;
    border-radius: 22px;
    background: linear-gradient(135deg, var(--gi-red), var(--gi-dark-red));
    color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 900;
    font-size: 18px;
    box-shadow: 0 16px 32px rgba(180, 0, 0, 0.18);
}

.gi-resource-badge-pdf {
    background: linear-gradient(135deg, #dc2626, #991b1b);
}

.gi-resource-badge-other {
    background: linear-gradient(135deg, #374151, #111827);
}

.gi-resource-type {
    display: inline-flex;
    color: var(--gi-red);
    background: #fff1f1;
    border-radius: 999px;
    padding: 7px 11px;
    font-size: 12px;
    font-weight: 900;
    margin-bottom: 10px;
}

.gi-resource-content h3 {
    color: var(--gi-dark);
    font-size: 25px;
    line-height: 1.18;
    margin: 0 0 10px;
}

.gi-resource-content p {
    color: var(--gi-muted);
    line-height: 1.6;
    margin: 0 0 14px;
}

.gi-resource-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.gi-resource-meta span {
    display: inline-flex;
    background: var(--gi-soft);
    color: var(--gi-text);
    border-radius: 999px;
    padding: 7px 10px;
    font-size: 13px;
    font-weight: 700;
}

.gi-download-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    background: linear-gradient(135deg, var(--gi-red), var(--gi-dark-red));
    border-radius: 999px;
    padding: 12px 18px;
    font-weight: 900;
    text-decoration: none;
    box-shadow: 0 12px 26px rgba(180, 0, 0, 0.18);
    white-space: nowrap;
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.gi-download-button:hover {
    color: #ffffff;
    transform: translateY(-2px);
    box-shadow: 0 16px 32px rgba(180, 0, 0, 0.24);
}

@media (max-width: 820px) {
    .gi-resource-item {
        grid-template-columns: 76px 1fr;
    }

    .gi-download-button {
        grid-column: 1 / -1;
        width: fit-content;
    }
}

@media (max-width: 560px) {
    .gi-resource-item {
        grid-template-columns: 1fr;
    }

    .gi-resource-badge {
        width: 68px;
        height: 68px;
    }
}

.gi-empty-state {
    background: #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 28px;
    padding: 32px;
    box-shadow: 0 14px 36px rgba(31, 41, 51, 0.07);
}

.gi-empty-state h3 {
    color: var(--gi-dark);
    margin: 0 0 8px;
    font-size: 24px;
}

.gi-empty-state p {
    color: var(--gi-muted);
    margin: 0;
}

.gi-member-bio {
    color: var(--gi-muted);
    line-height: 1.55;
    margin: 10px 0 0;
}

/* Detalle público de miembro */

.gi-member-detail-page {
    max-width: 1180px;
    margin: 0 auto;
    padding: 40px 24px 80px;
}

.gi-member-detail-hero {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 32px;
    align-items: center;
    background:
        radial-gradient(circle at top right, rgba(180, 0, 0, 0.12), transparent 34%),
        #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 34px;
    padding: 40px;
    box-shadow: 0 18px 50px rgba(31, 41, 51, 0.08);
    margin-bottom: 28px;
}

.gi-member-detail-photo {
    width: 190px;
    height: 190px;
    border-radius: 34px;
    background: linear-gradient(135deg, var(--gi-red), var(--gi-dark-red));
    color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 54px;
    font-weight: 900;
    overflow: hidden;
    box-shadow: 0 18px 42px rgba(180, 0, 0, 0.22);
}

.gi-member-detail-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.gi-back-link {
    display: inline-flex;
    color: var(--gi-muted);
    text-decoration: none;
    font-weight: 800;
    margin-bottom: 18px;
}

.gi-back-link:hover {
    color: var(--gi-red);
}

.gi-member-detail-main h1 {
    color: var(--gi-dark);
    font-size: clamp(36px, 5vw, 62px);
    letter-spacing: -0.05em;
    line-height: 1;
    margin: 0 0 16px;
}

.gi-member-detail-main p {
    color: var(--gi-muted);
    font-size: 18px;
    line-height: 1.65;
    max-width: 780px;
    margin: 0 0 24px;
}

.gi-member-detail-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.gi-member-detail-layout {
    display: grid;
    grid-template-columns: 320px 1fr;
    gap: 24px;
    align-items: start;
}

.gi-member-profile-card,
.gi-member-detail-section {
    background: #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 30px;
    padding: 28px;
    box-shadow: 0 14px 36px rgba(31, 41, 51, 0.07);
}

.gi-member-profile-card {
    position: sticky;
    top: 24px;
}

.gi-member-profile-card h2,
.gi-member-detail-section h2 {
    color: var(--gi-dark);
    font-size: 26px;
    line-height: 1.15;
    margin: 0 0 20px;
}

.gi-member-profile-card dl {
    margin: 0;
}

.gi-member-profile-card dl div {
    border-bottom: 1px solid var(--gi-border);
    padding: 14px 0;
}

.gi-member-profile-card dl div:last-child {
    border-bottom: 0;
}

.gi-member-profile-card dt {
    color: var(--gi-muted);
    font-size: 13px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 5px;
}

.gi-member-profile-card dd {
    margin: 0;
    color: var(--gi-dark);
    line-height: 1.45;
    word-break: break-word;
}

.gi-member-profile-card a {
    color: var(--gi-red);
    text-decoration: none;
    font-weight: 800;
}

.gi-member-profile-card a:hover {
    text-decoration: underline;
}

.gi-member-activity {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.gi-member-detail-section > p {
    color: var(--gi-text);
    line-height: 1.75;
    margin: 0;
}

.gi-muted-text {
    color: var(--gi-muted) !important;
}

.gi-member-related-list {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.gi-related-card {
    background: var(--gi-soft);
    border: 1px solid var(--gi-border);
    border-radius: 22px;
    padding: 20px;
}

.gi-related-badge {
    display: inline-flex;
    color: var(--gi-red);
    background: #fff1f1;
    border-radius: 999px;
    padding: 6px 10px;
    font-size: 12px;
    font-weight: 900;
    margin-bottom: 12px;
}

.gi-related-card h3 {
    color: var(--gi-dark);
    font-size: 21px;
    line-height: 1.25;
    margin: 0 0 10px;
}

.gi-related-card p {
    color: var(--gi-muted);
    line-height: 1.55;
    margin: 0 0 8px;
}

.gi-related-card a {
    color: var(--gi-red);
    font-weight: 900;
    text-decoration: none;
}

.gi-related-card a:hover {
    text-decoration: underline;
}

.gi-member-associated-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
}

.gi-member-associated-grid article {
    background: var(--gi-soft);
    border-radius: 22px;
    padding: 20px;
}

.gi-member-associated-grid span {
    display: block;
    color: var(--gi-red);
    font-weight: 900;
    margin-bottom: 8px;
}

.gi-member-associated-grid p {
    color: var(--gi-muted);
    line-height: 1.5;
    margin: 0;
}

@media (max-width: 900px) {
    .gi-member-detail-hero,
    .gi-member-detail-layout {
        grid-template-columns: 1fr;
    }

    .gi-member-profile-card {
        position: static;
    }

    .gi-member-associated-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 560px) {
    .gi-member-detail-hero {
        padding: 28px;
    }

    .gi-member-detail-photo {
        width: 140px;
        height: 140px;
        border-radius: 28px;
        font-size: 42px;
    }
}

.gi-associated-list {
    list-style: none;
    padding: 0;
    margin: 12px 0 0;
}

.gi-associated-list li {
    background: #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 16px;
    padding: 14px;
    margin-bottom: 10px;
}

.gi-associated-list strong {
    color: var(--gi-dark);
    display: block;
    margin-bottom: 6px;
}

.gi-associated-list p {
    color: var(--gi-muted);
    line-height: 1.45;
    margin: 0;
}

/* Detalle público de publicación */

.gi-publication-detail-page {
    max-width: 1180px;
    margin: 0 auto;
    padding: 40px 24px 80px;
}

.gi-publication-detail-hero {
    background:
        radial-gradient(circle at top right, rgba(180, 0, 0, 0.12), transparent 34%),
        #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 34px;
    padding: 44px;
    box-shadow: 0 18px 50px rgba(31, 41, 51, 0.08);
    margin-bottom: 28px;
}

.gi-publication-detail-hero h1 {
    color: var(--gi-dark);
    font-size: clamp(34px, 5vw, 58px);
    letter-spacing: -0.04em;
    line-height: 1.08;
    margin: 0 0 16px;
}

.gi-publication-detail-hero p {
    color: var(--gi-muted);
    font-size: 18px;
    line-height: 1.65;
    max-width: 820px;
    margin: 0 0 24px;
}

.gi-publication-detail-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.gi-publication-detail-layout {
    display: grid;
    grid-template-columns: 320px 1fr;
    gap: 24px;
    align-items: start;
}

.gi-publication-meta-card,
.gi-publication-detail-section {
    background: #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 30px;
    padding: 28px;
    box-shadow: 0 14px 36px rgba(31, 41, 51, 0.07);
}

.gi-publication-meta-card {
    position: sticky;
    top: 24px;
}

.gi-publication-meta-card h2,
.gi-publication-detail-section h2 {
    color: var(--gi-dark);
    font-size: 26px;
    line-height: 1.15;
    margin: 0 0 20px;
}

.gi-publication-meta-card dl {
    margin: 0;
}

.gi-publication-meta-card dl div {
    border-bottom: 1px solid var(--gi-border);
    padding: 14px 0;
}

.gi-publication-meta-card dl div:last-child {
    border-bottom: 0;
}

.gi-publication-meta-card dt {
    color: var(--gi-muted);
    font-size: 13px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 5px;
}

.gi-publication-meta-card dd {
    margin: 0;
    color: var(--gi-dark);
    line-height: 1.45;
    word-break: break-word;
}

.gi-publication-meta-card a {
    color: var(--gi-red);
    font-weight: 800;
    text-decoration: none;
}

.gi-publication-detail-content {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.gi-publication-detail-section > p {
    color: var(--gi-text);
    line-height: 1.75;
    margin: 0;
}

.gi-publication-info-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
}

.gi-publication-info-grid article {
    background: var(--gi-soft);
    border-radius: 22px;
    padding: 20px;
}

.gi-publication-info-grid span {
    display: block;
    color: var(--gi-red);
    font-weight: 900;
    margin-bottom: 8px;
}

.gi-publication-info-grid p {
    color: var(--gi-muted);
    line-height: 1.5;
    margin: 0;
}

.gi-bibtex-box {
    background: #111827;
    color: #e5e7eb;
    border-radius: 22px;
    padding: 22px;
    overflow-x: auto;
    white-space: pre-wrap;
    line-height: 1.5;
}

.gi-publication-title-link {
    color: inherit;
    text-decoration: none;
}

.gi-publication-title-link:hover {
    color: var(--gi-red);
    text-decoration: underline;
}

@media (max-width: 900px) {
    .gi-publication-detail-layout {
        grid-template-columns: 1fr;
    }

    .gi-publication-meta-card {
        position: static;
    }

    .gi-publication-info-grid {
        grid-template-columns: 1fr;
    }
}

.gi-login-page,
.gi-profile-page {
    max-width: 900px;
    margin: 0 auto;
    padding: 40px 24px 80px;
}

.gi-login-card {
    background: #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 30px;
    padding: 32px;
    box-shadow: 0 18px 50px rgba(31, 41, 51, 0.08);
}

.gi-login-card h2 {
    color: var(--gi-dark);
    font-size: 30px;
    margin: 0 0 24px;
}

.gi-form-field {
    margin-bottom: 18px;
}

.gi-form-field label {
    display: block;
    color: var(--gi-dark);
    font-weight: 900;
    margin-bottom: 8px;
}

.gi-form-field input,
.gi-form-field textarea {
    width: 100%;
    border: 1px solid var(--gi-border);
    border-radius: 16px;
    padding: 13px 15px;
    font-size: 16px;
    box-sizing: border-box;
}

.gi-form-field input:focus,
.gi-form-field textarea:focus {
    outline: none;
    border-color: var(--gi-red);
    box-shadow: 0 0 0 3px rgba(180, 0, 0, 0.12);
}

.gi-login-error {
    background: #fff1f1;
    color: var(--gi-red);
    border: 1px solid #fecaca;
    border-radius: 18px;
    padding: 14px 16px;
    font-weight: 800;
    margin-bottom: 18px;
}

.gi-login-success {
    background: #f0fdf4;
    color: #166534;
    border: 1px solid #bbf7d0;
    border-radius: 18px;
    padding: 14px 16px;
    font-weight: 800;
    margin-bottom: 18px;
}

/* Barra superior pública propia del plugin */

.gi-topbar-public {
    width: 100%;
    max-width: 1500px;
    margin: 0 auto 70px;
    padding: 24px 48px;

    display: flex;
    align-items: center;
    justify-content: space-between;

    box-sizing: border-box;
}

.gi-topbar-logo {
    color: var(--gi-dark);
    font-size: 30px;
    font-weight: 900;
    text-decoration: none;
}

.gi-topbar-actions {
    display: flex;
    align-items: center;
    gap: 24px;
}

.gi-topbar-actions a {
    color: var(--gi-dark);
    font-size: 18px;
    font-weight: 700;
    text-decoration: none;
}

.gi-topbar-actions a:hover {
    color: var(--gi-red);
}

.gi-import-card {
    margin-top: 28px;
}

.gi-import-card p {
    color: var(--gi-muted);
    line-height: 1.6;
    margin: 0 0 22px;
}

/* Selector de investigación */

.gi-research-selector {
    display: flex;
    flex-wrap: wrap;
    gap: 18px;
    align-items: center;
    justify-content: center;
    background: #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 28px;
    padding: 24px;
    margin: 32px auto 48px;
    box-shadow: 0 18px 50px rgba(31, 41, 51, 0.08);
}

.gi-research-tab {
    border: 0;
    background: var(--gi-soft);
    color: var(--gi-dark);
    border-radius: 999px;
    padding: 14px 26px;
    font-size: 18px;
    font-weight: 900;
    cursor: pointer;
    transition: all 0.2s ease;
}

.gi-research-tab:hover {
    background: #fff1f1;
    color: var(--gi-red);
    transform: translateY(-2px);
}

.gi-research-tab.active {
    background: var(--gi-red);
    color: #ffffff;
    box-shadow: 0 12px 28px rgba(180, 0, 0, 0.2);
}

.gi-research-content {
    display: none;
}

.gi-research-content.is-active {
    display: block;
    margin-top: 36px;
}

.gi-detail-link {
    color: inherit;
    text-decoration: none;
}

.gi-detail-link:hover {
    color: var(--gi-red);
    text-decoration: underline;
}

/* Detalles de investigación: trabajo, línea y proyecto */

.gi-detail-page {
    max-width: 1180px;
    margin: 0 auto;
    padding: 40px 24px 80px;
}

.gi-detail-hero {
    background:
        radial-gradient(circle at top right, rgba(180, 0, 0, 0.12), transparent 34%),
        #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 34px;
    padding: 44px;
    box-shadow: 0 18px 50px rgba(31, 41, 51, 0.08);
    margin-bottom: 28px;
}

.gi-detail-hero h1 {
    color: var(--gi-dark);
    font-size: clamp(34px, 5vw, 58px);
    letter-spacing: -0.04em;
    line-height: 1.08;
    margin: 0 0 16px;
}

.gi-detail-hero p {
    color: var(--gi-muted);
    font-size: 18px;
    line-height: 1.65;
    max-width: 900px;
    margin: 0;
}

.gi-detail-layout {
    display: grid;
    grid-template-columns: 320px 1fr;
    gap: 24px;
    align-items: start;
}

.gi-detail-meta-card,
.gi-detail-section {
    background: #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 30px;
    padding: 28px;
    box-shadow: 0 14px 36px rgba(31, 41, 51, 0.07);
}

.gi-detail-meta-card {
    position: sticky;
    top: 24px;
}

.gi-detail-meta-card h2,
.gi-detail-section h2 {
    color: var(--gi-dark);
    font-size: 26px;
    line-height: 1.15;
    margin: 0 0 20px;
}

.gi-detail-meta-card dl {
    margin: 0;
}

.gi-detail-meta-card dl div {
    border-bottom: 1px solid var(--gi-border);
    padding: 14px 0;
}

.gi-detail-meta-card dl div:last-child {
    border-bottom: 0;
}

.gi-detail-meta-card dt {
    color: var(--gi-muted);
    font-size: 13px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 5px;
}

.gi-detail-meta-card dd {
    margin: 0;
    color: var(--gi-dark);
    line-height: 1.45;
    word-break: break-word;
}

.gi-detail-content {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.gi-detail-content-full {
    grid-column: 1 / -1;
}

.gi-detail-link {
    color: inherit;
    text-decoration: none;
}

.gi-detail-link:hover {
    color: var(--gi-red);
    text-decoration: underline;
}

.gi-members-mini-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 14px;
}

.gi-mini-member {
    background: var(--gi-soft);
    border: 1px solid var(--gi-border);
    border-radius: 20px;
    padding: 16px;
    text-decoration: none;
    color: var(--gi-dark);
}

.gi-mini-member strong {
    display: block;
    margin-bottom: 6px;
}

.gi-mini-member span {
    color: var(--gi-muted);
    font-size: 14px;
}

@media (max-width: 900px) {
    .gi-detail-layout {
        grid-template-columns: 1fr;
    }

    .gi-detail-meta-card {
        position: static;
    }
}

/* Selector de recursos */

.gi-resource-selector {
    display: flex;
    flex-wrap: wrap;
    gap: 18px;
    align-items: center;
    justify-content: center;
    background: #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 28px;
    padding: 24px;
    margin: 32px auto 48px;
    box-shadow: 0 18px 50px rgba(31, 41, 51, 0.08);
}

.gi-resource-tab {
    border: 0;
    background: var(--gi-soft);
    color: var(--gi-dark);
    border-radius: 999px;
    padding: 14px 26px;
    font-size: 18px;
    font-weight: 900;
    cursor: pointer;
    transition: all 0.2s ease;
}

.gi-resource-tab:hover {
    background: #fff1f1;
    color: var(--gi-red);
    transform: translateY(-2px);
}

.gi-resource-tab.active {
    background: var(--gi-red);
    color: #ffffff;
    box-shadow: 0 12px 28px rgba(180, 0, 0, 0.2);
}

.gi-resource-panel {
    display: none;
}

.gi-detail-link {
    color: inherit;
    text-decoration: none;
}

.gi-detail-link:hover {
    color: var(--gi-red);
    text-decoration: underline;
}

/* Selector de recursos */

.gi-resource-selector {
    display: flex;
    flex-wrap: wrap;
    gap: 18px;
    align-items: center;
    justify-content: center;
    background: #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 28px;
    padding: 24px;
    margin: 32px auto 48px;
    box-shadow: 0 18px 50px rgba(31, 41, 51, 0.08);
}

.gi-resource-tab {
    border: 0;
    background: var(--gi-soft);
    color: var(--gi-dark);
    border-radius: 999px;
    padding: 14px 26px;
    font-size: 18px;
    font-weight: 900;
    cursor: pointer;
    transition: all 0.2s ease;
}

.gi-resource-tab:hover {
    background: #fff1f1;
    color: var(--gi-red);
    transform: translateY(-2px);
}

.gi-resource-tab.active {
    background: var(--gi-red);
    color: #ffffff;
    box-shadow: 0 12px 28px rgba(180, 0, 0, 0.2);
}

.gi-detail-link {
    color: inherit;
    text-decoration: none;
}

.gi-detail-link:hover {
    color: var(--gi-red);
    text-decoration: underline;
}

.gi-profile-links {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.gi-profile-links a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--gi-soft);
    border: 1px solid var(--gi-border);
    color: var(--gi-dark);
    border-radius: 999px;
    padding: 10px 16px;
    font-weight: 800;
    text-decoration: none;
    transition: all 0.2s ease;
}

.gi-profile-links a:hover {
    background: var(--gi-red);
    color: #ffffff;
    transform: translateY(-2px);
}

.gi-associated-link {
    color: var(--gi-dark);
    font-weight: 800;
    text-decoration: none;
}

.gi-associated-link:hover {
    color: var(--gi-red);
    text-decoration: underline;
}

/* Filtros reales de publicaciones */

.gi-publications-filters {
    background: #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 28px;
    padding: 24px;
    box-shadow: 0 18px 50px rgba(31, 41, 51, 0.08);
    margin-bottom: 36px;
}

.gi-filter-form {
    display: grid;
    grid-template-columns: 1.5fr 0.8fr 1fr auto;
    gap: 18px;
    align-items: end;
}

.gi-filter-form .gi-form-field {
    margin-bottom: 0;
}

.gi-filter-form label {
    display: block;
    color: var(--gi-dark);
    font-weight: 900;
    margin-bottom: 8px;
}

.gi-filter-form input,
.gi-filter-form select {
    width: 100%;
    border: 1px solid var(--gi-border);
    border-radius: 16px;
    padding: 13px 15px;
    font-size: 15px;
    box-sizing: border-box;
    background: #ffffff;
}

.gi-filter-form input:focus,
.gi-filter-form select:focus {
    outline: none;
    border-color: var(--gi-red);
    box-shadow: 0 0 0 3px rgba(180, 0, 0, 0.12);
}

.gi-filter-actions {
    display: flex;
    gap: 10px;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
}

@media (max-width: 950px) {
    .gi-filter-form {
        grid-template-columns: 1fr;
    }

    .gi-filter-actions {
        justify-content: flex-start;
    }
}

.gi-events-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin: 32px 0 20px;
}

.gi-events-filters a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--gi-soft);
    border: 1px solid var(--gi-border);
    color: var(--gi-dark);
    border-radius: 999px;
    padding: 10px 18px;
    font-weight: 800;
    text-decoration: none;
    transition: all 0.2s ease;
}

.gi-events-filters a:hover {
    background: #fff1f1;
    color: var(--gi-red);
    transform: translateY(-2px);
}

.gi-events-filters a.active {
    background: var(--gi-red);
    color: #ffffff;
    box-shadow: 0 10px 24px rgba(180, 0, 0, 0.18);
}

/* Exportación de publicaciones */

.gi-export-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    background: #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 28px;
    padding: 24px;
    margin-bottom: 36px;
    box-shadow: 0 18px 50px rgba(31, 41, 51, 0.08);
}

.gi-export-toolbar h2 {
    margin: 0 0 6px;
    color: var(--gi-dark);
    font-size: 24px;
}

.gi-export-toolbar p {
    margin: 0;
    color: var(--gi-muted);
}

.gi-export-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: flex-end;
}

@media (max-width: 850px) {
    .gi-export-toolbar {
        flex-direction: column;
        align-items: flex-start;
    }

    .gi-export-actions {
        justify-content: flex-start;
    }
}

.gi-publication-actions-separated {
    display: flex;
    gap: 18px;
    align-items: flex-start;
    justify-content: flex-end;
}

.gi-publication-action-group {
    display: flex;
    flex-direction: column;
    gap: 8px;
    align-items: stretch;
}

.gi-action-group-title {
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--gi-muted);
    text-align: center;
    margin-bottom: 2px;
}

.gi-publication-action-group .gi-pill {
    min-width: 84px;
    text-align: center;
    justify-content: center;
}

@media (max-width: 750px) {
    .gi-publication-actions-separated {
        justify-content: flex-start;
        margin-top: 18px;
    }

    .gi-publication-action-group {
        align-items: flex-start;
    }

    .gi-action-group-title {
        text-align: left;
    }
}

/* Estadísticas */

.gi-stats-page {
    max-width: 1280px;
}

.gi-stats-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 18px;
    margin-bottom: 36px;
}

.gi-stat-card {
    background: #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 26px;
    padding: 24px;
    box-shadow: 0 18px 50px rgba(31, 41, 51, 0.08);
}

.gi-stat-card span {
    display: block;
    color: var(--gi-red);
    font-weight: 900;
    text-transform: uppercase;
    font-size: 12px;
    letter-spacing: 0.08em;
    margin-bottom: 10px;
}

.gi-stat-card strong {
    display: block;
    color: var(--gi-dark);
    font-size: 44px;
    line-height: 1;
    margin-bottom: 12px;
}

.gi-stat-card p {
    margin: 0;
    color: var(--gi-muted);
    font-size: 15px;
}

.gi-stats-two-columns {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    margin-bottom: 36px;
}

.gi-stats-panel {
    background: #ffffff;
    border: 1px solid var(--gi-border);
    border-radius: 28px;
    padding: 28px;
    box-shadow: 0 18px 50px rgba(31, 41, 51, 0.08);
    margin-bottom: 36px;
}

.gi-event-stats {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
}

.gi-event-stats div {
    background: var(--gi-soft);
    border-radius: 22px;
    padding: 22px;
}

.gi-event-stats span {
    display: block;
    color: var(--gi-muted);
    font-weight: 800;
    margin-bottom: 8px;
}

.gi-event-stats strong {
    color: var(--gi-red);
    font-size: 38px;
}

.gi-stats-summary {
    list-style: none;
    padding: 0;
    margin: 0;
}

.gi-stats-summary li {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    padding: 14px 0;
    border-bottom: 1px solid var(--gi-border);
}

.gi-stats-summary li:last-child {
    border-bottom: 0;
}

.gi-stats-summary span {
    color: var(--gi-muted);
    font-weight: 700;
}

.gi-stats-summary strong {
    color: var(--gi-red);
    font-weight: 900;
}

.gi-bars-list {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.gi-bar-row {
    display: grid;
    grid-template-columns: 180px 1fr;
    gap: 18px;
    align-items: center;
}

.gi-bar-label {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    color: var(--gi-dark);
    font-weight: 800;
}

.gi-bar-label strong {
    color: var(--gi-red);
}

.gi-bar-track {
    height: 16px;
    border-radius: 999px;
    background: var(--gi-soft);
    overflow: hidden;
}

.gi-bar-fill {
    height: 100%;
    border-radius: 999px;
    background: var(--gi-red);
}

@media (max-width: 1050px) {
    .gi-stats-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .gi-stats-two-columns {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 650px) {
    .gi-stats-grid {
        grid-template-columns: 1fr;
    }

    .gi-event-stats {
        grid-template-columns: 1fr;
    }

    .gi-bar-row {
        grid-template-columns: 1fr;
    }
}

.gi-public-page.gi-site-modern {
    height: auto !important;
    min-height: 0 !important;
}

/* =========================================================
   DOCENCIA PÚBLICA
   ========================================================= */

.gi-teaching-page {
    width: 100%;
}

.gi-teaching-hero {
    margin-bottom: 30px;
}

.gi-teaching-filter-section {
    margin-bottom: 38px;
    padding: 22px 26px;
    border: 1px solid #e2e5e9;
    border-radius: 20px;
    background: #ffffff;
}

.gi-teaching-filter-heading {
    margin-bottom: 14px;
}

.gi-teaching-filter-heading span {
    color: #687180;
    font-size: 13px;
    font-weight: 800;
    letter-spacing: 0.07em;
    text-transform: uppercase;
}

.gi-teaching-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.gi-teaching-filter {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 9px 18px;
    border: 1px solid #d9dde3;
    border-radius: 999px;
    background: #ffffff;
    color: #28313d;
    font-size: 15px;
    font-weight: 700;
    line-height: 1;
    text-decoration: none;
    transition:
        background-color 0.2s ease,
        border-color 0.2s ease,
        color 0.2s ease;
}

.gi-teaching-filter:hover {
    border-color: #b40000;
    color: #b40000;
}

.gi-teaching-filter.is-active {
    border-color: #b40000;
    background: #b40000;
    color: #ffffff;
}

.gi-teaching-content {
    display: flex;
    flex-direction: column;
    gap: 38px;
}

.gi-teaching-cycle {
    overflow: hidden;
    border: 1px solid #e0e4e8;
    border-radius: 26px;
    background: #f5f6f8;
    box-shadow: 0 18px 45px rgba(31, 41, 51, 0.07);
}

.gi-teaching-cycle-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    padding: 27px 30px;
    background: #ffffff;
    border-bottom: 1px solid #e0e4e8;
}

.gi-teaching-cycle-label,
.gi-teaching-degree-label,
.gi-subject-card-label,
.gi-subject-teachers-label {
    display: block;
    margin-bottom: 5px;
    color: #b40000;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.gi-teaching-cycle-header h2 {
    margin: 0;
    color: #1f2933;
    font-size: 34px;
    line-height: 1.15;
}

.gi-teaching-cycle-count,
.gi-teaching-degree-count {
    flex-shrink: 0;
    padding: 8px 14px;
    border-radius: 999px;
    background: #f1f3f5;
    color: #596273;
    font-size: 14px;
    font-weight: 700;
}

.gi-teaching-degrees {
    display: flex;
    flex-direction: column;
    gap: 24px;
    padding: 28px;
}

.gi-teaching-degree {
    padding: 25px;
    border: 1px solid #e0e4e8;
    border-radius: 21px;
    background: #ffffff;
}

.gi-teaching-degree-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 22px;
    padding-bottom: 18px;
    border-bottom: 1px solid #e5e8ec;
}

.gi-teaching-degree-header h3 {
    margin: 0;
    color: #1f2933;
    font-size: 25px;
    line-height: 1.25;
}

.gi-subject-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.gi-subject-card {
    display: flex;
    flex-direction: column;
    min-width: 0;
    padding: 23px;
    border: 1px solid #e2e5e9;
    border-radius: 18px;
    background: #fafbfc;
}

.gi-subject-card-header {
    margin-bottom: 18px;
}

.gi-subject-card h4 {
    margin: 0;
    color: #1f2933;
    font-size: 22px;
    line-height: 1.3;
}

.gi-subject-meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin: 0 0 20px;
}

.gi-subject-meta div {
    padding: 13px 15px;
    border-radius: 13px;
    background: #ffffff;
}

.gi-subject-meta dt {
    margin-bottom: 4px;
    color: #697386;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.gi-subject-meta dd {
    margin: 0;
    color: #1f2933;
    font-size: 17px;
    font-weight: 700;
}

.gi-subject-teachers {
    margin-top: auto;
    padding-top: 18px;
    border-top: 1px solid #e2e5e9;
}

.gi-subject-teachers p {
    margin: 0;
    color: #414b59;
    line-height: 1.55;
}

.gi-subject-teachers .gi-muted-text {
    color: #788291;
}

@media (max-width: 900px) {
    .gi-subject-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 650px) {
    .gi-teaching-cycle-header,
    .gi-teaching-degree-header {
        align-items: flex-start;
        flex-direction: column;
    }

    .gi-teaching-degrees {
        padding: 18px;
    }

    .gi-teaching-degree {
        padding: 19px;
    }

    .gi-subject-meta {
        grid-template-columns: 1fr;
    }

    .gi-teaching-cycle-header h2 {
        font-size: 28px;
    }

    .gi-teaching-degree-header h3 {
        font-size: 22px;
    }

    
}

.gi-editar-publicacion {
    width: min(100% - 32px, 980px);
    margin: 60px auto;
    padding: 0;
}

.gi-editar-publicacion__cabecera {
    margin-bottom: 24px;
    padding: 32px;
    border: 1px solid #e3e6ea;
    border-radius: 28px;
    background:
        linear-gradient(
            135deg,
            #ffffff 55%,
            #fff1f1 100%
        );
    box-shadow: 0 18px 45px rgba(20, 30, 45, 0.08);
}

.gi-editar-publicacion__volver {
    display: inline-block;
    margin-bottom: 18px;
    color: #5d6878;
    font-weight: 700;
    text-decoration: none;
}

.gi-editar-publicacion__volver:hover {
    color: #b50000;
}

.gi-editar-publicacion__etiqueta {
    display: block;
    margin-bottom: 8px;
    color: #b50000;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.gi-editar-publicacion__cabecera h2 {
    margin: 0 0 12px;
    color: #18222d;
    font-size: clamp(2rem, 5vw, 3.2rem);
    line-height: 1.08;
}

.gi-editar-publicacion__cabecera p {
    margin: 0;
    color: #5d6878;
    font-size: 1.05rem;
}

.gi-form-publicacion {
    padding: 32px;
    border: 1px solid #e3e6ea;
    border-radius: 28px;
    background: #ffffff;
    box-shadow: 0 18px 45px rgba(20, 30, 45, 0.08);
}

.gi-form-publicacion__rejilla {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px;
}

.gi-form-publicacion__campo {
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-width: 0;
    margin-bottom: 22px;
}

.gi-form-publicacion__campo--completo {
    width: 100%;
}

.gi-form-publicacion__campo label {
    color: #18222d;
    font-size: 0.95rem;
    font-weight: 750;
}

.gi-form-publicacion__campo label span {
    color: #b50000;
}

.gi-form-publicacion input,
.gi-form-publicacion textarea {
    box-sizing: border-box;
    width: 100%;
    min-height: 50px;
    padding: 13px 15px;
    border: 1px solid #d8dde3;
    border-radius: 14px;
    background: #f7f8fa;
    color: #18222d;
    font: inherit;
    line-height: 1.45;
    transition:
        border-color 0.2s ease,
        box-shadow 0.2s ease,
        background-color 0.2s ease;
}

.gi-form-publicacion textarea {
    min-height: 120px;
    resize: vertical;
}

.gi-form-publicacion input:focus,
.gi-form-publicacion textarea:focus {
    outline: none;
    border-color: #b50000;
    background: #ffffff;
    box-shadow: 0 0 0 4px rgba(181, 0, 0, 0.1);
}

.gi-form-publicacion__acciones {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-top: 10px;
    padding-top: 26px;
    border-top: 1px solid #e3e6ea;
}

.gi-form-publicacion__guardar,
.gi-form-publicacion__cancelar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 50px;
    padding: 12px 24px;
    border-radius: 999px;
    font: inherit;
    font-weight: 800;
    text-decoration: none;
    cursor: pointer;
}

.gi-form-publicacion__guardar {
    border: 1px solid #b50000;
    background: #b50000;
    color: #ffffff;
    box-shadow: 0 12px 24px rgba(181, 0, 0, 0.2);
}

.gi-form-publicacion__guardar:hover {
    background: #900000;
    border-color: #900000;
}

.gi-form-publicacion__cancelar {
    border: 1px solid #d8dde3;
    background: #ffffff;
    color: #18222d;
}

.gi-form-publicacion__cancelar:hover {
    border-color: #b50000;
    color: #b50000;
}

@media (max-width: 700px) {
    .gi-editar-publicacion {
        width: min(100% - 20px, 980px);
        margin: 30px auto;
    }

    .gi-editar-publicacion__cabecera,
    .gi-form-publicacion {
        padding: 22px;
        border-radius: 20px;
    }

    .gi-form-publicacion__rejilla {
        grid-template-columns: 1fr;
        gap: 0;
    }

    .gi-form-publicacion__acciones {
        flex-direction: column;
    }

    .gi-form-publicacion__guardar,
    .gi-form-publicacion__cancelar {
        width: 100%;
    }
}

.gi-event-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;
    margin-top: 20px;
}

.gi-event-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 10px 20px;
    border: 1px solid #b50000;
    border-radius: 999px;
    background: #b50000;
    color: #ffffff;
    font-weight: 750;
    line-height: 1.2;
    text-decoration: none;
    transition:
        background-color 0.2s ease,
        border-color 0.2s ease,
        color 0.2s ease;
}

.gi-event-link:hover {
    border-color: #900000;
    background: #900000;
    color: #ffffff;
}

.gi-event-link--edit {
    border-color: #d8dde3;
    background: #ffffff;
    color: #18222d;
}

.gi-event-link--edit:hover {
    border-color: #b50000;
    background: #ffffff;
    color: #b50000;
}

/* Acciones de gestión del evento */
.gi-evento__acciones {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 20px;
}

/* Evita márgenes añadidos por WordPress al formulario */
.gi-evento__form-borrar {
    display: inline-flex;
    margin: 0;
    padding: 0;
}

/* Estilo común para editar y borrar */
.gi-evento__editar,
.gi-evento__borrar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 52px;
    padding: 0 20px;
    border-radius: 999px;
    font-family: inherit;
    font-size: 16px;
    font-weight: 700;
    line-height: 1;
    text-decoration: none;
    cursor: pointer;
    box-sizing: border-box;
    transition:
        background-color 0.2s ease,
        color 0.2s ease,
        border-color 0.2s ease,
        transform 0.2s ease,
        box-shadow 0.2s ease;
}

/* Botón editar */
.gi-evento__editar {
    border: 1px solid #d6dce5;
    background-color: #ffffff;
    color: #172033;
}

.gi-evento__editar:hover {
    border-color: #172033;
    background-color: #172033;
    color: #ffffff;
    transform: translateY(-1px);
}

/* Botón borrar */
.gi-evento__borrar {
    appearance: none;
    border: 1px solid #b00000;
    background-color: #ffffff;
    color: #b00000;
}

.gi-evento__borrar:hover {
    border-color: #b00000;
    background-color: #b00000;
    color: #ffffff;
    transform: translateY(-1px);
    box-shadow: 0 8px 18px rgba(176, 0, 0, 0.18);
}

/* Accesibilidad al navegar con teclado */
.gi-evento__editar:focus-visible,
.gi-evento__borrar:focus-visible {
    outline: 3px solid rgba(176, 0, 0, 0.25);
    outline-offset: 3px;
}

.gi-evento__crear {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 20px;
    min-height: 48px;
    padding: 0 22px;
    border: 1px solid #b00000;
    border-radius: 999px;
    background-color: #b00000;
    color: #ffffff;
    font-weight: 700;
    text-decoration: none;
    transition:
        background-color 0.2s ease,
        color 0.2s ease,
        transform 0.2s ease;
}

.gi-evento__crear:hover {
    background-color: #ffffff;
    color: #b00000;
    transform: translateY(-1px);
}

.gi-trabajo__crear {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 18px;
    min-height: 48px;
    padding: 0 22px;
    border: 1px solid #b00000;
    border-radius: 999px;
    background: #b00000;
    color: #ffffff;
    font-weight: 700;
    text-decoration: none;
    transition:
        background-color 0.2s ease,
        color 0.2s ease,
        transform 0.2s ease;
}

.gi-trabajo__crear:hover {
    background: #ffffff;
    color: #b00000;
    transform: translateY(-1px);
}

.gi-trabajo__acciones {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 20px;
}

.gi-trabajo__form-borrar {
    display: inline-flex;
    margin: 0;
    padding: 0;
}

.gi-trabajo__editar,
.gi-trabajo__borrar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 0 18px;
    border-radius: 999px;
    font-family: inherit;
    font-size: 15px;
    font-weight: 700;
    line-height: 1;
    text-decoration: none;
    cursor: pointer;
    box-sizing: border-box;
    transition:
        background-color 0.2s ease,
        color 0.2s ease,
        border-color 0.2s ease,
        transform 0.2s ease;
}

.gi-trabajo__editar {
    border: 1px solid #d6dce5;
    background: #ffffff;
    color: #172033;
}

.gi-trabajo__editar:hover {
    border-color: #172033;
    background: #172033;
    color: #ffffff;
    transform: translateY(-1px);
}

.gi-trabajo__borrar {
    appearance: none;
    border: 1px solid #b00000;
    background: #ffffff;
    color: #b00000;
}

.gi-trabajo__borrar:hover {
    background: #b00000;
    color: #ffffff;
    transform: translateY(-1px);
}

.gi-trabajo__crear:focus-visible,
.gi-trabajo__editar:focus-visible,
.gi-trabajo__borrar:focus-visible {
    outline: 3px solid rgba(176, 0, 0, 0.25);
    outline-offset: 3px;
}

/* =========================================================
   GESTIÓN PÚBLICA DE LÍNEAS DE INVESTIGACIÓN
   ========================================================= */

/* Botón principal para crear una línea */
.gi-linea__crear {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    margin-top: 18px;
    padding: 0 22px;

    border: 1px solid #b00000;
    border-radius: 999px;

    background-color: #b00000;
    color: #ffffff;

    font-family: inherit;
    font-size: 15px;
    font-weight: 700;
    line-height: 1;
    text-decoration: none;

    cursor: pointer;

    transition:
        background-color 0.2s ease,
        color 0.2s ease,
        border-color 0.2s ease,
        transform 0.2s ease,
        box-shadow 0.2s ease;
}

.gi-linea__crear:hover {
    border-color: #b00000;
    background-color: #ffffff;
    color: #b00000;
    text-decoration: none;

    transform: translateY(-1px);
    box-shadow: 0 8px 18px rgba(176, 0, 0, 0.15);
}


/* Contenedor de los botones de cada línea */
.gi-linea__acciones {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;

    margin-top: 20px;
}


/* Evita márgenes añadidos al formulario de borrado */
.gi-linea__form-borrar {
    display: inline-flex;
    margin: 0;
    padding: 0;
}


/* Estilo común de Editar y Borrar */
.gi-linea__editar,
.gi-linea__borrar {
    display: inline-flex;
    align-items: center;
    justify-content: center;

    min-height: 46px;
    padding: 0 18px;

    border-radius: 999px;

    font-family: inherit;
    font-size: 15px;
    font-weight: 700;
    line-height: 1;
    text-decoration: none;

    box-sizing: border-box;
    cursor: pointer;

    transition:
        background-color 0.2s ease,
        color 0.2s ease,
        border-color 0.2s ease,
        transform 0.2s ease,
        box-shadow 0.2s ease;
}


/* Botón Editar */
.gi-linea__editar {
    border: 1px solid #d6dce5;
    background-color: #ffffff;
    color: #172033;
}

.gi-linea__editar:hover {
    border-color: #172033;
    background-color: #172033;
    color: #ffffff;
    text-decoration: none;

    transform: translateY(-1px);
    box-shadow: 0 8px 18px rgba(23, 32, 51, 0.14);
}


/* Botón Borrar */
.gi-linea__borrar {
    appearance: none;

    border: 1px solid #b00000;
    background-color: #ffffff;
    color: #b00000;
}

.gi-linea__borrar:hover {
    border-color: #b00000;
    background-color: #b00000;
    color: #ffffff;

    transform: translateY(-1px);
    box-shadow: 0 8px 18px rgba(176, 0, 0, 0.16);
}


/* Accesibilidad al navegar con teclado */
.gi-linea__crear:focus-visible,
.gi-linea__editar:focus-visible,
.gi-linea__borrar:focus-visible {
    outline: 3px solid rgba(176, 0, 0, 0.25);
    outline-offset: 3px;
}


/* =========================================================
   FORMULARIOS PÚBLICOS DE CREACIÓN Y EDICIÓN
   ========================================================= */

/* Opciones de proyectos asociados */
.gi-form-linea fieldset {
    margin: 0;
    padding: 18px;

    border: 1px solid #dfe3e8;
    border-radius: 14px;

    background-color: #f8f9fb;
}

.gi-form-linea legend {
    padding: 0 8px;

    color: #172033;

    font-size: 15px;
    font-weight: 700;
}


/* Cada proyecto seleccionable */
.gi-form-linea__opcion {
    display: flex;
    align-items: center;
    gap: 10px;

    margin-bottom: 10px;
    padding: 12px 14px;

    border: 1px solid #e0e4ea;
    border-radius: 10px;

    background-color: #ffffff;
    color: #172033;

    cursor: pointer;

    transition:
        border-color 0.2s ease,
        background-color 0.2s ease,
        transform 0.2s ease;
}

.gi-form-linea__opcion:last-child {
    margin-bottom: 0;
}

.gi-form-linea__opcion:hover {
    border-color: #b00000;
    background-color: #fff8f8;
    transform: translateY(-1px);
}


/* Checkbox de los proyectos */
.gi-form-linea__opcion input[type="checkbox"] {
    width: 18px;
    height: 18px;
    margin: 0;

    accent-color: #b00000;
    cursor: pointer;
}


/* Cabecera específica de línea */
.gi-editar-linea .gi-editar-publicacion__cabecera {
    background:
        linear-gradient(
            135deg,
            #ffffff 0%,
            #ffffff 65%,
            #fff0f0 100%
        );
}


/* Mensajes dentro del formulario */
.gi-editar-linea .gi-mensaje {
    margin: 20px 0;
}


/* =========================================================
   ADAPTACIÓN PARA MÓVILES
   ========================================================= */

@media (max-width: 700px) {

    .gi-linea__acciones {
        align-items: stretch;
        flex-direction: column;
    }

    .gi-linea__form-borrar {
        width: 100%;
    }

    .gi-linea__editar,
    .gi-linea__borrar {
        width: 100%;
    }

    .gi-linea__crear {
        width: 100%;
    }

    .gi-form-linea fieldset {
        padding: 14px;
    }
}

/* =========================================================
   GESTIÓN PÚBLICA DE PROYECTOS DE INVESTIGACIÓN
   ========================================================= */

/* Botón principal Crear proyecto */
.gi-proyecto__crear {
    display: inline-flex;
    align-items: center;
    justify-content: center;

    min-height: 48px;
    margin-top: 18px;
    padding: 0 22px;

    border: 1px solid #b00000;
    border-radius: 999px;

    background-color: #b00000;
    color: #ffffff;

    font-family: inherit;
    font-size: 15px;
    font-weight: 700;
    line-height: 1;
    text-decoration: none;

    cursor: pointer;

    transition:
        background-color 0.2s ease,
        color 0.2s ease,
        border-color 0.2s ease,
        transform 0.2s ease,
        box-shadow 0.2s ease;
}

.gi-proyecto__crear:hover {
    border-color: #b00000;
    background-color: #ffffff;
    color: #b00000;
    text-decoration: none;

    transform: translateY(-1px);
    box-shadow: 0 8px 18px rgba(176, 0, 0, 0.15);
}


/* Contenedor de Editar y Borrar */
.gi-proyecto__acciones {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;

    margin-top: 20px;
}


/* Formulario de borrado */
.gi-proyecto__form-borrar {
    display: inline-flex;
    margin: 0;
    padding: 0;
}


/* Estilo común de los botones */
.gi-proyecto__editar,
.gi-proyecto__borrar {
    display: inline-flex;
    align-items: center;
    justify-content: center;

    min-height: 46px;
    padding: 0 18px;

    border-radius: 999px;

    font-family: inherit;
    font-size: 15px;
    font-weight: 700;
    line-height: 1;
    text-decoration: none;

    box-sizing: border-box;
    cursor: pointer;

    transition:
        background-color 0.2s ease,
        color 0.2s ease,
        border-color 0.2s ease,
        transform 0.2s ease,
        box-shadow 0.2s ease;
}


/* Botón Editar proyecto */
.gi-proyecto__editar {
    border: 1px solid #d6dce5;
    background-color: #ffffff;
    color: #172033;
}

.gi-proyecto__editar:hover {
    border-color: #172033;
    background-color: #172033;
    color: #ffffff;
    text-decoration: none;

    transform: translateY(-1px);
    box-shadow: 0 8px 18px rgba(23, 32, 51, 0.14);
}


/* Botón Borrar proyecto */
.gi-proyecto__borrar {
    appearance: none;

    border: 1px solid #b00000;
    background-color: #ffffff;
    color: #b00000;
}

.gi-proyecto__borrar:hover {
    border-color: #b00000;
    background-color: #b00000;
    color: #ffffff;

    transform: translateY(-1px);
    box-shadow: 0 8px 18px rgba(176, 0, 0, 0.16);
}


/* Accesibilidad con teclado */
.gi-proyecto__crear:focus-visible,
.gi-proyecto__editar:focus-visible,
.gi-proyecto__borrar:focus-visible {
    outline: 3px solid rgba(176, 0, 0, 0.25);
    outline-offset: 3px;
}


/* =========================================================
   FORMULARIOS PÚBLICOS DE PROYECTOS
   ========================================================= */

/* Cabecera de creación y edición */
.gi-editar-proyecto .gi-editar-publicacion__cabecera {
    background:
        linear-gradient(
            135deg,
            #ffffff 0%,
            #ffffff 65%,
            #fff0f0 100%
        );
}


/* Selección de líneas asociadas */
.gi-form-proyecto fieldset {
    margin: 0;
    padding: 18px;

    border: 1px solid #dfe3e8;
    border-radius: 14px;

    background-color: #f8f9fb;
}

.gi-form-proyecto legend {
    padding: 0 8px;

    color: #172033;

    font-size: 15px;
    font-weight: 700;
}


/* Cada línea seleccionable */
.gi-form-proyecto__opcion {
    display: flex;
    align-items: center;
    gap: 10px;

    margin-bottom: 10px;
    padding: 12px 14px;

    border: 1px solid #e0e4ea;
    border-radius: 10px;

    background-color: #ffffff;
    color: #172033;

    cursor: pointer;

    transition:
        border-color 0.2s ease,
        background-color 0.2s ease,
        transform 0.2s ease;
}

.gi-form-proyecto__opcion:last-child {
    margin-bottom: 0;
}

.gi-form-proyecto__opcion:hover {
    border-color: #b00000;
    background-color: #fff8f8;
    transform: translateY(-1px);
}


/* Checkbox de líneas */
.gi-form-proyecto__opcion input[type="checkbox"] {
    width: 18px;
    height: 18px;
    margin: 0;

    accent-color: #b00000;
    cursor: pointer;
}


/* Select del tipo de proyecto */
.gi-form-proyecto select {
    width: 100%;
    min-height: 48px;
    padding: 10px 12px;

    border: 1px solid #d6dce5;
    border-radius: 10px;

    background-color: #ffffff;
    color: #172033;

    font: inherit;
}


/* Campos al recibir el foco */
.gi-form-proyecto input:focus,
.gi-form-proyecto select:focus,
.gi-form-proyecto textarea:focus {
    border-color: #b00000;
    outline: none;

    box-shadow: 0 0 0 3px rgba(176, 0, 0, 0.12);
}


/* Mensajes de error dentro de la edición */
.gi-editar-proyecto .gi-mensaje {
    margin: 20px 0;
}


/* =========================================================
   ADAPTACIÓN PARA MÓVILES
   ========================================================= */

@media (max-width: 700px) {

    .gi-proyecto__acciones {
        align-items: stretch;
        flex-direction: column;
    }

    .gi-proyecto__form-borrar {
        width: 100%;
    }

    .gi-proyecto__crear,
    .gi-proyecto__editar,
    .gi-proyecto__borrar {
        width: 100%;
    }

    .gi-form-proyecto fieldset {
        padding: 14px;
    }
}

/* Acciones públicas de asignaturas */

.gi-subject-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;

    margin-top: 20px;
    padding-top: 18px;

    border-top: 1px solid #e2e5e9;
}

.gi-subject-actions .gi-btn {
    min-height: 46px;
    padding: 11px 18px;
    box-sizing: border-box;
}


/* Formulario público de asignaturas */

.gi-form-asignatura select {
    box-sizing: border-box;

    width: 100%;
    min-height: 50px;
    padding: 13px 15px;

    border: 1px solid #d8dde3;
    border-radius: 14px;

    background: #f7f8fa;
    color: #18222d;

    font: inherit;
}

.gi-form-asignatura select:focus {
    outline: none;

    border-color: #b50000;
    background: #ffffff;

    box-shadow: 0 0 0 4px rgba(181, 0, 0, 0.1);
}

.gi-editar-asignatura .gi-editar-publicacion__cabecera {
    background:
        linear-gradient(
            135deg,
            #ffffff 0%,
            #ffffff 65%,
            #fff0f0 100%
        );
}

@media (max-width: 650px) {
    .gi-subject-actions {
        align-items: stretch;
        flex-direction: column;
    }

    .gi-subject-actions .gi-btn {
        width: 100%;
    }
}

/* =========================================================
   PORTADA MIDA CENTRADA Y A ANCHO COMPLETO
   ========================================================= */

/*
 * La portada sale de la columna estrecha del tema,
 * pero permanece centrada respecto a la ventana.
 */
.gi-public-page.gi-site-modern {
    position: relative;
    left: auto;
    transform: none;

    width: 100vw;
    max-width: 100vw;

    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);

    padding: 24px;
    box-sizing: border-box;
}

/*
 * Centramos todos los bloques interiores.
 */
.gi-public-page.gi-site-modern .gi-topbar-public,
.gi-public-page.gi-site-modern .gi-inner-header,
.gi-public-page.gi-site-modern .gi-inner-main {
    width: 100%;
    max-width: 1320px;

    margin-left: auto;
    margin-right: auto;

    box-sizing: border-box;
}

/*
 * Anulamos el desplazamiento antiguo de la cabecera.
 */
.gi-public-page.gi-site-modern .gi-inner-header {
    position: sticky;
    top: 16px;
    left: auto;
    transform: none;

    margin-top: 0;
    margin-bottom: 34px;
}

/* Barra superior */
.gi-public-page.gi-site-modern .gi-topbar-public {
    margin-top: 0;
    margin-bottom: 30px;
}

/* Cuatro tarjetas en escritorio */
.gi-public-page.gi-site-modern .gi-dashboard-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;

    width: 100%;
    margin-bottom: 32px;
}

/* Bloque principal */
.gi-public-page.gi-site-modern .gi-welcome-section {
    grid-template-columns:
        minmax(0, 1.5fr)
        minmax(260px, 0.5fr);
}

/* Tres líneas en una fila */
.gi-public-page.gi-site-modern .gi-lineas-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

/* Tablet */
@media (max-width: 1050px) {
    .gi-public-page.gi-site-modern {
        padding: 18px;
    }

    .gi-public-page.gi-site-modern .gi-dashboard-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .gi-public-page.gi-site-modern .gi-welcome-section {
        grid-template-columns: 1fr;
    }

    .gi-public-page.gi-site-modern .gi-lineas-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* Móvil */
@media (max-width: 650px) {
    .gi-public-page.gi-site-modern {
        padding: 12px;
    }

    .gi-public-page.gi-site-modern .gi-dashboard-grid,
    .gi-public-page.gi-site-modern .gi-lineas-grid {
        grid-template-columns: 1fr;
    }
}

/* =========================================================
   MIEMBROS EN LA PORTADA
   ========================================================= */

.gi-home-members {
    margin: 10px 0 28px;
    padding: 30px 0;

    border-top: 1px solid var(--gi-border);
    border-bottom: 1px solid var(--gi-border);
}

.gi-home-members__header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 24px;

    margin-bottom: 22px;
}

.gi-home-members__header .gi-kicker {
    margin-bottom: 8px;
}

.gi-home-members__header h2 {
    margin: 0;

    color: var(--gi-dark);
    font-size: 30px;
    line-height: 1.2;
}

.gi-home-members__link {
    flex-shrink: 0;

    color: var(--gi-red);
    font-size: 15px;
    font-weight: 800;
    text-decoration: none;
}

.gi-home-members__link:hover {
    text-decoration: underline;
}

.gi-home-members__list {
    display: flex;
    flex-wrap: wrap;
    column-gap: 34px;
    row-gap: 12px;

    margin: 0;
    padding: 0;

    list-style: none;
}

.gi-home-members__list li {
    position: relative;

    padding-left: 16px;

    color: var(--gi-text);
    font-size: 17px;
    line-height: 1.5;
}

.gi-home-members__list li::before {
    content: "";

    position: absolute;
    top: 0.65em;
    left: 0;

    width: 6px;
    height: 6px;

    border-radius: 50%;
    background-color: var(--gi-red);
}

@media (max-width: 650px) {
    .gi-home-members__header {
        align-items: flex-start;
        flex-direction: column;
    }

    .gi-home-members__list {
        flex-direction: column;
        gap: 10px;
    }
}