.carlynn-toggle-btn{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:50%;bottom:24px;box-shadow:0 4px 20px rgba(99,102,241,.4);cursor:pointer;display:flex;height:56px;justify-content:center;position:fixed;right:24px;transition:all .3s ease;width:56px;z-index:9999}.carlynn-toggle-btn:hover{box-shadow:0 6px 25px rgba(99,102,241,.5);transform:scale(1.1)}.carlynn-toggle-btn svg{color:#fff;height:24px;width:24px}.carlynn-badge{background:#10b981;border-radius:10px;box-shadow:0 2px 8px rgba(16,185,129,.4);color:#fff;font-size:10px;font-weight:600;padding:2px 6px;position:absolute;right:-8px;top:-8px}.carlynn-chat-window{animation:slideUp .3s ease;background:#343541;border-radius:16px;bottom:96px;box-shadow:0 10px 40px rgba(0,0,0,.3);display:flex;flex-direction:column;height:520px;overflow:hidden;position:fixed;right:24px;width:380px;z-index:9998}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.carlynn-header{align-items:center;background:#202123;border-bottom:1px solid #444654;display:flex;justify-content:space-between;padding:16px}.carlynn-header-info{align-items:center;display:flex;gap:12px}.carlynn-avatar{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:50%;color:#fff;display:flex;font-size:16px;font-weight:700;height:40px;justify-content:center;width:40px}.carlynn-name{color:#ececf1;font-size:16px;font-weight:600}.carlynn-status{color:#8e8ea0;font-size:12px}.carlynn-header-actions{display:flex;gap:8px}.carlynn-header-actions button{background:transparent;border:none;border-radius:6px;cursor:pointer;padding:8px;transition:background .2s}.carlynn-header-actions button:hover{background:#444654}.carlynn-header-actions svg{color:#8e8ea0;height:18px;width:18px}.carlynn-messages{display:flex;flex:1 1;flex-direction:column;gap:16px;overflow-y:auto;padding:16px}.carlynn-messages::-webkit-scrollbar{width:6px}.carlynn-messages::-webkit-scrollbar-track{background:transparent}.carlynn-messages::-webkit-scrollbar-thumb{background:#444654;border-radius:3px}.carlynn-message{display:flex;gap:12px;max-width:90%}.carlynn-message.user{align-self:flex-end;flex-direction:row-reverse}.carlynn-message.assistant{align-self:flex-start}.carlynn-message-avatar{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:12px;font-weight:700;height:32px;justify-content:center;width:32px}.carlynn-message-content{border-radius:12px;font-size:14px;line-height:1.5;padding:12px 16px;white-space:pre-wrap;word-break:break-word}.carlynn-message.user .carlynn-message-content{background:#6366f1;border-bottom-right-radius:4px;color:#fff}.carlynn-message.assistant .carlynn-message-content{background:#444654;border-bottom-left-radius:4px;color:#ececf1}.carlynn-typing{display:flex;gap:4px;padding:16px 20px!important}.carlynn-typing span{animation:typing 1.4s ease-in-out infinite;background:#8e8ea0;border-radius:50%;height:8px;width:8px}.carlynn-typing span:nth-child(2){animation-delay:.2s}.carlynn-typing span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{opacity:.5;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}.carlynn-input-form{background:#202123;border-top:1px solid #444654;display:flex;gap:12px;padding:16px}.carlynn-input-form input{background:#40414f;border:1px solid #565869;border-radius:8px;color:#ececf1;flex:1 1;font-size:14px;outline:none;padding:12px 16px;transition:border-color .2s}.carlynn-input-form input::placeholder{color:#8e8ea0}.carlynn-input-form input:focus{border-color:#6366f1}.carlynn-input-form input:disabled{opacity:.6}.carlynn-input-form button{align-items:center;background:#6366f1;border:none;border-radius:8px;cursor:pointer;display:flex;height:44px;justify-content:center;transition:all .2s;width:44px}.carlynn-input-form button:hover:not(:disabled){background:#5558e3}.carlynn-input-form button:disabled{cursor:not-allowed;opacity:.5}.carlynn-input-form button svg{color:#fff;height:20px;width:20px}@media (max-width:480px){.carlynn-chat-window{bottom:88px;height:calc(100vh - 140px);right:16px;width:calc(100vw - 32px)}.carlynn-toggle-btn{bottom:16px;right:16px}}

/*!
 * Quill Editor v2.0.2
 * https://quilljs.com
 * Copyright (c) 2017-2024, Slab
 * Copyright (c) 2014, Jason Chen
 * Copyright (c) 2013, salesforce.com
 */.ql-container{box-sizing:border-box;font-family:Helvetica,Arial,sans-serif;font-size:13px;height:100%;margin:0;position:relative}.ql-container.ql-disabled .ql-tooltip{visibility:hidden}.ql-container:not(.ql-disabled) li[data-list=checked]>.ql-ui,.ql-container:not(.ql-disabled) li[data-list=unchecked]>.ql-ui{cursor:pointer}.ql-clipboard{height:1px;left:-100000px;overflow-y:hidden;position:absolute;top:50%}.ql-clipboard p{margin:0;padding:0}.ql-editor{word-wrap:break-word;box-sizing:border-box;counter-reset:list-0 list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9;height:100%;line-height:1.42;outline:none;overflow-y:auto;padding:12px 15px;-o-tab-size:4;tab-size:4;-moz-tab-size:4;text-align:left;white-space:pre-wrap}.ql-editor>*{cursor:text}.ql-editor blockquote,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6,.ql-editor ol,.ql-editor p,.ql-editor pre{margin:0;padding:0}@supports (counter-set:none){.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6,.ql-editor p{counter-set:list-0 list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6,.ql-editor p{counter-reset:list-0 list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor table{border-collapse:collapse}.ql-editor td{border:1px solid #000;padding:2px 5px}.ql-editor li,.ql-editor ol{padding-left:1.5em}.ql-editor li{list-style-type:none;position:relative}.ql-editor li>.ql-ui:before{display:inline-block;margin-left:-1.5em;margin-right:.3em;text-align:right;white-space:nowrap;width:1.2em}.ql-editor li[data-list=checked]>.ql-ui,.ql-editor li[data-list=unchecked]>.ql-ui{color:#777}.ql-editor li[data-list=bullet]>.ql-ui:before{content:"\2022"}.ql-editor li[data-list=checked]>.ql-ui:before{content:"\2611"}.ql-editor li[data-list=unchecked]>.ql-ui:before{content:"\2610"}@supports (counter-set:none){.ql-editor li[data-list]{counter-set:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list]{counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered]{counter-increment:list-0}.ql-editor li[data-list=ordered]>.ql-ui:before{content:counter(list-0,decimal) ". "}.ql-editor li[data-list=ordered].ql-indent-1{counter-increment:list-1}.ql-editor li[data-list=ordered].ql-indent-1>.ql-ui:before{content:counter(list-1,lower-alpha) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-1{counter-set:list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-1{counter-reset:list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-2{counter-increment:list-2}.ql-editor li[data-list=ordered].ql-indent-2>.ql-ui:before{content:counter(list-2,lower-roman) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-2{counter-set:list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-2{counter-reset:list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-3{counter-increment:list-3}.ql-editor li[data-list=ordered].ql-indent-3>.ql-ui:before{content:counter(list-3,decimal) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-3{counter-set:list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-3{counter-reset:list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-4{counter-increment:list-4}.ql-editor li[data-list=ordered].ql-indent-4>.ql-ui:before{content:counter(list-4,lower-alpha) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-4{counter-set:list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-4{counter-reset:list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-5{counter-increment:list-5}.ql-editor li[data-list=ordered].ql-indent-5>.ql-ui:before{content:counter(list-5,lower-roman) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-5{counter-set:list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-5{counter-reset:list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-6{counter-increment:list-6}.ql-editor li[data-list=ordered].ql-indent-6>.ql-ui:before{content:counter(list-6,decimal) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-6{counter-set:list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-6{counter-reset:list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-7{counter-increment:list-7}.ql-editor li[data-list=ordered].ql-indent-7>.ql-ui:before{content:counter(list-7,lower-alpha) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-7{counter-set:list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-7{counter-reset:list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-8{counter-increment:list-8}.ql-editor li[data-list=ordered].ql-indent-8>.ql-ui:before{content:counter(list-8,lower-roman) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-8{counter-set:list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-8{counter-reset:list-9}}.ql-editor li[data-list=ordered].ql-indent-9{counter-increment:list-9}.ql-editor li[data-list=ordered].ql-indent-9>.ql-ui:before{content:counter(list-9,decimal) ". "}.ql-editor .ql-indent-1:not(.ql-direction-rtl){padding-left:3em}.ql-editor li.ql-indent-1:not(.ql-direction-rtl){padding-left:4.5em}.ql-editor .ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:3em}.ql-editor li.ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:4.5em}.ql-editor .ql-indent-2:not(.ql-direction-rtl){padding-left:6em}.ql-editor li.ql-indent-2:not(.ql-direction-rtl){padding-left:7.5em}.ql-editor .ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:6em}.ql-editor li.ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:7.5em}.ql-editor .ql-indent-3:not(.ql-direction-rtl){padding-left:9em}.ql-editor li.ql-indent-3:not(.ql-direction-rtl){padding-left:10.5em}.ql-editor .ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:9em}.ql-editor li.ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:10.5em}.ql-editor .ql-indent-4:not(.ql-direction-rtl){padding-left:12em}.ql-editor li.ql-indent-4:not(.ql-direction-rtl){padding-left:13.5em}.ql-editor .ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:12em}.ql-editor li.ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:13.5em}.ql-editor .ql-indent-5:not(.ql-direction-rtl){padding-left:15em}.ql-editor li.ql-indent-5:not(.ql-direction-rtl){padding-left:16.5em}.ql-editor .ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:15em}.ql-editor li.ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:16.5em}.ql-editor .ql-indent-6:not(.ql-direction-rtl){padding-left:18em}.ql-editor li.ql-indent-6:not(.ql-direction-rtl){padding-left:19.5em}.ql-editor .ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:18em}.ql-editor li.ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:19.5em}.ql-editor .ql-indent-7:not(.ql-direction-rtl){padding-left:21em}.ql-editor li.ql-indent-7:not(.ql-direction-rtl){padding-left:22.5em}.ql-editor .ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:21em}.ql-editor li.ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:22.5em}.ql-editor .ql-indent-8:not(.ql-direction-rtl){padding-left:24em}.ql-editor li.ql-indent-8:not(.ql-direction-rtl){padding-left:25.5em}.ql-editor .ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:24em}.ql-editor li.ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:25.5em}.ql-editor .ql-indent-9:not(.ql-direction-rtl){padding-left:27em}.ql-editor li.ql-indent-9:not(.ql-direction-rtl){padding-left:28.5em}.ql-editor .ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:27em}.ql-editor li.ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:28.5em}.ql-editor li.ql-direction-rtl{padding-right:1.5em}.ql-editor li.ql-direction-rtl>.ql-ui:before{margin-left:.3em;margin-right:-1.5em;text-align:left}.ql-editor table{table-layout:fixed;width:100%}.ql-editor table td{outline:none}.ql-editor .ql-code-block-container{font-family:monospace}.ql-editor .ql-video{display:block;max-width:100%}.ql-editor .ql-video.ql-align-center{margin:0 auto}.ql-editor .ql-video.ql-align-right{margin:0 0 0 auto}.ql-editor .ql-bg-black{background-color:#000}.ql-editor .ql-bg-red{background-color:#e60000}.ql-editor .ql-bg-orange{background-color:#f90}.ql-editor .ql-bg-yellow{background-color:#ff0}.ql-editor .ql-bg-green{background-color:#008a00}.ql-editor .ql-bg-blue{background-color:#06c}.ql-editor .ql-bg-purple{background-color:#93f}.ql-editor .ql-color-white{color:#fff}.ql-editor .ql-color-red{color:#e60000}.ql-editor .ql-color-orange{color:#f90}.ql-editor .ql-color-yellow{color:#ff0}.ql-editor .ql-color-green{color:#008a00}.ql-editor .ql-color-blue{color:#06c}.ql-editor .ql-color-purple{color:#93f}.ql-editor .ql-font-serif{font-family:Georgia,Times New Roman,serif}.ql-editor .ql-font-monospace{font-family:Monaco,Courier New,monospace}.ql-editor .ql-size-small{font-size:.75em}.ql-editor .ql-size-large{font-size:1.5em}.ql-editor .ql-size-huge{font-size:2.5em}.ql-editor .ql-direction-rtl{direction:rtl;text-align:inherit}.ql-editor .ql-align-center{text-align:center}.ql-editor .ql-align-justify{text-align:justify}.ql-editor .ql-align-right{text-align:right}.ql-editor .ql-ui{position:absolute}.ql-editor.ql-blank:before{color:rgba(0,0,0,.6);content:attr(data-placeholder);font-style:italic;left:15px;pointer-events:none;position:absolute;right:15px}.ql-snow .ql-toolbar:after,.ql-snow.ql-toolbar:after{clear:both;content:"";display:table}.ql-snow .ql-toolbar button,.ql-snow.ql-toolbar button{background:none;border:none;cursor:pointer;display:inline-block;float:left;height:24px;padding:3px 5px;width:28px}.ql-snow .ql-toolbar button svg,.ql-snow.ql-toolbar button svg{float:left;height:100%}.ql-snow .ql-toolbar button:active:hover,.ql-snow.ql-toolbar button:active:hover{outline:none}.ql-snow .ql-toolbar input.ql-image[type=file],.ql-snow.ql-toolbar input.ql-image[type=file]{display:none}.ql-snow .ql-toolbar .ql-picker-item.ql-selected,.ql-snow .ql-toolbar .ql-picker-item:hover,.ql-snow .ql-toolbar .ql-picker-label.ql-active,.ql-snow .ql-toolbar .ql-picker-label:hover,.ql-snow .ql-toolbar button.ql-active,.ql-snow .ql-toolbar button:focus,.ql-snow .ql-toolbar button:hover,.ql-snow.ql-toolbar .ql-picker-item.ql-selected,.ql-snow.ql-toolbar .ql-picker-item:hover,.ql-snow.ql-toolbar .ql-picker-label.ql-active,.ql-snow.ql-toolbar .ql-picker-label:hover,.ql-snow.ql-toolbar button.ql-active,.ql-snow.ql-toolbar button:focus,.ql-snow.ql-toolbar button:hover{color:#06c}.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:focus .ql-fill,.ql-snow .ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover .ql-fill,.ql-snow .ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:focus .ql-fill,.ql-snow.ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:hover .ql-fill,.ql-snow.ql-toolbar button:hover .ql-stroke.ql-fill{fill:#06c}.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow .ql-toolbar button.ql-active .ql-stroke,.ql-snow .ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar button:focus .ql-stroke,.ql-snow .ql-toolbar button:focus .ql-stroke-miter,.ql-snow .ql-toolbar button:hover .ql-stroke,.ql-snow .ql-toolbar button:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow.ql-toolbar button.ql-active .ql-stroke,.ql-snow.ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar button:focus .ql-stroke,.ql-snow.ql-toolbar button:focus .ql-stroke-miter,.ql-snow.ql-toolbar button:hover .ql-stroke,.ql-snow.ql-toolbar button:hover .ql-stroke-miter{stroke:#06c}@media (pointer:coarse){.ql-snow .ql-toolbar button:hover:not(.ql-active),.ql-snow.ql-toolbar button:hover:not(.ql-active){color:#444}.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill{fill:#444}.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter{stroke:#444}}.ql-snow,.ql-snow *{box-sizing:border-box}.ql-snow .ql-hidden{display:none}.ql-snow .ql-out-bottom,.ql-snow .ql-out-top{visibility:hidden}.ql-snow .ql-tooltip{position:absolute;transform:translateY(10px)}.ql-snow .ql-tooltip a{cursor:pointer;text-decoration:none}.ql-snow .ql-tooltip.ql-flip{transform:translateY(-10px)}.ql-snow .ql-formats{display:inline-block;vertical-align:middle}.ql-snow .ql-formats:after{clear:both;content:"";display:table}.ql-snow .ql-stroke{fill:none;stroke:#444;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.ql-snow .ql-stroke-miter{fill:none;stroke:#444;stroke-miterlimit:10;stroke-width:2}.ql-snow .ql-fill,.ql-snow .ql-stroke.ql-fill{fill:#444}.ql-snow .ql-empty{fill:none}.ql-snow .ql-even{fill-rule:evenodd}.ql-snow .ql-stroke.ql-thin,.ql-snow .ql-thin{stroke-width:1}.ql-snow .ql-transparent{opacity:.4}.ql-snow .ql-direction svg:last-child{display:none}.ql-snow .ql-direction.ql-active svg:last-child{display:inline}.ql-snow .ql-direction.ql-active svg:first-child{display:none}.ql-snow .ql-editor h1{font-size:2em}.ql-snow .ql-editor h2{font-size:1.5em}.ql-snow .ql-editor h3{font-size:1.17em}.ql-snow .ql-editor h4{font-size:1em}.ql-snow .ql-editor h5{font-size:.83em}.ql-snow .ql-editor h6{font-size:.67em}.ql-snow .ql-editor a{text-decoration:underline}.ql-snow .ql-editor blockquote{border-left:4px solid #ccc;margin-bottom:5px;margin-top:5px;padding-left:16px}.ql-snow .ql-editor .ql-code-block-container,.ql-snow .ql-editor code{background-color:#f0f0f0;border-radius:3px}.ql-snow .ql-editor .ql-code-block-container{margin-bottom:5px;margin-top:5px;padding:5px 10px}.ql-snow .ql-editor code{font-size:85%;padding:2px 4px}.ql-snow .ql-editor .ql-code-block-container{background-color:#23241f;color:#f8f8f2;overflow:visible}.ql-snow .ql-editor img{max-width:100%}.ql-snow .ql-picker{color:#444;display:inline-block;float:left;font-size:14px;font-weight:500;height:24px;position:relative;vertical-align:middle}.ql-snow .ql-picker-label{cursor:pointer;display:inline-block;height:100%;padding-left:8px;padding-right:2px;position:relative;width:100%}.ql-snow .ql-picker-label:before{display:inline-block;line-height:22px}.ql-snow .ql-picker-options{background-color:#fff;display:none;min-width:100%;padding:4px 8px;position:absolute;white-space:nowrap}.ql-snow .ql-picker-options .ql-picker-item{cursor:pointer;display:block;padding-bottom:5px;padding-top:5px}.ql-snow .ql-picker.ql-expanded .ql-picker-label{color:#ccc;z-index:2}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-fill{fill:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-stroke{stroke:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-options{display:block;margin-top:-1px;top:100%;z-index:1}.ql-snow .ql-color-picker,.ql-snow .ql-icon-picker{width:28px}.ql-snow .ql-color-picker .ql-picker-label,.ql-snow .ql-icon-picker .ql-picker-label{padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-label svg,.ql-snow .ql-icon-picker .ql-picker-label svg{right:4px}.ql-snow .ql-icon-picker .ql-picker-options{padding:4px 0}.ql-snow .ql-icon-picker .ql-picker-item{height:24px;padding:2px 4px;width:24px}.ql-snow .ql-color-picker .ql-picker-options{padding:3px 5px;width:152px}.ql-snow .ql-color-picker .ql-picker-item{border:1px solid transparent;float:left;height:16px;margin:2px;padding:0;width:16px}.ql-snow .ql-picker:not(.ql-color-picker):not(.ql-icon-picker) svg{margin-top:-9px;position:absolute;right:0;top:50%;width:18px}.ql-snow .ql-picker.ql-font .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-label]:not([data-label=""]):before{content:attr(data-label)}.ql-snow .ql-picker.ql-header{width:98px}.ql-snow .ql-picker.ql-header .ql-picker-item:before,.ql-snow .ql-picker.ql-header .ql-picker-label:before{content:"Normal"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="1"]:before{content:"Heading 1"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="2"]:before{content:"Heading 2"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="3"]:before{content:"Heading 3"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="4"]:before{content:"Heading 4"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="5"]:before{content:"Heading 5"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="6"]:before{content:"Heading 6"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{font-size:2em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{font-size:1.5em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{font-size:1.17em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{font-size:1em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{font-size:.83em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{font-size:.67em}.ql-snow .ql-picker.ql-font{width:108px}.ql-snow .ql-picker.ql-font .ql-picker-item:before,.ql-snow .ql-picker.ql-font .ql-picker-label:before{content:"Sans Serif"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=serif]:before{content:"Serif"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=monospace]:before{content:"Monospace"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{font-family:Georgia,Times New Roman,serif}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{font-family:Monaco,Courier New,monospace}.ql-snow .ql-picker.ql-size{width:98px}.ql-snow .ql-picker.ql-size .ql-picker-item:before,.ql-snow .ql-picker.ql-size .ql-picker-label:before{content:"Normal"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=small]:before{content:"Small"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=large]:before{content:"Large"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=huge]:before{content:"Huge"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{font-size:10px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{font-size:18px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{font-size:32px}.ql-snow .ql-color-picker.ql-background .ql-picker-item{background-color:#fff}.ql-snow .ql-color-picker.ql-color .ql-picker-item{background-color:#000}.ql-code-block-container{position:relative}.ql-code-block-container .ql-ui{right:5px;top:5px}.ql-toolbar.ql-snow{border:1px solid #ccc;box-sizing:border-box;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;padding:8px}.ql-toolbar.ql-snow .ql-formats{margin-right:15px}.ql-toolbar.ql-snow .ql-picker-label{border:1px solid transparent}.ql-toolbar.ql-snow .ql-picker-options{border:1px solid transparent;box-shadow:0 2px 8px rgba(0,0,0,.2)}.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-label,.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-options{border-color:#ccc}.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item.ql-selected,.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item:hover{border-color:#000}.ql-toolbar.ql-snow+.ql-container.ql-snow{border-top:0}.ql-snow .ql-tooltip{background-color:#fff;border:1px solid #ccc;box-shadow:0 0 5px #ddd;color:#444;padding:5px 12px;white-space:nowrap}.ql-snow .ql-tooltip:before{content:"Visit URL:";line-height:26px;margin-right:8px}.ql-snow .ql-tooltip input[type=text]{border:1px solid #ccc;display:none;font-size:13px;height:26px;margin:0;padding:3px 5px;width:170px}.ql-snow .ql-tooltip a.ql-preview{display:inline-block;max-width:200px;overflow-x:hidden;text-overflow:ellipsis;vertical-align:top}.ql-snow .ql-tooltip a.ql-action:after{border-right:1px solid #ccc;content:"Edit";margin-left:16px;padding-right:8px}.ql-snow .ql-tooltip a.ql-remove:before{content:"Remove";margin-left:8px}.ql-snow .ql-tooltip a{line-height:26px}.ql-snow .ql-tooltip.ql-editing a.ql-preview,.ql-snow .ql-tooltip.ql-editing a.ql-remove{display:none}.ql-snow .ql-tooltip.ql-editing input[type=text]{display:inline-block}.ql-snow .ql-tooltip.ql-editing a.ql-action:after{border-right:0;content:"Save";padding-right:0}.ql-snow .ql-tooltip[data-mode=link]:before{content:"Enter link:"}.ql-snow .ql-tooltip[data-mode=formula]:before{content:"Enter formula:"}.ql-snow .ql-tooltip[data-mode=video]:before{content:"Enter video:"}.ql-snow a{color:#06c}.ql-container.ql-snow{border:1px solid #ccc}.template-selector{display:flex;gap:20px;height:100%;min-height:500px}.template-selector-left,.template-selector-right{background:#fff;border:1px solid #e0e0e0;border-radius:8px;display:flex;flex:1 1;flex-direction:column;overflow:hidden}.template-selector-left,.template-selector-right{max-width:50%}.panel-header{background:#f5f7fa;border-bottom:1px solid #e0e0e0;padding:12px 16px}.panel-header h4{color:#333;font-size:14px;font-weight:600;margin:0}.template-tree{flex:1 1;overflow-y:auto;padding:8px}.template-error,.template-loading{color:#666;padding:20px;text-align:center}.template-error{color:#d32f2f}.template-grade{margin-bottom:4px}.template-grade-header{align-items:center;background:#f8f9fa;border-radius:4px;cursor:pointer;display:flex;padding:8px 10px;transition:background .2s}.template-grade-header:hover{background:#e8f0fe}.template-grade-name{color:#333;flex:1 1;font-weight:600}.template-count{color:#888;font-size:12px;margin-left:8px}.template-subjects{border-left:2px solid #e0e0e0;margin-left:16px;margin-top:4px;padding-left:8px}.template-subject{margin-bottom:2px}.template-subject-header{align-items:center;border-radius:4px;cursor:pointer;display:flex;padding:6px 8px;transition:background .2s}.template-subject-header:hover{background:#f0f0f0}.template-subject-name{color:#444;flex:1 1;font-weight:500}.template-items{border-left:2px solid #e8e8e8;margin-left:16px;margin-top:2px;padding-left:8px}.template-item{align-items:center;border-radius:4px;cursor:pointer;display:flex;padding:4px 8px;transition:background .2s}.template-item:hover{background:#f5f5f5}.template-item.selected{background:#e3f2fd}.template-item-name{color:#555;flex:1 1;font-size:13px}.template-checkbox{align-items:center;border:2px solid #666;border-radius:3px;cursor:pointer;display:inline-flex;flex-shrink:0;font-size:12px;font-weight:700;height:18px;justify-content:center;margin-right:8px;transition:all .2s;width:18px}.template-checkbox.unchecked{background:#fff;border-color:#999}.template-checkbox.checked{background:#1976d2;border-color:#1976d2;color:#fff}.template-checkbox.partial{background:#9e9e9e;border-color:#9e9e9e;color:#fff}.template-checkbox:hover{border-color:#1976d2}.template-checkbox.disabled{cursor:not-allowed;opacity:.5}.template-checkbox.disabled:hover{border-color:#ddd}.template-item.invalid{background:#fff3e0;opacity:.6}.template-item-invalid-badge{font-size:12px;margin-left:auto}.template-expand-icon{color:#888;flex-shrink:0;font-size:10px;margin-right:6px;width:16px}.selected-empty{align-items:center;color:#888;display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:40px;text-align:center}.selected-empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.selected-empty p{margin:4px 0}.selected-empty .hint{color:#aaa;font-size:13px}.selected-items-list{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.selected-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:10px 16px}.selected-count{color:#666;font-size:13px;font-weight:500}.btn-clear-all{background:transparent;border:1px solid #d32f2f;border-radius:4px;color:#d32f2f;cursor:pointer;font-size:12px;padding:4px 10px;transition:all .2s}.btn-clear-all:hover{background:#d32f2f;color:#fff}.selected-items-container{flex:1 1;overflow-y:auto;padding:8px}.selected-item{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:6px;cursor:grab;display:flex;margin-bottom:6px;padding:10px 12px;transition:all .2s}.selected-item:hover{border-color:#1976d2;box-shadow:0 2px 4px rgba(0,0,0,.1)}.selected-item.dragging{background:#f0f0f0;opacity:.5}.selected-item.drag-over{background:#e3f2fd;border-color:#1976d2;border-style:dashed}.drag-handle{color:#aaa;cursor:grab;flex-shrink:0;font-size:14px;margin-right:10px}.selected-item-content{flex:1 1;min-width:0}.selected-item-name{color:#333;display:block;font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.selected-item-meta{color:#888;display:block;font-size:11px;margin-top:2px}.btn-remove-item{align-items:center;background:transparent;border:none;border-radius:4px;color:#999;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;height:24px;justify-content:center;transition:all .2s;width:24px}.btn-remove-item:hover{background:#ffebee;color:#d32f2f}@media (max-width:900px){.template-selector{flex-direction:column}.template-selector-left,.template-selector-right{max-width:100%;min-height:300px}}.course-management-page{margin:0 auto;max-width:1400px;padding:20px}.page-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.header-left h2{color:#1e293b;font-size:1.75rem;font-weight:600;margin:0}.page-description{color:#64748b;font-size:.95rem;margin-top:4px}.header-right{display:flex;gap:12px}.btn-primary{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);display:inline-flex;font-size:.95rem;gap:6px;transition:all .2s ease}.btn-primary:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 12px rgba(59,130,246,.3);transform:translateY(-1px)}.btn-primary:disabled{opacity:.6;transform:none}.btn-secondary{background:#f1f5f9;border:1px solid #e2e8f0;color:#475569;font-size:.95rem;transition:all .2s ease}.btn-secondary:hover{border-color:#cbd5e1}.message{border-radius:8px;font-size:.95rem;margin-bottom:16px;padding:12px 16px}.message.success{background:#dcfce7;border:1px solid #86efac;color:#166534}.message.error{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b}.filters-bar{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:20px;padding:16px}.filter-group{display:flex;flex-direction:column;gap:4px}.filter-input{background:#fff;border:1px solid #e2e8f0;border-radius:8px;font-size:.95rem;min-width:220px;padding:10px 14px;transition:all .2s ease}.filter-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.1);outline:none}.filter-select{background:#fff;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;font-size:.95rem;min-width:160px;padding:10px 14px;transition:all .2s ease}.filter-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.1);outline:none}.filter-results{color:#64748b;font-size:.9rem;margin-left:auto;padding:10px 0}.loading-state{align-items:center;color:#64748b;display:flex;flex-direction:column;justify-content:center;padding:60px 20px}.loading-spinner{animation:spin .8s linear infinite;border:3px solid #e2e8f0;border-top-color:#3b82f6}.error-state{align-items:center;color:#dc2626;display:flex;flex-direction:column;justify-content:center;padding:60px 20px;text-align:center}.error-icon{font-size:2rem;margin-bottom:12px}.error-state button{margin-top:12px}.courses-table{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px rgba(0,0,0,.05);overflow:hidden}.courses-table table{border-collapse:collapse;width:100%}.courses-table th{background:#f8fafc;border-bottom:1px solid #e2e8f0;color:#475569;font-size:.85rem;font-weight:600;letter-spacing:.05em;padding:14px 16px;text-align:left;text-transform:uppercase}.courses-table td{border-bottom:1px solid #f1f5f9;color:#334155;font-size:.95rem;padding:14px 16px}.courses-table tbody tr:hover{background:#f8fafc}.courses-table tbody tr:last-child td{border-bottom:none}.course-code{color:#3b82f6;font-family:Monaco,Menlo,monospace}.no-data{color:#94a3b8;padding:40px 16px!important}.status-active{background:#dcfce7;color:#166534}.status-inactive{background:#f1f5f9;color:#64748b}.status-draft{background:#fef3c7;color:#92400e}.status-enrolled{background:#dbeafe;color:#1e40af}.status-completed{background:#dcfce7;color:#166534}.status-withdrawn{background:#fee2e2;color:#991b1b}.action-btn{align-items:center;border:none;border-radius:6px;display:flex;font-size:1rem;height:32px;justify-content:center;transition:all .2s ease;width:32px}.action-btn:hover{transform:scale(1.1)}.enroll-btn{background:#dbeafe}.enroll-btn:hover{background:#bfdbfe}.edit-btn{background:#fef3c7}.edit-btn:hover{background:#fde68a}.delete-btn{background:#fee2e2}.delete-btn:hover{background:#fecaca}.withdraw-btn{background:#fee2e2}.withdraw-btn:hover{background:#fecaca}.pagination-controls{align-items:center;display:flex;gap:12px;justify-content:center;margin-top:12px;padding:20px}.pagination-btn{background:#fff;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;font-size:.9rem;padding:8px 14px;transition:all .2s ease}.pagination-btn:hover:not(:disabled){background:#f1f5f9;border-color:#cbd5e1}.pagination-btn:disabled{cursor:not-allowed;opacity:.5}.pagination-info{color:#64748b;font-size:.9rem;padding:0 12px}.course-modal{max-width:600px}.course-modal,.enrollment-modal{background:#fff;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.2);display:flex;flex-direction:column;max-height:90vh;overflow:hidden;width:100%}.enrollment-modal{max-width:800px}.modal-header{background:#f8fafc;border-bottom:1px solid #e2e8f0}.modal-header h3{color:#1e293b;font-size:1.25rem;font-weight:600}.modal-close{border-radius:4px;color:#64748b;padding:4px;transition:all .2s ease}.modal-close:hover{background:#e2e8f0;color:#334155}.modal-body{flex:1 1;overflow-y:auto;padding:24px}.modal-footer{background:#f8fafc;border-top:1px solid #e2e8f0;gap:12px;padding:16px 24px}.form-row{grid-template-columns:1fr 1fr}.form-group label{color:#475569}.form-input,.form-select,.form-textarea{border:1px solid #e2e8f0;box-sizing:border-box;padding:10px 14px;transition:all .2s ease}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.1)}.form-textarea{min-height:80px}.enroll-section{background:#f8fafc;border-radius:12px;margin-bottom:24px;padding:20px}.enroll-section h4{color:#1e293b;font-size:1rem;font-weight:600;margin:0 0 16px}.enroll-form{align-items:flex-end;display:flex;flex-wrap:wrap;gap:16px}.enroll-form .form-group{flex:1 1;margin-bottom:0;min-width:200px}.enroll-form .btn-primary.enroll-btn{height:44px;white-space:nowrap}.enrolled-section{border:1px solid #e2e8f0;border-radius:12px;padding:20px}.enrolled-section h4{color:#1e293b;font-size:1rem;font-weight:600;margin:0 0 16px}.no-students{color:#64748b;padding:30px;text-align:center}.enrolled-list{overflow-x:auto}.enrolled-table{border-collapse:collapse;width:100%}.enrolled-table th{background:#f1f5f9;color:#475569;font-size:.8rem;font-weight:600;letter-spacing:.05em;padding:12px;text-align:left;text-transform:uppercase}.enrolled-table td{border-bottom:1px solid #f1f5f9;color:#334155;font-size:.9rem;padding:12px}.enrolled-table tbody tr:hover{background:#f8fafc}.progress-bar{border-radius:8px;height:20px;min-width:80px;position:relative}.progress-fill{background:linear-gradient(90deg,#3b82f6,#2563eb);border-radius:8px;transition:width .3s ease}.progress-text{color:#334155;font-size:.75rem;font-weight:600;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}@media (max-width:768px){.course-management-page{padding:16px}.page-header{align-items:stretch;flex-direction:column;text-align:center}.header-right{justify-content:center}.filters-bar{flex-direction:column}.filter-input,.filter-select{min-width:auto;width:100%}.filter-results{margin-left:0;text-align:center}.courses-table{overflow-x:auto}.courses-table table{min-width:700px}.form-row{grid-template-columns:1fr}.modal-overlay{padding:10px}.course-modal,.enrollment-modal{max-height:95vh;max-width:100%}.enroll-form{flex-direction:column}.enroll-form .form-group{width:100%}}.division-home{background:linear-gradient(135deg,#f5f7fa,#e4e9f2);min-height:100vh}.division-navbar{align-items:center;background:#fff;box-shadow:0 2px 10px rgba(0,0,0,.1);display:flex;justify-content:space-between;padding:1rem 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:100}.division-navbar .navbar-left{align-items:center;display:flex;gap:1rem}.division-navbar h1{color:#1a365d;font-size:1.5rem;margin:0}.division-navbar .brand-title{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#1976d2,#42a5f5);-webkit-background-clip:text;background-clip:text;font-size:1.75rem;font-weight:700}.division-navbar .navbar-subtitle{border-left:2px solid #e2e8f0;color:#718096;font-size:.9rem;padding-left:1rem}.division-navbar .navbar-user{align-items:center;display:flex;gap:1rem}.division-navbar .navbar-roles{display:flex;gap:.25rem}.role-badge-small{background:#e2e8f0;border-radius:4px;color:#4a5568;padding:.2rem .5rem}.role-badge-small.more{background:#cbd5e0}.btn-back{background:transparent;border:1px solid #e2e8f0;border-radius:6px;color:#4a5568;padding:.5rem 1rem;transition:all .2s}.btn-back:hover{background:#f7fafc;border-color:#cbd5e0}.btn-secondary{background:#edf2f7;border:none;border-radius:6px;color:#4a5568;font-size:.85rem;padding:.5rem 1rem}.btn-secondary:hover{background:#e2e8f0}.btn-logout{background:#e53e3e;border:none;font-size:.85rem;padding:.5rem 1rem}.btn-logout:hover{background:#c53030}.btn-primary{background:#3182ce;border-radius:6px;font-size:1rem;padding:.75rem 1.5rem}.btn-primary:hover{background:#2c5282}.division-container{margin:0 auto;max-width:1400px;padding:2rem}.division-header{margin-bottom:2rem;text-align:center}.division-header h2{color:#1a365d;font-size:2rem;margin-bottom:.5rem}.division-subtitle{color:#718096;font-size:1rem}.division-header.submenu-header{align-items:center;background:#fff;border-left:4px solid #3182ce;border-left:4px solid var(--division-color,#3182ce);border-radius:12px;box-shadow:0 2px 10px rgba(0,0,0,.05);display:flex;gap:1.5rem;justify-content:flex-start;padding:1.5rem 2rem;text-align:left}.division-header-icon{align-items:center;background:#ebf8ff;background:var(--division-color-light,#ebf8ff);border-radius:12px;display:flex;font-size:3rem;height:80px;justify-content:center;width:80px}.division-header-text h2{font-size:1.75rem;margin:0 0 .25rem}.division-header-text .division-subtitle{margin:0}.division-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.division-card{background:#fff;border:2px solid transparent;border-radius:16px;box-shadow:0 4px 15px rgba(0,0,0,.08);cursor:pointer;display:flex;flex-direction:column;min-height:200px;overflow:hidden;padding:1.5rem;position:relative;transition:all .3s ease}.division-card.accessible{border-color:#3182ce;border-color:var(--division-color,#3182ce)}.division-card.accessible:hover{box-shadow:0 8px 25px rgba(0,0,0,.15);transform:translateY(-5px)}.division-card.accessible:before{background:#3182ce;background:var(--division-color,#3182ce);content:"";height:4px;left:0;position:absolute;right:0;top:0}.division-card.disabled{background:#f7fafc;cursor:not-allowed;opacity:.6}.division-card-icon{align-items:center;border-radius:12px;display:flex;font-size:2.5rem;height:60px;justify-content:center;margin-bottom:1rem;width:60px}.division-card-icon,.division-card.accessible .division-card-icon{background:#f0f5ff;background:var(--division-color-light,#f0f5ff)}.division-card.disabled .division-card-icon{background:#e2e8f0;filter:grayscale(100%)}.division-card-content h3{color:#1a365d;font-size:1.25rem;margin:0 0 .5rem}.division-card.disabled .division-card-content h3{color:#718096}.division-card-content p{color:#718096;font-size:.9rem;line-height:1.5;margin:0 0 1rem}.division-card-submenus{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:auto}.submenu-tag{background:#edf2f7;border-radius:4px;color:#4a5568;font-size:.75rem;padding:.25rem .5rem}.division-card.accessible .submenu-tag{background:#ebf8ff;background:var(--division-color-light,#ebf8ff);color:#3182ce;color:var(--division-color,#3182ce)}.submenu-tag.more{background:#e2e8f0;color:#718096}.division-card-overlay{align-items:center;background:hsla(0,0%,100%,.7);bottom:0;display:flex;flex-direction:column;gap:.5rem;justify-content:center;left:0;position:absolute;right:0;top:0}.lock-icon{font-size:2rem;opacity:.5}.division-card-overlay span:last-child{color:#718096;font-size:.9rem;font-weight:500}.submenu-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-top:2rem}.submenu-card{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 10px rgba(0,0,0,.06);cursor:pointer;display:flex;gap:1rem;padding:1.5rem;position:relative;transition:all .3s ease}.submenu-card.accessible,.submenu-card.accessible:hover{border-color:#3182ce;border-color:var(--division-color,#3182ce)}.submenu-card.accessible:hover{box-shadow:0 4px 15px rgba(0,0,0,.1);transform:translateX(5px)}.submenu-card.disabled{background:#f7fafc;cursor:not-allowed;opacity:.5}.submenu-card-icon{align-items:center;background:#f0f5ff;background:var(--division-color-light,#f0f5ff);border-radius:10px;display:flex;flex-shrink:0;font-size:1.75rem;height:50px;justify-content:center;width:50px}.submenu-card.disabled .submenu-card-icon{background:#e2e8f0;filter:grayscale(100%)}.submenu-card-content{flex:1 1}.submenu-card-content h3{color:#1a365d;font-size:1.1rem;margin:0 0 .25rem}.submenu-card.disabled .submenu-card-content h3{color:#718096}.submenu-card-content p{color:#718096;font-size:.85rem;margin:0}.submenu-card-arrow{color:#3182ce;color:var(--division-color,#3182ce);font-size:1.25rem;opacity:0;transition:opacity .2s,transform .2s}.submenu-card.accessible:hover .submenu-card-arrow{opacity:1;transform:translateX(3px)}.submenu-card-overlay{position:absolute;right:1rem;top:50%;transform:translateY(-50%)}.no-access-message{background:#fff;border-radius:12px;box-shadow:0 2px 10px rgba(0,0,0,.05);margin-top:2rem;padding:3rem;text-align:center}.no-access-icon{display:block;font-size:3rem;margin-bottom:1rem}.no-access-message h3{color:#1a365d;margin:0 0 .5rem}.no-access-message p{color:#718096;margin-bottom:1.5rem}.error-message{background:#fff;border-radius:12px;box-shadow:0 2px 10px rgba(0,0,0,.05);padding:3rem}.error-message h2{color:#c53030;margin-bottom:.5rem}.error-message p{color:#718096;margin-bottom:1.5rem}@media (max-width:768px){.division-navbar{flex-direction:column;gap:1rem;padding:1rem}.division-navbar .navbar-left,.division-navbar .navbar-user{flex-wrap:wrap;justify-content:center;width:100%}.division-container{padding:1rem}.division-grid,.submenu-grid{grid-template-columns:1fr}.division-header.submenu-header{flex-direction:column;text-align:center}}*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb;box-sizing:border-box}:after,:before{--tw-content:""}:host,html{-webkit-text-size-adjust:100%;font-feature-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-variation-settings:normal;line-height:1.5;tab-size:4}body{line-height:inherit;margin:0}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-feature-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{font-feature-settings:inherit;color:inherit;font-family:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.visible{visibility:visible}.collapse{visibility:collapse}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:-webkit-sticky;position:sticky}.inset-0{inset:0}.inset-y-0{bottom:0;top:0}.-bottom-16{bottom:-4rem}.-bottom-20{bottom:-5rem}.-left-16{left:-4rem}.-left-40{left:-10rem}.-right-20{right:-5rem}.-right-24{right:-6rem}.-top-24{top:-6rem}.-top-40{top:-10rem}.bottom-0{bottom:0}.bottom-2{bottom:.5rem}.left-0{left:0}.left-1\/4{left:25%}.left-5{left:1.25rem}.left-\[15px\]{left:15px}.right-0{right:0}.right-3{right:.75rem}.right-4{right:1rem}.top-0{top:0}.top-1\/2{top:50%}.top-2{top:.5rem}.top-3{top:.75rem}.top-4{top:1rem}.z-10{z-index:10}.z-50{z-index:50}.m-6{margin:1.5rem}.mx-2{margin-left:.5rem;margin-right:.5rem}.mx-3{margin-left:.75rem;margin-right:.75rem}.mx-4{margin-left:1rem;margin-right:1rem}.mx-auto{margin-left:auto;margin-right:auto}.my-8{margin-bottom:2rem;margin-top:2rem}.mb-1{margin-bottom:.25rem}.mb-1\.5{margin-bottom:.375rem}.mb-10{margin-bottom:2.5rem}.mb-12{margin-bottom:3rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-1\.5{margin-left:.375rem}.ml-2{margin-left:.5rem}.ml-3{margin-left:.75rem}.mr-1\.5{margin-right:.375rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.line-clamp-2{-webkit-box-orient:vertical;-webkit-line-clamp:2;display:-webkit-box;overflow:hidden}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.h-0\.5{height:.125rem}.h-1{height:.25rem}.h-1\.5{height:.375rem}.h-10{height:2.5rem}.h-11{height:2.75rem}.h-12{height:3rem}.h-14{height:3.5rem}.h-16{height:4rem}.h-2{height:.5rem}.h-24{height:6rem}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-40{height:10rem}.h-5{height:1.25rem}.h-56{height:14rem}.h-6{height:1.5rem}.h-64{height:16rem}.h-7{height:1.75rem}.h-72{height:18rem}.h-8{height:2rem}.h-80{height:20rem}.h-9{height:2.25rem}.h-96{height:24rem}.h-full{height:100%}.h-px{height:1px}.max-h-48{max-height:12rem}.max-h-60{max-height:15rem}.max-h-64{max-height:16rem}.max-h-72{max-height:18rem}.max-h-\[70vh\]{max-height:70vh}.max-h-\[85vh\]{max-height:85vh}.min-h-full{min-height:100%}.min-h-screen{min-height:100vh}.w-1\.5{width:.375rem}.w-10{width:2.5rem}.w-11{width:2.75rem}.w-12{width:3rem}.w-14{width:3.5rem}.w-16{width:4rem}.w-2{width:.5rem}.w-24{width:6rem}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-32{width:8rem}.w-48{width:12rem}.w-5{width:1.25rem}.w-56{width:14rem}.w-6{width:1.5rem}.w-7{width:1.75rem}.w-72{width:18rem}.w-8{width:2rem}.w-80{width:20rem}.w-9{width:2.25rem}.w-96{width:24rem}.w-fit{width:-webkit-fit-content;width:fit-content}.w-full{width:100%}.w-px{width:1px}.min-w-0{min-width:0}.min-w-\[320px\]{min-width:320px}.min-w-full{min-width:100%}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-6xl{max-width:72rem}.max-w-\[100px\]{max-width:100px}.max-w-\[80px\]{max-width:80px}.max-w-lg{max-width:32rem}.max-w-md{max-width:28rem}.max-w-sm{max-width:24rem}.max-w-xl{max-width:36rem}.max-w-xs{max-width:20rem}.flex-1{flex:1 1}.flex-shrink-0,.shrink-0{flex-shrink:0}.-translate-y-full{--tw-translate-y:-100%}.-translate-y-full,.translate-x-0{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-0{--tw-translate-x:0px}.translate-x-1{--tw-translate-x:0.25rem}.translate-x-1,.translate-x-full{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-full{--tw-translate-x:100%}.translate-y-0{--tw-translate-y:0px}.translate-y-0,.translate-y-full{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-full{--tw-translate-y:100%}.rotate-180{--tw-rotate:180deg}.rotate-180,.rotate-90{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.rotate-90{--tw-rotate:90deg}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.animate-spin{animation:spin 1s linear infinite}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.resize-none{resize:none}.appearance-none{-webkit-appearance:none;appearance:none}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-2\.5{gap:.625rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-6{gap:1.5rem}.gap-x-4{column-gap:1rem}.gap-y-1{row-gap:.25rem}.space-y-0>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(0px*var(--tw-space-y-reverse));margin-top:calc(0px*(1 - var(--tw-space-y-reverse)))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.5rem*var(--tw-space-y-reverse));margin-top:calc(.5rem*(1 - var(--tw-space-y-reverse)))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.75rem*var(--tw-space-y-reverse));margin-top:calc(.75rem*(1 - var(--tw-space-y-reverse)))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1rem*var(--tw-space-y-reverse));margin-top:calc(1rem*(1 - var(--tw-space-y-reverse)))}.space-y-5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1.25rem*var(--tw-space-y-reverse));margin-top:calc(1.25rem*(1 - var(--tw-space-y-reverse)))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1.5rem*var(--tw-space-y-reverse));margin-top:calc(1.5rem*(1 - var(--tw-space-y-reverse)))}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse:0;border-bottom-width:calc(1px*var(--tw-divide-y-reverse));border-top-width:calc(1px*(1 - var(--tw-divide-y-reverse)))}.divide-gray-100>:not([hidden])~:not([hidden]){--tw-divide-opacity:1;border-color:#f3f4f6;border-color:rgb(243 244 246/var(--tw-divide-opacity,1))}.divide-slate-100>:not([hidden])~:not([hidden]){--tw-divide-opacity:1;border-color:#f1f5f9;border-color:rgb(241 245 249/var(--tw-divide-opacity,1))}.divide-slate-200>:not([hidden])~:not([hidden]){--tw-divide-opacity:1;border-color:#e2e8f0;border-color:rgb(226 232 240/var(--tw-divide-opacity,1))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-visible{overflow:visible}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis}.truncate,.whitespace-nowrap{white-space:nowrap}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-xl{border-radius:.75rem}.rounded-b-2xl{border-bottom-left-radius:1rem;border-bottom-right-radius:1rem}.rounded-b-xl{border-bottom-left-radius:.75rem;border-bottom-right-radius:.75rem}.rounded-t-2xl{border-top-left-radius:1rem;border-top-right-radius:1rem}.border{border-width:1px}.border-0{border-width:0}.border-2{border-width:2px}.border-4{border-width:4px}.border-b{border-bottom-width:1px}.border-dashed{border-style:dashed}.border-\[\#1565c0\]\/30{border-color:rgba(21,101,192,.3)}.border-amber-200{--tw-border-opacity:1;border-color:#fde68a;border-color:rgb(253 230 138/var(--tw-border-opacity,1))}.border-blue-100{--tw-border-opacity:1;border-color:#dbeafe;border-color:rgb(219 234 254/var(--tw-border-opacity,1))}.border-blue-200{--tw-border-opacity:1;border-color:#bfdbfe;border-color:rgb(191 219 254/var(--tw-border-opacity,1))}.border-blue-300{--tw-border-opacity:1;border-color:#93c5fd;border-color:rgb(147 197 253/var(--tw-border-opacity,1))}.border-blue-500{--tw-border-opacity:1;border-color:#3b82f6;border-color:rgb(59 130 246/var(--tw-border-opacity,1))}.border-emerald-200{--tw-border-opacity:1;border-color:#a7f3d0;border-color:rgb(167 243 208/var(--tw-border-opacity,1))}.border-gray-100{--tw-border-opacity:1;border-color:#f3f4f6;border-color:rgb(243 244 246/var(--tw-border-opacity,1))}.border-gray-200{--tw-border-opacity:1;border-color:#e5e7eb;border-color:rgb(229 231 235/var(--tw-border-opacity,1))}.border-gray-300{--tw-border-opacity:1;border-color:#d1d5db;border-color:rgb(209 213 219/var(--tw-border-opacity,1))}.border-green-200{--tw-border-opacity:1;border-color:#bbf7d0;border-color:rgb(187 247 208/var(--tw-border-opacity,1))}.border-green-300{--tw-border-opacity:1;border-color:#86efac;border-color:rgb(134 239 172/var(--tw-border-opacity,1))}.border-red-200{--tw-border-opacity:1;border-color:#fecaca;border-color:rgb(254 202 202/var(--tw-border-opacity,1))}.border-red-300{--tw-border-opacity:1;border-color:#fca5a5;border-color:rgb(252 165 165/var(--tw-border-opacity,1))}.border-slate-100{--tw-border-opacity:1;border-color:#f1f5f9;border-color:rgb(241 245 249/var(--tw-border-opacity,1))}.border-slate-100\/60{border-color:rgba(241,245,249,.6)}.border-slate-200{--tw-border-opacity:1;border-color:#e2e8f0;border-color:rgb(226 232 240/var(--tw-border-opacity,1))}.border-slate-200\/80{border-color:rgba(226,232,240,.8)}.border-slate-300{--tw-border-opacity:1;border-color:#cbd5e1;border-color:rgb(203 213 225/var(--tw-border-opacity,1))}.border-slate-50{--tw-border-opacity:1;border-color:#f8fafc;border-color:rgb(248 250 252/var(--tw-border-opacity,1))}.border-slate-800{--tw-border-opacity:1;border-color:#1e293b;border-color:rgb(30 41 59/var(--tw-border-opacity,1))}.border-violet-200{--tw-border-opacity:1;border-color:#ddd6fe;border-color:rgb(221 214 254/var(--tw-border-opacity,1))}.border-white\/20{border-color:hsla(0,0%,100%,.2)}.border-white\/30{border-color:hsla(0,0%,100%,.3)}.border-t-blue-600{--tw-border-opacity:1;border-top-color:#2563eb;border-top-color:rgb(37 99 235/var(--tw-border-opacity,1))}.border-t-transparent{border-top-color:transparent}.border-t-white{--tw-border-opacity:1;border-top-color:#fff;border-top-color:rgb(255 255 255/var(--tw-border-opacity,1))}.bg-\[\#1565c0\]{--tw-bg-opacity:1;background-color:#1565c0;background-color:rgb(21 101 192/var(--tw-bg-opacity,1))}.bg-amber-100{--tw-bg-opacity:1;background-color:#fef3c7;background-color:rgb(254 243 199/var(--tw-bg-opacity,1))}.bg-amber-50{--tw-bg-opacity:1;background-color:#fffbeb;background-color:rgb(255 251 235/var(--tw-bg-opacity,1))}.bg-amber-50\/50{background-color:rgba(255,251,235,.5)}.bg-amber-500{--tw-bg-opacity:1;background-color:#f59e0b;background-color:rgb(245 158 11/var(--tw-bg-opacity,1))}.bg-black\/40{background-color:rgba(0,0,0,.4)}.bg-blue-100{--tw-bg-opacity:1;background-color:#dbeafe;background-color:rgb(219 234 254/var(--tw-bg-opacity,1))}.bg-blue-100\/80{background-color:rgba(219,234,254,.8)}.bg-blue-50{--tw-bg-opacity:1;background-color:#eff6ff;background-color:rgb(239 246 255/var(--tw-bg-opacity,1))}.bg-blue-50\/50{background-color:rgba(239,246,255,.5)}.bg-blue-500{--tw-bg-opacity:1;background-color:#3b82f6;background-color:rgb(59 130 246/var(--tw-bg-opacity,1))}.bg-blue-600{--tw-bg-opacity:1;background-color:#2563eb;background-color:rgb(37 99 235/var(--tw-bg-opacity,1))}.bg-cyan-50{--tw-bg-opacity:1;background-color:#ecfeff;background-color:rgb(236 254 255/var(--tw-bg-opacity,1))}.bg-cyan-500{--tw-bg-opacity:1;background-color:#06b6d4;background-color:rgb(6 182 212/var(--tw-bg-opacity,1))}.bg-emerald-50{--tw-bg-opacity:1;background-color:#ecfdf5;background-color:rgb(236 253 245/var(--tw-bg-opacity,1))}.bg-emerald-50\/30{background-color:rgba(236,253,245,.3)}.bg-emerald-500{--tw-bg-opacity:1;background-color:#10b981;background-color:rgb(16 185 129/var(--tw-bg-opacity,1))}.bg-gray-100{--tw-bg-opacity:1;background-color:#f3f4f6;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}.bg-gray-200{--tw-bg-opacity:1;background-color:#e5e7eb;background-color:rgb(229 231 235/var(--tw-bg-opacity,1))}.bg-gray-50{--tw-bg-opacity:1;background-color:#f9fafb;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.bg-gray-50\/50{background-color:rgba(249,250,251,.5)}.bg-green-100{--tw-bg-opacity:1;background-color:#dcfce7;background-color:rgb(220 252 231/var(--tw-bg-opacity,1))}.bg-green-300{--tw-bg-opacity:1;background-color:#86efac;background-color:rgb(134 239 172/var(--tw-bg-opacity,1))}.bg-green-50{--tw-bg-opacity:1;background-color:#f0fdf4;background-color:rgb(240 253 244/var(--tw-bg-opacity,1))}.bg-green-50\/30{background-color:rgba(240,253,244,.3)}.bg-green-50\/50{background-color:rgba(240,253,244,.5)}.bg-green-500{--tw-bg-opacity:1;background-color:#22c55e;background-color:rgb(34 197 94/var(--tw-bg-opacity,1))}.bg-indigo-50{--tw-bg-opacity:1;background-color:#eef2ff;background-color:rgb(238 242 255/var(--tw-bg-opacity,1))}.bg-indigo-500{--tw-bg-opacity:1;background-color:#6366f1;background-color:rgb(99 102 241/var(--tw-bg-opacity,1))}.bg-orange-50{--tw-bg-opacity:1;background-color:#fff7ed;background-color:rgb(255 247 237/var(--tw-bg-opacity,1))}.bg-orange-500{--tw-bg-opacity:1;background-color:#f97316;background-color:rgb(249 115 22/var(--tw-bg-opacity,1))}.bg-pink-50{--tw-bg-opacity:1;background-color:#fdf2f8;background-color:rgb(253 242 248/var(--tw-bg-opacity,1))}.bg-pink-500{--tw-bg-opacity:1;background-color:#ec4899;background-color:rgb(236 72 153/var(--tw-bg-opacity,1))}.bg-primary-400\/20{background-color:rgba(96,165,250,.2)}.bg-primary-50{--tw-bg-opacity:1;background-color:#eff6ff;background-color:rgb(239 246 255/var(--tw-bg-opacity,1))}.bg-purple-100{--tw-bg-opacity:1;background-color:#f3e8ff;background-color:rgb(243 232 255/var(--tw-bg-opacity,1))}.bg-purple-50{--tw-bg-opacity:1;background-color:#faf5ff;background-color:rgb(250 245 255/var(--tw-bg-opacity,1))}.bg-purple-500{--tw-bg-opacity:1;background-color:#a855f7;background-color:rgb(168 85 247/var(--tw-bg-opacity,1))}.bg-red-100{--tw-bg-opacity:1;background-color:#fee2e2;background-color:rgb(254 226 226/var(--tw-bg-opacity,1))}.bg-red-50{--tw-bg-opacity:1;background-color:#fef2f2;background-color:rgb(254 242 242/var(--tw-bg-opacity,1))}.bg-red-500{--tw-bg-opacity:1;background-color:#ef4444;background-color:rgb(239 68 68/var(--tw-bg-opacity,1))}.bg-rose-50{--tw-bg-opacity:1;background-color:#fff1f2;background-color:rgb(255 241 242/var(--tw-bg-opacity,1))}.bg-slate-100{--tw-bg-opacity:1;background-color:#f1f5f9;background-color:rgb(241 245 249/var(--tw-bg-opacity,1))}.bg-slate-100\/60{background-color:rgba(241,245,249,.6)}.bg-slate-200{--tw-bg-opacity:1;background-color:#e2e8f0;background-color:rgb(226 232 240/var(--tw-bg-opacity,1))}.bg-slate-400{--tw-bg-opacity:1;background-color:#94a3b8;background-color:rgb(148 163 184/var(--tw-bg-opacity,1))}.bg-slate-50{--tw-bg-opacity:1;background-color:#f8fafc;background-color:rgb(248 250 252/var(--tw-bg-opacity,1))}.bg-slate-50\/50{background-color:rgba(248,250,252,.5)}.bg-slate-50\/80{background-color:rgba(248,250,252,.8)}.bg-slate-500{--tw-bg-opacity:1;background-color:#64748b;background-color:rgb(100 116 139/var(--tw-bg-opacity,1))}.bg-slate-800{--tw-bg-opacity:1;background-color:#1e293b;background-color:rgb(30 41 59/var(--tw-bg-opacity,1))}.bg-slate-900\/50{background-color:rgba(15,23,42,.5)}.bg-teal-50{--tw-bg-opacity:1;background-color:#f0fdfa;background-color:rgb(240 253 250/var(--tw-bg-opacity,1))}.bg-teal-500{--tw-bg-opacity:1;background-color:#14b8a6;background-color:rgb(20 184 166/var(--tw-bg-opacity,1))}.bg-violet-100\/80{background-color:rgba(237,233,254,.8)}.bg-violet-50{--tw-bg-opacity:1;background-color:#f5f3ff;background-color:rgb(245 243 255/var(--tw-bg-opacity,1))}.bg-violet-500{--tw-bg-opacity:1;background-color:#8b5cf6;background-color:rgb(139 92 246/var(--tw-bg-opacity,1))}.bg-white{--tw-bg-opacity:1;background-color:#fff;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-white\/10{background-color:hsla(0,0%,100%,.1)}.bg-white\/15{background-color:hsla(0,0%,100%,.15)}.bg-white\/40{background-color:hsla(0,0%,100%,.4)}.bg-white\/5{background-color:hsla(0,0%,100%,.05)}.bg-yellow-100{--tw-bg-opacity:1;background-color:#fef9c3;background-color:rgb(254 249 195/var(--tw-bg-opacity,1))}.bg-opacity-10{--tw-bg-opacity:0.1}.bg-\[url\(\'data\:image\/svg\+xml\;base64\2c PHN2ZyB3aWR0aD0iNjAiIGhlaWdodD0iNjAiIHZpZXdCb3g9IjAgMCA2MCA2MCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48ZyBmaWxsPSJub25lIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiPjxnIGZpbGw9IiNmZmYiIGZpbGwtb3BhY2l0eT0iMC4wNSI\+PHBhdGggZD0iTTM2IDM0djItSDJ2LTJoMzR6bTAtMzBWMkgydjJoMzR6Ii8\+PC9nPjwvZz48L3N2Zz4\=\'\)\]{background-image:url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNjAiIGhlaWdodD0iNjAiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PHBhdGggZD0iTTM2IDM0djIiIGZpbGw9IiNmZmYiIGZpbGwtb3BhY2l0eT0iLjA1IiBmaWxsLXJ1bGU9ImV2ZW5vZGQiLz48L3N2Zz4=)}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.from-\[\#0d47a1\]{--tw-gradient-from:#0d47a1 var(--tw-gradient-from-position);--tw-gradient-to:rgba(13,71,161,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-\[\#1565c0\]{--tw-gradient-from:#1565c0 var(--tw-gradient-from-position);--tw-gradient-to:rgba(21,101,192,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-amber-500{--tw-gradient-from:#f59e0b var(--tw-gradient-from-position);--tw-gradient-to:rgba(245,158,11,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-blue-400{--tw-gradient-from:#60a5fa var(--tw-gradient-from-position);--tw-gradient-to:rgba(96,165,250,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-blue-50{--tw-gradient-from:#eff6ff var(--tw-gradient-from-position);--tw-gradient-to:rgba(239,246,255,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-blue-50\/80{--tw-gradient-from:rgba(239,246,255,.8) var(--tw-gradient-from-position);--tw-gradient-to:rgba(239,246,255,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-blue-500{--tw-gradient-from:#3b82f6 var(--tw-gradient-from-position);--tw-gradient-to:rgba(59,130,246,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-blue-600{--tw-gradient-from:#2563eb var(--tw-gradient-from-position);--tw-gradient-to:rgba(37,99,235,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-cyan-500{--tw-gradient-from:#06b6d4 var(--tw-gradient-from-position);--tw-gradient-to:rgba(6,182,212,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-emerald-500{--tw-gradient-from:#10b981 var(--tw-gradient-from-position);--tw-gradient-to:rgba(16,185,129,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-gray-50{--tw-gradient-from:#f9fafb var(--tw-gradient-from-position);--tw-gradient-to:rgba(249,250,251,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-green-500{--tw-gradient-from:#22c55e var(--tw-gradient-from-position);--tw-gradient-to:rgba(34,197,94,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-indigo-500{--tw-gradient-from:#6366f1 var(--tw-gradient-from-position);--tw-gradient-to:rgba(99,102,241,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-orange-500{--tw-gradient-from:#f97316 var(--tw-gradient-from-position);--tw-gradient-to:rgba(249,115,22,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-pink-500{--tw-gradient-from:#ec4899 var(--tw-gradient-from-position);--tw-gradient-to:rgba(236,72,153,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-primary-500{--tw-gradient-from:#3b82f6 var(--tw-gradient-from-position);--tw-gradient-to:rgba(59,130,246,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-primary-600{--tw-gradient-from:#2563eb var(--tw-gradient-from-position);--tw-gradient-to:rgba(37,99,235,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-purple-500{--tw-gradient-from:#a855f7 var(--tw-gradient-from-position);--tw-gradient-to:rgba(168,85,247,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-red-400{--tw-gradient-from:#f87171 var(--tw-gradient-from-position);--tw-gradient-to:hsla(0,91%,71%,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-red-500{--tw-gradient-from:#ef4444 var(--tw-gradient-from-position);--tw-gradient-to:rgba(239,68,68,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-rose-500{--tw-gradient-from:#f43f5e var(--tw-gradient-from-position);--tw-gradient-to:rgba(244,63,94,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-slate-200{--tw-gradient-from:#e2e8f0 var(--tw-gradient-from-position);--tw-gradient-to:rgba(226,232,240,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-slate-400{--tw-gradient-from:#94a3b8 var(--tw-gradient-from-position);--tw-gradient-to:rgba(148,163,184,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-slate-50{--tw-gradient-from:#f8fafc var(--tw-gradient-from-position);--tw-gradient-to:rgba(248,250,252,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-slate-50\/80{--tw-gradient-from:rgba(248,250,252,.8) var(--tw-gradient-from-position);--tw-gradient-to:rgba(248,250,252,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-slate-500{--tw-gradient-from:#64748b var(--tw-gradient-from-position);--tw-gradient-to:rgba(100,116,139,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-teal-500{--tw-gradient-from:#14b8a6 var(--tw-gradient-from-position);--tw-gradient-to:rgba(20,184,166,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-violet-50\/80{--tw-gradient-from:rgba(245,243,255,.8) var(--tw-gradient-from-position);--tw-gradient-to:rgba(245,243,255,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-violet-500{--tw-gradient-from:#8b5cf6 var(--tw-gradient-from-position);--tw-gradient-to:rgba(139,92,246,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.via-\[\#1565c0\]{--tw-gradient-to:rgba(21,101,192,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#1565c0 var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-indigo-600{--tw-gradient-to:rgba(79,70,229,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#4f46e5 var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-primary-700{--tw-gradient-to:rgba(29,78,216,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#1d4ed8 var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-white{--tw-gradient-to:hsla(0,0%,100%,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#fff var(--tw-gradient-via-position),var(--tw-gradient-to)}.to-\[\#1565c0\]{--tw-gradient-to:#1565c0 var(--tw-gradient-to-position)}.to-amber-600{--tw-gradient-to:#d97706 var(--tw-gradient-to-position)}.to-blue-100{--tw-gradient-to:#dbeafe var(--tw-gradient-to-position)}.to-blue-50\/30{--tw-gradient-to:rgba(239,246,255,.3) var(--tw-gradient-to-position)}.to-blue-500{--tw-gradient-to:#3b82f6 var(--tw-gradient-to-position)}.to-blue-600{--tw-gradient-to:#2563eb var(--tw-gradient-to-position)}.to-cyan-600{--tw-gradient-to:#0891b2 var(--tw-gradient-to-position)}.to-emerald-600{--tw-gradient-to:#059669 var(--tw-gradient-to-position)}.to-gray-100{--tw-gradient-to:#f3f4f6 var(--tw-gradient-to-position)}.to-green-500{--tw-gradient-to:#22c55e var(--tw-gradient-to-position)}.to-green-600{--tw-gradient-to:#16a34a var(--tw-gradient-to-position)}.to-indigo-50{--tw-gradient-to:#eef2ff var(--tw-gradient-to-position)}.to-indigo-500{--tw-gradient-to:#6366f1 var(--tw-gradient-to-position)}.to-indigo-600{--tw-gradient-to:#4f46e5 var(--tw-gradient-to-position)}.to-orange-500{--tw-gradient-to:#f97316 var(--tw-gradient-to-position)}.to-orange-600{--tw-gradient-to:#ea580c var(--tw-gradient-to-position)}.to-pink-500{--tw-gradient-to:#ec4899 var(--tw-gradient-to-position)}.to-pink-600{--tw-gradient-to:#db2777 var(--tw-gradient-to-position)}.to-primary-700{--tw-gradient-to:#1d4ed8 var(--tw-gradient-to-position)}.to-purple-500{--tw-gradient-to:#a855f7 var(--tw-gradient-to-position)}.to-purple-600{--tw-gradient-to:#9333ea var(--tw-gradient-to-position)}.to-red-500{--tw-gradient-to:#ef4444 var(--tw-gradient-to-position)}.to-red-600{--tw-gradient-to:#dc2626 var(--tw-gradient-to-position)}.to-rose-600{--tw-gradient-to:#e11d48 var(--tw-gradient-to-position)}.to-slate-100{--tw-gradient-to:#f1f5f9 var(--tw-gradient-to-position)}.to-slate-500{--tw-gradient-to:#64748b var(--tw-gradient-to-position)}.to-slate-600{--tw-gradient-to:#475569 var(--tw-gradient-to-position)}.to-teal-500{--tw-gradient-to:#14b8a6 var(--tw-gradient-to-position)}.to-teal-600{--tw-gradient-to:#0d9488 var(--tw-gradient-to-position)}.to-transparent{--tw-gradient-to:transparent var(--tw-gradient-to-position)}.to-violet-600{--tw-gradient-to:#7c3aed var(--tw-gradient-to-position)}.to-white{--tw-gradient-to:#fff var(--tw-gradient-to-position)}.p-1{padding:.25rem}.p-1\.5{padding:.375rem}.p-12{padding:3rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-12{padding-left:3rem;padding-right:3rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-3\.5{padding-left:.875rem;padding-right:.875rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-1{padding-bottom:.25rem;padding-top:.25rem}.py-1\.5{padding-bottom:.375rem;padding-top:.375rem}.py-12{padding-bottom:3rem;padding-top:3rem}.py-16{padding-bottom:4rem;padding-top:4rem}.py-2{padding-bottom:.5rem;padding-top:.5rem}.py-2\.5{padding-bottom:.625rem;padding-top:.625rem}.py-20{padding-bottom:5rem;padding-top:5rem}.py-3{padding-bottom:.75rem;padding-top:.75rem}.py-3\.5{padding-bottom:.875rem;padding-top:.875rem}.py-4{padding-bottom:1rem;padding-top:1rem}.py-5{padding-bottom:1.25rem;padding-top:1.25rem}.py-6{padding-bottom:1.5rem;padding-top:1.5rem}.py-8{padding-bottom:2rem;padding-top:2rem}.pb-5{padding-bottom:1.25rem}.pb-6{padding-bottom:1.5rem}.pl-10{padding-left:2.5rem}.pl-12{padding-left:3rem}.pl-3{padding-left:.75rem}.pl-3\.5{padding-left:.875rem}.pl-4{padding-left:1rem}.pl-9{padding-left:2.25rem}.pr-10{padding-right:2.5rem}.pr-12{padding-right:3rem}.pr-2{padding-right:.5rem}.pr-3{padding-right:.75rem}.pr-4{padding-right:1rem}.pr-8{padding-right:2rem}.pt-2{padding-top:.5rem}.pt-4{padding-top:1rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-5xl{font-size:3rem;line-height:1}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-normal{font-weight:400}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.capitalize{text-transform:capitalize}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-feature-settings:var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction);font-variant-numeric:var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction)}.leading-relaxed{line-height:1.625}.leading-tight{line-height:1.25}.tracking-wide{letter-spacing:.025em}.tracking-wider{letter-spacing:.05em}.text-\[\#1565c0\]{--tw-text-opacity:1;color:#1565c0;color:rgb(21 101 192/var(--tw-text-opacity,1))}.text-amber-100{--tw-text-opacity:1;color:#fef3c7;color:rgb(254 243 199/var(--tw-text-opacity,1))}.text-amber-200{--tw-text-opacity:1;color:#fde68a;color:rgb(253 230 138/var(--tw-text-opacity,1))}.text-amber-500{--tw-text-opacity:1;color:#f59e0b;color:rgb(245 158 11/var(--tw-text-opacity,1))}.text-amber-600{--tw-text-opacity:1;color:#d97706;color:rgb(217 119 6/var(--tw-text-opacity,1))}.text-amber-700{--tw-text-opacity:1;color:#b45309;color:rgb(180 83 9/var(--tw-text-opacity,1))}.text-amber-800{--tw-text-opacity:1;color:#92400e;color:rgb(146 64 14/var(--tw-text-opacity,1))}.text-blue-100{--tw-text-opacity:1;color:#dbeafe;color:rgb(219 234 254/var(--tw-text-opacity,1))}.text-blue-100\/80{color:rgba(219,234,254,.8)}.text-blue-200{--tw-text-opacity:1;color:#bfdbfe;color:rgb(191 219 254/var(--tw-text-opacity,1))}.text-blue-200\/50{color:rgba(191,219,254,.5)}.text-blue-200\/70{color:rgba(191,219,254,.7)}.text-blue-500{--tw-text-opacity:1;color:#3b82f6;color:rgb(59 130 246/var(--tw-text-opacity,1))}.text-blue-600{--tw-text-opacity:1;color:#2563eb;color:rgb(37 99 235/var(--tw-text-opacity,1))}.text-blue-700{--tw-text-opacity:1;color:#1d4ed8;color:rgb(29 78 216/var(--tw-text-opacity,1))}.text-cyan-700{--tw-text-opacity:1;color:#0e7490;color:rgb(14 116 144/var(--tw-text-opacity,1))}.text-emerald-500{--tw-text-opacity:1;color:#10b981;color:rgb(16 185 129/var(--tw-text-opacity,1))}.text-emerald-600{--tw-text-opacity:1;color:#059669;color:rgb(5 150 105/var(--tw-text-opacity,1))}.text-emerald-700{--tw-text-opacity:1;color:#047857;color:rgb(4 120 87/var(--tw-text-opacity,1))}.text-gray-300{--tw-text-opacity:1;color:#d1d5db;color:rgb(209 213 219/var(--tw-text-opacity,1))}.text-gray-400{--tw-text-opacity:1;color:#9ca3af;color:rgb(156 163 175/var(--tw-text-opacity,1))}.text-gray-500{--tw-text-opacity:1;color:#6b7280;color:rgb(107 114 128/var(--tw-text-opacity,1))}.text-gray-600{--tw-text-opacity:1;color:#4b5563;color:rgb(75 85 99/var(--tw-text-opacity,1))}.text-gray-700{--tw-text-opacity:1;color:#374151;color:rgb(55 65 81/var(--tw-text-opacity,1))}.text-gray-800{--tw-text-opacity:1;color:#1f2937;color:rgb(31 41 55/var(--tw-text-opacity,1))}.text-green-100{--tw-text-opacity:1;color:#dcfce7;color:rgb(220 252 231/var(--tw-text-opacity,1))}.text-green-200{--tw-text-opacity:1;color:#bbf7d0;color:rgb(187 247 208/var(--tw-text-opacity,1))}.text-green-500{--tw-text-opacity:1;color:#22c55e;color:rgb(34 197 94/var(--tw-text-opacity,1))}.text-green-600{--tw-text-opacity:1;color:#16a34a;color:rgb(22 163 74/var(--tw-text-opacity,1))}.text-green-700{--tw-text-opacity:1;color:#15803d;color:rgb(21 128 61/var(--tw-text-opacity,1))}.text-indigo-700{--tw-text-opacity:1;color:#4338ca;color:rgb(67 56 202/var(--tw-text-opacity,1))}.text-orange-700{--tw-text-opacity:1;color:#c2410c;color:rgb(194 65 12/var(--tw-text-opacity,1))}.text-pink-700{--tw-text-opacity:1;color:#be185d;color:rgb(190 24 93/var(--tw-text-opacity,1))}.text-primary-600{--tw-text-opacity:1;color:#2563eb;color:rgb(37 99 235/var(--tw-text-opacity,1))}.text-primary-700{--tw-text-opacity:1;color:#1d4ed8;color:rgb(29 78 216/var(--tw-text-opacity,1))}.text-purple-100{--tw-text-opacity:1;color:#f3e8ff;color:rgb(243 232 255/var(--tw-text-opacity,1))}.text-purple-200{--tw-text-opacity:1;color:#e9d5ff;color:rgb(233 213 255/var(--tw-text-opacity,1))}.text-purple-600{--tw-text-opacity:1;color:#9333ea;color:rgb(147 51 234/var(--tw-text-opacity,1))}.text-purple-700{--tw-text-opacity:1;color:#7e22ce;color:rgb(126 34 206/var(--tw-text-opacity,1))}.text-red-400{--tw-text-opacity:1;color:#f87171;color:rgb(248 113 113/var(--tw-text-opacity,1))}.text-red-500{--tw-text-opacity:1;color:#ef4444;color:rgb(239 68 68/var(--tw-text-opacity,1))}.text-red-600{--tw-text-opacity:1;color:#dc2626;color:rgb(220 38 38/var(--tw-text-opacity,1))}.text-red-700{--tw-text-opacity:1;color:#b91c1c;color:rgb(185 28 28/var(--tw-text-opacity,1))}.text-rose-600{--tw-text-opacity:1;color:#e11d48;color:rgb(225 29 72/var(--tw-text-opacity,1))}.text-slate-300{--tw-text-opacity:1;color:#cbd5e1;color:rgb(203 213 225/var(--tw-text-opacity,1))}.text-slate-400{--tw-text-opacity:1;color:#94a3b8;color:rgb(148 163 184/var(--tw-text-opacity,1))}.text-slate-500{--tw-text-opacity:1;color:#64748b;color:rgb(100 116 139/var(--tw-text-opacity,1))}.text-slate-600{--tw-text-opacity:1;color:#475569;color:rgb(71 85 105/var(--tw-text-opacity,1))}.text-slate-700{--tw-text-opacity:1;color:#334155;color:rgb(51 65 85/var(--tw-text-opacity,1))}.text-slate-800{--tw-text-opacity:1;color:#1e293b;color:rgb(30 41 59/var(--tw-text-opacity,1))}.text-teal-700{--tw-text-opacity:1;color:#0f766e;color:rgb(15 118 110/var(--tw-text-opacity,1))}.text-violet-500{--tw-text-opacity:1;color:#8b5cf6;color:rgb(139 92 246/var(--tw-text-opacity,1))}.text-violet-600{--tw-text-opacity:1;color:#7c3aed;color:rgb(124 58 237/var(--tw-text-opacity,1))}.text-violet-700{--tw-text-opacity:1;color:#6d28d9;color:rgb(109 40 217/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:#fff;color:rgb(255 255 255/var(--tw-text-opacity,1))}.text-white\/60{color:hsla(0,0%,100%,.6)}.text-white\/70{color:hsla(0,0%,100%,.7)}.text-white\/80{color:hsla(0,0%,100%,.8)}.text-yellow-600{--tw-text-opacity:1;color:#ca8a04;color:rgb(202 138 4/var(--tw-text-opacity,1))}.underline{-webkit-text-decoration-line:underline;text-decoration-line:underline}.placeholder-gray-400::placeholder{--tw-placeholder-opacity:1;color:#9ca3af;color:rgb(156 163 175/var(--tw-placeholder-opacity,1))}.opacity-0{opacity:0}.opacity-10{opacity:.1}.opacity-100{opacity:1}.opacity-25{opacity:.25}.opacity-40{opacity:.4}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-75{opacity:.75}.shadow{--tw-shadow:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1);--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color)}.shadow,.shadow-2xl{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-2xl{--tw-shadow:0 25px 50px -12px rgba(0,0,0,.25);--tw-shadow-colored:0 25px 50px -12px var(--tw-shadow-color)}.shadow-lg{--tw-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.shadow-lg,.shadow-md{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color)}.shadow-sm{--tw-shadow:0 1px 2px 0 rgba(0,0,0,.05);--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color)}.shadow-sm,.shadow-xl{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1);--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color)}.shadow-amber-500\/20{--tw-shadow-color:rgba(245,158,11,.2);--tw-shadow:var(--tw-shadow-colored)}.shadow-blue-500\/10{--tw-shadow-color:rgba(59,130,246,.1);--tw-shadow:var(--tw-shadow-colored)}.shadow-blue-500\/15{--tw-shadow-color:rgba(59,130,246,.15);--tw-shadow:var(--tw-shadow-colored)}.shadow-blue-500\/20{--tw-shadow-color:rgba(59,130,246,.2);--tw-shadow:var(--tw-shadow-colored)}.shadow-blue-500\/25{--tw-shadow-color:rgba(59,130,246,.25);--tw-shadow:var(--tw-shadow-colored)}.shadow-blue-900\/15{--tw-shadow-color:rgba(30,58,138,.15);--tw-shadow:var(--tw-shadow-colored)}.shadow-emerald-500\/20{--tw-shadow-color:rgba(16,185,129,.2);--tw-shadow:var(--tw-shadow-colored)}.shadow-emerald-500\/25{--tw-shadow-color:rgba(16,185,129,.25);--tw-shadow:var(--tw-shadow-colored)}.shadow-primary-500\/30{--tw-shadow-color:rgba(59,130,246,.3);--tw-shadow:var(--tw-shadow-colored)}.shadow-red-500\/20{--tw-shadow-color:rgba(239,68,68,.2);--tw-shadow:var(--tw-shadow-colored)}.shadow-rose-500\/20{--tw-shadow-color:rgba(244,63,94,.2);--tw-shadow:var(--tw-shadow-colored)}.shadow-slate-900\/10{--tw-shadow-color:rgba(15,23,42,.1);--tw-shadow:var(--tw-shadow-colored)}.shadow-violet-500\/20{--tw-shadow-color:rgba(139,92,246,.2);--tw-shadow:var(--tw-shadow-colored)}.ring{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring,.ring-1{box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.ring-1{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring-2{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring-2,.ring-4{box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.ring-4{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring-\[\#1565c0\]\/10{--tw-ring-color:rgba(21,101,192,.1)}.ring-amber-200{--tw-ring-opacity:1;--tw-ring-color:rgb(253 230 138/var(--tw-ring-opacity,1))}.ring-blue-100{--tw-ring-opacity:1;--tw-ring-color:rgb(219 234 254/var(--tw-ring-opacity,1))}.ring-blue-200{--tw-ring-opacity:1;--tw-ring-color:rgb(191 219 254/var(--tw-ring-opacity,1))}.ring-cyan-200{--tw-ring-opacity:1;--tw-ring-color:rgb(165 243 252/var(--tw-ring-opacity,1))}.ring-emerald-200{--tw-ring-opacity:1;--tw-ring-color:rgb(167 243 208/var(--tw-ring-opacity,1))}.ring-indigo-200{--tw-ring-opacity:1;--tw-ring-color:rgb(199 210 254/var(--tw-ring-opacity,1))}.ring-orange-200{--tw-ring-opacity:1;--tw-ring-color:rgb(254 215 170/var(--tw-ring-opacity,1))}.ring-pink-200{--tw-ring-opacity:1;--tw-ring-color:rgb(251 207 232/var(--tw-ring-opacity,1))}.ring-purple-200{--tw-ring-opacity:1;--tw-ring-color:rgb(233 213 255/var(--tw-ring-opacity,1))}.ring-red-200{--tw-ring-opacity:1;--tw-ring-color:rgb(254 202 202/var(--tw-ring-opacity,1))}.ring-slate-200{--tw-ring-opacity:1;--tw-ring-color:rgb(226 232 240/var(--tw-ring-opacity,1))}.ring-teal-200{--tw-ring-opacity:1;--tw-ring-color:rgb(153 246 228/var(--tw-ring-opacity,1))}.ring-violet-200{--tw-ring-opacity:1;--tw-ring-color:rgb(221 214 254/var(--tw-ring-opacity,1))}.blur-3xl{--tw-blur:blur(64px)}.blur-3xl,.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur{--tw-backdrop-blur:blur(8px)}.backdrop-blur,.backdrop-blur-sm{-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-blur-sm{--tw-backdrop-blur:blur(4px)}.transition{transition-duration:.15s;transition-property:color,background-color,border-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-all{transition-duration:.15s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-duration:.15s;transition-property:color,background-color,border-color,fill,stroke,-webkit-text-decoration-color;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,-webkit-text-decoration-color;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-opacity{transition-duration:.15s;transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-shadow{transition-property:box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-shadow,.transition-transform{transition-duration:.15s}.duration-300{transition-duration:.3s}.duration-500{transition-duration:.5s}.duration-700{transition-duration:.7s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:#f5f5f5;color:#333;line-height:1.6}.swal2-popup.swal-custom-popup,body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}.swal2-popup.swal-custom-popup{border:none;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.15),0 0 0 1px rgba(0,0,0,.04);padding:2rem 2rem 1.5rem}.swal-custom-popup .swal2-title{color:#1e293b;font-size:1.25rem;font-weight:700;padding:.5rem 0 0}.swal-custom-popup .swal2-html-container{color:#64748b;font-size:.9rem;line-height:1.6;margin:.75rem 1.5rem 0}.swal-custom-popup .swal2-icon{border-width:3px;height:56px;margin:.5rem auto;width:56px}.swal-custom-popup .swal2-icon .swal2-icon-content{font-size:2rem}.swal-custom-popup .swal2-actions{gap:.75rem;margin-top:1.25rem}.swal-custom-popup .swal2-styled.swal2-confirm{border-radius:10px;box-shadow:none;font-size:.875rem;font-weight:600;padding:.6rem 1.75rem;transition:all .15s ease}.swal-custom-popup .swal2-styled.swal2-confirm:hover{box-shadow:0 4px 12px rgba(0,0,0,.15);transform:translateY(-1px)}.swal-custom-popup .swal2-styled.swal2-cancel{background-color:#f1f5f9;border-radius:10px;box-shadow:none;color:#475569;font-size:.875rem;font-weight:600;padding:.6rem 1.75rem;transition:all .15s ease}.swal-custom-popup .swal2-styled.swal2-cancel:hover{background-color:#e2e8f0;transform:translateY(-1px)}.swal2-backdrop-show{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:rgba(15,23,42,.4)!important}.swal-custom-popup .swal2-icon.swal2-success{border-color:#22c55e;color:#22c55e}.swal-custom-popup .swal2-icon.swal2-success .swal2-success-ring{border-color:rgba(34,197,94,.3)}.swal-custom-popup .swal2-icon.swal2-success [class^=swal2-success-line]{background-color:#22c55e}.swal-custom-popup .swal2-icon.swal2-warning{border-color:#f59e0b;color:#f59e0b}.swal-custom-popup .swal2-icon.swal2-error{border-color:#ef4444}.swal-custom-popup .swal2-icon.swal2-error [class^=swal2-x-mark-line]{background-color:#ef4444}.swal2-popup.swal-toast-popup{align-items:center;border:none;border-radius:12px;box-shadow:0 8px 24px rgba(0,0,0,.12);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;font-size:.875rem;padding:.5rem 1rem}.swal-toast-popup.swal2-icon-success{background:#ecfdf5!important;border-left:4px solid #22c55e}.swal-toast-popup.swal2-icon-error{background:#fef2f2!important;border-left:4px solid #ef4444}.swal-toast-popup.swal2-icon-warning{background:#fffbeb!important;border-left:4px solid #f59e0b}.swal-toast-popup .swal2-title{color:#1e293b;font-size:.875rem;font-weight:600;margin:0;padding:0}.swal-toast-popup .swal2-icon{border-width:2px;height:1.5rem;margin:0 .5rem 0 0;width:1.5rem}.swal-toast-popup .swal2-icon .swal2-icon-content{font-size:.875rem}.swal-toast-popup .swal2-icon.swal2-success{border-color:#22c55e;color:#22c55e}.swal-toast-popup .swal2-icon.swal2-success .swal2-success-ring{border-color:rgba(34,197,94,.3)}.swal-toast-popup .swal2-icon.swal2-success [class^=swal2-success-line]{background-color:#22c55e}.swal-toast-popup .swal2-icon.swal2-warning{border-color:#f59e0b;color:#f59e0b}.swal-toast-popup .swal2-icon.swal2-error{border-color:#ef4444}.swal-toast-popup .swal2-icon.swal2-error [class^=swal2-x-mark-line]{background-color:#ef4444}.swal-toast-popup .swal2-timer-progress-bar{background:rgba(99,102,241,.4)}.ml-auto{margin-left:auto}.w-4{width:1rem}.h-4{height:1rem}.px-2{padding-left:.5rem;padding-right:.5rem}.py-0\.5{padding-bottom:.125rem;padding-top:.125rem}.text-xs{font-size:.75rem;line-height:1rem}.font-semibold{font-weight:600}.rounded-full{border-radius:9999px}.bg-white\/20{background-color:hsla(0,0%,100%,.2)}.border-white\/10{border-color:hsla(0,0%,100%,.1)}.border-t{border-top-style:solid;border-top-width:1px}.my-3{margin-bottom:.75rem;margin-top:.75rem}.mx-5{margin-left:1.25rem;margin-right:1.25rem}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-200{transition-duration:.2s}.rotate-180{transform:rotate(180deg)}.container{margin:0 auto;max-width:1200px;padding:20px}.auth-container{align-items:center;background:linear-gradient(135deg,#1976d2,#0d47a1);display:flex;justify-content:center;min-height:100vh}.auth-card{background:#fff;border-radius:12px;box-shadow:0 10px 40px rgba(0,0,0,.2);max-width:400px;padding:40px;width:100%}.auth-card h1{color:#1976d2;margin-bottom:8px;text-align:center}.auth-card .brand-title{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#1976d2,#42a5f5);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:700;margin-bottom:4px}.auth-card .portal-name{color:#666;font-size:1rem;font-weight:500;letter-spacing:2px;margin-bottom:20px;text-align:center;text-transform:uppercase}.auth-card h2{color:#666;font-size:1.1rem;font-weight:400;margin-bottom:30px;text-align:center}.form-group{margin-bottom:20px}.form-group label{color:#555}.form-group input{border:2px solid #e0e0e0;border-radius:8px;font-size:16px;padding:12px 16px;transition:border-color .2s;width:100%}.form-group input:focus{border-color:#1976d2;outline:none}.btn{border:none;border-radius:8px;cursor:pointer;font-size:16px;font-weight:600;padding:14px;transition:background-color .2s,transform .1s;width:100%}.btn:active{transform:scale(.98)}.btn-primary{background-color:#1976d2}.btn-primary:hover{background-color:#1565c0}.btn-primary:disabled{background-color:#90caf9}.btn-link{background:none;border:none;color:#1976d2;cursor:pointer;display:block;font-size:14px;margin-top:16px;text-align:center;text-decoration:underline}.btn-link:hover{color:#0d47a1}.error-message{background-color:#ffebee;color:#c62828}.error-message,.success-message{border-radius:8px;font-size:14px;margin-bottom:20px;padding:12px;text-align:center}.success-message{background-color:#e8f5e9;color:#2e7d32}.home-container{background-color:#f5f5f5;min-height:100vh}.navbar{background:linear-gradient(135deg,#1565c0,#0d47a1);box-shadow:0 2px 12px rgba(0,0,0,.15);height:60px;justify-content:space-between;padding:0 24px}.navbar,.navbar-left{align-items:center;display:flex}.navbar-left{gap:16px}.btn-menu{background:hsla(0,0%,100%,.1);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1.2rem;line-height:1;padding:8px 10px;transition:background .2s}.btn-menu:hover{background:hsla(0,0%,100%,.2)}.navbar h1{color:#fff;font-size:1.25rem;margin:0}.navbar .brand-title{color:#fff;font-size:1.15rem;font-weight:600;letter-spacing:-.01em}.navbar .navbar-subtitle{border-left:1px solid hsla(0,0%,100%,.2);color:hsla(0,0%,100%,.7);font-size:.8rem;font-weight:500;padding-left:16px}.env-badge,.navbar .navbar-subtitle{letter-spacing:.05em;text-transform:uppercase}.env-badge{border-radius:4px;font-size:.65rem;font-weight:600;margin-left:12px;padding:3px 8px}.env-badge.env-local,.env-badge.env-prod,.env-badge.env-uat{background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.2);color:hsla(0,0%,100%,.85)}.navbar-user{align-items:center;display:flex;gap:12px}.navbar-user>span{color:hsla(0,0%,100%,.9);font-size:.85rem;font-weight:500}.btn-logout{background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.2);border-radius:6px;color:#fff;cursor:pointer;font-size:.8rem;font-weight:500;padding:6px 14px;transition:all .2s}.btn-logout:hover{background:hsla(0,0%,100%,.2);border-color:hsla(0,0%,100%,.3)}.dashboard{padding:40px}.welcome-card{background:#fff;border-radius:12px;box-shadow:0 2px 12px rgba(0,0,0,.08);margin:0 auto;max-width:600px;padding:40px;text-align:center}.welcome-card h2{color:#1976d2;margin-bottom:16px}.welcome-card p{color:#666;font-size:1.1rem}.role-badge{background-color:#e3f2fd;border-radius:20px;color:#1976d2;display:inline-block;font-size:14px;margin:4px;padding:4px 12px}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-left:auto;margin-right:auto;margin-top:40px;max-width:800px}.stat-card{box-shadow:0 2px 12px rgba(0,0,0,.08);padding:24px;text-align:center}.stat-card h3{color:#1976d2;font-size:2rem;margin-bottom:8px}.stat-card p{color:#666}.app-wrapper{display:flex;flex-direction:column;min-height:100vh}.version-footer{background:transparent;bottom:0;font-size:12px;left:0;padding:8px 16px;pointer-events:none;position:fixed;right:0;text-align:center;z-index:1000}.auth-container~.version-footer,.version-footer{color:hsla(0,0%,100%,.7)}.home-container~.version-footer{color:rgba(0,0,0,.4)}.welcome-card .role-indicator{border-radius:20px;display:inline-block;font-size:.85rem;font-weight:600;letter-spacing:.5px;margin-top:12px;padding:6px 16px;text-transform:uppercase}.admin-welcome .role-indicator{background:#e3f2fd;color:#1565c0}.course-admin-welcome .role-indicator{background:#e0f7fa;color:#00838f}.principal-welcome .role-indicator{background:#f3e5f5;color:#7b1fa2}.parent-welcome .role-indicator{background:#e8f5e9;color:#2e7d32}.student-welcome .role-indicator{background:#fff3e0;color:#ef6c00}.program-welcome .role-indicator{background:#e0f7fa;color:#00838f}.admin-actions,.parent-actions,.principal-actions,.program-actions,.student-actions{margin:40px auto 0;max-width:800px;padding:0 20px}.admin-actions h3,.parent-actions h3,.principal-actions h3,.program-actions h3,.student-actions h3{color:#333;margin-bottom:20px}.action-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.action-btn{background:#fff;border:2px solid #e0e0e0;border-radius:12px;color:#555;font-size:14px;font-weight:500;padding:16px 20px}.action-btn:hover:not(:disabled){background:#f5f9ff;border-color:#1976d2;color:#1976d2}.action-btn:disabled{cursor:not-allowed;opacity:.6}.navbar-roles{display:flex;gap:6px}.role-badge-small{background:hsla(0,0%,100%,.15);border-radius:12px;color:#fff;font-size:.7rem;font-weight:500;letter-spacing:.03em;padding:4px 10px;text-transform:uppercase}.navbar-avatar-wrapper{position:relative}.navbar-avatar{align-items:center;background:hsla(0,0%,100%,.2);border:2px solid hsla(0,0%,100%,.4);border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:.8rem;font-weight:700;height:36px;justify-content:center;letter-spacing:.02em;transition:all .2s;width:36px}.navbar-avatar:hover{background:hsla(0,0%,100%,.3);border-color:hsla(0,0%,100%,.6);transform:scale(1.05)}.navbar-avatar-dropdown{animation:avatarDropdownIn .15s ease-out;background:#fff;border-radius:12px;box-shadow:0 8px 30px rgba(0,0,0,.15),0 2px 8px rgba(0,0,0,.08);min-width:240px;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);z-index:9999}@keyframes avatarDropdownIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.navbar-avatar-dropdown-header{align-items:center;display:flex;gap:12px;padding:16px}.navbar-avatar-lg{align-items:center;background:linear-gradient(135deg,#1565c0,#0d47a1);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.95rem;font-weight:700;height:42px;justify-content:center;width:42px}.navbar-avatar-info{display:flex;flex-direction:column;min-width:0}.navbar-avatar-name{color:#1a1a1a;font-size:.9rem;font-weight:600}.navbar-avatar-email,.navbar-avatar-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.navbar-avatar-email{color:#888;font-size:.75rem}.navbar-avatar-dropdown-divider{background:#eee;height:1px;margin:0}.navbar-avatar-dropdown-item{align-items:center;background:transparent;border:none;color:#555;cursor:pointer;display:flex;font-size:.85rem;font-weight:500;gap:10px;padding:12px 16px;text-align:left;transition:all .15s;width:100%}.navbar-avatar-dropdown-item:hover{background:#f5f5f5;color:#d32f2f}.navbar-avatar-dropdown-item svg{flex-shrink:0;opacity:.6}.navbar-avatar-dropdown-item:hover svg{opacity:1}.program-layout{display:flex;gap:24px;margin:0 auto;max-width:1400px;padding:20px}.program-sidebar{flex-shrink:0;width:400px}.program-main{flex:1 1;min-width:0}.history-list-container{background:#fff;border-radius:12px;box-shadow:0 2px 12px rgba(0,0,0,.08);overflow:hidden}.history-list-header{background:#f8f9fa;border-bottom:1px solid #e0e0e0;padding:16px 20px}.history-list-header h3{color:#333;font-size:1.1rem;margin:0 0 12px}.history-filter{display:flex;gap:8px}.history-filter select{background:#fff;border:1px solid #ddd;border-radius:6px;flex:1 1;font-size:14px;padding:8px 12px}.history-list{max-height:500px;overflow-y:auto}.history-item{border-bottom:1px solid #f0f0f0;cursor:pointer;padding:14px 20px;transition:background-color .15s}.history-item:hover{background-color:#f5f9ff}.history-item.selected{background-color:#e3f2fd;border-left:3px solid #1976d2}.history-item-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:6px}.history-item-title{align-items:center;color:#333;display:flex;font-size:.95rem;font-weight:500;gap:6px}.history-item-title.has-file{color:#1976d2;cursor:pointer}.history-item-title.has-file:hover{color:#1565c0;text-decoration:underline}.file-icon{font-size:.85rem}.history-item-type{border-radius:10px;font-size:.7rem;font-weight:500;padding:3px 8px;text-transform:uppercase}.history-item-type.transcript{background:#e8f5e9;color:#2e7d32}.history-item-type.testresult{background:#fff3e0;color:#ef6c00}.history-item-type.document{background:#e3f2fd;color:#1565c0}.history-item-type.certificate{background:#f3e5f5;color:#7b1fa2}.history-item-type.other{background:#f5f5f5;color:#666}.history-item-meta{color:#666;display:flex;font-size:.8rem;gap:16px}.history-item-student{color:#555;font-weight:500}.history-empty{color:#888}.history-empty,.history-loading{padding:40px 20px;text-align:center}.history-loading{color:#666}.file-drop-zone{background:#fafafa;border:2px dashed #ccc;border-radius:12px;cursor:pointer;margin:16px;padding:24px;text-align:center;transition:all .2s}.file-drop-zone:hover:not(.disabled){background:#f5f9ff;border-color:#1976d2}.file-drop-zone.dragging{background:#e3f2fd;border-color:#1976d2;border-style:solid}.file-drop-zone.disabled{background:#f5f5f5;cursor:not-allowed;opacity:.6}.drop-zone-content{pointer-events:none}.drop-zone-icon{font-size:2.5rem;margin-bottom:8px}.drop-zone-content p{color:#666;margin:4px 0}.drop-zone-hint{color:#888!important;font-size:.85rem}.drop-zone-formats{color:#aaa!important;font-size:.75rem;margin-top:8px!important}.upload-message{border-radius:8px;font-size:.9rem;margin:12px 16px;padding:10px 16px}.upload-message.success{background:#e8f5e9;border:1px solid #a5d6a7;color:#2e7d32}.upload-message.error{background:#ffebee;border:1px solid #ef9a9a;color:#c62828}.upload-progress{color:#1976d2;font-size:.9rem;padding:8px;text-align:center}.parent-dashboard{max-width:1400px}.parent-content{grid-gap:24px;display:grid;gap:24px;grid-template-columns:280px 1fr;margin-top:24px}.parent-sidebar{background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.1);padding:20px}.parent-sidebar h3{border-bottom:2px solid #e91e63;color:#333;font-size:1.1rem;margin:0 0 16px;padding-bottom:12px}.parent-main{gap:24px}.parent-main,.student-list{display:flex;flex-direction:column}.student-list{gap:8px;max-height:400px;overflow-y:auto}.student-item{background:#f8f9fa;border:2px solid transparent;border-radius:8px;cursor:pointer;padding:12px;transition:all .2s ease}.student-item:hover{background:#fce4ec;border-color:#f48fb1}.student-item.selected{background:#fce4ec;border-color:#e91e63}.student-name{color:#333;font-size:.95rem;font-weight:500}.student-relationship{color:#666;font-size:.8rem;margin-top:4px;text-transform:capitalize}.list-empty,.list-error,.list-loading{color:#666;font-size:.9rem;padding:20px;text-align:center}.list-empty small{color:#999;display:block;margin-top:8px}.child-details-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.1);padding:24px}.child-details-card h3{border-bottom:2px solid #e91e63;color:#333;margin:0 0 16px;padding-bottom:12px}.child-details-card p{color:#555;margin:8px 0}.sidebar-section{margin-bottom:24px}.sidebar-section:last-child{margin-bottom:0}.sidebar-actions{display:flex;flex-direction:column;gap:8px}.sidebar-action-btn{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;color:#333;cursor:pointer;font-size:.9rem;padding:10px 16px;text-align:left;transition:all .2s ease;width:100%}.sidebar-action-btn:hover:not(:disabled){background:#fce4ec;border-color:#f48fb1;color:#c2185b}.sidebar-action-btn:disabled{cursor:not-allowed;opacity:.6}.sidebar-action-btn.program:hover:not(:disabled){background:#e3f2fd;border-color:#64b5f6;color:#1565c0}.program-sidebar .sidebar-section{border-bottom:1px solid #eee;margin-bottom:20px;padding-bottom:16px}.program-sidebar .sidebar-section h3{border-bottom:2px solid #1976d2;color:#333;font-size:1rem;margin:0 0 12px;padding-bottom:8px}.resizable-splitter{display:flex;height:calc(100vh - 60px);overflow:hidden;width:100%}.resizable-left{display:flex;flex-direction:column;flex-shrink:0;height:100%;overflow:hidden;position:relative}.resizable-left .app-sidebar{height:100%;max-width:none;min-width:0;min-width:auto;overflow-x:hidden;overflow-y:auto;width:100%}.resizable-divider{align-items:center;background:linear-gradient(180deg,#1565c0,#0d47a1);cursor:col-resize;display:flex;flex-shrink:0;justify-content:center;min-width:8px;position:relative;transition:all .15s;width:8px;z-index:100}.resizable-divider.dragging,.resizable-divider:hover{background:#1976d2;width:10px}.divider-handle{background:hsla(0,0%,100%,.4);border-radius:2px;height:60px;transition:all .15s;width:4px}.resizable-divider.dragging .divider-handle,.resizable-divider:hover .divider-handle{background:hsla(0,0%,100%,.8);height:80px}.resizable-right{display:flex;flex:1 1;flex-direction:column;height:100%;min-width:300px;overflow:hidden}.dashboard-layout{display:flex;min-height:calc(100vh - 60px)}.app-sidebar{background:linear-gradient(180deg,#1565c0,#0d47a1);box-shadow:4px 0 20px rgba(0,0,0,.15);color:#fff;display:flex;flex-direction:column;max-width:320px;min-width:260px;overflow-y:auto;width:280px}.sidebar-header{border-bottom:1px solid hsla(0,0%,100%,.1);padding:20px 16px}.sidebar-title{align-items:center;color:#fff;display:flex;font-size:1.1rem;font-weight:600;gap:10px;letter-spacing:.02em;margin-bottom:16px}.sidebar-title-icon{flex-shrink:0;height:20px;opacity:.85;width:20px}.sidebar-title span{opacity:.95}.sidebar-stats{display:flex;gap:10px}.sidebar-stat{align-items:center;background:hsla(0,0%,100%,.1);border-radius:8px;display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:12px 10px;transition:background .2s ease}.sidebar-stat:hover{background:hsla(0,0%,100%,.15)}.sidebar-stat-value{color:#fff;font-size:1.25rem;font-weight:700;line-height:1}.sidebar-stat-label{font-size:.65rem;font-weight:500;letter-spacing:.05em;margin-top:4px;opacity:.6;text-transform:uppercase}.sidebar-nav{flex:1 1;overflow-y:auto;padding:12px}.sidebar-student-card{background:hsla(0,0%,100%,.12);border:1px solid hsla(0,0%,100%,.1);border-radius:10px;margin:0 12px 8px;padding:12px}.sidebar-student-card-top{align-items:center;display:flex;gap:10px;margin-bottom:10px}.sidebar-student-avatar{align-items:center;background:hsla(0,0%,100%,.2);border-radius:10px;color:#fff;display:flex;flex-shrink:0;font-size:.75rem;font-weight:700;height:36px;justify-content:center;text-transform:uppercase;width:36px}.sidebar-student-info{display:flex;flex-direction:column;min-width:0}.sidebar-student-name{color:#fff;font-size:.85rem;font-weight:600}.sidebar-student-detail,.sidebar-student-name{line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-student-detail{color:hsla(0,0%,100%,.6);font-size:.7rem}.sidebar-switch-btn{align-items:center;background:hsla(0,0%,100%,.08);border:1px solid hsla(0,0%,100%,.2);border-radius:8px;color:hsla(0,0%,100%,.85);cursor:pointer;display:flex;font-size:.75rem;font-weight:500;gap:6px;justify-content:center;padding:7px 10px;transition:all .2s;width:100%}.sidebar-switch-btn:hover{background:hsla(0,0%,100%,.2);border-color:hsla(0,0%,100%,.35);color:#fff}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:hsla(0,0%,100%,.15);border-radius:2px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:hsla(0,0%,100%,.25)}.sb-selector-card{background:hsla(0,0%,100%,.08);border:1px solid hsla(0,0%,100%,.1);border-radius:10px;margin:0 10px 10px;overflow:hidden}.sb-selector-header{align-items:center;background:transparent;border:none;color:#fff;cursor:pointer;display:flex;gap:10px;padding:10px 12px;text-align:left;transition:background .15s;width:100%}.sb-selector-header:hover{background:hsla(0,0%,100%,.06)}.sb-selector-header-icon{align-items:center;background:hsla(0,0%,100%,.15);border-radius:8px;color:#fff;display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.sb-selector-header-text{display:flex;flex:1 1;flex-direction:column;min-width:0}.sb-selector-title{color:#fff;font-size:.8rem;font-weight:600;line-height:1.3}.sb-selector-subtitle{color:hsla(0,0%,100%,.55);font-size:.65rem;line-height:1.3}.sb-selector-chevron{color:hsla(0,0%,100%,.5);flex-shrink:0;transition:transform .2s}.sb-selector-chevron-open{transform:rotate(180deg)}.sb-selector-body{padding:0 10px 10px}.sb-selector-step{margin-bottom:10px}.sb-selector-step-disabled{opacity:.4;pointer-events:none}.sb-selector-label{align-items:center;color:hsla(0,0%,100%,.75);display:flex;font-size:.7rem;font-weight:600;gap:6px;letter-spacing:.03em;margin-bottom:5px;text-transform:uppercase}.sb-selector-step-num{align-items:center;background:hsla(0,0%,100%,.18);border-radius:50%;color:#fff;display:inline-flex;flex-shrink:0;font-size:.6rem;font-weight:700;height:18px;justify-content:center;width:18px}.sb-selector-count{background:hsla(0,0%,100%,.1);border-radius:8px;color:hsla(0,0%,100%,.5);font-size:.6rem;font-weight:500;margin-left:auto;padding:1px 6px}.sb-selector-optional{color:hsla(0,0%,100%,.4);font-size:.6rem;font-style:italic;font-weight:400;margin-left:auto}.sb-selector-field{position:relative}.sb-selector-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:hsla(0,0%,100%,.08);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.5)' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;border:1px solid hsla(0,0%,100%,.15);border-radius:8px;color:#fff;cursor:pointer;font-size:.78rem;padding:7px 10px;transition:all .15s;width:100%}.sb-selector-select:focus{background:hsla(0,0%,100%,.12);border-color:hsla(0,0%,100%,.35);outline:none}.sb-selector-select:disabled{cursor:not-allowed;opacity:.5}.sb-selector-select option{background:#1e293b;color:#fff}.sb-selector-search{margin-bottom:6px;position:relative}.sb-selector-search-icon{color:hsla(0,0%,100%,.4);left:8px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.sb-selector-search-input{background:hsla(0,0%,100%,.08);border:1px solid hsla(0,0%,100%,.15);border-radius:8px;color:#fff;font-size:.75rem;padding:6px 8px 6px 28px;transition:all .15s;width:100%}.sb-selector-search-input::placeholder{color:hsla(0,0%,100%,.35)}.sb-selector-search-input:focus{background:hsla(0,0%,100%,.12);border-color:hsla(0,0%,100%,.35);outline:none}.sb-selector-placeholder{align-items:center;color:hsla(0,0%,100%,.4);display:flex;font-size:.72rem;gap:8px;justify-content:center;padding:14px 8px;text-align:center}.sb-selector-spinner{animation:spin .8s linear infinite;border:2px solid hsla(0,0%,100%,.15);border-radius:50%;border-top-color:hsla(0,0%,100%,.7);height:14px;width:14px}.sb-selector-student-list{background:rgba(0,0,0,.15);border:1px solid hsla(0,0%,100%,.1);border-radius:8px;max-height:180px;overflow-y:auto}.sb-selector-student-list::-webkit-scrollbar{width:4px}.sb-selector-student-list::-webkit-scrollbar-track{background:transparent}.sb-selector-student-list::-webkit-scrollbar-thumb{background:hsla(0,0%,100%,.15);border-radius:2px}.sb-selector-student-item{align-items:center;background:transparent;border:none;border-bottom:1px solid hsla(0,0%,100%,.05);color:#fff;cursor:pointer;display:flex;gap:8px;padding:7px 10px;text-align:left;transition:all .12s;width:100%}.sb-selector-student-item:last-child{border-bottom:none}.sb-selector-student-item:hover{background:hsla(0,0%,100%,.08)}.sb-selector-student-item-selected{background:rgba(25,118,210,.25)!important}.sb-selector-student-avatar{align-items:center;background:hsla(0,0%,100%,.15);border-radius:7px;color:hsla(0,0%,100%,.8);display:flex;flex-shrink:0;font-size:.6rem;font-weight:700;height:28px;justify-content:center;text-transform:uppercase;width:28px}.sb-selector-student-avatar-selected{background:linear-gradient(135deg,#1976d2,#42a5f5);color:#fff}.sb-selector-student-info{flex:1 1;min-width:0}.sb-selector-student-name{color:#fff;font-size:.75rem;font-weight:600}.sb-selector-student-email,.sb-selector-student-name{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sb-selector-student-email{color:hsla(0,0%,100%,.45);font-size:.62rem}.sb-selector-student-check{color:#42a5f5;flex-shrink:0}.sb-selector-continue-btn{align-items:center;background:linear-gradient(135deg,#1976d2,#1565c0);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.78rem;font-weight:600;gap:6px;justify-content:center;margin-top:4px;padding:8px;transition:all .15s;width:100%}.sb-selector-continue-btn:hover:not(:disabled){background:linear-gradient(135deg,#1e88e5,#1976d2);box-shadow:0 2px 8px rgba(25,118,210,.4)}.sb-selector-continue-btn:disabled{cursor:not-allowed;opacity:.35}.sb-selector-active{align-items:center;display:flex;gap:10px;padding:10px 12px}.sb-selector-active-avatar{align-items:center;background:linear-gradient(135deg,#1976d2,#42a5f5);border-radius:10px;color:#fff;display:flex;flex-shrink:0;font-size:.75rem;font-weight:700;height:36px;justify-content:center;text-transform:uppercase;width:36px}.sb-selector-active-info{display:flex;flex:1 1;flex-direction:column;min-width:0}.sb-selector-active-name{color:#fff;font-size:.82rem;font-weight:600}.sb-selector-active-detail,.sb-selector-active-name{line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sb-selector-active-detail{color:hsla(0,0%,100%,.55);font-size:.68rem}.sb-selector-switch-btn{align-items:center;background:hsla(0,0%,100%,.06);border:1px solid hsla(0,0%,100%,.18);border-radius:7px;color:hsla(0,0%,100%,.8);cursor:pointer;display:flex;font-size:.72rem;font-weight:500;gap:6px;justify-content:center;margin:0 10px 10px;padding:6px 10px;transition:all .15s;width:calc(100% - 20px)}.sb-selector-switch-btn:hover{background:hsla(0,0%,100%,.15);border-color:hsla(0,0%,100%,.3);color:#fff}.sidebar-footer{border-top:1px solid hsla(0,0%,100%,.1);padding:12px}.sidebar-logout-btn{align-items:center;background:hsla(0,0%,100%,.08);border:1px solid hsla(0,0%,100%,.1);border-radius:8px;color:hsla(0,0%,100%,.8);cursor:pointer;display:flex;font-size:.85rem;font-weight:500;gap:8px;justify-content:center;padding:10px 14px;transition:all .15s ease;width:100%}.sidebar-logout-btn:hover{background:hsla(0,0%,100%,.15);border-color:hsla(0,0%,100%,.2);color:#fff}.sidebar-logout-btn svg{height:18px;width:18px}.sidebar-version{font-size:.7rem;opacity:.4}.sidebar-menu-section{margin-bottom:4px}.sidebar-section-title{color:hsla(0,0%,100%,.4);font-size:.65rem;font-weight:600;letter-spacing:.08em;padding:12px 14px 6px;text-transform:uppercase}.sidebar-item{align-items:center;background:transparent;border:none;border-radius:8px;color:hsla(0,0%,100%,.7);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;margin:2px 0;padding:10px 14px;text-align:left;transition:all .15s ease;width:100%}.sidebar-item:hover:not(.disabled){background:hsla(0,0%,100%,.1);color:#fff}.sidebar-item.active{background:hsla(0,0%,100%,.15);color:#fff;font-weight:600}.sidebar-item.disabled{cursor:not-allowed;opacity:.4}.sidebar-item-icon{align-items:center;display:flex;flex-shrink:0;height:20px;justify-content:center;margin-right:10px;opacity:.8;width:20px}.sidebar-item-icon svg{height:100%;width:100%}.sidebar-item.active .sidebar-item-icon,.sidebar-item:hover:not(.disabled) .sidebar-item-icon{opacity:1}.sidebar-item-label{flex:1 1}.sidebar-submenu{display:flex;flex-direction:column}.sidebar-submenu-toggle{position:relative}.sidebar-submenu-arrow{font-size:.65rem;margin-left:8px;opacity:.5;transition:transform .2s ease}.sidebar-submenu.open .sidebar-submenu-arrow{transform:rotate(180deg)}.sidebar-submenu-items{border-left:1px solid hsla(0,0%,100%,.15);margin-bottom:2px;margin-left:30px;margin-top:2px;padding-left:12px}.sidebar-subitem{font-size:.8rem;padding:8px 12px}.sidebar-subitem .sidebar-item-icon{font-size:.95rem;margin-right:10px}.dashboard-content{background:#f5f5f5;display:flex;flex:1 1;flex-direction:column;overflow-x:hidden;overflow-y:auto}.dashboard-empty{align-items:center;color:#666;display:flex;font-size:1rem;height:100%;justify-content:center;padding:40px}.dashboard-empty .empty-state{max-width:400px;text-align:center}.dashboard-empty .empty-icon{font-size:3rem;margin-bottom:16px;opacity:.7}.dashboard-empty .empty-state h3{color:#333;font-size:1.3rem;margin:0 0 12px}.dashboard-empty .empty-state p{color:#666;margin:0 0 16px}.dashboard-empty .empty-options{list-style:none;margin:0;padding:0;text-align:left}.dashboard-empty .empty-options li{border-bottom:1px solid #eee;padding:8px 0}.dashboard-empty .empty-options li:last-child{border-bottom:none}.editor-full{display:flex;flex-direction:column;height:100%}.sidebar-filter{padding:8px 16px}.sidebar-select{background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.3);border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;padding:10px 12px;width:100%}.sidebar-select option{background:#1565c0;color:#fff}.sidebar-select:focus{background:hsla(0,0%,100%,.15);border-color:#fff;outline:none}.sidebar-history-list{margin:8px 0;max-height:300px;overflow-y:auto}.sidebar-history-item{border-bottom:1px solid hsla(0,0%,100%,.1);cursor:pointer;padding:10px 16px;transition:background .15s}.sidebar-history-item:hover{background:hsla(0,0%,100%,.1)}.sidebar-history-item.active{background:hsla(0,0%,100%,.2)}.sidebar-history-title{color:#fff;display:block;font-size:.9rem;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-history-title .file-icon{margin-right:6px}.sidebar-history-type{background:hsla(0,0%,100%,.2);border-radius:10px;color:#fff;font-size:.7rem;padding:2px 8px;text-transform:uppercase}.sidebar-history-actions{align-items:center;display:flex;gap:6px}.permissions-btn{background:transparent;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;opacity:.6;padding:2px 4px;transition:opacity .15s,background .15s}.permissions-btn:hover{background:hsla(0,0%,100%,.15);opacity:1}.sidebar-history-item:hover .permissions-btn{opacity:.8}.permissions-modal{background:#fff;border-radius:12px;box-shadow:0 10px 40px rgba(0,0,0,.3);max-width:380px;overflow:hidden;width:100%}.modal-header{background:#1976d2;color:#fff;padding:16px 20px}.modal-header h3{font-size:1.1rem;margin:0}.modal-close{background:transparent;color:#fff;font-size:1.5rem;opacity:.8}.modal-close:hover{opacity:1}.modal-body{padding:20px}.modal-subtitle{color:#666;font-size:.9rem;margin-bottom:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.permissions-grid{display:flex;flex-direction:column;gap:12px}.permissions-header{border-bottom:1px solid #eee;color:#666;font-size:.85rem;font-weight:600;padding-bottom:8px;text-align:center}.permissions-header,.permissions-row{grid-gap:8px;display:grid;gap:8px;grid-template-columns:80px 1fr 1fr}.permissions-row{align-items:center}.role-label{color:#333;font-weight:500}.checkbox-wrapper{cursor:pointer;display:flex;justify-content:center}.checkbox-wrapper input{accent-color:#1976d2;cursor:pointer;height:18px;width:18px}.modal-footer{background:#f5f5f5;border-top:1px solid #e0e0e0;display:flex;gap:10px;justify-content:flex-end;padding:16px 20px}.modal-footer .btn-secondary{background:#e0e0e0;border:none;border-radius:6px;color:#333;cursor:pointer;font-weight:500;padding:8px 16px}.modal-footer .btn-secondary:hover{background:#d0d0d0}.modal-footer .btn-primary{background:#1976d2;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:8px 16px}.modal-footer .btn-primary:hover{background:#1565c0}.modal-footer .btn-primary:disabled,.modal-footer .btn-secondary:disabled{cursor:not-allowed;opacity:.6}.sidebar-empty,.sidebar-error,.sidebar-loading{color:hsla(0,0%,100%,.7);font-size:.9rem;padding:16px;text-align:center}.app-sidebar .file-drop-zone{background:hsla(0,0%,100%,.05);border-color:hsla(0,0%,100%,.4);margin:8px 12px;padding:16px}.app-sidebar .file-drop-zone:hover:not(.disabled){background:hsla(0,0%,100%,.1);border-color:#fff}.app-sidebar .file-drop-zone.dragging{background:hsla(0,0%,100%,.15);border-color:#fff}.app-sidebar .drop-zone-content p{color:hsla(0,0%,100%,.9)}.app-sidebar .drop-zone-hint{color:hsla(0,0%,100%,.6)!important}.app-sidebar .upload-message{font-size:.85rem;margin:8px 12px}.app-sidebar .upload-progress{color:#fff;font-size:.85rem;padding:8px;text-align:center}.sidebar-section-subtitle{color:hsla(0,0%,100%,.6);font-size:.75rem;letter-spacing:.5px;padding:8px 16px 4px;text-transform:uppercase}.sidebar-course-add{padding:0 12px 8px}.sidebar-program-courses{margin:4px 0;max-height:250px;overflow-y:auto}.sidebar-program-course-item{align-items:center;border-bottom:1px solid hsla(0,0%,100%,.1);display:flex;gap:8px;padding:8px 12px;transition:background .15s}.sidebar-program-course-item:hover{background:hsla(0,0%,100%,.1)}.course-order-controls{display:flex;flex-direction:column;gap:2px}.order-btn{background:hsla(0,0%,100%,.15);border:none;border-radius:3px;color:#fff;cursor:pointer;font-size:.65rem;padding:2px 4px;transition:background .15s}.order-btn:hover:not(:disabled){background:hsla(0,0%,100%,.3)}.order-btn:disabled{cursor:not-allowed;opacity:.3}.course-info{flex:1 1;min-width:0}.course-info .course-title{color:#fff;display:block;font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.course-status-select{background:hsla(0,0%,100%,.15);border:1px solid hsla(0,0%,100%,.3);border-radius:4px;color:#fff;cursor:pointer;font-size:.7rem;margin-top:4px;padding:2px 6px}.course-status-select option{background:#2c3e50;color:#fff}.remove-course-btn{background:transparent;border:none;border-radius:4px;color:hsla(0,0%,100%,.6);cursor:pointer;font-size:1.2rem;padding:2px 6px;transition:color .15s,background .15s}.remove-course-btn:hover{background:hsla(0,0%,100%,.1);color:#ff6b6b}.sidebar-programs-list{border-top:1px solid hsla(0,0%,100%,.1);margin:4px 0;max-height:200px;overflow-y:auto;padding-top:8px}.sidebar-program-item{align-items:center;background:hsla(0,0%,100%,.05);border-radius:6px;cursor:pointer;display:flex;gap:8px;margin:4px 8px;padding:10px 12px;transition:background .15s,transform .1s}.sidebar-program-item:hover{background:hsla(0,0%,100%,.12)}.sidebar-program-item.active{background:rgba(25,118,210,.3);border-left:3px solid #1976d2}.program-item-active-indicator{align-items:center;color:#4caf50;display:flex;font-size:.75rem;font-weight:700;height:18px;justify-content:center;min-width:18px;width:18px}.program-item-info{flex:1 1;min-width:0}.program-item-name{color:#fff;display:block;font-size:.85rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.program-item-year{color:hsla(0,0%,100%,.6);display:block;font-size:.7rem;margin-top:2px}.program-item-count{background:hsla(0,0%,100%,.1);border-radius:10px;color:hsla(0,0%,100%,.5);font-size:.7rem;padding:2px 8px;white-space:nowrap}.sidebar-new-program-btn{background:linear-gradient(135deg,#1976d2,#1565c0);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;margin-top:8px;padding:10px 12px;transition:all .15s;width:100%}.sidebar-new-program-btn:hover{background:linear-gradient(135deg,#1565c0,#0d47a1);transform:translateY(-1px)}.create-program-content{margin:0 auto;max-width:1200px;padding:24px}.program-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:24px}.program-header-left{flex:1 1}.program-header-right{align-items:center;display:flex;gap:16px}.program-header-right .header-message{border-radius:4px;font-size:.875rem;padding:6px 12px}.program-header-right .header-message.success{background:#e8f5e9;color:#2e7d32}.program-header-right .header-message.error{background:#ffebee;color:#c62828}.save-program-btn{font-size:1rem;font-weight:600;padding:10px 24px}.content-tabs-bar{background:#1e2a38;border-bottom:1px solid #2c3e50;display:flex;min-height:40px;overflow-x:auto;padding:0 8px;scrollbar-width:thin}.content-tabs-bar::-webkit-scrollbar{height:4px}.content-tabs-bar::-webkit-scrollbar-thumb{background:hsla(0,0%,100%,.2);border-radius:2px}.content-tab{align-items:center;background:transparent;border:none;border-bottom:2px solid transparent;color:hsla(0,0%,100%,.7);cursor:pointer;display:flex;font-size:.875rem;gap:8px;padding:8px 12px;transition:all .15s;white-space:nowrap}.content-tab:hover{background:hsla(0,0%,100%,.05);color:#fff}.content-tab.active{background:hsla(0,0%,100%,.1);border-bottom-color:#1976d2;color:#fff}.content-tab-icon{font-size:1rem}.content-tab-title{max-width:150px;overflow:hidden;text-overflow:ellipsis}.content-tab-close{background:transparent;border:none;border-radius:4px;color:hsla(0,0%,100%,.5);cursor:pointer;font-size:1rem;line-height:1;padding:2px 6px;transition:all .15s}.content-tab-close:hover{background:hsla(0,0%,100%,.2);color:#fff}.content-tabs-content{flex:1 1;overflow:hidden;position:relative}.content-tab-panel{display:none;height:100%;overflow:auto}.content-tab-panel.active{display:block}.history-content{padding:24px}.history-content h2{color:#1976d2;margin-bottom:8px}.student-history-detail{display:flex;flex-direction:column;gap:24px}.student-history-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;gap:12px;padding-bottom:12px}.student-history-header h3{color:#333;font-size:1.25rem;margin:0}.school-year-badge{background:#e3f2fd;border-radius:16px;color:#1976d2;font-size:.85rem;font-weight:500;padding:4px 12px}.history-section{background:#fff;border-radius:8px;box-shadow:0 1px 3px rgba(0,0,0,.1);padding:16px}.history-section h4{border-bottom:1px solid #eee;color:#333;font-size:1rem;margin:0 0 12px;padding-bottom:8px}.history-empty,.history-loading{color:#666;font-style:italic;padding:16px;text-align:center}.history-programs-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.history-program-card{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;display:flex;flex-direction:column;gap:8px;padding:16px}.history-program-card:hover{border-color:#1976d2;box-shadow:0 2px 8px rgba(25,118,210,.15)}.program-card-header{align-items:flex-start;display:flex;justify-content:space-between}.program-name{color:#333;font-weight:600}.program-year{background:#e0e0e0;border-radius:4px;color:#666;font-size:.8rem;padding:2px 8px}.program-description{color:#666;font-size:.85rem;margin:0}.program-courses-count{color:#888;font-size:.8rem}.history-files-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.history-file-card{align-items:center;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;display:flex;gap:12px;padding:12px;transition:all .2s ease}.history-file-card:hover{background:#f5f9ff;border-color:#1976d2}.history-file-card.selected{background:#e3f2fd;border-color:#1976d2}.file-card-icon{flex-shrink:0;font-size:1.5rem}.file-card-info{display:flex;flex:1 1;flex-direction:column;gap:4px;min-width:0}.file-card-title{color:#333;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-card-type{border-radius:4px;display:inline-block;font-size:.75rem;padding:2px 8px;width:-webkit-fit-content;width:fit-content}.file-card-type.transcript{background:#e3f2fd;color:#1565c0}.file-card-type.testresult{background:#f3e5f5;color:#7b1fa2}.file-card-type.document{background:#e8f5e9;color:#2e7d32}.file-card-type.certificate{background:#fff8e1;color:#f57f17}.file-card-type.report{background:#fce4ec;color:#c2185b}.file-card-type.note{background:#fff3e0;color:#e65100}.file-card-date{color:#888;font-size:.75rem}.file-card-actions{display:flex;flex-shrink:0;gap:4px}.btn-icon{background:none;opacity:.7;padding:4px;transition:opacity .2s}.btn-icon:hover{opacity:1}.editor-panel{border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.program-header h2{align-items:center;color:#1976d2;display:flex;gap:12px;margin-bottom:4px}.program-active-badge{align-items:center;border-radius:12px;display:inline-flex;font-size:.75rem;font-weight:600;gap:4px;padding:4px 10px}.program-active-badge.active{background:#e8f5e9;border:1px solid #a5d6a7;color:#2e7d32}.program-active-badge.inactive{background:#fff3e0;border:1px solid #ffcc80;color:#e65100}.set-active-btn{margin-right:8px}.program-subtitle{color:#666;font-size:1rem}.program-placeholder{padding:60px 40px}.program-placeholder,.program-setup-form{background:#f8f9fa;border:2px dashed #ddd;border-radius:12px;text-align:center}.program-setup-form{margin:40px auto;max-width:500px;padding:40px}.program-setup-form h3{color:#333;margin-bottom:8px}.program-setup-form p{color:#666;margin-bottom:24px}.setup-form-fields{display:flex;flex-direction:column;gap:16px;text-align:left}.setup-form-fields .form-group{display:flex;flex-direction:column;gap:6px}.setup-form-fields label{color:#555;font-size:13px;font-weight:500}.setup-form-fields .form-select{background:#fff;border:1px solid #ddd;border-radius:6px;font-size:14px;padding:10px 12px}.saved-programs-section{border-top:1px solid #ddd;margin-top:24px;padding-top:24px;text-align:left}.saved-programs-section h4{color:#555;font-size:14px;margin-bottom:12px}.saved-programs-list{display:flex;flex-direction:column;gap:8px}.saved-program-item{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;display:flex;gap:10px;padding:10px 12px;transition:all .15s ease}.saved-program-item:hover{background:#e3f2fd;border-color:#1976d2}.sidebar-info{background:#f5f5f5;border-radius:6px;margin-bottom:12px;padding:12px}.info-row{display:flex;font-size:13px;justify-content:space-between;padding:4px 0}.info-label{color:#666}.info-value{color:#333;font-weight:500}.info-value.active{color:#2e7d32}.sidebar-hint{color:#666;font-size:13px;padding:12px;text-align:center}.placeholder-icon{font-size:3rem;margin-bottom:16px}.program-placeholder h3{color:#333;margin-bottom:8px}.program-placeholder p{color:#666;margin:0 auto;max-width:400px}.program-loading{padding:60px 40px;text-align:center}.loading-spinner{margin:0 auto 16px}.program-form{background:#fff;border-radius:12px;box-shadow:0 2px 12px rgba(0,0,0,.08)}.form-section{border-bottom:1px solid #eee;padding:20px 24px}.form-section h3{border-bottom:2px solid #1976d2;color:#333;display:inline-block;font-size:1rem;margin-bottom:16px;padding-bottom:8px}.form-input{border:2px solid #e0e0e0;border-radius:6px;font-size:.95rem;padding:10px 14px;transition:border-color .2s;width:100%}.form-input:focus{border-color:#1976d2;outline:none}.form-textarea{border:2px solid #e0e0e0;border-radius:6px;font-family:inherit;font-size:.95rem;padding:10px 14px;transition:border-color .2s;width:100%}.form-textarea:focus{border-color:#1976d2;outline:none}.no-courses-message{background:#f8f9fa;border-radius:8px;padding:24px;text-align:center}.no-courses-message p{color:#666;margin-bottom:8px}.no-courses-message .hint{color:#999;font-size:.85rem}.program-courses-table{overflow-x:auto}.program-courses-table table{border-collapse:collapse;width:100%}.program-courses-table td,.program-courses-table th{border-bottom:1px solid #eee;padding:12px;text-align:left}.program-courses-table th{background:#f8f9fa;color:#555;font-size:.85rem;font-weight:600;text-transform:uppercase}.program-courses-table tr:hover{background:#f8f9fa}.status-badge{border-radius:12px}.status-badge.status-planned{background:#e3f2fd;color:#1976d2}.status-badge.status-in-progress{background:#fff3e0;color:#f57c00}.status-badge.status-completed{background:#e8f5e9;color:#388e3c}.status-badge.status-dropped{background:#ffebee;color:#c62828}.btn-icon{padding:4px 8px;transition:background .15s}.btn-icon:hover{background:#f0f0f0}.form-actions{border-top:1px solid #eee;display:flex;gap:12px;justify-content:flex-end;padding:20px 24px}.form-actions .btn-primary{padding:10px 24px;width:auto}.form-actions .btn-secondary{background:#f0f0f0;color:#333;padding:10px 24px;width:auto}.form-actions .btn-secondary:hover{background:#e0e0e0}.template-section{padding:20px 24px}.template-section .section-description{color:#666;font-size:.9rem;line-height:1.5;margin-bottom:16px}.template-section .template-selector{min-height:450px}.create-program-content.with-templates{max-width:1400px}.content-section{background:#fff;border-radius:12px;box-shadow:0 2px 12px rgba(0,0,0,.08);margin-left:auto;margin-right:auto;margin-top:24px;max-width:800px;padding:24px}.content-section h3{border-bottom:2px solid #1976d2;color:#333;margin-bottom:16px;padding-bottom:12px}.user-list-container{background:#fff;border-radius:12px;box-shadow:0 2px 12px rgba(0,0,0,.08);margin-top:24px;overflow:hidden}.user-list-header{align-items:center;background:#f8f9fa;border-bottom:2px solid #1976d2;display:flex;justify-content:space-between;padding:20px 24px}.user-list-header h3{color:#333;margin:0}.user-list-header-right{align-items:center;display:flex;gap:16px}.btn-add-user{align-items:center;background:#4caf50;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:6px;padding:8px 16px;transition:background .2s}.btn-add-user:hover{background:#43a047}.user-count{background:#e3f2fd;border-radius:20px;color:#1565c0;font-size:.85rem;font-weight:500;padding:4px 12px}.user-list{overflow-x:auto}.user-table{border-collapse:collapse;width:100%}.user-table td,.user-table th{border-bottom:1px solid #eee;padding:14px 20px;text-align:left}.user-table th{background:#f8f9fa;color:#555;font-size:.85rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.user-table tr:hover{background:#f5f9ff}.user-table tr.inactive-row{background:#fafafa;opacity:.7}.user-name{color:#1976d2;cursor:pointer;font-weight:500}.user-name:hover{text-decoration:underline}.user-email{color:#666}.status-badge{display:inline-block;font-size:.8rem;font-weight:500;padding:4px 12px;text-transform:capitalize}.status-badge.active{background:#e8f5e9;color:#2e7d32}.status-badge.inactive{background:#ffebee;color:#c62828}.btn-edit,.btn-status{border:none;border-radius:6px;cursor:pointer;font-size:.85rem;padding:6px 12px;transition:all .2s}.btn-edit{background:#e3f2fd;color:#1565c0}.btn-edit:hover{background:#bbdefb}.btn-status.activate{background:#e8f5e9;color:#2e7d32}.btn-status.activate:hover{background:#c8e6c9}.btn-status.deactivate{background:#ffebee;color:#c62828}.btn-status.deactivate:hover{background:#ffcdd2}.btn-edit:disabled,.btn-status:disabled{cursor:not-allowed;opacity:.5}.content-error,.content-loading{background:#fff;border-radius:12px;color:#666;margin-top:24px;padding:40px;text-align:center}.content-error{background:#ffebee;color:#c62828}.modal-overlay{align-items:center;background:rgba(0,0,0,.5);bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,.3);max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.modal-header{align-items:center;background:#f8f9fa;border-bottom:2px solid #1976d2;display:flex;justify-content:space-between;padding:20px 24px}.modal-header h2{color:#333;font-size:1.3rem;margin:0}.modal-close{background:none;border:none;color:#999;cursor:pointer;font-size:1.8rem;height:32px;line-height:1;padding:0;width:32px}.modal-close:hover{color:#333}.modal-error,.modal-loading{color:#666;padding:40px;text-align:center}.modal-error{color:#c62828}.user-edit-form{padding:24px}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.form-row,.user-edit-form .form-group{margin-bottom:16px}.user-edit-form .form-group label{color:#555;display:block;font-size:.9rem;font-weight:500;margin-bottom:6px}.user-edit-form .form-group input{border:2px solid #e0e0e0;border-radius:8px;font-size:15px;padding:10px 14px;transition:border-color .2s;width:100%}.user-edit-form .form-group input:focus{border-color:#1976d2;outline:none}.form-error{background:#ffebee;border-radius:8px;color:#c62828;margin-bottom:16px;padding:12px;text-align:center}.form-info{background:#f5f5f5;margin-top:16px;padding:16px}.form-info p{color:#555;margin:4px 0}.password-note{color:#888!important;font-size:.9rem;margin-top:8px!important}.roles-section{background:#e3f2fd;border:1px solid #90caf9;border-radius:8px;margin-top:20px;padding:16px}.roles-section h4{color:#1565c0;font-size:1rem;margin:0 0 12px}.current-roles{margin-bottom:12px}.no-roles{color:#666;font-style:italic;margin:0}.role-tags{display:flex;flex-wrap:wrap;gap:8px}.role-tag{background:#1976d2;border-radius:20px;display:inline-flex;font-size:.9rem;font-weight:500;gap:6px;padding:6px 12px}.role-remove-btn,.role-tag{align-items:center;color:#fff}.role-remove-btn{background:hsla(0,0%,100%,.3);border:none;border-radius:50%;cursor:pointer;display:flex;font-size:14px;height:18px;justify-content:center;line-height:1;transition:background .2s;width:18px}.role-remove-btn:hover{background:hsla(0,0%,100%,.5)}.role-remove-btn:disabled{cursor:not-allowed;opacity:.5}.add-role-section{align-items:center;display:flex;gap:8px}.role-select{background:#fff;border:2px solid #90caf9;border-radius:8px;flex:1 1;font-size:14px;padding:8px 12px}.role-select:focus{border-color:#1976d2;outline:none}.btn-add-role{background:#4caf50;color:#fff;font-size:14px;padding:8px 16px;width:auto}.btn-add-role:hover{background:#43a047}.btn-add-role:disabled{background:#bdbdbd;cursor:not-allowed}.modal-actions{border-top:1px solid #eee;display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:16px}.btn-secondary{background:#f5f5f5;border:1px solid #ddd;color:#555}.btn-secondary:hover{background:#eee}.role-list-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.1);overflow:hidden}.role-list-header{align-items:center;background:#f8f9fa;border-bottom:2px solid #1976d2;display:flex;justify-content:space-between;padding:20px 24px}.role-list-header h3{color:#333;font-size:1.2rem;margin:0}.role-list-header .header-actions{align-items:center;display:flex;gap:16px}.role-count{color:#666;font-size:.9rem}.btn-add{background:#4caf50;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:background .2s;width:auto}.btn-add:hover{background:#43a047}.role-table{border-collapse:collapse;width:100%}.role-table th{background:#f0f0f0;border-bottom:1px solid #ddd;color:#555;font-weight:600;padding:14px 20px;text-align:left}.role-table td{border-bottom:1px solid #eee;padding:14px 20px}.role-table tr:hover{background:#f8f9fa}.role-table .inactive-row{background:#f5f5f5;opacity:.7}.role-name{color:#1976d2;cursor:pointer;font-weight:500}.role-name:hover{text-decoration:underline}.role-description{color:#666;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-danger{background:#f44336}.btn-danger:hover{background:#d32f2f}.btn-danger:disabled{background:#bdbdbd;cursor:not-allowed}.no-data{color:#999;font-style:italic;padding:40px!important;text-align:center}.role-edit-modal{max-width:500px}.role-edit-form{padding:24px}.role-edit-form .form-group{margin-bottom:20px}.role-edit-form .form-group label{color:#555;display:block;font-weight:500;margin-bottom:8px}.role-edit-form .form-group input,.role-edit-form .form-group textarea{border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:15px;padding:12px 14px;transition:border-color .2s;width:100%}.role-edit-form .form-group input:focus,.role-edit-form .form-group textarea:focus{border-color:#1976d2;outline:none}.role-edit-form .form-group textarea{min-height:80px;resize:vertical}.info-note{color:#888!important;font-size:.9rem;margin-top:8px!important}.icon-btn{background:transparent;border:none;border-radius:6px;cursor:pointer;font-size:1.2rem;opacity:.8;padding:6px 8px;transition:background .2s,transform .1s}.icon-btn:hover{background:rgba(0,0,0,.05);opacity:1;transform:scale(1.1)}.icon-btn:disabled{cursor:not-allowed;opacity:.4;transform:none}.icon-btn.icon-edit:hover{background:rgba(25,118,210,.1)}.icon-btn.icon-danger:hover{background:rgba(244,67,54,.1)}.icon-btn.icon-success:hover{background:rgba(76,175,80,.1)}.icon-btn.icon-warning:hover{background:rgba(255,152,0,.1)}.actions-cell{align-items:center;gap:4px}.course-list-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.1);overflow:hidden}.course-list-header{align-items:center;background:#f8f9fa;border-bottom:2px solid #1976d2;display:flex;justify-content:space-between;padding:20px 24px}.course-list-header h3{color:#333;font-size:1.2rem;margin:0}.course-count{color:#666;font-size:.9rem}.course-table{border-collapse:collapse;width:100%}.course-table th{background:#f0f0f0;border-bottom:1px solid #ddd;color:#555;font-weight:600;padding:14px 16px;text-align:left}.course-table td{border-bottom:1px solid #eee;padding:14px 16px}.course-table tr:hover{background:#f8f9fa}.course-table .inactive-row{background:#f5f5f5;opacity:.7}.course-code{color:#1976d2;cursor:pointer;font-weight:600}.course-code:hover{text-decoration:underline}.course-title{font-weight:500}.course-level,.course-subject{color:#666}.course-price{color:#2e7d32;font-weight:500}.course-edit-modal{max-width:600px}.course-edit-form{padding:24px}.course-edit-form .form-group{margin-bottom:16px}.course-edit-form .form-group label{color:#555;display:block;font-weight:500;margin-bottom:8px}.course-edit-form .form-group input,.course-edit-form .form-group select,.course-edit-form .form-group textarea{border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:15px;padding:10px 14px;transition:border-color .2s;width:100%}.course-edit-form .form-group input:focus,.course-edit-form .form-group select:focus,.course-edit-form .form-group textarea:focus{border-color:#1976d2;outline:none}.course-edit-form .form-group textarea{min-height:70px;resize:vertical}.course-edit-form .form-group select{background:#fff;cursor:pointer}.version-display{align-items:center;background:#f5f5f5;border-radius:8px;display:flex;font-size:15px;gap:10px;height:42px;padding:10px 14px}.version-number{color:#1976d2;font-size:16px;font-weight:600}.version-status{color:#666;font-size:13px}.version-status.active{color:#2e7d32}.version-status.inactive{color:#c62828}.btn-warning{background-color:#ff9800;border-radius:6px;transition:background-color .2s}.btn-warning:hover{background-color:#f57c00}.btn-warning:disabled{background-color:#ffcc80;cursor:not-allowed}.resources-layout{display:flex;gap:0;height:calc(100vh - 100px)}.resources-sidebar{background:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;min-width:280px;width:280px}.resources-editor{background:#fafafa;display:flex;flex:1 1;flex-direction:column;overflow:hidden}.history-with-editor{display:flex;gap:0;height:calc(100vh - 100px)}.history-dashboard{background:#f8f9fa;border-right:1px solid #e0e0e0;min-width:300px;overflow-y:auto;padding:20px;width:300px}.history-dashboard .welcome-card{margin-bottom:0}.history-editor{background:#fafafa;flex:1 1;overflow:hidden}.file-browser,.history-editor{display:flex;flex-direction:column}.file-browser{height:100%}.file-browser-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:16px}.file-browser-header h4{color:#333;font-size:14px;margin:0}.file-list{flex:1 1;overflow-y:auto;padding:8px}.file-item{align-items:center;border-radius:6px;cursor:pointer;display:flex;gap:12px;padding:10px 12px;transition:background-color .15s;-webkit-user-select:none;user-select:none}.file-item:hover{background-color:#e3f2fd}.file-item.selected{background-color:#bbdefb}.file-item .file-icon{flex-shrink:0;font-size:24px}.file-item .file-info{flex:1 1;min-width:0}.file-item .file-name{color:#333;display:block;font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-item .file-meta{color:#888;display:block;font-size:11px;margin-top:2px}.file-browser-footer{background:#f8f9fa;border-top:1px solid #e0e0e0;padding:12px 16px;text-align:center}.file-browser-footer small{color:#888;font-size:12px}.empty-files{color:#888;padding:40px 20px;text-align:center}.tabbed-editor{display:flex;flex-direction:column;height:100%}.tabbed-editor-empty{align-items:center;background:#fafafa;display:flex;height:100%;justify-content:center}.empty-message{color:#888}.empty-message .empty-icon{display:block;font-size:64px;margin-bottom:16px;opacity:.5}.empty-message h3{color:#666;margin:0 0 8px}.empty-message p{font-size:14px;margin:0}.editor-tabs{background:#e0e0e0;display:flex;flex-shrink:0;overflow-x:auto;padding:4px 4px 0}.editor-tab{align-items:center;background:#f5f5f5;border:1px solid #ddd;border-bottom:none;border-radius:6px 6px 0 0;color:#666;cursor:pointer;display:flex;font-size:13px;gap:8px;margin-right:2px;max-width:200px;min-width:120px;padding:8px 12px;transition:background-color .15s}.editor-tab:hover{background:#fff}.editor-tab.active{background:#fff;border-color:#ccc;color:#333}.editor-tab .tab-icon{flex-shrink:0;font-size:16px}.editor-tab .tab-name{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.editor-tab .tab-modified{color:#ff9800;font-size:18px;font-weight:700;margin-left:-4px}.editor-tab .tab-close{background:none;border:none;border-radius:3px;color:#888;cursor:pointer;flex-shrink:0;font-size:16px;line-height:1;padding:2px 4px}.editor-tab .tab-close:hover{background:#e0e0e0;color:#333}.editor-tab .tab-split-indicator{color:#1976d2;font-size:12px;margin-left:4px}.editor-tab.split-active{border-bottom:2px solid #ff9800}.tab-context-menu{animation:contextMenuFadeIn .15s ease;background:#fff;border:1px solid #ddd;border-radius:6px;box-shadow:0 4px 16px rgba(0,0,0,.15);min-width:180px;padding:4px 0;position:fixed;z-index:1000}@keyframes contextMenuFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.context-menu-item{align-items:center;color:#333;cursor:pointer;display:flex;font-size:14px;gap:10px;padding:8px 16px;transition:background .15s}.context-menu-item:hover{background:#f0f0f0}.context-menu-item .context-icon{color:#666;font-size:12px;text-align:center;width:16px}.context-menu-divider{background:#e0e0e0;height:1px;margin:4px 0}.editor-content-wrapper{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.editor-content-wrapper.split{flex-direction:row}.editor-content-wrapper.split .editor-content{flex:1 1;overflow:hidden}.editor-content-wrapper.split .split-panel{background:#fff;display:flex;flex:1 1;flex-direction:column;overflow:hidden}.editor-splitter-container{display:flex;flex:1 1;height:100%;overflow:hidden}.editor-splitter-left,.editor-splitter-right{display:flex;flex-direction:column;height:100%;overflow:hidden}.editor-splitter-divider{background:linear-gradient(180deg,#1976d2,#1565c0);cursor:col-resize;flex-shrink:0;min-width:6px;transition:width .15s,background .15s;width:6px}.editor-splitter-divider.dragging,.editor-splitter-divider:hover{background:#2196f3;width:8px}.split-panel-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;color:#555;display:flex;font-size:13px;font-weight:500;gap:8px;padding:8px 12px}.split-panel-header .tab-icon{font-size:14px}.split-close-btn{background:none;border:none;border-radius:3px;color:#888;cursor:pointer;font-size:16px;margin-left:auto;padding:2px 6px}.split-close-btn:hover{background:#e0e0e0;color:#333}.tab-splitter-container{display:flex;flex:1 1;height:100%;overflow:hidden}.tab-splitter-left,.tab-splitter-right{display:flex;flex-direction:column;height:100%;overflow:hidden}.tab-splitter-left .content-tab-panel,.tab-splitter-right .content-tab-panel{flex:1 1;overflow:auto}.tab-splitter-divider{background:linear-gradient(180deg,#1976d2,#1565c0);cursor:col-resize;flex-shrink:0;min-width:6px;transition:width .15s,background .15s;width:6px}.tab-splitter-divider.dragging,.tab-splitter-divider:hover{background:#2196f3;width:8px}.tab-splitter-right .split-panel-header{align-items:center;background:#f0f4f8;border-bottom:1px solid #e0e0e0;color:#555;display:flex;font-size:13px;font-weight:500;gap:8px;padding:8px 12px}.split-panel-icon{font-size:14px}.split-panel-title{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.editor-content{background:#fff;flex:1 1;overflow:hidden}.editor-content,.editor-loading{display:flex;flex-direction:column}.editor-loading{align-items:center;color:#888;height:100%;justify-content:center}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #e0e0e0;border-radius:50%;border-top-color:#1976d2;height:40px;margin-bottom:16px;width:40px}.editor-toolbar-actions{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:8px 16px}.editor-toolbar-actions .file-name{color:#333;font-weight:500}.editor-toolbar-actions .modified-indicator{color:#ff9800;font-style:italic}.editor-toolbar-actions .toolbar-buttons{display:flex;gap:8px}.btn-sm,.editor-error{font-size:13px}.editor-error{background:#ffebee;color:#c62828;padding:8px 16px}.rich-text-editor{display:flex;flex-direction:column;height:100%}.rich-text-editor .quill{display:flex;flex:1 1;flex-direction:column}.rich-text-editor .ql-container{flex:1 1;font-size:15px;overflow-y:auto}.rich-text-editor .ql-editor{min-height:300px}.spreadsheet-editor{display:flex;flex-direction:column;height:100%}.spreadsheet-container{flex:1 1;overflow:auto;padding:16px}.spreadsheet-container .Spreadsheet{width:100%}.spreadsheet-container .Spreadsheet__cell{border:1px solid #e0e0e0;min-width:80px;padding:6px 8px}.spreadsheet-container .Spreadsheet__header{background:#f5f5f5;font-weight:500}.pdf-viewer{display:flex;flex-direction:column;height:100%}.pdf-toolbar{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;padding:8px 16px}.pdf-info .file-name{color:#333;font-weight:500}.pdf-controls{align-items:center;display:flex;gap:16px}.page-controls,.zoom-controls{align-items:center;display:flex;gap:8px}.page-controls button,.zoom-controls button{background:#e0e0e0;border:none;border-radius:4px;cursor:pointer;font-size:14px;padding:6px 10px}.page-controls button:hover,.zoom-controls button:hover{background:#d0d0d0}.page-controls button:disabled{cursor:not-allowed;opacity:.5}.page-indicator{color:#666;font-size:13px;min-width:120px;text-align:center}.pdf-container{background:#e0e0e0;display:flex;flex:1 1;justify-content:center;overflow:auto;padding:20px}.pdf-loading{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:40px}.image-error .error-message,.pdf-error .error-message{align-items:center;display:flex;flex-direction:column;gap:12px;padding:40px}.error-message .error-icon{font-size:48px}.image-viewer{display:flex;flex-direction:column;height:100%}.image-toolbar{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:8px 16px}.image-toolbar .file-name{color:#333;font-weight:500}.image-controls{display:flex;gap:16px}.rotation-controls{display:flex;gap:8px}.rotation-controls button{background:#e0e0e0;border:none;border-radius:4px;cursor:pointer;font-size:14px;padding:6px 10px}.rotation-controls button:hover{background:#d0d0d0}.image-container{align-items:center;background:#e0e0e0;display:flex;flex:1 1;justify-content:center;overflow:auto;padding:20px}.image-container img{box-shadow:0 4px 20px rgba(0,0,0,.2);max-height:100%;max-width:100%;object-fit:contain}.image-loading{flex-direction:column}.image-loading,.unsupported-file{align-items:center;display:flex;height:100%;justify-content:center}.unsupported-file{color:#888;font-size:16px}.online-users-container{background:#fff;border-radius:12px;box-shadow:0 2px 12px rgba(0,0,0,.08);display:flex;flex-direction:column;max-height:400px;overflow:hidden}.online-users-header{align-items:center;background:#fafafa;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:16px 20px}.online-users-header h3{align-items:center;color:#333;display:flex;font-size:16px;gap:10px;margin:0}.status-dot{border-radius:50%;height:10px;width:10px}.status-dot.online{background:#4caf50;box-shadow:0 0 8px rgba(76,175,80,.5)}.status-dot.offline{background:#9e9e9e}.btn-retry{background:none;border:1px solid #1976d2;border-radius:4px;color:#1976d2;cursor:pointer;font-size:12px;padding:4px 12px}.btn-retry:hover{background:#e3f2fd}.connection-error{background:#ffebee;color:#c62828;font-size:13px;padding:12px 20px}.no-users-online{color:#666;padding:40px 20px;text-align:center}.online-users-list{flex:1 1;overflow-y:auto}.online-user-item{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;gap:12px;padding:12px 20px;transition:background .2s}.online-user-item:hover{background:#f5f5f5}.online-user-item:last-child{border-bottom:none}.online-user-item .user-avatar{align-items:center;background:linear-gradient(135deg,#1976d2,#0d47a1);border-radius:50%;color:#fff;display:flex;font-size:14px;font-weight:600;height:40px;justify-content:center;width:40px}.online-user-item .user-info{display:flex;flex:1 1;flex-direction:column}.online-user-item .user-name{color:#333;font-weight:500}.online-user-item .user-role{color:#666;font-size:12px}.user-actions{display:flex;gap:8px}.btn-call{align-items:center;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:16px;height:36px;justify-content:center;transition:transform .2s,box-shadow .2s;width:36px}.btn-call:hover{transform:scale(1.1)}.btn-call.audio{background:#4caf50;color:#fff}.btn-call.audio:hover{box-shadow:0 4px 12px rgba(76,175,80,.4)}.btn-call.video{background:#1976d2;color:#fff}.btn-call.video:hover{box-shadow:0 4px 12px rgba(25,118,210,.4)}.video-call-overlay{align-items:center;background:rgba(0,0,0,.9);bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.video-call-container{background:#1a1a1a;display:flex;flex-direction:column;height:100%;width:100%}.video-call-header{align-items:center;background:rgba(0,0,0,.5);display:flex;justify-content:space-between;left:0;padding:16px 24px;position:absolute;right:0;top:0;z-index:10}.peer-info{display:flex;flex-direction:column}.peer-name{color:#fff;font-size:18px;font-weight:600}.call-status{color:hsla(0,0%,100%,.7);font-size:14px}.btn-close-call{background:hsla(0,0%,100%,.2);border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:18px;height:40px;transition:background .2s;width:40px}.btn-close-call:hover{background:hsla(0,0%,100%,.3)}.video-call-content{align-items:center;display:flex;flex:1 1;justify-content:center;position:relative}.call-ended-prompt,.calling-prompt,.incoming-call-prompt{align-items:center;color:#fff;display:flex;flex-direction:column;gap:16px;text-align:center}.avatar-large,.caller-avatar{align-items:center;background:linear-gradient(135deg,#1976d2,#0d47a1);border-radius:50%;color:#fff;display:flex;font-size:40px;font-weight:600;height:120px;justify-content:center;width:120px}.caller-avatar.pulse{animation:pulse 2s ease-in-out infinite}.call-ended-prompt h3,.calling-prompt h3,.incoming-call-prompt h3{font-size:24px;margin:0}.call-ended-prompt p,.calling-prompt p,.incoming-call-prompt p{color:hsla(0,0%,100%,.7);margin:0}.incoming-call-actions{display:flex;gap:24px;margin-top:24px}.btn-accept,.btn-reject{align-items:center;border:none;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;font-size:14px;gap:8px;padding:16px 24px;transition:transform .2s,box-shadow .2s}.btn-accept span,.btn-reject span{align-items:center;border-radius:50%;display:flex;font-size:24px;height:50px;justify-content:center;width:50px}.btn-reject{background:#c62828;color:#fff}.btn-reject:hover{box-shadow:0 4px 20px rgba(198,40,40,.4);transform:scale(1.05)}.btn-reject span{background:hsla(0,0%,100%,.2)}.btn-accept{background:#4caf50;color:#fff}.btn-accept:hover{box-shadow:0 4px 20px rgba(76,175,80,.4);transform:scale(1.05)}.btn-accept span{background:hsla(0,0%,100%,.2)}.btn-cancel-call{background:#c62828;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;margin-top:24px;padding:12px 32px;transition:background .2s}.btn-cancel-call:hover{background:#b71c1c}.video-streams{height:100%;position:relative;width:100%}.remote-video-container{align-items:center;background:#000;display:flex;height:100%;justify-content:center;width:100%}.remote-video{height:100%;object-fit:contain;width:100%}.remote-video-container .video-placeholder,.remote-video-container.video-off .remote-video{display:none}.remote-video-container.video-off .video-placeholder{align-items:center;display:flex;justify-content:center}.peer-muted-indicator{background:rgba(0,0,0,.7);border-radius:8px;color:#fff;font-size:14px;padding:8px 16px;position:absolute;right:24px;top:80px}.local-video-container{background:#333;border-radius:12px;bottom:100px;box-shadow:0 4px 20px rgba(0,0,0,.4);height:150px;overflow:hidden;position:absolute;right:24px;width:200px}.local-video{height:100%;object-fit:cover;transform:scaleX(-1);width:100%}.local-video-container.video-off .local-video{display:none}.video-placeholder-small{align-items:center;color:#fff;display:none;font-size:14px;height:100%;justify-content:center;width:100%}.local-video-container.video-off .video-placeholder-small{display:flex}.video-call-controls{background:rgba(0,0,0,.7);border-radius:50px;bottom:24px;display:flex;gap:16px;left:50%;padding:16px 24px;position:absolute;transform:translateX(-50%);z-index:10}.control-btn{align-items:center;background:hsla(0,0%,100%,.2);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:24px;height:56px;justify-content:center;transition:background .2s,transform .2s;width:56px}.control-btn:hover{background:hsla(0,0%,100%,.3);transform:scale(1.1)}.control-btn.disabled{background:#c62828}.control-btn.end-call{background:#c62828;transform:rotate(135deg)}.control-btn.end-call:hover{background:#b71c1c}.call-error-message{align-items:center;color:#fff;display:flex;flex-direction:column;gap:16px;text-align:center}.call-error-message p{color:#ef5350;font-size:16px}@media (max-width:768px){.local-video-container{bottom:120px;height:90px;right:16px;width:120px}.video-call-controls{gap:12px;padding:12px 16px}.control-btn{font-size:20px;height:48px;width:48px}}.video-section-page{max-width:800px;padding:40px}.video-section-page h3{color:#333;font-size:24px;margin-bottom:8px}.video-section-page .section-description{color:#666;margin-bottom:24px}.video-section{margin-top:24px}.video-section h3{color:#333;font-size:18px;margin-bottom:8px}.video-section .section-description{color:#666;font-size:14px;margin-bottom:16px}.active-call-indicator{align-items:center;background:linear-gradient(135deg,#4caf50,#388e3c);color:#fff;cursor:pointer;display:flex;gap:12px;padding:12px 16px;transition:background .2s}.active-call-indicator:hover{background:linear-gradient(135deg,#43a047,#2e7d32)}.call-pulse{animation:callPulse 1.5s ease-in-out infinite;background:#fff;border-radius:50%;height:12px;width:12px}@keyframes callPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.8)}}.btn-focus-call{background:hsla(0,0%,100%,.2);border:1px solid hsla(0,0%,100%,.4);border-radius:4px;color:#fff;cursor:pointer;font-size:12px;margin-left:auto;padding:4px 12px}.btn-focus-call:hover{background:hsla(0,0%,100%,.3)}.btn-call:disabled{cursor:not-allowed;opacity:.5}.btn-call:disabled:hover{box-shadow:none;transform:none}.section-header{align-items:center;margin-bottom:20px}.section-header h3{margin:0}.quick-actions{background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.05);margin-bottom:24px;padding:20px}.quick-actions h3{margin-bottom:16px}.recent-assignments{background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.05);padding:20px}.recent-assignments h3{color:#333;margin-bottom:16px}.assignments-section,.user-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.05);padding:20px}.user-section h3{color:#333;margin-bottom:8px}.section-description{color:#666;font-size:.9rem;margin-bottom:20px}.actions-cell{display:flex;gap:8px}.btn-small{font-size:.85rem;padding:6px 12px;width:auto}.btn-secondary{background-color:#757575;color:#fff}.btn-secondary:hover{background-color:#616161}.btn-danger{background-color:#d32f2f}.btn-danger:hover{background-color:#c62828}.empty-message{color:#666;font-style:italic;padding:40px 20px;text-align:center}.stat-card{transition:transform .2s,box-shadow .2s}.stat-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.1)}.routing-form-list{background:#fff;border-radius:12px;padding:20px}.routing-form-list .section-header h3{color:#333;margin-bottom:8px}.routing-form-list .tabs{border-bottom:2px solid #e0e0e0;display:flex;gap:8px;margin-bottom:20px;padding-bottom:0}.routing-form-list .tab{background:transparent;border:none;border-bottom:2px solid transparent;color:#666;cursor:pointer;font-size:.95rem;margin-bottom:-2px;padding:12px 24px;transition:all .2s}.routing-form-list .tab:hover{color:#1976d2}.routing-form-list .tab.active{border-bottom-color:#1976d2;color:#1976d2;font-weight:500}.template-card{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:12px;overflow:hidden}.template-header{align-items:center;cursor:pointer;display:flex;justify-content:space-between;padding:16px;transition:background .2s}.template-header:hover{background:#f0f0f0}.template-info h4{color:#333;margin:0 0 4px}.template-description{color:#666;font-size:.9rem;margin-bottom:8px}.template-meta{align-items:center;display:flex;gap:12px}.step-count{color:#888;font-size:.85rem}.template-actions{align-items:center;display:flex;gap:8px}.expand-icon{color:#888;font-size:.8rem;margin-left:8px}.template-steps{background:#fff;border-top:1px solid #e0e0e0;padding:0 16px 16px}.template-steps h5{color:#666;margin:12px 0 8px}.step-list{margin:0;padding-left:20px}.step-item{align-items:center;border-bottom:1px solid #f0f0f0;justify-content:space-between;padding:8px 0}.step-item:last-child{border-bottom:none}.step-info{display:flex;flex-direction:column}.step-info strong{color:#333}.step-role{color:#888;font-size:.85rem}.step-days{background:#e3f2fd;border-radius:12px;color:#1976d2;font-size:.85rem;padding:2px 8px}.data-table{border-collapse:collapse;margin-top:16px;width:100%}.data-table td,.data-table th{border-bottom:1px solid #e0e0e0;padding:12px;text-align:left}.data-table th{background:#f5f5f5;color:#555;font-weight:600}.data-table tr:hover{background:#f8f9fa}.progress-cell{display:flex;flex-direction:column;gap:4px}.progress-bar{background:#e0e0e0;border-radius:4px;height:8px;width:100px}.progress-fill{background:linear-gradient(90deg,#4caf50,#8bc34a)}.progress-text{color:#666;font-size:.8rem}.status-active,.status-completed{background:#e8f5e9;color:#2e7d32}.status-in-progress,.status-progress{background:#fff3e0;color:#ef6c00}.status-draft{background:#e3f2fd;color:#1565c0}.status-pending{background:#f5f5f5;color:#757575}.status-inactive{background:#fafafa;color:#9e9e9e}.modal-large{max-height:90vh;max-width:800px;overflow-y:auto}.form-section{border-bottom:1px solid #e0e0e0;margin-bottom:24px;padding-bottom:16px}.form-section:last-child{border-bottom:none}.form-section h4{color:#333;margin-bottom:16px}.section-header-inline{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.section-hint{color:#666;font-size:.9rem;margin-bottom:16px}.steps-editor{display:flex;flex-direction:column;gap:16px}.step-editor-item{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;display:flex;gap:16px;padding:16px}.step-number{align-items:center;background:#1976d2;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-weight:700;height:32px;justify-content:center;width:32px}.step-fields{flex:1 1}.step-row{display:flex;gap:12px;margin-bottom:12px}.step-row .form-group{flex:1 1;margin-bottom:0}.form-group-small{max-width:80px}.step-options{margin-top:8px}.checkbox-label{align-items:center;color:#555;display:flex;font-size:.9rem;gap:8px}.step-actions{display:flex;flex-direction:column;gap:4px}.btn-icon{background:transparent;border:none;border-radius:4px;cursor:pointer;font-size:1rem;transition:background .2s}.btn-icon:hover{background:#e0e0e0}.btn-icon:disabled{cursor:not-allowed;opacity:.3}.btn-icon.btn-danger:hover{background:#ffebee}.student-routing-form{background:#fff;border-radius:12px;padding:24px}.form-header{align-items:flex-start;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.form-header-info h3{color:#333;margin:0 0 8px}.student-info{color:#666;margin-bottom:8px}.form-meta{align-items:center;display:flex;flex-wrap:wrap;gap:16px}.date-info{color:#888;font-size:.85rem}.form-notes{background:#fff3e0;border-left:4px solid #ff9800;border-radius:8px;margin-bottom:24px;padding:12px 16px}.steps-timeline h4{color:#333;margin-bottom:16px}.timeline{position:relative}.timeline-step{display:flex;gap:16px;padding-bottom:24px}.timeline-step:last-child{padding-bottom:0}.step-indicator{flex-direction:column}.step-circle{align-items:center;background:#e0e0e0;border-radius:50%;color:#666;display:flex;font-weight:700;height:32px;justify-content:center;transition:all .3s;width:32px}.step-completed .step-circle{background:#4caf50;color:#fff}.step-in-progress .step-circle{animation:pulse 2s infinite;background:#ff9800;color:#fff}@keyframes pulse{0%,to{box-shadow:0 0 0 0 rgba(255,152,0,.4)}50%{box-shadow:0 0 0 8px rgba(255,152,0,0)}}.step-line{background:#e0e0e0;flex:1 1;margin-top:4px;min-height:20px;width:2px}.step-completed .step-line{background:#4caf50}.step-content{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px}.step-in-progress .step-content{background:#fff8e1;border-color:#ff9800}.step-completed .step-content{background:#f1f8e9;border-color:#4caf50}.step-header h5{color:#333;margin:0}.step-status-badge{border-radius:12px;font-size:.8rem;font-weight:500;padding:4px 12px}.step-description{color:#666;margin-bottom:12px}.step-details{display:flex;flex-wrap:wrap;font-size:.9rem;gap:16px;margin-bottom:8px}.assigned-role,.due-date{color:#555}.signoff-info{background:#e8f5e9;border-radius:6px;color:#2e7d32;padding:8px 12px}.signoff-info,.step-notes{font-size:.9rem;margin-top:8px}.step-notes{color:#666;font-style:italic}.signoff-action{display:flex;flex-direction:column;gap:8px;margin-top:12px}.signoff-action textarea{border:1px solid #ddd;border-radius:6px;font-size:.9rem;padding:8px 12px;resize:vertical}.completion-banner{align-items:center;background:linear-gradient(135deg,#4caf50,#8bc34a);border-radius:12px;color:#fff;display:flex;gap:16px;margin-top:24px;padding:20px}.completion-banner span:first-child{font-size:2rem}.completion-banner strong{font-size:1.2rem}.completion-banner p{margin:4px 0 0;opacity:.9}.task-list .section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.task-summary{display:flex;gap:12px}.task-count{border-radius:12px;font-size:.9rem;font-weight:500;padding:4px 12px}.task-count.pending{background:#fff3e0;color:#ef6c00}.task-count.overdue{background:#ffebee;color:#c62828}.filter-bar{align-items:center;background:#f5f5f5;border-radius:8px;display:flex;gap:12px;margin-bottom:16px;padding:12px}.filter-bar label{color:#666;font-size:.9rem}.filter-bar select{border:1px solid #ddd;border-radius:6px;padding:6px 12px}.task-cards{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.task-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:16px;transition:all .2s}.task-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.1)}.task-card.overdue{background:#fff8f8;border-color:#ef5350}.task-card.due-soon{background:#fffbf5;border-color:#ff9800}.task-card.completed{background:#f5f5f5;opacity:.7}.task-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:8px}.task-card-header h4{color:#333;margin:0}.task-description{color:#666;font-size:.9rem;margin-bottom:12px}.task-details{display:flex;flex-wrap:wrap;font-size:.85rem;gap:12px;margin-bottom:12px}.assigned-role,.student-name{color:#555}.due-date-info{color:#666;font-size:.9rem;margin-bottom:12px}.due-date-info.overdue{color:#c62828}.due-date-info.due-soon{color:#ef6c00}.overdue-label{background:#c62828;border-radius:4px;color:#fff;font-size:.75rem;font-weight:700;margin-left:8px;padding:2px 8px}.task-actions{display:flex;gap:8px}.quick-actions{margin-top:24px}.quick-actions h3{color:#333;margin-bottom:12px}.action-buttons{display:flex;flex-wrap:wrap;gap:12px}.action-btn{background:#f5f5f5;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;font-size:.95rem;padding:12px 20px;transition:all .2s}.action-btn:hover{background:#e3f2fd;border-color:#1976d2;color:#1976d2}.info-section{background:#f8f9fa;border-radius:8px;margin-top:24px;padding:16px}.info-section h3{color:#333;margin-bottom:12px}.info-section ul{color:#555;margin:0;padding-left:20px}.info-section li{padding:4px 0}.action-bar{margin-bottom:16px}.stat-card.clickable{cursor:pointer}.stat-card.stat-warning{background:#fff8e1;border-color:#ff9800}.stat-card.stat-warning h3{color:#ef6c00}.empty-state{color:#666;padding:40px 20px;text-align:center}.empty-state p{margin-bottom:16px}.form-info{background:#e3f2fd;border-radius:8px;color:#1565c0;margin:16px 0;padding:12px 16px}.form-info p{font-size:.9rem;margin:0}.form-group-inline,.form-group-inline label{align-items:center;display:flex;gap:8px}.btn-view,.form-group-inline label{cursor:pointer}.btn-view{background:#1976d2;border:none;border-radius:4px;color:#fff}.btn-view:hover{background:#1565c0}.student-selector-overlay{align-items:center;background:linear-gradient(135deg,#1976d2,#0d47a1);display:flex;justify-content:center;min-height:calc(100vh - 60px);padding:24px}.student-selector-container{animation:selectorSlideUp .4s ease-out;background:#fff;border-radius:20px;box-shadow:0 25px 60px rgba(0,0,0,.3);max-width:560px;overflow:hidden;width:100%}@keyframes selectorSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.student-selector-header{padding:32px 24px 16px;text-align:center}.student-selector-icon{align-items:center;background:linear-gradient(135deg,#1976d2,#0d47a1);border-radius:16px;color:#fff;display:inline-flex;height:56px;justify-content:center;margin-bottom:16px;width:56px}.student-selector-title{color:#1e293b;font-size:1.5rem;font-weight:700;margin-bottom:4px}.student-selector-subtitle{color:#64748b;font-size:.875rem}.student-selector-body{padding:8px 24px 16px}.selector-step{margin-bottom:20px}.selector-step-disabled{opacity:.5;pointer-events:none}.selector-step-header{align-items:center;display:flex;gap:10px;margin-bottom:10px}.selector-step-number{align-items:center;background:linear-gradient(135deg,#1976d2,#0d47a1);border-radius:50%;color:#fff;display:inline-flex;flex-shrink:0;font-size:.75rem;font-weight:700;height:28px;justify-content:center;width:28px}.selector-step-label{color:#334155;font-size:.875rem;font-weight:600}.selector-step-count{background:#f1f5f9;border-radius:12px;color:#64748b;font-size:.75rem;padding:2px 8px}.selector-step-optional{background:#f8fafc;border-radius:12px;color:#94a3b8;font-size:.7rem;font-style:italic;padding:2px 8px}.selector-field{position:relative}.selector-field-icon{color:#94a3b8;left:12px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);z-index:1}.selector-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;border:2px solid #e2e8f0;border-radius:12px;color:#334155;cursor:pointer;font-size:.875rem;padding:10px 12px 10px 40px;transition:all .2s;width:100%}.selector-select:focus{border-color:#1976d2;box-shadow:0 0 0 3px rgba(25,118,210,.15);outline:none}.selector-select:disabled{background-color:#f8fafc;color:#94a3b8;cursor:not-allowed}.selector-search{margin-bottom:10px;position:relative}.selector-search-icon{color:#94a3b8;left:12px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.selector-search-input{border:2px solid #e2e8f0;border-radius:10px;color:#334155;font-size:.825rem;padding:8px 12px 8px 36px;transition:all .2s;width:100%}.selector-search-input:focus{border-color:#1976d2;box-shadow:0 0 0 3px rgba(25,118,210,.15);outline:none}.selector-loading{align-items:center;color:#64748b;display:flex;font-size:.85rem;gap:10px;justify-content:center;padding:24px}.selector-spinner{animation:spin .8s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#1976d2;height:20px;width:20px}.selector-placeholder{align-items:center;color:#94a3b8;display:flex;flex-direction:column;font-size:.85rem;gap:8px;padding:24px;text-align:center}.selector-student-list{background:#fafbfc;border:2px solid #e2e8f0;border-radius:12px;max-height:280px;overflow-y:auto}.selector-student-list::-webkit-scrollbar{width:6px}.selector-student-list::-webkit-scrollbar-track{background:transparent}.selector-student-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.selector-student-item{align-items:center;background:transparent;border:none;border-bottom:1px solid #f1f5f9;cursor:pointer;display:flex;gap:12px;padding:10px 14px;text-align:left;transition:all .15s;width:100%}.selector-student-item:last-child{border-bottom:none}.selector-student-item:hover{background:#f1f5f9}.selector-student-item-selected{background:linear-gradient(135deg,#e3f2fd,#bbdefb)!important}.selector-student-avatar{align-items:center;background:#e2e8f0;border-radius:10px;color:#64748b;display:flex;flex-shrink:0;font-size:.75rem;font-weight:700;height:36px;justify-content:center;text-transform:uppercase;width:36px}.selector-student-avatar-selected{background:linear-gradient(135deg,#1976d2,#0d47a1);color:#fff}.selector-student-info{flex:1 1;min-width:0}.selector-student-name{color:#1e293b;display:block;font-size:.85rem;font-weight:600}.selector-student-email{color:#94a3b8;display:block;font-size:.75rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.selector-student-check{color:#1976d2;flex-shrink:0}.student-selector-footer{padding:16px 24px 24px}.selector-continue-btn{align-items:center;background:linear-gradient(135deg,#1976d2,#0d47a1);border:none;border-radius:14px;box-shadow:0 4px 15px rgba(25,118,210,.4);color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:8px;justify-content:center;padding:14px;transition:all .2s;width:100%}.selector-continue-btn:hover:not(:disabled){box-shadow:0 6px 20px rgba(25,118,210,.5);transform:translateY(-1px)}.selector-continue-btn:disabled{box-shadow:none;cursor:not-allowed;opacity:.4;transform:none}.active-student-bar{align-items:center;background:linear-gradient(135deg,#e3f2fd,#bbdefb);border-bottom:1px solid #90caf9;display:flex;justify-content:space-between;min-height:48px;padding:8px 16px}.active-student-bar-left{align-items:center;display:flex;gap:10px}.active-student-bar-avatar{align-items:center;background:linear-gradient(135deg,#1976d2,#0d47a1);border-radius:8px;color:#fff;display:flex;font-size:.7rem;font-weight:700;height:32px;justify-content:center;text-transform:uppercase;width:32px}.active-student-bar-info{display:flex;flex-direction:column}.active-student-bar-name{color:#1e293b;font-size:.85rem;font-weight:600;line-height:1.2}.active-student-bar-detail{color:#64748b;font-size:.7rem;line-height:1.2}.active-student-bar-switch{align-items:center;background:#fff;border:1px solid #90caf9;border-radius:8px;color:#1565c0;cursor:pointer;display:flex;font-size:.8rem;font-weight:500;gap:6px;padding:6px 14px;transition:all .2s}.active-student-bar-switch:hover{background:#1565c0;border-color:#1565c0;color:#fff}.techservices-welcome{padding:24px}.welcome-header{margin-bottom:24px}.welcome-header h1{color:#1e293b;font-size:1.75rem;font-weight:600;margin-bottom:8px}.welcome-header p{color:#64748b;font-size:.95rem}.techservices-welcome .stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:32px}.stat-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:12px;cursor:pointer;display:flex;gap:16px;padding:20px;transition:all .2s}.stat-card:hover{border-color:#1565c0;box-shadow:0 4px 12px rgba(21,101,192,.15);transform:translateY(-2px)}.stat-icon{font-size:2rem}.stat-info{display:flex;flex-direction:column}.stat-value{color:#1e293b;font-size:1.75rem;font-weight:700}.stat-label{color:#64748b;font-size:.85rem}.quick-actions h2{color:#1e293b;font-size:1.25rem;font-weight:600;margin-bottom:16px}.actions-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.action-card{align-items:flex-start;background:linear-gradient(135deg,#1565c0,#1976d2);border:none;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:8px;padding:20px;text-align:left;transition:all .2s}.action-card:hover{box-shadow:0 8px 24px rgba(21,101,192,.3);transform:translateY(-2px)}.action-icon{font-size:1.5rem}.action-title{color:#fff;font-size:1rem;font-weight:600}.action-desc{color:hsla(0,0%,100%,.8);font-size:.85rem}.techservices-section{padding:24px}.section-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:24px}.section-header h2{color:#1e293b;font-size:1.5rem;font-weight:600;margin-bottom:4px}.section-subtitle{color:#64748b;font-size:.9rem}.section-loading{align-items:center;color:#64748b;display:flex;flex-direction:column;justify-content:center;padding:48px}.spinner{animation:spin 1s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#1565c0;height:40px;margin-bottom:16px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.assignments-list h3,.forms-list h3,.submissions-list h3,.tests-list h3{color:#1e293b;font-size:1.1rem;font-weight:600;margin-bottom:16px}.assignment-cards,.submissions-cards,.tests-cards{display:flex;flex-direction:column;gap:12px}.assignment-card,.submission-card,.test-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:10px;display:flex;gap:16px;padding:16px}.assignment-avatar{align-items:center;background:linear-gradient(135deg,#1565c0,#42a5f5);border-radius:50%;color:#fff;display:flex;font-size:1rem;font-weight:600;height:48px;justify-content:center;width:48px}.assignment-info,.submission-info,.test-info{display:flex;flex:1 1;flex-direction:column;gap:4px}.submission-name,.test-name,.tutor-name{color:#1e293b;font-weight:600}.submission-date,.test-description,.tutor-email{color:#64748b;font-size:.85rem}.assignment-date,.test-date{color:#94a3b8;font-size:.8rem}.assignment-actions,.submission-actions,.test-actions{align-items:center;display:flex;gap:8px}.submission-icon,.test-icon{font-size:1.5rem}.status-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:.75rem;font-weight:600;padding:4px 10px;text-transform:uppercase}.status-badge.active,.status-badge.approved,.status-badge.completed,.status-badge.success{background:#dcfce7;color:#166534}.status-badge.inprogress,.status-badge.pending,.status-badge.submitted,.status-badge.warning{background:#fef3c7;color:#92400e}.status-badge.cancelled,.status-badge.danger,.status-badge.needsrevision{background:#fee2e2;color:#991b1b}.status-badge.default,.status-badge.draft{background:#f1f5f9;color:#475569}.btn-primary{background:linear-gradient(135deg,#1565c0,#1976d2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:10px 20px;transition:all .2s}.btn-primary:hover{box-shadow:0 4px 12px rgba(21,101,192,.3)}.btn-primary:disabled{cursor:not-allowed;opacity:.5}.btn-secondary{background:#fff;border:1px solid #1565c0;border-radius:8px;color:#1565c0;cursor:pointer;font-weight:500;padding:10px 20px;transition:all .2s}.btn-secondary:hover{background:#e3f2fd}.btn-danger{background:#ef4444;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:10px 20px}.btn-danger:hover{background:#dc2626}.btn-warning{background:#f59e0b}.btn-success,.btn-warning{border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:10px 20px}.btn-success{background:#22c55e}.btn-sm{font-size:.85rem;padding:6px 12px}.btn-icon{align-items:center;border-radius:6px;display:flex;height:32px;justify-content:center;padding:0;width:32px}.btn-back{background:none;border:none;color:#1565c0;cursor:pointer;font-size:.9rem;margin-bottom:8px;padding:0}.btn-back:hover{text-decoration:underline}.alert{border-radius:8px;font-size:.9rem;margin-bottom:16px;padding:12px 16px}.alert-error{background:#fee2e2;border:1px solid #fecaca;color:#991b1b}.alert-success{background:#dcfce7;border:1px solid #bbf7d0;color:#166534}.alert-info{background:#e0f2fe;border:1px solid #7dd3fc;color:#0369a1}.modal{background:#fff;border-radius:12px;box-shadow:0 25px 50px rgba(0,0,0,.2);max-height:90vh;max-width:500px;overflow-y:auto;width:90%}.modal-lg{max-width:700px}.btn-close{background:none;border:none;color:#64748b;cursor:pointer;font-size:1.25rem}.btn-close:hover{color:#1e293b}.forms-table{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.forms-table table{border-collapse:collapse;width:100%}.forms-table td,.forms-table th{border-bottom:1px solid #e2e8f0;padding:12px 16px;text-align:left}.forms-table th{background:#f8fafc;color:#475569;font-size:.85rem;font-weight:600;text-transform:uppercase}.forms-table tr:hover{background:#f1f5f9}.forms-table td button,.progress-bar{margin-right:8px}.progress-bar{background:#e2e8f0;border-radius:3px;display:inline-block;height:6px;overflow:hidden;vertical-align:middle;width:80px}.progress-fill{background:linear-gradient(90deg,#22c55e,#16a34a);border-radius:3px;height:100%;transition:width .3s}.progress-text{color:#64748b;font-size:.85rem}.steps-timeline{display:flex;flex-direction:column;gap:0}.step-item{display:flex;gap:16px;padding-bottom:24px;position:relative}.step-item:not(:last-child):before{background:#e2e8f0;bottom:0;content:"";left:15px;position:absolute;top:36px;width:2px}.step-item.completed:before{background:#22c55e}.step-indicator{align-items:center;background:#e2e8f0;border-radius:50%;color:#64748b;display:flex;flex-shrink:0;font-size:.85rem;font-weight:600;height:32px;justify-content:center;width:32px}.step-item.completed .step-indicator{background:#22c55e;color:#fff}.step-item.inprogress .step-indicator{background:#f59e0b;color:#fff}.step-content{background:#fff;border:1px solid #e2e8f0;border-radius:10px;flex:1 1;padding:16px}.step-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.step-name{color:#1e293b;font-weight:600}.step-description{color:#64748b;font-size:.9rem;margin-bottom:8px}.step-meta{color:#94a3b8;display:flex;font-size:.8rem;gap:16px;margin-bottom:12px}.step-notes{background:#f8fafc;border-radius:6px;font-size:.85rem;margin-top:12px;padding:8px 12px}.tabs{border-bottom:2px solid #e2e8f0;display:flex;gap:0;margin-bottom:24px}.tab{background:none;border:none;color:#64748b;cursor:pointer;font-weight:500;padding:12px 24px;position:relative;transition:all .2s}.tab.active,.tab:hover{color:#1565c0}.tab.active:after{background:#1565c0;bottom:-2px;content:"";height:2px;left:0;position:absolute;right:0}.test-type-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr);margin-top:16px}.test-type-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;cursor:pointer;padding:16px;text-align:left;transition:all .2s}.test-type-card:hover{background:#e3f2fd;border-color:#1565c0}.test-type-name{color:#1e293b;display:block;font-weight:600;margin-bottom:4px}.test-type-desc{color:#64748b;display:block;font-size:.85rem}.review-details{flex-direction:column}.detail-row,.review-details{display:flex;gap:12px}.detail-row label{color:#475569;font-weight:600;min-width:100px}.detail-row.full-width{flex-direction:column}.answers-content{background:#f8fafc;border-radius:6px;font-size:.85rem;max-height:200px;overflow-x:auto;padding:12px}.form-group{margin-bottom:16px}.form-group label{color:#374151;display:block;font-size:.9rem;font-weight:500;margin-bottom:6px}.form-input,.form-select,.form-textarea{border:1px solid #d1d5db;border-radius:8px;font-size:.95rem;padding:10px 12px;transition:border-color .2s,box-shadow .2s;width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#1565c0;box-shadow:0 0 0 3px rgba(21,101,192,.1);outline:none}.form-textarea{resize:vertical}.attendance-status-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,1fr);margin-top:8px}.attendance-status-btn{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:10px;color:#64748b;cursor:pointer;display:flex;flex-direction:column;font-size:.85rem;font-weight:500;gap:6px;padding:14px 8px;transition:all .2s ease}.attendance-status-btn:hover{background:#f8fafc;border-color:#94a3b8}.attendance-status-btn.active{border-width:2px;font-weight:600}.attendance-status-btn.active.status-present{background:#f0fdf4;border-color:#22c55e;color:#16a34a}.attendance-status-btn.active.status-absent{background:#fef2f2;border-color:#ef4444;color:#dc2626}.attendance-status-btn.active.status-late{background:#fffbeb;border-color:#f59e0b;color:#d97706}.attendance-status-btn.active.status-excused{background:#eff6ff;border-color:#3b82f6;color:#2563eb}.attendance-status-btn .status-icon{font-size:1.5rem}.contact-method-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,1fr);margin-top:8px}.contact-method-btn{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:10px;color:#64748b;cursor:pointer;display:flex;flex-direction:column;font-size:.85rem;font-weight:500;gap:6px;padding:16px 10px;transition:all .2s ease}.contact-method-btn:hover{background:#f8fafc;border-color:#94a3b8}.contact-method-btn.active{background:#e3f2fd;border-color:#1565c0;color:#1565c0;font-weight:600}.contact-method-btn .method-icon{font-size:1.5rem}.missed-session-card{align-items:center;background:#fff;border:1px solid #fecaca;border-left:4px solid #ef4444;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:10px;padding:14px 16px}.missed-session-card .session-info h4{color:#1e293b;font-size:.95rem;margin:0 0 4px}.missed-session-card .session-info p{color:#64748b;font-size:.8rem;margin:0}.missed-session-card .session-actions{display:flex;gap:8px}.missed-session-card .session-actions button{background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;font-size:.8rem;padding:6px 12px;transition:all .2s}.missed-session-card .session-actions button:hover{background:#f1f5f9;border-color:#1565c0;color:#1565c0}.comm-log-entry{background:#fff;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:8px;padding:12px 16px}.comm-log-entry .comm-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.comm-log-entry .comm-header .comm-type{color:#1e293b;font-size:.85rem;font-weight:600}.comm-log-entry .comm-header .comm-date{color:#94a3b8;font-size:.8rem}.comm-log-entry .comm-body{color:#475569;font-size:.85rem;line-height:1.5}.report-detail{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:24px;padding:20px}.report-detail h4{color:#1e293b;font-size:1rem;margin:0 0 12px}.report-detail .report-stats{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.report-detail .report-stat{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:10px;text-align:center}.report-detail .report-stat .stat-value{color:#1565c0;display:block;font-size:1.4rem;font-weight:700}.report-detail .report-stat .stat-label{color:#64748b;font-size:.75rem;margin-top:2px}.quick-date-setters{display:flex;gap:8px;margin-bottom:12px}.quick-date-setters button{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#475569;cursor:pointer;font-size:.8rem;padding:6px 14px;transition:all .2s}.quick-date-setters button:hover{background:#e3f2fd;border-color:#1565c0;color:#1565c0}.attendance-progress{background:#e2e8f0;border-radius:4px;height:8px;overflow:hidden;width:100%}.attendance-progress .progress-fill{border-radius:4px;height:100%;transition:width .3s ease}.attendance-progress .progress-fill.rate-high{background:#22c55e}.attendance-progress .progress-fill.rate-medium{background:#f59e0b}.attendance-progress .progress-fill.rate-low{background:#ef4444}.admin-role-banner{align-items:center;background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #f59e0b;border-radius:12px;display:flex;gap:14px;margin-bottom:24px;padding:16px 20px}.admin-role-icon{flex-shrink:0;font-size:1.5rem}.admin-role-banner strong{color:#92400e;display:block;font-size:.95rem}.admin-role-banner p{color:#a16207;font-size:.85rem;margin:2px 0 0}.admin-department-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.admin-department-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;border-top:4px solid #94a3b8;padding:20px;transition:box-shadow .2s ease,transform .15s ease}.admin-department-card:hover{box-shadow:0 4px 16px rgba(0,0,0,.08);transform:translateY(-2px)}.admin-dept-header{align-items:center;display:flex;gap:10px;margin-bottom:8px}.admin-dept-icon{font-size:1.4rem}.admin-dept-header h3{color:#1e293b;font-size:1.05rem;font-weight:700;margin:0}.admin-dept-description{color:#64748b;font-size:.82rem;line-height:1.4;margin:0 0 14px}.admin-dept-links{display:flex;flex-direction:column;gap:4px}.admin-dept-link{align-items:center;background:#f8fafc;border:1px solid transparent;border-radius:8px;color:#334155;cursor:pointer;display:flex;font-size:.85rem;justify-content:space-between;padding:8px 12px;text-align:left;transition:all .15s ease}.admin-dept-link:hover{background:#e0f2fe;border-color:#bae6fd;color:#0369a1}.admin-dept-link-arrow{color:#94a3b8;font-size:.9rem;transition:transform .15s ease}.admin-dept-link:hover .admin-dept-link-arrow{color:#0369a1;transform:translateX(3px)}.prospect-pipeline{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(5,1fr)}.pipeline-stage{background:#fff;border:1px solid #e2e8f0;border-radius:8px;border-top:4px solid #94a3b8;padding:16px 8px;text-align:center}.pipeline-count{display:block;font-size:1.6rem;font-weight:700}.pipeline-label{color:#64748b;display:block;font-size:.8rem;margin-top:4px}.role-toggle-group{display:flex;gap:10px;margin-top:4px}.role-toggle-btn{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:10px;color:#64748b;cursor:pointer;display:flex;flex:1 1;font-size:.95rem;font-weight:500;gap:8px;justify-content:center;padding:14px;transition:all .2s ease}.role-toggle-btn:hover{background:#f8fafc;border-color:#94a3b8}.role-toggle-btn.active.student{background:#e3f2fd;border-color:#1565c0;color:#1565c0;font-weight:600}.role-toggle-btn.active.parent{background:#ede9fe;border-color:#7c3aed;color:#7c3aed;font-weight:600}.user-form-section{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;margin-top:16px;padding:20px}.user-form-section.parent-section{background:#faf5ff;border-color:#e9d5ff}.user-form-section-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;gap:10px;margin-bottom:16px;padding-bottom:12px}.parent-section .user-form-section-header{border-bottom-color:#e9d5ff}.user-form-section-icon{font-size:1.25rem}.user-form-section-header h3{color:#1e293b;font-size:1rem;font-weight:600;margin:0}.section-hint{color:#94a3b8;font-size:.8rem;margin-left:auto}.parent-option-tabs{display:flex;gap:8px;margin-bottom:12px}.parent-option-tab{background:#fff;border:2px solid #e2e8f0;border-radius:8px;color:#64748b;cursor:pointer;flex:1 1;font-size:.85rem;font-weight:500;padding:10px 12px;text-align:center;transition:all .2s ease}.parent-option-tab:hover{background:#faf5ff;border-color:#c4b5fd}.parent-option-tab.active{background:#ede9fe;border-color:#7c3aed;color:#7c3aed;font-weight:600}.parent-search-input-wrapper,.parent-search-section{position:relative}.parent-search-input-wrapper .form-input{padding-right:60px}.parent-clear-btn{align-items:center;background:#e2e8f0;border:none;border-radius:50%;color:#475569;cursor:pointer;display:flex;font-size:.75rem;height:22px;justify-content:center;position:absolute;right:36px;top:50%;transform:translateY(-50%);width:22px}.parent-clear-btn:hover{background:#cbd5e1}.parent-search-spinner{font-size:.9rem;position:absolute;right:10px;top:50%;transform:translateY(-50%)}.parent-search-dropdown{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.12);left:0;margin-top:4px;max-height:240px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:50}.parent-search-result{border-bottom:1px solid #f1f5f9;cursor:pointer;padding:10px 14px;transition:background .15s ease}.parent-search-result:last-child{border-bottom:none}.parent-search-result:hover{background:#f0e6ff}.parent-search-result-name{color:#1e293b;font-size:.9rem;font-weight:600}.parent-search-result-detail{color:#64748b;font-size:.8rem;margin-top:2px}.parent-search-no-results{color:#94a3b8;font-size:.85rem;padding:14px;text-align:center}.selected-parent-card{align-items:center;background:#ede9fe;border:1px solid #c4b5fd;border-radius:10px;display:flex;gap:12px;margin-top:12px;padding:14px 16px}.selected-parent-avatar{align-items:center;background:#fff;border-radius:50%;display:flex;font-size:1.5rem;height:40px;justify-content:center;width:40px}.selected-parent-info{display:flex;flex:1 1;flex-direction:column;gap:2px}.selected-parent-info strong{color:#1e293b;font-size:.95rem}.selected-parent-info span{color:#64748b;font-size:.8rem}.new-parent-form{border-top:1px dashed #d8b4fe;margin-top:12px;padding-top:12px}.no-parent-notice{align-items:flex-start;background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;display:flex;gap:10px;margin-top:8px;padding:14px 16px}.no-parent-icon{flex-shrink:0;font-size:1.1rem;margin-top:1px}.no-parent-notice p{color:#475569;font-size:.85rem;line-height:1.5;margin:0}.routing-template-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.routing-template-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px;transition:box-shadow .2s}.routing-template-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.08)}.template-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:8px}.template-card-header h3{color:#1e293b;font-size:1rem;margin:0}.template-step-count{background:#e3f2fd;border-radius:12px;color:#1565c0;font-size:.75rem;padding:2px 8px;white-space:nowrap}.template-description{color:#64748b;font-size:.85rem;line-height:1.4;margin:0 0 12px}.template-steps-preview{border-top:1px solid #f1f5f9;padding-top:10px}.template-step-item{align-items:center;color:#475569;display:flex;font-size:.8rem;gap:8px;padding:6px 0}.template-step-item .step-number{align-items:center;background:#e3f2fd;border-radius:50%;color:#1565c0;display:inline-flex;flex-shrink:0;font-size:.7rem;font-weight:600;height:20px;justify-content:center;width:20px}.template-step-item .step-name{flex:1 1}.template-step-item .step-role{background:#f1f5f9;border-radius:4px;color:#64748b;font-size:.7rem;padding:1px 6px}.template-step-item.more{color:#94a3b8;font-style:italic;padding-left:28px}.search-results-dropdown{background:#fff;border:1px solid #e2e8f0;border-radius:0 0 8px 8px;border-top:none;box-shadow:0 4px 12px rgba(0,0,0,.1);max-height:200px;overflow-y:auto;position:absolute;width:100%;z-index:10}.search-result-item{border-bottom:1px solid #f1f5f9;cursor:pointer;font-size:.9rem;padding:10px 12px}.search-result-item:hover{background:#f1f5f9}.search-result-item:last-child{border-bottom:none}.form-group{position:relative}.parent-results{display:flex;flex-direction:column;gap:12px}.parent-result-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;transition:box-shadow .2s}.parent-result-card:hover{box-shadow:0 2px 8px rgba(0,0,0,.06)}.parent-result-main{align-items:center;cursor:pointer;display:flex;gap:14px;padding:16px}.parent-avatar{align-items:center;background:linear-gradient(135deg,#1565c0,#1e88e5);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.9rem;font-weight:600;height:44px;justify-content:center;width:44px}.parent-info{flex:1 1}.parent-info h4{color:#1e293b;font-size:1rem;margin:0}.parent-contact{color:#64748b;display:flex;font-size:.8rem;gap:16px;margin-top:4px}.parent-status{align-items:center;display:flex;gap:8px}.expand-icon{color:#94a3b8;font-size:.7rem}.parent-result-detail{border-top:1px solid #f1f5f9;padding:12px 16px 16px}.children-list{display:flex;flex-direction:column;gap:8px}.child-card{align-items:center;background:#f8fafc;border-radius:8px;display:flex;gap:10px;padding:10px}.child-avatar{font-size:1.2rem}.activity-timeline{display:flex;flex-direction:column;gap:12px}.activity-item{border-bottom:1px solid #f1f5f9;display:flex;gap:10px;padding:10px 0}.activity-item:last-child{border-bottom:none}.activity-icon{flex-shrink:0;font-size:1.2rem;margin-top:2px}.activity-content{flex:1 1}.activity-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.activity-header strong{color:#1e293b;font-size:.85rem}.activity-date{color:#94a3b8;font-size:.75rem}.activity-notes{color:#475569;font-size:.85rem;line-height:1.4;margin:0}.activity-by{color:#94a3b8;display:block;font-size:.75rem;margin-top:4px}.validity-student-selector{margin-bottom:20px}.validity-label{color:#475569;display:block;font-size:.85rem;font-weight:600;margin-bottom:6px}.validity-selector-wrapper{position:relative}.validity-selected-student{align-items:center;background:#f0f9ff;border:2px solid #1565c0;border-radius:10px;display:flex;gap:12px;padding:10px 14px}.validity-student-avatar,.validity-student-avatar-sm{align-items:center;background:linear-gradient(135deg,#1565c0,#1976d2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.8rem;font-weight:600;height:38px;justify-content:center;text-transform:uppercase;width:38px}.validity-student-avatar-sm{font-size:.7rem;height:30px;width:30px}.validity-student-info{display:flex;flex:1 1;flex-direction:column}.validity-student-name{color:#1e293b;font-size:.95rem;font-weight:600}.validity-student-email{color:#64748b;font-size:.8rem}.validity-clear-btn{background:none;border:none;border-radius:6px;color:#94a3b8;cursor:pointer;font-size:1.4rem;padding:4px 8px}.validity-clear-btn:hover{background:#fee2e2;color:#991b1b}.validity-search-input-wrapper{position:relative}.validity-search-input{border:1px solid #e2e8f0;border-radius:10px;box-sizing:border-box;font-size:.9rem;outline:none;padding:10px 14px 10px 36px;width:100%}.validity-search-input:focus{border-color:#1565c0;box-shadow:0 0 0 3px rgba(21,101,192,.1)}.validity-search-icon{color:#94a3b8;font-size:.9rem;left:12px;position:absolute;top:50%;transform:translateY(-50%)}.validity-dropdown{background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.12);left:0;margin-top:4px;max-height:280px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:50}.validity-dropdown-item{align-items:center;cursor:pointer;display:flex;gap:10px;padding:10px 14px;transition:background .15s}.validity-dropdown-item:hover{background:#f0f9ff}.validity-dropdown-name{color:#1e293b;font-size:.9rem;font-weight:500}.validity-dropdown-email{color:#94a3b8;font-size:.78rem}.validity-dropdown-empty,.validity-dropdown-error{color:#94a3b8;font-size:.85rem;padding:16px;text-align:center}.validity-dropdown-error{background:#fee2e2;color:#991b1b}.validity-tabs{border-bottom:2px solid #e2e8f0;display:flex;gap:8px;margin-bottom:20px;padding-bottom:0}.validity-tab{align-items:center;background:none;border:none;border-bottom:3px solid transparent;color:#64748b;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:6px;margin-bottom:-2px;padding:10px 20px;transition:color .15s,border-color .15s}.validity-tab:hover{color:#1565c0}.validity-tab.active{border-bottom-color:#1565c0;color:#1565c0;font-weight:600}.validity-tab-icon{font-size:1rem}.validity-content{min-height:300px}.validity-empty-state{background:#fff;border:1px solid #e2e8f0;border-radius:12px;color:#94a3b8;padding:48px 20px;text-align:center}.validity-empty-icon{font-size:2.5rem;margin-bottom:12px}.validity-empty-state h3{color:#475569;font-size:1.1rem;margin-bottom:8px}.validity-empty-state p{font-size:.85rem}.validity-loading{color:#64748b;padding:40px 20px;text-align:center}.validity-loading .spinner{margin:0 auto 12px}.validity-panel-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.validity-panel-header h3{color:#1e293b;font-size:1.1rem;font-weight:600;margin:0}.validity-create-form{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:16px;padding:20px}.validity-create-form h4{color:#1e293b;font-size:1rem;margin:0 0 14px}.validity-form-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.validity-form-grid-2{grid-gap:12px;display:grid;gap:12px;grid-template-columns:2fr 1fr}.validity-form-group{margin-bottom:10px}.validity-form-group label{color:#475569;display:block;font-size:.8rem;font-weight:600;margin-bottom:4px}.validity-form-group input,.validity-form-group select,.validity-form-group textarea{border:1px solid #e2e8f0;border-radius:8px;box-sizing:border-box;font-family:inherit;font-size:.88rem;outline:none;padding:8px 12px;width:100%}.validity-form-group input:focus,.validity-form-group select:focus,.validity-form-group textarea:focus{border-color:#1565c0;box-shadow:0 0 0 3px rgba(21,101,192,.1)}.validity-form-group input:disabled,.validity-form-group select:disabled,.validity-form-group textarea:disabled{background:#f8fafc;color:#64748b;cursor:default}.validity-form-group textarea{resize:vertical}.validity-form-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:12px}.validity-grade-test-info{background:#f8fafc;border-radius:8px;margin-bottom:16px;padding:12px 16px}.validity-grade-row{display:flex;gap:8px;padding:4px 0}.validity-grade-label{color:#475569;font-size:.85rem;font-weight:600;min-width:90px}.validity-grade-value{color:#1e293b;font-size:.85rem}.validity-pass-indicator{border-radius:8px;font-size:.85rem;font-weight:600;margin-bottom:12px;padding:8px 12px;text-align:center}.validity-pass-indicator.pass{background:#dcfce7;color:#166534}.validity-pass-indicator.fail{background:#fee2e2;color:#991b1b}.validity-program-count{color:#64748b;font-size:.85rem;font-weight:400}.validity-program-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;margin-bottom:12px;padding:14px 16px}.validity-program-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.validity-program-card-header strong{color:#1e293b;font-size:.95rem}.validity-program-desc{color:#64748b;font-size:.83rem;margin:0 0 8px}.validity-program-meta{color:#94a3b8;display:flex;font-size:.78rem;gap:16px}.validity-grade-section-title{border-bottom:1px solid #e2e8f0;color:#1e293b;font-size:.95rem;font-weight:600;margin:20px 0 10px;padding-bottom:6px}.validity-grade-block{background:#fff;border:1px solid #e2e8f0;border-radius:10px;margin-bottom:10px;overflow:hidden}.validity-grade-block-header{align-items:center;background:#f8fafc;border-bottom:1px solid #e2e8f0;display:flex;gap:12px;padding:10px 14px}.validity-grade-badge{align-items:center;background:#e3f2fd;border-radius:20px;color:#1565c0;display:inline-flex;font-size:.78rem;font-weight:600;padding:4px 12px}.validity-grade-empty{font-size:.82rem}.validity-grade-items{padding:8px 14px}.validity-grade-item{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;padding:6px 0}.validity-grade-item:last-child{border-bottom:none}.validity-item-name{color:#1e293b;font-size:.88rem;font-weight:500}.validity-item-subject{color:#94a3b8;font-size:.8rem}.validity-earlier-work{margin-top:12px}.validity-earlier-note{background:#fef3c7;border-radius:8px;color:#92400e;font-size:.82rem;margin-bottom:10px;padding:8px 12px}.validity-test-summary{margin-top:16px}.validity-transcript-layout{grid-gap:20px;align-items:start;display:grid;gap:20px;grid-template-columns:1fr 1fr}@media (max-width:1100px){.validity-transcript-layout{grid-template-columns:1fr}}.validity-transcript-left,.validity-transcript-right{min-width:0}.validity-transcript-header-fields{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;margin-bottom:16px;padding:16px}.validity-transcript-year-block{background:#fff;border:1px solid #e2e8f0;border-radius:10px;margin-bottom:12px;overflow:hidden}.validity-transcript-year-header{align-items:center;background:#f8fafc;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:10px 14px}.validity-transcript-year-body{padding:14px}.validity-transcript-readonly{background:#f8fafc;border:1px solid #f1f5f9;border-radius:8px;color:#475569;font-size:.88rem;min-height:20px;padding:8px 12px;white-space:pre-wrap}.validity-li-table-wrap{width:100%}.validity-li-table{border-collapse:collapse;font-size:.88rem;width:100%}.validity-li-table thead th{background:#f1f5f9;border-bottom:2px solid #e2e8f0;color:#475569;font-size:.82rem;font-weight:600;padding:8px 12px;text-align:left;white-space:nowrap}.validity-li-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background .15s}.validity-li-table tbody tr:hover{background:#f8fafc}.validity-li-table td{color:#334155;padding:6px 12px;vertical-align:middle}.validity-li-subject{background:#faf5ff;border-right:2px solid #ede9fe;color:#6d28d9;font-weight:600;white-space:nowrap}.validity-li-course{font-weight:500}.validity-li-credits,.validity-li-grade{text-align:center;white-space:nowrap}.validity-li-notes{color:#64748b;font-size:.84rem}.validity-li-input{border:1px solid #e2e8f0;border-radius:6px;box-sizing:border-box;font-size:.85rem;padding:5px 8px;transition:border-color .2s;width:100%}.validity-li-input:focus{border-color:#6d28d9;box-shadow:0 0 0 2px rgba(109,40,217,.12);outline:none}.validity-li-input-sm{max-width:90px}.validity-li-actions-cell{align-items:center;display:flex;gap:4px}.validity-li-remove{background:none;border:none;border-radius:4px;color:#ef4444;cursor:pointer;flex-shrink:0;font-size:1.2rem;line-height:1;padding:2px 6px}.validity-li-remove:hover{background:#fef2f2}.validity-li-add-btn{align-items:center;background:#faf5ff;border:1px dashed #c4b5fd;border-radius:6px;color:#6d28d9;cursor:pointer;display:inline-flex;font-size:.84rem;font-weight:500;margin:8px 12px 10px;padding:5px 14px;transition:background .15s,border-color .15s}.validity-li-add-btn:hover{background:#ede9fe;border-color:#8b5cf6}.validity-li-count{color:#94a3b8;font-size:.82rem;margin-left:8px}.validity-grade-empty{color:#94a3b8;font-size:.86rem;font-style:italic}.placeholder\:text-slate-400::placeholder{--tw-text-opacity:1;color:#94a3b8;color:rgb(148 163 184/var(--tw-text-opacity,1))}.last\:border-0:last-child{border-width:0}.hover\:-translate-y-0\.5:hover{--tw-translate-y:-0.125rem}.hover\:-translate-y-0\.5:hover,.hover\:scale-\[1\.02\]:hover{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:scale-\[1\.02\]:hover{--tw-scale-x:1.02;--tw-scale-y:1.02}.hover\:border-amber-300:hover{--tw-border-opacity:1;border-color:#fcd34d;border-color:rgb(252 211 77/var(--tw-border-opacity,1))}.hover\:border-blue-300:hover{--tw-border-opacity:1;border-color:#93c5fd;border-color:rgb(147 197 253/var(--tw-border-opacity,1))}.hover\:border-emerald-300:hover{--tw-border-opacity:1;border-color:#6ee7b7;border-color:rgb(110 231 183/var(--tw-border-opacity,1))}.hover\:border-rose-300:hover{--tw-border-opacity:1;border-color:#fda4af;border-color:rgb(253 164 175/var(--tw-border-opacity,1))}.hover\:border-slate-300:hover{--tw-border-opacity:1;border-color:#cbd5e1;border-color:rgb(203 213 225/var(--tw-border-opacity,1))}.hover\:border-violet-300:hover{--tw-border-opacity:1;border-color:#c4b5fd;border-color:rgb(196 181 253/var(--tw-border-opacity,1))}.hover\:bg-amber-100:hover{--tw-bg-opacity:1;background-color:#fef3c7;background-color:rgb(254 243 199/var(--tw-bg-opacity,1))}.hover\:bg-blue-100:hover{--tw-bg-opacity:1;background-color:#dbeafe;background-color:rgb(219 234 254/var(--tw-bg-opacity,1))}.hover\:bg-blue-50\/50:hover{background-color:rgba(239,246,255,.5)}.hover\:bg-blue-700:hover{--tw-bg-opacity:1;background-color:#1d4ed8;background-color:rgb(29 78 216/var(--tw-bg-opacity,1))}.hover\:bg-gray-100:hover{--tw-bg-opacity:1;background-color:#f3f4f6;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}.hover\:bg-gray-200:hover{--tw-bg-opacity:1;background-color:#e5e7eb;background-color:rgb(229 231 235/var(--tw-bg-opacity,1))}.hover\:bg-gray-50:hover{--tw-bg-opacity:1;background-color:#f9fafb;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.hover\:bg-green-50:hover{--tw-bg-opacity:1;background-color:#f0fdf4;background-color:rgb(240 253 244/var(--tw-bg-opacity,1))}.hover\:bg-red-100:hover{--tw-bg-opacity:1;background-color:#fee2e2;background-color:rgb(254 226 226/var(--tw-bg-opacity,1))}.hover\:bg-red-50:hover{--tw-bg-opacity:1;background-color:#fef2f2;background-color:rgb(254 242 242/var(--tw-bg-opacity,1))}.hover\:bg-slate-100:hover{--tw-bg-opacity:1;background-color:#f1f5f9;background-color:rgb(241 245 249/var(--tw-bg-opacity,1))}.hover\:bg-slate-200:hover{--tw-bg-opacity:1;background-color:#e2e8f0;background-color:rgb(226 232 240/var(--tw-bg-opacity,1))}.hover\:bg-slate-50:hover{--tw-bg-opacity:1;background-color:#f8fafc;background-color:rgb(248 250 252/var(--tw-bg-opacity,1))}.hover\:bg-slate-50\/50:hover{background-color:rgba(248,250,252,.5)}.hover\:bg-white\/10:hover{background-color:hsla(0,0%,100%,.1)}.hover\:bg-white\/20:hover{background-color:hsla(0,0%,100%,.2)}.hover\:bg-white\/25:hover{background-color:hsla(0,0%,100%,.25)}.hover\:bg-white\/60:hover{background-color:hsla(0,0%,100%,.6)}.hover\:from-\[\#0d47a1\]:hover{--tw-gradient-from:#0d47a1 var(--tw-gradient-from-position);--tw-gradient-to:rgba(13,71,161,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.hover\:from-primary-700:hover{--tw-gradient-from:#1d4ed8 var(--tw-gradient-from-position);--tw-gradient-to:rgba(29,78,216,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.hover\:to-blue-600:hover{--tw-gradient-to:#2563eb var(--tw-gradient-to-position)}.hover\:to-primary-800:hover{--tw-gradient-to:#1e40af var(--tw-gradient-to-position)}.hover\:text-blue-600:hover{--tw-text-opacity:1;color:#2563eb;color:rgb(37 99 235/var(--tw-text-opacity,1))}.hover\:text-blue-700:hover{--tw-text-opacity:1;color:#1d4ed8;color:rgb(29 78 216/var(--tw-text-opacity,1))}.hover\:text-blue-800:hover{--tw-text-opacity:1;color:#1e40af;color:rgb(30 64 175/var(--tw-text-opacity,1))}.hover\:text-gray-600:hover{--tw-text-opacity:1;color:#4b5563;color:rgb(75 85 99/var(--tw-text-opacity,1))}.hover\:text-primary-700:hover{--tw-text-opacity:1;color:#1d4ed8;color:rgb(29 78 216/var(--tw-text-opacity,1))}.hover\:text-red-500:hover{--tw-text-opacity:1;color:#ef4444;color:rgb(239 68 68/var(--tw-text-opacity,1))}.hover\:text-red-600:hover{--tw-text-opacity:1;color:#dc2626;color:rgb(220 38 38/var(--tw-text-opacity,1))}.hover\:text-slate-600:hover{--tw-text-opacity:1;color:#475569;color:rgb(71 85 105/var(--tw-text-opacity,1))}.hover\:text-slate-700:hover{--tw-text-opacity:1;color:#334155;color:rgb(51 65 85/var(--tw-text-opacity,1))}.hover\:text-white:hover{--tw-text-opacity:1;color:#fff;color:rgb(255 255 255/var(--tw-text-opacity,1))}.hover\:shadow-lg:hover{--tw-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.hover\:shadow-lg:hover,.hover\:shadow-md:hover{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.hover\:shadow-md:hover{--tw-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color)}.hover\:shadow-blue-500\/40:hover{--tw-shadow-color:rgba(59,130,246,.4);--tw-shadow:var(--tw-shadow-colored)}.hover\:shadow-emerald-500\/40:hover{--tw-shadow-color:rgba(16,185,129,.4);--tw-shadow:var(--tw-shadow-colored)}.hover\:shadow-slate-200\/50:hover{--tw-shadow-color:rgba(226,232,240,.5);--tw-shadow:var(--tw-shadow-colored)}.focus\:border-\[\#1565c0\]:focus{--tw-border-opacity:1;border-color:#1565c0;border-color:rgb(21 101 192/var(--tw-border-opacity,1))}.focus\:border-blue-500:focus{--tw-border-opacity:1;border-color:#3b82f6;border-color:rgb(59 130 246/var(--tw-border-opacity,1))}.focus\:border-transparent:focus{border-color:transparent}.focus\:bg-white:focus{--tw-bg-opacity:1;background-color:#fff;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus\:ring-\[\#1565c0\]\/20:focus{--tw-ring-color:rgba(21,101,192,.2)}.focus\:ring-\[\#1565c0\]\/40:focus{--tw-ring-color:rgba(21,101,192,.4)}.focus\:ring-blue-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(59 130 246/var(--tw-ring-opacity,1))}.focus\:ring-blue-500\/20:focus{--tw-ring-color:rgba(59,130,246,.2)}.focus\:ring-blue-500\/30:focus{--tw-ring-color:rgba(59,130,246,.3)}.focus\:ring-blue-500\/50:focus{--tw-ring-color:rgba(59,130,246,.5)}.focus\:ring-primary-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(59 130 246/var(--tw-ring-opacity,1))}.focus\:ring-white\/30:focus{--tw-ring-color:hsla(0,0%,100%,.3)}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px}.disabled\:transform-none:disabled{transform:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:bg-gray-100:disabled{--tw-bg-opacity:1;background-color:#f3f4f6;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}.disabled\:opacity-30:disabled{opacity:.3}.disabled\:opacity-40:disabled{opacity:.4}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:opacity-70:disabled{opacity:.7}.disabled\:hover\:translate-y-0:hover:disabled{--tw-translate-y:0px}.disabled\:hover\:translate-y-0:hover:disabled,.group:hover .group-hover\:translate-x-0{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.group:hover .group-hover\:translate-x-0{--tw-translate-x:0px}.group:hover .group-hover\:scale-110{--tw-scale-x:1.1;--tw-scale-y:1.1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.group:hover .group-hover\:text-\[\#1565c0\]{--tw-text-opacity:1;color:#1565c0;color:rgb(21 101 192/var(--tw-text-opacity,1))}.group:hover .group-hover\:text-amber-600{--tw-text-opacity:1;color:#d97706;color:rgb(217 119 6/var(--tw-text-opacity,1))}.group:hover .group-hover\:text-blue-600{--tw-text-opacity:1;color:#2563eb;color:rgb(37 99 235/var(--tw-text-opacity,1))}.group:hover .group-hover\:text-emerald-600{--tw-text-opacity:1;color:#059669;color:rgb(5 150 105/var(--tw-text-opacity,1))}.group:hover .group-hover\:text-gray-600{--tw-text-opacity:1;color:#4b5563;color:rgb(75 85 99/var(--tw-text-opacity,1))}.group:hover .group-hover\:text-rose-600{--tw-text-opacity:1;color:#e11d48;color:rgb(225 29 72/var(--tw-text-opacity,1))}.group:hover .group-hover\:text-slate-400{--tw-text-opacity:1;color:#94a3b8;color:rgb(148 163 184/var(--tw-text-opacity,1))}.group:hover .group-hover\:text-violet-600{--tw-text-opacity:1;color:#7c3aed;color:rgb(124 58 237/var(--tw-text-opacity,1))}.group:hover .group-hover\:opacity-100{opacity:1}@media (min-width:640px){.sm\:block{display:block}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:items-center{align-items:center}.sm\:justify-between{justify-content:space-between}}@media (min-width:768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width:1024px){.lg\:mb-8{margin-bottom:2rem}.lg\:flex{display:flex}.lg\:hidden{display:none}.lg\:h-10{height:2.5rem}.lg\:h-12{height:3rem}.lg\:h-16{height:4rem}.lg\:h-4{height:1rem}.lg\:h-8{height:2rem}.lg\:w-1\/2{width:50%}.lg\:w-10{width:2.5rem}.lg\:w-12{width:3rem}.lg\:w-16{width:4rem}.lg\:w-4{width:1rem}.lg\:w-8{width:2rem}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:gap-3{gap:.75rem}.lg\:gap-4{gap:1rem}.lg\:gap-6{gap:1.5rem}.lg\:p-6{padding:1.5rem}.lg\:p-8{padding:2rem}.lg\:px-3{padding-left:.75rem;padding-right:.75rem}.lg\:px-4{padding-left:1rem;padding-right:1rem}.lg\:px-8{padding-left:2rem;padding-right:2rem}.lg\:py-10{padding-bottom:2.5rem;padding-top:2.5rem}.lg\:py-3{padding-bottom:.75rem;padding-top:.75rem}.lg\:text-2xl{font-size:1.5rem;line-height:2rem}.lg\:text-base{font-size:1rem;line-height:1.5rem}.lg\:text-sm{font-size:.875rem;line-height:1.25rem}}@media (min-width:1280px){.xl\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.xl\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.xl\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}}
/*# sourceMappingURL=main.5355ad41.css.map*/