/**
 * Archivo: assets/css/style.css
 * Descripción: Estilos profesionales para Mariam Enfermera - Frontend, Dashboard, Login y Modales.
 * Versión: 3.0.1
 */

/* ==========================================================================
   VARIABLES GENERALES
========================================================================== */

:root {
    --mariam-magenta: #DA5F87;
    --mariam-magenta-hover: #c55378;
    --mariam-magenta-soft: #fff0f6;
    --mariam-magenta-soft-2: #fdf2f8;

    --mariam-blue: #0EA5E9;
    --mariam-blue-hover: #0284c7;
    --mariam-blue-soft: #e0f2fe;

    --mariam-green: #10b981;
    --mariam-green-dark: #047857;
    --mariam-green-soft: #dcfce7;
    --mariam-green-extra-soft: #ecfdf5;

    --mariam-red: #ef4444;
    --mariam-red-soft: #fee2e2;

    --mariam-orange: #f59e0b;
    --mariam-orange-soft: #fef3c7;

    --mariam-gray-50: #f8fafc;
    --mariam-gray-100: #f1f5f9;
    --mariam-gray-200: #e2e8f0;
    --mariam-gray-300: #cbd5e1;
    --mariam-gray-400: #94a3b8;
    --mariam-gray-500: #64748b;
    --mariam-gray-600: #475569;
    --mariam-gray-700: #334155;
    --mariam-gray-800: #1e293b;

    --mariam-white: #ffffff;
    --mariam-border: #e5e7eb;
    --mariam-border-soft: #e2e8f0;

    --mariam-radius-sm: 8px;
    --mariam-radius: 14px;
    --mariam-radius-lg: 20px;

    --mariam-shadow-sm: 0 2px 8px rgba(15, 23, 42, 0.05);
    --mariam-shadow: 0 8px 24px rgba(15, 23, 42, 0.08);
    --mariam-shadow-lg: 0 18px 45px rgba(15, 23, 42, 0.18);

    --mariam-font: "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

/* ==========================================================================
   RESET CONTROLADO DEL PLUGIN
========================================================================== */

.mariam-form-container,
#mariam-admin-workspace,
.mariam-login-container {
    font-family: var(--mariam-font) !important;
    color: var(--mariam-gray-700) !important;
    box-sizing: border-box !important;
}

.mariam-form-container *,
#mariam-admin-workspace *,
.mariam-login-container * {
    box-sizing: border-box !important;
}

.mariam-form-container button,
#mariam-admin-workspace button,
.mariam-login-container button,
.mariam-form-container input,
#mariam-admin-workspace input,
.mariam-login-container input,
.mariam-form-container select,
#mariam-admin-workspace select,
.mariam-form-container textarea,
#mariam-admin-workspace textarea {
    font-family: inherit !important;
}

/* ==========================================================================
   BLINDAJE CONTRA ESTILOS DEL TEMA WORDPRESS
========================================================================== */

.mariam-form-container button,
#mariam-admin-workspace button,
.mariam-login-container button,
.mariam-form-container a,
#mariam-admin-workspace a,
.mariam-login-container a {
    text-decoration: none !important;
    outline: none !important;
    box-shadow: none;
}

.mariam-form-container button:hover,
#mariam-admin-workspace button:hover,
.mariam-login-container button:hover,
.mariam-form-container button:focus,
#mariam-admin-workspace button:focus,
.mariam-login-container button:focus,
.mariam-form-container button:active,
#mariam-admin-workspace button:active,
.mariam-login-container button:active,
.mariam-form-container a:hover,
#mariam-admin-workspace a:hover,
.mariam-login-container a:hover,
.mariam-form-container a:focus,
#mariam-admin-workspace a:focus,
.mariam-login-container a:focus {
    outline: none !important;
    text-decoration: none !important;
}

.mariam-form-container button,
#mariam-admin-workspace button,
.mariam-login-container button {
    appearance: none !important;
    -webkit-appearance: none !important;
}

/* ==========================================================================
   FRONTEND - FORMULARIO PÚBLICO
========================================================================== */

.mariam-form-container {
    width: 100% !important;
    max-width: 980px !important;
    margin: 30px auto !important;
    padding: 0 16px !important;
}

.mariam-form-notice {
    background: var(--mariam-magenta-soft) !important;
    border: 1px solid #f8bbd0 !important;
    border-radius: var(--mariam-radius) !important;
    padding: 15px 18px !important;
    margin-bottom: 24px !important;
    color: var(--mariam-gray-700) !important;
    font-size: 14px !important;
    box-shadow: var(--mariam-shadow-sm) !important;
}

.mariam-form-notice strong,
.mariam-form-notice span {
    color: var(--mariam-magenta) !important;
}

.form-section {
    background: var(--mariam-white) !important;
    border: 1px solid var(--mariam-border) !important;
    border-radius: var(--mariam-radius-lg) !important;
    padding: 28px !important;
    margin-bottom: 24px !important;
    box-shadow: var(--mariam-shadow-sm) !important;
}

.form-section h3 {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    margin: 0 0 22px 0 !important;
    padding: 0 0 14px 0 !important;
    color: var(--mariam-magenta) !important;
    font-size: 22px !important;
    font-weight: 750 !important;
    line-height: 1.2 !important;
    border-bottom: 2px solid var(--mariam-magenta-soft) !important;
}

.form-section h3 span {
    color: var(--mariam-magenta) !important;
}

.form-icon {
    flex: 0 0 auto !important;
    color: currentColor !important;
}

.section-helper {
    margin: -8px 0 22px 0 !important;
    font-size: 14px !important;
    color: var(--mariam-gray-500) !important;
}

.form-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 20px !important;
}

.form-grid.single-column {
    grid-template-columns: 1fr !important;
}

.health-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 20px !important;
}

.form-group {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
}

.form-group.full-width {
    width: 100% !important;
}

.form-group label {
    color: var(--mariam-gray-700) !important;
    font-size: 14px !important;
    font-weight: 700 !important;
}

.form-group label span {
    color: var(--mariam-magenta) !important;
}

.form-group input,
.form-group select,
.form-group textarea {
    width: 100% !important;
    min-height: 48px !important;
    padding: 12px 14px !important;
    border: 1.5px solid var(--mariam-border-soft) !important;
    border-radius: 10px !important;
    background: var(--mariam-gray-50) !important;
    color: var(--mariam-gray-800) !important;
    font-size: 15px !important;
    line-height: 1.4 !important;
    outline: none !important;
    box-shadow: none !important;
    transition: border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease !important;
}

.form-group textarea {
    min-height: 120px !important;
    resize: vertical !important;
}

.form-group input::placeholder,
.form-group textarea::placeholder {
    color: var(--mariam-gray-400) !important;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
    border-color: var(--mariam-magenta) !important;
    background: var(--mariam-white) !important;
    box-shadow: 0 0 0 4px rgba(218, 95, 135, 0.12) !important;
}

.form-group input.has-error,
.form-group select.has-error,
.form-group textarea.has-error {
    border-color: var(--mariam-red) !important;
    background: #fffafa !important;
}

.field-error {
    display: block !important;
    min-height: 16px !important;
    color: var(--mariam-red) !important;
    font-size: 12px !important;
    font-weight: 600 !important;
}

/* Calendario */

.date-time-section {
    overflow: hidden !important;
}

.calendar-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(108px, 1fr)) !important;
    gap: 12px !important;
    margin: 6px 0 28px 0 !important;
}

.mariam-form-container .date-item {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    width: 100% !important;
    min-width: 0 !important;
    min-height: 98px !important;
    padding: 14px 8px !important;
    border: 1.5px solid var(--mariam-border-soft) !important;
    border-radius: 14px !important;
    background: var(--mariam-white) !important;
    color: var(--mariam-gray-700) !important;
    cursor: pointer !important;
    text-align: center !important;
    line-height: 1 !important;
    box-shadow: none !important;
    transform: none !important;
    transition: border-color 0.2s ease, background 0.2s ease, color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease !important;
}

.mariam-form-container .date-item:hover {
    border-color: var(--mariam-magenta) !important;
    background: var(--mariam-magenta-soft) !important;
    color: var(--mariam-gray-800) !important;
    box-shadow: 0 6px 14px rgba(218, 95, 135, 0.10) !important;
    transform: translateY(-1px) !important;
}

.mariam-form-container .date-item:focus,
.mariam-form-container .date-item:active {
    border-color: var(--mariam-magenta) !important;
    background: var(--mariam-white) !important;
    color: var(--mariam-gray-800) !important;
    box-shadow: 0 0 0 4px rgba(218, 95, 135, 0.12) !important;
    outline: none !important;
}

.mariam-form-container .date-item.selected,
.mariam-form-container .date-item.selected:hover,
.mariam-form-container .date-item.selected:focus,
.mariam-form-container .date-item.selected:active {
    border-color: var(--mariam-magenta) !important;
    background: var(--mariam-magenta) !important;
    color: var(--mariam-white) !important;
    box-shadow: 0 8px 18px rgba(218, 95, 135, 0.28) !important;
}

.mariam-form-container .date-item .day-name,
.mariam-form-container .date-item .day-number,
.mariam-form-container .date-item .day-month {
    display: block !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    text-align: center !important;
    line-height: 1.1 !important;
    white-space: nowrap !important;
}

.mariam-form-container .date-item .day-name {
    color: inherit !important;
    font-size: 11px !important;
    font-weight: 850 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.04em !important;
}

.mariam-form-container .date-item .day-number {
    color: inherit !important;
    font-size: 26px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
}

.mariam-form-container .date-item .day-month {
    color: inherit !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    text-transform: capitalize !important;
}

.horarios-header {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: 16px !important;
    margin-top: 14px !important;
    padding-top: 20px !important;
    border-top: 1px solid var(--mariam-border) !important;
}

.horarios-header h4 {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    margin: 0 0 6px 0 !important;
    color: var(--mariam-gray-800) !important;
    font-size: 18px !important;
    font-weight: 800 !important;
}

.horarios-header p {
    margin: 0 !important;
    color: var(--mariam-gray-500) !important;
    font-size: 14px !important;
}

.status-libres {
    flex: 0 0 auto !important;
    padding: 8px 12px !important;
    border-radius: 999px !important;
    background: var(--mariam-green-soft) !important;
    color: var(--mariam-green-dark) !important;
    font-size: 13px !important;
    font-weight: 800 !important;
}

.status-libres:empty {
    display: none !important;
}

.horarios-legend {
    display: flex !important;
    gap: 18px !important;
    flex-wrap: wrap !important;
    margin: 18px 0 8px 0 !important;
}

.legend-item {
    display: inline-flex !important;
    align-items: center !important;
    gap: 7px !important;
    color: var(--mariam-gray-600) !important;
    font-size: 13px !important;
    font-weight: 700 !important;
}

.legend-item .box {
    width: 14px !important;
    height: 14px !important;
    border-radius: 4px !important;
    display: inline-block !important;
}

.legend-item .box.available {
    background: var(--mariam-green) !important;
}

.legend-item .box.occupied {
    background: #ff8a80 !important;
}

#mariam-hours-container {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(135px, 1fr)) !important;
    gap: 14px !important;
    margin-top: 18px !important;
}

.mariam-form-container .time-slot-btn {
    min-height: 48px !important;
    padding: 12px 10px !important;
    border-radius: 12px !important;
    border: 1.5px solid var(--mariam-border) !important;
    background: var(--mariam-white) !important;
    color: var(--mariam-gray-700) !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    cursor: pointer !important;
    box-shadow: none !important;
    outline: none !important;
    transition: all 0.2s ease !important;
}

.mariam-form-container .time-slot-btn.available {
    border-color: var(--mariam-green) !important;
    background: var(--mariam-green-extra-soft) !important;
    color: var(--mariam-gray-700) !important;
}

.mariam-form-container .time-slot-btn.available:hover,
.mariam-form-container .time-slot-btn.available:focus {
    border-color: var(--mariam-green) !important;
    background: var(--mariam-green-soft) !important;
    color: var(--mariam-gray-800) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 6px 14px rgba(16, 185, 129, 0.14) !important;
}

.mariam-form-container .time-slot-btn.available.selected,
.mariam-form-container .time-slot-btn.available.selected:hover,
.mariam-form-container .time-slot-btn.available.selected:focus {
    border-color: var(--mariam-magenta) !important;
    background: var(--mariam-magenta) !important;
    color: var(--mariam-white) !important;
    box-shadow: 0 8px 18px rgba(218, 95, 135, 0.25) !important;
}

.mariam-form-container .time-slot-btn.occupied,
.mariam-form-container .time-slot-btn.occupied:hover,
.mariam-form-container .time-slot-btn.occupied:focus {
    border-color: #ff8a80 !important;
    background: #fff5f5 !important;
    color: #ef4444 !important;
    cursor: not-allowed !important;
    opacity: 0.9 !important;
    transform: none !important;
    box-shadow: none !important;
}

.placeholder-msg {
    grid-column: 1 / -1 !important;
    margin: 0 !important;
    padding: 18px !important;
    border-radius: 12px !important;
    background: var(--mariam-gray-50) !important;
    color: var(--mariam-gray-500) !important;
    text-align: center !important;
    font-size: 14px !important;
}

.placeholder-msg.error {
    background: var(--mariam-red-soft) !important;
    color: #991b1b !important;
}

.form-response-message {
    display: none;
    margin: 22px 0 !important;
    padding: 16px 18px !important;
    border-radius: 14px !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    text-align: center !important;
}

.form-response-message.success,
.form-response-message.error {
    display: block !important;
}

.form-response-message.success {
    background: var(--mariam-green-soft) !important;
    color: var(--mariam-green-dark) !important;
    border: 1px solid #86efac !important;
}

.form-response-message.error {
    background: var(--mariam-red-soft) !important;
    color: #991b1b !important;
    border: 1px solid #fecaca !important;
}

/* Resumen de reserva recibida */

.mariam-booking-summary {
    width: 100% !important;
    padding: 20px !important;
    border-radius: 18px !important;
    background: var(--mariam-white) !important;
    border: 1px solid #86efac !important;
    box-shadow: var(--mariam-shadow-sm) !important;
    text-align: left !important;
}

.booking-summary-head {
    display: flex !important;
    align-items: flex-start !important;
    gap: 14px !important;
    padding-bottom: 16px !important;
    margin-bottom: 16px !important;
    border-bottom: 1px solid var(--mariam-border) !important;
}

.booking-summary-icon {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex: 0 0 auto !important;
    width: 42px !important;
    height: 42px !important;
    border-radius: 999px !important;
    background: var(--mariam-green) !important;
    color: var(--mariam-white) !important;
    font-size: 20px !important;
    font-weight: 950 !important;
    line-height: 1 !important;
}

.booking-summary-head h4 {
    margin: 0 0 6px 0 !important;
    color: var(--mariam-gray-800) !important;
    font-size: 20px !important;
    font-weight: 950 !important;
    line-height: 1.2 !important;
}

.booking-summary-head p {
    margin: 0 !important;
    color: var(--mariam-gray-600) !important;
    font-size: 14px !important;
    line-height: 1.55 !important;
    font-weight: 650 !important;
}

.booking-summary-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
    margin-bottom: 14px !important;
}

.booking-summary-grid div {
    padding: 13px 14px !important;
    border-radius: 14px !important;
    background: var(--mariam-gray-50) !important;
    border: 1px solid var(--mariam-border-soft) !important;
}

.booking-summary-grid span,
.booking-summary-status span {
    display: block !important;
    margin-bottom: 4px !important;
    color: var(--mariam-gray-500) !important;
    font-size: 12px !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.03em !important;
}

.booking-summary-grid strong,
.booking-summary-status strong {
    display: block !important;
    color: var(--mariam-gray-800) !important;
    font-size: 14px !important;
    font-weight: 900 !important;
    line-height: 1.35 !important;
}

.booking-summary-status {
    padding: 14px 16px !important;
    border-radius: 14px !important;
    background: var(--mariam-orange-soft) !important;
    border: 1px solid #fde68a !important;
}

.booking-summary-status strong {
    color: #92400e !important;
}

.form-submit {
    text-align: center !important;
    margin: 28px 0 10px 0 !important;
}

#btn-confirmar-cita {
    width: 100% !important;
    max-width: 360px !important;
    min-height: 54px !important;
    border: none !important;
    border-radius: 999px !important;
    background: var(--mariam-blue) !important;
    color: var(--mariam-white) !important;
    font-size: 17px !important;
    font-weight: 850 !important;
    cursor: pointer !important;
    box-shadow: 0 10px 22px rgba(14, 165, 233, 0.28) !important;
    outline: none !important;
    transition: background 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease !important;
}

#btn-confirmar-cita:hover,
#btn-confirmar-cita:focus {
    background: var(--mariam-blue-hover) !important;
    color: var(--mariam-white) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 14px 26px rgba(14, 165, 233, 0.32) !important;
}

#btn-confirmar-cita:disabled {
    opacity: 0.7 !important;
    cursor: wait !important;
    transform: none !important;
}

/* ==========================================================================
   LOGIN
========================================================================== */

.mariam-login-container {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    min-height: 520px !important;
    padding: 45px 16px !important;
    background: linear-gradient(180deg, #fff7fb 0%, #ffffff 100%) !important;
}

.mariam-login-box {
    width: 100% !important;
    max-width: 420px !important;
    padding: 34px 36px !important;
    border: 1px solid var(--mariam-border) !important;
    border-radius: 24px !important;
    background: var(--mariam-white) !important;
    text-align: center !important;
    box-shadow: var(--mariam-shadow) !important;
}

.mariam-login-logo {
    width: auto !important;
    max-width: 185px !important;
    max-height: 88px !important;
    object-fit: contain !important;
    margin: 0 auto 20px auto !important;
    display: block !important;
}

.mariam-login-box h2 {
    margin: 0 0 8px 0 !important;
    color: var(--mariam-magenta) !important;
    font-size: 26px !important;
    font-weight: 850 !important;
    line-height: 1.2 !important;
}

.login-subtitle {
    margin: 0 0 24px 0 !important;
    color: var(--mariam-gray-500) !important;
    font-size: 14px !important;
}

.mariam-error-notice {
    margin-bottom: 18px !important;
    padding: 12px 14px !important;
    border-radius: 12px !important;
    background: var(--mariam-red-soft) !important;
    color: #991b1b !important;
    border: 1px solid #fecaca !important;
    font-size: 14px !important;
    font-weight: 700 !important;
}

#loginform {
    text-align: left !important;
}

#loginform p {
    margin: 0 0 16px 0 !important;
}

#loginform label {
    display: block !important;
    margin-bottom: 7px !important;
    color: var(--mariam-gray-700) !important;
    font-size: 14px !important;
    font-weight: 750 !important;
}

#loginform input[type="text"],
#loginform input[type="password"] {
    width: 100% !important;
    min-height: 48px !important;
    padding: 12px 14px !important;
    border: 1.5px solid var(--mariam-border-soft) !important;
    border-radius: 12px !important;
    background: var(--mariam-gray-50) !important;
    color: var(--mariam-gray-800) !important;
    font-size: 15px !important;
    outline: none !important;
    box-shadow: none !important;
    transition: all 0.2s ease !important;
}

#loginform input[type="text"]:focus,
#loginform input[type="password"]:focus {
    border-color: var(--mariam-magenta) !important;
    background: var(--mariam-white) !important;
    box-shadow: 0 0 0 4px rgba(218, 95, 135, 0.12) !important;
}

.login-helpers {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    margin: 4px 0 20px 0 !important;
}

.login-remember label {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    color: var(--mariam-gray-600) !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
}

.login-remember input {
    accent-color: var(--mariam-magenta) !important;
}

.login-submit {
    margin-bottom: 0 !important;
}

#mariam_login_submit,
#loginform .button-primary {
    width: 100% !important;
    min-height: 50px !important;
    border: none !important;
    border-radius: 999px !important;
    background: var(--mariam-magenta) !important;
    color: var(--mariam-white) !important;
    font-size: 16px !important;
    font-weight: 850 !important;
    cursor: pointer !important;
    box-shadow: 0 10px 22px rgba(218, 95, 135, 0.28) !important;
    outline: none !important;
    transition: all 0.2s ease !important;
}

#mariam_login_submit:hover,
#loginform .button-primary:hover,
#mariam_login_submit:focus,
#loginform .button-primary:focus {
    background: var(--mariam-magenta-hover) !important;
    color: var(--mariam-white) !important;
    transform: translateY(-1px) !important;
}

/* ==========================================================================
   DASHBOARD GENERAL
========================================================================== */

#mariam-admin-workspace {
    width: 100% !important;
    max-width: 1240px !important;
    margin: 30px auto !important;
    padding: 24px !important;
    border-radius: 24px !important;
    background: #f8fafc !important;
    color: var(--mariam-gray-700) !important;
}

.mariam-admin-header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 18px !important;
    margin-bottom: 24px !important;
}

.mariam-admin-brand {
    display: flex !important;
    align-items: center !important;
    gap: 16px !important;
}

.mariam-admin-logo {
    width: 78px !important;
    height: 78px !important;
    object-fit: contain !important;
    border-radius: 18px !important;
    background: var(--mariam-white) !important;
    padding: 10px !important;
    box-shadow: var(--mariam-shadow-sm) !important;
}

.mariam-admin-brand h2 {
    margin: 0 0 4px 0 !important;
    color: var(--mariam-magenta) !important;
    font-size: 28px !important;
    font-weight: 900 !important;
    line-height: 1.1 !important;
}

.mariam-admin-brand p {
    margin: 0 !important;
    color: var(--mariam-gray-500) !important;
    font-size: 14px !important;
}

.mariam-admin-userbar {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
}

.mariam-user-chip {
    display: inline-flex !important;
    align-items: center !important;
    min-height: 38px !important;
    padding: 8px 14px !important;
    border-radius: 999px !important;
    background: var(--mariam-white) !important;
    color: var(--mariam-gray-600) !important;
    font-size: 13px !important;
    font-weight: 800 !important;
    box-shadow: var(--mariam-shadow-sm) !important;
}

/* Botones generales */

.mariam-btn,
.mariam-mini-btn,
.btn-footer,
.btn-quick,
.btn-config-time,
.modal-close-btn,
.filter-pill {
    appearance: none !important;
    -webkit-appearance: none !important;
    border: none !important;
    text-decoration: none !important;
    cursor: pointer !important;
    font-family: inherit !important;
    outline: none !important;
    box-shadow: none;
    transition: all 0.2s ease !important;
}

.mariam-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 42px !important;
    padding: 10px 18px !important;
    border-radius: 999px !important;
    font-size: 14px !important;
    font-weight: 850 !important;
}

.mariam-btn-primary {
    background: var(--mariam-magenta) !important;
    color: var(--mariam-white) !important;
    box-shadow: 0 8px 18px rgba(218, 95, 135, 0.22) !important;
}

.mariam-btn-primary:hover,
.mariam-btn-primary:focus {
    background: var(--mariam-magenta-hover) !important;
    color: var(--mariam-white) !important;
}

.mariam-btn-light {
    background: var(--mariam-white) !important;
    color: var(--mariam-magenta) !important;
    border: 1px solid #f7c3d3 !important;
}

.mariam-btn-light:hover,
.mariam-btn-light:focus {
    background: var(--mariam-magenta-soft) !important;
    color: var(--mariam-magenta) !important;
    border-color: #f7c3d3 !important;
}

.mariam-mini-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 34px !important;
    padding: 8px 12px !important;
    border-radius: 999px !important;
    font-size: 12px !important;
    font-weight: 850 !important;
    line-height: 1 !important;
}

.mariam-mini-btn.solid-blue {
    background: var(--mariam-blue) !important;
    color: var(--mariam-white) !important;
}

.mariam-mini-btn.solid-blue:hover,
.mariam-mini-btn.solid-blue:focus {
    background: var(--mariam-blue-hover) !important;
    color: var(--mariam-white) !important;
}

.mariam-mini-btn.gray {
    background: var(--mariam-gray-100) !important;
    color: var(--mariam-gray-700) !important;
}

.mariam-mini-btn.gray:hover,
.mariam-mini-btn.gray:focus {
    background: var(--mariam-gray-200) !important;
    color: var(--mariam-gray-800) !important;
}

.mariam-mini-btn.danger {
    background: var(--mariam-red-soft) !important;
    color: #991b1b !important;
}

.mariam-mini-btn.danger:hover,
.mariam-mini-btn.danger:focus {
    background: #fecaca !important;
    color: #7f1d1d !important;
}

.mariam-mini-btn.whatsapp,
.btn-footer.whatsapp {
    background: #22c55e !important;
    color: var(--mariam-white) !important;
}

.mariam-mini-btn.whatsapp:hover,
.btn-footer.whatsapp:hover,
.mariam-mini-btn.whatsapp:focus,
.btn-footer.whatsapp:focus {
    background: #16a34a !important;
    color: var(--mariam-white) !important;
}

.mariam-mini-btn.btn-download-ics {
    background: var(--mariam-magenta) !important;
    color: var(--mariam-white) !important;
}

.mariam-mini-btn.btn-download-ics:hover,
.mariam-mini-btn.btn-download-ics:focus {
    background: var(--mariam-magenta-hover) !important;
    color: var(--mariam-white) !important;
}

button:disabled,
.mariam-btn:disabled,
.mariam-mini-btn:disabled,
.btn-footer:disabled {
    opacity: 0.65 !important;
    cursor: wait !important;
}

/* Tabs */

.mariam-dash-tab-switch {
    display: flex !important;
    gap: 6px !important;
    padding: 6px !important;
    margin-bottom: 24px !important;
    border: 1px solid var(--mariam-border) !important;
    border-radius: 18px !important;
    background: var(--mariam-white) !important;
    box-shadow: var(--mariam-shadow-sm) !important;
}

#mariam-admin-workspace .mariam-dash-tab-btn {
    flex: 1 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 9px !important;
    min-height: 50px !important;
    padding: 12px 16px !important;
    border: 1px solid transparent !important;
    border-radius: 14px !important;
    background: transparent !important;
    color: var(--mariam-gray-600) !important;
    font-size: 15px !important;
    font-weight: 850 !important;
    box-shadow: none !important;
    outline: none !important;
}

#mariam-admin-workspace .mariam-dash-tab-btn:hover {
    background: var(--mariam-magenta-soft) !important;
    color: var(--mariam-magenta) !important;
    border-color: #f7c3d3 !important;
    box-shadow: none !important;
}

#mariam-admin-workspace .mariam-dash-tab-btn:focus,
#mariam-admin-workspace .mariam-dash-tab-btn:active {
    background: var(--mariam-white) !important;
    color: var(--mariam-gray-700) !important;
    border-color: #f7c3d3 !important;
    box-shadow: 0 0 0 4px rgba(218, 95, 135, 0.10) !important;
    outline: none !important;
}

#mariam-admin-workspace .mariam-dash-tab-btn.active,
#mariam-admin-workspace .mariam-dash-tab-btn.active:hover,
#mariam-admin-workspace .mariam-dash-tab-btn.active:focus,
#mariam-admin-workspace .mariam-dash-tab-btn.active:active {
    background: var(--mariam-magenta) !important;
    color: var(--mariam-white) !important;
    border-color: var(--mariam-magenta) !important;
    box-shadow: 0 10px 22px rgba(218, 95, 135, 0.25) !important;
}

.tab-icon {
    font-size: 16px !important;
}

.mariam-dash-view {
    display: none !important;
    animation: mariamFadeIn 0.25s ease !important;
}

.mariam-dash-view.active {
    display: block !important;
}

@keyframes mariamFadeIn {
    from {
        opacity: 0;
        transform: translateY(4px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.mariam-dashboard-notice {
    margin-bottom: 18px !important;
    padding: 14px 16px !important;
    border-radius: 14px !important;
    font-size: 14px !important;
    font-weight: 800 !important;
}

.mariam-dashboard-notice.success {
    background: var(--mariam-green-soft) !important;
    color: var(--mariam-green-dark) !important;
    border: 1px solid #86efac !important;
}

.mariam-dashboard-notice.error {
    background: var(--mariam-red-soft) !important;
    color: #991b1b !important;
    border: 1px solid #fecaca !important;
}

.mariam-dashboard-notice.warning {
    background: var(--mariam-orange-soft) !important;
    color: #92400e !important;
    border: 1px solid #fde68a !important;
}

/* Cards panel */

.mariam-panel-card {
    background: var(--mariam-white) !important;
    border: 1px solid var(--mariam-border) !important;
    border-radius: 22px !important;
    padding: 24px !important;
    margin-bottom: 24px !important;
    box-shadow: var(--mariam-shadow-sm) !important;
}

.section-heading-row {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: 18px !important;
    margin-bottom: 18px !important;
}

.section-title {
    margin: 0 0 5px 0 !important;
    color: var(--mariam-magenta) !important;
    font-size: 20px !important;
    font-weight: 900 !important;
}

.section-subtitle {
    margin: 0 !important;
    color: var(--mariam-gray-500) !important;
    font-size: 14px !important;
}

/* KPIs */

.mariam-kpi-grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 16px !important;
    margin-bottom: 24px !important;
}

.mariam-kpi-card {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    min-height: 112px !important;
    padding: 20px !important;
    border-radius: 20px !important;
    background: var(--mariam-white) !important;
    border: 1px solid var(--mariam-border) !important;
    border-left: 6px solid var(--mariam-gray-300) !important;
    box-shadow: var(--mariam-shadow-sm) !important;
}

.kpi-label {
    display: block !important;
    color: var(--mariam-gray-500) !important;
    font-size: 13px !important;
    font-weight: 850 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.03em !important;
}

.kpi-number {
    display: block !important;
    margin-top: 5px !important;
    color: var(--mariam-gray-800) !important;
    font-size: 34px !important;
    font-weight: 950 !important;
    line-height: 1 !important;
}

.kpi-icon {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 44px !important;
    height: 44px !important;
    border-radius: 14px !important;
    background: var(--mariam-gray-50) !important;
    color: var(--mariam-gray-500) !important;
    font-size: 20px !important;
    font-weight: 900 !important;
}

.mariam-kpi-card.status-pending {
    border-left-color: var(--mariam-orange) !important;
}

.mariam-kpi-card.status-approved {
    border-left-color: var(--mariam-green) !important;
}

.mariam-kpi-card.status-rejected {
    border-left-color: var(--mariam-red) !important;
}

.mariam-kpi-card.status-completed {
    border-left-color: var(--mariam-blue) !important;
}

/* Filtros */

.mariam-search-row {
    width: 100% !important;
}

.mariam-search-row input,
.mariam-inline-form input,
#mariam-admin-workspace .form-group input,
#mariam-admin-workspace .form-group textarea {
    width: 100% !important;
    min-height: 46px !important;
    padding: 12px 14px !important;
    border: 1.5px solid var(--mariam-border-soft) !important;
    border-radius: 12px !important;
    background: var(--mariam-gray-50) !important;
    color: var(--mariam-gray-800) !important;
    font-size: 14px !important;
    outline: none !important;
    box-shadow: none !important;
    transition: all 0.2s ease !important;
}

.mariam-search-row input:focus,
.mariam-inline-form input:focus,
#mariam-admin-workspace .form-group input:focus,
#mariam-admin-workspace .form-group textarea:focus {
    border-color: var(--mariam-magenta) !important;
    background: var(--mariam-white) !important;
    box-shadow: 0 0 0 4px rgba(218, 95, 135, 0.1) !important;
}

.mariam-filter-pills {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    margin-top: 16px !important;
}

#mariam-admin-workspace .filter-pill {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    min-height: 38px !important;
    padding: 8px 13px !important;
    border-radius: 999px !important;
    background: var(--mariam-gray-50) !important;
    color: var(--mariam-gray-600) !important;
    font-size: 13px !important;
    font-weight: 850 !important;
    border: 1px solid var(--mariam-border) !important;
    box-shadow: none !important;
    outline: none !important;
}

#mariam-admin-workspace .filter-pill span {
    min-width: 22px !important;
    height: 22px !important;
    padding: 2px 6px !important;
    border-radius: 999px !important;
    background: var(--mariam-white) !important;
    color: var(--mariam-gray-600) !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 11px !important;
}

#mariam-admin-workspace .filter-pill:hover,
#mariam-admin-workspace .filter-pill:focus {
    background: var(--mariam-magenta-soft) !important;
    color: var(--mariam-magenta) !important;
    border-color: #f7c3d3 !important;
    box-shadow: none !important;
    outline: none !important;
}

#mariam-admin-workspace .filter-pill:hover span,
#mariam-admin-workspace .filter-pill:focus span {
    color: var(--mariam-magenta) !important;
}

#mariam-admin-workspace .filter-pill.active,
#mariam-admin-workspace .filter-pill.active:hover,
#mariam-admin-workspace .filter-pill.active:focus {
    background: var(--mariam-magenta) !important;
    color: var(--mariam-white) !important;
    border-color: var(--mariam-magenta) !important;
    box-shadow: 0 8px 18px rgba(218, 95, 135, 0.20) !important;
}

#mariam-admin-workspace .filter-pill.active span,
#mariam-admin-workspace .filter-pill.active:hover span,
#mariam-admin-workspace .filter-pill.active:focus span {
    background: var(--mariam-white) !important;
    color: var(--mariam-magenta) !important;
}

/* ==========================================================================
   DISPONIBILIDAD DASHBOARD
========================================================================== */

.availability-list {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
}

.availability-row {
    display: grid !important;
    grid-template-columns: 160px 1fr auto !important;
    align-items: center !important;
    gap: 16px !important;
    padding: 16px !important;
    border: 1px solid var(--mariam-border) !important;
    border-radius: 16px !important;
    background: var(--mariam-white) !important;
}

.availability-row.enabled-row {
    background: linear-gradient(90deg, #f0fdf4 0%, #ffffff 42%) !important;
}

.availability-row.disabled-row {
    background: var(--mariam-gray-50) !important;
}

.day-info {
    display: flex !important;
    flex-direction: column !important;
    gap: 6px !important;
}

.day-info strong {
    color: var(--mariam-gray-800) !important;
    font-size: 15px !important;
    font-weight: 900 !important;
}

.status-badge {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: fit-content !important;
    min-height: 24px !important;
    padding: 4px 9px !important;
    border-radius: 999px !important;
    font-size: 11px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
}

.status-badge.green {
    background: var(--mariam-green-soft) !important;
    color: var(--mariam-green-dark) !important;
}

.status-badge.gray {
    background: var(--mariam-gray-200) !important;
    color: var(--mariam-gray-600) !important;
}

.time-tags {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
}

.time-tag {
    display: inline-flex !important;
    align-items: center !important;
    min-height: 28px !important;
    padding: 6px 10px !important;
    border-radius: 999px !important;
    background: var(--mariam-blue-soft) !important;
    color: #0369a1 !important;
    font-size: 12px !important;
    font-weight: 850 !important;
}

.empty-time-tags {
    color: var(--mariam-gray-400) !important;
    font-size: 13px !important;
    font-weight: 700 !important;
}

.btn-config-time {
    min-height: 38px !important;
    padding: 9px 14px !important;
    border-radius: 999px !important;
    background: var(--mariam-blue) !important;
    color: var(--mariam-white) !important;
    font-size: 12px !important;
    font-weight: 850 !important;
    white-space: nowrap !important;
}

.btn-config-time:hover,
.btn-config-time:focus {
    background: var(--mariam-blue-hover) !important;
    color: var(--mariam-white) !important;
}

/* ==========================================================================
   RESERVAS
========================================================================== */

.mariam-appointments-list {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 18px !important;
}

.appointment-card {
    background: var(--mariam-white) !important;
    border: 1px solid var(--mariam-border) !important;
    border-radius: 22px !important;
    padding: 22px !important;
    box-shadow: var(--mariam-shadow-sm) !important;
}

.appointment-card-top {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: 14px !important;
    margin-bottom: 16px !important;
}

.appointment-card h4 {
    margin: 0 0 8px 0 !important;
    color: var(--mariam-gray-800) !important;
    font-size: 20px !important;
    font-weight: 950 !important;
    line-height: 1.2 !important;
}

.appointment-primary-actions {
    display: flex !important;
    gap: 8px !important;
    flex-wrap: wrap !important;
    justify-content: flex-end !important;
}

.mariam-status-pill {
    display: inline-flex !important;
    align-items: center !important;
    min-height: 26px !important;
    padding: 5px 10px !important;
    border-radius: 999px !important;
    font-size: 11px !important;
    font-weight: 950 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.03em !important;
}

.mariam-status-pill.status-pendiente {
    background: var(--mariam-orange-soft) !important;
    color: #92400e !important;
}

.mariam-status-pill.status-aprobada {
    background: var(--mariam-green-soft) !important;
    color: var(--mariam-green-dark) !important;
}

.mariam-status-pill.status-rechazada {
    background: var(--mariam-red-soft) !important;
    color: #991b1b !important;
}

.mariam-status-pill.status-completada {
    background: var(--mariam-blue-soft) !important;
    color: #0369a1 !important;
}

.mariam-status-pill.status-cancelada {
    background: var(--mariam-gray-200) !important;
    color: var(--mariam-gray-600) !important;
}

.card-details-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
    margin-bottom: 14px !important;
}

.card-details-grid span {
    display: flex !important;
    align-items: center !important;
    min-height: 40px !important;
    padding: 10px 12px !important;
    border-radius: 12px !important;
    background: var(--mariam-gray-50) !important;
    color: var(--mariam-gray-600) !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    word-break: break-word !important;
}

.appointment-info-box,
.appointment-health-box {
    margin-top: 14px !important;
    padding: 14px !important;
    border-radius: 16px !important;
    background: var(--mariam-magenta-soft-2) !important;
    border: 1px solid #fbcfe8 !important;
}

.appointment-info-box strong,
.appointment-health-box strong {
    display: block !important;
    margin-bottom: 5px !important;
    color: var(--mariam-magenta) !important;
    font-size: 13px !important;
    font-weight: 900 !important;
}

.appointment-info-box p,
.appointment-health-box p {
    margin: 0 !important;
    color: var(--mariam-gray-700) !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
}

.appointment-health-box {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 14px !important;
    background: var(--mariam-gray-50) !important;
    border-color: var(--mariam-border) !important;
}

.card-actions {
    display: flex !important;
    justify-content: flex-end !important;
    gap: 8px !important;
    flex-wrap: wrap !important;
    margin-top: 16px !important;
    padding-top: 16px !important;
    border-top: 1px solid var(--mariam-border) !important;
}

/* ==========================================================================
   SERVICIOS
========================================================================== */

.mariam-inline-form {
    display: flex !important;
    gap: 12px !important;
    margin-bottom: 20px !important;
}

.mariam-inline-form input {
    flex: 1 !important;
}

.mariam-table-wrap {
    width: 100% !important;
    overflow-x: auto !important;
    border: 1px solid var(--mariam-border) !important;
    border-radius: 16px !important;
}

.mariam-table {
    width: 100% !important;
    min-width: 680px !important;
    border-collapse: collapse !important;
    background: var(--mariam-white) !important;
}

.mariam-table th,
.mariam-table td {
    padding: 14px 16px !important;
    border-bottom: 1px solid var(--mariam-border) !important;
    text-align: left !important;
    vertical-align: middle !important;
}

.mariam-table th {
    background: var(--mariam-gray-50) !important;
    color: var(--mariam-gray-500) !important;
    font-size: 12px !important;
    font-weight: 950 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.04em !important;
}

.mariam-table td {
    color: var(--mariam-gray-700) !important;
    font-size: 14px !important;
    font-weight: 700 !important;
}

.mariam-table tr:last-child td {
    border-bottom: none !important;
}

.service-name {
    color: var(--mariam-gray-800) !important;
    font-weight: 900 !important;
}

.text-right {
    text-align: right !important;
}

.service-actions {
    display: flex !important;
    justify-content: flex-end !important;
    gap: 8px !important;
}

.empty-row td {
    text-align: center !important;
    color: var(--mariam-gray-500) !important;
    font-weight: 700 !important;
}

/* ==========================================================================
   EXPEDIENTES
========================================================================== */

.mariam-expedientes-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 16px !important;
    margin-top: 18px !important;
}

.expediente-card {
    padding: 18px !important;
    border: 1px solid var(--mariam-border) !important;
    border-radius: 20px !important;
    background: var(--mariam-white) !important;
    box-shadow: var(--mariam-shadow-sm) !important;
}

.expediente-card-head {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: 12px !important;
    margin-bottom: 14px !important;
}

.expediente-card h4 {
    margin: 0 0 5px 0 !important;
    color: var(--mariam-gray-800) !important;
    font-size: 18px !important;
    font-weight: 950 !important;
}

.expediente-card-head span {
    color: var(--mariam-gray-500) !important;
    font-size: 13px !important;
    font-weight: 750 !important;
}

.expediente-meta {
    display: grid !important;
    gap: 8px !important;
    margin-bottom: 14px !important;
}

.expediente-meta span {
    display: block !important;
    padding: 9px 10px !important;
    border-radius: 12px !important;
    background: var(--mariam-gray-50) !important;
    color: var(--mariam-gray-600) !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    word-break: break-word !important;
}

.expediente-summary {
    padding: 12px !important;
    border-radius: 14px !important;
    background: var(--mariam-magenta-soft-2) !important;
    border: 1px solid #fbcfe8 !important;
}

.expediente-summary strong {
    display: block !important;
    margin-bottom: 4px !important;
    color: var(--mariam-magenta) !important;
    font-size: 13px !important;
    font-weight: 900 !important;
}

.expediente-summary p {
    margin: 0 !important;
    color: var(--mariam-gray-700) !important;
    font-size: 13px !important;
    line-height: 1.45 !important;
}

.expediente-detail-layout {
    display: grid !important;
    grid-template-columns: 1.35fr 0.85fr !important;
    gap: 20px !important;
}

.expediente-detail-main .form-grid {
    margin-bottom: 18px !important;
}

.expediente-history-box {
    padding: 16px !important;
    border-radius: 18px !important;
    background: var(--mariam-gray-50) !important;
    border: 1px solid var(--mariam-border) !important;
}

.expediente-history-box h4 {
    margin: 0 0 14px 0 !important;
    color: var(--mariam-gray-800) !important;
    font-size: 17px !important;
    font-weight: 950 !important;
}

.history-item {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: 10px !important;
    padding: 12px 0 !important;
    border-bottom: 1px solid var(--mariam-border) !important;
}

.history-item:last-child {
    border-bottom: none !important;
}

.history-item strong {
    display: block !important;
    color: var(--mariam-gray-800) !important;
    font-size: 13px !important;
    font-weight: 900 !important;
}

.history-item span {
    display: block !important;
    margin-top: 4px !important;
    color: var(--mariam-gray-500) !important;
    font-size: 12px !important;
    font-weight: 700 !important;
}

.mariam-muted-text {
    color: var(--mariam-gray-500) !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
}

.mariam-loading-text {
    padding: 30px !important;
    text-align: center !important;
    color: var(--mariam-gray-500) !important;
    font-weight: 800 !important;
}

/* ==========================================================================
   EMPTY STATES
========================================================================== */

.mariam-empty-state {
    grid-column: 1 / -1 !important;
    padding: 30px 22px !important;
    border: 1px dashed var(--mariam-gray-300) !important;
    border-radius: 20px !important;
    background: var(--mariam-white) !important;
    text-align: center !important;
}

.mariam-empty-state strong {
    display: block !important;
    margin-bottom: 6px !important;
    color: var(--mariam-gray-700) !important;
    font-size: 16px !important;
    font-weight: 900 !important;
}

.mariam-empty-state p {
    margin: 0 !important;
    color: var(--mariam-gray-500) !important;
    font-size: 14px !important;
}

/* ==========================================================================
   MODALES
========================================================================== */

.mariam-modal-overlay {
    position: fixed !important;
    inset: 0 !important;
    z-index: 999999 !important;
    display: none;
    align-items: center !important;
    justify-content: center !important;
    padding: 22px !important;
    background: rgba(15, 23, 42, 0.52) !important;
    backdrop-filter: blur(4px) !important;
}

.mariam-modal {
    width: 100% !important;
    max-width: 540px !important;
    max-height: calc(100vh - 44px) !important;
    overflow-y: auto !important;
    border-radius: 24px !important;
    background: var(--mariam-white) !important;
    box-shadow: var(--mariam-shadow-lg) !important;
    padding: 26px !important;
}

.mariam-modal-wide {
    max-width: 960px !important;
}

.modal-header {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: 14px !important;
    margin-bottom: 18px !important;
}

.modal-header h3 {
    margin: 0 0 4px 0 !important;
    color: var(--mariam-magenta) !important;
    font-size: 22px !important;
    font-weight: 950 !important;
}

.modal-header p {
    margin: 0 !important;
    color: var(--mariam-gray-500) !important;
    font-size: 14px !important;
}

.modal-close-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 38px !important;
    height: 38px !important;
    border-radius: 999px !important;
    background: var(--mariam-gray-100) !important;
    color: var(--mariam-gray-600) !important;
    font-size: 24px !important;
    line-height: 1 !important;
    font-weight: 700 !important;
}

.modal-close-btn:hover,
.modal-close-btn:focus {
    background: var(--mariam-red-soft) !important;
    color: #991b1b !important;
}

.modal-quick-actions {
    display: flex !important;
    gap: 10px !important;
    margin-bottom: 18px !important;
}

.btn-quick {
    flex: 1 !important;
    min-height: 40px !important;
    border-radius: 999px !important;
    font-size: 13px !important;
    font-weight: 900 !important;
}

.btn-quick.green-light {
    background: var(--mariam-green-soft) !important;
    color: var(--mariam-green-dark) !important;
}

.btn-quick.green-light:hover,
.btn-quick.green-light:focus {
    background: #bbf7d0 !important;
    color: var(--mariam-green-dark) !important;
}

.btn-quick.gray-light {
    background: var(--mariam-gray-100) !important;
    color: var(--mariam-gray-600) !important;
}

.btn-quick.gray-light:hover,
.btn-quick.gray-light:focus {
    background: var(--mariam-gray-200) !important;
    color: var(--mariam-gray-800) !important;
}

.time-selection-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 10px !important;
}

.time-slot-btn-admin {
    min-height: 46px !important;
    padding: 10px !important;
    border-radius: 12px !important;
    border: 1.5px solid var(--mariam-border) !important;
    background: var(--mariam-white) !important;
    color: var(--mariam-gray-600) !important;
    font-size: 14px !important;
    font-weight: 850 !important;
    cursor: pointer !important;
    outline: none !important;
    box-shadow: none !important;
    transition: all 0.2s ease !important;
}

.time-slot-btn-admin:hover,
.time-slot-btn-admin:focus {
    border-color: var(--mariam-green) !important;
    background: #f0fdf4 !important;
    color: var(--mariam-gray-800) !important;
}

.time-slot-btn-admin.active,
.time-slot-btn-admin.active:hover,
.time-slot-btn-admin.active:focus {
    border-color: var(--mariam-green) !important;
    background: var(--mariam-green) !important;
    color: var(--mariam-white) !important;
    box-shadow: 0 8px 18px rgba(16, 185, 129, 0.25) !important;
}

.modal-footer-status {
    margin-top: 16px !important;
    color: var(--mariam-gray-500) !important;
    font-size: 13px !important;
    font-weight: 800 !important;
}

.modal-footer-actions {
    display: flex !important;
    justify-content: flex-end !important;
    gap: 10px !important;
    margin-top: 18px !important;
}

.modal-footer-actions.align-right {
    justify-content: flex-end !important;
}

.btn-footer {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 42px !important;
    padding: 10px 18px !important;
    border-radius: 999px !important;
    font-size: 14px !important;
    font-weight: 900 !important;
    text-decoration: none !important;
}

.btn-footer.cancel {
    background: var(--mariam-gray-100) !important;
    color: var(--mariam-gray-600) !important;
}

.btn-footer.cancel:hover,
.btn-footer.cancel:focus {
    background: var(--mariam-gray-200) !important;
    color: var(--mariam-gray-800) !important;
}

.btn-footer.save {
    background: var(--mariam-magenta) !important;
    color: var(--mariam-white) !important;
}

.btn-footer.save:hover,
.btn-footer.save:focus {
    background: var(--mariam-magenta-hover) !important;
    color: var(--mariam-white) !important;
}

/* ==========================================================================
   RESPONSIVE
========================================================================== */

@media (max-width: 1024px) {
    .mariam-kpi-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .expediente-detail-layout {
        grid-template-columns: 1fr !important;
    }
}

@media (max-width: 860px) {
    #mariam-admin-workspace {
        padding: 18px !important;
        border-radius: 18px !important;
        margin: 18px auto !important;
    }

    .mariam-admin-header {
        flex-direction: column !important;
        align-items: flex-start !important;
    }

    .mariam-admin-userbar {
        width: 100% !important;
        justify-content: space-between !important;
    }

    .mariam-dash-tab-switch {
        flex-direction: column !important;
    }

    .availability-row {
        grid-template-columns: 1fr !important;
        align-items: stretch !important;
    }

    .btn-config-time {
        width: 100% !important;
    }

    .mariam-expedientes-grid {
        grid-template-columns: 1fr !important;
    }

    .appointment-card-top {
        flex-direction: column !important;
    }

    .appointment-primary-actions {
        justify-content: flex-start !important;
    }
}

@media (max-width: 700px) {
    .form-section {
        padding: 22px 18px !important;
        border-radius: 18px !important;
    }

    .form-section h3 {
        font-size: 19px !important;
    }

    .form-grid,
    .health-grid {
        grid-template-columns: 1fr !important;
    }

    .calendar-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .horarios-header {
        flex-direction: column !important;
    }

    #mariam-hours-container {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .mariam-kpi-grid {
        grid-template-columns: 1fr !important;
    }

    .card-details-grid,
    .appointment-health-box {
        grid-template-columns: 1fr !important;
    }

    .mariam-inline-form {
        flex-direction: column !important;
    }

    .time-selection-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .modal-footer-actions {
        flex-direction: column !important;
    }

    .btn-footer {
        width: 100% !important;
    }

    .mariam-login-box {
        padding: 28px 22px !important;
    }

    .mariam-booking-summary {
        padding: 16px !important;
    }

    .booking-summary-head {
        flex-direction: column !important;
        gap: 10px !important;
    }

    .booking-summary-grid {
        grid-template-columns: 1fr !important;
    }
}

@media (max-width: 420px) {
    .calendar-grid {
        grid-template-columns: 1fr !important;
    }

    #mariam-hours-container {
        grid-template-columns: 1fr !important;
    }

    .mariam-admin-brand {
        align-items: flex-start !important;
    }

    .mariam-admin-logo {
        width: 62px !important;
        height: 62px !important;
    }

    .mariam-admin-brand h2 {
        font-size: 23px !important;
    }
}