@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-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--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}*{border-color:var(--border)}}@layer components;@layer utilities{.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.border{border-style:var(--tw-border-style);border-width:1px}.filter{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))}@media(min-width:48rem){.md\:flex{display:flex}.md\:hidden{display:none}}}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#fff;background-color:#0a0a14;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;transition:background-color .5s,color .5s;overflow-x:hidden}code,.mono{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--background:#0a0a14;--foreground:#fff;--primary:#a855f7;--primary-hover:#9333ea;--secondary:#1a1a2e;--accent:#7c3aed;--border:#1e1e35;--muted:#94a3b8;--card:#0f0f1e;--radius:.75rem}html.light{--background:#f0e6f0;--foreground:#1a1a2e;--primary:#a855f7;--primary-hover:#9333ea;--secondary:#fff;--accent:#7c3aed;--border:#e2d5e2;--muted:#64748b;--card:#fff}html.light body{background-color:var(--background);color:var(--foreground)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--background)}::-webkit-scrollbar-thumb{background:var(--primary);border-radius:3px}.portfolio-bg{background:var(--background)}@keyframes heroBgShift{0%{opacity:.5;transform:translate(0)scale(1)}33%{opacity:.85;transform:translate(-3%,-3%)scale(1.05)}66%{opacity:.65;transform:translate(3%,2%)scale(1.02)}to{opacity:.5;transform:translate(0)scale(1)}}.hero-gradient{background:radial-gradient(ellipse 80% 60% at 50% 40%,#a855f738 0%,var(--background) 70%);transition:background .6s;position:relative;overflow:hidden}.hero-gradient:before{content:"";pointer-events:none;filter:blur(60px);background:radial-gradient(circle at 30% 30%,#a855f759,#0000 55%),radial-gradient(circle at 70% 60%,#7c3aed47,#0000 55%);animation:8s ease-in-out infinite heroBgShift;position:absolute;inset:-20%}html.light .hero-gradient{background:radial-gradient(ellipse 80% 60% at 50% 40%,#a855f71f 0%,var(--background) 70%)}html.light .hero-gradient:before{background:radial-gradient(circle at 30% 30%,#a855f738,#0000 55%),radial-gradient(circle at 70% 60%,#7c3aed29,#0000 55%)}.nav-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff12;border:1px solid #a855f74d;border-radius:50px;align-items:center;gap:24px;padding:8px 20px 8px 12px;transition:all .4s;display:flex;box-shadow:0 8px 32px #00000040}html.light .nav-card{background:#ffffffbf;border-color:#a855f738;box-shadow:0 8px 32px #0000001a}.nav-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:64px;height:64px}@media(max-width:480px){.nav-card{gap:12px;padding:6px 14px 6px 8px}.nav-avatar{width:40px;height:40px}}.nav-link{color:var(--muted);cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace;font-size:.875rem;transition:color .2s;display:flex}.nav-link:hover,.nav-link.active{color:var(--foreground)}@keyframes textGradientShift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}.gradient-text{-webkit-text-fill-color:transparent;background:linear-gradient(90deg,#c084fc,#a855f7,#7c3aed,#a855f7,#c084fc) 0 0/300% 300%;-webkit-background-clip:text;background-clip:text;animation:4s infinite textGradientShift}.cta-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#c084fc,#a855f7,#7c3aed) 0 0/200% 200%;border:none;border-radius:14px;align-items:center;gap:8px;padding:14px 36px;font-size:1rem;font-weight:600;transition:all .3s;display:inline-flex;position:relative;overflow:hidden;box-shadow:0 6px 24px #a855f766,inset 0 1px #fff3}.cta-button:before{content:"";opacity:0;pointer-events:none;background:linear-gradient(135deg,#ffffff40,#0000);transition:opacity .3s;position:absolute;inset:0}.cta-button:hover{transform:translateY(-3px);box-shadow:0 12px 36px #a855f780,inset 0 1px #ffffff4d}.cta-button:hover:before{opacity:1}.cta-button:active{transform:translateY(-1px)}.icon-btn{width:44px;height:44px;color:var(--muted);cursor:pointer;background:#a855f714;border:1px solid #a855f740;border-radius:50%;justify-content:center;align-items:center;transition:all .3s;display:flex}.icon-btn:hover{color:var(--primary);background:#a855f733;border-color:#a855f780;transform:scale(1.1)}@keyframes fadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.section-title{color:var(--foreground);align-items:center;gap:16px;margin-bottom:3rem;font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace;font-size:1.75rem;font-weight:600;transition:color .4s;display:flex}.section-title:after{content:"";background:linear-gradient(90deg,#a855f766,#0000);flex:1;max-width:200px;height:1px}.skill-card{background:var(--card);border:1px solid var(--border);aspect-ratio:1;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:20px;transition:all .2s;display:flex}.skill-card:hover{background:#a855f70d;border-color:#a855f766;transform:translateY(-2px)}.skill-icon{border-radius:10px;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.5rem;font-weight:700;display:flex}.project-card{background:var(--card);border:1px solid var(--border);border-radius:16px;grid-template-columns:1fr 1fr;min-height:200px;transition:border-color .2s,box-shadow .2s;display:grid;overflow:hidden}.project-card:hover{border-color:#a855f74d;box-shadow:0 8px 32px #a855f714}@media(max-width:768px){.project-card{grid-template-columns:1fr}}.social-btn{border:1px solid var(--border);background:var(--card);width:44px;height:44px;color:var(--muted);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;text-decoration:none;transition:all .2s;display:flex}.social-btn:hover{color:var(--primary);background:#a855f71a;border-color:#a855f780}.back-to-top{writing-mode:vertical-rl;text-orientation:mixed;color:var(--muted);letter-spacing:.1em;cursor:pointer;font-size:.75rem;transition:color .2s}.back-to-top:hover{color:var(--primary)}.about-photo-wrapper{padding:16px;position:relative}.about-photo{border-radius:2px;width:100%;height:100%;transition:transform .4s;overflow:hidden}.corner-border{background:var(--primary);z-index:4;opacity:0;transition:all .4s;position:absolute;box-shadow:0 0 8px #a855f799}.corner-border:after{content:"";background:var(--primary);position:absolute;box-shadow:0 0 8px #a855f799}.corner-border.top-left{width:3px;height:0;top:-16px;left:-16px}.corner-border.top-left:after{width:0;height:3px;top:0;left:0}.about-photo-wrapper:hover .corner-border.top-left{opacity:1;height:120px}.about-photo-wrapper:hover .corner-border.top-left:after{opacity:1;width:120px}.corner-border.top-right{width:3px;height:0;top:-16px;right:-16px}.corner-border.top-right:after{width:0;height:3px;top:0;right:0}.about-photo-wrapper:hover .corner-border.top-right{opacity:1;height:120px}.about-photo-wrapper:hover .corner-border.top-right:after{opacity:1;width:120px}.corner-border.bottom-left{width:3px;height:0;bottom:-16px;left:-16px}.corner-border.bottom-left:after{width:0;height:3px;bottom:0;left:0}.about-photo-wrapper:hover .corner-border.bottom-left{opacity:1;height:120px}.about-photo-wrapper:hover .corner-border.bottom-left:after{opacity:1;width:120px}.corner-border.bottom-right{width:3px;height:0;bottom:-16px;right:-16px}.corner-border.bottom-right:after{width:0;height:3px;bottom:0;right:0}.about-photo-wrapper:hover .corner-border.bottom-right{opacity:1;height:120px}.about-photo-wrapper:hover .corner-border.bottom-right:after{opacity:1;width:120px}.resume-btn{background:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;gap:0;width:48px;height:48px;text-decoration:none;transition:all .35s cubic-bezier(.4,0,.2,1);display:inline-flex;overflow:hidden;box-shadow:0 4px 16px #a855f759}.resume-btn .resume-label{opacity:0;white-space:nowrap;width:0;font-size:.9rem;font-weight:500;transition:all .35s cubic-bezier(.4,0,.2,1);overflow:hidden}.resume-btn:hover{border-radius:50px;gap:8px;width:130px;padding:0 18px 0 14px;box-shadow:0 6px 24px #a855f780}.resume-btn:hover .resume-label{opacity:1;width:auto}.tech-grid{grid-template-columns:repeat(5,1fr);gap:28px;max-width:1000px;margin:0 auto;display:grid}.tech-card{aspect-ratio:1;opacity:0;background:#14142a99;border:1px solid #a855f714;border-radius:24px;flex-direction:column;justify-content:center;align-items:center;transition:all .6s cubic-bezier(.22,1,.36,1);display:flex;position:relative;overflow:hidden;transform:translateY(30px)scale(.9)}.tech-card.visible{opacity:1;transform:translateY(0)scale(1)}.tech-card:hover{background:#a855f70f;border-color:#a855f740;transform:translateY(-4px)}.tech-icon{justify-content:center;align-items:center;width:80px;height:80px;margin-bottom:12px;display:flex}.tech-icon svg,.tech-icon img{object-fit:contain;width:100%;height:100%}.tech-label{color:var(--muted);letter-spacing:.08em;opacity:1;text-transform:uppercase;font-size:1rem;font-weight:700;transition:all .3s;transform:translateY(0)}@media(max-width:1024px){.tech-grid{grid-template-columns:repeat(4,1fr);max-width:800px}}@media(max-width:768px){.tech-grid{grid-template-columns:repeat(3,1fr);max-width:600px}.tech-icon{width:60px;height:60px}}@media(max-width:640px){.tech-grid{grid-template-columns:repeat(3,1fr);gap:14px}.tech-icon{width:50px;height:50px}.tech-label{font-size:.75rem}}@media(max-width:768px){.about-grid{grid-template-columns:1fr!important}.about-photo-wrapper{max-width:300px;margin:0 auto;width:100%!important;height:320px!important}}@keyframes enter{0%{opacity:var(--tw-enter-opacity,1);transform:translate3d(var(--tw-enter-translate-x,0),var(--tw-enter-translate-y,0),0) scale3d(var(--tw-enter-scale,1),var(--tw-enter-scale,1),var(--tw-enter-scale,1)) rotate(var(--tw-enter-rotate,0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity,1);transform:translate3d(var(--tw-exit-translate-x,0),var(--tw-exit-translate-y,0),0) scale3d(var(--tw-exit-scale,1),var(--tw-exit-scale,1),var(--tw-exit-scale,1)) rotate(var(--tw-exit-rotate,0))}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@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}
