@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Playfair+Display:ital,wght@0,400;0,700;1,400&display=swap");*{margin:0;padding:0;box-sizing:border-box}body{background:#050505;color:#e8e8e8;font-family:Inter,-apple-system,sans-serif;overflow-x:hidden}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#111}::-webkit-scrollbar-thumb{background:#333;border-radius:3px}@keyframes fadeUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes galleryIn{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes modalIn{0%{opacity:0}to{opacity:1}}@keyframes scrollPulse{0%,to{opacity:.3;transform:scaleY(.5)}50%{opacity:1;transform:scaleY(1)}}.app{min-height:100vh}.hero{position:relative;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center}.hero,.hero-bg{overflow:hidden}.hero-bg{position:absolute;inset:0}.hero-bg-image{position:absolute;width:100%;height:100%;object-fit:cover;opacity:.46;filter:saturate(.92) contrast(1.05);animation:heroDrift 40s linear infinite alternate}.hero-bg-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,5,5,.55) 0,rgba(5,5,5,.78) 55%,rgba(5,5,5,.9)),radial-gradient(circle at 50% 38%,rgba(255,255,255,.1),rgba(0,0,0,0) 55%)}@keyframes heroDrift{0%{transform:scale(1.06) translateY(-1.5%)}to{transform:scale(1.06) translateY(1.5%)}}.hero-title{font-family:Playfair Display,serif;font-size:clamp(2.5rem,6vw,5.5rem);font-weight:700;text-align:center;letter-spacing:-.02em;background:linear-gradient(135deg,#fff,#a5b4fc 50%,#f9a8d4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:1rem;animation:fadeUp 1s ease-out .3s forwards}.hero-subtitle,.hero-title{position:relative;opacity:0}.hero-subtitle{font-size:clamp(.9rem,2vw,1.2rem);font-weight:300;color:rgba(255,255,255,.5);letter-spacing:.3em;text-transform:uppercase;text-align:center;animation:fadeUp 1s ease-out .6s forwards}.hero-stats{position:relative;display:flex;gap:3rem;margin-top:2.5rem;opacity:0;animation:fadeUp 1s ease-out .9s forwards}.stat{text-align:center}.stat-number{font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,#c4b5fd,#f9a8d4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.2em;color:rgba(255,255,255,.35);margin-top:.25rem}.scroll-indicator{position:absolute;bottom:2rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;opacity:0;animation:fadeUp 1s ease-out 1.2s forwards}.scroll-indicator span{font-size:.65rem;text-transform:uppercase;letter-spacing:.2em;color:rgba(255,255,255,.3)}.scroll-line{width:1px;height:40px;background:linear-gradient(180deg,rgba(255,255,255,.4),transparent);animation:scrollPulse 2s ease-in-out infinite}.intro-section{padding:2.2rem 1.2rem .8rem}.intro-card{max-width:980px;margin:0 auto;border:1px solid rgba(255,255,255,.08);background:linear-gradient(135deg,rgba(255,255,255,.04),rgba(255,255,255,.015)),radial-gradient(circle at 15% 15%,rgba(80,140,255,.15),transparent 40%);border-radius:18px;padding:1.3rem 1.35rem}.intro-kicker{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.45)}.intro-title{margin-top:.5rem;font-family:Playfair Display,serif;font-size:clamp(1.2rem,2.5vw,1.8rem);color:#fff}.intro-text{margin-top:.55rem;line-height:1.7;color:rgba(255,255,255,.78);font-size:.92rem}.map-section{position:relative;padding:4rem 0}.section-header{text-align:center;margin-bottom:3rem;padding:0 2rem}.section-tag{font-size:.7rem;text-transform:uppercase;letter-spacing:.3em;color:rgba(255,255,255,.35);margin-bottom:.75rem}.section-title{font-family:Playfair Display,serif;font-size:clamp(1.8rem,3.5vw,3rem);font-weight:700;color:#fff}.map-container{max-width:1200px;margin:0 auto;padding:0 1rem}.map-wrapper{position:relative;background:radial-gradient(ellipse at center,rgba(99,102,241,.03) 0,transparent 70%);border-radius:1.5rem;overflow:hidden;border:1px solid rgba(255,255,255,.04)}.map-svg{width:100%;display:block}.dot-marker{cursor:pointer}.tooltip{position:fixed;pointer-events:none;z-index:100;background:rgba(15,15,25,.95);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:12px 16px;display:flex;align-items:center;gap:12px;box-shadow:0 20px 60px rgba(0,0,0,.5)}.tooltip-thumb{width:48px;height:48px;border-radius:8px;object-fit:cover}.tooltip-name{font-weight:600;font-size:.9rem;color:#fff}.tooltip-count{font-size:.75rem;color:rgba(255,255,255,.4);margin-top:2px}.countries-section{max-width:1200px;margin:0 auto;padding:4rem 1.5rem}.filter-bar{display:flex;justify-content:center;flex-wrap:wrap;gap:.5rem;margin-bottom:2.5rem}.filter-pill{padding:.4rem 1rem;border-radius:100px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);color:rgba(255,255,255,.5);font-size:.75rem;cursor:pointer;transition:all .2s ease;letter-spacing:.05em;font-family:inherit}.filter-pill:hover{background:rgba(255,255,255,.08);color:rgba(255,255,255,.8)}.filter-pill.active{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.2)}.countries-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:1.25rem;gap:1.25rem}.country-card{position:relative;border-radius:16px;overflow:hidden;cursor:pointer;aspect-ratio:4/3;display:block;text-decoration:none;color:inherit}.country-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.25,.46,.45,.94)}.country-card:hover img{transform:scale(1.08)}.country-card-overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.85) 0,rgba(0,0,0,.1) 50%,transparent);display:flex;flex-direction:column;justify-content:flex-end;padding:1.5rem}.country-card-accent{width:24px;height:3px;border-radius:2px;margin-bottom:.75rem;transition:width .3s ease}.country-card:hover .country-card-accent{width:40px}.country-card-name{font-family:Playfair Display,serif;font-size:1.5rem;font-weight:700;color:#fff}.country-card-name-ja{font-size:.8rem;color:rgba(255,255,255,.5);margin-top:.15rem}.country-card-meta{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem}.country-card-years{text-align:right;max-width:45%}.country-card-years-label{font-size:.68rem;color:rgba(255,255,255,.45);letter-spacing:.04em}.country-card-years-value{margin-top:.2rem;font-size:.82rem;color:rgba(255,255,255,.86);line-height:1.25}.country-card-count{font-size:.75rem;color:rgba(255,255,255,.4);margin-top:.5rem;display:flex;align-items:center;gap:.4rem}.scroll-top-btn{position:fixed;bottom:2rem;right:2rem;z-index:900;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);opacity:0;pointer-events:none;transform:translateY(10px);transition:all .3s ease}.scroll-top-btn.visible{opacity:1;pointer-events:auto;transform:translateY(0)}.scroll-top-btn:hover{background:rgba(255,255,255,.15)}.gallery-overlay{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.96);-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);overflow-y:auto;animation:modalIn .4s ease-out}.gallery-header{position:-webkit-sticky;position:sticky;top:0;z-index:10;display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;background:linear-gradient(180deg,rgba(0,0,0,.8),transparent)}.gallery-header-left{display:flex;align-items:center;gap:1rem}.gallery-back{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.gallery-back:hover{background:rgba(255,255,255,.15)}.gallery-title{font-family:Playfair Display,serif;font-size:1.8rem;font-weight:700;color:#fff}.gallery-subtitle{font-size:.85rem;color:rgba(255,255,255,.4)}.gallery-close{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);color:#fff;font-size:1.3rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.gallery-close:hover{background:rgba(255,255,255,.15);transform:rotate(90deg)}.gallery-grid{max-width:1400px;margin:0 auto;padding:1rem 2rem 4rem;columns:280px 3;column-gap:1rem}.gallery-item{page-break-inside:avoid;break-inside:avoid;margin-bottom:1rem;border-radius:12px;overflow:hidden;cursor:pointer;position:relative;animation:galleryIn .5s ease-out backwards}.gallery-item img{width:100%;display:block;transition:transform .5s ease}.gallery-item:hover img{transform:scale(1.04)}.gallery-item-caption{position:absolute;bottom:0;left:0;right:0;padding:2rem 1rem 1rem;background:linear-gradient(0deg,rgba(0,0,0,.7),transparent);font-size:.85rem;color:rgba(255,255,255,.8);opacity:0;transform:translateY(4px);transition:all .3s ease}.gallery-item:hover .gallery-item-caption{opacity:1;transform:translateY(0)}.gallery-item-caption-title{font-weight:600;color:rgba(255,255,255,.95);text-shadow:0 1px 8px rgba(0,0,0,.55)}.gallery-item-caption-detail{margin-top:.35rem;font-size:.75rem;line-height:1.35;color:rgba(255,255,255,.82);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.lightbox{position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.98);display:flex;align-items:center;justify-content:center;animation:modalIn .3s ease-out;padding:1.5rem}.lightbox-content{width:min(1200px,94vw);max-height:92vh;display:flex;flex-direction:column;gap:.85rem}.lightbox-media{position:relative;min-height:0;display:flex;align-items:center;justify-content:center}.lightbox-media>img{max-width:100%;max-height:min(76vh,calc(92vh - 180px));object-fit:contain;border-radius:8px;box-shadow:0 0 80px rgba(0,0,0,.5)}.lightbox-close{position:absolute;top:1.5rem;right:1.5rem;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.1);border:none;color:#fff;font-size:1.3rem;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:30}.lightbox-close:hover{background:rgba(255,255,255,.2)}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);color:#fff;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.lightbox-nav:hover{background:rgba(255,255,255,.15)}.lightbox-nav.prev{left:.75rem}.lightbox-nav.next{right:.75rem}.lightbox-caption{position:relative;font-size:.9rem;color:rgba(255,255,255,.85);text-align:left;background:rgba(0,0,0,.6);padding:.9rem 1.1rem;border-radius:14px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:100%;max-height:22vh;overflow:auto}.lightbox-caption-title{font-weight:600;color:#fff}.lightbox-caption-detail{margin-top:.35rem;font-size:.78rem;line-height:1.45;color:rgba(255,255,255,.86)}.lightbox-caption-date{margin-top:.5rem;font-size:.75rem;color:rgba(255,255,255,.72);padding-top:.45rem;text-align:right}.dest-hero{position:relative;height:60vh;min-height:340px;flex-direction:column;overflow:hidden}.dest-back,.dest-hero{display:flex;align-items:center;justify-content:center}.dest-back{position:absolute;top:1.5rem;left:1.5rem;z-index:10;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);color:#fff;text-decoration:none;transition:all .2s ease}.dest-back:hover{background:rgba(255,255,255,.15)}.dest-hero-map{position:relative;width:min(360px,80vw);margin-top:1.5rem;opacity:0;animation:fadeUp 1s ease-out .6s forwards}.dest-hero-map .dest-map-wrapper{border-radius:1rem}.dest-gallery-section{max-width:1400px;margin:0 auto;padding:2rem 2rem 4rem}.dest-gallery-section .gallery-grid{columns:280px 3;column-gap:1rem}.dest-nav-section{max-width:1200px;margin:0 auto;padding:2rem 1.5rem 1rem}.dest-nav-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-gap:1rem;gap:1rem}.dest-nav-card{position:relative;border-radius:12px;overflow:hidden;aspect-ratio:3/2;display:block;text-decoration:none;color:inherit}.dest-nav-card img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.dest-nav-card:hover img{transform:scale(1.06)}.dest-nav-card-overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.8) 0,rgba(0,0,0,.05) 60%,transparent);display:flex;flex-direction:column;justify-content:flex-end;padding:1rem}.dest-nav-card-accent{width:18px;height:2px;border-radius:2px;margin-bottom:.5rem;transition:width .3s ease}.dest-nav-card:hover .dest-nav-card-accent{width:30px}.dest-nav-card-name{font-family:Playfair Display,serif;font-size:1rem;font-weight:700;color:#fff}.dest-nav-card-name-ja{font-size:.7rem;color:rgba(255,255,255,.5);margin-top:.1rem}.dest-footer-link{color:rgba(255,255,255,.2);text-decoration:none;font-size:.75rem;letter-spacing:.1em;transition:color .2s ease}.dest-footer-link:hover{color:rgba(255,255,255,.5)}.footer{text-align:center;padding:3rem 2rem;border-top:1px solid rgba(255,255,255,.05);color:rgba(255,255,255,.2);font-size:.75rem;letter-spacing:.1em}@media (max-width:600px){.hero-stats{gap:1.5rem}.stat-number{font-size:1.8rem}.countries-grid{grid-template-columns:1fr}.gallery-grid{column-count:1}.intro-section{padding:1.7rem .8rem .4rem}.intro-card{padding:1rem;border-radius:14px}.lightbox{padding:1rem .7rem}.lightbox-content{width:100%;max-height:94vh;gap:.65rem}.lightbox-media>img{max-height:min(68vh,calc(94vh - 190px))}.lightbox-caption{max-height:24vh}.lightbox-nav.prev{left:.45rem}.lightbox-nav.next{right:.45rem}}