:root{--black:#020505;--surface-lowest:#050b0b;--surface-dim:#0a1111;--surface-low:#101919;--surface:#152020;--surface-high:#1c2d2d;--surface-highest:#253b3b;--on-surface:#e0f2f1;--on-surface-variant:#80a0a0;--outline:#4d6e6e;--outline-variant:#283e3e;--ghost:#0c1515;--primary:#2dd4bf;--primary-container:#0f766e;--indigo:#0891b2;--indigo-hover:#0e7490;--on-primary:#042f2e;--gutter:24px;--max-w:1200px;--radius:.5rem;--font:"Inter", system-ui, sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;width:100%;overflow:hidden scroll}body{font-family:var(--font);background:var(--black);color:var(--on-surface);-webkit-font-smoothing:antialiased;width:100%;min-height:100dvh;font-size:16px;line-height:1.6;overflow-x:hidden}#root{flex-direction:column;min-height:100dvh;display:flex}#root main{flex-grow:1}::selection{background:var(--indigo);color:#fff}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--black)}::-webkit-scrollbar-thumb{background:var(--ghost)}::-webkit-scrollbar-thumb:hover{background:var(--indigo)}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto;display:block}button,input,textarea,select{font-family:var(--font)}button{cursor:pointer;background:0 0;border:none}.material-symbols-outlined{font-variation-settings:"FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24}.container{max-width:var(--max-w);padding:0 var(--gutter);margin:0 auto}.section{padding:80px 0}.header{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--outline-variant);background:#0e0e0ed9;width:100%;position:fixed;top:0;left:0}.header-inner{max-width:var(--max-w);padding:0 var(--gutter);justify-content:space-between;align-items:center;height:64px;margin:0 auto;display:flex}.logo{cursor:pointer;align-items:center;gap:8px;display:flex}.logo-text{letter-spacing:-.03em;font-size:24px;font-weight:700}.nav-desktop{align-items:center;gap:32px;display:flex}.nav-link{color:var(--on-surface-variant);cursor:pointer;letter-spacing:.01em;background:0 0;border:none;padding:0;font-size:14px;font-weight:500;transition:color .2s}.nav-link:hover,.nav-link.active{color:var(--primary)}.nav-link.active{font-weight:700}.menu-btn{color:var(--on-surface);font-size:24px;display:none}.btn-resume{background:var(--indigo);color:#fff;border-radius:8px;padding:8px 20px;font-size:14px;font-weight:500;transition:all .2s;display:none}.btn-resume:hover{filter:brightness(1.1)}.btn-resume:active{transform:scale(.95)}.mobile-nav{z-index:100;background:var(--surface-lowest);border-top:1px solid var(--outline-variant);justify-content:space-around;width:100%;padding:8px 0;display:none;position:fixed;bottom:0;left:0}.mob-item{color:var(--on-surface-variant);cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:2px;padding:8px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.mob-item:active{transform:scale(.9)}.mob-item.active{color:var(--primary)}.btn{border-radius:var(--radius);letter-spacing:.01em;white-space:nowrap;justify-content:center;align-items:center;gap:8px;padding:12px 32px;font-size:14px;font-weight:500;transition:all .2s;display:inline-flex}.btn:active{transform:scale(.95)}.btn-primary{background:var(--indigo);color:#fff}.btn-primary:hover{filter:brightness(1.1)}.btn-ghost{border:1px solid var(--outline-variant);color:var(--on-surface);background:0 0}.btn-ghost:hover{background:var(--surface-low)}.chip{background:var(--surface);color:var(--on-surface-variant);border-radius:2px;padding:4px 12px;font-size:12px;font-weight:500;display:inline-block}.hero{text-align:center;min-height:calc(100dvh - 76px);padding:80px var(--gutter);flex-direction:column;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.hero-bg-image{z-index:0;background-position:top;background-repeat:no-repeat;background-size:cover;position:fixed;inset:0}.hero-bg-overlay{z-index:0;background:linear-gradient(#0000008c 0%,#000000b3 50%,#000000d9 100%);position:fixed;inset:0}.hero-glow-1{filter:blur(80px);pointer-events:none;z-index:0;background:radial-gradient(circle,#0d948826 0%,#0000 70%);width:400px;height:400px;animation:15s ease-in-out infinite drift;position:absolute;top:10%;left:20%}.hero-glow-2{filter:blur(100px);pointer-events:none;z-index:0;background:radial-gradient(circle,#06b6d41f 0%,#0000 70%);width:500px;height:500px;animation:20s ease-in-out infinite drift-reverse;position:absolute;bottom:10%;right:15%}@keyframes drift{0%{transform:translate(0)scale(1)}50%{transform:translate(40px,-60px)scale(1.2)}to{transform:translate(0)scale(1)}}@keyframes drift-reverse{0%{transform:translate(0)scale(1.2)}50%{transform:translate(-50px,40px)scale(.9)}to{transform:translate(0)scale(1.2)}}.hero-grid-overlay{display:none}.hero-badge{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#06b6d414;border:1px solid #06b6d440;border-radius:999px;align-items:center;gap:8px;margin-bottom:32px;padding:6px 16px;display:inline-flex}.pulse-dot{background:#22c55e;border-radius:50%;width:8px;height:8px;animation:2s infinite pulse;box-shadow:0 0 6px #22c55e80}.hero h1{letter-spacing:-.04em;color:#fff;max-width:850px;margin-bottom:20px;font-size:64px;font-weight:800;line-height:1.1}.hero h1 .accent{color:#fff;-webkit-text-fill-color:#fff}.hero p{color:var(--on-surface-variant);max-width:660px;margin:0 auto 40px;font-size:20px;font-weight:400;line-height:1.5}.hero-actions{flex-wrap:wrap;justify-content:center;gap:16px;display:flex}.hero-btn-glow{padding:14px 36px;font-size:15px;font-weight:600;transition:all .3s;box-shadow:0 0 24px #06b6d459,0 0 60px #06b6d41a}.hero-btn-glow:hover{transform:translateY(-2px);box-shadow:0 0 32px #06b6d480,0 0 80px #06b6d426}.hero-actions .btn-ghost{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff08;padding:14px 36px;font-size:15px;font-weight:500}.hero-img-wrap{border-radius:var(--radius);border:1px solid var(--ghost);width:100%;max-width:1024px;margin-top:80px;overflow:hidden;box-shadow:0 0 20px #06b6d426}.hero-img-wrap img{object-fit:cover;opacity:.8;width:100%;height:auto}.bento{gap:var(--gutter);grid-template-columns:1fr;display:grid}.bento-card{background:var(--surface);border:1px solid var(--outline-variant);border-radius:var(--radius);flex-direction:column;justify-content:flex-end;padding:32px;transition:border-color .5s;display:flex;position:relative;overflow:hidden}.bento-card:hover{border-color:var(--primary)}.bento-card-bg{opacity:.4;position:absolute;inset:0}.bento-card-bg img{object-fit:cover;filter:grayscale();width:100%;height:100%;transition:all .7s}.bento-card:hover .bento-card-bg img{filter:grayscale(0)}.bento-card-content{z-index:1;position:relative}.projects-grid{gap:var(--gutter);grid-template-columns:1fr;display:grid}.p-card{background:var(--surface-low);border:1px solid var(--ghost);border-radius:var(--radius);flex-direction:column;transition:border-color .5s;display:flex;overflow:hidden}.p-card:hover{border-color:#06b6d480}.p-card-img{aspect-ratio:16/9;overflow:hidden}.p-card-img img{object-fit:cover;filter:grayscale();opacity:.6;width:100%;height:100%;transition:all .7s}.p-card:hover .p-card-img img{filter:grayscale(0);opacity:1;transform:scale(1.05)}.p-card-body{flex-direction:column;flex-grow:1;padding:32px;display:flex}.p-card-body h3{margin-bottom:8px;font-size:24px;font-weight:600}.p-card-body p{color:var(--on-surface-variant);margin-bottom:32px}.tags{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.p-link{color:var(--primary);cursor:pointer;align-items:center;gap:8px;margin-top:auto;font-size:14px;font-weight:500;display:inline-flex}.p-link:hover .material-symbols-outlined{transform:translate(4px)}.p-link .material-symbols-outlined{font-size:16px;transition:transform .2s}.filter-bar{flex-wrap:wrap;gap:12px;margin-bottom:48px;display:flex}.filter-chip{border-radius:var(--radius);cursor:pointer;background:var(--surface);border:1px solid var(--outline-variant);color:var(--on-surface-variant);padding:8px 24px;font-size:14px;font-weight:500;transition:all .2s}.filter-chip:hover{border-color:var(--primary);color:var(--on-surface)}.filter-chip:active{transform:scale(.95)}.filter-chip.active{background:var(--primary);color:var(--on-primary);border-color:var(--primary)}.about-hero{flex-direction:column;align-items:center;gap:40px;display:flex}.about-hero>div:last-child{order:-1;width:200px}@media (width>=768px){.about-hero{text-align:left;flex-direction:row;gap:64px}.about-text{flex:55%}.about-hero>div:last-child{flex:0 0 400px;order:0;width:auto}}.portrait-wrapper{width:100%;max-width:440px;margin:0 auto;position:relative}.portrait-box{border:1px solid var(--outline-variant);background:var(--surface-low);border-radius:12px;width:100%;padding-bottom:100%;position:relative;overflow:hidden}.portrait-box img{object-fit:cover;filter:grayscale();width:100%;height:100%;transition:filter .5s;position:absolute;top:0;left:0}.portrait-box:hover img{filter:grayscale(0)}.experience-badge{background:var(--primary-container);color:#fff;border:1px solid #ffffff1a;border-radius:8px;flex-direction:column;padding:24px;display:none;position:absolute;bottom:-24px;left:-24px;box-shadow:0 10px 30px #00000080}@media (width>=768px){.experience-badge{display:flex}}.exp-num{margin-bottom:4px;font-size:36px;font-weight:800;line-height:1}.exp-text{text-transform:uppercase;letter-spacing:.1em;opacity:.9;font-size:11px;font-weight:700}.about-text{text-align:center}@media (width>=768px){.about-text{text-align:left}}.about-subtitle{color:var(--primary-container);text-transform:uppercase;letter-spacing:.15em;margin-bottom:16px;font-size:12px;font-weight:700;display:none}@media (width>=768px){.about-subtitle{display:block}}.about-text h1{letter-spacing:-.03em;color:#fff;margin-bottom:24px;font-size:32px;font-weight:700;line-height:1.1}@media (width>=768px){.about-text h1{font-size:48px}}.about-text p{color:var(--on-surface-variant);margin-bottom:40px;font-size:14px;line-height:1.7}@media (width>=768px){.about-text p{font-size:16px}}.about-buttons{display:none}@media (width>=768px){.about-buttons{gap:16px;display:flex}}.skills-grid{grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:8px;display:grid}@media (width>=768px){.skills-grid{grid-template-columns:1fr 1fr 1fr;gap:16px}}.skill-card{background:var(--surface);border:1px solid var(--outline-variant);flex-direction:column;gap:8px;padding:16px;transition:all .3s;display:flex}@media (width>=768px){.skill-card{gap:16px;padding:32px}}.skill-card:hover{border-color:var(--indigo);background:#111}.skill-card .material-symbols-outlined{color:var(--primary);font-size:36px}.skill-card h3{font-size:24px;font-weight:600}.skill-card p{color:var(--on-surface-variant);text-transform:uppercase;letter-spacing:.02em;font-size:12px}.contact-box{background:var(--surface-low);border:1px solid var(--outline-variant);max-width:720px;margin:0 auto;padding:32px}.contact-header{text-align:center;margin-bottom:48px}.contact-header h2{margin-bottom:16px;font-size:32px;font-weight:600}.contact-header p{color:var(--on-surface-variant)}.form-grid{gap:24px;display:grid}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{font-size:14px;font-weight:500}.form-input{background:var(--black);border:1px solid var(--ghost);width:100%;color:var(--on-surface);outline:none;padding:16px;font-size:16px;transition:border-color .2s}.form-input:focus{border-color:var(--indigo);box-shadow:0 0 0 1px var(--indigo)}.form-input::placeholder{color:#555}.form-row{grid-template-columns:1fr;gap:24px;display:grid}.btn-submit{background:var(--indigo);color:#fff;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;width:100%;padding:16px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.btn-submit:hover{background:var(--indigo-hover)}.btn-submit:active{transform:scale(.98)}.cta-box{background:var(--surface);border:1px solid var(--ghost);text-align:center;border-radius:12px;padding:48px;position:relative;overflow:hidden}.cta-gradient{pointer-events:none;background:linear-gradient(135deg,#06b6d40d,#0000);position:absolute;inset:0}.cta-box h2{z-index:1;margin-bottom:24px;font-size:32px;font-weight:600;position:relative}.cta-box h2 .accent{color:var(--indigo);font-style:italic}.cta-box>p{color:var(--on-surface-variant);z-index:1;max-width:560px;margin:0 auto 40px;position:relative}.cta-actions{z-index:1;flex-wrap:wrap;justify-content:center;gap:16px;display:flex;position:relative}.footer{border-top:1px solid var(--outline-variant);background:var(--surface-lowest);padding:64px 0}.footer-inner{max-width:var(--max-w);padding:0 var(--gutter);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin:0 auto;display:flex}.footer-links{gap:32px;display:flex}.footer-link{color:var(--on-surface-variant);text-transform:uppercase;letter-spacing:.02em;font-size:12px;font-weight:500;transition:color .2s}.footer-link:hover{color:var(--primary)}.case-label{align-items:center;gap:8px;margin-bottom:16px;display:flex}.case-label span:first-child{background:var(--primary);width:48px;height:1px}.case-label span:last-child{color:var(--primary);text-transform:uppercase;letter-spacing:.1em;font-size:14px;font-weight:500}.case-image{aspect-ratio:21/9;border-radius:var(--radius);border:1px solid var(--ghost);width:100%;position:relative;overflow:hidden}.case-image img{object-fit:cover;width:100%;height:100%}.case-overlay{background:linear-gradient(#0000,#0009);position:absolute;inset:0}.metrics{gap:var(--gutter);grid-template-columns:repeat(2,1fr);display:grid}.metric{border:1px solid var(--ghost);background:var(--black);border-radius:var(--radius);padding:32px}.metric-label{color:var(--on-surface-variant);text-transform:uppercase;font-size:12px}.metric-val{color:var(--primary);font-size:36px;font-weight:700}.metric-bar{background:var(--surface-highest);border-radius:2px;height:4px;margin-top:16px;overflow:hidden}.metric-bar-fill{background:var(--primary);border-radius:2px;height:100%}.process{grid-template-columns:1fr;gap:48px;display:grid}.step{text-align:center;flex-direction:column;align-items:center;gap:16px;display:flex}.step-dot{background:var(--surface-highest);border:1px solid var(--outline-variant);border-radius:50%;width:18px;height:18px}.step-dot.on{background:var(--primary);border:none}@media (width<=767px){.settings-panel{max-width:100%}.settings-btn{bottom:72px}}.settings-overlay{z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;justify-content:flex-end;display:flex;position:fixed;inset:0}.settings-panel{background:var(--surface-lowest);border-left:1px solid var(--outline-variant);flex-direction:column;width:100%;max-width:560px;height:100%;animation:.3s slideIn;display:flex}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.settings-header{border-bottom:1px solid var(--outline-variant);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.settings-tabs{border-bottom:1px solid var(--outline-variant);gap:0;display:flex}.settings-tab{color:var(--on-surface-variant);border-bottom:2px solid #0000;flex:1;justify-content:center;align-items:center;gap:6px;padding:12px 16px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.settings-tab:hover{color:var(--on-surface);background:var(--surface)}.settings-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.settings-body{flex:1;padding:24px;overflow-y:auto}.settings-section{flex-direction:column;gap:20px;display:flex}.settings-section-title{color:var(--primary);text-transform:uppercase;letter-spacing:.05em;font-size:14px;font-weight:600}.setting-label{color:var(--on-surface-variant);margin-bottom:4px;font-size:13px;font-weight:500;display:block}.settings-project-card{background:var(--surface);border:1px solid var(--ghost);border-radius:var(--radius);flex-direction:column;gap:16px;padding:20px;display:flex}.settings-footer{border-top:1px solid var(--outline-variant);justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}.settings-btn{z-index:90;background:var(--indigo);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;transition:all .2s;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 4px 20px #06b6d466}.settings-btn:hover{transform:scale(1.1);box-shadow:0 6px 30px #06b6d480}.settings-btn:active{transform:scale(.95)}.admin-page-wrap{background:var(--black);min-height:100vh;display:flex}.admin-sidebar{background:var(--surface-lowest);border-right:1px solid var(--outline-variant);flex-direction:column;width:280px;height:100vh;padding:32px 24px;display:flex;position:sticky;top:0}.admin-content{background:var(--black);flex:1;padding:40px}.admin-nav-item{color:var(--on-surface-variant);text-align:left;border-radius:8px;align-items:center;gap:12px;width:100%;padding:12px 16px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.admin-nav-item:hover{background:var(--surface);color:var(--on-surface)}.admin-nav-item.active{background:var(--indigo);color:#fff}.settings-page-content{background:var(--surface-lowest);border:1px solid var(--outline-variant);border-radius:var(--radius);flex-direction:column;width:100%;max-width:800px;height:auto;min-height:80vh;margin:0 auto;display:flex}@media (width<=1024px){.admin-sidebar{align-items:center;width:80px;padding:24px 12px}.admin-sidebar .logo-text,.admin-sidebar span:not(.material-symbols-outlined){display:none}.admin-nav-item{justify-content:center;padding:12px}}.img-placeholder{background:var(--surface);width:100%;height:100%;color:var(--on-surface-variant);justify-content:center;align-items:center;display:flex}.img-placeholder .material-symbols-outlined{opacity:.2;font-size:48px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in{animation:.5s forwards fadeIn}.login-container{min-height:100vh;padding:var(--gutter);background:radial-gradient(circle,#1a1a1a 0%,#000 100%);justify-content:center;align-items:center;display:flex}.login-box{background:var(--surface-low);border:1px solid var(--outline-variant);border-radius:var(--radius);width:100%;max-width:400px;padding:40px;box-shadow:0 20px 50px #00000080}.login-header{text-align:center;margin-bottom:32px}.login-header h2{margin-top:16px;margin-bottom:8px;font-size:24px;font-weight:700}.login-header p{color:var(--on-surface-variant);font-size:14px}.error-msg{color:#ef4444;text-align:center;background:#ef44441a;border-radius:4px;padding:10px;font-size:13px}.section-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:64px;display:flex}.section-head-left{max-width:560px}.section-head-left h2{margin-bottom:16px;font-size:32px;font-weight:600}.section-head-left p{color:var(--on-surface-variant);font-size:18px}.see-all{color:var(--primary);align-items:center;gap:8px;font-size:14px;font-weight:500;display:inline-flex}.see-all:hover .material-symbols-outlined{transform:translate(4px)}.see-all .material-symbols-outlined{font-size:18px;transition:transform .2s}@media (width>=768px){.hero-bg-image{background-position:100% 0;background-size:contain}.hero h1{letter-spacing:-.04em;font-size:64px;line-height:1.1}.section{padding:160px 0}.projects-grid{grid-template-columns:repeat(2,1fr)}.skills-grid{grid-template-columns:repeat(4,1fr)}.about-hero{text-align:left;grid-template-columns:auto 1fr}.about-text{text-align:left}.about-text p{margin:0}.portrait{width:256px;height:256px;margin:0}.form-row{grid-template-columns:1fr 1fr}.contact-box{padding:64px}.cta-box{padding:96px}.bento{grid-template-columns:repeat(12,1fr)}.bento-lg{grid-column:span 7;min-height:480px}.bento-sm-wrap{gap:var(--gutter);grid-column:span 5;grid-template-rows:1fr 1fr;display:grid}.metrics,.process{grid-template-columns:repeat(4,1fr)}.mobile-nav,.menu-btn{display:none!important}.nav-desktop{display:flex!important}.btn-resume{display:inline-flex}.footer{display:block}}@media (width<=767px){.nav-desktop{display:none}.menu-btn{display:block}.mobile-nav{display:flex}.footer{display:none}.hero{padding-top:96px}.hero-actions{flex-direction:column;width:100%}.hero-actions .btn{width:100%}.about-text h1{font-size:32px}}.project-modal-overlay{z-index:300;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#000000d9;justify-content:center;align-items:center;padding:24px;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.project-modal-card{background:var(--surface-lowest);border:1px solid var(--outline-variant);border-radius:16px;flex-direction:column;width:100%;max-width:640px;max-height:90vh;animation:.3s cubic-bezier(.34,1.56,.64,1) scaleUp;display:flex;position:relative;overflow-y:auto;box-shadow:0 20px 40px #0009}.project-modal-close{border:1px solid var(--outline-variant);color:#fff;cursor:pointer;z-index:10;background:#00000080;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:all .2s;display:flex;position:absolute;top:16px;right:16px}.project-modal-close:hover{background:var(--primary);border-color:var(--primary);transform:rotate(90deg)}.project-modal-header-banner{background:linear-gradient(135deg, var(--surface-low) 0%, var(--surface-dim) 100%);border-bottom:1px solid var(--outline-variant);flex-direction:column;justify-content:center;align-items:flex-start;width:100%;min-height:120px;padding:32px 64px 32px 32px;display:flex;position:relative;overflow:hidden}.project-modal-header-banner h2{color:#fff;letter-spacing:-.02em;margin:0;font-size:24px;font-weight:700;line-height:1.3}.project-modal-content{padding:32px}.project-modal-desc{color:var(--on-surface);letter-spacing:-.01em;white-space:pre-wrap;font-size:15px;line-height:1.8}@keyframes scaleUp{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@media (width<=767px){.project-modal-overlay{padding:16px}.project-modal-card{max-height:85vh}.project-modal-header-banner{min-height:100px;padding:24px 48px 24px 20px}.project-modal-header-banner h2{font-size:20px}.project-modal-content{padding:20px}}.footer{z-index:90;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--outline-variant);background:#0e0e0ed9;width:100%;position:fixed;bottom:0;left:0}.footer-inner{max-width:var(--max-w);justify-content:space-between;align-items:center;margin:0 auto;display:flex}@media (width<=767px){.footer{display:none!important}}
