@import "https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Rajdhani:wght@400;500;600;700&family=Inter:wght@300;400;500;600&display=swap";
*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--red:#e01818;--red-dark:#b01010;--bg:#0a0a0a;--bg2:#111;--bg3:#1a1a1a;--text:#fff;--text-muted:#aaa;--border:#ffffff14}html{scroll-behavior:smooth}body{color:var(--text);background:radial-gradient(at 50% 40%,#b4000017 0%,#0000 65%),#0a0a0a;font-family:Inter,sans-serif;overflow-x:hidden}nav{z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);background:#0a0a0af2;justify-content:space-between;align-items:center;padding:1.2rem 5%;display:flex;position:fixed;top:0;left:0;right:0}.logo{color:#fff;font-family:Rajdhani,sans-serif;font-size:1.8rem;font-weight:700}.logo span{color:var(--red)}.nav-links{gap:2rem;list-style:none;display:flex;position:absolute;left:50%;transform:translate(-50%)}.nav-links a{color:var(--text-muted);letter-spacing:.02em;font-size:.95rem;font-weight:500;text-decoration:none;transition:color .2s}.nav-links a:hover,.nav-links a.active{color:var(--red)}.nav-links a.active{border-bottom:2px solid var(--red);padding-bottom:2px}.theme-toggle{color:#7aa3e0;cursor:pointer;background:#0f1f3d;border:1.5px solid #1e3a6e;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:all .2s;display:flex}.theme-toggle:hover{border-color:var(--red);color:var(--red)}body.light-mode .theme-toggle{color:#a16207;background:#fef9c3;border-color:#fde047}.theme-toggle.spin svg{animation:.5s cubic-bezier(.34,1.2,.64,1) forwards spinOnce}@keyframes spinOnce{0%{transform:rotate(0)}to{transform:rotate(360deg)}}#home{align-items:center;min-height:100vh;padding:80px 5% 0;display:flex;position:relative;overflow:hidden}#home:before{content:"";pointer-events:none;background:radial-gradient(at 70%,#b4000012 0%,#0000 70%);width:55%;height:100%;position:absolute;top:0;right:0}.hero-content{z-index:1;flex:1}.hero-greeting{color:var(--text-muted);margin-bottom:1.5rem;font-size:1.1rem;font-weight:400}.hero-title{letter-spacing:.02em;color:#fff;margin-bottom:1.5rem;font-family:Bebas Neue,sans-serif;font-size:clamp(3.5rem,7vw,6rem);line-height:1}.hero-subtitle{color:var(--red);letter-spacing:.03em;margin-bottom:1.5rem;font-family:Rajdhani,sans-serif;font-size:1.4rem;font-weight:600}.hero-desc{color:var(--text-muted);max-width:420px;margin-bottom:2rem;font-size:.95rem;line-height:1.7}.hero-socials{gap:.8rem;margin-bottom:2.2rem;display:flex}.social-btn{cursor:pointer;width:42px;height:42px;color:var(--red);background:#fff;border:1.5px solid #fff3;border-radius:21px;flex-shrink:0;justify-content:center;align-items:center;gap:0;text-decoration:none;transition:width .6s,background .3s,border-color .3s,color .3s;display:flex;position:relative;overflow:hidden}.social-btn svg{flex-shrink:0;transition:transform .4s cubic-bezier(.34,1.1,.64,1)}.social-btn:hover svg{transform:rotate(360deg)}.social-btn:hover{border-color:var(--red);background:var(--red);color:#fff;justify-content:flex-start;gap:8px;width:fit-content;min-width:42px;padding:0 14px 0 12px}.social-btn .btn-label{letter-spacing:.06em;white-space:nowrap;opacity:0;width:0;font-family:Rajdhani,sans-serif;font-size:.85rem;font-weight:700;transition:opacity .35s .2s,width .6s;overflow:hidden}.social-btn:hover .btn-label{opacity:1;width:auto}.hero-btns{gap:1rem;display:flex}.btn-primary{background:var(--red);color:#fff;cursor:pointer;letter-spacing:.05em;border:none;border-radius:2px;padding:.75rem 1.8rem;font-family:Rajdhani,sans-serif;font-size:1rem;font-weight:600;transition:background .2s,transform .1s}.btn-primary:hover{background:var(--red-dark);transform:translateY(-1px)}.btn-outline{color:var(--red);border:1.5px solid var(--red);cursor:pointer;letter-spacing:.05em;background:0 0;border-radius:2px;padding:.75rem 1.8rem;font-family:Rajdhani,sans-serif;font-size:1rem;font-weight:600;transition:all .2s}.btn-outline:hover{color:#111;background:#fff}.hero-avatar{z-index:1;flex:none;animation:.8s .3s both fadeInUp,3s ease-in-out 1.1s infinite floating;position:relative;right:330px}@keyframes floating{0%{transform:translateY(0)}50%{transform:translateY(-22px)}to{transform:translateY(0)}}.avatar-ring{border:3px solid var(--red);border-radius:50%;width:256px;height:256px;overflow:hidden;box-shadow:0 0 60px #e0181899,0 0 120px #e0181859,0 0 200px #e0181826}.avatar-ring img{object-fit:cover;width:100%;height:100%;image-rendering:pixelated;display:block}section{z-index:2;padding:6rem 5%;position:relative}.section-title{letter-spacing:.04em;text-align:center;margin-bottom:3rem;font-family:Bebas Neue,sans-serif;font-size:clamp(2.5rem,5vw,3.5rem)}.section-title span{color:var(--red)}#about{background:0 0}.about-grid{grid-template-columns:256px 1fr;align-items:center;gap:9rem;padding:0 5%;display:grid}.about-img-wrap{width:256px;margin-top:-2.5rem;position:relative}.about-img{background:var(--bg3);border:2px solid var(--red);border-radius:4px;width:256px;height:256px;overflow:hidden}.about-img img{object-fit:cover;width:100%;height:100%;image-rendering:pixelated}.about-img-wrap:after{content:"";z-index:-1;border:1px solid #e018184d;border-radius:4px;width:100%;height:100%;position:absolute;bottom:-16px;right:-16px}.about-text h2{letter-spacing:.03em;margin-bottom:1.5rem;font-family:Bebas Neue,sans-serif;font-size:clamp(2.2rem,4vw,3rem)}.about-text h2 span{color:var(--red)}.about-text p{color:var(--text-muted);margin-bottom:1.2rem;font-size:.95rem;line-height:1.8}.skills-tags{flex-wrap:wrap;gap:.6rem;margin:1.8rem 0 2.2rem;display:flex}.tag{color:var(--text-muted);letter-spacing:.03em;cursor:default;border:1px solid #e0181880;border-radius:2px;padding:.35rem .9rem;font-size:.85rem;font-weight:500;transition:all .2s}.tag:hover{border-color:var(--red);color:#111;background:#fff}#services{background:0 0}.services-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}.service-card{background:var(--bg2);border:1px solid var(--border);text-align:center;border-radius:4px;padding:2.5rem 1.8rem;transition:all .3s;position:relative;overflow:hidden}.service-card:before{content:"";opacity:0;background:radial-gradient(at 50% 0,#e018181f 0%,#0000 70%);transition:opacity .3s;position:absolute;inset:0}.service-card:hover{border-color:#e0181880;transform:translateY(-4px)}.service-card:hover:before{opacity:1}.service-icon{color:var(--red);justify-content:center;margin-bottom:1.2rem;display:flex}.service-card h3{letter-spacing:.03em;margin-bottom:1rem;font-family:Rajdhani,sans-serif;font-size:1.3rem;font-weight:700}.service-card p{color:var(--text-muted);text-align:justify;margin-bottom:1.5rem;font-size:.9rem;line-height:1.7}#portfolio{background:0 0}.pf-header{margin-bottom:1rem}.pf-badge{color:var(--red);letter-spacing:.1em;background:#e018180f;border:1px solid #e0181866;border-radius:20px;align-items:center;gap:.4rem;margin-bottom:1.2rem;padding:.3rem .9rem;font-size:.75rem;font-weight:700;display:inline-flex}.timeline{max-width:780px;margin:0 auto;padding-left:2.5rem;position:relative}.timeline:before{content:"";background:linear-gradient(to bottom, var(--red), #e0181826);width:2px;position:absolute;top:0;bottom:0;left:0}.tl-item{margin-bottom:2rem;position:relative}.tl-dot{background:var(--bg);z-index:1;border:2px solid #e0181859;border-radius:50%;width:14px;height:14px;transition:all .3s;position:absolute;top:1.4rem;left:-2.85rem}.tl-dot.active{background:var(--red);border-color:var(--red);box-shadow:0 0 14px #e01818b3}.tl-dot-pulse{background:#e0181833;border-radius:50%;animation:1.8s ease-out infinite pulse;position:absolute;inset:-5px}@keyframes pulse{0%{opacity:.8;transform:scale(1)}to{opacity:0;transform:scale(2.2)}}.tl-item:hover .tl-dot{border-color:var(--red)}.tl-card{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:1.4rem 1.8rem;transition:all .3s}.tl-item:hover .tl-card{border-color:#e0181873;transform:translate(8px);box-shadow:0 6px 24px #e0181812}.tl-card-top{align-items:flex-start;gap:1rem;margin-bottom:1rem;display:flex}.tl-desc{color:var(--text-muted);margin-bottom:1rem;font-size:.9rem;line-height:1.7}.tl-tags{flex-wrap:wrap;gap:.5rem;display:flex}.pf-logo{width:72px;height:72px;color:var(--red);background:linear-gradient(135deg,#1a0505,#2a0808);border:1px solid #e018184d;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;font-family:Bebas Neue,sans-serif;font-size:2rem;display:flex}.pf-card-info{flex:1}.pf-name-row{flex-wrap:wrap;align-items:center;gap:.6rem;margin-bottom:.5rem;display:flex}.pf-name{font-family:Rajdhani,sans-serif;font-size:1.1rem;font-weight:700}.pf-role-badge{color:var(--text-muted);border:1px solid var(--border);letter-spacing:.03em;border-radius:4px;padding:.15rem .6rem;font-size:.72rem}.pf-meta-row{align-items:center;gap:1rem;display:flex}.pf-status{letter-spacing:.05em;font-size:.78rem;font-weight:600}.pf-status.active{color:#22c55e}.pf-status.done{color:var(--text-muted)}.pf-period{color:var(--text-muted);font-size:.8rem}#contact{background:0 0}.contact-grid{grid-template-columns:1fr 1fr;align-items:start;gap:4rem;display:grid}.contact-info h3{letter-spacing:.04em;margin-bottom:1rem;font-family:Bebas Neue,sans-serif;font-size:2.5rem}.contact-info h3 span{color:var(--red)}.contact-info p{color:var(--text-muted);margin-bottom:2rem;font-size:.95rem;line-height:1.7}.contact-detail{color:var(--text-muted);align-items:center;gap:.8rem;margin-bottom:1rem;font-size:.9rem;display:flex}.contact-detail-icon{width:36px;height:36px;color:var(--red);background:#e018181a;border:1px solid #e018184d;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.contact-form{flex-direction:column;gap:1rem;display:flex}.form-group{flex-direction:column;gap:.4rem;display:flex}.form-group label{color:var(--text-muted);letter-spacing:.03em;font-size:.85rem;font-weight:500}.form-group input,.form-group textarea{background:var(--bg3);border:1px solid var(--border);color:var(--text);resize:vertical;border-radius:2px;outline:none;padding:.75rem 1rem;font-family:Inter,sans-serif;font-size:.9rem;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{border-color:var(--red)}.form-group textarea{min-height:120px}footer{background:var(--bg);border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding:2rem 5%;display:flex}.footer-logo{font-family:Rajdhani,sans-serif;font-size:1.5rem;font-weight:700}.footer-logo span{color:var(--red)}footer p{color:var(--text-muted);font-size:.85rem}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.hero-content>*{animation:.6s both fadeInUp}.hero-greeting{animation-delay:.1s}.hero-title{animation-delay:.2s}.hero-subtitle{animation-delay:.3s}.hero-desc{animation-delay:.4s}.hero-socials{animation-delay:.5s}.hero-btns{animation-delay:.6s}body.light-mode{--bg:#f5f5f5;--bg2:#fff;--bg3:#ebebeb;--text:#111;--text-muted:#555;--border:#0000001a;background:radial-gradient(at 50% 40%,#b400000f 0%,#0000 65%),#f5f5f5}body.light-mode nav{background:#f5f5f5f2}body.light-mode .tl-card,body.light-mode .service-card{background:#fff}body.light-mode .hero-title{color:#111!important}body.light-mode .logo{color:#111}body.light-mode .social-btn{color:#fff;background:#111;border-color:#00000026}body.light-mode .social-btn:hover{background:var(--red);border-color:var(--red)}body.light-mode .tag:hover,body.light-mode .btn-outline:hover{color:#fff;background:#111;border-color:#111}@media (max-width:900px){#home{text-align:center;flex-direction:column;gap:3rem;padding-top:100px}.hero-content{order:2}.hero-avatar{order:1;margin:0;right:0}.hero-socials,.hero-btns{justify-content:center}.hero-desc{margin:0 auto 2rem}.about-grid{grid-template-columns:1fr;gap:2rem}.services-grid{grid-template-columns:1fr}.contact-grid{grid-template-columns:1fr;gap:2rem}footer{text-align:center;flex-direction:column;gap:1rem}}
