@charset "UTF-8";.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font-family:var(--font-family-sans);font-weight:var(--font-weight-medium);text-decoration:none;white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none;transition:all var(--duration-button) var(--ease-out);outline:none;border:1px solid transparent;border-radius:var(--radius-button)}.btn:focus-visible{box-shadow:var(--shadow-button-focus)}.btn-xs{padding:var(--space-1) var(--space-2);font-size:var(--font-size-xs);line-height:var(--line-height-tight);min-height:1.5rem}.btn-sm{padding:var(--space-1_5) var(--space-3);font-size:var(--font-size-sm);line-height:var(--line-height-tight);min-height:2rem}.btn-md{padding:var(--space-2_5) var(--space-4);font-size:var(--font-size-sm);line-height:var(--line-height-normal);min-height:2.5rem}.btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--font-size-base);line-height:var(--line-height-normal);min-height:3rem}.btn-xl{padding:var(--space-4) var(--space-8);font-size:var(--font-size-lg);line-height:var(--line-height-normal);min-height:3.5rem}.btn-primary{background:var(--primary, #2563eb);color:var(--primary-contrast, #ffffff);border-color:var(--primary, #2563eb)}.btn-primary:hover:not(.btn-disabled):not(.btn-loading){background:#1d4ed8;border-color:#1d4ed8;transform:translateY(-1px)}.btn-primary:active:not(.btn-disabled):not(.btn-loading){background:#1d4ed8;border-color:#1d4ed8;transform:translateY(0);transition-duration:var(--duration-fast)}.btn-secondary{background:var(--color-surface-elevated);color:var(--color-text);border-color:var(--color-border);box-shadow:var(--shadow-button-rest)}.btn-secondary:hover:not(.btn-disabled):not(.btn-loading){background:var(--color-surface);border-color:var(--color-border-strong);box-shadow:var(--shadow-button-hover);transform:translateY(-1px)}.btn-secondary:active:not(.btn-disabled):not(.btn-loading){background:var(--color-surface-elevated);border-color:var(--color-border);box-shadow:var(--shadow-button-active);transform:translateY(0)}.btn-ghost{background:var(--color-white, #ffffff);color:var(--color-text-inverse);border-color:var(--color-border)}.btn-ghost:hover:not(.btn-disabled):not(.btn-loading){background:var(--color-white, #ffffff);color:var(--color-text-inverse);border-color:var(--color-border-strong, #cbd5e1);transform:translateY(-1px)}.btn-ghost:active:not(.btn-disabled):not(.btn-loading){background:var(--color-white, #ffffff);color:var(--color-text-inverse)}.btn-danger{background:var(--danger, #ef4444);color:var(--danger-contrast, #ffffff);border-color:var(--danger, #ef4444)}.btn-danger:hover:not(.btn-disabled):not(.btn-loading){background:#dc2626;border-color:#dc2626;transform:translateY(-1px)}.btn-danger:active:not(.btn-disabled):not(.btn-loading){background:#dc2626;border-color:#dc2626;transform:translateY(0)}.btn-danger-ghost{background:var(--color-white, #ffffff);color:var(--color-error-600);border-color:var(--color-border)}.btn-danger-ghost:hover:not(.btn-disabled):not(.btn-loading){background:var(--color-surface, #f8fafc);border-color:var(--color-border-strong, #cbd5e1);color:var(--color-error-700)}.btn-success{background:linear-gradient(135deg,var(--color-success-500),var(--color-success-600));color:var(--color-text-inverse);border-color:var(--color-success-600);box-shadow:var(--shadow-button-rest)}.btn-success:hover:not(.btn-disabled):not(.btn-loading){background:linear-gradient(135deg,var(--color-success-400),var(--color-success-500));border-color:var(--color-success-500);box-shadow:var(--shadow-button-hover);transform:translateY(-1px)}.btn-success:active:not(.btn-disabled):not(.btn-loading){background:linear-gradient(135deg,var(--color-success-600),var(--color-success-700));border-color:var(--color-success-700);box-shadow:var(--shadow-button-active);transform:translateY(0)}.btn-warning{background:linear-gradient(135deg,var(--color-warning-500),var(--color-warning-600));color:var(--color-text-inverse);border-color:var(--color-warning-600);box-shadow:var(--shadow-button-rest)}.btn-warning:hover:not(.btn-disabled):not(.btn-loading){background:linear-gradient(135deg,var(--color-warning-400),var(--color-warning-500));border-color:var(--color-warning-500);box-shadow:var(--shadow-button-hover);transform:translateY(-1px)}.btn-warning:active:not(.btn-disabled):not(.btn-loading){background:linear-gradient(135deg,var(--color-warning-600),var(--color-warning-700));border-color:var(--color-warning-700);box-shadow:var(--shadow-button-active);transform:translateY(0)}.btn-disabled{opacity:.5;cursor:not-allowed;pointer-events:none;transform:none!important;box-shadow:none!important}.btn-loading{cursor:wait;pointer-events:none}.btn-content-loading{opacity:.7}.btn-full-width{width:100%}.btn-icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.btn-icon svg{width:1em;height:1em}.btn-xs .btn-icon svg{width:.75rem;height:.75rem}.btn-sm .btn-icon svg{width:.875rem;height:.875rem}.btn-md .btn-icon svg{width:1rem;height:1rem}.btn-lg .btn-icon svg{width:1.125rem;height:1.125rem}.btn-xl .btn-icon svg{width:1.25rem;height:1.25rem}.btn-spinner{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:inline-flex;align-items:center;justify-content:center}.btn-spinner svg{width:1rem;height:1rem}.btn-xs .btn-spinner svg{width:.75rem;height:.75rem}.btn-sm .btn-spinner svg{width:.875rem;height:.875rem}.btn-lg .btn-spinner svg{width:1.125rem;height:1.125rem}.btn-xl .btn-spinner svg{width:1.25rem;height:1.25rem}.animate-spin{animation:spin 1s linear infinite}.btn-group{display:inline-flex;border-radius:var(--radius-button);box-shadow:var(--shadow-sm)}.btn-group .btn{border-radius:0;border-right-width:0;position:relative;z-index:1}.btn-group .btn:first-child{border-top-left-radius:var(--radius-button);border-bottom-left-radius:var(--radius-button)}.btn-group .btn:last-child{border-top-right-radius:var(--radius-button);border-bottom-right-radius:var(--radius-button);border-right-width:1px}.btn-group .btn:hover,.btn-group .btn:focus{z-index:2}@media (max-width: 768px){.btn-lg{padding:var(--space-2_5) var(--space-5);min-height:2.75rem}.btn-xl{padding:var(--space-3) var(--space-6);min-height:3rem}}.card{position:relative;display:flex;flex-direction:column;background:var(--color-card-background);border:1px solid var(--color-card-border);border-radius:var(--radius-card);overflow:hidden;transition:all var(--duration-card) var(--ease-out)}.card-default{background:var(--color-card-background);border-color:var(--color-card-border)}.card-elevated{background:var(--color-surface-elevated);border-color:var(--color-border-subtle)}.card-outlined{background:transparent;border-color:var(--color-border);border-width:2px}.card-filled{background:var(--color-surface);border-color:var(--color-border-strong)}.card-padding-none{padding:0}.card-padding-sm{padding:var(--space-card-padding-sm)}.card-padding-md{padding:var(--space-card-padding-md)}.card-padding-lg{padding:var(--space-card-padding-lg)}.card-padding-xl{padding:var(--space-6)}.card-shadow-none{box-shadow:none}.card-shadow-sm{box-shadow:var(--shadow-card-rest)}.card-shadow-md{box-shadow:var(--shadow-md)}.card-shadow-lg{box-shadow:var(--shadow-lg)}.card-hover:hover{background:var(--color-card-hover);border-color:var(--color-border-strong);box-shadow:var(--shadow-card-hover);transform:var(--transform-translate-up)}.card-interactive{cursor:pointer;-webkit-user-select:none;user-select:none}.card-interactive:hover{background:var(--color-card-hover);border-color:var(--color-border-strong);box-shadow:var(--shadow-card-hover);transform:var(--transform-translate-up)}.card-interactive:active{background:var(--color-card-background);border-color:var(--color-card-border);box-shadow:var(--shadow-card-active);transform:var(--transform-scale-down);transition-duration:var(--duration-fast)}.card-clickable{cursor:pointer;-webkit-user-select:none;user-select:none;border:1px solid var(--color-card-border);background:var(--color-card-background);text-align:left;font-family:inherit;font-size:inherit;color:inherit;outline:none}.card-clickable:focus-visible{box-shadow:var(--shadow-glow-primary)}.card-clickable:hover{background:var(--color-card-hover);border-color:var(--color-border-strong);box-shadow:var(--shadow-card-hover);transform:translateY(-1px)}.card-clickable:active{background:var(--color-card-background);border-color:var(--color-card-border);box-shadow:var(--shadow-card-active);transform:translateY(0)}.card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-4) var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-subtle)}.card-padding-none .card-header{padding:var(--space-4)}.card-padding-sm .card-header{padding:var(--space-3) var(--space-3) var(--space-2) var(--space-3)}.card-padding-lg .card-header{padding:var(--space-6) var(--space-6) var(--space-4) var(--space-6)}.card-padding-xl .card-header{padding:var(--space-8) var(--space-8) var(--space-6) var(--space-8)}.card-body{flex:1;padding:var(--space-4)}.card-padding-none .card-body{padding:var(--space-4)}.card-padding-sm .card-body{padding:var(--space-3)}.card-padding-lg .card-body{padding:var(--space-6)}.card-padding-xl .card-body{padding:var(--space-8)}.card-padding-sm .card-body,.card-padding-md .card-body,.card-padding-lg .card-body,.card-padding-xl .card-body{padding:0}.card-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding:var(--space-3) var(--space-4) var(--space-4) var(--space-4);border-top:1px solid var(--color-border-subtle);background:var(--color-surface)}.card-padding-none .card-footer{padding:var(--space-3) var(--space-4) var(--space-4) var(--space-4)}.card-padding-sm .card-footer{padding:var(--space-2) var(--space-3) var(--space-3) var(--space-3)}.card-padding-lg .card-footer{padding:var(--space-4) var(--space-6) var(--space-6) var(--space-6)}.card-padding-xl .card-footer{padding:var(--space-6) var(--space-8) var(--space-8) var(--space-8)}.card-title{margin:0;font-size:var(--text-heading-h4);font-weight:var(--font-weight-semibold);line-height:var(--line-height-snug);color:var(--color-text)}.card-description{margin:var(--space-2) 0 0 0;font-size:var(--text-body-sm);line-height:var(--line-height-normal);color:var(--color-text-secondary)}.card-media{position:relative;width:100%;overflow:hidden;background:var(--color-neutral-100)}[data-theme=dark] .card-media{background:var(--color-neutral-800)}.card-media-image{width:100%;height:100%;object-fit:cover;transition:var(--transition-transform)}.card-interactive .card-media-image,.card-clickable .card-media-image{transition:var(--transition-transform)}.card-interactive:hover .card-media-image,.card-clickable:hover .card-media-image{transform:scale(1.05)}.card-task{position:relative;overflow:visible}.card-task:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--color-primary-500);border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.card-task.card-task-completed{opacity:.7}.card-task.card-task-completed:before{background:var(--color-success-500)}.card-task.card-task-overdue:before{background:var(--color-error-500)}.card-task.card-task-warning:before{background:var(--color-warning-500)}.card-course{position:relative;background:linear-gradient(135deg,var(--color-surface-elevated),var(--color-surface))}.card-course .card-header{background:var(--color-white-alpha-5);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.card-kpi{text-align:center;background:linear-gradient(135deg,var(--color-surface-elevated),var(--color-surface))}.card-kpi .card-body{display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.card-kpi-value{font-size:var(--text-display-sm);font-weight:var(--font-weight-bold);line-height:var(--line-height-none);color:var(--color-primary-500)}.card-kpi-label{font-size:var(--text-body-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide)}@media (max-width: 768px){.card-padding-lg{padding:var(--space-4)}.card-padding-xl{padding:var(--space-5)}.card-header{padding:var(--space-3) var(--space-4) var(--space-2) var(--space-4)}.card-footer{padding:var(--space-2) var(--space-4) var(--space-3) var(--space-4);gap:var(--space-2)}}.card-grid{display:grid;gap:var(--space-grid-gap-md)}.card-grid-1{grid-template-columns:1fr}.card-grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.card-grid-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.card-grid-4{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}@media (max-width: 768px){.card-grid-2,.card-grid-3,.card-grid-4{grid-template-columns:1fr}}.input-wrapper{display:flex;flex-direction:column;gap:var(--space-1_5)}.input-wrapper-full-width{width:100%}.input-wrapper-disabled{opacity:.6;pointer-events:none}.input-label{font-size:var(--text-body-sm);font-weight:var(--font-weight-medium);color:var(--color-text);line-height:var(--line-height-tight);cursor:pointer}.input-required{color:var(--color-error-500);margin-left:var(--space-0_5)}.input-container{position:relative;display:flex;align-items:center}.input{width:100%;border:1px solid var(--color-input-border);border-radius:var(--radius-input);background:var(--color-input-background);color:var(--color-text);font-family:var(--font-family-sans);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal);transition:var(--transition-colors),var(--transition-shadow);outline:none}.input::placeholder{color:var(--color-text-placeholder)}.input:focus{border-color:var(--color-input-border-focus);background:var(--color-input-background-focus);box-shadow:var(--shadow-input-focus)}.input:hover:not(:focus):not(.input-disabled){border-color:var(--color-input-border-hover);background:var(--color-input-background-hover)}.input-sm{padding:var(--space-2) var(--space-3);font-size:var(--text-body-sm);min-height:2rem}.input-md{padding:var(--space-2_5) var(--space-3_5);font-size:var(--text-body-sm);min-height:2.5rem}.input-lg{padding:var(--space-3) var(--space-4);font-size:var(--text-body-base);min-height:3rem}.input-default{border-color:var(--color-input-border);background:var(--color-input-background)}.input-filled{border-color:transparent;background:var(--color-surface-elevated)}.input-filled:focus{border-color:var(--color-primary-500);background:var(--color-input-background)}.input-outlined{border-width:2px;border-color:var(--color-border);background:transparent}.input-outlined:focus{border-color:var(--color-primary-500);background:var(--color-input-background)}.input-error{border-color:var(--color-error-500);background:var(--color-error-alpha-5)}.input-error:focus{border-color:var(--color-error-500);box-shadow:var(--shadow-glow-error)}.input-success{border-color:var(--color-success-500);background:var(--color-success-alpha-5)}.input-success:focus{border-color:var(--color-success-500);box-shadow:var(--shadow-glow-success)}.input-warning{border-color:var(--color-warning-500);background:var(--color-warning-alpha-5)}.input-warning:focus{border-color:var(--color-warning-500);box-shadow:var(--shadow-glow-warning)}.input-disabled{opacity:.6;cursor:not-allowed;pointer-events:none}.input-readonly{background:var(--color-surface);cursor:default}.input-full-width{width:100%}.input-icon{position:absolute;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);pointer-events:none;z-index:1}.input-icon-left{left:var(--space-3)}.input-icon-right{right:var(--space-3)}.input-icon svg{width:1rem;height:1rem}.input-sm .input-icon svg{width:.875rem;height:.875rem}.input-lg .input-icon svg{width:1.125rem;height:1.125rem}.input-has-left-icon.input-sm{padding-left:2.25rem}.input-has-left-icon.input-md{padding-left:2.5rem}.input-has-left-icon.input-lg{padding-left:2.75rem}.input-has-right-icon.input-sm{padding-right:2.25rem}.input-has-right-icon.input-md{padding-right:2.5rem}.input-has-right-icon.input-lg{padding-right:2.75rem}.input-addon{display:flex;align-items:center;padding:0 var(--space-3);background:var(--color-surface);border:1px solid var(--color-input-border);color:var(--color-text-secondary);font-size:var(--text-body-sm);font-weight:var(--font-weight-medium);white-space:nowrap}.input-addon-left{border-right:none;border-radius:var(--radius-input) 0 0 var(--radius-input)}.input-addon-right,.input-has-left-addon{border-left:none;border-radius:0 var(--radius-input) var(--radius-input) 0}.input-has-right-addon{border-right:none;border-radius:var(--radius-input) 0 0 var(--radius-input)}.input-has-left-addon.input-has-right-addon{border-left:none;border-right:none;border-radius:0}.input-helper-text{font-size:var(--text-body-xs);color:var(--color-text-secondary);line-height:var(--line-height-tight)}.input-error-text{font-size:var(--text-body-xs);color:var(--color-error-500);line-height:var(--line-height-tight);display:flex;align-items:center;gap:var(--space-1)}.input-error-text:before{content:"⚠";font-size:.75rem}.input-search{padding-left:2.5rem}.input-search .input-icon-left{left:var(--space-3)}.input-password .input-icon-right{cursor:pointer;pointer-events:auto;color:var(--color-text-secondary);transition:var(--transition-colors)}.input-password .input-icon-right:hover{color:var(--color-text)}.input-number{text-align:right}.input-file{cursor:pointer}.input-file::file-selector-button{padding:var(--space-1_5) var(--space-3);margin-right:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface-elevated);color:var(--color-text);font-size:var(--text-body-xs);font-weight:var(--font-weight-medium);cursor:pointer;transition:var(--transition-colors)}.input-file::file-selector-button:hover{background:var(--color-surface);border-color:var(--color-border-strong)}.input-group{display:flex;align-items:stretch}.input-group .input{border-radius:0;border-right-width:0}.input-group .input:first-child{border-top-left-radius:var(--radius-input);border-bottom-left-radius:var(--radius-input)}.input-group .input:last-child{border-top-right-radius:var(--radius-input);border-bottom-right-radius:var(--radius-input);border-right-width:1px}.input-group .input:focus{z-index:1;border-right-width:1px}@media (max-width: 768px){.input-lg{padding:var(--space-2_5) var(--space-3_5);min-height:2.75rem}.input-addon{padding:0 var(--space-2);font-size:var(--text-body-xs)}}@media (prefers-reduced-motion: reduce){.input{transition:none}}@media (prefers-contrast: high){.input{border-width:2px}.input:focus{border-width:3px}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;background:var(--color-modal-overlay);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:modalOverlayFadeIn var(--duration-normal) var(--ease-out);display:flex;align-items:center;justify-content:center;padding:var(--space-4)}.modal{position:relative;background:var(--color-modal-background);border:1px solid var(--color-modal-border);border-radius:var(--radius-modal);box-shadow:var(--shadow-modal);animation:modalSlideIn var(--duration-modal) var(--ease-back);outline:none;max-height:calc(100vh - var(--space-8));overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.modal::-webkit-scrollbar{width:6px}.modal::-webkit-scrollbar-track{background:transparent}.modal::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}.modal::-webkit-scrollbar-thumb:hover{background:var(--color-border-strong)}.modal-xs{width:100%;max-width:320px}.modal-sm{width:100%;max-width:400px}.modal-md{width:100%;max-width:500px}.modal-lg{width:100%;max-width:700px}.modal-xl{width:100%;max-width:900px}.modal-full{width:calc(100vw - var(--space-8));height:calc(100vh - var(--space-8));max-width:none;max-height:none}.modal-centered{margin:auto}.modal-close-button{position:absolute;top:var(--space-4);right:var(--space-4);z-index:1;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;background:var(--color-surface-elevated);color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:var(--radius-full);cursor:pointer;transition:var(--transition-colors);outline:none}.modal-close-button:hover{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border-strong)}.modal-close-button:focus-visible{box-shadow:var(--shadow-glow-primary)}.modal-close-button svg{width:1rem;height:1rem}.modal-header{padding:var(--space-6) var(--space-6) var(--space-4) var(--space-6);border-bottom:1px solid var(--color-modal-border);background:var(--color-surface-elevated);border-radius:var(--radius-modal) var(--radius-modal) 0 0}.modal-xs .modal-header,.modal-sm .modal-header{padding:var(--space-4) var(--space-4) var(--space-3) var(--space-4)}.modal-body{padding:var(--space-6);flex:1;overflow-y:auto}.modal-xs .modal-body,.modal-sm .modal-body{padding:var(--space-4)}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6) var(--space-6) var(--space-6);border-top:1px solid var(--color-modal-border);background:var(--color-surface);border-radius:0 0 var(--radius-modal) var(--radius-modal)}.modal-xs .modal-footer,.modal-sm .modal-footer{padding:var(--space-3) var(--space-4) var(--space-4) var(--space-4);gap:var(--space-2)}.modal-title{margin:0;font-size:var(--text-heading-h3);font-weight:var(--font-weight-semibold);line-height:var(--line-height-snug);color:var(--color-text);padding-right:var(--space-8)}.modal-xs .modal-title,.modal-sm .modal-title{font-size:var(--text-heading-h4);padding-right:var(--space-6)}@keyframes modalOverlayFadeIn{0%{opacity:0;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px)}to{opacity:1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.9) translateY(-30px)}50%{opacity:1;transform:scale(1.02) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-confirmation .modal-body{text-align:center;padding:var(--space-8) var(--space-6)}.modal-confirmation .modal-title{color:var(--color-text);margin-bottom:var(--space-4)}.modal-confirmation .modal-icon{width:3rem;height:3rem;margin:0 auto var(--space-4);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full)}.modal-confirmation.modal-danger .modal-icon{background:var(--color-error-alpha-10);color:var(--color-error-500)}.modal-confirmation.modal-warning .modal-icon{background:var(--color-warning-alpha-10);color:var(--color-warning-500)}.modal-confirmation.modal-success .modal-icon{background:var(--color-success-alpha-10);color:var(--color-success-500)}.modal-confirmation.modal-info .modal-icon{background:var(--color-info-alpha-10);color:var(--color-info-500)}.modal-form .modal-body{padding:var(--space-6)}.modal-form .form-group{margin-bottom:var(--space-5)}.modal-form .form-group:last-child{margin-bottom:0}.modal-loading .modal-body{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);padding:var(--space-8) var(--space-6);text-align:center}.modal-loading .loading-spinner{width:2rem;height:2rem;border:2px solid var(--color-border);border-top:2px solid var(--color-primary-500);border-radius:var(--radius-full);animation:spin 1s linear infinite}@media (max-width: 768px){.modal-overlay{padding:var(--space-2);align-items:flex-end}.modal{width:100%!important;max-width:none!important;margin:0;border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-height:90vh;animation:modalSlideUp .3s ease-out}.modal-full{height:100vh;border-radius:0}.modal-header{border-radius:var(--radius-lg) var(--radius-lg) 0 0}.modal-footer{flex-direction:column-reverse;gap:var(--space-2)}.modal-footer .btn{width:100%}}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes modalOverlayFadeOut{0%{opacity:1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}to{opacity:0;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px)}}@keyframes modalSlideOut{0%{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(.95) translateY(-20px)}}@media (prefers-reduced-motion: reduce){.modal-overlay,.modal{animation:none}.modal-close-button,.modal{transition:none}}.modal[aria-modal=true]{isolation:isolate}@media (prefers-contrast: high){.modal,.modal-close-button{border-width:2px}}.form-field{display:flex;flex-direction:column;gap:var(--space-1_5);width:100%}.form-field--full-width{width:100%}.form-field--disabled{opacity:.6;pointer-events:none}.form-field__label{display:flex;align-items:center;gap:var(--space-1);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text);line-height:var(--line-height-tight);margin:0}.form-field__required{color:var(--color-error-500);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm)}.form-field__input-wrapper{position:relative;width:100%}.form-field__helper-text{font-size:var(--font-size-xs);color:var(--color-text-secondary);line-height:var(--line-height-tight);margin:0}.form-field--error .form-field__label{color:var(--color-error-400)}.form-field__error-text{display:flex;align-items:center;gap:var(--space-1_5);font-size:var(--font-size-xs);color:var(--color-error-400);line-height:var(--line-height-tight);margin:0}.form-field__error-icon{flex-shrink:0;color:var(--color-error-500)}@media (max-width: 768px){.form-field{gap:var(--space-1)}.form-field__label{font-size:var(--font-size-xs)}.form-field__helper-text,.form-field__error-text{font-size:var(--font-size-2xs)}}.textarea-wrapper{position:relative;width:100%}.textarea{width:100%;font-family:var(--font-family-sans);font-weight:var(--font-weight-normal);line-height:var(--line-height-relaxed);background-color:var(--color-input-background);color:var(--color-text);border:1px solid var(--color-input-border);border-radius:var(--radius-input);transition:var(--transition-colors),var(--transition-shadow);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.textarea::placeholder{color:var(--color-text-tertiary)}.textarea:focus{border-color:var(--color-input-border-focus);box-shadow:0 0 0 3px var(--color-primary-alpha-20)}.textarea-sm{padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);min-height:4rem}.textarea-md{padding:var(--space-2_5) var(--space-3_5);font-size:var(--font-size-sm);min-height:5rem}.textarea-lg{padding:var(--space-3) var(--space-4);font-size:var(--font-size-base);min-height:6rem}.textarea-filled{background-color:var(--color-surface-elevated);border-color:transparent}.textarea-filled:focus{background-color:var(--color-input-background);border-color:var(--color-input-border-focus)}.textarea-outlined{background-color:transparent;border-width:2px}.textarea-error{border-color:var(--color-error-500);background-color:var(--color-error-alpha-10)}.textarea-error:focus{border-color:var(--color-error-500);box-shadow:0 0 0 3px var(--color-error-alpha-20)}.textarea-success{border-color:var(--color-success-500);background-color:var(--color-success-alpha-10)}.textarea-success:focus{border-color:var(--color-success-500);box-shadow:0 0 0 3px var(--color-success-alpha-20)}.textarea-warning{border-color:var(--color-warning-500);background-color:var(--color-warning-alpha-10)}.textarea-warning:focus{border-color:var(--color-warning-500);box-shadow:0 0 0 3px var(--color-warning-alpha-20)}.textarea-disabled{opacity:.6;cursor:not-allowed;background-color:var(--color-surface);color:var(--color-text-tertiary)}.textarea-readonly{background-color:var(--color-surface);cursor:default}.textarea-resize-none{resize:none}.textarea-resize-both{resize:both}.textarea-resize-horizontal{resize:horizontal}.textarea-resize-vertical{resize:vertical}.textarea-resize-handle{position:absolute;bottom:4px;right:4px;width:16px;height:16px;color:var(--color-text-tertiary);pointer-events:none;opacity:.5;transition:opacity var(--duration-normal) var(--ease-out)}.textarea-wrapper:hover .textarea-resize-handle{opacity:.8}.textarea-resize-none+.textarea-resize-handle{display:none}.textarea-full-width{width:100%}@media (max-width: 768px){.textarea-lg{padding:var(--space-2_5) var(--space-3_5);font-size:var(--font-size-sm)}}.select-wrapper{position:relative;width:100%}.select{position:relative;display:flex;align-items:center;width:100%;font-family:var(--font-family-sans);font-weight:var(--font-weight-normal);background-color:var(--color-input-background);color:var(--color-text);border:1px solid var(--color-input-border);border-radius:var(--radius-input);cursor:pointer;-webkit-user-select:none;user-select:none;transition:var(--transition-colors),var(--transition-shadow);outline:none}.select:focus{border-color:var(--color-input-border-focus);box-shadow:0 0 0 3px var(--color-primary-alpha-20)}.select:hover:not(.select-disabled){border-color:var(--color-border-strong)}.select-sm{padding:var(--space-1_5) var(--space-3);font-size:var(--font-size-sm);min-height:2rem;gap:var(--space-2)}.select-md{padding:var(--space-2_5) var(--space-3_5);font-size:var(--font-size-sm);min-height:2.5rem;gap:var(--space-2)}.select-lg{padding:var(--space-3) var(--space-4);font-size:var(--font-size-base);min-height:3rem;gap:var(--space-3)}.select-filled{background-color:var(--color-surface-elevated);border-color:transparent}.select-filled:focus{background-color:var(--color-input-background);border-color:var(--color-input-border-focus)}.select-outlined{background-color:transparent;border-width:2px}.select-error{border-color:var(--color-error-500);background-color:var(--color-error-alpha-10)}.select-error:focus{border-color:var(--color-error-500);box-shadow:0 0 0 3px var(--color-error-alpha-20)}.select-success{border-color:var(--color-success-500);background-color:var(--color-success-alpha-10)}.select-success:focus{border-color:var(--color-success-500);box-shadow:0 0 0 3px var(--color-success-alpha-20)}.select-warning{border-color:var(--color-warning-500);background-color:var(--color-warning-alpha-10)}.select-warning:focus{border-color:var(--color-warning-500);box-shadow:0 0 0 3px var(--color-warning-alpha-20)}.select-disabled{opacity:.6;cursor:not-allowed;background-color:var(--color-surface);color:var(--color-text-tertiary)}.select-open{border-color:var(--color-input-border-focus);box-shadow:0 0 0 3px var(--color-primary-alpha-20)}.select-open .select__arrow{transform:rotate(180deg)}.select__icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--color-text-secondary)}.select__icon--left{margin-right:var(--space-2)}.select-has-left-icon .select__content{margin-left:0}.select__content{flex:1;display:flex;align-items:center;min-width:0}.select__value{color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.select__value:empty:before{content:attr(data-placeholder);color:var(--color-text-tertiary)}.select__search{width:100%;background:transparent;border:none;outline:none;color:var(--color-text);font-size:inherit;font-family:inherit}.select__search::placeholder{color:var(--color-text-tertiary)}.select__actions{display:flex;align-items:center;gap:var(--space-1);flex-shrink:0}.select__clear{display:flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;background:none;border:none;border-radius:var(--radius-sm);color:var(--color-text-tertiary);cursor:pointer;transition:var(--transition-colors)}.select__clear:hover{background-color:var(--color-error-alpha-10);color:var(--color-error-500)}.select__arrow{display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);transition:transform var(--duration-normal) var(--ease-out)}.select__dropdown{position:absolute;top:100%;left:0;right:0;z-index:var(--z-index-dropdown);margin-top:var(--space-1);background-color:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-input);box-shadow:var(--shadow-lg);max-height:200px;overflow:hidden;animation:dropdown-enter var(--duration-fast) var(--ease-out)}@keyframes dropdown-enter{0%{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.select__options{list-style:none;margin:0;padding:var(--space-1);max-height:200px;overflow-y:auto}.select__option{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-colors);color:var(--color-text);font-size:inherit}.select__option:hover,.select__option--highlighted{background-color:var(--color-primary-alpha-10);color:var(--color-text)}.select__option--selected{background-color:var(--color-primary-alpha-20);color:var(--color-primary-400);font-weight:var(--font-weight-medium)}.select__option--empty{color:var(--color-text-tertiary);cursor:default;font-style:italic}.select__option--empty:hover{background-color:transparent}.select__option-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.select__option-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.select__option-check{flex-shrink:0;color:var(--color-primary-500)}.select-full-width{width:100%}@media (max-width: 768px){.select-lg{padding:var(--space-2_5) var(--space-3_5);font-size:var(--font-size-sm);min-height:2.75rem}.select__dropdown,.select__options{max-height:160px}}.react-datepicker__navigation-icon:before,.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow{border-color:#ccc;border-style:solid;border-width:3px 3px 0 0;content:"";display:block;height:9px;position:absolute;top:6px;width:9px}.react-datepicker-wrapper{display:inline-block;padding:0;border:0}.react-datepicker{font-family:Helvetica Neue,helvetica,arial,sans-serif;font-size:.8rem;background-color:#fff;color:#000;border:1px solid #aeaeae;border-radius:.3rem;display:inline-block;position:relative;line-height:initial}.react-datepicker--time-only .react-datepicker__time-container{border-left:0}.react-datepicker--time-only .react-datepicker__time,.react-datepicker--time-only .react-datepicker__time-box{border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem}.react-datepicker-popper{z-index:1;line-height:0}.react-datepicker-popper .react-datepicker__triangle{stroke:#aeaeae}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle{fill:#f0f0f0;color:#f0f0f0}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle{fill:#fff;color:#fff}.react-datepicker__header{text-align:center;background-color:#f0f0f0;border-bottom:1px solid #aeaeae;border-top-left-radius:.3rem;padding:8px 0;position:relative}.react-datepicker__header--time{padding-bottom:8px;padding-left:5px;padding-right:5px}.react-datepicker__header--time:not(.react-datepicker__header--time--only){border-top-left-radius:0}.react-datepicker__header:not(.react-datepicker__header--has-time-select){border-top-right-radius:.3rem}.react-datepicker__year-dropdown-container--select,.react-datepicker__month-dropdown-container--select,.react-datepicker__month-year-dropdown-container--select,.react-datepicker__year-dropdown-container--scroll,.react-datepicker__month-dropdown-container--scroll,.react-datepicker__month-year-dropdown-container--scroll{display:inline-block;margin:0 15px}.react-datepicker__current-month,.react-datepicker-time__header,.react-datepicker-year-header{margin-top:0;color:#000;font-weight:700;font-size:.944rem}h2.react-datepicker__current-month{padding:0;margin:0}.react-datepicker-time__header{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.react-datepicker__navigation{align-items:center;background:none;display:flex;justify-content:center;text-align:center;cursor:pointer;position:absolute;top:2px;padding:0;border:none;z-index:1;height:32px;width:32px;text-indent:-999em;overflow:hidden}.react-datepicker__navigation--previous{left:2px}.react-datepicker__navigation--next{right:2px}.react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:85px}.react-datepicker__navigation--years{position:relative;top:0;display:block;margin-left:auto;margin-right:auto}.react-datepicker__navigation--years-previous{top:4px}.react-datepicker__navigation--years-upcoming{top:-4px}.react-datepicker__navigation:hover *:before{border-color:#a6a6a6}.react-datepicker__navigation-icon{position:relative;top:-1px;font-size:20px;width:0}.react-datepicker__navigation-icon--next{left:-2px}.react-datepicker__navigation-icon--next:before{transform:rotate(45deg);left:-7px}.react-datepicker__navigation-icon--previous{right:-2px}.react-datepicker__navigation-icon--previous:before{transform:rotate(225deg);right:-7px}.react-datepicker__month-container{float:left}.react-datepicker__year{margin:.4rem;text-align:center}.react-datepicker__year-wrapper{display:flex;flex-wrap:wrap;max-width:180px}.react-datepicker__year .react-datepicker__year-text{display:inline-block;width:4rem;margin:2px}.react-datepicker__month{margin:.4rem;text-align:center}.react-datepicker__month .react-datepicker__month-text,.react-datepicker__month .react-datepicker__quarter-text{display:inline-block;width:4rem;margin:2px}.react-datepicker__input-time-container{clear:both;width:100%;float:left;margin:5px 0 10px 15px;text-align:left}.react-datepicker__input-time-container .react-datepicker-time__caption,.react-datepicker__input-time-container .react-datepicker-time__input-container{display:inline-block}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input{display:inline-block;margin-left:10px}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input{width:auto}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-inner-spin-button,.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]{-moz-appearance:textfield}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__delimiter{margin-left:5px;display:inline-block}.react-datepicker__time-container{float:right;border-left:1px solid #aeaeae;width:85px}.react-datepicker__time-container--with-today-button{display:inline;border:1px solid #aeaeae;border-radius:.3rem;position:absolute;right:-87px;top:0}.react-datepicker__time-container .react-datepicker__time{position:relative;background:#fff;border-bottom-right-radius:.3rem}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box{width:85px;overflow-x:hidden;margin:0 auto;text-align:center;border-bottom-right-radius:.3rem}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list{list-style:none;margin:0;height:calc(195px + .85rem);overflow-y:scroll;padding-right:0;padding-left:0;width:100%;box-sizing:content-box}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item{height:30px;padding:5px 10px;white-space:nowrap}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item:hover{cursor:pointer;background-color:#f0f0f0}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected{background-color:#216ba5;color:#fff;font-weight:700}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected:hover{background-color:#216ba5}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled{color:#ccc}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled:hover{cursor:default;background-color:transparent}.react-datepicker__week-number{color:#ccc;display:inline-block;width:1.7rem;line-height:1.7rem;text-align:center;margin:.166rem}.react-datepicker__week-number.react-datepicker__week-number--clickable{cursor:pointer}.react-datepicker__week-number.react-datepicker__week-number--clickable:not(.react-datepicker__week-number--selected):hover{border-radius:.3rem;background-color:#f0f0f0}.react-datepicker__week-number--selected{border-radius:.3rem;background-color:#216ba5;color:#fff}.react-datepicker__week-number--selected:hover{background-color:#1d5d90}.react-datepicker__day-names{white-space:nowrap;margin-bottom:-8px}.react-datepicker__week{white-space:nowrap}.react-datepicker__day-name,.react-datepicker__day,.react-datepicker__time-name{color:#000;display:inline-block;width:1.7rem;line-height:1.7rem;text-align:center;margin:.166rem}.react-datepicker__day,.react-datepicker__month-text,.react-datepicker__quarter-text,.react-datepicker__year-text{cursor:pointer}.react-datepicker__day:not([aria-disabled=true]):hover,.react-datepicker__month-text:not([aria-disabled=true]):hover,.react-datepicker__quarter-text:not([aria-disabled=true]):hover,.react-datepicker__year-text:not([aria-disabled=true]):hover{border-radius:.3rem;background-color:#f0f0f0}.react-datepicker__day--today,.react-datepicker__month-text--today,.react-datepicker__quarter-text--today,.react-datepicker__year-text--today{font-weight:700}.react-datepicker__day--highlighted,.react-datepicker__month-text--highlighted,.react-datepicker__quarter-text--highlighted,.react-datepicker__year-text--highlighted{border-radius:.3rem;background-color:#3dcc4a;color:#fff}.react-datepicker__day--highlighted:not([aria-disabled=true]):hover,.react-datepicker__month-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__year-text--highlighted:not([aria-disabled=true]):hover{background-color:#32be3f}.react-datepicker__day--highlighted-custom-1,.react-datepicker__month-text--highlighted-custom-1,.react-datepicker__quarter-text--highlighted-custom-1,.react-datepicker__year-text--highlighted-custom-1{color:#f0f}.react-datepicker__day--highlighted-custom-2,.react-datepicker__month-text--highlighted-custom-2,.react-datepicker__quarter-text--highlighted-custom-2,.react-datepicker__year-text--highlighted-custom-2{color:green}.react-datepicker__day--holidays,.react-datepicker__month-text--holidays,.react-datepicker__quarter-text--holidays,.react-datepicker__year-text--holidays{position:relative;border-radius:.3rem;background-color:#ff6803;color:#fff}.react-datepicker__day--holidays .overlay,.react-datepicker__month-text--holidays .overlay,.react-datepicker__quarter-text--holidays .overlay,.react-datepicker__year-text--holidays .overlay{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:4px;border-radius:4px;white-space:nowrap;visibility:hidden;opacity:0;transition:visibility 0s,opacity .3s ease-in-out}.react-datepicker__day--holidays:not([aria-disabled=true]):hover,.react-datepicker__month-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__year-text--holidays:not([aria-disabled=true]):hover{background-color:#cf5300}.react-datepicker__day--holidays:hover .overlay,.react-datepicker__month-text--holidays:hover .overlay,.react-datepicker__quarter-text--holidays:hover .overlay,.react-datepicker__year-text--holidays:hover .overlay{visibility:visible;opacity:1}.react-datepicker__day--selected,.react-datepicker__day--in-selecting-range,.react-datepicker__day--in-range,.react-datepicker__month-text--selected,.react-datepicker__month-text--in-selecting-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--selected,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--selected,.react-datepicker__year-text--in-selecting-range,.react-datepicker__year-text--in-range{border-radius:.3rem;background-color:#216ba5;color:#fff}.react-datepicker__day--selected:not([aria-disabled=true]):hover,.react-datepicker__day--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__day--in-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-range:not([aria-disabled=true]):hover{background-color:#1d5d90}.react-datepicker__day--keyboard-selected,.react-datepicker__month-text--keyboard-selected,.react-datepicker__quarter-text--keyboard-selected,.react-datepicker__year-text--keyboard-selected{border-radius:.3rem;background-color:#bad9f1;color:#000}.react-datepicker__day--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--keyboard-selected:not([aria-disabled=true]):hover{background-color:#1d5d90}.react-datepicker__day--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__month-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__quarter-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__year-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range){background-color:#216ba580}.react-datepicker__month--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range){background-color:#f0f0f0;color:#000}.react-datepicker__day--disabled,.react-datepicker__month-text--disabled,.react-datepicker__quarter-text--disabled,.react-datepicker__year-text--disabled{cursor:default;color:#ccc}.react-datepicker__day--disabled .overlay,.react-datepicker__month-text--disabled .overlay,.react-datepicker__quarter-text--disabled .overlay,.react-datepicker__year-text--disabled .overlay{position:absolute;bottom:70%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:4px;border-radius:4px;white-space:nowrap;visibility:hidden;opacity:0;transition:visibility 0s,opacity .3s ease-in-out}.react-datepicker__input-container{position:relative;display:inline-block;width:100%}.react-datepicker__input-container .react-datepicker__calendar-icon{position:absolute;padding:.5rem;box-sizing:content-box}.react-datepicker__view-calendar-icon input{padding:6px 10px 5px 25px}.react-datepicker__year-read-view,.react-datepicker__month-read-view,.react-datepicker__month-year-read-view{border:1px solid transparent;border-radius:.3rem;position:relative}.react-datepicker__year-read-view:hover,.react-datepicker__month-read-view:hover,.react-datepicker__month-year-read-view:hover{cursor:pointer}.react-datepicker__year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__year-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__month-read-view--down-arrow{border-top-color:#b3b3b3}.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow{transform:rotate(135deg);right:-16px;top:0}.react-datepicker__year-dropdown,.react-datepicker__month-dropdown,.react-datepicker__month-year-dropdown{background-color:#f0f0f0;position:absolute;width:50%;left:25%;top:30px;z-index:1;text-align:center;border-radius:.3rem;border:1px solid #aeaeae}.react-datepicker__year-dropdown:hover,.react-datepicker__month-dropdown:hover,.react-datepicker__month-year-dropdown:hover{cursor:pointer}.react-datepicker__year-dropdown--scrollable,.react-datepicker__month-dropdown--scrollable,.react-datepicker__month-year-dropdown--scrollable{height:150px;overflow-y:scroll}.react-datepicker__year-option,.react-datepicker__month-option,.react-datepicker__month-year-option{line-height:20px;width:100%;display:block;margin-left:auto;margin-right:auto}.react-datepicker__year-option:first-of-type,.react-datepicker__month-option:first-of-type,.react-datepicker__month-year-option:first-of-type{border-top-left-radius:.3rem;border-top-right-radius:.3rem}.react-datepicker__year-option:last-of-type,.react-datepicker__month-option:last-of-type,.react-datepicker__month-year-option:last-of-type{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem}.react-datepicker__year-option:hover,.react-datepicker__month-option:hover,.react-datepicker__month-year-option:hover{background-color:#ccc}.react-datepicker__year-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-upcoming{border-bottom-color:#b3b3b3}.react-datepicker__year-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-previous{border-top-color:#b3b3b3}.react-datepicker__year-option--selected,.react-datepicker__month-option--selected,.react-datepicker__month-year-option--selected{position:absolute;left:15px}.react-datepicker__close-icon{cursor:pointer;background-color:transparent;border:0;outline:0;padding:0 6px 0 0;position:absolute;top:0;right:0;height:100%;display:table-cell;vertical-align:middle}.react-datepicker__close-icon:after{cursor:pointer;background-color:#216ba5;color:#fff;border-radius:50%;height:16px;width:16px;padding:2px;font-size:12px;line-height:1;text-align:center;display:table-cell;vertical-align:middle;content:"×"}.react-datepicker__close-icon--disabled{cursor:default}.react-datepicker__close-icon--disabled:after{cursor:default;background-color:#ccc}.react-datepicker__today-button{background:#f0f0f0;border-top:1px solid #aeaeae;cursor:pointer;text-align:center;font-weight:700;padding:5px 0;clear:left}.react-datepicker__portal{position:fixed;width:100vw;height:100vh;background-color:#000c;left:0;top:0;justify-content:center;align-items:center;display:flex;z-index:2147483647}.react-datepicker__portal .react-datepicker__day-name,.react-datepicker__portal .react-datepicker__day,.react-datepicker__portal .react-datepicker__time-name{width:3rem;line-height:3rem}@media (max-width: 400px),(max-height: 550px){.react-datepicker__portal .react-datepicker__day-name,.react-datepicker__portal .react-datepicker__day,.react-datepicker__portal .react-datepicker__time-name{width:2rem;line-height:2rem}}.react-datepicker__portal .react-datepicker__current-month,.react-datepicker__portal .react-datepicker-time__header{font-size:1.44rem}.react-datepicker__children-container{width:13.8rem;margin:.4rem;padding-right:.2rem;padding-left:.2rem;height:auto}.react-datepicker__aria-live{position:absolute;clip-path:circle(0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;width:1px;white-space:nowrap}.react-datepicker__calendar-icon{width:1em;height:1em;vertical-align:-.125em}.date-picker-wrapper{position:relative;width:100%}.date-input{position:relative;display:flex;align-items:center;width:100%;font-family:var(--font-family-sans);font-weight:var(--font-weight-normal);background-color:var(--color-input-background);color:var(--color-text);border:1px solid var(--color-input-border);border-radius:var(--radius-input);cursor:pointer;transition:var(--transition-colors),var(--transition-shadow)}.date-input:hover:not(.date-input--disabled){border-color:var(--color-border-strong)}.date-input:focus-within{border-color:var(--color-input-border-focus);box-shadow:0 0 0 3px var(--color-primary-alpha-20)}.date-input-sm{padding:var(--space-1_5) var(--space-3);font-size:var(--font-size-sm);min-height:2rem;gap:var(--space-2)}.date-input-md{padding:var(--space-2_5) var(--space-3_5);font-size:var(--font-size-sm);min-height:2.5rem;gap:var(--space-2)}.date-input-lg{padding:var(--space-3) var(--space-4);font-size:var(--font-size-base);min-height:3rem;gap:var(--space-3)}.date-input--error{border-color:var(--color-error-500);background-color:var(--color-error-alpha-10)}.date-input--error:focus-within{border-color:var(--color-error-500);box-shadow:0 0 0 3px var(--color-error-alpha-20)}.date-input--disabled{opacity:.6;cursor:not-allowed;background-color:var(--color-surface);color:var(--color-text-tertiary)}.date-input__icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--color-text-secondary)}.date-input__field{flex:1;background:transparent;border:none;outline:none;color:var(--color-text);font-size:inherit;font-family:inherit;cursor:pointer;min-width:0}.date-input__field::placeholder{color:var(--color-text-tertiary)}.date-input--disabled .date-input__field{cursor:not-allowed}.date-input__actions{display:flex;align-items:center;gap:var(--space-1);flex-shrink:0}.date-input__clear{display:flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;background:none;border:none;border-radius:var(--radius-sm);color:var(--color-text-tertiary);cursor:pointer;transition:var(--transition-colors)}.date-input__clear:hover{background-color:var(--color-error-alpha-10);color:var(--color-error-500)}.date-input__calendar-icon{display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary)}.date-picker-popper{z-index:var(--z-index-dropdown)!important}.date-picker-calendar{font-family:var(--font-family-sans)!important;background-color:var(--color-surface-elevated)!important;border:1px solid var(--color-border)!important;border-radius:var(--radius-input)!important;box-shadow:var(--shadow-lg)!important}.react-datepicker__day,.react-datepicker__day--selected,.react-datepicker__day--keyboard-selected,.react-datepicker__day--today{cursor:pointer!important;pointer-events:auto!important}.react-datepicker__header{background-color:var(--color-surface)!important;border-bottom:1px solid var(--color-border)!important;border-top-left-radius:var(--radius-input)!important;border-top-right-radius:var(--radius-input)!important}.react-datepicker__current-month{color:var(--color-text)!important;font-weight:var(--font-weight-semibold)!important;font-size:var(--font-size-sm)!important}.react-datepicker__day-names{border-bottom:1px solid var(--color-border-subtle)!important}.react-datepicker__day-name{color:var(--color-text-secondary)!important;font-weight:var(--font-weight-medium)!important;font-size:var(--font-size-xs)!important}.react-datepicker__day{color:var(--color-text)!important;font-size:var(--font-size-sm)!important;border-radius:var(--radius-md)!important;transition:var(--transition-colors)!important;cursor:pointer!important;pointer-events:auto!important}.react-datepicker__day:hover{background-color:var(--color-primary-alpha-10)!important;color:var(--color-text)!important}.react-datepicker__day--selected{background-color:var(--color-primary-500)!important;color:var(--color-text-inverse)!important}.react-datepicker__day--selected:hover{background-color:var(--color-primary-400)!important}.react-datepicker__day--keyboard-selected{background-color:var(--color-primary-alpha-20)!important;color:var(--color-text)!important}.react-datepicker__day--today{background-color:var(--color-warning-alpha-10)!important;color:var(--color-warning-600)!important;font-weight:var(--font-weight-semibold)!important}.react-datepicker__day--disabled{color:var(--color-text-tertiary)!important;cursor:not-allowed!important;pointer-events:none!important}.react-datepicker__day--disabled:hover{background-color:transparent!important}.react-datepicker__day--outside-month{color:var(--color-text-tertiary)!important;cursor:pointer!important;pointer-events:auto!important}.react-datepicker__navigation{border:none!important;background:none!important;color:var(--color-text-secondary)!important;transition:var(--transition-colors)!important}.react-datepicker__navigation:hover{color:var(--color-text)!important}.react-datepicker__navigation--previous{border-right-color:var(--color-text-secondary)!important}.react-datepicker__navigation--next{border-left-color:var(--color-text-secondary)!important}.react-datepicker__navigation:hover .react-datepicker__navigation--previous{border-right-color:var(--color-text)!important}.react-datepicker__navigation:hover .react-datepicker__navigation--next{border-left-color:var(--color-text)!important}.react-datepicker__time-container{border-left:1px solid var(--color-border)!important}.react-datepicker__time-container .react-datepicker__time{background:var(--color-surface-elevated)!important}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box{width:100%!important}.react-datepicker__time-list-item{color:var(--color-text)!important;font-size:var(--font-size-sm)!important;transition:var(--transition-colors)!important}.react-datepicker__time-list-item:hover{background-color:var(--color-primary-alpha-10)!important}.react-datepicker__time-list-item--selected{background-color:var(--color-primary-500)!important;color:var(--color-text-inverse)!important}@media (max-width: 768px){.date-input-lg{padding:var(--space-2_5) var(--space-3_5);font-size:var(--font-size-sm);min-height:2.75rem}.react-datepicker{font-size:var(--font-size-sm)!important}.react-datepicker__day{width:2rem!important;line-height:2rem!important}}.custom-date-picker{position:relative;width:100%}.custom-date-input{position:relative;display:flex;align-items:center;width:100%;font-family:var(--font-family-sans);font-weight:var(--font-weight-normal);background-color:var(--color-input-background);color:var(--color-text);border:1px solid var(--color-input-border);border-radius:var(--radius-input);cursor:pointer;transition:var(--transition-colors),var(--transition-shadow)}.custom-date-input:hover:not(.custom-date-input--disabled){border-color:var(--color-border-strong)}.custom-date-input:focus-within{border-color:var(--color-input-border-focus);box-shadow:0 0 0 3px var(--color-primary-alpha-20)}.custom-date-input-sm{padding:var(--space-1_5) var(--space-3);font-size:var(--font-size-sm);min-height:2rem;gap:var(--space-2)}.custom-date-input-md{padding:var(--space-2_5) var(--space-3_5);font-size:var(--font-size-sm);min-height:2.5rem;gap:var(--space-2)}.custom-date-input-lg{padding:var(--space-3) var(--space-4);font-size:var(--font-size-base);min-height:3rem;gap:var(--space-3)}.custom-date-input--error{border-color:var(--color-error-500);background-color:var(--color-error-alpha-10)}.custom-date-input--error:focus-within{border-color:var(--color-error-500);box-shadow:0 0 0 3px var(--color-error-alpha-20)}.custom-date-input--disabled{opacity:.6;cursor:not-allowed;background-color:var(--color-surface);color:var(--color-text-tertiary)}.custom-date-input__icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--color-text-secondary)}.custom-date-input__field{flex:1;border:none;outline:none;color:var(--color-text)!important;font-size:inherit;font-family:inherit;cursor:pointer;min-width:0;font-weight:var(--font-weight-normal)}.custom-date-input__field[readonly]{color:var(--color-text)!important}.custom-date-input__field::placeholder{color:red}.custom-date-input--disabled .custom-date-input__field{cursor:not-allowed}.custom-date-input__calendar-icon{display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary)}.custom-calendar{position:absolute;top:100%;left:0;right:0;z-index:1000;margin-top:.25rem;background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:12px;box-shadow:var(--shadow-lg);padding:1rem;min-width:280px}.custom-calendar__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--color-border)}.custom-calendar__nav{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease}.custom-calendar__nav:hover{background:var(--color-surface-hover);color:var(--color-text);border-color:var(--color-border-strong)}.custom-calendar__selectors{display:flex;gap:.5rem}.custom-calendar__select{background:var(--color-input-background);border:1px solid var(--color-input-border);border-radius:6px;color:var(--color-text);padding:.375rem .5rem;font-size:.875rem;cursor:pointer;transition:all .2s ease}.custom-calendar__select:hover{background:var(--color-surface-hover);border-color:var(--color-border-strong)}.custom-calendar__select:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 2px var(--color-primary-alpha-20)}.custom-calendar__weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:.25rem;margin-bottom:.5rem}.custom-calendar__weekday{text-align:center;font-size:.75rem;font-weight:600;color:var(--color-text-secondary);padding:.5rem 0}.custom-calendar__days{display:grid;grid-template-columns:repeat(7,1fr);gap:.25rem}.custom-calendar__day{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:none;border:none;border-radius:6px;color:var(--color-text);font-size:.875rem;cursor:pointer;transition:all .2s ease;position:relative}.custom-calendar__day:hover{background:var(--color-surface-hover)}.custom-calendar__day--outside{color:var(--color-text-tertiary);opacity:.5}.custom-calendar__day--selected{background:var(--color-primary-500)!important;color:#fff;font-weight:600}.custom-calendar__day--today{background:#ffc10733;color:#ffc107;font-weight:600}.custom-calendar__day--today.custom-calendar__day--selected{background:var(--color-primary-500)!important;color:#fff}@media (max-width: 768px){.custom-calendar{min-width:260px;padding:.75rem}.custom-calendar__day{width:28px;height:28px;font-size:.8125rem}.custom-calendar__select{font-size:.8125rem;padding:.25rem .375rem}}@media (max-width: 480px){.custom-calendar{left:-1rem;right:-1rem;min-width:auto}}.skeleton{display:block;background:var(--color-surface-elevated);border-radius:var(--radius-sm);position:relative;overflow:hidden;width:100%;height:1rem}.skeleton-text{height:1em;border-radius:var(--radius-sm)}.skeleton-circular{border-radius:var(--radius-full);width:2.5rem;height:2.5rem}.skeleton-rectangular{border-radius:0}.skeleton-rounded{border-radius:var(--radius-md)}.skeleton-pulse{animation:skeletonPulse 1.5s ease-in-out infinite}.skeleton-wave{background:linear-gradient(90deg,var(--color-surface-elevated) 0%,var(--color-surface) 50%,var(--color-surface-elevated) 100%);background-size:200px 100%;animation:skeletonWave 1.5s ease-in-out infinite}@keyframes skeletonWave{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}.skeleton-text-block{display:flex;flex-direction:column;gap:var(--space-2)}.skeleton-card{padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-card-background)}.skeleton-card-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}.skeleton-card-title{flex:1;display:flex;flex-direction:column;gap:var(--space-1_5)}.skeleton-card-body{margin-bottom:var(--space-4)}.skeleton-card-footer{display:flex;justify-content:flex-end;gap:var(--space-2)}.skeleton-table{width:100%;border-collapse:collapse}.skeleton-table-header,.skeleton-table-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:var(--space-4);padding:var(--space-3) 0;border-bottom:1px solid var(--color-border)}.skeleton-table-header{border-bottom:2px solid var(--color-border);margin-bottom:var(--space-2)}.skeleton-table-row:last-child{border-bottom:none}.skeleton-task-card{padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-card-background);display:flex;flex-direction:column;gap:var(--space-3)}.skeleton-task-header{display:flex;justify-content:space-between;align-items:flex-start}.skeleton-task-title{flex:1;margin-right:var(--space-2)}.skeleton-task-meta{display:flex;justify-content:space-between;align-items:center}.skeleton-task-badges{display:flex;gap:var(--space-2)}.skeleton-course-card{padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-card-background);position:relative}.skeleton-course-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--color-surface-elevated);border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.skeleton-course-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3)}.skeleton-course-progress{margin:var(--space-3) 0}.skeleton-course-stats{display:flex;justify-content:space-between}.skeleton-kpi-card{padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-card-background);text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}@media (max-width: 768px){.skeleton-card{padding:var(--space-3)}.skeleton-card-header,.skeleton-card-body{margin-bottom:var(--space-3)}.skeleton-table-header,.skeleton-table-row{grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:var(--space-2)}}@media (prefers-reduced-motion: reduce){.skeleton-pulse,.skeleton-wave{animation:none}.skeleton{opacity:.7}}.skeleton-xs{height:.75rem}.skeleton-sm{height:.875rem}.skeleton-md{height:1rem}.skeleton-lg{height:1.125rem}.skeleton-xl{height:1.25rem}.skeleton-w-1\/4{width:25%}.skeleton-w-1\/2{width:50%}.skeleton-w-3\/4{width:75%}.skeleton-w-full{width:100%}.skeleton-mb-1{margin-bottom:var(--space-1)}.skeleton-mb-2{margin-bottom:var(--space-2)}.skeleton-mb-3{margin-bottom:var(--space-3)}.skeleton-mb-4{margin-bottom:var(--space-4)}.skeleton-delay-1{animation-delay:.1s}.skeleton-delay-2{animation-delay:.2s}.skeleton-delay-3{animation-delay:.3s}.skeleton-delay-4{animation-delay:.4s}.skeleton-delay-5{animation-delay:.5s}.lazy-load{position:relative;width:100%}.lazy-image{position:relative;display:block;overflow:hidden;border-radius:var(--radius-md);background:var(--color-surface-elevated)}.lazy-image-element{width:100%;height:auto;display:block;opacity:0;transition:opacity var(--duration-normal) var(--ease-out)}.lazy-image-element.loaded{opacity:1}.lazy-image-element.error{opacity:0}.lazy-image-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--color-surface-elevated);border-radius:inherit}.lazy-image-error{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--color-surface-elevated);color:var(--color-text-secondary);font-size:var(--text-sm);border-radius:inherit;border:1px dashed var(--color-border)}.lazy-list{position:relative;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-card-background)}.lazy-list::-webkit-scrollbar{width:8px}.lazy-list::-webkit-scrollbar-track{background:var(--color-surface);border-radius:var(--radius-sm)}.lazy-list::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-sm);transition:background var(--duration-fast) var(--ease-out)}.lazy-list::-webkit-scrollbar-thumb:hover{background:var(--color-border-subtle)}.lazy-list-item{display:flex;align-items:center;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-subtle);transition:background var(--duration-fast) var(--ease-out)}.lazy-list-item:last-child{border-bottom:none}.lazy-list-item:hover{background:var(--color-surface-elevated)}.lazy-load-skeleton{animation:skeletonPulse 1.5s ease-in-out infinite}@keyframes skeletonPulse{0%,to{opacity:1}50%{opacity:.6}}.lazy-load-fade-in{opacity:0;transform:translateY(20px);transition:opacity var(--duration-normal) var(--ease-out),transform var(--duration-normal) var(--ease-out)}.lazy-load-fade-in.in-view{opacity:1;transform:translateY(0)}.lazy-load-slide-up{opacity:0;transform:translateY(40px);transition:opacity var(--duration-slow) var(--ease-out),transform var(--duration-slow) var(--ease-out)}.lazy-load-slide-up.in-view{opacity:1;transform:translateY(0)}.lazy-load-scale{opacity:0;transform:scale(.9);transition:opacity var(--duration-normal) var(--ease-out),transform var(--duration-normal) var(--ease-out)}.lazy-load-scale.in-view{opacity:1;transform:scale(1)}@media (max-width: 768px){.lazy-list-item{padding:var(--space-2_5) var(--space-3)}.lazy-image-placeholder,.lazy-image-error{font-size:var(--text-xs)}}@media (prefers-reduced-motion: reduce){.lazy-image-element,.lazy-load-fade-in,.lazy-load-slide-up,.lazy-load-scale{transition:none}.lazy-load-skeleton{animation:none;opacity:.7}}.lazy-load-gpu{transform:translateZ(0);will-change:transform,opacity}.lazy-load-gpu-auto{will-change:auto}.lazy-load-rounded{border-radius:var(--radius-md)}.lazy-load-rounded-lg{border-radius:var(--radius-lg)}.lazy-load-rounded-xl{border-radius:var(--radius-xl)}.lazy-load-rounded-full{border-radius:var(--radius-full)}.lazy-load-shadow{box-shadow:var(--shadow-sm)}.lazy-load-shadow-md{box-shadow:var(--shadow-md)}.lazy-load-shadow-lg{box-shadow:var(--shadow-lg)}.lazy-card{background:var(--color-card-background);border:1px solid var(--color-border);border-radius:var(--radius-card);padding:var(--space-4);transition:all var(--duration-fast) var(--ease-out)}.lazy-card:hover{border-color:var(--color-border-subtle);box-shadow:var(--shadow-md);transform:var(--transform-translate-up)}.lazy-avatar{width:40px;height:40px;border-radius:var(--radius-full);overflow:hidden;background:var(--color-surface-elevated);display:flex;align-items:center;justify-content:center}.lazy-avatar-sm{width:32px;height:32px}.lazy-avatar-lg{width:48px;height:48px}.lazy-avatar-xl{width:64px;height:64px}.lazy-grid{display:grid;gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}@media (max-width: 640px){.lazy-grid{grid-template-columns:1fr;gap:var(--space-3)}}.lazy-masonry{column-count:3;column-gap:var(--space-4);column-fill:balance}@media (max-width: 1024px){.lazy-masonry{column-count:2}}@media (max-width: 640px){.lazy-masonry{column-count:1}}.lazy-masonry-item{break-inside:avoid;margin-bottom:var(--space-4);display:inline-block;width:100%}.kpi-card{display:flex;flex-direction:column;padding:var(--space-3);border-radius:var(--radius-lg);background:var(--color-card-background);border:1px solid var(--color-border);transition:all var(--duration-fast) var(--ease-out);position:relative;overflow:hidden;min-height:64px;cursor:default}.kpi-card:hover{border-color:var(--color-border-subtle);box-shadow:var(--shadow-md);transform:var(--transform-translate-up)}.kpi-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.kpi-card-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);background:var(--color-surface-elevated);color:var(--color-text-secondary);flex-shrink:0}.kpi-trend{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-weight-semibold)}.kpi-trend-up{background:var(--color-success-alpha-10);color:var(--color-success-600);border:1px solid var(--color-success-200)}.kpi-trend-down{background:var(--color-error-alpha-10);color:var(--color-error-600);border:1px solid var(--color-error-200)}.kpi-trend-neutral{background:var(--color-surface-elevated);color:var(--color-text-secondary);border:1px solid var(--color-border)}.kpi-trend-icon{font-size:var(--text-sm);line-height:1}.kpi-card-content{display:flex;flex-direction:column;gap:var(--space-2);height:100%}.kpi-card-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.kpi-card-value{font-size:var(--text-2xl);font-weight:var(--font-weight-bold);color:var(--color-text);line-height:var(--line-height-none);margin:0}.kpi-card-label{font-size:var(--text-2xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;line-height:var(--line-height-tight)}.kpi-card-default{border-color:var(--color-border)}.kpi-card-default .kpi-card-icon{background:var(--color-surface-elevated);color:var(--color-text-secondary)}.kpi-card-primary{background:linear-gradient(135deg,var(--color-primary-alpha-5),var(--color-primary-alpha-10));border-color:var(--color-primary-200)}.kpi-card-primary .kpi-card-icon{background:var(--color-primary-100);color:var(--color-primary-600)}.kpi-card-primary .kpi-card-value{color:var(--color-primary-600)}.kpi-card-primary:hover{border-color:var(--color-primary-300);box-shadow:var(--shadow-md),0 0 0 1px var(--color-primary-alpha-20)}.kpi-card-success{background:linear-gradient(135deg,var(--color-success-alpha-5),var(--color-success-alpha-10));border-color:var(--color-success-200)}.kpi-card-success .kpi-card-icon{background:var(--color-success-100);color:var(--color-success-600)}.kpi-card-success .kpi-card-value{color:var(--color-success-600)}.kpi-card-success:hover{border-color:var(--color-success-300);box-shadow:var(--shadow-md),0 0 0 1px var(--color-success-alpha-20)}.kpi-card-warning{background:linear-gradient(135deg,var(--color-warning-alpha-5),var(--color-warning-alpha-10));border-color:var(--color-warning-200)}.kpi-card-warning .kpi-card-icon{background:var(--color-warning-100);color:var(--color-warning-600)}.kpi-card-warning .kpi-card-value{color:var(--color-warning-600)}.kpi-card-warning:hover{border-color:var(--color-warning-300);box-shadow:var(--shadow-md),0 0 0 1px var(--color-warning-alpha-20)}.kpi-card-error{background:linear-gradient(135deg,var(--color-error-alpha-5),var(--color-error-alpha-10));border-color:var(--color-error-200)}.kpi-card-error .kpi-card-icon{background:var(--color-error-100);color:var(--color-error-600)}.kpi-card-error .kpi-card-value{color:var(--color-error-600)}.kpi-card-error:hover{border-color:var(--color-error-300);box-shadow:var(--shadow-md),0 0 0 1px var(--color-error-alpha-20)}.kpi-card-info{background:linear-gradient(135deg,var(--color-info-alpha-5),var(--color-info-alpha-10));border-color:var(--color-info-200)}.kpi-card-info .kpi-card-icon{background:var(--color-info-100);color:var(--color-info-600)}.kpi-card-info .kpi-card-value{color:var(--color-info-600)}.kpi-card-info:hover{border-color:var(--color-info-300);box-shadow:var(--shadow-md),0 0 0 1px var(--color-info-alpha-20)}@media (max-width: 768px){.kpi-card{padding:var(--space-3)}.kpi-card-value{font-size:var(--text-lg)}.kpi-card-label{font-size:var(--text-2xs)}.kpi-card-icon{width:36px;height:36px}}.kpi-card{animation:kpiCardFadeIn var(--duration-normal) var(--ease-out)}@keyframes kpiCardFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.kpi-card:nth-child(1){animation-delay:0ms}.kpi-card:nth-child(2){animation-delay:.1s}.kpi-card:nth-child(3){animation-delay:.2s}.kpi-card:nth-child(4){animation-delay:.3s}@media (prefers-reduced-motion: reduce){.kpi-card{animation:none;transition:none}.kpi-card:hover{transform:none}}@media (prefers-color-scheme: dark){.kpi-card-primary{background:linear-gradient(135deg,var(--color-primary-alpha-10),var(--color-primary-alpha-15))}.kpi-card-success{background:linear-gradient(135deg,var(--color-success-alpha-10),var(--color-success-alpha-15))}.kpi-card-warning{background:linear-gradient(135deg,var(--color-warning-alpha-10),var(--color-warning-alpha-15))}.kpi-card-error{background:linear-gradient(135deg,var(--color-error-alpha-10),var(--color-error-alpha-15))}.kpi-card-info{background:linear-gradient(135deg,var(--color-info-alpha-10),var(--color-info-alpha-15))}}.kpi-card-compact{padding:var(--space-3)}.kpi-card-large{padding:var(--space-6)}.kpi-card-no-hover:hover{transform:none;box-shadow:var(--shadow-sm)}.kpi-card-clickable{cursor:pointer}.kpi-card-clickable:active{transform:var(--transform-scale-down)}.toggle-wrapper{display:inline-block}.toggle-container{display:flex;align-items:flex-start;gap:var(--space-3);cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-container.toggle-disabled{cursor:not-allowed;opacity:.6}.toggle-input{position:absolute;opacity:0;pointer-events:none}.toggle-track{position:relative;border-radius:var(--radius-full);background:var(--color-surface-elevated);border:2px solid var(--color-border);transition:all var(--duration-fast) var(--ease-out);flex-shrink:0}.toggle-track:hover{border-color:var(--color-border-subtle)}.toggle-track.toggle-checked{background:var(--color-primary-500);border-color:var(--color-primary-500)}.toggle-thumb{position:absolute;top:2px;left:2px;background:var(--color-white);border-radius:var(--radius-full);transition:all var(--duration-fast) var(--ease-out);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}.toggle-checked .toggle-thumb{background:var(--color-white);box-shadow:var(--shadow-md)}.toggle-sm{width:36px;height:20px}.toggle-sm .toggle-thumb{width:16px;height:16px}.toggle-sm.toggle-checked .toggle-thumb{transform:translate(16px)}.toggle-md{width:44px;height:24px}.toggle-md .toggle-thumb{width:20px;height:20px}.toggle-md.toggle-checked .toggle-thumb{transform:translate(20px)}.toggle-lg{width:52px;height:28px}.toggle-lg .toggle-thumb{width:24px;height:24px}.toggle-lg.toggle-checked .toggle-thumb{transform:translate(24px)}.toggle-default.toggle-checked{background:var(--color-primary-500);border-color:var(--color-primary-500)}.toggle-default.toggle-checked:hover{background:var(--color-primary-600);border-color:var(--color-primary-600)}.toggle-primary.toggle-checked{background:var(--color-primary-500);border-color:var(--color-primary-500)}.toggle-primary.toggle-checked:hover{background:var(--color-primary-600);border-color:var(--color-primary-600)}.toggle-success.toggle-checked{background:var(--color-success-500);border-color:var(--color-success-500)}.toggle-success.toggle-checked:hover{background:var(--color-success-600);border-color:var(--color-success-600)}.toggle-warning.toggle-checked{background:var(--color-warning-500);border-color:var(--color-warning-500)}.toggle-warning.toggle-checked:hover{background:var(--color-warning-600);border-color:var(--color-warning-600)}.toggle-check-icon{width:12px;height:12px;color:var(--color-primary-500);opacity:0;transform:scale(.8);transition:all var(--duration-fast) var(--ease-out)}.toggle-checked .toggle-check-icon{opacity:1;transform:scale(1)}.toggle-content{display:flex;flex-direction:column;gap:var(--space-1);flex:1}.toggle-label{font-size:var(--text-sm);font-weight:var(--font-weight-medium);color:var(--color-text);line-height:1.4}.toggle-description{font-size:var(--text-xs);color:var(--color-text-secondary);line-height:1.4}.toggle-input:focus+.toggle-track{outline:2px solid var(--color-primary-alpha-50);outline-offset:2px}.toggle-input:focus+.toggle-track.toggle-checked{outline-color:var(--color-primary-alpha-50)}.toggle-disabled .toggle-track{background:var(--color-surface);border-color:var(--color-border-subtle);cursor:not-allowed}.toggle-disabled .toggle-track:hover{border-color:var(--color-border-subtle)}.toggle-disabled .toggle-thumb{background:var(--color-surface-elevated);box-shadow:none}.toggle-disabled .toggle-label,.toggle-disabled .toggle-description{color:var(--color-text-disabled)}.toggle-loading .toggle-thumb{animation:toggleLoading 1s ease-in-out infinite}@keyframes toggleLoading{0%,to{transform:scale(1)}50%{transform:scale(.9)}}@media (max-width: 768px){.toggle-container{gap:var(--space-2)}.toggle-label{font-size:var(--text-xs)}.toggle-description{font-size:var(--text-2xs)}}@media (prefers-reduced-motion: reduce){.toggle-track,.toggle-thumb,.toggle-check-icon{transition:none}.toggle-loading .toggle-thumb{animation:none}}@media (prefers-contrast: high){.toggle-track{border-width:3px}.toggle-checked{background:var(--color-text);border-color:var(--color-text)}.toggle-thumb{background:var(--color-background);border:2px solid var(--color-text)}}.toggle-inline{display:inline-flex;align-items:center}.toggle-reverse{flex-direction:row-reverse}.toggle-no-label .toggle-content{display:none}.chip{display:inline-flex;align-items:center;gap:var(--space-1_5);border-radius:var(--radius-full);font-weight:var(--font-weight-medium);line-height:1;transition:all var(--duration-fast) var(--ease-out);border:1px solid transparent;white-space:nowrap;-webkit-user-select:none;user-select:none;position:relative;overflow:hidden}.chip:focus{outline:2px solid var(--color-primary-alpha-50);outline-offset:2px}.chip-xs{padding:var(--space-1) var(--space-2);font-size:var(--text-2xs);height:20px}.chip-sm{padding:var(--space-1_5) var(--space-2_5);font-size:var(--text-xs);height:24px}.chip-md{padding:var(--space-2) var(--space-3);font-size:var(--text-sm);height:32px}.chip-lg{padding:var(--space-2_5) var(--space-4);font-size:var(--text-base);height:40px}.chip-default{background:var(--color-surface-elevated);color:var(--color-text-secondary);border-color:var(--color-border)}.chip-default:hover{background:var(--color-surface);border-color:var(--color-border-subtle)}.chip-default.chip-selected{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border-strong)}.chip-primary{background:var(--color-primary-500);color:var(--color-white);border-color:var(--color-primary-500)}.chip-primary:hover{background:var(--color-primary-600);border-color:var(--color-primary-600);box-shadow:var(--shadow-sm)}.chip-primary.chip-selected{background:var(--color-primary-600);box-shadow:var(--shadow-md)}.chip-secondary{background:var(--color-secondary-100);color:var(--color-secondary-700);border-color:var(--color-secondary-200)}.chip-secondary:hover{background:var(--color-secondary-200);border-color:var(--color-secondary-300)}.chip-success{background:var(--color-success-100);color:var(--color-success-700);border-color:var(--color-success-200)}.chip-success:hover{background:var(--color-success-200);border-color:var(--color-success-300)}.chip-warning{background:var(--color-warning-100);color:var(--color-warning-700);border-color:var(--color-warning-200)}.chip-warning:hover{background:var(--color-warning-200);border-color:var(--color-warning-300)}.chip-error{background:var(--color-error-100);color:var(--color-error-700);border-color:var(--color-error-200)}.chip-error:hover{background:var(--color-error-200);border-color:var(--color-error-300)}.chip-outline{background:var(--color-surface-elevated);color:var(--color-text);border-color:var(--color-border)}.chip-outline:hover{background:var(--color-surface);border-color:var(--color-border-subtle);color:var(--color-text);box-shadow:var(--shadow-sm)}.chip-outline.chip-selected{background:var(--color-primary-500);color:var(--color-white);border-color:var(--color-primary-500);box-shadow:var(--shadow-md)}.chip-clickable{cursor:pointer}.chip-clickable:active{transform:var(--transform-scale-down)}.chip-selected{position:relative}.chip-selected:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(45deg,transparent,var(--color-white-alpha-10),transparent);pointer-events:none}.chip-disabled{opacity:.6;cursor:not-allowed;pointer-events:none}.chip-content{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}.chip-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.chip-xs .chip-icon{width:12px;height:12px}.chip-sm .chip-icon{width:14px;height:14px}.chip-md .chip-icon{width:16px;height:16px}.chip-lg .chip-icon{width:18px;height:18px}.chip-remove{display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:inherit;opacity:.7;transition:all var(--duration-fast) var(--ease-out);border-radius:var(--radius-full);flex-shrink:0;margin-left:var(--space-1);padding:var(--space-0_5)}.chip-remove:hover{opacity:1;background:var(--color-white-alpha-20)}.chip-remove:active{transform:scale(.9)}.chip-xs .chip-remove{width:16px;height:16px}.chip-sm .chip-remove{width:18px;height:18px}.chip-md .chip-remove{width:20px;height:20px}.chip-lg .chip-remove{width:22px;height:22px}.chip[style*=--chip-color]{background:var(--chip-color, var(--color-surface-elevated));color:var(--color-white);border-color:var(--chip-color, var(--color-border))}.chip[style*=--chip-color]:hover{filter:brightness(1.1)}.chip{animation:chipFadeIn var(--duration-fast) var(--ease-out)}@keyframes chipFadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.chip:nth-child(1){animation-delay:0ms}.chip:nth-child(2){animation-delay:50ms}.chip:nth-child(3){animation-delay:.1s}.chip:nth-child(4){animation-delay:.15s}.chip:nth-child(5){animation-delay:.2s}.chip-group{display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:center}.chip-group-vertical{flex-direction:column;align-items:stretch}.chip-group-compact{gap:var(--space-1)}@media (max-width: 768px){.chip-md{padding:var(--space-1_5) var(--space-2_5);font-size:var(--text-xs);height:28px}.chip-lg{padding:var(--space-2) var(--space-3);font-size:var(--text-sm);height:32px}.chip-group{gap:var(--space-1_5)}}@media (prefers-reduced-motion: reduce){.chip{animation:none;transition:none}.chip-clickable:active,.chip-remove:active{transform:none}}@media (prefers-contrast: high){.chip{border-width:2px}.chip-outline{border-width:2px;border-style:solid}.chip-selected{border-width:3px}}.chip-no-animation{animation:none}.chip-full-width{width:100%;justify-content:center}.chip-compact{padding-left:var(--space-2);padding-right:var(--space-2)}.chip-rounded{border-radius:var(--radius-md)}.chip-square{border-radius:var(--radius-sm)}.course-card{position:relative;transition:all var(--duration-fast) var(--ease-out);cursor:pointer}.course-card:hover{transform:var(--transform-translate-up);box-shadow:var(--shadow-lg)}.course-card-active{border-color:var(--color-primary-300);box-shadow:var(--shadow-md),0 0 0 1px var(--color-primary-alpha-20)}.course-card-active .course-card-indicator{box-shadow:0 0 8px var(--color-primary-alpha-50)}.course-card-indicator{position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:var(--radius-sm) 0 0 var(--radius-sm);transition:all var(--duration-fast) var(--ease-out)}.course-card-content{padding:0;display:flex;flex-direction:column;gap:0}.course-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-2)}.course-card-title{flex:1;min-width:0}.course-name{font-size:var(--text-base);font-weight:var(--font-weight-semibold);color:var(--color-text);line-height:1.3;margin:0 0 var(--space-0_5) 0;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical}.course-code{font-size:var(--text-2xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.course-card-menu{position:relative;flex-shrink:0}.course-menu-trigger{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;color:var(--color-text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.course-menu-trigger:hover{background:var(--color-surface-elevated);color:var(--color-text)}.course-menu-trigger:active{transform:scale(.95)}.course-menu-dropdown{position:absolute;top:100%;right:0;z-index:50;min-width:140px;background:var(--color-card-background);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:var(--space-1);animation:dropdownFadeIn var(--duration-fast) var(--ease-out)}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-4px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.course-menu-item{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);border:none;background:transparent;color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-weight-medium);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);text-align:left}.course-menu-item:hover{background:var(--color-surface-elevated)}.course-menu-item-danger{color:var(--color-error-600)}.course-menu-item-danger:hover{background:var(--color-error-alpha-10);color:var(--color-error-700)}.course-card-progress{display:flex;flex-direction:column;gap:var(--space-1_5)}.progress-header{display:flex;align-items:center;justify-content:space-between}.progress-label{font-size:var(--text-2xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.progress-percentage{font-size:var(--text-sm);font-weight:var(--font-weight-bold);color:var(--color-text)}.progress-bar{position:relative;width:100%;height:6px;background:var(--color-surface-elevated);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;border-radius:var(--radius-full);transition:width var(--duration-slow) var(--ease-out);position:relative}.progress-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:progressShimmer 2s ease-in-out infinite}@keyframes progressShimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.course-badges-row{display:flex;align-items:center;gap:var(--space-1);margin-top:var(--space-1_5);flex-wrap:nowrap}.course-card-badges{display:flex;flex-wrap:wrap;gap:var(--space-2)}.course-badge{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);font-size:var(--text-1xs);font-weight:var(--font-medium);line-height:1}.course-badge-compact{padding:2px 6px!important;font-size:11px!important;gap:2px!important;font-weight:var(--font-weight-normal)!important;line-height:1.1!important;border-radius:4px!important;text-transform:lowercase!important;letter-spacing:0!important;opacity:.8!important}.course-badge-error{background:var(--color-error-alpha-10);color:var(--color-error-600);border:1px solid var(--color-error-200)}.course-badge-warning{background:var(--color-warning-alpha-10);color:var(--color-warning-600);border:1px solid var(--color-warning-200)}.course-badge-today{background:var(--color-primary-alpha-10);color:var(--color-primary-600);border:1px solid var(--color-primary-200);font-weight:var(--font-semibold)}.course-badge-success{background:var(--color-success-alpha-10);color:var(--color-success-600);border:1px solid var(--color-success-200)}.course-badge-info{background:var(--color-info-alpha-10);color:var(--color-info-600);border:1px solid var(--color-info-200)}@media (max-width: 768px){.course-card{min-height:140px}.course-card-content{padding:0;gap:0;min-height:100px}.course-name{font-size:var(--text-base);margin-bottom:var(--space-1_5);line-height:1.4}.course-code{font-size:var(--text-sm);font-weight:var(--font-weight-bold);opacity:1;display:block;margin-top:var(--space-0_5)}.course-card-header{gap:var(--space-3);margin-bottom:var(--space-1)}.progress-percentage{font-size:var(--text-sm)}.progress-label{font-size:var(--text-xs)}.course-badge{padding:var(--space-1) var(--space-2);font-size:var(--text-xs)}}.course-card{animation:courseCardFadeIn var(--duration-normal) var(--ease-out)}@keyframes courseCardFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.course-card:nth-child(1){animation-delay:0ms}.course-card:nth-child(2){animation-delay:.1s}.course-card:nth-child(3){animation-delay:.2s}.course-card:nth-child(4){animation-delay:.3s}.course-card:nth-child(5){animation-delay:.4s}@media (prefers-reduced-motion: reduce){.course-card,.course-menu-dropdown,.progress-fill{animation:none;transition:none}.course-card:hover,.course-menu-trigger:active{transform:none}.progress-fill:after{animation:none}}.course-card:focus{outline:2px solid var(--color-primary-alpha-50);outline-offset:2px}.course-menu-trigger:focus{outline:2px solid var(--color-primary-alpha-50);outline-offset:2px}.course-menu-item:focus{outline:2px solid var(--color-primary-alpha-50);outline-offset:-2px}.course-card-compact .course-card-content{padding:var(--space-3);gap:var(--space-2)}.course-card-large .course-card-content{padding:var(--space-6);gap:var(--space-4)}.course-card-no-hover:hover{transform:none;box-shadow:var(--shadow-sm)}.course-card-disabled{opacity:.6;cursor:not-allowed;pointer-events:none}@media (max-width: 1400px){.header{padding:8px calc(var(--gutter) - 2px)}.header-left,.header-center,.header-right{gap:12px}.header-title{display:none}.semester-selector{padding:6px 8px;font-size:.9rem}.header-center .view-tab span{display:none}.header-center .view-tabs{overflow-x:auto;scrollbar-width:thin}.header-center .view-tabs .view-tab{padding:6px 8px}}@media (max-width: 1200px){.action-buttons .action-btn.secondary{display:none}.action-btn.primary{padding:8px 10px}.header-center .view-tabs{gap:6px}.header-center .view-tabs .view-tab{padding:6px 8px;font-size:.9rem}}:root{--text: var(--color-text);--muted: var(--color-text-secondary);--accent: var(--color-primary-500);--danger: var(--color-error-500);--warn: var(--color-warning-500);--radius: var(--radius-2xl);--shadow: var(--shadow-lg);--gutter: var(--space-responsive-md)}html,body,#root{height:100%}body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Inter,Helvetica Neue,Arial;background:radial-gradient(1200px 800px at 10% -20%,#142042 0%,transparent 60%),radial-gradient(1000px 600px at 100% 0%,#0f1a38 0%,transparent 70%),linear-gradient(180deg,#0a0f1e,#0a0f1e 60%);color:var(--text)}.header{display:grid;grid-template-columns:auto 1fr auto;align-items:center;padding:10px var(--gutter);column-gap:12px;position:sticky;top:0;z-index:1200;background:#0a0f1eb3;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid rgba(255,255,255,.07)}.header-left,.header-center,.header-right{min-width:0}.header-center{overflow:visible}.header-left{display:flex;align-items:center;gap:20px}.header-center{display:flex;justify-content:space-between;align-items:center;gap:12px}.header-center .view-toggle-host{flex:1 1 auto;min-width:0}.header-center .expandable-search-host{flex:0 0 auto}.header .view-toggle-container.hidden{opacity:0!important;transform:translate(-20px)!important;pointer-events:none!important}.header-right{display:flex;align-items:center;justify-content:flex-end;gap:12px}.subscription-status-header{display:flex;align-items:center;margin-right:12px}@media (max-width: 768px){.subscription-status-header{display:none}}.action-label{display:inline}.overflow-actions{display:none}.dropdown-menu{z-index:2000}.header-center .view-tabs{white-space:nowrap;max-width:100%}.header-center .view-tabs{-webkit-mask-image:linear-gradient(to right,rgba(0,0,0,1) 90%,rgba(0,0,0,0));mask-image:linear-gradient(to right,#000 90%,#0000)}.header-title{font-size:22px;font-weight:700;letter-spacing:-.5px}.view-tab span{display:none}@media (min-width: 768px){.view-tab span{display:inline;margin-left:8px}}.menu-button{display:none;background:none;border:none;color:var(--muted);cursor:pointer;padding:4px}.menu-button:hover{color:var(--text)}h1{font-size:clamp(22px,2.2vw,30px);margin:0;letter-spacing:.3px}.subtitle{color:var(--muted);font-size:13px}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid rgba(255,255,255,.07);background:linear-gradient(180deg,#1b2341,#121a33);color:var(--text);padding:10px 14px;border-radius:12px;cursor:pointer;box-shadow:var(--shadow);transition:transform .08s ease,border-color .2s ease,background .2s ease}.btn:hover{transform:translateY(-1px);border-color:#ffffff29}.btn:active{transform:translateY(0)}.btn.ghost{background:transparent}.btn.primary{background:linear-gradient(180deg,#1c7bdc,#0a60bd);border-color:#ffffff24}.main{width:min(1600px,100%);margin:24px auto;padding:0 var(--gutter);display:grid;grid-template-columns:290px 1fr;gap:clamp(12px,2vw,20px)}@media (max-width: 900px){.main{grid-template-columns:1fr}.aside.desktop-sidebar{display:none}.menu-button{display:block}}@media (max-width: 1024px){.header{padding:8px calc(var(--gutter) - 4px)}.action-btn.secondary .action-label{display:none}.header-center{justify-content:flex-start}.header-center .view-tabs{overflow-x:auto;scrollbar-width:thin}.header-center .view-tabs::-webkit-scrollbar{height:6px}.overflow-actions{display:block}.action-btn{padding:8px 10px}.header-right .action-buttons{display:none}.semester-selector span{max-width:120px;display:inline-block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header.search-takeover .header-center{display:flex;align-items:center;gap:8px}.header.search-takeover .view-toggle-container,.header.search-takeover .view-toggle-host{display:none!important}.header.search-takeover .expandable-search-host{flex:1 1 auto;min-width:0}.header.search-takeover .expandable-search{flex:1 1 auto}}@media (max-width: 768px){.header{padding:6px calc(var(--gutter) - 6px);background:#0a0f1ee6;-webkit-backdrop-filter:none;backdrop-filter:none}.action-label{display:none}.header-center{gap:8px}.header .expandable-search-host{flex:1 1 auto;min-width:0}.header.search-takeover{grid-template-columns:1fr}.header.search-takeover .header-left,.header.search-takeover .header-right{display:none!important}.header.search-takeover .header-center{grid-column:1 / -1}.action-buttons .action-btn.secondary{display:none}.header-left,.header-right,.header-center{gap:10px}.action-btn{padding:6px 8px}.menu-button{display:block}.header-center .view-tabs{overflow-x:auto;scroll-snap-type:x mandatory}.header-center .view-tabs>*{scroll-snap-align:start}}@media (max-width: 640px){.header-title{display:none}}.aside{background:linear-gradient(180deg,#0e1429,#0c1326);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);box-shadow:var(--shadow)}.aside-inner{padding:24px}.main-title{font-size:20px;font-weight:700;margin-bottom:24px}.kpi-section{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.kpi-card b{font-size:28px;line-height:1;color:var(--text)}.kpi-card span{font-size:13px;color:var(--muted)}.kpi-card span{font-size:12px;color:var(--muted)}.sidebar-section{background:#ffffff05;border:1px solid rgba(255,255,255,.05);border-radius:12px;padding:16px;margin-bottom:16px}.field label{font-size:14px;font-weight:500;color:#d1d5db;margin:0 0 8px}.chip-group .chip{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);font-size:13px;padding:6px 12px;border-radius:8px;cursor:pointer}.chip-group .chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}.chip-group .view-tab:hover{color:var(--text);background:#ffffff08}.view-tabs{display:flex;align-items:center;gap:8px}.view-tab.active{background:#ffffff0d;color:var(--text);font-weight:600;border-color:#ffffff1a}.clear-filters-btn{background:none;border:none;color:var(--accent);font-size:12px;cursor:pointer;text-align:right;width:100%;padding:4px}.add-course-btn{background:var(--accent);color:#fff;border:none;border-radius:50%;width:24px;height:24px;font-size:16px;cursor:pointer}.course-list{display:flex;flex-direction:column;gap:12px}.task-card{display:flex;flex-direction:column;background:#1a2341;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:12px;cursor:pointer;transition:all .2s ease}.task-card:hover{background:#1c2647;border-color:#ffffff1f}.task-card.done{opacity:.5}.task-card.done .task-title{text-decoration:line-through;color:var(--muted)}.task-content{display:flex;flex-direction:column;gap:12px;padding:14px 14px 14px 18px}.task-info{cursor:pointer}.task-title{font-weight:500;margin:0 0 6px}.task-meta{display:flex;align-items:center;gap:8px}.course-badge{font-size:12px;font-weight:500;padding:3px 8px;border-radius:6px;background-color:var(--course-color);color:#fff}.due-date-badge{font-size:12px;color:var(--muted);background:#ffffff0d;padding:3px 8px;border-radius:6px}.due-date-badge.overdue{color:#ff8a8a;background:#ff8a8a1a}.task-actions{display:flex;align-items:center;gap:8px}.edit-btn{background:none;border:none;color:var(--muted);cursor:pointer;padding:4px}.edit-btn:hover{color:var(--text)}.panel{background:linear-gradient(180deg,#0e1429,#0c1326);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;padding:var(--gutter)}.tabs{display:flex;gap:6px}.tab{padding:8px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.18);background:#0f1a38;cursor:pointer;font-size:13px;color:var(--text);font-weight:600}.tab:hover{border-color:#ffffff52}.tab.active{background:linear-gradient(180deg,#2a3a68,#16264b);border-color:#49b6ff73;box-shadow:0 0 0 2px #49b6ff2e inset;color:#fff}.cols{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(320px,1fr);gap:16px;align-content:start;overflow-x:auto;overscroll-behavior-x:contain;scroll-snap-type:x mandatory;scrollbar-gutter:stable both-edges}.cols::-webkit-scrollbar{height:10px}.cols::-webkit-scrollbar-thumb{background:#ffffff2e;border-radius:999px}[data-theme=light] .cols::-webkit-scrollbar-thumb{background:#0a0f1e38}.list-view table{width:100%;border-collapse:collapse}.list-view th,.list-view td{padding:12px 16px;text-align:left;border-bottom:1px solid rgba(255,255,255,.08)}.list-view th{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.list-view td{font-size:14px}.list-view .truncate-cell{max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.col{background:linear-gradient(180deg,#0b1226,#0a1020);border:1px solid rgba(255,255,255,.06);border-radius:16px;display:flex;flex-direction:column;min-height:130px;scroll-snap-align:start}.col h3{font-size:13px;letter-spacing:.3px;font-weight:600;margin:0;padding:12px;color:var(--muted);border-bottom:1px solid rgba(255,255,255,.06)}.list{padding:10px;display:flex;flex-direction:column;gap:8px}.card{position:relative;background:linear-gradient(180deg,#0f1630,#0a1124);border:1px solid rgba(255,255,255,.08);border-radius:14px;display:flex;flex-direction:column;overflow:hidden}.card-main{padding:10px 12px;flex:1}.card.done{opacity:.55}.badge{font-size:11px;border:1px solid rgba(255,255,255,.16);padding:2px 8px;border-radius:999px}.title{font-size:14px;line-height:1.35}.meta{font-size:12px;color:var(--muted)}.due{font-size:12px;padding:2px 6px;border-radius:8px;background:#0a1328;border:1px solid rgba(255,255,255,.08)}.legend{display:flex;flex-wrap:wrap;gap:8px;padding:10px 16px;border-top:1px solid rgba(255,255,255,.06);background:linear-gradient(180deg,#0a1121,#0a0f1e)}.legend span{display:inline-flex;align-items:center;gap:8px;font-size:12px;color:var(--muted)}.search{display:flex;gap:8px;align-items:center}input[type=text],input[type=date],select,textarea{width:100%;background:#1f2937;border:1px solid #374151;color:var(--text);padding:8px;border-radius:8px;outline:none;transition:border-color .2s,box-shadow .2s}input[type=text]::placeholder,input[type=date]::placeholder,textarea::placeholder{color:#6b7280}input[type=date]{position:relative}input[type=text][placeholder=dd-mm-yyyy]::-webkit-calendar-picker-indicator,input[type=date]::-webkit-calendar-picker-indicator{position:absolute;right:16px;top:50%;transform:translateY(-50%);color:#9ca3af;background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><rect x="3" y="4" width="18" height="18" rx="2" ry="2"></rect><line x1="16" y1="2" x2="16" y2="6"></line><line x1="8" y1="2" x2="8" y2="6"></line><line x1="3" y1="10" x2="21" y2="10"></line></svg>') no-repeat;cursor:pointer;opacity:.7}textarea{min-height:90px}.dialog{background:linear-gradient(180deg,#181f38,#12182c);border:1px solid rgba(255,255,255,.1);border-radius:16px;box-shadow:0 20px 40px #0006;padding:0;width:550px;max-width:95%;color:var(--text);overflow:hidden}dialog::backdrop{background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.dialog .header{display:flex;justify-content:space-between;align-items:center;padding:20px 28px;background:#ffffff08;border-bottom:1px solid rgba(255,255,255,.1)}.dialog .title{font-size:20px;font-weight:600;margin:0}dialog .closeBtn{background:none;border:none;color:var(--muted);cursor:pointer;padding:4px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease}dialog .closeBtn:hover{background:#ffffff1a;color:var(--text)}.dialog .content{padding:28px}.formContent{display:flex;flex-direction:column;gap:20px}.formContent .fullWidth,.formContent .grid>div{display:flex;flex-direction:column;gap:8px}.formContent label{font-size:13px}.semesterForm{display:flex;flex-direction:column;gap:24px}.dateGrid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.field{display:flex;flex-direction:column;gap:10px}.formFooter{display:flex;justify-content:flex-end;gap:12px;padding-top:24px;margin-top:8px;border-top:1px solid #374151}.btn.primary{background:#3b82f6;color:#fff;border-color:#3b82f6}.btn.primary:hover{filter:brightness(1.15)}.btn.secondary{background:#374151;color:#d1d5db;border-color:#4b5563}.btn.secondary:hover{background:#4b5563;border-color:#6b7280}.semesterList{display:flex;flex-direction:column}.semesterItem{background:#ffffff08;border:1px solid rgba(255,255,255,.07);padding:20px;border-radius:12px;margin-bottom:10px;transition:all .2s ease-in-out}.semesterItem:hover{background:#ffffff12;border-color:#ffffff26;transform:translateY(-2px)}.semesterItem .semesterActions{opacity:0;transform:translate(10px);transition:all .25s ease}.semesterItem:hover .semesterActions{opacity:1;transform:translate(0)}.semesterInfo{display:flex;flex-direction:column;gap:4px;cursor:pointer}.semesterName{font-size:15px;font-weight:500}.semesterDates{font-size:13px;color:var(--muted)}.semesterActions{display:flex;align-items:center;gap:8px}.semesterActions .actionBtn{background:none;border:none;color:var(--muted);padding:8px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.semesterActions .actionBtn:hover{background:#ffffff26;color:var(--text)}.semesterActions .actionBtn.danger:hover{background:#ef444426;color:var(--danger);border-color:#ef44444d}.dialog .footer{display:flex;justify-content:flex-end;padding:20px 28px;background:#0000001a;border-top:1px solid rgba(255,255,255,.1)}dialog .footerRight{display:flex;gap:12px}.modal-h{display:flex;align-items:center;justify-content:space-between;padding:10px 2px;margin-bottom:6px}.grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media (max-width:640px){.grid{grid-template-columns:1fr}}.hint{font-size:12px;color:var(--muted)}.footer{display:flex;gap:8px;justify-content:flex-end;margin-top:12px}.ring{--p:0;width:64px;height:64px;background:conic-gradient(var(--accent) calc(var(--p)*1%),rgba(255,255,255,.08) 0);border-radius:50%;display:grid;place-items:center;border:2px solid rgba(255,255,255,.06)}.ring span{font-size:13px}.pill{padding:4px 8px;border-radius:999px;border:1px solid rgba(255,255,255,.12);font-size:12px}.note{font-size:12px;color:var(--muted);padding:10px 16px}[data-theme=light]{--text:#0b1020;--muted:#5b6375;--shadow:0 6px 20px rgba(10,15,30,.08) }[data-theme=light] body{background:radial-gradient(1200px 800px at 10% -20%,#e9eef9 0%,transparent 60%),radial-gradient(1000px 600px at 100% 0%,#eef2ff 0%,transparent 70%),linear-gradient(180deg,#fff,#f7fafc 60%);color:#0b1020}[data-theme=light] header{background:linear-gradient(180deg,#fffffff2,#ffffffb3);border-bottom-color:#0a0f1e14}[data-theme=light] .subtitle,[data-theme=light] .legend span{color:#5b6375}[data-theme=light] aside,[data-theme=light] .panel{background:#fff;border-color:#0a0f1e1a}[data-theme=light] .panel .hdr{border-bottom-color:#0a0f1e14}[data-theme=light] .col{background:#f8fafc;border-color:#0a0f1e14}[data-theme=light] .col h3{border-bottom-color:#0a0f1e14}[data-theme=light] .card{background:#fff;border-color:#0a0f1e1f}[data-theme=light] .badge{border-color:#0a0f1e2e}[data-theme=light] .pbar{background:#f1f5f9;border-color:#0a0f1e1f}[data-theme=light] .due{background:#f3f4f6;border-color:#0a0f1e1f}[data-theme=light] .tab{background:#f3f4f6;border-color:#0a0f1e2e;color:#0b1020}[data-theme=light] .tab:hover{border-color:#0a0f1e47}[data-theme=light] .tab.active{background:#dbeafe;border-color:#60a5fa;color:#0b1020}[data-theme=light] .btn{background:linear-gradient(180deg,#fff,#f3f4f6);color:#0b1020;border-color:#0a0f1e1f}[data-theme=light] .btn.ghost{background:transparent;color:#0b1020}[data-theme=light] input[type=text],[data-theme=light] input[type=date],[data-theme=light] select,[data-theme=light] textarea{background:#fff;color:#0b1020;border-color:#0a0f1e2e}.card{position:relative;--c:#7dd3fc}.card:before{content:"";position:absolute;left:-1px;top:-1px;bottom:-1px;width:6px;background:var(--c);border-radius:14px 0 0 14px;opacity:.9}.chips{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}.chip{font-size:11px;padding:2px 8px;border-radius:999px;border:1px solid rgba(255,255,255,.16);background:#ffffff0a}.chip.type{border-style:dashed;opacity:.9}.note-line{-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.btn-sm{padding:6px 8px;border-radius:8px}.side{display:flex;flex-direction:column;align-items:flex-end;gap:6px}.due.over{border-color:var(--danger);color:var(--danger);background:#ef44441a}.due.soon{border-color:var(--warn);color:var(--warn);background:#f59e0b1a}.semester-selector{display:flex;align-items:center;gap:8px;background:none;border:none;color:var(--text);font-size:16px;font-weight:600;cursor:pointer}.semester-selector:hover{color:var(--accent)}.dropdown{position:relative}.dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;background:#1a2036;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:6px;z-index:10;min-width:200px;box-shadow:0 8px 20px #0006}.dropdown-item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:8px 12px;border-radius:8px;background:none;border:none;color:var(--text-primary);font-size:13px;cursor:pointer;line-height:1}.view-toggle-more .dropdown-item .view-toggle-icon{display:inline-flex;align-items:center}.view-toggle-more .dropdown-item .view-toggle-icon svg{width:18px;height:18px;display:block}.view-toggle-more .dropdown-item .view-toggle-label{font-size:13px}.dropdown-item:hover{background:#ffffff0d}.dropdown-item.danger:hover{background:#ef44441a;color:var(--danger)}.view-tabs .view-tab{display:flex;align-items:center;gap:8px;padding:7px 14px;border-radius:8px;background:transparent;border:1px solid transparent;color:var(--muted);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease-in-out}.view-tabs .view-tab .sr-only{position:static;width:auto;height:auto;margin:0;overflow:visible;clip:auto}.action-buttons{display:flex;align-items:center;gap:12px}.action-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:9px 16px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease-in-out;border:1px solid transparent}.action-btn.primary{background:var(--accent);color:#fff;border:1px solid var(--accent)}.action-btn.primary:hover{filter:brightness(1.1)}.action-btn.secondary{background:transparent;color:var(--muted);border-color:#ffffff26}.action-btn.secondary:hover{background:#ffffff1a;color:var(--text);border-color:#fff3}.action-btn.icon-btn{padding:8px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1)}.user-profile{position:relative}.avatar-btn{background:none;border:none;padding:0;border-radius:50%;cursor:pointer}.user-profile .avatar-btn img{border:2px solid transparent;transition:border-color .2s ease;width:36px;height:36px;border-radius:50%}.user-profile .avatar-btn:hover img{border-color:var(--accent)}.profile-menu{right:0}.profile-info{padding:8px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:8px}.profile-info p{font-weight:600;margin:0}.profile-info span{font-size:.8rem;color:#aaa}.profile-menu .dropdown-item{display:block;width:100%;text-align:left;padding:8px 12px;border-radius:4px}.profile-menu .dropdown-item:hover{background:#ffffff1a}.custom-checkbox{display:inline-block;position:relative;cursor:pointer;width:20px;height:20px;-webkit-user-select:none;user-select:none}.custom-checkbox input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.custom-checkbox .checkmark{position:absolute;top:0;left:0;height:20px;width:20px;background-color:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;transition:background-color .2s ease}.custom-checkbox:hover input~.checkmark{background-color:#fff3}.custom-checkbox input:checked~.checkmark{background-color:var(--accent);border-color:var(--accent)}.custom-checkbox .checkmark:after{content:"";position:absolute;display:none}.custom-checkbox input:checked~.checkmark:after{display:block}.custom-checkbox .checkmark:after{left:6px;top:2px;width:5px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.switch{position:relative;display:inline-block;width:38px;height:22px}.switch input{opacity:0;width:0;height:0}.switch .slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:34px;transition:.4s}.switch .slider:before{position:absolute;content:"";height:14px;width:14px;left:3px;bottom:3px;background-color:#fff;border-radius:50%;transition:.4s}.switch input:checked+.slider{background-color:var(--accent)}.switch input:checked+.slider:before{transform:translate(16px)}:root{--color-primary-50: #eef2ff;--color-primary-100: #e0e7ff;--color-primary-200: #c7d2fe;--color-primary-300: #a5b4fc;--color-primary-400: #818cf8;--color-primary-500: #6366f1;--color-primary-600: #4f46e5;--color-primary-700: #4338ca;--color-primary-800: #3730a3;--color-primary-900: #312e81;--color-primary-950: #1e1b4b;--color-secondary-50: #faf5ff;--color-secondary-100: #f3e8ff;--color-secondary-200: #e9d5ff;--color-secondary-300: #d8b4fe;--color-secondary-400: #c084fc;--color-secondary-500: #a855f7;--color-secondary-600: #9333ea;--color-secondary-700: #7c3aed;--color-secondary-800: #6b21a8;--color-secondary-900: #581c87;--color-secondary-950: #3b0764;--color-success-50: #ecfdf5;--color-success-100: #d1fae5;--color-success-200: #a7f3d0;--color-success-300: #6ee7b7;--color-success-400: #34d399;--color-success-500: #10b981;--color-success-600: #059669;--color-success-700: #047857;--color-success-800: #065f46;--color-success-900: #064e3b;--color-success-950: #022c22;--color-warning-50: #fffbeb;--color-warning-100: #fef3c7;--color-warning-200: #fde68a;--color-warning-300: #fcd34d;--color-warning-400: #fbbf24;--color-warning-500: #f59e0b;--color-warning-600: #d97706;--color-warning-700: #b45309;--color-warning-800: #92400e;--color-warning-900: #78350f;--color-warning-950: #451a03;--color-error-50: #fef2f2;--color-error-100: #fee2e2;--color-error-200: #fecaca;--color-error-300: #fca5a5;--color-error-400: #f87171;--color-error-500: #ef4444;--color-error-600: #dc2626;--color-error-700: #b91c1c;--color-error-800: #991b1b;--color-error-900: #7f1d1d;--color-error-950: #450a0a;--color-info-50: #eff6ff;--color-info-100: #dbeafe;--color-info-200: #bfdbfe;--color-info-300: #93c5fd;--color-info-400: #60a5fa;--color-info-500: #3b82f6;--color-info-600: #2563eb;--color-info-700: #1d4ed8;--color-info-800: #1e40af;--color-info-900: #1e3a8a;--color-info-950: #172554;--color-neutral-50: #f8fafc;--color-neutral-100: #f1f5f9;--color-neutral-200: #e2e8f0;--color-neutral-300: #cbd5e1;--color-neutral-400: #94a3b8;--color-neutral-500: #64748b;--color-neutral-600: #475569;--color-neutral-700: #334155;--color-neutral-800: #1e293b;--color-neutral-900: #0f172a;--color-neutral-950: #020617;--color-background: var(--color-neutral-950);--color-surface: var(--color-neutral-900);--color-surface-elevated: var(--color-neutral-800);--color-surface-overlay: var(--color-neutral-800);--color-border: var(--color-neutral-800);--color-border-subtle: var(--color-neutral-900);--color-border-strong: var(--color-neutral-700);--color-text: var(--color-neutral-50);--color-text-secondary: var(--color-neutral-400);--color-text-tertiary: var(--color-neutral-500);--color-text-inverse: var(--color-neutral-900);--color-interactive: var(--color-primary-500);--color-interactive-hover: var(--color-primary-400);--color-interactive-active: var(--color-primary-600);--color-interactive-disabled: var(--color-neutral-600);--color-card-background: var(--color-surface);--color-card-border: var(--color-border);--color-card-hover: var(--color-surface-elevated);--color-button-primary: var(--color-primary-500);--color-button-primary-hover: var(--color-primary-400);--color-button-primary-active: var(--color-primary-600);--color-button-secondary: var(--color-neutral-700);--color-button-secondary-hover: var(--color-neutral-600);--color-button-secondary-active: var(--color-neutral-800);--color-input-background: var(--color-surface-elevated);--color-input-border: var(--color-border);--color-input-border-focus: var(--color-primary-500);--color-modal-background: var(--color-surface);--color-modal-overlay: rgba(0, 0, 0, .75);--color-course-blue: var(--color-info-500);--color-course-green: var(--color-success-500);--color-course-purple: var(--color-secondary-500);--color-course-orange: var(--color-warning-500);--color-course-red: var(--color-error-500);--color-course-indigo: var(--color-primary-500);--color-course-pink: #ec4899;--color-course-teal: #14b8a6;--color-course-cyan: #06b6d4;--color-course-lime: #84cc16}[data-theme=light]{--color-background: var(--color-neutral-50);--color-surface: var(--color-neutral-100);--color-surface-elevated: var(--color-neutral-50);--color-surface-overlay: var(--color-neutral-100);--color-border: var(--color-neutral-200);--color-border-subtle: var(--color-neutral-100);--color-border-strong: var(--color-neutral-300);--color-text: var(--color-gray-900);--color-text-secondary: var(--color-gray-600);--color-text-tertiary: var(--color-gray-500);--color-text-quaternary: var(--color-gray-400);--color-text-disabled: var(--color-gray-300);--color-text-inverse: var(--color-white);--color-interactive-disabled: var(--color-gray-300);--color-card-background: var(--color-neutral-50);--color-card-border: var(--color-neutral-200);--color-card-hover: var(--color-neutral-100);--color-button-secondary: var(--color-neutral-200);--color-button-secondary-hover: var(--color-neutral-300);--color-button-secondary-active: var(--color-neutral-100);--color-input-background: var(--color-neutral-50);--color-input-border: var(--color-neutral-300);--color-modal-background: var(--color-neutral-50);--color-modal-overlay: rgba(0, 0, 0, .5)}:root{--color-primary-alpha-10: rgba(99, 102, 241, .1);--color-primary-alpha-20: rgba(99, 102, 241, .2);--color-primary-alpha-30: rgba(99, 102, 241, .3);--color-primary-alpha-50: rgba(99, 102, 241, .5);--color-success-alpha-10: rgba(16, 185, 129, .1);--color-success-alpha-20: rgba(16, 185, 129, .2);--color-warning-alpha-10: rgba(245, 158, 11, .1);--color-warning-alpha-20: rgba(245, 158, 11, .2);--color-error-alpha-10: rgba(239, 68, 68, .1);--color-error-alpha-20: rgba(239, 68, 68, .2);--color-white-alpha-5: rgba(255, 255, 255, .05);--color-white-alpha-10: rgba(255, 255, 255, .1);--color-white-alpha-20: rgba(255, 255, 255, .2);--color-white-alpha-30: rgba(255, 255, 255, .3);--color-black-alpha-10: rgba(0, 0, 0, .1);--color-black-alpha-20: rgba(0, 0, 0, .2);--color-black-alpha-50: rgba(0, 0, 0, .5);--color-black-alpha-75: rgba(0, 0, 0, .75)}:root{--font-family-sans: "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-family-mono: ui-monospace, "SF Mono", "Monaco", "Inconsolata", "Roboto Mono", "Courier New", monospace;--font-family-display: var(--font-family-sans);--font-weight-thin: 100;--font-weight-extralight: 200;--font-weight-light: 300;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-extrabold: 800;--font-weight-black: 900;--text-2xs: clamp(.625rem, .6rem + .125vw, .6875rem);--text-xs: clamp(.6875rem, .65rem + .1875vw, .75rem);--text-sm: clamp(.75rem, .7rem + .25vw, .8125rem);--text-base: clamp(.8125rem, .775rem + .1875vw, .875rem);--text-md: clamp(.875rem, .825rem + .25vw, .9375rem);--text-lg: clamp(.9375rem, .875rem + .3125vw, 1rem);--text-xl: clamp(1rem, .95rem + .25vw, 1.125rem);--text-2xl: clamp(1.125rem, 1.05rem + .375vw, 1.25rem);--text-3xl: clamp(1.25rem, 1.15rem + .5vw, 1.5rem);--text-4xl: clamp(1.5rem, 1.35rem + .75vw, 1.875rem);--font-size-6xl: 3.75rem;--font-size-7xl: 4.5rem;--font-size-8xl: 6rem;--font-size-9xl: 8rem;--line-height-none: 1;--line-height-tight: 1.25;--line-height-snug: 1.375;--line-height-normal: 1.5;--line-height-relaxed: 1.625;--line-height-loose: 2;--letter-spacing-tighter: -.05em;--letter-spacing-tight: -.025em;--letter-spacing-normal: 0em;--letter-spacing-wide: .025em;--letter-spacing-wider: .05em;--letter-spacing-widest: .1em;--text-display-2xl: var(--font-size-7xl);--text-display-xl: var(--font-size-6xl);--text-display-lg: var(--font-size-5xl);--text-display-md: var(--font-size-4xl);--text-display-sm: var(--font-size-3xl);--text-heading-h1: var(--font-size-3xl);--text-heading-h2: var(--font-size-2xl);--text-heading-h3: var(--font-size-xl);--text-heading-h4: var(--font-size-lg);--text-heading-h5: var(--font-size-base);--text-heading-h6: var(--font-size-sm);--text-body-xl: var(--font-size-xl);--text-body-lg: var(--font-size-lg);--text-body-md: var(--font-size-base);--text-body-sm: var(--font-size-sm);--text-body-xs: var(--font-size-xs);--text-label-lg: var(--font-size-sm);--text-label-md: var(--font-size-xs);--text-label-sm: .6875rem}@media (max-width: 768px){:root{--text-display-2xl: clamp(2.5rem, 8vw, var(--font-size-7xl));--text-display-xl: clamp(2.25rem, 7vw, var(--font-size-6xl));--text-display-lg: clamp(2rem, 6vw, var(--font-size-5xl));--text-display-md: clamp(1.75rem, 5vw, var(--font-size-4xl));--text-display-sm: clamp(1.5rem, 4vw, var(--font-size-3xl));--text-heading-h1: clamp(1.5rem, 4vw, var(--font-size-3xl));--text-heading-h2: clamp(1.25rem, 3.5vw, var(--font-size-2xl))}}.text-display-2xl{font-size:var(--text-display-2xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-none);letter-spacing:var(--letter-spacing-tight)}.text-display-xl{font-size:var(--text-display-xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);letter-spacing:var(--letter-spacing-tight)}.text-display-lg{font-size:var(--text-display-lg);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);letter-spacing:var(--letter-spacing-tight)}.text-h1{font-size:var(--text-heading-h1);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);letter-spacing:var(--letter-spacing-tight)}.text-h2{font-size:var(--text-heading-h2);font-weight:var(--font-weight-semibold);line-height:var(--line-height-snug);letter-spacing:var(--letter-spacing-normal)}.text-h3{font-size:var(--text-heading-h3);font-weight:var(--font-weight-semibold);line-height:var(--line-height-snug);letter-spacing:var(--letter-spacing-normal)}.text-h4{font-size:var(--text-heading-h4);font-weight:var(--font-weight-medium);line-height:var(--line-height-normal);letter-spacing:var(--letter-spacing-normal)}.text-body-xl{font-size:var(--text-body-xl);font-weight:var(--font-weight-normal);line-height:var(--line-height-relaxed)}.text-body-lg{font-size:var(--text-body-lg);font-weight:var(--font-weight-normal);line-height:var(--line-height-relaxed)}.text-body{font-size:var(--text-body-md);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal)}.text-body-sm{font-size:var(--text-body-sm);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal)}.text-body-xs{font-size:var(--text-body-xs);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal)}.text-label-lg{font-size:var(--text-label-lg);font-weight:var(--font-weight-medium);line-height:var(--line-height-normal);letter-spacing:var(--letter-spacing-wide);text-transform:uppercase}.text-label{font-size:var(--text-label-md);font-weight:var(--font-weight-medium);line-height:var(--line-height-normal);letter-spacing:var(--letter-spacing-wide)}.text-label-sm{font-size:var(--text-label-sm);font-weight:var(--font-weight-medium);line-height:var(--line-height-normal);letter-spacing:var(--letter-spacing-wider);text-transform:uppercase}.font-thin{font-weight:var(--font-weight-thin)}.font-extralight{font-weight:var(--font-weight-extralight)}.font-light{font-weight:var(--font-weight-light)}.font-normal{font-weight:var(--font-weight-normal)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.font-extrabold{font-weight:var(--font-weight-extrabold)}.font-black{font-weight:var(--font-weight-black)}.leading-none{line-height:var(--line-height-none)}.leading-tight{line-height:var(--line-height-tight)}.leading-snug{line-height:var(--line-height-snug)}.leading-normal{line-height:var(--line-height-normal)}.leading-relaxed{line-height:var(--line-height-relaxed)}.leading-loose{line-height:var(--line-height-loose)}.tracking-tighter{letter-spacing:var(--letter-spacing-tighter)}.tracking-tight{letter-spacing:var(--letter-spacing-tight)}.tracking-normal{letter-spacing:var(--letter-spacing-normal)}.tracking-wide{letter-spacing:var(--letter-spacing-wide)}.tracking-wider{letter-spacing:var(--letter-spacing-wider)}.tracking-widest{letter-spacing:var(--letter-spacing-widest)}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-justify{text-align:justify}.text-underline{text-decoration:underline}.text-no-underline{text-decoration:none}.text-line-through{text-decoration:line-through}.text-uppercase{text-transform:uppercase}.text-lowercase{text-transform:lowercase}.text-capitalize{text-transform:capitalize}.text-normal-case{text-transform:none}.text-ellipsis{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-clip{overflow:hidden;text-overflow:clip;white-space:nowrap}.text-truncate-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;line-clamp:2}.text-truncate-3{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;line-clamp:3}:root{--space-unit: .25rem;--space-0: 0;--space-px: 1px;--space-0_5: clamp(.125rem, .1rem + .125vw, .1875rem);--space-1: clamp(.1875rem, .15rem + .1875vw, .25rem);--space-1_5: clamp(.25rem, .2rem + .25vw, .375rem);--space-2: clamp(.375rem, .3rem + .375vw, .5rem);--space-2_5: clamp(.5rem, .4rem + .5vw, .625rem);--space-3: clamp(.625rem, .5rem + .625vw, .75rem);--space-3_5: clamp(.75rem, .6rem + .75vw, .875rem);--space-4: clamp(.875rem, .7rem + .875vw, 1rem);--space-5: clamp(1rem, .8rem + 1vw, 1.25rem);--space-6: clamp(1.25rem, 1rem + 1.25vw, 1.5rem);--space-7: clamp(1.5rem, 1.2rem + 1.5vw, 1.75rem);--space-8: clamp(1.75rem, 1.4rem + 1.75vw, 2rem);--space-9: clamp(2rem, 1.6rem + 2vw, 2.25rem);--space-10: clamp(2.25rem, 1.8rem + 2.25vw, 2.5rem);--space-11: clamp(2.5rem, 2rem + 2.5vw, 2.75rem);--space-12: clamp(2.75rem, 2.2rem + 2.75vw, 3rem);--space-14: clamp(3rem, 2.4rem + 3vw, 3.5rem);--space-16: clamp(3.5rem, 2.8rem + 3.5vw, 4rem);--space-20: clamp(4rem, 3.2rem + 4vw, 5rem);--space-24: clamp(5rem, 4rem + 5vw, 6rem);--space-28: clamp(6rem, 4.8rem + 6vw, 7rem);--space-32: clamp(7rem, 5.6rem + 7vw, 8rem);--space-36: 9rem;--space-40: 10rem;--space-44: 11rem;--space-48: 12rem;--space-52: 13rem;--space-56: 14rem;--space-60: 15rem;--space-64: 16rem;--space-72: 18rem;--space-80: 20rem;--space-96: 24rem;--space-layout-xs: var(--space-4);--space-layout-sm: var(--space-6);--space-layout-md: var(--space-8);--space-layout-lg: var(--space-12);--space-layout-xl: var(--space-16);--space-layout-2xl: var(--space-24);--space-component-xs: var(--space-2);--space-component-sm: var(--space-3);--space-component-md: var(--space-4);--space-component-lg: var(--space-6);--space-component-xl: var(--space-8);--space-content-xs: var(--space-2);--space-content-sm: var(--space-3);--space-content-md: var(--space-4);--space-content-lg: var(--space-6);--space-content-xl: var(--space-8);--space-interactive-xs: var(--space-1);--space-interactive-sm: var(--space-2);--space-interactive-md: var(--space-3);--space-interactive-lg: var(--space-4);--space-interactive-xl: var(--space-6);--container-xs: 20rem;--container-sm: 24rem;--container-md: 28rem;--container-lg: 32rem;--container-xl: 36rem;--container-2xl: 42rem;--container-3xl: 48rem;--container-4xl: 56rem;--container-5xl: 64rem;--container-6xl: 72rem;--container-7xl: 80rem;--container-full: 100%;--space-responsive-xs: clamp(var(--space-2), 2vw, var(--space-4));--space-responsive-sm: clamp(var(--space-4), 3vw, var(--space-6));--space-responsive-md: clamp(var(--space-6), 4vw, var(--space-8));--space-responsive-lg: clamp(var(--space-8), 5vw, var(--space-12));--space-responsive-xl: clamp(var(--space-12), 6vw, var(--space-16));--space-responsive-2xl: clamp(var(--space-16), 8vw, var(--space-24));--space-card-padding-sm: var(--space-3);--space-card-padding-md: var(--space-4);--space-card-padding-lg: var(--space-6);--space-card-gap: var(--space-4);--space-button-padding-x-sm: var(--space-3);--space-button-padding-y-sm: var(--space-2);--space-button-padding-x-md: var(--space-4);--space-button-padding-y-md: var(--space-2_5);--space-button-padding-x-lg: var(--space-6);--space-button-padding-y-lg: var(--space-3);--space-input-padding-x: var(--space-3);--space-input-padding-y: var(--space-2_5);--space-modal-padding: var(--space-6);--space-modal-gap: var(--space-4);--space-header-padding-x: var(--space-responsive-md);--space-header-padding-y: var(--space-4);--space-header-gap: var(--space-4);--space-sidebar-padding: var(--space-6);--space-sidebar-gap: var(--space-4);--space-sidebar-width: 18rem;--space-grid-gap-sm: var(--space-3);--space-grid-gap-md: var(--space-4);--space-grid-gap-lg: var(--space-6);--space-grid-gap-xl: var(--space-8)}@media (max-width: 768px){:root{--space-layout-sm: var(--space-4);--space-layout-md: var(--space-6);--space-layout-lg: var(--space-8);--space-layout-xl: var(--space-12);--space-component-lg: var(--space-4);--space-component-xl: var(--space-6);--space-sidebar-width: 16rem;--space-modal-padding: var(--space-4)}}.m-0{margin:var(--space-0)}.m-px{margin:var(--space-px)}.m-0_5{margin:var(--space-0_5)}.m-1{margin:var(--space-1)}.m-1_5{margin:var(--space-1_5)}.m-2{margin:var(--space-2)}.m-2_5{margin:var(--space-2_5)}.m-3{margin:var(--space-3)}.m-4{margin:var(--space-4)}.m-5{margin:var(--space-5)}.m-6{margin:var(--space-6)}.m-8{margin:var(--space-8)}.m-10{margin:var(--space-10)}.m-12{margin:var(--space-12)}.m-16{margin:var(--space-16)}.m-20{margin:var(--space-20)}.m-24{margin:var(--space-24)}.mt-0{margin-top:var(--space-0)}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-0{margin-bottom:var(--space-0)}.mb-1{margin-bottom:var(--space-1)}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.ml-0{margin-left:var(--space-0)}.ml-1{margin-left:var(--space-1)}.ml-2{margin-left:var(--space-2)}.ml-3{margin-left:var(--space-3)}.ml-4{margin-left:var(--space-4)}.mr-0{margin-right:var(--space-0)}.mr-1{margin-right:var(--space-1)}.mr-2{margin-right:var(--space-2)}.mr-3{margin-right:var(--space-3)}.mr-4{margin-right:var(--space-4)}.p-0{padding:var(--space-0)}.p-1{padding:var(--space-1)}.p-2{padding:var(--space-2)}.p-3{padding:var(--space-3)}.p-4{padding:var(--space-4)}.p-5{padding:var(--space-5)}.p-6{padding:var(--space-6)}.p-8{padding:var(--space-8)}.p-10{padding:var(--space-10)}.p-12{padding:var(--space-12)}.pt-0{padding-top:var(--space-0)}.pt-1{padding-top:var(--space-1)}.pt-2{padding-top:var(--space-2)}.pt-3{padding-top:var(--space-3)}.pt-4{padding-top:var(--space-4)}.pt-6{padding-top:var(--space-6)}.pt-8{padding-top:var(--space-8)}.pb-0{padding-bottom:var(--space-0)}.pb-1{padding-bottom:var(--space-1)}.pb-2{padding-bottom:var(--space-2)}.pb-3{padding-bottom:var(--space-3)}.pb-4{padding-bottom:var(--space-4)}.pb-6{padding-bottom:var(--space-6)}.pb-8{padding-bottom:var(--space-8)}.px-0{padding-left:var(--space-0);padding-right:var(--space-0)}.px-1{padding-left:var(--space-1);padding-right:var(--space-1)}.px-2{padding-left:var(--space-2);padding-right:var(--space-2)}.px-3{padding-left:var(--space-3);padding-right:var(--space-3)}.px-4{padding-left:var(--space-4);padding-right:var(--space-4)}.px-6{padding-left:var(--space-6);padding-right:var(--space-6)}.py-0{padding-top:var(--space-0);padding-bottom:var(--space-0)}.py-1{padding-top:var(--space-1);padding-bottom:var(--space-1)}.py-2{padding-top:var(--space-2);padding-bottom:var(--space-2)}.py-3{padding-top:var(--space-3);padding-bottom:var(--space-3)}.py-4{padding-top:var(--space-4);padding-bottom:var(--space-4)}.py-6{padding-top:var(--space-6);padding-bottom:var(--space-6)}.gap-0{gap:var(--space-0)}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-5{gap:var(--space-5)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.w-full{width:100%}.w-auto{width:auto}.w-fit{width:fit-content}.max-w-xs{max-width:var(--container-xs)}.max-w-sm{max-width:var(--container-sm)}.max-w-md{max-width:var(--container-md)}.max-w-lg{max-width:var(--container-lg)}.max-w-xl{max-width:var(--container-xl)}.max-w-2xl{max-width:var(--container-2xl)}.max-w-3xl{max-width:var(--container-3xl)}.max-w-4xl{max-width:var(--container-4xl)}.max-w-5xl{max-width:var(--container-5xl)}.max-w-6xl{max-width:var(--container-6xl)}.max-w-7xl{max-width:var(--container-7xl)}.max-w-full{max-width:var(--container-full)}:root{--shadow-none: none;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-xl: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-2xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--shadow-3xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--shadow-primary-sm: 0 1px 2px 0 rgba(99, 102, 241, .1);--shadow-primary-md: 0 4px 6px -1px rgba(99, 102, 241, .1), 0 2px 4px -2px rgba(99, 102, 241, .1);--shadow-primary-lg: 0 10px 15px -3px rgba(99, 102, 241, .1), 0 4px 6px -4px rgba(99, 102, 241, .1);--shadow-primary-xl: 0 20px 25px -5px rgba(99, 102, 241, .25), 0 8px 10px -6px rgba(99, 102, 241, .1);--shadow-success-sm: 0 1px 2px 0 rgba(16, 185, 129, .1);--shadow-success-md: 0 4px 6px -1px rgba(16, 185, 129, .1), 0 2px 4px -2px rgba(16, 185, 129, .1);--shadow-warning-sm: 0 1px 2px 0 rgba(245, 158, 11, .1);--shadow-warning-md: 0 4px 6px -1px rgba(245, 158, 11, .1), 0 2px 4px -2px rgba(245, 158, 11, .1);--shadow-error-sm: 0 1px 2px 0 rgba(239, 68, 68, .1);--shadow-error-md: 0 4px 6px -1px rgba(239, 68, 68, .1), 0 2px 4px -2px rgba(239, 68, 68, .1);--shadow-inner-sm: inset 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-inner-md: inset 0 2px 4px 0 rgba(0, 0, 0, .1);--shadow-inner-lg: inset 0 4px 8px 0 rgba(0, 0, 0, .1);--shadow-glow-primary: 0 0 0 3px rgba(99, 102, 241, .1);--shadow-glow-success: 0 0 0 3px rgba(16, 185, 129, .1);--shadow-glow-warning: 0 0 0 3px rgba(245, 158, 11, .1);--shadow-glow-error: 0 0 0 3px rgba(239, 68, 68, .1);--shadow-card-rest: var(--shadow-sm);--shadow-card-hover: var(--shadow-md);--shadow-card-active: var(--shadow-lg);--shadow-button-rest: var(--shadow-sm);--shadow-button-hover: var(--shadow-md);--shadow-button-active: var(--shadow-inner-sm);--shadow-button-focus: var(--shadow-glow-primary);--shadow-modal: var(--shadow-2xl);--shadow-modal-backdrop: var(--shadow-3xl);--shadow-dropdown: var(--shadow-lg);--shadow-popover: var(--shadow-xl);--shadow-header: var(--shadow-sm);--shadow-sidebar: var(--shadow-md);--shadow-input-rest: var(--shadow-inner-sm);--shadow-input-focus: var(--shadow-inner-sm), var(--shadow-glow-primary);--shadow-input-error: var(--shadow-inner-sm), var(--shadow-glow-error);--shadow-toast: var(--shadow-xl);--shadow-notification: var(--shadow-2xl)}[data-theme=light]{--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .1);--shadow-md: 0 1px 3px 0 rgba(0, 0, 0, .15), 0 1px 2px -1px rgba(0, 0, 0, .15);--shadow-lg: 0 4px 6px -1px rgba(0, 0, 0, .15), 0 2px 4px -2px rgba(0, 0, 0, .15);--shadow-xl: 0 10px 15px -3px rgba(0, 0, 0, .15), 0 4px 6px -4px rgba(0, 0, 0, .15);--shadow-2xl: 0 20px 25px -5px rgba(0, 0, 0, .15), 0 8px 10px -6px rgba(0, 0, 0, .15);--shadow-3xl: 0 25px 50px -12px rgba(0, 0, 0, .35);--shadow-inner-sm: inset 0 1px 2px 0 rgba(0, 0, 0, .1);--shadow-inner-md: inset 0 2px 4px 0 rgba(0, 0, 0, .15);--shadow-inner-lg: inset 0 4px 8px 0 rgba(0, 0, 0, .15)}.shadow-none{box-shadow:var(--shadow-none)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:var(--shadow-xl)}.shadow-2xl{box-shadow:var(--shadow-2xl)}.shadow-3xl{box-shadow:var(--shadow-3xl)}.shadow-inner-sm{box-shadow:var(--shadow-inner-sm)}.shadow-inner-md{box-shadow:var(--shadow-inner-md)}.shadow-inner-lg{box-shadow:var(--shadow-inner-lg)}.shadow-primary-sm{box-shadow:var(--shadow-primary-sm)}.shadow-primary-md{box-shadow:var(--shadow-primary-md)}.shadow-primary-lg{box-shadow:var(--shadow-primary-lg)}.shadow-primary-xl{box-shadow:var(--shadow-primary-xl)}.shadow-success-sm{box-shadow:var(--shadow-success-sm)}.shadow-success-md{box-shadow:var(--shadow-success-md)}.shadow-warning-sm{box-shadow:var(--shadow-warning-sm)}.shadow-warning-md{box-shadow:var(--shadow-warning-md)}.shadow-error-sm{box-shadow:var(--shadow-error-sm)}.shadow-error-md{box-shadow:var(--shadow-error-md)}.shadow-glow-primary{box-shadow:var(--shadow-glow-primary)}.shadow-glow-success{box-shadow:var(--shadow-glow-success)}.shadow-glow-warning{box-shadow:var(--shadow-glow-warning)}.shadow-glow-error{box-shadow:var(--shadow-glow-error)}.shadow-card{box-shadow:var(--shadow-card-rest)}.shadow-card-hover{box-shadow:var(--shadow-card-hover)}.shadow-card-active{box-shadow:var(--shadow-card-active)}.shadow-button{box-shadow:var(--shadow-button-rest)}.shadow-button-hover{box-shadow:var(--shadow-button-hover)}.shadow-button-active{box-shadow:var(--shadow-button-active)}.shadow-button-focus{box-shadow:var(--shadow-button-focus)}.shadow-modal{box-shadow:var(--shadow-modal)}.shadow-dropdown{box-shadow:var(--shadow-dropdown)}.shadow-popover{box-shadow:var(--shadow-popover)}.shadow-header{box-shadow:var(--shadow-header)}.shadow-sidebar{box-shadow:var(--shadow-sidebar)}.shadow-input{box-shadow:var(--shadow-input-rest)}.shadow-input-focus{box-shadow:var(--shadow-input-focus)}.shadow-input-error{box-shadow:var(--shadow-input-error)}.shadow-toast{box-shadow:var(--shadow-toast)}.shadow-notification{box-shadow:var(--shadow-notification)}.shadow-transition{transition:box-shadow .15s ease-in-out}.shadow-transition-slow{transition:box-shadow .3s ease-in-out}.hover\:shadow-sm:hover{box-shadow:var(--shadow-sm)}.hover\:shadow-md:hover{box-shadow:var(--shadow-md)}.hover\:shadow-lg:hover{box-shadow:var(--shadow-lg)}.hover\:shadow-xl:hover{box-shadow:var(--shadow-xl)}.hover\:shadow-primary-md:hover{box-shadow:var(--shadow-primary-md)}.hover\:shadow-primary-lg:hover{box-shadow:var(--shadow-primary-lg)}.focus\:shadow-glow-primary:focus{box-shadow:var(--shadow-glow-primary)}.focus\:shadow-input-focus:focus{box-shadow:var(--shadow-input-focus)}.active\:shadow-inner-sm:active{box-shadow:var(--shadow-inner-sm)}.active\:shadow-button-active:active{box-shadow:var(--shadow-button-active)}:root{--ease-linear: linear;--ease-in: cubic-bezier(.4, 0, 1, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--ease-bounce: cubic-bezier(.68, -.55, .265, 1.55);--ease-elastic: cubic-bezier(.175, .885, .32, 1.275);--ease-back: cubic-bezier(.175, .885, .32, 1.275);--ease-anticipate: cubic-bezier(.25, .46, .45, .94);--ease-overshoot: cubic-bezier(.25, .46, .45, .94);--duration-instant: 0ms;--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .35s;--duration-slower: .5s;--duration-slowest: .75s;--duration-button: var(--duration-fast);--duration-card: var(--duration-normal);--duration-modal: var(--duration-normal);--duration-tooltip: var(--duration-fast);--duration-dropdown: var(--duration-normal);--duration-page: var(--duration-slow);--delay-none: 0ms;--delay-short: 75ms;--delay-medium: .15s;--delay-long: .3s;--delay-stagger-1: calc(var(--delay-short) * 1);--delay-stagger-2: calc(var(--delay-short) * 2);--delay-stagger-3: calc(var(--delay-short) * 3);--delay-stagger-4: calc(var(--delay-short) * 4);--delay-stagger-5: calc(var(--delay-short) * 5);--transform-scale-up: scale(1.05);--transform-scale-down: scale(.95);--transform-scale-button: scale(.98);--transform-translate-up: translateY(-2px);--transform-translate-down: translateY(2px);--transform-rotate-slight: rotate(1deg);--animation-fade-in: fadeIn var(--duration-normal) var(--ease-out);--animation-fade-out: fadeOut var(--duration-normal) var(--ease-in);--animation-slide-up: slideUp var(--duration-normal) var(--ease-out);--animation-slide-down: slideDown var(--duration-normal) var(--ease-out);--animation-slide-left: slideLeft var(--duration-normal) var(--ease-out);--animation-slide-right: slideRight var(--duration-normal) var(--ease-out);--animation-scale-in: scaleIn var(--duration-normal) var(--ease-back);--animation-scale-out: scaleOut var(--duration-fast) var(--ease-in);--animation-bounce-in: bounceIn var(--duration-slow) var(--ease-bounce);--animation-shake: shake var(--duration-normal) var(--ease-in-out);--animation-pulse: pulse 2s var(--ease-in-out) infinite;--animation-spin: spin 1s var(--ease-linear) infinite;--animation-hover-lift: var(--duration-button) var(--ease-out);--animation-hover-scale: var(--duration-button) var(--ease-out);--animation-focus-ring: var(--duration-fast) var(--ease-out);--animation-button-press: var(--duration-fast) var(--ease-in-out)}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideLeft{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes slideRight{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.9)}}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{opacity:1;transform:scale(1.05)}70%{transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-2px)}20%,40%,60%,80%{transform:translate(2px)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes glow{0%,to{box-shadow:0 0 5px var(--color-primary-500)}50%{box-shadow:0 0 20px var(--color-primary-500)}}.animate-fade-in{animation:var(--animation-fade-in)}.animate-fade-out{animation:var(--animation-fade-out)}.animate-slide-up{animation:var(--animation-slide-up)}.animate-slide-down{animation:var(--animation-slide-down)}.animate-slide-left{animation:var(--animation-slide-left)}.animate-slide-right{animation:var(--animation-slide-right)}.animate-scale-in{animation:var(--animation-scale-in)}.animate-scale-out{animation:var(--animation-scale-out)}.animate-bounce-in{animation:var(--animation-bounce-in)}.animate-shake{animation:var(--animation-shake)}.animate-pulse{animation:var(--animation-pulse)}.animate-spin{animation:var(--animation-spin)}.animate-float{animation:float 3s var(--ease-in-out) infinite}.animate-glow{animation:glow 2s var(--ease-in-out) infinite}.animate-stagger-1{animation-delay:var(--delay-stagger-1)}.animate-stagger-2{animation-delay:var(--delay-stagger-2)}.animate-stagger-3{animation-delay:var(--delay-stagger-3)}.animate-stagger-4{animation-delay:var(--delay-stagger-4)}.animate-stagger-5{animation-delay:var(--delay-stagger-5)}.hover-lift{transition:transform var(--animation-hover-lift)}.hover-lift:hover{transform:var(--transform-translate-up)}.hover-scale{transition:transform var(--animation-hover-scale)}.hover-scale:hover{transform:var(--transform-scale-up)}.hover-glow{transition:box-shadow var(--duration-normal) var(--ease-out)}.hover-glow:hover{box-shadow:var(--shadow-glow-primary)}.loading-shimmer{background:linear-gradient(90deg,var(--color-surface) 0%,var(--color-surface-elevated) 50%,var(--color-surface) 100%);background-size:200px 100%;animation:shimmer 1.5s infinite}.loading-skeleton{background:var(--color-surface-elevated);border-radius:var(--radius-sm);animation:pulse 1.5s ease-in-out infinite}.transition-all{transition:all var(--duration-normal) var(--ease-in-out)}.transition-colors{transition:color var(--duration-fast) var(--ease-in-out),background-color var(--duration-fast) var(--ease-in-out),border-color var(--duration-fast) var(--ease-in-out)}.transition-opacity{transition:opacity var(--duration-normal) var(--ease-in-out)}.transition-shadow{transition:box-shadow var(--duration-normal) var(--ease-in-out)}.transition-transform{transition:transform var(--duration-normal) var(--ease-in-out)}.duration-fast{transition-duration:var(--duration-fast)}.duration-normal{transition-duration:var(--duration-normal)}.duration-slow{transition-duration:var(--duration-slow)}.ease-linear{transition-timing-function:var(--ease-linear)}.ease-in{transition-timing-function:var(--ease-in)}.ease-out{transition-timing-function:var(--ease-out)}.ease-in-out{transition-timing-function:var(--ease-in-out)}.ease-bounce{transition-timing-function:var(--ease-bounce)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.animate-essential{animation-duration:.01ms!important;transition-duration:.01ms!important}.animate-decorative{animation:none!important;transition:none!important}.animate-pulse,.animate-spin,.animate-float,.animate-glow{animation:none}}.animate-gpu{transform:translateZ(0);will-change:transform,opacity}.animate-gpu-auto{will-change:auto}@media (max-width: 767px){.animate-mobile-optimized{animation-duration:calc(var(--duration-normal) * .7)!important;transition-duration:calc(var(--duration-fast) * .8)!important}.animate-complex-mobile-off{transform:none!important;animation:none!important}}@media (prefers-reduced-motion: no-preference){.animate-battery-aware{animation-play-state:running}}@media (prefers-reduced-motion: reduce){.animate-battery-aware{animation-play-state:paused;animation:none}}.animate-on-scroll{opacity:0;transform:translateY(20px);transition:opacity var(--duration-normal) var(--ease-out),transform var(--duration-normal) var(--ease-out)}.animate-on-scroll.in-view{opacity:1;transform:translateY(0)}.page-enter{opacity:0;transform:translateY(20px)}.page-enter-active{opacity:1;transform:translateY(0);transition:opacity var(--duration-page) var(--ease-out),transform var(--duration-page) var(--ease-out)}.page-exit{opacity:1;transform:translateY(0)}.page-exit-active{opacity:0;transform:translateY(-20px);transition:opacity var(--duration-normal) var(--ease-in),transform var(--duration-normal) var(--ease-in)}:root{--breakpoint-xs: 320px;--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1280px;--breakpoint-2xl: 1536px;--container-xs: 100%;--container-sm: 640px;--container-md: 768px;--container-lg: 1024px;--container-xl: 1280px;--container-2xl: 1536px;--space-fluid-xs: clamp(.25rem, .5vw, .5rem);--space-fluid-sm: clamp(.5rem, 1vw, 1rem);--space-fluid-md: clamp(1rem, 2vw, 2rem);--space-fluid-lg: clamp(1.5rem, 3vw, 3rem);--space-fluid-xl: clamp(2rem, 4vw, 4rem);--space-fluid-2xl: clamp(3rem, 6vw, 6rem);--text-fluid-xs: clamp(.75rem, .8vw, .875rem);--text-fluid-sm: clamp(.875rem, 1vw, 1rem);--text-fluid-base: clamp(1rem, 1.2vw, 1.125rem);--text-fluid-lg: clamp(1.125rem, 1.5vw, 1.25rem);--text-fluid-xl: clamp(1.25rem, 2vw, 1.5rem);--text-fluid-2xl: clamp(1.5rem, 2.5vw, 2rem);--text-fluid-3xl: clamp(2rem, 3vw, 2.5rem);--text-fluid-4xl: clamp(2.5rem, 4vw, 3.5rem);--button-height-mobile: 44px;--button-height-desktop: 40px;--button-padding-mobile: var(--space-3) var(--space-4);--button-padding-desktop: var(--space-2_5) var(--space-4);--card-padding-mobile: var(--space-4);--card-padding-desktop: var(--space-6);--card-gap-mobile: var(--space-3);--card-gap-desktop: var(--space-4);--modal-width-mobile: calc(100vw - var(--space-4));--modal-width-desktop: 500px;--modal-padding-mobile: var(--space-4);--modal-padding-desktop: var(--space-6);--header-height-mobile: 60px;--header-height-desktop: 64px;--sidebar-width-mobile: 280px;--sidebar-width-desktop: 320px}.container{width:100%;margin-left:auto;margin-right:auto;padding-left:var(--space-4);padding-right:var(--space-4)}.container-xs{max-width:var(--container-xs)}.container-sm{max-width:var(--container-sm)}.container-md{max-width:var(--container-md)}.container-lg{max-width:var(--container-lg)}.container-xl{max-width:var(--container-xl)}.container-2xl{max-width:var(--container-2xl)}.hidden-mobile{display:none}.hidden-desktop{display:block}@media (min-width: 768px){.hidden-mobile{display:block}.hidden-desktop{display:none}}.grid-responsive{display:grid;gap:var(--space-4);grid-template-columns:1fr}@media (min-width: 640px){.grid-responsive{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.grid-responsive{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1280px){.grid-responsive{grid-template-columns:repeat(4,1fr)}}.flex-responsive{display:flex;flex-direction:column;gap:var(--space-4)}@media (min-width: 768px){.flex-responsive{flex-direction:row;align-items:center}}.btn-responsive{min-height:var(--button-height-mobile);padding:var(--button-padding-mobile);font-size:var(--text-fluid-sm)}@media (min-width: 768px){.btn-responsive{min-height:var(--button-height-desktop);padding:var(--button-padding-desktop)}}.card-responsive{padding:var(--card-padding-mobile)}@media (min-width: 768px){.card-responsive{padding:var(--card-padding-desktop)}}.modal-responsive{width:var(--modal-width-mobile);padding:var(--modal-padding-mobile)}@media (min-width: 768px){.modal-responsive{width:var(--modal-width-desktop);padding:var(--modal-padding-desktop)}}.text-responsive-xs{font-size:var(--text-fluid-xs)}.text-responsive-sm{font-size:var(--text-fluid-sm)}.text-responsive-base{font-size:var(--text-fluid-base)}.text-responsive-lg{font-size:var(--text-fluid-lg)}.text-responsive-xl{font-size:var(--text-fluid-xl)}.text-responsive-2xl{font-size:var(--text-fluid-2xl)}.text-responsive-3xl{font-size:var(--text-fluid-3xl)}.text-responsive-4xl{font-size:var(--text-fluid-4xl)}.p-responsive{padding:var(--space-fluid-md)}.px-responsive{padding-left:var(--space-fluid-md);padding-right:var(--space-fluid-md)}.py-responsive{padding-top:var(--space-fluid-md);padding-bottom:var(--space-fluid-md)}.m-responsive{margin:var(--space-fluid-md)}.mx-responsive{margin-left:var(--space-fluid-md);margin-right:var(--space-fluid-md)}.my-responsive{margin-top:var(--space-fluid-md);margin-bottom:var(--space-fluid-md)}.gap-responsive{gap:var(--space-fluid-md)}.gap-responsive-sm{gap:var(--space-fluid-sm)}.gap-responsive-lg{gap:var(--space-fluid-lg)}@supports (container-type: inline-size){.container-query{container-type:inline-size}@container (min-width: 300px){.card-container-responsive{display:flex;flex-direction:row;align-items:center}}@container (min-width: 500px){.card-container-responsive{padding:var(--space-6)}}}@media (max-width: 767px){.animate-mobile-reduced{animation-duration:.2s!important;transition-duration:.2s!important}}@media (max-width: 767px) and (prefers-reduced-motion: no-preference){.animate-complex{animation:none!important}}.layout-sidebar{display:flex;flex-direction:column;min-height:100vh}@media (min-width: 1024px){.layout-sidebar{flex-direction:row}.layout-sidebar-nav{width:var(--sidebar-width-desktop);flex-shrink:0}.layout-sidebar-main{flex:1;min-width:0}}.dashboard-grid{display:grid;gap:var(--space-4);grid-template-columns:1fr}@media (min-width: 640px){.dashboard-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.dashboard-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1280px){.dashboard-grid{grid-template-columns:repeat(4,1fr)}}.img-responsive{max-width:100%;height:auto;display:block}.img-cover{width:100%;height:100%;object-fit:cover}.img-contain{width:100%;height:100%;object-fit:contain}.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch}@media (max-width: 767px){.table-stack{display:block}.table-stack thead{display:none}.table-stack tr{display:block;border:1px solid var(--color-border);margin-bottom:var(--space-4);border-radius:var(--radius-md)}.table-stack td{display:block;text-align:right;padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--color-border-subtle)}.table-stack td:before{content:attr(data-label) ": ";float:left;font-weight:var(--font-weight-semibold);color:var(--color-text)}}.form-responsive{display:grid;gap:var(--space-4);grid-template-columns:1fr}@media (min-width: 768px){.form-responsive{grid-template-columns:repeat(2,1fr)}.form-responsive .form-full-width{grid-column:1 / -1}}@media print{.no-print{display:none!important}.print-break-before{page-break-before:always}.print-break-after{page-break-after:always}.print-break-inside-avoid{page-break-inside:avoid}}:root{--radius-none: 0;--radius-sm: .125rem;--radius-md: .25rem;--radius-lg: .375rem;--radius-xl: .5rem;--radius-2xl: .75rem;--radius-3xl: 1rem;--radius-4xl: 1.5rem;--radius-full: 9999px;--radius-button: var(--radius-lg);--radius-card: var(--radius-2xl);--radius-modal: var(--radius-3xl);--radius-input: var(--radius-lg);--radius-badge: var(--radius-full);--radius-avatar: var(--radius-full)}:root{--z-index-hide: -1;--z-index-auto: auto;--z-index-base: 0;--z-index-docked: 10;--z-index-dropdown: 1000;--z-index-sticky: 1100;--z-index-banner: 1200;--z-index-overlay: 1300;--z-index-modal: 1400;--z-index-popover: 1500;--z-index-skiplink: 1600;--z-index-toast: 1700;--z-index-tooltip: 1800}:root{--duration-instant: 0ms;--duration-fast: .1s;--duration-normal: .2s;--duration-slow: .3s;--duration-slower: .5s;--duration-slowest: 1s;--ease-linear: linear;--ease-in: cubic-bezier(.4, 0, 1, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--ease-bounce: cubic-bezier(.68, -.55, .265, 1.55);--ease-elastic: cubic-bezier(.175, .885, .32, 1.275);--transition-fast: var(--duration-fast) var(--ease-out);--transition-normal: var(--duration-normal) var(--ease-out);--transition-slow: var(--duration-slow) var(--ease-out);--transition-colors: color var(--duration-normal) var(--ease-out), background-color var(--duration-normal) var(--ease-out), border-color var(--duration-normal) var(--ease-out);--transition-transform: transform var(--duration-normal) var(--ease-out);--transition-shadow: box-shadow var(--duration-normal) var(--ease-out);--transition-all: all var(--duration-normal) var(--ease-out)}:root{--breakpoint-xs: 475px;--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1280px;--breakpoint-2xl: 1536px}*{box-sizing:border-box}html{font-family:var(--font-family-sans);line-height:var(--line-height-normal);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;background-color:var(--color-background);color:var(--color-text);font-size:var(--font-size-base);line-height:var(--line-height-normal);transition:var(--transition-colors)}:focus{outline:2px solid var(--color-primary-500);outline-offset:2px}:focus:not(:focus-visible){outline:none}:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px}::selection{background-color:var(--color-primary-alpha-20);color:var(--color-text)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-surface)}::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.rounded-none{border-radius:var(--radius-none)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-3xl{border-radius:var(--radius-3xl)}.rounded-4xl{border-radius:var(--radius-4xl)}.rounded-full{border-radius:var(--radius-full)}.z-hide{z-index:var(--z-index-hide)}.z-auto{z-index:var(--z-index-auto)}.z-base{z-index:var(--z-index-base)}.z-docked{z-index:var(--z-index-docked)}.z-dropdown{z-index:var(--z-index-dropdown)}.z-sticky{z-index:var(--z-index-sticky)}.z-banner{z-index:var(--z-index-banner)}.z-overlay{z-index:var(--z-index-overlay)}.z-modal{z-index:var(--z-index-modal)}.z-popover{z-index:var(--z-index-popover)}.z-toast{z-index:var(--z-index-toast)}.z-tooltip{z-index:var(--z-index-tooltip)}.transition-none{transition:none}.transition-fast{transition:var(--transition-fast)}.transition-normal{transition:var(--transition-normal)}.transition-slow{transition:var(--transition-slow)}.transition-colors{transition:var(--transition-colors)}.transition-transform{transition:var(--transition-transform)}.transition-shadow{transition:var(--transition-shadow)}.transition-all{transition:var(--transition-all)}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.inline-grid{display:inline-grid}.hidden{display:none}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-nowrap{flex-wrap:nowrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.items-stretch{align-items:stretch}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.justify-evenly{justify-content:space-evenly}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-visible{overflow:visible}.overflow-scroll{overflow:scroll}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.overflow-x-hidden{overflow-x:hidden}.overflow-y-hidden{overflow-y:hidden}.cursor-auto{cursor:auto}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.cursor-wait{cursor:wait}.cursor-text{cursor:text}.cursor-move{cursor:move}.cursor-not-allowed{cursor:not-allowed}.select-none{-webkit-user-select:none;user-select:none}.select-text{-webkit-user-select:text;user-select:text}.select-all{-webkit-user-select:all;user-select:all}.select-auto{-webkit-user-select:auto;user-select:auto}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.not-sr-only{position:static;width:auto;height:auto;padding:0;margin:0;overflow:visible;clip:auto;white-space:normal}html body * label,html body * .premium-form-field__label,html body * .form-label,html body * [class*=label]{color:#f1f5f9!important}html body div * .input,html body div * .input input,html body div * .input__field,html body div * input.input,html body div * input.input-md,html body div * input.input-default,html body * .create-task-page .input,html body * .create-task-page input.input,html body * .create-task-page input[type=text],html body * .create-task-page input[type=number],html body * input.input.input-md.input-default,html body * input[class*=input],html body div.create-task-page input,html body div.create-task-page input[type=text],html body div.create-task-page input[type=number],html body div.create-task-page .input,html body div * .task-creation-form input,html body div * .task-creation-form .input,html body div * .textarea,html body div * textarea.textarea,html body * .create-task-page textarea{background-color:#1e293b!important;color:#f1f5f9!important;-webkit-text-fill-color:#f1f5f9!important;border-color:#374151!important}html body * .custom-date-input{background-color:var(--color-input-background)!important}html body * .custom-date-input__field{color:var(--color-text)!important;-webkit-text-fill-color:var(--color-text)!important;background-color:transparent!important}html body * .custom-dropdown__trigger,html body * .custom-dropdown__trigger span,html body * .premium-input input,html body * .premium-input__field,html body * [class*=premium-input] input,html body * [class*=custom-dropdown] span,html body * .custom-dropdown__selected-text{color:#1e293b!important;-webkit-text-fill-color:#1e293b!important;background-color:#fff!important}html body * input::placeholder,html body * textarea::placeholder,html body * .premium-input__field::placeholder,html body * .premium-textarea__field::placeholder,html body * .premium-date-picker__input::placeholder,html body * .react-datepicker__input-container input::placeholder{color:#64748b!important;opacity:1!important}html body * .premium-form-field__error,html body * .error-message,html body * [class*=error]{color:#fca5a5!important}input:not(.custom-date-picker input):not(.custom-date-picker__input):not(.select__input),textarea:not(.custom-date-picker textarea) textarea{background-color:#1f2937!important;color:#afb2b7!important;border-color:#afb2b7!important}html body * .select__menu,html body * [class*=select__menu]{background-color:#1a202c!important;border:1px solid #374151!important;border-radius:10px!important;box-shadow:0 10px 15px -3px #0003,0 4px 6px -2px #0000001a!important;padding:6px 0!important;margin-top:4px!important;z-index:9999!important;overflow:hidden!important;-webkit-backdrop-filter:blur(8px)!important;backdrop-filter:blur(8px)!important}html body * .select__option,html body * [class*=select__option]{background-color:transparent!important;color:#e5e7eb!important;padding:10px 16px!important;margin:1px 4px!important;border-radius:6px!important;font-size:14px!important;font-weight:450!important;cursor:pointer!important;transition:all .2s cubic-bezier(.4,0,.2,1)!important;border:none!important;position:relative!important;min-height:auto!important}html body * .select__option:before{content:""!important;position:absolute!important;left:0!important;top:0!important;bottom:0!important;width:3px!important;background:transparent!important;border-radius:0 3px 3px 0!important;transition:background-color .2s ease!important}html body * .select__option:hover,html body * .select__option--is-focused,html body * [class*=select__option]:hover,html body * [class*=select__option--is-focused]{background-color:#6366f114!important;color:#f9fafb!important;transform:translate(2px)!important}html body * .select__option:hover:before,html body * .select__option--is-focused:before{background-color:#6366f1!important}html body * .select__option--is-selected,html body * [class*=select__option--is-selected]{background-color:#6366f126!important;color:#fff!important;font-weight:500!important}html body * .select__option--is-selected:before{background-color:#6366f1!important}html body * .select__single-value,html body * [class*=select__single-value]{color:#f3f4f6!important;font-weight:450!important}html body * .select__placeholder,html body * [class*=select__placeholder]{color:#9ca3af!important;font-weight:400!important}html body * .select__control,html body * [class*=select__control]{border-color:#4b5563!important;background-color:#1f2937!important;min-height:46px!important;border-radius:8px!important;box-shadow:0 1px 2px #0000000d!important;transition:all .2s ease!important}html body * .select__control:hover,html body * [class*=select__control]:hover{border-color:#6b7280!important;box-shadow:0 1px 3px #0000001a!important}html body * .select__control--is-focused,html body * [class*=select__control--is-focused]{border-color:#6366f1!important;box-shadow:0 0 0 3px #6366f11a!important}html body * .select__indicator-separator,html body * [class*=select__indicator-separator]{background-color:#4b5563!important}html body * .select__dropdown-indicator,html body * [class*=select__dropdown-indicator]{color:#9ca3af!important;padding:8px!important;transition:color .2s ease,transform .2s ease!important}html body * .select__dropdown-indicator:hover,html body * [class*=select__dropdown-indicator]:hover{color:#d1d5db!important;transform:scale(1.1)!important}html body * .custom-dropdown:not(.custom-date-picker){position:relative!important;background:#fff!important;border:2px solid #e2e8f0!important;border-radius:12px!important}html body * .custom-dropdown__trigger{padding:.875rem 1rem!important;display:flex!important;align-items:center!important;justify-content:space-between!important;cursor:pointer!important}html body * .custom-dropdown__menu{position:absolute!important;top:100%!important;left:0!important;right:0!important;background:#1e293b!important;border:1px solid #374151!important;border-radius:8px!important;box-shadow:0 4px 6px -1px #0000001a!important;z-index:9999!important;max-height:200px!important;overflow-y:auto!important}html body * .custom-dropdown__option{padding:.75rem 1rem!important;cursor:pointer!important;transition:background-color .2s ease!important}html body * .custom-dropdown__option:hover{background-color:#374151!important}html body * .task-creation-form *,html body * .course-creation-form *,html body * .semester-creation-form *:not(.input),html body * .syllabus-creation-form *{color:#f1f5f9!important}html body * .semester-creation-form .input{color:var(--color-text)!important;-webkit-text-fill-color:var(--color-text)!important;background-color:var(--color-input-background)!important}html body * .premium-input,html body * .premium-select,html body * .premium-textarea,html body * .premium-date-picker{color:#f1f5f9!important}html body div[class*=premium] input,html body div[class*=premium] select,html body div[class*=premium] textarea,html body div[class*=custom] input:not(.custom-date-input__field),html body div[class*=custom] select,html body div[class*=custom] textarea{color:#f1f5f9!important;-webkit-text-fill-color:#f1f5f9!important}html body [class*=creation] input:not(.custom-date-input__field):not(.input),html body [class*=creation] textarea,html body [class*=Creation] input:not(.custom-date-input__field):not(.input),html body [class*=Creation] textarea,html body .task-creation-form input:not(.custom-date-input__field):not(.input),html body .task-creation-form textarea,html body .task-creation-form .custom-dropdown__trigger,html body .task-creation-form .custom-dropdown__trigger span,html body .task-creation-form .premium-input input,html body .task-creation-form .premium-input__field{background-color:#1f2937!important;color:#afb2b7!important;border-color:#afb2b7!important}html body .semester-creation-form input.input{color:var(--color-text)!important;-webkit-text-fill-color:var(--color-text)!important;background-color:var(--color-input-background)!important}html body [class*=creation] select,html body [class*=creation] label,html body [class*=Creation] select,html body [class*=Creation] label,html body .task-creation-form label{color:#f1f5f9!important;-webkit-text-fill-color:#f1f5f9!important}html body .task-creation-form *{color:inherit!important}html body .task-creation-form input:not(.custom-date-input__field):not(.input),html body .task-creation-form textarea,html body .task-creation-form [class*=dropdown] span,html body .task-creation-form [class*=input] input:not(.custom-date-input__field):not(.input),html body .task-creation-form .premium-textarea textarea,html body .task-creation-form .premium-textarea__field{color:#1e293b!important;-webkit-text-fill-color:#1e293b!important;background-color:#fff!important}html body textarea,html body .premium-textarea textarea,html body .premium-textarea__field,html body [class*=textarea] textarea{background-color:#1f2937!important;color:#afb2b7!important;border-color:#afb2b7!important}html body * .task-confirmation input,html body * .task-confirmation textarea,html body * .task-confirmation .react-datepicker__input-container input,html body * .task-confirmation [class*=input],html body * .task-confirmation [class*=textarea],html body * .syllabus-page input,html body * .syllabus-page textarea,html body * .syllabus-page .react-datepicker__input-container input,html body * .syllabus-page [class*=input]:not(.custom-date-input__field),html body * .syllabus-page [class*=textarea]{background-color:#1e293b!important;color:#f1f5f9!important;-webkit-text-fill-color:#f1f5f9!important;border-color:#374151!important}html body * .syllabus-page label,html body * .syllabus-page .form-label,html body * .syllabus-page .premium-form-field__label,html body * .task-confirmation label,html body * .task-confirmation .form-label,html body * .task-confirmation .premium-form-field__label{color:#f1f5f9!important}html body * .syllabus-page input::placeholder,html body * .syllabus-page textarea::placeholder,html body * .task-confirmation input::placeholder,html body * .task-confirmation textarea::placeholder{color:#64748b!important;opacity:1!important}html body * .syllabus-page .react-datepicker__calendar-icon,html body * .task-confirmation .react-datepicker__calendar-icon{color:#9ca3af!important}html body * .syllabus-page button[aria-label*=Remove],html body * .task-confirmation button[aria-label*=Remove],html body * .syllabus-page .remove-task-button,html body * .task-confirmation .remove-task-button{background-color:#dc2626!important;color:#fff!important;border:none!important;border-radius:4px!important;padding:4px 8px!important;font-size:14px!important;cursor:pointer!important}html body * .syllabus-page button[aria-label*=Remove]:hover,html body * .task-confirmation button[aria-label*=Remove]:hover,html body * .syllabus-page .remove-task-button:hover,html body * .task-confirmation .remove-task-button:hover{background-color:#b91c1c!important}html body * .search-input{background-color:transparent!important;color:#ffffffe6!important;border:1px solid rgba(255,255,255,.15)!important;-webkit-text-fill-color:rgba(255,255,255,.9)!important}html body * .search-input::placeholder{color:#ffffff80!important;-webkit-text-fill-color:rgba(255,255,255,.5)!important}html body * .avatar-btn img{opacity:1!important;visibility:visible!important;display:block!important}html body * .avatar-placeholder{width:36px;height:36px;border-radius:50%;background:#ffffff1a;display:flex;align-items:center;justify-content:center;color:#ffffffb3;border:2px solid transparent;transition:all .2s ease}html body * .avatar-btn:hover .avatar-placeholder{background:#ffffff26;border-color:var(--accent)}[data-theme=light] .premium-task-modal .premium-form-field__label,[data-theme=light] .premium-task-modal label{color:#334155!important}[data-theme=light] .premium-task-modal .premium-input__field,[data-theme=light] .premium-task-modal .premium-select__input,[data-theme=light] .premium-task-modal .premium-textarea__field,[data-theme=light] .premium-task-modal .premium-date-picker__input,[data-theme=light] .premium-task-modal input,[data-theme=light] .premium-task-modal select,[data-theme=light] .premium-task-modal textarea{color:#0f172a!important;-webkit-text-fill-color:#0f172a!important;background-color:#fff!important;opacity:1!important}body[data-theme=light] .premium-task-modal .premium-date-picker,body[data-theme=light] .premium-task-modal .premium-input,body[data-theme=light] .premium-task-modal .premium-select,body[data-theme=light] .premium-task-modal .premium-textarea{background-color:#fff!important;border-color:#e2e8f0!important}body[data-theme=light] .premium-task-modal .premium-input__field,body[data-theme=light] .premium-task-modal .premium-select__input,body[data-theme=light] .premium-task-modal .premium-textarea__field,body[data-theme=light] .premium-task-modal .premium-date-picker__input,body[data-theme=light] .premium-task-modal input,body[data-theme=light] .premium-task-modal select,body[data-theme=light] .premium-task-modal textarea{color:#0f172a!important;-webkit-text-fill-color:#0f172a!important;background-color:#fff!important;opacity:1!important}body[data-theme=light] .premium-task-modal .react-datepicker__input-container input{background-color:#fff!important;color:#0f172a!important;-webkit-text-fill-color:#0f172a!important;opacity:1!important}[data-theme=light] .premium-task-modal .premium-input__field::placeholder,[data-theme=light] .premium-task-modal .premium-textarea__field::placeholder,[data-theme=light] .premium-task-modal .premium-date-picker__input::placeholder,[data-theme=light] .premium-task-modal input::placeholder,[data-theme=light] .premium-task-modal textarea::placeholder{color:#64748b!important;opacity:1!important}[data-theme=light] .premium-task-modal .premium-date-picker{background:#fff!important}[data-theme=light] .premium-task-modal .premium-form-field__error{color:#b91c1c!important}[data-theme=light] .premium-task-modal .react-datepicker__input-container input{background-color:#fff!important;color:#0f172a!important;-webkit-text-fill-color:#0f172a!important;opacity:1!important}[data-theme=light] .premium-task-modal .react-datepicker__input-container input::placeholder{color:#64748b!important;opacity:1!important}[data-theme=light] .premium-task-modal .premium-input,[data-theme=light] .premium-task-modal .premium-select,[data-theme=light] .premium-task-modal .premium-textarea,[data-theme=light] .premium-task-modal .premium-date-picker,[data-theme=light] .premium-task-modal .premium-input *,[data-theme=light] .premium-task-modal .premium-select *,[data-theme=light] .premium-task-modal .premium-textarea *{opacity:1!important;filter:none!important}[data-theme=dark] .premium-task-modal .premium-form-field__label,[data-theme=dark] .premium-task-modal label{color:#cbd5e1!important}[data-theme=dark] .premium-task-modal .premium-input,[data-theme=dark] .premium-task-modal .premium-select,[data-theme=dark] .premium-task-modal .premium-textarea,[data-theme=dark] .premium-task-modal .premium-date-picker{background-color:#111827!important;border-color:#334155!important;color:#e5e7eb!important}[data-theme=dark] .premium-task-modal .premium-input__field,[data-theme=dark] .premium-task-modal .premium-select__input,[data-theme=dark] .premium-task-modal .premium-textarea__field,[data-theme=dark] .premium-task-modal .premium-date-picker__input,[data-theme=dark] .premium-task-modal input,[data-theme=dark] .premium-task-modal select,[data-theme=dark] .premium-task-modal textarea{color:#f3f4f6!important;-webkit-text-fill-color:#f3f4f6!important;background-color:transparent!important;opacity:1!important}[data-theme=dark] .premium-task-modal .premium-input__field::placeholder,[data-theme=dark] .premium-task-modal .premium-textarea__field::placeholder,[data-theme=dark] .premium-task-modal .premium-date-picker__input::placeholder,[data-theme=dark] .premium-task-modal input::placeholder,[data-theme=dark] .premium-task-modal textarea::placeholder{color:#9ca3af!important;opacity:1!important}[data-theme=dark] .premium-task-modal .premium-input:focus-within,[data-theme=dark] .premium-task-modal .premium-select:focus-within,[data-theme=dark] .premium-task-modal .premium-textarea:focus-within,[data-theme=dark] .premium-task-modal .premium-date-picker:focus-within{border-color:#6366f1!important;box-shadow:0 0 0 3px #6366f12e!important}[data-theme=dark] .premium-task-modal .premium-input__icon,[data-theme=dark] .premium-task-modal .premium-select__icon,[data-theme=dark] .premium-task-modal .premium-date-picker__icon{color:#9ca3af!important;border-right-color:#334155!important}[data-theme=dark] .premium-task-modal .react-datepicker__input-container input{color:#f3f4f6!important;-webkit-text-fill-color:#f3f4f6!important;background-color:transparent!important;opacity:1!important}[data-theme=dark] .premium-task-modal .react-datepicker,[data-theme=dark] .premium-task-modal .react-datepicker__month,[data-theme=dark] .premium-task-modal .react-datepicker__month-container{background-color:#fff!important;color:#0f172a!important}[data-theme=dark] .premium-task-modal .react-datepicker__header{background-color:#fff!important;border-bottom-color:#e5e7eb!important}[data-theme=dark] .premium-task-modal .react-datepicker__current-month{color:#0f172a!important}[data-theme=dark] .premium-task-modal .react-datepicker__day-name{color:#64748b!important}[data-theme=dark] .premium-task-modal .react-datepicker__day{color:#0f172a!important;opacity:1!important}[data-theme=dark] .task-completion-modal{background:#0b1220!important;color:#e5e7eb!important}[data-theme=dark] .task-completion-modal .modal-title{color:#cbd5e1!important;background:none!important;-webkit-text-fill-color:currentColor!important}[data-theme=dark] .task-completion-modal .task-info{background:#94a3b814!important;border-color:#334155!important}[data-theme=dark] .task-completion-modal .task-title,[data-theme=dark] .task-completion-modal .rating-label,[data-theme=dark] .task-completion-modal .difficulty-labels{color:#e5e7eb!important}[data-theme=dark] .task-completion-modal .star{color:#9ca3af!important}[data-theme=dark] .task-completion-modal .star:hover{background:#fbbf241f!important}[data-theme=dark] .task-completion-modal .difficulty-circle{border-color:#334155!important;background:#111827!important;color:#cbd5e1!important;box-shadow:none!important}[data-theme=dark] .task-completion-modal .difficulty-circle:hover{background:#1f2937!important;border-color:#6366f1!important;box-shadow:0 4px 12px #6366f126!important}[data-theme=dark] .task-completion-modal .difficulty-circle.selected{background:linear-gradient(135deg,#6366f1,#4f46e5)!important;border-color:#6366f1!important;color:#fff!important}[data-theme=dark] .task-completion-modal textarea{color:#fff!important;-webkit-text-fill-color:#ffffff!important}[data-theme=dark] .task-completion-modal .reflection-textarea{background:#0f172a!important;border-color:#334155!important;color:#fff!important;-webkit-text-fill-color:#ffffff!important;caret-color:#fff!important}[data-theme=dark] .task-completion-modal .reflection-textarea::placeholder,[data-theme=dark] .task-completion-modal .reflection-textarea::-webkit-input-placeholder,[data-theme=dark] .task-completion-modal .reflection-textarea::-moz-placeholder,[data-theme=dark] .task-completion-modal .reflection-textarea:-ms-input-placeholder,[data-theme=dark] .task-completion-modal .reflection-textarea:-moz-placeholder{color:#fff!important;opacity:1!important;font-weight:500!important}[data-theme=dark] .task-completion-modal .reflection-textarea:focus{border-color:#6366f1!important;box-shadow:0 0 0 3px #6366f12e!important;background:#0b1220!important;color:#fff!important;-webkit-text-fill-color:#ffffff!important}[data-theme=dark] .task-completion-modal .modal-actions{background:#0b1220!important;border-top-color:#334155!important}[data-theme=dark] .task-completion-modal .modal-actions .cancel-btn{background:#111827!important;border-color:#334155!important;color:#cbd5e1!important}[data-theme=dark] .task-completion-modal .modal-actions .cancel-btn:hover{background:#1f2937!important;border-color:#475569!important}[data-theme=dark] .task-completion-modal .modal-actions .complete-btn:disabled{background:#1f2937!important;color:#6b7280!important}[data-theme=dark] .task-completion-modal,[data-theme=dark] .task-completion-modal *{opacity:1!important;filter:none!important}.msg-html{color:inherit}.msg-html h2,.msg-html h3,.msg-html h4{margin:4px 0 2px;line-height:1.18}.msg-html p{margin:3px 0}.msg-html ul,.msg-html ol{margin:3px 0;padding-left:1.1rem}.msg-html li{margin:2px 0;list-style-position:outside;background:transparent!important;border:0!important;padding:0!important}.msg-html blockquote{margin:3px 0;padding-left:.8rem;border-left:0;background:transparent}.msg-html li>ul,.msg-html li>ol{margin:2px 0 1px}.msg-html pre{margin:10px 0}.upgrade-prompt-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.upgrade-prompt-modal{background:#fff;border-radius:1rem;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #0003;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.upgrade-prompt-header{position:relative;padding:2rem 2rem 1rem;text-align:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:1rem 1rem 0 0}.upgrade-icon{font-size:3rem;margin-bottom:1rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.upgrade-prompt-header h2{margin:0;font-size:1.5rem;font-weight:700}.close-button{position:absolute;top:1rem;right:1rem;background:#fff3;border:none;border-radius:.5rem;padding:.5rem;color:#fff;cursor:pointer;transition:all .2s ease}.close-button:hover{background:#ffffff4d;transform:scale(1.05)}.upgrade-prompt-content{padding:2rem}.limit-info{margin-bottom:2rem}.description{font-size:1rem;color:#6b7280;line-height:1.6;margin:0 0 1.5rem}.usage-display{background:#f9fafb;border-radius:.75rem;padding:1rem;border:1px solid #e5e7eb}.usage-bar{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden;margin-bottom:.5rem}.usage-fill{height:100%;background:linear-gradient(90deg,#ef4444,#dc2626);border-radius:4px;transition:width .3s ease}.usage-text{font-size:.875rem;color:#6b7280;font-weight:500}.upgrade-benefits{margin-bottom:2rem}.upgrade-benefits h3{margin:0 0 1rem;font-size:1.25rem;font-weight:600;color:#111827}.benefits-list{display:flex;flex-direction:column;gap:.75rem}.benefit-item{display:flex;align-items:center;gap:.75rem;font-size:.875rem;color:#374151}.benefit-item svg{color:#22c55e;flex-shrink:0}.pricing-info{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #bae6fd;border-radius:.75rem;padding:1.5rem;text-align:center;margin-bottom:2rem}.price-display{display:flex;flex-direction:column;align-items:center;gap:.5rem}.price{font-size:2rem;font-weight:800;color:#0c4a6e}.price-note{font-size:.875rem;color:#0c4a6e;opacity:.8}.upgrade-prompt-actions{display:flex;gap:1rem;padding:0 2rem;margin-bottom:1.5rem}.upgrade-prompt-actions .btn{flex:1}.upgrade-prompt-footer{padding:0 2rem 2rem}.security-badges{display:flex;justify-content:center;gap:2rem}.security-badge{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#6b7280}.security-badge svg{color:#22c55e}@media (max-width: 640px){.upgrade-prompt-overlay{padding:.5rem}.upgrade-prompt-modal{max-height:95vh}.upgrade-prompt-header{padding:1.5rem 1.5rem 1rem}.upgrade-prompt-header h2{font-size:1.25rem}.upgrade-prompt-content{padding:1.5rem}.upgrade-prompt-actions{flex-direction:column;padding:0 1.5rem}.upgrade-prompt-footer{padding:0 1.5rem 1.5rem}.security-badges{flex-direction:column;gap:1rem;align-items:center}.pricing-info{padding:1rem}.price{font-size:1.75rem}}@media (prefers-color-scheme: dark){.upgrade-prompt-modal{background:#1f2937;color:#f9fafb}.upgrade-benefits h3{color:#f9fafb}.description{color:#d1d5db}.benefit-item{color:#e5e7eb}.usage-display{background:#374151;border-color:#4b5563}.usage-text{color:#d1d5db}.pricing-info{background:#3b82f61a;border-color:#3b82f6}.price,.price-note{color:#93c5fd}.security-badge{color:#d1d5db}}.upgrade-prompt-modal:hover{transform:translateY(-2px);box-shadow:0 25px 50px #00000040}.benefit-item{transition:all .2s ease}.benefit-item:hover{transform:translate(4px);color:#111827}@media (prefers-color-scheme: dark){.benefit-item:hover{color:#f9fafb}}.close-button:focus{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}@media (prefers-contrast: high){.upgrade-prompt-modal{border:2px solid #000}.usage-display,.pricing-info{border-width:2px}}@media (prefers-reduced-motion: reduce){.upgrade-prompt-overlay,.upgrade-prompt-modal,.usage-fill,.benefit-item{animation:none;transition:none}}
