:root,:root[data-theme=light]{--primary-color:#667eea;--secondary-color:#764ba2;--success-color:#10b981;--danger-color:#ef4444;--warning-color:#f59e0b;--bg-primary:#f5f7fa;--bg-secondary:#e8ecf1;--bg-card:#fff;--bg-input:#f0f3f7;--bg-hover:#f0f3f7;--bg-selected:#e8ecf1;--text-primary:#1f2937;--text-secondary:#6b7280;--border-color:#d1d5db}*{box-sizing:border-box}*,body,html{margin:0;padding:0}body,html{height:100%;width:100%}body{color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;transition:background-color .3s ease,color .3s ease}#root,body{background:var(--bg-primary);min-height:100vh}#root{display:flex;flex-direction:column;width:100%}.container{margin:0 auto;max-width:1200px;padding:20px}.btn{align-items:center;border-radius:8px;display:inline-flex;gap:8px;transition:all .3s cubic-bezier(.4,0,.2,1);white-space:nowrap}.btn-primary{background:var(--primary-color)}.btn-primary:hover{transform:translateY(-2px)}.btn-secondary{background:var(--bg-hover);border:1px solid var(--border-color);color:var(--text-primary)}.btn-secondary:hover{background:var(--bg-selected);border-color:var(--primary-color)}.btn-danger{background:var(--danger-color);color:#fff}.btn-danger:hover{background:#dc2626}.btn-success{background:var(--success-color);color:#fff}input,select,textarea{background:var(--bg-input);border:1px solid var(--border-color);border-radius:8px;box-sizing:border-box;color:var(--text-primary);font-family:inherit;font-size:14px;padding:10px;transition:all .3s ease;width:100%}input::placeholder,textarea::placeholder{color:var(--text-secondary)}input:focus,select:focus,textarea:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #667eea1a;outline:none}.card{background:var(--bg-card);border:1px solid var(--border-color)}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;box-shadow:0 10px 40px #0000004d;max-height:90vh;max-width:600px;overflow-y:auto;padding:30px;width:90%}@media (max-width:768px){.container{padding:10px}.btn{font-size:14px;padding:8px 16px}.card{padding:15px}input,select,textarea{font-size:16px}}.btn,.btn-danger,.btn-primary,.btn-secondary,.btn-success,a,button,div,h1,h2,h3,h4,h5,h6,input,label,li,p,select,span,textarea{color:var(--text-primary)!important}input,select,textarea{background:var(--bg-input)!important;border-color:var(--border-color)!important}.text-secondary,input::placeholder,textarea::placeholder{color:var(--text-secondary)!important}.App{background:#f5f7fa;min-height:100vh}.main-content{box-sizing:border-box;margin:0 auto;max-width:1400px;padding:30px 20px;width:100%}.error,.loading{border-radius:10px;font-size:18px;margin:20px 0;padding:20px;text-align:center}.loading{background:#e3f2fd;color:#1976d2}.error{background:#ffebee;color:#d32f2f}.grid{grid-gap:20px;display:grid;gap:20px;margin-bottom:20px;width:100%}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.grid-4{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}@media (max-width:768px){.grid-3,.grid-4{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.main-content{padding:15px 10px}}.header{background:linear-gradient(135deg,var(--primary-color) 0,#764ba2 100%);box-shadow:0 2px 10px #0003;color:#fff;padding:15px 0;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header,.header *{color:#fff!important}.header-container{gap:20px;justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 20px}.header-container,.logo h1{align-items:center;display:flex}.logo h1{font-size:24px;gap:10px;margin:0}.nav{flex:1 1;gap:5px}.nav,.nav-link{align-items:center;display:flex}.nav-link{background:#0000;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:15px;font-weight:500;gap:8px;padding:10px 15px;transition:all .3s cubic-bezier(.4,0,.2,1)}.nav-link:hover{background:#ffffff26;transform:translateY(-2px)}.nav-link.active{background:#ffffff40;box-shadow:0 4px 12px #0003}.header-actions{align-items:center;display:flex;gap:12px}.user-name{color:#ffffffe6;font-size:14px;font-weight:500}.btn-logout{align-items:center;background:#ffffff1a;border:2px solid #ffffff4d;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:20px;height:44px;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);width:44px}.btn-logout:hover{background:#fff3;border-color:#ffffff80;transform:scale(1.05)}.btn-logout:active{transform:scale(.95)}.menu-toggle{background:#0000;border:none;color:#fff;cursor:pointer;display:none;padding:5px}@media (max-width:768px){.menu-toggle{align-items:center;display:flex}.header-actions{gap:8px}.user-name{display:none}.nav{background:#667eeaf2;flex-direction:column;gap:0;left:0;max-height:0;overflow:hidden;position:absolute;right:0;top:60px;transition:max-height .3s ease}.nav.open{max-height:200px}.nav-link{border:none;border-radius:0;justify-content:flex-start;padding:15px 20px;width:100%}.nav-link.active{border-left:3px solid #fff}.header-container{flex-wrap:wrap}.logo h1{font-size:18px}}.dashboard{display:flex;flex-direction:column;gap:30px;width:100%}.dashboard h2{font-size:28px}.dashboard h2,.dashboard h3{color:#333;margin-bottom:20px;margin-top:0}.dashboard h3{font-size:20px}.stat-card{align-items:center;background:#fff;border-left:4px solid;border-radius:10px;box-shadow:0 2px 8px #0000001a;display:flex;gap:15px;min-height:80px;padding:20px;transition:transform .3s ease}.stat-card:hover{transform:translateY(-5px)}.stat-card.total{border-left-color:#667eea}.stat-card.completed{border-left-color:#10b981}.stat-card.inprogress{border-left-color:#2196f3}.stat-card.todo{border-left-color:#ff9800}.stat-icon{font-size:32px}.stat-content{flex:1 1}.stat-value{color:#333;font-size:24px;font-weight:700}.stat-label{color:#666;font-size:13px;margin-top:5px}.card{box-shadow:0 2px 10px #0000001a;transition:box-shadow .3s ease}.card:hover{box-shadow:0 4px 20px #00000026}.large-progress{padding:20px 0;text-align:center;width:100%}.large-progress .progress-bar{background:#e0e0e0;border-radius:15px;height:30px;margin:15px 0;overflow:hidden;width:100%}.large-progress .progress-fill{background:linear-gradient(90deg,#667eea,#764ba2);height:100%;transition:width .3s ease}.phases-list{gap:15px;width:100%}.phase-item,.phases-list{display:flex;flex-direction:column}.phase-item{background:#f9f9f9;border-left:3px solid #667eea;border-radius:8px;gap:8px;padding:15px}.phase-name{color:#333;font-weight:600;margin:0}.phase-stats{color:#666;font-size:12px;margin:0}.phase-progress{align-items:center;display:flex;gap:10px}.phase-progress .progress-bar{background:#e0e0e0;border-radius:4px;flex:1 1;height:8px;min-width:100px;overflow:hidden}.phase-progress .progress-fill{background:linear-gradient(90deg,#667eea,#764ba2);height:100%;transition:width .3s ease}.progress-percent{color:#666;font-size:12px;font-weight:600;min-width:35px;text-align:right;white-space:nowrap}.priority-list{display:flex;flex-direction:column;gap:12px;width:100%}.priority-item{align-items:center;background:#f5f5f5;border-left:3px solid #667eea;border-radius:5px;display:flex;justify-content:space-between;padding:10px 15px}.priority-item .count{color:#667eea;font-size:18px;font-weight:700}.budget-display{padding:20px;text-align:center;width:100%}.budget-amount{color:#10b981;font-size:36px;font-weight:700;margin-bottom:10px;word-break:break-word}.budget-label{color:#666;font-size:14px}.urgent-tasks{gap:10px;width:100%}.urgent-item,.urgent-tasks{display:flex;flex-direction:column}.urgent-item{background:#fff5f5;border-left:3px solid #ef4444;border-radius:5px;gap:5px;padding:12px}.urgent-title{color:#333;font-weight:600;margin:0}.urgent-meta{display:flex;flex-wrap:wrap;font-size:12px;gap:10px}.phase-tag{background:#e3f2fd;color:#1976d2}.phase-tag,.status-tag{border-radius:3px;padding:3px 8px;white-space:nowrap}.status-tag{color:#fff;font-size:12px}.budget-amount.spent{color:#10b981}.empty-state{font-size:14px;padding:20px}.categories-summary{display:flex;flex-direction:column;gap:10px}.category-summary-item{align-items:center;background:#f9f9f9;border-left:3px solid #667eea;border-radius:6px;display:flex;justify-content:space-between;padding:10px}.category-info{gap:10px}.category-amount{font-size:14px}.category-badge{background:#667eea;border-radius:12px;color:#fff;font-size:12px;font-weight:600;min-width:24px;padding:2px 8px;text-align:center}@media (max-width:768px){.dashboard h2{font-size:20px}.stat-card{flex-direction:column;text-align:center}.stat-icon{font-size:28px}}.tm-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}.tm-modal{background:var(--bg-card);border-radius:10px;box-shadow:0 10px 40px #0000004d;color:var(--text-primary);max-width:800px;padding:20px;position:relative;width:90%}.tm-close{background:#0000;border:none;cursor:pointer;font-size:18px;position:absolute;right:12px;top:12px}.tm-list{display:flex;flex-direction:column;gap:12px;margin-top:8px}.tm-item{padding:12px}.tm-title{font-weight:700;margin-bottom:6px}.tm-meta{color:var(--text-secondary);display:flex;font-size:13px;gap:12px;margin-bottom:8px}.tm-desc{color:var(--text-primary);margin:0}.task-form{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;margin-bottom:20px;padding:20px}.task-form h3{color:#333;margin-bottom:20px}.form-group{margin-bottom:15px}.form-group label{display:block;margin-bottom:5px}.form-row{grid-template-columns:1fr 1fr}.form-actions{border-top:1px solid #eee;justify-content:flex-end;margin-top:20px;padding-top:20px}@media (max-width:768px){.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column}.form-actions button{width:100%}}.document-manager{background:#fff;border-left:3px solid #667eea;border-radius:8px;margin-top:15px;padding:15px}.doc-header{align-items:center;display:flex;gap:10px;justify-content:space-between;margin-bottom:15px}.doc-header h4{color:#333;font-size:16px;margin:0}.btn-upload-toggle{align-items:center;background:#667eea;border:none;border-radius:5px;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:6px;padding:8px 12px;transition:background .3s ease}.btn-upload-toggle:hover{background:#5568d3}.upload-form-container{background:#f9f9f9;border-radius:6px;margin-bottom:15px;padding:12px}.upload-form{display:flex;flex-direction:column;gap:10px}.upload-form .form-group{display:flex;flex-direction:column;gap:5px}.upload-form label{color:#555;font-size:13px;font-weight:600}.upload-form input[type=file],.upload-form input[type=text]{border:1px solid #ddd;border-radius:4px;font-size:13px;padding:8px}.upload-form input[type=file]:focus,.upload-form input[type=text]:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea1a;outline:none}.upload-actions{display:flex;gap:8px;margin-top:5px}.btn-cancel,.btn-submit{border:none;border-radius:4px;cursor:pointer;font-size:13px;font-weight:600;padding:8px 12px;transition:all .3s ease}.btn-submit{background:#10b981;color:#fff;flex:1 1}.btn-submit:hover:not(:disabled){background:#059669}.btn-submit:disabled{background:#9ca3af;cursor:not-allowed}.btn-cancel{background:#e5e7eb;color:#333;flex:1 1}.btn-cancel:hover{background:#d1d5db}.documents-list{display:flex;flex-direction:column;gap:10px}.empty-message{color:#999;font-size:13px;margin:0;padding:10px;text-align:center}.document-item{align-items:center;background:#f9f9f9;border-left:2px solid #667eea;border-radius:6px;display:flex;gap:10px;justify-content:space-between;padding:10px}.doc-info{align-items:flex-start;display:flex;flex:1 1;gap:10px;min-width:0}.doc-icon{align-items:center;background:#e3f2fd;border-radius:4px;color:#1976d2;display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.doc-details{display:flex;flex-direction:column;gap:3px;min-width:0}.doc-name{color:#333;font-size:13px;font-weight:600;word-break:break-word}.doc-description{color:#666;font-size:12px;font-style:italic}.doc-meta{color:#999;font-size:11px}.doc-actions{display:flex;flex-shrink:0;gap:5px}.btn-doc-action{align-items:center;background:none;border:none;border-radius:3px;color:#667eea;cursor:pointer;display:flex;justify-content:center;padding:5px 8px;transition:all .3s ease}.btn-doc-action:hover{background:#667eea1a;color:#5568d3}.btn-doc-action.delete{color:#ef4444}.btn-doc-action.delete:hover{background:#ef44441a;color:#dc2626}@media (max-width:768px){.doc-header{align-items:stretch;flex-direction:column}.btn-upload-toggle{justify-content:center}.document-item{align-items:flex-start;flex-direction:column}.doc-actions{align-self:flex-end}}.task-card{background:#fff;border-left:4px solid #667eea;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:15px;transition:all .3s ease}.task-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-2px)}.task-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:10px}.task-header h4{color:#333;flex:1 1;margin:0}.priority{font-size:20px;margin-left:10px}.task-desc{color:#666;font-size:13px;line-height:1.4;margin:10px 0}.task-meta{display:flex;flex-wrap:wrap;gap:10px;margin:10px 0}.phase{background:#e3f2fd;color:#1976d2}.phase,.status{border-radius:15px;font-size:12px;font-weight:600;padding:4px 10px}.status{color:#fff}.contractor,.cost{color:#555;font-size:13px;margin:5px 0}.task-dates{color:#666;display:flex;flex-wrap:wrap;font-size:12px;gap:10px;margin:10px 0}.progress-bar{border-radius:10px;height:20px;margin:10px 0;position:relative}.progress-text{color:#fff;font-size:11px;font-weight:600;left:50%;position:absolute;text-shadow:0 1px 2px #0003;top:50%;transform:translate(-50%,-50%)}.task-actions{border-top:1px solid #f0f0f0;display:flex;gap:8px;margin-top:15px;padding-top:15px}.icon-btn{align-items:center;background:#f5f5f5;border:none;border-radius:5px;color:#666;cursor:pointer;display:flex;font-size:16px;padding:8px 12px;transition:all .3s ease}.icon-btn:hover{background:#667eea;color:#fff}.icon-btn.danger:hover{background:#ef4444}.icon-btn.success:hover{background:#10b981}@media (max-width:768px){.task-card{padding:12px}.task-header{flex-direction:column;gap:5px}.priority{align-self:flex-start}}.tasks-page{display:flex;flex-direction:column;gap:25px;width:100%}.tasks-header{align-items:center;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;margin-bottom:20px}.tasks-header h2{color:#333;flex-grow:1;font-size:28px;margin:0;min-width:200px}.filters-bar{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;box-sizing:border-box;flex-wrap:wrap;gap:15px;margin-bottom:20px;padding:15px;width:100%}.filter-group,.filters-bar{align-items:center;display:flex}.filter-group{flex-shrink:0;gap:8px}.filter-group label{color:#555;font-weight:600;white-space:nowrap}.filter-group select{background:#fff;border:1px solid #ddd;min-width:150px}.filter-group select,.task-count{border-radius:5px;padding:8px 12px}.task-count{background:#f0f4ff;color:#667eea;font-weight:600;margin-left:auto;white-space:nowrap}.tasks-container{display:flex;flex-direction:column;gap:25px;width:100%}.phase-section{background:#fff;border-radius:10px;box-shadow:0 2px 8px #00000014;padding:20px}.phase-title{border-bottom:2px solid #667eea;color:#333;font-size:18px;margin:0 0 20px;padding-bottom:10px}.tasks-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));width:100%}.empty-state{background:#fff;border-radius:10px;color:#999;font-size:18px;grid-column:1/-1;padding:40px;width:100%}@media (max-width:768px){.tasks-header{align-items:stretch;flex-direction:column}.tasks-header h2{min-width:auto}.tasks-header button{width:100%}.filters-bar{align-items:stretch;flex-direction:column}.filter-group{flex-direction:column;gap:5px;width:100%}.filter-group select{min-width:100%}.task-count{margin-left:0;text-align:center;width:100%}.tasks-grid{grid-template-columns:1fr}}.budget-page{display:flex;flex-direction:column;gap:25px;width:100%}.budget-page h2{color:#333;font-size:28px;margin:0 0 20px}.budget-page h3{color:#333;font-size:20px;margin:0 0 15px}.summary-cards{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:20px;width:100%}.summary-card{background:#fff;border-left:4px solid #667eea;border-radius:10px;box-shadow:0 2px 8px #0000001a;padding:20px}.card-label{color:#666;font-size:13px;font-weight:600;margin-bottom:8px}.card-value{color:#10b981;font-size:24px;font-weight:700;word-break:break-word}.card-detail{color:#999;font-size:12px;margin-top:5px}.budget-content{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));width:100%}.budget-display-section,.budget-form-section{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;padding:20px}.budget-display-section h3,.budget-form-section h3{margin-top:0}.expense-form{display:flex;flex-direction:column;gap:15px}.form-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.btn-add-expense{align-items:center;background:#10b981;border:none;border-radius:5px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:12px 20px;transition:all .3s ease}.btn-add-expense:hover{background:#059669;box-shadow:0 4px 12px #10b9814d}.categories-list{display:flex;flex-direction:column;gap:12px}.category-item{background:#f9f9f9;border-left:3px solid #667eea;border-radius:8px;justify-content:space-between;padding:12px}.category-info,.category-item{align-items:center;display:flex}.category-info{flex:1 1;gap:12px}.category-color{border-radius:3px;flex-shrink:0;height:16px;width:16px}.category-details{display:flex;flex-direction:column;gap:2px}.category-name{color:#333;font-size:14px;font-weight:600}.category-count{color:#999;font-size:12px}.category-amount{color:#10b981;font-size:16px;font-weight:700;min-width:80px;text-align:right}.expenses-section{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;padding:20px;width:100%}.expenses-list{display:flex;flex-direction:column;gap:12px}.expense-item{background:#f9f9f9;border-left:3px solid #667eea;border-radius:8px;padding:15px}.expense-header{align-items:flex-start;display:flex;gap:10px;justify-content:space-between;margin-bottom:10px}.expense-type{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.type-badge{border-radius:4px;white-space:nowrap}.task-ref{background:#e3f2fd;border-radius:4px;color:#1976d2;font-size:12px;padding:4px 10px}.btn-delete{background:none;color:#ef4444;padding:5px;transition:color .3s ease}.btn-delete:hover{color:#dc2626}.expense-desc{color:#555;font-size:13px;font-style:italic;margin:5px 0}.expense-footer{align-items:center;border-top:1px solid #e5e7eb;display:flex;font-size:13px;justify-content:space-between;padding-top:10px}.expense-date{color:#999}.expense-amount{color:#10b981;font-size:16px;font-weight:700}.empty-text{color:#999;font-size:14px;padding:20px;text-align:center}.card{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;padding:20px}.card h3{color:#333;font-size:18px;margin:0 0 15px}.btn{border:none;border-radius:5px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .3s ease}@media (max-width:768px){.budget-content,.form-row,.summary-cards{grid-template-columns:1fr}}.phases-page{display:flex;flex-direction:column;gap:25px;width:100%}.phases-header{align-items:center;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;margin-bottom:20px}.phases-header h2{color:#333;flex-grow:1;font-size:28px;margin:0;min-width:200px}.phase-form{margin-bottom:20px;width:100%}.phase-form .form-group{margin-bottom:15px}.phase-form .form-group label{color:#555;display:block;font-weight:600;margin-bottom:5px}.phase-form .form-group input,.phase-form .form-group textarea{border:1px solid #ddd;border-radius:5px;box-sizing:border-box;padding:10px;width:100%}.phases-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));width:100%}.phase-card{background:#fff;border-radius:10px;border-top:4px solid #667eea;box-shadow:0 2px 8px #0000001a;padding:20px;transition:all .3s ease}.phase-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-5px)}.phase-card h3{color:#333;font-size:18px;margin:0 0 20px}.phase-stats{border-bottom:1px solid #f0f0f0;border-top:1px solid #f0f0f0;display:flex;justify-content:space-around;margin-bottom:20px;padding:15px 0}.stat{flex:1 1;text-align:center}.stat-number{color:#667eea;font-size:24px;font-weight:700}.stat-name{color:#999;font-size:11px;margin-top:5px;text-transform:uppercase}.phase-progress{margin-top:20px;width:100%}.progress-bar{background:#e0e0e0;border-radius:4px;height:8px;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(90deg,#667eea,#764ba2);height:100%;transition:width .3s ease}@media (max-width:768px){.phases-header{align-items:stretch;flex-direction:column}.phases-header h2{min-width:auto}.phases-header button{width:100%}.phases-grid{grid-template-columns:1fr}.phase-form .form-group input,.phase-form .form-group textarea{font-size:16px}}.contacts-page{display:flex;flex-direction:column;gap:25px;width:100%}.contacts-header{align-items:center;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;margin-bottom:20px}.contacts-header h2{color:#333;flex-grow:1;font-size:28px;margin:0;min-width:200px}.contact-form-card{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;margin-bottom:20px;padding:25px;width:100%}.contact-form-card h3{color:#333;font-size:20px;margin:0 0 20px}.contact-form-card form{display:flex;flex-direction:column;gap:15px}.form-row{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));width:100%}.form-group{gap:5px;width:100%}.form-group label{color:#555}.form-group input,.form-group select,.form-group textarea{border:1px solid #ddd;border-radius:5px;box-sizing:border-box;font-family:inherit;font-size:14px;padding:10px 12px;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-actions{display:flex;gap:10px;margin-top:10px;width:100%}.btn-icon,.btn-primary,.btn-secondary{align-items:center;border:none;border-radius:5px;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .3s ease}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover{background:#5568d3;box-shadow:0 4px 12px #667eea4d}.btn-secondary{background:#e5e7eb;color:#333}.btn-secondary:hover{background:#d1d5db}.btn-icon{align-items:center;background:none;border:none;color:#667eea;cursor:pointer;display:flex;justify-content:center;padding:8px}.btn-icon:hover{color:#5568d3}.btn-danger{color:#ef4444}.btn-danger:hover{color:#dc2626}.contacts-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));width:100%}.contact-card{background:#fff;border-left:4px solid #667eea;border-radius:10px;box-shadow:0 2px 8px #0000001a;padding:20px;transition:all .3s ease}.contact-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-5px)}.contact-header{align-items:flex-start;display:flex;gap:10px;justify-content:space-between;margin-bottom:15px}.contact-header h3{color:#333;font-size:18px;margin:0}.type-badge{border-radius:12px;color:#fff;display:inline-block;font-size:12px;font-weight:600;margin-top:5px;padding:4px 10px}.contact-actions{display:flex;gap:5px}.contact-company{color:#667eea;font-size:14px;font-weight:600;margin:5px 0}.contact-speciality{color:#666;font-size:13px;margin:5px 0}.contact-info{border-bottom:1px solid #f0f0f0;border-top:1px solid #f0f0f0;display:flex;flex-direction:column;gap:8px;margin:15px 0;padding:15px 0}.info-item{align-items:center;color:#666;display:flex;font-size:13px;gap:10px}.info-item a{color:#667eea;text-decoration:none;word-break:break-all}.info-item a:hover{text-decoration:underline}.contact-notes{background:#f9f9f9;border-radius:5px;margin-top:10px;padding:10px}.contact-notes p{color:#666;font-size:13px;line-height:1.4;margin:0}.empty-state{color:#666;padding:60px 20px;text-align:center}.empty-state p{font-size:16px;margin:10px 0}.text-muted{color:#999;font-size:14px}.loading{color:#666;padding:40px;text-align:center}@media (max-width:768px){.contacts-header{align-items:stretch;flex-direction:column}.contacts-header h2{min-width:auto}.contacts-header button{width:100%}.contacts-grid,.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column}.form-actions button{width:100%}}.admin-page{background:var(--bg-primary);color:var(--text-primary);padding:30px 20px}.admin-page h2{color:var(--text-primary);font-size:28px;margin:0 0 30px}.admin-content{grid-gap:30px;display:grid;gap:30px;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1200px}.add-user-section{background:var(--bg-card)}.add-user-section h3{color:var(--text-primary);font-size:18px;margin-bottom:20px}.admin-form{display:flex;flex-direction:column;gap:15px}.form-group{gap:8px}.form-group input{border:1px solid var(--border-color);border-radius:8px;font-size:14px;padding:12px}.users-list-section{background:var(--bg-card)}.users-list-section h3{color:var(--text-primary);font-size:18px;margin-bottom:20px}.users-table{display:flex;flex-direction:column;gap:12px}.user-item{align-items:center;background:var(--bg-hover);border:1px solid var(--border-color);border-radius:8px;display:flex;justify-content:space-between;padding:15px;transition:all .3s ease}.user-item:hover{background:var(--bg-selected);border-color:var(--primary-color)}.user-info{flex:1 1}.user-name{color:var(--text-primary);font-weight:600}.user-email,.user-name{align-items:center;display:flex;gap:8px;margin-bottom:6px}.user-email{color:var(--text-secondary);font-size:13px}.user-admin-badge{align-items:center;background:#10b9811a;border-radius:4px;color:#10b981;display:flex;font-size:12px;font-weight:600;gap:6px;padding:4px 8px;width:-webkit-fit-content;width:fit-content}.user-actions{display:flex;gap:8px}.btn-delete{align-items:center;background:var(--danger-color);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:16px;gap:6px;padding:8px 12px;transition:all .3s ease}.btn-delete:hover{background:#dc2626;transform:scale(1.05)}.btn-admin{align-items:center;background:var(--border-color);border:2px solid var(--border-color);border-radius:6px;color:var(--text-primary);cursor:pointer;display:flex;font-size:16px;gap:6px;padding:8px 12px;transition:all .3s ease}.btn-admin:hover{background:#10b9811a;border-color:#10b981;color:#10b981}.btn-admin-active{background:#10b98133;border-color:#10b981;color:#10b981}.alert{border-left:4px solid;border-radius:8px;font-size:14px;margin-bottom:15px;padding:12px 16px}.alert-error{background:#fee2e2;border-left-color:#dc2626;color:#991b1b}.alert-success{background:#dcfce7;border-left-color:#10b981;color:#166534}.empty-text,.loading-text{color:var(--text-secondary);font-size:14px;padding:30px 20px;text-align:center}@media (prefers-color-scheme:dark){.alert-error{background:#1f2937;border-left-color:#ef4444;color:#fca5a5}.alert-success{background:#1f2937;border-left-color:#10b981;color:#86efac}}@media (max-width:768px){.admin-content{grid-template-columns:1fr}.admin-page h2{font-size:22px}}.auth-container{align-items:center;background:linear-gradient(135deg,var(--primary-color) 0,#8b5cf6 100%);display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;justify-content:center;min-height:100vh;padding:20px}.auth-card{animation:slideUp .6s cubic-bezier(.4,0,.2,1);background:var(--bg-card);border-radius:20px;box-shadow:0 20px 60px #0003;max-width:420px;padding:40px;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.auth-header{margin-bottom:30px;text-align:center}.auth-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--primary-color) 0,#8b5cf6 100%);-webkit-background-clip:text;background-clip:text;color:var(--text-primary);font-size:28px;margin:0 0 8px}.auth-header p{color:var(--text-secondary);font-size:14px;margin:0}.auth-form{gap:20px}.auth-form,.form-group{display:flex;flex-direction:column}.form-group label{color:var(--text-primary);font-size:14px;font-weight:600;margin-bottom:8px}.form-group input{background:var(--bg-input);border:2px solid var(--border-color);border-radius:12px;color:var(--text-primary);font-size:15px;padding:12px 16px;transition:all .3s cubic-bezier(.4,0,.2,1)}.form-group input::placeholder{color:var(--text-secondary)}.form-group input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #667eea1a;outline:none}.auth-error{animation:shake .5s ease;background:#fee2e2;border-left:4px solid #dc2626;border-radius:12px;color:#991b1b;font-size:14px;padding:12px 16px}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-10px)}75%{transform:translateX(10px)}}.btn-auth{background:linear-gradient(135deg,var(--primary-color) 0,#8b5cf6 100%);border:none;border-radius:12px;box-shadow:0 4px 12px #667eea4d;color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:12px 20px;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-auth:hover:not(:disabled){box-shadow:0 8px 20px #667eea66;transform:translateY(-2px)}.btn-auth:active:not(:disabled){transform:translateY(0)}.btn-auth:disabled{cursor:not-allowed;opacity:.6}.btn-link{background:none;border:none;color:var(--primary-color);cursor:pointer;font-weight:600;padding:0;text-decoration:none;transition:color .3s ease}.btn-link:hover{color:#8b5cf6;text-decoration:underline}.auth-footer{color:var(--text-secondary);font-size:14px;margin-top:20px;text-align:center}.auth-footer p{margin:0}.auth-demo{border-top:1px solid var(--border-color);margin-top:30px;padding-top:30px;text-align:center}.demo-title{color:var(--text-secondary);font-size:13px;font-weight:600;margin:0 0 10px}.auth-demo code{background:var(--bg-hover);border-radius:8px;color:var(--primary-color);display:block;font-size:12px;padding:8px 12px;word-break:break-all}@media (prefers-color-scheme:dark){.auth-container{background:linear-gradient(135deg,#2d3748,#1a202c)}.auth-error{background:#1f2937;border-left-color:#ef4444;color:#fca5a5}}@media (max-width:480px){.auth-card{padding:30px 20px}.auth-header h1{font-size:24px}}
/*# sourceMappingURL=main.baf02daf.css.map*/