*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f7fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--primary-color:#3b82f6;--primary-dark:#2563eb;--secondary-color:#64748b;--success-color:#10b981;--danger-color:#ef4444;--warning-color:#f59e0b;--bg-color:#f5f7fa;--card-bg:#fff;--text-primary:#1e293b;--text-secondary:#64748b;--border-color:#e2e8f0;--sidebar-bg:#1e293b;--sidebar-text:#cbd5e1;--sidebar-active:#3b82f6}.container{margin:0 auto;max-width:1400px;padding:20px}.card{background:#fff;background:var(--card-bg);border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:20px;padding:20px}.btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:all .2s}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background:#3b82f6;background:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background:#2563eb;background:var(--primary-dark)}.btn-secondary{background:#64748b;background:var(--secondary-color);color:#fff}.btn-success{background:#10b981;background:var(--success-color);color:#fff}.btn-danger{background:#ef4444;background:var(--danger-color);color:#fff}.btn-outline{background:#0000;border:1px solid #e2e8f0;border:1px solid var(--border-color);color:#1e293b;color:var(--text-primary)}.input-group{margin-bottom:16px}.input-group label{color:#1e293b;color:var(--text-primary);display:block;font-size:14px;font-weight:500;margin-bottom:6px}.input-group input,.input-group select,.input-group textarea{border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:6px;font-size:14px;padding:10px 12px;transition:border-color .2s;width:100%}.input-group input:focus,.input-group select:focus,.input-group textarea:focus{border-color:#3b82f6;border-color:var(--primary-color);outline:none}.input-group textarea{min-height:100px;resize:vertical}.table-container{overflow-x:auto}table{border-collapse:collapse;width:100%}table td,table th{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);padding:12px;text-align:left}table th{color:#1e293b;color:var(--text-primary);font-weight:600}table th,table tr:hover{background:#f8fafc}.badge{border-radius:12px;display:inline-block;font-weight:500;padding:4px 12px}.badge-success{background:#d1fae5;color:#065f46}.badge-danger{background:#fee2e2;color:#991b1b}.badge-warning{background:#fef3c7;color:#92400e}.badge-info{background:#dbeafe;color:#1e40af}.loading{align-items:center;display:flex;justify-content:center;padding:40px}.spinner{animation:spin 1s linear infinite;border:3px solid #e2e8f0;border-top:3px solid #3b82f6;border:3px solid var(--border-color);border-radius:50%;border-top-color:var(--primary-color);height:40px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.error-message{background:#fee2e2;color:#991b1b}.error-message,.success-message{border-radius:6px;margin-bottom:16px;padding:12px}.success-message{background:#d1fae5;color:#065f46}@media (max-width:768px){.container{padding:10px}.card{padding:15px}table{font-size:12px}table td,table th{padding:8px}}.login-container{align-items:center;animation:gradientShift 15s ease infinite;background:linear-gradient(135deg,#667eea,#764ba2 50%,#f093fb);background-size:200% 200%;display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:20px;position:relative}@keyframes gradientShift{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}.login-container:before{animation:backgroundMove 20s linear infinite;background:radial-gradient(circle,#ffffff1a 1px,#0000 0);background-size:50px 50px;content:"";height:200%;left:-50%;position:absolute;top:-50%;width:200%}@keyframes backgroundMove{0%{transform:translate(0)}to{transform:translate(50px,50px)}}.login-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #ffffff4d;border-radius:24px;box-shadow:0 25px 50px -12px #00000040;max-width:440px;padding:48px;position:relative;width:100%;z-index:1}.login-header{margin-bottom:40px;text-align:center}.login-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:36px;font-weight:800;margin-bottom:8px}.login-header p{color:var(--text-secondary);font-size:15px;font-weight:500}.login-card .input-group{margin-bottom:20px}.login-card .input-group label{color:var(--text-primary);font-weight:600;margin-bottom:8px}.login-card .input-group input{border:2px solid var(--border-color);border-radius:12px;font-size:15px;padding:14px 16px;transition:all .3s ease}.login-card .input-group input:focus{border-color:#667eea;box-shadow:0 0 0 4px #667eea1a}.btn-block{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 15px #667eea66;font-size:16px;font-weight:700;margin-top:12px;padding:14px;width:100%}.btn-block:hover:not(:disabled){box-shadow:0 6px 20px #667eea80;transform:translateY(-2px)}.login-footer{border-top:1px solid var(--border-color);margin-top:32px;padding-top:24px;text-align:center}.login-footer p{background:#f8fafc;border-radius:8px;color:var(--text-secondary);font-size:13px;font-weight:500;padding:12px}@media (max-width:480px){.login-card{padding:32px 24px}.login-header h1{font-size:28px}}.stats-grid{grid-gap:20px;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:30px}.stat-card{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;display:flex;gap:20px;padding:24px;transition:transform .2s,box-shadow .2s}.stat-card:hover{box-shadow:0 4px 16px #0000001f;transform:translateY(-4px)}.stat-icon{align-items:center;border-radius:12px;display:flex;font-size:28px;height:60px;justify-content:center;width:60px}.stat-card:first-child .stat-icon{background:linear-gradient(135deg,#06b6d4,#3b82f6);color:#fff}.stat-card:nth-child(2) .stat-icon{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.stat-card:nth-child(3) .stat-icon{background:linear-gradient(135deg,#f97316,#ea580c);color:#fff}.stat-card:nth-child(4) .stat-icon{background:linear-gradient(135deg,#a855f7,#9333ea);color:#fff}.users-page{max-width:1400px}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.page-header h1{color:var(--text-primary);font-size:28px}.action-buttons{display:flex;gap:8px}.btn-icon{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:18px;padding:8px;transition:color .2s}.btn-icon:hover{color:var(--primary-color)}.btn-icon.danger:hover{color:var(--danger-color)}.mobile-card-header{gap:12px}.mobile-card-avatar{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:50%;box-shadow:0 2px 8px #6366f14d;color:#fff;display:flex;font-size:16px;font-weight:700;height:48px;justify-content:center;width:48px}.mobile-card-title{flex:1 1}.mobile-card-title h3{color:var(--text-primary);font-size:16px;font-weight:600;margin:0 0 4px}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal{background:#fff;border-radius:12px;max-height:90vh;max-width:600px;overflow-y:auto;padding:24px;width:100%}.modal h2{color:var(--text-primary);margin-bottom:20px}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.permissions-grid{grid-gap:12px;background:#f8fafc;border-radius:6px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));padding:12px}.checkbox-label{align-items:center;cursor:pointer;display:flex;font-size:14px;gap:8px}.checkbox-label input[type=checkbox]{cursor:pointer;width:auto}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.detail-grid{gap:16px}.detail-grid,.detail-item{display:flex;flex-direction:column}.detail-item{gap:4px}.detail-item strong{color:var(--text-secondary);font-size:14px}.detail-item span{color:var(--text-primary);font-size:16px}.permissions-list{margin-top:4px}@media (max-width:768px){.page-header{align-items:flex-start;flex-direction:column;gap:16px}.desktop-table{display:none}.mobile-cards{display:block}.form-row,.permissions-grid{grid-template-columns:1fr}.modal{padding:16px}}.departments-page{max-width:1400px}.departments-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.dept-card{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;gap:16px;padding:20px}.dept-header{align-items:center;display:flex;justify-content:space-between}.dept-header h3{color:var(--text-primary);font-size:18px;margin:0}.dept-description{line-height:1.5}.dept-description,.dept-stats{color:var(--text-secondary);font-size:14px}.dept-stats{background:#f8fafc;border-radius:6px;padding:12px}.dept-actions{align-items:center;border-top:1px solid var(--border-color);display:flex;gap:8px;justify-content:space-between;padding-top:16px}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr);margin:20px 0}.stat-item{background:#f8fafc;border-radius:6px;display:flex;flex-direction:column;gap:8px;padding:16px}.stat-item strong{color:var(--text-secondary);font-size:14px}.stat-item span{color:var(--text-primary);font-size:20px;font-weight:600}.text-success{color:var(--success-color)}.text-danger{color:var(--danger-color)}@media (max-width:768px){.departments-grid,.stats-grid{grid-template-columns:1fr}.dept-actions{flex-direction:column}}.customers-page{max-width:1400px}.filters-card{margin-bottom:20px}.search-box{margin-bottom:16px;position:relative}.search-box input{border:1px solid var(--border-color);border-radius:6px;font-size:14px;padding:10px 12px 10px 40px;width:100%}.search-icon{color:var(--text-secondary);left:12px;position:absolute;top:50%;transform:translateY(-50%)}.filters{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.filters select{border:1px solid var(--border-color);border-radius:6px;font-size:14px;padding:10px 12px}.modal-large{max-width:800px}.mobile-card{border-left:4px solid var(--primary-color)}@media (max-width:768px){.filters{grid-template-columns:1fr}.desktop-table{display:none}.mobile-cards{display:block}}.services-page{max-width:1200px}.mobile-card{border-left:4px solid var(--success-color)}.mobile-card-header{margin-bottom:16px}.pagination-container{align-items:center;display:flex;gap:1rem;justify-content:center;padding:1rem}.pagination-info{font-weight:500}.mobile-card-header h3{margin:0}.mobile-card-body{gap:12px}.mobile-card-row{gap:8px}.mobile-card-row .label{color:var(--text-secondary);font-size:13px;font-weight:600}.mobile-card-row .value{color:var(--text-primary);font-size:14px;text-align:right}.finances-page{max-width:1400px}.summary-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:24px}.summary-card{align-items:center;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;display:flex;gap:16px;padding:20px}.summary-icon{border-radius:8px;font-size:32px;padding:12px}.summary-card.income .summary-icon{background:#d1fae5;color:#065f46}.summary-card.expense .summary-icon{background:#fee2e2;color:#991b1b}.summary-card.profit.positive .summary-icon{background:#dbeafe;color:#1e40af}.summary-card.profit.negative .summary-icon{background:#fef3c7;color:#92400e}.summary-card h3{color:var(--text-secondary);font-size:14px;margin-bottom:4px}.summary-card p{color:var(--text-primary);font-size:24px;font-weight:700;margin:0}.mobile-card-header{align-items:center}.mobile-card-amount{font-size:18px;font-weight:700}@media (max-width:768px){.summary-cards{grid-template-columns:1fr}.desktop-table{display:none}.mobile-cards{display:block}}.communications-page{max-width:1400px}.mobile-cards{display:none}.mobile-card{background:#fff;border-radius:12px;box-shadow:var(--shadow-md);margin-bottom:16px;padding:16px;transition:all .3s ease}.mobile-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.mobile-card-header{align-items:flex-start;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:12px}.mobile-card-header h3{color:var(--text-primary);font-size:16px;font-weight:600;margin:0 0 4px}.mobile-card-company{color:var(--text-secondary);font-size:13px;margin:0}.mobile-card-body{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.mobile-card-row{align-items:center;display:flex;font-size:14px;justify-content:space-between}.mobile-card-label{color:var(--text-secondary);font-weight:500}.mobile-card-notes{background:var(--bg-color);border-radius:6px;display:flex;flex-direction:column;gap:4px;padding:8px}.mobile-card-notes p{color:var(--text-primary);font-size:13px;line-height:1.5;margin:0}.mobile-card-actions{border-top:1px solid var(--border-color);display:flex;gap:8px;justify-content:flex-end;padding-top:12px}@media (max-width:768px){.desktop-table{display:none}.mobile-cards{display:block}}:root{--info-color:#007bff;--info-bg:#e6f2ff;--warning-color:#ffc107;--warning-bg:#fff9e6;--success-color:#28a745;--success-bg:#eaf6ec;--surface-secondary:#f8f9fa;--border-color:#e0e0e0;--text-primary:#212529;--text-secondary:#6c757d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.notifications-page{margin:0 auto;max-width:1200px}.notifications-list{grid-gap:16px;display:grid;gap:16px}.notification-card{align-items:flex-start;background:#fff;border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);display:flex;gap:16px;padding:20px;transition:all .3s ease}.notification-card:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.notification-card.unread{background:linear-gradient(90deg,#fdfdff 0,#fff);border-left:4px solid #007bff;border-left:4px solid var(--info-color)}.notification-card.read{background:#f8f9fa;background:var(--surface-secondary);border-color:#e0e0e0;border-color:var(--border-color)}.notification-card.read .notification-header h3,.notification-card.read p{color:#6c757d;color:var(--text-secondary)}.notification-icon-wrapper{border-radius:50%;display:grid;flex-shrink:0;height:44px;place-items:center;width:44px}.notification-icon-wrapper .icon{height:20px;width:20px}.notification-card.type-announcement .notification-icon-wrapper{background-color:#e6f2ff;background-color:var(--info-bg);color:#007bff;color:var(--info-color)}.notification-card.type-reminder .notification-icon-wrapper{background-color:#fff9e6;background-color:var(--warning-bg);color:#ffc107;color:var(--warning-color)}.notification-card.type-task .notification-icon-wrapper{background-color:#eaf6ec;background-color:var(--success-bg);color:#28a745;color:var(--success-color)}.notification-content{display:flex;flex-direction:column;flex-grow:1;gap:8px;min-width:0}.notification-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between}.notification-header h3{color:#212529;color:var(--text-primary);flex:1 1;font-size:18px;font-weight:600;margin:0;overflow-wrap:break-word;word-break:break-all}.badge{border-radius:20px;font-size:12px;font-weight:600;padding:4px 10px;white-space:nowrap}.badge.type-announcement{background-color:#e6f2ff;background-color:var(--info-bg);color:#007bff;color:var(--info-color)}.badge.type-reminder{background-color:#fff9e6;background-color:var(--warning-bg);color:#ffc107;color:var(--warning-color)}.badge.type-task{background-color:#eaf6ec;background-color:var(--success-bg);color:#28a745;color:var(--success-color)}.notification-sender{color:#6c757d;color:var(--text-secondary);font-size:13px;font-weight:500;margin-top:-4px}.notification-content p{color:#6c757d;color:var(--text-secondary);line-height:1.6;margin:0;overflow-wrap:break-word;word-break:break-all}.notification-date{color:#6c757d;color:var(--text-secondary);font-size:13px;font-weight:500}.notification-actions{align-items:center;display:flex;flex-shrink:0;gap:8px}@media (max-width:768px){.notification-card{flex-direction:column;padding:16px}.notification-header{flex-direction:row}.notification-content{width:100%}.notification-actions{border-top:1px solid #e0e0e0;border-top:1px solid var(--border-color);justify-content:flex-end;margin-top:8px;padding-top:12px;width:100%}}.profile-page{max-width:1000px}.profile-page h1{color:var(--text-primary);margin-bottom:24px}.profile-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-bottom:20px}.card h2{color:var(--text-primary);font-size:18px;margin-bottom:20px}.info-grid{gap:16px}.info-grid,.info-item{display:flex;flex-direction:column}.info-item{background:#f8fafc;border-radius:6px;gap:4px;padding:12px}.info-item strong{color:var(--text-secondary);font-size:14px}.info-item span{color:var(--text-primary);font-size:16px}.permissions-list{display:flex;flex-wrap:wrap;gap:8px}@media (max-width:768px){.profile-grid{grid-template-columns:1fr}}.layout{background:var(--bg-color);display:flex;min-height:100vh}.sidebar{background:linear-gradient(180deg,#1e293b,#0f172a);box-shadow:4px 0 24px #0000001f;color:var(--sidebar-text);display:flex;flex-direction:column;height:100vh;left:0;overflow-y:auto;position:fixed;top:0;transition:transform .3s ease;width:280px;z-index:1000}.sidebar-header{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;padding:24px}.sidebar-header h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#a5b4fc);-webkit-background-clip:text;background-clip:text;color:#fff;font-size:22px;font-weight:700}.close-sidebar{background:none;border:none;color:#fff;cursor:pointer;display:none;font-size:24px;padding:0}.sidebar-nav{flex:1 1;overflow-y:auto;padding:20px 0}.nav-item{align-items:center;background:none;border:none;border-radius:12px;color:var(--sidebar-text);cursor:pointer;display:flex;font-size:15px;font-weight:500;gap:14px;margin:4px 12px;padding:14px 20px;text-align:left;text-decoration:none;transition:all .3s ease;width:calc(100% - 24px)}.nav-item:hover{background:#ffffff14;color:#fff;transform:translateX(4px)}.nav-item.active{background:linear-gradient(135deg,#6366f1,#8b5cf6);box-shadow:0 4px 12px #6366f166;color:#fff}.nav-icon{font-size:20px;min-width:20px}.sidebar-footer{border-top:1px solid #ffffff1a;padding:20px 0}.logout-btn{color:#ef4444}.main-content{display:flex;flex:1 1;flex-direction:column;margin-left:280px;min-height:100vh}.header{align-items:center;background:#fff;border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;padding:20px 32px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.menu-toggle{background:none;border:none;color:var(--text-primary);cursor:pointer;display:none;font-size:24px}.header-user{gap:12px}.header-user,.user-avatar{align-items:center;display:flex}.user-avatar{background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:50%;box-shadow:0 2px 8px #6366f14d;color:#fff;font-size:16px;font-weight:700;height:40px;justify-content:center;width:40px}.user-info{align-items:flex-end;display:flex;flex-direction:column}.user-info span{color:var(--text-primary);font-size:14px;font-weight:600}.user-role{background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:12px;box-shadow:0 2px 6px #6366f14d;color:#fff;font-size:12px;font-weight:600;margin-top:4px;padding:4px 12px}.content{flex:1 1;padding:32px}.footer{background:#fff;border-top:1px solid var(--border-color);color:var(--text-secondary);font-size:14px;padding:24px 32px;text-align:center}@media (max-width:768px){.sidebar{overflow-y:auto;position:fixed;transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.close-sidebar{display:block}.main-content{margin-left:0}.menu-toggle{display:block}.header{padding:16px}.user-info{display:none}.user-avatar{display:flex}.content{padding:16px}}@media (min-width:480px) and (max-width:768px){.user-info{display:flex}}
/*# sourceMappingURL=main.8a1b6d26.css.map*/