@import "https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&display=swap";:root{--color-primary-dark:#0f2d5c;--color-primary:#1e4d9b;--color-primary-light:#ebf1fa;--color-accent-red:#d62828;--color-accent-red-light:#fce8e6;--color-bg:#f5f7fa;--color-card-bg:#fff;--color-text-dark:#1e293b;--color-text-muted:#64748b;--color-text-light:#94a3b8;--border-color:#e2e8f0;--shadow-sm:0 1px 3px 0 #0f172a0d;--shadow-md:0 4px 6px -1px #0f172a0d, 0 2px 4px -2px #0f172a0d;--shadow-lg:0 10px 15px -3px #0f172a0a, 0 4px 6px -4px #0f172a0a;--font-main:"Poppins", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--transition-fast:all .15s ease-in-out;--transition-normal:all .25s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-main);background-color:var(--color-bg);color:var(--color-text-dark);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}.app-container{width:100vw;min-height:100vh;display:flex;position:relative}.sidebar{background-color:var(--color-card-bg);border-right:1px solid var(--border-color);z-index:100;width:260px;height:100vh;transition:var(--transition-normal);flex-direction:column;display:flex;position:fixed;top:0;left:0}.sidebar-brand{border-bottom:1px solid var(--border-color);align-items:center;gap:12px;padding:24px;display:flex}.sidebar-logo-img{background-color:var(--color-primary-dark);color:#fff;letter-spacing:1px;border-radius:8px;justify-content:center;align-items:center;width:44px;height:44px;font-size:16px;font-weight:700;display:flex}.sidebar-logo-text{color:var(--color-primary-dark);font-size:16px;font-weight:700;line-height:1.2}.sidebar-logo-subtext{color:var(--color-accent-red);text-transform:uppercase;letter-spacing:1.5px;font-size:11px;font-weight:500}.sidebar-section-title{color:var(--color-text-light);text-transform:uppercase;letter-spacing:1.5px;padding:20px 24px 8px;font-size:11px;font-weight:600}.sidebar-menu{flex:1;padding:0 12px;list-style:none;overflow-y:auto}.sidebar-menu-item{margin-bottom:4px}.sidebar-menu-link{color:var(--color-text-muted);transition:var(--transition-fast);cursor:pointer;border-left:3px solid #0000;border-radius:8px;align-items:center;gap:12px;padding:12px 16px;font-size:14px;font-weight:500;text-decoration:none;display:flex}.sidebar-menu-link:hover{background-color:var(--color-bg);color:var(--color-primary)}.sidebar-menu-link.active{background-color:var(--color-primary-light);color:var(--color-primary);border-left-color:var(--color-primary);font-weight:600}.sidebar-menu-link.active svg{color:var(--color-primary)}.sidebar-footer{border-top:1px solid var(--border-color);padding:16px 20px}.sidebar-logout{color:var(--color-accent-red);transition:var(--transition-fast);cursor:pointer;border-radius:8px;align-items:center;gap:12px;padding:12px 16px;font-size:14px;font-weight:600;text-decoration:none;display:flex}.sidebar-logout:hover{background-color:var(--color-accent-red-light)}.main-content{min-height:100vh;transition:var(--transition-normal);flex-direction:column;flex:1;gap:28px;margin-left:260px;padding:32px;display:flex}.header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.header-breadcrumbs{text-transform:uppercase;letter-spacing:1px;color:var(--color-text-light);align-items:center;gap:8px;font-size:11px;font-weight:600;display:flex}.header-title-container{flex-direction:column;gap:4px;display:flex}.header-title{color:var(--color-primary-dark);font-size:26px;font-weight:700}.header-actions{align-items:center;gap:16px;display:flex}.role-badge-selector{background-color:var(--color-card-bg);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);border-radius:30px;align-items:center;gap:8px;padding:6px 12px;display:flex}.role-badge-label{color:var(--color-text-muted);text-transform:uppercase;font-size:11px;font-weight:600}.role-badge-select{color:var(--color-primary);cursor:pointer;background:0 0;border:none;outline:none;padding-right:8px;font-size:13px;font-weight:600}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;display:grid}.kpi-card{background-color:var(--color-card-bg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);border-radius:12px;justify-content:space-between;align-items:center;padding:24px;transition:transform .2s,box-shadow .2s;display:flex;position:relative;overflow:hidden}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.kpi-card:before{content:"";background-color:var(--color-primary);width:4px;height:100%;position:absolute;top:0;left:0}.kpi-card.kpi-red:before{background-color:var(--color-accent-red)}.kpi-card.kpi-green:before{background-color:#10b981}.kpi-card.kpi-orange:before{background-color:#f59e0b}.kpi-card.kpi-purple:before{background-color:#8b5cf6}.kpi-content{flex-direction:column;gap:4px;display:flex}.kpi-value{color:var(--color-primary-dark);font-size:30px;font-weight:700;line-height:1.1}.kpi-title{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.kpi-icon-container{width:48px;height:48px;color:var(--color-primary);background-color:var(--color-primary-light);border-radius:50%;justify-content:center;align-items:center;display:flex}.kpi-card.kpi-red .kpi-icon-container{color:var(--color-accent-red);background-color:var(--color-accent-red-light)}.kpi-card.kpi-green .kpi-icon-container{color:#10b981;background-color:#ecfdf5}.kpi-card.kpi-orange .kpi-icon-container{color:#d97706;background-color:#fef3c7}.kpi-card.kpi-purple .kpi-icon-container{color:#7c3aed;background-color:#f5f3ff}.dashboard-row{grid-template-columns:2fr 1fr;gap:24px;display:grid}@media (width<=1024px){.dashboard-row{grid-template-columns:1fr}}.dashboard-card{background-color:var(--color-card-bg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);border-radius:12px;flex-direction:column;gap:20px;padding:24px;display:flex}.dashboard-card-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding-bottom:16px;display:flex}.dashboard-card-title{color:var(--color-primary-dark);align-items:center;gap:8px;font-size:16px;font-weight:700;display:flex}.filter-bar{background-color:var(--color-card-bg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);border-radius:12px;flex-wrap:wrap;align-items:center;gap:16px;padding:20px;display:flex}.filter-group{flex-direction:column;flex:1;gap:6px;min-width:180px;display:flex}.filter-label{color:var(--color-text-muted);text-transform:uppercase;font-size:11px;font-weight:600}.filter-input,.filter-select{border:1px solid var(--border-color);width:100%;font-family:var(--font-main);color:var(--color-text-dark);background-color:var(--color-card-bg);transition:var(--transition-fast);border-radius:8px;outline:none;padding:10px 14px;font-size:14px}.filter-input:focus,.filter-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.btn{font-family:var(--font-main);cursor:pointer;transition:var(--transition-fast);border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:600;display:inline-flex}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover{background-color:#173d7b}.btn-secondary{background-color:var(--color-card-bg);border-color:var(--border-color);color:var(--color-text-dark)}.btn-secondary:hover{background-color:var(--color-bg);border-color:var(--color-text-light)}.btn-danger{background-color:var(--color-accent-red);color:#fff}.btn-danger:hover{background-color:#b91c1c}.btn-sm{border-radius:6px;padding:6px 12px;font-size:12px}.table-container{background-color:var(--color-card-bg);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);border-radius:12px;overflow:hidden}.table-header-bar{background-color:var(--color-primary-dark);color:#fff;justify-content:space-between;align-items:center;padding:16px 24px;font-size:14px;font-weight:600;display:flex}.table-header-badge{text-transform:uppercase;background-color:#ffffff26;border-radius:20px;padding:4px 10px;font-size:11px;font-weight:700}.responsive-table-wrapper{width:100%;overflow-x:auto}.custom-table{border-collapse:collapse;text-align:left;width:100%;font-size:14px}.custom-table th{color:var(--color-text-muted);border-bottom:1px solid var(--border-color);text-transform:uppercase;letter-spacing:.5px;background-color:#f8fafc;padding:16px 20px;font-size:11px;font-weight:600}.custom-table td{border-bottom:1px solid var(--border-color);color:var(--color-text-dark);vertical-align:middle;padding:16px 20px}.custom-table tr:last-child td{border-bottom:none}.custom-table tr:hover td{background-color:#f8fafc}.cell-avatar-container{align-items:center;gap:12px;display:flex}.cell-avatar{background-color:var(--color-primary-light);width:38px;height:38px;color:var(--color-primary);text-transform:uppercase;border-radius:50%;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.cell-name-main{color:var(--color-primary-dark);font-weight:600}.cell-subtext{color:var(--color-text-muted);font-size:12px}.badge{text-transform:uppercase;letter-spacing:.5px;border-radius:30px;align-items:center;padding:4px 10px;font-size:11px;font-weight:700;display:inline-flex}.badge-blue{background-color:var(--color-primary-light);color:var(--color-primary)}.badge-green{color:#10b981;background-color:#ecfdf5}.badge-red{background-color:var(--color-accent-red-light);color:var(--color-accent-red)}.badge-orange{color:#d97706;background-color:#fef3c7}.badge-purple{color:#7c3aed;background-color:#f5f3ff}.badge-gray{color:#64748b;background-color:#f1f5f9}.detail-grid{grid-template-columns:1fr 2fr;gap:24px;display:grid}@media (width<=768px){.detail-grid{grid-template-columns:1fr}}.detail-sidebar-card{background-color:var(--color-card-bg);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);border-radius:12px;flex-direction:column;gap:20px;height:fit-content;padding:24px;display:flex}.detail-info-row{border-bottom:1px solid #f1f5f9;flex-direction:column;gap:4px;padding-bottom:12px;display:flex}.detail-info-row:last-child{border-bottom:none;padding-bottom:0}.detail-info-label{color:var(--color-text-light);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.detail-info-value{color:var(--color-text-dark);font-size:14px;font-weight:500}.tab-header{border-bottom:1px solid var(--border-color);display:flex}.tab-btn{color:var(--color-text-muted);font-family:var(--font-main);cursor:pointer;transition:var(--transition-fast);background:0 0;border:none;border-bottom:2px solid #0000;padding:12px 24px;font-size:14px;font-weight:600}.tab-btn:hover{color:var(--color-primary)}.tab-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.calendar-container{flex-direction:column;gap:16px;display:flex}.calendar-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.calendar-title-nav{align-items:center;gap:16px;display:flex}.calendar-title-text{color:var(--color-primary-dark);font-size:18px;font-weight:700}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:8px;display:grid}.calendar-day-header{text-align:center;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;background-color:#f8fafc;border-radius:6px;padding:12px;font-size:11px;font-weight:600}.calendar-cell{background-color:var(--color-card-bg);border:1px solid var(--border-color);min-height:120px;transition:var(--transition-fast);border-radius:8px;flex-direction:column;gap:6px;padding:8px;display:flex}.calendar-cell.other-month{opacity:.5;background-color:#f8fafc}.calendar-cell.today{border-color:var(--color-primary);background-color:#1e4d9b05}.calendar-cell-number{color:var(--color-text-muted);align-self:flex-end;font-size:12px;font-weight:600}.calendar-cell.today .calendar-cell-number{color:var(--color-primary);background-color:var(--color-primary-light);border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;display:flex}.calendar-events-container{flex-direction:column;flex:1;gap:4px;max-height:90px;display:flex;overflow-y:auto}.calendar-event{color:#fff;cursor:grab;white-space:nowrap;text-overflow:ellipsis;-webkit-user-select:none;user-select:none;border-radius:4px;padding:4px 6px;font-size:10px;font-weight:600;overflow:hidden}.calendar-event:active{cursor:grabbing}.event-maint{background-color:#1e4d9b}.event-repar{background-color:#d62828}.event-instal{background-color:#10b981}.event-garant{background-color:#d97706}.event-visita{background-color:#8b5cf6}.modal-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1000;background-color:#0f172a80;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-content{background-color:var(--color-card-bg);width:100%;max-width:600px;box-shadow:var(--shadow-lg);border-radius:12px;flex-direction:column;max-height:90vh;animation:.2s cubic-bezier(.16,1,.3,1) modalFadeIn;display:flex}.modal-content.modal-large{max-width:900px}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-title{color:var(--color-primary-dark);font-size:18px;font-weight:700}.modal-close{color:var(--color-text-light);cursor:pointer;background:0 0;border:none;font-size:20px;line-height:1}.modal-body{flex:1;padding:24px;overflow-y:auto}.modal-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}.form-grid{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}@media (width<=600px){.form-grid{grid-template-columns:1fr}}.form-group{flex-direction:column;gap:6px;display:flex}.form-group-full{grid-column:span 2}@media (width<=600px){.form-group-full{grid-column:span 1}}.form-label{color:var(--color-text-dark);font-size:12px;font-weight:600}.form-label span{color:var(--color-accent-red)}.form-input,.form-select,.form-textarea{border:1px solid var(--border-color);width:100%;font-family:var(--font-main);color:var(--color-text-dark);background-color:var(--color-card-bg);transition:var(--transition-fast);border-radius:8px;outline:none;padding:10px 12px;font-size:14px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.form-textarea{resize:vertical;min-height:80px}.signature-container{border:1px dashed var(--color-text-light);background-color:#f8fafc;border-radius:8px;flex-direction:column;align-items:center;gap:8px;padding:8px;display:flex;position:relative}.signature-canvas{border:1px solid var(--border-color);cursor:crosshair;background-color:#fff;border-radius:4px;width:100%;height:150px}.signature-actions{justify-content:flex-end;gap:8px;width:100%;display:flex}.photo-uploader{border:2px dashed var(--border-color);text-align:center;cursor:pointer;transition:var(--transition-fast);background-color:#f8fafc;border-radius:8px;padding:24px}.photo-uploader:hover{border-color:var(--color-primary)}.uploaded-photos-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px;margin-top:12px;display:grid}.uploaded-photo-item{aspect-ratio:1;border:1px solid var(--border-color);border-radius:6px;position:relative;overflow:hidden}.uploaded-photo-img{object-fit:cover;width:100%;height:100%}.uploaded-photo-remove{color:#fff;cursor:pointer;background-color:#d62828e6;border:none;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:12px;display:flex;position:absolute;top:4px;right:4px}.tech-portal-container{flex-direction:column;gap:16px;max-width:500px;margin:0 auto;display:flex}.tech-ot-card{background-color:var(--color-card-bg);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);border-radius:12px;flex-direction:column;gap:12px;padding:16px;display:flex}.tech-ot-header{justify-content:space-between;align-items:center;display:flex}.tech-ot-title{color:var(--color-primary-dark);font-weight:700}.tech-ot-detail-row{color:var(--color-text-muted);gap:8px;font-size:13px;display:flex}.tech-ot-detail-row svg{color:var(--color-primary);flex-shrink:0;margin-top:2px}.tech-ot-actions{grid-template-columns:1fr;gap:8px;margin-top:8px;display:grid}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.mobile-open{transform:translate(0)}.main-content{margin-left:0;padding:16px}.header{flex-direction:column;align-items:flex-start}.header-actions{justify-content:space-between;width:100%}.calendar-grid{grid-template-columns:1fr}.calendar-cell{min-height:80px}.calendar-day-header{display:none}}.mobile-menu-toggle{background-color:var(--color-primary);color:#fff;width:56px;height:56px;box-shadow:var(--shadow-lg);cursor:pointer;z-index:1000;border:none;border-radius:50%;justify-content:center;align-items:center;display:none;position:fixed;bottom:20px;right:20px}@media (width<=768px){.mobile-menu-toggle{display:flex}}.chart-container{justify-content:space-between;align-items:flex-end;gap:16px;width:100%;height:200px;padding:10px 0;display:flex}.chart-bar-group{flex-direction:column;flex:1;align-items:center;gap:8px;display:flex}.chart-bar-rail{background-color:#f1f5f9;border-radius:4px;align-items:flex-end;width:100%;height:150px;display:flex;position:relative;overflow:hidden}.chart-bar-fill{background-color:var(--color-primary);border-radius:4px;width:100%;transition:height .6s}.chart-bar-fill.bar-red{background-color:var(--color-accent-red)}.chart-bar-fill.bar-green{background-color:#10b981}.chart-bar-fill.bar-orange{background-color:#f59e0b}.chart-bar-fill.bar-purple{background-color:#8b5cf6}.chart-bar-label{color:var(--color-text-muted);text-align:center;white-space:nowrap;font-size:10px;font-weight:600}.chart-bar-value{text-align:center;color:var(--color-primary-dark);font-size:10px;font-weight:700;position:absolute;top:4px;left:0;right:0}.timeline{flex-direction:column;gap:20px;padding-left:20px;display:flex;position:relative}.timeline:before{content:"";background-color:var(--border-color);width:2px;position:absolute;top:0;bottom:0;left:6px}.timeline-item{flex-direction:column;gap:8px;display:flex;position:relative}.timeline-dot{background-color:var(--color-primary);width:14px;height:14px;box-shadow:0 0 0 1px var(--color-primary);z-index:2;border:3px solid #fff;border-radius:50%;position:absolute;top:6px;left:-20px}.timeline-item.timeline-red .timeline-dot{background-color:var(--color-accent-red);box-shadow:0 0 0 1px var(--color-accent-red)}.timeline-item.timeline-green .timeline-dot{background-color:#10b981;box-shadow:0 0 0 1px #10b981}.timeline-content{background-color:var(--color-bg);border:1px solid var(--border-color);border-radius:8px;padding:16px}.timeline-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:8px;display:flex}.timeline-title{color:var(--color-primary-dark);font-size:14px;font-weight:700}.timeline-date{color:var(--color-text-light);font-size:11px;font-weight:500}.timeline-body{color:var(--color-text-dark);flex-direction:column;gap:8px;font-size:13px;display:flex}@media print{body{color:#000;background:#fff}.sidebar,.mobile-menu-toggle,.header-actions,.filter-bar,.role-badge-selector{display:none!important}.main-content{margin-left:0!important;padding:0!important}.table-header-bar{-webkit-print-color-adjust:exact;print-color-adjust:exact;color:#fff!important;background-color:#0f2d5c!important}}
