: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;--black: #000000;--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;max-width:100vw}: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(--pics-color);padding:.5rem 1rem;border-radius:4px;cursor:pointer;color:var(--text-color)}.material-header{display:flex;gap:2rem;margin-bottom:2rem;background:#000;padding:1rem;border-radius:8px}.material-header img{width:150px;height:150px;object-fit:contain;border-radius:8px}.reservations-section p{color:#fff}.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}.reservations-list{list-style:none;padding:0}.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:#000}.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:contain;border-radius:.5rem;margin-bottom:.5rem;display:block;margin-left:auto;margin-right:auto}.card-name{font-weight:600;color:var(--text-color)}.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}.admin-container{padding:20px;max-width:1200px;margin:0 auto;width:100%}.access-denied{text-align:center;color:var(--danger-color, #dc3545);padding:20px;font-weight:700;font-size:1.2rem}.admin-tabs-nav{display:flex;justify-content:center;gap:15px;margin-bottom:25px;flex-wrap:wrap}.admin-tabs-nav button{background-color:#fff;border:2px solid var(--pics-color);color:var(--pics-color);padding:10px 20px;border-radius:25px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s ease;white-space:nowrap}.admin-tabs-nav button:hover{transform:translateY(-2px)}.admin-tabs-nav button.active{background-color:var(--pics-color);color:var(--secondary-color);box-shadow:0 4px 6px #0000001a}.admin-tab-content{background-color:#fff;padding:25px;border-radius:12px;box-shadow:0 4px 15px #0000000d;min-height:300px;overflow-x:auto}.admin-tab-content h2,.admin-tab-content h3{color:var(--pics-color);margin-top:0;margin-bottom:20px}.admin-tab-content table{width:100%;border-collapse:collapse;margin-bottom:20px;min-width:600px}.admin-tab-content th{background-color:var(--pics-color);color:var(--secondary-color);padding:12px;text-align:left}.admin-tab-content td{padding:12px;border-bottom:1px solid #eee}.admin-tab-content tr:hover{background-color:#f9f9f9}@media(max-width:768px){.admin-container{padding:5px;width:100%}.admin-tabs-nav{gap:8px;margin-bottom:15px}.admin-tabs-nav button{padding:8px 12px;font-size:.9rem;flex:1 1 auto;text-align:center}.admin-tab-content{padding:10px}}.admin-form-container{background-color:var(--pics-color);padding:20px;border-radius:12px;border:1px solid #eee;margin-bottom:25px}.admin-form-container h3{color:var(--secondary-color);margin-top:0;margin-bottom:15px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin-bottom:15px}.form-grid input,.form-grid select,.form-grid textarea{padding:10px;border:1px solid #ddd;border-radius:8px;width:100%;font-size:.95rem}.form-grid .full-width{grid-column:1 / -1}.filter-container{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px}.search-bar,.filter-select{padding:10px 15px;border:3px solid var(--pics-color);border-radius:25px;flex-grow:1;font-size:.95rem}.admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px}.admin-card{background:var(--black);border:1px solid #eee;border-radius:12px;padding:15px;display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s;box-shadow:0 2px 5px #0000000d;max-width:100%;overflow:hidden}.admin-card:hover{transform:translateY(-3px);box-shadow:0 8px 20px #0000001a}.admin-card img{width:100%;height:160px;object-fit:contain;margin-bottom:15px;border-radius:8px;background-color:#000}.admin-card-content{flex-grow:1;margin-bottom:15px;min-width:0}.admin-card-content h3{margin:0 0 10px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-card-content p{margin:5px 0;color:#fff}.admin-card-actions{display:flex;gap:10px}.submit-btn,.btn-save{background-color:var(--pics-color);color:var(--secondary-color);padding:10px 20px;border:none;border-radius:25px;cursor:pointer;font-weight:700;width:100%;transition:opacity .2s}.btn-edit{background-color:#e9ecef;color:#333;border:none;padding:8px 12px;border-radius:6px;cursor:pointer;flex:1;font-weight:500}.btn-delete,.btn-cancel{background-color:var(--danger-color, #dc3545);color:#fff;border:none;padding:8px 12px;border-radius:6px;cursor:pointer;flex:1;font-weight:500}@media(max-width:600px){.form-grid{grid-template-columns:1fr}.admin-card-actions{flex-direction:column}.admin-grid{grid-template-columns:1fr;gap:10px}}.user-reservations-container{padding:1rem}.back-button{margin-bottom:1rem;background-color:var(--pics-color);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:var(--pics-color);color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer}.reservations-list{list-style:none;padding:0;color:#000}.reservations-list li{display:flex;align-items:center;padding:1rem;gap:1rem}.reservations-list li .text{flex:1;overflow-wrap:break-word;min-width:0;white-space:normal}.resa-info{flex:1 1 auto;white-space:normal}.reservations-list li:hover{background-color:#f0f0f0}.resa-details-prompt{color:#007bff}.resa-status-row{display:flex;flex-wrap:wrap;gap:.5rem}.resa-status{white-space:nowrap;padding:.2rem .5rem;border-radius:4px;font-size:.8rem}.user-table-container{overflow-x:auto;border-radius:8px;box-shadow:0 2px 8px #0000000d;background:#fff}.user-table-container table{width:100%;border-collapse:collapse;min-width:700px}.user-table-container td{padding:12px;border-bottom:1px solid #eee;color:#000}.role-select{padding:6px 10px;border-radius:6px;border:1px solid var(--pics-color);background-color:#fff;font-size:.9rem;cursor:pointer}.action-btn{background-color:var(--pics-color);color:var(--secondary-color);border:none;padding:6px 15px;border-radius:20px;cursor:pointer;font-size:.9rem;font-weight:500;transition:transform .1s;white-space:nowrap}.action-btn:hover{transform:scale(1.05);opacity:.9}@media(max-width:768px){.user-table-container{background:transparent;box-shadow:none;overflow:visible}.user-table-container table,.user-table-container thead,.user-table-container tbody,.user-table-container th,.user-table-container td,.user-table-container tr{display:block;width:100%;min-width:0}.user-table-container thead tr{position:absolute;top:-9999px;left:-9999px}.user-table-container tr{background:#fff;border-radius:12px;box-shadow:0 2px 5px #0000000d;margin-bottom:15px;padding:15px;border:1px solid #eee}.user-table-container td{border:none;position:relative;padding:8px 0;display:flex;justify-content:space-between;align-items:center;text-align:right;word-break:break-word}.user-table-container td:before{content:attr(data-label);font-weight:700;color:var(--pics-color);margin-right:15px;text-align:left}}.gestion-emprunt-tab{width:100%}.table-responsive{overflow-x:auto;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000000d}.table-responsive td{padding:12px;border-bottom:1px solid #eee;color:#000}.admin-action-btn{background-color:var(--pics-color);color:var(--secondary-color);border:none;padding:10px 20px;border-radius:25px;cursor:pointer;font-weight:700;margin-bottom:20px;display:inline-block;transition:opacity .2s}.admin-action-btn:hover{opacity:.9}.description-cell{max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;color:var(--pics-color);font-weight:500}.description-cell:hover{border-color:var(--pics-color)}.btn-accept-sm{background-color:var(--success-color, #28a745);color:#fff;border:none;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:.9rem}.btn-delete-sm{background-color:var(--danger-color, #dc3545);color:#fff;border:none;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:.9rem}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:2000;padding:20px}.modal-content{background:#fff;padding:25px;border-radius:12px;max-width:500px;width:100%;position:relative;box-shadow:0 10px 25px #0003}.modal-close{position:absolute;top:10px;right:15px;background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666}@media(max-width:768px){.admin-action-btn{width:100%;text-align:center;margin-bottom:15px;white-space:normal}.table-responsive{background:transparent;box-shadow:none;overflow:visible}.table-responsive table,.table-responsive thead,.table-responsive tbody,.table-responsive th,.table-responsive td,.table-responsive tr{display:block;width:100%;min-width:0}.table-responsive thead tr{position:absolute;top:-9999px;left:-9999px}.table-responsive tr{background:#fff;border-radius:12px;box-shadow:0 2px 5px #0000000d;margin-bottom:15px;padding:15px;border:1px solid #eee;max-width:100%}.table-responsive td{border:none;position:relative;padding:8px 0;display:flex;justify-content:space-between;align-items:center;text-align:right;word-break:break-word;overflow-wrap:anywhere}.table-responsive td:before{content:attr(data-label);font-weight:700;color:var(--pics-color);margin-right:15px;text-align:left;flex-shrink:0;max-width:35%}.description-cell{max-width:none;white-space:normal}}.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}.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:#000;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.item-card{background-color:#000}.reservation-card.none-card{justify-content:center;align-items:center;font-weight:700;font-size:1.2rem;background-color:#000}.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:contain;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}}
