*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #faf9ff;--bg2: #ffffff;--surface: #ffffff;--surface2: #f3f0ff;--surface3: #ebe6ff;--border: rgba(109, 40, 217, .1);--border2: rgba(109, 40, 217, .2);--accent: #7c3aed;--accent-dark: #6d28d9;--accent-light: #ede9fe;--accent-glow: rgba(124, 58, 237, .2);--accent2: #f97316;--accent2-light: #fff7ed;--text: #1e1333;--text2: #2d1f4e;--muted: #6b6080;--muted2: #a89ec0;--shadow: 0 1px 4px rgba(109, 40, 217, .06), 0 4px 20px rgba(109, 40, 217, .08);--shadow-lg: 0 8px 36px rgba(109, 40, 217, .12);--shadow-xl: 0 20px 60px rgba(109, 40, 217, .16);--shadow-accent: 0 8px 28px rgba(124, 58, 237, .3);--font: "Inter", sans-serif;--font2: "Space Grotesk", sans-serif;--radius: 16px;--transition: .25s cubic-bezier(.4, 0, .2, 1);--navbar-bg: rgba(250, 249, 255, .5);--hero-gradient: linear-gradient(135deg, #fdf4ff 0%, #faf9ff 40%, #f0f4ff 100%);--card-gradient: linear-gradient(145deg, #ffffff, #f8f6ff)}html{scroll-behavior:smooth;font-size:15px}body{background:var(--bg);color:var(--text);font-family:var(--font);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;transition:background var(--transition),color var(--transition)}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}ul{list-style:none}.container{max-width:1100px;margin:0 auto;padding:0 24px}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 24px;border-radius:12px;font-family:var(--font);font-size:15px;font-weight:600;cursor:pointer;transition:var(--transition);border:none;outline:none;white-space:nowrap;letter-spacing:.01em}.btn-primary{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);color:#fff;box-shadow:0 4px 16px var(--accent-glow)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-accent);filter:brightness(1.06)}.btn-outline{background:transparent;color:var(--text);border:1.5px solid var(--border2);backdrop-filter:blur(4px)}.btn-outline:hover{background:var(--surface2);border-color:var(--accent);color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow)}.section{padding:80px 0}.section-alt{background:var(--surface);position:relative}.section-alt:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 0%,rgba(124,58,237,.025) 50%,transparent 100%);pointer-events:none}.section-label{font-family:var(--font2);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);display:flex;align-items:center;gap:10px;margin-bottom:16px}.section-label:before{content:"";width:22px;height:2.5px;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:2px;flex-shrink:0}.section-label:after{content:"";width:8px;height:2.5px;background:var(--accent);border-radius:2px;opacity:.4}.section-title{font-family:var(--font2);font-size:clamp(24px,3.5vw,40px);font-weight:800;line-height:1.12;color:var(--text);margin-bottom:16px;letter-spacing:-.03em}.section-sub{font-size:16px;color:var(--muted);max-width:500px;line-height:1.8}.section-head{margin-bottom:48px}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:16px 0;transition:var(--transition)}.navbar.scrolled{background:var(--navbar-bg);backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border-bottom:1px solid var(--border);box-shadow:0 4px 30px #0000000d;padding:10px 0}.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}.nav-logo{font-family:var(--font2);font-size:22px;font-weight:700;color:var(--text);letter-spacing:-.02em;flex-shrink:0}.nav-logo span{color:var(--accent)}.nav-links{display:flex;align-items:center;gap:4px}.nav-links a{padding:6px 14px;border-radius:10px;font-size:14px;font-weight:500;color:var(--muted);transition:var(--transition);letter-spacing:.01em}.nav-links a:hover{color:var(--text);background:var(--surface2)}.nav-links a.active{color:var(--accent);background:var(--accent-light);font-weight:600}.nav-cta{background:var(--accent)!important;color:#fff!important;border-radius:10px;font-weight:600!important}.nav-cta:hover{filter:brightness(1.1);color:#fff!important}.nav-right{display:flex;align-items:center;gap:10px}.theme-toggle{width:38px;height:38px;border-radius:10px;background:var(--surface2);border:1.5px solid var(--border);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:17px;transition:var(--transition);color:var(--text);flex-shrink:0}.theme-toggle:hover{background:var(--surface3);border-color:var(--accent)}.menu-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:var(--surface2);border-radius:10px;border:1.5px solid var(--border)}.menu-toggle span{width:20px;height:2px;background:var(--text);border-radius:2px;transition:var(--transition)}.hero{min-height:100vh;display:flex;align-items:center;padding-top:90px;position:relative;overflow:hidden;background:var(--hero-gradient)}.hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none}.hero-blob{position:absolute;border-radius:50%;filter:blur(120px);animation:blobFloat 10s ease-in-out infinite alternate}.hero-blob-1{width:600px;height:600px;background:#10b98124;top:-180px;right:-120px}.hero-blob-2{width:440px;height:440px;background:#4f46e517;bottom:-80px;left:-100px;animation-delay:-5s}.hero-blob-3{width:280px;height:280px;background:#10b98112;top:40%;left:35%;animation-delay:-2.5s}[data-theme=dark] .hero-blob-1{background:#34d39924}[data-theme=dark] .hero-blob-2{background:#818cf81a}[data-theme=dark] .hero-blob-3{background:#34d3990d}@keyframes blobFloat{0%{transform:translate(0) scale(1)}to{transform:translate(20px,-30px) scale(1.08)}}.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;position:relative;z-index:1}.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;margin-bottom:24px;background:var(--accent-light);border:1px solid rgba(16,185,129,.25);border-radius:100px;padding:6px 14px 6px 8px;width:fit-content}[data-theme=dark] .hero-eyebrow{background:var(--accent-light);border-color:#34d39933}.hero-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:pulse 2s infinite;flex-shrink:0;box-shadow:0 0 6px var(--accent)}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.hero-eyebrow-text{font-size:12px;font-weight:600;color:var(--accent);letter-spacing:.04em}.hero-name{font-family:var(--font2);font-size:clamp(36px,4.5vw,64px);font-weight:800;line-height:1.05;letter-spacing:-.035em;color:var(--text);margin-bottom:16px}.hero-name span{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-title{font-size:clamp(16px,1.8vw,22px);font-weight:400;color:var(--muted);margin-bottom:26px;min-height:34px}.hero-title .typed{color:var(--text);font-weight:600}.cursor{display:inline-block;width:2px;height:1em;background:var(--accent);margin-left:2px;vertical-align:text-bottom;animation:blink .9s step-end infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-bio{color:var(--muted);font-size:16px;line-height:1.8;margin-bottom:36px;max-width:460px}.hero-actions{display:flex;gap:12px;flex-wrap:wrap}.hero-visual{display:flex;justify-content:center;align-items:center}.hero-img-wrapper{position:relative;width:320px;height:320px}.hero-img-ring{position:absolute;inset:-20px;border-radius:50%;border:1.5px dashed rgba(16,185,129,.4);animation:spin 24s linear infinite}[data-theme=dark] .hero-img-ring{border-color:#34d39959}.hero-img-ring-2{position:absolute;inset:-38px;border-radius:50%;border:1px dashed rgba(79,70,229,.2);animation:spin 40s linear infinite reverse}[data-theme=dark] .hero-img-ring-2{border-color:#818cf82e}.hero-img-ring:after{content:"";position:absolute;top:-6px;left:50%;width:12px;height:12px;border-radius:50%;background:var(--accent);transform:translate(-50%);box-shadow:0 0 10px var(--accent-glow)}.hero-img{width:100%;height:100%;border-radius:50%;object-fit:cover;border:5px solid var(--surface);box-shadow:var(--shadow-lg),0 0 40px var(--accent-glow)}.hero-img-placeholder{width:100%;height:100%;border-radius:50%;background:linear-gradient(135deg,var(--surface2),var(--surface3));border:5px solid var(--surface);box-shadow:var(--shadow-lg);display:flex;align-items:center;justify-content:center;font-size:80px}.hero-socials{position:absolute;right:-62px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:10px}.hero-social-link{width:42px;height:42px;border-radius:12px;background:var(--surface);border:1.5px solid var(--border);box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--muted);transition:var(--transition);backdrop-filter:blur(8px)}.hero-social-link:hover{background:var(--accent);color:#fff;border-color:transparent;transform:translate(-5px);box-shadow:0 6px 22px var(--accent-glow)}[data-theme=dark] .hero-social-link:hover{color:#000}.about-layout{display:grid;grid-template-columns:1fr 360px;gap:72px;align-items:start}.about-left{display:flex;flex-direction:column;align-items:flex-start}.about-text{color:var(--muted);line-height:1.9;font-size:16px;margin-bottom:40px}.about-cta{display:flex;gap:14px;flex-wrap:wrap}.about-right{align-self:start;padding-top:128px}.about-sidebar-card{background:var(--card-gradient);border:1.5px solid var(--border);border-radius:20px;padding:28px;box-shadow:var(--shadow-lg)}.about-sidebar-title{font-family:var(--font2);font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:22px;padding-bottom:14px;border-bottom:1.5px solid var(--border)}.about-info-list{display:flex;flex-direction:column;gap:18px}.about-info-row{display:flex;align-items:flex-start;gap:14px}.about-info-icon{width:38px;height:38px;border-radius:11px;background:var(--accent-light);border:1px solid rgba(16,185,129,.15);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.about-info-details{display:flex;flex-direction:column;gap:3px;min-width:0}.about-info-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted2)}.about-info-value{font-size:14px;font-weight:600;color:var(--text);word-break:break-word}.skills-layout{display:grid;grid-template-columns:200px 1fr;gap:48px;align-items:start}.skills-cats{display:flex;flex-direction:column;gap:6px;position:sticky;top:100px}.skills-cat-btn{padding:11px 16px;border-radius:11px;background:transparent;border:1.5px solid var(--border);color:var(--muted);font-family:var(--font);font-size:14px;font-weight:500;cursor:pointer;transition:var(--transition);text-align:left}.skills-cat-btn:hover{background:var(--surface2);color:var(--text);border-color:var(--border2)}.skills-cat-btn.active{background:var(--accent-light);color:var(--accent);border-color:var(--accent);font-weight:600}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:14px}.skill-card{background:var(--navbar-bg);backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:20px;transition:var(--transition);box-shadow:0 4px 30px #0000000d;position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:center;text-align:center}[data-theme=dark] .skill-card{border:1px solid rgba(255,255,255,.05);box-shadow:0 4px 30px #0003}.skill-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--accent-glow),transparent 60%);opacity:0;transition:var(--transition);pointer-events:none}.skill-card:hover:before{opacity:1}.skill-card:hover{border-color:var(--accent);transform:translateY(-5px);box-shadow:var(--shadow-lg),0 0 0 1px #10b9811a}.skill-img-wrap{width:44px;height:44px;border-radius:12px;background:var(--surface2);display:flex;align-items:center;justify-content:center;margin-bottom:14px;overflow:hidden;flex-shrink:0;border:1px solid var(--border)}.skill-img-wrap img{width:100%;height:100%;object-fit:contain}.skill-img-icon{font-size:21px;color:var(--accent)}.skill-name{font-size:14px;font-weight:700;color:var(--text);margin-bottom:0;letter-spacing:.01em}.projects-filter{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:44px}.filter-btn{padding:8px 18px;border-radius:100px;background:var(--surface);border:1.5px solid var(--border);color:var(--muted);font-family:var(--font);font-size:13px;font-weight:500;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow)}.filter-btn.active,.filter-btn:hover{background:var(--accent);color:#fff;border-color:transparent;box-shadow:0 4px 14px #05966940}[data-theme=dark] .filter-btn.active,[data-theme=dark] .filter-btn:hover{color:#000}.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.project-card{background:var(--card-gradient);border:1.5px solid var(--border);border-radius:20px;overflow:hidden;transition:var(--transition);box-shadow:var(--shadow)}.project-card:hover{border-color:var(--accent);box-shadow:var(--shadow-xl),0 0 0 1px #10b9811a}.project-card:has(.project-iframe:hover){transform:none}.project-preview{width:100%;height:380px;position:relative;overflow:hidden;background:var(--surface2);border-bottom:1px solid var(--border)}.project-preview-bar{position:absolute;top:0;left:0;right:0;height:32px;background:var(--surface3);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:6px;padding:0 12px;z-index:2;flex-shrink:0}.preview-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.preview-dot-1{background:#ef4444}.preview-dot-2{background:#eab308}.preview-dot-3{background:#22c55e}.preview-url{flex:1;height:18px;background:var(--surface);border-radius:5px;border:1px solid var(--border);margin:0 10px;font-size:10px;font-family:monospace;color:var(--muted);display:flex;align-items:center;padding:0 10px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.project-iframe{position:absolute;top:32px;left:0;width:100%;height:calc(100% - 32px);border:none;pointer-events:auto;display:block}.project-static-img{position:absolute;inset:32px 0 0;object-fit:cover;width:100%;height:calc(100% - 32px)}.project-preview-placeholder{position:absolute;inset:32px 0 0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--muted2);background:linear-gradient(135deg,var(--surface2) 0%,var(--surface3) 100%)}.project-preview-placeholder span{font-size:40px}.project-preview-placeholder p{font-size:13px;font-weight:500}.preview-spinner{width:36px;height:36px;border:3px solid var(--surface3);border-top-color:var(--accent);border-radius:50%;animation:spinLoader .8s linear infinite}@keyframes spinLoader{to{transform:rotate(360deg)}}.project-body{padding:16px 20px}.project-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.project-tag{font-size:11px;padding:3px 10px;border-radius:100px;background:var(--surface2);color:var(--muted);border:1px solid var(--border);font-weight:500}.project-title{font-family:var(--font2);font-size:15px;font-weight:700;color:var(--text);margin-bottom:6px;line-height:1.3}.project-desc{font-size:14px;color:var(--muted);line-height:1.7;margin-bottom:18px;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-links{display:flex;gap:8px}.project-link{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:600;color:var(--accent);padding:7px 14px;border-radius:9px;background:var(--accent-light);border:1px solid rgba(5,150,105,.2);transition:var(--transition)}[data-theme=dark] .project-link{border-color:#6ee7b733}.project-link:hover{filter:brightness(1.08);transform:translateY(-2px)}.project-link.github{color:var(--muted);background:var(--surface2);border-color:var(--border)}.project-link.github:hover{color:var(--text);border-color:var(--border2)}.timeline-section{display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:start}.timeline-col-title{font-family:var(--font2);font-size:19px;font-weight:700;color:var(--text);margin-bottom:28px;display:flex;align-items:center;gap:12px}.timeline-col-icon{width:36px;height:36px;border-radius:10px;background:var(--accent-light);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}.timeline{position:relative}.timeline:before{content:"";position:absolute;left:16px;top:0;bottom:0;width:1px;background:var(--border2)}.timeline-item{position:relative;padding-left:48px;padding-bottom:30px}.timeline-item:last-child{padding-bottom:0}.timeline-dot{position:absolute;left:10px;top:5px;width:13px;height:13px;border-radius:50%;background:var(--accent);border:2px solid var(--bg);box-shadow:0 0 0 3px #05966933}[data-theme=dark] .timeline-dot{box-shadow:0 0 0 3px #6ee7b733}.timeline-dot.edu{background:var(--accent2);box-shadow:0 0 0 3px #2563eb33}.timeline-date{font-size:12px;font-weight:600;color:var(--accent);margin-bottom:5px}.timeline-role{font-family:var(--font2);font-size:16px;font-weight:700;color:var(--text);margin-bottom:3px;line-height:1.35}.timeline-company{font-size:14px;font-weight:500;color:var(--muted);margin-bottom:8px}.timeline-desc{font-size:14px;color:var(--muted);line-height:1.75}.timeline-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:2px 10px;border-radius:100px;background:#2563eb1a;color:var(--accent2);margin-top:8px}.timeline-current{background:#0596691a;color:var(--accent)}.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:18px}.service-card{background:var(--card-gradient);border:1.5px solid var(--border);border-radius:20px;padding:32px;transition:var(--transition);box-shadow:var(--shadow);position:relative;overflow:hidden}.service-card:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent2));transform:scaleX(0);transform-origin:left;transition:var(--transition);border-radius:0 0 2px 2px}.service-card:hover:after{transform:scaleX(1)}.service-card:hover{border-color:var(--accent);transform:translateY(-5px);box-shadow:var(--shadow-xl)}.service-icon{width:54px;height:54px;border-radius:16px;background:var(--accent-light);color:var(--accent);border:1px solid rgba(16,185,129,.2);display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:20px}.service-title{font-family:var(--font2);font-size:18px;font-weight:700;color:var(--text);margin-bottom:8px}.service-desc{font-size:14px;color:var(--muted);line-height:1.75}.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}.testimonial-card{background:var(--card-gradient);border:1.5px solid var(--border);border-radius:20px;padding:28px;display:flex;flex-direction:column;gap:18px;transition:var(--transition);box-shadow:var(--shadow);position:relative;overflow:hidden}.testimonial-card:before{content:"“";position:absolute;top:-10px;right:20px;font-size:100px;font-family:Georgia,serif;color:var(--accent);opacity:.07;line-height:1;pointer-events:none}.testimonial-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:var(--shadow-lg)}.testimonial-stars{display:flex;gap:3px}.testimonial-star{color:#f59e0b;font-size:14px}.testimonial-quote{font-size:15px;color:var(--text2);line-height:1.8;flex:1;font-style:italic}.testimonial-quote:before{content:'"';color:var(--accent);font-size:28px;line-height:0;vertical-align:-10px;margin-right:3px}.testimonial-author{display:flex;align-items:center;gap:12px}.testimonial-avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;background:var(--accent-light);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;color:var(--accent);border:2px solid var(--border);flex-shrink:0;overflow:hidden}.testimonial-info-name{font-size:14px;font-weight:700;color:var(--text)}.testimonial-info-role{font-size:12px;color:var(--muted)}.contact-wrapper{display:grid;grid-template-columns:1fr 1.3fr;gap:52px;align-items:start}.contact-info-items{display:flex;flex-direction:column;gap:12px;margin:26px 0 32px}.contact-info-item{display:flex;align-items:center;gap:14px}.contact-info-icon{width:42px;height:42px;border-radius:11px;background:var(--accent-light);border:1px solid rgba(5,150,105,.2);display:flex;align-items:center;justify-content:center;font-size:17px;color:var(--accent);flex-shrink:0}.contact-info-label{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.contact-info-value{font-size:15px;color:var(--text);font-weight:500}.contact-socials{display:flex;gap:9px}.contact-social{width:42px;height:42px;border-radius:11px;background:var(--surface2);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:17px;color:var(--muted);transition:var(--transition)}.contact-social:hover{background:var(--accent);color:#fff;border-color:transparent;transform:translateY(-3px);box-shadow:0 6px 18px #0596694d}[data-theme=dark] .contact-social:hover{color:#000}.contact-form{display:flex;flex-direction:column;gap:14px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:13px;font-weight:600;color:var(--text2)}.form-group input,.form-group textarea{background:var(--surface2);border:1.5px solid var(--border);border-radius:12px;padding:13px 16px;font-family:var(--font);font-size:15px;color:var(--text);transition:var(--transition);outline:none;resize:none}.form-group input:focus,.form-group textarea:focus{background:var(--surface);border-color:var(--accent);box-shadow:0 0 0 3px #10b9811a}[data-theme=dark] .form-group input,[data-theme=dark] .form-group textarea{background:var(--surface2)}[data-theme=dark] .form-group input:focus,[data-theme=dark] .form-group textarea:focus{background:var(--surface3);box-shadow:0 0 0 3px #34d3991a}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--muted2)}textarea{min-height:130px}.form-success{display:flex;align-items:center;gap:10px;padding:13px 16px;background:#05966914;border:1.5px solid rgba(5,150,105,.25);border-radius:11px;color:var(--accent);font-size:14px;font-weight:500}.form-error{color:#ef4444;font-size:13px;padding:3px 0}.footer{border-top:1px solid var(--border);padding:48px 0;background:var(--surface);position:relative}.footer:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:200px;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent)}.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}.footer-logo{font-family:var(--font2);font-size:20px;font-weight:700;color:var(--text)}.footer-logo span{color:var(--accent)}.footer-copy{font-size:14px;color:var(--muted)}.footer-links{display:flex;gap:20px}.footer-links a{font-size:14px;color:var(--muted);transition:var(--transition)}.footer-links a:hover{color:var(--accent)}.scroll-top{position:fixed;bottom:28px;right:28px;width:42px;height:42px;border-radius:11px;background:var(--accent);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:17px;transition:var(--transition);opacity:0;pointer-events:none;z-index:999;box-shadow:0 4px 18px #05966959}[data-theme=dark] .scroll-top{color:#000;box-shadow:0 4px 18px #6ee7b759}.scroll-top.visible{opacity:1;pointer-events:all}.scroll-top:hover{transform:translateY(-3px);filter:brightness(1.1)}@media(max-width:960px){.hero-grid{grid-template-columns:1fr;gap:44px}.hero-visual{order:-1}.hero-img-wrapper{width:260px;height:260px}.hero-socials{right:-18px}.about-grid{grid-template-columns:1fr;gap:44px}.about-img-badge{right:16px;bottom:16px}.skills-layout{grid-template-columns:1fr}.skills-cats{flex-direction:row;flex-wrap:wrap;position:static}.timeline-section,.projects-grid,.contact-wrapper{grid-template-columns:1fr}.nav-links{display:none}.nav-links.open{display:flex;flex-direction:column;position:fixed;inset:0;background:var(--bg);z-index:999;align-items:center;justify-content:center;gap:8px;font-size:20px}.nav-links.open a{padding:12px 28px}.menu-toggle{display:flex}.form-row{grid-template-columns:1fr}.footer-inner{flex-direction:column;text-align:center}}@media(max-width:600px){.section{padding:68px 0}.projects-grid{grid-template-columns:1fr}.hero-name{font-size:38px}}@keyframes skel-shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}.skel{display:block;background:linear-gradient(90deg,var(--surface2) 25%,var(--surface3) 50%,var(--surface2) 75%);background-size:600px 100%;animation:skel-shimmer 1.4s ease-in-out infinite}.reveal{opacity:0;transform:translateY(36px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1);transition-delay:var(--delay, 0ms)}.reveal.revealed{opacity:1;transform:none}.reveal-left{opacity:0;transform:translate(-40px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1);transition-delay:var(--delay, 0ms)}.reveal-left.revealed{opacity:1;transform:none}.reveal-right{opacity:0;transform:translate(40px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1);transition-delay:var(--delay, 0ms)}.reveal-right.revealed{opacity:1;transform:none}@media(prefers-reduced-motion:reduce){.reveal,.reveal-left,.reveal-right{opacity:1;transform:none;transition:none}}:root{--adm-bg: #0d0d0d;--adm-sidebar: #111115;--adm-surface: #18181d;--adm-surface2: #222228;--adm-surface3: #2a2a32;--adm-border: rgba(255, 255, 255, .06);--adm-border2: rgba(255, 255, 255, .12);--adm-accent: #6366f1;--adm-accent2: #8b5cf6;--adm-success: #22c55e;--adm-danger: #ef4444;--adm-warning: #f59e0b;--adm-text: #f1f1f4;--adm-text2: #a1a1b0;--adm-text3: #6b6b80;--adm-sidebar-w: 240px;--adm-radius: 14px;--adm-radius-sm: 8px;--adm-shadow: 0 4px 24px rgba(0, 0, 0, .4);--adm-shadow-lg: 0 8px 48px rgba(0, 0, 0, .6);--adm-trans: .2s cubic-bezier(.4, 0, .2, 1)}.admin-root *,.admin-root *:before,.admin-root *:after{box-sizing:border-box}.admin-root{display:flex;height:100vh;background:var(--adm-bg);color:var(--adm-text);font-family:Inter,sans-serif;overflow:hidden}.adm-sidebar{width:var(--adm-sidebar-w);min-width:var(--adm-sidebar-w);background:var(--adm-sidebar);border-right:1px solid var(--adm-border);display:flex;flex-direction:column;height:100vh;position:sticky;top:0;overflow-y:auto;overflow-x:hidden;z-index:50}.adm-sidebar-logo{padding:28px 20px 20px;border-bottom:1px solid var(--adm-border)}.adm-sidebar-logo-mark{display:flex;align-items:center;gap:10px;text-decoration:none}.adm-sidebar-logo-icon{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--adm-accent),var(--adm-accent2));display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;box-shadow:0 4px 12px #6366f159}.adm-sidebar-title{font-family:Space Grotesk,sans-serif;font-size:15px;font-weight:700;color:var(--adm-text);letter-spacing:-.01em}.adm-sidebar-subtitle{font-size:10px;color:var(--adm-text3);font-weight:500;letter-spacing:.04em;text-transform:uppercase;margin-top:2px}.adm-sidebar-user{padding:14px 20px;display:flex;align-items:center;gap:10px;background:var(--adm-surface);margin:12px 12px 0;border-radius:10px;border:1px solid var(--adm-border)}.adm-sidebar-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--adm-accent),var(--adm-accent2));display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0}.adm-sidebar-username{font-size:13px;font-weight:600;color:var(--adm-text);line-height:1.2}.adm-sidebar-role{font-size:10px;color:var(--adm-accent);font-weight:500;text-transform:uppercase;letter-spacing:.06em}.adm-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.adm-nav-section-label{font-size:9.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--adm-text3);padding:10px 8px 4px}.adm-nav-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:9px;font-size:13.5px;font-weight:500;color:var(--adm-text2);text-decoration:none;transition:var(--adm-trans);cursor:pointer;border:none;background:transparent;width:100%;text-align:left}.adm-nav-link:hover{background:var(--adm-surface2);color:var(--adm-text)}.adm-nav-link.active{background:#6366f126;color:#a5b4fc;font-weight:600}.adm-nav-link.active .adm-nav-icon{color:#a5b4fc}.adm-nav-icon{color:var(--adm-text3);flex-shrink:0;transition:var(--adm-trans)}.adm-nav-link:hover .adm-nav-icon{color:var(--adm-text)}.adm-nav-link.danger,.adm-nav-link.danger .adm-nav-icon{color:#f87171}.adm-nav-link.danger:hover{background:#ef44441a;color:#fca5a5}.adm-sidebar-footer{border-top:1px solid var(--adm-border);padding:12px}.adm-main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--adm-bg)}.adm-topbar{height:60px;border-bottom:1px solid var(--adm-border);background:#0d0d0de6;backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:space-between;padding:0 28px;flex-shrink:0;position:sticky;top:0;z-index:40}.adm-topbar-breadcrumb{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--adm-text2)}.adm-topbar-breadcrumb span{color:var(--adm-text);font-weight:600}.adm-topbar-actions{display:flex;align-items:center;gap:10px}.adm-topbar-badge{height:32px;padding:0 12px;border-radius:8px;background:var(--adm-surface2);border:1px solid var(--adm-border);font-size:12px;color:var(--adm-text2);display:flex;align-items:center;gap:6px;font-weight:500}.adm-topbar-badge .dot{width:6px;height:6px;border-radius:50%;background:var(--adm-success)}.adm-content{flex:1;overflow-y:auto;padding:28px}.adm-page-header{margin-bottom:28px}.adm-page-title{font-family:Space Grotesk,sans-serif;font-size:22px;font-weight:700;color:var(--adm-text);letter-spacing:-.02em;margin-bottom:4px}.adm-page-desc{font-size:13px;color:var(--adm-text2)}.adm-card{background:var(--adm-surface);border:1px solid var(--adm-border);border-radius:var(--adm-radius);padding:24px;box-shadow:var(--adm-shadow)}.adm-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--adm-border)}.adm-card-title{font-family:Space Grotesk,sans-serif;font-size:15px;font-weight:600;color:var(--adm-text)}.adm-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:28px}.adm-stat-card{background:var(--adm-surface);border:1px solid var(--adm-border);border-radius:var(--adm-radius);padding:20px;display:flex;flex-direction:column;gap:12px;transition:var(--adm-trans);cursor:pointer;text-decoration:none;position:relative;overflow:hidden}.adm-stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;border-radius:2px 2px 0 0;opacity:0;transition:opacity var(--adm-trans)}.adm-stat-card:hover{border-color:var(--adm-border2);transform:translateY(-2px);box-shadow:var(--adm-shadow)}.adm-stat-card:hover:before{opacity:1}.adm-stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px}.adm-stat-num{font-family:Space Grotesk,sans-serif;font-size:28px;font-weight:700;color:var(--adm-text);line-height:1}.adm-stat-label{font-size:12px;color:var(--adm-text2);font-weight:500}.adm-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.adm-form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.adm-form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.adm-form-group:last-child{margin-bottom:0}.adm-label{font-size:12px;font-weight:600;color:var(--adm-text2);letter-spacing:.02em;text-transform:uppercase}.adm-input{background:var(--adm-surface2);border:1px solid var(--adm-border2);border-radius:var(--adm-radius-sm);padding:10px 14px;font-size:13.5px;color:var(--adm-text);font-family:Inter,sans-serif;transition:var(--adm-trans);outline:none;width:100%}.adm-input::placeholder{color:var(--adm-text3)}.adm-input:focus{border-color:var(--adm-accent);box-shadow:0 0 0 3px #6366f126;background:var(--adm-surface3)}.adm-input:disabled{opacity:.5;cursor:not-allowed}select.adm-input{cursor:pointer}textarea.adm-input{resize:vertical;min-height:90px;line-height:1.6}input[type=range].adm-input{padding:6px 0;accent-color:var(--adm-accent);cursor:pointer}input[type=color].adm-input{height:42px;padding:4px 8px;cursor:pointer}.adm-input-hint{font-size:11px;color:var(--adm-text3);margin-top:2px}.adm-section-divider{border:none;border-top:1px solid var(--adm-border);margin:24px 0}.adm-section-subtitle{font-size:13px;font-weight:600;color:var(--adm-text);margin-bottom:16px;display:flex;align-items:center;gap:8px}.adm-upload-box{display:flex;align-items:center;gap:12px;background:var(--adm-surface2);border:1px dashed var(--adm-border2);border-radius:var(--adm-radius-sm);padding:12px 14px;transition:var(--adm-trans)}.adm-upload-box:hover{border-color:var(--adm-accent);background:var(--adm-surface3)}.adm-upload-preview{width:44px;height:44px;border-radius:8px;object-fit:cover;border:2px solid var(--adm-border2);flex-shrink:0}.adm-upload-preview.circle{border-radius:50%}.adm-upload-btn{flex:1}.adm-upload-btn input[type=file]{font-size:12px;color:var(--adm-text2);cursor:pointer;width:100%}.adm-btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:var(--adm-radius-sm);font-size:13px;font-weight:600;font-family:Inter,sans-serif;cursor:pointer;transition:var(--adm-trans);border:none;outline:none;white-space:nowrap;text-decoration:none}.adm-btn-primary{background:var(--adm-accent);color:#fff;box-shadow:0 4px 14px #6366f14d}.adm-btn-primary:hover{background:#5254e0;transform:translateY(-1px);box-shadow:0 6px 20px #6366f166}.adm-btn-secondary{background:var(--adm-surface2);color:var(--adm-text2);border:1px solid var(--adm-border2)}.adm-btn-secondary:hover{background:var(--adm-surface3);color:var(--adm-text);border-color:var(--adm-border2)}.adm-btn-danger{background:#ef444426;color:#f87171;border:1px solid rgba(239,68,68,.25)}.adm-btn-danger:hover{background:#ef444440;color:#fca5a5}.adm-btn-ghost{background:transparent;color:var(--adm-text3);padding:6px 8px}.adm-btn-ghost:hover{background:var(--adm-surface2);color:var(--adm-text)}.adm-btn-sm{padding:6px 12px;font-size:12px}.adm-btn-icon{padding:7px;border-radius:7px}.adm-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:100px;font-size:11px;font-weight:600}.adm-badge-success{background:#22c55e26;color:#4ade80;border:1px solid rgba(34,197,94,.2)}.adm-badge-warning{background:#f59e0b1f;color:#fbbf24;border:1px solid rgba(245,158,11,.2)}.adm-badge-danger{background:#ef44441f;color:#f87171;border:1px solid rgba(239,68,68,.2)}.adm-table-wrap{overflow-x:auto;border-radius:var(--adm-radius-sm);border:1px solid var(--adm-border)}.adm-table{width:100%;border-collapse:collapse;font-size:13px}.adm-table thead{background:var(--adm-surface2)}.adm-table th{padding:12px 14px;text-align:left;font-size:11px;font-weight:600;color:var(--adm-text3);text-transform:uppercase;letter-spacing:.08em;white-space:nowrap}.adm-table td{padding:12px 14px;color:var(--adm-text2);border-top:1px solid var(--adm-border);vertical-align:middle}.adm-table tbody tr:hover td{background:var(--adm-surface2);color:var(--adm-text)}.adm-table-actions{display:flex;align-items:center;gap:4px}.adm-toast{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:var(--adm-radius-sm);font-size:13px;font-weight:500;animation:fadeIn .3s ease}.adm-toast-success{background:#22c55e1f;color:#4ade80;border:1px solid rgba(34,197,94,.2)}.adm-toast-error{background:#ef44441f;color:#f87171;border:1px solid rgba(239,68,68,.2)}.adm-toast-info{background:#6366f11f;color:#a5b4fc;border:1px solid rgba(99,102,241,.2)}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}.adm-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;gap:14px;color:var(--adm-text2);font-size:14px}.adm-spinner{width:36px;height:36px;border:3px solid var(--adm-border2);border-top-color:var(--adm-accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.adm-btn-spinner{width:13px;height:13px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0;display:inline-block}.adm-btn:disabled{opacity:.65;cursor:not-allowed;transform:none!important;box-shadow:none!important}.adm-form-actions{display:flex;align-items:center;gap:12px;padding-top:20px;border-top:1px solid var(--adm-border);margin-top:20px}.adm-quick-grid{display:flex;flex-wrap:wrap;gap:10px}.adm-quick-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:9px;background:var(--adm-surface2);border:1px solid var(--adm-border2);color:var(--adm-text2);font-size:13px;font-weight:500;cursor:pointer;transition:var(--adm-trans);text-decoration:none}.adm-quick-btn:hover{background:#6366f11f;border-color:#6366f14d;color:#a5b4fc}.adm-login-wrap{height:100vh;display:flex;align-items:center;justify-content:center;background:var(--adm-bg);font-family:Inter,sans-serif}.adm-login-box{width:100%;max-width:400px;padding:36px;background:var(--adm-surface);border:1px solid var(--adm-border);border-radius:20px;box-shadow:var(--adm-shadow-lg)}.adm-login-logo{display:flex;align-items:center;gap:12px;margin-bottom:28px}.adm-login-logo-icon{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,var(--adm-accent),var(--adm-accent2));display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:0 4px 16px #6366f166}.adm-login-title{font-family:Space Grotesk,sans-serif;font-size:20px;font-weight:700;color:var(--adm-text)}.adm-login-sub{font-size:12px;color:var(--adm-text3)}.adm-color-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}@media(max-width:768px){.adm-sidebar{position:fixed;left:-100%;transition:left var(--adm-trans);z-index:100}.adm-sidebar.open{left:0}.adm-form-grid,.adm-form-grid-3{grid-template-columns:1fr}.adm-content{padding:16px}}
