:root{font-family:Figtree,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root,[data-theme=dark]{--bg: #0f0f0f;--bg-alt: #1c1c1c;--bg-alt2: #242424;--border: rgba(255, 107, 0, .18);--border-hi: #383838;--text: #f5f5f5;--text-muted: #737373;--text-dim: #555555;--text-faint: #333333;--orange: #ff6b00;--orange-hi: #ff9a40;--orange-lo: #cc4400;--orange-a44: #ff6b0044;--orange-a22: #ff6b0022;--orange-a12: #ff6b0012;--yellow: #facc15;--yellow-hi: #fde68a;--yellow-lo: #ca8a04;--yellow-a44: #facc1544;--yellow-a22: #facc1522;--btn-fg: #ffffff;--bg-primary: var(--bg);--bg-secondary: var(--bg-alt);--bg-card: var(--bg-alt2);--bg-hero: radial-gradient(ellipse at center, var(--orange-a12) 0%, transparent 70%);--bg-contact: radial-gradient(ellipse at center, var(--orange-a12) 0%, transparent 70%);--text-primary: var(--text);--text-secondary: var(--text-muted);--text-muted: var(--text-dim);--accent-primary: var(--orange);--accent-secondary: var(--orange-hi);--accent-tertiary: var(--yellow);--accent-quaternary: var(--yellow-hi);--border-primary: var(--border);--border-secondary: var(--border-hi);--shadow-primary: var(--orange-a22);--shadow-secondary: var(--orange-a44);--shadow-card: 0 20px 40px var(--orange-a12);--grid-color: var(--orange-a12);--code-bg: var(--bg-alt);--code-border: var(--border-hi);--code-text: var(--yellow-lo);--btn-radius: 16px;color-scheme:dark}body.light,[data-theme=light]{--bg: #f2f2f2;--bg-alt: #ffffff;--bg-alt2: #ffffff;--border: rgba(255, 107, 0, .18);--border-hi: #d4d4d4;--text: #222222;--text-muted: #888888;--text-dim: #737373;--text-faint: #d4d4d4;--orange: #ea580c;--orange-hi: #f97316;--orange-lo: #c2410c;--orange-a44: #ea580c33;--orange-a22: #ea580c18;--orange-a12: #ea580c0e;--yellow: #ca8a04;--yellow-hi: #facc15;--yellow-lo: #a16207;--yellow-a44: #ca8a0433;--yellow-a22: #ca8a0418;--btn-fg: #ffffff;--bg-primary: var(--bg);--bg-secondary: var(--bg-alt);--bg-card: var(--bg-alt2);--bg-hero: radial-gradient(ellipse at center, var(--orange-a12) 0%, transparent 70%);--bg-contact: radial-gradient(ellipse at center, var(--orange-a12) 0%, transparent 70%);--text-primary: var(--text);--text-secondary: var(--text-muted);--text-muted: var(--text-dim);--accent-primary: var(--orange);--accent-secondary: var(--orange-hi);--accent-tertiary: var(--yellow);--accent-quaternary: var(--yellow-hi);--border-primary: var(--border);--border-secondary: var(--border-hi);--shadow-primary: var(--orange-a12);--shadow-secondary: var(--orange-a22);--shadow-card: 0 20px 40px rgba(0, 0, 0, .05);--grid-color: var(--orange-a12);--code-bg: var(--bg-alt);--code-border: var(--border-hi);--code-text: var(--orange);--btn-radius: 16px;color-scheme:light}.theme-transition,.theme-transition *,.theme-transition *:before,.theme-transition *:after{transition:all .3s cubic-bezier(.4,0,.2,1)!important;transition-delay:0s!important}html{background:var(--bg-primary);color:var(--text-primary)}*{box-sizing:border-box}button,input,textarea,select{font:inherit}html{scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100vh;overflow-x:hidden}#root{width:100%;min-height:100vh}a{font-weight:500;color:#ff6b00;text-decoration:inherit;transition:color .3s ease}a:hover{color:#ff9a40}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600}p{margin:0}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-alt)}::-webkit-scrollbar-thumb{background:linear-gradient(45deg,var(--orange),var(--orange-hi));border-radius:4px}::-webkit-scrollbar-thumb:hover{background:linear-gradient(45deg,var(--orange-hi),var(--yellow))}::selection{background:var(--orange-a44);color:#fff}.theme-toggle{position:fixed;top:2rem;right:2rem;z-index:1000;background:none;border:none;cursor:pointer;padding:0;border-radius:var(--btn-radius);transition:all .3s ease}.theme-toggle:hover{transform:scale(1.05)}.theme-toggle-track{width:60px;height:30px;background:var(--toggle-bg);border-radius:20px;position:relative;border:2px solid var(--toggle-border);transition:all .3s ease;box-shadow:inset 0 2px 4px var(--toggle-shadow-inner),0 4px 12px var(--toggle-shadow-outer)}.theme-toggle-thumb{width:24px;height:24px;background:var(--toggle-thumb-bg);border-radius:50%;position:absolute;top:1px;left:1px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px var(--toggle-thumb-shadow)}[data-theme=light] .theme-toggle-thumb{transform:translate(30px)}.theme-icon{color:var(--toggle-icon-color);display:flex;align-items:center;justify-content:center;transition:all .3s ease}.theme-toggle:hover .theme-icon{transform:scale(1.1)}[data-theme=dark]{--toggle-bg: linear-gradient(135deg, #1a1a2e, #16213e);--toggle-border: rgba(100, 108, 255, .3);--toggle-shadow-inner: rgba(0, 0, 0, .3);--toggle-shadow-outer: rgba(100, 108, 255, .2);--toggle-thumb-bg: linear-gradient(135deg, var(--orange), var(--orange-hi));--toggle-thumb-shadow: var(--orange-a44);--toggle-icon-color: white}[data-theme=light]{--toggle-bg: linear-gradient(135deg, #f0f0f0, #e0e0e0);--toggle-border: rgba(0, 0, 0, .1);--toggle-shadow-inner: rgba(0, 0, 0, .1);--toggle-shadow-outer: rgba(0, 0, 0, .1);--toggle-thumb-bg: linear-gradient(135deg, var(--orange), var(--orange-hi));--toggle-thumb-shadow: var(--orange-a22);--toggle-icon-color: #333}@media(max-width:768px){.theme-toggle{top:1rem;right:1rem}.theme-toggle-track{width:50px;height:25px}.theme-toggle-thumb{width:21px;height:21px}[data-theme=light] .theme-toggle-thumb{transform:translate(25px)}.theme-icon svg{width:12px;height:12px}}.particle-canvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:-1;pointer-events:none;opacity:.8;transition:opacity .3s ease}@media(max-width:768px){.particle-canvas{opacity:.6}}@media(max-width:480px){.particle-canvas{opacity:.4}}@media(prefers-reduced-motion:reduce){.particle-canvas{opacity:.2}}.social-links{position:fixed;left:1rem;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:.75rem;z-index:1000}.social-link{height:56px;width:56px;display:inline-flex;align-items:center;justify-content:center;border-radius:9999px;background:linear-gradient(var(--bg-card),var(--bg-card)) padding-box,linear-gradient(45deg,var(--accent-primary),var(--accent-secondary)) border-box;border:2px solid transparent;color:var(--text-primary);box-shadow:0 6px 18px var(--shadow-primary);transition:transform .2s ease,box-shadow .2s ease,background .2s ease,color .2s ease;will-change:transform,box-shadow,background}.social-link:hover{transform:translateY(-2px) scale(1.08);background:linear-gradient(45deg,var(--accent-primary),var(--accent-secondary));color:#fff;box-shadow:0 8px 24px var(--shadow-secondary)}.social-link svg{width:26px;height:26px}.social-link:nth-child(1){background:linear-gradient(var(--bg-card),var(--bg-card)) padding-box,linear-gradient(45deg,#0a66c2,#39f) border-box}.social-link:nth-child(2){background:linear-gradient(var(--bg-card),var(--bg-card)) padding-box,linear-gradient(45deg,#111827,#6b7280) border-box}.social-link:nth-child(3){background:linear-gradient(var(--bg-card),var(--bg-card)) padding-box,linear-gradient(45deg,#ec4899,#7c3aed) border-box}.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}@media(max-width:768px){.social-links{top:auto;bottom:1rem;transform:none;left:50%;transform:translate(-50%);flex-direction:row;justify-content:center;width:auto}.social-link{height:48px;width:48px}.social-link svg{width:22px;height:22px}}.contact-form{width:100%;max-width:640px;margin-top:1.5rem;display:flex;flex-direction:column;gap:1rem}.form-field{display:flex;flex-direction:column;gap:.5rem}.form-field label{font-weight:600;color:var(--text-primary)}.form-field input,.form-field textarea{width:100%;padding:.9rem 1rem;border-radius:12px;border:1px solid var(--border-primary);background:var(--bg-card);color:var(--text-primary);outline:none;font:inherit;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.form-field input::placeholder,.form-field textarea::placeholder{color:var(--text-muted);font-family:inherit}.form-field input:focus,.form-field textarea:focus{border-color:var(--border-secondary);box-shadow:0 0 0 4px #646cff26}.contact-submit{align-self:center;padding:.9rem 1.75rem;border-radius:var(--btn-radius);border:none;font-weight:700;cursor:pointer;background:linear-gradient(45deg,var(--accent-primary),var(--accent-secondary));color:#fff;box-shadow:0 6px 18px var(--shadow-secondary);transition:transform .2s ease,box-shadow .2s ease}.contact-submit:hover{transform:translateY(-2px);box-shadow:0 10px 26px var(--shadow-secondary)}.contact-submit:disabled{opacity:.7;cursor:not-allowed}.contact-success{max-width:640px;margin-top:1.5rem;padding:1.25rem 1rem;background:var(--bg-card);border:1px solid var(--border-primary);border-radius:16px;text-align:center;box-shadow:0 8px 24px var(--shadow-primary)}.success-icon{font-size:2rem;margin-bottom:.5rem}@media(max-width:480px){.contact-form{max-width:100%}}.section-tracker{position:fixed;right:1rem;top:50%;transform:translateY(-50%);height:70vh;z-index:1000;pointer-events:none}.tracker-line{position:absolute;right:21px;top:0;bottom:0;width:2px;background:linear-gradient(180deg,var(--accent-primary),var(--accent-secondary));border-radius:2px;opacity:.5}.tracker-items{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:0;align-items:flex-end;height:100%;justify-content:space-between;pointer-events:auto}.tracker-items li{display:flex}.tracker-dot{display:inline-flex;flex-direction:row-reverse;align-items:center;justify-content:flex-start;gap:8px;background:transparent;border:none;padding:0;cursor:pointer;z-index:50}.tracker-dot:hover{transform:translateY(-2px) scale(1.05)}.tracker-dot .icon-wrap{height:42px;width:42px;display:inline-flex;align-items:center;justify-content:center;border-radius:9999px;background:linear-gradient(var(--bg-card),var(--bg-card)) padding-box,linear-gradient(45deg,var(--accent-primary),var(--accent-secondary)) border-box;border:2px solid transparent;color:var(--text-primary);box-shadow:0 4px 12px var(--shadow-primary);transition:transform .2s ease,box-shadow .2s ease,background .2s ease;line-height:1;font-size:18px}.tracker-label{white-space:nowrap;color:var(--text-primary);max-width:0;opacity:0;overflow:hidden;padding:6px 10px;border-radius:9999px;background:linear-gradient(var(--bg-card),var(--bg-card)) padding-box,linear-gradient(45deg,var(--accent-primary),var(--accent-secondary)) border-box;border:2px solid transparent;transition:max-width .25s ease,opacity .2s ease,background .2s ease,color .2s ease}.tracker-dot:hover .tracker-label,.tracker-dot.active .tracker-label{max-width:140px;opacity:1;background:linear-gradient(45deg,var(--accent-primary),var(--accent-secondary));color:#fff}.tracker-dot:hover .icon-wrap,.tracker-dot.active .icon-wrap{transform:scale(1.05);background:linear-gradient(45deg,var(--accent-primary),var(--accent-secondary));color:#fff}@media(max-width:768px){.section-tracker{display:none}}@media(prefers-reduced-motion:reduce){.tracker-dot{transition:none}}.skills{position:relative;padding:5rem 0}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2rem;margin-top:3rem}.skill-category{background:var(--bg-card);border-radius:16px;padding:2rem;border:1px solid var(--border-primary);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.skill-category:hover{transform:translateY(-5px);box-shadow:0 15px 35px var(--shadow-primary)}.skill-category h3{font-size:1.3rem;color:var(--accent-primary);margin-bottom:1.5rem;text-align:center;position:relative}.skill-category h3:after{content:"";position:absolute;bottom:-.5rem;left:50%;transform:translate(-50%);width:40px;height:2px;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));border-radius:2px}.skill-icons{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem}.skill-item{display:flex;flex-direction:column;align-items:center;padding:1rem;background:#ffffff0d;border-radius:12px;border:1px solid var(--border-primary);transition:all .3s ease;cursor:pointer}.skill-item:hover{background:#ffffff1a;transform:translateY(-3px);border-color:var(--accent-primary);box-shadow:0 8px 20px var(--shadow-primary)}.skill-icon{font-size:2.5rem;margin-bottom:.5rem;transition:all .3s ease;filter:grayscale(.3)}.skill-icon img{width:40px;height:40px;object-fit:contain;display:block}.skill-item:hover .skill-icon{transform:scale(1.1);filter:grayscale(0) brightness(1.2)}.skill-name{font-size:.9rem;font-weight:500;color:var(--text-primary);text-align:center;line-height:1.2}@media(max-width:768px){.skills-grid{grid-template-columns:1fr;gap:1.5rem}.skill-category{padding:1.5rem}.skill-icons{grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:.8rem}.skill-item{padding:.8rem}.skill-icon{font-size:2rem}.skill-name{font-size:.8rem}}@media(max-width:480px){.skill-icons{grid-template-columns:repeat(2,1fr)}.skill-category h3{font-size:1.1rem}}.about{position:relative;padding:8rem 0;overflow:hidden}.about-layout{display:flex;align-items:center;gap:4rem;max-width:1100px;margin:0 auto}.about-image-card{flex:0 0 315px;aspect-ratio:1;background:#141414;border-radius:999px;border:1px solid var(--accent-secondary);display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:-1px 5px 8px #0000004d;position:relative}.about-img{width:100%;height:100%;object-fit:cover;object-position:46% center;filter:drop-shadow(0 10px 20px rgba(0,0,0,.5));transition:transform .3s ease}.about-img:hover{transform:scale(1.05)}.about-content{flex:1;display:flex;flex-direction:column;gap:1.8rem}.about-content p{font-size:1.2rem;line-height:1.6;color:#a0a0a0;margin:0}[data-theme=light] .about-content p{color:#222}.about-content .highlight{color:var(--accent-primary);font-weight:600}.about-content strong{color:#fff;font-weight:600}[data-theme=light] .about-content strong{color:#000}@media(max-width:968px){.about-layout{flex-direction:column;text-align:center;gap:3rem}.about-image-card{flex:0 0 300px;width:300px}.about-content p{font-size:1.1rem}}.experience{padding:5rem 0}.timeline{position:relative;padding-left:2.5rem;margin-top:1rem}.timeline:before{content:"";position:absolute;left:17px;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,transparent,var(--accent-primary) 10%,var(--accent-tertiary) 50%,var(--accent-primary) 90%,transparent);border-radius:2px}.timeline-item{position:relative;margin-bottom:2.5rem;opacity:0;transform:translateY(52px) scale(.98);transition:opacity .55s cubic-bezier(.22,1,.36,1) var(--delay, 0ms),transform .55s cubic-bezier(.22,1,.36,1) var(--delay, 0ms)}.timeline-item.exp-animate{opacity:1;transform:translateY(0) scale(1)}.timeline-item:last-child{margin-bottom:0}.timeline-node{position:absolute;left:-2rem;top:1.4rem;width:20px;height:20px;display:flex;align-items:center;justify-content:center}.timeline-node-inner{width:12px;height:12px;border-radius:50%;background:var(--accent-primary);box-shadow:0 0 0 3px var(--orange-a44),0 0 12px var(--accent-primary);transition:box-shadow .3s ease,transform .3s ease}.timeline-item:hover .timeline-node-inner{box-shadow:0 0 0 5px var(--orange-a44),0 0 20px var(--accent-primary);transform:scale(1.2)}.timeline-content{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:1.75rem 2rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 24px var(--orange-a12);transition:border-color .3s ease,box-shadow .3s ease,transform .3s ease}.timeline-content:hover{border-color:var(--accent-secondary);box-shadow:0 8px 32px var(--orange-a22);transform:translateY(-2px)}.experience-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.experience-title-block{flex:1;min-width:0}.exp-role{font-size:1.2rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem;line-height:1.3}.company-line{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.company{font-size:1rem;font-weight:600;color:var(--accent-primary)}.emp-type{font-size:.78rem;color:var(--text-primary);background:var(--orange-a12);border:1px solid var(--orange-a22);border-radius:20px;padding:.15rem .6rem;font-weight:500}.experience-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.4rem;flex-shrink:0}.meta-pill{display:inline-flex;align-items:center;gap:.35rem;font-size:.78rem;color:var(--text-primary);background:var(--bg-alt);border:1px solid var(--border-primary);border-radius:20px;padding:.2rem .75rem;white-space:nowrap}.meta-icon{font-size:.75rem;line-height:1}.experience-desc{list-style:none;padding:0;margin:0 0 1.25rem;display:flex;flex-direction:column;gap:.55rem}.experience-desc li{position:relative;padding-left:1.25rem;font-size:.92rem;color:var(--text-primary);line-height:1.65}.experience-desc li:before{content:"→";position:absolute;left:0;color:var(--accent-primary);font-weight:700;font-size:.85rem}.exp-tags{display:flex;flex-wrap:wrap;gap:.45rem}.exp-tag{font-size:.78rem;font-weight:600;padding:.25rem .75rem;border-radius:20px;background:var(--orange-a12);border:1px solid var(--orange-a22);color:var(--accent-primary);transition:background .2s ease,border-color .2s ease}.exp-tag:hover{background:var(--orange-a22);border-color:var(--accent-primary)}[data-theme=light] .timeline-content{box-shadow:0 4px 24px #0000000f}[data-theme=light] .timeline-content:hover{box-shadow:0 8px 32px var(--orange-a22)}[data-theme=light] .meta-pill{background:var(--bg-alt2)}.experience-loading,.experience-empty{text-align:center;padding:3rem;background:var(--bg-card);border:1px solid var(--border-primary);border-radius:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.loading-spinner{font-size:2rem;margin-bottom:1rem;animation:spin 2s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.timeline{padding-left:0}.timeline:before,.timeline-node{display:none}.timeline-content{padding:1.25rem}.experience-header{flex-direction:column;gap:.75rem}.experience-meta{align-items:flex-start;flex-direction:row;flex-wrap:wrap}.exp-role{font-size:1.05rem}}@media(max-width:480px){.timeline{padding-left:0}.timeline-content{padding:1rem}}*{margin:0;padding:0;box-sizing:border-box}.scroll-progress{position:fixed;top:0;left:0;width:100%;height:4px;z-index:1000;background:var(--border-primary)}.scroll-progress-bar{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary),var(--accent-tertiary),var(--accent-quaternary));transition:width .1s ease;box-shadow:0 0 10px var(--accent-primary)}.grid-background{position:fixed;top:0;left:0;width:100%;height:100%;background-image:linear-gradient(var(--grid-color) 1px,transparent 1px),linear-gradient(90deg,var(--grid-color) 1px,transparent 1px);background-size:50px 50px;pointer-events:none;z-index:-1;animation:gridMove 20s linear infinite}@keyframes gridMove{0%{transform:translate(0)}to{transform:translate(50px,50px)}}.parallax-shape{position:fixed;pointer-events:none;z-index:-1}.shape-1{width:200px;height:200px;background:linear-gradient(45deg,#ff6b0033,#ff6b001f);border-radius:50%;top:20%;right:10%;filter:blur(40px)}.shape-2{width:300px;height:300px;background:linear-gradient(-45deg,#facc152e,#cc44002e);border-radius:30% 70% 70% 30%/30% 30% 70% 70%;bottom:20%;left:10%;filter:blur(60px)}.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;padding:2rem;background:var(--bg-hero)}.floating-code-blocks{position:absolute;width:100%;height:100%;pointer-events:none}.floating-code-blocks .code-block{pointer-events:auto}.code-block{position:absolute;background:var(--code-bg);border:1px solid var(--code-border);border-radius:8px;padding:1rem;font-family:Courier New,monospace;font-size:.8rem;color:var(--code-text);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 32px var(--shadow-primary);will-change:transform}.code-1{top:20%;left:7%;animation:float1 6s ease-in-out infinite}.code-2{top:60%;right:15%;animation:float2 8s ease-in-out infinite}.code-3{bottom:20%;left:15%;animation:float3 7s ease-in-out infinite}.code-block:hover{animation-play-state:paused}@keyframes jiggle-right{0%{transform:translate(var(--tx, 0px),var(--ty, 0px)) translate(0)}35%{transform:translate(var(--tx, 0px),var(--ty, 0px)) translate(8px)}65%{transform:translate(var(--tx, 0px),var(--ty, 0px)) translate(-4px)}85%{transform:translate(var(--tx, 0px),var(--ty, 0px)) translate(2px)}to{transform:translate(var(--tx, 0px),var(--ty, 0px)) translate(0)}}@keyframes jiggle-left{0%{transform:translate(var(--tx, 0px),var(--ty, 0px)) translate(0)}35%{transform:translate(var(--tx, 0px),var(--ty, 0px)) translate(-8px)}65%{transform:translate(var(--tx, 0px),var(--ty, 0px)) translate(4px)}85%{transform:translate(var(--tx, 0px),var(--ty, 0px)) translate(-2px)}to{transform:translate(var(--tx, 0px),var(--ty, 0px)) translate(0)}}@keyframes jiggle-down{0%{transform:translate(var(--tx, 0px),var(--ty, 0px)) translateY(0)}35%{transform:translate(var(--tx, 0px),var(--ty, 0px)) translateY(8px)}65%{transform:translate(var(--tx, 0px),var(--ty, 0px)) translateY(-4px)}85%{transform:translate(var(--tx, 0px),var(--ty, 0px)) translateY(2px)}to{transform:translate(var(--tx, 0px),var(--ty, 0px)) translateY(0)}}@keyframes jiggle-up{0%{transform:translate(var(--tx, 0px),var(--ty, 0px)) translateY(0)}35%{transform:translate(var(--tx, 0px),var(--ty, 0px)) translateY(-8px)}65%{transform:translate(var(--tx, 0px),var(--ty, 0px)) translateY(4px)}85%{transform:translate(var(--tx, 0px),var(--ty, 0px)) translateY(-2px)}to{transform:translate(var(--tx, 0px),var(--ty, 0px)) translateY(0)}}.code-block.jiggle-right{animation:jiggle-right .42s cubic-bezier(.22,1,.36,1);animation-play-state:running}.code-block.jiggle-left{animation:jiggle-left .42s cubic-bezier(.22,1,.36,1);animation-play-state:running}.code-block.jiggle-down{animation:jiggle-down .42s cubic-bezier(.22,1,.36,1);animation-play-state:running}.code-block.jiggle-up{animation:jiggle-up .42s cubic-bezier(.22,1,.36,1);animation-play-state:running}@media(prefers-reduced-motion:reduce){.code-block.jiggle-right,.code-block.jiggle-left,.code-block.jiggle-down,.code-block.jiggle-up{animation-duration:.2s}}@keyframes float1{0%,to{transform:translate(var(--tx, 0px),var(--ty, 0px)) translateY(0) rotate(0)}50%{transform:translate(var(--tx, 0px),var(--ty, 0px)) translateY(-20px) rotate(2deg)}}@keyframes float2{0%,to{transform:translate(var(--tx, 0px),var(--ty, 0px)) translateY(0) rotate(0)}50%{transform:translate(var(--tx, 0px),var(--ty, 0px)) translateY(-30px) rotate(-2deg)}}@keyframes float3{0%,to{transform:translate(var(--tx, 0px),var(--ty, 0px)) translateY(0) rotate(0)}50%{transform:translate(var(--tx, 0px),var(--ty, 0px)) translateY(-25px) rotate(1deg)}}.hero-content{text-align:center;z-index:2;max-width:800px;width:100%}.hero-title{font-size:clamp(2.5rem,8vw,5rem);font-weight:700;margin-bottom:1rem;line-height:1.1}.gradient-text{background:linear-gradient(45deg,var(--accent-primary),var(--accent-secondary),var(--accent-tertiary),var(--accent-quaternary));background-size:300% 300%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradientShift 3s ease-in-out infinite}.subtitle-line{display:block;margin-top:.5rem}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.hero-subtitle{font-size:1.2rem;margin-bottom:2rem;color:var(--text-primary)}.tech-icons{display:flex;justify-content:center;gap:2rem;margin:2rem 0}.tech-icon{width:60px;height:60px;display:flex;align-items:center;justify-content:center;font-size:2rem;border-radius:50%;background:var(--bg-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-primary);transition:all .3s ease;animation:iconFloat 4s ease-in-out infinite;position:relative}.tech-icon:hover{transform:scale(1.2) rotate(10deg);box-shadow:0 10px 30px var(--shadow-secondary)}.tech-icon:before{content:attr(title);position:absolute;top:-55px;left:50%;transform:translate(-50%);background:#ff6b00;color:#fff;padding:.6rem 1rem;border-radius:8px;font-size:.8rem;font-weight:600;white-space:nowrap;opacity:0;visibility:hidden;transition:all .3s ease;pointer-events:none;border:1px solid rgba(255,107,0,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 20px #ff6b004d;z-index:1000}.tech-icon:after{content:"";position:absolute;top:-47px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:8px solid #ff6b00;opacity:0;visibility:hidden;transition:all .3s ease;pointer-events:none;z-index:1001}.tech-icon:hover:before,.tech-icon:hover:after{opacity:1;visibility:visible;transform:translate(-50%) translateY(5px)}.think-icon{animation-delay:0s}.code-icon{animation-delay:.5s}.coffee-icon{animation-delay:1s}@keyframes iconFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.hero-buttons{display:flex;gap:1rem;justify-content:center;align-items:center;flex-wrap:wrap;margin-top:1rem}.cta-button,.contact-button,.resume-button{position:relative;padding:1rem 2rem;font-size:1.1rem;font-weight:600;border:none;border-radius:var(--btn-radius);cursor:pointer;overflow:hidden;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.5rem;min-height:56px;box-sizing:border-box}.cta-button,.contact-button{background:linear-gradient(45deg,var(--accent-primary),var(--accent-secondary));color:#fff;box-shadow:0 4px 15px var(--shadow-secondary)}.resume-button{background:#ffffff1a;color:var(--text-primary);border:1px solid var(--border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 15px var(--orange-a22)}.cta-button:hover,.contact-button:hover{transform:translateY(-2px);box-shadow:0 8px 25px #ff6b0066}.resume-button:hover{transform:translateY(-2px);background:#fff3;border-color:var(--accent-secondary);box-shadow:0 8px 25px var(--shadow-secondary)}.button-icon{font-size:1rem;transition:transform .3s ease;line-height:1}.resume-button:hover .button-icon{transform:scale(1.1) rotate(5deg)}.ripple{position:absolute;border-radius:50%;background:#fff9;transform:scale(0);animation:rippleEffect .6s linear;pointer-events:none}@keyframes rippleEffect{to{transform:scale(4);opacity:0}}.container{max-width:1200px;margin:0 auto;padding:0 2rem}section{padding:5rem 0}section h2{font-size:2.5rem;text-align:center;margin-bottom:3rem;background:linear-gradient(45deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,350px);justify-content:center;justify-items:center;gap:2rem;margin-top:3rem}.project-card{display:flex;flex-direction:column;background:var(--bg-card);border-radius:20px;overflow:hidden;border:1px solid var(--border-primary);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease;transform-style:preserve-3d;perspective:1000px;width:350px}.project-card:hover{transform:translateY(-10px) rotateX(5deg) rotateY(5deg);box-shadow:var(--shadow-card)}.project-image{height:200px;background:linear-gradient(45deg,#ff6b001a,#facc151a);display:flex;align-items:center;justify-content:center}.project-placeholder{font-size:3rem}.project-content{padding:1.5rem;display:flex;flex-direction:column;flex-grow:1}.project-content h3{font-size:1.3rem;margin-bottom:.5rem;color:var(--accent-primary)}.project-content p{color:var(--text-primary);margin-bottom:1rem;line-height:1.6;flex-grow:1}.project-tech{display:flex;gap:.5rem;flex-wrap:wrap}.project-tech span{padding:.3rem .8rem;background:#ff6b0026;border-radius:20px;font-size:.8rem;border:1px solid var(--border-secondary)}.project-actions{display:flex;gap:.5rem;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border-primary)}.project-link{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;font-size:.9rem;font-weight:500;text-decoration:none;color:var(--text-primary);background:#ffffff0d;border:1px solid var(--border-primary);transition:all .3s ease;flex:1;justify-content:center;min-width:0}.project-link:hover{transform:translateY(-2px);box-shadow:0 8px 25px #00000026;border-color:var(--accent-primary)}.demo-link:hover{background:linear-gradient(45deg,var(--accent-primary),var(--accent-secondary));color:#fff;border-color:transparent}.repo-link:hover{background:#ffffff1a}.link-icon{width:16px;height:16px;flex-shrink:0}.link-text{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-tech,.project-actions{margin-top:auto}.contact{text-align:center;background:var(--bg-contact)}.contact p{font-size:1.1rem;margin-bottom:2rem;color:var(--text-primary)}.scroll-animate{opacity:0;transform:translateY(50px);transition:all .8s ease}.scroll-animate.animate{opacity:1;transform:translateY(0)}.scroll-animate:nth-child(1){transition-delay:.1s}.scroll-animate:nth-child(2){transition-delay:.2s}.scroll-animate:nth-child(3){transition-delay:.3s}.scroll-animate:nth-child(4){transition-delay:.4s}@media(pointer:coarse){.custom-cursor,.cursor-trail{display:none!important}}[data-theme=light] .cursor-trail{background:radial-gradient(circle,transparent 30%,rgba(234,88,12,.2) 50%,transparent 70%)}[data-theme=light] .shape-1{background:linear-gradient(45deg,#ea580c33,#ea580c1f)}[data-theme=light] .shape-2{background:linear-gradient(-45deg,#ca8a0433,#ca44002e)}[data-theme=light] .project-image{background:linear-gradient(45deg,#ea580c1a,#ca8a041a)}[data-theme=light] .project-tech span{background:#ea580c26}[data-theme=light] .cta-button:hover,[data-theme=light] .contact-button:hover{box-shadow:0 8px 25px #ea580c66}[data-theme=light] .resume-button{background:#0000000d}[data-theme=light] .resume-button:hover{background:#0000001a}[data-theme=light] .code-icon img{content:url(/code-black.svg)}@media(max-width:768px){.hero{padding:1rem}.hero-title{font-size:2.5rem}.hero-buttons{flex-direction:column;gap:.8rem}.cta-button,.resume-button,.contact-button{width:100%;max-width:280px;justify-content:center}.tech-icons{gap:1rem}.tech-icon{width:50px;height:50px;font-size:1.5rem}.projects-grid{grid-template-columns:1fr;gap:1.5rem}.project-card{width:100%}.contact{padding-bottom:8rem}.floating-code-blocks{display:none}.code-block{font-size:.7rem;padding:.8rem}.timeline-content{padding:1.5rem}.experience-header h3{font-size:1.2rem}.company{font-size:1rem}}@media(max-width:480px){.container{padding:0 1rem}section{padding:3rem 0}section h2{font-size:2rem}}
