@import url(https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800;900&display=swap);:root{--primary:#e07c54;--primary-dark:#c96b42;--primary-light:#f09070;--primary-glow:#e07c542e;--secondary:#f4a56a;--accent:#6c63ff;--accent-light:#8b84ff;--accent-glow:#6c63ff26;--warm-1:#fdf6f0;--warm-2:#f9ede3;--warm-3:#f2dfd0;--warm-4:#e8ccbb;--success:#34c77b;--success-bg:#34c77b1a;--danger:#f05252;--danger-bg:#f052521a;--warning:#f59e0b;--warning-bg:#f59e0b1a;--info:#3b82f6;--info-bg:#3b82f61a;--bg:#fff;--bg2:#fdf6f0;--bg3:#f9ede3;--sidebar-bg:#1a1625;--sidebar-active:#e07c542e;--sidebar-hover:#ffffff0f;--topbar-bg:#ffffffeb;--card:#fff;--card-hover:#fdf6f0;--card-border:#f0e4d8;--glass:#ffffffb3;--text:#1e1b2e;--text-2:#4a3f6b;--text-muted:#7b6f8f;--text-dim:#b0a5c0;--radius:14px;--radius-lg:20px;--radius-xl:28px;--shadow-sm:0 2px 8px #503c2814;--shadow:0 8px 30px #503c281f;--shadow-md:0 12px 40px #503c2826;--shadow-glow:0 0 50px #e07c5440;--transition:all 0.3s cubic-bezier(0.34,1.56,0.64,1)}.theme-violet{--primary:#6c63ff;--primary-dark:#5b52e0;--primary-light:#8b84ff;--primary-glow:#6c63ff2e;--secondary:#a78bfa;--sidebar-active:#6c63ff2e;--shadow-glow:0 0 40px #6c63ff33}.theme-rose{--primary:#f43f5e;--primary-dark:#e11d48;--primary-light:#fb7185;--primary-glow:#f43f5e2e;--secondary:#fda4af;--sidebar-active:#f43f5e2e;--shadow-glow:0 0 40px #f43f5e33}.theme-teal{--primary:#0d9488;--primary-dark:#0f766e;--primary-light:#2dd4bf;--primary-glow:#0d94882e;--secondary:#5eead4;--sidebar-active:#0d94882e;--shadow-glow:0 0 40px #0d948833}.theme-amber{--primary:#d97706;--primary-dark:#b45309;--primary-light:#f59e0b;--primary-glow:#d977062e;--secondary:#fcd34d;--sidebar-active:#d977062e;--shadow-glow:0 0 40px #d9770633}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;background:#fff;background:var(--bg);color:#1e1b2e;color:var(--text);font-family:Plus Jakarta Sans,-apple-system,sans-serif;line-height:1.6;min-height:100vh}::-webkit-scrollbar{height:5px;width:5px}::-webkit-scrollbar-track{background:#fdf6f0;background:var(--warm-1)}::-webkit-scrollbar-thumb{background:#e8ccbb;background:var(--warm-4);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#e07c54;background:var(--primary)}.auth-page{display:grid;grid-template-columns:1fr 1fr;min-height:100vh}.auth-page,.auth-page-left{overflow:hidden;position:relative}.auth-page-left{align-items:center;background:linear-gradient(145deg,#1a1625,#2d1b69);background:linear-gradient(145deg,var(--sidebar-bg) 0,#2d1b69 100%);display:flex;flex-direction:column;justify-content:center;padding:60px 50px}.auth-page-left:before{background:radial-gradient(circle,#e07c542e 0,#0000 70%);background:radial-gradient(circle,var(--primary-glow) 0,#0000 70%);height:500px;left:-150px;top:-150px;width:500px}.auth-page-left:after,.auth-page-left:before{border-radius:50%;content:"";position:absolute}.auth-page-left:after{background:radial-gradient(circle,#6c63ff26 0,#0000 70%);bottom:-100px;height:400px;right:-100px;width:400px}.auth-left-content{color:#fff;position:relative;text-align:center;z-index:1}.auth-left-logo{align-items:center;animation:floatLogo 3s ease-in-out infinite;background:linear-gradient(135deg,#e07c54,#f4a56a);background:linear-gradient(135deg,var(--primary),var(--secondary));border-radius:24px;box-shadow:0 20px 60px #e07c5466;display:flex;font-size:36px;height:80px;justify-content:center;margin:0 auto 28px;width:80px}@keyframes floatLogo{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.auth-left-content h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff 30%,#f09070);background:linear-gradient(135deg,#fff 30%,var(--primary-light));-webkit-background-clip:text;font-size:40px;font-weight:900;letter-spacing:-1px;margin-bottom:12px}.auth-left-content p{color:#fff9;font-size:15px;margin:0 auto 40px;max-width:320px}.auth-features{display:flex;flex-direction:column;gap:14px;max-width:340px;width:100%}.auth-feature-item{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff12;border:1px solid #ffffff1a;border-radius:14px;display:flex;gap:14px;padding:14px 18px}.auth-feature-icon{align-items:center;background:linear-gradient(135deg,#e07c54,#f4a56a);background:linear-gradient(135deg,var(--primary),var(--secondary));border-radius:10px;display:flex;flex-shrink:0;font-size:18px;height:40px;justify-content:center;width:40px}.auth-feature-item span{color:#ffffffd9;font-size:14px;font-weight:500}.auth-page-right{align-items:center;background:#fff;background:var(--bg);display:flex;justify-content:center;overflow-y:auto;padding:40px}.auth-card{animation:fadeSlideUp .5s ease;max-width:420px;width:100%}.auth-logo{margin-bottom:36px}.auth-logo h2{color:#1e1b2e;color:var(--text);font-size:28px;font-weight:800;letter-spacing:-.5px;margin-bottom:6px}.auth-logo p{color:#7b6f8f;color:var(--text-muted);font-size:14px}.role-tabs{background:#fdf6f0;background:var(--warm-1);border:1px solid #f0e4d8;border:1px solid var(--card-border);border-radius:14px;border-radius:var(--radius);display:flex;gap:8px;margin-bottom:28px;padding:5px}.role-tab{align-items:center;background:#0000;border:none;border-radius:10px;color:#7b6f8f;color:var(--text-muted);cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-family:inherit;font-size:13px;font-weight:600;gap:4px;padding:10px 6px;transition:all .3s cubic-bezier(.34,1.56,.64,1);transition:var(--transition)}.role-tab .role-emoji{font-size:18px}.role-tab.active{background:#fff;box-shadow:0 2px 8px #503c2814;box-shadow:var(--shadow-sm);color:#e07c54;color:var(--primary)}.role-tab:hover:not(.active){background:#e07c5412}.auth-calendar{background:#fdf6f0;background:var(--warm-1);border:1px solid #f0e4d8;border:1px solid var(--card-border);border-radius:14px;border-radius:var(--radius);margin-top:20px;padding:16px}.auth-calendar-header{align-items:center;color:#1e1b2e;color:var(--text);display:flex;font-size:13px;font-weight:700;justify-content:space-between;margin-bottom:10px}.auth-calendar-grid{grid-gap:2px;display:grid;font-size:11px;gap:2px;grid-template-columns:repeat(7,1fr)}.cal-day{align-items:center;aspect-ratio:1;border-radius:6px;color:#7b6f8f;color:var(--text-muted);cursor:default;display:flex;font-weight:500;justify-content:center}.cal-day.header{color:#b0a5c0;color:var(--text-dim);font-weight:700}.cal-day.today{background:#e07c54;background:var(--primary);border-radius:6px;color:#fff;font-weight:700}.cal-day.has-event{position:relative}.cal-day.has-event:after{background:#f4a56a;background:var(--secondary);border-radius:50%;bottom:2px;content:"";height:4px;position:absolute;width:4px}.auth-info-cards{display:flex;flex-direction:column;gap:8px;margin-top:16px}.auth-info-card{align-items:center;border-radius:14px;border-radius:var(--radius);display:flex;font-size:12px;font-weight:500;gap:10px;padding:10px 14px}.auth-info-card.notice{background:#3b82f61a;background:var(--info-bg);border:1px solid #3b82f633;color:#3b82f6;color:var(--info)}.auth-info-card.alert{background:#f59e0b1a;background:var(--warning-bg);border:1px solid #f59e0b33;color:#f59e0b;color:var(--warning)}.form-group{margin-bottom:18px}.form-group label{color:#4a3f6b;color:var(--text-2);display:block;font-size:13px;font-weight:600;margin-bottom:7px}.form-control{background:#fdf6f0;background:var(--warm-1);border:1.5px solid #f0e4d8;border:1.5px solid var(--card-border);border-radius:14px;border-radius:var(--radius);color:#1e1b2e;color:var(--text);font-family:inherit;font-size:14px;outline:none;padding:13px 16px;transition:all .3s cubic-bezier(.34,1.56,.64,1);transition:var(--transition);width:100%}.form-control:focus{background:#fff;border-color:#e07c54;border-color:var(--primary);box-shadow:0 0 0 3px #e07c542e;box-shadow:0 0 0 3px var(--primary-glow)}.form-control::placeholder{color:#b0a5c0;color:var(--text-dim)}select.form-control{appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%237b6f8f'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;cursor:pointer;padding-right:40px}.btn{align-items:center;border:none;border-radius:14px;border-radius:var(--radius);cursor:pointer;display:inline-flex;font-family:inherit;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:12px 22px;text-decoration:none;transition:all .3s cubic-bezier(.34,1.56,.64,1);transition:var(--transition);white-space:nowrap}.btn-primary{background:linear-gradient(135deg,#e07c54,#c96b42);background:linear-gradient(135deg,var(--primary),var(--primary-dark));box-shadow:0 4px 18px #e07c542e;box-shadow:0 4px 18px var(--primary-glow);color:#fff}.btn-primary:hover{box-shadow:0 12px 32px #e07c542e;box-shadow:0 12px 32px var(--primary-glow);transform:translateY(-3px) scale(1.02)}.btn-primary:active{transform:translateY(0) scale(.98)}.btn-accent{background:linear-gradient(135deg,#6c63ff,#5046e5);background:linear-gradient(135deg,var(--accent),#5046e5);box-shadow:0 4px 18px #6c63ff26;box-shadow:0 4px 18px var(--accent-glow);color:#fff}.btn-accent:hover{box-shadow:0 12px 32px #6c63ff26;box-shadow:0 12px 32px var(--accent-glow);transform:translateY(-3px) scale(1.02)}.btn-outline{background:#0000;border:1.5px solid #e07c54;border:1.5px solid var(--primary);color:#e07c54;color:var(--primary)}.btn-outline:hover{background:#e07c542e;background:var(--primary-glow);transform:translateY(-1px)}.btn-ghost{background:#fdf6f0;background:var(--warm-1);border:1.5px solid #f0e4d8;border:1.5px solid var(--card-border);color:#4a3f6b;color:var(--text-2)}.btn-ghost:hover{background:#f9ede3;background:var(--warm-2);transform:translateY(-1px)}.btn-danger{background:#f052521a;background:var(--danger-bg);border:1.5px solid #f052524d;color:#f05252;color:var(--danger)}.btn-danger:hover{background:#f0525233}.btn-success{background:#34c77b1a;background:var(--success-bg);border:1.5px solid #34c77b4d;color:#34c77b;color:var(--success)}.btn-success:hover{background:#34c77b33}.btn-sm{border-radius:10px;font-size:12px;padding:8px 14px}.btn-xs{border-radius:8px;font-size:11px;padding:5px 10px}.btn-full{width:100%}.btn-icon{border-radius:12px;padding:10px}.app-layout{display:flex;min-height:100vh}.sidebar{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#1a1625d9;border-right:1px solid #ffffff0f;display:flex;flex-direction:column;height:100vh;left:0;overflow-x:hidden;overflow-y:auto;padding:20px 12px;position:fixed;top:0;transition:transform .3s cubic-bezier(.4,0,.2,1);width:260px;z-index:50}.sidebar-overlay{background:#00000080;display:none;inset:0;position:fixed;z-index:49}.sidebar-logo{align-items:center;border-bottom:1px solid #ffffff14;display:flex;gap:12px;margin-bottom:16px;padding:8px 10px 24px}.sidebar-logo .logo-icon{align-items:center;background:linear-gradient(135deg,#e07c54,#f4a56a);background:linear-gradient(135deg,var(--primary),var(--secondary));border-radius:14px;box-shadow:0 8px 24px #e07c544d;display:flex;flex-shrink:0;font-size:22px;height:44px;justify-content:center;width:44px}.sidebar-logo h2{color:#fff;font-size:17px;font-weight:800;letter-spacing:-.3px}.sidebar-logo span{color:#fff6;display:block;font-size:11px}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:2px}.nav-section-title{color:#ffffff40;font-size:10px;font-weight:700;letter-spacing:1.5px;padding:14px 12px 6px;text-transform:uppercase}.nav-link{align-items:center;background:none;border:none;border-radius:12px;color:#ffffff80;cursor:pointer;display:flex;font-family:inherit;font-size:13.5px;font-weight:500;gap:12px;padding:11px 14px;position:relative;text-decoration:none;transition:all .3s cubic-bezier(.34,1.56,.64,1);transition:var(--transition);width:100%}.nav-link:hover{background:#ffffff0f;background:var(--sidebar-hover);color:#ffffffd9}.nav-link.active{background:#e07c542e;background:var(--sidebar-active);color:#f09070;color:var(--primary-light);font-weight:600}.nav-link.active .nav-indicator{opacity:1}.nav-indicator{background:#e07c54;background:var(--primary);border-radius:50%;height:6px;opacity:0;position:absolute;right:10px;transition:all .3s cubic-bezier(.34,1.56,.64,1);transition:var(--transition);width:6px}.nav-link svg{flex-shrink:0;height:18px;opacity:.85;width:18px}.nav-badge{background:#f05252;background:var(--danger);border-radius:20px;color:#fff;font-size:10px;font-weight:700;margin-left:auto;min-width:20px;padding:2px 7px;text-align:center}.sidebar-footer{border-top:1px solid #ffffff14;margin-top:6px;padding-top:14px}.user-info-sidebar{align-items:center;background:#ffffff0f;border-radius:12px;cursor:pointer;display:flex;gap:10px;margin-bottom:8px;padding:10px 12px;transition:all .3s cubic-bezier(.34,1.56,.64,1);transition:var(--transition)}.user-info-sidebar:hover{background:#ffffff1a}.user-avatar{align-items:center;background:linear-gradient(135deg,#e07c54,#f4a56a);background:linear-gradient(135deg,var(--primary),var(--secondary));border-radius:12px;color:#fff;display:flex;flex-shrink:0;font-size:14px;font-weight:800;height:38px;justify-content:center;overflow:hidden;width:38px}.user-avatar img{border-radius:12px;height:100%;object-fit:cover;width:100%}.user-info-text .name{color:#fff;font-size:13px;font-weight:700}.user-info-text .role-badge{background:#e07c542e;background:var(--sidebar-active);border-radius:20px;color:#f09070;color:var(--primary-light);display:inline-block;font-size:10px;font-weight:600;margin-top:1px;padding:1px 6px;text-transform:capitalize}.main-content{background:#fdf6f0;background:var(--bg2);display:flex;flex:1 1;flex-direction:column;margin-left:260px;min-height:100vh}.topbar{align-items:center;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffeb;background:var(--topbar-bg);border-bottom:1px solid #f0e4d8;border-bottom:1px solid var(--card-border);display:flex;justify-content:space-between;padding:14px 28px;position:sticky;top:0;z-index:40}.topbar-left h2{color:#1e1b2e;color:var(--text);font-size:20px;font-weight:800;letter-spacing:-.3px}.topbar-left p{color:#7b6f8f;color:var(--text-muted);font-size:12.5px;margin-top:2px}.topbar-right{gap:10px}.topbar-btn,.topbar-right{align-items:center;display:flex}.topbar-btn{background:#fff;border:1.5px solid #f0e4d8;border:1.5px solid var(--card-border);border-radius:12px;color:#7b6f8f;color:var(--text-muted);cursor:pointer;font-family:inherit;height:40px;justify-content:center;position:relative;transition:all .3s cubic-bezier(.34,1.56,.64,1);transition:var(--transition);width:40px}.topbar-btn:hover{background:#fdf6f0;background:var(--warm-1);border-color:#e07c54;border-color:var(--primary);color:#e07c54;color:var(--primary)}.notif-dot{background:#f05252;background:var(--danger);border:2px solid #fff;border-radius:50%;height:8px;position:absolute;right:6px;top:6px;width:8px}.profile-btn{align-items:center;background:#fff;border:1.5px solid #f0e4d8;border:1.5px solid var(--card-border);border-radius:14px;cursor:pointer;display:flex;font-family:inherit;gap:10px;padding:6px 14px 6px 6px;transition:all .3s cubic-bezier(.34,1.56,.64,1);transition:var(--transition)}.profile-btn:hover{background:#fdf6f0;background:var(--warm-1);border-color:#e07c54;border-color:var(--primary)}.profile-btn .avatar-sm{align-items:center;background:linear-gradient(135deg,#e07c54,#f4a56a);background:linear-gradient(135deg,var(--primary),var(--secondary));border-radius:10px;color:#fff;display:flex;font-size:12px;font-weight:800;height:32px;justify-content:center;overflow:hidden;width:32px}.profile-btn .avatar-sm img{border-radius:10px;height:100%;object-fit:cover;width:100%}.profile-btn span{color:#1e1b2e;color:var(--text);font-size:13px;font-weight:600}.dropdown-menu{animation:fadeSlideUp .2s ease;background:#fff;border:1.5px solid #f0e4d8;border:1.5px solid var(--card-border);border-radius:20px;border-radius:var(--radius-lg);box-shadow:0 12px 40px #503c2826;box-shadow:var(--shadow-md);min-width:220px;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);z-index:100}.dropdown-menu a,.dropdown-menu button{align-items:center;background:none;border:none;color:#4a3f6b;color:var(--text-2);cursor:pointer;display:flex;font-family:inherit;font-size:13.5px;font-weight:500;gap:12px;padding:12px 18px;text-decoration:none;transition:all .3s cubic-bezier(.34,1.56,.64,1);transition:var(--transition);width:100%}.dropdown-menu a:hover,.dropdown-menu button:hover{background:#fdf6f0;background:var(--warm-1);color:#e07c54;color:var(--primary)}.dropdown-divider{background:#f0e4d8;background:var(--card-border);height:1px;margin:4px 0}.notif-panel{animation:fadeSlideUp .2s ease;background:#fff;border:1.5px solid #f0e4d8;border:1.5px solid var(--card-border);border-radius:20px;border-radius:var(--radius-lg);box-shadow:0 12px 40px #503c2826;box-shadow:var(--shadow-md);overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);width:320px;z-index:100}.notif-panel-header{align-items:center;color:#1e1b2e;color:var(--text);font-size:14px;font-weight:700;justify-content:space-between;padding:16px 18px}.notif-item,.notif-panel-header{border-bottom:1px solid #f0e4d8;border-bottom:1px solid var(--card-border);display:flex}.notif-item{align-items:flex-start;cursor:pointer;gap:12px;padding:14px 18px;transition:all .3s cubic-bezier(.34,1.56,.64,1);transition:var(--transition)}.notif-item:hover{background:#fdf6f0;background:var(--warm-1)}.notif-item:last-child{border-bottom:none}.notif-icon{align-items:center;border-radius:10px;display:flex;flex-shrink:0;font-size:16px;height:36px;justify-content:center;width:36px}.notif-text{color:#1e1b2e;color:var(--text);font-size:12.5px;font-weight:500}.notif-time{color:#7b6f8f;color:var(--text-muted);font-size:11px;margin-top:2px}.page-content{flex:1 1;padding:28px}.card{background:#fff;background:var(--card);border:1.5px solid #f0e4d8;border:1.5px solid var(--card-border);border-radius:20px;border-radius:var(--radius-lg);box-shadow:0 2px 8px #503c2814;box-shadow:var(--shadow-sm);padding:24px;transition:all .3s cubic-bezier(.34,1.56,.64,1);transition:var(--transition)}.card:hover{box-shadow:0 8px 30px #503c281f;box-shadow:var(--shadow)}.card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.card-title{color:#1e1b2e;color:var(--text);font-size:16px;font-weight:700}.card-subtitle{color:#7b6f8f;color:var(--text-muted);font-size:12.5px;margin-top:2px}.stat-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));margin-bottom:28px}.stat-card{align-items:flex-start;background:#fff;background:var(--card);border:1.5px solid #f0e4d8;border:1.5px solid var(--card-border);border-radius:20px;border-radius:var(--radius-lg);cursor:default;display:flex;gap:16px;overflow:hidden;padding:22px;position:relative;transition:all .3s cubic-bezier(.34,1.56,.64,1);transition:var(--transition)}.stat-card:after{background:linear-gradient(90deg,#e07c54,#f4a56a);background:linear-gradient(90deg,var(--primary),var(--secondary));bottom:0;content:"";height:3px;left:0;position:absolute;transform:scaleX(0);transform-origin:left;transition:transform .3s ease;width:100%}.stat-card:hover{border-color:#e07c54;border-color:var(--primary);box-shadow:0 12px 40px #503c2826;box-shadow:var(--shadow-md);transform:translateY(-3px)}.stat-card:hover:after{transform:scaleX(1)}.stat-icon{align-items:center;border-radius:16px;display:flex;flex-shrink:0;font-size:22px;height:50px;justify-content:center;width:50px}.stat-icon.coral{background:#e07c541f}.stat-icon.violet{background:#6c63ff1f}.stat-icon.teal{background:#0d94881f}.stat-icon.rose{background:#f43f5e1f}.stat-icon.amber{background:#f59e0b1f}.stat-icon.green{background:#34c77b1f}.stat-icon.blue{background:#3b82f61f}.stat-icon.purple{background:#a855f71f}.stat-value{color:#1e1b2e;color:var(--text);font-size:30px;font-weight:900;letter-spacing:-1px;line-height:1}.stat-label{color:#7b6f8f;color:var(--text-muted);font-size:12px;font-weight:500;margin-top:5px}.stat-change{align-items:center;display:flex;font-size:11px;font-weight:700;gap:3px;margin-top:4px}.stat-change.up{color:#34c77b;color:var(--success)}.stat-change.down{color:#f05252;color:var(--danger)}.page-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;margin-bottom:24px}.page-header-left h3{color:#1e1b2e;color:var(--text);font-size:22px;font-weight:800;letter-spacing:-.4px}.page-header-left p{color:#7b6f8f;color:var(--text-muted);font-size:13px;margin-top:3px}.page-header-actions{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.table-wrapper{background:#fff;border:1.5px solid #f0e4d8;border:1.5px solid var(--card-border);border-radius:20px;border-radius:var(--radius-lg);overflow-x:auto}table{border-collapse:collapse;width:100%}th{background:#fdf6f0;background:var(--warm-1);border-bottom:1.5px solid #f0e4d8;border-bottom:1.5px solid var(--card-border);color:#7b6f8f;color:var(--text-muted);font-size:11px;font-weight:700;letter-spacing:.8px;padding:13px 18px;text-align:left;text-transform:uppercase;white-space:nowrap}td{border-bottom:1px solid #f0e4d8;border-bottom:1px solid var(--card-border);color:#4a3f6b;color:var(--text-2);font-size:13.5px;padding:15px 18px}tbody tr:last-child td{border-bottom:none}tbody tr{position:relative;transition:all .3s cubic-bezier(.34,1.56,.64,1);transition:var(--transition);z-index:1}tbody tr:hover{border-radius:14px;border-radius:var(--radius);box-shadow:0 12px 40px #503c2826;box-shadow:var(--shadow-md);transform:scale(1.01);z-index:10}tbody tr:hover td{background:#fff;border-color:#0000}.badge{align-items:center;border-radius:20px;display:inline-flex;font-size:11.5px;font-weight:700;gap:5px;padding:4px 10px}.badge-student{background:#6c63ff1f;color:#6c63ff;color:var(--accent)}.badge-teacher{background:#0d94881f;color:#0d9488}.badge-admin{background:#e07c541f;color:#e07c54;color:var(--primary)}.badge-open{background:#f052521a;background:var(--danger-bg);color:#f05252;color:var(--danger)}.badge-in-progress{background:#f59e0b1a;background:var(--warning-bg);color:#f59e0b;color:var(--warning)}.badge-resolved{background:#34c77b1a;background:var(--success-bg);color:#34c77b;color:var(--success)}.badge-closed{background:#64748b1a;color:#64748b}.badge-pending{background:#f59e0b1a;background:var(--warning-bg);color:#f59e0b;color:var(--warning)}.badge-approved{background:#34c77b1a;background:var(--success-bg);color:#34c77b;color:var(--success)}.badge-rejected{background:#f052521a;background:var(--danger-bg);color:#f05252;color:var(--danger)}.badge-final{background:#34c77b1a;background:var(--success-bg);color:#34c77b;color:var(--success)}.badge-draft{background:#6c63ff1f;color:#6c63ff;color:var(--accent)}.badge-paid{background:#34c77b1a;background:var(--success-bg);color:#34c77b;color:var(--success)}.badge-unpaid{background:#f052521a;background:var(--danger-bg);color:#f05252;color:var(--danger)}.badge-role{align-items:center;border-radius:20px;display:inline-flex;font-size:11.5px;font-weight:700;padding:4px 10px}.badge-role.student{background:#6c63ff1f;color:#6c63ff;color:var(--accent)}.badge-role.teacher{background:#0d94881f;color:#0d9488}.badge-role.admin{background:#e07c541f;color:#e07c54;color:var(--primary)}.badge-status{align-items:center;border-radius:20px;display:inline-flex;font-size:11.5px;font-weight:700;padding:4px 10px}.badge-status.open{background:#f052521a;background:var(--danger-bg);color:#f05252;color:var(--danger)}.badge-status.in-progress{background:#f59e0b1a;background:var(--warning-bg);color:#f59e0b;color:var(--warning)}.badge-status.resolved{background:#34c77b1a;background:var(--success-bg);color:#34c77b;color:var(--success)}.badge-status.closed{background:#64748b1a;color:#64748b}.badge-status.pending{background:#f59e0b1a;background:var(--warning-bg);color:#f59e0b;color:var(--warning)}.badge-status.approved{background:#34c77b1a;background:var(--success-bg);color:#34c77b;color:var(--success)}.badge-status.rejected{background:#f052521a;background:var(--danger-bg);color:#f05252;color:var(--danger)}.badge-status.final{background:#34c77b1a;background:var(--success-bg);color:#34c77b;color:var(--success)}.badge-status.draft{background:#6c63ff1f;color:#6c63ff;color:var(--accent)}.search-bar{align-items:center;background:#fff;border:1.5px solid #f0e4d8;border:1.5px solid var(--card-border);border-radius:14px;border-radius:var(--radius);display:flex;gap:10px;padding:10px 16px;transition:all .3s cubic-bezier(.34,1.56,.64,1);transition:var(--transition)}.search-bar:focus-within{border-color:#e07c54;border-color:var(--primary);box-shadow:0 0 0 3px #e07c542e;box-shadow:0 0 0 3px var(--primary-glow)}.search-bar input{background:none;border:none;color:#1e1b2e;color:var(--text);flex:1 1;font-family:inherit;font-size:14px;outline:none}.search-bar input::placeholder,.search-bar svg{color:#b0a5c0;color:var(--text-dim)}.search-bar svg{flex-shrink:0}.modal-overlay{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#1e1b2e99;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:100}.modal{animation:fadeSlideUp .3s ease;background:#fff;border:1.5px solid #f0e4d8;border:1.5px solid var(--card-border);border-radius:28px;border-radius:var(--radius-xl);box-shadow:0 24px 80px #503c2833;max-height:90vh;max-width:540px;overflow-y:auto;padding:32px;width:100%}.modal-title{align-items:center;color:#1e1b2e;color:var(--text);display:flex;font-size:20px;font-weight:800;gap:10px;margin-bottom:24px}.modal-footer{border-top:1px solid #f0e4d8;border-top:1px solid var(--card-border);display:flex;gap:10px;justify-content:flex-end;margin-top:24px;padding-top:20px}.marks-bar{background:#f2dfd0;background:var(--warm-3);border-radius:4px;height:7px;margin-top:6px;overflow:hidden}.marks-bar-fill{background:linear-gradient(90deg,#e07c54,#f4a56a);background:linear-gradient(90deg,var(--primary),var(--secondary));border-radius:4px;height:100%;transition:width .7s cubic-bezier(.4,0,.2,1)}.marks-bar-fill.danger{background:linear-gradient(90deg,#f05252,#f87171);background:linear-gradient(90deg,var(--danger),#f87171)}.marks-bar-fill.warning{background:linear-gradient(90deg,#f59e0b,#fbbf24);background:linear-gradient(90deg,var(--warning),#fbbf24)}.empty-state{color:#7b6f8f;color:var(--text-muted);padding:60px 20px;text-align:center}.empty-state .empty-icon{font-size:48px;margin-bottom:16px;opacity:.6}.empty-state h4{color:#4a3f6b;color:var(--text-2);font-size:17px;font-weight:700;margin-bottom:8px}.empty-state p{color:#7b6f8f;color:var(--text-muted);font-size:13.5px}.loading-spinner{animation:spin .7s linear infinite;border:3px solid #f2dfd0;border-top-color:#e07c54;border:3px solid var(--warm-3);border-radius:50%;border-top-color:var(--primary);height:40px;margin:40px auto;width:40px}.loading-overlay{align-items:center;display:flex;justify-content:center;min-height:200px}@keyframes spin{to{transform:rotate(1turn)}}.ticket-chat{background:#fdf6f0;background:var(--warm-1);border:1.5px solid #f0e4d8;border:1.5px solid var(--card-border);border-radius:14px;border-radius:var(--radius);gap:12px;max-height:280px;overflow-y:auto;padding:16px}.chat-message,.ticket-chat{display:flex;flex-direction:column}.chat-message{gap:4px;max-width:80%}.chat-message.teacher{align-self:flex-end}.chat-bubble{border-radius:14px;font-size:13px;font-weight:500;line-height:1.5;padding:10px 14px}.chat-message.student .chat-bubble{background:#6c63ff1a;border:1px solid #6c63ff33;border-radius:14px 14px 14px 4px;color:#1e1b2e;color:var(--text)}.chat-message.teacher .chat-bubble{background:#e07c541a;border:1px solid #e07c5433;border-radius:14px 14px 4px 14px;color:#1e1b2e;color:var(--text)}.chat-meta{color:#b0a5c0;color:var(--text-dim);font-size:10px}.alert{align-items:center;border-radius:14px;border-radius:var(--radius);display:flex;font-size:13.5px;font-weight:500;gap:10px;margin-bottom:16px;padding:13px 16px}.alert-error{background:#f052521a;background:var(--danger-bg);border:1px solid #f0525233;color:#f05252;color:var(--danger)}.alert-success{background:#34c77b1a;background:var(--success-bg);border:1px solid #34c77b33;color:#34c77b;color:var(--success)}.alert-warning{background:#f59e0b1a;background:var(--warning-bg);border:1px solid #f59e0b33;color:#f59e0b;color:var(--warning)}.alert-info{background:#3b82f61a;background:var(--info-bg);border:1px solid #3b82f633;color:#3b82f6;color:var(--info)}.divider{background:#f0e4d8;background:var(--card-border);height:1px;margin:20px 0}.gradient-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#e07c54,#f4a56a);background:linear-gradient(135deg,var(--primary),var(--secondary));-webkit-background-clip:text}.chip{align-items:center;background:#f9ede3;background:var(--warm-2);border:1px solid #e8ccbb;border:1px solid var(--warm-4);border-radius:20px;color:#4a3f6b;color:var(--text-2);cursor:default;display:inline-flex;font-size:12px;font-weight:600;gap:5px;padding:4px 12px}.avatar-upload-wrapper{cursor:pointer;height:100px;margin:0 auto 20px;position:relative;width:100px}.avatar-upload-wrapper .avatar-lg{align-items:center;background:linear-gradient(135deg,#e07c54,#f4a56a);background:linear-gradient(135deg,var(--primary),var(--secondary));border:3px solid #f09070;border:3px solid var(--primary-light);border-radius:50%;color:#fff;display:flex;font-size:34px;font-weight:800;height:100px;justify-content:center;overflow:hidden;width:100px}.avatar-upload-wrapper .avatar-lg img{border-radius:50%;height:100%;object-fit:cover;width:100%}.avatar-upload-overlay{align-items:center;background:#00000080;border-radius:50%;color:#fff;display:flex;font-size:20px;inset:0;justify-content:center;opacity:0;position:absolute;transition:all .3s cubic-bezier(.34,1.56,.64,1);transition:var(--transition)}.avatar-upload-wrapper:hover .avatar-upload-overlay{opacity:1}.timetable-grid{grid-gap:4px;display:grid;gap:4px;grid-template-columns:80px repeat(6,1fr);overflow-x:auto}.tt-cell{align-items:center;border-radius:10px;display:flex;flex-direction:column;font-size:11.5px;font-weight:600;justify-content:center;min-height:56px;padding:10px 8px;text-align:center}.tt-header{background:#f9ede3;background:var(--warm-2);color:#4a3f6b;color:var(--text-2);font-size:12px;font-weight:700}.tt-time{background:#1a1625;background:var(--sidebar-bg);color:#ffffffb3;font-size:11px}.tt-subject{background:#fff;border:1.5px solid #f0e4d8;border:1.5px solid var(--card-border);color:#4a3f6b;color:var(--text-2);font-size:11px}.tt-subject.active{background:#e07c542e;background:var(--primary-glow);border-color:#f09070;border-color:var(--primary-light);color:#c96b42;color:var(--primary-dark)}.tt-subject .subject-name{font-weight:700}.tt-subject .teacher-name{color:#7b6f8f;color:var(--text-muted);font-weight:400;margin-top:2px}.admit-card-preview{background:linear-gradient(135deg,#fdf6f0,#fff);background:linear-gradient(135deg,var(--warm-1),#fff);border:2px solid #e07c54;border:2px solid var(--primary);border-radius:20px;border-radius:var(--radius-lg);overflow:hidden;padding:28px;position:relative}.admit-card-preview:before{background:radial-gradient(circle,#e07c542e,#0000);background:radial-gradient(circle,var(--primary-glow),#0000);content:"";height:100px;position:absolute;right:0;top:0;width:100px}.admit-card-preview h4{color:#1e1b2e;color:var(--text);font-size:19px;font-weight:800;margin-bottom:4px}.admit-card-preview .info-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr;margin-top:18px}.info-item label{color:#b0a5c0;color:var(--text-dim);font-size:10px;font-weight:600;letter-spacing:.8px;text-transform:uppercase}.info-item span{color:#1e1b2e;color:var(--text);display:block;font-size:14px;font-weight:700;margin-top:2px}.quick-actions-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.quick-action-card{align-items:center;background:#fff;border:1.5px solid #f0e4d8;border:1.5px solid var(--card-border);border-radius:20px;border-radius:var(--radius-lg);cursor:pointer;display:flex;flex-direction:column;gap:10px;padding:20px 16px;text-align:center;text-decoration:none;transition:all .3s cubic-bezier(.34,1.56,.64,1);transition:var(--transition)}.quick-action-card:hover{background:#fdf6f0;background:var(--warm-1);border-color:#e07c54;border-color:var(--primary);box-shadow:0 12px 40px #503c2826;box-shadow:var(--shadow-md);transform:translateY(-3px)}.quick-action-icon{align-items:center;background:#f9ede3;background:var(--warm-2);border-radius:16px;display:flex;font-size:24px;height:52px;justify-content:center;width:52px}.quick-action-card:hover .quick-action-icon{background:#e07c542e;background:var(--primary-glow)}.quick-action-label{color:#4a3f6b;color:var(--text-2);font-size:12.5px;font-weight:700}.theme-picker{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.theme-swatch{border:3px solid #0000;border-radius:50%;cursor:pointer;height:30px;position:relative;transition:all .3s cubic-bezier(.34,1.56,.64,1);transition:var(--transition);width:30px}.theme-swatch:hover{transform:scale(1.15)}.theme-swatch.active{border-color:#fff;box-shadow:0 0 0 2px #e07c54;box-shadow:0 0 0 2px var(--primary)}.theme-swatch.active:after{color:#fff;content:"✓";font-size:12px;font-weight:800;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.fee-item{align-items:center;background:#fff;border:1.5px solid #f0e4d8;border:1.5px solid var(--card-border);border-radius:14px;border-radius:var(--radius);display:flex;justify-content:space-between;padding:16px;transition:all .3s cubic-bezier(.34,1.56,.64,1);transition:var(--transition)}.fee-item:hover{background:#fdf6f0;background:var(--warm-1);border-color:#e07c54;border-color:var(--primary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.page-enter{animation:fadeSlideUp .35s ease}.slide-in-right{animation:slideInRight .3s ease}.auth-switch{color:#7b6f8f;color:var(--text-muted);font-size:13.5px;margin-top:22px;text-align:center}.auth-switch button{background:none;border:none;color:#e07c54;color:var(--primary);cursor:pointer;font-family:inherit;font-size:13.5px;font-weight:700;text-decoration:underline;text-underline-offset:2px}.profile-header-card{align-items:center;background:linear-gradient(135deg,#1a1625,#2d1b69);background:linear-gradient(135deg,var(--sidebar-bg),#2d1b69);border-radius:28px;border-radius:var(--radius-xl);color:#fff;display:flex;gap:28px;margin-bottom:24px;overflow:hidden;padding:40px;position:relative}.profile-header-card:before{background:radial-gradient(circle,#e07c542e 0,#0000 70%);background:radial-gradient(circle,var(--primary-glow) 0,#0000 70%);border-radius:50%;content:"";height:400px;position:absolute;right:-100px;top:-100px;width:400px}.attendance-calendar{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(7,1fr)}.att-day{align-items:center;aspect-ratio:1;border-radius:10px;cursor:default;display:flex;font-size:13px;font-weight:700;justify-content:center}.att-day.present{background:#34c77b1a;background:var(--success-bg);color:#34c77b;color:var(--success)}.att-day.absent{background:#f052521a;background:var(--danger-bg);color:#f05252;color:var(--danger)}.att-day.holiday{background:#3b82f61a;background:var(--info-bg);color:#3b82f6;color:var(--info)}.att-day.future{background:#fdf6f0;background:var(--warm-1);color:#b0a5c0;color:var(--text-dim)}.att-day.header{background:none;color:#7b6f8f;color:var(--text-muted);font-size:11px;font-weight:700}@media (max-width:900px){.auth-page{grid-template-columns:1fr}.auth-page-left{display:none}.auth-page-right{padding:40px 24px}}@media (max-width:768px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.sidebar-overlay{display:block}.main-content{margin-left:0}.stat-grid{grid-template-columns:1fr 1fr}.page-content{padding:18px 16px}.topbar{padding:12px 18px}.profile-header-card{flex-direction:column;padding:28px 20px;text-align:center}.quick-actions-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.admit-card-preview .info-grid,.stat-grid{grid-template-columns:1fr}}
/*# sourceMappingURL=main.77995aef.css.map*/