:root{--bg: #ffffff;--bg-secondary: #f9f9f9;--text: #111111;--muted: #777777;--border: #e5e5e5;--card-bg: #ffffff;--hover-bg: #f3f3f3}*{box-sizing:border-box}html{height:100%;margin:0;padding:0}body{height:100%;margin:0;padding:0;overflow:hidden;font-family:Didact Gothic,sans-serif;background:var(--bg);color:var(--text)}h1,h2,h3,h4,h5,h6{font-family:Be Vietnam Pro,sans-serif}#root{height:100%;width:100%;overflow:hidden}.scroll-snap-container{height:100%;width:100%;overflow-y:scroll;overflow-x:hidden;scroll-snap-type:y mandatory;scrollbar-width:none;-ms-overflow-style:none}.scroll-snap-container::-webkit-scrollbar{display:none}.full-screen-section{min-height:100vh;height:100vh;width:100%;scroll-snap-align:start;scroll-snap-stop:always;display:flex;flex-direction:column;justify-content:center;align-items:center;position:relative;overflow:hidden;flex-shrink:0}.full-screen-section>*{opacity:0;transform:translateY(10px);transition:opacity .4s ease-out,transform .4s ease-out}.full-screen-section.section-visible>*{opacity:1;transform:translateY(0)}.full-screen-section.gallery-section{justify-content:flex-start;align-items:stretch;overflow:hidden}.project-gallery-fullscreen{width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden;padding-top:80px}.project-gallery-topbar{display:flex;align-items:center;justify-content:space-between;padding:.75rem 2rem;border-bottom:1px solid var(--border);background:var(--bg);flex-shrink:0;z-index:10}.project-gallery-back{display:inline-flex;align-items:center;gap:.5rem;background:none;border:none;color:var(--muted);font-size:.95rem;font-family:inherit;cursor:pointer;padding:.4rem .75rem;border-radius:.375rem;transition:color .2s,background .2s}.project-gallery-back:hover{color:var(--text);background:var(--hover-bg)}.project-gallery-title{font-size:1rem;font-weight:600;color:var(--text);margin:0}.project-gallery-main{display:flex;flex:1;min-height:0;overflow:hidden;gap:1.25rem;padding:1.25rem 2rem}.project-gallery-thumbs{flex:0 0 130px;display:flex;flex-direction:column;gap:.6rem;overflow-y:auto;overflow-x:hidden;min-height:0;padding-right:.25rem;scrollbar-width:thin}.project-gallery-thumbs::-webkit-scrollbar{width:5px}.project-gallery-thumbs::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.project-gallery-thumbs::-webkit-scrollbar-thumb:hover{background:var(--muted)}.project-gallery-media{flex:1 1 0;min-width:0;display:flex;align-items:flex-start;justify-content:center;min-height:0}.project-gallery-media .pdf-video-section{width:100%;display:flex;align-items:flex-start;justify-content:center}.project-gallery-media .pdf-video-card{width:100%;max-width:100%;aspect-ratio:16 / 9;max-height:calc(100vh - 200px)}.project-gallery-media .pdf-video-card iframe,.project-gallery-media .pdf-video-card video{width:100%;height:100%;display:block;border:none}.project-gallery-media .pdf-hero-section{width:100%;display:flex;align-items:flex-start;justify-content:center}.project-gallery-media .pdf-hero-photo{max-width:100%;max-height:calc(100vh - 200px);overflow:hidden;cursor:pointer}.project-gallery-media .pdf-hero-photo img{max-width:100%;max-height:calc(100vh - 200px);object-fit:contain;display:block}.process-thumb{flex:0 0 auto;cursor:pointer;overflow:hidden;border-radius:4px;transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 1px 4px #0000001a}.process-thumb:hover{transform:scale(1.04);box-shadow:0 3px 10px #0003}.process-thumb img{width:100%;display:block;object-fit:cover}.project-gallery-info{flex:0 0 260px;padding-top:.5rem;overflow-y:auto}.thumbnail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;width:95%;max-width:1800px;margin:0 auto;padding:1rem;align-items:start}.thumbnail-card{position:relative;width:100%;aspect-ratio:12 / 7;overflow:hidden;box-shadow:0 2px 8px #0003;cursor:pointer;transition:transform .3s ease,box-shadow .3s ease}.thumbnail-card:hover{transform:scale(1.02);box-shadow:0 4px 16px #0000004d;z-index:10}.thumbnail-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.thumbnail-card:hover .thumbnail-overlay{opacity:1}.thumbnail-overlay-title{color:#fff;font-family:Be Vietnam Pro,sans-serif;font-size:1.25rem;font-weight:600;text-align:center;padding:1rem;text-shadow:0 1px 4px rgba(0,0,0,.4)}@media (max-width: 1200px){.project-gallery-info{flex:0 0 200px}.project-gallery-thumbs{flex:0 0 110px}.project-gallery-main{gap:1rem;padding:1rem 1.5rem}}@media (max-width: 900px){.project-gallery-main{flex-direction:column;padding:1rem;gap:1rem;overflow-y:auto}.project-gallery-thumbs{flex:0 0 auto;flex-direction:row;overflow-x:auto;overflow-y:hidden;max-height:100px;gap:.5rem;padding-right:0;padding-bottom:.25rem}.project-gallery-thumbs .process-thumb{height:80px;flex:0 0 auto}.project-gallery-thumbs .process-thumb img{height:100%;width:auto}.project-gallery-media{max-width:100%}.project-gallery-media .pdf-video-card,.project-gallery-media .pdf-hero-photo,.project-gallery-media .pdf-hero-photo img{max-height:45vh}.project-gallery-info{flex:0 0 auto}.project-gallery-topbar{padding:.75rem 1rem}.project-gallery-fullscreen{padding-top:60px}.thumbnail-grid{grid-template-columns:repeat(2,1fr);width:100%;padding:.75rem}}@media (max-width: 600px){.project-gallery-main{padding:.75rem;gap:.75rem}.project-gallery-thumbs{max-height:80px}.project-gallery-thumbs .process-thumb{height:60px}.project-gallery-media .pdf-video-card,.project-gallery-media .pdf-hero-photo,.project-gallery-media .pdf-hero-photo img{max-height:35vh}.project-gallery-fullscreen{padding-top:50px}.thumbnail-grid{grid-template-columns:repeat(2,1fr);gap:.35rem;padding:.5rem}.nav-inner{height:60px;padding:0 1rem}}@media (max-height: 700px){.project-gallery-media .pdf-video-card,.project-gallery-media .pdf-hero-photo{max-height:calc(100vh - 240px)}.project-gallery-process{height:100px;min-height:70px}}.section{scroll-margin-top:80px;padding:3rem 0;--section-opacity: 1;--section-translate: 0px;opacity:var(--section-opacity);transform:translateY(var(--section-translate))}#home.section{padding-top:0}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.container{max-width:1100px;margin:0 auto;padding:0 1rem}main.container{padding-top:96px}.nav{border-bottom:none;position:fixed;top:0;left:0;right:0;width:100%;background:transparent;z-index:1000;box-shadow:none}.nav-inner{display:flex;align-items:center;justify-content:space-between;height:80px;max-width:none;width:100%;padding:0 2rem}.nav-brand{display:flex;flex-direction:row;align-items:center;gap:12px}.nav-brand a{font-size:calc(1rem + 5pt);opacity:1;display:flex;align-items:center}.nav-logo{height:50px;width:auto;display:block}.nav-brand a:hover{opacity:1}.nav nav a{opacity:.7;transition:opacity .3s ease,background .3s ease}.nav nav a:hover{opacity:1}.nav-social-icons{display:flex;justify-content:center;gap:8px}.nav-social-icons .social-icon{margin-left:0;padding:2px}.about-socials{display:flex;gap:18px;align-items:center;justify-content:center}.about-socials .social-icon svg{width:30px;height:30px}.nav nav{display:flex;align-items:center}.nav a{margin-left:1rem;padding:.25rem .5rem;border-radius:.5rem}.nav a.active{background:var(--hover-bg)}.footer{border-top:1px solid var(--border);margin-top:4rem;padding:2rem 0;color:var(--muted);font-size:.9rem}.footer-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.footer-icons{display:flex;gap:1rem}.social-icon{color:var(--text);opacity:.7;transition:opacity .2s ease}.social-icon:hover{opacity:1}.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1rem}.card{border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--card-bg)}.card-body{padding:.75rem .9rem}.card-title{font-weight:600;margin:0 0 .25rem}.card-meta{color:var(--muted);font-size:.9rem}.hero{padding:0}.hero h1{font-size:clamp(2rem,2vw + 1.5rem,3rem);margin:0 0 .5rem}.hero p{color:var(--muted);margin:0}.btn{display:inline-block;border:1px solid var(--border);padding:.6rem .9rem;border-radius:.6rem;transition:background .15s ease}.btn:hover{background:#f6f6f6}.gallery-grid{margin:2rem 0 3rem}.project-page{max-width:1100px;margin:0 auto;padding:1rem 1rem 3rem}.back-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--muted);font-size:.95rem;margin-bottom:1.5rem;padding:.5rem 0;transition:color .2s ease}.back-link:hover{color:var(--text)}.project-header{margin-bottom:2rem;border-bottom:1px solid var(--border);padding-bottom:1.5rem}.project-header h1{font-size:2.25rem;margin:0 0 .5rem;font-weight:600}.project-count{color:var(--muted);margin:0}.project-video{margin-bottom:2.5rem}.project-video .card{max-width:900px;margin:0 auto}.project-gallery h2{font-size:1.5rem;margin:0 0 1.5rem;font-weight:600}.project-interactive-scroll{margin-top:2rem;margin-left:-1rem;margin-right:-1rem;width:calc(100% + 2rem)}.project-interactive-scroll h2{font-family:Be Vietnam Pro,sans-serif}@media (min-width: 700px){.col-3{grid-column:span 3}.col-4{grid-column:span 4}.col-6{grid-column:span 6}.col-12{grid-column:span 12}}@media (max-width: 699px){.col-12{grid-column:span 12}.project-header h1{font-size:1.75rem}}.auto-preview{display:flex;align-items:center;justify-content:center;width:100%;height:100%;position:relative;overflow:hidden;background:#000}.media-wrap{width:100%;height:100%;display:flex;align-items:center;justify-content:center;opacity:1;transform:scale(1)}.media{width:100%;height:100%;object-fit:cover;display:block}.auto-preview-title{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:30;color:#fff;pointer-events:none;font-weight:700;font-size:clamp(2.5rem,4vw + 1rem,4rem);text-align:center}.preview-container{position:relative;width:100%;height:100%}.preview-container .preview-text{position:absolute;top:12px;left:24px;z-index:20;pointer-events:none}.preview-container .preview-text h1,.preview-container .preview-text p{margin:0}.preview-container .preview-text h1{color:var(--text-color, #fff)}.preview-container .preview-text p{color:var(--muted-text-color, #fff);opacity:.92}.contact-page-fullscreen{display:flex;flex-direction:column;justify-content:center;align-items:center;width:100%}.contact-header-fullscreen{margin-bottom:2rem;text-align:center}.contact-header-fullscreen h1{font-size:3rem;margin:0;font-weight:600}.contact-content-fullscreen{display:flex;gap:3rem;max-width:1000px;width:100%;align-items:flex-start}.contact-info-fullscreen{flex:0 0 300px}.contact-form-fullscreen{flex:1}.contact-page{padding:2rem 0;max-width:1000px;margin:0 auto}.contact-header{text-align:center;margin-bottom:3rem}.contact-header h1{font-size:2.5rem;font-weight:600;margin:0 0 .5rem}.contact-subtitle{color:var(--muted);font-size:1.1rem;margin:0}.contact-content{display:grid;grid-template-columns:1fr 2fr;gap:3rem;padding:0 1.5rem}.contact-info h2{font-size:1.25rem;font-weight:600;margin:0 0 1.5rem}.contact-info p{margin:0 0 1rem;line-height:1.6}.contact-info a{color:var(--text);text-decoration:underline}.contact-info a:hover{opacity:.7}.contact-note{color:var(--muted);font-size:.95rem}.contact-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:500;font-size:.95rem}.form-group input,.form-group textarea{padding:.75rem 1rem;border:1px solid var(--border);border-radius:.375rem;font-size:1rem;font-family:inherit;transition:border-color .2s ease,box-shadow .2s ease;background:var(--card-bg);color:var(--text)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--text);box-shadow:0 0 0 3px #0000000d}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--muted)}.form-group textarea{resize:vertical;min-height:120px}.submit-btn{padding:.875rem 2rem;background:var(--text);color:var(--bg);border:none;border-radius:.375rem;font-size:1rem;font-weight:500;cursor:pointer;transition:opacity .2s ease,transform .2s ease;align-self:flex-start}.submit-btn:hover:not(:disabled){opacity:.85;transform:translateY(-1px)}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.form-status{padding:1rem;border-radius:.375rem;margin-top:.5rem;font-size:.95rem}.form-status.success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.form-status.error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}@media (max-width: 768px){.contact-content-fullscreen{flex-direction:column;gap:2rem}.contact-info-fullscreen{flex:1;text-align:center}.contact-header-fullscreen h1{font-size:2rem}.contact-content{grid-template-columns:1fr;gap:2rem}.contact-header h1{font-size:2rem}.contact-info{text-align:center}.submit-btn{width:100%}}.pdf-layout{display:grid;grid-template-columns:1fr 380px;gap:3rem;max-width:1400px;margin:0 auto;padding:0 1.5rem;min-height:100vh}.pdf-media-column{display:flex;flex-direction:column;gap:1.5rem}.pdf-video-section{width:100%}.pdf-video-card{overflow:hidden;background:#000;box-shadow:0 8px 32px #0000001f;max-width:900px;aspect-ratio:16 / 9}.pdf-video-card iframe,.pdf-video-card video{width:100%;height:100%;display:block;border:none}.pdf-video-info{background:var(--card-bg);padding:1rem 1.25rem;border:1px solid var(--border);border-top:none}.pdf-video-title{font-size:1.1rem;font-weight:600;margin:0 0 .25rem}.pdf-video-meta{color:var(--muted);font-size:.9rem}.pdf-hero-section{width:100%;margin-bottom:1.5rem}.pdf-hero-photo{overflow:hidden;background:#000;box-shadow:0 8px 32px #0000001f;cursor:pointer;transition:box-shadow .3s ease}.pdf-hero-photo:hover{box-shadow:0 12px 40px #0000002e}.pdf-hero-photo img{width:100%;height:auto;display:block}.pdf-hero-info{background:var(--card-bg);padding:1rem 1.25rem;border:1px solid var(--border);border-top:none}.pdf-hero-title{font-size:1.1rem;font-weight:600;margin:0}.pdf-photo-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;align-items:start}.pdf-photo-column{display:flex;flex-direction:column;gap:1rem}.pdf-photo-item{break-inside:avoid;margin-bottom:1rem;overflow:hidden;background:linear-gradient(145deg,var(--bg-secondary) 0%,var(--border) 100%);box-shadow:0 4px 16px #00000014;transition:transform .3s ease,box-shadow .3s ease;cursor:pointer}.pdf-photo-item:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000001f}.pdf-photo-item img{width:100%;height:auto;display:block}.pdf-photo-caption{padding:.75rem 1rem;background:var(--card-bg);font-size:.85rem;color:var(--muted);border-top:1px solid var(--border)}.pdf-text-column{padding-top:.5rem}.pdf-title{font-size:2rem;font-weight:600;margin:0 0 .5rem;line-height:1.2}.pdf-subtitle{color:var(--muted);font-size:.95rem;margin:0 0 2rem}.pdf-description{font-size:1.05rem;line-height:1.8;color:var(--text);margin:0 0 2rem}.pdf-programs{font-size:1rem;line-height:1.8;color:var(--text);margin:0 0 1.25rem}.pdf-programs strong{font-weight:600}.pdf-programs strong{color:var(--text);font-weight:600}.pdf-plain-text{line-height:1.8}.pdf-process-text{font-size:1rem;line-height:1.8;color:var(--text);margin:0 0 1.25rem}.pdf-process-text strong{font-weight:600}.pdf-back-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--muted);font-size:.95rem;padding:1rem 1.5rem;transition:color .2s ease}.pdf-back-link:hover{color:var(--text)}@media (max-width: 1000px){.pdf-layout{grid-template-columns:1fr;gap:2rem}.pdf-text-column{position:relative;top:0;max-height:none;order:-1}.pdf-photo-grid{grid-template-columns:1fr 1fr}}@media (max-width: 600px){.pdf-layout{padding:0 1rem}.pdf-photo-grid{grid-template-columns:1fr}.pdf-title{font-size:1.5rem}}.lightbox-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000f2;z-index:1000;display:flex;align-items:center;justify-content:center;cursor:pointer}.lightbox-close{position:absolute;top:1rem;right:1.5rem;background:none;border:none;color:#fff;font-size:2.5rem;cursor:pointer;opacity:.7;transition:opacity .2s ease;z-index:1001}.lightbox-close:hover{opacity:1}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:none;border:none;color:#fff;font-size:4rem;cursor:pointer;opacity:.7;transition:opacity .2s ease;padding:1rem;z-index:1001}.lightbox-nav:hover{opacity:1}.lightbox-prev{left:1rem}.lightbox-next{right:1rem}.lightbox-content{display:flex;flex-direction:column;align-items:center;max-width:90vw;max-height:90vh;cursor:default}.lightbox-content img{max-width:100%;max-height:80vh;object-fit:contain;border-radius:4px}.lightbox-caption{color:#fff;font-size:1rem;margin-top:1rem;text-align:center}.lightbox-credits{color:#fffffff2;font-size:.95rem;margin-top:.5rem;text-align:center}.lightbox-credits p{margin:.15rem 0}.lightbox-credits p:first-child{font-weight:700;text-transform:uppercase;letter-spacing:.04em}.lightbox-counter{color:#fff9;font-size:.85rem;margin-top:.5rem}@media (max-width: 600px){.lightbox-nav{font-size:2.5rem;padding:.5rem}.lightbox-prev{left:.5rem}.lightbox-next{right:.5rem}}
