@charset "UTF-8";*{margin:0;padding:0;box-sizing:border-box;scroll-behavior:smooth}:root{--primary-color: #3e91ee;--primary-color-hover: #367ecf;--primary-color-darken: #3c85d8;--primary-color-full-darken: #2c5ab1;--primary-color-muted-hover: #3e90ee23;--primary-btn-color: #5fa3fc;--light-blue-hover: #1080ff16;--background-color-white: #ffffff;--background-color-gray: #f7f7f7;--background-color-light-gray: #f8f8f8;--text-color: #121212;--text-color-dark-gray: #3e3e3e;--text-color-gray: #71717b;--text-color-light-gray: #999;--primary-text-color-active: #2b83e7;--text-color-warning: #a16207;--input-background: #f4f4f4;--muted: #ececf0;--destructive: #dc2626;--background-warning: #fefce8;--border-gray: #c7c7c7;--border-light-gray-hover: #9ca3af;--border-light-gray: #e1e1e1;--border-lighter-gray: #0000001a;--border-white-gray: #ebebeb;--border-primary-color-hover: #3e90ee6e;--border-warning: #fde68a;--card-border-radius: 12px;--border-radius-md: 8px;--font-weight-medium: 500;--font-weight-normal: 400;--chart-1: oklch(.646 .222 41.116);--chart-2: oklch(.6 .118 184.704);--chart-3: oklch(.398 .07 227.392);--chart-4: oklch(.828 .189 84.429);--chart-5: oklch(.769 .188 70.08);--private-classes-color: oklch(71.432% .15672 137.76)}body{font-family:Poppins,sans-serif;background-color:var(--background-color-white);color:var(--text-color)}.main-container{margin-left:220px;padding:1rem;min-height:100vh;display:flex;flex-direction:column}button{all:unset;box-sizing:border-box;cursor:pointer}.go3958317564{text-wrap:nowrap!important;min-width:fit-content!important}.spinner{width:50px;text-align:center;aspect-ratio:1;border-radius:50%;border:5px solid var(--primary-color);filter:drop-shadow(0px 0px 100px #000000);animation:circle-loader-1 .8s infinite linear alternate,circle-loader-2 1.6s infinite linear}.spinner-sm{width:35px!important;border:4px solid var(--primary-color)!important}@keyframes circle-loader-1{0%{clip-path:polygon(50% 50%,0 0,50% 0%,50% 0%,50% 0%,50% 0%,50% 0%)}12.5%{clip-path:polygon(50% 50%,0 0,50% 0%,100% 0%,100% 0%,100% 0%,100% 0%)}25%{clip-path:polygon(50% 50%,0 0,50% 0%,100% 0%,100% 100%,100% 100%,100% 100%)}50%{clip-path:polygon(50% 50%,0 0,50% 0%,100% 0%,100% 100%,50% 100%,0% 100%)}62.5%{clip-path:polygon(50% 50%,100% 0,100% 0%,100% 0%,100% 100%,50% 100%,0% 100%)}75%{clip-path:polygon(50% 50%,100% 100%,100% 100%,100% 100%,100% 100%,50% 100%,0% 100%)}to{clip-path:polygon(50% 50%,50% 100%,50% 100%,50% 100%,50% 100%,50% 100%,0% 100%)}}@keyframes circle-loader-2{0%{transform:scaleY(1) rotate(0)}49.99%{transform:scaleY(1) rotate(135deg)}50%{transform:scaleY(-1) rotate(0)}to{transform:scaleY(-1) rotate(-135deg)}}.general-loader-overlay{display:flex;align-items:center;justify-content:center;overflow:hidden;position:fixed;background-color:#ffffff90;z-index:9999;height:100vh;width:100vw;top:0;left:0}.general-loader-white-overlay{background-color:#fff!important}.general-loader-container{display:flex;flex-direction:column;align-items:center;gap:1rem;filter:drop-shadow(0px 0px 40px #000000)}.sidebar-header-main-container{display:flex;gap:.5rem;padding:1.5rem .5rem}.sidebar-header-text-container{display:flex;flex-direction:column;gap:.2rem;overflow:hidden;flex:1}.sidebar-header-user-title{font-size:1.1rem;font-weight:500;line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-header-user-mail{font-size:.9rem;font-weight:400;color:#747474;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.sidebar-item-container{display:flex;flex-direction:column;border-radius:var(--border-radius-md);border:1px solid transparent;transition:border .3s ease-in-out}.sidebar-item-header{display:flex;gap:.5rem;align-items:center;font-size:.9rem;padding:.5rem;cursor:pointer;border-radius:var(--border-radius-md);border:1px solid transparent;transition:border .3s ease-in-out}.sidebar-item-header:hover{background-color:var(--light-blue-hover)}.sidebar-item-header p{-webkit-user-select:none;user-select:none}.sidebar-item-header:has(~.sidebar-subitems:hover){background-color:var(--light-blue-hover)}.sidebar-item-active .sidebar-item-header p{font-weight:500;color:var(--primary-text-color-active)}.sidebar-item-active>.sidebar-item-header{border:1px solid var(--border-primary-color-hover)!important;background-color:var(--light-blue-hover);border-radius:var(--border-radius-md)}.sidebar-item-active>.sidebar-navlink.active>.sidebar-item-header{border:1px solid var(--border-primary-color-hover)!important;background-color:var(--light-blue-hover);border-radius:var(--border-radius-md)}.sidebar-item-chevron{font-size:.75rem;margin-left:auto;transition:transform .2s ease-in-out}.sidebar-item-chevron-open{transform:rotate(180deg)}.sidebar-item-logout .sidebar-item-header:hover{background-color:#f65e662d;color:#770004}.sidebar-navlink{text-decoration:none;color:inherit;-webkit-user-select:none;user-select:none}.sidebar-subitem-container{padding:6px 24px;cursor:pointer;font-size:.85rem;display:block;text-decoration:none;color:var(--text-color-dark-gray);-webkit-user-select:none;user-select:none}.sidebar-subitem-container:hover,.sidebar-subitem-active{font-weight:500;color:inherit}.sidebar-subitem-active{color:inherit;font-weight:600}.sidebar-subitem-active:hover{font-weight:600}.sidebar-footer-main-container{padding:.5rem .5rem 0;border-top:1px solid var(--border-gray)}.sidebar-main-container{height:100vh;width:220px;position:fixed;left:0;display:flex;flex-direction:column;justify-content:space-between;gap:.5rem;background-color:var(--input-background);border-right:1px solid var(--border-gray);padding:1rem}.sidebar-navbar{height:100%;padding:.5rem}.close-sidebar-btn{display:none}@media (max-width: 1362px){.sidebar-main-container{position:fixed;top:0;left:-100%;width:280px;height:100vh;z-index:1000;transition:left .3s cubic-bezier(.4,0,.2,1);box-shadow:2px 0 10px #0000001a;border-right:none}.sidebar-main-container.open{left:0}.close-sidebar-btn{display:block;position:absolute;top:1rem;right:1rem;font-size:1.5rem;color:var(--text-color-gray);cursor:pointer;z-index:1001;background:transparent;border:none}}@media (max-width: 500px){.sidebar-main-container{position:fixed;top:0;left:-100%;width:100%;max-width:100%;height:100vh;z-index:1000;transition:left .3s ease-in-out;box-shadow:2px 0 10px #0000001a}}.notification-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#0006;z-index:998;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.notification-backdrop.open{opacity:1;visibility:visible}.notification-panel{position:fixed;top:0;right:0;width:380px;max-width:90vw;height:100vh;background-color:#fff;box-shadow:-4px 0 15px #0000001a;z-index:999;display:flex;flex-direction:column;transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1)}.notification-panel.open{transform:translate(0)}.notification-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-lighter-gray, #e5e7eb)}.notification-header h3{margin:0;font-size:1.1rem;color:var(--text-color)}.notification-close-btn{background:none;border:none;color:var(--text-color-gray);font-size:1.1rem;cursor:pointer;padding:5px;transition:color .2s}.notification-close-btn:hover{color:var(--text-color)}.notification-content{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.6rem}.empty-notifications{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-color-gray);gap:1rem}.empty-icon{font-size:2rem;opacity:.3}.notification-item{display:flex;gap:12px;padding:1rem 1.5rem;border-radius:var(--card-border-radius);border:1px solid var(--border-white-gray);transition:background-color .2s;cursor:pointer;position:relative}.notification-item:hover{background-color:var(--background-color-light-gray);border-color:var(--border-lighter-gray)}.notification-item.unread{background-color:#eff6ff}.notif-icon-container{transform:translateY(-2px)}.notif-icon{color:var(--primary-color);font-size:1rem}.notif-body{flex:1}.notif-message{font-size:.9rem;color:var(--text-color);line-height:1.4}.notif-time{font-size:.75rem;color:var(--text-color-gray)}.unread-dot{width:8px;height:8px;margin-left:8px;background-color:var(--primary-color);border-radius:50%;align-self:center}.notif-delete-btn{position:absolute;right:1%;top:3%;background:none;border:none;color:#9ca3af;cursor:pointer;padding:6px;border-radius:100%;font-size:.85rem;opacity:0;transition:all .2s ease;z-index:2}.notif-delete-btn:hover{color:var(--text-color)}.notification-item:hover .notif-delete-btn{opacity:1}.notification-footer{padding:1rem;border-top:1px solid var(--border-lighter-gray);display:flex;justify-content:space-evenly;align-items:center;background-color:var(--background-color-white)}.footer-action-btn{background:none;border:none;font-size:.9rem;font-weight:500;cursor:pointer;transition:color .1s}.mark-read{color:var(--primary-color)}.mark-read:hover{color:var(--primary-color-full-darken);text-decoration:underline}.delete-all{color:var(--text-color-gray)}.delete-all:hover{color:var(--destructive);text-decoration:underline}.footer-divider{width:1px;height:100%;background-color:var(--border-gray)}@media (max-width: 768px){.notification-panel{width:100vw;max-width:100vw}.notif-delete-btn{opacity:1}}.mobile-header{display:none;justify-content:space-between}.mobile-header-left{display:flex;align-items:center;gap:1rem}.mobile-notification-btn{position:relative;padding:.5rem;font-size:1.4rem;color:var(--text-color);cursor:pointer;background:transparent;border:none}.mobile-notification-badge{position:absolute;top:5px;right:5px;width:8px;height:8px;background-color:var(--destructive);border-radius:50%;border:1px solid var(--background-color-white)}@media (max-width: 1362px){.main-container{margin-left:0!important;padding-top:80px}.mobile-header{display:flex;justify-content:space-between;align-items:center;position:fixed;top:0;left:0;width:100%;height:60px;background-color:var(--background-color-white);padding:0 1rem;z-index:99;border-bottom:1px solid var(--border-light-gray);box-shadow:0 2px 4px #0000000d}.hamburger-btn{font-size:1.5rem;color:var(--text-color);cursor:pointer;padding:.5rem}.mobile-page-title{display:none}.sidebar-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000080;visibility:hidden;opacity:0;z-index:998;transition:opacity .3s ease,visibility .3s ease}.sidebar-overlay-open{opacity:1;visibility:visible}}@media (max-width: 768px){.mobile-page-title{display:inline;font-size:1.4rem;font-weight:700;color:var(--text-color)}}@media (max-width: 500px){.sidebar-overlay{display:none}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;padding:32px;z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-content{background-color:var(--background-color-gray);border:1px solid var( --border-lighter-gray);border-radius:var(--card-border-radius);box-shadow:0 25px 50px -12px #00000040;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:modalAppear .2s ease-out}@keyframes modalAppear{0%{opacity:0;transform:scale(.95) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-content.sm{max-width:400px}.modal-content.md{max-width:500px}.modal-content.lg{max-width:800px}.modal-content.xl{max-width:1200px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:24px 24px 0;margin-bottom:24px}.modal-title{color:var(--text-color);margin:0}.modal-close-btn{background:transparent;border:none;padding:8px;border-radius:6px;color:var(--text-color-gray);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;margin:-8px -8px -8px 0}.modal-close-btn:hover{background-color:var(--light-blue-hover);color:var(--text-color)}.modal-body{padding:0 24px 24px;overflow-y:auto;flex:1}.form-error-message{display:flex;gap:.3rem;align-items:center;color:var(--destructive);font-size:.9rem}.form-error-message p{margin-top:2px}@media (max-width: 768px){.modal-overlay{padding:16px}.modal-content{max-width:none;margin:0}.modal-header{padding:16px 16px 0;margin-bottom:16px}.modal-body{padding:0 16px 16px}}.event-form{display:flex;flex-direction:column;gap:1.25rem}.event-form .form-group input,.event-form .form-group textarea,.event-form .form-group .form-date{padding:10px 12px;border-radius:6px;border:1px solid #ccc;font-size:1rem;width:100%;box-sizing:border-box;font-family:inherit}.event-form .form-group textarea{resize:vertical}.event-form .form-group textarea:focus,.event-form .form-group .form-date:focus{outline:none;border-color:var(--border-gray);box-shadow:0 0 0 1px var(--primary-color)}.event-form .field-error-message{font-size:.8rem;color:var(--error-color, #dc2626);margin-top:2px}.event-form .input-error{border-color:var(--error-color, #dc2626)}.event-form .form-actions-modal{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #eee}.small-loader-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;flex:1;width:100%}.loader-text{color:var(--text-color)}.stat-card{background-color:var(--background-color-white);border:1px solid var(--border-lighter-gray);border-radius:var(--card-border-radius);padding:24px;box-shadow:0 1px 3px #0000001a}.stat-content{display:flex;align-items:center;justify-content:space-between}.stat-label{font-size:.875rem;color:var(--text-color-gray);margin:0 0 4px}.stat-value{font-size:2rem;color:var(--text-color);margin:0 0 8px}.stat-change{display:flex;align-items:center;gap:4px}.stat-change-icon{color:var(--chart-2);font-size:.75rem}.stat-change span{color:var(--chart-2);font-size:.875rem}.stat-icon{padding:12px;border-radius:var(--card-border-radius);display:flex;align-items:center;justify-content:center}.stat-icon i{color:#fff;font-size:1.5rem}.stat-icon.chart-1{background-color:var(--chart-1)}.stat-icon.chart-2{background-color:var(--chart-2)}.stat-icon.chart-3{background-color:var(--chart-3)}.stat-icon.chart-4{background-color:var(--chart-4)}@media (max-width: 768px){.stat-card{padding:16px}.stat-value{font-size:1.5rem;margin-bottom:4px}.stat-label{font-size:.8rem}.stat-icon{padding:10px;width:40px;height:40px}.stat-icon i{font-size:1.2rem}}.quick-actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.quick-action-item{display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px;background:transparent;border:1px solid var(--border-lighter-gray);border-radius:var(--border-radius-md);cursor:pointer;transition:all .2s ease}.quick-action-item:hover{border-color:var(--primary-color);background-color:var(--light-blue-hover);box-shadow:0 2px 4px #0000001a}.quick-action-icon{padding:12px;border-radius:var(--card-border-radius);display:flex;align-items:center;justify-content:center}.quick-action-icon i{color:var(--background-color-white);font-size:1.25rem}.quick-action-icon.chart-1{background-color:var(--chart-1)}.quick-action-icon.chart-2{background-color:var(--chart-2)}.quick-action-icon.chart-3{background-color:var(--chart-3)}.quick-action-icon.chart-4{background-color:var(--chart-4)}.quick-action-item span{font-size:.875rem;color:var(--text-color)}@media (max-width: 768px){.quick-actions-grid{grid-template-columns:repeat(2,1fr);gap:10px}.quick-action-item{padding:12px;gap:8px}.quick-action-icon{padding:10px}.quick-action-icon i{font-size:1.1rem}.quick-action-item span{font-size:.8rem;text-align:center;line-height:1.2}}.page-title{color:var(--text-color);line-height:1;margin:0}.page-subtitle{color:var(--text-color-gray);margin:4px 0 0}.page-header-btn-container{display:flex;gap:.5rem;height:43px}.page-header-notification-btn{background-color:var(--muted);border:1px solid var(--border-light-gray)!important;font-size:1rem!important;display:flex;align-items:center;justify-content:center;position:relative;transition:background-color .2s ease}.page-header-notification-btn:hover{background-color:var(--border-light-gray);border-color:var(--text-color-light-gray)}.notification-badge-dot{position:absolute;top:9px;right:11px;width:8px;height:8px;background-color:var(--destructive);border-radius:50%;border:1px solid var(--background-color-white)}@media (max-width: 1362px){.page-header-notification-btn{display:none!important}}@media (max-width: 768px){.page-header,.page-title-container,.page-title,.page-subtitle{display:none!important}}.react-calendar{width:350px;max-width:100%;background:#fff;border:1px solid #a0a096;font-family:Arial,Helvetica,sans-serif;line-height:1.125em}.react-calendar--doubleView{width:700px}.react-calendar--doubleView .react-calendar__viewContainer{display:flex;margin:-.5em}.react-calendar--doubleView .react-calendar__viewContainer>*{width:50%;margin:.5em}.react-calendar,.react-calendar *,.react-calendar *:before,.react-calendar *:after{-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}.react-calendar button{margin:0;border:0;outline:none}.react-calendar button:enabled:hover{cursor:pointer}.react-calendar__navigation{display:flex;height:44px;margin-bottom:1em}.react-calendar__navigation button{min-width:44px;background:none}.react-calendar__navigation button:disabled{background-color:#f0f0f0}.react-calendar__navigation button:enabled:hover,.react-calendar__navigation button:enabled:focus{background-color:#e6e6e6}.react-calendar__month-view__weekdays{text-align:center;text-transform:uppercase;font:inherit;font-size:.75em;font-weight:700}.react-calendar__month-view__weekdays__weekday{padding:.5em}.react-calendar__month-view__weekNumbers .react-calendar__tile{display:flex;align-items:center;justify-content:center;font:inherit;font-size:.75em;font-weight:700}.react-calendar__month-view__days__day--weekend{color:#d10000}.react-calendar__month-view__days__day--neighboringMonth,.react-calendar__decade-view__years__year--neighboringDecade,.react-calendar__century-view__decades__decade--neighboringCentury{color:#757575}.react-calendar__year-view .react-calendar__tile,.react-calendar__decade-view .react-calendar__tile,.react-calendar__century-view .react-calendar__tile{padding:2em .5em}.react-calendar__tile{max-width:100%;padding:10px 6.6667px;background:none;text-align:center;font:inherit;font-size:.833em}.react-calendar__tile:disabled{background-color:#f0f0f0;color:#ababab}.react-calendar__month-view__days__day--neighboringMonth:disabled,.react-calendar__decade-view__years__year--neighboringDecade:disabled,.react-calendar__century-view__decades__decade--neighboringCentury:disabled{color:#cdcdcd}.react-calendar__tile:enabled:hover,.react-calendar__tile:enabled:focus{background-color:#e6e6e6}.react-calendar__tile--now{background:#ffff76}.react-calendar__tile--now:enabled:hover,.react-calendar__tile--now:enabled:focus{background:#ffffa9}.react-calendar__tile--hasActive{background:#76baff}.react-calendar__tile--hasActive:enabled:hover,.react-calendar__tile--hasActive:enabled:focus{background:#a9d4ff}.react-calendar__tile--active{background:#006edc;color:#fff}.react-calendar__tile--active:enabled:hover,.react-calendar__tile--active:enabled:focus{background:#1087ff}.react-calendar--selectRange .react-calendar__tile--hover{background-color:#e6e6e6}.calendar-header-custom{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #f3f4f6}.calendar-title{margin:0!important;font-size:1.17rem;font-weight:700;color:var(--text-color)}.calendar-legend{display:flex;gap:12px;font-size:.75rem;color:var(--text-color-gray)}.legend-item{display:flex;align-items:center;gap:4px}.dot-ref{width:8px;height:8px;border-radius:50%}.class-ref{background-color:var(--primary-color)}.holiday-ref{background-color:#ef4444;opacity:.6}.react-calendar{width:100%;border:none!important;font-family:inherit;background:transparent!important;overflow:visible!important}.react-calendar__navigation{height:40px;margin-bottom:10px;display:flex;gap:1rem}.react-calendar__navigation button{color:var(--text-color);min-width:30px;background:none;text-align:center;font-size:.95rem;font-weight:600;border-radius:var(--border-radius-md);transition:background-color .2s}.react-calendar__navigation button:enabled:hover,.react-calendar__navigation button:enabled:focus{background-color:var(--muted)}.react-calendar__month-view__weekdays{text-align:center;font-weight:600;font-size:.75rem;color:var(--text-color-light-gray);text-decoration:none;margin-bottom:8px}.react-calendar__month-view__weekdays__weekday abbr{text-decoration:none;cursor:default}.calendar-dot{width:5px;height:5px;position:absolute;left:50%;top:58%;transform:translate(-50%);background-color:var(--primary-color);border-radius:50%}.react-calendar__tile{position:relative;overflow:visible!important;padding:8px 0 10px;background:none;text-align:center;line-height:1.2;font-size:.9rem;font-weight:500;color:var(--text-color-dark-gray);border-radius:10px;border:1px solid transparent!important;height:48px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;z-index:1;transition:all .2s}.react-calendar__tile:hover{z-index:1000!important}.react-calendar__tile:enabled:hover,.react-calendar__tile:enabled:focus{background-color:var(--primary-color-muted-hover);color:var(--primary-color);z-index:100;overflow:visible;position:relative}.react-calendar__tile--active{background:transparent!important;border:1px solid var(--primary-color)!important}.react-calendar__tile--active abbr{color:var(--text-color)}.react-calendar__tile--active .calendar-dot{background-color:var(--primary-color)!important}.react-calendar__tile--active:hover{background-color:var(--primary-color-muted-hover)!important}.react-calendar__tile--active:hover abbr{color:var(--primary-color)!important}.react-calendar__tile--now{background-color:var(--primary-color)!important}.react-calendar__tile--now abbr{font-weight:700;color:var(--background-color-white)!important}.react-calendar__tile--now .calendar-dot{background-color:var(--background-color-white)!important}.react-calendar__tile--now:hover{background-color:var(--primary-color-hover)!important}.react-calendar__tile--now:hover abbr{color:var(--background-color-white)!important}.holiday-tile{background-color:#fef2f2!important;color:#ef4444!important}.holiday-tile:enabled:hover{background-color:#fee2e2!important}.holiday-tile .calendar-dot{display:none}.react-calendar__month-view__days__day--neighboringMonth{visibility:hidden;pointer-events:none}.tile-content-wrapper,.tooltip-wrapper{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.custom-tooltip{position:absolute;bottom:40px;left:50%;transform:translate(-50%);width:max-content;min-width:180px;max-width:250px;background-color:#1f2937;color:var(--background-color-white);padding:10px;border-radius:var(--border-radius-md);font-size:.75rem;line-height:1.4;text-align:left;box-shadow:0 10px 15px -3px #0003,0 4px 6px -2px #0000001a;z-index:1001;opacity:0;visibility:hidden;transition:opacity .2s ease,transform .2s ease;pointer-events:none}.custom-tooltip:after{content:"";position:absolute;top:100%;left:50%;margin-left:-6px;border-width:6px;border-style:solid;border-color:#1f2937 transparent transparent transparent}.react-calendar__tile:hover .custom-tooltip{opacity:1;visibility:visible;transform:translate(-50%) translateY(-8px)}.holiday-tooltip{background-color:#ef4444}.class-tooltip{text-align:left;min-width:140px}.tooltip-header{font-weight:700;margin-bottom:6px;padding-bottom:4px;border-bottom:1px solid rgba(255,255,255,.2);color:var(--primary-btn-color);display:block}.tooltip-header-holiday{color:var(--background-color-white)}.tooltip-row{display:flex;justify-content:flex-start;gap:3px;margin-bottom:3px}.tooltip-time{font-weight:600;color:var(--border-light-gray-hover);white-space:nowrap}.tooltip-title{opacity:.9;white-space:normal}.holiday-tooltip{background-color:#ef4444;text-align:left;min-width:140px}.holiday-tooltip:after{border-color:#ef4444 transparent transparent transparent}.calendar-card-wrapper{overflow:visible!important}@media (max-width: 768px){.calendar-card-wrapper{padding:0 0 1rem!important}.calendar-container{border:1px solid var(--border-white-gray);border-radius:var(--card-border-radius)}.calendar-header-custom{flex-direction:column;align-items:flex-start;gap:10px;border:none;padding:0}.calendar-legend{width:100%;justify-content:flex-start}.react-calendar__navigation{gap:.2rem}.react-calendar__navigation button{min-width:44px;padding:5px;font-size:1rem}.react-calendar__tile{height:40px;font-size:.85rem;padding-top:6px}.calendar-dot{width:4px;height:4px;top:65%}.react-calendar__month-view__weekdays__weekday{font-size:.7rem;padding:0}.custom-tooltip{display:none}}.resource-banner{display:flex;align-items:center;justify-content:space-between;gap:16px;background-color:var(--background-color-white);border:1px solid var(--border-lighter-gray);border-radius:var(--card-border-radius);box-shadow:0 1px 3px #0000001a}.resource-banner-inner-container{display:flex;align-items:center;justify-content:space-between;width:100%;padding:2rem;border-radius:var(--card-border-radius);border-left:10px solid var(--primary-color)}.resource-content{display:flex;align-items:center;gap:16px}.resource-icon-container{width:48px;height:48px;border-radius:var(--card-border-radius);background-color:#eff6ff;display:flex;align-items:center;justify-content:center;color:var(--primary-color);font-size:1.25rem;flex-shrink:0}.resource-text h3{font-size:1.17rem;font-weight:700;color:var(--text-color);margin:0 0 4px!important}.resource-text p{font-size:.85rem;color:var(--text-color-gray);margin:0;line-height:1.4}.resource-btn{background-color:var(--primary-color);color:var(--background-color-white);border:none;padding:10px 16px;border-radius:var(--border-radius-md);font-weight:600;font-size:.9rem;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background-color .2s ease;white-space:nowrap}.resource-btn:hover{background-color:var(--primary-color-hover)}.resource-btn:hover .resource-btn-icon{transform:translate(10%)}.resource-btn-icon{font-size:.9rem;transition:transform .1s ease-in-out}@media (max-width: 768px){.resource-banner{background:transparent;box-shadow:none;border:1px solid var(--border-lighter-gray)!important;margin:1rem 0}.resource-banner-inner-container{flex-direction:column;align-items:flex-start;padding:1.5rem;gap:1.5rem;width:100%}.resource-content{width:100%}.resource-text h3{font-size:1.1rem}.resource-btn{width:100%;justify-content:center;padding:12px}}.dashboard{display:flex;flex-direction:column;gap:24px;padding:1rem}.dashboard-grid{display:grid;grid-template-columns:2fr 1fr;gap:24px;align-items:start}.dashboard-left-col,.dashboard-right-col{display:flex;flex-direction:column;gap:24px}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.dashboard-title h1{color:var(--text-color);margin:0;line-height:1}.dashboard-title p{color:var(--text-color-gray);margin:4px 0 0}.dashboard-actions{display:flex;gap:12px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px}.dashboard-card{background-color:var(--background-color-white);border:1px solid var(--border-lighter-gray);border-radius:var(--card-border-radius);padding:24px;box-shadow:0 1px 3px #0000001a}.dashboard-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.dashboard-card-header h3{margin:0!important;color:var(--text-color)}.btn-link{background:none;border:none;color:var(--primary-color, #3b82f6);font-size:.875rem;font-weight:500;cursor:pointer;padding:4px}.btn-link:hover{text-decoration:underline}.dashboard-card h3{color:var(--text-color);margin:0 0 16px}.dashboard-list{display:flex;flex-direction:column;gap:12px}.activities-list{gap:16px}.activity-item{display:flex;align-items:flex-start;gap:12px;padding:12px;border-radius:var(--border-radius-md);transition:background-color .2s ease}.activity-item:hover{background-color:var(--light-blue-hover)}.activity-icon{background-color:#0302131a;padding:8px;border-radius:var(--border-radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.activity-check-icon{color:var(--text-color);font-size:.7rem}.activity-content{flex:1}.activity-action{color:var(--text-color);margin:0 0 4px}.activity-details{font-size:.875rem;color:var(--text-color-gray);margin:0 0 4px}.activity-time{font-size:.75rem;color:var(--text-color-gray);margin:0}.events-list{gap:12px}.event-item{padding:12px;border:1px solid var(--border-lighter-gray);border-radius:var(--border-radius-md);transition:all .2s ease}.event-item:hover{background-color:var(--light-blue-hover)}.event-title{color:var(--text-color);font-size:.875rem;margin:0 0 4px}.event-title-empty{color:var(--text-color);font-size:.875rem}.event-date{font-size:.75rem;color:var(--text-color-gray);margin:0}.class-event-item-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;gap:1rem;color:#6b7280;font-size:.9rem;font-style:italic}.class-event-item-loading svg{font-size:1.5rem}.event-title-empty-error{color:var(--destructive);font-weight:500;font-style:normal}.class-event-item{display:flex;align-items:center;gap:1rem;padding:12px;border-radius:var(--border-radius-md);background-color:var(--background-color-white);border:1px solid var(--border-lighter-gray);transition:background-color .2s,box-shadow .2s}.class-event-item:hover{background-color:var(--light-blue-hover);box-shadow:0 2px 4px #0000000a}.class-event-item:hover>.class-event-tag{color:var(--text-color-dark-gray);background-color:#dbdbdb}.task-item{display:flex;align-items:center;gap:12px;padding:12px;background-color:var(--background-color-gray);border:1px solid var(--border-lighter-gray);border-radius:var(--border-radius-md);transition:all .2s ease}.task-item:hover{border-color:var(--primary-color);background-color:var(--background-color-white);box-shadow:0 2px 4px #0000000d;transform:translate(1px)}.task-item:hover .task-action-btn{transform:translate(3px)}.task-icon-container{width:36px;height:36px;border-radius:var(--border-radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.task-icon{font-size:1rem}.task-icon.planificacion{color:#8b5cf6;background-color:#f3e8ff;padding:8px;border-radius:var(--border-radius-md)}.task-icon.horas_trabajadas{color:#f59e0b;background-color:#fef3c7;padding:8px;border-radius:var(--border-radius-md)}.task-content{flex:1;display:flex;flex-direction:column}.task-title{font-size:.9rem;font-weight:600;color:var(--text-color)}.task-desc{font-size:.75rem;color:var(--text-color-gray);line-height:1.2}.task-action-btn{background:none;border:none;color:var(--primary-color);cursor:pointer;padding:8px;border-radius:50%;transition:background-color .2s,transform .2s ease-in-out;display:flex;align-items:center;justify-content:center}.task-action-btn:hover{background-color:var(--light-blue-hover)}.class-event-icon{flex-shrink:0;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1rem}.class-event-icon.course{background-color:#3b82f6}.class-event-icon.student{background-color:#10b981}.class-event-details{flex-grow:1}.class-event-title{font-size:1rem;font-weight:600;color:var(--text-color);margin:0}.class-event-time-container{font-size:.85rem;color:var(--text-color-dark-gray);margin:2px 0 0;height:100%;display:flex;align-items:center;gap:.35rem}.class-event-time-container svg{font-size:.75rem}.class-event-time-container span{margin-top:3px}.class-event-tag{flex-shrink:0;font-size:.8rem;font-weight:500;color:var(--text-color-gray);background-color:var(--muted);padding:4px 8px;border-radius:99px;transition:all .1s ease-in-out}@media (max-width: 1024px){.dashboard-grid{grid-template-columns:1fr;gap:16px}.dashboard-left-col,.dashboard-right-col{gap:16px;width:100%}}@media (max-width: 768px){.dashboard{padding:0 0 1rem;gap:0}.dashboard-grid,.dashboard-left-col,.dashboard-right-col{gap:0}.dashboard-header{flex-direction:column;align-items:flex-start;gap:12px}.dashboard-title h1{font-size:1.5rem}.dashboard-actions{width:100%;overflow-x:auto;padding-bottom:4px}.dashboard-card{padding:1rem 0;box-shadow:none;border:none}.stats-grid{grid-template-columns:1fr;gap:12px}.activity-item,.task-item,.class-event-item,.event-item{padding:10px;gap:10px}.task-item{flex-wrap:wrap}.task-content{min-width:0;width:100%;flex:1 1 auto}.task-action-btn{margin-left:auto}.class-event-item{flex-wrap:wrap}.class-event-tag{margin-left:auto;font-size:.7rem}}.actions-dropdown-container{position:relative;display:inline-block}.actions-dropdown-menu{position:absolute;top:100%;right:0;z-index:10;background-color:#fff;border:1px solid var(--border-light-gray);border-radius:6px;box-shadow:0 4px 12px #0000001a;min-width:180px;padding:6px 0}.dropdown-item{display:block;width:100%;text-align:left;padding:8px 16px;font-size:.84rem;font-weight:600;color:var(--text-color-gray);background:none;border:none;cursor:pointer}.dropdown-item:hover{background-color:#f5f5f5}.data-card-list-container{display:flex;flex-direction:column;gap:1rem;padding-bottom:2rem}.data-cards-empty{text-align:center;padding:2rem;color:var(--text-color-gray);background-color:var(--input-background);border-radius:var(--border-radius-md)}.data-card{background-color:var(--background-color-white);border:1px solid var(--border-lighter-gray);border-radius:var(--card-border-radius);box-shadow:0 2px 4px #00000005;display:flex;flex-direction:column;position:relative}.data-card-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background-color:var(--background-color-light-gray);border-bottom:1px solid var(--border-lighter-gray);gap:1rem}.data-card-title{margin:0;font-size:1rem;font-weight:600;color:var(--text-color);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.data-card-menu-container{position:relative}.card-menu-trigger{background:transparent;border:none;color:var(--text-color-gray);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.1rem;transition:background-color .2s}.card-menu-trigger:hover,.card-menu-trigger.active{background-color:#0000000d;color:var(--text-color)}.card-dropdown-menu{position:absolute;top:100%;right:0;margin-top:5px;padding:5px;display:flex;flex-direction:column;gap:2px;background-color:var(--background-color-white);border:1px solid var(--border-lighter-gray);border-radius:var(--border-radius-md);box-shadow:0 4px 12px #00000026;min-width:160px;z-index:50;overflow:hidden;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.card-dropdown-item{text-align:left;padding:10px 16px;background:none;border:none;font-size:.9rem;color:var(--text-color);cursor:pointer;display:flex;align-items:center;gap:10px;transition:background-color .2s;border-radius:4px}.card-dropdown-item:hover{background-color:var(--background-color-gray)}.item-icon{width:16px;color:var(--text-color-gray);text-align:center}.card-dropdown-divider{height:1px;background-color:var(--border-lighter-gray)}.card-dropdown-item.delete{color:var(--destructive)}.card-dropdown-item.delete:hover{background-color:#dc26260d}.card-dropdown-item.delete .item-icon{color:var(--destructive)}.card-dropdown-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:40;background:transparent;cursor:default}.data-card-content{padding:1rem;display:flex;flex-direction:column;gap:.8rem}.data-card-row{display:flex;justify-content:space-between;align-items:center;font-size:.9rem;border-bottom:1px dashed var(--muted);padding-bottom:.5rem}.data-card-row:last-child{border-bottom:none;padding-bottom:0}.data-card-label{font-weight:500;color:var(--text-color-gray);font-size:.8rem;flex-shrink:0}.data-card-value{text-align:right;color:var(--text-color);word-break:break-word;max-width:65%}.data-table-container{background-color:var(--background-color-white);border:1px solid var( --border-lighter-gray);border-radius:var(--card-border-radius);box-shadow:0 1px 3px #0000001a}.data-table-loading,.data-table-empty{padding:64px 32px;text-align:center}.loading-spinner{width:32px;height:32px;border:2px solid var( --border-lighter-gray);border-top:2px solid var(--text-color);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.data-table-loading p,.data-table-empty p{color:var(--text-color-gray);margin:0}.data-table{width:100%;border-collapse:collapse}.data-table-wrapper{overflow-x:auto;width:100%}.data-table-header{background-color:var(--muted);border-bottom:1px solid var( --border-lighter-gray)}.data-table-th{padding:12px 24px;text-align:left;font-size:.75rem;font-weight:500;color:var(--text-color-gray);text-transform:uppercase;letter-spacing:.025em}.actions-header{text-align:right}.data-table-body{background-color:var(--background-color-white)}.data-table-row{border-bottom:1px solid var( --border-lighter-gray);transition:background-color .2s ease}.data-table-row:hover{background-color:var(--light-blue-hover)}.data-table-row:last-child{border-bottom:none}.data-table-td{padding:16px 24px;white-space:nowrap}.data-table-cell{font-size:.875rem;color:var(--text-color)}.actions-cell{text-align:right}.table-actions{display:flex;justify-content:flex-end;gap:8px}.table-action-btn{background:transparent;border:none;padding:6px;border-radius:6px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;color:var(--text-color-gray)}.table-action-btn:hover{background-color:var(--light-blue-hover)}.table-action-btn.view:hover{color:var(--text-color);background-color:#0302131a}.table-action-btn.edit:hover{color:var(--chart-2);background-color:#6699991a}.table-action-btn.delete:hover{color:var(--destructive);background-color:#d4183d1a}.table-action-btn i{font-size:.875rem}.table-action-btn.dropdown-toggle:hover{background-color:#0302131a;color:var(--text-color)}.status-badge{padding:4px 8px;width:fit-content;font-size:.75rem;border-radius:9999px;font-weight:500;display:flex;justify-content:space-between;align-items:center;gap:.2rem}.status-badge.activo{background-color:#6993;color:var(--chart-2)}.status-badge.inactivo{background-color:#d4183d33;color:var(--destructive)}.status-badge.draft,.status-badge.on-leave{background-color:#ffc40033;color:var(--chart-4)}@media (max-width: 768px){.data-table-th,.data-table-td{padding:12px 16px}.data-table-th{font-size:.7rem}.data-table-cell{font-size:.8rem}}.collapsible-card{border:1px solid var(--border-light-gray);border-radius:var(--border-radius-md);margin-bottom:1rem;overflow:hidden;width:100%;position:relative}.collapsible-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:1rem 1.5rem;background-color:#f9fafb;border:none;cursor:pointer;font-size:1.1rem;font-weight:600;color:#1f2937;text-align:left}.collapsible-header:hover{background-color:#f3f4f6}.collapsible-header span{flex:1;min-width:0;padding-right:1rem;word-break:break-word;font-size:1.1rem;font-weight:600;color:#1f2937}.collapsible-header svg{flex-shrink:0;color:var(--text-color-gray)}.collapsible-content{padding:1.5rem;background-color:var(--background-color-white)}.detail-item-nested{display:grid;grid-template-columns:150px 1fr;gap:1rem;padding:.5rem 0;font-size:.95rem}.detail-item-nested strong{color:#4b5563}@media (max-width: 768px){.collapsible-header{padding:.8rem 1rem}.collapsible-header span{font-size:1rem}.collapsible-content{padding:1rem}.detail-item-nested{grid-template-columns:1fr;gap:.2rem;margin-bottom:.8rem;padding:0}.detail-item-nested:last-child{margin-bottom:0}.detail-item-nested strong{font-size:.85rem;color:var(--text-color-gray)}.detail-item-nested span{font-size:.95rem}}.details-view-container{padding:2rem;background-color:#f9fafb}.details-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem;border-bottom:1px solid #e5e7eb;padding-bottom:1rem}.details-header h1{margin:0;font-size:2rem;color:#111827}.back-button{display:flex;align-items:center;gap:.5rem}.details-content{background-color:var(--background-color-white);padding:2rem;border-radius:var(--border-radius-md);box-shadow:0 4px 6px #0000000d}.detail-item{display:grid;grid-template-columns:200px 1fr;gap:1rem;padding:.75rem 0;font-size:1rem;border-bottom:1px solid #f3f4f6}.detail-item:last-child{border-bottom:none}.detail-item strong{color:#4b5563;font-weight:600}.detail-item span,.detail-item ul{color:#1f2937;margin:0;padding:0}.detail-item ul{list-style-position:inside}.nested-details{padding:1rem;background-color:#f9fafb;border-radius:6px;margin-top:.5rem}.details-section{background-color:var(--background-color-white);padding:1.5rem 2rem 2rem;border-radius:var(--border-radius-md);box-shadow:0 4px 6px #0000000d;margin-bottom:2rem}.details-section h2{font-size:1.5rem;color:#374151;border-bottom:1px solid #e5e7eb;padding-bottom:1rem;margin-top:0;margin-bottom:1.5rem}.section-content{display:grid;gap:1.5rem 2rem}.detail-item-grid{display:flex;flex-direction:column;gap:.5rem}.detail-item-grid.full-width{grid-column:1 / -1}.detail-item-grid strong{color:#4b5563;font-weight:600;font-size:.9rem}.item-content{display:flex;justify-content:space-between;align-items:center;min-height:38px}.item-content span,.item-content ul{color:#1f2937;margin:0;padding:0;font-size:1rem}.default-list,.timetable-list{list-style-type:none;padding:0}.details-view-container .default-list li{margin-bottom:5px}.timetable-list li{display:flex;align-items:center;justify-content:space-between;padding:.4rem .8rem;border-radius:6px;background-color:#f3f4f6;margin-bottom:.5rem}.timetable-list .day{font-weight:600;color:#111827}.timetable-list .time{margin-left:.8rem;padding-top:.1rem;font-size:.9rem}.details-view-link-button{margin-left:1rem;white-space:nowrap;color:var(--text-color-gray)}.linked-list{list-style-type:none;padding:0;display:flex;flex-direction:column;gap:.5rem}.link-style-button{background:none;border:none;padding:0;font:inherit;cursor:pointer;text-align:left;color:#3b82f6;font-weight:500;text-decoration:none}.link-style-button:hover{text-decoration:underline}@media (max-width: 768px){.details-view-container{padding:1rem 0;background-color:var(--background-color-white)}.details-header{gap:1rem;margin-bottom:1.5rem}.details-header h1{font-size:1.25rem;line-height:1.3;white-space:normal}.back-button-text{display:none}.back-button{padding:.5rem .75rem}.details-section{padding:1rem;margin-bottom:1rem}.details-section h2{font-size:1.1rem;margin-bottom:1rem}.section-content{grid-template-columns:1fr!important;gap:1rem}.detail-item-grid strong{font-size:.85rem}.item-content span,.item-content ul{font-size:.95rem}.timetable-list li{padding:.5rem;font-size:.85rem}.timetable-list .day{font-size:.85rem}.timetable-list .time{font-size:.85rem;margin-left:.5rem}.class-card-mobile-content{font-size:.9rem}.link-style-button{font-size:.95rem;padding:4px 0}}.confirmation-modal-body{margin-bottom:24px;color:var(--text-color-dark-gray);font-size:.9rem;line-height:1.5}.confirmation-modal-footer{display:flex;justify-content:flex-end;gap:12px}.btn-danger{background-color:#ef4444;color:#fff}.btn-danger:hover{background-color:#dc2626}.filter-container{display:flex;align-items:center;gap:8px}.filter-icon{color:#555}.filter-select{padding:8px 12px;border-radius:5px;border:1px solid var(--border-gray);background-color:#fff;font-size:14px}.add-button-mobile{display:none}@media (max-width: 768px){.add-button-mobile{display:flex;align-items:center;justify-content:center;position:fixed;bottom:24px;right:24px;width:56px;height:56px;background-color:var(--primary-color);color:#fff;border:none;border-radius:50%;font-size:1.5rem;cursor:pointer;box-shadow:0 4px 10px #0000004d;z-index:99;transition:transform .2s cubic-bezier(.34,1.56,.64,1)}.add-button-mobile:active{transform:scale(.9);background-color:var(--primary-color-darken)}}.course-name{color:var(--text-color)}.stat-value.draft{color:var(--chart-4)}.course-form{display:flex;flex-direction:column;gap:16px}.form-textarea:focus{outline:none;border-color:var(--border-gray);box-shadow:0 0 0 1px var(--primary-color)}.course-form-section{display:flex;flex-direction:column;gap:16px;margin-top:24px}.form-slot{display:flex;gap:1rem}.schedule-input{width:100%}.form-add-new-btn{width:fit-content!important}.course-form-info-container{display:flex;flex-direction:column;justify-content:center;margin-top:auto;height:42px;width:40%}.course-form-info{text-wrap:balance}.administration-page{display:flex;flex-direction:column;gap:24px}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.page-controls{display:flex;gap:16px;align-items:center}.stat-value.active{color:var(--chart-2)}.stat-value.inactive{color:var(--destructive)}.stat-value.current{color:var(--chart-1)}.student-id{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.875rem;color:var(--text-color)}.student-name{color:var(--text-color)}.student-email{font-size:.875rem;color:var(--text-color-gray)}.student-form{display:flex;flex-direction:column;gap:16px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group{display:flex;flex-direction:column;gap:4px}.form-label{font-size:.875rem;color:var(--text-color)}.form-input,.form-select,.form-date,textarea{padding:10px 12px;background-color:var(--input-background);border:1px solid var( --border-lighter-gray);border-radius:var(--border-radius-md);font-size:.875rem;transition:all .2s ease!important}.form-input:focus,.form-select:focus{outline:none;border-color:var(--border-gray);box-shadow:0 0 0 1px var(--primary-color)}.form-input:disabled,.form-select:disabled{background-color:#f0f0f0;cursor:not-allowed;border-color:#e0e0e0}.search-container{position:relative;flex:1;max-width:400px}.search-container:focus-within .search-icon{color:var(--text-color)}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-color-gray);font-size:.875rem;transition:color .1s ease-in-out}.search-input{width:100%;padding:10px 12px 10px 36px;background-color:var(--input-background);border:1px solid var( --border-lighter-gray);border-radius:var(--border-radius-md);font-size:.875rem;transition:all .2s ease}.field-note{font-size:.9rem;color:var(--text-color-gray);margin-top:4px}.form-fieldset{display:flex;flex-direction:column;gap:1rem;border:none;margin-bottom:8px}.form-fieldset legend{margin-bottom:10px;font-weight:600}.form-students-timetable{margin-top:0!important;margin-bottom:8px}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:16px;padding-top:16px;border-top:1px solid var( --border-lighter-gray)}.form-section{display:flex;flex-direction:column;gap:16px}@media (max-width: 768px){.page-header{flex-direction:column;align-items:flex-start}.page-controls{flex-direction:column;align-items:stretch}.search-container{max-width:none}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}}.teacher-account-form{padding:1rem;display:flex;flex-direction:column;gap:1rem}.teacher-account-form h3{margin-top:0;margin-bottom:.5rem;font-size:1.25rem;font-weight:600}.teacher-account-form p{margin-top:0;font-size:.9rem;color:#555}.form-note{font-size:.85rem;background-color:#f4f6f8;padding:10px;border-radius:4px;border:1px solid var(--border-light-gray)}.teacher-account-form-group{display:flex;flex-direction:column;gap:.25rem}.teacher-account-form-group input{padding:10px 12px;border-radius:6px;border:1px solid var(--border-gray);font-size:1rem}.teacher-account-form-group input:disabled{background-color:#f0f0f0;cursor:not-allowed}.teacher-account-form-actions{display:flex;justify-content:flex-end;gap:.75rem;border-top:1px solid #eee;padding-top:1.25rem}.copyable-input-wrapper{display:flex}.copyable-input-wrapper input{flex:1;padding:10px 12px;font-size:.9rem;background-color:#f4f6f8;border:1px solid var(--border-gray);border-right:none;border-radius:6px 0 0 6px;color:#333}.btn-copy{padding:0 16px;border:1px solid #007bff;background-color:#007bff;color:#fff;font-weight:500;cursor:pointer;border-radius:0 6px 6px 0;transition:background-color .2s}.btn-copy:hover{background-color:#0056b3}.form-header-info{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #eee;padding-bottom:.75rem}.form-header-info h3{margin-bottom:0}.alert-danger{background-color:#f8d7da;color:#842029;padding:10px;border-radius:6px;font-size:.9rem;border:1px solid #f5c2c7}.teacher-account-input-error{border-color:#dc3545!important}.teacher-account-form-error{color:#dc3545;font-size:.85rem;margin-top:.25rem}.checkbox-container{display:flex;align-items:center;cursor:pointer;padding:8px 0}.teacher-account-form-group input[type=checkbox]{width:auto;margin-right:10px;cursor:pointer;accent-color:#007bff;height:18px;width:18px;padding:0}.checkbox-label{font-size:.95rem;color:#333;display:flex;align-items:center;gap:8px}.teacher-account-form-actions.space-between{justify-content:space-between}.teacher-account-right-actions{display:flex;gap:.75rem}.teacher-account-btn-danger-outline{background-color:transparent;border:1px solid #dc3545!important;color:#dc3545;padding:10px 18px;width:fit-content;margin-top:2rem;border-radius:6px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s}.teacher-account-btn-danger-outline:hover:not(:disabled){background-color:#dc3545;color:#fff}.teacher-account-btn-danger-outline:disabled{opacity:.5;cursor:not-allowed}.teacher-account-form.success-view{text-align:center;padding:1rem 2rem}.teacher-account-success-header{display:flex;flex-direction:column;align-items:center;gap:1rem}.teacher-account-icon-circle{width:60px;height:60px;background-color:#d1e7dd;color:#198754;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.75rem}.teacher-account-success-content{display:flex;flex-direction:column;gap:1rem;width:100%;margin-bottom:1rem}.teacher-account-email-confirmation{background-color:#e7f1ff;color:#084298;padding:1rem;border-radius:6px;gap:10px;border:1px solid #b6d4fe}.teacher-account-email-warning{background-color:#fff3cd;color:#664d03;padding:1rem;border-radius:6px;border:1px solid #ffecb5}.teacher-account-link-backup{text-align:left;margin-top:.5rem}.teacher-account-link-backup p{font-weight:600;margin-bottom:.5rem;font-size:.8rem;text-transform:uppercase;color:#6c757d}.class-card-mobile-content{display:none;width:100%}.class-card-desktop-content{display:flex;align-items:center;gap:32px;width:100%}.class-card{background-color:var(--background-color-white);border:1px solid var(--border-light-gray);border-radius:var(--border-radius-md);display:flex;align-items:center;padding:32px;transition:border-color .3s ease,box-shadow .3s ease;width:100%}.class-card:hover{border-color:#d0d0d0;box-shadow:0 2px 12px #00000014}.class-card-icon-wrapper{flex-shrink:0}.class-card-icon{width:80px;height:80px;background-color:var(--primary-color);border-radius:99px;display:flex;justify-content:center;align-items:center;color:#fff;font-size:36px}.class-card-icon-private{background-color:var(--private-classes-color)}.class-card-content{flex:1;display:flex;align-items:center;gap:32px;min-width:0}.class-card-info{flex-shrink:0;min-width:240px}.class-card-title{color:var(--text-color)!important;margin:0 0 6px!important;font-size:1.3rem!important;border:none!important;padding:0!important}.class-card-subtitle{color:var(--text-color-gray);margin:0;font-size:.95rem}.class-card-divider{width:1px;height:60px;background-color:#e5e5e5;flex-shrink:0}.class-card-body{display:flex;flex-direction:column;gap:12px;flex:1;min-width:0}.class-info-item{display:flex;align-items:flex-start;color:var(--text-color)}.class-info-icon{color:#999;font-size:.9rem;min-width:16px;text-align:center;margin-right:12px;margin-top:3px}.class-info-value-list{display:flex;flex-direction:column;gap:8px}.class-info-value{color:var(--text-color);font-size:.95rem}.class-card-action{flex-shrink:0}.class-card-button{background-color:#3e91ee;color:var(--background-color-white);border:none;border-radius:6px;padding:12px 28px;font-size:.95rem;cursor:pointer;transition:background-color .3s ease;white-space:nowrap}.class-card-button:hover{background-color:#2e7fd4}.class-card-button:active{background-color:#1e6fc4}@media screen and (max-width: 1190px){.class-card-desktop-content{display:none}.class-card-mobile-content{display:flex;flex-direction:column;align-items:stretch;gap:22px}.class-card{flex-direction:column;align-items:stretch;gap:20px;padding:24px;max-width:none;margin:0}.class-card-divider,.class-card-icon-wrapper{display:none}.class-card-content{flex-direction:column;align-items:stretch;gap:1rem;width:100%}.class-card-info{min-width:0;width:100%;display:flex;align-items:center;gap:16px}.class-card-header-mobile{display:flex;align-items:center;gap:20px;margin-bottom:0;width:100%}.class-card-icon-mobile{width:64px;height:64px;font-size:28px;background-color:var(--primary-color);border-radius:99px;display:flex;justify-content:center;align-items:center;color:var(--background-color-white);flex-shrink:0}.class-card-icon-mobile.private{background-color:var(--private-classes-color)}.class-card-title-wrapper-mobile{flex:1;min-width:0}.class-card-title{font-size:1.15rem;line-height:1.3;margin-bottom:4px}.class-card-subtitle{font-size:.95rem}.class-card-divider-mobile{width:100%;height:1px;background-color:#e5e5e5;margin-bottom:0}.class-card-body{gap:12px;margin-bottom:0;width:100%}.class-info-item{align-items:baseline;gap:20px;width:100%}.class-info-icon{font-size:.95rem;min-width:64px;flex-shrink:0;text-align:left;margin-right:0;margin-top:1px}.class-info-value,.class-info-value-list span{font-size:.95rem;line-height:1.4}.class-info-value-list{gap:6px}.class-card-action{width:fit-content}.class-card-button{width:100%;padding:13px 28px;font-size:1rem}}@media screen and (max-width: 1115px){.class-info-icon{font-size:.95rem;text-align:left;min-width:0;margin-top:0}}@media screen and (max-width: 1015px){.class-card-icon-mobile{width:58px;height:58px;font-size:22px;align-self:flex-start}.class-card-title{font-size:1.1rem;line-height:1.3;margin-bottom:4px}}@media screen and (max-width: 915px){.class-card-mobile-content{gap:22px}.class-card-header-mobile{gap:1rem}.class-info-icon{font-size:.95rem;text-align:left;min-width:0;margin-top:0}}@media screen and (max-width: 710px){.class-card-action{width:100%}}@media screen and (max-width: 620px){.class-card-icon-mobile{width:58px;height:58px;font-size:22px}.class-card-title{font-size:1.1rem;line-height:1.3;margin-bottom:4px}.class-card-subtitle{font-size:.9rem}.class-info-item{gap:.8rem}.class-info-icon{font-size:.9rem}.class-info-value,.class-info-value-list span{font-size:.9rem;line-height:1.4}.class-card-button{width:100%;padding:10px;font-size:.9rem}}@media screen and (max-width: 550px){.class-card-icon-mobile{width:50px;height:50px;font-size:1rem}}@media screen and (max-width: 480px){.class-card{padding:16px}.class-card-header-mobile{gap:12px}.class-card-icon-mobile{width:48px;height:48px;font-size:20px}.class-card-title{font-size:1rem}.class-card-subtitle{font-size:.85rem}.class-card-body{gap:8px}.class-info-icon{font-size:.85rem;min-width:50px}.class-info-value,.class-info-value-list span{font-size:.85rem}.class-card-button{padding:11px 20px;font-size:.9rem;text-align:center}}.teacher-id{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.875rem;color:var(--text-color)}.teacher-name{color:var(--text-color)}.teacher-email{font-size:.875rem;color:var(--text-color-gray)}.stat-value.on-leave{color:var(--chart-4)}.teacher-form{display:flex;flex-direction:column;gap:16px}.form-row-3{grid-template-columns:1fr 1fr 1fr}input[type=date i]{font-family:Poppins;line-height:1}.form-textarea{padding:10px 12px;background-color:var(--input-background);border:1px solid var( --border-lighter-gray);border-radius:var(--border-radius-md);font-size:.875rem;font-family:inherit;resize:vertical;min-height:80px;transition:all .2s ease}.teacher-classes-grid{display:grid;gap:1.5rem;width:100%;margin-top:1rem}.no-classes-message{color:#666;font-style:italic;padding:1rem;background-color:var(--background-color-light-gray);border-radius:6px;text-align:center}@media (max-width: 768px){.form-row-3{grid-template-columns:1fr}}.rbc-btn{color:inherit;font:inherit;margin:0}button.rbc-btn{overflow:visible;text-transform:none;-webkit-appearance:button;-moz-appearance:button;appearance:button;cursor:pointer}button[disabled].rbc-btn{cursor:not-allowed}button.rbc-input::-moz-focus-inner{border:0;padding:0}.rbc-calendar{-webkit-box-sizing:border-box;box-sizing:border-box;height:100%;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-align:stretch;-ms-flex-align:stretch;align-items:stretch}.rbc-m-b-negative-3{margin-bottom:-3px}.rbc-h-full{height:100%}.rbc-calendar *,.rbc-calendar *:before,.rbc-calendar *:after{-webkit-box-sizing:inherit;box-sizing:inherit}.rbc-abs-full,.rbc-row-bg{overflow:hidden;position:absolute;inset:0}.rbc-ellipsis,.rbc-show-more,.rbc-row-segment .rbc-event-content,.rbc-event-label{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{overflow:hidden;-webkit-box-flex:1;-ms-flex:1 0 0%;flex:1 0 0%;text-overflow:ellipsis;white-space:nowrap;padding:0 3px;text-align:center;vertical-align:middle;font-weight:700;font-size:90%;min-height:0;border-bottom:1px solid #ddd}.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{color:inherit;background:none;margin:0;padding:0;border:none;cursor:pointer;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}.rbc-row-content{position:relative;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-user-select:none;z-index:4}.rbc-row-content-scrollable{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;height:100%}.rbc-row-content-scrollable .rbc-row-content-scroll-container{height:100%;overflow-y:scroll;-ms-overflow-style:none;scrollbar-width:none}.rbc-row-content-scrollable .rbc-row-content-scroll-container::-webkit-scrollbar{display:none}.rbc-today{background-color:#eaf6ff}.rbc-toolbar{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;margin-bottom:10px;font-size:16px}.rbc-toolbar .rbc-toolbar-label{-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;padding:0 10px;text-align:center}.rbc-toolbar button{color:#373a3c;display:inline-block;margin:0;text-align:center;vertical-align:middle;background:none;background-image:none;border:1px solid #ccc;padding:.375rem 1rem;border-radius:4px;line-height:normal;white-space:nowrap}.rbc-toolbar button:active,.rbc-toolbar button.rbc-active{background-image:none;-webkit-box-shadow:inset 0 3px 5px rgba(0,0,0,.125);box-shadow:inset 0 3px 5px #00000020;background-color:#e6e6e6;border-color:#adadad}.rbc-toolbar button:active:hover,.rbc-toolbar button:active:focus,.rbc-toolbar button.rbc-active:hover,.rbc-toolbar button.rbc-active:focus{color:#373a3c;background-color:#d4d4d4;border-color:#8c8c8c}.rbc-toolbar button:focus{color:#373a3c;background-color:#e6e6e6;border-color:#adadad}.rbc-toolbar button:hover{color:#373a3c;cursor:pointer;background-color:#e6e6e6;border-color:#adadad}.rbc-btn-group{display:inline-block;white-space:nowrap}.rbc-btn-group>button:first-child:not(:last-child){border-top-right-radius:0;border-bottom-right-radius:0}.rbc-btn-group>button:last-child:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.rbc-rtl .rbc-btn-group>button:first-child:not(:last-child){border-radius:0 4px 4px 0}.rbc-rtl .rbc-btn-group>button:last-child:not(:first-child){border-radius:4px 0 0 4px}.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{-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}}.rbc-event,.rbc-day-slot .rbc-background-event{border:none;-webkit-box-sizing:border-box;box-sizing:border-box;-webkit-box-shadow:none;box-shadow:none;margin:0;padding:2px 5px;background-color:#3174ad;border-radius:5px;color:#fff;cursor:pointer;width:100%;text-align:left}.rbc-slot-selecting .rbc-event,.rbc-slot-selecting .rbc-day-slot .rbc-background-event,.rbc-day-slot .rbc-slot-selecting .rbc-background-event{cursor:inherit;pointer-events:none}.rbc-event.rbc-selected,.rbc-day-slot .rbc-selected.rbc-background-event{background-color:#265985}.rbc-event:focus,.rbc-day-slot .rbc-background-event:focus{outline:5px auto #3b99fc}.rbc-event-label{font-size:80%}.rbc-event-overlaps{-webkit-box-shadow:-1px 1px 5px 0px rgba(51,51,51,.5);box-shadow:-1px 1px 5px #33333380}.rbc-event-continues-prior{border-top-left-radius:0;border-bottom-left-radius:0}.rbc-event-continues-after{border-top-right-radius:0;border-bottom-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:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.rbc-row-segment{padding:0 1px 1px}.rbc-selected-cell{background-color:#0000001a}.rbc-show-more{background-color:#ffffff4d;z-index:4;font-weight:700;font-size:85%;height:auto;line-height:normal;color:#3174ad}.rbc-show-more:hover,.rbc-show-more:focus{color:#265985}.rbc-month-view{position:relative;border:1px solid #ddd;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;width:100%;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-user-select:none;height:100%}.rbc-month-header{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.rbc-month-row{display:-webkit-box;display:-ms-flexbox;display:flex;position:relative;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;-ms-flex-preferred-size:0px;flex-basis:0px;overflow:hidden;height:100%}.rbc-month-row+.rbc-month-row{border-top:1px solid #ddd}.rbc-date-cell{-webkit-box-flex:1;-ms-flex:1 1 0px;flex:1 1 0;min-width:0;padding-right:5px;text-align:right}.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:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;overflow:hidden;right:1px}.rbc-day-bg{-webkit-box-flex:1;-ms-flex:1 0 0%;flex:1 0 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{position:absolute;z-index:5;border:1px solid #e5e5e5;background-color:#fff;-webkit-box-shadow:0 5px 15px rgba(0,0,0,.25);box-shadow:0 5px 15px #00000040;padding:10px}.rbc-overlay>*+*{margin-top:1px}.rbc-overlay-header{border-bottom:1px solid #e5e5e5;margin:-10px -10px 5px;padding:2px 10px}.rbc-agenda-view{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;overflow:auto}.rbc-agenda-view table.rbc-agenda-table{width:100%;border:1px solid #ddd;border-spacing:0;border-collapse:collapse}.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{padding:3px 5px;text-align:left;border-bottom:1px solid #ddd}.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:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;min-height:100%}.rbc-time-column .rbc-timeslot-group{-webkit-box-flex:1;-ms-flex:1;flex:1}.rbc-timeslot-group{border-bottom:1px solid #ddd;min-height:40px;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-flow:column nowrap;flex-flow:column nowrap}.rbc-time-gutter,.rbc-header-gutter{-webkit-box-flex:0;-ms-flex:none;flex:none}.rbc-label{padding:0 5px}.rbc-day-slot{position:relative}.rbc-day-slot .rbc-events-container{inset:0;position:absolute;margin-right:10px}.rbc-day-slot .rbc-events-container.rbc-rtl{left:10px;right:0}.rbc-day-slot .rbc-event,.rbc-day-slot .rbc-background-event{border:1px solid #265985;display:-webkit-box;display:-ms-flexbox;display:flex;max-height:100%;min-height:20px;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-flow:column wrap;flex-flow:column wrap;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start;overflow:hidden;position:absolute}.rbc-day-slot .rbc-background-event{opacity:.75}.rbc-day-slot .rbc-event-label{-webkit-box-flex:0;-ms-flex:none;flex:none;padding-right:5px;width:auto}.rbc-day-slot .rbc-event-content{width:100%;-webkit-box-flex:1;-ms-flex:1 1 0px;flex:1 1 0;word-wrap:break-word;line-height:1;height:100%;min-height:1em}.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{position:sticky;left:0;background-color:#fff;border-right:1px solid #ddd;z-index:10;margin-right:-1px}.rbc-time-view-resources .rbc-time-header{overflow:hidden}.rbc-time-view-resources .rbc-time-header-content{min-width:auto;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;-ms-flex-preferred-size:0px;flex-basis:0px}.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-header,.rbc-time-view-resources .rbc-day-bg{width:140px;-webkit-box-flex:1;-ms-flex:1 1 0px;flex:1 1 0;-ms-flex-preferred-size:0 px;flex-basis:0 px}.rbc-time-header-content+.rbc-time-header-content{margin-left:-1px}.rbc-time-slot{-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0}.rbc-time-slot.rbc-now{font-weight:700}.rbc-day-header{text-align:center}.rbc-slot-selection{z-index:10;position:absolute;background-color:#00000080;color:#fff;font-size:75%;width:100%;padding:3px}.rbc-slot-selecting{cursor:move}.rbc-time-view{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-flex:1;-ms-flex:1;flex:1;width:100%;border:1px solid #ddd;min-height:0}.rbc-time-view .rbc-time-gutter{white-space:nowrap;text-align:right}.rbc-time-view .rbc-allday-cell{-webkit-box-sizing:content-box;box-sizing:content-box;width:100%;height:100%;position:relative}.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{-webkit-box-sizing:border-box;box-sizing:border-box;min-height:20px}.rbc-time-header{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.rbc-time-header.rbc-overflowing{border-right:1px solid #ddd}.rbc-rtl .rbc-time-header.rbc-overflowing{border-right-width:0;border-left:1px solid #ddd}.rbc-time-header>.rbc-row:first-child{border-bottom:1px solid #ddd}.rbc-time-header>.rbc-row.rbc-row-resource{border-bottom:1px solid #ddd}.rbc-time-header-cell-single-day{display:none}.rbc-time-header-content{-webkit-box-flex:1;-ms-flex:1;flex:1;display:-webkit-box;display:-ms-flexbox;display:flex;min-width:0;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;border-left:1px solid #ddd}.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;-ms-flex-negative:0;flex-shrink:0}.rbc-time-content{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-flex:1;-ms-flex:1 0 0%;flex:1 0 0%;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start;width:100%;border-top:2px solid #ddd;overflow-y:auto;position:relative}.rbc-time-content>.rbc-time-gutter{-webkit-box-flex:0;-ms-flex:none;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{width:100%;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-user-select:none}.rbc-current-time-indicator{position:absolute;z-index:3;left:0;right:0;height:1px;background-color:#74ad31;pointer-events:none}.rbc-resource-grouping.rbc-time-header-content{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.rbc-resource-grouping .rbc-row .rbc-header{width:141px}.schedule-main-container{display:flex;flex-direction:column;height:100%;flex:1}.schedule-loader-container{display:flex;justify-content:center;align-items:center;height:100%;width:100%;flex-grow:1}.schedule-calendar-wrapper{flex:1;overflow-x:auto;overflow-y:auto;padding-bottom:8px}.schedule-week{display:grid;grid-template-columns:repeat(6,auto);gap:12px;align-items:start;padding:8px}.day-column{display:flex;flex-direction:column;border:2px solid #424242;border-radius:var(--border-radius-md);background:var(--background-color-white);min-width:min-content}.day-column-header{font-weight:600;padding:10px 12px;border-bottom:1px solid #424242;position:sticky;top:0;color:var(--background-color-gray);background-color:#282e54;z-index:2;white-space:nowrap}.day-calendar{flex:1;overflow:visible!important}.day-column:not(:first-child) .rbc-time-gutter{display:none}.day-column:not(:first-child) .rbc-time-header-gutter{display:none}.rbc-time-header-content>.rbc-row.rbc-row-resource{border-bottom:none!important;width:100%}.rbc-time-slot{display:flex;align-items:center;justify-content:center}.rbc-timeslot-group{min-height:35px}.rbc-label{font-size:.85rem}.rbc-event{border:1px solid #424242;transition:border-color .09s ease-in;white-space:normal!important;overflow:hidden}.rbc-event:hover{border-color:var(--text-color)!important}.rbc-event:not(.availability-event):hover{min-height:fit-content!important;z-index:50!important;opacity:1!important;box-shadow:0 4px 8px #0000004d}.rbc-time-view-resources .rbc-day-slot{width:100%}.day-column:not(:first-child) .rbc-time-gutter,.day-column:not(:first-child) .rbc-time-header-gutter{display:none}.rbc-time-view{border:0}.rbc-allday-cell{display:none!important}.rbc-time-header-content{border-left:1px solid #424242!important}.rbc-header{border-bottom:none!important;padding:0!important}.rbc-time-content{border-top:2px solid #424242}.rbc-today{background-color:inherit!important}.rbc-current-time-indicator{display:none}.rbc-time-gutter.rbc-time-column{background-color:#ececec}.rbc-day-slot,.rbc-events-container{margin-right:0!important}.rbc-event{border:1px solid #424242;width:100%!important;left:0!important;right:0!important}.rbc-time-view-resources .rbc-day-slot{min-width:0!important;width:100%}.rbc-time-view-resources .rbc-header,.rbc-time-view-resources .rbc-day-bg{width:auto!important;min-width:0!important;flex:1 1 0px!important}.rbc-row-resource .rbc-header{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rbc-event-label{font-size:95%;font-weight:600}.rbc-event-content{white-space:normal!important;height:auto!important}.rbc-event.availability-event{width:100%!important;left:0!important;right:0!important;max-width:none!important}.options-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:998;opacity:0;visibility:hidden;transition:opacity .3s ease}.options-overlay.open{opacity:1;visibility:visible}.options-drawer{position:fixed;top:0;right:0;width:320px;height:100%;background:#fff;box-shadow:-2px 0 10px #0003;z-index:999;transform:translate(100%);transition:transform .3s ease-in-out;display:flex;flex-direction:column}.options-drawer.open{transform:translate(0)}.options-header{padding:15px 20px;background:#282e54;color:#fff;display:flex;justify-content:space-between;align-items:center}.close-btn{background:none;border:none;color:#fff;font-size:2rem;cursor:pointer}.options-content{padding:20px;height:auto}.options-container{margin-bottom:20px}.availability-section{height:100%}.options-container h4{margin-top:0;margin-bottom:10px;color:#333}.availability-section-teacher-name{font-weight:500;color:var(--text-color-dark-gray)}.availability-section-teacher-name:hover{color:var(--text-color)}.toggle-container,.checkbox-item{display:flex;align-items:center;gap:10px;cursor:pointer;margin-bottom:8px}.help-text{font-size:.85rem;color:#666;display:block;margin-top:5px}.divider{border:0;border-top:1px solid #eee;margin:20px 0}.teachers-list{display:flex;flex-direction:column;gap:5px;overflow-y:auto}.schedule-options-trigger-container{position:fixed;bottom:40px;right:40px;height:55px;width:55px;text-align:center;border-radius:9999px;background-color:var(--primary-color-full-darken);color:var(--background-color-white);border:none;box-shadow:0 4px 6px #0000004d;cursor:pointer;font-size:1.2rem;z-index:100}.schedule-options-trigger-icon{transform:translate(-.02rem)}.input-group{position:relative;display:flex;flex-direction:column;gap:10px}.register-input,.login-input{width:100%;margin-top:2rem;margin-bottom:1.5rem}.form-item{border:none;outline:none;border-bottom:2px solid var(--border-gray);background-color:var(--background-color-white);display:block;width:100%;color:var(--text-color);font-family:Poppins,sans-serif;font-size:1rem;font-weight:400;height:2.5rem;padding:0 .4rem;transition:all .2s ease-in-out}.form-item::placeholder{color:transparent;font-size:.9rem;font-family:Poppins,sans-serif}.form-item:focus{border-bottom:2px solid var(--primary-color)}input:-webkit-autofill,input:-webkit-autofill:hover,input:-webkit-autofill:focus,input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 1000px var(--background-color-white) inset!important;-webkit-text-fill-color:var(--text-color)!important}.placeholder-label{position:absolute;font-family:Poppins,sans-serif;left:.4rem;top:5px;color:var(--text-color-light-gray);cursor:text;transition:all .2s ease;pointer-events:none}.form-item:focus+.placeholder-label,.form-item:-webkit-autofill+.placeholder-label,.form-item:not(:placeholder-shown)+.placeholder-label{top:-1rem;font-size:.75rem;color:var(--primary-color)}.error-container{display:flex;align-items:center;gap:7px}.error-icon{font-size:1.1rem;color:var(--destructive)}.error-msg{font-size:.85rem;color:var(--destructive);transform:translateY(.032rem)}@media screen and (max-width: 1350px){.form-item{font-size:.9rem}}@media screen and (max-width: 899px){.input-group{width:100%}}@media screen and (max-width: 409px){.form-item::placeholder{font-size:.8rem}}.login-btn{margin:0!important}.login-form-container{display:flex;flex-direction:column;width:100%;gap:.5rem}.form-section-title{font-weight:500;font-size:1rem}.login-title{margin:15px 0}.login-form-section{margin:30px 0 16px}.match-error{margin-top:-15px}.register-submit-btn{margin:1.5rem auto 2rem!important}@media screen and (max-width: 1350px){.form-section-title{font-size:.9rem}.login-btn{font-size:.9rem!important;padding:.75rem 2.25rem!important}}@media screen and (max-width: 984px){.select-label{font-size:.8rem}.form-item::placeholder{font-size:.8rem}}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border:none;border-radius:var(--border-radius-md);cursor:pointer;transition:all .2s ease;text-decoration:none;font-size:.875rem}.confirmation-modal-btn{padding:10px 16px;border-radius:var(--border-radius-md);border:1px solid transparent;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease,border-color .2s ease}.menu-btn{display:block;width:100%}.cart-button{font-family:Poppins,sans-serif;font-size:1rem;border:none;padding:10px}.admin-add-product-btn{font-size:1rem;letter-spacing:-.02rem;text-wrap:nowrap;padding:12px 40px}.product-detail-add{font-size:1rem;padding:1rem}.btn-img{height:max-content}.submit-btn{display:flex;justify-content:center;align-content:center;align-self:center;background-color:var(--primary-color);color:var(--background-color-white);font-family:Poppins;font-weight:500;font-size:1rem;letter-spacing:-.02rem;text-wrap:nowrap;border:none;border-radius:9999px;transition:opacity .2s;cursor:pointer;padding:.9rem 3rem;margin:1rem auto 0}.btn-primary{background-color:var(--primary-color)!important;color:var(--background-color-white)!important;border:solid 1px var(--primary-color)!important;transition:all .1s ease-in-out!important}.btn-primary:hover{background-color:var(--primary-color-darken)!important;border-color:var(--primary-color-darken)!important}.btn-secondary{color:var(--text-color);background-color:transparent;border:solid 1px var(--border-gray);transition:all .2s ease-in-out}.btn-secondary:hover{background-color:var(--input-background);border-color:var(--text-color)}.modal-btn{padding:10px 25px;width:7.75rem!important}.checkout-btn{width:11rem}.disabled{background-color:#474747!important;border:solid 1px #474747!important;opacity:.9}.disabled:hover{background-color:#474747!important}.login-form-main-container{display:flex;flex-direction:column;justify-content:center;align-items:center;margin:auto;height:100dvh;max-width:500px}.login-logo{width:180px}.login-no-account-message{margin-top:1.5rem;font-size:.9rem;color:var(--text-color-gray)}.login-no-account-link{color:var(--text-color);font-weight:600;text-decoration:none}.login-no-account-link:hover{text-decoration:underline}@media screen and (max-width: 1350px){.login-logo{width:150px}.login-no-account-message{font-size:.8rem}}@media screen and (max-width: 690px){.login-form-main-container{max-width:400px}}@media screen and (max-width: 478px){.login-form-main-container{padding:0 40px}.login-no-account-message,.login-no-account-link{text-align:center}}.mis-clases-page{display:flex;flex-direction:column;gap:24px;flex:1;padding:1rem}.mis-clases-header{margin-bottom:2rem}.mis-clases-header h1{margin:0;font-size:2rem;color:var(--text-color);line-height:1}.mis-clases-header p{font-size:1.1rem;color:#4b5563;margin-top:.5rem}.class-card-grid{display:flex;flex-direction:column;gap:1.5rem}@media screen and (max-width: 1190px){.class-card-grid{flex-direction:row;flex-wrap:wrap;gap:2rem}.class-card{flex-basis:400px}}@media screen and (max-width: 1115px){.class-card{flex-basis:350px}}@media screen and (max-width: 1015px){.class-card{flex-basis:300px}}@media screen and (max-width: 915px){.class-card{flex-basis:inherit}}.custom-select-container{position:relative;width:100%;min-width:250px}.custom-select-trigger{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:8px 12px;background-color:var(--background-color-white);border:1px solid var(--border-light-gray);border-radius:6px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:border-color .2s}.custom-select-trigger:hover{border-color:var(--border-light-gray-hover)}.custom-select-trigger-disabled{background-color:#f3f4f6;cursor:not-allowed;border-color:#e0e0e0}.selected-value{display:flex;align-items:center;gap:10px;font-size:.95rem;color:var(--text-color)}.placeholder-text{color:var(--text-color);font-size:.95rem;line-height:1.2}.select-arrow{color:#9ca3af;font-size:.72rem}.custom-options-list{position:absolute;top:100%;left:0;right:0;background-color:#fff;border:1px solid var(--border-light-gray);border-radius:6px;box-shadow:0 4px 6px #0000001a;margin-top:4px;z-index:50;max-height:300px;overflow-y:auto}.custom-option{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;transition:background-color .1s;border-bottom:1px solid #f3f4f6}.custom-option:last-child{border-bottom:none}.custom-option:hover{background-color:#f9fafb}.custom-option.selected{background-color:#eff6ff}.subject-icon-wrapper{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;flex-shrink:0}.subject-icon-wrapper.course{background-color:#e0e7ff;color:#4338ca}.subject-icon-wrapper.student{background-color:#dcfce7;color:#15803d}.subject-name{font-weight:500;color:#374151;line-height:1.2;font-size:.95rem}.subject-type-label{font-size:.75rem;color:#6b7280;margin-left:auto}.planning-page{display:flex;flex-direction:column;gap:24px;padding:1rem}.planning-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.planning-header h1{margin:0;line-height:1;font-size:2rem;color:var(--text-color)}.planning-header p{font-size:1.1rem;color:#4b5563;margin-top:.5rem}.loading-message,.error-message,.select-student-prompt{padding:1rem;margin-top:1rem;border-radius:6px;text-align:center}.loading-message{color:#4b5563}.planning-admin-selector-container{margin-bottom:1.5rem}.select-student-prompt{background-color:var(--background-warning);color:var(--text-color-warning);border:1px solid var(--border-warning)}.no-links-message{display:flex;gap:.8rem;align-items:flex-start}.no-links-icon{color:var(--text-color-light-gray);padding-top:.16rem}.no-links-text{font-size:.9rem;color:var(--text-color-light-gray);font-weight:500}.planning-content-container{display:flex;flex-direction:column;gap:2rem}.planning-main-section{display:flex;flex-direction:column;background-color:var(--background-color-white);border:1px solid var(--border-lighter-gray);padding:1.5rem 2rem 2rem;border-radius:var(--card-border-radius);box-shadow:0 4px 6px #0000000d}.planning-main-section h2{font-size:1.5rem;color:var(--text-color);margin-top:0;margin-bottom:1rem}.planning-controls{display:flex;gap:1.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.planning-control-group{display:flex;align-items:center;gap:.75rem}.planning-control-group label{font-weight:500;color:#374151}.planning-control-group select{padding:8px 2.5rem 8px 12px;border-radius:6px;border:1px solid var(--border-light-gray);background-color:var(--background-color-white);font-size:.95rem;min-width:150px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.add-entry-button{margin-bottom:1rem;display:inline-flex;align-items:center;gap:.5rem}.planning-table{width:100%;border-collapse:collapse;margin-top:1rem;border-radius:var(--border-radius-md);border:1px solid var(--muted)}.planning-table th,.planning-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #f3f4f6}.planning-table th{background-color:#f9fafb;font-weight:600;color:#4b5563;font-size:.85rem;text-transform:uppercase}.planning-table tr:last-child td{border-bottom:none}.planning-table th:first-child,.planning-table td:first-child{width:100px}.planning-table th:last-child,.planning-table td:last-child{width:35%}.planning-table .activities-cell{white-space:pre-wrap;word-break:break-word}.planning-table .homework-cell{white-space:pre-wrap;word-break:break-word;color:#4b5563}.planning-table th.column-actions,.planning-table td.action-cell{width:100px;text-align:center;vertical-align:middle}.btn-icon{background:none;border:none;padding:5px;cursor:pointer;color:#9ca3af;font-size:.95rem;line-height:1;transition:color .2s}.btn-icon:hover{color:var(--primary-color, #3b82f6)}.btn-icon.btn-delete:hover{color:#ef4444}.btn-icon:disabled{color:#d1d5db;cursor:not-allowed}.absence-text{font-weight:600;font-style:italic}tr.entry-absent-excused td{background-color:#fef9c3;color:#713f12}tr.entry-absent-excused .absence-text{color:#b45309}tr.entry-absent-unexcused td{background-color:#fee2e2;color:#7f1d1d}tr.entry-absent-unexcused .absence-text{color:#b91c1c}.planning-links-section{background-color:var(--background-color-white);border:1px solid var(--border-lighter-gray);padding:1.5rem 2rem 2rem;border-radius:var(--card-border-radius);box-shadow:0 4px 6px #0000000d;align-self:start;width:100%}.planning-links-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e5e7eb;padding-bottom:1rem;margin-bottom:1.5rem}.planning-links-header h2{margin:0;padding:0;border:none;font-size:1.5rem;color:var(--text-color)}.btn-edit-links:disabled{opacity:.5;cursor:not-allowed}.links-container{display:flex;flex-direction:row;flex-wrap:wrap;align-items:center;gap:1rem}.planning-link-button{display:inline-flex;align-items:center;gap:.75rem;text-decoration:none}.planning-link-button.disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.edit-links-form{display:flex;flex-direction:column;gap:1.25rem}.planning-entry-form{display:flex;flex-direction:column;gap:1rem}.planning-entry-form .form-group input,.planning-entry-form .form-group textarea{padding:10px 12px;border-radius:6px;border:1px solid var(--border-gray);font-size:1rem;width:100%;box-sizing:border-box;font-family:inherit}.planning-entry-form .form-group textarea{resize:vertical}.planning-entry-form .form-group textarea:focus,.planning-entry-form .form-group .form-date:focus{outline:none;border-color:var(--border-gray);box-shadow:0 0 0 1px var(--primary-color)}.form-group-radio{display:flex;gap:1.5rem;background-color:#f9fafb;padding:.75rem 1rem;border-radius:6px;border:1px solid var(--input-background)}.form-group-radio label{display:flex;align-items:center;gap:.5rem;font-weight:500;color:#374151;cursor:pointer}.form-group-radio input[type=radio]{width:1.1em;height:1.1em;accent-color:var(--primary-color, #3b82f6)}.entry-delete-preview{margin-top:1rem;padding:.75rem;background-color:var(--background-color-white);border-radius:4px;border:1px solid var(--border-light-gray);font-size:.9rem;color:var(--text-color-dark-gray)}.entry-delete-preview strong{color:var(--text-color)}.admin-note-badge{background-color:#fffbeb;color:#b45309;padding:4px 8px;border-radius:4px;font-size:.85rem;border:1px solid #fcd34d;white-space:pre-wrap}.planning-mobile-list{display:flex;flex-direction:column;gap:1rem}.planning-card{background-color:var(--background-color-white);border:1px solid var(--border-lighter-gray);border-radius:var(--card-border-radius);box-shadow:0 2px 4px #00000005;overflow:hidden;display:flex;flex-direction:column}.planning-card-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background-color:#f9fafb;border-bottom:1px solid var(--border-lighter-gray)}.planning-card-date{font-weight:600;color:var(--text-color);text-transform:capitalize;font-size:.95rem}.planning-card-actions{display:flex;gap:.5rem}.btn-icon-mobile{width:32px;height:32px;border-radius:6px;border:1px solid transparent;background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.9rem}.btn-icon-mobile.edit{color:var(--chart-2)}.btn-icon-mobile.edit:hover{background-color:#6699991a}.btn-icon-mobile.delete{color:var(--destructive)}.btn-icon-mobile.delete:hover{background-color:#dc26261a}.planning-card-body{padding:1rem;display:flex;flex-direction:column;gap:.8rem}.planning-card-row{display:flex;flex-direction:column;gap:.25rem}.planning-text{color:var(--text-color);line-height:1.5;white-space:pre-wrap}.planning-text-sm{color:var(--text-color-dark-gray);font-size:.9rem;white-space:pre-wrap}.planning-card.entry-absent-excused{border-left:4px solid #b45309}.planning-card.entry-absent-excused .planning-card-header{background-color:#fefce8}.planning-card.entry-absent-unexcused{border-left:4px solid #b91c1c}.planning-card.entry-absent-unexcused .planning-card-header{background-color:#fef2f2}.planning-absence-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-weight:600;font-size:.85rem;background-color:var(--muted);color:var(--text-color);width:fit-content}.planning-card.entry-absent-excused .planning-absence-badge{background-color:#fef9c3;color:#713f12}.planning-card.entry-absent-unexcused .planning-absence-badge{background-color:#fee2e2;color:#7f1d1d}.no-entries-mobile{text-align:center;padding:2rem;color:var(--text-color-gray);background-color:var(--input-background);border-radius:var(--border-radius-md)}@media (max-width: 1024px){.planning-links-section{align-self:stretch}.no-links-message{align-items:center}.no-links-icon{padding-top:0}}@media (max-width: 768px){.planning-page{padding:1rem;gap:16px}.btn-edit-links .btn-text-mobile-hidden{display:none}.btn-edit-links{padding:8px 12px;min-width:0;aspect-ratio:1;display:flex;align-items:center;justify-content:center}.planning-admin-selector-container{margin-bottom:1rem}.planning-controls{flex-direction:column;gap:1rem}.planning-control-group{flex-direction:column;align-items:stretch;gap:.4rem}.planning-control-group select,.planning-control-group input{width:100%;min-width:0}.links-container{flex-direction:column}.planning-link-button{width:100%}.add-entry-button{width:100%;justify-content:center;padding:12px}.planning-main-section{padding:1rem}}.worked-hours-page{display:flex;flex-direction:column;gap:24px;padding:1rem;flex:1}.worked-hours-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb;flex-shrink:0}.worked-hours-header h1{margin:0;line-height:1;font-size:2rem;color:var(--text-color)}.worked-hours-header p{font-size:1.1rem;color:#4b5563;margin-top:.5rem}.worked-hours-controls{display:flex;gap:1.5rem;width:fit-content;align-items:center;background-color:var(--background-color-white);border:1px solid var(--border-light-gray);padding:1rem 2rem;border-radius:var(--border-radius-md);box-shadow:0 2px 4px #0000000d}.worked-hours-control-group{display:flex;align-items:center;gap:.75rem}.worked-hours-control-group label{font-weight:500;color:#374151}.worked-hours-control-group select{padding:8px 2.5rem 8px 12px;border-radius:6px;border:1px solid var(--border-light-gray);background-color:var(--background-color-white);font-size:1rem;min-width:130px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.loading-message,.error-message,.select-prompt{text-align:center;padding:2rem;font-size:1.1rem;color:#6b7280}.select-prompt{background-color:var(--background-warning);border:1px solid var(--border-warning);color:var(--text-color-warning);border-radius:6px;padding:1rem;margin-bottom:2rem;max-width:1000px}.error-message{color:var(--destructive);background-color:var(--error-bg-color, #fee2e2);border:1px solid var(--error-border-color, #fca5a5);border-radius:6px;padding:1rem;margin-bottom:2rem;max-width:1000px}.worked-hours-table-container{background-color:var(--background-color-white);width:100%;max-width:1000px;border-radius:var(--border-radius-md);border:1px solid var(--border-light-gray);box-shadow:0 4px 6px #0000000d;overflow:hidden}.worked-hours-table{width:100%;border-collapse:collapse}.worked-hours-table th,.worked-hours-table td{padding:1rem 1.25rem;text-align:left;border-bottom:1px solid #f3f4f6}.worked-hours-table th{background-color:#f9fafb;font-weight:600;color:#4b5563;font-size:.9rem;text-transform:uppercase;letter-spacing:.05em}.entry-name-cell{position:relative;font-weight:500;color:#1f2937}.worked-hours-table td:first-child{font-weight:500;color:#1f2937}.worked-hours-table td:last-child{width:150px}.worked-hours-table tr:last-child td{border-bottom:none}.hours-input{width:100%;padding:8px 10px!important;font-size:1rem;text-align:left;box-sizing:border-box}.hours-input::placeholder{text-align:left}.hours-input.input-error{border-color:var(--destructive);background-color:var(--error-bg-light, #fef2f2)}.hours-input.input-error:focus{box-shadow:0 0 0 2px var(--error-border-color, #fca5a5)}.btn-delete-row{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;padding:5px;cursor:pointer;color:#9ca3af;font-size:.9rem;line-height:1;visibility:hidden;opacity:0;transition:visibility .1s,opacity .1s ease-in-out}.hour-entry-row:hover .btn-delete-row{visibility:visible;opacity:1}.btn-delete-row:hover{color:#ef4444}.btn-delete-row:disabled{color:#d1d5db;cursor:not-allowed}.table-actions-container{padding:1.5rem 1.25rem;background-color:#f9fafb;display:flex;justify-content:space-between;align-items:center;border-top:1px solid #f3f4f6}.add-extra-button{display:flex;align-items:center;gap:.5rem}.add-extra-button:disabled{opacity:.6;cursor:not-allowed}.save-hours-button:disabled{opacity:.6;cursor:not-allowed}.add-extra-form{display:flex;flex-direction:column;gap:1rem}.add-extra-form .form-group{display:flex;flex-direction:column;gap:.25rem}.add-extra-form .form-group input{padding:10px 12px;border-radius:6px;border:1px solid var(--border-gray);font-size:1rem}.add-extra-form .form-group input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px var(--primary-light-color, #bfdbfe)}.add-extra-form .form-group input.input-error{border-color:var(--destructive)}.form-error-modal{font-size:.8rem;color:var(--destructive);margin-top:2px}.form-actions-modal{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #eee}@media (max-width: 768px){.worked-hours-controls{flex-direction:column;align-items:stretch;width:100%;padding:1rem;gap:1rem;box-sizing:border-box}.worked-hours-control-group{flex-direction:column;align-items:flex-start;gap:.4rem;width:100%}.worked-hours-control-group select{width:100%;min-width:0}.worked-hours-table-container{border:none;box-shadow:none;background-color:transparent}.worked-hours-mobile-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.hour-card{background-color:var(--background-color-white);border:1px solid var(--border-lighter-gray);border-radius:var(--card-border-radius);box-shadow:0 2px 4px #00000005;overflow:hidden}.hour-card-header{display:flex;justify-content:space-between;align-items:center;padding:.8rem 1rem;background-color:#f9fafb;border-bottom:1px solid var(--border-lighter-gray)}.hour-card-title{font-weight:600;color:var(--text-color);font-size:.95rem}.hour-card-body{padding:1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.hour-input-label{font-size:.9rem;color:var(--text-color-gray)}.hours-input-mobile{width:100px;padding:10px;font-size:1.1rem;text-align:center;border:1px solid var(--border-gray);border-radius:6px;font-weight:500}.hours-input-mobile:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px var(--primary-light-color, #bfdbfe)}.hours-input-mobile.input-error{border-color:var(--destructive);background-color:#fef2f2}.btn-icon-mobile.delete{width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:var(--destructive);background:#dc26261a;border-radius:6px;border:none}.table-actions-container{flex-direction:column;gap:.8rem;padding:1rem;background-color:var(--background-color-white);border:1px solid var(--border-lighter-gray);border-radius:var(--card-border-radius)}.add-extra-button,.save-hours-button{width:100%;justify-content:center;padding:12px;font-size:1rem}.no-hours-msg{text-align:center;color:var(--text-color-gray);font-style:italic;padding:2rem}}.my-profile-page{display:flex;flex-direction:column;gap:24px;padding:1rem;width:100%;max-width:900px;margin:0 auto}.profile-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.profile-header h1{margin:0;line-height:1;font-size:2rem;color:var(--text-color)}.profile-header p{font-size:1.1rem;color:#4b5563;margin-top:.5rem}.profile-loading,.profile-error{text-align:center;padding:3rem 1rem;font-size:1.2rem;color:#6b7280}.profile-error{color:var(--error-color, #dc2626)}.success-message{background-color:#d1fae5;color:#065f46;border:1px solid #6ee7b7;padding:1rem 1.5rem;border-radius:6px;margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem}.error-message.form-error{background-color:var(--error-bg-color, #fee2e2);color:var(--error-color, #dc2626);border:1px solid var(--error-border-color, #fca5a5);padding:1rem 1.5rem;border-radius:6px;margin-bottom:1.5rem;text-align:center}.profile-form{display:flex;flex-direction:column;gap:2.5rem}.profile-section{background-color:var(--background-color-white);border:1px solid var(--border-lighter-gray);padding:1.5rem 2rem 2rem;border-radius:var(--border-radius-md);box-shadow:0 4px 6px #0000000d}.profile-section h2{font-size:1.5rem;color:var(--text-color);border-bottom:1px solid #e5e7eb;padding-bottom:1rem;margin-top:0;margin-bottom:1.5rem}.profile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem 2rem}.form-group input[type=email],.form-group input[type=tel],.form-group select,.custom-form-select,.form-group input[type=time]{line-height:1.2;font-family:Poppins,sans-serif}.form-group select,.form-slot select,.custom-form-select{appearance:none;background-color:var(--input-background);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%239ca3af'%3E%3Cpath fill-rule='evenodd' d='M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z' clip-rule='evenodd'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:1.25em 1.25em;padding-right:2.5rem}.custom-form-select:hover{border-color:var(--border-light-gray-hover)}.form-group-readonly span{font-size:1rem;color:#1f2937;padding:3px 0}.field-error-message{font-size:.8rem;color:var(--destructive);margin-top:3px}.form-group-error input,.form-group-error select{border-color:var(--destructive)}.form-group-error input:focus,.form-group-error select:focus{box-shadow:0 0 0 2px var(--error-border-color, #fca5a5)}.availability-row .form-group{position:relative}.availability-editor{display:flex;flex-direction:column;gap:1rem}.no-availability{color:#6b7280;font-style:italic;padding:1rem 0}.availability-row{display:grid;grid-template-columns:1.5fr 1fr 1fr 40px;gap:1rem;align-items:flex-start}.availability-row .form-group select,.availability-row .form-group input[type=time]{height:40px;margin-top:0}.btn-remove-availability{display:flex;align-self:flex-start;background:none;border:none;cursor:pointer;line-height:1;color:#9ca3af;font-size:1.2rem;margin-top:2.2rem;transition:color .2s}.btn-remove-availability:hover{color:#ef4444}.btn-remove-availability:disabled{color:#d1d5db;cursor:not-allowed}.btn-add-availability{display:flex;align-items:center;gap:.5rem;align-self:flex-start;margin-top:.3rem}.btn-remove-text{display:none}.profile-actions{display:flex;justify-content:flex-end}.btn-save-profile{width:fit-content;transition:width .2s ease-in-out}.btn-save-profile:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.my-profile-page{padding:1rem}.profile-section{padding:1.5rem}.profile-grid{grid-template-columns:1fr;gap:1rem}.availability-row{display:flex;flex-direction:column;gap:1rem;background-color:#f9fafb;border:1px solid var(--border-lighter-gray);border-radius:var(--border-radius-md);padding:1rem;margin-bottom:1rem}.row-day,.row-time-start,.row-time-end{grid-area:auto;width:100%}.btn-remove-availability{position:static;width:100%;margin-top:.5rem;display:flex;justify-content:center;align-items:center;gap:.5rem;padding:10px;font-size:.95rem;font-weight:500;background-color:#fff;border:1px solid #fecaca;color:var(--destructive);border-radius:6px;box-shadow:0 1px 2px #0000000d;transition:background-color .2s}.btn-remove-availability:active{background-color:#fef2f2}.btn-remove-availability .btn-remove-text{display:inline}.availability-row .form-group,.availability-row .form-group select,.availability-row .form-group input{width:100%;box-sizing:border-box}.btn-add-availability{width:100%;justify-content:center;padding:12px;margin-top:.5rem}.profile-actions{flex-direction:column;margin-top:1rem}.btn-save-profile{width:100%;justify-content:center;font-size:1rem;padding:12px}}.pagination-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;margin-top:2rem;padding:1rem;border-radius:var(--border-radius-md)}.pagination-controls{display:flex;gap:.5rem}.pagination-btn{background-color:var(--background-color-white);border:1px solid var(--border-gray);color:var(--text-color-dark-gray);padding:8px 14px;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){background-color:#f9fafb;border-color:#9ca3af;color:var(--text-color)}.pagination-btn.active{background-color:var(--primary-color);border-color:var(--primary-color);color:var(--background-color-white);cursor:default}.pagination-btn:disabled{cursor:not-allowed}.pagination-info{font-size:.85rem;color:var(--text-color-dark-gray)}.activity-log-page{flex:1;display:flex;flex-direction:column}.activity-log-page .page-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--border-lighter-gray);flex-shrink:0}.prune-description{color:var(--text-color-dark-gray);font-size:.95rem;line-height:1.5;margin-bottom:1.5rem}.prune-form-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}.prune-form-group label{font-size:.9rem;font-weight:600;color:var(--text-color)}.prune-summary{background-color:var(--background-color-white);border:1px solid var(--border-light-gray);padding:1rem;border-radius:var(--border-radius-md);margin-bottom:2rem}.summary-row{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.9rem;color:#555}.summary-row:last-child{margin-bottom:0}.summary-row.delete-row{color:#d32f2f;border-top:1px solid #eee;padding-top:.5rem;margin-top:.5rem}.prune-actions{display:flex;justify-content:flex-end;gap:1rem}.events-log-page{flex:1;display:flex;flex-direction:column}.events-log-page .page-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--border-lighter-gray);flex-shrink:0}.events-log-list{display:flex;flex-direction:column;gap:1rem}.list-loading-state,.list-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem;color:var(--text-color-gray);font-size:1.1rem;border-radius:var(--border-radius-md)}.list-loading-state svg{font-size:1.5rem}.list-empty-state svg{font-size:2rem;color:var(--text-color-gray)}.list-empty-state.error p{color:var(--destructive);font-style:normal;font-weight:500}.event-entry-delete-preview{margin:1rem 0;padding:.75rem;background-color:var(--background-color-white);border-radius:4px;border:1px solid var(--border-light-gray);font-size:.9rem;color:var(--text-color-dark-gray)}@media (max-width: 768px){.event-log-item{flex-direction:column;align-items:flex-start;gap:1rem}.event-log-details,.event-log-action{width:100%}.event-log-action .btn{flex-grow:1;justify-content:center}}@media (max-width: 480px){.event-log-action .copy-text{display:none}.event-log-action .btn{padding:10px 12px}}.event-log-item{display:flex;align-items:center;gap:1.5rem;padding:1.5rem;background-color:var(--background-color-white);border:1px solid var(--border-lighter-gray);border-radius:var(--border-radius-md);box-shadow:0 2px 4px #0000000d;transition:box-shadow .2s}.event-log-item:hover{box-shadow:0 4px 8px #00000012}.event-log-date{display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:var(--background-color-white);border-radius:6px;width:70px;height:70px;flex-shrink:0;font-weight:600}.event-log-date .month{font-size:.8rem;text-transform:uppercase;color:var(--text-color-dark-gray)}.event-log-date .day{font-size:1.75rem;color:var(--primary-color);line-height:1.1}.event-log-date .year{font-size:.8rem;color:var(--text-color-dark-gray)}.event-log-details{flex-grow:1}.event-log-details .time{font-size:.85rem;font-weight:500;color:var(--primary-color);margin-bottom:2px}.event-log-details .title{font-size:1.1rem;font-weight:600;color:var(--text-color);margin:0}.event-log-details .description{font-size:.9rem;color:var(--text-color-gray);margin:4px 0 0;white-space:pre-wrap}.event-log-actions{display:flex;justify-content:flex-end;align-items:center;gap:1rem;flex-shrink:0;padding:1.5rem}.event-log-main-actions{display:flex;gap:.75rem}.event-log-action .copy-text{display:inline}.event-log-action .btn{display:inline-flex;align-items:center;gap:.4rem}.event-log-divider{align-self:stretch;width:1px;background-color:var(--border-gray)}.event-log-admin-actions{display:flex;gap:.5rem}.btn-event-log{padding:10px!important}.event-log-icon{font-size:1rem}.reset-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;max-width:500px;margin:auto;text-align:center}.reset-header{margin-bottom:2rem;display:flex;flex-direction:column;align-items:center;gap:10px}.reset-logo{width:180px}.reset-header h1{font-size:1.5rem;color:#333;margin:0}.auth-subtitle{color:#666;font-size:.95rem;text-align:center;padding:.75rem;margin:0 auto 2rem;text-wrap:balance}.reset-form{width:100%;max-width:400px;display:flex;flex-direction:column;gap:2rem}.reset-input{width:100%;margin-bottom:.5rem}.status-card{background:#fff;padding:2rem;border-radius:var(--card-border-radius);box-shadow:0 4px 20px #00000014;max-width:400px;display:flex;flex-direction:column;align-items:center;gap:1rem}.reset-password-success-icon{object-fit:contain;width:600px;height:fit-content;position:absolute;margin-bottom:200px}.reset-password-success-text-container{display:flex;flex-direction:column;align-items:center;padding-top:100px}.status-card.success .status-icon{color:#28a745}.status-card.error .status-icon{color:#dc3545}.status-card h2{margin:0;font-size:1.4rem;color:#333}.status-card p{color:#666;line-height:1.5;margin-bottom:1rem}.loader-icon{color:#007bff;margin-bottom:1rem}.book-form{display:flex;flex-direction:column;gap:1.5rem}.image-upload-container{width:100%}.drag-drop-zone{width:100%;height:160px;border:2px dashed #ccc;border-radius:var(--border-radius-md);background-color:#f9f9f9;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;position:relative}.drag-drop-zone:hover{background-color:#f0f7ff;border-color:#3e91ee}.drag-drop-zone.dragging{background-color:#e1effe;border-color:#3e91ee;transform:scale(1.01)}.drag-content{display:flex;flex-direction:column;align-items:center;color:#666;pointer-events:none}.upload-icon{font-size:2.5rem;color:#3e91ee;margin-bottom:12px}.drag-content span{font-weight:600;font-size:1rem;color:#333}.drag-content small{margin-top:5px;color:#999}.hidden-file-input{display:none}.image-preview-active{position:relative;width:138px;height:170px;border-radius:var(--border-radius-md);overflow:hidden;box-shadow:0 4px 10px #0000001a;border:1px solid #eee;cursor:pointer}.image-preview-active:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background-color:#0006;opacity:0;transition:opacity .3s ease;z-index:1}.image-preview-active:hover:after{opacity:1}.image-preview-active img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease-in-out}.image-preview-active:hover img{filter:brightness(.7)}.remove-image-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.8);background:var(--background-color-white);color:#dc3545;border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 6px #0003;opacity:0;visibility:hidden;z-index:2;transition:all .3s cubic-bezier(.175,.885,.32,1.275)}.image-preview-active:hover .remove-image-btn{opacity:1;visibility:visible;transform:translate(-50%,-50%) scale(1)}.remove-image-btn:hover{background-color:#dc3545;color:var(--background-color-white);box-shadow:0 6px 12px #dc35454d}.book-type-badge{padding:4px 10px;border-radius:var(--card-border-radius);font-size:.8rem;font-weight:600;text-transform:capitalize}.book-type-badge.students{background-color:#e3f2fd;color:#0d47a1}.book-type-badge.workbook{background-color:#fff3e0;color:#e65100}.book-type-badge.lectura{background-color:#e8f5e9;color:#1b5e20}.book-thumbnail-wrapper{position:relative;width:50px;height:55px;cursor:pointer}.book-thumbnail-img{width:100%;height:100%;object-fit:contain;border-radius:4px;border:1px solid #cacaca;transition:transform .2s ease}.book-thumbnail-popup{display:none;position:absolute;top:-50px;left:50px;z-index:1000;background:var(--background-color-white);padding:5px;border-radius:var(--border-radius-md);box-shadow:0 10px 25px #0003;width:180px;height:auto;border:1px solid #ddd}.book-thumbnail-popup img{width:100%;height:auto;border-radius:4px;display:block;outline:none!important;border:none!important}.book-thumbnail-wrapper:hover .book-thumbnail-popup{display:block;animation:fadeIn .2s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.book-detail-image-container{width:100%;max-width:200px;border-radius:8px;overflow:hidden;border:1px solid var(--border-lighter-gray);box-shadow:0 4px 6px #0000001a;margin-bottom:1rem}.book-detail-image-container img{width:100%;height:auto;display:block;object-fit:cover}.configuration-page{display:flex;flex-direction:column;gap:24px;padding:1rem}.config-section{display:flex;flex-direction:column;gap:1rem;background:var(--background-color-white);border:1px solid var(--border-lighter-gray);border-radius:8px;padding:25px;max-width:800px;box-shadow:0 2px 4px #00000005}.config-item{display:flex;justify-content:space-between;align-items:center;padding:15px 0;border-bottom:1px solid #f3f4f6}.config-item:last-child{border-bottom:none}.config-info h4{margin:0 0 5px;font-size:1rem;font-weight:600;color:var(--text-color)}.config-info p{margin:0;font-size:.85rem;color:var(--text-color-gray)}.switch{position:relative;display:inline-block;width:50px;height:26px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#ccc;transition:.4s;border-radius:34px}.slider:before{position:absolute;content:"";height:18px;width:18px;left:4px;bottom:4px;background-color:var(--background-color-white);transition:.4s;border-radius:50%}input:checked+.slider{background-color:var(--primary-color)}input:focus+.slider{box-shadow:0 0 1px var(--primary-color)}input:checked+.slider:before{transform:translate(24px)}.toast-bell-slash-icon{color:var(--destructive)}
