@import"https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Roboto+Flex:opsz,wght@8..144,100..1000&display=swap";:root{--font-sans: "Poppins", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif;--background-light: #f0f2f5;--text-primary-light: #1c1e21;--text-secondary-light: #323436;--accent-light: #0866ff;--panel-bg-light: rgba(255, 255, 255, .85);--prelayer-1-light: #e0e2e5;--prelayer-2-light: #cdd0d4;--background-dark: #121212;--text-primary-dark: #e4e6eb;--text-secondary-dark: #c1c1c1;--accent-dark: #4597ff;--panel-bg-dark: rgba(30, 30, 30, .85);--prelayer-1-dark: #242526;--prelayer-2-dark: #3a3b3c}html{scroll-behavior:smooth}html[data-theme=light]{--background: var(--background-light);--text-primary: var(--text-primary-light);--text-secondary: var(--text-secondary-light);--accent: var(--accent-light);--panel-bg: var(--panel-bg-light);--prelayer-1: var(--prelayer-1-light);--prelayer-2: var(--prelayer-2-light)}html[data-theme=dark]{--background: var(--background-dark);--text-primary: var(--text-primary-dark);--text-secondary: var(--text-secondary-dark);--accent: var(--accent-dark);--panel-bg: var(--panel-bg-dark);--prelayer-1: var(--prelayer-1-dark);--prelayer-2: var(--prelayer-2-dark)}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:var(--font-sans);background-color:var(--background);color:var(--text-primary);transition:background-color .3s ease,color .3s ease;overflow-x:hidden}.popup-close-button{position:absolute;top:1.5rem;right:2rem;width:48px;height:48px;background-color:var(--panel-bg);border:none;border-radius:50%;cursor:pointer;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;z-index:60;transition:background-color .3s ease,transform .3s ease;box-shadow:0 0 20px 2px #0000000d}.popup-close-button:hover{transform:scale(1.05)}.popup-close-button .line{width:22px;height:2px;background-color:var(--text-primary);border-radius:2px;transform-origin:center}.popup-close-button .line-1{transform:translateY(3.5px) rotate(45deg)}.popup-close-button .line-2{transform:translateY(-3.5px) rotate(-45deg)}.app-background{position:fixed;inset:0;width:100vw;height:100vh;z-index:-1}main{position:relative;z-index:1}.content-wrapper{position:relative;z-index:2;padding:2rem;max-width:1280px;margin:0 auto}.content-section{min-height:100vh;padding-top:120px;display:flex;flex-direction:column}@media (max-width: 768px){.content-wrapper{padding:1.5rem}.content-section{padding-top:100px}}.dot-grid{display:flex;align-items:center;justify-content:center;height:100%;width:100%;position:relative}.dot-grid__wrap{width:100%;height:100%;position:relative}.dot-grid__canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}.staggered-menu-wrapper{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:20}.staggered-menu-panel{position:absolute;top:0;right:0;width:clamp(500px,30vw,420px);height:100vh;background:var(--panel-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;flex-direction:column;padding:8em 2.5em 2em 2em;overflow-y:auto;z-index:10;pointer-events:auto}.sm-prelayers{position:absolute;top:0;right:0;bottom:0;width:clamp(500px,30vw,420px);pointer-events:none;z-index:5}.sm-prelayer{position:absolute;top:0;right:0;height:100%;width:100%;transform:translate(0)}.sm-prelayers .sm-prelayer:nth-of-type(1){background-color:var(--prelayer-1)}.sm-prelayers .sm-prelayer:nth-of-type(2){background-color:var(--prelayer-2)}.sm-panel-inner{flex:1;display:flex;flex-direction:column;gap:1.25rem}.sm-panel-itemWrap{overflow:hidden}.sm-panel-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.sm-panel-item{position:relative;color:var(--text-primary);font-weight:700;font-size:3.5rem;cursor:pointer;line-height:1;letter-spacing:-2px;text-transform:uppercase;transition:color .25s;display:inline-block;text-decoration:none;padding-right:.5em}.sm-panel-item:hover{color:var(--accent)}.sm-panel-list[data-numbering]{counter-reset:smItem}.sm-panel-list[data-numbering] .sm-panel-item:after{counter-increment:smItem;content:counter(smItem,decimal-leading-zero);position:absolute;top:20%;right:0;transform:translateY(-50%);font-size:1rem;font-weight:400;color:var(--accent);letter-spacing:0px;pointer-events:none;-webkit-user-select:none;user-select:none;opacity:.5;transition:opacity .3s ease}.sm-panel-item:hover:after{opacity:1}.sm-socials{margin-top:auto;padding-top:2rem;display:flex;flex-direction:column;gap:.75rem}.sm-socials-title{margin:0;font-size:1rem;font-weight:500;color:var(--accent)}.sm-socials-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:row;align-items:center;gap:1rem;flex-wrap:wrap}.sm-socials-link{font-size:1.2rem;font-weight:500;color:var(--text-primary);text-decoration:none;position:relative;padding:2px 0;display:inline-block;transition:color .3s ease,opacity .3s ease}.sm-socials-link:hover{color:var(--accent)}.sm-socials-list:hover .sm-socials-link:not(:hover){opacity:.35}@media (max-width: 1200px){.sm-panel-item{font-size:3rem}}@media (max-width: 768px){.staggered-menu-panel,.sm-prelayers{width:clamp(280px,60vw,420px)}.sm-panel-item{font-size:2.5rem}}@media (max-width: 640px){.staggered-menu-panel,.sm-prelayers{width:100%;right:0}}.clock-display{font-size:.9rem;font-weight:500;color:var(--text-primary);letter-spacing:.5px}.main-header{position:fixed;top:0;left:0;width:100%;display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;z-index:30;pointer-events:none}.main-header>*{pointer-events:auto}.header-left,.header-right{display:flex;align-items:center;gap:1.5rem}.menu-toggle-button{position:relative;width:48px;height:48px;background-color:var(--panel-bg);border:none;border-radius:50%;cursor:pointer;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;z-index:1001;transition:background-color .3s ease;box-shadow:0 0 20px 2px #0000000d}.menu-toggle-button .line{width:22px;height:2px;background-color:var(--text-primary);border-radius:2px;transition:transform .3s ease,opacity .3s ease,background-color .3s ease;transform-origin:center}.menu-toggle-button.is-open .line{background-color:var(--text-primary)}.menu-toggle-button.is-open .line-1{transform:translateY(7px) rotate(45deg)}.menu-toggle-button.is-open .line-2{opacity:0}.menu-toggle-button.is-open .line-3{transform:translateY(-7px) rotate(-45deg)}@media (max-width: 768px){.main-header{padding:1rem}.header-left{display:flex}}.gradual-blur-inner{position:relative;width:100%;height:100%}.gradual-blur-inner>div{-webkit-backdrop-filter:inherit;backdrop-filter:inherit}.gradual-blur{isolation:isolate}@supports not (backdrop-filter: blur(1px)){.gradual-blur-inner>div{background:#0000004d;opacity:.5}}.gradual-blur-fixed{position:fixed!important;inset:0;pointer-events:none;z-index:10}.variable-proximity{font-family:Roboto Flex,sans-serif}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.hero-section{min-height:100vh;width:100%;display:flex;padding:2rem}.hero-content-wrapper{width:100%;display:flex;align-items:center;justify-content:flex-start}.hero-text-content{display:flex;flex-direction:column;align-items:flex-start;gap:.5rem;max-width:50%;text-align:left}.hero-tagline{font-size:clamp(1.2rem,3vw,1.5rem);color:var(--accent);margin:0;font-weight:300;text-transform:uppercase;letter-spacing:1.5px}.hero-title-container{width:100%;max-width:600px;height:110px}.hero-description{font-family:Poppins,sans-serif;font-size:clamp(1rem,2vw,1.1rem);color:var(--text-secondary);margin:0;max-width:600px;line-height:1.7;font-weight:400;text-align:justify}.hero-buttons{display:flex;gap:1rem;margin-top:1.5rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:8px;text-decoration:none;font-weight:600;font-size:1rem;transition:all .3s ease;border:2px solid transparent}.btn-icon{transition:transform .3s ease}.btn:hover .btn-icon{transform:translateY(2px)}.btn-primary{background-color:var(--accent);color:var(--background)}.btn-primary:hover{background-color:transparent;color:var(--accent);border-color:var(--accent)}.btn-secondary{background-color:transparent;color:var(--text-secondary);border-color:var(--text-secondary)}.btn-secondary:hover{color:var(--accent);border-color:var(--accent)}@media (max-width: 900px){.hero-content-wrapper{justify-content:center}.hero-text-content{max-width:80%;align-items:center;text-align:center}}@media (max-width: 640px){.hero-text-content{max-width:100%}.hero-title-container{height:80px}.hero-description{text-align:center}.btn-icon{display:none}}.about-grid{width:100%;display:grid;gap:1rem;grid-template-columns:repeat(4,1fr);grid-auto-rows:auto}.grid-item{background-color:var(--panel-bg);border-radius:12px;padding:1.5rem;box-shadow:0 4px 6px #0000000d;transition:all .3s ease;display:flex;flex-direction:column;position:relative;z-index:1;min-height:120px}.grid-item:hover{transform:translateY(0);box-shadow:0 10px 15px #0000000d;z-index:10}.div1{grid-column:span 4;min-height:450px}.div2,.div7{grid-column:span 4;min-height:120px}.div4{grid-column:span 4;min-height:150px}.div3{grid-column:span 4;min-height:200px}@media (min-width: 1024px){.about-grid{grid-template-columns:repeat(6,1fr);grid-template-rows:repeat(3,auto)}.div1{grid-area:1 / 1 / 3 / 5}.div2{grid-area:1 / 5 / 2 / 7}.div7{grid-area:2 / 5 / 3 / 7}.div4{grid-area:3 / 1 / 4 / 7}.div3{grid-area:4 / 1 / 5 / 7}}.section-title-container{width:100%;margin-bottom:2rem}.section-title{font-family:var(--font-sans);font-size:clamp(1.2rem,3vw,1.5rem);color:var(--accent);margin:0;font-weight:600;text-transform:uppercase;letter-spacing:1.5px}.accordion-card{display:flex;flex-direction:column;gap:1.5rem;height:100%;width:100%}.accordion-image-container{width:100%;flex-shrink:0}.profile-image{width:100%;height:100%;aspect-ratio:1 / 1;object-fit:cover;border-radius:12px}.accordion-container{width:100%;display:flex;flex-direction:column}.accordion-item{border-bottom:1px solid var(--prelayer-1)}.accordion-item:last-child{border-bottom:none}.accordion-trigger{display:flex;justify-content:space-between;align-items:center;width:100%;padding:1rem 0;font-size:1.1rem;font-weight:600;color:var(--text-primary);cursor:pointer;background:none;border:none}.accordion-icon{color:var(--accent)}.accordion-content p{padding-bottom:1rem;color:var(--text-secondary);line-height:1.6}@media (min-width: 768px){.accordion-card{flex-direction:row}.accordion-image-container{width:35%}}.typing-speed-card{height:100%;width:100%;display:flex;flex-direction:column;justify-content:space-between;align-items:stretch}.typing-speed-label{display:flex;align-items:center;gap:.75rem}.typing-speed-icon{color:var(--text-secondary);flex-shrink:0}.typing-speed-title{font-size:1.1rem;font-weight:600;color:var(--text-secondary);margin:0;white-space:nowrap}.typing-speed-display{display:flex;align-items:baseline;justify-content:flex-end;gap:.5rem}.typing-speed-value{width:120px;height:80px}.typing-speed-wpm{font-size:1.5rem;font-weight:700;color:var(--accent)}@media (max-width: 640px){.typing-speed-value{width:90px;height:60px}.typing-speed-wpm{font-size:1.2rem}}.location-card{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;height:100%}.location-title{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary)}.location-icon{flex-shrink:0}.location-title h3{margin:0;font-size:1.1rem;font-weight:600}.location-link{font-size:1.2rem;font-weight:700;color:var(--text-primary);text-decoration:none;border-bottom:2px solid transparent;transition:border-color .3s ease;cursor:pointer;background:none;border:none;padding:0;font:inherit}.location-link:hover{border-color:var(--accent)}.hover-card-content{border-radius:12px;padding:1rem;width:300px;background-color:var(--panel-bg);box-shadow:0 10px 30px #0000001a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);animation:fadeIn .3s ease-out;z-index:50}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.tooltip-image{width:100%;height:150px;object-fit:cover;border-radius:8px;margin-bottom:1rem}.tooltip-text h4{margin:0 0 .5rem;color:var(--text-primary);font-size:1rem}.tooltip-text p{margin:0;color:var(--text-secondary);font-size:.9rem;line-height:1.5}.github-card{height:100%;width:100%;display:flex;flex-direction:column}.github-header{display:flex;align-items:center;gap:.75rem;color:var(--text-primary);width:100%;justify-content:flex-start;padding-bottom:1.2rem}.github-logo{color:var(--text-primary)}.github-header h3{font-size:1rem;font-weight:600;margin:0}.github-title{display:flex;align-items:center;gap:.75rem}.github-content-wrapper{display:flex;flex-grow:1;gap:1.5rem;overflow:hidden}.calendar-container{color:var(--text-secondary);overflow-x:auto;flex-grow:1;padding-bottom:12px}.github-profile-link{display:inline-flex;flex-direction:row;justify-content:center;align-items:center;min-width:290px;gap:.5rem;flex-shrink:0;padding:.75rem 1.25rem;background-color:var(--prelayer-1);color:var(--text-secondary);border-radius:12px;text-decoration:none;font-weight:600;transition:all .3s ease;margin-bottom:12px}.github-profile-link:hover{background-color:var(--accent);color:var(--background)}.profile-link-icon{margin-bottom:.5rem}@media (max-width: 1270px){.github-content-wrapper{flex-direction:column;gap:1rem}.github-profile-link{width:100%;height:auto;flex-direction:row;padding:.75rem 1rem;border-radius:9999px;gap:.5rem}.profile-link-icon{margin-bottom:0}}.react-activity-calendar{font-family:Poppins,sans-serif!important}.calendar-container::-webkit-scrollbar{height:4px}.calendar-container::-webkit-scrollbar-track{background:transparent}.calendar-container::-webkit-scrollbar-thumb{background:var(--text-secondary);border-radius:4px}.calendar-container::-webkit-scrollbar-thumb:hover{background:var(--accent)}.logoloop{position:relative;overflow-x:hidden;--logoloop-gap: 48px;--logoloop-logoHeight: 48px;--logoloop-fadeColorAuto: var(--panel-bg);padding:.5rem 0}.logoloop__track{display:flex;width:max-content;will-change:transform;-webkit-user-select:none;user-select:none}.logoloop__list{display:flex;align-items:center;list-style:none;margin:0;padding:0}.logoloop__item{flex:0 0 auto;margin-right:var(--logoloop-gap);font-size:var(--logoloop-logoHeight);line-height:1;background-color:var(--panel-bg);transition:opacity .3s ease,transform .3s ease;display:flex;justify-content:center;align-items:center;width:var(--logoloop-logoHeight);height:var(--logoloop-logoHeight);overflow:visible}.logoloop__node svg{width:100%;height:100%;object-fit:contain}.logoloop.is-hovered .logoloop__item:not(:hover){opacity:.5}.logoloop__item:hover,.logoloop__item.active{transform:scale(1.15)}.logoloop.is-hovered .logoloop__item.active:not(:hover){opacity:1}.logoloop__node{display:inline-flex;align-items:center;color:var(--text-secondary);width:100%;height:100%}.logoloop__link{display:inline-flex;align-items:center;justify-content:center;background:none;border:none;padding:0;cursor:pointer;border-radius:4px;width:100%;height:100%}.logoloop__link:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.logoloop--fade:before,.logoloop--fade:after{content:"";position:absolute;top:0;bottom:0;width:clamp(24px,8%,120px);pointer-events:none;z-index:1}.logoloop--fade:before{left:0;background:linear-gradient(to right,var(--logoloop-fadeColor, var(--logoloop-fadeColorAuto)) 0%,transparent 100%)}.logoloop--fade:after{right:0;background:linear-gradient(to left,var(--logoloop-fadeColor, var(--logoloop-fadeColorAuto)) 0%,transparent 100%)}.tech-carousel-card{padding:0!important;display:flex;flex-direction:column;justify-content:flex-start;gap:1.5rem;transition:all .4s ease;overflow:hidden;height:100%;cursor:pointer}.tech-carousel-card.expanded{height:auto}.tech-carousel-header{display:flex;align-items:center;gap:.75rem;color:var(--text-primary);width:100%;justify-content:flex-start}.tech-carousel-header h3{font-size:1rem;font-weight:600;margin:0}.logo-loop-container{width:100%;flex-grow:1;display:flex;align-items:center;padding:0 1.5rem 1rem;cursor:default}.selected-tech-title{color:var(--text-primary);font-weight:700;font-size:1.8rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 1.5rem 1.5rem;width:100%;line-height:1}@media (min-width: 769px){.selected-tech-title{text-align:left;font-size:1.8rem}}@media (max-width: 768px){.selected-tech-title{text-align:center;font-size:1.5rem}}.certificates-list-container{width:100%;margin:0 auto;display:flex;flex-direction:column}.certificates-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1rem}.certificate-item{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;padding:1rem;border-radius:12px;background-color:var(--panel-bg);cursor:pointer;transition:background-color .2s,transform .2s;box-shadow:0 4px 6px #0000000d}.certificate-item:hover{transform:translateY(-2px);background-color:var(--prelayer-2)}.item-content{display:flex;align-items:center;gap:1.5rem;margin-bottom:.5rem}.item-image{width:60px;height:60px;border-radius:10px;object-fit:contain}.item-title{font-weight:600;color:var(--text-primary)}.item-description{color:var(--text-secondary);font-size:.9rem}.item-button{padding:.5rem 1rem;border-radius:10px;background-color:var(--accent);color:#fff;font-weight:600;font-size:1.1rem;border:none;cursor:pointer}.view-all-certs-link{display:inline-flex;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem;background-color:var(--panel-bg);color:var(--text-secondary);border-radius:9999px;text-decoration:none;font-weight:600;transition:all .3s ease;margin-top:2rem;box-shadow:0 4px 6px #0000000d}.profile-link-icon{transition:transform .3s ease}.card-overlay{position:fixed;inset:0;background-color:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:40}.active-card-wrapper{position:fixed;inset:0;display:grid;place-items:center;z-index:50;padding:1rem}.active-card-content{width:80%;max-height:90vh;background-color:var(--panel-bg);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;padding:1.5rem;gap:1.5rem;position:relative}.active-card-header{display:flex;align-items:flex-start;gap:1rem}.active-card-image{width:80px;height:80px;border-radius:12px;object-fit:contain;flex-shrink:0;background-color:var(--prelayer-1)}.header-text-content{flex-grow:1}.card-title{font-size:1.25rem;font-weight:700;margin:0;color:var(--text-primary)}.card-description{font-size:.9rem;color:var(--text-secondary);margin-top:.25rem}.cta-button{padding:.75rem 1.5rem;border-radius:10px;background-color:var(--accent);color:#fff;font-weight:600;text-decoration:none;transition:transform .2s ease;margin-top:1.5rem;align-self:flex-end}.cta-button:hover{transform:scale(1.05)}.card-body-wrapper{display:flex;flex-direction:column;flex-grow:1;min-height:0}.card-main-content{font-size:1rem;line-height:1.7;color:var(--text-secondary);overflow-y:auto;padding-right:.5rem;flex-grow:1}@media (max-width: 640px){.item-content{width:100%;margin-bottom:1rem}.item-button{width:100%;text-align:center}}@media (max-width: 768px){.close-button{display:none}.active-card-header{flex-direction:column;align-items:center;text-align:center}.cta-button{width:100%;margin-top:1rem}}@media (min-width: 1024px){.view-all-certs-link{width:auto;padding:.5rem 1rem;margin-top:2rem;align-self:flex-end}}.carousel-wrapper{padding:2rem 0}.carousel-container{display:flex;gap:1rem;overflow-x:auto;padding:1rem;scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none}.carousel-container::-webkit-scrollbar{display:none}.carousel-item{flex:0 0 auto;width:320px;height:480px;scroll-snap-align:center;cursor:pointer}.card-content{height:100%;width:100%;border-radius:2rem;overflow:hidden;position:relative;background-color:var(--panel-bg);box-shadow:0 10px 20px #0000000d}.card-image-container{position:absolute;inset:0;width:100%;height:100%}.card-image{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}@media (hover: hover){.carousel-item:hover .card-image{transform:scale(1.05)}}.card-details{position:absolute;bottom:0;left:0;right:0;padding:2rem;color:var(--text-primary);background:linear-gradient(to top,var(--background) 30%,transparent)}.card-category{font-size:.9rem;font-weight:500;color:var(--text-secondary)}.card-title{font-size:1.5rem;font-weight:700;margin-top:.25rem;color:var(--text-primary)}.carousel-controls{display:flex;justify-content:center;align-items:center;padding:1rem 2rem 0;gap:1rem}.more-projects-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:99px;background:var(--prelayer-1);color:var(--text-secondary);font-weight:600;text-decoration:none;transition:all .2s}.more-projects-btn:hover{background:var(--accent);color:var(--background)}.nav-buttons{display:flex;align-items:center;gap:.5rem}.nav-buttons button{background:var(--prelayer-1);color:var(--text-primary);border:none;width:40px;height:40px;border-radius:30px;font-size:1rem;cursor:pointer;transition:all .2s}.nav-buttons button:hover:not(:disabled){background:var(--accent);color:var(--background)}.nav-buttons button:disabled{opacity:.4;cursor:not-allowed}@media (min-width: 769px){.carousel-controls{justify-content:flex-end}}@media (max-width: 768px){.carousel-item{width:280px;height:420px}.carousel-controls{gap:.75rem}}.project-overlay{position:fixed;inset:0;background-color:#000000b3;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:40}.expanded-card-wrapper{position:fixed;inset:0;display:grid;place-items:center;z-index:50;padding:1rem}.expanded-card-content{background-color:var(--background);color:var(--text-primary);width:100%;max-width:60rem;max-height:90vh;overflow-y:auto;border-radius:1.5rem;display:flex;gap:2rem;padding:2rem;position:relative}.project-content-image{width:55%;height:auto;object-fit:cover;border-radius:1rem;flex-shrink:0;aspect-ratio:16 / 10}.project-content-details{display:flex;flex-direction:column}.project-content-header{margin-bottom:1rem}.project-content-header h3{font-size:2rem;font-weight:700;margin:0}.project-content-header .project-year{font-size:1rem;font-weight:500;color:var(--text-secondary);margin-top:.25rem}.project-content-description{font-size:1rem;color:var(--text-secondary);line-height:1.7;margin-bottom:1.5rem;flex-grow:1}.project-content-tech{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem}.tech-tag{background-color:var(--prelayer-2);padding:.25rem .75rem;border-radius:99px;font-size:.8rem;font-weight:500}.project-buttons{display:flex;gap:1rem;margin-top:auto}.project-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:8px;text-decoration:none;font-weight:600;font-size:1rem;transition:all .3s ease;border:2px solid transparent}.project-btn.github{background-color:transparent;color:var(--text-secondary);border-color:var(--text-secondary)}.project-btn.github:hover{color:var(--accent);border-color:var(--accent)}.project-btn.live{background-color:var(--accent);color:var(--background)}.project-btn.live:hover{background-color:transparent;color:var(--accent);border-color:var(--accent)}@media (max-width: 768px){.expanded-card-content{flex-direction:column;padding:1.5rem}.project-content-image{width:100%}.project-content-details{padding:0}.project-content-header h3{font-size:1.5rem}}body.flash-effect{animation:flash .5s 2}@keyframes flash{0%,to{opacity:1}50%{opacity:.5}}.contact-section{position:relative;padding:120px 2rem 2rem;color:var(--text-primary);min-height:90vh;display:flex;flex-direction:column;overflow:hidden}.contact-gradient-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to top,var(--background) 70%,transparent 100%);z-index:0;pointer-events:none}.contact-container{position:relative;z-index:1;max-width:1280px;margin:0 auto;width:100%;flex-grow:1;display:flex;flex-direction:column}.contact-grid{display:grid;grid-template-columns:1fr;gap:4rem;flex-grow:1;align-items:end}.contact-left{text-align:left;display:flex;flex-direction:column;justify-content:flex-end}.contact-name{font-size:2rem;font-weight:700}.contact-email-link{display:inline-flex;align-items:center;gap:.25rem;color:var(--text-secondary);text-decoration:none;font-weight:500;margin-top:.5rem;position:relative;width:fit-content}.contact-email-link:after{content:"";position:absolute;bottom:-2px;left:0;width:100%;height:1px;background-color:var(--text-secondary);transform:scaleX(0);transform-origin:right;transition:transform .3s ease-out}.contact-email-link:hover:after{transform:scaleX(1);transform-origin:left}.contact-email-icon{opacity:1;transition:transform .3s ease}.contact-email-link:hover .contact-email-icon{transform:translate(2px) translateY(-2px)}.contact-description{font-size:1rem;color:var(--text-secondary);max-width:400px;margin:1.5rem 0}.social-links{display:flex;justify-content:flex-start;gap:1.5rem;list-style:none;padding:0;font-size:1.5rem}.social-links a{color:var(--text-secondary);transition:color .2s,transform .2s}.social-links a:hover{color:var(--accent);transform:scale(1.1)}.contact-right{display:flex;flex-direction:column;justify-content:flex-end}.contact-nav{display:none;justify-content:flex-end;gap:2rem;margin-bottom:2rem}.contact-nav a{text-decoration:none;color:var(--text-secondary);font-weight:500;transition:color .2s}.contact-nav a:hover{color:var(--accent)}.contact-form-container{background-color:var(--panel-bg);padding:2rem;border-radius:16px;display:flex;flex-direction:column;max-height:80vh;height:auto}.contact-form{display:flex;flex-direction:column;gap:1rem;flex-grow:1}.contact-form input,.contact-form textarea{background-color:var(--prelayer-1);border:1px solid var(--prelayer-2);padding:.75rem 1rem;border-radius:8px;color:var(--text-primary);font-family:inherit}.contact-form textarea{min-height:1px;resize:vertical;flex-grow:1}.send-button{background-color:var(--accent);color:var(--background);border:none;padding:.75rem;border-radius:8px;font-weight:600;cursor:pointer;transition:opacity .2s}.send-button:hover{opacity:.8}.chatbot-toggle{display:flex;justify-content:space-between;align-items:center;width:100%;margin-top:1rem;padding:.75rem 1rem;background:none;border:1px solid var(--prelayer-2);color:var(--text-secondary);font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s;position:relative;overflow:hidden;z-index:1}.chatbot-toggle .hoverEffect{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:-1}.chatbot-toggle .hoverEffect div{background:linear-gradient(90deg,#958ffc,#217df9,#a0a8b0);border-radius:50%;width:40rem;height:40rem;transition:.4s;filter:blur(20px);animation:rotate 3s linear infinite;opacity:.5}.chatbot-toggle:hover .hoverEffect div{width:35rem;height:35rem}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.chatbot-toggle:hover:before{transform:translate(-50%,-50%) scale(1)}.chatbot-toggle:hover{background-color:var(--prelayer-2);color:var(--text-primary)}.chatbot-view{display:flex;flex-direction:column;height:100%;flex-grow:1;min-height:0}.chatbot-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-bottom:1px solid var(--prelayer-2);cursor:pointer;color:var(--text-secondary);font-weight:500}.chatbot-container{display:flex;flex-direction:column;flex-grow:1;overflow:hidden}.chatbot-messages{flex-grow:1;overflow-y:auto;padding:.5rem;display:flex;flex-direction:column;gap:.75rem;scrollbar-width:none}.chatbot-messages::-webkit-scrollbar{display:none}.message{padding:.5rem 1rem;border-radius:12px;max-width:80%}.message.ai{background-color:var(--prelayer-1);align-self:flex-start}.message.user{background-color:var(--accent);color:var(--background);align-self:flex-end}.chatbot-input-area{display:flex;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--prelayer-2);flex-shrink:0}.chatbot-input-area input{flex-grow:1;background-color:var(--prelayer-1);border:1px solid var(--prelayer-2);padding:.75rem 1rem;border-radius:8px;color:var(--text-primary)}.chatbot-input-area button{background-color:var(--accent);color:var(--background);border:none;width:44px;height:44px;border-radius:8px;cursor:pointer;display:grid;place-items:center}.contact-footer{display:flex;justify-content:space-between;align-items:center;margin-top:4rem;padding-top:2rem;border-top:1px solid var(--prelayer-2);color:var(--text-secondary);font-size:.9rem;position:relative}.gemini-credit{position:absolute;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:.5rem}.footer-copyright{flex:1;text-align:left}.footer-legal{flex:1;text-align:right}.gemini-logo{filter:grayscale(1);transition:filter .3s}.gemini-credit:hover .gemini-logo{filter:grayscale(0)}.footer-legal a{text-decoration:none;color:var(--text-secondary);transition:text-decoration .2s}.footer-legal a:hover{text-decoration:underline}.app-content{overflow-x:hidden}@media (min-width: 1024px){.contact-grid{grid-template-columns:1fr 1.5fr;gap:6rem}.contact-nav{display:flex}}@media (max-width: 768px){.contact-footer{flex-direction:column;gap:1rem}.gemini-credit{position:static;transform:none;order:-1}}.privacy-policy-container{padding:120px 2rem 2rem;min-height:100vh}.privacy-policy-card{background-color:var(--panel-bg);border-radius:12px;padding:2rem;max-width:800px;margin:0 auto}.privacy-content ul{list-style-position:inside;padding-left:1rem}.context-menu-content,.context-menu-sub-content{min-width:12rem;border-radius:12px;padding:.5rem;z-index:50;overflow:hidden;background-color:var(--panel-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:var(--text-primary);box-shadow:0 10px 38px -10px #16171859,0 10px 20px -15px #16171833;animation:fadeIn .15s ease-out}.context-menu-sub-content[data-state=open]{animation:slideIn .2s ease-out;left:100%}@keyframes fadeIn{0%{opacity:0;transform:scale(.98) translateY(2px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:scale(.98) translate(-5px)}to{opacity:1;transform:scale(1) translate(0)}}.context-menu-item,.context-menu-checkbox-item,.context-menu-radio-item,.context-menu-sub-trigger{font-size:.9rem;line-height:1;border-radius:8px;display:flex;align-items:center;position:relative;padding:.65rem .75rem;-webkit-user-select:none;user-select:none;outline:none;cursor:pointer;gap:.75rem;color:var(--text-secondary);transition:background-color .1s ease-in-out,color .1s ease-in-out}.context-menu-item:not([data-disabled]):hover,.context-menu-checkbox-item:not([data-disabled]):hover,.context-menu-radio-item:not([data-disabled]):hover,.context-menu-sub-trigger[data-state=open]{background-color:var(--accent);color:#fff}.context-menu-item>span,.context-menu-sub-trigger>span,.context-menu-radio-item>span,.context-menu-checkbox-item>span:not(.context-menu-item-indicator-wrapper){flex-grow:1}.context-menu-item[data-disabled]{color:var(--prelayer-2);pointer-events:none}.context-menu-sub-trigger-icon{margin-left:auto;width:1rem;height:1rem}.context-menu-separator{height:1px;background-color:var(--prelayer-2);margin:.5rem -.5rem}.context-menu-label{padding:.5rem .75rem;font-size:.8rem;font-weight:600;color:var(--text-secondary)}.context-menu-item-indicator-wrapper{position:absolute;left:.5rem;width:1rem;display:inline-flex;justify-content:center;align-items:center}.context-menu-radio-item,.context-menu-checkbox-item{padding-left:2rem}.accordion-content{overflow:hidden}.pwa-toast{position:fixed;right:1rem;bottom:1rem;margin:16px;padding:12px;border:1px solid var(--prelayer-2);border-radius:8px;z-index:1000;text-align:left;box-shadow:0 4px 12px #0000001a;background:var(--panel-bg);color:var(--text-primary);display:flex;align-items:center;gap:1rem}.pwa-toast-message{flex-grow:1}.pwa-toast-buttons{display:flex;gap:.5rem}.pwa-toast-button{display:flex;align-items:center;gap:.5rem;background-color:var(--accent);color:var(--background);border:none;border-radius:6px;padding:.5rem 1rem;cursor:pointer;font-weight:500}.pwa-toast-button.close{background-color:var(--prelayer-1);color:var(--text-secondary)}.error-page-container{padding:2rem;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center}.error-card{background-color:var(--panel-bg);border-radius:12px;padding:2rem;max-width:500px;width:100%;margin:0 auto}.error-image-container{margin-bottom:2rem}.error-image{max-width:200px;height:auto}.error-content .error-code{font-size:1.5rem;font-weight:700;color:var(--accent);margin:0}.error-content .error-title{font-size:2rem;font-weight:700;color:var(--text-primary);margin:.5rem 0}.error-content .error-message{font-size:1rem;color:var(--text-secondary);line-height:1.6}.error-attribution{margin-top:2rem;font-size:.8rem}.error-attribution a{color:var(--text-secondary);text-decoration:none;transition:color .2s ease}.error-attribution a:hover{color:var(--accent);text-decoration:underline}.back-button{position:absolute;top:2rem;left:2rem;font-size:1.1rem;font-weight:500;text-decoration:none;color:var(--text-secondary);z-index:10;display:flex;align-items:center;gap:.5rem;transition:color .2s ease}.back-button:hover{color:var(--accent)}
