.portfolio-cards{position:relative;height:150vh;background:var(--background);overflow:hidden}.portfolio-cards,.portfolio-cards-container{width:100%;display:flex;justify-content:center;align-items:center}.portfolio-cards-container{max-width:1400px;padding:0 2rem;height:100%;flex-direction:column}.portfolio-cards-header{text-align:center;margin-bottom:4rem;z-index:2}.portfolio-cards-header h2{font-size:3.5rem;font-family:Cormorant Garamond,serif;font-weight:600;color:var(--foreground);margin-bottom:1rem;text-shadow:2px 2px 4px rgba(0,0,0,.8)}.portfolio-cards-header p{font-size:1.2rem;color:rgba(255,255,255,.8);font-weight:300;max-width:600px;margin:0 auto}.portfolio-cards-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;width:100%;max-width:1200px;z-index:2}.portfolio-card{position:relative;height:300px;border-radius:1.5rem;overflow:hidden;cursor:pointer;transition:all .4s cubic-bezier(.4,0,.2,1);box-shadow:0 10px 30px rgba(0,0,0,.3)}.portfolio-card:hover{transform:translateY(-10px) scale(1.02);box-shadow:0 20px 40px rgba(0,0,0,.4)}.portfolio-card-image{position:relative;width:100%;height:100%;overflow:hidden}.portfolio-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .4s cubic-bezier(.4,0,.2,1)}.portfolio-card:hover .portfolio-card-image img{transform:scale(1.1)}.portfolio-card-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,rgba(0,0,0,.7),rgba(0,0,0,.4) 50%,rgba(0,0,0,.8));display:flex;align-items:flex-end;padding:2rem;opacity:1;transition:opacity .3s ease}.portfolio-card:hover .portfolio-card-overlay{background:linear-gradient(135deg,rgba(0,0,0,.8),rgba(0,0,0,.6) 50%,rgba(0,0,0,.9))}.portfolio-card-content{color:white;width:100%}.portfolio-card-content h3{font-size:2rem;font-family:Cormorant Garamond,serif;font-weight:600;margin-bottom:.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.8)}.portfolio-card-content p{font-size:1rem;margin-bottom:1rem;opacity:.9;line-height:1.4}.portfolio-card-count{display:inline-block;background:rgba(255,255,255,.2);backdrop-filter:blur(10px);padding:.5rem 1rem;border-radius:2rem;font-size:.9rem;font-weight:500;border:1px solid rgba(255,255,255,.3)}@media (max-width:1024px){.portfolio-cards-grid{grid-template-columns:1fr;gap:1.5rem;max-width:600px}.portfolio-card{height:250px}.portfolio-cards-header h2{font-size:3rem}}@media (max-width:768px){.portfolio-cards-container{padding:0 1rem}.portfolio-cards-header{margin-bottom:2rem}.portfolio-cards-header h2{font-size:2.5rem}.portfolio-cards-header p{font-size:1rem}.portfolio-card{height:200px}.portfolio-card-content h3{font-size:1.5rem}.portfolio-card-content p{font-size:.9rem}.portfolio-card-overlay{padding:1.5rem}}@media (max-width:480px){.portfolio-cards-header h2{font-size:2rem}.portfolio-card{height:180px}.portfolio-card-content h3{font-size:1.3rem}.portfolio-card-overlay{padding:1rem}}.image-gallery-modal{position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgba(0,0,0,.95);backdrop-filter:blur(10px);z-index:9999;display:flex;justify-content:center;align-items:center;padding:2rem;animation:modalFadeIn .3s ease-out}.image-gallery-modal.fullscreen{padding:0}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.image-gallery-modal.closing{animation:modalFadeOut .3s ease-out forwards}@keyframes modalFadeOut{0%{opacity:1}to{opacity:0}}.modal-content{width:100%;height:100%;max-width:1400px;max-height:90vh;display:flex;flex-direction:column;background:rgba(20,20,20,.9);border-radius:1rem;overflow:hidden;box-shadow:0 25px 50px rgba(0,0,0,.5);animation:modalSlideIn .3s ease-out}.image-gallery-modal.fullscreen .modal-content{max-height:100vh;border-radius:0;max-width:100vw}@keyframes modalSlideIn{0%{transform:scale(.9) translateY(20px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;background:rgba(0,0,0,.8);border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.modal-title h2{font-size:2rem;font-family:Cormorant Garamond,serif;font-weight:600;color:white;margin:0 0 .25rem}.modal-title p{font-size:1rem;color:rgba(255,255,255,.7);margin:0}.modal-controls{display:flex;gap:.5rem}.control-btn{width:40px;height:40px;border:none;border-radius:50%;background:rgba(255,255,255,.1);color:white;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;backdrop-filter:blur(10px)}.control-btn:hover{background:rgba(255,255,255,.2);transform:scale(1.1)}.close-btn:hover{background:rgba(255,0,0,.3)}.modal-image-container{position:relative;flex:1;display:flex;justify-content:center;align-items:center;padding:2rem;overflow:hidden}.modal-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:.5rem;box-shadow:0 10px 30px rgba(0,0,0,.5);transition:transform .3s ease}.modal-image:hover{transform:scale(1.02)}.nav-btn{position:absolute;top:50%;transform:translateY(-50%);width:60px;height:60px;border:none;border-radius:50%;background:rgba(0,0,0,.7);color:white;font-size:2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;backdrop-filter:blur(10px);z-index:10}.nav-btn:hover{background:rgba(0,0,0,.9);transform:translateY(-50%) scale(1.1)}.prev-btn{left:2rem}.next-btn{right:2rem}.thumbnail-strip{display:flex;gap:.5rem;padding:1rem 2rem;background:rgba(0,0,0,.8);border-top:1px solid rgba(255,255,255,.1);overflow-x:auto;flex-shrink:0}.thumbnail{width:80px;height:60px;border-radius:.5rem;overflow:hidden;cursor:pointer;transition:all .3s ease;border:2px solid transparent;flex-shrink:0}.thumbnail:hover{transform:scale(1.1);border-color:rgba(255,255,255,.3)}.thumbnail.active{border-color:white;transform:scale(1.1)}.thumbnail img{width:100%;height:100%;object-fit:cover}.modal-instructions{padding:1rem 2rem;text-align:center;background:rgba(0,0,0,.8);border-top:1px solid rgba(255,255,255,.1);flex-shrink:0}.modal-instructions p{color:rgba(255,255,255,.6);font-size:.9rem;margin:0}@media (max-width:1024px){.image-gallery-modal{padding:1rem}.modal-header{padding:1rem 1.5rem}.modal-title h2{font-size:1.5rem}.modal-image-container{padding:1rem}.nav-btn{width:50px;height:50px;font-size:1.5rem}.prev-btn{left:1rem}.next-btn{right:1rem}.thumbnail-strip{padding:.75rem 1.5rem}.thumbnail{width:60px;height:45px}}@media (max-width:768px){.image-gallery-modal{padding:.5rem}.modal-header{padding:1rem}.modal-title h2{font-size:1.3rem}.modal-image-container{padding:.5rem}.nav-btn{width:45px;height:45px;font-size:1.3rem}.prev-btn{left:.5rem}.next-btn{right:.5rem}.thumbnail-strip{padding:.5rem 1rem}.thumbnail{width:50px;height:37px}.modal-instructions{padding:.75rem 1rem}.modal-instructions p{font-size:.8rem}}@media (max-width:480px){.modal-title h2{font-size:1.1rem}.modal-title p{font-size:.9rem}.control-btn{width:35px;height:35px;font-size:1rem}.nav-btn{width:40px;height:40px;font-size:1.1rem}.thumbnail{width:45px;height:33px}}