/* File: assets/css/style.css */
/* Paleta de Colores Original (Predeterminada para toda la aplicación) */
:root {
    --color-primary: #530f59;          /* Morado oscuro principal */
    --color-primary-light: rgba(83, 15, 89, 0.2); /* Morado oscuro más claro para efectos focus/ring */
    
    --color-accent: #fcd232;           /* Amarillo - Acento principal */
    --color-accent-hover: #e4bd2d;     /* Amarillo más oscuro para hover */

    --color-secondary-1: #9a398d;      /* Morado medio */
    --color-secondary-1-light: rgba(154, 57, 141, 0.15); 
    
    --color-secondary-2: #d65496;      /* Morado rosáceo */
    --color-secondary-2-light: rgba(214, 84, 150, 0.1);

    --color-background-page: #dfbfef;  /* Lila claro - Fondo de página por defecto */
    --color-background-container: #ffffff; /* Blanco para contenedores/tarjetas */

    --color-text-dark: #000000;        /* Negro para texto principal sobre fondos claros */
    --color-text-light: #ffffff;       /* Blanco para texto principal sobre fondos oscuros */
    
    /* Colores de texto más específicos para mejor contraste y jerarquía */
    --color-text-on-primary-bg: var(--color-text-light); /* Texto sobre fondo primario (morado oscuro) */
    --color-text-on-accent-bg: var(--color-text-dark);   /* Texto sobre fondo de acento (amarillo) */
    --color-text-headings-on-light-bg: var(--color-primary); /* Títulos sobre fondo claro */
    --color-text-body-on-light-bg: #333333; /* Gris oscuro para cuerpo de texto sobre fondo claro */
    --color-text-muted-on-light-bg: #666666;   /* Gris medio para texto silenciado */

    --color-border-light: #e0e0e0;     /* Gris claro para bordes sutiles */
    --color-border-medium: #cccccc;    /* Gris medio para bordes de inputs */

    --font-main: 'Inter', sans-serif;
}

:root {
    --color-primary: #033d68;
    --color-primary-light: rgba(3, 61, 104, 0.18);
    --color-accent: #0976b2;
    --color-accent-hover: #066395;
    --color-secondary-1: #94c0d5;
    --color-secondary-1-light: rgba(148, 192, 213, 0.18);
    --color-secondary-2: #0976b2;
    --color-secondary-2-light: rgba(9, 118, 178, 0.1);
    --color-background-page: #f5f5ef;
    --color-text-on-primary-bg: var(--color-text-light);
    --color-text-on-accent-bg: var(--color-text-light);
    --color-text-body-on-light-bg: #1f2937;
    --color-text-muted-on-light-bg: #64748b;
    --color-border-light: #e2e8f0;
    --color-border-medium: #bfd3df;
}

body {
    font-family: var(--font-main);
    background-color: #f4f6f8;
    color: var(--color-text-body-on-light-bg);  
    margin: 0;
    padding: 0;
    line-height: 1.6;
}

.app-shell {
    background: #f4f6f8;
}

.app-main {
    background:
        linear-gradient(180deg, rgba(83, 15, 89, 0.07), rgba(244, 246, 248, 0) 260px),
        #f4f6f8;
}

.app-page {
    width: min(100%, 1180px);
    margin: 0 auto;
    padding: 1.5rem;
}

@media (min-width: 768px) {
    .app-page {
        padding: 2rem;
    }
}

.app-page-header {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.app-page-title {
    color: #1f2937;
    font-size: 1.875rem;
    line-height: 2.25rem;
    font-weight: 750;
    letter-spacing: 0;
}

.app-page-kicker {
    color: var(--color-primary);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.app-page-subtitle {
    color: #64748b;
    margin-top: 0.25rem;
    font-size: 0.95rem;
}

.app-card {
    background: #ffffff;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 0.5rem;
    box-shadow: 0 12px 30px -24px rgba(15, 23, 42, 0.45);
}

.app-card-pad {
    padding: 1rem;
}

@media (min-width: 640px) {
    .app-card-pad {
        padding: 1.25rem;
    }
}

.app-stat-grid {
    display: grid;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: 0.75rem;
}

@media (min-width: 640px) {
    .app-stat-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

.app-stat {
    background: #ffffff;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 0.5rem;
    padding: 1rem;
}

.app-stat-label {
    color: #64748b;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.app-stat-value {
    color: #111827;
    font-size: 1.75rem;
    line-height: 2rem;
    font-weight: 750;
    margin-top: 0.35rem;
}

.app-quick-grid {
    display: grid;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: 0.75rem;
}

@media (min-width: 640px) {
    .app-quick-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 1024px) {
    .app-quick-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

.app-quick-link {
    display: flex;
    min-height: 112px;
    flex-direction: column;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 1rem;
    color: #1f2937;
    text-decoration: none;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 0.5rem;
    background: #ffffff;
    box-shadow: 0 8px 22px -22px rgba(15, 23, 42, 0.65);
    transition: transform 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease;
}

.app-quick-link:hover {
    border-color: var(--color-primary-light);
    box-shadow: 0 14px 30px -24px rgba(15, 23, 42, 0.7);
    transform: translateY(-1px);
}

.app-quick-title {
    color: #111827;
    font-weight: 700;
}

.app-quick-meta {
    color: #64748b;
    font-size: 0.86rem;
    line-height: 1.35;
}

.announcement-carousel {
    overflow: hidden;
}

.announcement-carousel-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 1rem 0.75rem;
}

.announcement-carousel-controls {
    display: flex;
    gap: 0.4rem;
}

.announcement-carousel-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.2rem;
    height: 2.2rem;
    border: 1px solid rgba(15, 23, 42, 0.1);
    border-radius: 999px;
    background: #ffffff;
    color: var(--color-primary);
    font-size: 1.35rem;
    font-weight: 800;
    line-height: 1;
}

.announcement-carousel-btn:hover {
    background: var(--color-primary-light);
}

.announcement-carousel-viewport {
    overflow: hidden;
    width: 100%;
    padding: 0 1rem;
}

.announcement-carousel-track {
    display: flex;
    flex-wrap: nowrap;
    align-items: stretch;
    width: 100%;
    transition: transform 0.28s ease;
    touch-action: pan-y;
    will-change: transform;
}

.announcement-slide {
    flex: 0 0 100%;
    min-width: 100%;
    max-width: 100%;
    padding: 0 0.35rem 0.35rem;
}

@media (min-width: 768px) {
    .announcement-slide {
        flex-basis: 33.3333%;
        min-width: 33.3333%;
        max-width: 33.3333%;
    }
}

.announcement-slide {
    display: flex;
    min-height: 100%;
    flex-direction: column;
}

.announcement-slide-image {
    width: 100%;
    height: 11rem;
    object-fit: contain;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-bottom: 0;
    border-radius: 0.5rem 0.5rem 0 0;
    background: #ffffff;
}

.announcement-slide-body {
    flex: 1;
    padding: 0.9rem;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 0.5rem;
    background: #f8fbff;
}

.announcement-slide-image + .announcement-slide-body {
    border-radius: 0 0 0.5rem 0.5rem;
}

.announcement-slide-title {
    color: #0f172a;
    font-weight: 800;
    line-height: 1.25;
}

.announcement-slide-date {
    flex: 0 0 auto;
    border-radius: 999px;
    background: #e0f2fe;
    color: #075985;
    font-size: 0.72rem;
    font-weight: 800;
    padding: 0.18rem 0.5rem;
}

.announcement-slide-text {
    color: #475569;
    font-size: 0.88rem;
    line-height: 1.45;
    margin-top: 0.5rem;
}

.announcement-slide-video {
    position: relative;
    width: 100%;
    margin-top: 0.75rem;
    overflow: hidden;
    border-radius: 0.5rem;
    background: #000000;
    padding-bottom: 56.25%;
}

.announcement-carousel-dots {
    display: flex;
    justify-content: center;
    gap: 0.4rem;
    padding: 0.65rem 1rem 1rem;
}

.announcement-carousel-dot {
    width: 0.55rem;
    height: 0.55rem;
    border-radius: 999px;
    background: #cbd5e1;
}

.announcement-carousel-dot.is-active {
    width: 1.4rem;
    background: var(--color-primary);
}

.app-filter-bar {
    display: flex;
    flex-wrap: wrap;
    align-items: end;
    gap: 0.75rem;
    padding: 1rem;
    border-radius: 0.5rem;
    background: #f8fafc;
    border: 1px solid rgba(15, 23, 42, 0.06);
}

.app-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
}

.app-table thead th {
    color: #475569;
    background: #f8fafc;
    border-bottom: 1px solid rgba(15, 23, 42, 0.08);
    font-size: 0.75rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.app-table tbody tr:hover {
    background: #fbfdff;
}

.app-action-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.app-badge {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 0.2rem 0.55rem;
    font-size: 0.75rem;
    font-weight: 700;
}

.app-badge-success {
    color: #166534;
    background: #dcfce7;
}

.app-badge-danger {
    color: #991b1b;
    background: #fee2e2;
}

.offering-report-card {
    display: grid;
    gap: 1rem;
}

.offering-report-main {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 0.75rem;
    align-items: start;
}

.offering-report-amount {
    padding: 0.75rem;
    border-radius: 0.5rem;
    background: #f8fafc;
}

.offering-report-grid {
    display: grid;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: 0.75rem;
}

.offering-report-grid > div {
    min-width: 0;
}

.offering-report-grid span {
    display: block;
    color: #64748b;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.offering-report-grid strong {
    display: block;
    color: #111827;
    font-size: 0.88rem;
    line-height: 1.35;
    margin-top: 0.15rem;
}

.offering-report-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
    padding-top: 0.75rem;
    border-top: 1px solid rgba(15, 23, 42, 0.08);
}

.offering-inline-form {
    display: grid;
    grid-template-columns: minmax(12rem, 1fr) auto;
    gap: 0.5rem;
    align-items: center;
    flex: 1 1 20rem;
}

.offering-wompi-form {
    grid-template-columns: minmax(10rem, 0.85fr) minmax(14rem, 1fr) auto;
}

@media (min-width: 640px) {
    .offering-report-main {
        grid-template-columns: minmax(0, 1fr) auto;
    }

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

@media (min-width: 1024px) {
    .offering-report-grid {
        grid-template-columns: repeat(5, minmax(0, 1fr));
    }
}

@media (max-width: 767px) {
    .offering-inline-form,
    .offering-wompi-form {
        grid-template-columns: minmax(0, 1fr);
        flex-basis: 100%;
    }

.offering-report-actions .btn,
.offering-report-actions form {
    width: 100%;
}

.report-table-wrap {
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.report-table {
    width: 100%;
    border-collapse: collapse;
}

.report-table th {
    color: #334155;
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.report-table th,
.report-table td {
    padding: 0.75rem;
    vertical-align: top;
}

.report-table tbody tr {
    border-bottom: 1px solid rgba(15, 23, 42, 0.08);
}

@media (max-width: 760px) {
    .report-table-wrap {
        overflow-x: visible;
    }

    .report-table,
    .report-table thead,
    .report-table tbody,
    .report-table tr,
    .report-table th,
    .report-table td {
        display: block;
        width: 100%;
    }

    .report-table thead {
        display: none;
    }

    .report-table tbody tr {
        background: #ffffff;
        border: 1px solid rgba(15, 23, 42, 0.08);
        border-radius: 0.5rem;
        margin-bottom: 0.75rem;
        padding: 0.75rem;
    }

    .report-table td {
        border: 0;
        padding: 0.45rem 0;
    }

    .report-table td::before {
        content: attr(data-label);
        display: block;
        color: #64748b;
        font-size: 0.7rem;
        font-weight: 800;
        letter-spacing: 0.04em;
        text-transform: uppercase;
    }
}
}

.btn-sm {
    padding: 0.42rem 0.7rem;
    font-size: 0.78rem;
}

.sidebar {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0) 180px),
        var(--color-primary);
    box-shadow: 18px 0 40px -32px rgba(15, 23, 42, 0.95);
}

.sidebar-mobile-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.85rem 1rem 0.35rem;
}

.sidebar-close-btn {
    color: #ffffff;
    font-size: 1.75rem;
    line-height: 1;
}

.sidebar-brand {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

.sidebar-brand-mark {
    display: grid;
    flex: 0 0 auto;
    width: 2.45rem;
    height: 2.45rem;
    place-items: center;
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: 0.5rem;
    background: rgba(255, 255, 255, 0.12);
    color: #ffffff;
    font-size: 0.82rem;
    font-weight: 800;
}

.sidebar-brand-logo {
    flex: 0 0 auto;
    width: min(100%, 9.5rem);
    height: 3.25rem;
    object-fit: contain;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 0.5rem;
    background: rgba(255, 255, 255, 0.08);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
    opacity: 1;
    padding: 0.25rem;
}

.sidebar-brand-title {
    color: #ffffff;
    font-size: 0.98rem;
    font-weight: 800;
    line-height: 1.1;
}

.sidebar-brand-subtitle {
    color: rgba(255, 255, 255, 0.68);
    font-size: 0.78rem;
    margin-top: 0.15rem;
}

.sidebar-user-panel {
    margin: 0 0.75rem 0.75rem;
    padding: 0.75rem;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 0.5rem;
    background: rgba(255, 255, 255, 0.08);
}

.sidebar-user-name {
    overflow: hidden;
    color: #ffffff;
    font-size: 0.88rem;
    font-weight: 700;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.sidebar-user-role {
    color: rgba(255, 255, 255, 0.68);
    font-size: 0.75rem;
    margin-top: 0.1rem;
}

.sidebar-scroll {
    overflow-y: auto;
    padding: 0 0.65rem 0.75rem;
}

.sidebar-scroll::-webkit-scrollbar {
    width: 8px;
}

.sidebar-scroll::-webkit-scrollbar-thumb {
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.18);
}

.sidebar-nav {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}

.sidebar-section-heading {
    color: rgba(255, 255, 255, 0.52);
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    margin: 0.8rem 0.55rem 0.35rem;
    text-transform: uppercase;
}

.sidebar-nav-link {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    min-height: 38px;
    padding: 0.5rem 0.65rem;
    border-radius: 0.5rem;
    color: rgba(255, 255, 255, 0.78);
    font-size: 0.9rem;
    font-weight: 600;
    text-decoration: none;
    transition: background-color 0.15s ease, color 0.15s ease, transform 0.15s ease;
}

.sidebar-nav-link:hover {
    background: rgba(255, 255, 255, 0.1);
    color: #ffffff;
    transform: translateX(1px);
}

.sidebar-nav-dot {
    width: 0.42rem;
    height: 0.42rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.34);
    flex: 0 0 auto;
}

.sidebar-nav-link.is-active {
    background: rgba(255, 255, 255, 0.16);
    color: #ffffff;
    font-weight: 800;
    box-shadow: inset 3px 0 0 var(--color-accent);
}

.sidebar-nav-link.is-active .sidebar-nav-dot {
    background: var(--color-accent);
}

.sidebar-footer {
    padding: 0.75rem;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
}

.sidebar-logout {
    display: flex;
    align-items: center;
    min-height: 40px;
    padding: 0.5rem 0.75rem;
    border-radius: 0.5rem;
    color: rgba(255, 255, 255, 0.88);
    font-size: 0.9rem;
    font-weight: 800;
    text-decoration: none;
}

.sidebar-logout:hover {
    background: rgba(220, 38, 38, 0.88);
    color: #ffffff;
}

.dashboard-header-bar {
    position: sticky;
    top: 0;
    z-index: 10;
}

.language-switcher {
    display: inline-flex;
    align-items: center;
    gap: 0.2rem;
    padding: 0.18rem;
    border: 1px solid rgba(255, 255, 255, 0.24);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
}

.language-switcher-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2rem;
    min-height: 1.65rem;
    padding: 0 0.45rem;
    border-radius: 999px;
    color: rgba(255, 255, 255, 0.78);
    font-size: 0.72rem;
    font-weight: 800;
    text-decoration: none;
}

.language-switcher-link:hover,
.language-switcher-link.is-active {
    background: #ffffff;
    color: var(--color-primary);
}

.language-switcher-light {
    border-color: rgba(15, 23, 42, 0.12);
    background: rgba(255, 255, 255, 0.86);
    box-shadow: 0 10px 28px -24px rgba(15, 23, 42, 0.8);
}

.language-switcher-light .language-switcher-link {
    color: #475569;
}

.language-switcher-light .language-switcher-link:hover,
.language-switcher-light .language-switcher-link.is-active {
    background: var(--color-primary);
    color: #ffffff;
}

.header-logo {
    max-height: 40px;
    margin-right: 0.75rem;
    object-fit: contain;
}

@media (max-width: 480px) {
    .language-switcher-link {
        min-width: 1.75rem;
        padding: 0 0.35rem;
        font-size: 0.68rem;
    }
}

@media (max-width: 767px) {
    .app-responsive-table thead {
        display: none;
    }

    .app-responsive-table,
    .app-responsive-table tbody,
    .app-responsive-table tr,
    .app-responsive-table td {
        display: block;
        width: 100%;
    }

    .app-responsive-table tr {
        border: 1px solid rgba(15, 23, 42, 0.08);
        border-radius: 0.5rem;
        padding: 0.75rem;
        margin-bottom: 0.75rem;
        background: #ffffff;
    }

    .app-responsive-table td {
        border: 0;
        padding: 0.35rem 0;
    }

    .app-responsive-table td::before {
        content: attr(data-label);
        display: block;
        color: #64748b;
        font-size: 0.7rem;
        font-weight: 700;
        letter-spacing: 0.05em;
        text-transform: uppercase;
    }
}

/* Contenedores Principales */
.auth-container, 
.admin-container, 
.profile-card, 
.dashboard-container, 
.form-container {
    background-color: var(--color-background-container);
    border: 1px solid var(--color-primary-light); /* Borde sutil con el primario claro */
    border-radius: 0.5rem; 
    box-shadow: 0 4px 10px -3px rgba(0, 0, 0, 0.08), 0 2px 6px -1px rgba(0, 0, 0, 0.05);
}

/* Inputs, Selects, Textareas */
.form-input, .select-form, .textarea-form, 
.input-admin, .select-admin, .textarea-admin, .input-profile {
    width: 100%; 
    border-width: 1px;
    border-style: solid;
    border-color: var(--color-border-medium); 
    border-radius: 0.375rem; 
    padding: 0.65rem 0.85rem;
    transition: border-color 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
    color: var(--color-text-dark);
    background-color: var(--color-text-light); 
}
.form-input::placeholder, .input-admin::placeholder, 
.input-profile::placeholder, .textarea-form::placeholder, 
.textarea-admin::placeholder {
    color: var(--color-text-muted-on-light-bg);
}
.form-input:focus, .select-form:focus, .textarea-form:focus,
.input-admin:focus, .select-admin:focus, .textarea-admin:focus, 
.input-profile:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px var(--color-primary-light); 
    outline: none;
}
.radio-form, .checkbox-form {
    color: var(--color-primary); 
}
.radio-form:focus, .checkbox-form:focus {
    ring-color: var(--color-primary-light);
    ring-offset-color: var(--color-background-container); 
}


/* Botones */
.btn { 
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.65rem 1.25rem;
    border-radius: 0.375rem;
    font-weight: 500; 
    transition: background-color 0.2s ease-in-out, border-color 0.2s ease-in-out, color 0.2s ease-in-out;
    border: 1px solid transparent;
    cursor: pointer;
    text-decoration: none; 
}
.btn:focus {
    outline: none;
    box-shadow: 0 0 0 3px var(--color-primary-light);
}

.btn-primary {
    background-color: var(--color-primary);
    color: var(--color-text-on-primary-bg);
    border-color: var(--color-primary);
}
.btn-primary:hover {
    background-color: var(--color-secondary-1); 
    border-color: var(--color-secondary-1);
}

.btn-accent {
    background-color: var(--color-accent);
    color: var(--color-text-on-accent-bg); 
    border-color: var(--color-accent);
}
.btn-accent:hover {
    background-color: var(--color-accent-hover);
    border-color: var(--color-accent-hover);
}

.btn-secondary {
    background-color: transparent;
    color: var(--color-primary);
    border-color: var(--color-border-medium);
}
.btn-secondary:hover {
    background-color: var(--color-primary-light);
    border-color: var(--color-primary);
}

.btn-danger {
    background-color: var(--color-secondary-2); /* Morado rosáceo para peligro */
    color: var(--color-text-light);
    border-color: var(--color-secondary-2);
}
.btn-danger:hover {
    background-color: #c0488a; /* Un tono más oscuro de morado rosáceo */
    border-color: #c0488a;
}

.btn-manage-q {
    background-color: var(--color-secondary-1); 
    color: var(--color-text-light);
    border-color: var(--color-secondary-1);
    padding: 0.4rem 0.8rem; 
    font-size: 0.75rem;
}
.btn-manage-q:hover {
    background-color: #822f77; /* Morado medio más oscuro */
    border-color: #822f77;
}

/* Mapeo de clases antiguas/específicas a las nuevas clases de botón base */
.btn-admin-action, .btn-profile, .btn-submit, 
.btn-primary-login, .btn-primary-register, .btn-admin-primary {
    /* Heredan de .btn y .btn-primary */
}
.btn-download, .btn-edit, .btn-admin-secondary {
    /* Heredan de .btn y .btn-accent */
}
.btn-delete, .btn-admin-danger {
    /* Heredan de .btn y .btn-danger */
}


/* Enlaces */
.link-accent, .link-accent-login, .link-accent-register {
    color: var(--color-secondary-2); /* Morado rosáceo para enlaces */
    font-weight: 500;
    text-decoration: none;
}
.link-accent:hover, .link-accent-login:hover, .link-accent-register:hover {
    color: var(--color-primary); 
    text-decoration: underline;
}

/* Títulos */
.auth-title, .page-main-title {
    color: var(--color-text-headings-on-light-bg); 
    font-weight: 700; 
}
.section-title {
    color: var(--color-secondary-1); 
    font-weight: 600;
}
.section-header-text { 
    color: var(--color-text-headings-on-light-bg); 
    border-bottom: 2px solid var(--color-accent); 
    padding-bottom: 0.5rem; 
}

/* Textos */
.text-muted {
    color: var(--color-text-muted-on-light-bg);
}

/* Mensajes de Alerta */
.alert-message { padding: 0.75rem 1rem; margin-bottom: 1rem; border-radius: 0.375rem; font-size: 0.875rem; border-width: 1px;}
.alert-success { background-color: #eaf8f4; border-color: var(--color-secondary-1); color: #0f5132; } /* Tono verde pastel */
.alert-danger { background-color: #fce7ec; border-color: var(--color-secondary-2); color: #842029; } /* Tono rosado pastel */
.alert-info { background-color: #e7e9f8; border-color: var(--color-primary); color: #084298; } /* Tono lila/azul pastel */
.alert-warning { background-color: #fff9e6; border-color: var(--color-accent); color: #664d03; } /* Tono amarillo pastel */


/* Dashboards */
.dashboard-header-bar {
    background-color: var(--color-primary); 
    color: var(--color-text-on-primary-bg);
}
.nav-link, .nav-link-dashboard, .nav-link-profile, .nav-link-char {
    color: var(--color-accent); 
    text-decoration: none;
    font-weight: 500;
    margin-left: 0.75rem;
}
.nav-link:hover, .nav-link-dashboard:hover, .nav-link-profile:hover, .nav-link-char:hover {
    text-decoration: underline;
    color: var(--color-text-light); 
}

.dashboard-card {
    background-color: var(--color-background-container);
    border: 1px solid var(--color-border-light);
    transition: transform 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
}
.dashboard-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 6px 12px -3px rgba(0,0,0,0.1);
}
.dashboard-card h3 { color: var(--color-text-headings-on-light-bg); } 
.dashboard-card a.module-link { color: var(--color-secondary-1); font-weight: 500; } 
.dashboard-card a.module-link:hover { color: var(--color-primary); }


/* Fotos de Perfil */
.profile-pic-header {
    width: 32px; 
    height: 32px; 
    border-radius: 50%;
    object-fit: cover;
    margin-right: 0.5rem; 
    border: 2px solid var(--color-accent); 
}
.profile-pic-display { 
    width: 128px; 
    height: 128px; 
    border-radius: 50%; 
    object-fit: cover; 
    border: 4px solid var(--color-accent); 
}

/* Tablas */
th, td { padding: 0.75rem; text-align: left; border-bottom: 1px solid var(--color-border-light); font-size: 0.875rem; }
thead th { background-color: #f8fafc; font-weight: 600; color: var(--color-text-headings-on-light-bg); } 

/* Paginación */
.pagination a, .pagination span { 
    margin: 0 0.25rem; 
    padding: 0.35rem 0.65rem; 
    border: 1px solid var(--color-border-medium); 
    border-radius: 0.25rem; 
    color: var(--color-primary);
    font-size: 0.875rem;
}
.pagination a:hover { 
    background-color: var(--color-primary-light); 
    border-color: var(--color-primary);
}
.pagination .current-page { 
    background-color: var(--color-primary); 
    color: var(--color-text-on-primary-bg); 
    border-color: var(--color-primary); 
}

/* Formularios de Caracterización */
.char-grid-table th, .char-grid-table td { font-size: 0.875rem; border: 1px solid var(--color-border-medium); }
.char-grid-table thead th { background-color: #f8fafc; } 

/* Utilitarias */
.text-danger { color: var(--color-secondary-2); } /* Usar el morado rosáceo como color de "peligro" o alerta en texto */
.required-asterisk { color: var(--color-secondary-2); font-weight: bold; margin-left: 2px; }

/* Experiencia publica (login/registro/recuperacion/form-share) */
.public-auth-card {
    background-color: #ffffff;
    border: 1px solid var(--color-border-light);
    border-radius: 14px;
    box-shadow: 0 16px 36px -20px rgba(3, 61, 104, 0.45), 0 8px 16px -10px rgba(3, 61, 104, 0.24);
}
.public-auth-title {
    color: var(--color-text-headings-on-light-bg);
    font-weight: 700;
    letter-spacing: -0.01em;
}
.public-auth-subtitle {
    color: var(--color-text-muted-on-light-bg);
}
.public-auth-card .form-input {
    border-radius: 10px;
    border-color: var(--color-border-medium);
    padding: 0.72rem 0.9rem;
}
.public-auth-card .btn {
    min-height: 44px;
    border-radius: 10px;
    font-weight: 600;
    box-shadow: 0 5px 14px -10px rgba(3, 61, 104, 0.45);
}

