:root{--bg-primary:#0c1222;--bg-secondary:#111827;--bg-surface:#1a2438;--bg-surface-hover:#1f2d45;--color-primary:#d4a574;--color-primary-dim:#d4a57499;--color-secondary:#5b8a8f;--color-accent:#c75b39;--text-primary:#e8e2d9;--text-secondary:#7a8494;--text-muted:#4f5b6b;--border-color:#d4a5741f;--border-color-strong:#d4a57440;--glow-primary:#d4a57426;--glow-accent:#c75b3933;--glass-bg:#121a2ad9;--glass-bg-hover:#1a2438e6;--glass-border:#d4a5741a;--glass-blur:20px;--font-sans:"DM Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-display:"Space Grotesk", var(--font-sans);--font-mono:"JetBrains Mono", monospace;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-in-out:cubic-bezier(.65, 0, .35, 1);--transition-fast:.2s var(--ease-out);--transition-normal:.35s var(--ease-out);--transition-slow:.5s var(--ease-out)}body.theme-light{--bg-primary:#f9fafb;--bg-secondary:#f3f4f6;--bg-surface:#fff;--bg-surface-hover:#f8fafc;--color-primary:#d4a574;--color-primary-dim:#d4a57466;--color-secondary:#3b82f6;--color-accent:#c75b39;--text-primary:#111827;--text-secondary:#4b5563;--text-muted:#9ca3af;--border-color:#0000001a;--border-color-strong:#0003;--glow-primary:#d4a57440;--glow-accent:#c75b394d;--glass-bg:#ffffffd9;--glass-bg-hover:#fffffff2;--glass-border:#0000000d}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5;transition:background-color .5s,color .5s}.nav-toggles{border-left:1px solid var(--border-color);align-items:center;gap:16px;margin-left:24px;padding-left:24px;display:flex}.theme-switch,.lang-switch{cursor:pointer;font-family:var(--font-display);color:var(--text-secondary);transition:color var(--transition-fast);background:0 0;border:none;align-items:center;gap:8px;font-size:13px;font-weight:600;display:flex}.theme-switch:hover,.lang-switch:hover{color:var(--text-primary)}.switch-track{background-color:var(--bg-secondary);border:1px solid var(--border-color);width:40px;height:22px;transition:all var(--transition-fast);border-radius:20px;align-items:center;display:flex;position:relative}body.theme-light .switch-track{background-color:#e5e7eb}.switch-thumb{background-color:var(--color-primary);border-radius:50%;width:16px;height:16px;transition:transform .3s cubic-bezier(.68,-.55,.265,1.55);position:absolute;left:3px}.theme-switch[aria-checked=true] .switch-thumb{background-color:var(--color-accent);transform:translate(18px)}.lang-switch[aria-checked=true] .switch-thumb{background-color:var(--color-secondary);transform:translate(18px)}.switch-icon{width:14px;height:14px;color:inherit}a{color:inherit;text-decoration:none}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}.glass-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-lg)}.glass-card-solid{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.custom-scrollbar::-webkit-scrollbar{width:4px}.custom-scrollbar::-webkit-scrollbar-track{background:0 0}.custom-scrollbar::-webkit-scrollbar-thumb{background:var(--color-primary-dim);border-radius:4px}.custom-scrollbar::-webkit-scrollbar-thumb:hover{background:var(--color-primary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 8px var(--color-primary-dim), 0 0 20px #d4a5741a}50%{box-shadow:0 0 16px var(--color-primary), 0 0 40px #d4a57433}}@keyframes marker-pulse{0%{opacity:.8;transform:translate(-50%,-50%)scale(1)}to{opacity:0;transform:translate(-50%,-50%)scale(3)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes twinkle{0%,to{opacity:.3}50%{opacity:1}}@keyframes spin-slow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.app{background:var(--bg-primary);width:100vw;height:100vh;position:relative;overflow:hidden}.navbar{z-index:50;animation:fadeInUp .6s var(--ease-out);padding:12px 16px;position:fixed;top:0;left:0;right:0}@media (min-width:768px){.navbar{padding:16px 24px}}.navbar-inner{justify-content:space-between;align-items:center;padding:10px 20px;display:flex}@media (min-width:768px){.navbar-inner{padding:12px 24px}}.nav-logo{transition:transform var(--transition-fast);align-items:center;gap:10px;display:flex}.nav-logo:hover{transform:scale(1.02)}.nav-logo-image-container{align-items:center;display:flex}.nav-logo-image{object-fit:contain;filter:drop-shadow(0 2px 4px #0000004d);width:auto;height:42px;animation:10s ease-in-out infinite logo-3d}@media (min-width:768px){.nav-logo-image{height:52px}}@keyframes logo-3d{0%{transform:perspective(1000px)rotateY(0)rotateX(0)scale(1)}20%{transform:perspective(1000px)rotateY(25deg)rotateX(10deg)scale(1.05)}40%{transform:perspective(1000px)rotateY(-25deg)rotateX(10deg)scale(1.05)}50%{transform:perspective(1000px)rotateY(180deg)rotateX(0)scale(1.25)}60%{transform:perspective(1000px)rotateY(360deg)rotateX(0)scale(1.1)}80%{transform:perspective(1000px)rotateY(0)rotateX(15deg)scale(1.1)}to{transform:perspective(1000px)rotateY(0)rotateX(0)scale(1)}}.nav-links{align-items:center;gap:4px;display:none}@media (min-width:768px){.nav-links{display:flex}}.nav-link{border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--transition-fast);padding:8px 16px;font-size:14px;font-weight:500;position:relative}.nav-link:hover,.nav-link.active{color:var(--text-primary);background:#d4a57414}.nav-link.active:after{content:"";background:var(--color-primary);border-radius:1px;width:16px;height:2px;position:absolute;bottom:4px;left:50%;transform:translate(-50%)}.nav-divider{background:var(--border-color);width:1px;height:24px;margin:0 8px}.nav-icon-btn{border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--transition-fast);padding:8px}.nav-icon-btn:hover{color:var(--text-primary);background:#d4a57414}.nav-mobile-actions{align-items:center;gap:4px;display:flex}@media (min-width:768px){.nav-mobile-actions{display:none}}.mobile-menu-overlay{z-index:100;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);animation:fadeIn .3s var(--ease-out);background:#0c1222f2;flex-direction:column;justify-content:center;align-items:center;gap:8px;display:flex;position:fixed;inset:0}.mobile-menu-close{color:var(--text-secondary);padding:8px;position:absolute;top:20px;right:20px}.mobile-menu-link{font-family:var(--font-display);color:var(--text-secondary);border-radius:var(--radius-md);transition:all var(--transition-fast);padding:16px 32px;font-size:24px;font-weight:600}.mobile-menu-link:hover,.mobile-menu-link.active{color:var(--color-primary);background:#d4a57414}.sidebar{z-index:40;pointer-events:auto;width:320px;animation:slideInLeft .5s var(--ease-out);padding:16px;display:none;position:absolute;top:88px;bottom:0;left:0}@media (min-width:768px){.sidebar{display:block}}@media (min-width:1024px){.sidebar{width:380px;padding:20px}}.sidebar-inner{flex-direction:column;height:100%;display:flex;overflow:hidden}.sidebar-header{border-bottom:1px solid var(--border-color);background:#0003;padding:16px}.sidebar-title{font-family:var(--font-display);background:linear-gradient(135deg, var(--text-primary), var(--color-primary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:20px;font-weight:700}.sidebar-count{color:var(--text-secondary);margin-top:2px;font-size:12px}.sidebar-list{flex-direction:column;flex:1;gap:8px;padding:12px;display:flex;overflow-y:auto}.project-card{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-normal);border:1px solid #0000;padding:14px 16px;position:relative}.project-card:hover{background:var(--bg-surface-hover);border-color:var(--border-color)}.project-card.active{background:var(--bg-surface);border-color:var(--border-color-strong);box-shadow:0 0 20px var(--glow-primary)}.project-card-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:8px;display:flex}.project-card-title{font-family:var(--font-display);color:var(--text-primary);font-size:15px;font-weight:600;line-height:1.3}.project-card-year{color:var(--color-primary);white-space:nowrap;background:#d4a5741a;border-radius:20px;flex-shrink:0;padding:2px 10px;font-size:12px;font-weight:600}.project-card-location{color:var(--text-secondary);align-items:center;gap:4px;margin-bottom:6px;font-size:12px;display:flex}.project-card-location svg{width:12px;height:12px;color:var(--color-accent);flex-shrink:0}.project-card-desc{color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:12.5px;line-height:1.5;display:-webkit-box;overflow:hidden}.project-card-category{text-transform:uppercase;letter-spacing:.5px;color:var(--color-secondary);margin-top:8px;font-size:10px;font-weight:600;display:inline-block}.sidebar-list .project-card:before{content:"";background:var(--border-color);border-radius:1px;width:2px;position:absolute;top:0;bottom:0;left:-6px}.sidebar-list .project-card.active:before{background:var(--color-primary);box-shadow:0 0 8px var(--glow-primary)}.sidebar-list .project-card:after{content:"";border:2px solid var(--border-color);background:var(--bg-primary);border-radius:50%;width:10px;height:10px;position:absolute;top:20px;left:-10px}.sidebar-list .project-card.active:after{border-color:var(--color-primary);background:var(--color-primary);box-shadow:0 0 10px var(--glow-primary)}.mobile-bottom-sheet{z-index:45;-webkit-backdrop-filter:blur(24px);will-change:transform;background:#0a0e1af7;border-top:1px solid #d4a57440;border-radius:20px 20px 0 0;flex-direction:column;height:72vh;transition:transform .38s cubic-bezier(.32,.72,0,1);display:flex;position:fixed;bottom:0;left:0;right:0;overflow:hidden;box-shadow:0 -8px 40px #0009}@media (min-width:768px){.mobile-bottom-sheet{display:none}}.mobile-bottom-sheet.is-collapsed{transform:translateY(calc(100% - 64px))}.mobile-bottom-sheet.is-expanded{transform:translateY(0)}.bottom-sheet-handle{cursor:pointer;touch-action:none;-webkit-user-select:none;user-select:none;flex-direction:column;flex-shrink:0;align-items:center;gap:6px;height:64px;padding:10px 16px 0;display:flex}.handle-bar{background:#ffffff40;border-radius:2px;flex-shrink:0;width:36px;height:4px}.handle-label{align-items:center;gap:8px;width:100%;display:flex}.handle-label>svg:first-child{width:16px;height:16px;color:var(--color-primary);flex-shrink:0}.handle-label span{color:var(--text-primary);font-size:14px;font-weight:600}.handle-label .count{color:var(--text-muted);background:var(--bg-secondary);border-radius:10px;padding:2px 7px;font-size:11px}.sheet-chevron{width:16px;height:16px;color:var(--text-muted);flex-shrink:0;margin-left:auto;transition:transform .3s;transform:rotate(180deg)}.sheet-chevron.up{transform:rotate(0)}.bottom-sheet-content{flex-direction:column;flex:1;gap:8px;padding:8px 12px 32px;display:flex;overflow-y:auto}.bottom-sheet-project-card{border-radius:var(--radius-lg);cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:pan-y;background:#ffffff0f;border:1px solid #ffffff1a;padding:14px;transition:border-color .2s,background .2s}.bottom-sheet-project-card .project-card-title{color:#e8e2d9}.bottom-sheet-project-card .project-card-year{color:var(--color-primary)}.bottom-sheet-project-card .project-card-category{color:#d4a574b3}.bottom-sheet-project-card .project-card-location span{color:#ffffff8c}.bottom-sheet-project-card:active,.bottom-sheet-project-card.active{border-color:var(--color-primary);background:#d4a5741f}.detail-panel{z-index:40;pointer-events:auto;width:400px;animation:slideInRight .4s var(--ease-out);padding:16px;display:none;position:absolute;top:88px;bottom:0;right:0}@media (min-width:768px){.detail-panel{display:block}}@media (min-width:1024px){.detail-panel{width:420px;padding:20px}}.detail-panel-inner{flex-direction:column;height:100%;display:flex;overflow:hidden}.detail-header{border-bottom:1px solid var(--border-color);padding:20px;position:relative}.detail-close{border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--transition-fast);padding:6px;position:absolute;top:16px;right:16px}.detail-close:hover{color:var(--text-primary);background:#d4a5741a}.detail-category{text-transform:uppercase;letter-spacing:1px;color:var(--color-accent);margin-bottom:10px;font-size:10px;font-weight:700;display:inline-block}.detail-title{font-family:var(--font-display);color:var(--text-primary);margin-bottom:12px;font-size:24px;font-weight:700;line-height:1.2}.detail-location{color:var(--text-secondary);align-items:center;gap:6px;font-size:13px;display:flex}.detail-location svg{width:14px;height:14px;color:var(--color-accent)}.detail-body{flex:1;padding:20px;overflow-y:auto}.detail-year-badge{color:var(--color-primary);border:1px solid var(--border-color);background:#d4a57414;border-radius:20px;align-items:center;gap:6px;margin-bottom:16px;padding:6px 14px;font-size:13px;font-weight:600;display:inline-flex}.detail-year-badge svg{width:14px;height:14px}.detail-description{color:var(--text-secondary);margin-bottom:24px;font-size:14px;line-height:1.7}.detail-tags-title{text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:10px;font-size:11px;font-weight:700}.detail-tags{flex-wrap:wrap;gap:6px;display:flex}.detail-tag{transition:all var(--transition-normal);cursor:default;border-radius:8px;justify-content:center;align-items:center;padding:6px 14px;font-size:12px;font-weight:600;display:inline-flex;position:relative}.detail-tag:hover{transform:translateY(-2px)}.detail-tag:nth-child(5n+1){color:#60a5fa;background:linear-gradient(135deg,#3b82f626,#2563eb0d);border:1px solid #3b82f64d}.detail-tag:nth-child(5n+2){color:#34d399;background:linear-gradient(135deg,#10b98126,#0596690d);border:1px solid #10b9814d}.detail-tag:nth-child(5n+3){color:#fbbf24;background:linear-gradient(135deg,#f59e0b26,#d977060d);border:1px solid #f59e0b4d}.detail-tag:nth-child(5n+4){color:#a78bfa;background:linear-gradient(135deg,#8b5cf626,#6d28d90d);border:1px solid #8b5cf64d}.detail-tag:nth-child(5n+5){color:#f472b6;background:linear-gradient(135deg,#ec489926,#db27770d);border:1px solid #ec48994d}.detail-tag:nth-child(5n+1):hover{color:#fff;background:linear-gradient(135deg,#3b82f64d,#2563eb1a);box-shadow:0 4px 15px #3b82f64d}.detail-tag:nth-child(5n+2):hover{color:#fff;background:linear-gradient(135deg,#10b9814d,#0596691a);box-shadow:0 4px 15px #10b9814d}.detail-tag:nth-child(5n+3):hover{color:#fff;background:linear-gradient(135deg,#f59e0b4d,#d977061a);box-shadow:0 4px 15px #f59e0b4d}.detail-tag:nth-child(5n+4):hover{color:#fff;background:linear-gradient(135deg,#8b5cf64d,#6d28d91a);box-shadow:0 4px 15px #8b5cf64d}.detail-tag:nth-child(5n+5):hover{color:#fff;background:linear-gradient(135deg,#ec48994d,#db27771a);box-shadow:0 4px 15px #ec48994d}body.theme-light .detail-tag:nth-child(5n+1){color:#2563eb;border-color:#3b82f666}body.theme-light .detail-tag:nth-child(5n+2){color:#059669;border-color:#10b98166}body.theme-light .detail-tag:nth-child(5n+3){color:#d97706;border-color:#f59e0b66}body.theme-light .detail-tag:nth-child(5n+4){color:#7c3aed;border-color:#8b5cf666}body.theme-light .detail-tag:nth-child(5n+5){color:#db2777;border-color:#ec489966}.mobile-detail-overlay{z-index:100;-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border-color);background:#0c1222d9;border-radius:24px 24px 0 0;max-height:75vh;padding:24px;animation:.4s cubic-bezier(.16,1,.3,1) slideUp;position:fixed;inset:auto 0 0;overflow-y:auto;box-shadow:0 -10px 40px #00000080}@media (min-width:768px){.mobile-detail-overlay{display:none}}.mobile-detail-header{justify-content:space-between;align-items:center;margin-bottom:24px;padding-top:8px;display:flex}.mobile-detail-close{border-radius:var(--radius-sm);color:var(--text-secondary);background:#ffffff0d;padding:8px}.globe-container{z-index:1;position:absolute;inset:0}.globe-container .maplibregl-map{width:100%;height:100%}.maplibregl-ctrl-attrib{color:var(--text-muted)!important;background:#0c1222b3!important;border-radius:4px!important;font-size:10px!important}@media (max-width:767px){.maplibregl-ctrl-attrib{display:none!important}}.maplibregl-ctrl-attrib a{color:var(--color-primary-dim)!important}.maplibregl-ctrl-group{background:var(--glass-bg)!important;border:1px solid var(--glass-border)!important;border-radius:var(--radius-sm)!important;box-shadow:0 4px 20px #0000004d!important}.maplibregl-ctrl-group button{border-color:var(--border-color)!important}.maplibregl-ctrl-group button+button{border-top:1px solid var(--border-color)!important}.maplibregl-ctrl-group button:hover{background:var(--bg-surface-hover)!important}.maplibregl-ctrl-group button .maplibregl-ctrl-icon{filter:invert(.8)}.project-marker{background:var(--color-primary);cursor:pointer;width:16px;height:16px;transition:all var(--transition-fast);border:2px solid #d4a57499;border-radius:50%;position:relative;box-shadow:0 0 12px #d4a5744d}.project-marker:hover{transform:scale(1.4);box-shadow:0 0 20px #d4a57480}.project-marker.active{background:var(--color-accent);border-color:#c75b3999;transform:scale(1.5);box-shadow:0 0 24px #c75b3980}.project-marker-pulse{background:var(--color-primary);pointer-events:none;border-radius:50%;width:100%;height:100%;animation:2s ease-out infinite marker-pulse;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.project-marker.active .project-marker-pulse{background:var(--color-accent)}.marker-label{white-space:nowrap;color:var(--text-primary);background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius-sm);border:1px solid var(--glass-border);pointer-events:none;opacity:0;transition:opacity var(--transition-fast);padding:4px 10px;font-size:11px;font-weight:600;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);box-shadow:0 4px 12px #0000004d}.project-marker:hover .marker-label,.project-marker.active .marker-label{opacity:1}.starfield{z-index:0;pointer-events:none;position:absolute;inset:0;overflow:hidden}.star{background:var(--text-primary);border-radius:50%;position:absolute}.interaction-hint{z-index:10;pointer-events:none;animation:fadeInUp 1s var(--ease-out) 1s both;display:none;position:absolute;bottom:32px;left:50%;transform:translate(-50%)}@media (min-width:768px){.interaction-hint{display:block}}.interaction-hint-inner{text-align:center;padding:12px 24px}.interaction-hint-text{color:var(--text-secondary);font-size:13px}.interaction-hint-text .highlight{color:var(--color-primary)}.loading-screen{z-index:200;background:var(--bg-primary);pointer-events:all;transition:opacity .6s var(--ease-out);position:fixed;inset:0}.loading-screen.fade-out{opacity:0;pointer-events:none}.loading-logo-wrapper{z-index:201;width:130px;height:130px;transition:opacity .6s var(--ease-out);justify-content:center;align-items:center;display:flex;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.loading-logo-wrapper.fade-away{opacity:0;pointer-events:none}.loading-logo{object-fit:contain;filter:drop-shadow(0 4px 16px #0006);pointer-events:none;-webkit-user-drag:none;-webkit-user-select:none;user-select:none;z-index:1;width:auto;height:80px;animation:2s ease-in-out infinite loading-logo-pulse;position:relative}@keyframes loading-logo-pulse{0%,to{filter:drop-shadow(0 4px 16px #0006)}50%{filter:drop-shadow(0 0 20px #d4a57480)}}.loading-spinner{border:2px solid #ffffff14;border-top-color:var(--color-primary);border-radius:50%;transition:opacity .25s;animation:1.4s linear infinite spin-slow;position:absolute;inset:0}.loading-spinner.fade-away{opacity:0}.loading-text{z-index:201;font-family:var(--font-display);color:var(--text-secondary);letter-spacing:2px;text-transform:uppercase;white-space:nowrap;font-size:14px;transition:opacity .25s;position:fixed;top:calc(50% + 82px);left:50%;transform:translate(-50%)}.loading-text.fade-away{opacity:0}.about-page{background:var(--bg-primary);gap:0;display:flex;position:absolute;inset:88px 0 0;overflow:hidden}.about-profile-col{width:380px;animation:slideInLeft .5s var(--ease-out);flex-shrink:0;align-items:flex-start;padding:24px;display:flex;overflow-y:auto}.about-profile-card{text-align:center;flex-direction:column;align-items:center;width:100%;padding:32px 24px;display:flex;position:sticky;top:0}.about-avatar{margin-bottom:20px;position:relative}.about-avatar-ring{background:conic-gradient(var(--color-primary) 0%, var(--color-secondary) 33%, var(--color-accent) 66%, var(--color-primary) 100%);border-radius:50%;width:130px;height:130px;padding:3px}.about-avatar-inner{background:var(--bg-surface);border-radius:50%;justify-content:center;align-items:center;width:100%;height:100%;display:flex;overflow:hidden}.about-avatar-inner img{object-fit:cover;width:100%;height:100%}.about-avatar-status{border:3px solid var(--bg-surface);background:#4ade80;border-radius:50%;width:16px;height:16px;position:absolute;bottom:6px;right:6px;box-shadow:0 0 8px #4ade8066}.about-name{font-family:var(--font-display);color:var(--text-primary);margin-bottom:8px;font-size:28px;font-weight:700;line-height:1.2}.about-tagline{letter-spacing:1.5px;text-transform:uppercase;color:var(--text-secondary);margin-bottom:20px;font-size:11px;font-weight:600;line-height:1.6}.about-social{gap:10px;margin-bottom:24px;display:flex}.about-social-link{border:1px solid var(--border-color);width:42px;height:42px;color:var(--text-secondary);transition:all var(--transition-fast);border-radius:50%;justify-content:center;align-items:center;display:flex}.about-social-link:hover{color:var(--color-primary);border-color:var(--color-primary);box-shadow:0 4px 12px var(--glow-primary);background:#d4a57414;transform:translateY(-2px)}.about-info-list{border-radius:var(--radius-md);border:1px solid var(--border-color);background:#0003;flex-direction:column;gap:10px;width:100%;margin-bottom:24px;padding:16px;display:flex}.about-info-item{color:var(--text-secondary);align-items:center;gap:10px;font-size:13px;display:flex}.about-info-item svg{color:var(--color-primary);flex-shrink:0}.about-cta-group{flex-direction:column;gap:8px;width:100%;display:flex}.about-btn-primary{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--color-primary), var(--color-accent));color:var(--bg-primary);letter-spacing:1px;transition:all var(--transition-fast);justify-content:center;align-items:center;gap:8px;padding:12px 20px;font-size:13px;font-weight:700;display:flex}.about-btn-primary:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 6px 20px #d4a5744d}.about-btn-secondary{border-radius:var(--radius-md);border:1px solid var(--border-color);color:var(--text-secondary);letter-spacing:1px;transition:all var(--transition-fast);background:#ffffff0a;justify-content:center;align-items:center;gap:8px;padding:12px 20px;font-size:13px;font-weight:700;display:flex}.about-btn-secondary:hover{border-color:var(--border-color-strong);color:var(--text-primary);background:#ffffff0f}.about-content-col{animation:fadeInUp .5s var(--ease-out);flex:1;padding:24px 32px;overflow-y:auto}.about-section{margin-bottom:48px}.about-section-header{align-items:center;gap:12px;margin-bottom:20px;display:flex}.about-section-header svg{color:var(--color-primary)}.about-section-title{font-family:var(--font-display);color:var(--text-primary);white-space:nowrap;font-size:26px;font-weight:700}.about-section-line{background:linear-gradient(90deg, var(--color-primary), transparent);flex:1;height:1px}.about-terminal{overflow:hidden}.about-terminal-header{border-bottom:1px solid var(--border-color);background:#0000004d;align-items:center;gap:12px;padding:12px 16px;display:flex}.about-terminal-dots{gap:6px;display:flex}.about-terminal-dots span{border-radius:50%;width:10px;height:10px}.about-terminal-title{font-family:var(--font-mono);color:var(--text-muted);font-size:12px}.about-terminal-body{padding:20px 24px}.about-terminal-prompt{font-family:var(--font-mono);align-items:center;gap:8px;margin-bottom:16px;font-size:13px;display:flex}.prompt-symbol{color:var(--color-primary);font-weight:700}.prompt-cmd{color:var(--color-secondary)}.about-terminal-text{color:var(--text-secondary);margin-bottom:16px;font-size:14px;line-height:1.8}.about-terminal-text:last-child{margin-bottom:0}.about-tech-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;display:grid}.about-tech-card{transition:all var(--transition-normal);padding:20px}.about-tech-card:hover{border-color:var(--border-color-strong);transform:translateY(-2px);box-shadow:0 8px 30px #0000004d}.about-tech-card-header{align-items:center;gap:10px;margin-bottom:16px;display:flex}.about-tech-icon{border-radius:var(--radius-sm);background:#ffffff0d;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.about-tech-category{font-family:var(--font-display);letter-spacing:.5px;color:var(--text-primary);font-size:14px;font-weight:700}.about-tech-tags{flex-wrap:wrap;gap:6px;display:flex}.about-tech-tag{color:var(--text-secondary);border:1px solid var(--border-color);transition:all var(--transition-fast);background:#ffffff05;border-radius:20px;padding:5px 12px;font-size:12px}.about-tech-tag:hover{color:var(--text-primary);background:#ffffff0f}.about-timeline{flex-direction:column;gap:0;display:flex}.about-timeline-item{gap:16px;display:flex;position:relative}.about-timeline-icon-wrap{flex-direction:column;flex-shrink:0;align-items:center;display:flex}.about-timeline-icon{background:var(--bg-surface);border:1px solid var(--border-color);width:44px;height:44px;color:var(--color-primary);z-index:1;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.about-timeline-connector{background:linear-gradient(180deg, var(--border-color-strong), var(--border-color));flex:1;width:2px;min-height:24px}.about-timeline-card{transition:all var(--transition-normal);flex:1;margin-bottom:16px;padding:20px}.about-timeline-card:hover{border-color:var(--border-color-strong);box-shadow:0 4px 20px #0003}.about-timeline-card-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px;display:flex}.about-timeline-title{font-family:var(--font-display);color:var(--text-primary);font-size:18px;font-weight:700}.about-timeline-company{color:var(--text-secondary);margin-top:2px;font-size:13px}.about-timeline-period{color:var(--color-primary);border:1px solid var(--border-color);white-space:nowrap;background:#d4a5741a;border-radius:20px;flex-shrink:0;padding:4px 12px;font-size:12px;font-weight:600}.about-timeline-desc{color:var(--text-secondary);font-size:13.5px;line-height:1.7}.about-edu-list{flex-direction:column;gap:12px;display:flex}.about-edu-card{transition:all var(--transition-normal);align-items:center;gap:16px;padding:20px;display:flex}.about-edu-card:hover{border-color:var(--border-color-strong);box-shadow:0 4px 20px #0003}.about-edu-icon{width:44px;height:44px;color:var(--color-secondary);background:#5b8a8f1a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.about-edu-info{flex:1}.about-edu-degree{font-family:var(--font-display);color:var(--text-primary);font-size:16px;font-weight:600}.about-edu-institution{color:var(--text-secondary);margin-top:2px;font-size:13px}.about-edu-year{color:var(--text-muted);border:1px solid var(--border-color);background:#ffffff0a;border-radius:20px;flex-shrink:0;padding:4px 12px;font-size:12px;font-weight:600}@media (max-width:768px){.about-page{flex-direction:column;overflow-y:auto}.about-profile-col{width:100%;padding:16px}.about-profile-card{position:static}.about-content-col{padding:16px;overflow:visible}.about-tech-grid{grid-template-columns:1fr}.about-section-title{font-size:22px}.about-timeline-card-header{flex-direction:column}}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.custom-marker{cursor:pointer;justify-content:center;align-items:center;width:40px;height:40px;display:flex;position:relative}.marker-diamond{z-index:2;background-color:#d4a574;width:12px;height:12px;transition:all .3s;position:relative;transform:rotate(45deg);box-shadow:0 0 10px 2px #d4a57499}.marker-ping{z-index:1;background-color:#d4a574;width:12px;height:12px;animation:2s cubic-bezier(0,0,.2,1) infinite ping-animation;position:absolute;transform:rotate(45deg)}@keyframes ping-animation{0%{opacity:.8;transform:rotate(45deg)scale(1)}75%,to{opacity:0;transform:rotate(45deg)scale(3)}}.custom-marker.selected .marker-diamond,.custom-marker:hover .marker-diamond{background-color:#c75b39;transform:rotate(45deg)scale(1.4);box-shadow:0 0 15px 4px #c75b39cc}.custom-marker.selected .marker-ping,.custom-marker:hover .marker-ping{background-color:#c75b39;animation:1.5s cubic-bezier(0,0,.2,1) infinite ping-animation}.detail-gallery{flex-direction:column;gap:.5rem;margin-top:1rem;margin-bottom:1.5rem;display:flex}.detail-gallery-main{aspect-ratio:16/9;background-color:#ffffff0d;border:1px solid #ffffff0d;border-radius:12px;width:100%;position:relative;overflow:hidden;box-shadow:0 8px 30px #0003}.gallery-image{object-fit:cover;opacity:0;pointer-events:none;-webkit-user-drag:none;user-drag:none;-webkit-user-select:none;user-select:none;width:100%;height:100%;transition:opacity .5s ease-in-out,transform .5s ease-in-out;position:absolute;inset:0;transform:scale(1.05)}.gallery-image.active{opacity:1;pointer-events:none;transform:scale(1)}.gallery-overlay{pointer-events:none;z-index:5;background:linear-gradient(#0000 60%,#0c1222cc 100%);position:absolute;inset:0}.gallery-protect{pointer-events:auto;cursor:default;-webkit-user-select:none;user-select:none}.gallery-arrow{-webkit-backdrop-filter:blur(8px);color:#fff;opacity:0;cursor:pointer;z-index:10;background:#ffffff1a;border:1px solid #fff3;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:absolute;top:50%;transform:translateY(-50%)}.detail-gallery-main:hover .gallery-arrow{opacity:1}.gallery-arrow:hover{color:#111827;background:#d4a574cc;border-color:#d4a574;transform:translateY(-50%)scale(1.1)}.gallery-prev{left:-20px}.detail-gallery-main:hover .gallery-prev{left:12px}.gallery-next{right:-20px}.detail-gallery-main:hover .gallery-next{right:12px}.gallery-arrow svg{width:18px;height:18px}.gallery-indicators{z-index:10;gap:8px;display:flex;position:absolute;bottom:12px;left:50%;transform:translate(-50%)}.gallery-dot{cursor:pointer;background:#ffffff4d;border-radius:2px;width:24px;height:4px;transition:all .3s}.gallery-dot:hover{background:#fff9}.gallery-dot.active{background:var(--color-primary);width:32px;box-shadow:0 0 8px var(--color-primary)}body.theme-light .detail-gallery-main{background-color:#0000000d}
