*{margin:0;padding:0;box-sizing:border-box}:root{--bleu-roi: #0047AB;--jaune-or: #FFD700;--noir: #000000;--blanc: #FFFFFF;--gris-clair: #F5F5F5;--gris-moyen: #CCCCCC;--gris-fonce: #333333;--succes: #10B981;--erreur: #EF4444;--warning: #F59E0B;--info: #3B82F6}body{font-family:Roboto,sans-serif;color:var(--noir);background-color:var(--blanc);line-height:1.6}nav{background-color:var(--bleu-roi);color:var(--blanc);padding:1rem 2rem;position:sticky;top:0;z-index:100;box-shadow:0 2px 4px #0000001a}.nav-container{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.nav-brand{font-weight:700;font-size:1.2rem}.nav-toggle{display:none;background:none;border:none;color:var(--blanc);font-size:1.5rem;cursor:pointer;padding:.5rem}nav ul{list-style:none;display:flex;gap:2rem;flex-wrap:wrap;align-items:center}nav li{cursor:pointer;transition:opacity .3s}nav li:hover{opacity:.8}nav li.active{font-weight:700;text-decoration:underline}#app{min-height:calc(100vh - 60px)}.container{max-width:1400px;margin:0 auto;padding:2rem}.home-hero{background:linear-gradient(135deg,var(--bleu-roi) 0%,#0056c7 100%);color:var(--blanc);text-align:center;padding:4rem 2rem;margin-bottom:3rem}.home-title{font-family:Great Vibes,cursive;font-size:4rem;margin-bottom:1rem;color:var(--jaune-or)}.home-subtitle{font-size:1.2rem;opacity:.9}.tiles-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:3rem}.tile{background:var(--blanc);border-radius:8px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .3s;box-shadow:0 4px 6px #0000001a}.tile:hover{transform:translateY(-5px);box-shadow:0 8px 12px #00000026}.tile-icon{font-size:4rem;margin-bottom:1rem}.tile-title{font-size:1.8rem;color:var(--bleu-roi);margin-bottom:.5rem}.tile-description{color:var(--gris-fonce)}.catalog-layout{display:grid;grid-template-columns:280px 1fr;gap:2rem;margin-top:2rem}.filters-backdrop{display:none}@media (max-width: 768px){.catalog-layout{grid-template-columns:1fr}}.filters-toggle{display:none;background-color:var(--bleu-roi);color:var(--blanc);border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;margin-bottom:1rem;font-size:1rem;width:100%}.filters{background:var(--gris-clair);padding:1.5rem;border-radius:8px;height:fit-content;position:sticky;top:80px;transition:transform .3s,opacity .3s}.filter-section{margin-bottom:1.5rem}.filter-section h3{font-size:1rem;margin-bottom:.75rem;color:var(--bleu-roi)}.filter-section label{display:block;margin-bottom:.5rem;cursor:pointer;font-size:.9rem}.filter-section input[type=checkbox],.filter-section input[type=radio]{margin-right:.5rem}.filter-section select{width:100%;padding:.5rem;border:1px solid var(--gris-moyen);border-radius:4px;font-family:inherit}.search-bar{margin-bottom:1.5rem;display:flex;gap:.5rem;align-items:center}.search-bar input{flex:1;min-width:0;padding:.75rem;border:1px solid var(--gris-moyen);border-radius:4px;font-family:inherit;font-size:1rem}.search-bar .btn{padding:.75rem;flex-shrink:0;min-width:auto}.btn{padding:.75rem 1.5rem;border:none;border-radius:4px;cursor:pointer;font-family:inherit;font-size:1rem;transition:all .3s}.btn-primary{background-color:var(--bleu-roi);color:var(--blanc)}.btn-primary:hover{background-color:#003a8c}.btn-secondary{background-color:var(--gris-moyen);color:var(--noir)}.btn-secondary:hover{background-color:#b3b3b3}.catalog-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.catalog-header h2{font-size:2rem;color:var(--bleu-roi)}.sort-controls{display:flex;gap:.5rem;align-items:center}.sort-controls select{padding:.5rem;border:1px solid var(--gris-moyen);border-radius:4px;font-family:inherit}.items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.item-card{background:var(--blanc);border-radius:8px;box-shadow:0 2px 4px #0000001a;cursor:pointer;transition:all .3s;overflow:hidden}.item-card:hover{transform:translateY(-3px);box-shadow:0 4px 8px #00000026}.item-image{width:100%;aspect-ratio:2/3;object-fit:cover;background:var(--gris-clair);display:flex;align-items:center;justify-content:center;font-size:3rem}.item-info{padding:1rem}.item-title{font-size:1rem;font-weight:500;margin-bottom:.25rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.item-author{font-size:.875rem;color:var(--gris-fonce);margin-bottom:.5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-badges{display:flex;gap:.5rem;flex-wrap:wrap}.badge{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.badge-disponible{background-color:var(--succes);color:var(--blanc)}.badge-emprunte{background-color:var(--erreur);color:var(--blanc)}.badge-category{background-color:#e0f2fe;color:var(--info)}.pagination-wrapper{display:flex;flex-direction:column;gap:1rem;align-items:center;margin:2rem 0}.pagination-info{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:1.5rem;width:100%;font-size:.9rem;color:var(--gris-fonce)}.pagination-count{white-space:nowrap}.pagination-count strong{color:var(--bleu-roi);font-weight:600}.pagination-per-page{display:flex;align-items:center;gap:.5rem}.pagination-per-page label{white-space:nowrap;margin:0}.per-page-select{padding:.4rem .8rem;border:1px solid var(--gris-moyen);border-radius:4px;background:var(--blanc);cursor:pointer;font-family:inherit;font-size:.9rem;transition:all .3s}.per-page-select:hover{border-color:var(--bleu-roi)}.per-page-select:focus{outline:none;border-color:var(--bleu-roi);box-shadow:0 0 0 2px #0047ab1a}.pagination-controls{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;align-items:center}.pagination-btn{padding:.5rem 1rem;border:1px solid var(--gris-moyen);background:var(--blanc);cursor:pointer;border-radius:4px;transition:all .3s;font-family:inherit;font-size:.9rem;font-weight:500;white-space:nowrap}.pagination-btn:hover:not(:disabled){background:var(--bleu-roi);color:var(--blanc);border-color:var(--bleu-roi);transform:translateY(-1px)}.pagination-btn.active{background:var(--bleu-roi);color:var(--blanc);border-color:var(--bleu-roi);font-weight:700}.pagination-btn:disabled{opacity:.4;cursor:not-allowed;background:var(--gris-clair)}.pagination-ellipsis{padding:.5rem;color:var(--gris-fonce);-webkit-user-select:none;user-select:none}.pagination-first,.pagination-last{font-weight:600}.pagination-number{min-width:44px}.detail-container{display:grid;grid-template-columns:400px 1fr;gap:3rem;margin-top:2rem}@media (max-width: 968px){.detail-container{grid-template-columns:1fr}}.detail-image{width:100%;border-radius:8px;box-shadow:0 4px 8px #0000001a}.detail-image-placeholder{width:100%;aspect-ratio:2/3;background:var(--gris-clair);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:6rem}.detail-content h1{font-size:2.5rem;color:var(--bleu-roi);margin-bottom:1rem}.detail-meta{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem}.detail-meta-item{display:flex;gap:.5rem}.detail-meta-label{font-weight:500;min-width:120px}.detail-description{line-height:1.8;margin-top:2rem;padding-top:2rem;border-top:1px solid var(--gris-moyen)}.detail-description h3{margin-bottom:1rem;color:var(--bleu-roi)}.detail-actions{margin-top:2rem;display:flex;gap:1rem}.contact-container{max-width:700px;margin:2rem auto}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500}.form-group input,.form-group textarea,.form-group select{width:100%;padding:.75rem;border:1px solid var(--gris-moyen);border-radius:4px;font-family:inherit;font-size:1rem}.form-group textarea{min-height:150px;resize:vertical}.form-group.error input,.form-group.error textarea{border-color:var(--erreur)}.form-error{color:var(--erreur);font-size:.875rem;margin-top:.25rem}.form-success{background:#d1fae5;color:#065f46;border-radius:4px;margin-bottom:1rem;padding:1rem}.loading{text-align:center;padding:3rem;font-size:1.2rem;color:var(--gris-fonce)}.empty-state{text-align:center;padding:3rem;color:var(--gris-fonce)}.empty-state-icon{font-size:4rem;margin-bottom:1rem}@media (max-width: 768px){.home-title{font-size:2.5rem}.items-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.catalog-header{flex-direction:column;align-items:flex-start}.nav-toggle{display:block}nav ul{display:none;flex-direction:column;width:100%;gap:0;position:absolute;top:100%;left:0;background-color:var(--bleu-roi);padding:0;box-shadow:0 4px 6px #0000001a}nav ul.nav-open{display:flex}nav li{width:100%;padding:1rem 2rem;border-bottom:1px solid rgba(255,255,255,.1)}nav li:hover{background-color:#ffffff1a;opacity:1}.filters-toggle{display:block}.filters{position:fixed;top:0;left:0;width:85%;max-width:320px;height:100vh;z-index:1000;transform:translate(-100%);opacity:0;overflow-y:auto}.filters.filters-open{transform:translate(0);opacity:1}.filters-backdrop{display:none;position:fixed;top:0;left:0;width:100%;height:100vh;background-color:#00000080;z-index:999}.filters-backdrop.active{display:block}.filters-close{display:block;background:var(--bleu-roi);color:var(--blanc);border:none;padding:.75rem;width:100%;text-align:right;font-size:1.5rem;cursor:pointer;margin-bottom:1rem;border-radius:4px}.pagination-wrapper{gap:1.5rem}.pagination-info{flex-direction:column;gap:1rem;text-align:center}.pagination-count{font-size:.85rem}.pagination-controls{gap:.3rem}.pagination-btn{padding:.4rem .7rem;font-size:.85rem}.pagination-first,.pagination-last{display:none}}@media (max-width: 480px){.pagination-btn{padding:.3rem .5rem;font-size:.8rem}.pagination-number{min-width:36px}.pagination-prev,.pagination-next{font-size:0;padding:.4rem .8rem}.pagination-prev:before{content:"‹";font-size:1.2rem}.pagination-next:before{content:"›";font-size:1.2rem}}.filters-close{display:none}.item-detail-container{padding:2rem 1rem}.btn-back{background:var(--bleu-roi);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;margin-bottom:2rem;transition:background .3s}.btn-back:hover{background:#003380}.item-detail{display:grid;grid-template-columns:1fr;gap:2rem;background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000001a}.item-detail-image{display:flex;justify-content:center;align-items:flex-start}.item-detail-image img{max-width:400px;width:100%;height:auto;border-radius:8px;box-shadow:0 4px 12px #00000026}.item-detail-content h1{color:var(--bleu-roi);font-size:2rem;margin-bottom:1.5rem;line-height:1.2}.item-detail-meta{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.meta-row{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.meta-label{font-weight:600;color:var(--gris-fonce);min-width:120px}.meta-value{color:var(--gris-fonce)}.badges-list{display:flex;flex-wrap:wrap;gap:.5rem}.badge-etat{background:var(--info);color:#fff}.badge-category{background:var(--bleu-clair, #E0F2FE);color:var(--bleu-roi)}.badge-abonnement{background:var(--jaune-or);color:var(--noir);font-weight:600}.item-detail-description{margin-top:2rem;padding-top:2rem;border-top:2px solid var(--gris-clair)}.item-detail-description h2{color:var(--bleu-roi);font-size:1.5rem;margin-bottom:1rem}.item-detail-description p{line-height:1.6;color:var(--gris-fonce);white-space:pre-wrap}.item-detail-actions{margin-top:2rem;display:flex;gap:1rem}.error-message{text-align:center;padding:3rem 1rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.error-message p{font-size:1.25rem;color:var(--erreur);margin-bottom:1.5rem}@media (min-width: 768px){.item-detail{grid-template-columns:400px 1fr}.item-detail-content h1{font-size:2.5rem}}.contact-layout{display:grid;grid-template-columns:300px 1fr;gap:3rem;margin-top:2rem}.contact-info-sidebar{background:#f8f9fa;padding:2rem;border-radius:8px;height:fit-content}.contact-info-sidebar h3{color:var(--bleu-roi);margin-bottom:1.5rem;font-size:1.2rem}.contact-item{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:1.5rem}.contact-item:last-child{margin-bottom:0}.contact-item i{font-size:1.5rem;min-width:24px}.contact-item a{color:var(--bleu-roi);text-decoration:none}.contact-item a:hover{text-decoration:underline}.contact-item span{line-height:1.6}@media (max-width: 768px){.contact-layout{grid-template-columns:1fr;gap:2rem}}
