@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-cyrillic-ext-400-normal-BQZuk6qB.woff2)format("woff2"),url(/assets/inter-cyrillic-ext-400-normal-DQukG94-.woff)format("woff");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-cyrillic-400-normal-obahsSVq.woff2)format("woff2"),url(/assets/inter-cyrillic-400-normal-HOLc17fK.woff)format("woff");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-greek-ext-400-normal-DGGRlc-M.woff2)format("woff2"),url(/assets/inter-greek-ext-400-normal-KugGGMne.woff)format("woff");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-greek-400-normal-B4URO6DV.woff2)format("woff2"),url(/assets/inter-greek-400-normal-q2sYcFCs.woff)format("woff");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-vietnamese-400-normal-DMkecbls.woff2)format("woff2"),url(/assets/inter-vietnamese-400-normal-Bbgyi5SW.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-latin-ext-400-normal-C1nco2VV.woff2)format("woff2"),url(/assets/inter-latin-ext-400-normal-77YHD8bZ.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-latin-400-normal-C38fXH4l.woff2)format("woff2"),url(/assets/inter-latin-400-normal-CyCys3Eg.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-cyrillic-ext-500-normal-B0yAr1jD.woff2)format("woff2"),url(/assets/inter-cyrillic-ext-500-normal-BmqWE9Dz.woff)format("woff");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-cyrillic-500-normal-BasfLYem.woff2)format("woff2"),url(/assets/inter-cyrillic-500-normal-CxZf_p3X.woff)format("woff");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-greek-ext-500-normal-C4iEst2y.woff2)format("woff2"),url(/assets/inter-greek-ext-500-normal-2j5mBUwD.woff)format("woff");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-greek-500-normal-BIZE56-Y.woff2)format("woff2"),url(/assets/inter-greek-500-normal-Xzm54t5V.woff)format("woff");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-vietnamese-500-normal-DOriooB6.woff2)format("woff2"),url(/assets/inter-vietnamese-500-normal-mJboJaSs.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-latin-ext-500-normal-CV4jyFjo.woff2)format("woff2"),url(/assets/inter-latin-ext-500-normal-BxGbmqWO.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-latin-500-normal-Cerq10X2.woff2)format("woff2"),url(/assets/inter-latin-500-normal-BL9OpVg8.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/inter-cyrillic-ext-600-normal-Dfes3d0z.woff2)format("woff2"),url(/assets/inter-cyrillic-ext-600-normal-Bcila6Z-.woff)format("woff");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/inter-cyrillic-600-normal-CWCymEST.woff2)format("woff2"),url(/assets/inter-cyrillic-600-normal-4D_pXhcN.woff)format("woff");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/inter-greek-ext-600-normal-DRtmH8MT.woff2)format("woff2"),url(/assets/inter-greek-ext-600-normal-B8X0CLgF.woff)format("woff");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/inter-greek-600-normal-plRanbMR.woff2)format("woff2"),url(/assets/inter-greek-600-normal-BZpKdvQh.woff)format("woff");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/inter-vietnamese-600-normal-Cc8MFFhd.woff2)format("woff2"),url(/assets/inter-vietnamese-600-normal-BuLX-rYi.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/inter-latin-ext-600-normal-D2bJ5OIk.woff2)format("woff2"),url(/assets/inter-latin-ext-600-normal-CIVaiw4L.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/inter-latin-600-normal-LgqL8muc.woff2)format("woff2"),url(/assets/inter-latin-600-normal-CiBQ2DWP.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-cyrillic-ext-700-normal-BjwYoWNd.woff2)format("woff2"),url(/assets/inter-cyrillic-ext-700-normal-LO58E6JB.woff)format("woff");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-cyrillic-700-normal-CjBOestx.woff2)format("woff2"),url(/assets/inter-cyrillic-700-normal-DrXBdSj3.woff)format("woff");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-greek-ext-700-normal-qfdV9bQt.woff2)format("woff2"),url(/assets/inter-greek-ext-700-normal-BoQ6DsYi.woff)format("woff");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-greek-700-normal-C3JjAnD8.woff2)format("woff2"),url(/assets/inter-greek-700-normal-BUv2fZ6O.woff)format("woff");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-vietnamese-700-normal-DlLaEgI2.woff2)format("woff2"),url(/assets/inter-vietnamese-700-normal-BZaoP0fm.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-latin-ext-700-normal-Ca8adRJv.woff2)format("woff2"),url(/assets/inter-latin-ext-700-normal-TidjK2hL.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-latin-700-normal-Yt3aPRUw.woff2)format("woff2"),url(/assets/inter-latin-700-normal-BLAVimhd.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:800;src:url(/assets/inter-cyrillic-ext-800-normal-BZOjs1Xv.woff2)format("woff2"),url(/assets/inter-cyrillic-ext-800-normal-Ca-gJeZY.woff)format("woff");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:800;src:url(/assets/inter-cyrillic-800-normal-C7MGvYyJ.woff2)format("woff2"),url(/assets/inter-cyrillic-800-normal-CCHyn08d.woff)format("woff");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:800;src:url(/assets/inter-greek-ext-800-normal-B--PVpEC.woff2)format("woff2"),url(/assets/inter-greek-ext-800-normal-DUe57HfS.woff)format("woff");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:800;src:url(/assets/inter-greek-800-normal-CLIouy3y.woff2)format("woff2"),url(/assets/inter-greek-800-normal-BU00tryP.woff)format("woff");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:800;src:url(/assets/inter-vietnamese-800-normal-Cm7tD1pz.woff2)format("woff2"),url(/assets/inter-vietnamese-800-normal-DDlpr_Ee.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:800;src:url(/assets/inter-latin-ext-800-normal-DZJjya6U.woff2)format("woff2"),url(/assets/inter-latin-ext-800-normal-BOMpwxm3.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:800;src:url(/assets/inter-latin-800-normal-BYj_oED-.woff2)format("woff2"),url(/assets/inter-latin-800-normal-D1mf63XC.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--bg-primary:#0b1120;--bg-card:#0f172a;--bg-elevated:#1e293b;--bg-hover:#334155;--border-color:#1e293b;--border-hover:#475569;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--accent-blue:#38bdf8;--accent-blue-dim:#38bdf81f;--accent-purple:#818cf8;--accent-purple-dim:#818cf81f;--accent-green:#2dd4bf;--accent-green-dim:#2dd4bf1f;--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--radius-xl:28px;--font-family:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--transition-fast:.2s ease;--transition-med:.3s ease;--transition-slow:.5s ease;--max-width:1200px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;overflow-x:hidden}#root{min-height:100vh}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:var(--font-family);color:var(--text-primary);background:0 0;border:none}ul{list-style:none}img{max-width:100%;display:block}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:#334155;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#475569}.container{max-width:var(--max-width);margin:0 auto;padding:0 24px}.header{z-index:100;-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color);background:#0b1120d9;padding:16px 24px;position:fixed;top:0;left:0;right:0}.header-inner{max-width:var(--max-width);justify-content:space-between;align-items:center;margin:0 auto;display:flex}.header-logo{letter-spacing:-.5px;background:linear-gradient(135deg, var(--accent-blue), var(--accent-green));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.3rem;font-weight:800}.header-nav{background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:100px;align-items:center;gap:4px;padding:4px;display:flex}.header-nav a{color:var(--text-secondary);transition:all var(--transition-fast);border-radius:100px;padding:8px 20px;font-size:.85rem;font-weight:500}.header-nav a:hover,.header-nav a.active{color:var(--text-primary);background:var(--bg-hover)}.header-right{align-items:center;gap:12px;display:flex}.lang-toggle{background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:100px;align-items:center;gap:0;padding:3px;font-size:.78rem;display:flex}.lang-toggle button{color:var(--text-secondary);transition:all var(--transition-fast);border-radius:100px;padding:5px 12px;font-size:.78rem;font-weight:500}.lang-toggle button.active{background:var(--bg-hover);color:var(--text-primary)}.hamburger{cursor:pointer;flex-direction:column;gap:5px;padding:8px;display:none}.hamburger span{background:var(--text-primary);width:20px;height:2px;transition:all var(--transition-fast);border-radius:2px}.mobile-menu{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color);z-index:99;background:#0b1120f2;padding:24px;display:none;position:fixed;top:65px;left:0;right:0}.mobile-menu.open{flex-direction:column;gap:8px;display:flex}.mobile-menu a{border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast);padding:12px 16px;font-size:1rem}.mobile-menu a:hover{background:var(--bg-elevated);color:var(--text-primary)}.hero{text-align:center;padding:160px 24px 80px;position:relative;overflow:hidden}.hero:before{content:"";pointer-events:none;background:radial-gradient(circle,#38bdf80f 0%,#2dd4bf08 40%,#0000 70%);width:600px;height:600px;position:absolute;top:0;left:50%;transform:translate(-50%)}.hero-name{letter-spacing:-2px;margin-bottom:16px;font-size:clamp(2.5rem,6vw,4.2rem);font-weight:800;line-height:1.1}.hero-name .gradient-text{background:linear-gradient(135deg, var(--accent-blue), var(--accent-green));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-role{color:var(--text-secondary);margin-bottom:20px;font-size:clamp(1rem,2.5vw,1.25rem);font-weight:500}.hero-desc{max-width:640px;color:var(--text-muted);margin:0 auto 36px;font-size:1rem;line-height:1.7}.hero-buttons{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.btn-primary{background:linear-gradient(135deg, var(--accent-blue), var(--accent-green));color:#0b1120;transition:all var(--transition-med);border:none;border-radius:100px;align-items:center;gap:8px;padding:12px 28px;font-size:.9rem;font-weight:700;display:inline-flex}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px #38bdf840}.btn-ghost{color:var(--text-primary);border:1px solid var(--border-hover);transition:all var(--transition-med);background:0 0;border-radius:100px;align-items:center;gap:8px;padding:12px 28px;font-size:.9rem;font-weight:600;display:inline-flex}.btn-ghost:hover{background:var(--bg-elevated);border-color:var(--text-muted);transform:translateY(-2px)}.filter-bar{max-width:var(--max-width);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin:0 auto;padding:0 24px 40px;display:flex}.filter-pills{flex-wrap:wrap;gap:8px;display:flex}.filter-pill{color:var(--text-secondary);background:var(--bg-elevated);border:1px solid var(--border-color);transition:all var(--transition-fast);cursor:pointer;border-radius:100px;padding:8px 20px;font-size:.85rem;font-weight:500}.filter-pill:hover{border-color:var(--border-hover);color:var(--text-primary)}.filter-pill.active{background:var(--accent-blue-dim);border-color:var(--accent-blue);color:var(--accent-blue)}.filter-actions{gap:8px;display:flex}.project-grid{max-width:var(--max-width);grid-template-columns:repeat(3,1fr);gap:20px;margin:0 auto;padding:0 24px 60px;display:grid}.project-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);transition:all var(--transition-med);flex-direction:column;padding:28px;display:flex;position:relative;overflow:hidden}.project-card:before{content:"";border-radius:var(--radius-xl) var(--radius-xl) 0 0;height:3px;position:absolute;top:0;left:0;right:0}.project-card.blue:before{background:linear-gradient(90deg, var(--accent-blue), #7dd3fc)}.project-card.purple:before{background:linear-gradient(90deg, var(--accent-purple), #a5b4fc)}.project-card.green:before{background:linear-gradient(90deg, var(--accent-green), #5eead4)}.project-card:hover{border-color:var(--border-hover);transform:translateY(-4px)}.project-card.blue:hover{box-shadow:0 8px 40px #38bdf81a}.project-card.purple:hover{box-shadow:0 8px 40px #818cf81a}.project-card.green:hover{box-shadow:0 8px 40px #2dd4bf1a}.card-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:20px;font-size:1.4rem;display:flex}.card-icon.blue{background:var(--accent-blue-dim);color:var(--accent-blue)}.card-icon.purple{background:var(--accent-purple-dim);color:var(--accent-purple)}.card-icon.green{background:var(--accent-green-dim);color:var(--accent-green)}.card-title{margin-bottom:4px;font-size:1.2rem;font-weight:700}.card-subtitle{color:var(--text-secondary);margin-bottom:20px;font-size:.85rem}.card-features{flex-direction:column;flex:1;gap:10px;margin-bottom:24px;display:flex}.card-feature{color:var(--text-secondary);align-items:flex-start;gap:10px;font-size:.85rem;line-height:1.5;display:flex}.card-feature .feature-icon{opacity:.6;flex-shrink:0;margin-top:3px;font-size:.75rem}.card-footer{border-top:1px solid var(--border-color);justify-content:space-between;align-items:center;padding-top:20px;display:flex}.card-techs{flex-wrap:wrap;gap:6px;display:flex}.tech-badge{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:100px;padding:4px 10px;font-size:.7rem;font-weight:500}.card-link{transition:color var(--transition-fast);white-space:nowrap;align-items:center;gap:6px;font-size:.85rem;font-weight:600;display:inline-flex}.card-link svg{transition:transform var(--transition-fast);flex-shrink:0}.card-link.blue{color:var(--accent-blue)}.card-link.purple{color:var(--accent-purple)}.card-link.green{color:var(--accent-green)}.card-link:hover svg{transform:translate(4px)}.bundle-section{max-width:var(--max-width);margin:0 auto 60px;padding:0 24px}.bundle-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);transition:all var(--transition-med);justify-content:space-between;align-items:center;gap:24px;padding:32px 36px;display:flex;position:relative;overflow:hidden}.bundle-card:before{content:"";background:linear-gradient(90deg, var(--accent-blue), var(--accent-green));height:3px;position:absolute;top:0;left:0;right:0}.bundle-card:hover{border-color:var(--border-hover);transform:translateY(-2px);box-shadow:0 8px 40px #38bdf814}.bundle-icons{gap:12px;display:flex}.bundle-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:44px;height:44px;font-size:1.2rem;display:flex}.bundle-info{flex:1}.bundle-info h3{margin-bottom:2px;font-size:1.2rem;font-weight:700}.bundle-info p{color:var(--text-secondary);font-size:.88rem}.skills-section{max-width:var(--max-width);margin:0 auto;padding:60px 24px}.skills-section h2{text-align:center;letter-spacing:-1px;margin-bottom:40px;font-size:2rem;font-weight:800}.skills-grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.skill-group{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);transition:all var(--transition-med);padding:28px}.skill-group:hover{border-color:var(--border-hover);transform:translateY(-2px)}.skill-group h3{color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;margin-bottom:16px;font-size:.85rem;font-weight:600}.skill-tags{flex-wrap:wrap;gap:8px;display:flex}.skill-tag{background:var(--bg-elevated);border:1px solid var(--border-color);color:var(--text-primary);transition:all var(--transition-fast);border-radius:100px;align-items:center;gap:6px;padding:8px 16px;font-size:.82rem;font-weight:500;display:inline-flex}.skill-tag-icon{opacity:.6;transition:opacity var(--transition-fast);font-size:.95rem}.skill-tag:hover .skill-tag-icon{opacity:1}.skill-tag:hover{border-color:var(--accent-blue);background:var(--accent-blue-dim);color:var(--accent-blue);transform:translateY(-1px)}.education-section{max-width:var(--max-width);margin:0 auto;padding:60px 24px}.education-section h2{text-align:center;letter-spacing:-1px;margin-bottom:40px;font-size:2rem;font-weight:800}.education-grid{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}.edu-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);transition:all var(--transition-med);padding:28px}.edu-card:hover{border-color:var(--border-hover);transform:translateY(-2px)}.edu-card .edu-icon{border-radius:var(--radius-md);background:var(--accent-blue-dim);width:48px;height:48px;color:var(--accent-blue);justify-content:center;align-items:center;margin-bottom:16px;font-size:1.4rem;display:flex}.edu-card h3{margin-bottom:4px;font-size:1.1rem;font-weight:700}.edu-card .edu-sub{color:var(--text-secondary);margin-bottom:4px;font-size:.88rem}.edu-card .edu-detail{color:var(--text-muted);font-size:.82rem}.cert-list{flex-direction:column;gap:16px;display:flex}.cert-item{align-items:center;gap:14px;display:flex}.cert-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.2rem;display:flex}.cert-icon.microsoft{background:var(--accent-blue-dim);color:var(--accent-blue)}.cert-icon.google{background:var(--accent-green-dim);color:var(--accent-green)}.cert-info h4{font-size:.92rem;font-weight:600}.cert-info p{color:var(--text-secondary);font-size:.8rem}.contact-section{max-width:var(--max-width);text-align:center;margin:0 auto;padding:60px 24px 40px}.contact-section h2{letter-spacing:-1px;margin-bottom:8px;font-size:2rem;font-weight:800}.contact-section .contact-sub{color:var(--text-secondary);margin-bottom:36px;font-size:1rem}.contact-cards{flex-wrap:wrap;justify-content:center;gap:16px;display:flex}.contact-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-med);align-items:center;gap:12px;padding:16px 24px;text-decoration:none;display:flex}.contact-card:hover{border-color:var(--border-hover);background:var(--bg-elevated);transform:translateY(-2px)}.contact-card .contact-icon{border-radius:var(--radius-sm);background:var(--accent-purple-dim);width:40px;height:40px;color:var(--accent-purple);justify-content:center;align-items:center;font-size:1.1rem;display:flex}.contact-card span{font-size:.9rem;font-weight:500}.footer{max-width:var(--max-width);border-top:1px solid var(--border-color);text-align:center;margin:0 auto;padding:32px 24px}.footer p{color:var(--text-muted);font-size:.82rem}.footer .heart{color:var(--accent-green)}.detail-page{background:var(--bg-primary);min-height:100vh}.detail-header-bar{z-index:100;-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color);background:#0b1120d9;padding:16px 24px;position:fixed;top:0;left:0;right:0}.back-btn{color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:8px;font-size:1rem;font-weight:700;display:inline-flex}.back-btn:hover{opacity:.7}.back-btn span{background:linear-gradient(135deg, var(--accent-blue), var(--accent-green));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.github-link-btn{background:var(--bg-elevated);border:1px solid var(--border-color);color:var(--text-primary);transition:all var(--transition-fast);border-radius:100px;align-items:center;gap:6px;padding:8px 20px;font-size:.85rem;font-weight:500;display:inline-flex}.github-link-btn:hover{border-color:var(--border-hover);background:var(--bg-hover)}.detail-container{padding-top:100px;padding-bottom:80px}.breadcrumbs{align-items:center;gap:8px;margin-bottom:32px;font-size:.85rem;display:flex}.breadcrumb-link{color:var(--text-muted);transition:color var(--transition-fast);font-weight:500}.breadcrumb-link:hover{color:var(--accent-blue)}.breadcrumb-sep{color:var(--text-muted);opacity:.5;font-size:.7rem}.breadcrumb-current{color:var(--text-secondary);font-weight:600}.detail-hero{text-align:center;margin-bottom:60px}.detail-badge{border-radius:100px;margin-bottom:20px;padding:6px 16px;font-size:.8rem;font-weight:600;display:inline-block}.detail-title{letter-spacing:-1.5px;margin-bottom:12px;font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;line-height:1.15}.detail-subtitle{color:var(--text-secondary);font-size:1.1rem}.detail-section{margin-bottom:48px}.section-header{align-items:center;gap:14px;margin-bottom:20px;display:flex}.section-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.2rem;display:flex}.section-header h2{font-size:1.4rem;font-weight:700}.section-text{color:var(--text-secondary);padding-left:58px;font-size:1rem;line-height:1.8}.approach-grid{grid-template-columns:repeat(2,1fr);gap:16px;padding-left:58px;display:grid}.approach-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-med);padding:24px}.approach-card:hover{border-color:var(--border-hover);transform:translateY(-2px)}.approach-number{opacity:.7;margin-bottom:10px;font-size:.8rem;font-weight:700}.approach-card h3{margin-bottom:8px;font-size:1rem;font-weight:600}.approach-card p{color:var(--text-secondary);font-size:.88rem;line-height:1.6}.results-list{flex-direction:column;gap:14px;padding-left:58px;display:flex}.result-item{align-items:flex-start;gap:14px;display:flex}.result-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:8px}.result-item p{color:var(--text-secondary);font-size:.95rem;line-height:1.6}.tech-tags-detail{flex-wrap:wrap;gap:10px;padding-left:58px;display:flex}.tech-tag-detail{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-primary);transition:all var(--transition-fast);border-radius:100px;padding:10px 20px;font-size:.88rem;font-weight:500}.tech-tag-detail:hover{background:var(--bg-elevated);transform:translateY(-2px)}.detail-cta{border-top:1px solid var(--border-color);justify-content:center;gap:16px;margin-top:60px;padding-top:40px;display:flex}@media (width<=1023px){.project-grid,.skills-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.header-nav{display:none}.hamburger{display:flex}.hero{padding:130px 20px 60px}.hero-name{letter-spacing:-1px;font-size:2rem}.project-grid,.skills-grid,.education-grid{grid-template-columns:1fr}.bundle-card{text-align:center;flex-direction:column}.bundle-icons{justify-content:center}.filter-bar{flex-direction:column;align-items:flex-start}.filter-actions{width:100%}.filter-actions .btn-ghost{flex:1;justify-content:center}.approach-grid{grid-template-columns:1fr;padding-left:0}.section-text,.results-list,.tech-tags-detail{padding-left:0}.detail-cta{flex-direction:column;align-items:center}}@media (width<=480px){.hero-buttons{flex-direction:column;align-items:center;gap:16px}.btn-primary,.btn-ghost{justify-content:center;width:100%;min-height:48px}.contact-cards{flex-direction:column}.contact-card{justify-content:center;width:100%}.breadcrumbs{gap:6px;font-size:.78rem}}
