@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
:root{--green-50:#f0fdf4;--green-100:#dcfce7;--green-200:#bbf7d0;--green-300:#86efac;--green-400:#4ade80;--green-500:#22c55e;--green-600:#16a34a;--green-700:#0d7c42;--green-800:#166534;--green-900:#14532d;--green-950:#052e16;--yellow-50:#fefce8;--yellow-100:#fef9c3;--yellow-200:#fef08a;--yellow-300:#fde047;--yellow-400:#f5c518;--yellow-500:#eab308;--yellow-600:#ca8a04;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--bg-primary:#f8faf9;--bg-card:#fff;--bg-sidebar:var(--green-950);--text-primary:var(--gray-900);--text-secondary:var(--gray-600);--border-color:var(--gray-200);--accent:var(--green-700);--accent-light:var(--green-100);--accent-yellow:var(--yellow-400);--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 10px 30px #0000001a;--shadow-xl:0 20px 50px #0000001f;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--transition:all .2s cubic-bezier(.4,0,.2,1)}*{box-sizing:border-box;margin:0;padding:0}html,body{color:var(--text-primary);background:var(--bg-primary);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6}.login-container{background:linear-gradient(135deg,var(--green-950)0%,var(--green-800)50%,var(--green-700)100%);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-container:before{content:"";background:radial-gradient(circle,#f5c51826 0%,#0000 70%);border-radius:50%;width:600px;height:600px;animation:8s ease-in-out infinite float;position:absolute;top:-200px;right:-200px}.login-container:after{content:"";background:radial-gradient(circle,#22c55e1f 0%,#0000 70%);border-radius:50%;width:400px;height:400px;animation:10s ease-in-out infinite reverse float;position:absolute;bottom:-100px;left:-100px}@keyframes float{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-30px)scale(1.05)}}.login-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-xl);z-index:1;background:#ffffff0d;border:1px solid #ffffff1a;width:100%;max-width:440px;padding:48px;animation:.6s ease-out slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-card h1{color:#fff;letter-spacing:-.5px;margin-bottom:4px;font-size:28px;font-weight:800}.login-card .brand-accent{color:var(--accent-yellow)}.login-card .subtitle{color:#fff9;margin-bottom:32px;font-size:14px}.login-card label{color:#ffffffb3;margin-bottom:6px;font-size:13px;font-weight:500;display:block}.login-card input{border-radius:var(--radius-sm);color:#fff;width:100%;transition:var(--transition);background:#ffffff14;border:1px solid #ffffff26;outline:none;margin-bottom:20px;padding:12px 16px;font-family:inherit;font-size:15px}.login-card input:focus{border-color:var(--accent-yellow);background:#ffffff1f;box-shadow:0 0 0 3px #f5c51826}.login-card input::placeholder{color:#ffffff4d}.login-btn{background:linear-gradient(135deg,var(--green-600),var(--green-700));color:#fff;border-radius:var(--radius-sm);cursor:pointer;width:100%;transition:var(--transition);border:none;padding:14px;font-family:inherit;font-size:15px;font-weight:600;position:relative;overflow:hidden}.login-btn:hover{background:linear-gradient(135deg,var(--green-500),var(--green-600));transform:translateY(-1px);box-shadow:0 8px 25px #0d7c4259}.login-btn:active{transform:translateY(0)}.login-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.login-error{color:#fca5a5;border-radius:var(--radius-sm);background:#ef444426;border:1px solid #ef44444d;margin-bottom:16px;padding:10px 14px;font-size:13px;animation:.4s ease-in-out shake}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}.dashboard-layout{min-height:100vh;display:flex}.sidebar{background:linear-gradient(180deg,var(--green-950)0%,#0a1f14 100%);color:#fff;z-index:100;border-right:1px solid #ffffff0f;flex-direction:column;width:260px;padding:0;transition:transform .3s;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-brand{border-bottom:1px solid #ffffff0f;padding:24px 20px}.sidebar-brand h2{letter-spacing:-.3px;font-size:18px;font-weight:800}.sidebar-brand span{color:var(--accent-yellow)}.sidebar-brand .role-badge{color:var(--accent-yellow);letter-spacing:.3px;background:#f5c51826;border:1px solid #f5c51840;border-radius:20px;margin-top:6px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-block}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.sidebar-nav a{color:#fff9;border-radius:var(--radius-sm);transition:var(--transition);align-items:center;gap:12px;margin-bottom:2px;padding:11px 14px;font-size:14px;font-weight:500;text-decoration:none;display:flex}.sidebar-nav a:hover{color:#fff;background:#ffffff14}.sidebar-nav a.active{color:#fff;background:linear-gradient(135deg,#0d7c4266,#0d7c4233);border:1px solid #22c55e33}.sidebar-nav a .nav-icon{text-align:center;width:24px;font-size:18px}.sidebar-footer{border-top:1px solid #ffffff0f;padding:16px 12px}.sidebar-footer .user-info{border-radius:var(--radius-sm);align-items:center;gap:10px;margin-bottom:8px;padding:10px;display:flex}.sidebar-footer .user-avatar{background:linear-gradient(135deg,var(--green-500),var(--green-700));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.sidebar-footer .user-name{color:#fff;font-size:13px;font-weight:600}.sidebar-footer .user-email{color:#ffffff73;font-size:11px}.logout-btn{color:#fca5a5;border-radius:var(--radius-sm);cursor:pointer;width:100%;transition:var(--transition);background:#ef44441a;border:1px solid #ef444433;padding:10px;font-family:inherit;font-size:13px;font-weight:500}.logout-btn:hover{color:#fff;background:#ef444433}.main-content{flex:1;min-height:100vh;margin-left:260px;padding:28px 32px}.page-header{justify-content:space-between;align-items:center;margin-bottom:28px;display:flex}.page-header h1{color:var(--green-900);letter-spacing:-.5px;font-size:26px;font-weight:800}.page-header .header-subtitle{color:var(--text-secondary);margin-top:2px;font-size:14px}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px;margin-bottom:32px;display:grid}.stat-card{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-color);transition:var(--transition);padding:22px 24px;position:relative;overflow:hidden}.stat-card:before{content:"";background:linear-gradient(90deg,var(--green-500),var(--accent-yellow));opacity:0;height:3px;transition:var(--transition);position:absolute;top:0;left:0;right:0}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card:hover:before{opacity:1}.stat-card .stat-icon{margin-bottom:10px;font-size:28px}.stat-card .stat-label{color:var(--text-secondary);font-size:13px;font-weight:500}.stat-card .stat-value{color:var(--green-800);letter-spacing:-1px;font-size:28px;font-weight:800}.stat-card .stat-sub{color:var(--green-600);margin-top:2px;font-size:12px;font-weight:500}.data-section{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-color);margin-bottom:24px;overflow:hidden}.data-section-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:18px 24px;display:flex}.data-section-header h2{color:var(--green-900);font-size:16px;font-weight:700}.data-table{border-collapse:collapse;width:100%}.data-table th{background:var(--gray-50);text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-color);padding:12px 16px;font-size:12px;font-weight:600}.data-table td{border-bottom:1px solid var(--gray-100);color:var(--text-primary);padding:14px 16px;font-size:14px}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--green-50)}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);border:none;align-items:center;gap:8px;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:600;text-decoration:none;display:inline-flex}.btn-primary{background:linear-gradient(135deg,var(--green-600),var(--green-700));color:#fff}.btn-primary:hover{background:linear-gradient(135deg,var(--green-500),var(--green-600));transform:translateY(-1px);box-shadow:0 4px 15px #0d7c424d}.btn-secondary{background:var(--gray-100);color:var(--gray-700);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--gray-200)}.btn-danger{color:#dc2626;background:#ef44441a;border:1px solid #ef444433}.btn-danger:hover{background:#ef444433}.btn-sm{padding:6px 14px;font-size:13px}.btn-icon{padding:8px 12px}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#00000080;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-card);border-radius:var(--radius-lg);width:100%;max-width:560px;max-height:90vh;box-shadow:var(--shadow-xl);animation:.3s ease-out modalSlideUp;overflow-y:auto}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h2{color:var(--green-900);font-size:18px;font-weight:700}.modal-close{background:var(--gray-100);cursor:pointer;width:32px;height:32px;color:var(--gray-500);transition:var(--transition);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:18px;display:flex}.modal-close:hover{background:var(--gray-200);color:var(--gray-800)}.modal-body{padding:24px}.form-group{margin-bottom:18px}.form-group label{color:var(--gray-700);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border-color);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);background:var(--bg-card);transition:var(--transition);outline:none;padding:10px 14px;font-family:inherit;font-size:14px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--green-500);box-shadow:0 0 0 3px #22c55e1a}.form-group textarea{resize:vertical;min-height:80px}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.modal-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:10px;padding:16px 24px;display:flex}.status-badge{letter-spacing:.2px;border-radius:20px;align-items:center;padding:4px 12px;font-size:12px;font-weight:600;display:inline-flex}.status-new{color:#1d4ed8;background:#dbeafe}.status-contacted{color:#a16207;background:#fef9c3}.status-site-visit{color:#16a34a;background:#dcfce7}.status-quoted{color:#7c3aed;background:#f3e8ff}.status-closed{color:#059669;background:#d1fae5}.status-lost{color:#dc2626;background:#fee2e2}.status-planning{color:#1d4ed8;background:#dbeafe}.status-in-progress{color:#a16207;background:#fef9c3}.status-completed{color:#059669;background:#d1fae5}.status-on-hold{color:#7c3aed;background:#f3e8ff}.status-cancelled{color:#dc2626;background:#fee2e2}.empty-state{text-align:center;color:var(--text-secondary);padding:60px 20px}.empty-state .empty-icon{opacity:.5;margin-bottom:12px;font-size:48px}.empty-state h3{color:var(--gray-600);margin-bottom:4px;font-size:16px;font-weight:600}.empty-state p{color:var(--gray-400);font-size:14px}.loading-container{justify-content:center;align-items:center;padding:80px;display:flex}.spinner{border:3px solid var(--gray-200);border-top-color:var(--green-600);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.mobile-toggle{z-index:200;background:var(--green-700);border-radius:var(--radius-sm);color:#fff;cursor:pointer;width:42px;height:42px;box-shadow:var(--shadow-md);border:none;font-size:20px;display:none;position:fixed;top:16px;left:16px}@media (max-width:768px){.mobile-toggle{justify-content:center;align-items:center;display:flex}.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0;padding:70px 16px 16px}.stats-grid{grid-template-columns:1fr 1fr;gap:12px}.form-row{grid-template-columns:1fr}.data-table{font-size:13px}.page-header{flex-direction:column;align-items:flex-start;gap:12px}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.material-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.material-item{justify-content:space-between;align-items:center;gap:10px;display:flex}.material-item label{color:var(--gray-700);flex:1;min-width:0;font-size:13px}.material-item input{border:1px solid var(--border-color);border-radius:var(--radius-sm);width:100px;transition:var(--transition);outline:none;padding:6px 10px;font-family:inherit;font-size:13px}.material-item input:focus{border-color:var(--green-500);box-shadow:0 0 0 2px #22c55e1a}.toast{background:var(--green-800);color:#fff;border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:2000;padding:14px 20px;font-size:14px;font-weight:500;animation:.3s ease-out toastIn;position:fixed;bottom:24px;right:24px}.toast.error{background:#dc2626}@keyframes toastIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
