:root{--primary-color:#000;--secondary-color:#06f;--secondary-hover:#0052cc;--background-color:#fff;--text-color:#000;--error-color:#ef4444;--gray-50:#f9f9f9;--gray-100:#f8f9fa;--gray-200:#e5e5e5;--gray-300:#e0e0e0;--gray-400:#d4d4d4;--gray-500:#666;--gray-600:#555;--gray-700:#333;--gray-800:#1a1a1a;--gray-900:#111;--gray-light:#f5f5f5;--gray-lighter:#f0f0f0;--gray-border:#e5e5e5;--gray-text-light:#999;--gray-text-muted:#888;--gray-text-subtle:#aaa;--gray-bg-subtle:#f7f8fa;--gray-bg-light:#eff6ff;--text-primary:var(--text-color);--text-secondary:var(--gray-500);--text-muted:var(--gray-text-muted);--text-light:var(--gray-text-light);--text-subtle:var(--gray-text-subtle);--border-color:var(--gray-300);--border-light:var(--gray-200);--border-subtle:#eee;--surface-color:var(--gray-50);--surface-hover:var(--gray-100);--surface-light:var(--gray-light);--surface-lighter:var(--gray-lighter);--bg-secondary:var(--gray-bg-subtle);--bg-accent:var(--gray-bg-light)}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;background-color:var(--background-color);color:#000;color:var(--text-color);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}.container{margin:0 auto;max-width:1440px;padding:0 1.5rem;width:100%}.app-layout{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1 1}.btn{border:2px solid #0000;border-radius:6px;cursor:pointer;display:inline-block;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;text-align:center;text-decoration:none;transition:all .2s}.btn-primary{background-color:#06f;background-color:var(--secondary-color);color:#fff}.btn-primary:hover{background-color:#0052cc;background-color:var(--secondary-hover)}.btn-outline{background-color:initial;border-color:#000;border-color:var(--primary-color);color:#000;color:var(--primary-color)}.btn-outline:hover{background-color:#000;background-color:var(--primary-color);color:#fff}.header{backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);background:#ffffffb3;border:1px solid #fffc;box-shadow:0 8px 32px 0 #1f268726,inset 0 0 0 1px #fff3;left:50%;padding:2rem 3rem;position:fixed;transform:translateX(-50%);transition:all .3s ease;width:100%;z-index:1000}.header-transparent{backdrop-filter:blur(10px) saturate(150%);-webkit-backdrop-filter:blur(10px) saturate(150%);background:#ffffff1a;border:1px solid #fff3;box-shadow:0 4px 16px 0 #0000001a,inset 0 0 0 1px #ffffff1a}.header-container{justify-content:space-between;margin:0 auto;max-width:1440px;position:relative;width:100%}.header-container,.logo{align-items:center;display:flex}.logo-link{align-items:center;display:inline-flex;justify-content:center;padding:0;text-decoration:none}.logo-link img{display:block;height:25px;width:auto}.desktop-nav{display:block}.nav-list{align-items:center;display:flex;gap:2.5rem;list-style:none;margin:0;padding:0}.nav-item a{color:var(--gray-500);font-size:1.2rem;font-weight:600;position:relative;text-decoration:none;transition:all .2s ease}.header-transparent .nav-item a{color:#fff}.header-transparent .nav-item a:active,.nav-item a.active,.nav-item a:active,.nav-item a:hover{color:var(--gray-300)}.drawer-button{align-items:center;background:#0000;border:none;cursor:pointer;display:none;flex-direction:column;gap:5px;height:32px;justify-content:center;padding:0;position:absolute;right:0;width:32px;z-index:1003}.drawer-button span{background-color:var(--gray-800);border-radius:2px;display:block;height:2px;transform-origin:center;transition:all .3s cubic-bezier(.4,0,.2,1);width:22px}.header-transparent .drawer-button span{background-color:#fff}.mobile-overlay{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background-color:#00000080;height:100%;left:0;opacity:0;position:fixed;top:0;transition:opacity .3s ease,visibility .3s ease;visibility:hidden;width:100%;z-index:1001}.mobile-overlay.open{opacity:1;visibility:visible}.mobile-nav{backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);background:#fffffff2;box-shadow:-4px 0 24px #0000001a;display:flex;flex-direction:column;height:100%;max-width:320px;overflow-y:auto;padding:2rem;position:fixed;right:0;top:0;transform:translateX(100%);transition:transform .3s ease;width:80%;z-index:1002}.mobile-nav.open{transform:translateX(0)}.mobile-nav-logo{margin-bottom:2rem;text-align:center}.mobile-nav-logo img{display:block;height:25px;margin:0 auto;width:auto}.mobile-nav-list{display:flex;flex-direction:column;gap:.5rem;list-style:none;margin:0;padding:0}.mobile-nav-item{border-bottom:1px solid #0000000d}.mobile-nav-item a{color:var(--gray-800);display:block;font-size:1.1rem;font-weight:600;padding:1.25rem 0;text-decoration:none;transition:color .2s ease}.mobile-nav-item a:active,.mobile-nav-item a:hover{color:var(--gray-600)}.mobile-nav-item a.active{color:var(--gray-800);font-weight:700}@media (max-width:768px){.header{padding:1.5rem}.desktop-nav{display:none}.drawer-button{display:flex}.header-container{gap:0;justify-content:space-between}.logo-link img{height:15px}}.mobile-nav-social{border-top:1px solid #0000000d;display:flex;gap:1rem;justify-content:end;padding-top:2rem}.social-button{align-items:center;background:#0000;border:1px solid #0000001a;border-radius:50%;color:var(--gray-600);display:flex;height:40px;justify-content:center;text-decoration:none;transition:all .2s ease;width:40px}.social-button:hover{background:var(--gray-100);border-color:var(--gray-400);color:var(--gray-800);transform:scale(1.05)}.social-button:active{transform:scale(.95)}.glass-button{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:2px solid #ffffff4d;border-radius:50px;color:#fff;cursor:pointer;display:inline-flex;font-size:1.1rem;font-weight:600;gap:.75rem;justify-content:center;padding:1.25rem 2rem;text-decoration:none;transition:all .3s ease}.glass-button:hover{background:#fff3;border-color:#ffffff80;color:#fff}.glass-button.secondary{background:#0000000d;border:2px solid #0003;color:#000}.glass-button.secondary:hover{background:#0000001a;border-color:#0006;color:#000}@media (max-width:768px){.glass-button{font-size:.9rem;min-width:-webkit-fit-content;min-width:fit-content;padding:1.1rem 2rem;width:auto}}.footer{background-color:#000;color:#f5f5f5;margin-top:auto;padding:2rem 0 1rem}.footer-container{display:flex;flex-direction:column;gap:1.5rem;margin:0 auto;max-width:1400px;padding:0 1.25rem}.footer-cta{padding:2rem 0}.footer-cta-content{align-items:center;display:flex;flex-direction:column;gap:2rem;justify-content:space-between}.footer-cta-text{flex:1 1;text-align:center}.footer-cta-title{color:#fff;font-size:2.5rem;font-weight:700;letter-spacing:-.025em;line-height:1.2;margin:0}.footer-cta-text p{color:#f5f5f5;font-size:1.5rem;font-weight:400;line-height:1.4;margin:.5rem 0 0}.footer-cta-actions{flex-shrink:0}.footer-divider{background:#fff;height:1px;margin:1rem 0;width:100%}.footer-content{grid-gap:2.5rem 3rem;align-items:start;display:grid;gap:2.5rem 3rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.footer-section{display:flex;flex-direction:column;gap:.75rem}.footer-logo{align-items:center;display:flex;margin-bottom:.5rem}.footer-logo img{display:block;filter:invert(1);height:25px;width:auto}.footer-section-right{align-items:flex-end}.footer-section h3{color:#fff;font-size:1.5rem;font-weight:700;margin-bottom:1.25rem}.footer-section h4{color:#fff;font-size:1.1rem;font-weight:600;margin-bottom:1rem}.footer-section-left .business-info{display:flex;flex-direction:column;gap:.5rem}.footer-section-left .business-info p{color:var(--gray-400);font-size:.9rem;line-height:1.6;margin:0}.contact-inline{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:flex-end;width:100%}.contact-link{color:#f5f5f5;display:inline-block;font-size:.95rem;text-decoration:none}.social-icons{gap:1rem}.social-icon,.social-icons{align-items:center;display:flex}.social-icon{background-color:var(--gray-900);border-radius:8px;color:#fff;height:40px;justify-content:center;text-decoration:none;width:40px}.social-icon svg{height:20px;width:20px}.footer-bottom{border-top:1px solid var(--gray-800);padding-top:1rem;text-align:center}.footer-bottom p{color:var(--gray-text-light);font-size:.85rem;margin:0}@media (max-width:992px){.footer-cta-content{align-items:center;flex-direction:column;padding:2.5rem}.footer-cta-title{font-size:2rem}.footer-cta-text p{font-size:1.2rem}.footer-cta-actions{min-width:-webkit-fit-content;min-width:fit-content;width:auto}}@media (max-width:768px){.footer-cta-content{align-items:center;flex-direction:column;gap:1.5rem;padding:2rem}.footer-cta-text{width:100%}.footer-cta-title{font-size:1.8rem}.footer-cta-text p{font-size:1rem}.footer-cta-actions{min-width:-webkit-fit-content;min-width:fit-content;width:auto}.footer{padding:1.5rem 0 1rem}.footer-cta{padding:3rem 0}.footer-cta-content{padding:2rem}.footer-content{gap:2rem;grid-template-columns:1fr}.footer-section h3{font-size:1.3rem;margin-bottom:1rem}.footer-logo img{height:20px}.footer-section-right{align-items:flex-start}.contact-inline{justify-content:flex-start}}.scroll-to-top{align-items:center;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);background:#ffffffe6;border:1px solid #fffc;border-radius:50%;bottom:2rem;box-shadow:0 8px 32px 0 #1f268726,inset 0 0 0 1px #fff3;color:var(--gray-800);cursor:pointer;display:flex;height:50px;justify-content:center;opacity:0;position:fixed;right:2rem;transform:translateY(20px);transition:all .3s ease;visibility:hidden;width:50px;z-index:999}.scroll-to-top.visible{opacity:1;transform:translateY(0);visibility:visible}.scroll-to-top:hover{background:#fff;box-shadow:0 12px 40px 0 #1f268733,inset 0 0 0 1px #ffffff4d;transform:translateY(-4px)}.scroll-to-top:active{transform:translateY(-2px)}.scroll-to-top svg{height:24px;width:24px}@media (max-width:768px){.scroll-to-top{bottom:1.5rem;height:48px;right:1.5rem;width:48px}.scroll-to-top svg{height:20px;width:20px}}.portfolio-card{background:#fff;border:1px solid #e5e5e5;border-radius:24px;box-shadow:0 4px 20px #00000014;color:inherit;display:block;overflow:hidden;text-decoration:none;transition:transform .3s ease,box-shadow .3s ease}.portfolio-card:hover{box-shadow:0 12px 40px #00000026;transform:translateY(-6px)}.portfolio-card__thumbnail{aspect-ratio:1/1;background:#f2f2f2;overflow:hidden;position:relative;width:100%}.portfolio-card--landscape .portfolio-card__thumbnail{aspect-ratio:3/2}.portfolio-card__thumbnail img{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.portfolio-card:hover .portfolio-card__thumbnail img{transform:scale(1.05)}.portfolio-card__placeholder{align-items:center;background:#f2f2f2;display:flex;height:100%;justify-content:center;width:100%}.portfolio-card__placeholder-text{color:#000;font-size:2rem;font-weight:600;letter-spacing:-.02em;opacity:.6}.portfolio-card__overlay{align-items:flex-end;background:linear-gradient(180deg,#0003,#000c);display:flex;inset:0;padding:1.5rem;position:absolute}.portfolio-card__overlay-content{color:#fff;display:flex;flex-direction:column;gap:.75rem}.portfolio-card__title{font-size:1.4rem;font-weight:700;letter-spacing:-.02em;margin:0}.portfolio-card__description{color:#ffffffd9;font-size:.95rem;line-height:1.6;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.portfolio-card__tags{display:flex;flex-wrap:nowrap;gap:.5rem;overflow:hidden}.portfolio-card__tag{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff1f;border:1px solid #ffffff59;border-radius:999px;color:#fff;display:inline-flex;font-size:.8rem;font-weight:600;justify-content:center;padding:.4rem .85rem}@keyframes portfolioFadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.portfolio-card{animation:portfolioFadeInUp .6s ease forwards;opacity:0}@media (max-width:768px){.portfolio-card__overlay{padding:1rem}.portfolio-card__title{font-size:1.1rem}.portfolio-card__description{font-size:.85rem}.portfolio-card__tag{font-size:.7rem}}body,html{margin:0!important;max-width:100vw!important;overflow-x:hidden!important;padding:0!important;width:100%!important}*,:after,:before{box-sizing:border-box}*{max-width:100vw}.home-page{background-color:#fff;box-sizing:border-box}.blog-section,.hero-section,.home-page,.portfolio-section,.process-section,.services-section{max-width:100vw;overflow-x:hidden;width:100%}.hero-section{align-items:center;background-image:url(/static/media/devit_hero.afdf707f6b6c145eed4e.png);background-position:50%;background-repeat:no-repeat;background-size:cover;display:flex;justify-content:center;min-height:100vh;padding:8rem 0;position:relative}.hero-section:before{background:#0003;bottom:0;content:"";left:0;position:absolute;right:0;top:0;z-index:0}.hero-content{align-items:center;display:flex;flex-direction:column;max-width:100%;position:relative;text-align:center;width:100%;z-index:1}.hero-logo{animation:fadeIn .8s ease-out forwards;animation-delay:.2s;margin-bottom:2rem;opacity:0}.hero-logo img{filter:invert(1) drop-shadow(0 2px 4px rgba(0,0,0,.5));height:auto;max-width:500px;min-width:200px;width:25vw}.hero-slogan{animation:fadeIn .8s ease-out forwards;animation-delay:.4s;font-family:Inter,sans-serif;font-size:3.2rem;font-weight:800;letter-spacing:-.025em;line-height:1.15;margin-bottom:1.5rem;text-align:center;width:100%}.hero-section .hero-subtitle,.hero-slogan{color:#fff;opacity:0;text-shadow:0 2px 4px #0000004d;word-break:keep-all}.hero-section .hero-subtitle{animation:fadeIn .8s ease-out forwards;animation-delay:.5s;font-size:1.5rem;font-weight:400;line-height:1.7;margin-bottom:3rem;margin-left:auto;margin-right:auto;max-width:700px}.hero-cta{align-items:center;animation:fadeIn .8s ease-out forwards;animation-delay:.8s;display:flex;gap:1.5rem;opacity:0}.blog-section{background:#fff;padding:8rem 0}.blog-grid{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:repeat(3,1fr);margin-top:4rem;max-width:100%;overflow-x:hidden}.blog-item{display:flex;flex-direction:column;gap:1.5rem}.blog-card{background:#fff;border:1px solid #f0f0f0;border-radius:24px;box-shadow:0 4px 20px #00000014;color:inherit;display:flex;flex:0 0 auto;flex-direction:column;overflow:hidden;text-decoration:none;transition:all .3s ease}.blog-card:hover .blog-thumbnail{transform:scale(1.2)}.blog-thumbnail{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);display:flex;height:280px;justify-content:center;position:relative;transition:transform .3s ease;width:100%}.blog-thumbnail img{height:100%;object-fit:cover;width:100%}.blog-placeholder{align-items:center;display:flex;height:100%;justify-content:center;width:100%}.blog-text{color:#000;font-size:2rem;font-weight:600;letter-spacing:-.02em;opacity:.6}.blog-title{color:#000;font-size:1.5rem;font-weight:400;line-height:1.4;margin:0;text-align:start}.blog-empty,.blog-loading{color:#666;padding:3rem;text-align:center}.blog-empty p,.blog-loading p{font-size:1.1rem}.section-header{margin-bottom:6rem;text-align:center}.section-title{color:#000;font-size:3rem;font-weight:900;letter-spacing:-.025em;line-height:1.1;margin-bottom:1rem;margin-top:0}.section-description{color:#555;font-size:1.3rem;margin:0 auto;max-width:600px}.services-section{padding:8rem 0}.services-list{display:flex;flex-direction:column;gap:5rem}.service-item{grid-gap:3rem;--service-accent:#1f6feb;align-items:center;display:grid;gap:3rem;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);overflow:hidden;padding:3.5rem 3rem;position:relative}.service-item.is-reversed{grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr)}.service-item.is-reversed .service-text{order:2}.service-item.is-reversed .service-visual{order:1}.service-text{align-items:center;background:#f8f8f8;border-radius:32px;display:flex;flex-direction:column;gap:1.5rem;padding:2rem 1rem;position:relative;text-align:left;text-align:center;transition:box-shadow .3s ease;z-index:1}.service-tag{color:#777;font-size:.9rem;font-weight:600;letter-spacing:.2em}.service-item-title h3{color:#000;font-size:2.6rem;font-weight:900;letter-spacing:-.02em;line-height:1.1;margin:0 0 .6rem}.service-subtitle{color:#4f4f4f;font-size:1.15rem;font-weight:400;line-height:1.5;margin:0}.service-summary{grid-gap:.9rem;display:grid;gap:.9rem;justify-items:start;list-style:none;margin:0;padding:0}.service-summary li{align-items:flex-start;color:#4f4f4f;font-size:1rem;line-height:1.7;padding-left:1.6rem;position:relative;text-align:left;word-break:keep-all}.service-summary li:before{color:var(--service-accent);content:"■";font-size:.7rem;font-weight:700;left:0;position:absolute;top:.35rem}.service-visual{min-height:320px}.service-visual,.service-visual-content{align-items:center;color:var(--service-accent);display:flex;justify-content:center;position:relative}.service-visual-content{flex-direction:column;gap:1rem;z-index:1}.service-visual-content svg{height:120px;width:120px}.service-visual-title{color:#111;font-size:1.1rem;font-weight:700;letter-spacing:.08em}@media (max-width:992px){.services-list{gap:4rem}.service-item{gap:2.5rem;grid-template-columns:1fr;padding:3rem 2rem}.service-item-title h3{font-size:2.3rem}.service-subtitle{font-size:1.05rem}.service-summary li{font-size:.95rem}.service-visual{min-height:260px}.service-visual-content svg{height:100px;width:100px}}@media (max-width:768px){.services-section{padding:6rem 0}.services-list{gap:3rem}.service-item{padding:2.5rem 1.5rem}.service-item-title h3{font-size:1.8rem}.service-subtitle{font-size:1rem}.service-summary li{font-size:.9rem;line-height:1.6}.service-visual{min-height:220px;order:2}.service-text{order:1}.service-visual-content svg{height:90px;width:90px}}@media (max-width:480px){.services-section{padding:4rem 0}.service-item{padding:2rem 1rem}.service-item-title h3{font-size:1.6rem}.service-summary li{font-size:.9rem}.service-visual-title{font-size:1rem}}.section-divider{background:#dbdada;height:1px;margin:auto;position:relative;width:80%}@media (max-width:992px){.hero-slogan{font-size:2.6rem}.hero-section .hero-subtitle{font-size:1.35rem;max-width:100%}.blog-grid{gap:3rem;grid-template-columns:repeat(2,1fr)}.blog-thumbnail{height:240px}.blog-title{font-size:1.4rem}.blog-empty,.blog-loading{padding:2rem}.blog-empty p,.blog-loading p{font-size:1rem}}@media (max-width:768px){.hero-section{min-height:100vh;padding:8rem 0}.hero-section:before{background:#0003}.hero-content{align-items:center;text-align:center}.hero-slogan{text-align:center}.hero-slogan,.section-title{font-size:2rem}.section-description{font-size:1rem}.hero-section .hero-subtitle{font-size:1.1rem;margin-bottom:3rem;max-width:100%}.hero-cta{gap:1rem;width:100%}.blog-grid{grid-template-columns:1fr}.blog-thumbnail{height:200px}.blog-text{font-size:1.5rem}.blog-title{font-size:1.3rem}}@media (max-width:480px){.hero-section:before{background:#0003}.hero-slogan{font-size:1.6rem}.hero-section .hero-subtitle{font-size:1rem}.blog-text{font-size:1.25rem}}.process-section{background-color:#fff;padding:8rem 0}.process-steps{align-items:stretch;display:flex;flex-wrap:wrap;justify-content:space-between;margin-top:5rem;max-width:100%;min-height:300px;overflow-x:hidden;position:relative}.process-step-card{align-items:center;background:#fff;border:1px solid #f0f0f0;border-radius:24px;box-shadow:0 4px 20px #00000014;display:flex;flex:1 1;flex-direction:column;max-width:320px;padding:3rem 2rem;position:relative;text-align:center;transition:all .3s ease}.process-step-card:hover{box-shadow:0 8px 30px #0000001f;transform:translateY(-4px)}.process-step-content{align-items:center;display:flex;flex-direction:column;gap:1.5rem;width:100%}.process-step-icon-wrapper{display:flex;justify-content:center;margin-bottom:.5rem;width:100%}.process-step-icon{align-items:center;background:#f8f9fa;border:2px solid #e9ecef;border-radius:50%;color:#000;display:flex;flex-shrink:0;height:120px;justify-content:center;width:120px}.process-step-label{color:#999;font-size:.875rem;font-weight:500;letter-spacing:.05em;margin-top:.5rem;text-transform:uppercase}.process-step-title{color:#000;font-size:1.5rem;font-weight:700;letter-spacing:-.02em;line-height:1.3;margin:0}.process-step-description{color:#666;font-size:1rem;line-height:1.6;margin:0;word-break:keep-all}.process-connector{align-items:center;color:#d0d0d0;display:flex;flex-shrink:0;justify-content:center;margin:0 1.5rem}@media (max-width:992px){.process-section{padding:6rem 0}.process-steps{align-items:center;flex-direction:column;gap:3rem;margin-top:4rem}.process-step-card{max-width:500px;padding:2.5rem 2rem;width:100%}.process-step-content{gap:1.25rem}.process-connector{margin:1.5rem 0}.process-connector svg{transform:rotate(90deg)}.process-step-icon{height:100px;width:100px}.process-step-title{font-size:1.4rem}}@media (max-width:768px){.process-section{padding:6rem 0}.process-step-card{max-width:100%;padding:2rem 1.5rem}.process-step-content{gap:1rem}.process-step-icon{height:90px;width:90px}.process-step-label{font-size:.8rem}.process-step-title{font-size:1.3rem}.process-step-description{font-size:.95rem}.section-title{font-size:2.5rem}.section-description{font-size:1.2rem}}@media (max-width:480px){.process-section{padding:4rem 0}.process-step-card{padding:1.5rem 1.25rem}.process-step-icon{height:80px;width:80px}.portfolio-grid{grid-template-columns:repeat(2,1fr)}.process-step-title{font-size:1.2rem}.process-step-description{font-size:.9rem}.section-title{font-size:2.2rem}}.portfolio-section{background-color:#fff;padding:6rem 0}.portfolio-container{margin-top:3rem}.portfolio-grid{grid-gap:1rem;gap:1rem;max-width:100%;overflow-x:hidden}.portfolio-empty,.portfolio-loading{color:#666;padding:3rem;text-align:center}.portfolio-empty p,.portfolio-loading p{font-size:1.1rem}@media (max-width:768px){.portfolio-section{padding:4rem 0}.portfolio-grid{grid-template-columns:repeat(2,1fr)}}.contact-page{background-color:var(--background-color);min-height:100vh;padding-top:80px}.quote-form-wrapper{padding:8rem 0;position:relative}.form-background-logo{color:var(--text-color);font-family:inherit;font-size:20rem;font-weight:700;left:50%;letter-spacing:.05em;opacity:.12;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);-webkit-user-select:none;user-select:none;white-space:nowrap;z-index:0}.quote-form-title,.quote-form-wrapper .container{position:relative;z-index:1}.quote-form-title{color:var(--text-color);font-size:2.5rem;font-weight:700;line-height:1.4;margin-bottom:3rem;text-align:center}.quote-form{backdrop-filter:blur(20px) saturate(200%);-webkit-backdrop-filter:blur(30px) saturate(200%);background:#ffffff80;border:1px solid #ffffffb3;border-radius:24px;box-shadow:0 8px 32px 0 #1f268733,inset 0 0 0 1px #ffffff4d,inset 0 1px 0 0 #ffffff80;margin:0 auto;max-width:1200px;padding:3rem;position:relative;transition:all .3s ease;z-index:1}.form-section{margin-bottom:2.5rem}.form-section:last-of-type{margin-bottom:3rem}.form-section-title{border-bottom:2px solid var(--border-subtle);color:var(--gray-700);font-size:1.25rem;font-weight:600;margin-bottom:1.5rem;padding-bottom:.5rem}.input-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;margin-bottom:1.5rem}.input-grid.three-columns{grid-template-columns:repeat(3,1fr)}.input-grid.two-columns{grid-template-columns:repeat(2,1fr)}.form-group.full-width{width:100%}.form-group label{color:var(--text-color);font-size:.9rem;font-weight:500;margin-bottom:.5rem}.required{color:var(--error-color);margin-left:.25rem}.budget-hint{color:var(--text-muted);font-size:.85rem;font-weight:400}.form-group input,.form-group textarea{background-color:var(--background-color);border:1px solid var(--border-color);border-radius:12px;box-sizing:border-box;color:var(--text-color);font-family:inherit;font-size:.95rem;padding:.875rem 1.125rem;transition:all .3s ease;width:100%}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}.form-group input:focus,.form-group textarea:focus{background-color:#ffffff1f;border-color:var(--secondary-color);box-shadow:0 0 0 3px #0066ff1a;outline:none}.form-group textarea{line-height:1.6;min-height:160px;resize:vertical}.form-agreements{display:flex;flex-direction:column;gap:.875rem;margin-bottom:2rem;padding-left:.5rem}.checkbox-group{align-items:center;display:flex;gap:.625rem}.checkbox-group input[type=checkbox]{accent-color:var(--secondary-color);border-radius:4px;cursor:pointer;height:18px;width:18px}.checkbox-group label{color:var(--text-muted);cursor:pointer;font-size:.9rem;-webkit-user-select:none;user-select:none}.form-submit{display:flex;justify-content:center;margin-top:2rem}.submit-button{background-color:var(--secondary-color);border:none;border-radius:12px;box-shadow:0 4px 15px #0066ff4d;color:#fff;cursor:pointer;font-size:1.125rem;font-weight:600;min-width:240px;padding:1rem 3rem;transition:all .3s ease}.submit-button:hover:not(:disabled){background-color:var(--secondary-hover);box-shadow:0 6px 20px #06f6;transform:translateY(-2px)}.submit-button:active:not(:disabled){transform:translateY(0)}.submit-button:disabled{cursor:not-allowed;opacity:.7}.form-success-message{animation:fadeInUp .5s ease;backdrop-filter:blur(30px) saturate(200%);-webkit-backdrop-filter:blur(30px) saturate(200%);background:#ffffff80;border:1px solid #ffffffb3;border-radius:24px;box-shadow:0 8px 32px 0 #1f268733,inset 0 0 0 1px #ffffff4d,inset 0 1px 0 0 #ffffff80;margin:0 auto;max-width:1200px;padding:4rem 2rem;position:relative;text-align:center;z-index:1}.success-icon{align-items:center;animation:scaleIn .5s ease;background-color:#0066ff1a;border-radius:50%;display:flex;height:80px;justify-content:center;margin:0 auto 1.5rem;width:80px}.form-success-message h3{color:var(--text-color);font-size:1.75rem;font-weight:700;margin-bottom:.75rem}.form-success-message p{color:var(--text-muted);font-size:1rem;line-height:1.6}.form-error-message{animation:fadeIn .3s ease;background-color:#ef44441a;border:1px solid #ef44444d;border-radius:12px;color:var(--error-color);font-size:.95rem;margin:1rem auto 0;max-width:1200px;padding:1rem;text-align:center}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width:992px){.quote-form-wrapper{padding:4rem 0}.form-background-logo{font-size:15rem}.quote-form-title{font-size:2rem;margin-bottom:2.5rem}.quote-form{padding:2.5rem}.input-grid.three-columns{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.quote-form-wrapper{padding:3rem 0}.form-background-logo{font-size:10rem}.quote-form-title{font-size:1.75rem;margin-bottom:2rem;padding:0 1rem}.quote-form{border-radius:16px;padding:2rem 1rem}.input-grid,.input-grid.three-columns,.input-grid.two-columns{gap:1.25rem;grid-template-columns:1fr}.form-group input,.form-group textarea{font-size:16px;padding:.75rem 1rem}.form-group textarea{min-height:150px}.form-agreements{gap:.75rem;padding-left:0}.checkbox-group label{font-size:.85rem}.submit-button{font-size:1rem;min-width:auto;padding:.875rem 2rem;width:100%}.form-success-message{padding:3rem 1.5rem}.form-success-message h3{font-size:1.5rem}.success-icon{height:64px;width:64px}}@media (max-width:480px){.form-background-logo{font-size:8rem}.quote-form-title{font-size:1.5rem}.quote-form{padding:1.5rem 1rem}.form-group label{font-size:.85rem}}.page-header{margin-bottom:3rem;text-align:center}.page-header h1{font-size:2.5rem;margin-top:10rem}.page-header p{color:var(--text-secondary);font-size:1.1rem}@media (max-width:768px){.page-header h1{font-size:2rem;margin-top:6rem}.page-header p{font-size:1rem}}.blog-page{min-height:100vh;width:100%}.blog-category-nav,.blog-page{background:var(--background-color)}.blog-category-nav{border-bottom:1px solid var(--border-subtle);position:-webkit-sticky;position:sticky;top:0;z-index:100}.category-list{display:flex;gap:0;justify-content:center;list-style:none;margin:0 auto;max-width:1200px;padding:0}.category-item{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:1rem;font-weight:500;padding:1.25rem 1.5rem;position:relative;transition:color .2s ease}.category-item.active,.category-item:hover{color:var(--text-color)}.category-item.active{font-weight:600}.category-item.active:after{background:var(--primary-color);bottom:0;content:"";height:2px;left:0;position:absolute;right:0}.blog-content-wrapper{margin:0 auto;max-width:1200px;padding:3rem 2rem}.blog-layout{display:block}.blog-main{min-width:0}.post-list{list-style:none;margin:0;padding:0}.post-list>li{border-bottom:1px solid var(--border-subtle)}.post-list>li:last-child{border-bottom:none}.post-item{color:inherit;display:flex;gap:2rem;padding:2rem 0;text-decoration:none;transition:opacity .2s ease}.post-item:hover{opacity:.7}.post-text{display:flex;flex:1 1;flex-direction:column;justify-content:center;min-width:0}.post-title{color:var(--text-color);font-size:1.25rem;font-weight:600;line-height:1.5;margin:0 0 .75rem}.post-excerpt,.post-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.post-excerpt{color:var(--text-secondary);font-size:.95rem;line-height:1.7;margin:0 0 1rem}.post-meta{align-items:center;color:var(--text-muted);display:flex;font-size:.875rem;gap:.5rem}.post-separator{color:var(--border-light)}.post-author,.post-date{color:var(--text-muted)}.post-thumbnail{background:var(--surface-light);border-radius:8px;flex-shrink:0;height:140px;overflow:hidden;width:200px}.post-thumbnail img{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.post-item:hover .post-thumbnail img{transform:scale(1.05)}.blog-pagination{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:2.5rem}.blog-pagination .pagination-btn,.blog-pagination .pagination-number{background:var(--background-color);border:1px solid var(--border-subtle);border-radius:999px;color:var(--text-secondary);cursor:pointer;font-size:.9rem;padding:.5rem .9rem;transition:all .2s ease}.blog-pagination .pagination-btn:hover,.blog-pagination .pagination-number:hover{border-color:var(--text-color);color:var(--text-color)}.blog-pagination .pagination-number.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff;font-weight:600}.blog-pagination .pagination-btn:disabled{cursor:not-allowed;opacity:.5}.blog-pagination .pagination-numbers{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.blog-loading{padding:6rem 2rem}.blog-empty,.blog-loading{color:var(--text-secondary);font-size:1rem;text-align:center}.blog-empty{background:var(--gray-100);border-radius:8px;padding:4rem 2rem}@media (max-width:1024px){.post-thumbnail{height:110px;width:160px}}@media (max-width:768px){.blog-content-wrapper{padding:2rem 1rem}.blog-category-nav{-webkit-overflow-scrolling:touch;overflow-x:auto}.category-list{justify-content:flex-start;min-width:-webkit-max-content;min-width:max-content;padding:0 1rem}.category-item{font-size:.9rem;padding:1rem;white-space:nowrap}.post-item{flex-direction:column-reverse;gap:1rem;padding:1.5rem 0}.post-thumbnail{height:200px;width:100%}.post-title{font-size:1.1rem}.post-excerpt{font-size:.9rem}.blog-pagination{gap:.75rem}}@media (max-width:480px){.post-thumbnail{height:180px}}.blog-detail-page{background-color:var(--background-color);min-height:100vh}.blog-detail-loading{color:var(--text-secondary);font-size:1.1rem;min-height:400px}.blog-detail-loading,.blog-not-found{align-items:center;display:flex;justify-content:center}.blog-not-found{flex-direction:column;min-height:60vh;padding:2rem;text-align:center}.blog-not-found h1{color:var(--text-color);font-size:2rem;font-weight:800;margin-bottom:1rem}.blog-not-found p{color:var(--text-secondary);margin-bottom:2rem}.blog-not-found .back-button{align-items:center;background:var(--primary-color);border-radius:50px;color:#fff;display:inline-flex;font-weight:600;gap:.5rem;padding:.875rem 1.5rem;text-decoration:none;transition:all .3s ease}.blog-not-found .back-button:hover{background:var(--secondary-color)}.blog-detail-container{margin:0 auto;max-width:800px;padding:0 1.5rem 4rem}.post-meta-bar{align-items:center;border-bottom:1px solid var(--surface-lighter);display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;padding-bottom:1.5rem}.meta-category{background:var(--bg-accent);border-radius:6px;color:var(--secondary-color);display:inline-block;font-size:.85rem;font-weight:600;padding:.4rem .8rem}.meta-date,.meta-views{color:var(--text-muted);font-size:.9rem}.post-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem}.post-tag{background:var(--surface-light);border-radius:20px;color:var(--text-secondary);display:inline-block;font-size:.85rem;padding:.3rem .75rem;transition:all .2s ease}.post-tag:hover{background:var(--gray-border)}.post-hero-image{border-radius:16px;box-shadow:0 4px 20px #00000014;margin-bottom:3rem;overflow:hidden;width:100%}.post-hero-image img{display:block;height:auto;width:100%}.post-body{color:var(--gray-700);font-size:1.1rem;line-height:1.8}.post-body h1{color:var(--text-color);font-size:2rem;font-weight:800;margin:2em 0 1em}.post-body h2{font-size:1.6rem;margin:1.5em 0 .75em}.post-body h2,.post-body h3{color:var(--text-color);font-weight:700}.post-body h3{font-size:1.3rem;margin:1.25em 0 .5em}.post-body p{margin-bottom:1.5em}.post-body img{border-radius:12px;box-shadow:0 4px 12px #00000014;height:auto;margin:2rem 0;max-width:100%}.post-body ol,.post-body ul{margin-bottom:1.5em;padding-left:1.5em}.post-body li{margin-bottom:.5em}.post-body blockquote{background:var(--gray-100);border-left:4px solid var(--secondary-color);border-radius:0 12px 12px 0;color:var(--text-secondary);font-style:italic;margin:2rem 0;padding:1.5rem}.post-body a{color:var(--secondary-color);text-decoration:underline}.post-body a:hover{text-decoration:none}.post-body code,.post-body pre{background:var(--surface-light);border-radius:6px;font-family:Consolas,Monaco,monospace}.post-body code{font-size:.9em;padding:.2em .4em}.post-body pre{margin:1.5rem 0;overflow-x:auto;padding:1.5rem}.post-body pre code{background:none;padding:0}.post-body hr{border:none;border-top:1px solid #e5e5e5;margin:3rem 0}.post-footer{border-top:1px solid var(--surface-lighter);margin-top:4rem;padding-top:2rem}.back-to-list{align-items:center;background:var(--surface-light);border:none;border-radius:50px;color:var(--gray-700);cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:500;gap:.5rem;padding:.75rem 1.25rem;transition:all .2s ease}.back-to-list:hover{background:var(--gray-border)}.related-posts-section{background:var(--gray-100);padding:5rem 1.5rem}.related-posts-container{margin:0 auto;max-width:1200px}.related-title{border-left:4px solid #000;color:var(--text-color);font-size:1.5rem;font-weight:800;margin-bottom:2rem;padding-left:1rem}.related-posts-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(3,1fr)}.related-post-card{background:var(--background-color);border:1px solid var(--gray-border);border-radius:16px;color:inherit;overflow:hidden;text-decoration:none;transition:all .3s ease}.related-post-card:hover{box-shadow:0 16px 32px #00000014;transform:translateY(-8px)}.related-post-thumbnail{background:var(--surface-lighter);height:180px;overflow:hidden;width:100%}.related-post-thumbnail img{height:100%;object-fit:cover;transition:transform .4s ease;width:100%}.related-post-card:hover .related-post-thumbnail img{transform:scale(1.05)}.related-post-info{padding:1.5rem}.related-post-category{color:var(--secondary-color);display:inline-block;font-size:.8rem;font-weight:600;margin-bottom:.5rem}.related-post-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--text-color);display:-webkit-box;font-size:1.1rem;font-weight:700;line-height:1.4;margin:0 0 .75rem;overflow:hidden}.related-post-date{color:var(--text-muted);font-size:.85rem}@media (max-width:1024px){.related-posts-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.blog-detail-container{padding:0 1rem 3rem}.post-meta-bar{gap:.75rem}.post-body{font-size:1rem}.post-body h1{font-size:1.6rem}.post-body h2{font-size:1.4rem}.post-body h3{font-size:1.2rem}.related-posts-section{padding:3rem 1rem}.related-posts-grid{gap:1.5rem;grid-template-columns:1fr}.related-post-thumbnail{height:160px}}.portfolio-page{background-color:var(--background-color);overflow-x:hidden}.portfolio-container{margin:0 auto;max-width:1440px;padding:0 1.5rem 6rem}.reveal{opacity:0;transform:translateY(30px);transition:all .8s cubic-bezier(.16,1,.3,1)}.reveal.active{opacity:1;transform:translateY(0)}.portfolio-filter{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;margin-bottom:4rem}.filter-tab{background:var(--background-color);border:1px solid var(--border-color);border-radius:50px;color:var(--text-secondary);cursor:pointer;font-size:.95rem;font-weight:500;padding:.6rem 1.5rem;transition:all .25s cubic-bezier(.16,1,.3,1)}.filter-tab:hover{border-color:#000;color:var(--text-color)}.filter-tab.active{background:var(--primary-color);border-color:#000;color:#fff}.portfolio-grid{grid-gap:2.5rem;display:grid;gap:2.5rem;grid-template-columns:repeat(3,1fr)}.portfolio-pagination{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:3.5rem}.pagination-btn,.pagination-number{background:var(--background-color);border:1px solid var(--border-color);border-radius:999px;color:var(--text-secondary);cursor:pointer;font-size:.9rem;padding:.5rem .9rem;transition:all .2s ease}.pagination-btn:hover,.pagination-number:hover{border-color:#000;color:var(--text-color)}.pagination-number.active{background:var(--primary-color);border-color:#000;color:#fff;font-weight:600}.pagination-btn:disabled{cursor:not-allowed;opacity:.5}.pagination-numbers{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.portfolio-empty{color:var(--text-secondary);font-size:1.1rem;text-align:center}.portfolio-empty,.portfolio-loading{padding:6rem 2rem}@media (max-width:1024px){.portfolio-grid{gap:2rem;grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.portfolio-container{padding:0 1rem 4rem}.portfolio-filter{gap:.5rem;margin-bottom:3rem}.filter-tab{font-size:.85rem;padding:.5rem 1rem}.portfolio-grid{gap:1.5rem;grid-template-columns:1fr}.portfolio-pagination{gap:.75rem}}@media (max-width:480px){.filter-tab{font-size:.8rem;padding:.4rem .8rem}}.portfolio-detail-page{background-color:var(--background-color);margin:0 auto;max-width:1440px;overflow-x:hidden;padding:4rem 2rem;width:100%}.detail-hero-image{margin:0 auto;max-width:1200px;padding:4rem 1.5rem 0;width:100%}.detail-hero-image img{border-radius:16px;box-shadow:0 4px 24px #00000014;height:auto;max-height:600px;object-fit:cover;width:100%}.detail-container{margin:0 auto;max-width:1200px;padding:0 1.5rem}.detail-header{border-bottom:1px solid var(--surface-lighter);padding:3rem 0 2rem}.detail-title{color:var(--text-color);font-size:2.5rem;font-weight:800;letter-spacing:-.02em;line-height:1.2;margin:0 0 .75rem}.detail-subtitle{color:var(--text-secondary);font-size:1.25rem;line-height:1.5;margin:0}.detail-meta-grid{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:1fr 1fr;padding:2.5rem 0}.meta-column{gap:2rem}.meta-column,.meta-item{display:flex;flex-direction:column}.meta-item{gap:.75rem}.meta-label{color:var(--text-muted);font-size:.9rem;font-weight:600;letter-spacing:.02em;margin:0}.meta-tags{display:flex;flex-wrap:wrap;gap:.5rem}.meta-tag{background:var(--background-color);border:1px solid var(--border-color);border-radius:6px;color:var(--gray-700);display:inline-block;font-size:.9rem;font-weight:500;padding:.5rem 1rem}.detail-client-info{padding:1.5rem 0}.client-row{align-items:baseline;display:flex;gap:2rem}.client-label{color:var(--text-muted);font-size:.9rem;font-weight:600;min-width:80px}.client-value{color:var(--text-color);font-size:1rem;font-weight:600}.detail-divider{border:none;border-top:1px solid var(--gray-border);margin:1rem 0 3rem}.detail-content{padding-bottom:4rem}.content-body{color:var(--gray-700);font-size:1.1rem;line-height:1.8;max-width:100%}.content-body h1{color:var(--text-color);font-size:2rem;font-weight:800;letter-spacing:-.02em;margin:2.5em 0 1em}.content-body h2{font-size:1.5rem;margin:2em 0 .75em}.content-body h2,.content-body h3{color:var(--text-color);font-weight:700}.content-body h3{font-size:1.25rem;margin:1.5em 0 .5em}.content-body p{margin-bottom:1.5em}.content-body img{border-radius:12px;box-shadow:0 4px 16px #00000014;height:auto;margin:2rem 0;max-width:100%}.content-body ol,.content-body ul{margin-bottom:1.5em;padding-left:1.5em}.content-body li{margin-bottom:.5em}.content-body blockquote{background:var(--gray-100);border-left:4px solid var(--secondary-color);border-radius:0 12px 12px 0;color:var(--text-secondary);font-style:italic;margin:2rem 0;padding:1.25rem 1.5rem}.content-body a{color:var(--secondary-color);text-decoration:underline;text-underline-offset:2px}.content-body a:hover{text-decoration:none}.content-body hr{border:none;border-top:1px solid var(--gray-border);margin:3rem 0}.content-body code,.content-body pre{background:var(--surface-light);border-radius:6px;font-family:Consolas,Monaco,monospace}.content-body code{font-size:.9em;padding:.2em .4em}.content-body pre{margin:1.5rem 0;overflow-x:auto;padding:1.25rem}.content-body pre code{background:none;padding:0}.detail-related{border-top:1px solid var(--gray-border);padding:4rem 0}.related-section-title{color:var(--text-color);font-size:1.25rem;font-weight:700;letter-spacing:-.01em;margin:0 0 2rem}.related-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(3,1fr)}.portfolio-loading{color:var(--text-secondary);font-size:1.1rem}.portfolio-loading,.portfolio-not-found{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:60vh;padding:4rem 1.5rem;text-align:center}.portfolio-not-found h1{color:var(--text-color);font-size:2rem;margin-bottom:1rem}.portfolio-not-found p{color:var(--text-secondary);font-size:1.1rem;margin-bottom:2rem}.back-button{background:var(--primary-color);border-radius:50px;color:#fff;display:inline-block;font-weight:600;padding:1rem 2rem;text-decoration:none}@media (max-width:1024px){.detail-hero-image{padding:1.5rem 1.5rem 0}.detail-hero-image img{max-height:500px}.detail-title{font-size:2rem}.detail-meta-grid{gap:2rem}.related-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.detail-hero-image{padding:1rem 1rem 0}.detail-hero-image img{border-radius:12px;max-height:400px}.detail-container{padding:0 1rem}.detail-header{padding:2rem 0 1.5rem}.detail-title{font-size:1.75rem}.detail-subtitle{font-size:1.1rem}.detail-meta-grid{gap:1.5rem;grid-template-columns:1fr;padding:2rem 0}.meta-column{gap:1.5rem}.meta-tag{font-size:.85rem;padding:.4rem .85rem}.client-row{flex-direction:column;gap:.5rem}.detail-divider{margin:.5rem 0 2rem}.content-body{font-size:1rem}.content-body h1{font-size:1.5rem}.content-body h2{font-size:1.3rem}.content-body h3{font-size:1.15rem}.detail-related{padding:3rem 0}.related-grid{gap:1.5rem;grid-template-columns:1fr}.detail-cta{padding:3.5rem 1rem}.cta-content h2{font-size:1.5rem}.cta-content p{font-size:1rem}}@media (max-width:480px){.detail-hero-image img{border-radius:10px;max-height:300px}.detail-title{font-size:1.5rem}.detail-subtitle{font-size:1rem}.meta-label{font-size:.85rem}.meta-tag{font-size:.8rem;padding:.35rem .75rem}.related-section-title{font-size:1.1rem}}.admin-layout{background:linear-gradient(135deg,#f4f6fb,#fff 45%,#fff);display:grid;grid-template-columns:260px 1fr;min-height:100vh}.admin-sidebar{background:#fff;box-shadow:0 4px 20px #00000014;color:#0f172a;display:flex;flex-direction:column;gap:2rem;padding:2.5rem 1.75rem}.admin-sidebar-brand{align-items:center;display:flex;flex-direction:column;font-size:1.1rem;font-weight:700;gap:.75rem;letter-spacing:.03em}.admin-brand-logo{height:auto;width:80px}.admin-brand-label{color:#000;display:block;font-size:.9rem;font-weight:600}.admin-sidebar-footer{display:flex;justify-content:center;margin-top:auto}.admin-logout-button{background:#e2e8f0;border:none;border-radius:12px;color:#1f2937;cursor:pointer;font-weight:600;padding:.75rem 1rem;transition:background .2s ease,transform .2s ease;width:100%}.admin-logout-button:hover{background:#cbd5f5;transform:translateY(-1px)}.admin-login{align-items:center;background:radial-gradient(circle at top,#e7edff 0,#f8fafc 45%,#fff 100%);display:flex;justify-content:center;min-height:100vh;padding:2rem 1.5rem}.admin-login-card{background:#fff;border:1px solid #0f172a14;border-radius:22px;box-shadow:0 24px 40px #0f172a26;padding:2.5rem;text-align:center;width:min(420px,100%)}.admin-login-logo{height:auto;margin-bottom:1.25rem;width:72px}.admin-login-title{color:#0f172a;font-size:1.75rem;margin:0 0 .5rem}.admin-login-subtitle{color:#64748b;font-size:.95rem;margin:0 0 2rem}.admin-login-form{display:flex;flex-direction:column;gap:.75rem;text-align:left}.admin-login-label{color:#1f2937;font-size:.85rem;font-weight:600}.admin-login-input{border:1px solid #e2e8f0;border-radius:12px;font-size:.95rem;padding:.75rem 1rem;transition:border-color .2s ease,box-shadow .2s ease}.admin-login-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26;outline:none}.admin-login-error{color:#dc2626;font-size:.85rem;margin:0}.admin-login-button{background:#1d4ed8;border:none;border-radius:12px;box-shadow:0 12px 22px #1d4ed84d;color:#fff;cursor:pointer;font-weight:600;margin-top:.5rem;padding:.85rem 1rem;transition:transform .2s ease,box-shadow .2s ease}.admin-login-button:hover{box-shadow:0 16px 28px #1d4ed859;transform:translateY(-1px)}.admin-login-button:disabled{background:#94a3b8;box-shadow:none;cursor:not-allowed;transform:none}.admin-login-footnote{color:#94a3b8;font-size:.8rem;margin:1.5rem 0 0}@media (max-width:960px){.admin-layout{grid-template-columns:1fr}.admin-sidebar{align-items:center;flex-direction:row;justify-content:space-between}.admin-nav{flex-direction:row;flex-wrap:wrap;justify-content:flex-end}.admin-sidebar-footer{margin-top:0}}@media (max-width:720px){.admin-login-card{padding:2rem 1.5rem}.admin-sidebar{align-items:flex-start;flex-direction:column}.admin-nav{flex-direction:column;width:100%}.admin-sidebar-footer{width:100%}}.admin-nav{display:flex;flex-direction:column;gap:.75rem}.admin-nav-link{background:#0000;border-radius:12px;color:#64748b;font-weight:500;padding:.75rem 1rem;text-decoration:none;transition:all .2s ease}.admin-nav-link:hover{background:#0000000a;color:#0f172a}.admin-nav-link.is-active{background:#1d4ed8;box-shadow:0 12px 25px #1d4ed859;color:#fff}.admin-content{display:flex;flex-direction:column;gap:2rem;padding:2.5rem 3rem}.admin-content-header{display:flex;flex-direction:column;gap:.5rem}.admin-content-title{color:var(--text-primary);font-size:1.75rem;font-weight:700;margin:0}.admin-content-subtitle{color:var(--text-secondary);font-size:1rem}.admin-content-body{display:flex;flex:1 1;flex-direction:column;gap:1.5rem}.admin-panel{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.admin-panel-card{background:#fff;border:1px solid var(--border-light);border-radius:18px;box-shadow:0 14px 30px #0f172a14;padding:1.5rem}.admin-panel-label{color:var(--text-muted);font-size:.95rem;margin:0 0 .5rem}.admin-panel-value{color:var(--text-primary);font-size:1.6rem}.admin-panel-subtext{color:var(--text-light);font-size:.9rem;margin:.75rem 0 0}.admin-section-card{background:#fff;border:1px solid var(--border-subtle);border-radius:20px;box-shadow:0 18px 32px #0f172a14;padding:2rem}.admin-section-head{align-items:flex-start;display:flex;gap:1.5rem;justify-content:space-between;margin-bottom:1.5rem}.admin-action-button{align-items:center;background:#06f;border-radius:12px;box-shadow:0 10px 20px #1d4ed833;color:#fff;cursor:pointer;display:inline-flex;font-weight:600;padding:.75rem 1.25rem;text-decoration:none;transition:transform .2s ease,box-shadow .2s ease}.admin-action-button__text{display:flex}.admin-muted{color:var(--text-muted);margin:0 0 1rem}.admin-error{color:var(--error-color);margin:0 0 1rem}.admin-section-card h2{color:var(--text-primary);font-size:1.35rem;margin:0 0 .75rem}.admin-section-card p{color:var(--text-secondary);line-height:1.5;margin:0 0 1rem}.admin-card-footnote{color:var(--text-light);display:inline-block;font-size:.85rem}.admin-portfolio-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(6,minmax(0,1fr));margin-bottom:1rem}.admin-portfolio-card{animation:none;opacity:1}.admin-portfolio-card .portfolio-card__overlay{background:#0f172a8c}.admin-portfolio-card .portfolio-card__tags{flex-wrap:wrap}.html-editor{background:#fff;border:none;border-radius:0;box-shadow:none;overflow:visible}.html-editor-toolbar{align-items:center;background:#f8f9fa;border-bottom:1px solid #e5e5e5;display:flex;flex-wrap:wrap;gap:.5rem;padding:1rem}.html-editor-mode-buttons{align-items:center;display:flex;gap:.25rem;margin-right:1rem}.html-editor-mode-button{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;display:flex;font-size:.875rem;gap:.25rem;padding:.5rem .75rem;transition:all .2s ease}.html-editor-mode-button:hover{background:#f3f4f6;border-color:#9ca3af}.html-editor-mode-button.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.html-editor-mode-button.active:hover{background:#2563eb;border-color:#2563eb}.html-editor-button{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;display:flex;font-size:.875rem;gap:.25rem;padding:.5rem .75rem;transition:all .2s ease}.html-editor-button:hover{background:#f3f4f6;border-color:#9ca3af}.html-editor-button:active{background:#e5e7eb}.html-editor-group{align-items:center;display:flex;gap:.5rem}.html-editor-select{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:.875rem;padding:.45rem .6rem}.html-editor-color{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:#fff;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;height:34px;padding:0;width:34px}.html-editor-color::-webkit-color-swatch-wrapper{padding:2px}.html-editor-color::-webkit-color-swatch{border:none;border-radius:6px}.html-editor-color::-moz-color-swatch{border:none;border-radius:6px}.html-editor-container{border:none;border-radius:0;box-shadow:none;position:relative}.html-editor-content{word-wrap:break-word;background:#0000;border:none;color:#374151;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:.875rem;line-height:1.6;min-height:600px;overflow-wrap:break-word;padding:1.25rem;width:100%}.html-editor-content,.html-editor-content:focus,.html-editor:focus-within{box-shadow:none;outline:none}.html-editor-content:empty:before{color:#9ca3af;content:attr(data-placeholder);pointer-events:none}.html-editor-content.resizing{pointer-events:none;-webkit-user-select:none;user-select:none}.html-editor-content.resizing *{pointer-events:none}.html-editor-content h1{font-size:2rem;font-weight:700;line-height:1.2;margin:1rem 0 .5rem}.html-editor-content h2{font-size:1.75rem;font-weight:700;line-height:1.3;margin:1rem 0 .5rem}.html-editor-content h3{font-size:1.5rem;font-weight:700;line-height:1.4;margin:1rem 0 .5rem}.html-editor-content p{margin:.5rem 0}.html-editor-content blockquote{border-left:4px solid #d1d5db;color:#6b7280;font-style:italic;margin:1rem 0;padding-left:1rem}.html-editor-content ol,.html-editor-content ul{margin:.5rem 0;padding-left:1.5rem}.html-editor-content li{margin:.25rem 0}.html-editor-content a{color:#3b82f6;text-decoration:underline}.html-editor-content a:hover{color:#2563eb}.html-editor-content strong{font-weight:700}.html-editor-content em{font-style:italic}.html-editor-content u{text-decoration:underline}.html-editor-content img{border-radius:4px;cursor:pointer;height:auto;margin:.5rem 0;max-width:100%}.html-editor-content .editor-image{min-height:50px;min-width:50px;transition:outline .2s ease}.html-editor-content .editor-image:hover{outline:2px solid #3b82f6;outline-offset:2px}.html-editor-content .editor-image[selected]{box-shadow:0 0 8px #3b82f64d;outline:2px solid #3b82f6;outline-offset:2px}.resize-handles{pointer-events:none;position:absolute;z-index:10}.resize-handles .resize-handle{background:#3b82f6;border:2px solid #fff;border-radius:50%;box-shadow:0 0 4px #0003;cursor:pointer;height:12px;pointer-events:auto;position:absolute;transition:all .1s ease;width:12px}.resize-handles .resize-handle:hover{background:#2563eb;transform:scale(1.2)}.resize-handles .resize-handle:active{background:#1d4ed8;transform:scale(1.1)}.resize-handles .nw{cursor:nw-resize;left:-6px;top:-6px}.resize-handles .ne{cursor:ne-resize;right:-6px;top:-6px}.resize-handles .sw{bottom:-6px;cursor:sw-resize;left:-6px}.resize-handles .se{bottom:-6px;cursor:se-resize;right:-6px}.html-editor-preview{background:#f8f9fa;border-radius:0;border-top:1px solid #e5e5e5;box-shadow:none}.html-editor-preview-content{color:#374151;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:.875rem;line-height:1.6;min-height:400px;padding:1.25rem}.html-editor-preview-content img{border-radius:4px;height:auto;margin:.5rem 0;max-width:100%}.html-editor-preview-content p{margin:0 0 1rem}.html-editor-preview-content p:last-child{margin-bottom:0}.portfolio-form{display:flex;flex-direction:column;gap:1.5rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-size:.9rem;font-weight:600;margin:0}.form-input,.form-label{color:var(--text-primary)}.form-input{background:#fff;border:1px solid var(--border-light);border-radius:8px;font-size:.95rem;padding:.75rem;transition:border-color .2s ease}.form-input:focus{border-color:#1d4ed8;box-shadow:0 0 0 3px #1d4ed81a;outline:none}.form-input::placeholder{color:var(--text-muted)}.thumbnail-upload{display:flex;flex-direction:column;gap:.75rem}.thumbnail-input{display:none}.thumbnail-label{align-items:center;background:#f8f9fa;border:1px solid var(--border-light);border-radius:8px;color:var(--text-secondary);cursor:pointer;display:inline-flex;font-size:.9rem;justify-content:center;padding:.75rem 1rem;transition:all .2s ease}.thumbnail-label:hover{background:#e9ecef;border-color:#1d4ed8}.thumbnail-preview{border:1px solid var(--border-light);border-radius:8px;max-width:200px;overflow:hidden;position:relative;width:100%}.thumbnail-preview img{display:block;height:auto;width:100%}.thumbnail-delete-btn{align-items:center;background:#ef4444e6;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:700;height:24px;justify-content:center;line-height:1;opacity:0;position:absolute;right:8px;top:8px;transition:opacity .2s ease,transform .2s ease;width:24px}.thumbnail-preview:hover .thumbnail-delete-btn{opacity:1}.thumbnail-delete-btn:hover{background:#ef4444;transform:scale(1.1)}.form-actions{border-top:1px solid var(--border-light);display:flex;gap:.75rem;justify-content:flex-end;padding-top:1rem}.form-button{border:none;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:600;padding:.75rem 1.5rem;text-decoration:none;transition:all .2s ease}.form-button:disabled{cursor:not-allowed;opacity:.6}.form-button-primary{background:#1d4ed8;color:#fff}.form-button-primary:hover:not(:disabled){background:#1e40af}.form-button-secondary{background:#f8f9fa;border:1px solid var(--border-light);color:var(--text-secondary)}.form-button-secondary:hover:not(:disabled){background:#e9ecef}.admin-blog-list{list-style:none;margin:0;padding:0}.admin-blog-list>li{border-bottom:1px solid #e5e5e5}.admin-blog-list>li:last-child{border-bottom:none}.admin-blog-item{color:inherit;display:flex;gap:2rem;padding:2rem 0;text-decoration:none;transition:opacity .2s ease}.admin-blog-item:hover{opacity:.7}.admin-blog-text{display:flex;flex:1 1;flex-direction:column;justify-content:center;min-width:0}.admin-blog-title{color:#000;font-size:1.25rem;font-weight:600;line-height:1.5;margin:0 0 .75rem}.admin-blog-excerpt,.admin-blog-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.admin-blog-excerpt{color:#666;font-size:.95rem;line-height:1.7;margin:0 0 1rem}.admin-blog-meta{align-items:center;color:#888;display:flex;font-size:.875rem;gap:.5rem}.admin-blog-separator{color:#ccc}.admin-blog-author,.admin-blog-category,.admin-blog-date{color:#888}.admin-blog-thumbnail{background:#f2f2f2;border-radius:8px;flex-shrink:0;height:140px;overflow:hidden;width:200px}.admin-blog-thumbnail img{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.admin-blog-item:hover .admin-blog-thumbnail img{transform:scale(1.05)}@media (max-width:1024px){.admin-blog-thumbnail{height:110px;width:160px}}@media (max-width:768px){.admin-blog-item{flex-direction:column-reverse;gap:1rem;padding:1.5rem 0}.admin-blog-thumbnail{height:200px;width:100%}.admin-blog-title{font-size:1.1rem}.admin-blog-excerpt{font-size:.9rem}}@media (max-width:480px){.admin-blog-thumbnail{height:180px}}.not-found-page{align-items:center;background-color:#fff;display:flex;justify-content:center;min-height:100vh;padding:2rem 0}.error-section{padding:4rem 0;width:100%}.error-content{margin:0 auto;max-width:600px;text-align:center}.error-icon{color:#000;display:inline-block;margin-bottom:3rem}.error-title{color:#000;font-size:2.5rem;font-weight:700;margin:0 0 1.5rem}.error-description{color:#666;font-size:1.1rem;line-height:1.6;margin-bottom:3rem}.error-actions{display:flex;gap:1rem;justify-content:center}.error-button{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;flex-shrink:0;font-size:1.1rem;font-weight:600;justify-content:center;padding:1rem 2rem;text-decoration:none;width:180px}.error-button-primary{background-color:#000;border:2px solid #000;color:#fff}.error-button-secondary{background-color:initial;border:2px solid #000;color:#000}@media (max-width:768px){.error-icon svg{height:120px;width:120px}.error-title{font-size:2rem}.error-description{font-size:1rem}.error-actions{gap:.75rem}.error-button{font-size:1rem;padding:.875rem 1.25rem;width:140px}}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}
/*# sourceMappingURL=main.2f6855ae.css.map*/