/* ============================================
   MODERN UI ENHANCEMENTS FOR ATTENDANCE SYSTEM
   Author: 4Born Technologies
   Version: 2.0 - Professional Teal Theme
   Description: Enhanced UI for Index.php Dashboard
   ============================================ */

/* ============================================
   CSS CUSTOM PROPERTIES (VARIABLES)
   ============================================ */
:root {
    /* Primary Teal Colors */
    --primary-teal: #14B8A6;
    --primary-teal-dark: #0D9488;
    --primary-teal-light: #2DD4BF;
    --primary-teal-lighter: #5EEAD4;
    --primary-teal-bg: rgba(20, 184, 166, 0.1);

    /* Status Colors */
    --success-green: #10B981;
    --success-green-light: #34D399;
    --danger-red: #EF4444;
    --danger-red-light: #F87171;

    /* Neutral Colors */
    --dark-text: #1F2937;
    --medium-text: #4B5563;
    --light-text: #6B7280;
    --border-color: #E5E7EB;
    --bg-light: #F9FAFB;
    --bg-lighter: #F3F4F6;
    --bg-white: #FFFFFF;

    /* Shadows */
    --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
    --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
    --shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
    --shadow-teal: 0 10px 25px -5px rgba(20, 184, 166, 0.3);
    --shadow-teal-lg: 0 20px 35px -5px rgba(20, 184, 166, 0.4);

    /* Transitions */
    --transition-fast: 150ms cubic-bezier(0.4, 0, 0.2, 1);
    --transition-base: 300ms cubic-bezier(0.4, 0, 0.2, 1);

    /* Border Radius */
    --radius-sm: 6px;
    --radius-md: 10px;
    --radius-lg: 14px;
    --radius-xl: 18px;
    --radius-full: 9999px;

    /* Spacing */
    --space-sm: 8px;
    --space-md: 16px;
    --space-lg: 24px;
}

/* ============================================
   HEADER ENHANCEMENTS
   ============================================ */

.header-dashboard {
    background: linear-gradient(135deg, var(--bg-white) 0%, var(--bg-lighter) 100%);
    border-bottom: 1px solid var(--border-color);
    backdrop-filter: blur(10px);
    box-shadow: var(--shadow-sm);
}

/* Analytics Header Section */
.analytics {
    transition: all var(--transition-base);
    padding: var(--space-sm);
    border-radius: var(--radius-md);
}

.analytics:hover {
    background: var(--primary-teal-bg);
}

.analytics i {
    background: linear-gradient(135deg, var(--primary-teal) 0%, var(--primary-teal-dark) 100%);
    box-shadow: var(--shadow-teal);
    transition: all var(--transition-base);
}

.analytics:hover i {
    transform: scale(1.08) rotate(5deg);
    box-shadow: var(--shadow-teal-lg);
}

.analytics h3 {
    color: var(--light-text);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-weight: 600;
}

.analytics h4 {
    color: var(--dark-text);
    font-size: 20px;
    font-weight: 700;
    background: linear-gradient(135deg, var(--dark-text) 0%, var(--primary-teal-dark) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* Profile Dropdown */
.main-profile-drop .dropdown button img {
    transition: all var(--transition-base);
    box-shadow: 0 4px 15px rgba(20, 184, 166, 0.25);
    border: 2px solid var(--primary-teal);
}

.main-profile-drop .dropdown button:hover img {
    transform: scale(1.08);
    box-shadow: 0 6px 20px rgba(20, 184, 166, 0.35);
    border-color: var(--primary-teal-light);
}

.main-profile-drop .dropdown ul {
    box-shadow: var(--shadow-xl);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
}

.main-profile-drop .dropdown ul .dropdown-item {
    transition: all var(--transition-base);
    border-radius: var(--radius-sm);
    margin: 2px 4px;
    padding: 10px 16px;
}

.main-profile-drop .dropdown ul .dropdown-item:hover {
    background: linear-gradient(90deg, var(--primary-teal-bg) 0%, transparent 100%);
    transform: translateX(5px);
    color: var(--primary-teal-dark);
}

.main-profile-drop .dropdown ul .dropdown-item i {
    color: var(--primary-teal);
    margin-right: 8px;
}

/* ============================================
   SIDEBAR NAVIGATION
   ============================================ */

.sidebar-icon {
    background: linear-gradient(180deg, #1a1d2e 0%, #16192a 100%);
    /* background: linear-gradient(180deg, #1a1d2e 0%, var(--primary-teal-lighter) 100%); */
}

.sidebar-icon .side-link ul li a {
    position: relative;
    transition: all var(--transition-base);
    border-radius: var(--radius-sm);
    margin: 4px 0;
}

.sidebar-icon .side-link ul li a::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 3px;
    height: 0;
    background: linear-gradient(180deg, var(--primary-teal) 0%, var(--primary-teal-light) 100%);
    border-radius: 0 3px 3px 0;
    transition: height var(--transition-base);
}

.sidebar-icon .side-link ul li a:hover::before,
.sidebar-icon .side-link ul li a.active::before {
    height: 70%;
}

.sidebar-icon .side-link ul li a:hover {
    background: rgba(20, 184, 166, 0.15);
    transform: translateX(4px);
}

.sidebar-icon .side-link ul li a.active {
    background: rgba(20, 184, 166, 0.2);
}

.sidebar-icon .side-link ul li a i {
    transition: all var(--transition-base);
}

.sidebar-icon .side-link ul li a:hover i {
    color: var(--primary-teal-light);
    transform: scale(1.15);
}

/* Main Sidebar */
.sidebar-layout {
    background: var(--bg-white);
    box-shadow: var(--shadow-lg);
}

.sidebar-page .nav-link {
    position: relative;
    transition: all var(--transition-base);
    border-radius: var(--radius-md);
    margin-bottom: 6px;
    padding: 10px 12px;
    color: var(--medium-text);
}

.sidebar-page .nav-link::after {
    content: '';
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 0;
    height: 60%;
    background: linear-gradient(180deg, var(--primary-teal) 0%, var(--primary-teal-dark) 100%);
    border-radius: 3px 0 0 3px;
    transition: width var(--transition-base);
}

.sidebar-page .nav-link:hover {
    background: var(--primary-teal-bg);
    transform: translateX(6px);
    padding-left: 16px;
    color: var(--primary-teal-dark);
}

.sidebar-page .nav-link:hover::after {
    width: 4px;
}

.sidebar-page .nav-link.active {
    position: relative;
    border-left: 4px solid var(--primary-teal);
    font-weight: 600;
    background: linear-gradient(135deg, var(--dark-text) 0%, var(--primary-teal-dark) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.sidebar-page .nav-link.active::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(90deg, var(--primary-teal-bg) 0%, transparent 100%);
    z-index: -1;
    border-radius: var(--radius-md);
}

.sidebar-page .nav-link img {
    transition: transform var(--transition-base);
    filter: grayscale(0.3);
}

.sidebar-page .nav-link:hover img,
.sidebar-page .nav-link.active img {
    transform: scale(1.12);
    filter: grayscale(0);
}

/* ============================================
   BUTTONS - CONSISTENT COLORS
   ============================================ */

/* Primary Buttons - Teal */
.btn.login-btn,
.btn.apply-btn,
.btn.save-modal-btn {
    background: #14B8A6 !important;
    border: none;
    box-shadow: 0 4px 12px rgba(20, 184, 166, 0.3);
    transition: all var(--transition-base);
    font-weight: 600;
    letter-spacing: 0.3px;
    color: #FFFFFF !important;
}

.btn.login-btn:hover,
.btn.apply-btn:hover,
.btn.save-modal-btn:hover {
    background: #0D9488 !important;
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(20, 184, 166, 0.4);
}

.btn.login-btn:active,
.btn.apply-btn:active,
.btn.save-modal-btn:active {
    transform: translateY(0);
}

/* Cancel Buttons - Gray */
.btn.cancel-btn,
.btn.cancel-modal-btn {
    background: #6B7280 !important;
    border: none;
    transition: all var(--transition-base);
    color: #FFFFFF !important;
}

.btn.cancel-btn:hover,
.btn.cancel-modal-btn:hover {
    background: #4B5563 !important;
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

/* ============================================
   FORM ELEMENTS
   ============================================ */

.form-control {
    transition: all var(--transition-base);
    border-radius: var(--radius-md);
    border: 2px solid var(--border-color);
}

.form-control:focus {
    border-color: var(--primary-teal);
    box-shadow: 0 0 0 4px var(--primary-teal-bg);
    transform: translateY(-1px);
    outline: none;
}

select.form-control {
    transition: all var(--transition-base);
    border-radius: var(--radius-md);
}

select.form-control:focus {
    border-color: var(--primary-teal);
    box-shadow: 0 0 0 4px var(--primary-teal-bg);
}

/* ============================================
   ENHANCED INPUT FIELD STYLING
   ============================================ */

/* General Input, Textarea, Select Styling */
input.form-control,
textarea.form-control,
select.form-control,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="date"],
input[type="time"],
input[type="file"] {
    height: 42px;
    padding: 10px 14px;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.5;
    color: var(--dark-text);
    background-color: var(--bg-white);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    transition: all var(--transition-base);
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

/* Textarea specific */
textarea.form-control {
    height: auto;
    min-height: 100px;
    resize: vertical;
    padding: 12px 14px;
}

/* Focus State */
input.form-control:focus,
textarea.form-control:focus,
select.form-control:focus,
input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="number"]:focus,
input[type="date"]:focus,
input[type="time"]:focus {
    border-color: var(--primary-teal);
    box-shadow: 0 0 0 3px rgba(20, 184, 166, 0.1), 0 1px 3px rgba(0, 0, 0, 0.1);
    outline: none;
    background-color: var(--bg-white);
}

/* Hover State */
input.form-control:hover:not(:focus),
textarea.form-control:hover:not(:focus),
select.form-control:hover:not(:focus) {
    border-color: var(--primary-teal-light);
}

/* Disabled State */
input.form-control:disabled,
textarea.form-control:disabled,
select.form-control:disabled {
    background-color: var(--bg-lighter);
    color: var(--medium-text);
    cursor: not-allowed;
    opacity: 0.6;
}

/* Readonly State */
input.form-control[readonly],
textarea.form-control[readonly] {
    background-color: var(--bg-lighter);
    border-color: var(--border-color);
    cursor: default;
}

/* Placeholder Styling */
input.form-control::placeholder,
textarea.form-control::placeholder {
    color: var(--medium-text);
    opacity: 0.7;
    font-style: italic;
}

/* File Input Styling */
input[type="file"].form-control {
    padding: 8px 14px;
    cursor: pointer;
}

input[type="file"].form-control::-webkit-file-upload-button {
    padding: 6px 12px;
    margin-right: 12px;
    background: var(--primary-teal);
    color: white;
    border: none;
    border-radius: var(--radius-sm);
    cursor: pointer;
    font-size: 13px;
    font-weight: 600;
    transition: all var(--transition-base);
}

input[type="file"].form-control::-webkit-file-upload-button:hover {
    background: var(--primary-teal-dark);
    transform: translateY(-1px);
}

/* Input Group Styling */
.input-group {
    position: relative;
    display: flex;
    align-items: stretch;
    width: 100%;
}

.input-group .form-control {
    position: relative;
    flex: 1 1 auto;
    width: 1%;
    min-width: 0;
}

/* Form Label Styling */
label.form-label,
.form-label {
    display: inline-block;
    margin-bottom: 8px;
    font-size: 13px;
    font-weight: 600;
    color: var(--dark-text);
}

/* Required Field Indicator */
label.required::after,
.form-label.required::after {
    content: " *";
    color: var(--danger-red);
}

/* Help Text */
.form-text {
    display: block;
    margin-top: 6px;
    font-size: 12px;
    color: var(--medium-text);
    font-style: italic;
}

/* Error State */
input.form-control.is-invalid,
textarea.form-control.is-invalid,
select.form-control.is-invalid {
    border-color: var(--danger-red);
}

input.form-control.is-invalid:focus,
textarea.form-control.is-invalid:focus,
select.form-control.is-invalid:focus {
    border-color: var(--danger-red);
    box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1);
}

.invalid-feedback {
    display: block;
    margin-top: 6px;
    font-size: 12px;
    color: var(--danger-red);
}

/* Success State */
input.form-control.is-valid,
textarea.form-control.is-valid,
select.form-control.is-valid {
    border-color: var(--success-green);
}

input.form-control.is-valid:focus,
textarea.form-control.is-valid:focus,
select.form-control.is-valid:focus {
    border-color: var(--success-green);
    box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.1);
}

/* ============================================
   LEAVE DETAILS STYLING
   ============================================ */

ul.leave-details {
    padding: 15px 20px;
    list-style: none;
    margin: 0;
}

ul.leave-details li {
    display: grid;
    grid-template-columns: 120px 1fr;
    gap: 12px;
    align-items: start;
    margin-bottom: 12px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border-color);
    transition: all var(--transition-base);
}

ul.leave-details li:last-child {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

ul.leave-details li:hover {
    background: var(--primary-teal-bg);
    padding-left: 8px;
    margin-left: -8px;
    padding-right: 8px;
    margin-right: -8px;
    border-radius: var(--radius-sm);
}

ul.leave-details li span:first-child {
    font-weight: 600;
    color: var(--medium-text);
    display: flex;
    align-items: flex-start;
    padding-top: 2px;
}

ul.leave-details li span:first-child b {
    color: var(--dark-text);
    font-weight: 600;
}

ul.leave-details li span:last-child {
    color: var(--dark-text);
    word-wrap: break-word;
    word-break: break-word;
    overflow-wrap: break-word;
    line-height: 1.6;
    text-align: left;
}

/* Special styling for reason field */
ul.leave-details li:has(.leave-reason) span:last-child,
ul.leave-details li:last-child span:last-child {
    font-style: italic;
    color: var(--medium-text);
    background: var(--bg-lighter);
    padding: 8px 12px;
    border-radius: var(--radius-sm);
    border-left: 3px solid var(--primary-teal);
}

/* ============================================
   TEAM MEMBERS PAGE STYLING
   ============================================ */

/* Team Grid Container */
.grid-team {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
    gap: 24px;
    padding: 0;
}

/* Team Member Card */
.team-box {
    background: var(--bg-white);
    border-radius: var(--radius-lg);
    padding: 20px;
    box-shadow: var(--shadow-md);
    border: 1px solid var(--border-color);
    transition: all var(--transition-base);
    position: relative;
    display: flex;
    flex-direction: column;
    min-height: 380px;
    height: 100%;
}

/* Hover Effect with Teal Accent */
.team-box:hover {
    box-shadow: var(--shadow-xl);
    transform: translateY(-4px);
    border-color: var(--primary-teal);
    background: linear-gradient(to bottom, rgba(20, 184, 166, 0.02) 0%, var(--bg-white) 100%);
}

/* Edit/Delete Icons Container */
.edit-delet-icon {
    position: absolute;
    top: 16px;
    right: 16px;
    display: flex;
    gap: 6px;
    z-index: 2;
}

/* Toggle Switch Positioning */
/* .toggle-switch {
    position: absolute;
    top: 16px;
    left: 16px;
    z-index: 2;
} */

/* Team Member Image Section */
.team-img {
    text-align: center;
    margin-bottom: 16px;
    margin-top: 12px;
}

.team-img img {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid var(--border-color);
    transition: all var(--transition-base);
    box-shadow: var(--shadow-sm);
}

.team-box:hover .team-img img {
    border-color: var(--primary-teal);
    box-shadow: 0 8px 20px rgba(20, 184, 166, 0.25);
    transform: scale(1.05);
}

.team-img h3 {
    font-size: 17px;
    font-weight: 700;
    margin: 10px 0 4px 0;
    background: linear-gradient(135deg, var(--dark-text) 0%, var(--primary-teal-dark) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    transition: all var(--transition-base);
}

.team-box:hover .team-img h3 {
    background: linear-gradient(135deg, var(--primary-teal) 0%, var(--primary-teal-dark) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.team-img p {
    font-size: 13px;
    color: var(--medium-text);
    margin: 0 0 4px 0;
    font-weight: 500;
}

.team-img a {
    text-decoration: none;
    color: inherit;
}

/* In/Out Time Section */
.in-time-out-time {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    margin: 20px 0;
    padding: 16px;
    background: var(--bg-lighter);
    border-radius: var(--radius-md);
    border: 1px solid var(--border-color);
    transition: all var(--transition-base);
}

.team-box:hover .in-time-out-time {
    background: rgba(20, 184, 166, 0.05);
    border-color: var(--primary-teal-lighter);
}

.in-time,
.out-time {
    flex: 1;
    text-align: center;
}

.in-time p,
.out-time p {
    font-size: 11px;
    color: var(--light-text);
    margin: 0 0 6px 0;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-weight: 600;
}

.in-time h4 {
    font-size: 16px;
    font-weight: 700;
    color: var(--success-green);
    margin: 0;
}

.out-time h4 {
    font-size: 16px;
    font-weight: 700;
    color: var(--danger-red);
    margin: 0;
}

/* Status Button Container */
.team-box .text-center {
    margin-top: auto;
    padding-top: 16px;
}

/* Status Buttons - Enhanced */
.team-box .button.button-xs {
    width: 100%;
    padding: 10px 20px;
    border-radius: var(--radius-md);
    font-weight: 600;
    font-size: 13px;
    letter-spacing: 0.3px;
    transition: all var(--transition-base);
    border: none;
    box-shadow: var(--shadow-sm);
}

.team-box .button.button-xs:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

/* Action Buttons - Improved */
.edit-delet-icon .button.button-box {
    width: 32px;
    height: 32px;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-sm);
    transition: all var(--transition-base);
    box-shadow: var(--shadow-sm);
    border: 1px solid transparent;
}

.edit-delet-icon .button.button-box:hover {
    transform: scale(1.1);
    box-shadow: var(--shadow-md);
}

.edit-delet-icon .button.button-box i {
    font-size: 14px;
}

/* ============================================
   COMPREHENSIVE MODAL STYLING
   ============================================ */

/* Modal Content Container */
.modal-content {
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow-2xl);
    background: var(--bg-white);
}

/* Modal Header */
.modal-header {
    background: linear-gradient(135deg, var(--bg-white) 0%, var(--bg-lighter) 100%);
    border-bottom: 1px solid var(--border-color);
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    padding: 20px 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.modal-header .modal-title,
.modal-title {
    font-weight: 700 !important;
    color: var(--dark-text) !important;
    font-size: 18px !important;
    margin: 0 !important;
    line-height: 1.4 !important;
}

.modal-header .close,
.modal-header .btn-close {
    background: transparent !important;
    border: none !important;
    font-size: 20px !important;
    color: var(--medium-text) !important;
    opacity: 0.7 !important;
    transition: all var(--transition-base) !important;
    padding: 0 !important;
    width: 32px !important;
    height: 32px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: var(--radius-sm) !important;
    cursor: pointer !important;
    margin: 0 !important;
    box-shadow: none !important;
}

/* For BS5 btn-close which uses background-image */
.modal-header .btn-close {
    background-image: none !important;
    position: relative;
}

.modal-header .btn-close::before {
    content: "×";
    font-size: 28px;
    line-height: 1;
}

.modal-header .close:hover,
.modal-header .btn-close:hover {
    opacity: 1 !important;
    background: var(--bg-lighter) !important;
    color: var(--danger-red) !important;
    transform: rotate(90deg) !important;
}

.modal-body {
    padding: 24px;
    background: var(--bg-white);
}

/* Modal Body Form Elements */
.modal-body .form-control,
.modal-body input.form-control,
.modal-body textarea.form-control,
.modal-body select.form-control {
    margin-bottom: 0;
}

.modal-body .col-12,
.modal-body .mb-15,
.modal-body .mb-20 {
    margin-bottom: 16px;
}

.modal-body .col-12:last-child,
.modal-body .mb-15:last-child,
.modal-body .mb-20:last-child {
    margin-bottom: 0;
}

/* Modal Body Labels */
.modal-body .sub-title,
.modal-body h5.sub-title,
.modal-body label {
    font-size: 13px;
    font-weight: 600;
    color: var(--dark-text);
    margin-bottom: 8px;
    display: block;
}

/* Modal Footer */
.modal-footer {
    background: var(--bg-lighter);
    border-top: 1px solid var(--border-color);
    border-radius: 0 0 var(--radius-lg) var(--radius-lg);
    padding: 16px 24px;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 12px;
}

/* Modal Footer Buttons - Consistent Styling */
.modal-footer .button,
.modal-footer .btn,
.modal-footer button[type="submit"],
.modal-footer button.button-primary {
    min-width: 100px;
    padding: 10px 20px;
    font-size: 14px;
    font-weight: 600;
    border-radius: var(--radius-md);
    transition: all var(--transition-base);
    border: none;
    cursor: pointer;
}

/* Primary Button in Modal Footer */
.modal-footer .button-primary,
.modal-footer .btn-primary,
.modal-footer button[type="submit"] {
    background: var(--primary-teal) !important;
    color: white !important;
    border-color: var(--primary-teal) !important;
}

.modal-footer .button-primary:hover,
.modal-footer .btn-primary:hover,
.modal-footer button[type="submit"]:hover {
    background: var(--primary-teal-dark) !important;
    border-color: var(--primary-teal-dark) !important;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(20, 184, 166, 0.4);
}

/* Secondary/Cancel Button in Modal Footer */
.modal-footer .button-secondary,
.modal-footer .btn-secondary,
.modal-footer button[data-dismiss="modal"] {
    background: var(--bg-white) !important;
    color: var(--medium-text) !important;
    border: 1px solid var(--border-color) !important;
}

.modal-footer .button-secondary:hover,
.modal-footer .btn-secondary:hover,
.modal-footer button[data-dismiss="modal"]:hover {
    background: var(--bg-lighter) !important;
    border-color: var(--medium-text) !important;
    color: var(--dark-text) !important;
    transform: translateY(-1px);
}

/* Danger Button in Modal Footer */
.modal-footer .button-danger,
.modal-footer .btn-danger {
    background: var(--danger-red) !important;
    color: white !important;
    border-color: var(--danger-red) !important;
}

.modal-footer .button-danger:hover,
.modal-footer .btn-danger:hover {
    background: #DC2626 !important;
    border-color: #DC2626 !important;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(239, 68, 68, 0.4);
}

/* Success Button in Modal Footer */
.modal-footer .button-success,
.modal-footer .btn-success {
    background: var(--success-green) !important;
    color: white !important;
    border-color: var(--success-green) !important;
}

.modal-footer .button-success:hover,
.modal-footer .btn-success:hover {
    background: #059669 !important;
    border-color: #059669 !important;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(16, 185, 129, 0.4);
}

/* Modal Image Centering */
.modal-body .team-img {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    flex-direction: column;
    margin-bottom: 20px;
}

.modal-body .team-img img {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid var(--primary-teal);
    box-shadow: 0 4px 12px rgba(20, 184, 166, 0.2);
    cursor: pointer;
    transition: all var(--transition-base);
}

.modal-body .team-img img:hover {
    transform: scale(1.05);
    box-shadow: 0 6px 16px rgba(20, 184, 166, 0.3);
}

/* ============================================
   BUTTON GROUP SPACING
   ============================================ */

/* Fix for buttons appearing too close together */
div[style*="display:ruby"],
div[style*="display: ruby"] {
    display: flex !important;
    gap: 8px;
    flex-wrap: wrap;
    align-items: center;
}

/* General button spacing in action groups */
.table-action-buttons {
    display: flex;
    gap: 8px;
    align-items: center;
}

/* Button spacing in status column */
td>.button+.button,
td>form+.button,
td>.button+form {
    margin-left: 8px;
}

/* Inline form buttons */
form[name="leave form"] {
    display: inline-block;
    margin: 0 8px 0 0;
}

/* Badge + Button spacing */
.badge+.button,
.badge+form {
    margin-left: 8px;
}

/* ============================================
   FILTER SECTION STYLING
   ============================================ */

/* Filter Container - Compact Height */
.box.box-border-less {
    border: none !important;
    box-shadow: none !important;
    background: transparent !important;
    min-height: auto !important;
    padding: 0 !important;
}

.box.box-border-less .box-body {
    padding: 20px !important;
    background: var(--bg-white);
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow-sm);
}

/* Filter Row Spacing */
.box-body .row {
    margin: 0 -8px;
}

.box-body .row>[class*="col-"] {
    padding: 0 8px;
}

/* Filter Labels */
.sub-title {
    font-size: 13px;
    font-weight: 600;
    color: var(--dark-text);
    margin-bottom: 8px;
    text-transform: none;
    letter-spacing: 0;
    transition: color var(--transition-base);
}

/* ============================================
   FILTER SECTION HOVER EFFECTS
   ============================================ */

/* Container Hover Effect */
.box.box-border-less .box-body {
    transition: all var(--transition-base);
}

.box.box-border-less .box-body:hover {
    box-shadow: var(--shadow-md);
    border-color: var(--primary-teal-light);
}

/* Label Hover - Changes color when hovering over input container */
.box-body .my-2:hover .sub-title {
    color: var(--primary-teal);
}

/* Input Field Hover Effects */
.box-body .form-control:hover:not(:focus):not([readonly]),
.box-body .input-date:hover:not(:focus) {
    border-color: var(--primary-teal-light);
    box-shadow: 0 2px 4px rgba(20, 184, 166, 0.08);
    transform: translateY(-1px);
}

/* Enhanced Focus State */
.box-body .form-control:focus,
.box-body .input-date:focus {
    transform: translateY(-1px);
}

/* Select2 Hover Effect */
.box-body .select2-container:hover .select2-selection {
    border-color: var(--primary-teal-light) !important;
    box-shadow: 0 2px 4px rgba(20, 184, 166, 0.08) !important;
}

/* Input Container Hover - Subtle Background */
.box-body .my-2 {
    transition: all var(--transition-base);
    border-radius: var(--radius-md);
}

.box-body .my-2:hover {
    background: linear-gradient(to right, rgba(20, 184, 166, 0.02) 0%, transparent 100%);
    padding: 4px;
    margin: -4px;
}


/* Compact Filter Grid */
@media (min-width: 1200px) {
    .box-body .row>.col-xl-4 {
        flex: 0 0 auto;
        width: 33.333333%;
    }
}

@media (min-width: 992px) and (max-width: 1199px) {
    .box-body .row>.col-lg-6 {
        flex: 0 0 auto;
        width: 50%;
    }
}

/* ============================================
   RESPONSIVE ADJUSTMENTS
   ============================================ */

@media (max-width: 768px) {
    .box:hover {
        transform: translateY(-2px);
    }

    .sidebar-page .nav-link:hover {
        transform: translateX(3px);
    }

    /* Leave Details Responsive */
    ul.leave-details li {
        grid-template-columns: 1fr;
        gap: 6px;
    }

    ul.leave-details li span:first-child {
        font-size: 13px;
    }

    ul.leave-details li span:last-child {
        font-size: 14px;
        padding-left: 0;
    }

    ul.leave-details {
        padding: 12px 15px;
    }

    /* Team Member Cards Responsive */
    .grid-team {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .team-box {
        min-height: auto;
        padding: 20px;
    }

    .team-img img {
        width: 80px;
        height: 80px;
    }

    .in-time-out-time {
        flex-direction: column;
        gap: 12px;
        padding: 12px;
    }

    .edit-delet-icon .button.button-box {
        width: 28px;
        height: 28px;
    }
}

/* ============================================
   SYSTEM-WIDE BUTTON COLOR STANDARDIZATION
   This file ensures ALL buttons use consistent colors
   ============================================ */

/* ============================================
   CONSISTENT COLOR DEFINITIONS
   ============================================ */

/* Primary Teal - For main action buttons */
.btn.login-btn,
.btn.apply-btn,
.btn.save-modal-btn,
.button.button-primary,
.applyBtn {
    background: #14B8A6 !important;
    border-color: #14B8A6 !important;
    color: #FFFFFF !important;
    transition: all 0.3s ease;
}

.btn.login-btn:hover,
.btn.apply-btn:hover,
.btn.save-modal-btn:hover,
.button.button-primary:hover,
.applyBtn:hover {
    background: #0D9488 !important;
    border-color: #0D9488 !important;
    transform: translateY(-2px) scale(1.02);
    box-shadow: 0 6px 20px rgba(20, 184, 166, 0.4);
}

/* Success Green - ONE SINGLE SHADE FOR ALL SUCCESS BUTTONS */
.btn-cmp,
.button.button-success,
.button-success,
.btn.btn-success,
button[class*="success"],
a.button-success,
.badge-success,
.badge.badge-success {
    background: #10B981 !important;
    border-color: #10B981 !important;
    color: #FFFFFF !important;
    transition: all 0.3s ease;
}

.btn-cmp:hover,
.button.button-success:hover,
.button-success:hover,
.btn.btn-success:hover,
button[class*="success"]:hover,
a.button-success:hover {
    background: #059669 !important;
    border-color: #059669 !important;
    transform: translateY(-2px) scale(1.02);
    box-shadow: 0 6px 20px rgba(16, 185, 129, 0.4);
}

/* Danger Red - For delete/reject buttons */
.btn-pnd,
.button.button-danger,
.button-danger,
.btn.btn-danger,
button[class*="danger"],
a.button-danger,
.delete,
.badge-danger,
.badge.badge-danger {
    background: #EF4444 !important;
    border-color: #EF4444 !important;
    color: #FFFFFF !important;
    transition: all 0.3s ease;
}

.btn-pnd:hover,
.button.button-danger:hover,
.button-danger:hover,
.btn.btn-danger:hover,
button[class*="danger"]:hover,
a.button-danger:hover,
.delete:hover {
    background: #DC2626 !important;
    border-color: #DC2626 !important;
    transform: translateY(-2px) scale(1.02);
    box-shadow: 0 6px 20px rgba(239, 68, 68, 0.4);
}

/* Warning Orange - For warning/pending buttons */
.btn-yellow,
.button.button-warning,
.button-warning,
.btn.btn-warning,
button[class*="warning"],
a.button-warning,
.badge-warning,
.badge.badge-warning {
    background: #F59E0B !important;
    border-color: #F59E0B !important;
    color: #FFFFFF !important;
    transition: all 0.3s ease;
}

.btn-yellow:hover,
.button.button-warning:hover,
.button-warning:hover,
.btn.btn-warning:hover,
button[class*="warning"]:hover,
a.button-warning:hover {
    background: #D97706 !important;
    border-color: #D97706 !important;
    transform: translateY(-2px) scale(1.02);
    box-shadow: 0 6px 20px rgba(245, 158, 11, 0.4);
}

/* Cancel/Secondary Gray */
.btn.cancel-btn,
.btn.cancel-modal-btn,
.button.button-secondary {
    background: #6B7280 !important;
    border-color: #6B7280 !important;
    color: #FFFFFF !important;
    transition: all 0.3s ease;
}

.btn.cancel-btn:hover,
.btn.cancel-modal-btn:hover,
.button.button-secondary:hover {
    background: #4B5563 !important;
    border-color: #4B5563 !important;
    transform: translateY(-2px) scale(1.02);
    box-shadow: 0 4px 12px rgba(75, 85, 99, 0.4);
}

/* ============================================
   REMOVE ALL GRADIENTS
   ============================================ */

.btn,
.button,
.badge {
    background-image: none !important;
}

/* ============================================
   ENSURE WHITE TEXT ON ALL COLORED BUTTONS
   ============================================ */

.btn.login-btn,
.btn.apply-btn,
.btn.save-modal-btn,
.button.button-primary,
.button.button-success,
.button.button-danger,
.button.button-warning,
.btn-cmp,
.btn-pnd,
.btn-yellow,
.badge-success,
.badge-danger,
.badge-warning,
.applyBtn {
    color: #FFFFFF !important;
}

/* ============================================
   SMALL ICON BUTTONS
   ============================================ */

.button.button-box {
    transition: all 0.3s ease;
}

.button.button-box:hover {
    transform: scale(1.15);
}

.button.button-box.button-success {
    background: #10B981 !important;
}

.button.button-box.button-success:hover {
    background: #059669 !important;
    box-shadow: 0 4px 12px rgba(16, 185, 129, 0.4);
}

.button.button-box.button-danger {
    background: #EF4444 !important;
}

.button.button-box.button-danger:hover {
    background: #DC2626 !important;
    box-shadow: 0 4px 12px rgba(239, 68, 68, 0.4);
}

.button.button-box.button-prymary {
    background: #14B8A6 !important;
}

.button.button-box.button-prymary:hover {
    background: #0D9488 !important;
    box-shadow: 0 4px 12px rgba(20, 184, 166, 0.4);
}

/* ============================================
   SPECIFIC ATTENDANCE BUTTONS
   ============================================ */

/* Removed span-specific backgrounds to fix two-tone button issue */

/* ============================================
   BADGE STYLING - LEAVE STATUS
   ============================================ */

/* Base Badge Styling */
.badge {
    display: inline-block;
    padding: 8px 16px;
    font-size: 13px;
    font-weight: 600;
    line-height: 1.4;
    text-align: center;
    white-space: nowrap;
    vertical-align: baseline;
    border-radius: 6px;
    transition: all 0.3s ease;
    border: none;
    min-width: 90px;
}

/* Success Badge - Approved */
.badge-success {
    background: #10B981 !important;
    color: #FFFFFF !important;
}

.badge-success:hover {
    background: #059669 !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3);
}

/* Danger Badge - Rejected */
.badge-danger {
    background: #EF4444 !important;
    color: #FFFFFF !important;
}

.badge-danger:hover {
    background: #DC2626 !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(239, 68, 68, 0.3);
}

/* Secondary Badge - Cancelled */
.badge-secondary {
    background: #6B7280 !important;
    color: #FFFFFF !important;
    padding: 8px 16px;
    font-size: 13px;
    font-weight: 600;
    min-width: 90px;
}

.badge-secondary:hover {
    background: #4B5563 !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(107, 114, 128, 0.3);
}

/* Warning Badge - Pending */
.badge-warning {
    background: #F59E0B !important;
    color: #FFFFFF !important;
}

.badge-warning:hover {
    background: #D97706 !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(245, 158, 11, 0.3);
}

/* Primary Badge - Withdrawn */
.badge-primary {
    background: #3B82F6 !important;
    color: #FFFFFF !important;
}

.badge-primary:hover {
    background: #2563EB !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(59, 130, 246, 0.3);
}

/* ============================================
   SMOOTH SCROLLING
   ============================================ */

html {
    scroll-behavior: smooth;
}

/* ============================================
   WEEKEND SETTINGS MODAL STYLING
   ============================================ */

.weekend-settings-form {
    display: flex;
    flex-direction: column;
}

.weekend-settings-container {
    padding: 24px;
    background: var(--bg-white);
}

.settings-group {
    margin-bottom: 24px;
}

.settings-group:last-child {
    margin-bottom: 0;
}

.group-title {
    font-size: 12px;
    font-weight: 700;
    color: var(--medium-text);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 16px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--border-color);
}

.weekend-setting-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px;
    background: var(--bg-lighter);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    margin-bottom: 12px;
    transition: all var(--transition-base);
}

.weekend-setting-item:last-child {
    margin-bottom: 0;
}

.weekend-setting-item:hover {
    background: var(--bg-white);
    border-color: var(--primary-teal-light);
    transform: translateY(-2px);
    box-shadow: var(--shadow-sm);
}

.setting-info {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.setting-name {
    font-size: 14px;
    font-weight: 600;
    color: var(--dark-text);
}

.setting-desc {
    font-size: 12px;
    color: var(--medium-text);
}

/* Modern Toggle Switch */
.modern-switch {
    position: relative;
    display: inline-block;
    width: 48px;
    height: 24px;
    flex-shrink: 0;
}

.modern-switch input {
    opacity: 0;
    width: 0;
    height: 0;
}

.switch-slider {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: #CBD5E1;
    transition: .4s;
    border-radius: 24px;
}

.switch-slider:before {
    position: absolute;
    content: "";
    height: 18px;
    width: 18px;
    left: 3px;
    bottom: 3px;
    background-color: white;
    transition: .4s;
    border-radius: 50%;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.modern-switch input:checked+.switch-slider {
    background-color: var(--primary-teal);
}

.modern-switch input:focus+.switch-slider {
    box-shadow: 0 0 1px var(--primary-teal);
}

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

/* Adjust warning color to match orange if needed, using variable */
.modern-switch input:checked[name="saturday"]+.switch-slider {
    background-color: #F59E0B;
    /* Orange for Saturday as per theme */
}

.modern-switch input:checked[name="sunday"]+.switch-slider {
    background-color: #EF4444;
    /* Red for Sunday or keep teal */
}

/* Customizing Saturday to Orange as requested by visual cues in image */
.weekend-setting-item:hover:has(input[name="saturday"]:checked) {
    border-color: #FCD34D;
}

.weekend-setting-item:hover:has(input[name="sunday"]:checked) {
    border-color: #FCA5A5;
}