.layout{background:var(--surface-1);display:flex;min-height:100vh}.sidebar{background:var(--surface-0);border-right:1px solid var(--border-1);display:flex;flex-direction:column;flex-shrink:0;height:100vh;overflow:hidden;position:sticky;top:0;transition:width .25s ease;width:240px}.layout.collapsed .sidebar{width:68px}.sidebar-header{border-bottom:1px solid var(--border-1);justify-content:space-between;min-height:70px;padding:20px 16px}.sidebar-header,.sidebar-logo{align-items:center;display:flex}.sidebar-logo{gap:10px;overflow:hidden}.logo-icon{align-items:center;border:1px solid var(--border-1);border-radius:8px;display:flex;flex-shrink:0;font-size:11px;height:32px;justify-content:center;letter-spacing:.8px;width:32px}.logo-icon,.logo-text{color:var(--text-1);font-weight:700}.logo-text{font-family:var(--font-display);font-size:17px;letter-spacing:.3px;white-space:nowrap}.collapse-btn{align-items:center;background:#0000;border:1px solid var(--border-1);border-radius:4px;color:var(--text-2);display:flex;flex-shrink:0;font-size:16px;height:26px;justify-content:center;transition:all .15s;width:26px}.collapse-btn:hover{border-color:var(--border-2);color:var(--text-1)}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:4px;overflow-y:auto;padding:12px 10px}.nav-item{align-items:center;border-radius:6px;color:var(--text-2);display:flex;font-size:14px;font-weight:500;gap:12px;overflow:hidden;padding:11px 12px;text-decoration:none;transition:all .15s;white-space:nowrap}.nav-item:hover{background:var(--surface-2);color:var(--text-1)}.nav-item.active{background:var(--surface-3);border:1px solid var(--border-2);color:var(--text-1)}.nav-icon{align-items:center;border:1px solid var(--border-1);border-radius:999px;display:inline-flex;flex-shrink:0;font-size:10px;height:20px;justify-content:center;letter-spacing:.6px;text-align:center;width:26px}.nav-label{font-family:var(--font-display);font-weight:600}.sidebar-footer{align-items:center;border-top:1px solid var(--border-1);display:flex;gap:10px;padding:16px 10px}.faculty-avatar{align-items:center;background:var(--surface-2);border:1px solid var(--border-1);border-radius:8px;color:var(--text-1);display:flex;flex-shrink:0;font-family:var(--font-display);font-size:12px;font-weight:700;height:36px;justify-content:center;width:36px}.faculty-info{flex:1 1;overflow:hidden}.faculty-name{color:var(--text-1);font-size:13px;font-weight:600}.faculty-dept,.faculty-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.faculty-dept{color:var(--text-3);font-size:11px}.logout-btn{align-items:center;background:#0000;border:1px solid var(--border-1);border-radius:6px;color:var(--text-2);display:flex;flex-shrink:0;font-size:12px;font-weight:600;height:30px;justify-content:center;transition:all .15s;width:38px}.logout-btn:hover{border-color:var(--border-2);color:var(--text-1)}.main-content{background:var(--surface-1);flex:1 1;overflow-y:auto}.page-header{align-items:center;background:var(--surface-0);border-bottom:1px solid var(--border-1);display:flex;justify-content:space-between;padding:24px 32px}.page-title{color:var(--text-1);font-family:var(--font-display);font-size:24px;font-weight:700}.page-subtitle{color:var(--text-3);font-size:13px;margin-top:2px}.page-body{padding:28px 32px}.card{background:var(--surface-0);border:1px solid var(--border-1);border-radius:12px;box-shadow:var(--shadow-sm);padding:24px}.btn{align-items:center;border:1px solid #0000;border-radius:6px;cursor:pointer;display:inline-flex;font-family:var(--font-body);font-size:13px;font-weight:600;gap:6px;padding:9px 16px;text-decoration:none;transition:all .15s}.btn-navy{background:var(--text-1);border-color:var(--text-1);color:var(--surface-0)}.btn-navy:hover{opacity:.9}.btn-red{background:var(--surface-0);border-color:var(--border-2);color:var(--text-1)}.btn-red:hover{background:var(--surface-2)}.btn-ghost{background:#0000;border:1px solid var(--border-1);color:var(--text-2)}.btn-ghost:hover{background:var(--surface-2);border-color:var(--border-2);color:var(--text-1)}.btn-sm{font-size:12px;padding:6px 12px}.btn-lg{font-size:15px;padding:12px 24px}.field{display:flex;flex-direction:column;gap:6px}.field label{color:var(--text-3);font-size:12px;font-weight:600;letter-spacing:.8px;text-transform:uppercase}.field input,.field select,.field textarea{background:var(--surface-0);border:1px solid var(--border-1);border-radius:6px;color:var(--text-1);font-size:14px;outline:none;padding:10px 14px;transition:border-color .15s,background .15s}.field input:focus,.field select:focus,.field textarea:focus{background:var(--surface-2);border-color:var(--border-2)}.field textarea{min-height:80px;resize:vertical}.grid-2{grid-gap:16px;grid-template-columns:1fr 1fr}.grid-2,.grid-3{display:grid;gap:16px}.grid-3{grid-gap:16px;grid-template-columns:1fr 1fr 1fr}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr)}.stat-card{background:var(--surface-0);border:1px solid var(--border-1);border-radius:12px;box-shadow:var(--shadow-sm);padding:20px 24px}.stat-value{color:var(--text-1);font-family:var(--font-display);font-size:30px;font-weight:700}.stat-label{font-size:12px;letter-spacing:.8px;margin-top:4px}.stat-icon,.stat-label{color:var(--text-3);text-transform:uppercase}.stat-icon{font-size:11px;letter-spacing:1.2px;margin-bottom:8px}.modal-overlay{align-items:center;animation:fadeIn .2s ease;background:#0f172a59;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:100}.modal{animation:fadeIn .25s ease;background:var(--surface-0);border:1px solid var(--border-1);border-radius:14px;box-shadow:var(--shadow-lg);max-height:90vh;max-width:580px;overflow-y:auto;width:100%}.modal-header{align-items:center;display:flex;justify-content:space-between;padding:24px 28px 0}.modal-title{color:var(--text-1);font-family:var(--font-display);font-size:20px;font-weight:700}.modal-close{background:#0000;border:1px solid var(--border-1);border-radius:6px;color:var(--text-2);cursor:pointer;font-size:14px;height:32px;width:32px}.modal-close:hover{border-color:var(--border-2);color:var(--text-1)}.modal-body{display:flex;flex-direction:column;gap:16px;padding:20px 28px 28px}.modal-footer{display:flex;gap:10px;justify-content:flex-end;padding:0 28px 28px}.table-wrap{border:1px solid var(--gray-100);border-radius:var(--radius-lg);overflow-x:auto}table{border-collapse:collapse;width:100%}thead{background:var(--gray-50)}th{color:var(--text-3);font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:.8px;padding:12px 16px;text-align:left;text-transform:uppercase}td,th{border-bottom:1px solid var(--border-1)}td{color:var(--text-2);font-size:13px;padding:14px 16px}tr:last-child td{border-bottom:none}tr:hover td{background:var(--surface-2)}.empty-state{padding:60px 20px;text-align:center}.empty-icon{color:var(--text-3);font-size:11px;letter-spacing:1.2px;margin-bottom:12px;opacity:.6;text-transform:uppercase}.empty-title{color:var(--text-2);font-family:var(--font-display);font-size:18px;margin-bottom:6px}.empty-text{color:var(--text-3);font-size:13px}.page-loading{align-items:center;display:flex;height:300px;justify-content:center}.page-loading .spinner{border-color:var(--border-1);border-top-color:var(--text-2);height:36px;width:36px}@media (max-width:900px){.layout{flex-direction:column}.sidebar{height:auto;position:static}.layout.collapsed .sidebar,.sidebar{width:100%}.sidebar-nav{flex-direction:row;flex-wrap:wrap}.nav-item{flex:1 1 45%}}.auth-page{background:var(--surface-1);display:flex;min-height:100vh}.auth-left{color:var(--text-1);display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:48px}.auth-brand{margin-bottom:48px}.brand-name{color:var(--text-1);font-family:var(--font-display);font-size:40px;font-weight:700;line-height:1}.brand-tagline{color:var(--text-3);font-size:15px;margin-top:8px}.auth-features{display:flex;flex-direction:column;gap:20px}.feature-item{align-items:flex-start;background:var(--surface-0);border:1px solid var(--border-1);border-radius:10px;display:flex;padding:16px 20px}.feature-item strong{color:var(--text-1);display:block;font-family:var(--font-display);font-size:15px;margin-bottom:2px}.feature-item p{color:var(--text-3);font-size:13px;margin:0}.auth-right{align-items:center;background:var(--surface-0);border-left:1px solid var(--border-1);display:flex;justify-content:center;padding:40px;width:500px}.auth-card{width:100%}.auth-tabs{background:var(--surface-2);border-radius:10px;display:flex;margin-bottom:28px;padding:4px}.auth-tab{background:#0000;border:none;border-radius:10px;color:var(--text-3);flex:1 1;font-family:var(--font-display);font-size:14px;font-weight:600;padding:10px;transition:all .2s}.auth-tab.active{background:var(--surface-0);border:1px solid var(--border-1);color:var(--text-1)}.auth-form{display:flex;flex-direction:column;gap:16px}.form-row{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{color:var(--text-3);font-size:12px;font-weight:600;letter-spacing:.8px;text-transform:uppercase}.form-group input,.form-group select{background:var(--surface-0);border:1px solid var(--border-1);border-radius:6px;color:var(--text-1);font-size:14px;outline:none;padding:11px 14px;transition:border-color .2s,background .2s}.form-group input::placeholder{color:var(--text-3)}.form-group input:focus,.form-group select:focus{background:var(--surface-2);border-color:var(--border-2)}.form-group select option{background:var(--surface-0);color:var(--text-1)}.btn-primary{align-items:center;background:var(--text-1);border:1px solid var(--text-1);border-radius:6px;color:var(--surface-0);display:flex;font-family:var(--font-display);font-size:15px;font-weight:600;gap:8px;justify-content:center;letter-spacing:.3px;margin-top:4px;padding:14px;transition:all .2s}.btn-primary:hover:not(:disabled){opacity:.9}.btn-primary:disabled{cursor:not-allowed;opacity:.7}.auth-hint{color:var(--text-3);font-size:13px;text-align:center}.auth-hint button{background:none;border:none;color:var(--text-2);cursor:pointer;font-size:13px;text-decoration:underline}@media (max-width:900px){.auth-page{flex-direction:column}.auth-left,.auth-right{padding:28px}.auth-right{border-left:none;border-top:1px solid var(--border-1);width:100%}.form-row{grid-template-columns:1fr}}.gate-left,.gate-page{display:flex;min-height:100vh}.gate-left{align-items:center;background:#1d2939;flex:1 1;flex-direction:column;justify-content:center;padding:40px;position:relative}.gate-header{margin-bottom:36px;text-align:center}.gate-logo{align-items:center;border:1px solid #ffffff4d;border-radius:999px;color:#ffffffe6;display:inline-flex;font-size:12px;height:32px;justify-content:center;letter-spacing:1px;margin-bottom:12px;text-transform:uppercase;width:72px}.gate-title{color:#fff;font-family:var(--font-display);font-size:32px;font-weight:800;margin-bottom:6px}.gate-subtitle{color:#ffffff80;font-size:14px}.scan-area{align-items:center;background:#ffffff0a;border:2px solid #ffffff1a;border-radius:12px;display:flex;justify-content:center;margin-bottom:24px;max-width:380px;min-height:260px;overflow:hidden;transition:border-color .3s;width:100%}.scan-area.scanning{border-color:#e6394699}.scan-animation,.scan-idle{align-items:center;display:flex;flex-direction:column;padding:30px}.scan-frame{height:140px;position:relative;width:140px}.scan-line{animation:scanLine 1.2s ease-in-out infinite alternate;background:var(--red);box-shadow:0 0 8px var(--red);height:2px;left:8px;position:absolute;right:8px}.scan-corner{border-color:#fff;border-style:solid;height:20px;position:absolute;width:20px}.scan-corner.tl{border-width:3px 0 0 3px;left:0;top:0}.scan-corner.tr{border-width:3px 3px 0 0;right:0;top:0}.scan-corner.bl{border-width:0 0 3px 3px;bottom:0;left:0}.scan-corner.br{border-width:0 3px 3px 0;bottom:0;right:0}.scan-result{animation:successPop .4s ease forwards;border:2px solid;border-radius:16px;flex-direction:column;padding:24px;text-align:center;width:100%}.result-icon,.scan-result{align-items:center;display:flex}.result-icon{border:2px solid;border-radius:999px;font-size:15px;font-weight:700;height:54px;justify-content:center;letter-spacing:.8px;margin-bottom:8px;width:54px}.result-status{font-family:var(--font-display);font-size:20px;font-weight:800;margin-bottom:4px}.result-subtitle{color:var(--gray-500);font-size:13px;margin-bottom:14px}.result-pass-info{background:var(--gray-50);border-radius:10px;margin-bottom:14px;padding:14px;text-align:left;width:100%}.pass-info-name{color:var(--navy);font-family:var(--font-display);font-size:16px;font-weight:800;margin-bottom:3px}.pass-info-detail{color:var(--gray-600);font-size:13px;margin-bottom:6px}.pass-info-event,.pass-info-host{color:var(--gray-500);font-size:12px}.pass-info-host{border-top:1px solid var(--gray-200);margin-top:6px;padding-top:6px}.btn-verify-again{background:#0f172a;border:1px solid #fff3;border-radius:6px;color:#fff;cursor:pointer;font-family:var(--font-display);font-size:13px;font-weight:700;padding:10px 24px;transition:all .15s}.btn-verify-again:hover{background:var(--navy-mid)}.code-input-section{max-width:380px;width:100%}.code-input{background:#ffffff1a;border:2px solid #ffffff26;border-radius:var(--radius-sm);color:#fff;flex:1 1;font-family:Courier New,monospace;font-size:18px;font-weight:700;letter-spacing:3px;outline:none;padding:14px 18px;transition:border-color .2s;width:100%}.code-input::placeholder{color:#ffffff40;font-family:var(--font-body);font-size:14px;font-weight:400;letter-spacing:1px}.code-input:focus{border-color:#ffffff80}.verify-btn{align-items:center;background:#0f172a;border:1px solid #ffffff40;border-radius:6px;color:#fff;display:flex;flex-shrink:0;font-size:13px;font-weight:700;height:54px;justify-content:center;letter-spacing:.5px;transition:all .15s;width:54px}.verify-btn:hover:not(:disabled){background:#101828}.verify-btn:disabled{cursor:not-allowed;opacity:.5}.gate-right{background:var(--surface-0);border-left:1px solid var(--border-1);display:flex;flex-direction:column;overflow-y:auto;width:360px}.history-list{display:flex;flex:1 1;flex-direction:column;gap:10px;padding:0 16px}.history-item{background:var(--gray-50);border-left:4px solid;border-radius:var(--radius-sm);padding:12px 14px}@media (max-width:768px){.gate-page{flex-direction:column}.gate-right{width:100%}}*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--surface-0:#fff;--surface-1:#f5f6f8;--surface-2:#eef0f3;--surface-3:#e7eaee;--text-1:#101828;--text-2:#344054;--text-3:#667085;--border-1:#d0d5dd;--border-2:#98a2b3;--navy:#101828;--navy-mid:#344054;--red:#101828;--red-dark:#000;--white:#fff;--gray-50:#f9fafb;--gray-100:#f2f4f7;--gray-200:#eaecf0;--gray-300:#d0d5dd;--gray-400:#98a2b3;--gray-500:#667085;--gray-600:#475467;--gray-700:#344054;--gray-800:#1d2939;--gray-900:#101828;--green:#10b981;--green-light:#d1fae5;--amber:#f59e0b;--amber-light:#fef3c7;--font-display:"Syne",sans-serif;--font-body:"DM Sans",sans-serif;--shadow-sm:0 1px 2px #1018280f;--shadow:0 4px 12px #10182814;--shadow-lg:0 12px 30px #1018281f;--shadow-xl:0 24px 56px #1018282e;--radius-sm:6px;--radius:12px;--radius-lg:18px;--radius-xl:24px}html{font-size:15px}body{-webkit-font-smoothing:antialiased;background:#f5f6f8;background:var(--surface-1);color:#344054;color:var(--text-2);font-family:DM Sans,sans-serif;font-family:var(--font-body);line-height:1.6}h1,h2,h3,h4,h5{font-family:Syne,sans-serif;font-family:var(--font-display);line-height:1.2}input,select,textarea{font-size:14px}button,input,select,textarea{font-family:DM Sans,sans-serif;font-family:var(--font-body)}button{cursor:pointer}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#d0d5dd;background:var(--gray-300);border-radius:3px}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translateX(-12px)}to{opacity:1;transform:translateX(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{to{transform:rotate(1turn)}}@keyframes scanLine{0%{top:0}to{top:100%}}@keyframes successPop{0%{opacity:0;transform:scale(.8)}60%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}@keyframes shake{0%,to{transform:translateX(0)}20%,60%{transform:translateX(-8px)}40%,80%{transform:translateX(8px)}}.fade-in{animation:fadeIn .3s ease forwards}.slide-in{animation:slideIn .3s ease forwards}.spinner{animation:spin .7s linear infinite;border:2px solid #d0d5dd;border-top-color:#344054;border:2px solid var(--border-1);border-radius:50%;border-top-color:var(--text-2);display:inline-block;height:20px;width:20px}.badge{align-items:center;border:1px solid #0000;border-radius:999px;display:inline-flex;font-size:11px;font-weight:600;gap:4px;letter-spacing:.8px;padding:3px 10px;text-transform:uppercase}.badge-active{background:#ecfdf3;border-color:#a6f4c5;color:#027a48}.badge-used{background:#f2f4f7;border-color:#d0d5dd;color:#475467}.badge-expired{background:#fffaeb;border-color:#fedf89;color:#b54708}.badge-revoked{background:#fef3f2;border-color:#fecdca;color:#b42318}.badge-upcoming{background:#f2f4f7;border-color:#d0d5dd;color:#475467}.badge-ongoing{background:#ecfdf3;border-color:#a6f4c5;color:#027a48}.badge-completed{background:#f2f4f7;border-color:#d0d5dd;color:#475467}.badge-cancelled{background:#fef3f2;border-color:#fecdca;color:#b42318}
/*# sourceMappingURL=main.65ab19a7.css.map*/