.home{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#0a0e27 0%,#1a1f3a 100%)}.home-container{max-width:900px;width:100%}.home-header{text-align:center;margin-bottom:4rem}.home-header h1{font-size:3rem;font-weight:700;background:linear-gradient(135deg,#5865f2 0%,#7289da 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem}.home-header .subtitle{font-size:1.25rem;color:#b5bac1}.home-content{margin-bottom:4rem}.intro-text{text-align:center;margin-bottom:3rem;font-size:1.1rem;color:#dbdee1}.intro-text p{margin-bottom:1rem;line-height:1.6}.login-options{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:3rem}.login-option{padding:2.5rem;border-radius:1rem;text-align:center;transition:all .3s ease;border:2px solid rgba(88,101,242,.3);background:rgba(20,25,45,.6);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-option:hover{border-color:#5865f2cc;background:rgba(20,25,45,.9);transform:translateY(-4px);box-shadow:0 8px 24px #5865f233}.login-option .option-icon{font-size:3rem;margin-bottom:1rem}.login-option h3{font-size:1.5rem;margin-bottom:.5rem;color:#f2f3f5}.login-option p{color:#9ca3af;font-size:.95rem}.admin-option{border-color:#5865f24d}.admin-option:hover{border-color:#5865f2;box-shadow:0 8px 24px #5865f233}.staff-option{border-color:#5865f24d}.staff-option:hover{border-color:#5865f2;box-shadow:0 8px 24px #5865f233}.home-footer{text-align:center;color:#72767d;font-size:.9rem}@media (max-width: 768px){.login-options{grid-template-columns:1fr}.home-header h1{font-size:2rem}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#0a0e27 0%,#1a1f3a 100%)}.login-card{width:100%;max-width:420px;padding:3rem;border-radius:1rem;background:rgba(20,25,45,.8);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(88,101,242,.2);box-shadow:0 8px 32px #0000004d}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:1.75rem;font-weight:700;color:#f2f3f5;margin-bottom:.5rem}.login-header p{color:#b5bac1;font-size:.95rem}.admin-card{border-color:#5865f24d}.admin-card:hover{border-color:#5865f280;box-shadow:0 12px 48px #5865f226}.staff-card{border-color:#5865f24d}.staff-card:hover{border-color:#5865f280;box-shadow:0 12px 48px #5865f226}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#dbdee1;font-size:.9rem}.form-group input{width:100%;padding:.75rem;border-radius:.5rem;border:1px solid #3a3f54;background:rgba(20,25,45,.6);color:#e0e0e0}.form-group input:focus{border-color:#5865f2;background:rgba(20,25,45,.9);box-shadow:0 0 0 3px #5865f21a}.error-message{padding:.75rem;margin-bottom:1.5rem;background:rgba(239,68,68,.1);border:1px solid #ef4444;border-radius:.5rem;color:#fca5a5;font-size:.9rem;text-align:center}.submit-button{width:100%;padding:.75rem;margin-bottom:1.5rem;background:linear-gradient(135deg,#5865f2 0%,#7289da 100%);color:#fff;border-radius:.5rem;font-weight:600;transition:all .3s ease}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #5865f24d}.submit-button:disabled{opacity:.7;cursor:not-allowed}.login-footer{text-align:center;padding-top:1.5rem;border-top:1px solid rgba(88,101,242,.2);color:#72767d;font-size:.85rem}.login-footer p{margin-bottom:.5rem}.login-footer p:last-child{margin-bottom:0}@media (max-width: 480px){.login-card{padding:2rem}.login-header h1{font-size:1.5rem}}.admin-dashboard{min-height:100vh;background:linear-gradient(135deg,#0a0e27 0%,#1a1f3a 100%);display:flex;flex-direction:column}.dashboard-header{background:rgba(20,25,45,.9);border-bottom:1px solid rgba(88,101,242,.2);padding:1.5rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 8px #0000004d}.header-content h1{font-size:1.75rem;font-weight:700;color:#f2f3f5;margin-bottom:.25rem}.header-content p{color:#b5bac1;font-size:.95rem}.dashboard-container{display:flex;flex:1;overflow:hidden}.staff-sidebar{width:300px;background:rgba(20,25,45,.7);border-right:1px solid rgba(88,101,242,.2);display:flex;flex-direction:column;overflow-y:auto;padding:1.5rem}.sidebar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;gap:1rem}.sidebar-header h2{font-size:1.1rem;font-weight:600;color:#f2f3f5}.add-staff-button{padding:.5rem 1rem;background:linear-gradient(135deg,#5865f2 0%,#7289da 100%);color:#fff;border-radius:.375rem;font-size:.875rem;font-weight:500;white-space:nowrap;transition:all .2s ease}.add-staff-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #5865f24d}.add-staff-form{margin-bottom:1.5rem;padding:1rem;background:rgba(88,101,242,.1);border-radius:.5rem;border:1px solid rgba(88,101,242,.3)}.add-staff-form input{width:100%;margin-bottom:.75rem}.add-staff-form .form-buttons{display:flex;gap:.5rem}.form-buttons{display:flex;gap:.75rem}.button-primary{flex:1;padding:.5rem;background:linear-gradient(135deg,#5865f2 0%,#7289da 100%);color:#fff;border-radius:.375rem;font-weight:500;font-size:.875rem;transition:all .2s ease}.button-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #5865f24d}.button-secondary{flex:1;padding:.5rem;background:transparent;border:1px solid #3a3f54;color:#b5bac1;border-radius:.375rem;font-weight:500;font-size:.875rem;transition:all .2s ease}.button-secondary:hover{background:rgba(88,101,242,.1);border-color:#5865f2;color:#dbdee1}.staff-list{flex:1;overflow-y:auto}.staff-item{display:flex;gap:1rem;padding:1rem;margin-bottom:.75rem;background:rgba(88,101,242,.05);border-radius:.5rem;cursor:pointer;transition:all .2s ease;border:2px solid transparent;align-items:center}.staff-item:hover{background:rgba(88,101,242,.15);border-color:#5865f24d}.staff-item.selected{background:rgba(88,101,242,.2);border-color:#5865f2}.staff-item img{width:48px;height:48px;border-radius:50%;object-fit:cover;flex-shrink:0}.staff-info{flex:1;min-width:0}.staff-name{font-weight:600;color:#f2f3f5;margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.staff-points{color:#b5bac1;font-size:.85rem}.staff-details{flex:1;display:flex;flex-direction:column;overflow-y:auto;padding:2rem}.no-selection{display:flex;align-items:center;justify-content:center;height:100%;color:#72767d;text-align:center}.staff-header{margin-bottom:2rem;border-radius:1rem;overflow:hidden;background:rgba(88,101,242,.1);border:1px solid rgba(88,101,242,.2)}.staff-header .banner{width:100%;height:200px;object-fit:cover;display:block}.staff-header-info{padding:2rem;display:flex;gap:1.5rem;align-items:flex-start}.staff-header .avatar{width:120px;height:120px;border-radius:50%;object-fit:cover;border:4px solid rgba(88,101,242,.5);flex-shrink:0}.staff-header-info h2{font-size:1.75rem;color:#f2f3f5;margin-bottom:.5rem}.points-display{font-size:1.25rem;font-weight:600;color:#5865f2;margin-bottom:.5rem}.joined-date{color:#b5bac1;font-size:.95rem}.staff-actions{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.button-edit,.button-record,.button-delete{padding:.75rem 1.5rem;border-radius:.5rem;font-weight:500;transition:all .2s ease}.button-edit{background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);color:#fff}.button-edit:hover{transform:translateY(-2px);box-shadow:0 4px 12px #3b82f64d}.button-record{background:linear-gradient(135deg,#10b981 0%,#059669 100%);color:#fff}.button-record:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.button-delete{background:linear-gradient(135deg,#ef4444 0%,#dc2626 100%);color:#fff}.button-delete:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ef44444d}.edit-staff-form,.record-form{padding:1.5rem;margin-bottom:2rem;background:rgba(88,101,242,.1);border:1px solid rgba(88,101,242,.3);border-radius:.5rem}.edit-staff-form h3,.record-form h3{margin-bottom:1rem;font-size:1.1rem;color:#f2f3f5}.edit-staff-form .form-group,.record-form .form-group{margin-bottom:1rem}.edit-staff-form label,.record-form label{display:block;margin-bottom:.5rem;font-weight:500;color:#dbdee1;font-size:.9rem}.edit-staff-form input,.edit-staff-form select,.record-form input,.record-form select,.record-form textarea{width:100%}.records-section{flex:1;display:flex;flex-direction:column}.records-section h3{margin-bottom:1rem;font-size:1.1rem;color:#f2f3f5}.records-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.75rem}@media (max-width: 1024px){.staff-sidebar{width:250px}.staff-header-info{flex-direction:column}.staff-header .avatar{width:100px;height:100px}}@media (max-width: 768px){.dashboard-container{flex-direction:column}.staff-sidebar{width:100%;max-height:200px}.staff-details{padding:1rem}.staff-header .banner{height:150px}.staff-actions{flex-direction:column}.button-edit,.button-record,.button-delete{width:100%}}.staff-profile{min-height:100vh;background:linear-gradient(135deg,#0a0e27 0%,#1a1f3a 100%);display:flex;flex-direction:column}.staff-profile.loading,.staff-profile.error{align-items:center;justify-content:center;color:#b5bac1;font-size:1.1rem}.profile-header{background:rgba(20,25,45,.9);border-bottom:1px solid rgba(88,101,242,.2);padding:1.5rem 2rem;box-shadow:0 2px 8px #0000004d}.header-top{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto}.profile-header h1{font-size:1.75rem;font-weight:700;color:#f2f3f5}.logout-button{padding:.75rem 1.5rem;background:linear-gradient(135deg,#ef4444 0%,#dc2626 100%);color:#fff;border-radius:.5rem;font-weight:500;transition:all .2s ease}.logout-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ef44444d}.profile-container{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:2rem;padding:2rem;max-width:1200px;margin:0 auto;width:100%;overflow-y:auto}.profile-card{background:rgba(20,25,45,.7);border:1px solid rgba(88,101,242,.2);border-radius:1rem;overflow:hidden;box-shadow:0 4px 16px #0003}.profile-banner-section{height:180px;overflow:hidden;background:rgba(88,101,242,.1)}.profile-banner-section img{width:100%;height:100%;object-fit:cover}.profile-banner-section .edit-input{padding:1rem;height:100%;display:flex;align-items:center}.profile-banner-section input{width:100%}.profile-info{padding:2rem;text-align:center}.profile-avatar-section{margin-bottom:1.5rem}.profile-avatar-section img{width:120px;height:120px;border-radius:50%;object-fit:cover;border:4px solid rgba(88,101,242,.5);margin:0 auto;display:block}.profile-avatar-section .edit-input{padding:0 1rem;display:flex;align-items:center;justify-content:center;margin:0 auto}.profile-avatar-section input{width:100%;max-width:300px}.profile-text h2{font-size:1.75rem;color:#f2f3f5;margin-bottom:.5rem}.profile-text .points{font-size:1.25rem;font-weight:600;color:#5865f2;margin-bottom:.5rem}.profile-text .joined{color:#b5bac1;font-size:.95rem;margin-bottom:1.5rem}.edit-button{padding:.75rem 1.5rem;background:linear-gradient(135deg,#5865f2 0%,#7289da 100%);color:#fff;border-radius:.5rem;font-weight:500;transition:all .2s ease}.edit-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #5865f24d}.edit-form{padding:1.5rem;background:rgba(88,101,242,.1);border-top:1px solid rgba(88,101,242,.2)}.edit-form h3{margin-bottom:.5rem;color:#f2f3f5}.edit-description{color:#b5bac1;font-size:.9rem;margin-bottom:1rem}.edit-form .form-buttons{display:flex;gap:.75rem}.button-save{flex:1;padding:.75rem;background:linear-gradient(135deg,#10b981 0%,#059669 100%);color:#fff;border-radius:.375rem;font-weight:500;transition:all .2s ease}.button-save:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.button-cancel{flex:1;padding:.75rem;background:transparent;border:1px solid #3a3f54;color:#b5bac1;border-radius:.375rem;font-weight:500;transition:all .2s ease}.button-cancel:hover{background:rgba(88,101,242,.1);border-color:#5865f2;color:#dbdee1}.records-section{background:rgba(20,25,45,.7);border:1px solid rgba(88,101,242,.2);border-radius:1rem;padding:2rem;display:flex;flex-direction:column}.records-section h3{margin-bottom:1.5rem;font-size:1.1rem;color:#f2f3f5}.records-list{display:flex;flex-direction:column;gap:.75rem;flex:1;overflow-y:auto}.record-item{padding:1rem;background:rgba(88,101,242,.08);border-radius:.5rem;border-left:4px solid #5865f2;display:flex;gap:1rem;align-items:flex-start}.record-promotion{border-left-color:#10b981;background:rgba(16,185,129,.08)}.record-demotion{border-left-color:#f59e0b;background:rgba(245,158,11,.08)}.record-warning{border-left-color:#ef4444;background:rgba(239,68,68,.08)}.record-strike{border-left-color:#dc2626;background:rgba(220,38,38,.08)}.record-note{border-left-color:#8b5cf6;background:rgba(139,92,246,.08)}.record-type{padding:.25rem .75rem;background:rgba(88,101,242,.2);border-radius:.375rem;font-weight:600;font-size:.75rem;color:#a5b4fc;white-space:nowrap;flex-shrink:0}.record-promotion .record-type{background:rgba(16,185,129,.2);color:#86efac}.record-demotion .record-type{background:rgba(245,158,11,.2);color:#fcd34d}.record-warning .record-type{background:rgba(239,68,68,.2);color:#fca5a5}.record-strike .record-type{background:rgba(220,38,38,.2);color:#fca5a5}.record-note .record-type{background:rgba(139,92,246,.2);color:#d8b4fe}.record-content{flex:1;min-width:0}.record-description{color:#dbdee1;margin-bottom:.25rem;word-break:break-word}.record-meta{color:#72767d;font-size:.85rem}.no-records{color:#72767d;text-align:center;padding:2rem}.error-notification{position:fixed;bottom:2rem;right:2rem;padding:1rem 1.5rem;background:rgba(239,68,68,.9);color:#fff;border-radius:.5rem;box-shadow:0 4px 12px #ef44444d;max-width:400px}@media (max-width: 1024px){.profile-container{grid-template-columns:1fr}}@media (max-width: 768px){.profile-header{padding:1rem}.header-top{flex-direction:column;gap:1rem}.profile-header h1{font-size:1.5rem}.profile-container{padding:1rem;gap:1rem}.profile-card{padding:0}.profile-banner-section{height:120px}.profile-info{padding:1.5rem}.profile-avatar-section img{width:100px;height:100px}.profile-text h2{font-size:1.5rem}}.app{width:100%;height:100%}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#0a0e27 0%,#1a1f3a 100%);color:#e0e0e0;min-height:100vh}html,body,#root{height:100%;width:100%}button{cursor:pointer;border:none;font-family:inherit;font-size:1rem;transition:all .2s ease}input,select,textarea{font-family:inherit;font-size:1rem;border:1px solid #3a3f54;padding:.75rem;border-radius:.5rem;background:rgba(20,25,45,.8);color:#e0e0e0;transition:all .2s ease}input:focus,select:focus,textarea:focus{outline:none;border-color:#5865f2;background:rgba(20,25,45,1);box-shadow:0 0 0 3px #5865f21a}input::placeholder{color:#8b8c9f}textarea{resize:vertical;min-height:100px}a{text-decoration:none;color:#5865f2}a:hover{color:#7289da}
