﻿:root {
    --primary-color: rgb(102 153 255);
    --rz-primary: #333;
}

.\!bg-primary {
    color: white !important;
    --tw-bg-opacity: 1 !important;
    background-color: rgb(102 153 255 / var(--tw-bg-opacity)) !important;
}
.\!bg-secondary {
    color: white !important;
    --tw-bg-opacity: 1 !important;
    background-color: rgb(13 1 73 / var(--tw-bg-opacity)) !important;
}

.\!bg-grey {
    color:white !important;
    --tw-bg-opacity: 1 !important;
    background-color: rgb(100 100 100 / var(--tw-bg-opacity)) !important;
}
.rz-state-focused {
    color: #333 !important;
}
/* Overlay del Loader */
.loader-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.2);
    justify-content: center;
    align-items: center;
    display: grid;
    z-index: 999;
}
/** Color of text when ho
/* Spinner */
.spinner {
    border: 6px solid #f3f3f3; /* Fondo */
    border-top: 6px solid #3498db; /* Color del spinner */
    border-radius: 50%;
    width: 50px;
    height: 50px;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}
body {
    background-color: #f3f4f6 !important;
}

/* Login page responsive styles (global fallback for login) */
.login-shell {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  padding: 2rem;
  background: linear-gradient(135deg, #0b1020 0%, #1b1b2b 60%, #0b1b3a 100%);
}
.login-card {
  width: 420px;
  max-width: 92vw;
  padding: 28px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.94);
  backdrop-filter: blur(6px);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);
}
.title {
  text-align: center;
  font-size: 28px;
  font-weight: 700;
  color: #1f2937;
  margin-bottom: 8px;
}
.form-row { margin-bottom: 12px; }
.label { display: block; font-size: 14px; font-weight: 600; color: #374151; margin-bottom: 6px; }
.input { width: 100%; padding: 12px 14px; border-radius: 8px; border: 1px solid #d1d5db; font-size: 15px; background: #fff; }
.remember { display: flex; align-items: center; gap: 8px; font-size: 14px; color: #374151; }
.btn-primary { width: 100%; padding: 12px 16px; border-radius: 8px; border: 0; cursor: pointer; font-weight: 600; color: #fff; background: linear-gradient(135deg, #4f46e5, #06b6d4); }
.btn-primary[disabled] { opacity: 0.65; cursor: not-allowed; }
.links { text-align: center; margin-top: 12px; font-size: 13px; color: #374151; }
.link { color: #2563eb; text-decoration: none; }
.subtitle { text-align: center; color: #6b7280; font-size: 14px; margin-bottom: 20px; }
.success-message { text-align: center; padding: 20px 0; }
.success-icon { font-size: 48px; color: #10b981; margin-bottom: 12px; }
.success-message p { color: #374151; font-size: 15px; }
.error-message { text-align: center; padding: 20px 0; }
.error-icon { font-size: 48px; color: #ef4444; margin-bottom: 12px; }
.error-message p { color: #6b7280; font-size: 15px; }
@media (max-width: 600px) {
  .login-card { width: 100%; }
}
.rz-tabview-panel {
    padding:0px 5px 0px 5px !important;
}

/*ToolBarMenu - Modern Sidebar Styles*/
.rz-stack-ToolbarMenu {
    background: linear-gradient(135deg, #1e3a5f 0%, #0f2744 100%) !important;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.15);
}
.rz-sidebar-ToolbarMenu {
    background: linear-gradient(180deg, #1e3a5f 0%, #0d1f38 100%) !important;
    box-shadow: 2px 0 12px rgba(0, 0, 0, 0.1);
}

/* Modern Sidebar */
.gm-main-header {
    background: #fff !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08) !important;
    border-bottom: 1px solid #e5e7eb !important;
}

.gm-sidebar-toggle {
    background: transparent !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 8px !important;
    color: #374151 !important;
}

.gm-sidebar-toggle:hover {
    background: #f3f4f6 !important;
}

.gm-brand {
    font-weight: 700 !important;
    font-size: 18px !important;
    color: #1e3a5f !important;
    letter-spacing: -0.5px;
}

.gm-user {
    font-weight: 500 !important;
    color: #4b5563 !important;
    font-size: 14px;
}

.gm-user-divider {
    width: 1px;
    height: 24px;
    background: #e5e7eb;
}

.gm-notif-btn {
    border-radius: 10px !important;
    transition: all 0.2s ease !important;
}

.gm-notif-btn:hover {
    background: #f3f4f6 !important;
    transform: scale(1.05);
}

.gm-avatar {
    background: linear-gradient(135deg, #3b82f6, #06b6d4) !important;
    color: #fff !important;
    font-weight: 600 !important;
    box-shadow: 0 2px 8px rgba(59, 130, 246, 0.3);
}

.gm-profile-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    color: #374151;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.15s ease;
    border-radius: 8px;
}

.gm-profile-item:hover {
    background: #f3f4f6;
    color: #1e3a5f;
}

.gm-profile-item .material-icons {
    font-size: 20px;
    color: #6b7280;
}

.gm-profile-item:hover .material-icons {
    color: #3b82f6;
}

.gm-profile-item.gm-logout:hover {
    background: #fee2e2;
    color: #dc2626;
}

.gm-profile-item.gm-logout:hover .material-icons {
    color: #dc2626;
}

.gm-profile-divider {
    height: 1px;
    background: #e5e7eb;
    margin: 4px 0;
}

/* Sidebar Menu */
.gm-sidebar {
    background: linear-gradient(180deg, #1e3a5f 0%, #0d1f38 100%) !important;
    box-shadow: 2px 0 16px rgba(0, 0, 0, 0.15) !important;
}

.gm-sidebar-header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 20px 16px;
    color: #fff;
    font-size: 16px;
    font-weight: 600;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.gm-sidebar-icon {
    font-size: 24px !important;
    color: #60a5fa !important;
}

.gm-menu .rz-navigation-item {
    margin: 4px 12px !important;
    border-radius: 10px !important;
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.gm-menu .rz-navigation-item:hover {
    background: rgba(255, 255, 255, 0.1) !important;
    transform: translateX(4px);
}

.gm-menu .rz-navigation-item-link {
    padding: 12px 16px !important;
    border-radius: 10px !important;
    color: rgba(255, 255, 255, 0.85) !important;
    font-weight: 500 !important;
    font-size: 14px !important;
    transition: all 0.2s ease !important;
}

.gm-menu .rz-navigation-item-link:hover {
    color: #fff !important;
    background: rgba(255, 255, 255, 0.08) !important;
}

.gm-menu .rz-navigation-item-icon {
    color: #60a5fa !important;
    font-size: 20px !important;
}

.gm-menu .rz-navigation-item.rz-navigation-item-active .rz-navigation-item-link {
    background: linear-gradient(135deg, #3b82f6, #06b6d4) !important;
    color: #fff !important;
    box-shadow: 0 4px 12px rgba(59, 130, 246, 0.4);
}

.gm-menu .rz-navigation-item.rz-navigation-item-active .rz-navigation-item-icon {
    color: #fff !important;
}

.gm-sidebar-footer {
    margin-top: auto;
    padding: 16px !important;
    text-align: center;
    color: rgba(255, 255, 255, 0.4) !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    letter-spacing: 0.5px;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
}

.gm-sidebar-footer .material-icons {
    font-size: 14px !important;
    color: #ef4444 !important;
}

.rz-panelmenu .rz-panelmenu-header > a {
    background: transparent !important;
    color: rgba(255, 255, 255, 0.85) !important;
    border-radius: 8px !important;
    margin: 2px 8px !important;
}

.rz-panelmenu .rz-panelmenu-header > a:hover {
    background: rgba(255, 255, 255, 0.1) !important;
}
.rz-CardComponent {
    max-width: 500px;
    padding: 20px;
    border-radius: 10px;
}
.rz-CardComponent-Image {
    border-radius: 10px;
    width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
}

/*GridComponent*/

.rz-datatable {
    border: none;
}
.rz-datatable-emptymessage-row {
    cursor: default;
}
.rz-datatable-data tr:first-child > td, .rz-grid-table tr:first-child > td {
    border-top: var(--rz-grid-border);
}
.rz-datatable-thead th, .rz-grid-table thead th, .rz-datatable-scrollable-header, .rz-datatable-tfoot td, .rz-grid-table tfoot td, .rz-datatable-odd > td, .rz-grid-table-striped tbody tr:not(.rz-expanded-row-content):nth-child(even) > td {
    background-color: white;
 
}
.rz-frozen-cell {
    background-color: white !important;
}
.rz-selectable tbody tr.rz-data-row:hover:not(.rz-state-highlight) > td:not(.rz-frozen-cell) {
    background-color: transparent;
    border-right: none;
    cursor: pointer;
}
.rz-selectable tbody tr.rz-data-row:hover:not(.rz-state-highlight) .rz-cell-data {
    color: #000;
}
.rz-datatable-data td:not(:last-child), .rz-datatable-data td.rz-composite-cell, .rz-grid-table td:not(:last-child), .rz-grid-table td.rz-composite-cell, .rz-datatable-tfoot td:not(:last-child), .rz-grid-table tfoot td:not(:last-child) {
    border-right: none;
}
.rz-paginator-page.rz-state-active {
    color: var(--primary-color);
}

/* Keep input/dropdown corner radius visually consistent */
.rz-form-field,
.rz-form-field .rz-form-field-content,
.rz-form-field .rz-textbox,
.rz-form-field .rz-inputtext,
.rz-form-field .rz-dropdown,
.rz-form-field .rz-multiselect,
.rz-form-field .rz-spinner,
.rz-form-field .rz-textarea,
.rz-form-field .rz-datepicker {
    border-radius: 10px !important;
}

.rz-autocomplete:hover:not(.rz-state-disabled), .rz-radiobutton-box:hover:not(.rz-state-disabled), .rz-chkbox-box:hover:not(.rz-state-disabled), .rz-colorpicker:not(:disabled):not(.rz-state-disabled):focus, .rz-lookup-search input:not(:disabled):not(.rz-state-disabled):focus, .rz-spinner:not(:disabled):not(.rz-state-disabled):focus, .rz-calendar .rz-inputtext:not(:disabled):not(.rz-state-disabled):focus, .rz-multiselect:not(:disabled):not(.rz-state-disabled):focus, .rz-dropdown:not(:disabled):not(.rz-state-disabled):focus, .mask:not(:disabled):not(.rz-state-disabled):focus, .rz-textarea:not(:disabled):not(.rz-state-disabled):focus, .rz-textbox:not(:disabled):not(.rz-state-disabled):focus, .rz-colorpicker:not(:disabled):not(.rz-state-disabled):hover, .rz-lookup-search input:not(:disabled):not(.rz-state-disabled):hover, .rz-spinner:not(:disabled):not(.rz-state-disabled):hover, .rz-calendar .rz-inputtext:not(:disabled):not(.rz-state-disabled):hover, .rz-multiselect:not(:disabled):not(.rz-state-disabled):hover, .rz-dropdown:not(:disabled):not(.rz-state-disabled):hover, .mask:not(:disabled):not(.rz-state-disabled):hover, .rz-textarea:not(:disabled):not(.rz-state-disabled):hover, .rz-textbox:not(:disabled):not(.rz-state-disabled):hover {
    box-shadow: inset 0 4px 7px 0 rgba(0, 0, 0, 0.03);
    border: 1px solid var(--primary-color);
    border-radius: 10px;
}
.rz-paginator-first,
.rz-paginator-prev {
    background-color: #479cc8;
    color: #ffffff;
}
.autoSizeColumn {
    white-space: nowrap;
    width: 1%;
}
.minSizeColumn {
    width: 90px !important;
}
.whites-nowrap {
    white-space: nowrap;
}

.whites-pre-wrap {
    white-space: pre-wrap;
}

/*DialogComponent*/
.rz-dialog {
    background-color: rgba(0, 0, 0, 0.2) !important;
}
.rz-dialog-titlebar {
    background-color: #f3f4f6 !important;
}
.rz-dialog-content {
    background-color: #f3f4f6 !important;
}
.rz-fieldset {
    background-color: #fff !important;
}
.rz-fieldset-legend {
    margin-bottom: 0px !important;
}
.rz-fieldset-content {
    padding-top: 0px !important;
    background-color: #fff !important;
    padding-bottom: 0px !important;
}
.rz-fieldset-content-wrapper {
    padding-bottom:10px;
    background-color: #fff !important;
}

/*ServiceComponent*/
.rz-radzenbadge {
    border-radius: 30px;
    color: white;
    font-size: 10px;
    text-wrap-mode: wrap;
    width: 30px;
    height: 25px;
    margin-top: 10px;
}

/* Botón normal */
.responsive-btn .rz-button-text {
    display: inline;
}

/* Radzen upload component */
.rz-fileupload-row {
    overflow:auto !important;
}

/* Oculta el texto cuando la pantalla es pequeña */
@media (max-width: 640px) {
    .responsive-btn .rz-button-text {
        display: none;
    }

    /* Ajusta el tamaño del botón si lo deseas */
    .responsive-btn {
        padding: 6px !important;
        width: 40px;
        justify-content: center;
    }
}

/* Doctor Grid - selected row consistency */
.doctor-grid .rz-state-highlight,
.doctor-grid .rz-datagrid-row-selected,
.doctor-grid .rz-datagrid-row-selected > td,
.doctor-grid .rz-datatable-even.rz-state-highlight,
.doctor-grid .rz-datatable-even.rz-state-highlight > td {
    background-color: #dbeafe !important;
    color: #0f172a !important;
}

.doctor-grid .rz-datagrid-row-selected a,
.doctor-grid .rz-datagrid-row-selected span,
.doctor-grid .rz-datagrid-row-selected .rz-cell-data {
    color: #0f172a !important;
}

/* Patient Grid - selected row consistency */
.patient-grid .rz-state-highlight,
.patient-grid .rz-datagrid-row-selected,
.patient-grid .rz-datagrid-row-selected > td,
.patient-grid .rz-datatable-even.rz-state-highlight,
.patient-grid .rz-datatable-even.rz-state-highlight > td {
    background-color: #dbeafe !important;
    color: #0f172a !important;
}

/* User Grid - selected row consistency */
.user-grid .rz-state-highlight,
.user-grid .rz-datagrid-row-selected,
.user-grid .rz-datagrid-row-selected > td,
.user-grid .rz-datatable-even.rz-state-highlight,
.user-grid .rz-datatable-even.rz-state-highlight > td {
    background-color: #dbeafe !important;
    color: #0f172a !important;
}

.user-grid .rz-datagrid-row-selected a,
.user-grid .rz-datagrid-row-selected span,
.user-grid .rz-datagrid-row-selected .rz-cell-data {
    color: #0f172a !important;
}

.patient-grid .rz-datagrid-row-selected a,
.patient-grid .rz-datagrid-row-selected span,
.patient-grid .rz-datagrid-row-selected .rz-cell-data {
    color: #0f172a !important;
}

/* Reminder Grid - selected row consistency */
.reminder-grid .rz-state-highlight,
.reminder-grid .rz-datagrid-row-selected,
.reminder-grid .rz-datagrid-row-selected > td,
.reminder-grid .rz-datatable-even.rz-state-highlight,
.reminder-grid .rz-datatable-even.rz-state-highlight > td {
    background-color: #dbeafe !important;
    color: #0f172a !important;
}

.reminder-grid .rz-datagrid-row-selected a,
.reminder-grid .rz-datagrid-row-selected span,
.reminder-grid .rz-datagrid-row-selected .rz-cell-data {
    color: #0f172a !important;
}

/* Consultations / Prescription Grid - selected row consistency */
.consultations-grid .rz-state-highlight,
.consultations-grid .rz-datagrid-row-selected,
.consultations-grid .rz-datagrid-row-selected > td,
.consultations-grid .rz-datatable-even.rz-state-highlight,
.consultations-grid .rz-datatable-even.rz-state-highlight > td,
.consultations-grid tr.rz-state-highlight > td,
.consultations-grid tr.rz-datagrid-row-selected > td,
.consultations-grid tr.rz-datatable-even.rz-state-highlight > td,
.prescription-grid .rz-state-highlight,
.prescription-grid .rz-datagrid-row-selected,
.prescription-grid .rz-datagrid-row-selected > td,
.prescription-grid .rz-datatable-even.rz-state-highlight,
.prescription-grid .rz-datatable-even.rz-state-highlight > td,
.prescription-grid tr.rz-state-highlight > td,
.prescription-grid tr.rz-datagrid-row-selected > td,
.prescription-grid tr.rz-datatable-even.rz-state-highlight > td {
    background-color: #e7f0ff !important;
    color: #0f172a !important;
}

.consultations-grid .rz-state-highlight a,
.consultations-grid .rz-state-highlight span,
.consultations-grid .rz-state-highlight .rz-cell-data,
.consultations-grid .rz-datagrid-row-selected a,
.consultations-grid .rz-datagrid-row-selected span,
.consultations-grid .rz-datagrid-row-selected .rz-cell-data,
.prescription-grid .rz-state-highlight a,
.prescription-grid .rz-state-highlight span,
.prescription-grid .rz-state-highlight .rz-cell-data,
.prescription-grid .rz-datagrid-row-selected a,
.prescription-grid .rz-datagrid-row-selected span,
.prescription-grid .rz-datagrid-row-selected .rz-cell-data {
    color: #0f172a !important;
}

/* User detail read-only fields */
.user-read-field {
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 0.16rem !important;
    min-height: 38px !important;
    padding: 0.32rem 0 !important;
}

.user-read-label {
    color: #7a8699 !important;
    display: block !important;
    font-family: "Space Grotesk", "Manrope", sans-serif !important;
    font-size: 0.64rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.1em !important;
    line-height: 1.15 !important;
    margin-bottom: 0.14rem !important;
    text-transform: uppercase !important;
}

.user-read-value {
    color: #1f2937 !important;
    display: block !important;
    font-family: "Manrope", "Segoe UI", sans-serif !important;
    font-size: 0.98rem !important;
    font-weight: 400 !important;
    letter-spacing: 0 !important;
    line-height: 1.4 !important;
    word-break: break-word !important;
}

/* Doctor detail read-only fields */
.doctor-read-field {
    background: transparent !important;
    border: 0 !important;
    border-radius: 0;
    display: flex;
    flex-direction: column;
    gap: 0.16rem;
    min-height: 38px;
    padding: 0.32rem 0;
}

.doctor-read-label {
    color: #7a8699 !important;
    display: block;
    font-family: "Space Grotesk", "Manrope", sans-serif;
    font-size: 0.64rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    line-height: 1.15;
    margin-bottom: 0.14rem;
    text-transform: uppercase;
}

.doctor-read-value {
    color: #1f2937 !important;
    display: block;
    font-family: "Manrope", "Segoe UI", sans-serif;
    font-size: 0.98rem;
    font-weight: 400;
    letter-spacing: 0;
    line-height: 1.4;
    word-break: break-word;
}

.doctor-read-notes {
    min-height: 88px;
    white-space: pre-wrap;
}

/* Patient detail read-only fields */
.patient-read-field {
    background: transparent !important;
    border: 0 !important;
    border-radius: 0;
    display: flex;
    flex-direction: column;
    gap: 0.16rem;
    min-height: 38px;
    padding: 0.32rem 0;
}

.patient-read-label {
    color: #7a8699 !important;
    display: block;
    font-family: "Space Grotesk", "Manrope", sans-serif;
    font-size: 0.64rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    line-height: 1.15;
    margin-bottom: 0.14rem;
    text-transform: uppercase;
}

.patient-read-value {
    color: #1f2937 !important;
    display: block;
    font-family: "Manrope", "Segoe UI", sans-serif;
    font-size: 0.98rem;
    font-weight: 400;
    letter-spacing: 0;
    line-height: 1.4;
    word-break: break-word;
}

.patient-read-notes {
    min-height: 88px;
    white-space: pre-wrap;
}
