@charset "UTF-8";@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Playfair+Display:wght@400;500;600;700&display=swap);*{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}div[contenteditable],input,p,span,textarea{-webkit-user-select:text;user-select:text}.btn,.card,.nav-item,.tab,a,button{-webkit-tap-highlight-color:rgba(26,35,126,.1);min-height:44px;min-width:44px;touch-action:manipulation}@media screen and (max-width:767px){input,select,textarea{-webkit-appearance:none;appearance:none;border-radius:8px;font-size:16px!important;transform:translateZ(0)}h1{font-size:1.75rem;line-height:1.2}h2{font-size:1.5rem;line-height:1.3}h3{font-size:1.25rem}h3,h4{line-height:1.4}h4{font-size:1.125rem}.container,.max-w-7xl{padding-left:1rem;padding-right:1rem}.card,.card-harmony{border-radius:12px;margin-bottom:1rem;padding:1rem}.nav-item{margin-bottom:4px;padding:12px 16px}.btn,.nav-item,button{border-radius:8px;font-size:16px}.btn,button{font-weight:600;padding:12px 24px}.table-container{-webkit-overflow-scrolling:touch;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow-x:auto}table{font-size:14px;min-width:600px}td,th{padding:12px 8px;white-space:nowrap}.modal{border-radius:12px;margin:1rem;max-width:calc(100vw - 2rem)}.form-group{margin-bottom:1.5rem}.form-control{border:2px solid #e2e8f0;border-radius:8px;font-size:16px;padding:12px 16px;transition:border-color .2s ease}.form-control:focus{border-color:var(--harmony-primary);box-shadow:0 0 0 3px #1a237e1a;outline:none}}@media screen and (min-width:768px) and (max-width:1023px){.container{padding-left:2rem;padding-right:2rem}.grid-cols-tablet{gap:1.5rem;grid-template-columns:repeat(2,1fr)}.sidebar{width:240px}h1{font-size:2rem}h2{font-size:1.75rem}h3{font-size:1.5rem}}@media screen and (max-width:767px){.calendar-container{padding:.5rem}.calendar-grid{gap:2px}.calendar-day{font-size:14px;min-height:40px;padding:4px}.calendar-event{border-radius:4px;font-size:10px;margin-bottom:2px;padding:2px 4px}.announcement-card{border-radius:8px;margin-bottom:1rem;padding:1rem}.announcement-title{font-size:1.125rem;margin-bottom:.5rem}.announcement-content{font-size:14px;line-height:1.5}.quiz-card,.task-card{border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:1rem;padding:1rem}.quiz-title,.task-title{font-size:1.125rem;font-weight:600;margin-bottom:.5rem}.quiz-meta,.task-meta{color:#64748b;font-size:14px;margin-bottom:.75rem}.quiz-status,.task-status{border-radius:12px;display:inline-block;font-size:12px;font-weight:500;letter-spacing:.5px;padding:4px 8px;text-transform:uppercase}.payment-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr;margin-bottom:2rem}.payment-stat-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:1rem;text-align:center}.payment-stat-value{font-size:1.5rem;font-weight:700;margin-bottom:.25rem}.payment-stat-label{color:#64748b;font-size:14px}.payment-actions{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem}.payment-action-btn{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;padding:12px 16px;transition:all .2s ease}.document-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr}.document-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:1rem}.document-title{font-size:1rem;font-weight:600;margin-bottom:.5rem}.document-meta{color:#64748b;font-size:14px;margin-bottom:.75rem}.document-actions{display:flex;flex-wrap:wrap;gap:.5rem}.document-action-btn{background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;font-size:12px;padding:6px 12px}}.scroll-container{-webkit-overflow-scrolling:touch;scrollbar-width:thin}@media screen and (max-width:767px){body{padding-bottom:env(safe-area-inset-bottom,0)}.layout-main-mobile{min-height:calc(100vh - 100px)}.layout-main-mobile,.mobile-sidebar{padding-bottom:100px}.fixed-footer-mobile{bottom:0;left:0;position:fixed!important;right:0;transform:translateZ(0);-webkit-transform:translateZ(0);z-index:1000}select{-webkit-appearance:none;appearance:none;background-color:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:16px;border:2px solid #e2e8f0;border-radius:8px;font-size:16px;padding:12px 16px}}.loading-mobile{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:2rem;text-align:center}.loading-spinner-mobile{animation:spin 1s linear infinite;border:3px solid #f3f4f6;border-radius:50%;border-top:3px solid var(--harmony-primary);height:40px;margin-bottom:1rem;width:40px}.error-mobile{background-color:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#991b1b}.error-mobile,.success-mobile{margin:1rem;padding:1rem;text-align:center}.success-mobile{background-color:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;color:#166534}@media screen and (max-width:767px){.mobile-footer{background:var(--harmony-gradient-primary);bottom:0;box-shadow:0 -2px 8px #0000001a;left:0;padding:12px 16px;position:fixed;right:0;z-index:40}.mobile-content-with-footer{padding-bottom:100px}.mobile-sidebar-bottom{margin-bottom:80px;padding-bottom:20px}.mobile-nav-bar{align-items:center;background:#fff;border-bottom:1px solid #e2e8f0;display:flex;height:60px;justify-content:space-between;left:0;padding:0 1rem;position:fixed;right:0;top:0;z-index:50}.mobile-nav-title{color:var(--harmony-primary);font-size:1.125rem;font-weight:600}.mobile-nav-menu-btn{align-items:center;background:#0000;border:none;border-radius:8px;color:var(--harmony-primary);cursor:pointer;display:flex;height:44px;justify-content:center;width:44px}.mobile-content-offset{padding-top:60px}}@supports (-webkit-touch-callout:none){.ios-fix{-webkit-appearance:none;appearance:none;border-radius:0}input[type=email],input[type=number],input[type=password],input[type=search],input[type=tel],input[type=text],input[type=url],select,textarea{font-size:16px!important}button,input[type=button],input[type=submit]{-webkit-appearance:none;appearance:none;border-radius:8px}}@media screen and (max-width:767px){.mobile-sidebar-container{height:100vh;overflow:hidden;position:relative;z-index:1100}.mobile-sidebar-content{-webkit-overflow-scrolling:touch;bottom:80px;left:0;overflow-y:auto;position:absolute;right:0;top:0}.mobile-sidebar-user{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);bottom:0;left:0;position:absolute;right:0;z-index:1110}.mobile-nav-padding{padding-bottom:24px}.mobile-sidebar-overlay{z-index:1050}}@media screen and (-webkit-min-device-pixel-ratio:0){.android-fix{-webkit-text-size-adjust:none}}@media screen and (-webkit-min-device-pixel-ratio:2),screen and (min-resolution:2dppx){.high-dpi-image{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}}@media screen and (max-width:767px) and (orientation:landscape){.landscape-hide{display:none}.sidebar-mobile{width:280px}.main-content-landscape{padding:.5rem}}@media print{.no-print{display:none!important}.print-friendly{background:#fff!important;color:#000!important;font-size:12pt;line-height:1.4}}[data-theme=dark]{@media screen and (max-width:767px){.card,.card-harmony{background-color:var(--harmony-gray-100)!important;border-color:var(--harmony-gray-300)!important;color:var(--harmony-gray-700)!important}.nav-item{background-color:initial!important;color:var(--harmony-gray-600)!important}.nav-item:focus,.nav-item:hover{background-color:var(--harmony-gray-200)!important;color:var(--harmony-gray-800)!important}.btn,button{border-color:var(--harmony-primary)!important;color:#fff!important}.btn,.btn:hover,button,button:hover{background-color:var(--harmony-primary)!important}.btn:hover,button:hover{opacity:.9}.form-control{background-color:var(--harmony-gray-200)!important;border-color:var(--harmony-gray-300)!important;color:var(--harmony-gray-700)!important}.form-control:focus{border-color:var(--harmony-primary)!important;box-shadow:0 0 0 3px #4c5af71a!important}.announcement-card,.form-control:focus{background-color:var(--harmony-gray-100)!important}.announcement-card{border-color:var(--harmony-gray-300)!important}.announcement-title{color:var(--harmony-gray-800)!important}.announcement-content{color:var(--harmony-gray-600)!important}.quiz-card,.task-card{background-color:var(--harmony-gray-100)!important;border-color:var(--harmony-gray-300)!important;color:var(--harmony-gray-700)!important}.quiz-title,.task-title{color:var(--harmony-gray-800)!important}.quiz-meta,.task-meta{color:var(--harmony-gray-500)!important}.quiz-status,.task-status{background-color:var(--harmony-gray-200)!important;color:var(--harmony-gray-700)!important}.payment-stat-card{background-color:var(--harmony-gray-100)!important;border-color:var(--harmony-gray-300)!important;color:var(--harmony-gray-700)!important}.payment-stat-value{color:var(--harmony-gray-800)!important}.payment-stat-label{color:var(--harmony-gray-500)!important}.document-card{background-color:var(--harmony-gray-100)!important;border-color:var(--harmony-gray-300)!important;color:var(--harmony-gray-700)!important}.document-title{color:var(--harmony-gray-800)!important}.document-meta{color:var(--harmony-gray-500)!important}.document-action-btn{background-color:var(--harmony-gray-200)!important;border-color:var(--harmony-gray-300)!important}.document-action-btn,.modal{color:var(--harmony-gray-700)!important}.modal{background-color:var(--harmony-gray-100)!important}.mobile-nav-bar{background-color:var(--harmony-gray-50)!important;border-color:var(--harmony-gray-300)!important}.mobile-nav-title{color:var(--harmony-gray-800)!important}.mobile-sidebar-container,.mobile-sidebar-user{background-color:var(--harmony-gray-50)!important}.mobile-sidebar-user{border-color:var(--harmony-gray-300)!important}.error-mobile{background-color:#ef44441a!important;border-color:#ef44444d!important;color:#fca5a5!important}.success-mobile{background-color:#22c55e1a!important;border-color:#22c55e4d!important;color:#86efac!important}.mobile-footer{background:var(--harmony-gradient-primary)!important}select{background-color:var(--harmony-gray-200)!important;border-color:var(--harmony-gray-300)!important;color:var(--harmony-gray-700)!important}.table-container,table{background-color:var(--harmony-gray-100)!important}th{background-color:var(--harmony-gray-200)!important;color:var(--harmony-gray-700)!important}td{background-color:var(--harmony-gray-100)!important;color:var(--harmony-gray-600)!important}}}@media screen and (max-width:767px){.mobile-btn-primary{-webkit-tap-highlight-color:transparent!important;align-items:center!important;background:linear-gradient(135deg,#3b82f6,#8b5cf6)!important;border:none!important;border-radius:12px!important;box-shadow:0 4px 15px #3b82f64d!important;color:#fff!important;display:flex!important;font-size:16px!important;font-weight:600!important;gap:8px!important;justify-content:center!important;margin-bottom:8px!important;min-height:56px!important;padding:16px 24px!important;touch-action:manipulation!important;transition:all .3s ease!important;width:100%!important}.mobile-btn-primary:hover{box-shadow:0 6px 20px #3b82f666!important;transform:translateY(-2px)!important}.mobile-btn-primary:active{box-shadow:0 2px 10px #3b82f64d!important;transform:translateY(0)!important}.mobile-btn-secondary{-webkit-tap-highlight-color:transparent!important;align-items:center!important;background:#fff!important;border:2px solid #e5e7eb!important;border-radius:10px!important;color:#374151!important;display:flex!important;font-size:15px!important;font-weight:500!important;gap:6px!important;justify-content:center!important;margin-bottom:8px!important;min-height:52px!important;padding:14px 20px!important;touch-action:manipulation!important;transition:all .3s ease!important;width:100%!important}.mobile-btn-secondary:hover{background:#f9fafb!important;border-color:#d1d5db!important;transform:translateY(-1px)!important}.mobile-btn-secondary:active{background:#f3f4f6!important;transform:translateY(0)!important}.mobile-btn-danger{-webkit-tap-highlight-color:transparent!important;align-items:center!important;background:linear-gradient(135deg,#ef4444,#dc2626)!important;border:none!important;border-radius:10px!important;box-shadow:0 4px 15px #ef44444d!important;color:#fff!important;display:flex!important;font-size:15px!important;font-weight:500!important;gap:6px!important;justify-content:center!important;margin-bottom:8px!important;min-height:52px!important;padding:14px 20px!important;touch-action:manipulation!important;transition:all .3s ease!important;width:100%!important}.mobile-btn-danger:hover{box-shadow:0 6px 20px #ef444466!important;transform:translateY(-1px)!important}.mobile-btn-danger:active{box-shadow:0 2px 10px #ef44444d!important;transform:translateY(0)!important}.mobile-btn-success{-webkit-tap-highlight-color:transparent!important;align-items:center!important;background:linear-gradient(135deg,#10b981,#059669)!important;border:none!important;border-radius:12px!important;box-shadow:0 4px 15px #10b9814d!important;color:#fff!important;display:flex!important;font-size:16px!important;font-weight:600!important;gap:8px!important;justify-content:center!important;margin-bottom:8px!important;min-height:56px!important;padding:16px 24px!important;touch-action:manipulation!important;transition:all .3s ease!important;width:100%!important}.mobile-btn-success:hover{box-shadow:0 6px 20px #10b98166!important;transform:translateY(-2px)!important}.mobile-btn-success:active{box-shadow:0 2px 10px #10b9814d!important;transform:translateY(0)!important}.mobile-btn-gold{-webkit-tap-highlight-color:transparent!important;align-items:center!important;background:linear-gradient(135deg,#f59e0b,#d97706)!important;border:none!important;border-radius:12px!important;box-shadow:0 4px 15px #f59e0b4d!important;color:#fff!important;display:flex!important;font-size:16px!important;font-weight:600!important;gap:8px!important;justify-content:center!important;margin-bottom:8px!important;min-height:56px!important;padding:16px 24px!important;touch-action:manipulation!important;transition:all .3s ease!important;width:100%!important}.mobile-btn-gold:hover{box-shadow:0 6px 20px #f59e0b66!important;transform:translateY(-2px)!important}.mobile-btn-gold:active{box-shadow:0 2px 10px #f59e0b4d!important;transform:translateY(0)!important}.mobile-btn-compact{font-size:14px!important;font-weight:500!important;gap:4px!important;min-height:44px!important;padding:12px 16px!important}.mobile-btn-compact,.mobile-btn-icon{-webkit-tap-highlight-color:transparent!important;align-items:center!important;border-radius:8px!important;display:flex!important;justify-content:center!important;margin:4px!important;touch-action:manipulation!important;transition:all .3s ease!important}.mobile-btn-icon{background:#0000!important;border:1px solid #e5e7eb!important;color:#6b7280!important;height:44px!important;padding:0!important;width:44px!important}.mobile-btn-icon:hover{background:#f3f4f6!important;border-color:#d1d5db!important}.mobile-btn-icon.danger{border-color:#fecaca!important;color:#ef4444!important}.mobile-btn-icon.danger:hover{background:#fef2f2!important;border-color:#f87171!important}.mobile-btn-group{flex-direction:column!important}.mobile-btn-group,.mobile-btn-group-horizontal{display:flex!important;gap:8px!important;margin-top:16px!important;width:100%!important}.mobile-btn-group-horizontal{flex-direction:row!important}.mobile-btn-group-horizontal .mobile-btn-compact{flex:1 1!important;margin:0!important}.mobile-modal-buttons{border-top:1px solid #e5e7eb!important;display:flex!important;flex-direction:column!important;gap:12px!important;margin-top:24px!important;padding-top:24px!important}.mobile-btn-active{background:linear-gradient(135deg,#10b981,#059669)!important;color:#fff!important}.mobile-btn-overdue{background:linear-gradient(135deg,#ef4444,#dc2626)!important;color:#fff!important}.mobile-btn-due-today{background:linear-gradient(135deg,#f59e0b,#d97706)!important;color:#fff!important}.mobile-btn-disabled{cursor:not-allowed!important;opacity:.6!important}.mobile-btn-disabled,.mobile-btn-disabled:active,.mobile-btn-disabled:hover{box-shadow:none!important;transform:none!important}.mobile-btn-loading{color:#0000!important;position:relative!important}.mobile-btn-loading:after{animation:spin 1s linear infinite!important;border:2px solid #0000!important;border-radius:50%!important;border-top-color:currentcolor!important;content:""!important;height:20px!important;left:50%!important;margin-left:-10px!important;margin-top:-10px!important;position:absolute!important;top:50%!important;width:20px!important}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.mobile-btn-danger,.mobile-btn-gold,.mobile-btn-primary,.mobile-btn-secondary,.mobile-btn-success{overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important}.mobile-btn-danger svg,.mobile-btn-gold svg,.mobile-btn-primary svg,.mobile-btn-secondary svg,.mobile-btn-success svg{flex-shrink:0!important;height:20px!important;width:20px!important}.mobile-btn-compact svg{flex-shrink:0!important;height:16px!important;width:16px!important}.mobile-btn-icon svg{flex-shrink:0!important;height:18px!important;width:18px!important}}@media screen and (min-width:768px) and (max-width:1023px){.mobile-btn-group{flex-direction:row!important;gap:12px!important}.mobile-btn-group>*{flex:1 1!important}.mobile-modal-buttons{flex-direction:row!important;justify-content:flex-end!important}.mobile-modal-buttons>*{flex:0 0 auto!important;min-width:120px!important;width:auto!important}}[data-theme=dark]{@media screen and (max-width:767px){.mobile-btn-secondary{background:var(--harmony-gray-800)!important;border-color:var(--harmony-gray-600)!important;color:var(--harmony-gray-100)!important}.mobile-btn-secondary:hover{background:var(--harmony-gray-700)!important;border-color:var(--harmony-gray-500)!important}.mobile-btn-icon{background:var(--harmony-gray-800)!important;border-color:var(--harmony-gray-600)!important;color:var(--harmony-gray-300)!important}.mobile-btn-icon:hover{background:var(--harmony-gray-700)!important;border-color:var(--harmony-gray-500)!important}}}@media screen and (max-width:767px){.announcements-header{align-items:stretch!important;flex-direction:column!important;gap:1rem!important;padding:1rem!important}.announcements-header h1{font-size:1.75rem!important;margin-bottom:.5rem!important;text-align:center!important}.announcements-header .new-badge{align-self:center!important}.announcement-card{border-radius:12px!important;box-shadow:0 2px 8px #0000001a!important;margin-bottom:1rem!important;padding:1.25rem!important}.announcement-title{font-size:1.125rem!important;line-height:1.4!important;margin-bottom:.75rem!important}.announcement-content{font-size:14px!important;line-height:1.6!important;margin-bottom:1rem!important}.announcement-meta{align-items:flex-start!important;flex-direction:column!important;gap:.5rem!important}.announcement-priority-badge{align-self:flex-start!important;font-size:12px!important;padding:4px 8px!important}.announcement-actions{border-top:1px solid #e5e7eb!important;justify-content:flex-end!important;margin-top:1rem!important;padding-top:1rem!important}.quizzes-header{align-items:stretch!important;flex-direction:column!important;gap:1rem!important;padding:1rem!important}.quizzes-header h1{font-size:1.75rem!important;margin-bottom:.5rem!important;text-align:center!important}.quizzes-filter-row{display:flex!important;flex-direction:column!important;gap:.75rem!important}.quizzes-filter-select{background-color:#fff!important;border:2px solid #e5e7eb!important;border-radius:8px!important;font-size:16px!important;padding:12px 16px!important;width:100%!important}.quiz-grid{gap:1rem!important;grid-template-columns:1fr!important;padding:0 1rem!important}.quiz-card{border-radius:12px!important;box-shadow:0 2px 8px #0000001a!important;padding:1.25rem!important}.quiz-card,.quiz-card-header{margin-bottom:1rem!important}.quiz-title{font-size:1.125rem!important;line-height:1.4!important;margin-bottom:.5rem!important}.quiz-description{color:#6b7280!important;font-size:14px!important;line-height:1.5!important;margin-bottom:.75rem!important}.quiz-meta-row{display:flex!important;flex-direction:column!important;gap:.5rem!important;margin-bottom:1rem!important}.quiz-due-date{color:#6b7280!important;font-size:14px!important;gap:.25rem!important}.quiz-due-date,.quiz-status-row{align-items:center!important;display:flex!important}.quiz-status-row{flex-wrap:wrap!important;gap:.5rem!important;justify-content:space-between!important;margin-bottom:1rem!important}.quiz-status-badge{border-radius:12px!important;font-size:12px!important;font-weight:500!important;padding:4px 8px!important;text-transform:uppercase!important}.quiz-points{color:#6b7280!important;font-size:14px!important;font-weight:500!important}.quiz-class-info{border-radius:6px!important;color:#9ca3af!important;font-size:12px!important;padding:.5rem!important}.quiz-class-info,.quiz-student-status{background-color:#f9fafb!important;margin-bottom:1rem!important}.quiz-student-status{border:1px solid #e5e7eb!important;border-radius:8px!important;padding:.75rem!important}.quiz-student-status-row{display:flex!important;font-size:14px!important;justify-content:space-between!important;margin-bottom:.25rem!important}.quiz-student-status-row:last-child{margin-bottom:0!important}.mobile-modal{border-radius:0!important;bottom:0!important;height:100%!important;left:0!important;margin:0!important;max-height:none!important;max-width:none!important;overflow-y:auto!important;position:fixed!important;right:0!important;top:0!important;width:100%!important}.mobile-modal-content{display:flex!important;flex-direction:column!important;min-height:100vh!important;padding:1.5rem!important}.mobile-modal-header{align-items:center!important;border-bottom:1px solid #e5e7eb!important;display:flex!important;justify-content:space-between!important;margin-bottom:1.5rem!important;padding-bottom:1rem!important}.mobile-modal-title{font-size:1.25rem!important;font-weight:600!important}.mobile-modal-close{align-items:center!important;background:#0000!important;border:1px solid #e5e7eb!important;border-radius:8px!important;color:#6b7280!important;display:flex!important;height:44px!important;justify-content:center!important;width:44px!important}.mobile-modal-body{flex:1 1!important}.mobile-form-group,.mobile-modal-body{margin-bottom:1.5rem!important}.mobile-form-label{color:#374151!important;display:block!important;font-size:14px!important;font-weight:500!important;margin-bottom:.5rem!important}.mobile-form-input,.mobile-form-select,.mobile-form-textarea{background-color:#fff!important;border:2px solid #e5e7eb!important;border-radius:8px!important;font-size:16px!important;padding:12px 16px!important;transition:border-color .2s ease!important;width:100%!important}.mobile-form-input:focus,.mobile-form-select:focus,.mobile-form-textarea:focus{border-color:#3b82f6!important;box-shadow:0 0 0 3px #3b82f61a!important;outline:none!important}.mobile-form-textarea{min-height:120px!important;resize:vertical!important}.mobile-error-banner{background-color:#fef2f2!important;border:1px solid #fecaca!important;border-radius:8px!important;color:#991b1b!important}.mobile-error-banner,.mobile-success-banner{margin:1rem!important;padding:1rem!important}.mobile-success-banner{background-color:#f0fdf4!important;border:1px solid #bbf7d0!important;border-radius:8px!important;color:#166534!important}.mobile-empty-state{padding:3rem 1rem!important;text-align:center!important}.mobile-empty-state-icon{color:#d1d5db!important;height:4rem!important;margin:0 auto 1rem!important;width:4rem!important}.mobile-empty-state-title{color:#374151!important;font-size:1.125rem!important;font-weight:600!important;margin-bottom:.5rem!important}.mobile-empty-state-description{color:#6b7280!important;line-height:1.5!important;margin-bottom:1.5rem!important}.mobile-loading-container{align-items:center!important;display:flex!important;flex-direction:column!important;justify-content:center!important;padding:3rem 1rem!important}.mobile-loading-spinner{animation:spin 1s linear infinite!important;border:3px solid #f3f4f6!important;border-radius:50%!important;border-top-color:#3b82f6!important;height:3rem!important;margin-bottom:1rem!important;width:3rem!important}.mobile-loading-text{color:#6b7280!important;font-size:14px!important}.mobile-content-container{padding:1rem!important}.mobile-section-spacing{margin-bottom:2rem!important}.mobile-responsive-image{border-radius:8px!important;height:auto!important;width:100%!important}.mobile-heading-1{font-size:1.75rem!important;font-weight:700!important;line-height:1.2!important;margin-bottom:1rem!important}.mobile-heading-2{font-size:1.5rem!important;font-weight:600!important;line-height:1.3!important;margin-bottom:.75rem!important}.mobile-heading-3{font-size:1.25rem!important;font-weight:600!important;line-height:1.4!important;margin-bottom:.5rem!important}.mobile-body-text{color:#374151!important;font-size:14px!important;line-height:1.6!important}.mobile-small-text{color:#6b7280!important;font-size:12px!important;line-height:1.5!important}.mobile-safe-area-top{padding-top:env(safe-area-inset-top,0)!important}.mobile-safe-area-bottom{padding-bottom:env(safe-area-inset-bottom,0)!important}.mobile-safe-area-left{padding-left:env(safe-area-inset-left,0)!important}.mobile-safe-area-right{padding-right:env(safe-area-inset-right,0)!important}}@media screen and (min-width:768px) and (max-width:1023px){.quiz-grid{gap:1.5rem!important;grid-template-columns:repeat(2,1fr)!important}.announcements-header,.quizzes-header{align-items:center!important;flex-direction:row!important;justify-content:space-between!important}.mobile-modal{border-radius:12px!important;height:auto!important;left:50%!important;max-height:90vh!important;max-width:600px!important;position:fixed!important;top:50%!important;transform:translate(-50%,-50%)!important;width:90%!important}.mobile-modal-buttons{flex-direction:row!important;gap:.75rem!important;justify-content:flex-end!important}.mobile-modal-buttons>*{min-width:120px!important;width:auto!important}}*,: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:#3b82f680;--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:#3b82f680;--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.17 | 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:Inter,sans-serif;font-variation-settings:normal;line-height:1.5;tab-size:4}body{line-height:inherit}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:initial}sub{bottom:-.25em}sup{top:-.5em}table{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:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-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}.sr-only{clip:rect(0,0,0,0);border-width:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.inset-y-0{bottom:0;top:0}.bottom-0{bottom:0}.bottom-2{bottom:.5rem}.left-0{left:0}.left-3{left:.75rem}.right-0{right:0}.right-2{right:.5rem}.top-0{top:0}.top-1\/2{top:50%}.top-3{top:.75rem}.z-40{z-index:40}.z-50{z-index:50}.z-\[1100\]{z-index:1100}.m-1{margin:.25rem}.m-2{margin:.5rem}.m-4{margin:1rem}.mx-4{margin-left:1rem;margin-right:1rem}.mx-auto{margin-left:auto;margin-right:auto}.-mb-px{margin-bottom:-1px}.-mr-12{margin-right:-3rem}.mb-0\.5{margin-bottom:.125rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-1{margin-left:.25rem}.ml-2{margin-left:.5rem}.ml-3{margin-left:.75rem}.ml-4{margin-left:1rem}.ml-8{margin-left:2rem}.mr-1{margin-right:.25rem}.mr-2{margin-right:.5rem}.mr-3{margin-right:.75rem}.mr-4{margin-right:1rem}.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{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.contents{display:contents}.hidden{display:none}.h-0{height:0}.h-0\.5{height:.125rem}.h-1{height:.25rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-16{height:4rem}.h-2{height:.5rem}.h-20{height:5rem}.h-24{height:6rem}.h-3{height:.75rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-5\/6{height:83.333333%}.h-6{height:1.5rem}.h-8{height:2rem}.h-full{height:100%}.h-px{height:1px}.h-screen{height:100vh}.max-h-32{max-height:8rem}.max-h-48{max-height:12rem}.max-h-\[90vh\]{max-height:90vh}.max-h-full{max-height:100%}.min-h-10{min-height:2.5rem}.min-h-12{min-height:3rem}.min-h-14{min-height:3.5rem}.min-h-16{min-height:4rem}.min-h-24{min-height:6rem}.min-h-64{min-height:16rem}.min-h-full{min-height:100%}.min-h-screen{min-height:100vh}.w-0{width:0}.w-0\.5{width:.125rem}.w-1{width:.25rem}.w-10{width:2.5rem}.w-12{width:3rem}.w-16{width:4rem}.w-2{width:.5rem}.w-20{width:5rem}.w-24{width:6rem}.w-3{width:.75rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-64{width:16rem}.w-8{width:2rem}.w-80{width:20rem}.w-full{width:100%}.w-px{width:1px}.min-w-0{min-width:0}.min-w-10{min-width:2.5rem}.min-w-12{min-width:3rem}.min-w-14{min-width:3.5rem}.min-w-\[24px\]{min-width:24px}.min-w-\[28px\]{min-width:28px}.min-w-full{min-width:100%}.max-w-2xl{max-width:42rem}.max-w-4xl{max-width:56rem}.max-w-6xl{max-width:72rem}.max-w-7xl{max-width:80rem}.max-w-full{max-width:100%}.max-w-lg{max-width:32rem}.max-w-md{max-width:28rem}.max-w-none{max-width:none}.max-w-sm{max-width:24rem}.max-w-xs{max-width:20rem}.flex-1{flex:1 1}.flex-shrink-0{flex-shrink:0}.-translate-y-1\/2{--tw-translate-y:-50%}.-translate-y-1\/2,.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))}@keyframes ping{75%,to{opacity:0;transform:scale(2)}}.animate-ping{animation:ping 1s cubic-bezier(0,0,.2,1) infinite}.animate-spin{animation:spin 1s linear infinite}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.touch-manipulation{touch-action:manipulation}.resize-none{resize:none}.resize{resize:both}.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))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.space-x-0\.5>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.125rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.125rem*var(--tw-space-x-reverse))}.space-x-1>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.25rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.25rem*var(--tw-space-x-reverse))}.space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.5rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.5rem*var(--tw-space-x-reverse))}.space-x-3>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.75rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.75rem*var(--tw-space-x-reverse))}.space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(1rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(1rem*var(--tw-space-x-reverse))}.space-x-6>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(1.5rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(1.5rem*var(--tw-space-x-reverse))}.space-x-8>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(2rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(2rem*var(--tw-space-x-reverse))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.25rem*var(--tw-space-y-reverse));margin-top:calc(.25rem*(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-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)))}.space-y-8>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(2rem*var(--tw-space-y-reverse));margin-top:calc(2rem*(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-200>:not([hidden])~:not([hidden]){--tw-divide-opacity:1;border-color:#e5e7eb;border-color:rgb(229 231 235/var(--tw-divide-opacity,1))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis}.truncate,.whitespace-nowrap{white-space:nowrap}.whitespace-pre-wrap{white-space:pre-wrap}.break-all{word-break:break-all}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-xl{border-radius:.75rem}.rounded-t-xl{border-top-left-radius:.75rem;border-top-right-radius:.75rem}.border{border-width:1px}.border-0{border-width:0}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-b-2{border-bottom-width:2px}.border-l{border-left-width:1px}.border-l-4{border-left-width:4px}.border-r{border-right-width:1px}.border-t{border-top-width:1px}.border-dashed{border-style:dashed}.border-amber-200{--tw-border-opacity:1;border-color:#fde68a;border-color:rgb(253 230 138/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-400{--tw-border-opacity:1;border-color:#60a5fa;border-color:rgb(96 165 250/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-blue-600{--tw-border-opacity:1;border-color:#2563eb;border-color:rgb(37 99 235/var(--tw-border-opacity,1))}.border-blue-800{--tw-border-opacity:1;border-color:#1e40af;border-color:rgb(30 64 175/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-gray-400{--tw-border-opacity:1;border-color:#9ca3af;border-color:rgb(156 163 175/var(--tw-border-opacity,1))}.border-gray-600{--tw-border-opacity:1;border-color:#4b5563;border-color:rgb(75 85 99/var(--tw-border-opacity,1))}.border-gray-700{--tw-border-opacity:1;border-color:#374151;border-color:rgb(55 65 81/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-green-400{--tw-border-opacity:1;border-color:#4ade80;border-color:rgb(74 222 128/var(--tw-border-opacity,1))}.border-green-500{--tw-border-opacity:1;border-color:#22c55e;border-color:rgb(34 197 94/var(--tw-border-opacity,1))}.border-green-800{--tw-border-opacity:1;border-color:#166534;border-color:rgb(22 101 52/var(--tw-border-opacity,1))}.border-indigo-200{--tw-border-opacity:1;border-color:#c7d2fe;border-color:rgb(199 210 254/var(--tw-border-opacity,1))}.border-orange-200{--tw-border-opacity:1;border-color:#fed7aa;border-color:rgb(254 215 170/var(--tw-border-opacity,1))}.border-pink-200{--tw-border-opacity:1;border-color:#fbcfe8;border-color:rgb(251 207 232/var(--tw-border-opacity,1))}.border-pink-500{--tw-border-opacity:1;border-color:#ec4899;border-color:rgb(236 72 153/var(--tw-border-opacity,1))}.border-pink-600{--tw-border-opacity:1;border-color:#db2777;border-color:rgb(219 39 119/var(--tw-border-opacity,1))}.border-purple-200{--tw-border-opacity:1;border-color:#e9d5ff;border-color:rgb(233 213 255/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-red-500{--tw-border-opacity:1;border-color:#ef4444;border-color:rgb(239 68 68/var(--tw-border-opacity,1))}.border-red-800{--tw-border-opacity:1;border-color:#991b1b;border-color:rgb(153 27 27/var(--tw-border-opacity,1))}.border-transparent{border-color:#0000}.border-white{--tw-border-opacity:1;border-color:#fff;border-color:rgb(255 255 255/var(--tw-border-opacity,1))}.border-white\/30{border-color:#ffffff4d}.border-yellow-200{--tw-border-opacity:1;border-color:#fef08a;border-color:rgb(254 240 138/var(--tw-border-opacity,1))}.border-yellow-300{--tw-border-opacity:1;border-color:#fde047;border-color:rgb(253 224 71/var(--tw-border-opacity,1))}.bg-amber-50{--tw-bg-opacity:1;background-color:#fffbeb;background-color:rgb(255 251 235/var(--tw-bg-opacity,1))}.bg-black{--tw-bg-opacity:1;background-color:#000;background-color:rgb(0 0 0/var(--tw-bg-opacity,1))}.bg-blue-100{--tw-bg-opacity:1;background-color:#dbeafe;background-color:rgb(219 234 254/var(--tw-bg-opacity,1))}.bg-blue-50{--tw-bg-opacity:1;background-color:#eff6ff;background-color:rgb(239 246 255/var(--tw-bg-opacity,1))}.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-blue-900{--tw-bg-opacity:1;background-color:#1e3a8a;background-color:rgb(30 58 138/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-300{--tw-bg-opacity:1;background-color:#d1d5db;background-color:rgb(209 213 219/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-500{--tw-bg-opacity:1;background-color:#6b7280;background-color:rgb(107 114 128/var(--tw-bg-opacity,1))}.bg-gray-600{--tw-bg-opacity:1;background-color:#4b5563;background-color:rgb(75 85 99/var(--tw-bg-opacity,1))}.bg-gray-800{--tw-bg-opacity:1;background-color:#1f2937;background-color:rgb(31 41 55/var(--tw-bg-opacity,1))}.bg-gray-900{--tw-bg-opacity:1;background-color:#111827;background-color:rgb(17 24 39/var(--tw-bg-opacity,1))}.bg-green-100{--tw-bg-opacity:1;background-color:#dcfce7;background-color:rgb(220 252 231/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-500{--tw-bg-opacity:1;background-color:#22c55e;background-color:rgb(34 197 94/var(--tw-bg-opacity,1))}.bg-green-600{--tw-bg-opacity:1;background-color:#16a34a;background-color:rgb(22 163 74/var(--tw-bg-opacity,1))}.bg-green-900{--tw-bg-opacity:1;background-color:#14532d;background-color:rgb(20 83 45/var(--tw-bg-opacity,1))}.bg-indigo-100{--tw-bg-opacity:1;background-color:#e0e7ff;background-color:rgb(224 231 255/var(--tw-bg-opacity,1))}.bg-orange-100{--tw-bg-opacity:1;background-color:#ffedd5;background-color:rgb(255 237 213/var(--tw-bg-opacity,1))}.bg-pink-100{--tw-bg-opacity:1;background-color:#fce7f3;background-color:rgb(252 231 243/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-pink-600{--tw-bg-opacity:1;background-color:#db2777;background-color:rgb(219 39 119/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-600{--tw-bg-opacity:1;background-color:#9333ea;background-color:rgb(147 51 234/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-600{--tw-bg-opacity:1;background-color:#dc2626;background-color:rgb(220 38 38/var(--tw-bg-opacity,1))}.bg-red-900{--tw-bg-opacity:1;background-color:#7f1d1d;background-color:rgb(127 29 29/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\/20{background-color:#fff3}.bg-yellow-100{--tw-bg-opacity:1;background-color:#fef9c3;background-color:rgb(254 249 195/var(--tw-bg-opacity,1))}.bg-yellow-400{--tw-bg-opacity:1;background-color:#facc15;background-color:rgb(250 204 21/var(--tw-bg-opacity,1))}.bg-yellow-50{--tw-bg-opacity:1;background-color:#fefce8;background-color:rgb(254 252 232/var(--tw-bg-opacity,1))}.bg-opacity-10{--tw-bg-opacity:0.1}.bg-opacity-20{--tw-bg-opacity:0.2}.bg-opacity-30{--tw-bg-opacity:0.3}.bg-opacity-50{--tw-bg-opacity:0.5}.bg-opacity-75{--tw-bg-opacity:0.75}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.from-blue-400{--tw-gradient-from:#60a5fa var(--tw-gradient-from-position);--tw-gradient-to:#60a5fa00 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:#3b82f600 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:#2563eb00 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:#f9fafb00 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-green-400{--tw-gradient-from:#4ade80 var(--tw-gradient-from-position);--tw-gradient-to:#4ade8000 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:#22c55e00 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:#ec489900 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-purple-400{--tw-gradient-from:#c084fc var(--tw-gradient-from-position);--tw-gradient-to:#c084fc00 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:#a855f700 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-yellow-400{--tw-gradient-from:#facc15 var(--tw-gradient-from-position);--tw-gradient-to:#facc1500 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-yellow-500{--tw-gradient-from:#eab308 var(--tw-gradient-from-position);--tw-gradient-to:#eab30800 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.to-blue-600{--tw-gradient-to:#2563eb var(--tw-gradient-to-position)}.to-blue-700{--tw-gradient-to:#1d4ed8 var(--tw-gradient-to-position)}.to-green-600{--tw-gradient-to:#16a34a var(--tw-gradient-to-position)}.to-purple-600{--tw-gradient-to:#9333ea var(--tw-gradient-to-position)}.to-white{--tw-gradient-to:#fff var(--tw-gradient-to-position)}.to-yellow-600{--tw-gradient-to:#ca8a04 var(--tw-gradient-to-position)}.bg-right{background-position:100%}.bg-no-repeat{background-repeat:no-repeat}.object-contain{object-fit:contain}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-1{padding-left:.25rem;padding-right:.25rem}.px-12{padding-left:3rem;padding-right:3rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0\.5{padding-bottom:.125rem;padding-top:.125rem}.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-2{padding-bottom:.5rem;padding-top:.5rem}.py-3{padding-bottom:.75rem;padding-top:.75rem}.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-4{padding-bottom:1rem}.pb-6{padding-bottom:1.5rem}.pl-1{padding-left:.25rem}.pl-10{padding-left:2.5rem}.pl-2{padding-left:.5rem}.pl-4{padding-left:1rem}.pr-10{padding-right:2.5rem}.pr-2{padding-right:.5rem}.pr-3{padding-right:.75rem}.pr-4{padding-right:1rem}.pt-16{padding-top:4rem}.pt-2{padding-top:.5rem}.pt-4{padding-top:1rem}.pt-5{padding-top:1.25rem}.pt-6{padding-top:1.5rem}.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-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}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.italic{font-style:italic}.leading-4{line-height:1rem}.leading-5{line-height:1.25rem}.leading-relaxed{line-height:1.625}.leading-tight{line-height:1.25}.tracking-wide{letter-spacing:.025em}.tracking-wider{letter-spacing:.05em}.tracking-widest{letter-spacing:.1em}.text-amber-400{--tw-text-opacity:1;color:#fbbf24;color:rgb(251 191 36/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-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-blue-800{--tw-text-opacity:1;color:#1e40af;color:rgb(30 64 175/var(--tw-text-opacity,1))}.text-blue-900{--tw-text-opacity:1;color:#1e3a8a;color:rgb(30 58 138/var(--tw-text-opacity,1))}.text-gray-100{--tw-text-opacity:1;color:#f3f4f6;color:rgb(243 244 246/var(--tw-text-opacity,1))}.text-gray-200{--tw-text-opacity:1;color:#e5e7eb;color:rgb(229 231 235/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-gray-900{--tw-text-opacity:1;color:#111827;color:rgb(17 24 39/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-400{--tw-text-opacity:1;color:#4ade80;color:rgb(74 222 128/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-green-800{--tw-text-opacity:1;color:#166534;color:rgb(22 101 52/var(--tw-text-opacity,1))}.text-green-900{--tw-text-opacity:1;color:#14532d;color:rgb(20 83 45/var(--tw-text-opacity,1))}.text-indigo-800{--tw-text-opacity:1;color:#3730a3;color:rgb(55 48 163/var(--tw-text-opacity,1))}.text-orange-600{--tw-text-opacity:1;color:#ea580c;color:rgb(234 88 12/var(--tw-text-opacity,1))}.text-orange-800{--tw-text-opacity:1;color:#9a3412;color:rgb(154 52 18/var(--tw-text-opacity,1))}.text-pink-100{--tw-text-opacity:1;color:#fce7f3;color:rgb(252 231 243/var(--tw-text-opacity,1))}.text-pink-600{--tw-text-opacity:1;color:#db2777;color:rgb(219 39 119/var(--tw-text-opacity,1))}.text-pink-800{--tw-text-opacity:1;color:#9d174d;color:rgb(157 23 77/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-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-purple-800{--tw-text-opacity:1;color:#6b21a8;color:rgb(107 33 168/var(--tw-text-opacity,1))}.text-purple-900{--tw-text-opacity:1;color:#581c87;color:rgb(88 28 135/var(--tw-text-opacity,1))}.text-red-100{--tw-text-opacity:1;color:#fee2e2;color:rgb(254 226 226/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-red-800{--tw-text-opacity:1;color:#991b1b;color:rgb(153 27 27/var(--tw-text-opacity,1))}.text-red-900{--tw-text-opacity:1;color:#7f1d1d;color:rgb(127 29 29/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:#fff;color:rgb(255 255 255/var(--tw-text-opacity,1))}.text-yellow-100{--tw-text-opacity:1;color:#fef9c3;color:rgb(254 249 195/var(--tw-text-opacity,1))}.text-yellow-200{--tw-text-opacity:1;color:#fef08a;color:rgb(254 240 138/var(--tw-text-opacity,1))}.text-yellow-400{--tw-text-opacity:1;color:#facc15;color:rgb(250 204 21/var(--tw-text-opacity,1))}.text-yellow-600{--tw-text-opacity:1;color:#ca8a04;color:rgb(202 138 4/var(--tw-text-opacity,1))}.text-yellow-700{--tw-text-opacity:1;color:#a16207;color:rgb(161 98 7/var(--tw-text-opacity,1))}.text-yellow-800{--tw-text-opacity:1;color:#854d0e;color:rgb(133 77 14/var(--tw-text-opacity,1))}.text-yellow-900{--tw-text-opacity:1;color:#713f12;color:rgb(113 63 18/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))}.placeholder-gray-500::placeholder{--tw-placeholder-opacity:1;color:#6b7280;color:rgb(107 114 128/var(--tw-placeholder-opacity,1))}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.opacity-80{opacity:.8}.opacity-90{opacity:.9}.shadow{--tw-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color)}.shadow,.shadow-lg{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-lg{--tw-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.shadow-md{--tw-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color)}.shadow-md,.shadow-sm{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-sm{--tw-shadow:0 1px 2px 0 #0000000d;--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color)}.shadow-xl{--tw-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color);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)}.outline{outline-style:solid}.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);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-blue-200{--tw-ring-opacity:1;--tw-ring-color:rgb(191 219 254/var(--tw-ring-opacity,1))}.drop-shadow-lg{--tw-drop-shadow:drop-shadow(0 10px 8px #0000000a) drop-shadow(0 4px 3px #0000001a)}.drop-shadow-lg,.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-sm{--tw-backdrop-blur:blur(4px);-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)}.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-duration:.15s;transition-property:box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-transform{transition-duration:.15s;transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}:root{--harmony-primary:#1a237e;--harmony-secondary:#e91e63;--harmony-accent:#fff;--harmony-gold:#ffc107;--harmony-light-pink:#f8bbd9;--harmony-dark-blue:#0d1b69;--harmony-navy:#1a237e;--harmony-gray-50:#fafafa;--harmony-gray-100:#f5f5f5;--harmony-gray-200:#eee;--harmony-gray-300:#e0e0e0;--harmony-gray-400:#bdbdbd;--harmony-gray-500:#9e9e9e;--harmony-gray-600:#757575;--harmony-gray-700:#616161;--harmony-gray-800:#424242;--harmony-gray-900:#212121;--harmony-success:#4caf50;--harmony-warning:#ffc107;--harmony-error:#f44336;--harmony-info:#2196f3;--harmony-gradient-primary:linear-gradient(135deg,#1a237e,#303f9f);--harmony-gradient-secondary:linear-gradient(135deg,#e91e63,#f48fb1);--harmony-gradient-hero:linear-gradient(135deg,#1a237e,#e91e63 50%,#fff);--harmony-gradient-accent:linear-gradient(135deg,#fff,#f5f5f5);--harmony-shadow-sm:0 1px 3px 0 #1a237e1a,0 1px 2px 0 #1a237e0f;--harmony-shadow-md:0 4px 6px -1px #1a237e1a,0 2px 4px -1px #1a237e0f;--harmony-shadow-lg:0 10px 15px -3px #1a237e1a,0 4px 6px -2px #1a237e0d;--harmony-shadow-brand:0 10px 25px -3px #1a237e40;--harmony-shadow-pink:0 10px 25px -3px #e91e6340}[data-theme=dark]{--harmony-primary:#4c5af7;--harmony-secondary:#ff4081;--harmony-accent:#121826;--harmony-gold:#ffd740;--harmony-gray-50:#0f1419;--harmony-gray-100:#1a202c;--harmony-gray-200:#2d3748;--harmony-gray-300:#4a5568;--harmony-gray-400:#718096;--harmony-gray-500:#a0aec0;--harmony-gray-600:#cbd5e0;--harmony-gray-700:#e2e8f0;--harmony-gray-800:#f7fafc;--harmony-gray-900:#fff;--harmony-gradient-primary:linear-gradient(135deg,#4c5af7,#6366f1);--harmony-gradient-secondary:linear-gradient(135deg,#ff4081,#ff6ec7);--harmony-gradient-hero:linear-gradient(135deg,#0f1419,#1a202c 50%,#2d3748);--harmony-gradient-accent:linear-gradient(135deg,#1a202c,#2d3748);--harmony-shadow-sm:0 1px 3px 0 #0000004d,0 1px 2px 0 #0003;--harmony-shadow-md:0 4px 6px -1px #0006,0 2px 4px -1px #0000004d;--harmony-shadow-lg:0 10px 15px -3px #00000080,0 4px 6px -2px #0006;--harmony-shadow-brand:0 10px 25px -3px #4c5af766;--harmony-shadow-pink:0 10px 25px -3px #ff408166}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;background-color:#fafafa;background-color:var(--harmony-gray-50);color:#212121;color:var(--harmony-gray-900);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0;overflow-x:hidden;transition:background-color .3s ease,color .3s ease}.font-brand{font-family:Playfair Display,serif}.font-display{font-family:Inter,sans-serif;font-weight:600}.text-harmony-primary{color:#1a237e;color:var(--harmony-primary)}.text-harmony-secondary{color:#e91e63;color:var(--harmony-secondary)}.text-harmony-accent{color:#fff;color:var(--harmony-accent)}.text-harmony-gold{color:#ffc107;color:var(--harmony-gold)}.text-harmony-navy{color:#1a237e;color:var(--harmony-navy)}.bg-harmony-primary{background-color:#1a237e;background-color:var(--harmony-primary)}.bg-harmony-secondary{background-color:#e91e63;background-color:var(--harmony-secondary)}.bg-harmony-accent{background-color:#fff;background-color:var(--harmony-accent)}.bg-harmony-gold{background-color:#ffc107;background-color:var(--harmony-gold)}.bg-harmony-navy{background-color:#1a237e;background-color:var(--harmony-navy)}.border-harmony-primary{border-color:#1a237e;border-color:var(--harmony-primary)}.border-harmony-secondary{border-color:#e91e63;border-color:var(--harmony-secondary)}.border-harmony-accent{border-color:#fff;border-color:var(--harmony-accent)}.border-harmony-navy{border-color:#1a237e;border-color:var(--harmony-navy)}.bg-gradient-primary{background:linear-gradient(135deg,#1a237e,#303f9f);background:var(--harmony-gradient-primary)}.bg-gradient-secondary{background:linear-gradient(135deg,#e91e63,#f48fb1);background:var(--harmony-gradient-secondary)}.bg-gradient-accent{background:linear-gradient(135deg,#fff,#f5f5f5);background:var(--harmony-gradient-accent)}.btn-harmony-primary,.shadow-harmony{box-shadow:0 10px 25px -3px #1a237e40;box-shadow:var(--harmony-shadow-brand)}.btn-harmony-primary{background:linear-gradient(135deg,#1a237e,#303f9f);background:var(--harmony-gradient-primary);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;letter-spacing:.5px;padding:12px 24px;transition:all .3s ease}.btn-harmony-primary:hover{box-shadow:0 10px 15px -3px #1a237e1a,0 4px 6px -2px #1a237e0d;box-shadow:var(--harmony-shadow-lg);transform:translateY(-2px)}.btn-harmony-secondary{background:linear-gradient(135deg,#e91e63,#f48fb1);background:var(--harmony-gradient-secondary);border:none;border-radius:8px;box-shadow:0 10px 25px -3px #e91e6340;box-shadow:var(--harmony-shadow-pink);color:#fff;cursor:pointer;font-size:14px;font-weight:600;letter-spacing:.5px;padding:12px 24px;transition:all .3s ease}.btn-harmony-secondary:hover{box-shadow:0 10px 15px -3px #1a237e1a,0 4px 6px -2px #1a237e0d;box-shadow:var(--harmony-shadow-lg);transform:translateY(-2px)}.card-harmony{background:#fff;border:1px solid #eee;border:1px solid var(--harmony-gray-200);border-radius:12px;box-shadow:0 4px 6px -1px #1a237e1a,0 2px 4px -1px #1a237e0f;box-shadow:var(--harmony-shadow-md);padding:24px;transition:all .3s ease}.card-harmony:hover{box-shadow:0 10px 15px -3px #1a237e1a,0 4px 6px -2px #1a237e0d;box-shadow:var(--harmony-shadow-lg);transform:translateY(-2px)}.nav-item-harmony{border-radius:8px;transition:all .3s ease}.nav-item-harmony:hover{background:linear-gradient(135deg,#f8bbd9,#fffc);background:linear-gradient(135deg,var(--harmony-light-pink) 0,#fffc 100%);transform:translateX(4px)}.hero-harmony{background:linear-gradient(135deg,#1a237e,#e91e63 50%,#fff);background:var(--harmony-gradient-hero);color:#fff;overflow:hidden;padding:60px 0;position:relative}.hero-harmony:before{background:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cdefs%3E%3Cpattern id='a' x='0' y='0' width='20' height='20' patternUnits='userSpaceOnUse'%3E%3Ccircle cx='10' cy='10' r='1' fill='rgba(255,255,255,0.1)'/%3E%3C/pattern%3E%3C/defs%3E%3Cpath fill='url(%23a)' d='M0 0h100v100H0z'/%3E%3C/svg%3E");bottom:0;content:"";left:0;opacity:.3;position:absolute;right:0;top:0}.academic-badge{align-items:center;background:linear-gradient(135deg,#fff,#f5f5f5);background:var(--harmony-gradient-accent);border-radius:20px;color:#fff;display:inline-flex;font-size:12px;font-weight:500;gap:8px;letter-spacing:.5px;padding:8px 16px;text-transform:uppercase}.achievement-medal{align-items:center;background:linear-gradient(135deg,#1a237e,#303f9f);background:var(--harmony-gradient-primary);border-radius:50%;box-shadow:0 4px 6px -1px #1a237e1a,0 2px 4px -1px #1a237e0f;box-shadow:var(--harmony-shadow-md);color:#fff;display:flex;font-size:16px;font-weight:600;height:40px;justify-content:center;position:relative;width:40px}.achievement-medal:after{animation:rotate 3s linear infinite;background:conic-gradient(#ffc107,#1a237e,#e91e63,#fff,#ffc107);background:conic-gradient(var(--harmony-gold),var(--harmony-primary),var(--harmony-secondary),var(--harmony-accent),var(--harmony-gold));border-radius:50%;bottom:-2px;content:"";left:-2px;position:absolute;right:-2px;top:-2px;z-index:-1}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}button,input,select,textarea{-webkit-tap-highlight-color:transparent;touch-action:manipulation}button{min-height:44px;min-width:44px;padding:8px 16px}input,select,textarea{border-radius:8px;font-size:16px;max-width:100%;min-height:44px;padding:12px 16px;width:100%}img{height:auto;max-width:100%}table{border-collapse:collapse;display:block;overflow-x:auto;white-space:nowrap;width:100%}@media (min-width:768px){table{display:table;white-space:normal}}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f5f9}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}@keyframes slideIn{0%{transform:translateX(-100%)}to{transform:translateX(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-fade-in{animation:fadeIn .3s ease-out}.animate-slide-in{animation:slideIn .3s ease-out}.animate-pulse{animation:pulse 1s infinite}.priority-low{background-color:#f3f4f6;background-color:rgb(243 244 246/var(--tw-bg-opacity,1));color:#1f2937;color:rgb(31 41 55/var(--tw-text-opacity,1))}.priority-low,.priority-normal{--tw-bg-opacity:1;--tw-text-opacity:1}.priority-normal{background-color:#dbeafe;background-color:rgb(219 234 254/var(--tw-bg-opacity,1));color:#1e40af;color:rgb(30 64 175/var(--tw-text-opacity,1))}.priority-high{background-color:#fef9c3;background-color:rgb(254 249 195/var(--tw-bg-opacity,1));color:#854d0e;color:rgb(133 77 14/var(--tw-text-opacity,1))}.priority-high,.priority-urgent{--tw-bg-opacity:1;--tw-text-opacity:1}.priority-urgent{background-color:#fee2e2;background-color:rgb(254 226 226/var(--tw-bg-opacity,1));color:#991b1b;color:rgb(153 27 27/var(--tw-text-opacity,1))}.status-draft{background-color:#f3f4f6;background-color:rgb(243 244 246/var(--tw-bg-opacity,1));color:#1f2937;color:rgb(31 41 55/var(--tw-text-opacity,1))}.status-draft,.status-submitted{--tw-bg-opacity:1;--tw-text-opacity:1}.status-submitted{background-color:#dbeafe;background-color:rgb(219 234 254/var(--tw-bg-opacity,1));color:#1e40af;color:rgb(30 64 175/var(--tw-text-opacity,1))}.status-graded{background-color:#dcfce7;background-color:rgb(220 252 231/var(--tw-bg-opacity,1));color:#166534;color:rgb(22 101 52/var(--tw-text-opacity,1))}.status-graded,.status-returned{--tw-bg-opacity:1;--tw-text-opacity:1}.status-returned{background-color:#fef9c3;background-color:rgb(254 249 195/var(--tw-bg-opacity,1));color:#854d0e;color:rgb(133 77 14/var(--tw-text-opacity,1))}[data-theme=dark]{.card-harmony{background:#f5f5f5;background:var(--harmony-gray-100);border-color:#e0e0e0;border-color:var(--harmony-gray-300);color:#616161;color:var(--harmony-gray-700)}.card-harmony:hover{background:#eee;background:var(--harmony-gray-200);border-color:#bdbdbd;border-color:var(--harmony-gray-400)}.nav-item-harmony:hover{background:linear-gradient(135deg,#4c5af71a,#ff40810d)}.btn-harmony-primary{background:linear-gradient(135deg,#1a237e,#303f9f);background:var(--harmony-gradient-primary);box-shadow:0 10px 25px -3px #1a237e40;box-shadow:var(--harmony-shadow-brand)}.btn-harmony-secondary{background:linear-gradient(135deg,#e91e63,#f48fb1);background:var(--harmony-gradient-secondary);box-shadow:0 10px 25px -3px #e91e6340;box-shadow:var(--harmony-shadow-pink)}.announcement-card{background:#f5f5f5!important;background:var(--harmony-gray-100)!important;border-color:#e0e0e0!important;border-color:var(--harmony-gray-300)!important;color:#616161!important;color:var(--harmony-gray-700)!important}.announcement-title{color:#424242!important;color:var(--harmony-gray-800)!important}.announcement-content{color:#757575!important;color:var(--harmony-gray-600)!important}.priority-low{background:#eee!important;background:var(--harmony-gray-200)!important;color:#616161!important;color:var(--harmony-gray-700)!important}.priority-normal{background:#4c5af733!important;color:#a5b4fc!important}.priority-high{background:#ffd70033!important;color:#fde047!important}.priority-urgent{background:#ff408133!important;color:#fca5a5!important}.status-draft{background:#eee!important;background:var(--harmony-gray-200)!important;color:#616161!important;color:var(--harmony-gray-700)!important}.status-submitted{background:#4c5af733!important;color:#a5b4fc!important}.status-graded{background:#22c55e33!important;color:#86efac!important}.status-returned{background:#ffd70033!important;color:#fde047!important}input,select,textarea{background-color:#eee!important;background-color:var(--harmony-gray-200)!important;border-color:#e0e0e0!important;border-color:var(--harmony-gray-300)!important;color:#616161!important;color:var(--harmony-gray-700)!important}input:focus,select:focus,textarea:focus{background-color:#f5f5f5!important;background-color:var(--harmony-gray-100)!important;border-color:#1a237e!important;border-color:var(--harmony-primary)!important}input::placeholder,textarea::placeholder{color:#9e9e9e!important;color:var(--harmony-gray-500)!important}table{background-color:#f5f5f5!important;background-color:var(--harmony-gray-100)!important}th{background-color:#eee!important;background-color:var(--harmony-gray-200)!important;border-color:#e0e0e0!important;border-color:var(--harmony-gray-300)!important;color:#616161!important;color:var(--harmony-gray-700)!important}td{color:#757575!important;color:var(--harmony-gray-600)!important}.modal-content,td{background-color:#f5f5f5!important;background-color:var(--harmony-gray-100)!important;border-color:#e0e0e0!important;border-color:var(--harmony-gray-300)!important}.modal-content{color:#616161!important;color:var(--harmony-gray-700)!important}.sidebar{background-color:#fafafa!important;background-color:var(--harmony-gray-50)!important;border-color:#e0e0e0!important;border-color:var(--harmony-gray-300)!important}.fixed-footer-mobile{background:linear-gradient(135deg,#1a237e,#303f9f)!important;background:var(--harmony-gradient-primary)!important}}.file\:mr-4::-webkit-file-upload-button{margin-right:1rem}.file\:mr-4::file-selector-button{margin-right:1rem}.file\:rounded-md::-webkit-file-upload-button{border-radius:.375rem}.file\:rounded-md::file-selector-button{border-radius:.375rem}.file\:border-0::-webkit-file-upload-button{border-width:0}.file\:border-0::file-selector-button{border-width:0}.file\:bg-blue-50::-webkit-file-upload-button{--tw-bg-opacity:1;background-color:#eff6ff;background-color:rgb(239 246 255/var(--tw-bg-opacity,1))}.file\:bg-blue-50::file-selector-button{--tw-bg-opacity:1;background-color:#eff6ff;background-color:rgb(239 246 255/var(--tw-bg-opacity,1))}.file\:px-4::-webkit-file-upload-button{padding-left:1rem;padding-right:1rem}.file\:px-4::file-selector-button{padding-left:1rem;padding-right:1rem}.file\:py-2::-webkit-file-upload-button{padding-bottom:.5rem;padding-top:.5rem}.file\:py-2::file-selector-button{padding-bottom:.5rem;padding-top:.5rem}.file\:text-sm::-webkit-file-upload-button{font-size:.875rem;line-height:1.25rem}.file\:text-sm::file-selector-button{font-size:.875rem;line-height:1.25rem}.file\:font-medium::-webkit-file-upload-button{font-weight:500}.file\:font-medium::file-selector-button{font-weight:500}.file\:text-blue-700::-webkit-file-upload-button{--tw-text-opacity:1;color:#1d4ed8;color:rgb(29 78 216/var(--tw-text-opacity,1))}.file\:text-blue-700::file-selector-button{--tw-text-opacity:1;color:#1d4ed8;color:rgb(29 78 216/var(--tw-text-opacity,1))}.focus-within\:outline-none:focus-within{outline:2px solid #0000;outline-offset:2px}.focus-within\:ring-2:focus-within{--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-within\:ring-blue-500:focus-within{--tw-ring-opacity:1;--tw-ring-color:rgb(59 130 246/var(--tw-ring-opacity,1))}.focus-within\:ring-offset-2:focus-within{--tw-ring-offset-width:2px}.hover\:scale-105:hover{--tw-scale-x:1.05;--tw-scale-y:1.05;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\:border-gray-300:hover{--tw-border-opacity:1;border-color:#d1d5db;border-color:rgb(209 213 219/var(--tw-border-opacity,1))}.hover\:border-red-300:hover{--tw-border-opacity:1;border-color:#fca5a5;border-color:rgb(252 165 165/var(--tw-border-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:hover{--tw-bg-opacity:1;background-color:#eff6ff;background-color:rgb(239 246 255/var(--tw-bg-opacity,1))}.hover\:bg-blue-600:hover{--tw-bg-opacity:1;background-color:#2563eb;background-color:rgb(37 99 235/var(--tw-bg-opacity,1))}.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-300:hover{--tw-bg-opacity:1;background-color:#d1d5db;background-color:rgb(209 213 219/var(--tw-bg-opacity,1))}.hover\:bg-gray-400:hover{--tw-bg-opacity:1;background-color:#9ca3af;background-color:rgb(156 163 175/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-gray-600:hover{--tw-bg-opacity:1;background-color:#4b5563;background-color:rgb(75 85 99/var(--tw-bg-opacity,1))}.hover\:bg-gray-700:hover{--tw-bg-opacity:1;background-color:#374151;background-color:rgb(55 65 81/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-green-600:hover{--tw-bg-opacity:1;background-color:#16a34a;background-color:rgb(22 163 74/var(--tw-bg-opacity,1))}.hover\:bg-green-700:hover{--tw-bg-opacity:1;background-color:#15803d;background-color:rgb(21 128 61/var(--tw-bg-opacity,1))}.hover\:bg-pink-600:hover{--tw-bg-opacity:1;background-color:#db2777;background-color:rgb(219 39 119/var(--tw-bg-opacity,1))}.hover\:bg-pink-700:hover{--tw-bg-opacity:1;background-color:#be185d;background-color:rgb(190 24 93/var(--tw-bg-opacity,1))}.hover\:bg-purple-700:hover{--tw-bg-opacity:1;background-color:#7e22ce;background-color:rgb(126 34 206/var(--tw-bg-opacity,1))}.hover\:bg-red-200:hover{--tw-bg-opacity:1;background-color:#fecaca;background-color:rgb(254 202 202/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-red-700:hover{--tw-bg-opacity:1;background-color:#b91c1c;background-color:rgb(185 28 28/var(--tw-bg-opacity,1))}.hover\:bg-yellow-300:hover{--tw-bg-opacity:1;background-color:#fde047;background-color:rgb(253 224 71/var(--tw-bg-opacity,1))}.hover\:bg-yellow-50:hover{--tw-bg-opacity:1;background-color:#fefce8;background-color:rgb(254 252 232/var(--tw-bg-opacity,1))}.hover\:bg-opacity-50:hover{--tw-bg-opacity:0.5}.hover\:bg-opacity-90:hover{--tw-bg-opacity:0.9}.hover\:from-blue-700:hover{--tw-gradient-from:#1d4ed8 var(--tw-gradient-from-position);--tw-gradient-to:#1d4ed800 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.hover\:to-blue-800:hover{--tw-gradient-to:#1e40af var(--tw-gradient-to-position)}.hover\:text-blue-500:hover{--tw-text-opacity:1;color:#3b82f6;color:rgb(59 130 246/var(--tw-text-opacity,1))}.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-blue-900:hover{--tw-text-opacity:1;color:#1e3a8a;color:rgb(30 58 138/var(--tw-text-opacity,1))}.hover\:text-gray-200:hover{--tw-text-opacity:1;color:#e5e7eb;color:rgb(229 231 235/var(--tw-text-opacity,1))}.hover\:text-gray-500:hover{--tw-text-opacity:1;color:#6b7280;color:rgb(107 114 128/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-gray-700:hover{--tw-text-opacity:1;color:#374151;color:rgb(55 65 81/var(--tw-text-opacity,1))}.hover\:text-gray-900:hover{--tw-text-opacity:1;color:#111827;color:rgb(17 24 39/var(--tw-text-opacity,1))}.hover\:text-green-700:hover{--tw-text-opacity:1;color:#15803d;color:rgb(21 128 61/var(--tw-text-opacity,1))}.hover\:text-green-900:hover{--tw-text-opacity:1;color:#14532d;color:rgb(20 83 45/var(--tw-text-opacity,1))}.hover\:text-pink-700:hover{--tw-text-opacity:1;color:#be185d;color:rgb(190 24 93/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-red-700:hover{--tw-text-opacity:1;color:#b91c1c;color:rgb(185 28 28/var(--tw-text-opacity,1))}.hover\:text-red-800:hover{--tw-text-opacity:1;color:#991b1b;color:rgb(153 27 27/var(--tw-text-opacity,1))}.hover\:text-red-900:hover{--tw-text-opacity:1;color:#7f1d1d;color:rgb(127 29 29/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\:underline:hover{-webkit-text-decoration-line:underline;text-decoration-line:underline}.hover\:shadow-lg:hover{--tw-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--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 #0000001a,0 2px 4px -2px #0000001a;--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color)}.hover\:shadow-xl:hover{--tw-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color);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\:file\:bg-blue-100::-webkit-file-upload-button:hover{--tw-bg-opacity:1;background-color:#dbeafe;background-color:rgb(219 234 254/var(--tw-bg-opacity,1))}.hover\:file\:bg-blue-100::file-selector-button:hover{--tw-bg-opacity:1;background-color:#dbeafe;background-color:rgb(219 234 254/var(--tw-bg-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-pink-500:focus{--tw-border-opacity:1;border-color:#ec4899;border-color:rgb(236 72 153/var(--tw-border-opacity,1))}.focus\:border-transparent:focus{border-color:#0000}.focus\:outline-none:focus{outline:2px solid #0000;outline-offset:2px}.focus\:ring-1: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(1px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.focus\:ring-1:focus,.focus\:ring-2:focus{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-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)}.focus\:ring-inset:focus{--tw-ring-inset:inset}.focus\:ring-blue-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(59 130 246/var(--tw-ring-opacity,1))}.focus\:ring-gray-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(107 114 128/var(--tw-ring-opacity,1))}.focus\:ring-green-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(34 197 94/var(--tw-ring-opacity,1))}.focus\:ring-pink-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(236 72 153/var(--tw-ring-opacity,1))}.focus\:ring-red-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(239 68 68/var(--tw-ring-opacity,1))}.focus\:ring-white:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(255 255 255/var(--tw-ring-opacity,1))}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px}.active\:scale-95:active{--tw-scale-x:.95;--tw-scale-y:.95;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))}.active\:bg-gray-100:active{--tw-bg-opacity:1;background-color:#f3f4f6;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}.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\:bg-gray-50:disabled{--tw-bg-opacity:1;background-color:#f9fafb;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.disabled\:text-gray-500:disabled{--tw-text-opacity:1;color:#6b7280;color:rgb(107 114 128/var(--tw-text-opacity,1))}.disabled\:opacity-50:disabled{opacity:.5}@media (min-width:640px){.sm\:mx-auto{margin-left:auto;margin-right:auto}.sm\:block{display:block}.sm\:hidden{display:none}.sm\:w-auto{width:auto}.sm\:w-full{width:100%}.sm\:max-w-md{max-width:28rem}.sm\:flex-initial{flex:0 1 auto}.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\:flex-row{flex-direction:row}.sm\:items-center{align-items:center}.sm\:space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(1rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(1rem*var(--tw-space-x-reverse))}.sm\: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)))}.sm\:rounded-lg{border-radius:.5rem}.sm\:px-10{padding-left:2.5rem;padding-right:2.5rem}.sm\:px-4{padding-left:1rem;padding-right:1rem}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}.sm\:py-6{padding-bottom:1.5rem;padding-top:1.5rem}.sm\:pl-4{padding-left:1rem}.sm\:pt-4{padding-top:1rem}}@media (min-width:768px){.md\:col-span-2{grid-column:span 2/span 2}.md\:col-span-3{grid-column:span 3/span 3}.md\:flex{display:flex}.md\:hidden{display:none}.md\:flex-shrink-0{flex-shrink:0}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}}@media (min-width:1024px){.lg\:col-span-2{grid-column:span 2/span 2}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:px-8{padding-left:2rem;padding-right:2rem}}@media (prefers-color-scheme:dark){.dark\:bg-gray-900{--tw-bg-opacity:1;background-color:#111827;background-color:rgb(17 24 39/var(--tw-bg-opacity,1))}.dark\:text-gray-300{--tw-text-opacity:1;color:#d1d5db;color:rgb(209 213 219/var(--tw-text-opacity,1))}.dark\:text-white{--tw-text-opacity:1;color:#fff;color:rgb(255 255 255/var(--tw-text-opacity,1))}}.rbc-btn{color:inherit;font:inherit;margin:0}button.rbc-btn{-webkit-appearance:button;appearance:button;cursor:pointer;overflow:visible;text-transform:none}button[disabled].rbc-btn{cursor:not-allowed}button.rbc-input::-moz-focus-inner{border:0;padding:0}.rbc-calendar{align-items:stretch;box-sizing:border-box;display:flex;flex-direction:column;height:100%}.rbc-m-b-negative-3{margin-bottom:-3px}.rbc-h-full{height:100%}.rbc-calendar *,.rbc-calendar :after,.rbc-calendar :before{box-sizing:inherit}.rbc-abs-full,.rbc-row-bg{bottom:0;left:0;overflow:hidden;position:absolute;right:0;top:0}.rbc-ellipsis,.rbc-event-label,.rbc-row-segment .rbc-event-content,.rbc-show-more{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rbc-rtl{direction:rtl}.rbc-off-range{color:#999}.rbc-off-range-bg{background:#e6e6e6}.rbc-header{border-bottom:1px solid #ddd;flex:1 0;font-size:90%;font-weight:700;min-height:0;overflow:hidden;padding:0 3px;text-align:center;text-overflow:ellipsis;vertical-align:middle;white-space:nowrap}.rbc-header+.rbc-header{border-left:1px solid #ddd}.rbc-rtl .rbc-header+.rbc-header{border-left-width:0;border-right:1px solid #ddd}.rbc-header>a,.rbc-header>a:active,.rbc-header>a:visited{color:inherit;text-decoration:none}.rbc-button-link{background:none;border:none;color:inherit;cursor:pointer;margin:0;padding:0;-webkit-user-select:text;user-select:text}.rbc-row-content{position:relative;user-select:none;-webkit-user-select:none;z-index:4}.rbc-row-content-scrollable{display:flex;flex-direction:column;height:100%}.rbc-row-content-scrollable .rbc-row-content-scroll-container{-ms-overflow-style:none;height:100%;overflow-y:scroll;scrollbar-width:none}.rbc-row-content-scrollable .rbc-row-content-scroll-container::-webkit-scrollbar{display:none}.rbc-today{background-color:#eaf6ff}.rbc-toolbar{align-items:center;display:flex;flex-wrap:wrap;font-size:16px;justify-content:center;margin-bottom:10px}.rbc-toolbar .rbc-toolbar-label{flex-grow:1;padding:0 10px;text-align:center}.rbc-toolbar button{background:none;background-image:none;border:1px solid #ccc;border-radius:4px;color:#373a3c;display:inline-block;line-height:normal;margin:0;padding:.375rem 1rem;text-align:center;vertical-align:middle;white-space:nowrap}.rbc-toolbar button.rbc-active,.rbc-toolbar button:active{background-color:#e6e6e6;background-image:none;border-color:#adadad;box-shadow:inset 0 3px 5px rgba(0,0,0,.125)}.rbc-toolbar button.rbc-active:focus,.rbc-toolbar button.rbc-active:hover,.rbc-toolbar button:active:focus,.rbc-toolbar button:active:hover{background-color:#d4d4d4;border-color:#8c8c8c;color:#373a3c}.rbc-toolbar button:focus,.rbc-toolbar button:hover{background-color:#e6e6e6;border-color:#adadad;color:#373a3c}.rbc-toolbar button:hover{cursor:pointer}.rbc-btn-group{display:inline-block;white-space:nowrap}.rbc-btn-group>button:first-child:not(:last-child){border-bottom-right-radius:0;border-top-right-radius:0}.rbc-btn-group>button:last-child:not(:first-child){border-bottom-left-radius:0;border-top-left-radius:0}.rbc-rtl .rbc-btn-group>button:first-child:not(:last-child){border-radius:4px;border-bottom-left-radius:0;border-top-left-radius:0}.rbc-rtl .rbc-btn-group>button:last-child:not(:first-child){border-radius:4px;border-bottom-right-radius:0;border-top-right-radius:0}.rbc-btn-group>button:not(:first-child):not(:last-child){border-radius:0}.rbc-btn-group button+button{margin-left:-1px}.rbc-rtl .rbc-btn-group button+button{margin-left:0;margin-right:-1px}.rbc-btn-group+.rbc-btn-group,.rbc-btn-group+button{margin-left:10px}@media (max-width:767px){.rbc-toolbar{flex-direction:column}}.rbc-day-slot .rbc-background-event,.rbc-event{background-color:#3174ad;border:none;border-radius:5px;box-shadow:none;box-sizing:border-box;color:#fff;cursor:pointer;margin:0;padding:2px 5px;text-align:left;width:100%}.rbc-day-slot .rbc-slot-selecting .rbc-background-event,.rbc-slot-selecting .rbc-day-slot .rbc-background-event,.rbc-slot-selecting .rbc-event{cursor:inherit;pointer-events:none}.rbc-day-slot .rbc-selected.rbc-background-event,.rbc-event.rbc-selected{background-color:#265985}.rbc-day-slot .rbc-background-event:focus,.rbc-event:focus{outline:5px auto #3b99fc}.rbc-event-label{font-size:80%}.rbc-event-overlaps{box-shadow:-1px 1px 5px 0 #33333380}.rbc-event-continues-prior{border-bottom-left-radius:0;border-top-left-radius:0}.rbc-event-continues-after{border-bottom-right-radius:0;border-top-right-radius:0}.rbc-event-continues-earlier{border-top-left-radius:0;border-top-right-radius:0}.rbc-event-continues-later{border-bottom-left-radius:0;border-bottom-right-radius:0}.rbc-row{display:flex;flex-direction:row}.rbc-row-segment{padding:0 1px 1px}.rbc-selected-cell{background-color:#0000001a}.rbc-show-more{background-color:#ffffff4d;color:#3174ad;font-size:85%;font-weight:700;height:auto;line-height:normal;z-index:4}.rbc-show-more:focus,.rbc-show-more:hover{color:#265985}.rbc-month-view{border:1px solid #ddd;display:flex;flex:1 0;flex-direction:column;height:100%;position:relative;user-select:none;-webkit-user-select:none;width:100%}.rbc-month-header{display:flex;flex-direction:row}.rbc-month-row{display:flex;flex:1 0;flex-basis:0px;flex-direction:column;height:100%;overflow:hidden;position:relative}.rbc-month-row+.rbc-month-row{border-top:1px solid #ddd}.rbc-date-cell{flex:1 1;min-width:0;padding-right:5px}.rbc-date-cell.rbc-now{font-weight:700}.rbc-date-cell>a,.rbc-date-cell>a:active,.rbc-date-cell>a:visited{color:inherit;text-decoration:none}.rbc-row-bg{display:flex;flex:1 0;flex-direction:row;overflow:hidden;right:1px}.rbc-day-bg{flex:1 0}.rbc-day-bg+.rbc-day-bg{border-left:1px solid #ddd}.rbc-rtl .rbc-day-bg+.rbc-day-bg{border-left-width:0;border-right:1px solid #ddd}.rbc-overlay{background-color:#fff;border:1px solid #e5e5e5;box-shadow:0 5px 15px #00000040;padding:10px;position:absolute;z-index:5}.rbc-overlay>*+*{margin-top:1px}.rbc-overlay-header{border-bottom:1px solid #e5e5e5;margin:-10px -10px 5px;padding:2px 10px}.rbc-agenda-view{display:flex;flex:1 0;flex-direction:column;overflow:auto}.rbc-agenda-view table.rbc-agenda-table{border:1px solid #ddd;border-collapse:collapse;border-spacing:0;width:100%}.rbc-agenda-view table.rbc-agenda-table tbody>tr>td{padding:5px 10px;vertical-align:top}.rbc-agenda-view table.rbc-agenda-table .rbc-agenda-time-cell{padding-left:15px;padding-right:15px;text-transform:lowercase}.rbc-agenda-view table.rbc-agenda-table tbody>tr>td+td{border-left:1px solid #ddd}.rbc-rtl .rbc-agenda-view table.rbc-agenda-table tbody>tr>td+td{border-left-width:0;border-right:1px solid #ddd}.rbc-agenda-view table.rbc-agenda-table tbody>tr+tr{border-top:1px solid #ddd}.rbc-agenda-view table.rbc-agenda-table thead>tr>th{border-bottom:1px solid #ddd;padding:3px 5px;text-align:left}.rbc-rtl .rbc-agenda-view table.rbc-agenda-table thead>tr>th{text-align:right}.rbc-agenda-time-cell{text-transform:lowercase}.rbc-agenda-time-cell .rbc-continues-after:after{content:" »"}.rbc-agenda-time-cell .rbc-continues-prior:before{content:"« "}.rbc-agenda-date-cell,.rbc-agenda-time-cell{white-space:nowrap}.rbc-agenda-event-cell{width:100%}.rbc-time-column{display:flex;flex-direction:column;min-height:100%}.rbc-time-column .rbc-timeslot-group{flex:1 1}.rbc-timeslot-group{border-bottom:1px solid #ddd;display:flex;flex-flow:column nowrap;min-height:40px}.rbc-header-gutter,.rbc-time-gutter{flex:none}.rbc-label{padding:0 5px}.rbc-day-slot{position:relative}.rbc-day-slot .rbc-events-container{bottom:0;left:0;margin-right:10px;position:absolute;right:0;top:0}.rbc-day-slot .rbc-events-container.rbc-rtl{left:10px;right:0}.rbc-day-slot .rbc-background-event,.rbc-day-slot .rbc-event{align-items:flex-start;border:1px solid #265985;display:flex;flex-flow:column wrap;max-height:100%;min-height:20px;overflow:hidden;position:absolute}.rbc-day-slot .rbc-background-event{opacity:.75}.rbc-day-slot .rbc-event-label{flex:none;padding-right:5px;width:auto}.rbc-day-slot .rbc-event-content{word-wrap:break-word;flex:1 1;height:100%;line-height:1;min-height:1em;width:100%}.rbc-day-slot .rbc-time-slot{border-top:1px solid #f7f7f7}.rbc-time-view-resources .rbc-time-gutter,.rbc-time-view-resources .rbc-time-header-gutter{background-color:#fff;border-right:1px solid #ddd;left:0;margin-right:-1px;position:-webkit-sticky;position:sticky;z-index:10}.rbc-time-view-resources .rbc-time-header{overflow:hidden}.rbc-time-view-resources .rbc-time-header-content{flex:1 0;flex-basis:0px;min-width:auto}.rbc-time-view-resources .rbc-time-header-cell-single-day{display:none}.rbc-time-view-resources .rbc-day-slot{min-width:140px}.rbc-time-view-resources .rbc-day-bg,.rbc-time-view-resources .rbc-header{flex:1 1;flex-basis:0 px;width:140px}.rbc-time-header-content+.rbc-time-header-content{margin-left:-1px}.rbc-time-slot{flex:1 0}.rbc-time-slot.rbc-now{font-weight:700}.rbc-day-header{text-align:center}.rbc-slot-selection{background-color:#00000080;color:#fff;font-size:75%;padding:3px;position:absolute;width:100%;z-index:10}.rbc-slot-selecting{cursor:move}.rbc-time-view{border:1px solid #ddd;display:flex;flex:1 1;flex-direction:column;min-height:0;width:100%}.rbc-time-view .rbc-time-gutter{text-align:right;white-space:nowrap}.rbc-time-view .rbc-allday-cell{box-sizing:initial;height:100%;position:relative;width:100%}.rbc-time-view .rbc-allday-cell+.rbc-allday-cell{border-left:1px solid #ddd}.rbc-time-view .rbc-allday-events{position:relative;z-index:4}.rbc-time-view .rbc-row{box-sizing:border-box;min-height:20px}.rbc-time-header{display:flex;flex:0 0 auto;flex-direction:row}.rbc-time-header.rbc-overflowing{border-right:1px solid #ddd}.rbc-rtl .rbc-time-header.rbc-overflowing{border-left:1px solid #ddd;border-right-width:0}.rbc-time-header>.rbc-row.rbc-row-resource,.rbc-time-header>.rbc-row:first-child{border-bottom:1px solid #ddd}.rbc-time-header-cell-single-day{display:none}.rbc-time-header-content{border-left:1px solid #ddd;display:flex;flex:1 1;flex-direction:column;min-width:0}.rbc-rtl .rbc-time-header-content{border-left-width:0;border-right:1px solid #ddd}.rbc-time-header-content>.rbc-row.rbc-row-resource{border-bottom:1px solid #ddd;flex-shrink:0}.rbc-time-content{align-items:flex-start;border-top:2px solid #ddd;display:flex;flex:1 0;overflow-y:auto;position:relative;width:100%}.rbc-time-content>.rbc-time-gutter{flex:none}.rbc-time-content>*+*>*{border-left:1px solid #ddd}.rbc-rtl .rbc-time-content>*+*>*{border-left-width:0;border-right:1px solid #ddd}.rbc-time-content>.rbc-day-slot{user-select:none;-webkit-user-select:none;width:100%}.rbc-current-time-indicator{background-color:#74ad31;height:1px;left:0;pointer-events:none;position:absolute;right:0;z-index:3}.rbc-resource-grouping.rbc-time-header-content{display:flex;flex-direction:column}.rbc-resource-grouping .rbc-row .rbc-header{width:141px}.calendar-container{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;min-height:100vh;padding:24px}.calendar-header{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;margin-bottom:24px;overflow:hidden}.header-content{justify-content:space-between;padding:32px}.header-content,.header-title{align-items:center;display:flex}.header-title{gap:16px}.header-icon{color:#3b82f6;height:32px;width:32px}.header-title h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;background-clip:text;color:#1f2937;font-size:2.5rem;font-weight:700;margin:0}.create-event-btn{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border:none;border-radius:12px;box-shadow:0 4px 15px #3b82f64d;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease}.create-event-btn:hover{box-shadow:0 6px 20px #3b82f666;transform:translateY(-2px)}.btn-icon{height:20px;width:20px}.error-banner{align-items:center;background:#fee2e2;border:1px solid #fecaca;border-radius:12px;color:#dc2626;display:flex;gap:12px;margin-bottom:24px;padding:16px 24px}.error-icon{flex-shrink:0;height:20px;width:20px}.error-close{background:none;border:none;border-radius:4px;color:#dc2626;cursor:pointer;margin-left:auto;padding:4px}.close-icon{height:16px;width:16px}.calendar-legend{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;display:flex;flex-wrap:wrap;gap:24px;margin-bottom:24px;padding:20px 24px}.legend-item{align-items:center;background:#f8fafc;border-radius:8px;color:#374151;display:flex;font-size:14px;font-weight:500;gap:8px;padding:8px 16px}.legend-color{border-radius:50%;flex-shrink:0;height:12px;width:12px}.calendar-wrapper{background:#fff;overflow:hidden;padding:24px}.calendar-wrapper,.loading-spinner{border-radius:16px;box-shadow:0 4px 20px #00000014}.loading-spinner{height:400px}.spinner{border-top-color:#3b82f6;margin-bottom:16px}.loading-spinner p{color:#6b7280;font-size:16px;margin:0}.calendar-event{border-radius:4px;display:flex;flex-direction:column;font-size:12px;line-height:1.2;padding:2px 4px}.event-title{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.event-time{font-size:10px;opacity:.8}.rbc-calendar{background:#0000;border:none;font-family:inherit}.rbc-header{font-size:14px;padding:16px 8px}.rbc-month-view{border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}.rbc-date-cell{color:#6b7280;font-size:14px;text-align:right}.rbc-date-cell.rbc-off-range{color:#d1d5db}.rbc-date-cell.rbc-now{background:#dbeafe;color:#1e40af;font-weight:600}.rbc-day-bg{background:#fefefe;border-bottom:1px solid #f3f4f6;border-right:1px solid #f3f4f6}.rbc-day-bg.rbc-today{background:#f0f9ff}.rbc-event{background:#3b82f6;border-radius:6px;box-shadow:0 1px 3px #0000001a;font-size:12px}.rbc-event.rbc-selected{background:#1e40af;box-shadow:0 2px 8px #1e40af4d}.rbc-toolbar{background:#f8fafc;border-radius:12px;margin-bottom:24px;padding:16px 24px}.rbc-toolbar button{background:#fff;border:1px solid #e5e7eb;border-radius:8px;font-weight:500;transition:all .2s ease}.rbc-toolbar button:hover{background:#f3f4f6;border-color:#d1d5db}.rbc-toolbar button.rbc-active{background:#3b82f6;border-color:#3b82f6}.rbc-toolbar-label{color:#1f2937;font-size:18px}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:16px;box-shadow:0 10px 40px #00000026;max-height:90vh;max-width:500px;overflow-y:auto;width:90%}.modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:24px}.modal-header h3{color:#1f2937;font-size:20px;font-weight:600;margin:0}.close-btn{background:none;border:none;border-radius:4px;color:#6b7280;cursor:pointer;font-size:24px;padding:4px;transition:all .2s ease}.close-btn:hover{background:#f3f4f6;color:#374151}.modal-body{padding:24px}.event-details{padding:16px 0}.event-details h4{color:#1f2937;font-size:18px;font-weight:600;margin:0 0 16px}.event-details p{color:#6b7280;line-height:1.5;margin:8px 0}.event-details strong{color:#374151}.form-group{margin-bottom:20px}.form-group label{color:#374151;display:block;font-weight:500;margin-bottom:8px}.form-group input,.form-group select,.form-group textarea{border:1px solid #d1d5db;border-radius:8px;font-size:16px;padding:12px 16px;transition:border-color .2s ease;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.form-actions{border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:24px}.form-actions button{border-radius:8px;cursor:pointer;font-weight:500;padding:12px 24px;transition:all .2s ease}.form-actions button[type=button]{background:#f3f4f6;border:1px solid #d1d5db;color:#374151}.form-actions button[type=button]:hover{background:#e5e7eb}.form-actions button[type=submit]{background:#3b82f6;border:1px solid #3b82f6;color:#fff}.form-actions button[type=submit]:hover{background:#2563eb}.rbc-calendar{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.rbc-header{background:#f8fafc;border-bottom:1px solid #e5e7eb;color:#374151;font-weight:600;padding:15px 10px}.rbc-month-view{border:none}.rbc-date-cell{padding:8px}.rbc-date-cell.rbc-off-range-bg{background:#f9fafb}.rbc-today{background:#dbeafe}.rbc-event{border:none;border-radius:4px;font-size:.85rem;font-weight:500;padding:2px 6px}.rbc-event:hover{opacity:.8}.rbc-show-more{background:#e5e7eb;border-radius:4px;color:#374151;font-size:.8rem;margin:2px;padding:2px 6px}.rbc-toolbar{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;padding:15px 20px}.rbc-toolbar button{background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;margin:0 2px;padding:8px 16px;transition:all .2s}.rbc-toolbar button:hover{background:#e5e7eb}.rbc-toolbar button.rbc-active{background:#1e3a8a;border-color:#1e3a8a;color:#fff}.rbc-toolbar-label{color:#1e3a8a;font-size:1.2rem;font-weight:600}@media (max-width:768px){.calendar-container{padding:16px}.header-content{flex-direction:column;gap:16px;text-align:center}.header-title h1{font-size:2rem}.calendar-legend{flex-direction:column;gap:12px}.form-row{grid-template-columns:1fr}.form-actions,.rbc-toolbar{flex-direction:column}.rbc-toolbar{gap:12px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.calendar-header,.calendar-legend,.calendar-wrapper{animation:fadeIn .5s ease-out}[data-theme=dark]{.calendar-container{background:linear-gradient(135deg,var(--harmony-gray-50) 0,var(--harmony-gray-100) 100%)}.calendar-header{background-color:var(--harmony-gray-100);border-color:var(--harmony-gray-300)}.header-title h1{-webkit-text-fill-color:#0000;background:var(--harmony-gradient-primary);-webkit-background-clip:text;background-clip:text;color:var(--harmony-gray-800)}.create-event-btn{background:var(--harmony-gradient-primary);box-shadow:var(--harmony-shadow-brand)}.create-event-btn:hover{box-shadow:0 6px 20px #4c5af766}.error-banner{background-color:#ef44441a;border-color:#ef44444d;color:#fca5a5}.calendar-legend{background-color:var(--harmony-gray-100);border-color:var(--harmony-gray-300)}.legend-item{background-color:var(--harmony-gray-200);color:var(--harmony-gray-700)}.calendar-wrapper,.loading-spinner{background-color:var(--harmony-gray-100);border-color:var(--harmony-gray-300)}.loading-spinner{color:var(--harmony-gray-700)}.loading-spinner p{color:var(--harmony-gray-600)}.rbc-calendar{background-color:var(--harmony-gray-100)}.rbc-header{background-color:var(--harmony-gray-200);color:var(--harmony-gray-700)}.rbc-header,.rbc-month-view{border-color:var(--harmony-gray-300)}.rbc-date-cell{background-color:var(--harmony-gray-100);color:var(--harmony-gray-600)}.rbc-date-cell.rbc-off-range{background-color:var(--harmony-gray-50);color:var(--harmony-gray-400)}.rbc-date-cell.rbc-now{background-color:#4c5af71a;color:var(--harmony-primary)}.rbc-day-bg{background-color:var(--harmony-gray-100);border-color:var(--harmony-gray-300)}.rbc-day-bg.rbc-today{background-color:#4c5af70d}.rbc-toolbar{background-color:var(--harmony-gray-200)}.rbc-toolbar,.rbc-toolbar button{border-color:var(--harmony-gray-300)}.rbc-toolbar button{background-color:var(--harmony-gray-100);color:var(--harmony-gray-700)}.rbc-toolbar button:hover{background-color:var(--harmony-gray-200);border-color:var(--harmony-gray-400)}.rbc-toolbar button.rbc-active{background-color:var(--harmony-primary);border-color:var(--harmony-primary);color:#fff}.rbc-toolbar-label{color:var(--harmony-gray-800)}.modal-overlay{background:#000c}.modal-content{background-color:var(--harmony-gray-100);color:var(--harmony-gray-700)}.modal-header{border-color:var(--harmony-gray-300)}.modal-header h3{color:var(--harmony-gray-800)}.close-btn{color:var(--harmony-gray-500)}.close-btn:hover{background-color:var(--harmony-gray-200);color:var(--harmony-gray-700)}.event-details h4{color:var(--harmony-gray-800)}.event-details p{color:var(--harmony-gray-600)}.event-details strong,.form-group label{color:var(--harmony-gray-700)}.form-group input,.form-group select,.form-group textarea{background-color:var(--harmony-gray-200);border-color:var(--harmony-gray-300);color:var(--harmony-gray-700)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{background-color:var(--harmony-gray-100);border-color:var(--harmony-primary);box-shadow:0 0 0 3px #4c5af71a}.form-actions,.form-actions button[type=button]{border-color:var(--harmony-gray-300)}.form-actions button[type=button]{background-color:var(--harmony-gray-200);color:var(--harmony-gray-700)}.form-actions button[type=button]:hover{background-color:var(--harmony-gray-300)}.form-actions button[type=submit]{background:var(--harmony-gradient-primary);border-color:var(--harmony-primary)}.form-actions button[type=submit]:hover{background:var(--harmony-gradient-primary);opacity:.9}}.analytics-container{background:#f8f9fa;min-height:100vh;padding:20px}.analytics-header{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;margin-bottom:30px;padding:20px}.analytics-header h2{color:#1e3a8a;font-size:1.8rem;font-weight:600;margin:0}.analytics-controls select{background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;font-size:.9rem;padding:8px 12px}.analytics-controls select:focus{border-color:#1e3a8a;box-shadow:0 0 0 3px #1e3a8a1a;outline:none}.loading-spinner{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;height:300px;justify-content:center}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f4f6;border-radius:50%;border-top-color:#1e3a8a;height:40px;margin-bottom:10px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.error-message{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:40px;text-align:center}.error-message h3{color:#dc2626;margin-bottom:10px}.error-message button{background:#1e3a8a;border:none;border-radius:6px;color:#fff;cursor:pointer;margin-top:15px;padding:10px 20px}.error-message button:hover{background:#1e40af}.alert{align-items:center;border-radius:6px;display:flex;justify-content:space-between;margin-bottom:20px;padding:12px 16px}.alert-danger{background-color:#fee2e2;border:1px solid #fecaca;color:#dc2626}.alert button{background:none;border:none;cursor:pointer;font-size:1.2rem;margin-left:10px;padding:0}.analytics-content{display:flex;flex-direction:column;gap:30px}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.stat-card{background:#fff;border-left:4px solid #1e3a8a;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:25px;text-align:center}.stat-value{color:#1e3a8a;font-size:2.5rem;font-weight:700;margin-bottom:8px}.stat-label{color:#6b7280;font-size:.9rem;letter-spacing:.5px;text-transform:uppercase}.charts-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr))}.chart-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:25px}.chart-container h3{color:#1e3a8a;font-size:1.2rem;font-weight:600;margin:0 0 20px}.task-list{max-height:300px;overflow-y:auto}.task-item{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:15px}.task-item:last-child{border-bottom:none}.task-title{color:#374151;font-weight:500;margin-bottom:5px}.task-info{align-items:center;display:flex;gap:15px}.task-type{background:#dbeafe;border-radius:4px;color:#1e3a8a;font-size:.8rem;padding:4px 8px;text-transform:uppercase}.task-score{color:#059669;font-weight:600}.class-stats{background:#f8fafc;border-radius:6px;display:flex;flex-direction:column;gap:15px;padding:20px}.stat-item{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:10px 0}.stat-item:last-child{border-bottom:none}.stat-item strong{color:#374151}.additional-stats{margin-top:30px}.stat-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:25px}.stat-section h3{color:#1e3a8a;font-size:1.2rem;font-weight:600;margin:0 0 20px}.performance-stats{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.perf-item{align-items:center;background:#f8fafc;border-left:3px solid #1e3a8a;border-radius:6px;display:flex;justify-content:space-between;padding:15px}.perf-item strong{color:#374151}@media (max-width:768px){.analytics-container{padding:15px}.analytics-header{flex-direction:column;gap:15px;text-align:center}.charts-grid,.stats-grid{grid-template-columns:1fr}.chart-container{padding:20px}.performance-stats{grid-template-columns:1fr}.task-item{align-items:flex-start;flex-direction:column;gap:10px}.task-info{justify-content:space-between;width:100%}}@media (max-width:480px){.analytics-header h2{font-size:1.5rem}.stat-value{font-size:2rem}.chart-container{padding:15px}.stat-card{padding:20px}}[data-theme=dark]{.analytics-container{background-color:var(--harmony-gray-50);color:var(--harmony-gray-700)}.analytics-header{background-color:var(--harmony-gray-100);border-color:var(--harmony-gray-300)}.analytics-header h2{-webkit-text-fill-color:#0000;background:var(--harmony-gradient-primary);-webkit-background-clip:text;background-clip:text;color:var(--harmony-gray-800)}.stats-grid{gap:25px}.stat-card,.stat-item{background-color:var(--harmony-gray-100);border-color:var(--harmony-gray-300);color:var(--harmony-gray-700)}.stat-value{color:var(--harmony-primary)}.stat-label{color:var(--harmony-gray-500)}.chart-container{background-color:var(--harmony-gray-100);border-color:var(--harmony-gray-300)}.chart-container h3{color:var(--harmony-gray-800)}.task-item{background-color:var(--harmony-gray-100);border-color:var(--harmony-gray-300)}.task-item:hover{background-color:var(--harmony-gray-200)}.task-title{color:var(--harmony-gray-700)}.task-type{background-color:#4c5af733;color:#a5b4fc}.task-score{color:#86efac}.class-stats{border-color:var(--harmony-gray-300)}.class-stats,.perf-item{background-color:var(--harmony-gray-200)}.perf-item{border-color:var(--harmony-primary)}.perf-item strong{color:var(--harmony-gray-700)}.stat-section{background-color:var(--harmony-gray-100);border-color:var(--harmony-gray-300)}.stat-section h3{color:var(--harmony-gray-800)}.error-message{background-color:#ef44441a;border-color:#ef44444d;color:#fca5a5}.error-message h3{color:#f87171}.error-message button{background:var(--harmony-gradient-primary);color:#fff}.error-message button:hover{background:var(--harmony-gradient-primary);opacity:.9}.alert-danger{background-color:#ef44441a;border-color:#ef44444d;color:#fca5a5}.alert button{color:var(--harmony-gray-500)}.alert button:hover{background-color:var(--harmony-gray-200);color:var(--harmony-gray-700)}}.recharts-tooltip-wrapper{border-radius:6px;box-shadow:0 4px 6px #0000001a}.recharts-tooltip-content{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:10px}.recharts-tooltip-label{color:#374151;font-weight:500;margin-bottom:5px}.recharts-tooltip-item{color:#1e3a8a}.recharts-responsive-container{min-height:250px}.recharts-pie-label-text{fill:#374151;font-size:12px;font-weight:500}.recharts-bar{transition:opacity .2s ease}.recharts-bar:hover{opacity:.8}
/*# sourceMappingURL=main.e63bf9c8.css.map*/