@import url(https://fonts.googleapis.com/css2?family=Lato:wght@300;400;700&display=swap);
:root{--color-primary: #262B64;--color-accent: #63BEFF;--color-secondary-blue: #3A82FF;--color-deep-blue: #1c1e35;--color-white: #ffffff;--color-background: #f9f9f9;--color-surface: #ffffff;--color-border: #C7C7C7;--color-text-primary: #333333;--color-text-secondary: #878787;--color-text-muted: #C7C7C7;--color-text-inverse: #ffffff;--color-success: #00A308;--color-error: #E6463B;--color-warning: #f1d10d;--color-info: #3A82FF;--color-focus: #007bff;--color-disabled-bg: #f5f5f5;--color-disabled-text: #878787;--color-backdrop: rgba(0, 0, 0, 0.5)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes slideDown{from{opacity:0;transform:translateY(-1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{from{opacity:0;transform:translateX(-1rem)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{from{opacity:0;transform:translateX(1rem)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0.9)}}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-0.5rem)}}@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}.toast-container{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%);z-index:700;display:flex;flex-direction:column;align-items:center;gap:.5rem;pointer-events:none;max-width:420px;width:calc(100vw - 1.5rem*2)}.toast{display:flex;align-items:flex-start;gap:.5rem;padding:1rem;background-color:#fff;border-radius:5px;box-shadow:0px 4px 10px 0px rgba(0,0,0,.5);border-left:4px solid #c7c7c7;pointer-events:all;animation:slideUp .3s ease-in-out ease-out forwards}.toast--success{border-left-color:#00a308}.toast--error{border-left-color:#e6463b}.toast--warning{border-left-color:#f1d10d}.toast--info{border-left-color:#3a82ff}.toast__icon{flex-shrink:0;font-size:1rem;font-weight:700;line-height:1.5}.toast--success .toast__icon{color:#00a308}.toast--error .toast__icon{color:#e6463b}.toast--warning .toast__icon{color:rgb(120.0255905512,104.0885826772,6.4744094488)}.toast--info .toast__icon{color:#3a82ff}.toast__message{flex:1;font-size:.875rem;line-height:1.5;color:#333;word-break:break-word}.toast__close{flex-shrink:0;background:none;border:none;padding:0;margin-left:.25rem;font-size:1.25rem;line-height:1;color:#878787;cursor:pointer;transition:color .15s ease-in-out;align-self:center}.toast__close:hover{color:#333}@media(max-width: 576px){.toast-container{left:50%;transform:translateX(-50%);bottom:.5rem;max-width:none;width:calc(100vw - 0.5rem*2)}}
:root{--color-primary: #262B64;--color-accent: #63BEFF;--color-secondary-blue: #3A82FF;--color-deep-blue: #1c1e35;--color-white: #ffffff;--color-background: #f9f9f9;--color-surface: #ffffff;--color-border: #C7C7C7;--color-text-primary: #333333;--color-text-secondary: #878787;--color-text-muted: #C7C7C7;--color-text-inverse: #ffffff;--color-success: #00A308;--color-error: #E6463B;--color-warning: #f1d10d;--color-info: #3A82FF;--color-focus: #007bff;--color-disabled-bg: #f5f5f5;--color-disabled-text: #878787;--color-backdrop: rgba(0, 0, 0, 0.5)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes slideDown{from{opacity:0;transform:translateY(-1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{from{opacity:0;transform:translateX(-1rem)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{from{opacity:0;transform:translateX(1rem)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0.9)}}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-0.5rem)}}@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}.side-nav{--side-nav-width: 260px;display:flex;flex-direction:column;width:var(--side-nav-width);min-height:100vh;position:sticky;top:0;overflow:hidden;background:linear-gradient(180deg, #191A22 0%, #1B1E38 100%);color:var(--color-text-inverse)}.side-nav__header{display:flex;align-items:center;padding:1.5rem 1rem;border-bottom:1px solid hsla(0,0%,100%,.1);min-height:64px}.side-nav__brand{display:flex;align-items:center;gap:.5rem;color:var(--color-white);text-decoration:none;font-size:1.25rem;font-weight:700;transition:color .15s ease-in-out}.side-nav__brand:hover{color:var(--color-accent)}.side-nav__brand:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px;border-radius:5px}.side-nav__brand-icon{width:24px;height:24px;flex-shrink:0;color:#63beff}.side-nav__brand-text{white-space:nowrap}.side-nav__menu{display:flex;flex-direction:column;padding:1rem 0;flex:1;overflow-y:auto}.side-nav__menu::-webkit-scrollbar{width:6px;height:6px}.side-nav__menu::-webkit-scrollbar-track{background:rgba(0,0,0,0)}.side-nav__menu::-webkit-scrollbar-thumb{background:hsla(0,0%,100%,.2);border-radius:6px}.side-nav__menu::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}.side-nav__link{min-height:44px;min-width:44px;display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;color:hsla(0,0%,100%,.75);text-decoration:none;white-space:nowrap;border-left:3px solid rgba(0,0,0,0);font-size:.875rem;transition:all .3s ease-in-out;position:relative}.side-nav__link:hover{color:var(--color-white);background:rgba(99,190,255,.1);border-left-color:rgba(99,190,255,.5)}.side-nav__link:focus-visible{outline:2px solid var(--color-accent);outline-offset:-2px}.side-nav__link--active{background:linear-gradient(90deg, rgba(99, 190, 255, 0.2) 0%, rgba(99, 190, 255, 0.05) 100%);border-left-color:var(--color-accent);color:var(--color-white);font-weight:500}.side-nav__link-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;flex-shrink:0}.side-nav__link-icon svg{width:18px;height:18px}.side-nav__link-text{line-height:1.25}.side-nav__footer{padding:1.5rem;border-top:1px solid hsla(0,0%,100%,.1);margin-top:auto}.side-nav__user{display:flex;flex-direction:column;gap:.5rem}.side-nav__username{font-size:.875rem;color:hsla(0,0%,100%,.6);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.side-nav__logout{background:none;border:none;padding:0;margin:0;font:inherit;color:inherit;cursor:pointer;min-height:44px;min-width:44px;padding:.5rem 1rem;border:1px solid hsla(0,0%,100%,.2);border-radius:.75rem;color:var(--color-text-inverse);font-size:.875rem;font-weight:500;text-align:center;white-space:nowrap;transition:all .15s ease-in-out}.side-nav__logout:hover{background-color:hsla(0,0%,100%,.1);border-color:hsla(0,0%,100%,.4)}.side-nav__logout:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px;border-radius:5px}
.inactivity-warning-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.75);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease-in-out;backdrop-filter:blur(4px)}.inactivity-warning-modal{background:#fff;border-radius:12px;padding:2rem;max-width:480px;width:90%;box-shadow:0 20px 60px rgba(0,0,0,.3);animation:slideUp .3s ease-out;text-align:center}.inactivity-warning-icon{font-size:3rem;margin-bottom:1rem;animation:pulse 2s ease-in-out infinite}.inactivity-warning-title{font-size:1.5rem;font-weight:600;color:#d97706;margin:0 0 1rem 0}.inactivity-warning-message{font-size:1rem;line-height:1.6;color:#374151;margin:0 0 1.5rem 0}.inactivity-warning-message strong{color:#dc2626;font-weight:700;font-size:1.1em}.inactivity-warning-actions{display:flex;gap:1rem;justify-content:center;margin-bottom:1rem}.inactivity-warning-note{font-size:.875rem;color:#6b7280;margin:0;font-style:italic}.btn{padding:.75rem 2rem;font-size:1rem;font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:all .2s ease;font-family:inherit}.btn:focus{outline:3px solid #3b82f6;outline-offset:2px}.btn:active{transform:scale(0.98)}.btn-primary{background:#2563eb;color:#fff}.btn-primary:hover{background:#1d4ed8;box-shadow:0 4px 12px rgba(37,99,235,.3)}.btn-primary:focus{outline-color:#3b82f6}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}@media(max-width: 640px){.inactivity-warning-modal{padding:1.5rem;width:95%}.inactivity-warning-title{font-size:1.25rem}.inactivity-warning-message{font-size:.9375rem}.btn{width:100%}}@media(prefers-contrast: high){.inactivity-warning-modal{border:2px solid #000}.btn-primary{border:2px solid #000}}@media(prefers-reduced-motion: reduce){.inactivity-warning-overlay,.inactivity-warning-modal,.inactivity-warning-icon{animation:none}.btn{transition:none}}
:root{--color-primary: #262B64;--color-accent: #63BEFF;--color-secondary-blue: #3A82FF;--color-deep-blue: #1c1e35;--color-white: #ffffff;--color-background: #f9f9f9;--color-surface: #ffffff;--color-border: #C7C7C7;--color-text-primary: #333333;--color-text-secondary: #878787;--color-text-muted: #C7C7C7;--color-text-inverse: #ffffff;--color-success: #00A308;--color-error: #E6463B;--color-warning: #f1d10d;--color-info: #3A82FF;--color-focus: #007bff;--color-disabled-bg: #f5f5f5;--color-disabled-text: #878787;--color-backdrop: rgba(0, 0, 0, 0.5)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes slideDown{from{opacity:0;transform:translateY(-1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{from{opacity:0;transform:translateX(-1rem)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{from{opacity:0;transform:translateX(1rem)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0.9)}}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-0.5rem)}}@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(180deg, #2533cc 0%, #262B64 33%, #262B64 66%, #262B64 100%);padding:1rem}.login-container{background:var(--color-surface);padding:3rem;border-radius:1.5rem;box-shadow:0px 4px 10px 0px rgba(0,0,0,.5);width:100%;max-width:400px}@media(max-width: 374px){.login-container{padding:2rem;max-width:100%}}.login-title{margin:0 0 .5rem 0;font-size:2.25rem;font-weight:700;line-height:1.1;color:var(--color-primary);text-align:center}@media(max-width: 374px){.login-title{font-size:1.5rem}}.login-subtitle{margin:0 0 2rem 0;text-align:center;color:var(--color-text-secondary);font-size:.875rem;line-height:1.5}.login-form .form-group{margin-bottom:1.5rem}.login-form .form-label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.875rem;color:var(--color-text-primary)}.login-form .form-input{width:100%;padding:1rem;border:1px solid var(--color-border);border-radius:.75rem;font-size:1rem;font-family:"Lato",-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;color:var(--color-text-primary);background-color:var(--color-surface);transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out;min-height:44px;min-width:44px}.login-form .form-input:focus{outline:none;border-color:var(--color-secondary-blue);box-shadow:0 0 0 3px rgba(58,130,255,.1)}.login-form .form-input:disabled{background-color:var(--color-disabled-bg);color:var(--color-disabled-text);cursor:not-allowed}.login-form .form-input::-moz-placeholder{color:var(--color-text-muted)}.login-form .form-input::placeholder{color:var(--color-text-muted)}.login-error{padding:1rem;margin-bottom:1.5rem;background-color:rgba(230,70,59,.1);border:1px solid rgba(230,70,59,.3);border-radius:.75rem;color:var(--color-error);font-size:.875rem;line-height:1.5}.login-button{width:100%;padding:1rem 1.5rem;background-color:var(--color-secondary-blue);color:var(--color-text-inverse);border:none;border-radius:.75rem;font-size:1rem;font-weight:500;font-family:"Lato",-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;cursor:pointer;transition:background-color .3s ease-in-out,transform .15s ease-in-out,box-shadow .15s ease-in-out;min-height:44px;min-width:44px}.login-button:hover:not(:disabled){background-color:rgb(17.2,104.1116751269,255);transform:translateY(-2px);box-shadow:0px 2px 6px 0px rgba(0,0,0,.25)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:focus{outline:none;box-shadow:0 0 0 3px rgba(58,130,255,.3)}.login-button:disabled{background-color:var(--color-disabled-bg);color:var(--color-disabled-text);cursor:not-allowed;transform:none;box-shadow:none}.login-button.loading{position:relative;color:rgba(0,0,0,0);pointer-events:none}.login-button.loading::after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%, -50%);width:1rem;height:1rem;border:2px solid currentColor;border-radius:50%;border-top-color:rgba(0,0,0,0);animation:spin .6s linear infinite}
:root{--color-primary: #262B64;--color-accent: #63BEFF;--color-secondary-blue: #3A82FF;--color-deep-blue: #1c1e35;--color-white: #ffffff;--color-background: #f9f9f9;--color-surface: #ffffff;--color-border: #C7C7C7;--color-text-primary: #333333;--color-text-secondary: #878787;--color-text-muted: #C7C7C7;--color-text-inverse: #ffffff;--color-success: #00A308;--color-error: #E6463B;--color-warning: #f1d10d;--color-info: #3A82FF;--color-focus: #007bff;--color-disabled-bg: #f5f5f5;--color-disabled-text: #878787;--color-backdrop: rgba(0, 0, 0, 0.5)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes slideDown{from{opacity:0;transform:translateY(-1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{from{opacity:0;transform:translateX(-1rem)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{from{opacity:0;transform:translateX(1rem)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0.9)}}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-0.5rem)}}@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}.unauthorized-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(180deg, #2533cc 0%, #262B64 33%, #262B64 66%, #262B64 100%);padding:1rem}.unauthorized-container{background:var(--color-surface);padding:4rem 3rem;border-radius:1.5rem;box-shadow:0px 4px 10px 0px rgba(0,0,0,.5);width:100%;max-width:500px;text-align:center}@media(max-width: 374px){.unauthorized-container{padding:2rem;max-width:100%}}.unauthorized-code{margin:0 0 1rem 0;font-size:5rem;font-weight:700;line-height:1.1;color:var(--color-error)}@media(max-width: 374px){.unauthorized-code{font-size:4rem}}.unauthorized-title{margin:0 0 1rem 0;font-size:1.5rem;font-weight:700;line-height:1.25;color:var(--color-text-primary)}@media(max-width: 374px){.unauthorized-title{font-size:1.25rem}}.unauthorized-message{margin:0 0 3rem 0;color:var(--color-text-secondary);font-size:1rem;line-height:1.5}.unauthorized-actions{display:flex;flex-direction:row;align-items:center;gap:1rem;justify-content:center;flex-wrap:wrap}.unauthorized-button{display:inline-block;padding:1rem 2rem;background-color:var(--color-secondary-blue);color:var(--color-text-inverse);border:none;border-radius:.75rem;font-size:1rem;font-weight:500;font-family:"Lato",-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;text-decoration:none;cursor:pointer;transition:background-color .3s ease-in-out,transform .15s ease-in-out,box-shadow .15s ease-in-out;min-height:44px;min-width:44px}.unauthorized-button:hover{background-color:rgb(17.2,104.1116751269,255);transform:translateY(-2px);box-shadow:0px 2px 6px 0px rgba(0,0,0,.25)}.unauthorized-button:active{transform:translateY(0)}.unauthorized-button:focus{outline:none;box-shadow:0 0 0 3px rgba(58,130,255,.3)}.unauthorized-button--secondary{background-color:rgba(0,0,0,0);color:var(--color-secondary-blue);border:2px solid var(--color-secondary-blue)}.unauthorized-button--secondary:hover{background-color:rgba(58,130,255,.1);transform:translateY(-2px)}.unauthorized-button--secondary:focus{box-shadow:0 0 0 3px rgba(58,130,255,.2)}
:root{--color-primary: #262B64;--color-accent: #63BEFF;--color-secondary-blue: #3A82FF;--color-deep-blue: #1c1e35;--color-white: #ffffff;--color-background: #f9f9f9;--color-surface: #ffffff;--color-border: #C7C7C7;--color-text-primary: #333333;--color-text-secondary: #878787;--color-text-muted: #C7C7C7;--color-text-inverse: #ffffff;--color-success: #00A308;--color-error: #E6463B;--color-warning: #f1d10d;--color-info: #3A82FF;--color-focus: #007bff;--color-disabled-bg: #f5f5f5;--color-disabled-text: #878787;--color-backdrop: rgba(0, 0, 0, 0.5)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes slideDown{from{opacity:0;transform:translateY(-1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{from{opacity:0;transform:translateX(-1rem)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{from{opacity:0;transform:translateX(1rem)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0.9)}}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-0.5rem)}}@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}.not-found-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(180deg, #2533cc 0%, #262B64 33%, #262B64 66%, #262B64 100%);padding:1rem}.not-found-container{background:var(--color-surface);padding:4rem 3rem;border-radius:1.5rem;box-shadow:0px 4px 10px 0px rgba(0,0,0,.5);width:100%;max-width:500px;text-align:center}@media(max-width: 374px){.not-found-container{padding:2rem;max-width:100%}}.not-found-code{margin:0 0 1rem 0;font-size:5rem;font-weight:700;line-height:1.1;color:var(--color-primary)}@media(max-width: 374px){.not-found-code{font-size:4rem}}.not-found-title{margin:0 0 1rem 0;font-size:1.5rem;font-weight:700;line-height:1.25;color:var(--color-text-primary)}@media(max-width: 374px){.not-found-title{font-size:1.25rem}}.not-found-message{margin:0 0 3rem 0;color:var(--color-text-secondary);font-size:1rem;line-height:1.5}.not-found-button{display:inline-block;padding:1rem 2rem;background-color:var(--color-secondary-blue);color:var(--color-text-inverse);border:none;border-radius:.75rem;font-size:1rem;font-weight:500;font-family:"Lato",-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;text-decoration:none;cursor:pointer;transition:background-color .3s ease-in-out,transform .15s ease-in-out,box-shadow .15s ease-in-out;min-height:44px;min-width:44px}.not-found-button:hover{background-color:rgb(17.2,104.1116751269,255);transform:translateY(-2px);box-shadow:0px 2px 6px 0px rgba(0,0,0,.25)}.not-found-button:active{transform:translateY(0)}.not-found-button:focus{outline:none;box-shadow:0 0 0 3px rgba(58,130,255,.3)}
:root{--color-primary: #262B64;--color-accent: #63BEFF;--color-secondary-blue: #3A82FF;--color-deep-blue: #1c1e35;--color-white: #ffffff;--color-background: #f9f9f9;--color-surface: #ffffff;--color-border: #C7C7C7;--color-text-primary: #333333;--color-text-secondary: #878787;--color-text-muted: #C7C7C7;--color-text-inverse: #ffffff;--color-success: #00A308;--color-error: #E6463B;--color-warning: #f1d10d;--color-info: #3A82FF;--color-focus: #007bff;--color-disabled-bg: #f5f5f5;--color-disabled-text: #878787;--color-backdrop: rgba(0, 0, 0, 0.5)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes slideDown{from{opacity:0;transform:translateY(-1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{from{opacity:0;transform:translateX(-1rem)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{from{opacity:0;transform:translateX(1rem)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0.9)}}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-0.5rem)}}@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}.select-container,.select-wrapper{display:flex;flex-direction:column;gap:.25rem}.select-container--full-width,.select-container--fullWidth,.select-wrapper--full-width,.select-wrapper--fullWidth{width:100%}.select{border-radius:.75rem;transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out;padding:.75rem 2.5rem .75rem 1rem;font-family:"Lato",-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;font-size:.875rem;line-height:1.25;font-weight:400;color:var(--color-text-primary);background:var(--color-white);border:2px solid var(--color-border);min-height:44px;width:100%;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 width=%2712%27 height=%278%27 viewBox=%270 0 12 8%27%3E%3Cpath fill=%27%23333%27 d=%27M6 8L0 2 1.4 0.6 6 5.2 10.6 0.6 12 2z%27/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;background-size:12px 8px}.select:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px rgba(99,190,255,.1)}.select:hover:not(:disabled):not(.select--disabled){border-color:var(--color-text-secondary)}.select--error{border-color:var(--color-error)}.select--error:focus{border-color:var(--color-error);box-shadow:0 0 0 3px rgba(230,70,59,.1)}.select:disabled,.select--disabled{background:var(--color-disabled-bg);color:var(--color-disabled-text);cursor:not-allowed;border-color:var(--color-border);opacity:.6}.select option{color:var(--color-text-primary);background:var(--color-white);padding:.5rem}.select option:disabled{color:var(--color-disabled-text)}.select option:checked{background:var(--color-accent);color:var(--color-text-inverse)}.select__label{font-size:.875rem;font-weight:500;line-height:1.25;color:var(--color-text-primary);display:flex;align-items:center;gap:.25rem}.select__label--required::after{content:" *";color:var(--color-error);font-weight:700}.select__helper{font-size:.75rem;font-weight:400;line-height:1.5;color:var(--color-text-secondary);color:var(--color-text-secondary)}.select__error{font-size:.75rem;font-weight:400;line-height:1.5;color:var(--color-text-secondary);color:var(--color-error);font-weight:500;display:flex;align-items:center;gap:.25rem}.select__error::before{content:"⚠";font-size:1rem}select.select[multiple]{padding:.5rem;min-height:120px;background-image:none}select.select[multiple] option{padding:.5rem;border-radius:5px;margin-bottom:2px}select.select[multiple] option:checked{background:var(--color-accent);color:var(--color-text-inverse)}@media(max-width: 575px){.select{font-size:1rem}}
:root{--color-primary: #262B64;--color-accent: #63BEFF;--color-secondary-blue: #3A82FF;--color-deep-blue: #1c1e35;--color-white: #ffffff;--color-background: #f9f9f9;--color-surface: #ffffff;--color-border: #C7C7C7;--color-text-primary: #333333;--color-text-secondary: #878787;--color-text-muted: #C7C7C7;--color-text-inverse: #ffffff;--color-success: #00A308;--color-error: #E6463B;--color-warning: #f1d10d;--color-info: #3A82FF;--color-focus: #007bff;--color-disabled-bg: #f5f5f5;--color-disabled-text: #878787;--color-backdrop: rgba(0, 0, 0, 0.5)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes slideDown{from{opacity:0;transform:translateY(-1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{from{opacity:0;transform:translateX(-1rem)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{from{opacity:0;transform:translateX(1rem)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0.9)}}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-0.5rem)}}@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}.button{min-height:44px;min-width:44px;border-radius:.75rem;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 2.5rem;font-family:"Lato",-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;font-size:1rem;font-weight:700;line-height:1.25;text-decoration:none;text-align:center;white-space:nowrap;border:none;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:all .3s ease-in-out}.button:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px;border-radius:5px}.button:disabled,.button--disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.button--primary{background:linear-gradient(180deg, #2533cc 0%, var(--color-primary) 100%);background-size:100% 300%;background-position:0% 33%;color:var(--color-text-inverse);border:2px solid rgba(0,0,0,0)}.button--primary:hover:not(:disabled):not(.button--disabled):not(.button--loading){background-position:0% 0%;transform:translateY(-1px);box-shadow:0px 6px 16px 0px rgba(0,0,0,.35)}.button--primary:active:not(:disabled):not(.button--disabled):not(.button--loading){transform:translateY(0);box-shadow:0px 2px 6px 0px rgba(0,0,0,.25)}.button--secondary{background:var(--color-white);color:var(--color-primary);border:2px solid var(--color-primary)}.button--secondary:hover:not(:disabled):not(.button--disabled):not(.button--loading){background:var(--color-primary);color:var(--color-text-inverse);transform:translateY(-1px);box-shadow:0px 2px 6px 0px rgba(0,0,0,.25)}.button--secondary:active:not(:disabled):not(.button--disabled):not(.button--loading){transform:translateY(0)}.button--danger{background:var(--color-error);color:var(--color-text-inverse);border:2px solid rgba(0,0,0,0)}.button--danger:hover:not(:disabled):not(.button--disabled):not(.button--loading){background:rgb(211.0769230769,38.7692307692,26.9230769231);transform:translateY(-1px);box-shadow:0px 6px 16px 0px rgba(0,0,0,.35)}.button--danger:active:not(:disabled):not(.button--disabled):not(.button--loading){transform:translateY(0);box-shadow:0px 2px 6px 0px rgba(0,0,0,.25)}.button--ghost{background:rgba(0,0,0,0);color:var(--color-primary);border:2px solid rgba(0,0,0,0)}.button--ghost:hover:not(:disabled):not(.button--disabled):not(.button--loading){background:rgba(38,43,100,.1);color:var(--color-primary)}.button--ghost:active:not(:disabled):not(.button--disabled):not(.button--loading){background:rgba(38,43,100,.15)}.button--small{padding:.375rem 1rem;font-size:.875rem;min-height:44px}.button--large{padding:.875rem 3rem;font-size:1rem;min-height:52px}.button--full-width,.button--fullWidth{width:100%}.button--loading{position:relative;pointer-events:none}.button__spinner{position:absolute;top:50%;left:50%;transform:translate(-50%, -50%);display:flex;align-items:center;justify-content:center}.button__content{display:inline-flex;align-items:center;gap:.5rem}.button__content--hidden{visibility:hidden;opacity:0}.spinner{width:1.25rem;height:1.25rem;animation:spin .6s linear infinite}.spinner__path{stroke:currentColor;stroke-linecap:round;stroke-dasharray:90,150;stroke-dashoffset:0;animation:spinnerPath 1.5s ease-in-out infinite}@keyframes spinnerPath{0%{stroke-dasharray:1,150;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-35}100%{stroke-dasharray:90,150;stroke-dashoffset:-124}}@media(max-width: 575px){.button{padding:.75rem 1.5rem}.button--small{padding:.5rem 1rem}.button--large{padding:1rem 2rem}}
:root{--color-primary: #262B64;--color-accent: #63BEFF;--color-secondary-blue: #3A82FF;--color-deep-blue: #1c1e35;--color-white: #ffffff;--color-background: #f9f9f9;--color-surface: #ffffff;--color-border: #C7C7C7;--color-text-primary: #333333;--color-text-secondary: #878787;--color-text-muted: #C7C7C7;--color-text-inverse: #ffffff;--color-success: #00A308;--color-error: #E6463B;--color-warning: #f1d10d;--color-info: #3A82FF;--color-focus: #007bff;--color-disabled-bg: #f5f5f5;--color-disabled-text: #878787;--color-backdrop: rgba(0, 0, 0, 0.5)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes slideDown{from{opacity:0;transform:translateY(-1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{from{opacity:0;transform:translateX(-1rem)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{from{opacity:0;transform:translateX(1rem)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0.9)}}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-0.5rem)}}@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}.term-planning-grid__header{margin-bottom:2rem}.term-planning-grid__title{font-size:1.5rem;font-weight:700;line-height:1.25;color:var(--color-text-primary);margin:0;color:var(--color-primary);margin-bottom:.5rem}.term-planning-grid__description{font-size:.875rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);color:var(--color-text-secondary);margin:0}.term-planning-grid__terms{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.term-planning-grid__term-row{border-radius:1.5rem;box-shadow:0px 2px 6px 0px rgba(0,0,0,.25);padding:1.5rem;background:var(--color-surface);border:2px solid rgba(0,0,0,0);transition:all .3s ease-in-out}.term-planning-grid__term-row--dragging{opacity:.5;box-shadow:0px 4px 10px 0px rgba(0,0,0,.5);transform:rotate(2deg)}.term-planning-grid__term-row--drag-over{border-color:var(--color-accent);background:rgba(99,190,255,.05);box-shadow:0px 6px 16px 0px rgba(0,0,0,.35)}.term-planning-grid__term-row:hover{box-shadow:0px 4px 10px 0px rgba(0,0,0,.5)}.term-planning-grid__term-header{display:flex;align-items:center;gap:1rem;padding-bottom:1rem;margin-bottom:1rem;border-bottom:2px solid var(--color-border)}.term-planning-grid__drag-handle{background:none;border:none;padding:0;margin:0;font:inherit;color:inherit;cursor:pointer;min-height:44px;min-width:44px;border-radius:.75rem;display:flex;align-items:center;justify-content:center;padding:.5rem;border:2px solid var(--color-border);color:var(--color-text-secondary);font-size:1.25rem;cursor:grab;transition:all .15s ease-in-out}.term-planning-grid__drag-handle:hover:not(:disabled){background:var(--color-disabled-bg);border-color:var(--color-accent);color:var(--color-accent)}.term-planning-grid__drag-handle:active{cursor:grabbing;background:var(--color-accent);color:var(--color-text-inverse);border-color:var(--color-accent)}.term-planning-grid__drag-handle:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.term-planning-grid__drag-handle:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px;border-radius:5px}.term-planning-grid__term-info{display:flex;flex-direction:column;gap:.25rem;flex:1}.term-planning-grid__term-position{font-size:.75rem;font-weight:700;line-height:1.25;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:1px;font-size:.75rem;color:var(--color-text-secondary)}.term-planning-grid__term-name{font-size:1rem;font-weight:700;line-height:1.25;color:var(--color-text-primary);margin:0;color:var(--color-text-primary);margin:0}.term-planning-grid__remove-term{background:none;border:none;padding:0;margin:0;font:inherit;color:inherit;cursor:pointer;min-height:44px;min-width:44px;border-radius:.75rem;display:flex;align-items:center;justify-content:center;padding:.5rem;border:2px solid var(--color-error);color:var(--color-error);font-size:1.5rem;transition:all .15s ease-in-out}.term-planning-grid__remove-term:hover:not(:disabled){background:var(--color-error);color:var(--color-text-inverse);transform:scale(1.05)}.term-planning-grid__remove-term:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.term-planning-grid__remove-term:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px;border-radius:5px}.term-planning-grid__courses{margin-bottom:1rem}.term-planning-grid__no-courses{display:flex;align-items:center;justify-content:center;border-radius:.75rem;padding:2rem;margin:0;color:var(--color-text-muted);font-style:italic;background:var(--color-background);border:2px dashed var(--color-border);transition:all .15s ease-in-out}.term-planning-grid__no-courses--drag-over{border-color:var(--color-accent);background:rgba(99,190,255,.1);color:var(--color-accent)}.term-planning-grid__course-list{list-style:none;padding-left:0;margin:0;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.term-planning-grid__course-item{border-radius:.75rem;display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--color-white);border:2px solid var(--color-border);transition:all .15s ease-in-out}.term-planning-grid__course-item:hover{border-color:var(--color-accent);box-shadow:0px 2px 6px 0px rgba(0,0,0,.25);transform:translateX(4px)}.term-planning-grid__course-item--dragging{opacity:.5;box-shadow:0px 4px 10px 0px rgba(0,0,0,.5)}.term-planning-grid__course-item--drag-over{border-color:var(--color-success);background:rgba(0,163,8,.05)}.term-planning-grid__course-drag-handle{background:none;border:none;padding:0;margin:0;font:inherit;color:inherit;cursor:pointer;display:flex;align-items:center;justify-content:center;width:24px;height:24px;color:var(--color-text-secondary);cursor:grab;transition:color .15s ease-in-out}.term-planning-grid__course-drag-handle:hover{color:var(--color-accent)}.term-planning-grid__course-drag-handle:active{cursor:grabbing}@media(max-width: 767px){.term-planning-grid__course-drag-handle{width:32px;height:32px;font-size:1.25rem}}.term-planning-grid__course-code{font-family:source-code-pro,Menlo,Monaco,Consolas,"Courier New",monospace;font-size:.9em;background:var(--color-disabled-bg);padding:.125rem .375rem;border-radius:5px;color:var(--color-text-primary);border-radius:.75rem;font-weight:700;font-size:.875rem;padding:.25rem .5rem;background:#3a82ff;color:var(--color-text-inverse)}.term-planning-grid__course-item--loa .term-planning-grid__course-code{background:#ffd600;color:var(--color-text-inverse)}.term-planning-grid__course-item--elective .term-planning-grid__course-code{background:#ff9100;color:var(--color-text-inverse)}.term-planning-grid__course-item--inactive .term-planning-grid__course-code{background:#ff9100;color:var(--color-text-inverse)}.term-planning-grid__course-item--failed .term-planning-grid__course-code{background:#dd2c00;color:var(--color-text-inverse)}.term-planning-grid__course-name{font-size:.875rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);flex:1;color:var(--color-text-primary)}.term-planning-grid__course-credits{font-size:.75rem;font-weight:400;line-height:1.5;color:var(--color-text-secondary);color:var(--color-text-secondary);font-weight:700;padding:0 .25rem}.term-planning-grid__course-credits::after{content:" cr";font-weight:400}.term-planning-grid__toggle-failed{background:none;border:none;padding:0;margin:0;font:inherit;color:inherit;cursor:pointer;min-height:32px;min-width:32px;display:flex;align-items:center;justify-content:center;min-width:32px;padding:.25rem;background:rgba(0,0,0,0);color:var(--color-text-secondary);font-size:1.125rem;border:none;cursor:pointer;transition:all .15s ease-in-out}.term-planning-grid__toggle-failed:hover:not(:disabled){color:var(--color-accent);transform:scale(1.15)}.term-planning-grid__toggle-failed:disabled{opacity:.5;cursor:not-allowed}.term-planning-grid__toggle-failed:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px;border-radius:5px}.term-planning-grid__remove-course{background:none;border:none;padding:0;margin:0;font:inherit;color:inherit;cursor:pointer;min-height:32px;min-width:32px;border-radius:.75rem;display:flex;align-items:center;justify-content:center;min-width:32px;padding:.25rem;border:1px solid var(--color-error);color:var(--color-error);font-size:1.25rem;transition:all .15s ease-in-out}.term-planning-grid__remove-course:hover:not(:disabled){background:var(--color-error);color:var(--color-text-inverse)}.term-planning-grid__remove-course:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.term-planning-grid__remove-course:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px;border-radius:5px}.term-planning-grid__add-course{display:flex;align-items:flex-end;gap:1rem;padding:1rem;background:var(--color-background);border-radius:.75rem}.term-planning-grid__add-course>div{flex:1}@media(max-width: 767px){.term-planning-grid__add-course{flex-direction:column;align-items:stretch}.term-planning-grid__add-course>div{width:100%}.term-planning-grid__add-course .button{width:100%}}.term-planning-grid__add-term{border-radius:1.5rem;box-shadow:0px 2px 6px 0px rgba(0,0,0,.25);display:flex;align-items:flex-end;gap:1rem;padding:1.5rem;background:var(--color-surface);border:2px dashed var(--color-border)}.term-planning-grid__add-term>div{flex:1}@media(max-width: 767px){.term-planning-grid__add-term{flex-direction:column;align-items:stretch}.term-planning-grid__add-term>div{width:100%}.term-planning-grid__add-term .button{width:100%}}.term-planning-grid__empty{display:flex;align-items:center;justify-content:center;border-radius:1.5rem;flex-direction:column;gap:1rem;padding:4rem;text-align:center;background:var(--color-background);border:2px dashed var(--color-border)}.term-planning-grid__empty p{font-size:1rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);margin:0;color:var(--color-text-secondary)}.term-planning-grid__empty .button{margin-top:1rem}@media(max-width: 767px){.term-planning-grid__term-header{flex-wrap:wrap;gap:.5rem}.term-planning-grid__term-info{width:100%;order:2}.term-planning-grid__drag-handle{order:1}.term-planning-grid__remove-term{order:3;margin-left:auto}.term-planning-grid__course-item{flex-wrap:wrap;gap:.5rem}.term-planning-grid__course-code{order:1}.term-planning-grid__course-name{order:3;width:100%}.term-planning-grid__course-credits{order:2;margin-left:auto}.term-planning-grid__course-drag-handle{order:0}.term-planning-grid__remove-course{order:4}}@media(max-width: 575px){.term-planning-grid__term-row{padding:1rem}.term-planning-grid__course-item{padding:.5rem}.term-planning-grid__add-term,.term-planning-grid__add-course{padding:1rem}}.term-planning-grid--is-dragging .term-planning-grid__term-row{border-color:var(--color-border)}.term-planning-grid--is-dragging .term-planning-grid__term-row:not(.term-planning-grid__term-row--dragging){opacity:.7}.term-planning-grid--is-dragging .term-planning-grid__no-courses{border-style:solid;background:rgba(99,190,255,.05)}
:root{--color-primary: #262B64;--color-accent: #63BEFF;--color-secondary-blue: #3A82FF;--color-deep-blue: #1c1e35;--color-white: #ffffff;--color-background: #f9f9f9;--color-surface: #ffffff;--color-border: #C7C7C7;--color-text-primary: #333333;--color-text-secondary: #878787;--color-text-muted: #C7C7C7;--color-text-inverse: #ffffff;--color-success: #00A308;--color-error: #E6463B;--color-warning: #f1d10d;--color-info: #3A82FF;--color-focus: #007bff;--color-disabled-bg: #f5f5f5;--color-disabled-text: #878787;--color-backdrop: rgba(0, 0, 0, 0.5)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes slideDown{from{opacity:0;transform:translateY(-1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{from{opacity:0;transform:translateX(-1rem)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{from{opacity:0;transform:translateX(1rem)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0.9)}}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-0.5rem)}}@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}.validation-errors{background-color:rgba(230,70,59,.08);border:1px solid var(--color-error);border-radius:5px;padding:1rem;margin-bottom:1rem;animation:slideDown .3s ease-in-out}.validation-errors--warning{background-color:rgba(241,209,13,.1);border-color:var(--color-warning)}.validation-errors--warning .validation-errors__title{color:rgb(47.4409448819,41.1417322835,2.5590551181)}.validation-errors--warning .validation-errors__item{color:rgb(23.2460629921,20.1594488189,1.2539370079)}.validation-errors--warning .validation-errors__item:before{content:"⚠ "}.validation-errors--info{background-color:rgba(58,130,255,.08);border-color:var(--color-info)}.validation-errors--info .validation-errors__title{color:rgb(0,77.116751269,211)}.validation-errors--info .validation-errors__item{color:rgb(0,67.7969543147,185.5)}.validation-errors--info .validation-errors__item:before{content:"ⓘ "}.validation-errors__title{font-size:1rem;font-weight:700;margin:0 0 .5rem 0;color:rgb(211.0769230769,38.7692307692,26.9230769231);line-height:1.25;display:flex;align-items:center;gap:.25rem}.validation-errors__title:before{content:"⚠";font-size:1.2em}.validation-errors__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.25rem}.validation-errors__item{padding:.25rem 0;color:rgb(188.4615384615,34.6153846154,24.0384615385);font-size:.875rem;line-height:1.5;display:flex;align-items:flex-start;gap:.5rem}.validation-errors__item:before{content:"⚠";flex-shrink:0;font-size:1.1em;margin-top:.1em}
:root{--color-primary: #262B64;--color-accent: #63BEFF;--color-secondary-blue: #3A82FF;--color-deep-blue: #1c1e35;--color-white: #ffffff;--color-background: #f9f9f9;--color-surface: #ffffff;--color-border: #C7C7C7;--color-text-primary: #333333;--color-text-secondary: #878787;--color-text-muted: #C7C7C7;--color-text-inverse: #ffffff;--color-success: #00A308;--color-error: #E6463B;--color-warning: #f1d10d;--color-info: #3A82FF;--color-focus: #007bff;--color-disabled-bg: #f5f5f5;--color-disabled-text: #878787;--color-backdrop: rgba(0, 0, 0, 0.5)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes slideDown{from{opacity:0;transform:translateY(-1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{from{opacity:0;transform:translateX(-1rem)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{from{opacity:0;transform:translateX(1rem)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0.9)}}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-0.5rem)}}@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}.iframe-plan{font-family:"Lato",-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;min-height:100vh;background:var(--color-background);box-sizing:border-box}.iframe-plan *,.iframe-plan *::before,.iframe-plan *::after{box-sizing:inherit}.iframe-plan__loading{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:2rem}.iframe-plan__error-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:2rem 1rem}.iframe-plan__error-card{background:var(--color-surface);border-radius:1.5rem;box-shadow:0px 2px 6px 0px rgba(0,0,0,.25);padding:3rem 2rem;max-width:480px;width:100%;text-align:center;border-top:4px solid var(--color-error)}.iframe-plan__error-card--auth{border-top-color:var(--color-error)}.iframe-plan__error-card--param{border-top-color:var(--color-warning)}.iframe-plan__error-card--missing{border-top-color:var(--color-warning)}.iframe-plan__error-card--network{border-top-color:var(--color-info)}.iframe-plan__error-card--server{border-top-color:var(--color-error)}.iframe-plan__error-card--deleted{border-top-color:var(--color-success)}.iframe-plan__error-icon{font-size:2.5rem;line-height:1;display:block;margin-bottom:1.5rem}.iframe-plan__error-title{font-size:1.5rem;font-weight:700;line-height:1.25;color:var(--color-text-primary);margin:0;color:var(--color-primary);margin:0 0 1rem}.iframe-plan__error-body{font-size:.875rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);color:var(--color-text-secondary);line-height:1.5;margin:0 0 1.5rem}.iframe-plan__error-detail{font-size:.75rem;font-weight:400;line-height:1.5;color:var(--color-text-secondary);color:var(--color-text-secondary);font-family:source-code-pro,Menlo,Monaco,Consolas,"Courier New",monospace;background:var(--color-disabled-bg);border:1px solid var(--color-border);border-radius:.75rem;padding:.5rem 1rem;margin:0 0 1.5rem;text-align:left;word-break:break-word;white-space:pre-wrap}.iframe-plan__error-actions{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.iframe-plan__content{padding:1.5rem}.iframe-plan__content-header{margin-bottom:1rem}.iframe-plan__content-title{font-size:1.5rem;font-weight:700;line-height:1.25;color:var(--color-text-primary);margin:0;color:var(--color-primary);margin:0 0 1rem}.iframe-plan__meta{display:grid;grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));gap:1.5rem;padding:1.5rem;background:var(--color-background);border-radius:.75rem;margin-bottom:1rem}.iframe-plan__meta-label{display:flex;flex-direction:column;gap:.25rem}.iframe-plan__meta-key{font-size:.875rem;font-weight:500;line-height:1.25;color:var(--color-text-primary);color:var(--color-text-secondary);text-transform:uppercase;font-size:.75rem;letter-spacing:.5px}.iframe-plan__meta-value{font-size:1rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);color:var(--color-text-primary);font-weight:500}.iframe-plan__actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--color-border)}.iframe-plan__confirm-backdrop{position:fixed;inset:0;background:var(--color-backdrop);display:flex;align-items:center;justify-content:center;z-index:400;padding:1rem}.iframe-plan__confirm-dialog{background:var(--color-surface);border-radius:.75rem;box-shadow:0px 4px 10px 0px rgba(0,0,0,.5);padding:2rem;max-width:420px;width:100%}.iframe-plan__confirm-title{font-size:1.25rem;font-weight:700;line-height:1.25;color:var(--color-text-primary);margin:0;color:var(--color-primary);margin:0 0 1rem}.iframe-plan__confirm-body{font-size:.875rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);color:var(--color-text-secondary);line-height:1.5;margin:0 0 2rem}.iframe-plan__confirm-actions{display:flex;gap:.5rem;justify-content:flex-end}
:root{--color-primary: #262B64;--color-accent: #63BEFF;--color-secondary-blue: #3A82FF;--color-deep-blue: #1c1e35;--color-white: #ffffff;--color-background: #f9f9f9;--color-surface: #ffffff;--color-border: #C7C7C7;--color-text-primary: #333333;--color-text-secondary: #878787;--color-text-muted: #C7C7C7;--color-text-inverse: #ffffff;--color-success: #00A308;--color-error: #E6463B;--color-warning: #f1d10d;--color-info: #3A82FF;--color-focus: #007bff;--color-disabled-bg: #f5f5f5;--color-disabled-text: #878787;--color-backdrop: rgba(0, 0, 0, 0.5)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes slideDown{from{opacity:0;transform:translateY(-1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{from{opacity:0;transform:translateX(-1rem)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{from{opacity:0;transform:translateX(1rem)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0.9)}}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-0.5rem)}}@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}.home-page{min-height:100%;background-color:var(--color-background)}.home-hero{background:linear-gradient(135deg, #262B64 0%, #1c1e35 100%);padding:4rem 3rem;text-align:center;position:relative;overflow:hidden;color:#fff}.home-hero::before{content:"";position:absolute;top:-80px;right:-100px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle, rgba(99, 190, 255, 0.14) 0%, transparent 65%);pointer-events:none}.home-hero::after{content:"";position:absolute;bottom:-100px;left:-80px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle, rgba(58, 130, 255, 0.1) 0%, transparent 65%);pointer-events:none}.home-hero__inner{position:relative;z-index:1;max-width:560px;margin:0 auto}.home-hero__icon{width:60px;height:60px;display:block;margin:0 auto 1.5rem;color:#63beff;filter:drop-shadow(0 0 16px rgba(99, 190, 255, 0.5))}.home-hero__title{margin:0 0 1rem;font-size:2.25rem;font-weight:700;line-height:1.1;color:#fff;letter-spacing:-0.01em}@media(max-width: 767px){.home-hero__title{font-size:1.5rem}}.home-hero__subtitle{margin:0;font-size:1rem;color:hsla(0,0%,100%,.65);line-height:1.5;letter-spacing:.02em}@media(max-width: 767px){.home-hero__subtitle{font-size:.875rem}}.home-content{padding:3rem;max-width:1400px;margin:0 auto}@media(max-width: 767px){.home-content{padding:2rem 1rem}}.home-content__label{margin:0 0 1.5rem;font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-secondary)}.home-cards{display:grid;grid-template-columns:repeat(3, 1fr);gap:1.5rem}@media(max-width: 991px){.home-cards{grid-template-columns:repeat(2, 1fr)}}@media(max-width: 767px){.home-cards{grid-template-columns:1fr}}.home-card{display:flex;align-items:center;gap:1.5rem;padding:2rem;background:var(--color-surface);border-radius:.75rem;border:1px solid var(--color-border);text-decoration:none;color:inherit;transition:transform .15s ease-in-out,box-shadow .15s ease-in-out,border-color .15s ease-in-out;box-shadow:0px 2px 6px 0px rgba(0,0,0,.25)}.home-card:hover{transform:translateY(-3px);box-shadow:0px 6px 16px 0px rgba(0,0,0,.35);border-color:#3a82ff;text-decoration:none}.home-card:hover .home-card__arrow{transform:translateX(4px);color:#3a82ff}.home-card:hover .home-card__icon-wrap{background:linear-gradient(135deg, rgba(38, 43, 100, 0.12), rgba(58, 130, 255, 0.16))}.home-card:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px;border-radius:5px;text-decoration:none}.home-card__icon-wrap{flex-shrink:0;width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg, rgba(38, 43, 100, 0.08), rgba(58, 130, 255, 0.1));border-radius:5px;color:#262b64;transition:background .15s ease-in-out}.home-card__icon-wrap svg{width:26px;height:26px}.home-card__body{flex:1;min-width:0}.home-card__title{margin:0 0 .25rem;font-size:1rem;font-weight:700;color:var(--color-text-primary);line-height:1.25}.home-card__desc{margin:0;font-size:.875rem;color:var(--color-text-secondary);line-height:1.5}.home-card__arrow{flex-shrink:0;color:var(--color-text-muted);font-size:1rem;transition:transform .15s ease-in-out,color .15s ease-in-out}
:root{--color-primary: #262B64;--color-accent: #63BEFF;--color-secondary-blue: #3A82FF;--color-deep-blue: #1c1e35;--color-white: #ffffff;--color-background: #f9f9f9;--color-surface: #ffffff;--color-border: #C7C7C7;--color-text-primary: #333333;--color-text-secondary: #878787;--color-text-muted: #C7C7C7;--color-text-inverse: #ffffff;--color-success: #00A308;--color-error: #E6463B;--color-warning: #f1d10d;--color-info: #3A82FF;--color-focus: #007bff;--color-disabled-bg: #f5f5f5;--color-disabled-text: #878787;--color-backdrop: rgba(0, 0, 0, 0.5)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes slideDown{from{opacity:0;transform:translateY(-1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{from{opacity:0;transform:translateX(-1rem)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{from{opacity:0;transform:translateX(1rem)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0.9)}}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-0.5rem)}}@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}.input-container,.input-wrapper{display:flex;flex-direction:column;gap:.25rem}.input-container--full-width,.input-container--fullWidth,.input-wrapper--full-width,.input-wrapper--fullWidth{width:100%}.input{border-radius:.75rem;transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out;padding:.75rem 1rem;font-family:"Lato",-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;font-size:.875rem;line-height:1.25;font-weight:400;color:var(--color-text-primary);background:var(--color-white);border:2px solid var(--color-border);min-height:44px;width:100%}.input::-moz-placeholder{color:var(--color-text-muted)}.input::placeholder{color:var(--color-text-muted)}.input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px rgba(99,190,255,.1)}.input:hover:not(:disabled):not(.input--disabled){border-color:var(--color-text-secondary)}.input--error{border-color:var(--color-error)}.input--error:focus{border-color:var(--color-error);box-shadow:0 0 0 3px rgba(230,70,59,.1)}.input:disabled,.input--disabled{background:var(--color-disabled-bg);color:var(--color-disabled-text);cursor:not-allowed;border-color:var(--color-border)}.input:disabled::-moz-placeholder, .input--disabled::-moz-placeholder{color:var(--color-disabled-text)}.input:disabled::placeholder,.input--disabled::placeholder{color:var(--color-disabled-text)}.input:-moz-read-only{background:var(--color-disabled-bg);cursor:default}.input:read-only{background:var(--color-disabled-bg);cursor:default}.input__label{font-size:.875rem;font-weight:500;line-height:1.25;color:var(--color-text-primary);display:flex;align-items:center;gap:.25rem}.input__label--required::after{content:" *";color:var(--color-error);font-weight:700}.input__helper{font-size:.75rem;font-weight:400;line-height:1.5;color:var(--color-text-secondary);color:var(--color-text-secondary)}.input__error{font-size:.75rem;font-weight:400;line-height:1.5;color:var(--color-text-secondary);color:var(--color-error);font-weight:500;display:flex;align-items:center;gap:.25rem}.input__error::before{content:"⚠";font-size:1rem}textarea.input{min-height:120px;resize:vertical;padding:.75rem 1rem;line-height:1.5}input[type=number].input{-moz-appearance:textfield}input[type=number].input::-webkit-outer-spin-button,input[type=number].input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=search].input::-webkit-search-cancel-button,input[type=search].input::-webkit-search-decoration{-webkit-appearance:none}input[type=date].input::-webkit-calendar-picker-indicator,input[type=datetime-local].input::-webkit-calendar-picker-indicator,input[type=time].input::-webkit-calendar-picker-indicator{cursor:pointer;filter:invert(0.5)}input[type=date].input::-webkit-calendar-picker-indicator:hover,input[type=datetime-local].input::-webkit-calendar-picker-indicator:hover,input[type=time].input::-webkit-calendar-picker-indicator:hover{filter:invert(0.3)}input[type=file].input{padding:.5rem}input[type=file].input::file-selector-button{border-radius:5px;padding:.375rem 1rem;margin-right:1rem;font-family:"Lato",-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;font-size:.875rem;font-weight:500;background:var(--color-primary);color:var(--color-text-inverse);border:none;cursor:pointer;transition:background .15s ease-in-out}input[type=file].input::file-selector-button:hover{background:var(--color-secondary-blue)}@media(max-width: 575px){.input{font-size:1rem}}
:root{--color-primary: #262B64;--color-accent: #63BEFF;--color-secondary-blue: #3A82FF;--color-deep-blue: #1c1e35;--color-white: #ffffff;--color-background: #f9f9f9;--color-surface: #ffffff;--color-border: #C7C7C7;--color-text-primary: #333333;--color-text-secondary: #878787;--color-text-muted: #C7C7C7;--color-text-inverse: #ffffff;--color-success: #00A308;--color-error: #E6463B;--color-warning: #f1d10d;--color-info: #3A82FF;--color-focus: #007bff;--color-disabled-bg: #f5f5f5;--color-disabled-text: #878787;--color-backdrop: rgba(0, 0, 0, 0.5)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes slideDown{from{opacity:0;transform:translateY(-1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{from{opacity:0;transform:translateX(-1rem)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{from{opacity:0;transform:translateX(1rem)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0.9)}}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-0.5rem)}}@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}.dp-modal-backdrop{position:fixed;inset:0;z-index:400;display:flex;align-items:center;justify-content:center;background:var(--color-backdrop);backdrop-filter:blur(3px);padding:1.5rem;animation:dp-modal-backdrop-enter .15s ease-in-out}.dp-modal{width:100%;max-height:90vh;overflow:auto;border-radius:.75rem;background:var(--color-surface);box-shadow:0px 4px 10px 0px rgba(0,0,0,.5);border:1px solid var(--color-border);animation:dp-modal-enter .3s ease-in-out ease-out}.dp-modal:focus{outline:2px solid var(--color-focus);outline-offset:2px}.dp-modal--small{max-width:32ch}.dp-modal--medium{max-width:50ch}.dp-modal--large{max-width:72ch}.dp-modal__header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:1rem 1.5rem .5rem;border-bottom:1px solid var(--color-border)}.dp-modal__title{margin:0;font-size:1.25rem;font-weight:700;color:var(--color-text-primary);line-height:1.1}.dp-modal__close{border:0;background:rgba(0,0,0,0);font-size:1.35rem;line-height:1;cursor:pointer;color:var(--color-text-secondary);border-radius:5px;padding:.25rem .5rem;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;transition:background-color .15s ease-in-out,color .15s ease-in-out}.dp-modal__close:hover{background:var(--color-disabled-bg);color:var(--color-text-primary)}.dp-modal__close:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px}.dp-modal__content{padding:1rem 1.5rem;color:var(--color-text-primary);line-height:1.5}.dp-modal__footer{display:flex;justify-content:flex-end;align-items:center;flex-wrap:wrap;gap:.5rem;padding:.5rem 1.5rem 1rem;border-top:1px solid var(--color-border);background:var(--color-background)}@keyframes dp-modal-backdrop-enter{from{opacity:0}to{opacity:1}}@keyframes dp-modal-enter{from{opacity:0;transform:translateY(6px) scale(0.98)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width: 576px){.dp-modal-backdrop{padding:1rem}.dp-modal{max-width:90vw;max-height:95vh;border-radius:5px}.dp-modal__header,.dp-modal__content,.dp-modal__footer{padding-left:1rem;padding-right:1rem}.dp-modal__footer{flex-direction:column-reverse;align-items:stretch}.dp-modal__footer button{width:100%}}
:root{--color-primary: #262B64;--color-accent: #63BEFF;--color-secondary-blue: #3A82FF;--color-deep-blue: #1c1e35;--color-white: #ffffff;--color-background: #f9f9f9;--color-surface: #ffffff;--color-border: #C7C7C7;--color-text-primary: #333333;--color-text-secondary: #878787;--color-text-muted: #C7C7C7;--color-text-inverse: #ffffff;--color-success: #00A308;--color-error: #E6463B;--color-warning: #f1d10d;--color-info: #3A82FF;--color-focus: #007bff;--color-disabled-bg: #f5f5f5;--color-disabled-text: #878787;--color-backdrop: rgba(0, 0, 0, 0.5)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes slideDown{from{opacity:0;transform:translateY(-1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{from{opacity:0;transform:translateX(-1rem)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{from{opacity:0;transform:translateX(1rem)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0.9)}}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-0.5rem)}}@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}.card{border-radius:1.5rem;transition:transform .3s ease-in-out;background:var(--color-surface);display:flex;flex-direction:column;overflow:hidden}.card--outlined{border:1px solid var(--color-border)}.card--elevated{box-shadow:0px 2px 6px 0px rgba(0,0,0,.25)}.card--elevated:hover{box-shadow:0px 4px 10px 0px rgba(0,0,0,.5);transform:translateY(-2px)}.card__header{padding:1.5rem;border-bottom:1px solid var(--color-border);background:var(--color-background)}.card__header h1,.card__header h2,.card__header h3,.card__header h4,.card__header h5,.card__header h6{margin:0}.card__content{padding:1.5rem;flex:1}.card__footer{padding:1.5rem;border-top:1px solid var(--color-border);background:var(--color-background);display:flex;align-items:center;justify-content:flex-end;gap:1rem}.card--clickable{cursor:pointer;transition:all .3s ease-in-out}.card--clickable:hover{box-shadow:0px 4px 10px 0px rgba(0,0,0,.5);transform:translateY(-4px)}.card--clickable:active{transform:translateY(-1px);box-shadow:0px 2px 6px 0px rgba(0,0,0,.25)}.card--compact .card__header,.card--compact .card__content,.card--compact .card__footer{padding:1rem}.card--spacious .card__header,.card--spacious .card__content,.card--spacious .card__footer{padding:2rem}@media(max-width: 767px){.card{border-radius:.75rem}.card__header,.card__content,.card__footer{padding:1rem}.card--compact .card__header,.card--compact .card__content,.card--compact .card__footer{padding:.5rem}}
:root{--color-primary: #262B64;--color-accent: #63BEFF;--color-secondary-blue: #3A82FF;--color-deep-blue: #1c1e35;--color-white: #ffffff;--color-background: #f9f9f9;--color-surface: #ffffff;--color-border: #C7C7C7;--color-text-primary: #333333;--color-text-secondary: #878787;--color-text-muted: #C7C7C7;--color-text-inverse: #ffffff;--color-success: #00A308;--color-error: #E6463B;--color-warning: #f1d10d;--color-info: #3A82FF;--color-focus: #007bff;--color-disabled-bg: #f5f5f5;--color-disabled-text: #878787;--color-backdrop: rgba(0, 0, 0, 0.5)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes slideDown{from{opacity:0;transform:translateY(-1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{from{opacity:0;transform:translateX(-1rem)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{from{opacity:0;transform:translateX(1rem)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0.9)}}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-0.5rem)}}@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}.user-form-modal__form{display:flex;flex-direction:column;gap:1.5rem}.user-form-modal__roles-field fieldset{border:1px solid var(--color-border);border-radius:.75rem;padding:1rem;margin:0}.user-form-modal__roles-label{font-size:.875rem;font-weight:500;line-height:1.25;color:var(--color-text-primary);color:var(--color-text-primary);font-weight:700;padding:0 .25rem}.user-form-modal__roles-list{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem;max-height:200px;overflow-y:auto}.user-form-modal__roles-list::-webkit-scrollbar{width:8px;height:8px}.user-form-modal__roles-list::-webkit-scrollbar-track{background:rgba(0,0,0,0)}.user-form-modal__roles-list::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:8px}.user-form-modal__roles-list::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}.user-form-modal__role-option{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem;font-weight:400;line-height:1.5;color:var(--color-text-primary)}.user-form-modal__role-option input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--color-primary)}.user-form-modal__role-option:hover span{color:var(--color-primary)}.user-form-modal__roles-empty{font-size:.75rem;font-weight:400;line-height:1.5;color:var(--color-text-secondary);color:var(--color-text-secondary);font-style:italic}.user-form-modal__delete-view{display:flex;flex-direction:column;gap:1.5rem}.user-form-modal__readonly-list{display:flex;flex-direction:column;gap:.5rem;margin:0;padding:1.5rem;background:var(--color-background);border-radius:.75rem;border:1px solid var(--color-border)}.user-form-modal__readonly-item{display:flex;gap:1rem}.user-form-modal__readonly-item dt{font-size:.875rem;font-weight:500;line-height:1.25;color:var(--color-text-primary);font-weight:700;color:var(--color-text-secondary);min-width:90px}.user-form-modal__readonly-item dd{font-size:.875rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);color:var(--color-text-primary);margin:0;word-break:break-all}.user-form-modal__confirm-text{font-size:.875rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);color:var(--color-error, #c0392b);font-weight:700;padding:1rem;background:rgba(192,57,43,.08);border-left:4px solid var(--color-error, #c0392b);border-radius:5px;margin:0}.user-form-modal__error{font-size:.75rem;font-weight:400;line-height:1.5;color:var(--color-text-secondary);color:var(--color-error, #c0392b);margin-top:.5rem;padding:.5rem 1rem;background:rgba(192,57,43,.08);border-radius:5px}.user-form-modal__footer{display:flex;justify-content:flex-end;gap:1rem}
:root{--color-primary: #262B64;--color-accent: #63BEFF;--color-secondary-blue: #3A82FF;--color-deep-blue: #1c1e35;--color-white: #ffffff;--color-background: #f9f9f9;--color-surface: #ffffff;--color-border: #C7C7C7;--color-text-primary: #333333;--color-text-secondary: #878787;--color-text-muted: #C7C7C7;--color-text-inverse: #ffffff;--color-success: #00A308;--color-error: #E6463B;--color-warning: #f1d10d;--color-info: #3A82FF;--color-focus: #007bff;--color-disabled-bg: #f5f5f5;--color-disabled-text: #878787;--color-backdrop: rgba(0, 0, 0, 0.5)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes slideDown{from{opacity:0;transform:translateY(-1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{from{opacity:0;transform:translateX(-1rem)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{from{opacity:0;transform:translateX(1rem)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0.9)}}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-0.5rem)}}@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}.user-management-page{width:100%;max-width:1200px;margin-left:auto;margin-right:auto;padding-left:1rem;padding-right:1rem;padding:2rem}.user-management-page__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:3rem;gap:1.5rem}@media(max-width: 767px){.user-management-page__header{flex-direction:column}}.user-management-page__header-content{flex:1}.user-management-page__title{font-size:2.25rem;font-weight:700;line-height:1.1;color:var(--color-text-primary);margin:0;color:var(--color-primary);margin-bottom:.5rem}.user-management-page__subtitle{font-size:1rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);color:var(--color-text-secondary);margin:0}.user-management-page__content{display:flex;flex-direction:column;gap:2rem}.user-management-page__table-wrapper{background:var(--color-surface);border:1px solid var(--color-border);border-radius:.75rem;box-shadow:0px 2px 6px 0px rgba(0,0,0,.25);overflow-x:auto;-webkit-overflow-scrolling:touch}.user-management-page__table{width:100%;border-collapse:collapse;font-size:.875rem;min-width:700px}.user-management-page__table thead{background:var(--color-primary);color:var(--color-text-inverse)}.user-management-page__table thead th{padding:.5rem 1.5rem;text-align:left;font-weight:700;-webkit-user-select:none;-moz-user-select:none;user-select:none;color:var(--color-text-inverse);border-right:1px solid hsla(0,0%,100%,.1);vertical-align:top}.user-management-page__table thead th:last-child{border-right:none}.user-management-page__table tbody tr{border-bottom:1px solid var(--color-border);transition:background-color .15s ease-in-out}.user-management-page__table tbody tr:hover{background-color:rgba(99,190,255,.05)}.user-management-page__table tbody tr:nth-child(even){background-color:var(--color-background)}.user-management-page__table tbody tr:nth-child(odd){background-color:var(--color-surface)}.user-management-page__table tbody tr:last-child{border-bottom:none}.user-management-page__table tbody td{padding:1rem 1.5rem;color:var(--color-text-primary);vertical-align:middle;border-right:1px solid var(--color-border);word-break:break-word;max-width:200px}.user-management-page__table tbody td:last-child{border-right:none}.user-management-page__th--sortable .user-management-page__th-label{cursor:pointer}.user-management-page__th--sortable .user-management-page__th-label:hover{opacity:.85}.user-management-page__th-label{display:flex;align-items:center;gap:.25rem;white-space:nowrap;padding-bottom:.25rem;font-weight:700}.user-management-page__filter-input{display:block;width:100%;padding:.25rem .5rem;background:hsla(0,0%,100%,.15);border:1px solid hsla(0,0%,100%,.35);border-radius:5px;color:var(--color-text-inverse);font-size:.75rem;line-height:1.4;outline:none;transition:background .15s ease-in-out,border-color .15s ease-in-out}.user-management-page__filter-input::-moz-placeholder{color:hsla(0,0%,100%,.55)}.user-management-page__filter-input::placeholder{color:hsla(0,0%,100%,.55)}.user-management-page__filter-input:focus{background:hsla(0,0%,100%,.25);border-color:hsla(0,0%,100%,.7)}.user-management-page__filter-summary{font-size:.75rem;font-weight:400;line-height:1.5;color:var(--color-text-secondary);color:var(--color-text-secondary);display:flex;align-items:center;gap:1rem}.user-management-page__clear-filters{font-size:.75rem;font-weight:400;line-height:1.5;color:var(--color-text-secondary);color:var(--color-primary);background:none;border:none;cursor:pointer;padding:0;text-decoration:underline}.user-management-page__clear-filters:hover{color:var(--color-accent)}.user-management-page__no-results{padding:2rem 1.5rem;text-align:center;color:var(--color-text-secondary);font-size:.875rem;font-weight:400;line-height:1.5;color:var(--color-text-primary)}.user-management-page__table-actions{display:flex;gap:.5rem;flex-wrap:nowrap}.user-management-page__loading{display:flex;align-items:center;justify-content:center;min-height:300px;padding:3rem}.user-management-page__error{padding:1.5rem;background:rgba(192,57,43,.08);border-left:4px solid var(--color-error, #c0392b);border-radius:5px;color:var(--color-error, #c0392b)}.user-management-page__error p{margin:0}.user-management-page__empty{display:flex;align-items:center;justify-content:center;min-height:200px;padding:3rem;color:var(--color-text-secondary)}.user-management-page__empty p{font-size:1rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);margin:0}
:root{--color-primary: #262B64;--color-accent: #63BEFF;--color-secondary-blue: #3A82FF;--color-deep-blue: #1c1e35;--color-white: #ffffff;--color-background: #f9f9f9;--color-surface: #ffffff;--color-border: #C7C7C7;--color-text-primary: #333333;--color-text-secondary: #878787;--color-text-muted: #C7C7C7;--color-text-inverse: #ffffff;--color-success: #00A308;--color-error: #E6463B;--color-warning: #f1d10d;--color-info: #3A82FF;--color-focus: #007bff;--color-disabled-bg: #f5f5f5;--color-disabled-text: #878787;--color-backdrop: rgba(0, 0, 0, 0.5)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes slideDown{from{opacity:0;transform:translateY(-1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{from{opacity:0;transform:translateX(-1rem)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{from{opacity:0;transform:translateX(1rem)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0.9)}}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-0.5rem)}}@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}.permission-form-modal__form{display:flex;flex-direction:column;gap:1.5rem}.permission-form-modal__delete-view{display:flex;flex-direction:column;gap:1.5rem}.permission-form-modal__readonly-list{display:flex;flex-direction:column;gap:.5rem;margin:0;padding:1.5rem;background:var(--color-background);border-radius:.75rem;border:1px solid var(--color-border)}.permission-form-modal__readonly-item{display:flex;gap:1rem}.permission-form-modal__readonly-item dt{font-size:.875rem;font-weight:500;line-height:1.25;color:var(--color-text-primary);font-weight:700;color:var(--color-text-secondary);min-width:90px}.permission-form-modal__readonly-item dd{font-size:.875rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);color:var(--color-text-primary);margin:0;word-break:break-all}.permission-form-modal__confirm-text{font-size:.875rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);color:var(--color-error, #c0392b);font-weight:700;padding:1rem;background:rgba(192,57,43,.08);border-left:4px solid var(--color-error, #c0392b);border-radius:5px;margin:0}.permission-form-modal__error{font-size:.75rem;font-weight:400;line-height:1.5;color:var(--color-text-secondary);color:var(--color-error, #c0392b);margin-top:.5rem;padding:.5rem 1rem;background:rgba(192,57,43,.08);border-radius:5px}.permission-form-modal__footer{display:flex;justify-content:flex-end;gap:1rem}
:root{--color-primary: #262B64;--color-accent: #63BEFF;--color-secondary-blue: #3A82FF;--color-deep-blue: #1c1e35;--color-white: #ffffff;--color-background: #f9f9f9;--color-surface: #ffffff;--color-border: #C7C7C7;--color-text-primary: #333333;--color-text-secondary: #878787;--color-text-muted: #C7C7C7;--color-text-inverse: #ffffff;--color-success: #00A308;--color-error: #E6463B;--color-warning: #f1d10d;--color-info: #3A82FF;--color-focus: #007bff;--color-disabled-bg: #f5f5f5;--color-disabled-text: #878787;--color-backdrop: rgba(0, 0, 0, 0.5)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes slideDown{from{opacity:0;transform:translateY(-1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{from{opacity:0;transform:translateX(-1rem)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{from{opacity:0;transform:translateX(1rem)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0.9)}}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-0.5rem)}}@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}.permissions-management-page{width:100%;max-width:1200px;margin-left:auto;margin-right:auto;padding-left:1rem;padding-right:1rem;padding:2rem}.permissions-management-page__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:3rem;gap:1.5rem}@media(max-width: 767px){.permissions-management-page__header{flex-direction:column}}.permissions-management-page__header-content{flex:1}.permissions-management-page__title{font-size:2.25rem;font-weight:700;line-height:1.1;color:var(--color-text-primary);margin:0;color:var(--color-primary);margin-bottom:.5rem}.permissions-management-page__subtitle{font-size:1rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);color:var(--color-text-secondary);margin:0}.permissions-management-page__content{display:flex;flex-direction:column;gap:2rem}.permissions-management-page__table-wrapper{background:var(--color-surface);border:1px solid var(--color-border);border-radius:.75rem;box-shadow:0px 2px 6px 0px rgba(0,0,0,.25);overflow-x:auto;-webkit-overflow-scrolling:touch}.permissions-management-page__table{width:100%;border-collapse:collapse;font-size:.875rem;min-width:600px}.permissions-management-page__table thead{background:var(--color-primary);color:var(--color-text-inverse)}.permissions-management-page__table thead th{padding:.5rem 1.5rem;text-align:left;font-weight:700;-webkit-user-select:none;-moz-user-select:none;user-select:none;color:var(--color-text-inverse);border-right:1px solid hsla(0,0%,100%,.1);vertical-align:top}.permissions-management-page__table thead th:last-child{border-right:none}.permissions-management-page__table tbody tr{border-bottom:1px solid var(--color-border);transition:background-color .15s ease-in-out}.permissions-management-page__table tbody tr:hover{background-color:rgba(99,190,255,.05)}.permissions-management-page__table tbody tr:nth-child(even){background-color:var(--color-background)}.permissions-management-page__table tbody tr:nth-child(odd){background-color:var(--color-surface)}.permissions-management-page__table tbody tr:last-child{border-bottom:none}.permissions-management-page__table tbody td{padding:1rem 1.5rem;color:var(--color-text-primary);vertical-align:middle;border-right:1px solid var(--color-border);word-break:break-word;max-width:220px}.permissions-management-page__table tbody td:last-child{border-right:none}.permissions-management-page__th--sortable .permissions-management-page__th-label{cursor:pointer}.permissions-management-page__th--sortable .permissions-management-page__th-label:hover{opacity:.85}.permissions-management-page__th-label{display:flex;align-items:center;gap:.25rem;white-space:nowrap;padding-bottom:.25rem;font-weight:700}.permissions-management-page__filter-input{display:block;width:100%;padding:.25rem .5rem;background:hsla(0,0%,100%,.15);border:1px solid hsla(0,0%,100%,.35);border-radius:5px;color:var(--color-text-inverse);font-size:.75rem;line-height:1.4;outline:none;transition:background .15s ease-in-out,border-color .15s ease-in-out}.permissions-management-page__filter-input::-moz-placeholder{color:hsla(0,0%,100%,.55)}.permissions-management-page__filter-input::placeholder{color:hsla(0,0%,100%,.55)}.permissions-management-page__filter-input:focus{background:hsla(0,0%,100%,.25);border-color:hsla(0,0%,100%,.7)}.permissions-management-page__filter-summary{font-size:.75rem;font-weight:400;line-height:1.5;color:var(--color-text-secondary);color:var(--color-text-secondary);display:flex;align-items:center;gap:1rem}.permissions-management-page__clear-filters{font-size:.75rem;font-weight:400;line-height:1.5;color:var(--color-text-secondary);color:var(--color-primary);background:none;border:none;cursor:pointer;padding:0;text-decoration:underline}.permissions-management-page__clear-filters:hover{color:var(--color-accent)}.permissions-management-page__no-results{padding:2rem 1.5rem;text-align:center;color:var(--color-text-secondary);font-size:.875rem;font-weight:400;line-height:1.5;color:var(--color-text-primary)}.permissions-management-page__table-actions{display:flex;gap:.5rem;flex-wrap:nowrap}.permissions-management-page__loading{display:flex;align-items:center;justify-content:center;min-height:300px;padding:3rem}.permissions-management-page__error{padding:1.5rem;background:rgba(192,57,43,.08);border-left:4px solid var(--color-error, #c0392b);border-radius:5px;color:var(--color-error, #c0392b)}.permissions-management-page__error p{margin:0}.permissions-management-page__empty{display:flex;align-items:center;justify-content:center;min-height:200px;padding:3rem;color:var(--color-text-secondary)}.permissions-management-page__empty p{font-size:1rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);margin:0}
:root{--color-primary: #262B64;--color-accent: #63BEFF;--color-secondary-blue: #3A82FF;--color-deep-blue: #1c1e35;--color-white: #ffffff;--color-background: #f9f9f9;--color-surface: #ffffff;--color-border: #C7C7C7;--color-text-primary: #333333;--color-text-secondary: #878787;--color-text-muted: #C7C7C7;--color-text-inverse: #ffffff;--color-success: #00A308;--color-error: #E6463B;--color-warning: #f1d10d;--color-info: #3A82FF;--color-focus: #007bff;--color-disabled-bg: #f5f5f5;--color-disabled-text: #878787;--color-backdrop: rgba(0, 0, 0, 0.5)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes slideDown{from{opacity:0;transform:translateY(-1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{from{opacity:0;transform:translateX(-1rem)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{from{opacity:0;transform:translateX(1rem)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0.9)}}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-0.5rem)}}@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}.cohort-data-table{width:100%;position:relative;background:var(--color-surface);border:1px solid var(--color-border);border-radius:.75rem;box-shadow:0px 2px 6px 0px rgba(0,0,0,.25);overflow:hidden}.cohort-data-table__wrapper{width:100%;overflow-x:auto}.cohort-data-table__wrapper::-webkit-scrollbar{width:10px;height:10px}.cohort-data-table__wrapper::-webkit-scrollbar-track{background:var(--color-background)}.cohort-data-table__wrapper::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:10px}.cohort-data-table__wrapper::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}.cohort-data-table__wrapper{-webkit-overflow-scrolling:touch}@media(max-width: 767px){.cohort-data-table__wrapper::after{content:"";position:absolute;bottom:0;right:0;width:40px;height:100%;background:linear-gradient(to left, rgba(255, 255, 255, 0.9), transparent);pointer-events:none}}.cohort-data-table__table{width:100%;border-collapse:collapse;font-size:.875rem;min-width:800px}@media(max-width: 575px){.cohort-data-table__table{font-size:.75rem;min-width:600px}}.cohort-data-table__table thead{background:var(--color-primary);color:var(--color-text-inverse);position:sticky;top:0;z-index:200;box-shadow:0px 2px 6px 0px rgba(0,0,0,.25)}.cohort-data-table__table th{padding:1rem 1.5rem;text-align:left;font-weight:700;font-size:.875rem;color:#fff;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;user-select:none;border-right:1px solid hsla(0,0%,100%,.1);transition:background-color .15s ease-in-out}.cohort-data-table__table th:last-child{border-right:none}@media(max-width: 575px){.cohort-data-table__table th{padding:.5rem 1rem;font-size:.75rem}}.cohort-data-table__table tbody tr{border-bottom:1px solid var(--color-border);transition:background-color .15s ease-in-out,transform .15s ease-in-out}.cohort-data-table__table tbody tr:hover{background-color:rgba(99,190,255,.05);transform:scale(1.001);box-shadow:0px 2px 6px 0px rgba(0,0,0,.25)}.cohort-data-table__table tbody tr:nth-child(even){background-color:var(--color-background)}.cohort-data-table__table tbody tr:nth-child(odd){background-color:var(--color-surface)}.cohort-data-table__table tbody tr:last-child{border-bottom:none}.cohort-data-table__table tbody td{padding:1rem 1.5rem;text-align:left;color:var(--color-text-primary);vertical-align:middle;border-right:1px solid var(--color-border)}.cohort-data-table__table tbody td:last-child{border-right:none}@media(max-width: 575px){.cohort-data-table__table tbody td{padding:.5rem 1rem}}.cohort-data-table__th--sortable{cursor:pointer;position:relative;padding-right:2rem}.cohort-data-table__th--sortable:hover{background-color:hsla(0,0%,100%,.1)}.cohort-data-table__th--sortable:active{background-color:hsla(0,0%,100%,.15)}.cohort-data-table__th--sortable::after{content:"";position:absolute;right:1rem;top:50%;transform:translateY(-50%);width:0;height:0;border-left:5px solid rgba(0,0,0,0);border-right:5px solid rgba(0,0,0,0);opacity:.3;transition:opacity .15s ease-in-out,transform .15s ease-in-out}@media(max-width: 575px){.cohort-data-table__th--sortable::after{right:.5rem}}.cohort-data-table__th--sortable::after{border-bottom:6px solid currentColor}.cohort-data-table__th--sortable[data-sort=asc]::after{border-bottom:6px solid currentColor;border-top:none;opacity:1}.cohort-data-table__th--sortable[data-sort=desc]::after{border-top:6px solid currentColor;border-bottom:none;opacity:1;transform:translateY(-50%) rotate(180deg)}.cohort-data-table__actions{display:flex;gap:.5rem;flex-wrap:nowrap}.cohort-data-table__actions button{min-height:36px;min-width:36px;padding:.5rem 1rem;font-size:.75rem;white-space:nowrap}@media(max-width: 575px){.cohort-data-table__actions button{padding:.25rem .5rem;font-size:.625rem}}.cohort-data-table__loading{display:flex;align-items:center;justify-content:center;min-height:300px;padding:3rem;color:var(--color-text-secondary)}@media(max-width: 575px){.cohort-data-table__loading{min-height:200px;padding:2rem}}.cohort-data-table__loading p{font-size:.875rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);margin-top:1rem}.cohort-data-table__skeleton tbody tr td{background:linear-gradient(90deg, var(--color-disabled-bg) 0%, var(--color-background) 50%, var(--color-disabled-bg) 100%);background-size:1000px 100%;animation:shimmer 2s linear infinite;height:48px;border-radius:5px}.cohort-data-table__empty{display:flex;align-items:center;justify-content:center;display:flex;flex-direction:column;min-height:300px;padding:3rem;color:var(--color-text-secondary);gap:1rem}@media(max-width: 575px){.cohort-data-table__empty{min-height:200px;padding:2rem}}.cohort-data-table__empty p{font-size:1rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);color:var(--color-text-secondary);text-align:center;margin:0}.cohort-data-table__empty svg,.cohort-data-table__empty img{width:64px;height:64px;opacity:.5;margin-bottom:.5rem}@media(max-width: 767px){.cohort-data-table__table th,.cohort-data-table__table td{padding:.5rem 1rem}.cohort-data-table__wrapper{position:relative}}@media(max-width: 575px){.cohort-data-table{border-radius:5px}.cohort-data-table__actions{flex-direction:column;gap:.25rem}}
:root{--color-primary: #262B64;--color-accent: #63BEFF;--color-secondary-blue: #3A82FF;--color-deep-blue: #1c1e35;--color-white: #ffffff;--color-background: #f9f9f9;--color-surface: #ffffff;--color-border: #C7C7C7;--color-text-primary: #333333;--color-text-secondary: #878787;--color-text-muted: #C7C7C7;--color-text-inverse: #ffffff;--color-success: #00A308;--color-error: #E6463B;--color-warning: #f1d10d;--color-info: #3A82FF;--color-focus: #007bff;--color-disabled-bg: #f5f5f5;--color-disabled-text: #878787;--color-backdrop: rgba(0, 0, 0, 0.5)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes slideDown{from{opacity:0;transform:translateY(-1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{from{opacity:0;transform:translateX(-1rem)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{from{opacity:0;transform:translateX(1rem)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0.9)}}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-0.5rem)}}@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}.cohort-student-plans-table{width:100%;overflow-x:auto}.cohort-student-plans-table__table{width:100%;border-collapse:collapse;font-size:.875rem}.cohort-student-plans-table__table thead{background:var(--color-primary);position:sticky;top:0;z-index:200;box-shadow:0px 2px 6px 0px rgba(0,0,0,.25)}.cohort-student-plans-table__table th{padding:1rem 1.5rem;text-align:left;font-weight:700;font-size:.875rem;color:#fff;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;user-select:none;border-right:1px solid hsla(0,0%,100%,.1);cursor:pointer;transition:background-color .15s ease-in-out}.cohort-student-plans-table__table th:last-child{border-right:none}.cohort-student-plans-table__table th:hover{background-color:hsla(0,0%,100%,.1)}.cohort-student-plans-table__table tbody tr{border-bottom:1px solid var(--color-border);transition:background-color .15s ease-in-out}.cohort-student-plans-table__table tbody tr:hover{background-color:rgba(99,190,255,.05)}.cohort-student-plans-table__table tbody tr:nth-child(even){background-color:var(--color-background)}.cohort-student-plans-table__table tbody tr:nth-child(odd){background-color:var(--color-surface)}.cohort-student-plans-table__table tbody tr:last-child{border-bottom:none}.cohort-student-plans-table__table tbody td{padding:1rem 1.5rem;text-align:left;color:var(--color-text-primary);vertical-align:middle;border-right:1px solid var(--color-border)}.cohort-student-plans-table__table tbody td:last-child{border-right:none}.cohort-student-plans-table .off-sequence-indicator{color:var(--color-warning, #d97706);font-weight:700}
:root{--color-primary: #262B64;--color-accent: #63BEFF;--color-secondary-blue: #3A82FF;--color-deep-blue: #1c1e35;--color-white: #ffffff;--color-background: #f9f9f9;--color-surface: #ffffff;--color-border: #C7C7C7;--color-text-primary: #333333;--color-text-secondary: #878787;--color-text-muted: #C7C7C7;--color-text-inverse: #ffffff;--color-success: #00A308;--color-error: #E6463B;--color-warning: #f1d10d;--color-info: #3A82FF;--color-focus: #007bff;--color-disabled-bg: #f5f5f5;--color-disabled-text: #878787;--color-backdrop: rgba(0, 0, 0, 0.5)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes slideDown{from{opacity:0;transform:translateY(-1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{from{opacity:0;transform:translateX(-1rem)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{from{opacity:0;transform:translateX(1rem)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0.9)}}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-0.5rem)}}@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}.cohort-plan-detail{display:flex;flex-direction:column;gap:2rem;padding:2rem 0;max-width:1400px;margin:0 auto}.cohort-plan-detail__header{display:flex;flex-direction:column;gap:1rem}.cohort-plan-detail__back-button{display:inline-flex;align-items:center;gap:.5rem}.cohort-plan-detail__back-button .button{padding-left:1rem;padding-right:1rem}.cohort-plan-detail__back-button svg,.cohort-plan-detail__back-button .icon{width:1.25rem;height:1.25rem}.cohort-plan-detail__breadcrumbs{list-style:none;padding-left:0;margin:0;display:flex;flex-direction:row;align-items:center;gap:.5rem;flex-wrap:wrap;font-size:.875rem;color:var(--color-text-secondary)}.cohort-plan-detail__breadcrumb-item{display:flex;align-items:center;gap:.5rem}.cohort-plan-detail__breadcrumb-item:not(:last-child)::after{content:"/";color:var(--color-border);font-weight:400}.cohort-plan-detail__breadcrumb-item a{color:var(--color-primary);text-decoration:none;transition:color .15s ease-in-out}.cohort-plan-detail__breadcrumb-item a:hover{color:var(--color-secondary-blue);text-decoration:underline}.cohort-plan-detail__breadcrumb-item a:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px;border-radius:5px}.cohort-plan-detail__breadcrumb-item--current{color:var(--color-text-primary);font-weight:500}.cohort-plan-detail__title{font-size:1.5rem;font-weight:700;color:var(--color-text-primary);margin:0 0 .5rem 0;line-height:1.25}.cohort-plan-detail__organization{font-size:.875rem;color:var(--color-text-secondary);margin:0}.cohort-plan-detail .plan-terms-section,.cohort-plan-detail .student-plans-section,.cohort-plan-detail .add-students-section{border-radius:1.5rem;box-shadow:0px 2px 6px 0px rgba(0,0,0,.25);background:var(--color-surface);padding:2rem;transition:box-shadow .3s ease-in-out}.cohort-plan-detail .plan-terms-section:hover,.cohort-plan-detail .student-plans-section:hover,.cohort-plan-detail .add-students-section:hover{box-shadow:0px 4px 10px 0px rgba(0,0,0,.5)}.cohort-plan-detail .plan-terms-section h3,.cohort-plan-detail .student-plans-section h3,.cohort-plan-detail .add-students-section h3{font-size:1.25rem;font-weight:700;color:var(--color-text-primary);margin:0 0 1.5rem 0}.cohort-plan-detail__terms-container{display:flex;flex-direction:column;gap:1.5rem}.cohort-plan-detail__term-card{border-radius:.75rem;padding:1rem;border:1px solid var(--color-border);background:var(--color-background);transition:all .15s ease-in-out}.cohort-plan-detail__term-card:hover{border-color:var(--color-primary);box-shadow:0px 2px 6px 0px rgba(0,0,0,.25);transform:translateY(-1px)}.cohort-plan-detail__term-header{font-weight:700;font-size:1rem;color:var(--color-text-primary);margin-bottom:.5rem;display:flex;align-items:baseline;gap:.5rem}.cohort-plan-detail__term-date{font-weight:400;font-size:.875rem;color:var(--color-text-secondary)}.cohort-plan-detail__courses-list{list-style:none;padding-left:0;margin:0;padding-left:1.5rem;margin:0}.cohort-plan-detail__courses-list li{font-size:.875rem;color:var(--color-text-primary);padding:.25rem 0;position:relative}.cohort-plan-detail__courses-list li::before{content:"•";position:absolute;left:-1.5rem;color:var(--color-primary);font-weight:700}.cohort-plan-detail__course-failed{color:var(--color-error);font-weight:700;margin-left:.5rem}.cohort-plan-detail__no-courses,.cohort-plan-detail__no-terms{font-size:.875rem;color:var(--color-text-secondary);font-style:italic;margin:0}.cohort-plan-detail .student-plans-section .cohort-student-plans-table{margin-top:1rem}.cohort-plan-detail .student-plans-section .cohort-data-table::-webkit-scrollbar{width:8px;height:8px}.cohort-plan-detail .student-plans-section .cohort-data-table::-webkit-scrollbar-track{background:var(--color-background)}.cohort-plan-detail .student-plans-section .cohort-data-table::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:8px}.cohort-plan-detail .student-plans-section .cohort-data-table::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}.cohort-plan-detail .student-plans-section .off-sequence-indicator{color:var(--color-warning);font-weight:700}.cohort-plan-detail .add-students-form h3{font-size:1.25rem;font-weight:700;color:var(--color-text-primary);margin:0 0 1.5rem 0}.cohort-plan-detail .add-students-form label{display:block;font-size:.875rem;font-weight:500;color:var(--color-text-primary);margin-bottom:.5rem}.cohort-plan-detail .add-students-form textarea{width:100%;min-height:150px;padding:1rem;font-family:source-code-pro,Menlo,Monaco,Consolas,"Courier New",monospace;font-size:.875rem;line-height:1.5;border:2px solid var(--color-border);border-radius:.75rem;background:var(--color-surface);color:var(--color-text-primary);resize:vertical;transition:border-color .15s ease-in-out}.cohort-plan-detail .add-students-form textarea:hover{border-color:var(--color-primary)}.cohort-plan-detail .add-students-form textarea:focus{outline:2px solid var(--color-focus);outline-offset:2px;border-radius:5px;border-color:var(--color-primary)}.cohort-plan-detail .add-students-form textarea::-moz-placeholder{color:var(--color-text-muted);opacity:.7}.cohort-plan-detail .add-students-form textarea::placeholder{color:var(--color-text-muted);opacity:.7}.cohort-plan-detail .add-students-form textarea:disabled{background:var(--color-disabled-bg);color:var(--color-disabled-text);cursor:not-allowed;opacity:.6}.cohort-plan-detail .add-students-form__helper-text{font-size:.75rem;color:var(--color-text-secondary);margin:.5rem 0 1rem 0}.cohort-plan-detail .add-students-form [role=status]{padding:1rem;border-radius:.75rem;background:rgba(0,163,8,.1);color:var(--color-success);border-left:4px solid var(--color-success);margin-bottom:1rem;font-size:.875rem;font-weight:500}.cohort-plan-detail .add-students-form [role=alert]{padding:1rem;border-radius:.75rem;background:rgba(230,70,59,.1);color:var(--color-error);border-left:4px solid var(--color-error);margin-bottom:1rem;font-size:.875rem;font-weight:500}.cohort-plan-detail .add-students-form__actions{display:flex;justify-content:flex-start;gap:1rem;margin-top:1rem}.cohort-plan-detail .cohort-data-table__table th{position:sticky;top:0;z-index:200;background-color:var(--color-background);box-shadow:0 2px 4px rgba(0,0,0,.05)}.cohort-plan-detail .cohort-data-table__table th[style*="cursor: pointer"]{transition:background-color .15s ease-in-out}.cohort-plan-detail .cohort-data-table__table th[style*="cursor: pointer"]:hover{background-color:var(--color-border)}.cohort-plan-detail .cohort-data-table__table tbody tr{transition:all .15s ease-in-out}.cohort-plan-detail .cohort-data-table__table tbody tr:hover{background-color:rgba(38,43,100,.05);transform:translateX(2px);box-shadow:0px 2px 6px 0px rgba(0,0,0,.25)}.cohort-plan-detail .cohort-data-table__table td{vertical-align:middle}.cohort-plan-detail .cohort-data-table__table td .button{min-width:80px}@media(max-width: 767px){.cohort-plan-detail{padding:1.5rem 0;gap:1.5rem}.cohort-plan-detail .plan-terms-section,.cohort-plan-detail .student-plans-section,.cohort-plan-detail .add-students-section{padding:1.5rem;border-radius:.75rem}.cohort-plan-detail__title{font-size:1.25rem}.cohort-plan-detail__term-card{padding:.5rem}}@media(max-width: 575px){.cohort-plan-detail{padding:1rem 0;gap:1rem}.cohort-plan-detail .plan-terms-section,.cohort-plan-detail .student-plans-section,.cohort-plan-detail .add-students-section{padding:1rem;margin:-0.5rem}.cohort-plan-detail__title{font-size:1rem}.cohort-plan-detail__breadcrumbs{font-size:.75rem}.cohort-plan-detail__term-card{padding:.5rem}.cohort-plan-detail__courses-list{padding-left:1rem}.cohort-plan-detail__courses-list li{font-size:.75rem}.cohort-plan-detail .cohort-data-table{overflow-x:auto;-webkit-overflow-scrolling:touch}.cohort-plan-detail .cohort-data-table__table{min-width:600px}.cohort-plan-detail .add-students-form textarea{min-height:120px;font-size:.75rem}.cohort-plan-detail .add-students-form__actions{flex-direction:column}.cohort-plan-detail .add-students-form__actions .button{width:100%}}@media(max-width: 374px){.cohort-plan-detail__back-button .button{padding:.5rem;font-size:.875rem}.cohort-plan-detail__breadcrumbs{display:none}}
:root{--color-primary: #262B64;--color-accent: #63BEFF;--color-secondary-blue: #3A82FF;--color-deep-blue: #1c1e35;--color-white: #ffffff;--color-background: #f9f9f9;--color-surface: #ffffff;--color-border: #C7C7C7;--color-text-primary: #333333;--color-text-secondary: #878787;--color-text-muted: #C7C7C7;--color-text-inverse: #ffffff;--color-success: #00A308;--color-error: #E6463B;--color-warning: #f1d10d;--color-info: #3A82FF;--color-focus: #007bff;--color-disabled-bg: #f5f5f5;--color-disabled-text: #878787;--color-backdrop: rgba(0, 0, 0, 0.5)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes slideDown{from{opacity:0;transform:translateY(-1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{from{opacity:0;transform:translateX(-1rem)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{from{opacity:0;transform:translateX(1rem)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0.9)}}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-0.5rem)}}@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}.snap-page{width:100%;max-width:1200px;margin-left:auto;margin-right:auto;padding-left:1rem;padding-right:1rem;padding:2rem}.snap-page__header{margin-bottom:3rem}.snap-page__title{font-size:2.25rem;font-weight:700;line-height:1.1;color:var(--color-text-primary);margin:0;color:var(--color-primary);margin-bottom:.5rem}.snap-page__description{font-size:1rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);color:var(--color-text-secondary);margin:0}.snap-page__error-notice{display:flex;align-items:flex-start;gap:1rem;padding:1rem 1.5rem;margin-bottom:1.5rem;background:#fff2f2;border:2px solid var(--color-danger, #c0392b);border-radius:.75rem}.snap-page__error-notice-icon{font-size:1.25rem;line-height:1;color:var(--color-danger, #c0392b);flex-shrink:0;margin-top:.1rem}.snap-page__error-notice-body{flex:1;min-width:0}.snap-page__error-notice-title{font-size:.875rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);font-weight:700;color:var(--color-danger, #c0392b);display:block;margin-bottom:.25rem}.snap-page__error-notice-message{font-size:.875rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);color:var(--color-text-primary);margin:0}.snap-page__error-notice-dismiss{background:none;border:none;cursor:pointer;font-size:1.5rem;line-height:1;color:var(--color-text-secondary);padding:0;flex-shrink:0}.snap-page__error-notice-dismiss:hover{color:var(--color-danger, #c0392b)}.snap-page__error-notice-dismiss:focus-visible{outline:2px solid var(--color-accent);border-radius:2px}.snap-page__content{display:flex;flex-direction:column;gap:2rem}.snap-page__section{border-radius:1.5rem;box-shadow:0px 2px 6px 0px rgba(0,0,0,.25);position:relative;background:var(--color-surface);padding:2rem;padding-left:5.5rem;transition:box-shadow .3s ease-in-out}.snap-page__section:hover{box-shadow:0px 4px 10px 0px rgba(0,0,0,.5)}.snap-page__section::before{content:attr(data-number);position:absolute;left:1.5rem;top:2rem;width:2.25rem;height:2.25rem;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg, var(--color-accent) 0%, var(--color-secondary-blue) 100%);color:var(--color-text-inverse);border-radius:50%;font-size:1rem;font-weight:700;box-shadow:0px 2px 6px 0px rgba(0,0,0,.25)}.snap-page__section[data-number="1"]::before{background:linear-gradient(135deg, #63BEFF 0%, #3A82FF 100%)}.snap-page__section[data-number="2"]::before{background:linear-gradient(135deg, #3A82FF 0%, #262B64 100%)}.snap-page__section[data-number="3"]::before{background:linear-gradient(135deg, #262B64 0%, #1c1e35 100%)}.snap-page__section-title{font-size:1.5rem;font-weight:700;line-height:1.25;color:var(--color-text-primary);margin:0;color:var(--color-primary);margin-bottom:1.5rem}.snap-page__section-description{font-size:.875rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);color:var(--color-text-secondary);margin-bottom:1.5rem}.snap-page__form-row{display:grid;grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));gap:1rem;margin-bottom:1.5rem}.snap-page__form-row:last-child{margin-bottom:0}.snap-page__form-group{display:flex;flex-direction:column;gap:.25rem}.snap-page__textarea{min-height:120px;resize:vertical}.snap-page__actions{display:flex;justify-content:flex-end;align-items:center;gap:1rem;padding-top:2rem;margin-top:2rem;border-top:2px solid var(--color-border)}@media(max-width: 767px){.snap-page__actions{flex-direction:column-reverse;align-items:stretch}.snap-page__actions .button{width:100%}}.snap-page__results{border-radius:1.5rem;background:var(--color-background);padding:2rem;margin-top:2rem;border:2px solid var(--color-accent)}.snap-page__results-title{font-size:1.25rem;font-weight:700;line-height:1.25;color:var(--color-text-primary);margin:0;color:var(--color-primary);margin-bottom:1rem}.snap-page__results-content{display:flex;flex-direction:column;gap:1rem}.snap-page__progress{display:flex;justify-content:space-between;align-items:center;margin-bottom:3rem;padding:1.5rem;background:var(--color-background);border-radius:.75rem}.snap-page__progress-step{display:flex;flex-direction:column;align-items:center;gap:.25rem;flex:1;position:relative}.snap-page__progress-step::after{content:"";position:absolute;top:1rem;left:50%;width:100%;height:2px;background:var(--color-border);z-index:-1}.snap-page__progress-step:last-child::after{display:none}.snap-page__progress-step--active .snap-page__progress-number{background:var(--color-accent);color:var(--color-text-inverse);border-color:var(--color-accent)}.snap-page__progress-step--completed .snap-page__progress-number{background:var(--color-success);color:var(--color-text-inverse);border-color:var(--color-success)}.snap-page__progress-number{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:50%;border:2px solid var(--color-border);background:var(--color-white);color:var(--color-text-secondary);font-weight:700;font-size:.875rem}.snap-page__progress-label{font-size:.75rem;font-weight:400;line-height:1.5;color:var(--color-text-secondary);color:var(--color-text-secondary);text-align:center}@media(max-width: 767px){.snap-page{padding:1.5rem 1rem}.snap-page__section{padding:1.5rem;padding-left:4.5rem}.snap-page__section::before{left:1rem;top:1rem;width:2rem;height:2rem;font-size:.875rem}.snap-page__form-row{grid-template-columns:1fr}}@media(max-width: 575px){.snap-page{padding:1rem}.snap-page__section{padding:1rem;padding-top:4rem;padding-left:1rem}.snap-page__section::before{left:50%;top:1rem;transform:translateX(-50%)}}
.student-info-card{padding:1.5rem;background-color:#f9f9f9;border:1px solid #ddd;border-radius:4px}.student-info-card__title{font-size:1.125rem;font-weight:600;margin:0 0 1rem 0}.student-info-card__details{margin:0}.student-info-card__row{display:flex;margin-bottom:.75rem}.student-info-card__row:last-child{margin-bottom:0}.student-info-card__label{font-weight:600;min-width:120px;margin:0}.student-info-card__value{margin:0;color:#333}
:root{--color-primary: #262B64;--color-accent: #63BEFF;--color-secondary-blue: #3A82FF;--color-deep-blue: #1c1e35;--color-white: #ffffff;--color-background: #f9f9f9;--color-surface: #ffffff;--color-border: #C7C7C7;--color-text-primary: #333333;--color-text-secondary: #878787;--color-text-muted: #C7C7C7;--color-text-inverse: #ffffff;--color-success: #00A308;--color-error: #E6463B;--color-warning: #f1d10d;--color-info: #3A82FF;--color-focus: #007bff;--color-disabled-bg: #f5f5f5;--color-disabled-text: #878787;--color-backdrop: rgba(0, 0, 0, 0.5)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes slideDown{from{opacity:0;transform:translateY(-1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{from{opacity:0;transform:translateX(-1rem)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{from{opacity:0;transform:translateX(1rem)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0.9)}}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-0.5rem)}}@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}.student-plan-edit-page{width:100%;max-width:1200px;margin-left:auto;margin-right:auto;padding-left:1rem;padding-right:1rem;padding:2rem}.student-plan-edit-page__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:3rem;gap:1.5rem}@media(max-width: 767px){.student-plan-edit-page__header{flex-direction:column}}.student-plan-edit-page__header-content{flex:1}.student-plan-edit-page__title{font-size:2.25rem;font-weight:700;line-height:1.1;color:var(--color-text-primary);margin:0;color:var(--color-primary);margin-bottom:.5rem}.student-plan-edit-page__subtitle{font-size:1rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);color:var(--color-text-secondary);margin:0}.student-plan-edit-page__header-actions{display:flex;gap:1rem;align-items:center}@media(max-width: 767px){.student-plan-edit-page__header-actions{width:100%;flex-wrap:wrap}}.student-plan-edit-page__content{display:flex;flex-direction:column;gap:2rem}.student-plan-edit-page__section{border-radius:1.5rem;box-shadow:0px 2px 6px 0px rgba(0,0,0,.25);background:var(--color-surface);padding:2rem;transition:box-shadow .3s ease-in-out}.student-plan-edit-page__section:hover{box-shadow:0px 4px 10px 0px rgba(0,0,0,.5)}.student-plan-edit-page__section-title{font-size:1.5rem;font-weight:700;line-height:1.25;color:var(--color-text-primary);margin:0;color:var(--color-primary);margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--color-border)}.student-plan-edit-page__details{display:grid;grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));gap:1.5rem;padding:1.5rem;background:var(--color-background);border-radius:.75rem}.student-plan-edit-page__field{display:flex;flex-direction:column;gap:.25rem}.student-plan-edit-page__field-label{font-size:.875rem;font-weight:500;line-height:1.25;color:var(--color-text-primary);color:var(--color-text-secondary);text-transform:uppercase;font-size:.75rem;letter-spacing:.5px}.student-plan-edit-page__field-value{font-size:1rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);color:var(--color-text-primary);font-weight:500}.student-plan-edit-page__actions{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding-top:2rem;margin-top:2rem;border-top:2px solid var(--color-border)}@media(max-width: 767px){.student-plan-edit-page__actions{flex-direction:column;align-items:stretch}.student-plan-edit-page__actions .button{width:100%}}.student-plan-edit-page__actions-left{display:flex;gap:1rem}@media(max-width: 767px){.student-plan-edit-page__actions-left{width:100%;flex-direction:column}}.student-plan-edit-page__actions-right{display:flex;gap:1rem}@media(max-width: 767px){.student-plan-edit-page__actions-right{width:100%;flex-direction:column-reverse}}.student-plan-edit-page__loading{display:flex;align-items:center;justify-content:center;min-height:400px;color:var(--color-text-secondary)}.student-plan-edit-page__loading-spinner{animation:spin .6s linear infinite;width:3rem;height:3rem;border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;margin-bottom:1rem}@media(max-width: 767px){.student-plan-edit-page{padding:1.5rem 1rem}.student-plan-edit-page__details{grid-template-columns:1fr;gap:1rem}.student-plan-edit-page__section{padding:1.5rem}}@media(max-width: 575px){.student-plan-edit-page{padding:1rem}.student-plan-edit-page__section{padding:1rem}}
:root{--color-primary: #262B64;--color-accent: #63BEFF;--color-secondary-blue: #3A82FF;--color-deep-blue: #1c1e35;--color-white: #ffffff;--color-background: #f9f9f9;--color-surface: #ffffff;--color-border: #C7C7C7;--color-text-primary: #333333;--color-text-secondary: #878787;--color-text-muted: #C7C7C7;--color-text-inverse: #ffffff;--color-success: #00A308;--color-error: #E6463B;--color-warning: #f1d10d;--color-info: #3A82FF;--color-focus: #007bff;--color-disabled-bg: #f5f5f5;--color-disabled-text: #878787;--color-backdrop: rgba(0, 0, 0, 0.5)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes slideDown{from{opacity:0;transform:translateY(-1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{from{opacity:0;transform:translateX(-1rem)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{from{opacity:0;transform:translateX(1rem)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0.9)}}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-0.5rem)}}@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}.cohort-plan-edit-page{width:100%;max-width:1200px;margin-left:auto;margin-right:auto;padding-left:1rem;padding-right:1rem;padding:2rem}.cohort-plan-edit-page__back-button{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:1rem}.cohort-plan-edit-page__back-button .button{padding-left:1rem;padding-right:1rem}.cohort-plan-edit-page__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:3rem;gap:1.5rem}@media(max-width: 767px){.cohort-plan-edit-page__header{flex-direction:column}}.cohort-plan-edit-page__header-content{flex:1}.cohort-plan-edit-page__title{font-size:2.25rem;font-weight:700;line-height:1.1;color:var(--color-text-primary);margin:0;color:var(--color-primary);margin-bottom:.5rem}.cohort-plan-edit-page__subtitle{font-size:1rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);color:var(--color-text-secondary);margin:0}.cohort-plan-edit-page__header-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem 1rem;background:var(--color-accent);color:var(--color-text-inverse);border-radius:.75rem;font-size:.75rem;font-weight:700;margin-left:1rem}.cohort-plan-edit-page__content{display:flex;flex-direction:column;gap:2rem}.cohort-plan-edit-page__section{border-radius:1.5rem;box-shadow:0px 2px 6px 0px rgba(0,0,0,.25);background:var(--color-surface);padding:2rem;transition:box-shadow .3s ease-in-out}.cohort-plan-edit-page__section:hover{box-shadow:0px 4px 10px 0px rgba(0,0,0,.5)}.cohort-plan-edit-page__section-title{font-size:1.5rem;font-weight:700;line-height:1.25;color:var(--color-text-primary);margin:0;color:var(--color-primary);margin-bottom:1.5rem}.cohort-plan-edit-page__section-description{font-size:.875rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);color:var(--color-text-secondary);margin-bottom:1.5rem;padding:1rem;background:var(--color-background);border-left:4px solid var(--color-accent);border-radius:5px}.cohort-plan-edit-page__cohort-info{display:grid;grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));gap:1.5rem;padding:1.5rem;background:linear-gradient(135deg, var(--color-background) 0%, var(--color-surface) 100%);border-radius:.75rem;border:1px solid var(--color-border)}.cohort-plan-edit-page__info-item{display:flex;flex-direction:column;gap:.25rem}.cohort-plan-edit-page__info-label{font-size:.875rem;font-weight:500;line-height:1.25;color:var(--color-text-primary);color:var(--color-text-secondary);text-transform:uppercase;font-size:.75rem;letter-spacing:.5px}.cohort-plan-edit-page__info-value{font-size:1rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);color:var(--color-text-primary);font-weight:700}.cohort-plan-edit-page__warning{display:flex;align-items:flex-start;gap:1rem;padding:1.5rem;background:rgba(241,209,13,.1);border-left:4px solid var(--color-warning);border-radius:5px;margin-bottom:1.5rem}.cohort-plan-edit-page__warning-icon{font-size:1.5rem;color:var(--color-warning);flex-shrink:0}.cohort-plan-edit-page__warning-content{flex:1}.cohort-plan-edit-page__warning-title{font-size:1rem;font-weight:700;line-height:1.25;color:var(--color-text-primary);margin:0;color:var(--color-text-primary);margin-bottom:.25rem}.cohort-plan-edit-page__warning-text{font-size:.875rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);color:var(--color-text-primary)}.cohort-plan-edit-page__students-list{list-style:none;padding-left:0;margin:0;display:flex;flex-direction:column;gap:.5rem;max-height:300px;overflow-y:auto}.cohort-plan-edit-page__students-list::-webkit-scrollbar{width:8px;height:8px}.cohort-plan-edit-page__students-list::-webkit-scrollbar-track{background:rgba(0,0,0,0)}.cohort-plan-edit-page__students-list::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:8px}.cohort-plan-edit-page__students-list::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}.cohort-plan-edit-page__students-list{padding:1rem;background:var(--color-background);border-radius:.75rem}.cohort-plan-edit-page__student-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;background:var(--color-surface);border-radius:5px;transition:background .15s ease-in-out}.cohort-plan-edit-page__student-item:hover{background:var(--color-disabled-bg)}.cohort-plan-edit-page__student-item--excluded{opacity:.6;text-decoration:line-through}.cohort-plan-edit-page__student-name{font-size:.875rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);font-weight:500}.cohort-plan-edit-page__student-status{font-size:.75rem;font-weight:400;line-height:1.5;color:var(--color-text-secondary);color:var(--color-text-secondary)}.cohort-plan-edit-page__actions{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding-top:2rem;margin-top:2rem;border-top:2px solid var(--color-border)}@media(max-width: 767px){.cohort-plan-edit-page__actions{flex-direction:column;align-items:stretch}.cohort-plan-edit-page__actions .button{width:100%}}.cohort-plan-edit-page__actions-left{display:flex;gap:1rem}@media(max-width: 767px){.cohort-plan-edit-page__actions-left{width:100%;order:2}}.cohort-plan-edit-page__actions-right{display:flex;gap:1rem}@media(max-width: 767px){.cohort-plan-edit-page__actions-right{width:100%;flex-direction:column-reverse;order:1}}.cohort-plan-edit-page__confirmation-content{padding:1.5rem}.cohort-plan-edit-page__confirmation-title{font-size:1.25rem;font-weight:700;line-height:1.25;color:var(--color-text-primary);margin:0;color:var(--color-primary);margin-bottom:1rem}.cohort-plan-edit-page__confirmation-message{font-size:.875rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);color:var(--color-text-primary);margin-bottom:1.5rem}.cohort-plan-edit-page__confirmation-count{display:inline-flex;padding:.25rem 1rem;background:var(--color-accent);color:var(--color-text-inverse);border-radius:5px;font-weight:700}@media(max-width: 767px){.cohort-plan-edit-page{padding:1.5rem 1rem}.cohort-plan-edit-page__cohort-info{grid-template-columns:1fr;gap:1rem}.cohort-plan-edit-page__section{padding:1.5rem}}@media(max-width: 575px){.cohort-plan-edit-page{padding:1rem}.cohort-plan-edit-page__section{padding:1rem}.cohort-plan-edit-page__warning{flex-direction:column}}
:root{--color-primary: #262B64;--color-accent: #63BEFF;--color-secondary-blue: #3A82FF;--color-deep-blue: #1c1e35;--color-white: #ffffff;--color-background: #f9f9f9;--color-surface: #ffffff;--color-border: #C7C7C7;--color-text-primary: #333333;--color-text-secondary: #878787;--color-text-muted: #C7C7C7;--color-text-inverse: #ffffff;--color-success: #00A308;--color-error: #E6463B;--color-warning: #f1d10d;--color-info: #3A82FF;--color-focus: #007bff;--color-disabled-bg: #f5f5f5;--color-disabled-text: #878787;--color-backdrop: rgba(0, 0, 0, 0.5)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes slideDown{from{opacity:0;transform:translateY(-1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{from{opacity:0;transform:translateX(-1rem)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{from{opacity:0;transform:translateX(1rem)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0.9)}}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-0.5rem)}}@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{height:100%;font-size:16px;-webkit-text-size-adjust:100%}body{height:100%;font-family:"Lato",-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;font-size:.875rem;line-height:1.5;color:var(--color-text-primary);background-color:var(--color-background);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}#root{height:100%;display:flex;flex-direction:column}h1{font-size:2.25rem;font-weight:700;line-height:1.1;color:var(--color-text-primary);margin:0;margin-bottom:1.5rem}h2{font-size:1.5rem;font-weight:700;line-height:1.25;color:var(--color-text-primary);margin:0;margin-bottom:1rem}h3{font-size:1.25rem;font-weight:700;line-height:1.25;color:var(--color-text-primary);margin:0;margin-bottom:1rem}h4{font-size:1rem;font-weight:700;line-height:1.25;color:var(--color-text-primary);margin:0;margin-bottom:.5rem}h5{font-size:.875rem;font-weight:700;line-height:1.25;color:var(--color-text-primary);margin:0;margin-bottom:.5rem}h6{font-size:.75rem;font-weight:700;line-height:1.25;color:var(--color-text-primary);margin:0;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}p{font-size:.875rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);margin-bottom:1rem}p:last-child{margin-bottom:0}a{color:var(--color-accent);text-decoration:none;transition:color .15s ease-in-out}a:hover{color:var(--color-secondary-blue);text-decoration:underline}a:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px;border-radius:2px}strong,b{font-weight:700}em,i{font-style:italic}small{font-size:.75rem;font-weight:400;line-height:1.5;color:var(--color-text-secondary)}code,kbd,samp,pre{font-family:source-code-pro,Menlo,Monaco,Consolas,"Courier New",monospace;font-size:.9em}code{font-family:source-code-pro,Menlo,Monaco,Consolas,"Courier New",monospace;font-size:.9em;background:var(--color-disabled-bg);padding:.125rem .375rem;border-radius:5px;color:var(--color-text-primary)}pre{background:var(--color-disabled-bg);padding:1rem;border-radius:.75rem;overflow-x:auto}pre::-webkit-scrollbar{width:8px;height:8px}pre::-webkit-scrollbar-track{background:rgba(0,0,0,0)}pre::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:8px}pre::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}pre code{background:none;padding:0}ul,ol{padding-left:1.5rem;margin-bottom:1rem}ul:last-child,ol:last-child{margin-bottom:0}li{margin-bottom:.25rem}button,input,select,textarea{font-family:inherit;font-size:100%;line-height:inherit;margin:0}button{cursor:pointer}input:disabled,select:disabled,textarea:disabled{cursor:not-allowed}*:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px;border-radius:5px}*:focus:not(:focus-visible){outline:none}img,picture,video,canvas,svg{display:block;max-width:100%;height:auto}table{width:100%;border-collapse:collapse;border-spacing:0}th,td{text-align:left;padding:.5rem}th{font-weight:700;color:var(--color-text-primary)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0}.not-sr-only{position:static;width:auto;height:auto;padding:0;margin:0;overflow:visible;clip:auto;white-space:normal}@media print{*,*::before,*::after{background:rgba(0,0,0,0) !important;color:#000 !important;box-shadow:none !important;text-shadow:none !important}a,a:visited{text-decoration:underline}a[href]::after{content:" (" attr(href) ")"}abbr[title]::after{content:" (" attr(title) ")"}pre,blockquote{border:1px solid #999;page-break-inside:avoid}thead{display:table-header-group}tr,img{page-break-inside:avoid}p,h2,h3{orphans:3;widows:3}h2,h3{page-break-after:avoid}}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(180deg, #2533cc 0%, #262B64 33%, #262B64 66%, #262B64 100%);padding:1rem}.login-container{background:var(--color-surface);padding:3rem;border-radius:1.5rem;box-shadow:0px 4px 10px 0px rgba(0,0,0,.5);width:100%;max-width:400px}@media(max-width: 374px){.login-container{padding:2rem;max-width:100%}}.login-title{margin:0 0 .5rem 0;font-size:2.25rem;font-weight:700;line-height:1.1;color:var(--color-primary);text-align:center}@media(max-width: 374px){.login-title{font-size:1.5rem}}.login-subtitle{margin:0 0 2rem 0;text-align:center;color:var(--color-text-secondary);font-size:.875rem;line-height:1.5}.login-form .form-group{margin-bottom:1.5rem}.login-form .form-label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.875rem;color:var(--color-text-primary)}.login-form .form-input{width:100%;padding:1rem;border:1px solid var(--color-border);border-radius:.75rem;font-size:1rem;font-family:"Lato",-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;color:var(--color-text-primary);background-color:var(--color-surface);transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out;min-height:44px;min-width:44px}.login-form .form-input:focus{outline:none;border-color:var(--color-secondary-blue);box-shadow:0 0 0 3px rgba(58,130,255,.1)}.login-form .form-input:disabled{background-color:var(--color-disabled-bg);color:var(--color-disabled-text);cursor:not-allowed}.login-form .form-input::-moz-placeholder{color:var(--color-text-muted)}.login-form .form-input::placeholder{color:var(--color-text-muted)}.login-error{padding:1rem;margin-bottom:1.5rem;background-color:rgba(230,70,59,.1);border:1px solid rgba(230,70,59,.3);border-radius:.75rem;color:var(--color-error);font-size:.875rem;line-height:1.5}.login-button{width:100%;padding:1rem 1.5rem;background-color:var(--color-secondary-blue);color:var(--color-text-inverse);border:none;border-radius:.75rem;font-size:1rem;font-weight:500;font-family:"Lato",-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;cursor:pointer;transition:background-color .3s ease-in-out,transform .15s ease-in-out,box-shadow .15s ease-in-out;min-height:44px;min-width:44px}.login-button:hover:not(:disabled){background-color:rgb(17.2,104.1116751269,255);transform:translateY(-2px);box-shadow:0px 2px 6px 0px rgba(0,0,0,.25)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:focus{outline:none;box-shadow:0 0 0 3px rgba(58,130,255,.3)}.login-button:disabled{background-color:var(--color-disabled-bg);color:var(--color-disabled-text);cursor:not-allowed;transform:none;box-shadow:none}.login-button.loading{position:relative;color:rgba(0,0,0,0);pointer-events:none}.login-button.loading::after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%, -50%);width:1rem;height:1rem;border:2px solid currentColor;border-radius:50%;border-top-color:rgba(0,0,0,0);animation:spin .6s linear infinite}.home-page{min-height:100%;background-color:var(--color-background)}.home-hero{background:linear-gradient(135deg, #262B64 0%, #1c1e35 100%);padding:4rem 3rem;text-align:center;position:relative;overflow:hidden;color:#fff}.home-hero::before{content:"";position:absolute;top:-80px;right:-100px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle, rgba(99, 190, 255, 0.14) 0%, transparent 65%);pointer-events:none}.home-hero::after{content:"";position:absolute;bottom:-100px;left:-80px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle, rgba(58, 130, 255, 0.1) 0%, transparent 65%);pointer-events:none}.home-hero__inner{position:relative;z-index:1;max-width:560px;margin:0 auto}.home-hero__icon{width:60px;height:60px;display:block;margin:0 auto 1.5rem;color:#63beff;filter:drop-shadow(0 0 16px rgba(99, 190, 255, 0.5))}.home-hero__title{margin:0 0 1rem;font-size:2.25rem;font-weight:700;line-height:1.1;color:#fff;letter-spacing:-0.01em}@media(max-width: 767px){.home-hero__title{font-size:1.5rem}}.home-hero__subtitle{margin:0;font-size:1rem;color:hsla(0,0%,100%,.65);line-height:1.5;letter-spacing:.02em}@media(max-width: 767px){.home-hero__subtitle{font-size:.875rem}}.home-content{padding:3rem;max-width:1400px;margin:0 auto}@media(max-width: 767px){.home-content{padding:2rem 1rem}}.home-content__label{margin:0 0 1.5rem;font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-secondary)}.home-cards{display:grid;grid-template-columns:repeat(3, 1fr);gap:1.5rem}@media(max-width: 991px){.home-cards{grid-template-columns:repeat(2, 1fr)}}@media(max-width: 767px){.home-cards{grid-template-columns:1fr}}.home-card{display:flex;align-items:center;gap:1.5rem;padding:2rem;background:var(--color-surface);border-radius:.75rem;border:1px solid var(--color-border);text-decoration:none;color:inherit;transition:transform .15s ease-in-out,box-shadow .15s ease-in-out,border-color .15s ease-in-out;box-shadow:0px 2px 6px 0px rgba(0,0,0,.25)}.home-card:hover{transform:translateY(-3px);box-shadow:0px 6px 16px 0px rgba(0,0,0,.35);border-color:#3a82ff;text-decoration:none}.home-card:hover .home-card__arrow{transform:translateX(4px);color:#3a82ff}.home-card:hover .home-card__icon-wrap{background:linear-gradient(135deg, rgba(38, 43, 100, 0.12), rgba(58, 130, 255, 0.16))}.home-card:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px;border-radius:5px;text-decoration:none}.home-card__icon-wrap{flex-shrink:0;width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg, rgba(38, 43, 100, 0.08), rgba(58, 130, 255, 0.1));border-radius:5px;color:#262b64;transition:background .15s ease-in-out}.home-card__icon-wrap svg{width:26px;height:26px}.home-card__body{flex:1;min-width:0}.home-card__title{margin:0 0 .25rem;font-size:1rem;font-weight:700;color:var(--color-text-primary);line-height:1.25}.home-card__desc{margin:0;font-size:.875rem;color:var(--color-text-secondary);line-height:1.5}.home-card__arrow{flex-shrink:0;color:var(--color-text-muted);font-size:1rem;transition:transform .15s ease-in-out,color .15s ease-in-out}.degree-plans-list-page{padding:2rem;max-width:1400px;margin:0 auto;animation:fadeIn .3s ease-in-out ease-in-out 0s forwards}@media(max-width: 767px){.degree-plans-list-page{padding:1.5rem 1rem}}@media(max-width: 575px){.degree-plans-list-page{padding:1rem}}.degree-plans-list-page>h1{font-size:2.25rem;font-weight:700;line-height:1.1;color:var(--color-text-primary);margin:0;margin-bottom:.5rem;color:var(--color-primary)}.degree-plans-list-page>p{font-size:.875rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);color:var(--color-text-secondary);margin-bottom:2rem}@media(max-width: 575px){.degree-plans-list-page>p{margin-bottom:1.5rem}}.degree-plans-list-page .page-controls{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem;padding:1.5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:.75rem;box-shadow:0px 2px 6px 0px rgba(0,0,0,.25)}@media(max-width: 575px){.degree-plans-list-page .page-controls{padding:1rem;margin-bottom:1.5rem}}.degree-plans-list-page .page-controls .organization-select{max-width:400px}@media(max-width: 575px){.degree-plans-list-page .page-controls .organization-select{max-width:100%}}.degree-plans-list-page .page-prompt{display:flex;align-items:center;justify-content:center;min-height:300px;padding:2rem;background:var(--color-background);border:2px dashed var(--color-border);border-radius:.75rem;animation:fadeIn .3s ease-in-out ease-in-out 0s forwards}@media(max-width: 575px){.degree-plans-list-page .page-prompt{min-height:200px;padding:1.5rem}}.degree-plans-list-page .page-prompt p{font-size:1rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);color:var(--color-text-secondary);text-align:center;margin:0}.degree-plans-list-page .page-error{padding:1.5rem;margin-bottom:2rem;background:rgba(230,70,59,.1);border:1px solid #e6463b;border-left-width:4px;border-radius:.75rem;animation:slideDown .3s ease-in-out ease-out 0s forwards}@media(max-width: 575px){.degree-plans-list-page .page-error{padding:1rem;margin-bottom:1.5rem}}.degree-plans-list-page .page-error p{font-size:.875rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);color:#e6463b;margin:0;font-weight:500}.degree-plans-list-page .cohort-data-table{margin-bottom:2rem;animation:slideUp .3s ease-in-out ease-out 0s forwards}@media(max-width: 575px){.degree-plans-list-page .cohort-data-table{margin-bottom:1.5rem}}.degree-plans-list-page .cohort-plan-detail-view{animation:slideInRight .3s ease-in-out ease-out 0s forwards}.degree-plans-list-page .loading-spinner-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--color-backdrop);display:flex;align-items:center;justify-content:center;z-index:400;animation:fadeIn .15s ease-in-out ease-in-out 0s forwards}.degree-plans-list-page .loading-spinner-overlay .spinner{animation:spin .6s linear infinite}@media(max-width: 767px){.degree-plans-list-page h1{font-size:1.5rem}}@media(max-width: 575px){.degree-plans-list-page h1{font-size:1.25rem}.degree-plans-list-page>p{font-size:.75rem}}.degree-plans-list-page__section{margin-bottom:3rem}@media(max-width: 575px){.degree-plans-list-page__section{margin-bottom:2rem}}.degree-plans-list-page__card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:.75rem;box-shadow:0px 2px 6px 0px rgba(0,0,0,.25);padding:1.5rem}@media(max-width: 575px){.degree-plans-list-page__card{padding:1rem}}.loading-container{display:flex;align-items:center;justify-content:center;min-height:100vh}.loading-spinner{font-size:1.25rem;color:#0abca7}.main-layout{display:grid;grid-template-columns:auto 1fr;grid-template-rows:1fr;min-height:100vh;width:100%;background-color:var(--color-background)}.main-layout__sidebar{grid-row:1/-1;position:sticky;top:0;height:100vh;overflow-y:auto;z-index:200}.main-layout__content{padding:2rem;overflow-y:auto;background-color:var(--color-background);color:var(--color-text-primary);max-width:1400px;margin:0 auto;width:100%}@media(max-width: 767px){.main-layout{grid-template-columns:260px 1fr}.main-layout .main-layout__content{padding:1.5rem 1rem}}@media(min-width: 768px){.main-layout{grid-template-columns:260px 1fr}.main-layout .main-layout__content{padding:2rem 1.5rem}}@media(min-width: 1200px){.main-layout .main-layout__content{padding:3rem 2rem}}.main-content{padding:2rem;overflow-y:auto;background-color:var(--color-background);color:var(--color-text-primary)}.main-content__title{font-size:2.25rem;font-weight:700;line-height:1.1;color:var(--color-text-primary);margin:0;margin-bottom:2rem;color:var(--color-primary)}.main-content__subtitle{font-size:1.25rem;font-weight:700;line-height:1.25;color:var(--color-text-primary);margin:0;margin-bottom:1rem;color:var(--color-text-secondary)}.main-content__section{margin-bottom:3rem}.main-content__section:last-child{margin-bottom:0}.main-content__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:1rem}@media(max-width: 767px){.main-content__header{flex-direction:column;align-items:flex-start}}.main-content__actions{display:flex;gap:1rem;align-items:center}@media(max-width: 767px){.main-content__actions{width:100%;flex-wrap:wrap}}@media(max-width: 767px){.main-content{padding:1.5rem 1rem}}@media(max-width: 575px){.main-content{padding:1rem}}.content-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));gap:1rem;gap:1.5rem}@media(max-width: 767px){.content-grid{grid-template-columns:1fr}}.content-grid--two-columns{display:grid;grid-template-columns:repeat(2, 1fr);gap:1.5rem}@media(max-width: 767px){.content-grid--two-columns{grid-template-columns:1fr}}.content-grid--three-columns{display:grid;grid-template-columns:repeat(3, 1fr);gap:1.5rem}@media(max-width: 991px){.content-grid--three-columns{grid-template-columns:repeat(2, 1fr)}}@media(max-width: 767px){.content-grid--three-columns{grid-template-columns:1fr}}.main-content__loading{display:flex;align-items:center;justify-content:center;min-height:300px;color:var(--color-text-secondary)}.main-content__empty{display:flex;align-items:center;justify-content:center;flex-direction:column;min-height:300px;padding:3rem;text-align:center;color:var(--color-text-secondary)}.main-content__empty-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.main-content__empty-message{font-size:1rem;font-weight:400;line-height:1.5;color:var(--color-text-primary);margin-bottom:1.5rem}
