body{background-color:#f9fafb;font-family:"Arial",sans-serif;padding:0}.container{max-width:800px;margin:2rem auto}.document-request-card{background-color:#fff;box-shadow:0 4px 6px rgba(0,0,0,.1);border-radius:.75rem;padding:2rem}.page-title{text-align:center;color:#2c3e50;font-size:1.875rem;margin-bottom:1.5rem}.document-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:1rem;gap:1rem;margin-bottom:1.5rem}.document-item{border:1px solid #e0e0e0;border-radius:.5rem;padding:1rem;display:flex;align-items:center;cursor:pointer;transition:all .3s ease;position:relative}.document-item:hover{background-color:#f5f5f5;border-color:#3b82f6}.document-item.selected{background-color:#dbeafe;border-color:#3b82f6}.document-item-details{margin-left:1rem;flex-grow:1}.document-item-title{font-weight:600;color:#333}.document-item-description{color:#666;font-size:.875rem}.document-item input[type=checkbox]{position:absolute;top:1rem;right:1rem;cursor:pointer}.submit-button{width:100%;background-color:#2563eb;color:#fff;padding:.75rem;border:none;border-radius:.5rem;cursor:pointer;transition:background-color .3s ease;margin-top:1rem}.submit-button:disabled{background-color:#93c5fd;cursor:not-allowed}.submit-button:hover:not(:disabled){background-color:#1d4ed8}.requests-section{margin-top:2rem}.request-item{background-color:#f3f4f6;border-radius:.5rem;padding:1rem;margin-bottom:1rem}.request-details{flex-grow:1}.request-status{display:flex;align-items:center;margin-top:.5rem}.request-item.ready-to-retrieve{background-color:rgba(220,252,231,.6);border-left:4px solid #22c55e;box-shadow:0 2px 8px rgba(0,0,0,.05);transition:all .2s ease}.request-item.ready-to-retrieve:hover{background-color:rgba(220,252,231,.8)}.request-item.ready-to-retrieve .request-status{font-weight:600;color:#16a34a}.status-icon{margin-right:.5rem}.loading-spinner{height:200px;color:#2563eb;font-size:1.25rem}.error-message,.loading-spinner{display:flex;justify-content:center;align-items:center}.error-message{color:#dc2626;grid-gap:.5rem;gap:.5rem;margin-top:1rem}.request-item{position:relative;display:flex;justify-content:space-between;align-items:center}.delete-button{padding:5px}.delete-button .icon{color:red;width:20px;height:20px;transition:transform .2s ease-in-out}.delete-button:hover .icon{transform:scale(1.1)}.request-actions{display:flex;grid-gap:8px;gap:8px;align-items:center}.retrieve-button{background-color:#f44;color:#fff;border:none;border-radius:4px;padding:6px 12px;font-size:14px;cursor:pointer;transition:background-color .2s}.retrieve-button:hover{background-color:red}.delete-button{background:none;border:none;cursor:pointer;color:#666;display:flex;align-items:center;justify-content:center;padding:4px}.delete-button:hover{color:#f44}.attendance-modal{width:90%;max-width:1200px;max-height:90vh;overflow-y:auto}.attendance-section{padding:20px}.attendance-section h3{color:#333;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid #007bff}.loading{color:#666;font-style:italic}.loading,.no-data{text-align:center;padding:40px}.no-data{color:#999;background-color:#f8f9fa;border-radius:8px;border:2px dashed #ddd}.reservations-list{display:flex;flex-direction:column;grid-gap:15px;gap:15px}.reservation-card{background:#fff;border:1px solid #ddd;border-radius:8px;padding:20px;box-shadow:0 2px 4px rgba(0,0,0,.1);transition:box-shadow .2s ease}.reservation-card:hover{box-shadow:0 4px 8px rgba(0,0,0,.15)}.reservation-info{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:15px}.place-details h4{color:#007bff;margin:0 0 5px;font-size:1.2em}.place-details p{color:#666;margin:0;font-size:.9em}.time-info p{margin:0 0 5px;font-size:.9em}.status{padding:3px 8px;border-radius:4px;font-size:.8em;font-weight:700}.status.validByAdministrator,.status.validByManager{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.attendance-confirmed{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;padding:15px}.confirmation-status{margin-bottom:10px}.status-badge{display:inline-block;padding:6px 12px;border-radius:20px;font-weight:700;font-size:.9em;margin-bottom:8px}.status-badge.valid{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.status-badge.invalid{background-color:#fff3cd;color:#856404;border:1px solid #ffeaa7}.confirmation-time{color:#666;font-size:.85em;margin:5px 0}.ip-warning{color:#856404;font-size:.85em;font-style:italic;margin:5px 0}.attendance-notes{background-color:#e9ecef;padding:10px;border-radius:4px;margin-top:10px}.confirm-attendance{border-top:1px solid #e9ecef;padding-top:15px}.notes-input{margin-bottom:15px}.notes-input label{display:block;margin-bottom:5px;font-weight:700;color:#333}.notes-input textarea{width:100%;border:1px solid #ddd;border-radius:4px;padding:8px;font-family:inherit;resize:vertical;min-height:60px}.notes-input textarea:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px rgba(0,123,255,.25)}.confirm-button{background-color:#28a745;color:#fff;border:none;padding:12px 24px;border-radius:6px;font-weight:700;cursor:pointer;transition:background-color .2s ease;width:100%}.confirm-button:hover{background-color:#218838}.confirm-button:disabled{background-color:#6c757d;cursor:not-allowed}.admin-attendances{display:flex;flex-direction:column;grid-gap:20px;gap:20px}.admin-attendance-card{background:#fff;border:1px solid #ddd;border-radius:8px;padding:20px;box-shadow:0 2px 4px rgba(0,0,0,.1)}.attendance-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:15px;padding-bottom:10px;border-bottom:1px solid #e9ecef}.user-info h4{color:#007bff;margin:0 0 5px;font-size:1.1em}.user-info p{color:#666;margin:0;font-size:.9em}.status-info{text-align:right}.ip-status{display:inline-block;padding:4px 10px;border-radius:4px;font-size:.85em;font-weight:700;margin-bottom:5px}.ip-status.valid{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.ip-status.invalid{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.place-info,.reservation-details{margin-bottom:10px;color:#333;font-size:.9em}.ip-details{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;padding:10px;margin:10px 0}.ip-info{margin-bottom:5px;font-size:.85em;font-family:"Courier New",monospace}.ip-info:last-child{margin-bottom:0}.notes-section{margin-top:15px}.notes-section label{display:block;margin-bottom:5px;color:#333}.notes-section textarea{width:100%;border:1px solid #ddd;border-radius:4px;padding:8px;font-family:inherit;resize:vertical;min-height:60px}.notes-section textarea:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px rgba(0,123,255,.25)}.notes-section textarea:disabled{background-color:#f8f9fa;cursor:not-allowed}@media (max-width:768px){.attendance-modal{width:95%}.attendance-header,.reservation-info{flex-direction:column;grid-gap:10px;gap:10px}.status-info{text-align:left}}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen,Ubuntu,Cantarell,"Open Sans","Helvetica Neue",sans-serif;color:#333;background-color:#f5f5f5}.container{max-width:1200px;margin:0 auto;padding:1rem}.card{background-color:#fff;border-radius:.5rem;box-shadow:0 4px 6px rgba(0,0,0,.1);padding:1.5rem}h1{font-size:1.5rem;font-weight:700}.selectors,h1{margin-bottom:1.5rem}.selectors{grid-gap:1rem;gap:1rem}label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.25rem}input[type=date],select{width:100%;padding:.5rem;border:1px solid #ccc;border-radius:.25rem;font-size:1rem}.desk-visualization{background-color:#f8f8f8;padding:1rem;border-radius:.5rem;margin-bottom:1.5rem}.desk-legend{align-items:center;margin-bottom:1rem}.legend-item{margin-right:1rem}.color-box{width:1rem;height:1rem;margin-right:.5rem}.color-box.available{background-color:#d1d5db}.color-box.booked{background-color:#10b981}.desk-grid{display:grid;grid-template-columns:repeat(5,1fr);grid-gap:1rem;gap:1rem}.desk{padding:.75rem;border-radius:.5rem;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:all .2s}.desk.available{background-color:#d1d5db;cursor:pointer}.desk.available:hover{background-color:#9ca3af}.desk.booked{background-color:#10b981;color:#fff}.desk-icon{width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;margin-bottom:.25rem}.desk-icon svg{width:2rem;height:2rem}.desk span{font-size:.875rem;font-weight:500}.modal-overlay{position:fixed;top:40px;left:100px;right:0;bottom:0;display:block;background-color:rgba(0,0,0,.5);z-index:1000;overflow-y:auto}.info-button{border:none;background:none;outline:none}.modal{position:relative;margin:40px auto 20px;border-radius:.5rem;padding:1.5rem;width:95%;max-width:600px;min-width:300px;box-shadow:0 4px 6px rgba(0,0,0,.1),0 1px 3px rgba(0,0,0,.08);box-sizing:border-box}.modal,.modal-header{background-color:#fff}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;position:-webkit-sticky;position:sticky;top:0;z-index:1;padding-bottom:.75rem;border-bottom:1px solid #e5e7eb}@media (max-width:640px){.modal{margin-top:20px;width:92%}}.form-actions{position:-webkit-sticky;position:sticky;bottom:0;background-color:#fff;padding-top:.5rem;z-index:1}.modal-header h2{font-size:1.25rem;font-weight:700}.close-button{background:none;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer}.close-button:hover{color:#374151}.info-box{margin-bottom:1rem;padding:.75rem;background-color:#eff6ff;border-radius:.5rem;display:flex;align-items:center}.info-icon{margin-right:.75rem;color:#3b82f6}.info-icon svg{width:1.25rem;height:1.25rem}.info-text{font-size:.875rem;color:#1e40af}.form-group{margin-bottom:1rem}.label-with-icon{margin-bottom:.25rem}.label-with-icon svg{margin-right:.25rem}.button{padding:.5rem 1rem;border-radius:.25rem;font-size:.875rem;cursor:pointer;transition:background-color .2s}.button.secondary{background-color:#fff;border:1px solid #ccc;margin-right:.5rem}.button.secondary:hover{background-color:#f3f4f6}.button.primary{background-color:#3b82f6;color:#fff;border:none}.button.primary:hover{background-color:#2563eb}.error-message{color:red;font-size:.875rem;margin-top:.25rem}.selectors{display:flex;flex-wrap:wrap;grid-gap:15px;gap:15px;margin-bottom:20px}.selector{flex:1 1;min-width:200px}.selector label{display:block;margin-bottom:5px;font-weight:500}.selector input,.selector select{width:100%;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px}.label-with-icon{display:flex;align-items:center;grid-gap:5px;gap:5px}.desk-image{margin-bottom:15px;text-align:center}.desk-preview-image{max-width:100%;max-height:200px;border-radius:4px;box-shadow:0 2px 4px rgba(0,0,0,.1)}.reservations-table-container{margin-top:20px;border-top:1px solid #eee;padding-top:20px}.reservations-table-container h3{margin-bottom:15px}.table-responsive{overflow-x:auto}.reservations-table{width:100%;border-collapse:collapse;margin-bottom:15px}.reservations-table td,.reservations-table th{padding:8px 12px;border:1px solid #ddd;text-align:left}.reservations-table th{background-color:#f5f5f5;font-weight:500}.action-buttons{display:flex;grid-gap:5px;gap:5px}.pagination{display:flex;justify-content:center;align-items:center;grid-gap:15px;gap:15px;margin-top:15px}.pagination-button{padding:6px 12px;background-color:#f5f5f5;border:1px solid #ddd;border-radius:4px;cursor:pointer}.pagination-button:hover{background-color:#e9e9e9}.pagination-button:disabled{opacity:.5;cursor:not-allowed}.empty-state{padding:20px;text-align:center;color:#666;background-color:#f9f9f9;border-radius:4px;margin:15px 0}.desk{cursor:pointer}.desk.available{background-color:#f0f0f0;border:1px solid #ddd}.desk.pending{background-color:#fff3e0;border:1px solid #ffb74d;color:#e65100}.desk.validated-admin{background-color:#e8f5e9;border:1px solid #66bb6a;color:#2e7d32}.desk.validated-manager{background-color:#e3f2fd;border:1px solid #42a5f5;color:#1565c0}.desk-legend{display:flex;margin-bottom:20px;flex-wrap:wrap}.legend-item{display:flex;align-items:center;margin-right:20px;margin-bottom:10px}.color-box{width:16px;height:16px;margin-right:8px;border-radius:2px}.color-box.available{background-color:#f0f0f0;border:1px solid #ddd}.color-box.pending{background-color:#fff3e0;border:1px solid #ffb74d}.color-box.validated-admin{background-color:#e8f5e9;border:1px solid #66bb6a}.color-box.validated-manager{background-color:#e3f2fd;border:1px solid #42a5f5}.card-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;margin-bottom:1rem}.card-header h1{margin:0;font-size:1.5rem;color:#333;font-weight:600}.bulk-reservation-button{display:flex;align-items:center;grid-gap:.5rem;gap:.5rem;padding:.5rem 1rem;background-color:#007bff;color:#fff;border:none;border-radius:.25rem;cursor:pointer;transition:background-color .3s ease}.bulk-reservation-button:hover{background-color:#0056b3}.bulk-reservation-button:focus{outline:none;box-shadow:0 0 0 3px rgba(0,123,255,.3)}.bulk-reservation-button:disabled{background-color:#6c757d;cursor:not-allowed}.bulk-reservation-modal{max-width:600px;width:100%;padding:1.5rem}.bulk-reservation-content{display:flex;flex-direction:column;grid-gap:1rem;gap:1rem}.form-group{display:flex;flex-direction:column;grid-gap:.5rem;gap:.5rem}.form-group label{font-weight:600;color:#333}.form-group .full-width,.form-group select.full-width{width:100%;padding:.5rem;border:1px solid #ddd;border-radius:.25rem}.form-actions{display:flex;justify-content:flex-end;grid-gap:1rem;gap:1rem;margin-top:1rem}.tabs-navigation{display:flex;border-bottom:1px solid #ddd;margin-bottom:20px}.tab-button{padding:10px 20px;border:none;background:transparent;cursor:pointer;font-size:16px;position:relative;transition:color .3s}.tab-button:hover{color:#007bff}.tab-button.active{color:#007bff;font-weight:700}.tab-button.active:after{content:"";position:absolute;bottom:-1px;left:0;width:100%;height:3px;background-color:#007bff}.tab-content{padding:10px 0}.reservations-tab,.visualization-tab{width:100%}.info-modal{max-width:750px}.info-icon-emoji{font-size:16px;margin-right:4px}.info-modal-body-content{padding:0}.visualization-images-grid{display:flex;flex-direction:column;grid-gap:30px;gap:30px}.visualization-item h4{margin:0 0 15px;color:#333;font-size:18px;text-align:center}.visualization-image{display:block;margin:0 auto}@media (min-width:768px){.visualization-images-grid{flex-direction:row;justify-content:space-around}.visualization-item{flex:1 1;max-width:45%}}.plan-navigation{grid-gap:20px;gap:20px;padding:20px}.nav-button,.plan-navigation{display:flex;align-items:center;justify-content:center}.nav-button{background:#f8f9fa;border:1px solid #ddd;border-radius:50%;width:40px;height:40px;cursor:pointer;font-size:20px;font-weight:700;transition:all .2s ease}.nav-button:hover:not(:disabled){background:#e9ecef;border-color:#adb5bd}.nav-button:disabled{opacity:.3;cursor:not-allowed}.plan-content{text-align:center;flex:1 1;max-width:600px}.plan-content h4{margin:0 0 15px;color:#333;font-size:18px}.plan-indicators{display:flex;justify-content:center;grid-gap:10px;gap:10px;padding:0 20px 20px}.indicator{width:30px;height:30px;border-radius:50%;border:1px solid #ddd;background:#f8f9fa;cursor:pointer;font-size:14px;transition:all .2s ease}.indicator:hover{background:#e9ecef}.indicator.active{background:#007bff;color:#fff;border-color:#007bff}.visualization-image{max-width:100%;height:auto;border:1px solid #ddd;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.1);transition:transform .2s ease}.visualization-image:hover{transform:scale(1.02)}.attendance-button{background-color:#17a2b8;color:#fff;border:1px solid #17a2b8;padding:.5rem 1rem;border-radius:.25rem;font-size:.875rem;cursor:pointer;transition:background-color .2s;margin-right:.5rem}.attendance-button:hover{background-color:#138496;border-color:#117a8b}.header-right{display:flex;align-items:center;grid-gap:10px;gap:10px}.attendance-button{position:relative}.attendance-button.has-notifications:after{content:"";position:absolute;top:-2px;right:-2px;width:8px;height:8px;background-color:#dc3545;border-radius:50%;border:2px solid #fff}@media (max-width:640px){.plan-navigation{grid-gap:10px;gap:10px;padding:15px}.nav-button{width:35px;height:35px;font-size:18px}}.date-filter-section{margin-bottom:20px;padding:15px;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.date-filter-section h4{margin:0 0 12px;color:#495057;font-size:14px;font-weight:600}.date-filter-row{display:flex;align-items:end;grid-gap:15px;gap:15px;flex-wrap:wrap}.date-input-group{display:flex;flex-direction:column;grid-gap:4px;gap:4px;min-width:140px}.date-input-group label{font-size:12px;font-weight:500;color:#6c757d;margin:0}.date-input{padding:6px 8px;border:1px solid #ced4da;border-radius:4px;font-size:13px;height:32px;background:#fff;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out}.date-input:focus{outline:none;border-color:#80bdff;box-shadow:0 0 0 2px rgba(0,123,255,.25)}.apply-filter-btn{padding:6px 16px;background:#007bff;color:#fff;border:none;border-radius:4px;font-size:13px;font-weight:500;height:32px;cursor:pointer;transition:background-color .15s ease-in-out;white-space:nowrap}.apply-filter-btn:hover:not(:disabled){background:#0056b3}.apply-filter-btn:disabled{background:#6c757d;cursor:not-allowed}@media (max-width:768px){.date-filter-row{flex-direction:column;align-items:stretch}.date-input-group{min-width:auto}.apply-filter-btn{width:100%}}.date-filter-row.ultra-compact{grid-gap:8px;gap:8px}.date-filter-row.ultra-compact .date-input-group{min-width:120px}.date-filter-row.ultra-compact .date-input{font-size:12px;height:28px;padding:4px 6px}.date-filter-row.ultra-compact .apply-filter-btn{height:28px;padding:4px 12px;font-size:12px}body{margin:0;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}code{font-family:source-code-pro,Menlo,Monaco,Consolas,"Courier New",monospace}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb,::-webkit-scrollbar-thumb:hover{background:#ccc}