*,*:before,*:after{box-sizing:border-box}:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.5;font-weight:400;color:#222;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}img{max-width:100%;height:auto}a{color:inherit;text-decoration:none}.navbar{position:sticky;top:0;z-index:100;background:#fff;border-bottom:1px solid #e8e8e8}.navbar-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;height:64px}.navbar-brand{font-size:1.1rem;font-weight:600;letter-spacing:.2em;color:#111;text-decoration:none}.navbar-links{list-style:none;display:flex;gap:2rem;margin:0;padding:0}.navbar-links a{color:#888;text-decoration:none;font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;transition:color .2s;padding:.25rem 0}.navbar-links a:hover,.navbar-links a.active{color:#111}.navbar-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}.navbar-toggle span{display:block;width:24px;height:2px;background:#222;transition:transform .3s,opacity .3s}.navbar-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.navbar-toggle.open span:nth-child(2){opacity:0}.navbar-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}@media(max-width:640px){.navbar-toggle{display:flex}.navbar-links{position:absolute;top:64px;left:0;right:0;flex-direction:column;background:#fff;border-bottom:1px solid #e8e8e8;gap:0;max-height:0;overflow:hidden;transition:max-height .3s ease}.navbar-links.open{max-height:200px}.navbar-links li{border-top:1px solid #e8e8e8}.navbar-links a{display:block;padding:1rem 1.5rem}}.thumbnail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.thumbnail-grid.mixed-orientations{grid-template-columns:repeat(3,1fr)}.thumbnail-card{text-decoration:none;color:inherit;display:block;border-radius:4px;overflow:hidden;background:#fff;border:1px solid #eee;transition:transform .2s,box-shadow .2s}.thumbnail-card.landscape-span{grid-column:span 2}.thumbnail-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000014}.thumbnail-img-wrapper{position:relative;width:100%;aspect-ratio:16 / 10;overflow:hidden;background:#f5f5f5}.thumbnail-img-wrapper.portrait{aspect-ratio:3 / 4}.thumbnail-img-wrapper img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}.thumbnail-card:hover .thumbnail-img-wrapper img{transform:scale(1.05)}.thumbnail-title{padding:.75rem 1rem;font-size:.9rem;font-weight:500;color:#333;margin:0}@media(max-width:640px){.thumbnail-grid,.thumbnail-grid.mixed-orientations{grid-template-columns:1fr;gap:1rem}.thumbnail-card.landscape-span{grid-column:span 1}}.home-page{padding:2rem 0}.section{margin-bottom:3rem}.section-heading{font-size:.8rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:#999;margin-bottom:1.25rem;padding-bottom:.5rem;border-bottom:1px solid #e8e8e8}.loading{display:flex;align-items:center;justify-content:center;min-height:60vh;color:#aaa;font-size:.9rem;letter-spacing:.1em}.detail-page{padding:2rem 0;max-width:900px;margin:0 auto}.back-link{display:inline-block;color:#999;text-decoration:none;font-size:.85rem;letter-spacing:.05em;margin-bottom:1.5rem;transition:color .2s}.back-link:hover{color:#111}.detail-title{font-size:1.5rem;font-weight:600;color:#111;margin:0 0 1.25rem;line-height:1.3}.detail-media{margin-bottom:1.5rem;border-radius:4px;overflow:hidden;background:#f5f5f5}.detail-image{width:100%;height:auto;display:block}.video-container{position:relative;width:100%;padding-top:56.25%}.video-container iframe,.video-container video{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.detail-description{color:#555;font-size:.95rem;line-height:1.7;margin:0 0 2%}.detail-links{list-style:none;padding:0;margin:0 0 1.25rem;display:flex;flex-wrap:wrap;gap:.5rem 1.25rem}.detail-links a{color:#444;font-size:.85rem;text-decoration:underline;text-underline-offset:2px;transition:color .2s}.detail-links a:hover{color:#000}.not-found{color:#999;font-size:.95rem}@media(max-width:640px){.detail-title{font-size:1.2rem}.detail-description{font-size:.9rem}}.page-element{margin-top:2.5rem;padding-top:2rem;border-top:1px solid #e8e8e8}.page-element-title{font-size:1.15rem;font-weight:600;color:#222;margin:0 0 1rem}.carousel{margin-bottom:1.5rem}.carousel-controls{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:.75rem}.carousel-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:1px solid #ddd;background:#fff;color:#333;cursor:pointer;transition:background .2s,border-color .2s;padding:0}.carousel-btn:hover{background:#f0f0f0;border-color:#bbb}.carousel-counter{font-size:.8rem;color:#999;letter-spacing:.05em;min-width:3rem;text-align:center}.about-page{padding:2rem 0}.about-content{max-width:800px;margin:0 auto}.about-heading{font-size:.8rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:#999;margin-bottom:2rem;padding-bottom:.5rem;border-bottom:1px solid #e8e8e8}.about-body{display:flex;gap:2.5rem;align-items:flex-start}.about-photo-wrapper{flex-shrink:0}.about-photo-placeholder{width:180px;height:220px;background:#f5f5f5;border-radius:4px;display:flex;align-items:center;justify-content:center;color:#ccc}.about-text p{color:#555;font-size:.95rem;line-height:1.7;margin:0 0 1rem}.about-contact{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e8e8e8}.about-contact h2{font-size:1rem;font-weight:600;color:#222;margin:0 0 .5rem}.about-contact p{color:#777;font-size:.9rem;margin:0 0 .75rem}.contact-link{color:#111;text-decoration:none;font-size:.9rem;border-bottom:1px solid #ccc;padding-bottom:2px;transition:border-color .2s}.contact-link:hover{border-color:#111}@media(max-width:640px){.about-body{flex-direction:column;align-items:center;text-align:center}.about-photo-placeholder{width:140px;height:170px}}.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}.footer{margin-top:4rem;padding:2rem 1.5rem;text-align:center;border-top:1px solid #e0e0e0}.footer p{color:#999;font-size:.75rem;letter-spacing:.05em;margin:0}
