*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:#f3f4f6;color:#111827;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}:root{--brand: #1CB657;--brand-dark: #159446;--bg: #f3f4f6;--surface: #ffffff;--border: #e5e7eb;--text: #111827;--muted: #6b7280;--error-bg: #fee2e2;--error-text: #b91c1c;--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow-md: 0 4px 12px rgba(0,0,0,.06)}.navbar{background:var(--brand);color:#fff;box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:50}.navbar-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:64px}.navbar-brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:18px;color:#fff}.navbar-toggle{background:transparent;border:none;color:#fff;display:none;padding:8px}.navbar-menu{display:flex;align-items:center;gap:20px}.navbar-link{color:#fff;font-weight:500;opacity:.9;transition:opacity .15s}.navbar-link:hover{opacity:1}.navbar-user{color:#fff;opacity:.85;font-size:14px}.navbar-logout{display:inline-flex;align-items:center;gap:6px;background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.25);padding:8px 14px;border-radius:8px;font-size:14px;font-weight:500;transition:background .15s}.navbar-logout:hover{background:#ffffff40}@media(max-width:768px){.navbar-toggle{display:inline-flex}.navbar-menu{position:absolute;top:64px;left:0;right:0;flex-direction:column;gap:12px;background:var(--brand);padding:16px 24px;align-items:flex-start;display:none;box-shadow:var(--shadow-md)}.navbar-menu.open{display:flex}.navbar-logout{width:100%;justify-content:center}}.app-shell{min-height:100%;display:flex;flex-direction:column}.app-main{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:32px 24px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(135deg,#f3f4f6,#e5e7eb)}.login-card{width:100%;max-width:420px;background:var(--surface);border-radius:16px;padding:40px 32px;box-shadow:var(--shadow-md);border:1px solid var(--border)}.login-header{text-align:center;margin-bottom:28px}.login-icon{width:56px;height:56px;border-radius:14px;background:#1cb6571f;color:var(--brand);display:inline-flex;align-items:center;justify-content:center;margin-bottom:12px}.login-header h1{margin:0 0 4px;font-size:24px}.login-header p{margin:0;color:var(--muted);font-size:14px}.login-form{display:flex;flex-direction:column;gap:16px}.field{display:flex;flex-direction:column;gap:6px;font-size:14px;color:#374151}.input-wrap{display:flex;align-items:center;gap:8px;border:1px solid var(--border);border-radius:10px;padding:0 12px;background:#fff;transition:border-color .15s,box-shadow .15s}.input-wrap:focus-within{border-color:var(--brand);box-shadow:0 0 0 3px #1cb65726}.input-wrap svg{color:var(--muted);flex-shrink:0}.input-wrap input{flex:1;border:none;outline:none;padding:12px 0;font-size:15px;background:transparent}.alert-error{background:var(--error-bg);color:var(--error-text);padding:10px 12px;border-radius:8px;font-size:14px}.btn-primary{background:var(--brand);color:#fff;border:none;border-radius:10px;padding:12px 16px;font-size:15px;font-weight:600;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:background .15s,transform .05s}.btn-primary:hover:not(:disabled){background:var(--brand-dark)}.btn-primary:active{transform:translateY(1px)}.btn-primary:disabled{opacity:.7;cursor:not-allowed}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dashboard{display:flex;flex-direction:column;gap:28px}.dashboard-header h1{margin:0 0 4px;font-size:26px}.dashboard-header p{margin:0;color:var(--muted)}.stats-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:20px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow-sm);transition:transform .15s,box-shadow .15s}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-icon{width:44px;height:44px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center}.stat-label{color:var(--muted);font-size:13px}.stat-value{font-size:20px;font-weight:700;margin-top:2px}.panel{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:24px;box-shadow:var(--shadow-sm)}.panel h2{margin:0 0 16px;font-size:18px}.activity{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.activity li{display:flex;align-items:center;gap:10px;color:#374151;font-size:14px;padding:10px 12px;background:#f9fafb;border-radius:8px}.dot{width:8px;height:8px;border-radius:50%;background:var(--brand);flex-shrink:0}.alert-success{background:#dcfce7;color:#166534;padding:10px 12px;border-radius:8px;font-size:14px;margin-bottom:12px}.users-table{width:100%;border-collapse:collapse}.users-table th,.users-table td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--border);font-size:14px}.users-table th{color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.04em}.users-table tbody tr:hover{background:#f9fafb}.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600}.badge-on{background:#dcfce7;color:#166534}.badge-off{background:#f3f4f6;color:#6b7280}.icon-btn{background:transparent;border:1px solid var(--border);border-radius:8px;padding:6px;margin-left:6px;color:var(--text);display:inline-flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s}.icon-btn:hover{background:#f3f4f6}.icon-btn-danger{color:#b91c1c}.icon-btn-danger:hover{background:#fee2e2;border-color:#fecaca}.modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:100;padding:16px}.modal{background:var(--surface);border-radius:14px;width:100%;max-width:460px;box-shadow:0 20px 60px #00000040;padding:24px}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.modal-header h2{margin:0;font-size:18px}.toggle-row{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text);padding:8px 0}.toggle-row input{width:18px;height:18px;accent-color:var(--brand)}
