@charset "UTF-8";.role-management .page-header{margin-bottom:2rem}.role-management .page-header h1{color:#2c3e50;margin-bottom:.5rem;font-size:2rem;font-weight:600}.role-management .page-header p{color:#7f8c8d;font-size:1rem;margin:0}.role-management .permissions-table-container{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;overflow:hidden;border:1px solid #e9ecef}.role-management .permissions-table{width:100%;border-collapse:collapse;font-size:.9rem}.role-management .permissions-table th,.role-management .permissions-table td{padding:1rem .75rem;text-align:left;border-bottom:1px solid #e9ecef}.role-management .permissions-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.role-management .permissions-table thead th{font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:none}.role-management .permissions-table thead .module-header{width:200px;min-width:200px}.role-management .permissions-table thead .role-header{text-align:center;min-width:120px}.role-management .permissions-table thead .role-header .role-info .role-name{font-size:.9rem;font-weight:600;margin-bottom:.25rem}.role-management .permissions-table thead .role-header .role-info .role-code{font-size:.75rem;opacity:.8;font-weight:400}.role-management .permissions-table tbody .module-row{background:#f8f9fa}.role-management .permissions-table tbody .module-row .module-name{font-weight:600;color:#495057;font-size:1rem;padding:.75rem 1rem;border-bottom:1px solid #dee2e6}.role-management .permissions-table tbody .permission-row{transition:background-color .2s ease}.role-management .permissions-table tbody .permission-row:hover{background-color:#f8f9fa}.role-management .permissions-table tbody .permission-row .permission-name{font-weight:500;color:#6c757d;padding-left:2rem;position:relative}.role-management .permissions-table tbody .permission-row .permission-name:before{content:"•";position:absolute;left:1rem;color:#adb5bd}.role-management .permissions-table tbody .permission-row .permission-cell{text-align:center;padding:.75rem}.role-management .permission-checkbox{display:inline-flex;align-items:center;justify-content:center;cursor:pointer;position:relative}.role-management .permission-checkbox input[type=checkbox]{opacity:0;position:absolute;width:0;height:0}.role-management .permission-checkbox .checkmark{width:20px;height:20px;border:2px solid #dee2e6;border-radius:4px;background:#fff;display:flex;align-items:center;justify-content:center;transition:all .2s ease;position:relative}.role-management .permission-checkbox .checkmark:after{content:"✓";color:#fff;font-size:12px;font-weight:700;opacity:0;transform:scale(.5);transition:all .2s ease}.role-management .permission-checkbox input[type=checkbox]:checked+.checkmark{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea}.role-management .permission-checkbox input[type=checkbox]:checked+.checkmark:after{opacity:1;transform:scale(1)}.role-management .permission-checkbox input[type=checkbox]:disabled+.checkmark{opacity:.5;cursor:not-allowed}.role-management .permission-checkbox:hover input[type=checkbox]:not(:disabled)+.checkmark{border-color:#667eea;transform:scale(1.05)}.role-management .saving-indicator{position:fixed;bottom:2rem;right:2rem;background:#fff;padding:1rem 1.5rem;border-radius:8px;box-shadow:0 4px 20px #00000026;display:flex;align-items:center;gap:.75rem;border:1px solid #e9ecef;z-index:1000}.role-management .saving-indicator .saving-spinner{width:20px;height:20px;border:2px solid #f3f3f3;border-top:2px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}.role-management .saving-indicator span{color:#495057;font-weight:500;font-size:.9rem}.role-management .access-denied{text-align:center;padding:4rem 2rem;background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;border:1px solid #e9ecef}.role-management .access-denied h2{color:#e74c3c;margin-bottom:1rem;font-size:1.5rem}.role-management .access-denied p{color:#7f8c8d;font-size:1rem;margin:0}.role-management .loading-container{text-align:center;padding:4rem 2rem}.role-management .loading-container .loading-spinner{color:#667eea;font-size:1.1rem;font-weight:500}@media (max-width: 768px){.role-management .permissions-table-container{overflow-x:auto}.role-management .permissions-table{min-width:600px;font-size:.8rem}.role-management .permissions-table th,.role-management .permissions-table td{padding:.75rem .5rem}.role-management .permissions-table .permission-name{padding-left:1.5rem}.role-management .permissions-table .permission-name:before{left:.75rem}.role-management .saving-indicator{bottom:1rem;right:1rem;padding:.75rem 1rem}.role-management .saving-indicator span{font-size:.8rem}}.models-grid.cards-v2{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;padding:16px 0}@media (max-width: 768px){.models-grid.cards-v2{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px;padding:12px 0}}@media (max-width: 480px){.models-grid.cards-v2{grid-template-columns:1fr 1fr;gap:8px}}.model-card.v2{display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px;border:1px solid rgba(0,0,0,.08);border-radius:12px;background:#fff;cursor:pointer;text-align:center;transition:transform .2s,box-shadow .2s;height:320px;min-height:320px;max-height:320px;width:100%;box-sizing:border-box}.model-card.v2:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000001a}@media (max-width: 768px){.model-card.v2{padding:16px;gap:10px;height:280px;min-height:280px;max-height:280px}}@media (max-width: 480px){.model-card.v2{padding:12px;gap:8px;height:260px;min-height:260px;max-height:260px}}.model-card-avatar{width:120px;height:120px;border-radius:50%;overflow:hidden;background:#f3f4f6;display:grid;place-items:center}@media (max-width: 768px){.model-card-avatar{width:100px;height:100px}}@media (max-width: 480px){.model-card-avatar{width:80px;height:80px}}.model-card-avatar img{width:100%;height:100%;object-fit:cover}.model-card .avatar-fallback{font-weight:600;color:#6b7280;font-size:28px}.model-card-name{font-size:15px;font-weight:700;color:#111827;margin-top:8px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;line-height:1.3;height:2.6em;min-height:2.6em;max-height:2.6em;width:100%;word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}@media (max-width: 768px){.model-card-name{font-size:14px;height:2.4em;min-height:2.4em;max-height:2.4em}}@media (max-width: 480px){.model-card-name{font-size:13px;line-height:1.2;height:2.4em;min-height:2.4em;max-height:2.4em}}.model-card-line{display:flex;align-items:center;gap:8px;color:#374151;font-size:14px;height:20px;min-height:20px;flex-shrink:0}@media (max-width: 768px){.model-card-line{font-size:13px;gap:6px;height:18px;min-height:18px}}@media (max-width: 480px){.model-card-line{font-size:12px;gap:4px;height:16px;min-height:16px}}.model-card-line .icon{opacity:.7}.model-card-preview{width:60px;height:60px;border-radius:8px;overflow:hidden;background:#f5f5f5;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s}.model-card-preview:hover{transform:scale(1.05)}.model-card-preview img{width:100%;height:100%;object-fit:cover}.model-profile-modal .modal-content.model-profile{max-width:95vw;width:1200px;max-height:90vh;overflow-y:auto}@media (max-width: 1280px){.model-profile-modal .modal-content.model-profile{max-width:90vw;width:100%}}@media (max-width: 768px){.model-profile-modal .modal-content.model-profile{max-width:95vw;width:100%;max-height:95vh;margin:10px}}.model-profile .profile-header{display:flex;align-items:center;gap:16px;margin-bottom:16px;flex-wrap:wrap}.model-profile .profile-header .avatar{width:96px;height:96px;border-radius:999px;overflow:hidden;background:#f3f4f6;display:grid;place-items:center;flex-shrink:0}.model-profile .profile-header .avatar img{width:100%;height:100%;object-fit:cover}.model-profile .profile-header .avatar-fallback{font-size:28px;font-weight:600;color:#6b7280}.model-profile .profile-header .names .full{font-size:20px;font-weight:700;line-height:1.2}.model-profile .profile-header .names .short{color:#6b7280;margin-top:4px}.model-profile .profile-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-top:16px}.model-profile .profile-columns{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}@media (max-width: 1024px){.model-profile .profile-columns{grid-template-columns:1fr;gap:16px}}@media (max-width: 768px){.model-profile .profile-header{flex-direction:column;text-align:center;gap:12px}.model-profile .profile-columns{gap:12px}}.model-profile .section{background:#fff;border:1px solid var(--border, rgba(0, 0, 0, .08));border-radius:12px;padding:16px;position:relative}.model-profile .section-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.model-profile .section-title{font-weight:700;font-size:16px}.model-profile .info-row{display:grid;grid-template-columns:180px 1fr;gap:12px;align-items:center;padding:10px 0;border-bottom:1px dashed rgba(0,0,0,.06)}@media (max-width: 768px){.model-profile .info-row{grid-template-columns:1fr;gap:4px;text-align:left}.model-profile .info-row .label{font-size:12px;font-weight:600;text-transform:uppercase}}.model-profile .info-row .label{color:#6b7280}.model-profile .info-row .value{color:#111827;font-weight:500}.model-profile .actions{display:flex;align-items:center;gap:8px;margin-top:16px}.model-profile .comments{display:flex;flex-direction:column;gap:8px}.model-profile .comments-list{max-height:260px;overflow:auto;display:flex;flex-direction:column;gap:8px}.model-profile .comment{background:#f9fafb;border:1px solid rgba(0,0,0,.06);border-radius:8px;padding:8px}.model-profile .comment .time{font-size:12px;color:#6b7280;margin-bottom:4px}.model-profile .comments-add{display:flex;gap:8px}.model-profile .comments-add input{flex:1}.model-profile .files-list{display:flex;flex-direction:column;gap:10px;max-height:420px;overflow:auto}.model-profile .file-row{display:flex;gap:12px;align-items:flex-start;padding:8px;border:1px solid rgba(0,0,0,.06);border-radius:8px;background:#fff}.model-profile .file-row .preview{width:80px;height:60px;overflow:hidden;border-radius:6px;background:#f3f4f6;display:grid;place-items:center;flex-shrink:0}.model-profile .file-row .preview img{width:100%;height:100%;object-fit:cover}.model-profile .file-row .meta{flex:1;display:flex;flex-direction:column;gap:6px;min-width:0}.model-profile .file-row .name{font-weight:600;font-size:12px;word-break:break-all}.model-profile .file-row .controls{display:flex;gap:4px;flex-wrap:wrap}.model-profile .file-row .controls .btn{font-size:11px;padding:4px 8px}.model-profile .muted{color:#6b7280}.model-profile .status-log{max-height:260px;overflow:auto;display:flex;flex-direction:column;gap:6px}.model-profile .log-row{display:grid;grid-template-columns:180px 1fr;gap:8px;font-size:13px}.model-profile .log-time{color:#6b7280}.layout{min-height:100vh;display:flex;flex-direction:column}.header{background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:100}.header-content{display:flex;align-items:center;justify-content:space-between;padding:16px 0}@media (max-width: 768px){.header-content{padding:12px 0;flex-wrap:wrap;gap:12px}}.logo{font-size:24px;font-weight:700;background:linear-gradient(135deg,var(--primary),var(--secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}@media (max-width: 768px){.logo{font-size:20px}}@media (max-width: 480px){.logo{font-size:18px}}.nav{display:flex;gap:32px}@media (max-width: 768px){.nav{gap:20px}}@media (max-width: 480px){.nav{gap:16px;flex-wrap:wrap}}.nav-link{color:var(--text-secondary);text-decoration:none;font-weight:500;position:relative;transition:var(--transition)}@media (max-width: 768px){.nav-link{font-size:14px}}@media (max-width: 480px){.nav-link{font-size:13px}}.nav-link:hover{color:var(--text-primary)}.nav-link.active{color:var(--primary)}.nav-link.active:after{content:"";position:absolute;bottom:-20px;left:0;right:0;height:2px;background:var(--primary)}@media (max-width: 768px){.nav-link.active:after{bottom:-16px}}.header-user{display:flex;align-items:center;gap:16px}.header-user .username{font-weight:500;color:var(--text-primary)}.main{flex:1;padding:32px 0}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.page-header h2{font-size:32px;font-weight:700}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2)}.login-card{width:100%;max-width:400px;padding:48px}.login-card .login-title{text-align:center;margin-bottom:32px;font-size:36px;font-weight:700;background:linear-gradient(135deg,var(--primary),var(--secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.models-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}.model-card .model-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.model-card .model-header h3{font-size:20px;font-weight:600}.model-card .model-fullname{color:var(--text-secondary);margin-bottom:12px}.model-card .model-contacts{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;font-size:14px;color:var(--text-secondary)}.model-card .model-notes{padding:12px;background:var(--light);border-radius:8px;margin-bottom:16px;font-size:14px}.model-card .model-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.model-card .model-tags .tag{padding:4px 12px;background:var(--primary);color:#fff;border-radius:20px;font-size:12px;font-weight:500}.model-card .model-files{margin-bottom:16px;font-size:14px;color:var(--text-secondary)}.model-card .model-actions{display:flex;gap:8px;flex-wrap:wrap}.slots-calendar{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}.slot-card .slot-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.slot-card .slot-datetime{display:flex;flex-direction:column;gap:4px}.slot-card .slot-datetime .slot-date{font-weight:600;font-size:16px}.slot-card .slot-datetime .slot-time{color:var(--text-secondary);font-size:14px}.slot-card .slot-model,.slot-card .slot-notes{padding:12px;background:var(--light);border-radius:8px;margin-bottom:16px;font-size:14px}.slot-card .slot-files{margin-bottom:16px;font-size:14px;color:var(--text-secondary)}.slot-card .slot-actions{display:flex;gap:8px;flex-wrap:wrap}.slot-card .slot-actions select{padding:6px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text-primary);font-size:14px;cursor:pointer}.audit-filters{margin-bottom:24px}.audit-filters .filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;align-items:end}.audit-page .entity-id{font-family:monospace;font-size:12px}.audit-page .user-agent{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.audit-page details summary{cursor:pointer;color:var(--primary);font-size:14px}.audit-page details summary:hover{text-decoration:underline}.audit-page details pre{margin-top:8px;padding:8px;background:var(--light);border-radius:4px;font-size:12px;overflow-x:auto}.file-upload-modal{position:fixed;bottom:20px;right:20px;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:20px;z-index:200}.file-upload-content .dropzone{border:2px dashed var(--border);border-radius:var(--radius);padding:40px;text-align:center;cursor:pointer;transition:var(--transition);margin-bottom:16px}.file-upload-content .dropzone:hover{border-color:var(--primary);background:var(--light)}.file-upload-content .dropzone p{color:var(--text-secondary)}.slots-layout{display:grid;grid-template-columns:320px 1fr;gap:24px}@media (max-width: 1024px){.slots-layout{grid-template-columns:280px 1fr;gap:16px}}@media (max-width: 768px){.slots-layout{grid-template-columns:1fr;gap:16px}}.slots-sidebar{display:flex;flex-direction:column;gap:16px}@media (max-width: 768px){.slots-sidebar{order:-1;flex-direction:row;overflow-x:auto;gap:12px;padding-bottom:8px}.slots-sidebar .month-card{min-width:280px;flex-shrink:0}.slots-sidebar .legend{min-width:240px;flex-shrink:0}}.sidebar-header{display:flex;align-items:center;justify-content:space-between}.sidebar-clock{text-align:right;font-weight:600}.sidebar-clock .sidebar-date{color:var(--text-secondary);font-weight:400;font-size:12px}.month-card{padding:16px}.month-header{display:grid;grid-template-columns:32px 1fr 32px auto;align-items:center;gap:8px;margin-bottom:12px}.month-title{font-weight:700;text-transform:capitalize;text-align:center;display:inline-flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap}.month-title .caret{color:var(--text-secondary);font-weight:400}.month-nav{width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text-primary);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition)}.month-nav:hover{background:var(--light)}.today-link{justify-self:end;background:transparent;border:none;color:var(--primary);font-weight:600;cursor:pointer}.mini-month .weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px}.mini-month .weekdays span{color:#6b7280;font-size:12px;text-align:center;font-weight:600}.mini-month .days{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.mini-month .days .day{height:32px;width:32px;border:1px solid #e5e7eb;border-radius:6px;background:#fff;color:#111827;font-size:13px;font-weight:500;line-height:1;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.mini-month .days .day:hover{background:#f3f4f6;border-color:#d1d5db}.mini-month .days .day.active{background:#3b82f6;color:#fff;border-color:#3b82f6;font-weight:600}.mini-month .days .day.muted{color:#9ca3af;opacity:.6}.mini-month .days .day.today{box-shadow:0 0 0 2px #3b82f6 inset;font-weight:600}.create-slot-btn{height:44px}.legend{padding:16px}.legend h4{margin-bottom:12px}.legend ul{list-style:none;display:flex;flex-direction:column;gap:8px}.legend-item{display:flex;align-items:center;gap:10px;color:var(--text-secondary);font-size:14px}.legend-dot{width:14px;height:14px;border-radius:50%;display:inline-block;border:2px solid transparent}.legend-dot.dashed{border-style:dashed;background:transparent!important}.legend-dot.not_confirmed{background:#ffe5e5;border-color:#c00}.legend-dot.confirmed{background:#e5f5ff;border-color:#06c}.legend-dot.drained{background:#fff5e5;border-color:#c60}.legend-dot.registered{background:#e5ffe5;border-color:#0c0}.legend-dot.candidate_refused{background:#ffe5f5;border-color:#c06}.legend-dot.our_refusal{background:#f5e5ff;border-color:#60c}.legend-dot.thinking{background:#fffacd;border-color:#980}.slots-main{display:flex;flex-direction:column;gap:16px}.day-header{display:flex;align-items:center;justify-content:center}.day-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px 24px}@media (max-width: 1024px){.day-grid{grid-template-columns:repeat(2,1fr);gap:12px 16px}}@media (max-width: 768px){.day-grid{grid-template-columns:1fr;gap:12px}}.time-column{display:flex;flex-direction:column;gap:8px}.time-label{color:var(--text-secondary);font-size:14px;padding-left:6px}.time-stack{padding:12px;min-height:72px;display:flex;flex-direction:column;gap:8px;background:var(--surface)}.free-slot{color:var(--text-secondary);border:1px dashed var(--border);border-radius:10px;padding:10px 12px;text-align:center}.slot-chip{border-radius:12px;padding:12px 14px;color:#000;font-weight:600;transition:all .2s ease}@media (max-width: 768px){.slot-chip{padding:10px 12px;font-size:14px}}@media (max-width: 480px){.slot-chip{padding:8px 10px;font-size:13px}}.slot-chip:hover{transform:translateY(-1px);box-shadow:0 4px 8px #0000001a}.slot-chip .chip-sub{opacity:.8;font-weight:500;margin-top:2px}.chip-actions{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}.slot-chip.not_confirmed{background:#fff5e5;color:#c60}.slot-chip.arrived{background:#d5ffd5;color:#0a0}.slot-chip.confirmed{background:#e5f5ff;color:#06c}.slot-chip.drained{background:#ffe5e5;color:#c00}.slot-chip.registered{background:#e5ffe5;color:#0c0}.slot-chip.candidate_refused{background:#ffe5f5;color:#c06;border:2px dashed #CC0066}.slot-chip.our_refusal{background:#f5e5ff;color:#60c}.slot-chip.thinking{background:#fffacd;color:#980}.employees-page .container{max-width:1200px}.employees-page .btn-primary{background:#3b82f6!important;color:#fff!important;border:none!important;display:inline-block!important;visibility:visible!important;opacity:1!important;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:6px}.employees-page .btn-primary:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 8px #3b82f64d}.employees-page .btn-primary:active{transform:translateY(0)}.employees-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;gap:20px}@media (max-width: 768px){.employees-header{flex-direction:column;align-items:stretch;gap:16px}}.employees-table-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #0000001a;border:1px solid #e5e7eb}.employees-table{width:100%;border-collapse:collapse;background:#fff;color:#374151}.employees-table thead{background:#f9fafb}.employees-table thead th{padding:16px 20px;text-align:left;font-weight:600;font-size:14px;color:#6b7280;border-bottom:1px solid #e5e7eb}.employees-table thead th:last-child{text-align:center;width:60px}.employees-table tbody tr{border-bottom:1px solid #f3f4f6;transition:background-color .2s}.employees-table tbody tr:hover{background:#f9fafb}.employees-table tbody tr:last-child{border-bottom:none}.employees-table tbody td{padding:16px 20px;vertical-align:middle}.employees-table tbody td:last-child{text-align:center}.employee-info{display:flex;align-items:center;gap:12px}.employee-avatar{width:40px;height:40px;border-radius:50%;background:#f3f4f6;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.employee-details{display:flex;flex-direction:column;gap:2px}.employee-name{font-weight:600;color:#111827;font-size:14px}.employee-username{font-size:13px;color:#6b7280}.employee-email{color:#374151;font-size:14px}.employee-role{color:#374151;font-size:14px;font-weight:500}.status-badge{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;border:none;cursor:pointer;transition:all .2s}.status-badge.active{background:#48bb78;color:#fff}.status-badge.active:hover{background:#38a169}.status-badge.inactive{background:#f56565;color:#fff}.status-badge.inactive:hover{background:#e53e3e}.employee-actions{display:flex;justify-content:center}.action-btn{width:32px;height:32px;border-radius:6px;background:#f3f4f6;border:none;color:#6b7280;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .2s}.action-btn:hover{background:#e5e7eb;color:#374151}.modal .btn-success{background-color:#28a745;color:#fff;border:1px solid #28a745}.modal .btn-success:hover{background-color:#218838;border-color:#1e7e34}.modal .btn-purple{background-color:#6f42c1;color:#fff;border:1px solid #6f42c1}.modal .btn-purple:hover{background-color:#5a32a3;border-color:#4e2a8e}.modal .button-group{display:flex;flex-direction:column;gap:4px}.modal .button-group .btn{padding:12px 16px;border:2px solid;border-radius:4px;cursor:pointer;transition:all .2s;font-size:14px;font-weight:400;text-align:center;background:#fff;color:#666;border-color:#ddd}.modal .button-group .btn:hover:not(.btn-selected){background-color:#f8f9fa}.modal .button-group .btn.btn-selected{font-weight:500}.modal .button-group .btn.btn-selected[data-status=not_confirmed]{background:#fff5e5;color:#c60;border-color:#c60}.modal .button-group .btn.btn-selected[data-status=confirmed]{background:#e5f5ff;color:#06c;border-color:#06c}.modal .button-group .btn.btn-selected[data-status=drained]{background:#ffe5e5;color:#c00;border-color:#c00}.modal .button-group .btn.btn-selected[data-status=arrived]{background:#d5ffd5;color:#0a0;border-color:#0a0}.modal .button-group .btn.btn-selected[data-status=not_arrived]{background:#e5f5ff;color:#06c;border-color:#06c}.modal .button-group .btn.btn-selected[data-status=other]{background:#fffacd;color:#980;border-color:#980}.modal .button-group .btn.btn-selected[data-status=candidate_refused]{background:#fff;color:#0c0;border-color:#0c0;border-style:dashed}.modal .button-group .btn.btn-selected[data-status=our_refusal]{background:#f5e5ff;color:#60c;border-color:#60c}.modal .button-group .btn.btn-selected[data-status=thinking]{background:#fffacd;color:#980;border-color:#980}.modal .file-upload{display:flex;align-items:center;gap:10px;margin-top:5px}.modal .file-upload .file-name{color:#666;font-size:14px;font-style:italic}.modal .registration-fields{animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.modal textarea{width:100%;padding:8px;border:1px solid #ddd;border-radius:4px;font-family:inherit;resize:vertical;min-height:80px}.modal-content{background:#fff;border-radius:12px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}@media (max-width: 768px){.modal-content{max-width:100%;max-height:85vh;border-radius:8px}}@media (max-width: 480px){.modal-content{max-height:90vh;border-radius:6px}}.modal-header{padding:20px;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}@media (max-width: 768px){.modal-header{padding:16px}}@media (max-width: 480px){.modal-header{padding:12px}}.modal-header h2{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.modal-header button{background:none;border:none;color:#666;font-size:24px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%}.modal-header button:hover{background:#e9ecef;color:#333}.file-preview-content{padding:20px;display:flex;align-items:center;justify-content:center;min-height:200px}.file-preview-content .preview-image{max-width:100%;max-height:70vh;object-fit:contain;border-radius:8px}.file-preview-content .preview-video{max-width:100%;max-height:70vh;border-radius:8px}.file-preview-content .audio-preview{display:flex;flex-direction:column;align-items:center;gap:20px}.file-preview-content .audio-preview .audio-icon{font-size:48px;opacity:.6}.file-preview-content .audio-preview .audio-player{width:300px;max-width:100%}.file-preview-content .unknown-file{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center}.file-preview-content .unknown-file .file-icon{font-size:48px;opacity:.6}.file-preview-content .unknown-file p{color:#666;margin:0}.file-preview-content .unknown-file .download-btn{background:#007bff;color:#fff;padding:8px 16px;border-radius:6px;text-decoration:none;font-size:14px}.file-preview-content .unknown-file .download-btn:hover{background:#0056b3}.error{border-color:#dc3545!important;box-shadow:0 0 0 .2rem #dc354540}.error-message{color:#dc3545;font-size:.875rem;margin-top:.25rem;display:block}.slot-chip .chip-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;font-weight:500;font-size:14px;line-height:1.3}.slot-chip .chip-sub{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;font-size:13px;opacity:.8;margin-top:3px}.dashboard-page{padding:20px;max-width:1200px;margin:0 auto}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.dashboard-header h2{margin:0;color:var(--text-primary)}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:30px}.metric-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;gap:16px}.metric-card .metric-icon{font-size:32px;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:#f8f9fa;border-radius:12px}.metric-card .metric-content{flex:1}.metric-card .metric-content h3{font-size:28px;font-weight:700;margin:0 0 4px;color:var(--text-primary)}.metric-card .metric-content p{margin:0 0 8px;color:var(--text-secondary);font-size:14px}.metric-card .metric-content .metric-trend{font-size:12px;color:var(--text-muted)}.activity-section{margin-bottom:30px}.activity-section h3{margin-bottom:16px;color:var(--text-primary)}.activity-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px}.activity-card{background:#fff;border-radius:8px;padding:20px;text-align:center;box-shadow:0 2px 4px #0000001a}.activity-card .activity-number{font-size:24px;font-weight:700;color:var(--primary-color);margin-bottom:8px}.activity-card .activity-label{font-size:14px;color:var(--text-secondary)}.conversion-section{margin-bottom:30px}.conversion-section h3{margin-bottom:20px;color:var(--text-primary)}.conversion-funnel{display:flex;align-items:center;justify-content:center;gap:20px;background:#fff;border-radius:12px;padding:30px;box-shadow:0 2px 8px #0000001a;margin-bottom:16px;flex-wrap:wrap}.funnel-step{text-align:center;position:relative}.funnel-step .funnel-number{font-size:24px;font-weight:700;color:var(--primary-color);margin-bottom:8px}.funnel-step .funnel-label{font-size:14px;color:var(--text-secondary);margin-bottom:8px}.funnel-step .funnel-percent{font-size:12px;color:var(--success-color);font-weight:700}.funnel-step .funnel-arrow{font-size:20px;color:var(--text-muted);margin-top:8px}.overall-conversion{text-align:center;font-size:16px;color:var(--text-primary)}.overall-conversion strong{color:var(--success-color);font-size:18px}.status-section h3{margin-bottom:20px;color:var(--text-primary)}.status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.status-card{background:#fff;border-radius:8px;padding:20px;text-align:center;box-shadow:0 2px 4px #0000001a;position:relative}.status-card .status-count{font-size:28px;font-weight:700;margin-bottom:8px}.status-card .status-label{font-size:14px;margin-bottom:8px}.status-card .status-percentage{font-size:12px;color:var(--text-muted)}.status-card .status-change{position:absolute;top:8px;right:8px;font-size:12px;font-weight:700}.status-card .status-change:before{content:""}.status-selector{position:relative;display:inline-block}.status-selector-trigger{display:flex;align-items:center;gap:8px;padding:12px 16px;border:none;border-radius:16px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.25,.46,.45,.94);box-shadow:0 4px 16px #0000001f,0 1px 3px #00000014,inset 0 1px #ffffff1a;border:1px solid rgba(255,255,255,.15);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);letter-spacing:.3px}.status-selector-trigger:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 8px 32px #0003,0 4px 8px #0000001f,inset 0 1px #fff3}.status-icon{font-size:12px;opacity:.8}.status-selector-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:999}.status-selector-dropdown{position:absolute;top:100%;left:0;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;z-index:1000;min-width:200px;max-height:300px;overflow-y:auto;padding:8px 0;margin-top:8px}.profile-status-selector .status-selector-dropdown{right:0;left:auto}.model-profile .status-selector-dropdown{right:0;left:auto;transform:translate(0)}.modal .status-selector-dropdown{z-index:1050}.status-columns{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.status-column h4{margin:0 0 12px;font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;text-align:left;padding:0 0 8px;background:none;border:none;border-bottom:1px solid var(--border)}.status-dot-option{display:flex;align-items:center;gap:12px;padding:8px 12px;margin-bottom:6px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.status-dot-option:hover{background:var(--light)}.status-dot-option.active{background:var(--primary-light)}.status-dot-option.active .status-dot{transform:scale(1.2);box-shadow:0 0 0 2px var(--surface),0 0 0 4px var(--primary)}.status-dot{width:12px;height:12px;border-radius:50%;border:2px solid var(--surface);transition:all .2s ease;flex-shrink:0}.status-label{color:var(--text);font-weight:500}.status-option{display:block;width:100%;padding:10px 12px;margin-bottom:6px;border:none;border-radius:12px;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.25,.46,.45,.94);text-align:center;position:relative;overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 16px #0000001f,0 1px 3px #00000014,inset 0 1px #ffffff1a;border:1px solid rgba(255,255,255,.15);letter-spacing:.3px}.status-option:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#ffffff1a,#ffffff0d);opacity:0;transition:opacity .3s ease}.status-option:hover{transform:translateY(-2px);box-shadow:0 8px 32px #00000029,0 2px 8px #0000001f,inset 0 1px #ffffff26}.status-option.active{transform:scale(1.05);box-shadow:0 8px 32px #0003,0 4px 16px #00000026,inset 0 1px #fff3,0 0 0 3px #ffffff4d;border-color:#fffc}.status-option.active:before{opacity:1}.status-option:last-child{margin-bottom:0}.registration-badge{display:inline-block;margin-left:8px;font-size:14px;opacity:.8;transition:opacity .2s ease}.registration-badge:hover{opacity:1}.model-card-status{margin-top:auto;display:flex;justify-content:center;height:24px;min-height:24px;flex-shrink:0;align-items:center}.model-card-status .status-dot-container{display:flex;align-items:center;gap:8px}.model-card-status .status-dot-card{width:12px;height:12px;border-radius:50%;border:2px solid rgba(255,255,255,.8);flex-shrink:0}.model-card-status .status-text{font-size:11px;font-weight:500;color:var(--text);text-transform:none}.model-card-status .status-badge{padding:6px 12px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 4px #0000001a;border:1px solid rgba(255,255,255,.2)}.model-card-status.status-not_confirmed{border-left:4px solid #CC6600}.model-card-status.status-not_confirmed .status-count{color:#c60}.model-card-status.status-confirmed{border-left:4px solid #0066CC}.model-card-status.status-confirmed .status-count{color:#06c}.model-card-status.status-registered{border-left:4px solid #00CC00}.model-card-status.status-registered .status-count{color:#0c0}.model-card-status.status-drained{border-left:4px solid #CC0000}.model-card-status.status-drained .status-count{color:#c00}.model-card-status.status-candidate_refused{border-left:4px solid #CC0066}.model-card-status.status-candidate_refused .status-count{color:#c06}.model-card-status.status-our_refusal{border-left:4px solid #6600CC}.model-card-status.status-our_refusal .status-count{color:#60c}.model-card-status.status-thinking{border-left:4px solid #998800}.model-card-status.status-thinking .status-count{color:#980}.model-card-status.status-arrived{border-left:4px solid #00AA00}.model-card-status.status-arrived .status-count{color:#0a0}.model-card-status.status-no_show{border-left:4px solid #AA0000}.model-card-status.status-no_show .status-count{color:#a00}.selected-status-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;margin:2px;border-radius:6px;font-size:11px;font-weight:500;color:#fff;border:1px solid rgba(255,255,255,.2);box-shadow:0 1px 2px #0000001a}.selected-status-chip:before{content:"";width:6px;height:6px;border-radius:50%;background:#fffc}.pagination-container{display:flex;justify-content:space-between;align-items:center;margin:20px 0;padding:16px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.pagination-info{font-size:14px;color:var(--text-secondary)}.pagination-controls{display:flex;align-items:center;gap:16px}.items-per-page-select{padding:6px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;background:#fff}.pagination-buttons{display:flex;gap:4px}.pagination-btn{padding:8px 12px;border:1px solid #ddd;background:#fff;color:var(--text-primary);border-radius:4px;cursor:pointer;font-size:14px;min-width:40px}.pagination-btn:hover:not(:disabled){background:#f5f5f5}.pagination-btn.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-btn.dots{border:none;background:none;cursor:default}.pagination-btn.dots:hover{background:none}@media (max-width: 768px){.pagination-container,.pagination-controls{flex-direction:column;gap:12px}.conversion-funnel{flex-direction:column}.conversion-funnel .funnel-arrow{transform:rotate(90deg)}.metrics-grid{grid-template-columns:1fr}}.model-search{background:#fff;border-radius:8px;padding:20px;margin-bottom:24px;box-shadow:0 2px 4px #0000001a}.model-search .search-main .search-input-group{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.model-search .search-main .search-input-group .search-input{flex:1;min-width:300px;padding:12px 16px;border:1px solid #ddd;border-radius:6px;font-size:16px}.model-search .search-main .search-input-group .search-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.model-search .search-main .search-input-group .btn{padding:12px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.model-search .search-main .search-input-group .btn.btn-outline{background:#fff;border:1px solid #ddd;color:#666}.model-search .search-main .search-input-group .btn.btn-outline:hover{background:#f8f9fa;border-color:#007bff;color:#007bff}.model-search .search-main .search-input-group .btn.btn-secondary{background:#6c757d;color:#fff}.model-search .search-main .search-input-group .btn.btn-secondary:hover{background:#5a6268}.model-search .search-filters{margin-top:20px;padding-top:20px;border-top:1px solid #eee}.model-search .search-filters .filters-row{display:flex;gap:20px;margin-bottom:16px;flex-wrap:wrap}.model-search .search-filters .filters-row .filter-group{flex:1;min-width:200px}.model-search .search-filters .filters-row .filter-group label{display:block;margin-bottom:6px;font-weight:500;color:#333;font-size:14px}.model-search .search-filters .filters-row .filter-group select,.model-search .search-filters .filters-row .filter-group input[type=date]{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;background:#fff}.model-search .search-filters .filters-row .filter-group select:focus,.model-search .search-filters .filters-row .filter-group input[type=date]:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}@media (max-width: 768px){.model-search{padding:16px}.model-search .search-main .search-input-group .search-input{min-width:100%;margin-bottom:12px}.model-search .search-main .search-input-group .btn{flex:1;min-width:120px}.model-search .search-filters .filters-row{flex-direction:column;gap:16px}.model-search .search-filters .filters-row .filter-group{min-width:100%}}@media (max-width: 480px){.model-search{padding:12px;margin-bottom:16px}.model-search .search-main .search-input-group{flex-direction:column}.model-search .search-main .search-input-group .btn{width:100%}}.accounts-modal .modal-content{max-width:700px;max-height:80vh;overflow-y:auto}.accounts-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #eee}.accounts-modal .modal-header h2{margin:0;font-size:20px;font-weight:600;color:#333}.accounts-modal .modal-header .modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:#666;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px}.accounts-modal .modal-header .modal-close:hover{background:#f5f5f5;color:#333}.accounts-modal .modal-body{padding:24px}.accounts-modal .accounts-list{margin-bottom:20px}.accounts-modal .accounts-list .account-row{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:16px;align-items:end;padding:16px 0;border-bottom:1px solid #eee}.accounts-modal .accounts-list .account-row:last-child{border-bottom:none}.accounts-modal .accounts-list .account-row .form-group{display:flex;flex-direction:column;gap:6px}.accounts-modal .accounts-list .account-row .form-group label{font-size:13px;font-weight:500;color:#555}.accounts-modal .accounts-list .account-row .form-group input{padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .2s,box-shadow .2s}.accounts-modal .accounts-list .account-row .form-group input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.accounts-modal .accounts-list .account-row .form-group input::placeholder{color:#999}.accounts-modal .accounts-list .account-row .form-group input[type=password]{font-family:monospace}.accounts-modal .accounts-list .account-row .btn-sm{padding:8px 16px;font-size:13px;border-radius:4px;border:none;cursor:pointer;transition:all .2s}.accounts-modal .accounts-list .account-row .btn-sm.btn-danger{background:#dc3545;color:#fff}.accounts-modal .accounts-list .account-row .btn-sm.btn-danger:hover{background:#c82333}.accounts-modal .modal-footer{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-top:1px solid #eee;background:#f8f9fa}.accounts-modal .modal-footer .btn{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:none}.accounts-modal .modal-footer .btn.btn-secondary{background:#6c757d;color:#fff}.accounts-modal .modal-footer .btn.btn-secondary:hover{background:#5a6268}.accounts-modal .modal-footer .btn.btn-primary{background:#007bff;color:#fff}.accounts-modal .modal-footer .btn.btn-primary:hover{background:#0056b3}.accounts-modal .muted{color:#666;font-style:italic;text-align:center;padding:40px 20px;background:#f8f9fa;border-radius:8px;border:2px dashed #ddd}.shifts-page{padding:20px 0;min-height:calc(100vh - 80px);background-color:var(--bg-primary);color:var(--text-primary)}.shifts-page .container{max-width:1200px;margin:0 auto;padding:0 20px}.shifts-header{padding:12px 0;margin-bottom:24px}.shifts-header h1{font-size:32px;font-weight:700;text-align:center;margin-bottom:24px;color:var(--text-primary)}.filters{display:flex;gap:10px;margin-bottom:24px;flex-wrap:wrap}.filter-button{padding:10px 16px;background-color:#f8f9fa;border:2px solid #e9ecef;border-radius:6px;color:#495057;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;min-height:40px;display:inline-flex;align-items:center;justify-content:center}.filter-button.active{background-color:#3b82f6;color:#fff;border-color:#3b82f6;font-weight:600;box-shadow:0 2px 4px #3b82f64d}.filter-button:hover:not(.active){background-color:#e9ecef;border-color:#3b82f6;color:#212529}.shifts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.shift-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:16px;box-shadow:0 1px 3px #0000001a;transition:all .2s ease;color:#1a202c}.shift-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026;border-color:#cbd5e0}.shift-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.shift-model{font-size:16px;font-weight:600;color:#2d3748;margin:0 0 4px}.shift-status{padding:4px 8px;border-radius:4px;font-size:10px;font-weight:500;text-transform:uppercase;min-width:70px;text-align:center}.shift-status.status-pending{background:#f59e0b;color:#fff}.shift-status.status-active{background:#10b981;color:#fff}.shift-status.status-completed{background:#3b82f6;color:#fff}.shift-status.status-inactive{background:#6b7280;color:#fff}.shift-title-section{display:flex;align-items:center;flex:1}.shift-title-section .shift-title{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:4px;display:block}.shift-title-section .shift-type{font-size:11px;padding:3px 8px;border-radius:4px;font-weight:500;text-transform:uppercase}.shift-title-section .shift-type.type-regular{background-color:var(--primary-color);color:#fff}.shift-title-section .shift-type.type-training{background-color:#f59e0b;color:#fff}.shift-actions{display:flex;gap:6px;flex-wrap:wrap}.shift-actions .btn{display:flex;align-items:center;gap:4px;padding:6px 10px;border-radius:4px;font-size:11px;font-weight:500;text-decoration:none;transition:all .2s ease;border:1px solid transparent;cursor:pointer}.shift-actions .btn .material-icons{font-size:14px}.shift-actions .btn.btn-secondary{background:#4a5568!important;color:#fff!important;border-color:#4a5568!important}.shift-actions .btn.btn-secondary:hover{background:#2d3748!important;border-color:#2d3748!important}.shift-actions .btn.btn-outline{background:#fff!important;color:#4a5568!important;border-color:#cbd5e0!important}.shift-actions .btn.btn-outline:hover{background:#f7fafc!important;border-color:#cbd5e0!important}.shift-actions .btn.btn-danger{background:#fc8181!important;color:#fff!important}.shift-actions .btn.btn-danger:hover{background:#f56565!important}.shift-actions .btn.btn-success{background:#48bb78!important;color:#fff!important}.shift-actions .btn.btn-success:hover{background:#38a169!important}.shift-card .btn{display:flex!important;align-items:center!important;gap:4px!important;padding:6px 10px!important;border-radius:4px!important;font-size:11px!important;font-weight:500!important;text-decoration:none!important;transition:all .2s ease!important;border:1px solid transparent!important;cursor:pointer!important}.shift-card .btn .material-icons{font-size:14px!important}.shift-card .btn.btn-secondary{background:#4a5568!important;color:#fff!important;border-color:#4a5568!important}.shift-card .btn.btn-secondary:hover{background:#2d3748!important;border-color:#2d3748!important}.shift-card .btn.btn-outline{background:#fff!important;color:#4a5568!important;border-color:#cbd5e0!important}.shift-card .btn.btn-outline:hover{background:#f7fafc!important;border-color:#cbd5e0!important}.shift-card .btn.btn-danger{background:#fc8181!important;color:#fff!important}.shift-card .btn.btn-danger:hover{background:#f56565!important}.shift-card .btn.btn-success{background:#48bb78!important;color:#fff!important}.shift-card .btn.btn-success:hover{background:#38a169!important}.shift-timer-modal{max-width:500px}.shift-timer-modal .shift-info-summary{text-align:center;margin-bottom:24px;padding:16px;background:#f8f9fa;border-radius:8px}.shift-timer-modal .shift-info-summary h3{margin:0 0 8px;font-size:18px;font-weight:600;color:#2d3748}.shift-timer-modal .shift-info-summary .shift-address{margin:4px 0;color:#4a5568;font-size:14px}.shift-timer-modal .shift-info-summary .shift-producer{margin:4px 0;color:#718096;font-size:13px}.shift-timer-modal .timer-display{text-align:center;margin-bottom:32px}.shift-timer-modal .timer-display .timer-time{font-size:48px;font-weight:700;color:#2d3748;font-family:Courier New,monospace;margin-bottom:8px}.shift-timer-modal .timer-display .timer-status .status-active{color:#38a169;font-weight:600;font-size:14px}.shift-timer-modal .timer-display .timer-status .status-inactive{color:#718096;font-weight:500;font-size:14px}.shift-timer-modal .timer-controls{text-align:center;margin-bottom:24px}.shift-timer-modal .timer-controls .btn-large{padding:12px 24px;font-size:16px;font-weight:600;min-width:180px}.shift-timer-modal .timer-controls .btn-large .material-icons{font-size:20px;margin-right:8px}.shift-timer-modal .timer-controls .active-controls{display:flex;gap:12px;justify-content:center;align-items:center}.shift-timer-modal .timer-controls .active-controls .btn-outline{padding:8px 16px;font-size:14px}.shift-timer-modal .shift-timestamps{background:#f8f9fa;border-radius:8px;padding:16px;margin-bottom:16px}.shift-timer-modal .shift-timestamps .timestamp-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.shift-timer-modal .shift-timestamps .timestamp-item:last-child{margin-bottom:0}.shift-timer-modal .shift-timestamps .timestamp-item .timestamp-label{font-weight:500;color:#4a5568;font-size:14px}.shift-timer-modal .shift-timestamps .timestamp-item .timestamp-value{color:#2d3748;font-size:14px;font-family:Courier New,monospace}.shift-timer-modal .model-accounts-section{margin-bottom:24px}.shift-timer-modal .model-accounts-section h4{margin:0 0 12px;font-size:16px;font-weight:600;color:#2d3748}.shift-timer-modal .model-accounts-section .loading-accounts{text-align:center;color:#718096;font-size:14px;padding:16px}.shift-timer-modal .model-accounts-section .accounts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.shift-timer-modal .model-accounts-section .accounts-grid .account-card{background:#f8f9fa;border:1px solid #e2e8f0;border-radius:6px;padding:12px}.shift-timer-modal .model-accounts-section .accounts-grid .account-card .account-site{font-weight:600;color:#2d3748;font-size:13px;margin-bottom:4px}.shift-timer-modal .model-accounts-section .accounts-grid .account-card .account-login{color:#4a5568;font-size:12px;font-family:Courier New,monospace;margin-bottom:4px}.shift-timer-modal .model-accounts-section .accounts-grid .account-card .account-password{color:#4a5568;font-size:12px;font-family:Courier New,monospace;margin-bottom:8px}.shift-timer-modal .model-accounts-section .accounts-grid .account-card .account-earnings{margin-top:8px}.shift-timer-modal .model-accounts-section .accounts-grid .account-card .account-earnings label{display:block;font-size:11px;color:#4a5568;margin-bottom:4px;font-weight:500}.shift-timer-modal .model-accounts-section .accounts-grid .account-card .account-earnings .earnings-input{width:100%;padding:6px 8px;border:1px solid #d1d5db;border-radius:4px;font-size:12px;font-family:Courier New,monospace;background-color:#fff}.shift-timer-modal .model-accounts-section .accounts-grid .account-card .account-earnings .earnings-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.shift-timer-modal .model-accounts-section .accounts-grid .account-card .account-earnings .earnings-input::placeholder{color:#9ca3af}.shift-timer-modal .total-earnings-display{text-align:center;margin:16px 0;padding:12px;background-color:#f0f9ff;border:1px solid #0ea5e9;border-radius:8px}.shift-timer-modal .total-earnings-display h4{margin:0;color:#0c4a6e;font-size:16px;font-weight:600}.tabs-navigation{display:flex;gap:8px;margin-bottom:24px;border-bottom:1px solid #e2e8f0}.tabs-navigation .tab-button{display:flex;align-items:center;gap:8px;padding:12px 20px;background:none;border:none;border-bottom:2px solid transparent;color:#64748b;font-weight:500;cursor:pointer;transition:all .2s ease}.tabs-navigation .tab-button .material-icons{font-size:20px}.tabs-navigation .tab-button:hover{color:#3b82f6;background-color:#f8fafc}.tabs-navigation .tab-button.active{color:#3b82f6;border-bottom-color:#3b82f6;background-color:#f8fafc}.action-icon{color:var(--text-muted);cursor:pointer;font-size:18px;transition:color .2s}.action-icon:hover{color:var(--primary-color)}.shift-details{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.detail-section{display:flex;flex-direction:column;gap:2px}.detail-section .detail-label{font-size:10px;color:#718096;text-transform:uppercase;font-weight:500}.detail-section .detail-value{font-size:12px;color:#2d3748;font-weight:500}.detail-section.earnings .detail-value{color:#38a169;font-weight:600}.shift-info{display:flex;flex-direction:column;gap:4px}.shift-type-badge{font-size:10px;color:#718096;text-transform:uppercase;font-weight:500}.shift-timing{display:flex;justify-content:space-between;margin-bottom:12px;padding:8px 0;border-top:1px solid #e2e8f0}.shift-timing .timing-section{display:flex;flex-direction:column;gap:2px}.shift-timing .timing-section .timing-label{font-size:10px;color:#718096;text-transform:uppercase;font-weight:500}.shift-timing .timing-section .timing-value{font-size:11px;color:#2d3748;font-weight:500}.detail-row{display:flex;align-items:center;gap:6px;color:#a0aec0;font-size:12px}.detail-row .material-icons{font-size:14px;color:#718096}.detail-row span{color:#e2e8f0}.detail-item{display:flex;flex-direction:column}.detail-label{font-size:12px;color:var(--text-muted);margin-bottom:2px}.detail-value{font-size:14px;font-weight:500;color:var(--text-primary)}.shift-time{display:flex;justify-content:space-between;padding-top:12px;border-top:1px solid var(--border);font-size:13px}.time-item{display:flex;flex-direction:column}.status-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:11px;font-weight:500;margin-top:6px}.status-badge.status-active{background-color:#22c55e1a;color:#22c55e;border:1px solid rgba(34,197,94,.2)}.status-badge.status-completed{background-color:#6b72801a;color:#6b7280;border:1px solid rgba(107,114,128,.2)}.status-badge.status-upcoming{background-color:#3b82f61a;color:#3b82f6;border:1px solid rgba(59,130,246,.2)}.add-button{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background-color:var(--primary-color);border:none;display:flex;justify-content:center;align-items:center;color:#fff;font-size:24px;box-shadow:0 4px 12px #00000026;cursor:pointer;transition:transform .2s,box-shadow .2s;z-index:100}.add-button:hover{transform:scale(1.05);box-shadow:0 6px 16px #0003}.empty-state{text-align:center;color:var(--text-muted);padding:40px;font-size:16px}.password-input-container{position:relative;display:flex;align-items:center}.password-input-container input{flex:1;padding-right:40px}.password-input-container .password-toggle{position:absolute;right:10px;background:none;border:none;cursor:pointer;font-size:16px;padding:4px}.password-input-container .password-toggle:hover{opacity:.7}.shifts-page{padding:24px;max-width:1400px;margin:0 auto}.shifts-page .page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;gap:24px;padding:0}.shifts-page .page-header .header-left{flex:1}.shifts-page .page-header .header-left .page-title{font-size:2rem;font-weight:600;margin:0 0 12px;color:var(--text-primary);line-height:1.2}.shifts-page .page-header .header-left .header-stats{display:flex;gap:20px;flex-wrap:wrap}.shifts-page .page-header .header-left .header-stats .stat{color:var(--text-secondary);font-size:.9rem}.shifts-page .page-header .header-left .header-stats .stat strong{color:var(--text-primary);font-weight:600}.shifts-page .page-header .header-right{flex-shrink:0;display:flex;align-items:flex-start}.shifts-page .page-header .header-right .btn{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;font-size:.95rem;font-weight:500;border-radius:8px;border:none;cursor:pointer;transition:all .2s ease;text-decoration:none;white-space:nowrap}.shifts-page .page-header .header-right .btn.btn-primary{background:var(--primary-color, #667eea);color:#fff}.shifts-page .page-header .header-right .btn.btn-primary:hover{background:var(--primary-hover, #5a6fd8);transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.shifts-page .page-header .header-right .btn .material-icons{font-size:18px}.shifts-page .filters-section{background:var(--background-secondary);border-radius:12px;padding:20px;margin-bottom:24px;border:1px solid var(--border-color)}.shifts-page .filters-section .search-container{position:relative;margin-bottom:16px}.shifts-page .filters-section .search-container .material-icons{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-secondary);font-size:20px}.shifts-page .filters-section .search-container .search-input{width:100%;padding:12px 12px 12px 44px;border:1px solid var(--border-color);border-radius:8px;background:var(--background-primary);color:var(--text-primary);font-size:.95rem;transition:all .2s ease}.shifts-page .filters-section .search-container .search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #667eea1a}.shifts-page .filters-section .search-container .search-input::placeholder{color:var(--text-secondary)}.shifts-page .filters-section .filter-controls{display:flex;gap:16px;flex-wrap:wrap}.shifts-page .filters-section .filter-controls .filter-select{padding:10px 12px;border:1px solid var(--border-color);border-radius:8px;background:var(--background-primary);color:var(--text-primary);font-size:.9rem;min-width:160px;transition:all .2s ease}.shifts-page .filters-section .filter-controls .filter-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #667eea1a}.shifts-page .shifts-content{min-height:400px}.shifts-page .shifts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:24px}.shifts-page .shifts-grid .shift-card{background:var(--background-secondary);border:1px solid var(--border-color);border-radius:12px;padding:20px;transition:all .3s ease;position:relative;overflow:hidden}.shifts-page .shifts-grid .shift-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px #00000026;border-color:var(--primary-color)}.shifts-page .shifts-grid .shift-card .shift-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;gap:12px}.shifts-page .shifts-grid .shift-card .shift-header .shift-model{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0;flex:1;line-height:1.3}.shifts-page .shifts-grid .shift-card .shift-header .shift-status{padding:6px 12px;border-radius:20px;font-size:.8rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.shifts-page .shifts-grid .shift-card .shift-header .shift-status.status-pending{background:#ffc10733;color:#ffc107;border:1px solid rgba(255,193,7,.3)}.shifts-page .shifts-grid .shift-card .shift-header .shift-status.status-active{background:#28a74533;color:#28a745;border:1px solid rgba(40,167,69,.3)}.shifts-page .shifts-grid .shift-card .shift-header .shift-status.status-completed{background:#6c757d33;color:#6c757d;border:1px solid rgba(108,117,125,.3)}.shifts-page .shifts-grid .shift-card .shift-header .shift-status.status-inactive{background:#dc354533;color:#dc3545;border:1px solid rgba(220,53,69,.3)}.shifts-page .shifts-grid .shift-card .shift-details{margin-bottom:20px}.shifts-page .shifts-grid .shift-card .shift-details .detail-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;color:var(--text-secondary);font-size:.9rem}.shifts-page .shifts-grid .shift-card .shift-details .detail-row .material-icons{font-size:16px;color:var(--text-tertiary);width:20px;flex-shrink:0}.shifts-page .shifts-grid .shift-card .shift-details .detail-row span{line-height:1.4}.shifts-page .shifts-grid .shift-card .shift-details .detail-row:last-child{margin-bottom:0}.shifts-page .shifts-grid .shift-card .shift-actions{display:flex;gap:8px;flex-wrap:wrap}.shifts-page .shifts-grid .shift-card .shift-actions .btn{display:flex;align-items:center;gap:6px;padding:8px 12px;font-size:.85rem;border-radius:6px;transition:all .2s ease;flex:1;min-width:0;justify-content:center}.shifts-page .shifts-grid .shift-card .shift-actions .btn .material-icons{font-size:16px}.shifts-page .shifts-grid .shift-card .shift-actions .btn.btn-secondary{background:var(--primary-color);color:#fff;border:1px solid var(--primary-color)}.shifts-page .shifts-grid .shift-card .shift-actions .btn.btn-secondary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.shifts-page .shifts-grid .shift-card .shift-actions .btn.btn-outline{background:transparent;color:var(--text-primary);border:1px solid var(--border-color)}.shifts-page .shifts-grid .shift-card .shift-actions .btn.btn-outline:hover{background:var(--background-tertiary);border-color:var(--primary-color);color:var(--primary-color)}.shifts-page .shifts-grid .shift-card .shift-actions .btn.btn-danger{background:transparent;color:#dc3545;border:1px solid rgba(220,53,69,.3)}.shifts-page .shifts-grid .shift-card .shift-actions .btn.btn-danger:hover{background:#dc35451a;border-color:#dc3545}.shifts-page .empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:80px 20px;color:var(--text-secondary);min-height:400px}.shifts-page .empty-state .empty-icon{margin-bottom:24px}.shifts-page .empty-state .empty-icon .material-icons{font-size:4rem;color:var(--text-tertiary);opacity:.6}.shifts-page .empty-state h3{font-size:1.5rem;color:var(--text-primary);margin:0 0 12px;font-weight:600}.shifts-page .empty-state p{font-size:1rem;margin:0 0 32px;max-width:400px;line-height:1.6;color:var(--text-secondary)}.shifts-page .empty-state .btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;font-size:.95rem;border-radius:8px;transition:all .2s ease}.shifts-page .empty-state .btn .material-icons{font-size:18px}.shifts-page .loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-secondary)}.shifts-page .loading-container .loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top:3px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.shifts-page .loading-container p{font-size:1rem;margin:0}@media (max-width: 768px){.shifts-page{padding:16px}.shifts-page .page-header{flex-direction:column;align-items:stretch;gap:16px}.shifts-page .page-header .header-left .header-stats{flex-direction:column;gap:8px}.shifts-page .page-header .header-right{align-self:stretch}.shifts-page .page-header .header-right .btn{width:100%;justify-content:center}.shifts-page .filters-section .filter-controls{flex-direction:column}.shifts-page .filters-section .filter-controls .filter-select{min-width:100%}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;opacity:1;visibility:visible;transition:all .3s ease;padding:20px}.modal-overlay.active{opacity:1;visibility:visible}.modal-overlay .modal{background:#fff;border-radius:12px;width:100%;max-width:520px;display:flex;flex-direction:column;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-overlay .modal.active{transform:scale(1)}.modal-overlay .modal .modal-header{padding:16px 20px 0;border-bottom:none}.modal-overlay .modal .modal-header .modal-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0}.modal-overlay .modal .modal-header .modal-close{position:absolute;top:12px;right:12px;background:none;border:none;font-size:1.3rem;cursor:pointer;color:var(--text-secondary);padding:4px;border-radius:4px;transition:all .2s ease}.modal-overlay .modal .modal-header .modal-close:hover{background:var(--background-secondary);color:var(--text-primary)}.modal-overlay .modal .modal-body{padding:24px;max-height:calc(90vh - 140px);overflow-y:auto}.modal-overlay .modal .modal-body .shift-type-selector{display:flex;gap:8px;margin-bottom:16px}.modal-overlay .modal .modal-body .shift-type-selector .type-selector{flex:1;padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;text-align:center;cursor:pointer;transition:all .2s ease;font-weight:500;font-size:.85rem;color:var(--text-secondary)}.modal-overlay .modal .modal-body .shift-type-selector .type-selector:hover{border-color:var(--primary-color);color:var(--text-primary)}.modal-overlay .modal .modal-body .shift-type-selector .type-selector.active{border-color:var(--primary-color);background:var(--primary-color);color:#fff}.modal-overlay .modal .modal-body .shift-type-selector .type-selector.active:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.modal-overlay .modal .modal-body .form-group{margin-bottom:12px}.modal-overlay .modal .modal-body .form-group:last-child{margin-bottom:0}.modal-overlay .modal .modal-body .form-group .form-label{display:block;font-weight:600;margin-bottom:4px;color:var(--text-primary);font-size:.8rem}.modal-overlay .modal .modal-body .form-group .form-input,.modal-overlay .modal .modal-body .form-group .form-select{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:4px;font-size:.85rem;transition:all .2s ease;background:#fff}.modal-overlay .modal .modal-body .form-group .form-input:focus,.modal-overlay .modal .modal-body .form-group .form-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #6366f11a}.modal-overlay .modal .modal-body .form-group .form-input:disabled,.modal-overlay .modal .modal-body .form-group .form-select:disabled{background:var(--background-secondary);color:var(--text-secondary);cursor:not-allowed}.modal-overlay .modal .modal-body .form-group .comment-textarea{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:4px;font-size:.85rem;min-height:60px;resize:vertical;font-family:inherit;transition:all .2s ease}.modal-overlay .modal .modal-body .form-group .comment-textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #6366f11a}.modal-overlay .modal .modal-body .form-group .searchable-select{position:relative}.modal-overlay .modal .modal-body .form-group .searchable-select .dropdown-options{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--border-color);border-radius:6px;box-shadow:0 4px 6px -1px #0000001a;max-height:200px;overflow-y:auto;z-index:1000;display:none}.modal-overlay .modal .modal-body .form-group .searchable-select .dropdown-options.active{display:block}.modal-overlay .modal .modal-body .form-group .searchable-select .dropdown-options .option{padding:8px 12px;cursor:pointer;transition:background-color .2s ease;border-bottom:1px solid var(--border-color)}.modal-overlay .modal .modal-body .form-group .searchable-select .dropdown-options .option:hover{background:var(--background-secondary)}.modal-overlay .modal .modal-body .form-group .searchable-select .dropdown-options .option:last-child{border-bottom:none}.modal-overlay .modal .modal-body .form-group .searchable-select .dropdown-options .option.disabled{cursor:not-allowed;color:var(--text-secondary);background:var(--background-secondary);font-style:italic}.modal-overlay .modal .modal-body .form-group .searchable-select .dropdown-options .option .option-name{font-weight:500;color:var(--text-primary);font-size:.85rem}.modal-overlay .modal .modal-body .form-group .searchable-select .dropdown-options .option .option-status{font-size:.75rem;color:var(--text-secondary);margin-top:2px}.modal-overlay .modal .modal-body .accounts-list{border:1px solid var(--border-color);border-radius:8px;padding:12px;background:var(--background-secondary)}.modal-overlay .modal .modal-body .accounts-list.active{display:block}.modal-overlay .modal .modal-body .accounts-list .account-item{padding:8px 12px;background:var(--background-primary);border-radius:6px;margin-bottom:8px;color:var(--text-primary);font-size:.9rem}.modal-overlay .modal .modal-body .accounts-list .account-item:last-child{margin-bottom:0}.modal-overlay .modal .modal-body .comment-textarea{width:100%;min-height:80px}.modal-overlay .modal-footer{padding:12px 20px 16px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:8px}.modal-overlay .modal-footer .btn{padding:8px 16px;border:none;border-radius:4px;font-weight:500;cursor:pointer;transition:all .2s ease;font-size:.85rem}.modal-overlay .modal-footer .btn.btn-secondary{background:var(--background-secondary);color:var(--text-secondary)}.modal-overlay .modal-footer .btn.btn-secondary:hover{background:var(--border-color);color:var(--text-primary)}.modal-overlay .modal-footer .btn.btn-primary{background:var(--primary-color);color:#fff}.modal-overlay .modal-footer .btn.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.modal-overlay .modal-footer .btn.btn-primary:disabled{background:var(--text-secondary);cursor:not-allowed;transform:none;box-shadow:none}@media (max-width: 768px){.modal-overlay .modal-overlay{padding:8px}.modal-overlay .modal-overlay .modal{max-height:98vh}.modal-overlay .modal-overlay .modal .modal-header{padding:12px 16px 0}.modal-overlay .modal-overlay .modal .modal-header .modal-title{font-size:1rem}.modal-overlay .modal-overlay .modal .modal-body{padding:12px 16px;max-height:calc(98vh - 100px)}.modal-overlay .modal-overlay .modal .modal-body .shift-type-selector{margin-bottom:12px}.modal-overlay .modal-overlay .modal .modal-body .shift-type-selector .type-selector{padding:6px 8px;font-size:.8rem}.modal-overlay .modal-overlay .modal .modal-body .form-group{margin-bottom:10px}.modal-overlay .modal-overlay .modal .modal-body .form-group .form-label{font-size:.75rem;margin-bottom:3px}.modal-overlay .modal-overlay .modal .modal-body .form-group .form-input,.modal-overlay .modal-overlay .modal .modal-body .form-group .form-select{padding:6px 10px;font-size:.8rem}.modal-overlay .modal-overlay .modal .modal-body .form-group .comment-textarea{min-height:50px}.modal-overlay .modal-overlay .modal .modal-footer{padding:8px 16px 12px}.modal-overlay .modal-overlay .modal .modal-footer .btn{flex:1;min-width:0;padding:6px 12px;font-size:.8rem}}.modal-overlay .apartments-page .addresses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:24px;margin-top:24px}.modal-overlay .apartments-page .address-card{background:#fff;border-radius:12px;border:1px solid #e5e7eb;overflow:hidden;box-shadow:0 1px 3px #0000001a;transition:all .2s ease}.modal-overlay .apartments-page .address-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.modal-overlay .apartments-page .address-header{padding:20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:space-between;align-items:flex-start}.modal-overlay .apartments-page .address-header .address-info{flex:1}.modal-overlay .apartments-page .address-header .address-info .address-title{margin:0 0 8px;font-size:18px;font-weight:600;display:flex;align-items:center;gap:8px}.modal-overlay .apartments-page .address-header .address-info .address-title .material-icons{font-size:20px}.modal-overlay .apartments-page .address-header .address-info .rooms-count{font-size:14px;opacity:.9}.modal-overlay .apartments-page .address-header .address-actions .btn{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff}.modal-overlay .apartments-page .address-header .address-actions .btn:hover{background:#ffffff4d}.modal-overlay .apartments-page .rooms-list{padding:0}.modal-overlay .apartments-page .room-item{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #f3f4f6}.modal-overlay .apartments-page .room-item:last-child{border-bottom:none}.modal-overlay .apartments-page .room-item .room-info{display:flex;align-items:center;gap:12px}.modal-overlay .apartments-page .room-item .room-info .material-icons{color:#6b7280;font-size:20px}.modal-overlay .apartments-page .room-item .room-info .room-name{font-weight:500;color:#374151}.modal-overlay .apartments-page .room-item .room-actions{display:flex;gap:8px}.modal-overlay .apartments-page .room-item .room-actions .btn{padding:6px 8px;min-width:auto}.modal-overlay .apartments-page .room-item .room-actions .btn .material-icons{font-size:18px}.modal-overlay .apartments-page .empty-state{text-align:center;padding:60px 20px;color:#6b7280}.modal-overlay .apartments-page .empty-state .material-icons{font-size:64px;color:#d1d5db;margin-bottom:16px}.modal-overlay .apartments-page .empty-state h3{margin:0 0 8px;color:#374151}.modal-overlay .apartments-page .empty-state p{margin:0 0 24px}.modal-overlay .shift-history{margin-top:20px}.modal-overlay .shift-history .history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.modal-overlay .shift-history .history-header h3{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0}.modal-overlay .shift-history .history-filters{display:flex;gap:8px;margin-bottom:16px}.modal-overlay .shift-history .history-filters .filter-btn{padding:6px 12px;border:1px solid var(--border-color);border-radius:6px;background:#fff;color:var(--text-secondary);font-size:.85rem;cursor:pointer;transition:all .2s ease}.modal-overlay .shift-history .history-filters .filter-btn:hover{border-color:var(--primary-color);color:var(--text-primary)}.modal-overlay .shift-history .history-filters .filter-btn.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.modal-overlay .shift-history .history-list .history-item{padding:12px;border:1px solid var(--border-color);border-radius:6px;margin-bottom:8px;background:#fff}.modal-overlay .shift-history .history-list .history-item:last-child{margin-bottom:0}.modal-overlay .shift-history .history-list .history-item .item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.modal-overlay .shift-history .history-list .history-item .item-header .shift-type{font-size:.8rem;padding:2px 8px;border-radius:4px;font-weight:500}.modal-overlay .shift-history .history-list .history-item .item-header .shift-type.regular{background:#e3f2fd;color:#1976d2}.modal-overlay .shift-history .history-list .history-item .item-header .shift-type.training{background:#f3e5f5;color:#7b1fa2}.modal-overlay .shift-history .history-list .history-item .item-header .shift-date{font-size:.8rem;color:var(--text-secondary)}.modal-overlay .shift-history .history-list .history-item .item-details{font-size:.85rem;color:var(--text-primary);line-height:1.4}.modal-overlay .shift-history .history-list .empty-history{text-align:center;padding:20px;color:var(--text-secondary);font-size:.9rem}.modal-overlay .shifts-page .modal-header{padding:16px 20px;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center;background:#fff}.modal-overlay .shifts-page .modal-header .modal-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.modal-overlay .shifts-page .modal-header .modal-close{background:none;border:none;color:#666;font-size:24px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%}.modal-overlay .shifts-page .modal-header .modal-close:hover{background:#e9ecef;color:#333}.modal-overlay .shifts-page .modal-body{padding:20px;flex:1;overflow-y:auto}.modal-overlay .shifts-page .form-group{margin-bottom:16px}.modal-overlay .shifts-page .form-group .form-label{display:block;margin-bottom:6px;font-weight:500;color:var(--text-primary);font-size:14px}.modal-overlay .shifts-page .form-group .form-input,.modal-overlay .shifts-page .form-group .form-select{width:100%;padding:10px 12px;background-color:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:14px}.modal-overlay .shifts-page .form-group .form-input:focus,.modal-overlay .shifts-page .form-group .form-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #3b82f61a}.modal-overlay .shifts-page .form-group .form-input::placeholder,.modal-overlay .shifts-page .form-group .form-select::placeholder{color:var(--text-muted)}.modal-overlay .shifts-page .form-group .form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 12px center;background-size:16px;padding-right:40px}.modal-overlay .shifts-page .searchable-select{position:relative}.modal-overlay .shifts-page .searchable-select input{width:100%;padding:10px 12px;background-color:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:14px}.modal-overlay .shifts-page .searchable-select input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #3b82f61a}.modal-overlay .shifts-page .searchable-select input::placeholder{color:var(--text-muted)}.modal-overlay .shifts-page .dropdown-options{position:absolute;top:100%;left:0;right:0;background-color:var(--surface);border:1px solid var(--border);border-radius:8px;margin-top:4px;max-height:200px;overflow-y:auto;z-index:10;display:none;box-shadow:0 4px 12px #0000001a}.modal-overlay .shifts-page .dropdown-options.active{display:block}.modal-overlay .shifts-page .option{padding:12px 14px;cursor:pointer;transition:background-color .2s;color:var(--text-primary)}.modal-overlay .shifts-page .option:hover{background-color:var(--bg-secondary)}.modal-overlay .shifts-page .accounts-list{margin-top:6px;background-color:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;padding:6px;display:none}.modal-overlay .shifts-page .accounts-list.active{display:block}.modal-overlay .shifts-page .account-item{background-color:var(--surface);border:1px solid var(--border);border-radius:4px;padding:4px 6px;margin-bottom:4px;color:var(--text-primary);font-size:12px}.modal-overlay .shifts-page .account-item:last-child{margin-bottom:0}.modal-overlay .shifts-page .modal-footer{padding:16px 20px;border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;background:#fff}.modal-overlay .shifts-page .modal-footer .btn{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;border:none;transition:all .2s}.modal-overlay .shifts-page .modal-footer .btn.btn-secondary{background:#f8f9fa;color:#6c757d;border:1px solid #dee2e6}.modal-overlay .shifts-page .modal-footer .btn.btn-secondary:hover{background:#e9ecef;color:#495057}.modal-overlay .shifts-page .modal-footer .btn.btn-primary{background:var(--primary-color);color:#fff}.modal-overlay .shifts-page .modal-footer .btn.btn-primary:hover{background:var(--primary-hover)}.modal-overlay .shifts-page .modal-footer .btn.btn-primary:disabled{background:#6c757d;cursor:not-allowed}@media (max-width: 480px){.modal-overlay .shifts-page .modal-footer{padding:12px 16px;flex-direction:column}.modal-overlay .shifts-page .modal-footer .btn{width:100%}}.modal-overlay .shifts-page .comment-textarea{width:100%;min-height:80px;background-color:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);padding:10px 12px;font-size:14px;resize:vertical;font-family:inherit}.modal-overlay .shifts-page .comment-textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #3b82f61a}.modal-overlay .shifts-page .comment-textarea::placeholder{color:var(--text-muted)}.modal-overlay .shifts-page .view-modal .form-input,.modal-overlay .shifts-page .view-modal .form-select,.modal-overlay .shifts-page .view-modal .searchable-select input{background-color:var(--bg-secondary);border:1px solid var(--border);pointer-events:none;cursor:default}.modal-overlay .shifts-page .view-modal .comment-textarea{background-color:var(--bg-secondary);pointer-events:none;cursor:default}.modal-overlay .shift-type-selector{display:flex!important;gap:8px;margin-bottom:16px}.modal-overlay .type-selector{flex:1;padding:12px 16px;text-align:center;background-color:#f8f9fa!important;border:2px solid #e9ecef!important;border-radius:8px;cursor:pointer;transition:all .2s;color:#495057!important;font-size:14px;font-weight:500;min-height:44px;display:flex!important;align-items:center;justify-content:center}.modal-overlay .type-selector.active{background-color:#3b82f6!important;border-color:#3b82f6!important;color:#fff!important;font-weight:600;box-shadow:0 2px 4px #3b82f64d}.modal-overlay .type-selector:hover:not(.active){background-color:#e9ecef!important;border-color:#3b82f6!important;color:#212529!important}.modal-overlay .shift-history{background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 8px #0000001a}.modal-overlay .shift-history .shift-history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:16px}.modal-overlay .shift-history .shift-history-header h3{margin:0;color:var(--text-primary);font-size:18px;font-weight:600}.modal-overlay .shift-history .shift-history-header .shift-history-filters{display:flex;gap:8px}.modal-overlay .shift-history .shift-history-header .shift-history-filters .filter-btn{padding:8px 16px;border:1px solid var(--border);background:var(--surface);color:var(--text-primary);border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s}.modal-overlay .shift-history .shift-history-header .shift-history-filters .filter-btn:hover{border-color:var(--primary-color);background:var(--bg-secondary)}.modal-overlay .shift-history .shift-history-header .shift-history-filters .filter-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.modal-overlay .shift-history .shift-history-loading{text-align:center;padding:40px 20px;color:var(--text-muted)}.modal-overlay .shift-history .shift-history-loading .loading-spinner{width:32px;height:32px;border:3px solid #f3f3f3;border-top:3px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}.modal-overlay .shift-history .empty-history{text-align:center;padding:60px 20px;color:var(--text-muted)}.modal-overlay .shift-history .empty-history .material-icons{font-size:48px;color:var(--text-muted);margin-bottom:16px}.modal-overlay .shift-history .empty-history p{font-size:18px;margin:0 0 8px;color:var(--text-primary)}.modal-overlay .shift-history .empty-history span{font-size:14px}.modal-overlay .shift-history .history-list{display:flex;flex-direction:column;gap:16px}.modal-overlay .shift-history .history-item{border:1px solid var(--border);border-radius:8px;overflow:hidden;transition:box-shadow .2s}.modal-overlay .shift-history .history-item:hover{box-shadow:0 4px 12px #0000001a}.modal-overlay .shift-history .history-item .history-item-header{background:var(--bg-secondary);padding:12px 16px;display:flex;justify-content:space-between;align-items:center}.modal-overlay .shift-history .history-item .history-item-header .history-date{display:flex;align-items:center;gap:8px;color:var(--text-primary);font-weight:500}.modal-overlay .shift-history .history-item .history-item-header .history-date .material-icons{font-size:18px;color:var(--text-muted)}.modal-overlay .shift-history .history-item .history-item-header .history-type{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:500}.modal-overlay .shift-history .history-item .history-item-header .history-type.shift-type-regular{background:#e3f2fd;color:#1976d2}.modal-overlay .shift-history .history-item .history-item-header .history-type.shift-type-training{background:#fff3e0;color:#f57c00}.modal-overlay .shift-history .history-item .history-item-body{padding:16px}.modal-overlay .shift-history .history-item .history-item-body .history-details{display:flex;flex-direction:column;gap:8px}.modal-overlay .shift-history .history-item .history-item-body .history-details .detail-row{display:flex;justify-content:space-between;align-items:flex-start}.modal-overlay .shift-history .history-item .history-item-body .history-details .detail-row .detail-label{color:var(--text-muted);font-size:14px;min-width:120px;flex-shrink:0}.modal-overlay .shift-history .history-item .history-item-body .history-details .detail-row .detail-value{color:var(--text-primary);font-size:14px;text-align:right;flex:1}.modal-overlay .shift-history .history-item .history-item-body .history-details .detail-row .detail-value.earnings{color:#22c55e;font-weight:600}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.modal-overlay .shift-history{padding:16px}.modal-overlay .shift-history .shift-history-header{flex-direction:column;align-items:flex-start}.modal-overlay .shift-history .shift-history-header .shift-history-filters{width:100%;justify-content:space-between}.modal-overlay .shift-history .shift-history-header .shift-history-filters .filter-btn{flex:1;text-align:center}.modal-overlay .shift-history .history-item-header{flex-direction:column;align-items:flex-start;gap:8px}.modal-overlay .shift-history .detail-row{flex-direction:column;align-items:flex-start!important;gap:4px}.modal-overlay .shift-history .detail-row .detail-value{text-align:left!important}}.modal-overlay .employee-profile-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-overlay .employee-profile-modal{background:#fff;border-radius:12px;max-width:800px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 40px #00000026}.modal-overlay .employee-profile-header{padding:24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:flex-start;gap:20px}.modal-overlay .employee-profile-header .employee-info{display:flex;gap:16px;align-items:center}.modal-overlay .employee-profile-header .employee-info .employee-avatar{width:80px;height:80px;border-radius:50%;overflow:hidden;border:3px solid var(--border)}.modal-overlay .employee-profile-header .employee-info .employee-avatar img{width:100%;height:100%;object-fit:cover}.modal-overlay .employee-profile-header .employee-info .employee-avatar .avatar-placeholder{width:100%;height:100%;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center}.modal-overlay .employee-profile-header .employee-info .employee-avatar .avatar-placeholder .material-icons{font-size:36px;color:var(--text-muted)}.modal-overlay .employee-profile-header .employee-info .employee-details h2{margin:0 0 8px;color:var(--text-primary);font-size:24px;font-weight:600}.modal-overlay .employee-profile-header .employee-info .employee-details .employee-meta{display:flex;gap:12px;align-items:center}.modal-overlay .employee-profile-header .employee-info .employee-details .employee-meta .role{background:var(--primary-color);color:#fff;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:500}.modal-overlay .employee-profile-header .employee-info .employee-details .employee-meta .status{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:500}.modal-overlay .employee-profile-header .employee-info .employee-details .employee-meta .status.status-active{background:#dcfce7;color:#166534}.modal-overlay .employee-profile-header .employee-info .employee-details .employee-meta .status.status-inactive{background:#f3f4f6;color:#6b7280}.modal-overlay .employee-profile-header .employee-info .employee-details .employee-meta .status.status-suspended{background:#fef2f2;color:#dc2626}.modal-overlay .employee-profile-header .profile-actions{display:flex;gap:8px;flex-shrink:0}.modal-overlay .employee-profile-header .profile-actions .btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:6px;font-size:14px}.modal-overlay .employee-profile-header .profile-actions .btn .material-icons{font-size:18px}.modal-overlay .employee-profile-content{flex:1;overflow-y:auto;padding:24px}.modal-overlay .employee-profile-content .profile-section{margin-bottom:32px}.modal-overlay .employee-profile-content .profile-section:last-child{margin-bottom:0}.modal-overlay .employee-profile-content .profile-section h3{margin:0 0 16px;color:var(--text-primary);font-size:18px;font-weight:600}.modal-overlay .employee-profile-content .profile-section .info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.modal-overlay .employee-profile-content .profile-section .info-grid .info-item{display:flex;flex-direction:column;gap:4px}.modal-overlay .employee-profile-content .profile-section .info-grid .info-item label{font-size:12px;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.modal-overlay .employee-profile-content .profile-section .info-grid .info-item span{font-size:14px;color:var(--text-primary)}@media (max-width: 768px){.modal-overlay .employee-profile-overlay{padding:10px}.modal-overlay .employee-profile-header{flex-direction:column;align-items:flex-start}.modal-overlay .employee-profile-header .employee-info{width:100%}.modal-overlay .employee-profile-header .employee-info .employee-avatar{width:60px;height:60px}.modal-overlay .employee-profile-header .employee-info .employee-details h2{font-size:20px}.modal-overlay .employee-profile-header .profile-actions{width:100%;justify-content:flex-end}.modal-overlay .employee-profile-content{padding:16px}.modal-overlay .employee-profile-content .info-grid{grid-template-columns:1fr}}.modal-overlay .employee-profile-modal .modal-overlay{z-index:1001!important;background:#0009!important}.modal-overlay .add-employee-modal,.modal-overlay .register-modal{max-width:400px;width:100%;max-height:calc(100vh - 40px);background:#282828f2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;box-shadow:0 20px 40px #0000004d;display:flex;flex-direction:column;position:relative}@media (max-width: 480px){.modal-overlay .add-employee-modal,.modal-overlay .register-modal{max-width:calc(100vw - 40px);max-height:calc(100vh - 40px)}}.modal-overlay .add-employee-modal .modal-header,.modal-overlay .register-modal .modal-header{padding:1.5rem 2rem 1rem;border-bottom:none;background:transparent;position:relative}.modal-overlay .add-employee-modal .modal-header .modal-title,.modal-overlay .register-modal .modal-header .modal-title{color:#fff;font-size:1.3rem;font-weight:600;margin:0;text-align:center;padding-right:40px}.modal-overlay .add-employee-modal .modal-header .modal-close,.modal-overlay .register-modal .modal-header .modal-close{position:absolute;top:1rem;right:1rem;background:#ffffff1a;border:none;color:#fff;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;font-size:16px}.modal-overlay .add-employee-modal .modal-header .modal-close:hover,.modal-overlay .register-modal .modal-header .modal-close:hover{background:#fff3;transform:scale(1.1)}.modal-overlay .add-employee-modal .modal-body,.modal-overlay .register-modal .modal-body{padding:0 2rem 1.5rem;max-height:calc(100vh - 200px);overflow-y:auto;flex:1;display:flex;flex-direction:column}.modal-overlay .add-employee-modal .form-group,.modal-overlay .register-modal .form-group{margin-bottom:1.2rem}.modal-overlay .add-employee-modal .form-group:last-child,.modal-overlay .register-modal .form-group:last-child{margin-bottom:0}.modal-overlay .add-employee-modal .form-label,.modal-overlay .register-modal .form-label{display:block;margin-bottom:.4rem;font-weight:500;color:#fff;font-size:.85rem}.modal-overlay .add-employee-modal .form-input,.modal-overlay .register-modal .form-input,.modal-overlay .add-employee-modal .form-select,.modal-overlay .register-modal .form-select{width:100%;padding:.7rem .9rem;border:1px solid rgba(255,255,255,.2);border-radius:10px;background:#ffffff0d;color:#fff;font-size:.85rem;transition:all .2s ease}.modal-overlay .add-employee-modal .form-input:focus,.modal-overlay .register-modal .form-input:focus,.modal-overlay .add-employee-modal .form-select:focus,.modal-overlay .register-modal .form-select:focus{outline:none;border-color:#3b82f699;background:#ffffff1a;box-shadow:0 0 0 2px #3b82f633}.modal-overlay .add-employee-modal .form-input::placeholder,.modal-overlay .register-modal .form-input::placeholder,.modal-overlay .add-employee-modal .form-select::placeholder,.modal-overlay .register-modal .form-select::placeholder{color:#ffffff80}.modal-overlay .add-employee-modal .form-select,.modal-overlay .register-modal .form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 12px center;background-size:16px;padding-right:40px}.modal-overlay .add-employee-modal .form-select option,.modal-overlay .register-modal .form-select option{background:#2a2a2a;color:#fff}.modal-overlay .add-employee-modal .photo-upload,.modal-overlay .register-modal .photo-upload{display:flex;justify-content:center;margin-top:.5rem}.modal-overlay .add-employee-modal .photo-upload .photo-input,.modal-overlay .register-modal .photo-upload .photo-input{display:none}.modal-overlay .add-employee-modal .photo-upload .photo-upload-label,.modal-overlay .register-modal .photo-upload .photo-upload-label{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100px;height:100px;border:2px dashed rgba(255,255,255,.3);border-radius:12px;cursor:pointer;transition:all .2s ease;background:#ffffff0d}.modal-overlay .add-employee-modal .photo-upload .photo-upload-label:hover,.modal-overlay .register-modal .photo-upload .photo-upload-label:hover{border-color:#3b82f699;background:#3b82f61a;transform:scale(1.02)}.modal-overlay .add-employee-modal .photo-upload .photo-preview,.modal-overlay .register-modal .photo-upload .photo-preview{width:100%;height:100%;object-fit:cover;border-radius:10px}.modal-overlay .add-employee-modal .photo-upload .photo-placeholder,.modal-overlay .register-modal .photo-upload .photo-placeholder{display:flex;flex-direction:column;align-items:center;gap:.3rem;color:#ffffffb3}.modal-overlay .add-employee-modal .photo-upload .photo-icon,.modal-overlay .register-modal .photo-upload .photo-icon{font-size:2rem;opacity:.8}.modal-overlay .add-employee-modal .photo-upload .photo-text,.modal-overlay .register-modal .photo-upload .photo-text{font-size:.7rem;text-align:center;font-weight:500}.modal-overlay .add-employee-modal .modal-footer,.modal-overlay .register-modal .modal-footer{display:flex!important;justify-content:flex-end!important;gap:12px!important;padding:20px 24px!important;background:#f9fafb!important;border-top:1px solid #e5e7eb!important;margin:0!important}.modal-overlay .add-employee-modal .modal-footer .btn,.modal-overlay .register-modal .modal-footer .btn,.modal-overlay .add-employee-modal .modal-footer .btn-secondary,.modal-overlay .register-modal .modal-footer .btn-secondary{padding:10px 20px!important;border:1px solid #d1d5db!important;border-radius:8px!important;background:#fff!important;color:#374151!important;cursor:pointer!important;transition:all .2s ease!important;font-weight:500!important;font-size:14px!important;display:inline-block!important;visibility:visible!important;opacity:1!important}.modal-overlay .add-employee-modal .modal-footer .btn:hover,.modal-overlay .register-modal .modal-footer .btn:hover,.modal-overlay .add-employee-modal .modal-footer .btn-secondary:hover,.modal-overlay .register-modal .modal-footer .btn-secondary:hover{background:#f9fafb!important;border-color:#9ca3af!important}.modal-overlay .add-employee-modal .modal-footer .btn-primary,.modal-overlay .register-modal .modal-footer .btn-primary{padding:10px 20px!important;border:none!important;border-radius:8px!important;background:#3b82f6!important;color:#fff!important;display:inline-block!important;visibility:visible!important;opacity:1!important;cursor:pointer!important;font-weight:500!important;font-size:14px!important;transition:all .2s ease!important;box-shadow:none!important}.modal-overlay .add-employee-modal .modal-footer .btn-primary:hover,.modal-overlay .register-modal .modal-footer .btn-primary:hover{background:#2563eb!important}.modal-overlay .employee-action-btn{cursor:pointer!important;border:1px solid #d1d5db!important;background:#fff!important;font-size:18px!important;padding:6px 10px!important;border-radius:6px!important;color:#374151!important;transition:all .2s ease!important;pointer-events:auto!important;z-index:999!important;position:relative!important;min-width:32px!important;min-height:32px!important;display:inline-flex!important;align-items:center!important;justify-content:center!important}.modal-overlay .employee-action-btn:hover{background:#f3f4f6!important;border-color:#9ca3af!important;color:#111827!important;transform:scale(1.05)!important}.modal-overlay .employee-action-btn:active{background:#e5e7eb!important;transform:scale(.95)!important}.modal-overlay .address-modal .modal-footer{display:flex!important;justify-content:flex-end!important;gap:12px!important;padding:20px 24px!important;background:#f9fafb!important;border-top:1px solid #e5e7eb!important}.modal-overlay .address-modal .modal-footer .btn{padding:10px 20px!important;border-radius:8px!important;font-size:14px!important;font-weight:500!important;cursor:pointer!important;display:inline-block!important;visibility:visible!important;opacity:1!important;min-width:80px!important;text-align:center!important}.modal-overlay .address-modal .modal-footer .btn.btn-secondary{background:#fff!important;color:#374151!important;border:1px solid #d1d5db!important}.modal-overlay .address-modal .modal-footer .btn.btn-secondary:hover{background:#f9fafb!important;border-color:#9ca3af!important}.modal-overlay .address-modal .modal-footer .btn.btn-primary{background:#3b82f6!important;color:#fff!important;border:none!important}.modal-overlay .address-modal .modal-footer .btn.btn-primary:hover{background:#2563eb!important}.modal-overlay .register-modal .modal-header .modal-title{text-align:center;padding-right:0;width:100%}.modal-overlay .register-modal .password-group{position:relative;display:flex;align-items:center;gap:.5rem}.modal-overlay .register-modal .password-group .form-input{flex:1}.modal-overlay .register-modal .password-group .btn-generate-password{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;font-size:1.2rem}.modal-overlay .register-modal .password-group .btn-generate-password:hover{background:#3b82f633;border-color:#3b82f666;transform:scale(1.05)}.modal-overlay .register-modal .password-group .btn-generate-password:active{transform:scale(.95)}.modal-overlay .register-link{text-align:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1)}.modal-overlay .register-link p{color:#ffffffb3;margin:0 0 .5rem;font-size:.9rem}.modal-overlay .register-link .btn-link{background:none;border:none;color:#3b82f6;text-decoration:underline;cursor:pointer;font-size:.9rem;transition:color .2s ease}.modal-overlay .register-link .btn-link:hover{color:#60a5fa}.material-icons{font-family:Material Icons!important;font-weight:400!important;font-style:normal!important;font-size:24px!important;line-height:1!important;letter-spacing:normal!important;text-transform:none!important;display:inline-block!important;white-space:nowrap!important;word-wrap:normal!important;direction:ltr!important;-webkit-font-feature-settings:"liga"!important;font-feature-settings:"liga"!important;-webkit-font-smoothing:antialiased!important}.apartments-page{padding:24px!important;background-color:#f8fafc!important;min-height:100vh!important}.apartments-page .page-header{display:flex!important;justify-content:space-between!important;align-items:flex-start!important;margin-bottom:24px!important;padding:24px!important;background:#fff!important;border-radius:12px!important;box-shadow:0 1px 3px #0000001a!important}.apartments-page .page-header .header-left .page-title{display:flex!important;align-items:center!important;gap:12px!important;margin:0 0 12px!important;font-size:28px!important;font-weight:600!important;color:#1f2937!important}.apartments-page .page-header .header-left .page-title .material-icons{font-size:32px!important;color:#3b82f6!important}.apartments-page .page-header .header-left .header-stats{display:flex!important;gap:24px!important}.apartments-page .page-header .header-left .header-stats .stat{color:#6b7280!important;font-size:14px!important}.apartments-page .page-header .header-left .header-stats .stat strong{color:#1f2937!important;font-weight:600!important}.apartments-page .page-header .header-right .btn{display:flex!important;align-items:center!important;gap:8px!important}.apartments-page .filters-section{margin-bottom:24px!important;padding:20px 24px!important;background:#fff!important;border-radius:12px!important;box-shadow:0 1px 3px #0000001a!important}.apartments-page .filters-section .search-container{position:relative!important;max-width:400px!important}.apartments-page .filters-section .search-container .material-icons{position:absolute!important;left:12px!important;top:50%!important;transform:translateY(-50%)!important;color:#9ca3af!important;font-size:20px!important}.apartments-page .filters-section .search-container .search-input{width:100%!important;padding:12px 12px 12px 44px!important;border:1px solid #d1d5db!important;border-radius:8px!important;font-size:14px!important;background:#fff!important}.apartments-page .filters-section .search-container .search-input:focus{outline:none!important;border-color:#3b82f6!important;box-shadow:0 0 0 3px #3b82f61a!important}.apartments-page .filters-section .search-container .search-input::placeholder{color:#9ca3af!important}.apartments-page .content-section .empty-state{text-align:center!important;padding:60px 24px!important;background:#fff!important;border-radius:12px!important;box-shadow:0 1px 3px #0000001a!important}.apartments-page .content-section .empty-state .material-icons{font-size:64px!important;color:#d1d5db!important;margin-bottom:16px!important}.apartments-page .content-section .empty-state h3{margin:0 0 8px!important;font-size:20px!important;font-weight:600!important;color:#1f2937!important}.apartments-page .content-section .empty-state p{margin:0 0 24px!important;color:#6b7280!important;font-size:16px!important}.apartments-page .content-section .empty-state .btn{display:inline-flex!important;align-items:center!important;gap:8px!important}.apartments-page .content-section .addresses-grid{display:grid!important;gap:24px!important;grid-template-columns:repeat(auto-fill,minmax(400px,1fr))!important}.apartments-page .content-section .addresses-grid .address-card{background:#fff!important;border-radius:12px!important;box-shadow:0 1px 3px #0000001a!important;overflow:hidden!important;transition:box-shadow .2s ease!important}.apartments-page .content-section .addresses-grid .address-card:hover{box-shadow:0 4px 12px #00000026!important}.apartments-page .content-section .addresses-grid .address-card .address-header{display:flex!important;justify-content:space-between!important;align-items:flex-start!important;padding:20px 24px 16px!important;border-bottom:1px solid #f3f4f6!important}.apartments-page .content-section .addresses-grid .address-card .address-header .address-info .address-title{display:flex!important;align-items:center!important;gap:12px!important;margin:0 0 8px!important;font-size:18px!important;font-weight:600!important;color:#1f2937!important}.apartments-page .content-section .addresses-grid .address-card .address-header .address-info .address-title .material-icons{font-size:20px!important;color:#ef4444!important}.apartments-page .content-section .addresses-grid .address-card .address-header .address-info .address-comment{font-size:14px!important;color:#6b7280!important;font-style:italic!important;margin-top:4px!important;display:block!important}.apartments-page .content-section .addresses-grid .address-card .address-header .address-actions .btn{display:flex!important;align-items:center!important;justify-content:center!important;width:32px!important;height:32px!important;padding:0!important;border-radius:6px!important}.apartments-page .content-section .addresses-grid .address-card .address-header .address-actions .btn .material-icons{font-size:16px!important}.apartments-page .content-section .addresses-grid .address-card .rooms-list{padding:0!important}.apartments-page .content-section .addresses-grid .address-card .rooms-list .room-item{display:flex!important;justify-content:space-between!important;align-items:center!important;padding:16px 24px!important;border-bottom:1px solid #f3f4f6!important;transition:background-color .2s ease!important}.apartments-page .content-section .addresses-grid .address-card .rooms-list .room-item:last-child{border-bottom:none!important}.apartments-page .content-section .addresses-grid .address-card .rooms-list .room-item:hover{background-color:#f9fafb!important}.apartments-page .content-section .addresses-grid .address-card .rooms-list .room-item .room-info{display:flex!important;align-items:center!important;gap:12px!important}.apartments-page .content-section .addresses-grid .address-card .rooms-list .room-item .room-info .material-icons{font-size:20px!important;color:#8b5cf6!important}.apartments-page .content-section .addresses-grid .address-card .rooms-list .room-item .room-info .room-name{font-weight:500!important;color:#1f2937!important}.apartments-page .content-section .addresses-grid .address-card .rooms-list .room-item .room-comment{display:block!important;font-size:12px!important;color:#6b7280!important;font-style:italic!important;margin-top:4px!important;line-height:1.3!important}.apartments-page .content-section .addresses-grid .address-card .rooms-list .room-item .room-actions{display:flex!important;gap:8px!important;pointer-events:auto!important;z-index:5!important;position:relative!important}.apartments-page .content-section .addresses-grid .address-card .rooms-list .room-item .room-actions .btn{display:flex!important;align-items:center!important;justify-content:center!important;width:32px!important;height:32px!important;padding:0!important;border-radius:6px!important;cursor:pointer!important;pointer-events:auto!important;z-index:10!important;position:relative!important}.apartments-page .content-section .addresses-grid .address-card .rooms-list .room-item .room-actions .btn .material-icons{font-size:16px!important}.apartments-page .content-section .addresses-grid .address-card .rooms-list .room-item .room-actions .btn.btn-secondary{background-color:#f3f4f6!important;border-color:#f3f4f6!important;color:#6b7280!important}.apartments-page .content-section .addresses-grid .address-card .rooms-list .room-item .room-actions .btn.btn-secondary:hover{background-color:#e5e7eb!important;border-color:#e5e7eb!important;color:#374151!important}.apartments-page .content-section .addresses-grid .address-card .rooms-list .room-item .room-actions .btn.btn-danger{background-color:#fef2f2!important;border-color:#fef2f2!important;color:#dc2626!important}.apartments-page .content-section .addresses-grid .address-card .rooms-list .room-item .room-actions .btn.btn-danger:hover{background-color:#fee2e2!important;border-color:#fee2e2!important;color:#b91c1c!important}.role-management .permissions-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}@media (max-width: 479px){.role-management .permissions-table-container{margin:0 -16px;border-radius:0}}.role-management .permissions-table{min-width:800px}@media (max-width: 479px){.role-management .permissions-table{min-width:600px;font-size:12px}}@media (max-width: 479px){.role-management .permissions-table .role-header{padding:8px 4px}.role-management .permissions-table .role-header .role-name{font-size:11px}.role-management .permissions-table .role-header .role-code{font-size:10px}}@media (max-width: 479px){.role-management .permissions-table .permission-row .permission-name{padding:8px 12px;font-size:11px}}@media (max-width: 479px){.role-management .permissions-table .permission-row .permission-cell{padding:8px 4px}}@media (max-width: 479px){.nav{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);padding:8px 0;z-index:100;justify-content:space-around;box-shadow:0 -2px 10px #0000001a}.nav-link{display:flex;flex-direction:column;align-items:center;gap:4px;font-size:10px;padding:8px 4px}.nav-link:before{content:"";width:20px;height:20px;background-size:contain;background-repeat:no-repeat;background-position:center}.nav-link[href="/models"]:before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='currentColor'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M12 4.354a4 4 0 110 5.292M15 21H3v-1a6 6 0 0112 0v1zm0 0h6v-1a6 6 0 00-9-5.197m13.5-9a2.5 2.5 0 11-5 0 2.5 2.5 0 015 0z'/%3E%3C/svg%3E")}.nav-link[href="/slots"]:before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='currentColor'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M8 7V3m8 4V3m-9 8h10M5 21h14a2 2 0 002-2V7a2 2 0 00-2-2H5a2 2 0 00-2 2v12a2 2 0 002 2z'/%3E%3C/svg%3E")}.nav-link[href="/shifts"]:before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='currentColor'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M12 8v4l3 3m6-3a9 9 0 11-18 0 9 9 0 0118 0z'/%3E%3C/svg%3E")}.nav-link[href="/analytics"]:before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='currentColor'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M9 19v-6a2 2 0 00-2-2H5a2 2 0 00-2 2v6a2 2 0 002 2h2a2 2 0 002-2zm0 0V9a2 2 0 012-2h2a2 2 0 012 2v10m-6 0a2 2 0 002 2h2a2 2 0 002-2m0 0V5a2 2 0 012-2h2a2 2 0 012 2v14a2 2 0 01-2 2h-2a2 2 0 01-2-2z'/%3E%3C/svg%3E")}.nav-link.active:after{display:none}.nav-link.active{color:var(--primary);background:#007aff1a;border-radius:8px}}@media (max-width: 479px){.main{padding-bottom:80px}}@media (max-width: 479px){.header .header-content{padding:8px 0}.header .logo{font-size:16px}.header .header-user .username{display:none}}@media (max-width: 479px){.form-group{margin-bottom:16px}.form-group label{font-size:14px;margin-bottom:6px}.form-group input,.form-group textarea,.form-group select{padding:10px 12px;font-size:16px}}@media (max-width: 479px){.card{padding:16px;margin-bottom:12px}}@media (max-width: 479px){.models-grid{grid-template-columns:1fr;gap:12px}}@media (min-width: 480px) and (max-width: 767px){.models-grid{grid-template-columns:repeat(2,1fr);gap:16px}}@media (max-width: 479px){.dashboard-page{padding:12px}}@media (max-width: 479px){.dashboard-page .metrics-grid{grid-template-columns:1fr;gap:12px}}@media (min-width: 480px) and (max-width: 767px){.dashboard-page .metrics-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 479px){.employees-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -12px;border-radius:0}}@media (max-width: 479px){.employees-table{min-width:600px;font-size:12px}.employees-table th,.employees-table td{padding:8px 6px}.employees-table .employee-info{gap:8px}.employees-table .employee-avatar{width:32px;height:32px;font-size:14px}.employees-table .employee-name{font-size:12px}.employees-table .employee-username{font-size:10px}}@media (max-width: 479px){.audit-filters .filters-grid{grid-template-columns:1fr;gap:12px}}@media (min-width: 480px) and (max-width: 767px){.audit-filters .filters-grid{grid-template-columns:repeat(2,1fr)}}@media (hover: none) and (pointer: coarse){.btn{min-height:44px;padding:12px 20px}.slot-chip,.nav-link,.dropdown-menu-item{min-height:44px;padding:12px 16px}}@media (max-width: 768px) and (orientation: landscape){.header{position:sticky;top:0;z-index:101}.nav{display:none}.main{padding-bottom:20px}}@media print{.nav,.header-user,.btn,.modal{display:none!important}.main{padding:0}.card{break-inside:avoid;box-shadow:none;border:1px solid #ccc}}.mobile-nav{display:none}@media (max-width: 768px){.mobile-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);padding:8px 0 calc(8px + env(safe-area-inset-bottom));z-index:1000;justify-content:space-around;box-shadow:0 -2px 10px #0000001a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 12px;border-radius:8px;text-decoration:none;color:var(--text-secondary);font-size:11px;font-weight:500;transition:all .2s ease;min-width:60px}.mobile-nav-item:hover{color:var(--text-primary);background:var(--light)}.mobile-nav-item.active{color:var(--primary);background:#007aff1a}.mobile-nav-item .icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center}.mobile-nav-item .icon svg{width:20px;height:20px;stroke-width:2}.mobile-nav-item .label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}@media (max-width: 768px){.layout .main{padding-bottom:calc(80px + env(safe-area-inset-bottom))}.nav{display:none}.header .header-content{padding:12px 0}.header .header-content .nav{display:none}.header .logo{font-size:18px}.header .header-user{gap:8px}.header .header-user .username{display:none}.header .header-user .btn{padding:6px 12px;font-size:12px}}@media (min-width: 769px) and (max-width: 1024px){.nav{gap:20px}.nav-link{font-size:14px;padding:8px 12px}.header-content{padding:14px 0}}@supports (padding-bottom: env(safe-area-inset-bottom)){.mobile-nav{padding-bottom:calc(8px + env(safe-area-inset-bottom))}@media (max-width: 768px){.layout .main{padding-bottom:calc(80px + env(safe-area-inset-bottom))}}}.desktop-only{display:block}.mobile-only{display:none}@media (max-width: 768px){.desktop-only{display:none!important}.mobile-only{display:block!important}.slots-layout{flex-direction:column}.slots-layout .slots-sidebar{order:2;width:100%;margin-top:1rem}.slots-layout .slots-sidebar .month-card,.slots-layout .slots-sidebar .legend{display:none}.slots-layout .slots-sidebar .create-slot-btn{margin-bottom:1rem}.slots-layout .slots-main{order:1;width:100%}.slots-layout .slots-main .day-header{text-align:center;margin-bottom:1rem}.slots-layout .slots-main .day-header h3{font-size:1.2rem}.mobile-create-btn{width:100%;padding:.75rem;font-size:1rem;border-radius:8px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border:none;cursor:pointer;transition:all .2s ease}.mobile-create-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.mobile-table-wrapper .table{display:none}.mobile-table-wrapper .mobile-table-cards{display:block}}@media (min-width: 769px){.mobile-table-cards{display:none}}.mobile-table-cards{display:none;flex-direction:column;gap:12px}.mobile-table-cards .mobile-table-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;box-shadow:var(--shadow-sm)}.mobile-table-cards .mobile-table-card .card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border)}.mobile-table-cards .mobile-table-card .card-header .card-title{font-weight:600;font-size:16px;color:var(--text-primary)}.mobile-table-cards .mobile-table-card .card-header .card-status{font-size:12px;padding:4px 8px;border-radius:12px;font-weight:500}.mobile-table-cards .mobile-table-card .card-body{display:flex;flex-direction:column;gap:8px}.mobile-table-cards .mobile-table-card .card-body .card-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0}.mobile-table-cards .mobile-table-card .card-body .card-row .label{font-size:13px;color:var(--text-secondary);font-weight:500;min-width:80px}.mobile-table-cards .mobile-table-card .card-body .card-row .value{font-size:14px;color:var(--text-primary);text-align:right;flex:1;word-break:break-word}.mobile-table-cards .mobile-table-card .card-actions{margin-top:12px;padding-top:8px;border-top:1px solid var(--border);display:flex;gap:8px;flex-wrap:wrap}.mobile-table-cards .mobile-table-card .card-actions .btn{flex:1;min-width:80px;font-size:12px;padding:6px 12px}.audit-mobile-card .card-header .card-title{font-family:monospace;font-size:14px}.audit-mobile-card .card-row.details-row{flex-direction:column;align-items:flex-start;gap:4px}.audit-mobile-card .card-row.details-row .label{min-width:auto}.audit-mobile-card .card-row.details-row .value{text-align:left;font-size:12px;background:var(--light);padding:8px;border-radius:6px;width:100%;font-family:monospace;white-space:pre-wrap;word-break:break-all}.analytics-mobile-card .metric-value{font-size:18px;font-weight:700;color:var(--primary)}.analytics-mobile-card .metric-change{font-size:12px;padding:2px 6px;border-radius:8px}.analytics-mobile-card .metric-change.positive{background:#e5ffe5;color:#0c0}.analytics-mobile-card .metric-change.negative{background:#ffe5e5;color:#c00}.employees-mobile-card .card-header .employee-info{display:flex;align-items:center;gap:12px}.employees-mobile-card .card-header .employee-info .employee-avatar{width:40px;height:40px;border-radius:50%;background:var(--light);display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--text-secondary)}.employees-mobile-card .card-header .employee-info .employee-details .employee-name{font-weight:600;font-size:14px;color:var(--text-primary)}.employees-mobile-card .card-header .employee-info .employee-details .employee-username{font-size:12px;color:var(--text-secondary)}@media (max-width: 768px){.role-management .permissions-table-container{display:none}.role-management .mobile-roles-container{display:block}}@media (min-width: 769px){.role-management .mobile-roles-container{display:none}}.mobile-roles-container{display:none}.mobile-roles-container .role-section{margin-bottom:24px}.mobile-roles-container .role-section .role-header{background:var(--primary);color:#fff;padding:16px;border-radius:12px 12px 0 0}.mobile-roles-container .role-section .role-header .role-name{font-size:18px;font-weight:600}.mobile-roles-container .role-section .role-header .role-code{font-size:14px;opacity:.8}.mobile-roles-container .role-section .modules-list{background:var(--surface);border:1px solid var(--border);border-top:none;border-radius:0 0 12px 12px}.mobile-roles-container .role-section .modules-list .module-item{padding:16px;border-bottom:1px solid var(--border)}.mobile-roles-container .role-section .modules-list .module-item:last-child{border-bottom:none}.mobile-roles-container .role-section .modules-list .module-item .module-name{font-weight:600;font-size:16px;color:var(--text-primary);margin-bottom:12px}.mobile-roles-container .role-section .modules-list .module-item .permissions-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.mobile-roles-container .role-section .modules-list .module-item .permissions-grid .permission-item{display:flex;align-items:center;gap:8px;padding:8px;background:var(--light);border-radius:8px}.mobile-roles-container .role-section .modules-list .module-item .permissions-grid .permission-item input[type=checkbox]{margin:0}.mobile-roles-container .role-section .modules-list .module-item .permissions-grid .permission-item label{font-size:13px;color:var(--text-primary);margin:0;cursor:pointer}@media (max-width: 768px){.slots-page .day-grid .time-column .time-stack .slot-chip{padding:12px}.slots-page .day-grid .time-column .time-stack .slot-chip .chip-title{font-size:13px;line-height:1.2}.slots-page .day-grid .time-column .time-stack .slot-chip .chip-sub{font-size:11px;margin-top:4px}.slots-page .day-grid .time-column .time-stack .slot-chip .registration-badge{font-size:12px}}@media (max-width: 768px){.responsive-table{overflow-x:auto;-webkit-overflow-scrolling:touch}.responsive-table table{min-width:600px;font-size:12px}.responsive-table table th,.responsive-table table td{padding:8px 6px;white-space:nowrap}.responsive-table table th{font-size:11px;position:sticky;top:0;background:var(--light);z-index:10}}.mobile-table-cards .loading-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px}.mobile-table-cards .loading-card .skeleton{background:linear-gradient(90deg,var(--light) 25%,rgba(255,255,255,.5) 50%,var(--light) 75%);background-size:200% 100%;animation:loading 1.5s infinite;border-radius:4px}.mobile-table-cards .loading-card .skeleton.title{height:20px;width:60%;margin-bottom:12px}.mobile-table-cards .loading-card .skeleton.line{height:14px;margin-bottom:8px}.mobile-table-cards .loading-card .skeleton.line:nth-child(2){width:80%}.mobile-table-cards .loading-card .skeleton.line:nth-child(3){width:65%}.mobile-table-cards .loading-card .skeleton.line:nth-child(4){width:90%}@keyframes loading{0%{background-position:-200% 0}to{background-position:200% 0}}@font-face{font-family:SF Pro Display;src:url(/fonts/SF-Pro-Display-Ultralight.otf) format("opentype");font-weight:100;font-style:normal}.password-grid{display:grid;grid-template-columns:1fr auto;gap:8px}.photo-picker-wrap{display:flex;align-items:center}.photo-input-hidden{display:none}.photo-picker{display:inline-flex;align-items:center;justify-content:center;width:160px;height:120px;border:1px dashed var(--border);border-radius:10px;background:var(--surface);color:var(--text-secondary);cursor:pointer}.photo-preview{max-width:100%;max-height:100%;border-radius:8px}.photo-placeholder{display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--text-secondary)}@font-face{font-family:SF Pro Display;src:url(/fonts/SF-Pro-Display-UltralightItalic.otf) format("opentype");font-weight:100;font-style:italic}@font-face{font-family:SF Pro Display;src:url(/fonts/SF-Pro-Display-Thin.otf) format("opentype");font-weight:200;font-style:normal}@font-face{font-family:SF Pro Display;src:url(/fonts/SF-Pro-Display-ThinItalic.otf) format("opentype");font-weight:200;font-style:italic}@font-face{font-family:SF Pro Display;src:url(/fonts/SF-Pro-Display-Light.otf) format("opentype");font-weight:300;font-style:normal}@font-face{font-family:SF Pro Display;src:url(/fonts/SF-Pro-Display-LightItalic.otf) format("opentype");font-weight:300;font-style:italic}@font-face{font-family:SF Pro Display;src:url(/fonts/SF-Pro-Display-Regular.otf) format("opentype");font-weight:400;font-style:normal}@font-face{font-family:SF Pro Display;src:url(/fonts/SF-Pro-Display-RegularItalic.otf) format("opentype");font-weight:400;font-style:italic}@font-face{font-family:SF Pro Display;src:url(/fonts/SF-Pro-Display-Medium.otf) format("opentype");font-weight:500;font-style:normal}@font-face{font-family:SF Pro Display;src:url(/fonts/SF-Pro-Display-MediumItalic.otf) format("opentype");font-weight:500;font-style:italic}@font-face{font-family:SF Pro Display;src:url(/fonts/SF-Pro-Display-Semibold.otf) format("opentype");font-weight:600;font-style:normal}@font-face{font-family:SF Pro Display;src:url(/fonts/SF-Pro-Display-SemiboldItalic.otf) format("opentype");font-weight:600;font-style:italic}@font-face{font-family:SF Pro Display;src:url(/fonts/SF-Pro-Display-Bold.otf) format("opentype");font-weight:700;font-style:normal}@font-face{font-family:SF Pro Display;src:url(/fonts/SF-Pro-Display-BoldItalic.otf) format("opentype");font-weight:700;font-style:italic}@font-face{font-family:SF Pro Display;src:url(/fonts/SF-Pro-Display-Heavy.otf) format("opentype");font-weight:800;font-style:normal}@font-face{font-family:SF Pro Display;src:url(/fonts/SF-Pro-Display-HeavyItalic.otf) format("opentype");font-weight:800;font-style:italic}@font-face{font-family:SF Pro Display;src:url(/fonts/SF-Pro-Display-Black.otf) format("opentype");font-weight:900;font-style:normal}@font-face{font-family:SF Pro Display;src:url(/fonts/SF-Pro-Display-BlackItalic.otf) format("opentype");font-weight:900;font-style:italic}*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #007AFF;--secondary: #5856D6;--success: #34C759;--warning: #FF9500;--danger: #FF3B30;--dark: #1C1C1E;--light: #F2F2F7;--gray: #8E8E93;--white: #FFFFFF;--background: #F2F2F7;--surface: #FFFFFF;--text-primary: #000000;--text-secondary: #8E8E93;--border: #C6C6C8;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 30px rgba(0, 0, 0, .15);--radius: 12px;--transition: all .3s ease}[data-theme=dark]{--background: #000000;--surface: #1C1C1E;--text-primary: #FFFFFF;--text-secondary: #8E8E93;--border: #38383A}body{font-family:SF Pro Display,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--background);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;flex-direction:column}.container{max-width:1280px;margin:0 auto;padding:0 24px}@media (max-width: 768px){.container{padding:0 16px}}@media (max-width: 480px){.container{padding:0 12px}}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 20px;border:none;border-radius:var(--radius);font-size:16px;font-weight:500;cursor:pointer;transition:var(--transition);text-decoration:none;outline:none}@media (max-width: 768px){.btn{padding:8px 16px;font-size:14px}}@media (max-width: 480px){.btn{padding:6px 12px;font-size:13px}}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:#0051d5}.btn-secondary{background:var(--light);color:var(--text-primary)}.btn-secondary:hover{background:#e5e5ea}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#d70015}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#30b350}.btn-sm{padding:6px 12px;font-size:14px}.btn-lg{padding:14px 28px;font-size:18px}.btn-block{width:100%}.btn:disabled{opacity:.5;cursor:not-allowed}.card{background:var(--surface);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm);transition:var(--transition)}.card:hover{box-shadow:var(--shadow-md)}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:var(--text-primary)}.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text-primary);font-size:16px;transition:var(--transition)}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #007aff1a}.form-group input::placeholder,.form-group textarea::placeholder,.form-group select::placeholder{color:var(--text-secondary)}.form-group textarea{resize:vertical;min-height:120px}.status-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:20px;font-size:13px;font-weight:500;background:var(--light);color:var(--text-primary)}.status-badge.not_confirmed{background:#ffe5e5;color:#c00}.status-badge.no_show{background:#ffd5d5;color:#a00}.status-badge.arrived{background:#d5ffd5;color:#0a0}.status-badge.confirmed{background:#e5f5ff;color:#06c}.status-badge.drained{background:#fff5e5;color:#c60}.status-badge.registered{background:#e5ffe5;color:#0c0}.status-badge.candidate_refused{background:#ffe5f5;color:#c06}.status-badge.our_refusal{background:#f5e5ff;color:#60c}.status-badge.thinking{background:#fffacd;color:#980}.modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}@media (max-width: 768px){.modal{padding:20px 12px 12px;align-items:flex-start}}@media (max-width: 480px){.modal{padding:16px 8px 8px}}.modal-content{background:var(--surface);border-radius:var(--radius);padding:32px;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}@media (max-width: 768px){.modal-content{padding:24px;width:95%;max-height:85vh;border-radius:8px}}@media (max-width: 480px){.modal-content{padding:16px;width:100%;max-height:90vh;border-radius:6px}}.modal-content .form-group input,.modal-content .form-group textarea,.modal-content .form-group select{background:var(--surface);color:var(--text-primary);border:1px solid var(--border)}.modal-content .form-group input::placeholder,.modal-content .form-group textarea::placeholder{color:var(--text-secondary)}.modal-content input:-webkit-autofill,.modal-content input:-webkit-autofill:hover,.modal-content input:-webkit-autofill:focus,.modal-content textarea:-webkit-autofill,.modal-content select:-webkit-autofill{-webkit-text-fill-color:var(--text-primary);-webkit-box-shadow:0 0 0px 1000px var(--surface) inset;transition:background-color 9999s ease-in-out 0s}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.modal-header h2{font-size:24px;font-weight:600}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--text-secondary);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:var(--transition)}.modal-close:hover{background:var(--light)}.modal-footer{display:flex;justify-content:flex-end;gap:12px;margin-top:24px}.table{width:100%;border-collapse:collapse}@media (max-width: 768px){.table{font-size:14px}}@media (max-width: 480px){.table{font-size:12px}}.table thead{background:var(--light)}.table thead th{padding:12px;text-align:left;font-weight:600;color:var(--text-primary);border-bottom:2px solid var(--border)}@media (max-width: 768px){.table thead th{padding:8px}}@media (max-width: 480px){.table thead th{padding:6px;font-size:11px}}.table tbody tr{border-bottom:1px solid var(--border);transition:var(--transition)}.table tbody tr:hover{background:var(--light)}.table tbody td{padding:12px;color:var(--text-primary)}@media (max-width: 768px){.table tbody td{padding:8px}}@media (max-width: 480px){.table tbody td{padding:6px}}.grid{display:grid;gap:24px}.grid-cols-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid-cols-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.grid-cols-4{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.loading{display:flex;align-items:center;justify-content:center;padding:48px}.loading-spinner{width:48px;height:48px;border:4px solid var(--light);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:48px}.empty-state svg{width:120px;height:120px;margin-bottom:24px;opacity:.3}.empty-state h3{font-size:20px;margin-bottom:12px;color:var(--text-primary)}.empty-state p{color:var(--text-secondary);margin-bottom:24px}.tabs{display:flex;gap:8px;border-bottom:1px solid var(--border);margin-bottom:24px}.tabs-tab{padding:12px 24px;background:none;border:none;color:var(--text-secondary);font-size:16px;font-weight:500;cursor:pointer;position:relative;transition:var(--transition)}.tabs-tab:hover{color:var(--text-primary)}.tabs-tab.active{color:var(--primary)}.tabs-tab.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--primary)}.dropdown{position:relative;display:inline-block}.dropdown-menu{position:absolute;top:100%;right:0;margin-top:8px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);min-width:200px;z-index:100}.dropdown-menu-item{padding:12px 16px;color:var(--text-primary);cursor:pointer;transition:var(--transition)}.dropdown-menu-item:hover{background:var(--light)}.dropdown-menu-item:first-child{border-radius:var(--radius) var(--radius) 0 0}.dropdown-menu-item:last-child{border-radius:0 0 var(--radius) var(--radius)}
