@import"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;overflow:hidden}.hero-bg{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden}.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;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,#0505058c,#050505c7 55%,#050505e6),radial-gradient(circle at 50% 38%,#ffffff1a,#0000 55%)}@keyframes heroDrift{0%{transform:scale(1.06) translateY(-1.5%)}to{transform:scale(1.06) translateY(1.5%)}}.hero-title{position:relative;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,#f9a8d4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:1rem;opacity:0;animation:fadeUp 1s ease-out .3s forwards}.hero-subtitle{position:relative;font-size:clamp(.9rem,2vw,1.2rem);font-weight:300;color:#ffffff80;letter-spacing:.3em;text-transform:uppercase;text-align:center;opacity:0;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:#ffffff59;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:#ffffff4d}.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,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,#ffffff0a,#ffffff04),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:#ffffff73}.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:#ffffffc7;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:#ffffff59;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:#0f0f19f2;-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 #00000080}.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:#fff6;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:#ffffff0a;border:1px solid rgba(255,255,255,.08);color:#ffffff80;font-size:.75rem;cursor:pointer;transition:all .2s ease;letter-spacing:.05em;font-family:inherit}.filter-pill:hover{background:#ffffff14;color:#fffc}.filter-pill.active{background:#ffffff1f;color:#fff;border-color:#fff3}.countries-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}.country-card{position:relative;border-radius:16px;overflow:hidden;cursor:pointer;aspect-ratio:4/3}.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;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.1) 50%,transparent 100%);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:#ffffff80;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:#ffffff73;letter-spacing:.04em}.country-card-years-value{margin-top:.2rem;font-size:.82rem;color:#ffffffdb;line-height:1.25}.country-card-count{font-size:.75rem;color:#fff6;margin-top:.5rem;display:flex;align-items:center;gap:.4rem}.gallery-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#000000f5;-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);overflow-y:auto;animation:modalIn .4s ease-out}.gallery-header{position:sticky;top:0;z-index:10;display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;background:linear-gradient(to bottom,rgba(0,0,0,.8),transparent)}.gallery-title{font-family:Playfair Display,serif;font-size:1.8rem;font-weight:700;color:#fff}.gallery-subtitle{font-size:.85rem;color:#fff6}.gallery-close{width:44px;height:44px;border-radius:50%;background:#ffffff14;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:#ffffff26;transform:rotate(90deg)}.gallery-grid{max-width:1400px;margin:0 auto;padding:1rem 2rem 4rem;columns:3 280px;column-gap:1rem}.gallery-item{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(to top,rgba(0,0,0,.7),transparent);font-size:.85rem;color:#fffc;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:#fffffff2;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:#ffffffd1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;background:#000000fa;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 #00000080}.lightbox-close{position:absolute;top:1.5rem;right:1.5rem;width:44px;height:44px;border-radius:50%;background:#ffffff1a;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:#fff3}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:#ffffff14;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:#ffffff26}.lightbox-nav.prev{left:.75rem}.lightbox-nav.next{right:.75rem}.lightbox-caption{position:relative;font-size:.9rem;color:#ffffffd9;text-align:left;background:#0009;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:#ffffffdb}.lightbox-caption-date{margin-top:.5rem;font-size:.75rem;color:#ffffffb8;padding-top:.45rem;text-align:right}.footer{text-align:center;padding:3rem 2rem;border-top:1px solid rgba(255,255,255,.05);color:#fff3;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{columns: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}}
