@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&display=swap";
@layer components;

@layer properties {
    @supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))) {

        *,
        :before,
        :after,
        ::backdrop {
            --tw-translate-x: 0;
            --tw-translate-y: 0;
            --tw-translate-z: 0;
            --tw-scale-x: 1;
            --tw-scale-y: 1;
            --tw-scale-z: 1;
            --tw-rotate-x: initial;
            --tw-rotate-y: initial;
            --tw-rotate-z: initial;
            --tw-skew-x: initial;
            --tw-skew-y: initial;
            --tw-space-y-reverse: 0;
            --tw-divide-y-reverse: 0;
            --tw-border-style: solid;
            --tw-gradient-position: initial;
            --tw-gradient-from: #0000;
            --tw-gradient-via: #0000;
            --tw-gradient-to: #0000;
            --tw-gradient-stops: initial;
            --tw-gradient-via-stops: initial;
            --tw-gradient-from-position: 0%;
            --tw-gradient-via-position: 50%;
            --tw-gradient-to-position: 100%;
            --tw-leading: initial;
            --tw-font-weight: initial;
            --tw-tracking: initial;
            --tw-ordinal: initial;
            --tw-slashed-zero: initial;
            --tw-numeric-figure: initial;
            --tw-numeric-spacing: initial;
            --tw-numeric-fraction: initial;
            --tw-shadow: 0 0 #0000;
            --tw-shadow-color: initial;
            --tw-shadow-alpha: 100%;
            --tw-inset-shadow: 0 0 #0000;
            --tw-inset-shadow-color: initial;
            --tw-inset-shadow-alpha: 100%;
            --tw-ring-color: initial;
            --tw-ring-shadow: 0 0 #0000;
            --tw-inset-ring-color: initial;
            --tw-inset-ring-shadow: 0 0 #0000;
            --tw-ring-inset: initial;
            --tw-ring-offset-width: 0px;
            --tw-ring-offset-color: #fff;
            --tw-ring-offset-shadow: 0 0 #0000;
            --tw-outline-style: solid;
            --tw-blur: initial;
            --tw-brightness: initial;
            --tw-contrast: initial;
            --tw-grayscale: initial;
            --tw-hue-rotate: initial;
            --tw-invert: initial;
            --tw-opacity: initial;
            --tw-saturate: initial;
            --tw-sepia: initial;
            --tw-drop-shadow: initial;
            --tw-drop-shadow-color: initial;
            --tw-drop-shadow-alpha: 100%;
            --tw-drop-shadow-size: initial;
            --tw-backdrop-blur: initial;
            --tw-backdrop-brightness: initial;
            --tw-backdrop-contrast: initial;
            --tw-backdrop-grayscale: initial;
            --tw-backdrop-hue-rotate: initial;
            --tw-backdrop-invert: initial;
            --tw-backdrop-opacity: initial;
            --tw-backdrop-saturate: initial;
            --tw-backdrop-sepia: initial;
            --tw-duration: initial;
            --tw-ease: initial;
            --tw-content: ""
        }
    }
}

@layer theme {

    :root,
    :host {
        --font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
        --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
        --color-red-50: oklch(97.1% .013 17.38);
        --color-red-100: oklch(93.6% .032 17.717);
        --color-red-200: oklch(88.5% .062 18.334);
        --color-red-300: oklch(80.8% .114 19.571);
        --color-red-400: oklch(70.4% .191 22.216);
        --color-red-500: oklch(63.7% .237 25.331);
        --color-red-600: oklch(57.7% .245 27.325);
        --color-red-700: oklch(50.5% .213 27.518);
        --color-red-800: oklch(44.4% .177 26.899);
        --color-red-900: oklch(39.6% .141 25.723);
        --color-orange-100: oklch(95.4% .038 75.164);
        --color-orange-300: oklch(83.7% .128 66.29);
        --color-orange-400: oklch(75% .183 55.934);
        --color-orange-500: oklch(70.5% .213 47.604);
        --color-orange-600: oklch(64.6% .222 41.116);
        --color-orange-700: oklch(55.3% .195 38.402);
        --color-amber-50: oklch(98.7% .022 95.277);
        --color-amber-100: oklch(96.2% .059 95.617);
        --color-amber-200: oklch(92.4% .12 95.746);
        --color-amber-300: oklch(87.9% .169 91.605);
        --color-amber-400: oklch(82.8% .189 84.429);
        --color-amber-600: oklch(66.6% .179 58.318);
        --color-amber-700: oklch(55.5% .163 48.998);
        --color-amber-800: oklch(47.3% .137 46.201);
        --color-amber-900: oklch(41.4% .112 45.904);
        --color-yellow-50: oklch(98.7% .026 102.212);
        --color-yellow-100: oklch(97.3% .071 103.193);
        --color-yellow-200: oklch(94.5% .129 101.54);
        --color-yellow-300: oklch(90.5% .182 98.111);
        --color-yellow-400: oklch(85.2% .199 91.936);
        --color-yellow-500: oklch(79.5% .184 86.047);
        --color-yellow-600: oklch(68.1% .162 75.834);
        --color-yellow-700: oklch(55.4% .135 66.442);
        --color-green-50: oklch(98.2% .018 155.826);
        --color-green-100: oklch(96.2% .044 156.743);
        --color-green-400: oklch(79.2% .209 151.711);
        --color-green-500: oklch(72.3% .219 149.579);
        --color-green-600: oklch(62.7% .194 149.214);
        --color-green-700: oklch(52.7% .154 150.069);
        --color-green-900: oklch(39.3% .095 152.535);
        --color-emerald-50: oklch(97.9% .021 166.113);
        --color-emerald-100: oklch(95% .052 163.051);
        --color-emerald-200: oklch(90.5% .093 164.15);
        --color-emerald-300: oklch(84.5% .143 164.978);
        --color-emerald-500: oklch(69.6% .17 162.48);
        --color-emerald-600: oklch(59.6% .145 163.225);
        --color-emerald-700: oklch(50.8% .118 165.612);
        --color-emerald-900: oklch(37.8% .077 168.94);
        --color-blue-50: oklch(97% .014 254.604);
        --color-blue-100: oklch(93.2% .032 255.585);
        --color-blue-200: oklch(88.2% .059 254.128);
        --color-blue-300: oklch(80.9% .105 251.813);
        --color-blue-400: oklch(70.7% .165 254.624);
        --color-blue-500: oklch(62.3% .214 259.815);
        --color-blue-600: oklch(54.6% .245 262.881);
        --color-blue-700: oklch(48.8% .243 264.376);
        --color-blue-800: oklch(42.4% .199 265.638);
        --color-blue-900: oklch(37.9% .146 265.522);
        --color-indigo-50: oklch(96.2% .018 272.314);
        --color-indigo-100: oklch(93% .034 272.788);
        --color-indigo-400: oklch(67.3% .182 276.935);
        --color-indigo-500: oklch(58.5% .233 277.117);
        --color-indigo-600: oklch(51.1% .262 276.966);
        --color-indigo-700: oklch(45.7% .24 277.023);
        --color-purple-50: oklch(97.7% .014 308.299);
        --color-purple-100: oklch(94.6% .033 307.174);
        --color-purple-400: oklch(71.4% .203 305.504);
        --color-purple-600: oklch(55.8% .288 302.321);
        --color-purple-900: oklch(38.1% .176 304.987);
        --color-rose-50: oklch(96.9% .015 12.422);
        --color-rose-200: oklch(89.2% .058 10.001);
        --color-rose-500: oklch(64.5% .246 16.439);
        --color-rose-600: oklch(58.6% .253 17.585);
        --color-rose-700: oklch(51.4% .222 16.935);
        --color-slate-50: oklch(98.4% .003 247.858);
        --color-slate-100: oklch(96.8% .007 247.896);
        --color-slate-200: oklch(92.9% .013 255.508);
        --color-slate-300: oklch(86.9% .022 252.894);
        --color-slate-400: oklch(70.4% .04 256.788);
        --color-slate-500: oklch(55.4% .046 257.417);
        --color-slate-600: oklch(44.6% .043 257.281);
        --color-slate-700: oklch(37.2% .044 257.287);
        --color-slate-800: oklch(27.9% .041 260.031);
        --color-slate-900: oklch(20.8% .042 265.755);
        --color-slate-950: oklch(12.9% .042 264.695);
        --color-gray-300: oklch(87.2% .01 258.338);
        --color-gray-600: oklch(44.6% .03 256.802);
        --color-black: #000;
        --color-white: #fff;
        --spacing: .25rem;
        --container-sm: 24rem;
        --container-md: 28rem;
        --container-lg: 32rem;
        --container-xl: 36rem;
        --container-2xl: 42rem;
        --container-6xl: 72rem;
        --text-xs: .75rem;
        --text-xs--line-height: calc(1/.75);
        --text-sm: .875rem;
        --text-sm--line-height: calc(1.25/.875);
        --text-base: 1rem;
        --text-base--line-height: 1.5;
        --text-lg: 1.125rem;
        --text-lg--line-height: calc(1.75/1.125);
        --text-xl: 1.25rem;
        --text-xl--line-height: calc(1.75/1.25);
        --text-2xl: 1.5rem;
        --text-2xl--line-height: calc(2/1.5);
        --text-3xl: 1.875rem;
        --text-3xl--line-height: 1.2;
        --text-4xl: 2.25rem;
        --text-4xl--line-height: calc(2.5/2.25);
        --text-5xl: 3rem;
        --text-5xl--line-height: 1;
        --font-weight-normal: 400;
        --font-weight-medium: 500;
        --font-weight-semibold: 600;
        --font-weight-bold: 700;
        --font-weight-extrabold: 800;
        --font-weight-black: 900;
        --tracking-tighter: -.05em;
        --tracking-tight: -.025em;
        --tracking-wide: .025em;
        --tracking-wider: .05em;
        --tracking-widest: .1em;
        --leading-tight: 1.25;
        --leading-snug: 1.375;
        --leading-normal: 1.5;
        --leading-relaxed: 1.625;
        --radius-md: .375rem;
        --radius-lg: .5rem;
        --radius-xl: .75rem;
        --radius-2xl: 1rem;
        --radius-3xl: 1.5rem;
        --drop-shadow-sm: 0 1px 2px #00000026;
        --ease-out: cubic-bezier(0, 0, .2, 1);
        --animate-spin: spin 1s linear infinite;
        --animate-pulse: pulse 2s cubic-bezier(.4, 0, .6, 1)infinite;
        --blur-sm: 8px;
        --blur-md: 12px;
        --blur-xl: 24px;
        --blur-2xl: 40px;
        --aspect-video: 16/9;
        --default-transition-duration: .15s;
        --default-transition-timing-function: cubic-bezier(.4, 0, .2, 1);
        --default-font-family: var(--font-sans);
        --default-mono-font-family: var(--font-mono);
        --color-primary: var(--primary);
        --color-primary-light: var(--primary-light)
    }
}

@layer base {

    *,
    :after,
    :before,
    ::backdrop {
        box-sizing: border-box;
        border: 0 solid;
        margin: 0;
        padding: 0
    }

    ::file-selector-button {
        box-sizing: border-box;
        border: 0 solid;
        margin: 0;
        padding: 0
    }

    html,
    :host {
        -webkit-text-size-adjust: 100%;
        tab-size: 4;
        line-height: 1.5;
        font-family: var(--default-font-family, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");
        font-feature-settings: var(--default-font-feature-settings, normal);
        font-variation-settings: var(--default-font-variation-settings, normal);
        -webkit-tap-highlight-color: transparent
    }

    hr {
        height: 0;
        color: inherit;
        border-top-width: 1px
    }

    abbr:where([title]) {
        -webkit-text-decoration: underline dotted;
        text-decoration: underline dotted
    }

    h1,
    h2,
    h3,
    h4,
    h5,
    h6 {
        font-size: inherit;
        font-weight: inherit
    }

    a {
        color: inherit;
        -webkit-text-decoration: inherit;
        text-decoration: inherit
    }

    b,
    strong {
        font-weight: bolder
    }

    code,
    kbd,
    samp,
    pre {
        font-family: var(--default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);
        font-feature-settings: var(--default-mono-font-feature-settings, normal);
        font-variation-settings: var(--default-mono-font-variation-settings, normal);
        font-size: 1em
    }

    small {
        font-size: 80%
    }

    sub,
    sup {
        vertical-align: baseline;
        font-size: 75%;
        line-height: 0;
        position: relative
    }

    sub {
        bottom: -.25em
    }

    sup {
        top: -.5em
    }

    table {
        text-indent: 0;
        border-color: inherit;
        border-collapse: collapse
    }

    :-moz-focusring {
        outline: auto
    }

    progress {
        vertical-align: baseline
    }

    summary {
        display: list-item
    }

    ol,
    ul,
    menu {
        list-style: none
    }

    img,
    svg,
    video,
    canvas,
    audio,
    iframe,
    embed,
    object {
        vertical-align: middle;
        display: block
    }

    img,
    video {
        max-width: 100%;
        height: auto
    }

    button,
    input,
    select,
    optgroup,
    textarea {
        font: inherit;
        font-feature-settings: inherit;
        font-variation-settings: inherit;
        letter-spacing: inherit;
        color: inherit;
        opacity: 1;
        background-color: #0000;
        border-radius: 0
    }

    ::file-selector-button {
        font: inherit;
        font-feature-settings: inherit;
        font-variation-settings: inherit;
        letter-spacing: inherit;
        color: inherit;
        opacity: 1;
        background-color: #0000;
        border-radius: 0
    }

    :where(select:is([multiple], [size])) optgroup {
        font-weight: bolder
    }

    :where(select:is([multiple], [size])) optgroup option {
        padding-inline-start: 20px
    }

    ::file-selector-button {
        margin-inline-end: 4px
    }

    ::placeholder {
        opacity: 1
    }

    @supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px) {
        ::placeholder {
            color: currentColor
        }

        @supports (color:color-mix(in lab, red, red)) {
            ::placeholder {
                color: color-mix(in oklab, currentcolor 50%, transparent)
            }
        }
    }

    textarea {
        resize: vertical
    }

    ::-webkit-search-decoration {
        -webkit-appearance: none
    }

    ::-webkit-date-and-time-value {
        min-height: 1lh;
        text-align: inherit
    }

    ::-webkit-datetime-edit {
        display: inline-flex
    }

    ::-webkit-datetime-edit-fields-wrapper {
        padding: 0
    }

    ::-webkit-datetime-edit {
        padding-block: 0
    }

    ::-webkit-datetime-edit-year-field {
        padding-block: 0
    }

    ::-webkit-datetime-edit-month-field {
        padding-block: 0
    }

    ::-webkit-datetime-edit-day-field {
        padding-block: 0
    }

    ::-webkit-datetime-edit-hour-field {
        padding-block: 0
    }

    ::-webkit-datetime-edit-minute-field {
        padding-block: 0
    }

    ::-webkit-datetime-edit-second-field {
        padding-block: 0
    }

    ::-webkit-datetime-edit-millisecond-field {
        padding-block: 0
    }

    ::-webkit-datetime-edit-meridiem-field {
        padding-block: 0
    }

    ::-webkit-calendar-picker-indicator {
        line-height: 1
    }

    :-moz-ui-invalid {
        box-shadow: none
    }

    button,
    input:where([type=button], [type=reset], [type=submit]) {
        appearance: button
    }

    ::file-selector-button {
        appearance: button
    }

    ::-webkit-inner-spin-button {
        height: auto
    }

    ::-webkit-outer-spin-button {
        height: auto
    }

    [hidden]:where(:not([hidden=until-found])) {
        display: none !important
    }
}


html {
    font-size: 15px
}

:root {
    --primary: #002395;
    --primary-rgb: 0, 35, 149;
    --primary-light: #3b82f6;
    --primary-text: #002395;
    --accent: #eab308;
    --accent-rgb: 234, 179, 8;
    --bg-color: #f8fafc;
    --text-color: #0f172a;
    --text-color-rgb: 15, 23, 42;
    --border-color: #00000014;
    --glass-bg: #ffffffd9;
    --input-bg: #fff;
    --card-shadow: 0 1px 3px 0 #0000001a, 0 1px 2px 0 #0000000f;
    --glass-border: #94a3b826;
    --sidebar-bg: linear-gradient(to bottom, #dbeafe, #fff);
    --navbar-bg: linear-gradient(to right, #dbeafe, #fff);
    --card-bg: #fffc;
    --card-header-bg: #f8fafc80;
    --item-bg: #fff;
    --item-border: #0000000d
}

.dark {
    --primary: #60a5fa;
    --primary-rgb: 96, 165, 250;
    --primary-text: #93c5fd;
    --bg-color: #020617;
    --text-color: #f8fafc;
    --text-color-rgb: 248, 250, 252;
    --border-color: #ffffff1f;
    --glass-bg: #0f172ad9;
    --input-bg: #0f172a;
    --card-shadow: 0 20px 25px -5px #00000080;
    --glass-border: #ffffff1a;
    --sidebar-bg: #0f172a;
    --navbar-bg: #0f172ae6;
    --card-bg: #0f172a99;
    --card-header-bg: #1e293b66;
    --item-bg: #1e293b4d;
    --item-border: #ffffff14
}

body {
    background-color: var(--bg-color);
    color: var(--text-color);
    background-image: radial-gradient(circle at 0% 0%, rgba(var(--primary-rgb), .05)0%, transparent 50%), radial-gradient(circle at 100% 100%, rgba(var(--accent-rgb), .05)0%, transparent 50%);
    -webkit-font-smoothing: antialiased;
    background-attachment: fixed;
    min-height: 100vh;
    margin: 0;
    font-family: Outfit, sans-serif
}

#root {
    flex-direction: column;
    width: 100%;
    min-height: 100vh;
    display: flex
}

.glass-panel {
    background: var(--glass-bg);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid var(--glass-border);
    box-shadow: var(--card-shadow);
    border-radius: 16px
}

.btn {
    cursor: pointer;
    border: none;
    border-radius: 8px;
    padding: .75rem 1.5rem;
    font-weight: 600;
    transition: all .2s
}

.btn-primary {
    background: var(--primary);
    color: #fff;
    box-shadow: 0 4px 12px #00239533
}

.btn-primary:hover {
    background: var(--primary-light);
    transform: translateY(-2px);
    box-shadow: 0 6px 16px #0023954d
}

input,
textarea {
    background: var(--input-bg);
    border: 1px solid var(--border-color);
    color: var(--text-color);
    box-sizing: border-box;
    border-radius: 8px;
    width: 100%;
    padding: .75rem;
    font-family: inherit;
    transition: border-color .2s
}

input:focus,
textarea:focus {
    border-color: var(--primary);
    outline: none;
    box-shadow: 0 0 0 3px #0023951a
}

.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 2rem
}

.grid-dashboard {
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    display: grid
}

.section-title {
    color: var(--primary);
    text-transform: uppercase;
    letter-spacing: .05em;
    border-bottom: 2px solid #e2e8f0;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
    padding-bottom: .5rem;
    font-size: 1.25rem;
    font-weight: 700;
    display: flex
}

.navbar-glass {
    background: var(--glass-bg);
    -webkit-backdrop-filter: blur(12px);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--border-color);
    z-index: 50;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 2rem;
    display: flex;
    position: sticky;
    top: 0;
    box-shadow: 0 1px 2px #0000000d
}

.navbar-brand {
    align-items: center;
    gap: 1rem;
    display: flex
}

.navbar-logo {
    background: var(--input-bg);
    border: 1px solid var(--glass-border);
    border-radius: 50%;
    flex-shrink: 0;
    justify-content: center;
    align-items: center;
    width: 40px;
    height: 40px;
    display: flex;
    overflow: hidden;
    box-shadow: 0 2px 8px #0000000d
}

.navbar-logo img {
    object-fit: contain;
    width: 70%;
    height: 70%
}

.navbar-title {
    letter-spacing: -.02em;
    color: var(--primary);
    margin: 0;
    font-size: 1.25rem;
    font-weight: 800;
    line-height: 1.1
}

.navbar-user-info {
    text-align: right
}

.department-name {
    color: var(--text-color);
    font-weight: 600
}

.user-role {
    color: #64748b;
    font-size: .8rem
}

.dashboard-container {
    box-sizing: border-box;
    flex: 1;
    width: 100%;
    max-width: 100%;
    margin: 1rem 0;
    padding: 0 1rem
}

.header-actions {
    justify-content: space-between;
    align-items: center;
    margin-bottom: 2rem;
    display: flex
}

.page-title {
    color: var(--primary);
    font-size: 1.5rem;
    font-weight: 700
}

.admin-badge {
    color: #854d0e;
    background: #fef9c3;
    border: 1px solid #fde047;
    border-radius: 4px;
    margin-left: 1rem;
    padding: .2rem .5rem;
    font-size: .9rem
}

.mobile-only-flex,
.mobile-only-block {
    display: none !important
}

.desktop-only-flex {
    display: flex !important
}

@media(max-width:768px) {
    .mobile-only-flex {
        display: flex !important
    }

    .mobile-only-block {
        display: block !important
    }

    .desktop-only-flex {
        display: none !important
    }
}

.login-page {
    background: var(--bg-color);
    box-sizing: border-box;
    justify-content: center;
    align-items: center;
    min-height: 100vh;
    padding: 2rem;
    display: flex
}

.login-card {
    background: var(--input-bg);
    border-radius: 24px;
    width: 100%;
    max-width: 1000px;
    height: 600px;
    display: flex;
    position: relative;
    overflow: hidden;
    box-shadow: 0 25px 50px -12px #0000001a, 0 0 0 1px #0000000d
}

.theme-toggle-btn {
    z-index: 50;
    background: var(--bg-color);
    border: 1px solid var(--glass-border);
    cursor: pointer;
    color: var(--text-color);
    border-radius: 50%;
    justify-content: center;
    align-items: center;
    padding: .5rem;
    transition: transform .2s;
    display: flex;
    position: absolute;
    top: 1.5rem;
    right: 1.5rem
}

.theme-toggle-btn:hover {
    transform: scale(1.1)
}

.login-brand-side {
    flex-direction: column;
    flex: 1.2;
    justify-content: flex-end;
    padding: 3rem;
    display: flex;
    position: relative;
    overflow: hidden
}

.login-bg-img {
    object-fit: cover;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0
}

.login-overlay {
    background: linear-gradient(#00239566, #002395e6);
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0
}

.login-brand-content {
    z-index: 10;
    position: relative
}

.login-logo-wrapper {
    background: #fff;
    border-radius: 50%;
    justify-content: center;
    align-items: center;
    width: 60px;
    height: 60px;
    margin-bottom: 1.5rem;
    display: flex;
    overflow: hidden;
    box-shadow: 0 10px 20px #0000001a
}

.login-logo {
    object-fit: contain;
    width: 70%;
    height: auto
}

.login-title {
    color: #fff;
    margin-top: 0;
    margin-bottom: .5rem;
    font-size: 2.5rem;
    font-weight: 700;
    line-height: 1.1
}

.login-title-accent {
    color: var(--accent)
}

.login-subtitle {
    color: #e2e8f0;
    max-width: 90%;
    font-size: 1rem;
    line-height: 1.6
}

.login-branding-pills {
    gap: .4rem;
    margin-top: 2rem;
    display: flex
}

.pill-active {
    background: var(--accent);
    border-radius: 2px;
    width: 2rem;
    height: 4px
}

.pill-inactive {
    background: #ffffff4d;
    border-radius: 2px;
    width: .5rem;
    height: 4px
}

.login-form-side {
    background: var(--input-bg);
    flex: 1;
    justify-content: center;
    align-items: center;
    padding: 3rem;
    display: flex
}

.login-form-container {
    width: 100%;
    max-width: 320px
}

.login-form-header {
    margin-bottom: 2.5rem
}

.login-welcome-text {
    color: var(--text-color);
    margin-top: 0;
    margin-bottom: .5rem;
    font-size: 2rem;
    font-weight: 700
}

.login-instruction-text {
    color: #64748b;
    margin: 0
}

.dark .login-instruction-text {
    color: #94a3b8
}

.login-error-msg {
    color: #991b1b;
    text-align: center;
    background: #fee2e2;
    border: 1px solid #fecaca;
    border-radius: 6px;
    margin-bottom: 1.5rem;
    padding: .75rem;
    font-size: .85rem
}

.form-group {
    margin-bottom: 1.25rem
}

.form-label {
    color: #64748b;
    margin-bottom: .5rem;
    font-size: .85rem;
    font-weight: 600;
    display: block
}

.password-input-wrapper {
    position: relative
}

.password-input {
    width: 100%;
    padding-right: 2.5rem !important
}

.password-toggle-btn {
    cursor: pointer;
    color: var(--text-color);
    opacity: .6;
    background: 0 0;
    border: none;
    justify-content: center;
    align-items: center;
    padding: 4px;
    display: flex;
    position: absolute;
    top: 50%;
    right: 10px;
    transform: translateY(-50%)
}

.password-toggle-btn:hover {
    opacity: 1;
    color: var(--primary)
}

.form-input {
    transition: all .2s
}

.form-input.focused {
    border-color: var(--primary);
    background: var(--input-bg);
    box-shadow: 0 0 0 3px #0023951a
}

.login-btn {
    background: var(--primary);
    color: #fff;
    cursor: pointer;
    border: none;
    border-radius: 8px;
    justify-content: center;
    align-items: center;
    gap: .5rem;
    width: 100%;
    padding: 1rem;
    font-size: 1rem;
    font-weight: 700;
    transition: all .2s;
    display: flex;
    box-shadow: 0 4px 12px #00239533
}

.login-btn:hover:not(:disabled) {
    background: var(--primary-light);
    transform: translateY(-2px);
    box-shadow: 0 6px 16px #0023954d
}

.login-btn:disabled {
    opacity: .7;
    cursor: wait
}

.footer-main {
    background: var(--bg-color);
    border-top: 1px solid var(--border-color);
    text-align: center;
    margin-top: auto;
    padding: 2rem
}

.footer-container {
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    max-width: 1200px;
    margin: 0 auto;
    display: flex
}

.footer-logos {
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 3rem;
    display: flex
}

.footer-logo-item {
    flex-direction: column;
    align-items: center;
    gap: .5rem;
    display: flex
}

.footer-logo-img {
    object-fit: contain;
    width: auto;
    height: 40px
}

.footer-divider {
    background: var(--border-color);
    width: 1px;
    height: 40px
}

.footer-copyright {
    color: var(--text-color);
    opacity: .8;
    margin-top: 1rem;
    font-size: .8rem
}

@media(max-width:768px) {
    .login-card {
        border-radius: 16px;
        flex-direction: column;
        max-width: 450px;
        height: auto
    }

    .login-brand-side {
        min-height: 250px;
        padding: 2rem
    }

    .login-brand-content .login-logo-wrapper {
        width: 45px;
        height: 45px;
        margin-bottom: 1rem
    }

    .login-title {
        font-size: 1.8rem
    }

    .login-subtitle {
        font-size: .9rem
    }

    .login-form-side {
        padding: 2rem
    }

    .login-welcome-text {
        font-size: 1.5rem
    }

    .navbar-glass {
        padding: 1rem
    }

    .navbar-title {
        font-size: 1.2rem
    }

    .department-name {
        display: none
    }

    .grid-dashboard {
        grid-template-columns: 1fr;
        gap: 1rem
    }

    .dashboard-container {
        margin: 1rem auto;
        padding: 0 1rem
    }

    .header-actions {
        flex-direction: column;
        align-items: flex-start;
        gap: 1rem
    }

    .page-title {
        font-size: 1.25rem
    }

    .request-footer {
        margin-top: 2rem;
        padding: 1.5rem
    }

    .footer-form {
        flex-direction: column;
        gap: 1rem
    }

    .footer-btn {
        justify-content: center;
        width: 100%;
        padding: 1rem
    }

    .footer-main {
        padding: 1.5rem
    }
}
