@import "https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;600;700&family=DM+Serif+Display:ital@0;1&display=swap";
:root{--color-primary:#2563b4;--color-primary-dark:#1e50a2;--color-primary-light:#dbeafe;--color-accent:#0ea5a0;--color-accent-dark:#0c8f8a;--color-accent-light:#ccfbf1;--color-white:#fff;--color-surface:#f8fafc;--color-surface-2:#f1f5f9;--color-border:#e2e8f0;--color-border-light:#f1f5f9;--color-text-primary:#1a2535;--color-text-secondary:#64748b;--color-text-muted:#94a3b8;--color-text-invert:#fff;--color-badge-photo:#2563b4;--color-badge-guide:#0ea5a0;--color-badge-both:#7c3aed;--color-star:#f59e0b;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:40px;--space-2xl:64px;--space-3xl:96px;--font-body:"Noto Sans JP", sans-serif;--font-display:"DM Serif Display", serif;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--text-5xl:3rem;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow-md:0 4px 16px #00000014, 0 2px 6px #0000000a;--shadow-lg:0 12px 40px #0000001a, 0 4px 12px #0000000f;--shadow-xl:0 24px 64px #0000001f;--radius-sm:6px;--radius-md:12px;--radius-lg:20px;--radius-xl:28px;--radius-full:9999px;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease;--container-max:1280px;--header-height:72px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-body);color:var(--color-text-primary);background-color:var(--color-white);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.7}img{object-fit:cover;max-width:100%;display:block}a{color:inherit;text-decoration:none}ul,ol{list-style:none}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}.container{width:100%;max-width:var(--container-max);padding:0 var(--space-lg);margin:0 auto}@media (min-width:768px){.container{padding:0 var(--space-xl)}}.section{padding:var(--space-3xl) 0}.section-sm{padding:var(--space-2xl) 0}.section-header{text-align:center;margin-bottom:var(--space-2xl)}.section-label{font-size:var(--text-xs);letter-spacing:.12em;text-transform:uppercase;color:var(--color-accent);background:var(--color-accent-light);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);margin-bottom:var(--space-md);font-weight:600;display:inline-block}.section-title{font-family:var(--font-display);font-size:var(--text-3xl);color:var(--color-text-primary);margin-bottom:var(--space-md);line-height:1.3}.section-title span{color:var(--color-primary)}.section-desc{font-size:var(--text-lg);color:var(--color-text-secondary);max-width:600px;margin:0 auto;line-height:1.8}.btn{align-items:center;gap:var(--space-sm);border-radius:var(--radius-full);font-size:var(--text-base);transition:all var(--transition-base);white-space:nowrap;border:2px solid #0000;padding:14px 28px;font-weight:600;text-decoration:none;display:inline-flex}.btn-primary{background:var(--color-primary);color:var(--color-text-invert);border-color:var(--color-primary)}.btn-primary:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark);transform:translateY(-2px);box-shadow:0 8px 24px #2563b459}.btn-accent{background:var(--color-accent);color:var(--color-text-invert);border-color:var(--color-accent)}.btn-accent:hover{background:var(--color-accent-dark);border-color:var(--color-accent-dark);transform:translateY(-2px);box-shadow:0 8px 24px #0ea5a059}.btn-outline{color:var(--color-primary);border-color:var(--color-primary);background:0 0}.btn-outline:hover{background:var(--color-primary);color:var(--color-text-invert);transform:translateY(-2px)}.btn-outline-white{color:var(--color-white);background:0 0;border-color:#fff9}.btn-outline-white:hover{border-color:var(--color-white);background:#ffffff26}.btn-sm{font-size:var(--text-sm);padding:10px 20px}.btn-lg{font-size:var(--text-lg);padding:18px 36px}.badge{border-radius:var(--radius-full);font-size:var(--text-xs);letter-spacing:.02em;align-items:center;gap:4px;padding:4px 10px;font-weight:600;display:inline-flex}.badge-photo{color:var(--color-badge-photo);background:#2563b41a}.badge-guide{color:var(--color-badge-guide);background:#0ea5a01a}.badge-both{color:var(--color-badge-both);background:#7c3aed1a}.badge-kimono{color:#db2777;background:#db27771a}.badge-video{color:#ea580c;background:#ea580c1a}.badge-cosplay{color:#a855f7;background:#a855f71a}.badge-rickshaw{color:#dc2626;background:#dc26261a}.badge-other{color:#6b7280;background:#6b72801a}.tag{border-radius:var(--radius-full);font-size:var(--text-xs);background:var(--color-surface-2);color:var(--color-text-secondary);border:1px solid var(--color-border);padding:4px 12px;font-weight:500;display:inline-block}.stars{color:var(--color-star);align-items:center;gap:2px;display:flex}.stars span{font-size:14px}.stars .rating-text{margin-left:var(--space-xs);font-size:var(--text-sm);color:var(--color-text-secondary);font-weight:500}.site-header{height:var(--header-height);z-index:1000;-webkit-backdrop-filter:blur(12px);transition:border-color var(--transition-base), background var(--transition-base), box-shadow var(--transition-base);background:#ffffffeb;border-bottom:1px solid #0000;position:fixed;top:0;left:0;right:0}.site-header.scrolled{border-bottom-color:var(--color-border);box-shadow:var(--shadow-sm);background:#fffffffa}.header-inner{align-items:center;gap:var(--space-xl);height:100%;display:flex}.header-logo{align-items:center;gap:var(--space-sm);flex-shrink:0;text-decoration:none;display:flex}.logo-icon{background:linear-gradient(135deg, var(--color-primary), var(--color-accent));border-radius:var(--radius-sm);justify-content:center;align-items:center;width:36px;height:36px;display:flex}.logo-icon svg{fill:#fff;width:20px;height:20px}.logo-text{flex-direction:column;line-height:1.1;display:flex}.logo-text-ja{font-size:var(--text-base);color:var(--color-text-primary);letter-spacing:-.02em;font-weight:700}.logo-text-en{color:var(--color-text-muted);letter-spacing:.08em;text-transform:uppercase;font-size:10px;font-weight:500}.header-nav{flex:1;align-items:center;gap:4px;display:none}@media (min-width:1024px){.header-nav{display:flex}}.nav-link{font-size:var(--text-sm);color:var(--color-text-secondary);border-radius:var(--radius-sm);transition:color var(--transition-fast), background var(--transition-fast);padding:8px 14px;font-weight:500;text-decoration:none}.nav-link:hover,.nav-link.active{color:var(--color-primary);background:var(--color-primary-light)}.header-actions{align-items:center;gap:var(--space-sm);margin-left:auto;display:flex}.header-login{font-size:var(--text-sm);color:var(--color-text-secondary);border:1.5px solid var(--color-border);border-radius:var(--radius-full);transition:all var(--transition-fast);padding:8px 18px;font-weight:600;text-decoration:none;display:none}.header-login:hover{color:var(--color-primary);border-color:var(--color-primary)}@media (min-width:640px){.header-login{align-items:center;display:inline-flex}}.hamburger{background:0 0;border:none;flex-direction:column;justify-content:center;gap:5px;width:32px;height:32px;padding:4px;display:flex}.hamburger span{background:var(--color-text-primary);height:2px;transition:all var(--transition-base);border-radius:2px;display:block}.hamburger.active span:first-child{transform:translateY(7px)rotate(45deg)}.hamburger.active span:nth-child(2){opacity:0;transform:scaleX(0)}.hamburger.active span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}@media (min-width:1024px){.hamburger{display:none}}.mobile-menu{top:var(--header-height);background:var(--color-white);border-bottom:1px solid var(--color-border);padding:var(--space-md) 0;opacity:0;transition:transform var(--transition-base), opacity var(--transition-base);z-index:999;box-shadow:var(--shadow-md);position:fixed;left:0;right:0;transform:translateY(-110%)}.mobile-menu.open{opacity:1;transform:translateY(0)}.mobile-menu-nav{padding:0 var(--space-lg);flex-direction:column;gap:4px;display:flex}.mobile-nav-link{font-size:var(--text-base);color:var(--color-text-secondary);border-radius:var(--radius-sm);transition:all var(--transition-fast);padding:12px 16px;font-weight:500;display:block}.mobile-nav-link:hover{color:var(--color-primary);background:var(--color-primary-light)}.mobile-menu-btns{gap:var(--space-sm);padding:var(--space-md) var(--space-lg) var(--space-sm);border-top:1px solid var(--color-border);margin-top:var(--space-sm);display:flex}.mobile-menu-btns .btn{flex:1;justify-content:center}.site-footer{background:var(--color-text-primary);color:#ffffffb3;padding:var(--space-3xl) 0 0}.footer-grid{gap:var(--space-2xl);margin-bottom:var(--space-2xl);grid-template-columns:1fr;display:grid}@media (min-width:640px){.footer-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr}}.footer-brand .logo-text-ja{color:#fff}.footer-brand .logo-text-en{color:#fff6}.footer-brand-desc{margin-top:var(--space-md);font-size:var(--text-sm);color:#ffffff8c;max-width:280px;line-height:1.8}.footer-heading{font-size:var(--text-sm);color:#fff;letter-spacing:.06em;margin-bottom:var(--space-md);font-weight:700}.footer-links{flex-direction:column;gap:10px;display:flex}.footer-link{font-size:var(--text-sm);color:#ffffff8c;transition:color var(--transition-fast);text-decoration:none}.footer-link:hover{color:#fff}.footer-bottom{padding:var(--space-lg) 0;align-items:center;gap:var(--space-md);text-align:center;border-top:1px solid #ffffff1a;flex-direction:column;display:flex}@media (min-width:768px){.footer-bottom{text-align:left;flex-direction:row;justify-content:space-between}}.footer-copy{font-size:var(--text-xs);color:#ffffff59}.footer-bottom-links{gap:var(--space-lg);flex-wrap:wrap;justify-content:center;display:flex}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.hidden{display:none}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}.breadcrumb{align-items:center;gap:var(--space-sm);font-size:var(--text-sm);color:var(--color-text-muted);display:flex}.breadcrumb a{color:var(--color-primary);text-decoration:none}.breadcrumb a:hover{text-decoration:underline}.breadcrumb-sep{color:var(--color-border)}.page-hero{background:linear-gradient(135deg, var(--color-surface) 0%, var(--color-primary-light) 100%);padding:calc(var(--header-height) + var(--space-2xl)) 0 var(--space-2xl)}.page-hero-title{font-family:var(--font-display);font-size:var(--text-4xl);color:var(--color-text-primary);margin-bottom:var(--space-sm)}.page-hero-desc{font-size:var(--text-lg);color:var(--color-text-secondary)}.spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.animate-fade-in-up{animation:.6s both fadeInUp}.reveal{opacity:0;transition:opacity .6s,transform .6s;transform:translateY(24px)}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}.reveal-delay-4{transition-delay:.4s}.reveal-delay-5{transition-delay:.5s}
