/* ========================================
   HR Superawesome - shadcn-inspired Theme
   ======================================== */

/* CSS Variables - shadcn color palette */
:root {
    /* Zinc palette for neutral colors */
    --zinc-50: #fafafa;
    --zinc-100: #f4f4f5;
    --zinc-200: #e4e4e7;
    --zinc-300: #d4d4d8;
    --zinc-400: #a1a1aa;
    --zinc-500: #71717a;
    --zinc-600: #52525b;
    --zinc-700: #3f3f46;
    --zinc-800: #27272a;
    --zinc-900: #18181b;
    --zinc-950: #09090b;

    /* Accent colors */
    --blue-50: #E6EEFF;
    --blue-100: #CCE0FF;
    --blue-200: #99C2FF;
    --blue-500: #0057FF;
    --blue-600: #0047D1;
    --blue-700: #0038A3;
    --green-50: #f0fdf4;
    --green-100: #dcfce7;
    --green-200: #bbf7d0;
    --green-500: #22c55e;
    --green-600: #16a34a;
    --green-700: #15803d;
    --red-50: #fef2f2;
    --red-100: #fee2e2;
    --red-200: #fecaca;
    --red-500: #ef4444;
    --red-600: #dc2626;
    --red-700: #b91c1c;
    --yellow-500: #eab308;
    --yellow-600: #ca8a04;
    --amber-50: #fffbeb;
    --amber-100: #fef3c7;
    --amber-200: #fde68a;
    --amber-500: #f59e0b;
    --amber-600: #d97706;
    --amber-700: #b45309;

    /* Time off type colors */
    --timeoff-personal-bg: #E6EEFF;
    --timeoff-personal-border: #99C2FF;
    --timeoff-personal-text: #0047D1;
    --timeoff-patron-bg: #FEF3C7;
    --timeoff-patron-border: #F4C542;
    --timeoff-patron-text: #D4A017;
    --timeoff-sick-bg: #EAF3E3;
    --timeoff-sick-border: #A8C99C;
    --timeoff-sick-text: #6B8E5E;
    --timeoff-death-bg: #F4F4F5;
    --timeoff-death-border: #D4D4D8;
    --timeoff-death-text: #71717a;
    --timeoff-moving-bg: #FFEDD5;
    --timeoff-moving-border: #FDBA74;
    --timeoff-moving-text: #C87A33;
    --timeoff-marriage-bg: #FCE7F3;
    --timeoff-marriage-border: #F9A8D4;
    --timeoff-marriage-text: #DB2777;
    --timeoff-childbirth-bg: #dcfce7;
    --timeoff-childbirth-border: #86efac;
    --timeoff-childbirth-text: #16a34a;
    --timeoff-paternity-bg: #dcfce7;
    --timeoff-paternity-border: #86efac;
    --timeoff-paternity-text: #16a34a;
    --timeoff-maternity-bg: #dcfce7;
    --timeoff-maternity-border: #86efac;
    --timeoff-maternity-text: #16a34a;

    /* Semantic colors */
    --background: var(--zinc-50);
    --foreground: var(--zinc-900);
    --card: #ffffff;
    --card-foreground: var(--zinc-900);
    --muted: var(--zinc-100);
    --muted-foreground: var(--zinc-500);
    --border: var(--zinc-200);
    --input: var(--zinc-200);
    --primary: #0057FF;
    --primary-hover: #0047D1;
    --primary-foreground: #ffffff;
    --ring: var(--zinc-400);

    /* Spacing and sizing */
    --radius: 0.5rem;
    --radius-sm: 0.375rem;
    --radius-lg: 0.75rem;

}

/* ========================================
   Base Styles
   ======================================== */

body {
    background-color: var(--background);
    color: var(--foreground);
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    font-size: 0.875rem;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* ========================================
   Navigation
   ======================================== */

.navbar {
    background-color: var(--card) !important;
    border-bottom: 1px solid var(--border);
    box-shadow: none;
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
}

.navbar-brand {
    font-weight: 600;
    font-size: 1rem;
    color: var(--foreground) !important;
}

.navbar-brand .text-primary {
    color: var(--primary) !important;
}

.nav-link {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--muted-foreground) !important;
    transition: color 0.2s ease;
    padding: 0.5rem 0.75rem !important;
}

.nav-link:hover {
    color: var(--foreground) !important;
}

.nav-link.active {
    color: var(--foreground) !important;
    background-color: var(--muted);
    border-radius: var(--radius-sm);
}

.dropdown-menu {
    --bs-dropdown-bg: #ffffff;
    border: 1px solid var(--border);
    box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
    border-radius: var(--radius);
}

.dropdown-item {
    font-size: 0.875rem;
    color: var(--foreground);
    padding: 0.5rem 1rem;
}

.dropdown-item:hover {
    background-color: var(--muted);
    color: var(--foreground);
}

/* ========================================
   Cards
   ======================================== */

.card {
    --bs-card-bg: #ffffff;
    background-color: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: none;
    transition: border-color 0.2s ease;
}

.card:hover {
    border-color: var(--zinc-300);
}

.card-header {
    background-color: transparent;
    border-bottom: 1px solid var(--border);
    padding: 1rem 1.5rem;
    font-weight: 600;
    font-size: 0.875rem;
    color: var(--foreground);
}

.card-body {
    padding: 1.5rem;
}

.card-footer {
    background-color: transparent;
    border-top: 1px solid var(--border);
    padding: 1rem 1.5rem;
}

/* Border variants */
.border-primary {
    border-color: var(--primary) !important;
}

.border-warning {
    border-color: var(--amber-500) !important;
}

/* ========================================
   Buttons
   ======================================== */

.btn {
    border-radius: 9999px;
    font-size: 0.875rem;
    font-weight: 500;
    padding: 0.5rem 1rem;
    transition: all 0.2s ease;
    border: 1px solid transparent;
}

.btn-primary {
    background-color: var(--primary);
    border-color: var(--primary);
    color: var(--primary-foreground);
}

.btn-primary:hover,
.btn-primary:focus {
    background-color: var(--primary-hover);
    border-color: var(--primary-hover);
    color: var(--primary-foreground);
}

.btn-outline-primary {
    background-color: transparent;
    border-color: var(--border);
    color: var(--foreground);
}

.btn-outline-primary:hover,
.btn-outline-primary:focus {
    background-color: var(--muted);
    border-color: var(--zinc-300);
    color: var(--foreground);
}

.btn-success {
    background-color: var(--green-600);
    border-color: var(--green-600);
    color: white;
}

.btn-success:hover,
.btn-success:focus {
    background-color: var(--green-700);
    border-color: var(--green-700);
    color: white;
}

.btn-danger {
    background-color: var(--red-600);
    border-color: var(--red-600);
    color: white;
}

.btn-danger:hover,
.btn-danger:focus {
    background-color: var(--red-700);
    border-color: var(--red-700);
    color: white;
}

.btn-warning {
    background-color: var(--amber-500);
    border-color: var(--amber-500);
    color: white;
}

.btn-warning:hover,
.btn-warning:focus {
    background-color: var(--amber-600);
    border-color: var(--amber-600);
    color: white;
}

.btn-outline-secondary,
.btn-secondary {
    background-color: var(--muted);
    border-color: var(--border);
    color: var(--foreground);
}

.btn-outline-secondary:hover,
.btn-secondary:hover {
    background-color: var(--zinc-200);
    border-color: var(--zinc-300);
    color: var(--foreground);
}

.btn-sm {
    padding: 0.375rem 0.75rem;
    font-size: 0.8125rem;
}

.btn-lg {
    padding: 0.75rem 1.5rem;
    font-size: 1rem;
}

/* ========================================
   Forms
   ======================================== */

.form-control,
.form-select {
    border: 1px solid var(--input);
    border-radius: var(--radius);
    background-color: var(--card);
    color: var(--foreground);
    font-size: 0.875rem;
    padding: 0.5rem 0.75rem;
    transition: all 0.2s ease;
}

.form-control:focus,
.form-select:focus {
    border-color: var(--ring);
    box-shadow: 0 0 0 3px rgba(161, 161, 170, 0.1);
    outline: none;
}

.form-control::placeholder {
    color: var(--muted-foreground);
}

.form-label {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--foreground);
    margin-bottom: 0.5rem;
}

.form-check-input {
    border: 1px solid var(--input);
}

.form-check-input:checked {
    background-color: var(--primary);
    border-color: var(--primary);
}

.form-check-label {
    font-size: 0.875rem;
    color: var(--foreground);
}

.input-group-text {
    background-color: var(--muted);
    border: 1px solid var(--border);
    color: var(--muted-foreground);
}

/* ========================================
   Tables
   ======================================== */

.table {
    --bs-table-bg: #ffffff;
    font-size: 0.875rem;
    color: var(--foreground);
}

.table thead th {
    background-color: transparent;
    border-bottom: 1px solid var(--border);
    color: var(--muted-foreground);
    font-weight: 600;
    font-size: 0.8125rem;
    text-transform: uppercase;
    letter-spacing: 0.025em;
    padding: 0.75rem;
}

.table tbody td {
    border-bottom: 1px solid var(--border);
    padding: 0.75rem;
    vertical-align: middle;
}

.table tbody tr:last-child td {
    border-bottom: none;
}

.table-hover tbody tr:hover {
    background-color: var(--muted);
}

.table-striped tbody tr:nth-of-type(odd) {
    background-color: var(--zinc-50);
}

/* ========================================
   Badges
   ======================================== */

.badge {
    font-size: 0.7em;
    font-weight: 700;
    padding: 0.25rem 0.625rem;
    border-radius: 9999px;
    border: 1px solid transparent;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.bg-primary {
    background-color: var(--primary) !important;
    color: var(--primary-foreground) !important;
}

.bg-success {
    background-color: var(--green-100) !important;
    color: var(--green-700) !important;
    border-color: var(--green-200) !important;
}

.bg-danger {
    background-color: var(--red-100) !important;
    color: var(--red-700) !important;
    border-color: var(--red-200) !important;
}

.bg-warning {
    background-color: var(--amber-100) !important;
    color: var(--amber-700) !important;
    border-color: var(--amber-200) !important;
}

.bg-info {
    background-color: var(--blue-100) !important;
    color: var(--blue-700) !important;
    border-color: var(--blue-200) !important;
}

.bg-secondary {
    background-color: var(--muted) !important;
    color: var(--muted-foreground) !important;
    border-color: var(--border) !important;
}

.bg-light {
    background-color: var(--muted) !important;
    color: var(--foreground) !important;
}

/* ========================================
   Alerts
   ======================================== */

.alert {
    border-radius: var(--radius);
    border: 1px solid;
    font-size: 0.875rem;
    padding: 1rem;
}

.alert-success {
    background-color: var(--green-50);
    border-color: var(--green-200);
    color: var(--green-700);
}

.alert-danger {
    background-color: var(--red-50);
    border-color: var(--red-200);
    color: var(--red-700);
}

.alert-warning {
    background-color: var(--amber-50);
    border-color: var(--amber-200);
    color: var(--amber-700);
}

.alert-info {
    background-color: var(--blue-50);
    border-color: var(--blue-200);
    color: var(--blue-700);
}

.alert-primary {
    background-color: var(--zinc-50);
    border-color: var(--zinc-200);
    color: var(--zinc-700);
}

.alert .alert-heading {
    font-weight: 600;
    margin-bottom: 0.5rem;
}

/* ========================================
   List Groups
   ======================================== */

.list-group-item {
    border: 1px solid var(--border);
    background-color: transparent;
    color: var(--foreground);
    font-size: 0.875rem;
    padding: 0.75rem 1rem;
}

.list-group-item:hover {
    background-color: var(--muted);
}

.list-group-flush .list-group-item {
    border-left: 0;
    border-right: 0;
    border-radius: 0;
}

/* ========================================
   Typography
   ======================================== */

h1, h2, h3, h4, h5, h6 {
    color: var(--foreground);
    font-weight: 600;
}

h1 { font-size: 2rem; }
h2 { font-size: 1.5rem; }
h3 { font-size: 1.25rem; }
h4 { font-size: 1.125rem; }
h5 { font-size: 1rem; }
h6 { font-size: 0.875rem; }

.text-muted {
    color: var(--muted-foreground) !important;
}

.text-primary {
    color: var(--primary) !important;
}

.text-success {
    color: var(--green-600) !important;
}

.text-danger {
    color: var(--red-600) !important;
}

.text-warning {
    color: var(--amber-600) !important;
}

.display-4 {
    font-weight: 700;
}

/* ========================================
   Footer
   ======================================== */

footer {
    background-color: var(--card) !important;
    border-top: 1px solid var(--border);
}

/* ========================================
   Calendar Specific Styles
   ======================================== */

.calendar-table {
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
}

.calendar-table th {
    background-color: var(--muted);
    border: 1px solid var(--border);
    color: var(--foreground);
    font-weight: 600;
    font-size: 0.8125rem;
}

.calendar-table td {
    border: 1px solid var(--border);
    background-color: var(--card);
}

.calendar-day {
    min-height: 80px;
}

.calendar-day.today {
    border: 2px solid var(--blue-500);
}

.calendar-day.other-month {
    background-color: var(--zinc-50);
    opacity: 0.5;
}

.calendar-holiday {
    background-color: var(--red-50) !important;
}

.calendar-holiday-name {
    color: var(--red-600);
    font-size: 0.75rem;
    font-weight: 500;
}

.time-off-item {
    border-radius: var(--radius-sm);
    font-size: 0.75rem;
    border: 1px solid;
}

/* Time off type colors - light backgrounds with borders and colored text */
.time-off-personal {
    background-color: var(--timeoff-personal-bg);
    border: 1px solid var(--timeoff-personal-border);
    color: var(--timeoff-personal-text);
}

.time-off-patron {
    background-color: var(--timeoff-patron-bg);
    border: 1px solid var(--timeoff-patron-border);
    color: var(--timeoff-patron-text);
}

.time-off-sick {
    background-color: var(--timeoff-sick-bg);
    border: 1px solid var(--timeoff-sick-border);
    color: var(--timeoff-sick-text);
}

.time-off-death_in_family {
    background-color: var(--timeoff-death-bg);
    border: 1px solid var(--timeoff-death-border);
    color: var(--timeoff-death-text);
}

.time-off-moving {
    background-color: var(--timeoff-moving-bg);
    border: 1px solid var(--timeoff-moving-border);
    color: var(--timeoff-moving-text);
}

.time-off-marriage {
    background-color: var(--timeoff-marriage-bg);
    border: 1px solid var(--timeoff-marriage-border);
    color: var(--timeoff-marriage-text);
}

.time-off-childbirth {
    background-color: var(--timeoff-childbirth-bg);
    border: 1px solid var(--timeoff-childbirth-border);
    color: var(--timeoff-childbirth-text);
}

.time-off-paternity_leave {
    background-color: var(--timeoff-paternity-bg);
    border: 1px solid var(--timeoff-paternity-border);
    color: var(--timeoff-paternity-text);
}

.time-off-maternity_leave {
    background-color: var(--timeoff-maternity-bg);
    border: 1px solid var(--timeoff-maternity-border);
    color: var(--timeoff-maternity-text);
}

/* ========================================
   Utilities
   ======================================== */

.shadow-sm {
    box-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05) !important;
}

.shadow {
    box-shadow: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1) !important;
}

.border-top {
    border-top-color: var(--border) !important;
}

.border-bottom {
    border-bottom-color: var(--border) !important;
}

.border {
    border-color: var(--border) !important;
}

/* Container adjustments */
.container {
    max-width: 1400px;
}

/* Pagination */
.pagination .page-link {
    border: 1px solid var(--border);
    color: var(--foreground);
    border-radius: var(--radius-sm);
    margin: 0 0.125rem;
}

.pagination .page-link:hover {
    background-color: var(--muted);
    border-color: var(--border);
}

.pagination .page-item.active .page-link {
    background-color: var(--primary);
    border-color: var(--primary);
}

/* Pagination Arrow Styling - Swapped appearance */
/* Clickable arrows: prominent, fully opaque */
.pagination-arrow {
    opacity: 1;
    background-color: var(--muted) !important;
    border-color: var(--border) !important;
    color: var(--foreground) !important;
    cursor: pointer;
}

.pagination-arrow:hover {
    background-color: var(--zinc-200) !important;
    border-color: var(--zinc-300) !important;
}

/* Disabled arrows: subtle, dimmed appearance */
.pagination-arrow-disabled {
    opacity: 0.4;
    background-color: transparent !important;
    border-color: var(--border) !important;
    color: var(--muted-foreground) !important;
    cursor: not-allowed;
    pointer-events: none;
}

/* Modal */
.modal-content {
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
}

.modal-header {
    border-bottom: 1px solid var(--border);
}

.modal-footer {
    border-top: 1px solid var(--border);
}

/* Tooltips */
.tooltip-inner {
    background-color: var(--zinc-900);
    border-radius: var(--radius);
    font-size: 0.75rem;
}

/* Progress bars */
.progress {
    background-color: var(--muted);
    border-radius: var(--radius);
}

.progress-bar {
    background-color: var(--primary);
}

/* Close button */
.btn-close {
    opacity: 0.5;
}

.btn-close:hover {
    opacity: 1;
}
