* { margin:0; padding:0; box-sizing:border-box; } body { font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif; background:#f0f2f5; color:#1a1a2e; } .container { max-width:1200px; margin:0 auto; padding:0 20px; } nav { background:linear-gradient(135deg,#1a1a2e 0%,#16213e 100%); color:#fff; padding:0 20px; box-shadow:0 2px 12px rgba(0,0,0,0.15); position:sticky; top:0; z-index:100; } nav .container { display:flex; align-items:center; justify-content:space-between; height:60px; } nav .brand { font-size:1.3rem; font-weight:800; color:#fff; text-decoration:none; letter-spacing:-0.5px; } nav .brand span { color:#00d4aa; } nav .nav-links { display:flex; gap:2px; } nav .nav-links a { color:#8899aa; text-decoration:none; padding:8px 18px; border-radius:8px; font-size:0.9rem; font-weight:500; transition:all .2s; } nav .nav-links a:hover { color:#fff; background:rgba(255,255,255,0.08); } nav .nav-links a.active { background:#00d4aa; color:#1a1a2e; font-weight:700; } nav .user-info { color:#667788; font-size:0.85rem; display:flex; align-items:center; gap:8px; } nav .user-info a { color:#ff6b6b; text-decoration:none; padding:4px 12px; border-radius:6px; font-size:0.8rem; border:1px solid rgba(255,107,107,0.3); transition:all .2s; } nav .user-info a:hover { background:rgba(255,107,107,0.1); border-color:#ff6b6b; } .card { background:#fff; border-radius:12px; box-shadow:0 1px 4px rgba(0,0,0,0.06); padding:24px; margin-bottom:20px; border:1px solid rgba(0,0,0,0.04); } .card-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:16px; } .card-header h2 { font-size:1.1rem; font-weight:700; color:#1a1a2e; } .card-header h2 .count { color:#667788; font-weight:400; font-size:0.9rem; } .stats-grid { display:grid; grid-template-columns:repeat(4, 1fr); gap:14px; margin-bottom:28px; } .stat-card { background:#fff; border-radius:14px; padding:18px 16px; box-shadow:0 1px 4px rgba(0,0,0,0.05); border:1px solid rgba(0,0,0,0.04); transition:all .2s; cursor:default; position:relative; overflow:hidden; } .stat-card:hover { transform:translateY(-2px); box-shadow:0 6px 20px rgba(0,0,0,0.1); } .stat-card .stat-icon { font-size:1.5rem; margin-bottom:4px; } .stat-card .stat-value { font-size:1.5rem; font-weight:800; line-height:1.2; letter-spacing:-0.5px; word-break:break-word; overflow-wrap:break-word; } .stat-card .stat-label { font-size:0.75rem; color:#8899aa; margin-top:2px; font-weight:500; text-transform:uppercase; letter-spacing:0.4px; } .stat-card .stat-bar { height:3px; border-radius:2px; margin-top:10px; width:36px; } .stat-card.green { border-left:4px solid #00d4aa; } .stat-card.green .stat-value { color:#00b894; } .stat-card.green .stat-bar { background:#00d4aa; } .stat-card.red { border-left:4px solid #ff6b6b; } .stat-card.red .stat-value { color:#e05555; } .stat-card.red .stat-bar { background:#ff6b6b; } .stat-card.orange { border-left:4px solid #f39c12; } .stat-card.orange .stat-value { color:#d68910; } .stat-card.orange .stat-bar { background:#f39c12; } .stat-card.blue { border-left:4px solid #3498db; } .stat-card.blue .stat-value { color:#2980b9; } .stat-card.blue .stat-bar { background:#3498db; } .stat-card.purple { border-left:4px solid #9b59b6; } .stat-card.purple .stat-value { color:#8e44ad; } .stat-card.purple .stat-bar { background:#9b59b6; } .stat-card.teal { border-left:4px solid #1abc9c; } .stat-card.teal .stat-value { color:#16a085; } .stat-card.teal .stat-bar { background:#1abc9c; } table { width:100%; border-collapse:collapse; } th, td { text-align:left; padding:12px 14px; border-bottom:1px solid #f0f0f0; font-size:0.9rem; } th { background:#f8f9fa; font-weight:700; color:#667788; font-size:0.75rem; text-transform:uppercase; letter-spacing:0.6px; padding:10px 14px; } tr:last-child td { border-bottom:none; } tr:hover td { background:#f8f9fa; } .badge { display:inline-block; padding:3px 12px; border-radius:20px; font-size:0.75rem; font-weight:600; letter-spacing:0.2px; } .badge-active { background:#d4edda; color:#155724; } .badge-cancelled { background:#f8d7da; color:#721c24; } .badge-wiped { background:#fff3cd; color:#856404; } .badge-pending { background:#fff3cd; color:#856404; } .badge-paid { background:#d4edda; color:#155724; } .badge-overdue { background:#f8d7da; color:#721c24; animation:pulse 1.5s infinite; } @keyframes pulse { 0%,100%{opacity:1} 50%{opacity:0.7} } .form-group { margin-bottom:18px; } .form-group label { display:block; font-size:0.85rem; font-weight:600; color:#444; margin-bottom:6px; } .form-group input, .form-group select, .form-group textarea { width:100%; padding:10px 14px; border:1.5px solid #e0e0e0; border-radius:8px; font-size:0.9rem; transition:all .2s; background:#fafafa; } .form-group input:focus, .form-group select:focus, .form-group textarea:focus { outline:none; border-color:#00d4aa; background:#fff; box-shadow:0 0 0 4px rgba(0,212,170,0.12); } .form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; } .btn { display:inline-flex; align-items:center; gap:4px; padding:9px 20px; border-radius:8px; font-size:0.85rem; font-weight:600; text-decoration:none; border:none; cursor:pointer; transition:all .2s; } .btn-primary { background:#00d4aa; color:#1a1a2e; } .btn-primary:hover { background:#00b894; transform:translateY(-1px); box-shadow:0 4px 12px rgba(0,212,170,0.3); } .btn-secondary { background:#6c757d; color:#fff; } .btn-secondary:hover { background:#5a6268; transform:translateY(-1px); } .btn-danger { background:#ff6b6b; color:#fff; } .btn-danger:hover { background:#e05555; transform:translateY(-1px); } .btn-sm { padding:5px 14px; font-size:0.8rem; } .btn-warning { background:#f39c12; color:#fff; } .btn-warning:hover { background:#d68910; transform:translateY(-1px); } .search-bar { display:flex; gap:10px; margin-bottom:20px; } .search-bar input { flex:1; padding:10px 16px; border:1.5px solid #e0e0e0; border-radius:8px; font-size:0.9rem; transition:all .2s; } .search-bar input:focus { outline:none; border-color:#00d4aa; box-shadow:0 0 0 4px rgba(0,212,170,0.12); } .login-page { display:flex; justify-content:center; align-items:center; min-height:100vh; background:linear-gradient(135deg,#1a1a2e 0%,#0f3460 100%); } .login-card { background:#fff; border-radius:16px; padding:44px; width:420px; box-shadow:0 20px 60px rgba(0,0,0,0.3); } .login-card h1 { text-align:center; margin-bottom:4px; font-size:1.8rem; } .login-card h1 span { color:#00d4aa; } .login-card .subtitle { text-align:center; color:#8899aa; font-size:0.9rem; margin-bottom:28px; } .login-card .error { background:#fef2f2; border:1px solid #f8d7da; color:#721c24; padding:12px; border-radius:8px; margin-bottom:20px; font-size:0.85rem; text-align:center; } .login-card .btn { width:100%; padding:12px; font-size:1rem; justify-content:center; } .page-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:24px; } .page-header h1 { font-size:1.5rem; font-weight:800; } .alert { padding:14px 20px; border-radius:10px; margin-bottom:20px; font-size:0.9rem; display:flex; align-items:center; gap:10px; } .alert-warning { background:#fffbe6; color:#856404; border:1px solid #ffeeba; } .action-bar { display:flex; gap:8px; align-items:center; } .empty { text-align:center; padding:48px 20px; color:#aaa; } code { background:#f0f2f5; padding:2px 8px; border-radius:4px; font-size:0.85rem; font-family:'SF Mono','Monaco','Menlo',monospace; color:#e05555; } @media (max-width:1024px){ .stats-grid { grid-template-columns:repeat(2, 1fr); } } @media (max-width:768px){ .form-row { grid-template-columns:1fr; } .stats-grid { grid-template-columns:1fr 1fr; } .stat-card { padding:14px 12px; } .stat-card .stat-value { font-size:1.2rem; } nav .nav-links a { padding:6px 10px; font-size:0.8rem; } }