*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #eaf6ff;--bg2: #ffffff;--surface: #ffffff;--surface2: #e0f2fe;--surface3: #bae6fd;--border: rgba(14, 165, 233, .15);--border2: rgba(14, 165, 233, .25);--accent: #0ea5e9;--accent-dark: #0369a1;--accent-light: #e0f2fe;--accent-glow: rgba(14, 165, 233, .25);--accent2: #2dd4bf;--accent2-light: #f0fdfa;--text: #0f172a;--text2: #1e293b;--muted: #475569;--muted2: #94a3b8;--shadow: 0 1px 4px rgba(14, 165, 233, .06), 0 4px 20px rgba(14, 165, 233, .08);--shadow-lg: 0 8px 36px rgba(14, 165, 233, .12);--shadow-xl: 0 20px 60px rgba(14, 165, 233, .16);--shadow-accent: 0 8px 28px rgba(14, 165, 233, .3);--font: "Inter", sans-serif;--font2: "Space Grotesk", sans-serif;--radius: 16px;--transition: .25s cubic-bezier(.4, 0, .2, 1);--navbar-bg: rgba(255, 255, 255, .35);--hero-gradient: linear-gradient(135deg, #bae6fd 0%, #e0f2fe 50%, #dbeafe 100%);--card-gradient: linear-gradient(145deg, #ffffff, #e0f2fe)}html{scroll-behavior:smooth;font-size:15px}body{background:var(--hero-gradient);background-attachment:fixed;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,#0ea5e9,#0284c7);color:#fff;box-shadow:0 4px 16px var(--accent-glow);border:1px solid rgba(255,255,255,.3)}.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 rgba(255,255,255,.5);box-shadow:0 10px 30px #0ea5e914;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-split{min-height:100vh;display:flex;overflow:hidden;position:relative;background:#fff}.hero-split:after{content:"";position:absolute;top:0;right:0;width:50%;height:100%;background:#0f172a;clip-path:polygon(15% 0,100% 0,100% 100%,0% 100%);z-index:1}.hero-left{flex:1;display:flex;align-items:center;justify-content:center;padding:80px 40px;background:#fff;z-index:2;position:relative}.hero-content{max-width:540px;width:100%}.hero-greeting{font-size:24px;font-weight:500;color:#1f2937;margin-bottom:8px;font-family:var(--font2);opacity:0;transform:translateY(20px);animation:fadeUp .8s forwards}.hero-name-big{font-size:clamp(40px,6vw,76px);font-weight:900;color:#111827;line-height:1.1;margin-bottom:20px;text-transform:uppercase;font-family:var(--font2);opacity:0;transform:translateY(20px);animation:fadeUp .8s .2s forwards}.hero-name-big span{color:var(--accent)}.hero-subtitle{font-size:20px;color:#4b5563;margin-bottom:32px;font-weight:400;font-family:var(--font);opacity:0;transform:translateY(20px);animation:fadeUp .8s .4s forwards;min-height:30px;display:block}.hero-social-row{display:flex;gap:12px;margin-bottom:32px;opacity:0;transform:translateY(20px);animation:fadeUp .8s .6s forwards}.hero-social-box{width:44px;height:44px;background:#374151;color:#fff;display:flex;align-items:center;justify-content:center;border-radius:8px;font-size:18px;transition:all .3s ease;box-shadow:0 4px 10px #0000001a}.hero-social-box:hover{background:var(--accent);transform:translateY(-4px);box-shadow:0 8px 20px var(--accent-glow)}.hero-cv-actions{display:flex;gap:16px;opacity:0;transform:translateY(20px);animation:fadeUp .8s .8s forwards}.cv-btn{display:inline-flex;align-items:center;gap:10px;padding:12px 24px;border-radius:8px;font-weight:700;font-size:14px;transition:all .3s ease;text-transform:uppercase;letter-spacing:.05em}.cv-btn.primary{background:#f97316;color:#fff}.cv-btn.secondary{background:#374151;color:#fff}.cv-btn:hover{transform:translateY(-2px);filter:brightness(1.1);box-shadow:0 10px 20px #00000026}.hero-divide-line{position:absolute;top:0;right:0;width:50%;height:100%;z-index:5;pointer-events:none}.hero-divide-line:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to bottom,transparent 0%,rgba(14,165,233,.2) 20%,rgba(14,165,233,.8) 50%,rgba(14,165,233,.2) 80%,transparent 100%);background-size:100% 150px;background-repeat:no-repeat;clip-path:polygon(15% 0,15.6% 0,.6% 100%,0% 100%);animation:sparkSlide 3s infinite linear;filter:drop-shadow(0 0 8px var(--accent));opacity:.6}@keyframes sparkSlide{0%{background-position:0 -150px}to{background-position:0 100vh}}@media(max-width:992px){.hero-divide-line{display:none}}.hero-right{flex:1;display:flex;align-items:center;justify-content:center;z-index:2;position:relative}.hero-img-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden;opacity:0;transform:translate(50px) scale(.95);animation:imageEnter 1.2s cubic-bezier(.23,1,.32,1) .5s forwards}.hero-main-img{width:100%;height:100%;object-fit:cover}.hero-img-placeholder{font-size:120px;color:#ffffff1a}@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}@keyframes imageEnter{to{opacity:1;transform:translate(0) scale(1)}}@media(max-width:992px){.hero-split{flex-direction:column}.hero-split:after{width:100%;height:50%;bottom:0;top:auto;clip-path:polygon(0 15%,100% 0,100% 100%,0% 100%)}.hero-left,.hero-right{padding:60px 24px}.hero-right{min-height:400px}}.about-layout{display:flex;flex-direction:column;align-items:flex-start;text-align:left;width:100%}.about-left{display:flex;flex-direction:column;align-items:flex-start;width:100%}.about-text{color:var(--muted);line-height:1.9;font-size:16px;margin-bottom:40px;text-align:justify}.about-cta{display:flex;justify-content:flex-start;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:8px;letter-spacing:.01em}.skill-level-container{width:100%;display:flex;align-items:center;gap:8px;margin-top:4px}.skill-level-progress{flex:1;height:4px;background:var(--surface3);border-radius:10px;overflow:hidden;position:relative}.skill-level-bar{height:100%;border-radius:10px;transition:width 1.5s cubic-bezier(.17,.67,.83,.67);box-shadow:0 0 8px var(--accent-glow)}.skill-level-percent{font-size:11px;font-weight:600;color:var(--muted);min-width:25px;text-align:right}.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-card{background:#fff6;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.5);border-radius:20px;padding:24px 30px;box-shadow:0 10px 40px #0ea5e914,inset 0 0 0 1px #fff6;transition:transform .3s ease,box-shadow .3s ease}.timeline-card:hover{transform:translateY(-4px);box-shadow:0 15px 50px #0ea5e926,inset 0 0 0 1px #fff9}.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:#ffffff80;backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.6);display:flex;align-items:center;justify-content:center;font-size:17px;color:var(--accent-dark);flex-shrink:0;box-shadow:0 4px 12px #0ea5e91a}.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:#fff6;backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;font-size:17px;color:var(--muted);transition:var(--transition);box-shadow:0 4px 12px #0ea5e90d}.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:#ffffff73;backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.6);border-radius:12px;padding:13px 16px;font-family:var(--font);font-size:15px;color:var(--text);transition:var(--transition);outline:none;resize:none;box-shadow:inset 0 2px 4px #00000005}.form-group input:focus,.form-group textarea:focus{background:#ffffffb3;border-color:var(--accent);box-shadow:0 0 0 3px #0ea5e926,inset 0 2px 4px #00000005}[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}.nav-logo{font-size:20px;max-width:200px;white-space:normal;line-height:1.2}.hero-actions{flex-direction:column;align-items:stretch}.hero-actions .btn{width:100%;text-align:center;justify-content:center}.contact-form{width:100%;overflow:hidden}.form-group input,.form-group textarea{width:100%;max-width:100%;box-sizing:border-box}}@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}.snowfall-container{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:hidden;z-index:0}.snowflake{position:absolute;top:-10%;background:#fff;border-radius:50%;filter:blur(1px);animation:fall linear infinite}@keyframes fall{0%{transform:translateY(0) translate(0) scale(1);opacity:1}to{transform:translateY(110vh) translate(var(--drift)) scale(var(--scale));opacity:0}}@media(prefers-reduced-motion:reduce){.reveal,.reveal-left,.reveal-right{opacity:1;transform:none;transition:none}}.testi-section{position:relative;overflow:hidden;background:var(--bg)}.testi-blob{position:absolute;border-radius:50%;filter:blur(100px);pointer-events:none;z-index:0}.testi-blob-1{width:500px;height:500px;background:#0ea5e914;top:-100px;left:-150px}.testi-blob-2{width:400px;height:400px;background:#2dd4bf0f;bottom:-80px;right:-100px}.testi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}.testi-card{position:relative;background:var(--surface);border-radius:20px;padding:32px 28px 24px;border:1.5px solid var(--border);box-shadow:var(--shadow);transition:var(--transition);overflow:hidden;display:flex;flex-direction:column;gap:14px}.testi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:20px 20px 0 0;opacity:0;transition:var(--transition)}.testi-card:hover:before{opacity:1}.testi-card:hover{border-color:var(--accent);transform:translateY(-6px);box-shadow:var(--shadow-lg),0 0 0 1px #0ea5e91a}.testi-quote-icon{font-family:Georgia,serif;font-size:72px;line-height:.6;color:var(--accent);opacity:.15;position:absolute;top:28px;right:24px;user-select:none;pointer-events:none}.testi-stars{display:flex;gap:3px}.testi-star{font-size:15px;color:var(--surface3);transition:color .2s}.testi-star.filled{color:#f59e0b}.testi-text{font-size:15px;color:var(--muted);line-height:1.8;flex:1;font-style:italic}.testi-divider{height:1px;background:linear-gradient(90deg,var(--accent),transparent);opacity:.25}.testi-author{display:flex;align-items:center;gap:14px}.testi-avatar{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff;flex-shrink:0;overflow:hidden;border:2.5px solid var(--accent-light);box-shadow:0 0 0 3px var(--border)}.testi-avatar img{width:100%;height:100%;object-fit:cover}.testi-name{font-size:15px;font-weight:700;color:var(--text);font-family:var(--font2)}.testi-role{font-size:12px;color:var(--accent);font-weight:500;margin-top:2px;letter-spacing:.02em}: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}}
