*{margin:0;padding:0;box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#ffffffde;background-color:#000;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background:#000}#root{min-height:100vh}button{font-family:inherit;cursor:pointer}img{max-width:100%;display:block}.main-navigation{display:flex;justify-content:center;gap:3rem;padding:0;border:none;background:transparent}.main-navigation button{background:none;border:none;color:#ffffffb3;font-size:1rem;font-weight:300;letter-spacing:.1em;text-transform:uppercase;padding:.5rem 0;transition:all .3s ease;position:relative;text-shadow:0 2px 10px rgba(0,0,0,.8)}.main-navigation button:hover,.main-navigation button.active{color:#fff}.main-navigation button.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:#fff;box-shadow:0 0 10px #ffffff80}@media(max-width:768px){.main-navigation{gap:2rem;flex-wrap:wrap}.main-navigation button{font-size:.9rem}}.video-player-overlay{position:fixed;inset:0;background:#000000f2;z-index:1000;display:flex;align-items:center;justify-content:center;padding:2rem;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.video-player-container{position:relative;width:100%;max-width:1400px;max-height:90vh;display:flex;flex-direction:column}.close-button{position:absolute;top:-3rem;right:0;background:none;border:none;color:#fff;font-size:3rem;cursor:pointer;z-index:10;padding:0;width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;transition:opacity .2s}.close-button:hover{opacity:.7}.video-wrapper{position:relative;width:100%;background:#000;border-radius:2px;overflow:hidden}.video-wrapper video,.video-wrapper iframe{width:100%;height:auto;max-height:75vh;display:block}.video-wrapper iframe{aspect-ratio:16 / 9;height:75vh}.video-info{padding:1.5rem 0;color:#fff}.video-info h3{font-size:1.5rem;font-weight:400;margin-bottom:.5rem;letter-spacing:.02em}.video-info p{font-size:1rem;color:#999;line-height:1.6}@media(max-width:768px){.video-player-overlay{padding:1rem}.close-button{top:-2.5rem;font-size:2.5rem}.video-wrapper video{max-height:60vh}.video-info{padding:1rem 0}.video-info h3{font-size:1.2rem}.video-info p{font-size:.9rem}}.grid-item{cursor:pointer;position:relative;overflow:hidden;background:#111;border-radius:2px;transition:transform .3s ease}.grid-item:hover{transform:scale(1.02)}.grid-item-image{position:relative;width:100%;aspect-ratio:16 / 9;overflow:hidden}.grid-item-image img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.grid-item:hover .grid-item-image img{transform:scale(1.05)}.grid-item-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,#0003,#000c);display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding:2rem;opacity:0;transition:opacity .3s ease}.grid-item:hover .grid-item-overlay{opacity:1}.grid-item-title{font-size:1.8rem;font-weight:300;letter-spacing:.1em;text-transform:uppercase;color:#fff;margin:0 0 1rem;text-align:center;text-shadow:0 2px 20px rgba(0,0,0,.8);line-height:1.2}.play-icon{font-size:3rem;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.5);margin-top:auto}.grid-item-info{padding:1.5rem 1rem}.grid-item-info h3{font-size:1.1rem;font-weight:400;letter-spacing:.02em;color:#fff;margin-bottom:.75rem}.grid-item-description{font-size:.9rem;line-height:1.6;color:#999;font-weight:300;white-space:pre-line}.grid-item.highlighted{grid-column:span 1}.grid-item.highlighted .grid-item-image{aspect-ratio:16 / 9}@media(max-width:768px){.grid-item-info{padding:1rem .5rem}.grid-item-info h3{font-size:1rem}.play-icon{font-size:2.5rem}}.home-section{padding:0}.hero-video-container{width:100%;max-width:1400px;margin:0 auto;padding:4rem 4vw}.video-embed-wrapper{position:relative;width:100%;padding-bottom:56.25%;height:0;overflow:hidden;background:#000}.video-embed-wrapper iframe{position:absolute;top:0;left:0;width:100%;height:100%}.videos-grid-section{width:100%;padding:4rem 4vw;background:#000}.videos-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;max-width:1400px;margin:0 auto}.home-contact-section{width:100%;padding:6rem 4vw;background:#0a0a0a;border-top:1px solid #222}.home-contact-container{max-width:900px;margin:0 auto;text-align:center}.home-contact-container h2{font-size:2rem;font-weight:300;letter-spacing:.1em;text-transform:uppercase;margin:0 0 3rem;color:#fff}.home-contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3rem;margin-bottom:3rem}.home-contact-item{display:flex;flex-direction:column;gap:.5rem}.contact-label{font-size:.8rem;font-weight:300;letter-spacing:.1em;text-transform:uppercase;color:#888}.contact-value{font-size:1rem;font-weight:300;color:#fff;text-decoration:none;transition:color .3s ease}a.contact-value:hover{color:#ccc}.home-social-links{display:flex;justify-content:center;gap:2rem;padding-top:2rem;border-top:1px solid #222}.social-link{font-size:.9rem;font-weight:300;letter-spacing:.1em;text-transform:uppercase;color:#888;text-decoration:none;transition:color .3s ease}.social-link:hover{color:#fff}@media(max-width:768px){.hero-video-container,.videos-grid-section{padding:3rem 5vw}.videos-grid{grid-template-columns:1fr;gap:1.5rem}.home-contact-section{padding:4rem 5vw}.home-contact-container h2{font-size:1.5rem;margin-bottom:2rem}.home-contact-grid{grid-template-columns:1fr;gap:2rem}.home-social-links{flex-direction:column;gap:1rem}}.photo-gallery-overlay{position:fixed;inset:0;background:#000000f2;z-index:1000;display:flex;align-items:center;justify-content:center;padding:2rem;animation:fadeIn .3s ease}.photo-gallery-container{position:relative;width:100%;max-width:1400px;max-height:90vh;display:flex;flex-direction:column}.photo-display{position:relative;display:flex;align-items:center;justify-content:center;margin-bottom:2rem}.photo-display img{max-width:100%;max-height:65vh;object-fit:contain;border-radius:2px}.nav-button{position:absolute;background:#ffffff1a;border:none;color:#fff;font-size:3rem;width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s;border-radius:50%}.nav-button:hover{background:#fff3}.nav-button.prev{left:1rem}.nav-button.next{right:1rem}.photo-info{text-align:center;color:#fff;margin-bottom:1.5rem}.photo-info h3{font-size:1.5rem;font-weight:400;margin-bottom:.5rem;letter-spacing:.02em}.photo-counter{font-size:.9rem;color:#999;margin-bottom:.5rem}.photo-info p{font-size:1rem;color:#999;line-height:1.6}.thumbnail-strip{display:flex;gap:.5rem;overflow-x:auto;padding:.5rem 0;justify-content:center}.thumbnail-strip img{width:80px;height:60px;object-fit:cover;cursor:pointer;opacity:.5;transition:opacity .2s;border-radius:2px}.thumbnail-strip img:hover{opacity:.8}.thumbnail-strip img.active{opacity:1;outline:2px solid #fff}@media(max-width:768px){.photo-gallery-overlay{padding:1rem}.photo-display img{max-height:50vh}.nav-button{font-size:2rem;width:2.5rem;height:2.5rem}.nav-button.prev{left:.5rem}.nav-button.next{right:.5rem}.photo-info h3{font-size:1.2rem}.photo-info p{font-size:.9rem}.thumbnail-strip{gap:.3rem}.thumbnail-strip img{width:60px;height:45px}}.portfolio-section{min-height:60vh}.all-work-section{padding:3rem 4vw 4rem}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(450px,1fr));gap:3rem;max-width:1800px;margin:0 auto}@media(max-width:768px){.grid{grid-template-columns:1fr;gap:2rem}.all-work-section{padding:2rem 5vw}}.about-section{min-height:60vh;padding:4rem 4vw}.about-container{max-width:900px;margin:0 auto}.bio-section,.cv-section{margin-bottom:4rem}.about-section h2{font-size:1.5rem;font-weight:300;letter-spacing:.1em;text-transform:uppercase;margin-bottom:2rem;color:#fff}.bio{font-size:1.2rem;line-height:1.8;color:#ccc;font-weight:300}.cv-items{display:flex;flex-direction:column;gap:2.5rem}.cv-item{border-left:1px solid #333;padding-left:1.5rem;transition:border-color .3s ease}.cv-item:hover{border-color:#666}.cv-item-header{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:.5rem}.cv-item h3{font-size:1.1rem;font-weight:400;color:#fff;margin:0}.cv-year{font-size:.9rem;color:#666;white-space:nowrap;font-weight:300}.cv-role{font-size:1rem;color:#999;margin-bottom:.5rem;font-weight:300}.cv-description{font-size:.95rem;color:#888;line-height:1.6;font-weight:300}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.skill-item{padding:1rem 1.5rem;background:#111;border-radius:2px;color:#ccc;font-size:.95rem;font-weight:300;text-align:center;border:1px solid #222}@media(max-width:768px){.about-section{padding:3rem 5vw}.about-section h2{font-size:1.2rem}.bio{font-size:1rem}.cv-item-header{flex-direction:column;align-items:flex-start;gap:.25rem}.cv-item h3{font-size:1rem}.skills-grid{grid-template-columns:1fr}}.contact-section{padding:3rem 4vw 4rem;min-height:60vh;display:flex;align-items:center;justify-content:center}.contact-container{max-width:700px;width:100%;text-align:center}.contact-section h2{font-size:2rem;font-weight:300;letter-spacing:.1em;text-transform:uppercase;margin-bottom:3rem;color:#fff}.contact-methods{display:flex;flex-direction:column;gap:2.5rem;margin-bottom:4rem}.contact-item h3{font-size:.85rem;font-weight:300;letter-spacing:.15em;text-transform:uppercase;color:#666;margin-bottom:.75rem}.contact-link{font-size:1.5rem;color:#fff;text-decoration:none;font-weight:300;transition:color .3s ease;display:inline-block}.contact-link:hover{color:#999}.contact-text{font-size:1.2rem;color:#ccc;font-weight:300}.social-links{border-top:1px solid #222;padding-top:2.5rem}.social-links h3{font-size:.85rem;font-weight:300;letter-spacing:.15em;text-transform:uppercase;color:#666;margin-bottom:1.5rem}.social-links-grid{display:flex;gap:2rem;justify-content:center;flex-wrap:wrap}.social-link{padding:.75rem 2rem;background:#111;border:1px solid #222;color:#ccc;text-decoration:none;font-size:.95rem;font-weight:300;letter-spacing:.05em;transition:all .3s ease;border-radius:2px}.social-link:hover{background:#1a1a1a;border-color:#444;color:#fff}@media(max-width:768px){.contact-section{padding:2rem 5vw}.contact-section h2{font-size:1.5rem}.contact-link{font-size:1.2rem}.social-links-grid{flex-direction:column;align-items:center}.social-link{width:100%;max-width:250px}}.app{min-height:100vh;background:#000;color:#fff}.loading,.error{display:flex;justify-content:center;align-items:center;min-height:100vh;font-size:1.2rem;color:#888}.hero-header{position:relative;width:100%;height:70vh;min-height:500px;overflow:hidden;display:flex;flex-direction:column;justify-content:center;align-items:center}.hero-video-background{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0}.header-background-video,.header-background-image{width:100%;height:100%;object-fit:cover;object-position:center}.hero-header-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to bottom,#0006,#000000b3)}.hero-header-content{position:relative;z-index:10;text-align:center;padding:2rem}.hero-header-content h1{font-size:3.5rem;font-weight:300;letter-spacing:.15em;margin:0 0 1rem;text-transform:uppercase;text-shadow:0 2px 20px rgba(0,0,0,.8)}.hero-header-content .subtitle{font-size:1.2rem;font-weight:300;color:#ddd;margin:0 0 3rem;letter-spacing:.1em;text-shadow:0 2px 10px rgba(0,0,0,.8)}.main-content{position:relative;z-index:1}@media(max-width:768px){.hero-header{height:60vh;min-height:400px}.hero-header-content h1{font-size:2rem}.hero-header-content .subtitle{font-size:1rem;margin-bottom:2rem}}
