@import"https://fonts.googleapis.com/css2?family=Caveat:wght@400;500;600;700&family=Inter:wght@300;400;500;600;700&display=swap";*{margin:0;padding:0;box-sizing:border-box}:root{--bg-color: #f5f3ef;--text-dark: #1a1a1a;--white: #ffffff;--font-display: "Caveat", cursive;--font-body: "Inter", -apple-system, BlinkMacSystemFont, sans-serif}html,body,#root{width:100%;height:100%;overflow:hidden}body{font-family:var(--font-body);background-color:var(--bg-color);color:var(--text-dark);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{text-decoration:none;color:inherit}button{font-family:var(--font-body);cursor:pointer;border:none;background:none}.left-panel{position:fixed;top:0;left:0;height:100%;width:160px;background-color:var(--bg-color);display:flex;flex-direction:column;align-items:flex-start;padding:32px 0 0 32px;z-index:100;pointer-events:none}.left-panel>*{pointer-events:auto}.profile-section{display:flex;flex-direction:column;align-items:center;gap:8px}.profile-image{width:90px;height:90px;border-radius:50%;border:2.5px solid var(--text-dark);background-color:var(--white);overflow:hidden}.profile-image img{width:100%;height:100%;object-fit:contain;object-position:center center}.name-and-links{display:flex;flex-direction:column;align-items:flex-start;gap:16px}.profile-name{font-family:var(--font-display);font-size:36px;font-weight:400;color:var(--text-dark);font-style:italic}.socials-section{display:flex;flex-direction:column;align-items:flex-start;gap:4px}.socials-label{font-size:24px;font-weight:400;color:var(--text-dark)}.social-link-item{font-size:18px;font-weight:400;color:var(--text-dark)}.social-link{color:var(--text-dark);text-decoration:none;font-size:20px;font-weight:400;transition:opacity .2s ease}.social-link:hover{opacity:.6;text-decoration:underline}@media(max-width:768px){.left-panel{width:auto;background-color:transparent;padding:16px 0 0 16px}.profile-image{width:65px;height:65px;cursor:pointer;opacity:1;transition:opacity .15s ease;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;user-select:none;-webkit-user-select:none}.profile-image:hover:not(.sidebar-open){opacity:.8}.profile-image:active:not(.sidebar-open){opacity:1}.profile-image.sidebar-open{opacity:.5;cursor:pointer}.profile-image.sidebar-open:hover{opacity:.6}.profile-image.sidebar-open:active{opacity:.4}.profile-image.no-hover,.profile-image.no-hover:hover,.profile-image.no-hover:active{opacity:1!important;transition:none!important}.name-and-links{display:none}.mobile-profile-overlay{position:fixed;inset:0;background-color:#00000080;z-index:999}.mobile-profile-menu{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background-color:var(--bg-color);border:2.5px solid var(--text-dark);border-radius:12px;padding:32px;z-index:1000;max-width:90%;box-shadow:0 4px 20px #0000004d}.mobile-profile-close{position:absolute;top:8px;right:12px;background:none;border:none;font-size:36px;color:var(--text-dark);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;line-height:1}.mobile-profile-content{display:flex;flex-direction:column;align-items:center;gap:16px}.profile-image-large{width:120px;height:120px;border-radius:50%;border:2.5px solid var(--text-dark);background-color:var(--white);overflow:hidden}.profile-image-large img{width:100%;height:100%;object-fit:contain;object-position:center center}.profile-name-mobile{font-family:var(--font-display);font-size:36px;font-weight:400;color:var(--text-dark);font-style:italic}.socials-section-mobile{display:flex;flex-direction:column;align-items:flex-start;gap:4px;width:100%}.socials-label-mobile{font-size:24px;font-weight:400;color:var(--text-dark)}.social-link-item-mobile{font-size:18px;font-weight:400;color:var(--text-dark)}.social-link-mobile{color:var(--text-dark);text-decoration:none;font-size:20px;font-weight:400;transition:opacity .2s ease}.social-link-mobile:hover{opacity:.6;text-decoration:underline}}@media(min-width:769px){.mobile-profile-overlay,.mobile-profile-menu{display:none}.profile-image{cursor:default}}.right-panel{position:fixed;top:0;right:0;height:100%;width:160px;background-color:var(--bg-color);display:flex;flex-direction:column;align-items:flex-end;padding:32px 32px 0 0;z-index:100;pointer-events:none}.right-panel>*{pointer-events:auto}.star-icon{display:block;margin-bottom:24px;transition:transform .2s ease,opacity .2s ease}.star-icon:hover{transform:scale(1.1);opacity:.8}.star-icon img{width:64px;height:auto}.nav-links{display:flex;flex-direction:column;align-items:flex-end;gap:8px}.nav-link{font-size:32px;font-weight:400;color:var(--text-dark);transition:opacity .2s ease}.nav-link:hover{opacity:.6}@media(max-width:768px){.right-panel{width:180px;transform:translate(100%);transition:transform .3s ease;box-shadow:-4px 0 20px #0000001a;padding:20px 20px 0 0;align-items:center}.right-panel.open{transform:translate(0)}.star-icon{cursor:pointer;margin-bottom:16px}.star-icon img{width:72px}.nav-links{gap:12px;margin-top:8px;align-items:center}.nav-link{font-size:28px}}.landmark{position:absolute;cursor:pointer;background:transparent;border:none;padding:0;outline:none;z-index:10;pointer-events:auto;transition:transform .2s ease,filter .2s ease}.landmark-image{width:100%;height:100%;object-fit:contain;pointer-events:none;transition:filter .2s ease}.landmark:hover,.landmark.hovered{transform:scale(1.05);z-index:20}.landmark:hover .landmark-image,.landmark.hovered .landmark-image{filter:drop-shadow(0 0 8px rgba(124,124,124,.5)) drop-shadow(0 0 16px rgba(141,141,141,.3))}.landmark-tooltip{position:absolute;bottom:calc(100% + 12px);left:50%;transform:translate(-50%) translateY(10px);opacity:0;visibility:hidden;transition:all .3s cubic-bezier(.34,1.56,.64,1);pointer-events:none;z-index:100}.landmark:hover .landmark-tooltip,.landmark.hovered .landmark-tooltip{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}.landmark-tooltip-text{display:block;background-color:var(--white);color:var(--text-dark);font-family:var(--font-heading);font-size:14px;font-weight:500;padding:10px 16px;border-radius:8px;white-space:nowrap;box-shadow:0 4px 20px #0000001f,0 2px 8px #00000014}.landmark-tooltip-arrow{position:absolute;bottom:-6px;left:50%;transform:translate(-50%) rotate(45deg);width:12px;height:12px;background-color:var(--white);box-shadow:2px 2px 4px #0000000d}@media(max-width:768px){.landmark{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.landmark:active,.landmark:hover,.landmark.hovered{transform:none}.landmark:hover .landmark-image,.landmark.hovered .landmark-image{filter:none}.landmark-tooltip{display:none}}.modal-overlay{position:fixed;inset:0;background-color:#0a0a0a99;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.modal{background-color:var(--white);border-radius:20px;max-width:580px;width:100%;max-height:85vh;overflow-y:auto;position:relative;box-shadow:0 25px 80px #00000040,0 10px 30px #00000026}.modal-close{position:absolute;top:20px;right:20px;width:40px;height:40px;border-radius:50%;background-color:var(--bg-color);display:flex;align-items:center;justify-content:center;color:var(--text-dark);transition:all .2s ease;z-index:10}.modal-close:hover{background-color:var(--text-dark);color:var(--white);transform:rotate(90deg)}.modal-content{padding:48px 40px}.modal-label{display:inline-block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:#666;margin-bottom:12px;text-decoration:none;transition:color .2s ease}.modal-label:hover{color:var(--text-dark);text-decoration:underline}.modal-title{font-size:32px;font-weight:700;margin-bottom:20px;color:var(--text-dark);line-height:1.1}.modal-description{font-size:17px;line-height:1.7;color:var(--text-dark);margin-bottom:20px;font-weight:500}.modal-expand-section{margin-bottom:24px}.modal-expand-row{display:flex;align-items:center;gap:12px}.modal-expand-toggle{display:inline-flex;align-items:center;gap:6px;background:none;border:none;padding:8px 0;font-size:14px;font-weight:600;color:var(--text-dark);cursor:pointer;transition:color .2s ease}.modal-expand-toggle:hover{color:var(--accent)}.modal-expand-toggle .expand-icon{transition:transform .3s ease}.modal-expand-toggle.expanded .expand-icon{transform:rotate(180deg)}.modal-expand-divider{color:#ccc;font-weight:300}.modal-nav-link{display:inline-flex;align-items:center;gap:6px;background:none;border:none;padding:8px 0;font-size:14px;font-weight:600;color:var(--text-dark);cursor:pointer;transition:color .2s ease}.modal-nav-link:hover{color:var(--accent)}.modal-nav-link svg{transition:transform .2s ease}.modal-nav-link:hover svg{transform:translate(2px,-2px)}.modal-text-link{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:var(--text-dark);text-decoration:none;transition:color .2s ease}.modal-text-link:hover{color:var(--accent)}.modal-text-link svg{transition:transform .2s ease}.modal-text-link:hover svg{transform:translate(2px,-2px)}.modal-contact-section{display:flex;flex-direction:column;gap:20px}.modal-contact-info{display:flex;flex-direction:column;gap:8px}.contact-item{display:flex;align-items:center;gap:8px;font-size:15px}.contact-label{font-weight:600;color:var(--text-dark)}.contact-link{color:#555;font-weight:500;text-decoration:none;transition:color .2s ease}.contact-link:hover{color:var(--accent)}.modal-title-row{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:20px}.modal-title-row .modal-title{margin-bottom:0}.skill-filter{display:flex;align-items:center;gap:12px;flex-shrink:0}.skill-filter-dropdown{position:relative}.skill-filter-toggle{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#fafafa;border:1px solid #e0e0e0;border-radius:8px;font-size:13px;font-weight:500;color:var(--text-dark);cursor:pointer;transition:all .2s ease}.skill-filter-toggle:hover,.skill-filter-toggle.open{background:#f5f5f5;border-color:#ccc}.skill-filter-toggle .dropdown-icon{transition:transform .2s ease}.skill-filter-toggle.open .dropdown-icon{transform:rotate(180deg)}.skill-filter-menu{position:absolute;top:calc(100% + 4px);right:0;min-width:220px;max-height:300px;background:var(--white);border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 16px #0000001a;z-index:100;overflow:hidden}.skill-search-wrapper{padding:10px 12px;border-bottom:1px solid #eee}.skill-search-input{width:100%;padding:8px 12px;border:1px solid #e0e0e0;border-radius:6px;font-size:14px;font-weight:500;color:var(--text-dark);outline:none;transition:border-color .2s ease}.skill-search-input::placeholder{color:#999}.skill-search-input:focus{border-color:#bbb}.skill-options-list{max-height:200px;overflow-y:auto;padding:8px 0}.skill-filter-option{display:flex;align-items:center;gap:10px;padding:8px 14px;cursor:pointer;transition:background-color .15s ease}.skill-filter-option:hover{background:#f5f5f5}.skill-filter-option input{display:none}.skill-checkbox{width:16px;height:16px;border:2px solid #ccc;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .15s ease;flex-shrink:0}.skill-filter-option input:checked+.skill-checkbox{background:var(--text-dark);border-color:var(--text-dark)}.skill-filter-option input:checked+.skill-checkbox:after{content:"";width:6px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg) translateY(-1px)}.skill-label{font-size:13px;font-weight:500;color:var(--text-dark)}.skill-filter-clear{background:none;border:none;font-size:13px;font-weight:500;color:#888;cursor:pointer;padding:0;transition:color .2s ease}.skill-filter-clear:hover{color:var(--text-dark)}.expand-collapse-all{background:none;border:none;font-size:13px;font-weight:500;color:#888;cursor:pointer;padding:0;transition:color .2s ease;white-space:nowrap}.expand-collapse-all:hover{color:var(--text-dark)}.modal-companies{margin-bottom:24px}.company-card{display:grid;grid-template-columns:1fr 3fr;border:1px solid #c0c0c0;border-radius:12px;margin-bottom:16px;overflow:hidden}.company-card:last-child{margin-bottom:0}.company-card-left{padding:20px;border-right:1px solid #c0c0c0;display:flex;flex-direction:column;gap:4px}.company-card-name{font-size:16px;font-weight:700;color:var(--text-dark);line-height:1.3;margin:0}.company-card-role{font-size:13px;color:#555;font-weight:500}.company-card-period{font-size:13px;color:#888;font-weight:400}.company-card-right{display:flex;flex-direction:column}.project-accordion-item{border-bottom:1px solid #c0c0c0}.project-accordion-item:last-child{border-bottom:none}.project-accordion-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:none;border:none;cursor:pointer;transition:background-color .2s ease;text-align:left}.project-accordion-header:hover{background:#fafafa}.project-accordion-title{font-size:14px;font-weight:600;color:var(--text-dark);transition:color .2s ease}.project-accordion-header:hover .project-accordion-title{color:#333}.project-accordion-header .expand-icon{transition:transform .3s ease;color:#888;flex-shrink:0}.project-accordion-header.expanded .expand-icon{transform:rotate(180deg)}.project-details{overflow:hidden}.project-details-inner{padding:0 20px 16px}.project-description{font-size:14px;line-height:1.6;color:var(--text-dark);margin-bottom:12px}.project-skills{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.skill-tag{font-size:11px;font-weight:500;padding:4px 10px;background:#f0f0f0;color:#555;border-radius:100px}.project-links{display:flex;flex-wrap:wrap;gap:12px}.project-link{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:500;color:var(--text-dark);text-decoration:none;transition:color .2s ease}.project-link:hover{color:var(--accent)}.project-link svg{transition:transform .2s ease}.project-link:hover svg{transform:translate(1px,-1px)}.modal-long-description{overflow:hidden}.modal-long-description-inner{padding-top:16px;border-top:1px solid #eee;margin-top:8px}.modal-long-description-inner p{font-size:17px;line-height:1.7;color:var(--text-dark);font-weight:500;margin-bottom:16px}.modal-long-description-inner p:last-child{margin-bottom:0}.modal-link{display:inline-flex;align-items:center;gap:8px;background-color:var(--text-dark);color:var(--white);font-family:var(--font-heading);font-size:14px;font-weight:500;padding:14px 28px;border-radius:100px;transition:all .25s ease}.modal-link:hover{background-color:#333;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.modal-link svg{transition:transform .25s ease}.modal-link:hover svg{transform:translate(2px,-2px)}@media(min-width:541px){.modal{max-width:max(960px,80%);min-height:70vh;max-height:94vh}.modal-content{padding:64px 60px}.modal-label{font-size:13px;letter-spacing:2px;margin-bottom:16px}.modal-title{font-size:46px;margin-bottom:28px}.modal-description{font-size:21px;line-height:1.8;margin-bottom:32px}.modal-expand-toggle,.modal-nav-link{font-size:18px;padding:12px 0}.modal-text-link{font-size:18px}.modal-long-description-inner p{font-size:21px;line-height:1.8;margin-bottom:24px}.contact-item,.contact-label,.contact-link{font-size:19px}.modal-link{font-size:18px;padding:18px 36px}.modal-title-row{margin-bottom:28px}.skill-filter-toggle{font-size:16px;padding:14px 18px}.skill-filter-menu{min-width:260px}.skill-search-input{font-size:15px;padding:10px 14px}.skill-label,.skill-filter-clear,.expand-collapse-all{font-size:16px}.company-card-name{font-size:20px}.company-card-role,.company-card-period{font-size:15px}.company-card-left{padding:28px}.project-accordion-header{padding:16px 24px}.project-accordion-title{font-size:18px}.project-details-inner{padding:0 24px 20px}.project-description{font-size:17px;line-height:1.75}.skill-tag{font-size:13px;padding:6px 14px}.project-link{font-size:15px}}@media(max-width:540px){.modal-content{padding:40px 28px}.modal-title{font-size:26px}.modal-description,.modal-long-description-inner p{font-size:15px}.modal-expand-toggle,.modal-nav-link{font-size:13px}.contact-item{font-size:14px}.modal-text-link{font-size:13px}.modal-title-row{flex-direction:column;align-items:flex-start;gap:16px}.modal-title-row .modal-title{margin-bottom:0}.modal-title-row .skill-filter{width:100%;flex-wrap:wrap}.modal-title-row .skill-filter-dropdown{flex-grow:1}.modal-title-row .skill-filter-toggle{width:100%;justify-content:space-between}.modal-title-row .skill-filter-menu{left:0;right:0;min-width:unset}.modal-title-row .skill-filter-clear,.modal-title-row .expand-collapse-all{display:none}.mobile-filter-actions{display:flex;width:100%;gap:12px;margin-top:8px}.mobile-filter-actions .expand-collapse-all,.mobile-filter-actions .skill-filter-clear{display:inline-block;font-size:13px}.skill-filter-menu-clear{display:block;padding:10px 14px;border-top:1px solid #eee;background:#fafafa;font-size:13px;font-weight:500;color:#888;cursor:pointer;text-align:center;transition:all .2s ease}.skill-filter-menu-clear:hover{color:var(--text-dark);background:#f0f0f0}.company-card{grid-template-columns:1fr}.company-card-left{border-right:none;border-bottom:1px solid #c0c0c0;padding:16px}.company-card-name{font-size:15px}.company-card-role,.company-card-period{font-size:12px}.project-accordion-header{padding:12px 16px}.project-accordion-title{font-size:13px}.project-details-inner{padding:0 16px 14px}}.misc-projects{display:flex;flex-direction:column;gap:16px;margin-top:8px}.misc-project-card{border:1px solid #c0c0c0;border-radius:12px;padding:20px}.misc-project-name{font-family:var(--font-body);font-size:15px;font-weight:600;color:var(--text-dark);margin:0 0 8px}.misc-project-description{font-size:13px;line-height:1.5;color:#555;margin:0}.misc-project-site-link{display:flex;width:fit-content;align-items:center;gap:4px;margin-top:12px;font-size:13px;font-weight:500;color:var(--text-dark);text-decoration:underline;text-underline-offset:3px;transition:color .2s ease}.misc-project-site-link:hover{color:#555}.misc-project-site-link svg{stroke:currentColor}.misc-project-repo-link{display:inline-flex;align-items:center;gap:4px;margin-top:8px;font-size:11px;color:#999;text-decoration:underline;text-underline-offset:3px;transition:color .2s ease}.misc-project-repo-link svg{stroke:currentColor}.misc-project-repo-link:hover{color:#555}@media(min-width:541px){.misc-project-name{font-size:16px}.misc-project-description,.misc-project-site-link{font-size:14px}.misc-project-repo-link{font-size:12px}}@media(min-width:541px){.mobile-filter-actions,.skill-filter-menu-clear{display:none}}.app{width:100%;height:100%;position:relative;overflow:hidden;background-color:var(--bg-color)}.map-container{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:1}.map-content{position:relative;height:100%;display:flex;align-items:center;justify-content:center}.map-image-wrapper{position:relative;height:100%;display:inline-block}.map-image{height:100%;width:auto;max-width:none;object-fit:contain;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;display:block}.landmarks-container{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;min-width:100%;min-height:100%}@media(max-width:768px){.app{overflow:visible}.map-container{touch-action:none;cursor:grab;overflow:visible}.map-container.dragging{cursor:grabbing}.map-content{transition:none;will-change:transform;overflow:visible}.map-image-wrapper{overflow:visible}.map-image{transition:none}.landmarks-container{overflow:visible}}.mobile-menu-btn{display:none;position:fixed;top:16px;right:16px;padding:12px;background:var(--white);border:2.5px solid var(--text-dark);border-radius:50%;z-index:999;cursor:pointer;transition:transform .2s ease,opacity .2s ease;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;user-select:none;-webkit-user-select:none;touch-action:manipulation}.mobile-menu-btn:hover{transform:scale(1.1)}.mobile-menu-btn:active{transform:scale(1)}.mobile-menu-btn img{width:36px;height:auto;display:block;pointer-events:none}.mobile-menu-btn.hidden{opacity:0;pointer-events:none}.mobile-menu-btn.modal-open{z-index:1001;filter:brightness(.5);cursor:pointer}.mobile-menu-btn.modal-open:hover,.mobile-menu-btn.modal-open:active{transform:none;filter:brightness(.5)}.mobile-menu-btn.no-hover,.mobile-menu-btn.no-hover:hover,.mobile-menu-btn.no-hover:active{transform:none!important;filter:none!important;transition:none!important}@media(hover:none)and (pointer:coarse){.mobile-menu-btn:hover,.mobile-menu-btn:active{transform:none}.mobile-menu-btn.modal-open,.mobile-menu-btn.modal-open:hover,.mobile-menu-btn.modal-open:active{transform:none;filter:brightness(.5)}.mobile-menu-btn.no-hover,.mobile-menu-btn.no-hover:hover,.mobile-menu-btn.no-hover:active{transform:none!important;filter:none!important}}.mobile-overlay{display:none;position:fixed;inset:0;background-color:#0000004d;z-index:90}@media(max-width:768px){.mobile-menu-btn,.mobile-overlay{display:block}}.mobile-scroll-hint{display:none;position:fixed;bottom:32px;left:50%;transform:translate(-50%);background-color:var(--text-dark);color:var(--white);padding:12px 24px;border-radius:100px;font-size:14px;font-weight:500;z-index:500;box-shadow:0 4px 20px #0003;animation:fadeInUp .5s ease-out;gap:12px;align-items:center}.scroll-hint-text{white-space:nowrap}.scroll-hint-arrow{font-size:16px}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media(max-width:768px){.mobile-scroll-hint{display:flex}}
