@import url(https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap);:root{--green-900:#052e1c;--green-800:#0a4a35;--green-700:#0d6e4f;--green-600:#16a566;--green-500:#22c97f;--green-400:#4ddba0;--green-300:#88ecc2;--green-200:#c8f5e0;--green-100:#edfaf3;--green-50:#f5fdf9;--ink:#0a1f14;--ink-700:#1a3a28;--ink-500:#3d6650;--ink-400:#4a7060;--ink-300:#7a9a8a;--ink-200:#b8d4c4;--ink-100:#deeee7;--ink-50:#f4faf7;--white:#fff;--success:#22c97f;--warning:#f59e0b;--error:#ef4444;--info:#3b82f6;--font:"Plus Jakarta Sans",sans-serif;--radius-sm:8px;--radius:12px;--radius-lg:16px;--radius-xl:24px;--shadow-sm:0 1px 4px #0000000f;--shadow:0 4px 16px #00000014;--shadow-md:0 8px 28px #0000001a;--shadow-lg:0 16px 48px #0000001f;--shadow-green:0 4px 16px #22c97f59;--transition:0.2s ease}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;background:#fff;background:var(--white);font-family:Plus Jakarta Sans,sans-serif;font-family:var(--font);line-height:1.6}body,h1,h2,h3,h4,h5,h6{color:#0a1f14;color:var(--ink)}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2}h1{font-size:clamp(2rem,4vw,3rem);font-weight:800;letter-spacing:-.03em}h2{font-size:clamp(1.5rem,3vw,2rem);letter-spacing:-.02em}h3{font-size:1.25rem}h4{font-size:1.1rem}p{color:#3d6650;color:var(--ink-500);line-height:1.7}a{color:#16a566;color:var(--green-600);text-decoration:none;transition:color .2s ease;transition:color var(--transition)}a:hover{color:#0d6e4f;color:var(--green-700)}.btn{align-items:center;border:none;border-radius:12px;border-radius:var(--radius);cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-family:var(--font);font-size:.9rem;font-weight:700;gap:8px;justify-content:center;padding:12px 24px;text-decoration:none;transition:all .2s ease;transition:all var(--transition);white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background:linear-gradient(135deg,#22c97f,#0d6e4f);background:linear-gradient(135deg,var(--green-500),var(--green-700));box-shadow:0 4px 16px #22c97f59;box-shadow:var(--shadow-green);color:#fff;color:var(--white)}.btn-primary:hover:not(:disabled){box-shadow:0 8px 24px #22c97f73;transform:translateY(-1px)}.btn-secondary{background:#edfaf3;background:var(--green-100);border:1.5px solid #c8f5e0;border:1.5px solid var(--green-200);color:#0a4a35;color:var(--green-800)}.btn-secondary:hover:not(:disabled){background:#c8f5e0;background:var(--green-200)}.btn-outline{background:#0000;border:1.5px solid #22c97f;border:1.5px solid var(--green-500);color:#0d6e4f;color:var(--green-700)}.btn-outline:hover:not(:disabled){background:#edfaf3;background:var(--green-100)}.btn-ghost{background:#0000;border:1.5px solid #deeee7;border:1.5px solid var(--ink-100);color:#3d6650;color:var(--ink-500)}.btn-ghost:hover:not(:disabled){background:#f4faf7;background:var(--ink-50);color:#0a1f14;color:var(--ink)}.btn-danger{background:#fee2e2;border:1.5px solid #fecaca;color:#ef4444;color:var(--error)}.btn-danger:hover:not(:disabled){background:#fecaca}.btn-sm{font-size:.82rem;padding:8px 16px}.btn-lg{font-size:1rem;padding:16px 32px}.btn-full{width:100%}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.form-label{color:#0a1f14;color:var(--ink);font-size:.85rem;font-weight:600}.form-label span{color:#ef4444;color:var(--error);margin-left:2px}.form-input,.form-select,.form-textarea{background:#fff;background:var(--white);border:1.5px solid #deeee7;border:1.5px solid var(--ink-100);border-radius:12px;border-radius:var(--radius);color:#0a1f14;color:var(--ink);font-family:Plus Jakarta Sans,sans-serif;font-family:var(--font);font-size:.9rem;font-weight:500;outline:none;padding:11px 14px;transition:border-color .2s ease,box-shadow .2s ease;transition:border-color var(--transition),box-shadow var(--transition);width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#22c97f;border-color:var(--green-500);box-shadow:0 0 0 3px #22c97f1f}.form-input::placeholder{color:#b8d4c4;color:var(--ink-200);font-weight:400}.form-input.error{border-color:#ef4444;border-color:var(--error)}.form-error{color:#ef4444;color:var(--error);font-size:.8rem;font-weight:500}.form-textarea{min-height:100px;resize:vertical}.form-select{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%234a7060'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m19 9-7 7-7-7'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:16px;cursor:pointer;padding-right:36px}.card{background:#fff;background:var(--white);border:1.5px solid #deeee7;border:1.5px solid var(--ink-100);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 1px 4px #0000000f;box-shadow:var(--shadow-sm);padding:24px;transition:box-shadow .2s ease;transition:box-shadow var(--transition)}.card:hover{box-shadow:0 4px 16px #00000014;box-shadow:var(--shadow)}.card-elevated{border:none;box-shadow:0 8px 28px #0000001a;box-shadow:var(--shadow-md)}.badge{align-items:center;border-radius:20px;display:inline-flex;font-size:.72rem;font-weight:700;gap:4px;letter-spacing:.02em;padding:3px 10px}.badge-green{background:#edfaf3;background:var(--green-100);color:#0a4a35;color:var(--green-800)}.badge-blue{background:#dbeafe;color:#1d4ed8}.badge-yellow{background:#fef3c7;color:#92400e}.badge-red{background:#fee2e2;color:#991b1b}.badge-grey{background:#f4faf7;background:var(--ink-50);color:#3d6650;color:var(--ink-500)}.badge-dbs{background:#d1fae5;border:1px solid #a7f3d0;color:#065f46}.container{max-width:1200px}.container,.container-sm{margin:0 auto;padding:0 24px}.container-sm{max-width:800px}.container-xs{margin:0 auto;max-width:480px;padding:0 24px}.page-wrapper{display:flex;flex-direction:column;min-height:100vh}.page-content{flex:1 1;padding:32px 0}.dashboard-layout{display:flex;min-height:100vh}.sidebar{background:#052e1c;background:var(--green-900);display:flex;flex-direction:column;flex-shrink:0;height:100vh;left:0;overflow-y:auto;padding:24px 0;position:fixed;top:0;width:260px;z-index:100}.sidebar-logo{border-bottom:1px solid #ffffff14;margin-bottom:16px;padding:0 24px 24px}.sidebar-logo a{align-items:center;color:#fff;color:var(--white);display:flex;font-size:1.1rem;font-weight:800;gap:10px;text-decoration:none}.sidebar-logo-icon{align-items:center;background:linear-gradient(135deg,#22c97f,#0d6e4f);background:linear-gradient(135deg,var(--green-500),var(--green-700));border-radius:8px;display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.sidebar-logo-accent{color:#4ddba0;color:var(--green-400)}.sidebar-nav{flex:1 1;padding:0 12px}.sidebar-section{margin-bottom:24px}.sidebar-section-label{color:#ffffff59;font-size:.68rem;font-weight:700;letter-spacing:.1em;margin-bottom:6px;padding:0 12px;text-transform:uppercase}.sidebar-link{align-items:center;border-radius:12px;border-radius:var(--radius);color:#ffffffa6;display:flex;font-size:.875rem;font-weight:600;gap:10px;margin-bottom:2px;padding:10px 12px;text-decoration:none;transition:all .2s ease;transition:all var(--transition)}.sidebar-link:hover{background:#ffffff14;color:#fff;color:var(--white)}.sidebar-link.active{background:#22c97f26;color:#4ddba0;color:var(--green-400)}.sidebar-link svg{flex-shrink:0;height:18px;width:18px}.sidebar-link .badge-count{background:#22c97f;background:var(--green-500);border-radius:12px;color:#fff;color:var(--white);font-size:.68rem;font-weight:700;margin-left:auto;padding:2px 7px}.sidebar-footer{border-top:1px solid #ffffff14;padding:16px 12px}.sidebar-user{align-items:center;border-radius:12px;border-radius:var(--radius);color:#ffffffb3;display:flex;gap:10px;padding:10px 12px}.sidebar-user-avatar{align-items:center;background:linear-gradient(135deg,#22c97f,#0d6e4f);background:linear-gradient(135deg,var(--green-500),var(--green-700));border-radius:50%;color:#fff;color:var(--white);display:flex;flex-shrink:0;font-size:.8rem;font-weight:700;height:32px;justify-content:center;width:32px}.sidebar-user-name{color:#fff;color:var(--white);font-size:.82rem;font-weight:600}.sidebar-user-role{color:#fff6;font-size:.7rem}.dashboard-main{background:#f8fdf9;flex:1 1;margin-left:260px;min-height:100vh}.dashboard-topbar{align-items:center;background:#fff;background:var(--white);border-bottom:1px solid #deeee7;border-bottom:1px solid var(--ink-100);display:flex;height:64px;justify-content:space-between;padding:0 32px;position:-webkit-sticky;position:sticky;top:0;z-index:50}.dashboard-page{padding:32px}.dashboard-page-header{margin-bottom:28px}.dashboard-page-header h1{font-size:1.6rem}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));margin-bottom:28px}.stat-card{background:#fff;background:var(--white);border:1.5px solid #deeee7;border:1.5px solid var(--ink-100);border-radius:16px;border-radius:var(--radius-lg);padding:20px 24px}.stat-card-label{color:#7a9a8a;color:var(--ink-300);font-size:.78rem;font-weight:600;letter-spacing:.05em;margin-bottom:6px;text-transform:uppercase}.stat-card-value{color:#0a1f14;color:var(--ink);font-size:1.8rem;font-weight:800;line-height:1;margin-bottom:4px}.stat-card-sub{color:#7a9a8a;color:var(--ink-300);font-size:.78rem;font-weight:500}.stat-card-icon{align-items:center;background:#edfaf3;background:var(--green-100);border-radius:12px;border-radius:var(--radius);display:flex;height:40px;justify-content:center;margin-bottom:12px;width:40px}.stat-card-icon svg{color:#16a566;color:var(--green-600);height:20px;width:20px}.table-wrap{border:1.5px solid #deeee7;border:1.5px solid var(--ink-100);border-radius:16px;border-radius:var(--radius-lg);overflow-x:auto}table{border-collapse:collapse;width:100%}thead{background:#f5fdf9;background:var(--green-50)}th{border-bottom:1px solid #deeee7;border-bottom:1px solid var(--ink-100);color:#3d6650;color:var(--ink-500);font-size:.78rem;font-weight:700;letter-spacing:.03em;padding:12px 16px;text-align:left;text-transform:uppercase}td{border-bottom:1px solid #f4faf7;border-bottom:1px solid var(--ink-50);color:#0a1f14;color:var(--ink);font-size:.875rem;padding:14px 16px;vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:#f5fdf9;background:var(--green-50)}.avatar{border-radius:50%;flex-shrink:0;object-fit:cover}.avatar-sm{height:32px;width:32px}.avatar-md{height:44px;width:44px}.avatar-lg{height:64px;width:64px}.avatar-xl{height:96px;width:96px}.avatar-placeholder{align-items:center;background:linear-gradient(135deg,#22c97f,#0d6e4f);background:linear-gradient(135deg,var(--green-500),var(--green-700));border-radius:50%;color:#fff;color:var(--white);display:flex;flex-shrink:0;font-weight:700;justify-content:center}.stars{display:flex;gap:2px}.star-filled{color:#f59e0b}.star-empty{color:#deeee7;color:var(--ink-100)}.alert{align-items:flex-start;border-radius:12px;border-radius:var(--radius);display:flex;font-size:.875rem;font-weight:500;gap:10px;padding:14px 18px}.alert-success{background:#edfaf3;background:var(--green-100);border:1px solid #88ecc2;border:1px solid var(--green-300);color:#0a4a35;color:var(--green-800)}.alert-error{background:#fee2e2;border:1px solid #fecaca;color:#991b1b}.alert-warning{background:#fef3c7;border:1px solid #fde68a;color:#92400e}.alert-info{background:#dbeafe;border:1px solid #bfdbfe;color:#1d4ed8}.spinner{animation:spin .8s linear infinite;border:3px solid #c8f5e0;border-top-color:#22c97f;border:3px solid var(--green-200);border-radius:50%;border-top-color:var(--green-500);height:24px;width:24px}.spinner-lg{border-width:4px;height:40px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.loading-screen{flex-direction:column;gap:16px;min-height:400px}.loading-screen,.modal-overlay{align-items:center;display:flex;justify-content:center}.modal-overlay{background:#00000073;inset:0;padding:24px;position:fixed;z-index:1000}.modal{background:#fff;background:var(--white);border-radius:24px;border-radius:var(--radius-xl);box-shadow:0 16px 48px #0000001f;box-shadow:var(--shadow-lg);max-width:520px;padding:32px;position:relative;width:100%}.modal-close{align-items:center;background:#f4faf7;background:var(--ink-50);border:none;border-radius:8px;cursor:pointer;display:flex;height:32px;justify-content:center;position:absolute;right:16px;top:16px;width:32px}.modal-title{font-size:1.25rem;font-weight:800;margin-bottom:8px}.modal-body{margin-top:16px}.modal-footer{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.stepper{display:flex;gap:0;margin-bottom:40px}.step-item{align-items:center;display:flex;flex:1 1;flex-direction:column;position:relative}.step-item:not(:last-child):after{background:#deeee7;background:var(--ink-100);content:"";height:2px;left:calc(50% + 16px);position:absolute;right:calc(-50% + 16px);top:16px;z-index:0}.step-item.completed:after{background:#22c97f;background:var(--green-500)}.step-circle{align-items:center;background:#deeee7;background:var(--ink-100);border-radius:50%;color:#7a9a8a;color:var(--ink-300);display:flex;font-size:.8rem;font-weight:700;height:32px;justify-content:center;position:relative;width:32px;z-index:1}.step-item.completed .step-circle{background:#22c97f;background:var(--green-500);color:#fff;color:var(--white)}.step-item.active .step-circle{background:#0a4a35;background:var(--green-800);box-shadow:0 0 0 4px #edfaf3;box-shadow:0 0 0 4px var(--green-100);color:#fff;color:var(--white)}.step-label{color:#7a9a8a;color:var(--ink-300);font-size:.72rem;font-weight:600;margin-top:6px;text-align:center}.step-item.active .step-label,.step-item.completed .step-label{color:#0d6e4f;color:var(--green-700)}.tutor-card{background:#fff;background:var(--white);border:1.5px solid #deeee7;border:1.5px solid var(--ink-100);border-radius:16px;border-radius:var(--radius-lg);overflow:hidden;transition:box-shadow .2s ease,transform .2s ease;transition:box-shadow var(--transition),transform var(--transition)}.tutor-card:hover{box-shadow:0 8px 28px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.tutor-card-header{align-items:flex-start;display:flex;gap:14px;padding:20px}.tutor-card-info{flex:1 1}.tutor-card-name{color:#0a1f14;color:var(--ink);font-size:1rem;font-weight:700;margin-bottom:2px}.tutor-card-subjects{color:#4a7060;color:var(--ink-400);font-size:.8rem}.tutor-card-body{padding:0 20px 16px}.tutor-card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.tutor-card-tag{background:#f5fdf9;background:var(--green-50);border-radius:6px;color:#0d6e4f;color:var(--green-700);font-size:.72rem;font-weight:600;padding:3px 8px}.tutor-card-footer{align-items:center;border-top:1px solid #f4faf7;border-top:1px solid var(--ink-50);display:flex;justify-content:space-between;padding:14px 20px}.tutor-card-rate{color:#0a4a35;color:var(--green-800);font-size:1.1rem;font-weight:800}.tutor-card-rate span{color:#4a7060;color:var(--ink-400);font-size:.75rem;font-weight:500}.notif-dot{background:#ef4444;background:var(--error);border-radius:50%;height:8px;position:absolute;right:2px;top:2px;width:8px}@media (max-width:1024px){.sidebar{transform:translateX(-100%);transition:transform .3s ease}.sidebar.open{transform:translateX(0)}.dashboard-main{margin-left:0}}@media (max-width:768px){.stats-grid{grid-template-columns:repeat(2,1fr)}.dashboard-page{padding:20px 16px}.container{padding:0 16px}}@media (max-width:480px){.stats-grid{grid-template-columns:1fr}}
/*# sourceMappingURL=main.9118ef38.css.map*/