:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;width:100%;overflow-x:hidden}:root{--header-height: 60px}.layout-container{display:flex;min-height:100vh;width:100%}.sidebar{position:fixed;top:var(--header-height);left:-260px;width:250px;height:calc(100% - var(--header-height));background:#fff;border-right:1px solid #e0e0e0;box-shadow:2px 0 5px #0000001a;padding:20px;transition:left .3s ease-in-out;z-index:1000}.sidebar.open{left:0}.sidebar ul{list-style:none;padding:40px 0 0;margin:0}.sidebar li{margin-bottom:15px}.sidebar a{text-decoration:none;color:#333;font-size:1.1rem;font-weight:500;padding:10px;display:block;border-radius:5px}.sidebar a:hover{background-color:#f4f4f4}.close-btn{position:absolute;top:10px;right:15px;font-size:2rem;background:none;border:none;cursor:pointer}.main-content{flex-grow:1;min-height:100vh;display:flex;flex-direction:column;width:100%;overflow-x:hidden}.main-header{position:fixed;top:0;left:0;right:0;width:100%;display:flex;align-items:center;padding:0 20px;height:60px;background:#fff;border-bottom:1px solid #e0e0e0;z-index:1001}.menu-btn{background:none;border:none;font-size:24px;cursor:pointer;margin-right:15px}.main-header h1{font-size:1.5rem;margin:0}.content-area{padding-top:var(--header-height);flex-grow:1;padding:20px;overflow-y:auto;background-color:#f9f9f9}.overlay{position:fixed;top:var(--header-height);left:0;width:100%;height:calc(100% - var(--header-height));background:#0006;z-index:999;opacity:1;transition:opacity .3s ease-in-out}.sidebar:not(.open)+.overlay{opacity:0;pointer-events:none}@media(max-width:992px){.content-area{margin:0;max-width:100%}}@media(max-width:576px){.sidebar{width:85%;max-width:280px;left:-85%;top:var(--header-height);height:calc(100% - var(--header-height))}.sidebar.open{left:0}.main-header h1{font-size:1.2rem}.content-area{padding:10px;padding-top:calc(var(--header-height) + 10px)}.auth-section{gap:10px}.overlay{top:var(--header-height);height:calc(100% - var(--header-height))}}.main-header{display:flex;align-items:center;padding:0 20px}.main-header h1{margin:0 0 0 15px}.auth-section{display:flex;align-items:center;gap:15px;margin-left:auto}.user-pseudo{font-size:.9rem;color:#333;font-weight:500;white-space:nowrap}.logout-btn{background-color:#dc2626;color:#fff;border:none;padding:8px 12px;border-radius:.375rem;cursor:pointer;font-size:.9rem;font-weight:500;transition:background-color .2s}.logout-btn:hover{background-color:#b91c1c}@media(max-width:576px){.user-pseudo{display:none}.main-header h1{font-size:1.2rem}.edit-form-buttons button{padding:10px 16px}}.material-detail-container{padding:1rem}.material-header{display:flex;gap:2rem;margin-bottom:2rem;background:#f8f9fa;padding:1rem;border-radius:8px}.material-header img{width:150px;height:150px;object-fit:cover;border-radius:8px}.material-info h2,.reservations-section h3{margin-top:0}.reservations-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.reservations-list li{display:flex;justify-content:space-between;padding:.75rem;border-radius:4px;margin-bottom:.5rem;background:#fff;border:1px solid #eee;cursor:pointer;transition:background-color .2s}.resa-status.accepted{color:#28a745;font-weight:700}.resa-status.pending{color:#ffc107;font-weight:700}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;padding:2rem;border-radius:8px;max-width:500px;width:90%;position:relative}.modal-close{position:absolute;top:10px;right:15px;background:none;border:none;font-size:1.5rem;cursor:pointer}.modal-content h3{margin-top:0}.modal-content ul{padding-left:20px}.inventaire-container{padding:1rem}.inventaire-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.inventaire-card{border:1px solid #e5e7eb;border-radius:8px;padding:1rem;text-align:center;cursor:pointer;transition:box-shadow .2s,transform .2s;background:#fff}.inventaire-card:hover{transform:translateY(-5px);box-shadow:0 4px 12px #0000001a}.inventaire-card img{width:100%;height:150px;object-fit:cover;border-radius:4px;margin-bottom:.75rem}.card-name{font-weight:600}.my-reservations-section{margin-bottom:2.5rem;padding:1rem;background-color:#f8f9fa;border-radius:8px}.my-reservations-section h3{margin-top:0;margin-bottom:1rem;text-align:center}.my-reservations-section ul{list-style:none;padding:0}.my-reservations-section li{background:#fff;padding:.75rem;border-radius:4px;margin-bottom:.5rem;border-left:4px solid #ffc107}.reservation-item{display:flex;justify-content:space-between;align-items:center}.my-reservations-section li.accepted{border-left-color:#28a745}.my-reservations-section li.pending{border-left-color:#ffc107}.my-reservations-section li.accepted .resa-status{color:#28a745}.my-reservations-section li.pending .resa-status{color:#ffc107}.my-reservations-section.late{background-color:#ffebee}.my-reservations-section.late li{border-left-color:#dc3545;display:flex;justify-content:space-between;align-items:center}.my-reservations-section.current li{display:flex;justify-content:space-between;align-items:center}.category-tabs-nav{display:flex;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap;justify-content:center}.category-tabs-nav button{padding:.5rem 1rem;border:1px solid #ccc;background-color:#f8f9fa;cursor:pointer;border-radius:20px;transition:all .2s}.category-tabs-nav button.active{background-color:#007bff;color:#fff;border-color:#007bff}.date-mode-toggle{align-self:flex-end;background:none;border:none;color:#007bff;cursor:pointer;text-decoration:underline}.reservation-container{padding:1rem}.reservation-container h2{text-align:center;margin-bottom:1.5rem}.date-picker-container{display:flex;justify-content:center;gap:2rem;margin-bottom:2rem;flex-wrap:wrap}.date-field{display:flex;flex-direction:column}.date-field label{margin-bottom:.5rem;font-weight:500}.date-field input{padding:.5rem;border:1px solid #d1d5db;border-radius:.375rem}.reservation-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;width:100%;box-sizing:border-box}.reservation-card{border:2px solid #d1d5db;border-radius:.5rem;padding:1rem;display:flex;flex-direction:column;align-items:center;cursor:pointer;transition:box-shadow .2s,border-color .2s;background:#fff;width:100%;box-sizing:border-box;position:relative}.reservation-card:hover{box-shadow:0 4px 6px #0000001a}.reservation-card.selected{border-color:#2563eb;box-shadow:0 0 10px #2563eb66}.reservation-card.reserved{background-color:#f3f4f6;cursor:not-allowed;opacity:.6}.reservation-card.none-card{justify-content:center;align-items:center;font-weight:700;font-size:1.2rem;background-color:#e9ecef;border-style:dashed}.availability-dot{width:12px;height:12px;border-radius:50%;position:absolute;top:10px;right:10px;border:1px solid white}.availability-dot.available{background-color:#22c55e}.availability-dot.reserved{background-color:#ef4444}.card-content{text-align:center}.reservation-end-date{font-size:.75rem;color:#ef4444;font-weight:500;margin-top:4px}.reservation-card img{width:100%;max-width:140px;height:auto;aspect-ratio:1 / 1;object-fit:cover;border-radius:.5rem;margin-bottom:.5rem;display:block}.reservation-footer{position:fixed;bottom:0;left:0;width:100%;padding:1rem;background:#fff;box-shadow:0 -4px 6px #0000001a;text-align:center}.submit-reservation-btn{padding:.75rem 1.5rem;background-color:#2563eb;color:#fff;font-weight:600;border:none;border-radius:.5rem;cursor:pointer}.return-btn{padding:.5rem 1rem;background-color:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.return-btn:hover{background-color:#0056b3}.cancel-btn{padding:.4rem .8rem;background-color:#dc3545;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.cancel-btn:hover{background-color:#c82333}@media(max-width:576px){.reservation-grid{grid-template-columns:1fr}}.admin-container{padding:1rem;background-color:#f9fafb}.admin-container h2,.admin-container h3{text-align:center;color:#111827}.admin-form-container{background-color:#fff;padding:1.5rem;border-radius:.75rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;margin-bottom:2rem}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.5rem}.form-group{display:flex;flex-direction:column}.form-group.full-width{grid-column:1 / -1}.form-group label{margin-bottom:.5rem;font-weight:500;color:#374151}.form-group input,.form-group select,.form-group textarea{padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;width:100%;box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33}.submit-btn{width:100%;padding:.75rem;background-color:#16a34a;color:#fff;font-weight:600;border-radius:.375rem;border:none;cursor:pointer;transition:background-color .2s}.submit-btn:hover{background-color:#15803d}.filter-container{display:flex;gap:1rem;margin-bottom:1.5rem}.search-bar,.filter-select{flex-grow:1;padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem}.admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.admin-card{background-color:#fff;border-radius:.75rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;overflow:hidden;display:flex;flex-direction:column}.admin-card-image-wrapper{width:100%;aspect-ratio:1 / 1;background-color:#f3f4f6}.admin-card img{width:100%;height:100%;object-fit:cover}.admin-card-content{padding:1rem;flex-grow:1;display:flex;flex-direction:column;justify-content:space-between}.admin-card-content h3{font-size:1.125rem;font-weight:600;margin-bottom:.5rem}.admin-card-content p{font-size:.875rem;color:#4b5563;margin-bottom:.5rem}.admin-card-actions{display:flex;gap:.5rem;padding:1rem;padding-top:0;margin-top:1rem;border-top:1px solid #e5e7eb}.admin-card-actions button{flex:1;padding:.5rem;border-radius:.375rem;font-weight:500;color:#fff;border:none;cursor:pointer;transition:background-color .2s}.admin-card-actions .btn-edit{background-color:#2563eb}.admin-card-actions .btn-edit:hover{background-color:#1d4ed8}.admin-card-actions .btn-delete{background-color:#dc2626}.admin-card-actions .btn-delete:hover{background-color:#b91c1c}.edit-form{width:100%;padding:.5rem}.edit-form-grid{display:flex;flex-direction:column;gap:.75rem}.edit-form-buttons{display:flex;justify-content:space-around;margin-top:1rem}.edit-form-buttons button{flex:1;padding:.5rem;border-radius:.375rem;font-weight:500;color:#fff;border:none;cursor:pointer;transition:background-color .2s;margin:0 .25rem}.edit-form-buttons .btn-save{background-color:#16a34a}.edit-form-buttons .btn-save:hover{background-color:#15803d}.edit-form-buttons .btn-cancel{background-color:#6b7280}.edit-form-buttons .btn-cancel:hover{background-color:#4b5563}@media(max-width:640px){.form-grid{grid-template-columns:1fr}.filter-container{flex-direction:column}.admin-grid{grid-template-columns:1fr}}.admin-tabs-nav{display:flex;gap:1rem;border-bottom:2px solid #eee;margin-bottom:1.5rem}.admin-tabs-nav button{padding:.5rem 1rem;border:none;background-color:transparent;cursor:pointer;font-size:1rem;color:#555;border-bottom:3px solid transparent;transition:all .2s ease-in-out}.admin-tabs-nav button.active{color:#007bff;border-bottom-color:#007bff;font-weight:600}.admin-tabs-nav button:hover{background-color:#f8f9fa}.user-reservations-container{padding:1rem}.back-button{margin-bottom:1rem;background:none;border:1px solid #ccc;padding:.5rem 1rem;border-radius:4px;cursor:pointer}.reservations-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;border-bottom:1px solid #eee;padding-bottom:1rem}.reservations-header h3{margin:0}.history-toggle{background-color:#6c757d;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer}.reservations-list{list-style:none;padding:0}.reservations-list li{display:flex;justify-content:space-between;align-items:center;padding:.75rem;border-radius:4px;margin-bottom:.5rem;background:#fff;border:1px solid #eee;cursor:pointer;transition:background-color .2s}.reservations-list li:hover{background-color:#f0f0f0}.resa-details-prompt{color:#007bff}.user-table-container{overflow-x:auto}.user-table{width:100%;border-collapse:collapse;text-align:left;box-shadow:0 2px 8px #0000000d;border-radius:8px;overflow:hidden}.user-table th,.user-table td{padding:12px 15px;border-bottom:1px solid #ddd}.user-table thead tr{background-color:#007bff;color:#fff;font-weight:600}.user-table tbody tr:nth-of-type(2n){background-color:#f8f9fa}.user-table tbody tr:hover{background-color:#f1f1f1}.role-select{padding:6px 10px;border-radius:4px;border:1px solid #ccc;background-color:#fff}.error-message{color:#dc3545;text-align:center;padding:1rem}.action-btn{padding:6px 12px;font-size:.875rem;background-color:#17a2b8;color:#fff;border:none;border-radius:4px;cursor:pointer}.action-btn:hover{background-color:#138496}
