.footer{background:var(--bg-primary);padding:1.5rem 0 2.5rem;display:flex;justify-content:center;align-items:center;width:100%;min-height:auto;text-align:center;margin:0}.footer-content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;max-width:1200px;width:100%;text-align:center;margin:0 auto;padding:0 1.5rem}.social-icons{display:flex;gap:1.5rem;align-items:center;justify-content:center}.social-link{display:flex;align-items:center;justify-content:center;padding:.5rem;color:var(--text-muted);text-decoration:none;border-radius:.5rem;transition:all .3s ease;cursor:pointer}.social-link:hover{color:var(--text-primary)}.social-link:focus{outline:2px solid var(--text-primary);outline-offset:2px}.social-link svg{width:18px;height:18px;transition:none}.social-link:hover svg{transform:none}.copyright{font-size:.75rem;color:var(--text-muted);text-align:center;opacity:.8;font-weight:400}@media (max-width: 768px){.footer{padding:1rem 0 2.25rem;min-height:auto}.footer-content{padding:0 1rem}.social-icons{gap:1rem}.social-link{padding:.4rem}.social-link svg{width:16px;height:16px}.copyright{font-size:.7rem}}:root{--bg-primary: #f4f3f1;--bg-secondary: #faf9f7;--text-primary: #222;--text-secondary: #555;--text-muted: #aaa;--border-color: #eee;--shadow-color: rgba(0,0,0,.08);--shadow-light: rgba(0,0,0,.06);--nav-bg: #faf9f7;--nav-shadow: rgba(0,0,0,.08);--card-bg: #faf9f7;--video-bg: #000;--home-title-color: #222}*{box-sizing:border-box}html{margin:0;padding:0;width:100%}.dark{--bg-primary: #1F2020;--bg-secondary: #1a1a1a;--text-primary: #ffffff;--text-secondary: #cccccc;--text-muted: #888888;--border-color: #333333;--shadow-color: rgba(0,0,0,.3);--shadow-light: rgba(0,0,0,.2);--nav-bg: #1a1a1a;--nav-shadow: rgba(0,0,0,.3);--card-bg: #1a1a1a;--video-bg: #000;--home-title-color: #ffffff}#root{margin:0;padding:0;text-align:center;width:100%;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:var(--text-muted)}body{margin:0;padding:0;font-family:system-ui,sans-serif;background:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease;overflow-x:hidden;width:100%;box-sizing:border-box}.nav{display:flex;gap:1.5rem;padding:.5rem 1.5rem;background:var(--nav-bg);border-radius:1.5rem;box-shadow:0 4px 16px var(--nav-shadow);margin:0;width:fit-content;align-items:center;min-height:unset;transition:background-color .3s ease,box-shadow .3s ease;position:fixed;left:50%;transform:translate(-50%);z-index:1000}.nav-link.active{color:var(--text-primary);background:none;border-radius:0}.nav-link:hover{color:var(--text-primary);background:none;text-decoration:none}.theme-toggle{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:color .15s ease,background-color .15s ease;margin-left:.5rem}.theme-toggle:hover{color:var(--text-primary);background-color:var(--shadow-light)}main.legacy{max-width:1400px;margin:2rem auto;padding:0 3rem}.title{font-size:2.5rem;margin-bottom:1rem;color:var(--text-primary)}.tagline{font-size:1.2rem;color:var(--text-secondary);margin-bottom:2.5rem}.video-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2.5rem}.video-item{display:flex;flex-direction:column;align-items:center}.video-responsive{position:relative;width:100%;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:8px;box-shadow:0 2px 8px var(--shadow-light);background:var(--video-bg);transition:box-shadow .3s ease}.video-responsive iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}.video-title{margin-top:1rem;font-size:1rem;color:var(--text-primary)}.contact{margin-top:3rem;text-align:center}@media (max-width: 600px){.portfolio-container{padding:0 1rem}.portfolio-sidebar{margin-left:0;margin-right:1.5rem;padding-right:1rem;width:auto;min-width:auto}.sidebar-btn{padding:.4rem 0;font-size:13px}.sidebar-btn:hover,.sidebar-btn.active,.sidebar-btn.hovered{color:var(--text-primary);background:none}}.portfolio-sidebar{min-width:110px;border-right:2px solid var(--border-color);padding:1.5rem 2rem 1.5rem 0;margin-right:1.5rem;display:flex;flex-direction:column;align-items:flex-end;text-align:right;height:100%;justify-content:center;width:110px;gap:.5rem;transition:border-color .3s ease}.sidebar-section{margin-bottom:2rem;width:100%}.sidebar-section-title{font-size:.55rem;font-weight:700;letter-spacing:.05em;margin-bottom:.5rem;text-align:right;width:100%;padding:0}.sidebar-btn{background:none;border:none;border-radius:0;color:var(--text-muted);font-weight:500;padding:.4rem 0;cursor:pointer;font-size:14px;outline:none;transition:color .15s ease;text-align:right;display:block;width:100%;margin-bottom:1rem;text-decoration:none}.sidebar-btn:hover,.sidebar-btn.active,.sidebar-btn.hovered{color:var(--text-primary);background:none}.sidebar-btn:disabled{color:var(--text-muted);opacity:.3;cursor:not-allowed}.portfolio-content{flex:1 1 auto;padding:2rem 0 1.5rem;text-align:left}.portfolio-title{margin-top:0;color:var(--text-primary)}.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:2rem;margin-bottom:2rem}.portfolio-item.large{grid-column:span 2;grid-row:span 2}.portfolio-item.medium,.portfolio-item.small{grid-column:span 1;grid-row:span 1}.item-container{background:var(--card-bg);border-radius:8px;overflow:hidden;box-shadow:0 2px 8px var(--shadow-light);transition:transform .3s ease,box-shadow .3s ease;cursor:pointer;height:100%}.item-container:hover{transform:translateY(-4px);box-shadow:0 4px 16px var(--shadow-color)}.item-thumbnail{position:relative;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;height:160px;overflow:hidden}.thumbnail-icon{font-size:2.5rem;opacity:.8}.play-overlay{position:absolute;inset:0;background:#0000004d;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.item-container:hover .play-overlay{opacity:1}.play-icon{width:30px;height:30px;background:#ffffffe6;border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;transition:transform .2s ease}.play-icon:hover{transform:scale(1.1);background:#fff}.play-icon:before{content:"";width:0;height:0;border-left:9px solid #333;border-top:6px solid transparent;border-bottom:6px solid transparent;margin-left:2px}.item-info{padding:1.25rem;display:flex;justify-content:space-between;align-items:center}.item-title{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.item-duration{font-size:.875rem;color:var(--text-muted);background:var(--shadow-light);padding:.25rem .5rem;border-radius:4px}.portfolio-card{border-radius:8px;overflow:hidden;box-shadow:0 2px 8px var(--shadow-light);background:var(--card-bg);transition:box-shadow .3s ease,background-color .3s ease}.video-container{position:relative;width:100%;padding-bottom:56.25%;height:0;background:var(--video-bg)}.video-container iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}.photo-image{width:100%;height:220px;object-fit:cover}.card-title{padding:.5rem;text-align:center;font-size:16px;color:var(--text-primary)}.portfolio-details-title{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:1.5rem;margin-top:3rem;line-height:1.2}.portfolio-details-desc{color:var(--text-secondary);line-height:1.8;font-size:1.1rem;margin-bottom:2.5rem}.portfolio-details-meta{margin-bottom:2.5rem}.meta-item{display:flex;margin-bottom:.75rem;align-items:center}.meta-label{font-weight:600;color:var(--text-primary);min-width:80px;font-size:.9rem}.meta-value{color:var(--text-secondary);font-size:.9rem}.mux-video-container{width:100%;background:var(--video-bg)}.loading-spinner{width:24px;height:24px;border:2px solid var(--border-color);border-top:2px solid var(--accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:2rem;margin-bottom:3rem}@media (max-width: 768px){.portfolio-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}}.portfolio-item{cursor:pointer;transition:transform .2s ease}.portfolio-item:hover{transform:scale(1.02)}.item-thumbnail img{transition:opacity .3s ease}.item-container:hover .item-thumbnail img{opacity:.9}html{scroll-behavior:smooth}.single-page-container{width:100%;min-height:100vh;position:relative;margin:0;padding:0}.single-page-container main{margin:0 auto;max-width:none;width:100%}.scroll-container{width:100%;overflow-y:auto;overflow-x:hidden;scroll-snap-type:y proximity}.section{min-height:100vh;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 0 3rem;scroll-snap-align:start;position:relative}.section-home{min-height:100vh;padding:0;justify-content:flex-start;overflow:visible}.section-portfolio{min-height:100vh;padding-top:3rem;padding-bottom:4rem}.section-about{min-height:100vh;display:flex;align-items:center;justify-content:center}.section-footer{min-height:auto;padding:0;display:flex;align-items:center;justify-content:center}.nav{position:fixed;left:50%;transform:translate(-50%);z-index:100;transition:background-color .3s ease,box-shadow .3s ease;will-change:top}.nav-link{text-decoration:none;color:var(--text-muted);font-weight:500;padding:.5rem 1rem;transition:color .15s;background:none;border:none;border-radius:0;position:relative;cursor:pointer;font-size:16px;font-family:inherit}.home{width:100%;max-width:none;margin:0;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;position:relative;padding:0;overflow:visible;min-height:100vh}.home-title-wrapper{display:flex;align-items:center;justify-content:center;margin:3.6rem auto 1.75rem;z-index:10;position:relative}.home-title{font-size:1.05rem;font-weight:800;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;letter-spacing:.22em;text-transform:uppercase;color:var(--home-title-color);text-align:center;white-space:nowrap;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;margin:0;padding:5px 1rem}.cursor-lines{display:flex;flex-direction:row;align-items:center}.cursor-line{opacity:.6}.home-video-wrapper{position:relative;top:0;left:0;width:100%;max-width:100%;height:62.5vh;min-height:400px;max-height:62.5vw;aspect-ratio:1.6 / 1;display:flex;justify-content:center;align-items:center;margin:2rem auto 0;padding:0;overflow:hidden;z-index:1;box-sizing:border-box}.home-video-container{position:absolute;left:0;right:0;top:0;width:100%;height:100%;overflow:hidden;display:flex;justify-content:center;align-items:center;margin:0;box-sizing:border-box}.home-video{width:100%;height:100%;object-fit:cover;object-position:center;background:#000;transform:translateZ(0);backface-visibility:hidden;min-height:100%;min-width:100%}.home-video-loading{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;z-index:2}.portfolio-container{width:100%;max-width:none;margin:0;display:flex;padding:0 2rem;min-height:auto;height:auto;overflow:visible;box-sizing:border-box;justify-content:center;align-items:flex-start;contain:layout style}.portfolio-inner-wrapper{display:flex;width:100%;max-width:1300px;align-items:flex-start;margin:0 auto}.portfolio-content{overflow-y:visible;height:auto;flex:1;max-width:none;padding:0}.about{max-width:1300px;margin:0 auto;width:100%;padding:0 2rem}.about-content{display:flex;gap:3rem;align-items:flex-start;margin-bottom:3rem}.about-image-display{flex:0 0 400px;height:500px;border:3px solid #333;border-radius:20px;overflow:hidden;position:relative}.display-image{width:100%;height:100%;object-fit:cover;transition:opacity .3s ease}.about-text-section{flex:1;text-align:left;padding-top:2rem}.about-title{color:var(--text-primary);margin-bottom:1.5rem;font-size:2.5rem;font-weight:700;text-align:left}.about-text{color:var(--text-secondary);line-height:1.6;font-size:1.1rem;margin-bottom:1rem}.gallery-container{margin-top:2rem}.photo-gallery{display:flex;gap:1.5rem;overflow-x:auto;padding:1rem 0;scrollbar-width:thin;scrollbar-color:#ccc transparent}.photo-gallery::-webkit-scrollbar{height:8px}.photo-gallery::-webkit-scrollbar-track{background:transparent}.photo-gallery::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}.photo-gallery::-webkit-scrollbar-thumb:hover{background:#999}.gallery-photo{flex:0 0 120px;height:120px;border:3px solid #333;border-radius:15px;overflow:hidden;cursor:pointer;transition:all .3s ease;opacity:.7}.gallery-photo:hover{opacity:.9;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.gallery-photo.active{opacity:1;border-color:var(--text-primary, #333);transform:translateY(-2px);box-shadow:0 4px 12px #0003}.gallery-image{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.gallery-photo:hover .gallery-image{transform:scale(1.05)}@media (max-width: 768px){.about-content{flex-direction:column;gap:2rem}.about-image-display{flex:none;width:100%;max-width:350px;height:400px;margin:0 auto}.about-text-section{text-align:center;padding-top:0}.about-title{text-align:center}.gallery-photo{flex:0 0 100px;height:100px}}@media (max-width: 480px){.photo-gallery{gap:1rem}.gallery-photo{flex:0 0 80px;height:80px}}@media (max-width: 1024px) and (min-width: 769px){.home-title-wrapper{margin:3rem auto 1.5rem}.home-title{font-size:1.1rem;letter-spacing:.3em;padding:5px 1rem}.cursor-lines{transform:scale(.9)}}@media (max-width: 768px){.section{padding:3rem 0 2rem}.section-home{padding:0}.section-portfolio{padding-top:2.5rem}.home-title-wrapper{margin:0;position:fixed;top:1.5rem;left:50%;transform:translate(-50%);z-index:10}.home-title{font-size:1rem;font-weight:800;letter-spacing:.25em;padding:5px 1rem;max-width:calc(100vw - 2rem);white-space:normal;line-height:1.2;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.5);margin:0;text-align:center}.cursor-lines{display:none}.home{padding-top:62.5vw}.home-video-wrapper{position:fixed;top:2rem;left:0;width:100%;height:62.5vh;min-height:400px;max-height:62.5vw;aspect-ratio:1.6 / 1;margin:0;padding:0;overflow:hidden;z-index:1;box-sizing:border-box}.home-video-container{position:absolute;left:0;right:0;top:0;width:100%;height:100%;overflow:hidden;margin:0;box-sizing:border-box}.home-video{width:100%;height:100%;object-fit:cover;object-position:center;transform:translateZ(0);backface-visibility:hidden;min-height:100%;min-width:100%}}@media (max-width: 480px){.home-title-wrapper{top:1rem}.home-title{font-size:.9rem;letter-spacing:.2em;padding:5px .5rem;max-width:calc(100vw - 1rem);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}}@media (prefers-reduced-motion: no-preference){.section{animation:fadeIn .6s ease-in-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}}.youtube-layout{display:grid;grid-template-columns:1fr 280px;gap:.75rem;width:100%;align-items:start;max-width:100vw;overflow:visible}.main-video-section{min-width:0;display:flex;flex-direction:column;margin-left:1rem}.main-video-player{width:100%;max-width:900px;aspect-ratio:16/9;position:relative;background:#000;border-radius:8px;overflow:hidden;margin-bottom:0;box-sizing:border-box}.main-video-player .mux-video-container{position:absolute;top:0;left:0;width:100%;height:100%;transition:all .3s ease}.video-details{padding:1.5rem 0 0;text-align:left}.video-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 .25rem;line-height:1.3;word-wrap:break-word;overflow-wrap:break-word}.video-metadata{display:flex;flex-direction:row;align-items:center;gap:.75rem;color:var(--text-secondary);font-size:.95rem;margin-bottom:1rem}.video-duration{color:var(--text-primary);font-weight:600}.video-client{display:inline-block;background:var(--text-primary);color:var(--bg-primary);padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:500}.video-year{color:var(--text-secondary);font-size:.75rem;font-weight:500}.video-description{color:var(--text-secondary);line-height:1.6;font-size:1rem}.video-description p{margin:0}.playlist-sidebar{width:280px;min-width:280px;max-width:280px;border:2px solid var(--border-color);border-radius:12px;padding:1rem;display:flex;flex-direction:column;flex-shrink:0;box-sizing:border-box;align-self:start}.playlist-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;text-align:left}.playlist-header h3{margin:0;font-size:1.2rem;font-weight:600;color:var(--text-primary)}.playlist-count{color:var(--text-secondary);font-size:.9rem}.playlist-content{flex:1;overflow-y:auto}.playlist-content::-webkit-scrollbar{width:6px}.playlist-content::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:3px}.playlist-content::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:3px}.playlist-content::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.playlist-item{display:flex;gap:.5rem;padding:.4rem;border-radius:8px;cursor:pointer;transition:all .15s ease;margin-bottom:.2rem}.playlist-item:hover{background:none;transform:none}.playlist-item:hover .play-overlay{opacity:1}.playlist-item:hover .playlist-title{color:var(--text-primary)}.playlist-item:hover .playlist-client{color:var(--text-secondary)}.playlist-item.active{background:none}.playlist-item.active .playlist-title{color:var(--text-primary);font-weight:600}.playlist-thumbnail{position:relative;width:95px;height:53px;flex-shrink:0;border-radius:6px;overflow:hidden;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center}.playlist-thumbnail img{width:100%;height:100%;object-fit:cover}.placeholder-thumbnail{font-size:1.5rem;opacity:.8}.playlist-duration{position:absolute;bottom:4px;right:4px;background:#000c;color:#fff;padding:2px 4px;border-radius:3px;font-size:.75rem;font-weight:500}.playlist-info{flex:1;min-width:0;text-align:left}.playlist-title{margin:0 0 .2rem;font-size:.85rem;font-weight:500;color:var(--text-muted);line-height:1.2;transition:color .15s ease;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.playlist-client{margin:0;font-size:.75rem;color:var(--text-muted);transition:color .15s ease;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 1100px){.youtube-layout{display:flex;flex-direction:column;gap:1rem}.main-video-section{margin-left:0}.main-video-player{width:100%;max-width:640px;aspect-ratio:16/9;margin-bottom:0}.playlist-sidebar{width:100%;min-width:0;max-width:none;height:auto!important;min-height:300px;box-sizing:border-box}.playlist-item{padding:.5rem;gap:.5rem}.playlist-thumbnail{width:95px;height:53px}}@media (max-width: 1000px) and (min-width: 769px){.playlist-sidebar{width:260px;min-width:260px;max-width:260px;padding:.8rem;box-sizing:border-box}.main-video-player{max-width:800px;aspect-ratio:16/9;margin-bottom:0}.playlist-thumbnail{width:85px;height:48px}.playlist-title{font-size:.8rem}.playlist-client{font-size:.7rem}}@media (max-width: 768px){.youtube-layout{gap:1.5rem}.main-video-player{margin-bottom:0;width:100%;max-width:480px;aspect-ratio:16/9}.playlist-sidebar{width:100%;min-width:0;max-width:none;height:auto!important;min-height:250px;box-sizing:border-box}.video-title{font-size:1.25rem}.video-metadata{font-size:.9rem}.playlist-header h3{font-size:1.1rem}.playlist-item{gap:.5rem;padding:.5rem}.playlist-thumbnail{width:95px;height:53px}.playlist-title{font-size:.85rem}.playlist-client{font-size:.75rem}}
