@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700;800&family=Space+Mono:wght@400;700&family=Syne:wght@700;800;900&display=swap";:root{--bg-primary:#f2f2f2;--bg-secondary:#e5e5e5;--bg-card:#fff;--bg-card-hover:#fcfcfc;--text-primary:#1a1a1a;--text-secondary:#333;--text-muted:#666;--accent:#1a1a1a;--accent-warm:#1a1a1a;--accent-warn-lt:#333;--accent-gradient:linear-gradient(90deg,#1a1a1a 0%,#333 100%);--border:#1a1a1a;--border-light:#1a1a1a;--font-primary:"Space Grotesk",system-ui,sans-serif;--font-display:"Syne",sans-serif;--font-mono:"Space Mono",monospace;--radius-sm:6px;--radius-md:6px;--radius-lg:6px;font-family:var(--font-primary);color:var(--text-primary);background-color:var(--bg-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;font-weight:400;line-height:1.6}html.dark-theme{--bg-primary:#111;--bg-secondary:#1a1a1a;--bg-card:#000;--bg-card-hover:#080808;--text-primary:#f2f2f2;--text-secondary:#ccc;--text-muted:#888;--accent:#f2f2f2;--accent-warm:#f2f2f2;--accent-warn-lt:#ccc;--accent-gradient:linear-gradient(90deg,#f2f2f2 0%,#ccc 100%);--border:#f2f2f2;--border-light:#f2f2f2}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background-color:var(--bg-primary);min-width:320px;min-height:100vh;color:var(--text-primary);margin:0;overflow-x:hidden}#root{width:100%;min-height:100vh}a{color:var(--text-primary);font-weight:600;text-decoration:none;transition:color .2s}a:hover{color:var(--accent-warm)}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:800;line-height:1.1}::selection{background:var(--accent);color:#fff}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:0}::-webkit-scrollbar-thumb:hover{background:var(--accent-warm)}*{cursor:none!important}.circle-cursor{pointer-events:none;z-index:99999;will-change:transform;mix-blend-mode:difference;transition:width .3s cubic-bezier(.23,1,.32,1),height .3s cubic-bezier(.23,1,.32,1),border-color .3s,background-color .3s;position:fixed;top:0;left:0}.circle-cursor.cursor-hover{background-color:#00ffc814;border-radius:50%;border-color:#00ffc8cc!important;width:20px!important;height:20px!important}.circle-cursor.cursor-click{border-color:#00dcff!important;transform:scale(.6)!important}.circle-cursor-trail{pointer-events:none;z-index:99998;will-change:transform;opacity:.7;transition:opacity .3s,width .4s,height .4s;position:fixed;top:0;left:0}.circle-cursor-trail.trail-hover{opacity:.9;width:80px!important;height:80px!important}.circle-cursor-trail.trail-click{opacity:.3}@font-face{font-family:Billy-Font;src:url(/assets/billy-custom-B_ZRq6qT.ttf)format("truetype");font-weight:400;font-style:normal}.header{z-index:999;background-color:var(--bg-primary);border-bottom:2px solid var(--border);justify-content:space-between;align-items:center;width:100%;height:80px;padding:0 60px;transition:all .3s;animation:.55s forwards fadein;display:flex;position:fixed;top:0;left:0}.header.scrolled{-webkit-backdrop-filter:blur(12px);background-color:#fff9;border-bottom:2px solid #0000001a}.dark-theme .header.scrolled{background-color:#0009}.left-section{align-items:center;display:flex}.name-logo{font-family:var(--font-display);color:var(--text-primary);opacity:1;cursor:pointer;letter-spacing:-1px;margin:-30px;font-size:1.8rem;font-weight:900;transition:all .2s}.name-logo:hover{color:var(--text-secondary)}.name-logo *{color:var(--text-primary)!important}.header_items{gap:40px;display:flex}.header_items ul{align-items:baseline;gap:32px;margin:0;padding:0;list-style:none;display:flex}.header_item-text{font-family:var(--font-mono);color:var(--text-primary);text-transform:uppercase;letter-spacing:1px;font-size:.85rem;font-weight:700;text-decoration:none;transition:all .2s;position:relative}.header_item-text:hover,.header_item-text.active{color:var(--text-muted)}.header_item-text.active:after{content:"";background-color:var(--text-primary);width:100%;height:4px;position:absolute;bottom:-4px;left:0}.header-buttons{align-items:center;gap:12px;margin-left:20px;display:flex}.btn-primary.btn-resume:hover{color:var(--text-primary)!important;box-shadow:6px 6px 0 var(--border)!important;background-color:#0000!important}.btn-primary.btn-resume:active{color:var(--text-primary)!important;box-shadow:2px 2px 0 var(--border)!important;background-color:#0000!important;transform:translate(2px,2px)!important}.btn-theme-toggle{background-color:var(--bg-card);color:var(--text-primary);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.2rem;display:flex}.mobile-hamburger{color:var(--text-primary);cursor:pointer;background:0 0;border:none;margin-left:16px;font-size:1.8rem;display:none}@keyframes fadein{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:968px){.header_items ul{background:var(--bg-primary);border-left:2px solid var(--border);z-index:1000;flex-direction:column;align-items:flex-start;gap:24px;width:70%;height:calc(100vh - 80px);padding:30px 20px;transition:transform .4s;position:fixed;top:80px;right:0;transform:translate(100%)}.header_items ul.mobile-open{transform:translate(30%)}.mobile-hamburger{display:block}}::view-transition-old(root){mix-blend-mode:normal;animation:none}::view-transition-new(root){mix-blend-mode:normal;animation:none}.loading-screen{z-index:9999;background:var(--bg-primary);will-change:opacity,transform;justify-content:center;align-items:center;transition:opacity .55s,transform .55s;display:flex;position:fixed;inset:0}.loading-exit{opacity:0;pointer-events:none;transform:scale(1.03)}.loading-inner{flex-direction:column;align-items:center;gap:28px;width:100%;max-width:420px;padding:0 24px;display:flex}.loading-logo{font-family:var(--font-display);letter-spacing:-2px;align-items:center;gap:4px;font-size:clamp(3rem,10vw,5rem);font-weight:900;line-height:1;display:flex}.loading-logo-bracket{color:var(--text-muted);font-weight:400}.loading-logo-text{color:var(--text-primary)}.loading-message{font-family:var(--font-mono);color:var(--text-secondary);letter-spacing:1px;white-space:nowrap;align-items:center;gap:2px;max-width:100%;min-height:1.4em;font-size:.75rem;display:flex;overflow:hidden}.loading-prompt{color:var(--text-secondary);flex-shrink:0}.loading-msg-text{text-overflow:ellipsis;overflow:hidden}.loading-cursor{color:var(--text-primary);flex-shrink:0;animation:1s step-end infinite cursorBlink}@keyframes cursorBlink{0%,to{opacity:1}50%{opacity:0}}.loading-bar-wrap{background:var(--bg-secondary);border:1.5px solid var(--border);border-radius:0;width:100%;height:3px;overflow:hidden}.loading-bar-fill{background:var(--text-primary);will-change:width;height:100%;transition:width 60ms linear}.loading-pct{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:3px;text-transform:uppercase;align-self:flex-end;font-size:.7rem}.shiny-text{display:inline-block}.rotating-skill{color:var(--accent-cyan,#00dce8);letter-spacing:.5px;background:#00dce812;border-radius:8px;align-items:center;padding:2px 14px 4px;font-weight:700;transition:box-shadow .4s ease-in-out;display:inline-flex;position:relative;overflow:hidden}@keyframes skillUnderlineSlide{0%{background-position:0 0}to{background-position:300% 0}}.text-rotate{white-space:pre-wrap;flex-wrap:wrap;display:flex;position:relative}.text-rotate-sr-only{clip:clip(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.text-rotate-word{display:inline-flex}.text-rotate-lines{flex-direction:column;width:100%;display:flex}.text-rotate-element{display:inline-block}.text-rotate-space{white-space:pre}.console-typewriter{font-family:var(--font-mono);letter-spacing:1.5px;color:#00ff41;border-radius:var(--radius-sm);text-shadow:0 0 6px #00ff4159;background:#111;border:1px solid #2a2a2a;align-items:center;padding:6px 14px;font-size:.85rem;display:inline-flex;box-shadow:inset 0 1px 6px #0009,0 2px 8px #00000040}.console-prompt{opacity:.5;color:#00ff41;margin-right:8px}.console-text{color:#00ff41}.console-cursor{color:#00ff41;margin-left:2px;animation:.7s step-end infinite cursorBlink;display:inline-block}.scroll-reveal{margin:20px 0}.scroll-reveal-text{font-size:clamp(1.6rem,4vw,3rem);font-weight:600;line-height:1.5}.word{display:inline-block}.portfolio{background:var(--bg-primary);width:100%;min-height:100%;position:relative}.portfolio:not(.app-loaded) *{transition:none!important;animation:none!important}.portfolio.app-loaded *{animation-play-state:running}.bg-fixed,.bg-gradient-overlay{display:none}.portfolio-content{z-index:1;position:relative}.section{border-bottom:2px solid var(--border);justify-content:center;align-items:center;min-height:100vh;padding:120px 60px;display:flex;position:relative}.section-inner{width:100%;max-width:1100px;margin:0 auto}.section-label{font-family:var(--font-mono);letter-spacing:5px;text-transform:uppercase;color:var(--text-muted);border:1.5px solid var(--border-light);border-radius:var(--radius-sm);margin-bottom:14px;padding:3px 10px;font-size:.7rem;display:inline-block}.section-title{font-family:var(--font-display);color:var(--text-primary);margin-bottom:36px;font-size:clamp(2.2rem,5vw,3.8rem);font-weight:900;line-height:1.05}.section-divider{background:var(--accent);border-radius:0;width:50px;height:4px;margin-bottom:40px}.hero{background:var(--bg-primary);border-bottom:2px solid var(--border);justify-content:center;align-items:center;min-height:100vh;padding:0 60px;display:flex;position:relative;overflow:hidden}.hero:before{content:"";pointer-events:none;z-index:0;background-image:linear-gradient(#1111100d 1px,#0000 1px),linear-gradient(90deg,#1111100d 1px,#0000 1px);background-size:40px 40px;position:absolute;inset:0}.hero-container{z-index:1;justify-content:space-between;align-items:center;gap:60px;width:100%;max-width:1400px;display:flex;position:relative}.hero-text{flex:1}.hero-greeting{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:3px;text-transform:uppercase;opacity:0;margin-bottom:16px;font-size:.85rem;animation:.6s .2s forwards fadeSlideUp}.hero-greeting .console-typewriter{text-transform:none}.name-start{font-family:var(--font-mono);text-transform:uppercase;opacity:0;color:var(--text-secondary);letter-spacing:2px;margin-bottom:-4px;margin-left:2px;font-size:1rem;animation:.6s .35s forwards fadeSlideUp}.name-start *{-webkit-text-fill-color:var(--text-secondary)!important;background:0 0!important}.hero-name{font-family:var(--font-display);letter-spacing:-2px;color:var(--text-primary);opacity:0;white-space:normal;margin-bottom:6px;font-size:clamp(2.2rem,8vw,6rem);font-weight:900;line-height:1;animation:.6s .5s forwards fadeSlideUp}.hero-name span,.hero-name *{color:var(--text-primary)!important}.hero-name-gradient span,.hero-name-gradient *{-webkit-text-stroke:2px var(--border);color:#0000!important;background:0 0!important;-webkit-text-fill-color:transparent!important;-webkit-background-clip:text!important;background-clip:text!important}.hero-title-line{font-family:var(--font-display);color:var(--text-secondary);opacity:0;align-items:center;gap:14px;margin-bottom:28px;font-size:clamp(1.1rem,2.5vw,1.6rem);font-weight:700;animation:.6s .65s forwards fadeSlideUp;display:flex}.hero-summary{color:var(--text-secondary);opacity:0;max-width:70%;margin-bottom:40px;font-size:1rem;font-weight:500;line-height:1.75;animation:.6s .8s forwards fadeSlideUp}.hero-actions{opacity:0;flex-wrap:wrap;gap:14px;animation:.6s .95s forwards fadeSlideUp;display:flex}.btn{border-radius:var(--radius-sm);font-family:var(--font-mono);letter-spacing:1px;text-transform:uppercase;cursor:pointer;border:2px solid var(--border);background:var(--bg-card);color:var(--text-primary);box-shadow:4px 4px 0 var(--border);align-items:center;gap:8px;padding:13px 28px;font-size:.85rem;font-weight:700;text-decoration:none;transition:all .1s;display:inline-flex;position:relative;overflow:hidden}.btn:hover{transform:translateY(-1.5px)scale(1.01)}.btn-primary:hover{color:var(--text-primary)!important;box-shadow:6px 6px 0 var(--border)!important;background-color:#0000!important}.btn-primary:active{color:var(--text-primary)!important;box-shadow:2px 2px 0 var(--border)!important;background-color:#0000!important;transform:translate(2px,2px)!important}.btn-primary{background:var(--border);color:var(--bg-primary)}.btn:active{box-shadow:2px 2px 0 var(--border);transform:translate(2px,2px)}.btn-primary:active{color:var(--bg-primary)}.btn-outline{background:var(--bg-primary)}.btn-outline:active{color:var(--text-primary)}.hero-photo-wrapper{z-index:2;flex-direction:column;flex-shrink:0;align-items:center;gap:0;margin-top:0;display:flex;position:relative}.hero-photo-container{width:300px;height:400px;position:relative;overflow:hidden}.hero-photo{object-fit:contain;object-position:bottom center;z-index:1;filter:grayscale();background:0 0;border:none;border-radius:0;width:100%;height:100%;margin-bottom:-5px;animation:1s cubic-bezier(.33,1,.68,1) .8s forwards riseFromLine;position:absolute;bottom:0;left:0;transform:translateY(105%)}.hero-photo-line{background:var(--text-primary);transform-origin:50%;flex-shrink:0;width:115%;height:2px;margin-top:0;animation:.5s .3s forwards expandLine;transform:scaleX(0)}@keyframes expandLine{to{transform:scaleX(1)}}@keyframes riseFromLine{to{transform:translateY(0)scale(1.5)}}.ticker-wrap{background:var(--accent);color:#fff;white-space:nowrap;border-top:2px solid var(--border);border-bottom:2px solid var(--border);width:100%;padding:14px 0;display:flex;overflow:hidden}.ticker-track{gap:0;animation:22s linear infinite ticker;display:inline-flex}.ticker-item{font-family:var(--font-mono);letter-spacing:3px;text-transform:uppercase;align-items:center;gap:20px;padding:0 38px;font-size:.8rem;display:inline-flex}.ticker-item:after{content:"✦";opacity:.5}@keyframes ticker{0%{transform:translate(0)}to{transform:translate(-50%)}}.about-content{grid-template-columns:1fr 1fr;align-items:start;gap:60px;display:grid}.about-text{color:var(--text-secondary);font-size:1.05rem;font-weight:500;line-height:1.8}.about-stats{grid-template-columns:repeat(2,1fr);gap:16px;margin-top:10px;display:grid}.stat-card{background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius-sm);box-shadow:4px 4px 0 var(--border-light);cursor:default;padding:28px 20px;transition:all .2s}.stat-card:hover{box-shadow:7px 7px 0 var(--border);transform:translate(-3px,-3px)}.stat-number{font-family:var(--font-display);color:var(--text-primary);margin-bottom:4px;font-size:2.4rem;font-weight:900}.stat-label{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:3px;font-size:.7rem}.skills-grid{grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:16px;display:grid}.skill-card{background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius-sm);text-align:center;box-shadow:4px 4px 0 var(--border);cursor:pointer;padding:28px 20px;transition:all .1s;position:relative;overflow:hidden}.skill-card:before{display:none}.skill-card:active{box-shadow:2px 2px 0 var(--border);transform:translate(2px,2px)}.skill-card:hover{background:var(--border);color:var(--bg-primary)}.skill-card:hover .skill-name,.skill-card:hover .skill-level{color:var(--bg-primary)}.skill-icon{z-index:1;margin-bottom:14px;font-size:2.2rem;display:block;position:relative}.skill-name{font-family:var(--font-display);color:var(--text-primary);z-index:1;margin-bottom:6px;font-size:.95rem;font-weight:700;transition:color .2s;position:relative}.skill-level{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:2px;text-transform:uppercase;z-index:1;font-size:.65rem;transition:color .2s;position:relative}.projects-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px;display:grid}.project-card{border-radius:var(--radius-sm);background:var(--bg-card);border:2px solid var(--border);box-shadow:6px 6px 0 var(--border);cursor:pointer;transition:all .15s;position:relative;overflow:hidden}.project-card:hover{box-shadow:8px 8px 0 var(--border);transform:translate(-2px,-2px)}.project-card:active{box-shadow:4px 4px 0 var(--border);transform:translate(2px,2px)}.project-card-header{border-bottom:2px solid var(--border);height:150px;position:relative;overflow:hidden}.project-card-gradient{filter:grayscale(40%)contrast(1.1);justify-content:center;align-items:center;width:100%;height:100%;font-size:3rem;display:flex}.project-card-gradient:after{display:none}.project-card-body{padding:22px}.project-card-title{font-family:var(--font-display);color:var(--text-primary);margin-bottom:8px;font-size:1.15rem;font-weight:800}.project-card-desc{color:var(--text-secondary);margin-bottom:16px;font-size:.88rem;font-weight:500;line-height:1.65}.project-tags{flex-wrap:wrap;gap:8px;display:flex}.project-tag{font-family:var(--font-mono);background:var(--bg-secondary);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);letter-spacing:1px;text-transform:uppercase;padding:3px 10px;font-size:.65rem}.contact-container{text-align:center;max-width:560px;margin:0 auto}.contact-desc{color:var(--text-secondary);margin-bottom:40px;font-size:1.05rem;font-weight:500;line-height:1.75}.contact-links{flex-wrap:wrap;justify-content:center;gap:14px;display:flex}.contact-link{background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-mono);letter-spacing:1px;text-transform:uppercase;box-shadow:4px 4px 0 var(--border-light);align-items:center;gap:10px;padding:12px 24px;font-size:.8rem;font-weight:700;text-decoration:none;transition:all .2s;display:inline-flex}.contact-link:hover{box-shadow:7px 7px 0 var(--border);background:var(--accent);color:#fff;border-color:var(--accent);transform:translate(-3px,-3px)}.contact-link-icon{font-size:1.1rem}.footer{text-align:center;border-top:2px solid var(--border);background:var(--accent);padding:32px 60px}.footer-text{font-family:var(--font-mono);color:#ffffffb3;letter-spacing:2px;text-transform:uppercase;font-size:.75rem}.footer-accent{color:#fff;font-weight:700}.shiny-text,[class*=shiny]{-webkit-text-fill-color:inherit!important;color:inherit!important;background:0 0!important}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes photoRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.scroll-reveal,.scroll-reveal-text{font-size:inherit;font-weight:inherit;line-height:inherit;margin:0;color:var(--text-secondary)!important}@media (max-width:1024px){.section{padding:100px 40px}.hero{padding:0 40px}}@media (max-width:968px){.section{min-height:unset;padding:80px 24px}.hero{min-height:unset;padding:100px 24px 60px}.hero-container{text-align:left;flex-direction:column-reverse;gap:36px}.hero-name{white-space:normal;font-size:clamp(3rem,8vw,4.5rem)}.hero-title-line,.hero-actions{justify-content:flex-start}.hero-summary{max-width:100%}.hero-photo-container{width:220px;height:260px}.about-content{grid-template-columns:1fr;gap:36px}.projects-grid{grid-template-columns:1fr}.contact-links{flex-direction:column;align-items:center}.footer{padding:24px}}@media (max-width:600px){.section{padding:60px 18px}.hero{padding:80px 18px 50px}.hero-name{letter-spacing:-1px;white-space:normal;font-size:clamp(2.4rem,10vw,3.2rem)}.skills-grid{grid-template-columns:repeat(2,1fr);gap:10px}.about-stats{grid-template-columns:repeat(2,1fr)}.hero-photo-container{width:170px;height:200px}.btn{padding:11px 20px;font-size:.78rem}.hero-actions{flex-direction:column}}
