:root{--color-bg-base:#050a14;--color-bg-surface:#0a1628;--color-bg-elevated:#0d1f3c;--color-bg-overlay:#050a14d9;--color-accent:#00c2ff;--color-accent-dim:#00c2ff26;--color-accent-glow:#00c2ff59;--color-gold:#f5a623;--color-gold-dim:#f5a62326;--color-gold-glow:#f5a62359;--color-success:#00e5a0;--color-error:#ff4d6d;--color-text-primary:#e8f4ff;--color-text-secondary:#7a9bbf;--color-text-muted:#3d5a78;--color-text-inverse:#050a14;--glass-bg:#0a16288c;--glass-bg-hover:#0d1f3cb3;--glass-border:#00c2ff1a;--glass-border-hover:#00c2ff47;--glass-blur:blur(18px) saturate(180%);--glass-shadow:0 8px 32px #00000073;--glass-shadow-hover:0 20px 60px #0000008c, 0 0 0 1px #00c2ff1f;--font-display:"Space Grotesk", system-ui, sans-serif;--font-body:"Inter", system-ui, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--text-5xl:3rem;--text-6xl:3.75rem;--text-7xl:4.5rem;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--space-32:8rem;--radius-sm:6px;--radius-md:12px;--radius-lg:20px;--radius-xl:32px;--radius-full:9999px;--ease-smooth:cubic-bezier(.16, 1, .3, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--ease-in:cubic-bezier(.4, 0, 1, 1);--ease-out:cubic-bezier(0, 0, .2, 1);--dur-fast:.15s;--dur-base:.3s;--dur-slow:.6s;--dur-slower:.9s;--z-base:0;--z-above:10;--z-nav:100;--z-modal:200;--z-toast:300;--gradient-accent:linear-gradient(135deg, #00c2ff 0%, #06c 100%);--gradient-gold:linear-gradient(135deg, #f5a623 0%, #e8840a 100%);--gradient-hero:radial-gradient(ellipse 80% 60% at 50% -10%, #00c2ff2e 0%, transparent 60%), radial-gradient(ellipse 60% 40% at 80% 80%, #f5a62314 0%, transparent 50%)}[data-theme=light]{--color-bg-base:#f0f6ff;--color-bg-surface:#fff;--color-bg-elevated:#e8f2ff;--color-bg-overlay:#f0f6ffe6;--color-text-primary:#0a1628;--color-text-secondary:#2d4a6a;--color-text-muted:#6b8aad;--glass-bg:#ffffffa6;--glass-bg-hover:#ffffffd9;--glass-border:#0066cc1f;--glass-border-hover:#0066cc47;--glass-shadow:0 8px 32px #0032781f;--glass-shadow-hover:0 20px 60px #0032782e;--gradient-hero:radial-gradient(ellipse 80% 60% at 50% -10%, #00c2ff1f 0%, transparent 60%), radial-gradient(ellipse 60% 40% at 80% 80%, #f5a6230f 0%, transparent 50%)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;tab-size:4}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;min-height:100dvh;line-height:1.6}img,video,svg,canvas{max-width:100%;display:block}img,video{height:auto}input,button,textarea,select{font:inherit;color:inherit}button{cursor:pointer;background:0 0;border:none}a{color:inherit;text-decoration:none}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2}p{max-width:70ch}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}body{font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text-primary);background-color:var(--color-bg-base);line-height:1.7}.display-1{font-family:var(--font-display);font-size:clamp(2.5rem, 7vw, var(--text-7xl));letter-spacing:-.03em;font-weight:700;line-height:1.05}.display-2{font-family:var(--font-display);font-size:clamp(2rem, 5vw, var(--text-6xl));letter-spacing:-.025em;font-weight:700;line-height:1.1}h1,.h1{font-family:var(--font-display);font-size:clamp(1.75rem, 4vw, var(--text-5xl));letter-spacing:-.02em;font-weight:700}h2,.h2{font-family:var(--font-display);font-size:clamp(1.5rem, 3.5vw, var(--text-4xl));letter-spacing:-.015em;font-weight:700}h3,.h3{font-family:var(--font-display);font-size:clamp(1.25rem, 2.5vw, var(--text-3xl));letter-spacing:-.01em;font-weight:600}h4,.h4{font-family:var(--font-display);font-size:var(--text-xl);font-weight:600}h5,.h5{font-family:var(--font-display);font-size:var(--text-lg);font-weight:600}h6,.h6{font-family:var(--font-display);font-size:var(--text-base);font-weight:600}.section-label{font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:.2em;text-transform:uppercase;color:var(--color-accent);font-weight:500}.text-lg{font-size:var(--text-lg)}.text-sm{font-size:var(--text-sm)}.text-xs{font-size:var(--text-xs)}.text-mono{font-family:var(--font-mono)}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-text-muted)}.text-accent{color:var(--color-accent)}.text-gold{color:var(--color-gold)}.gradient-text{background:var(--gradient-accent);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.gradient-text-gold{background:var(--gradient-gold);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.highlight{color:var(--color-accent);display:inline-block;position:relative}.link{color:var(--color-accent);transition:opacity var(--dur-fast) var(--ease-smooth)}.link:hover{opacity:.8}.glass-card{background:var(--glass-bg);border:1px solid var(--glass-border);-webkit-backdrop-filter:var(--glass-blur);box-shadow:var(--glass-shadow);border-radius:var(--radius-lg);transition:border-color var(--dur-base) var(--ease-smooth), box-shadow var(--dur-base) var(--ease-smooth), transform var(--dur-base) var(--ease-smooth), background var(--dur-base) var(--ease-smooth)}.glass-card:hover{background:var(--glass-bg-hover);border-color:var(--glass-border-hover);box-shadow:var(--glass-shadow-hover);transform:translateY(-4px)}.glass-panel{background:var(--glass-bg);border:1px solid var(--glass-border);-webkit-backdrop-filter:var(--glass-blur);box-shadow:var(--glass-shadow);border-radius:var(--radius-xl)}.glass-nav{border-bottom:1px solid var(--glass-border);-webkit-backdrop-filter:blur(24px)saturate(200%);background:#050a14bf}[data-theme=light] .glass-nav{background:#f0f6ffd9}.glass-badge{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);background:var(--color-accent-dim);border-radius:var(--radius-full);font-size:var(--text-xs);color:var(--color-accent);font-weight:500;font-family:var(--font-mono);letter-spacing:.05em;border:1px solid #00c2ff33;display:inline-flex}.glass-badge-gold{background:var(--color-gold-dim);color:var(--color-gold);border-color:#f5a62333}.glow-accent{box-shadow:0 0 20px var(--color-accent-glow), 0 0 60px #00c2ff1a}.glow-gold{box-shadow:0 0 20px var(--color-gold-glow), 0 0 60px #f5a6231a}.tech-card{background:var(--glass-bg);border:1px solid var(--glass-border);-webkit-backdrop-filter:var(--glass-blur);border-radius:var(--radius-md);padding:var(--space-4);transition:border-color var(--dur-base) var(--ease-smooth), box-shadow var(--dur-base) var(--ease-smooth), transform var(--dur-base) var(--ease-smooth);text-align:center;cursor:default}.tech-card:hover{border-color:var(--glass-border-hover);box-shadow:0 16px 40px #0006, 0 0 0 1px var(--color-accent-dim);transform:translateY(-6px)scale(1.03)}[data-reveal]{opacity:0;transition:opacity var(--dur-slow) var(--ease-smooth), transform var(--dur-slow) var(--ease-smooth);transform:translateY(28px)}[data-reveal=left]{transform:translate(-40px)}[data-reveal=right]{transform:translate(40px)}[data-reveal=scale]{transform:scale(.92)}[data-reveal=none]{transform:none}[data-reveal].revealed{opacity:1;transform:none}.typed-cursor{background:var(--color-accent);vertical-align:text-bottom;border-radius:2px;width:3px;height:1em;margin-left:4px;animation:1.1s step-end infinite blink;display:inline-block}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.float{animation:float 4s var(--ease-smooth) infinite}.float-delayed{animation:float 4s var(--ease-smooth) 1.5s infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 0 0 var(--color-accent-glow)}50%{box-shadow:0 0 30px 8px var(--color-accent-glow)}}.pulse-glow{animation:3s ease-in-out infinite pulse-glow}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.shimmer{background:linear-gradient(90deg, var(--color-bg-surface) 25%, var(--color-bg-elevated) 50%, var(--color-bg-surface) 75%);background-size:200% 100%;animation:1.8s ease-in-out infinite shimmer}@keyframes fill-bar{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.bar-fill{transform-origin:0;transition:transform var(--dur-slower) var(--ease-smooth);transform:scaleX(0)}.bar-fill.revealed{transform:scaleX(1)}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:1s linear infinite spin}@keyframes bounce-down{0%,to{opacity:.5;transform:translateY(0)}50%{opacity:1;transform:translateY(8px)}}.scroll-indicator{animation:1.8s ease-in-out infinite bounce-down}#progress-bar{background:var(--gradient-accent);width:0%;height:2px;z-index:calc(var(--z-nav) + 1);box-shadow:0 0 8px var(--color-accent-glow);transition:width .1s linear;position:fixed;top:0;left:0}.gradient-mesh{background:var(--gradient-hero);pointer-events:none;z-index:0;position:absolute;inset:0}.orb{border-radius:var(--radius-full);filter:blur(80px);pointer-events:none;position:absolute}.orb-cyan{background:radial-gradient(circle,#00c2ff26 0%,#0000 70%)}.orb-gold{background:radial-gradient(circle,#f5a6231a 0%,#0000 70%)}.btn{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);border-radius:var(--radius-md);font-family:var(--font-display);font-weight:600;font-size:var(--text-sm);letter-spacing:.02em;transition:transform var(--dur-fast) var(--ease-spring), box-shadow var(--dur-base) var(--ease-smooth), opacity var(--dur-fast) var(--ease-smooth);cursor:pointer;display:inline-flex;position:relative;overflow:hidden}.btn:before{content:"";opacity:0;transition:opacity var(--dur-fast) var(--ease-smooth);background:#ffffff14;position:absolute;inset:0}.btn:hover:before{opacity:1}.btn:hover{transform:translateY(-2px)}.btn:active{transform:translateY(0)}.btn-primary{background:var(--gradient-accent);color:var(--color-bg-base);box-shadow:0 4px 24px #00c2ff4d}.btn-primary:hover{box-shadow:0 8px 32px #00c2ff73}.btn-secondary{color:var(--color-text-primary);border:1px solid var(--glass-border-hover);background:0 0}.btn-secondary:hover{border-color:var(--color-accent);color:var(--color-accent);box-shadow:0 0 0 1px var(--color-accent-dim), inset 0 0 20px var(--color-accent-dim)}.btn-gold{background:var(--gradient-gold);color:var(--color-bg-base);box-shadow:0 4px 24px #f5a6234d}.btn-ghost{color:var(--color-accent);padding:var(--space-2) var(--space-3);background:0 0;border:none}.btn-ghost:hover{background:var(--color-accent-dim)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--text-base);border-radius:var(--radius-lg)}.btn-sm{padding:var(--space-2) var(--space-4);font-size:var(--text-xs);border-radius:var(--radius-sm)}.container{width:100%;max-width:1200px;padding-inline:var(--space-6);margin-inline:auto}.container-sm{max-width:720px}.container-lg{max-width:1400px}.container-xl{max-width:1600px}@media (width<=480px){.container{padding-inline:var(--space-4)}}.section{padding-block:var(--space-32);position:relative;overflow:hidden}.section-sm{padding-block:var(--space-20)}.section-header{text-align:center;margin-bottom:var(--space-16)}.section-header .section-label{margin-bottom:var(--space-3);display:block}.section-header h2{margin-bottom:var(--space-4)}.section-header p{color:var(--color-text-secondary);font-size:var(--text-lg);max-width:56ch;margin-inline:auto}.flex{display:flex}.flex-col{flex-direction:column}.flex-center{justify-content:center;align-items:center;display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.flex-wrap{flex-wrap:wrap}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.gap-12{gap:var(--space-12)}.grid{display:grid}.grid-2{gap:var(--space-6);grid-template-columns:repeat(2,1fr);display:grid}.grid-3{gap:var(--space-6);grid-template-columns:repeat(3,1fr);display:grid}.grid-4{gap:var(--space-6);grid-template-columns:repeat(4,1fr);display:grid}.grid-auto{gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}@media (width<=900px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.grid-2,.grid-3{grid-template-columns:1fr}.grid-4{grid-template-columns:repeat(2,1fr)}}@media (width<=420px){.grid-4{grid-template-columns:1fr}}.divider{background:linear-gradient(90deg, transparent 0%, var(--glass-border-hover) 30%, var(--glass-border-hover) 70%, transparent 100%);width:100%;height:1px;margin-block:var(--space-8)}.scroll-target{scroll-margin-top:80px}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.mb-12{margin-bottom:var(--space-12)}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-label{font-size:var(--text-sm);color:var(--color-text-secondary);font-weight:500}.form-input,.form-textarea,.form-select{width:100%;padding:var(--space-3) var(--space-4);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-body);font-size:var(--text-base);transition:border-color var(--dur-fast) var(--ease-smooth), box-shadow var(--dur-fast) var(--ease-smooth);outline:none}.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-dim)}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-muted)}.form-textarea{resize:vertical;min-height:140px}#main-nav{z-index:var(--z-nav);transition:background var(--dur-base) var(--ease-smooth), box-shadow var(--dur-base) var(--ease-smooth);position:fixed;top:0;left:0;right:0}#main-nav.scrolled{box-shadow:0 4px 30px #0006}.nav-inner{justify-content:space-between;align-items:center;gap:var(--space-6);height:72px;display:flex}.nav-logo{align-items:center;gap:var(--space-3);flex-shrink:0;display:flex}.nav-logo-name{font-family:var(--font-display);font-size:var(--text-xl);letter-spacing:-.02em;font-weight:700}.nav-logo-badge{display:none}@media (width>=768px){.nav-logo-badge{display:inline-flex}}.nav-links{align-items:center;gap:var(--space-1);list-style:none;display:flex}@media (width<=900px){.nav-links{display:none}}.nav-link{padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--color-text-secondary);transition:color var(--dur-fast) var(--ease-smooth), background var(--dur-fast) var(--ease-smooth);font-weight:500}.nav-link:hover,.nav-link.active{color:var(--color-text-primary);background:var(--glass-bg)}.nav-link.active{color:var(--color-accent)}.nav-actions{align-items:center;gap:var(--space-2);display:flex}.nav-theme-btn{border-radius:var(--radius-md);width:40px;height:40px;color:var(--color-text-secondary);transition:color var(--dur-fast), background var(--dur-fast);justify-content:center;align-items:center;display:flex}.nav-theme-btn:hover{color:var(--color-accent);background:var(--glass-bg)}.nav-cta{display:none}@media (width>=640px){.nav-cta{display:inline-flex}}.nav-hamburger{border-radius:var(--radius-sm);background:var(--glass-bg);border:1px solid var(--glass-border);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:40px;height:40px;display:none}@media (width<=900px){.nav-hamburger{display:flex}}.nav-hamburger span{background:var(--color-text-primary);width:20px;height:2px;transition:transform var(--dur-base) var(--ease-smooth), opacity var(--dur-base);border-radius:2px;display:block}.nav-hamburger.open span:first-child{transform:translateY(7px)rotate(45deg)}.nav-hamburger.open span:nth-child(2){opacity:0}.nav-hamburger.open span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.nav-mobile{background:var(--color-bg-overlay);-webkit-backdrop-filter:blur(24px);padding:var(--space-6);z-index:calc(var(--z-nav) - 1);transition:transform var(--dur-base) var(--ease-smooth);display:none;position:fixed;inset:72px 0 0;transform:translate(100%)}@media (width<=900px){.nav-mobile{display:block}}.nav-mobile.open{transform:translate(0)}.nav-mobile-links{gap:var(--space-2);flex-direction:column;display:flex}.nav-mobile-link{padding:var(--space-4);font-size:var(--text-lg);color:var(--color-text-secondary);border-radius:var(--radius-md);transition:color var(--dur-fast), background var(--dur-fast);font-weight:500;display:block}.nav-mobile-link:hover{color:var(--color-text-primary);background:var(--glass-bg)}.hero-section{align-items:center;min-height:100dvh;padding-top:72px;display:flex;position:relative;overflow:hidden}#hero-canvas{z-index:0;pointer-events:none;position:absolute;inset:0}.hero-content{z-index:1;gap:var(--space-16);padding-block:var(--space-24);grid-template-columns:1fr 1fr;align-items:center;display:grid;position:relative}@media (width<=900px){.hero-content{gap:var(--space-12);grid-template-columns:1fr}}.hero-badge{align-items:center;gap:var(--space-2);margin-bottom:var(--space-6);display:inline-flex}.hero-badge-dot{background:var(--color-accent);width:8px;height:8px;box-shadow:0 0 8px var(--color-accent);border-radius:50%;animation:2s ease-in-out infinite pulse-glow}.hero-headline{margin-bottom:var(--space-6);line-height:1.05}.hero-line-1,.hero-line-2{display:block}.hero-typed-line{font-size:var(--text-lg);margin-bottom:var(--space-5);min-height:1.7em}.hero-sub{color:var(--color-text-secondary);font-size:var(--text-lg);max-width:50ch;margin-bottom:var(--space-8);line-height:1.65}.hero-ctas{gap:var(--space-3);margin-bottom:var(--space-8);flex-wrap:wrap;display:flex}.hero-stats{gap:var(--space-3);flex-wrap:wrap;display:flex}.hero-code-block{font-family:var(--font-mono);font-size:var(--text-sm);padding:0;line-height:1.7;overflow:hidden}@media (width<=900px){.hero-code-block{display:none}}.hero-code-header{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--glass-border);background:#0003;display:flex}.hero-code-dot{border-radius:50%;width:12px;height:12px}.hero-code-filename{font-size:var(--text-xs);color:var(--color-text-muted);margin-left:auto}.hero-code-body{padding:var(--space-5);margin:0;overflow:auto}.hero-code-body code{display:block}.code-keyword{color:#c792ea}.code-var{color:#82aaff}.code-str{color:#c3e88d}.code-key{color:#f07178}.code-fn{color:#89ddff}.code-comment{color:#546e7a;font-style:italic}.hero-scroll-indicator{bottom:var(--space-8);color:var(--color-text-muted);z-index:1;position:absolute;left:50%;transform:translate(-50%)}.about-grid{gap:var(--space-20);grid-template-columns:1fr 1.2fr;align-items:start;display:grid}@media (width<=900px){.about-grid{grid-template-columns:1fr}}.about-visual{position:relative}.about-avatar-wrapper{aspect-ratio:1;max-width:340px;margin-bottom:var(--space-6);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.about-avatar-photo{object-fit:cover;object-position:center top;width:100%;height:100%;display:block}.about-avatar-badge{bottom:var(--space-4);right:var(--space-4);position:absolute}.about-stats{gap:var(--space-3);grid-template-columns:repeat(2,1fr);display:grid}.about-stat{padding:var(--space-4);text-align:center}.about-stat-value{font-size:var(--text-2xl);margin-bottom:var(--space-1);font-weight:700;display:block}.about-stat-label{font-size:var(--text-sm)}.about-text .section-label{margin-bottom:var(--space-3)}.about-text h2{margin-bottom:var(--space-6)}.about-para{color:var(--color-text-secondary);margin-bottom:var(--space-4);max-width:none;line-height:1.75}.about-para em{color:var(--color-accent);font-style:normal}.about-para strong{color:var(--color-text-primary)}.services-grid{gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(260px,1fr));display:grid}.service-card{padding:var(--space-6);gap:var(--space-3);flex-direction:column;display:flex}.service-icon{font-size:2rem;line-height:1}.service-title{font-size:var(--text-lg);font-weight:600}.service-desc{font-size:var(--text-sm);flex:1;line-height:1.65}.service-highlight{align-self:flex-start;margin-top:auto}.portfolio-grid{gap:var(--space-8);grid-template-columns:repeat(auto-fill,minmax(340px,1fr));display:grid}@media (width<=480px){.portfolio-grid{grid-template-columns:1fr}}.portfolio-card{cursor:default;flex-direction:column;padding:0;display:flex;overflow:hidden}.portfolio-card-header{padding:var(--space-8) var(--space-6) var(--space-6);background:linear-gradient(135deg, color-mix(in srgb, var(--proj-color,#00c2ff) 12%, transparent), transparent 60%);border-bottom:1px solid var(--glass-border);justify-content:space-between;align-items:flex-start;display:flex}.portfolio-icon{font-size:2.5rem;line-height:1}.portfolio-card-body{padding:var(--space-6);gap:var(--space-4);flex-direction:column;flex:1;display:flex}.portfolio-title{font-size:var(--text-xl);font-weight:700}.portfolio-pain-solution{gap:var(--space-3);flex-direction:column;display:flex}.portfolio-problem,.portfolio-solution{background:var(--color-bg-surface);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);line-height:1.6}.portfolio-problem{border-left:3px solid var(--color-error)}.portfolio-solution{border-left:3px solid var(--color-success)}.portfolio-problem-label,.portfolio-solution-label{align-items:center;gap:var(--space-1);font-weight:600;font-size:var(--text-xs);letter-spacing:.05em;text-transform:uppercase;margin-bottom:var(--space-2);color:var(--color-text-primary);display:flex}.portfolio-result{font-size:var(--text-sm);align-items:flex-start;gap:var(--space-2);flex-wrap:wrap;display:flex}.portfolio-tags{gap:var(--space-2);flex-wrap:wrap;margin-top:auto;display:flex}.tech-categories{gap:var(--space-12);flex-direction:column;display:flex}.tech-category-label{margin-bottom:var(--space-4)}.tech-grid{gap:var(--space-3);grid-template-columns:repeat(auto-fill,minmax(90px,1fr));display:grid}.tech-icon{width:40px;height:40px;margin:0 auto var(--space-2);transition:filter var(--dur-base)}.tech-card:hover .tech-icon{filter:drop-shadow(0 0 8px var(--tech-color,var(--color-accent)))}.tech-name{font-size:var(--text-xs);color:var(--color-text-secondary);text-align:center;font-weight:500;display:block}.testimonials-grid{gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));display:grid}.testimonial-card{padding:var(--space-6);gap:var(--space-4);flex-direction:column;display:flex}.testimonial-stars{gap:var(--space-1);display:flex}.testimonial-quote p{color:var(--color-text-secondary);font-size:var(--text-base);max-width:none;font-style:italic;line-height:1.75}.testimonial-footer{align-items:center;gap:var(--space-3);flex-wrap:wrap;margin-top:auto;display:flex}.testimonial-avatar{background:var(--color-bg-elevated);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex;overflow:hidden}.testimonial-initials{font-family:var(--font-display);font-size:var(--text-sm);color:var(--color-accent);font-weight:700}.testimonial-meta{flex:1}.testimonial-name{font-weight:600;font-size:var(--text-sm);display:block}.testimonial-role{font-size:var(--text-xs)}.testimonial-project{margin-left:auto}.downloads-grid{gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.download-card{padding:var(--space-5);gap:var(--space-4);flex-direction:column;display:flex}.download-thumb{border-radius:var(--radius-md);background:var(--color-bg-elevated);justify-content:center;align-items:center;width:80px;height:80px;display:flex;position:relative;overflow:hidden}.download-thumb img{object-fit:cover;width:100%;height:100%}.download-thumb-placeholder{font-size:2rem}.download-featured{position:absolute;top:-8px;right:-8px}.download-info{gap:var(--space-2);flex-direction:column;flex:1;display:flex}.download-name{font-size:var(--text-lg);font-weight:600}.download-meta{gap:var(--space-2);flex-wrap:wrap;display:flex}.download-desc{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.6}.download-date{font-size:var(--text-xs)}.download-btn{justify-content:center;width:100%;margin-top:auto}.downloads-loading{align-items:center;gap:var(--space-4);padding:var(--space-20);color:var(--color-text-muted);flex-direction:column;grid-column:1/-1;display:flex}.downloads-spinner{border:3px solid var(--glass-border);border-top-color:var(--color-accent);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.downloads-empty,.downloads-error{align-items:center;gap:var(--space-4);padding:var(--space-20);text-align:center;flex-direction:column;grid-column:1/-1;display:flex}.downloads-empty-icon{font-size:3rem}.contact-grid{gap:var(--space-20);grid-template-columns:1fr 1.3fr;align-items:start;display:grid}@media (width<=900px){.contact-grid{grid-template-columns:1fr}}.contact-headline{margin:var(--space-3) 0 var(--space-6)}.contact-sub{max-width:42ch;margin-bottom:var(--space-8)}.contact-notes{gap:var(--space-3);margin-bottom:var(--space-8);flex-direction:column;display:flex}.contact-note{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--color-text-secondary);display:flex}.contact-social{gap:var(--space-3);display:flex}.social-link{border-radius:var(--radius-md);width:44px;height:44px;color:var(--color-text-secondary);transition:color var(--dur-fast), transform var(--dur-fast) var(--ease-spring);justify-content:center;align-items:center;display:flex}.social-link:hover{color:var(--color-accent);transform:translateY(-3px)}.contact-form{padding:var(--space-8);gap:var(--space-5);flex-direction:column;display:flex}@media (width<=640px){.contact-form{padding:var(--space-5)}}.contact-submit{justify-content:center;width:100%}.contact-status{margin-top:var(--space-2)}.contact-success,.contact-error{align-items:flex-start;gap:var(--space-3);padding:var(--space-4);font-size:var(--text-sm);line-height:1.5;display:flex}.contact-success strong,.contact-error strong{margin-bottom:var(--space-1);display:block}#main-footer{background:var(--color-bg-surface);border-top:1px solid var(--glass-border);padding-block:var(--space-12) var(--space-8)}.footer-inner{gap:var(--space-8);flex-direction:column;display:flex}.footer-top{gap:var(--space-8);grid-template-columns:1.5fr 1fr auto;align-items:start;display:grid}@media (width<=768px){.footer-top{grid-template-columns:1fr 1fr}}@media (width<=480px){.footer-top{grid-template-columns:1fr}}.footer-logo{font-family:var(--font-display);font-size:var(--text-2xl);letter-spacing:-.02em;margin-bottom:var(--space-3);font-weight:700;display:block}.footer-tagline{max-width:36ch}.footer-nav ul{gap:var(--space-2);flex-direction:column;display:flex}.footer-link{font-size:var(--text-sm);color:var(--color-text-secondary);transition:color var(--dur-fast)}.footer-link:hover{color:var(--color-accent)}.footer-social{gap:var(--space-3);flex-wrap:wrap;align-items:flex-start;display:flex}.footer-bottom{justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.footer-lang-switcher{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.footer-lang-btn{font-size:var(--text-xs)}
