@import url(https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap);:root{--navy:#0f1629;--blue:#2563eb;--green:#10b981;--green-pale:#d1fae5;--amber:#f59e0b;--amber-pale:#fef3c7;--red:#ef4444;--red-pale:#fee2e2;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-400:#94a3b8;--gray-600:#475569;--gray-800:#1e293b;--radius:12px;--radius-sm:8px;--shadow:0 1px 3px #00000014,0 4px 16px #0000000f}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{background:#f8fafc;background:var(--gray-50);color:#0f172a;font-family:Plus Jakarta Sans,sans-serif;line-height:1.6}.loading-screen{align-items:center;display:flex;height:100vh;justify-content:center}.spinner{animation:spin .8s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#2563eb;border:3px solid var(--gray-200);border-top-color:var(--blue);height:36px;width:36px}@keyframes spin{to{transform:rotate(1turn)}}.app-layout{display:flex;min-height:100vh}.sidebar{background:#0f1629;background:var(--navy);color:#fff;display:flex;flex-direction:column;height:100vh;left:0;overflow-y:auto;position:fixed;top:0;width:240px;z-index:100}.sidebar-logo{border-bottom:1px solid #ffffff14;padding:24px 20px}.logo-mark{gap:10px}.logo-icon,.logo-mark{align-items:center;display:flex}.logo-icon{background:#2563eb;background:var(--blue);border-radius:10px;font-size:18px;height:36px;justify-content:center;width:36px}.logo-text{color:#fff;font-size:18px;font-weight:800}.logo-sub{color:#ffffff73;font-size:11px;margin-top:2px}.sidebar-nav{flex:1 1;padding:16px 12px}.nav-section{margin-bottom:24px}.nav-section-label{color:#ffffff4d;font-size:10px;font-weight:700;letter-spacing:.08em;margin-bottom:8px;padding:0 8px;text-transform:uppercase}.nav-item{align-items:center;background:none;border:none;border-radius:8px;border-radius:var(--radius-sm);color:#ffffffa6;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:10px;padding:10px 12px;text-align:left;transition:all .15s ease;width:100%}.nav-item:hover{background:#ffffff14;color:#fff}.nav-item.active{background:#2563eb;background:var(--blue);color:#fff}.nav-icon{font-size:16px;text-align:center;width:20px}.sidebar-footer{border-top:1px solid #ffffff14;padding:16px 12px}.user-card{background:#ffffff0f;border-radius:8px;border-radius:var(--radius-sm);gap:10px;padding:10px}.avatar,.user-card{align-items:center;display:flex}.avatar{background:#2563eb;background:var(--blue);border-radius:50%;color:#fff;flex-shrink:0;font-size:14px;font-weight:700;height:34px;justify-content:center;width:34px}.user-info{flex:1 1;min-width:0}.user-name{color:#fff;font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role{color:#fff6;font-size:11px}.logout-btn{background:none;border:none;border-radius:4px;color:#fff6;cursor:pointer;font-size:16px;padding:4px;transition:color .15s}.logout-btn:hover{color:#ef4444;color:var(--red)}.main-content{flex:1 1;margin-left:240px;min-height:100vh}.page-header{background:#fff;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--gray-200);padding:20px 32px}.page-title{color:#0f1629;color:var(--navy);font-size:22px;font-weight:800}.page-subtitle{color:#475569;color:var(--gray-600);font-size:14px;margin-top:2px}.page-body{padding:28px 32px}.card{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 3px #00000014,0 4px 16px #0000000f;box-shadow:var(--shadow);padding:24px}.card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.card-title{color:#0f1629;color:var(--navy);font-size:16px;font-weight:700}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:24px}.stat-card{align-items:flex-start;background:#fff;border:1px solid #e2e8f0;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);display:flex;gap:14px;padding:20px}.stat-icon{align-items:center;border-radius:10px;display:flex;flex-shrink:0;font-size:20px;height:44px;justify-content:center;width:44px}.stat-icon.blue{background:#dbeafe}.stat-icon.green{background:#d1fae5}.stat-icon.amber{background:#fef3c7}.stat-icon.purple{background:#ede9fe}.stat-label{color:#475569;color:var(--gray-600);font-size:12px;font-weight:500}.stat-value{color:#0f1629;color:var(--navy);font-size:24px;font-weight:800;margin-top:4px}.stat-change{color:#10b981;color:var(--green);font-size:12px;font-weight:600;margin-top:2px}.form-group{margin-bottom:16px}.form-label{color:#475569;color:var(--gray-600);display:block;font-size:13px;font-weight:600;margin-bottom:6px}.form-input,.form-select{background:#fff;border:1.5px solid #e2e8f0;border:1.5px solid var(--gray-200);border-radius:8px;border-radius:var(--radius-sm);color:#0f172a;font-family:inherit;font-size:14px;outline:none;padding:10px 14px;transition:border-color .15s;width:100%}.form-input:focus,.form-select:focus{border-color:#2563eb;border-color:var(--blue);box-shadow:0 0 0 3px #2563eb1a}.btn{align-items:center;border:none;border-radius:8px;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;font-family:inherit;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:10px 20px;transition:all .15s ease;white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background:#2563eb;background:var(--blue);color:#fff}.btn-primary:hover:not(:disabled){background:#1d4ed8}.btn-success{background:#10b981;background:var(--green);color:#fff}.btn-success:hover:not(:disabled){background:#059669}.btn-danger{background:#ef4444;background:var(--red);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-ghost{background:#f1f5f9;background:var(--gray-100);color:#1e293b;color:var(--gray-800)}.btn-ghost:hover:not(:disabled){background:#e2e8f0;background:var(--gray-200)}.btn-lg{font-size:15px;padding:13px 28px}.btn-full,table{width:100%}table{border-collapse:collapse;font-size:14px}th{background:#f8fafc;background:var(--gray-50);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--gray-200);color:#475569;color:var(--gray-600);font-size:11px;font-weight:700;letter-spacing:.06em;padding:11px 14px;text-align:left;text-transform:uppercase}td{border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--gray-100);padding:13px 14px;vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:#f8fafc;background:var(--gray-50)}.badge{align-items:center;border-radius:100px;display:inline-flex;font-size:12px;font-weight:600;padding:3px 10px}.badge-green{background:#d1fae5;background:var(--green-pale);color:#065f46}.badge-amber{background:#fef3c7;background:var(--amber-pale);color:#92400e}.badge-red{background:#fee2e2;background:var(--red-pale);color:#991b1b}.badge-blue{background:#dbeafe;color:#1e40af}.badge-gray{background:#f1f5f9;background:var(--gray-100);color:#475569;color:var(--gray-600)}.login-page{background:linear-gradient(135deg,#0f1629,#1e3a8a);background:linear-gradient(135deg,var(--navy) 0,#1e3a8a 100%);display:flex;min-height:100vh}.login-left{align-items:center;display:flex;flex:1 1;justify-content:center;padding:40px}.login-card{background:#fff;border-radius:20px;box-shadow:0 1px 3px #00000014,0 4px 16px #0000000f;box-shadow:var(--shadow);max-width:420px;padding:44px;width:100%}.login-brand{color:#0f1629;color:var(--navy);font-size:26px;font-weight:800}.login-brand span{color:#2563eb;color:var(--blue)}.login-tagline{color:#475569;color:var(--gray-600);font-size:13px;margin-bottom:32px;margin-top:4px}.login-title{color:#0f1629;color:var(--navy);font-size:22px;font-weight:800;margin-bottom:6px}.login-sub{color:#475569;color:var(--gray-600);font-size:14px;margin-bottom:28px}.login-right{align-items:center;color:#fff;display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:60px}.login-hero-title{font-size:42px;font-weight:800;line-height:1.2;margin-bottom:20px}.login-hero-title span{color:#06b6d4}.login-hero-desc{color:#ffffffb3;font-size:16px;line-height:1.7;max-width:440px}.feature-list{display:flex;flex-direction:column;gap:16px;margin-top:36px}.feature-item{align-items:center;display:flex;gap:12px}.feature-icon{font-size:24px}.feature-text{color:#ffffffd9;font-size:15px}.error-msg{background:#fee2e2;background:var(--red-pale);border-radius:8px;border-radius:var(--radius-sm);color:#991b1b;font-size:13px;margin-bottom:16px;padding:10px 14px}.events-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.event-card{background:#fff;border:1.5px solid #e2e8f0;border:1.5px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);cursor:pointer;padding:20px;transition:all .15s ease}.event-card:hover{box-shadow:0 0 0 3px #2563eb14}.event-card.selected,.event-card:hover{border-color:#2563eb;border-color:var(--blue)}.event-card.selected{background:#eff6ff}.event-name{color:#0f1629;color:var(--navy);font-size:16px;font-weight:700;margin-bottom:8px}.event-meta{align-items:center;color:#475569;color:var(--gray-600);display:flex;font-size:13px;gap:6px;margin-bottom:4px}.event-price{color:#2563eb;color:var(--blue);font-size:22px;font-weight:800;margin-top:12px}.stock-bar{background:#e2e8f0;background:var(--gray-200);border-radius:100px;height:4px;margin-top:12px;overflow:hidden}.stock-fill{background:#10b981;background:var(--green);border-radius:100px;height:100%}.sale-success{color:#10b981;color:var(--green);font-size:18px;font-weight:800;margin-bottom:8px}.sale-ref{background:#f1f5f9;background:var(--gray-100);border-radius:6px;display:inline-block;font-family:monospace;font-size:13px;margin-bottom:16px;padding:6px 12px}.sale-ref,.ticket-details{color:#475569;color:var(--gray-600)}.ticket-details{font-size:14px;line-height:1.8;text-align:left}.ticket-details strong{color:#0f1629;color:var(--navy)}.scanner-container{margin:0 auto;max-width:480px}.scanner-box{align-items:center;aspect-ratio:1;background:#0f1629;background:var(--navy);border:2px solid #e2e8f0;border:2px solid var(--gray-200);border-radius:12px;border-radius:var(--radius);display:flex;justify-content:center;overflow:hidden;position:relative;width:100%}.scan-result{border:2px solid;border-radius:12px;border-radius:var(--radius);margin-top:20px;padding:24px;text-align:center}.scan-result.valid{background:#d1fae5;background:var(--green-pale);border-color:#10b981;border-color:var(--green)}.scan-result.invalid{background:#fee2e2;background:var(--red-pale);border-color:#ef4444;border-color:var(--red)}.scan-result.already_used{background:#fef3c7;background:var(--amber-pale);border-color:#f59e0b;border-color:var(--amber)}.scan-icon{font-size:48px;margin-bottom:12px}.scan-title{font-size:20px;font-weight:800;margin-bottom:8px}.scan-title.valid{color:#10b981;color:var(--green)}.scan-title.invalid{color:#ef4444;color:var(--red)}.scan-title.already_used{color:#f59e0b;color:var(--amber)}.scan-info{color:#475569;color:var(--gray-600);font-size:14px;line-height:1.7}.scan-info strong{color:#0f1629;color:var(--navy)}.manual-input-row{display:flex;gap:8px;margin-top:16px}.manual-input-row .form-input{flex:1 1}@media (max-width:768px){.stats-grid{grid-template-columns:repeat(2,1fr)}.login-right{display:none}.page-body{padding:20px 16px}}
/*# sourceMappingURL=main.9d5fa2e1.css.map*/