:root{--void: #050505;--void-soft: #0a0a0a;--accent: #d4a853;--accent-dim: #9a7a3c;--accent-glow: #e8c36a;--text: #ffffff;--text-dim: rgba(255, 255, 255, .5);--text-faint: rgba(255, 255, 255, .25);--pointer-x: 0;--pointer-y: 0}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background-color:var(--void);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.container{max-width:1100px;margin:0 auto;padding:0 24px}.section{padding:80px 0;position:relative;z-index:2;contain:layout style;content-visibility:auto;contain-intrinsic-size:auto 600px}.App{position:relative;overflow-x:hidden}.void-bg{position:fixed;inset:0;z-index:0;overflow:hidden;pointer-events:none;background:var(--void);contain:strict}.spotlight-anchor{position:absolute;top:0;left:0;width:100%;height:100vh;z-index:1;pointer-events:none;overflow:visible;-webkit-mask-image:linear-gradient(to bottom,white 50%,transparent 100%);mask-image:linear-gradient(to bottom,white 50%,transparent 100%);opacity:0}.entered .spotlight-anchor{animation:spotlight-soft-on .8s ease-out both}@keyframes spotlight-soft-on{0%{opacity:0}20%{opacity:.35}40%{opacity:.15}60%{opacity:.75}to{opacity:1}}.spotlight-wire{position:absolute;top:0;left:50%;transform:translate(-50%);width:1.5px;height:38px;background:linear-gradient(180deg,#ffffff08,#b4a07826 40%,#d4a8534d);z-index:11}.spotlight-housing{position:absolute;top:36px;left:50%;transform:translate(-50%);width:22px;height:18px;background:linear-gradient(180deg,#1a1710,#0e0d0a 60%,#1a1710);border-radius:3px 3px 1px 1px;z-index:12;box-shadow:inset 0 1px #d4a85326,inset 0 -1px #d4a85314,-1px 0 #d4a8530f,1px 0 #d4a8530f}.spotlight-housing:before{content:"";position:absolute;top:-2px;left:50%;transform:translate(-50%);width:10px;height:3px;background:#1a1710;border-radius:2px 2px 0 0;box-shadow:inset 0 1px #d4a8531a}.spotlight-housing:after{content:"";position:absolute;bottom:-1px;left:50%;transform:translate(-50%);width:26px;height:2px;background:linear-gradient(90deg,transparent 0%,rgba(212,168,83,.12) 30%,rgba(212,168,83,.2) 50%,rgba(212,168,83,.12) 70%,transparent 100%);border-radius:0 0 1px 1px}.spotlight-reflector{position:absolute;top:53px;left:50%;transform:translate(-50%);width:40px;height:16px;background:linear-gradient(180deg,#12100d,#0a0908);clip-path:polygon(10% 0%,90% 0%,100% 100%,0% 100%);z-index:11;box-shadow:inset 0 -4px 8px #d4a85314,inset 0 -1px 3px #fff0c80d}.spotlight-reflector:before{content:"";position:absolute;bottom:0;left:10%;width:80%;height:60%;background:radial-gradient(ellipse at center bottom,rgba(212,168,83,.12) 0%,rgba(212,168,83,.04) 50%,transparent 100%);border-radius:0 0 40% 40%}.spotlight-reflector:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(212,168,83,.15) 25%,rgba(212,168,83,.25) 50%,rgba(212,168,83,.15) 75%,transparent 100%)}.spotlight-glow{position:absolute;top:63px;left:50%;width:12px;height:12px;transform:translate(-50%) translateZ(0);border-radius:50%;background:radial-gradient(circle,#fff 0%,#fff5d6 25%,#ffe8b0 50%,rgba(212,168,83,.6) 75%,transparent 100%);box-shadow:0 0 4px 2px #ffffffe6,0 0 12px 6px #fff0c880,0 0 30px 12px #d4a85359,0 0 60px 25px #d4a85326,0 0 120px 50px #d4a8530f;z-index:10;animation:spotlight-flicker 8s ease infinite;pointer-events:none}.spotlight-glow:before{content:"";position:absolute;top:50%;left:50%;width:200px;height:150px;transform:translate(-50%,-40%);background:radial-gradient(ellipse at center,rgba(212,168,83,.07) 0%,rgba(212,168,83,.025) 40%,transparent 70%);border-radius:50%}.spotlight-cone{position:absolute;top:69px;left:50%;transform:translate(-50%) translateZ(0);width:120%;height:calc(100% - 69px);clip-path:polygon(50% 0%,18% 100%,82% 100%);background:linear-gradient(180deg,rgba(212,168,83,.15) 0%,rgba(212,168,83,.07) 15%,rgba(212,168,83,.03) 40%,rgba(212,168,83,.008) 70%,transparent 100%);z-index:3;animation:spotlight-flicker 8s ease infinite}.spotlight-cone:before{content:"";position:absolute;inset:0;clip-path:polygon(50% 0%,35% 100%,65% 100%);background:linear-gradient(180deg,rgba(255,255,255,.1) 0%,rgba(255,240,200,.05) 15%,rgba(212,168,83,.02) 45%,transparent 80%)}.spotlight-cone:after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 38% 75% at 50% 0%,rgba(212,168,83,.07) 0%,rgba(212,168,83,.025) 35%,transparent 65%)}.spotlight-floor{position:absolute;bottom:0;left:50%;transform:translate(-50%) translateZ(0);width:75%;height:42%;background:radial-gradient(ellipse 45% 50% at 50% 100%,rgba(212,168,83,.07) 0%,rgba(212,168,83,.03) 35%,transparent 70%);z-index:3;animation:spotlight-flicker 8s ease infinite}.spotlight-dust{position:absolute;inset:0;z-index:5;clip-path:polygon(50% 0%,12% 100%,88% 100%);background-image:radial-gradient(1px 1px at 20% 30%,rgba(255,240,200,.4) 50%,transparent 50%),radial-gradient(1px 1px at 65% 55%,rgba(255,240,200,.3) 50%,transparent 50%),radial-gradient(1px 1px at 40% 70%,rgba(212,168,83,.35) 50%,transparent 50%),radial-gradient(1px 1px at 75% 25%,rgba(255,255,255,.25) 50%,transparent 50%),radial-gradient(1px 1px at 50% 85%,rgba(212,168,83,.3) 50%,transparent 50%),radial-gradient(1px 1px at 30% 15%,rgba(255,240,200,.2) 50%,transparent 50%),radial-gradient(1.5px 1.5px at 85% 45%,rgba(255,255,255,.2) 50%,transparent 50%),radial-gradient(1px 1px at 15% 60%,rgba(212,168,83,.25) 50%,transparent 50%);background-size:300px 400px;animation:dust-float 20s linear infinite,spotlight-flicker 8s ease infinite;opacity:.6;transform:translateZ(0)}@keyframes dust-float{0%{background-position:0px 0px}to{background-position:-150px -400px}}.void-grid{position:absolute;top:-15%;left:-15%;width:130%;height:500%;z-index:1;transform:translateZ(0);will-change:transform;background-image:linear-gradient(rgba(255,255,255,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.07) 1px,transparent 1px);background-size:70px 70px}@keyframes spotlight-flicker{0%{opacity:1}5%{opacity:1}5.5%{opacity:.55}6.5%{opacity:.9}7%{opacity:.5}8%{opacity:1}45%{opacity:1}45.5%{opacity:.6}46.5%{opacity:1}80%{opacity:1}80.5%{opacity:.45}81%{opacity:.8}81.5%{opacity:.5}82.5%{opacity:1}to{opacity:1}}.void-vignette{position:absolute;inset:0;background:radial-gradient(ellipse 50% 45% at 50% 45%,transparent 10%,rgba(5,5,5,.3) 40%,rgba(5,5,5,.75) 65%,rgba(5,5,5,.98) 100%);z-index:6;transform:translateZ(0)}.header{position:fixed;top:0;left:0;right:0;z-index:100;background:transparent;transition:transform .3s ease-in-out,background .3s}.header.scrolled{background:#050505d9;backdrop-filter:blur(10px);border-bottom:1px solid rgba(212,168,83,.08)}.header-container{display:flex;align-items:center;justify-content:space-between;height:64px}.header .logo{font-size:1.15rem;font-weight:600;color:var(--accent);letter-spacing:1px;text-transform:uppercase;position:relative}.header .logo:after{content:"";position:absolute;bottom:-3px;left:0;width:100%;height:1px;background:var(--accent);opacity:.3}.nav{display:flex;align-items:center;gap:32px}.nav a{font-size:.8rem;color:var(--text-dim);transition:color .3s;font-weight:400;letter-spacing:.5px;text-transform:uppercase;position:relative}.nav a:hover{color:var(--accent)}.nav a.btn-primary{background:transparent;border:1px solid var(--accent-dim);color:var(--accent);padding:8px 20px;border-radius:2px;font-size:.75rem;letter-spacing:1px;text-transform:uppercase;transition:all .3s}.nav a.btn-primary:hover{background:var(--accent);color:var(--void);border-color:var(--accent)}.mobile-menu-btn{display:none;background:none;border:none;color:var(--accent);font-size:1.5rem;cursor:pointer}.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;padding-top:64px;position:relative;z-index:2;visibility:hidden}.entered .hero{visibility:visible}.hero-content{max-width:700px;position:relative}.hero-content:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:500px;height:400px;background:radial-gradient(ellipse at center,rgba(212,168,83,.06) 0%,transparent 70%);pointer-events:none;z-index:-1}.hero-greeting{font-size:.8rem;text-transform:uppercase;letter-spacing:4px;color:var(--accent-dim);margin-bottom:20px;font-weight:400}.hero-title{font-size:clamp(2.5rem,7vw,5rem);font-weight:600;color:var(--text);line-height:1.05;letter-spacing:-2px}.hero-title .highlight{color:var(--accent);position:relative}.hero-title .highlight:after{content:attr(data-text);position:absolute;left:0;top:0;color:var(--accent);filter:blur(30px);opacity:.3;pointer-events:none}.hero-role{font-size:clamp(1.2rem,3vw,1.8rem);font-weight:300;color:var(--text-dim);margin-top:12px;letter-spacing:2px}.hero-subtitle{font-size:1rem;color:var(--text-faint);margin-top:24px;max-width:480px;margin-left:auto;margin-right:auto;line-height:1.8}.hero-divider{width:40px;height:1px;background:var(--accent);margin:28px auto;opacity:.5}.hero-buttons{display:flex;gap:14px;justify-content:center;margin-top:36px}.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;background:var(--accent);color:var(--void);border:1px solid var(--accent);border-radius:2px;font-size:.8rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:all .3s}.btn-primary:hover{background:var(--accent-glow);box-shadow:0 0 30px #d4a85333}.btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;background:transparent;color:var(--text-dim);border:1px solid rgba(255,255,255,.12);border-radius:2px;font-size:.8rem;font-weight:500;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:all .3s}.btn-secondary:hover{border-color:var(--accent-dim);color:var(--accent)}.section-title{font-size:1.6rem;font-weight:600;color:var(--text);margin-bottom:40px;letter-spacing:-.5px;position:relative;display:inline-block}.section-title:after{content:"";position:absolute;bottom:-8px;left:0;width:30px;height:2px;background:var(--accent)}.section-title.left-align{text-align:left}.about-section{padding:80px 0}.about-container{display:grid;grid-template-columns:1fr;gap:40px}.about-content{max-width:700px}.about-text{font-size:.95rem;color:var(--text-dim);margin-bottom:16px;line-height:1.9}.about-text .highlight{color:var(--accent);font-weight:500}.about-actions{margin-top:28px}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.skills-title{opacity:0;transform:translate(-100px)}.skills-title.slide-in{animation:slide-from-left .6s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes slide-from-left{0%{opacity:0;transform:translate(-100px)}to{opacity:1;transform:translate(0)}}.skill-card{background:#ffffff05;border:1px solid rgba(255,255,255,.06);border-radius:4px;padding:24px;opacity:0;transform:scaleY(0);transform-origin:top;transition:border-color .3s,box-shadow .3s}.skill-card.unfold{animation:curtain-unfold .5s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes curtain-unfold{0%{opacity:0;transform:scaleY(0) translateY(-20px)}50%{opacity:.5}to{opacity:1;transform:scaleY(1) translateY(0)}}.skill-card:hover{border-color:#d4a85340;box-shadow:0 0 20px #d4a8531f}.skill-category{font-size:.85rem;font-weight:600;color:var(--accent);margin-bottom:14px;text-transform:uppercase;letter-spacing:.5px}.skill-tags{display:flex;flex-wrap:wrap;gap:8px}.skill-tag{font-size:.72rem;padding:4px 10px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:2px;color:var(--text-dim);opacity:0;transform:scale(0) rotate(-10deg);transition:background .15s,border-color .15s,color .15s,box-shadow .15s,filter .15s}.skill-tag.appear{animation:tag-pop-in .4s cubic-bezier(.68,-.55,.265,1.55) forwards}@keyframes tag-pop-in{0%{opacity:0;transform:scale(0) rotate(-10deg)}60%{transform:scale(1.15) rotate(3deg)}to{opacity:1;transform:scale(1) rotate(0)}}.skill-tag:hover{background:#d4a8531a;border-color:var(--accent-dim);color:var(--accent);box-shadow:0 0 8px #d4a8534d}.skill-tag.flicker-active{background:#d4a85326!important;border-color:var(--accent)!important;color:var(--accent-glow)!important;box-shadow:0 0 12px #d4a85380,0 0 4px #d4a8534d;filter:brightness(1.4);transition:all .05s ease-in}.skill-tag.tag-lit{background:#d4a8531a;border-color:var(--accent-dim);color:var(--accent);box-shadow:0 0 8px #d4a85340;transition:all .2s ease-out}.skill-tag.tag-lit:hover{background:#d4a85338;border-color:var(--accent-glow);color:#fff;box-shadow:0 0 16px #d4a85399,0 0 6px #d4a85366;filter:brightness(1.3);transform:scale(1.08);transition:all .1s ease-out}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.project-section-title{opacity:0;transform:translate(-80px);transition:none}.project-section-title.animate-in{animation:project-title-in .7s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes project-title-in{0%{opacity:0;transform:translate(-80px)}to{opacity:1;transform:translate(0)}}.project-card-entrance{opacity:0;transform:translateY(40px) scale(.95)}.project-card-entrance.animate-in{animation:project-card-rise .6s cubic-bezier(.34,1.56,.64,1) forwards;animation-delay:calc(.3s + var(--card-index) * .15s)}@keyframes project-card-rise{0%{opacity:0;transform:translateY(40px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.carousel-container.animate-in{animation:carousel-reveal .6s cubic-bezier(.25,.46,.45,.94) .25s forwards}@keyframes carousel-reveal{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.carousel-slide.animate-in{animation:slide-card-in .5s cubic-bezier(.34,1.56,.64,1) forwards;animation-delay:calc(.5s + var(--card-index) * .1s)}@keyframes slide-card-in{0%{opacity:0;transform:translateY(25px)}to{opacity:1;transform:translateY(0)}}.carousel-nav-btn.carousel-nav-prev{opacity:0;transform:translateY(-50%) translate(-20px)}.carousel-nav-btn.carousel-nav-prev.animate-in{animation:nav-btn-left-in .5s cubic-bezier(.25,.46,.45,.94) .7s forwards}@keyframes nav-btn-left-in{0%{opacity:0;transform:translateY(-50%) translate(-20px)}to{opacity:1;transform:translateY(-50%) translate(0)}}.carousel-nav-btn.carousel-nav-next{opacity:0;transform:translateY(-50%) translate(20px)}.carousel-nav-btn.carousel-nav-next.animate-in{animation:nav-btn-right-in .5s cubic-bezier(.25,.46,.45,.94) .7s forwards}@keyframes nav-btn-right-in{0%{opacity:0;transform:translateY(-50%) translate(20px)}to{opacity:1;transform:translateY(-50%) translate(0)}}.carousel-nav-dots.animate-in{animation:dots-pop-up .4s ease-out .9s forwards}@keyframes dots-pop-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.carousel-container{position:relative;width:100%;padding:0 4px;opacity:0;transform:translateY(30px)}.carousel-track{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;cursor:grab;padding:8px 0;scrollbar-width:none;-ms-overflow-style:none}.carousel-track::-webkit-scrollbar{display:none}.carousel-track:active{cursor:grabbing;scroll-snap-type:none}.carousel-slide{flex:0 0 calc((100% - 40px) / 3);scroll-snap-align:start;scroll-snap-stop:always;min-width:0;opacity:0;transform:translateY(25px)}.carousel-slide .project-card{width:100%;user-select:none}.carousel-nav-btn{position:absolute;top:50%;transform:translateY(-50%);background:#050505d9;border:1px solid rgba(212,168,83,.25);color:var(--accent);width:40px;height:40px;border-radius:50%;cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;z-index:10;transition:all .25s;backdrop-filter:blur(8px)}.carousel-nav-btn:hover{background:#d4a85326;border-color:var(--accent);box-shadow:0 0 18px #d4a85340;transform:translateY(-50%) scale(1.08)}.carousel-nav-prev{left:-50px;opacity:0;transform:translateY(-50%) translate(-20px)}.carousel-nav-next{right:-50px;opacity:0;transform:translateY(-50%) translate(20px)}.carousel-nav-dots{display:flex;justify-content:center;gap:8px;margin-top:20px;opacity:0;transform:translateY(10px)}.carousel-nav-dot{width:8px;height:8px;border-radius:50%;background:#ffffff26;border:1px solid rgba(255,255,255,.1);cursor:pointer;transition:all .3s;padding:0}.carousel-nav-dot:hover{background:#d4a8534d;transform:scale(1.3)}.carousel-nav-dot.active{background:var(--accent);border-color:var(--accent);box-shadow:0 0 6px #d4a85366;transform:scale(1.2)}.project-card{background:#ffffff05;border:1px solid rgba(255,255,255,.06);border-radius:4px;overflow:hidden;cursor:pointer;transition:border-color .3s,transform .3s}.project-card:hover{border-color:#d4a85340;transform:translateY(-3px)}.card-image-wrapper{position:relative;width:100%;height:200px;overflow:hidden}.card-image{width:100%;height:100%;object-fit:cover;transition:transform .5s}.project-card:hover .card-image{transform:scale(1.03)}.card-overlay{position:absolute;inset:0;background:#05050599;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}.project-card:hover .card-overlay{opacity:1}.card-overlay span{color:var(--accent);font-size:.75rem;font-weight:500;padding:6px 18px;border:1px solid var(--accent-dim);border-radius:2px;text-transform:uppercase;letter-spacing:1px}.card-content{padding:20px}.card-title{font-size:.95rem;font-weight:600;color:var(--text);margin-bottom:8px}.card-desc{font-size:.8rem;color:var(--text-faint);line-height:1.7;margin-bottom:14px;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-tags{display:flex;flex-wrap:wrap;gap:6px}.tag{font-size:.65rem;padding:3px 8px;background:#d4a85314;border:1px solid rgba(212,168,83,.15);border-radius:2px;color:var(--accent-dim);text-transform:uppercase;letter-spacing:.5px}.modal-overlay{position:fixed;inset:0;background:#050505e6;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#0c0c0c;border:1px solid rgba(255,255,255,.08);border-radius:6px;max-width:700px;width:100%;max-height:90vh;overflow:hidden;position:relative;display:flex;flex-direction:column}.modal-header-image{position:relative;width:100%;height:280px;min-height:280px;overflow:hidden;border-radius:6px 6px 0 0;flex-shrink:0;background:#0a0a0a}.carousel-image{position:absolute;width:100%;height:100%;object-fit:contain}.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);background:#050505b3;border:1px solid rgba(255,255,255,.1);color:var(--accent);width:34px;height:34px;border-radius:50%;cursor:pointer;font-size:.85rem;display:flex;align-items:center;justify-content:center;z-index:2;transition:background .2s}.carousel-btn:hover{background:#d4a85326}.carousel-btn.prev{left:10px}.carousel-btn.next{right:10px}.carousel-dots{position:absolute;bottom:12px;left:50%;transform:translate(-50%);display:flex;gap:6px}.carousel-dot{width:7px;height:7px;border-radius:50%;background:#ffffff40;cursor:pointer;transition:background .2s}.carousel-dot.active{background:var(--accent)}.close-modal-btn{position:absolute;top:12px;right:12px;background:#050505b3;border:none;color:var(--text-dim);width:32px;height:32px;border-radius:50%;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:3;transition:color .2s}.close-modal-btn:hover{color:var(--accent)}.modal-body{padding:24px 28px;display:flex;flex-direction:column;overflow:hidden;flex:1;min-height:0}.modal-title{font-size:1.2rem;font-weight:600;color:var(--text);margin-bottom:12px}.modal-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px;flex-shrink:0}.modal-description{font-size:.85rem;color:var(--text-dim);line-height:1.8;margin-bottom:20px;overflow-y:auto;flex:1;min-height:0;padding-right:8px}.modal-description::-webkit-scrollbar{width:4px}.modal-description::-webkit-scrollbar-track{background:transparent}.modal-description::-webkit-scrollbar-thumb{background:#d4a85340;border-radius:4px}.modal-description::-webkit-scrollbar-thumb:hover{background:#d4a85373}.modal-actions{display:flex;gap:10px;flex-shrink:0;padding-top:4px}.contact-section{text-align:center;position:relative}.contact-divider{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:32px;opacity:0}.contact-divider.animate-in{animation:divider-reveal .8s ease-out forwards}.contact-divider-line{display:block;width:60px;height:1px;background:linear-gradient(90deg,transparent,var(--accent-dim),transparent)}.contact-divider-diamond{color:var(--accent);font-size:.6rem;opacity:.6}@keyframes divider-reveal{0%{opacity:0;transform:scaleX(0)}to{opacity:1;transform:scaleX(1)}}.contact-title{opacity:0;transform:translateY(20px)}.contact-title.animate-in{animation:contact-title-in .7s cubic-bezier(.34,1.56,.64,1) .2s forwards}@keyframes contact-title-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.contact-text{font-size:.95rem;color:var(--text-dim);margin-bottom:40px;max-width:480px;margin-left:auto;margin-right:auto;line-height:1.7;opacity:0}.contact-text.animate-in{animation:contact-text-in .6s ease-out .45s forwards}@keyframes contact-text-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.contact-buttons{display:flex;justify-content:center;gap:20px;flex-wrap:wrap}.contact-buttons.animate-in .contact-card{animation:contact-card-in .5s cubic-bezier(.34,1.56,.64,1) forwards;animation-delay:calc(.6s + var(--btn-index) * .12s)}.contact-card{display:flex;flex-direction:column;align-items:center;gap:10px;padding:28px 36px;background:#ffffff05;border:1px solid rgba(255,255,255,.06);border-radius:4px;text-decoration:none;color:var(--text-dim);min-width:180px;position:relative;overflow:hidden;opacity:0;transform:translateY(30px);transition:all .35s cubic-bezier(.25,.46,.45,.94)}.contact-card:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center bottom,rgba(212,168,83,.06) 0%,transparent 70%);opacity:0;transition:opacity .35s}.contact-card:hover{border-color:#d4a8534d;transform:translateY(-4px);box-shadow:0 8px 30px #d4a85314,0 0 0 1px #d4a8531a}.contact-card:hover:before{opacity:1}.contact-card-icon{font-size:1.5rem;color:var(--accent);transition:transform .3s,filter .3s}.contact-card:hover .contact-card-icon{transform:scale(1.15);filter:drop-shadow(0 0 8px rgba(212,168,83,.4))}.contact-card-label{font-size:.85rem;font-weight:600;color:var(--text);letter-spacing:1px;text-transform:uppercase}.contact-card-value{font-size:.72rem;color:var(--text-faint);letter-spacing:.5px}.contact-card:hover .contact-card-value{color:var(--accent-dim)}@keyframes contact-card-in{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.footer{border-top:1px solid rgba(255,255,255,.05);padding:32px 0;text-align:center;position:relative;z-index:2}.footer p{font-size:.75rem;color:var(--text-faint);margin-bottom:12px}.social-links{display:flex;justify-content:center;gap:20px}.social-links a{color:var(--text-faint);font-size:1rem;transition:color .3s}.social-links a:hover{color:var(--accent)}.loading-screen{position:fixed;inset:0;background:var(--void);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999}.loading-percentage{font-size:.7rem;font-weight:300;color:#d4a85359;letter-spacing:4px;font-family:Courier New,monospace;margin-top:12px}.loading-bar-track{width:120px;height:1px;background:#ffffff0f;border-radius:1px;overflow:hidden}.loading-bar-fill{height:100%;background:var(--accent);border-radius:1px;transition:width .3s ease-out;box-shadow:0 0 8px #d4a8534d}@media(max-width:768px){.mobile-menu-btn{display:block}.nav{position:fixed;inset:64px 0 0;background:#050505f7;flex-direction:column;justify-content:center;gap:36px;opacity:0;pointer-events:none;transition:opacity .3s}.nav.open{opacity:1;pointer-events:auto}.nav a{font-size:1rem;letter-spacing:2px}body.menu-open{overflow:hidden}.hero-title{font-size:clamp(2rem,10vw,3.5rem)}.hero-buttons{flex-direction:column;align-items:center}.about-container,.skills-grid,.projects-grid{grid-template-columns:1fr}.carousel-slide{flex:0 0 100%}.carousel-nav-prev{left:4px}.carousel-nav-next{right:4px}.carousel-nav-btn{width:32px;height:32px;font-size:.75rem;background:#050505e6}.modal-header-image{height:200px}.contact-buttons{flex-direction:column;align-items:center}.contact-card{width:100%;max-width:280px}}
