:root{--color-white:#fff;--color-off-white:#fafafa;--color-black:#0a0a0a;--color-dark:#1a1a1a;--color-gray-100:#f5f5f5;--color-gray-200:#e5e5e5;--color-gray-300:#d4d4d4;--color-gray-400:#a3a3a3;--color-gray-500:#737373;--color-gray-600:#525252;--color-bg:var(--color-white);--color-bg-alt:var(--color-off-white);--color-text:var(--color-black);--color-text-secondary:var(--color-gray-500);--color-accent:var(--color-black);--color-border:var(--color-gray-200);--transition-fast:0.2s ease;--transition-base:0.3s ease;--transition-slow:0.5s ease}*{box-sizing:border-box;padding:0}*,body{margin:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;background-color:var(--color-bg);color:#0a0a0a;color:var(--color-text);font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,SF Pro Text,Segoe UI,Roboto,Helvetica Neue,sans-serif;overflow-x:hidden}::selection{background-color:#0a0a0a26;color:#0a0a0a;color:var(--color-black)}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{background-color:#fff;color:#1d1d1f;min-height:100vh;width:100%}html{scroll-behavior:smooth}section{padding:80px 0;position:relative}@media (max-width:768px){section{padding:60px 0}}.navbar{backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);background-color:#ffffffe6;border-bottom:1px solid var(--color-gray-200);height:48px;left:0;padding:0;position:fixed;right:0;top:0;transition:all .3s ease;z-index:1000}.navbar.scrolled{background-color:#fffffffa;box-shadow:0 1px 8px #0a0a0a0a}.navbar-container{align-items:center;display:flex;height:100%;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 24px;position:relative}.navbar-logo{color:var(--color-black);display:inline-block;font-size:13px;font-weight:600;letter-spacing:-.01em;margin-right:auto;text-decoration:none;transition:color .3s ease,transform .3s ease}.navbar-logo:hover{color:var(--color-gray-600);transform:translateX(-2px)}.navbar-back-button{align-items:center;border:1px solid var(--color-gray-200);border-radius:0;color:var(--color-black);display:inline-flex;font-size:12px;font-weight:500;gap:8px;margin-left:auto;padding:8px 16px;text-decoration:none;transition:all .2s ease}.navbar-back-button:hover{background-color:var(--color-black);border-color:var(--color-black);color:var(--color-white)}.navbar-back-button svg{transition:transform .2s ease}.navbar-back-button:hover svg{transform:translateX(-3px)}.navbar-menu{align-items:center;display:flex;flex:1 1;gap:8px;justify-content:center;list-style:none;margin:0;padding:0}.navbar-menu li a{color:var(--color-black);display:block;font-size:11px;font-weight:400;line-height:40px;padding:0 4px;position:relative;text-decoration:none;transition:color .3s ease}.navbar-menu li a:hover{color:var(--color-gray-600)}.navbar-menu li a.active{color:var(--color-black);font-weight:500}.navbar-menu li a:after{background-color:var(--color-black);bottom:8px;content:"";height:2px;left:12px;margin:0 auto;position:absolute;right:12px;transition:width .3s ease;width:0}.navbar-menu li a.active:after,.navbar-menu li a:hover:after{width:calc(100% - 24px)}.mobile-menu-toggle{background:#0000;border:none;cursor:pointer;display:none;flex-direction:column;height:22px;justify-content:space-around;padding:0;position:relative;width:22px;z-index:1001}.mobile-menu-toggle span{background-color:var(--color-black);border-radius:0;height:2px;transform-origin:center;transition:all .3s ease;width:100%}.mobile-menu-toggle.open span:first-child{transform:rotate(45deg) translate(6px,6px)}.mobile-menu-toggle.open span:nth-child(2){opacity:0}.mobile-menu-toggle.open span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}@media (max-width:768px){.navbar{height:44px}.mobile-menu-toggle{display:flex}.navbar-menu{backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);background-color:#fffffffa;border-bottom:1px solid var(--color-gray-200);box-shadow:0 8px 24px #0a0a0a0f;flex-direction:column;gap:0;left:0;opacity:0;padding:24px 0;position:fixed;right:0;top:44px;transform:translateY(-100%);transition:transform .3s ease,opacity .3s ease,visibility .3s ease;visibility:hidden}.navbar-menu.mobile-open{opacity:1;transform:translateY(0);visibility:visible}.navbar-menu li{border-bottom:1px solid var(--color-gray-200);width:100%}.navbar-menu li:last-child{border-bottom:none}.navbar-menu li a{display:block;font-size:12px;line-height:1.5;padding:18px 24px;width:100%}.navbar-menu li a:after{bottom:14px;left:24px;right:24px}.navbar-menu li a.active:after,.navbar-menu li a:hover:after{width:calc(100% - 48px)}.navbar-logo{font-size:16px}.navbar-back-button{font-size:11px;padding:6px 12px}.navbar-back-button span{display:none}}.hero{align-items:center;background:linear-gradient(180deg,var(--color-white) 0,var(--color-off-white) 100%);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:164px 22px 80px;position:relative}.hero:before{background:radial-gradient(circle at 50% 50%,#0a0a0a05 0,#0000 70%);content:"";pointer-events:none}.hero-background-image,.hero:before{bottom:0;left:0;position:absolute;right:0;top:0;z-index:0}.hero-background-image{height:100%;overflow:hidden;width:100%}.hero-background-img{height:100%;left:0;object-fit:cover;object-position:center;opacity:1;position:absolute;top:0;width:100%;z-index:0}.hero-background-img-fade-out{animation:backgroundImageFadeOut .6s ease-out forwards}.hero-background-img-fade-in{animation:backgroundImageFadeIn .8s ease-out forwards;opacity:0}.hero-container{align-items:center;display:flex;gap:60px;justify-content:center;margin:0 auto;max-width:1200px;position:relative;width:100%;z-index:2}.hero-content{animation:slideToLeft 1s ease-in-out 3.5s forwards;flex:0 0 auto;max-width:700px;padding:60px 40px;position:relative;text-align:center;width:100%;z-index:10}.hero:after{background-color:#fffffff2;border-radius:0;content:"";height:450px;left:0;pointer-events:none;position:absolute;right:0;top:50%;transform:translateY(-40%);width:100vw;will-change:auto;z-index:1}.hero-image-wrapper{animation:slideInFromRight 1s ease-in-out 3.5s forwards;flex:0 0;min-width:0;opacity:0;overflow:hidden;transform:translateX(150px);visibility:hidden;width:0}.hero-image{border-radius:18px;box-shadow:0 20px 60px #0a0a0a14;height:100%;min-height:550px;overflow:hidden;position:relative;transition:transform .3s ease,box-shadow .3s ease;width:100%}.hero-image:hover{box-shadow:0 30px 80px #0a0a0a1f;transform:translateY(-4px)}.hero-image-img{border-radius:18px;display:block;height:100%;left:0;min-height:550px;object-fit:cover;position:absolute;top:0;width:100%}.hero-image-img.image-fade-out{animation:imageFadeOut .6s ease-out forwards}.hero-image-img-new{opacity:0}.hero-image-slide-right{animation:imageSlideInFromRight .8s ease-out forwards;transform:translateX(150px)}.hero-image-slide-top{animation:imageSlideInFromTop .8s ease-out forwards;transform:translateY(-150px)}.hero-title{animation:fadeInTitle .6s ease-out;color:var(--color-black);display:inline-block;font-size:64px;font-weight:600;letter-spacing:-1.6px;line-height:1.05;margin-bottom:16px;overflow:hidden;position:relative}.hero-title:after{animation:lightBeamMove 2.5s ease-in-out .6s;background:linear-gradient(110deg,#0000,#0000 45%,#ffffff80 48%,#fff 49%,#fff 50%,#fff 51%,#ffffff80 52%,#0000 55%,#0000);border-radius:4px;content:"";filter:brightness(1.5) contrast(1.2);height:100%;left:-150%;mix-blend-mode:screen;opacity:.9;pointer-events:none;position:absolute;top:0;width:150%;z-index:1}.hero-subtitle{color:var(--color-black);font-size:22px;font-weight:400;letter-spacing:.007em;line-height:1.14286;margin-bottom:13px;min-height:1.5em;opacity:0;transition:none}.hero-subtitle.text-fade-in{animation:textFadeIn .8s ease-out forwards;pointer-events:auto;will-change:opacity,transform}.hero-subtitle.text-fade-out{animation:textFadeOut .8s ease-out forwards!important;opacity:1!important;pointer-events:none;transition:none!important;will-change:opacity,transform}.hero-description{color:var(--color-gray-500);font-size:17px;font-weight:400;letter-spacing:.011em;line-height:1.381;margin-bottom:32px;min-height:1.5em;opacity:0;transition:none}.hero-description.text-fade-in{animation:textFadeIn .8s ease-out forwards;pointer-events:auto;will-change:opacity,transform}.hero-description.text-fade-out{animation:textFadeOut .8s ease-out forwards!important;opacity:1!important;pointer-events:none;transition:none!important;will-change:opacity,transform}.hero-cta{animation:fadeInUp .8s ease-out 4.9s both;display:flex;flex-wrap:wrap;gap:16px;justify-content:flex-start;left:0;opacity:0;transform:translateX(0);width:-webkit-fit-content;width:fit-content}.cta-button,.hero-cta{align-items:center;position:relative}.cta-button{background-color:var(--color-black);border-radius:0;box-shadow:none;color:var(--color-white);display:inline-flex;font-size:14px;font-weight:400;gap:6px;justify-content:center;letter-spacing:.02em;min-width:140px;overflow:hidden;padding:14px 28px;text-align:center;text-decoration:none;transition:all .3s ease}.cta-button:before{background:linear-gradient(90deg,#0000,#ffffff1a,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.cta-button:hover:before{left:100%}.cta-button:hover{background-color:var(--color-gray-600);box-shadow:0 6px 20px #0a0a0a33;transform:translateY(-2px)}.cta-button:active{transform:translateY(0)}.cta-button svg{flex-shrink:0;transition:transform .3s ease}.cta-button:hover svg{transform:translateX(4px)}.cta-link{align-items:center;border-radius:0;color:var(--color-black);display:inline-flex;font-size:14px;font-weight:400;gap:6px;justify-content:center;padding:14px 28px;position:relative;text-decoration:none;transition:all .3s ease}.cta-link:after{background-color:var(--color-black);bottom:12px;content:"";height:1px;left:28px;position:absolute;right:28px;transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.cta-link:hover{background-color:#0a0a0a08;color:var(--color-gray-600)}.cta-link:hover:after{transform:scaleX(1)}.cta-link svg{flex-shrink:0;transition:transform .3s ease}.cta-link:hover svg{transform:translateX(4px)}@keyframes fadeInTitle{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes lightBeamMove{0%{left:-150%}to{left:100%}}@keyframes textFadeOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}@keyframes textFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes imageFadeOut{0%{opacity:1}to{opacity:0}}@keyframes imageSlideInFromRight{0%{opacity:0;transform:translateX(150px)}to{opacity:1;transform:translateX(0)}}@keyframes imageSlideInFromTop{0%{opacity:0;transform:translateY(-150px)}to{opacity:1;transform:translateY(0)}}@keyframes backgroundImageFadeOut{0%{opacity:1}to{opacity:0}}@keyframes backgroundImageFadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUpAndCenter{0%{opacity:0;transform:translateY(30px) translateX(-50%)}to{opacity:1;transform:translateY(0) translateX(-50%)}}@keyframes slideToLeft{0%{text-align:center;transform:translateX(0)}to{text-align:left;transform:translateX(-15%)}}@keyframes slideInFromRight{0%{flex:0 0;min-width:0;opacity:0;transform:translateX(150px);visibility:hidden;width:0}to{flex:1 1 auto;max-width:650px;min-width:0;opacity:1;transform:translateX(0);visibility:visible;width:auto}}@keyframes buttonsSlideLeft{0%{justify-content:center;left:50%;transform:translateY(0) translateX(-50%)}to{justify-content:flex-start;left:0;transform:translateY(0) translateX(0)}}@media (max-width:1068px){.hero-container{flex-direction:column;gap:40px}.hero-content{max-width:100%;padding:50px 30px;text-align:center}.hero:after{height:400px}.hero-content.slideToLeft{text-align:left}.hero-image-wrapper{max-width:100%}.hero-title{font-size:51px}.hero-subtitle{font-size:19px}.hero-description{font-size:15px}}@media (max-width:768px){.hero{min-height:90vh;padding:144px 22px 60px}.hero-container{flex-direction:column;gap:30px}.hero-content{padding:40px 20px;text-align:center!important;transform:none!important}.hero:after{height:350px}.hero-image-wrapper{max-width:100%!important;opacity:1!important;transform:none!important}.hero-image,.hero-image-img{min-height:400px}.hero-title{font-size:38px;letter-spacing:-.8px}.hero-subtitle{font-size:17px}.hero-description{font-size:14px}.hero-cta{flex-direction:column}.cta-button,.cta-link{font-size:12px;max-width:240px;padding:12px 24px;width:100%}}.active-flower-container{align-items:center;display:flex;height:auto;justify-content:center;max-width:640px;position:absolute;width:auto}.active-flower-container.centered-vertical{transform:translateY(-50%)}.active-flower-image{-webkit-user-drag:none;display:block;height:auto;max-width:640px;object-fit:contain;transition:opacity .3s ease;-webkit-user-select:none;user-select:none;width:100%}.active-flower-image.loading{opacity:0}.active-flower-image.loaded{opacity:1}.active-flower-loading{align-items:center;display:flex;height:40px;justify-content:center;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:40px}.loading-spinner{animation:spin .8s linear infinite;border:2px solid #0071e333;border-radius:50%;border-top-color:#0071e3;height:24px;width:24px}@media (max-width:1024px){.active-flower-container,.active-flower-image{max-width:240px}}@media (max-width:768px){.active-flower-container{left:-24px!important;max-width:160px}.active-flower-image{max-width:160px}}@media (max-width:480px){.active-flower-container,.active-flower-image{max-width:120px}}@media (prefers-reduced-motion:reduce){.active-flower-image{transition:none}.loading-spinner{animation:none;border-top-color:#0071e333}}@media (-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.active-flower-image{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}}.about{align-items:center;background:var(--color-white);display:flex;overflow:hidden;padding:64px 0;position:relative}.about:before{background:radial-gradient(ellipse at 30% 20%,#0a0a0a05 0,#0000 50%),radial-gradient(ellipse at 70% 80%,hsla(0,0%,4%,.015) 0,#0000 50%);content:"";pointer-events:none}.about-background-image,.about:before{bottom:0;left:0;position:absolute;right:0;top:0;z-index:0}.about-background-image{overflow:hidden}.about-background-img{filter:saturate(0) contrast(1.1);height:100%;object-fit:cover;object-position:center;opacity:.08;width:100%}.about-container{margin:0 auto;max-width:1200px;padding:0 24px;position:relative;width:100%;z-index:2}.about-header{margin-bottom:32px;opacity:0;text-align:center;transform:translateY(24px)}.about-header.fade-in-up{animation:fadeIn .6s ease-out forwards}.about-section-title{color:var(--color-black);font-size:36px;font-weight:600;letter-spacing:-.02em;line-height:1.15;margin-bottom:12px}.about-section-description{color:var(--color-gray-500);font-size:15px;font-weight:400;line-height:1.55;margin:0 auto 20px;max-width:580px}.about-industries{align-items:center;display:flex;flex-direction:column;gap:12px}.industry-label{color:var(--color-black);font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase}.industry-tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.industry-tag{background:#0000;border:1px solid var(--color-gray-300);border-radius:100px;color:var(--color-black);font-size:12px;font-weight:500;letter-spacing:.01em;padding:6px 12px;transition:all .2s ease}.industry-tag:hover{background:var(--color-black);border-color:var(--color-black);color:var(--color-white);transform:translateY(-1px)}.about-features{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr);margin-bottom:32px}.feature-item{background:#fffc;border:1px solid var(--color-gray-200);border-radius:0;padding:20px 18px;text-align:center;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.feature-item:hover{background:#fff;border-color:var(--color-black);box-shadow:0 4px 16px #0a0a0a0f}.feature-icon{display:block;font-size:24px;margin-bottom:10px}.feature-item h3{color:var(--color-black);font-size:13px;font-weight:600;letter-spacing:-.01em;line-height:1.3;margin-bottom:6px}.feature-item p{color:var(--color-gray-500);font-size:11px;font-weight:400;line-height:1.45;margin:0}.about-stats{grid-gap:12px;border-top:1px solid var(--color-gray-200);display:grid;gap:12px;grid-template-columns:repeat(4,1fr);opacity:0;padding:24px 0 0;transform:translateY(20px)}.about-stats.fade-in-up{animation:fadeIn .5s ease-out forwards}.stat-item{padding:12px 8px;text-align:center}.stat-number{color:var(--color-black);display:block;font-size:26px;font-weight:600;letter-spacing:-.02em;line-height:1.1;margin-bottom:4px}.stat-label{color:var(--color-gray-500);display:block;font-size:10px;font-weight:500;letter-spacing:.06em;text-transform:uppercase}@media (max-width:1068px){.about{padding:56px 0}.about-section-title{font-size:36px}.about-section-description{font-size:15px}.about-features{gap:14px;grid-template-columns:repeat(2,1fr)}.feature-item{padding:18px 16px}.feature-item h3{font-size:14px}.feature-item p{font-size:11px}.about-stats{gap:10px;grid-template-columns:repeat(4,1fr)}.stat-number{font-size:28px}}@media (max-width:768px){.about{padding:48px 0}.about-header{margin-bottom:24px}.about-section-title{font-size:30px;margin-bottom:12px}.about-section-description{font-size:14px;margin-bottom:18px}.about-industries{gap:10px}.industry-label{font-size:9px}.industry-tags{gap:6px}.industry-tag{font-size:11px;padding:6px 12px}.about-features{gap:10px;grid-template-columns:repeat(2,1fr);margin-bottom:24px}.feature-item{padding:16px 14px}.feature-icon{font-size:20px;margin-bottom:8px}.feature-item h3{font-size:13px}.feature-item p{font-size:11px}.about-stats{gap:8px;grid-template-columns:repeat(4,1fr);padding:18px 0 0}.stat-item{padding:10px 6px}.stat-number{font-size:24px}.stat-label{font-size:8px}}@media (max-width:480px){.about{padding:40px 0}.about-container{padding:0 16px}.about-header{margin-bottom:20px}.about-section-title{font-size:26px}.about-section-description{font-size:13px;margin-bottom:14px}.industry-tags{gap:5px}.industry-tag{font-size:10px;padding:5px 10px}.about-features{gap:8px;grid-template-columns:1fr;margin-bottom:20px}.feature-item{padding:14px 16px}.feature-icon{font-size:18px;margin-bottom:6px}.feature-item h3{font-size:13px;margin-bottom:6px}.feature-item p{font-size:11px}.about-stats{gap:8px;grid-template-columns:repeat(2,1fr);padding:16px 0 0}.stat-number{font-size:22px;margin-bottom:4px}.stat-label{font-size:8px}}.services{background:var(--color-off-white);box-sizing:border-box;display:flex;flex-direction:column;min-height:100vh;overflow:hidden;padding:44px 0 0;position:relative}.services:before{background:radial-gradient(ellipse at 30% 20%,#0a0a0a05 0,#0000 50%),radial-gradient(ellipse at 70% 80%,hsla(0,0%,4%,.015) 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:0}.services-container{box-sizing:border-box;display:flex;flex-direction:column;margin:0 auto;max-width:1200px;padding:48px 24px 32px;position:relative;width:100%;z-index:1}.services-header{margin-bottom:36px;opacity:0;text-align:center;transform:translateY(24px);transition:opacity .6s ease-out,transform .6s ease-out}.services-header.fade-in-up{opacity:1;transform:translateY(0)}.service-section-title{color:var(--color-black);font-size:36px;font-weight:600;letter-spacing:-.02em;line-height:1.15;margin-bottom:12px}.service-section-description{color:var(--color-gray-500);font-size:15px;font-weight:400;line-height:1.55;margin:0 auto;max-width:580px}.services-error,.services-loading{color:var(--color-gray-500);font-size:13px;font-weight:400;padding:32px 16px;text-align:center}.services-loading{align-items:center;display:flex;flex-direction:column;gap:12px}.services-loading:before{animation:spin .7s linear infinite;border:2px solid var(--color-gray-200);border-radius:50%;border-top-color:var(--color-black);content:"";height:24px;width:24px}.services-error{background:#c54b4b0f;border:1px solid #c54b4b26;border-radius:0;color:#c54b4b;margin:0 auto;max-width:360px;padding:14px 18px}.services-drawer-list{background:#ffffffe6;border:1px solid var(--color-gray-200);border-radius:0;display:flex;flex-direction:column;gap:0;overflow:hidden;width:100%}.service-drawer{border-bottom:1px solid var(--color-gray-200);opacity:0;transform:translateY(16px)}.service-drawer:last-child{border-bottom:none}.service-drawer.fade-in-up{animation:fadeInUp .4s ease-out forwards}.service-drawer-header{align-items:center;background:#0000;border:none;cursor:pointer;display:flex;gap:16px;justify-content:space-between;padding:18px 22px;text-align:left;transition:background-color .2s ease;width:100%}.service-drawer-header:hover{background:#0a0a0a08}.service-drawer.expanded .service-drawer-header{background:#0a0a0a0d}.service-drawer-header:focus-visible{background:#0a0a0a0d;outline:none}.service-drawer-left{gap:16px}.service-drawer-left,.service-icon{align-items:center;display:flex;flex-shrink:0}.service-icon{background:#0a0a0a0d;border-radius:0;font-size:24px;height:40px;justify-content:center;line-height:1;transition:background .2s ease;width:40px}.service-drawer.expanded .service-icon,.service-drawer:hover .service-icon{background:#0a0a0a14}.service-title{color:var(--color-black);font-size:14px;font-weight:600;letter-spacing:-.01em;line-height:1.35;margin:0;white-space:nowrap}.service-drawer-right{gap:16px}.service-drawer-right,.service-tech-preview{align-items:center;display:flex;flex:1 1;justify-content:flex-end;min-width:0}.service-tech-preview{gap:8px;transition:opacity .2s ease}.service-tech-preview.hidden{opacity:0;pointer-events:none}.tech-preview-tag{background:#0a0a0a0d;border-radius:100px;color:var(--color-gray-500);font-size:10px;font-weight:500;line-height:1;padding:4px 10px;transition:color .2s ease,background .2s ease;white-space:nowrap}.service-drawer:hover .tech-preview-tag{background:#0a0a0a14;color:var(--color-black)}.tech-preview-more{background:#0a0a0a0a;border-radius:100px;color:var(--color-gray-500);font-size:10px;font-weight:500;padding:4px 6px;transition:color .2s ease,background .2s ease;white-space:nowrap}.service-drawer:hover .tech-preview-more{background:#0a0a0a14;color:var(--color-black)}.service-drawer-toggle{align-items:center;color:var(--color-gray-500);display:flex;flex-shrink:0;height:28px;justify-content:center;transition:transform .3s cubic-bezier(.4,0,.2,1),color .2s ease;width:28px}.service-drawer:hover .service-drawer-toggle{color:var(--color-black)}.service-drawer-toggle.expanded{color:var(--color-black);transform:rotate(180deg)}.service-drawer-content{max-height:0;overflow:hidden;transition:max-height .35s cubic-bezier(.4,0,.2,1)}.service-drawer-content.expanded{max-height:400px}.service-drawer-body{padding:20px 78px 24px}.service-description{color:var(--color-gray-500);font-size:13px;font-weight:400;line-height:1.55;margin:0 0 16px}.service-tech{display:flex;flex-direction:column;gap:10px}.service-tech-label{color:var(--color-black);font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase}.service-tech-list{display:flex;flex-wrap:wrap;gap:8px;list-style:none;margin:0;padding:0}.tech-tag{background:#0000;border:1px solid var(--color-gray-300);border-radius:100px;letter-spacing:.01em;line-height:1;transition:all .2s ease}.tech-tag:hover{background:var(--color-black);border-color:var(--color-black);color:var(--color-white);transform:translateY(-1px)}@media (max-width:1068px){.services{min-height:100vh;padding:44px 0 0}.services-container{padding:40px 20px 28px}.services-header{margin-bottom:28px}.service-section-title{font-size:36px}.service-section-description{font-size:15px}.service-drawer-header{gap:14px;padding:16px 20px}.service-drawer-left{gap:14px}.service-icon{font-size:22px;height:36px;width:36px}.service-title{font-size:14px}.service-drawer-right{gap:12px}.service-tech-preview{gap:6px}.tech-preview-tag{font-size:9px;padding:4px 10px}.tech-preview-more{font-size:9px;padding:4px 6px}.service-drawer-body{padding:0 20px 20px 70px}.service-description{font-size:13px}.tech-tag{font-size:11px;padding:6px 12px}}@media (max-width:768px){.services{min-height:100vh;padding:44px 0 0}.services-container{padding:32px 16px 24px}.services-header{margin-bottom:24px}.service-section-title{font-size:30px;margin-bottom:12px}.service-section-description{font-size:14px}.service-drawer-header{gap:12px;padding:14px 16px}.service-drawer-left{gap:12px}.service-icon{font-size:20px;height:34px;width:34px}.service-title{font-size:13px}.service-drawer-right{gap:10px}.service-tech-preview{gap:5px}.tech-preview-tag{font-size:9px;padding:3px 8px}.tech-preview-more{font-size:9px;padding:3px 6px}.service-drawer-toggle{height:24px;width:24px}.service-drawer-toggle svg{height:14px;width:14px}.service-drawer-body{padding:0 16px 18px 62px}.service-description{font-size:12px;line-height:1.55;margin-bottom:14px}.service-tech-label{font-size:9px}.service-tech-list{gap:6px}.tech-tag{font-size:11px;padding:6px 12px}}@media (max-width:480px){.services{min-height:100vh;padding:44px 0 0}.services-container{padding:28px 16px 20px}.services-header{margin-bottom:20px}.service-section-title{font-size:26px}.service-section-description{font-size:13px}.service-drawer-header{gap:10px;padding:12px 14px}.service-drawer-left{gap:10px}.service-icon{font-size:18px;height:32px;width:32px}.service-title{font-size:12px}.service-drawer-right{flex:0 1;gap:8px}.service-tech-preview{display:none}.service-drawer-toggle{height:22px;width:22px}.service-drawer-toggle svg{height:12px;width:12px}.service-drawer-body{padding:0 14px 16px}.service-description{font-size:11px;line-height:1.5;margin-bottom:14px}.service-tech{gap:8px}.service-tech-label{font-size:8px}.service-tech-list{gap:5px}.tech-tag{font-size:10px;padding:5px 10px}}.portfolio{align-items:center;background-color:var(--color-white);display:flex;min-height:100vh;overflow:hidden;padding:64px 0;position:relative}.portfolio:before{background:radial-gradient(ellipse at 60% 30%,#0a0a0a05 0,#0000 50%),radial-gradient(ellipse at 40% 70%,hsla(0,0%,4%,.015) 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:0}.portfolio-container{display:flex;flex-direction:column;justify-content:center;margin:0 auto;max-width:1200px;padding:0 24px;position:relative;width:100%;z-index:1}.portfolio-header{opacity:0;transform:translateY(30px);transition:opacity .8s ease-out,transform .8s ease-out}.portfolio-header.fade-in-up{opacity:1;transform:translateY(0)}.portfolio-error,.portfolio-loading{color:var(--color-gray-500);font-size:14px;padding:48px 16px;text-align:center}.portfolio-error{color:#c54b4b}.portfolio-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(3,1fr);margin-top:0}.portfolio-item{background-color:#fffc;border:1px solid var(--color-gray-200);border-radius:0;opacity:0;overflow:hidden;padding:28px 24px;position:relative;transform:translateY(30px);transition:transform .3s ease,box-shadow .3s ease,background-color .3s ease}.portfolio-item.fade-in-up{animation:fadeInUp .6s ease-out forwards}.portfolio-item:before{background:linear-gradient(90deg,var(--color-black) 0,var(--color-gray-600) 100%);content:"";height:3px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.portfolio-item:hover:before{transform:scaleX(1)}.portfolio-item:hover{background-color:#fff;border-color:var(--color-black);box-shadow:0 16px 40px #0a0a0a14;transform:translateY(-6px)}.portfolio-icon{display:inline-block;font-size:36px;margin-bottom:16px;transition:transform .3s ease}.portfolio-item:hover .portfolio-icon{transform:scale(1.1) rotate(5deg)}.portfolio-category{font-size:10px;letter-spacing:.05em;margin-bottom:8px;opacity:.8;text-transform:uppercase}.portfolio-category,.portfolio-title{color:var(--color-black);font-weight:600}.portfolio-title{font-size:21px;letter-spacing:-.5px;line-height:1.2;margin-bottom:10px}.portfolio-description{color:var(--color-gray-500);font-size:13px;font-weight:400;letter-spacing:.012em;line-height:1.5;margin-bottom:13px}.portfolio-highlight{background-color:#0a0a0a0d;border-left:2px solid var(--color-black);border-radius:6px;color:var(--color-black);display:inline-block;font-size:11px;font-weight:600;margin-bottom:16px;padding:6px 10px}.portfolio-tech{display:flex;flex-wrap:wrap;gap:8px}.tech-tag{background-color:#0a0a0a0d;border:1px solid #0a0a0a1a;border-radius:5px;color:var(--color-black);transition:all .3s ease}.portfolio-item:hover .tech-tag{border-color:var(--color-black);color:var(--color-black)}.section-title{color:var(--color-black);font-size:38px;font-weight:600;letter-spacing:-.5px;line-height:1.07143;margin-bottom:13px;text-align:center}.section-description{color:var(--color-gray-500);font-size:15px;font-weight:400;letter-spacing:.011em;line-height:1.381;margin:0 auto 32px;max-width:640px;text-align:center}@media (max-width:1068px){.portfolio{min-height:100vh;padding:48px 0}.section-title{font-size:36px}.section-description{font-size:15px;margin-bottom:28px}.portfolio-grid{gap:16px;grid-template-columns:repeat(2,1fr)}.portfolio-item{padding:24px 20px}.portfolio-icon{font-size:32px;margin-bottom:14px}.portfolio-title{font-size:21px}.portfolio-description{font-size:13px;margin-bottom:14px}.portfolio-highlight{font-size:10px;margin-bottom:16px}}@media (max-width:768px){.portfolio{min-height:100vh;padding:48px 0}.portfolio-container{padding:0 16px}.section-title{font-size:30px;margin-bottom:12px}.section-description{font-size:14px;margin-bottom:24px}.portfolio-grid{gap:16px;grid-template-columns:1fr}.portfolio-item{padding:22px 18px}.portfolio-icon{font-size:28px;margin-bottom:12px}.portfolio-title{font-size:20px;margin-bottom:10px}.portfolio-description{font-size:13px;margin-bottom:12px}.portfolio-highlight{font-size:10px;margin-bottom:14px;padding:6px 10px}.tech-tag{font-size:10px;padding:5px 10px}}@media (max-width:480px){.portfolio{padding:32px 0}.section-title{font-size:26px}.section-description{font-size:13px;margin-bottom:20px}.portfolio-item{padding:18px 16px}.portfolio-icon{font-size:24px;margin-bottom:10px}.portfolio-title{font-size:18px}.portfolio-description{font-size:12px}.portfolio-tech{gap:6px}.tech-tag{font-size:10px;padding:4px 8px}}.notification{animation:slideInRight .3s ease-out;border-radius:8px;box-shadow:0 4px 12px #00000026;max-width:500px;min-width:300px;overflow:hidden;position:fixed;right:20px;top:20px;z-index:10000}@keyframes slideInRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.notification-content{align-items:center;display:flex;gap:12px;padding:16px 20px}.notification-success{background-color:#4caf50;color:#fff}.notification-error{background-color:#f44336;color:#fff}.notification-icon{align-items:center;background-color:#fff3;border-radius:50%;display:flex;flex-shrink:0;font-size:20px;font-weight:700;height:24px;justify-content:center;width:24px}.notification-message{flex:1 1;font-size:14px;font-weight:500;line-height:1.5}.notification-close{align-items:center;background:none;border:none;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:24px;height:24px;justify-content:center;line-height:1;opacity:.8;padding:0;transition:opacity .2s ease;width:24px}.notification-close:hover{opacity:1}.notification-close:focus{border-radius:4px;outline:2px solid #ffffff80;outline-offset:2px}@media (max-width:768px){.notification{left:10px;max-width:none;min-width:auto;right:10px;top:10px}.notification-content{padding:14px 16px}.notification-message{font-size:13px}}.cnt-contact{align-items:center;background-color:var(--color-black);display:flex;min-height:100vh;overflow:hidden;padding:64px 0;position:relative}.cnt-contact:before{background:radial-gradient(ellipse at 20% 30%,#ffffff08 0,#0000 50%),radial-gradient(ellipse at 80% 70%,#ffffff05 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:0}.cnt-container{display:flex;flex-direction:column;justify-content:center;margin:0 auto;max-width:1200px;padding:0 24px;position:relative;width:100%;z-index:1}.cnt-header{opacity:0;transform:translateY(30px);transition:opacity .8s ease-out,transform .8s ease-out}.cnt-header.cnt-fade-in-up{opacity:1;transform:translateY(0)}.cnt-section-title{color:var(--color-white);font-size:38px;font-weight:600;letter-spacing:-.5px;line-height:1.07143;margin-bottom:13px;text-align:center}.cnt-section-description{color:var(--color-gray-400);font-size:15px;font-weight:400;letter-spacing:.011em;line-height:1.381;margin:0 auto 32px;max-width:640px;text-align:center}.cnt-content{grid-gap:48px;display:grid;gap:48px;grid-template-columns:1fr 1.5fr;margin-top:0}.cnt-info{opacity:0;transform:translateY(30px);transition:opacity .8s ease-out,transform .8s ease-out}.cnt-info.cnt-fade-in-up{animation:cntFadeInUp .6s ease-out forwards}.cnt-info h3{color:var(--color-white);font-size:26px;font-weight:600;letter-spacing:-.5px;margin-bottom:13px}.cnt-info-description{color:var(--color-gray-400);font-size:14px;font-weight:400;line-height:1.5;margin-bottom:26px}.cnt-info-items{display:flex;flex-direction:column;font-style:normal;gap:16px}.cnt-info-item{align-items:flex-start;background-color:#ffffff08;border:1px solid #ffffff14;border-radius:0;display:flex;gap:14px;opacity:0;padding:18px;transform:translateY(20px);transition:transform .3s ease,background-color .3s ease,border-color .3s ease}.cnt-info-item.cnt-fade-in-up{animation:cntFadeInUp .6s ease-out forwards}.cnt-info-item:hover{background-color:#ffffff0d;border-color:#fff3;transform:translateY(-3px)}.cnt-info-icon{flex-shrink:0;font-size:26px;transition:transform .3s ease}.cnt-info-item:hover .cnt-info-icon{transform:scale(1.1) rotate(5deg)}.cnt-info-content{flex:1 1}.cnt-info-content strong{color:var(--color-white);display:block;font-size:10px;font-weight:600;letter-spacing:.05em;margin-bottom:5px;text-transform:uppercase}.cnt-info-content a{color:var(--color-white);display:block;font-size:14px;font-style:normal;font-weight:400;text-decoration:none;transition:color .3s ease}.cnt-info-content a:hover{color:var(--color-gray-300);text-decoration:none}.cnt-info-content span{color:var(--color-white);display:block;font-size:14px;font-style:normal;font-weight:400}.cnt-form{display:flex;flex-direction:column;gap:18px;opacity:0;transform:translateY(30px);transition:opacity .8s ease-out,transform .8s ease-out}.cnt-form.cnt-fade-in-up{animation:cntFadeInUp .6s ease-out forwards}.cnt-form-group{margin-bottom:4px;position:relative;width:100%}.cnt-form-label{color:var(--color-white);display:block;font-size:12px;font-weight:600;letter-spacing:.01em;margin-bottom:8px}.cnt-form-label .cnt-required{color:var(--color-gray-400);margin-left:2px}.cnt-form-group input,.cnt-form-group textarea{background-color:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;color:var(--color-white);font-family:inherit;font-size:14px;font-weight:400;padding:13px 14px;transition:all .3s ease;width:100%}.cnt-form-group input:focus,.cnt-form-group textarea:focus{background-color:#ffffff14;border-color:var(--color-white);box-shadow:0 0 0 3px #ffffff1a;outline:none}.cnt-form-group input.cnt-error,.cnt-form-group textarea.cnt-error{background-color:#c54b4b14;border-color:#c54b4b;box-shadow:0 0 0 3px #c54b4b1a}.cnt-form-group input.cnt-error:focus,.cnt-form-group textarea.cnt-error:focus{border-color:#c54b4b;box-shadow:0 0 0 3px #c54b4b26}.cnt-form-group input.cnt-valid,.cnt-form-group textarea.cnt-valid{background-color:#4caf5014;border-color:#4caf50}.cnt-form-group input.cnt-valid:focus,.cnt-form-group textarea.cnt-valid:focus{border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a}.cnt-form-group input::placeholder,.cnt-form-group textarea::placeholder{color:var(--color-gray-500)}.cnt-form-group textarea{min-height:120px;resize:vertical}.cnt-error-message{animation:cntSlideDown .2s ease-out;color:#e57373;display:block;font-size:11px;font-weight:500;margin-top:6px}@keyframes cntSlideDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.cnt-textarea-footer{align-items:flex-start;display:flex;justify-content:space-between;margin-top:6px;min-height:18px}.cnt-character-count{color:var(--color-gray-500);font-size:11px;font-weight:500;margin-left:auto}.cnt-character-count.cnt-warning{color:#ffb74d}.cnt-character-count.cnt-warning:after{content:" (approaching limit)";font-size:10px}.cnt-submit-button{align-items:center;align-self:flex-start;background-color:var(--color-white);border:none;border-radius:0;color:var(--color-black);cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:6px;justify-content:center;min-width:160px;overflow:hidden;padding:11px 22px;position:relative;text-decoration:none;transition:all .3s ease}.cnt-submit-button:before{background:linear-gradient(90deg,#0000,#0000001a,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.cnt-submit-button:hover:before{left:100%}.cnt-submit-button:hover:not(:disabled){background-color:var(--color-gray-200);box-shadow:0 6px 20px #fff3;transform:translateY(-2px)}.cnt-submit-button:active:not(:disabled){transform:translateY(0)}.cnt-submit-button:disabled{cursor:not-allowed;opacity:.7;transform:none}.cnt-submit-button:disabled:before{display:none}.cnt-submit-button svg{flex-shrink:0;transition:transform .3s ease}.cnt-submit-button:hover:not(:disabled) svg{transform:translateX(3px)}.cnt-spinner{animation:cntSpin .6s linear infinite;border:2px solid #0a0a0a4d;border-radius:50%;border-top:2px solid var(--color-black);flex-shrink:0;height:14px;width:14px}@keyframes cntSpin{to{transform:rotate(1turn)}}@keyframes cntFadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (max-width:1068px){.cnt-contact{min-height:100vh;padding:48px 0}.cnt-section-title{font-size:36px}.cnt-section-description{font-size:15px;margin-bottom:32px}.cnt-content{gap:36px;grid-template-columns:1fr}.cnt-info h3{font-size:24px}.cnt-info-description{font-size:14px;margin-bottom:24px}.cnt-info-item{padding:16px}.cnt-info-icon{font-size:24px}}@media (max-width:768px){.cnt-contact{min-height:100vh;padding:48px 0}.cnt-container{padding:0 16px}.cnt-section-title{font-size:30px;margin-bottom:12px}.cnt-section-description{font-size:14px;margin-bottom:28px}.cnt-info h3{font-size:22px}.cnt-info-description{font-size:13px;margin-bottom:20px}.cnt-info-items{gap:14px}.cnt-info-item{font-size:13px;padding:14px}.cnt-info-icon{font-size:22px}.cnt-info-content a,.cnt-info-content span{font-size:13px}.cnt-form-label{font-size:10px;margin-bottom:6px}.cnt-form-group input,.cnt-form-group textarea{font-size:14px;padding:12px 14px}.cnt-error-message{font-size:10px;margin-top:5px}.cnt-character-count{font-size:10px}.cnt-submit-button{font-size:12px;min-width:auto;padding:14px 28px;width:100%}}@media (max-width:480px){.cnt-contact{padding:32px 0}.cnt-section-title{font-size:26px}.cnt-section-description{font-size:13px;margin-bottom:24px}.cnt-content{gap:28px}.cnt-info-item{align-items:center;flex-direction:column;gap:10px;padding:12px;text-align:center}.cnt-info-icon{font-size:24px}}.footer{background-color:var(--color-black);border-top:none;margin-top:0;padding:80px 0 24px;position:relative}.footer:before{background:radial-gradient(ellipse at 20% 20%,#ffffff08 0,#0000 40%),radial-gradient(ellipse at 80% 80%,#ffffff05 0,#0000 40%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:0}.footer-container{margin:0 auto;max-width:1200px;padding:0 24px;position:relative;z-index:1}.footer-content{grid-gap:48px;border-bottom:1px solid #ffffff14;display:grid;gap:48px;grid-template-columns:1.5fr repeat(3,1fr);margin-bottom:40px;opacity:0;padding-bottom:40px;transform:translateY(30px);transition:opacity .8s ease-out,transform .8s ease-out}.footer-content.fade-in-up{opacity:1;transform:translateY(0)}.footer-section{display:flex;flex-direction:column;opacity:0;transform:translateY(20px);transition:opacity .6s ease-out,transform .6s ease-out}.footer-section.fade-in-up{animation:fadeInUp .6s ease-out forwards}.footer-content.fade-in-up .footer-brand{opacity:1;transform:translateY(0)}.footer-brand{max-width:340px}.footer-section h3{font-size:18px;letter-spacing:-.01em;text-transform:none}.footer-section h3,.footer-section h4{color:var(--color-white);font-weight:600;margin-bottom:16px}.footer-section h4{font-size:11px;letter-spacing:.05em;opacity:.8;text-transform:uppercase}.footer-section p{color:var(--color-gray-400);font-size:13px;font-weight:400;letter-spacing:-.01em;line-height:1.6;margin:0 0 24px}.footer-social{display:flex;gap:12px;margin-top:8px}.social-link{align-items:center;background-color:#ffffff0d;border:1px solid #ffffff14;border-radius:0;display:flex;height:40px;justify-content:center;text-decoration:none;transition:all .3s ease;width:40px}.social-link:hover{background-color:var(--color-white);border-color:var(--color-white);transform:translateY(-3px)}.social-icon{font-size:18px;transition:transform .3s ease}.social-link:hover .social-icon{transform:scale(1.1)}.footer-section ul{list-style:none;margin:0;padding:0}.footer-section ul li{margin-bottom:12px}.footer-section ul li:last-child{margin-bottom:0}.footer-section ul li a{color:#fff9;display:inline-block;font-size:13px;font-weight:400;letter-spacing:-.01em;line-height:1.6;padding:2px 0;position:relative;text-decoration:none;transition:all .2s ease}.footer-section ul li a:hover{color:var(--color-white);transform:translateX(4px)}.footer-section ul li a:after{background-color:var(--color-white);bottom:0;content:"";height:1px;left:0;position:absolute;transition:width .2s ease;width:0}.footer-section ul li a:hover:after{width:100%}.footer-bottom{align-items:center;display:flex;flex-direction:column;gap:14px;justify-content:center;opacity:0;padding-top:24px;text-align:center;transform:translateY(20px);transition:opacity .6s ease-out,transform .6s ease-out}.footer-bottom.fade-in-up{animation:fadeInUp .6s ease-out forwards}.footer-bottom p{color:var(--color-gray-500);font-size:12px;font-weight:400;letter-spacing:-.01em;line-height:1.5;margin:0}.footer-legal{align-items:center;display:flex;font-size:11px;gap:16px}.footer-legal a{color:#ffffff80;text-decoration:none;transition:color .2s ease}.footer-legal a:hover{color:var(--color-white)}.footer-legal .separator{color:var(--color-gray-500);opacity:.4}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (max-width:1068px){.footer{padding:64px 0 20px}.footer-content{gap:40px;grid-template-columns:repeat(2,1fr)}.footer-brand{grid-column:1/-1;max-width:100%}.footer-section h3{font-size:22px}.footer-section p{font-size:13px}}@media (max-width:768px){.footer{padding:52px 0 20px}.footer-container{padding:0 16px}.footer-content{gap:32px;grid-template-columns:1fr;margin-bottom:32px;padding-bottom:32px}.footer-brand{grid-column:1}.footer-section h3{font-size:20px;margin-bottom:12px}.footer-section h4{font-size:10px;margin-bottom:14px}.footer-section p{font-size:13px;margin-bottom:20px}.footer-section ul li a{font-size:13px}.footer-section ul li{margin-bottom:10px}.footer-social{gap:10px}.social-link{height:36px;width:36px}.social-icon{font-size:16px}.footer-bottom{gap:12px;padding-top:20px}.footer-bottom p{font-size:11px}.footer-legal{font-size:10px;gap:12px}}@media (max-width:480px){.footer{padding:40px 0 16px}.footer-content{gap:28px;margin-bottom:28px;padding-bottom:28px}.footer-section h3{font-size:18px}.footer-section p,.footer-section ul li a{font-size:12px}.footer-bottom p{font-size:10px}.footer-legal{flex-direction:column;gap:8px}.footer-legal .separator{display:none}}.admin-login{align-items:center;background:linear-gradient(180deg,#f8f9fa,#fff);display:flex;justify-content:center;min-height:100vh;padding:40px 20px}.admin-login-container{max-width:440px;width:100%}.admin-login-card{background-color:#fff;border:1px solid #00000014;border-radius:18px;box-shadow:0 4px 24px #00000014;padding:48px 40px}.admin-login-header{margin-bottom:32px;text-align:center}.admin-login-header h1{color:#1d1d1f;font-size:32px;font-weight:600;letter-spacing:-.5px;margin-bottom:8px}.admin-login-header p{color:#86868b;font-size:17px;line-height:1.5}.admin-login-error{background-color:#fff5f5;border:1px solid #feb2b2;border-radius:8px;color:#c53030;font-size:14px;line-height:1.5;margin-bottom:24px;padding:12px 16px}.admin-login-form{display:flex;flex-direction:column;gap:24px}.admin-login-form .form-group{display:flex;flex-direction:column;gap:8px}.admin-login-form label{color:#1d1d1f;font-size:14px;font-weight:500}.admin-login-form input{background-color:#fff;border:1px solid #0003;border-radius:10px;color:#1d1d1f;font-family:inherit;font-size:17px;padding:14px 16px;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.admin-login-form input:focus{border-color:#0071e3;box-shadow:0 0 0 4px #0071e31a;outline:none}.admin-login-form input::placeholder{color:#86868b}.admin-login-button{background-color:#0071e3;border:none;border-radius:10px;color:#fff;cursor:pointer;font-family:inherit;font-size:17px;font-weight:500;margin-top:8px;padding:14px 24px;transition:background-color .2s ease,transform .1s ease;width:100%}.admin-login-button:hover:not(:disabled){background-color:#0077ed}.admin-login-button:active:not(:disabled){transform:scale(.98)}.admin-login-button:disabled{cursor:not-allowed;opacity:.6}.admin-login-footer{border-top:1px solid #00000014;margin-top:32px;padding-top:24px;text-align:center}.back-link{color:#0071e3;font-size:15px;text-decoration:none;transition:color .2s ease}.back-link:hover{color:#0077ed;text-decoration:underline}@media (max-width:768px){.admin-login{padding:20px 16px}.admin-login-card{padding:40px 32px}.admin-login-header h1{font-size:28px}.admin-login-header p{font-size:16px}}@media (max-width:480px){.admin-login-card{padding:32px 24px}.admin-login-header h1{font-size:24px}}.admin-navbar{backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);background-color:#fffc;border-bottom:1px solid #0000001a;height:44px;left:0;padding:0;position:fixed;right:0;top:0;transition:background-color .3s ease;z-index:1000}.admin-navbar.scrolled{background-color:#fffffff2}.admin-navbar-container{align-items:center;display:flex;height:100%;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 22px;position:relative}.admin-navbar-logo{color:#1d1d1f;display:inline-block;font-size:14px;font-weight:600;letter-spacing:-.01em;margin-right:auto}.admin-navbar-menu{align-items:center;display:flex;flex:1 1;gap:24px;justify-content:center}.admin-navbar-link{color:#1d1d1f;display:block;font-size:12px;font-weight:400;line-height:44px;padding:0 4px;position:relative;text-decoration:none;transition:color .3s ease}.admin-navbar-link:hover{color:#0071e3}.admin-navbar-link.active{color:#0071e3;font-weight:500}.admin-navbar-link:after{background-color:#0071e3;border-radius:2px 2px 0 0;bottom:0;content:"";height:2px;left:4px;margin:0 auto;position:absolute;right:4px;transition:width .3s ease;width:0}.admin-navbar-link.active:after,.admin-navbar-link:hover:after{width:calc(100% - 8px)}.admin-navbar-actions{align-items:center;display:flex;gap:12px}.admin-navbar-button{align-items:center;background-color:initial;border:1px solid #0000001a;border-radius:6px;color:#1d1d1f;cursor:pointer;display:flex;font-family:inherit;font-size:12px;font-weight:400;gap:6px;line-height:1.5;padding:6px 12px;transition:all .3s ease}.admin-navbar-button:hover:not(:disabled){background-color:#0071e30d;border-color:#0071e3;color:#0071e3}.admin-navbar-button:active:not(:disabled){transform:scale(.98)}.admin-navbar-button:disabled{cursor:not-allowed;opacity:.6}.admin-navbar-register{color:#1d1d1f}.admin-navbar-logout{border-color:#d32f2f33;color:#d32f2f}.admin-navbar-logout:hover:not(:disabled){background-color:#d32f2f0d;border-color:#d32f2f;color:#b71c1c}.admin-navbar-icon{align-items:center;display:flex;font-size:14px;justify-content:center}.admin-navbar-button-text{font-size:12px;font-weight:400}@media (max-width:768px){.admin-navbar-container{padding:0 16px}.admin-navbar-logo{font-size:13px}.admin-navbar-menu{gap:16px}.admin-navbar-link{font-size:11px}.admin-navbar-actions{gap:8px}.admin-navbar-button{gap:4px;padding:6px 10px}.admin-navbar-button-text{font-size:11px}.admin-navbar-icon{font-size:13px}}@media (max-width:480px){.admin-navbar-menu{gap:12px}.admin-navbar-link{font-size:10px}.admin-navbar-button-text{display:none}.admin-navbar-button{justify-content:center;min-width:36px;padding:6px 10px}}.traffic-overview-container{margin:0 auto 40px;max-width:1400px;padding:0 20px;width:100%}.traffic-overview-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:32px}.traffic-overview-header h2{color:#1d1d1f;font-size:32px;font-weight:600;letter-spacing:-.5px;margin:0}.duration-selector{align-items:center;display:flex;gap:12px}.duration-selector label{color:#1d1d1f;font-size:14px;font-weight:500;white-space:nowrap}.duration-selector .duration-select{background-color:#fff;border:1px solid #00000026;border-radius:8px;color:#1d1d1f;cursor:pointer;font-size:14px;padding:8px 12px;transition:border-color .2s ease}.duration-selector .duration-select:hover{border-color:#0071e3}.duration-selector .duration-select:focus{border-color:#0071e3;box-shadow:0 0 0 3px #0071e31a;outline:none}.traffic-overview-error,.traffic-overview-loading{color:#86868b;font-size:17px;padding:60px 20px;text-align:center}.traffic-overview-error{background-color:#fff5f5;border:1px solid #feb2b2;border-radius:10px;color:#d32f2f;padding:20px}.traffic-metrics-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.metric-card{align-items:flex-start;background-color:#fff;border:1px solid #00000014;border-radius:12px;box-shadow:0 2px 8px #0000000d;display:flex;gap:16px;padding:24px;transition:transform .2s ease,box-shadow .2s ease}.metric-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.metric-icon{flex-shrink:0;font-size:32px;line-height:1}.metric-content{flex:1 1;min-width:0}.metric-label{color:#86868b;font-size:13px;font-weight:500;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.metric-value{color:#1d1d1f;font-size:28px;font-weight:600;letter-spacing:-.5px;line-height:1.2;margin-bottom:4px}.metric-percentage{color:#86868b;font-size:13px;margin-top:4px}@media (max-width:1024px){.traffic-overview-container{padding:0 16px}.traffic-overview-header h2{font-size:28px}.traffic-metrics-grid{gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.metric-card{padding:20px}.metric-value{font-size:24px}}@media (max-width:768px){.traffic-overview-header{align-items:flex-start;flex-direction:column}.traffic-overview-header h2{font-size:24px}.traffic-metrics-grid{gap:12px;grid-template-columns:1fr}.metric-card{padding:16px}.metric-icon{font-size:28px}.metric-value{font-size:22px}}.activity-container{margin:0 auto;max-width:1400px;padding:0 20px;width:100%}.activity-header{margin-bottom:32px}.activity-header h2{color:#1d1d1f;font-size:32px;font-weight:600;letter-spacing:-.5px;margin-bottom:8px}.activity-header p{color:#86868b;font-size:17px;line-height:1.5}.activity-empty,.activity-error,.activity-loading{color:#86868b;font-size:17px;padding:60px 20px;text-align:center}.activity-error{background-color:#fff5f5;border:1px solid #feb2b2;border-radius:10px;color:#d32f2f;padding:20px}.activity-controls{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.mode-toggle{background-color:#f5f5f7;border-radius:10px;display:flex;gap:4px;padding:4px}.mode-button{background:#0000;border:none;border-radius:8px;color:#515154;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.mode-button:hover{background-color:#0000000d}.mode-button.active{background-color:#fff;box-shadow:0 2px 4px #0000001a;color:#0071e3}.refresh-button{align-items:center;background-color:#fff;border:1px solid #00000026;border-radius:8px;color:#1d1d1f;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:all .2s ease}.refresh-button:hover:not(:disabled){background-color:#f0f7ff;border-color:#0071e3;color:#0071e3}.refresh-button:disabled{cursor:not-allowed;opacity:.6}.refresh-icon{display:inline-block;font-size:16px;transition:transform .3s ease}.refresh-button:not(:disabled):hover .refresh-icon{transform:rotate(180deg)}.refresh-button:disabled .refresh-icon{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.time-plot-controls{align-items:center;display:flex;flex-wrap:wrap;gap:24px}.control-group{align-items:center;display:flex;gap:12px}.control-group label{color:#1d1d1f;font-size:14px;font-weight:500;white-space:nowrap}.duration-select{background-color:#fff;border:1px solid #00000026;border-radius:8px;color:#1d1d1f;cursor:pointer;font-size:14px;padding:8px 12px;transition:border-color .2s ease}.duration-select:hover{border-color:#0071e3}.duration-select:focus{border-color:#0071e3;box-shadow:0 0 0 3px #0071e31a;outline:none}.chart-type-buttons{display:flex;gap:8px}.chart-type-button{background-color:#fff;border:1px solid #00000026;border-radius:8px;color:#515154;cursor:pointer;font-size:13px;font-weight:500;padding:8px 16px;transition:all .2s ease}.chart-type-button:hover{border-color:#0071e3;color:#0071e3}.chart-type-button.active{background-color:#0071e3;border-color:#0071e3;color:#fff}.activity-row-view{width:100%}.activity-table-wrapper{background-color:#fff;border:1px solid #00000014;border-radius:12px;box-shadow:0 2px 8px #0000000d;margin-bottom:24px;overflow-x:auto}.activity-table{border-collapse:collapse;min-width:2000px;width:100%}.activity-table thead{background-color:#f5f5f7;border-bottom:2px solid #0000001a}.activity-table th{color:#1d1d1f;font-size:13px;font-weight:600;letter-spacing:.01em;padding:16px 12px;text-align:left;text-transform:uppercase;white-space:nowrap}.activity-table tbody tr{border-bottom:1px solid #0000000f;transition:background-color .2s ease}.activity-table tbody tr:hover{background-color:#f8f9fa}.activity-table tbody tr:last-child{border-bottom:none}.activity-table td{color:#1d1d1f;font-size:14px;padding:16px 12px;vertical-align:middle}.activity-id{color:#86868b;font-size:13px;font-weight:600;text-align:center;width:60px}.activity-ip{color:#515154;font-family:Courier New,monospace;font-size:13px}.activity-type-cell{min-width:120px}.activity-type-badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:500;padding:4px 10px;text-transform:capitalize;white-space:nowrap}.activity-type-badge.page_view{background-color:#e8f4f8;color:#0071e3}.activity-type-badge.contact_view{background-color:#e6ffed;color:#28a745}.activity-type-badge.unknown{background-color:#f5f5f7;color:#86868b}.activity-method{min-width:80px}.method-badge{border-radius:12px;display:inline-block;font-family:Courier New,monospace;font-size:12px;font-weight:500;padding:4px 10px;white-space:nowrap}.method-badge.GET{background-color:#e6ffed;color:#28a745}.method-badge.POST{background-color:#fff3cd;color:#856404}.method-badge.PUT{background-color:#cfe2ff;color:#084298}.method-badge.DELETE{background-color:#f8d7da;color:#721c24}.method-badge.unknown{background-color:#f5f5f7;color:#86868b}.activity-browser,.activity-device,.activity-os{color:#515154;font-size:13px;white-space:nowrap}.activity-endpoint,.activity-response-time{color:#515154;font-family:Courier New,monospace;font-size:13px;white-space:nowrap}.activity-endpoint{max-width:200px;overflow:hidden;text-overflow:ellipsis}.activity-date{color:#86868b;font-size:13px;min-width:180px;white-space:nowrap}.activity-user-agent{color:#515154;font-family:Courier New,monospace;font-size:12px;max-width:250px;min-width:200px}.truncate-text{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.activity-timezone{min-width:140px}.activity-location,.activity-timezone{color:#515154;font-size:13px;white-space:nowrap}.activity-location{max-width:220px;min-width:180px}.activity-coordinates{color:#515154;font-family:Courier New,monospace;font-size:12px;min-width:140px;white-space:nowrap}.coordinate-text{display:inline-block}.activity-request-body{color:#515154;font-family:Courier New,monospace;font-size:12px;max-width:200px;min-width:150px}.request-body-text{cursor:help;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.empty-value{color:#86868b;font-style:italic}.activity-count{color:#515154;font-size:13px;font-weight:500;min-width:80px;text-align:center}.activity-pagination{align-items:center;display:flex;gap:16px;justify-content:center;padding:20px}.pagination-button{background-color:#fff;border:1px solid #00000026;border-radius:8px;color:#1d1d1f;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.pagination-button:hover:not(:disabled){background-color:#f0f7ff;border-color:#0071e3;color:#0071e3}.pagination-button:disabled{cursor:not-allowed;opacity:.5}.pagination-info{color:#86868b;font-size:14px}.activity-time-plot-view{width:100%}.chart-container{background-color:#fff;border:1px solid #00000014;border-radius:12px;box-shadow:0 2px 8px #0000000d;margin-top:24px;padding:24px}@media (max-width:1024px){.activity-container{padding:0 16px}.activity-header h2{font-size:28px}.activity-controls,.time-plot-controls{align-items:stretch;flex-direction:column}.time-plot-controls{gap:16px}.control-group{align-items:stretch;flex-direction:column}.chart-type-buttons{width:100%}.chart-type-button{flex:1 1}.activity-table-wrapper{border-radius:10px}.activity-table td,.activity-table th{font-size:13px;padding:12px 8px}.activity-date{font-size:12px;min-width:150px}}@media (max-width:768px){.activity-header h2{font-size:24px}.activity-header p{font-size:15px}.activity-table{min-width:2000px}.chart-container{padding:16px}}.admin-profile{background:linear-gradient(180deg,#f8f9fa,#fff);min-height:100vh;padding:84px 20px 40px}.admin-profile-container{display:flex;flex-direction:column;gap:60px;margin:0 auto;max-width:1200px;width:100%}.admin-profile-header{padding:60px 20px;text-align:center}.admin-profile-header h1{color:#1d1d1f;font-size:48px;font-weight:600;letter-spacing:-.5px;margin-bottom:16px}.admin-profile-header p{color:#86868b;font-size:19px;line-height:1.5}@media (max-width:768px){.admin-profile{padding:20px 16px}.admin-profile-header{padding:40px 20px}.admin-profile-header h1{font-size:36px}.admin-profile-header p{font-size:17px}}.create-service-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:10000}.create-service-modal{animation:slideUp .3s ease-out;background-color:#fff;border-radius:18px;box-shadow:0 8px 32px #0003;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.create-service-modal-header{align-items:center;border-bottom:1px solid #00000014;display:flex;justify-content:space-between;padding:24px 28px}.create-service-modal-header h2{color:#1d1d1f;font-size:28px;font-weight:600;letter-spacing:-.5px;margin:0}.create-service-modal-close{align-items:center;background:none;border:none;border-radius:8px;color:#86868b;cursor:pointer;display:flex;justify-content:center;padding:8px;transition:background-color .2s ease,color .2s ease}.create-service-modal-close:hover:not(:disabled){background-color:#0000000d;color:#1d1d1f}.create-service-modal-close:disabled{cursor:not-allowed;opacity:.5}.create-service-form{display:flex;flex-direction:column;gap:24px;padding:28px}.create-service-error{background-color:#fff5f5;border:1px solid #feb2b2;border-radius:10px;color:#c53030;font-size:14px;line-height:1.5;padding:12px 16px}.form-group{gap:8px}.form-group label{font-size:14px}.form-group input,.form-group textarea{border-radius:10px;font-size:17px;padding:14px 16px}.form-group input:focus,.form-group textarea:focus{box-shadow:0 0 0 4px #0071e31a}.form-group textarea{min-height:100px}.form-hint{font-size:13px;margin-top:-4px}.tech-stack-input-wrapper{gap:8px}.add-tech-button{border-radius:10px;font-size:15px;padding:14px 20px}.tech-stack-tags{gap:8px;margin-top:4px}.tech-tag{font-size:13px;gap:6px;padding:6px 12px}.tech-tag-remove{font-size:18px;height:18px;width:18px}.create-service-form-actions{border-top:1px solid #00000014;display:flex;gap:12px;justify-content:flex-end;margin-top:8px;padding-top:8px}.cancel-button,.submit-button{border-radius:10px;font-size:15px;padding:12px 24px}.submit-button:hover:not(:disabled){box-shadow:0 4px 12px #0071e34d}@media (max-width:768px){.create-service-modal-overlay{padding:16px}.create-service-modal{border-radius:16px;max-height:95vh}.create-service-modal-header{padding:20px 24px}.create-service-modal-header h2{font-size:24px}.create-service-form{gap:20px;padding:24px}.tech-stack-input-wrapper{flex-direction:column}.add-tech-button{width:100%}.create-service-form-actions{flex-direction:column-reverse}.cancel-button,.submit-button{width:100%}}.delete-confirmation-overlay{align-items:center;animation:fadeIn .2s ease-out;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:10001}.delete-confirmation-modal{animation:slideUp .3s ease-out;background-color:#fff;border-radius:18px;box-shadow:0 8px 32px #0003;max-width:440px;overflow:hidden;width:100%}.delete-confirmation-icon{display:flex;justify-content:center;padding:32px 28px 0}.delete-confirmation-content{padding:24px 28px;text-align:center}.delete-confirmation-content h2{color:#1d1d1f;font-size:24px;font-weight:600;letter-spacing:-.5px;margin:0 0 12px}.delete-confirmation-content p{color:#515154;font-size:15px;line-height:1.5;margin:0}.delete-confirmation-content strong{color:#1d1d1f;font-weight:600}.delete-confirmation-actions{border-top:1px solid #00000014;display:flex;gap:12px;padding:20px 28px 28px}.delete-cancel-button{background-color:#fff;border:1px solid #0003;border-radius:10px;color:#1d1d1f;cursor:pointer;flex:1 1;font-size:15px;font-weight:500;padding:12px 24px;transition:all .2s ease}.delete-cancel-button:hover:not(:disabled){background-color:#f5f5f7;border-color:#0000004d}.delete-cancel-button:disabled{cursor:not-allowed;opacity:.5}.delete-confirm-button{background-color:#d32f2f;border:none;border-radius:10px;color:#fff;cursor:pointer;flex:1 1;font-size:15px;font-weight:500;padding:12px 24px;transition:all .2s ease}.delete-confirm-button:hover:not(:disabled){background-color:#c62828;box-shadow:0 4px 12px #d32f2f4d;transform:translateY(-1px)}.delete-confirm-button:active:not(:disabled){transform:translateY(0)}.delete-confirm-button:disabled{cursor:not-allowed;opacity:.6;transform:none}@media (max-width:768px){.delete-confirmation-overlay{padding:16px}.delete-confirmation-modal{border-radius:16px;max-width:100%}.delete-confirmation-content{padding:20px 24px}.delete-confirmation-content h2{font-size:22px}.delete-confirmation-content p{font-size:14px}.delete-confirmation-actions{flex-direction:column-reverse;padding:16px 24px 24px}.delete-cancel-button,.delete-confirm-button{width:100%}}.services-table-container{margin:0 auto;max-width:1400px;padding:0 20px;width:100%}.services-table-header{margin-bottom:32px}.services-table-header-content{align-items:flex-start;display:flex;gap:20px;justify-content:space-between}.services-table-header h2{color:#1d1d1f;font-size:32px;font-weight:600;letter-spacing:-.5px;margin-bottom:8px}.services-table-header p{color:#86868b;font-size:17px;line-height:1.5}.create-service-button{align-items:center;background-color:#0071e3;border:none;border-radius:10px;box-shadow:0 2px 8px #0071e333;color:#fff;cursor:pointer;display:flex;font-size:15px;font-weight:500;gap:8px;padding:12px 24px;transition:all .2s ease;white-space:nowrap}.create-service-button:hover{background-color:#0077ed;box-shadow:0 4px 12px #0071e34d;transform:translateY(-1px)}.create-service-button:active{box-shadow:0 2px 8px #0071e333;transform:translateY(0)}.create-service-button svg{height:16px;width:16px}.services-table-empty,.services-table-error,.services-table-loading{color:#86868b;font-size:17px;padding:60px 20px;text-align:center}.services-table-error{background-color:#fff5f5;border:1px solid #feb2b2;border-radius:10px;color:#d32f2f;padding:20px}.services-table-wrapper{background-color:#fff;border:1px solid #00000014;border-radius:12px;box-shadow:0 2px 8px #0000000d;overflow-x:auto}.services-table{border-collapse:collapse;min-width:1000px;width:100%}.services-table thead{background-color:#f5f5f7;border-bottom:2px solid #0000001a}.services-table th{color:#1d1d1f;font-size:13px;font-weight:600;letter-spacing:.01em;padding:16px 12px;text-align:left;text-transform:uppercase;white-space:nowrap}.services-table tbody tr{border-bottom:1px solid #0000000f;transition:background-color .2s ease}.services-table tbody tr:hover{background-color:#f8f9fa}.services-table tbody tr:last-child{border-bottom:none}.services-table td{color:#1d1d1f;font-size:14px;padding:16px 12px;vertical-align:top}.service-id{color:#86868b;font-size:13px;font-weight:600}.service-icon-cell,.service-id{text-align:center;width:60px}.service-icon-img{border-radius:6px;height:32px;object-fit:contain;width:32px}.service-icon-placeholder{background-color:#f5f5f7;border-radius:6px;display:flex;margin:0 auto}.service-icon-placeholder,.service-icon-text{align-items:center;font-size:20px;height:32px;justify-content:center;width:32px}.service-icon-text{display:inline-block;display:flex;line-height:1;text-align:center}.service-name{color:#1d1d1f;font-weight:600;min-width:150px}.table-service-description{max-width:300px}.table-service-description-text{-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;color:#515154;display:-webkit-box;line-height:1.5;overflow:hidden;text-overflow:ellipsis}.service-tech{min-width:200px}.tech-tag{border-radius:12px;font-size:12px;padding:4px 10px}.no-tech,.service-date{font-size:13px}.service-date{color:#86868b;min-width:140px;white-space:nowrap}.service-actions{white-space:nowrap;width:100px}.action-button{border-radius:6px;font-size:16px;padding:6px 8px}@media (max-width:1024px){.services-table-container{padding:0 16px}.services-table-header-content{align-items:stretch;flex-direction:column}.create-service-button{justify-content:center;width:100%}.services-table-header h2{font-size:28px}.services-table-wrapper{border-radius:10px}.services-table td,.services-table th{font-size:13px;padding:12px 8px}.table-service-description{max-width:250px}.table-service-description-text{-webkit-line-clamp:2;line-clamp:2}}@media (max-width:768px){.services-table-header h2{font-size:24px}.services-table-header p{font-size:15px}.services-table{min-width:800px}.table-service-description{max-width:200px}.service-date{font-size:12px;min-width:120px}}.create-profile-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:10000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.create-profile-modal{animation:slideUp .3s ease-out;background-color:#fff;border-radius:14px;box-shadow:0 6px 26px #0003;max-height:90vh;max-width:560px;overflow-y:auto;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.create-profile-modal-header{align-items:center;border-bottom:1px solid #00000014;display:flex;justify-content:space-between;padding:19px 22px}.create-profile-modal-header h2{color:#1d1d1f;font-size:22px;font-weight:600;letter-spacing:-.5px;margin:0}.create-profile-modal-close{align-items:center;background:none;border:none;border-radius:6px;color:#86868b;cursor:pointer;display:flex;justify-content:center;padding:6px;transition:background-color .2s ease,color .2s ease}.create-profile-modal-close:hover:not(:disabled){background-color:#0000000d;color:#1d1d1f}.create-profile-modal-close:disabled{cursor:not-allowed;opacity:.5}.create-profile-form{display:flex;flex-direction:column;gap:19px;padding:22px}.create-profile-error{background-color:#fff5f5;border:1px solid #feb2b2;border-radius:8px;color:#c53030;font-size:11px;line-height:1.5;padding:10px 13px}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{color:#1d1d1f;font-size:11px;font-weight:500}.form-group input,.form-group textarea{background-color:#fff;border:1px solid #0003;border-radius:8px;color:#1d1d1f;font-family:inherit;font-size:14px;padding:11px 13px;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#0071e3;box-shadow:0 0 0 3px #0071e31a;outline:none}.form-group input:disabled,.form-group textarea:disabled{background-color:#f5f5f7;cursor:not-allowed;opacity:.7}.form-group input::placeholder,.form-group textarea::placeholder{color:#86868b}.form-group textarea{font-family:inherit;min-height:80px;resize:vertical}.form-hint{color:#86868b;font-size:10px;margin-top:-3px}.progress-input-wrapper{display:flex;flex-direction:column;gap:10px}.progress-input{max-width:96px;width:100%}.progress-slider-wrapper{display:flex;flex-direction:column;gap:6px}.progress-slider{-webkit-appearance:none;appearance:none;background:#f5f5f7;border-radius:3px;height:6px;outline:none;width:100%}.progress-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#0071e3;border-radius:50%;box-shadow:0 2px 3px #0071e34d;cursor:pointer;height:16px;-webkit-transition:background .2s ease,transform .1s ease;transition:background .2s ease,transform .1s ease;width:16px}.progress-slider::-webkit-slider-thumb:hover{background:#0077ed;transform:scale(1.1)}.progress-slider::-moz-range-thumb{background:#0071e3;border:none;border-radius:50%;box-shadow:0 2px 3px #0071e34d;cursor:pointer;height:16px;-moz-transition:background .2s ease,transform .1s ease;transition:background .2s ease,transform .1s ease;width:16px}.progress-slider::-moz-range-thumb:hover{background:#0077ed;transform:scale(1.1)}.progress-slider:disabled{cursor:not-allowed;opacity:.5}.progress-preview{background-color:#f5f5f7;border-radius:10px;height:19px;overflow:hidden;position:relative;width:100%}.progress-preview-fill{background:linear-gradient(90deg,#0071e3,#0077ed);border-radius:10px;height:100%;left:0;position:absolute;top:0;transition:width .3s ease}.progress-preview-text{color:#1d1d1f;font-size:9px;font-weight:600;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);white-space:nowrap;z-index:1}.tech-stack-input-wrapper{display:flex;gap:6px}.tech-stack-input-wrapper input{flex:1 1}.add-tech-button{background-color:#fff;border:1px solid #0071e3;border-radius:8px;color:#0071e3;cursor:pointer;font-size:12px;font-weight:500;padding:11px 16px;transition:all .2s ease;white-space:nowrap}.add-tech-button:hover:not(:disabled){background-color:#0071e3;color:#fff}.add-tech-button:disabled{cursor:not-allowed;opacity:.5}.tech-stack-tags{gap:6px;margin-top:3px}.tech-tag{align-items:center;display:inline-flex;gap:5px;padding:5px 10px}.tech-tag-remove{align-items:center;background:none;border:none;border-radius:50%;color:#0071e3;cursor:pointer;display:flex;font-size:14px;height:14px;justify-content:center;line-height:1;margin:0;padding:0;transition:background-color .2s ease,color .2s ease;width:14px}.tech-tag-remove:hover:not(:disabled){background-color:#0071e333;color:#0051a3}.tech-tag-remove:disabled{cursor:not-allowed;opacity:.5}.create-profile-form-actions{border-top:1px solid #00000014;display:flex;gap:10px;justify-content:flex-end;margin-top:6px;padding-top:6px}.cancel-button{background-color:#fff;border:1px solid #0003;border-radius:8px;color:#1d1d1f;cursor:pointer;font-size:12px;font-weight:500;padding:10px 19px;transition:all .2s ease}.cancel-button:hover:not(:disabled){background-color:#f5f5f7;border-color:#0000004d}.cancel-button:disabled{cursor:not-allowed;opacity:.5}.submit-button{background-color:#0071e3;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:12px;font-weight:500;padding:10px 19px;transition:all .2s ease}.submit-button:hover:not(:disabled){background-color:#0077ed;box-shadow:0 3px 10px #0071e34d;transform:translateY(-1px)}.submit-button:active:not(:disabled){transform:translateY(0)}.submit-button:disabled{cursor:not-allowed;opacity:.6;transform:none}@media (max-width:768px){.create-profile-modal-overlay{padding:13px}.create-profile-modal{border-radius:13px;max-height:95vh;max-width:100%}.create-profile-modal-header{padding:16px 19px}.create-profile-modal-header h2{font-size:19px}.create-profile-form{gap:16px;padding:19px}.form-row{gap:16px;grid-template-columns:1fr}.tech-stack-input-wrapper{flex-direction:column}.add-tech-button{width:100%}.create-profile-form-actions{flex-direction:column-reverse}.cancel-button,.submit-button{width:100%}}.profile-table-container{margin:0 auto;max-width:1400px;padding:0 20px;width:100%}.profile-table-header{margin-bottom:26px}.profile-table-header-content{align-items:flex-start;display:flex;gap:16px;justify-content:space-between}.profile-table-header h2{color:#1d1d1f;font-size:26px;font-weight:600;letter-spacing:-.5px;margin-bottom:6px}.profile-table-header p{color:#86868b;font-size:14px;line-height:1.5}.create-profile-button{align-items:center;background-color:#0071e3;border:none;border-radius:8px;box-shadow:0 2px 6px #0071e333;color:#fff;cursor:pointer;display:flex;font-size:12px;font-weight:500;gap:6px;padding:10px 19px;transition:all .2s ease;white-space:nowrap}.create-profile-button:hover{background-color:#0077ed;box-shadow:0 3px 10px #0071e34d;transform:translateY(-1px)}.create-profile-button:active{box-shadow:0 2px 6px #0071e333;transform:translateY(0)}.create-profile-button svg{height:13px;width:13px}.profile-table-empty,.profile-table-error,.profile-table-loading{color:#86868b;font-size:14px;padding:48px 16px;text-align:center}.profile-table-error{background-color:#fff5f5;border:1px solid #feb2b2;border-radius:8px;color:#d32f2f;padding:16px}.profile-table-wrapper{background-color:#fff;border:1px solid #00000014;border-radius:10px;box-shadow:0 2px 6px #0000000d;overflow-x:auto}.profile-table{border-collapse:collapse;min-width:960px;width:100%}.profile-table thead{background-color:#f5f5f7;border-bottom:2px solid #0000001a}.profile-table th{color:#1d1d1f;font-size:10px;font-weight:600;letter-spacing:.01em;padding:13px 10px;text-align:left;text-transform:uppercase;white-space:nowrap}.profile-table tbody tr{border-bottom:1px solid #0000000f;transition:background-color .2s ease}.profile-table tbody tr:hover{background-color:#f8f9fa}.profile-table tbody tr:last-child{border-bottom:none}.profile-table td{color:#1d1d1f;font-size:11px;padding:13px 10px;vertical-align:top}.profile-id{color:#86868b;font-size:10px;font-weight:600}.profile-icon-cell,.profile-id{text-align:center;width:48px}.profile-icon-img{border-radius:5px;height:26px;object-fit:contain;width:26px}.profile-icon-placeholder{background-color:#f5f5f7;border-radius:5px;display:flex;margin:0 auto}.profile-icon-placeholder,.profile-icon-text{align-items:center;font-size:16px;height:26px;justify-content:center;width:26px}.profile-icon-text{display:inline-block;display:flex;line-height:1;text-align:center}.profile-title{color:#1d1d1f;font-weight:600;min-width:144px}.profile-work-type{color:#515154;font-size:10px;min-width:112px}.profile-description{max-width:240px}.profile-description-text{-webkit-line-clamp:3;-webkit-box-orient:vertical;line-clamp:3;color:#515154;display:-webkit-box;line-height:1.5;overflow:hidden;text-overflow:ellipsis}.profile-progress{min-width:96px}.progress-bar-container{background-color:#f5f5f7;border-radius:10px;height:19px;overflow:hidden;position:relative;width:80px}.progress-bar-fill{background:linear-gradient(90deg,#0071e3,#0077ed);border-radius:10px;height:100%;left:0;position:absolute;top:0;transition:width .3s ease}.progress-text{color:#1d1d1f;font-size:9px;font-weight:600;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);white-space:nowrap;z-index:1}.profile-progress-note{color:#515154;font-size:10px;font-style:italic;min-width:120px}.profile-tech{min-width:160px}.tech-stack-tags{display:flex;flex-wrap:wrap;gap:5px}.tech-tag{background-color:#e8f4f8;border-radius:10px;color:#0071e3;display:inline-block;font-size:10px;font-weight:500;padding:3px 8px;white-space:nowrap}.no-tech{color:#86868b;font-size:10px;font-style:italic}.profile-status{min-width:80px}.status-badge{border-radius:10px;display:inline-block;font-size:10px;font-weight:600;letter-spacing:.5px;padding:3px 10px;text-transform:uppercase}.status-badge.active{background-color:#e8f5e9;color:#2e7d32}.status-badge.inactive{background-color:#ffebee;color:#c62828}.profile-date{color:#86868b;font-size:10px;min-width:112px;white-space:nowrap}.profile-actions{white-space:nowrap;width:80px}.action-button{align-items:center;background:none;border:none;border-radius:5px;cursor:pointer;display:inline-flex;font-size:13px;justify-content:center;margin:0 2px;padding:5px 6px;transition:background-color .2s ease,transform .1s ease}.action-button:hover{background-color:#0000000d;transform:scale(1.1)}.action-button:active{transform:scale(.95)}.edit-button:hover{background-color:#0071e31a}.delete-button:hover{background-color:#d32f2f1a}@media (max-width:1024px){.profile-table-container{padding:0 16px}.profile-table-header-content{align-items:stretch;flex-direction:column}.create-profile-button{justify-content:center;width:100%}.profile-table-header h2{font-size:22px}.profile-table-wrapper{border-radius:8px}.profile-table{min-width:800px}.profile-table td,.profile-table th{font-size:10px;padding:10px 6px}.profile-description{max-width:200px}.profile-description-text{-webkit-line-clamp:2;line-clamp:2}}@media (max-width:768px){.profile-table-header h2{font-size:19px}.profile-table-header p{font-size:12px}.profile-table{min-width:720px}.profile-description{max-width:160px}.profile-date{font-size:10px;min-width:96px}}.prv-page{background-color:var(--color-white);display:flex;flex-direction:column;min-height:100vh}.prv-page section{padding:16px 0}.prv-page section:first-of-type{padding-top:0}.prv-page section:last-of-type{padding-bottom:0}.prv-hero{background:linear-gradient(180deg,var(--color-off-white) 0,var(--color-white) 100%);opacity:0;padding:80px 24px 32px;text-align:center;transform:translateY(20px);transition:opacity .6s ease-out,transform .6s ease-out}.prv-hero.prv-visible{opacity:1;transform:translateY(0)}.prv-hero-container{margin:0 auto;max-width:1200px}.prv-hero-title{color:var(--color-black);font-size:42px;font-weight:600;letter-spacing:-.03em;line-height:1.1;margin-bottom:12px}.prv-hero-description{color:var(--color-gray-500);font-size:15px;font-weight:400;line-height:1.5;margin-bottom:10px;margin-left:auto;margin-right:auto;max-width:580px}.prv-effective-date{color:var(--color-gray-400);font-size:11px;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.prv-logo-container{align-items:center;display:flex;justify-content:center;margin-top:20px}.prv-logo-image{animation:prvLogoRotate 30s linear infinite;height:120px;object-fit:contain;width:120px}@keyframes prvLogoRotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (prefers-reduced-motion:reduce){.prv-logo-image{animation:none}}.prv-content{flex:1 1;padding:32px 24px 48px}.prv-content-container{margin:0 auto;max-width:1200px}.prv-section{margin-bottom:0;opacity:0;transform:translateY(20px);transition:opacity .5s ease-out,transform .5s ease-out}.prv-section.prv-visible{opacity:1;transform:translateY(0)}.prv-intro{border-bottom:1px solid var(--color-gray-200);margin-bottom:28px;padding-bottom:24px}.prv-intro p{color:var(--color-gray-600);font-size:14px;font-weight:400;line-height:1.6;margin-bottom:12px}.prv-intro p:last-child{margin-bottom:0}.prv-sections-grid{display:flex;flex-direction:column;gap:24px}.prv-section-title{align-items:baseline;border-bottom:1px solid var(--color-gray-200);color:var(--color-black);display:flex;font-size:18px;font-weight:600;gap:10px;letter-spacing:-.02em;margin-bottom:14px;padding-bottom:8px}.prv-section-number{color:var(--color-gray-400);font-size:11px;font-weight:500;letter-spacing:.05em}.prv-section-content{display:flex;flex-direction:column;gap:14px}.prv-content-block{padding-left:0}.prv-content-subtitle{color:var(--color-black);font-size:13px;font-weight:600;letter-spacing:-.01em;margin-bottom:4px}.prv-content-text{color:var(--color-gray-500);font-size:13px;font-weight:400;line-height:1.6;margin:0}@media (max-width:1068px){.prv-hero{padding:72px 24px 28px}.prv-hero-title{font-size:38px}.prv-hero-description{font-size:14px}.prv-content{padding:28px 24px 40px}.prv-sections-grid{gap:22px}.prv-section-title{font-size:17px}}@media (max-width:768px){.prv-hero{padding:64px 16px 24px}.prv-hero-title{font-size:30px;margin-bottom:10px}.prv-hero-description{font-size:13px}.prv-effective-date{font-size:10px}.prv-logo-container{margin-top:16px}.prv-logo-image{height:80px;width:80px}.prv-content{padding:24px 16px 36px}.prv-sections-grid{gap:20px}.prv-intro{margin-bottom:24px;padding-bottom:20px}.prv-intro p{font-size:13px}.prv-section-title{font-size:16px;gap:8px;margin-bottom:12px}.prv-section-number{font-size:10px}.prv-section-content{gap:12px}.prv-content-subtitle,.prv-content-text{font-size:12px}}@media (max-width:480px){.prv-hero{padding:56px 16px 20px}.prv-hero-title{font-size:26px}.prv-hero-description{font-size:12px}.prv-logo-container{margin-top:14px}.prv-logo-image{height:64px;width:64px}.prv-sections-grid{gap:18px}.prv-section-title{align-items:flex-start;flex-direction:column;font-size:15px;gap:2px}.prv-section-content{gap:10px}.prv-content-subtitle{font-size:12px}.prv-content-text{font-size:11px;line-height:1.5}}.tos-page{background-color:var(--color-white);display:flex;flex-direction:column;min-height:100vh}.tos-page section{padding:16px 0}.tos-page section:first-of-type{padding-top:0}.tos-page section:last-of-type{padding-bottom:0}.tos-hero{background:linear-gradient(180deg,var(--color-off-white) 0,var(--color-white) 100%);opacity:0;padding:80px 24px 32px;text-align:center;transform:translateY(20px);transition:opacity .6s ease-out,transform .6s ease-out}.tos-hero.tos-visible{opacity:1;transform:translateY(0)}.tos-hero-container{margin:0 auto;max-width:1200px}.tos-hero-title{color:var(--color-black);font-size:42px;font-weight:600;letter-spacing:-.03em;line-height:1.1;margin-bottom:12px}.tos-hero-description{color:var(--color-gray-500);font-size:15px;font-weight:400;line-height:1.5;margin-bottom:10px;margin-left:auto;margin-right:auto;max-width:580px}.tos-effective-date{color:var(--color-gray-400);font-size:11px;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.tos-logo-container{align-items:center;display:flex;justify-content:center;margin-top:20px}.tos-logo-image{animation:tosLogoRotate 30s linear infinite;height:120px;object-fit:contain;width:120px}@keyframes tosLogoRotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (prefers-reduced-motion:reduce){.tos-logo-image{animation:none}}.tos-content{flex:1 1;padding:32px 24px 48px}.tos-content-container{margin:0 auto;max-width:1200px}.tos-section{margin-bottom:0;opacity:0;transform:translateY(20px);transition:opacity .5s ease-out,transform .5s ease-out}.tos-section.tos-visible{opacity:1;transform:translateY(0)}.tos-intro{border-bottom:1px solid var(--color-gray-200);margin-bottom:28px;padding-bottom:24px}.tos-intro p{color:var(--color-gray-600);font-size:14px;font-weight:400;line-height:1.6;margin-bottom:12px}.tos-intro p:last-child{margin-bottom:0}.tos-sections-grid{display:flex;flex-direction:column;gap:24px}.tos-section-title{align-items:baseline;border-bottom:1px solid var(--color-gray-200);color:var(--color-black);display:flex;font-size:18px;font-weight:600;gap:10px;letter-spacing:-.02em;margin-bottom:14px;padding-bottom:8px}.tos-section-number{color:var(--color-gray-400);font-size:11px;font-weight:500;letter-spacing:.05em}.tos-section-content{display:flex;flex-direction:column;gap:14px}.tos-content-block{padding-left:0}.tos-content-subtitle{color:var(--color-black);font-size:13px;font-weight:600;letter-spacing:-.01em;margin-bottom:4px}.tos-content-text{color:var(--color-gray-500);font-size:13px;font-weight:400;line-height:1.6;margin:0}@media (max-width:1068px){.tos-hero{padding:72px 24px 28px}.tos-hero-title{font-size:38px}.tos-hero-description{font-size:14px}.tos-content{padding:28px 24px 40px}.tos-sections-grid{gap:22px}.tos-section-title{font-size:17px}}@media (max-width:768px){.tos-hero{padding:64px 16px 24px}.tos-hero-title{font-size:30px;margin-bottom:10px}.tos-hero-description{font-size:13px}.tos-effective-date{font-size:10px}.tos-logo-container{margin-top:16px}.tos-logo-image{height:80px;width:80px}.tos-content{padding:24px 16px 36px}.tos-sections-grid{gap:20px}.tos-intro{margin-bottom:24px;padding-bottom:20px}.tos-intro p{font-size:13px}.tos-section-title{font-size:16px;gap:8px;margin-bottom:12px}.tos-section-number{font-size:10px}.tos-section-content{gap:12px}.tos-content-subtitle,.tos-content-text{font-size:12px}}@media (max-width:480px){.tos-hero{padding:56px 16px 20px}.tos-hero-title{font-size:26px}.tos-hero-description{font-size:12px}.tos-logo-container{margin-top:14px}.tos-logo-image{height:64px;width:64px}.tos-sections-grid{gap:18px}.tos-section-title{align-items:flex-start;flex-direction:column;font-size:15px;gap:2px}.tos-section-content{gap:10px}.tos-content-subtitle{font-size:12px}.tos-content-text{font-size:11px;line-height:1.5}}.cookie-consent-overlay{align-items:flex-end;animation:slideUpFadeIn .4s ease-out;bottom:0;display:flex;justify-content:flex-end;padding:20px;pointer-events:none;position:fixed;right:0;z-index:10000}@keyframes slideUpFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.cookie-consent-container{backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);background-color:#fff;border:1px solid #0000001a;border-radius:12px;box-shadow:0 8px 32px #0000001f;max-width:500px;padding:24px;pointer-events:auto;position:relative;width:100%}.cookie-consent-close{align-items:center;background:none;border:none;border-radius:6px;color:#86868b;cursor:pointer;display:flex;height:32px;justify-content:center;padding:8px;position:absolute;right:16px;top:16px;transition:color .2s ease,background-color .2s ease;width:32px}.cookie-consent-close:hover{background-color:#0000000d;color:#1d1d1f}.cookie-consent-close:active{background-color:#0000001a}.cookie-consent-content{margin-bottom:20px;padding-right:32px}.cookie-consent-title{color:#1d1d1f;font-size:20px;font-weight:600;letter-spacing:-.3px;line-height:1.3;margin:0 0 12px}.cookie-consent-text{color:#86868b;font-size:14px;line-height:1.5;margin:0;text-align:justify}.cookie-consent-actions{display:flex;flex-direction:column;gap:10px}.cookie-consent-button{border:1px solid #0000;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;letter-spacing:-.1px;padding:12px 24px;text-align:center;transition:all .2s ease;width:100%}.cookie-consent-button-accept{background-color:#0071e3;border-color:#0071e3;color:#fff}.cookie-consent-button-accept:hover{background-color:#0077ed;border-color:#0077ed;box-shadow:0 4px 12px #0071e34d;transform:translateY(-1px)}.cookie-consent-button-accept:active{box-shadow:0 2px 6px #0071e333;transform:translateY(0)}.cookie-consent-button-deny{background-color:#fff;border-color:#00000026;color:#1d1d1f}.cookie-consent-button-deny:hover{background-color:#f5f5f7;border-color:#0003;box-shadow:0 2px 8px #00000014;transform:translateY(-1px)}.cookie-consent-button-deny:active{box-shadow:0 1px 4px #0000000d;transform:translateY(0)}.cookie-consent-button:disabled{cursor:not-allowed;opacity:.6;transform:none!important}.cookie-consent-button:disabled:hover{box-shadow:none!important;transform:none!important}@media (max-width:768px){.cookie-consent-overlay{padding:16px}.cookie-consent-container{max-width:100%;padding:20px}.cookie-consent-title{font-size:18px;margin-bottom:10px}.cookie-consent-text{font-size:13px}.cookie-consent-button{font-size:13px;padding:11px 20px}.cookie-consent-close{height:28px;padding:6px;right:12px;top:12px;width:28px}}@media (max-width:480px){.cookie-consent-overlay{padding:12px}.cookie-consent-container{border-radius:10px;padding:18px}.cookie-consent-content{margin-bottom:16px;padding-right:28px}.cookie-consent-title{font-size:17px}.cookie-consent-text{font-size:12px;line-height:1.4}}
/*# sourceMappingURL=main.9626e560.css.map*/