#app{height:100vh}*{margin:0;padding:0;box-sizing:border-box;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}:root{--primary: #2c6fbb;--primary-dark: #1a5ca3;--secondary: #f8f9fa;--accent: #4CAF50;--warning: #ff9800;--danger: #f44336;--text: #333;--text-light: #666;--border: #e0e0e0;--card-shadow: 0 4px 12px rgba(0, 0, 0, .08)}body{background-color:#f5f7fa;color:var(--text);overflow-x:hidden}.login-container{display:flex;justify-content:center;align-items:center;height:100vh;background:linear-gradient(135deg,#6a11cb 0%,#2575fc 100%);padding:20px}.login-card{background:white;border-radius:10px;box-shadow:var(--card-shadow);width:100%;max-width:420px;padding:40px;text-align:center}.login-card h2{color:var(--primary);margin-bottom:30px;font-weight:600}.login-log{width:100px;height:100px}.input-group{margin-bottom:20px;text-align:left}.input-group label{display:block;margin-bottom:8px;color:var(--text-light);font-weight:500}.input-group input{width:100%;padding:12px 15px;border:1px solid var(--border);border-radius:6px;font-size:16px;transition:border .3s}.input-group input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #2c6fbb1a}.remember-forgot{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px}.remember{display:flex;align-items:center}.remember input{margin-right:8px}.forgot-password{color:var(--primary);text-decoration:none;transition:color .3s}.forgot-password:hover{color:var(--primary-dark);text-decoration:underline}.login-btn{background:var(--primary);color:#fff;border:none;border-radius:6px;padding:12px;width:100%;font-size:16px;font-weight:600;cursor:pointer;transition:background .3s}.login-btn:hover{background:var(--primary-dark)}.dashboard-container{display:flex;min-height:100vh}.sidebar{width:250px;background:var(--primary);color:#fff;transition:all .3s;box-shadow:3px 0 10px #0000001a;z-index:100}.sidebar-header{padding:20px 15px;display:flex;align-items:center;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-header h2{font-size:22px;font-weight:600;margin-left:10px}.admin-logo{background:white;width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--primary);font-size:20px}.nav-links{padding:15px 0}.nav-item{padding:12px 20px;display:flex;align-items:center;cursor:pointer;transition:all .3s;border-left:4px solid transparent;text-decoration:none;color:#fff}.nav-item:hover,.nav-item.active{background:rgba(255,255,255,.1);border-left:4px solid white}.nav-item i{margin-right:12px;font-size:18px;width:24px;text-align:center}.main-content{flex:1;display:flex;flex-direction:column;background:#f5f7fa}.topbar{background:white;padding:15px 30px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000001a}.topbar-left h1{font-size:24px;font-weight:600;color:var(--text)}.topbar-right{display:flex;align-items:center;gap:20px}.user-info{display:flex;align-items:center;gap:10px}.user-avatar{width:40px;height:40px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px}.logout-btn{background:none;border:1px solid var(--border);padding:8px 16px;border-radius:6px;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .3s}.logout-btn:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.logout-btn i{font-size:14px}.content{flex:1;padding:30px;overflow-y:auto}.card{background:white;border-radius:10px;box-shadow:var(--card-shadow);margin-bottom:20px;overflow:hidden}.card-header{padding:20px 30px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.card-title{font-size:18px;font-weight:600;color:var(--text)}.btn{padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;display:inline-flex;align-items:center;gap:8px;transition:all .3s}.btn i{font-size:14px}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-success{background:var(--accent);color:#fff}.btn-warning{background:var(--warning);color:#fff}.btn-danger{background:var(--danger);color:#fff}.table-container{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{padding:12px 15px;text-align:left;border-bottom:1px solid var(--border)}th{background:#f8f9fa;font-weight:600;color:var(--text)}tr:hover{background:#f8f9fa}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:20px}.form-group{display:flex;flex-direction:column}.form-group label{margin-bottom:8px;font-weight:500;color:var(--text)}.form-group input,.form-group select{padding:10px 12px;border:1px solid var(--border);border-radius:6px;font-size:14px}.form-group textarea{padding:10px 12px;border:1px solid var(--border);border-radius:6px;font-size:14px;resize:vertical;min-height:100px}.status-badge{padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.status-active{background:#e8f5e8;color:var(--accent)}.status-inactive{background:#ffeaea;color:var(--danger)}.action-btns{display:flex;gap:8px}.action-btn{width:32px;height:32px;border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;font-size:14px}.action-btn.edit{background:#e3f2fd;color:#1976d2}.action-btn.delete{background:#ffebee;color:var(--danger)}.action-btn.view{background:#f3e5f5;color:#7b1fa2}.action-btn:hover{transform:scale(1.1)}.permission-tree{padding:20px}.tree-node{margin-bottom:20px}.tree-header{display:flex;align-items:center;gap:10px;padding:10px;background:#f8f9fa;border-radius:6px;font-weight:600;margin-bottom:10px}.tree-header i{color:var(--primary);font-size:16px}.tree-children{margin-left:30px}.tree-child{display:flex;align-items:center;gap:10px;padding:8px 0}.tree-child i{color:var(--text-light);font-size:12px}.tree-child input[type=checkbox]{margin-right:8px}.stats-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:20px}.stat-card{background:white;border-radius:10px;box-shadow:var(--card-shadow);padding:20px;display:flex;align-items:center;gap:15px}.stat-icon{width:60px;height:60px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:24px;color:#fff}.stat-card:nth-child(1) .stat-icon{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.stat-card:nth-child(2) .stat-icon{background:linear-gradient(135deg,#f093fb 0%,#f5576c 100%)}.stat-card:nth-child(3) .stat-icon{background:linear-gradient(135deg,#4facfe 0%,#00f2fe 100%)}.stat-card:nth-child(4) .stat-icon{background:linear-gradient(135deg,#43e97b 0%,#38f9d7 100%)}.stat-info h3{font-size:24px;font-weight:600;margin-bottom:5px}.stat-info p{color:var(--text-light);font-size:14px}.agc-connection{background:white;border-radius:10px;box-shadow:var(--card-shadow);padding:20px;margin-bottom:20px}.agc-connection h3{display:flex;align-items:center;gap:10px;margin-bottom:15px;font-size:18px;font-weight:600}.agc-connection h3 i{color:var(--accent);font-size:20px}.agc-status{display:flex;align-items:center;gap:10px;margin-bottom:10px;padding:10px;background:#f8f9fa;border-radius:6px}.status-indicator{width:12px;height:12px;border-radius:50%;background:#ccc}.agc-status.connected .status-indicator{background:var(--accent)}.agc-status.disconnected .status-indicator{background:var(--danger)}.agc-actions{display:flex;gap:10px;margin-top:15px}@media (max-width: 768px){.sidebar{width:60px}.sidebar-header h2,.nav-item span{display:none}.nav-item{justify-content:center;padding:15px 10px}.nav-item i{margin-right:0}.stats-container{grid-template-columns:1fr}.topbar{padding:15px 20px}.topbar-right{gap:10px}}@media (max-width: 480px){.login-card{padding:30px 20px}.content{padding:20px 15px}.card,.form-group{margin-bottom:15px}}
