:root{--primary: #4f46e5;--primary-dark: #4338ca;--primary-light: #eef2ff;--primary-text: #4338ca;--sidebar-bg: #0f172a;--sidebar-hover: #1e293b;--sidebar-border: #1e293b;--sidebar-text: #94a3b8;--sidebar-text-active: #ffffff;--bg: #f8fafc;--white: #ffffff;--border: #e2e8f0;--border-light: #f1f5f9;--text: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--radius-sm: 6px;--radius: 10px;--radius-lg: 14px;--radius-xl: 18px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .05);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .08);--shadow-xl: 0 20px 40px rgba(0, 0, 0, .12)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}button{cursor:pointer;border:none;background:none;font-family:inherit}input,select,textarea{font-family:inherit}a{text-decoration:none;color:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px}.app-layout{display:flex;height:100vh;overflow:hidden}.main-area{display:flex;flex-direction:column;flex:1;min-width:0;overflow:hidden}.page-content{flex:1;overflow-y:auto;padding:24px}.sidebar{width:240px;background:var(--sidebar-bg);display:flex;flex-direction:column;flex-shrink:0}.sidebar-header{display:flex;align-items:center;gap:10px;padding:18px 20px;border-bottom:1px solid var(--sidebar-border)}.sidebar-logo{width:36px;height:36px;object-fit:contain;flex-shrink:0}.sidebar-brand-name{font-size:15px;font-weight:700;color:#fff;line-height:1.2}.sidebar-brand-sub{font-size:11px;color:var(--sidebar-text)}.sidebar-nav{flex:1;padding:12px 10px;display:flex;flex-direction:column;gap:2px}.sidebar-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius);font-size:13.5px;font-weight:500;color:var(--sidebar-text);transition:background .15s,color .15s}.sidebar-link:hover{background:var(--sidebar-hover);color:#fff}.sidebar-link.active{background:var(--primary);color:#fff}.sidebar-footer{padding:12px 10px;border-top:1px solid var(--sidebar-border)}.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px 12px;margin-bottom:4px}.sidebar-avatar{width:32px;height:32px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:700;flex-shrink:0}.sidebar-user-name{font-size:13px;font-weight:500;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:11px;color:var(--sidebar-text)}.sidebar-logout{display:flex;align-items:center;gap:10px;width:100%;padding:8px 12px;border-radius:var(--radius);font-size:13.5px;color:var(--sidebar-text);transition:background .15s,color .15s}.sidebar-logout:hover{background:var(--sidebar-hover);color:#fff}.top-header{height:56px;background:var(--white);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;flex-shrink:0}.top-header h1{font-size:17px;font-weight:600;color:var(--text)}.btn{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border-radius:var(--radius);font-size:13.5px;font-weight:500;transition:background .15s,opacity .15s;flex-shrink:0}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-secondary{background:#f1f5f9;color:var(--text-secondary)}.btn-secondary:hover:not(:disabled){background:#e2e8f0}.btn-ghost-edit{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:var(--radius-sm);color:var(--text-muted);transition:background .15s,color .15s}.btn-ghost-edit:hover{background:var(--primary-light);color:var(--primary)}.btn-ghost-delete{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:var(--radius-sm);color:var(--text-muted);transition:background .15s,color .15s}.btn-ghost-delete:hover:not(:disabled){background:#fee2e2;color:#dc2626}.btn-ghost-delete:disabled{opacity:.3;cursor:not-allowed}.btn-text{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:var(--primary);padding:4px 0;transition:color .15s}.btn-text:hover{color:var(--primary-dark)}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:100px;font-size:11.5px;font-weight:500;white-space:nowrap}.badge-new{background:#e0f2fe;color:#0369a1}.badge-assigned{background:#fef9c3;color:#854d0e}.badge-in-progress{background:#ffedd5;color:#9a3412}.badge-completed{background:#dcfce7;color:#166534}.badge-cancelled{background:#fee2e2;color:#991b1b}.badge-low{background:#f1f5f9;color:#475569}.badge-medium{background:#dbeafe;color:#1d4ed8}.badge-high{background:#ffedd5;color:#9a3412}.badge-urgent{background:#fee2e2;color:#991b1b}.badge-master-active{background:#dcfce7;color:#166534}.badge-master-vacation{background:#fef9c3;color:#854d0e}.badge-master-fired{background:#fee2e2;color:#991b1b}.badge-brigade-active{background:#dcfce7;color:#166534}.badge-brigade-inactive{background:#f1f5f9;color:#64748b}.badge-role-admin{background:#f3e8ff;color:#7e22ce}.badge-role-manager{background:#dbeafe;color:#1d4ed8}.badge-role-master{background:#ccfbf1;color:#0f766e}.form-field{display:flex;flex-direction:column;gap:5px}.form-label{font-size:13px;font-weight:500;color:var(--text-secondary)}.form-input,.form-select,.form-textarea{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:13.5px;color:var(--text);background:var(--white);outline:none;transition:border-color .15s,box-shadow .15s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.form-textarea{resize:none}.form-error{font-size:12px;color:#dc2626}.form-section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding-top:6px}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-actions{display:flex;justify-content:flex-end;gap:10px;padding-top:16px;margin-top:8px;border-top:1px solid var(--border-light)}.panel{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.panel-header{padding:14px 20px;border-bottom:1px solid var(--border-light)}.panel-header h3{font-size:14.5px;font-weight:600;color:var(--text)}.table-wrap{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:13.5px}.data-table thead tr{background:#f8fafc;border-bottom:1px solid var(--border-light)}.data-table thead th{padding:10px 18px;text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);white-space:nowrap}.data-table tbody tr{border-bottom:1px solid var(--border-light);transition:background .1s}.data-table tbody tr:last-child{border-bottom:none}.data-table tbody tr:hover{background:#f8fafc}.data-table tbody tr.clickable{cursor:pointer}.data-table td{padding:12px 18px;color:var(--text-secondary);vertical-align:middle}.data-table td .cell-primary{font-weight:500;color:var(--text);margin-bottom:2px}.data-table td .cell-secondary{font-size:12px;color:var(--text-muted)}.data-table td .cell-mono{font-family:SF Mono,Fira Code,monospace;font-size:12px;color:var(--text-muted)}.table-actions{display:flex;align-items:center;gap:4px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:50;display:flex;align-items:flex-start;justify-content:center;padding:60px 16px 16px}.modal{position:relative;background:var(--white);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;display:flex;flex-direction:column;max-height:85vh}.modal-sm{max-width:420px}.modal-md{max-width:560px}.modal-lg{max-width:680px}.modal-xl{max-width:860px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 22px;border-bottom:1px solid var(--border-light);flex-shrink:0}.modal-header h2{font-size:16px;font-weight:600;color:var(--text)}.modal-close{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:var(--radius-sm);color:var(--text-muted);transition:background .15s,color .15s}.modal-close:hover{background:#f1f5f9;color:var(--text)}.modal-body{overflow-y:auto;flex:1;padding:20px 22px;display:flex;flex-direction:column;gap:14px}.spinner{border-radius:50%;border:2px solid var(--border);border-top-color:var(--primary);animation:spin .7s linear infinite}.spinner-sm{width:16px;height:16px}.spinner-md{width:24px;height:24px}.spinner-lg{width:40px;height:40px;border-width:3px}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{display:flex;align-items:center;justify-content:center;height:180px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;text-align:center}.empty-state-icon{width:56px;height:56px;background:#f1f5f9;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:var(--text-muted);margin-bottom:14px}.empty-state-title{font-size:14.5px;font-weight:500;color:var(--text-secondary);margin-bottom:4px}.empty-state-desc{font-size:13px;color:var(--text-muted)}.pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-top:1px solid var(--border-light)}.pagination-info{font-size:12.5px;color:var(--text-muted)}.pagination-controls{display:flex;align-items:center;gap:8px}.pagination-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text-secondary);transition:background .15s}.pagination-btn:hover:not(:disabled){background:#f1f5f9}.pagination-btn:disabled{opacity:.35;cursor:not-allowed}.pagination-label{font-size:13px;color:var(--text-secondary)}.page-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.search-box{position:relative;flex:1;max-width:320px}.search-box svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.search-box input{width:100%;padding:8px 12px 8px 34px;border:1px solid var(--border);border-radius:var(--radius);font-size:13.5px;color:var(--text);background:var(--white);outline:none;transition:border-color .15s,box-shadow .15s}.search-box input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.filter-icon{color:var(--text-muted);flex-shrink:0}.filter-select{padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:13.5px;color:var(--text);background:var(--white);outline:none;cursor:pointer;transition:border-color .15s}.filter-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.login-page{min-height:100vh;background:linear-gradient(135deg,#0f172a,#1e293b);display:flex;align-items:center;justify-content:center;padding:16px}.login-container{width:100%;max-width:400px}.login-logo{text-align:center;margin-bottom:28px}.login-logo-img{display:block;width:72px;height:72px;object-fit:contain;margin:0 auto 12px}.login-logo h1{font-size:22px;font-weight:700;color:#fff;margin-bottom:4px}.login-logo p{font-size:13px;color:#94a3b8}.login-box{background:var(--white);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:32px}.login-box h2{font-size:18px;font-weight:600;color:var(--text);margin-bottom:22px}.login-form{display:flex;flex-direction:column;gap:16px}.password-input-wrap{position:relative}.password-input-wrap input{width:100%;padding-right:40px}.password-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);display:flex;align-items:center;transition:color .15s}.password-toggle:hover{color:var(--text-secondary)}.page-stack{display:flex;flex-direction:column;gap:20px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}@media (max-width: 1100px){.stats-grid{grid-template-columns:repeat(2,1fr)}}.stat-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;display:flex;align-items:center;gap:14px}.stat-card-icon{width:44px;height:44px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.icon-indigo{background:#4f46e5}.icon-orange{background:#ea580c}.icon-green{background:#16a34a}.icon-sky{background:#0284c7}.icon-violet{background:#7c3aed}.icon-teal{background:#0d9488}.stat-card-value{font-size:24px;font-weight:700;color:var(--text);line-height:1;margin-bottom:3px}.stat-card-label{font-size:12.5px;color:var(--text-muted)}.charts-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}@media (max-width: 900px){.charts-row{grid-template-columns:1fr}}.chart-list{display:flex;flex-direction:column;gap:12px;padding:16px 20px}.chart-row{display:flex;flex-direction:column;gap:5px}.chart-row-label{display:flex;justify-content:space-between;font-size:13px}.chart-row-label span:first-child{color:var(--text-secondary)}.chart-row-label span:last-child{font-weight:500;color:var(--text)}.progress-bar{height:6px;background:#f1f5f9;border-radius:100px;overflow:hidden}.progress-fill{height:100%;background:var(--primary);border-radius:100px;transition:width .4s ease}.service-list{display:flex;flex-direction:column;padding:8px 0}.service-row{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;border-bottom:1px solid var(--border-light);font-size:13.5px}.service-row:last-child{border-bottom:none}.service-row span:first-child{color:var(--text-secondary)}.service-row span:last-child{font-weight:600;color:var(--text)}.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}@media (max-width: 1100px){.cards-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 700px){.cards-grid{grid-template-columns:1fr}}.brigade-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;display:flex;flex-direction:column;gap:12px}.brigade-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.brigade-card-title{font-size:14.5px;font-weight:600;color:var(--text)}.brigade-card-desc{font-size:12px;color:var(--text-muted);margin-top:2px}.brigade-card-capacity{font-size:13px;color:var(--text-secondary)}.brigade-card-capacity strong{color:var(--text)}.masters-label{font-size:12px;color:var(--text-muted);margin-bottom:6px}.masters-tags{display:flex;flex-wrap:wrap;gap:5px}.master-tag{background:#f1f5f9;color:var(--text-secondary);font-size:12px;padding:3px 9px;border-radius:var(--radius-sm)}.no-masters{font-size:12px;color:var(--text-muted);font-style:italic}.card-actions{display:flex;align-items:center;gap:4px;padding-top:8px;border-top:1px solid var(--border-light);margin-top:auto}.card-action-btn{display:flex;align-items:center;gap:5px;padding:5px 9px;border-radius:var(--radius-sm);font-size:12px;color:var(--text-muted);transition:background .15s,color .15s}.card-action-btn:hover{background:#f1f5f9;color:var(--text-secondary)}.card-action-btn.danger:hover{background:#fee2e2;color:#dc2626}.card-action-btn.ml-auto{margin-left:auto}.checkbox-list{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;max-height:200px;overflow-y:auto}.checkbox-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border-light);cursor:pointer;transition:background .1s}.checkbox-item:last-child{border-bottom:none}.checkbox-item:hover{background:#f8fafc}.checkbox-item input[type=checkbox]{width:15px;height:15px;accent-color:var(--primary);cursor:pointer}.checkbox-item-name{font-size:13.5px;font-weight:500;color:var(--text)}.checkbox-item-sub{font-size:12px;color:var(--text-muted)}.spec-tags{display:flex;flex-wrap:wrap;gap:7px}.spec-tag{padding:5px 12px;border-radius:var(--radius);font-size:12.5px;font-weight:500;border:1px solid var(--border);color:var(--text-secondary);background:var(--white);cursor:pointer;transition:background .15s,border-color .15s,color .15s}.spec-tag.selected{background:var(--primary);border-color:var(--primary);color:#fff}.spec-in-table{display:inline-block;background:var(--primary-light);color:var(--primary-text);font-size:11.5px;padding:2px 8px;border-radius:var(--radius-sm)}.date-list{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;max-height:260px;overflow-y:auto}.date-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border-light);cursor:pointer;transition:background .1s;width:100%;text-align:left;background:none;border-left:none;border-right:none;border-top:none}.date-item:last-child{border-bottom:none}.date-item:hover:not(.date-item-disabled){background:#f8fafc}.date-item.date-item-selected{background:var(--primary-light);border-left:2px solid var(--primary)}.date-item.date-item-disabled{opacity:.4;cursor:not-allowed;background:#f8fafc}.date-item-left{display:flex;align-items:center;gap:10px}.date-radio{width:15px;height:15px;border-radius:50%;border:2px solid var(--border);flex-shrink:0}.date-radio.checked{background:var(--primary);border-color:var(--primary);box-shadow:inset 0 0 0 3px #fff}.date-day-name{font-size:13.5px;font-weight:500;color:var(--text)}.date-day-name span{font-size:12px;font-weight:400;color:var(--text-muted);margin-left:6px;text-transform:capitalize}.date-status-badge{font-size:11.5px;font-weight:500;padding:3px 9px;border-radius:var(--radius-sm)}.date-status-free{background:#dcfce7;color:#166534}.date-status-partial{background:#fef9c3;color:#854d0e}.date-status-full{background:#fee2e2;color:#991b1b}.date-selected-info{font-size:12.5px;color:var(--primary-text);font-weight:500}.detail-badges{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.detail-row{display:flex;align-items:flex-start;gap:10px}.detail-row-icon{width:30px;height:30px;background:#f1f5f9;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--text-muted);flex-shrink:0}.detail-row-label{font-size:11.5px;color:var(--text-muted);margin-bottom:2px}.detail-row-value{font-size:13.5px;font-weight:500;color:var(--text)}.brigade-info-box{background:#f8fafc;border-radius:var(--radius);padding:12px 14px}.brigade-info-box .detail-row-label{margin-bottom:4px}.brigade-info-box .detail-row-value{font-size:14px}.description-block .detail-row-label{margin-bottom:4px}.description-text{font-size:13.5px;color:var(--text-secondary);line-height:1.6}.history-list{display:flex;flex-direction:column;gap:8px;max-height:160px;overflow-y:auto}.history-item{display:flex;align-items:flex-start;gap:8px;font-size:12.5px}.history-dot{width:6px;height:6px;border-radius:50%;background:var(--primary);margin-top:5px;flex-shrink:0}.history-text{color:var(--text-secondary)}.history-who{font-weight:500;color:var(--text)}.history-time{color:var(--text-muted);margin-left:4px}.profile-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px}.profile-top{display:flex;align-items:flex-start;gap:18px}.profile-avatar{width:60px;height:60px;border-radius:var(--radius-lg);background:var(--primary);display:flex;align-items:center;justify-content:center;color:#fff;font-size:22px;font-weight:700;flex-shrink:0}.profile-name-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:3px}.profile-name{font-size:20px;font-weight:700;color:var(--text)}.profile-username{font-size:13.5px;color:var(--text-muted);font-family:SF Mono,Fira Code,monospace;margin-bottom:12px}.profile-meta{display:flex;flex-wrap:wrap;gap:14px;margin-top:10px}.profile-meta-item{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary)}.profile-specs{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}.profile-spec-tag{background:var(--primary-light);color:var(--primary-text);font-size:12px;font-weight:500;padding:4px 11px;border-radius:var(--radius)}.user-avatar-sm{width:32px;height:32px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:700;flex-shrink:0}.user-cell{display:flex;align-items:center;gap:10px}.you-badge{font-size:11px;background:#f1f5f9;color:var(--text-muted);padding:2px 7px;border-radius:var(--radius-sm)}
