:root{--color-primary:#0078D4;--color-primary-light:#50E6FF;--color-primary-dark:#003D5B;--color-accent:#D83B01;--color-accent-hover:#c33401;--color-white:#FFFFFF;--color-bg:#FFFFFF;--color-bg-alt:#E8F4FD;--color-bg-gradient-start:#FFFFFF;--color-bg-gradient-end:#F0F7FF;--color-border:#E8E8E8;--color-text:#333333;--color-text-light:#666666;--color-text-muted:#999999;--color-error:#dc3545;--color-error-bg:#f8d7da;--color-error-border:#f5c6cb;--color-success:#155724;--color-success-bg:#d4edda;--color-success-border:#c3e6cb;--font-heading:'Poppins',sans-serif;--font-body:'Inter',sans-serif;--font-size-base:16px;--line-height-base:1.6;--line-height-heading:1.2;--font-size-h1:2.5rem;--font-size-h2:2rem;--font-size-h3:1.5rem;--font-size-h4:1.25rem;--font-size-h5:1.125rem;--font-size-h6:1rem;--font-size-body:1rem;--font-size-small:0.875rem;--font-size-xs:0.75rem;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--font-weight-extrabold:800;--spacing-xs:0.5rem;--spacing-sm:1rem;--spacing-md:2rem;--spacing-lg:4rem;--spacing-xl:6rem;--spacing-xxl:8rem;--radius-sm:4px;--radius-md:8px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-sm:0 2px 4px rgba(0, 0, 0, 0.1);--shadow-md:0 4px 6px rgba(0, 0, 0, 0.1);--shadow-lg:0 10px 15px rgba(0, 0, 0, 0.1);--shadow-xl:0 20px 25px rgba(0, 0, 0, 0.15);--transition-fast:0.15s ease;--transition-base:0.3s ease;--transition-slow:0.5s ease;--z-base:1;--z-dropdown:100;--z-sticky:200;--z-fixed:300;--z-modal-backdrop:400;--z-modal:500;--z-popover:600;--z-tooltip:700;--pattern-dot:url("data:image/svg+xml,%3Csvg width='20' height='20' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='1' cy='1' r='1' fill='%23e8e8e8'/%3E%3C/svg%3E")}[data-theme=dark]{--color-bg:#1a1a1a;--color-bg-alt:#1E3A4D;--color-bg-gradient-start:#1a1a1a;--color-bg-gradient-end:#0a1929;--color-border:#404040;--color-text:#e0e0e0;--color-text-light:#a0a0a0;--color-text-muted:#707070;--color-primary-dark:#50E6FF;--shadow-sm:0 2px 4px rgba(0, 0, 0, 0.3);--shadow-md:0 4px 6px rgba(0, 0, 0, 0.3);--shadow-lg:0 10px 15px rgba(0, 0, 0, 0.3);--shadow-xl:0 20px 25px rgba(0, 0, 0, 0.4);--pattern-dot:url("data:image/svg+xml,%3Csvg width='20' height='20' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='1' cy='1' r='1' fill='%23333333'/%3E%3C/svg%3E")}.floating-controls{position:fixed;right:20px;bottom:24px;display:flex;flex-direction:column;align-items:center;gap:16px;z-index:var(--z-tooltip)}.language-toggle{width:50px;height:50px;border-radius:var(--radius-full);background:var(--color-bg);border:2px solid var(--color-border);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);transition:all var(--transition-base);position:relative}.language-toggle:hover{transform:scale(1.1);border-color:var(--color-primary);box-shadow:var(--shadow-lg)}.language-toggle:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.language-toggle:active{transform:scale(1.05)}.language-toggle__label{position:absolute;font-size:.75rem;font-weight:var(--font-weight-semibold);color:var(--color-primary);transition:opacity var(--transition-fast),transform var(--transition-base)}.language-toggle__label--en{opacity:0;transform:rotate(180deg)}.language-toggle__label--bg{opacity:1;transform:rotate(0)}[data-language=bg] .language-toggle__label--en{opacity:1;transform:rotate(0)}[data-language=bg] .language-toggle__label--bg{opacity:0;transform:rotate(180deg)}.theme-toggle{width:50px;height:50px;border-radius:var(--radius-full);background:var(--color-bg);border:2px solid var(--color-border);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);transition:all var(--transition-base)}.theme-toggle:hover{transform:scale(1.1);border-color:var(--color-primary);box-shadow:var(--shadow-lg)}.theme-toggle:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.theme-toggle:active{transform:scale(1.05)}.theme-toggle__icon{width:24px;height:24px;transition:opacity var(--transition-fast),transform var(--transition-base);position:absolute}.theme-toggle__icon--sun{color:var(--color-accent);opacity:1;transform:rotate(0)}.theme-toggle__icon--moon{color:var(--color-primary);opacity:0;transform:rotate(180deg)}[data-theme=dark] .theme-toggle__icon--sun{opacity:0;transform:rotate(180deg)}[data-theme=dark] .theme-toggle__icon--moon{opacity:1;transform:rotate(0)}@media (max-width:768px){.floating-controls{right:16px;bottom:20px}.language-toggle,.theme-toggle{width:44px;height:44px}.language-toggle__label{font-size:.7rem}.theme-toggle__icon{width:20px;height:20px}}@media (max-width:480px){.floating-controls{right:16px;bottom:16px}.language-toggle,.theme-toggle{width:40px;height:40px}.language-toggle__label{font-size:.65rem}.theme-toggle__icon{width:18px;height:18px}}.main-nav{position:fixed;top:0;left:0;right:0;background:rgba(255,255,255,.95);backdrop-filter:blur(10px);box-shadow:var(--shadow-md);z-index:var(--z-fixed);transform:translateY(-100%);transition:transform var(--transition-base)}.main-nav.visible{transform:translateY(0)}.main-nav__container{display:flex;justify-content:space-between;align-items:center;padding:1rem var(--spacing-md);max-width:1200px}.nav-logo{font-size:1.5rem;font-weight:var(--font-weight-bold);color:var(--color-primary);text-decoration:none;font-family:var(--font-heading);transition:color var(--transition-base);display:flex;align-items:center;gap:var(--spacing-xs)}.nav-logo__picture{display:block}.nav-logo__image{width:32px;height:auto}.nav-logo:focus,.nav-logo:hover{color:var(--color-primary-light)}.nav-logo:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.nav-menu{display:flex;list-style:none;gap:var(--spacing-sm);margin:0;padding:0}.nav-link{color:var(--color-text);text-decoration:none;padding:.5rem 1rem;border-radius:var(--radius-sm);transition:all var(--transition-fast);position:relative;font-weight:var(--font-weight-medium)}.nav-link:hover{color:var(--color-primary);background:var(--color-bg-alt)}.nav-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.nav-link.active{color:var(--color-primary);font-weight:var(--font-weight-semibold)}.nav-link.active::after{content:'';position:absolute;bottom:0;left:1rem;right:1rem;height:2px;background:var(--color-primary);border-radius:1px}[data-theme=dark] .main-nav{background:rgba(26,26,26,.95)}[data-theme=dark] .contact-primary-cta{box-shadow:0 8px 20px rgba(216,59,1,.4)}[data-theme=dark] .contact-primary-cta:hover{box-shadow:0 12px 30px rgba(216,59,1,.5)}[data-theme=dark] .contact-info-card{background:var(--color-bg-alt);border-color:var(--color-border)}[data-theme=dark] .contact-info-card--location .contact-info-card__icon-wrapper{background:rgba(80,230,255,.15)}[data-theme=dark] .contact-info-card--social .contact-info-card__icon-wrapper{background:rgba(216,59,1,.15)}[data-theme=dark] .contact-social-icon{box-shadow:0 2px 8px rgba(216,59,1,.3)}[data-theme=dark] .contact-social-icon:hover{box-shadow:0 4px 12px rgba(216,59,1,.5)}[data-theme=dark] .footer{background-color:#0d1b24}[data-theme=dark] .footer__heading{color:#50e6ff}[data-theme=dark] .footer__content{border-bottom-color:rgba(255,255,255,.15)}[data-theme=dark] .footer__social a{background:rgba(255,255,255,.15)}[data-theme=dark] .footer__social a:focus,[data-theme=dark] .footer__social a:hover{background:#50e6ff;color:#0d1b24}@media (max-width:768px){.main-nav__container{padding:.75rem var(--spacing-sm)}.nav-logo{font-size:1.25rem}.nav-menu{gap:.25rem}.nav-link{padding:.5rem .75rem;font-size:var(--font-size-small)}.nav-link.active::after{left:.75rem;right:.75rem}.nav-link:focus-visible{outline-offset:1px}.nav-link.active:focus-visible::after{display:none}.nav-link.active:focus-visible{background:rgba(0,120,212,.1)}}@media (max-width:480px){.nav-menu{gap:.125rem}.nav-link{padding:.5rem .5rem;font-size:.75rem}.nav-link.active::after{display:none}.nav-link.active{background:rgba(0,120,212,.1);border-radius:var(--radius-sm)}}.about,.btn,.contact,.contact-info-card,.contact-primary-cta,.contact-social-icon,.expertise-list li,.footer,.hero,.portfolio,.portfolio-card,.service-card,.services,.skill-badge,.stat,body{transition:background-color var(--transition-base),color var(--transition-base),border-color var(--transition-base)}*,::after,::before{margin:0;padding:0;box-sizing:border-box}html{font-size:var(--font-size-base);scroll-behavior:smooth}body{font-family:var(--font-body);font-size:var(--font-size-body);font-weight:var(--font-weight-normal);line-height:var(--line-height-base);color:var(--color-text);background:linear-gradient(to bottom,var(--color-bg-gradient-start),var(--color-bg-gradient-end));background-attachment:fixed;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img{display:block;max-width:100%;height:auto}picture{display:block}img[loading=lazy]{opacity:0;transition:opacity var(--transition-base)}img[loading=lazy].loaded{opacity:1}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:var(--font-weight-bold);line-height:var(--line-height-heading);color:var(--color-primary-dark);margin-bottom:var(--spacing-sm)}h1{font-size:var(--font-size-h1);font-weight:var(--font-weight-extrabold)}h2{font-size:var(--font-size-h2);font-weight:var(--font-weight-bold)}h3{font-size:var(--font-size-h3);font-weight:var(--font-weight-semibold)}h4{font-size:var(--font-size-h4);font-weight:var(--font-weight-semibold)}h5{font-size:var(--font-size-h5);font-weight:var(--font-weight-medium)}h6{font-size:var(--font-size-h6);font-weight:var(--font-weight-medium)}p{margin-bottom:var(--spacing-sm)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-base)}a:hover{color:var(--color-primary-light)}a:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}small{font-size:var(--font-size-small)}.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-bg-gradient-start) 0,var(--color-bg-gradient-end) 100%);position:relative;overflow:hidden}.hero__decorations{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}.hero__shape{position:absolute;opacity:.1;animation:float 6s ease-in-out infinite}.hero__shape--1{width:300px;height:300px;background:var(--color-primary);top:10%;left:-100px;animation-delay:0s}.hero__shape--2{width:200px;height:200px;background:var(--color-primary-light);top:60%;right:-50px;animation-delay:2s}.hero__shape--3{width:150px;height:150px;background:var(--color-accent);bottom:20%;left:20%;animation-delay:4s}.hero__container{position:relative;z-index:1;width:100%;max-width:1200px;padding:var(--spacing-md);display:flex;flex-direction:column;align-items:center}.hero__content{text-align:center;display:flex;flex-direction:column;align-items:center}.hero__image{width:200px;height:200px;border-radius:var(--radius-full);object-fit:cover;border:4px solid var(--color-primary);box-shadow:var(--shadow-lg);margin-bottom:var(--spacing-md);animation:fadeIn 1s ease-out}.hero__logo{width:clamp(140px,30vw,220px);margin-bottom:var(--spacing-sm)}.hero__logo-image{width:100%;height:auto}.hero__title{font-family:var(--font-heading);font-size:clamp(2.5rem, 5vw, 4rem);color:var(--color-primary-dark);margin-bottom:var(--spacing-xs);animation:fadeInUp 1s ease-out .2s both}.hero__subtitle{font-size:clamp(1.25rem, 3vw, 1.75rem);color:var(--color-primary);margin-bottom:var(--spacing-md);animation:fadeInUp 1s ease-out .4s both;font-weight:var(--font-weight-medium)}.hero__tagline{font-size:clamp(1rem, 2vw, 1.25rem);color:var(--color-text-light);max-width:600px;margin:0 auto var(--spacing-md);animation:fadeInUp 1s ease-out .6s both;line-height:1.6}.btn{display:inline-block;padding:1rem 2rem;border-radius:var(--radius-md);font-weight:var(--font-weight-semibold);text-decoration:none;transition:all var(--transition-base);cursor:pointer;font-family:var(--font-body);font-size:var(--font-size-body);border:none}.btn--primary{background-color:var(--color-accent);color:var(--color-white);box-shadow:var(--shadow-md);animation:fadeInUp 1s ease-out .8s both}.btn--primary:focus,.btn--primary:hover{background-color:var(--color-accent-hover);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn--primary:active{transform:translateY(0);box-shadow:var(--shadow-md)}.hero__cta{margin-bottom:var(--spacing-md)}.hero__scroll-indicator{position:absolute;bottom:var(--spacing-md);left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;cursor:pointer;animation:fadeIn 2s ease-out 1s both}.hero__scroll-arrow{width:24px;height:24px;border-left:2px solid var(--color-primary);border-bottom:2px solid var(--color-primary);transform:rotate(-45deg);animation:bounce 2s infinite}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,100%,20%,50%,80%{transform:rotate(-45deg) translateY(0)}40%{transform:rotate(-45deg) translateY(-10px)}60%{transform:rotate(-45deg) translateY(-5px)}}main{max-width:1200px;margin:var(--spacing-md) auto;padding:0 var(--spacing-sm)}section{scroll-margin-top:80px}header{scroll-margin-top:80px}.section-divider{position:relative;height:60px;margin-bottom:var(--spacing-md);overflow:hidden;line-height:0}.section-divider--wave{background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 120' preserveAspectRatio='none'%3E%3Cpath d='M321.39,56.44c58-10.79,114.16-30.13,172-41.86,82.39-16.72,168.19-17.73,250.45-.39C823.78,31,906.67,72,985.66,92.83c70.05,18.48,146.53,26.09,214.34,3V0H0V27.35A600.21,600.21,0,0,0,321.39,56.44Z' fill='%23ffffff'/%3E%3C/svg%3E") no-repeat;background-size:cover}[data-theme=dark] .section-divider--wave{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 120' preserveAspectRatio='none'%3E%3Cpath d='M321.39,56.44c58-10.79,114.16-30.13,172-41.86,82.39-16.72,168.19-17.73,250.45-.39C823.78,31,906.67,72,985.66,92.83c70.05,18.48,146.53,26.09,214.34,3V0H0V27.35A600.21,600.21,0,0,0,321.39,56.44Z' fill='%231a1a1a'/%3E%3C/svg%3E")}@media (max-width:768px){.section-divider{height:40px}}.footer{background-color:var(--color-primary-dark);color:var(--color-white);padding:var(--spacing-lg) 0 var(--spacing-md);margin-top:var(--spacing-xl)}.footer__content{display:grid;grid-template-columns:1fr;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:1px solid rgba(255,255,255,.1)}.footer__section{text-align:center}.footer__heading{font-size:1.25rem;margin-bottom:var(--spacing-md);color:var(--color-primary-light);font-family:var(--font-heading);font-weight:var(--font-weight-semibold)}.footer__text{line-height:1.6;color:rgba(255,255,255,.8);margin-bottom:0}.footer__nav{list-style:none;padding:0;margin:0}.footer__nav li{margin-bottom:var(--spacing-xs)}.footer__nav a{color:rgba(255,255,255,.8);text-decoration:none;transition:color var(--transition-fast);display:inline-block;padding:.25rem 0}.footer__nav a:focus,.footer__nav a:hover{color:var(--color-primary-light)}.footer__nav a:focus-visible{outline:2px solid var(--color-primary-light);outline-offset:2px}.footer__social{display:flex;gap:var(--spacing-sm);justify-content:center}.footer__social a{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:rgba(255,255,255,.1);border-radius:var(--radius-full);color:var(--color-white);transition:all var(--transition-base);text-decoration:none}.footer__social a:focus,.footer__social a:hover{background:var(--color-primary-light);transform:translateY(-3px);box-shadow:var(--shadow-md)}.footer__social a:focus-visible{outline:2px solid var(--color-primary-light);outline-offset:2px}.footer__social svg{width:20px;height:20px;fill:currentColor}.footer__bottom{text-align:center;color:rgba(255,255,255,.6);font-size:.875rem}.footer__copyright{margin-bottom:var(--spacing-xs)}.footer__tagline{margin-bottom:0;font-style:italic}.about{padding:var(--spacing-lg) 0;background-image:var(--pattern-dot);background-size:20px 20px;background-position:0 0}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-sm)}.section__title{font-size:clamp(2rem, 4vw, 3rem);color:var(--color-primary-dark);text-align:center;margin-bottom:var(--spacing-lg);position:relative}.section__title::after{content:'';display:block;width:60px;height:4px;background:var(--color-primary);margin:var(--spacing-sm) auto 0;border-radius:2px}.about__content{max-width:900px;margin:0 auto}.about__bio{font-size:1.125rem;line-height:1.8;color:var(--color-text);margin-bottom:var(--spacing-lg)}.about__bio p{margin-bottom:var(--spacing-sm)}.about__stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.stat{text-align:center;padding:var(--spacing-md);background:var(--color-bg-alt);border-radius:var(--radius-md);border:2px solid var(--color-border);transition:transform var(--transition-base),box-shadow var(--transition-base)}.stat:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.stat__number{display:block;font-size:2.5rem;font-weight:700;color:var(--color-primary);font-family:var(--font-heading)}.stat__label{display:block;font-size:.875rem;color:var(--color-text-light);margin-top:var(--spacing-xs)}.about__expertise,.about__skills{margin-bottom:var(--spacing-lg)}.about__expertise h3,.about__skills h3{color:var(--color-primary-dark);margin-bottom:var(--spacing-md);font-size:1.5rem}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--spacing-sm);margin-top:var(--spacing-md)}.skill-badge{display:inline-block;padding:.5rem 1rem;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));color:#fff;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;text-align:center;text-shadow:1px 1px 0 #000;transition:transform var(--transition-base),box-shadow var(--transition-base);box-shadow:var(--shadow-sm)}.skill-badge:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.expertise-list{list-style:none;margin-top:var(--spacing-md);padding:0}.expertise-list li{padding:var(--spacing-sm);margin-bottom:var(--spacing-xs);border-left:3px solid var(--color-accent);padding-left:var(--spacing-md);background:var(--color-bg-alt);border-radius:0 var(--radius-sm) var(--radius-sm) 0;transition:transform var(--transition-base),box-shadow var(--transition-base)}.expertise-list li:hover{transform:translateX(5px);box-shadow:var(--shadow-sm)}.services{padding:var(--spacing-lg) 0;background:linear-gradient(180deg,var(--color-bg-alt) 0,var(--color-bg) 100%)}.section__subtitle{text-align:center;font-size:1.125rem;color:var(--color-text-light);margin-top:calc(var(--spacing-md) * -1);margin-bottom:var(--spacing-lg);max-width:600px;margin-left:auto;margin-right:auto}.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-md);margin-top:var(--spacing-lg)}.service-card{background:var(--color-bg);border-radius:var(--radius-lg);padding:var(--spacing-lg);text-align:center;transition:all var(--transition-base);border:1px solid var(--color-border);box-shadow:0 1px 3px rgba(0,0,0,.05),0 4px 6px rgba(0,0,0,.05);position:relative;overflow:hidden}.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--color-primary),var(--color-primary-light));transform:scaleX(1);transform-origin:left;opacity:.5;transition:opacity var(--transition-base),transform var(--transition-base)}.service-card:nth-child(3n+1)::before{background:linear-gradient(90deg,var(--color-primary),var(--color-primary-light))}.service-card:nth-child(3n+2)::before{background:linear-gradient(90deg,var(--color-accent),#ff6b35)}.service-card:nth-child(3n+3)::before{background:linear-gradient(90deg,#10b981,#34d399)}.service-card:hover{transform:translateY(-8px);box-shadow:0 10px 20px rgba(0,0,0,.1),0 6px 6px rgba(0,0,0,.05);border-color:var(--color-primary-light)}.service-card:hover::before{opacity:1}[data-theme=dark] .service-card{box-shadow:0 1px 3px rgba(0,0,0,.2),0 4px 6px rgba(0,0,0,.2)}[data-theme=dark] .service-card:hover{box-shadow:0 10px 20px rgba(0,0,0,.3),0 6px 6px rgba(0,0,0,.2)}.service-card:focus-within{outline:2px solid var(--color-primary);outline-offset:2px}.service-card__icon{width:60px;height:60px;margin:0 auto var(--spacing-md);background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;transition:transform var(--transition-base)}.service-card:hover .service-card__icon{transform:scale(1.1) rotate(5deg)}.service-card__icon svg{width:32px;height:32px;fill:currentColor}.service-card__title{font-size:1.5rem;color:var(--color-primary-dark);margin-bottom:var(--spacing-sm);font-family:var(--font-heading)}.service-card__description{color:var(--color-text);line-height:1.6;font-size:1rem}@media (min-width:768px){:root{--font-size-h1:3rem;--font-size-h2:2.5rem;--font-size-h3:1.75rem;--font-size-h4:1.5rem;--font-size-h5:1.25rem}main{padding:0 var(--spacing-md)}.hero__image{width:250px;height:250px}.hero__tagline{max-width:700px}.container{padding:0 var(--spacing-md)}.about__bio{font-size:1.25rem}.skills-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.services-grid{grid-template-columns:repeat(2,1fr)}.section__subtitle{font-size:1.25rem}}@media (min-width:1024px){:root{--font-size-h1:3.5rem;--font-size-h2:3rem;--font-size-h3:2rem;--font-size-h4:1.5rem;--font-size-body:1.125rem}main{margin:var(--spacing-lg) auto}.hero__image{width:280px;height:280px}.hero__tagline{max-width:800px}.btn{padding:1.125rem 2.5rem;font-size:1.125rem}.about{padding:var(--spacing-xl) 0}.skills-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.stat__number{font-size:3rem}.services{padding:var(--spacing-xl) 0}.services-grid{grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg)}.service-card__icon{width:70px;height:70px}.service-card__icon svg{width:36px;height:36px}.service-card__description{font-size:1.125rem}}.portfolio{padding:var(--spacing-lg) 0;background-image:var(--pattern-dot);background-size:20px 20px;background-position:0 0}.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--spacing-lg);margin-top:var(--spacing-lg)}.portfolio-card{background:var(--color-bg);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:transform var(--transition-base),box-shadow var(--transition-base);border:1px solid var(--color-border)}.portfolio-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}.portfolio-card:focus-within{outline:2px solid var(--color-primary);outline-offset:2px}.portfolio-card__image{position:relative;overflow:hidden;height:250px;background:var(--color-bg-alt)}.portfolio-card__image picture{width:100%;height:100%;position:relative;z-index:1}.portfolio-card__image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow),opacity var(--transition-base)}.portfolio-card__image.blur-load{background-size:cover;background-position:center}.portfolio-card__image.blur-load::before{content:'';position:absolute;inset:0;background:inherit;filter:blur(18px);transform:scale(1.1);opacity:1;transition:opacity var(--transition-base)}.portfolio-card__image.blur-load img{opacity:0}.portfolio-card__image.blur-load.loaded::before{opacity:0}.portfolio-card__image.blur-load.loaded img{opacity:1}.portfolio-card:hover .portfolio-card__image img{transform:scale(1.1)}.portfolio-card__overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,120,212,.9);display:flex;align-items:center;justify-content:center;opacity:0;z-index:2;transition:opacity var(--transition-base)}.portfolio-card:nth-child(3n+1) .portfolio-card__overlay{background:rgba(0,120,212,.9)}.portfolio-card:nth-child(3n+2) .portfolio-card__overlay{background:rgba(216,59,1,.9)}.portfolio-card:nth-child(3n+3) .portfolio-card__overlay{background:rgba(0,61,91,.9)}.portfolio-card:hover .portfolio-card__overlay{opacity:1}.portfolio-card__content{padding:var(--spacing-md)}.portfolio-card__title{font-size:1.5rem;color:var(--color-primary-dark);margin-bottom:var(--spacing-sm);font-family:var(--font-heading)}.portfolio-card__description{color:var(--color-text);line-height:1.6;margin-bottom:var(--spacing-md)}.portfolio-card__tags{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.tag{display:inline-block;padding:.25rem .75rem;background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.75rem;color:var(--color-text-light);transition:all var(--transition-fast)}.tag:hover{background:var(--color-primary);color:var(--color-white);border-color:var(--color-primary)}.btn--sm{padding:.5rem 1rem;font-size:.875rem}@media (min-width:768px){.portfolio-grid{grid-template-columns:repeat(2,1fr)}.portfolio-card__image{height:280px}}@media (min-width:1024px){.portfolio{padding:var(--spacing-xl) 0}.portfolio-grid{grid-template-columns:repeat(3,1fr);gap:var(--spacing-md)}.portfolio-card__image{height:300px}.portfolio-card__title{font-size:1.75rem}.portfolio-card__description{font-size:1.125rem}.tag{font-size:.875rem}}.contact{padding:var(--spacing-lg) 0;background-image:var(--pattern-dot);background-size:20px 20px;background-position:0 0}.contact-wrapper{display:flex;flex-direction:column;gap:var(--spacing-lg);margin-top:var(--spacing-lg)}.contact-primary-cta{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background:linear-gradient(135deg,var(--color-accent) 0,var(--color-primary) 100%);border-radius:var(--radius-lg);box-shadow:0 8px 20px rgba(216,59,1,.25);transition:all .3s cubic-bezier(.4, 0, .2, 1);text-decoration:none;position:relative;overflow:hidden;min-height:120px}.contact-primary-cta::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(255,255,255,.1) 0,rgba(255,255,255,0) 100%);opacity:0;transition:opacity var(--transition-base)}.contact-primary-cta:hover{transform:translateY(-5px) scale(1.02);box-shadow:0 12px 30px rgba(216,59,1,.35)}.contact-primary-cta:hover::before{opacity:1}.contact-primary-cta:active{transform:translateY(-2px) scale(1.01)}.contact-primary-cta:focus-visible{outline:3px solid var(--color-primary-light);outline-offset:4px}.contact-primary-cta__icon{width:48px;height:48px;color:var(--color-white);flex-shrink:0;z-index:1}.contact-primary-cta__content{display:flex;flex-direction:column;gap:.25rem;min-width:0;z-index:1}.contact-primary-cta__email{font-size:1.5rem;font-weight:var(--font-weight-bold);color:var(--color-white);font-family:var(--font-heading);line-height:1.2;overflow-wrap:break-word}.contact-primary-cta__subtext{font-size:1rem;color:rgba(255,255,255,.9);font-weight:var(--font-weight-normal)}.contact-info-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-md)}.contact-info-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--color-bg);border-radius:var(--radius-md);border:2px solid var(--color-border);box-shadow:var(--shadow-sm);transition:all var(--transition-base);position:relative;min-height:140px}.contact-info-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:var(--radius-md) 0 0 var(--radius-md);transition:width var(--transition-base)}.contact-info-card--location::before{background:var(--color-primary)}.contact-info-card--social::before{background:var(--color-accent)}.contact-info-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.contact-info-card--location:hover{border-color:var(--color-primary)}.contact-info-card--social:hover{border-color:var(--color-accent)}.contact-info-card:hover::before{width:6px}.contact-info-card__icon-wrapper{width:60px;height:60px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform var(--transition-base)}.contact-info-card--location .contact-info-card__icon-wrapper{background:rgba(0,120,212,.1)}.contact-info-card--social .contact-info-card__icon-wrapper{background:rgba(216,59,1,.1)}.contact-info-card:hover .contact-info-card__icon-wrapper{transform:scale(1.1) rotate(5deg)}.contact-info-card__icon{width:32px;height:32px;flex-shrink:0}.contact-info-card--location .contact-info-card__icon{color:var(--color-primary)}.contact-info-card--social .contact-info-card__icon{color:var(--color-accent)}.contact-info-card__content{flex:1}.contact-info-card h3{font-size:1.25rem;color:var(--color-primary-dark);margin-bottom:var(--spacing-xs);font-family:var(--font-heading);font-weight:var(--font-weight-semibold)}.contact-info-card p{color:var(--color-text);margin-bottom:0;font-size:1rem}@media (max-width:480px){.contact-primary-cta{gap:var(--spacing-sm);padding:var(--spacing-sm);min-height:auto}.contact-primary-cta__icon{width:40px;height:40px}.contact-primary-cta__email{font-size:1.25rem}.contact-primary-cta__subtext{font-size:.95rem}.contact-info-grid{gap:var(--spacing-sm)}.contact-info-card{padding:var(--spacing-sm);gap:var(--spacing-sm);min-height:auto}.contact-info-card__icon-wrapper{width:52px;height:52px}.contact-info-card__icon{width:28px;height:28px}.contact-info-card h3{font-size:1.125rem}.contact-info-card p{font-size:.95rem}.contact-social-links{gap:.5rem}.contact-social-icon{width:40px;height:40px}.contact-social-icon svg{width:20px;height:20px}}.contact-social-links{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-xs)}.contact-social-icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--color-accent);color:var(--color-white);border-radius:var(--radius-full);transition:all var(--transition-base);text-decoration:none}.contact-social-icon:hover{transform:scale(1.15) rotate(5deg);box-shadow:0 4px 12px rgba(216,59,1,.4);background:var(--color-accent-hover)}.contact-social-icon:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.contact-social-icon svg{width:22px;height:22px}.contact-form{background:var(--color-bg);padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--color-border)}.form-group{margin-bottom:var(--spacing-md)}.form-group label{display:block;font-weight:var(--font-weight-semibold);color:var(--color-text);margin-bottom:var(--spacing-xs);font-family:var(--font-body)}.required{color:var(--color-accent)}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:2px solid var(--color-border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:1rem;color:var(--color-text);background:var(--color-bg);transition:border-color var(--transition-fast)}.form-group input:hover,.form-group textarea:hover{border-color:var(--color-primary-light)}.form-group input:focus,.form-group textarea:focus{outline:0;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(0,120,212,.1)}.form-group textarea{resize:vertical;min-height:120px}.form-group input.error,.form-group textarea.error{border-color:var(--color-error)}.error-message{display:block;color:var(--color-error);font-size:.875rem;margin-top:var(--spacing-xs);min-height:1.25rem;font-weight:var(--font-weight-normal)}.form-status{margin-top:var(--spacing-md);padding:var(--spacing-sm);border-radius:var(--radius-sm);text-align:center;font-weight:var(--font-weight-medium);display:none}.form-status.success{display:block;background:var(--color-success-bg);color:var(--color-success);border:1px solid var(--color-success-border)}.form-status.error{display:block;background:var(--color-error-bg);color:var(--color-error);border:1px solid var(--color-error-border)}@media (min-width:768px){.contact-wrapper{gap:var(--spacing-xl)}.contact-info-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}.contact-primary-cta__email{font-size:1.75rem}}@media (min-width:1024px){.contact{padding:var(--spacing-xl) 0}.contact-wrapper{gap:calc(var(--spacing-xl) + var(--spacing-md))}.contact-primary-cta{padding:calc(var(--spacing-lg) + var(--spacing-sm));min-height:140px}.contact-primary-cta__icon{width:56px;height:56px}.contact-primary-cta__email{font-size:2rem}.contact-primary-cta__subtext{font-size:1.125rem}.contact-info-card{padding:calc(var(--spacing-lg) + var(--spacing-sm));min-height:160px}.contact-info-card__icon-wrapper{width:70px;height:70px}.contact-info-card__icon{width:36px;height:36px}.contact-info-card h3{font-size:1.375rem}.contact-info-card p{font-size:1.125rem}.contact-social-icon{width:48px;height:48px}.contact-social-icon svg{width:24px;height:24px}}@media (min-width:768px){.footer__content{grid-template-columns:repeat(2,1fr);gap:var(--spacing-xl)}.footer__section{text-align:left}.footer__social{justify-content:flex-start}}@media (min-width:1024px){.footer{padding:var(--spacing-xl) 0 var(--spacing-lg)}.footer__content{grid-template-columns:repeat(3,1fr);gap:var(--spacing-xl)}.footer__heading{font-size:1.5rem}.footer__text{font-size:1rem}.footer__social a{width:44px;height:44px}.footer__social svg{width:22px;height:22px}.footer__bottom{font-size:1rem}}.skip-link{position:absolute;top:-40px;left:0;background:var(--color-primary);color:var(--color-white);padding:.75rem 1.5rem;text-decoration:none;z-index:10000;border-radius:0 0 var(--radius-sm) 0;font-weight:var(--font-weight-semibold);transition:top var(--transition-fast)}.skip-link:focus{top:0;outline:2px solid var(--color-white);outline-offset:-4px}:focus{outline:2px solid var(--color-primary);outline-offset:2px}:focus:not(:focus-visible){outline:0}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:2px}.btn:focus-visible{outline:3px solid var(--color-primary);outline-offset:4px}a:focus-visible{outline:2px dashed var(--color-primary);outline-offset:2px;border-radius:2px}.portfolio-card:focus-within,.service-card:focus-within{outline:2px solid var(--color-primary);outline-offset:4px;border-radius:var(--radius-lg)}.hero__scroll-indicator{background:0 0;border:none;cursor:pointer;padding:0}.hero__scroll-indicator:focus-visible{outline:2px solid var(--color-primary);outline-offset:4px;border-radius:var(--radius-sm)}[data-theme=dark] :focus-visible{outline-color:var(--color-primary-light)}[data-theme=dark] .skip-link{background:var(--color-primary-light);color:var(--color-primary-dark)}[data-theme=dark] .skip-link:focus{outline-color:var(--color-white)}.sr-only,.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.sr-only-focusable:focus,.visually-hidden-focusable:focus{position:static;width:auto;height:auto;overflow:visible;clip:auto;white-space:normal}@media (prefers-reduced-motion:reduce){*,::after,::before{animation-duration:0s!important;animation-iteration-count:1!important;transition-duration:0s!important;scroll-behavior:auto!important}.hero__shape{animation:none}}.fade-in{opacity:0;transform:translateY(30px);transition:opacity .6s ease-out,transform .6s ease-out}.fade-in.visible{opacity:1;transform:translateY(0)}.fade-in-stagger>*{opacity:0;transform:translateY(20px);transition:opacity .5s ease-out,transform .5s ease-out}.fade-in-stagger.visible>*{opacity:1;transform:translateY(0)}.btn-pulse{position:relative;overflow:hidden}.btn-pulse::before{content:'';position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:rgba(255,255,255,.3);transform:translate(-50%,-50%);transition:width .6s ease,height .6s ease}.btn-pulse:hover::before{width:300px;height:300px}.hover-scale{transition:transform var(--transition-base);will-change:transform}.hover-scale:hover{transform:scale(1.02)}.animated-underline{position:relative;text-decoration:none}.animated-underline::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--color-primary);transition:width var(--transition-base)}.animated-underline:focus::after,.animated-underline:hover::after{width:100%}@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-20px)}}.float{animation:float 3s ease-in-out infinite}@keyframes gradient-shift{0%{background-position:0 50%}50%{background-position:100% 50%}100%{background-position:0 50%}}.gradient-animated{background-size:200% 200%;animation:gradient-shift 15s ease infinite}.loading-spinner{display:inline-block;width:40px;height:40px;border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn-pulse::before,.fade-in,.fade-in-stagger>*,.hover-scale,.portfolio-card,.service-card{will-change:transform,opacity}.fade-in-stagger.visible>*,.fade-in.visible{will-change:auto}