/* Main layout, sidebar, headers, cards, forms, modals, notifications, print styles... */
/* This file contains all shared styles for the application. */

:root {
    /* Updated modern color palette inspired by Soft UI Dashboard */
    --primary-color: #cb0c9f; /* Pink-purple */
    --primary-hover: #a80a84;
    --primary-light: #f7e6f3; /* Light pink */
    --secondary-color: #67748e; /* Grayish blue */
    --success-color: #2dce89; /* Green */
    --warning-color: #fb6340; /* Orange-red */
    --danger-color: #f5365c; /* Red */
    --info-color: #11cdef; /* Light blue */
    --background-color: #f8f9fa; /* Light gray background */
    --content-bg: #ffffff; /* White content background */
    --sidebar-bg: #ffffff; /* White sidebar */
    --header-bg: #ffffff; /* White header */
    --card-bg: #ffffff; /* White card background */
    --text-color: #344767; /* Dark grayish blue text */
    --text-light: #67748e; /* Lighter grayish blue text */
    --border-color: #e9ecef; /* Light border */
    
    /* Updated modern shadows for Soft UI look */
    --shadow-sm: 0 0 0 transparent; /* Soft UI uses subtle box-shadow with blur and spread */
    --shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -2px rgba(0, 0, 0, 0.06); /* Default shadow */
    --shadow-md: 0 7px 14px 0 rgba(0, 0, 0, 0.1), 0 3px 6px 0 rgba(0, 0, 0, 0.08); /* Medium shadow for cards */
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -4px rgba(0, 0, 0, 0.05); /* Larger shadow */
    --shadow-inset: inset 0 2px 4px rgba(0,0,0,0.06); /* For pressed states */
    --shadow-soft-ui: 0 8px 24px rgba(50, 50, 93, 0.1), 0 3px 6px rgba(0, 0, 0, 0.08); /* Typical Soft UI card shadow */
    
    /* Refined spacing (using rem for scalability) */
    --spacing-xs: 0.25rem;
    --spacing-sm: 0.5rem;
    --spacing-md: 0.8rem; 
    --spacing-lg: 1.25rem;
    --spacing-xl: 2rem;
    
    /* Refined border radius - Soft UI is very rounded */
    --radius-sm: 0.5rem; /* 8px */
    --radius-md: 0.75rem; /* 12px */
    --radius-lg: 1rem; /* 16px */
    --radius-xl: 1.25rem; /* 20px */
    
    /* Transitions */
    --transition-fast: 150ms ease-in-out;
    --transition-normal: 250ms ease-in-out;
    --transition-slow: 400ms ease-in-out;
    
    /* NEW: Specific colors for themed backgrounds */
    --warning-color-light-bg: #fffbeb; /* Background color for warning info boxes */
    --warning-color-light-border: #fbbf24; /* Border color for warning info boxes */
    --info-color-light-bg: #f0f9ff; /* Background color for info boxes */
    --info-color-light-border: #0ea5e9; /* Border color for info boxes */
    --danger-color-light: #fef2f2; /* Light red for danger zones */
}

/* Dark mode variables for Soft UI aesthetic */
[data-theme="dark"] {
    --primary-color: #e91e63; /* Brighter pink for dark mode */
    --primary-hover: #c41852;
    --primary-light: #442a3a;
    --secondary-color: #adb5bd; /* Lighter gray */
    --success-color: #48bb78;
    --warning-color: #ed8936;
    --danger-color: #f05252;
    --info-color: #36a3b8;
    --background-color: #1a202c; /* Dark background */
    --content-bg: #2d3748; /* Darker content background */
    --sidebar-bg: #2d3748; /* Dark sidebar */
    --header-bg: #2d3748; /* Dark header */
    --card-bg: #2d3748; /* Dark card background */
    --text-color: #f8f9fa; /* Light text */
    --text-light: #a0aec0; /* Lighter text */
    --border-color: #4a5568; /* Darker border */
    
    --shadow-soft-ui: 0 8px 24px rgba(0, 0, 0, 0.3), 0 3px 6px rgba(0, 0, 0, 0.2);
    --primary-light: rgba(233, 30, 99, 0.15); /* Adjusted for better contrast on dark backgrounds */

    /* NEW: Dark mode specific colors for themed backgrounds */
    --warning-color-light-bg: #4A3020; /* Darker background for warning info boxes */
    --warning-color-light-border: #D97706; /* Darker border for warning info boxes */
    --info-color-light-bg: #203A4A; /* Darker background for info boxes */
    --info-color-light-border: #0EA5E9; /* Retain strong info border */
    --danger-color-light: #4a2d3c; /* Darker red for danger zones */
}

/* Global Styles */
html {
    box-sizing: border-box;
}
*, *:before, *:after {
    box-sizing: inherit;
}
body {
    font-family: 'Inter', system-ui, -apple-system, sans-serif;
    margin: 0;
    background-color: var(--background-color);
    color: var(--text-color);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    display: flex; /* For app-container full height */
    flex-direction: column;
    min-height: 100vh;
}

/* App Layout */
.app-container {
    display: flex; 
    flex-grow: 1; /* Allow to take full height */
    height: 100vh;
    background-color: var(--background-color);
    width: 100%; 
    max-width: 100%; 
    overflow: hidden; 
}
.main-content {
    position: relative;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    background-color: var(--background-color);
    width: 100%; 
    max-width: 100%; 
    min-height: 0; /* Important for flex child */
}
.content-area {
    min-height: unset; /* Override potential min-height issues */
    width: 100%;
    max-width: 100%; 
    margin: 0 auto;
    background: var(--background-color);
    flex-grow: 1;
    overflow-y: visible;
    min-height: 0;
    padding-left: 1.25rem;
    padding-right: 1.25rem;
    padding-bottom: 1.75rem;
    padding-top: calc(64px + 0.5rem);
}
#appVersionFooter {
    text-align: center;
    width: 100%;
    color: var(--text-light);
    font-size: 0.97em;
    padding: 0.8em 0 1.1em 0;
    margin-top: 1.5em;
    background: var(--background-color);
    user-select: none;
    letter-spacing: 0.01em;
    flex-shrink: 0; /* Prevents shrinking */
}
#appVersionFooter span {
    color: var(--text-light);
}

/* Splash Screen */
.splash-screen {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: linear-gradient(195deg, #42424a, #1a1a1a);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 9999;
    color: white;
    text-align: center;
    opacity: 1;
    transition: opacity 0.5s ease-out;
}
[data-theme="dark"] .splash-screen {
    background: linear-gradient(195deg, #2d3748, #1a202c);
}
.splash-screen.fade-out {
    opacity: 0;
    pointer-events: none; 
    transition: opacity 0.5s ease-out; 
}
.splash-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    animation: fadeInScale 0.8s ease-out;
}
.logo-animation {
    width: 120px;
    height: 120px;
    margin-bottom: 1.5rem;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}
.logo-animation-circle {
    width: 100%;
    height: 100%;
    border-radius: 24px; /* More of a squircle */
    background-color: rgba(255, 255, 255, 0.1);
    position: absolute;
    animation: soft-pulse 2.5s infinite cubic-bezier(0.4, 0, 0.2, 1);
}
.logo-animation-icon {
    font-size: 50px;
    color: white;
    z-index: 1;
    animation: icon-pop-in 1.2s cubic-bezier(0.68, -0.55, 0.355, 1.55);
}
.splash-title {
    font-size: 2.5rem;
    font-weight: 700;
    margin: 0;
    letter-spacing: 0.05em;
    text-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

/* NEW Modern Spinner */
.splash-loading-spinner {
    width: 60px;
    height: 15px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 1.5rem;
}
.splash-loading-spinner .dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background-color: white;
    animation: wave 1.2s ease-in-out infinite;
}
.splash-loading-spinner .dot:nth-child(2) {
    animation-delay: 0.2s;
}
.splash-loading-spinner .dot:nth-child(3) {
    animation-delay: 0.4s;
}

.splash-message {
    margin-top: 1.5rem; /* Increased margin */
    font-size: 1.1rem;
    opacity: 0.8;
}

/* Login Screen */
.login-screen, .pending-approval-screen {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    background: url('https://demos.creative-tim.com/soft-ui-dashboard/assets/img/curved-images/curved14.jpg') no-repeat center center fixed;
    background-size: cover;
    position: relative;
    z-index: 10; /* Ensure it's above other elements if displayed */
}
.login-screen::before, .pending-approval-screen::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(195deg, rgba(73,163,241,0.6), rgba(23,43,77,0.6));
    z-index: 1;
}
[data-theme="dark"] .login-screen::before, [data-theme="dark"] .pending-approval-screen::before {
    background: linear-gradient(195deg, rgba(45,55,72,0.7), rgba(26,32,44,0.7));
}
.login-container, .pending-approval-screen .message-container {
    background: var(--content-bg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-soft-ui);
    padding: 2.5rem 1.8rem 2rem 1.8rem;
    width: 100%;
    max-width: 420px;
    min-width: 0;
    position: relative;
    text-align: center;
    animation: loginSlideIn 0.5s cubic-bezier(.87,.02,.34,1.11);
    z-index: 2;
}
[data-theme="dark"] .login-container, [data-theme="dark"] .pending-approval-screen .message-container {
    background: var(--card-bg);
    box-shadow: var(--shadow-soft-ui);
}
.login-header, .pending-approval-screen .logo {
    margin-bottom: 2.2rem;
}
.login-header .logo, .pending-approval-screen .logo {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-color);
    font-weight: 700;
    font-size: 2.2rem;
    gap: 0.6rem;
    margin-bottom: 0.6rem;
}
[data-theme="dark"] .login-header .logo, [data-theme="dark"] .pending-approval-screen .logo { color: var(--text-color); } 
.login-header .logo i, .pending-approval-screen .logo i {
    font-size: 2rem;
    color: var(--primary-color);
}
[data-theme="dark"] .login-header .logo i, [data-theme="dark"] .pending-approval-screen .logo i { color: var(--primary-color); }
.login-header h2, .pending-approval-screen h2 {
    font-size: 2rem;
    font-weight: 700;
    margin: 0 0 0.2rem 0;
    letter-spacing: -1px;
    color: var(--text-color);
}
[data-theme="dark"] .login-header h2, [data-theme="dark"] .pending-approval-screen h2 { color: var(--text-color); }
.login-header p, .pending-approval-screen p {
    font-size: 1rem;
    color: var(--text-light);
    margin-bottom: 0.5rem;
    font-weight: 400;
}
[data-theme="dark"] .login-header p, [data-theme="dark"] .pending-approval-screen p { color: var(--text-light); }

.login-form {
    margin-bottom: 1.6rem;
    text-align: left;
}
.login-form .form-group {
    margin-bottom: 1.5rem;
}
.login-form .form-label {
    color: var(--text-color);
    font-size: 0.9rem;
    font-weight: 600;
    margin-bottom: 0.3rem;
    display: block;
}
[data-theme="dark"] .login-form .form-label { color: var(--text-color); }
.login-form .form-input {
    font-size: 1rem;
    padding: 0.7rem 0.9rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    width: 100%;
    background: var(--content-bg);
    color: var(--text-color);
    margin-bottom: 0.25rem;
    transition: all 0.2s ease;
}
[data-theme="dark"] .login-form .form-input {
    background: var(--background-color);
    border-color: var(--border-color);
    color: var(--text-color);
}
.login-form .form-input:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(203, 12, 159, 0.1);
}
[data-theme="dark"] .login-form .form-input:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(233, 30, 99, 0.1);
}
.login-form .form-help {
    color: var(--text-light);
    font-size: 0.85rem;
    margin-top: 0.2rem;
}
[data-theme="dark"] .form-help { color: var(--text-light); }
.login-form .input-error-message {
    color: var(--danger-color);
    background: #fdf3f5;
    border-radius: var(--radius-sm);
    margin-top: 0.3rem;
    padding: 0.4rem 0.8rem;
    font-size: 0.9rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
/* Input Group for Date Range Picker */
.input-group {
    display: flex;
    align-items: center;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    overflow: hidden;
    transition: all 0.2s ease;
    background: var(--content-bg);
}
[data-theme="dark"] .input-group {
    background: var(--background-color);
}
.input-group .form-input {
    border: none;
    border-radius: 0;
    padding: 0.65rem 0.5rem;
    background: transparent;
}
.input-group .form-input:focus {
    box-shadow: none;
}
.input-group-text {
    padding: 0 0.75rem;
    background: var(--background-color);
    color: var(--text-light);
}
[data-theme="dark"] .input-group-text {
    background: var(--content-bg);
}
/* Modern Datepicker Styles */
.datepicker {
    background-color: var(--content-bg);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-md);
    color: var(--text-color);
    font-size: 0.95rem;
}
.datepicker-picker .datepicker-controls .button {
    background-color: transparent;
    border: none;
    color: var(--text-color);
    font-size: 1rem;
    padding: 0.5rem;
    border-radius: var(--radius-sm);
    transition: background-color 0.15s ease;
    cursor: pointer;
}
.datepicker-picker .datepicker-controls .button:hover:not(:disabled) {
    background-color: var(--primary-light);
    color: var(--primary-color);
}
.datepicker-picker .datepicker-controls .datepicker-title {
    color: var(--text-color);
    font-weight: 600;
}
.datepicker-grid {
    padding: 0.5rem;
}
.datepicker-cell {
    color: var(--text-color);
    border-radius: var(--radius-sm);
    transition: background-color 0.15s ease;
    padding: 0.4rem 0.2rem;
}
.datepicker-cell.day, .datepicker-cell.month, .datepicker-cell.year {
    height: 32px;
    line-height: 32px;
    cursor: pointer;
}
.datepicker-cell:hover:not(.disabled):not(.selected),
.datepicker-cell.month:hover:not(.disabled):not(.selected),
.datepicker-cell.year:hover:not(.disabled):not(.selected) {
    background-color: var(--primary-light);
    color: var(--primary-color);
}
.datepicker-cell.selected {
    background-color: var(--primary-color);
    color: white;
}
.datepicker-cell.selected:hover {
    background-color: var(--primary-hover);
    color: white;
}
.datepicker-cell.today {
    border: 1px solid #5a0000;
    background-color: #fce6eb;
}
[data-theme="dark"] .datepicker-cell.today {
    border: 1px solid #4a333f;
    background-color: #4a333f;
}
.datepicker-cell.disabled {
    color: var(--text-light);
    opacity: 0.6;
    cursor: not-allowed;
    background-color: transparent;
}
/* Dark mode specific overrides for datepicker to ensure good contrast */
[data-theme="dark"] .datepicker {
    background-color: var(--card-bg);
    border-color: var(--border-color);
    color: var(--text-color);
}
[data-theme="dark"] .datepicker-picker .datepicker-controls .button {
    color: var(--text-color);
}
[data-theme="dark"] .datepicker-picker .datepicker-controls .button:hover:not(:disabled) {
    background-color: var(--primary-light);
    color: var(--text-color);
}
[data-theme="dark"] .datepicker-picker .datepicker-controls .datepicker-title {
    color: var(--text-color);
}
[data-theme="dark"] .datepicker-grid {
    padding: 0.5rem;
}
[data-theme="dark"] .datepicker-cell {
    color: var(--text-color);
}
[data-theme="dark"] .datepicker-cell.day:hover:not(.disabled):not(.selected),
[data-theme="dark"] .datepicker-cell.month:hover:not(.disabled):not(.selected),
[data-theme="dark"] .datepicker-cell.year:hover:not(.disabled):not(.selected) {
    background-color: var(--primary-light); /* Dark mode's primary-light */
    color: var(--text-color); /* Keep text color readable */
}
[data-theme="dark"] .datepicker-cell.selected {
    background-color: var(--primary-color); /* Dark mode's primary color */
    color: white;
}
[data-theme="dark"] .datepicker-cell.selected:hover {
    background-color: var(--primary-hover); /* Dark mode's primary-hover */
    color: white;
}
[data-theme="dark"] .datepicker-cell.today {
    border-color: var(--primary-color); /* Dark mode's primary color */
    color: var(--text-color);
}
[data-theme="dark"] .datepicker-cell.disabled {
    color: var(--text-light);
}
/* Ensure proper spacing for the input group with datepicker */
.input-group .form-input[type="text"][name="checkIn"],
.input-group .form-input[type="text"][name="checkOut"] {
    flex: 1; /* Allow inputs to grow within the group */
    min-width: 80px; /* Ensure they don't get too small */
}

/* Modals */
.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 1000;
    padding: 1rem;
}
.modal {
    background: var(--content-bg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-soft-ui);
    width: 100vw;
    max-width: 820px;
    min-width: 0;
    min-height: 0;
    max-height: 94vh;
    height: auto;
    display: flex;
    flex-direction: column;
    animation: modalSlideIn 0.3s ease-out;
    margin: auto;
}
[data-theme="dark"] .modal {
    background: var(--card-bg);
    box-shadow: var(--shadow-soft-ui);
}
.modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.9rem 1.2rem;
    border-bottom: 1px solid var(--border-color);
}
[data-theme="dark"] .modal-header {
    border-bottom: 1px solid var(--border-color);
}
.modal-title {
    font-size: 1.25rem;
    font-weight: 600;
    margin: 0;
    color: var(--text-color);
}
[data-theme="dark"] .modal-title { color: var(--text-color); }
.modal-close {
    background: none;
    border: none;
    font-size: 1.5rem;
    color: var(--text-light);
    cursor: pointer;
}
[data-theme="dark"] .modal-close { color: var(--text-light); }
.modal-body {
    padding: 1.2rem;
    overflow-y: auto;
}
.modal-footer {
    padding: 0.9rem 1.2rem;
    border-top: 1px solid var(--border-color);
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
}
[data-theme="dark"] .modal-footer {
    border-top: 1px solid var(--border-color);
}

/* Notifications */
.notification-container {
    position: fixed;
    top: 1.5rem; /* Default top position on desktop */
    right: 1.5rem; /* Default right position on desktop */
    z-index: 9999;
    display: flex;
    flex-direction: column-reverse; /* Stacks new notifications above old ones */
    gap: 0.75rem;
    pointer-events: none; /* Allows clicks through the container, but not on individual notifications */
    width: 100%; /* For mobile full width */
    max-width: 420px; /* Default desktop max width */
    align-items: flex-end; /* Aligns notifications to the right within the container */
}

/* Specific styling for when it should appear below the header and near the icon */
.notification-container.below-header {
    top: calc(64px + 0.5rem); /* Below header (64px height), slightly below the actual header-actions bar */
    right: 1.5rem; /* Align to the right edge of the header actions */
    left: unset; /* Remove left constraint if it was set for centering */
    margin: unset; /* Remove margin auto if it was set for centering */
    max-width: 420px; /* Keep consistent with default notification width */
    align-items: flex-end; /* Still align notifications to the right inside the container */
}

@media (max-width: 900px) {
  .notification-container {
      /* Keep top, left, right for full mobile width */
      top: 55px; /* Adjust top for smaller header */
      left: 10px;
      right: 10px;
      width: auto;
      max-width: none;
      align-items: center; /* Center notifications on mobile */
  }
  .notification-container.below-header {
    top: calc(48px + 0.5rem); /* Adjust for smaller mobile header (48px height) */
    left: 10px;
    right: 10px;
    max-width: 97%;
    align-items: center;
  }
}
.notification {
    display: flex;
    align-items: flex-start;
    padding: 0.8rem 1rem;
    border-radius: var(--radius-lg);
    background: var(--content-bg);
    border: none;
    margin-bottom: 0.75rem;
    animation: slideInBelowHeader 0.38s cubic-bezier(.28,.53,.47,1.17);
    box-shadow: var(--shadow-md);
    min-width: 260px;
    min-height: 50px;
    pointer-events: all;
    position: relative;
    max-width: 98vw;
    transition: box-shadow 0.15s;
    overflow: visible;
}
[data-theme="dark"] .notification {
    background: var(--card-bg);
}
.notification.success { background-color: #e6f7ef; color: #2dce89; }
.notification.error { background-color: #fce6eb; color: #f5365c; }
.notification.warning { background-color: #fff0e6; color: #fb6340; }
.notification.info { background-color: #e6f3fa; color: #11cdef; }
[data-theme="dark"] .notification.success { background-color: #48bb78; color: white; }
[data-theme="dark"] .notification.error { background-color: #f05252; color: white; }
[data-theme="dark"] .notification.warning { background-color: #ed8936; color: white; }
[data-theme="dark"] .notification.info { background-color: #36a3b8; color: white; }
.notification-icon { 
    font-size: 1.2rem; 
    margin-right: 0.8rem;
    animation: fadeInScale 0.33s cubic-bezier(0.28, 0.68, 0.53, 1.01);
}
.notification-title { font-weight: 600; margin-bottom: 0.15rem; color: var(--text-color); }
.notification-message { font-size: 0.9rem; color: var(--text-light); }
.notification-close {
    margin-left: auto;
    background: none;
    border: none;
    color: var(--text-light);
    cursor: pointer;
    font-size: 0.9rem;
    opacity: 0.65;
    padding: 2px 5px;
    border-radius: 6px;
    transition: background 0.15s;
}
.notification-close:hover { background: var(--background-color);}
.notification.slide-out {
    animation: slideOutBelowHeader 0.36s cubic-bezier(0.32, 0, 0.53, 1.25) forwards;
    opacity: 0;
}

/* NEW: Notification Archive Modal Styles */
.notification-archive-modal-content {
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
}

.notification-archive-item {
    display: flex;
    align-items: flex-start;
    padding: 0.8rem;
    border-radius: var(--radius-md);
    background-color: var(--background-color); /* Light gray for unread */
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--border-color);
    transition: all 0.2s ease;
    cursor: pointer;
}
[data-theme="dark"] .notification-archive-item {
    background-color: var(--background-color);
}

.notification-archive-item.read {
    background-color: #f8fafc; /* Even lighter for read */
    opacity: 0.7;
    border-color: #f1f5f9;
}
[data-theme="dark"] .notification-archive-item.read {
    background-color: #262c38;
    opacity: 0.7;
}

.notification-archive-item:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}

.notification-archive-icon {
    font-size: 1.1rem;
    margin-right: 0.8rem;
    color: var(--primary-color);
    flex-shrink: 0;
    line-height: 1.4;
}
/* Specific colors for icons in archive */
.notification-archive-item.read .notification-archive-icon { color: var(--text-light); }
.notification-archive-item.read .notification-archive-title { color: var(--text-light); font-weight: normal;}
.notification-archive-item.read .notification-archive-message { color: var(--text-light); opacity: 0.8; }


.notification-archive-details {
    flex-grow: 1;
}

.notification-archive-title {
    font-weight: 600;
    color: var(--text-color);
    margin-bottom: 0.2rem;
    font-size: 0.95rem;
}

.notification-archive-message {
    font-size: 0.85rem;
    color: var(--text-light);
    line-height: 1.4;
}

.notification-archive-meta {
    font-size: 0.75rem;
    color: var(--text-light);
    margin-top: 0.4rem;
}

.notification-archive-actions {
    margin-left: 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    flex-shrink: 0;
}
.notification-archive-actions .btn-xs {
    min-width: 80px;
}
@media (max-width: 768px) {
    .notification-archive-item {
        flex-direction: column;
        align-items: flex-start;
    }
    .notification-archive-actions {
        flex-direction: row;
        margin-top: 0.8rem;
        margin-left: 0;
        width: 100%;
        justify-content: flex-end;
    }
    .notification-archive-icon {
        margin-bottom: 0.5rem;
    }
}
@media (max-width: 768px) {
    .content-area {
        padding-top: calc(48px + 0.5rem); 
    }
}

/* Dashboard styles */
.dashboard-overview {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}
.dashboard-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--card-bg);
    padding: 2rem;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-soft-ui);
}

.dashboard-header h2 {
    font-size: 2rem;
    font-weight: 700;
    margin: 0 0 0.5rem 0;
    color: var(--text-color);
}

.dashboard-header p {
    font-size: 1rem;
    color: var(--text-light);
    margin: 0;
}

.dashboard-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 1.5rem;
}
.stat-card, .operational-card {
    background: var(--card-bg);
    border-radius: var(--radius-lg);
    padding: 1.25rem;
    box-shadow: var(--shadow-soft-ui);
    border: none;
    transition: all 0.3s ease;
    overflow: hidden;
    position: relative;
}
[data-theme="dark"] .stat-card, [data-theme="dark"] .operational-card {
    background: var(--card-bg);
}
.stat-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 20px rgba(0,0,0,0.15);
}
.stat-card-header, .card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 0.8rem;
}
.stat-card-title, .card-title {
    font-weight: 600;
    color: var(--text-color);
}
.stat-card-icon, .card-icon {
    width: 44px;
    height: 44px;
    border-radius: var(--radius-md);
    display: flex;
    justify-content: center;
    align-items: center;
    color: white;
    font-size: 1.1rem;
    background: linear-gradient(195deg, var(--primary-color), #ec407a);
    box-shadow: var(--shadow-md);
}
[data-theme="dark"] .stat-card-icon, [data-theme="dark"] .card-icon {
    background: linear-gradient(195deg, #e91e63, #d81b60);
}
.stat-card-value, .metric-value {
    font-size: 2rem;
    font-weight: 700;
    color: var(--text-color);
}
.stat-card-change {
    font-size: 0.875rem;
    margin-top: 0.5rem;
    color: var(--text-light);
}
.stat-card-change i {
    margin-right: 0.25rem;
}
.positive { color: var(--success-color); }
.negative { color: var(--danger-color); }
[data-theme="dark"] .stat-card-change { color: var(--text-light); }

.financial-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--border-color);
}

.financial-item:last-child {
    border-bottom: none;
}

.financial-item span {
    font-weight: 500;
}

.financial-item strong {
    font-size: 1.1rem;
}

.alert-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.alert-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem;
    border-radius: var(--radius-md);
    background: var(--background-color);
    transition: background-color 0.2s;
    cursor: pointer;
}

.alert-item:hover {
    background: var(--primary-light);
}

.alert-icon {
    font-size: 1.2rem;
}

.alert-icon.warning {
    color: var(--warning-color);
}

.alert-icon.danger {
    color: var(--danger-color);
}

.alert-item span {
    flex-grow: 1;
    font-weight: 500;
}

.alert-count {
    font-weight: 700;
    padding: 0.25rem 0.5rem;
    border-radius: var(--radius-sm);
    color: white;
}

.alert-count.warning {
    background: var(--warning-color);
}

.alert-count.danger {
    background: var(--danger-color);
}

.tabs {
    display: flex;
    border-bottom: 1px solid var(--border-color);
    margin-bottom: 1rem;
}

.tab-button {
    padding: 0.75rem 1rem;
    border: none;
    background: none;
    cursor: pointer;
    font-weight: 500;
    color: var(--text-light);
    border-bottom: 2px solid transparent;
    transition: all 0.2s;
}

.tab-button.active {
    color: var(--primary-color);
    border-bottom-color: var(--primary-color);
}

.tab-content {
    display: none;
}

.tab-content.active {
    display: block;
}

.event-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.75rem 0.5rem;
    border-bottom: 1px solid var(--border-color);
    cursor: pointer;
    border-radius: var(--radius-sm);
    transition: background-color 0.2s;
}

.event-item:hover {
    background-color: var(--background-color);
}

.event-item:last-child {
    border-bottom: none;
}

.event-guest-info {
    display: flex;
    flex-direction: column;
}

.guest-name {
    font-weight: 600;
}

.room-info {
    font-size: 0.875rem;
    color: var(--text-light);
}

.debt-badge {
    color: var(--danger-color);
    font-weight: 600;
    font-size: 0.875rem;
}

.paid-badge {
    color: var(--success-color);
    font-weight: 600;
    font-size: 0.875rem;
}

.chart-card .card-header {
    border-bottom: 1px solid var(--border-color);
    padding-bottom: 1rem;
}

.chart-container {
    position: relative;
    padding-top: 1rem;
}

/* System error styles */
.system-error {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100vh;
    background: var(--background-color);
    font-family: Arial, sans-serif;
}
.error-card {
    text-align: center;
    background: var(--content-bg);
    padding: 2rem;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-soft-ui);
    max-width: 500px;
    color: var(--text-color);
}
.error-title {
    color: var(--danger-color);
    margin-bottom: 1rem;
}
.error-message {
    color: var(--text-color);
    margin-bottom: 2rem;
}
.error-details {
    margin-top: 1rem;
    padding: 1rem;
    background: var(--background-color);
    border-radius: var(--radius-md);
    font-family: monospace;
    font-size: 0.875rem;
    color: var(--text-light);
    text-align: left;
    word-break: break-all;
}
/* System Error Log Table Styles */
.error-log-card {
    background: var(--card-bg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-soft-ui);
    overflow: hidden;
    border: none;
}
.error-log-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.25rem;
    border-bottom: 1px solid var(--border-color);
}
.error-log-title {
    font-size: 1.25rem;
    font-weight: 600;
    margin: 0;
    color: var(--text-color);
}
.error-log-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
}
.error-log-table th, .error-log-table td {
    border-bottom: 1px solid var(--border-color);
    padding: 0.65rem 0.9rem;
    text-align: left;
    vertical-align: top;
    color: var(--text-color);
}
.error-log-table th {
    background-color: var(--background-color);
    font-weight: 600;
    color: var(--text-color);
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.error-log-table tbody tr:hover td {
    background: var(--primary-light);
}
.error-log-table .error-message-col {
    max-width: 350px;
    white-space: pre-wrap;
    word-break: break-word;
    font-family: monospace;
    font-size: 0.9em;
}
.error-log-table .error-stack-col {
    max-width: 400px;
    white-space: pre-wrap;
    word-break: break-all;
    font-family: monospace;
    font-size: 0.85em;
    color: var(--text-light);
}
.error-log-table .error-status-badge {
    padding: 0.3em 0.6em;
    border-radius: var(--radius-sm);
    font-size: 0.8em;
    font-weight: 500;
    display: inline-block;
}
.error-log-table .status-resolved {
    background-color: #e6f7ef;
    color: #2dce89;
}
.error-log-table .status-unresolved {
    background-color: #fce6eb;
    color: #f5365c;
}

/* Settings Page */
.settings-modern-container {
    display: flex;
    flex-direction: row;
    gap: 1.5rem;
}
.settings-menu {
    flex: 0 0 300px;
    background: var(--card-bg);
    border-radius: var(--radius-lg);
    padding: 1.25rem;
    box-shadow: var(--shadow-soft-ui);
}
[data-theme="dark"] .settings-menu {
    background: var(--card-bg);
}
.settings-menu-header {
    font-size: 1.2rem;
    font-weight: 700;
    margin-bottom: 1.25rem;
    color: var(--text-color);
    display: flex;
    align-items: center;
    gap: 0.7rem;
}
.settings-menu-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
.settings-menu-btn {
    width: 100%;
    background: var(--content-bg);
    color: var(--text-color);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: 0.7rem 0.9rem;
    display: flex;
    align-items: center;
    gap: 1rem;
    text-align: left;
    font-size: 0.92rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
    white-space: nowrap;
    box-shadow: var(--shadow-sm);
}
[data-theme="dark"] .settings-menu-btn {
    background: var(--background-color);
    color: var(--text-color);
    border: 1px solid var(--border-color);
}
.settings-menu-btn.active, .settings-menu-btn:hover {
    background: var(--primary-light);
    border-color: var(--primary-color);
    color: var(--primary-color);
}
[data-theme="dark"] .settings-menu-btn.active {
    background: var(--primary-light);
    color: var(--text-color);
    border-color: var(--primary-color);
}
[data-theme="dark"] .settings-menu-btn:hover {
    background: var(--primary-light);
}
.settings-menu-icon {
    font-size: 1.1rem;
    width: 24px;
    text-align: center;
}
.settings-menu-text {
    flex-grow: 1;
}
.settings-menu-desc {
    display: block;
    font-size: 0.8em;
    color: var(--text-light);
    font-weight: 400;
    margin-top: 2px;
}
[data-theme="dark"] .settings-menu-btn small {
    color: var(--text-light);
}
.settings-menu-chevron {
    color: var(--text-light);
}
.settings-main {
    flex: 1;
    background: var(--card-bg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-soft-ui);
    padding: 1.8rem;
}
[data-theme="dark"] .settings-main {
    background: var(--card-bg);
}
.settings-content-header {
    display: none; /* Hidden on desktop, shown on mobile */
}
[data-theme="dark"] .settings-content-header {
    background: var(--card-bg);
    border-bottom-color: var(--border-color);
}
/* Danger Zone */
.danger-zone-section {
    background-color: var(--danger-color-light); /* Uses #fef2f2 in light mode */
    border: 2px solid var(--danger-color);
    color: var(--text-color); /* Main text color for readability */
}
.danger-zone-section .table-header .table-title {
    color: var(--danger-color); /* Keep the red color for the title */
}
.danger-zone-section h4.card-title {
    color: var(--text-color); /* Ensure sub-headings are dark for readability on light background */
}
.danger-zone-section p {
    color: var(--text-light); /* Keep paragraphs slightly lighter but readable */
}
/* Dark mode overrides for Danger Zone */
[data-theme="dark"] .danger-zone-section {
    background-color: #632c3f; /* A darker red for dark mode, providing better contrast */
    border-color: var(--danger-color); /* Keep the primary danger color for border */
    color: var(--text-color); /* Will be white/light in dark mode */
}
[data-theme="dark"] .danger-zone-section .table-header .table-title {
    color: var(--danger-color);
}
[data-theme="dark"] .danger-zone-section h4.card-title {
    color: var(--text-color); /* Will be white/light in dark mode */
}
[data-theme="dark"] .danger-zone-section p {
    color: var(--text-light); /* Will be lighter white/gray in dark mode */
}

/* Category & Permission Styles */
.category-inline-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5em;
    align-items: center;
    margin-bottom: 0.4rem;
}
.category-chip {
    background: var(--primary-light);
    color: var(--primary-color);
    padding: 0.45em 0.95em 0.45em 0.87em;
    border-radius: var(--radius-md);
    margin-right: 0.5em;
    margin-bottom: 0.4em;
    display: inline-flex;
    align-items: center;
    gap: 0.35em;
}
.category-chip-input-wrapper {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    background: var(--background-color);
    padding: 0.4rem 0.6rem;
    border-radius: var(--radius-md);
    border: 1px solid var(--border-color);
}
.category-chip-input-wrapper .form-input {
    border: none;
    padding: 0.2rem;
    background: transparent;
    box-shadow: none;
    font-size: 0.9em;
}
.category-chip-input-wrapper .form-input:focus {
    box-shadow: none;
}
.category-chip-delete {
    background: none;
    border: none;
    color: var(--danger-color);
    cursor: pointer;
    font-size: 1.05em;
    margin-left: 0.35em;
    transition: color 0.17s;
}
.category-chip-delete:hover {
    color: #b91c1c;
}
.permission-checkboxes-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(70px, 1fr));
    gap: 0.4rem;
    padding: 0.4rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    background: var(--background-color);
    font-size: 0.88em;
}
[data-theme="dark"] .permission-checkboxes-grid {
    background: var(--background-color);
    border-color: var(--border-color);
}
.permission-checkbox-label {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    cursor: pointer;
    white-space: nowrap;
    padding: 0.08em 0.4em;
    transition: background-color 0.15s ease;
    border-radius: var(--radius-sm);
}
.permission-checkbox-label:hover {
    background-color: var(--primary-light);
}
[data-theme="dark"] .permission-checkbox-label:hover {
    background-color: var(--primary-light);
}
.permission-checkbox-label input[type="checkbox"] {
    transform: scale(0.9);
    margin-right: 0.2em;
    cursor: pointer;
}
.modal .data-table th, .modal .data-table td {
    padding: 0.45rem 0.75rem;
}
.modal .data-table th:nth-child(3) {
    width: 35%;
}

/* Calendar Styles (General for Reservations and Rooms) */
.calendar-container {
    background-color: var(--card-bg);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-soft-ui);
    border: none;
}
[data-theme="dark"] .calendar-container {
    background-color: var(--card-bg);
}
.calendar-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-lg);
}
.calendar-header h2 {
    margin: 0;
    font-size: 1.4rem;
    font-weight: 600;
    color: var(--text-color);
}
.calendar-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 4px;
}
.calendar-day-name {
    text-align: center;
    font-weight: 600;
    color: var(--text-light);
    padding-bottom: 0.5rem;
}
.calendar-day {
    background-color: var(--background-color);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    min-height: 100px;
    padding: 0.4rem;
    display: flex;
    flex-direction: column;
    color: var(--text-color);
}
[data-theme="dark"] .calendar-day {
    background-color: var(--background-color);
    border: 1px solid var(--border-color);
}
.calendar-day.empty {
    background-color: transparent;
    border: 1px solid transparent;
}
.calendar-day.today {
    border: 2px solid #5a0000;
    background-color: #fce6eb;
}
[data-theme="dark"] .calendar-day.today {
    border: 2px solid #4a333f;
    background-color: #4a333f;
}
.day-number {
    font-weight: 500;
    margin-bottom: 0.4rem;
}
.reservations-on-day {
    display: flex;
    flex-direction: column;
    gap: 3px;
    overflow-y: auto;
    max-height: 70px;
}
.reservation-cal-item {
    background-color: var(--primary-color);
    color: white;
    padding: 2px 5px;
    border-radius: var(--radius-sm);
    font-size: 0.7rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    cursor: pointer;
    transition: background-color 0.2s;
}
[data-theme="dark"] .reservation-cal-item {
    background-color: var(--primary-color);
}
.reservation-cal-item:hover {
    background-color: var(--primary-hover);
}
.reservation-cal-item.pending {
    background-color: var(--warning-color);
    color: white;
}
[data-theme="dark"] .reservation-cal-item.pending {
    background-color: var(--warning-color);
}
.reservation-cal-item.pending:hover {
    background-color: #d97706;
}
[data-theme="dark"] .reservation-cal-item.pending:hover {
    background-color: var(--warning-color);
}
/* Rooms Calendar */
.rooms-calendar-container {
    background-color: var(--card-bg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-soft-ui);
    border: none;
    overflow-x: auto;
    min-width: 0;
}
.rooms-calendar-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.9rem 1.2rem;
    border-bottom: 1px solid var(--border-color);
}
.rooms-calendar-header h2 {
    margin: 0;
    font-size: 1.15rem;
    font-weight: 600;
    color: var(--text-color);
}
.rooms-calendar-nav button { /* Reusing .btn styles where possible */
    background: none;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: 0.4rem 0.6rem;
    cursor: pointer;
    transition: all 0.2s;
}
.rooms-calendar-nav button:hover {
    background-color: var(--primary-light);
    border-color: var(--primary-color);
}
[data-theme="dark"] .rooms-calendar-nav button {
    background: var(--background-color);
    border: 1px solid var(--border-color);
    color: var(--text-color);
}
[data-theme="dark"] .rooms-calendar-nav button:hover {
    background-color: var(--content-bg);
}
.rooms-calendar-table-wrapper {
    width: 100%;
    overflow-x: auto;
    padding-bottom: 15px;
}
.rooms-calendar-table {
    width: auto;
    min-width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    font-size: 0.875rem;
}
.rooms-calendar-table th, .rooms-calendar-table td {
    padding: 0.45rem 0.65rem;
    border-bottom: 1px solid var(--border-color);
    text-align: center;
    white-space: nowrap;
    min-width: 55px;
    height: 45px;
    color: var(--text-color);
}
.rooms-calendar-table td:first-child, .rooms-calendar-table th:first-child {
  border-left: none;
}
.rooms-calendar-table td:last-child, .rooms-calendar-table th:last-child {
  border-right: none;
}
.rooms-calendar-table tbody tr:last-child td {
  border-bottom: none;
}
[data-theme="dark"] .rooms-calendar-table th {
    background-color: var(--background-color);
    color: var(--text-color);
}
.rooms-calendar-table tbody tr:hover td {
    background-color: var(--primary-light);
}
[data-theme="dark"] .rooms-calendar-table tbody tr:hover td {
    background-color: var(--background-color);
}
.rooms-calendar-table .room-info-col {
    position: sticky;
    left: 0;
    background-color: var(--card-bg);
    z-index: 15;
    border-right: 2px solid var(--border-color);
    font-weight: 600;
    text-align: left;
    min-width: 100px;
    max-width: 150px;
    word-break: break-word;
    white-space: normal;
}
[data-theme="dark"] .rooms-calendar-table .room-info-col {
    background-color: var(--card-bg);
}
.rooms-calendar-table .date-header-col {
    min-width: 70px;
    padding-top: 0.3rem;
    padding-bottom: 0.3rem;
    border-bottom: 1px solid var(--border-color);
    background-color: var(--background-color);
    text-align: center;
}
[data-theme="dark"] .rooms-calendar-table .date-header-col {
    background-color: var(--background-color);
}
.rooms-calendar-table .room-calendar-cell {
    position: relative;
    cursor: pointer;
    overflow: hidden;
}
.room-status-badge {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    border-radius: var(--radius-sm);
    font-size: 0.7rem;
    font-weight: 500;
    color: white;
    padding: 0.15rem 0.25rem;
    box-sizing: border-box;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    transition: all 0.2s;
}
.room-status-badge.available { background-color: #2dce89; }
.room-status-badge.occupied { background-color: #f5365c; }
.room-status-badge.maintenance { background-color: #fb6340; }
.room-status-badge.reserved { background-color: #11cdef; }
.room-status-badge.dirty { background-color: #67748e; }
.room-status-badge.pending_reservation { background-color: var(--warning-color); }
.room-status-badge.pending_reservation { color: white; }
.room-calendar-cell.today-column {
    background-color: var(--primary-light); /* Highlight the entire column cell */
}
.room-calendar-cell.today-column .room-status-badge {
    border: 2px solid var(--primary-color);
    box-shadow: 0 0 5px rgba(203, 12, 159, 0.3);
}
.rooms-calendar-table .room-calendar-cell:hover .room-status-badge {
    transform: scale(1.05);
    box-shadow: 0 2px 8px rgba(0,0,0, 0.1);
}
.rooms-calendar-scroll-wrapper {
    width: 100%;
    overflow-x: auto;
    padding-bottom: 15px;
}
.rooms-calendar-table {
    width: auto;
    min-width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    font-size: 0.875rem;
}
.rooms-calendar-table th.today-col {
    background-color: var(--primary-light);
    color: var(--primary-color);
    font-weight: 700;
}
[data-theme="dark"] .rooms-calendar-table th.today-col {
    background-color: var(--primary-light);
    color: var(--primary-color);
}

/* Quick Actions */
.floating-quick-actions {
    position: fixed;
    bottom: 1rem;
    right: 1rem;
    z-index: 100;
}
body.login-active .floating-quick-actions {
    display: none;
}
.quick-actions-trigger {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: linear-gradient(195deg, var(--primary-color), #ec407a);
    border: none;
    color: white;
    font-size: 1.2rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: var(--shadow-md);
    transition: all var(--transition-fast);
    position: relative;
    z-index: 2;
    outline: none;
}
[data-theme="dark"] .quick-actions-trigger {
    background: linear-gradient(195deg, #e91e63, #d81b60);
}
.quick-actions-trigger:hover, .quick-actions-trigger:focus {
    transform: scale(1.08);
    box-shadow: var(--shadow-lg);
}
.quick-actions-menu {
    position: absolute;
    bottom: 0;
    right: 0;
    width: 200px;
    background: var(--content-bg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-soft-ui);
    padding: 0.6rem 0.2rem;
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
    opacity: 0;
    pointer-events: none;
    transform: translateY(12px) scale(0.97);
    transition: all 0.23s cubic-bezier(0.22, 0.68, 0.53, 1.01);
    border: none;
}
[data-theme="dark"] .quick-actions-menu {
    background: var(--card-bg);
    box-shadow: var(--shadow-soft-ui);
}
.quick-actions-menu.show {
    opacity: 1;
    pointer-events: all;
    transform: translateY(0) scale(1.01);
}
.quick-action-list-btn {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    padding: 0.6em 0.7em 0.6em 0.54em;
    width: 100%;
    background: transparent;
    border: none;
    color: var(--text-color);
    font-size: 0.98em;
    border-radius: var(--radius-md);
    transition: background 0.16s;
    cursor: pointer;
    position: relative;
    min-height: 40px;
}
[data-theme="dark"] .quick-action-list-btn { color: var(--text-color); }
.quick-action-list-btn .qa-circle {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 1.2rem;
    box-shadow: var(--shadow-sm);
}
[data-theme="dark"] .quick-action-list-btn .qa-circle { box-shadow: none; }
.quick-action-list-btn:hover {
    background: var(--primary-light);
}
[data-theme="dark"] .quick-action-list-btn:hover { background: var(--primary-light); }
.quick-action-list-btn .qa-label {
    flex: 1;
    font-size: 1.03em;
    font-weight: 530;
}
.quick-action-list-btn .qa-desc {
    font-size: 0.85rem;
    color: var(--text-light);
    line-height: 1.18em;
    display: block;
    margin-top: 1px;
}
[data-theme="dark"] .quick-action-list-btn .qa-desc { color: var(--text-light); }
/* Quick Action specific colors */
.quick-action-list-btn.reservation .qa-circle { background-color: #e6f3fa; color: #11cdef; }
.quick-action-list-btn.guest .qa-circle { background-color: #e6f7ef; color: #2dce89; }
.quick-action-list-btn.payment .qa-circle { background-color: #fff0e6; color: #fb6340; }
.quick-action-list-btn.pos .qa-circle { background-color: #f7e6f3; color: #cb0c9f; }
.quick-action-list-btn.maintenance .qa-circle { background-color: #fce6eb; color: #f5365c; }
.quick-action-list-btn.reports .qa-circle { background-color: #e2e8f0; color: #67748e; }
[data-theme="dark"] .quick-action-list-btn.reservation .qa-circle { background-color: #36a3b8; color: white; }
[data-theme="dark"] .quick-action-list-btn.guest .qa-circle { background-color: #48bb78; color: white; }
[data-theme="dark"] .quick-action-list-btn.payment .qa-circle { background-color: #ed8936; color: white; }
[data-theme="dark"] .quick-action-list-btn.pos .qa-circle { background-color: #e91e63; color: white; }
[data-theme="dark"] .quick-action-list-btn.maintenance .qa-circle { background-color: #f05252; color: white; }
[data-theme="dark"] .quick-action-list-btn.reports .qa-circle { background-color: #4a5568; color: white; }

/* NEW: Reusable Info Box for modals and forms */
.info-box {
    background: #f8fafc;
    padding: 1rem;
    border-radius: 0.5rem;
    border: 1px solid #e2e8f0;
}
.info-box h4, .info-box .info-box-title {
    margin: 0 0 0.5rem 0;
    color: #1e293b;
}

[data-theme="dark"] .info-box {
    background: var(--background-color);
    border-color: var(--border-color);
}
[data-theme="dark"] .info-box h4,
[data-theme="dark"] .info-box .info-box-title,
[data-theme="dark"] .info-box,
[data-theme="dark"] .info-box span,
[data-theme="dark"] .info-box strong,
[data-theme="dark"] .info-box div {
    color: var(--text-color) !important;
}

[data-theme="dark"] .info-box .positive,
[data-theme="dark"] .info-box span[style*="#10b981"] {
    color: var(--success-color) !important;
}
[data-theme="dark"] .info-box .negative,
[data-theme="dark"] .info-box span[style*="#ef4444"] {
    color: var(--danger-color) !important;
}

/* Scroll to Top button */
.scroll-to-top-container {
    position: fixed;
    bottom: 60px; 
    right: 1rem;
    z-index: 100;
    transition: opacity 0.3s ease-in-out, transform 0.3s ease-in-out;
    opacity: 0;
    transform: translateY(10px);
}
.scroll-to-top-container.show {
    opacity: 1;
    transform: translateY(0);
}
.scroll-to-top-btn {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: linear-gradient(195deg, var(--primary-color), #ec407a);
    border: none;
    color: white;
    font-size: 1rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: var(--shadow-md);
    transition: all var(--transition-fast);
    outline: none;
}
[data-theme="dark"] .scroll-to-top-btn {
    background: linear-gradient(195deg, #e91e63, #d81b60);
}
.scroll-to-top-btn:hover, .scroll-to-top-btn:focus {
    transform: scale(1.08);
    box-shadow: var(--shadow-lg);
}

/* Pull-to-refresh styles */
.ptr__pull-down {
    position: absolute;
    top: -50px; 
    left: 0;
    right: 0;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.9em;
    color: var(--text-light);
    opacity: 0;
    pointer-events: none;
    z-index: 10; 
    transition: opacity 0.2s ease-out, transform 0.2s ease-out;
}
.ptr__pull-down i {
    margin-right: 8px;
    transition: transform 0.2s ease-out;
}
.ptr__pull-down.ready i {
    transform: rotate(180deg); 
}
.main-content.ptr .content-area {
    will-change: transform;
    transition: transform 0s ease-out; 
}
.main-content.ptr .ptr__pull-down {
    opacity: 1;
}
.main-content.ptr--refresh .ptr__pull-down i {
    animation: spin 1s linear infinite; 
}
.main-content.ptr--refresh .content-area {
    transform: translateY(60px) !important; 
}

/* Reports Component Styling */
.reports-container {
    padding: 0; /* Already has padding from .table-container */
    border-radius: var(--radius-lg);
    overflow: hidden; /* For inner elements */
}

.reports-nav {
    padding: 0.8rem 1.5rem;
    border-bottom: 1px solid var(--border-color);
    background-color: var(--content-bg);
}
[data-theme="dark"] .reports-nav {
    background-color: var(--card-bg);
    border-bottom: 1px solid var(--border-color);
}

.report-category-links {
    display: flex;
    gap: 0.8rem;
    flex-wrap: wrap; /* Allow wrapping on smaller screens */
}

.report-nav-btn {
    display: inline-flex;
    align-items: center;
    padding: 0.7rem 1.2rem;
    border-radius: var(--radius-md);
    font-size: 0.95rem;
    font-weight: 600;
    cursor: pointer;
    transition: all var(--transition-normal);
    white-space: nowrap;
    background: var(--background-color);
    color: var(--text-color);
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow-sm);
}
[data-theme="dark"] .report-nav-btn {
    background: var(--background-color);
    color: var(--text-color);
    border: 1px solid var(--border-color);
}

.report-nav-btn:hover {
    background: var(--primary-light);
    border-color: var(--primary-color);
    color: var(--primary-color);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}
[data-theme="dark"] .report-nav-btn:hover {
    background: var(--primary-light);
    color: var(--text-color); /* Keep text color for dark mode */
}

.report-nav-btn.active {
    background: linear-gradient(195deg, var(--primary-color), #ec407a);
    color: white;
    border: none;
    box-shadow: var(--shadow-md);
}
[data-theme="dark"] .report-nav-btn.active {
    background: linear-gradient(195deg, #e91e63, #d81b60);
    color: white;
}

.report-nav-btn i {
    margin-right: 0.6rem;
    font-size: 1.1rem;
}

.reports-content {
    padding: 1.5rem;
    background-color: var(--content-bg); /* Match table-container background */
}
[data-theme="dark"] .reports-content {
    background-color: var(--card-bg);
}

.report-section h4 {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--text-color);
    margin-top: 0;
    margin-bottom: 1.5rem;
    border-bottom: 1px solid var(--border-color);
    padding-bottom: 0.8rem;
}
[data-theme="dark"] .report-section h4 {
    color: var(--text-color);
}

.report-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.5rem;
}

.report-card {
    background-color: var(--background-color); /* Lighter background for cards within content area */
    border-radius: var(--radius-md);
    padding: 1.2rem;
    box-shadow: var(--shadow-sm);
    transition: all 0.2s ease;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    border: 1px solid var(--border-color);
}
[data-theme="dark"] .report-card {
    background-color: var(--background-color);
    border: 1px solid var(--border-color);
}

.report-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-md);
    border-color: var(--primary-color);
}
[data-theme="dark"] .report-card:hover {
    border-color: var(--primary-color);
}

.report-icon {
    font-size: 1.5rem;
    width: 48px;
    height: 48px;
    border-radius: var(--radius-md);
    display: flex;
    justify-content: center;
    align-items: center;
    color: white;
    margin-bottom: 1rem;
    box-shadow: var(--shadow-sm);
}
[data-theme="dark"] .report-icon {
    box-shadow: none; /* No inner shadow for dark icons */
}

/* Specific icon colors for categories */
.report-icon.financial { background-color: #3b82f6; } /* Blue */
.report-icon.operational { background-color: #f59e0b; } /* Orange */
.report-icon.guests { background-color: #10b981; } /* Green */
.report-icon.rooms { background-color: #cb0c9f; } /* Pink-purple */

/* Dark mode specific icon colors (adjust slightly if needed for better contrast) */
[data-theme="dark"] .report-icon.financial { background-color: #4991eb; } /* Brighter blue */
[data-theme="dark"] .report-icon.operational { background-color: #ed8936; } /* Brighter orange */
[data-theme="dark"] .report-icon.guests { background-color: #48bb78; } /* Brighter green */
[data-theme="dark"] .report-icon.rooms { background-color: #e91e63; } /* Brighter pink */


.report-card h5 {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-color);
    margin: 0 0 0.5rem 0;
}
[data-theme="dark"] .report-card h5 {
    color: var(--text-color);
}

.report-card p {
    font-size: 0.85rem;
    color: var(--text-light);
    margin: 0;
    line-height: 1.4;
}
[data-theme="dark"] .report-card p {
    color: var(--text-light);
}

/* Animations */
@keyframes fadeInScale {
    from { opacity: 0; transform: scale(0.95); }
    to { opacity: 1; transform: scale(1); }
}
@keyframes soft-pulse {
    0% { transform: scale(0.95); opacity: 0.7; }
    50% { transform: scale(1.05); opacity: 0.3; }
    100% { transform: scale(0.95); opacity: 0.7; }
}
@keyframes icon-pop-in {
    0% { transform: scale(0); opacity: 0; }
    60% { transform: scale(1.1); opacity: 1; }
    80% { transform: scale(0.95); }
    100% { transform: scale(1); opacity: 1; }
}
@keyframes wave {
    0%, 60%, 100% {
        transform: translateY(0);
    }
    30% {
        transform: translateY(-12px);
    }
}
@keyframes loginSlideIn {
    0% { transform: translateY(40px) scale(0.96); opacity: 0; }
    100% { transform: translateY(0) scale(1); opacity: 1; }
}
@keyframes modalSlideIn {
    from { opacity: 0; transform: translateY(-10px); }
    to { opacity: 1; transform: translateY(0); }
}
@keyframes shimmer {
    0% { transform: translateX(-100%); }
    100% { transform: translateX(100%); }
}
@keyframes slideInBelowHeader {
    0% { opacity: 0; transform: translateY(-10px) scale(0.9); } /* Start slightly above and smaller */
    100% { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes slideOutBelowHeader {
    0% { opacity: 1; transform: translateY(0) scale(1); }
    100% { opacity: 0; transform: translateY(-10px) scale(0.9); } /* Disappear upwards and shrink */
}

/* Loading states */
.loading {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem;
    color: var(--text-light);
}
.loading::after {
    content: '';
    width: 2rem;
    height: 2rem;
    border: 2px solid var(--primary-light);
    border-top-color: var(--primary-color);
    border-radius: 50%;
    animation: spin 0.6s linear infinite;
}

/* Improved scrollbars */
::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}
::-webkit-scrollbar-track {
    background: transparent;
    border-radius: 4px;
}
::-webkit-scrollbar-thumb {
    background: rgba(100, 116, 139, 0.2);
    border-radius: 3px;
}
::-webkit-scrollbar-thumb:hover {
    background: rgba(100, 116, 139, 0.3);
}
/* Scrollbar for dark mode */
[data-theme="dark"]::-webkit-scrollbar-thumb {
    background: rgba(176, 176, 176, 0.2);
}
[data-theme="dark"]::-webkit-scrollbar-thumb:hover {
    background: rgba(176, 176, 176, 0.3);
}

/* Add subtle hover effects to clickable elements */
[role="button"], .clickable {
    transition: all 0.2s ease;
}
[role="button"]:hover, .clickable:hover {
    transform: translateY(-1px);
}

/* Responsive adjustments */
@media (max-width: 900px) { /* Medium screens - tablets and smaller laptops */
    .app-container {
        flex-direction: column;
    }
    .sidebar {
        position: fixed;
        left: -280px;
        top: 0;
        width: 280px;
        height: 100%;
        z-index: 500;
        transition: left 0.3s ease;
        box-shadow: var(--shadow-lg);
    }
    .sidebar.show {
        left: 0;
    }
    .mobile-menu-btn {
        display: block;
        color: var(--text-color);
        padding: 0.5rem;
    }
    .header-title {
        flex-grow: 1;
        text-align: center;
        margin: 0 auto;
    }
    .header-actions {
        gap: 0.25rem;
    }
    #currentUserName {
        display: none;
    }
    .user-profile .user-btn {
        padding: 0.5rem;
    }
    /* Content Area & General Padding */
    .content-area {
        padding: 1rem;
        padding-top: calc(54px + 1rem); /* Adjust padding for smaller header */
    }
    .notification-container {
        top: 55px; /* Adjust top for smaller header */
        left: 10px;
        right: 10px;
        width: auto;
        max-width: none;
        align-items: center;
    }
    .notification-container.below-header {
      top: calc(54px + 0.5rem); /* Adjust for smaller mobile header (54px height) */
      left: 10px;
      right: 10px;
      max-width: 97%;
      align-items: center;
    }
    /* Tables */
    .table-container {
        padding: 0.7rem; /* Reduce padding for tables */
        overflow-x: auto;
    }
    .table-header {
        padding: 0.9rem 0.5rem; /* Adjust header padding */
        flex-direction: column;
        gap: 1rem;
        align-items: stretch;
    }
    .data-table {
        min-width: 600px; /* Ensure table remains wide enough for scrolling */
        font-size: 0.85rem;
    }
    .data-table th, .data-table td {
        padding: 0.6rem;
        white-space: nowrap;
    }
    .data-table th {
        font-size: 0.75rem;
    }
    .table-filters {
        flex-direction: column;
    }
    .table-filters .form-select, .table-filters .form-input {
        max-width: 100% !important;
        width: 100%;
    }


    /* --- Settings & Reports Tabs --- */
    .settings-modern-container {
        flex-direction: column;
        gap: 0;
    }
    .settings-menu {
        flex-basis: auto;
        width: 100%;
        box-shadow: none;
        padding: 0.5rem;
        border-bottom: 1px solid var(--border-color);
    }
    .settings-menu-header {
        display: none;
    }
    .settings-menu-list {
        flex-direction: row;
        overflow-x: auto;
        padding-bottom: 0.5rem;
    }
    .settings-menu-list::-webkit-scrollbar { height: 4px; }
    .settings-menu-list::-webkit-scrollbar-thumb { background: var(--border-color); }
    .settings-menu-btn {
        flex-shrink: 0;
    }
    .settings-menu-desc {
        display: none;
    }
    .settings-main {
        padding: 1rem;
        box-shadow: none;
    }

    .reports-nav {
        padding: 0.5rem;
    }
    .report-category-links {
        overflow-x: auto;
        padding-bottom: 0.5rem;
        flex-wrap: nowrap;
    }
    .report-category-links::-webkit-scrollbar { height: 4px; }
    .report-category-links::-webkit-scrollbar-thumb { background: var(--border-color); }
    .report-nav-btn {
        flex-shrink: 0;
    }
}

/* Specific adjustments for smaller mobile phones */
@media (max-width: 768px) {
    html {
        font-size: 14px;
    }
    .header {
        height: 48px;
    }
    .content-area {
        padding: 1rem;
        padding-top: calc(48px + 1rem); 
    }
    .modal {
        max-height: 95vh;
        width: 100%;
        margin: 0;
    }
    .modal-overlay {
        padding: 0.5rem;
        align-items: flex-start;
        padding-top: 1rem;
    }
    .modal-footer {
        flex-direction: column;
        gap: 0.5rem;
    }
    .modal-footer .btn {
        width: 100%;
    }
    .form-grid {
        grid-template-columns: 1fr;
    }
    .form-input, .form-select, .form-textarea {
        font-size: 16px; /* Prevent iOS zoom on focus */
    }
    .btn {
        padding: 0.8rem 1rem;
    }
    .floating-quick-actions {
        bottom: 0.5rem;
        right: 0.5rem;
    }
}

/* Adjustments for large screens for better space utilization */
@media (min-width: 1400px) {
    .content-area {
        padding-left: 2rem;
        padding-right: 2rem;
        padding-bottom: 2rem;
        padding-top: calc(70px + 2rem); 
    }
}


/* Ensure content-area always stretches without minimum height issues */
.content-area {
    min-height: unset;
}

/* Loading states */
.loading {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem;
    color: var(--text-light);
}
.loading::after {
    content: '';
    width: 2rem;
    height: 2rem;
    border: 2px solid var(--primary-light);
    border-top-color: var(--primary-color);
    border-radius: 50%;
    animation: spin 0.6s linear infinite;
}

/* Improved scrollbars */
::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}
::-webkit-scrollbar-track {
    background: transparent;
    border-radius: 4px;
}
::-webkit-scrollbar-thumb {
    background: rgba(100, 116, 139, 0.2);
    border-radius: 3px;
}
::-webkit-scrollbar-thumb:hover {
    background: rgba(100, 116, 139, 0.3);
}
/* Scrollbar for dark mode */
[data-theme="dark"]::-webkit-scrollbar-thumb {
    background: rgba(176, 176, 176, 0.2);
}
[data-theme="dark"]::-webkit-scrollbar-thumb:hover {
    background: rgba(176, 176, 176, 0.3);
}

/* Add subtle hover effects to clickable elements */
[role="button"], .clickable {
    transition: all 0.2s ease;
}
[role="button"]:hover, .clickable:hover {
    transform: translateY(-1px);
}

/* A4 Print Styles */
@page {
    size: A4 portrait; /* Set page size to A4 and orientation to portrait */
    margin: 1cm; /* Default margins for A4 print */
}
@media print {
    html, body {
        width: 210mm; /* A4 width */
        min-height: 297mm; /* A4 height */
        padding: 0;
        margin: 0;
        font-size: 9pt; /* Smaller base font for print */
        color: #000;
        background-color: #fff !important; /* Force white background */
    }
    .app-container, .main-content, .content-area, .sidebar, .header,
    .dashboard-overview, .reports-container, .modal-overlay, .modal {
        visibility: hidden; /* Hide everything by default */
        display: none;
    }
    /* Make the report content visible */
    .report-body {
        visibility: visible;
        display: block;
        position: static; /* Remove fixed/absolute positioning */
        width: 100%;
        max-width: 100%;
        height: auto;
        padding: 0; /* Remove internal padding if desired for full bleed */
        box-shadow: none !important;
        background: #fff !important; /* Ensure white background for report content */
        overflow: visible; /* Ensure content is not clipped */
    }

    /* General print layout for tables and sections */
    .report-body h4, .report-section-header {
        font-size: 12pt;
        margin-top: 15pt;
        margin-bottom: 8pt;
        border-bottom: 1px solid #ccc;
        padding-bottom: 4pt;
        color: #333 !important; /* Force black/dark gray */
    }
    .report-info-grid, .info-card {
        display: block; /* Stack items */
        margin-bottom: 10pt;
        background: none !important;
        box-shadow: none !important;
        border: none !important;
        padding: 0 !important;
    }
    .report-info-grid div, .info-card div, .info-card p, .info-card ul {
        font-size: 9pt;
        line-height: 1.4;
        color: #333 !important;
    }
    .report-info-grid strong {
        color: #000 !important;
    }
    .info-card ul {
        list-style-type: disc;
        padding-left: 15pt;
        margin-top: 5pt;
        margin-bottom: 5pt;
    }
    .info-card li {
        margin-bottom: 3pt;
    }
    .info-card .summary-item {
        border-bottom: 1px dashed #e0e0e0;
        padding: 3pt 0;
        display: flex;
        justify-content: space-between;
        align-items: center;
    }
    .info-card .summary-item span {
        font-weight: 700;
        margin-left: 5pt;
        color: #000 !important; /* Ensure amounts are black */
    }
    /* Specific colors for positive/negative amounts */
    .info-card .summary-item span.positive { color: #2dce89 !important; }
    .info-card .summary-item span.negative { color: #f5365c !important; }

    .signatures-block {
        display: flex;
        justify-content: space-around;
        margin-top: 40pt;
        flex-wrap: nowrap;
        gap: 15pt;
    }
    .signature-item {
        flex: 1;
        text-align: center;
        min-width: 100pt;
        max-width: 150pt;
    }
    .signature-line {
        border-bottom: 1px solid #000;
        margin-top: 25pt;
        margin-bottom: 5pt;
    }
    .signature-person {
        font-size: 9pt;
        font-weight: 600;
        color: #000 !important;
    }
    .signature-label {
        font-size: 8pt;
        color: #555 !important;
    }
    table {
        width: 100%;
        border-collapse: collapse;
        margin-top: 10pt;
        margin-bottom: 15pt;
    }
    th, td {
        border: 1px solid #ccc;
        padding: 5pt 7pt;
        text-align: left;
        font-size: 9pt;
        color: #333;
    }
    th {
        background-color: #f0f0f0;
        color: #000;
    }
    .text-right { text-align: right; }
    .text-center { text-align: center; }
    .total-debt, .total-amount {
        font-size: 10pt;
        border-top: 1px dashed #ccc !important;
        padding-top: 5pt;
        color: #333 !important;
    }
    .total-debt span, .total-amount span {
        font-weight: 700;
        color: #000 !important;
    }
    .negative { color: #f5365c !important; }
    .positive { color: #2dce89 !important; }

    /* New specific overrides for text readability in print media */
    .report-description,
    .info-card p,
    .info-card ul,
    .info-card li,
    .report-info-grid div,
    .report-info-grid span {
        color: #333 !important; /* Ensure readability for main text content */
    }
    .report-description {
        margin-bottom: 10pt !important; /* Reduce margin for print */
    }

    /* Hide no-print elements explicitly */
    .no-print {
        display: none !important;
    }
}

/* Sidebar */
.sidebar {
    width: 260px;
    min-width: 260px; 
    flex-shrink: 0;  
    background-color: var(--sidebar-bg);
    color: var(--text-color);
    display: flex;
    flex-direction: column;
    transition: all var(--transition-normal);
    position: relative;
    z-index: 40;
    border-right: 1px solid var(--border-color);
}
[data-theme="dark"] .sidebar {
    background-color: var(--sidebar-bg);
    border-right: 1px solid var(--border-color);
    color: var(--text-color);
}
.sidebar-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.5rem;
    border-bottom: 1px solid var(--border-color);
}
[data-theme="dark"] .sidebar-header {
    border-bottom: 1px solid var(--border-color);
    background: var(--card-bg);
}
.sidebar-header .logo {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--text-color);
}
.sidebar-header .logo i {
    margin-right: 0.5rem;
    color: var(--primary-color);
}
.sidebar-toggle {
    background: none;
    border: none;
    color: var(--text-light);
    font-size: 1.25rem;
    cursor: pointer;
}
.sidebar-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 499;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}
.sidebar-overlay.show {
    opacity: 1;
    visibility: visible;
}
.sidebar-nav {
    flex-grow: 1;
    overflow-y: auto;
    padding: 0 1rem;
    min-height: 0; /* Add this to ensure scrolling works correctly in a flex container */
}
.sidebar-nav::-webkit-scrollbar {
    width: 4px;
}
.sidebar-nav::-webkit-scrollbar-thumb {
    background: var(--border-color);
    border-radius: 4px;
}
.sidebar-nav ul {
    list-style: none;
    padding: 0;
    margin: 1rem 0;
}
.sidebar-nav li a {
    display: flex;
    align-items: center;
    padding: 0.65rem 1rem;
    color: var(--text-color);
    text-decoration: none;
    transition: all var(--transition-normal);
    font-weight: 500;
    border-radius: var(--radius-md);
    margin: 0.25rem 0;
    position: relative;
    overflow: hidden;
}
.sidebar-nav li a:hover {
    background-color: var(--primary-light);
    color: var(--primary-color);
}
[data-theme="dark"] .sidebar-nav li a:hover {
    background-color: var(--primary-light);
    color: var(--text-color);
}
.sidebar-nav li a.active {
    background: linear-gradient(195deg, var(--primary-color), #ec407a);
    color: white;
    box-shadow: var(--shadow-md);
}
[data-theme="dark"] .sidebar-nav li a.active {
    background: linear-gradient(195deg, #e91e63, #d81b60);
    color: white;
}
.sidebar-nav li a i {
    width: 24px;
    text-align: center;
    margin-right: 1rem;
    font-size: 1.1rem;
}

/* Header */
.header {
    display: flex;
    align-items: center;
    padding: 0.85rem 1.5rem;
    background: var(--header-bg);
    border-bottom: 1px solid var(--border-color);
    box-shadow: var(--shadow-sm);
    position: sticky;
    top: 0;
    z-index: 30;
}
[data-theme="dark"] .header {
    background: var(--header-bg);
    border-bottom: 1px solid var(--border-color);
    color: var(--text-color);
}
.mobile-menu-btn {
    display: none; /* Hidden by default on desktop */
    background: none;
    border: none;
    font-size: 1.5rem;
    cursor: pointer;
    margin-right: 1rem;
}
.header-title {
    flex-grow: 1; 
}
.header-title h1 {
    font-size: 1.5rem;
    margin: 0;
    font-weight: 600;
    color: var(--text-color);
}
[data-theme="dark"] .header-title h1 { color: var(--text-color); }
.header-actions {
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.notification-wrapper {
    position: relative;
    display: flex;
}
.notification-btn, .user-btn, .logout-btn {
    background: none;
    border: none;
    font-size: 1.2rem;
    color: var(--text-light);
    cursor: pointer;
    position: relative;
    padding: 0.5rem;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all var(--transition-fast);
}
[data-theme="dark"] .notification-btn, [data-theme="dark"] .user-btn, [data-theme="dark"] .logout-btn {
    color: var(--text-light);
}
.notification-btn:hover, .user-btn:hover, .logout-btn:hover {
    background-color: var(--background-color);
}
[data-theme="dark"] .notification-btn:hover, [data-theme="dark"] .user-btn:hover, [data-theme="dark"] .logout-btn:hover {
    background-color: var(--content-bg);
}
.notification-badge {
    position: absolute;
    top: 5px;
    right: 5px;
    background-color: var(--danger-color);
    color: white;
    border-radius: 50%;
    width: 18px;
    height: 18px;
    font-size: 0.7rem;
    display: flex;
    justify-content: center;
    align-items: center;
    font-weight: bold;
}
.user-info {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
#currentUserName {
    font-weight: 500;
    max-width: 120px; 
    overflow: hidden; 
    text-overflow: ellipsis; 
    white-space: nowrap; 
}
.user-profile .user-btn {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.5rem;
    border-radius: 20px;
}
/* Connection Status Indicators */
#syncStatusBtn { /* Using #firebaseSyncBtn in HTML for this now */
    position: relative;
    transition: color 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0.5rem;
}
#syncStatusBtn.online {
    color: var(--success-color);
}
#syncStatusBtn.offline {
    color: var(--danger-color);
}
#syncStatusBtn.syncing {
    color: var(--warning-color);
}
#syncStatusBtn::after {
    content: '';
    position: absolute;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    bottom: 5px;
    right: 5px;
}
#syncStatusBtn.online::after {
    background: var(--success-color);
}
#syncStatusBtn.offline::after {
    background: var(--danger-color);
}
#syncStatusBtn.syncing::after {
    background: var(--warning-color);
}
/* Integration Status Indicator */
.integration-status-indicator {
    display: inline-block;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    margin-left: 0.5em;
    vertical-align: middle;
    border: 1px solid rgba(0,0,0,0.1); /* Subtle border for visibility on different backgrounds */
}
.integration-status-indicator.status-green {
    background-color: var(--success-color);
}
.integration-status-indicator.status-red {
    background-color: var(--danger-color);
}
.integration-status-indicator.status-yellow {
    background-color: var(--warning-color);
}
.integration-status-indicator.status-orange { /* For specific orange status like 'no recipients' */
    background-color: #f59e0b; /* Tailwind orange-500 */
}
/* Update for dark mode */
[data-theme="dark"] .integration-status-indicator.status-green {
    background-color: var(--success-color);
}
[data-theme="dark"] .integration-status-indicator.status-red {
    background-color: var(--danger-color);
}
[data-theme="dark"] .integration-status-indicator.status-yellow {
    background-color: var(--warning-color);
}
[data-theme="dark"] .integration-status-indicator.status-orange {
    background-color: #d97706; /* Darker orange for dark mode */
}

/* General Buttons */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.75rem 1.25rem;
    border-radius: var(--radius-md);
    font-size: 0.9rem;
    font-weight: 600;
    cursor: pointer;
    transition: all var(--transition-normal);
    white-space: nowrap;
    text-decoration: none;
    line-height: 1.2;
    outline: none;
}
.btn:focus-visible {
    outline: 2px solid var(--primary-color);
    outline-offset: 2px;
    box-shadow: 0 0 0 3px rgba(203, 12, 159, 0.1);
}
[data-theme="dark"] .btn:focus-visible {
    outline: 2px solid var(--primary-color);
    box-shadow: 0 0 0 3px rgba(233, 30, 99, 0.2);
}
.btn-primary {
    background: linear-gradient(195deg, var(--primary-color), #ec407a);
    color: white;
    border: none;
    box-shadow: var(--shadow-md);
}
.btn-primary:hover {
    background: linear-gradient(195deg, var(--primary-hover), #d81b60);
    box-shadow: var(--shadow-lg);
    transform: translateY(-2px);
}
.btn-primary:active {
    background: linear-gradient(195deg, var(--primary-hover), #c2185b);
    transform: translateY(0);
    box-shadow: var(--shadow-inset);
}
[data-theme="dark"] .btn-primary {
    background: linear-gradient(195deg, #e91e63, #d81b60);
    box-shadow: var(--shadow-md);
}
[data-theme="dark"] .btn-primary:hover {
    background: linear-gradient(195deg, #d81b60, #c2185b);
    box-shadow: var(--shadow-lg);
}
.btn-secondary {
    background: var(--content-bg);
    color: var(--text-color);
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow-sm);
}
.btn-secondary:hover {
    background: var(--background-color);
    border-color: #aeb8c6;
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}
.btn-secondary:active {
    transform: translateY(0);
    background: var(--border-color);
    box-shadow: var(--shadow-inset);
}
[data-theme="dark"] .btn-secondary {
    background: var(--background-color);
    color: var(--text-color);
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow-sm);
}
[data-theme="dark"] .btn-secondary:hover {
    background: var(--content-bg);
    border-color: #aeb8c6;
    box-shadow: var(--shadow-md);
}
.btn-danger {
    background: linear-gradient(195deg, var(--danger-color), #ef5350);
    color: white;
    border: none;
    box-shadow: var(--shadow-md);
}
.btn-danger:hover {
    background: linear-gradient(195deg, #d32f2f, #d32f2f);
    box-shadow: var(--shadow-lg);
    transform: translateY(-2px);
}
.btn-danger:active {
    transform: translateY(0);
    box-shadow: var(--shadow-inset);
}
[data-theme="dark"] .btn-danger {
    background: linear-gradient(195deg, #f05252, #e53935);
    box-shadow: var(--shadow-md);
}
[data-theme="dark"] .btn-danger:hover {
    background: linear-gradient(195deg, #d32f2f, #c62828);
    box-shadow: var(--shadow-lg);
}
.btn-full {
    width: 100%;
}
.btn-sm {
    padding: 0.5rem 0.9rem;
    font-size: 0.82rem;
    border-radius: var(--radius-sm);
}
.btn-xs {
    padding: 0.35rem 0.6rem;
    font-size: 0.7rem;
    border-radius: var(--radius-sm);
}
.btn:disabled, .btn[disabled] {
    opacity: 0.6;
    cursor: not-allowed;
    box-shadow: none;
    transform: none;
}

/* Tables */
.table-container {
    background: var(--card-bg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-soft-ui);
    overflow-x: auto; /* Allows horizontal scrolling for table content */
    border: none;
    padding: 0;
    width: 100%; 
    max-width: 100%; 
}
[data-theme="dark"] .table-container {
    background: var(--card-bg);
}
.table-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.5rem;
    border-bottom: 1px solid var(--border-color);
}
[data-theme="dark"] .table-header {
    border-bottom: 1px solid var(--border-color);
    background: var(--card-bg);
}
.table-title {
    font-size: 1.25rem;
    font-weight: 600;
    margin: 0;
    color: var(--text-color);
}
.data-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    table-layout: auto; /* Ensure table layout is auto to respect min-width of cells */
}
.data-table th, .data-table td {
    padding: 0.75rem 1rem;
    border-bottom: 1px solid var(--border-color);
    transition: background var(--transition-fast);
    color: var(--text-color);
}
.data-table td:first-child, .data-table th:first-child {
  border-left: none;
}
.data-table td:last-child, .data-table th:last-child {
  border-right: none;
}
.data-table tbody tr:last-child td {
  border-bottom: none;
}
[data-theme="dark"] .data-table td {
    color: var(--text-color);
}
.data-table th {
    background: var(--background-color);
    font-weight: 600;
    color: var(--text-color);
    font-size: 0.875rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
[data-theme="dark"] .data-table th {
    background: var(--background-color);
    color: var(--text-color);
}
.data-table tbody tr:hover td {
    background: var(--primary-light);
}
[data-theme="dark"] .data-table tbody tr:hover td {
    background: var(--background-color);
}
/* Pagination */
.pagination-container {
    display: flex; justify-content: center; align-items: center; gap: 0.5rem; margin-top: 1.5rem; }
.pagination-item {
    background: #fff; border: 1px solid #e2e8f0; border-radius: 0.5rem;
    min-width: 36px; height: 36px; padding: 0 0.75rem;
    cursor: pointer; transition: all 0.2s; font-weight: 500;
    display: inline-flex; align-items: center; justify-content: center;
}
.pagination-item:hover:not(:disabled) { background: #f1f5f9; border-color: #cbd5e1; }
.pagination-item.active { background: var(--primary-color); color: white; border-color: var(--primary-color); }
.pagination-item:disabled { opacity: 0.5; cursor: not-allowed; }
.pagination-item.ellipsis { border: none; background: none; cursor: default; }

/* Status Badges */
.status-badge {
    padding: 0.375rem 0.75rem;
    border-radius: var(--radius-sm);
    font-size: 0.75rem;
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    position: relative;
    overflow: hidden;
    background: var(--primary-light);
    color: var(--primary-color);
    border: none;
}
.status-badge::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 100%;
    background: linear-gradient(45deg, transparent, rgba(255,255,255,0.2), transparent);
    animation: shimmer 2s infinite;
}
.status-confirmed, .status-active, .status-available {
    background-color: #e6f7ef;
    color: #2dce89;
}
[data-theme="dark"] .status-badge.status-confirmed, [data-theme="dark"] .status-badge.status-active, [data-theme="dark"] .status-badge.status-available {
    background-color: #48bb78;
    color: white;
}
.status-pending {
    background-color: #fff0e6;
    color: #fb6340;
}
[data-theme="dark"] .status-badge.status-pending {
    background-color: #ed8936;
    color: white;
}
.status-cancelled, .status-occupied, .status-inactive {
    background-color: #fce6eb;
    color: #f5365c;
}
[data-theme="dark"] .status-badge.status-cancelled, [data-theme="dark"] .status-badge.status-occupied, [data-theme="dark"] .status-badge.status-inactive {
    background-color: #f05252;
    color: white;
}
.status-maintenance, .status-checkout {
    background-color: #e2e8f0;
    color: #67748e;
}
[data-theme="dark"] .status-badge.status-maintenance, [data-theme="dark"] .status-badge.status-checkout {
    background-color: #4a5568;
    color: white;
}

/* Forms */
.form-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 1.25rem;
}
.form-group {
    display: flex;
    flex-direction: column;
}
.form-label {
    font-weight: 500;
    margin-bottom: 0.4rem;
    font-size: 0.9rem;
    color: var(--text-color);
}
[data-theme="dark"] .form-label { color: var(--text-color); }
.form-label.required::after {
    content: ' *';
    color: var(--danger-color);
}
.form-input, .form-select, .form-textarea {
    width: 100%;
    padding: 0.65rem 0.9rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    font-size: 0.92rem;
    transition: all 0.2s ease;
    background: var(--content-bg);
    color: var(--text-color);
}
[data-theme="dark"] .form-input, [data-theme="dark"] .form-select, [data-theme="dark"] .form-textarea {
    background: var(--background-color);
    border-color: var(--border-color);
    color: var(--text-color);
}
.form-input:hover, .form-select:hover, .form-textarea:hover {
    border-color: var(--secondary-color);
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(203, 12, 159, 0.1);
}
[data-theme="dark"] .form-input:focus, [data-theme="dark"] .form-select:focus, [data-theme="dark"] .form-textarea:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(233, 30, 99, 0.1);
}
.form-help {
    color: var(--text-light);
    font-size: 0.85rem;
    margin-top: 0.2rem;
}
[data-theme="dark"] .form-help { color: var(--text-light); }
.input-error-message {
    color: var(--danger-color);
    background: #fdf3f5;
    border-radius: var(--radius-sm);
    margin-top: 0.3rem;
    padding: 0.4rem 0.8rem;
    font-size: 0.9rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
/* Input Group for Date Range Picker */
.input-group {
    display: flex;
    align-items: center;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    overflow: hidden;
    transition: all 0.2s ease;
    background: var(--content-bg);
}
[data-theme="dark"] .input-group {
    background: var(--background-color);
}
.input-group .form-input {
    border: none;
    border-radius: 0;
    padding: 0.65rem 0.5rem;
    background: transparent;
}
.input-group .form-input:focus {
    box-shadow: none;
}
.input-group-text {
    padding: 0 0.75rem;
    background: var(--background-color);
    color: var(--text-light);
}
[data-theme="dark"] .input-group-text {
    background: var(--content-bg);
}
/* Modern Datepicker Styles */
.datepicker {
    background-color: var(--content-bg);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-md);
    color: var(--text-color);
    font-size: 0.95rem;
}
.datepicker-picker .datepicker-controls .button {
    background-color: transparent;
    border: none;
    color: var(--text-color);
    font-size: 1rem;
    padding: 0.5rem;
    border-radius: var(--radius-sm);
    transition: background-color 0.15s ease;
    cursor: pointer;
}
.datepicker-picker .datepicker-controls .button:hover:not(:disabled) {
    background-color: var(--primary-light);
    color: var(--primary-color);
}
.datepicker-picker .datepicker-controls .datepicker-title {
    color: var(--text-color);
    font-weight: 600;
}
.datepicker-grid {
    padding: 0.5rem;
}
.datepicker-cell {
    color: var(--text-color);
    border-radius: var(--radius-sm);
    transition: background-color 0.15s ease;
    padding: 0.4rem 0.2rem;
}
.datepicker-cell.day, .datepicker-cell.month, .datepicker-cell.year {
    height: 32px;
    line-height: 32px;
    cursor: pointer;
}
.datepicker-cell:hover:not(.disabled):not(.selected),
.datepicker-cell.month:hover:not(.disabled):not(.selected),
.datepicker-cell.year:hover:not(.disabled):not(.selected) {
    background-color: var(--primary-light);
    color: var(--primary-color);
}
.datepicker-cell.selected {
    background-color: var(--primary-color);
    color: white;
}
.datepicker-cell.selected:hover {
    background-color: var(--primary-hover);
    color: white;
}
.datepicker-cell.today {
    border: 1px solid #5a0000;
    background-color: #fce6eb;
}
[data-theme="dark"] .datepicker-cell.today {
    border: 1px solid #4a333f;
    background-color: #4a333f;
}
.datepicker-cell.disabled {
    color: var(--text-light);
    opacity: 0.6;
    cursor: not-allowed;
    background-color: transparent;
}
/* Dark mode specific overrides for datepicker to ensure good contrast */
[data-theme="dark"] .datepicker {
    background-color: var(--card-bg);
    border-color: var(--border-color);
    color: var(--text-color);
}
[data-theme="dark"] .datepicker-picker .datepicker-controls .button {
    color: var(--text-color);
}
[data-theme="dark"] .datepicker-picker .datepicker-controls .button:hover:not(:disabled) {
    background-color: var(--primary-light);
    color: var(--text-color);
}
[data-theme="dark"] .datepicker-picker .datepicker-controls .datepicker-title {
    color: var(--text-color);
}
[data-theme="dark"] .datepicker-grid {
    padding: 0.5rem;
}
[data-theme="dark"] .datepicker-cell {
    color: var(--text-color);
}
[data-theme="dark"] .datepicker-cell.day:hover:not(.disabled):not(.selected),
[data-theme="dark"] .datepicker-cell.month:hover:not(.disabled):not(.selected),
[data-theme="dark"] .datepicker-cell.year:hover:not(.disabled):not(.selected) {
    background-color: var(--primary-light); /* Dark mode's primary-light */
    color: var(--text-color); /* Keep text color readable */
}
[data-theme="dark"] .datepicker-cell.selected {
    background-color: var(--primary-color); /* Dark mode's primary color */
    color: white;
}
[data-theme="dark"] .datepicker-cell.selected:hover {
    background-color: var(--primary-hover); /* Dark mode's primary-hover */
    color: white;
}
[data-theme="dark"] .datepicker-cell.today {
    border-color: var(--primary-color); /* Dark mode's primary color */
    color: var(--text-color);
}
[data-theme="dark"] .datepicker-cell.disabled {
    color: var(--text-light);
}
/* Ensure proper spacing for the input group with datepicker */
.input-group .form-input[type="text"][name="checkIn"],
.input-group .form-input[type="text"][name="checkOut"] {
    flex: 1; /* Allow inputs to grow within the group */
    min-width: 80px; /* Ensure they don't get too small */
}

/* Modals */
.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 1000;
    padding: 1rem;
}
.modal {
    background: var(--content-bg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-soft-ui);
    width: 100vw;
    max-width: 820px;
    min-width: 0;
    min-height: 0;
    max-height: 94vh;
    height: auto;
    display: flex;
    flex-direction: column;
    animation: modalSlideIn 0.3s ease-out;
    margin: auto;
}
[data-theme="dark"] .modal {
    background: var(--card-bg);
    box-shadow: var(--shadow-soft-ui);
}
.modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.9rem 1.2rem;
    border-bottom: 1px solid var(--border-color);
}
[data-theme="dark"] .modal-header {
    border-bottom: 1px solid var(--border-color);
}
.modal-title {
    font-size: 1.25rem;
    font-weight: 600;
    margin: 0;
    color: var(--text-color);
}
[data-theme="dark"] .modal-title { color: var(--text-color); }
.modal-close {
    background: none;
    border: none;
    font-size: 1.5rem;
    color: var(--text-light);
    cursor: pointer;
}
[data-theme="dark"] .modal-close { color: var(--text-light); }
.modal-body {
    padding: 1.2rem;
    overflow-y: auto;
}
.modal-footer {
    padding: 0.9rem 1.2rem;
    border-top: 1px solid var(--border-color);
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
}
[data-theme="dark"] .modal-footer {
    border-top: 1px solid var(--border-color);
}

/* Notifications */
.notification-container {
    position: fixed;
    top: 1.5rem; /* Default top position on desktop */
    right: 1.5rem; /* Default right position on desktop */
    z-index: 9999;
    display: flex;
    flex-direction: column-reverse; /* Stacks new notifications above old ones */
    gap: 0.75rem;
    pointer-events: none; /* Allows clicks through the container, but not on individual notifications */
    width: 100%; /* For mobile full width */
    max-width: 420px; /* Default desktop max width */
    align-items: flex-end; /* Aligns notifications to the right within the container */
}

/* Specific styling for when it should appear below the header and near the icon */
.notification-container.below-header {
    top: calc(64px + 0.5rem); /* Below header (64px height), slightly below the actual header-actions bar */
    right: 1.5rem; /* Align to the right edge of the header actions */
    left: unset; /* Remove left constraint if it was set for centering */
    margin: unset; /* Remove margin auto if it was set for centering */
    max-width: 420px; /* Keep consistent with default notification width */
    align-items: flex-end; /* Still align notifications to the right inside the container */
}

@media (max-width: 900px) {
  .notification-container {
      /* Keep top, left, right for full mobile width */
      top: 55px; /* Adjust top for smaller header */
      left: 10px;
      right: 10px;
      width: auto;
      max-width: none;
      align-items: center; /* Center notifications on mobile */
  }
  .notification-container.below-header {
    top: calc(48px + 0.5rem); /* Adjust for smaller mobile header (48px height) */
    left: 10px;
    right: 10px;
    max-width: 97%;
    align-items: center;
  }
}
.notification {
    display: flex;
    align-items: flex-start;
    padding: 0.8rem 1rem;
    border-radius: var(--radius-lg);
    background: var(--content-bg);
    border: none;
    margin-bottom: 0.75rem;
    animation: slideInBelowHeader 0.38s cubic-bezier(.28,.53,.47,1.17);
    box-shadow: var(--shadow-md);
    min-width: 260px;
    min-height: 50px;
    pointer-events: all;
    position: relative;
    max-width: 98vw;
    transition: box-shadow 0.15s;
    overflow: visible;
}
[data-theme="dark"] .notification {
    background: var(--card-bg);
}
.notification.success { background-color: #e6f7ef; color: #2dce89; }
.notification.error { background-color: #fce6eb; color: #f5365c; }
.notification.warning { background-color: #fff0e6; color: #fb6340; }
.notification.info { background-color: #e6f3fa; color: #11cdef; }
[data-theme="dark"] .notification.success { background-color: #48bb78; color: white; }
[data-theme="dark"] .notification.error { background-color: #f05252; color: white; }
[data-theme="dark"] .notification.warning { background-color: #ed8936; color: white; }
[data-theme="dark"] .notification.info { background-color: #36a3b8; color: white; }
.notification-icon { 
    font-size: 1.2rem; 
    margin-right: 0.8rem;
    animation: fadeInScale 0.33s cubic-bezier(0.28, 0.68, 0.53, 1.01);
}
.notification-title { font-weight: 600; margin-bottom: 0.15rem; color: var(--text-color); }
.notification-message { font-size: 0.9rem; color: var(--text-light); }
.notification-close {
    margin-left: auto;
    background: none;
    border: none;
    color: var(--text-light);
    cursor: pointer;
    font-size: 0.9rem;
    opacity: 0.65;
    padding: 2px 5px;
    border-radius: 6px;
    transition: background 0.15s;
}
.notification-close:hover { background: var(--background-color);}
.notification.slide-out {
    animation: slideOutBelowHeader 0.36s cubic-bezier(0.32, 0, 0.53, 1.25) forwards;
    opacity: 0;
}

/* NEW: Notification Archive Modal Styles */
.notification-archive-modal-content {
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
}

.notification-archive-item {
    display: flex;
    align-items: flex-start;
    padding: 0.8rem;
    border-radius: var(--radius-md);
    background-color: var(--background-color); /* Light gray for unread */
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--border-color);
    transition: all 0.2s ease;
    cursor: pointer;
}
[data-theme="dark"] .notification-archive-item {
    background-color: var(--background-color);
}

.notification-archive-item.read {
    background-color: #f8fafc; /* Even lighter for read */
    opacity: 0.7;
    border-color: #f1f5f9;
}
[data-theme="dark"] .notification-archive-item.read {
    background-color: #262c38;
    opacity: 0.7;
}

.notification-archive-item:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}

.notification-archive-icon {
    font-size: 1.1rem;
    margin-right: 0.8rem;
    color: var(--primary-color);
    flex-shrink: 0;
    line-height: 1.4;
}
/* Specific colors for icons in archive */
.notification-archive-item.read .notification-archive-icon { color: var(--text-light); }
.notification-archive-item.read .notification-archive-title { color: var(--text-light); font-weight: normal;}
.notification-archive-item.read .notification-archive-message { color: var(--text-light); opacity: 0.8; }


.notification-archive-details {
    flex-grow: 1;
}

.notification-archive-title {
    font-weight: 600;
    color: var(--text-color);
    margin-bottom: 0.2rem;
    font-size: 0.95rem;
}

.notification-archive-message {
    font-size: 0.85rem;
    color: var(--text-light);
    line-height: 1.4;
}

.notification-archive-meta {
    font-size: 0.75rem;
    color: var(--text-light);
    margin-top: 0.4rem;
}

.notification-archive-actions {
    margin-left: 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    flex-shrink: 0;
}
.notification-archive-actions .btn-xs {
    min-width: 80px;
}
@media (max-width: 768px) {
    .notification-archive-item {
        flex-direction: column;
        align-items: flex-start;
    }
    .notification-archive-actions {
        flex-direction: row;
        margin-top: 0.8rem;
        margin-left: 0;
        width: 100%;
        justify-content: flex-end;
    }
    .notification-archive-icon {
        margin-bottom: 0.5rem;
    }
}
@media (max-width: 768px) {
    .content-area {
        padding-top: calc(48px + 0.5rem); 
    }
}

/* Dashboard styles */
.dashboard-overview {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}
.dashboard-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--card-bg);
    padding: 2rem;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-soft-ui);
}

.dashboard-header h2 {
    font-size: 2rem;
    font-weight: 700;
    margin: 0 0 0.5rem 0;
    color: var(--text-color);
}

.dashboard-header p {
    font-size: 1rem;
    color: var(--text-light);
    margin: 0;
}

.dashboard-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 1.5rem;
}
.stat-card, .operational-card {
    background: var(--card-bg);
    border-radius: var(--radius-lg);
    padding: 1.25rem;
    box-shadow: var(--shadow-soft-ui);
    border: none;
    transition: all 0.3s ease;
    overflow: hidden;
    position: relative;
}
[data-theme="dark"] .stat-card, [data-theme="dark"] .operational-card {
    background: var(--card-bg);
}
.stat-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 20px rgba(0,0,0,0.15);
}
.stat-card-header, .card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 0.8rem;
}
.stat-card-title, .card-title {
    font-weight: 600;
    color: var(--text-color);
}
.stat-card-icon, .card-icon {
    width: 44px;
    height: 44px;
    border-radius: var(--radius-md);
    display: flex;
    justify-content: center;
    align-items: center;
    color: white;
    font-size: 1.1rem;
    background: linear-gradient(195deg, var(--primary-color), #ec407a);
    box-shadow: var(--shadow-md);
}
[data-theme="dark"] .stat-card-icon, [data-theme="dark"] .card-icon {
    background: linear-gradient(195deg, #e91e63, #d81b60);
}
.stat-card-value, .metric-value {
    font-size: 2rem;
    font-weight: 700;
    color: var(--text-color);
}
.stat-card-change {
    font-size: 0.875rem;
    margin-top: 0.5rem;
    color: var(--text-light);
}
.stat-card-change i {
    margin-right: 0.25rem;
}
.positive { color: var(--success-color); }
.negative { color: var(--danger-color); }
[data-theme="dark"] .stat-card-change { color: var(--text-light); }

.financial-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--border-color);
}

.financial-item:last-child {
    border-bottom: none;
}

.financial-item span {
    font-weight: 500;
}

.financial-item strong {
    font-size: 1.1rem;
}

.alert-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.alert-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem;
    border-radius: var(--radius-md);
    background: var(--background-color);
    transition: background-color 0.2s;
    cursor: pointer;
}

.alert-item:hover {
    background: var(--primary-light);
}

.alert-icon {
    font-size: 1.2rem;
}

.alert-icon.warning {
    color: var(--warning-color);
}

.alert-icon.danger {
    color: var(--danger-color);
}

.alert-item span {
    flex-grow: 1;
    font-weight: 500;
}

.alert-count {
    font-weight: 700;
    padding: 0.25rem 0.5rem;
    border-radius: var(--radius-sm);
    color: white;
}

.alert-count.warning {
    background: var(--warning-color);
}

.alert-count.danger {
    background: var(--danger-color);
}

.tabs {
    display: flex;
    border-bottom: 1px solid var(--border-color);
    margin-bottom: 1rem;
}

.tab-button {
    padding: 0.75rem 1rem;
    border: none;
    background: none;
    cursor: pointer;
    font-weight: 500;
    color: var(--text-light);
    border-bottom: 2px solid transparent;
    transition: all 0.2s;
}

.tab-button.active {
    color: var(--primary-color);
    border-bottom-color: var(--primary-color);
}

.tab-content {
    display: none;
}

.tab-content.active {
    display: block;
}

.event-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.75rem 0.5rem;
    border-bottom: 1px solid var(--border-color);
    cursor: pointer;
    border-radius: var(--radius-sm);
    transition: background-color 0.2s;
}

.event-item:hover {
    background-color: var(--background-color);
}

.event-item:last-child {
    border-bottom: none;
}

.event-guest-info {
    display: flex;
    flex-direction: column;
}

.guest-name {
    font-weight: 600;
}

.room-info {
    font-size: 0.875rem;
    color: var(--text-light);
}

.debt-badge {
    color: var(--danger-color);
    font-weight: 600;
    font-size: 0.875rem;
}

.paid-badge {
    color: var(--success-color);
    font-weight: 600;
    font-size: 0.875rem;
}

.chart-card .card-header {
    border-bottom: 1px solid var(--border-color);
    padding-bottom: 1rem;
}

.chart-container {
    position: relative;
    padding-top: 1rem;
}

/* System error styles */
.system-error {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100vh;
    background: var(--background-color);
    font-family: Arial, sans-serif;
}
.error-card {
    text-align: center;
    background: var(--content-bg);
    padding: 2rem;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-soft-ui);
    max-width: 500px;
    color: var(--text-color);
}
.error-title {
    color: var(--danger-color);
    margin-bottom: 1rem;
}
.error-message {
    color: var(--text-color);
    margin-bottom: 2rem;
}
.error-details {
    margin-top: 1rem;
    padding: 1rem;
    background: var(--background-color);
    border-radius: var(--radius-md);
    font-family: monospace;
    font-size: 0.875rem;
    color: var(--text-light);
    text-align: left;
    word-break: break-all;
}
/* System Error Log Table Styles */
.error-log-card {
    background: var(--card-bg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-soft-ui);
    overflow: hidden;
    border: none;
}
.error-log-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.25rem;
    border-bottom: 1px solid var(--border-color);
}
.error-log-title {
    font-size: 1.25rem;
    font-weight: 600;
    margin: 0;
    color: var(--text-color);
}
.error-log-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
}
.error-log-table th, .error-log-table td {
    border-bottom: 1px solid var(--border-color);
    padding: 0.65rem 0.9rem;
    text-align: left;
    vertical-align: top;
    color: var(--text-color);
}
.error-log-table th {
    background-color: var(--background-color);
    font-weight: 600;
    color: var(--text-color);
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.error-log-table tbody tr:hover td {
    background: var(--primary-light);
}
.error-log-table .error-message-col {
    max-width: 350px;
    white-space: pre-wrap;
    word-break: break-word;
    font-family: monospace;
    font-size: 0.9em;
}
.error-log-table .error-stack-col {
    max-width: 400px;
    white-space: pre-wrap;
    word-break: break-all;
    font-family: monospace;
    font-size: 0.85em;
    color: var(--text-light);
}
.error-log-table .error-status-badge {
    padding: 0.3em 0.6em;
    border-radius: var(--radius-sm);
    font-size: 0.8em;
    font-weight: 500;
    display: inline-block;
}
.error-log-table .status-resolved {
    background-color: #e6f7ef;
    color: #2dce89;
}
.error-log-table .status-unresolved {
    background-color: #fce6eb;
    color: #f5365c;
}

/* Settings Page */
.settings-modern-container {
    display: flex;
    flex-direction: row;
    gap: 1.5rem;
}
.settings-menu {
    flex: 0 0 300px;
    background: var(--card-bg);
    border-radius: var(--radius-lg);
    padding: 1.25rem;
    box-shadow: var(--shadow-soft-ui);
}
[data-theme="dark"] .settings-menu {
    background: var(--card-bg);
}
.settings-menu-header {
    font-size: 1.2rem;
    font-weight: 700;
    margin-bottom: 1.25rem;
    color: var(--text-color);
    display: flex;
    align-items: center;
    gap: 0.7rem;
}
.settings-menu-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
.settings-menu-btn {
    width: 100%;
    background: var(--content-bg);
    color: var(--text-color);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: 0.7rem 0.9rem;
    display: flex;
    align-items: center;
    gap: 1rem;
    text-align: left;
    font-size: 0.92rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
    white-space: nowrap;
    box-shadow: var(--shadow-sm);
}
[data-theme="dark"] .settings-menu-btn {
    background: var(--background-color);
    color: var(--text-color);
    border: 1px solid var(--border-color);
}
.settings-menu-btn.active, .settings-menu-btn:hover {
    background: var(--primary-light);
    border-color: var(--primary-color);
    color: var(--primary-color);
}
[data-theme="dark"] .settings-menu-btn.active {
    background: var(--primary-light);
    color: var(--text-color);
    border-color: var(--primary-color);
}
[data-theme="dark"] .settings-menu-btn:hover {
    background: var(--primary-light);
}
.settings-menu-icon {
    font-size: 1.1rem;
    width: 24px;
    text-align: center;
}
.settings-menu-text {
    flex-grow: 1;
}
.settings-menu-desc {
    display: block;
    font-size: 0.8em;
    color: var(--text-light);
    font-weight: 400;
    margin-top: 2px;
}
[data-theme="dark"] .settings-menu-btn small {
    color: var(--text-light);
}
.settings-menu-chevron {
    color: var(--text-light);
}
.settings-main {
    flex: 1;
    background: var(--card-bg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-soft-ui);
    padding: 1.8rem;
}
[data-theme="dark"] .settings-main {
    background: var(--card-bg);
}
.settings-content-header {
    display: none; /* Hidden on desktop, shown on mobile */
}
[data-theme="dark"] .settings-content-header {
    background: var(--card-bg);
    border-bottom-color: var(--border-color);
}
/* Danger Zone */
.danger-zone-section {
    background-color: var(--danger-color-light); /* Uses #fef2f2 in light mode */
    border: 2px solid var(--danger-color);
    color: var(--text-color); /* Main text color for readability */
}
.danger-zone-section .table-header .table-title {
    color: var(--danger-color); /* Keep the red color for the title */
}
.danger-zone-section h4.card-title {
    color: var(--text-color); /* Ensure sub-headings are dark for readability on light background */
}
.danger-zone-section p {
    color: var(--text-light); /* Keep paragraphs slightly lighter but readable */
}
/* Dark mode overrides for Danger Zone */
[data-theme="dark"] .danger-zone-section {
    background-color: #632c3f; /* A darker red for dark mode, providing better contrast */
    border-color: var(--danger-color); /* Keep the primary danger color for border */
    color: var(--text-color); /* Will be white/light in dark mode */
}
[data-theme="dark"] .danger-zone-section .table-header .table-title {
    color: var(--danger-color);
}
[data-theme="dark"] .danger-zone-section h4.card-title {
    color: var(--text-color); /* Will be white/light in dark mode */
}
[data-theme="dark"] .danger-zone-section p {
    color: var(--text-light); /* Will be lighter white/gray in dark mode */
}

/* Category & Permission Styles */
.category-inline-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5em;
    align-items: center;
    margin-bottom: 0.4rem;
}
.category-chip {
    background: var(--primary-light);
    color: var(--primary-color);
    padding: 0.45em 0.95em 0.45em 0.87em;
    border-radius: var(--radius-md);
    margin-right: 0.5em;
    margin-bottom: 0.4em;
    display: inline-flex;
    align-items: center;
    gap: 0.35em;
}
.category-chip-input-wrapper {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    background: var(--background-color);
    padding: 0.4rem 0.6rem;
    border-radius: var(--radius-md);
    border: 1px solid var(--border-color);
}
.category-chip-input-wrapper .form-input {
    border: none;
    padding: 0.2rem;
    background: transparent;
    box-shadow: none;
    font-size: 0.9em;
}
.category-chip-input-wrapper .form-input:focus {
    box-shadow: none;
}
.category-chip-delete {
    background: none;
    border: none;
    color: var(--danger-color);
    cursor: pointer;
    font-size: 1.05em;
    margin-left: 0.35em;
    transition: color 0.17s;
}
.category-chip-delete:hover {
    color: #b91c1c;
}
.permission-checkboxes-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(70px, 1fr));
    gap: 0.4rem;
    padding: 0.4rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    background: var(--background-color);
    font-size: 0.88em;
}
[data-theme="dark"] .permission-checkboxes-grid {
    background: var(--background-color);
    border-color: var(--border-color);
}
.permission-checkbox-label {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    cursor: pointer;
    white-space: nowrap;
    padding: 0.08em 0.4em;
    transition: background-color 0.15s ease;
    border-radius: var(--radius-sm);
}
.permission-checkbox-label:hover {
    background-color: var(--primary-light);
}
[data-theme="dark"] .permission-checkbox-label:hover {
    background-color: var(--primary-light);
}
.permission-checkbox-label input[type="checkbox"] {
    transform: scale(0.9);
    margin-right: 0.2em;
    cursor: pointer;
}
.modal .data-table th, .modal .data-table td {
    padding: 0.45rem 0.75rem;
}
.modal .data-table th:nth-child(3) {
    width: 35%;
}

/* Calendar Styles (General for Reservations and Rooms) */
.calendar-container {
    background-color: var(--card-bg);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-soft-ui);
    border: none;
}
[data-theme="dark"] .calendar-container {
    background-color: var(--card-bg);
}
.calendar-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-lg);
}
.calendar-header h2 {
    margin: 0;
    font-size: 1.4rem;
    font-weight: 600;
    color: var(--text-color);
}
.calendar-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 4px;
}
.calendar-day-name {
    text-align: center;
    font-weight: 600;
    color: var(--text-light);
    padding-bottom: 0.5rem;
}
.calendar-day {
    background-color: var(--background-color);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    min-height: 100px;
    padding: 0.4rem;
    display: flex;
    flex-direction: column;
    color: var(--text-color);
}
[data-theme="dark"] .calendar-day {
    background-color: var(--background-color);
    border: 1px solid var(--border-color);
}
.calendar-day.empty {
    background-color: transparent;
    border: 1px solid transparent;
}
.calendar-day.today {
    border: 2px solid #5a0000;
    background-color: #fce6eb;
}
[data-theme="dark"] .calendar-day.today {
    border: 2px solid #4a333f;
    background-color: #4a333f;
}
.day-number {
    font-weight: 500;
    margin-bottom: 0.4rem;
}
.reservations-on-day {
    display: flex;
    flex-direction: column;
    gap: 3px;
    overflow-y: auto;
    max-height: 70px;
}
.reservation-cal-item {
    background-color: var(--primary-color);
    color: white;
    padding: 2px 5px;
    border-radius: var(--radius-sm);
    font-size: 0.7rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    cursor: pointer;
    transition: background-color 0.2s;
}
[data-theme="dark"] .reservation-cal-item {
    background-color: var(--primary-color);
}
.reservation-cal-item:hover {
    background-color: var(--primary-hover);
}
.reservation-cal-item.pending {
    background-color: var(--warning-color);
    color: white;
}
[data-theme="dark"] .reservation-cal-item.pending {
    background-color: var(--warning-color);
}
.reservation-cal-item.pending:hover {
    background-color: #d97706;
}
[data-theme="dark"] .reservation-cal-item.pending:hover {
    background-color: var(--warning-color);
}
/* Rooms Calendar */
.rooms-calendar-container {
    background-color: var(--card-bg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-soft-ui);
    border: none;
    overflow-x: auto;
    min-width: 0;
}
.rooms-calendar-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.9rem 1.2rem;
    border-bottom: 1px solid var(--border-color);
}
.rooms-calendar-header h2 {
    margin: 0;
    font-size: 1.15rem;
    font-weight: 600;
    color: var(--text-color);
}
.rooms-calendar-nav button { /* Reusing .btn styles where possible */
    background: none;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: 0.4rem 0.6rem;
    cursor: pointer;
    transition: all 0.2s;
}
.rooms-calendar-nav button:hover {
    background-color: var(--primary-light);
    border-color: var(--primary-color);
}
[data-theme="dark"] .rooms-calendar-nav button {
    background: var(--background-color);
    border: 1px solid var(--border-color);
    color: var(--text-color);
}
[data-theme="dark"] .rooms-calendar-nav button:hover {
    background-color: var(--content-bg);
}
.rooms-calendar-table-wrapper {
    width: 100%;
    overflow-x: auto;
    padding-bottom: 15px;
}
.rooms-calendar-table {
    width: auto;
    min-width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    font-size: 0.875rem;
}
.rooms-calendar-table th, .rooms-calendar-table td {
    padding: 0.45rem 0.65rem;
    border-bottom: 1px solid var(--border-color);
    text-align: center;
    white-space: nowrap;
    min-width: 55px;
    height: 45px;
    color: var(--text-color);
}
.rooms-calendar-table td:first-child, .rooms-calendar-table th:first-child {
  border-left: none;
}
.rooms-calendar-table td:last-child, .rooms-calendar-table th:last-child {
  border-right: none;
}
.rooms-calendar-table tbody tr:last-child td {
  border-bottom: none;
}
[data-theme="dark"] .rooms-calendar-table th {
    background-color: var(--background-color);
    color: var(--text-color);
}
.rooms-calendar-table tbody tr:hover td {
    background-color: var(--primary-light);
}
[data-theme="dark"] .rooms-calendar-table tbody tr:hover td {
    background-color: var(--background-color);
}
.rooms-calendar-table .room-info-col {
    position: sticky;
    left: 0;
    background-color: var(--card-bg);
    z-index: 15;
    border-right: 2px solid var(--border-color);
    font-weight: 600;
    text-align: left;
    min-width: 100px;
    max-width: 150px;
    word-break: break-word;
    white-space: normal;
}
[data-theme="dark"] .rooms-calendar-table .room-info-col {
    background-color: var(--card-bg);
}
.rooms-calendar-table .date-header-col {
    min-width: 70px;
    padding-top: 0.3rem;
    padding-bottom: 0.3rem;
    border-bottom: 1px solid var(--border-color);
    background-color: var(--background-color);
    text-align: center;
}
[data-theme="dark"] .rooms-calendar-table .date-header-col {
    background-color: var(--background-color);
}
.rooms-calendar-table .room-calendar-cell {
    position: relative;
    cursor: pointer;
    overflow: hidden;
}
.room-status-badge {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    border-radius: var(--radius-sm);
    font-size: 0.7rem;
    font-weight: 500;
    color: white;
    padding: 0.15rem 0.25rem;
    box-sizing: border-box;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    transition: all 0.2s;
}
.room-status-badge.available { background-color: #2dce89; }
.room-status-badge.occupied { background-color: #f5365c; }
.room-status-badge.maintenance { background-color: #fb6340; }
.room-status-badge.reserved { background-color: #11cdef; }
.room-status-badge.dirty { background-color: #67748e; }
.room-status-badge.pending_reservation { background-color: var(--warning-color); }
.room-status-badge.pending_reservation { color: white; }
.room-calendar-cell.today-column {
    background-color: var(--primary-light); /* Highlight the entire column cell */
}
.room-calendar-cell.today-column .room-status-badge {
    border: 2px solid var(--primary-color);
    box-shadow: 0 0 5px rgba(203, 12, 159, 0.3);
}
.rooms-calendar-table .room-calendar-cell:hover .room-status-badge {
    transform: scale(1.05);
    box-shadow: 0 2px 8px rgba(0,0,0, 0.1);
}
.rooms-calendar-scroll-wrapper {
    width: 100%;
    overflow-x: auto;
    padding-bottom: 15px;
}
.rooms-calendar-table {
    width: auto;
    min-width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    font-size: 0.875rem;
}
.rooms-calendar-table th.today-col {
    background-color: var(--primary-light);
    color: var(--primary-color);
    font-weight: 700;
}
[data-theme="dark"] .rooms-calendar-table th.today-col {
    background-color: var(--primary-light);
    color: var(--primary-color);
}

/* Quick Actions */
.floating-quick-actions {
    position: fixed;
    bottom: 1rem;
    right: 1rem;
    z-index: 100;
}
body.login-active .floating-quick-actions {
    display: none;
}
.quick-actions-trigger {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: linear-gradient(195deg, var(--primary-color), #ec407a);
    border: none;
    color: white;
    font-size: 1.2rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: var(--shadow-md);
    transition: all var(--transition-fast);
    position: relative;
    z-index: 2;
    outline: none;
}
[data-theme="dark"] .quick-actions-trigger {
    background: linear-gradient(195deg, #e91e63, #d81b60);
}
.quick-actions-trigger:hover, .quick-actions-trigger:focus {
    transform: scale(1.08);
    box-shadow: var(--shadow-lg);
}
.quick-actions-menu {
    position: absolute;
    bottom: 0;
    right: 0;
    width: 200px;
    background: var(--content-bg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-soft-ui);
    padding: 0.6rem 0.2rem;
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
    opacity: 0;
    pointer-events: none;
    transform: translateY(12px) scale(0.97);
    transition: all 0.23s cubic-bezier(0.22, 0.68, 0.53, 1.01);
    border: none;
}
[data-theme="dark"] .quick-actions-menu {
    background: var(--card-bg);
    box-shadow: var(--shadow-soft-ui);
}
.quick-actions-menu.show {
    opacity: 1;
    pointer-events: all;
    transform: translateY(0) scale(1.01);
}
.quick-action-list-btn {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    padding: 0.6em 0.7em 0.6em 0.54em;
    width: 100%;
    background: transparent;
    border: none;
    color: var(--text-color);
    font-size: 0.98em;
    border-radius: var(--radius-md);
    transition: background 0.16s;
    cursor: pointer;
    position: relative;
    min-height: 40px;
}
[data-theme="dark"] .quick-action-list-btn { color: var(--text-color); }
.quick-action-list-btn .qa-circle {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 1.2rem;
    box-shadow: var(--shadow-sm);
}
[data-theme="dark"] .quick-action-list-btn .qa-circle { box-shadow: none; }
.quick-action-list-btn:hover {
    background: var(--primary-light);
}
[data-theme="dark"] .quick-action-list-btn:hover { background: var(--primary-light); }
.quick-action-list-btn .qa-label {
    flex: 1;
    font-size: 1.03em;
    font-weight: 530;
}
.quick-action-list-btn .qa-desc {
    font-size: 0.85rem;
    color: var(--text-light);
    line-height: 1.18em;
    display: block;
    margin-top: 1px;
}
[data-theme="dark"] .quick-action-list-btn .qa-desc { color: var(--text-light); }
/* Quick Action specific colors */
.quick-action-list-btn.reservation .qa-circle { background-color: #e6f3fa; color: #11cdef; }
.quick-action-list-btn.guest .qa-circle { background-color: #e6f7ef; color: #2dce89; }
.quick-action-list-btn.payment .qa-circle { background-color: #fff0e6; color: #fb6340; }
.quick-action-list-btn.pos .qa-circle { background-color: #f7e6f3; color: #cb0c9f; }
.quick-action-list-btn.maintenance .qa-circle { background-color: #fce6eb; color: #f5365c; }
.quick-action-list-btn.reports .qa-circle { background-color: #e2e8f0; color: #67748e; }
[data-theme="dark"] .quick-action-list-btn.reservation .qa-circle { background-color: #36a3b8; color: white; }
[data-theme="dark"] .quick-action-list-btn.guest .qa-circle { background-color: #48bb78; color: white; }
[data-theme="dark"] .quick-action-list-btn.payment .qa-circle { background-color: #ed8936; color: white; }
[data-theme="dark"] .quick-action-list-btn.pos .qa-circle { background-color: #e91e63; color: white; }
[data-theme="dark"] .quick-action-list-btn.maintenance .qa-circle { background-color: #f05252; color: white; }
[data-theme="dark"] .quick-action-list-btn.reports .qa-circle { background-color: #4a5568; color: white; }

/* NEW: Reusable Info Box for modals and forms */
.info-box {
    background: #f8fafc;
    padding: 1rem;
    border-radius: 0.5rem;
    border: 1px solid #e2e8f0;
}
.info-box h4, .info-box .info-box-title {
    margin: 0 0 0.5rem 0;
    color: #1e293b;
}

[data-theme="dark"] .info-box {
    background: var(--background-color);
    border-color: var(--border-color);
}
[data-theme="dark"] .info-box h4,
[data-theme="dark"] .info-box .info-box-title,
[data-theme="dark"] .info-box,
[data-theme="dark"] .info-box span,
[data-theme="dark"] .info-box strong,
[data-theme="dark"] .info-box div {
    color: var(--text-color) !important;
}

[data-theme="dark"] .info-box .positive,
[data-theme="dark"] .info-box span[style*="#10b981"] {
    color: var(--success-color) !important;
}
[data-theme="dark"] .info-box .negative,
[data-theme="dark"] .info-box span[style*="#ef4444"] {
    color: var(--danger-color) !important;
}

/* Scroll to Top button */
.scroll-to-top-container {
    position: fixed;
    bottom: 60px; 
    right: 1rem;
    z-index: 100;
    transition: opacity 0.3s ease-in-out, transform 0.3s ease-in-out;
    opacity: 0;
    transform: translateY(10px);
}
.scroll-to-top-container.show {
    opacity: 1;
    transform: translateY(0);
}
.scroll-to-top-btn {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: linear-gradient(195deg, var(--primary-color), #ec407a);
    border: none;
    color: white;
    font-size: 1rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: var(--shadow-md);
    transition: all var(--transition-fast);
    outline: none;
}
[data-theme="dark"] .scroll-to-top-btn {
    background: linear-gradient(195deg, #e91e63, #d81b60);
}
.scroll-to-top-btn:hover, .scroll-to-top-btn:focus {
    transform: scale(1.08);
    box-shadow: var(--shadow-lg);
}

/* Pull-to-refresh styles */
.ptr__pull-down {
    position: absolute;
    top: -50px; 
    left: 0;
    right: 0;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.9em;
    color: var(--text-light);
    opacity: 0;
    pointer-events: none;
    z-index: 10; 
    transition: opacity 0.2s ease-out, transform 0.2s ease-out;
}
.ptr__pull-down i {
    margin-right: 8px;
    transition: transform 0.2s ease-out;
}
.ptr__pull-down.ready i {
    transform: rotate(180deg); 
}
.main-content.ptr .content-area {
    will-change: transform;
    transition: transform 0s ease-out; 
}
.main-content.ptr .ptr__pull-down {
    opacity: 1;
}
.main-content.ptr--refresh .ptr__pull-down i {
    animation: spin 1s linear infinite; 
}
.main-content.ptr--refresh .content-area {
    transform: translateY(60px) !important; 
}

/* Reports Component Styling */
.reports-container {
    padding: 0; /* Already has padding from .table-container */
    border-radius: var(--radius-lg);
    overflow: hidden; /* For inner elements */
}

.reports-nav {
    padding: 0.8rem 1.5rem;
    border-bottom: 1px solid var(--border-color);
    background-color: var(--content-bg);
}
[data-theme="dark"] .reports-nav {
    background-color: var(--card-bg);
    border-bottom: 1px solid var(--border-color);
}

.report-category-links {
    display: flex;
    gap: 0.8rem;
    flex-wrap: wrap; /* Allow wrapping on smaller screens */
}

.report-nav-btn {
    display: inline-flex;
    align-items: center;
    padding: 0.7rem 1.2rem;
    border-radius: var(--radius-md);
    font-size: 0.95rem;
    font-weight: 600;
    cursor: pointer;
    transition: all var(--transition-normal);
    white-space: nowrap;
    background: var(--background-color);
    color: var(--text-color);
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow-sm);
}
[data-theme="dark"] .report-nav-btn {
    background: var(--background-color);
    color: var(--text-color);
    border: 1px solid var(--border-color);
}

.report-nav-btn:hover {
    background: var(--primary-light);
    border-color: var(--primary-color);
    color: var(--primary-color);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}
[data-theme="dark"] .report-nav-btn:hover {
    background: var(--primary-light);
    color: var(--text-color); /* Keep text color for dark mode */
}

.report-nav-btn.active {
    background: linear-gradient(195deg, var(--primary-color), #ec407a);
    color: white;
    border: none;
    box-shadow: var(--shadow-md);
}
[data-theme="dark"] .report-nav-btn.active {
    background: linear-gradient(195deg, #e91e63, #d81b60);
    color: white;
}

.report-nav-btn i {
    margin-right: 0.6rem;
    font-size: 1.1rem;
}

.reports-content {
    padding: 1.5rem;
    background-color: var(--content-bg); /* Match table-container background */
}
[data-theme="dark"] .reports-content {
    background-color: var(--card-bg);
}

.report-section h4 {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--text-color);
    margin-top: 0;
    margin-bottom: 1.5rem;
    border-bottom: 1px solid var(--border-color);
    padding-bottom: 0.8rem;
}
[data-theme="dark"] .report-section h4 {
    color: var(--text-color);
}

.report-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.5rem;
}

.report-card {
    background-color: var(--background-color); /* Lighter background for cards within content area */
    border-radius: var(--radius-md);
    padding: 1.2rem;
    box-shadow: var(--shadow-sm);
    transition: all 0.2s ease;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    border: 1px solid var(--border-color);
}
[data-theme="dark"] .report-card {
    background-color: var(--background-color);
    border: 1px solid var(--border-color);
}

.report-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-md);
    border-color: var(--primary-color);
}
[data-theme="dark"] .report-card:hover {
    border-color: var(--primary-color);
}

.report-icon {
    font-size: 1.5rem;
    width: 48px;
    height: 48px;
    border-radius: var(--radius-md);
    display: flex;
    justify-content: center;
    align-items: center;
    color: white;
    margin-bottom: 1rem;
    box-shadow: var(--shadow-sm);
}
[data-theme="dark"] .report-icon {
    box-shadow: none; /* No inner shadow for dark icons */
}

/* Specific icon colors for categories */
.report-icon.financial { background-color: #3b82f6; } /* Blue */
.report-icon.operational { background-color: #f59e0b; } /* Orange */
.report-icon.guests { background-color: #10b981; } /* Green */
.report-icon.rooms { background-color: #cb0c9f; } /* Pink-purple */

/* Dark mode specific icon colors (adjust slightly if needed for better contrast) */
[data-theme="dark"] .report-icon.financial { background-color: #4991eb; } /* Brighter blue */
[data-theme="dark"] .report-icon.operational { background-color: #ed8936; } /* Brighter orange */
[data-theme="dark"] .report-icon.guests { background-color: #48bb78; } /* Brighter green */
[data-theme="dark"] .report-icon.rooms { background-color: #e91e63; } /* Brighter pink */


.report-card h5 {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-color);
    margin: 0 0 0.5rem 0;
}
[data-theme="dark"] .report-card h5 {
    color: var(--text-color);
}

.report-card p {
    font-size: 0.85rem;
    color: var(--text-light);
    margin: 0;
    line-height: 1.4;
}
[data-theme="dark"] .report-card p {
    color: var(--text-light);
}

/* Animations */
@keyframes fadeInScale {
    from { opacity: 0; transform: scale(0.95); }
    to { opacity: 1; transform: scale(1); }
}
@keyframes soft-pulse {
    0% { transform: scale(0.95); opacity: 0.7; }
    50% { transform: scale(1.05); opacity: 0.3; }
    100% { transform: scale(0.95); opacity: 0.7; }
}
@keyframes icon-pop-in {
    0% { transform: scale(0); opacity: 0; }
    60% { transform: scale(1.1); opacity: 1; }
    80% { transform: scale(0.95); }
    100% { transform: scale(1); opacity: 1; }
}
@keyframes wave {
    0%, 60%, 100% {
        transform: translateY(0);
    }
    30% {
        transform: translateY(-12px);
    }
}
@keyframes loginSlideIn {
    0% { transform: translateY(40px) scale(0.96); opacity: 0; }
    100% { transform: translateY(0) scale(1); opacity: 1; }
}
@keyframes modalSlideIn {
    from { opacity: 0; transform: translateY(-10px); }
    to { opacity: 1; transform: translateY(0); }
}
@keyframes shimmer {
    0% { transform: translateX(-100%); }
    100% { transform: translateX(100%); }
}
@keyframes slideInBelowHeader {
    0% { opacity: 0; transform: translateY(-10px) scale(0.9); } /* Start slightly above and smaller */
    100% { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes slideOutBelowHeader {
    0% { opacity: 1; transform: translateY(0) scale(1); }
    100% { opacity: 0; transform: translateY(-10px) scale(0.9); } /* Disappear upwards and shrink */
}

/* Loading states */
.loading {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem;
    color: var(--text-light);
}
.loading::after {
    content: '';
    width: 2rem;
    height: 2rem;
    border: 2px solid var(--primary-light);
    border-top-color: var(--primary-color);
    border-radius: 50%;
    animation: spin 0.6s linear infinite;
}

/* Improved scrollbars */
::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}
::-webkit-scrollbar-track {
    background: transparent;
    border-radius: 4px;
}
::-webkit-scrollbar-thumb {
    background: rgba(100, 116, 139, 0.2);
    border-radius: 3px;
}
::-webkit-scrollbar-thumb:hover {
    background: rgba(100, 116, 139, 0.3);
}
/* Scrollbar for dark mode */
[data-theme="dark"]::-webkit-scrollbar-thumb {
    background: rgba(176, 176, 176, 0.2);
}
[data-theme="dark"]::-webkit-scrollbar-thumb:hover {
    background: rgba(176, 176, 176, 0.3);
}

/* Add subtle hover effects to clickable elements */
[role="button"], .clickable {
    transition: all 0.2s ease;
}
[role="button"]:hover, .clickable:hover {
    transform: translateY(-1px);
}

/* Responsive adjustments */
@media (max-width: 900px) { /* Medium screens - tablets and smaller laptops */
    .app-container {
        flex-direction: column;
    }
    .sidebar {
        position: fixed;
        left: -280px;
        top: 0;
        width: 280px;
        height: 100%;
        z-index: 500;
        transition: left 0.3s ease;
        box-shadow: var(--shadow-lg);
    }
    .sidebar.show {
        left: 0;
    }
    .mobile-menu-btn {
        display: block;
        color: var(--text-color);
        padding: 0.5rem;
    }
    .header-title {
        flex-grow: 1;
        text-align: center;
        margin: 0 auto;
    }
    .header-actions {
        gap: 0.25rem;
    }
    #currentUserName {
        display: none;
    }
    .user-profile .user-btn {
        padding: 0.5rem;
    }
    /* Content Area & General Padding */
    .content-area {
        padding: 1rem;
        padding-top: calc(54px + 1rem); /* Adjust padding for smaller header */
    }
    .notification-container {
        top: 55px; /* Adjust top for smaller header */
        left: 10px;
        right: 10px;
        width: auto;
        max-width: none;
        align-items: center;
    }
    .notification-container.below-header {
      top: calc(54px + 0.5rem); /* Adjust for smaller mobile header (54px height) */
      left: 10px;
      right: 10px;
      max-width: 97%;
      align-items: center;
    }
    /* Tables */
    .table-container {
        padding: 0.7rem; /* Reduce padding for tables */
        overflow-x: auto;
    }
    .table-header {
        padding: 0.9rem 0.5rem; /* Adjust header padding */
        flex-direction: column;
        gap: 1rem;
        align-items: stretch;
    }
    .data-table {
        min-width: 600px; /* Ensure table remains wide enough for scrolling */
        font-size: 0.85rem;
    }
    .data-table th, .data-table td {
        padding: 0.6rem;
        white-space: nowrap;
    }
    .data-table th {
        font-size: 0.75rem;
    }
    .table-filters {
        flex-direction: column;
    }
    .table-filters .form-select, .table-filters .form-input {
        max-width: 100% !important;
        width: 100%;
    }


    /* --- Settings & Reports Tabs --- */
    .settings-modern-container {
        flex-direction: column;
        gap: 0;
    }
    .settings-menu {
        flex-basis: auto;
        width: 100%;
        box-shadow: none;
        padding: 0.5rem;
        border-bottom: 1px solid var(--border-color);
    }
    .settings-menu-header {
        display: none;
    }
    .settings-menu-list {
        flex-direction: row;
        overflow-x: auto;
        padding-bottom: 0.5rem;
    }
    .settings-menu-list::-webkit-scrollbar { height: 4px; }
    .settings-menu-list::-webkit-scrollbar-thumb { background: var(--border-color); }
    .settings-menu-btn {
        flex-shrink: 0;
    }
    .settings-menu-desc {
        display: none;
    }
    .settings-main {
        padding: 1rem;
        box-shadow: none;
    }

    .reports-nav {
        padding: 0.5rem;
    }
    .report-category-links {
        overflow-x: auto;
        padding-bottom: 0.5rem;
        flex-wrap: nowrap;
    }
    .report-category-links::-webkit-scrollbar { height: 4px; }
    .report-category-links::-webkit-scrollbar-thumb { background: var(--border-color); }
    .report-nav-btn {
        flex-shrink: 0;
    }
}

/* Specific adjustments for smaller mobile phones */
@media (max-width: 768px) {
    html {
        font-size: 14px;
    }
    .header {
        height: 48px;
    }
    .content-area {
        padding: 1rem;
        padding-top: calc(48px + 1rem); 
    }
    .modal {
        max-height: 95vh;
        width: 100%;
        margin: 0;
    }
    .modal-overlay {
        padding: 0.5rem;
        align-items: flex-start;
        padding-top: 1rem;
    }
    .modal-footer {
        flex-direction: column;
        gap: 0.5rem;
    }
    .modal-footer .btn {
        width: 100%;
    }
    .form-grid {
        grid-template-columns: 1fr;
    }
    .form-input, .form-select, .form-textarea {
        font-size: 16px; /* Prevent iOS zoom on focus */
    }
    .btn {
        padding: 0.8rem 1rem;
    }
    .floating-quick-actions {
        bottom: 0.5rem;
        right: 0.5rem;
    }
}

/* Adjustments for large screens for better space utilization */
@media (min-width: 1400px) {
    .content-area {
        padding-left: 2rem;
        padding-right: 2rem;
        padding-bottom: 2rem;
        padding-top: calc(70px + 2rem); 
    }
}


/* Ensure content-area always stretches without minimum height issues */
.content-area {
    min-height: unset;
}

/* Loading states */
.loading {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem;
    color: var(--text-light);
}
.loading::after {
    content: '';
    width: 2rem;
    height: 2rem;
    border: 2px solid var(--primary-light);
    border-top-color: var(--primary-color);
    border-radius: 50%;
    animation: spin 0.6s linear infinite;
}

/* Improved scrollbars */
::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}
::-webkit-scrollbar-track {
    background: transparent;
    border-radius: 4px;
}
::-webkit-scrollbar-thumb {
    background: rgba(100, 116, 139, 0.2);
    border-radius: 3px;
}
::-webkit-scrollbar-thumb:hover {
    background: rgba(100, 116, 139, 0.3);
}
/* Scrollbar for dark mode */
[data-theme="dark"]::-webkit-scrollbar-thumb {
    background: rgba(176, 176, 176, 0.2);
}
[data-theme="dark"]::-webkit-scrollbar-thumb:hover {
    background: rgba(176, 176, 176, 0.3);
}

/* Add subtle hover effects to clickable elements */
[role="button"], .clickable {
    transition: all 0.2s ease;
}
[role="button"]:hover, .clickable:hover {
    transform: translateY(-1px);
}

/* A4 Print Styles */
@page {
    size: A4 portrait; /* Set page size to A4 and orientation to portrait */
    margin: 1cm; /* Default margins for A4 print */
}
@media print {
    html, body {
        width: 210mm; /* A4 width */
        min-height: 297mm; /* A4 height */
        padding: 0;
        margin: 0;
        font-size: 9pt; /* Smaller base font for print */
        color: #000;
        background-color: #fff !important; /* Force white background */
    }
    .app-container, .main-content, .content-area, .sidebar, .header,
    .dashboard-overview, .reports-container, .modal-overlay, .modal {
        visibility: hidden; /* Hide everything by default */
        display: none;
    }
    /* Make the report content visible */
    .report-body {
        visibility: visible;
        display: block;
        position: static; /* Remove fixed/absolute positioning */
        width: 100%;
        max-width: 100%;
        height: auto;
        padding: 0; /* Remove internal padding if desired for full bleed */
        box-shadow: none !important;
        background: #fff !important; /* Ensure white background for report content */
        overflow: visible; /* Ensure content is not clipped */
    }

    /* General print layout for tables and sections */
    .report-body h4, .report-section-header {
        font-size: 12pt;
        margin-top: 15pt;
        margin-bottom: 8pt;
        border-bottom: 1px solid #ccc;
        padding-bottom: 4pt;
        color: #333 !important; /* Force black/dark gray */
    }
    .report-info-grid, .info-card {
        display: block; /* Stack items */
        margin-bottom: 10pt;
        background: none !important;
        box-shadow: none !important;
        border: none !important;
        padding: 0 !important;
    }
    .report-info-grid div, .info-card div, .info-card p, .info-card ul {
        font-size: 9pt;
        line-height: 1.4;
        color: #333 !important;
    }
    .report-info-grid strong {
        color: #000 !important;
    }
    .info-card ul {
        list-style-type: disc;
        padding-left: 15pt;
        margin-top: 5pt;
        margin-bottom: 5pt;
    }
    .info-card li {
        margin-bottom: 3pt;
    }
    .info-card .summary-item {
        border-bottom: 1px dashed #e0e0e0;
        padding: 3pt 0;
        display: flex;
        justify-content: space-between;
        align-items: center;
    }
    .info-card .summary-item span {
        font-weight: 700;
        margin-left: 5pt;
        color: #000 !important; /* Ensure amounts are black */
    }
    /* Specific colors for positive/negative amounts */
    .info-card .summary-item span.positive { color: #2dce89 !important; }
    .info-card .summary-item span.negative { color: #f5365c !important; }

    .signatures-block {
        display: flex;
        justify-content: space-around;
        margin-top: 40pt;
        flex-wrap: nowrap;
        gap: 15pt;
    }
    .signature-item {
        flex: 1;
        text-align: center;
        min-width: 100pt;
        max-width: 150pt;
    }
    .signature-line {
        border-bottom: 1px solid #000;
        margin-top: 25pt;
        margin-bottom: 5pt;
    }
    .signature-person {
        font-size: 9pt;
        font-weight: 600;
        color: #000 !important;
    }
    .signature-label {
        font-size: 8pt;
        color: #555 !important;
    }
    table {
        width: 100%;
        border-collapse: collapse;
        margin-top: 10pt;
        margin-bottom: 15pt;
    }
    th, td {
        border: 1px solid #ccc;
        padding: 5pt 7pt;
        text-align: left;
        font-size: 9pt;
        color: #333;
    }
    th {
        background-color: #f0f0f0;
        color: #000;
    }
    .text-right { text-align: right; }
    .text-center { text-align: center; }
    .total-debt, .total-amount {
        font-size: 10pt;
        border-top: 1px dashed #ccc !important;
        padding-top: 5pt;
        color: #333 !important;
    }
    .total-debt span, .total-amount span {
        font-weight: 700;
        color: #000 !important;
    }
    .negative { color: #f5365c !important; }
    .positive { color: #2dce89 !important; }

    /* New specific overrides for text readability in print media */
    .report-description,
    .info-card p,
    .info-card ul,
    .info-card li,
    .report-info-grid div,
    .report-info-grid span {
        color: #333 !important; /* Ensure readability for main text content */
    }
    .report-description {
        margin-bottom: 10pt !important; /* Reduce margin for print */
    }

    /* Hide no-print elements explicitly */
    .no-print {
        display: none !important;
    }
}