:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;transition:border-color .25s}button:hover{border-color:#646cff}@media (pointer: fine){body,button{cursor:none}}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}#root{max-width:1280px;margin:0 auto;padding:1.25rem 2rem 0;text-align:center;width:100%;box-sizing:border-box}.app-shell{display:flex;flex-direction:column;min-height:100vh}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}header{position:fixed;top:0;left:0;width:100vw;padding:1rem 0;z-index:1000}.main-content{padding-top:6.5rem;flex:1}.home-flex{display:flex;align-items:center;justify-content:space-between;gap:clamp(2rem,5vw,5rem);min-height:calc(100vh - 10rem);position:relative}.home-left{flex:2;text-align:left;position:relative}.home-right{flex:1;display:flex;justify-content:center;align-items:center}.headshot-img{width:min(34vw,420px);max-width:100%;aspect-ratio:4 / 5;object-fit:cover;border-radius:22px;border:1px solid var(--surface-border);box-shadow:var(--shadow-lg)}:root{--bg-color: #09111f;--text-color: #eef6ff;--muted-text-color: #a7b4c6;--alt-bg-color: rgba(12, 22, 38, .76);--desc-bg-color: rgba(14, 28, 48, .88);--border: rgba(170, 210, 255, .2);--surface-border: rgba(255, 255, 255, .16);--footer-bg-color: #0c1728;--footer-bg-translucent: rgba(7, 14, 25, .84);--reverse-background: white;--reverse-text: black;--header-text-color: #67e8f9;--accent-color: #f6c85f;--accent-strong: #ff9f1c;--surface-glow: rgba(103, 232, 249, .18);--shadow-lg: 0 24px 80px rgba(0, 0, 0, .38);--shadow-md: 0 18px 45px rgba(0, 0, 0, .28);--logo-primary: #2596be;--logo-secondary: #20293c;--logo-tertiary: #1b69a7;--logo-quaternary: #334768}body{background:radial-gradient(circle at 15% 10%,rgba(103,232,249,.16),transparent 30rem),radial-gradient(circle at 85% 15%,rgba(246,200,95,.12),transparent 28rem),linear-gradient(145deg,#07101d 0%,var(--bg-color) 48%,#0d1728 100%);color:var(--text-color);transition:background-color .4s cubic-bezier(.4,0,.2,1),color .4s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;min-height:100vh;margin:0}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}footer{background:var(--footer-bg-translucent);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-top:1px solid var(--surface-border);opacity:1;transition:background-color .4s cubic-bezier(.4,0,.2,1),color .4s cubic-bezier(.4,0,.2,1);padding:1rem 0;position:relative;width:100vw;margin-left:calc((100vw - 100%)/-2);margin-right:calc((100vw - 100%)/-2);margin-top:auto;z-index:10}.email{text-decoration:underline;color:var(--text-color)}.email:hover{color:var(--header-text-color)}.social-links{display:flex;gap:.5rem;justify-content:right;margin-top:.5rem;margin-right:1rem}.popup-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:2000}.popup-content{background:#0a1424f5;color:var(--text-color);padding:2rem;border:1px solid var(--surface-border);border-radius:18px;box-shadow:var(--shadow-lg);max-width:400px;width:90%;text-align:center;animation:popup-fade .3s ease}.popup-content h2{margin-top:0}.popup-content button{margin-top:1rem;padding:.5rem 1rem;border:none;border-radius:8px;background:linear-gradient(135deg,var(--header-text-color),#3b82f6);color:#fff;transition:background-color .3s ease}.popup-content button:hover{background-color:#2563eb}@keyframes popup-fade{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.contact-button{display:flex;justify-content:left;align-items:center;border:1px solid var(--surface-border);border-radius:999px;background:linear-gradient(135deg,var(--header-text-color),#3b82f6);color:#05101f;font-weight:800;transition:background-color .3s ease;margin-top:-5px;position:absolute;left:0;margin-left:2rem}.text-box{border:1px solid var(--surface-border);border-radius:10px;background:var(--desc-bg-color);color:var(--text-color);padding:.5rem;margin-top:.5rem;width:calc(100% - 1rem);box-sizing:border-box;transition:background-color .4s cubic-bezier(.4,0,.2,1),color .4s cubic-bezier(.4,0,.2,1)}button:disabled{background-color:#888;opacity:.6}.submit-button{border:none;border-radius:999px;background:linear-gradient(135deg,var(--header-text-color),#3b82f6);color:#fff;transition:background-color .3s ease;margin-top:1rem;margin-right:1rem}.nav-link{color:var(--text-color);text-decoration:none;font-weight:700;font-size:2rem;padding:.25rem .75rem;display:inline-block;outline:none;background-color:transparent}.nav-link:focus,.nav-link:hover{outline:none;box-shadow:none;background-color:transparent;text-decoration:none}.nav-link.no-hover-highlight:hover{background-color:transparent}.loader{border:6px solid #f3f3f3;border-top:6px solid #3498db;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.page-loading-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#000000d9;color:#fff;z-index:999999;opacity:1;transition:opacity .3s ease}.page-loading-inner{text-align:center}.page-loading-overlay .loader{border:6px solid rgba(255,255,255,.2);border-top:6px solid #fff}.page-loading-overlay.fade-out{opacity:0;pointer-events:none}@media (max-width: 1024px){#root{padding:1.5rem 1.5rem 0}.home-flex{gap:2rem}}@media (max-width: 900px){#root{padding:1.35rem 1.25rem 0}.main-content{padding-top:6.25rem}.home-flex{flex-direction:column-reverse;align-items:center;text-align:center;gap:2.25rem;min-height:auto}.home-left{text-align:center;width:100%}.home-right{justify-content:center;width:100%}.headshot-img{width:min(70vw,360px)}footer{position:static;padding:1.5rem 0}footer>div{display:flex;justify-content:center;text-align:center;flex-direction:column;align-items:center;gap:.75rem;padding:0 1.25rem}.social-links{width:100%;justify-content:center;flex-wrap:wrap;gap:.65rem 1.25rem}.contact-button{position:static;width:100%;max-width:100px;margin-left:0;color:#fff;justify-content:center}}@media (max-width: 600px){#root{padding:1.2rem 1rem 0}.main-content{padding-top:6rem}.home-flex{gap:1.75rem}.headshot-img{width:min(82vw,320px)}footer>div{padding:0 1rem;align-items:center}.email{display:inline-block}.social-links{justify-content:flex-end;flex-wrap:nowrap;gap:.35rem;padding-right:1.25rem}.contact-button{width:auto;max-width:none;margin-right:13.5rem;padding:.4rem .75rem}}@media (max-width: 420px){#root{padding:1.05rem .75rem 0}.contact-button{width:auto;max-width:none;margin-right:auto;margin-left:.5rem;padding:.35rem .6rem}}body.projects-full-bleed #root,body.experience-full-bleed #root{max-width:none;padding:0;margin:0;width:100%}body.projects-full-bleed,body.experience-full-bleed{overflow-x:hidden}@media (pointer: fine){body{cursor:none}}.navbar{background-color:#333;padding:1rem;display:flex;gap:1rem;position:fixed;top:0;left:0;right:0;z-index:1000}.nav-link{color:var(--text-color);text-decoration:none;font-weight:700;padding:.5rem 1rem;transition:background-color .3s;position:relative}.nav-link:not(:last-child):after{content:"";position:absolute;right:0;top:25%;height:50%;width:1px;background-color:#777}.nav-link:hover{background-color:#555;border-radius:4px}.home-content{text-align:center;padding:2rem}.home-content h1{font-size:2.5rem;margin-bottom:1rem}.home-content p{font-size:1.2rem;color:#555}.home-content button{margin-top:1rem;padding:.5rem 1.5rem;font-size:1rem;background-color:#4caf50;color:#fff;border:none;border-radius:5px}@media (pointer: fine){.home-content button{cursor:none}}.home-content button:hover{background-color:#45a049}.zoom:hover{transform:scale(1.5)}.skills-section{display:flex;flex-direction:column;align-items:center;justify-content:center;border:1px solid var(--surface-border);border-radius:22px;background:linear-gradient(145deg,#ffffff17,#ffffff09);color:var(--text-color);padding:clamp(1.75rem,4vw,3rem);box-shadow:var(--shadow-md);margin:clamp(3rem,6vw,5rem) auto 50px;transition:background-color .4s cubic-bezier(.4,0,.2,1),color .4s cubic-bezier(.4,0,.2,1);max-width:980px;box-sizing:border-box;width:100%;overflow:hidden;position:relative}.skills-section .logoloop{width:100%!important}.skills-section .logoloop--fade:before,.skills-section .logoloop--fade:after{width:0;background:none}.skills-section h1{text-align:center;margin:0 0 2rem;font-size:clamp(2.3rem,5vw,4rem)}.skills-section img{transition:transform .2s}@media (pointer: fine){.skills-section img{cursor:none}}.skills-section img:hover{transform:scale(1.5)}.skills-row{display:flex;justify-content:center;gap:50px;margin-bottom:2rem}.home-intro{display:block;font-size:clamp(2rem,3.6vw,4.1rem);margin-bottom:1rem;font-weight:900;color:var(--text-color);line-height:.95;letter-spacing:0;transition:color .4s cubic-bezier(.4,0,.2,1);white-space:nowrap;max-width:100%}.home-kicker,.section-eyebrow{margin:0 0 .85rem;color:var(--accent-color);font-size:.82rem;font-weight:900;letter-spacing:.12em;text-transform:uppercase}.home-summary{max-width:680px;margin:0 0 1.7rem;color:var(--muted-text-color);font-size:clamp(1.08rem,1.8vw,1.35rem);line-height:1.65}.home-actions{display:flex;align-items:center;gap:.9rem;flex-wrap:wrap}.primary-action,.secondary-action{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:0 1.1rem;border-radius:999px;font-weight:850;text-decoration:none;transition:transform .25s ease,border-color .25s ease,background-color .25s ease}.primary-action{color:#06111f;background:linear-gradient(135deg,var(--header-text-color),#60a5fa);box-shadow:0 14px 34px #2563eb40}.secondary-action{color:var(--text-color);border:1px solid var(--surface-border);background:#ffffff0e}.primary-action:hover,.secondary-action:hover{transform:translateY(-2px);color:var(--text-color);border-color:#67e8f96b}.about-me-text{font-size:clamp(1.15rem,1.3vw,1.35rem);line-height:1.85;min-height:auto;max-width:900px;margin:0 auto;color:var(--muted-text-color);transition:color .4s cubic-bezier(.4,0,.2,1)}.about-me-section{width:100%;margin-top:clamp(2.5rem,6vw,5rem);padding:clamp(2rem,5vw,4rem);border:1px solid var(--surface-border);border-radius:22px;background:#ffffff0b;box-shadow:var(--shadow-md);box-sizing:border-box}.about-me-section h1{margin-top:0;font-size:clamp(2.5rem,5vw,4.5rem)}.skill-logo{padding:6px 12px;margin:0 8px;border-radius:6px;text-decoration:none;display:inline-block;background-color:transparent}.resume-link{text-decoration:none;color:#07111f;margin-top:1rem;border:none;padding:.5rem 1rem;border-radius:999px;background:linear-gradient(135deg,var(--accent-color),var(--accent-strong));font-weight:850;transition:background-color .3s ease}.resume-link:hover{background-color:#004494;color:#fff}.resume-card{border:1px solid var(--surface-border);padding:1rem;border-radius:18px;background:#ffffff14;position:relative;align-items:center;justify-content:center;display:flex;flex-direction:column;gap:.5rem;margin-top:2rem;box-shadow:var(--shadow-md);width:fit-content;max-width:180px;box-sizing:border-box}.resume-qr{max-width:135px;width:100%;border-radius:10px}@media (max-width: 900px){.skills-section{display:flex;flex-direction:column;align-items:center;padding:1.75rem 1.5rem;margin:3rem auto;width:min(100%,900px);box-sizing:border-box}.skills-row{flex-wrap:wrap;gap:2rem}.resume-card{position:relative;left:auto;margin-left:0;max-width:190px;width:fit-content;background:#ffffff14;margin:1.75rem auto 0;align-items:center}.resume-link{color:#fff}}@media (max-width: 600px){.home-intro{font-size:clamp(1.45rem,6.6vw,2rem)}.about-me-text{font-size:clamp(1.05rem,1.2vw + 1rem,1.25rem);line-height:1.9;padding:0 .5rem}.home-actions{justify-content:center}.skills-section{padding:1.5rem}.skills-row{gap:1.25rem}.resume-card{padding:1rem 1.25rem;border-width:3px}.resume-qr{width:min(100%,220px)}}.projects-page{position:relative;min-height:100vh;width:100%;isolation:isolate;padding:clamp(7rem,10vw,9rem) 0 clamp(4rem,8vw,6rem);z-index:1}.projects-background{--parallax-offset: 0px;position:absolute;top:-12vh;left:50%;bottom:0;width:100vw;transform:translate3d(-50%,calc(var(--parallax-offset, 0px) * -0),0);z-index:0;pointer-events:none;will-change:transform;min-height:calc(100% + 0vh)}.projects-background__canvas{width:100%;height:100%;pointer-events:none}.projects-header{position:relative;margin:0;padding-left:clamp(2rem,5vw,6rem);font-size:clamp(3.5rem,7vw,6rem);letter-spacing:0;z-index:1;-webkit-backdrop-filter:blur(.5px);backdrop-filter:blur(.5px);color:var(--text-color);text-shadow:0 0 34px rgba(103,232,249,.35)}.project-title{position:relative;grid-area:title;left:auto;margin:0;font-size:clamp(2rem,4vw,3.15rem);font-weight:900;z-index:100;text-align:left}.projects-content{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0;position:relative;margin:clamp(1.5rem,3vw,3rem) auto 0;width:min(1120px,94vw);padding:0 clamp(1.5rem,4vw,2.5rem);box-sizing:border-box;z-index:1}.projects-display{position:absolute;top:0;right:0;display:flex;flex-direction:column;align-items:flex-end;justify-content:flex-start}.project-display{position:relative;display:grid;grid-template-columns:minmax(280px,.8fr) minmax(360px,1.2fr);grid-template-areas:"title media" "description media";align-items:stretch;justify-content:space-between;gap:1.5rem 2rem;border:1px solid var(--surface-border);border-radius:22px;background:linear-gradient(145deg,#ffffff1a,#ffffff09),var(--alt-bg-color);padding:clamp(1.4rem,3vw,2.25rem);box-shadow:var(--shadow-md);transition:transform .25s ease,border-color .25s ease,background-color .4s cubic-bezier(.4,0,.2,1),color .4s cubic-bezier(.4,0,.2,1);margin-bottom:2.5rem;max-width:100%;overflow:hidden}.project-display:before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 82% 18%,rgba(103,232,249,.16),transparent 24rem)}.project-display:hover{transform:translateY(-4px);border-color:#67e8f952}.project-description{grid-area:description;min-width:0;width:auto;max-width:100%;word-wrap:break-word;text-align:left;margin:0;border:1px solid var(--surface-border);border-radius:16px;background:#050d1a57;color:var(--muted-text-color);padding:clamp(1rem,2vw,1.35rem);box-shadow:none;line-height:1.68;transition:background-color .4s cubic-bezier(.4,0,.2,1),color .4s cubic-bezier(.4,0,.2,1)}.project-video{grid-area:media;display:flex;flex-direction:column;align-items:flex-end;justify-content:flex-start;flex:1 1 0;margin-top:0;padding-top:0;gap:1rem;align-self:stretch}.project-video video{border-radius:16px;max-width:100%;min-height:260px;background:linear-gradient(135deg,#67e8f91a,#f6c85f14),#050d1a94;align-self:flex-end;cursor:pointer;pointer-events:auto;transition:transform .3s ease;border:1px solid var(--surface-border);box-shadow:0 18px 44px #0000003d}.project-video__player:hover,.project-video__player:focus-visible{transform:scale(1.02)}.project-video__player:focus-visible{outline:3px solid rgba(94,234,212,.65);outline-offset:3px}.project-language{font-size:.92rem;color:#06111f;font-weight:900;margin-top:auto;text-align:right;align-self:flex-end;padding:.45rem .75rem;border-radius:999px;background:linear-gradient(135deg,var(--accent-color),var(--accent-strong))}@media (max-width: 900px){.projects-header{position:static;margin:1.5rem auto .75rem;font-size:clamp(2.75rem,14vw,5rem);text-align:center;width:100%;padding-left:0;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.project-display{grid-template-columns:1fr;grid-template-areas:"title" "description" "media";align-items:center;gap:1.5rem;padding:1.5rem;width:min(600px,100%)}.project-title{position:static;font-size:2.25rem;text-align:center}.project-description{width:92%;align-self:center;margin-top:0;margin-left:auto;margin-right:auto;text-align:center;padding:1rem}.project-video{width:100%;margin-top:0;padding-top:0;gap:1rem;align-items:center;justify-content:flex-start;align-self:center;flex:none}.project-video video{width:100%;min-height:auto;height:auto;align-self:center}.project-language{position:static;transform:none;margin-top:.75rem;align-self:center;text-align:center;padding:0}}@media (max-width: 600px){.projects-header{font-size:clamp(2.5rem,13vw,3rem);margin-top:1.25rem}.project-display{padding:1.25rem;width:100%}.project-description{width:80%;align-items:center;padding:1rem;margin-left:auto;margin-right:auto;text-align:center}.project-language{font-size:1rem}}@media (max-width: 350px){.projects-header{font-size:clamp(2.3rem,12vw,3rem);margin-top:1.25rem;padding-left:0}.project-display{padding:1.25rem}.project-description{width:85%;padding:1rem;margin-left:auto;margin-right:auto;text-align:center}.project-language{font-size:1rem}}.experience-page{position:relative;min-height:100vh;width:100%;isolation:isolate;padding:clamp(7rem,10vw,9rem) 0 clamp(4rem,8vw,6rem);z-index:1}.experience-page:before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background:linear-gradient(90deg,#070e19e6,#070e19c2),radial-gradient(circle at 70% 18%,rgba(103,232,249,.14),transparent 28rem)}.experience-background{--parallax-offset: 0px;position:absolute;top:-12vh;left:50%;bottom:0;width:100vw;transform:translate3d(-50%,calc(var(--parallax-offset, 0px) * -0),0);z-index:0;pointer-events:none;will-change:transform;min-height:calc(100% + 3vh);opacity:.42;filter:saturate(.85)}.experience-background__canvas{width:100%;height:100%;pointer-events:none}.experience-header{position:relative;margin:0;padding-left:clamp(2rem,5vw,6rem);font-size:clamp(3.5rem,7vw,6rem);z-index:1;-webkit-backdrop-filter:blur(.5px);backdrop-filter:blur(.5px);color:var(--text-color);text-shadow:0 0 34px rgba(103,232,249,.35)}.experience-content{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));align-items:center;justify-content:center;padding:0 clamp(1.5rem,4vw,2.5rem);position:relative;margin:clamp(1.5rem,3vw,3rem) auto 0;width:min(1120px,94vw);box-sizing:border-box;gap:clamp(1.75rem,3vw,2.5rem);z-index:1}.experience-display{position:relative;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;border:1px solid var(--surface-border);border-radius:22px;background:radial-gradient(circle at top right,rgba(103,232,249,.18),transparent 15rem),linear-gradient(145deg,#0f1b2ef5,#091220f0);box-shadow:0 22px 60px #00000075;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:clamp(1.75rem,3vw,2.5rem);transition:transform .25s ease,border-color .25s ease,background-color .4s cubic-bezier(.4,0,.2,1),color .4s cubic-bezier(.4,0,.2,1);width:100%;min-height:330px;box-sizing:border-box}.experience-display:hover{transform:translateY(-4px);border-color:#67e8f952}.experience-logo{position:absolute;top:1rem;right:1rem;width:75px;height:auto;margin-bottom:1rem;border-radius:10px;background:#ffffffeb;padding:.45rem}.experience-title{font-size:clamp(1.85rem,3vw,2.55rem);margin:0 5rem 1.2rem 0;line-height:1.05;text-align:left;color:var(--text-color);text-shadow:0 2px 18px rgba(0,0,0,.42)}.experience-subtitle{font-size:1.2rem;margin-bottom:1rem;font-weight:900;color:var(--accent-color);text-align:left}.experience-description{font-size:1.1rem;line-height:1.6;text-align:left;margin:0;color:#d8e3ef}@media (max-width: 1000px){.experience-content{grid-template-columns:1fr}.experience-header{font-size:clamp(3rem,7vw,4.5rem)}.experience-title{font-size:clamp(2rem,3.5vw,3rem);text-align:left}}@media (max-width: 640px){.experience-display{align-items:center;padding:clamp(1.5rem,6vw,2.25rem);text-align:center}.experience-logo{position:static;width:60px;margin:0 0 1.25rem}.experience-title{text-align:center;margin-right:0}.experience-subtitle,.experience-description{text-align:center}}@media (pointer: fine){.cursor-target:hover{cursor:none}}.header{background:#070e19b8;color:var(--text-color);width:100%;z-index:1000;opacity:1;backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);border-bottom:1px solid var(--surface-border)}.header-nav{display:flex;align-items:center;justify-content:center;gap:2rem;position:relative;width:100%;max-width:1280px;margin:0 auto;padding:.2rem 1.5rem}.header-logo-link{position:absolute;left:16px;display:inline-flex;align-items:center}.header-logo{height:52px;width:auto;filter:drop-shadow(0 10px 18px rgba(103,232,249,.18))}.header-nav-links{display:flex;align-items:center;gap:.45rem;padding:.35rem;background:#ffffff0e;border:1px solid var(--surface-border);border-radius:999px;box-shadow:0 16px 40px #0000002e}.header-link{text-decoration:none;color:var(--muted-text-color);padding:.55rem 1rem;background-color:transparent;border-radius:999px;box-shadow:none;border:1px solid transparent;transition:color .25s ease,background-color .25s ease,border-color .25s ease;font-weight:750}.header-link:hover,.header-link.is-active{color:var(--text-color);background:#67e8f91f;border-color:#67e8f947}.header-controls{position:absolute;right:16px;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:.75rem}.theme-toggle{width:32px;height:32px;background-color:#333;border-radius:50%;position:relative;cursor:pointer;transition:background-color .3s ease;display:flex;align-items:center;justify-content:center;overflow:hidden;border:none}@media (pointer: fine){.theme-toggle{cursor:none}}.theme-toggle .toggle-icon{width:24px;height:24px}body.dark-mode .theme-toggle{background-color:#fff}.header-menu-toggle{display:none;background:#ffffff14;border:1px solid var(--surface-border);padding:.5rem;border-radius:8px}.header-menu-icon{display:inline-flex;flex-direction:column;gap:6px;width:22px}.header-menu-icon span{display:block;height:2px;width:100%;background-color:var(--text-color);transition:transform .3s ease,opacity .3s ease}.header-menu-toggle.is-open .header-menu-icon span:nth-child(1){transform:translateY(8px) rotate(45deg)}.header-menu-toggle.is-open .header-menu-icon span:nth-child(2){opacity:0}.header-menu-toggle.is-open .header-menu-icon span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}@media (max-width: 1024px){.header-nav{padding:0 1.25rem;gap:1rem}.header-link{padding:.45rem .9rem}}@media (max-width: 900px){.header{padding:.75rem 0}.header-nav{padding:0 1rem;gap:.5rem;justify-content:space-between;align-items:center;flex-wrap:nowrap;width:100%;max-width:100%;margin:0}.header-logo-link{position:static;margin-right:auto}.header-controls{position:static;transform:none;margin-left:0;gap:.5rem;order:0}.theme-toggle{cursor:pointer;width:40px;height:40px}.header-menu-toggle{display:inline-flex;align-items:center;justify-content:center;order:0;margin-right:1rem}.header-nav-links{position:absolute;top:calc(100% + .75rem);left:46%;transform:translate(-50%);width:min(520px,calc(100vw - 2rem));flex-direction:column;align-items:stretch;gap:0;background:#070e19f5;border:1px solid var(--surface-border);border-radius:16px;box-shadow:var(--shadow-md);max-height:0;overflow:hidden;padding:0;opacity:0;pointer-events:none;transition:max-height .3s ease,padding .3s ease,opacity .25s ease;z-index:1200}body.dark-mode .header-nav-links{box-shadow:0 16px 30px #00000059}.header-nav-links.is-open{padding:.75rem 0;max-height:360px;opacity:1;pointer-events:auto}.header-link{background-color:transparent;color:var(--text-color);border-radius:0;box-shadow:none;padding:.75rem 1.5rem;display:block;border:none;text-align:center}.header-link+.header-link{border-top:1px solid rgba(0,0,0,.08)}body.dark-mode .header-link+.header-link{border-top:1px solid rgba(255,255,255,.14)}.header-link:hover{transform:none;background-color:#67e8f91f;box-shadow:none}body.dark-mode .header-link:hover{background-color:#ffffff14}}@media (max-width: 480px){.header-nav{padding:0 .75rem}.header-logo{height:44px}}.photo-gallery{position:relative;min-height:100vh;width:100%;isolation:isolate;padding:clamp(6rem,9vw,8rem) 0 clamp(4rem,8vw,6rem);z-index:1}.photo-gallery-background{position:absolute;top:-12vh;left:50%;bottom:0;width:100vw;transform:translate3d(-50%,0,0);z-index:0;pointer-events:none;will-change:transform;min-height:calc(100% + 28vh);overflow:hidden}.photo-gallery-background__canvas{width:100%;height:100%;display:block;pointer-events:none}.photo-gallery-header{position:relative;margin:0;padding-left:clamp(2rem,5vw,6rem);font-size:clamp(3.5rem,6vw,4.5rem);z-index:1;color:var(--text-color);text-align:left}.photo-gallery-intro{position:relative;display:flex;align-items:center;justify-content:center;margin:clamp(1.5rem,3vw,3rem) auto 0;width:min(1120px,94vw);min-height:clamp(220px,26vw,330px);padding:clamp(1.5rem,4vw,3rem);box-sizing:border-box;border:1px solid var(--surface-border);border-radius:22px;background:#070e199e;box-shadow:var(--shadow-md);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:1}.gallery-header-text{margin:0;max-width:980px;font-size:clamp(2.75rem,6vw,5rem);line-height:1.12;text-align:center;backdrop-filter:none;-webkit-backdrop-filter:none;border:0;background:transparent;box-shadow:none}.gallery-heading-copy{display:inline}.photo-gallery-content{width:min(1120px,94vw);margin:clamp(5rem,12vw,10rem) auto 0;box-sizing:border-box;padding:.35rem;overflow-x:hidden;background:#ffffff0e;border:1px solid var(--surface-border);border-radius:22px;box-shadow:var(--shadow-md);transition:background-color .4s cubic-bezier(.4,0,.2,1),color .4s cubic-bezier(.4,0,.2,1);position:relative;z-index:1}.photo-gallery-content,.photo-gallery-content *{pointer-events:auto!important}.react-photo-album--photo{margin:0;overflow:hidden;border:2px solid transparent;border-radius:14px;padding:0;transition:transform .25s ease,border-color .25s ease,background-color .4s cubic-bezier(.4,0,.2,1),color .4s cubic-bezier(.4,0,.2,1)}.react-photo-album--photo:hover{transform:scale(.985);border-color:#67e8f980}.react-photo-album--photo.cursor-target{cursor:pointer}.react-photo-album--photo>div{pointer-events:auto}.react-photo-album--photo img{pointer-events:none}.react-photo-album--photo img,.photo-gallery-content img{display:block;width:100%;object-fit:cover}.photo-item.cursor-target{cursor:pointer}.yet-another-react-lightbox,.yarl,.yarl__container,.yarl__root,.yarl__portal{z-index:999999!important}.yet-another-react-lightbox,.yarl,.yarl__container,.yarl__root,.yarl__portal,.pg-overlay,.yet-another-react-lightbox *,.yarl *{cursor:auto!important}.custom-lightbox-slide img{border-radius:6px;box-shadow:0 8px 28px #00000073}.custom-lightbox-caption{margin-top:.75rem;max-width:90%;text-align:center;color:var(--text-color);font-size:1rem;line-height:1.3}@media (max-width: 1024px){.gallery-header-text{font-size:clamp(2.5rem,7vw,3rem)}}@media (max-width: 640px){.photo-gallery{padding:clamp(5rem,16vw,6rem) 0 clamp(3rem,12vw,4rem)}.photo-gallery-header{padding-left:0;text-align:center}.photo-gallery-intro{margin-top:clamp(1rem,6vw,2rem);min-height:auto;padding:1rem;width:min(92vw,360px)}.gallery-header-text{font-size:clamp(1rem,5vw,1.35rem);line-height:1.25;text-align:center}.photo-gallery-content{margin:clamp(2rem,5vw,3.5rem) auto 0;padding:.5rem;width:min(94vw,390px)}}
