@charset "UTF-8";.tabs-container{background:#fff;border-bottom:1px solid #e2e2e0;box-shadow:0 2px 4px #7c776926}.tabs{display:flex;gap:4px;padding:0 24px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.tabs::-webkit-scrollbar{display:none}.tabs .tab{position:relative;display:flex;align-items:center;gap:8px;padding:16px 24px;background:transparent;border:none;border-bottom:3px solid transparent;color:#bcbdb7;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.tabs .tab:hover{color:#7c7769;background:#f8f8ef}.tabs .tab.active{color:#d4aa3e;border-bottom-color:#f4ce54;font-weight:700}.tabs .tab.active .tab-icon{color:#f4ce54}.tabs .tab .tab-icon{font-size:20px;transition:color .2s}.tabs .tab .tab-label{-webkit-user-select:none;user-select:none}@media (max-width: 768px){.tabs{padding:0 16px}.tabs .tab{padding:8px 16px;font-size:14px}.tabs .tab .tab-icon{font-size:16px}}.notification-list{max-height:400px;display:flex;flex-direction:column}.notification-list .notification-header{padding:16px 24px;border-bottom:1px solid #e2e2e0;display:flex;justify-content:space-between;align-items:center}.notification-list .notification-header h3{margin:0;font-size:16px;font-weight:700;font-family:Salvatore Roman,Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:#191919}.notification-list .notification-header .mark-all-btn{background:none;border:none;color:#d4aa3e;font-size:12px;cursor:pointer;padding:0;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-weight:700}.notification-list .notification-header .mark-all-btn:hover{text-decoration:underline}.notification-list .notification-items{overflow-y:auto;flex:1}.notification-list .notification-items .no-notifications{padding:32px;text-align:center;color:#bcbdb7;font-size:14px;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.notification-list .notification-items .notification-item{padding:16px 24px;border-bottom:1px solid #e2e2e0;display:flex;gap:16px;cursor:pointer;transition:background-color .2s;position:relative}.notification-list .notification-items .notification-item:hover{background-color:#e2e2e0}.notification-list .notification-items .notification-item.unread{background-color:#f4ce541a}.notification-list .notification-items .notification-item .notif-icon{padding-top:2px;display:flex;align-items:flex-start}.notification-list .notification-items .notification-item .notif-content{flex:1}.notification-list .notification-items .notification-item .notif-content .notif-title{margin:0 0 4px;font-weight:700;font-size:14px;color:#191919;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.notification-list .notification-items .notification-item .notif-content .notif-message{margin:0 0 4px;font-size:12px;color:#7c7769;line-height:1.4;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.notification-list .notification-items .notification-item .notif-content .notif-time{font-size:.7rem;color:#bcbdb7;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.notification-list .notification-items .notification-item .unread-dot{position:absolute;top:16px;right:24px;width:8px;height:8px;background-color:#de776b;border-radius:9999px}.notification-list .notification-footer{padding:8px 24px;border-top:1px solid #e2e2e0;text-align:center}.notification-list .notification-footer button{background:none;border:none;color:#bcbdb7;cursor:pointer;font-size:12px;width:100%;padding:4px;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-weight:700}.notification-list .notification-footer button:hover{color:#7c7769}.notification-list-loading{padding:32px;text-align:center;color:#bcbdb7;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.toast-container{position:fixed;top:24px;right:24px;z-index:10000;display:flex;flex-direction:column;gap:12px}.toast{background:#fff;border-radius:8px;padding:12px 16px;box-shadow:0 4px 12px #00000026;display:flex;align-items:flex-start;gap:12px;min-width:300px;max-width:400px;animation:slideIn .3s ease-out;border-left:4px solid transparent}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast.toast-success{border-left-color:#52c41a}.toast.toast-error{border-left-color:#ff4d4f}.toast.toast-info{border-left-color:#1890ff}.toast.toast-warning{border-left-color:#faad14}.toast.toast-booking{border-left-color:#722ed1}.toast .toast-icon{font-size:1.2rem}.toast .toast-content{flex:1}.toast .toast-content .toast-title{font-weight:600;margin-bottom:4px;color:#333}.toast .toast-content .toast-message{font-size:.9rem;color:#666;line-height:1.4}.toast .toast-close{background:none;border:none;color:#999;font-size:1.2rem;cursor:pointer;padding:0;margin-left:8px;line-height:1}.toast .toast-close:hover{color:#666}.notification-bell-container{position:relative;display:inline-block}.notification-bell-container .notification-bell-btn{background:#fff;border:1px solid #e2e2e0;cursor:pointer;position:relative;padding:4px;border-radius:9999px;transition:all .2s;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #7c776926}.notification-bell-container .notification-bell-btn:hover{background-color:#e2e2e0;transform:translateY(-1px)}.notification-bell-container .notification-bell-btn .bell-icon{width:24px;height:24px;object-fit:contain}.notification-bell-container .notification-bell-btn .badge{position:absolute;top:-5px;right:-5px;background-color:#de776b;color:#fff;font-size:.7rem;font-weight:700;padding:0 5px;border-radius:9999px;min-width:18px;height:18px;display:flex;align-items:center;justify-content:center;border:2px solid #FFFFFF;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.notification-bell-container .notification-dropdown{position:absolute;top:120%;right:0;width:350px;background:#fff;border-radius:24px;box-shadow:0 4px 8px #7c776926;z-index:1000;overflow:hidden;border:1px solid #e2e2e0}.layout{min-height:100vh;display:flex;flex-direction:column}.layout-header{background:#fff;border-bottom:1px solid #e2e2e0;box-shadow:0 4px 8px #7c776926;position:sticky;top:0;z-index:100}.layout-header .header-content{display:flex;justify-content:space-between;align-items:center;padding:24px 32px;max-width:1400px;margin:0 auto}.layout-header .logo{display:flex;align-items:center;gap:8px}.layout-header .logo .logo-icon{width:40px;height:40px;border-radius:50%;background-color:#f8f8ef;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #7c776926}.layout-header .logo .logo-icon img{width:32px;height:32px}.layout-header .logo h1{font-family:Salvatore Roman,Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:24px;color:#de776b;margin:4px 0 0}.layout-header .logo .push-status{font-size:14px;margin-left:4px;cursor:help;opacity:.7}.layout-header .header-right{display:flex;align-items:center;gap:16px}.layout-header .header-right .user-name{font-size:14px;color:#7c7769;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-weight:700}.layout-header .header-right .logout-btn{padding:8px 24px;background:#de776b;color:#fff;border:none;border-radius:9999px;font-size:14px;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-weight:700;cursor:pointer;transition:all .2s}.layout-header .header-right .logout-btn:hover{background:#c75b55;box-shadow:0 2px 4px #7c776926;transform:translateY(-1px)}.layout-header .header-right .logout-btn:active{transform:translateY(1px)}.layout-main{flex:1;padding:32px;max-width:1400px;width:100%;margin:0 auto}@media (max-width: 768px){.layout-header .header-content{padding:16px 24px}.layout-header .logo h1{font-size:20px}.layout-header .header-right{gap:8px}.layout-header .header-right .user-name{display:none}.layout-header .header-right .logout-btn{padding:4px;margin-left:4px;font-size:0;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center}.layout-header .header-right .logout-btn:before{content:"🚪";font-size:16px}.layout-main{padding:8px}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background-color:#e2e2e0}.login-container{width:100%;max-width:420px}.login-card{background:#fff;border-radius:24px;padding:48px;display:flex;flex-direction:column;gap:24px;box-shadow:0 8px 16px #7c776940}.login-header{text-align:center;margin-bottom:16px}.login-header .login-title{font-family:Salvatore Roman,Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:40px;font-weight:700;margin:0 0 8px;color:#d4aa3e}.login-header .login-subtitle{font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:16px;color:#bcbdb7;margin:0;font-weight:500}.login-form{display:flex;flex-direction:column;gap:24px}.login-form .error-message{padding:16px;background:#de776b1a;border:1px solid #de776b;border-radius:16px;color:#c75b55;font-size:14px;text-align:center;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-weight:700}.login-form .form-group{display:flex;flex-direction:column;gap:4px}.login-form .form-group label{font-size:14px;font-weight:700;color:#7c7769;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;text-transform:uppercase;letter-spacing:.5px}.login-form .form-group input{padding:16px;background:#f8f8ef;border:1px solid transparent;border-radius:9999px;font-size:16px;color:#191919;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;transition:all .2s}.login-form .form-group input:focus{border-color:#f4ce54;background:#fff;outline:none;box-shadow:0 2px 4px #7c776926}.login-form .form-group input::placeholder{color:#bcbdb7}.login-form .login-button{margin-top:16px;padding:16px;background:#ffcc02;color:#191919;border:none;border-radius:9999px;font-size:16px;font-weight:700;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;cursor:pointer;transition:all .2s;text-transform:uppercase;letter-spacing:1px;box-shadow:0 2px 4px #7c776926}.login-form .login-button:hover:not(:disabled){transform:translateY(-2px);background:#ffd635;box-shadow:0 4px 8px #7c776926}.login-form .login-button:active:not(:disabled){transform:translateY(0)}.login-form .login-button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.login-card{padding:32px}.login-header .login-title{font-size:32px}}.table-container{background:#fff;border-radius:16px;box-shadow:0 4px 8px #7c776926;overflow:hidden}.table-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;gap:16px}.table-loading .spinner{width:40px;height:40px;border:4px solid #e2e2e0;border-top-color:#f4ce54;border-radius:50%;animation:spin .8s linear infinite}.table-loading p{color:#bcbdb7;font-size:14px}@keyframes spin{to{transform:rotate(360deg)}}.table-search{position:relative;padding:24px;border-bottom:1px solid #e2e2e0}.table-search .search-input{width:100%;padding:8px 32px 8px 16px;border:1px solid #bcbdb7;border-radius:8px;font-size:14px;transition:all .2s}.table-search .search-input:focus{border-color:#f4ce54;outline:none;box-shadow:0 2px 4px #7c776926}.table-search .search-input::placeholder{color:#bcbdb7}.table-search .clear-search{position:absolute;right:32px;top:50%;transform:translateY(-50%);background:transparent;border:none;color:#bcbdb7;font-size:20px;cursor:pointer;padding:4px;line-height:1;transition:color .2s}.table-search .clear-search:hover{color:#7c7769}.table-wrapper{overflow-x:auto}.table{width:100%;border-collapse:collapse;font-size:14px}.table thead{background:#f8f8ef;border-bottom:2px solid #bcbdb7}.table thead tr th{padding:16px 24px;text-align:left;font-weight:600;color:#7c7769;white-space:nowrap}.table thead tr th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.table thead tr th.sortable:hover{background:#e2e2e0}.table thead tr th.sorted{color:#d4aa3e}.table thead tr th .th-content{display:flex;align-items:center;gap:4px}.table thead tr th .th-content .sort-icon{color:#bcbdb7;font-size:12px}.table thead tr th.actions-column{text-align:center}.table tbody tr{border-bottom:1px solid #e2e2e0;transition:background-color .2s}.table tbody tr.clickable{cursor:pointer}.table tbody tr.clickable:hover{background:#f8f8ef}.table tbody tr:last-child{border-bottom:none}.table tbody tr td{padding:16px 24px;color:#7c7769;vertical-align:middle}.table tbody tr td.empty-state{text-align:center;padding:48px;color:#bcbdb7;font-style:italic}.table tbody tr td.actions-cell{text-align:center;white-space:nowrap}.table-pagination{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-top:1px solid #e2e2e0;flex-wrap:wrap;gap:16px}.table-pagination .pagination-info{color:#bcbdb7;font-size:14px}.table-pagination .pagination-controls{display:flex;gap:4px;align-items:center}.table-pagination .pagination-controls .page-btn{min-width:32px;height:32px;padding:0 8px;border:1px solid #bcbdb7;background:#fff;color:#7c7769;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.table-pagination .pagination-controls .page-btn:hover:not(:disabled){background:#f9e7a3;border-color:#f4ce54;color:#191919}.table-pagination .pagination-controls .page-btn.active{background:#f4ce54;border-color:#f4ce54;color:#fff;font-weight:700}.table-pagination .pagination-controls .page-btn:disabled{opacity:.4;cursor:not-allowed}.table-pagination .pagination-controls .pagination-ellipsis{padding:0 4px;color:#bcbdb7}@media (max-width: 768px){.table-search{background:#fff;border-radius:16px;box-shadow:0 4px 8px #7c776926;margin-bottom:16px;border:none}.table-search .search-input{font-size:16px}.table-container{background:transparent;box-shadow:none;border-radius:0}.table{display:block}.table thead{display:none}.table tbody{display:block}.table tr{display:block;margin-bottom:16px;border:1px solid rgba(0,0,0,.05);border-radius:16px;box-shadow:0 4px 12px #00000014;background:#fff;overflow:hidden}.table tr td{display:flex;justify-content:space-between;align-items:center;padding:8px 16px;text-align:right;border-bottom:1px solid #e2e2e0;font-size:14px}.table tr td:last-child{border-bottom:none}.table tr td:before{content:attr(data-label);font-weight:600;margin-right:16px;text-align:left;color:#bcbdb7;flex-shrink:0}.table tr td.actions-cell{justify-content:center;padding:16px}.table tr td.actions-cell:before{display:none}.table tr td.empty-state{display:block;text-align:center}.table tr td.empty-state:before{display:none}.table-pagination{flex-direction:column;align-items:center;gap:16px}.table-pagination .pagination-info{margin-bottom:4px}.table-pagination .pagination-controls{width:100%;justify-content:center}}.clients-page{padding:24px;min-height:100vh}.clients-page .page-header{margin-bottom:32px}.clients-page .page-header .page-title{font-family:Salvatore Roman,Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:32px;font-weight:700;color:#292927;margin:0 0 24px}.clients-page .page-header .page-stats{display:flex;gap:16px}.clients-page .page-header .page-stats .stat-card{background:#fff;padding:24px;border-radius:24px;box-shadow:0 2px 4px #7c776926;display:flex;flex-direction:column;gap:4px;border:1px solid rgba(188,189,183,.2)}.clients-page .page-header .page-stats .stat-card .stat-label{font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;color:#bcbdb7;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.clients-page .page-header .page-stats .stat-card .stat-value{font-family:Salvatore Roman,Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:24px;font-weight:700;color:#191919}.clients-page .page-content{background:#fff;border-radius:24px;padding:24px;box-shadow:0 4px 8px #7c776926}@media (max-width: 768px){.clients-page{padding:16px}.clients-page .page-header .page-title{font-size:24px}.clients-page .page-header .page-stats{flex-direction:column}.clients-page .page-header .page-stats .stat-card{width:100%}.clients-page .page-content{padding:16px}}.teachers-page{padding:24px;min-height:100vh}.teachers-page .page-header{margin-bottom:32px}.teachers-page .page-header .page-title{font-family:Salvatore Roman,Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:32px;font-weight:700;color:#292927;margin:0 0 24px}.teachers-page .page-header .page-stats{display:flex;gap:16px}.teachers-page .page-header .page-stats .stat-card{background:#fff;padding:24px;border-radius:24px;box-shadow:0 2px 4px #7c776926;display:flex;flex-direction:column;gap:4px;flex:1;border:1px solid rgba(188,189,183,.2)}.teachers-page .page-header .page-stats .stat-card .stat-label{font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;color:#bcbdb7;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.teachers-page .page-header .page-stats .stat-card .stat-value{font-family:Salvatore Roman,Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:24px;font-weight:700;color:#191919}.teachers-page .page-header .page-stats .stat-card.active .stat-value{color:#8fcc99}.teachers-page .page-header .page-stats .stat-card.inactive .stat-value{color:#bcbdb7}.teachers-page .page-content{background:#fff;border-radius:24px;padding:24px;box-shadow:0 4px 8px #7c776926}.teachers-page .page-content .status-badge{padding:4px 8px;border-radius:9999px;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:12px;font-weight:700;text-transform:uppercase}.teachers-page .page-content .status-badge.active{background:#8fcc9933;color:#5ab469}.teachers-page .page-content .status-badge.inactive{background:#bcbdb733;color:#8a8c82}.teachers-page .page-content .teacher-actions{display:flex;gap:8px}.teachers-page .page-content .action-btn{padding:4px 16px;border-radius:9999px;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;border:none;display:flex;align-items:center;justify-content:center}.teachers-page .page-content .action-btn.view{background:#e2e2e0;color:#7c7769}.teachers-page .page-content .action-btn.view:hover{background:#c9c9c6}.teachers-page .page-content .action-btn.activate{background:#8fcc99;color:#fff}.teachers-page .page-content .action-btn.activate:hover{background:#6fa374}.teachers-page .page-content .action-btn.deactivate{background:#de776b;color:#fff}.teachers-page .page-content .action-btn.deactivate:hover{background:#c75b55}@media (max-width: 768px){.teachers-page{padding:16px}.teachers-page .page-header .page-title{font-size:24px}.teachers-page .page-header .page-stats{flex-direction:row;flex-wrap:wrap}.teachers-page .page-header .page-stats .stat-card{min-width:calc(50% - 8px);flex:1 0 auto}.teachers-page .page-content{padding:16px}.teachers-page .page-content .teacher-actions{flex-direction:column;width:100%}.teachers-page .page-content .action-btn{width:100%;text-align:center}}.teacher-detail-page .back-button{background:none;border:none;color:#5aaed1;font-size:16px;font-weight:500;cursor:pointer;margin-bottom:24px;padding:8px 16px;border-radius:8px;transition:all .2s}.teacher-detail-page .back-button:hover{background:#81c9e81a}.teacher-detail-page .loading,.teacher-detail-page .not-found{text-align:center;padding:48px;color:#bcbdb7;font-size:20px}.teacher-detail-page .teacher-header{display:flex;gap:32px;background:#fff;padding:32px;border-radius:24px;box-shadow:0 4px 8px #7c776926;margin-bottom:32px}.teacher-detail-page .teacher-header .teacher-avatar{flex-shrink:0}.teacher-detail-page .teacher-header .teacher-avatar img{width:120px;height:120px;border-radius:9999px;object-fit:cover;border:4px solid #f4ce54}.teacher-detail-page .teacher-header .teacher-avatar .avatar-placeholder{width:120px;height:120px;border-radius:9999px;background:#f4ce54;display:flex;align-items:center;justify-content:center;font-size:40px;font-weight:700;color:#fff}.teacher-detail-page .teacher-header .teacher-info{flex:1}.teacher-detail-page .teacher-header .teacher-info .teacher-name{font-size:32px;font-weight:700;color:#191919;margin:0 0 4px}.teacher-detail-page .teacher-header .teacher-info .teacher-headline{font-size:20px;color:#7c7769;margin:0 0 16px}.teacher-detail-page .teacher-header .teacher-info .teacher-contact{display:flex;gap:24px;margin-bottom:16px}.teacher-detail-page .teacher-header .teacher-info .teacher-contact .email,.teacher-detail-page .teacher-header .teacher-info .teacher-contact .phone{color:#bcbdb7;font-size:14px}.teacher-detail-page .teacher-header .teacher-info .status-badge{display:inline-block;padding:4px 16px;border-radius:8px;font-size:14px;font-weight:600}.teacher-detail-page .teacher-header .teacher-info .status-badge.active{background:#8fcc9926;color:#6fa374}.teacher-detail-page .teacher-header .teacher-info .status-badge.inactive{background:#bcbdb726;color:#bcbdb7}.teacher-detail-page .stats-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-bottom:32px}.teacher-detail-page .stats-grid .stat-card{background:#fff;padding:24px;border-radius:16px;box-shadow:0 2px 4px #7c776926;text-align:center}.teacher-detail-page .stats-grid .stat-card .stat-label{display:block;font-size:14px;color:#bcbdb7;margin-bottom:4px}.teacher-detail-page .stats-grid .stat-card .stat-value{display:block;font-size:24px;font-weight:700;color:#191919}.teacher-detail-page .stats-grid .stat-card .stat-value.completed{color:#8fcc99}.teacher-detail-page .stats-grid .stat-card .stat-value.paid{color:#6fa374}.teacher-detail-page .stats-grid .stat-card .stat-value.pending{color:#de776b}.teacher-detail-page .profile-section{background:#fff;padding:32px;border-radius:24px;box-shadow:0 2px 4px #7c776926;margin-bottom:32px}.teacher-detail-page .profile-section h2{font-size:20px;font-weight:700;color:#191919;margin:0 0 24px}.teacher-detail-page .profile-section .profile-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.teacher-detail-page .profile-section .profile-grid .profile-item .label{display:block;font-size:14px;color:#bcbdb7;margin-bottom:4px}.teacher-detail-page .profile-section .profile-grid .profile-item .value{display:block;font-size:16px;color:#191919}.teacher-detail-page .history-section{background:#fff;border-radius:24px;box-shadow:0 2px 4px #7c776926;overflow:hidden}.teacher-detail-page .history-section .tabs{display:flex;border-bottom:1px solid #f8f8ef}.teacher-detail-page .history-section .tabs .tab{flex:1;padding:16px 24px;background:none;border:none;font-size:16px;font-weight:500;color:#bcbdb7;cursor:pointer;transition:all .2s;border-bottom:3px solid transparent}.teacher-detail-page .history-section .tabs .tab:hover{color:#7c7769;background:#f4ce540d}.teacher-detail-page .history-section .tabs .tab.active{color:#d4aa3e;border-bottom-color:#f4ce54;background:#f4ce541a}.teacher-detail-page .history-section .tab-content{padding:24px}.teacher-detail-page .history-section .tab-content .status-badge{display:inline-block;padding:4px 8px;border-radius:8px;font-size:12px;font-weight:600}.teacher-detail-page .history-section .tab-content .status-badge.pending{background:#f4ce5426;color:#d4aa3e}.teacher-detail-page .history-section .tab-content .status-badge.accepted{background:#81c9e826;color:#5aaed1}.teacher-detail-page .history-section .tab-content .status-badge.completed{background:#8fcc9926;color:#6fa374}.teacher-detail-page .history-section .tab-content .status-badge.cancelled{background:#de776b26;color:#c75b55}.teacher-detail-page .history-section .tab-content .status-badge.changed{background:#f4ce5426;color:#d4aa3e}.teacher-detail-page .history-section .tab-content .payment-badge{display:inline-block;padding:4px 8px;border-radius:8px;font-size:12px;font-weight:600}.teacher-detail-page .history-section .tab-content .payment-badge.paid{background:#8fcc9926;color:#6fa374}.teacher-detail-page .history-section .tab-content .payment-badge.unpaid{background:#de776b26;color:#c75b55}@media (max-width: 1024px){.teacher-detail-page .stats-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.teacher-detail-page .teacher-header{flex-direction:column;align-items:center;text-align:center}.teacher-detail-page .teacher-header .teacher-contact{flex-direction:column;gap:4px}.teacher-detail-page .stats-grid{grid-template-columns:repeat(2,1fr)}.teacher-detail-page .profile-section .profile-grid{grid-template-columns:1fr}}.bookings-page{padding:24px;min-height:100vh}.bookings-page .page-header{margin-bottom:32px}.bookings-page .page-header .page-title{font-family:Salvatore Roman,Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:32px;font-weight:700;color:#292927;margin:0 0 24px}.bookings-page .stats-row{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:24px}.bookings-page .stats-row .stat-card{background:#fff;padding:24px;border-radius:24px;box-shadow:0 2px 4px #7c776926;display:flex;flex-direction:column;gap:4px;flex:1;min-width:140px;border:1px solid rgba(188,189,183,.2)}.bookings-page .stats-row .stat-card .stat-label{font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;color:#bcbdb7;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.bookings-page .stats-row .stat-card .stat-value{font-family:Salvatore Roman,Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:24px;font-weight:700;color:#191919}.bookings-page .stats-row .stat-card.pending .stat-value{color:#f4ce54}.bookings-page .stats-row .stat-card.completed .stat-value{color:#8fcc99}.bookings-page .stats-row .stat-card.unpaid-client{border-left:4px solid #de776b}.bookings-page .stats-row .stat-card.unpaid-client .stat-value{color:#de776b}.bookings-page .stats-row .stat-card.unpaid-teacher{border-left:4px solid #de776b}.bookings-page .stats-row .stat-card.unpaid-teacher .stat-value,.bookings-page .stats-row .stat-card.unpaid .stat-value{color:#de776b}.bookings-page .stats-row .stat-card.accepted .stat-value{color:#81c9e8}.bookings-page .tabs-container{display:flex;gap:16px;margin-bottom:24px;background:#fff;padding:4px;border-radius:9999px;width:fit-content;box-shadow:0 2px 4px #7c776926}.bookings-page .tabs-container .tab-btn{padding:8px 32px;border-radius:9999px;border:none;background:transparent;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:16px;font-weight:700;color:#bcbdb7;cursor:pointer;transition:all .3s ease}.bookings-page .tabs-container .tab-btn.active{background:#f4ce54;color:#191919;box-shadow:0 2px 4px #7c776926}.bookings-page .tabs-container .tab-btn:hover:not(.active){color:#7c7769;background:#f4ce541a}.bookings-page .filters-container{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.bookings-page .filters-container .filter-btn{padding:8px 24px;border-radius:9999px;border:1px solid rgba(188,189,183,.2);background:#fff;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;color:#bcbdb7;font-weight:700;cursor:pointer;transition:all .2s}.bookings-page .filters-container .filter-btn.active{background:#f4ce54;color:#fff;border-color:#f4ce54;box-shadow:0 2px 4px #7c776926}.bookings-page .filters-container .filter-btn:hover:not(.active){background:#e2e2e0;color:#191919}.bookings-page .page-content{padding:0}.bookings-page .page-content .status-badge{padding:4px 8px;border-radius:9999px;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:12px;font-weight:700;text-transform:uppercase;white-space:nowrap}.bookings-page .page-content .status-badge.pending{background:#f4ce5433;color:#ecb80f}.bookings-page .page-content .status-badge.accepted{background:#81c9e833;color:#40addc}.bookings-page .page-content .status-badge.completed{background:#8fcc9933;color:#5ab469}.bookings-page .page-content .status-badge.cancelled,.bookings-page .page-content .status-badge.changed{background:#de776b33;color:#ce3f2e}.bookings-page .page-content .payment-badge{padding:4px 8px;border-radius:9999px;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:12px;font-weight:700;white-space:nowrap}.bookings-page .page-content .payment-badge.paid{background:#8fcc9933;color:#5ab469}.bookings-page .page-content .payment-badge.unpaid{background:#de776b33;color:#ce3f2e}.bookings-page .page-content .booking-actions{display:flex;gap:8px;justify-content:flex-start}.bookings-page .page-content .booking-actions .action-btn{padding:4px 16px;border-radius:9999px;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;border:none;white-space:nowrap;display:flex;align-items:center;justify-content:center}.bookings-page .page-content .booking-actions .action-btn.view{background:#e2e2e0;color:#7c7769}.bookings-page .page-content .booking-actions .action-btn.view:hover{background:#c9c9c6}.bookings-page .page-content .booking-actions .action-btn.payment{min-width:140px}.bookings-page .page-content .booking-actions .action-btn.payment.paid{background:#b7e1c0;color:#6fa374;border:1px solid #8fcc99}.bookings-page .page-content .booking-actions .action-btn.payment.paid:hover{background:#8fcc99;color:#fff}.bookings-page .page-content .booking-actions .action-btn.payment.unpaid{background:#ffcc02;color:#191919;box-shadow:0 2px 4px #7c776926}.bookings-page .page-content .booking-actions .action-btn.payment.unpaid:hover{background:#ffd635;transform:translateY(-1px);box-shadow:0 4px 8px #7c776926}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-overlay .modal-content{background:#fff;width:90%;max-width:800px;max-height:90vh;border-radius:32px;box-shadow:0 8px 16px #7c776940;display:flex;flex-direction:column;overflow:hidden}.modal-overlay .modal-content .modal-header{padding:24px;border-bottom:1px solid #e2e2e0;display:flex;justify-content:space-between;align-items:center}.modal-overlay .modal-content .modal-header h2{font-family:Salvatore Roman,Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:24px;color:#191919;margin:0}.modal-overlay .modal-content .modal-header .close-btn{background:none;border:none;font-size:24px;color:#bcbdb7;cursor:pointer}.modal-overlay .modal-content .modal-header .close-btn:hover{color:#191919}.modal-overlay .modal-content .modal-body{padding:24px;overflow-y:auto}.modal-overlay .modal-content .modal-body .kp-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:32px;background:#f8f8ef;padding:24px;border-radius:24px}.modal-overlay .modal-content .modal-body .kp-details-grid .kp-item{display:flex;flex-direction:column;gap:4px}.modal-overlay .modal-content .modal-body .kp-details-grid .kp-item strong{font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:12px;color:#bcbdb7;text-transform:uppercase}.modal-overlay .modal-content .modal-body .kp-details-grid .kp-item{font-family:Salvatore Roman,Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:20px;color:#191919}.modal-overlay .modal-content .modal-body h3{font-family:Salvatore Roman,Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:20px;color:#191919;margin-bottom:16px}.modal-overlay .modal-content .modal-body .modal-table-container{border-radius:24px;overflow:hidden;border:1px solid #e2e2e0}@media (max-width: 768px){.bookings-page{padding:16px}.bookings-page .page-header .page-title{font-size:24px}.bookings-page .page-header .page-stats .stat-card{min-width:calc(50% - 8px)}.bookings-page .tabs-container{width:100%;justify-content:space-between}.bookings-page .tabs-container .tab-btn{padding:8px 16px;font-size:14px}.bookings-page .page-content .booking-actions{flex-direction:column}.bookings-page .page-content .booking-actions .action-btn.payment{width:100%}}.booking-detail-page{padding:24px;min-height:100vh}.booking-detail-page .page-header{display:flex;align-items:center;gap:16px;margin-bottom:32px}.booking-detail-page .page-header .back-btn{background:#fff;border:1px solid #e2e2e0;font-size:16px;color:#bcbdb7;cursor:pointer;padding:4px 24px;border-radius:9999px;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-weight:700;box-shadow:0 2px 4px #7c776926;transition:all .2s}.booking-detail-page .page-header .back-btn:hover{background:#e2e2e0;color:#191919;transform:translate(-2px)}.booking-detail-page .page-header .page-title{margin:0;font-family:Salvatore Roman,Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:32px;color:#292927}.booking-detail-page .detail-container{display:flex;flex-direction:column;gap:32px;max-width:800px;margin:0 auto}.booking-detail-page .info-section{background:#fff;padding:32px;border-radius:24px;box-shadow:0 4px 8px #7c776926}.booking-detail-page .info-section h2{font-family:Salvatore Roman,Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:24px;margin:0 0 24px;color:#7c7769;border-bottom:1px solid #e2e2e0;padding-bottom:8px}.booking-detail-page .info-section .info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:24px}.booking-detail-page .info-section .info-grid .info-item{display:flex;flex-direction:column;gap:4px}.booking-detail-page .info-section .info-grid .info-item label{font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;color:#bcbdb7;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.booking-detail-page .info-section .info-grid .info-item span{font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:16px;color:#191919;font-weight:700}.booking-detail-page .info-section .info-grid .info-item .status-badge{display:inline-block;padding:4px 8px;border-radius:9999px;font-size:12px;text-transform:uppercase;width:fit-content;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-weight:700}.booking-detail-page .info-section .info-grid .info-item .status-badge.pending{background:#f4ce5433;color:#ecb80f}.booking-detail-page .info-section .info-grid .info-item .status-badge.accepted{background:#81c9e833;color:#40addc}.booking-detail-page .info-section .info-grid .info-item .status-badge.completed{background:#8fcc9933;color:#5ab469}.booking-detail-page .info-section .info-grid .info-item .status-badge.cancelled,.booking-detail-page .info-section .info-grid .info-item .status-badge.changed{background:#de776b33;color:#ce3f2e}.booking-detail-page .people-section{display:grid;grid-template-columns:1fr 1fr;gap:24px}@media (max-width: 768px){.booking-detail-page .people-section{grid-template-columns:1fr}}.booking-detail-page .people-section .person-card{background:#fff;padding:24px;border-radius:24px;box-shadow:0 2px 4px #7c776926;border:1px solid rgba(188,189,183,.2)}.booking-detail-page .people-section .person-card h3{margin:0 0 16px;font-family:Salvatore Roman,Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:20px;color:#191919}.booking-detail-page .people-section .person-card p{margin:4px 0;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;color:#7c7769}.booking-detail-page .people-section .person-card .paid{color:#8fcc99;font-weight:700}.booking-detail-page .people-section .person-card .unpaid{color:#de776b;font-weight:700}.booking-detail-page .payment-proof-section{background:#fff;padding:32px;border-radius:24px;box-shadow:0 4px 8px #7c776926}.booking-detail-page .payment-proof-section h2{font-family:Salvatore Roman,Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:24px;margin:0 0 24px;color:#7c7769;border-bottom:1px solid #e2e2e0;padding-bottom:8px}.booking-detail-page .payment-proof-section .qr-container{display:flex;flex-direction:column;align-items:center;gap:8px}.booking-detail-page .payment-proof-section .qr-container .payment-proof-img{max-width:100%;max-height:400px;border:1px solid #e2e2e0;border-radius:16px;cursor:pointer;transition:transform .2s}.booking-detail-page .payment-proof-section .qr-container .payment-proof-img:hover{box-shadow:0 0 10px #0003}.booking-detail-page .payment-proof-section .qr-container .hint{font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;color:#bcbdb7;font-style:italic}.subscription-detail-page{padding:24px;min-height:100vh}.subscription-detail-page .back-button{background:none;border:none;color:#bcbdb7;font-size:16px;font-weight:500;cursor:pointer;margin-bottom:24px;padding:8px 16px;border-radius:8px;transition:all .2s;display:flex;align-items:center;gap:4px;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.subscription-detail-page .back-button:hover{background:#f4ce541a;color:#191919}.subscription-detail-page .page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.subscription-detail-page .page-header .page-title{font-family:Salvatore Roman,Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:32px;font-weight:700;color:#191919;margin:0}.subscription-detail-page .page-header .page-title .status-badge{display:inline-block;margin-left:16px;padding:4px 16px;border-radius:9999px;font-size:14px;font-weight:700;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;vertical-align:middle}.subscription-detail-page .page-header .page-title .status-badge.pending{background:#f4ce5426;color:#d4a50e}.subscription-detail-page .page-header .page-title .status-badge.accepted{background:#8fcc9926;color:#4da85c}.subscription-detail-page .page-header .page-title .status-badge.cancelled{background:#de776b26;color:#ba3829}.subscription-detail-page .page-header .header-actions{display:flex;gap:16px}.subscription-detail-page .info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-bottom:32px}.subscription-detail-page .info-grid .info-card{background:#fff;padding:24px;border-radius:24px;box-shadow:0 4px 8px #7c776926;border:1px solid #e2e2e0}.subscription-detail-page .info-grid .info-card h3{font-family:Salvatore Roman,Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:20px;color:#191919;margin-bottom:16px;border-bottom:1px solid #e2e2e0;padding-bottom:8px}.subscription-detail-page .info-grid .info-card .card-content{display:grid;grid-template-columns:1fr;gap:16px}.subscription-detail-page .info-grid .info-card .card-content .info-item{display:flex;flex-direction:column}.subscription-detail-page .info-grid .info-card .card-content .info-item .label{font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:12px;color:#bcbdb7;font-weight:700;text-transform:uppercase;margin-bottom:4px}.subscription-detail-page .info-grid .info-card .card-content .info-item .value{font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:16px;color:#191919;font-weight:500;display:flex;align-items:center;gap:8px}.subscription-detail-page .info-grid .info-card .card-content .info-item .value img{width:32px;height:32px;border-radius:9999px;object-fit:cover}.subscription-detail-page .bookings-section{background:#fff;border-radius:24px;box-shadow:0 4px 8px #7c776926;padding:24px;border:1px solid #e2e2e0}.subscription-detail-page .bookings-section h2{font-family:Salvatore Roman,Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:24px;color:#191919;margin-bottom:24px}.subscription-detail-page .bookings-section .status-badge{display:inline-block;padding:4px 8px;border-radius:9999px;font-size:12px;font-weight:700;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;text-transform:uppercase}.subscription-detail-page .bookings-section .status-badge.pending{background:#f4ce5426;color:#ecb80f}.subscription-detail-page .bookings-section .status-badge.accepted{background:#8fcc9926;color:#5ab469}.subscription-detail-page .bookings-section .status-badge.completed{background:#81c9e826;color:#40addc}.subscription-detail-page .bookings-section .status-badge.cancelled{background:#de776b26;color:#ce3f2e}.subscription-detail-page .loading-container{display:flex;justify-content:center;align-items:center;height:50vh;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:#bcbdb7;font-size:20px}.subscription-detail-page .error-container{text-align:center;padding:48px;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:#de776b}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-overlay .modal-content{background:#fff;border-radius:16px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-overlay .modal-content .modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e0e0e0}.modal-overlay .modal-content .modal-header h2{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary)}.modal-overlay .modal-content .modal-header .btn-close{background:transparent;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary);padding:.25rem .5rem;border-radius:6px;transition:all .2s}.modal-overlay .modal-content .modal-header .btn-close:hover{background:#0000000d;color:var(--text-primary)}.modal-overlay .modal-content .modal-body{padding:1.5rem}.modal-overlay .modal-content .modal-body .form-group{margin-bottom:1.5rem}.modal-overlay .modal-content .modal-body .form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--text-primary);font-size:.95rem}.modal-overlay .modal-content .modal-body .form-group label .label-hint{font-weight:400;color:var(--text-secondary);font-size:.875rem;margin-left:.5rem}.modal-overlay .modal-content .modal-body .form-group input[type=text],.modal-overlay .modal-content .modal-body .form-group input[type=number]{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:all .2s}.modal-overlay .modal-content .modal-body .form-group input[type=text]:focus,.modal-overlay .modal-content .modal-body .form-group input[type=number]:focus{outline:none;border-color:var(--primary)}.modal-overlay .modal-content .modal-body .form-group input[type=text].error,.modal-overlay .modal-content .modal-body .form-group input[type=number].error{border-color:var(--accent)}.modal-overlay .modal-content .modal-body .form-group .slider-container{display:flex;align-items:center;gap:1rem}.modal-overlay .modal-content .modal-body .form-group .slider-container .slider{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:8px;border-radius:4px;background:#e0e0e0;outline:none;transition:background .2s}.modal-overlay .modal-content .modal-body .form-group .slider-container .slider::-webkit-slider-track{-webkit-appearance:none;height:8px;border-radius:4px;background:#e0e0e0}.modal-overlay .modal-content .modal-body .form-group .slider-container .slider::-moz-range-track{height:8px;border-radius:4px;background:#e0e0e0;border:none}.modal-overlay .modal-content .modal-body .form-group .slider-container .slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--primary);cursor:pointer;box-shadow:0 2px 6px #0000004d;transition:all .2s;margin-top:-6px}.modal-overlay .modal-content .modal-body .form-group .slider-container .slider::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 3px 8px #0006}.modal-overlay .modal-content .modal-body .form-group .slider-container .slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--primary);cursor:pointer;border:none;box-shadow:0 2px 6px #0000004d;transition:all .2s}.modal-overlay .modal-content .modal-body .form-group .slider-container .slider::-moz-range-thumb:hover{transform:scale(1.1);box-shadow:0 3px 8px #0006}.modal-overlay .modal-content .modal-body .form-group .slider-container .slider:hover{background:#d5d5d5}.modal-overlay .modal-content .modal-body .form-group .slider-container .slider-value{min-width:50px;text-align:right;font-weight:600;color:var(--primary);font-size:1.125rem}.modal-overlay .modal-content .modal-body .form-group .price-preview{margin-top:.5rem;padding:.75rem;background:#f5f5f5;border-radius:6px;font-size:.875rem;color:var(--text-secondary)}.modal-overlay .modal-content .modal-body .form-group .error-message{display:block;margin-top:.25rem;color:var(--accent);font-size:.875rem}.modal-overlay .modal-content .modal-body .form-group.checkbox-group label{display:flex;align-items:center;cursor:pointer}.modal-overlay .modal-content .modal-body .form-group.checkbox-group label input[type=checkbox]{width:auto;margin-right:.5rem;cursor:pointer}.modal-overlay .modal-content .modal-body .form-group.checkbox-group label span{font-weight:400}.modal-overlay .modal-content .modal-body .section-divider{margin:2rem 0 1.5rem;padding-top:1.5rem;border-top:2px solid #e0e0e0}.modal-overlay .modal-content .modal-body .section-divider h3{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-primary)}.modal-overlay .modal-content .modal-body .features-list{display:flex;flex-direction:column;gap:.5rem}.modal-overlay .modal-content .modal-body .features-list .feature-item{display:flex;gap:.5rem;align-items:center}.modal-overlay .modal-content .modal-body .features-list .feature-item input[type=text]{flex:1;padding:.5rem;border:2px solid #e0e0e0;border-radius:6px;font-size:.9rem}.modal-overlay .modal-content .modal-body .features-list .feature-item input[type=text]:focus{outline:none;border-color:var(--primary)}.modal-overlay .modal-content .modal-body .features-list .feature-item .btn-remove-feature{background:var(--accent);color:#fff;border:none;border-radius:6px;padding:.5rem .75rem;cursor:pointer;font-size:1rem;font-weight:700;transition:all .2s}.modal-overlay .modal-content .modal-body .features-list .feature-item .btn-remove-feature:hover{background:#c76760;transform:scale(1.05)}.modal-overlay .modal-content .modal-body .features-list .btn-add-feature{background:#f5f5f5;border:2px dashed #d0d0d0;color:var(--text-secondary);padding:.75rem;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s;margin-top:.5rem}.modal-overlay .modal-content .modal-body .features-list .btn-add-feature:hover{background:#e8e8e8;border-color:var(--primary);color:var(--primary)}.modal-overlay .modal-content .modal-body .modal-footer{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem;padding-top:1rem;border-top:1px solid #e0e0e0}.modal-overlay .modal-content .modal-body .modal-footer button{padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;font-size:1rem}.modal-overlay .modal-content .modal-body .modal-footer button.btn-secondary{background:#e0e0e0;color:var(--text-primary)}.modal-overlay .modal-content .modal-body .modal-footer button.btn-secondary:hover{background:#d0d0d0}.modal-overlay .modal-content .modal-body .modal-footer button.btn-primary{background:var(--primary);color:var(--text-primary)}.modal-overlay .modal-content .modal-body .modal-footer button.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #f4ce5466}.modal-overlay .modal-content .modal-body .modal-footer button.btn-primary:disabled{opacity:.6;cursor:not-allowed}.config-page{padding:24px;min-height:100vh}.config-page .page-header{margin-bottom:32px}.config-page .page-header .page-title{font-family:Salvatore Roman,Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:32px;font-weight:700;color:#292927;margin-bottom:24px}.config-page .page-header .page-stats{display:flex;gap:16px;flex-wrap:wrap}.config-page .page-header .page-stats .stat-card{background:#fff;border-radius:24px;padding:24px;display:flex;flex-direction:column;gap:4px;box-shadow:0 2px 4px #7c776926;min-width:150px;border:1px solid rgba(188,189,183,.2)}.config-page .page-header .page-stats .stat-card .stat-value{font-family:Salvatore Roman,Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:24px;font-weight:700;color:#d4aa3e}.config-page .page-header .page-stats .stat-card .stat-label{font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;color:#bcbdb7;text-transform:uppercase;letter-spacing:.5px;font-weight:700}.config-page .page-content-wrapper{background:#fff;border-radius:24px;padding:24px;box-shadow:0 4px 8px #7c776926}.config-page .page-content-wrapper .table-header{display:flex;justify-content:flex-end;margin-bottom:16px}.config-page .page-content-wrapper .table-header .btn-primary{padding:8px 24px;background:#f4ce54;color:#292927;border:none;border-radius:9999px;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-weight:700;cursor:pointer;transition:all .2s;font-size:14px;box-shadow:0 2px 4px #7c776926}.config-page .page-content-wrapper .table-header .btn-primary:hover{transform:translateY(-2px);background:#f6d56c;box-shadow:0 4px 8px #7c776926}.config-page .page-content-wrapper .table-header .btn-primary:active{transform:translateY(0)}.config-page .page-content-wrapper .status-badge{padding:4px 8px;border-radius:9999px;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.config-page .page-content-wrapper .status-badge.status-active{background:#8fcc9933;color:#5ab469}.config-page .page-content-wrapper .status-badge.status-inactive{background:#de776b33;color:#ce3f2e}.config-page .page-content-wrapper .action-buttons{display:flex;gap:4px;justify-content:center}.config-page .page-content-wrapper .action-buttons .btn-action{background:transparent;border:none;font-size:20px;cursor:pointer;padding:4px;border-radius:8px;transition:all .2s}.config-page .page-content-wrapper .action-buttons .btn-action:hover{transform:scale(1.1);background:#e2e2e0}.config-page .page-content-wrapper .action-buttons .btn-action.btn-edit:hover{background:#f4ce5433;color:#d4aa3e}.config-page .page-content-wrapper .action-buttons .btn-action.btn-delete:hover{background:#de776b33;color:#c75b55}.config-page .loading,.config-page .error{padding:32px;text-align:center;font-size:16px;color:#bcbdb7;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.config-page .error{color:#de776b}.syllabus-page{padding:16px;min-height:100vh;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.syllabus-page .page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:16px}.syllabus-page .page-header .logo-container{display:flex;align-items:center;gap:8px}.syllabus-page .page-header .logo-container .brand-name{font-family:Salvatore Roman,Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:24px;font-weight:700;color:#191919}.syllabus-page .page-header .header-titles .tabs{display:flex;gap:8px;background:#fff;padding:4px;border-radius:9999px;box-shadow:0 2px 4px #7c776926}.syllabus-page .page-header .header-titles .tabs .tab-btn{padding:4px 24px;border:none;border-radius:9999px;background-color:transparent;cursor:pointer;font-weight:700;font-size:14px;color:#bcbdb7;transition:all .2s ease;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.syllabus-page .page-header .header-titles .tabs .tab-btn:hover{background-color:#e2e2e0}.syllabus-page .page-header .header-titles .tabs .tab-btn.active{color:#fff;box-shadow:0 2px 4px #7c776926}.syllabus-page .page-header .header-titles .tabs .tab-btn.active.math{background:linear-gradient(135deg,#f4ce54,#f1c024);color:#292927}.syllabus-page .page-header .header-titles .tabs .tab-btn.active.language{background:linear-gradient(135deg,#de776b,#d55141)}.syllabus-page .page-header .header-titles .tabs .tab-btn.active.english{background:linear-gradient(135deg,#8fcc99,#6cbc79)}.syllabus-page .page-header .header-titles .print-btn{margin-left:16px;padding:4px 24px;background:#e2e2e0;border:1px solid #bcbdb7;border-radius:9999px;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-weight:700;color:#bcbdb7;cursor:pointer;transition:all .2s}.syllabus-page .page-header .header-titles .print-btn:hover{background:#d6d6d3;color:#191919}.syllabus-page .syllabus-content{background:#fff;border-radius:24px;overflow:hidden;box-shadow:0 4px 8px #7c776926}.syllabus-page .syllabus-content .route-header{padding:16px 24px;text-align:center}.syllabus-page .syllabus-content .route-header h2{margin:0;font-size:20px;font-weight:700;color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.1);font-family:Salvatore Roman,Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.syllabus-page .syllabus-content .roadmap-horizontal{padding:32px;display:flex;flex-wrap:wrap;justify-content:center;align-items:flex-start;gap:16px;overflow-x:visible}.syllabus-page .syllabus-content .roadmap-horizontal .roadmap-column{display:flex;flex-direction:column;align-items:center;width:155px;min-width:auto;flex-shrink:0}.syllabus-page .syllabus-content .roadmap-horizontal .roadmap-column .group-badge{padding:4px 8px;border-radius:16px;display:flex;flex-direction:column;align-items:center;margin-bottom:8px;color:#fff;box-shadow:0 2px 4px #7c776926;width:100%}.syllabus-page .syllabus-content .roadmap-horizontal .roadmap-column .group-badge .group-id{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;opacity:.9}.syllabus-page .syllabus-content .roadmap-horizontal .roadmap-column .group-badge .group-label{font-size:.7rem;font-weight:700;margin-top:2px;text-align:center;line-height:1.1}.syllabus-page .syllabus-content .roadmap-horizontal .roadmap-column .nodes-column{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%}.syllabus-page .syllabus-content .roadmap-horizontal .arrow-connector{display:none}.node-expanded{border-width:2px;border-style:solid;border-radius:16px;width:100%;overflow:hidden;transition:transform .2s ease}.node-expanded:hover{transform:scale(1.02);box-shadow:0 4px 8px #7c776926}.node-expanded .node-header{padding:4px 8px;text-align:center}.node-expanded .node-header .node-id{font-size:.85rem;font-weight:700;color:#fff;text-shadow:1px 1px 0 rgba(0,0,0,.1)}.node-expanded .node-title{padding:6px 8px;font-size:.7rem;font-weight:700;color:#191919;text-align:center;line-height:1.2;background:#ffffff80;text-transform:uppercase;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.node-expanded .node-details{padding:8px;font-size:.6rem;background:#fff9;border-top:1px solid rgba(0,0,0,.05);font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.node-expanded .node-details .objective{margin:0 0 6px;color:#bcbdb7;line-height:1.4}.node-expanded .node-details ul{margin:0 0 6px;padding-left:12px}.node-expanded .node-details ul li{color:#292927;margin-bottom:2px}.node-expanded .node-details .readings{font-size:.55rem;color:#bcbdb7;font-style:italic;line-height:1.3}.node-expanded .node-details .readings strong{font-style:normal}.syllabus-page .syllabus-content .roadmap-horizontal::-webkit-scrollbar{height:6px}.syllabus-page .syllabus-content .roadmap-horizontal::-webkit-scrollbar-track{background:#e2e2e0;border-radius:3px}.syllabus-page .syllabus-content .roadmap-horizontal::-webkit-scrollbar-thumb{background:#bcbdb7;border-radius:3px}.syllabus-page .syllabus-content .roadmap-horizontal::-webkit-scrollbar-thumb:hover{background:#a3a59c}@media print{@page{size:landscape;margin:5mm}.no-print{display:none!important}.syllabus-page{background:#fff;min-height:auto;margin:0;padding:0;width:100vw;height:100vh;overflow:visible}.syllabus-page :global(.sidebar),.syllabus-page :global(.navbar),.syllabus-page :global(.main-layout-nav),.syllabus-page .page-header .logo-container,.syllabus-page .page-header .print-btn,.syllabus-page .page-header .tabs{display:none!important}.syllabus-page .page-header{display:block!important;padding:10px 0;margin-bottom:20px;border-bottom:2px solid #ccc;text-align:center}.syllabus-page .page-header .header-titles{display:block;width:100%;text-align:center}.syllabus-page .page-header .header-titles:before{content:"Crescendo - Ruta de Aprendizaje";display:block;font-size:2rem;font-weight:700;color:#191919;margin-bottom:10px}.syllabus-page .syllabus-content{padding:0;box-shadow:none}.syllabus-page .syllabus-content .route-header{display:block!important;background-color:transparent!important;color:#000!important;padding:0;margin-bottom:15px;text-align:center}.syllabus-page .syllabus-content .route-header h2{font-size:1.8rem;margin:0;color:#000;text-shadow:none}.syllabus-page .syllabus-content .roadmap-horizontal{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;padding:0;align-items:flex-start;overflow:visible}.syllabus-page .syllabus-content .roadmap-horizontal .arrow-connector{display:none}.syllabus-page .syllabus-content .roadmap-horizontal .roadmap-column{min-width:auto;width:155px;max-width:none;margin-bottom:8px;page-break-inside:avoid}.syllabus-page .syllabus-content .roadmap-horizontal .roadmap-column .group-badge{padding:4px 8px;margin-bottom:8px;width:100%;-webkit-print-color-adjust:exact;print-color-adjust:exact;box-shadow:none}.syllabus-page .syllabus-content .roadmap-horizontal .roadmap-column .group-badge .group-id{font-size:.5rem}.syllabus-page .syllabus-content .roadmap-horizontal .roadmap-column .group-badge .group-label{font-size:.6rem;max-width:none}.syllabus-page .syllabus-content .roadmap-horizontal .roadmap-column .nodes-column{width:100%;gap:6px}.syllabus-page .syllabus-content .roadmap-horizontal .roadmap-column .nodes-column .node-expanded{width:100%;page-break-inside:avoid;border-width:1px;-webkit-print-color-adjust:exact;print-color-adjust:exact;box-shadow:none}.syllabus-page .syllabus-content .roadmap-horizontal .roadmap-column .nodes-column .node-expanded .node-header{padding:2px 4px}.syllabus-page .syllabus-content .roadmap-horizontal .roadmap-column .nodes-column .node-expanded .node-header .node-id{font-size:.7rem;text-shadow:none}.syllabus-page .syllabus-content .roadmap-horizontal .roadmap-column .nodes-column .node-expanded .node-title{padding:4px;font-size:.65rem}.syllabus-page .syllabus-content .roadmap-horizontal .roadmap-column .nodes-column .node-expanded .node-details{padding:4px}.syllabus-page .syllabus-content .roadmap-horizontal .roadmap-column .nodes-column .node-expanded .node-details .objective{font-size:.55rem;margin-bottom:4px;line-height:1.2}.syllabus-page .syllabus-content .roadmap-horizontal .roadmap-column .nodes-column .node-expanded .node-details ul{padding-left:10px}.syllabus-page .syllabus-content .roadmap-horizontal .roadmap-column .nodes-column .node-expanded .node-details ul li{font-size:.5rem;line-height:1.1}.syllabus-page .syllabus-content .roadmap-horizontal .roadmap-column .nodes-column .node-expanded .node-details .readings{font-size:.5rem;margin-top:2px}}:export{primary:#f4ce54;primaryLight:#f9e7a3;primaryDark:#d4aa3e;accent:#de776b;accentLight:#f2b1aa;accentDark:#c75b55;blue:#81c9e8;blueLight:#b7e2f3;blueDark:#5aaed1;green:#8fcc99;greenLight:#b7e1c0;greenDark:#6fa374}@font-face{font-family:Salvatore Roman;src:url(/assets/SalvatoreRoman-Regular-BOF3i-sY.ttf) format("truetype");font-weight:400;font-style:normal}@font-face{font-family:Salvatore Roman;src:url(/assets/SalvatoreRoman-Bold-C2PmdyVT.ttf) format("truetype");font-weight:700;font-style:normal}@font-face{font-family:Salvatore Roman;src:url(/assets/SalvatoreRoman-RegularItalic-CXOYCmTO.ttf) format("truetype");font-weight:400;font-style:italic}@font-face{font-family:Nunito;src:url(/assets/Nunito-Regular-BaWrjX0c.ttf) format("truetype");font-weight:400;font-style:normal}@font-face{font-family:Nunito;src:url(/assets/Nunito-Bold-LWqDuPdh.ttf) format("truetype");font-weight:700;font-style:normal}@font-face{font-family:Nunito;src:url(/assets/Nunito-SemiBold-B4qcAUfD.ttf) format("truetype");font-weight:600;font-style:normal}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#7c7769;background:linear-gradient(180deg,#fff4d9,#e7f9ff);min-height:100vh}#root{min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}button{font-family:inherit;cursor:pointer;border:none;outline:none}button:disabled{cursor:not-allowed;opacity:.6}input,textarea,select{font-family:inherit;outline:none}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f8f8ef;border-radius:8px}::-webkit-scrollbar-thumb{background:#bcbdb7;border-radius:8px}::-webkit-scrollbar-thumb:hover{background:#7c7769}
