@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.block{display:block}.contents{display:contents}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--color-bg-primary:#050510;--color-bg-secondary:#0a0a1a;--color-bg-tertiary:#0f0f24;--color-text-primary:#f5f5f7;--color-text-secondary:#a1a1aa;--color-text-muted:#52525b;--color-accent-red-start:#c43a31;--color-accent-red-end:#e8175d;--color-accent-blue-start:#38bdf8;--color-accent-blue-end:#3b82f6;--space-xs:.5rem;--space-sm:1rem;--space-md:1.5rem;--space-lg:2rem;--space-xl:3rem;--space-2xl:5rem;--space-3xl:8rem;--font-display:"Roboto",-apple-system,BlinkMacSystemFont,sans-serif;--font-body:"Roboto",-apple-system,BlinkMacSystemFont,sans-serif;--text-hero:clamp(2rem,8vw,5rem);--text-section-title:clamp(1.5rem,4vw,2.5rem);--text-project-name:clamp(1.25rem,3vw,2rem);--text-body:clamp(1rem,2vw,1.125rem);--text-small:clamp(.875rem,1.5vw,1rem);--transition-fast:.15s ease;--transition-normal:.3s ease;--transition-slow:.5s ease}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);font-size:var(--text-body);color:var(--color-text-primary);background:var(--color-bg-primary);margin:0;padding:0;line-height:1.6}#app{background:radial-gradient(ellipse 80% 50% at 50% -20%,#38bdf814,transparent),radial-gradient(ellipse 60% 40% at 100% 50%,#c43a310d,transparent),linear-gradient(to bottom,var(--color-bg-primary),var(--color-bg-secondary));background-attachment:fixed;min-height:100vh;position:relative}#app:before{content:"";pointer-events:none;opacity:.025;z-index:1000;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:1000px 1000px;width:100%;height:100%;position:absolute;top:0;left:0}a{color:inherit;text-decoration:none}.accent-red{background:linear-gradient(135deg,var(--color-accent-red-start),var(--color-accent-red-end));-webkit-text-fill-color:transparent;filter:brightness(.5);-webkit-background-clip:text;background-clip:text;font-weight:600;transition:filter .8s}.accent-red.bright,.hero-line.active .accent-red{filter:brightness(1.3)drop-shadow(0 0 20px #e8175d4d)}.accent-blue{background:linear-gradient(135deg,var(--color-accent-blue-start),var(--color-accent-blue-end));-webkit-text-fill-color:transparent;transition:filter var(--transition-fast);filter:drop-shadow(0 0 12px #38bdf833);-webkit-background-clip:text;background-clip:text;font-weight:500}.accent-blue:hover{filter:drop-shadow(0 0 16px #38bdf866)}.hero{min-height:100dvh;padding:var(--space-lg);padding-left:clamp(var(--space-lg),10vw,12%);align-items:center;display:flex}.hero-content{max-width:900px}.hero-lines{gap:var(--space-xs);flex-direction:column;display:flex}.hero-line{font-family:var(--font-display);font-size:var(--text-hero);cursor:default;color:var(--color-text-muted);font-weight:700;line-height:1.15;transition:color .8s}.hero-line.active{color:var(--color-text-primary)}.hero-divider{background:linear-gradient(90deg,var(--color-accent-red-end),var(--color-accent-red-start));width:80px;height:2px;margin:var(--space-xl)0;opacity:.7}.hero-nav{align-items:center;gap:var(--space-md);flex-wrap:wrap;display:flex}.nav-link{font-size:var(--text-body);font-weight:500;position:relative}.nav-link:after{content:"";background:linear-gradient(90deg,var(--color-accent-blue-start),var(--color-accent-blue-end));width:0;height:1px;transition:width var(--transition-normal);position:absolute;bottom:-2px;left:0}.nav-link:hover:after{width:100%}.nav-separator{color:var(--color-text-muted);-webkit-user-select:none;user-select:none}.arrow{-webkit-text-fill-color:var(--color-accent-blue-start);animation:2s ease-in-out infinite bounce;display:inline-block}@keyframes bounce{0%,to{animation-timing-function:cubic-bezier(.8,0,1,1);transform:translateY(-25%)}50%{animation-timing-function:cubic-bezier(0,0,.2,1);transform:none}}.section-container{max-width:900px;padding:var(--space-3xl)var(--space-lg);margin:0 auto}.section-title{font-family:var(--font-display);font-size:var(--text-section-title);color:var(--color-text-primary);margin:0 0 var(--space-xl)0;font-weight:700;position:relative}.section-title:after{content:"";background:linear-gradient(90deg,var(--color-accent-red-start),var(--color-accent-red-end));width:40px;height:2px;position:absolute;bottom:-8px;left:0}.about{background:var(--color-bg-secondary);border-top:1px solid #ffffff0d;border-bottom:1px solid #ffffff0d}.about-content{gap:var(--space-md);flex-direction:column;display:flex}.about-content p{color:var(--color-text-secondary);max-width:65ch;font-size:var(--text-body);margin:0;line-height:1.8}.about-content p:first-child{color:var(--color-text-primary)}.skills{background:var(--color-bg-primary)}.skills-grid{gap:var(--space-xl);grid-template-columns:1fr;display:grid}@media(min-width:640px){.skills-grid{gap:var(--space-lg);grid-template-columns:repeat(3,1fr)}}.skill-category{padding:var(--space-lg);background:var(--color-bg-tertiary);transition:border-color var(--transition-normal),transform var(--transition-normal),box-shadow var(--transition-normal);border:1px solid #ffffff14;border-radius:12px;position:relative;overflow:hidden}.skill-category:before{content:"";background:linear-gradient(90deg,transparent,var(--color-accent-red-start),var(--color-accent-red-end),transparent);opacity:0;height:2px;transition:opacity var(--transition-normal);position:absolute;top:0;left:0;right:0}.skill-category:after{content:"";background:radial-gradient(circle at var(--mouse-x,50%)var(--mouse-y,50%),#e8175d0f,transparent 50%);pointer-events:none;opacity:0;transition:opacity var(--transition-normal);position:absolute;inset:0}.skill-category:hover{border-color:#ffffff26;transform:translateY(-4px);box-shadow:0 20px 40px #0006,0 0 60px #e8175d14}.skill-category:hover:before,.skill-category:hover:after{opacity:1}.skill-category-title{font-family:var(--font-display);color:var(--color-text-primary);margin:0 0 var(--space-md)0;padding-bottom:var(--space-sm);border-bottom:1px solid #ffffff14;font-size:1.1rem;font-weight:500}.skill-list{gap:var(--space-xs);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.skill-list li{color:var(--color-text-secondary);font-size:var(--text-small);padding:4px 0 4px 16px;position:relative}.skill-list li:before{content:"›";color:var(--color-text-muted);transition:color var(--transition-fast);position:absolute;left:0}.skill-list li:hover:before{color:var(--color-accent-red-start)}.projects-featured{background:var(--color-bg-primary)}.featured-project{background:var(--color-bg-tertiary);padding:var(--space-xl);transition:border-color var(--transition-normal),transform var(--transition-normal),box-shadow var(--transition-normal);border:1px solid #ffffff14;border-radius:16px;position:relative;overflow:hidden}.featured-project:before{content:"";background:linear-gradient(90deg,transparent,var(--color-accent-red-start),var(--color-accent-red-end),transparent);opacity:0;height:2px;transition:opacity var(--transition-normal);position:absolute;top:0;left:0;right:0}.featured-project:after{content:"";background:radial-gradient(circle at var(--mouse-x,50%)var(--mouse-y,50%),#e8175d0f,transparent 50%);pointer-events:none;opacity:0;transition:opacity var(--transition-normal);position:absolute;inset:0}.featured-project:hover{border-color:#ffffff26;transform:translateY(-4px);box-shadow:0 20px 40px #0006,0 0 60px #e8175d14}.featured-project:hover:before,.featured-project:hover:after{opacity:1}.project-header{margin-bottom:var(--space-lg)}.project-name{font-family:var(--font-display);font-size:var(--text-project-name);color:var(--color-text-primary);margin:0 0 var(--space-xs)0;font-weight:700}.project-tagline{font-size:var(--text-small);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.1em;margin:0}.project-description{margin-bottom:var(--space-lg)}.project-description p{color:var(--color-text-secondary);margin:0;line-height:1.7}.project-tech{gap:var(--space-xs);flex-wrap:wrap;display:flex}.tech-tag{color:var(--color-text-secondary);transition:all var(--transition-fast);background:#ffffff0d;border:1px solid #ffffff14;border-radius:6px;padding:6px 12px;font-size:.8rem}.tech-tag:hover{color:var(--color-text-primary);background:#ffffff14}.projects-other{background:var(--color-bg-secondary);border-top:1px solid #ffffff0d}.projects-mosaic{gap:var(--space-md);grid-template-rows:auto;grid-template-columns:1fr;display:grid}@media(min-width:768px){.projects-mosaic{gap:var(--space-lg);grid-template-rows:auto auto;grid-template-columns:1.4fr 1fr}.mosaic-card--large{grid-row:span 2}.mosaic-card--medium{grid-area:1/2}.mosaic-card--small{grid-area:2/2}}.mosaic-card{background:var(--color-bg-tertiary);transition:border-color var(--transition-normal),transform var(--transition-normal),box-shadow var(--transition-normal);border:1px solid #ffffff14;border-radius:16px;position:relative;overflow:hidden}.mosaic-card:before{content:"";background:linear-gradient(90deg,transparent,var(--color-accent-red-start),var(--color-accent-red-end),transparent);opacity:0;height:2px;transition:opacity var(--transition-normal);position:absolute;top:0;left:0;right:0}.mosaic-card:after{content:"";background:radial-gradient(circle at var(--mouse-x,50%)var(--mouse-y,50%),#e8175d0f,transparent 50%);pointer-events:none;opacity:0;transition:opacity var(--transition-normal);position:absolute;inset:0}.mosaic-card:hover{border-color:#ffffff26;transform:translateY(-4px);box-shadow:0 20px 40px #0006,0 0 60px #e8175d14}.mosaic-card:hover:before,.mosaic-card:hover:after{opacity:1}.mosaic-card-accent{display:none}.mosaic-card-content{padding:var(--space-lg);flex-direction:column;height:100%;display:flex}.mosaic-card-number{font-family:var(--font-display);color:var(--color-text-muted);letter-spacing:.15em;margin-bottom:var(--space-sm);opacity:.6;font-size:.7rem;font-weight:500}.mosaic-card-name{font-family:var(--font-display);color:var(--color-text-primary);margin:0 0 var(--space-xs)0;transition:color var(--transition-fast);font-size:clamp(1.25rem,3vw,1.5rem);font-weight:700}.mosaic-card:hover .mosaic-card-name{color:#fff}.mosaic-card-tagline{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.12em;margin:0 0 var(--space-md)0;font-size:.75rem}.mosaic-card-description{color:var(--color-text-secondary);font-size:var(--text-small);margin:0 0 var(--space-md)0;line-height:1.7}.mosaic-card-tech{margin-bottom:var(--space-sm);flex-wrap:wrap;gap:8px;display:flex}.tech-tag-small{color:var(--color-text-muted);transition:all var(--transition-fast);background:#ffffff0a;border:1px solid #ffffff14;border-radius:6px;padding:5px 10px;font-size:.7rem}.mosaic-card:hover .tech-tag-small{color:var(--color-text-secondary);background:#ffffff0f;border-color:#ffffff1f}.mosaic-card-link{font-size:var(--text-small);padding-top:var(--space-sm);width:fit-content;margin-top:auto;display:inline-block;position:relative}.mosaic-card-link:after{content:"";background:linear-gradient(90deg,var(--color-accent-blue-start),var(--color-accent-blue-end));width:0;height:1px;transition:width var(--transition-normal);position:absolute;bottom:-2px;left:0}.mosaic-card-link:hover:after{width:100%}.mosaic-card--large .mosaic-card-content{padding:var(--space-xl)}.mosaic-card--large .mosaic-card-name{font-size:clamp(1.5rem,4vw,2rem)}.mosaic-card--large .mosaic-card-description{font-size:var(--text-body);max-width:45ch}.mosaic-card--large .mosaic-card-tagline{margin-bottom:var(--space-lg)}.mosaic-card--medium .mosaic-card-content,.mosaic-card--small .mosaic-card-content{padding:var(--space-lg)}.footer{background:var(--color-bg-primary);padding:var(--space-xl)var(--space-lg);border-top:1px solid #ffffff0d}.footer-content{justify-content:space-between;align-items:center;gap:var(--space-md);flex-wrap:wrap;max-width:900px;margin:0 auto;display:flex}.footer-name{font-family:var(--font-display);color:var(--color-text-muted);font-size:1rem}.footer-links{gap:var(--space-md);display:flex}.footer-link{font-size:var(--text-small);color:var(--color-text-muted);transition:color var(--transition-fast)}.footer-link:hover{color:var(--color-text-primary)}.fade-in-section{opacity:0;transition:opacity .6s ease-out,transform .6s ease-out;transform:translateY(20px)}.fade-in-section.visible{opacity:1;transform:translateY(0)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.hero-content{animation:.6s ease-out fadeInUp}.hero-divider{animation:.6s ease-out .4s backwards fadeInUp}.hero-nav{animation:.6s ease-out .5s backwards fadeInUp}@media(max-width:480px){.hero{padding-left:var(--space-lg)}.hero-nav{gap:var(--space-sm)}.section-container{padding:var(--space-2xl)var(--space-md)}.featured-project{padding:var(--space-lg)}.project-card{padding:var(--space-md)}.footer-content{text-align:center;flex-direction:column}}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
