@import url(https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;0,900;1,400&family=DM+Sans:wght@300;400;500;600&family=DM+Mono:wght@400;500&display=swap);:root{--bg-primary:#151617;--bg-secondary:#0d1117;--bg-card:#111720;--bg-card-hover:#161e2a;--border:#1e2d3d;--border-light:#243447;--accent:#e8c44a;--accent-dim:#e8c44a1f;--accent-glow:#e8c44a4d;--text-primary:#e8edf2;--text-secondary:#89a;--text-muted:#a7adb8;--text-accent:#e8c44a;--font-display:"Playfair Display",Georgia,serif;--font-body:"DM Sans",sans-serif;--font-mono:"DM Mono",monospace;--radius:8px;--radius-lg:16px;--transition:0.3s cubic-bezier(0.4,0,0.2,1);--transition-slow:0.6s cubic-bezier(0.4,0,0.2,1);--shadow:0 4px 24px #c6adad66;--shadow-accent:0 0 40px #e8c44a1a;--navbar-height:72px}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#151617;background-color:var(--bg-primary);color:#e8edf2;color:var(--text-primary);font-family:DM Sans,sans-serif;font-family:var(--font-body);line-height:1.7;overflow-x:hidden}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#151617;background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:#243447;background:var(--border-light);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#e8c44a;background:var(--accent)}::selection{background:#e8c44a;background:var(--accent);color:#151617;color:var(--bg-primary)}h1,h2,h3,h4,h5,h6{color:#e8edf2;color:var(--text-primary);font-family:Playfair Display,Georgia,serif;font-family:var(--font-display);line-height:1.2}a{color:inherit;text-decoration:none;transition:color .3s cubic-bezier(.4,0,.2,1);transition:color var(--transition)}img{display:block;height:auto;max-width:100%}button{border:none;cursor:pointer;outline:none}button,input,select,textarea{font-family:DM Sans,sans-serif;font-family:var(--font-body)}.container{margin:0 auto;max-width:1200px;padding:0 2rem}.section{padding:6rem 0}.section-tag{align-items:center;color:#e8c44a;color:var(--accent);display:flex;font-family:DM Mono,monospace;font-family:var(--font-mono);font-size:.75rem;gap:.75rem;letter-spacing:.2em;margin-bottom:1rem;text-transform:uppercase}.section-tag:before{background:#e8c44a;background:var(--accent);content:"";display:block;height:1px;width:2rem}.section-title{color:#e8edf2;color:var(--text-primary);font-family:Playfair Display,Georgia,serif;font-family:var(--font-display);font-size:clamp(2rem,4vw,3rem);font-weight:700;margin-bottom:1rem}.section-subtitle{color:#89a;color:var(--text-secondary);font-size:1.1rem;line-height:1.8;max-width:560px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}@keyframes scanline{0%{transform:translateY(-100%)}to{transform:translateY(100vh)}}.animate-fadeInUp{animation:fadeInUp .7s ease forwards}.animate-fadeIn{animation:fadeIn .5s ease forwards}.grid-bg{background-image:linear-gradient(#e8c44a08 1px,#0000 0),linear-gradient(90deg,#e8c44a08 1px,#0000 0);background-size:60px 60px}.glass-card{background:#111720;background:var(--bg-card);border:1px solid #1e2d3d;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius-lg);transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--transition)}.glass-card:hover{background:#161e2a;background:var(--bg-card-hover);border-color:#243447;border-color:var(--border-light);box-shadow:0 0 40px #e8c44a1a;box-shadow:var(--shadow-accent)}.badge{background:#e8c44a1f;background:var(--accent-dim);border:1px solid #e8c44a4d;border:1px solid var(--accent-glow);border-radius:4px;color:#e8c44a;color:var(--accent);display:inline-block;font-family:DM Mono,monospace;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.05em;padding:.2rem .7rem}.btn-primary{align-items:center;background:#e8c44a;background:var(--accent);border-radius:8px;border-radius:var(--radius);color:#151617;color:var(--bg-primary);display:inline-flex;font-size:.9rem;font-weight:600;gap:.5rem;letter-spacing:.03em;overflow:hidden;padding:.85rem 2rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--transition)}.btn-primary:before{background:#ffffff26;content:"";inset:0;position:absolute;transform:translateX(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);transition:transform var(--transition)}.btn-primary:hover:before{transform:translateX(0)}.btn-primary:hover{box-shadow:0 8px 24px #e8c44a4d;box-shadow:0 8px 24px var(--accent-glow);transform:translateY(-2px)}.btn-outline{align-items:center;background:#0000;border:1px solid #243447;border:1px solid var(--border-light);border-radius:8px;border-radius:var(--radius);color:#e8edf2;color:var(--text-primary);display:inline-flex;font-size:.9rem;font-weight:500;gap:.5rem;padding:.85rem 2rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--transition)}.btn-outline:hover{border-color:#e8c44a;border-color:var(--accent);color:#e8c44a;color:var(--accent);transform:translateY(-2px)}.loading-screen{align-items:center;animation:fadeIn .3s ease;background:#151617;background:var(--bg-primary);display:flex;inset:0;justify-content:center;position:fixed;z-index:9999}.loading-spinner{animation:spin .8s linear infinite;border:2px solid #1e2d3d;border-top-color:#e8c44a;border:2px solid var(--border);border-radius:50%;border-top-color:var(--accent);height:48px;width:48px}@keyframes spin{to{transform:rotate(1turn)}}.divider{background:linear-gradient(90deg,#0000,#243447,#0000);background:linear-gradient(90deg,#0000,var(--border-light),#0000);height:1px;margin:0}@media (max-width:768px){.container{padding:0 1.25rem}.section{padding:4rem 0}.section-title{font-size:1.8rem}}.App{min-height:100vh}.navbar{height:var(--navbar-height);left:0;position:fixed;right:0;top:0;transition:all .4s ease;z-index:1000}.navbar.scrolled{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#080b0feb;border-bottom:1px solid var(--border);box-shadow:0 4px 30px #0000004d}.navbar-container{gap:2rem;height:100%;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 2rem}.navbar-container,.navbar-logo{align-items:center;display:flex}.navbar-logo{color:var(--text-primary);flex-shrink:0;font-family:var(--font-mono);font-size:1.1rem;font-weight:500;gap:.1rem;text-decoration:none;transition:all .3s ease}.logo-bracket,.navbar-logo:hover{color:var(--accent)}.logo-name{color:var(--text-primary);margin:0 .2rem}.navbar-links{align-items:center;display:flex;gap:.25rem;list-style:none}.nav-link{background:none;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;font-family:var(--font-body);font-size:.9rem;font-weight:400;padding:.5rem 1rem;position:relative;transition:all .25s ease}.nav-link:after{background:var(--accent);bottom:4px;content:"";height:1.5px;left:50%;position:absolute;transform:translateX(-50%);transition:width .3s ease;width:0}.nav-link:hover{color:var(--text-primary)}.nav-link.active{color:var(--accent)}.nav-link.active:after,.nav-link:hover:after{width:60%}.navbar-admin-btn{align-items:center;background:var(--accent-dim);border:1px solid var(--accent-glow);border-radius:6px;color:var(--accent);display:inline-flex;font-size:.83rem;font-weight:500;gap:.5rem;padding:.5rem 1.1rem;text-decoration:none;transition:all .25s ease;white-space:nowrap}.navbar-admin-btn:hover{background:var(--accent);color:var(--bg-primary);transform:translateY(-1px)}.hamburger{background:none;border:none;cursor:pointer;display:none;flex-direction:column;gap:5px;padding:4px}.hamburger span{background:var(--text-primary);border-radius:2px;display:block;height:1.5px;transform-origin:center;transition:all .3s ease;width:22px}.hamburger.open span:first-child{transform:translateY(6.5px) rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}.hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}.mobile-menu{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0d1117fa;border-bottom:1px solid var(--border);left:0;padding:1.5rem;position:fixed;right:0;top:var(--navbar-height);transform:translateY(-110%);transition:transform .4s cubic-bezier(.4,0,.2,1);z-index:999}.mobile-menu.open{transform:translateY(0)}.mobile-menu ul{display:flex;flex-direction:column;gap:.5rem;list-style:none}.mobile-menu a,.mobile-menu button{background:none;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;display:block;font-family:var(--font-body);font-size:1rem;padding:.9rem 1rem;text-align:left;text-decoration:none;transition:all .2s ease;width:100%}.mobile-menu a:hover,.mobile-menu button:hover{background:var(--bg-card);color:var(--accent);padding-left:1.5rem}.mobile-overlay{background:#00000080;inset:0;position:fixed;z-index:998}@media (max-width:768px){.navbar-admin-btn,.navbar-links{display:none}.hamburger{display:flex}}.hero{align-items:center;background:var(--bg-primary);display:flex;min-height:100vh;overflow:hidden;position:relative}.hero-canvas{height:100%;inset:0;opacity:.6;position:absolute;width:100%}.hero-glow{background:radial-gradient(circle,#e8c44a0f 0,#0000 70%);height:600px;left:50%;pointer-events:none;position:absolute;top:30%;transform:translate(-50%,-50%);width:600px}.hero-content{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1fr auto;padding-top:var(--navbar-height);position:relative;z-index:1}.hero-text{max-width:560px}.hero-greeting{align-items:center;color:var(--accent);display:flex;font-family:var(--font-mono);font-size:.85rem;gap:1rem;letter-spacing:.15em;margin-bottom:1.2rem;opacity:0;text-transform:uppercase}.greeting-line{background:var(--accent);display:block;height:1px;width:2.5rem}.hero-name{color:var(--text-primary);font-family:var(--font-display);font-size:clamp(2.8rem,6vw,5rem);font-weight:900;line-height:1.05;margin-bottom:.8rem;opacity:0}.hero-title-wrapper{margin-bottom:1.5rem;opacity:0}.hero-title{background:var(--bg-card);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:0 var(--radius) var(--radius) 0;display:inline-block;font-family:var(--font-mono);font-size:clamp(1rem,2vw,1.2rem);padding:.5rem 1rem}.hero-bio,.hero-title{color:var(--text-secondary)}.hero-bio{font-size:1.05rem;line-height:1.8;margin-bottom:2.2rem;opacity:0}.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2.5rem;opacity:0}.hero-socials{display:flex;gap:.75rem;opacity:0}.social-link{align-items:center;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;color:var(--text-secondary);display:flex;height:42px;justify-content:center;transition:all .3s ease;width:42px}.social-link:hover{background:var(--accent-dim);border-color:var(--accent-glow);color:var(--accent);transform:translateY(-3px)}.hero-visual{align-items:center;display:flex;flex-direction:column;gap:1.5rem;opacity:0}.hero-avatar-frame{align-items:center;display:flex;justify-content:center;position:relative}.avatar-ring{animation:float 6s ease-in-out infinite;border:1px solid var(--border-light);height:260px;width:260px}.avatar-ring,.avatar-ring:before{border-radius:50%;position:absolute}.avatar-ring:before{background:var(--accent);content:"";height:6px;left:50%;top:-3px;transform:translateX(-50%);width:6px}.avatar-inner{align-items:center;animation:float 6s ease-in-out infinite;animation-delay:-3s;background:var(--bg-card);border:2px solid var(--border-light);border-radius:50%;display:flex;height:220px;justify-content:center;overflow:hidden;position:relative;width:220px;z-index:1}.avatar-img{height:100%;object-fit:cover;width:100%}.avatar-placeholder{align-items:center;color:var(--text-muted);display:flex;justify-content:center}.avatar-badge{background:var(--bg-card);border:1px solid var(--border-light);border-left:3px solid #4ade80;border-radius:0 6px 6px 0;bottom:10px;color:#4ade80;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.05em;padding:.4rem .8rem;position:absolute;right:-10px;white-space:nowrap;z-index:2}.avatar-badge:before{animation:pulse 2s ease infinite;background:#4ade80;border-radius:50%;content:"";display:inline-block;height:6px;margin-right:.5rem;width:6px}.hero-stats{display:flex;gap:1rem}.stat-card{align-items:center;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;gap:.3rem;min-width:70px;padding:.8rem 1.2rem;transition:all .3s ease}.stat-card:hover{background:var(--accent-dim);border-color:var(--accent-glow)}.stat-num{color:var(--accent);font-family:var(--font-display);font-size:1.5rem;font-weight:700;line-height:1}.stat-label{font-size:.65rem;letter-spacing:.1em;text-align:center}.hero-scroll-hint,.stat-label{color:var(--text-muted);font-family:var(--font-mono);text-transform:uppercase}.hero-scroll-hint{align-items:center;animation:fadeIn 1s ease 1.5s both;bottom:2rem;display:flex;flex-direction:column;font-size:.7rem;gap:.5rem;left:50%;letter-spacing:.15em;position:absolute;transform:translateX(-50%)}.scroll-dot{animation:scroll-line 2s ease-in-out infinite;background:linear-gradient(to bottom,var(--text-muted),#0000);height:40px;width:1px}@keyframes scroll-line{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform:scaleY(1);transform-origin:bottom}to{transform:scaleY(0);transform-origin:bottom}}@media (max-width:900px){.hero-content{gap:3rem;grid-template-columns:1fr;text-align:center}.hero-text{max-width:100%}.hero-actions,.hero-greeting,.hero-socials{justify-content:center}.hero-visual{order:-1}.avatar-ring{height:200px;width:200px}.avatar-inner{height:170px;width:170px}}@media (max-width:480px){.hero-stats{gap:.6rem}.stat-card{min-width:60px;padding:.6rem .8rem}}.about-section{border-bottom:1px solid var(--border);border-top:1px solid var(--border)}.about-grid{grid-gap:5rem;align-items:start;display:grid;gap:5rem;grid-template-columns:1fr 1fr}.about-bio{color:var(--text-secondary);font-size:1.05rem;line-height:1.9;margin-bottom:2rem}.about-details{display:flex;flex-direction:column;gap:.75rem}.detail-row{gap:.75rem}.detail-icon,.detail-row{align-items:center;display:flex}.detail-icon{background:var(--accent-dim);border-radius:6px;color:var(--accent);flex-shrink:0;height:32px;justify-content:center;width:32px}.detail-value{color:var(--text-secondary);font-size:.9rem;transition:color .2s}a.detail-value:hover{color:var(--accent)}.skills-title{color:var(--text-muted);font-family:var(--font-mono);font-size:.8rem;letter-spacing:.15em;margin-bottom:1.2rem;text-transform:uppercase}.skills-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.skill-group{padding:1.2rem}.skill-category{color:var(--accent);font-family:var(--font-mono);font-size:.75rem;letter-spacing:.1em;margin-bottom:.8rem;text-transform:uppercase}.skill-tags{display:flex;flex-wrap:wrap;gap:.4rem}.skill-tag{background:var(--bg-secondary);border:1px solid var(--border);border-radius:4px;color:var(--text-secondary);display:inline-block;font-family:var(--font-mono);font-size:.72rem;padding:.22rem .6rem;transition:all .2s ease}.skill-tag:hover{background:var(--accent-dim);border-color:var(--accent-glow);color:var(--accent)}.edu-card{margin-bottom:.75rem;padding:1.2rem}.edu-header{align-items:center;display:flex;gap:1rem;justify-content:space-between;margin-bottom:.4rem}.edu-degree{color:var(--text-primary);font-family:var(--font-body);font-size:.95rem;font-weight:600}.edu-institution{color:var(--accent);font-size:.85rem;margin-bottom:.4rem}.edu-desc{color:var(--text-muted);font-size:.85rem}@media (max-width:900px){.about-grid{gap:3rem;grid-template-columns:1fr}}@media (max-width:480px){.skills-grid{grid-template-columns:1fr}}.portfolio-section{background:var(--bg-secondary)}.section-header{margin-bottom:3rem}.filter-tabs{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2.5rem}.filter-tab{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text-muted);cursor:pointer;font-family:var(--font-mono);font-size:.85rem;font-weight:500;letter-spacing:.05em;padding:.5rem 1.2rem;transition:all .25s ease}.filter-tab:hover{border-color:var(--border-light);color:var(--text-secondary)}.filter-tab.active{background:var(--accent-dim);border-color:var(--accent-glow);color:var(--accent)}.projects-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}.project-card{animation:fadeInUp .5s ease both;display:flex;flex-direction:column;overflow:hidden}.project-card.featured{border-color:var(--accent-glow)}.project-image{background:var(--bg-secondary);height:200px;overflow:hidden;position:relative}.project-image img{height:100%;object-fit:cover;transition:transform .5s ease;width:100%}.project-card:hover .project-image img{transform:scale(1.06)}.project-image-placeholder{align-items:center;background:linear-gradient(135deg,var(--bg-card),var(--bg-secondary));color:var(--text-muted);display:flex;height:100%;justify-content:center;width:100%}.featured-badge{background:var(--accent);border-radius:4px;color:var(--bg-primary);font-family:var(--font-mono);font-size:.65rem;font-weight:600;left:1rem;letter-spacing:.1em;padding:.25rem .6rem;position:absolute;text-transform:uppercase;top:1rem;z-index:2}.project-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#080b0fe0;display:flex;inset:0;justify-content:center;opacity:0;position:absolute;transition:opacity .3s ease}.project-card:hover .project-overlay{opacity:1}.overlay-links{display:flex;gap:.75rem}.overlay-btn{align-items:center;background:var(--accent);border-radius:6px;color:var(--bg-primary);display:inline-flex;font-size:.83rem;font-weight:600;gap:.4rem;padding:.6rem 1.1rem;text-decoration:none;transition:all .2s ease}.overlay-btn:hover{opacity:.9;transform:translateY(-2px)}.overlay-btn.outline{background:#0000;border:1px solid #ffffff4d;color:var(--text-primary)}.overlay-btn.outline:hover{border-color:var(--accent);color:var(--accent)}.project-content{display:flex;flex:1 1;flex-direction:column;padding:1.5rem}.project-meta,.project-title{margin-bottom:.6rem}.project-title{color:var(--text-primary);font-family:var(--font-display);font-size:1.2rem;font-weight:700;transition:color .2s}.project-card:hover .project-title{color:var(--accent)}.project-desc{color:var(--text-secondary);flex:1 1;font-size:.88rem;line-height:1.7;margin-bottom:1rem}.project-tech{display:flex;flex-wrap:wrap;gap:.4rem}.tech-tag{background:var(--bg-secondary);border:1px solid var(--border);border-radius:4px;color:var(--text-muted);display:inline-block;font-family:var(--font-mono);font-size:.68rem;padding:.2rem .55rem;transition:all .2s ease}.project-card:hover .tech-tag{border-color:var(--border-light);color:var(--text-secondary)}.no-projects{border:1px dashed var(--border);border-radius:var(--radius-lg);color:var(--text-muted);font-family:var(--font-mono);padding:4rem;text-align:center}@media (max-width:768px){.projects-grid{grid-template-columns:1fr}}.experience-section{border-bottom:1px solid var(--border);border-top:1px solid var(--border)}.experience-layout{grid-gap:2rem;align-items:start;display:grid;gap:2rem;grid-template-columns:280px 1fr}.experience-sidebar{display:flex;flex-direction:column;gap:0;padding-left:1.5rem;position:relative}.sidebar-line{background:var(--border);border-radius:2px;bottom:0;left:0;position:absolute;top:0;width:2px}.sidebar-line-fill{background:var(--accent);border-radius:2px;min-height:4px;transition:height .5s cubic-bezier(.4,0,.2,1);width:100%}.exp-tab{background:none;border:none;border-radius:0 var(--radius) var(--radius) 0;cursor:pointer;display:flex;flex-direction:column;gap:.25rem;padding:1rem 1rem 1rem .5rem;position:relative;text-align:left;transition:all .25s ease}.exp-tab:before{background:var(--border);border:2px solid var(--bg-primary);border-radius:50%;content:"";height:8px;left:-1.5rem;position:absolute;top:50%;transform:translateY(-50%);transition:all .25s ease;width:8px;z-index:1}.exp-tab.active:before,.exp-tab:hover:before{background:var(--accent)}.exp-tab:hover{background:var(--bg-card)}.exp-tab.active{background:var(--accent-dim)}.exp-tab-company{color:var(--text-secondary);font-size:.92rem;font-weight:600;transition:color .2s}.exp-tab.active .exp-tab-company,.exp-tab:hover .exp-tab-company{color:var(--accent)}.exp-tab-role{color:var(--text-muted);font-family:var(--font-mono);font-size:.8rem}.current-dot{animation:pulse 2s ease infinite;background:#4ade80;border-radius:50%;height:6px;position:absolute;right:.75rem;top:.75rem;width:6px}.experience-detail{animation:fadeInUp .4s ease;padding:2rem}.detail-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between}.detail-role{color:var(--text-primary);font-family:var(--font-display);font-size:1.6rem;font-weight:700;margin-bottom:.4rem}.detail-company{color:var(--text-secondary);font-size:1rem}.detail-company span{color:var(--accent);font-weight:600}.detail-meta{align-items:flex-end;display:flex;flex-direction:column;gap:.5rem}.current-badge{align-items:center;color:#4ade80;display:flex;font-family:var(--font-mono);font-size:.72rem;gap:.4rem;letter-spacing:.05em}.dot-pulse{animation:pulse 2s ease infinite;background:#4ade80;border-radius:50%;display:inline-block;height:6px;width:6px}.detail-description{color:var(--text-secondary);font-size:1rem;line-height:1.9;margin-bottom:2rem}.detail-nav{gap:1rem}.detail-nav,.nav-arrow{align-items:center;display:flex}.nav-arrow{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);cursor:pointer;height:36px;justify-content:center;transition:all .2s ease;width:36px}.nav-arrow:hover:not(:disabled){border-color:var(--accent-glow);color:var(--accent)}.nav-arrow:disabled{cursor:not-allowed;opacity:.3}.nav-counter{color:var(--text-muted);font-family:var(--font-mono);font-size:.8rem}@media (max-width:768px){.experience-layout{grid-template-columns:1fr}.experience-sidebar{flex-direction:row;gap:.5rem;overflow-x:auto;padding-bottom:.5rem;padding-left:0}.sidebar-line{display:none}.exp-tab{border:1px solid var(--border);border-radius:var(--radius);flex-shrink:0;padding:.6rem 1rem;white-space:nowrap}.exp-tab:before{display:none}.exp-tab.active{border-color:var(--accent-glow)}.detail-header{flex-direction:column}.detail-meta{align-items:flex-start}}.contact-section{background:var(--bg-secondary)}.contact-grid{grid-gap:4rem;align-items:start;display:grid;gap:4rem;grid-template-columns:1fr 1.2fr}.contact-body{color:var(--text-secondary);font-size:1.05rem;line-height:1.8;margin-bottom:2rem}.contact-cards{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem}.contact-card{align-items:center;display:flex;gap:1rem;padding:1rem 1.25rem;text-decoration:none;transition:all .25s ease}.contact-card-icon{align-items:center;background:var(--accent-dim);border-radius:10px;color:var(--accent);display:flex;flex-shrink:0;height:42px;justify-content:center;width:42px}.contact-card-label{color:var(--text-muted);font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;margin-bottom:.2rem;text-transform:uppercase}.contact-card-value{color:var(--text-secondary);font-size:.9rem;transition:color .2s}a.contact-card:hover .contact-card-value{color:var(--accent)}.contact-socials{display:flex;flex-wrap:wrap;gap:.6rem}.social-pill{align-items:center;background:var(--bg-card);border:1px solid var(--border);border-radius:100px;color:var(--text-secondary);display:inline-flex;font-size:.83rem;gap:.35rem;padding:.4rem 1rem;text-decoration:none;transition:all .2s ease}.social-pill:hover{border-color:var(--accent-glow);color:var(--accent);transform:translateY(-2px)}.contact-form-wrap{padding:2.5rem}.form-title{color:var(--text-primary);font-family:var(--font-display);font-size:1.3rem;font-weight:700;margin-bottom:1.8rem}.contact-form{display:flex;flex-direction:column;gap:1.2rem}.form-group{gap:.5rem}.form-label{color:var(--text-muted);font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase}.form-input{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:.92rem;outline:none;padding:.85rem 1rem;transition:all .25s ease;width:100%}.form-input::placeholder{color:var(--text-muted)}.form-input:focus{background:var(--bg-card);border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.form-textarea{line-height:1.6;min-height:120px;resize:vertical}.form-error{align-items:center;background:#ef444414;border:1px solid #ef44444d;border-radius:var(--radius);color:#f87171;display:flex;font-size:.85rem;gap:.5rem;padding:.8rem 1rem}.form-submit{font-size:1rem;justify-content:center;padding:1rem;width:100%}.btn-spinner{animation:spin .7s linear infinite;border:2px solid #0003;border-radius:50%;border-top:2px solid var(--bg-primary);display:inline-block;height:16px;width:16px}.form-success{padding:2rem;text-align:center}.success-icon{align-items:center;background:#4ade801a;border:1px solid #4ade804d;border-radius:50%;color:#4ade80;display:flex;height:72px;justify-content:center;margin:0 auto 1.5rem;width:72px}.form-success h3{font-family:var(--font-display);font-size:1.5rem;margin-bottom:.75rem}.form-success p{color:var(--text-secondary);font-size:.95rem}@media (max-width:900px){.contact-grid{gap:3rem;grid-template-columns:1fr}}@media (max-width:480px){.form-row{grid-template-columns:1fr}.contact-form-wrap{padding:1.5rem}}.footer{background:var(--bg-primary);border-top:1px solid var(--border);padding:2.5rem 0}.footer-inner{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between}.footer-logo{color:var(--text-primary);font-family:var(--font-mono);font-size:1rem;font-weight:500}.footer-tagline{color:var(--text-muted);font-size:.82rem;margin-top:.3rem}.footer-copy{color:var(--text-muted);font-family:var(--font-mono);font-size:.75rem;letter-spacing:.05em}@media (max-width:600px){.footer-inner{flex-direction:column;text-align:center}}.admin-login-screen{align-items:center;background:var(--bg-primary);display:flex;justify-content:center;min-height:100vh;padding:2rem}.admin-login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);max-width:420px;padding:2.5rem;text-align:center;width:100%}.admin-login-icon{align-items:center;background:var(--accent-dim);border:1px solid var(--accent-glow);border-radius:16px;color:var(--accent);display:flex;height:64px;justify-content:center;margin:0 auto 1.5rem;width:64px}.admin-login-title{font-family:var(--font-display);font-size:1.8rem;font-weight:700;margin-bottom:.5rem}.admin-login-sub{color:var(--text-muted);font-size:.9rem;margin-bottom:2rem}.admin-login-form{display:flex;flex-direction:column;gap:1rem}.admin-key-input{font-family:var(--font-mono);font-size:.9rem;letter-spacing:.1em}.admin-error{background:#ef444414;border:1px solid #ef444433;border-radius:var(--radius);color:#f87171;font-size:.83rem;padding:.6rem .8rem}.admin-back-link{color:var(--text-muted);display:inline-block;font-family:var(--font-mono);font-size:.78rem;margin-top:1.5rem;transition:color .2s}.admin-back-link:hover{color:var(--accent)}.admin-page{background:var(--bg-primary);display:flex;flex-direction:column;min-height:100vh}.admin-header{align-items:center;background:var(--bg-secondary);border-bottom:1px solid var(--border);display:flex;gap:1rem;height:60px;justify-content:space-between;padding:0 2rem;position:sticky;top:0;z-index:100}.admin-header-left{align-items:center;display:flex;gap:.75rem}.admin-logo{color:var(--text-primary);font-family:var(--font-mono);font-size:.95rem;text-decoration:none}.admin-sep{color:var(--text-muted)}.admin-page-label{color:var(--text-secondary);font-family:var(--font-mono);font-size:.85rem}.admin-header-right{align-items:center;display:flex;gap:.75rem}.unread-badge{align-items:center;background:var(--accent-dim);border:1px solid var(--accent-glow);border-radius:100px;color:var(--accent);display:inline-flex;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.05em;padding:.25rem .7rem}.admin-refresh{align-items:center;display:flex;font-size:.82rem;gap:.4rem;padding:.45rem .9rem}.admin-layout{display:grid;flex:1 1;grid-template-columns:340px 1fr;overflow:hidden}.admin-sidebar{background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.sidebar-filters{border-bottom:1px solid var(--border);display:flex;gap:.4rem;padding:.75rem}.sidebar-filter-btn{align-items:center;background:none;border:1px solid #0000;border-radius:6px;color:var(--text-muted);cursor:pointer;display:flex;flex:1 1;font-family:var(--font-mono);font-size:.8rem;gap:.4rem;justify-content:center;padding:.5rem;transition:all .2s}.sidebar-filter-btn:hover{background:var(--bg-card);color:var(--text-secondary)}.sidebar-filter-btn.active{background:var(--accent-dim);border-color:var(--accent-glow);color:var(--accent)}.filter-count{align-items:center;background:var(--bg-card);border-radius:100px;display:inline-flex;font-size:.65rem;height:18px;justify-content:center;min-width:18px;padding:0 4px}.messages-list{flex:1 1;overflow-y:auto}.list-empty,.list-loading{align-items:center;color:var(--text-muted);display:flex;flex-direction:column;font-family:var(--font-mono);font-size:.85rem;gap:.5rem;justify-content:center;padding:4rem 2rem;text-align:center}.message-item{border-bottom:1px solid var(--border);cursor:pointer;padding:1rem 1.25rem;position:relative;transition:background .2s}.message-item:hover{background:var(--bg-card)}.message-item.selected{background:var(--accent-dim);border-left:2px solid var(--accent)}.message-item.unread{background:#e8c44a08}.unread-dot{background:var(--accent);border-radius:50%;height:7px;position:absolute;right:1rem;top:1.1rem;width:7px}.msg-item-header{align-items:center;display:flex;gap:.5rem;justify-content:space-between;margin-bottom:.3rem}.msg-item-name{truncate:ellipsis;color:var(--text-primary);font-size:.88rem;font-weight:600}.msg-item-date{color:var(--text-muted);flex-shrink:0;font-family:var(--font-mono);font-size:.68rem;white-space:nowrap}.msg-item-subject{color:var(--text-secondary);font-size:.82rem;font-weight:500;margin-bottom:.2rem}.msg-item-preview,.msg-item-subject{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.msg-item-preview{color:var(--text-muted);font-size:.78rem}.admin-detail{background:var(--bg-primary);overflow-y:auto}.detail-empty{align-items:center;color:var(--text-muted);display:flex;flex-direction:column;gap:1rem;height:100%;justify-content:center;min-height:60vh;text-align:center}.detail-empty h3{color:var(--text-secondary);font-family:var(--font-display);font-size:1.2rem}.detail-empty p{font-size:.85rem}.message-detail{padding:2rem}.detail-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.status-read{background:#4ade8014;border:1px solid #4ade8033;border-radius:4px;color:#4ade80}.status-read,.status-unread{font-family:var(--font-mono);font-size:.72rem;padding:.25rem .6rem}.status-unread{background:var(--accent-dim);border:1px solid var(--accent-glow);border-radius:4px;color:var(--accent)}.toolbar-actions{display:flex;flex-wrap:wrap;gap:.5rem}.toolbar-btn{align-items:center;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);cursor:pointer;display:inline-flex;font-family:var(--font-body);font-size:.82rem;gap:.4rem;padding:.5rem 1rem;text-decoration:none;transition:all .2s}.toolbar-btn:hover{border-color:var(--border-light);color:var(--text-primary)}.toolbar-btn.accent{background:var(--accent-dim);border-color:var(--accent-glow);color:var(--accent)}.toolbar-btn.accent:hover{background:var(--accent);color:var(--bg-primary)}.toolbar-btn.danger:hover{background:#ef44441a;border-color:#ef44444d;color:#f87171}.message-detail-body{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem}.detail-subject{font-family:var(--font-display);font-size:1.5rem;font-weight:700;margin-bottom:1.2rem}.detail-meta-row{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between}.detail-sender{gap:.75rem}.detail-sender,.sender-avatar{align-items:center;display:flex}.sender-avatar{background:var(--accent-dim);border:1px solid var(--accent-glow);border-radius:50%;color:var(--accent);flex-shrink:0;font-family:var(--font-display);font-size:1.1rem;font-weight:700;height:42px;justify-content:center;width:42px}.sender-name{font-size:.92rem;font-weight:600}.sender-email{font-size:.82rem}.detail-timestamp,.sender-email{color:var(--text-muted);font-family:var(--font-mono)}.detail-timestamp{font-size:.75rem}.detail-message-body{color:var(--text-secondary);font-size:.96rem;line-height:1.9;margin-bottom:2rem}.detail-message-body p{margin-bottom:.5rem}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.modal-box{animation:fadeInUp .2s ease;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);max-width:400px;padding:2rem;width:90%}.modal-box h3{font-family:var(--font-display);font-size:1.2rem;margin-bottom:.75rem}.modal-box p{color:var(--text-secondary);font-size:.9rem;margin-bottom:1.5rem}.modal-actions{gap:.75rem}@media (max-width:768px){.admin-layout{grid-template-columns:1fr}.admin-sidebar{border-bottom:1px solid var(--border);border-right:none;max-height:50vh}}.project-management{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-top:2rem;padding:1.5rem}.project-section-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1rem}.project-section-header h2{color:var(--text-primary);font-size:1.3rem;margin:0}.project-section-header p{color:var(--text-muted);font-size:.95rem;margin:.5rem 0 0}.project-list{grid-gap:1rem;display:grid;gap:1rem}.project-card.admin-project-card{align-items:flex-start;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;display:flex;gap:1rem;justify-content:space-between;padding:1rem}.project-card-top{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem}.project-card-top h3{font-size:1.05rem;margin:0}.project-featured-badge{align-items:center;background:gold;border-radius:999px;color:#111;display:inline-flex;font-size:.75rem;letter-spacing:.05em;padding:.2rem .5rem;text-transform:uppercase}.project-card-category{color:var(--accent);font-size:.85rem;margin:.5rem 0 0;text-transform:capitalize}.project-card-description{color:var(--text-secondary);line-height:1.5;margin:.75rem 0 0}.project-card-actions{align-items:flex-start;display:flex;gap:.75rem}.project-empty,.project-error,.project-loading{background:var(--bg-primary);border:1px dashed var(--border);border-radius:12px;color:var(--text-secondary);padding:1.5rem}.project-empty p{margin:0}@media (max-width:768px){.project-card.admin-project-card{align-items:stretch;flex-direction:column}.project-card-actions{justify-content:flex-start;width:100%}}.admin-add-project{align-items:center;display:flex;gap:.5rem;margin-right:1rem}.admin-add-project svg{height:14px;width:14px}.project-modal{max-height:90vh;max-width:600px;overflow-y:auto;width:90vw}.modal-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.modal-header h3{font-family:var(--font-display);font-size:1.5rem;margin:0}.modal-close{background:none;border:none;border-radius:4px;color:var(--text-muted);cursor:pointer;font-size:1.5rem;padding:.25rem;transition:all .2s ease}.modal-close:hover{background:var(--bg-secondary);color:var(--text-primary)}.project-form{display:flex;flex-direction:column;gap:1rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.form-group{display:flex;flex-direction:column}.form-group label{color:var(--text-primary);font-size:.9rem;font-weight:500;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{background:var(--bg-primary);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:.9rem;padding:.75rem}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent);outline:none}.form-group textarea{min-height:80px;resize:vertical}.checkbox-label{align-items:center;cursor:pointer;display:flex;font-weight:500;gap:.5rem}.checkbox-label input[type=checkbox]{margin:0;width:auto}.modal-actions{border-top:1px solid var(--border);display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem;padding-top:1rem}@media (max-width:768px){.form-row{grid-template-columns:1fr}.modal-actions{flex-direction:column}.modal-actions button{width:100%}}
/*# sourceMappingURL=main.dc166f8d.css.map*/