*{padding:0;margin:0;box-sizing:border-box}body{font-family:Roboto,sans-serif;background-color:#fbfbfb}.root{display:flex;flex-direction:column;background-color:beige;padding-top:60px}.header{background-color:#8b4513;padding:.8rem 1.5rem;box-shadow:0 4px 12px #0000001a;position:fixed;width:100%;top:0;z-index:1000;transition:all .3s ease}.header-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.logo-container{display:flex;align-items:center;justify-content:space-between}.logo{height:60px;display:block;border-radius:8px;padding:5px;transition:transform .3s ease}.menu-toggle{display:none;background:none;border:none;color:beige;font-size:1.5rem;cursor:pointer;padding:.5rem;transition:transform .3s ease}.menu-toggle:hover{transform:scale(1.1)}.nav-list{list-style:none;display:flex;gap:1.5rem;margin:0;padding:0}.nav-item{color:beige;text-decoration:none;font-weight:500;padding:.6rem 1.2rem;border-radius:4px;transition:all .3s ease;cursor:pointer;position:relative;letter-spacing:.5px}.nav-item:after{content:"";position:absolute;width:0;height:2px;bottom:0;left:50%;background-color:beige;transition:all .3s ease;transform:translate(-50%)}.nav-item:hover{background-color:#f5f5dc26}.nav-item:hover:after{width:70%}.nav-item.active{background-color:#f5f5dc33}.nav-item.active:after{width:80%}@media (max-width: 900px){.nav-list{gap:.8rem}.nav-item{padding:.5rem .8rem;font-size:.9rem}}@media (max-width: 768px){.header{padding:1rem}.header-content{flex-direction:column;align-items:stretch}.menu-toggle{display:block}.logo-container{display:flex;align-items:center;justify-content:space-between}.logo{height:50px}.nav{max-height:0;overflow:hidden;transition:max-height .5s ease}.nav-open{max-height:300px}.nav-list{flex-direction:column;padding:1rem 0;gap:0}.nav-item{display:block;text-align:center;padding:.8rem;margin:.5rem 0}}@media (max-width: 480px){.nav-item{font-size:.85rem}}.error-container{padding:4rem 2rem;text-align:center;min-height:60vh;display:flex;align-items:center;justify-content:center}.error-content{max-width:600px}.error-content h1{font-size:6rem;color:#8b4513;margin:0}.error-content h2{font-size:2rem;color:#333;margin:1rem 0}.error-content p{color:#666;margin-bottom:2rem}.back-home{display:inline-block;padding:.8rem 1.5rem;background-color:#8b4513;color:#fff;text-decoration:none;border-radius:4px;transition:background-color .3s}.back-home:hover{background-color:#6b3410}.footer{background-color:#fff;color:#333;padding:4rem 2rem 2rem;border-top:1px solid #eaeaea}.footer-content{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:3rem}.footer-section{padding:1rem;transition:all .3s ease}.footer-section h3{color:#8b4513;margin-bottom:1.5rem;font-size:1.4rem;display:flex;align-items:center;gap:.5rem;border-bottom:2px solid #8B451333;padding-bottom:.5rem}.map-container{margin-top:1.5rem;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #0000001a}.hours-list{list-style:none;padding:0}.hours-list li{margin-bottom:.8rem;padding:.5rem 0;border-bottom:1px solid #eee}.hours-list li:last-child{border-bottom:none}.hours-list span{color:#8b4513;font-weight:600;display:inline-block;width:130px}.contact-link{display:flex;align-items:center;gap:8px;color:inherit;text-decoration:none;transition:color .3s}.contact-link:hover{color:#8b4513}.social-links{display:flex;gap:1.5rem;margin-top:1.5rem}.social-links a{color:#8b4513;font-size:2.5rem;background-color:#f0e6e0;width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.social-links a:hover{transform:scale(1.1) rotate(5deg);background-color:#8b4513;color:#fff;box-shadow:0 5px 15px #8b45134d}.footer p{margin-bottom:.8rem;display:flex;align-items:center;gap:.5rem}@media (max-width: 768px){.footer-content{grid-template-columns:1fr;gap:2rem}.footer-section{text-align:center}.hours-list span{width:auto;margin-right:.5rem}.social-links,.footer p{justify-content:center}}.welcome-container{height:90vh;width:100%;background:linear-gradient(#00000080,#00000080),url(/assets/20241223_115719-Cw8DlfgK.jpg);background-size:cover;background-position:center;background-repeat:no-repeat;background-attachment:scroll;display:flex;align-items:center;justify-content:center;text-align:center;margin-top:20px}.welcome-content{color:#fff;max-width:800px}.welcome-content h1{font-size:4rem;font-weight:700;margin-bottom:1rem;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.welcome-content p{font-size:1.5rem;margin-bottom:2rem;text-shadow:1px 1px 2px rgba(0,0,0,.5)}@media (max-width: 768px){.welcome-container{background-position:center center;background-size:cover;height:80vh}.welcome-content h1{font-size:2.5rem}.welcome-content p{font-size:1.2rem}}.about-section{padding:5rem 2rem;background-color:#f9f9f9}.about-container{max-width:1200px;margin:0 auto}.about-title{text-align:center;color:#8b4513;font-size:2.5rem;margin-bottom:3rem;position:relative}.about-title:after{content:"";position:absolute;bottom:-10px;left:50%;transform:translate(-50%);width:60px;height:3px;background-color:#8b4513}.about-content{display:flex;flex-direction:column;gap:3rem}.about-text{text-align:center;max-width:800px;margin:0 auto}.about-text p{margin-bottom:1.5rem;line-height:1.6;color:#333;font-size:1.1rem}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-top:2rem}.feature-card{background-color:beige;padding:2rem;border-radius:8px;text-align:center;transition:transform .3s ease;box-shadow:0 2px 8px #8b45131a}.feature-icon{color:#8b4513;font-size:2.5rem;margin-bottom:1rem}.feature-card h3{color:#8b4513;margin-bottom:1rem}.feature-card p{color:#666;line-height:1.5}@media (max-width: 768px){.about-section{padding:3rem 1rem}.about-title{font-size:2rem}.features-grid{grid-template-columns:1fr}}.works-section{padding:5rem 2rem;background-color:#fff}.works-container{max-width:1200px;margin:0 auto}.works-title{text-align:center;color:#8b4513;font-size:2.5rem;margin-bottom:3rem;position:relative}.works-title:after{content:"";position:absolute;bottom:-10px;left:50%;transform:translate(-50%);width:60px;height:3px;background-color:#8b4513}.category-filters{display:flex;justify-content:center;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.filter-btn{padding:.5rem 1.5rem;border:2px solid #8B4513;background:transparent;color:#8b4513;border-radius:25px;cursor:pointer;transition:all .3s ease}.filter-btn:hover,.filter-btn.active{background-color:#8b4513;color:#fff}.works-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin-top:2rem;justify-content:center}.work-card{background-color:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #8b45131a;transition:transform .3s ease;display:flex;flex-direction:column;height:100%}.works-grid:has(.work-card:nth-child(1):nth-last-child(-n+2)){grid-template-columns:repeat(auto-fit,minmax(280px,350px));justify-content:center;gap:2rem}.works-grid .work-card{max-width:350px;width:100%;justify-self:center}.work-image{width:100%;height:200px;overflow:hidden}.work-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.work-info{padding:1.5rem;display:flex;flex-direction:column;flex-grow:1}.work-info h3{color:#8b4513;margin-bottom:.5rem}.work-info p{color:#666;margin-bottom:1rem;line-height:1.5;flex-grow:1}.work-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;width:100%}.category-tag{display:inline-block;padding:.3rem .8rem;background-color:beige;color:#8b4513;border-radius:15px;font-size:.9rem}.view-all-btn{background-color:#8b4513;color:#fff;border:none;padding:.5rem 1rem;border-radius:25px;cursor:pointer;transition:background-color .3s ease;font-size:.9rem}.view-all-btn:hover{background-color:#6b3712}.gallery-modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000c;z-index:1001;display:flex;justify-content:center;align-items:center;padding:1rem;overflow-y:auto;cursor:pointer}.gallery-content{background-color:#fff;border-radius:8px;width:90%;max-width:1000px;max-height:90vh;overflow-y:auto;padding:2rem;position:relative;cursor:default}.close-gallery{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:2rem;cursor:pointer;color:#8b4513}.gallery-images{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem;margin-top:1rem}.gallery-image{border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #8b45131a;position:relative;width:100%;height:auto;aspect-ratio:1}.gallery-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease;cursor:pointer}.gallery-image.portrait{grid-row:span 2}.gallery-image.landscape{grid-column:span 2}.image-skeleton{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:loading 1.5s infinite;z-index:1;border-radius:8px}.loading-gallery{display:flex;justify-content:center;align-items:center;width:100%;min-height:200px;font-size:18px;color:#666}.loading-gallery:after{content:"...";animation:dots 1.5s steps(5,end) infinite;display:inline-block;width:0;overflow:hidden;vertical-align:bottom}@keyframes dots{0%,20%{content:""}40%{content:"."}60%{content:".."}80%,to{content:"..."}}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.gallery-images.few-images{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))!important}.gallery-images.few-images .gallery-image{max-width:100%}.gallery-image{position:relative}.gallery-image img{position:relative;z-index:2}.slideshow-modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000e6;z-index:1002;display:flex;justify-content:center;align-items:center;cursor:pointer}.slideshow-content{position:relative;width:90%;height:90%;max-width:1200px;display:flex;align-items:center;justify-content:center;cursor:default}.close-slideshow{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:2rem;cursor:pointer;color:#fff;z-index:1003}.slide-container{position:relative;width:100%;height:100%;display:flex;justify-content:center;align-items:center;overflow:hidden}.slide-image{max-width:100%;max-height:90vh;object-fit:contain;transition:transform .3s ease}.slide-counter{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);background:#00000080;color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.9rem}.slide-nav{color:#fff;font-size:2rem;background:#0000004d;border:none;border-radius:50%;width:50px;height:50px;display:flex;align-items:center;justify-content:center;cursor:pointer;margin:0 1rem;transition:background-color .3s ease;z-index:1003}.slide-nav:hover{background:#0009}.gallery-image{cursor:pointer}@media (max-width: 768px){.works-section{padding:3rem 1rem}.works-title{font-size:2rem}.works-grid{grid-template-columns:1fr}.gallery-content{padding:1rem}.gallery-images{grid-template-columns:1fr}.work-footer{flex-direction:column;gap:.8rem;align-items:flex-start}.view-all-btn{align-self:flex-end}.slideshow-content{width:100%;height:80%}.slide-nav{width:40px;height:40px;font-size:1.5rem;margin:0 .5rem}.close-slideshow{top:.5rem;right:.5rem;font-size:1.5rem}.slide-image{max-height:80vh}.slide-counter{padding:.3rem .8rem;font-size:.8rem;bottom:.5rem}.slideshow-modal{padding:0}}.steps-section{padding:5rem 2rem;background-color:#f9f9f9}.steps-container{max-width:1200px;margin:0 auto}.steps-title{text-align:center;color:#8b4513;font-size:2.5rem;margin-bottom:3rem;position:relative}.steps-title:after{content:"";position:absolute;bottom:-10px;left:50%;transform:translate(-50%);width:60px;height:3px;background-color:#8b4513}.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:2rem}.step-card{background-color:#fff;padding:2rem;border-radius:8px;text-align:center;position:relative;box-shadow:0 2px 8px #8b45131a;transition:transform .3s ease}.step-number{position:absolute;top:-15px;left:-15px;width:40px;height:40px;background-color:#8b4513;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem}.step-icon{font-size:2.5rem;color:#8b4513;margin-bottom:1rem}.step-card h3{color:#8b4513;margin-bottom:1rem;font-size:1.3rem}.step-card p{color:#666;line-height:1.5}@media (max-width: 1024px){.steps-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.steps-section{padding:3rem 1rem}.steps-title{font-size:2rem}.steps-grid{grid-template-columns:1fr}}@media (max-width: 640px){.steps-grid{grid-template-columns:1fr}}.scroll-to-top{position:fixed;bottom:20px;right:20px;background-color:#8b4513;color:beige;width:40px;height:40px;border-radius:50%;display:flex;justify-content:center;align-items:center;cursor:pointer;transition:all .3s ease;z-index:1000}.scroll-to-top:hover{background-color:sienna;transform:translateY(-3px)}
