@import "https://api.fontshare.com/v2/css?f[]=clash-display@400,500,700&f[]=satoshi@300,400,500,700&display=swap";:root{--bg-color:#fbfbfe;--dot-color:#d1d1d6;--card-bg:#fff;--text-primary:#1d1d1f;--text-muted:#86868b;--stage-width:4000px;--stage-height:3000px;--shadow:0 10px 40px #0000000f;--border:1px solid #0000000d;--nav-bg:linear-gradient(to bottom, #fbfbfee6, transparent);--grid-reveal-color:#000}body.dark-mode{--bg-color:#0d0d14;--dot-color:#2a2a3a;--card-bg:#1a1a24;--text-primary:#fff;--text-muted:#888;--shadow:0 20px 40px #0006;--border:1px solid #ffffff1a;--nav-bg:linear-gradient(to bottom, #0d0d14e6, transparent);--grid-reveal-color:#fff}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-primary);overscroll-behavior:none;font-family:Satoshi,sans-serif;transition:background-color .4s,color .4s;overflow:hidden}#viewport{cursor:grab;-webkit-user-select:none;user-select:none;background-color:var(--bg-color);background-image:radial-gradient(circle, var(--dot-color) 1px, transparent 1px);background-size:28px 28px;width:100vw;height:100vh;transition:background-color .4s;position:relative;overflow:hidden}#grid-overlay{background-image:radial-gradient(circle, var(--grid-reveal-color) 1px, transparent 1px);pointer-events:none;-webkit-mask-image:radial-gradient(circle at var(--mouseX,50%) var(--mouseY,50%), black 0%, transparent 150px);mask-image:radial-gradient(circle at var(--mouseX,50%) var(--mouseY,50%), black 0%, transparent 150px);-webkit-mask-image:radial-gradient(circle at var(--mouseX,50%) var(--mouseY,50%), black 0%, transparent 150px);z-index:1;background-size:28px 28px;position:absolute;inset:0}#viewport.dragging{cursor:grabbing}#stage{width:var(--stage-width);height:var(--stage-height);transform-origin:0 0;will-change:transform;pointer-events:none;z-index:2;position:absolute}.card-container{pointer-events:auto;position:absolute}.card-label{letter-spacing:.1em;color:var(--text-muted);margin-bottom:8px;font-family:monospace;font-size:10px;font-weight:600;display:block}.card{background-color:var(--card-bg);width:300px;height:200px;box-shadow:var(--shadow);border:var(--border);border-radius:12px;justify-content:center;align-items:center;transition:background-color .4s,border .4s,box-shadow .4s;display:flex}#hero-container{white-space:nowrap;text-align:center;pointer-events:auto;flex-direction:column;align-items:center;width:auto;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.draggable-sticker-container{pointer-events:auto;z-index:10;cursor:grab;transition:transform .3s cubic-bezier(.34,1.56,.64,1);position:absolute;transform:translate(-50%,-50%)}.draggable-sticker-container:hover{transform:translate(-50%,-50%)scale(1.1)}.draggable-sticker-container:active{cursor:grabbing;transform:translate(-50%,-50%)scale(1.05)}.floating-sticker{object-fit:contain;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;width:350px;height:auto;animation:4s ease-in-out infinite float-bob}@keyframes float-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}.hero-sticker-wrapper{justify-content:center;align-items:center;width:250px;height:250px;margin-bottom:24px;display:flex;position:relative}.hero-sticker{object-fit:contain;width:100%;height:100%;transition:opacity .6s cubic-bezier(.4,0,.2,1);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.dark-only{opacity:0;pointer-events:none}.light-only,body.dark-mode .dark-only{opacity:1;pointer-events:auto}body.dark-mode .light-only{opacity:0;pointer-events:none}#hero-title{letter-spacing:-.04em;color:var(--text-primary);margin:0;font-family:Clash Display,sans-serif;font-size:4.5rem;font-weight:400;line-height:1}#hero-subtitle{text-transform:uppercase;letter-spacing:.15em;color:var(--text-muted);opacity:.8;margin-top:24px;font-size:1.1rem;font-weight:500}#navbar{z-index:1000;pointer-events:auto;background:0 0;justify-content:flex-end;align-items:center;width:100%;padding:24px 40px;display:flex;position:fixed;top:0;left:0}.switch{width:60px;height:34px;margin-right:20px;display:inline-block;position:relative}.switch #theme-checkbox{opacity:0;width:0;height:0}.slider{cursor:pointer;z-index:0;background-color:#2196f3;transition:all .4s;position:absolute;inset:0;overflow:hidden}.sun-moon{content:"";background-color:#ff0;width:26px;height:26px;transition:all .4s;position:absolute;bottom:4px;left:4px}#theme-checkbox:checked+.slider{background-color:#000}#theme-checkbox:focus+.slider{box-shadow:0 0 1px #2196f3}#theme-checkbox:checked+.slider .sun-moon{background-color:#fff;animation:.6s ease-in-out both rotate-center;transform:translate(26px)}.moon-dot{opacity:0;fill:gray;transition:all .4s}#theme-checkbox:checked+.slider .sun-moon .moon-dot{opacity:1}.slider.round{border-radius:34px}.slider.round .sun-moon{border-radius:50%}#moon-dot-1{z-index:4;width:6px;height:6px;position:absolute;top:3px;left:10px}#moon-dot-2{z-index:4;width:10px;height:10px;position:absolute;top:10px;left:2px}#moon-dot-3{z-index:4;width:3px;height:3px;position:absolute;top:18px;left:16px}#light-ray-1{z-index:-1;fill:#fff;opacity:.1;width:43px;height:43px;position:absolute;top:-8px;left:-8px}#light-ray-2{z-index:-1;fill:#fff;opacity:.1;width:55px;height:55px;position:absolute;top:-50%;left:-50%}#light-ray-3{z-index:-1;fill:#fff;opacity:.1;width:60px;height:60px;position:absolute;top:-18px;left:-18px}.cloud-light{fill:#eee;animation-name:cloud-move;animation-duration:6s;animation-iteration-count:infinite;position:absolute}.cloud-dark{fill:#ccc;animation-name:cloud-move;animation-duration:6s;animation-iteration-count:infinite;animation-delay:1s;position:absolute}#cloud-1{width:40px;top:15px;left:30px}#cloud-2{width:20px;top:10px;left:44px}#cloud-3{width:30px;top:24px;left:18px}#cloud-4{width:40px;top:18px;left:36px}#cloud-5{width:20px;top:14px;left:48px}#cloud-6{width:30px;top:26px;left:22px}@keyframes cloud-move{0%{transform:translate(0)}40%{transform:translate(4px)}80%{transform:translate(-4px)}to{transform:translate(0)}}.stars{opacity:0;transition:all .4s;transform:translateY(-32px)}.star{fill:#fff;transition:all .4s;animation-name:star-twinkle;animation-duration:2s;animation-iteration-count:infinite;position:absolute}#theme-checkbox:checked+.slider .stars{opacity:1;transform:translateY(0)}#star-1{width:20px;animation-delay:.3s;top:2px;left:3px}#star-2{width:6px;top:16px;left:3px}#star-3{width:12px;animation-delay:.6s;top:20px;left:10px}#star-4{width:18px;animation-delay:1.3s;top:0;left:18px}@keyframes star-twinkle{0%{transform:scale(1)}40%{transform:scale(1.2)}80%{transform:scale(.8)}to{transform:scale(1)}}@keyframes rotate-center{0%{transform:translate(26px)rotate(0)}to{transform:translate(26px)rotate(360deg)}}.nav-right{align-items:center;display:flex}.nav-right a{color:var(--text-primary);opacity:.6;margin-left:32px;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .2s}.nav-right a:hover{opacity:1}#hint{color:var(--text-primary);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);pointer-events:none;z-index:999;background:#0000000d;border:1px solid #0000000d;border-radius:100px;padding:10px 20px;font-size:.9rem;font-weight:500;transition:all 1s;position:fixed;bottom:40px;left:50%;transform:translate(-50%)}body.dark-mode #hint{background:#ffffff1a;border-color:#ffffff1a}#hint.fade-out{opacity:0;visibility:hidden}#recenter-btn{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:var(--border);width:48px;height:48px;color:var(--text-primary);cursor:pointer;z-index:1000;pointer-events:auto;background:#ffffff1a;border-radius:12px;justify-content:center;align-items:center;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;bottom:40px;left:40px;box-shadow:0 4px 20px #0000000a}body.dark-mode #recenter-btn{background:#ffffff0d}#recenter-btn:hover{background:#fff3;transform:scale(1.05);box-shadow:0 8px 32px #00000014}#recenter-btn:active{transform:scale(.95)}#stage.smooth-reset{transition:transform .8s cubic-bezier(.19,1,.22,1)}#floating-menu{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:var(--border);z-index:1000;background:#ffffff1a;border-radius:16px;flex-direction:column;gap:12px;padding:12px;transition:all .4s;display:flex;position:fixed;top:50%;left:40px;transform:translateY(-50%);box-shadow:0 8px 32px #0000000d}body.dark-mode #floating-menu{background:#ffffff0d}#floating-menu a{width:44px;height:44px;color:var(--text-primary);opacity:.6;border-radius:12px;justify-content:center;align-items:center;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}#floating-menu a:hover{opacity:1;background:#0000000d;transform:translate(4px)}body.dark-mode #floating-menu a:hover{background:#ffffff1a}@media (width<=480px){#floating-menu,.nav-right a{display:none}#navbar{padding:16px 20px}.nav-right{justify-content:flex-end;width:100%}.switch{margin-right:0}#hero-title{font-size:2.5rem}.hero-sticker-wrapper{width:160px;height:160px;margin-bottom:16px}.floating-sticker{width:220px}#hero-subtitle{margin-top:16px;font-size:.8rem}#recenter-btn{width:44px;height:44px;bottom:24px;left:24px}#hint{padding:8px 16px;font-size:.8rem;bottom:24px}}.social-card{background:var(--card-bg);border:var(--border);width:180px;height:180px;box-shadow:var(--shadow);border-radius:24px;transition:all .6s cubic-bezier(.23,1,.32,1);position:relative;overflow:hidden}.social-background{background:linear-gradient(135deg,#9cb8ec1a 0%,#ff89cc0d 50%,#62c2fe1a 100%);transition:opacity .4s;position:absolute;inset:0}.social-logo{z-index:10;transition:all .5s cubic-bezier(.23,1,.32,1);position:absolute;bottom:50%;right:50%;transform:translate(50%,50%)}.social-logo .social-logo-img{opacity:.95;object-fit:contain;width:82px;height:auto}.social-box a{color:inherit;justify-content:center;align-items:center;width:100%;height:100%;text-decoration:none;display:flex}.social-icon{width:22px;height:22px;display:inline-block}.social-icon .social-svg{fill:var(--text-color);opacity:.6;width:100%;transition:all .4s}.social-box{text-align:right;background:var(--card-bg);border:var(--border);transform-origin:0 100%;border-radius:12px 12px 32px 0;padding:12px;transition:all .6s cubic-bezier(.23,1,.32,1);position:absolute;box-shadow:0 4px 15px #00000008}.social-box:hover .social-svg{fill:#fff;opacity:1}.social-box1{width:70%;height:70%;bottom:-70%;left:-70%}.social-box1:hover{border-color:#ea4335;background:#ea4335!important}.social-box2{width:50%;height:50%;transition-delay:.1s;bottom:-50%;left:-50%}.social-box2:hover{border-color:#0077b5;background:#0077b5!important}.social-box3{width:32%;height:32%;transition-delay:.2s;bottom:-32%;left:-32%}.social-box3:hover{border-color:#333;background:#333!important}.social-box4{background:var(--text-color);opacity:.1;width:15%;height:15%;transition-delay:.3s;bottom:-15%;left:-15%}.social-card:hover{transform:scale(1.05)translateY(-5px);box-shadow:0 20px 50px #0000001a}.social-card:hover .social-box{bottom:-1px;left:-1px}.social-card:hover .social-logo{opacity:1;top:16px;bottom:auto;right:16px;transform:translate(0)}[data-theme=dark] .social-box1:hover{background:#ff5c5c!important}[data-theme=dark] .social-box2:hover{background:#00a0dc!important}[data-theme=dark] .social-box3:hover{background:#444!important}.chat-card{-webkit-backdrop-filter:blur(25px);background:#ffffff05;border:1px solid #ffffff0d;border-radius:20px;flex-direction:column;justify-content:flex-end;width:460px;height:260px;padding:30px;transition:all .4s;display:flex;position:relative;overflow:hidden;box-shadow:0 30px 80px #00000026}body.dark-mode .chat-card{background:#00000026}.chat-character{z-index:5;pointer-events:none;filter:drop-shadow(0 10px 20px #0000001a);width:250px;animation:5s ease-in-out infinite floatingChar;position:absolute;bottom:0;left:0}@keyframes floatingChar{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.chat-bubble{color:#1a1a24;scrollbar-width:thin;scrollbar-color:#00000026 transparent;z-index:10;opacity:1;transform-origin:0 100%;background:#fff;border-radius:24px 24px 24px 4px;max-width:260px;max-height:140px;padding:20px 25px;font-family:Satoshi,sans-serif;font-size:1.1rem;font-weight:500;line-height:1.5;transition:transform .4s cubic-bezier(.175,.885,.32,1.275),opacity .4s;position:absolute;top:30px;left:170px;overflow-y:auto;box-shadow:0 15px 40px #00000014}.chat-bubble::-webkit-scrollbar{width:4px}.chat-bubble::-webkit-scrollbar-track{background:0 0}.chat-bubble::-webkit-scrollbar-thumb{background-color:#00000026;border-radius:4px}body.dark-mode .chat-bubble{color:#fff;scrollbar-color:#ffffff26 transparent;background:#1a1a24;border:1px solid #ffffff1a}body.dark-mode .chat-bubble::-webkit-scrollbar-thumb{background-color:#ffffff26}.chat-paragraph{margin:0 0 10px}.chat-paragraph:last-child{margin-bottom:0}.chat-list{margin:0 0 10px 20px;padding:0;list-style-type:disc}.chat-list li{margin-bottom:4px}.chat-list li:last-child{margin-bottom:0}.chat-spacer{height:10px}.inline-code{background:#0000000d;border-radius:4px;padding:2px 4px;font-family:monospace;font-size:.9em}body.dark-mode .inline-code{background:#ffffff26}.chat-input-container{z-index:20;width:65%;margin-left:auto;position:relative}.chat-input-field{color:#1a1a24;background:#fffffff2;border:none;border-radius:50px;outline:none;width:100%;height:44px;padding:0 20px;font-family:Satoshi,sans-serif;font-size:.95rem;box-shadow:0 5px 15px #00000008}body.dark-mode .chat-input-field{color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff14}.chat-input-field::placeholder{color:#0000004d}body.dark-mode .chat-input-field::placeholder{color:#ffffff4d}.chat-dot{opacity:0;background:#007bff;border-radius:50%;width:6px;height:6px;position:absolute;top:50%;right:15px;transform:translateY(-50%)}.typing .chat-dot{opacity:1;animation:1s infinite alternate pulseDot}@keyframes pulseDot{0%{opacity:.2}to{opacity:1}}@media (width<=768px){.chat-card{width:340px;height:240px;padding:20px}.chat-character{width:180px}.chat-bubble{max-width:220px;max-height:115px;font-size:.95rem;top:25px;left:100px}.chat-input-container{width:100%}}.bankai-active{text-shadow:0 0 10px #ff3c0066;animation:1.5s infinite alternate fire-flicker;color:#ff3c00!important;font-weight:800!important}@keyframes fire-flicker{0%{filter:brightness();transform:scale(1)}to{filter:brightness(1.2);transform:scale(1.02)}}.container{justify-content:center;align-items:center;display:flex;position:relative}.container .glass{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:180px;height:200px;transform:rotate(calc(var(--r) * 1deg));cursor:pointer;background:linear-gradient(#fff2,#0000);border:1px solid #ffffff1a;border-radius:10px;justify-content:center;align-items:center;margin:0 -45px;transition:all .5s;display:flex;position:relative;box-shadow:0 25px 25px #00000040}.container:hover .glass{margin:0 10px;transform:rotate(0)}.container .glass:before{content:attr(data-text);width:100%;height:40px;color:var(--text-primary);letter-spacing:.2em;background:#0000000d;justify-content:center;align-items:center;font-size:.75rem;font-weight:500;display:flex;position:absolute;bottom:0}body.dark-mode .container .glass:before{background:#ffffff0d}.container .glass svg{width:44px;height:44px;stroke:var(--text-primary);fill:none}.hero-character-wrapper{transition:transform .4s cubic-bezier(.34,1.56,.64,1)}.hero-character-wrapper:hover{transform:scale(1.05)}.hero-character-wrapper:active{transform:scale(.98)}.box{z-index:1;justify-content:center;align-items:center;width:220px;height:300px;transition:all .5s;display:flex;position:relative}.box:before{content:" ";background:#fff;border-radius:8px;width:50%;height:100%;text-decoration:none;transition:all .5s;position:absolute;top:0;left:50px;transform:skew(15deg)}.box:after{content:"";filter:blur(15px);opacity:.6;background:#fff;border-radius:8px;width:50%;height:100%;transition:all .5s;position:absolute;top:0;left:50px;transform:skew(15deg)}.box:hover:before,.box:hover:after{transform:skew(0)scaleX(1.3)}.box:before,.box:after{background:linear-gradient(315deg,#ffbc00,#ff0058)}.box span{z-index:5;pointer-events:none;display:block;position:absolute;inset:0}.box span:before{content:"";-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);opacity:.8;background:#ffffff0d;border-radius:8px;width:50px;height:50px;transition:all .1s;animation:2s ease-in-out infinite animate;position:absolute;top:-40px;left:40px;box-shadow:0 5px 15px #0000000d}.box span:after{content:"";-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);opacity:.8;background:#ffffff0d;border-radius:8px;width:50px;height:50px;transition:all .5s;animation:2s ease-in-out -1s infinite animate;position:absolute;bottom:-40px;right:40px;box-shadow:0 5px 15px #0000000d}.box .content{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1;color:#fff;text-align:center;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;width:190px;height:254px;padding:20px 40px;transition:all .5s;display:flex;position:relative;box-shadow:0 5px 15px #0000001a}.box .content h2{color:#fff;margin:0;font-size:20px}@keyframes animate{0%,to{transform:translateY(10px)}50%{transform:translateY(-10px)}}.hero-sticker-wrapper{cursor:pointer}.modal-overlay{-webkit-backdrop-filter:blur(20px);z-index:2000;opacity:0;visibility:hidden;background:#0006;justify-content:center;align-items:center;transition:opacity .3s,visibility .3s;display:flex;position:fixed;inset:0}.modal-overlay.active{opacity:1;visibility:visible}.modal-content{background:var(--card-bg);border:var(--border);border-radius:40px;width:90%;max-width:600px;height:600px;position:relative;overflow:hidden;box-shadow:0 40px 100px #0003}.close-modal{width:44px;height:44px;color:var(--text-primary);cursor:pointer;z-index:10;background:#0000000d;border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .3s;display:flex;position:absolute;top:24px;right:24px}body.dark-mode .close-modal{background:#ffffff1a}.close-modal:hover{color:#fff;background:#ff5c5c;transform:rotate(90deg)}.modal-content iframe{background:0 0;border:none;width:100%;height:100%}@media (width<=480px){.modal-content{border-radius:32px;height:80vh}}.intro-container{text-align:center;width:100%;height:100%;color:var(--text-primary);justify-content:center;align-items:center;padding:20px;font-family:Satoshi,sans-serif;display:flex}.intro-content{background:var(--card-bg);border:var(--border);max-width:540px;box-shadow:var(--shadow);border-radius:40px;padding:48px;animation:.8s cubic-bezier(.23,1,.32,1) slide-up;position:relative;overflow:hidden}.intro-content:before{content:"";pointer-events:none;background:radial-gradient(circle,#9cb8ec0d 0%,#0000 70%);width:200%;height:200%;position:absolute;top:-50%;left:-50%}.intro-title{letter-spacing:-.02em;margin-bottom:24px;font-family:Clash Display,sans-serif;font-size:2.8rem;line-height:1.1}.intro-text{color:var(--text-muted);margin-bottom:24px;font-size:1.15rem;font-weight:400;line-height:1.7}.highlight{color:var(--text-primary);font-weight:700;display:inline-block;position:relative}.highlight:after{content:"";z-index:-1;background:#ffbc0033;border-radius:4px;width:100%;height:8px;position:absolute;bottom:2px;left:0}@keyframes slide-up{0%{opacity:0;transform:translateY(60px)}to{opacity:1;transform:translateY(0)}}@media (width<=480px){.intro-title{font-size:2.2rem}.intro-text{font-size:1.05rem}.intro-content{border-radius:32px;padding:32px}}.hub-container{width:100%;max-width:1000px;color:var(--text-primary);flex-direction:column;align-items:center;min-height:100%;margin:auto;padding:80px 20px 40px;font-family:Satoshi,sans-serif;display:flex;overflow-x:hidden}.hub-header{text-align:center;margin-bottom:60px}.hub-title{letter-spacing:-.03em;margin-bottom:12px;font-family:Clash Display,sans-serif;font-size:3.5rem;font-weight:600}.hub-subtitle{color:var(--text-muted);opacity:.7;font-size:1.2rem}.section-grid{justify-content:center;gap:24px;width:100%;padding:20px 0;display:flex}.project-link{flex:1;min-height:320px;text-decoration:none;display:flex}.project-section{background:var(--card-bg);border:var(--border);text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:32px;flex-direction:column;align-items:center;width:100%;padding:40px 30px;transition:all .5s cubic-bezier(.23,1,.32,1);display:flex;position:relative;overflow:hidden;box-shadow:0 10px 30px #0000000a}.project-section:hover{background:#ffffff0d;border-color:#9cb8ec80;transform:translateY(-10px);box-shadow:0 30px 60px #0000001f}.section-title{color:var(--text-primary);margin-bottom:16px;font-family:Clash Display,sans-serif;font-size:1.6rem;font-weight:600}.section-desc{color:var(--text-muted);flex-grow:1;margin-bottom:30px;font-size:1rem;line-height:1.6}.cta-btn{background:var(--text-primary);color:var(--card-bg);border-radius:100px;padding:10px 24px;font-size:.85rem;font-weight:600;transition:all .3s}body.dark-mode .cta-btn{color:#000;background:#fff}.project-section:hover .cta-btn{color:#fff;background:#0077b5;transform:scale(1.05)}@media (width<=768px){.section-grid{flex-direction:column;align-items:center}.project-link{width:100%;min-height:auto}}.stack-card-modern{background:var(--card-bg);border:var(--border);width:260px;box-shadow:var(--shadow);border-radius:24px;padding:24px;transition:all .5s cubic-bezier(.23,1,.32,1);position:relative;overflow:hidden}.stack-card-modern:before{content:"";pointer-events:none;background:radial-gradient(circle,#ffbc000a 0%,#0000 70%);width:180%;height:180%;position:absolute;top:-40%;left:-40%}.stack-card-modern:hover{transform:translateY(-5px);box-shadow:0 20px 60px #0000001a}.stack-card-header{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.stack-card-title{color:var(--text-primary);margin:0;font-family:Clash Display,sans-serif;font-size:1.3rem;font-weight:600}.stack-card-count{color:var(--text-muted);letter-spacing:.05em;background:#0000000a;border-radius:100px;padding:4px 10px;font-size:.7rem;font-weight:600}body.dark-mode .stack-card-count{background:#ffffff14}.stack-icon-grid{flex-wrap:wrap;gap:6px;display:flex}.stack-icon-pill{background:var(--tech-bg);color:var(--tech-color);cursor:default;border:1px solid #0000;border-radius:20px;align-items:center;gap:5px;padding:5px 10px;font-size:.65rem;font-weight:600;transition:all .3s cubic-bezier(.23,1,.32,1);animation:.5s cubic-bezier(.23,1,.32,1) both stackPillIn;display:flex}.stack-icon-pill:hover{border-color:var(--tech-color);transform:translateY(-2px)scale(1.05);box-shadow:0 4px 15px #00000014}@keyframes stackPillIn{0%{opacity:0;transform:translateY(8px)scale(.9)}to{opacity:1;transform:translateY(0)scale(1)}}.stack-icon-svg{flex-shrink:0;align-items:center;width:14px;height:14px;display:flex}.stack-icon-svg svg{width:100%;height:100%}.stack-icon-name{white-space:nowrap;letter-spacing:.02em}.projects-content{width:100%;height:100%;color:var(--text-primary);flex-direction:column;padding:40px 30px 20px;font-family:Satoshi,sans-serif;display:flex;overflow:hidden auto}.projects-header{text-align:center;flex-shrink:0;margin-bottom:24px}.projects-header-badge{color:var(--text-muted);letter-spacing:.05em;background:#0000000a;border-radius:100px;align-items:center;gap:8px;margin-bottom:16px;padding:6px 16px;font-size:.75rem;font-weight:600;display:inline-flex}body.dark-mode .projects-header-badge{background:#ffffff14}.projects-badge-dot{background:#10b981;border-radius:50%;width:6px;height:6px;animation:2s infinite pulseDot}.projects-title{letter-spacing:-.03em;margin-bottom:8px;font-family:Clash Display,sans-serif;font-size:2.4rem;font-weight:600}.projects-subtitle{color:var(--text-muted);opacity:.7;font-size:1rem}.bubble-category-filter{flex-wrap:wrap;flex-shrink:0;justify-content:center;gap:8px;margin-bottom:24px;padding:0 10px;display:flex}.bubble-filter-pill{color:var(--text-muted);cursor:pointer;background:#00000008;border:1px solid #0000;border-radius:100px;align-items:center;gap:5px;padding:6px 14px;font-family:Satoshi,sans-serif;font-size:.72rem;font-weight:600;transition:all .3s;display:inline-flex}body.dark-mode .bubble-filter-pill{background:#ffffff0f}.bubble-filter-pill:hover{color:var(--text-primary);background:#0000000f}body.dark-mode .bubble-filter-pill:hover{background:#ffffff1f}.bubble-filter-pill.active{background:var(--text-primary);color:var(--card-bg);border-color:var(--text-primary)}body.dark-mode .bubble-filter-pill.active{color:#000;background:#fff}.bubble-filter-icon{font-size:.85rem}.bubble-filter-count{opacity:.6;margin-left:2px;font-size:.6rem}.bubble-grid-wrapper{flex:1;min-height:450px;position:relative}.bubble-grid{cursor:default;width:100%;min-height:450px;position:relative}.project-bubble{background:var(--bubble-gradient);cursor:pointer;will-change:transform;border:2px solid #ffffff26;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;transition:box-shadow .25s,border-color .25s;animation:.5s cubic-bezier(.23,1,.32,1) both bubbleAppear;display:flex;position:absolute;box-shadow:0 8px 25px #00000026}@keyframes bubbleAppear{0%{opacity:0;transform:translate(-50%,-50%)scale(0)}to{opacity:1}}.project-bubble:hover{border-color:#fff6;box-shadow:0 12px 40px #00000040}.project-bubble.near .bubble-label{opacity:1;visibility:visible;transform:translate(-50%)translateY(0)}.project-bubble.selected{box-shadow:0 0 0 3px var(--bubble-color), 0 12px 40px #0000004d;border-color:#fff}.bubble-inner{flex-direction:column;align-items:center;gap:4px;display:flex}.bubble-category-icon{filter:drop-shadow(0 2px 4px #0003);font-size:1.4rem}.bubble-tech-dots{gap:3px;display:flex}.bubble-tech-dot{border:1px solid #ffffff4d;border-radius:50%;width:5px;height:5px}.bubble-label{background:var(--card-bg);border:var(--border);text-align:center;white-space:nowrap;opacity:0;visibility:hidden;pointer-events:none;z-index:100;border-radius:12px;padding:6px 12px;transition:all .3s cubic-bezier(.23,1,.32,1);position:absolute;bottom:-44px;left:50%;transform:translate(-50%)translateY(6px);box-shadow:0 8px 25px #0000001a}.bubble-name{color:var(--text-primary);margin-bottom:1px;font-size:.72rem;font-weight:700;display:block}.bubble-cat-tag{color:var(--text-muted);font-size:.6rem;display:block}.project-detail-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:200;background:#0000004d;border-radius:40px;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:absolute;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.project-detail-card{background:var(--card-bg);border:var(--border);border-radius:24px;width:340px;animation:.35s cubic-bezier(.23,1,.32,1) cardSlideUp;position:relative;overflow:hidden;box-shadow:0 30px 80px #0003}@keyframes cardSlideUp{0%{opacity:0;transform:translateY(30px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.project-detail-close{cursor:pointer;color:#fff;z-index:10;background:#fff3;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex;position:absolute;top:12px;right:12px}.project-detail-close:hover{background:#fff6;transform:rotate(90deg)}.project-detail-header{color:#fff;align-items:center;gap:10px;padding:28px 24px 20px;display:flex}.project-detail-icon{font-size:1.6rem}.project-detail-category{letter-spacing:.05em;opacity:.9;font-size:.8rem;font-weight:600}.project-detail-body{padding:24px}.project-detail-name{color:var(--text-primary);margin-bottom:8px;font-family:Clash Display,sans-serif;font-size:1.4rem;font-weight:600}.project-detail-desc{color:var(--text-muted);margin-bottom:16px;font-size:.9rem;line-height:1.6}.project-detail-stack{flex-wrap:wrap;gap:6px;margin-bottom:20px;display:flex}.tech-pill{background:var(--pill-bg);color:var(--pill-color);letter-spacing:.02em;border:1px solid #0000000a;border-radius:100px;align-items:center;padding:4px 12px;font-size:.7rem;font-weight:600;display:inline-flex}body.dark-mode .tech-pill{border-color:#ffffff0f}.project-detail-link{background:var(--text-primary);color:var(--card-bg);border-radius:100px;align-items:center;gap:8px;padding:10px 20px;font-size:.8rem;font-weight:600;text-decoration:none;transition:all .3s;display:inline-flex}body.dark-mode .project-detail-link{color:#000;background:#fff}.project-detail-link:hover{transform:translateY(-2px);box-shadow:0 8px 25px #00000026}.mobile-project-grid{flex-direction:column;gap:12px;padding-bottom:20px;display:flex}.mobile-project-card{background:var(--card-bg);border:var(--border);color:inherit;border-radius:18px;align-items:stretch;text-decoration:none;transition:all .4s cubic-bezier(.23,1,.32,1);animation:.5s cubic-bezier(.23,1,.32,1) both mobileCardIn;display:flex;overflow:hidden;box-shadow:0 4px 15px #0000000a}@keyframes mobileCardIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.mobile-project-card:hover{transform:translateY(-3px);box-shadow:0 12px 40px #0000001a}.mobile-card-top{flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:6px;width:56px;min-height:100%;padding:12px 8px;display:flex}.mobile-card-icon{font-size:1.2rem}.mobile-card-category{color:#fffc;writing-mode:vertical-rl;text-orientation:mixed;letter-spacing:.1em;font-size:.5rem;font-weight:600}.mobile-card-body{flex:1;min-width:0;padding:14px 16px}.mobile-card-title{color:var(--text-primary);margin-bottom:4px;font-family:Clash Display,sans-serif;font-size:.95rem;font-weight:600}.mobile-card-desc{color:var(--text-muted);-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;margin-bottom:8px;font-size:.75rem;line-height:1.5;display:-webkit-box;overflow:hidden}.mobile-card-stack{flex-wrap:wrap;gap:4px;display:flex}.tech-pill-sm{color:var(--pill-color);letter-spacing:.02em;background:#00000008;border-radius:100px;padding:2px 8px;font-size:.6rem;font-weight:600}body.dark-mode .tech-pill-sm{background:#ffffff0f}.mobile-card-arrow{color:var(--text-muted);opacity:.4;flex-shrink:0;align-items:center;padding:0 16px;font-size:1.1rem;display:flex}.projects-footer{text-align:center;color:var(--text-muted);opacity:.6;flex-shrink:0;padding:20px 0 10px;font-size:.75rem}.projects-footer a{color:var(--text-primary);font-weight:600;text-decoration:none}.projects-footer a:hover{text-decoration:underline}.chat-history-mini{z-index:8;pointer-events:none;flex-direction:column;gap:2px;max-width:260px;display:flex;position:absolute;top:5px;left:170px}.chat-mini-msg{opacity:.4;white-space:nowrap;text-overflow:ellipsis;border-radius:8px;max-width:200px;padding:2px 8px;font-size:.55rem;overflow:hidden}.chat-mini-msg.user{color:var(--text-muted);text-align:right;margin-left:auto}.chat-mini-msg.ai{color:var(--text-muted)}.chat-typing-indicator{align-items:center;gap:3px;display:flex;position:absolute;top:50%;right:40px;transform:translateY(-50%)}.chat-typing-indicator span{background:var(--text-muted);border-radius:50%;width:4px;height:4px;animation:1.2s infinite typingBounce}.chat-typing-indicator span:nth-child(2){animation-delay:.2s}.chat-typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,80%,to{opacity:.3;transform:scale(.6)}40%{opacity:1;transform:scale(1)}}.gemini-badge{color:var(--text-muted);opacity:.4;z-index:25;align-items:center;gap:4px;font-size:.55rem;transition:opacity .3s;display:flex;position:absolute;bottom:8px;right:12px}.gemini-badge:hover{opacity:.8}.gemini-badge svg{opacity:.5}@media (width<=768px){.chat-history-mini{display:none}.gemini-badge{font-size:.5rem;bottom:6px;right:8px}}.education-content{width:100%;height:100%;color:var(--text-primary);flex-direction:column;padding:40px 30px 20px;font-family:Satoshi,sans-serif;display:flex;overflow:hidden auto}.education-header{text-align:center;flex-shrink:0;margin-bottom:30px}.education-header-badge{color:var(--text-muted);letter-spacing:.05em;background:#0000000a;border-radius:100px;align-items:center;gap:8px;margin-bottom:16px;padding:6px 16px;font-size:.75rem;font-weight:600;display:inline-flex}body.dark-mode .education-header-badge{background:#ffffff14}.education-badge-dot{background:#007bff;border-radius:50%;width:6px;height:6px;animation:2s infinite pulseDot}body.dark-mode .education-badge-dot{background:#62c2fe}.education-title{letter-spacing:-.03em;margin-bottom:8px;font-family:Clash Display,sans-serif;font-size:2.4rem;font-weight:600}.education-subtitle{color:var(--text-muted);max-width:500px;margin:0 auto;font-size:1rem;line-height:1.5}.timeline-container{justify-content:center;align-items:stretch;gap:40px;width:100%;max-width:1100px;margin:30px auto 0;padding:20px 0;display:flex;position:relative}.timeline-connecting-line{z-index:1;background:linear-gradient(90deg,#007bff1a 0%,#62c2fe80 50%,#007bff1a 100%) 0 0/200% 100%;height:3px;animation:4s linear infinite moveGradient;position:absolute;top:45px;left:25%;right:25%}.timeline-node{z-index:2;opacity:0;flex-direction:column;flex:1;align-items:center;max-width:500px;animation:.8s cubic-bezier(.23,1,.32,1) forwards nodeFadeIn;display:flex;position:relative;transform:translateY(30px)}.timeline-dot{background:var(--card-bg);border:2px solid var(--border-color,#0000001a);width:50px;height:50px;box-shadow:var(--shadow);z-index:5;border-radius:50%;justify-content:center;align-items:center;margin-bottom:24px;font-size:1.4rem;transition:all .3s cubic-bezier(.23,1,.32,1);display:flex}.timeline-node:hover .timeline-dot{border-color:#007bff;transform:scale(1.15)rotate(15deg);box-shadow:0 8px 24px #007bff33}body.dark-mode .timeline-node:hover .timeline-dot{border-color:#62c2fe;box-shadow:0 8px 24px #62c2fe4d}.timeline-card{background:var(--card-gradient);border:var(--border);width:100%;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(20px);text-align:left;border-radius:24px;flex-direction:column;gap:16px;padding:26px;transition:all .4s cubic-bezier(.23,1,.32,1);display:flex}.timeline-node:hover .timeline-card{border-color:#62c2fe4d;transform:translateY(-6px);box-shadow:0 20px 45px #00000014}.timeline-card-header{border-bottom:1px solid #0000000d;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;padding-bottom:12px;display:flex}body.dark-mode .timeline-card-header{border-bottom-color:#ffffff0f}.timeline-badge{color:#007bff;letter-spacing:.02em;background:#007bff14;border-radius:100px;padding:4px 12px;font-size:.75rem;font-weight:700}body.dark-mode .timeline-badge{color:#62c2fe;background:#62c2fe26}.timeline-node-location{color:var(--text-muted);font-size:.75rem;font-weight:500}.timeline-institution{color:var(--text-primary);letter-spacing:-.01em;margin:0;font-family:Clash Display,sans-serif;font-size:1.35rem;font-weight:600;line-height:1.25}.timeline-degree{color:var(--text-muted);margin:0;font-size:.9rem;font-weight:500;line-height:1.4}.timeline-milestones-list{flex-direction:column;gap:10px;margin:5px 0;display:flex}.timeline-milestone-item{background:#ffffff59;border:1px solid #00000005;border-radius:14px;align-items:flex-start;gap:12px;padding:10px 14px;display:flex}body.dark-mode .timeline-milestone-item{background:#0000002e;border-color:#ffffff05}.milestone-year{color:var(--text-primary);background:#0000000a;border-radius:6px;flex-shrink:0;padding:2px 8px;font-size:.7rem;font-weight:700}body.dark-mode .milestone-year{background:#ffffff14}.milestone-label{color:var(--text-primary);font-size:.8rem;font-weight:500;line-height:1.4}.timeline-map-wrapper{flex-direction:column;gap:8px;margin-top:5px;display:flex}.timeline-map-header{color:var(--text-muted);align-items:center;gap:6px;font-size:.75rem;font-weight:600;display:flex}.timeline-map-iframe{border:var(--border);background:#00000005;border-radius:16px;width:100%;height:150px;transition:all .3s cubic-bezier(.23,1,.32,1)}body.dark-mode .timeline-map-iframe{background:#ffffff05}.timeline-node:hover .timeline-map-iframe{border-color:#62c2fe66;box-shadow:0 4px 15px #00000008}.education-footer{text-align:center;color:var(--text-muted);flex-shrink:0;margin-top:30px;padding-bottom:20px;font-size:.85rem}.education-redirect-btn{font-size:inherit;color:#007bff;cursor:pointer;background:0 0;border:none;padding:0;font-weight:600;text-decoration:underline;transition:color .2s}body.dark-mode .education-redirect-btn{color:#62c2fe}.education-redirect-btn:hover{color:#ff3c00}@keyframes nodeFadeIn{0%{opacity:0;transform:translateY(35px)}to{opacity:1;transform:translateY(0)}}@keyframes moveGradient{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}@media (width<=768px){.education-content{padding:30px 15px 15px}.education-title{font-size:2rem}.timeline-container.vertical{flex-direction:column;align-items:flex-start;gap:30px;margin-top:20px;padding-left:20px;position:relative}.timeline-container.vertical:before{content:"";z-index:1;background:linear-gradient(#007bff1a 0%,#62c2fe80 50%,#007bff1a 100%);width:3px;position:absolute;top:25px;bottom:25px;left:25px}.timeline-node{flex-direction:row;align-items:flex-start;gap:20px;width:100%;max-width:100%}.timeline-dot{z-index:2;flex-shrink:0;width:44px;height:44px;margin-bottom:0;font-size:1.25rem}.timeline-container.vertical:before{left:22px}.timeline-card{border-radius:20px;flex:1;padding:20px}.timeline-institution{font-size:1.2rem}}
