@charset "UTF-8";*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8f9fa}.app-container{display:flex;height:100vh;overflow:hidden}.main-content{flex:1;margin-left:250px;background-color:#f8f9fa;display:flex;flex-direction:column;position:relative;z-index:1;min-height:0;overflow:hidden}.content-area{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden;position:relative}.detail-overlay{position:fixed;top:0;left:250px;right:0;bottom:0;z-index:600;background-color:#f5f5f5;display:flex;flex-direction:column;overflow:hidden}.detail-overlay-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.detail-overlay-content>.reports-container{flex:1;display:flex;flex-direction:column;overflow:hidden}.users-overlay{position:absolute;top:0;left:0;right:0;bottom:0;z-index:700;background-color:#f8f9fa}@media (max-width: 768px){.app-container{flex-direction:column;height:100vh}.main-content{margin-left:0;flex:1;min-height:0;order:1;overflow:hidden}.content-area{height:100%;min-height:0;overflow:hidden}.detail-overlay{left:0}}.Button{background-color:#ececec;cursor:pointer;border:none;border-radius:5px;padding:6px 15px;white-space:nowrap;transition:all .2s ease;font-weight:600;flex:1;display:inline-flex;align-items:center;justify-content:center}.Button_POSITIVE{background-color:#04f;color:#fff}.Button_NEGATIVE{background-color:#fd565f;color:#fff}.Button_NEUTRAL{background-color:#64c964;color:#fff}.no-permission{background-color:#fff;color:#000}@media (max-width: 768px){.action-buttons{gap:6px!important}.Button{padding:6px 12px;white-space:nowrap;justify-content:center}}@media (max-width: 480px){.Button{padding:4px 6px}}.Header{display:flex;align-items:center;padding:10px 24px;border-bottom:1px solid rgb(226,226,226);background:#fff;position:relative;z-index:100}.Header>div{display:flex}.Header .header_center{width:60%;justify-content:center;font-weight:600;font-size:min(1.5vw,22px);color:#2c3e50}.Header .header_left{width:20%;justify-content:flex-start}.Header .header_right{width:20%;justify-content:flex-end;align-items:center;gap:15px}.user-section{display:flex;align-items:center;gap:15px;position:relative}.user-info{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;transition:background-color .2s ease;border:1px solid transparent}.user-info:hover{background-color:#f8f9fa;border-color:#e9ecef}.user-info.disabled{opacity:.5;cursor:not-allowed!important}.user-info.disabled:hover{background-color:transparent;border-color:transparent}.user-details{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.user-name{font-weight:600;color:#2c3e50;line-height:1.2}.user-role{font-weight:500;text-transform:uppercase;letter-spacing:.5px}.dropdown-arrow{color:#6c757d;transition:transform .2s ease}.user-info:hover .dropdown-arrow{transform:rotate(180deg)}.user-menu{position:absolute;top:100%;right:0;background:#fff;border:1px solid #e9ecef;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:200px;z-index:1000;margin-top:5px;overflow:hidden}.menu-header{padding:12px 16px;background:#f8f9fa;border-bottom:1px solid #e9ecef}.menu-header strong{display:block;color:#2c3e50;margin-bottom:2px}.menu-name-role{display:flex;align-items:center;gap:8px;margin-bottom:4px}.menu-name-role strong{margin-bottom:0}.menu-email{color:#6c757d}.menu-role{font-weight:500;text-transform:uppercase;letter-spacing:.5px}.menu-divider{height:1px;background:#e9ecef}.logout-btn{width:100%;padding:12px 16px;background-color:#dc3545;color:#fff;border:none;cursor:pointer;font-weight:500;transition:background-color .2s ease;text-align:left}.logout-btn:hover:not(:disabled){background-color:#c82333}.logout-btn:disabled{opacity:.6;cursor:not-allowed}.menu-item-btn{width:100%;padding:12px 16px;background-color:#f8f9fa;color:#2c3e50;border:none;cursor:pointer;font-weight:500;transition:background-color .2s ease;text-align:left;display:flex;align-items:center;gap:8px}.menu-item-btn:hover{background-color:#e9ecef}.modal-overlay{position:fixed;top:0;left:250px;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px}.modal-content{background:#fff;border-radius:12px;box-shadow:0 10px 25px #00000026;width:100%;max-width:450px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e9ecef}.modal-header h2{margin:0;font-weight:600;color:#2c3e50}.modal-close{background:none;border:none;color:#6c757d;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s ease}.modal-close:hover{background-color:#f8f9fa;color:#2c3e50}.password-form{padding:24px}.form-group input{width:100%;padding:12px 16px;border:1px solid #ced4da;border-radius:8px;transition:border-color .2s ease;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.form-group input::placeholder{color:#6c757d}@media (max-width: 1024px){.user-avatar{display:none!important}}@media (max-width: 768px){.Header .header_center{width:70%;font-size:min(2vw,22px)}.Header .header_left{width:15%}.Header .header_right{width:15}.user-section{gap:8px}.user-info{padding:6px 8px}.user-menu{min-width:180px;right:-10px}.menu-header,.logout-btn{padding:10px 12px}}@media (max-width: 480px){.user-info{padding:4px}.dropdown-arrow{display:none}}@media (max-width: 768px){.user-role{font-size:.9rem}.menu-header strong{font-size:1.1rem}.menu-email,.menu-role{font-size:.9rem}.logout-btn,.menu-item-btn{font-size:1.1rem}.modal-header h2{font-size:1.5rem}.password-form label,.password-form input{font-size:1.2rem}}.kakao-map{border-radius:8px;overflow:hidden;height:150px!important;border:1px solid #e5e7eb}@media (pointer: coarse){.kakao-map{touch-action:none}}:global(.info-window){width:250px;max-width:280px;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;border-radius:8px;overflow:hidden;box-shadow:0 4px 12px #00000026}:global(.info-header){display:flex;justify-content:center;align-items:center;padding:12px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}:global(.info-header h4){margin:0;font-weight:600;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}:global(.status-badge){padding:4px 8px;border-radius:12px;font-weight:500;color:#fff;margin-left:8px;white-space:nowrap}:global(.info-content){padding:12px 16px;background:#fff}:global(.info-item){margin-bottom:8px;line-height:1.4}:global(.info-item strong){color:#374151;font-weight:600}:global(.info-item:last-child){margin-bottom:0}@media (max-width: 768px){:global(.info-window){width:200px;max-width:220px}:global(.info-header){padding:10px 12px}:global(.info-content){padding:10px 12px}}.current-location-button{z-index:10!important}.current-location-button button{width:35px;height:35px;background:#fff;border:1px solid #ccc;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0000001a;transition:all .2s ease;position:relative}.current-location-button button:hover{background:#f8f9fa;border-color:#999;box-shadow:0 2px 8px #00000026}.current-location-button button:disabled{opacity:.6;cursor:not-allowed}.current-location-button button svg{color:#666;transition:color .2s ease}.current-location-button button:hover svg{color:#333}.current-location-button .loading-spinner{width:16px;height:16px;border:2px solid #f3f3f3;border-top:2px solid #666;border-radius:50%;animation:spin 1s linear infinite;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes spin{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}.zoom-level-slider{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:8px;box-shadow:0 2px 6px #0000001a;width:35px;min-width:20px;z-index:10!important}.zoom-slider-container{display:flex;flex-direction:column;align-items:center;gap:8px}.zoom-btn{width:20px;height:40px;background:#fff;border:1px solid #e5e7eb;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#6b7280;transition:all .2s ease;flex-shrink:0}.zoom-btn:hover:not(:disabled){background:#f9fafb;border-color:#d1d5db;color:#374151}.zoom-btn:disabled{opacity:.4;cursor:not-allowed}.zoom-slider-wrapper{display:flex;flex-direction:column;align-items:center;gap:6px;height:100px}.zoom-slider{width:3px;height:70px;border-radius:2px;background:#e5e7eb;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;writing-mode:bt-lr;-webkit-writing-mode:bt-lr;-ms-writing-mode:bt-lr;writing-mode:vertical-lr;-webkit-writing-mode:vertical-lr;-ms-writing-mode:vertical-lr;transform:rotate(180deg)}.zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:#667eea;cursor:pointer;border:2px solid white;box-shadow:0 1px 3px #0003;transition:all .2s ease}.zoom-slider::-webkit-slider-thumb:hover{background:#5a67d8;transform:scale(1.1)}.zoom-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:#667eea;cursor:pointer;border:2px solid white;box-shadow:0 1px 3px #0003}.zoom-value{font-weight:600;color:#667eea;background:#f3f4f6;padding:2px 6px;border-radius:3px;min-width:16px;text-align:center;line-height:1}@media (max-width: 768px){.zoom-level-slider{width:35px;min-width:20px;padding:6px}.zoom-btn{width:20px;height:40px}.zoom-btn svg{width:14px;height:14px}.zoom-slider-wrapper{height:90px}.zoom-slider{height:65px}.zoom-value{padding:1px 4px}}.kakao-map div[style*=cluster]{cursor:pointer}.kakao-map div[class*=cluster]{display:flex!important;align-items:flex-start!important;justify-content:center!important;padding-top:0!important}:global(.customoverlay){cursor:pointer}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px}.loading-spinner-container.small{padding:10px}.loading-spinner-container.medium{padding:20px}.loading-spinner-container.large{padding:40px}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;animation:spin 1s linear infinite}.loading-spinner-container.small .loading-spinner{width:20px;height:20px;border-width:2px}.loading-spinner-container.large .loading-spinner{width:60px;height:60px;border-width:6px}.loading-text{margin-top:10px;color:#666;text-align:center}.loading-spinner-container.small .loading-text{margin-top:5px}.loading-spinner-container.large .loading-text{margin-top:15px}.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#fffc;display:flex;align-items:center;justify-content:center;z-index:9999}.button-loading{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#6b7280;font-weight:500;cursor:not-allowed}.button-loading .loading-spinner{width:16px;height:16px;border-width:2px}.login-button.button-loading{background-color:#3b82f6;color:#fff;border-color:#3b82f6}.image-upload-container{display:flex;flex-direction:column;align-items:center;gap:8px}.image-preview{position:relative;display:inline-block}.image-preview img{width:100%;max-width:400px;height:200px;object-fit:cover;border-radius:8px;border:2px solid #e2e8f0;transition:transform .2s ease}.image-preview img:hover{transform:scale(1.02)}.image-cancel-btn{position:absolute;top:5px;right:5px;width:24px;height:24px;background:#dc3545;color:#fff;border:none;border-radius:50%;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 2px 4px #0003}.image-cancel-btn:hover{background:#c82333;transform:scale(1.1)}.image-placeholder{width:100%;max-width:400px;height:200px;display:flex;align-items:center;justify-content:center;background-color:#f8f9fa;border:2px dashed #d1d5db;border-radius:8px;color:#6b7280;font-style:italic}.file-input{opacity:0;position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.file-input-container{position:relative;display:flex;flex-direction:row;gap:8px;align-items:center;min-height:40px}.address-map-group{display:flex;flex-direction:column;gap:12px}.form-row:last-of-type{grid-template-columns:1fr}.map-container .infowindow,.map-container .infowindow div,.map-container .infowindow span{font-family:Malgun Gothic,sans-serif!important;line-height:1.4!important;color:#333!important;background:#fff!important;border:1px solid #ccc!important;border-radius:4px!important;padding:8px!important;box-shadow:0 2px 6px #0003!important}.map-container .infowindow img,.map-container .infowindow svg{display:none!important}.map-container .infowindow:after{display:none!important}.map-container .infowindow:before{display:none!important}.map-container .MapTypeControl,.map-container .MapZoomControl,.map-container [title*=확대],.map-container [title*=축소]{display:none!important}@media (max-width: 768px){.map-container .kakao-map{height:250px!important}.image-preview img,.image-placeholder{max-width:250px;height:150px}.file-input-container{flex-direction:column;align-items:stretch;gap:4px}}select.disabled{background-color:#f3f4f6;color:#9ca3af;cursor:not-allowed;opacity:.7}.manager-notice{margin-top:4px;color:#6b7280;font-size:12px;font-style:italic}.image-modal-overlay{position:fixed;top:0;left:250px;right:0;bottom:0;background-color:#000c;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px}.image-modal-content{position:relative;max-width:90vw;max-height:90vh;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 10px 30px #0000004d}.image-modal-image{width:100%;height:100%;object-fit:contain;display:block}.image-modal-error{width:100%;height:200px;display:flex;align-items:center;justify-content:center;background:#f8f9fa;color:#6c757d;font-style:italic}@media (max-width: 768px){.image-modal-overlay{left:0;padding:10px}.image-modal-content{max-width:95vw;max-height:95vh}}.reports-container.overlay-mode{background-color:#f5f5f5;height:100%;display:flex;flex-direction:column}.detail-overlay-header{display:flex;align-items:center;padding:12px 16px;background-color:#fff;border-bottom:1px solid #e0e0e0;gap:12px}.detail-close-btn{background:none;border:none;font-size:20px;cursor:pointer;color:#666;padding:4px 8px;border-radius:4px;transition:background-color .2s}.detail-close-btn:hover{background-color:#f0f0f0}.detail-overlay-title{font-size:16px;font-weight:600;color:#333}.reports-container.overlay-mode .new-work-container{flex:1;overflow-y:auto;display:flex;flex-direction:column}.reports-container.overlay-mode .new-work-form{flex:1;display:flex;flex-direction:column}.reports-container.overlay-mode .new-work-form>.form-row:first-child{flex:1;min-height:0}.reports-container.overlay-mode .new-work-form>.form-row:first-child .form-group{display:flex;flex-direction:column;flex:1;min-height:0}.reports-container.overlay-mode .new-work-form>.form-row:first-child .map-container{flex:1;min-height:200px}.detail-actions{display:flex;gap:12px;margin-bottom:6px;justify-content:flex-end}.work-detail{padding:20px;background:#fff;border-radius:8px;margin:10px 10px 30px;box-shadow:0 2px 8px #0000001a}.detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #e0e0e0}.detail-header h3{margin:0;color:#333}.work-id-badge{color:#888;margin-left:12px}.close-detail-btn{background:none;border:none;cursor:pointer;color:#666;padding:5px;border-radius:50%;width:35px;height:35px;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease}.close-detail-btn:hover{background-color:#f0f0f0;color:#333}.detail-content{display:grid;grid-template-columns:1fr 2fr;gap:30px}.detail-info{display:flex;flex-direction:column;gap:15px}.info-group{display:flex;flex-direction:column;gap:5px}.info-group.full-width{grid-column:1 / -1}.info-group label{font-weight:600;color:#555}.info-group span{color:#333;padding:8px 12px;background-color:#f8f9fa;border-radius:4px;border-left:3px solid #2196f3}.detail-images{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.image-section{display:flex;flex-direction:column;gap:10px}.image-section h4{margin:0;color:#333;text-align:center;padding:8px;background-color:#f0f0f0;border-radius:4px}.no-image-placeholder{width:100%;height:200px;display:flex;align-items:center;justify-content:center;background-color:#f8f9fa;border:2px dashed #ccc;border-radius:8px;color:#999;font-style:italic}.map-container .kakao-map{width:100%;height:300px!important;border-radius:8px}.reports-container.overlay-mode .map-container .kakao-map{height:100%!important}.map-container img[src*=mhsafety_icon]{filter:contrast(1.2) brightness(.9) saturate(1.1) drop-shadow(2px 2px 4px rgba(0,0,0,.3))!important;mix-blend-mode:multiply;background:transparent!important}.map-container img[src*=mhsafety_icon]:hover{filter:contrast(1.3) brightness(1.1) saturate(1.2) drop-shadow(3px 3px 6px rgba(0,0,0,.4))!important}.map-container img{filter:none!important}.detail-address-row{display:flex;align-items:center;gap:8px}.detail-address-row .go-to-location-btn{padding:2px 4px;min-width:30px;width:30px;font-size:12px;background-color:#e0f2fe;border:1px solid #7dd3fc;border-radius:4px;cursor:pointer;flex:0 0 30px}.detail-address-row .go-to-location-btn:hover{background-color:#bae6fd}@media (max-width: 768px){.detail-content{grid-template-columns:1fr;gap:20px}.detail-images{grid-template-columns:1fr;gap:15px}.work-detail{margin:5px;padding:15px}.map-container .kakao-map{height:250px!important;min-height:200px}.detail-actions button.print-button{display:none!important}}@media print{.pdf-hide,.detail-actions,.back-button,.go-to-location-btn,header,.left-menu,.header-container{display:none!important}@page{size:A4;margin:10mm}*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}.reports-container{padding:0!important;margin:0!important;background:#fff!important}.new-work-container{padding:0!important;margin:0!important}.map-container{width:100%!important;height:120mm!important;page-break-inside:avoid}.map-container .kakao-map{width:100%!important;height:120mm!important}.detail-image{max-height:200px!important;page-break-inside:avoid}.form-row{page-break-inside:avoid;margin-bottom:10px!important}}.left-menu{width:250px;height:100vh;background-color:#2c3e50;color:#fff;position:fixed;left:0;top:0;box-shadow:2px 0 5px #0000001a;display:flex;flex-direction:column;z-index:1000;overflow:hidden;transform:translateZ(0);will-change:transform}.logo-section{text-align:center;border-bottom:1px solid #34495e;background-color:#d3d9de;position:relative;z-index:1001}.left-menu .company-logo{width:230px;height:200px;object-fit:contain}.menu-nav{padding:20px 0;flex:1;display:flex;flex-direction:column;background-color:#e3e7ea;position:relative;z-index:1001}.menu-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}.menu-item{margin:0;padding:0}.menu-link{display:flex;align-items:center;padding:15px 20px;color:#34495e;text-decoration:none;transition:all .3s ease;border-left:3px solid transparent;background-color:transparent}button.menu-link{width:100%;border:none;border-left:3px solid transparent;cursor:pointer;font-size:inherit;font-family:inherit;text-align:left}.menu-link:hover{background-color:#c2c9d1;color:#1976d2;border-left-color:#1976d2;text-decoration:none}.menu-link:active{background-color:#b0bec5;color:#1976d2}.menu-icon{margin-right:12px;width:24px;text-align:center}.menu-text{font-weight:500}.menu-link.active{background-color:#b0bec5;color:#1976d2;border-left-color:#1976d2}.left-menu.pdf-generating{opacity:.6;pointer-events:none}.menu-link.disabled{opacity:.5;cursor:not-allowed!important;pointer-events:none}.menu-link.disabled:hover{background-color:transparent;color:#34495e;border-left-color:transparent}@media (max-width: 768px){.left-menu{width:100%;font-size:20px;height:50px;position:relative;box-shadow:0 -2px 5px #0000001a;z-index:1000;overflow:hidden;order:2;flex-shrink:0;background-color:#2c3e50;touch-action:manipulation}.logo-section{display:none}.menu-nav{padding:0;height:100%}.menu-list{flex-direction:row;height:100%;justify-content:space-around;align-items:center}.menu-item{flex:1;height:100%}.menu-link{flex-direction:column;justify-content:center;align-items:center;height:100%;padding:8px 5px;border-left:none;border-bottom:3px solid transparent;min-height:44px;touch-action:manipulation}button.menu-link{border-left:none;text-align:center}.menu-link:hover,.menu-link.active{border-left-color:transparent;border-bottom-color:#3498db}.left-menu.pdf-generating{opacity:.6;pointer-events:none}.menu-link.disabled{opacity:.5;cursor:not-allowed!important;pointer-events:none}.menu-link.disabled:hover{border-bottom-color:transparent}.menu-icon{margin-right:0;margin-bottom:4px;width:auto}.menu-text{font-weight:400;font-size:.8rem;line-height:1.2;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}}.filters-section{display:flex;flex-direction:column;gap:16px;margin-bottom:.5rem;padding:.5rem 1rem;background:#fff;border-radius:8px;border:1px solid #e9ecef}.filter-section{display:flex;flex-direction:column;gap:6px}.filters-section input,.filters-section select{padding:.5rem 1rem;border:1px solid #ced4da;border-radius:6px;background:#fff;transition:border-color .2s ease;box-sizing:border-box}.filters-section input:focus,.filters-section select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.filter-row{display:flex;gap:12px;align-items:flex-end}.filter-group{display:flex;flex-direction:column;gap:4px;height:59px;justify-content:flex-end;position:relative}.filter-group.filter-province label{display:flex;align-items:center;flex-wrap:nowrap;gap:8px;margin-bottom:4px;line-height:1}.filter-province,.filter-city{flex:1;min-width:120px;max-width:150px}.filter-detail-address{flex:2;min-width:200px;max-width:300px}.filter-date-range{flex:1;min-width:200px;max-width:250px}.date-range-input{width:100%;padding:.5rem 1rem;border:1px solid #ced4da;border-radius:6px;background:#fff;cursor:pointer;box-sizing:border-box}.date-range-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.react-datepicker-popper{z-index:9999!important}.react-datepicker{font-family:inherit;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 12px #00000026}.react-datepicker__header{background:#f8f9fa;border-bottom:1px solid #e5e7eb;border-radius:8px 8px 0 0}.react-datepicker__day--selected,.react-datepicker__day--in-selecting-range,.react-datepicker__day--in-range{background-color:#667eea;color:#fff}.react-datepicker__day--selected:hover,.react-datepicker__day--in-selecting-range:hover,.react-datepicker__day--in-range:hover{background-color:#5a67d8}.react-datepicker__day--keyboard-selected{background-color:#667eea;color:#fff}.react-datepicker__close-icon:after{background-color:#6b7280}.filter-worker{flex:1;min-width:120px;max-width:200px}.worker-filter-container{display:flex;align-items:center;justify-content:space-between;gap:8px}.total-count{font-size:1rem;color:#6c757d;font-weight:500;white-space:nowrap;padding:4px 8px;background-color:#f8f9fa;border-radius:4px;border:1px solid #dee2e6}.filter-select{cursor:pointer;transition:border-color .2s ease}.filter-select:disabled{background-color:#f8f9fa;color:#495057;cursor:not-allowed;border-color:#dee2e6;font-weight:500;opacity:.8}.filter-select:disabled:hover{background-color:#f8f9fa;border-color:#dee2e6}.filter-select:disabled:focus{outline:none;border-color:#dee2e6;box-shadow:none}.filter-select:disabled option{color:#6c757d;font-style:italic}.filter-city .filter-select:disabled{background-color:#f3f4f6;color:#6b7280;border-color:#d1d5db;font-style:italic}.filter-city .filter-select:disabled option{color:#9ca3af;font-style:italic}.date-input{width:100%}@media (max-width: 768px){.date-input:before{content:attr(data-placeholder);font-size:1rem;height:90%;padding:.2rem .5rem;color:#626161;position:absolute;top:30%;transform:translateY(-50%);pointer-events:none;z-index:1;background:#fff;width:calc(100% - 20px);box-sizing:border-box}.date-input:not([value=""]):before{display:none}.date-input:focus:before{display:none}}@media (max-width: 768px){.filters-section{padding:12px 15px}.filter-row{flex-direction:row;gap:8px;flex-wrap:wrap;align-items:flex-end}.filter-group.filter-group1{height:40px!important}.filter-group.filter-group2{height:20px!important}.filter-group label{display:none}.filter-group.filter-province{height:20px}.filter-province,.filter-city{flex:1;min-width:80px;max-width:120px}.filter-detail-address{flex:2;min-width:120px;max-width:200px}.filter-date-range{flex:1;min-width:140px;max-width:180px}.date-range-input{padding:.3rem .8rem;font-size:.9rem}.filter-worker{flex:1;min-width:80px;max-width:120px}.worker-filter-container{flex-direction:row;gap:4px;align-items:center;justify-content:space-between}.total-count{font-size:.9rem;padding:2px 6px;text-align:right}}@media (max-width: 768px){.filters-section input,.filters-section select{padding:.3rem .8rem}}@media (min-width: 769px) and (max-width: 1024px){.filter-province,.filter-city{min-width:100px;max-width:120px}.filter-date-range{min-width:160px;max-width:200px}.filter-worker{min-width:100px;max-width:150px}.filter-group{height:50px}.filter-group.filter-province label{display:flex;align-items:center;flex-wrap:nowrap;gap:8px;margin-bottom:4px;line-height:1}}.filter-select.disabled{background-color:#f3f4f6;color:#9ca3af;cursor:not-allowed;opacity:.7}.manager-notice{color:#6b7280;font-size:12px;font-style:italic;white-space:nowrap;flex-shrink:0;display:inline;vertical-align:baseline}@media (max-width: 400px){.date-input:before{top:45%}}.users-container{height:100%;display:flex;flex-direction:column;background-color:#f5f5f5;padding:0 10px;box-sizing:border-box;overflow:hidden}.users-content{max-width:1200px;margin:0 auto;flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.actions-section{width:100%;display:flex;justify-content:flex-end}.action-buttons{display:flex;gap:12px;justify-content:flex-end;align-items:center}.no-permission{background-color:#f3f4f6!important;color:#9ca3af!important;border:1px solid #d1d5db!important;cursor:not-allowed!important;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;min-width:60px;text-align:center}.users-header{display:flex;justify-content:flex-end;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:15px}.users-header h2{margin:0;color:#333}.users-table-container{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a;flex:1;display:flex;flex-direction:column;min-height:0}.users-table{width:100%;background:#fff;border-collapse:collapse;display:flex;flex-direction:column;flex:1;min-height:0}.users-table thead{flex-shrink:0}.users-table tbody{flex:1;overflow-y:auto}.users-table thead,.users-table tbody{display:block}.users-table tr{display:table;width:100%;table-layout:fixed}.users-table th,.users-table td{padding:12px 16px;text-align:center;border-bottom:1px solid #e5e7eb;vertical-align:middle}.users-table th:nth-child(3),.users-table td:nth-child(3){width:120px;text-align:center}.users-table th:nth-child(4),.users-table td:nth-child(4){width:180px;text-align:center}.users-table th:nth-child(5),.users-table td:nth-child(5){width:80px;text-align:center}.users-table th{background:#f8fafc;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.users-table td{color:#6b7280;word-wrap:break-word;overflow-wrap:break-word}.users-table tr:hover{background:#f9fafb}.users-table tr:last-child td{border-bottom:none}.disabled-input{background-color:#f3f4f6!important;color:#6b7280!important;cursor:not-allowed!important;border-color:#d1d5db!important}.user-info{display:flex;align-items:center;gap:10px}.user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600}.user-name{font-weight:500;color:#374151}.role-badge{display:inline-block;padding:4px 8px;border-radius:20px;font-weight:600;text-align:center;color:#fff;white-space:nowrap}.location-text{color:#6b7280;font-weight:500}.area-info{display:flex;flex-direction:column;gap:2px;align-items:center}.province-name{color:#374151;font-weight:500}.city-name{color:#6b7280;font-weight:400}.no-data{text-align:center;color:#9ca3af;font-style:italic;padding:40px 20px}.no-action{color:#d1d5db;padding:4px 8px;border-radius:4px;background:#f9fafb;border:1px solid #e5e7eb;display:inline-block;min-width:40px;text-align:center}.user-actions{display:flex;gap:8px}.modal-overlay{position:fixed;top:0;left:250px;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px;overflow-y:auto;min-height:100vh}.modal-content{background:#fff;border-radius:12px;max-width:500px;max-height:90vh;width:100%;display:flex;flex-direction:column;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-header{padding:20px 24px;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center;background:#f8fafc;border-radius:12px 12px 0 0}.modal-header h2{margin:0;font-weight:600;color:#374151}.modal-close{background:none;border:none;cursor:pointer;color:#6b7280;padding:12px;border-radius:12px;transition:all .2s ease}.modal-close:hover{background:#f3f4f6;color:#374151}.user-form{padding:24px;overflow-y:auto;flex:1}.area-selector{display:flex;gap:10px;flex-wrap:wrap}.area-selector select{flex:1;min-width:150px;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;background-color:#fff;color:#374151;transition:border-color .2s ease}.area-selector select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.area-selector select:disabled{background-color:#f3f4f6;color:#9ca3af;cursor:not-allowed}.modal{background:#fff;border-radius:12px;max-width:500px;max-height:calc(100vh - 40px);width:100%;display:flex;flex-direction:column;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;margin:auto}.modal form{padding:24px;overflow-y:auto;flex:1;min-height:0}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#374151}.form-group input,.form-group select{padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;background-color:#fff;color:#374151;transition:border-color .2s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:20px;border-top:1px solid #e5e7eb}.close-button{background:none;border:none;cursor:pointer;color:#6b7280;padding:4px;border-radius:4px;transition:all .2s ease}.close-button:hover{background:#f3f4f6;color:#374151}.modal-error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;margin:0 24px 16px;border-radius:6px;font-size:14px;font-weight:500}.user-form-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.user-form-content{background:#fff;border-radius:12px;padding:30px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto}.user-form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.user-form-header h3{margin:0;color:#374151;font-weight:700}.role-group{display:flex;gap:12px;margin-top:8px}.role-option{display:flex;align-items:center;gap:8px}.role-option input[type=radio]{margin:0}.role-option label{margin:0;font-weight:500;color:#374151;cursor:pointer}.error-message{background:#fef2f2;color:#dc2626;padding:12px 16px;border-radius:6px;margin-bottom:20px;border:1px solid #fecaca}.access-denied{display:flex;flex-direction:column;align-items:center;justify-content:center;height:calc(100vh - 200px);text-align:center;color:#6b7280}.access-denied-icon{margin-bottom:20px}.access-denied h2{margin:0 0 10px;color:#374151}.access-denied p{margin:5px 0}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:calc(100vh - 200px);text-align:center;color:#6b7280}.loading .loading-spinner{margin-bottom:20px}.empty-users{text-align:center;padding:60px 20px;color:#6b7280}.empty-users h3{margin:0 0 10px;color:#374151}.empty-users p{margin:0}@media (max-width: 1024px){.users-table th:nth-child(3),.users-table td:nth-child(3){width:90px}.users-table th:nth-child(4),.users-table td:nth-child(4){width:140px}.users-table th:nth-child(5),.users-table td:nth-child(5){width:70px}}@media (max-width: 768px){.modal-overlay{left:0;align-items:flex-start;padding:10px}.modal{max-height:calc(100vh - 20px);margin:0;width:100%;max-width:none}.modal form{padding:16px}.modal-header{padding:16px 20px}.loading,.access-denied{height:100%}.users-header{flex-direction:column;align-items:stretch}.users-header h2{text-align:center}.actions-section{justify-content:flex-end}.users-table th,.users-table td{padding:8px 6px}.users-table th:nth-child(3),.users-table td:nth-child(3){width:70px}.users-table th:nth-child(4),.users-table td:nth-child(4){width:120px}.users-table th:nth-child(5),.users-table td:nth-child(5){width:60px}.users-table-container .user-avatar{display:none}.user-form-content{padding:20px;margin:20px}.modal-content{margin:10px;max-height:calc(100vh - 20px)}.modal{max-height:calc(100vh - 40px);margin:10px}.modal-overlay{align-items:flex-start;padding:10px}.role-group{flex-direction:column;gap:8px}}@media (max-width: 480px){.modal-overlay{padding:5px}.modal{max-height:calc(100vh - 10px);border-radius:8px}.modal form{padding:12px}.modal-header{padding:12px 16px}.form-group input,.form-group select{padding:8px 10px}.modal-actions{padding:16px 0 0;margin-top:16px}.users-table th:nth-child(3),.users-table td:nth-child(3){width:65px}.users-table th:nth-child(4),.users-table td:nth-child(4){width:90px}.users-table th:nth-child(5),.users-table td:nth-child(5){width:50px}}.react-datepicker__navigation-icon:before,.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow{border-color:#ccc;border-style:solid;border-width:3px 3px 0 0;content:"";display:block;height:9px;position:absolute;top:6px;width:9px}.react-datepicker__sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip-path:inset(50%);white-space:nowrap;border:0}.react-datepicker-wrapper{display:inline-block;padding:0;border:0}.react-datepicker{font-family:Helvetica Neue,helvetica,arial,sans-serif;font-size:.8rem;background-color:#fff;color:#000;border:1px solid #aeaeae;border-radius:.3rem;display:inline-block;position:relative;line-height:initial}.react-datepicker--time-only .react-datepicker__time-container{border-left:0}.react-datepicker--time-only .react-datepicker__time,.react-datepicker--time-only .react-datepicker__time-box{border-bottom-left-radius:.3em;border-bottom-right-radius:.3em}.react-datepicker-popper{z-index:1;line-height:0}.react-datepicker-popper .react-datepicker__triangle{stroke:#aeaeae}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle{fill:#f0f0f0;color:#f0f0f0}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle,.react-datepicker-popper--header-middle[data-placement^=bottom] .react-datepicker__triangle,.react-datepicker-popper--header-bottom[data-placement^=bottom] .react-datepicker__triangle{fill:#fff;color:#fff}.react-datepicker-popper--header-bottom[data-placement^=top] .react-datepicker__triangle{fill:#f0f0f0;color:#f0f0f0}.react-datepicker__header{text-align:center;background-color:#f0f0f0;border-bottom:1px solid #aeaeae;border-top-left-radius:.3rem;padding:8px 0;position:relative}.react-datepicker__header--time{padding-bottom:8px;padding-left:5px;padding-right:5px}.react-datepicker__header--time:not(.react-datepicker__header--time--only){border-top-left-radius:0}.react-datepicker__header:not(.react-datepicker__header--has-time-select,.react-datepicker__header--middle,.react-datepicker__header--bottom){border-top-right-radius:.3rem}.react-datepicker__header--middle{border-top:1px solid #aeaeae;border-radius:0;margin-top:4px}.react-datepicker__header--bottom{border-bottom:none;border-top:1px solid #aeaeae;border-radius:0 0 .3rem .3rem}.react-datepicker__header-wrapper{position:relative}.react-datepicker__header-wrapper .react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:2px}.react-datepicker__year-dropdown-container--select,.react-datepicker__month-dropdown-container--select,.react-datepicker__month-year-dropdown-container--select,.react-datepicker__year-dropdown-container--scroll,.react-datepicker__month-dropdown-container--scroll,.react-datepicker__month-year-dropdown-container--scroll{display:inline-block;margin:0 15px}.react-datepicker__current-month,.react-datepicker-time__header,.react-datepicker-year-header{margin-top:0;color:#000;font-weight:700;font-size:.944rem}h2.react-datepicker__current-month{padding:0;margin:0}.react-datepicker-time__header{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.react-datepicker__navigation{align-items:center;background:none;display:flex;justify-content:center;text-align:center;cursor:pointer;position:absolute;top:2px;padding:0;border:none;z-index:1;height:32px;width:32px;text-indent:-999em;overflow:hidden}.react-datepicker__navigation--previous{left:2px}.react-datepicker__navigation--next{right:2px}.react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:85px}.react-datepicker__navigation--years{position:relative;top:0;display:block;margin-left:auto;margin-right:auto}.react-datepicker__navigation--years-previous{top:4px}.react-datepicker__navigation--years-upcoming{top:-4px}.react-datepicker__navigation:hover *:before{border-color:#a6a6a6}.react-datepicker__navigation-icon{position:relative;top:-1px;font-size:20px;width:0}.react-datepicker__navigation-icon--next{left:-2px}.react-datepicker__navigation-icon--next:before{transform:rotate(45deg);left:-7px}.react-datepicker__navigation-icon--previous{right:-2px}.react-datepicker__navigation-icon--previous:before{transform:rotate(225deg);right:-7px}.react-datepicker__month-container{float:left}.react-datepicker__year{margin:.4em;text-align:center}.react-datepicker__year-wrapper{display:flex;flex-wrap:wrap;max-width:180px}.react-datepicker__year .react-datepicker__year-text{display:inline-block;width:4em;margin:2px}.react-datepicker__month{margin:.4em;text-align:center}.react-datepicker__month .react-datepicker__month-text,.react-datepicker__month .react-datepicker__quarter-text{display:inline-block;width:4em;margin:2px}.react-datepicker__input-time-container{clear:both;width:100%;float:left;margin:5px 0 10px 15px;text-align:left}.react-datepicker__input-time-container .react-datepicker-time__caption,.react-datepicker__input-time-container .react-datepicker-time__input-container{display:inline-block}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input{display:inline-block;margin-left:10px}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input{width:auto}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-inner-spin-button,.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]{-moz-appearance:textfield}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__delimiter{margin-left:5px;display:inline-block}.react-datepicker__time-container{float:right;border-left:1px solid #aeaeae;width:85px}.react-datepicker__time-container--with-today-button{display:inline;border:1px solid #aeaeae;border-radius:.3em;position:absolute;right:-87px;top:0}.react-datepicker__time-container .react-datepicker__time{position:relative;background:#fff;border-bottom-right-radius:.3em}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box{width:85px;overflow-x:hidden;margin:0 auto;text-align:center;border-bottom-right-radius:.3em}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list{list-style:none;margin:0;height:calc(195px + .85em);overflow-y:scroll;padding-right:0;padding-left:0;width:100%;box-sizing:content-box}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item{height:30px;padding:5px 10px;white-space:nowrap}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item:hover{cursor:pointer;background-color:#f0f0f0}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected{background-color:#216ba5;color:#fff;font-weight:700}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected:hover{background-color:#216ba5}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled{color:#ccc}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled:hover{cursor:default;background-color:transparent}.react-datepicker__week-number{color:#ccc;display:inline-block;width:1.7em;line-height:1.7em;text-align:center;margin:.166em}.react-datepicker__week-number.react-datepicker__week-number--clickable{cursor:pointer}.react-datepicker__week-number.react-datepicker__week-number--clickable:not(.react-datepicker__week-number--selected):hover{border-radius:.3rem;background-color:#f0f0f0}.react-datepicker__week-number--selected{border-radius:.3rem;background-color:#216ba5;color:#fff}.react-datepicker__week-number--selected:hover{background-color:#1d5d90}.react-datepicker__day-names{text-align:center;white-space:nowrap;margin-bottom:-8px}.react-datepicker__week{white-space:nowrap}.react-datepicker__day-name,.react-datepicker__day,.react-datepicker__time-name{color:#000;display:inline-block;width:1.7em;line-height:1.7em;text-align:center;margin:.166em}.react-datepicker__day-name--disabled,.react-datepicker__day--disabled,.react-datepicker__time-name--disabled{cursor:default;color:#ccc}.react-datepicker__day,.react-datepicker__month-text,.react-datepicker__quarter-text,.react-datepicker__year-text{cursor:pointer}.react-datepicker__day:not([aria-disabled=true]):hover,.react-datepicker__month-text:not([aria-disabled=true]):hover,.react-datepicker__quarter-text:not([aria-disabled=true]):hover,.react-datepicker__year-text:not([aria-disabled=true]):hover{border-radius:.3rem;background-color:#f0f0f0}.react-datepicker__day--today,.react-datepicker__month-text--today,.react-datepicker__quarter-text--today,.react-datepicker__year-text--today{font-weight:700}.react-datepicker__day--highlighted,.react-datepicker__month-text--highlighted,.react-datepicker__quarter-text--highlighted,.react-datepicker__year-text--highlighted{border-radius:.3rem;background-color:#3dcc4a;color:#fff}.react-datepicker__day--highlighted:not([aria-disabled=true]):hover,.react-datepicker__month-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__year-text--highlighted:not([aria-disabled=true]):hover{background-color:#32be3f}.react-datepicker__day--highlighted-custom-1,.react-datepicker__month-text--highlighted-custom-1,.react-datepicker__quarter-text--highlighted-custom-1,.react-datepicker__year-text--highlighted-custom-1{color:#f0f}.react-datepicker__day--highlighted-custom-2,.react-datepicker__month-text--highlighted-custom-2,.react-datepicker__quarter-text--highlighted-custom-2,.react-datepicker__year-text--highlighted-custom-2{color:green}.react-datepicker__day--holidays,.react-datepicker__month-text--holidays,.react-datepicker__quarter-text--holidays,.react-datepicker__year-text--holidays{position:relative;border-radius:.3rem;background-color:#ff6803;color:#fff}.react-datepicker__day--holidays .overlay,.react-datepicker__month-text--holidays .overlay,.react-datepicker__quarter-text--holidays .overlay,.react-datepicker__year-text--holidays .overlay{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:4px;border-radius:4px;white-space:nowrap;visibility:hidden;opacity:0;transition:visibility 0s,opacity .3s ease-in-out}.react-datepicker__day--holidays:not([aria-disabled=true]):hover,.react-datepicker__month-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__year-text--holidays:not([aria-disabled=true]):hover{background-color:#cf5300}.react-datepicker__day--holidays:hover .overlay,.react-datepicker__month-text--holidays:hover .overlay,.react-datepicker__quarter-text--holidays:hover .overlay,.react-datepicker__year-text--holidays:hover .overlay{visibility:visible;opacity:1}.react-datepicker__day--selected,.react-datepicker__day--in-selecting-range,.react-datepicker__day--in-range,.react-datepicker__month-text--selected,.react-datepicker__month-text--in-selecting-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--selected,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--selected,.react-datepicker__year-text--in-selecting-range,.react-datepicker__year-text--in-range{border-radius:.3rem;background-color:#216ba5;color:#fff}.react-datepicker__day--selected:not([aria-disabled=true]):hover,.react-datepicker__day--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__day--in-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-range:not([aria-disabled=true]):hover{background-color:#1d5d90}.react-datepicker__day--keyboard-selected,.react-datepicker__month-text--keyboard-selected,.react-datepicker__quarter-text--keyboard-selected,.react-datepicker__year-text--keyboard-selected{border-radius:.3rem;background-color:#bad9f1;color:#000}.react-datepicker__day--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--keyboard-selected:not([aria-disabled=true]):hover{background-color:#1d5d90;color:#fff}.react-datepicker__day--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__month-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__quarter-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__year-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range){background-color:#216ba580}.react-datepicker__month--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range){background-color:#f0f0f0;color:#000}.react-datepicker__day--disabled,.react-datepicker__month-text--disabled,.react-datepicker__quarter-text--disabled,.react-datepicker__year-text--disabled{cursor:default;color:#ccc}.react-datepicker__day--disabled .overlay,.react-datepicker__month-text--disabled .overlay,.react-datepicker__quarter-text--disabled .overlay,.react-datepicker__year-text--disabled .overlay{position:absolute;bottom:70%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:4px;border-radius:4px;white-space:nowrap;visibility:hidden;opacity:0;transition:visibility 0s,opacity .3s ease-in-out}.react-datepicker__input-container{position:relative;display:inline-block;width:100%}.react-datepicker__input-container .react-datepicker__calendar-icon{position:absolute;padding:.5em;box-sizing:content-box}.react-datepicker__view-calendar-icon input{padding:6px 10px 5px 25px}.react-datepicker__year-read-view,.react-datepicker__month-read-view,.react-datepicker__month-year-read-view{border:1px solid transparent;border-radius:.3rem;position:relative}.react-datepicker__year-read-view:hover,.react-datepicker__month-read-view:hover,.react-datepicker__month-year-read-view:hover{cursor:pointer}.react-datepicker__year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__year-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__month-read-view--down-arrow{border-top-color:#b3b3b3}.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow{transform:rotate(135deg);right:-16px;top:0}.react-datepicker__year-dropdown,.react-datepicker__month-dropdown,.react-datepicker__month-year-dropdown{background-color:#f0f0f0;position:absolute;width:50%;left:25%;top:30px;z-index:1;text-align:center;border-radius:.3rem;border:1px solid #aeaeae}.react-datepicker__year-dropdown:hover,.react-datepicker__month-dropdown:hover,.react-datepicker__month-year-dropdown:hover{cursor:pointer}.react-datepicker__year-dropdown--scrollable,.react-datepicker__month-dropdown--scrollable,.react-datepicker__month-year-dropdown--scrollable{height:150px;overflow-y:scroll}.react-datepicker__year-option,.react-datepicker__month-option,.react-datepicker__month-year-option{line-height:20px;width:100%;display:block;margin-left:auto;margin-right:auto}.react-datepicker__year-option:first-of-type,.react-datepicker__month-option:first-of-type,.react-datepicker__month-year-option:first-of-type{border-top-left-radius:.3rem;border-top-right-radius:.3rem}.react-datepicker__year-option:last-of-type,.react-datepicker__month-option:last-of-type,.react-datepicker__month-year-option:last-of-type{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem}.react-datepicker__year-option:hover,.react-datepicker__month-option:hover,.react-datepicker__month-year-option:hover{background-color:#ccc}.react-datepicker__year-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-upcoming{border-bottom-color:#b3b3b3}.react-datepicker__year-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-previous{border-top-color:#b3b3b3}.react-datepicker__year-option--selected,.react-datepicker__month-option--selected,.react-datepicker__month-year-option--selected{position:absolute;left:15px}.react-datepicker__close-icon{cursor:pointer;background-color:transparent;border:0;outline:0;padding:0 6px 0 0;position:absolute;top:0;right:0;height:100%;display:table-cell;vertical-align:middle}.react-datepicker__close-icon:after{cursor:pointer;background-color:#216ba5;color:#fff;border-radius:50%;height:16px;width:16px;padding:2px;font-size:12px;line-height:1;text-align:center;display:table-cell;vertical-align:middle;content:"×"}.react-datepicker__close-icon--disabled{cursor:default}.react-datepicker__close-icon--disabled:after{cursor:default;background-color:#ccc}.react-datepicker__today-button{background:#f0f0f0;border-top:1px solid #aeaeae;cursor:pointer;text-align:center;font-weight:700;padding:5px 0;clear:left}.react-datepicker__portal{position:fixed;width:100vw;height:100vh;background-color:#000c;left:0;top:0;justify-content:center;align-items:center;display:flex;z-index:2147483647}.react-datepicker__portal .react-datepicker__day-name,.react-datepicker__portal .react-datepicker__day,.react-datepicker__portal .react-datepicker__time-name{width:3em;line-height:3em}@media (max-width: 400px),(max-height: 550px){.react-datepicker__portal .react-datepicker__day-name,.react-datepicker__portal .react-datepicker__day,.react-datepicker__portal .react-datepicker__time-name{width:2em;line-height:2em}}.react-datepicker__portal .react-datepicker__current-month,.react-datepicker__portal .react-datepicker-time__header{font-size:1.44rem}.react-datepicker__children-container{width:13.8em;margin:.4em;padding-right:.2em;padding-left:.2em;height:auto}.react-datepicker__aria-live{position:absolute;clip-path:circle(0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;width:1px;white-space:nowrap}.react-datepicker__calendar-icon{width:1em;height:1em;vertical-align:-.125em}.react-datepicker-popper-offset{margin-top:-.7em}.table-container{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden;position:relative;flex:1;display:flex;flex-direction:column;min-height:0}.no-permission{background-color:#f3f4f6!important;color:#9ca3af!important;border:1px solid #d1d5db!important;cursor:not-allowed!important;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;min-width:60px;text-align:center;display:flex;align-items:center;justify-content:center}.no-permission:hover{background-color:#f3f4f6!important;color:#9ca3af!important;transform:none!important}.table-header{display:grid;grid-template-columns:70px 110px 1fr 1fr 1fr 80px;background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-bottom:2px solid #e2e8f0;position:sticky;top:0;transition:width .2s ease;background-size:100% 100%;background-repeat:no-repeat;position:relative}.table-header:after{content:"";position:absolute;top:0;right:calc(-1 * var(--scrollbar-width, 0px));width:var(--scrollbar-width, 0px);height:100%;background:#e2e8f0;border-bottom:2px solid #e2e8f0}.table-container.pdf-mode .table-header{grid-template-columns:70px 110px 1fr 1fr 1fr}.header-row{display:contents}.header-cell{padding:12px 8px;font-weight:600;color:#1e293b;text-align:center;border-right:1px solid #e2e8f0;display:flex;align-items:center;justify-content:center}.header-cell:last-child{border-right:none}.pdf-hidden{display:none!important}.header-address{grid-column:span 3;background:#f1f5f9;border-top:1px solid #e2e8f0}.table-body{background:#fff;flex:1;overflow-y:auto;overflow-x:hidden}.table-body::-webkit-scrollbar{width:8px}.table-body::-webkit-scrollbar-track{background:#f1f5f9}.table-body::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.table-body::-webkit-scrollbar-thumb:hover{background:#94a3b8}.table-container.pdf-mode .table-body{max-height:none;overflow:visible}.table-row{display:grid;grid-template-columns:70px 110px 1fr 1fr 1fr 80px;border-bottom:1px solid #e2e8f0;transition:background-color .2s ease;cursor:pointer}.table-container.pdf-mode .table-row{grid-template-columns:70px 110px 1fr 1fr 1fr!important}.table-row:hover{background-color:#f1f5f9;transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.table-row-content,.table-row-address{display:contents}.table-cell{padding:12px 8px;display:flex;align-items:center;justify-content:center;border-right:1px solid #e2e8f0}.table-cell:last-child{border-right:none}.table-cell.pdf-hidden{display:none!important}.work-id-cell{justify-content:center}.work-id{display:inline-block;color:#1e293b;padding:6px 12px;border-radius:8px;font-weight:600;min-width:50px;text-align:center}.work-date-cell{color:#64748b;font-weight:500}.work-front-cell,.work-before-cell,.work-after-cell{padding:8px}.table-image{width:100%;height:80px;object-fit:cover;border-radius:6px;cursor:pointer;border:2px solid #e2e8f0;transition:all .2s ease}.table-image:hover{transform:scale(1.05);border-color:#667eea;box-shadow:0 4px 12px #00000026}.no-image{width:100%;height:60px;display:flex;align-items:center;justify-content:center;background:#f1f5f9;border:2px dashed #cbd5e1;border-radius:6px;color:#94a3b8;text-align:center}.work-address-cell{grid-column:span 3;background:#f8fafc;border-top:1px solid #e2e8f0;justify-content:flex-start;padding:8px 12px;display:flex;align-items:center;gap:8px}.go-to-location-btn{padding:2px 4px;min-width:30px;width:30px;font-size:12px;background-color:#e0f2fe;border:1px solid #7dd3fc;border-radius:4px;cursor:pointer;flex:0 0 30px}.go-to-location-btn:hover{background-color:#bae6fd}.go-to-location-btn.pdf-hidden{display:none}.address-text{color:#475569;line-height:1.4;word-break:break-all;text-align:left;flex:1}.work-status-cell{justify-content:center}.status-text{display:inline-block;padding:6px 12px;border-radius:8px;font-weight:600;border:2px solid}.status-text.status-완료{color:#059669;border-color:#10b981;background:#ecfdf5}.status-text.status-진행중{color:#d97706;border-color:#f59e0b;background:#fffbeb}.status-text.status-대기{color:#6b7280;border-color:#9ca3af;background:#f9fafb}.work-actions-cell{justify-content:center}.delete-btn:hover{background:#fee2e2;color:#dc2626;transform:scale(1.1)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.empty-icon{margin-bottom:20px;color:#94a3b8}.empty-state h3{margin:0 0 10px;color:#1e293b}.empty-state p{margin:0;color:#64748b}@media (max-width: 1024px){.table-header,.table-row{grid-template-columns:50px 90px 1fr 1fr 1fr 60px}.table-container.pdf-mode .table-header,.table-container.pdf-mode .table-row{grid-template-columns:50px 90px 1fr 1fr 1fr}.header-cell,.table-cell{padding:8px 4px}.work-front-cell,.work-before-cell,.work-after-cell{padding:4px}}@media (max-width: 768px){.table-container{overflow-x:auto}.table-header,.table-row{grid-template-columns:50px 50px 1fr 1fr 1fr 50px}.table-container.pdf-mode .table-header,.table-container.pdf-mode .table-row{grid-template-columns:40px 80px 1fr 1fr 1fr;min-width:460px}.header-cell,.table-cell{padding:6px 3px}.work-front-cell,.work-before-cell,.work-after-cell{padding:3px}.table-image{height:80px}.status-text{padding:4px 8px}}@media (max-width: 768px){.no-image{font-size:10px}.empty-state{font-size:18px}.empty-state p{font-size:14px}}.pdf-dialog-overlay{position:fixed;top:0;left:250px;right:0;bottom:0;background-color:#000000d9;display:flex;justify-content:center;align-items:center;z-index:99999;padding:20px}.pdf-dialog{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;width:100%;max-width:1200px;height:95vh;overflow:hidden;display:flex;flex-direction:column;z-index:10000}.pdf-dialog-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:16px 24px;display:flex;justify-content:space-between;align-items:center;border-radius:12px 12px 0 0}.pdf-dialog-header h2{margin:0;font-size:1.3rem;font-weight:600}.pdf-dialog-header button{background:#fff3;border:none;color:#fff;width:32px;height:32px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;transition:background-color .2s}.pdf-dialog-header button:hover{background:#ffffff4d}.pdf-dialog-header button:disabled{opacity:.5;cursor:not-allowed}.pdf-dialog-header button:disabled:hover{background:#fff3}.pdf-search-conditions{background:#f8fafc;padding:12px 24px;border-bottom:1px solid #e5e7eb;font-size:.9rem;color:#374151;display:flex;justify-content:space-between;align-items:center}.pdf-search-conditions strong{color:#1f2937;font-weight:600}.search-conditions-left{flex:1;text-align:left}.search-conditions-right{flex-shrink:0;text-align:right;font-weight:600;color:#059669}.pdf-actions{padding:12px 24px;background:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.pdf-generate-button{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:5px 24px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s;box-shadow:0 4px 6px -1px #0000001a}.pdf-generate-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 8px -1px #00000026}.pdf-generate-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.pdf-actions-left{flex:1}.pdf-actions-right{flex-shrink:0}.pdf-preview-info{font-size:.9rem;color:#6b7280;font-weight:500}.pdf-progress-container{position:absolute;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;justify-content:center;align-items:center;z-index:10001;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.pdf-progress-content{background:#fff;border-radius:16px;padding:32px;text-align:center;max-width:400px;width:90%;box-shadow:0 20px 25px -5px #0000004d,0 10px 10px -5px #0003;animation:pdfProgressSlideIn .3s ease-out}@keyframes pdfProgressSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.pdf-progress-header h3{margin:0 0 16px;font-size:1.5rem;font-weight:700;color:#1f2937}.pdf-progress-text{margin:0 0 24px;font-size:1rem;color:#6b7280;font-weight:500}.pdf-progress-bar-container{position:relative;background:#e5e7eb;border-radius:12px;height:24px;margin:0 0 24px;overflow:hidden;box-shadow:inset 0 2px 4px #0000001a}.pdf-progress-bar{background:linear-gradient(90deg,#10b981,#059669);height:100%;border-radius:12px;transition:width .3s ease;position:relative;overflow:hidden}.pdf-progress-bar:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:pdfProgressShimmer 1.5s infinite}@keyframes pdfProgressShimmer{0%{left:-100%}to{left:100%}}.pdf-progress-percentage{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.875rem;font-weight:700;color:#1f2937;text-shadow:0 1px 2px rgba(255,255,255,.8)}.pdf-progress-info{background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;padding:16px;margin:0}.pdf-progress-info p{margin:0;font-size:.875rem;color:#92400e;font-weight:500}.pdf-cancel-button{margin-top:20px;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;padding:12px 32px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s;box-shadow:0 4px 6px -1px #0000001a;width:100%}.pdf-cancel-button:hover{transform:translateY(-1px);box-shadow:0 6px 8px -1px #00000026;background:linear-gradient(135deg,#dc2626,#b91c1c)}.pdf-preview-container{flex:1;overflow-y:auto;padding:20px;background:#fff;min-height:0;max-height:none}.pdf-preview-header{text-align:center;margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid #e5e7eb}.pdf-preview-header h3{margin:0;font-size:1.3rem;font-weight:700;color:#1f2937}.pdf-preview-content{width:100%;max-width:210mm;margin:0 auto}.pdf-work-table-container{width:100%;overflow-x:auto;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #0000001a}.pdf-preview-notice{background-color:#fef3c7;border:1px solid #f59e0b;border-radius:6px;padding:10px 16px;margin-bottom:12px;font-size:.875rem;color:#92400e;font-weight:500}.pdf-work-table{border-collapse:collapse;background:#fff;font-size:.875rem;table-layout:fixed}.pdf-work-table thead{background:linear-gradient(135deg,#f3f4f6,#e5e7eb)}.pdf-work-table th{padding:12px 8px;text-align:center;font-weight:600;color:#374151;border-bottom:2px solid #d1d5db;font-size:.875rem;white-space:nowrap}.pdf-work-table tbody tr{border-bottom:1px solid #e5e7eb}.pdf-work-table tbody tr:hover{background-color:#f9fafb}.pdf-work-table td{padding:8px;text-align:center;vertical-align:middle;border-right:1px solid #f3f4f6}.pdf-work-table td:last-child{border-right:none}.pdf-work-id{font-weight:600;color:#1f2937;font-size:.8rem}.pdf-work-date{color:#6b7280;font-size:.8rem}.pdf-work-image-cell{width:250px;height:150px;padding:6px!important;background:#f8fafc}.pdf-work-image{width:100%;height:130px;max-height:130px;object-fit:contain;border-radius:6px;border:1px solid #e5e7eb;background:#fff;display:block;margin:0 auto}.pdf-no-image{width:100%;height:130px;background:#f3f4f6;border:2px dashed #d1d5db;border-radius:6px;display:flex;align-items:center;justify-content:center;color:#9ca3af;font-size:.75rem;font-weight:500}.pdf-address-row{background-color:#f8fafc;border-top:1px solid #e5e7eb}.pdf-work-address-content{padding:8px 12px!important;font-size:.875rem;color:#374151;text-align:center;word-break:break-all;line-height:1.3;background:#f8fafc;border-bottom:1px solid #e5e7eb}.pdf-work-address{margin-top:8px;font-size:.75rem;color:#374151;text-align:center;word-break:break-all;padding:0 4px;line-height:1.2;max-width:180px;margin-left:auto;margin-right:auto}.pdf-no-data{text-align:center;padding:40px 20px;color:#6b7280;font-size:1rem}.pdf-work-table th:nth-child(1),.pdf-work-table td.pdf-work-id{width:36px;padding-left:4px;padding-right:4px}.pdf-work-table th:nth-child(2),.pdf-work-table td.pdf-work-date{min-width:60px;max-width:80px;width:60px;padding-left:4px;padding-right:4px}@media (max-width: 768px){.pdf-dialog-overlay{left:0}.pdf-dialog{margin:10px;height:90vh}.pdf-dialog-header{padding:12px 20px}.pdf-dialog-header h2{font-size:1.1rem}.pdf-search-conditions{padding:8px 20px;font-size:.8rem;flex-direction:column;gap:4px;align-items:flex-start}.search-conditions-right{align-self:flex-end}.pdf-actions{padding:8px 20px;flex-direction:column;gap:8px;align-items:stretch}.pdf-actions-left{text-align:center}.pdf-preview-info{font-size:.8rem}.pdf-preview-container{padding:12px 20px;min-height:0;max-height:none}.pdf-work-table{font-size:.75rem}.pdf-work-table th,.pdf-work-table td{padding:4px 2px}.pdf-work-image-cell{width:70px;min-width:70px;max-width:90px;height:100px}.pdf-work-image{height:80px;max-height:80px}.pdf-no-image{height:80px}}@media print{.pdf-dialog-overlay{position:static;background:none;padding:0}.pdf-dialog{box-shadow:none;border:none;max-height:none;max-width:none}.pdf-dialog-header,.pdf-search-conditions,.pdf-actions{display:none}.pdf-preview-container{padding:0;min-height:auto;max-height:none}.pdf-work-image-cell{height:200px;min-width:160px;max-width:180px}.pdf-work-image{height:180px;max-height:180px}}.pull-to-refresh-container{position:relative;height:100%;overflow:hidden;touch-action:pan-y}.pull-to-refresh-indicator{position:absolute;top:-60px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;justify-content:center;width:60px;height:60px;background:#ffffffe6;border-radius:50%;box-shadow:0 2px 8px #0000001a;z-index:1000;transition:all .3s ease}.pull-to-refresh-indicator.refreshing{background:#667eeae6;color:#fff}.refresh-icon{font-size:20px;margin-bottom:4px;transition:transform .3s ease}.refresh-text{font-size:10px;font-weight:500;text-align:center;line-height:1.2;color:#666;white-space:nowrap}.pull-to-refresh-indicator.refreshing .refresh-text{color:#fff}.pull-to-refresh-content{height:100%;overflow:visible}@media (max-width: 768px){.pull-to-refresh-indicator{width:50px;height:50px;top:-50px}.refresh-icon{font-size:18px}.refresh-text{font-size:9px}}@media (prefers-color-scheme: dark){.pull-to-refresh-indicator{background:#1e1e1ee6;color:#fff}.refresh-text{color:#ccc}}.pull-to-refresh-indicator.refreshing .refresh-icon{animation:spin 1s linear infinite}.work-list-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#fff;z-index:500;display:flex;flex-direction:column;overflow:hidden;height:100%!important}.work-list-overlay-content{flex:1;overflow:hidden;padding:10px 16px 0;background:#f8f9fa;display:flex;flex-direction:column;min-height:0}.reports-content{max-width:100%;margin:0 auto;flex:1;overflow:hidden;position:relative;display:flex;flex-direction:column}.detail-overlay-container{position:absolute;top:0;left:0;right:0;bottom:0;background:#f5f5f5;z-index:600;overflow:hidden}.actions-section{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;flex-wrap:wrap;gap:15px}.sort-controls{display:flex;align-items:center;gap:10px;order:-1;margin-right:auto}.sort-select{padding:8px 12px;border:2px solid #e5e7eb;border-radius:6px;background:#fff;min-width:120px;font-weight:500;color:#374151;transition:all .2s ease}.sort-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.works-table-section{margin-bottom:20px}.pagination{display:flex;justify-content:center;align-items:center;gap:15px}.pagination-top{margin-bottom:5px}.pagination-bottom{margin-top:5px}.page-btn{padding:8px 16px;border:2px solid #e5e7eb;border-radius:6px;background:#fff;cursor:pointer;transition:all .2s ease}.page-btn:hover:not(:disabled){background:#f3f4f6;border-color:#d1d5db;transform:translateY(-1px)}.page-btn:disabled{opacity:.5;cursor:not-allowed}.page-btn.active{background:#667eea;color:#fff;border-color:#667eea;font-weight:600}.page-btn.active:hover{background:#5a67d8;border-color:#5a67d8}.main-screen-blocker{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:9998;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.blocker-content{background:#fff;border-radius:16px;padding:40px;text-align:center;max-width:400px;width:90%;box-shadow:0 20px 25px -5px #0000004d,0 10px 10px -5px #0003;animation:blockerSlideIn .3s ease-out}@keyframes blockerSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.blocker-icon{font-size:3rem;margin-bottom:20px;animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.blocker-content h3{margin:0 0 16px;font-size:1.5rem;font-weight:700;color:#1f2937}.blocker-content p{margin:0;font-size:1rem;color:#6b7280;font-weight:500;line-height:1.5}.results-summary{margin-bottom:15px;padding:12px 16px;background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-radius:8px;border-left:4px solid #667eea}.results-summary p{margin:0;color:#374151;font-weight:500}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.new-work-form{background:#fff;border-radius:12px;max-width:90vw;max-height:90vh;overflow-y:auto;overflow-x:clip}.new-work-form h2{margin:0 0 20px;color:#374151;font-weight:700}@media (max-width: 768px){.actions-section{flex-direction:row;align-items:center;gap:8px;flex-wrap:nowrap;overflow-x:auto}.sort-controls{order:0;margin-right:auto;flex-shrink:0;gap:6px}.sort-select{min-width:80px;padding:6px 8px}.reports-content{margin:0!important;width:100%!important;min-width:0!important;max-width:100vw!important;touch-action:pan-y;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.table-container{width:100%!important;min-width:0!important;max-width:100vw!important}.pagination{gap:4px;flex-wrap:nowrap;width:100%;max-width:100%;justify-content:stretch;padding:0;box-sizing:border-box}.page-btn{padding:4px 0;min-width:0;font-size:15px;flex:1}}@media (max-width: 400px){.pagination{gap:4px;padding:0}.page-btn{padding:4px;min-width:0;flex:1;font-size:14px}}.work-location-container{height:100%;display:flex;flex-direction:column;background:#f8fafc;overflow:hidden}.work-location-container .kakao-map{height:100%!important}.map-section{flex:1;position:relative;overflow:hidden;flex-direction:column}.work-location-map{width:100%;height:100%}.map-loading,.map-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;background:#fff;color:#6b7280;text-align:center}.map-loading .loading-spinner,.map-empty .empty-icon{margin-bottom:20px}.map-empty h3{margin:0 0 10px;color:#374151}.map-empty p{margin:0}.map-empty.error-state{background:#fef2f2}.map-empty.error-state .empty-icon{font-size:3rem}.map-empty.error-state h3{color:#dc2626}.map-overlay-state{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#ffffffe6;color:#6b7280;text-align:center;z-index:100}.map-overlay-state .empty-icon{margin-bottom:20px}.map-overlay-state h3{margin:0 0 10px;color:#374151}.map-overlay-state p{margin:0}.map-overlay-state.error-state{background:#fef2f2f2}.map-overlay-state.error-state .empty-icon{font-size:3rem}.map-overlay-state.error-state h3{color:#dc2626}.info-window{background:#fff;border-radius:8px;padding:12px;box-shadow:0 4px 12px #00000026;border:1px solid #e5e7eb;min-width:200px;max-width:250px}.info-window h4{margin:0 0 8px;font-weight:600;color:#374151}.info-window p{margin:4px 0;color:#6b7280;line-height:1.4}.info-window .status{display:inline-block;padding:2px 8px;border-radius:12px;font-weight:600;text-transform:uppercase}.dialog-overlay{position:fixed;top:0;left:250px;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.dialog-content{background:#fff;border-radius:12px;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;position:relative}.dialog-close-btn{position:absolute;top:8px;right:8px;background:#0000001a;border:none;font-size:16px;color:#6b7280;cursor:pointer;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10;line-height:1}.dialog-close-btn:hover{background:#0003;color:#374151}.dialog-header{display:flex;justify-content:center;align-items:center;padding:16px 24px;border-bottom:1px solid #e5e7eb}.dialog-header h3{margin:0;color:#111827;font-size:18px;font-weight:600}.dialog-body{padding:24px}.dialog-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid #e5e7eb}.work-details{margin-bottom:24px}.work-info{margin-bottom:16px}.work-images{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.image-section{text-align:center}.image-section h5{margin:0 0 12px;color:#374151;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.work-image{width:100%;height:150px;object-fit:cover;border-radius:8px;border:2px solid #e5e7eb;cursor:pointer;transition:all .2s ease}.no-image-text{display:flex;align-items:center;justify-content:center;height:150px;background:#f9fafb;border:2px dashed #d1d5db;border-radius:8px;color:#6b7280;font-style:italic}.work-location-map img[src*=mhsafety_icon]{width:32px!important;height:32px!important;cursor:pointer;transition:transform .2s ease}.work-location-map img[src*=mhsafety_icon]:hover{transform:scale(1.1)}.hoverable-image{cursor:pointer}@media (max-width: 768px){.dialog-overlay{left:0}.dialog-content{margin:10px;max-height:95vh}.work-details{margin-bottom:16px}.work-images{grid-template-columns:1fr;gap:12px}.work-image,.no-image-text{height:120px}}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.login-box{background:#fff;padding:40px;border-radius:15px;box-shadow:0 20px 40px #0000001a;width:100%;max-width:450px;position:relative;overflow:hidden}.login-box:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(135deg,#667eea,#764ba2)}.login-box .login-form input{padding:6px}.login-header{text-align:center;margin-bottom:30px;width:240px;height:240px;border-radius:50%;border:3px solid #667eea;display:flex;flex-direction:column;justify-content:center;align-items:center;margin-left:auto;margin-right:auto;background:linear-gradient(135deg,#667eea1a,#764ba21a);box-shadow:0 8px 32px #667eea33}.login-title{color:#333;font-weight:700;margin-bottom:12px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-subtitle{font-size:16px;color:#666;font-weight:500;margin:0;line-height:1.3;text-align:center;max-width:240px;white-space:nowrap}.login-form{display:flex;flex-direction:column;gap:20px;margin-bottom:30px}.form-group input{padding:14px 16px;border:2px solid #e1e5e9;border-radius:10px;transition:all .3s ease;background:#fafbfc}.form-group input:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed;opacity:.7}.password-input-container{position:relative;display:flex;align-items:center}.password-toggle{position:absolute;right:12px;background:none;border:none;cursor:pointer;padding:4px;border-radius:4px;transition:background-color .2s ease}.password-toggle:hover:not(:disabled){background-color:#0000000d}.password-toggle:disabled{opacity:.5;cursor:not-allowed}.loading-spinner{display:inline-block;animation:spin 1s linear infinite}.error-message{background:#fef2f2;color:#dc2626;padding:12px 16px;border-radius:8px;text-align:center;border:1px solid #fecaca;display:flex;align-items:center;justify-content:center;gap:8px}.test-accounts{margin-top:30px;padding:20px;background:#f8fafc;border-radius:12px;border-left:4px solid #667eea}.test-accounts h3{color:#333;font-weight:600;margin-bottom:15px;text-align:center}.test-account-btn{flex:1;min-width:80px;padding:8px 12px;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s ease;color:#fff}.test-account-btn.admin{background:#dc2626}.test-account-btn.manager{background:#ea580c}.test-account-btn.user{background:#059669}.test-account-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.test-account-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.account-info{background:#fff;padding:12px;border-radius:6px;border:1px solid #e2e8f0}.account-info p{margin:4px 0;color:#64748b;line-height:1.4}.account-info strong{color:#334155}.login-footer{text-align:center;margin-top:30px;padding-top:20px;border-top:1px solid #e2e8f0}.login-footer p{color:#64748b;margin:0}.copyright{margin-top:20px;text-align:center}.copyright-content{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px 16px 8px;border-top:1px solid #e2e8f0}.copyright-logo{width:20px;height:20px;object-fit:contain}.copyright-text{color:#64748b;font-size:14px;font-weight:500}.company-copyright{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:30px;padding-top:20px;border-top:1px solid #e2e8f0}.company-copyright .company-logo{width:24px;height:24px;object-fit:contain}.company-name{color:#64748b;font-weight:500}@media (max-width: 480px){.login-box{padding:30px 20px;margin:10px}.login-header{width:220px;height:220px;border-width:2px}.login-subtitle{max-width:180px}.copyright{margin-top:15px}.copyright-content{padding:12px 12px 6px}.copyright-logo{width:16px;height:16px}.copyright-text{font-size:12px}.company-copyright{margin-top:20px;padding-top:15px}.company-copyright .company-logo{width:20px;height:20px}}@media (prefers-color-scheme: dark){.login-box{background:#1f2937;color:#fff}.login-header{border-color:#8b5cf6;background:linear-gradient(135deg,#8b5cf61a,#a855f71a);box-shadow:0 8px 32px #8b5cf633}.login-title{color:#fff}.form-group input{background:#374151;border-color:#4b5563;color:#fff}.form-group input:focus{background:#374151;border-color:#667eea}.test-accounts{background:#374151}.account-info{background:#4b5563;border-color:#6b7280}.account-info p{color:#d1d5db}.account-info strong{color:#f3f4f6}.company-copyright{border-top-color:#4b5563}.company-name{color:#d1d5db}}.App{min-height:100vh}.reports-container{height:100%;background-color:#f5f5f5;padding:0 10px;box-sizing:border-box;display:flex;flex-direction:column}.new-work-container{width:100%;max-width:100%;margin:0 auto;background:#fff;border-radius:8px;padding:5px 30px;min-height:auto;box-sizing:border-box}.new-work-form{display:flex;flex-direction:column}.form-row{display:flex;gap:24px;margin-bottom:6px}.form-row .form-group{flex:1}.form-group{display:flex;flex-direction:column}.form-group label{margin-bottom:3px;font-weight:600;color:#333}.form-group input,.form-group select,.form-group textarea{padding:3px;border:1px solid #ddd;border-radius:4px;transition:border-color .2s ease,box-shadow .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group textarea{resize:vertical;height:35px;min-height:50px}.required{color:red;font-weight:700}.detail-value{padding:4px 12px;background-color:#f8f9fa;border-radius:4px;border-left:3px solid #667eea;color:#333;line-height:1.4}.detail-value.description{white-space:pre-wrap;min-height:50px;line-height:1.6}.status-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-weight:600;text-align:center;border:1px solid}.status-completed{background-color:#e8f5e8;color:#2e7d32;border-color:#2e7d32}.status-progress{background-color:#fff3e0;color:#f57c00;border-color:#f57c00}.status-waiting{background-color:#f3e5f5;color:#7b1fa2;border-color:#7b1fa2}.status-default{background-color:#f5f5f5;color:#666;border-color:#666}.image-container{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%}.detail-image{width:100%;max-width:400px;height:200px;object-fit:cover;border-radius:8px;border:2px solid #e2e8f0;transition:transform .2s ease;cursor:pointer}.detail-image:hover{transform:scale(1.02)}.no-image{width:100%;max-width:400px;height:200px;display:flex;align-items:center;justify-content:center;background-color:#f8f9fa;border:2px dashed #d1d5db;border-radius:8px;color:#6b7280;font-style:italic}.image-preview{display:block}.preview-image{display:block;margin:0 auto;max-width:100%;max-height:150px;object-fit:cover;border-radius:6px;border:2px solid #e2e8f0}.file-input-container{display:flex;flex-direction:row;gap:8px;align-items:center}.form-group input[type=file]{border:2px dashed #ddd;background:#f9f9f9;cursor:pointer}.form-group input[type=file]:hover{border-color:#667eea;background:#f0f8ff}.file-cancel-btn{padding:6px 12px;background:#dc3545;color:#fff;border:none;border-radius:4px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.file-cancel-btn:hover{background:#c82333}.file-select-btn{padding:8px 16px;background:#007bff;color:#fff;border:none;border-radius:4px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.file-select-btn:hover{background:#0056b3}.file-select-btn:disabled{background:#6c757d;cursor:not-allowed}.form-actions{display:flex;gap:12px;justify-content:flex-end}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:calc(100vh - 80px);background:#fff;color:#6b7280;text-align:center}.loading-spinner{animation:spin 1s linear infinite;margin-bottom:20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:calc(100vh - 80px);background:#fff;color:#6b7280;text-align:center}.error-icon{font-size:3rem;margin-bottom:20px}.error-container h3{margin:0 0 10px;color:#374151}.error-container p{margin:0}.map-container{width:100%;border-radius:8px;overflow:hidden;border:1px solid #e5e7eb;margin-top:4px}.no-location{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;background-color:#f8f9fa;border:2px dashed #d1d5db;border-radius:8px;color:#6b7280;text-align:center}.no-location p{margin:0;font-style:italic}@media (max-width: 1024px){html,body,button,input,select,textarea{font-size:13px}.work-list-overlay,.work-location-container .kakao-map{flex:1}}@media (max-width: 768px){html,body,button,input,select,textarea{font-size:13px}body{margin-bottom:0!important}.form-group label,.form-group input,.form-group select,.form-group textarea,.detail-value{font-size:1rem}.status-badge,.no-image{font-size:.9rem}.error-container h3{font-size:1.3rem}.error-container p,.no-location p{font-size:1rem}.reports-container{padding:0 10px 60px}.new-work-container{padding:0 20px}.form-actions{flex-direction:row;gap:10px}.detail-image,.no-image{height:150px}.work-list-overlay,.work-location-container .kakao-map{flex:1}}@media (max-width: 480px){html,body,button,input,select,textarea{font-size:11px}.reports-container{padding:8px 8px 60px}.new-work-container{padding:6px 15px}.form-group input,.form-group select,.form-group textarea{padding:8px}.work-list-overlay,.work-location-container .kakao-map{flex:1}}html,body{color:#222;font-family:Noto Sans KR,Apple SD Gothic Neo,Arial,sans-serif;margin:0;padding:0}
