@import url("https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,200..800;1,200..800&display=swap");:root{--primary:#be4848;--primary-dark:#a03030;--primary-light:#d96060;--sidebar-bg:#1a1a2e;--sidebar-text:#c8c8d8;--sidebar-active:#be4848;--bg:#f9fafb;--card-bg:#ffffff;--border:#e5e7eb;--text:#111827;--text-muted:#6b7280;--radius:10px;--shadow:0 1px 3px rgba(0,0,0,0.1),0 1px 2px rgba(0,0,0,0.06);--shadow-md:0 4px 6px rgba(0,0,0,0.07),0 2px 4px rgba(0,0,0,0.06)}*,:after,:before{box-sizing:border-box}body,html{margin:0;padding:0;font-family:Plus Jakarta Sans,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.6}a{color:inherit;text-decoration:none}button{cursor:pointer}button,input,select,textarea{font-family:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.dashboard-layout,.sidebar{display:flex;min-height:100vh}.sidebar{width:260px;background:var(--sidebar-bg);flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:100;transition:transform .3s ease}.sidebar-logo{height:80px;padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:12px}.sidebar-logo-icon{width:40px;height:40px;background:var(--primary);border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:800;color:white;font-size:18px}.sidebar-logo-text{display:flex;flex-direction:column}.sidebar-logo-title{font-weight:700;color:white;font-size:15px;line-height:1.2}.sidebar-logo-sub{font-size:11px;color:var(--sidebar-text);opacity:.7}.sidebar-nav{flex:1 1;padding:16px 0;overflow-y:auto}.sidebar-section-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.3);padding:12px 24px 4px}.sidebar-link{display:flex;align-items:center;gap:10px;padding:10px 24px;color:var(--sidebar-text);font-size:13.5px;font-weight:500;border-radius:0;transition:background .15s,color .15s;cursor:pointer;border:none;background:none;width:100%;text-align:left}.sidebar-link:hover{background:rgba(255,255,255,.06);color:white}.sidebar-link.active{background:transparent;color:var(--primary)}.sidebar-link svg{width:18px;height:18px;flex-shrink:0}.sidebar-submenu{padding-left:32px}.main-content{margin-left:260px;flex:1 1;min-height:100vh;display:flex;flex-direction:column;transition:margin-left .3s ease}.topbar{height:80px;background:var(--card-bg);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;position:-webkit-sticky;position:sticky;top:0;z-index:50;gap:16px}.topbar-title{font-weight:700;font-size:18px;flex:1 1}.topbar-user{display:flex;flex-direction:column;align-items:flex-end;font-size:13px}.topbar-role{font-weight:700;color:var(--primary);font-size:10px;letter-spacing:.06em;text-transform:uppercase}.topbar-date{color:var(--text-muted);font-size:11px}.topbar-avatar{width:38px;height:38px;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:white;font-weight:700;font-size:16px}.page-content{padding:24px;flex:1 1}.card{background:var(--card-bg);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow)}.card-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}.card-title{font-weight:700;font-size:15px}.card-body{padding:20px}.table-wrap{overflow-x:auto;overflow-y:auto;max-height:calc(100vh - 310px)}table{width:100%;border-collapse:collapse}th{position:-webkit-sticky;position:sticky;top:0;z-index:5;background:#f9fafb;text-align:left;padding:10px 14px;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted);white-space:nowrap}td,th{border-bottom:1px solid var(--border)}td{padding:12px 14px;vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:#fafafa}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.form-label{font-size:12px;font-weight:600;color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase}.form-input{padding:10px 14px;border:1.5px solid var(--border);border-radius:8px;font-size:14px;outline:none;transition:border-color .15s;background:white;width:100%}.form-input:focus{border-color:var(--primary)}.form-input::placeholder{color:#aaa}textarea.form-input{resize:vertical;min-height:100px}select.form-input{cursor:pointer}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px}.modal{background:white;border-radius:12px;width:100%;max-width:560px;max-height:90vh;box-shadow:0 20px 60px rgba(0,0,0,.2)}.modal,.modal>form{display:flex;flex-direction:column;overflow:hidden}.modal>form{flex:1 1;min-height:0}.modal-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-title{font-weight:700;font-size:16px}.modal-body{padding:24px;overflow-y:auto;flex:1 1}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600}.badge-green{background:#dcfce7;color:#166534}.badge-red{background:#fee2e2;color:#991b1b}.badge-yellow{background:#fef9c3;color:#854d0e}.badge-gray{background:#f3f4f6;color:#374151}.badge-blue{background:#dbeafe;color:#1e40af}.badge-purple{background:#f3e8ff;color:#6b21a8}.badge-orange{background:#ffedd5;color:#9a3412}.welcome-banner{background:var(--primary);border-radius:12px;padding:28px 32px;justify-content:space-between;margin-bottom:24px}.welcome-banner,.welcome-circle{display:flex;align-items:center;color:white}.welcome-circle{width:80px;height:80px;border:3px solid rgba(255,255,255,.4);border-radius:50%;flex-direction:column;justify-content:center;font-size:24px;font-weight:800}.welcome-circle span{font-size:11px;font-weight:600;opacity:.85}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:16px;gap:16px;margin-bottom:24px}.stat-card{background:white;border:1px solid var(--border);border-radius:10px;padding:20px;gap:16px}.stat-card,.stat-icon{display:flex;align-items:center}.stat-icon{width:48px;height:48px;border-radius:12px;justify-content:center}.stat-icon-red{background:#fee2e2;color:var(--primary)}.stat-icon-blue{background:#dbeafe;color:#2563eb}.stat-icon-green{background:#dcfce7;color:#16a34a}.stat-icon-yellow{background:#fef9c3;color:#ca8a04}.stat-icon-purple{background:#f3e8ff;color:#9333ea}.stat-num{font-size:26px;font-weight:800;line-height:1}.stat-label{font-size:12px;color:var(--text-muted);margin-top:2px}.pagination{gap:6px;justify-content:flex-end;padding:16px;position:-webkit-sticky!important;position:sticky!important;bottom:0!important;background:white!important;z-index:10!important}.page-btn,.pagination{display:flex;align-items:center}.page-btn{min-width:32px;height:32px;border:1px solid var(--border);border-radius:6px;background:white;font-size:13px;justify-content:center;cursor:pointer;transition:all .15s}.page-btn:hover{background:#f3f4f6}.page-btn.active{background:var(--primary);color:white;border-color:var(--primary)}.page-btn:disabled{opacity:.4;cursor:not-allowed}.dashboard-layout.sidebar-collapsed .sidebar{transform:translateX(-100%)}.dashboard-layout.sidebar-collapsed .main-content{margin-left:0}.sidebar-overlay-mobile{display:none}@media (max-width:768px){.sidebar{transform:translateX(-100%)}.dashboard-layout.sidebar-open .sidebar{transform:translateX(0)}.main-content{margin-left:0}.sidebar-overlay-mobile{display:block}}.student-bottom-nav{display:none}@media (max-width:768px){.dashboard-layout.student-layout .sidebar,.dashboard-layout.student-layout .sidebar-overlay-mobile{display:none!important}.dashboard-layout.student-layout .main-content{margin-left:0!important;padding-bottom:calc(72px + env(safe-area-inset-bottom))!important}.dashboard-layout.student-layout .topbar button[aria-label="Toggle sidebar"]{display:none!important}.student-bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:calc(64px + env(safe-area-inset-bottom));background:rgba(255,255,255,.85);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(229,231,235,.8);z-index:500;align-items:center;justify-content:space-around;padding-bottom:env(safe-area-inset-bottom);box-shadow:0 -4px 16px rgba(0,0,0,.05)}.student-bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);font-size:10px;font-weight:700;text-decoration:none;flex:1 1;height:100%;gap:4px;transition:color .15s,transform .15s ease}.student-bottom-nav-item svg{width:20px;height:20px;transition:transform .15s ease}.student-bottom-nav-item:active{transform:scale(.95)}.student-bottom-nav-item:active svg{transform:scale(1.15)}.student-bottom-nav-item.active{color:var(--primary)}}.calendar-container{display:flex;flex-direction:column;height:calc(100vh - 150px);background:var(--card-bg);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);overflow:hidden}.calendar-header-bar{padding:16px 24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.calendar-nav{display:flex;align-items:center;gap:8px}.calendar-month-title{font-size:18px;font-weight:700;color:var(--text);min-width:150px;text-align:center}.calendar-filters{display:flex;align-items:center;gap:16px}.calendar-filter-label{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.calendar-grid{flex:1 1;display:flex;flex-direction:column;min-height:0}.calendar-days-header{display:grid;grid-template-columns:repeat(7,1fr);background:#f9fafb;border-bottom:1px solid var(--border)}.calendar-header-cell{padding:10px 0;text-align:center;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-right:1px solid var(--border)}.calendar-header-cell:last-child{border-right:none}.calendar-body-grid{min-height:0}.calendar-body-grid,.calendar-week-row{flex:1 1;display:flex;flex-direction:column}.calendar-week-row{position:relative;min-height:80px;border-bottom:1px solid var(--border)}.calendar-week-row:last-child{border-bottom:none}.calendar-week-bg{position:absolute;inset:0;display:grid;grid-template-columns:repeat(7,1fr);pointer-events:none}.calendar-day-bg-cell{border-right:1px solid var(--border)}.calendar-day-bg-cell:last-child{border-right:none}.calendar-day-bg-cell.other-month{background:#fafafa}.calendar-week-days-nums{display:grid;grid-template-columns:repeat(7,1fr);z-index:2;pointer-events:none}.calendar-day-num-wrapper{padding:6px 8px}.calendar-day-num{font-size:12px;font-weight:600;color:var(--text-muted)}.calendar-day-num.current-month{color:var(--text)}.calendar-day-num.today{background:var(--primary);color:white;border-radius:50%;display:inline-flex;width:22px;height:22px;align-items:center;justify-content:center;font-weight:700}.calendar-events-layer{margin-top:28px;position:relative;flex:1 1;display:grid;grid-template-columns:repeat(7,1fr);grid-auto-rows:24px;grid-gap:2px 0;gap:2px 0;padding-bottom:4px;z-index:3}.calendar-event-bar{height:20px;background:rgba(190,72,72,.08);color:var(--primary);border-left:3px solid var(--primary);font-size:11px;font-weight:700;padding:0 8px;display:flex;align-items:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin:1px 2px;border-radius:4px;cursor:pointer;transition:all .15s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.calendar-event-bar:hover{background:rgba(190,72,72,.15);transform:translateY(-.5px);box-shadow:0 1px 3px rgba(0,0,0,.05)}.calendar-event-bar.left-flat{border-top-left-radius:0;border-bottom-left-radius:0;margin-left:0;border-left:none}.calendar-event-bar.right-flat{border-top-right-radius:0;border-bottom-right-radius:0;margin-right:0}.mobile-bottom-nav{display:none}@media (max-width:768px){.dashboard-layout.student-layout .sidebar,.dashboard-layout.student-layout .sidebar-overlay-mobile{display:none!important}.dashboard-layout.student-layout .main-content{margin-left:0!important}.dashboard-layout.student-layout .topbar button[aria-label="Toggle sidebar"],.nav-mobile{display:none!important}.mobile-bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:calc(64px + env(safe-area-inset-bottom));background:rgba(255,255,255,.95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid rgba(229,231,235,.7);z-index:500;align-items:center;justify-content:space-around;padding-bottom:env(safe-area-inset-bottom);box-shadow:0 -4px 20px rgba(0,0,0,.05)}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#6b7280;font-size:10px;font-weight:600;text-decoration:none;flex:1 1;height:100%;gap:3px;transition:color .15s,transform .1s ease}.mobile-nav-item svg{width:20px;height:20px;transition:transform .15s ease}.mobile-nav-item:active{transform:scale(.95)}.mobile-nav-item.active{color:#be4848}.mobile-nav-center-btn{flex-direction:column;text-decoration:none;flex:1 1;height:100%;margin-top:-18px;position:relative;z-index:501;gap:3px}.center-btn-inner,.mobile-nav-center-btn{display:flex;align-items:center;justify-content:center}.center-btn-inner{width:48px;height:48px;background:linear-gradient(135deg,#be4848,#8b1a1a);border-radius:50%;box-shadow:0 4px 12px rgba(190,72,72,.4);transition:transform .15s ease;border:3px solid white}.mobile-nav-center-btn:active .center-btn-inner{transform:scale(.9)}.mobile-nav-center-btn span{font-size:10px;font-weight:600;color:#6b7280}#workshops,.dashboard-layout.student-layout .main-content,body,main{padding-bottom:calc(72px + env(safe-area-inset-bottom))!important}}