.hero{padding:100px 0;text-align:center;min-height:calc(100vh - 200px);display:flex;align-items:center}
.hero-title{font-size:3.5rem;font-weight:300;margin-bottom:1rem;letter-spacing:-1px}
.hero-subtitle{font-size:1.25rem;color:var(--color-dark-gray);margin-bottom:2rem;font-weight:300}
.hero-description{max-width:800px;margin:0 auto 3rem;font-size:1.1rem;line-height:1.8}
.cta{font-style:italic;margin-top:1.5rem;font-size:1rem}

.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;padding:3rem 0;max-width:1200px;margin:0 auto}
.gallery-item{position:relative;overflow:hidden;cursor:pointer;background:var(--color-gray);aspect-ratio:4/3;transition:var(--transition);border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,0.1)}
.gallery-item:hover{transform:translateY(-5px);box-shadow:0 8px 24px rgba(0,0,0,0.15)}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:var(--transition)}
.gallery-item:hover img{transform:scale(1.08)}
.gallery-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,0.85) 0%,rgba(0,0,0,0.4) 70%,transparent 100%);padding:1.5rem;opacity:1;transition:var(--transition)}
.gallery-item:hover .gallery-overlay{background:linear-gradient(to top,rgba(0,0,0,0.95) 0%,rgba(0,0,0,0.6) 70%,transparent 100%)}
.gallery-title{color:var(--color-white);font-size:1.25rem;font-weight:600;margin-bottom:0.5rem}
.gallery-count{color:rgba(255,255,255,0.9);font-size:0.95rem;font-weight:300}

.image-grid{display:flex;flex-wrap:wrap;gap:6px;padding:2rem 0}
.image-item{position:relative;overflow:hidden;border-radius:6px;background:var(--color-gray);flex-grow:1;cursor:pointer}
.image-item:hover{transform:translateY(-3px);box-shadow:0 4px 15px rgba(0,0,0,0.2)}
.image-item img{width:100%;height:100%;object-fit:cover;display:block;border-radius:6px;cursor:pointer}
.image-item img.loaded{opacity:1}
.image-item:hover img{transform:scale(1.03)}
.image-item::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(0,0,0,0.1) 0%,rgba(0,0,0,0.3) 100%);opacity:0;transition:var(--transition);border-radius:6px;z-index:1}
.image-item:hover::before{opacity:1}

.modal{display:none;position:fixed;top:0;left:0;width:100%;height:100dvh;height:100vh;background:rgba(0,0,0,.95);z-index:2000;opacity:0;transition:opacity .3s ease}
.modal.active{display:flex;opacity:1}
.modal-content{display:flex;width:100%;height:100%;position:relative}
.modal-image-container{flex:1;display:flex;align-items:center;justify-content:center;padding:20px;position:relative;min-height:0;overflow:hidden;cursor:grab;touch-action:pan-x pan-y;user-select:none}
.modal-image-container:active{cursor:grabbing}
.modal-image-container.dragging{cursor:grabbing}
.modal-slider{position:relative;width:100%;height:100%;overflow:hidden}
.modal-slide{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;opacity:0;transform:translateX(100%);transition:transform .4s cubic-bezier(.4,0,.2,1),opacity .4s ease}
.modal-slide.active{opacity:1;transform:translateX(0)}
.modal-slide.prev{transform:translateX(-100%)}
.modal-slide.next{transform:translateX(100%)}
.modal-image{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;background:transparent;transition:transform .2s ease-out;transform-origin:center center;user-select:none;-webkit-user-select:none;pointer-events:none}
.modal-sidebar{display:none}
.modal-close{position:absolute;top:25px;right:20px;font-size:2rem;color:var(--color-white);cursor:pointer;background:rgba(0,0,0,.5);border:none;width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:var(--transition);z-index:10;touch-action:manipulation}
.modal-close:hover{background:rgba(0,0,0,.8);transform:scale(1.1)}
.modal-nav{position:absolute;top:50%;transform:translateY(-50%);font-size:1.5rem;color:var(--color-white);cursor:pointer;background:rgba(0,0,0,.5);border:none;width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:var(--transition);z-index:10;touch-action:manipulation}
.modal-prev{left:20px}
.modal-next{right:20px}
.modal-nav:hover{background:rgba(0,0,0,.8);transform:translateY(-50%) scale(1.1)}
.modal-nav:disabled{opacity:.3;cursor:not-allowed}
.modal-info{display:none}
.btn-full-quality,.btn-download{display:none}
.modal-action-btn{position:absolute;top:25px;font-size:1rem;font-weight:600;color:var(--color-white);cursor:pointer;background:rgba(0,0,0,.5);border:none;width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:var(--transition);z-index:10;touch-action:manipulation}
.modal-action-btn:hover{background:rgba(0,0,0,.8);transform:scale(1.1)}
.modal-action-btn:disabled{opacity:.3;cursor:not-allowed}
.modal-action-btn.full-quality-loaded{color:#00ff00;background:rgba(0,255,0,.2)}
.modal-hq-btn{right:140px;transition:right .3s ease}
.modal-download-btn{right:80px}
.modal-download-btn svg{width:20px;height:20px;fill:currentColor}
.modal-download-btn[style*="display: none"] ~ .modal-hq-btn{right:80px}
.modal-counter{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,0.9);font-size:1rem;background:rgba(0,0,0,0.6);padding:6px 16px;border-radius:20px 20px 0 0;z-index:10;backdrop-filter:blur(4px);line-height:1.2}

.about-section,.contact-section{padding:4rem 0;max-width:800px;margin:0 auto}
.about-section h2,.contact-section h2{font-size:2.5rem;font-weight:300;margin-bottom:2rem;text-align:center}
.about-content p,.contact-info p{margin-bottom:1.5rem;line-height:1.8}
.download-all{text-align:center;padding:2rem 0;display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}

@media(max-width:1024px){
.gallery-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem;padding:2rem 0}
}

@media(max-width:768px){
.gallery-grid{grid-template-columns:1fr;gap:1.5rem;padding:1.5rem 0}
.modal{height:100dvh;height:100vh}
.modal-content{flex-direction:column;position:relative;height:100%}
.modal-sidebar{width:100%;height:auto;border-left:none;border-top:1px solid rgba(255,255,255,.1);padding:15px 20px;padding-bottom:20px;order:2;position:relative;display:flex;flex-direction:column;gap:0;overflow:visible}
.modal-info{margin-bottom:0;display:block}
.modal-image-container{flex:1;display:flex;align-items:center;justify-content:center;padding:60px 10px 20px 10px;order:1;position:relative;min-height:0;height:auto}
.modal-nav{position:absolute;top:50%;transform:translateY(-50%);font-size:1.2rem;width:40px;height:40px;z-index:15}
.modal-prev{left:10px}
.modal-next{right:10px}
.modal-close{position:absolute;top:10px;right:10px;font-size:1.5rem;width:40px;height:40px;z-index:15}
.modal-hq-btn{left:10px;top:10px;width:40px;height:40px;font-size:0.75rem;right:auto;transition:left .3s ease}
.modal-download-btn{left:60px;top:10px;width:40px;height:40px;right:auto}
.modal-download-btn svg{width:18px;height:18px}
.modal-download-btn[style*="display: none"] ~ .modal-hq-btn{left:10px}
.modal-counter{display:none}
}

@media(max-width:480px){
.modal-sidebar{padding:12px 15px}
.modal-image-container{padding:55px 5px 15px 5px}
.modal-close{top:8px;right:8px;width:36px;height:36px;font-size:1.3rem}
.modal-hq-btn{left:8px;top:8px;width:36px;height:36px;font-size:0.7rem}
.modal-download-btn{left:52px;top:8px;width:36px;height:36px}
.modal-download-btn svg{width:16px;height:16px}
.modal-nav{width:36px;height:36px;font-size:1.1rem}
.modal-prev{left:8px}
.modal-next{right:8px}
}
