*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-body)}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}a{color:inherit;text-decoration:none}ul,ol{list-style:none}:root{--dev-bg: #0D1117;--dev-bg-secondary: #161B22;--dev-text: #E6EDF3;--dev-text-muted: #8B949E;--dev-accent: #39FF14;--dev-accent-dim: rgba(57, 255, 20, .15);--dev-border: #30363D;--dev-font: "JetBrains Mono", "Fira Code", monospace;--pm-bg: #FAFAFA;--pm-bg-secondary: #F0F0F0;--pm-text: #1A1A2E;--pm-text-muted: #6B7280;--pm-accent: #1E40AF;--pm-accent-dim: rgba(30, 64, 175, .1);--pm-border: #E5E7EB;--pm-font: "Inter", system-ui, -apple-system, sans-serif;--ai-accent: #8B5CF6;--ai-accent-dim: rgba(139, 92, 246, .12);--ai-gradient: linear-gradient(135deg, #8B5CF6, #6D28D9);--bg-primary: #0D1117;--bg-neutral: #111827;--text-primary: #E6EDF3;--font-body: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--space-4xl: 6rem;--max-width: 1200px;--section-padding: var(--space-4xl) var(--space-xl);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .5);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--split-pct: 50%}@font-face{font-family:JetBrains Mono;src:url(/fonts/jetbrains-mono.woff2) format("woff2");font-weight:400 700;font-display:swap}@font-face{font-family:Inter;src:url(/fonts/inter.woff2) format("woff2");font-weight:400 700;font-display:swap}.container{width:100%;max-width:var(--max-width);margin-inline:auto;padding-inline:var(--space-xl)}.section{padding:var(--section-padding)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.skip-link{position:absolute;top:-100%;left:50%;transform:translate(-50%);z-index:9999;background:var(--dev-accent);color:var(--dev-bg);padding:var(--space-sm) var(--space-lg);border-radius:0 0 var(--radius-md) var(--radius-md);font-weight:600;font-size:.9rem;text-decoration:none;transition:top var(--transition-fast)}.skip-link:focus{top:0}:focus-visible{outline:2px solid var(--dev-accent);outline-offset:2px}button:focus-visible,a:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--dev-accent);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.dev-side{color:var(--dev-text);font-family:var(--dev-font)}.dev-side:not(.hero-panel){background:var(--dev-bg)}.dev-side .hero-heading{font-family:var(--dev-font);color:var(--dev-accent);font-size:clamp(1.2rem,2.5vw,2rem);line-height:1.4}.dev-side .hero-subtext{color:var(--dev-text-muted);font-family:var(--dev-font);font-size:clamp(.8rem,1.2vw,1rem)}.dev-side .cursor{display:inline-block;width:.6em;height:1.1em;background:var(--dev-accent);margin-left:2px;vertical-align:text-bottom;animation:blink 1s step-end infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.dev-side .prompt{color:var(--dev-text-muted)}.dev-side .prompt:before{content:"> ";color:var(--dev-accent)}.pm-side{color:var(--pm-text);font-family:var(--pm-font)}.pm-side:not(.hero-panel){background:var(--pm-bg)}.pm-side .hero-heading{font-family:var(--pm-font);color:var(--pm-text);font-size:clamp(1.5rem,3vw,2.5rem);font-weight:700;letter-spacing:-.02em;line-height:1.2}.pm-side .hero-subtext{color:var(--pm-text-muted);font-family:var(--pm-font);font-size:clamp(.9rem,1.3vw,1.1rem);font-weight:400}.pm-side .title-role{color:var(--pm-accent);font-weight:600;text-transform:uppercase;letter-spacing:.05em;font-size:.85em}.hero{position:relative;width:100%;height:100vh;min-height:600px;overflow:hidden}.hero-panel{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;overflow:hidden;transition:clip-path var(--transition-fast)}.hero-panel--pm{clip-path:polygon(0 0,var(--split-pct) 0,var(--split-pct) 100%,0 100%);z-index:1}.hero-panel--dev{clip-path:polygon(var(--split-pct) 0,100% 0,100% 100%,var(--split-pct) 100%);z-index:1}.hero-bg{position:absolute;inset:0;background-image:url(/images/dp.jpeg);background-size:cover;background-position:center 20%;background-repeat:no-repeat;z-index:0}.hero-panel--dev .hero-bg{background-blend-mode:normal}.hero-panel--dev .hero-bg:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#0d1117d1,#0d1117bf)}.hero-panel--pm .hero-bg:after{content:"";position:absolute;inset:0;background:linear-gradient(225deg,#f8fafcd1,#f1f5f9bf)}.hero-content{position:relative;z-index:2;max-width:420px;padding:var(--space-3xl)}.hero-panel--pm .hero-content{margin-left:5%;text-align:left}.hero-panel--dev .hero-content{margin-left:auto;margin-right:5%;text-align:right}.hero-panel--dev .hero-content *{text-shadow:0 1px 6px rgba(0,0,0,.5)}.hero-panel--pm .hero-content .hero-heading,.hero-panel--pm .hero-content .title-role{text-shadow:0 1px 3px rgba(0,0,0,.08)}.hero-panel--pm .hero-content .hero-subtext{text-shadow:none}.hero-divider{position:absolute;top:0;bottom:0;z-index:10;width:4px;cursor:col-resize;left:var(--split-pct);transform:translate(-50%);padding:0 20px;background-clip:content-box;touch-action:none;background:linear-gradient(180deg,#ffffff08,#ffffff59 30%,#ffffff80,#ffffff59 70%,#ffffff08)}.hero-divider:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px;border-radius:50%;background:#ffffff1f;backdrop-filter:blur(8px);border:2px solid rgba(255,255,255,.35);transition:transform var(--transition-base),background var(--transition-base)}.hero-divider:hover:before,.hero-divider:active:before{transform:translate(-50%,-50%) scale(1.2);background:#ffffff40}.hero-divider__arrows{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:14px;pointer-events:none;display:flex;gap:6px;opacity:.9;font-weight:700}.hero-tagline{position:absolute;bottom:var(--space-3xl);left:50%;transform:translate(-50%);z-index:20;text-align:center;color:#ffffffe6;font-family:var(--pm-font);font-size:clamp(.9rem,1.5vw,1.2rem);font-weight:400;letter-spacing:.02em;text-shadow:0 2px 12px rgba(0,0,0,.7);white-space:nowrap}.hero-scroll{position:absolute;bottom:var(--space-lg);left:50%;transform:translate(-50%);z-index:20;display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);color:#fff9;font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;animation:float 2s ease-in-out infinite;text-shadow:0 1px 4px rgba(0,0,0,.5)}.hero-scroll svg{width:20px;height:20px}@keyframes float{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(6px)}}@media(min-width:768px)and (max-width:1024px){.hero-content{max-width:320px;padding:var(--space-2xl)}.hero-mobile-toggle{display:none}}@media(max-width:767px){.hero{height:100vh;min-height:600px;position:relative}.hero:before{content:"";position:absolute;inset:0;background-image:url(/images/dp.jpeg);background-size:cover;background-position:center 15%;z-index:0}.hero:after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,#0d111766,#0d11178c,#0d1117d9);z-index:1}.hero-panel{position:absolute;clip-path:none!important;width:100%;background:none!important;inset:auto 0 0;height:auto;justify-content:flex-end;z-index:2;transition:opacity .3s ease}.hero-panel .hero-bg{display:none}.hero-panel--pm{opacity:1;pointer-events:auto}.hero-panel--dev{opacity:0;pointer-events:none}.hero-panel--dev .hero-content,.hero-panel--pm .hero-content{margin:0 auto;text-align:center;max-width:100%;padding:var(--space-xl) var(--space-xl) var(--space-3xl)}.hero-panel--pm .hero-content .hero-heading{color:#fff}.hero-panel--pm .hero-content .hero-subtext{color:#fffc;text-shadow:0 1px 4px rgba(0,0,0,.4)}.hero-panel--pm .hero-content .title-role{text-shadow:0 1px 4px rgba(0,0,0,.3)}.hero-divider{display:none}.hero-tagline{position:absolute;bottom:var(--space-md);left:50%;transform:translate(-50%);z-index:20;padding:0;background:none;white-space:nowrap;font-size:.8rem;color:#fff9}.hero-scroll{display:none}.hero-mobile-toggle{display:flex}}@media(min-width:768px){.hero-mobile-toggle{display:none}}.hero-mobile-toggle{position:absolute;top:var(--space-3xl);left:50%;transform:translate(-50%);z-index:30;gap:0;border-radius:var(--radius-md);overflow:hidden;border:1px solid rgba(255,255,255,.25);backdrop-filter:blur(8px);background:#0003}.hero-mobile-toggle button{padding:var(--space-sm) var(--space-lg);border:none;cursor:pointer;font-size:.85rem;font-weight:600;transition:all var(--transition-base)}.hero-mobile-toggle button[data-active=true]{background:#fff3;color:#fff}.hero-mobile-toggle button[data-active=false]{background:transparent;color:#ffffff80}.projects{padding:var(--section-padding);background:var(--bg-neutral);transition:background .5s ease}.projects__header{text-align:center;margin-bottom:var(--space-3xl)}.projects__title{font-size:clamp(1.8rem,3vw,2.5rem);color:var(--text-primary);margin-bottom:var(--space-sm);transition:color .5s ease}.projects__subtitle{color:var(--dev-text-muted);font-size:1rem;transition:color .5s ease}.projects.pm-mode .projects__title{color:var(--pm-text)}.projects.pm-mode .projects__subtitle{color:var(--pm-text-muted)}.projects__split{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-xl);margin-bottom:var(--space-3xl);transition:grid-template-columns .5s ease}.projects__column{display:flex;flex-direction:column;gap:var(--space-lg);transition:opacity .5s ease,flex .5s ease}.projects__column-title{font-size:1.1rem;text-transform:uppercase;letter-spacing:.08em;padding-bottom:var(--space-sm);margin-bottom:var(--space-sm)}.projects__column--dev .projects__column-title{color:var(--dev-accent);border-bottom:2px solid var(--dev-accent-dim);font-family:var(--dev-font)}.projects__column--pm .projects__column-title{color:var(--pm-accent);border-bottom:2px solid var(--pm-accent-dim);font-family:var(--pm-font)}.project-card{border-radius:var(--radius-lg);padding:var(--space-lg);transition:transform var(--transition-base),box-shadow var(--transition-base);cursor:pointer;position:relative;overflow:hidden}.project-card:hover{transform:translateY(-4px)}.project-card--dev{background:var(--dev-bg-secondary);border:1px solid var(--dev-border);font-family:var(--dev-font)}.project-card--dev:hover{box-shadow:0 0 20px var(--dev-accent-dim),var(--shadow-md);border-color:var(--dev-accent)}.project-card--dev .project-card__title{color:var(--dev-accent);font-family:var(--dev-font);font-size:1rem}.project-card--dev .project-card__title:before{content:"> ";opacity:.5}.project-card--dev .project-card__desc{color:var(--dev-text-muted);font-size:.85rem}.project-card--dev .project-card__tags{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-top:var(--space-sm)}.project-card--dev .project-card__tag{background:var(--dev-accent-dim);color:var(--dev-accent);padding:2px 8px;border-radius:var(--radius-sm);font-size:.75rem}.project-card--pm{background:var(--pm-bg);border:1px solid var(--pm-border);font-family:var(--pm-font)}.project-card--pm:hover{box-shadow:0 0 20px var(--pm-accent-dim),var(--shadow-md);border-color:var(--pm-accent)}.project-card--pm .project-card__title{color:var(--pm-accent);font-weight:700;font-size:1rem}.project-card--pm .project-card__desc{color:var(--pm-text-muted);font-size:.9rem;line-height:1.5}.project-card--pm .project-card__tags{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-top:var(--space-sm)}.project-card--pm .project-card__tag{background:var(--pm-accent-dim);color:var(--pm-accent);padding:2px 8px;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500}.project-card--pm .project-card__narrative{margin-top:var(--space-sm)}.project-card--pm .project-card__narrative dt{color:var(--pm-accent);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;margin-top:var(--space-sm)}.project-card--pm .project-card__narrative dd{color:var(--pm-text-muted);font-size:.85rem;margin-left:0}.projects__ai{background:var(--ai-gradient);border-radius:var(--radius-xl);padding:var(--space-2xl);text-align:center}.projects__ai-title{color:#fff;font-size:clamp(1.3rem,2vw,1.8rem);margin-bottom:var(--space-md)}.projects__ai-desc{color:#ffffffd9;max-width:600px;margin:0 auto var(--space-xl)}.projects__ai-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-lg)}.ai-card{background:#ffffff1a;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-lg);padding:var(--space-lg);text-align:left;transition:transform var(--transition-base)}.ai-card:hover{transform:translateY(-4px)}.ai-card__title{color:#fff;font-weight:600;margin-bottom:var(--space-xs)}.ai-card__desc{color:#ffffffbf;font-size:.85rem}.ai-card__tag{display:inline-block;margin-top:var(--space-sm);background:#ffffff26;color:#fff;padding:2px 10px;border-radius:var(--radius-sm);font-size:.75rem}.project-modal-overlay{position:fixed;inset:0;background:#000000b3;z-index:100;display:none;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity var(--transition-base)}.project-modal-overlay.active{display:flex;opacity:1;pointer-events:all;backdrop-filter:blur(4px)}.project-modal{background:var(--dev-bg-secondary);border:1px solid var(--dev-border);border-radius:var(--radius-xl);padding:var(--space-2xl);max-width:700px;width:90%;max-height:80vh;overflow-y:auto;transform:translateY(20px);transition:transform var(--transition-base)}.project-modal-overlay.active .project-modal{transform:translateY(0)}.project-modal__close{position:absolute;top:var(--space-md);right:var(--space-md);background:none;border:none;color:var(--dev-text-muted);cursor:pointer;font-size:1.5rem}@media(max-width:767px){.projects__split,.projects__ai-grid{grid-template-columns:1fr}}.pokemon-world{padding:var(--section-padding);background:var(--dev-bg);text-align:center}.pokemon-world__header{margin-bottom:var(--space-2xl)}.pokemon-world__title{font-size:clamp(1.8rem,3vw,2.5rem);color:var(--text-primary);margin-bottom:var(--space-sm)}.pokemon-world__subtitle{color:var(--dev-text-muted);font-size:1rem}.pokemon-world__canvas-wrap{position:relative;width:100%;max-width:960px;margin:0 auto;aspect-ratio:16 / 10;background:#000;border-radius:var(--radius-lg);overflow:hidden;border:2px solid var(--dev-border);box-shadow:var(--shadow-lg)}.pokemon-world__canvas-wrap canvas{width:100%!important;height:100%!important}.pokemon-world__loading{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#000;color:var(--dev-text);font-family:var(--dev-font);gap:var(--space-md);z-index:5;transition:opacity .5s ease}.pokemon-world__loading.hidden{opacity:0;pointer-events:none}.pokemon-world__loading-bar{width:200px;height:8px;background:var(--dev-border);border-radius:4px;overflow:hidden}.pokemon-world__loading-fill{height:100%;background:var(--dev-accent);border-radius:4px;width:0%;transition:width .3s ease}.pokemon-world__controls{display:flex;justify-content:center;align-items:center;gap:var(--space-xl);margin-top:var(--space-lg);color:var(--dev-text-muted);font-family:var(--dev-font);font-size:.85rem}.pokemon-world__controls kbd{display:inline-block;background:var(--dev-bg-secondary);border:1px solid var(--dev-border);border-radius:var(--radius-sm);padding:2px 6px;font-family:var(--dev-font);font-size:.8rem;color:var(--dev-text)}.pokemon-world__sound-toggle{background:var(--dev-bg-secondary);border:1px solid var(--dev-border);border-radius:var(--radius-sm);padding:4px 10px;font-family:var(--dev-font);font-size:.8rem;color:var(--dev-text-muted);cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast)}.pokemon-world__sound-toggle:hover,.pokemon-world__sound-toggle[aria-pressed=true]{color:var(--dev-accent);border-color:var(--dev-accent)}.pokemon-world__fallback{background:var(--dev-bg-secondary);border:1px solid var(--dev-border);border-radius:var(--radius-lg);padding:var(--space-xl);text-align:center;color:var(--dev-text-muted)}.pokemon-world__fallback a{color:var(--dev-accent);text-decoration:underline}.pokemon-world__badges{display:flex;justify-content:center;align-items:center;gap:var(--space-md);margin-top:var(--space-lg);color:var(--dev-text);font-family:var(--dev-font)}.pokemon-world__badge-tray{display:flex;gap:var(--space-sm)}.pokemon-world__badge{width:28px;height:28px;border-radius:50%;border:2px solid var(--dev-border);display:flex;align-items:center;justify-content:center;font-size:14px;transition:all var(--transition-base)}.pokemon-world__badge--collected{border-color:var(--dev-accent);background:var(--dev-accent-dim);animation:badge-pop .4s ease}.pokemon-world__badge--empty{opacity:.3}@keyframes badge-pop{0%{transform:scale(0)}50%{transform:scale(1.3)}to{transform:scale(1)}}@media(max-width:767px){.pokemon-world__controls{flex-direction:column;gap:var(--space-sm)}}.js-enabled .reveal{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}.reveal.visible{opacity:1;transform:translateY(0)}.js-enabled .reveal-stagger>*{opacity:0;transform:translateY(20px);transition:opacity .4s ease,transform .4s ease}.reveal-stagger.visible>*:nth-child(1){transition-delay:0ms}.reveal-stagger.visible>*:nth-child(2){transition-delay:80ms}.reveal-stagger.visible>*:nth-child(3){transition-delay:.16s}.reveal-stagger.visible>*:nth-child(4){transition-delay:.24s}.reveal-stagger.visible>*:nth-child(5){transition-delay:.32s}.reveal-stagger.visible>*:nth-child(6){transition-delay:.4s}.reveal-stagger.visible>*:nth-child(7){transition-delay:.48s}.reveal-stagger.visible>*:nth-child(8){transition-delay:.56s}.reveal-stagger.visible>*:nth-child(9){transition-delay:.64s}.reveal-stagger.visible>*:nth-child(10){transition-delay:.72s}.reveal-stagger.visible>*{opacity:1;transform:translateY(0)}.fade-in{opacity:0;transition:opacity .6s ease}.fade-in.visible{opacity:1}.scale-in{opacity:0;transform:scale(.9);transition:opacity .5s ease,transform .5s ease}.scale-in.visible{opacity:1;transform:scale(1)}.slide-left{opacity:0;transform:translate(-40px);transition:opacity .6s ease,transform .6s ease}.slide-left.visible{opacity:1;transform:translate(0)}.slide-right{opacity:0;transform:translate(40px);transition:opacity .6s ease,transform .6s ease}.slide-right.visible{opacity:1;transform:translate(0)}.count-up{font-variant-numeric:tabular-nums}.typewriter{overflow:hidden;white-space:nowrap;border-right:2px solid var(--dev-accent);animation:typewriter-cursor .8s step-end infinite}@keyframes typewriter-cursor{0%,to{border-color:var(--dev-accent)}50%{border-color:transparent}}@keyframes tag-pop{0%{transform:scale(0);opacity:0}70%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.tag-pop{animation:tag-pop .3s ease forwards}@keyframes wipe-in{0%{clip-path:inset(0 100% 0 0)}to{clip-path:inset(0 0 0 0)}}@keyframes confetti-fall{0%{transform:translateY(-10px) rotate(0);opacity:1}to{transform:translateY(60px) rotate(360deg);opacity:0}}
