#preloader.hidden,.spinner-hidden:before{opacity:0;pointer-events:none}.item,body,html{font-family:Montserrat,Arial,sans-serif}.gallery-arrow,.gallery-close{cursor:pointer;position:absolute}#preloader{position:fixed;inset:0;background:#fff;z-index:50000;display:flex;align-items:center;justify-content:center;transition:opacity .7s cubic-bezier(.77,0,.17,1);opacity:1;pointer-events:all;will-change:opacity}.menu,.preloader-spinner{display:flex;align-items:center}.preloader-spinner{position:relative;width:230px;height:230px;justify-content:center}.preloader-spinner:before{content:"";position:absolute;inset:0;border-radius:50%;border:12px solid #e6e6e6;border-top:12px solid #0a66c2;border-bottom:12px solid #d6249f;animation:1.15s linear infinite rotate-spinner;z-index:1;box-sizing:border-box}@keyframes rotate-spinner{100%{transform:rotate(360deg)}}.spinner-hidden:before{transition:opacity .5s cubic-bezier(.77,0,.17,1)}.preloader-logo{width:151px;max-width:73%;height:auto;object-fit:contain;z-index:2;position:relative;display:block;transition:transform .8s cubic-bezier(.77,0,.17,1);will-change:transform}body,html{width:100vw;height:100vh;min-width:100vw;min-height:100vh;margin:0;padding:0;background:#fff;color:#222;overflow-x:hidden}.menu{position:fixed;top:0;left:0;width:100vw;height:9.8vh;min-height:56px;background:rgba(0,0,0,.8);backdrop-filter:blur(5px);z-index:1000;justify-content:space-between;padding:0 2.8vw;box-sizing:border-box}.menu .logo,.menu .logo a{display:flex;align-items:center}.menu .logo{justify-content:space-between;width:fit-content}.logo-img{height:53.2px;width:auto;max-height:8.4vh;object-fit:contain;display:block}#menu-toggle,.menu .logo label{display:none}.items{display:flex;align-items:center;gap:1vw}.item{text-decoration:none;color:#fff;font-size:1.54em;padding:.7em 1.2em;border-radius:8.4px;background:0 0;transition:color .2s}.item:hover{color:#bdbdbd}@media screen and (max-width:710px){#menu-toggle:checked~.items,.items{transition:max-height .5s cubic-bezier(.77,0,.17,1)}.menu{height:clamp(50px,11.2vh,65px);min-height:50.4px;padding:0 1.4vw;flex-direction:column;align-items:flex-start}.logo-img{height:clamp(25px,7vh,45px);max-height:7vh}.menu .logo{width:100%;padding:.5em 2vw;position:relative}.menu .logo label{display:block;cursor:pointer;position:absolute;top:50%;right:8px;transform:translateY(-50%);width:30px;height:30px;background:0 0}.menu .logo label::before{content:"menu";font-family:"Material Icons";font-size:30px;color:#fff}.items{flex-direction:column;align-items:stretch;max-height:0;overflow:hidden;width:100vw;left:0;top:100%;background:rgba(0,0,0,.8);backdrop-filter:blur(5px);box-shadow:0 2px 16px rgba(0,0,0,.4);position:absolute;z-index:9999;padding:0}.item{width:100%;min-height:48px;font-size:clamp(.9em, 3vw, 1.1em);line-height:1.25;padding:.7em 0;border-top:1px solid rgba(255,255,255,.15);color:#fff;text-align:center;background:0 0;border-radius:0;margin:0;display:flex;align-items:center;justify-content:center;box-shadow:none;transition:background .12s}.item:last-child{border-bottom:1px solid rgba(255,255,255,.15)}.item:focus,.item:hover{background:rgba(255,255,255,.1);color:#ddd}#menu-toggle:checked~.items{max-height:100vh}#menu-toggle:checked~.logo label::before{content:"close"}}.projects-main{width:100vw;min-height:100vh;padding-top:9.8vh;background:#fff;display:flex;justify-content:center;align-items:flex-start}.projects-grid{display:grid;grid-template-columns:repeat(2,minmax(240px,1fr));gap:2.5vw;width:90vw;max-width:1100px;margin:32px auto;justify-items:center}.project-card{position:relative;background:#fff;border:none;border-radius:0;box-shadow:0 2px 14px rgba(0,0,0,.07);transition:box-shadow .2s,transform .2s;display:flex;flex-direction:column;align-items:stretch}.project-card:hover{box-shadow:0 4px 24px rgba(0,0,0,.17);transform:translateY(-3px) scale(1.02)}.project-img{display:block;width:100%;aspect-ratio:4/3;object-fit:cover;transition:filter .2s,opacity .2s;border:none;border-radius:0}.project-card:hover .project-img{filter:brightness(1.09) blur(1px);opacity:.85}.project-label{position:absolute;top:13px;left:18px;background:rgba(255,255,255,.72);border-radius:0 0 12px;padding:7px 16px 7px 12px;z-index:2;box-shadow:0 1px 6px rgba(0,0,0,.07);display:flex;flex-direction:column;align-items:flex-start}.project-title{font-size:1.14em;font-weight:600;letter-spacing:.01em;color:#222;margin-bottom:.08em;line-height:1;text-align:left}.project-subtitle{font-size:1em;font-weight:400;color:#666;margin-top:2px;line-height:1.1;text-align:left}.gallery-lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:2000;justify-content:center;align-items:center;transition:opacity .2s}.gallery-lightbox.open{display:flex;animation:.2s fadeIn}@keyframes fadeIn{from{opacity:0}to{opacity:1}}.gallery-content{position:relative;background:0 0;display:flex;align-items:center;justify-content:center;max-width:96vw;max-height:92vh;width:720px;min-width:240px;min-height:180px;flex-direction:row;padding:10px 0}.gallery-image{max-width:70vw;max-height:78vh;border-radius:0;box-shadow:0 4px 32px rgba(0,0,0,.25);background:#fff;object-fit:contain;margin:0 56px;transition:box-shadow .2s;display:block}.gallery-arrow{top:50%;transform:translateY(-50%);background:rgba(0,0,0,.45);color:#fff;border:none;border-radius:50%;width:46px;height:46px;font-size:1.5em;display:flex;align-items:center;justify-content:center;z-index:3;transition:background .15s,transform .15s}.gallery-arrow-left{left:16px;margin-left:0}.gallery-arrow-right{right:16px;margin-right:0}.gallery-arrow:hover{background:rgba(0,0,0,.75);transform:translateY(-50%) scale(1.1)}.gallery-close{top:24px;right:24px;background:rgba(255,255,255,.7);color:#222;border:none;font-size:2em;border-radius:50%;width:40px;height:40px;z-index:4;transition:background .15s,color .15s}.menu-toggle,.nav-links a{color:#fff;background:0 0}.gallery-close:hover{background:#fff;color:#d6249f}.gallery-dots{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;gap:7px;z-index:5}.gallery-dot{width:13px;height:13px;border-radius:50%;background:rgba(255,255,255,.55);border:2px solid #888;cursor:pointer;transition:background .15s,border .15s}.gallery-dot.active{background:#d6249f;border:2px solid #fff}@media (max-width:900px){.projects-grid{grid-template-columns:1fr;gap:3vw;width:98vw}.gallery-content{width:95vw;max-width:98vw;min-width:0;padding:6px 0}.gallery-image{max-width:75vw;max-height:60vh;margin:0 36px}.gallery-arrow{width:36px;height:36px;font-size:1.2em}.gallery-arrow-left{left:6px}.gallery-arrow-right{right:6px}.gallery-close{right:10px;top:12px;width:32px;height:32px;font-size:1.3em}.gallery-dots{bottom:10px}}@media (max-width:700px){.projects-main{padding-top:11.2vh}.gallery-content{flex-direction:column;justify-content:center;align-items:center;width:100vw;max-width:100vw;min-width:0;height:100dvh;padding:0}.gallery-image{width:88vw;max-width:92vw;min-width:0;margin:0;max-height:58vh}.gallery-arrow{top:unset;bottom:60px;left:unset;right:unset;position:absolute}.gallery-arrow-left{left:15vw;right:unset;bottom:48px;transform:none}.gallery-arrow-right{right:15vw;left:unset;bottom:48px;transform:none}.gallery-close{top:10px;right:10px;width:29px;height:29px;font-size:1em;z-index:10}.gallery-dots{bottom:20px}}@media (max-width:600px){.preloader-spinner{width:120px;height:120px}.preloader-logo{width:82px;max-width:72%}.menu{flex-direction:row;height:clamp(40px,14vh,60px);min-height:44.8px;align-items:center;padding:0 2.8vw}.logo-img{height:clamp(20px,5.6vh,40px)}.projects-main{padding-top:14vh}.gallery-content{width:100vw;min-width:0;margin:0}.gallery-image{margin:0 12vw;max-width:80vw;max-height:60vh}.gallery-arrow{width:36px;height:36px;font-size:1.1em}.gallery-arrow-left{left:15vw;bottom:48px}.gallery-arrow-right{right:15vw;bottom:48px}.gallery-close{width:29px;height:29px;font-size:1em;top:10px;right:10px;z-index:10}.gallery-dots{bottom:20px}}@media (max-width:450px){.gallery-image{width:95vw;max-width:100vw;min-width:0;max-height:42vh}.gallery-arrow-left{left:8vw;bottom:38px}.gallery-arrow-right{right:8vw;bottom:38px}}.social-floating{position:fixed;right:2vw;bottom:2vh;display:flex;flex-direction:column;gap:.7em;z-index:1001;pointer-events:none}.social-icon{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.35);display:flex;align-items:center;justify-content:center;font-size:1.3em;color:#fff;box-shadow:0 2px 10px rgba(0,0,0,.19);opacity:.95;transition:opacity .2s,background .2s,transform .2s;pointer-events:auto;border:1.5px solid rgba(255,255,255,.35);backdrop-filter:blur(3px);margin-bottom:.1em}.social-icon:hover{opacity:1;background:rgba(255,255,255,.6);transform:scale(1.08)}.social-icon.linkedin{color:#0a66c2}.social-icon.instagram{color:#d6249f}.copyright{position:fixed;left:2vw;bottom:2vh;z-index:30;color:#999;font-size:1.12em;opacity:.82;font-weight:600;letter-spacing:.03em;pointer-events:none;user-select:none;text-shadow:0 2px 14px rgba(0,0,0,.2),0 1px 7px rgba(0,0,0,.18);transition:opacity .3s,color .18s}.copyright:hover{opacity:1;color:#616161}@media (max-width:600px){.social-icon{width:30px;height:30px;font-size:1em}.social-floating{gap:.4em}.copyright{font-size:.97em;left:3vw;bottom:1.5vh;text-shadow:0 1px 8px rgba(0,0,0,.17)}}