*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#fafafa;--fg:#111;--muted:#999;--border:#eee;--radius:2px;--transition:.3s ease}[data-theme=dark]{--bg:#0a0a0a;--fg:#e0e0e0;--muted:#666;--border:#1a1a1a}html{background:var(--bg);color:var(--fg);transition:background var(--transition), color var(--transition);scroll-behavior:smooth;font-family:Helvetica Neue,Helvetica,Arial,sans-serif}body{min-height:100vh}#root{flex-direction:column;min-height:100vh;display:flex}a{color:inherit;text-decoration:none}.banner{background:var(--fg);color:var(--bg);text-align:center;letter-spacing:.02em;padding:.5rem 1rem;font-size:.75rem}.header{justify-content:space-between;align-items:center;width:80vw;max-width:1200px;margin:0 auto;padding:1.5rem 2rem;display:flex}.logo{letter-spacing:.12em;transition:opacity var(--transition);font-size:1rem;font-weight:300}.logo:hover{opacity:.5}.header nav{align-items:center;gap:1.5rem;display:flex}.header nav a{color:var(--muted);transition:color var(--transition);letter-spacing:.03em;text-transform:uppercase;font-size:.8rem}.header nav a:hover,.header nav a.active{color:var(--fg)}.theme-toggle{cursor:pointer;opacity:.6;transition:opacity var(--transition), transform var(--transition);background:0 0;border:none;font-size:.85rem}.theme-toggle:hover{opacity:1;transform:rotate(20deg)}.menu-toggle{cursor:pointer;color:var(--fg);z-index:1001;background:0 0;border:none;padding:0;font-size:1.5rem;line-height:1;display:none}.menu-overlay{display:none}main{flex:1;width:80vw;max-width:1200px;margin:0 auto;padding:0 0 4rem}.hero{text-align:center;padding:6rem 0 5rem}.hero h1{display:none}.hero p{color:var(--muted);letter-spacing:.08em;font-size:1.3rem;font-weight:300}.album-grid{flex-direction:column;gap:4rem;display:flex}.album-card a{display:block;overflow:hidden}.album-card a:hover .album-card__thumb img{transform:scale(1.02)}.album-card__title{letter-spacing:.08em;text-align:center;margin-bottom:2.5rem;font-size:2.4rem;font-weight:300}.album-card__thumb{border-radius:var(--radius);width:100%;position:relative;overflow:hidden}.album-card__thumb img{width:100%;height:auto;transition:transform .8s;display:block}.album-card__placeholder{aspect-ratio:3/2;background:var(--border);opacity:.15;justify-content:center;align-items:center;font-size:3rem;display:flex}.pagination{text-align:center;margin-top:3rem}.pagination button{border:1px solid var(--border);color:var(--muted);cursor:pointer;letter-spacing:.03em;transition:all var(--transition);background:0 0;border-radius:999px;padding:.6rem 1.8rem;font-size:.75rem}.pagination button:hover{color:var(--fg);border-color:var(--fg)}.page{padding:2rem 0}.page h1{letter-spacing:-.02em;margin-bottom:1.5rem;font-size:1.8rem;font-weight:300}.album-page{padding:1rem 0}.album-header{text-align:center;margin-bottom:3rem}.back-link{color:var(--muted);transition:color var(--transition);margin-bottom:1.5rem;font-size:.8rem;display:inline-block}.back-link:hover{color:var(--fg)}.album-header h1{letter-spacing:-.02em;margin-bottom:.4rem;font-size:2rem;font-weight:300}.album-subtitle{color:var(--muted);margin-bottom:.5rem;font-size:1rem;font-style:italic}.album-meta{color:var(--muted);margin-bottom:1rem;font-size:.8rem}.album-categories{flex-wrap:wrap;justify-content:center;gap:.5rem;margin-bottom:1rem;display:flex}.tag{border:1px solid var(--border);color:var(--muted);text-transform:uppercase;letter-spacing:.06em;border-radius:999px;padding:.15rem .5rem;font-size:.65rem}.album-desc{color:var(--muted);max-width:550px;font-size:.9rem;line-height:1.7}.album-photos{flex-direction:column;gap:3rem;display:flex}.album-photo{width:100%}.album-photo img{border-radius:var(--radius);width:100%;height:auto;display:block}.photo-placeholder{border:1px dashed var(--border);border-radius:var(--radius);text-align:center;color:var(--muted);padding:5rem 2rem;font-size:.85rem}.related-albums{border-top:1px solid var(--border);margin-top:4rem;padding-top:2rem}.related-albums h3{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.8rem;font-size:.75rem;font-weight:400}.related-albums ul{gap:1.5rem;list-style:none;display:flex}.related-albums a{transition:opacity var(--transition);font-size:.9rem}.related-albums a:hover{opacity:.5}.map-container{border-radius:var(--radius);z-index:0;width:100%;height:550px}.locations-list{margin-top:3rem}.locations-list h2{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:1.5rem;font-size:.75rem;font-weight:400}.locations-grid{grid-template-columns:repeat(3,1fr);gap:1.2rem;display:grid}.location-item{border-radius:var(--radius);transition:background var(--transition);align-items:flex-start;gap:.8rem;padding:.8rem;display:flex}.location-item:hover{background:var(--border)}.location-flag{flex-shrink:0;font-size:1.4rem;line-height:1}.location-name{margin-bottom:.3rem;font-size:.85rem;font-weight:500;display:block}.location-albums{flex-direction:column;gap:.15rem;display:flex}.location-albums a{color:var(--muted);transition:color var(--transition);font-size:.75rem}.location-albums a:hover{color:var(--fg)}.about-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.about-header h1{margin-bottom:0}.lang-toggle{background:var(--border);border-radius:999px;gap:.3rem;padding:.2rem;display:flex}.lang-toggle button{cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:999px;padding:.25rem .5rem;font-size:.9rem;line-height:1}.lang-toggle button.active{background:var(--bg);box-shadow:0 1px 3px #00000014}[data-theme=dark] .lang-toggle button.active{box-shadow:0 1px 3px #0000004d}.about-page p{max-width:550px;color:var(--muted);margin-bottom:1.2rem;font-size:.9rem;line-height:1.8}.about-contact{border-top:1px solid var(--border);margin-top:1.5rem;padding-top:1.5rem}.about-contact h2{text-transform:uppercase;letter-spacing:.06em;color:var(--fg);margin-bottom:.8rem;font-size:.75rem;font-weight:400}.about-contact p{margin-bottom:1rem}.about-links{gap:1.5rem;display:flex}.about-links a{color:var(--fg);border-bottom:1px solid var(--border);transition:opacity var(--transition);padding-bottom:.1rem;font-size:.85rem}.about-links a:hover{opacity:.5}.about-gear{border-top:1px solid var(--border);padding-top:1.2rem;color:var(--muted)!important;margin-top:1rem!important;font-size:.8rem!important}.archives-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.archives-header h1{margin-bottom:0}.archives-sort{background:var(--border);border-radius:999px;gap:.3rem;padding:.2rem;display:flex}.archives-sort button{color:var(--muted);cursor:pointer;letter-spacing:.03em;transition:all var(--transition);background:0 0;border:none;border-radius:999px;padding:.35rem .9rem;font-size:.7rem}.archives-sort button.active{background:var(--bg);color:var(--fg);box-shadow:0 1px 3px #00000014}[data-theme=dark] .archives-sort button.active{box-shadow:0 1px 3px #0000004d}.archives-list{list-style:none}.archives-list li{border-bottom:1px solid var(--border)}.archives-list li:first-child{border-top:1px solid var(--border)}.archives-list a{transition:opacity var(--transition);align-items:center;gap:1.5rem;padding:1rem 0;display:flex}.archives-list a:hover{opacity:.5}.archives-date{color:var(--muted);font-variant-numeric:tabular-nums;min-width:110px;font-size:.75rem}.archives-title{flex:1;font-size:.75rem;font-weight:500}.archives-sep{background:var(--border);flex-shrink:0;width:1px;height:12px}.archives-category{color:var(--muted);min-width:80px;font-size:.75rem}.archives-location{color:var(--muted);text-align:right;min-width:150px;font-size:.75rem}.categories-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:2rem;display:grid}.category-block h2{align-items:center;gap:.5rem;margin-bottom:.6rem;font-size:.85rem;font-weight:500;display:flex}.category-count{color:var(--muted);background:var(--border);border-radius:999px;padding:.1rem .45rem;font-size:.65rem;font-weight:400}.category-block ul{flex-direction:column;gap:.25rem;list-style:none;display:flex}.category-block a{color:var(--muted);transition:color var(--transition);font-size:.75rem}.category-block a:hover{color:var(--fg)}.changelog-entry{margin-bottom:3rem}.changelog-entry h2{letter-spacing:-.02em;margin-bottom:.5rem;font-size:1.4rem;font-weight:400}.changelog-entry h3{color:var(--muted);margin-bottom:1rem;font-size:1rem;font-weight:500}.changelog-entry ul{padding-left:0;list-style:none}.changelog-entry li{padding:.4rem 0 .4rem 1.2rem;line-height:1.6;position:relative}.changelog-entry li:before{content:"•";color:var(--muted);position:absolute;left:0}.footer{text-align:center;color:var(--muted);letter-spacing:.02em;padding:2.5rem;font-size:.7rem}.footer a{text-underline-offset:2px;text-decoration:underline}.footer a:hover{color:var(--fg)}@media (width<=768px){.header,main{width:90vw}.header{position:relative}.menu-toggle{display:block}.menu-overlay{z-index:999;background:#00000080;width:100%;height:100vh;display:block;position:fixed;top:0;left:0}.header nav{background:var(--bg);z-index:1000;flex-direction:column;align-items:flex-start;gap:0;width:70%;max-width:300px;height:100vh;padding:5rem 2rem 2rem;transition:right .3s;position:fixed;top:0;right:-100%;box-shadow:-2px 0 10px #0000001a}.header nav.nav-open{right:0}.header nav a{border-bottom:1px solid var(--border);width:100%;padding:1rem 0;font-size:.9rem}.header nav .theme-toggle{align-self:flex-start;margin-top:1rem}.hero{padding:4rem 0 3rem}.hero h1{font-size:1.8rem}.album-grid{gap:2.5rem}.album-card__overlay{opacity:1}.album-card__title{margin-bottom:1.5rem;font-size:1.8rem}.archives-list a{flex-direction:column;align-items:flex-start;gap:.4rem;padding:1.2rem 0}.archives-date{order:1;font-size:.7rem}.archives-title{order:2;margin-bottom:.2rem;font-size:.95rem}.archives-category{order:3;font-size:.7rem}.archives-location{text-align:left;order:4;font-size:.7rem}.archives-sep{display:none}.archives-header{margin-bottom:1rem}.archives-sort{flex-shrink:0}.map-container{display:none}.locations-list h2{margin-bottom:1rem}.locations-grid{grid-template-columns:1fr;gap:.8rem}.location-item{padding:1rem}}.search-trigger{cursor:pointer;opacity:.6;transition:opacity var(--transition);background:0 0;border:none;padding:0;font-size:1rem}.search-trigger:hover{opacity:1}.search-overlay{z-index:9998;background:#00000080;width:100%;height:100vh;position:fixed;top:0;left:0}.search-modal{background:var(--bg);border-radius:var(--radius);z-index:9999;flex-direction:column;width:90%;max-width:600px;max-height:70vh;display:flex;position:fixed;top:20%;left:50%;overflow:hidden;transform:translate(-50%);box-shadow:0 10px 40px #0003}.search-input-wrapper{border-bottom:1px solid var(--border);align-items:center;gap:.8rem;padding:1.2rem;display:flex}.search-icon{opacity:.5;font-size:1.2rem}.search-input{color:var(--fg);background:0 0;border:none;outline:none;flex:1;font-size:1rem}.search-kbd{border:1px solid var(--border);color:var(--muted);border-radius:3px;padding:.2rem .5rem;font-family:monospace;font-size:.7rem}.search-results{max-height:calc(70vh - 80px);overflow-y:auto}.search-result-item{border-bottom:1px solid var(--border);transition:background var(--transition);gap:1rem;padding:1rem;display:flex}.search-result-item:hover{background:var(--border)}.search-result-thumb{border-radius:var(--radius);flex-shrink:0;width:80px;height:60px;overflow:hidden}.search-result-thumb img{object-fit:cover;width:100%;height:100%}.search-result-info{flex:1}.search-result-title{margin-bottom:.3rem;font-size:.9rem;font-weight:500}.search-result-meta{color:var(--muted);font-size:.75rem}.search-no-results,.search-hint{text-align:center;color:var(--muted);padding:2rem;font-size:.85rem}.lightbox-overlay{z-index:10000;background:#000000f2;justify-content:center;align-items:center;width:100%;height:100vh;display:flex;position:fixed;top:0;left:0}.lightbox-content{max-width:90vw;max-height:90vh;position:relative}.lightbox-content img{object-fit:contain;max-width:100%;max-height:90vh;display:block}.lightbox-close{color:#fff;cursor:pointer;z-index:10001;background:#ffffff1a;border:none;border-radius:50%;width:50px;height:50px;font-size:2rem;transition:background .3s;position:fixed;top:2rem;right:2rem}.lightbox-close:hover{background:#fff3}.lightbox-nav{color:#fff;cursor:pointer;z-index:10001;background:#ffffff1a;border:none;border-radius:50%;width:60px;height:60px;font-size:3rem;transition:background .3s;position:fixed;top:50%;transform:translateY(-50%)}.lightbox-nav:hover:not(:disabled){background:#fff3}.lightbox-nav:disabled{opacity:.3;cursor:not-allowed}.lightbox-prev{left:2rem}.lightbox-next{right:2rem}.lightbox-counter{color:#fff;background:#00000080;border-radius:999px;padding:.5rem 1rem;font-size:.85rem;position:absolute;bottom:-3rem;left:50%;transform:translate(-50%)}.stories-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem;margin-top:2rem;display:grid}.story-card{border-radius:var(--radius);transition:transform var(--transition);display:block;overflow:hidden}.story-card:hover{transform:translateY(-4px)}.story-cover{aspect-ratio:16/9;width:100%;overflow:hidden}.story-cover img{object-fit:cover;width:100%;height:100%;transition:transform .6s}.story-card:hover .story-cover img{transform:scale(1.05)}.story-content{background:var(--border);padding:1.5rem}.story-category{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:.5rem;font-size:.7rem;display:block}.story-content h2{margin-bottom:.8rem;font-size:1.2rem;font-weight:400}.story-content p{color:var(--muted);margin-bottom:1rem;font-size:.85rem;line-height:1.6}.story-date{color:var(--muted);font-size:.75rem}.story-page{max-width:700px;margin:0 auto}.story-header{text-align:center;margin-bottom:2rem}.story-header h1{margin-bottom:1rem;font-size:2.5rem;font-weight:300}.story-meta{color:var(--muted);font-size:.85rem}.story-cover-large{border-radius:var(--radius);width:100%;margin-bottom:3rem;overflow:hidden}.story-cover-large img{width:100%;height:auto;display:block}.story-content-wrapper{color:var(--fg);font-size:1rem;line-height:1.8}.story-content-wrapper h2{margin:2rem 0 1rem;font-size:1.5rem;font-weight:400}.story-content-wrapper p{margin-bottom:1.5rem}.story-content-wrapper ul{margin:1.5rem 0;padding-left:1.5rem}.story-content-wrapper li{color:var(--muted);margin-bottom:.5rem}.story-cta{text-align:center;margin:3rem 0}.story-cta-button{border:1px solid var(--border);transition:all var(--transition);border-radius:999px;padding:.8rem 2rem;font-size:.85rem;display:inline-block}.story-cta-button:hover{background:var(--border)}.skeleton{pointer-events:none}.skeleton-title{background:linear-gradient(90deg, var(--border) 25%, var(--bg) 50%, var(--border) 75%);border-radius:var(--radius);background-size:200% 100%;width:60%;height:2rem;margin:0 auto 2rem;animation:1.5s infinite skeleton-loading}.skeleton-thumb{aspect-ratio:3/2;background:linear-gradient(90deg, var(--border) 25%, var(--bg) 50%, var(--border) 75%);border-radius:var(--radius);background-size:200% 100%;width:100%;animation:1.5s infinite skeleton-loading}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.pull-to-refresh{background:var(--fg);color:var(--bg);border-radius:0 0 var(--radius) var(--radius);z-index:100;padding:.5rem 1rem;font-size:.75rem;transition:transform .3s;position:fixed;top:0;left:50%;transform:translate(-50%)}@media (width<=768px){.search-modal{width:95%;top:10%}.lightbox-close{width:40px;height:40px;font-size:1.5rem;top:1rem;right:1rem}.lightbox-nav{width:50px;height:50px;font-size:2rem}.lightbox-prev{left:1rem}.lightbox-next{right:1rem}.stories-grid{grid-template-columns:1fr}.story-header h1{font-size:1.8rem}}.beta-badge{background:var(--fg);color:var(--bg);text-transform:uppercase;letter-spacing:.08em;border-radius:999px;padding:.25rem .6rem;font-size:.65rem;font-weight:500;display:inline-block}.beta-notice-full{border-radius:var(--radius);color:var(--muted);text-align:center;background:#ffa5001a;border:1px solid #ffa5004d;width:100%;margin-bottom:2rem;padding:1rem 1.5rem;font-size:.85rem}[data-theme=dark] .beta-notice-full{background:#ffa5000d;border-color:#ffa50033}
