:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;--pics-color: #0a0a2a;--pics-bg-color: #112440;--secondary-color: #ffffff;--third-color: #3b82f6;--success-color: #28a745;--danger-color: #dc3545;--pending-color: #ffc107;--title-font: "Dosis";--title-pics-font: "FeatherScript";color:var(--secondary-color);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}*{margin:0;box-sizing:border-box}html,body,#root{min-height:100vh;background-color:var(--pics-bg-color);margin:0 auto;padding:2rem}*,*: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:var(--pics-color);border-right:1px solid var(--pics-bg-color);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:var(--secondary-color);font-size:1.1rem;font-weight:500;padding:10px;display:block;border-radius:5px}.sidebar a:hover{background-color:var(--pics-bg-color)}.close-btn{position:absolute;top:10px;right:15px;font-size:2rem;background:none;color:var(--secondary-color);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:var(--pics-color);border-bottom:1px solid var(--pics-bg-color);color:var(--secondary-color);z-index:1001}.menu-btn{background:none;color:var(--secondary-color);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:var(--pics-bg-color)}.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:var(--secondary-color);font-weight:500;white-space:nowrap}.logout-btn{background-color:var(--danger-color);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:#c82333}@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}.back-button{margin-bottom:1rem;border:1px solid var(--secondary-color);padding:.5rem 1rem;border-radius:4px;cursor:pointer;color:var(--text-color)}.material-header{display:flex;gap:2rem;margin-bottom:2rem;background:var(--pics-color);padding:1rem;border-radius:8px}.material-header img{width:150px;height:150px;object-fit:cover;border-radius:8px}.material-info h2{margin-top:0;color:var(--text-color)}.material-info p{color:var(--text-color)}.reservations-section h3{margin-top:0;color:var(--text-color)}.reservations-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.history-toggle{background-color:var(--pics-color);color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer}.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{padding:1rem;border-radius:1rem;text-align:center;cursor:pointer;transition:box-shadow .2s,transform .2s;background:var(--pics-color)}.inventaire-card:hover{transform:translateY(-5px);box-shadow:0 4px 12px #0000001a}.inventaire-card img{width:100%;max-width:140px;height:auto;aspect-ratio:1 / 1;object-fit:cover;border-radius:.5rem;margin-bottom:.5rem;display:block;margin-left:auto;margin-right:auto}.card-name{font-weight:600;color:var(--text-color)}.my-reservations-section{margin-bottom:2.5rem;padding:1rem;background-color:var(--pics-color);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:var(--pics-bg-color);padding:.75rem;border-radius:4px;margin-bottom:1rem;border-left:4px solid var(--pending-color);text-align:center}.reservation-item{justify-content:space-between;align-items:center}.my-reservations-section li.accepted{border-left-color:var(--success-color)}.my-reservations-section li.pending{border-left-color:var(--pending-color)}.my-reservations-section li .resa-status{font-weight:700}.my-reservations-section.late{background-color:var(--danger-color)}.my-reservations-section.late li{border-left-color:#fff;background-color:#ef4444;display:flex;justify-content:space-between;align-items:center}.my-reservations-section.late .return-btn{color:#000;background-color:#fff;font-weight:700}.my-reservations-section.current{background-color:var(--success-color)}.my-reservations-section.current li{border-left-color:#fff;background-color:#22c55e;display:flex;justify-content:space-between;align-items:center}.my-reservations-section.current .return-btn{color:#000;background-color:#fff;font-weight:700}.category-tabs-nav{display:flex;gap:.75rem;margin-bottom:2rem;flex-wrap:wrap;justify-content:center}.category-tabs-nav button{padding:.6rem 1.25rem;border:2px solid var(--secondary-color);background-color:var(--pics-color);color:var(--secondary-color);cursor:pointer;border-radius:9999px;font-weight:500;transition:all .3s ease-in-out;box-shadow:0 1px 3px #ffffff0d}.category-tabs-nav button:hover{border-color:var(--third-color);box-shadow:0 4px 6px #ffffff4d;transform:translateY(-1px)}.category-tabs-nav button.active{background-color:var(--pics-bg-color);color:#fff;border-color:var(--pics-bg-color);box-shadow:0 4px 6px #ffffff0d}.category-tabs-nav button:focus{outline:none}.date-picker-container{display:flex;flex-wrap:wrap;gap:1.5rem;padding:2rem;margin-bottom:2rem;border-radius:8px;background-color:var(--pics-color);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.date-field{display:flex;flex-direction:column;flex-grow:1}.date-field label{font-size:1rem;font-weight:600;color:var(--text-color);margin-bottom:.5rem}.date-field input,.date-field select{padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;color:#000;background-color:var(--secondary-color);transition:border-color .2s}.date-field input:focus,.date-field select:focus{border-color:var(--third-color);outline:none;box-shadow:0 0 0 3px #3b82f633}.date-mode-toggle{align-self:flex-start;margin-top:2rem;background:none;border:none;color:var(--third-color);font-weight:500;cursor:pointer;text-decoration:none;transition:color .2s}.date-picker-container.advanced .date-mode-toggle{align-self:flex-end;margin-top:0}.date-mode-toggle:hover{color:var(--third-color);text-decoration:underline}p{text-align:center;color:#000;font-style:italic;margin-top:1rem}.reservation-container{padding:2rem}.reservation-container h2{font-family:FeatherScript;font-size:3rem;text-align:center;margin-bottom:1.5rem;color:var(--text-color)}.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-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-radius:2rem;padding:1rem;display:flex;flex-direction:column;align-items:center;cursor:pointer;transition:box-shadow .2s,border-color .2s;background:var(--pics-color);width:100%;box-sizing:border-box;position:relative;margin-bottom:1em}.reservation-card:hover{box-shadow:0 4px 6px #ffffff80}.reservation-card.selected{border:2px solid var(--third-color)}.reservation-card.reserved{cursor:not-allowed;opacity:.6}.reservation-card.none-card{justify-content:center;align-items:center;font-weight:700;font-size:1.2rem;background-color:var(pi--pics-bg-color)}.availability-dot{width:12px;height:12px;border-radius:50%;position:absolute;top:100px;right:40px}.availability-dot.available{background-color:var(--success-color)}.availability-dot.reserved{background-color:var(--danger-color)}.card-content{text-align:center}.reservation-end-date{font-size:.75rem;color:var(--danger-color);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:.7rem;background:var(--pics-color);box-shadow:0 -4px 6px #0000001a;text-align:center}.submit-reservation-btn{padding:.75rem 1.5rem;background-color:var(--third-color);color:var(--text-color);font-weight:600;border:none;border-radius:.5rem;cursor:pointer}.return-btn{padding:.5rem 1rem;background-color:var(--third-color);color:var(--text-color);border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.return-btn:hover{background-color:#0056b3}.cancel-btn{padding:.4rem .8rem;background-color:var(--danger-color);color:var(--text-color);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}.protected-route-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;text-align:center}.protected-route-container p{margin:1rem 0;color:var(--text-color)}.protected-route-container h2{color:var(--text-color)}.protected-route-container button{padding:.75rem 1.5rem;background-color:var(--pics-color);color:#fff;font-weight:600;border:none;border-radius:.5rem;cursor:pointer}
