.realisation-gallery{padding:2rem 0}.gallery-filters{flex-wrap:wrap;justify-content:center;gap:.5rem;margin-bottom:2rem;padding:0 1rem;display:flex}.filter-btn{border:1px solid var(--base-300);color:var(--base-300);cursor:pointer;background:0 0;border-radius:2rem;padding:.5rem 1rem;font-size:.9rem;font-weight:500;transition:all .3s}.filter-btn:hover{border-color:var(--base-100);color:var(--base-100);transform:translateY(-2px)}.filter-btn.active{background:var(--base-100);color:var(--base-500);border-color:var(--base-100)}.gallery-counter{text-align:center;color:var(--base-300);margin-bottom:1.5rem;padding:0 1rem;font-size:.9rem}.gallery-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;max-width:1200px;margin:0 auto;padding:0 2rem;display:grid}.gallery-item{aspect-ratio:1;cursor:pointer;border-radius:.75rem;justify-self:center;max-width:280px;transition:transform .3s,box-shadow .3s;position:relative;overflow:hidden}.gallery-item:hover{transform:translateY(-5px);box-shadow:0 10px 30px #0000004d}.gallery-item img{object-fit:cover;backface-visibility:hidden;width:100%;height:100%;transition:transform .3s;display:block;transform:translateZ(0)}.gallery-item:hover img{transform:scale(1.05)}.gallery-overlay{opacity:0;background:#00000080;border-radius:.5rem;flex-direction:column;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:absolute;inset:0}.gallery-item:hover .gallery-overlay{opacity:1}.gallery-icon{color:#fff;margin-bottom:.5rem;font-size:2rem;font-weight:300;transition:transform .3s}.gallery-item:hover .gallery-icon{transform:scale(1.2)}.gallery-category{color:#fff;text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0009;border-radius:1rem;padding:.25rem .75rem;font-size:.8rem;font-weight:500}.gallery-modal{z-index:1000;background:#000000e6;justify-content:center;align-items:center;padding:2rem;display:flex;position:fixed;inset:0}.modal-content{z-index:1;justify-content:center;align-items:center;max-width:90vw;max-height:90vh;display:flex;position:relative}.modal-slide{justify-content:center;align-items:center;width:92vw;max-width:1300px;height:75vh;max-height:800px;display:flex}.modal-slide.single,.modal-slide.double,.modal-slide.triple{height:75vh;max-height:800px}.modal-slide.double{grid-template-columns:1fr 1fr;gap:1rem;width:100%;height:75vh;min-height:0;max-height:800px;display:grid}.modal-slide.double .modal-image-container:first-child{grid-area:1/1;height:100%}.modal-slide.double .modal-image-container:nth-child(2){grid-area:1/2;height:100%}.modal-slide.triple{grid-template-rows:1fr 1fr;grid-template-columns:1fr 1fr;gap:1rem;width:100%;height:75vh;min-height:0;max-height:800px;display:grid}.modal-slide.triple .modal-image-container:first-child{grid-area:1/1/3;width:100%;height:100%;min-height:0;display:flex}.modal-slide.triple .modal-image-container:nth-child(2){grid-area:1/2;width:100%;height:100%;min-height:0;display:flex}.modal-slide.triple .modal-image-container:nth-child(3){grid-area:2/2;width:100%;height:100%;min-height:0;display:flex}.modal-image-container{z-index:0;border-radius:.5rem;align-items:stretch;height:100%;min-height:0;max-height:100%;display:flex;position:relative;overflow:hidden}.modal-image{object-fit:cover;opacity:1;backface-visibility:hidden;border-radius:.5rem;flex:1;width:100%;height:100%;min-height:0;display:block;transform:translateZ(0)}.modal-close{color:#fff;cursor:pointer;background:0 0;border:none;padding:.5rem;font-size:2rem;transition:opacity .3s;position:absolute;top:-3rem;right:0}.modal-close:hover{opacity:.7}.modal-nav{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:100;background:#fff3;border:none;border-radius:50%;justify-content:center;align-items:center;width:4rem;height:4rem;font-size:2rem;transition:background .3s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.modal-nav:hover{background:#ffffff4d}.modal-prev{left:-4rem}.modal-next{right:-4rem}.modal-counter{color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#00000080;border-radius:1rem;padding:.5rem 1rem;font-size:1rem;position:absolute;bottom:-3rem;left:50%;transform:translate(-50%)}.modal-category{color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#00000080;border-radius:1rem;padding:.25rem .75rem;font-size:.9rem;position:absolute;top:-3rem;left:50%;transform:translate(-50%)}.modal-description{color:#fff;text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000000b3;border-radius:1rem;width:95%;max-width:none;padding:1.5rem;position:absolute;bottom:-4.5rem;left:50%;transform:translate(-50%)}.modal-description h3{color:#fff;margin:0 0 .75rem;font-size:1.25rem;font-weight:600}.modal-description p{color:#ffffffe6;margin:0;font-size:.95rem;line-height:1.6}@media (max-width:768px){.gallery-filters{gap:.25rem;margin-bottom:1.5rem}.filter-btn{padding:.4rem .8rem;font-size:.8rem}.gallery-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.75rem;padding:0 1rem}.gallery-item{max-width:240px}.gallery-modal{padding:1rem}.modal-slide{width:96vw;max-width:880px;height:65vh;max-height:550px}.modal-slide.single,.modal-slide.double,.modal-slide.triple{height:65vh;max-height:550px}.modal-slide.double,.modal-slide.triple{gap:.5rem}.modal-nav{width:3rem;height:3rem;font-size:1.5rem}.modal-prev{left:-2rem}.modal-next{right:-2rem}.modal-close{font-size:1.5rem;top:-2rem}.modal-counter{font-size:.9rem;bottom:-2rem}.modal-description{width:98%;max-width:none;padding:1rem;bottom:-4rem}.modal-description h3{margin-bottom:.5rem;font-size:1rem}.modal-description p{font-size:.85rem}}@media (max-width:480px){.gallery-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.2rem;padding:0 .5rem}.gallery-item{max-width:200px}.modal-slide{width:97vw;max-width:660px;height:55vh;max-height:380px}.modal-slide.single,.modal-slide.double,.modal-slide.triple{height:55vh;max-height:380px}.modal-slide.double,.modal-slide.triple{gap:.25rem}.modal-nav{width:2.5rem;height:2.5rem;font-size:1.2rem}.modal-prev{left:.5rem}.modal-next{right:.5rem}.modal-description{width:100%;max-width:none;padding:.75rem;bottom:-3.5rem}.modal-description h3{margin-bottom:.4rem;font-size:.9rem}.modal-description p{font-size:.8rem;line-height:1.4}}@supports (-webkit-touch-callout:none){.gallery-item img{content-visibility:auto}.gallery-grid{transform:translateZ(0)}.modal-image{will-change:transform;transform:translateZ(0)}}
.realisation-page{background:var(--base-500);min-height:100vh;color:var(--base-100);padding-top:2rem}.realisation-header{text-align:center;max-width:800px;margin:0 auto;padding:3rem 1rem}.realisation-header h1{color:var(--base-100);margin-bottom:1rem;font-size:3rem;font-weight:300}.realisation-header p{color:var(--base-200);max-width:600px;margin:0 auto;font-size:1.2rem;line-height:1.6}.realisation-not-found{text-align:center;background:var(--base-500);min-height:100vh;color:var(--base-100);flex-direction:column;justify-content:center;align-items:center;padding:2rem;display:flex}.realisation-not-found h1{color:var(--base-100);margin-bottom:1rem;font-size:2.5rem}.realisation-not-found p{color:var(--base-200);margin-bottom:2rem;font-size:1.1rem}.realisation-not-found a{color:var(--base-100);border:1px solid var(--base-100);border-radius:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s}.realisation-not-found a:hover{background:var(--base-100);color:var(--base-500)}@media (max-width:768px){.realisation-page{padding-top:4rem}.realisation-header h1{font-size:2.5rem}.realisation-header p{font-size:1.1rem}.realisation-not-found h1{font-size:2rem}}@media (max-width:480px){.realisation-header{padding:2rem 1rem}.realisation-header h1{font-size:2rem}.realisation-header p{font-size:1rem}}
