@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=DM+Serif+Display:ital@0;1&family=Outfit:wght@300;400;500;600;700&display=swap";:root{--font-display: "DM Serif Display", Georgia, "Times New Roman", serif;--font-heading: "Outfit", system-ui, sans-serif;--font-body: "DM Sans", system-ui, sans-serif;font-family:var(--font-body);line-height:1.6;font-weight:400;color-scheme:dark;--color-bg-primary: #0b0b0f;--color-bg-secondary: #131318;--color-bg-tertiary: #1a1a22;--color-bg-elevated: #1f1f2a;--color-text-primary: #eae8e4;--color-text-secondary: #a8a5a0;--color-text-muted: #6b6966;--color-accent: #8b7cf6;--color-accent-light: #a193f8;--color-accent-lighter: #c4bafc;--color-accent-lightest: #ddd8fd;--color-accent-bg: rgba(139, 124, 246, .07);--color-accent-border: rgba(139, 124, 246, .12);--color-accent-border-hover: rgba(139, 124, 246, .25);--color-accent-glow: rgba(139, 124, 246, .15);--color-border: rgba(255, 255, 255, .06);--color-border-hover: rgba(255, 255, 255, .12);--color-success: #3dd68c;--color-warning: #f0c040;--color-error: #e85d5d;--color-card-bg: rgba(19, 19, 24, .6);--color-card-bg-hover: rgba(31, 31, 42, .8);--color-shadow: rgba(0, 0, 0, .4);color:var(--color-text-primary);background-color:var(--color-bg-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}[data-theme=light]{color-scheme:light;--color-bg-primary: #f6f4f0;--color-bg-secondary: #ffffff;--color-bg-tertiary: #eeebe5;--color-bg-elevated: #ffffff;--color-text-primary: #1a1818;--color-text-secondary: #5a5654;--color-text-muted: #8a8684;--color-accent: #6d5bd0;--color-accent-light: #7f6ee0;--color-accent-lighter: #a899ea;--color-accent-lightest: #d0c9f5;--color-accent-bg: rgba(109, 91, 208, .06);--color-accent-border: rgba(109, 91, 208, .12);--color-accent-border-hover: rgba(109, 91, 208, .25);--color-accent-glow: rgba(109, 91, 208, .1);--color-border: rgba(0, 0, 0, .06);--color-border-hover: rgba(0, 0, 0, .12);--color-success: #22c55e;--color-warning: #d4a017;--color-error: #dc4040;--color-card-bg: rgba(255, 255, 255, .7);--color-card-bg-hover: rgba(255, 255, 255, .95);--color-shadow: rgba(0, 0, 0, .06)}body{margin:0;min-width:320px;min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:600;line-height:1.15;margin-bottom:.5rem;letter-spacing:-.02em}p{margin-bottom:1rem}a{color:var(--color-accent-light);text-decoration:none;transition:color .25s ease}a:hover{color:var(--color-accent-lighter)}.btn-accent{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 1.75rem;background:var(--color-accent);color:#fff;text-decoration:none;border-radius:.5rem;font-family:var(--font-heading);font-weight:500;font-size:.95rem;letter-spacing:.01em;border:none;cursor:pointer;transition:all .25s ease}.btn-accent:hover{background:var(--color-accent-light);transform:translateY(-1px);box-shadow:0 8px 30px var(--color-accent-glow)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6;color:var(--color-text-primary);background:var(--color-bg-primary)}.app{min-height:100vh;display:flex;flex-direction:column;background:var(--color-bg-primary)}main{flex:1}.container{max-width:1100px;margin:0 auto;padding:0 2rem}.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}*:focus{outline:2px solid var(--color-accent);outline-offset:2px}*:focus:not(:focus-visible){outline:none}*:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}a,button,input,textarea,.project-card,.contact-item,.path-card,.skill-tag,.tech-tag,.social-link,.profile-photo{transition:color .25s ease,background-color .25s ease,border-color .25s ease,transform .25s ease,box-shadow .25s ease,opacity .25s ease}.section-label{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-heading);font-size:.8rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--color-accent);margin-bottom:1rem}.section-label:before{content:"";display:inline-block;width:1.5rem;height:1px;background:var(--color-accent)}.noise-overlay:after{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");background-repeat:repeat;background-size:256px 256px;pointer-events:none;z-index:0}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in-up{animation:fadeInUp .5s ease-out both}@media (max-width: 768px){body{font-size:.95rem}}@media (max-width: 480px){.container{padding:0 1.25rem}}
