@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@400;500;600;700&display=swap";*{box-sizing:border-box;margin:0;padding:0}*:focus{outline:none;background-color:transparent}html,body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0;height:100%;line-height:normal}#root{height:100%}*,*:before,*:after{box-sizing:border-box}html{font-family:"Inter, system-ui, -apple-system, sans-serif";line-height:1.6;font-weight:400;color-scheme:light;color:#111827;background-color:#fff;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;background-color:#f9fafb}#root{width:100%;min-height:100vh}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600;line-height:1.2}h1{font-size:3rem}h2{font-size:2.25rem}h3{font-size:1.875rem}h4{font-size:1.5rem}h5{font-size:1.25rem}h6{font-size:1.125rem}p{margin:0;line-height:line-height("relaxed")}a,.app-link{font-weight:500;color:#1a73e8;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px;transition:color .15s ease-in-out;cursor:pointer;display:inline-flex;align-items:center}a:is(button),.app-link:is(button){background:none;border:none;padding:0;font:inherit;color:#1a73e8}a:hover,.app-link:hover{color:#1765cc}a:focus-visible,.app-link:focus-visible{outline:2px solid #1a73e8;outline-offset:2px;border-radius:.125rem}a--muted,.app-link--muted{color:#9ca3af;text-decoration:none;cursor:default;pointer-events:none}.sr-only,.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.focus-ring:focus-visible{outline:2px solid #4d4d4d;outline-offset:2px}.controls-row{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.controls-row .controls-left{display:flex;align-items:center;gap:1rem;flex:1;max-width:500px}.controls-row .controls-right{display:flex;align-items:center;gap:.75rem}.table-container,.table-wrapper{background:#fff;border-radius:.5rem;border:1px solid #f3f4f6;box-shadow:"0 1px 2px 0 rgba(0, 0, 0, 0.05)";overflow:auto hidden}@media(prefers-color-scheme:dark){html{color:#f3f4f6;background-color:#111827}body{background-color:#1f2937}}.common-mb-1{margin-bottom:.25rem}.common-mb-2{margin-bottom:.5rem}.common-mb-3{margin-bottom:.75rem}.common-mb-4{margin-bottom:1rem}.common-mb-5{margin-bottom:1.25rem}.common-mb-6{margin-bottom:1.5rem}.common-mb-8{margin-bottom:2rem}.common-mt-1{margin-top:.25rem}.common-mt-2{margin-top:.5rem}.common-mt-3{margin-top:.75rem}.common-mt-4{margin-top:1rem}.common-mt-5{margin-top:1.25rem}.common-mt-6{margin-top:1.5rem}.common-mt-8{margin-top:2rem}.common-margin-0{margin:0}.common-flex-column{display:flex;flex-direction:column}.common-align-center{display:flex;align-items:center}.common-justify-between{display:flex;justify-content:space-between}.common-gap-1{gap:.25rem}.common-gap-2{gap:.5rem}.common-gap-3{gap:.75rem}.common-gap-4{gap:1rem}.common-gap-6{gap:1.5rem}:root{--color-white: #ffffff;--color-black: #0e0e0e;--color-grey-primary: #5e5e5e;--color-grey-light: #f9f9f9;--color-grey-border: #c2c2c2;--color-grey-surface: #f6f8f9;--color-bits-blue: #1a165a;--color-bits-sky: #76c2e5;--color-bits-red: #ed1c24;--color-bits-orange: #f0a413;--color-bits-orange-alt: #e8982f;--color-action-default: var(--color-bits-blue);--color-action-hover: #15114a;--color-action-disabled: #9e9e9e;--color-brand-100: #d9d8ef;--color-brand-200: #b5b2dd;--color-brand-300: var(--color-bits-blue);--color-brand-400: #15114a;--color-brand-500: #100d3c;--color-brand-600: #0b092d;--color-brand-light: var(--color-grey-surface);--color-brand-light-hover: #eef2f5;--color-brand-gradient: linear-gradient( 135deg, var(--color-bits-blue) 0%, var(--color-bits-sky) 100% );--color-accent-blue: var(--color-bits-sky);--color-accent-red: var(--color-bits-red);--color-accent-orange: var(--color-bits-orange);--color-accent-orange-alt: var(--color-bits-orange-alt);--color-contrast-brand: var(--color-white);--color-contrast-white: var(--color-white);--color-contrast-black: var(--color-black);--color-contrast-focused: var(--color-bits-blue);--color-feedback-danger-100: #fde8e9;--color-feedback-danger-200: #f9c2c4;--color-feedback-danger-300: #f16f75;--color-feedback-danger-400: #e5484d;--color-feedback-danger-500: #c72c32;--color-feedback-danger-600: #9f1f24;--color-feedback-positive-100: #e4f7eb;--color-feedback-positive-200: #bdeacb;--color-feedback-positive-300: #6dcb8d;--color-feedback-positive-400: #2ea85d;--color-feedback-positive-500: #228247;--color-feedback-positive-600: #196438;--color-feedback-warning-100: #fdf2dc;--color-feedback-warning-200: #f9d8a5;--color-feedback-warning-300: #f4b14c;--color-feedback-warning-400: #e8982f;--color-feedback-warning-500: #c77e14;--color-feedback-warning-600: #9c620e;--color-feedback-info-100: #e6f5fb;--color-feedback-info-200: #c6e7f4;--color-feedback-info-300: var(--color-bits-sky);--color-feedback-info-400: #52afd8;--color-feedback-info-500: #3198c4;--color-feedback-info-600: #217da3;--color-neutral-50: var(--color-grey-light);--color-neutral-75: var(--color-grey-surface);--color-neutral-100: var(--color-white);--color-neutral-200: #e6e6e6;--color-neutral-300: var(--color-grey-border);--color-neutral-400: #999999;--color-neutral-500: var(--color-grey-primary);--color-neutral-600: var(--color-black);--color-neutral-background: var(--color-grey-light);--color-neutral-table-row-banding: var(--color-grey-surface);--color-opacity-default: rgba(255, 255, 255, .32);--color-opacity-hover: rgba(118, 194, 229, .25);--color-opacity-disabled: rgba(194, 194, 194, .32);--color-opacity-error: rgba(237, 28, 36, .12);--color-opacity-backdrop: rgba(0, 0, 0, .5);--font-family-base: "Inter", system-ui, -apple-system, sans-serif;--font-family-heading: "Outfit", sans-serif;--font-family-accent: "Inter", sans-serif;--font-weight-light: 300;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--color-box-shadow: 0 4px 6px rgba(0, 0, 0, .1)}.dashboard{max-width:1200px;margin:0 auto}.dashboard-header{text-align:center;margin-bottom:2rem}.dashboard-title{font-size:2.25rem;font-weight:700;color:#111827;margin-bottom:1rem;line-height:1.2}.dashboard-description{font-size:1.125rem;color:#4b5563;line-height:1.75;max-width:600px;margin:0 auto}.section-title{font-size:1.5rem;font-weight:600;color:#111827;margin-bottom:1.5rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2.5rem}.stat-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:1.5rem;display:flex;align-items:center;gap:1rem;box-shadow:"0 1px 2px 0 rgba(0, 0, 0, 0.05)";transition:all .2s ease-in-out}.stat-card:hover{transform:translateY(-2px);box-shadow:"0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06)"}.stat-card-icon{font-size:1.875rem;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background-color:#e0e0e0;border-radius:.5rem;flex-shrink:0}.stat-card-content{flex:1}.stat-number{font-size:1.875rem;font-weight:700;color:#111827;margin:0 0 .25rem;line-height:1.2}.stat-label{font-size:1rem;color:#4b5563;margin:0;line-height:1.6}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2.5rem}.activity-list{display:flex;flex-direction:column;gap:1rem}.activity-item{display:flex;align-items:flex-start;gap:1rem;padding:1rem;background-color:#fff;border:1px solid #e5e7eb;border-radius:.375rem;transition:all .15s ease-in-out}.activity-item:hover{background-color:#f9fafb;border-color:#d1d5db}.activity-icon{font-size:1.125rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background-color:#d1fae5;border-radius:9999px;flex-shrink:0}.activity-content{flex:1}.activity-text{font-size:1rem;color:#111827;margin:0 0 .25rem;line-height:1.6}.activity-time{font-size:.875rem;color:#6b7280;line-height:1.6}@media(max-width:1023px){.dashboard-title{font-size:1.875rem}.dashboard-description{font-size:1rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.actions-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}}@media(max-width:767px){.dashboard-title{font-size:1.5rem}.dashboard-description{font-size:.875rem}.stats-grid{grid-template-columns:1fr;gap:.75rem}.stat-card{padding:1rem;gap:.75rem}.stat-card-icon{font-size:1.5rem;width:48px;height:48px}.stat-number{font-size:1.5rem}.actions-grid{grid-template-columns:1fr}.section-title{font-size:1.25rem}}@media(max-width:639px){.dashboard-header{margin-bottom:1.5rem}.stat-card{padding:.75rem;flex-direction:column;text-align:center;gap:.5rem}.stat-card-icon{margin:0 auto}.activity-item{padding:.75rem;gap:.75rem}}.custom-sonner{position:fixed;z-index:9999;display:flex;flex-direction:column;gap:.5rem;width:380px;max-width:calc(100vw - 1rem);padding:1rem;pointer-events:none}.custom-sonner-top-left{top:0;left:0;align-items:flex-start}.custom-sonner-top-center{top:0;left:50%;align-items:center;transform:translate(-50%)}.custom-sonner-top-right{top:0;right:0;align-items:flex-end}.custom-sonner-bottom-left{bottom:0;left:0;align-items:flex-start;flex-direction:column-reverse}.custom-sonner-bottom-center{bottom:0;left:50%;align-items:center;flex-direction:column-reverse;transform:translate(-50%)}.custom-sonner-bottom-right{right:0;bottom:0;align-items:flex-end;flex-direction:column-reverse}.custom-sonner-toast{--custom-sonner-accent: #80919b;--custom-sonner-icon-color: #3d515c;--custom-sonner-icon-background: #e6e9eb;display:flex;align-items:flex-start;gap:.75rem;width:100%;padding:.75rem;border:1px solid;border-left:4px solid var(--custom-sonner-accent);border-radius:.75rem;background:#fff;box-shadow:0 4px 16px #00000014,0 1px 4px #0000000f;pointer-events:all;animation:custom-sonner-in .3s cubic-bezier(.16,1,.3,1) both;will-change:transform,opacity}.custom-sonner-toast-default{--custom-sonner-accent: #80919b;--custom-sonner-icon-color: #3d515c;--custom-sonner-icon-background: #e6e9eb}.custom-sonner-toast-success{--custom-sonner-accent: #059669;--custom-sonner-icon-color: #059669;--custom-sonner-icon-background: #d1fae5}.custom-sonner-toast-error{--custom-sonner-accent: #dc2626;--custom-sonner-icon-color: #dc2626;--custom-sonner-icon-background: #fee2e2}.custom-sonner-toast-warning{--custom-sonner-accent: #d97706;--custom-sonner-icon-color: #b45309;--custom-sonner-icon-background: #fef3c7}.custom-sonner-toast-info{--custom-sonner-accent: #4d4d4d;--custom-sonner-icon-color: #262626;--custom-sonner-icon-background: #f5f5f5}.custom-sonner-toast-loading{--custom-sonner-accent: #333;--custom-sonner-icon-color: #333;--custom-sonner-icon-background: #f5f5f5}.custom-sonner-toast-exit{animation:custom-sonner-out .28s cubic-bezier(.4,0,1,1) forwards}@keyframes custom-sonner-in{0%{opacity:0;transform:translate(12px) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes custom-sonner-out{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.92) translateY(-4px)}}.custom-sonner-toast-icon{display:flex;flex-shrink:0;align-items:center;justify-content:center;width:28px;height:28px;min-width:28px;margin-top:1px;border-radius:.375rem;background:var(--custom-sonner-icon-background);color:var(--custom-sonner-icon-color)}.custom-sonner-toast-icon-spin{animation:custom-sonner-spin .8s linear infinite}@keyframes custom-sonner-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.custom-sonner-toast-body{display:flex;flex:1;flex-direction:column;gap:.25rem;min-width:0;padding-top:1px}.custom-sonner-toast-title{margin:0;color:#0d0d0d;font-size:.875rem;font-weight:600;line-height:1.4}.custom-sonner-toast-description{margin:0;color:#4d4d4d;font-size:.75rem;line-height:1.5}.custom-sonner-toast-action{align-self:flex-start;margin-top:.25rem;padding:3px .5rem;border:1px solid #a5f3fc;border-radius:.375rem;background:transparent;color:#262626;cursor:pointer;font-family:"Inter, system-ui, -apple-system, sans-serif";font-size:.75rem;font-weight:500;transition:background .15s ease,border-color .15s ease}.custom-sonner-toast-action:hover{border-color:#999;background:#f5f5f5}.custom-sonner-toast-close{display:flex;flex-shrink:0;align-items:center;justify-content:center;width:22px;height:22px;min-width:22px;margin-top:2px;border:none;border-radius:.375rem;background:transparent;color:#666;cursor:pointer;transition:background .15s ease,color .15s ease}.custom-sonner-toast-close:hover{background:#cffafe;color:#0e7490}.custom-sonner-toast-close:focus-visible{outline:2px solid #4d4d4d;outline-offset:1px}.custom-btn{display:inline-flex;align-items:center;justify-content:center;gap:0;border:none;border-radius:.375rem;line-height:1;font-weight:500;text-decoration:none;cursor:pointer;transition:all .2s ease-in-out;position:relative;overflow:hidden}.custom-btn:disabled{opacity:.6;cursor:not-allowed;pointer-events:none}.custom-btn-full-width{width:100%;display:flex}.custom-btn-icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.custom-btn-icon-left{margin-right:.5rem}.custom-btn-icon-right{margin-left:.5rem}.custom-btn-icon svg{width:1.125em;height:1.125em}.custom-btn-label{display:flex;line-height:1;gap:1rem;align-items:center}.custom-btn-icon-only{padding:0;display:inline-flex;align-items:center;justify-content:center;aspect-ratio:1/1;background-color:transparent;border:none;color:#3d515c}.custom-btn-icon-only:hover:not(:disabled){background-color:#f3f4f6;color:#0f1417}.custom-btn-icon-only.custom-btn-sm{width:2rem;height:2rem}.custom-btn-icon-only.custom-btn-md{width:2.5rem;height:2.5rem}.custom-btn-icon-only.custom-btn-lg{width:3rem;height:3rem}.custom-btn-icon-only svg{margin:0}.custom-btn-loading{cursor:wait;opacity:.7}.custom-btn-loading .custom-btn-loader{width:1rem;height:1rem;border:2px solid currentcolor;border-top-color:transparent;border-radius:50%;animation:button-spin .6s linear infinite;display:inline-block;flex-shrink:0}@keyframes button-spin{to{transform:rotate(360deg)}}.custom-btn-sm{padding:.75rem;font-size:.75rem}.custom-btn-md{padding:.5rem 1rem;font-size:.875rem}.custom-btn-lg{padding:.75rem 1.5rem;font-size:1rem}.custom-btn-primary{background-color:#1f282e;color:#fff}.custom-btn-primary:focus-visible{outline:2px solid #4d6573;outline-offset:2px}.custom-btn-primary:hover:not(:disabled){background-color:#0f1417;transform:translateY(-1px);box-shadow:"0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06)"}.custom-btn-primary:active:not(:disabled){transform:translateY(0)}.custom-btn-secondary{background-color:#fff;color:#374151;border:1px solid #d1d5db}.custom-btn-secondary:focus-visible{outline:2px solid #4d6573;outline-offset:2px}.custom-btn-secondary:hover:not(:disabled){background-color:#f9fafb;border-color:#9ca3af}.custom-btn-success{background-color:#059669;color:#fff}.custom-btn-success:focus-visible{outline:2px solid #10b981;outline-offset:2px}.custom-btn-success:hover:not(:disabled){background-color:#047857}.custom-btn-warning{background-color:#d97706;color:#fff}.custom-btn-warning:focus-visible{outline:2px solid #f59e0b;outline-offset:2px}.custom-btn-warning:hover:not(:disabled){background-color:#b45309}.custom-btn-error{background-color:#dc2626;color:#fff}.custom-btn-error:focus-visible{outline:2px solid #ef4444;outline-offset:2px}.custom-btn-error:hover:not(:disabled){background-color:#b91c1c}.custom-btn-outline{background-color:#fff;color:#374151;border:1px solid #d1d5db}.custom-btn-outline:hover:not(:disabled){background-color:#f9fafb;border-color:#9ca3af}.custom-btn-ghost{background-color:transparent;color:#4b5563;border:1px solid transparent}.custom-btn-ghost:hover:not(:disabled){background-color:#f3f4f6;color:#111827}.custom-btn-link{background-color:transparent;color:#1765cc;padding:0;min-width:auto;height:auto;border-radius:0;font-weight:500;font-size:.75rem;text-decoration:underline}.custom-btn-link:disabled{color:#9ca3af;opacity:1}.custom-btn-link:hover:not(:disabled){color:#1254a3;text-decoration:underline;background-color:transparent}.custom-select-wrapper{display:inline-flex;flex-direction:column}.custom-select-wrapper-full-width{display:flex;width:100%}.custom-select-label{display:flex;align-items:center;gap:.25rem;margin-bottom:.25rem;color:#374151;font-size:.875rem;line-height:1.6;text-transform:capitalize}.custom-select-required{color:#dc2626;font-weight:600}.custom-select-container{--custom-select-height: 44px;--custom-select-padding-inline: 1rem;--custom-select-icon-width: 40px;--custom-select-icon-font-size: 1rem;--custom-select-field-font-size: .875rem;position:relative;display:flex;align-items:stretch;width:100%;overflow:hidden;border:1px solid #d1d5db;border-radius:.375rem;background:#fff;box-shadow:0 1px 2px #0f172a0a;transition:border-color .2s ease-in-out,box-shadow .2s ease-in-out,background-color .2s ease-in-out}.custom-select-container:hover{border-color:#9ca3af}.custom-select-container-sm{--custom-select-height: 36px;--custom-select-padding-inline: .75rem;--custom-select-icon-width: 32px;--custom-select-icon-font-size: .875rem;--custom-select-field-font-size: .75rem}.custom-select-container-md{--custom-select-height: 44px;--custom-select-padding-inline: 1rem;--custom-select-icon-width: 40px;--custom-select-icon-font-size: 1rem;--custom-select-field-font-size: .875rem}.custom-select-container-lg{--custom-select-height: 48px;--custom-select-padding-inline: 1rem;--custom-select-icon-width: 48px;--custom-select-icon-font-size: 1.125rem;--custom-select-field-font-size: 1rem}.custom-select-field{flex:1;min-width:0;height:var(--custom-select-height);border:none;outline:none;background:transparent;color:#374151;font-family:"Inter, system-ui, -apple-system, sans-serif";font-size:var(--custom-select-field-font-size);line-height:1.4;cursor:pointer;appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-left:var(--custom-select-padding-inline);padding-right:var(--custom-select-icon-width)}.custom-select-field:disabled{cursor:not-allowed;color:#6b7280;-webkit-text-fill-color:#6b7280;opacity:1}.custom-select-field:invalid{color:#9ca3af}.custom-select-field option[value=""][disabled]{color:#9ca3af}.custom-select-icon{display:flex;flex-shrink:0;align-items:center;justify-content:center;width:var(--custom-select-icon-width);height:var(--custom-select-height);color:#9ca3af;font-size:var(--custom-select-icon-font-size)}.custom-select-icon-left{order:-1}.custom-select-chevron{position:absolute;right:0;order:1;display:flex;flex-shrink:0;align-items:center;justify-content:center;width:var(--custom-select-icon-width);height:var(--custom-select-height);background:transparent;color:#9ca3af;pointer-events:none;transition:transform .2s ease-in-out}@keyframes custom-select-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.custom-select-loading{animation:custom-select-spin 1s linear infinite;color:#80919b}.custom-select-container-has-left-icon .custom-select-field{padding-left:0}.custom-select-container:focus-within{border-color:#6b7280;box-shadow:0 0 0 3px #e6e9ebe6;outline:none}.custom-select-container:focus-within .custom-select-chevron{transform:rotate(180deg);color:#4b5563}.custom-select-container-error{border-color:#ef4444}.custom-select-container-error:focus-within{border-color:#ef4444;box-shadow:0 0 0 3px #fee2e2f2}.custom-select-container-success{border-color:#10b981}.custom-select-container-success:focus-within{border-color:#10b981;box-shadow:0 0 0 3px #d1fae5f2}.custom-select-container-disabled{pointer-events:none;cursor:not-allowed;border-color:#e5e7eb;background:#f9fafb}.custom-select-message{display:flex;align-items:center;gap:.25rem;margin:0;margin-top:.25rem;font-size:.75rem;line-height:1.6}.custom-select-message-helper{color:#6b7280}.custom-select-message-error{color:#dc2626}.custom-select-message-success{color:#059669}.custom-dropdown{position:relative;display:inline-flex}.custom-dropdown-trigger{display:inline-flex;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none}.custom-dropdown-menu{position:fixed;padding:0;border:1px solid #d1d5db;border-radius:.75rem;background:#fff;box-shadow:0 12px 48px #00000026,0 4px 12px #00000014;animation:custom-dropdown-open .15s ease-out both;z-index:1050;max-width:calc(100vw - 16px);overflow:visible}.custom-dropdown-caret{position:absolute;top:-6px;width:12px;height:12px;background:#fff;border-top:1px solid #d1d5db;border-left:1px solid #d1d5db;transform:rotate(45deg);z-index:10;box-shadow:-2px -2px 5px #0000000a}.custom-dropdown-caret-start{left:16px}.custom-dropdown-caret-center{left:50%;margin-left:-6px}.custom-dropdown-caret-end{right:16px}.custom-dropdown-header{padding:1rem;border-bottom:1px solid #f3f4f6;background:#fff;border-radius:.75rem .75rem 0 0}.custom-dropdown-footer{padding:1rem;border-top:1px solid #f3f4f6;background:#f9fafb;border-radius:0 0 .75rem .75rem;display:flex;justify-content:center;align-items:center}@keyframes custom-dropdown-open{0%{opacity:0;transform:translateY(-8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.custom-dropdown-group{display:flex;flex-direction:column;padding:.25rem}.custom-dropdown-group-label{display:block;padding:.5rem 1rem .25rem;color:#9ca3af;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.custom-dropdown-separator{height:1px;background:#f3f4f6}.custom-dropdown-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;border:none;border-radius:.375rem;background:transparent;color:#1f282e;cursor:pointer;font-family:"Inter, system-ui, -apple-system, sans-serif";font-size:.875rem;font-weight:500;text-align:left;transition:all .2s ease-in-out}.custom-dropdown-item:hover:not(:disabled){background:#f9fafb;color:#111827}.custom-dropdown-item-disabled{pointer-events:none;cursor:not-allowed;opacity:.38}.custom-dropdown-item-icon{display:flex;flex-shrink:0;align-items:center;justify-content:center;width:20px;height:20px;color:#6b7280}.custom-dropdown-item-icon svg{width:16px;height:16px}.custom-dropdown-item-label{flex:1;line-height:1.4;white-space:normal}.custom-dropdown-item-shortcut{flex-shrink:0;color:#9ca3af;font-size:.75rem}.custom-dropdown-item-danger{color:#dc2626}.custom-dropdown-item-danger:hover:not(:disabled){background:#fef2f2;color:#b91c1c}.custom-dropdown-item-danger .custom-dropdown-item-icon{color:inherit}.header{height:5rem;background-color:#fff;border-bottom:1px solid #d1d5db;display:flex;align-items:center;justify-content:space-between;padding:0 2rem;position:sticky;top:0;z-index:1020}.header-left{display:flex;align-items:center;gap:1rem}.header-left .header-brand{display:flex;align-items:center}.header-left .header-brand .brand-label{font-size:1.5rem;font-weight:800;color:#0d0d0d;letter-spacing:.04em;text-transform:uppercase;line-height:1}.header-left .header-breadcrumbs{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:#6b7280;margin-top:.25rem}.header-left .header-breadcrumbs .separator{font-size:10px;opacity:.5;margin:0 .25rem}.header-right{display:flex;align-items:center;gap:1rem}.header-right .header-divider{width:1px;height:1.5rem;background-color:#e5e7eb;margin:0 .5rem}.header-right .icon-btn{background:none;border:none;color:#6b7280;cursor:pointer;padding:0;border-radius:9999px;transition:all .15s;position:relative;display:flex;align-items:center;justify-content:center}.header-right .icon-btn:hover{background-color:#f9fafb;color:#333}.header-right .icon-btn .badge{position:absolute;top:4px;right:4px;background-color:#dc2626;color:#fff;font-size:10px;font-weight:700;width:16px;height:16px;border-radius:9999px;display:flex;align-items:center;justify-content:center;border:2px solid #fff}.header-right .search-container{margin-right:1rem}.header-right .search-container .search-wrapper{display:flex;align-items:center;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;padding:.25rem .75rem;width:18.75rem;transition:all .15s}.header-right .search-container .search-wrapper:focus-within{background-color:#fff;border-color:#999;box-shadow:0 0 0 3px #f5f5f5}.header-right .search-container .search-icon{color:#9ca3af;margin-right:.5rem}.header-right .search-container .search-input{border:none;background:none;outline:none;width:100%;font-size:.875rem;color:#1a1a1a;padding:.25rem 0}.header-right .search-container .search-input::placeholder{color:#9ca3af}.header-right .user-badge{display:flex;align-items:center;gap:.75rem;padding:.25rem .75rem;background-color:#f9fafb;border-radius:9999px;border:1px solid #f3f4f6}.header-right .user-badge .user-icon{width:1.75rem;height:1.75rem;background-color:#fff;border-radius:9999px;display:flex;align-items:center;justify-content:center;color:#333;box-shadow:"0 1px 2px 0 rgba(0, 0, 0, 0.05)"}.header-right .role-switcher{display:flex;align-items:center;margin-right:.5rem;width:13.125rem}.header-right .role-switcher .custom-select-container{flex-direction:row;align-items:center;gap:.75rem}.header-right .logout-btn{background:none;border:none;display:flex;align-items:center;gap:.5rem;color:#4b5563;font-size:.875rem;font-weight:500;cursor:pointer;padding:.5rem .75rem;border-radius:.375rem;transition:all .15s}.header-right .logout-btn:hover{background-color:#f9fafb;color:#0d0d0d}.notification-header{display:flex;align-items:center;justify-content:space-between;width:100%}.notification-header-left{display:flex;align-items:center;gap:.5rem}.notification-header-left .notification-title{font-size:1rem;font-weight:700;color:#111827}.notification-header-left .notification-badge{color:#9ca3af;font-size:11px;font-weight:600;text-transform:uppercase;padding:2px 4px;line-height:1}.notification-header .close-btn{color:#9ca3af;padding:.25rem}.notification-header .close-btn:hover{color:#4b5563;background:#f3f4f6}.notification-icon-wrapper{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:9999px;flex-shrink:0}.notification-icon-wrapper.info{background-color:#e8f0fe;color:#1765cc}.notification-icon-wrapper.warning{background-color:#fffbeb;color:#d97706}.notification-icon-wrapper.success{background-color:#ecfdf5;color:#059669}.notification-item-content{display:flex;flex-direction:column;gap:2px}.notification-item-content .notification-item-title{font-size:.875rem;font-weight:600;color:#0f1417;margin:0}.notification-item-content .notification-item-desc{font-size:.75rem;color:#6b7280;margin:0;line-height:1.4}.notification-item-content .notification-item-time{font-size:11px;color:#9ca3af;margin-top:4px;text-align:right;display:block}.notification-footer{width:100%;display:flex;justify-content:center}.notification-footer .view-all-btn{font-size:.75rem;font-weight:700;letter-spacing:.05em;padding:.75rem 0}.sidebar{width:17.5rem;height:100vh;background:#fff;border-right:1px solid #e5e7eb;display:flex;flex-direction:column;transition:all .3s ease-in-out;position:relative;flex-shrink:0;z-index:1020;box-shadow:"0 1px 2px 0 rgba(0, 0, 0, 0.05)"}.sidebar-header{padding:.5rem;display:flex;align-items:center;margin-bottom:.5rem;position:relative;border-bottom:1px solid #e5e7eb}.sidebar-logo-container{display:flex;align-items:center;gap:.75rem}.sidebar-logo-wrapper{display:flex;align-items:center;justify-content:center}.sidebar-logo{height:100%;max-width:11.25rem;object-fit:contain;transition:transform .3s ease-in-out}.sidebar-logo:hover{transform:scale(1.05)}.sidebar-brand-text{display:flex;flex-direction:column;padding-left:1rem;border-left:1px solid #e5e7eb;justify-content:center}.sidebar-brand-text .portal-name{font-size:.75rem;font-weight:800;color:#0f1417;letter-spacing:.18em;text-transform:uppercase;line-height:1}.sidebar-toggle{position:absolute;right:-.75rem;top:50%;transform:translateY(-50%);width:1.75rem;height:1.75rem;background:linear-gradient(135deg,#fff,#f9fafb);border:1px solid #e5e7eb;border-radius:9999px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 12px #0000001a;color:#6b7280;transition:all .3s ease;z-index:2;padding:0}.sidebar-toggle:hover{color:#333;border-color:#999;background:linear-gradient(135deg,#f5f5f5,#fff);box-shadow:"0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06)";transform:translateY(-50%) scale(1.1)}.sidebar-toggle:active{transform:translateY(-50%) scale(.95)}.sidebar-nav-section{flex:1;display:flex;flex-direction:column}.nav-section-header{padding:0 1.5rem .75rem;font-size:.875rem;font-weight:600;color:#6b7280;text-transform:uppercase}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:.25rem}.sidebar-nav-item{display:flex;align-items:center;padding:.75rem 1rem;color:#374151;text-decoration:none;transition:all .3s ease;font-size:1rem;position:relative;background:#fff}.sidebar-nav-item .sidebar-nav-icon{display:flex;align-items:center;justify-content:center;margin-right:.75rem;color:#9ca3af;transition:all .3s ease}.sidebar-nav-item-active{background:#111827;color:#fff;font-weight:600;border:1px solid #1f2937}.sidebar-nav-item-active .sidebar-nav-icon{color:#fff;transform:scale(1.1)}.sidebar-nav-item:hover{background:#111827;color:#fff;transform:translate(.25rem);box-shadow:0 4px 12px #00000026}.sidebar-nav-item:hover .sidebar-nav-icon{color:#fff;transform:scale(1.05)}.sidebar-nav-item .sidebar-nav-label{font-weight:500;font-size:1rem}.sidebar-footer{margin-top:auto;border-top:1px solid #e5e7eb;background:#fff}.user-profile{display:flex;align-items:center;gap:.75rem;padding:1rem .75rem;overflow:hidden}.user-profile .user-avatar{width:2.5rem;height:2.5rem;border-radius:.5rem;background:#f5f5f5;color:#333;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid #e0e0e0}.user-profile .user-info{flex:1;display:flex;flex-direction:column;min-width:0}.user-profile .user-info .user-name{font-size:.875rem;font-weight:600;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-profile .user-info .user-role{font-size:.75rem;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-profile .logout-icon-btn{color:#9ca3af;transition:all .2s ease;flex-shrink:0;padding:0}.user-profile .logout-icon-btn:hover{color:#dc2626;background:#fef2f2}.sidebar-collapsed{width:80px}.sidebar-collapsed .sidebar-header{justify-content:center;padding:1rem 0}.sidebar-collapsed .sidebar-logo-container{padding:0}.sidebar-collapsed .sidebar-nav{padding:0 .5rem}.sidebar-collapsed .sidebar-nav-item{justify-content:center;padding:.75rem 0}.sidebar-collapsed .sidebar-nav-item:hover{transform:none}.sidebar-collapsed .sidebar-nav-item .sidebar-nav-icon{margin-right:0}.sidebar-collapsed .user-profile{justify-content:center;padding:1rem 0}.custom-breadcrumbs-container{padding:.75rem 2rem;background-color:#fff;border-bottom:1px solid;width:100%}.custom-breadcrumbs-list{display:flex;align-items:center;list-style:none;padding:0;margin:0;flex-wrap:wrap;gap:.25rem}.custom-breadcrumb-current{color:#1f282e;font-weight:600;padding:.25rem .5rem;background-color:#f3f4f6;border-radius:.375rem}.custom-breadcrumb-link{display:flex;align-items:center;color:#6b7280;text-decoration:none;padding:.25rem .5rem;border-radius:.375rem;transition:all .15s ease-in-out}.custom-breadcrumb-link:hover{color:#1f282e;background-color:#f3f4f6;text-decoration:none}.custom-breadcrumb-item{display:flex;align-items:center;font-size:.875rem;font-weight:500;line-height:1}.custom-breadcrumb-item.custom-breadcrumb-back-button{cursor:pointer;color:#4d6573;padding:.25rem .5rem;border-radius:.375rem;transition:all .15s ease-in-out;margin-right:.25rem}.custom-breadcrumb-item.custom-breadcrumb-back-button:hover{background-color:#f3f4f6;color:#1f282e}.custom-breadcrumb-item.custom-breadcrumb-back-button:active{background-color:#e5e7eb}.custom-breadcrumb-item.custom-breadcrumb-active .custom-breadcrumb-current{background-color:#f5f5f5;color:#262626}.custom-breadcrumb-separator{color:#d1d5db;flex-shrink:0;margin:0}.main-layout{display:flex;height:100vh;width:100%;overflow:hidden;background-color:#f9fafb}.main-layout-container{flex:1;min-width:0;min-height:0;display:flex;flex-direction:column;height:100%;overflow:hidden;background-color:transparent;position:relative}.main-layout-content{flex:1;min-height:0;overflow:hidden auto;scrollbar-gutter:stable;position:relative;padding:0 2rem 2rem;display:flex;flex-direction:column;background-color:transparent}.main-layout-content .page-wrapper{position:relative;z-index:1;width:100%;min-height:100%}.custom-bits-watermark{position:fixed;inset:0;pointer-events:none;z-index:0;display:flex;align-items:center;justify-content:center;overflow:hidden;opacity:.05}.custom-bits-watermark-image{width:min(85vw,650px);height:auto;object-fit:contain;-webkit-user-select:none;user-select:none}.geometric-background{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0;display:block;background:transparent}.auth-layout{display:flex;min-height:100vh;width:100%;position:relative;overflow:hidden}.auth-layout .geometric-background,.auth-layout .geometric-bg{position:absolute;inset:0;z-index:5;width:100%;height:100%;pointer-events:none;opacity:.6}.auth-layout-sidebar{display:none;width:50%;background-color:#1a1a1a;padding:3rem;color:#fff;flex-direction:column;position:relative;z-index:2;overflow:hidden}@media(min-width:1024px){.auth-layout-sidebar{display:flex}}.auth-layout-content{flex:1;background-color:#f2f4f5;display:flex;flex-direction:column;padding:1.5rem;position:relative;z-index:2}@media(min-width:1024px){.auth-layout-content{padding:3rem}}.auth-layout-page-content{flex:1;display:flex;align-items:center;justify-content:center;width:100%}.auth-layout-footer{width:100%;margin-top:auto;padding-top:2rem;display:flex;justify-content:center;align-items:center;gap:.75rem;font-size:.875rem;color:#9ca3af}.auth-layout-footer .footer-link{display:flex;align-items:center;color:inherit;text-decoration:none;transition:color .2s}.auth-layout-footer .footer-link:hover{color:#333}.auth-layout-footer .footer-link svg{color:#9ca3af}.auth-layout-footer .separator{width:4px;height:4px;background-color:#d1d5db;border-radius:9999px;margin:0 .25rem}.branding-sidebar{display:flex;flex-direction:column;height:100%;position:relative;z-index:3;justify-content:space-between}.branding-sidebar-logo-container{display:flex;align-items:center;gap:1rem}.branding-sidebar-header{margin-bottom:3rem}.branding-sidebar-header-text{display:flex;flex-direction:column}.branding-sidebar-header-text .university-name{font-family:Cormorant Garamond,serif;font-size:2.25rem;color:#e5e7eb;line-height:1.2}.branding-sidebar-header-text .programme-name{font-size:.65rem;font-weight:500;color:#9ca3af;text-transform:uppercase;letter-spacing:.2em;margin-top:.5rem}.branding-sidebar-logo{width:80px;height:80px;object-fit:contain}.branding-sidebar-main-content{display:flex;flex-direction:column;gap:2rem}.branding-sidebar-title{font-family:Cormorant Garamond,serif;font-size:3rem;font-weight:400;line-height:1.2;color:#fff}.branding-sidebar-title .title-accent{color:#d1d5db}.branding-sidebar-description{font-size:1rem;color:#9ca3af;line-height:1.75;max-width:448px}.branding-sidebar-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;max-width:448px}.branding-sidebar-card{background:#0d0d0d;border:1px solid #1f2937;border-radius:.125rem;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;flex-direction:column;gap:.5rem}.branding-sidebar-card .icon-box{width:40px;height:40px;color:#9ca3af;margin-bottom:.25rem}.branding-sidebar-card .icon-box .lab-card-icon{width:100%;height:100%}.branding-sidebar-card .card-title{font-size:.875rem;color:#fff}.branding-sidebar-card .card-desc{font-size:.75rem;color:#6b7280;margin-top:.25rem}.branding-sidebar-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;max-width:448px;margin-top:1rem}.branding-sidebar-stats .stat-item{text-align:center;padding:1rem;border:1px solid #1f2937;border-radius:.125rem}.branding-sidebar-stats .stat-item .stat-value{font-family:Cormorant Garamond,serif;font-size:1.5rem;color:#d1d5db}.branding-sidebar-stats .stat-item .stat-label{font-size:.65rem;color:#6b7280;text-transform:uppercase;letter-spacing:.1em;margin-top:.25rem}.branding-sidebar-footer{font-size:.75rem;margin-top:2rem;color:#4b5563}
