*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#0f172a;color:#e2e8f0;min-height:100vh}.auth-outer{min-height:100vh;background:linear-gradient(to right,#150462,#03003c);padding:24px;display:flex}.auth-split{display:grid;grid-template-columns:1fr 1fr;flex:1;min-height:calc(100vh - 48px);overflow:hidden;border-radius:24px}.auth-hero{overflow:hidden;border-radius:24px 0 0 24px;background:#0f172a}.auth-hero img{width:100%;height:100%;object-fit:cover;display:block}.auth-panel{background:#fff;border-radius:0 24px 24px 0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 40px;overflow-y:auto;color:#111827}.auth-logo-top{height:44px;margin-bottom:36px;display:block}.auth-card-light{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:32px 28px;width:100%;max-width:460px;box-shadow:0 4px 24px #00000014}.form-heading{font-size:1.35rem;font-weight:600;color:#111827;margin-bottom:24px}.form-footer{display:flex;align-items:center;justify-content:space-between;margin-top:20px}.forgot-link{background:none;border:none;color:#33f;font-size:.82rem;cursor:pointer;padding:0;text-decoration:underline}.btn-login{padding:10px 28px;background:#33f;color:#fff;border:none;border-radius:6px;font-size:.82rem;font-weight:700;letter-spacing:.06em;cursor:pointer;transition:background .15s;white-space:nowrap}.btn-login:hover{background:#22d}.btn-login:disabled{background:#a5b4fc;cursor:not-allowed}.auth-footer-link{margin-top:20px;font-size:.82rem;color:#6b7280}.auth-footer-link a{color:#33f;text-decoration:none}.auth-footer-link a:hover{text-decoration:underline}.auth-panel .field label{color:#374151;font-weight:500}.auth-panel .field input,.auth-panel .field select{background:#f3f4f6;border-color:#d1d5db;color:#111827}.auth-panel .field input:focus,.auth-panel .field select:focus{border-color:#33f;background:#fff}.auth-panel .field-error{color:#dc2626}.auth-panel .check-row{color:#374151}.auth-panel .check-row a,.auth-panel .btn-ghost{color:#33f}.auth-panel .alert-error{background:#fef2f2;border-color:#fca5a5;color:#dc2626}.auth-panel .alert-info{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.auth-panel .wizard-step{background:#e5e7eb}.auth-panel .wizard-step.done{background:#33f}.auth-panel .wizard-step.active{background:#6366f1}.auth-panel .btn-primary{background:#33f}.auth-panel .btn-primary:hover{background:#22d}.auth-panel .btn-primary:disabled{background:#a5b4fc;color:#fff}.auth-page,.auth-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px}.auth-card{background:#1e293b;border:1px solid #334155;border-radius:16px;padding:40px;width:100%;max-width:420px}.auth-logo{height:36px;display:block;margin-bottom:28px}.auth-title{font-size:1.2rem;font-weight:700;color:#f1f5f9;margin-bottom:6px}.auth-sub{font-size:.85rem;color:#64748b;margin-bottom:28px}.field{margin-bottom:18px}.field label{display:block;font-size:.8rem;font-weight:600;color:#94a3b8;margin-bottom:6px}.field input,.field select{width:100%;padding:10px 14px;background:#0f172a;border:1px solid #334155;border-radius:8px;color:#e2e8f0;font-size:.9rem;outline:none;transition:border-color .15s}.field input:focus,.field select:focus{border-color:#38bdf8}.field-error{font-size:.73rem;color:#f87171;margin-top:5px}.check-row{display:flex;align-items:flex-start;gap:10px;margin-bottom:14px;font-size:.82rem;color:#94a3b8}.check-row input{margin-top:3px;flex-shrink:0;accent-color:#38bdf8}.check-row a{color:#38bdf8}.btn-primary{width:100%;padding:11px;border:none;border-radius:8px;background:#0284c7;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s}.btn-primary:hover{background:#0369a1}.btn-primary:disabled{background:#1e3a5f;color:#475569;cursor:not-allowed}.btn-ghost{background:none;border:none;color:#38bdf8;font-size:.82rem;cursor:pointer;padding:0;text-decoration:underline}.alert{padding:10px 14px;border-radius:8px;font-size:.82rem;margin-bottom:18px}.alert-error{background:#7f1d1d33;border:1px solid #7f1d1d;color:#fca5a5}.alert-info{background:#0c4a6e33;border:1px solid #0c4a6e;color:#7dd3fc}.dashboard{display:flex;min-height:100vh}.sidebar-mock{width:220px;background:#1e293b;border-right:1px solid #334155;padding:24px 16px;flex-shrink:0}.sidebar-logo{font-size:1rem;font-weight:700;color:#38bdf8;margin-bottom:32px}.sidebar-nav{list-style:none;display:flex;flex-direction:column;gap:4px}.sidebar-nav li a{display:block;padding:8px 12px;border-radius:8px;color:#94a3b8;font-size:.85rem;text-decoration:none}.sidebar-nav li a:hover,.sidebar-nav li a.active{background:#334155;color:#f1f5f9}.main-content{flex:1;padding:32px;overflow:auto}.page-title{font-size:1.4rem;font-weight:700;color:#f1f5f9;margin-bottom:24px}.table-toolbar{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap;align-items:center}.search-input{padding:8px 12px;background:#1e293b;border:1px solid #334155;border-radius:8px;color:#e2e8f0;font-size:.85rem;outline:none;min-width:220px}.search-input:focus{border-color:#38bdf8}.filter-select{padding:8px 12px;background:#1e293b;border:1px solid #334155;border-radius:8px;color:#e2e8f0;font-size:.85rem;outline:none}.fd-table{width:100%;border-collapse:collapse;font-size:.85rem}.fd-table th{background:#1e293b;color:#94a3b8;padding:10px 14px;text-align:left;border-bottom:2px solid #334155;white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none}.fd-table th:hover{color:#e2e8f0}.fd-table td{padding:10px 14px;border-bottom:1px solid #1e293b77;color:#cbd5e1;vertical-align:middle}.fd-table tr:hover td{background:#1e293b55}.status-badge{display:inline-block;padding:2px 10px;border-radius:9999px;font-size:.72rem;font-weight:700;white-space:nowrap}.status-ACTIVE{background:#14532d;color:#86efac}.status-UPCOMING{background:#1e3a5f;color:#7dd3fc}.status-ENDED{background:#334155;color:#64748b}.status-REMOVED{background:#292524;color:#78716c}.pagination{display:flex;align-items:center;gap:12px;margin-top:16px;font-size:.82rem;color:#64748b}.pagination button{padding:6px 14px;background:#1e293b;border:1px solid #334155;border-radius:6px;color:#94a3b8;cursor:pointer;font-size:.82rem}.pagination button:hover:not(:disabled){background:#334155;color:#f1f5f9}.pagination button:disabled{opacity:.4;cursor:not-allowed}.wizard-steps{display:flex;gap:8px;margin-bottom:28px}.wizard-step{flex:1;height:4px;border-radius:2px;background:#334155}.wizard-step.done{background:#0284c7}.wizard-step.active{background:#38bdf8}.step-nav{display:flex;justify-content:space-between;margin-top:24px}
