:root{--color-bg: #fafafa;--color-bg-alt: #ffffff;--color-bg-elevated: #ffffff;--color-bg-card: #ffffff;--color-text: #1a1a1a;--color-text-secondary: #555555;--color-text-muted: #888888;--color-border: #e5e5e5;--color-border-light: #f0f0f0;--color-primary: #0066cc;--color-primary-hover: #0052a3;--color-primary-light: rgba(0, 102, 204, .08);--color-accent: #0066cc;--color-accent-glow: rgba(0, 102, 204, .12);--color-success: #059669;--color-error: #dc2626;--color-warning: #d97706;--font-display: "Clash Display", -apple-system, BlinkMacSystemFont, sans-serif;--font-body: "Satoshi", -apple-system, BlinkMacSystemFont, sans-serif;--font-family: "Satoshi", -apple-system, BlinkMacSystemFont, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--font-size-4xl: 2.5rem;--font-size-5xl: 3rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.15;--line-height-snug: 1.25;--line-height-normal: 1.6;--line-height-relaxed: 1.75;--letter-spacing-tight: -.02em;--letter-spacing-wide: .02em;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--space-32: 8rem;--max-width: 1100px;--max-width-narrow: 720px;--max-width-wide: 1280px;--navbar-height: 72px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 10px;--radius-xl: 14px;--radius-2xl: 20px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .1);--shadow-xl: 0 16px 40px rgba(0, 0, 0, .12);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal: 400;--z-tooltip: 500}[data-theme=dark]{--color-bg: #0a0a0a;--color-bg-alt: #111111;--color-bg-elevated: #161616;--color-bg-card: #141414;--color-text: #f5f5f5;--color-text-secondary: #a0a0a0;--color-text-muted: #666666;--color-border: #262626;--color-border-light: #1f1f1f;--color-primary: #3b82f6;--color-primary-hover: #2563eb;--color-primary-light: rgba(59, 130, 246, .12);--color-accent: #3b82f6;--color-accent-glow: rgba(59, 130, 246, .15);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .4);--shadow-xl: 0 16px 40px rgba(0, 0, 0, .5)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%}body{font-family:var(--font-body);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--color-text);background-color:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit;color:inherit}button{cursor:pointer;border:none;background:none}a{color:inherit;text-decoration:none}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);letter-spacing:var(--letter-spacing-tight)}p{max-width:65ch}.skip-link{position:absolute;top:-100%;left:50%;transform:translate(-50%);background:var(--color-primary);color:#fff;padding:var(--space-3) var(--space-6);border-radius:var(--radius-md);z-index:var(--z-tooltip);font-weight:var(--font-weight-medium);transition:top var(--transition-fast)}.skip-link:focus{top:var(--space-4)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.section-title{font-family:var(--font-display);font-size:var(--font-size-3xl);font-weight:var(--font-weight-semibold);color:var(--color-text);margin-bottom:var(--space-6);letter-spacing:var(--letter-spacing-tight)}@media (min-width: 768px){.section-title{font-size:var(--font-size-4xl)}}.container{width:100%;max-width:var(--max-width);margin-inline:auto;padding-inline:var(--space-4)}@media (min-width: 768px){.container{padding-inline:var(--space-6)}}@media (min-width: 1024px){.container{padding-inline:var(--space-8)}}.fade-in{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}.fade-in--visible{opacity:1;transform:translateY(0)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}::selection{background-color:var(--color-primary);color:#fff}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);min-height:44px;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);border-radius:var(--radius-md);transition:all var(--transition-base);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none}.btn--primary{background-color:var(--color-primary);color:#fff;border:none}.btn--primary:hover{background-color:var(--color-primary-hover)}.btn--secondary{background-color:transparent;color:var(--color-text);border:1px solid var(--color-border)}.btn--secondary:hover{border-color:var(--color-text)}.btn:disabled{opacity:.6;cursor:not-allowed}.navbar-safe-area{position:fixed;top:0;left:0;right:0;height:env(safe-area-inset-top,0px);background:var(--color-bg);z-index:10001}.navbar{position:fixed;top:env(safe-area-inset-top,0px);left:0;right:0;height:var(--navbar-height);background:var(--color-bg);z-index:10000;transition:background .2s ease,box-shadow .2s ease}.navbar--scrolled{background:#fafafaf2;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--color-border)}[data-theme=dark] .navbar--scrolled{background:#0a0a0af2}.navbar__inner{display:flex;align-items:center;justify-content:space-between;height:100%;max-width:var(--max-width-wide);margin:0 auto;padding:0 var(--space-4)}@media (min-width: 768px){.navbar__inner{padding:0 var(--space-8)}}.navbar__logo{display:flex;align-items:center;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);z-index:10}.navbar__logo-text{color:var(--color-text)}.navbar__logo-accent{color:var(--color-primary)}.navbar__desktop-nav{display:none}@media (min-width: 768px){.navbar__desktop-nav{display:block}}.navbar__desktop-menu{display:flex;align-items:center;gap:var(--space-8);list-style:none;margin:0;padding:0}.navbar__desktop-link{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);transition:color .2s ease;position:relative}.navbar__desktop-link:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--color-primary);transition:width .3s ease}.navbar__desktop-link:hover{color:var(--color-text)}.navbar__desktop-link:hover:after{width:100%}.navbar__actions{display:flex;align-items:center;gap:var(--space-3)}.navbar__theme-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md);color:var(--color-text-secondary);background:transparent;border:none;cursor:pointer;transition:background .2s ease,color .2s ease}.navbar__theme-btn:hover{background:var(--color-bg-alt);color:var(--color-text)}.navbar__cta-btn{display:none;padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:#fff;background:var(--color-primary);border-radius:var(--radius-md);transition:background .2s ease,transform .2s ease,box-shadow .2s ease}.navbar__cta-btn:hover{background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px -2px var(--color-accent-glow)}@media (min-width: 768px){.navbar__cta-btn{display:block}}.navbar__hamburger{display:flex;flex-direction:column;justify-content:center;align-items:center;width:40px;height:40px;gap:6px;background:transparent;border:none;cursor:pointer;padding:0;z-index:10002}@media (min-width: 768px){.navbar__hamburger{display:none}}.navbar__hamburger-line{display:block;width:24px;height:2px;background:var(--color-text);transition:transform .3s ease,opacity .3s ease}.navbar__hamburger--active .navbar__hamburger-line:nth-child(1){transform:translateY(8px) rotate(45deg)}.navbar__hamburger--active .navbar__hamburger-line:nth-child(2){opacity:0}.navbar__hamburger--active .navbar__hamburger-line:nth-child(3){transform:translateY(-8px) rotate(-45deg)}.mobile-menu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;z-index:9998}.mobile-menu-overlay--visible{opacity:1;visibility:visible}.mobile-menu{position:fixed;top:calc(var(--navbar-height) + env(safe-area-inset-top,0px));right:0;width:100%;max-width:320px;height:calc(100vh - var(--navbar-height) - env(safe-area-inset-top,0px));height:calc(100dvh - var(--navbar-height) - env(safe-area-inset-top,0px));background:var(--color-bg-alt);transform:translate(100%);transition:transform .3s ease;z-index:9999;overflow-y:auto;-webkit-overflow-scrolling:touch;border-left:1px solid var(--color-border)}.mobile-menu--open{transform:translate(0)}.mobile-menu__list{list-style:none;margin:0;padding:var(--space-6) 0;padding-bottom:calc(var(--space-6) + env(safe-area-inset-bottom,0px))}.mobile-menu__item{opacity:0;transform:translate(20px);transition:opacity .3s ease,transform .3s ease}.mobile-menu--open .mobile-menu__item{opacity:1;transform:translate(0)}.mobile-menu__link{display:block;padding:var(--space-5) var(--space-6);font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);color:var(--color-text);border-bottom:1px solid var(--color-border);transition:color .2s ease,background .2s ease}.mobile-menu__link:hover,.mobile-menu__link:active{color:var(--color-primary);background:var(--color-primary-light)}.mobile-menu__item:last-child .mobile-menu__link{border-bottom:none}.service-card{position:relative;display:flex;flex-direction:column;padding:var(--space-8);background-color:var(--color-bg-elevated);border:1px solid var(--color-border-light);border-radius:var(--radius-2xl);transition:transform .4s cubic-bezier(.34,1.56,.64,1),box-shadow .4s cubic-bezier(.4,0,.2,1),border-color .3s ease;overflow:hidden}.service-card:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:inherit;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-warm) 100%);opacity:0;z-index:-1;transition:opacity .3s ease}.service-card:after{content:"";position:absolute;top:1px;right:1px;bottom:1px;left:1px;background-color:var(--color-bg-elevated);border-radius:calc(var(--radius-2xl) - 1px);z-index:-1}.service-card:hover{border-color:transparent;box-shadow:0 20px 60px -12px #00000040,0 0 40px -15px var(--color-accent-glow);transform:translateY(-8px) scale(1.02)}.service-card:hover:before{opacity:1}[data-theme=dark] .service-card:hover{box-shadow:0 20px 60px -12px #00000080,0 0 50px -15px var(--color-accent-glow)}.service-card--popular{border-color:var(--color-primary);box-shadow:0 0 30px -10px var(--color-accent-glow)}.service-card--popular:before{opacity:.3}.service-card__badge{position:absolute;top:var(--space-4);right:var(--space-4);padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:#fff;background-color:var(--color-primary);border-radius:var(--radius-full)}.service-card__icon{width:56px;height:56px;margin-bottom:var(--space-5);color:var(--color-primary);padding:var(--space-3);background:var(--color-primary-light);border-radius:var(--radius-lg);transition:transform .3s cubic-bezier(.34,1.56,.64,1),background-color .3s ease}.service-card:hover .service-card__icon{transform:scale(1.1) rotate(5deg);background:linear-gradient(135deg,var(--color-primary-light) 0%,rgba(255,107,53,.1) 100%)}.service-card__title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-2)}.service-card__description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-4);flex-grow:1}.service-card__features{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-6)}.service-card__features li{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.service-card__features svg{flex-shrink:0;color:var(--color-success)}.service-card__footer{display:flex;align-items:center;justify-content:center;padding-top:var(--space-4);margin-top:auto;border-top:1px solid var(--color-border-light)}.service-card__cta{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:#fff;background:var(--color-primary);border-radius:var(--radius-md);transition:background .2s ease,transform .2s ease,gap .2s ease}.service-card__cta:hover{background:var(--color-primary-hover);transform:translateY(-2px);gap:var(--space-3)}.project-card{display:flex;flex-direction:column;background-color:var(--color-bg-elevated);border:1px solid var(--color-border-light);border-radius:var(--radius-xl);overflow:hidden;position:relative;transition:transform .4s cubic-bezier(.34,1.56,.64,1),box-shadow .4s cubic-bezier(.4,0,.2,1),border-color .3s ease}.project-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;padding:1px;background:linear-gradient(135deg,var(--color-primary) 0%,transparent 50%,var(--color-warm) 100%);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .3s ease}.project-card:hover{border-color:transparent;box-shadow:0 20px 60px -12px #0000004d,0 0 40px -10px var(--color-accent-glow);transform:translateY(-12px) scale(1.02)}.project-card:hover:before{opacity:1}[data-theme=dark] .project-card:hover{box-shadow:0 20px 60px -12px #0009,0 0 60px -10px var(--color-accent-glow)}.project-card__image{position:relative;aspect-ratio:16 / 10;overflow:hidden}.project-card__placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;position:relative;background:linear-gradient(135deg,var(--project-color) 0%,color-mix(in srgb,var(--project-color) 70%,black) 100%);overflow:hidden}.project-card__placeholder:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:repeating-linear-gradient(45deg,transparent,transparent 10px,rgba(255,255,255,.03) 10px,rgba(255,255,255,.03) 20px);opacity:.5}.project-card__placeholder:after{content:"";position:absolute;top:-50%;right:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.15) 0%,transparent 70%);opacity:0;transition:opacity .5s ease,transform .5s ease}.project-card:hover .project-card__placeholder:after{opacity:1;transform:translate(-25%,25%)}.project-card__initials{font-family:var(--font-display);font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);color:#fff;opacity:.95;text-shadow:0 2px 20px rgba(0,0,0,.3);position:relative;z-index:1;transition:transform .3s ease,opacity .3s ease}.project-card:hover .project-card__initials{transform:scale(.95);opacity:0}.project-card__overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background-color:#000c;opacity:0;transition:opacity var(--transition-base);z-index:2}.project-card:hover .project-card__overlay{opacity:1}.project-card__view{padding:var(--space-3) var(--space-6);font-weight:var(--font-weight-medium);color:#fff;background-color:var(--color-primary);border-radius:var(--radius-md);transform:translateY(10px);transition:all var(--transition-base)}.project-card:hover .project-card__view{transform:translateY(0)}.project-card__view:hover{background-color:var(--color-primary-hover)}.project-card__content{display:flex;flex-direction:column;padding:var(--space-5)}.project-card__category{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-primary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-2)}.project-card__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-2)}.project-card__description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-4);display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.project-card__tech{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:auto}.project-card__tag{padding:var(--space-1) var(--space-2);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);background-color:var(--color-bg);border-radius:var(--radius-sm)}.contact__form-group{margin-bottom:var(--space-5)}.contact__label{display:block;margin-bottom:var(--space-2);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text)}.contact__label span{color:var(--color-error)}.contact__input,.contact__select,.contact__textarea{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--font-size-base);color:var(--color-text);background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-fast)}.contact__input:focus,.contact__select:focus,.contact__textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.contact__input::placeholder,.contact__textarea::placeholder{color:var(--color-text-muted)}.contact__select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23737373' stroke-width='2'%3E%3Cpolyline points='6,9 12,15 18,9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;background-size:16px;padding-right:var(--space-10)}.contact__textarea{resize:vertical;min-height:120px}.contact__status-message{padding:var(--space-3) var(--space-4);margin-bottom:var(--space-4);font-size:var(--font-size-sm);border-radius:var(--radius-md)}.contact__status-message--success{color:#065f46;background-color:#d1fae5;border:1px solid #6ee7b7}.contact__status-message--error{color:#991b1b;background-color:#fee2e2;border:1px solid #fca5a5}[data-theme=dark] .contact__status-message--success{color:#34d399;background-color:#064e3b;border-color:#065f46}[data-theme=dark] .contact__status-message--error{color:#f87171;background-color:#7f1d1d;border-color:#991b1b}.contact__submit{width:100%;padding:var(--space-4)}@media (min-width: 768px){.contact__submit{width:auto}}.contact__spinner{display:inline-block;width:16px;height:16px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .8s linear infinite}.footer{padding:var(--space-16) 0 var(--space-8);background-color:var(--color-bg-alt);border-top:1px solid var(--color-border-light)}.footer__container{max-width:var(--max-width);margin-inline:auto;padding-inline:var(--space-4)}@media (min-width: 768px){.footer__container{padding-inline:var(--space-8)}}.footer__main{display:grid;gap:var(--space-10);margin-bottom:var(--space-10)}@media (min-width: 768px){.footer__main{grid-template-columns:1fr 2fr;gap:var(--space-16)}}.footer__brand{max-width:280px}.footer__logo{display:inline-flex;align-items:center;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-4)}.footer__logo-text{color:var(--color-text)}.footer__logo-accent{color:var(--color-primary)}.footer__tagline{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-4)}.footer__location{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-muted)}.footer__links{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-8)}@media (min-width: 640px){.footer__links{grid-template-columns:repeat(3,1fr)}}.footer__column h4{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text);margin-bottom:var(--space-4)}.footer__column ul{display:flex;flex-direction:column;gap:var(--space-3)}.footer__column a{font-size:var(--font-size-sm);color:var(--color-text-secondary);transition:color var(--transition-fast)}.footer__column a:hover{color:var(--color-primary)}.footer__bottom{display:flex;flex-direction:column;gap:var(--space-2);padding-top:var(--space-8);border-top:1px solid var(--color-border-light);text-align:center}@media (min-width: 640px){.footer__bottom{flex-direction:row;justify-content:space-between;text-align:left}}.footer__copyright,.footer__credit{font-size:var(--font-size-sm);color:var(--color-text-muted)}.footer__back-to-top{position:fixed;bottom:var(--space-6);right:var(--space-6);display:flex;align-items:center;justify-content:center;width:48px;height:48px;background-color:var(--color-primary);color:#fff;border-radius:var(--radius-full);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(20px);transition:all var(--transition-base);z-index:var(--z-fixed)}.footer__back-to-top--visible{opacity:1;visibility:visible;transform:translateY(0)}.footer__back-to-top:hover{background-color:var(--color-primary-hover);transform:translateY(-4px)}.hero{min-height:85vh;display:flex;align-items:center;padding-top:calc(var(--navbar-height) + var(--space-12));padding-bottom:var(--space-16);background:var(--color-bg)}.hero__container{width:100%;max-width:var(--max-width-narrow);margin-inline:auto;padding-inline:var(--space-4)}@media (min-width: 768px){.hero__container{padding-inline:var(--space-6)}}.hero__content{text-align:center}@media (min-width: 768px){.hero__content{text-align:left}}.hero__title{font-family:var(--font-display);font-size:clamp(2rem,5vw,3rem);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);letter-spacing:var(--letter-spacing-tight);color:var(--color-text);margin-bottom:var(--space-6)}.hero__description{font-size:var(--font-size-lg);color:var(--color-text-secondary);line-height:var(--line-height-relaxed);max-width:520px;margin-bottom:var(--space-8)}@media (max-width: 767px){.hero__description{margin-inline:auto}}.hero__cta-group{display:flex;flex-wrap:wrap;gap:var(--space-4)}@media (max-width: 767px){.hero__cta-group{justify-content:center}}.hero__cta{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-4) var(--space-6);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);border-radius:var(--radius-md);transition:all var(--transition-base);cursor:pointer}.hero__cta--primary{background:var(--color-primary);color:#fff;border:none}.hero__cta--primary:hover{background:var(--color-primary-hover)}.hero__cta--primary svg{transition:transform var(--transition-base)}.hero__cta--primary:hover svg{transform:translate(4px)}.hero__cta--secondary{background:transparent;color:var(--color-text);border:1px solid var(--color-border)}.hero__cta--secondary:hover{border-color:var(--color-text)}.work{padding:var(--space-20) 0;background-color:var(--color-bg-alt)}.work__container{max-width:var(--max-width-wide);margin-inline:auto;padding-inline:var(--space-4)}@media (min-width: 768px){.work__container{padding-inline:var(--space-6)}}.work__header{margin-bottom:var(--space-10)}.case-study{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-md)}@media (min-width: 900px){.case-study{display:grid;grid-template-columns:1.3fr 1fr}}@media (min-width: 1100px){.case-study{grid-template-columns:1.5fr 1fr}}.case-study__image{position:relative;aspect-ratio:16 / 10;background-color:var(--color-border-light);overflow:hidden}@media (min-width: 900px){.case-study__image{aspect-ratio:auto;min-height:100%}}.case-study__image img{width:100%;height:100%;object-fit:cover}.case-study__image-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);font-family:var(--font-display);font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);color:#fff;opacity:1}.case-study__image img:not([src=""])+.case-study__image-placeholder{opacity:0}.case-study__content{padding:var(--space-8)}@media (min-width: 768px){.case-study__content{padding:var(--space-10)}}@media (min-width: 900px){.case-study__content{display:flex;flex-direction:column;justify-content:center}}.case-study__header{margin-bottom:var(--space-8)}.case-study__title{font-family:var(--font-display);font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-2)}.case-study__tagline{font-size:var(--font-size-base);color:var(--color-text-secondary)}.case-study__details{margin-bottom:var(--space-8)}.case-study__block{margin-bottom:var(--space-6)}.case-study__block:last-child{margin-bottom:0}.case-study__block h4{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);color:var(--color-primary);margin-bottom:var(--space-2)}.case-study__block p{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:var(--line-height-relaxed)}.case-study__link{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:#fff;background:var(--color-primary);border-radius:var(--radius-md);transition:all var(--transition-base)}.case-study__link:hover{background:var(--color-primary-hover)}.case-study__link svg{transition:transform var(--transition-base)}.case-study__link:hover svg{transform:translate(2px,-2px)}.work__cta{text-align:center;margin-top:var(--space-12)}.work__cta p{font-size:var(--font-size-lg);color:var(--color-text-secondary);margin-bottom:var(--space-5);margin-inline:auto}.about{padding:var(--space-20) 0;background-color:var(--color-bg)}.about__container{max-width:var(--max-width-narrow);margin-inline:auto;padding-inline:var(--space-4)}@media (min-width: 768px){.about__container{padding-inline:var(--space-6)}}.about__header{margin-bottom:var(--space-8)}.about__content{display:grid;gap:var(--space-10)}@media (min-width: 768px){.about__content{grid-template-columns:1.5fr 1fr;gap:var(--space-12);align-items:start}}.about__text p{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:var(--line-height-relaxed);margin-bottom:var(--space-4)}.about__lead{font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);color:var(--color-text)}.about__skills{display:flex;flex-direction:column;gap:var(--space-3)}.about__skills li{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text);background-color:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:var(--radius-md)}.about__skills svg{flex-shrink:0;color:var(--color-primary)}.contact{padding:var(--space-20) 0;background-color:var(--color-bg-alt)}.contact__container{max-width:var(--max-width-narrow);margin-inline:auto;padding-inline:var(--space-4)}@media (min-width: 768px){.contact__container{padding-inline:var(--space-6)}}.contact__header{margin-bottom:var(--space-10)}.contact__header .section-subtitle{margin-top:var(--space-2)}.contact__content{display:grid;gap:var(--space-10)}@media (min-width: 768px){.contact__content{grid-template-columns:1fr 1.5fr;gap:var(--space-12)}}.contact__info-card{padding:var(--space-6);background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.contact__info-card h3{font-family:var(--font-display);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-5)}.contact__details{display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-6)}.contact__details li{display:flex;align-items:center;gap:var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.contact__details svg{flex-shrink:0;color:var(--color-primary)}.contact__details a{color:var(--color-text-secondary);transition:color var(--transition-fast)}.contact__details a:hover{color:var(--color-primary)}.contact__social h4{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-3)}.contact__social-links{display:flex;gap:var(--space-3);margin-bottom:var(--space-6)}.contact__social-link{display:flex;align-items:center;justify-content:center;width:44px;height:44px;color:var(--color-text-secondary);background-color:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-base)}.contact__social-link:hover{color:var(--color-primary);border-color:var(--color-primary)}.contact__availability{display:flex;align-items:center;gap:var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.contact__status{width:8px;height:8px;background-color:var(--color-success);border-radius:50%;animation:pulse 2s infinite}.contact__form{padding:var(--space-6);background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.case-study__preview{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-6);background:linear-gradient(135deg,#f0f4f8,#e2e8f0);min-height:400px}[data-theme=dark] .case-study__preview{background:linear-gradient(135deg,#1a1a2e,#16213e)}@media (min-width: 900px){.case-study__preview{padding:var(--space-8);min-height:520px}}@media (min-width: 1100px){.case-study__preview{padding:var(--space-10);min-height:580px}}.device-toggle{display:flex;gap:var(--space-2);padding:var(--space-1);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-full);margin-bottom:var(--space-5)}.device-toggle__btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-muted);background:transparent;border:none;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-base)}.device-toggle__btn:hover{color:var(--color-text)}.device-toggle__btn--active{color:#fff;background:var(--color-primary)}.device-toggle__btn--active:hover{color:#fff}.device-frame{position:relative;background:#1a1a1a;border-radius:var(--radius-lg);padding:var(--space-2);box-shadow:var(--shadow-lg),0 0 0 1px #0000001a;transition:width .4s cubic-bezier(.4,0,.2,1),max-width .4s cubic-bezier(.4,0,.2,1),border-radius .4s cubic-bezier(.4,0,.2,1),padding .4s cubic-bezier(.4,0,.2,1)}.device-frame--desktop{width:100%;max-width:560px;border-radius:var(--radius-lg)}@media (min-width: 1100px){.device-frame--desktop{max-width:620px}}.device-frame--desktop:before{content:"";display:block;height:24px;background:#2a2a2a;border-radius:var(--radius-md) var(--radius-md) 0 0;margin:calc(var(--space-2) * -1);margin-bottom:var(--space-2);position:relative}.device-frame--desktop:after{content:"";position:absolute;top:10px;left:50%;transform:translate(-50%);display:flex;gap:6px;width:48px;height:8px;background:radial-gradient(circle at 8px 4px,#ff5f57 4px,transparent 4px),radial-gradient(circle at 24px 4px,#febc2e 4px,transparent 4px),radial-gradient(circle at 40px 4px,#28c840 4px,transparent 4px)}.device-frame--mobile{width:220px;max-height:460px;border-radius:28px;padding:var(--space-3)}@media (min-width: 1100px){.device-frame--mobile{width:240px;max-height:520px;border-radius:32px}}.device-frame--mobile:before{content:"";display:block;width:80px;height:6px;background:#3a3a3a;border-radius:var(--radius-full);margin:0 auto var(--space-3)}.device-frame__screen{position:relative;overflow:hidden;border-radius:var(--radius-md);background:#000}.device-frame--mobile .device-frame__screen{border-radius:24px;aspect-ratio:9 / 19.5}.device-frame--desktop .device-frame__screen{aspect-ratio:16 / 10}.device-frame__video{width:100%;height:100%;object-fit:cover;display:block}.case-study__expand-btn{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-4);padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base)}.case-study__expand-btn:hover{color:var(--color-text);border-color:var(--color-text)}@media (min-width: 900px){.case-study__expand-btn{display:none}}.video-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;display:flex;align-items:center;justify-content:center;padding:var(--space-4);background:#000000e6;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.video-modal__content{position:relative;display:flex;flex-direction:column;align-items:center;max-width:100%;max-height:100%}.video-modal__close{position:absolute;top:-48px;right:0;display:flex;align-items:center;justify-content:center;width:40px;height:40px;color:#fff;background:#ffffff1a;border:none;border-radius:var(--radius-full);cursor:pointer;transition:background var(--transition-base)}.video-modal__close:hover{background:#fff3}.video-modal__toggle{display:flex;gap:var(--space-2);padding:var(--space-1);background:#ffffff1a;border-radius:var(--radius-full);margin-bottom:var(--space-5)}.video-modal__toggle .device-toggle__btn{color:#fff9}.video-modal__toggle .device-toggle__btn:hover{color:#fff}.video-modal__toggle .device-toggle__btn--active{color:#fff;background:var(--color-primary)}.video-modal__frame{background:#1a1a1a;border-radius:var(--radius-lg);padding:var(--space-2);box-shadow:0 25px 50px -12px #00000080}.video-modal__frame--desktop{width:90vw;max-width:900px;border-radius:var(--radius-lg)}.video-modal__frame--desktop:before{content:"";display:block;height:32px;background:#2a2a2a;border-radius:var(--radius-md) var(--radius-md) 0 0;margin:calc(var(--space-2) * -1);margin-bottom:var(--space-2)}.video-modal__frame--mobile{width:320px;max-width:90vw;border-radius:36px;padding:var(--space-4)}.video-modal__frame--mobile:before{content:"";display:block;width:80px;height:6px;background:#3a3a3a;border-radius:var(--radius-full);margin:0 auto var(--space-3)}.video-modal__frame video{width:100%;border-radius:var(--radius-md);display:block}.video-modal__frame--mobile video{border-radius:20px;aspect-ratio:9 / 19.5;object-fit:cover}.video-modal__frame--desktop video{aspect-ratio:16 / 10;object-fit:cover}
