*{box-sizing:border-box;margin:0;padding:0}:root{--primary:#2d4270;--primary-light:#eef1f8;--primary-dark:#1e2e52;--primary-mid:#4a6499;--accent:#f9b08f;--accent-light:#fef0e8;--accent-dark:#c97840;--red:#e24b4a;--red-light:#fcebeb;--amber:#ef9f27;--amber-light:#faeeda;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-400:#9ca3af;--gray-600:#4b5563;--gray-800:#1f2937;--border:1px solid #e5e7eb;--radius:12px;--radius-sm:8px;--shadow:0 1px 3px #00000014;--shadow-md:0 4px 12px #0000001a;--sidebar-width:240px;--content-max:900px}#root,body,html{-webkit-font-smoothing:antialiased;background:#f0f2f7;color:#1f2937;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:16px;height:100%}.app-shell{display:flex;flex-direction:column;min-height:100vh}@media(max-width:767px){.app-shell{background:#f0f2f7;max-width:100%}.with-nav{padding-bottom:calc(72px + env(safe-area-inset-bottom, 0px))}.sidebar{display:none}.bottom-nav{display:flex}.page-content{padding:1rem}.main-area{flex:1 1}}@media(min-width:768px) and (max-width:1199px){.app-shell{flex-direction:row}.sidebar{display:flex;flex-shrink:0;width:240px;width:var(--sidebar-width)}.bottom-nav{display:none}.main-area{flex:1 1;overflow-y:auto}.page-content{max-width:900px;max-width:var(--content-max);padding:1.5rem}.with-nav{padding-bottom:1.5rem}.stats-grid{grid-template-columns:repeat(4,1fr)}.card-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr)}}.card-grid{display:flex;flex-direction:column;gap:12px}@media(min-width:1200px){.app-shell{flex-direction:row}.sidebar{display:flex;flex-shrink:0;width:240px;width:var(--sidebar-width)}.bottom-nav{display:none}.main-area{flex:1 1;overflow-y:auto}.page-content{margin:0 auto;max-width:900px;max-width:var(--content-max);padding:2rem}.with-nav{padding-bottom:2rem}.stats-grid{grid-template-columns:repeat(4,1fr)}.card-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr)}}.sidebar{background:#2d4270;background:var(--primary);flex-direction:column;height:100vh;min-height:100vh;overflow-y:auto;position:sticky;top:0}.sidebar-logo{border-bottom:1px solid #ffffff1a;padding:24px 20px 20px}.sidebar-logo img{height:auto;max-width:160px;object-fit:contain;width:100%}.sidebar-subtitle{color:#ffffff80;font-size:10px;letter-spacing:.1em;margin-top:6px;text-transform:uppercase}.sidebar-nav{flex:1 1;padding:16px 12px}.sidebar-item{align-items:center;background:none;border:none;border-radius:8px;border-radius:var(--radius-sm);color:#ffffffb3;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:12px;margin-bottom:4px;padding:10px 12px;position:relative;text-align:left;transition:background .15s;width:100%}.sidebar-item:hover{background:#ffffff14}.sidebar-item.active{background:#ffffff26;color:#fff}.sidebar-item svg{flex-shrink:0;height:18px;width:18px}.sidebar-badge{background:#f9b08f;background:var(--accent);border-radius:50%;height:7px;position:absolute;right:12px;top:50%;transform:translateY(-50%);width:7px}.sidebar-footer{border-top:1px solid #ffffff1a;padding:16px}.sidebar-user{align-items:center;border-radius:8px;border-radius:var(--radius-sm);color:#fffc;cursor:pointer;display:flex;font-size:13px;gap:10px;padding:8px}.sidebar-avatar{background:#ffffff26;border-radius:50%;color:#fff;font-size:12px;font-weight:600;height:32px;justify-content:center;width:32px}.mobile-header,.sidebar-avatar{align-items:center;display:flex;flex-shrink:0}.mobile-header{background:#2d4270;background:var(--primary);justify-content:space-between;padding:10px 16px;position:sticky;top:0;z-index:10}.mobile-header img{height:32px;object-fit:contain;width:auto}.mobile-header-right{align-items:center;display:flex;gap:10px}.accent-stripe{background:#f9b08f;background:var(--accent);flex-shrink:0;height:3px}.page-title{border-bottom:1px solid #e5e7eb;border-bottom:var(--border);color:#2d4270;color:var(--primary);font-size:22px;font-weight:600;margin-bottom:1.5rem;padding-bottom:1rem}@media(max-width:767px){.page-title{display:none}.mobile-header{display:flex}}@media(min-width:768px){.mobile-header{display:none}}.card{background:#fff;border:1px solid #e5e7eb;border:var(--border);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 3px #00000014;box-shadow:var(--shadow);margin-bottom:12px;padding:1rem 1.25rem}.btn{border:none;border-radius:8px;border-radius:var(--radius-sm);cursor:pointer;display:block;font-size:15px;font-weight:500;padding:12px;transition:all .15s;width:100%}.btn:active{opacity:.85;transform:scale(.99)}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background:#2d4270;background:var(--primary);color:#fff}.btn-primary:hover{background:#1e2e52;background:var(--primary-dark)}.btn-secondary{background:#f3f4f6;background:var(--gray-100);border:1px solid #e5e7eb;border:var(--border);color:#1f2937;color:var(--gray-800)}.btn-secondary:hover{background:#e5e7eb;background:var(--gray-200)}.btn-danger{background:#fcebeb;background:var(--red-light);border:1px solid #f09595;color:#a32d2d}.btn-accent{background:#f9b08f;background:var(--accent);color:#fff}.btn-sm{display:inline-block;font-size:13px;padding:6px 14px;width:auto}.field{margin-bottom:14px}.field label{color:#4b5563;color:var(--gray-600);display:block;font-size:12px;font-weight:500;margin-bottom:4px}.field input,.field select,.field textarea{appearance:none;background:#fff;border:1px solid #e5e7eb;border:var(--border);border-radius:8px;border-radius:var(--radius-sm);color:#1f2937;color:var(--gray-800);font-size:15px;padding:10px 12px;width:100%}.field input:focus,.field select:focus,.field textarea:focus{border-color:#2d4270;border-color:var(--primary);box-shadow:0 0 0 3px #2d42701a;outline:none}.field textarea{line-height:1.5;min-height:70px;resize:vertical}.badge{border-radius:20px;display:inline-block;font-size:11px;font-weight:600;padding:3px 10px}.badge-q15{background:#faece7;color:#993c1d}.badge-q30{background:#faeeda;background:var(--amber-light);color:#854f0b}.badge-q60{background:#eef1f8;background:var(--primary-light);color:#2d4270;color:var(--primary)}.badge-q180{background:#fef0e8;background:var(--accent-light);color:#c97840;color:var(--accent-dark)}.badge-late{background:#fcebeb;background:var(--red-light);color:#a32d2d}.badge-ontime{background:#eef1f8;background:var(--primary-light);color:#1e2e52;color:var(--primary-dark)}.stats-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,1fr);margin-bottom:16px}.stat-card{background:#fff;border:1px solid #e5e7eb;border:var(--border);border-radius:8px;border-radius:var(--radius-sm);box-shadow:0 1px 3px #00000014;box-shadow:var(--shadow);padding:12px;text-align:center}.stat-card .num{color:#2d4270;color:var(--primary);font-size:26px;font-weight:700}.stat-card .lbl{color:#9ca3af;color:var(--gray-400);font-size:11px;letter-spacing:.04em;margin-top:2px;text-transform:uppercase}.stat-card.danger .num{color:#e24b4a;color:var(--red)}.alert-bar{border-radius:8px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:12px;padding:10px 14px}.alert-bar.danger{background:#fcebeb;background:var(--red-light);border:1px solid #f09595;color:#a32d2d}.alert-bar.warning{background:#faeeda;background:var(--amber-light);border:1px solid #fac775;color:#854f0b}.alert-bar.success{background:#eef1f8;background:var(--primary-light);border:1px solid #b0bfe0;color:#2d4270;color:var(--primary)}.alert-bar.info{background:#fef0e8;background:var(--accent-light);border:1px solid #f9b08f;border:1px solid var(--accent);color:#c97840;color:var(--accent-dark)}.divider{border:none;border-top:1px solid #e5e7eb;border-top:var(--border);margin:12px 0}.spinner{animation:spin .7s linear infinite;border:3px solid #e5e7eb;border-top-color:#2d4270;border:3px solid var(--gray-200);border-radius:50%;border-top-color:var(--primary);height:32px;margin:2rem auto;width:32px}@keyframes spin{to{transform:rotate(1turn)}}.empty-state{font-size:14px;padding:3rem 1rem;text-align:center}.empty-state,.section-label{color:#9ca3af;color:var(--gray-400)}.section-label{font-size:11px;font-weight:600;letter-spacing:.06em;margin-bottom:8px;text-transform:uppercase}.tab-row{display:flex;gap:6px;margin-bottom:1rem}.tab{background:#fff;border:1px solid #e5e7eb;border:var(--border);border-radius:8px;border-radius:var(--radius-sm);color:#4b5563;color:var(--gray-600);cursor:pointer;flex:1 1;font-size:13px;font-weight:500;padding:9px;text-align:center}.tab.active{background:#2d4270;background:var(--primary);border-color:#2d4270;border-color:var(--primary);color:#fff}.modal-overlay{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:100}.modal{background:#fff;border-radius:12px;border-radius:var(--radius);box-shadow:0 4px 12px #0000001a;box-shadow:var(--shadow-md);max-width:440px;padding:1.5rem;width:100%}.modal h2{color:#2d4270;color:var(--primary);font-size:17px;font-weight:600;margin-bottom:12px}.bottom-nav{background:#fff;border-top:1px solid #e5e7eb;border-top:var(--border);bottom:0;left:0;padding-bottom:env(safe-area-inset-bottom,0);position:fixed;right:0;z-index:20}.nav-item{align-items:center;background:none;border:none;color:#9ca3af;color:var(--gray-400);cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-size:10px;font-weight:500;padding:10px 4px 14px}.nav-item.active{color:#2d4270;color:var(--primary)}.nav-item svg{height:22px;margin-bottom:3px;width:22px}.nav-badge{background:#f9b08f;background:var(--accent);border-radius:50%;height:6px;position:absolute;right:-2px;top:6px;width:6px}.log-entry{background:#fff;border-left:3px solid #2d4270;border-left:3px solid var(--primary);border-radius:0 8px 8px 0;border-radius:0 var(--radius-sm) var(--radius-sm) 0;box-shadow:0 1px 3px #00000014;box-shadow:var(--shadow);margin-bottom:10px;padding:10px 14px}.log-entry.late{border-left-color:#e24b4a;border-left-color:var(--red)}.log-entry .le-time{color:#9ca3af;color:var(--gray-400);font-size:11px}.log-entry .le-client{font-size:14px;font-weight:600}.log-entry .le-detail{color:#4b5563;color:var(--gray-600);font-size:13px;margin-top:2px}.session-warning{align-items:center;background:#2d4270;background:var(--primary);border-radius:8px;border-radius:var(--radius-sm);bottom:80px;box-shadow:0 4px 12px #0000001a;box-shadow:var(--shadow-md);color:#fff;display:flex;font-size:13px;justify-content:space-between;left:50%;max-width:500px;padding:12px 16px;position:fixed;transform:translateX(-50%);width:calc(100% - 28px);z-index:50}@media(min-width:768px){.session-warning{bottom:20px;left:260px;left:calc(var(--sidebar-width) + 20px);max-width:400px;transform:none;width:auto}}.session-warning button{background:#f9b08f;background:var(--accent);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;margin-left:12px;padding:5px 12px;white-space:nowrap}.login-page{background:#fff;display:flex;min-height:100vh}.login-left{align-items:center;background:#2d4270;background:var(--primary);display:none;flex-direction:column;justify-content:center;padding:3rem}.login-right{display:flex;flex:1 1;flex-direction:column;justify-content:center;margin:0 auto;max-width:440px;padding:2rem;width:100%}@media(min-width:768px){.login-left{display:flex;flex-shrink:0;width:380px}.login-page{flex-direction:row}.login-right{max-width:none;padding:3rem}}@media(min-width:1200px){.login-left{width:480px}}
/*# sourceMappingURL=main.ebab97a4.css.map*/