/* CLINIC DASHBOARD STYLES - Todos con !important */

/* Ocultar header del tema cuando se muestra el nuevo dashboard */
body:has(.user-dashboard-wrapper) #header,
body:has(.user-dashboard-wrapper) header#header,
body:has(.user-dashboard-wrapper) .header,
body:has(.user-dashboard-wrapper) #masthead,
body:has(.user-dashboard-wrapper) .site-header,
body:has(.user-dashboard-wrapper) #top-bar,
body:has(.user-dashboard-wrapper) .top-bar,
body:has(.clinic-dashboard-wrapper) #header,
body:has(.clinic-dashboard-wrapper) header#header,
body:has(.clinic-dashboard-wrapper) .header,
body:has(.clinic-dashboard-wrapper) #masthead,
body:has(.clinic-dashboard-wrapper) .site-header,
body:has(.clinic-dashboard-wrapper) #top-bar,
body:has(.clinic-dashboard-wrapper) .top-bar {
    display: none !important;
}

/* Ocultar sidebar antiguo cuando se muestra el nuevo dashboard */
.user-dashboard-wrapper,
.clinic-dashboard-wrapper {
    position: relative !important;
    z-index: 10 !important;
}

/* Ocultar completamente el sidebar antiguo cuando hay nuevo dashboard */
#dashboard:has(.user-dashboard-wrapper) .dashboard-nav,
#dashboard:has(.clinic-dashboard-wrapper) .dashboard-nav,
body:has(.user-dashboard-wrapper) .dashboard-nav,
body:has(.clinic-dashboard-wrapper) .dashboard-nav {
    display: none !important;
    visibility: hidden !important;
}

/* Ocultar trigger responsive también */
#dashboard:has(.user-dashboard-wrapper) .dashboard-responsive-nav-trigger,
#dashboard:has(.clinic-dashboard-wrapper) .dashboard-responsive-nav-trigger,
body:has(.user-dashboard-wrapper) .dashboard-responsive-nav-trigger,
body:has(.clinic-dashboard-wrapper) .dashboard-responsive-nav-trigger {
    display: none !important;
}

.clinic-dashboard-wrapper {
    display: flex !important;
    min-height: 100vh !important;
    background: #f8f9fa !important;
    font-family: 'Inter', sans-serif !important;
}

/* Botón abrir menú (solo visible en móvil) */
.clinic-sidebar-toggle {
    display: none !important;
    align-items: center !important;
    justify-content: center !important;
    width: 44px !important;
    height: 44px !important;
    margin-right: 12px !important;
    padding: 0 !important;
    background: #f3f4f6 !important;
    border: none !important;
    border-radius: 10px !important;
    color: #1B5D63 !important;
    cursor: pointer !important;
    flex-shrink: 0 !important;
}
.clinic-sidebar-toggle:hover {
    background: #e5e7eb !important;
}

/* Botón cerrar menú (dentro del sidebar, solo móvil) */
.clinic-sidebar-close {
    display: none !important;
    position: absolute !important;
    top: 16px !important;
    right: 16px !important;
    width: 40px !important;
    height: 40px !important;
    padding: 0 !important;
    background: #f3f4f6 !important;
    border: none !important;
    border-radius: 8px !important;
    color: #374151 !important;
    cursor: pointer !important;
    align-items: center !important;
    justify-content: center !important;
}
.clinic-sidebar-close:hover {
    background: #e5e7eb !important;
}

/* Overlay móvil (oculto por defecto) */
.clinic-sidebar-overlay {
    display: none !important;
    position: fixed !important;
    inset: 0 !important;
    background: rgba(0, 0, 0, 0.4) !important;
    z-index: 99 !important;
    opacity: 0 !important;
    transition: opacity 0.25s ease !important;
}

/* SIDEBAR */
.clinic-sidebar {
    width: 260px !important;
    background: white !important;
    border-right: 1px solid #e5e7eb !important;
    padding: 24px 0 !important;
    display: flex !important;
    flex-direction: column !important;
    position: fixed !important;
    height: 100vh !important;
    overflow-y: auto !important;
    z-index: 100 !important;
    left: 0 !important;
    top: 0 !important;
    transition: transform 0.25s ease !important;
}

.clinic-sidebar .sidebar-logo {
    display: block !important;
    padding: 16px 24px !important;
    text-decoration: none !important;
}

.clinic-sidebar .sidebar-logo-img {
    max-width: 150px !important;
    width: 100% !important;
    height: 100px !important;
    object-fit: contain !important;
}

.sidebar-header h3 {
    padding: 0 24px 24px !important;
    font-size: 1.2rem !important;
    font-weight: 700 !important;
    color: #1B5D63 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
}

.sidebar-nav {
    flex: 1 !important;
    padding: 0 16px !important;
}

.sidebar-nav .nav-item {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 12px 16px !important;
    border-radius: 12px !important;
    color: #6b7280 !important;
    text-decoration: none !important;
    transition: all 0.2s !important;
    margin-bottom: 4px !important;
    font-size: 1.25rem !important;
    font-weight: 500 !important;
}

.sidebar-nav .nav-item:hover {
    background: #f3f4f6 !important;
    color: #1B5D63 !important;
}

.sidebar-nav .nav-item.active {
    background: #1B5D63 !important;
    color: white !important;
}

.sidebar-nav .nav-item-locked {
    cursor: default !important;
    opacity: 0.9 !important;
    pointer-events: auto !important;
}

.sidebar-nav .nav-item-locked:hover {
    background: #f3f4f6 !important;
    color: #6b7280 !important;
}

.sidebar-nav .nav-item-locked {
    position: relative !important;
}

.sidebar-nav .nav-item-tooltip {
    position: absolute !important;
    left: -5% !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    margin-left: 12px !important;
    padding: 12px 16px !important;
    background: #1f2937 !important;
    color: #fff !important;
    font-size: 1.1rem !important;
    font-weight: 500 !important;
    line-height: 1.4 !important;
    white-space: normal !important;
    width: 220px !important;
    border-radius: 10px !important;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.2) !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transition: opacity 0.2s, visibility 0.2s !important;
    z-index: 9999999 !important;
    pointer-events: none !important;
}

.sidebar-nav .nav-item-tooltip::before {
    content: '' !important;
    position: absolute !important;
    right: 100% !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    border: 6px solid transparent !important;
    border-right-color: #1f2937 !important;
}

.sidebar-nav .nav-item-locked:hover .nav-item-tooltip {
    opacity: 1 !important;
    visibility: visible !important;
}

/* MAIN CONTENT */
.clinic-main-content {
    flex: 1 !important;
    margin-left: 260px !important;
    padding: 32px !important;
    max-width: calc(100% - 260px) !important;
}

.clinic-header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: flex-start !important;
    margin-bottom: 32px !important;
}

.header-title-section h1 {
    font-size: 2.4rem !important;
    font-weight: 700 !important;
    color: #1f2937 !important;
    margin-bottom: 4px !important;
}

.clinic-subtitle {
    color: #6b7280 !important;
    font-size: 1.15rem !important;
}

.header-user {
    display: flex !important;
    align-items: center !important;
}

.header-user-dropdown {
    position: relative !important;
}

.header-user-trigger {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    background: none !important;
    border: none !important;
    cursor: pointer !important;
    border-radius: 50% !important;
}

.header-user-trigger:hover .user-avatar,
.header-user-trigger:focus .user-avatar {
    box-shadow: 0 0 0 2px var(--clinic-accent, #14b8a6) !important;
}

.header-user-menu {
    position: absolute !important;
    top: 100% !important;
    right: 0 !important;
    margin-top: 8px !important;
    min-width: 180px !important;
    background: #fff !important;
    border-radius: 12px !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.12) !important;
    padding: 8px 0 !important;
    z-index: 1000 !important;
    list-style: none !important;
}

.header-user-menu[hidden] {
    display: none !important;
}

.header-user-menu:not([hidden]) {
    display: block !important;
}

.header-user-menu-item {
    display: block !important;
    padding: 10px 16px !important;
    font-size: 0.9375rem !important;
    color: #374151 !important;
    text-decoration: none !important;
    transition: background 0.15s, color 0.15s !important;
}

.header-user-menu-item:hover {
    background: #f3f4f6 !important;
    color: var(--clinic-accent, #14b8a6) !important;
}

.header-user-menu-item-logout {
    color: #dc2626 !important;
    border-top: 1px solid #e5e7eb !important;
    margin-top: 4px !important;
    padding-top: 12px !important;
}

.header-user-menu-item-logout:hover {
    background: #fef2f2 !important;
    color: #b91c1c !important;
}

.user-avatar {
    width: 48px !important;
    height: 48px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
}

.clinic-content-area {
    background: transparent !important;
}

/* METRICS */
.metrics-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)) !important;
    gap: 16px !important;
    margin-bottom: 32px !important;
}

.metric-card {
    background: white !important;
    padding: 24px !important;
    border-radius: 16px !important;
    display: flex !important;
    align-items: center !important;
    gap: 16px !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1) !important;
}

.metric-icon {
    width: 56px !important;
    height: 56px !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.metric-icon.blue {
    background: #e0f2fe !important;
    color: #0284c7 !important;
}

.metric-icon.green {
    background: #dcfce7 !important;
    color: #16a34a !important;
}

.metric-icon.orange {
    background: #fef3c7 !important;
    color: #d97706 !important;
}

.metric-content {
    display: flex !important;
    flex-direction: column !important;
}

.metric-label {
    font-size: 1.35rem !important;
    color: #6b7280 !important;
    margin-bottom: 4px !important;
    font-weight: 500 !important;
}

.metric-value {
    font-size: 2.2rem !important;
    font-weight: 700 !important;
    color: #1f2937 !important;
}

/* ACTIVITY SECTIONS */
.activity-sections {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 24px !important;
}

.activity-card {
    background: white !important;
    padding: 24px !important;
    border-radius: 16px !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1) !important;
}

.activity-header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 16px !important;
}

.activity-header h3 {
    font-size: 1.4rem !important;
    font-weight: 700 !important;
    color: #1f2937 !important;
}

.view-all-link {
    color: #1B5D63 !important;
    font-weight: 600 !important;
    font-size: 1.2rem !important;
    text-decoration: none !important;
}

.view-all-link:hover {
    text-decoration: underline !important;
}

.activity-menu-btn {
    width: 32px !important;
    height: 32px !important;
    border-radius: 8px !important;
    border: 1px solid #e5e7eb !important;
    background: white !important;
    color: #6b7280 !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: all 0.2s !important;
}

.activity-menu-btn:hover {
    background: #f3f4f6 !important;
    border-color: #1B5D63 !important;
    color: #1B5D63 !important;
}

.activity-empty {
    text-align: center !important;
    padding: 40px 20px !important;
    color: #6b7280 !important;
    font-size: 1.35rem !important;
}

/* SOLICITUDES PAGE */
.solicitudes-page {
    background: transparent !important;
}

.page-header-tabs {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 24px !important;
}

.section-title {
    font-size: 1.5rem !important;
    font-weight: 700 !important;
    color: #1f2937 !important;
}

.tabs-container {
    display: flex !important;
    gap: 8px !important;
    background: #f3f4f6 !important;
    padding: 4px !important;
    border-radius: 12px !important;
}

.tab-btn {
    padding: 8px 16px !important;
    border: none !important;
    background: transparent !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    color: #6b7280 !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    transition: all 0.2s !important;
}

.tab-btn.active {
    background: white !important;
    color: #1B5D63 !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1) !important;
}

.solicitudes-content {
    background: white !important;
    border-radius: 16px !important;
    padding: 40px !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1) !important;
}

.empty-state {
    text-align: center !important;
    color: #6b7280 !important;
}

/* CHATS PAGE */
.chats-page {
    background: transparent !important;
}

.chats-layout {
    display: grid !important;
    grid-template-columns: 350px 1fr !important;
    gap: 24px !important;
}

.chats-sidebar {
    background: white !important;
    border-radius: 16px !important;
    padding: 20px !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1) !important;
}

.chats-sidebar h3 {
    font-size: 1.1rem !important;
    font-weight: 700 !important;
    color: #1f2937 !important;
    margin-bottom: 16px !important;
}

.chats-search {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 12px 16px !important;
    background: #f9fafb !important;
    border-radius: 12px !important;
    margin-bottom: 20px !important;
}

.chats-search svg {
    color: #9ca3af !important;
}

.chats-search input {
    flex: 1 !important;
    border: none !important;
    outline: none !important;
    background: transparent !important;
    color: #1f2937 !important;
    font-size: 1.2rem !important;
    margin:0 !important;
    padding:0 !important;
}

.conversation-list {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
}

.conversation-item {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 12px !important;
    border-radius: 12px !important;
    cursor: pointer !important;
    transition: all 0.2s !important;
}

.conversation-item:hover {
    background: #f3f4f6 !important;
}

.conversation-avatar {
    width: 48px !important;
    height: 48px !important;
    min-width: 48px !important;
    min-height: 48px !important;
    border-radius: 50% !important;
    background: #e5e7eb !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: hidden !important;
    flex-shrink: 0 !important;
}

.conversation-avatar img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
}

.conversation-info {
    flex: 1 !important;
    min-width: 0 !important;
}

.conversation-name {
    font-weight: 600 !important;
    color: #1f2937 !important;
    margin-bottom: 2px !important;
    font-size: 1.2rem !important;
}

.conversation-preview {
    font-size: 1rem !important;
    color: #6b7280 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.conversation-time {
    font-size: 0.75rem !important;
    color: #9ca3af !important;
}

.chats-main {
    background: white !important;
    border-radius: 16px !important;
    padding: 0 !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1) !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    min-height: 400px !important;
}

.chats-main .chats-empty-state {
    padding: 40px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
}

.chats-main:has(.chats-header) {
    padding: 0 !important;
}

.chats-main:has(.chats-header) .chats-messages {
    flex: 1 !important;
    min-height: 200px !important;
    overflow-y: auto !important;
}

.chats-empty-state {
    text-align: center !important;
}

.chats-empty-state svg {
    color: #d1d5db !important;
    margin-bottom: 16px !important;
}

.chats-empty-state h3 {
    font-size: 1.25rem !important;
    font-weight: 700 !important;
    color: #1f2937 !important;
    margin-bottom: 8px !important;
}

.chats-empty-state p {
    color: #6b7280 !important;
}

/* Chat: cabecera, mensajes y avatares */
.chats-main .chats-header {
    padding: 20px 24px !important;
    border-bottom: 1px solid #e5e7eb !important;
    background: white !important;
}

.chats-main .chats-header-user {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
}

.chats-main .chats-header-user .avatar,
.chats-main .chats-header-user img {
    width: 48px !important;
    height: 48px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
    display: block !important;
}

.chats-main .chats-messages {
    flex: 1 !important;
    overflow-y: auto !important;
    padding: 24px !important;
    background: #f9fafb !important;
}

.chats-main .message-bubble {
    display: flex !important;
    align-items: flex-end !important;
    gap: 10px !important;
    margin-bottom: 16px !important;
}

.chats-main .message-bubble.mine {
    flex-direction: row-reverse !important;
}

.chats-main .message-avatar {
    flex-shrink: 0 !important;
    width: 40px !important;
    height: 40px !important;
}

.chats-main .message-bubble.mine .message-avatar {
    display: none !important;
}

.chats-main .message-avatar img {
    width: 40px !important;
    height: 40px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
    display: block !important;
}

.chats-main .message-content {
    max-width: 70% !important;
}

.chats-main .message-bubble.mine .message-content {
    text-align: right !important;
}

.chats-main .message-text {
    background: white !important;
    padding: 12px 16px !important;
    border-radius: 16px !important;
    box-shadow: 0 1px 2px rgba(0,0,0,0.08) !important;
    display: inline-block !important;
    text-align: left !important;
}

.chats-main .message-bubble.mine .message-text {
    background: #1B5D63 !important;
    color: white !important;
}

.chats-main .message-time {
    font-size: 0.75rem !important;
    color: #9ca3af !important;
    display: block !important;
    margin-top: 4px !important;
}

.chats-main .chats-reply {
    padding: 20px 24px !important;
    background: white !important;
    border-top: 1px solid #e5e7eb !important;
    max-width: 100% !important;
    overflow: hidden !important;
}

.chats-main .chats-reply form {
    display: flex !important;
    gap: 12px !important;
    align-items: center !important;
    min-width: 0 !important;
    width: 100% !important;
}

.chats-main .chats-reply textarea {
    flex: 1 1 auto !important;
    min-width: 0 !important;
    max-width: 100% !important;
    padding: 12px 16px !important;
    border: 2px solid #e5e7eb !important;
    border-radius: 12px !important;
    resize: none !important;
    min-height: 50px !important;
    max-height: 60px !important;
    font-family: inherit !important;
    font-size: 1.1rem !important;
    box-sizing: border-box !important;
    margin: 0 !important;
}

.chats-main .chats-reply .send-btn {
    flex-shrink: 0 !important;
    padding: 12px 20px !important;
    background: #1B5D63 !important;
    color: white !important;
    border: none !important;
    border-radius: 12px !important;
    font-weight: 600 !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    cursor: pointer !important;
    white-space: nowrap !important;
}

/* AGENDA PAGE */
.agenda-page {
    background: transparent !important;
}

.agenda-header-controls {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 24px !important;
}

.calendar-nav {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
}

.calendar-nav button {
    width: 32px !important;
    height: 32px !important;
    border-radius: 8px !important;
    border: 1px solid #e5e7eb !important;
    background: white !important;
    color: #6b7280 !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: all 0.2s !important;
}

.calendar-nav button:hover {
    border-color: #1B5D63 !important;
    color: #1B5D63 !important;
}

.current-month {
    font-weight: 600 !important;
    color: #1f2937 !important;
}

.block-slot-btn {
    padding: 10px 20px !important;
    background: #1B5D63 !important;
    color: white !important;
    border: none !important;
    border-radius: 12px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: all 0.2s !important;
}

.block-slot-btn:hover {
    background: #145048 !important;
}

.weekly-calendar {
    background: white !important;
    border-radius: 16px !important;
    padding: 24px !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1) !important;
}

.calendar-header {
    display: grid !important;
    grid-template-columns: repeat(7, 1fr) !important;
    gap: 4px !important;
    margin-bottom: 12px !important;
    background: #f9fafb !important;
    padding: 8px !important;
    border-radius: 12px !important;
}

.day-header {
    text-align: center !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    color: #1B5D63 !important;
    padding: 8px 4px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
}

.calendar-dates {
    display: grid !important;
    grid-template-columns: repeat(7, 1fr) !important;
    gap: 4px !important;
    margin-bottom: 16px !important;
    padding: 0 8px !important;
}

.date-cell {
    aspect-ratio: 1 !important;
    max-width: 100% !important;
    border-radius: 8px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-weight: 600 !important;
    font-size: 1rem !important;
    color: #1f2937 !important;
    cursor: pointer !important;
    transition: all 0.2s !important;
    border: 1px solid transparent !important;
}

.date-cell:hover {
    background: #f3f4f6 !important;
    border-color: #1B5D63 !important;
}

.date-cell.active {
    background: #1B5D63 !important;
    color: white !important;
    font-weight: 700 !important;
    box-shadow: 0 2px 8px rgba(27, 93, 99, 0.3) !important;
}

.calendar-grid {
    display: flex !important;
    flex-direction: column !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    background: white !important;
}

.time-slot {
    display: grid !important;
    grid-template-columns: 90px repeat(7, 1fr) !important;
    border-bottom: 1px solid #e5e7eb !important;
}

.time-slot:last-child {
    border-bottom: none !important;
}

.time-label {
    padding: 12px 16px !important;
    font-size: 1.1rem !important;
    color: #6b7280 !important;
    text-align: right !important;
    font-weight: 600 !important;
    background: #f9fafb !important;
    border-right: 1px solid #e5e7eb !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
}

.day-slots {
    display: contents !important;
}

.slot-cell {
    min-height: 60px !important;
    border-right: 1px solid #e5e7eb !important;
    cursor: pointer !important;
    transition: all 0.2s !important;
    position: relative !important;
    font-size: 1.1rem !important;
    padding: 4px !important;
}

.slot-cell:last-child {
    border-right: none !important;
}

.slot-cell:hover {
    background: rgba(27, 93, 99, 0.05) !important;
}

/* HORARIOS PAGE */
.horarios-page {
    background: transparent !important;
}

.horarios-header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 32px !important;
}

.horarios-header h2 {
    font-size: 1.5rem !important;
    font-weight: 700 !important;
    color: #1f2937 !important;
}

.save-changes-btn {
    padding: 12px 24px !important;
    background: #1B5D63 !important;
    color: white !important;
    border: none !important;
    border-radius: 12px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    transition: all 0.2s !important;
}

.save-changes-btn:hover {
    background: #145048 !important;
}

.opening-hours-form {
    background: white !important;
    border-radius: 16px !important;
    padding: 32px !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1) !important;
}

.hours-list {
    margin-bottom: 32px !important;
}

.hours-row {
    display: flex !important;
    align-items: center !important;
    gap: 16px !important;
    padding: 16px 0 !important;
    border-bottom: 1px solid #e5e7eb !important;
}

.day-name {
    width: 120px !important;
    font-weight: 600 !important;
    color: #1f2937 !important;
}

.hours-inputs {
    flex: 1 !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
}

.time-input {
    padding: 8px 12px !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 8px !important;
    font-size: 1.2rem !important;
    color: #1f2937 !important;
}

.time-input:focus {
    outline: none !important;
    border-color: #1B5D63 !important;
}

.toggle-switch {
    position: relative !important;
    width: 48px !important;
    height: 24px !important;
}

.toggle-switch input {
    opacity: 0 !important;
    width: 0 !important;
    height: 0 !important;
}

.slider {
    position: absolute !important;
    cursor: pointer !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background-color: #cbd5e1 !important;
    transition: 0.3s !important;
    border-radius: 24px !important;
}

.slider:before {
    position: absolute !important;
    content: "" !important;
    height: 18px !important;
    width: 18px !important;
    left: 3px !important;
    bottom: 3px !important;
    background-color: white !important;
    transition: 0.3s !important;
    border-radius: 50% !important;
}

.toggle-switch input:checked + .slider {
    background-color: #1B5D63 !important;
}

.toggle-switch input:checked + .slider:before {
    transform: translateX(24px) !important;
}

.special-services {
    padding-top: 24px !important;
    border-top: 1px solid #e5e7eb !important;
}

.special-services h3 {
    font-size: 1.1rem !important;
    font-weight: 700 !important;
    color: #1f2937 !important;
    margin-bottom: 8px !important;
}

.special-services-hint {
    font-size: 1.1rem !important;
    color: #6b7280 !important;
    margin-bottom: 16px !important;
}

.service-checkbox {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 12px !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 8px !important;
    margin-bottom: 12px !important;
    cursor: pointer !important;
    transition: all 0.2s !important;
}

.service-checkbox:hover {
    background: #f9fafb !important;
    border-color: #1B5D63 !important;
}

.service-checkbox:has(input:checked) .checkbox-text {
    color: #1B5D63 !important;
    font-weight: 600 !important;
}

/* PERFIL PAGE - Edit Public Profile */
.perfil-page {
    background: transparent !important;
}

.perfil-layout {
    display: grid !important;
    grid-template-columns: 2fr 1fr !important;
    gap: 32px !important;
}

.perfil-form-section {
    background: white !important;
    border-radius: 20px !important;
    padding: 40px !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06) !important;
    border: 1px solid #e5e7eb !important;
}

.perfil-form-section h2 {
    font-size: 1.65rem !important;
    font-weight: 700 !important;
    color: #1B5D63 !important;
    margin-bottom: 28px !important;
    font-family: inherit !important;
    letter-spacing: -0.02em !important;
}

.clinic-profile-form .form-group {
    margin-bottom: 24px !important;
}

.clinic-profile-form label {
    display: flex !important;
    font-weight: 600 !important;
    color: #374151 !important;
    margin-bottom: 10px !important;
    font-size: 1.35rem !important;
    font-family: inherit !important;
}

.clinic-profile-form .form-input,
.clinic-profile-form .form-textarea {
    font-size: 1.35rem !important;
    font-family: inherit !important;
    margin: 0 !important;
}

.form-input {
    width: 100% !important;
    padding: 14px 18px !important;
    border: 2px solid #e5e7eb !important;
    border-radius: 12px !important;
    font-size: 1.35rem !important;
    color: #1f2937 !important;
    transition: all 0.2s !important;
}

.form-input:focus {
    outline: none !important;
    border-color: #1B5D63 !important;
    box-shadow: 0 0 0 4px rgba(27, 93, 99, 0.12) !important;
}

.form-input[readonly] {
    background: #f9fafb !important;
    color: #6b7280 !important;
}

.form-textarea {
    width: 100% !important;
    padding: 14px 18px !important;
    border: 2px solid #e5e7eb !important;
    border-radius: 12px !important;
    font-size: 1.35rem !important;
    color: #1f2937 !important;
    font-family: inherit !important;
    resize: vertical !important;
    min-height: 100px !important;
}

.form-textarea:focus {
    outline: none !important;
    border-color: #1B5D63 !important;
    box-shadow: 0 0 0 4px rgba(27, 93, 99, 0.12) !important;
}

.checkbox-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)) !important;
    gap: 12px !important;
}

.checkbox-label {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 12px !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    transition: all 0.2s !important;
}

.checkbox-label:hover {
    background: #f9fafb !important;
    border-color: #1B5D63 !important;
}

.checkbox-label input[type="checkbox"] {
    width: 18px !important;
    height: 18px !important;
    cursor: pointer !important;
}

.checkbox-label input[type="checkbox"]:checked + span {
    color: #1B5D63 !important;
    font-weight: 600 !important;
}

.perfil-preview-section {
    display: flex !important;
    flex-direction: column !important;
    gap: 16px !important;
}

.publish-btn {
    padding: 14px 32px !important;
    background: #16a34a !important;
    color: white !important;
    border: none !important;
    border-radius: 12px !important;
    font-weight: 700 !important;
    font-size: 1rem !important;
    cursor: pointer !important;
    transition: all 0.2s !important;
    width: 100% !important;
}

.publish-btn:hover {
    background: #15803d !important;
    transform: translateY(-1px) !important;
}

.preview-card {
    background: white !important;
    border-radius: 16px !important;
    padding: 24px !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1) !important;
}

.preview-card h3 {
    font-size: 1.1rem !important;
    font-weight: 700 !important;
    color: #1f2937 !important;
    margin-bottom: 16px !important;
}

.preview-image {
    width: 100% !important;
    aspect-ratio: 16/9 !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    margin-bottom: 16px !important;
    background: #f3f4f6 !important;
}

.preview-image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}

.preview-placeholder {
    width: 100% !important;
    height: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 3rem !important;
}

.preview-info h4 {
    font-size: 1.1rem !important;
    font-weight: 700 !important;
    color: #1f2937 !important;
    margin-bottom: 8px !important;
}

.preview-location {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    color: #6b7280 !important;
    font-size: 1.2rem !important;
    margin-bottom: 12px !important;
}

.preview-tags {
    display: flex !important;
    gap: 8px !important;
    flex-wrap: wrap !important;
}

.preview-tag {
    padding: 4px 12px !important;
    background: #f3f4f6 !important;
    color: #4b5563 !important;
    border-radius: 12px !important;
    font-size: 1rem !important;
    font-weight: 500 !important;
}

/* STATS PAGE */
.stats-page {
    background: transparent !important;
}

.stats-section {
    background: white !important;
    border-radius: 16px !important;
    padding: 32px !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1) !important;
}

.stats-section h3 {
    font-size: 1.5rem !important;
    font-weight: 700 !important;
    color: #1f2937 !important;
    margin-bottom: 32px !important;
}

.stats-subsection {
    margin-bottom: 48px !important;
}

.stats-subsection:last-child {
    margin-bottom: 0 !important;
}

.stats-subsection h4 {
    font-size: 1.1rem !important;
    font-weight: 700 !important;
    color: #1f2937 !important;
    margin-bottom: 20px !important;
}

.chart-container {
    margin-bottom: 24px !important;
}

.bar-chart {
    display: flex !important;
    align-items: flex-end !important;
    gap: 8px !important;
    height: 120px !important;
    padding: 16px 0 !important;
}

.bar {
    flex: 1 !important;
    background: #e5e7eb !important;
    border-radius: 4px 4px 0 0 !important;
    min-height: 10px !important;
    transition: all 0.3s !important;
}

.bar:hover {
    background: #1B5D63 !important;
}

.chart-stats {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
}

.stat-value-large {
    font-size: 2rem !important;
    font-weight: 700 !important;
    color: #1f2937 !important;
}

.stat-growth {
    padding: 4px 12px !important;
    border-radius: 12px !important;
    font-size: 1.2rem !important;
    font-weight: 600 !important;
}

.stat-growth.positive {
    background: #dcfce7 !important;
    color: #16a34a !important;
}

.ratio-display {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 16px !important;
}

.circular-progress {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.progress-ring {
    transform: rotate(-90deg) !important;
}

.progress-ring-circle {
    fill: none !important;
    stroke-linecap: round !important;
}

.progress-ring-progress {
    fill: none !important;
    stroke-linecap: round !important;
    transition: stroke-dashoffset 0.3s !important;
}

.progress-text {
    position: absolute !important;
    font-size: 1.5rem !important;
    font-weight: 700 !important;
    color: #1f2937 !important;
}

.ratio-description {
    text-align: center !important;
    color: #6b7280 !important;
    max-width: 300px !important;
}

/* RESPONSIVE */
@media (max-width: 1024px) {
    .activity-sections {
        grid-template-columns: 1fr !important;
    }
    
    .perfil-layout {
        grid-template-columns: 1fr !important;
    }
    
    .chats-layout {
        grid-template-columns: 1fr !important;
    }
}

@media (max-width: 768px) {
    /* Overlay en móvil (visible solo cuando sidebar abierto) */
    .clinic-sidebar-overlay {
        display: block !important;
        pointer-events: none !important;
    }
    
    /* Botón abrir menú visible en móvil */
    .clinic-sidebar-toggle {
        display: flex !important;
    }
    
    /* Sidebar oculto por defecto (fuera de pantalla) */
    .clinic-sidebar {
        width: 260px !important;
        transform: translateX(-100%) !important;
    }
    
    .clinic-main-content {
        margin-left: 0 !important;
        max-width: 100% !important;
        padding: 16px !important;
    }
    
    /* Ocultar textos del sidebar cuando está colapsado (por si se usa sin JS) */
    .sidebar-header h3,
    .sidebar-nav .nav-item span {
        display: none !important;
    }
    
    /* Cuando el sidebar está abierto */
    .clinic-dashboard-wrapper.clinic-sidebar-open .clinic-sidebar {
        transform: translateX(0) !important;
    }
    .clinic-dashboard-wrapper.clinic-sidebar-open .sidebar-header h3,
    .clinic-dashboard-wrapper.clinic-sidebar-open .sidebar-nav .nav-item span {
        display: block !important;
    }
    .clinic-dashboard-wrapper.clinic-sidebar-open .clinic-sidebar-overlay {
        display: block !important;
        opacity: 1 !important;
        pointer-events: auto !important;
    }
    
    /* Botón cerrar visible dentro del sidebar en móvil */
    .clinic-sidebar-close {
        display: flex !important;
    }
    
    .calendar-header,
    .calendar-dates,
    .day-slots {
        grid-template-columns: repeat(7, 1fr) !important;
    }
}

/* ============================================
   RESPONSIVE - Dashboard principal (dashboard-main.php)
   ============================================ */
@media (max-width: 1024px) {
    .profile-completion-header {
        flex-wrap: wrap !important;
        gap: 20px !important;
    }
    
    .profile-completion-btn {
        align-self: flex-start !important;
    }
    
    .metrics-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

@media (max-width: 768px) {
    .profile-completion-card {
        padding: 16px 20px !important;
    }
    
    .profile-completion-header {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 16px !important;
    }
    
    .profile-completion-circle {
        width: 60px !important;
        height: 60px !important;
    }
    
    .profile-completion-pct {
        font-size: 1.25rem !important;
    }
    
    .profile-completion-info h3 {
        font-size: 1.15rem !important;
    }
    
    .profile-completion-info > p,
    .profile-missing-label,
    .profile-missing-list {
        font-size: 1.1rem !important;
    }
    
    .profile-completion-btn {
        width: 100% !important;
        text-align: center !important;
        padding: 12px 20px !important;
    }
    
    .metrics-grid {
        grid-template-columns: 1fr !important;
        gap: 12px !important;
        margin-bottom: 24px !important;
    }
    
    .metric-card {
        padding: 18px 20px !important;
    }
    
    .metric-icon {
        width: 48px !important;
        height: 48px !important;
    }
    
    .metric-label {
        font-size: 1.2rem !important;
    }
    
    .metric-value {
        font-size: 1.9rem !important;
    }
    
    .activity-sections {
        gap: 16px !important;
    }
    
    .activity-card {
        padding: 20px !important;
    }
    
    .activity-header h3 {
        font-size: 1.25rem !important;
    }
    
    .view-all-link {
        font-size: 1.1rem !important;
    }
    
    .clinic-info-grid {
        grid-template-columns: 1fr !important;
        gap: 16px !important;
        margin-top: 20px !important;
    }
    
    .info-card {
        padding: 20px !important;
    }
    
    .info-card-header h3 {
        font-size: 1rem !important;
    }
}

@media (max-width: 480px) {
    .profile-completion-card {
        padding: 14px 16px !important;
        margin-bottom: 20px !important;
    }
    
    .profile-completion-circle {
        width: 54px !important;
        height: 54px !important;
    }
    
    .profile-completion-pct {
        font-size: 1.1rem !important;
    }
    
    .profile-completion-info h3 {
        font-size: 1.05rem !important;
    }
    
    .profile-missing-list {
        display: block !important;
    }
    
    .profile-missing-list li {
        display: block !important;
    }
    
    .profile-missing-list li:not(:last-child)::after {
        content: '' !important;
    }
    
    .header-title-section h1 {
        font-size: 1.75rem !important;
    }
    
    .clinic-subtitle {
        font-size: 1rem !important;
    }
    
    .metric-card {
        padding: 16px !important;
    }
    
    .metric-value {
        font-size: 1.7rem !important;
    }
    
    .activity-header {
        flex-wrap: wrap !important;
        gap: 8px !important;
    }
    
    .activity-header h3 {
        font-size: 1.15rem !important;
    }
    
    .service-item,
    .animal-item {
        padding: 8px 12px !important;
        font-size: 0.9rem !important;
    }
    .clinic-sidebar .sidebar-logo{
        padding: 5px !important;
    }
    .sidebar-nav .nav-item{
        padding: 12px !important;
    }
}

/* ============================================
   RESPONSIVE - Perfil y Horarios (.perfil-form-section, .opening-hours-form)
   ============================================ */
@media (max-width: 768px) {
    .perfil-form-section {
        padding: 24px 20px !important;
        border-radius: 16px !important;
    }
    
    .perfil-form-section h2 {
        font-size: 1.4rem !important;
        margin-bottom: 20px !important;
    }
    
    .clinic-profile-form .form-group {
        margin-bottom: 20px !important;
    }
    
    .clinic-profile-form label {
        font-size: 1.2rem !important;
    }
    
    .clinic-profile-form .form-input,
    .clinic-profile-form .form-textarea {
        font-size: 1.2rem !important;
    }
    
    .form-input {
        padding: 12px 14px !important;
        font-size: 1.2rem !important;
    }
    
    .form-textarea {
        padding: 12px 14px !important;
        font-size: 1.2rem !important;
        min-height: 80px !important;
    }
    
    .clinic-profile-form .location-field-group .location-input-wrap {
        display: flex !important;
        flex-wrap: wrap !important;
        gap: 8px !important;
    }
    
    .clinic-profile-form .location-input-wrap .form-input {
        flex: 1 1 100% !important;
        min-width: 0 !important;
    }
    
    .clinic-profile-form .btn-current-location {
        flex-shrink: 0 !important;
    }
    
    .clinic-profile-form .type-checkboxes,
    .clinic-profile-form .referral-checkboxes {
        display: flex !important;
        flex-wrap: wrap !important;
        gap: 10px !important;
    }
    
    .clinic-profile-form .prices-grid {
        padding: 14px !important;
        border-radius: 10px !important;
    }
    
    .clinic-profile-form .prices-loader {
        font-size: 1rem !important;
        padding: 12px !important;
    }
    
    .clinic-profile-form .prices-loader .loader-spinner {
        width: 20px !important;
        height: 20px !important;
    }
    
    .clinic-profile-form .prices-header {
        grid-template-columns: 1fr 1fr minmax(70px, 90px) 40px !important;
        gap: 8px !important;
        font-size: 0.95rem !important;
        padding: 8px 0 !important;
        margin-bottom: 10px !important;
    }
    
    .clinic-profile-form .prices-header span {
        min-width: 0 !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }
    
    .clinic-profile-form .prices-rows .prices-row {
        grid-template-columns: 1fr 1fr minmax(70px, 90px) 40px !important;
        gap: 8px !important;
        margin-bottom: 10px !important;
        align-items: center !important;
    }
    
    .clinic-profile-form .prices-rows .prices-row .price-service-select,
    .clinic-profile-form .prices-rows .prices-row .price-animal-select {
        min-width: 0 !important;
        font-size: 1rem !important;
        padding: 10px 8px !important;
    }
    
    .clinic-profile-form .prices-rows .prices-row input[name="price_value[]"] {
        font-size: 1rem !important;
        padding: 10px 8px !important;
        min-width: 0 !important;
    }
    
    .clinic-profile-form .prices-rows .prices-row .btn-remove-price {
        width: 36px !important;
        height: 36px !important;
        padding: 0 !important;
        font-size: 1.5rem !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        flex-shrink: 0 !important;
    }
    
    .clinic-profile-form .btn-add-price {
        width: 100% !important;
        padding: 12px 14px !important;
        font-size: 1rem !important;
        margin-top: 10px !important;
    }
    
    .clinic-profile-form .gallery-upload-zone {
        padding: 20px 16px !important;
    }
    
    .clinic-profile-form .gallery-preview {
        gap: 10px !important;
    }
    
    .clinic-profile-form .gallery-thumb {
        min-width: 80px !important;
        max-width: 80px !important;
    }
    
    .clinic-profile-form .services-autocomplete-input,
    .clinic-profile-form .animals-autocomplete-input {
        font-size: 1.1rem !important;
        padding: 10px 14px !important;
    }
    
    .clinic-profile-form .service-tag,
    .clinic-profile-form .animal-tag {
        font-size: 1rem !important;
        padding: 6px 10px !important;
    }
    
    .publish-btn {
        padding: 12px 24px !important;
        font-size: 1rem !important;
    }
    
    .opening-hours-form {
        padding: 24px 20px !important;
        border-radius: 16px !important;
    }
    
    .opening-hours-form .hours-row {
        flex-wrap: wrap !important;
        gap: 12px !important;
    }
    
    .opening-hours-form .day-name {
        width: 100% !important;
        min-width: 0 !important;
    }
    
    .opening-hours-form .hours-inputs {
        flex-wrap: wrap !important;
    }
}

@media (max-width: 480px) {
    .perfil-form-section {
        padding: 20px 16px !important;
        border-radius: 14px !important;
    }
    
    .perfil-form-section h2 {
        font-size: 1.25rem !important;
        margin-bottom: 16px !important;
    }
    
    .clinic-profile-form .form-group {
        margin-bottom: 18px !important;
    }
    
    .clinic-profile-form label {
        font-size: 1.1rem !important;
    }
    
    .clinic-profile-form .form-input,
    .clinic-profile-form .form-textarea {
        font-size: 16px !important;
    }
    
    .form-input {
        padding: 12px 14px !important;
        font-size: 16px !important;
    }
    
    .form-textarea {
        padding: 12px 14px !important;
        font-size: 16px !important;
        min-height: 70px !important;
    }
    
    .clinic-profile-form .type-checkboxes,
    .clinic-profile-form .referral-checkboxes {
        flex-direction: column !important;
        align-items: flex-start !important;
    }
    
    .clinic-profile-form .prices-grid {
        padding: 12px !important;
        border-radius: 10px !important;
    }
    
    /* Móvil: layout 2x2 (Service | Animal arriba, Price | Botón abajo) */
    .clinic-profile-form .prices-header {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        grid-template-rows: auto auto !important;
        gap: 6px 10px !important;
        font-size: 0.85rem !important;
        font-weight: 600 !important;
        color: #374151 !important;
        padding: 8px 0 !important;
        margin-bottom: 6px !important;
    }
    
    .clinic-profile-form .prices-header span:nth-child(1) {
        grid-column: 1 !important;
        grid-row: 1 !important;
    }
    
    .clinic-profile-form .prices-header span:nth-child(2) {
        grid-column: 2 !important;
        grid-row: 1 !important;
    }
    
    .clinic-profile-form .prices-header span:nth-child(3) {
        grid-column: 1 !important;
        grid-row: 2 !important;
    }
    
    .clinic-profile-form .prices-header span:nth-child(4) {
        grid-column: 2 !important;
        grid-row: 2 !important;
        visibility: hidden !important;
    }
    
    .clinic-profile-form .prices-rows .prices-row {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        grid-template-rows: auto auto !important;
        gap: 8px 10px !important;
        margin-bottom: 12px !important;
        padding: 12px !important;
        background: #fff !important;
        border-radius: 8px !important;
        border: 1px solid #e5e7eb !important;
        align-items: center !important;
    }
    
    .clinic-profile-form .prices-rows .prices-row .price-service-select {
        grid-column: 1 !important;
        grid-row: 1 !important;
        min-width: 0 !important;
        font-size: 16px !important;
        padding: 10px 10px !important;
    }
    
    .clinic-profile-form .prices-rows .prices-row .price-animal-select {
        grid-column: 2 !important;
        grid-row: 1 !important;
        min-width: 0 !important;
        font-size: 16px !important;
        padding: 10px 10px !important;
    }
    
    .clinic-profile-form .prices-rows .prices-row input[name="price_value[]"] {
        grid-column: 1 !important;
        grid-row: 2 !important;
        min-width: 0 !important;
        font-size: 16px !important;
        padding: 10px 10px !important;
    }
    
    .clinic-profile-form .prices-rows .prices-row .btn-remove-price {
        grid-column: 2 !important;
        grid-row: 2 !important;
        justify-self: start !important;
        width: 40px !important;
        height: 40px !important;
        padding: 0 !important;
        font-size: 1.5rem !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        flex-shrink: 0 !important;
    }
    
    .clinic-profile-form .btn-add-price {
        width: 100% !important;
        padding: 12px 14px !important;
        font-size: 1rem !important;
        margin-top: 8px !important;
    }
    
    .clinic-profile-form .prices-loader {
        font-size: 0.95rem !important;
    }
    
    .clinic-profile-form .gallery-upload-zone {
        padding: 16px 12px !important;
    }
    
    .clinic-profile-form .upload-text {
        font-size: 1rem !important;
    }
    
    .clinic-profile-form .gallery-thumb {
        min-width: 70px !important;
        max-width: 70px !important;
    }
    
    .clinic-profile-form .services-autocomplete-input,
    .clinic-profile-form .animals-autocomplete-input {
        font-size: 16px !important;
        padding: 10px 12px !important;
    }
    
    .clinic-profile-form .service-tag,
    .clinic-profile-form .animal-tag {
        font-size: 0.95rem !important;
        padding: 5px 8px !important;
    }
    
    .opening-hours-form {
        padding: 20px 16px !important;
    }
    
    .opening-hours-form .hours-list {
        margin-bottom: 24px !important;
    }
    
    .opening-hours-form .hours-row {
        padding: 12px 0 !important;
    }
    
    .opening-hours-form .day-name {
        font-size: 1rem !important;
    }
    
    .opening-hours-form .time-input {
        padding: 6px 10px !important;
        font-size: 1rem !important;
    }
}

/* ============================================
   RESPONSIVE - Agenda (agenda.php)
   ============================================ */
@media (max-width: 1200px) {
    .agenda-layout {
        grid-template-columns: 1fr !important;
        height: auto !important;
    }
    
    .day-details-panel {
        max-height: 500px !important;
    }
}

@media (max-width: 768px) {
    .agenda-page .agenda-layout {
        gap: 16px !important;
    }
    
    .agenda-page .calendar-view {
        padding: 16px !important;
    }
    
    .agenda-page .calendar-header-nav {
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 12px !important;
        margin-bottom: 16px !important;
    }
    
    .agenda-page .calendar-header-nav h2 {
        font-size: 1.5rem !important;
        text-align: center !important;
    }
    
    .agenda-page .calendar-nav-buttons {
        justify-content: center !important;
    }
    
    .agenda-page .nav-btn {
        padding: 8px 14px !important;
        font-size: 1rem !important;
    }
    
    .agenda-page .month-calendar {
        padding: 12px !important;
    }
    
    .agenda-page .calendar-weekdays {
        gap: 4px !important;
    }
    
    .agenda-page .weekday-label {
        font-size: 0.9rem !important;
        padding: 6px 4px !important;
    }
    
    .agenda-page .calendar-days-grid {
        gap: 6px !important;
    }
    
    .agenda-page .calendar-day {
        padding: 6px !important;
        border-radius: 10px !important;
    }
    
    .agenda-page .day-number {
        font-size: 1rem !important;
    }
    
    .agenda-page .bookings-badge {
        width: 20px !important;
        height: 20px !important;
        font-size: 0.7rem !important;
    }
    
    .agenda-page .day-details-panel {
        padding: 20px !important;
    }
    
    .agenda-page .panel-header {
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 12px !important;
        margin-bottom: 16px !important;
    }
    
    .agenda-page .panel-header h3 {
        font-size: 1.2rem !important;
    }
    
    .agenda-page .block-slot-btn {
        width: 100% !important;
        justify-content: center !important;
        padding: 10px 14px !important;
        font-size: 1rem !important;
    }
    
    .agenda-page .booking-card {
        padding: 14px !important;
    }
    
    .agenda-page .booking-time-badge {
        font-size: 1.1rem !important;
    }
    
    .agenda-page .client-data h4 {
        font-size: 1.15rem !important;
    }
    
    .agenda-page .booking-actions {
        flex-wrap: wrap !important;
    }
    
    .agenda-page .action-btn {
        min-width: calc(50% - 4px) !important;
    }
    
    .agenda-page .modal-content {
        width: 95% !important;
        max-width: none !important;
    }
    
    .agenda-page .modal-header,
    .agenda-page .modal-body {
        padding: 16px 20px !important;
    }
    
    .agenda-page .modal-footer {
        padding: 14px 20px !important;
        flex-wrap: wrap !important;
    }
}

@media (max-width: 480px) {
    .agenda-page .calendar-view {
        padding: 12px !important;
    }
    
    .agenda-page .calendar-header-nav h2 {
        font-size: 1.35rem !important;
    }
    
    .agenda-page .month-calendar {
        padding: 10px !important;
    }
    
    .agenda-page .weekday-label {
        font-size: 0.8rem !important;
    }
    
    .agenda-page .calendar-days-grid {
        gap: 4px !important;
    }
    
    .agenda-page .calendar-day {
        padding: 4px !important;
        min-height: 36px !important;
        aspect-ratio: auto !important;
    }
    
    .agenda-page .day-number {
        font-size: 0.9rem !important;
    }
    
    .agenda-page .day-details-panel {
        padding: 16px !important;
    }
    
    .agenda-page .panel-header h3 {
        font-size: 1.1rem !important;
    }
    
    .agenda-page .day-bookings-list {
        gap: 10px !important;
    }
    
    .agenda-page .booking-card {
        padding: 12px !important;
    }
    
    .agenda-page .booking-client-info {
        flex-wrap: wrap !important;
    }
    
    .agenda-page .booking-actions {
        flex-direction: column !important;
    }
    
    .agenda-page .action-btn {
        min-width: 100% !important;
    }
    
    .agenda-page .modal-content {
        width: 100% !important;
        margin: 16px !important;
        border-radius: 12px !important;
    }
    
    .agenda-page .modal-header h3 {
        font-size: 1.2rem !important;
    }
    
    .agenda-page .form-input,
    .agenda-page .form-textarea {
        font-size: 16px !important;
    }
}
