*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--font-sans:var(--font-inter,"Inter",system-ui,-apple-system,sans-serif);--font-mono:var(--font-mono-var,"JetBrains Mono","Fira Code",monospace);--bg:#0a0a0f;--bg-secondary:#0f0f1a;--bg-card:#12121f;--bg-glass:rgba(18,18,31,0.75);--border:rgba(255,255,255,0.07);--border-hover:rgba(99,102,241,0.4);--text-primary:#f1f1f6;--text-secondary:#8b8ba8;--text-muted:#5a5a7a;--accent:#6366f1;--accent-light:#818cf8;--accent-glow:rgba(99,102,241,0.15);--accent-2:#22d3ee;--accent-2-glow:rgba(34,211,238,0.1);--success:#34d399;--shadow-sm:0 1px 3px rgba(0,0,0,.4);--shadow-md:0 4px 24px rgba(0,0,0,.5);--shadow-lg:0 16px 48px rgba(0,0,0,.6);--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--radius-xl:28px;--transition:0.25s cubic-bezier(0.4,0,0.2,1)}[data-theme=light]{--bg:#f8f8ff;--bg-secondary:#f0f0fb;--bg-card:#ffffff;--bg-glass:rgba(255,255,255,0.85);--border:rgba(0,0,0,0.07);--border-hover:rgba(99,102,241,0.4);--text-primary:#0f0f1a;--text-secondary:#5a5a7a;--text-muted:#9090b0;--accent:#4f46e5;--accent-light:#6366f1;--accent-glow:rgba(99,102,241,0.1);--accent-2:#0891b2;--accent-2-glow:rgba(8,145,178,0.08);--success:#059669;--shadow-sm:0 1px 3px rgba(0,0,0,.08);--shadow-md:0 4px 24px rgba(0,0,0,.1);--shadow-lg:0 16px 48px rgba(0,0,0,.12)}html{scroll-behavior:smooth}body{font-family:var(--font-sans);background:var(--bg);color:var(--text-primary);line-height:1.6;overflow-x:hidden;transition:background var(--transition),color var(--transition)}::selection{background:var(--accent);color:#fff}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--accent);border-radius:2px}.container{max-width:1160px;margin:0 auto}section{padding:clamp(5rem,10vw,8rem) clamp(1.5rem,5vw,4rem)}.section-label{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:.75rem;font-weight:500;color:var(--accent);letter-spacing:.12em;text-transform:uppercase;margin-bottom:1rem}.section-label:before{content:"";width:24px;height:1px;background:var(--accent)}.section-title{font-size:clamp(1.75rem,4vw,2.75rem);font-weight:800;letter-spacing:-.04em;line-height:1.15;color:var(--text-primary)}.section-desc{font-size:1.0625rem;color:var(--text-secondary);max-width:52ch;margin-top:.75rem;line-height:1.7}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.55rem 1.25rem;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;cursor:pointer;text-decoration:none;transition:all var(--transition);border:none;letter-spacing:.01em;font-family:var(--font-sans)}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-light);transform:translateY(-1px);box-shadow:0 8px 24px var(--accent-glow)}.btn-outline{background:transparent;color:var(--text-primary);border:1px solid var(--border)}.btn-outline:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}.btn-lg{padding:.85rem 2rem;font-size:1rem;border-radius:var(--radius-md)}.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s cubic-bezier(.4,0,.2,1),transform .6s cubic-bezier(.4,0,.2,1)}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}.reveal-delay-4{transition-delay:.4s}.reveal-delay-5{transition-delay:.5s}@keyframes float{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-24px) scale(1.03)}}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.5)}}.nav{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(1.5rem,5vw,4rem);height:64px;background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);transition:background var(--transition),border-color var(--transition)}.nav-logo{font-weight:800;font-size:1.15rem;letter-spacing:-.5px;color:var(--text-primary);text-decoration:none}.nav-logo span{color:var(--accent)}.nav-links{display:flex;align-items:center;gap:2rem;list-style:none}.nav-links a{font-size:.875rem;font-weight:500;color:var(--text-secondary);text-decoration:none;transition:color var(--transition)}.nav-links a.active,.nav-links a:hover{color:var(--text-primary)}.nav-actions{gap:.75rem}.nav-actions,.theme-toggle{display:flex;align-items:center}.theme-toggle{width:38px;height:38px;border-radius:50%;border:1px solid var(--border);background:transparent;color:var(--text-secondary);cursor:pointer;justify-content:center;transition:all var(--transition);font-size:1rem}.theme-toggle:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none}.hamburger span{width:22px;height:2px;background:var(--text-primary);border-radius:2px;transition:all var(--transition);display:block}.hamburger.open span:first-child{transform:rotate(45deg) translate(5px,5px)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.mobile-nav{display:none;position:fixed;top:64px;left:0;right:0;background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);z-index:999;padding:1.5rem clamp(1.5rem,5vw,4rem);flex-direction:column;gap:0}.mobile-nav.open{display:flex}.mobile-nav a{font-size:1rem;font-weight:500;color:var(--text-secondary);text-decoration:none;padding:.75rem 0;border-bottom:1px solid var(--border);transition:color var(--transition)}.mobile-nav a:last-child{border-bottom:none}.mobile-nav a:hover{color:var(--accent)}.hero{min-height:100dvh;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden;padding-top:64px;padding-inline:clamp(1.5rem,5vw,4rem)}.hero-bg{pointer-events:none;overflow:hidden}.hero-bg,.hero-grid{position:absolute;inset:0}.hero-grid{background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:60px 60px;-webkit-mask-image:radial-gradient(ellipse at 60% 40%,black 30%,transparent 70%);mask-image:radial-gradient(ellipse at 60% 40%,black 30%,transparent 70%)}.hero-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.22}.hero-orb-1{width:600px;height:600px;background:var(--accent);top:-100px;right:-100px;animation:float 8s ease-in-out infinite}.hero-orb-2{width:400px;height:400px;background:var(--accent-2);bottom:0;left:-80px;animation:float 11s ease-in-out infinite reverse}.hero-content{position:relative;z-index:1;max-width:1160px;margin:0 auto;width:100%}.hero-inner{display:grid;grid-template-columns:1fr 420px;grid-gap:4rem;gap:4rem;align-items:center}.hero-text{display:flex;flex-direction:column}.hero-location-row{display:flex;align-items:center;gap:.625rem;flex-wrap:wrap;margin-bottom:2rem}.hero-loc-chip{display:inline-flex;align-items:center;gap:.375rem;font-size:.8125rem;font-weight:500;color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border);border-radius:100px;padding:.3rem .75rem}.hero-scroll-indicator{bottom:2.5rem;gap:.5rem}.scroll-dot{width:24px;height:40px;border:2px solid var(--border);border-radius:100px;position:relative;display:flex;justify-content:center;padding-top:6px}.scroll-dot:after{content:"";width:4px;height:8px;background:var(--accent);border-radius:2px;animation:scroll-dot-anim 2s ease infinite}@keyframes scroll-dot-anim{0%{transform:translateY(0);opacity:1}80%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:0}}.hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.35rem .875rem;background:var(--accent-glow);border:1px solid var(--border-hover);border-radius:100px;font-size:.8125rem;font-weight:500;color:var(--accent-light);margin-bottom:1.75rem}.hero-badge .dot{width:7px;height:7px;background:var(--success);border-radius:50%;animation:pulse-dot 2s infinite}.hero-title{font-size:clamp(1.75rem,3.5vw,3rem);font-weight:800;letter-spacing:-.04em;line-height:1.15;margin-bottom:1.25rem}.hero-title .line-accent{display:inline-block;font-size:clamp(1.1rem,2vw,1.5rem);font-weight:600;line-height:1.4;letter-spacing:0;-webkit-margin-before:.6rem;margin-block-start:.6rem;background:linear-gradient(135deg,var(--accent) 0,var(--accent-2) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-sub{font-size:clamp(1rem,2vw,1.25rem);color:var(--text-secondary);max-width:58ch;line-height:1.7;margin-bottom:2.5rem}.hero-sub strong{color:var(--text-primary);font-weight:600}.hero-actions{align-items:center;gap:1rem;margin-bottom:4rem}.hero-actions,.hero-stats{display:flex;flex-wrap:wrap}.hero-stats{gap:2.5rem;align-items:flex-start}.stat{display:flex;flex-direction:column}.stat-value{font-size:1.875rem;font-weight:800;letter-spacing:-.04em;color:var(--text-primary)}.stat-label{font-size:.8125rem;color:var(--text-muted);font-weight:500}.stat-divider{width:1px;background:var(--border);align-self:stretch;min-height:40px}.about{background:var(--bg-secondary)}.about-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:5rem;gap:5rem;align-items:center;max-width:1160px;margin:0 auto}.about-card,.about-visual{position:relative}.about-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:2.5rem;overflow:hidden}.about-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent-2))}.about-avatar{width:80px;height:80px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;font-size:1.75rem;font-weight:800;color:#fff;margin-bottom:1.5rem;letter-spacing:-.02em;-webkit-user-select:none;-moz-user-select:none;user-select:none}.about-name{font-size:1.25rem;font-weight:700;margin-bottom:.25rem}.about-role{font-size:.875rem;color:var(--accent);font-weight:500;font-family:var(--font-mono);margin-bottom:1.5rem}.about-details{display:flex;flex-direction:column;gap:.75rem}.about-detail{gap:.75rem;color:var(--text-secondary)}.about-detail,.about-detail .icon{display:flex;align-items:center;font-size:.875rem}.about-detail .icon{width:32px;height:32px;border-radius:8px;background:var(--bg-secondary);justify-content:center;flex-shrink:0}.floating-chip{position:absolute;background:var(--bg-card);border:1px solid var(--border);border-radius:100px;padding:.4rem .875rem;font-size:.75rem;font-weight:600;color:var(--text-secondary);display:flex;align-items:center;gap:.4rem;box-shadow:var(--shadow-md);white-space:nowrap}.chip-1{top:-18px;right:20px;animation:float 5s ease-in-out 0s infinite}.chip-2{bottom:20px;left:-30px;animation:float 5s ease-in-out 1.5s infinite}.chip-3{top:45%;right:-30px;animation:float 5s ease-in-out 3s infinite}.about-text p{color:var(--text-secondary);line-height:1.8;font-size:1.0625rem;margin-bottom:1.25rem}.about-text p:last-child{margin-bottom:0}.about-text strong{color:var(--text-primary);font-weight:600}.about-pillars{display:grid;grid-template-columns:1fr 1fr;grid-gap:.75rem;gap:.75rem;margin-top:2rem}.pillar{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:1rem;transition:all var(--transition)}.pillar:hover{border-color:var(--border-hover);background:var(--accent-glow)}.pillar-icon{font-size:1.25rem;margin-bottom:.4rem}.pillar-title{font-size:.8125rem;font-weight:700;color:var(--text-primary);margin-bottom:.2rem}.pillar-desc{font-size:.75rem;color:var(--text-muted)}.projects{background:var(--bg)}.projects-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3.5rem;max-width:1160px;margin-inline:auto}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr));grid-gap:1.5rem;gap:1.5rem;max-width:1160px;margin:0 auto}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:0;display:flex;flex-direction:column;transition:all var(--transition);position:relative;overflow:hidden}.project-card:hover{border-color:var(--border-hover);transform:translateY(-6px);box-shadow:0 24px 64px rgba(0,0,0,.55)}.project-card.featured{grid-column:span 2;flex-direction:column}.project-meta{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;flex-wrap:wrap}.project-tag{font-size:.6875rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:.2rem .6rem;border-radius:100px;background:var(--accent-glow);color:var(--accent-light);border:1px solid rgba(99,102,241,.2)}.project-tag.cyan{background:var(--accent-2-glow);color:var(--accent-2);border-color:rgba(34,211,238,.2)}.project-tag.green{background:rgba(52,211,153,.1);color:var(--success);border-color:rgba(52,211,153,.2)}.project-tag.amber{background:rgba(217,119,6,.1);color:#f59e0b;border-color:rgba(245,158,11,.2)}.project-tag.pink{background:rgba(190,24,93,.1);color:#ec4899;border-color:rgba(236,72,153,.2)}.project-name{font-size:1.25rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.625rem}.project-desc{font-size:.9375rem;color:var(--text-secondary);line-height:1.65;flex:1 1}.project-desc strong{color:var(--text-primary);font-weight:600}.project-footer{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:1rem}.project-impact{font-size:.8125rem;color:var(--text-muted);display:flex;align-items:center;gap:.4rem;flex:1 1;min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.project-impact strong{color:var(--text-secondary)}.project-stack{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.875rem}.stack-chip{font-family:var(--font-mono);font-size:.6875rem;color:var(--text-muted);background:var(--bg-secondary);border:1px solid var(--border);padding:.2rem .55rem;border-radius:4px}.project-body{flex:1 1;padding:1.75rem}.project-year{font-family:var(--font-mono);font-size:.6875rem;color:var(--text-muted);-webkit-margin-start:auto;margin-inline-start:auto}.case-study-link{display:inline-flex;align-items:center;gap:.35rem;font-size:.8125rem;font-weight:700;color:var(--accent);text-decoration:none;white-space:nowrap;flex-shrink:0;transition:all var(--transition)}.case-study-link:hover{gap:.6rem}.skills{background:var(--bg-secondary)}.skills-container{max-width:1160px;margin:0 auto}.skills-header{margin-bottom:3.5rem}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));grid-gap:1.5rem;gap:1.5rem}.skill-group{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.75rem;transition:all var(--transition)}.skill-group:hover{border-color:var(--border-hover)}.skill-group-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem}.skill-group-icon{width:40px;height:40px;border-radius:var(--radius-sm);background:var(--accent-glow);border:1px solid var(--border-hover);display:flex;align-items:center;justify-content:center;font-size:1.125rem;flex-shrink:0}.skill-group-name{font-size:.9375rem;font-weight:700;letter-spacing:-.01em}.skill-tags{display:flex;flex-wrap:wrap;gap:.5rem}.skill-tag{font-size:.8125rem;font-weight:500;padding:.35rem .75rem;border-radius:var(--radius-sm);background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-secondary);transition:all var(--transition)}.skill-group:hover .skill-tag{border-color:rgba(99,102,241,.2);color:var(--text-primary)}.experience{background:var(--bg)}.exp-container{max-width:1160px;margin:0 auto}.exp-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:5rem;gap:5rem;margin-top:4rem}.lifecycle-stages{display:flex;flex-direction:column;gap:0}.stage{display:flex;gap:1.5rem;position:relative}.stage-line{flex-direction:column}.stage-dot,.stage-line{display:flex;align-items:center;flex-shrink:0}.stage-dot{width:36px;height:36px;border-radius:50%;background:var(--accent-glow);border:2px solid var(--accent);justify-content:center;font-size:.875rem;position:relative;z-index:1;transition:all var(--transition)}.stage:hover .stage-dot{background:var(--accent);box-shadow:0 0 20px var(--accent-glow)}.stage-connector{width:2px;flex:1 1;background:linear-gradient(180deg,var(--accent) 0,transparent 100%);min-height:40px;opacity:.3}.stage:last-child .stage-connector{display:none}.stage-content{padding-bottom:2.5rem;flex:1 1}.stage:last-child .stage-content{padding-bottom:0}.stage-title{font-size:1.0625rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.375rem}.stage-desc{font-size:.9rem;color:var(--text-secondary);line-height:1.7}.exp-highlights{display:flex;flex-direction:column;gap:1rem}.highlight-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.5rem;display:flex;gap:1rem;align-items:flex-start;transition:all var(--transition)}.highlight-card:hover{border-color:var(--border-hover);transform:translateX(4px)}.highlight-icon{font-size:1.5rem;flex-shrink:0}.highlight-title{font-size:.9375rem;font-weight:700;margin-bottom:.25rem}.highlight-desc{font-size:.875rem;color:var(--text-secondary);line-height:1.6}.contact{background:var(--bg-secondary);text-align:center}.contact-container{max-width:680px;margin:0 auto}.contact-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:clamp(2.5rem,6vw,4rem);margin-top:3rem;position:relative;overflow:hidden}.contact-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent-2))}.contact-card-title{font-size:clamp(1.5rem,3vw,2rem);font-weight:800;letter-spacing:-.04em;margin-bottom:.75rem}.contact-card-desc{font-size:1rem;color:var(--text-secondary);line-height:1.7;margin-bottom:2.5rem}.contact-actions{gap:1rem;margin-bottom:2.5rem}.contact-actions,.contact-links{display:flex;justify-content:center;flex-wrap:wrap}.contact-links{gap:.75rem}.contact-link{display:flex;align-items:center;gap:.5rem;padding:.55rem 1rem;border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text-secondary);text-decoration:none;font-size:.875rem;font-weight:500;transition:all var(--transition)}.contact-link:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}.footer{background:var(--bg);border-top:1px solid var(--border);padding:2rem clamp(1.5rem,5vw,4rem);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}.footer-copy{font-size:.8125rem;color:var(--text-muted)}.footer-back-top{font-size:.8125rem;font-weight:600;color:var(--text-secondary);text-decoration:none;display:flex;align-items:center;gap:.375rem;transition:color var(--transition)}.footer-back-top:hover{color:var(--accent)}@media (max-width:1100px){.hero-inner{grid-template-columns:1fr 360px;gap:3rem}}@media (max-width:900px){.nav-links{display:none}.hamburger{display:flex}.hero{min-height:auto;padding-block:6rem 3rem}.hero-inner{grid-template-columns:1fr;gap:2rem}.hero-text{align-items:center;text-align:center}.hero-sub,.hero-title{max-width:100%}.hero-actions,.hero-location-row,.hero-photo-col,.hero-stats{justify-content:center}.hero-photo-col{display:flex;order:-1;align-self:center;width:100%;-webkit-padding-before:0;padding-block-start:0}.hero-photo-wrap{width:240px;height:240px;margin:0 auto}.hero-photo-ring{border-radius:50%;padding:3px}.hero-photo-scene{width:100%;height:100%}.hero-code-card,.photo-badge{display:none}.about-grid{grid-template-columns:1fr;gap:3rem}.about-visual{order:-1}.chip-2{left:0}.chip-3{right:0}.project-card.featured{grid-column:span 1}.exp-grid{gap:3rem}.cs-two-col,.exp-grid{grid-template-columns:1fr}.cs-features-grid{grid-template-columns:1fr 1fr}}@media (max-width:640px){.projects-header{flex-direction:column;align-items:flex-start;gap:1rem}.projects-grid{grid-template-columns:1fr}.project-card.featured{grid-column:span 1}.hero-stats{gap:1.5rem}.stat-divider{display:none}.about-pillars,.cs-features-grid,.skills-grid{grid-template-columns:1fr}.cs-meta-row{flex-direction:column;gap:1rem}.cs-meta-divider{display:none}.cs-hero-content{padding:2rem 1.5rem}.pm-sidebar{display:none}}@keyframes gradient-border{0%,to{background-position:0 50%}50%{background-position:100% 50%}}.hero-photo-col{display:flex;justify-content:center;align-self:start;-webkit-padding-before:3rem;padding-block-start:3rem}.hero-photo-wrap{position:relative;width:360px;height:420px;flex-shrink:0}.hero-photo-ring{width:100%;height:100%;border-radius:var(--radius-xl);padding:3px;background:linear-gradient(135deg,var(--accent),var(--accent-2),#7c3aed,var(--accent));background-size:300% 300%;animation:gradient-border 5s ease infinite;box-shadow:0 0 60px rgba(99,102,241,.25),0 0 120px rgba(34,211,238,.1)}.hero-photo-avatar{width:100%;height:100%;border-radius:calc(var(--radius-xl) - 3px);background:linear-gradient(145deg,#1a1a2e,#16213e 40%,#0f3460);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.avatar-pattern{position:absolute;inset:0;background-image:radial-gradient(circle at 30% 20%,rgba(99,102,241,.15) 0,transparent 50%),radial-gradient(circle at 70% 80%,rgba(34,211,238,.1) 0,transparent 50%);background-size:120px 120px,100px 100px}.avatar-initials{font-size:6rem;font-weight:900;letter-spacing:-.05em;background:linear-gradient(135deg,#fff 0,var(--accent-light) 50%,var(--accent-2) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative;z-index:1;text-shadow:none}.photo-badge{position:absolute;background:var(--bg-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:100px;padding:.45rem 1rem;font-size:.8rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:.4rem;box-shadow:var(--shadow-md);white-space:nowrap}.photo-badge-1{top:-16px;left:50%;transform:translateX(-50%);animation:float 5s ease-in-out 0s infinite}.photo-badge-2{right:-20px;top:25%;animation:float 5s ease-in-out 1s infinite}.photo-badge-3{bottom:60px;left:-24px;animation:float 5s ease-in-out 2s infinite}.photo-badge-4{bottom:-16px;right:20%;animation:float 5s ease-in-out 3s infinite}.project-mockup-wrap{width:100%;height:260px;border-radius:var(--radius-lg) var(--radius-lg) 0 0;overflow:hidden;position:relative;flex-shrink:0}.project-card.featured .project-mockup-wrap{height:300px}.pm-screen{width:100%;height:100%;display:flex;flex-direction:column}.pm-topbar{display:flex;align-items:center;gap:.625rem;padding:.5rem .875rem;background:rgba(0,0,0,.35);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);flex-shrink:0}.pm-dots{display:flex;gap:.3rem}.pm-dots span{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.2)}.pm-dots span:first-child{background:#ff5f57}.pm-dots span:nth-child(2){background:#febc2e}.pm-dots span:nth-child(3){background:#28c840}.pm-bar-title{font-size:.7rem;font-weight:500;color:rgba(255,255,255,.5);flex:1 1;font-family:var(--font-mono)}.pm-bar-status{font-size:.65rem;color:rgba(255,255,255,.5);display:flex;align-items:center;gap:.3rem}.pm-online-dot{width:6px;height:6px;border-radius:50%;background:#28c840;display:inline-block;animation:pulse-dot 2s infinite}.pm-body{flex:1 1;display:flex;overflow:hidden;gap:0}.pm-body-col{flex-direction:column;padding:.75rem;gap:.625rem}.pm-sidebar{width:120px;background:rgba(0,0,0,.25);padding:.625rem .5rem;display:flex;flex-direction:column;gap:.25rem;flex-shrink:0}.pm-nav-item{font-size:.65rem;color:rgba(255,255,255,.4);padding:.35rem .5rem;border-radius:6px;font-weight:500;cursor:default}.pm-nav-item.active{background:rgba(255,255,255,.12);color:rgba(255,255,255,.9)}.pm-main{flex:1 1;padding:.75rem;display:flex;flex-direction:column;gap:.625rem;overflow:hidden}.pm-stats-row{display:flex;gap:.5rem}.pm-stat-card{flex:1 1;background:rgba(255,255,255,.08);border-radius:8px;padding:.5rem}.pm-stat-num{font-size:1rem;font-weight:800;color:rgba(255,255,255,.9);line-height:1.1}.pm-stat-lbl{font-size:.55rem;color:rgba(255,255,255,.4);margin-top:.1rem;font-weight:500}.pm-list{display:flex;flex-direction:column;gap:.25rem}.pm-list-item{font-size:.65rem;color:rgba(255,255,255,.65);background:rgba(255,255,255,.06);border-radius:6px;padding:.35rem .5rem;display:flex;align-items:center;gap:.4rem}.pm-badge{font-size:.55rem;font-weight:700;padding:.15rem .4rem;border-radius:3px}.pm-badge.green{background:rgba(40,200,64,.25);color:#28c840}.pm-badge.blue{background:rgba(99,102,241,.25);color:#818cf8}.pm-badge.orange{background:rgba(251,146,60,.25);color:#fb923c}.pm-bar-chart{display:flex;align-items:flex-end;gap:4px;height:55px;flex:1 1}.pm-bar{flex:1 1;background:rgba(255,255,255,.2);border-radius:3px 3px 0 0;transition:height .3s}.pm-bar:last-child{background:rgba(255,255,255,.5)}.pm-chart-label{font-size:.6rem;color:rgba(255,255,255,.45);font-weight:500}.pm-employee-grid{display:flex;gap:.4rem;flex-wrap:wrap}.pm-emp-avatar{width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.15);font-size:.55rem;font-weight:700;color:rgba(255,255,255,.8);justify-content:center}.pm-emp-avatar,.pm-payroll-bar{display:flex;align-items:center}.pm-payroll-bar{justify-content:space-between;background:rgba(255,255,255,.06);border-radius:8px;padding:.5rem .625rem}.pm-payroll-label{font-size:.65rem;color:rgba(255,255,255,.55);font-weight:500}.pm-search-bar{background:rgba(255,255,255,.1);border-radius:8px;padding:.4rem .625rem;font-size:.65rem;color:rgba(255,255,255,.4)}.pm-product-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:.4rem;gap:.4rem;flex:1 1}.pm-product-card{background:rgba(255,255,255,.08);border-radius:8px;padding:.4rem}.pm-product-img{font-size:1.1rem;margin-bottom:.15rem}.pm-product-name{font-size:.6rem;font-weight:700;color:rgba(255,255,255,.8)}.pm-product-ex{font-size:.55rem;color:rgba(255,255,255,.4)}.pm-match-row{font-size:.65rem;color:rgba(255,255,255,.6);background:rgba(255,255,255,.07);border-radius:8px;padding:.4rem .625rem;display:flex;align-items:center;gap:.4rem}.pm-pipeline{gap:.5rem}.pm-pipeline,.pm-pipeline-col{display:flex;flex:1 1;overflow:hidden}.pm-pipeline-col{flex-direction:column;gap:.3rem}.pm-pipeline-header{font-size:.6rem;font-weight:700;color:rgba(255,255,255,.5);display:flex;align-items:center;justify-content:space-between;padding:0 .25rem}.pm-pipeline-header span{background:rgba(255,255,255,.15);border-radius:100px;width:16px;height:16px;display:flex;align-items:center;justify-content:center;font-size:.55rem}.pm-deal-card{background:rgba(255,255,255,.08);border-radius:6px;padding:.4rem .5rem}.pm-deal-card.active{background:rgba(99,102,241,.25);border:1px solid rgba(99,102,241,.4)}.pm-deal-card.won{background:rgba(40,200,64,.15);border:1px solid rgba(40,200,64,.3)}.pm-deal-name{font-size:.6rem;font-weight:600;color:rgba(255,255,255,.8)}.pm-deal-val{font-size:.55rem;color:rgba(255,255,255,.45);margin-top:.1rem}.pm-pipeline-total{font-size:.65rem;color:rgba(255,255,255,.5);padding:.25rem 0}.pm-pipeline-total strong{color:rgba(255,255,255,.85)}.cs-main{padding-top:64px;min-height:100dvh}.cs-hero{position:relative;padding:clamp(4rem,8vw,7rem) clamp(1.5rem,5vw,4rem) clamp(3rem,6vw,5rem);overflow:hidden}.cs-hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.1),rgba(0,0,0,.5))}.cs-hero-content{position:relative;z-index:1}.cs-back{display:inline-flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:rgba(255,255,255,.7);text-decoration:none;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:100px;padding:.4rem 1rem;margin-bottom:2.5rem;transition:all var(--transition);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.cs-back:hover{color:#fff;background:rgba(255,255,255,.2)}.cs-hero-icon{font-size:3.5rem;margin-bottom:1.25rem;filter:drop-shadow(0 4px 24px rgba(0,0,0,.4))}.cs-hero-tags{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.cs-hero-tag{font-size:.6875rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:.25rem .75rem;border-radius:100px;background:rgba(255,255,255,.15);color:rgba(255,255,255,.9);border:1px solid rgba(255,255,255,.25);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.cs-hero-title{font-size:clamp(2rem,5vw,3.5rem);font-weight:900;letter-spacing:-.04em;color:#fff;line-height:1.1;margin-bottom:.75rem}.cs-hero-tagline{font-size:clamp(1rem,2vw,1.2rem);color:rgba(255,255,255,.7);max-width:60ch;line-height:1.6;margin-bottom:2.5rem}.cs-meta-row{display:flex;align-items:center;gap:2rem;flex-wrap:wrap}.cs-meta-item{display:flex;flex-direction:column;gap:.2rem}.cs-meta-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.4);font-weight:600}.cs-meta-value{font-size:.9375rem;font-weight:700;color:rgba(255,255,255,.9)}.cs-meta-divider{width:1px;height:40px;background:rgba(255,255,255,.2)}.cs-body{padding:clamp(3rem,6vw,5rem) clamp(1.5rem,5vw,4rem);display:flex;flex-direction:column;gap:5rem}.cs-section-label{font-family:var(--font-mono);font-size:.75rem;font-weight:500;color:var(--accent);letter-spacing:.12em;text-transform:uppercase;margin-bottom:.625rem;display:flex;align-items:center;gap:.5rem}.cs-section-label:before{content:"";width:20px;height:1px;background:var(--accent)}.cs-section-title{font-size:clamp(1.5rem,3vw,2rem);font-weight:800;letter-spacing:-.04em;margin-bottom:1.5rem}.cs-prose{font-size:1.0625rem;color:var(--text-secondary);line-height:1.8;max-width:72ch}.cs-two-col{display:grid;grid-template-columns:1fr 1fr;grid-gap:1.5rem;gap:1.5rem}.cs-col-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2.5rem}.cs-col-icon{font-size:2rem;margin-bottom:1rem}.cs-col-title{font-size:1.25rem;font-weight:800;letter-spacing:-.03em;margin-bottom:1rem}.cs-challenge{border-top:3px solid rgba(251,146,60,.6)}.cs-solution{border-top:3px solid rgba(52,211,153,.6)}.cs-features-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:1.25rem;gap:1.25rem}.cs-feature-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.5rem;transition:all var(--transition)}.cs-feature-card:hover{border-color:var(--border-hover);transform:translateY(-2px)}.cs-feature-icon{font-size:1.5rem;margin-bottom:.75rem}.cs-feature-title{font-size:.9375rem;font-weight:700;margin-bottom:.375rem}.cs-feature-desc{font-size:.875rem;color:var(--text-secondary);line-height:1.6}.cs-stack-grid{display:flex;gap:.75rem;flex-wrap:wrap}.cs-stack-pill{display:flex;align-items:center;gap:.5rem;padding:.5rem 1.125rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.9375rem;font-weight:600;color:var(--text-primary)}.cs-stack-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.cs-impact-section{border:1px solid var(--border);border-radius:var(--radius-lg);padding:3rem}.cs-impact-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:1rem;gap:1rem;margin-top:0}.cs-impact-item{display:flex;align-items:flex-start;gap:.875rem;font-size:1rem;color:var(--text-secondary);line-height:1.6;padding:1rem;background:var(--bg-card);border-radius:var(--radius-sm);border:1px solid var(--border)}.cs-impact-check{font-size:1.1rem;font-weight:900;flex-shrink:0;margin-top:.1rem}.cs-cta-section{text-align:center;padding:4rem;background:var(--bg-secondary);border-radius:var(--radius-xl);border:1px solid var(--border)}.cs-cta-title{font-size:clamp(1.5rem,3vw,2rem);font-weight:800;letter-spacing:-.04em;margin-bottom:.75rem}.cs-cta-desc{font-size:1rem;color:var(--text-secondary);max-width:50ch;margin:0 auto 2rem;line-height:1.7}.cs-cta-actions{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.cs-next-project{padding-bottom:2rem}.cs-next-label{font-family:var(--font-mono);font-size:.75rem;font-weight:500;color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;display:block;margin-bottom:1rem}.cs-next-card{display:flex;align-items:center;gap:1.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem 2rem;text-decoration:none;color:inherit;transition:all var(--transition)}.cs-next-card:hover{border-color:var(--border-hover);transform:translateX(4px);box-shadow:var(--shadow-md)}.cs-next-icon{width:56px;height:56px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.cs-next-info{flex:1 1}.cs-next-name{font-size:1.0625rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.25rem}.cs-next-tagline{font-size:.875rem;color:var(--text-secondary);line-height:1.5}.cs-next-arrow{color:var(--text-muted);flex-shrink:0;transition:transform var(--transition)}.cs-next-card:hover .cs-next-arrow{transform:translateX(4px);color:var(--accent)}.tilt-wrap{position:relative;transform-style:preserve-3d;will-change:transform}.tilt-gloss{inset:0;border-radius:inherit;z-index:2;transition:background .1s linear}.hero-floor-grid,.tilt-gloss{position:absolute;pointer-events:none}.hero-floor-grid{bottom:0;left:50%;transform:translateX(-50%) perspective(600px) rotateX(55deg);transform-origin:bottom center;width:180%;height:60%;background-image:linear-gradient(rgba(99,102,241,.12) 1px,transparent 0),linear-gradient(90deg,rgba(99,102,241,.12) 1px,transparent 0);background-size:60px 60px;-webkit-mask-image:linear-gradient(180deg,transparent,rgba(0,0,0,.6) 40%,black);mask-image:linear-gradient(180deg,transparent,rgba(0,0,0,.6) 40%,black)}.hero-noise{position:absolute;inset:0;pointer-events:none;z-index:0;opacity:.025;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:128px}.hero-photo-scene{position:relative;width:100%;height:100%}.hero-code-card{position:absolute;bottom:-24px;inset-inline-start:-20px;background:rgba(12,12,24,.9);border:1px solid rgba(99,102,241,.3);border-radius:var(--radius-md);padding:.875rem 1rem;min-width:240px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 24px 48px rgba(0,0,0,.5),0 0 0 1px rgba(99,102,241,.1);animation:float 7s ease-in-out 2s infinite;transform:translateZ(30px)}[data-theme=light] .hero-code-card{background:rgba(255,255,255,.92);border-color:rgba(99,102,241,.2)}.hcc-dot{width:8px;height:8px;border-radius:50%;display:inline-block;-webkit-margin-end:4px;margin-inline-end:4px}.hcc-dot.green{background:#28c840}.hcc-dot.amber{background:#febc2e}.hcc-dot.red{background:#ff5f57}.hcc-line{font-family:var(--font-mono);font-size:.72rem;margin-top:.5rem;line-height:1.5}.hcc-kw{color:#c084fc}.hcc-var{color:#67e8f9}.hcc-op{color:#818cf8}.hcc-str{color:#86efac}.hcc-fn{color:#fbbf24}[data-theme=light] .hcc-kw{color:#7c3aed}[data-theme=light] .hcc-var{color:#0891b2}[data-theme=light] .hcc-str{color:#16a34a}[data-theme=light] .hcc-fn{color:#d97706}.avatar-dots{position:absolute;inset:0;border-radius:inherit;display:grid;grid-template-columns:repeat(5,1fr);grid-gap:20px;gap:20px;padding:24px;align-content:center;justify-content:center;opacity:.15}.avatar-dots span{width:6px;height:6px;border-radius:50%;background:#fff;display:block}.hero-orb-3{width:300px;height:300px;background:radial-gradient(circle,#7c3aed,transparent);position:absolute;top:60%;right:30%;filter:blur(60px);opacity:.15;animation:float 13s ease-in-out 1s infinite}.btn-glow{background:linear-gradient(135deg,var(--accent) 0,#7c3aed 100%);box-shadow:0 0 0 0 rgba(99,102,241,0);transition:all var(--transition),box-shadow .3s ease}.btn-glow:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(99,102,241,.45),0 0 0 4px rgba(99,102,241,.1)}.btn-glass{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);color:var(--text-primary);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all var(--transition)}.btn-glass:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.22);transform:translateY(-2px)}[data-theme=light] .btn-glass{background:rgba(0,0,0,.04);border-color:rgba(0,0,0,.1);color:var(--text-primary)}[data-theme=light] .btn-glass:hover{background:rgba(0,0,0,.08);border-color:rgba(99,102,241,.3)}.about,.projects,.skills{position:relative}.project-card{box-shadow:0 2px 8px rgba(0,0,0,.3),0 1px 2px rgba(0,0,0,.2)}.project-card:hover{box-shadow:0 30px 60px rgba(0,0,0,.5),0 10px 20px rgba(0,0,0,.3),0 0 0 1px var(--border-hover),inset 0 1px 0 rgba(255,255,255,.05)}[data-theme=light] .project-card:hover{box-shadow:0 30px 60px rgba(0,0,0,.12),0 10px 20px rgba(0,0,0,.06),0 0 0 1px rgba(99,102,241,.3)}.project-mockup-wrap{transform:translateZ(0);transition:transform .3s ease}.tilt-wrap:hover .project-mockup-wrap{transform:translateZ(16px) scale(1.01)}.skill-group{transform-style:preserve-3d;transition:transform .3s ease,border-color var(--transition),box-shadow .3s ease}.skill-group:hover{transform:translateY(-6px) perspective(600px) rotateX(3deg);box-shadow:0 20px 40px rgba(0,0,0,.3),0 0 0 1px var(--border-hover)}[data-theme=light] .skill-group:hover{box-shadow:0 16px 32px rgba(0,0,0,.08),0 0 0 1px rgba(99,102,241,.3)}.highlight-card{transform-style:preserve-3d}.highlight-card:hover{transform:translateX(6px) translateZ(8px);box-shadow:-4px 12px 32px rgba(0,0,0,.3)}.hero-badge{box-shadow:0 0 0 1px rgba(99,102,241,.2),0 4px 16px rgba(99,102,241,.1);animation:badge-glow 3s ease-in-out infinite}@keyframes badge-glow{0%,to{box-shadow:0 0 0 1px rgba(99,102,241,.2),0 4px 16px rgba(99,102,241,.1)}50%{box-shadow:0 0 0 1px rgba(99,102,241,.4),0 4px 24px rgba(99,102,241,.25)}}.stat-value{background:linear-gradient(135deg,var(--text-primary) 0,var(--accent-light) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.section-title{position:relative}.hero-photo-ring{box-shadow:0 0 0 1px rgba(99,102,241,.2),0 20px 60px rgba(99,102,241,.2),0 0 120px rgba(34,211,238,.08),inset 0 0 40px rgba(99,102,241,.05)}.about-card{transform-style:preserve-3d;transition:transform .4s ease,box-shadow .4s ease}.about-visual:hover .about-card{transform:perspective(800px) rotateY(-4deg) rotateX(2deg) translateZ(8px);box-shadow:20px 20px 60px rgba(0,0,0,.35),0 0 0 1px var(--border-hover)}.contact-card{transition:box-shadow .4s ease,transform .4s ease}.contact-card:hover{transform:translateY(-4px);box-shadow:0 32px 64px rgba(0,0,0,.4),0 0 0 1px var(--border-hover)}[data-theme=light] .contact-card:hover{box-shadow:0 24px 48px rgba(0,0,0,.1),0 0 0 1px rgba(99,102,241,.3)}.stage-dot{box-shadow:0 0 0 4px var(--bg),0 0 0 6px rgba(99,102,241,.2);transition:box-shadow .3s ease,background .3s ease}.stage:hover .stage-dot{box-shadow:0 0 0 4px var(--bg),0 0 0 8px rgba(99,102,241,.35),0 0 20px rgba(99,102,241,.3)}.floating-chip{box-shadow:0 8px 24px rgba(0,0,0,.25),0 2px 4px rgba(0,0,0,.15);transition:box-shadow .3s ease}.floating-chip:hover{box-shadow:0 12px 32px rgba(0,0,0,.35),0 0 0 1px var(--border-hover)}.nav{box-shadow:0 1px 0 var(--border),0 4px 24px rgba(0,0,0,.15)}.cs-feature-card{transform-style:preserve-3d;transition:all .3s ease}.cs-feature-card:hover{transform:translateY(-6px) perspective(600px) rotateX(3deg);box-shadow:0 20px 40px rgba(0,0,0,.25),0 0 0 1px var(--border-hover)}[data-theme=light] .cs-feature-card:hover{box-shadow:0 16px 32px rgba(0,0,0,.08),0 0 0 1px rgba(99,102,241,.3)}.hero-scroll-indicator{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;opacity:.5;transition:opacity .3s}.hero-scroll-indicator:hover{opacity:1}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.skip-link{position:absolute;inset-inline-start:-9999px;top:0;background:var(--accent);color:#fff;padding:.5rem 1rem;z-index:1000;text-decoration:none;border-radius:0 0 var(--radius-sm) 0}.skip-link:focus{inset-inline-start:0}.lang-switcher{display:inline-flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--text-muted)}.lang-switcher-btn{background:transparent;border:0;color:inherit;cursor:pointer;padding:.25rem .4rem;border-radius:var(--radius-sm);font:inherit;transition:color var(--transition),background var(--transition)}.lang-switcher-btn:hover{color:var(--text-primary)}.lang-switcher-btn[aria-current=true]{color:var(--accent);font-weight:600}.lang-switcher-btn:disabled{opacity:.5;cursor:wait}.lang-switcher-sep{color:var(--border)}.page-main{padding-block:clamp(5rem,10vh,8rem) clamp(4rem,8vh,6rem);padding-inline:clamp(1.25rem,5vw,4rem);min-height:70vh}.page-section{max-width:800px;margin-inline:auto}.page-title{font-size:clamp(2rem,5vw,3rem);line-height:1.15;margin-block:.5rem 1.5rem;letter-spacing:-.02em}.page-lede{font-size:clamp(1.05rem,2vw,1.2rem);line-height:1.6}.page-lede,.page-prose{color:var(--text-secondary);-webkit-margin-after:2rem;margin-block-end:2rem}.page-prose{font-size:1rem;line-height:1.75}.page-cta-row{display:flex;gap:1rem;flex-wrap:wrap;-webkit-margin-before:2rem;margin-block-start:2rem}.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,260px),1fr));grid-gap:1.25rem;gap:1.25rem;-webkit-margin-before:2.5rem;margin-block-start:2.5rem}.service-card{display:block;padding:1.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);text-decoration:none;color:inherit;transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition)}.service-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px var(--accent-glow)}.service-card-title{font-size:1.1rem;font-weight:700;-webkit-margin-after:.5rem;margin-block-end:.5rem;color:var(--text-primary)}.service-card-summary{font-size:.9rem;color:var(--text-muted);line-height:1.55;-webkit-margin-after:1rem;margin-block-end:1rem}.service-card-cta{font-size:.85rem;font-weight:600;color:var(--accent)}.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr));grid-gap:1.5rem;gap:1.5rem;-webkit-margin-before:2.5rem;margin-block-start:2.5rem}.portfolio-card{display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);text-decoration:none;color:inherit;overflow:hidden;transition:border-color var(--transition),transform var(--transition)}.portfolio-card:hover{border-color:var(--accent);transform:translateY(-2px)}.portfolio-card-icon{height:120px;display:flex;align-items:center;justify-content:center;font-size:2.5rem}.portfolio-card-body{padding:1.25rem 1.5rem 1.5rem}.portfolio-card-tags{display:flex;gap:.4rem;flex-wrap:wrap;-webkit-margin-after:.75rem;margin-block-end:.75rem}.portfolio-card-tag{font-family:var(--font-mono);font-size:.65rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--bg-secondary);border:1px solid var(--border);padding:.2rem .55rem;border-radius:4px}.portfolio-card-title{font-size:1.15rem;font-weight:700;-webkit-margin-after:.5rem;margin-block-end:.5rem;color:var(--text-primary)}.portfolio-card-tagline{font-size:.875rem;color:var(--text-muted);line-height:1.55;-webkit-margin-after:1rem;margin-block-end:1rem}.portfolio-card-cta{font-size:.85rem;font-weight:600;color:var(--accent)}.blog-list{list-style:none;padding:0;margin:2.5rem 0 0;display:flex;flex-direction:column;gap:1.25rem}.blog-list-link{display:block;padding:1.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);text-decoration:none;color:inherit;transition:border-color var(--transition)}.blog-list-link:hover{border-color:var(--accent)}.blog-list-meta{display:flex;gap:.5rem;font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.blog-list-meta,.blog-list-title{-webkit-margin-after:.5rem;margin-block-end:.5rem}.blog-list-title{font-size:1.2rem;font-weight:700;color:var(--text-primary)}.blog-list-desc{font-size:.9rem;color:var(--text-muted);line-height:1.55;-webkit-margin-after:1rem;margin-block-end:1rem}.blog-list-tags{display:flex;gap:.4rem;flex-wrap:wrap}.blog-list-tag{font-size:.65rem;background:var(--bg-secondary);border:1px solid var(--border);padding:.2rem .55rem;border-radius:4px}.blog-list-tag,.blog-post .blog-meta{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.blog-post .blog-meta{font-size:.75rem;-webkit-margin-after:2rem;margin-block-end:2rem}.blog-post h1{font-size:clamp(2rem,4vw,2.75rem);line-height:1.2;-webkit-margin-after:1rem;margin-block-end:1rem}.blog-post h2{font-size:1.5rem;margin-block:2.5rem 1rem;color:var(--text-primary)}.blog-post h3{font-size:1.15rem;margin-block:1.75rem .75rem;color:var(--text-primary)}.blog-post p{font-size:1rem;-webkit-margin-after:1rem;margin-block-end:1rem}.blog-post p,.blog-post ul{color:var(--text-secondary);line-height:1.75}.blog-post ul{-webkit-margin-after:1.5rem;margin-block-end:1.5rem;-webkit-padding-start:1.5rem;padding-inline-start:1.5rem}.blog-post a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}.footer-links{display:inline-flex;gap:.5rem;font-size:.85rem;color:var(--text-muted)}.footer-links a{color:var(--text-muted);text-decoration:none;transition:color var(--transition)}.footer-links a:hover{color:var(--text-primary)}[dir=rtl] .blog-list-link svg,[dir=rtl] .case-study-link svg,[dir=rtl] .cs-back svg,[dir=rtl] .portfolio-card-cta:after,[dir=rtl] .service-card-cta:after{transform:scaleX(-1)}.home-section{padding-block:clamp(4rem,8vh,6rem)}.home-section+.home-section{-webkit-border-before:1px solid var(--border);border-block-start:1px solid var(--border)}.home-services{background:var(--bg)}.home-featured{background:var(--bg-secondary)}.home-testimonials{background:var(--bg)}.home-tech-stack{background:var(--bg-secondary)}.home-cta{background:var(--bg)}.home-section-cta{display:flex;justify-content:center}.home-section-cta,.testimonials-grid{-webkit-margin-before:2.5rem;margin-block-start:2.5rem}.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:1.5rem;gap:1.5rem}.testimonial-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.75rem;margin:0;display:flex;flex-direction:column;gap:1rem}.testimonial-mark{color:var(--accent);opacity:.4}.testimonial-quote{font-size:.95rem;line-height:1.7;color:var(--text-secondary);margin:0;font-style:italic;flex:1 1}.testimonial-attr{display:flex;flex-direction:column;gap:.15rem;-webkit-border-before:1px solid var(--border);border-block-start:1px solid var(--border);-webkit-padding-before:1rem;padding-block-start:1rem}.testimonial-author{font-weight:700;font-size:.9rem;color:var(--text-primary)}.testimonial-role{font-size:.8rem;color:var(--text-muted)}.tech-stack-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:1.5rem;gap:1.5rem;-webkit-margin-before:2.5rem;margin-block-start:2.5rem}.tech-stack-group{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.5rem}.tech-stack-group-name{font-family:var(--font-mono);font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);margin:0 0 .875rem}.tech-stack-list{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.4rem}.tech-stack-item{font-family:var(--font-mono);font-size:.7rem;color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border);padding:.25rem .55rem;border-radius:4px}.home-cta-card{text-align:center;max-width:720px;margin-inline:auto;padding:3rem 2rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl)}.home-cta-card .page-cta-row{justify-content:center}.page-h2{font-size:clamp(1.5rem,3vw,2rem);line-height:1.25;margin-block:0 1.25rem;letter-spacing:-.015em;color:var(--text-primary)}.page-cta-section{-webkit-margin-before:3rem;margin-block-start:3rem;-webkit-padding-before:3rem;padding-block-start:3rem;-webkit-border-before:1px solid var(--border);border-block-start:1px solid var(--border)}.lifecycle-list{list-style:none;padding:0;margin:1.5rem 0 0;display:flex;flex-direction:column;gap:1.25rem;counter-reset:lifecycle}.lifecycle-item{display:flex;gap:1.25rem;align-items:flex-start;padding:1.25rem 1.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md)}.lifecycle-num{font-family:var(--font-mono);font-size:1.25rem;font-weight:700;color:var(--accent);flex-shrink:0;min-width:2.5rem}.lifecycle-title{font-size:1.05rem;font-weight:700;margin:0 0 .4rem;color:var(--text-primary)}.lifecycle-body{font-size:.9rem;color:var(--text-muted);line-height:1.6;margin:0}.principles-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));grid-gap:1rem;gap:1rem;-webkit-margin-before:1.5rem;margin-block-start:1.5rem}.principle-card{padding:1.25rem 1.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md)}.principle-title{font-size:.95rem;font-weight:700;margin:0 0 .4rem;color:var(--text-primary)}.principle-body{font-size:.85rem;color:var(--text-muted);line-height:1.6;margin:0}.faq-list{-webkit-margin-before:1.5rem;margin-block-start:1.5rem;display:flex;flex-direction:column;gap:.75rem}.faq-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.faq-item[open]{border-color:var(--accent)}.faq-question{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;cursor:pointer;font-weight:600;font-size:.95rem;color:var(--text-primary);list-style:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.faq-question::-webkit-details-marker{display:none}.faq-icon{flex-shrink:0;color:var(--text-muted);transition:transform var(--transition)}.faq-item[open] .faq-icon{transform:rotate(180deg)}.faq-answer{padding:0 1.25rem 1.25rem}.faq-answer p{margin:0;font-size:.9rem;color:var(--text-muted);line-height:1.7}.about-article{display:flex;flex-direction:column;gap:.5rem}.about-article .page-section{-webkit-margin-after:0;margin-block-end:0;padding-block:1.5rem}.breadcrumbs{margin-block:1.5rem 1rem;font-size:.85rem;color:var(--text-muted)}.breadcrumbs-list{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.breadcrumbs-item{display:inline-flex;align-items:center;gap:.5rem}.breadcrumbs-link{color:var(--text-muted);text-decoration:none;transition:color var(--transition)}.breadcrumbs-current,.breadcrumbs-link:hover{color:var(--text-primary)}.breadcrumbs-current{font-weight:500}.breadcrumbs-sep{color:var(--border)}.contact-grid{display:grid;grid-template-columns:minmax(0,1fr);grid-gap:2.5rem;gap:2.5rem;-webkit-margin-before:2.5rem;margin-block-start:2.5rem;align-items:start}@media (min-width:880px){.contact-grid{grid-template-columns:minmax(0,2fr) minmax(0,1fr)}}.contact-form-wrap>.page-h2{-webkit-margin-before:0;margin-block-start:0}.contact-aside{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.5rem}.contact-aside-title{font-size:1.05rem;margin:0 0 .5rem;color:var(--text-primary)}.contact-aside-desc{font-size:.9rem;color:var(--text-muted);-webkit-margin-after:1rem;margin-block-end:1rem;line-height:1.6}.contact-aside-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.contact-aside-list a{color:var(--text-primary);text-decoration:none;font-size:.9rem;-webkit-border-after:1px dashed var(--border);border-block-end:1px dashed var(--border);-webkit-padding-after:.25rem;padding-block-end:.25rem;transition:color var(--transition)}.contact-aside-list a:hover{color:var(--accent)}.contact-aside-address{font-size:.85rem;color:var(--text-muted);font-style:normal}.contact-form{display:flex;flex-direction:column;gap:1rem;-webkit-margin-before:1.5rem;margin-block-start:1.5rem}.form-row{display:grid;grid-template-columns:minmax(0,1fr);grid-gap:1rem;gap:1rem}@media (min-width:600px){.form-row{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}}.form-field{display:flex;flex-direction:column;gap:.4rem}.form-label{font-size:.85rem;font-weight:600;color:var(--text-primary)}.form-field input,.form-field select,.form-field textarea,.newsletter-field input{font:inherit;width:100%;padding:.65rem .85rem;background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);outline:none;transition:border-color var(--transition),box-shadow var(--transition)}.form-field input:focus,.form-field select:focus,.form-field textarea:focus,.newsletter-field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.form-field input[aria-invalid=true],.form-field textarea[aria-invalid=true]{border-color:#ef4444}.form-field textarea{resize:vertical;min-height:7rem;font-family:inherit}.form-error{font-size:.8rem;color:#ef4444}.form-error-banner{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.4);border-radius:var(--radius-sm);padding:.75rem 1rem;display:flex;flex-direction:column;gap:.25rem;font-size:.85rem;color:var(--text-primary)}.form-honeypot{position:absolute;inset-inline-start:-9999px;width:1px;height:1px;overflow:hidden}.form-result{padding:2rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);text-align:center}.form-result-ok{border-color:var(--success);background:rgba(34,197,94,.05)}.form-result-title{font-size:1.25rem;margin:0 0 .5rem;color:var(--text-primary)}.form-result-body{margin:0;color:var(--text-muted)}.newsletter{display:grid;grid-template-columns:minmax(0,1fr);grid-gap:1.5rem;gap:1.5rem;padding-block:2.5rem;-webkit-border-after:1px solid var(--border);border-block-end:1px solid var(--border)}@media (min-width:720px){.newsletter{grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:center}}.newsletter-title{font-size:1.15rem;margin:0 0 .4rem;color:var(--text-primary)}.newsletter-body{margin:0;font-size:.9rem;color:var(--text-muted);line-height:1.6}.newsletter-form{display:flex;gap:.5rem;align-items:stretch;flex-wrap:wrap}.newsletter-field{flex:1 1;min-width:200px;margin:0}.newsletter-status{flex-basis:100%;font-size:.85rem;-webkit-margin-before:.4rem;margin-block-start:.4rem}.newsletter-status-ok{color:var(--success)}.newsletter-status-error{color:#ef4444}.footer-block{background:var(--bg-secondary);-webkit-border-before:1px solid var(--border);border-block-start:1px solid var(--border);-webkit-margin-before:4rem;margin-block-start:4rem}.footer-container{padding-block:0}.footer-bottom{justify-content:space-between;gap:1rem;padding-block:1.5rem;font-size:.85rem;color:var(--text-muted)}.footer-bottom,.share-buttons{display:flex;flex-wrap:wrap;align-items:center}.share-buttons{gap:.5rem;-webkit-margin-before:3rem;margin-block-start:3rem;-webkit-padding-before:1.5rem;padding-block-start:1.5rem;-webkit-border-before:1px solid var(--border);border-block-start:1px solid var(--border)}.share-label{font-size:.85rem;color:var(--text-muted);-webkit-margin-end:.5rem;margin-inline-end:.5rem}.share-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem .85rem;font-size:.8rem;font-weight:500;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);text-decoration:none;cursor:pointer;transition:border-color var(--transition),color var(--transition)}.share-btn:hover{border-color:var(--accent);color:var(--accent)}.cookie-banner{position:fixed;inset-block-end:1rem;inset-inline-start:1rem;inset-inline-end:1rem;z-index:1100;background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);max-width:1100px;margin-inline:auto;animation:cookie-slide-up .35s cubic-bezier(.4,0,.2,1)}@keyframes cookie-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.cookie-banner-inner{display:grid;grid-gap:1.25rem;gap:1.25rem;padding:1.25rem 1.5rem}@media (min-width:920px){.cookie-banner-inner{grid-template-columns:minmax(0,1.4fr) minmax(0,1fr) auto;align-items:center}}.cookie-banner-title{font-size:1rem;margin:0 0 .25rem;color:var(--text-primary)}.cookie-banner-body{font-size:.85rem;color:var(--text-muted);line-height:1.55;margin:0}.cookie-banner-policy{display:inline-block;font-size:.8rem;color:var(--accent);text-decoration:none;-webkit-margin-before:.4rem;margin-block-start:.4rem}.cookie-banner-policy:hover{text-decoration:underline}.cookie-banner-options{display:flex;flex-direction:column;gap:.5rem}.cookie-toggle{display:flex;align-items:flex-start;gap:.6rem;font-size:.8rem;cursor:pointer}.cookie-toggle input{-webkit-margin-before:.15rem;margin-block-start:.15rem;flex-shrink:0}.cookie-toggle input:disabled{opacity:.6}.cookie-toggle-text{display:flex;flex-direction:column;gap:.1rem}.cookie-toggle-text strong{font-weight:600;color:var(--text-primary)}.cookie-toggle-text span{color:var(--text-muted);font-size:.75rem;line-height:1.4}.cookie-banner-actions{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}@media (min-width:920px){.cookie-banner-actions{flex-direction:column;align-items:stretch}}.footer-prefs-link{background:none;border:0;color:var(--text-muted);text-decoration:none;font:inherit;font-size:inherit;cursor:pointer;padding:0;transition:color var(--transition)}.footer-prefs-link:hover{color:var(--text-primary)}.loading-skeleton{display:flex;flex-direction:column;gap:1rem}.skeleton-line{height:1rem;background:linear-gradient(90deg,var(--bg-card) 0,var(--bg-secondary) 50%,var(--bg-card) 100%);background-size:200% 100%;border-radius:var(--radius-sm);animation:skeleton-pulse 1.4s ease-in-out infinite}.skeleton-label{width:8rem;height:.75rem}.skeleton-title{width:75%;height:2.25rem}.skeleton-lede{width:100%}.skeleton-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:1rem;gap:1rem;-webkit-margin-before:2rem;margin-block-start:2rem}.skeleton-card{height:180px;background:linear-gradient(90deg,var(--bg-card) 0,var(--bg-secondary) 50%,var(--bg-card) 100%);background-size:200% 100%;border-radius:var(--radius-md);animation:skeleton-pulse 1.4s ease-in-out infinite}@keyframes skeleton-pulse{0%{background-position:200% 0}to{background-position:-200% 0}}.error-digest{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted);-webkit-margin-before:1rem;margin-block-start:1rem}.error-digest code{background:var(--bg-card);border:1px solid var(--border);padding:.2rem .5rem;border-radius:4px}.credentials-row{list-style:none;padding:0;margin:1.5rem 0 2rem;display:flex;flex-wrap:wrap;gap:.5rem}.credential-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.45rem .85rem;background:var(--bg-card);border:1px solid var(--border);border-radius:999px;font-size:.82rem;color:var(--text-secondary);line-height:1.3}.credential-chip:hover{border-color:var(--accent);color:var(--text-primary)}.credential-icon{font-size:.95rem;display:inline-flex}@media (max-width:480px){section{padding:clamp(3.5rem,12vw,5rem) 1.25rem}.hero,.page-main{padding-inline:1.25rem}.hero{padding-block:5rem 2.5rem}.hero-photo-wrap{width:220px;height:220px;margin:0 auto}.hero-title{font-size:clamp(2rem,9vw,2.75rem)}.hero-sub{font-size:.95rem;margin-bottom:1.75rem}.hero-badge{margin-bottom:1rem}.hero-location-row{gap:.4rem;margin-bottom:1.5rem}.hero-loc-chip{font-size:.72rem;padding:.25rem .6rem}.hero-actions{flex-direction:column;align-items:stretch;gap:.75rem;margin-bottom:2rem;width:100%}.hero-actions .btn{justify-content:center;width:100%}.hero-stats{gap:1rem 1.25rem;width:100%}.hero-stats .stat-divider{display:none}.hero-stats .stat{flex-grow:1;flex-shrink:1;flex-basis:calc(50% - 0.625rem);text-align:center}.page-cta-row{flex-direction:column;align-items:stretch}.page-cta-row .btn{justify-content:center;width:100%}.cs-impact-grid{grid-template-columns:1fr}.newsletter-form{flex-direction:column;align-items:stretch}.newsletter-form .btn{width:100%;justify-content:center}.footer-bottom{flex-direction:column;align-items:flex-start;gap:.75rem}.nav{padding:0 1rem}.nav-actions{gap:.5rem}.nav-actions .btn{padding:.45rem .85rem;font-size:.8rem}.cookie-banner{inset-block-end:.5rem;inset-inline-start:.5rem;inset-inline-end:.5rem}.cookie-banner-inner{padding:1rem;gap:1rem}.cookie-banner-actions .btn{flex:1 1 auto}.contact-aside-list a{word-break:break-word}.breadcrumbs{font-size:.78rem}.breadcrumbs-list{gap:.35rem}.credentials-row{gap:.4rem}.credential-chip{font-size:.78rem;padding:.4rem .75rem}.photo-badge{font-size:.7rem;padding:.3rem .6rem}}@media (max-width:360px){.hero-title{font-size:1.75rem}.hero-stats .stat-value{font-size:1.5rem}.hero-stats .stat-label{font-size:.7rem}.page-title{font-size:1.65rem}.nav-logo{font-size:1rem}.nav-actions .btn{padding:.4rem .7rem;font-size:.75rem}}.home-consultation{padding-block:clamp(2.5rem,5vw,4rem)}.consultation-card{display:grid;grid-template-columns:auto 1fr auto;align-items:center;grid-gap:1.5rem 2rem;gap:1.5rem 2rem;padding:1.75rem 2rem;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--accent-glow) 0,transparent 60%),var(--bg-card);border:1px solid var(--border);box-shadow:0 8px 24px rgba(0,0,0,.08)}.consultation-icon{display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:50%;background:var(--accent-glow);color:var(--accent);flex-shrink:0}.consultation-text{min-width:0}.consultation-label{font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin:0 0 .4rem}.consultation-title{font-size:clamp(1.1rem,2vw,1.4rem);font-weight:700;margin:0 0 .4rem;color:var(--text-primary);line-height:1.25}.consultation-body{font-size:.9rem;color:var(--text-muted);line-height:1.55;margin:0}.consultation-cta{flex-shrink:0}@media (max-width:760px){.consultation-card{grid-template-columns:1fr;text-align:center;padding:1.5rem}.consultation-icon{margin-inline:auto}.consultation-cta{width:100%}.consultation-cta .btn{width:100%;justify-content:center}}