*{margin:0;padding:0;box-sizing:border-box}#root{min-height:100vh}:root{--primary: #2563eb;--primary-dark: #1e40af;--primary-light: #3b82f6;--accent: #0ea5e9;--text-primary: #0f172a;--text-secondary: #64748b;--text-light: #94a3b8;--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--border: #e2e8f0;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--spacing-xs: .5rem;--spacing-sm: 1rem;--spacing-md: 1.5rem;--spacing-lg: 2rem;--spacing-xl: 3rem;--spacing-2xl: 4rem;--spacing-3xl: 5rem;--spacing-4xl: 6rem;--surface-content: #fefefe;--surface-nav: #eff5ff;--surface-footer: #edf4ff;--surface-border-strong: #c7d9f7;--footer-text-primary: #172554;--footer-text-secondary: #334155;--footer-text-muted: #64748b;--header-height: 72px;--content-separation: 0px}@media (max-width: 1140px){:root{--header-height: 62px}}@media (max-width: 768px){:root{--header-height: 62px;--content-separation: 0px}}.dark{--primary: #60a5fa;--primary-dark: #3b82f6;--primary-light: #93c5fd;--accent: #38bdf8;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-light: #94a3b8;--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--border: #475569;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .5);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .6), 0 2px 4px -2px rgba(0, 0, 0, .5);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .6), 0 4px 6px -4px rgba(0, 0, 0, .5);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .6), 0 8px 10px -6px rgba(0, 0, 0, .5);--surface-content: #0b1220;--surface-nav: #111b30;--surface-footer: #111b30;--surface-border-strong: #1f3358;--footer-text-primary: #dbeafe;--footer-text-secondary: #cbd5e1;--footer-text-muted: #94a3b8}.high-contrast-light{--primary: #0000cc;--primary-dark: #000099;--primary-light: #0000ee;--accent: #0000cc;--text-primary: #000000;--text-secondary: #1a1a1a;--text-light: #333333;--bg-primary: #ffffff;--bg-secondary: #f0f0f0;--bg-tertiary: #e5e5e5;--border: #000000;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .15);--shadow-md: 0 2px 6px rgba(0, 0, 0, .2);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .25);--shadow-xl: 0 6px 20px rgba(0, 0, 0, .3);--surface-content: #ffffff;--surface-nav: #ffffff;--surface-footer: #ffffff;--surface-border-strong: #000000;--footer-text-primary: #000000;--footer-text-secondary: #1a1a1a;--footer-text-muted: #333333}.high-contrast-light,.high-contrast-light p,.high-contrast-light span,.high-contrast-light div,.high-contrast-light h1,.high-contrast-light h2,.high-contrast-light h3,.high-contrast-light h4,.high-contrast-light h5,.high-contrast-light h6,.high-contrast-light li,.high-contrast-light label,.high-contrast-light strong,.high-contrast-light em{color:var(--text-primary)!important}.high-contrast-light body,.high-contrast-light html{background-color:var(--bg-primary)!important}.high-contrast-light button,.high-contrast-light input,.high-contrast-light textarea,.high-contrast-light select,.high-contrast-light .skill-tag,.high-contrast-light .tech-tag,.high-contrast-light .card,.high-contrast-light .team-card,.high-contrast-light .skill-card,.high-contrast-light .about-card,.high-contrast-light .project-card,.high-contrast-light .hero-badge,.high-contrast-light .section-divider{border:2px solid var(--border)!important}.high-contrast-light header,.high-contrast-light .navbar{background-color:#fff!important;border-bottom:3px solid #000000!important;box-shadow:0 2px 8px #00000080!important}.high-contrast-light header *,.high-contrast-light .navbar *{color:#000!important}.high-contrast-light .logo{color:var(--primary)!important}.high-contrast-light .logo:hover{color:var(--primary-dark)!important;outline:2px solid var(--primary)!important;outline-offset:4px!important}.high-contrast-light .nav-menu a{color:var(--text-primary)!important;border-bottom:2px solid transparent!important;text-decoration:none!important}.high-contrast-light .nav-menu a:hover,.high-contrast-light .nav-menu a:focus{color:var(--primary)!important;background-color:transparent!important;border-bottom-color:var(--primary)!important;outline:2px solid var(--primary)!important;outline-offset:4px!important}.high-contrast-light .nav-menu a:after{background-color:var(--primary)!important;height:3px!important}.high-contrast-light .language-selector-btn,.high-contrast-light .nav-search-open-btn,.high-contrast-light .theme-toggle,.high-contrast-light .mobile-menu-toggle{background-color:var(--bg-primary)!important;color:var(--text-primary)!important;border:2px solid var(--border)!important}.high-contrast-light .language-selector-btn:hover,.high-contrast-light .nav-search-open-btn:hover,.high-contrast-light .theme-toggle:hover,.high-contrast-light .mobile-menu-toggle:hover{background-color:var(--primary)!important;color:#fff!important;border-color:var(--primary)!important;outline:2px solid var(--primary)!important;outline-offset:2px!important}.high-contrast-light .language-dropdown,.high-contrast-light .theme-select-dropdown{background-color:#fff!important;border:3px solid #000000!important;box-shadow:0 4px 12px #0009!important}.high-contrast-light .language-dropdown *,.high-contrast-light .theme-select-dropdown *{color:#000!important}.high-contrast-light .language-option{color:var(--text-primary)!important;border-bottom:1px solid var(--border)!important}.high-contrast-light .language-option:hover,.high-contrast-light .language-option:focus,.high-contrast-light .theme-select-option:hover,.high-contrast-light .theme-select-option:focus{background-color:var(--primary)!important;color:#fff!important}.high-contrast-light .btn-primary{background-color:#06c!important;color:#fff!important;border:3px solid #000000!important;box-shadow:0 4px 12px #06c9!important;font-weight:700!important}.high-contrast-light .btn-primary:hover,.high-contrast-light .btn-primary:focus{background-color:#0052a3!important;border-color:#000!important;color:#fff!important;outline:4px solid #0066CC!important;outline-offset:4px!important;transform:translateY(-2px)!important;box-shadow:0 6px 16px #06cc!important}.high-contrast-light .btn-secondary{background-color:var(--bg-primary)!important;color:var(--text-primary)!important;border:3px solid var(--border)!important;font-weight:700!important}.high-contrast-light .btn-secondary:hover,.high-contrast-light .btn-secondary:focus{background-color:#06c!important;color:#fff!important;border-color:#000!important;outline:4px solid #0066CC!important;outline-offset:4px!important;transform:translateY(-2px)!important}.high-contrast-light a{color:var(--primary)!important;text-decoration:underline!important;text-decoration-thickness:2px!important;text-underline-offset:3px!important}.high-contrast-light a:visited{color:purple!important}.high-contrast-light a:hover,.high-contrast-light a:focus{background-color:var(--primary)!important;color:#fff!important;outline:3px solid var(--primary)!important;outline-offset:3px!important;text-decoration:underline!important}.high-contrast-light .accessibility-toggle{background-color:#06c!important;color:#fff!important;border:3px solid #000000!important;box-shadow:0 4px 12px #06c9!important}.high-contrast-light .accessibility-toggle:hover,.high-contrast-light .accessibility-toggle:focus{background-color:#0052a3!important;border-color:#000!important;outline:4px solid #0066CC!important;outline-offset:4px!important}.high-contrast-light .accessibility-panel{background-color:#fff!important;border:3px solid #000000!important;box-shadow:0 8px 24px #000000b3!important;color:#000!important}.high-contrast-light .accessibility-panel *{color:#000!important}.high-contrast-light .accessibility-panel-header{border-bottom:2px solid var(--border)!important}.high-contrast-light .accessibility-panel-close{color:var(--text-primary)!important;border:2px solid transparent!important}.high-contrast-light .accessibility-panel-close:hover{background-color:var(--primary)!important;color:#fff!important;border-color:var(--primary)!important}.high-contrast-light .accessibility-select{background-color:#fff!important;color:#000!important;border:3px solid #000000!important;font-weight:600!important}.high-contrast-light .accessibility-select:hover,.high-contrast-light .accessibility-select:focus{border-color:var(--primary)!important;outline:2px solid var(--primary)!important;outline-offset:2px!important}.high-contrast-light .accessibility-option{background-color:#fff!important;color:#000!important;border:3px solid #000000!important;font-weight:600!important}.high-contrast-light .accessibility-option:hover{border-color:var(--primary)!important;outline:2px solid var(--primary)!important;outline-offset:2px!important}.high-contrast-light .accessibility-option.active{background-color:#06c!important;color:#fff!important;border-color:#000!important}.high-contrast-light .accessibility-setting-icon{background:var(--primary)!important;border:3px solid #000000!important}.high-contrast-light .accessibility-setting-icon svg,.high-contrast-light .accessibility-option svg,.high-contrast-light .accessibility-toggle svg,.high-contrast-light .accessibility-panel-close svg{stroke-width:2.5!important;stroke:#000!important;fill:none!important;filter:none!important}.high-contrast-light .accessibility-setting-icon{background-color:#fff!important;border:3px solid #000000!important}.high-contrast-light .accessibility-option.active svg{stroke:#fff!important}.high-contrast-light .accessibility-toggle svg{stroke:#fff!important}.high-contrast-light .about-card,.high-contrast-light .team-card,.high-contrast-light .skill-card,.high-contrast-light .project-card,.high-contrast-light .skill-tooltip-card{background-color:#fff!important;border:3px solid #000000!important;box-shadow:0 4px 12px #00000080!important;color:#000!important}.high-contrast-light .about-card *,.high-contrast-light .team-card *,.high-contrast-light .skill-card *,.high-contrast-light .project-card *,.high-contrast-light .skill-tooltip-card *{color:#000!important}.high-contrast-light .about-card:hover,.high-contrast-light .team-card:hover,.high-contrast-light .skill-card:hover,.high-contrast-light .project-card:hover{border-color:var(--primary)!important;box-shadow:0 6px 16px #0000ff80!important;outline:2px solid var(--primary)!important;outline-offset:2px!important}.high-contrast-light .mobile-menu{background-color:#fff!important;border:3px solid #000000!important;box-shadow:0 8px 24px #0009!important}.high-contrast-light .mobile-menu *{color:#000!important}.high-contrast-light .mobile-menu .nav-menu li{border-bottom:2px solid var(--border)!important}.high-contrast-light .mobile-menu .nav-menu li a:hover,.high-contrast-light .mobile-menu .nav-menu li a:focus{background-color:var(--primary)!important;color:#fff!important;border-left:4px solid #FFFFFF!important}.high-contrast-light .skill-tag,.high-contrast-light .tech-tag{background-color:#fff!important;color:#000!important;border:3px solid #000000!important;font-weight:700!important;padding:6px 12px!important}.high-contrast-light .skill-tag:hover,.high-contrast-light .tech-tag:hover,.high-contrast-light .skill-tag:focus,.high-contrast-light .tech-tag:focus{background-color:#00f!important;color:#fff!important;border-color:#00f!important;outline:3px solid #0000FF!important;outline-offset:2px!important}.high-contrast-light .skill-tag-text,.high-contrast-light .tech-tag-text{color:#000!important;font-weight:700!important}.high-contrast-light .skill-tag:hover .skill-tag-text,.high-contrast-light .tech-tag:hover .tech-tag-text{color:#fff!important}.high-contrast-light input[type=text],.high-contrast-light input[type=email],.high-contrast-light input[type=tel],.high-contrast-light textarea{background-color:#fff!important;color:#000!important;border:3px solid #000000!important;padding:12px!important;font-size:1rem!important;font-weight:500!important}.high-contrast-light input:focus,.high-contrast-light textarea:focus{outline:4px solid #0000FF!important;outline-offset:2px!important;border-color:#00f!important;background-color:#fff!important}.high-contrast-light input::placeholder,.high-contrast-light textarea::placeholder{color:#666!important;opacity:1!important}.high-contrast-light .hero-badge{background-color:#fff!important;color:#000!important;border:3px solid #000000!important}.high-contrast-light .section-divider{border-color:#000!important;border-width:3px!important}.high-contrast-light .progress-bar{background-color:#000!important}.high-contrast-light .progress-bar-fill{background-color:#06c!important;border:2px solid #000000!important}.high-contrast-dark{--primary: #ffff00;--primary-dark: #e6e600;--primary-light: #ffff66;--accent: #ffff00;--text-primary: #ffffff;--text-secondary: #f0f0f0;--text-light: #e0e0e0;--bg-primary: #000000;--bg-secondary: #1a1a1a;--bg-tertiary: #2a2a2a;--border: #ffffff;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow-md: 0 2px 6px rgba(0, 0, 0, .45);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .5);--shadow-xl: 0 6px 20px rgba(0, 0, 0, .55);--surface-content: #000000;--surface-nav: #000000;--surface-footer: #000000;--surface-border-strong: #ffffff;--footer-text-primary: #ffffff;--footer-text-secondary: #f0f0f0;--footer-text-muted: #e0e0e0}.high-contrast-dark,.high-contrast-dark p,.high-contrast-dark span,.high-contrast-dark div,.high-contrast-dark li,.high-contrast-dark label,.high-contrast-dark strong,.high-contrast-dark em,.high-contrast-dark h1,.high-contrast-dark h2,.high-contrast-dark h3,.high-contrast-dark h4,.high-contrast-dark h5,.high-contrast-dark h6{color:var(--text-primary)!important}.high-contrast-dark body,.high-contrast-dark html{background-color:var(--bg-primary)!important}.high-contrast-dark button,.high-contrast-dark input,.high-contrast-dark textarea,.high-contrast-dark select,.high-contrast-dark .skill-tag,.high-contrast-dark .tech-tag,.high-contrast-dark .card,.high-contrast-dark .team-card,.high-contrast-dark .skill-card,.high-contrast-dark .about-card,.high-contrast-dark .project-card,.high-contrast-dark .hero-badge,.high-contrast-dark .section-divider{border:2px solid var(--border)!important}.high-contrast-dark header,.high-contrast-dark .navbar{background-color:var(--bg-primary)!important;border-bottom:2px solid var(--border)!important;box-shadow:var(--shadow-md)!important}.high-contrast-dark header *,.high-contrast-dark .navbar *{color:#fff!important}.high-contrast-dark .logo{color:var(--primary)!important}.high-contrast-dark .logo:hover{color:var(--primary-light)!important;outline:2px solid var(--primary)!important;outline-offset:4px!important}.high-contrast-dark .nav-menu a{color:var(--text-primary)!important;border-bottom:2px solid transparent!important;text-decoration:none!important}.high-contrast-dark .nav-menu a:hover,.high-contrast-dark .nav-menu a:focus{color:var(--primary)!important;background-color:transparent!important;border-bottom-color:var(--primary)!important;outline:2px solid var(--primary)!important;outline-offset:4px!important}.high-contrast-dark .nav-menu a:after{background-color:var(--primary)!important;height:3px!important}.high-contrast-dark .language-selector-btn,.high-contrast-dark .nav-search-open-btn,.high-contrast-dark .theme-toggle,.high-contrast-dark .mobile-menu-toggle{background-color:var(--bg-secondary)!important;color:var(--text-primary)!important;border:2px solid var(--border)!important}.high-contrast-dark .language-selector-btn:hover,.high-contrast-dark .nav-search-open-btn:hover,.high-contrast-dark .theme-toggle:hover,.high-contrast-dark .mobile-menu-toggle:hover{background-color:var(--primary)!important;color:#000!important;border-color:var(--primary)!important;outline:2px solid var(--primary)!important;outline-offset:2px!important}.high-contrast-dark .language-dropdown,.high-contrast-dark .theme-select-dropdown{background-color:var(--bg-primary)!important;border:2px solid var(--border)!important;box-shadow:var(--shadow-lg)!important}.high-contrast-dark .language-dropdown *,.high-contrast-dark .theme-select-dropdown *{color:var(--text-primary)!important}.high-contrast-dark .language-option{color:var(--text-primary)!important;border-bottom:1px solid var(--border)!important}.high-contrast-dark .language-option:hover,.high-contrast-dark .language-option:focus,.high-contrast-dark .theme-select-option:hover,.high-contrast-dark .theme-select-option:focus{background-color:var(--primary)!important;color:#1a1a1a!important}.high-contrast-dark .btn-primary{background-color:var(--primary)!important;color:#1a1a1a!important;border:2px solid var(--primary)!important;box-shadow:var(--shadow-md)!important;font-weight:600!important}.high-contrast-dark .btn-primary:hover,.high-contrast-dark .btn-primary:focus{background-color:var(--primary-light)!important;border-color:var(--primary-light)!important;color:#1a1a1a!important;outline:2px solid var(--primary)!important;outline-offset:2px!important;transform:translateY(-1px)!important}.high-contrast-dark .btn-secondary{background-color:var(--bg-secondary)!important;color:var(--text-primary)!important;border:2px solid var(--border)!important;font-weight:600!important}.high-contrast-dark .btn-secondary:hover,.high-contrast-dark .btn-secondary:focus{background-color:var(--primary)!important;color:#1a1a1a!important;border-color:var(--primary)!important;outline:2px solid var(--primary)!important;outline-offset:2px!important;transform:translateY(-1px)!important}.high-contrast-dark a{color:var(--primary-light)!important;text-decoration:underline!important;text-decoration-thickness:1px!important;text-underline-offset:2px!important}.high-contrast-dark a:visited{color:#c9a0e0!important}.high-contrast-dark a:hover,.high-contrast-dark a:focus{background-color:var(--primary)!important;color:#1a1a1a!important;outline:2px solid var(--primary)!important;outline-offset:2px!important;text-decoration:underline!important}.high-contrast-dark .accessibility-toggle{background-color:var(--primary)!important;color:#1a1a1a!important;border:2px solid var(--primary)!important;box-shadow:var(--shadow-md)!important}.high-contrast-dark .accessibility-toggle:hover,.high-contrast-dark .accessibility-toggle:focus{background-color:var(--primary-light)!important;border-color:var(--border)!important;outline:2px solid var(--primary)!important;outline-offset:2px!important}.high-contrast-dark .accessibility-panel{background-color:var(--bg-primary)!important;border:2px solid var(--border)!important;box-shadow:var(--shadow-xl)!important;color:var(--text-primary)!important}.high-contrast-dark .accessibility-panel *{color:var(--text-primary)!important}.high-contrast-dark .accessibility-panel-header{border-bottom:2px solid var(--border)!important}.high-contrast-dark .accessibility-panel-close{color:var(--text-primary)!important;border:2px solid transparent!important}.high-contrast-dark .accessibility-panel-close:hover{background-color:var(--primary)!important;color:#1a1a1a!important;border-color:var(--primary)!important}.high-contrast-dark .accessibility-select{background-color:#000!important;color:#fff!important;border:3px solid #FFFFFF!important;font-weight:600!important}.high-contrast-dark .accessibility-select:hover,.high-contrast-dark .accessibility-select:focus{border-color:var(--primary)!important;outline:2px solid var(--primary)!important;outline-offset:2px!important}.high-contrast-dark .accessibility-option{background-color:#000!important;color:#fff!important;border:3px solid #FFFFFF!important;font-weight:600!important}.high-contrast-dark .accessibility-option:hover{border-color:var(--primary)!important;outline:2px solid var(--primary)!important;outline-offset:2px!important}.high-contrast-dark .accessibility-option.active{background-color:var(--primary)!important;color:#1a1a1a!important;border-color:var(--primary)!important}.high-contrast-dark .accessibility-setting-icon{background:var(--primary)!important;border:2px solid var(--border)!important}.high-contrast-dark .accessibility-setting-icon svg,.high-contrast-dark .accessibility-option svg{stroke-width:3!important;stroke:currentColor!important}.high-contrast-dark .accessibility-toggle svg{stroke-width:3!important;stroke:currentColor!important}.high-contrast-dark .accessibility-panel-close svg{stroke-width:3!important;stroke:currentColor!important}.high-contrast-dark .about-card,.high-contrast-dark .team-card,.high-contrast-dark .skill-card,.high-contrast-dark .project-card,.high-contrast-dark .skill-tooltip-card{background-color:var(--bg-secondary)!important;border:2px solid var(--border)!important;box-shadow:var(--shadow-md)!important;color:var(--text-primary)!important}.high-contrast-dark .about-card *,.high-contrast-dark .team-card *,.high-contrast-dark .skill-card *,.high-contrast-dark .project-card *,.high-contrast-dark .skill-tooltip-card *{color:var(--text-primary)!important}.high-contrast-dark .about-card:hover,.high-contrast-dark .team-card:hover,.high-contrast-dark .skill-card:hover,.high-contrast-dark .project-card:hover{border-color:var(--primary)!important;box-shadow:0 6px 16px #ffff0080!important;outline:2px solid var(--primary)!important;outline-offset:2px!important}.high-contrast-dark .mobile-menu{background-color:var(--bg-primary)!important;border:2px solid var(--border)!important;box-shadow:var(--shadow-lg)!important}.high-contrast-dark .mobile-menu *{color:var(--text-primary)!important}.high-contrast-dark .mobile-menu .nav-menu li{border-bottom:2px solid var(--border)!important}.high-contrast-dark .mobile-menu .nav-menu li a:hover,.high-contrast-dark .mobile-menu .nav-menu li a:focus{background-color:var(--primary)!important;color:#1a1a1a!important;border-left:4px solid var(--primary)!important}.high-contrast-dark .skill-tag,.high-contrast-dark .tech-tag{background-color:var(--bg-secondary)!important;color:var(--text-primary)!important;border:2px solid var(--border)!important;font-weight:600!important;padding:6px 12px!important}.high-contrast-dark .skill-tag:hover,.high-contrast-dark .tech-tag:hover,.high-contrast-dark .skill-tag:focus,.high-contrast-dark .tech-tag:focus{background-color:var(--primary)!important;color:#1a1a1a!important;border-color:var(--primary)!important;outline:2px solid var(--primary)!important;outline-offset:2px!important}.high-contrast-dark .skill-tag-text,.high-contrast-dark .tech-tag-text{color:var(--text-primary)!important;font-weight:600!important}.high-contrast-dark .skill-tag:hover .skill-tag-text,.high-contrast-dark .tech-tag:hover .tech-tag-text{color:#1a1a1a!important}.high-contrast-dark input[type=text],.high-contrast-dark input[type=email],.high-contrast-dark input[type=tel],.high-contrast-dark textarea{background-color:var(--bg-primary)!important;color:var(--text-primary)!important;border:2px solid var(--border)!important;padding:12px!important;font-size:1rem!important;font-weight:500!important}.high-contrast-dark input:focus,.high-contrast-dark textarea:focus{outline:2px solid var(--primary)!important;outline-offset:2px!important;border-color:var(--primary)!important;background-color:var(--bg-primary)!important}.high-contrast-dark input::placeholder,.high-contrast-dark textarea::placeholder{color:var(--text-light)!important;opacity:1!important}.high-contrast-dark .hero-badge{background-color:var(--primary)!important;color:#1a1a1a!important;border:2px solid var(--primary)!important}.high-contrast-dark .section-divider{border-color:var(--border)!important;border-width:2px!important}.high-contrast-dark .hero-title,.high-contrast-dark .section-title,.high-contrast-dark .hero-description,.high-contrast-dark .section-subtitle{color:var(--text-primary)!important}.high-contrast-dark .progress-bar{background-color:var(--bg-tertiary)!important}.high-contrast-dark .progress-bar-fill{background-color:var(--primary)!important;border:2px solid var(--border)!important}.high-contrast-dark .search-container,.high-contrast-dark .search-input,.high-contrast-dark .search-results{background-color:var(--bg-primary)!important;border:3px solid var(--border)!important;color:var(--text-primary)!important}.high-contrast-dark .search-input:focus{border-color:var(--primary)!important;outline:3px solid var(--primary)!important;outline-offset:2px!important}.high-contrast-dark .project-popup-overlay{background-color:#000000d9!important}.high-contrast-dark .project-popup-container{background-color:var(--bg-primary)!important;border:2px solid var(--border)!important;box-shadow:var(--shadow-xl)!important}.high-contrast-dark .project-popup-container *{color:var(--text-primary)!important}.high-contrast-dark .project-popup-header{border-bottom:2px solid var(--border)!important}.high-contrast-dark .project-popup-close{color:var(--text-primary)!important;border:2px solid transparent!important}.high-contrast-dark .project-popup-close:hover{background-color:var(--primary)!important;color:#1a1a1a!important;border-color:var(--primary)!important}.high-contrast-dark .back-to-top-btn{background-color:var(--primary)!important;color:#1a1a1a!important;border:2px solid var(--primary)!important;box-shadow:var(--shadow-md)!important}.high-contrast-dark .back-to-top-btn:hover{background-color:var(--primary-light)!important;border-color:var(--primary-light)!important;outline:2px solid var(--primary)!important;outline-offset:2px!important}.high-contrast-dark .back-to-top-arrow{color:#1a1a1a!important}.high-contrast-dark svg{fill:var(--text-primary)!important;stroke:var(--text-primary)!important}.high-contrast-dark svg[aria-hidden=true]{fill:#fff!important;stroke:#fff!important}.high-contrast-dark .logo svg{fill:#ff0!important;stroke:#ff0!important}.high-contrast-dark .btn-primary svg{fill:#000!important;stroke:#000!important}.high-contrast-dark footer,.high-contrast-dark .footer-content,.high-contrast-dark .footer-main,.high-contrast-dark .footer-brand,.high-contrast-dark .footer-bottom{background-color:#000!important;border-color:#fff!important;color:#fff!important;box-shadow:none!important}.high-contrast-dark .footer-tagline,.high-contrast-dark .footer-heading,.high-contrast-dark .footer-copyright,.high-contrast-dark .footer-company,.high-contrast-dark .footer-menu span{color:#fff!important;opacity:1!important}.high-contrast-dark .footer-menu a,.high-contrast-dark footer a{color:#ff0!important;text-decoration:underline!important;text-decoration-thickness:2px!important}.high-contrast-dark .footer-menu a:hover,.high-contrast-dark .footer-menu a:focus,.high-contrast-dark footer a:hover,.high-contrast-dark footer a:focus{background-color:#ff0!important;color:#000!important;outline:2px solid #ffffff!important;outline-offset:2px!important}.high-contrast-dark .footer-menu svg{stroke:#fff!important;opacity:1!important}.high-contrast-dark .footer-bottom{border-top:2px solid #ffffff!important}.high-contrast-dark .footer-logo-img{filter:brightness(0) invert(1)}.high-contrast-light .search-container,.high-contrast-light .search-input,.high-contrast-light .search-results{background-color:var(--bg-primary)!important;border:3px solid var(--border)!important;color:var(--text-primary)!important}.high-contrast-light .search-input:focus{border-color:var(--primary)!important;outline:3px solid var(--primary)!important;outline-offset:2px!important}.high-contrast-light .project-popup-overlay{background-color:#fffffff2!important}.high-contrast-light .project-popup-container{background-color:#fff!important;border:3px solid #000000!important;box-shadow:0 8px 32px #000000b3!important}.high-contrast-light .project-popup-container *{color:#000!important}.high-contrast-light .project-popup-header{border-bottom:2px solid var(--border)!important}.high-contrast-light .project-popup-close{color:var(--text-primary)!important;border:2px solid transparent!important}.high-contrast-light .project-popup-close:hover{background-color:var(--primary)!important;color:#fff!important;border-color:var(--primary)!important}.high-contrast-light .back-to-top-btn{background-color:var(--primary)!important;color:#fff!important;border:3px solid var(--primary)!important;box-shadow:0 4px 16px #0000ff80!important}.high-contrast-light .back-to-top-btn:hover{background-color:var(--primary-dark)!important;border-color:var(--primary-dark)!important;outline:3px solid var(--primary)!important;outline-offset:3px!important}.high-contrast-light .back-to-top-arrow{color:#fff!important}.high-contrast-light svg{fill:#000!important;stroke:#000!important}.high-contrast-light svg[aria-hidden=true]{fill:#000!important;stroke:#000!important}.high-contrast-light .logo svg{fill:#00f!important;stroke:#00f!important}.high-contrast-light .btn-primary svg{fill:#fff!important;stroke:#fff!important}.high-contrast-light footer,.high-contrast-light .footer-content,.high-contrast-light .footer-main,.high-contrast-light .footer-brand,.high-contrast-light .footer-bottom{background-color:#fff!important;border-color:#000!important;color:#000!important;box-shadow:none!important}.high-contrast-light .footer-tagline,.high-contrast-light .footer-heading,.high-contrast-light .footer-copyright,.high-contrast-light .footer-company,.high-contrast-light .footer-menu span{color:#000!important;opacity:1!important}.high-contrast-light .footer-menu a,.high-contrast-light footer a{color:#00c!important;text-decoration:underline!important;text-decoration-thickness:2px!important}.high-contrast-light .footer-menu a:hover,.high-contrast-light .footer-menu a:focus,.high-contrast-light footer a:hover,.high-contrast-light footer a:focus{background-color:#00c!important;color:#fff!important;outline:2px solid #000000!important;outline-offset:2px!important}.high-contrast-light .footer-menu svg{stroke:#000!important;opacity:1!important}.high-contrast-light .footer-bottom{border-top:2px solid #000000!important}.high-contrast-light .footer-logo-img{filter:none}.high-contrast-light .contact-form-container{background-color:#fff!important;border:3px solid #000000!important;color:#000!important}.high-contrast-light .contact-form-container *{color:#000!important}.high-contrast-light .contact-form-heading{color:#000!important;border-bottom:3px solid #000000!important;padding-bottom:12px!important}.high-contrast-light .form-group{border:2px solid transparent!important}.high-contrast-light .form-group:focus-within{border:2px solid #0000FF!important;outline:2px solid #0000FF!important;outline-offset:2px!important}.high-contrast-light .form-label{color:#000!important;font-weight:700!important}.high-contrast-light .form-input,.high-contrast-light .form-textarea{background-color:#fff!important;color:#000!important;border:3px solid #000000!important;font-weight:500!important}.high-contrast-light .form-input:focus,.high-contrast-light .form-textarea:focus{border-color:#00f!important;outline:4px solid #0000FF!important;outline-offset:2px!important}.high-contrast-dark .contact-form-container{background-color:#000!important;border:3px solid #FFFFFF!important;color:#fff!important}.high-contrast-dark .contact-form-container *{color:#fff!important}.high-contrast-dark .contact-form-heading{color:#fff!important;border-bottom:3px solid #FFFFFF!important;padding-bottom:12px!important}.high-contrast-dark .form-group{border:2px solid transparent!important}.high-contrast-dark .form-group:focus-within{border:2px solid #FFFF00!important;outline:2px solid #FFFF00!important;outline-offset:2px!important}.high-contrast-dark .form-label{color:#fff!important;font-weight:700!important}.high-contrast-dark .form-input,.high-contrast-dark .form-textarea{background-color:#000!important;color:#fff!important;border:3px solid #FFFFFF!important;font-weight:500!important}.high-contrast-dark .form-input:focus,.high-contrast-dark .form-textarea:focus{border-color:#ff0!important;outline:4px solid #FFFF00!important;outline-offset:2px!important}.font-small{font-size:87.5%!important;line-height:1.6!important}.font-small,.font-small *:not(h1):not(h2):not(h3):not(h4):not(h5):not(h6):not(.skill-tag):not(.tech-tag){font-size:inherit!important}.font-small h1{font-size:1.75rem!important}.font-small h2{font-size:1.53125rem!important}.font-small h3{font-size:1.3125rem!important}.font-small h4{font-size:1.09375rem!important}.font-small h5{font-size:calc(1.125rem * .875)!important}.font-small h6{font-size:.875rem!important}.font-normal{font-size:100%!important}.font-large{font-size:125%!important;line-height:1.7!important}.font-large,.font-large *{font-size:inherit!important}.font-large h1{font-size:3.25rem!important}.font-large h2{font-size:2.6rem!important}.font-large h3{font-size:2.275rem!important}.font-large h4{font-size:calc(1.5rem * 1.3)!important}.font-large h5{font-size:1.625rem!important}.font-large h6{font-size:calc(1.125rem * 1.3)!important}.font-xlarge{font-size:125%!important;line-height:1.9!important}.font-xlarge,.font-xlarge *:not(h1):not(h2):not(h3):not(h4):not(h5):not(h6):not(.skill-tag):not(.tech-tag){font-size:inherit!important}.font-xlarge *{max-width:100%!important;box-sizing:border-box!important}.font-xlarge .container{max-width:100%!important;padding-left:var(--spacing-md)!important;padding-right:var(--spacing-md)!important}.font-xlarge img,.font-xlarge svg{max-width:100%!important;height:auto!important}.font-large img,.font-large svg{transform:scale(1.125);transform-origin:center}.font-xlarge img,.font-xlarge svg{transform:scale(1.25);transform-origin:center}.font-large .project-card-favicon,.font-large .team-member-avatar,.font-large .member-avatar,.font-large .team-avatar,.font-large .skill-tooltip-image,.font-large .skill-tooltip-image-wrapper,.font-large .logo svg,.font-large .section-icon,.font-large .card-icon,.font-large .card-icon svg,.font-large .contact-icon,.font-large .contact-icon svg,.font-large .language-flag-img,.font-large .language-flag-img-btn,.font-large .footer-logo-img{transform:scale(1.125)}.font-xlarge .project-card-favicon,.font-xlarge .team-member-avatar,.font-xlarge .member-avatar,.font-xlarge .team-avatar,.font-xlarge .skill-tooltip-image,.font-xlarge .skill-tooltip-image-wrapper,.font-xlarge .logo svg,.font-xlarge .section-icon,.font-xlarge .card-icon,.font-xlarge .card-icon svg,.font-xlarge .contact-icon,.font-xlarge .contact-icon svg,.font-xlarge .language-flag-img,.font-xlarge .language-flag-img-btn,.font-xlarge .footer-logo-img{transform:scale(1.25)}.font-large .project-image,.font-large .team-card img,.font-large .about-card img{transform:scale(1.125)}.font-xlarge .project-image,.font-xlarge .team-card img,.font-xlarge .about-card img{transform:scale(1.25)}.font-xlarge .hero-title,.font-xlarge .section-title,.font-xlarge h1,.font-xlarge h2,.font-xlarge h3{word-wrap:break-word!important;overflow-wrap:break-word!important;-webkit-hyphens:auto!important;hyphens:auto!important}.font-xlarge h1{font-size:3.75rem!important}.font-xlarge h2{font-size:3.125rem!important}.font-xlarge h3{font-size:2.5rem!important}.font-xlarge h4{font-size:2.1875rem!important}.font-xlarge h5{font-size:1.875rem!important}.font-xlarge h6{font-size:1.5625rem!important}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:16px;line-height:1.7;color:var(--text-primary);background-color:var(--surface-content);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;will-change:scroll-position;overflow-x:hidden;max-width:100vw;padding-top:var(--header-height)}*{scrollbar-width:auto;scrollbar-color:rgba(37,99,235,.6) rgba(37,99,235,.1)}*::-webkit-scrollbar{width:14px;height:14px}*::-webkit-scrollbar-track{background:#2563eb0d;border-radius:10px;border:1px solid rgba(37,99,235,.1)}*::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#2563ebcc,#0ea5e9cc);border-radius:10px;border:2px solid rgba(37,99,235,.1);background-clip:padding-box;transition:background .3s ease}*::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#2563eb,#0ea5e9);background-clip:padding-box}*::-webkit-scrollbar-thumb:active{background:linear-gradient(135deg,#1d4ed8,#0284c7);background-clip:padding-box}*::-webkit-scrollbar-corner{background:#2563eb0d}.dark *{scrollbar-color:rgba(96,165,250,.6) rgba(96,165,250,.1)}.dark *::-webkit-scrollbar-track{background:#60a5fa0d;border-color:#60a5fa1a}.dark *::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#60a5facc,#38bdf8cc);border-color:#60a5fa1a}.dark *::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#60a5fa,#38bdf8)}.dark *::-webkit-scrollbar-thumb:active{background:linear-gradient(135deg,#3b82f6,#0ea5e9)}.dark *::-webkit-scrollbar-corner{background:#60a5fa0d}.high-contrast-light *{scrollbar-color:rgba(0,0,255,.8) rgba(0,0,255,.2)}.high-contrast-light *::-webkit-scrollbar-track{background:#0000ff1a;border:1px solid rgba(0,0,255,.3)}.high-contrast-light *::-webkit-scrollbar-thumb{background:#00f;border:2px solid #FFFFFF}.high-contrast-light *::-webkit-scrollbar-thumb:hover{background:#00c}.high-contrast-dark *{scrollbar-color:rgba(255,255,0,.8) rgba(255,255,0,.2)}.high-contrast-dark *::-webkit-scrollbar-track{background:#ffff001a;border:1px solid rgba(255,255,0,.3)}.high-contrast-dark *::-webkit-scrollbar-thumb{background:#ff0;border:2px solid #000000}.high-contrast-dark *::-webkit-scrollbar-thumb:hover{background:#ff6}@media (max-width: 768px){body{padding-top:var(--header-height)}}html{scroll-behavior:smooth;overflow-x:hidden;max-width:100%}.accessibility-toggle-wrapper{position:fixed;left:auto;right:24px;bottom:104px;z-index:9998}.accessibility-toggle{width:56px;height:56px;border-radius:50%;background-color:var(--primary);color:#fff;border:2px solid white;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);transition:all .3s ease;position:relative}.accessibility-toggle:hover{transform:scale(1.1);box-shadow:var(--shadow-xl)}.accessibility-toggle:focus-visible{outline:3px solid var(--accent);outline-offset:2px}.accessibility-toggle[aria-expanded=true]{background-color:var(--primary-dark)}.accessibility-tooltip{position:absolute;bottom:calc(100% + 12px);left:auto;right:0;transform:none;background-color:#0f172af2;color:#fff;padding:8px 12px;border-radius:var(--radius-md);font-size:.875rem;white-space:normal;box-shadow:var(--shadow-lg);pointer-events:none;z-index:10000;animation:tooltipFadeIn .2s ease-out;max-width:min(280px,calc(100vw - 80px));min-width:150px;word-wrap:break-word;text-align:left}.accessibility-tooltip:after{content:"";position:absolute;top:100%;left:auto;right:28px;transform:none;width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid rgba(15,23,42,.95)}@media (max-width: 400px){.accessibility-tooltip{left:auto;right:0;transform:none;max-width:calc(100vw - 80px);margin:0}.accessibility-tooltip:after{left:auto;right:24px;transform:none}}.dark .accessibility-tooltip{background-color:#1e293bf2}.dark .accessibility-tooltip:after{border-top-color:#1e293bf2}.dark .accessibility-panel{background-color:var(--bg-primary);border-color:var(--border)}.dark .accessibility-panel-header{background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%);border-bottom-color:var(--border)}.dark .accessibility-option{background-color:var(--bg-secondary);border-color:var(--border);color:var(--text-primary)}.dark .accessibility-option:hover{background-color:var(--bg-tertiary);border-color:var(--primary)}.dark .accessibility-option.active{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);color:#fff}.dark .accessibility-setting-icon{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%)}.accessibility-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9998;margin:0;padding:0;border:none;background:#0f172a73;cursor:pointer;animation:backdropFadeIn .2s ease-out}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:1}}.accessibility-panel{position:fixed;z-index:9999;display:flex;flex-direction:column;overflow:hidden;background-color:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:min(380px,calc(100vw - 2rem));max-height:min(560px,calc(100dvh - 2rem));animation:panelSlideUp .3s ease-out;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.accessibility-panel--right{left:auto;right:max(1rem,env(safe-area-inset-right,0px));top:max(1rem,env(safe-area-inset-top,0px));bottom:calc(2.25rem + 56px);width:min(380px,calc(100vw - 2rem));max-height:none;height:auto;animation:panelSlideInRight .3s ease-out}@keyframes panelSlideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes panelSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.accessibility-panel-header{display:flex;justify-content:space-between;align-items:center;flex-shrink:0;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border);background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%)}.accessibility-panel-header h2{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0;display:flex;align-items:center;gap:var(--spacing-xs)}.accessibility-panel-close{background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:4px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .2s ease}.accessibility-panel-close:hover{background-color:var(--bg-secondary);color:var(--text-primary)}.accessibility-panel-content{flex:1;min-height:0;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;padding:var(--spacing-sm) var(--spacing-lg);display:flex;flex-direction:column;gap:0}.accessibility-setting{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:0}.accessibility-setting:last-child{margin-bottom:0}.accessibility-setting-header{display:flex;align-items:flex-start;gap:var(--spacing-sm)}.accessibility-setting-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);color:#fff;flex-shrink:0;box-shadow:0 2px 8px #2563eb33}.accessibility-setting-info{flex:1;display:flex;flex-direction:column;gap:2px}.accessibility-label{display:block;font-size:.9375rem;font-weight:700;color:var(--text-primary);margin:0;line-height:1.4}.accessibility-description{font-size:.8125rem;color:var(--text-secondary);margin:0;line-height:1.4}.accessibility-options{display:flex;gap:var(--spacing-xs);flex-wrap:wrap}.accessibility-options-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-xs)}.accessibility-option{flex:1;min-width:0;display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--border);border-radius:var(--radius-md);background-color:var(--bg-primary);color:var(--text-primary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden}.accessibility-option:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s ease}.accessibility-option:hover:before{left:100%}.accessibility-option:hover{border-color:var(--primary);background-color:var(--bg-secondary);transform:translateY(-1px);box-shadow:0 2px 8px #2563eb26}.accessibility-option.active{border-color:var(--primary);background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);color:#fff;box-shadow:0 4px 12px #2563eb4d}.accessibility-option.active:hover{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 100%);box-shadow:0 6px 16px #2563eb66}.accessibility-option svg{flex-shrink:0;opacity:.8;transition:opacity .2s ease}.accessibility-option.active svg{opacity:1}.accessibility-option span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.font-size-preview{font-weight:700;line-height:1;display:inline-block}.accessibility-option:focus-visible{outline:3px solid var(--primary);outline-offset:2px}.accessibility-setting-row{display:grid;grid-template-columns:1fr auto;align-items:center;column-gap:var(--spacing-sm);row-gap:var(--spacing-xs);padding:var(--spacing-sm) 0;border-bottom:1px solid var(--border)}.accessibility-setting-row .accessibility-switch{grid-column:2;grid-row:1;justify-self:end}.accessibility-setting-info-text{grid-column:1 / -1}.accessibility-setting-row:last-of-type{border-bottom:none}.accessibility-setting-row-left{grid-column:1;grid-row:1;display:flex;align-items:center;gap:var(--spacing-xs);min-width:0}.accessibility-setting-row .accessibility-setting-icon{width:32px;height:32px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;color:var(--primary)}.accessibility-setting-row .accessibility-setting-icon svg{width:20px;height:20px}.accessibility-setting-row .accessibility-setting-label{font-size:.9375rem;font-weight:600;color:var(--text-primary);flex:1;min-width:0}.accessibility-info-btn{width:22px;height:22px;flex-shrink:0;border-radius:50%;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);font-size:.75rem;font-weight:700;font-family:inherit;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s ease}.accessibility-info-btn:hover,.accessibility-info-btn:focus-visible{background:var(--primary);color:#fff;border-color:var(--primary)}.accessibility-info-icon{line-height:1}.accessibility-setting-info-text{width:100%;font-size:.8125rem;color:var(--text-secondary);margin:0;padding:var(--spacing-xs) 0 0 0;padding-left:calc(32px + var(--spacing-xs));line-height:1.4}.accessibility-switch{width:48px;height:26px;flex-shrink:0;border-radius:13px;border:2px solid var(--border);background:var(--bg-tertiary);cursor:pointer;position:relative;transition:background .2s ease,border-color .2s ease}.accessibility-switch:hover{border-color:var(--primary)}.accessibility-switch:focus-visible{outline:3px solid var(--primary);outline-offset:2px}.accessibility-switch-knob{position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:var(--text-secondary);transition:transform .2s ease,background .2s ease}.accessibility-switch--on{background:var(--primary);border-color:var(--primary)}.accessibility-switch--on .accessibility-switch-knob{transform:translate(22px);background:#fff}.accessibility-panel-footer{flex-shrink:0;margin-top:0;padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border);background:var(--bg-primary)}.accessibility-storage-note{margin:0 0 var(--spacing-sm);font-size:.75rem;line-height:1.45;color:var(--text-secondary)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.a11y-reduce-motion .accessibility-panel,.a11y-reduce-motion .accessibility-backdrop{animation:none!important}.accessibility-reset-btn{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:.9375rem;font-weight:600;font-family:inherit;color:var(--primary);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease}.accessibility-reset-btn:hover,.accessibility-reset-btn:focus-visible{background:var(--bg-tertiary);border-color:var(--primary)}.a11y-large-cursor,.a11y-large-cursor *{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2'%3E%3Cpath d='M3 3l7.07 16.97 2.51-7.39 7.39-2.51L3 3z'/%3E%3C/svg%3E") 2 2,auto!important}.dark.a11y-large-cursor,.dark.a11y-large-cursor *,.high-contrast-dark.a11y-large-cursor,.high-contrast-dark.a11y-large-cursor *{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2'%3E%3Cpath d='M3 3l7.07 16.97 2.51-7.39 7.39-2.51L3 3z'/%3E%3C/svg%3E") 2 2,auto!important}@font-face{font-family:OpenDyslexic;src:url(https://cdnjs.cloudflare.com/ajax/libs/open-dyslexic/2.0.1/font/OpenDyslexic-Regular.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:OpenDyslexic;src:url(https://cdnjs.cloudflare.com/ajax/libs/open-dyslexic/2.0.1/font/OpenDyslexic-Bold.woff2) format("woff2");font-weight:700;font-style:normal;font-display:swap}.a11y-dyslexia-font,.a11y-dyslexia-font *:not(svg):not(path):not(line):not(circle):not(rect):not(polyline):not(polygon){font-family:OpenDyslexic,Comic Sans MS,Chalkboard,sans-serif!important;letter-spacing:.05em;word-spacing:.1em}.a11y-highlight-links a,.a11y-highlight-links [role=link],.a11y-highlight-links .btn-link{text-decoration:underline!important;text-underline-offset:.2em;text-decoration-thickness:2px;outline:2px solid var(--primary)!important;outline-offset:2px;background-color:#2563eb14}.a11y-reduce-motion,.a11y-reduce-motion *,.a11y-reduce-motion *:before,.a11y-reduce-motion *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}@media (prefers-reduced-motion: reduce){.a11y-reduce-motion,.a11y-reduce-motion *{animation:none!important;transition:none!important}}.a11y-increase-spacing{--a11y-space-scale: 1.38;--a11y-content-line-height: 1.8;--spacing-xs: calc(.5rem * var(--a11y-space-scale));--spacing-sm: calc(1rem * var(--a11y-space-scale));--spacing-md: calc(1.5rem * var(--a11y-space-scale));--spacing-lg: calc(2rem * var(--a11y-space-scale));--spacing-xl: calc(3rem * var(--a11y-space-scale));--spacing-2xl: calc(4rem * var(--a11y-space-scale));--spacing-3xl: calc(5rem * var(--a11y-space-scale));--spacing-4xl: calc(6rem * var(--a11y-space-scale));letter-spacing:.03em;word-spacing:.05em}.a11y-increase-spacing main p,.a11y-increase-spacing .hero-subtitle,.a11y-increase-spacing .section-subtitle,.a11y-increase-spacing .about-card-text,.a11y-increase-spacing .about-card-title,.a11y-increase-spacing .project-card-description,.a11y-increase-spacing .project-outcome,.a11y-increase-spacing .team-role-text,.a11y-increase-spacing .team-description,.a11y-increase-spacing .why-us-card .card-description,.a11y-increase-spacing .pricing-card-features li,.a11y-increase-spacing .card-description,.a11y-increase-spacing .home-cta-text,.a11y-increase-spacing .footer-tagline,.a11y-increase-spacing .footer-copyright,.a11y-increase-spacing .footer-company,.a11y-increase-spacing .contact-item span,.a11y-increase-spacing .privacy-content p,.a11y-increase-spacing .impressum-content p,.a11y-increase-spacing .process-step-label,.a11y-increase-spacing .accessibility-setting-label,.a11y-increase-spacing .accessibility-setting-info-text{line-height:var(--a11y-content-line-height)}.a11y-increase-spacing main p{margin-bottom:.9em}.a11y-increase-spacing main p:last-child{margin-bottom:0}.a11y-increase-spacing .section-header{margin-bottom:var(--spacing-2xl);gap:var(--spacing-md)}.a11y-increase-spacing .section-title{line-height:1.3}.a11y-increase-spacing .about-card-title{margin-bottom:var(--spacing-sm)}.a11y-increase-spacing .about-card-text{margin-bottom:var(--spacing-xs)}.a11y-increase-spacing .home-cta-title{margin-bottom:var(--spacing-md)}.a11y-increase-spacing .home-cta-text,.a11y-increase-spacing .pricing-footnote,.a11y-increase-spacing .pricing-bottom-text{margin-bottom:var(--spacing-xl)}.a11y-increase-spacing .footer-menu{gap:calc(var(--spacing-sm) * 1.15)}.a11y-increase-spacing .footer-menu li{margin-bottom:0}.a11y-increase-spacing .footer-content{gap:var(--spacing-2xl)}.a11y-increase-spacing .form-group+.form-group{margin-top:var(--spacing-md)}.a11y-increase-spacing .projects-grid{gap:clamp(1.55rem,3.2vw,2.65rem)}.a11y-increase-spacing .accessibility-setting-row{padding-top:var(--spacing-sm);padding-bottom:var(--spacing-sm);row-gap:var(--spacing-xs)}.a11y-increase-spacing .btn-primary,.a11y-increase-spacing .btn-secondary,.a11y-increase-spacing .home-cta-btn,.a11y-increase-spacing .contact-form-container .btn{min-height:2.75rem;padding-top:.65em;padding-bottom:.65em}.a11y-increase-spacing .contact-form-container input,.a11y-increase-spacing .contact-form-container textarea,.a11y-increase-spacing .contact-form-container select{padding-top:.7em;padding-bottom:.7em;line-height:var(--a11y-content-line-height)}.line-guide-overlay{z-index:9990}.high-contrast-light .hero,.high-contrast-light .hero-section{background:#fff!important;color:#000!important}.high-contrast-dark .hero,.high-contrast-dark .hero-section{background:#000!important;color:#fff!important}.high-contrast-light .home-cta-section,.high-contrast-light .home-cta-panel{background-color:#fff!important;border:3px solid #000000!important;box-shadow:none!important}.high-contrast-dark .home-cta-section,.high-contrast-dark .home-cta-panel{background-color:#000!important;border:3px solid #ffffff!important;box-shadow:none!important}.high-contrast-light .home-cta-title,.high-contrast-light .home-cta-text,.high-contrast-light .process-step-label{color:#000!important}.high-contrast-dark .home-cta-title,.high-contrast-dark .home-cta-text,.high-contrast-dark .process-step-label{color:#fff!important}.high-contrast-light .App,.high-contrast-light #main-content{background-color:#fff!important}.high-contrast-dark .App,.high-contrast-dark #main-content{background-color:#000!important}.high-contrast-light .accessibility-switch,.high-contrast-dark .accessibility-switch{border-width:2px!important}.high-contrast-light .accessibility-switch--on,.high-contrast-dark .accessibility-switch--on{border-color:var(--primary)!important}.cookie-consent-overlay{position:fixed;bottom:var(--spacing-lg);left:50%;transform:translate(-50%);z-index:10000;animation:cookieFadeIn .3s ease-out}@keyframes cookieFadeIn{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.cookie-consent-container{max-width:420px;width:calc(100vw - 2rem);background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 8px 32px #0000001f;overflow:hidden}.cookie-consent-main{padding:var(--spacing-md)}.cookie-consent-content-wrapper{display:flex;align-items:flex-start;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.cookie-icon{width:24px;height:24px;flex-shrink:0;object-fit:contain;margin-top:2px}.cookie-consent-text-wrapper{flex:1;min-width:0}.cookie-consent-text{font-size:.875rem;color:var(--text-secondary);margin:0;line-height:1.5}.cookie-consent-buttons{display:flex;gap:var(--spacing-sm);align-items:center;justify-content:flex-end;flex-wrap:wrap}.cookie-btn{padding:8px 16px;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center}.cookie-btn-primary{background-color:var(--primary);color:#fff}.cookie-btn-primary:hover{background-color:var(--primary-dark)}.cookie-btn-link{background:transparent;color:var(--text-secondary);padding:8px 12px}.cookie-btn-link:hover{color:var(--primary);background-color:var(--bg-secondary)}.cookie-btn-secondary{background-color:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border)}.cookie-btn-secondary:hover{background-color:var(--bg-tertiary);border-color:var(--primary)}.cookie-consent-details-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);border-bottom:1px solid var(--border)}.cookie-consent-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.cookie-consent-close-btn{background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:4px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .2s ease}.cookie-consent-close-btn:hover{background-color:var(--bg-secondary);color:var(--text-primary)}.cookie-consent-actions{display:flex;gap:var(--spacing-sm);padding:var(--spacing-md);border-top:1px solid var(--border);justify-content:flex-end;align-items:center}.cookie-btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.cookie-consent-details{max-height:70vh;overflow-y:auto}.cookie-categories{padding:var(--spacing-md);display:flex;flex-direction:column;gap:0}.cookie-category{padding:var(--spacing-md);background-color:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);transition:all .2s ease;margin-bottom:var(--spacing-sm)}.cookie-category:hover{border-color:var(--primary)}.cookie-category-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-md)}.cookie-category-info{flex:1;min-width:0}.cookie-category-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0 0 var(--spacing-xs) 0;line-height:1.4}.cookie-category-description{font-size:.875rem;color:var(--text-secondary);margin:0;line-height:1.5}.cookie-toggle{position:relative;display:inline-block;width:48px;height:24px;flex-shrink:0;cursor:pointer}.cookie-toggle input{opacity:0;width:0;height:0}.cookie-toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--border);transition:.3s;border-radius:24px}.cookie-toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%;box-shadow:0 2px 4px #0003}.cookie-toggle input:checked+.cookie-toggle-slider{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%)}.cookie-toggle input:checked+.cookie-toggle-slider:before{transform:translate(24px)}.cookie-toggle input:disabled+.cookie-toggle-slider{opacity:.6;cursor:not-allowed;background-color:var(--primary)}.cookie-toggle input:focus-visible+.cookie-toggle-slider{outline:3px solid var(--primary);outline-offset:2px}.dark .cookie-toggle-slider{background-color:var(--bg-tertiary)}.dark .cookie-toggle input:checked+.cookie-toggle-slider{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%)}.high-contrast-light .cookie-category,.high-contrast-light .cookie-toggle-slider{border:3px solid #000000!important;background-color:#fff!important}.high-contrast-light .cookie-toggle input:checked+.cookie-toggle-slider{background-color:#06c!important;border-color:#000!important}.high-contrast-light .cookie-toggle input:focus+.cookie-toggle-slider{outline:4px solid #0066CC!important;outline-offset:4px!important}.high-contrast-dark .cookie-category,.high-contrast-dark .cookie-toggle-slider{border:3px solid #FFFFFF!important;background-color:#000!important}.high-contrast-dark .cookie-toggle input:checked+.cookie-toggle-slider{background-color:#ff0!important;border-color:#fff!important}.high-contrast-dark .cookie-toggle input:focus+.cookie-toggle-slider{outline:4px solid #FFFF00!important;outline-offset:4px!important}.dark .cookie-consent-container{background-color:var(--bg-primary);border-color:var(--border)}.dark .cookie-consent-btn-decline{background-color:var(--bg-secondary);border-color:var(--border)}.dark .cookie-consent-btn-decline:hover{background-color:var(--bg-tertiary)}.high-contrast-light .cookie-consent-container{background-color:#fff!important;border:3px solid #000000!important;box-shadow:0 4px 12px #000c!important}.high-contrast-light .cookie-consent-text,.high-contrast-light .cookie-consent-title,.high-contrast-light .cookie-consent-description-compact{color:#000!important;font-weight:600!important}.high-contrast-light .cookie-icon{filter:none!important;opacity:1!important}.high-contrast-light .cookie-btn{border:3px solid #000000!important;font-weight:700!important;min-height:44px!important}.high-contrast-light .cookie-btn-primary{background-color:#06c!important;color:#fff!important;border-color:#000!important}.high-contrast-light .cookie-btn-primary:hover,.high-contrast-light .cookie-btn-primary:focus{background-color:#0052a3!important;outline:4px solid #0066CC!important;outline-offset:4px!important}.high-contrast-light .cookie-btn-link{background-color:#fff!important;color:#000!important;border-color:#000!important}.high-contrast-light .cookie-btn-link:hover,.high-contrast-light .cookie-btn-link:focus{background-color:#06c!important;color:#fff!important;outline:4px solid #0066CC!important;outline-offset:4px!important}.high-contrast-light .cookie-btn-secondary{background-color:#fff!important;color:#000!important;border-color:#000!important}.high-contrast-light .cookie-btn-secondary:hover,.high-contrast-light .cookie-btn-secondary:focus{background-color:#06c!important;color:#fff!important;outline:4px solid #0066CC!important;outline-offset:4px!important}.high-contrast-light .cookie-consent-close-btn{border:2px solid #000000!important;color:#000!important}.high-contrast-light .cookie-consent-close-btn:hover,.high-contrast-light .cookie-consent-close-btn:focus{background-color:#06c!important;color:#fff!important;outline:4px solid #0066CC!important;outline-offset:4px!important}.high-contrast-light .cookie-consent-close-btn svg{stroke-width:3!important}.high-contrast-light .cookie-category-title,.high-contrast-light .cookie-category-description{color:#000!important;font-weight:600!important}.high-contrast-dark .cookie-consent-container{background-color:#000!important;border:3px solid #FFFFFF!important;box-shadow:0 4px 12px #fffc!important}.high-contrast-dark .cookie-consent-text,.high-contrast-dark .cookie-consent-title,.high-contrast-dark .cookie-consent-description-compact{color:#fff!important;font-weight:600!important}.high-contrast-dark .cookie-icon{filter:brightness(0) invert(1)!important;opacity:1!important}.high-contrast-dark .cookie-btn{border:3px solid #FFFFFF!important;font-weight:700!important;min-height:44px!important}.high-contrast-dark .cookie-btn-primary{background-color:#ff0!important;color:#000!important;border-color:#fff!important}.high-contrast-dark .cookie-btn-primary:hover,.high-contrast-dark .cookie-btn-primary:focus{background-color:#ff3!important;outline:4px solid #FFFF00!important;outline-offset:4px!important}.high-contrast-dark .cookie-btn-link{background-color:#000!important;color:#fff!important;border-color:#fff!important}.high-contrast-dark .cookie-btn-link:hover,.high-contrast-dark .cookie-btn-link:focus{background-color:#ff0!important;color:#000!important;outline:4px solid #FFFF00!important;outline-offset:4px!important}.high-contrast-dark .cookie-btn-secondary{background-color:#000!important;color:#fff!important;border-color:#fff!important}.high-contrast-dark .cookie-btn-secondary:hover,.high-contrast-dark .cookie-btn-secondary:focus{background-color:#ff0!important;color:#000!important;outline:4px solid #FFFF00!important;outline-offset:4px!important}.high-contrast-dark .cookie-consent-close-btn{border:2px solid #FFFFFF!important;color:#fff!important}.high-contrast-dark .cookie-consent-close-btn:hover,.high-contrast-dark .cookie-consent-close-btn:focus{background-color:#ff0!important;color:#000!important;outline:4px solid #FFFF00!important;outline-offset:4px!important}.high-contrast-dark .cookie-consent-close-btn svg{stroke-width:3!important}.high-contrast-dark .cookie-category-title,.high-contrast-dark .cookie-category-description{color:#fff!important;font-weight:600!important}@media (max-width: 768px){.accessibility-toggle-wrapper{display:none!important}.accessibility-panel,.accessibility-panel.accessibility-panel--right{left:0;right:0;top:max(.5rem,env(safe-area-inset-top,0px));bottom:calc(72px + env(safe-area-inset-bottom,0px));width:100%;max-width:100%;max-height:none;height:auto;border-radius:var(--radius-xl) var(--radius-xl) 0 0;border-left:none;border-right:none;border-bottom:none;animation:panelSlideUp .25s ease-out}.accessibility-panel-header h2{font-size:1.125rem}.accessibility-setting-row .accessibility-setting-label{font-size:.875rem}.accessibility-setting-info-text{padding-left:calc(32px + var(--spacing-xs));font-size:.8125rem}.accessibility-options-grid{grid-template-columns:1fr}.cookie-consent-overlay{bottom:var(--spacing-sm);left:var(--spacing-sm);right:var(--spacing-sm);transform:none}.cookie-consent-container{max-width:100%;width:100%}.cookie-consent-main{padding:var(--spacing-sm)}.cookie-consent-content-wrapper{margin-bottom:var(--spacing-sm)}.cookie-consent-buttons{flex-direction:column;width:100%}.cookie-btn{width:100%}.cookie-consent-details{max-height:80vh}.cookie-category-header{flex-direction:column;gap:var(--spacing-sm)}.cookie-toggle{align-self:flex-start}.accessibility-tooltip{white-space:normal;max-width:calc(100vw - 80px);left:auto;right:0;transform:none}.accessibility-tooltip:after{left:auto;right:24px;transform:none}}*:focus-visible{outline:3px solid var(--primary);outline-offset:2px;border-radius:4px}button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:3px solid var(--primary);outline-offset:2px}.high-contrast-light *:focus-visible,.high-contrast-light button:focus-visible,.high-contrast-light a:focus-visible,.high-contrast-light input:focus-visible,.high-contrast-light textarea:focus-visible,.high-contrast-light select:focus-visible{outline:4px solid #0000FF!important;outline-offset:4px!important;border-radius:0!important}.high-contrast-dark *:focus-visible,.high-contrast-dark button:focus-visible,.high-contrast-dark a:focus-visible,.high-contrast-dark input:focus-visible,.high-contrast-dark textarea:focus-visible,.high-contrast-dark select:focus-visible{outline:4px solid #00FFFF!important;outline-offset:4px!important;border-radius:0!important}*:focus:not(:focus-visible){outline:none}img{max-width:100%;height:auto;display:block;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}img[loading=lazy]{background-color:transparent;transition:opacity .3s ease}img[loading=lazy]:not([src]){opacity:0}.container{max-width:1280px;margin:0 auto;padding:0 var(--spacing-lg)}@media (max-width: 1200px){.container{padding:0 var(--spacing-md)}}@media (max-width: 768px){.container{padding:0 var(--spacing-sm)}body{font-size:15px}}@media (max-width: 480px){body{font-size:14px}}.progress-bar-container{position:fixed;top:0;left:0;width:100%;height:3px;background-color:transparent;z-index:10000;overflow:hidden;opacity:1;transition:opacity .3s ease}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--accent),var(--primary-light));background-size:200% 100%;animation:progress-shimmer 1.5s ease-in-out infinite;box-shadow:0 0 10px #2563eb80,0 0 20px #2563eb4d;transition:width .08s linear,opacity .3s ease;opacity:1}.progress-bar-fill.complete{animation:progress-shimmer .5s ease-in-out,progress-complete .4s ease-out .1s}@keyframes progress-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes progress-complete{0%{opacity:1}to{opacity:0}}header{background-color:var(--surface-nav);border-bottom:1px solid var(--surface-border-strong);position:fixed;top:0;left:0;right:0;width:100%;z-index:1000;box-shadow:0 14px 30px -24px #1e40af73;transition:background-color .25s ease,border-color .25s ease;min-height:var(--header-height)}.dark header{background-color:var(--surface-nav);border-bottom-color:var(--surface-border-strong);box-shadow:0 12px 28px -20px #020617e6}.dark .hero-badge{background:#1e293bcc;border-color:var(--border);color:var(--text-secondary);box-shadow:0 2px 8px #0000004d}.dark .member-header{background:linear-gradient(135deg,#3b82f61a,#38bdf81a);border-bottom-color:var(--border)}.dark .project-content{background-color:var(--bg-secondary)}.navbar{padding:0;min-height:var(--header-height);display:flex;align-items:center;box-sizing:border-box}.navbar .container.navbar-inner{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;column-gap:clamp(var(--spacing-sm),2vw,var(--spacing-xl));row-gap:var(--spacing-xs);position:relative;padding-left:clamp(var(--spacing-xs),1.25vw,var(--spacing-md));padding-right:clamp(var(--spacing-xs),1.25vw,var(--spacing-md));min-height:var(--header-height);box-sizing:border-box}.navbar-nav-center{justify-self:center;justify-content:center;min-width:0;max-width:100%}.navbar-brand{display:flex;align-items:center;justify-self:start;min-width:0;flex-shrink:0}.navbar-actions{display:flex;align-items:center;justify-content:flex-end;justify-self:end;gap:clamp(.65rem,1.5vw,1.1rem);flex-shrink:0;min-width:0}.logo-wrapper{position:relative;display:flex;align-items:center;align-self:center;flex:0 0 auto;margin-left:0}.navbar-search-standalone{display:flex;align-items:center;flex-shrink:0}.navbar-utilities{display:inline-flex;align-items:stretch;flex-shrink:0;gap:0}.navbar-utilities .language-selector-wrapper{margin-right:0}.language-selector-wrapper,.theme-select-wrapper{position:relative;z-index:5}@media (min-width: 1141px){.navbar-search-standalone{border-radius:var(--radius-lg);background:color-mix(in srgb,var(--bg-primary) 72%,var(--surface-nav));border:1px solid color-mix(in srgb,var(--surface-border-strong) 65%,var(--border));box-shadow:0 2px 10px -8px #2563eb8c;padding:0 .2rem;min-height:44px}.navbar-search-standalone .nav-search-open-btn{width:44px;height:44px}.navbar-utilities{border-radius:var(--radius-lg);background:color-mix(in srgb,var(--bg-primary) 72%,var(--surface-nav));border:1px solid color-mix(in srgb,var(--surface-border-strong) 65%,var(--border));overflow:visible;box-shadow:0 2px 10px -8px #2563eb99}.navbar-utilities>.theme-select-wrapper,.navbar-utilities>.language-selector-wrapper{display:flex;align-items:center;justify-content:center;min-height:44px;padding:0 .35rem}.navbar-utilities>*+*{border-left:1px solid color-mix(in srgb,var(--surface-border-strong) 70%,transparent)}.navbar-utilities .language-selector-btn{min-height:44px;padding:0 .65rem}}.dark .navbar-utilities{box-shadow:0 4px 18px -14px #93c5fd80}.nav-search-open-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);border:none;background:transparent;color:var(--text-secondary);cursor:pointer;padding:0;flex-shrink:0;transition:color .2s ease,background .2s ease}.nav-search-open-btn:hover{color:var(--primary);background:color-mix(in srgb,var(--bg-primary) 70%,transparent)}.nav-search-open-btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.nav-search-open-btn svg{width:20px;height:20px}.search-overlay-root{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10050;display:flex;align-items:flex-start;justify-content:center;padding:min(10vh,5rem) var(--spacing-md) var(--spacing-md);pointer-events:none}.search-overlay-root>*{pointer-events:auto}.search-overlay-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;margin:0;padding:0;border:none;cursor:pointer;background:#0f172a7a;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:searchOverlayFadeIn .2s ease}.dark .search-overlay-backdrop{background:#020617bf}@keyframes searchOverlayFadeIn{0%{opacity:0}to{opacity:1}}.search-overlay-panel{position:relative;z-index:1;width:100%;max-width:560px;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl),0 24px 48px #0f172a1f;padding:var(--spacing-md);animation:searchPanelIn .28s cubic-bezier(.22,1,.36,1)}.dark .search-overlay-panel{box-shadow:var(--shadow-xl),0 0 0 1px #94a3b814}@keyframes searchPanelIn{0%{opacity:0;transform:translateY(-10px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}.search-overlay-header{display:flex;align-items:flex-start;gap:var(--spacing-sm)}.search-overlay-input-wrap{flex:1;min-width:0}.search-overlay-input{width:100%!important;max-width:none!important}.search-overlay-input:focus{width:100%!important}.search-overlay-shortcut{opacity:.9}.search-overlay-close{flex-shrink:0;width:40px;height:40px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:border-color .2s ease,color .2s ease,background .2s ease}.search-overlay-close:hover{color:var(--primary);border-color:color-mix(in srgb,var(--primary) 35%,var(--border));background:var(--bg-tertiary)}.search-overlay-close:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.search-overlay-panel .search-dropdown.search-overlay-dropdown{position:static;margin-top:var(--spacing-sm);width:100%;left:auto;right:auto;max-height:min(420px,55vh);transform:none}.search-overlay-panel .search-dropdown.search-overlay-dropdown.active{display:block;opacity:1;transform:none}.theme-toggle{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);cursor:pointer;transition:color .2s ease,background .2s ease;padding:0;position:relative;flex-shrink:0;border:none;background:transparent;color:var(--text-secondary);box-shadow:none}.theme-toggle:hover{color:var(--primary);background:color-mix(in srgb,var(--bg-primary) 70%,transparent)}.theme-toggle:active{transform:scale(.97)}.theme-toggle:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.theme-toggle svg{width:20px;height:20px;transition:opacity .2s ease}.theme-toggle:hover svg{transform:none}.theme-select-btn.theme-toggle{width:auto;min-width:44px;height:44px;padding:0 .5rem 0 .45rem;gap:4px;border-radius:var(--radius-md)}.theme-select-glyph{display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.theme-select-btn.theme-toggle:hover .theme-select-glyph{color:var(--primary)}.theme-select-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background:var(--bg-primary);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 24px #0000001f,0 2px 8px #00000014;overflow:hidden;z-index:1200;animation:dropdownFadeIn .15s ease;padding:4px}.theme-select-option{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 12px;background:none;border:none;border-radius:8px;cursor:pointer;color:var(--text-primary);font-size:.9375rem;font-weight:500;text-align:left;transition:background .15s ease;gap:var(--spacing-sm)}.theme-select-option:hover{background:var(--bg-secondary)}.theme-select-option.active{background:var(--bg-secondary);color:var(--primary)}.theme-select-option-label{flex:1}.language-selector-wrapper{position:relative;z-index:100;margin-right:calc(-1 * var(--spacing-sm))}.logo{display:flex;align-items:center;gap:var(--spacing-xs);line-height:0;text-decoration:none;transition:opacity .2s ease,transform .2s ease}.logo:hover{opacity:.9;transform:translateY(-1px)}.navbar-logo-img{display:block;height:44px;width:auto;max-height:46px;object-fit:contain}@media (max-width: 768px){.navbar-logo-img{height:36px;max-height:38px}}.language-selector-btn{display:flex;align-items:center;gap:6px;padding:6px 10px;background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;color:var(--text-primary);transition:background .15s ease,color .15s ease;min-width:auto;font-size:.875rem}.language-selector-btn:hover{background:color-mix(in srgb,var(--bg-primary) 70%,transparent)}.language-flag-wrapper{position:relative;width:28px;height:20px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.language-flag-wrapper-dropdown{position:relative;width:32px;height:24px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.language-flag-img-btn{width:28px;height:20px;object-fit:contain;flex-shrink:0;border-radius:4px;box-shadow:none;border:none;display:block}.language-flag-img{width:32px;height:24px;object-fit:contain;flex-shrink:0;border-radius:4px;box-shadow:none;border:none;display:block}.language-flag-emoji,.language-flag-emoji-dropdown{font-size:20px;line-height:1;display:block;width:28px;height:20px;text-align:center;flex-shrink:0}.language-code{font-size:.8125rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-left:2px}.language-name-wrapper{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.language-code-dropdown{font-size:.6875rem;font-weight:600;color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;opacity:.7}.language-arrow{width:12px;height:12px;transition:transform .2s ease;color:var(--text-secondary);margin-left:2px}.language-arrow.open{transform:rotate(180deg)}.language-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background:var(--bg-primary);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 24px #0000001f,0 2px 8px #00000014;overflow:hidden;z-index:1200;animation:dropdownFadeIn .15s ease;padding:4px}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.language-option{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 12px;background:none;border:none;border-radius:8px;cursor:pointer;color:var(--text-primary);font-size:.9375rem;font-weight:400;text-align:left;transition:all .15s ease;gap:var(--spacing-sm)}.language-option:hover,.language-option.active{background:var(--bg-secondary)}.language-option-content{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.language-name{font-weight:500;color:var(--text-primary)}.language-option.active .language-name{font-weight:600;color:var(--primary)}.language-check{width:18px;height:18px;color:var(--primary);flex-shrink:0;opacity:0;transform:scale(.8);transition:all .15s ease}.language-option.active .language-check{opacity:1;transform:scale(1)}.nav-search-container{position:relative;display:flex;align-items:center;width:100%}.nav-search-icon{position:absolute;left:var(--spacing-md);width:20px;height:20px;color:var(--text-secondary);pointer-events:none;z-index:1}.search-overlay-input.nav-search-input{width:100%;padding:var(--spacing-sm) 5.5rem var(--spacing-sm) 3rem;border:2px solid var(--border);border-radius:var(--radius-xl);background:var(--bg-secondary);color:var(--text-primary);font-size:.9375rem;font-weight:500;outline:none;height:44px;line-height:1;box-sizing:border-box}.search-overlay-input.nav-search-input:focus{border-color:var(--primary);background:var(--bg-primary);box-shadow:0 0 0 4px #2563eb1a}.search-overlay-input.nav-search-input::placeholder{color:var(--text-light);font-weight:400;opacity:.7}.search-shortcut-hint{position:absolute;right:var(--spacing-md);display:flex;align-items:center;gap:2px;pointer-events:none;opacity:1;z-index:2}.search-shortcut-hint kbd{display:inline-flex;align-items:center;justify-content:center;padding:2px 6px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:4px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:.75rem;font-weight:600;color:var(--text-secondary);line-height:1;box-shadow:0 1px 2px #0000000d;min-width:20px;text-align:center}.search-dropdown{display:none;position:absolute;top:calc(100% + var(--spacing-xs));left:0;right:0;width:100%;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 12px 48px #00000026;max-height:500px;overflow:hidden;z-index:1001;opacity:0;transform:translateY(-8px) scale(.98);transition:opacity .2s ease-out .1s,transform .2s ease-out .1s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);margin-top:var(--spacing-xs);will-change:opacity,transform}.search-dropdown.active{display:block;opacity:1;transform:translateY(0) scale(1)}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.search-hint{padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-secondary);border-bottom:none}.search-results-list:not(:empty){border-top:1px solid var(--border);padding-top:var(--spacing-sm)}.search-hint-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;color:var(--text-primary);font-weight:600;font-size:.8125rem}.search-hint-header svg{width:16px;height:16px;color:var(--primary);flex-shrink:0}.search-hint-content{display:flex;flex-direction:column;gap:.25rem}.search-hint-item{display:flex;align-items:center;gap:.5rem;padding:.375rem .5rem;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.8125rem;transition:all .2s ease}.search-hint-item:hover{background:#2563eb0d;color:var(--text-primary)}.search-hint-item svg{width:16px;height:16px;color:var(--primary);flex-shrink:0}.search-hint-item strong{color:var(--text-primary);font-weight:600}.nav-menu{display:flex;list-style:none;gap:clamp(.35rem,1.1vw,var(--spacing-xl));align-items:center;margin:0;padding:0;justify-content:center;flex-wrap:nowrap;min-width:0;max-width:100%}.nav-menu>li{display:flex;align-items:center}.nav-menu a{display:inline-flex;align-items:center;gap:.45rem;text-decoration:none;color:var(--text-primary);font-weight:500;font-size:.9375rem;line-height:1.2;padding:.35rem 0;position:relative;transition:color .2s ease;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.nav-menu a svg{width:19px;height:19px;flex-shrink:0;display:block;opacity:.78;transition:opacity .2s ease}.nav-menu a:hover{color:var(--primary)}.nav-menu>li>a.nav-link-active,.nav-dropdown-toggle.nav-link-active{color:var(--accent);font-weight:600}.nav-menu>li>a.nav-link-active svg,.nav-dropdown-toggle.nav-link-active svg{opacity:1}.nav-menu>li>a.nav-link-active:after,.nav-dropdown-toggle.nav-link-active:after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:2px;background-color:var(--accent);border-radius:999px}.nav-submenu a.nav-link-active{background:var(--bg-secondary, #f8fafc);color:var(--primary, #2563eb);font-weight:600}.nav-submenu a.nav-link-active svg{opacity:1}.mobile-menu-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:var(--spacing-xs);transition:all .4s cubic-bezier(.4,0,.2,1)}@media (min-width: 1141px){.mobile-menu-toggle{display:none!important}.navbar .container.navbar-inner{grid-template-columns:auto minmax(0,1fr) auto}.nav-menu,.nav-menu.navbar-nav-center{position:static;top:auto;left:auto;right:auto;flex-direction:row;width:auto;max-width:100%;max-height:none;opacity:1;visibility:visible;overflow:visible;padding:0;margin:0;box-shadow:none;border:none;background:transparent;z-index:auto}.nav-menu li{width:auto;border-bottom:none}.nav-menu li a{width:auto;min-height:unset;padding:.35rem .15rem;font-size:clamp(.8125rem,.9vw,.9375rem);justify-content:center}.nav-menu li a span{position:static;width:auto;height:auto;padding:0;margin:0;overflow:visible;clip:auto;white-space:nowrap;border:0}.nav-menu li a:after{display:block}.nav-menu li a:hover,.nav-menu li a:active{background-color:transparent;padding-left:.15rem}}.mobile-menu-toggle span{width:24px;height:2px;background-color:var(--text-primary);border-radius:2px;transition:all .3s ease}.search-results-list{padding:var(--spacing-sm);max-height:400px;overflow-y:auto}.search-results-list:empty{display:none}.search-result-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);text-decoration:none;color:var(--text-primary);margin-bottom:var(--spacing-xs);border:1px solid transparent;background:transparent}.search-result-item:last-child{margin-bottom:0}.search-result-item:hover{background:var(--bg-secondary);border-color:#2563eb26;transform:translate(2px);box-shadow:0 2px 8px #0000000d}.search-result-item.active{background:linear-gradient(135deg,#2563eb14,#0ea5e914);border-color:#2563eb33}.search-result-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#2563eb14,#0ea5e914);border-radius:var(--radius-md);flex-shrink:0;color:var(--primary);border:1px solid rgba(37,99,235,.12);transition:all .2s ease;padding:0}.search-result-item:hover .search-result-icon{background:linear-gradient(135deg,#2563eb1f,#0ea5e91f);border-color:#2563eb33;transform:scale(1.05)}.search-result-icon svg{width:20px;height:20px;flex-shrink:0}.search-result-favicon{width:20px;height:20px;object-fit:contain;border-radius:var(--radius-sm);display:block;flex-shrink:0}.search-result-content{flex:1;min-width:0}.search-result-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:4px;line-height:1.3;transition:color .2s ease}.search-result-item:hover .search-result-title{color:var(--primary)}.search-result-subtitle{font-size:.875rem;color:var(--text-secondary);line-height:1.4;opacity:.8;transition:opacity .2s ease}.search-result-item:hover .search-result-subtitle{opacity:1}.search-result-meta{font-size:.8125rem;color:var(--text-secondary);display:flex;align-items:center;gap:var(--spacing-xs);flex-wrap:wrap;line-height:1.5}.search-result-tech{display:inline-flex;align-items:center;padding:2px 6px;background:var(--bg-secondary);border-radius:4px;font-size:.75rem;font-weight:500;color:var(--primary)}.search-no-results{padding:var(--spacing-xl);text-align:center;color:var(--text-secondary);font-size:.875rem;line-height:1.6}@media (max-width: 968px){.navbar .container.navbar-inner{grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);column-gap:var(--spacing-md)}.nav-menu{gap:var(--spacing-md)}}@media (max-width: 1140px){.navbar{padding:0;height:var(--header-height);min-height:var(--header-height);max-height:var(--header-height)}.navbar .container.navbar-inner{display:grid;grid-template-columns:auto 1fr auto;align-items:center;column-gap:var(--spacing-sm);padding:0 clamp(var(--spacing-sm),2vw,var(--spacing-md));height:100%;position:relative}.navbar-nav-center{position:fixed;justify-self:stretch}.navbar-brand{display:flex;align-items:center;gap:var(--spacing-md);flex:0 0 auto}.logo-wrapper{position:relative;display:flex;align-items:center;min-width:0;height:100%;width:auto}.logo{font-size:1.25rem;display:flex;align-items:center;gap:var(--spacing-xs);transition:opacity .2s ease,visibility .2s ease;white-space:nowrap;position:relative;z-index:1}.logo svg{width:28px;height:28px;flex-shrink:0}.nav-menu{position:fixed;top:calc(var(--header-height) + 1px);left:0;right:0;background-color:var(--bg-primary);flex-direction:column;gap:0;padding:var(--spacing-sm) 0;box-shadow:0 4px 20px #0000001a;max-height:0;overflow-y:auto;overflow-x:hidden;transition:max-height .3s ease,padding .3s ease,opacity .3s ease,visibility .3s ease;border-bottom:1px solid var(--border);z-index:999;width:100%;opacity:0;visibility:hidden}.nav-menu.active{max-height:min(70vh,22rem);opacity:1;visibility:visible;padding:.25rem 0}.nav-menu li{width:100%;margin:0}.nav-menu li{border-bottom:1px solid var(--border)}.nav-menu li:last-child{border-bottom:none}.nav-menu li a{padding:.55rem var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-sm);width:100%;font-size:.875rem;justify-content:flex-start;min-height:42px;transition:background-color .2s ease,color .2s ease;border-radius:0}.nav-menu li a:after{display:none}.nav-menu li a svg{width:20px;height:20px;flex-shrink:0;opacity:.8}.nav-menu li a span{font-weight:500}.nav-dropdown{width:100%}.navbar .nav-dropdown-toggle{width:100%;justify-content:flex-start;padding:var(--spacing-md) var(--spacing-lg);border-radius:0;border:none;background:transparent;cursor:default}.navbar .nav-dropdown-toggle:hover,.navbar .nav-dropdown-toggle:focus-visible{border-color:transparent;background:transparent}.navbar .nav-dropdown-toggle .chevron{display:none}.navbar .nav-submenu{position:static;box-shadow:none;border:none;padding:0;background:transparent;display:block;margin:0}.navbar .nav-submenu a{padding:.5rem var(--spacing-xl);font-size:.9rem}.nav-menu li a:hover,.nav-menu li a:active{background-color:var(--bg-secondary);color:var(--primary);padding-left:calc(var(--spacing-lg) + 4px)}.nav-menu li a:hover svg,.nav-menu li a:active svg{opacity:1;transform:scale(1.1)}.navbar-actions{display:flex;align-items:center;gap:.35rem;flex-shrink:0;padding:0;border:none;border-radius:0;background:none}.navbar-search-standalone{border:none;border-radius:0;background:none;box-shadow:none;padding:0;min-height:unset}.navbar-utilities{display:inline-flex;align-items:center;gap:.25rem;flex-wrap:nowrap;border:none;border-radius:0;background:none;overflow:visible}.navbar-utilities>.theme-select-wrapper,.navbar-utilities>.language-selector-wrapper{min-height:unset;padding:0;border:none;border-radius:0}.navbar-utilities>*+*{border-left:none}.navbar-utilities .language-selector-wrapper{margin:0}.navbar-search-standalone .nav-search-open-btn{width:40px;height:40px}.theme-select-btn.theme-toggle{width:40px;min-width:40px;height:40px;padding:0}.theme-select-btn.theme-toggle .language-arrow{display:none}.mobile-menu-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;flex-shrink:0;position:relative;z-index:1001;padding:4px}.navbar-logo-img{max-height:36px;width:auto}.language-selector-btn{min-width:52px;padding:2px 4px;font-size:.75rem}.language-dropdown{right:0;left:auto}}@media (max-width: 768px){.accessibility-toggle-wrapper{display:none!important}.back-to-top-wrapper{bottom:calc(88px + env(safe-area-inset-bottom,0));z-index:100}.App,#main-content{padding-bottom:calc(72px + env(safe-area-inset-bottom,0))}}.bottom-nav{display:none}@media (max-width: 768px){.bottom-nav{display:block;position:fixed;bottom:0;left:0;right:0;z-index:1000;width:100%;height:72px;min-height:72px;padding-bottom:env(safe-area-inset-bottom,0);background-color:var(--bg-primary);border-top:1px solid var(--border);box-shadow:0 -4px 20px #00000014}.bottom-nav-inner{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));max-width:100%;height:100%;margin:0 auto;padding:0 .15rem;align-items:center}.bottom-nav-link,.bottom-nav-link-button{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.5rem .25rem;min-height:56px;color:var(--text-secondary);text-decoration:none;transition:background-color .15s ease,color .15s ease;-webkit-tap-highlight-color:transparent;border:none;background:none;cursor:pointer;font:inherit}.bottom-nav-link:hover,.bottom-nav-link-button:hover{background-color:var(--bg-secondary);color:var(--primary)}.bottom-nav-link:focus-visible,.bottom-nav-link-button:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.bottom-nav-link--active,.bottom-nav-link--active .bottom-nav-icon{color:var(--primary)}.bottom-nav-icon{width:24px;height:24px;flex-shrink:0;color:inherit}.bottom-nav-icon svg{width:100%;height:100%}.bottom-nav-label{font-size:.625rem;line-height:1.15;text-align:center;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;padding:0 1px}.bottom-nav-icon{width:22px;height:22px}}.high-contrast-light .bottom-nav{background-color:#fff!important;border-top:3px solid #000000!important}.high-contrast-light .bottom-nav-link,.high-contrast-light .bottom-nav-link-button{color:#000!important}.high-contrast-light .bottom-nav-link--active,.high-contrast-light .bottom-nav-link:hover,.high-contrast-light .bottom-nav-link-button:hover{color:var(--primary)!important}.high-contrast-dark .bottom-nav{background-color:#000!important;border-top:3px solid #FFFFFF!important}.high-contrast-dark .bottom-nav-link,.high-contrast-dark .bottom-nav-link-button{color:#fff!important}.high-contrast-dark .bottom-nav-link--active,.high-contrast-dark .bottom-nav-link:hover,.high-contrast-dark .bottom-nav-link-button:hover{color:var(--primary)!important}.hero,.hero-section{background:linear-gradient(135deg,#f8fafc,#e0e7ff,#f0f9ff);color:var(--text-primary);padding:0;position:relative;overflow-x:hidden;overflow-y:visible;min-height:100vh;display:flex;align-items:center;justify-content:center;transition:background .3s ease}.dark .hero,.dark .hero-section{background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a)}.hero .container,.hero-section .container{padding:var(--spacing-4xl) var(--spacing-lg);position:relative;z-index:1;width:100%;overflow:visible}.hero-background{position:absolute;top:0;left:0;right:0;bottom:0;overflow:hidden}.hero-gradient-orb{position:absolute;border-radius:50%;filter:blur(100px);opacity:.3;animation:floatOrb 20s infinite ease-in-out}.hero-orb-1{width:600px;height:600px;background:radial-gradient(circle,#3b82f6 0%,transparent 70%);top:-200px;right:-200px;animation-delay:0s}.hero-orb-2{width:500px;height:500px;background:radial-gradient(circle,#0ea5e9 0%,transparent 70%);bottom:-150px;left:-150px;animation-delay:-7s}.hero-orb-3{width:400px;height:400px;background:radial-gradient(circle,#2563eb 0%,transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:-14s}.hero-badge{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-md);margin-bottom:var(--spacing-2xl);background:#fff9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius-xl);border:1px solid rgba(0,0,0,.08);color:var(--text-secondary);font-size:.875rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase;animation:fadeInUp .6s ease-out;box-shadow:0 2px 12px #00000014}.dark .hero-badge{background:#1e293b99;border:1px solid rgba(255,255,255,.1);box-shadow:0 2px 12px #0000004d}.badge-dot{width:4px;height:4px;border-radius:50%;background:var(--primary);display:inline-block}.badge-text{color:var(--text-secondary)}.badge-sub{color:var(--text-secondary);opacity:.8}.hero-content{max-width:1000px;margin:0 auto;text-align:center}.hero-title{font-size:clamp(2.5rem,6vw,5rem);font-weight:800;margin-bottom:var(--spacing-2xl);line-height:1.3;letter-spacing:-.02em;text-align:center;overflow:visible;animation:fadeInUp .8s ease-out .2s both}.title-line{display:block;animation:fadeInUp .8s ease-out both;padding:.1em 0;overflow:visible;text-overflow:clip}.title-line:nth-child(1){animation-delay:.1s}.title-line:nth-child(2){animation-delay:.2s}.title-line:nth-child(3){animation-delay:.3s}.hero-title .highlight{background:linear-gradient(135deg,#2563eb,#0ea5e9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative;overflow:visible;padding:.1em 0}.hero-description{font-size:clamp(1rem,1.8vw,1.25rem);color:var(--text-secondary);max-width:650px;margin:0 auto var(--spacing-xl);line-height:1.75;animation:fadeInUp .8s ease-out .4s both}.hero-buttons,.hero-actions{display:flex;gap:var(--spacing-md);justify-content:center;margin-bottom:var(--spacing-2xl);flex-wrap:wrap;animation:fadeInUp .8s ease-out .5s both}.btn{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-2xl);border-radius:var(--radius-md);text-decoration:none;font-weight:600;font-size:clamp(.9375rem,1.5vw,1rem);line-height:1.5;transition:all .3s cubic-bezier(.4,0,.2,1);border:none;cursor:pointer;position:relative}.btn-primary{background:linear-gradient(135deg,#2563eb,#1e40af);color:#fff;box-shadow:0 4px 12px #2563eb40}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #2563eb59;background:linear-gradient(135deg,#1e40af,#1e3a8a)}.btn-primary svg{transition:transform .3s ease}.btn-primary:hover svg{transform:translate(4px)}.btn-secondary{background:#fff;color:var(--text-primary);border:2px solid var(--border);box-shadow:0 2px 8px #0000000d}.dark .btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border);box-shadow:0 2px 8px #0000004d}.btn-secondary:hover{background:var(--bg-secondary);border-color:var(--primary);color:var(--primary);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.dark .btn-secondary:hover{background:var(--bg-tertiary);border-color:var(--primary);color:var(--primary);box-shadow:0 4px 12px #3b82f64d}.hero-stats{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xl);max-width:600px;margin:0 auto;animation:fadeInUp .8s ease-out .6s both}.stat-item{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs)}.stat-number{font-size:clamp(2rem,5vw,3.5rem);font-weight:800;color:var(--text-primary);letter-spacing:-.02em;line-height:1.1}.stat-label{font-size:clamp(.8125rem,1.5vw,.875rem);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-weight:500;line-height:1.4}.stat-divider{width:1px;height:40px;background:linear-gradient(180deg,transparent,var(--border),transparent)}.hero-scroll-indicator{position:absolute;bottom:var(--spacing-xl);left:50%;transform:translate(-50%);color:var(--text-secondary);cursor:pointer;z-index:1;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm)}.hero-scroll-indicator:hover{color:var(--primary)}.scroll-line{width:1px;height:40px;background:linear-gradient(180deg,var(--border),transparent);animation:scrollLine 2s infinite}.hero-scroll-indicator svg{width:20px;height:20px;animation:bounceArrow 2s infinite}@keyframes floatOrb{0%,to{transform:translate(0) scale(1)}33%{transform:translate(50px,-50px) scale(1.1)}66%{transform:translate(-30px,30px) scale(.9)}}@keyframes bounceArrow{0%,to{transform:translateY(0)}50%{transform:translateY(8px)}}@keyframes scrollLine{0%{opacity:.3;transform:translateY(0)}50%{opacity:1;transform:translateY(10px)}to{opacity:.3;transform:translateY(20px)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}section{padding:var(--spacing-4xl) 0;position:relative}#main-content>section:first-child{padding-top:var(--page-section-top, var(--spacing-2xl))}#main-content>section.hero-section--marketing:first-child{padding-top:clamp(1rem,2.5vh,1.75rem);padding-bottom:clamp(3rem,7vh,4.5rem)}#main-content>section.not-found-section:first-child{padding-top:var(--spacing-3xl)}.section-divider{position:relative}.section-divider:before{content:"";position:absolute;top:0;left:0;right:0;width:100%;height:1px;background:var(--border)}.section-divider:after{content:"";position:absolute;top:-2px;left:50%;transform:translate(-50%);width:80px;height:3px;background:var(--primary);border-radius:2px}.welcome-section{position:relative;padding:var(--spacing-4xl) var(--spacing-lg);background:linear-gradient(135deg,#2563eb08,#0ea5e90d);overflow:hidden;min-height:60vh;display:flex;align-items:center;justify-content:center}.dark .welcome-section{background:linear-gradient(135deg,#2563eb14,#0ea5e91a)}.welcome-section:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 50% 0%,rgba(37,99,235,.1),transparent 70%);pointer-events:none}.welcome-content{max-width:800px;margin:0 auto;text-align:center;position:relative;z-index:1;animation:fadeInUp .8s ease-out}.welcome-icon-wrapper{display:inline-flex;align-items:center;justify-content:center;width:100px;height:100px;margin-bottom:var(--spacing-xl);background:linear-gradient(135deg,#2563eb1a,#0ea5e926);border-radius:50%;border:2px solid rgba(37,99,235,.2);position:relative;animation:fadeInScale .8s ease-out .2s both}.welcome-icon-wrapper:before{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;background:linear-gradient(135deg,#2563eb33,#0ea5e94d);opacity:0;animation:pulse 2s ease-in-out infinite;z-index:-1}.welcome-icon{width:48px;height:48px;color:var(--primary);animation:float 3s ease-in-out infinite}.welcome-title{font-size:clamp(2rem,4vw,3rem);font-weight:800;margin-bottom:var(--spacing-md);line-height:1.2;letter-spacing:-.02em;background:linear-gradient(135deg,var(--text-primary) 0%,var(--primary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:fadeInUp .8s ease-out .3s both}.dark .welcome-title{background:linear-gradient(135deg,#f1f5f9,#60a5fa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.welcome-subtitle{font-size:clamp(1.125rem,1.5vw,1.375rem);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-sm);line-height:1.5;animation:fadeInUp .8s ease-out .4s both}.welcome-description{font-size:clamp(1rem,1.2vw,1.125rem);color:var(--text-secondary);line-height:1.7;max-width:600px;margin:0 auto;animation:fadeInUp .8s ease-out .5s both}@keyframes fadeInScale{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulse{0%,to{opacity:0;transform:scale(1)}50%{opacity:.3;transform:scale(1.1)}}.section-header{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-2xl);opacity:1;transform:translateY(0)}.section-header.animated{opacity:1;transform:translateY(0)}.section-title-wrapper{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md)}.section-title{font-size:clamp(1.875rem,4vw,2.75rem);font-weight:800;margin-bottom:0;color:var(--text-primary);letter-spacing:-.02em;line-height:1.2}.section-icon{width:1em;height:1em;color:var(--text-primary);padding:0;background:transparent;border:none;flex-shrink:0;display:block}.section-title-wrapper .section-icon{font-size:clamp(2rem,4vw,3rem)}.section-subtitle{font-size:clamp(1rem,1.5vw,1.125rem);color:var(--text-secondary);max-width:600px;margin:0 auto;text-align:center;line-height:1.7}.team-section{background-color:transparent}.team-section--unified{margin-top:var(--spacing-xl);margin-bottom:0}.team-layout{width:100%;max-width:100%;box-sizing:border-box;padding:var(--spacing-2xl) var(--spacing-xl);border-radius:var(--radius-xl);border:1px solid color-mix(in srgb,var(--border) 85%,transparent);background:linear-gradient(165deg,color-mix(in srgb,var(--primary) 6%,var(--bg-primary)) 0%,var(--bg-primary) 50%,var(--bg-secondary) 100%);box-shadow:0 1px #ffffff0f inset,0 20px 50px #02061712;overflow:visible}.dark .team-layout{background:linear-gradient(165deg,#1e293b8c,#0f172aeb 55%,#0f172afa);border-color:color-mix(in srgb,var(--border) 70%,transparent);box-shadow:0 1px #ffffff0a inset,0 24px 56px #00000059}.team-page{background-color:var(--bg-secondary);padding-bottom:var(--spacing-4xl)}.team-page .section-header{margin-bottom:var(--spacing-xl)}.skills-section--after-team{margin-top:var(--spacing-3xl);padding-top:var(--spacing-3xl)}.team-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--spacing-lg);align-items:stretch;width:100%}.team-member,.team-card{background:var(--bg-primary);min-width:0;height:100%;padding:calc(var(--spacing-xl) + .25rem) var(--spacing-lg) var(--spacing-md);border-radius:var(--radius-xl);box-shadow:0 8px 22px #0206170f;transition:transform .24s ease,box-shadow .24s ease,border-color .24s ease,background .24s ease;border:1px solid rgba(148,163,184,.22);opacity:1;transform:translateZ(0);overflow:hidden;position:relative;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.15rem;isolation:isolate}.team-card--has-photo{background:radial-gradient(760px 220px at 50% 0%,rgba(37,99,235,.05),transparent 58%),var(--bg-primary)}.team-card--has-photo:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius-xl);pointer-events:none;background:radial-gradient(180px 180px at 50% 108px,rgba(14,165,233,.12),transparent 62%);opacity:.28}.team-card>*{position:relative;z-index:1}.team-extra-section{margin-top:var(--spacing-2xl);position:relative;padding:var(--spacing-2xl) 0 var(--spacing-3xl);border-radius:0;background:transparent;box-shadow:none;overflow:visible}.team-extra-section .section-header{margin-bottom:var(--spacing-xl)}.team-extra-section:before{content:none}.team-extra-section>*{position:relative;z-index:1}.org-card{position:relative;background:var(--bg-primary);border-radius:var(--radius-md);padding:var(--spacing-xl);border:1px solid var(--border);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--spacing-md);text-align:left}.dark .org-card{background:var(--bg-secondary);border-color:var(--border);box-shadow:var(--shadow-sm)}.org-card-header{display:flex;flex-direction:row;align-items:center;gap:var(--spacing-md);text-align:left}.org-timeline{position:relative;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));column-gap:var(--spacing-3xl);row-gap:var(--spacing-2xl);padding:var(--spacing-lg) 0}.org-timeline:before{content:"";position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%);width:3px;background:linear-gradient(180deg,#94a3b8e6,#94a3b826)}.org-timeline-item{position:relative;padding-top:var(--spacing-md)}.org-timeline-item:before{content:"";position:absolute;top:1.5rem;left:50%;transform:translate(-50%);width:14px;height:14px;border-radius:999px;background:var(--bg-primary);border:2px solid var(--border);box-shadow:0 0 0 4px var(--bg-primary)}.org-timeline-item--left{grid-column:1 / 2}.org-timeline-item--right{grid-column:2 / 3}.org-timeline-date{position:absolute;top:.4rem;font-size:.9rem;font-weight:600;letter-spacing:.04em;text-transform:none;color:var(--primary-dark);background:#bfdbfee6;padding:4px 14px;border-radius:999px;border:1px solid rgba(129,140,248,.8);box-shadow:0 4px 12px #94a3b899;white-space:nowrap;z-index:2}.org-timeline-item--left .org-timeline-date{right:calc(50% + 1.2rem)}.org-timeline-item--right .org-timeline-date{left:calc(50% + 1.2rem);color:var(--text-primary)}.org-card-logo{display:flex;justify-content:center;align-items:center;width:auto;margin-bottom:0}.org-card-logo-inner{width:72px;height:72px;border-radius:999px;background:var(--bg-tertiary);border:1px solid rgba(148,163,184,.7);display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #0f172a2e;transition:all .4s cubic-bezier(.34,1.56,.64,1)}.org-card:hover .org-card-logo-inner{transform:scale(1.1) rotate(5deg);box-shadow:0 8px 20px #2563eb40;border-color:var(--primary);background:linear-gradient(135deg,#2563eb1a,#0ea5e91a)}.dark .org-card-logo{background:transparent}.dark .org-card-logo-inner{background:#020617;border-color:#94a3b8cc;box-shadow:0 8px 20px #0f172acc}.org-card--training .org-card-logo-inner{background:#0f172a;border-color:#0f172acc}.dark .org-card--training .org-card-logo-inner{background:#020617;border-color:#94a3b8d9}.org-card-logo img{display:block;max-width:64px;max-height:64px;width:auto;height:auto;object-fit:contain}.org-card-header-text{display:flex;flex-direction:column;gap:.25rem}.org-card-title{font-size:1.25rem;font-weight:700;margin:0;color:var(--text-primary)}.org-card-meta{margin:0;font-size:.85rem;color:var(--text-secondary)}.org-card-period{margin:0;font-size:.85rem;font-weight:500;letter-spacing:.02em;text-transform:none;color:var(--text-secondary);margin-top:.15rem}.dark .org-card-period{color:var(--text-light)}.org-card-text{margin:0;color:var(--text-secondary);line-height:1.7}.teacher-name{color:var(--text-primary);font-weight:600;text-decoration:underline;text-decoration-color:var(--border);text-underline-offset:3px;cursor:help;position:relative;display:inline-block}.org-card-list{list-style:disc;padding-left:var(--spacing-lg);color:var(--text-primary);display:flex;flex-direction:column;gap:.35rem;margin-top:var(--spacing-sm)}.org-card-list li{color:var(--text-primary)}@media (max-width: 900px){.org-timeline{grid-template-columns:1fr;padding-left:2.25rem}.org-timeline:before{left:.75rem;transform:none}.org-timeline-item--left,.org-timeline-item--right{grid-column:1 / 2}.org-timeline-item:before{left:.75rem;transform:none}.org-timeline-date{left:1.75rem;right:auto}}@media (max-width: 600px){.org-timeline{padding-left:1.5rem;row-gap:var(--spacing-lg)}.org-timeline-date{font-size:.8rem;padding:3px 10px;max-width:calc(100% - 3rem);white-space:normal;line-height:1.4}.org-card{padding:var(--spacing-lg)}.org-card-header{align-items:flex-start;gap:var(--spacing-sm)}.org-card-logo-inner{width:56px;height:56px}.org-card-logo img{max-width:46px;max-height:46px}}.dark .team-member,.dark .team-card{background-color:#1e293b99;border-color:var(--border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.team-member:before,.team-card:before{content:none}.team-member:hover:before,.team-card:hover:before{transform:none}.team-member.animated,.team-card.animated{opacity:1;transform:translateY(0);transition:opacity .6s ease,transform .6s ease}.team-member:hover,.team-card:hover{transform:translateZ(0) scale(1.035);box-shadow:0 18px 36px #0206171f;border-color:#2563eb47}.dark .team-card:hover{transform:translateZ(0) scale(1.035);box-shadow:0 20px 40px #0000006b;border-color:color-mix(in srgb,var(--primary) 42%,var(--border))}.member-header{padding:var(--spacing-xl);text-align:center;background:linear-gradient(135deg,#2563eb08,#0ea5e908);border-bottom:1px solid var(--border)}.member-avatar,.team-avatar{width:200px;height:200px;margin:0 auto calc(var(--spacing-md) + .2rem);border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;transition:box-shadow .24s ease;position:relative;box-shadow:0 10px 28px #0206171f;overflow:hidden;flex-shrink:0}.team-avatar:before,.team-avatar:after{content:none}.avatar-ring{display:none}.team-member:hover .avatar-ring,.team-card:hover .avatar-ring{opacity:0;transform:none}.team-member:hover .member-avatar,.team-card:hover .team-avatar{transform:none;box-shadow:0 8px 20px #0206171a}.avatar-placeholder,.avatar-initials{font-size:2.5rem;font-weight:700;color:#fff;z-index:1}.team-avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover;object-position:50% 28%;z-index:1;border:3px solid rgba(37,99,235,.92);box-shadow:none;box-sizing:border-box}.dark .team-avatar-img{border-color:#60a5faf2}.team-links{display:flex;flex-direction:column;gap:.5rem;align-items:center;margin-top:auto;margin-bottom:0;padding-top:var(--spacing-md);width:100%}.team-link-row{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.62rem .85rem;border-radius:16px;border:1px solid rgba(148,163,184,.22);background:#ffffffdb;width:fit-content;max-width:100%;box-shadow:0 10px 22px #0206170a;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease,background .18s ease}.dark .team-link-row{background:#02061770;border-color:#94a3b82e;box-shadow:0 10px 22px #00000040}.team-link-row:hover{transform:translateY(-1px);border-color:#2563eb3d;box-shadow:0 16px 34px #02061714;background:#fffffff0}.dark .team-link-row:hover{background:#0206178c;border-color:#2563eb38}.team-link-icon{width:36px;height:36px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;color:#2563ebe6;background:#2563eb14;border:1px solid rgba(37,99,235,.12);flex:0 0 auto}.team-link-icon svg{width:18px;height:18px}.dark .team-link-icon{background:#2563eb1f;border-color:#2563eb2e}.team-link{color:var(--text-primary);font-weight:600;text-decoration:none;font-size:.95rem;line-height:1.2;max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.team-link-row:hover .team-link{color:var(--primary)}.team-link:hover,.team-link:focus-visible{text-decoration:underline;text-underline-offset:3px}.team-copy-btn{width:40px;height:40px;border-radius:14px;border:1px solid rgba(148,163,184,.22);background:linear-gradient(180deg,#fffffffa,#f8fafce0);color:#1e293bb8;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .15s ease,background .15s ease,border-color .15s ease,color .15s ease;flex:0 0 auto}.dark .team-copy-btn{background:linear-gradient(180deg,#0206178c,#02061759);border-color:#94a3b829;color:#e2e8f0bf}.team-copy-btn svg{width:18px;height:18px}.team-copy-btn:hover{transform:translateY(-1px);border-color:#2563eb47;color:var(--primary);box-shadow:0 14px 26px #0206171a}.team-copy-btn.is-copied{color:#16a34a;border-color:#16a34a59;background:linear-gradient(180deg,#f0fdf4fa,#dcfce7e6)}.team-copy-btn:focus-visible{outline:2px solid rgba(37,99,235,.6);outline-offset:2px}.team-name{margin-top:.25rem;letter-spacing:-.01em}.team-role-row{display:flex;justify-content:center;width:100%;margin-bottom:var(--spacing-md)}.team-role-badge{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;max-width:100%;padding:.45rem 1.05rem .45rem .75rem;border-radius:9999px;font-size:clamp(.8125rem,1.4vw,.875rem);font-weight:600;line-height:1.35;letter-spacing:.02em;text-align:center;color:var(--primary);background:color-mix(in srgb,var(--primary) 14%,transparent);border:1px solid color-mix(in srgb,var(--primary) 32%,transparent);box-shadow:0 1px #ffffff0f inset}.team-role-badge-icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;width:1.65rem;height:1.65rem;border-radius:999px;background:color-mix(in srgb,var(--primary) 22%,transparent);border:1px solid color-mix(in srgb,var(--primary) 35%,transparent);color:var(--primary)}.team-role-badge-icon-svg{width:.95rem;height:.95rem;display:block}.team-role-badge-text{text-align:left}.dark .team-role-badge-icon{background:color-mix(in srgb,var(--accent) 18%,transparent);border-color:color-mix(in srgb,var(--accent) 40%,transparent);color:var(--accent)}.dark .team-role-badge{background:color-mix(in srgb,var(--primary) 22%,transparent);border-color:color-mix(in srgb,var(--accent) 45%,transparent);color:var(--accent);box-shadow:0 1px #ffffff0a inset}.team-description{margin:0 auto;flex-grow:0;max-width:36ch;min-height:3.2em;color:var(--text-secondary);font-size:.95rem;line-height:1.55;text-align:center;font-style:italic;opacity:.95}.member-info{text-align:center}.member-name,.team-name{font-size:clamp(1.25rem,2vw,1.5rem);font-weight:600;margin-bottom:var(--spacing-xs);color:var(--text-primary);line-height:1.3}.member-role{display:inline-flex;align-items:center;gap:var(--spacing-xs);color:var(--text-secondary);font-size:clamp(.875rem,1.5vw,.95rem);font-weight:500;line-height:1.5;margin-bottom:var(--spacing-md)}.member-role svg{width:16px;height:16px;opacity:.7}.member-skills-section{padding:var(--spacing-lg) var(--spacing-xl) var(--spacing-xl)}.skills-header{display:flex;align-items:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-md);color:var(--text-secondary);font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.skills-header svg{width:18px;height:18px;opacity:.7}.member-skills,.team-skills,.skills-list{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);justify-content:center}.skills-label{display:block;margin-bottom:var(--spacing-sm);color:var(--text-secondary);font-size:.875rem;font-weight:600}.skill-tag{display:inline-flex;align-items:center;gap:.25rem;background-color:var(--bg-secondary);color:var(--primary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-xl);font-size:.875rem;font-weight:500;border:1px solid var(--border);transition:all .2s ease;position:relative;cursor:help}.skill-tag-text{color:var(--text-primary);font-weight:500}.skill-tag:hover{background-color:var(--primary);border-color:var(--primary)}.skill-tag:hover .skill-tag-text{color:#fff}.skill-tag-icon{width:16px;height:16px;object-fit:contain;opacity:.8;transition:opacity .2s ease;flex-shrink:0}.skill-tag svg{width:14px;height:14px;opacity:.7}.skill-tag:hover{background-color:var(--primary);color:#fff;border-color:var(--primary);transform:translateY(-1px)}.skill-tag:hover .skill-tag-icon{opacity:1;filter:brightness(0) invert(1)}.skill-tag:hover svg{opacity:1}.projects-section{background-color:var(--bg-primary)}.project-controls{display:flex;flex-direction:column;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.project-search-container{width:100%}.search-wrapper{position:relative;max-width:100%;margin:0}.search-icon{position:absolute;left:var(--spacing-lg);top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--text-secondary);pointer-events:none;z-index:1}.project-search-input{width:100%;padding:var(--spacing-md) var(--spacing-md) var(--spacing-md) 3.5rem;font-size:1rem;border:2px solid var(--border);border-radius:var(--radius-xl);background-color:var(--bg-primary);color:var(--text-primary);transition:all .3s ease;outline:none}.project-search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a;background-color:var(--bg-primary)}.project-search-input::placeholder{color:var(--text-secondary);opacity:.6}.project-filters-wrapper{display:flex;flex-direction:column;gap:var(--spacing-md)}.filters-header{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--text-secondary);font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.filters-header svg{width:18px;height:18px;opacity:.7}.project-filters{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);padding:0;background-color:transparent;border-radius:0}.project-filters-bar{display:flex;flex-wrap:wrap;align-items:flex-start;gap:var(--spacing-md);width:100%}.project-filter-dd{position:relative;flex:1 1 240px;min-width:min(100%,240px);max-width:400px}.project-filter-dd__trigger{display:flex;align-items:center;gap:.5rem;width:100%;padding:.65rem .9rem;border:2px solid var(--border);border-radius:var(--radius-xl);background:var(--bg-primary);color:var(--text-primary);font-size:.9375rem;font-weight:600;cursor:pointer;text-align:left;transition:border-color .25s ease,box-shadow .25s ease,background .25s ease}.dark .project-filter-dd__trigger{background:var(--bg-secondary)}.project-filter-dd__trigger:hover{border-color:#2563eb59}.dark .project-filter-dd__trigger:hover{border-color:#60a5fa59}.project-filter-dd__trigger--open{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1f}.dark .project-filter-dd__trigger--open{border-color:var(--primary-light);box-shadow:0 0 0 3px #60a5fa1f}.project-filter-dd__label{flex-shrink:0;color:var(--text-secondary);font-weight:600;font-size:.8125rem;text-transform:uppercase;letter-spacing:.04em}.project-filter-dd__summary{flex:1;min-width:0;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-filter-dd__chevron{flex-shrink:0;opacity:.65;transition:transform .3s cubic-bezier(.16,1,.3,1)}.project-filter-dd__trigger--open .project-filter-dd__chevron{transform:rotate(180deg)}.project-filter-dd__panel{position:absolute;inset-inline-start:0;top:calc(100% + 6px);z-index:50;min-width:100%;max-width:min(100vw - 2rem,360px);max-height:min(70vh,320px);display:flex;flex-direction:column;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-primary);box-shadow:var(--shadow-lg);overflow:hidden}.dark .project-filter-dd__panel{background:var(--bg-secondary);border-color:var(--border)}.project-filter-dd__scroll{overflow-y:auto;padding:var(--spacing-xs) 0;overscroll-behavior:contain}.project-filter-dd__row{display:flex;align-items:center;gap:.65rem;padding:.55rem 1rem;margin:0;cursor:pointer;font-size:.9375rem;color:var(--text-primary);transition:background .15s ease}.project-filter-dd__row:hover{background:#2563eb0f}.dark .project-filter-dd__row:hover{background:#60a5fa14}.project-filter-dd__checkbox{width:1.125rem;height:1.125rem;flex-shrink:0;accent-color:var(--primary);cursor:pointer}.project-filter-dd__icon{width:22px;height:22px;object-fit:contain;flex-shrink:0;border-radius:4px}.project-filter-dd__icon-fallback{width:22px;height:22px;flex-shrink:0;border-radius:4px;background:var(--bg-tertiary);border:1px solid var(--border)}.project-filter-dd__status-icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;width:22px;height:22px}.project-filter-dd__status-icon svg{display:block}.project-filter-dd__status-icon[data-status=completed],.project-filter-dd__status-icon[data-status=live],.project-filter-dd__status-icon[data-status=delivered]{color:#16a34a}.project-filter-dd__status-icon[data-status=inDevelopment],.project-filter-dd__status-icon[data-status=examNoClient]{color:#2563eb}.project-filter-dd__status-icon[data-status=cancelledPurchasable]{color:#ca8a04}.project-filter-dd__status-icon[data-status=default]{color:var(--text-secondary)}.dark .project-filter-dd__status-icon[data-status=completed],.dark .project-filter-dd__status-icon[data-status=live],.dark .project-filter-dd__status-icon[data-status=delivered]{color:#4ade80}.dark .project-filter-dd__status-icon[data-status=inDevelopment],.dark .project-filter-dd__status-icon[data-status=examNoClient]{color:#93c5fd}.dark .project-filter-dd__status-icon[data-status=cancelledPurchasable]{color:#facc15}.project-filter-dd__text{flex:1;min-width:0;line-height:1.35}.project-filter-dd__footer{padding:.5rem .75rem;border-top:1px solid var(--border);background:var(--bg-secondary)}.project-filter-dd__clear{width:100%;padding:.45rem .65rem;border:none;border-radius:var(--radius-md);background:transparent;color:var(--primary);font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s ease}.project-filter-dd__clear:hover{background:#2563eb14}.dark .project-filter-dd__clear:hover{background:#60a5fa1a}.search-results{text-align:left;padding-top:var(--spacing-md);border-top:1px solid var(--border)}.results-count{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-lg);background-color:transparent;color:var(--text-secondary);border-radius:var(--radius-xl);font-size:.9375rem;font-weight:500}.results-count #resultsCount{color:var(--primary);font-weight:700;font-size:1.125rem}.filter-btn{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);background-color:var(--bg-primary);color:var(--text-secondary);border:2px solid var(--border);border-radius:var(--radius-xl);font-size:.9375rem;font-weight:500}.filter-btn-icon{width:20px;height:20px;object-fit:contain;flex-shrink:0;border-radius:0}.filter-btn svg{width:16px;height:16px;opacity:.7;transition:opacity .25s ease}.filter-btn:hover:not(.active){background-color:#2563eb0d;border-color:#2563eb4d;color:var(--primary);transform:translateY(-2px)}.filter-btn:hover:not(.active) svg{opacity:1}.filter-btn.active{background-color:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 4px 12px #2563eb40;transform:translateY(-2px)}.filter-btn.active svg{opacity:1}.filter-btn.active:hover{background-color:var(--primary-dark);border-color:var(--primary-dark);box-shadow:0 6px 16px #2563eb4d}.project-card.hidden{display:none!important}[data-keyboard-navigable]{position:relative;transition:all .2s ease}[data-keyboard-navigable]:focus-visible{outline:3px solid var(--primary);outline-offset:4px;box-shadow:0 0 0 2px var(--bg-primary),0 0 0 5px var(--primary);z-index:10}[data-keyboard-navigable]:focus-visible:not(:hover){transform:translateY(-2px)}.dark [data-keyboard-navigable]:focus-visible{outline-color:var(--primary-light);box-shadow:0 0 0 2px var(--bg-secondary),0 0 0 5px var(--primary-light)}[data-keyboard-navigable]:focus:not(:focus-visible){outline:none}.project-card--development{border:2px dashed rgba(26,54,93,.35);border-radius:var(--radius-xl);box-shadow:0 2px 8px #0000000d}.project-card--development:hover{border-color:#1a365d80;box-shadow:0 20px 40px #0000001a,0 0 0 1px #1a365d1a}.project-card--development .project-card__media{filter:blur(3px) brightness(.85)}.project-card--development.project-card--clear-dev-blur .project-card__media{filter:none}.project-card--development .project-content{opacity:.8}.project-card--development.project-card--clear-dev-blur .project-content{opacity:1}.dark .project-card--development{border-color:#63b3ed4d;box-shadow:0 2px 8px #0003}.dark .project-card--development:hover{border-color:#63b3ed73;box-shadow:0 20px 40px #00000059,0 0 0 1px #63b3ed26}.dark .project-card--development .project-card__media{filter:blur(3px) brightness(.7)}.dark .project-card--development.project-card--clear-dev-blur .project-card__media{filter:none}.dark .project-card--development .project-content{opacity:.85}.dark .project-card--development.project-card--clear-dev-blur .project-content{opacity:1}.project-card--accent-yellow{border:2px solid rgba(202,138,4,.75);box-shadow:0 2px 12px #eab30824;position:relative}.project-card--accent-yellow:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#ca8a04,#eab308,#facc15);z-index:2;border-radius:var(--radius-xl) var(--radius-xl) 0 0;pointer-events:none}.dark .project-card--accent-yellow{border-color:#facc1580;box-shadow:0 2px 12px #00000040}.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.25rem,2.5vw,2rem)}@keyframes project-card-reveal{0%{opacity:0;transform:translateY(.75rem)}to{opacity:1;transform:translateY(0)}}@keyframes project-card-search-flash{0%{box-shadow:0 1px 2px #0f172a0a,0 8px 24px #0f172a0f,0 0 #2563eb59}18%{box-shadow:0 8px 24px #2563eb2e,0 20px 48px #2563eb1f,0 0 0 1px #2563eb40;transform:translateY(-4px)}to{box-shadow:0 1px 2px #0f172a0a,0 8px 24px #0f172a0f;transform:translateY(0)}}@keyframes project-card-search-flash-dark{0%{box-shadow:0 2px 8px #00000026,0 0 #60a5fa66}18%{box-shadow:0 12px 32px #0006,0 0 0 1px #60a5fa59;transform:translateY(-4px)}to{box-shadow:0 2px 8px #00000026;transform:translateY(0)}}.projects-grid .project-card{animation:project-card-reveal .7s cubic-bezier(.16,1,.3,1) backwards}.projects-grid .project-card:nth-child(1){animation-delay:.03s}.projects-grid .project-card:nth-child(2){animation-delay:.08s}.projects-grid .project-card:nth-child(3){animation-delay:.13s}.projects-grid .project-card:nth-child(4){animation-delay:.18s}.projects-grid .project-card:nth-child(5){animation-delay:.23s}.projects-grid .project-card:nth-child(6){animation-delay:.28s}.projects-grid .project-card:nth-child(7){animation-delay:.33s}.projects-grid .project-card:nth-child(8){animation-delay:.38s}.projects-grid .project-card:nth-child(9){animation-delay:.43s}.projects-grid .project-card:nth-child(10){animation-delay:.48s}.projects-grid .project-card:nth-child(11){animation-delay:.53s}.projects-grid .project-card:nth-child(12){animation-delay:.58s}.projects-grid .project-card.project-card--search-flash{animation:project-card-search-flash 2.1s cubic-bezier(.16,1,.3,1) forwards}.dark .projects-grid .project-card.project-card--search-flash{animation:project-card-search-flash-dark 2.1s cubic-bezier(.16,1,.3,1) forwards}.no-results{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl) var(--spacing-lg);text-align:center;min-height:300px;margin-top:var(--spacing-xl)}.no-results-icon{width:60px;height:60px;margin-bottom:var(--spacing-md);color:var(--text-secondary);opacity:.5}.no-results-icon svg{width:100%;height:100%}.no-results-title{font-size:clamp(1.25rem,2vw,1.5rem);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs);line-height:1.3}.no-results-message{font-size:clamp(.9375rem,1.5vw,1rem);color:var(--text-secondary);line-height:1.6;max-width:500px;margin-bottom:var(--spacing-lg)}.no-results-reset-btn{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-lg);background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border:none;border-radius:var(--radius-md);font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .3s ease;margin-top:var(--spacing-md)}.no-results-reset-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.no-results-reset-btn:active{transform:translateY(0)}.project-card{--project-card-ease: cubic-bezier(.16, 1, .3, 1);background-color:var(--bg-primary);border-radius:var(--radius-xl);overflow:hidden;transition:transform .55s var(--project-card-ease),box-shadow .55s var(--project-card-ease),border-color .4s ease;border:1px solid var(--border);transform:translateY(0);display:flex;flex-direction:column;box-shadow:0 1px 2px #0f172a0a,0 8px 28px #0f172a12;cursor:default;position:relative;isolation:isolate}.dark .project-card{background-color:var(--bg-secondary);border-color:var(--border);box-shadow:0 2px 8px #00000038,0 1px #ffffff08 inset}.project-card-link{text-decoration:none;color:inherit;cursor:pointer}.project-card-link:hover{text-decoration:none;color:inherit}.project-card:hover{transform:translateY(-6px);box-shadow:0 4px 12px #0f172a0d,0 20px 48px #0f172a1a;border-color:#2563eb33}.dark .project-card:hover{box-shadow:0 8px 24px #00000059,0 0 0 1px #60a5fa1f;border-color:#60a5fa38}.project-card.project-card--accent-yellow:hover{border-color:#a16207d9;box-shadow:0 8px 24px #eab3081f,0 20px 48px #00000014,0 0 0 1px #eab30838}.dark .project-card.project-card--accent-yellow:hover{border-color:#facc15bf;box-shadow:0 12px 32px #0006,0 0 0 1px #facc1533}.project-card__media{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-secondary) 100%)}.project-card__media-inner{position:relative;aspect-ratio:16 / 10;width:100%;overflow:hidden}.project-card__media-inner .project-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .8s var(--project-card-ease)}.project-card:hover .project-card__media-inner .project-img:not(.project-favicon){transform:scale(1.045)}.project-img.project-favicon{position:relative;object-fit:contain;width:auto;height:auto;max-width:80px;max-height:80px;padding:var(--spacing-lg);background-color:transparent;border-radius:var(--radius-md)}.project-img.project-screenshot{object-fit:cover}.project-card__media-fade{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none;background:linear-gradient(to top,rgba(15,23,42,.5) 0%,rgba(15,23,42,.12) 42%,transparent 65%)}.dark .project-card__media-fade{background:linear-gradient(to top,rgba(0,0,0,.58) 0%,rgba(0,0,0,.14) 42%,transparent 68%)}.project-card__media-shine{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;pointer-events:none;opacity:0;background:linear-gradient(118deg,transparent 36%,rgba(255,255,255,.14) 42%,rgba(255,255,255,.06) 48%,transparent 54%);transform:translate(-120%) skew(-14deg);transition:opacity .45s ease,transform .85s var(--project-card-ease)}.project-card:hover .project-card__media-shine{opacity:1;transform:translate(120%) skew(-14deg)}.project-image{width:100%;height:240px;overflow:hidden;background-color:transparent;position:relative;display:flex;align-items:center;justify-content:center}.project-img{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .8s var(--project-card-ease, cubic-bezier(.16, 1, .3, 1))}.project-card:hover .project-image>.project-img:not(.project-favicon){transform:scale(1.045)}.project-card:hover .project-image>.project-img.project-favicon{transform:scale(1.06)}.project-header-block{width:100%;margin-bottom:var(--spacing-sm)}.project-title-row{display:flex;align-items:center;gap:.65rem}.project-title-row .project-title{flex:1;min-width:0}.project-card-favicon.project-card-favicon--title{width:28px;height:28px;flex-shrink:0;border-radius:8px;object-fit:contain;box-shadow:0 1px 3px #0f172a1f;border:1px solid var(--border);background:var(--bg-primary)}.dark .project-card-favicon.project-card-favicon--title{border-color:#94a3b859;background:var(--bg-tertiary)}.project-status-badge-icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;width:.875rem;height:.875rem;color:inherit}.project-status-badge-icon svg{display:block;width:100%;height:100%}.project-status-line{margin:.45rem 0 0;padding:.35rem 0 .35rem .65rem;font-size:.8125rem;line-height:1.45;color:var(--text-secondary);font-weight:500;border-left:3px solid rgba(37,99,235,.45)}.dark .project-status-line{border-left-color:#60a5fa8c}.project-status-chip{display:inline-flex;align-items:center;align-self:flex-start;gap:.4rem;margin-top:.45rem;padding:.35rem .65rem .35rem .5rem;border-radius:999px;font-size:.75rem;font-weight:700;letter-spacing:.02em;border:1px solid transparent;line-height:1.2}.project-status-chip--success{color:#166534;background:#dcfce7;border-color:#86efac}.project-status-chip--info{color:#1e3a8a;background:#dbeafe;border-color:#93c5fd}.project-status-chip--warning{color:#854d0e;background:#fef3c7;border-color:#facc15}.dark .project-status-chip--success{color:#bbf7d0;background:#16653440;border-color:#4ade8066}.dark .project-status-chip--info{color:#bfdbfe;background:#1e3a8a40;border-color:#60a5fa73}.dark .project-status-chip--warning{color:#fef08a;background:#854d0e3d;border-color:#facc1599}.project-status-chip.project-card__status-chip{margin-top:.5rem}.project-title-wrapper{display:flex;align-items:center;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.project-card-favicon{width:24px;height:24px;object-fit:contain;flex-shrink:0;border-radius:var(--radius-sm)}.project-title{font-size:clamp(1.125rem,1.65vw,1.375rem);font-weight:600;letter-spacing:-.02em;line-height:1.3;margin:0}.project-status-pill{display:inline-flex;align-items:center;justify-content:center;margin-left:auto;padding:.24rem .6rem;border-radius:999px;font-size:.72rem;font-weight:700;letter-spacing:.02em;border:1px solid transparent}.project-status-pill--completed{color:#166534;background:#dcfce7;border-color:#86efac}.project-status-pill--cancelled{color:#854d0e;background:#fef3c7;border-color:#facc15}.dark .project-status-pill--completed{color:#bbf7d0;background:#16653440;border-color:#4ade8066}.dark .project-status-pill--cancelled{color:#fef08a;background:#854d0e3d;border-color:#facc1599}.project-card-actions{margin-top:var(--spacing-xs);width:100%}.project-preview-btn{display:inline-flex;align-items:center;justify-content:center;gap:.625rem;padding:.75rem 1.25rem;margin-top:0;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border:none;border-radius:var(--radius-md);font-size:.9375rem;font-weight:600;cursor:pointer;transition:background .45s cubic-bezier(.16,1,.3,1),transform .45s cubic-bezier(.16,1,.3,1),box-shadow .45s cubic-bezier(.16,1,.3,1);width:100%;position:relative;overflow:hidden;box-shadow:0 2px 10px #2563eb38}.project-preview-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);transition:left .65s cubic-bezier(.16,1,.3,1)}.project-preview-btn:hover{background:linear-gradient(135deg,var(--primary-dark),var(--primary));transform:translateY(-2px);box-shadow:0 8px 24px #2563eb52}.project-preview-btn:hover:before{left:100%}.project-preview-btn:active{transform:translateY(0);box-shadow:0 2px 10px #2563eb38;transition-duration:.12s}.project-preview-btn svg{width:18px;height:18px;flex-shrink:0;transition:transform .45s cubic-bezier(.16,1,.3,1);opacity:1}.project-preview-btn:hover svg{transform:scale(1.06) translate(1px)}@media (prefers-reduced-motion: reduce){.projects-grid .project-card{animation:none;opacity:1;transform:none}.project-card:hover{transform:none}.project-card:hover .project-card__media-inner .project-img:not(.project-favicon){transform:none}.project-card:hover .project-card__media-shine{opacity:0;transform:translate(-120%) skew(-14deg)}.projects-grid .project-card.project-card--search-flash,.dark .projects-grid .project-card.project-card--search-flash{animation:none}.project-preview-btn,.project-preview-btn:before,.project-preview-btn svg{transition-duration:.01ms}.project-preview-btn:hover svg{transform:none}}.project-status-under-development{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.75rem 1.25rem;margin-top:var(--spacing-sm);background-color:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;letter-spacing:.02em}.project-status-under-development svg{flex-shrink:0;opacity:.8}.project-status-badge{display:flex;align-items:center;justify-content:center;width:100%;padding:.75rem 1rem;margin-top:var(--spacing-sm);border-radius:var(--radius-md);font-size:.82rem;font-weight:600;line-height:1.35;text-align:center;border:1px solid transparent}.project-status-badge--yellow{color:#854d0e;background:#fef3c7;border-color:#facc15}.project-status-badge--info{color:#1e3a8a;background:#dbeafe;border-color:#93c5fd}.dark .project-status-badge--yellow{color:#fef08a;background:#854d0e33;border-color:#facc1599}.dark .project-status-badge--info{color:#bfdbfe;background:#1e3a8a40;border-color:#60a5fa73}.dark .project-status-under-development{background-color:var(--bg-tertiary);border-color:var(--border);color:var(--text-secondary)}.project-description{color:var(--text-secondary);line-height:1.75;font-size:clamp(.875rem,1.5vw,.95rem);margin-bottom:var(--spacing-md);flex:1}.project-details{display:flex;flex-direction:column;gap:var(--spacing-md);padding-top:var(--spacing-md);margin-top:auto;border-top:1px solid var(--border)}.project-details .project-preview-btn,.project-details .project-status-under-development,.project-details .project-status-badge,.project-details .project-card-actions{flex-shrink:0;min-height:2.75rem}.project-content{padding:var(--spacing-lg) var(--spacing-lg) var(--spacing-md);flex:1;display:flex;flex-direction:column;background-color:var(--bg-primary);gap:var(--spacing-sm);text-align:left}.project-tech{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.tech-tag{display:inline-flex;align-items:center;background-color:var(--bg-secondary);color:var(--primary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;border:1px solid var(--border);transition:all .2s ease;gap:.25rem;position:relative;cursor:help}.tech-tag-text{color:var(--text-primary);font-weight:500}.tech-tag:hover{background-color:var(--primary);border-color:var(--primary);transform:translateY(-1px)}.tech-tag:hover .tech-tag-text{color:#fff}.tech-tag-icon{width:16px;height:16px;object-fit:contain;opacity:.8;transition:opacity .2s ease;flex-shrink:0}.tech-tag:hover .tech-tag-icon{opacity:1;filter:brightness(0) invert(1)}.skill-tooltip{pointer-events:none;position:fixed!important;z-index:10000!important;display:block!important;visibility:visible!important;opacity:1!important}.skill-tooltip-card{background-color:var(--bg-primary);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);text-align:center;border:1px solid var(--border);display:flex;flex-direction:column;align-items:center;position:relative;max-width:min(280px,calc(100vw - 40px));min-width:200px;width:max-content;pointer-events:auto;animation:tooltipCardFadeIn .3s cubic-bezier(.4,0,.2,1);transform-origin:center bottom}.teacher-tooltip-card{background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%);border:2px solid var(--primary);box-shadow:0 12px 40px #2563eb40;padding:var(--spacing-lg);max-width:min(320px,calc(100vw - 40px));min-width:240px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.teacher-tooltip-card:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(37,99,235,.1),transparent 70%);opacity:0;transition:opacity .3s ease;pointer-events:none}.teacher-tooltip-card:hover{transform:scale(1.03);box-shadow:0 16px 56px #2563eb59,0 0 0 1px #2563eb33;border-color:var(--primary-dark)}.teacher-tooltip-card:hover:before{opacity:1}.dark .teacher-tooltip-card{background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%);border-color:var(--primary-light);box-shadow:0 16px 48px #3b82f64d}.dark .teacher-tooltip-card:hover{box-shadow:0 20px 64px #3b82f666,0 0 0 1px #3b82f64d;border-color:var(--primary)}@media (max-width: 480px){.skill-tooltip-card{max-width:calc(100vw - 20px);min-width:180px;padding:var(--spacing-md)}}.dark .skill-tooltip-card{background-color:var(--bg-secondary);border-color:var(--border);box-shadow:0 10px 25px #0009}.skill-tooltip-image-wrapper{width:80px;height:80px;margin:0 auto var(--spacing-md);background-color:transparent;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);padding:0;position:relative}.skill-tooltip-image{width:100%;height:100%;object-fit:contain;display:block;transition:transform .3s cubic-bezier(.4,0,.2,1);filter:drop-shadow(0 4px 8px rgba(0,0,0,.1))}.dark .skill-tooltip-image{filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}.skill-tooltip-name{font-size:clamp(1rem,2vw,1.25rem);font-weight:600;margin-bottom:var(--spacing-sm);color:var(--text-primary);letter-spacing:-.01em;line-height:1.3;transition:color .3s ease}.teacher-tooltip-card .skill-tooltip-name{font-size:clamp(1.125rem,2vw,1.375rem);font-weight:700;color:var(--primary);margin-bottom:var(--spacing-xs);transition:all .3s cubic-bezier(.4,0,.2,1)}.teacher-tooltip-card:hover .skill-tooltip-name{color:var(--primary-dark);transform:translateY(-1px);text-shadow:0 2px 8px rgba(37,99,235,.3)}.teacher-tooltip-role{font-size:clamp(.875rem,1.5vw,.9375rem);font-weight:600;color:var(--primary-dark);background:linear-gradient(135deg,#2563eb1f,#0ea5e91f);padding:.5rem .875rem;border-radius:var(--radius-md);margin-bottom:var(--spacing-md);display:inline-block;border:1px solid rgba(37,99,235,.25);transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.teacher-tooltip-role:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s ease}.teacher-tooltip-card:hover .teacher-tooltip-role{background:linear-gradient(135deg,#2563eb2e,#0ea5e92e);border-color:#2563eb66;transform:translateY(-1px);box-shadow:0 4px 12px #2563eb33}.teacher-tooltip-card:hover .teacher-tooltip-role:before{left:100%}.dark .teacher-tooltip-role{color:var(--primary-light);background:linear-gradient(135deg,#3b82f626,#38bdf826);border-color:#3b82f64d}.dark .teacher-tooltip-card:hover .teacher-tooltip-role{background:linear-gradient(135deg,#3b82f638,#38bdf838);border-color:#3b82f673;box-shadow:0 4px 16px #3b82f64d}.skill-tooltip-card:hover .skill-tooltip-name{color:var(--primary)}.skill-tooltip-description{color:var(--text-secondary);line-height:1.75;font-size:clamp(.8125rem,1.5vw,.875rem);margin-top:auto;transition:color .3s ease}.teacher-tooltip-card .skill-tooltip-description{color:var(--text-primary);line-height:1.8;font-size:clamp(.875rem,1.5vw,.9375rem);text-align:left;margin-top:0;transition:color .3s ease}.teacher-tooltip-card:hover .skill-tooltip-description{color:var(--text-primary)}.skill-tooltip-arrow{position:absolute;width:0;height:0;transform:translate(-50%);border-left:8px solid transparent;border-right:8px solid transparent;transition:all .2s ease}.tooltip-below .skill-tooltip-arrow{top:-8px;border-top:none;border-bottom:8px solid var(--bg-primary)}.teacher-tooltip-card+.skill-tooltip-arrow{border-bottom-color:var(--primary)}.dark .teacher-tooltip-card+.skill-tooltip-arrow{border-bottom-color:var(--primary-light)}.dark .tooltip-below .skill-tooltip-arrow{border-bottom-color:var(--bg-secondary)}.tooltip-above .skill-tooltip-arrow{bottom:-8px;border-bottom:none;border-top:8px solid var(--bg-primary)}.teacher-tooltip-card+.skill-tooltip-arrow.tooltip-above{border-top-color:var(--primary)}.dark .teacher-tooltip-card+.skill-tooltip-arrow.tooltip-above{border-top-color:var(--primary-light)}.dark .tooltip-above .skill-tooltip-arrow{border-top-color:var(--bg-secondary)}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes tooltipCardFadeIn{0%{opacity:0;transform:translateY(8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.project-contributors{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.875rem;color:var(--text-secondary)}.project-contributors svg{width:16px;height:16px;opacity:.7;flex-shrink:0}.project-contributors svg{width:16px;height:16px;opacity:.7}.project-actions{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--border)}.project-read-button{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);width:100%;text-decoration:none;margin:0}.project-read-button svg{flex-shrink:0;transition:transform .3s ease}.project-read-button:hover svg{transform:translate(4px)}.about-section{background-color:var(--bg-primary)}.about-content{margin-top:var(--spacing-2xl)}.about-grid,.about-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-xl)}.about-card{background-color:var(--bg-secondary);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;align-items:flex-start;overflow:visible}.dark .about-card{background-color:#1e293b99;border-color:var(--border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.about-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:var(--primary)}.about-icon,.card-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:var(--radius-md);margin-bottom:var(--spacing-md);color:#fff}.about-card-title,.card-title{font-size:clamp(1.25rem,2vw,1.5rem);font-weight:600;margin-bottom:var(--spacing-sm);color:var(--text-primary);line-height:1.3}.about-card-description,.card-description{color:var(--text-secondary);font-size:clamp(.9rem,1.5vw,1rem);line-height:1.7;margin:0}.skills-section{background-color:var(--bg-secondary)}.skills-detailed,.skills-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-xl)}.skill-group-frontend:nth-child(1),.skill-group-frontend:nth-child(2){grid-column:auto}.skill-group-javascript:nth-child(3),.skill-group-javascript:nth-child(4){grid-column:auto}.skill-group-react:nth-child(5){grid-column:auto}.skill-group-css-frameworks:nth-child(6),.skill-group-css-frameworks:nth-child(7){grid-column:auto}.skill-group-php:nth-child(8),.skill-group-php:nth-child(9),.skill-group-php:nth-child(10){grid-column:auto}.skill-group-backend:nth-child(11),.skill-group-backend:nth-child(12){grid-column:auto}.skill-group-database:nth-child(13){grid-column:auto}.skill-card{background-color:var(--bg-primary);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);text-align:center;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid var(--border);opacity:1;transform:translateY(0);display:flex;flex-direction:column;align-items:center;position:relative;overflow:visible}.dark .skill-card{background-color:#0f172a99;border-color:var(--border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.skill-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:#2563eb33}.skill-icon,.skill-image-wrapper{width:100px;height:100px;margin:0 auto var(--spacing-lg);background-color:transparent;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);padding:0;position:relative}.skill-card:hover .skill-icon{transform:scale(1.2)}.skill-image{width:100%;height:100%;object-fit:contain;display:block;transition:transform .3s cubic-bezier(.4,0,.2,1);filter:drop-shadow(0 4px 8px rgba(0,0,0,.1))}.skill-card:hover .skill-image{transform:scale(1.15);filter:drop-shadow(0 8px 16px rgba(0,0,0,.15))}.skill-name{font-size:clamp(1.125rem,2vw,1.375rem);font-weight:600;margin-bottom:var(--spacing-sm);color:var(--text-primary);letter-spacing:-.01em;line-height:1.3;transition:color .3s ease}.skill-card:hover .skill-name{color:var(--primary)}.skill-description{color:var(--text-secondary);line-height:1.75;font-size:clamp(.875rem,1.5vw,.9375rem);margin-top:auto;transition:color .3s ease}.contact-section{background-color:var(--bg-primary)}.contact-page-header{margin-bottom:var(--spacing-3xl);text-align:center}.contact-header-content{max-width:800px;margin:0 auto}.contact-page-title{font-size:clamp(2rem,4vw,3rem);font-weight:700;color:var(--text-primary);margin:0 0 var(--spacing-md) 0;line-height:1.2;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.contact-page-subtitle{font-size:clamp(1rem,2vw,1.125rem);color:var(--text-secondary);line-height:1.7;margin:0}.impressum-section,.privacy-section,.pricing-section,.terms-section{background-color:var(--bg-primary)}.impressum-content,.privacy-content{max-width:1000px;margin:0 auto;padding:var(--spacing-xl) 0}.impressum-intro-card{background-color:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-2xl);display:flex;align-items:flex-start;gap:var(--spacing-md)}.impressum-intro-icon{width:24px;height:24px;color:var(--text-secondary);flex-shrink:0;margin-top:2px;opacity:.7}.impressum-intro{font-size:clamp(1rem,2vw,1.125rem);color:var(--text-primary);line-height:1.8;margin:0}.impressum-intro-note{font-size:clamp(.875rem,1.5vw,.9375rem);color:var(--text-secondary);line-height:1.8;margin:var(--spacing-md) 0 0 0;font-style:italic;padding-top:var(--spacing-md);border-top:1px solid var(--border)}.impressum-cards,.privacy-cards{display:grid;grid-template-columns:1fr;gap:var(--spacing-xl)}.impressum-card,.privacy-card{background-color:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--spacing-xl);box-shadow:var(--shadow-sm)}.dark .impressum-card,.dark .privacy-card{background-color:var(--bg-secondary);border-color:var(--border);box-shadow:var(--shadow-sm)}.impressum-card-header,.privacy-card-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--border)}.impressum-card-icon,.privacy-card-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background-color:var(--bg-secondary);border-radius:var(--radius-sm);color:var(--text-secondary);flex-shrink:0;opacity:.8}.impressum-card-title,.privacy-card-title{font-size:clamp(1.25rem,2.5vw,1.5rem);font-weight:700;color:var(--text-primary);margin:0}.impressum-card-content,.privacy-card-content{display:flex;flex-direction:column;gap:var(--spacing-md)}.impressum-info-item{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-md) 0}.impressum-info-item:not(:last-child){border-bottom:1px solid var(--border)}.impressum-info-item-header{flex-direction:column;gap:var(--spacing-xs);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--border);margin-bottom:var(--spacing-xs)}.impressum-info-icon{width:18px;height:18px;color:var(--text-secondary);flex-shrink:0;margin-top:2px;opacity:.6}.impressum-info-label{font-weight:700;color:var(--text-primary);font-size:clamp(1rem,2vw,1.125rem);display:block}.impressum-info-item-header .impressum-info-label{font-size:clamp(1.125rem,2.5vw,1.25rem);color:var(--text-primary);margin-bottom:var(--spacing-xs)}.impressum-info-value{color:var(--text-secondary);font-size:clamp(.9375rem,1.5vw,1rem);line-height:1.7;flex:1}.impressum-info-item-header .impressum-info-value{color:var(--text-primary);font-size:clamp(.9375rem,1.5vw,1rem)}.privacy-card-content p{font-size:clamp(.9375rem,1.5vw,1rem);color:var(--text-primary);line-height:1.8;margin:0 0 var(--spacing-md) 0}.privacy-card-content p:last-child{margin-bottom:0}.privacy-intro-text{font-size:clamp(1rem,2vw,1.125rem);color:var(--text-secondary);line-height:1.8;margin-bottom:var(--spacing-lg)!important}.privacy-legal-basis{font-size:clamp(.9375rem,1.5vw,1rem);color:var(--text-primary);line-height:1.8;margin:var(--spacing-md) 0;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--bg-secondary);border-left:3px solid var(--primary);border-radius:var(--radius-sm);font-weight:500}.privacy-info-box{background-color:var(--bg-secondary);border:1px solid var(--border);border-left:3px solid var(--border);border-radius:var(--radius-md);padding:var(--spacing-md);margin:var(--spacing-md) 0;display:flex;align-items:flex-start;gap:var(--spacing-md)}.privacy-info-box-secondary{background-color:var(--bg-secondary);border-color:var(--border);border-left-color:var(--border)}.privacy-info-icon{width:20px;height:20px;color:var(--text-secondary);flex-shrink:0;margin-top:2px;opacity:.6}.privacy-info-box-secondary .privacy-info-icon{color:var(--text-secondary);opacity:.6}.privacy-info-box p{margin:0 0 var(--spacing-sm) 0;font-size:clamp(.9375rem,1.5vw,1rem);line-height:1.7}.privacy-info-box p:last-child{margin-bottom:0}.privacy-info-box p strong{color:var(--text-primary);font-weight:600}.privacy-cookie-type{margin:var(--spacing-lg) 0;padding:var(--spacing-md);background-color:var(--bg-secondary);border-radius:var(--radius-md);border-left:3px solid var(--border)}.privacy-cookie-type-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.privacy-cookie-icon{width:20px;height:20px;color:var(--text-secondary);flex-shrink:0;opacity:.6}.privacy-cookie-type-title{font-size:clamp(1rem,2vw,1.125rem);font-weight:700;color:var(--text-primary);margin:0}.privacy-cookie-type p{margin:0;font-size:clamp(.9375rem,1.5vw,1rem);color:var(--text-primary);line-height:1.7}.privacy-update-note{margin-top:var(--spacing-2xl);padding:var(--spacing-md);background-color:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);text-align:center}.privacy-update-note p{margin:0;font-size:clamp(.875rem,1.5vw,.9375rem);color:var(--text-secondary);line-height:1.6;font-style:italic}.contact-main-layout{display:grid;grid-template-columns:1fr 1.2fr;gap:var(--spacing-3xl);max-width:1400px;margin:0 auto;align-items:start}.contact-info-section{display:flex;flex-direction:column;gap:var(--spacing-xl)}.contact-info-cards{display:flex;flex-direction:column;gap:var(--spacing-lg)}.contact-info-card{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-xl);background-color:var(--bg-secondary);border:2px solid var(--border);border-radius:var(--radius-lg);transition:all .3s ease;position:relative;overflow:hidden}.contact-info-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(135deg,var(--primary),var(--accent));transform:scaleY(0);transition:transform .3s ease}.contact-info-card:hover{border-color:var(--primary);box-shadow:0 8px 24px #2563eb1f;transform:translateY(-2px)}.contact-info-card:hover:before{transform:scaleY(1)}.contact-info-card-icon{flex-shrink:0;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:var(--radius-lg);color:#fff;transition:transform .3s ease}.contact-info-card:hover .contact-info-card-icon{transform:scale(1.1) rotate(5deg)}.contact-info-card-content{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs)}.contact-info-card-label{font-size:clamp(.75rem,1.5vw,.875rem);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0}.contact-info-card-link{font-size:clamp(1.125rem,2vw,1.25rem);font-weight:600;color:var(--text-primary);text-decoration:none;transition:all .3s ease;display:inline-flex;align-items:center;gap:var(--spacing-xs)}.contact-info-card-link:hover{color:var(--primary);transform:translate(4px)}.contact-info-card-link:after{content:"→";opacity:0;transform:translate(-8px);transition:all .3s ease}.contact-info-card-link:hover:after{opacity:1;transform:translate(0)}.contact-billing-note-card{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-lg);background-color:var(--bg-secondary);border:2px solid var(--border);border-left:4px solid var(--primary);border-radius:var(--radius-lg);margin-top:var(--spacing-md)}.contact-billing-note-icon{flex-shrink:0;width:24px;height:24px;color:var(--primary);margin-top:2px}.contact-billing-note-text{font-size:clamp(.875rem,1.5vw,.9375rem);color:var(--text-secondary);line-height:1.7;margin:0}.contact-form-section{position:sticky;top:calc(var(--spacing-xl) + var(--header-height) + var(--content-separation))}.contact-form-wrapper{background-color:var(--bg-secondary);border:2px solid var(--border);border-radius:var(--radius-xl);padding:var(--spacing-3xl);box-shadow:0 4px 16px #0000000a;transition:all .3s ease}.contact-form-wrapper:hover{box-shadow:0 8px 32px #00000014;border-color:var(--primary)}.contact-form-header{margin-bottom:var(--spacing-2xl);padding-bottom:var(--spacing-xl);border-bottom:2px solid var(--border)}.contact-form-heading{font-size:clamp(1.5rem,3vw,2rem);font-weight:700;color:var(--text-primary);margin:0 0 var(--spacing-sm) 0;line-height:1.3}.contact-form-description{font-size:clamp(.9375rem,1.5vw,1rem);color:var(--text-secondary);line-height:1.6;margin:0}.contact-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-label{font-size:clamp(.875rem,1.5vw,.9375rem);font-weight:600;color:var(--text-primary)}.form-input,.form-textarea{width:100%;padding:var(--spacing-lg);background-color:var(--bg-primary);border:2px solid var(--border);border-radius:var(--radius-lg);font-size:clamp(.9375rem,1.5vw,1rem);color:var(--text-primary);transition:all .3s ease;font-family:inherit}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px #2563eb1a;background-color:var(--bg-secondary)}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-secondary);opacity:.6}.form-textarea{min-height:150px;max-height:300px;resize:vertical;line-height:1.6}.form-submit-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-lg) var(--spacing-2xl);background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border:none;border-radius:var(--radius-lg);font-size:clamp(1rem,2vw,1.125rem);font-weight:600;cursor:pointer;transition:all .3s ease;width:100%;position:relative;overflow:hidden}.form-submit-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.form-submit-btn:hover:before{left:100%}.form-submit-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #2563eb4d}.form-submit-btn:active{transform:translateY(0)}.form-submit-btn svg{transition:transform .3s ease}.form-submit-btn:hover svg{transform:translate(4px)}.form-submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.form-submit-btn:disabled:hover{transform:none;box-shadow:none}.form-submit-btn:disabled:before{display:none}.form-submit-wrapper{margin-top:var(--spacing-xl)}.form-input-error,.form-textarea.form-input-error{border-color:#ef4444;box-shadow:0 0 0 4px #ef44441a;background-color:#ef444408}.form-input-error:focus,.form-textarea.form-input-error:focus{border-color:#ef4444;box-shadow:0 0 0 4px #ef444426}.form-error{display:flex;align-items:center;gap:var(--spacing-xs);font-size:clamp(.8125rem,1.5vw,.875rem);color:#ef4444;margin-top:var(--spacing-sm);font-weight:500}.form-error:before{content:"⚠";font-size:1rem;flex-shrink:0}.form-required{color:#ef4444;margin-left:4px;font-weight:700}.form-group-checkbox{margin-top:var(--spacing-md);padding:var(--spacing-lg);background-color:var(--bg-primary);border:2px solid var(--border);border-radius:var(--radius-lg);transition:all .3s ease}.form-group-checkbox:has(input:focus){border-color:var(--primary);box-shadow:0 0 0 4px #2563eb1a}.form-checkbox-label{display:flex;align-items:flex-start;gap:var(--spacing-md);cursor:pointer;font-size:clamp(.9375rem,1.5vw,1rem);line-height:1.7}.form-checkbox-label input[type=checkbox]{width:20px;height:20px;margin-top:2px;cursor:pointer;accent-color:var(--primary);flex-shrink:0;border-radius:var(--radius-sm);transition:all .2s ease}.form-checkbox-label input[type=checkbox]:focus{outline:2px solid var(--primary);outline-offset:2px;border-radius:2px}.form-checkbox-text{color:var(--text-primary);flex:1}.form-privacy-link{color:var(--primary);text-decoration:none;font-weight:600;border-bottom:2px solid transparent;transition:all .2s ease;display:inline-block}.form-privacy-link:hover{color:var(--accent);border-bottom-color:var(--accent)}.form-checkbox-error{border-color:#ef4444!important;box-shadow:0 0 0 4px #ef44441a!important;background-color:#ef444408!important}.form-status-message{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);border-radius:var(--radius-lg);margin-bottom:var(--spacing-xl);font-size:clamp(.9375rem,1.5vw,1rem);font-weight:500;animation:slideIn .3s ease-out;border:2px solid}.form-status-icon{flex-shrink:0;width:24px;height:24px}.form-status-text{flex:1;line-height:1.6}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.form-status-success{background-color:#22c55e14;color:#16a34a;border-color:#22c55e4d}.form-status-error{background-color:#ef444414;color:#dc2626;border-color:#ef44444d}.form-status-message svg{flex-shrink:0}.form-spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dark .form-input-error,.dark .form-textarea.form-input-error{border-color:#f87171;box-shadow:0 0 0 3px #f8717133}.dark .form-error{color:#f87171}.dark .form-status-success{background-color:#22c55e26;color:#4ade80;border-color:#22c55e66}.dark .form-status-error{background-color:#ef444426;color:#f87171;border-color:#ef444466}.form-input:disabled,.form-textarea:disabled{opacity:.6;cursor:not-allowed;background-color:var(--bg-secondary)}.contact-additional-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-lg);margin-top:var(--spacing-2xl)}.contact-info-card{display:flex;gap:var(--spacing-md);padding:var(--spacing-lg);background-color:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all .3s ease}.contact-info-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary)}.contact-info-icon{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#6366f11a,#a855f71a);border-radius:var(--radius-md);color:var(--primary)}.contact-info-content{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs)}.contact-info-title{font-size:clamp(.9375rem,1.5vw,1rem);font-weight:600;color:var(--text-primary);margin:0}.contact-info-text{font-size:clamp(.8125rem,1.5vw,.875rem);color:var(--text-secondary);line-height:1.6;margin:0}.not-found-section{min-height:calc(100vh - 300px);display:flex;align-items:center;justify-content:center;padding:var(--spacing-3xl) var(--spacing-lg);background-color:var(--bg-primary)}.not-found-content{text-align:center;max-width:500px;margin:0 auto;width:100%}.not-found-title{font-size:clamp(3rem,8vw,5rem);font-weight:700;color:var(--text-primary);margin:0 0 var(--spacing-md);line-height:1.1;letter-spacing:-.02em}.not-found-subtitle{font-size:clamp(1.25rem,2.5vw,1.75rem);font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-md);line-height:1.4}.not-found-description{font-size:clamp(.9375rem,1.5vw,1.0625rem);color:var(--text-secondary);line-height:1.6;margin:0 0 var(--spacing-2xl)}.not-found-actions{display:flex;gap:var(--spacing-md);justify-content:center;flex-wrap:wrap}.contact-info{max-width:600px;margin:0 auto}.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-xl)}.contact-item{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);background-color:var(--bg-secondary);padding:var(--spacing-xl);border-radius:var(--radius-lg);text-align:center;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.contact-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.contact-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:var(--radius-md);margin-bottom:var(--spacing-xs)}.contact-icon svg{width:24px;height:24px;color:#fff}.contact-item strong{color:var(--primary);font-weight:600;font-size:clamp(.8125rem,1.5vw,.875rem);text-transform:uppercase;letter-spacing:.5px;line-height:1.4}.contact-item span{color:var(--text-primary);font-size:clamp(.9375rem,1.5vw,1rem);line-height:1.6}footer{background:var(--surface-footer);color:var(--footer-text-primary);padding:var(--spacing-2xl) 0 var(--spacing-xl);border-top:1px solid var(--surface-border-strong);margin-top:var(--spacing-2xl);box-shadow:inset 0 1px #ffffff52;transition:background-color .25s ease,border-color .25s ease}.dark footer{background:var(--surface-footer);border-top-color:var(--surface-border-strong);box-shadow:none}.footer-content{display:flex;flex-direction:column;gap:var(--spacing-2xl)}.footer-main{display:grid;grid-template-columns:1fr 1.5fr;gap:var(--spacing-3xl);align-items:start}.footer-brand{display:flex;flex-direction:column;gap:var(--spacing-md)}.footer-logo{display:flex;align-items:center;margin-bottom:0}.footer-logo-img{display:block;height:52px;width:auto;max-width:min(280px,100%);object-fit:contain}.footer-tagline{color:var(--footer-text-secondary);font-size:.9375rem;line-height:1.6;max-width:320px}.footer-links{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-xl)}.footer-column{display:flex;flex-direction:column;gap:var(--spacing-md)}.footer-heading{font-size:.875rem;font-weight:700;color:var(--footer-text-primary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:0;margin-top:0}.footer-menu{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.footer-menu li{display:flex;align-items:center;gap:var(--spacing-sm)}.footer-menu a{color:var(--footer-text-secondary);text-decoration:none;font-size:.9375rem;transition:all .2s ease;display:flex;align-items:center;gap:var(--spacing-sm);padding:.25rem 0}.footer-menu a:hover{color:var(--primary);transform:translate(4px);text-shadow:0 0 0 rgba(0,0,0,0)}.footer-menu svg{width:18px;height:18px;opacity:.8;flex-shrink:0;transition:opacity .2s ease}.footer-menu a:hover svg{opacity:1}.footer-menu span{color:var(--footer-text-secondary);font-size:.9375rem}.footer-bottom{padding-top:var(--spacing-lg);border-top:1px solid color-mix(in srgb,var(--surface-border-strong) 78%,transparent);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--spacing-md)}.footer-link-button{background:none;border:none;padding:0;font:inherit;color:var(--footer-text-secondary);cursor:pointer;text-align:left;text-decoration:underline;text-underline-offset:2px}.footer-link-button:hover,.footer-link-button:focus-visible{color:var(--primary)}.footer-menu .footer-link-button{width:100%}.terms-last-updated{margin-top:var(--spacing-sm);font-size:.875rem;color:var(--text-secondary)}.privacy-intro-card{margin-bottom:var(--spacing-xl)}.search-no-results{padding:var(--spacing-lg);text-align:center;color:var(--text-secondary);font-size:.95rem}.footer-copyright{color:var(--footer-text-secondary);font-size:.875rem;margin:0}.footer-company{color:var(--footer-text-muted);font-size:.8125rem;margin:0;opacity:.8}.back-to-top-wrapper{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;align-items:center;justify-content:center}.back-to-top-btn{background:linear-gradient(135deg,#2563ebf2,#3b82f6f2);color:#fff;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #2563eb4d;padding:0;position:relative;z-index:1;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);margin:0}.back-to-top-btn:hover{background:linear-gradient(135deg,#1d4ed8f2,#2563ebf2);box-shadow:0 6px 24px #2563eb80}.back-to-top-btn:active{box-shadow:0 4px 16px #2563eb66}.back-to-top-progress-circle{position:absolute;top:0;left:0;pointer-events:none;z-index:0}.back-to-top-arrow{position:relative;z-index:2;width:20px;height:20px;transition:transform .3s ease;color:#fff}.back-to-top-btn:hover .back-to-top-arrow{transform:translateY(-2px)}@media (max-width: 1200px){.team-grid,.projects-grid,.skills-detailed,.skills-grid,.contact-grid,.about-grid,.about-cards{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (max-width: 968px){.navbar-brand,.nav-menu{gap:var(--spacing-lg)}.footer-main{grid-template-columns:1fr}.footer-links{grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}.footer-bottom{padding-top:var(--spacing-md);flex-direction:column;align-items:flex-start}.team-grid,.projects-grid,.skills-detailed,.skills-grid,.contact-grid,.about-grid,.about-cards{grid-template-columns:repeat(2,minmax(0,1fr))}.hero{min-height:90vh}.hero .container{padding:var(--spacing-2xl) var(--spacing-md)}.hero-title{margin-bottom:var(--spacing-md);gap:.1em}.hero-description{margin-bottom:var(--spacing-2xl);line-height:1.7}.section-title-wrapper{flex-wrap:wrap;gap:var(--spacing-sm)}.section-icon{font-size:clamp(1.5rem,4vw,2rem)!important}.section-title{line-height:1.2}.section-subtitle{line-height:1.6;padding:0 var(--spacing-sm)}.hero-buttons{flex-wrap:wrap;gap:var(--spacing-md);margin-bottom:var(--spacing-2xl)}.btn{flex:1;min-width:200px;justify-content:center}.hero-stats{flex-wrap:wrap;gap:var(--spacing-lg);justify-content:center}.stat-divider{display:none}.hero-orb-1,.hero-orb-2,.hero-orb-3{opacity:.3}}@media (max-width: 768px){.welcome-section{padding:var(--spacing-3xl) var(--spacing-md)}.welcome-icon-wrapper{width:80px;height:80px;margin-bottom:var(--spacing-lg)}.welcome-icon{width:40px;height:40px}.welcome-title{margin-bottom:var(--spacing-sm)}.welcome-subtitle{margin-bottom:var(--spacing-xs)}.team-grid,.projects-grid,.skills-detailed,.skills-grid,.contact-grid,.about-grid,.about-cards{grid-template-columns:1fr}.team-card{padding-top:calc(var(--spacing-lg) + .35rem)}.team-avatar{width:176px;height:176px}.team-layout{padding:var(--spacing-xl) var(--spacing-md)}.contact-page-header{padding:0 var(--spacing-sm);margin-bottom:var(--spacing-xl)}.contact-main-layout{grid-template-columns:1fr;gap:var(--spacing-2xl)}.contact-form-section{position:static}.contact-form-wrapper{padding:var(--spacing-xl)}.contact-info-card{padding:var(--spacing-lg)}.contact-info-card-icon{width:48px;height:48px}footer{padding:var(--spacing-md) 0}.footer-content,.footer-main{gap:var(--spacing-md)}.footer-logo-img{height:42px;max-width:min(220px,100%)}.footer-tagline{font-size:.8125rem}.footer-links{grid-template-columns:1fr;gap:var(--spacing-lg)}.footer-column{gap:var(--spacing-xs)}.footer-heading{font-size:.75rem;margin-bottom:var(--spacing-xs)}.footer-menu{gap:.5rem}.footer-menu a,.footer-menu span{font-size:.8125rem}.footer-bottom{padding-top:var(--spacing-md)}.footer-copyright{font-size:.75rem}.footer-company{font-size:.6875rem}.back-to-top-wrapper{bottom:20px;right:20px}.impressum-card,.privacy-card{padding:var(--spacing-md)}.impressum-card-header,.privacy-card-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.impressum-card-icon,.privacy-card-icon{width:40px;height:40px}.impressum-intro-card{flex-direction:column;gap:var(--spacing-sm)}}@media (max-width: 480px){.container{padding:0 var(--spacing-md)}.navbar{padding:0}.navbar .container.navbar-inner{padding:0 var(--spacing-sm);gap:var(--spacing-sm)}.navbar-logo{font-size:1.125rem}.navbar-actions{gap:var(--spacing-xs)}.nav-menu{top:calc(var(--header-height) + 1px)}.nav-menu.active{max-height:min(70vh,22rem)}.hero-buttons{flex-wrap:wrap;gap:var(--spacing-sm)}.btn{flex:1;min-width:150px;justify-content:center;font-size:.875rem;padding:var(--spacing-sm) var(--spacing-lg)}.hero-stats{flex-wrap:wrap;gap:var(--spacing-md)}.stat-divider{display:none}.search-dropdown{max-height:50vh}.search-hint{padding:var(--spacing-sm)}.search-result-item{padding:var(--spacing-xs)}}.project-popup-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10000;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);opacity:0;animation:popupFadeIn .2s ease-out forwards}@keyframes popupFadeIn{0%{opacity:0}to{opacity:1}}.project-popup-container{background-color:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:0 20px 60px #0000004d;width:100%;max-width:1400px;height:85vh;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;transform:scale(.95);animation:popupSlideIn .2s ease-out forwards}@keyframes popupSlideIn{0%{transform:scale(.95) translateY(20px)}to{transform:scale(1) translateY(0)}}.project-popup-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg) var(--spacing-xl);border-bottom:1px solid var(--border);background-color:var(--bg-secondary);flex-shrink:0}.project-popup-header-info{display:flex;flex-direction:column;gap:var(--spacing-xs);flex:1;min-width:0}.project-popup-title-wrapper{display:flex;align-items:center;gap:var(--spacing-sm)}.project-popup-title-main{display:flex;align-items:flex-start;gap:var(--spacing-sm);min-width:0}.project-popup-title-row{display:flex;align-items:center;gap:.65rem;min-width:0}.project-popup-title-row .project-popup-title{flex:1;min-width:0}.project-popup-title-text{flex:1;min-width:0;display:flex;flex-direction:column;align-items:flex-start}.project-popup__status-chip{margin-top:.45rem}.project-popup-status-line{margin:.35rem 0 0;font-size:.8125rem;line-height:1.45;font-weight:500;color:var(--text-secondary);padding-left:.65rem;border-left:3px solid rgba(37,99,235,.45)}.dark .project-popup-status-line{border-left-color:#60a5fa8c}.project-popup-favicon{width:32px;height:32px;object-fit:contain;border-radius:var(--radius-sm);flex-shrink:0}.project-popup-title{font-size:clamp(1.25rem,2vw,1.5rem);font-weight:600;color:var(--text-primary);margin:0}.project-popup-url{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--text-secondary);font-size:.875rem;text-decoration:none;transition:color .2s ease;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-popup-url:hover{color:var(--primary)}.project-popup-url svg{flex-shrink:0}.project-popup-url--note{white-space:normal;line-height:1.45;color:var(--text-secondary);font-size:.8125rem;margin:0}.project-popup-static{display:flex;flex-direction:column;height:100%;min-height:0;overflow:auto}.project-popup-static-media{flex:0 0 auto;max-height:42vh;background:linear-gradient(180deg,rgba(37,99,235,.06),transparent);display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);border-bottom:1px solid var(--border)}.project-popup-static-img{max-width:100%;max-height:40vh;width:auto;height:auto;object-fit:contain;border-radius:var(--radius-md);box-shadow:0 12px 32px #0206171f}.project-popup-static-body{padding:var(--spacing-lg) var(--spacing-xl);flex:1}.project-popup-static-desc{margin:0;color:var(--text-secondary);font-size:.9375rem;line-height:1.7}.project-popup-close{background:none;border:none;padding:var(--spacing-xs);cursor:pointer;color:#ef4444;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .2s ease;width:40px;height:40px}.project-popup-close:hover{background-color:#ef44441a;color:#dc2626;transform:none}.project-popup-content{flex:1;overflow:hidden;position:relative;min-height:0;background-color:var(--bg-primary)}.project-popup-iframe{width:100%;height:100%;border:none;display:block;background-color:#fff}@media (max-width: 768px){.project-popup-overlay{padding:var(--spacing-sm)}.project-popup-container{height:90vh;max-height:90vh;border-radius:var(--radius-lg)}.project-popup-header{padding:var(--spacing-md)}.project-popup-header-info{gap:var(--spacing-xs)}.project-popup-url{font-size:.8125rem}.project-popup-content{min-height:0}}.nav-dropdown{position:relative}.nav-dropdown-toggle{display:inline-flex;align-items:center;gap:.35rem;padding:.45rem .75rem;background:transparent;border:1px solid transparent;border-radius:8px;color:inherit;cursor:pointer;font:inherit;transition:var(--transition-all, all .2s ease);position:relative}.nav-dropdown-toggle:hover,.nav-dropdown-toggle:focus-visible{border-color:var(--border, #e2e8f0);background:var(--bg-secondary, #f8fafc)}.nav-dropdown .chevron{transition:transform .2s ease}.nav-dropdown .chevron.open{transform:rotate(180deg)}.nav-submenu{position:absolute;top:calc(100% + .45rem);left:0;min-width:200px;background:var(--bg-primary, #fff);border:1px solid var(--border, #e2e8f0);border-radius:10px;box-shadow:0 12px 30px #0000001a;padding:.4rem 0;display:none;z-index:20;list-style:none;margin:0}.nav-submenu.open{display:block}.nav-submenu li{width:100%;list-style:none}.nav-submenu a{display:flex;width:100%;padding:.55rem 1rem;align-items:center;gap:.5rem;border-radius:8px;color:inherit;text-decoration:none;transition:var(--transition-all, all .2s ease);position:relative}.nav-submenu a:hover,.nav-submenu a:focus-visible{background:var(--bg-secondary, #f8fafc);color:var(--primary, #2563eb)}.hero-subtitle{font-size:clamp(1.05rem,2vw,1.35rem);color:var(--text-secondary);max-width:720px;margin:0 auto var(--spacing-2xl);line-height:1.65;text-align:center;animation:fadeInUp .8s ease-out .35s both}.process-section{background-color:var(--bg-secondary);padding-bottom:var(--spacing-3xl)}.process-section-title{margin-bottom:var(--spacing-xl)}.process-steps{list-style:none;padding:0;display:flex;flex-wrap:wrap;justify-content:center;gap:var(--spacing-md);max-width:1000px;margin:0 auto}.process-step{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.dark .process-step{background:#1e293b80}.process-step-index{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;font-weight:700;font-size:.875rem;flex-shrink:0}.process-step-label{font-weight:600;color:var(--text-primary)}.home-cta-section{padding:var(--spacing-3xl) 0}.home-cta-section--center{background:linear-gradient(180deg,var(--bg-primary) 0%,var(--bg-secondary) 100%)}.home-cta-section--bottom{background-color:var(--bg-secondary);padding-bottom:var(--spacing-4xl)}.home-cta-panel{max-width:640px;margin:0 auto;text-align:center;padding:var(--spacing-2xl);border-radius:var(--radius-xl);border:1px solid var(--border);background:var(--bg-secondary);box-shadow:var(--shadow-md)}.dark .home-cta-panel{background:#1e293b8c}.home-cta-panel--bottom{border-color:#2563eb40;box-shadow:0 8px 32px #2563eb1f}.home-cta-title{font-size:clamp(1.5rem,3vw,1.85rem);margin-bottom:var(--spacing-md);color:var(--text-primary)}.home-cta-text{color:var(--text-secondary);line-height:1.75;margin-bottom:var(--spacing-xl);font-size:1.05rem}.home-cta-btn{min-width:220px;justify-content:center}.pricing-section .section-header{margin-bottom:var(--spacing-3xl)}.pricing-section-intro.section-subtitle{max-width:720px;margin-left:auto;margin-right:auto;text-align:center}.pricing-intro-note{color:var(--text-secondary);line-height:1.75;max-width:720px;margin:var(--spacing-md) auto 0;text-align:center;font-weight:600;color:var(--text-primary)}.pricing-content{max-width:1000px;margin:0 auto;padding:0 0 var(--spacing-xl)}.pricing-headline-block{text-align:center;max-width:640px;margin:0 auto var(--spacing-3xl);padding:var(--spacing-xl);border-radius:var(--radius-lg);background:var(--bg-secondary);border:1px solid var(--border)}.dark .pricing-headline-block{background:#1e293b73}.pricing-headline{font-size:1.15rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-sm)}.pricing-headline-cta{margin:0;color:var(--primary);font-weight:700;font-size:1.1rem}.pricing-packages-title{text-align:center;font-size:clamp(1.35rem,2.5vw,1.6rem);margin-bottom:var(--spacing-2xl);color:var(--text-primary)}.pricing-packages{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-xl);margin-bottom:var(--spacing-3xl)}@media (max-width: 960px){.pricing-packages{grid-template-columns:1fr}}.pricing-card{padding:var(--spacing-2xl);border-radius:var(--radius-xl);border:1px solid var(--border);background:var(--bg-secondary);display:flex;flex-direction:column;transition:transform .25s ease,box-shadow .25s ease}.pricing-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.dark .pricing-card{background:#1e293b80}.pricing-card--basic{border-top:4px solid #22c55e}.pricing-card--business{border-top:4px solid #3b82f6}.pricing-card--custom{border-top:4px solid #a855f7}.pricing-card-name{font-size:1.25rem;margin:0 0 var(--spacing-sm);color:var(--text-primary)}.pricing-card-price{font-size:1.5rem;font-weight:800;color:var(--primary);margin:0 0 var(--spacing-lg)}.pricing-card-features{margin:0;padding-left:1.15rem;color:var(--text-secondary);line-height:1.8;flex:1}.pricing-footnote{text-align:center;color:var(--text-secondary);line-height:1.75;max-width:640px;margin:0 auto var(--spacing-3xl);font-size:.9375rem}.pricing-repeat-block{text-align:center;max-width:560px;margin:0 auto var(--spacing-3xl);padding:var(--spacing-xl);line-height:1.75;color:var(--text-secondary)}.pricing-repeat-cta{margin:var(--spacing-md) 0 0;font-weight:700;color:var(--primary)}.pricing-bottom-cta{text-align:center;padding:var(--spacing-3xl) var(--spacing-lg);margin-bottom:var(--spacing-2xl);border-radius:var(--radius-xl);background:linear-gradient(135deg,#2563eb14,#0ea5e914);border:1px solid var(--border)}.dark .pricing-bottom-cta{background:linear-gradient(135deg,#2563eb26,#0ea5e91f)}.pricing-bottom-title{font-size:clamp(1.35rem,2.5vw,1.65rem);margin-bottom:var(--spacing-sm);color:var(--text-primary)}.pricing-bottom-text{color:var(--text-secondary);margin-bottom:var(--spacing-xl);font-size:1.05rem}.about-cards--four{grid-template-columns:repeat(2,minmax(0,1fr))}@media (min-width: 992px){.about-cards--four{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (max-width: 640px){.about-cards--four{grid-template-columns:1fr}}.why-us-section{margin-top:var(--spacing-3xl)}.why-us-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--spacing-lg);margin-top:var(--spacing-xl)}@media (max-width: 768px){.why-us-grid{grid-template-columns:1fr}}.team-role-text{font-size:.95rem;font-weight:600;color:var(--primary);margin:.25rem 0 var(--spacing-sm);text-align:center}.project-content--portfolio .project-tech,.project-content--portfolio .project-contributors,.project-card--portfolio .project-status-chip,.project-card--portfolio .project-status-under-development{display:none!important}.project-client{margin:0 0 var(--spacing-xs);font-size:.875rem;font-weight:600;color:var(--primary)}.project-completed-date{margin:0 0 var(--spacing-sm);font-size:.8125rem;color:var(--text-secondary)}.project-completed-label{font-weight:600;color:var(--text-primary)}.project-outcome{margin:var(--spacing-sm) 0 var(--spacing-md);font-size:.95rem;color:var(--text-secondary);line-height:1.5}.project-outcome strong{color:var(--text-primary)}.project-card-actions{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.project-preview-btn--link{text-decoration:none;display:inline-flex;align-items:center;justify-content:center}.project-preview-btn--secondary{background:transparent;border:1px solid var(--border);color:var(--text-primary)}.project-controls--simple{margin-bottom:var(--spacing-xl)}.pricing-card-price-label{display:block;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);margin-bottom:.15rem}.pricing-pricing-note{text-align:center;max-width:42rem;margin:var(--spacing-sm) auto var(--spacing-lg);color:var(--text-secondary);font-weight:500}html{overflow-x:clip}body,#root{overflow-x:clip;min-width:0}img,video,iframe,svg{max-width:100%;height:auto}.hero-section--marketing{min-height:auto;align-items:stretch}.hero-section--marketing .container{padding-top:var(--spacing-md);padding-bottom:var(--spacing-2xl)}.hero-section--marketing .hero-badge{margin-top:0;margin-bottom:var(--spacing-lg)}.hero-section--marketing .hero-background{pointer-events:none}.dark .hero-section--marketing{background:linear-gradient(165deg,#0b1220,#111827 42%,#0f172a)}.hero-section--marketing .hero-content{max-width:52rem}.hero-section--marketing .hero-title{font-size:clamp(2rem,5.5vw,3.35rem);margin-bottom:var(--spacing-lg);line-height:1.15}.hero-section--marketing .hero-subtitle{margin-bottom:var(--spacing-xl);max-width:38rem}.hero-section--marketing .hero-actions{margin-bottom:var(--spacing-xl);max-width:28rem;margin-left:auto;margin-right:auto}.hero-section--marketing .hero-actions .btn{flex:1 1 12rem;min-width:0;max-width:none}.hero-trust-panel{margin:0 auto;max-width:44rem;padding:var(--spacing-lg) var(--spacing-xl);border-radius:var(--radius-xl);border:1px solid color-mix(in srgb,var(--border) 80%,transparent);background:color-mix(in srgb,var(--bg-primary) 72%,transparent);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 12px 40px #0f172a1f}.dark .hero-trust-panel{background:color-mix(in srgb,var(--bg-secondary) 65%,transparent);border-color:color-mix(in srgb,var(--border) 60%,transparent);box-shadow:0 16px 48px #00000059}.hero-trust-strip{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--spacing-md) var(--spacing-xl);text-align:left}.hero-trust-item{display:flex;align-items:flex-start;gap:var(--spacing-sm);font-size:.9rem;color:var(--text-secondary);line-height:1.5}.hero-trust-check{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:1.35rem;height:1.35rem;margin-top:.1rem;color:var(--primary)}.hero-trust-check svg{display:block}.team-description p{margin:0}.team-description p+p{margin-top:var(--spacing-sm)}.form-checkbox-legend{margin:0 0 var(--spacing-sm);font-size:.9375rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:.25rem}@media (max-width: 640px){.hero-trust-strip{grid-template-columns:1fr}.hero-section--marketing .hero-actions{flex-direction:column;max-width:100%}.hero-section--marketing .hero-actions .btn{width:100%}.hero-trust-panel{padding:var(--spacing-md) var(--spacing-lg)}}.home-why-choose-section .section-header{text-align:center}.home-why-choose-grid{margin-top:var(--spacing-xl)}.pricing-card-price-note{margin:var(--spacing-xs) 0 var(--spacing-md);font-size:.875rem;color:var(--text-secondary);line-height:1.4}.contact-response-note{margin-top:var(--spacing-lg);text-align:center;font-size:.95rem;font-weight:600;color:var(--primary)}.hero-actions{display:flex;flex-wrap:wrap;gap:var(--spacing-md);justify-content:center;align-items:center}.hero-actions .btn{flex:1 1 auto;min-width:min(100%,12.5rem);justify-content:center;text-align:center}.hero-title,.title-line,.section-title,.project-title{overflow-wrap:anywhere;word-break:break-word}@media (max-width: 1200px){.about-cards--four,.pricing-packages{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 968px){.contact-main-layout{grid-template-columns:1fr;gap:var(--spacing-2xl)}.footer-main{grid-template-columns:1fr}.process-steps{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 768px){.about-cards--four,.pricing-packages{grid-template-columns:1fr}.hero-actions{flex-direction:column;width:100%}.hero-actions .btn{width:100%;min-width:0}.project-card-actions{flex-direction:column;align-items:stretch}.project-preview-btn,.project-preview-btn--link{width:100%}.project-popup-overlay{padding:0;align-items:flex-end}.project-popup-container{width:100%;max-width:100%;height:min(92vh,100dvh);max-height:min(92vh,100dvh);border-radius:var(--radius-lg) var(--radius-lg) 0 0;margin:0}.home-cta-panel,.pricing-headline-block,.pricing-bottom-cta{padding-left:var(--spacing-md);padding-right:var(--spacing-md)}.cookie-consent-container{margin:var(--spacing-sm);max-width:calc(100% - 2 * var(--spacing-sm))}.search-overlay-dropdown{left:var(--spacing-sm)!important;right:var(--spacing-sm)!important;width:auto!important;max-width:none!important}}@media (max-width: 480px){.container{padding-left:max(.75rem,env(safe-area-inset-left));padding-right:max(.75rem,env(safe-area-inset-right))}.bottom-nav-label{font-size:.5625rem}.bottom-nav-icon{width:20px;height:20px}.process-steps,.team-grid,.why-us-grid{grid-template-columns:1fr}}@media (max-width: 380px){.bottom-nav-inner{grid-template-columns:repeat(3,minmax(0,1fr));grid-template-rows:repeat(2,1fr);row-gap:0;padding:.2rem 0}.bottom-nav-link,.bottom-nav-link-button{min-height:48px;padding:.35rem .1rem}}.existing-website-section{padding:var(--spacing-3xl) 0;background:var(--bg-secondary)}.existing-website-panel{max-width:720px;margin:0 auto;text-align:center;padding:var(--spacing-2xl);border-radius:var(--radius-xl);border:1px solid var(--border);background:var(--bg-primary);box-shadow:var(--shadow-md)}.existing-website-title{font-size:clamp(1.35rem,3vw,1.75rem);margin-bottom:var(--spacing-md);color:var(--text-primary)}.existing-website-text{color:var(--text-secondary);line-height:1.75;margin-bottom:var(--spacing-xl)}.section-cta-link{display:flex;justify-content:center;margin-top:var(--spacing-2xl)}.process-step-content{display:flex;flex-direction:column;gap:.15rem}.process-step-subtitle{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.process-steps--detailed .process-step{flex-direction:column;align-items:flex-start;min-width:200px;flex:1 1 200px}.projects-preview-section{padding:var(--spacing-3xl) 0}.projects-preview-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--spacing-xl)}.project-preview-card{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-secondary);box-shadow:var(--shadow-sm)}.project-preview-card__media{aspect-ratio:16 / 10;overflow:hidden}.project-preview-img{width:100%;height:100%;object-fit:cover;display:block}.project-preview-card__body{padding:var(--spacing-lg)}.project-preview-title{margin:0 0 var(--spacing-sm);font-size:1.1rem}.project-preview-desc,.project-preview-outcome{margin:0;color:var(--text-secondary);line-height:1.6;font-size:.95rem}.project-preview-outcome{margin-top:var(--spacing-sm);font-weight:600;color:var(--primary)}.testimonials-section{padding:var(--spacing-4xl) 0;background:linear-gradient(180deg,var(--bg-secondary) 0%,var(--bg-primary) 100%)}.testimonials-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--spacing-xl);align-items:stretch}.testimonial-card{margin:0;padding:var(--spacing-2xl);border-radius:var(--radius-xl);border:1px solid color-mix(in srgb,var(--primary) 22%,var(--border));background:var(--bg-primary);box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:var(--spacing-lg);min-height:100%;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}.testimonial-card:hover{transform:translateY(-4px);border-color:color-mix(in srgb,var(--primary) 45%,var(--border));box-shadow:var(--shadow-lg)}.testimonial-quote-icon{color:color-mix(in srgb,var(--primary) 70%,transparent);opacity:.85}.testimonial-quote{margin:0;flex:1;color:var(--text-secondary);line-height:1.8;font-size:1.02rem}.testimonial-author{display:flex;align-items:center;gap:var(--spacing-md);margin-top:auto;padding-top:var(--spacing-md);border-top:1px solid var(--border)}.testimonial-author-avatar{width:2.75rem;height:2.75rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;color:#fff;background:linear-gradient(135deg,var(--primary),var(--accent));flex-shrink:0}.testimonial-author-meta{display:flex;flex-direction:column;gap:.15rem;min-width:0}.testimonial-author cite{font-style:normal;font-weight:700;color:var(--text-primary);font-size:.95rem}.testimonial-role{font-size:.8125rem;color:var(--text-secondary)}.services-page{padding-bottom:var(--spacing-4xl)}.services-page .page-header{text-align:center;margin-bottom:var(--spacing-3xl)}.services-page .page-header .section-title-wrapper{justify-content:center}.services-page .section-subtitle{max-width:720px;margin-left:auto;margin-right:auto}.page-header-cta{margin-top:var(--spacing-lg)}.services-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--spacing-xl);margin-bottom:var(--spacing-2xl)}.service-card{padding:var(--spacing-xl);border-radius:var(--radius-xl);border:1px solid var(--border);background:var(--bg-secondary);display:flex;flex-direction:column;gap:var(--spacing-sm);min-height:100%;transition:border-color .2s ease,box-shadow .2s ease}.service-card:hover{border-color:color-mix(in srgb,var(--primary) 35%,var(--border));box-shadow:var(--shadow-md)}.service-card-title{margin:0;font-size:1.2rem;color:var(--text-primary)}.service-card-description{margin:0;color:var(--text-secondary);line-height:1.7;flex:1}.service-card-features{margin:var(--spacing-sm) 0 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.4rem}.service-card-features li{position:relative;padding-left:1.35rem;color:var(--text-secondary);font-size:.925rem}.service-card-features li:before{content:"";position:absolute;left:0;top:.55em;width:.45rem;height:.45rem;border-radius:50%;background:var(--primary)}.project-case-block{margin-top:var(--spacing-md)}.project-case-label{margin:0 0 .25rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;color:var(--primary);font-weight:700}.project-case-text{margin:0;color:var(--text-secondary);line-height:1.65}.why-us-grid--modern{grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--spacing-md)}.why-us-card--simple{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-lg) var(--spacing-xl);border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-primary);box-shadow:var(--shadow-sm);transition:border-color .2s ease,transform .2s ease}.why-us-card--simple:hover{border-color:color-mix(in srgb,var(--primary) 40%,var(--border));transform:translateY(-2px)}.why-us-card--simple .card-title{margin:0;font-size:1rem;line-height:1.45}.why-us-check{flex-shrink:0;width:2rem;height:2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--primary) 12%,transparent);color:var(--primary)}.pricing-footnote-banner{display:flex;align-items:flex-start;gap:var(--spacing-md);max-width:820px;margin:0 auto var(--spacing-3xl);padding:var(--spacing-lg) var(--spacing-xl);border-radius:var(--radius-lg);border:1px solid color-mix(in srgb,var(--primary) 35%,var(--border));background:color-mix(in srgb,var(--primary) 8%,var(--bg-secondary));color:var(--text-primary);font-weight:600;line-height:1.6;text-align:left}.pricing-footnote-banner p{margin:0}.pricing-footnote-banner svg{flex-shrink:0;color:var(--primary);margin-top:.1rem}.pricing-packages--uniform,.pricing-packages--additional{display:grid;gap:var(--spacing-xl);margin-bottom:var(--spacing-3xl)}.pricing-packages--uniform,.pricing-packages--additional{grid-template-columns:repeat(3,minmax(0,1fr))}.pricing-packages-title--secondary{margin-top:var(--spacing-xl)}.pricing-card--uniform{display:flex;flex-direction:column;min-height:100%}.pricing-card-description{margin:0 0 var(--spacing-sm);color:var(--text-secondary);line-height:1.65;font-size:.925rem}.pricing-card-audience{margin:0 0 var(--spacing-sm);color:var(--text-secondary);font-size:.925rem;line-height:1.5}.pricing-card-price{margin:0 0 var(--spacing-md)}.pricing-card-price-custom{font-weight:700;color:var(--primary);font-size:1.2rem}.pricing-card-features{flex:1;margin-bottom:var(--spacing-lg)}.pricing-card-cta{margin-top:auto;width:100%;justify-content:center;text-align:center}.contact-form--structured .form-row--two{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--spacing-lg)}.form-hint{display:block;margin-top:.35rem;font-size:.8125rem;color:var(--text-secondary);line-height:1.45}.form-custom-select{position:relative;width:100%}.form-custom-select-button{width:100%;min-height:48px;display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);padding:.75rem 1rem;border:2px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-primary);color:var(--text-primary);font:inherit;font-size:1rem;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease}.form-custom-select-button:hover:not(:disabled){border-color:color-mix(in srgb,var(--primary) 45%,var(--border))}.form-custom-select.open .form-custom-select-button,.form-custom-select-button:focus-visible{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 22%,transparent)}.form-custom-select.error .form-custom-select-button{border-color:#ef4444}.form-custom-select-value.placeholder{color:var(--text-secondary)}.form-custom-select-arrow{flex-shrink:0;transition:transform .2s ease;color:var(--text-secondary)}.form-custom-select-arrow.open{transform:rotate(180deg)}.form-custom-select-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:50;max-height:280px;overflow-y:auto;border:2px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-primary);box-shadow:var(--shadow-lg);padding:.35rem;animation:formSelectDropIn .18s ease}@keyframes formSelectDropIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.form-custom-select-option{width:100%;display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);padding:.65rem .85rem;border:none;border-radius:var(--radius-md);background:transparent;color:var(--text-primary);font:inherit;font-size:.9375rem;text-align:left;cursor:pointer}.form-custom-select-option:hover,.form-custom-select-option.focused{background:color-mix(in srgb,var(--primary) 10%,var(--bg-secondary))}.form-custom-select-option.selected{background:color-mix(in srgb,var(--primary) 14%,var(--bg-secondary));color:var(--primary);font-weight:600}.form-custom-select.disabled .form-custom-select-button{opacity:.6;cursor:not-allowed}.dark .form-custom-select-dropdown{background:var(--bg-secondary);border-color:var(--border)}.high-contrast-light .form-custom-select-button,.high-contrast-dark .form-custom-select-button{border-width:2px}@media (min-width: 1141px) and (max-width: 1320px){.navbar .container.navbar-inner{column-gap:var(--spacing-sm);grid-template-columns:auto minmax(0,1fr) auto}.nav-menu{gap:clamp(.25rem,.7vw,.55rem);flex-wrap:nowrap;justify-content:center;min-width:0}.nav-menu a{font-size:clamp(.75rem,.95vw,.8125rem);padding:.35rem .05rem;gap:.25rem;white-space:nowrap}.nav-menu a svg{width:16px;height:16px}.navbar-actions{gap:.35rem;flex-shrink:0}.navbar-logo-img{max-height:40px}}@media (min-width: 1141px) and (max-width: 1260px){.nav-menu a span{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.nav-menu a{padding:.45rem .5rem}.nav-menu>li>a.nav-link-active:after{bottom:0;width:60%;left:20%}}@media (max-width: 1200px){.pricing-packages--uniform,.pricing-packages--additional,.why-us-grid--modern{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 968px){.projects-preview-grid,.testimonials-grid,.services-grid,.contact-form--structured .form-row--two,.pricing-packages--uniform,.pricing-packages--additional{grid-template-columns:1fr}}
