@import url(https://fonts.googleapis.com/css2?family=Sora:wght@300;400;500;600;700&family=DM+Sans:wght@400;500&display=swap);*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--brand:#1a6b3c;--brand-light:#e8f5ee;--brand-dark:#134d2c;--accent:#f59e0b;--accent-light:#fef3c7;--danger:#dc2626;--danger-light:#fee2e2;--info:#2563eb;--info-light:#dbeafe;--bg:#f5f4f0;--surface:#fff;--surface2:#fafaf8;--border:#e8e6e0;--border-dark:#d1cec6;--text:#1a1916;--text-2:#6b6860;--text-3:#a09d97;--radius:12px;--radius-sm:8px;--shadow:0 1px 3px #00000014,0 1px 2px #0000000a;--shadow-md:0 4px 16px #0000001a;--sidebar-w:240px;--font-display:"Sora",sans-serif;--font-body:"DM Sans",sans-serif}#root,body,html{height:100%}body{-webkit-font-smoothing:antialiased;background:#f5f4f0;background:var(--bg);color:#1a1916;color:var(--text);font-family:DM Sans,sans-serif;font-family:var(--font-body);font-size:15px;line-height:1.6}h1,h2,h3,h4{font-family:Sora,sans-serif;font-family:var(--font-display);font-weight:600;line-height:1.3}button{border:none;cursor:pointer;transition:all .15s ease}button,input,select,textarea{font-family:DM Sans,sans-serif;font-family:var(--font-body);outline:none}input,select,textarea{background:#fff;background:var(--surface);border:1.5px solid #e8e6e0;border:1.5px solid var(--border);border-radius:8px;border-radius:var(--radius-sm);color:#1a1916;color:var(--text);font-size:15px;padding:10px 14px;transition:border-color .15s;width:100%}input:focus,select:focus,textarea:focus{border-color:#1a6b3c;border-color:var(--brand)}a{color:inherit;text-decoration:none}.app-shell{display:flex;height:100vh;overflow:hidden}@media (max-width:768px){.app-shell{height:100%;min-height:100vh;overflow:visible}.main-content{-webkit-overflow-scrolling:touch;height:calc(100vh - 60px);overflow-y:auto}}.sidebar{background:#134d2c;background:var(--brand-dark);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;width:240px;width:var(--sidebar-w)}.sidebar-logo{border-bottom:1px solid #ffffff14;padding:24px 20px 16px}.sidebar-logo h1{color:#fff;font-size:18px;letter-spacing:-.3px}.sidebar-logo span{color:#ffffff73;display:block;font-size:11px;font-weight:400;margin-top:2px}.sidebar-nav{flex:1 1;padding:12px 10px}.nav-section{color:#ffffff4d;font-size:10px;font-weight:600;letter-spacing:.08em;padding:12px 10px 6px;text-transform:uppercase}.nav-item{align-items:center;border-radius:8px;border-radius:var(--radius-sm);color:#ffffffa6;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:10px;margin-bottom:2px;padding:10px 12px;transition:all .15s}.nav-item:hover{background:#ffffff14;color:#fff}.nav-item.active{background:#1a6b3c;background:var(--brand);color:#fff}.nav-item .icon{font-size:16px;text-align:center;width:20px}.sidebar-footer{border-top:1px solid #ffffff14;color:#fff6;font-size:13px;padding:16px}.sidebar-footer strong{color:#ffffffbf;display:block}.main-content{display:flex;flex:1 1;flex-direction:column;overflow-y:auto}.page-header{align-items:center;background:#fff;background:var(--surface);border-bottom:1px solid #e8e6e0;border-bottom:1px solid var(--border);display:flex;flex-shrink:0;justify-content:space-between;padding:20px 32px}.page-header h2{color:#1a1916;color:var(--text);font-size:20px}.page-header p{color:#6b6860;color:var(--text-2);font-size:13px;margin-top:2px}.page-body{flex:1 1;padding:28px 32px}.card{background:#fff;background:var(--surface);border:1px solid #e8e6e0;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 3px #00000014,0 1px 2px #0000000a;box-shadow:var(--shadow)}.card-header{align-items:center;border-bottom:1px solid #e8e6e0;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:18px 20px 14px}.card-header h3{color:#1a1916;color:var(--text);font-size:15px}.card-body{padding:20px}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:28px}.stat-card{background:#fff;background:var(--surface);border:1px solid #e8e6e0;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 3px #00000014,0 1px 2px #0000000a;box-shadow:var(--shadow);padding:20px}.stat-card .label{color:#6b6860;color:var(--text-2);font-size:12px;font-weight:600;letter-spacing:.05em;margin-bottom:8px;text-transform:uppercase}.stat-card .value{color:#1a1916;color:var(--text);font-family:Sora,sans-serif;font-family:var(--font-display);font-size:28px;font-weight:700;line-height:1}.stat-card .sub{color:#a09d97;color:var(--text-3);font-size:12px;margin-top:6px}.stat-card.green{border-left:3px solid #1a6b3c;border-left:3px solid var(--brand)}.stat-card.amber{border-left:3px solid #f59e0b;border-left:3px solid var(--accent)}.stat-card.red{border-left:3px solid #dc2626;border-left:3px solid var(--danger)}.stat-card.blue{border-left:3px solid #2563eb;border-left:3px solid var(--info)}.btn{align-items:center;border-radius:8px;border-radius:var(--radius-sm);display:inline-flex;font-size:14px;font-weight:500;gap:6px;padding:9px 18px}.btn-primary{background:#1a6b3c;background:var(--brand);color:#fff}.btn-primary:hover{background:#134d2c;background:var(--brand-dark)}.btn-secondary{background:#fff;background:var(--surface);border:1.5px solid #e8e6e0;border:1.5px solid var(--border);color:#1a1916;color:var(--text)}.btn-secondary:hover{border-color:#1a6b3c;border-color:var(--brand);color:#1a6b3c;color:var(--brand)}.btn-danger{background:#fee2e2;background:var(--danger-light);color:#dc2626;color:var(--danger)}.btn-sm{font-size:13px;padding:6px 12px}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}thead th{background:#fafaf8;background:var(--surface2);border-bottom:1.5px solid #e8e6e0;border-bottom:1.5px solid var(--border);color:#6b6860;color:var(--text-2);font-size:12px;font-weight:600;letter-spacing:.05em;padding:10px 16px;text-align:left;text-transform:uppercase}tbody td{border-bottom:1px solid #e8e6e0;border-bottom:1px solid var(--border);color:#1a1916;color:var(--text);font-size:14px;padding:13px 16px}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:#fafaf8;background:var(--surface2)}.badge{align-items:center;border-radius:20px;display:inline-flex;font-size:12px;font-weight:600;padding:3px 10px}.badge-green{background:#e8f5ee;background:var(--brand-light);color:#134d2c;color:var(--brand-dark)}.badge-amber{background:#fef3c7;background:var(--accent-light);color:#92400e}.badge-red{background:#fee2e2;background:var(--danger-light);color:#dc2626;color:var(--danger)}.badge-gray{background:#f5f4f0;background:var(--bg);border:1px solid #e8e6e0;border:1px solid var(--border);color:#6b6860;color:var(--text-2)}.form-group{margin-bottom:16px}.form-group label{color:#6b6860;color:var(--text-2);display:block;font-size:13px;font-weight:500;margin-bottom:6px}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.modal-overlay{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:100}.modal{animation:slideUp .2s ease;background:#fff;background:var(--surface);border-radius:12px;border-radius:var(--radius);box-shadow:0 4px 16px #0000001a;box-shadow:var(--shadow-md);max-width:480px;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e8e6e0;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:20px 24px 16px}.modal-header h3{font-size:17px}.modal-body{padding:24px}.modal-footer{border-top:1px solid #e8e6e0;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end;padding:16px 24px}.modal-close{background:none;color:#6b6860;color:var(--text-2);font-size:20px;line-height:1}.modal-close:hover{color:#1a1916;color:var(--text)}.login-page{align-items:center;background:#134d2c;background:var(--brand-dark);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{background:#fff;background:var(--surface);border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:420px;padding:40px;width:100%}.login-logo{margin-bottom:28px}.login-logo h1{color:#1a6b3c;color:var(--brand);font-size:24px}.login-logo p{color:#6b6860;color:var(--text-2);font-size:14px;margin-top:4px}.empty-state{color:#a09d97;color:var(--text-3);padding:60px 20px;text-align:center}.empty-state .icon{font-size:40px;margin-bottom:12px}.empty-state p,.loading{font-size:14px}.loading{align-items:center;color:#6b6860;color:var(--text-2);display:flex;justify-content:center;padding:60px}.alert{border-radius:8px;border-radius:var(--radius-sm);font-size:14px;margin-bottom:16px;padding:12px 16px}.alert-error{background:#fee2e2;background:var(--danger-light);color:#dc2626;color:var(--danger)}.alert-success{background:#e8f5ee;background:var(--brand-light);color:#134d2c;color:var(--brand-dark)}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in{animation:fadeIn .25s ease}.hamburger{background:none;border:none;border-radius:6px;color:#1a1916;color:var(--text);cursor:pointer;display:none;flex-shrink:0;font-size:22px;padding:4px 6px}.hamburger:hover{background:#e8e6e0;background:var(--border)}@media (max-width:768px){.app-shell{display:block;height:auto;min-height:100vh;overflow:visible}.sidebar{display:flex;height:100vh;left:0;position:fixed;top:0;transform:translateX(-100%);transition:transform .25s ease;width:240px;width:var(--sidebar-w);z-index:100}.main-content{-webkit-overflow-scrolling:touch;height:auto;min-height:100vh;overflow-y:visible;width:100%}.hamburger{display:block}.page-body{padding:16px 12px}.page-header{flex-wrap:wrap;padding:14px 16px}.page-header h2{font-size:17px}.form-row{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr 1fr}.table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.modal-overlay{align-items:flex-end;padding:0}.modal{border-radius:16px 16px 0 0!important;max-width:100%!important}}@media (max-width:400px){.stats-grid{grid-template-columns:1fr}}@media (max-width:768px){.mobile-logout-btn{display:block!important}}.demo-banner-active .main-content{padding-top:44px}@media (max-width:768px){body,html{overflow-x:hidden}.main-content,body,html{-webkit-overflow-scrolling:touch}.main-content{overflow-y:auto;overscroll-behavior:contain}.page-body{min-height:100vh}}
/*# sourceMappingURL=main.c3ad727d.css.map*/