:root{--color-void:#060708;--color-page:#0b0d12;--color-surface:#12151c;--color-surface-up:#181c26;--color-border-subtle:#ffffff0f;--color-border-strong:#ffffff1f;--color-mint:#5eead4;--color-sky:#7dd3fc;--color-violet:#a78bfa;--color-warm:#fcd34d;--color-pale-sky:#1e2836;--color-frosted-blue:#243044;--color-baby-blue-ice:var(--color-sky);--color-glaucous:#64748b;--color-charcoal:#0f1218;--color-teal:var(--color-mint);--color-turquoise:#2dd4bf;--color-mint-blue:#5eead4;--color-aqua:var(--color-sky);--color-cyan-green:var(--color-mint);--color-primary:var(--color-sky);--color-primary-dark:#94a3b8;--color-primary-light:#bae6fd;--color-accent:var(--color-mint);--color-accent-hover:var(--color-turquoise);--color-bg-primary:var(--color-surface-up);--color-bg-secondary:var(--color-surface);--color-bg-light:var(--color-surface);--color-bg-dark:var(--color-page);--color-text-primary:#e8eaef;--color-text-secondary:#949aa8;--color-text-light:#6b7280;--color-text-dark:#cbd5e1;--color-text-on-dark:#f1f5f9;--color-border:var(--color-border-strong);--color-border-light:var(--color-border-subtle);--color-border-dark:#ffffff2e;--color-success:#34d399;--color-error:#f87171;--color-warning:#fbbf24;--color-info:var(--color-sky);--gradient-primary:linear-gradient(135deg,var(--color-sky) 0%,var(--color-violet) 100%);--gradient-accent:linear-gradient(135deg,var(--color-mint) 0%,var(--color-sky) 100%);--gradient-hero:linear-gradient(145deg,#0b0d12,#121a24 40%,#0d1520);--gradient-subtle:linear-gradient(135deg,#7dd3fc1f,#5eead414);--shadow-glow:0 0 80px #5eead40f;--radius-sm:10px;--radius-md:16px;--radius-lg:24px;--font-display:"Manrope",system-ui,sans-serif;--font-body:"Outfit",system-ui,sans-serif;--font-logo:"Unbounded",system-ui,sans-serif;--font-hero:"Fraunces",Georgia,"Times New Roman",serif}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-50px)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(50px)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}@keyframes gradientShift{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.animate-fade-in-up{animation:fadeInUp .6s ease-out forwards}.animate-fade-in{animation:fadeIn .8s ease-out forwards}.animate-slide-in-left{animation:slideInLeft .6s ease-out forwards}.animate-slide-in-right{animation:slideInRight .6s ease-out forwards}.animate-scale-in{animation:scaleIn .5s ease-out forwards}.animate-float{animation:float 3s ease-in-out infinite}.fade-in-on-scroll{opacity:0;transform:translateY(30px);transition:opacity .6s ease-out,transform .6s ease-out}.fade-in-on-scroll.visible{opacity:1;transform:translateY(0)}@media (prefers-reduced-motion:reduce){.fade-in-on-scroll{opacity:1;transform:none;transition:none}}.stagger-1{animation-delay:.1s}.stagger-2{animation-delay:.2s}.stagger-3{animation-delay:.3s}.stagger-4{animation-delay:.4s}.stagger-5{animation-delay:.5s}.hover-lift{transition:transform .3s ease,box-shadow .3s ease}.hover-lift:hover{box-shadow:0 12px 24px #89bbfe4d;transform:translateY(-8px)}.hover-glow{transition:box-shadow .3s ease}.hover-glow:hover{box-shadow:0 0 20px #4ecdc480}.spinner{animation:rotate 1s linear infinite;border-top:3px solid var(--color-border-light);border:3px solid var(--color-border-light);border-radius:50%;border-top-color:var(--color-primary);height:40px;margin:0 auto;width:40px}.animated-gradient{animation:gradientShift 5s ease infinite;background-size:200% 200%}*{transition:color .3s ease,background-color .3s ease,border-color .3s ease}.page-enter{opacity:0;transform:translateY(20px)}.page-enter-active{opacity:1;transform:translateY(0);transition:opacity .4s ease,transform .4s ease}.container{width:100%}@media (max-width:968px){.container{padding:0 1.5rem}}@media (max-width:768px){.container{padding:0 1.5rem}}@media (max-width:480px){.container{padding:0 1rem}}body,html{max-width:100vw;overflow-x:hidden;width:100%}@media (max-width:768px){.btn,a.btn,button{-webkit-tap-highlight-color:rgba(137,187,254,.2);tap-highlight-color:#89bbfe33;min-height:44px;min-width:44px}.portfolio-card:hover,.service-card:hover{transform:none}.portfolio-card:hover .portfolio-card-image img{transform:scale(1.05)}body{font-size:16px;line-height:1.6}h1{font-size:2rem;line-height:1.2}h2{font-size:1.5rem;line-height:1.3}h3{font-size:1.25rem;line-height:1.4}}@media (prefers-reduced-motion:no-preference){html{scroll-behavior:smooth}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}body{background-color:var(--color-page);margin:0}.navigation{animation:fadeInDown .6s ease-out;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);background:#0b0d12c7;border-bottom:1px solid var(--color-border-light);box-shadow:0 1px 0 var(--color-border-subtle);position:-webkit-sticky;position:sticky;top:0;transition:all .3s ease;z-index:1000}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.nav-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:1rem 2rem}.nav-logo{color:var(--color-text-primary);font-family:var(--font-logo);font-size:1.35rem;font-weight:700;letter-spacing:-.02em;text-decoration:none;transition:color .3s ease}.nav-logo:hover{color:var(--color-primary)}.logo-text{-webkit-text-fill-color:#0000;background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text}.nav-menu{display:flex;gap:2rem;list-style:none;margin:0;padding:0}.nav-link{color:var(--color-text-primary);font-weight:500;padding:.5rem 0;position:relative;text-decoration:none;transition:all .3s ease}.nav-link:before{background:var(--gradient-accent);bottom:0;content:"";height:2px;left:50%;position:absolute;transform:translateX(-50%) scaleX(0);transition:transform .3s ease;width:100%}.nav-link.active:before,.nav-link:hover:before{transform:translateX(-50%) scaleX(1)}.nav-link:hover{transform:translateY(-2px)}.nav-link.active,.nav-link:hover{color:var(--color-primary)}.nav-link.active:after{background:var(--gradient-accent);bottom:-5px;content:"";height:2px;left:0;position:absolute;right:0}@media (max-width:968px){.nav-container{padding:1rem 1.5rem}.nav-menu{gap:1.5rem}}@media (max-width:768px){.nav-container{flex-direction:column;gap:1rem;padding:1rem}.nav-logo{font-size:1.3rem}.nav-menu{flex-wrap:wrap;gap:1rem;justify-content:center;width:100%}.nav-link{font-size:.95rem;padding:.4rem 0}}@media (max-width:480px){.nav-container{padding:.75rem}.nav-logo{font-size:1.2rem}.nav-menu{font-size:.9rem;gap:.75rem}}.footer{background:linear-gradient(165deg,var(--color-void) 0,#12151c 50%,#0d1118 100%);border-top:1px solid var(--color-border-light);color:var(--color-text-on-dark);margin-top:0;overflow:hidden;position:relative}.footer:before{animation:float 10s ease-in-out infinite;background:radial-gradient(circle at 20% 30%,#4ecdc41a 0,#0000 50%),radial-gradient(circle at 80% 70%,#89bbfe1a 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.footer-container{margin:0 auto;max-width:1200px;padding:3rem 2rem 1rem;position:relative;z-index:1}.footer-content{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.footer-section h3{color:var(--color-mint);font-family:var(--font-display);font-size:1.15rem;font-weight:600;letter-spacing:-.02em;margin-bottom:1rem}.footer-section p{color:var(--color-text-light);line-height:1.6}.footer-section ul{list-style:none;padding:0}.footer-section ul li{color:var(--color-text-light);margin-bottom:.5rem}.footer-cta{background:var(--gradient-accent);border-radius:5px;color:var(--color-void);display:inline-block;font-weight:600;margin-top:1rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s ease}.footer-cta:hover{box-shadow:0 4px 12px #4ecdc466;transform:translateY(-2px)}.footer-bottom{border-top:1px solid var(--color-glaucous);color:var(--color-text-light);padding-top:1.5rem;text-align:center}@media (max-width:968px){.footer-content{gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width:768px){.footer-container{padding:2rem 1.5rem 1rem}.footer-content{gap:2rem;grid-template-columns:1fr;margin-bottom:1.5rem}.footer-section h3{font-size:1.2rem}.footer-cta{font-size:.9rem;padding:.65rem 1.25rem}}@media (max-width:480px){.footer-container{padding:1.5rem 1rem 1rem}.footer-content{gap:1.5rem}.footer-section{text-align:center}}.portfolio-card{background:var(--color-surface-up);border:1px solid var(--color-border-light);border-radius:var(--radius-md);box-shadow:var(--shadow-glow);display:flex;flex-direction:column;height:100%;overflow:hidden;position:relative;transition:all .4s cubic-bezier(.175,.885,.32,1.275)}.portfolio-card:after{background:linear-gradient(135deg,#4ecdc40d,#89bbfe0d);bottom:0;content:"";left:0;opacity:0;pointer-events:none;position:absolute;right:0;top:0;transition:opacity .4s ease}.portfolio-card:hover:after{opacity:1}.portfolio-card:hover{border-color:#5eead44d;box-shadow:0 24px 48px #0006,0 0 0 1px #7dd3fc26;transform:translateY(-8px)}.portfolio-card-image{background:var(--color-surface);height:220px;overflow:hidden;position:relative;width:100%}.portfolio-card-image:before{background:linear-gradient(180deg,#0000 0,#6f8ab71a);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .4s ease;z-index:1}.portfolio-card:hover .portfolio-card-image:before{opacity:1}.portfolio-card-image img{height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.175,.885,.32,1.275);width:100%}.portfolio-card-video-thumb{color:inherit;display:block;height:100%;position:relative;text-decoration:none;width:100%}.portfolio-card-video-thumb img{object-fit:cover}.portfolio-card-play-label{align-items:center;background:#00000040;color:#fffffff2;display:flex;font-size:3rem;inset:0;justify-content:center;position:absolute;text-shadow:0 2px 12px #00000080;transition:background .3s ease,transform .3s ease}.portfolio-card:hover .portfolio-card-play-label{background:#0006;transform:scale(1.06)}.portfolio-card-video-cta{align-items:center;background:var(--gradient-primary);color:var(--color-void);display:flex;font-size:1.1rem;font-weight:700;height:100%;justify-content:center;text-decoration:none;transition:filter .3s ease,transform .3s ease;width:100%}.portfolio-card-video-cta:hover{filter:brightness(1.08);transform:scale(1.02)}.portfolio-card:hover .portfolio-card-image img{transform:scale(1.15) rotate(1deg)}.portfolio-card-content{display:flex;flex-direction:column;flex-grow:1;padding:1.5rem}.portfolio-card-category{background:var(--gradient-subtle);border-radius:25px;box-shadow:0 2px 8px #89bbfe33;color:var(--color-primary-dark);display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.5px;margin-bottom:.75rem;padding:.35rem 1rem;text-transform:uppercase;transition:all .3s ease;width:-webkit-fit-content;width:fit-content}.portfolio-card:hover .portfolio-card-category{background:var(--gradient-accent);color:var(--color-void);transform:scale(1.05)}.portfolio-card-title{color:var(--color-text-primary);font-family:var(--font-display);font-size:1.2rem;font-weight:600;letter-spacing:-.02em;margin:0 0 .75rem}.portfolio-card-description{-webkit-line-clamp:3;-webkit-box-orient:vertical;color:var(--color-text-secondary);display:-webkit-box;flex-grow:1;line-height:1.6;margin-bottom:1rem;overflow:hidden}.portfolio-card-actions{display:flex;gap:1rem;margin-top:auto}.portfolio-card-link{background:var(--gradient-primary);border-radius:8px;color:var(--color-void);flex:1 1;font-size:.9rem;font-weight:600;overflow:hidden;padding:.65rem 1.25rem;position:relative;text-align:center;text-decoration:none;transition:all .4s cubic-bezier(.175,.885,.32,1.275)}.portfolio-card-link:before{background:#ffffff4d;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .6s,height .6s;width:0}.portfolio-card-link:hover:before{height:300px;width:300px}.portfolio-card-link:hover{background:var(--gradient-accent);box-shadow:0 6px 20px #4ecdc466;transform:translateY(-2px) scale(1.05)}.portfolio-card-link.external{background:#0000;border:2px solid var(--color-primary);color:var(--color-primary)}.portfolio-card-link.external:hover{background:var(--color-primary);color:var(--color-void)}@media (max-width:768px){.portfolio-card{border-radius:12px}.portfolio-card-image{height:180px}.portfolio-card-content{padding:1.25rem}.portfolio-card-title{font-size:1.1rem}.portfolio-card-description{font-size:.9rem}.portfolio-card-actions{flex-direction:column;gap:.75rem}.portfolio-card-link{font-size:.85rem;padding:.6rem 1rem}}@media (max-width:480px){.portfolio-card-image{height:160px}.portfolio-card-content{padding:1rem}.portfolio-card-category{font-size:.7rem;padding:.3rem .8rem}}.home{min-height:100vh}.hero{align-items:center;animation:gradientShift 12s ease infinite;background:var(--gradient-hero);background-size:200% 200%;color:var(--color-text-on-dark);display:flex;justify-content:center;min-height:88vh;overflow:hidden;padding:8rem 2rem;position:relative;text-align:center;width:100%}.hero:before{animation:float 8s ease-in-out infinite;background:radial-gradient(ellipse 80% 50% at 15% 40%,#7dd3fc24 0,#0000 55%),radial-gradient(ellipse 70% 45% at 85% 60%,#5eead41f 0,#0000 50%),radial-gradient(ellipse 50% 40% at 50% 0,#a78bfa14 0,#0000 45%);bottom:0;left:0;right:0;top:0}.hero:after,.hero:before{content:"";pointer-events:none;position:absolute}.hero:after{animation:rotate 20s linear infinite;background:repeating-linear-gradient(45deg,#0000,#0000 10px,#ffffff08 0,#ffffff08 20px);height:200%;left:-50%;top:-50%;width:200%}.hero-content{animation:fadeInUp 1s ease-out;margin:0 auto;max-width:900px;position:relative;z-index:1}.hero-title{-webkit-text-fill-color:#0000;animation:fadeInUp .8s ease-out .2s both;background:linear-gradient(120deg,#f8fafc,#bae6fd 42%,#5eead4);-webkit-background-clip:text;background-clip:text;font-family:var(--font-hero);font-size:clamp(2.4rem,5.5vw,4.25rem);font-weight:800;letter-spacing:-.04em;line-height:1.05;margin-bottom:1.5rem}.hero-subtitle{animation:fadeInUp .8s ease-out .4s both;color:var(--color-text-secondary);font-size:clamp(1rem,2vw,1.25rem);font-weight:400;line-height:1.75;margin-bottom:3rem;margin-left:auto;margin-right:auto;max-width:36rem;opacity:.82}.hero-actions{animation:fadeInUp .8s ease-out .6s both;display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center}.btn{border-radius:50px;box-shadow:0 4px 15px #89bbfe4d;display:inline-block;letter-spacing:.5px;padding:.9rem 2.5rem;text-decoration:none;transition:all .4s cubic-bezier(.175,.885,.32,1.275)}.btn,.btn-primary{overflow:hidden;position:relative}.btn-primary{background:var(--gradient-accent);border:1px solid #ffffff1f;color:var(--color-void)}.btn-primary:before{background:#89bbfe33;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .6s,height .6s;width:0;z-index:0}.btn-primary:hover:before{height:400px;width:400px}.btn-primary span{color:var(--color-void);position:relative;transition:none;z-index:1}.btn-primary:hover{box-shadow:0 12px 40px #5eead440;filter:brightness(1.08);transform:translateY(-3px)}.btn-primary:hover span{color:var(--color-void)}.btn-secondary{background:#ffffff0a;border:1px solid var(--color-border-strong);color:var(--color-text-on-dark);overflow:hidden;position:relative}.btn-secondary:before{background:#fff3;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .6s,height .6s;width:0;z-index:0}.btn-secondary:hover:before{height:400px;width:400px}.btn-secondary:hover{background:#ffffff1a;border-color:var(--color-sky);box-shadow:0 8px 32px #00000059;color:var(--color-text-on-dark);transform:translateY(-3px)}.btn-secondary span{position:relative;z-index:1}.btn-outline{background:#0000;border:2px solid var(--color-primary);color:var(--color-primary);overflow:hidden;position:relative}.btn-outline:before{background:var(--gradient-primary);border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .6s,height .6s;width:0;z-index:0}.btn-outline:hover:before{height:400px;width:400px}.btn-outline:hover{background:var(--gradient-primary);box-shadow:0 8px 28px #7dd3fc33;color:var(--color-void);transform:translateY(-3px)}.btn-outline span{position:relative;z-index:1}.container{margin:0 auto;max-width:1200px;padding:0 2rem}.services{background:var(--color-page);padding:5rem 0;position:relative}.services:before{background:radial-gradient(ellipse 100% 80% at 50% 0,#7dd3fc0a 0,#0000 55%);content:"";inset:0;pointer-events:none;position:absolute}.section-title{-webkit-text-fill-color:#0000;animation:gradientShift 6s ease infinite;background:linear-gradient(100deg,#e8eaef,#7dd3fc 50%,#5eead4);-webkit-background-clip:text;background-clip:text;background-size:200% 200%;color:var(--color-text-primary);font-family:var(--font-display);font-size:clamp(1.75rem,4vw,2.75rem);font-weight:700;letter-spacing:-.03em;margin-bottom:4rem;position:relative;text-align:center}.section-title:after{background:var(--gradient-accent);border-radius:2px;bottom:-15px;content:"";height:4px;left:50%;position:absolute;transform:translateX(-50%);width:80px}.services-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.service-card{background:var(--color-surface-up);border:1px solid var(--color-border-light);border-radius:var(--radius-md);box-shadow:var(--shadow-glow);overflow:hidden;padding:2.5rem;position:relative;text-align:center;transition:all .4s cubic-bezier(.175,.885,.32,1.275)}.service-card:before{background:linear-gradient(90deg,#0000,#4ecdc41a,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.service-card:hover:before{left:100%}.service-card:hover{border-color:#5eead459;box-shadow:0 20px 50px #00000059,0 0 0 1px #5eead433;transform:translateY(-6px)}.service-icon{display:inline-block;filter:drop-shadow(0 4px 8px rgba(137,187,254,.2));font-size:4rem;margin-bottom:1.5rem;transition:transform .4s ease}.service-card:hover .service-icon{transform:scale(1.2) rotate(5deg)}.service-card h3{color:var(--color-text-primary);font-family:var(--font-display);font-weight:600;margin-bottom:1rem}.service-card p{color:var(--color-text-secondary);line-height:1.6}.featured-portfolio{background:linear-gradient(180deg,var(--color-page) 0,var(--color-surface) 100%);border-top:1px solid var(--color-border-light);padding:5rem 0}.portfolio-grid{margin-bottom:2rem}.section-footer{margin-top:2rem;text-align:center}@media (max-width:968px){.hero-actions{align-items:stretch;flex-direction:column;gap:1rem}.btn{text-align:center;width:100%}.services-grid{gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.portfolio-grid{gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media (max-width:768px){.hero{min-height:60vh;padding:4rem 1.5rem}.hero-title{font-size:2.2rem;line-height:1.2}.hero-subtitle{font-size:1rem;margin-bottom:2rem}.section-title{font-size:1.8rem;margin-bottom:2.5rem}.section-title:after{height:3px;width:60px}.portfolio-grid,.services-grid{gap:1.5rem;grid-template-columns:1fr}.service-card{padding:2rem 1.5rem}.service-icon{font-size:3rem}.container{padding:0 1.5rem}}@media (max-width:480px){.hero{min-height:50vh;padding:3rem 1rem}.hero-title{font-size:1.8rem}.hero-subtitle{font-size:.95rem}.section-title{font-size:1.5rem}.service-card{padding:1.5rem}.btn{font-size:.95rem;padding:.75rem 1.5rem}}.portfolio-page{animation:fadeIn .6s ease-out;background:var(--color-page);min-height:100vh;padding:4rem 0}.page-title{-webkit-text-fill-color:#0000;background:linear-gradient(100deg,#e8eaef,#7dd3fc 55%,#5eead4);-webkit-background-clip:text;background-clip:text;font-family:var(--font-display);font-size:clamp(2rem,4vw,2.75rem);font-weight:800;letter-spacing:-.03em;margin-bottom:.5rem;text-align:center}.page-subtitle{color:var(--color-text-secondary);font-size:1.1rem;margin-bottom:3rem;text-align:center}.portfolio-filters{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:3rem}.filter-btn{background:#0000;border:2px solid var(--color-primary);border-radius:30px;color:var(--color-primary);cursor:pointer;font-weight:600;letter-spacing:.3px;overflow:hidden;padding:.6rem 1.8rem;position:relative;transition:all .4s cubic-bezier(.175,.885,.32,1.275)}.filter-btn:before{background:var(--gradient-primary);border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .5s,height .5s;width:0;z-index:-1}.filter-btn.active:before,.filter-btn:hover:before{height:300px;width:300px}.filter-btn:hover{background:var(--color-primary);border-color:var(--color-primary);box-shadow:0 6px 20px #89bbfe66;color:var(--color-void);transform:translateY(-3px) scale(1.05)}.filter-btn.active{background:var(--gradient-accent);border-color:var(--color-accent);box-shadow:0 6px 20px #4ecdc466;color:var(--color-void);transform:scale(1.05)}.portfolio-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.loading,.no-items{animation:fadeIn .6s ease-out;color:var(--color-text-secondary);font-size:1.1rem;padding:3rem;text-align:center}.loading-spinner{align-items:center;display:flex;flex-direction:column;grid-column:1/-1;justify-content:center;padding:4rem}@media (max-width:968px){.portfolio-grid{gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media (max-width:768px){.portfolio-page{padding:3rem 0}.page-title{font-size:2rem}.page-subtitle{font-size:1rem}.portfolio-filters{gap:.5rem;margin-bottom:2rem}.filter-btn{font-size:.85rem;padding:.5rem 1.2rem}.portfolio-grid{gap:1.5rem;grid-template-columns:1fr}}@media (max-width:480px){.portfolio-page{padding:2rem 0}.page-title{font-size:1.6rem}.portfolio-filters{flex-wrap:wrap;gap:.4rem}.filter-btn{font-size:.8rem;padding:.4rem 1rem}}.portfolio-video-embed{background:var(--color-bg-secondary);border:1px solid var(--color-border-light);border-radius:15px;box-shadow:0 8px 30px #6f8ab740;margin-bottom:2rem;overflow:hidden;position:relative;width:100%}.portfolio-video-embed--detail.portfolio-video-embed--16-9{height:0;padding-bottom:56.25%}.portfolio-video-embed--detail.portfolio-video-embed--9-16{height:0;margin-left:auto;margin-right:auto;max-width:420px;padding-bottom:min(120%,85vh)}.portfolio-video-embed__iframe,.portfolio-video-embed__media{border:0;display:block;height:100%;left:0;position:absolute;top:0;width:100%}.portfolio-detail{animation:fadeIn .6s ease-out;background:var(--color-page);min-height:100vh;padding:4rem 0}.detail-header{animation:fadeInUp .6s ease-out}.back-link{color:var(--color-primary);display:inline-block;font-weight:500;margin-bottom:2rem;text-decoration:none;transition:color .3s ease}.back-link:hover{color:var(--color-primary-dark)}.detail-header{margin-bottom:2rem}.detail-category{background:#5eead41a;border:1px solid #5eead440;border-radius:999px;color:var(--color-mint);display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.08em;margin-bottom:1rem;padding:.45rem 1rem;text-transform:uppercase}.detail-title{-webkit-text-fill-color:#0000;background:linear-gradient(100deg,#e8eaef,#7dd3fc 50%,#a78bfa);-webkit-background-clip:text;background-clip:text;color:var(--color-text-primary);font-family:var(--font-display);font-size:clamp(1.75rem,4vw,2.75rem);font-weight:800;letter-spacing:-.03em;margin:0}.detail-image{animation:scaleIn .8s ease-out .2s both;border:1px solid var(--color-border-light);border-radius:15px;box-shadow:0 8px 30px #6f8ab740;margin-bottom:2rem;overflow:hidden;transition:transform .3s ease;width:100%}.detail-image:hover{box-shadow:0 12px 40px #89bbfe4d;transform:scale(1.01)}.detail-image img{display:block;height:auto;width:100%}.detail-video-slot{animation:scaleIn .8s ease-out .3s both;scroll-margin-top:5rem}.detail-video-slot .portfolio-video-embed{animation:none}.detail-video-fallback{background:var(--color-pale-sky);border:1px solid var(--color-border-light);border-radius:12px;margin-bottom:2rem;padding:1rem 1.25rem}.detail-video-fallback-note{color:var(--color-text-secondary);font-size:.9rem}.detail-content{animation:fadeInUp .8s ease-out .4s both;margin:0 auto;max-width:800px}.detail-description{margin-bottom:2rem}.detail-description h2{color:var(--color-text-primary);margin-bottom:1rem}.detail-description p{color:var(--color-text-secondary);font-size:1.1rem;line-height:1.8}.detail-actions{padding:2rem 0;text-align:center}.detail-actions .btn{background:var(--gradient-primary);border-radius:50px;box-shadow:0 4px 15px #89bbfe4d;color:var(--color-void);display:inline-block;font-size:1.1rem;font-weight:600;overflow:hidden;padding:1rem 2.5rem;position:relative;text-decoration:none;transition:all .4s cubic-bezier(.175,.885,.32,1.275)}.detail-actions .btn:before{background:#ffffff4d;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .6s,height .6s;width:0;z-index:0}.detail-actions .btn:hover:before{height:500px;width:500px}.detail-actions .btn:hover{background:var(--gradient-accent);box-shadow:0 8px 25px #89bbfe66;transform:translateY(-4px) scale(1.05)}.detail-actions .btn span{position:relative;z-index:1}.error,.loading{color:var(--color-text-secondary);font-size:1.1rem;padding:3rem;text-align:center}.error{color:var(--color-error)}@media (max-width:968px){.detail-content{max-width:100%}}@media (max-width:768px){.portfolio-detail{padding:3rem 0}.detail-title{font-size:1.75rem;line-height:1.3}.detail-description h2{font-size:1.3rem}.detail-description p{font-size:1rem;line-height:1.7}.detail-actions .btn{font-size:1rem;padding:.9rem 2rem;width:100%}}@media (max-width:480px){.portfolio-detail{padding:2rem 0}.detail-title{font-size:1.5rem}.detail-category{font-size:.75rem;padding:.4rem .8rem}.detail-description h2{font-size:1.2rem}.detail-description p{font-size:.95rem}}.contact-page{animation:fadeIn .6s ease-out;background:var(--color-page);min-height:100vh;padding:4rem 0}.contact-page .page-title{-webkit-text-fill-color:#0000;background:linear-gradient(100deg,#e8eaef,#7dd3fc 55%,#5eead4);-webkit-background-clip:text;background-clip:text;font-family:var(--font-display);font-size:clamp(2rem,4vw,2.75rem);font-weight:800;letter-spacing:-.03em;margin-bottom:.5rem;text-align:center}.contact-page .page-subtitle{color:var(--color-text-secondary);font-size:1.1rem;margin-bottom:2rem;margin-left:auto;margin-right:auto;max-width:36rem;text-align:center}.contact-content{grid-gap:4rem;animation:fadeInUp .8s ease-out .2s both;display:grid;gap:4rem;grid-template-columns:1fr 1.5fr;margin-top:3rem}.contact-info h2{-webkit-text-fill-color:#0000;background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;color:var(--color-text-primary);margin-bottom:1rem}.contact-info p{color:var(--color-text-secondary);line-height:1.8;margin-bottom:2rem}.contact-details{background:var(--color-bg-secondary);border:1px solid var(--color-border-light);border-radius:10px;padding:1.5rem}.contact-details p{color:var(--color-text-primary);margin-bottom:1rem}.contact-details ul{list-style:none;padding:0}.contact-details ul li{border-bottom:1px solid var(--color-border);color:var(--color-text-secondary);padding:.5rem 0}.contact-details ul li:last-child{border-bottom:none}.contact-form{background:var(--color-surface-up);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-glow);overflow:hidden;padding:2.5rem;position:relative;transition:all .3s ease}.contact-form:before{animation:float 8s ease-in-out infinite;background:radial-gradient(circle,#4ecdc40d 0,#0000 70%);content:"";height:200%;pointer-events:none;position:absolute;right:-50%;top:-50%;width:200%}.form-group input,.form-group textarea{background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);color:var(--color-text-primary);font-family:inherit;font-size:1rem;padding:.75rem;transition:border-color .3s ease;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 4px #89bbfe26,0 4px 12px #89bbfe1a;outline:none;transform:translateY(-2px)}.form-group input.error,.form-group textarea.error{border-color:var(--color-error)}.alert-success{background:#27ae601a;border:1px solid #27ae604d;color:var(--color-success)}.contact-form .btn{background:var(--gradient-primary);border-radius:50px;box-shadow:0 4px 15px #89bbfe4d;color:var(--color-void);font-size:1.1rem;font-weight:600;overflow:hidden;padding:1rem;position:relative;transition:all .4s cubic-bezier(.175,.885,.32,1.275);width:100%}.contact-form .btn:before{background:#ffffff4d;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .6s,height .6s;width:0}.contact-form .btn:hover:before{height:500px;width:500px}.contact-form .btn:hover{background:var(--gradient-accent);box-shadow:0 8px 25px #89bbfe66;transform:translateY(-3px) scale(1.02)}.contact-form .btn:disabled{cursor:not-allowed;opacity:.6}@media (max-width:968px){.contact-content{gap:2rem;grid-template-columns:1fr}.contact-info{order:2}.contact-form{order:1}}@media (max-width:768px){.contact-page{padding:3rem 0}.contact-content{gap:1.5rem;margin-top:2rem}.contact-form{padding:1.5rem}.contact-info h2{font-size:1.5rem}}@media (max-width:480px){.contact-page{padding:2rem 0}.page-title{font-size:1.8rem}.page-subtitle{font-size:1rem}.contact-details,.contact-form{padding:1.25rem}}.admin-login{align-items:center;background:var(--color-page);display:flex;justify-content:center;min-height:calc(100vh - 200px);padding:2rem}@media (max-width:768px){.admin-login{min-height:calc(100vh - 150px);padding:1.5rem}.login-box{padding:2rem 1.5rem}.login-box h1{font-size:1.5rem}}@media (max-width:480px){.admin-login{padding:1rem}.login-box{padding:1.5rem 1.25rem}.login-box h1{font-size:1.3rem}.login-subtitle{font-size:.9rem}}.login-container{max-width:400px;width:100%}.login-box{background:var(--color-surface-up);border:1px solid var(--color-border-light);border-radius:var(--radius-md);box-shadow:var(--shadow-glow);padding:2.5rem}.login-box h1{-webkit-text-fill-color:#0000;background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;font-family:var(--font-display);font-weight:700;margin-bottom:.5rem;text-align:center}.login-subtitle{color:var(--color-text-secondary);margin-bottom:2rem;text-align:center}.form-group input{background:var(--color-bg-primary);border:2px solid var(--color-border);border-radius:5px;font-size:1rem;padding:.75rem;transition:border-color .3s ease;width:100%}.form-group input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #89bbfe1a;outline:none}.form-group input.error{border-color:var(--color-error)}.btn{padding:.75rem;width:100%}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.login-version-block{margin-top:1.25rem}.login-version{color:#6b7280;color:var(--color-text-secondary,#6b7280);font-size:.75rem;line-height:1.4;margin-bottom:0;margin-top:.35rem;text-align:center}.login-version-block .login-version:first-child{margin-top:0}.btn-secondary{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-primary)}.btn-secondary:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary-light)}.btn-secondary:disabled{cursor:not-allowed;opacity:.55}.admin-login-modal-backdrop{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a8c;display:flex;inset:0;justify-content:center;padding:1.5rem;position:fixed;z-index:1000}.admin-login-modal{background:var(--color-surface-up);border:1px solid var(--color-border-light);border-radius:var(--radius-md);box-shadow:var(--shadow-glow);max-width:400px;outline:none;padding:1.75rem 1.5rem;width:100%}.admin-login-modal-title{color:var(--color-text-primary);font-family:var(--font-display);font-size:1.25rem;font-weight:700;margin:0 0 .5rem}.admin-login-modal-desc{color:var(--color-text-secondary);font-size:.875rem;line-height:1.45;margin:0 0 1rem}.admin-login-modal .form-group{margin-bottom:1rem}.admin-login-modal-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.25rem}.admin-login-modal-actions .btn{flex:1 1 auto;min-width:0;width:auto}.admin-login-modal-verify{flex:1 1 100%}@media (min-width:420px){.admin-login-modal-verify{flex:1 1 auto}}.admin-dashboard{background:var(--color-page);min-height:100vh;padding:4rem 0}.dashboard-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.dashboard-header h1{-webkit-text-fill-color:#0000;background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;font-family:var(--font-display);font-weight:700;letter-spacing:-.02em}.dashboard-session-hint{color:var(--color-text-secondary);font-size:.9rem;margin:-.5rem 0 1.75rem}.form-hint{color:var(--color-text-secondary);display:block;font-size:.8rem;line-height:1.4;margin-top:.35rem}.dashboard-actions,.dashboard-form{margin-bottom:2rem}.dashboard-form{background:var(--color-bg-primary);border:1px solid var(--color-border-light);border-radius:10px;box-shadow:0 2px 10px #6f8ab71a;padding:2rem}.dashboard-form h2{color:var(--color-text-primary);margin-bottom:1.5rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.form-group{margin-bottom:1.5rem}.form-group label{color:var(--color-text-primary);display:block;font-weight:500;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{background:var(--color-bg-primary);border:2px solid var(--color-border);border-radius:5px;font-family:inherit;font-size:1rem;padding:.75rem;transition:border-color .3s ease;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #89bbfe1a;outline:none}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:var(--color-error)}.error-message{color:var(--color-error);display:block;font-size:.875rem;margin-top:.25rem}.alert{border-radius:5px;margin-bottom:1.5rem;padding:1rem}.alert-error{background:#e74c3c1a;border:1px solid #e74c3c4d;color:var(--color-error)}.form-actions{display:flex;gap:1rem}.dashboard-items{background:var(--color-bg-primary);border:1px solid var(--color-border-light);border-radius:10px;box-shadow:0 2px 10px #6f8ab71a;padding:2rem}.dashboard-items h2{color:var(--color-text-primary);margin-bottom:1.5rem}.items-table{overflow-x:auto}.items-table table{border-collapse:collapse;width:100%}.items-table td,.items-table th{border-bottom:1px solid var(--color-border);padding:1rem;text-align:left}.items-table th{color:var(--color-text-primary);font-weight:600}.items-table th,.items-table tr:hover{background:var(--color-bg-secondary)}.btn{border:none;border-radius:5px;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease}.btn-primary{background:var(--gradient-primary);color:var(--color-bg-primary)}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark);box-shadow:0 4px 12px #89bbfe4d;transform:translateY(-1px)}.btn-secondary{background:var(--color-glaucous);color:var(--color-bg-primary)}.btn-secondary:hover{background:var(--color-charcoal)}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-small{font-size:.875rem;margin-right:.5rem;padding:.4rem .8rem}.btn-edit{background:var(--color-primary);color:var(--color-bg-primary)}.btn-edit:hover{background:var(--color-primary-dark)}.btn-delete{background:var(--color-error);color:var(--color-bg-primary)}.btn-delete:hover{background:#c0392b}.no-items{padding:2rem}.loading,.no-items{color:var(--color-text-secondary);text-align:center}.loading{padding:3rem}@media (max-width:968px){.dashboard-items{overflow-x:auto}.items-table{min-width:600px}}@media (max-width:768px){.admin-dashboard{padding:2rem 0}.form-row{grid-template-columns:1fr}.dashboard-header{align-items:flex-start;flex-direction:column;gap:1rem}.dashboard-header h1{font-size:1.5rem}.dashboard-form,.dashboard-items{padding:1.5rem}.items-table{font-size:.875rem;min-width:100%}.items-table td,.items-table th{padding:.5rem}.btn-small{font-size:.8rem;margin-right:.25rem;padding:.3rem .6rem}}@media (max-width:480px){.admin-dashboard{padding:1.5rem 0}.container{padding:0 1rem}.dashboard-form,.dashboard-items{padding:1.25rem}.dashboard-form h2,.dashboard-items h2{font-size:1.2rem}.items-table{font-size:.75rem}.items-table td,.items-table th{padding:.4rem}}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--color-text-primary);font-family:var(--font-body);line-height:1.6;overflow-x:hidden;width:100%}.App{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1 1}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}